| 
									
										
										
										
											2019-08-14 17:42:56 -06:00
										 |  |  | /* | 
					
						
							|  |  |  |  * This Source Code Form is subject to the terms of the Mozilla Public | 
					
						
							|  |  |  |  * License, v. 2.0. If a copy of the MPL was not distributed with this | 
					
						
							|  |  |  |  * file, You can obtain one at http://mozilla.org/MPL/2.0/.
 | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | function leafletMap() { | 
					
						
							|  |  |  |     var map = L.map('mapbox', { | 
					
						
							|  |  |  |         zoomSnap: 0.25, | 
					
						
							| 
									
										
										
										
											2019-08-22 22:21:03 -06:00
										 |  |  |         minZoom: 1, | 
					
						
							| 
									
										
										
										
											2019-09-10 22:00:44 -06:00
										 |  |  |         maxZoom: 19, | 
					
						
							| 
									
										
										
										
											2019-08-22 22:21:03 -06:00
										 |  |  |         zoom: 12, | 
					
						
							| 
									
										
										
										
											2019-08-14 17:42:56 -06:00
										 |  |  |         center: L.latLng(46.5966, -112.0180), | 
					
						
							| 
									
										
										
										
											2019-09-10 22:34:01 -06:00
										 |  |  |         attributionControl: false | 
					
						
							| 
									
										
										
										
											2019-08-14 17:42:56 -06:00
										 |  |  |     }); | 
					
						
							| 
									
										
										
										
											2019-12-22 21:07:45 -07:00
										 |  |  |      | 
					
						
							|  |  |  |     map.maptype = "leaflet"; | 
					
						
							| 
									
										
										
										
											2019-08-14 17:42:56 -06:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-08-22 22:21:03 -06:00
										 |  |  |     if (localStorage.getItem("mapsource") == null) { | 
					
						
							| 
									
										
										
										
											2019-09-11 19:13:54 -06:00
										 |  |  |         localStorage.setItem("mapsource", "liberty"); | 
					
						
							| 
									
										
										
										
											2019-08-22 22:21:03 -06:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2019-11-12 21:36:28 -07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-10-27 21:06:12 -06:00
										 |  |  |     $("#mapbox").css("background-color", SETTINGS.maptileurls[localStorage.getItem("mapsource")].bgcolor); | 
					
						
							| 
									
										
										
										
											2019-08-22 22:21:03 -06:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-10-27 21:06:12 -06:00
										 |  |  |     L.tileLayer(SETTINGS.maptileurls[localStorage.getItem("mapsource")].url, { | 
					
						
							| 
									
										
										
										
											2019-09-11 20:50:43 -06:00
										 |  |  |         minZoom: 1, | 
					
						
							|  |  |  |         maxZoom: 19 | 
					
						
							|  |  |  |     }).addTo(map); | 
					
						
							| 
									
										
										
										
											2019-08-14 17:42:56 -06:00
										 |  |  | 
 | 
					
						
							|  |  |  |     map.locateControl = L.control.locate({ | 
					
						
							| 
									
										
										
										
											2019-09-11 20:29:37 -06:00
										 |  |  |         flyTo: false, // Hopefully this will lower the number of map tile requests when location is found
 | 
					
						
							|  |  |  |         showPopup: false, | 
					
						
							|  |  |  |         locateOptions: { | 
					
						
							|  |  |  |             enableHighAccuracy: true, | 
					
						
							| 
									
										
										
										
											2019-09-11 23:46:32 -06:00
										 |  |  |             maxZoom: 16 | 
					
						
							| 
									
										
										
										
											2019-09-11 20:29:37 -06:00
										 |  |  |         }, | 
					
						
							| 
									
										
										
										
											2019-09-11 23:46:32 -06:00
										 |  |  |         setView: "untilPanOrZoom", | 
					
						
							| 
									
										
										
										
											2019-08-14 17:42:56 -06:00
										 |  |  |         icon: "far fa-compass", | 
					
						
							|  |  |  |         iconLoading: "far fa-compass fa-spin" | 
					
						
							|  |  |  |     }).addTo(map); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-08-20 16:07:53 -06:00
										 |  |  |     map.packagelayer = L.markerClusterGroup(); | 
					
						
							| 
									
										
										
										
											2019-08-14 17:42:56 -06:00
										 |  |  | 
 | 
					
						
							|  |  |  |     map.packagelayer.addTo(map); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-09-28 21:29:16 -06:00
										 |  |  |     map.setView({lat: userPosition.coords.latitude, lng: userPosition.coords.longitude}, 2); | 
					
						
							| 
									
										
										
										
											2019-08-14 17:42:56 -06:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-12-22 21:07:45 -07:00
										 |  |  |     map.startLocateControl = function () { | 
					
						
							|  |  |  |         map.locateControl.start(); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     map.stopLocateControl = function () { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-08-14 17:42:56 -06:00
										 |  |  |     map.setMapHeading = function (heading) { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     map.setMapLocation = function (latitude, longitude) { | 
					
						
							|  |  |  |         map.setView({ | 
					
						
							|  |  |  |             lng: longitude, | 
					
						
							|  |  |  |             lat: latitude | 
					
						
							|  |  |  |         }); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     map.updatePackageLayer = function (data) { | 
					
						
							|  |  |  |         map.packagelayer.clearLayers(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-09-26 20:58:13 -06:00
										 |  |  |         console.log(data); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-09-26 10:53:38 -06:00
										 |  |  |         for (var i = 0; i < data.length; i++) { | 
					
						
							| 
									
										
										
										
											2019-09-26 20:58:13 -06:00
										 |  |  |             // JavaScript variable scope and anonymous functions are dumb
 | 
					
						
							|  |  |  |             // This is necessary, otherwise all the on(click)s will fire for the last iteration
 | 
					
						
							|  |  |  |             // of the loop, or something like that
 | 
					
						
							|  |  |  |             (function (datai) { | 
					
						
							|  |  |  |                 var iconName = getMapIconForItems(datai.items); | 
					
						
							| 
									
										
										
										
											2019-11-12 21:36:28 -07:00
										 |  |  |                 console.log(iconName); | 
					
						
							| 
									
										
										
										
											2019-09-26 20:58:13 -06:00
										 |  |  | 
 | 
					
						
							|  |  |  |                 var icon = L.icon({ | 
					
						
							|  |  |  |                     iconUrl: "assets/images/" + iconName + ".png", | 
					
						
							|  |  |  |                     iconSize: [25, 25], | 
					
						
							|  |  |  |                     iconAnchor: [12.5, 12.5] | 
					
						
							|  |  |  |                 }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 var marker = L.marker( | 
					
						
							|  |  |  |                         [ | 
					
						
							|  |  |  |                             datai.coords[0], | 
					
						
							|  |  |  |                             datai.coords[1] | 
					
						
							|  |  |  |                         ], | 
					
						
							|  |  |  |                         { | 
					
						
							|  |  |  |                             icon: icon | 
					
						
							|  |  |  |                         }) | 
					
						
							|  |  |  |                         .on("click", function () { | 
					
						
							|  |  |  |                             openPackageInfoSheet(datai.id) | 
					
						
							|  |  |  |                         }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 map.packagelayer.addLayer(marker); | 
					
						
							|  |  |  |             })(data[i]); | 
					
						
							| 
									
										
										
										
											2019-09-26 10:53:38 -06:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2019-08-14 17:42:56 -06:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     map.animateMapIn = function (latitude, longitude, zoom, heading) { | 
					
						
							|  |  |  |         if (typeof zoom == 'undefined') { | 
					
						
							|  |  |  |             zoom = 14; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         if (typeof heading == 'undefined') { | 
					
						
							|  |  |  |             heading = 0; | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |         map.flyTo([latitude, longitude], zoom); | 
					
						
							|  |  |  |         // Set min zoom after some time to fly in
 | 
					
						
							|  |  |  |         setTimeout(function () { | 
					
						
							|  |  |  |             map.setMinZoom(12); | 
					
						
							|  |  |  |             map.setZoom(zoom); | 
					
						
							|  |  |  |         }, 1000); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     return map; | 
					
						
							|  |  |  | } |