1 | import { Directive, EventEmitter, HostListener, Input, Output } from '@angular/core';
|
2 | import { latLng, map } from 'leaflet';
|
3 | import { LeafletUtil } from './leaflet.util';
|
4 | import * as i0 from "@angular/core";
|
5 | export class LeafletDirective {
|
6 | constructor(element, zone) {
|
7 | this.element = element;
|
8 | this.zone = zone;
|
9 | this.DEFAULT_ZOOM = 1;
|
10 | this.DEFAULT_CENTER = latLng(38.907192, -77.036871);
|
11 | this.DEFAULT_FPZ_OPTIONS = {};
|
12 | this.fitBoundsOptions = this.DEFAULT_FPZ_OPTIONS;
|
13 | this.panOptions = this.DEFAULT_FPZ_OPTIONS;
|
14 | this.zoomOptions = this.DEFAULT_FPZ_OPTIONS;
|
15 | this.zoomPanOptions = this.DEFAULT_FPZ_OPTIONS;
|
16 | // Default configuration
|
17 | this.options = {};
|
18 | // Configure callback function for the map
|
19 | this.mapReady = new EventEmitter();
|
20 | this.zoomChange = new EventEmitter();
|
21 | this.centerChange = new EventEmitter();
|
22 | // Mouse Map Events
|
23 | this.onClick = new EventEmitter();
|
24 | this.onDoubleClick = new EventEmitter();
|
25 | this.onMouseDown = new EventEmitter();
|
26 | this.onMouseUp = new EventEmitter();
|
27 | this.onMouseMove = new EventEmitter();
|
28 | this.onMouseOver = new EventEmitter();
|
29 | this.onMouseOut = new EventEmitter();
|
30 | // Map Move Events
|
31 | this.onMapMove = new EventEmitter();
|
32 | this.onMapMoveStart = new EventEmitter();
|
33 | this.onMapMoveEnd = new EventEmitter();
|
34 | // Map Zoom Events
|
35 | this.onMapZoom = new EventEmitter();
|
36 | this.onMapZoomStart = new EventEmitter();
|
37 | this.onMapZoomEnd = new EventEmitter();
|
38 | // Nothing here
|
39 | }
|
40 | ngOnInit() {
|
41 | // Create the map outside of angular so the various map events don't trigger change detection
|
42 | this.zone.runOutsideAngular(() => {
|
43 | // Create the map with some reasonable defaults
|
44 | this.map = map(this.element.nativeElement, this.options);
|
45 | this.addMapEventListeners();
|
46 | });
|
47 | // Only setView if there is a center/zoom
|
48 | if (null != this.center && null != this.zoom) {
|
49 | this.setView(this.center, this.zoom);
|
50 | }
|
51 | // Set up all the initial settings
|
52 | if (null != this.fitBounds) {
|
53 | this.setFitBounds(this.fitBounds);
|
54 | }
|
55 | if (null != this.maxBounds) {
|
56 | this.setMaxBounds(this.maxBounds);
|
57 | }
|
58 | if (null != this.minZoom) {
|
59 | this.setMinZoom(this.minZoom);
|
60 | }
|
61 | if (null != this.maxZoom) {
|
62 | this.setMaxZoom(this.maxZoom);
|
63 | }
|
64 | this.doResize();
|
65 | // Fire map ready event
|
66 | this.mapReady.emit(this.map);
|
67 | }
|
68 | ngOnChanges(changes) {
|
69 | /*
|
70 | * The following code is to address an issue with our (basic) implementation of
|
71 | * zooming and panning. From our testing, it seems that a pan operation followed
|
72 | * by a zoom operation in the same thread will interfere with eachother. The zoom
|
73 | * operation interrupts/cancels the pan, resulting in a final center point that is
|
74 | * inaccurate. The solution seems to be to either separate them with a timeout or
|
75 | * to collapse them into a setView call.
|
76 | */
|
77 | // Zooming and Panning
|
78 | if (changes['zoom'] && changes['center'] && null != this.zoom && null != this.center) {
|
79 | this.setView(changes['center'].currentValue, changes['zoom'].currentValue);
|
80 | }
|
81 | // Set the zoom level
|
82 | else if (changes['zoom']) {
|
83 | this.setZoom(changes['zoom'].currentValue);
|
84 | }
|
85 | // Set the map center
|
86 | else if (changes['center']) {
|
87 | this.setCenter(changes['center'].currentValue);
|
88 | }
|
89 | // Other options
|
90 | if (changes['fitBounds']) {
|
91 | this.setFitBounds(changes['fitBounds'].currentValue);
|
92 | }
|
93 | if (changes['maxBounds']) {
|
94 | this.setMaxBounds(changes['maxBounds'].currentValue);
|
95 | }
|
96 | if (changes['minZoom']) {
|
97 | this.setMinZoom(changes['minZoom'].currentValue);
|
98 | }
|
99 | if (changes['maxZoom']) {
|
100 | this.setMaxZoom(changes['maxZoom'].currentValue);
|
101 | }
|
102 | }
|
103 | ngOnDestroy() {
|
104 | // If this directive is destroyed, the map is too
|
105 | if (null != this.map) {
|
106 | this.map.remove();
|
107 | }
|
108 | }
|
109 | getMap() {
|
110 | return this.map;
|
111 | }
|
112 | onResize() {
|
113 | this.delayResize();
|
114 | }
|
115 | addMapEventListeners() {
|
116 | const registerEventHandler = (eventName, handler) => {
|
117 | this.map.on(eventName, handler);
|
118 | };
|
119 | // Add all the pass-through mouse event handlers
|
120 | registerEventHandler('click', (e) => LeafletUtil.handleEvent(this.zone, this.onClick, e));
|
121 | registerEventHandler('dblclick', (e) => LeafletUtil.handleEvent(this.zone, this.onDoubleClick, e));
|
122 | registerEventHandler('mousedown', (e) => LeafletUtil.handleEvent(this.zone, this.onMouseDown, e));
|
123 | registerEventHandler('mouseup', (e) => LeafletUtil.handleEvent(this.zone, this.onMouseUp, e));
|
124 | registerEventHandler('mouseover', (e) => LeafletUtil.handleEvent(this.zone, this.onMouseOver, e));
|
125 | registerEventHandler('mouseout', (e) => LeafletUtil.handleEvent(this.zone, this.onMouseOut, e));
|
126 | registerEventHandler('mousemove', (e) => LeafletUtil.handleEvent(this.zone, this.onMouseMove, e));
|
127 | registerEventHandler('zoomstart', (e) => LeafletUtil.handleEvent(this.zone, this.onMapZoomStart, e));
|
128 | registerEventHandler('zoom', (e) => LeafletUtil.handleEvent(this.zone, this.onMapZoom, e));
|
129 | registerEventHandler('zoomend', (e) => LeafletUtil.handleEvent(this.zone, this.onMapZoomEnd, e));
|
130 | registerEventHandler('movestart', (e) => LeafletUtil.handleEvent(this.zone, this.onMapMoveStart, e));
|
131 | registerEventHandler('move', (e) => LeafletUtil.handleEvent(this.zone, this.onMapMove, e));
|
132 | registerEventHandler('moveend', (e) => LeafletUtil.handleEvent(this.zone, this.onMapMoveEnd, e));
|
133 | // Update any things for which we provide output bindings
|
134 | const outputUpdateHandler = () => {
|
135 | const zoom = this.map.getZoom();
|
136 | if (zoom !== this.zoom) {
|
137 | this.zoom = zoom;
|
138 | LeafletUtil.handleEvent(this.zone, this.zoomChange, zoom);
|
139 | }
|
140 | const center = this.map.getCenter();
|
141 | if (null != center || null != this.center) {
|
142 | if (((null == center || null == this.center) && center !== this.center)
|
143 | || (center.lat !== this.center.lat || center.lng !== this.center.lng)) {
|
144 | this.center = center;
|
145 | LeafletUtil.handleEvent(this.zone, this.centerChange, center);
|
146 | }
|
147 | }
|
148 | };
|
149 | registerEventHandler('moveend', outputUpdateHandler);
|
150 | registerEventHandler('zoomend', outputUpdateHandler);
|
151 | }
|
152 | /**
|
153 | * Resize the map to fit it's parent container
|
154 | */
|
155 | doResize() {
|
156 | // Run this outside of angular so the map events stay outside of angular
|
157 | this.zone.runOutsideAngular(() => {
|
158 | // Invalidate the map size to trigger it to update itself
|
159 | if (null != this.map) {
|
160 | this.map.invalidateSize({});
|
161 | }
|
162 | });
|
163 | }
|
164 | /**
|
165 | * Manage a delayed resize of the component
|
166 | */
|
167 | delayResize() {
|
168 | if (null != this.resizeTimer) {
|
169 | clearTimeout(this.resizeTimer);
|
170 | }
|
171 | this.resizeTimer = setTimeout(this.doResize.bind(this), 200);
|
172 | }
|
173 | /**
|
174 | * Set the view (center/zoom) all at once
|
175 | * @param center The new center
|
176 | * @param zoom The new zoom level
|
177 | */
|
178 | setView(center, zoom) {
|
179 | if (null != this.map && null != center && null != zoom) {
|
180 | this.map.setView(center, zoom, this.zoomPanOptions);
|
181 | }
|
182 | }
|
183 | /**
|
184 | * Set the map zoom level
|
185 | * @param zoom the new zoom level for the map
|
186 | */
|
187 | setZoom(zoom) {
|
188 | if (null != this.map && null != zoom) {
|
189 | this.map.setZoom(zoom, this.zoomOptions);
|
190 | }
|
191 | }
|
192 | /**
|
193 | * Set the center of the map
|
194 | * @param center the center point
|
195 | */
|
196 | setCenter(center) {
|
197 | if (null != this.map && null != center) {
|
198 | this.map.panTo(center, this.panOptions);
|
199 | }
|
200 | }
|
201 | /**
|
202 | * Fit the map to the bounds
|
203 | * @param latLngBounds the boundary to set
|
204 | */
|
205 | setFitBounds(latLngBounds) {
|
206 | if (null != this.map && null != latLngBounds) {
|
207 | this.map.fitBounds(latLngBounds, this.fitBoundsOptions);
|
208 | }
|
209 | }
|
210 | /**
|
211 | * Set the map's max bounds
|
212 | * @param latLngBounds the boundary to set
|
213 | */
|
214 | setMaxBounds(latLngBounds) {
|
215 | if (null != this.map && null != latLngBounds) {
|
216 | this.map.setMaxBounds(latLngBounds);
|
217 | }
|
218 | }
|
219 | /**
|
220 | * Set the map's min zoom
|
221 | * @param number the new min zoom
|
222 | */
|
223 | setMinZoom(zoom) {
|
224 | if (null != this.map && null != zoom) {
|
225 | this.map.setMinZoom(zoom);
|
226 | }
|
227 | }
|
228 | /**
|
229 | * Set the map's min zoom
|
230 | * @param number the new min zoom
|
231 | */
|
232 | setMaxZoom(zoom) {
|
233 | if (null != this.map && null != zoom) {
|
234 | this.map.setMaxZoom(zoom);
|
235 | }
|
236 | }
|
237 | }
|
238 | LeafletDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.4", ngImport: i0, type: LeafletDirective, deps: [{ token: i0.ElementRef }, { token: i0.NgZone }], target: i0.ɵɵFactoryTarget.Directive });
|
239 | LeafletDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.0.4", type: LeafletDirective, selector: "[leaflet]", inputs: { fitBoundsOptions: ["leafletFitBoundsOptions", "fitBoundsOptions"], panOptions: ["leafletPanOptions", "panOptions"], zoomOptions: ["leafletZoomOptions", "zoomOptions"], zoomPanOptions: ["leafletZoomPanOptions", "zoomPanOptions"], options: ["leafletOptions", "options"], zoom: ["leafletZoom", "zoom"], center: ["leafletCenter", "center"], fitBounds: ["leafletFitBounds", "fitBounds"], maxBounds: ["leafletMaxBounds", "maxBounds"], minZoom: ["leafletMinZoom", "minZoom"], maxZoom: ["leafletMaxZoom", "maxZoom"] }, outputs: { mapReady: "leafletMapReady", zoomChange: "leafletZoomChange", centerChange: "leafletCenterChange", onClick: "leafletClick", onDoubleClick: "leafletDoubleClick", onMouseDown: "leafletMouseDown", onMouseUp: "leafletMouseUp", onMouseMove: "leafletMouseMove", onMouseOver: "leafletMouseOver", onMouseOut: "leafletMouseOut", onMapMove: "leafletMapMove", onMapMoveStart: "leafletMapMoveStart", onMapMoveEnd: "leafletMapMoveEnd", onMapZoom: "leafletMapZoom", onMapZoomStart: "leafletMapZoomStart", onMapZoomEnd: "leafletMapZoomEnd" }, host: { listeners: { "window:resize": "onResize()" } }, usesOnChanges: true, ngImport: i0 });
|
240 | i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.4", ngImport: i0, type: LeafletDirective, decorators: [{
|
241 | type: Directive,
|
242 | args: [{
|
243 | selector: '[leaflet]'
|
244 | }]
|
245 | }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.NgZone }]; }, propDecorators: { fitBoundsOptions: [{
|
246 | type: Input,
|
247 | args: ['leafletFitBoundsOptions']
|
248 | }], panOptions: [{
|
249 | type: Input,
|
250 | args: ['leafletPanOptions']
|
251 | }], zoomOptions: [{
|
252 | type: Input,
|
253 | args: ['leafletZoomOptions']
|
254 | }], zoomPanOptions: [{
|
255 | type: Input,
|
256 | args: ['leafletZoomPanOptions']
|
257 | }], options: [{
|
258 | type: Input,
|
259 | args: ['leafletOptions']
|
260 | }], mapReady: [{
|
261 | type: Output,
|
262 | args: ['leafletMapReady']
|
263 | }], zoom: [{
|
264 | type: Input,
|
265 | args: ['leafletZoom']
|
266 | }], zoomChange: [{
|
267 | type: Output,
|
268 | args: ['leafletZoomChange']
|
269 | }], center: [{
|
270 | type: Input,
|
271 | args: ['leafletCenter']
|
272 | }], centerChange: [{
|
273 | type: Output,
|
274 | args: ['leafletCenterChange']
|
275 | }], fitBounds: [{
|
276 | type: Input,
|
277 | args: ['leafletFitBounds']
|
278 | }], maxBounds: [{
|
279 | type: Input,
|
280 | args: ['leafletMaxBounds']
|
281 | }], minZoom: [{
|
282 | type: Input,
|
283 | args: ['leafletMinZoom']
|
284 | }], maxZoom: [{
|
285 | type: Input,
|
286 | args: ['leafletMaxZoom']
|
287 | }], onClick: [{
|
288 | type: Output,
|
289 | args: ['leafletClick']
|
290 | }], onDoubleClick: [{
|
291 | type: Output,
|
292 | args: ['leafletDoubleClick']
|
293 | }], onMouseDown: [{
|
294 | type: Output,
|
295 | args: ['leafletMouseDown']
|
296 | }], onMouseUp: [{
|
297 | type: Output,
|
298 | args: ['leafletMouseUp']
|
299 | }], onMouseMove: [{
|
300 | type: Output,
|
301 | args: ['leafletMouseMove']
|
302 | }], onMouseOver: [{
|
303 | type: Output,
|
304 | args: ['leafletMouseOver']
|
305 | }], onMouseOut: [{
|
306 | type: Output,
|
307 | args: ['leafletMouseOut']
|
308 | }], onMapMove: [{
|
309 | type: Output,
|
310 | args: ['leafletMapMove']
|
311 | }], onMapMoveStart: [{
|
312 | type: Output,
|
313 | args: ['leafletMapMoveStart']
|
314 | }], onMapMoveEnd: [{
|
315 | type: Output,
|
316 | args: ['leafletMapMoveEnd']
|
317 | }], onMapZoom: [{
|
318 | type: Output,
|
319 | args: ['leafletMapZoom']
|
320 | }], onMapZoomStart: [{
|
321 | type: Output,
|
322 | args: ['leafletMapZoomStart']
|
323 | }], onMapZoomEnd: [{
|
324 | type: Output,
|
325 | args: ['leafletMapZoomEnd']
|
326 | }], onResize: [{
|
327 | type: HostListener,
|
328 | args: ['window:resize', []]
|
329 | }] } });
|
330 | //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"leaflet.directive.js","sourceRoot":"","sources":["../../../../../projects/ngx-leaflet/src/lib/core/leaflet.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n\tDirective, ElementRef, EventEmitter, HostListener, Input, NgZone, OnChanges, OnDestroy, OnInit, Output,\n\tSimpleChange\n} from '@angular/core';\n\nimport { latLng, LatLng, LatLngBounds, LeafletEvent, LeafletMouseEvent, map, Map, MapOptions } from 'leaflet';\n\nimport { LeafletUtil } from './leaflet.util';\n\n@Directive({\n\tselector: '[leaflet]'\n})\nexport class LeafletDirective\n\timplements OnChanges, OnDestroy, OnInit {\n\n\treadonly DEFAULT_ZOOM = 1;\n\treadonly DEFAULT_CENTER = latLng(38.907192, -77.036871);\n\treadonly DEFAULT_FPZ_OPTIONS = {};\n\n\tresizeTimer: any;\n\n\t// Reference to the primary map object\n\tmap: Map;\n\n\t@Input('leafletFitBoundsOptions') fitBoundsOptions = this.DEFAULT_FPZ_OPTIONS;\n\t@Input('leafletPanOptions') panOptions = this.DEFAULT_FPZ_OPTIONS;\n\t@Input('leafletZoomOptions') zoomOptions = this.DEFAULT_FPZ_OPTIONS;\n\t@Input('leafletZoomPanOptions') zoomPanOptions = this.DEFAULT_FPZ_OPTIONS;\n\n\n\t// Default configuration\n\t@Input('leafletOptions') options: MapOptions = {};\n\n\t// Configure callback function for the map\n\t@Output('leafletMapReady') mapReady = new EventEmitter<Map>();\n\n\t// Zoom level for the map\n\t@Input('leafletZoom') zoom: number;\n\t@Output('leafletZoomChange') zoomChange = new EventEmitter<number>();\n\n\t// Center of the map\n\t@Input('leafletCenter') center: LatLng;\n\t@Output('leafletCenterChange') centerChange = new EventEmitter<LatLng>();\n\n\t// Set fit bounds for map\n\t@Input('leafletFitBounds') fitBounds: LatLngBounds;\n\n\t// Set the max bounds for the map\n\t@Input('leafletMaxBounds') maxBounds: LatLngBounds;\n\n\t// Set the min zoom for the map\n\t@Input('leafletMinZoom') minZoom: number;\n\n\t// Set the max zoom for the map\n\t@Input('leafletMaxZoom') maxZoom: number;\n\n\n\t// Mouse Map Events\n\t@Output('leafletClick') onClick = new EventEmitter<LeafletMouseEvent>();\n\t@Output('leafletDoubleClick') onDoubleClick = new EventEmitter<LeafletMouseEvent>();\n\t@Output('leafletMouseDown') onMouseDown = new EventEmitter<LeafletMouseEvent>();\n\t@Output('leafletMouseUp') onMouseUp = new EventEmitter<LeafletMouseEvent>();\n\t@Output('leafletMouseMove') onMouseMove = new EventEmitter<LeafletMouseEvent>();\n\t@Output('leafletMouseOver') onMouseOver = new EventEmitter<LeafletMouseEvent>();\n\t@Output('leafletMouseOut') onMouseOut = new EventEmitter<LeafletMouseEvent>();\n\n\t// Map Move Events\n\t@Output('leafletMapMove') onMapMove = new EventEmitter<LeafletEvent>();\n\t@Output('leafletMapMoveStart') onMapMoveStart = new EventEmitter<LeafletEvent>();\n\t@Output('leafletMapMoveEnd') onMapMoveEnd = new EventEmitter<LeafletEvent>();\n\n\t// Map Zoom Events\n\t@Output('leafletMapZoom') onMapZoom = new EventEmitter<LeafletEvent>();\n\t@Output('leafletMapZoomStart') onMapZoomStart = new EventEmitter<LeafletEvent>();\n\t@Output('leafletMapZoomEnd') onMapZoomEnd = new EventEmitter<LeafletEvent>();\n\n\tconstructor(private element: ElementRef, private zone: NgZone) {\n\t\t// Nothing here\n\t}\n\n\tngOnInit() {\n\n\t\t// Create the map outside of angular so the various map events don't trigger change detection\n\t\tthis.zone.runOutsideAngular(() => {\n\n\t\t\t// Create the map with some reasonable defaults\n\t\t\tthis.map = map(this.element.nativeElement, this.options);\n\t\t\tthis.addMapEventListeners();\n\n\t\t});\n\n\t\t// Only setView if there is a center/zoom\n\t\tif (null != this.center && null != this.zoom) {\n\t\t\tthis.setView(this.center, this.zoom);\n\t\t}\n\n\t\t// Set up all the initial settings\n\t\tif (null != this.fitBounds) {\n\t\t\tthis.setFitBounds(this.fitBounds);\n\t\t}\n\n\t\tif (null != this.maxBounds) {\n\t\t\tthis.setMaxBounds(this.maxBounds);\n\t\t}\n\n\t\tif (null != this.minZoom) {\n\t\t\tthis.setMinZoom(this.minZoom);\n\t\t}\n\n\t\tif (null != this.maxZoom) {\n\t\t\tthis.setMaxZoom(this.maxZoom);\n\t\t}\n\n\t\tthis.doResize();\n\n\t\t// Fire map ready event\n\t\tthis.mapReady.emit(this.map);\n\n\t}\n\n\tngOnChanges(changes: { [key: string]: SimpleChange }) {\n\n\t\t/*\n\t\t * The following code is to address an issue with our (basic) implementation of\n\t\t * zooming and panning. From our testing, it seems that a pan operation followed\n\t\t * by a zoom operation in the same thread will interfere with eachother. The zoom\n\t\t * operation interrupts/cancels the pan, resulting in a final center point that is\n\t\t * inaccurate. The solution seems to be to either separate them with a timeout or\n\t\t  * to collapse them into a setView call.\n\t\t */\n\n\t\t// Zooming and Panning\n\t\tif (changes['zoom'] && changes['center'] && null != this.zoom && null != this.center) {\n\t\t\tthis.setView(changes['center'].currentValue, changes['zoom'].currentValue);\n\t\t}\n\t\t// Set the zoom level\n\t\telse if (changes['zoom']) {\n\t\t\tthis.setZoom(changes['zoom'].currentValue);\n\t\t}\n\t\t// Set the map center\n\t\telse if (changes['center']) {\n\t\t\tthis.setCenter(changes['center'].currentValue);\n\t\t}\n\n\t\t// Other options\n\t\tif (changes['fitBounds']) {\n\t\t\tthis.setFitBounds(changes['fitBounds'].currentValue);\n\t\t}\n\n\t\tif (changes['maxBounds']) {\n\t\t\tthis.setMaxBounds(changes['maxBounds'].currentValue);\n\t\t}\n\n\t\tif (changes['minZoom']) {\n\t\t\tthis.setMinZoom(changes['minZoom'].currentValue);\n\t\t}\n\n\t\tif (changes['maxZoom']) {\n\t\t\tthis.setMaxZoom(changes['maxZoom'].currentValue);\n\t\t}\n\n\t}\n\n\tngOnDestroy() {\n\t\t// If this directive is destroyed, the map is too\n\t\tif (null != this.map) {\n\t\t\tthis.map.remove();\n\t\t}\n\t}\n\n\tpublic getMap() {\n\t\treturn this.map;\n\t}\n\n\n\t@HostListener('window:resize', [])\n\tonResize() {\n\t\tthis.delayResize();\n\t}\n\n\tprivate addMapEventListeners() {\n\n\t\tconst registerEventHandler = (eventName: string, handler: (e: LeafletEvent) => any) => {\n\t\t\tthis.map.on(eventName, handler);\n\t\t};\n\n\n\t\t// Add all the pass-through mouse event handlers\n\t\tregisterEventHandler('click', (e: LeafletMouseEvent) => LeafletUtil.handleEvent(this.zone, this.onClick, e));\n\t\tregisterEventHandler('dblclick', (e: LeafletMouseEvent) => LeafletUtil.handleEvent(this.zone, this.onDoubleClick, e));\n\t\tregisterEventHandler('mousedown', (e: LeafletMouseEvent) => LeafletUtil.handleEvent(this.zone, this.onMouseDown, e));\n\t\tregisterEventHandler('mouseup', (e: LeafletMouseEvent) => LeafletUtil.handleEvent(this.zone, this.onMouseUp, e));\n\t\tregisterEventHandler('mouseover', (e: LeafletMouseEvent) => LeafletUtil.handleEvent(this.zone, this.onMouseOver, e));\n\t\tregisterEventHandler('mouseout', (e: LeafletMouseEvent) => LeafletUtil.handleEvent(this.zone, this.onMouseOut, e));\n\t\tregisterEventHandler('mousemove', (e: LeafletMouseEvent) => LeafletUtil.handleEvent(this.zone, this.onMouseMove, e));\n\n\t\tregisterEventHandler('zoomstart', (e: LeafletEvent) => LeafletUtil.handleEvent(this.zone, this.onMapZoomStart, e));\n\t\tregisterEventHandler('zoom', (e: LeafletEvent) => LeafletUtil.handleEvent(this.zone, this.onMapZoom, e));\n\t\tregisterEventHandler('zoomend', (e: LeafletEvent) => LeafletUtil.handleEvent(this.zone, this.onMapZoomEnd, e));\n\t\tregisterEventHandler('movestart', (e: LeafletEvent) => LeafletUtil.handleEvent(this.zone, this.onMapMoveStart, e));\n\t\tregisterEventHandler('move', (e: LeafletEvent) => LeafletUtil.handleEvent(this.zone, this.onMapMove, e));\n\t\tregisterEventHandler('moveend', (e: LeafletEvent) => LeafletUtil.handleEvent(this.zone, this.onMapMoveEnd, e));\n\n\n\t\t// Update any things for which we provide output bindings\n\t\tconst outputUpdateHandler = () => {\n\t\t\tconst zoom = this.map.getZoom();\n\t\t\tif (zoom !== this.zoom) {\n\t\t\t\tthis.zoom = zoom;\n\t\t\t\tLeafletUtil.handleEvent(this.zone, this.zoomChange, zoom);\n\t\t\t}\n\n\t\t\tconst center = this.map.getCenter();\n\t\t\tif (null != center || null != this.center) {\n\n\t\t\t\tif (((null == center || null == this.center) && center !== this.center)\n\t\t\t\t\t|| (center.lat !== this.center.lat || center.lng !== this.center.lng)) {\n\n\t\t\t\t\tthis.center = center;\n\t\t\t\t\tLeafletUtil.handleEvent(this.zone, this.centerChange, center);\n\n\t\t\t\t}\n\t\t\t}\n\t\t};\n\n\t\tregisterEventHandler('moveend', outputUpdateHandler);\n\t\tregisterEventHandler('zoomend', outputUpdateHandler);\n\t}\n\n\t/**\n\t * Resize the map to fit it's parent container\n\t */\n\tprivate doResize() {\n\n\t\t// Run this outside of angular so the map events stay outside of angular\n\t\tthis.zone.runOutsideAngular(() => {\n\n\t\t\t// Invalidate the map size to trigger it to update itself\n\t\t\tif (null != this.map) {\n\t\t\t\tthis.map.invalidateSize({});\n\t\t\t}\n\n\t\t});\n\n\t}\n\n\t/**\n\t * Manage a delayed resize of the component\n\t */\n\tprivate delayResize() {\n\t\tif (null != this.resizeTimer) {\n\t\t\tclearTimeout(this.resizeTimer);\n\t\t}\n\t\tthis.resizeTimer = setTimeout(this.doResize.bind(this), 200);\n\t}\n\n\n\t/**\n\t * Set the view (center/zoom) all at once\n\t * @param center The new center\n\t * @param zoom The new zoom level\n\t */\n\tprivate setView(center: LatLng, zoom: number) {\n\n\t\tif (null != this.map && null != center && null != zoom) {\n\t\t\tthis.map.setView(center, zoom, this.zoomPanOptions);\n\t\t}\n\n\t}\n\n\t/**\n\t * Set the map zoom level\n\t * @param zoom the new zoom level for the map\n\t */\n\tprivate setZoom(zoom: number) {\n\n\t\tif (null != this.map && null != zoom) {\n\t\t\tthis.map.setZoom(zoom, this.zoomOptions);\n\t\t}\n\n\t}\n\n\t/**\n\t * Set the center of the map\n\t * @param center the center point\n\t */\n\tprivate setCenter(center: LatLng) {\n\n\t\tif (null != this.map && null != center) {\n\t\t\tthis.map.panTo(center, this.panOptions);\n\t\t}\n\n\t}\n\n\t/**\n\t * Fit the map to the bounds\n\t * @param latLngBounds the boundary to set\n\t */\n\tprivate setFitBounds(latLngBounds: LatLngBounds) {\n\n\t\tif (null != this.map && null != latLngBounds) {\n\t\t\tthis.map.fitBounds(latLngBounds, this.fitBoundsOptions);\n\t\t}\n\n\t}\n\n\t/**\n\t * Set the map's max bounds\n\t * @param latLngBounds the boundary to set\n\t */\n\tprivate setMaxBounds(latLngBounds: LatLngBounds) {\n\n\t\tif (null != this.map && null != latLngBounds) {\n\t\t\tthis.map.setMaxBounds(latLngBounds);\n\t\t}\n\n\t}\n\n\t/**\n\t * Set the map's min zoom\n\t * @param number the new min zoom\n\t */\n\tprivate setMinZoom(zoom: number) {\n\n\t\tif (null != this.map && null != zoom) {\n\t\t\tthis.map.setMinZoom(zoom);\n\t\t}\n\n\t}\n\n\t/**\n\t * Set the map's min zoom\n\t * @param number the new min zoom\n\t */\n\tprivate setMaxZoom(zoom: number) {\n\n\t\tif (null != this.map && null != zoom) {\n\t\t\tthis.map.setMaxZoom(zoom);\n\t\t}\n\n\t}\n\n}\n"]} |
\ | No newline at end of file |