| 
									
										
										
										
											2020-06-24 00:35:19 +02:00
										 |  |  | import L from "leaflet" | 
					
						
							| 
									
										
										
										
											2020-08-17 17:23:15 +02:00
										 |  |  | import {UIEventSource} from "../UIEventSource"; | 
					
						
							| 
									
										
										
										
											2020-07-30 00:59:08 +02:00
										 |  |  | import {UIElement} from "../../UI/UIElement"; | 
					
						
							| 
									
										
										
										
											2020-06-24 00:35:19 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-07-22 14:46:43 +02:00
										 |  |  | export class BaseLayers { | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-07 20:50:46 +02:00
										 |  |  |     public static readonly defaultLayer: { name: string, layer: any, id: string } = { | 
					
						
							|  |  |  |         id: "osm", | 
					
						
							| 
									
										
										
										
											2020-07-24 14:46:25 +02:00
										 |  |  |         name: "Kaart van OpenStreetMap", layer: L.tileLayer("https://tile.openstreetmap.org/{z}/{x}/{y}.png", | 
					
						
							|  |  |  |             { | 
					
						
							|  |  |  |                 attribution: '', | 
					
						
							|  |  |  |                 maxZoom: 19, | 
					
						
							|  |  |  |                 minZoom: 1 | 
					
						
							|  |  |  |             }) | 
					
						
							|  |  |  |     }; | 
					
						
							| 
									
										
										
										
											2020-08-07 20:50:46 +02:00
										 |  |  |     public static readonly baseLayers: { name: string, layer: any, id: string } [] = [ | 
					
						
							| 
									
										
										
										
											2020-07-24 14:46:25 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |         { | 
					
						
							| 
									
										
										
										
											2020-08-07 20:50:46 +02:00
										 |  |  |             id: "aiv-latest", | 
					
						
							| 
									
										
										
										
											2020-07-24 14:46:25 +02:00
										 |  |  |             name: "Luchtfoto Vlaanderen (recentste door AIV)", | 
					
						
							|  |  |  |             layer: L.tileLayer("https://tile.informatievlaanderen.be/ws/raadpleegdiensten/wmts?SERVICE=WMTS&REQUEST=GetTile&VERSION=1.0.0&" + | 
					
						
							| 
									
										
										
										
											2020-07-22 14:46:43 +02:00
										 |  |  |                 "LAYER=omwrgbmrvl&STYLE=&FORMAT=image/png&tileMatrixSet=GoogleMapsVL&tileMatrix={z}&tileRow={y}&tileCol={x}", | 
					
						
							|  |  |  |                 { | 
					
						
							|  |  |  |                     // omwrgbmrvl
 | 
					
						
							|  |  |  |                     attribution: 'Luchtfoto\'s van © AIV Vlaanderen (Laatste)  © AGIV', | 
					
						
							| 
									
										
										
										
											2020-09-24 00:33:23 +02:00
										 |  |  |                     maxZoom: 22, | 
					
						
							| 
									
										
										
										
											2020-07-22 14:46:43 +02:00
										 |  |  |                     minZoom: 1, | 
					
						
							|  |  |  |                     wmts: true | 
					
						
							| 
									
										
										
										
											2020-07-24 14:46:25 +02:00
										 |  |  |                 }) | 
					
						
							|  |  |  |         }, | 
					
						
							|  |  |  |         BaseLayers.defaultLayer, | 
					
						
							|  |  |  |         { | 
					
						
							| 
									
										
										
										
											2020-08-07 20:50:46 +02:00
										 |  |  |             id: "aiv-13-15", | 
					
						
							| 
									
										
										
										
											2020-07-24 14:46:25 +02:00
										 |  |  |             name: "Luchtfoto Vlaanderen (2013-2015, door AIV)", | 
					
						
							|  |  |  |             layer: L.tileLayer.wms('https://geoservices.informatievlaanderen.be/raadpleegdiensten/OGW/wms?s', | 
					
						
							|  |  |  |                 { | 
					
						
							|  |  |  |                     layers: "OGWRGB13_15VL", | 
					
						
							|  |  |  |                     attribution: "Luchtfoto's van © AIV Vlaanderen (2013-2015) | " | 
					
						
							|  |  |  |                 }) | 
					
						
							|  |  |  |         }, | 
					
						
							|  |  |  |         { | 
					
						
							| 
									
										
										
										
											2020-08-07 20:50:46 +02:00
										 |  |  |             id:"grb", | 
					
						
							| 
									
										
										
										
											2020-07-24 14:46:25 +02:00
										 |  |  |             name: "Kaart Grootschalig ReferentieBestand Vlaanderen (GRB) door AIV", | 
					
						
							|  |  |  |             layer: L.tileLayer("https://tile.informatievlaanderen.be/ws/raadpleegdiensten/wmts?SERVICE=WMTS&REQUEST=GetTile&VERSION=1.0.0&LAYER=grb_bsk&STYLE=&FORMAT=image/png&tileMatrixSet=GoogleMapsVL&tileMatrix={z}&tileCol={x}&tileRow={y}", | 
					
						
							|  |  |  |                 { | 
					
						
							|  |  |  |                     attribution: 'Achtergrond <i>Grootschalig ReferentieBestand</i>(GRB) © AGIV', | 
					
						
							|  |  |  |                     maxZoom: 20, | 
					
						
							|  |  |  |                     minZoom: 1, | 
					
						
							|  |  |  |                     wmts: true | 
					
						
							|  |  |  |                 }) | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     ] | 
					
						
							|  |  |  |     ; | 
					
						
							| 
									
										
										
										
											2020-06-24 00:35:19 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-07-22 14:46:43 +02:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2020-06-24 00:35:19 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-07-22 14:46:43 +02:00
										 |  |  | // Contains all setup and baselayers for Leaflet stuff
 | 
					
						
							|  |  |  | export class Basemap { | 
					
						
							| 
									
										
										
										
											2020-06-24 00:35:19 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-07-22 14:46:43 +02:00
										 |  |  |     // @ts-ignore
 | 
					
						
							| 
									
										
										
										
											2020-08-30 01:13:18 +02:00
										 |  |  |     public readonly map: Map; | 
					
						
							| 
									
										
										
										
											2020-06-24 00:35:19 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-30 01:13:18 +02:00
										 |  |  |     public readonly Location: UIEventSource<{ zoom: number, lat: number, lon: number }>; | 
					
						
							|  |  |  |     public readonly LastClickLocation: UIEventSource<{ lat: number, lon: number }> = new UIEventSource<{ lat: number, lon: number }>(undefined) | 
					
						
							|  |  |  |     private  _previousLayer: L.tileLayer = undefined; | 
					
						
							|  |  |  |     public readonly CurrentLayer: UIEventSource<{ | 
					
						
							| 
									
										
										
										
											2020-08-07 20:50:46 +02:00
										 |  |  |         id: string, | 
					
						
							| 
									
										
										
										
											2020-07-22 14:46:43 +02:00
										 |  |  |         name: string, | 
					
						
							|  |  |  |         layer: L.tileLayer | 
					
						
							| 
									
										
										
										
											2020-07-24 14:46:25 +02:00
										 |  |  |     }> = new UIEventSource<L.tileLayer>(BaseLayers.defaultLayer); | 
					
						
							| 
									
										
										
										
											2020-06-24 00:35:19 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-06-29 03:12:44 +02:00
										 |  |  |     constructor(leafletElementId: string, | 
					
						
							|  |  |  |                 location: UIEventSource<{ zoom: number, lat: number, lon: number }>, | 
					
						
							|  |  |  |                 extraAttribution: UIElement) { | 
					
						
							| 
									
										
										
										
											2020-06-27 03:06:51 +02:00
										 |  |  |         this.map = L.map(leafletElementId, { | 
					
						
							| 
									
										
										
										
											2020-08-26 20:11:43 +02:00
										 |  |  |             center: [location.data.lat ?? 0, location.data.lon ?? 0], | 
					
						
							|  |  |  |             zoom: location.data.zoom ?? 2, | 
					
						
							| 
									
										
										
										
											2020-07-24 14:46:25 +02:00
										 |  |  |             layers: [BaseLayers.defaultLayer.layer], | 
					
						
							| 
									
										
										
										
											2020-06-24 00:35:19 +02:00
										 |  |  |         }); | 
					
						
							| 
									
										
										
										
											2020-07-22 15:17:29 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-08-28 03:16:21 +02:00
										 |  |  |         // Users are not allowed to zoom to the 'copies' on the left and the right, stuff goes wrong then
 | 
					
						
							|  |  |  |         // We give a bit of leeway for people on the edges
 | 
					
						
							|  |  |  |         // Also see: https://www.reddit.com/r/openstreetmap/comments/ih4zzc/mapcomplete_a_new_easytouse_editor/g31ubyv/
 | 
					
						
							|  |  |  |         this.map.setMaxBounds( | 
					
						
							|  |  |  |             [[-100,-200],[100,200]] | 
					
						
							|  |  |  |         ); | 
					
						
							| 
									
										
										
										
											2020-06-29 03:40:19 +02:00
										 |  |  |         this.map.attributionControl.setPrefix( | 
					
						
							|  |  |  |             extraAttribution.Render() + " | <a href='https://osm.org'>OpenStreetMap</a>"); | 
					
						
							| 
									
										
										
										
											2020-06-24 00:35:19 +02:00
										 |  |  |         this.Location = location; | 
					
						
							| 
									
										
										
										
											2020-06-29 03:12:44 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-06-27 03:06:51 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-06-28 00:06:23 +02:00
										 |  |  |         this.map.zoomControl.setPosition("bottomright"); | 
					
						
							| 
									
										
										
										
											2020-06-24 00:35:19 +02:00
										 |  |  |         const self = this; | 
					
						
							| 
									
										
										
										
											2020-06-27 03:06:51 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-06-24 00:35:19 +02:00
										 |  |  |         this.map.on("moveend", function () { | 
					
						
							|  |  |  |             location.data.zoom = self.map.getZoom(); | 
					
						
							|  |  |  |             location.data.lat = self.map.getCenter().lat; | 
					
						
							| 
									
										
										
										
											2020-06-29 03:12:44 +02:00
										 |  |  |             location.data.lon = self.map.getCenter().lng; | 
					
						
							| 
									
										
										
										
											2020-06-24 00:35:19 +02:00
										 |  |  |             location.ping(); | 
					
						
							| 
									
										
										
										
											2020-06-27 03:06:51 +02:00
										 |  |  |         }); | 
					
						
							| 
									
										
										
										
											2020-07-22 15:17:29 +02:00
										 |  |  |          | 
					
						
							|  |  |  |         this.CurrentLayer.addCallback((layer:{layer: L.tileLayer}) => { | 
					
						
							|  |  |  |             if(self._previousLayer !== undefined){ | 
					
						
							|  |  |  |                 self.map.removeLayer(self._previousLayer); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |             self._previousLayer = layer.layer; | 
					
						
							|  |  |  |             self.map.addLayer(layer.layer); | 
					
						
							|  |  |  |         }); | 
					
						
							| 
									
										
										
										
											2020-06-27 03:06:51 +02:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-06-29 03:12:44 +02:00
										 |  |  |         this.map.on("click", function (e) { | 
					
						
							|  |  |  |             self.LastClickLocation.setData({lat: e.latlng.lat, lon: e.latlng.lng}) | 
					
						
							|  |  |  |         }); | 
					
						
							| 
									
										
										
										
											2020-09-05 18:40:16 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |         this.map.on("contextmenu", function (e) { | 
					
						
							|  |  |  |             self.LastClickLocation.setData({lat: e.latlng.lat, lon: e.latlng.lng}); | 
					
						
							|  |  |  |             console.log("Right click") | 
					
						
							|  |  |  |             e.preventDefault(); | 
					
						
							|  |  |  |         }); | 
					
						
							| 
									
										
										
										
											2020-06-24 00:35:19 +02:00
										 |  |  |     } | 
					
						
							| 
									
										
										
										
											2020-07-26 02:01:34 +02:00
										 |  |  |      | 
					
						
							| 
									
										
										
										
											2020-06-24 00:35:19 +02:00
										 |  |  | } |