function mapClickSim(m,i){$('#contentMapModal_'+m).modal('show');function w(){if(window.contentMaps[m]!==undefined&&typeof toggleMapIconClick==="function"&&typeof resetMarkersAndCards==="function"){resetMarkersAndCards(m);toggleMapIconClick(m,i);}else{setTimeout(w,100);}} w();} function handleActionClick(e){const target=e.target.closest('[data-action]');if(!target)return;const{action,actionArgs}=target.dataset;const fn={mapClickSim}[action];fn&&fn(...actionArgs.split(',').map(Number));} if(document.readyState==='loading'){document.addEventListener('DOMContentLoaded',()=>{document.querySelectorAll('[data-action]').forEach(b=>b.addEventListener('click',handleActionClick));});}else{document.querySelectorAll('[data-action]').forEach(b=>b.addEventListener('click',handleActionClick));}if(typeof window.contentMaps==='undefined'){window.contentMaps={};window.initialMapBounds={};} if(typeof window.bounds==='undefined'){window.bounds={};} if(typeof window.markerData==='undefined'){window.markerData={};} if(!markerData[1]){markerData[1]={};} function initMapbox_1(){mapboxgl.accessToken='pk.eyJ1IjoibGF6eXRyaXBzIiwiYSI6ImNsaTJ4anh2MTA5NDYzZW85ODJmMm45ZzcifQ.9u5pN47V7SsoFwF6_Pw5bQ';const contentMap_1=new mapboxgl.Map({container:'contentMap_1',style:'mapbox://styles/mapbox/streets-v11',center:[-111.899906,40.760370],zoom:5,cooperativeGestures:false});window.contentMaps[1]=contentMap_1;if(typeof window.bounds[1]==='undefined'){window.bounds[1]=new mapboxgl.LngLatBounds();} markerData[1][0]={"lonLat":["-111.899906","40.760370"],"type":"star-plain"};markerData[1][1]={"lonLat":["-110.958018","44.659589"],"best":"1","time":"270","distance":320,"type":"numbered","onClick":true,"route":{"id":"757","color":"#fa5050"},"card":{"title":"Yellowstone National Park","distanceTime":"\ud83d\ude97 320 miles \u23f1\ufe0f 4 hours, 30 minutes","photoCode":"\"Geyser","oX":175,"oY":0},"cardLink":"\/trip\/road-trip-from-salt-lake-city-to-yellowstone-national-park","cardLinkText":"Read more"};function getNewLngLat(map,originalLngLat,offsets){var pixel=map.project(new mapboxgl.LngLat(originalLngLat[0],originalLngLat[1]));pixel.x+=offsets.x;pixel.y+=offsets.y;return map.unproject(pixel);} Object.keys(contentMaps).forEach(function(mapNum){contentMaps[mapNum].on('zoom',function(){Object.keys(markerData[mapNum]).forEach(function(iconNum){var marker=markerData[mapNum][iconNum];if(!isMobileDevice()&&marker.cardInstance){var offsets={x:marker.card.oX,y:marker.card.oY};var newLngLat=getNewLngLat(contentMaps[mapNum],marker.lonLat,offsets);marker.cardInstance.setLngLat([newLngLat.lng,newLngLat.lat]);}});});});async function fetchRoute(d,m,i,c){const p={routeId:d};const r=await fetch('/api/request-route',{method:'POST',headers:{'Content-Type':'application/json'},body:JSON.stringify(p)});if(r.ok){const data=await r.json();if(data.response&&data.response.route){const d=JSON.parse(data.response.route);markerData[m][i].routeJson=d;updateMapWithRoute(m,i,d,c);}}} function updateMapWithRoute(m,i,r,c){const l='iconRoute_'+m+'_'+i;const g={type:'Feature',properties:{},geometry:{type:'LineString',coordinates:r}};if(contentMaps[m].getLayer(l)){contentMaps[m].setLayoutProperty(l,'visibility','visible');contentMaps[m].getSource(l).setData(g);}else{contentMaps[m].addLayer({id:l,type:'line',source:{type:'geojson',data:g},layout:{'line-join':'round','line-cap':'round'},paint:{'line-color':c,'line-width':5,'line-opacity':0.8}});}} function hideRouteLayer(m,i){const l='iconRoute_'+m+'_'+i;if(contentMaps[m].getLayer(l)){contentMaps[m].setLayoutProperty(l,'visibility','none');}} window.toggleMapIconClick=function(m,iconNum){if(markerData[m][iconNum].a){return;} for(const[key,icon]of Object.entries(markerData[m])){if(parseInt(key)===iconNum){continue;} if(icon.popupInstance){icon.popupInstance.remove();delete icon.popupInstance;} if(icon.route&&contentMaps[m].getLayer('iconRoute_'+m+'_'+key)){hideRouteLayer(m,key);} if(icon.marker){icon.marker.getElement().classList.remove('markerSpanSelect');} if(icon.cardInstance){icon.cardInstance.remove();delete icon.cardInstance;} if(icon.cardOverlay){var overlayToRemove=icon.cardOverlay;if(overlayToRemove&&overlayToRemove.parentNode){overlayToRemove.parentNode.removeChild(overlayToRemove);delete icon.cardOverlay;}} icon.a=false;} if(!markerData[m][iconNum].a){markerData[m][iconNum].marker.getElement().classList.add('markerSpanSelect');if(markerData[m][iconNum].popup){const t=markerData[m][iconNum].popup.title;const p=markerData[m][iconNum].popup.text;let popupHTML='
';if(t){popupHTML+='

'+t+'

';} if(p){popupHTML+='

'+p+'

';} popupHTML+='
';var popup=new mapboxgl.Popup({anchor:'bottom',closeButton:false,closeOnClick:false,className:'pointer'}).setLngLat(markerData[m][iconNum].lonLat).setHTML(popupHTML).addTo(contentMaps[m]);markerData[m][iconNum].popupInstance=popup;popup._content.addEventListener('click',function(){toggleMapIconClick(m,iconNum);});markerData[m][iconNum].marker.getElement().style.display='none';} if(markerData[m][iconNum].route){const layerId='iconRoute_'+m+'_'+iconNum;if(contentMaps[m].getLayer(layerId)){contentMaps[m].setLayoutProperty(layerId,'visibility','visible');}else{fetchRoute(markerData[m][iconNum].route.id,m,iconNum,markerData[m][iconNum].route.color);}} if(markerData[m][iconNum].card){var cardContent={cardTitle:markerData[m][iconNum].card.title,cardDistanceTime:markerData[m][iconNum].card.distanceTime,photoCode:markerData[m][iconNum].card.photoCode,};if(markerData[m][iconNum].hasOwnProperty('cardLink')){cardContent.cardLink=markerData[m][iconNum].cardLink;} if(markerData[m][iconNum].hasOwnProperty('cardLinkText')){cardContent.cardLinkText=markerData[m][iconNum].cardLinkText;} if(!isMobileDevice()){var cardContentHtml=createCardContentHtml(cardContent,false);var offsets={x:markerData[m][iconNum].card.oX,y:markerData[m][iconNum].card.oY};var newLngLat=getNewLngLat(contentMaps[m],markerData[m][iconNum]['lonLat'],offsets);var cardPopup=new mapboxgl.Popup({anchor:'bottom',closeButton:false,closeOnClick:false,className:'mapPopupCard'}).setHTML(cardContentHtml).setLngLat([newLngLat.lng,newLngLat.lat]).addTo(contentMaps[m]);markerData[m][iconNum].cardInstance=cardPopup;}else{var cardMobile=document.createElement('div');cardMobile.className='mapPopupCardMobile';cardMobile.innerHTML=createCardContentHtml(cardContent,true);var mapContainer=contentMaps[m].getContainer();mapContainer.appendChild(cardMobile);markerData[m][iconNum].cardOverlay=cardMobile;}} markerData[m][iconNum].a=true;updateMapBounds(m,iconNum);}else{resetMarkersAndCards(m);}} window.resetMarkersAndCards=function(m){Object.keys(markerData[m]).forEach((i)=>{if(markerData[m][i].marker){markerData[m][i].marker.getElement().classList.remove('markerSpanSelect');} if(markerData[m][i].popupInstance){markerData[m][i].popupInstance.remove();delete markerData[m][i].popupInstance;} if(markerData[m][i].route){if(contentMaps[m].getLayer('iconRoute_'+m+'_'+i)){hideRouteLayer(m,i);}} if(markerData[m][i].card){if(markerData[m][i].cardInstance){markerData[m][i].cardInstance.remove();delete markerData[m][i].cardInstance;}} if(markerData[m][i].cardOverlay){var overlayToRemove=markerData[m][i].cardOverlay;if(overlayToRemove&&overlayToRemove.parentNode){overlayToRemove.parentNode.removeChild(overlayToRemove);delete markerData[m][i].cardOverlay;}} markerData[m][i].marker.getElement().style.display='block';markerData[m][i].a=false;if(markerData[m][i].best){updateMapBounds(m,i);}});} function createCardContentHtml(c,m){let htmlContent='
';if(c.photoCode){htmlContent+='
'+c.photoCode+'
';} if(c.cardTitle||c.cardDistanceTime||c.cardLink){htmlContent+='
';if(c.cardTitle){htmlContent+='
'+c.cardTitle+'
';} if(c.cardDistanceTime){if(m){const parts=c.cardDistanceTime.split('⏱️');htmlContent+='
'+parts[0].trim()+'
⏱️ '+parts[1].trim()+'
';}else{htmlContent+='
'+c.cardDistanceTime+'
';}} if(c.cardLink){var linkText=c.cardLinkText||'Read more';htmlContent+=''+linkText+'';} htmlContent+='
';} htmlContent+='
';return htmlContent;} $(document).on('shown.bs.modal','[id^=contentMapModal_]',function(){let modalId=$(this).attr('id');let mapNum=modalId.replace('contentMapModal_','');if(window.contentMaps&&window.contentMaps[mapNum]){window.contentMaps[mapNum].resize();Object.keys(markerData[mapNum]).forEach((i)=>{updateMapBounds(mapNum,i);});}});$(document).on('hidden.bs.modal','[id^=contentMapModal_]',function(){resetMarkersAndCards($(this).attr('id').replace('contentMapModal_',''));});function isMobileDevice(){return window.innerWidth<=768||window.innerHeight<=600;} function updateMapBounds(mapNum,iconNum){const oldBounds=contentMaps[mapNum].getBounds();const newBounds=contentMaps[mapNum].getBounds();const mapDimensions=contentMaps[mapNum].getContainer().getBoundingClientRect();const clickedMarker=markerData[mapNum][iconNum];const lngDiff=oldBounds.getNorthEast().lng-oldBounds.getSouthWest().lng;const latDiff=oldBounds.getNorthEast().lat-oldBounds.getSouthWest().lat;const lngPerPx=lngDiff / mapDimensions.width;const latPerPx=latDiff / mapDimensions.height;if(clickedMarker['popup']&&clickedMarker.a){const pixelCoordinates=contentMaps[mapNum].project(clickedMarker.lonLat);const tooCloseX=100;const tooCloseT=80;const tooCloseB=10;const eXp=120;const eTp=120;const eBp=20;const extendNWSE=[0,0,0,0];if(pixelCoordinates.xmapDimensions.width-tooCloseX){extendNWSE[1]=eXp-(mapDimensions.width-pixelCoordinates.x);} if(pixelCoordinates.ymapDimensions.height-tooCloseB){extendNWSE[2]=eBp-(mapDimensions.height-pixelCoordinates.y);} for(let i=0;i0){switch(i){case 0:const extendNorthLat=extendNWSE[i]*latPerPx;newBounds.extend(new mapboxgl.LngLat(clickedMarker.lonLat[0],oldBounds.getNorthEast().lat+extendNorthLat));break;case 1:const extendEastLng=extendNWSE[i]*lngPerPx;newBounds.extend(new mapboxgl.LngLat(oldBounds.getNorthEast().lng+extendEastLng,clickedMarker.lonLat[1]));break;case 2:const extendSouthLat=extendNWSE[i]*latPerPx;newBounds.extend(new mapboxgl.LngLat(clickedMarker.lonLat[0],oldBounds.getSouthWest().lat-extendSouthLat));break;case 3:const extendWestLng=extendNWSE[i]*lngPerPx;newBounds.extend(new mapboxgl.LngLat(oldBounds.getSouthWest().lng-extendWestLng,clickedMarker.lonLat[1]));break;}}} if(Math.abs(newBounds.getSouthWest().lng-oldBounds.getSouthWest().lng)>1e-6||Math.abs(newBounds.getSouthWest().lat-oldBounds.getSouthWest().lat)>1e-6||Math.abs(newBounds.getNorthEast().lng-oldBounds.getNorthEast().lng)>1e-6||Math.abs(newBounds.getNorthEast().lat-oldBounds.getNorthEast().lat)>1e-6){contentMaps[mapNum].fitBounds(newBounds,{padding:0,duration:600,easing:(t)=>t*(2-t)});}} if(clickedMarker['route']&&clickedMarker['routeJson']&&clickedMarker['clicked']){const paddingRoutePixels=20;let extendWest=false,extendEast=false,extendNorth=false,extendSouth=false;clickedMarker['routeJson'].forEach(coord=>{if(coord[0]newBounds.getEast())extendEast=true;if(coord[1]>newBounds.getNorth())extendNorth=true;if(coord[1]t*(2-t)});} if(!isMobileDevice()&&markerData[mapNum][iconNum].card&&markerData[mapNum][iconNum].a){const w=300;const h=360;const p=100;const oX=markerData[mapNum][iconNum].card.oX;const oY=markerData[mapNum][iconNum].card.oY;const markerPixel=contentMaps[mapNum].project(clickedMarker.lonLat);const topLeftPixel={x:markerPixel.x+oX-w/2-p,y:markerPixel.y+oY-h-p};const topRightPixel={x:topLeftPixel.x+w+(2*p),y:topLeftPixel.y};const bottomLeftPixel={x:topLeftPixel.x,y:topLeftPixel.y+h+(2*p)};const bottomRightPixel={x:topRightPixel.x,y:bottomLeftPixel.y};[topLeftPixel,topRightPixel,bottomLeftPixel,bottomRightPixel].forEach(pixel=>{const lngLat=contentMaps[mapNum].unproject(pixel);newBounds.extend(lngLat);});contentMaps[mapNum].fitBounds(newBounds,{padding:0,duration:600,easing:(t)=>t*(2-t)});}}markerData[1][2]={"lonLat":[" -106.81851529029224","39.191379900464135"],"best":"2","time":"380","distance":410,"type":"numbered","onClick":true,"route":{"id":"2624","color":"#fa5050"},"card":{"title":"Aspen","distanceTime":"\ud83d\ude97 410 miles \u23f1\ufe0f 6 hours, 20 minutes","photoCode":"\"A","oX":175,"oY":0},"cardLink":"#","cardLinkText":""};markerData[1][3]={"lonLat":["-113.030857","37.296647"],"best":"3","time":"270","distance":295,"type":"numbered","onClick":true,"route":{"id":"735","color":"#fa5050"},"card":{"title":"Zion National Park","distanceTime":"\ud83d\ude97 295 miles \u23f1\ufe0f 4 hours, 30 minutes","photoCode":"\"Red","oX":-175,"oY":0},"cardLink":"\/trip\/road-trip-from-salt-lake-city-to-zion-national-park","cardLinkText":"Read more"};markerData[1][4]={"lonLat":["-120.045287","39.101541"],"best":"4","time":"480","distance":550,"type":"numbered","onClick":true,"route":{"id":"1638","color":"#fa5050"},"card":{"title":"Lake Tahoe","distanceTime":"\ud83d\ude97 550 miles \u23f1\ufe0f 8 hours","photoCode":"\"Paddle","oX":-175,"oY":0},"cardLink":"#","cardLinkText":""};markerData[1][5]={"lonLat":["-115.173143","36.109787"],"best":"5","time":"540","distance":570,"type":"numbered","onClick":true,"route":{"id":"1040","color":"#fa5050"},"card":{"title":"Las Vegas","distanceTime":"\ud83d\ude97 570 miles \u23f1\ufe0f 9 hours","photoCode":"\"Close","oX":-175,"oY":0},"cardLink":"\/trip\/road-trip-from-salt-lake-city-to-las-vegas","cardLinkText":"Read more"};markerData[1][6]={"lonLat":["-109.539773","38.588650"],"best":"6","time":"220","distance":235,"type":"numbered","onClick":true,"route":{"id":"1630","color":"#fa5050"},"card":{"title":"Moab","distanceTime":"\ud83d\ude97 235 miles \u23f1\ufe0f 3 hours, 40 minutes","photoCode":"\"Dusting","oX":175,"oY":0},"cardLink":"#","cardLinkText":""};markerData[1][7]={"lonLat":["-104.988929","39.740535"],"best":"7","time":"580","distance":610,"type":"numbered","onClick":true,"route":{"id":"1173","color":"#fa5050"},"card":{"title":"Denver","distanceTime":"\ud83d\ude97 610 miles \u23f1\ufe0f 9 hours, 40 minutes","photoCode":"\"The","oX":175,"oY":0},"cardLink":"\/trip\/road-trip-from-salt-lake-city-to-denver","cardLinkText":"Read more"};markerData[1][8]={"lonLat":["-103.511373","43.863222"],"best":"8","time":"600","distance":650,"type":"numbered","onClick":true,"route":{"id":"1642","color":"#fa5050"},"card":{"title":"Mount Rushmore","distanceTime":"\ud83d\ude97 650 miles \u23f1\ufe0f 10 hours","photoCode":"\"Mount","oX":175,"oY":0},"cardLink":"#","cardLinkText":""};markerData[1][9]={"lonLat":["-110.676563","43.786227"],"best":"9","time":"300","distance":310,"type":"numbered","onClick":true,"route":{"id":"1633","color":"#fa5050"},"card":{"title":"Grand Teton National Park","distanceTime":"\ud83d\ude97 310 miles \u23f1\ufe0f 5 hours","photoCode":"\"Grand","oX":175,"oY":0},"cardLink":"#","cardLinkText":""};markerData[1][10]={"lonLat":[" -106.6504210962498","35.084335274282495"],"best":"10","time":"575","distance":600,"type":"numbered","onClick":true,"route":{"id":"2625","color":"#fa5050"},"card":{"title":"Albuquerque","distanceTime":"\ud83d\ude97 600 miles \u23f1\ufe0f 9 hours, 35 minutes","photoCode":"\"Hot","oX":175,"oY":0},"cardLink":"#","cardLinkText":""};markerData[1][11]={"lonLat":["-111.140116","38.091594"],"best":"11","time":"205","distance":229,"type":"numbered","onClick":true,"route":{"id":"1628","color":"#fa5050"},"card":{"title":"Capitol Reef National Park","distanceTime":"\ud83d\ude97 229 miles \u23f1\ufe0f 3 hours, 25 minutes","photoCode":"\"Capitol","oX":175,"oY":0},"cardLink":"#","cardLinkText":""};markerData[1][12]={"lonLat":[" -105.93800353445357","35.68743293099332"],"best":"12","time":"700","distance":660,"type":"numbered","onClick":true,"route":{"id":"2626","color":"#fa5050"},"card":{"title":"Santa Fe","distanceTime":"\ud83d\ude97 660 miles \u23f1\ufe0f 11 hours, 40 minutes","photoCode":"\"Santa","oX":175,"oY":0},"cardLink":"#","cardLinkText":""};markerData[1][13]={"lonLat":["-112.117736","36.065438"],"best":"13","time":"540","distance":530,"type":"numbered","onClick":true,"route":{"id":"1065","color":"#fa5050"},"card":{"title":"Grand Canyon National Park","distanceTime":"\ud83d\ude97 530 miles \u23f1\ufe0f 9 hours","photoCode":"\"Toroweap","oX":175,"oY":360},"cardLink":"\/trip\/road-trip-from-salt-lake-city-to-grand-canyon-national-park","cardLinkText":"Read more"};markerData[1][14]={"lonLat":["-111.468792","36.904645"],"best":"14","time":"395","distance":420,"type":"numbered","onClick":true,"route":{"id":"1637","color":"#fa5050"},"card":{"title":"Page","distanceTime":"\ud83d\ude97 420 miles \u23f1\ufe0f 6 hours, 35 minutes","photoCode":"\"Antelope","oX":175,"oY":0},"cardLink":"#","cardLinkText":""};markerData[1][15]={"lonLat":["-109.525372","40.468942"],"best":"15","time":"180","distance":170,"type":"numbered","onClick":true,"route":{"id":"1627","color":"#fa5050"},"card":{"title":"Vernal","distanceTime":"\ud83d\ude97 170 miles \u23f1\ufe0f 3 hours","photoCode":"\"Vernal's","oX":175,"oY":0},"cardLink":"#","cardLinkText":""};markerData[1][16]={"lonLat":["-110.707403","38.573625"],"best":"16","time":"210","distance":220,"type":"numbered","onClick":true,"route":{"id":"1629","color":"#fa5050"},"card":{"title":"Goblin Valley State Park","distanceTime":"\ud83d\ude97 220 miles \u23f1\ufe0f 3 hours, 30 minutes","photoCode":"\"Goblin","oX":175,"oY":0},"cardLink":"#","cardLinkText":""};markerData[1][17]={"lonLat":["-114.342700","43.682331"],"best":"17","time":"270","distance":290,"type":"numbered","onClick":true,"route":{"id":"1632","color":"#fa5050"},"card":{"title":"Ketchum & Sun Valley","distanceTime":"\ud83d\ude97 290 miles \u23f1\ufe0f 4 hours, 30 minutes","photoCode":"\"Winter","oX":-175,"oY":0},"cardLink":"#","cardLinkText":""};markerData[1][18]={"lonLat":["-112.213696","40.959121"],"best":"18","time":"50","distance":40,"type":"numbered","onClick":true,"route":{"id":"1625","color":"#fa5050"},"card":{"title":"Antelope Island State Park","distanceTime":"\ud83d\ude97 40 miles \u23f1\ufe0f 50 minutes","photoCode":"\"Pronghorn","oX":-175,"oY":0},"cardLink":"#","cardLinkText":""};markerData[1][19]={"lonLat":["-107.315875","39.536602"],"best":"19","time":"320","distance":370,"type":"numbered","onClick":true,"route":{"id":"1634","color":"#fa5050"},"card":{"title":"Glenwood Springs","distanceTime":"\ud83d\ude97 370 miles \u23f1\ufe0f 5 hours, 20 minutes","photoCode":"\"Hanging","oX":175,"oY":0},"cardLink":"#","cardLinkText":""};markerData[1][20]={"lonLat":["-105.265803","40.039421"],"best":"20","time":"490","distance":540,"type":"numbered","onClick":true,"route":{"id":"1640","color":"#fa5050"},"card":{"title":"Boulder","distanceTime":"\ud83d\ude97 540 miles \u23f1\ufe0f 8 hours, 10 minutes","photoCode":"\"Boulder,","oX":175,"oY":0},"cardLink":"#","cardLinkText":""};markerData[1][21]={"lonLat":["-112.16719938963004","37.57783654390525"],"best":"21","time":"390","distance":340,"type":"numbered","onClick":true,"route":{"id":"2631","color":"#fa5050"},"card":{"title":"Bryce Canyon National Park","distanceTime":"\ud83d\ude97 340 miles \u23f1\ufe0f 6 hours, 30 minutes","photoCode":"\"Bryce","oX":-175,"oY":0},"cardLink":"\/trip\/road-trip-from-salt-lake-city-to-bryce-canyon","cardLinkText":"Read more"};markerData[1][22]={"lonLat":["-111.658524","40.234220"],"best":"22","time":"45","distance":45,"type":"numbered","onClick":true,"route":{"id":"1626","color":"#fa5050"},"card":{"title":"Provo","distanceTime":"\ud83d\ude97 45 miles \u23f1\ufe0f 45 minutes","photoCode":"\"Provo,","oX":175,"oY":0},"cardLink":"#","cardLinkText":""};markerData[1][23]={"lonLat":["-111.97390216421378","41.22288903098787"],"best":"23","time":"40","distance":40,"type":"numbered","onClick":true,"route":{"id":"2629","color":"#fa5050"},"card":{"title":"Ogden","distanceTime":"\ud83d\ude97 40 miles \u23f1\ufe0f 40 minutes","photoCode":"\"Downtown","oX":-175,"oY":0},"cardLink":"#","cardLinkText":""};markerData[1][24]={"lonLat":["-111.4979565200086","40.64608563182756"],"best":"24","time":"40","distance":35,"type":"numbered","onClick":true,"route":{"id":"1624","color":"#fa5050"},"card":{"title":"Park City","distanceTime":"\ud83d\ude97 35 miles \u23f1\ufe0f 40 minutes","photoCode":"\"Autumn","oX":175,"oY":0},"cardLink":"#","cardLinkText":""};markerData[1][25]={"lonLat":["-111.41490873487065","40.50090623748402"],"best":"25","time":"50","distance":45,"type":"numbered","onClick":true,"route":{"id":"2627","color":"#fa5050"},"card":{"title":"Heber City","distanceTime":"\ud83d\ude97 45 miles \u23f1\ufe0f 50 minutes","photoCode":"\"The","oX":175,"oY":0},"cardLink":"#","cardLinkText":""};markerData[1][26]={"lonLat":["-111.47243431145867","40.51216450310545"],"best":"26","time":"50","distance":50,"type":"numbered","onClick":true,"route":{"id":"2632","color":"#fa5050"},"card":{"title":"Midway","distanceTime":"\ud83d\ude97 50 miles \u23f1\ufe0f 50 minutes","photoCode":"\"Towering","oX":175,"oY":0},"cardLink":"#","cardLinkText":""};initialMapBounds[1]=new mapboxgl.LngLatBounds(window.bounds[1].getSouthWest(),window.bounds[1].getNorthEast());const visibleMapRoutes_1=[];contentMaps[1].on('click',(e)=>{resetMarkersAndCards(1);});const markerConfig={'finish':{className:'marker_finish',size:[58,58],offset:[0,-29],span:false,best:false,text:false,},'start':{className:'marker_start',size:[58,58],offset:[0,-29],span:false,best:false,text:false,},'star':{className:'marker_star',size:[58,58],offset:[0,-29],span:false,best:false,text:false,},'numbered':{className:'mapMarkerNum',size:false,offset:[0,0],span:true,best:true,text:false,},'star-plain':{className:'mapMarkerNum markerSpanRed',size:false,offset:[0,0],span:true,best:false,text:'☆',},'grey':{className:'mapMarkerNum markerSpanGrey',size:false,offset:[0,0],span:true,best:false,text:false,},};function addMarkersToMap(m,f=null){Object.values(markerData[m]).forEach((i,n)=>{if(f!==null&&n'+t+'';} if(mC.width&&mC.height){el.style.width=mC.width+'px';el.style.height=mC.height+'px';} var marker=new mapboxgl.Marker(el,{offset:mC.offset}).setLngLat(i.lonLat).addTo(window.contentMaps[m]);marker.markerType=i.iconType;if(f!==null){} i.marker=marker;if(i.best){window.bounds[m].extend(i.lonLat);} if(i.onClick){marker.getElement().addEventListener('click',function(){event.stopPropagation();toggleMapIconClick(m,n);});}});} markerData[1][32]={"lonLat":["-112.074075","33.448221"],"time":"820","distance":780,"type":"grey","onClick":true,"route":{"id":"1796","color":"#fa5050"},"card":{"title":"Phoenix","distanceTime":"\ud83d\ude97 780 miles \u23f1\ufe0f 13 hours, 40 minutes","photoCode":"\"Camelback","oX":-175,"oY":0},"cardLink":"\/trip\/road-trip-from-salt-lake-city-to-phoenix","cardLinkText":"Read more"};markerData[1][27]={"lonLat":["-122.648148","45.547824"],"time":"810","distance":830,"type":"grey","onClick":true,"route":{"id":"1647","color":"#fa5050"},"card":{"title":"Portland","distanceTime":"\ud83d\ude97 830 miles \u23f1\ufe0f 13 hours, 30 minutes","photoCode":"\"View","oX":-175,"oY":0},"cardLink":"#","cardLinkText":""};markerData[1][28]={"lonLat":["-122.391347","37.761317"],"time":"810","distance":830,"type":"grey","onClick":true,"route":{"id":"812","color":"#fa5050"},"card":{"title":"San Francisco","distanceTime":"\ud83d\ude97 830 miles \u23f1\ufe0f 13 hours, 30 minutes","photoCode":"\"Golden","oX":-175,"oY":0},"cardLink":"\/trip\/road-trip-from-salt-lake-city-to-san-francisco","cardLinkText":"Read more"};markerData[1][29]={"lonLat":["-113.988617","48.502554"],"time":"880","distance":830,"type":"grey","onClick":true,"route":{"id":"1044","color":"#fa5050"},"card":{"title":"Glacier National Park","distanceTime":"\ud83d\ude97 830 miles \u23f1\ufe0f 14 hours, 40 minutes","photoCode":"\"Glacier","oX":-175,"oY":0},"cardLink":"\/trip\/road-trip-from-salt-lake-city-to-glacier-national-park","cardLinkText":"Read more"};markerData[1][30]={"lonLat":["-118.242644","34.054920"],"time":"870","distance":910,"type":"grey","onClick":true,"route":{"id":"1055","color":"#fa5050"},"card":{"title":"Los Angeles","distanceTime":"\ud83d\ude97 910 miles \u23f1\ufe0f 14 hours, 30 minutes","photoCode":"\"Beautiful","oX":175,"oY":360},"cardLink":"\/trip\/road-trip-from-salt-lake-city-to-los-angeles","cardLinkText":"Read more"};markerData[1][31]={"lonLat":["-122.332549","47.606079"],"time":"860","distance":950,"type":"grey","onClick":true,"route":{"id":"809","color":"#fa5050"},"card":{"title":"Seattle","distanceTime":"\ud83d\ude97 950 miles \u23f1\ufe0f 14 hours, 20 minutes","photoCode":"\"A","oX":-175,"oY":0},"cardLink":"\/trip\/road-trip-from-salt-lake-city-to-seattle","cardLinkText":"Read more"};addMarkersToMap(1);contentMap_1.fitBounds(window.bounds[1],{padding:{top:60,bottom:60,left:60,right:60}});const sortByValue=document.querySelector('.cardListSortDropdown').value;sortMapMarkers(markerData,sortOptionsMap,sortByValue,1);}const sortOptionsMap={'best':'best','distance':'distanceSort',};function sortMapMarkers(markerData,sortOptionsMap,sortBy,listNum){const markersWithDistance=Object.values(markerData[listNum]).filter(marker=>marker.hasOwnProperty('distance')&&marker.hasOwnProperty('best'));const hasDistanceSort=markersWithDistance.some(marker=>marker.hasOwnProperty('distanceSort'));if(!hasDistanceSort){const sortedMarkers=markersWithDistance.sort((a,b)=>a.distance-b.distance);sortedMarkers.forEach((sortedMarker,index)=>{sortedMarker.distanceSort=index+1;});} Object.keys(markerData[listNum]).forEach(iconNum=>{const marker=markerData[listNum][iconNum];if(marker.hasOwnProperty('distance')&&marker.hasOwnProperty('best')){const markerElement=document.getElementById('markerSpan-'+listNum+'-'+iconNum);if(markerElement){const propertyToUse=sortOptionsMap[sortBy]||sortBy;const v=marker[propertyToUse];if(v!==undefined){markerElement.innerHTML=v;}else{markerElement.innerHTML='';}}}});document.querySelectorAll('.cardListSortDropdown').forEach(function(dropdownUpdate){dropdownUpdate.value=sortBy;});} (function(){function initializeSortDropdown(){document.querySelectorAll('.cardListSortDropdown').forEach(function(dropdown){dropdown.addEventListener('change',function(){const sortBy=this.value;const listNum=this.getAttribute('data-listnum');const cardsContainer=document.querySelector('.row[data-listnum=\"'+listNum+'\"]');Array.from(cardsContainer.children).sort((a,b)=>{const aValue=parseFloat(a.getAttribute('data-'+sortBy)||Infinity);const bValue=parseFloat(b.getAttribute('data-'+sortBy)||Infinity);return aValue-bValue;}).forEach((card,index)=>{cardsContainer.appendChild(card);const titleElement=card.querySelector('.card-title.cardListCardTitle');if(titleElement){const updatedTitle=(index+1)+titleElement.innerHTML.replace(/^\d+\./,'.');titleElement.innerHTML=updatedTitle;}});sortMapMarkers(markerData,sortOptionsMap,sortBy,listNum);});});} if(document.readyState==='loading'){document.addEventListener('DOMContentLoaded',initializeSortDropdown);}else{initializeSortDropdown();}})(); var mapScriptCreated = 0; var mapCssCreated = 0; var mapScriptLoaded = 0; var mapCssLoaded = 0; var mapLoadList = []; function showLazyMap(fname) { if (mapScriptLoaded == 1 && mapCssLoaded == 1) { if (!mapLoadList.includes(fname)) { window[fname](); mapLoadList.push(fname); } } } (function fn() { var pics = document.querySelectorAll('.no-js-hide'); pics.forEach(function(pic) { pic.classList.toggle('no-js-hide'); }); var lazyImages = [].slice.call(document.querySelectorAll(".lazeeload")); if ("IntersectionObserver" in window) { const config = { root: null, rootMargin: '1000px', threshold: 0 }; let lazyImageObserver = new IntersectionObserver(function(entries, observer) { entries.forEach(function(entry) { if (entry.isIntersecting) { let lazyImage = entry.target; if (lazyImage.dataset.src) {lazyImage.src = lazyImage.dataset.src;} if (lazyImage.dataset.srcset) {lazyImage.srcset = lazyImage.dataset.srcset;} if (lazyImage.dataset.map) { const fname = "initMapbox_"+lazyImage.dataset.map; if (mapScriptLoaded == 0) { let script = document.createElement('script'); script.async=true; script.defer=true; script.src = "https://api.mapbox.com/mapbox-gl-js/v3.0.0/mapbox-gl.js"; script.onload = function(){ mapScriptLoaded = 1; showLazyMap(fname); } document.head.appendChild(script); mapScriptCreated = 1; let css = document.createElement('link'); css.rel = "stylesheet"; css.href = "https://api.mapbox.com/mapbox-gl-js/v3.0.0/mapbox-gl.css"; css.onload = function(){ mapCssLoaded = 1; showLazyMap(fname); } document.head.appendChild(css); mapCssCreated = 1; } else { if (typeof window[fname] === 'function') { window[fname](); } showLazyMap(fname); } } lazyImage.classList.remove("no-js-hide"); lazyImage.classList.remove("lazeeload"); lazyImageObserver.unobserve(lazyImage); } }); }, config); lazyImages.forEach(function(lazyImage) { lazyImageObserver.observe(lazyImage); lazyImage.classList.add("lazeeload-activated"); }); } else { let active = false; const lazyLoad = function() { if (active === false) { active = true; setTimeout(function() { lazyImages.forEach(function(lazyImage) { if ((lazyImage.getBoundingClientRect().top <= window.innerHeight+1000 && lazyImage.getBoundingClientRect().bottom >= 0) && getComputedStyle(lazyImage).display !== "none") { if (lazyImage.dataset.src) lazyImage.src = lazyImage.dataset.src; if (lazyImage.dataset.srcset) lazyImage.srcset = lazyImage.dataset.srcset; if (lazyImage.dataset.onload) lazyImage.onload = lazyImage.dataset.onload; lazyImage.classList.remove("lazeeload"); lazyImages = lazyImages.filter(function(image) { return image !== lazyImage; }); if (lazyImages.length === 0) { document.removeEventListener("scroll", lazyLoad); window.removeEventListener("resize", lazyLoad); window.removeEventListener("orientationchange", lazyLoad); } } }); active = false; }, 200); } }; document.addEventListener("scroll", lazyLoad); window.addEventListener("resize", lazyLoad); window.addEventListener("orientationchange", lazyLoad); } var lazyImages = [].slice.call(document.querySelectorAll(".lazeeload")); i=1; lazyImages.forEach(function(lazyImage) { if (!(lazyImage.classList.contains("lazeeload-activated"))) { if (lazyImage.dataset.src) lazyImage.src = lazyImage.dataset.src; if (lazyImage.dataset.srcset) lazyImage.srcset = lazyImage.dataset.srcset; lazyImage.classList.remove("lazeeload"); } }); })();