{"version":3,"file":"scripts/search/searchresultsmap.js","mappings":"MAAAA,eAAeC,EAAUC,GACrB,IAAIC,EAAe,GAYnB,aAVuBC,MAAMF,GACxBG,MAAK,SAASC,GACX,IAAKA,EAASC,GACV,MAAM,IAAIC,MAAM,wBAA0BF,EAASG,QAEvD,OAAOH,EAASI,UAEnBL,MAAK,SAASK,GACXP,EAAeO,KAEhBP,EAGX,IAAIQ,EAyDJC,OAAOC,QAvDP,WAEI,IAAIC,EAAaC,SAASC,eAAe,qBACzCF,EAAWG,MAAMC,OAAS,OAC1BP,EAAY,IAAIQ,OAAOC,KAAKC,IAAIP,EAC5B,CACIQ,gBAAgB,IAIxB,IAAIC,EAAa,IAAIJ,OAAOC,KAAKI,WAAW,CACxCC,QAAS,YACTC,SAAU,MAId,IACIC,EADAC,EAAe,IAAIT,OAAOC,KAAKS,aAEnCzB,MAAM0B,iBACDzB,MAAK,SAAUC,GACZ,IAAKA,EAASC,GACV,MAAM,IAAIC,MAAM,wBAA0BF,EAASG,QAEvD,OAAOH,EAASyB,UAEnB1B,MAAK,SAAU0B,GACZJ,EAAUI,EACV,IAAK,IAAIC,EAAI,EAAGA,EAAID,EAAKE,OAAQD,IAAK,CAClC,MAAME,EAAS,IAAIf,OAAOC,KAAKe,OAAOJ,EAAKC,GAAGI,SAAUL,EAAKC,GAAGK,WAEhE,IAAIC,EAAS,IAAInB,OAAOC,KAAKmB,OAAO,CAChCC,SAAUN,EACVO,IAAK9B,IAGT2B,EAAOI,YAAY,aACf1C,UAEI,IAAIyB,QAAgBxB,EAAU0B,EAAQK,GAAGW,SACzCpB,EAAWqB,WAAW,+CAAiDnB,EAAU,UACjFF,EAAWsB,KAAK,CACZC,OAAQR,EACRG,IAAK9B,EACLoC,aAAa,OAGzBnB,EAAaoB,OAAOV,EAAOW,mBAGlC5C,MAAK,WACFM,EAAUuC,UAAUtB,EAAc,S","sources":["webpack://BokaWeb/./src/js/components/search/searchresultsmap.js"],"sourcesContent":["async function fetchCard(url) {\r\n let returnString = \"\";\r\n // TODO: Improve implementation\r\n const response = await fetch(url)\r\n .then(function(response) {\r\n if (!response.ok) {\r\n throw new Error(\"HTTP error, status = \" + response.status);\r\n }\r\n return response.text();\r\n })\r\n .then(function(text) {\r\n returnString = text;\r\n });\r\n return returnString;\r\n}\r\n\r\nlet googleMap;\r\n\r\nfunction initMap() {\r\n // Setup Google Maps\r\n let mapElement = document.getElementById(\"search-result-map\");\r\n mapElement.style.height = \"65vh\";\r\n googleMap = new google.maps.Map(mapElement,\r\n {\r\n clickableIcons: false\r\n });\r\n\r\n // InfoWindow\r\n let infoWindow = new google.maps.InfoWindow({\r\n content: \"Laddar...\",\r\n maxWidth: 300 // px\r\n });\r\n\r\n // Add markers\r\n var markerBounds = new google.maps.LatLngBounds();\r\n var markers;\r\n fetch(markersEndpoint)\r\n .then(function (response) {\r\n if (!response.ok) {\r\n throw new Error(\"HTTP error, status = \" + response.status);\r\n }\r\n return response.json();\r\n })\r\n .then(function (json) {\r\n markers = json;\r\n for (let i = 0; i < json.length; i++) {\r\n const latLng = new google.maps.LatLng(json[i].latitude, json[i].longitude);\r\n\r\n let marker = new google.maps.Marker({\r\n position: latLng,\r\n map: googleMap,\r\n });\r\n\r\n marker.addListener(\"mouseover\",\r\n async () => {\r\n // TODO: Add caching, maybe by using HTTP attributes\r\n let content = await fetchCard(markers[i].cardUrl);\r\n infoWindow.setContent('