ca-components 1.0.3 → 1.0.4

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (38) hide show
  1. package/esm2022/lib/ca-components.module.mjs +12 -6
  2. package/esm2022/lib/components/ca-dots-menu/ca-dots-menu.component.mjs +33 -0
  3. package/esm2022/lib/components/ca-dropdown/ca-dropdown.component.mjs +3 -3
  4. package/esm2022/lib/components/ca-input/components/ca-input-placeholder-icon/ca-input-placeholder-icon.component.mjs +3 -3
  5. package/esm2022/lib/components/ca-map/ca-map.component.mjs +270 -187
  6. package/esm2022/lib/components/ca-map/models/map.model.mjs +1 -1
  7. package/esm2022/lib/components/ca-map/utils/constants/map-info-window-options.constants.mjs +2 -2
  8. package/esm2022/lib/components/ca-map/utils/constants/map-options.constants.mjs +15 -1
  9. package/esm2022/lib/components/ca-map-dropdown/ca-map-dropdown.component.mjs +43 -14
  10. package/esm2022/lib/components/ca-map-dropdown/models/index.mjs +2 -0
  11. package/esm2022/lib/components/ca-map-dropdown/models/map-dropdown-content.model.mjs +2 -0
  12. package/esm2022/lib/components/ca-map-dropdown/pipes/index.mjs +3 -0
  13. package/esm2022/lib/components/ca-map-dropdown/pipes/map-dropdown-cluster-content-type.pipe.mjs +19 -0
  14. package/esm2022/lib/components/ca-map-dropdown/pipes/map-dropdown-content-type.pipe.mjs +19 -0
  15. package/esm2022/lib/components/ca-map-dropdown/utils/svg-routes/map-dropdown-svg-routes.mjs +4 -1
  16. package/esm2022/lib/components/ca-period-content/components/ca-period-content-payment/ca-period-content-payment.component.mjs +8 -4
  17. package/esm2022/lib/components/ca-progress-bar/ca-progress-bar.component.mjs +1 -1
  18. package/esm2022/public-api.mjs +2 -1
  19. package/fesm2022/ca-components.mjs +403 -212
  20. package/fesm2022/ca-components.mjs.map +1 -1
  21. package/lib/ca-components.module.d.ts +2 -1
  22. package/lib/components/ca-dots-menu/ca-dots-menu.component.d.ts +12 -0
  23. package/lib/components/ca-map/ca-map.component.d.ts +48 -16
  24. package/lib/components/ca-map/models/map.model.d.ts +15 -3
  25. package/lib/components/ca-map/utils/constants/map-options.constants.d.ts +18 -0
  26. package/lib/components/ca-map-dropdown/ca-map-dropdown.component.d.ts +13 -6
  27. package/lib/components/ca-map-dropdown/models/index.d.ts +1 -0
  28. package/lib/components/ca-map-dropdown/models/map-dropdown-content.model.d.ts +28 -0
  29. package/lib/components/ca-map-dropdown/pipes/index.d.ts +2 -0
  30. package/lib/components/ca-map-dropdown/pipes/map-dropdown-cluster-content-type.pipe.d.ts +8 -0
  31. package/lib/components/ca-map-dropdown/pipes/map-dropdown-content-type.pipe.d.ts +8 -0
  32. package/lib/components/ca-map-dropdown/utils/svg-routes/map-dropdown-svg-routes.d.ts +3 -0
  33. package/package.json +1 -1
  34. package/public-api.d.ts +1 -0
  35. package/src/assets/ca-components/svg/map/ic_date_checked.svg +1 -0
  36. package/src/assets/ca-components/svg/map/ic_date_deactivated.svg +3 -0
  37. package/src/assets/ca-components/svg/map/ic_favorite.svg +3 -0
  38. package/src/assets/ca-components/svg/map/ic_permanently_closed.svg +4 -0
@@ -1,17 +1,13 @@
1
1
  import { CommonModule } from '@angular/common';
2
- import { Component, EventEmitter, Input, Output, ViewChild, ViewChildren, ViewEncapsulation, } from '@angular/core';
3
- //Modules
2
+ import { Component, EventEmitter, Input, Output, ViewChild, ViewEncapsulation, } from '@angular/core';
4
3
  import { GoogleMap, GoogleMapsModule, MapInfoWindow, } from '@angular/google-maps';
5
- //icon
6
4
  import { AngularSvgIconModule } from 'angular-svg-icon';
7
- //Components
5
+ // Components
8
6
  import { CaMapDropdownComponent } from '../ca-map-dropdown/ca-map-dropdown.component';
9
- //Enums
7
+ // Enums
10
8
  import { GoogleMapEnum } from '../ca-map/enums/google-map.enum';
11
- //HelperFuntion
9
+ // Helpers
12
10
  import { MapHelper } from '../ca-map/utils/helpers/map.helper';
13
- //svg-routes
14
- import { MapSvgRoutes } from '../ca-map/utils/map-svg-routes/map-svg-routes';
15
11
  // Constants
16
12
  import { MapInfoWindowOptionsConstants, MapOptionsConstants, } from './utils/constants';
17
13
  import { MapConstants } from '../../constants/map.constant';
@@ -21,11 +17,11 @@ import * as i2 from "@angular/common";
21
17
  export class CaMapComponent {
22
18
  constructor(cd) {
23
19
  this.cd = cd;
24
- this.markerClick = new EventEmitter();
25
- this.currentlyOpenWindowIndex = null;
26
- this.currentlyOpenWindowIndexRouting = null;
27
- this.showLabel = true;
28
- this.focusedIcon = null;
20
+ this.resetSelectedMarkerItem = new EventEmitter();
21
+ this.clusterMarkerClick = new EventEmitter();
22
+ this.clusterListScrollEvent = new EventEmitter();
23
+ this.getInfoWindowData = new EventEmitter();
24
+ this.boundsChanged = new EventEmitter();
29
25
  this.directionService = new google.maps.DirectionsService();
30
26
  this.directionsRenderers = [];
31
27
  this.initialIcons = [];
@@ -35,6 +31,16 @@ export class CaMapComponent {
35
31
  this.mapZoom = MapOptionsConstants.defaultMapZoom;
36
32
  this.mapCenter = MapOptionsConstants.defaultMapCenter;
37
33
  this.map = null;
34
+ this.isMapCenterSet = false;
35
+ this.clusterMarkersData = [];
36
+ this.markersData = [];
37
+ this.mapData = {};
38
+ this.openedInfoWindowData = null;
39
+ this.areaFilterData = MapOptionsConstants.areaFilterData;
40
+ this.isAreaFilterActive = false;
41
+ }
42
+ set data(values) {
43
+ this.handleMapData(values);
38
44
  }
39
45
  ngOnInit() {
40
46
  this.storeInitialIconForMarker();
@@ -45,78 +51,41 @@ export class CaMapComponent {
45
51
  //Display routes for routingMarkers
46
52
  this.calculateAndDisplayRoute();
47
53
  }
48
- ngOnChanges(changes) {
49
- if (changes['routingMarkers']) {
50
- this.data.routingMarkers = changes['routingMarkers'].currentValue;
51
- }
52
- }
53
54
  storeInitialIconForMarker() {
54
- this.data.markers?.forEach((marker, index) => {
55
+ this.initialMarkerIcons = [];
56
+ this.mapData.markers?.forEach((marker, index) => {
55
57
  this.initialMarkerIcons[index] = {
56
58
  url: marker.icon.url,
57
59
  labelOrigin: marker.icon.labelOrigin,
60
+ zIndex: marker.options?.zIndex ?? 1,
58
61
  };
59
62
  });
60
63
  }
61
64
  storeInitialIconForRoutingMarker() {
62
- this.data.routingMarkers?.forEach((marker, index) => {
65
+ this.mapData.routingMarkers?.forEach((marker, index) => {
63
66
  this.initialIcons[index] = {
64
67
  url: marker.icon.url,
65
68
  labelOrigin: marker.icon.labelOrigin,
66
69
  };
67
70
  });
68
71
  }
69
- onMarkerClick(i, event, markeritem) {
70
- if (markeritem?.infoWindowContent) {
71
- if (this.currentlyOpenWindowIndex === i && this.currentlyOpenWindow) {
72
- const infoWindow = this.infoWindowsView.toArray()[i];
73
- // Close the currently open info window and reset the index
74
- this.data.markers.map((item, index) => {
75
- if (index === i) {
76
- item.icon = {
77
- url: this.initialMarkerIcons[index].url,
78
- labelOrigin: this.initialMarkerIcons[index].labelOrigin,
79
- };
80
- }
81
- });
82
- infoWindow.close();
83
- this.currentlyOpenWindowIndex = null;
84
- this.focusedIcon = null;
85
- }
86
- else {
87
- const markerIndex = this.marker.toArray()[i];
88
- const infoWindow = this.infoWindowsView.toArray()[i];
89
- if (this.currentlyOpenWindow) {
90
- this.currentlyOpenWindow.close();
91
- }
92
- if (infoWindow) {
93
- this.data.markers.map((item, index) => {
94
- if (index === i) {
95
- this.focusedIcon = i;
96
- this.showLabel = false;
97
- item.icon = {
98
- url: this.initialMarkerIcons[index].url,
99
- scaledSize: new google.maps.Size(55, 55),
100
- };
101
- }
102
- else {
103
- this.showLabel = true;
104
- item.icon = {
105
- url: this.initialMarkerIcons[index].url,
106
- labelOrigin: this.initialMarkerIcons[index].labelOrigin,
107
- };
108
- }
109
- });
110
- infoWindow.open(markerIndex);
111
- this.currentlyOpenWindow = infoWindow;
112
- this.currentlyOpenWindowIndex = i;
113
- this.markerClick.emit(event);
114
- }
115
- }
116
- }
117
- else {
118
- return;
119
- }
72
+ onClusterMarkerClick(markerItem) {
73
+ const isInfoWindowOpened = this.checkInfoWindowPosition(markerItem, this.openedInfoWindowData);
74
+ if (!isInfoWindowOpened)
75
+ this.clusterMarkerClick.emit(markerItem);
76
+ else
77
+ this.closeInfoWindow();
78
+ }
79
+ getMarkerInfoWindow(markerId) {
80
+ if (markerId)
81
+ this.getInfoWindowData.emit(markerId);
82
+ }
83
+ onMarkerClick(markerItem) {
84
+ const isInfoWindowOpened = this.checkInfoWindowPosition(markerItem, this.openedInfoWindowData);
85
+ if (!isInfoWindowOpened)
86
+ this.getMarkerInfoWindow(markerItem.data.id);
87
+ else
88
+ this.closeInfoWindow();
120
89
  }
121
90
  setDirectionsOnMap() {
122
91
  if (this.maps?.googleMap) {
@@ -124,11 +93,11 @@ export class CaMapComponent {
124
93
  }
125
94
  }
126
95
  calculateAndDisplayRoute() {
127
- if (this.data.routePaths) {
96
+ if (this.mapData.routePaths) {
128
97
  // Clear previous directions renderers
129
98
  this.directionsRenderers.forEach((renderer) => renderer.setMap(null));
130
99
  this.directionsRenderers = [];
131
- this.data.routePaths.forEach((route) => {
100
+ this.mapData.routePaths.forEach((route) => {
132
101
  const request = {
133
102
  origin: route.path[0],
134
103
  destination: route.path[route.path.length - 1],
@@ -161,88 +130,77 @@ export class CaMapComponent {
161
130
  }
162
131
  }
163
132
  onRoutingMarkerClick(i, event, markeritem) {
164
- if (markeritem?.infoWindowContent) {
165
- if (this.currentlyOpenWindowIndexRouting === i &&
166
- this.currentlyOpenWindowRouting) {
167
- const infoWindow = this.infoWindowsViewRouting.toArray()[i];
168
- // Close the currently open info window and reset the index
169
- this.data.routingMarkers.map((item, index) => {
170
- if (index === i) {
171
- item.icon = {
172
- url: this.initialIcons[index].url,
173
- labelOrigin: this.initialIcons[index].labelOrigin,
174
- };
175
- }
176
- });
177
- infoWindow.close();
178
- this.currentlyOpenWindowIndexRouting = null;
179
- }
180
- else {
181
- const markerIndex = this.markerRouting.toArray()[i];
182
- const infoWindow = this.infoWindowsViewRouting.toArray()[i];
183
- if (this.currentlyOpenWindowRouting) {
184
- this.currentlyOpenWindowRouting.close();
185
- }
186
- if (infoWindow) {
187
- // Restore the previous icon for the previously focused routing marker
188
- if (this.focusedIconRouting !== undefined &&
189
- this.focusedIconRouting !== i) {
190
- const previousFocusedItem = this.data.routingMarkers[this.focusedIconRouting];
191
- if (previousFocusedItem) {
192
- previousFocusedItem.icon = {
193
- url: this.initialIcons[this.focusedIconRouting].url,
194
- labelOrigin: this.initialIcons[this.focusedIconRouting].labelOrigin,
195
- };
196
- }
197
- }
198
- // Update the current marker
199
- this.data.routingMarkers.map((item, index) => {
200
- if (index === i) {
201
- this.previousIconUrlRouting = item.icon ? item.icon.url : '';
202
- this.focusedIconRouting = i;
203
- this.showLabel = false;
204
- item.icon = {
205
- url: this.data.isUnitViewStops || this.data.isDriverMiles
206
- ? item.icon.url
207
- : MapSvgRoutes.markerSvgRoute,
208
- };
209
- }
210
- else {
211
- this.showLabel = true;
212
- }
213
- });
214
- infoWindow.open(markerIndex);
215
- this.currentlyOpenWindowRouting = infoWindow;
216
- this.currentlyOpenWindowIndexRouting = i;
217
- this.markerClick.emit(event);
218
- }
219
- }
220
- }
221
- else {
222
- return;
223
- }
133
+ // if (markeritem?.infoWindowContent) {
134
+ // if (
135
+ // this.currentlyOpenWindowIndexRouting === i &&
136
+ // this.currentlyOpenWindowRouting
137
+ // ) {
138
+ // const infoWindow = this.infoWindowsViewRouting.toArray()[i];
139
+ // // Close the currently open info window and reset the index
140
+ // this.mapData.routingMarkers!.map((item: IMapMarkers, index: number) => {
141
+ // if (index === i) {
142
+ // item.icon = {
143
+ // url: this.initialIcons[index]!.url,
144
+ // labelOrigin: this.initialIcons[index]!.labelOrigin,
145
+ // };
146
+ // }
147
+ // });
148
+ // infoWindow.close();
149
+ // this.currentlyOpenWindowIndexRouting = null;
150
+ // } else {
151
+ // const markerIndex = this.markerRouting.toArray()[i];
152
+ // const infoWindow = this.infoWindowsViewRouting.toArray()[i];
153
+ // if (this.currentlyOpenWindowRouting) {
154
+ // this.currentlyOpenWindowRouting.close();
155
+ // }
156
+ // if (infoWindow) {
157
+ // // Restore the previous icon for the previously focused routing marker
158
+ // if (
159
+ // this.focusedIconRouting !== undefined &&
160
+ // this.focusedIconRouting !== i
161
+ // ) {
162
+ // const previousFocusedItem =
163
+ // this.mapData.routingMarkers![this.focusedIconRouting];
164
+ // if (previousFocusedItem) {
165
+ // previousFocusedItem.icon = {
166
+ // url: this.initialIcons[this.focusedIconRouting].url,
167
+ // labelOrigin:
168
+ // this.initialIcons[this.focusedIconRouting].labelOrigin,
169
+ // };
170
+ // }
171
+ // }
172
+ // // Update the current marker
173
+ // this.mapData.routingMarkers!.map(
174
+ // (item: IMapMarkers, index: number) => {
175
+ // if (index === i) {
176
+ // this.previousIconUrlRouting = item.icon ? item.icon.url : '';
177
+ // this.focusedIconRouting = i;
178
+ // this.showLabel = false;
179
+ // item.icon = {
180
+ // url:
181
+ // this.mapData.isUnitViewStops || this.mapData.isDriverMiles
182
+ // ? item.icon!.url
183
+ // : MapSvgRoutes.markerSvgRoute,
184
+ // };
185
+ // } else {
186
+ // this.showLabel = true;
187
+ // }
188
+ // }
189
+ // );
190
+ // infoWindow.open(markerIndex);
191
+ // this.currentlyOpenWindowRouting = infoWindow;
192
+ // this.currentlyOpenWindowIndexRouting = i;
193
+ // }
194
+ // }
195
+ // this.markerClick.emit(markeritem);
196
+ // } else {
197
+ // return;
198
+ // }
224
199
  }
225
200
  ngAfterViewInit() {
226
201
  this.maps.googleMap?.addListener('click', () => {
227
- this.infoWindowsView.forEach((window) => {
228
- window.close();
229
- this.currentlyOpenWindow = null;
230
- });
231
- this.infoWindowsViewRouting.forEach((window) => {
232
- window.close();
233
- this.currentlyOpenWindowRouting = null;
234
- });
235
- this.data.markers?.forEach((item, i) => {
236
- if (i === this.focusedIcon) {
237
- item.icon = {
238
- url: this.initialMarkerIcons[i].url,
239
- labelOrigin: this.initialMarkerIcons[i].labelOrigin,
240
- };
241
- this.focusedIcon = null;
242
- this.cd.detectChanges();
243
- }
244
- });
245
- this.data.routingMarkers?.map((item, i) => {
202
+ this.closeInfoWindow();
203
+ this.mapData.routingMarkers?.map((item, i) => {
246
204
  if (i === this.focusedIconRouting) {
247
205
  item.icon = {
248
206
  url: this.initialIcons[i].url,
@@ -253,16 +211,20 @@ export class CaMapComponent {
253
211
  });
254
212
  }
255
213
  resetMarkersIcons() {
256
- this.data.markers?.forEach((marker, index) => {
257
- marker.icon = {
258
- url: this.initialMarkerIcons[index].url,
259
- labelOrigin: this.initialMarkerIcons[index].labelOrigin,
214
+ this.mapData.markers?.map((marker, index) => {
215
+ return {
216
+ ...marker,
217
+ icon: {
218
+ ...marker.icon,
219
+ scaledSize: MapOptionsConstants.defaultMarkerSize,
220
+ },
221
+ options: { zIndex: index + 1 },
260
222
  };
261
223
  });
262
224
  this.cd.detectChanges();
263
225
  }
264
226
  resetRoutingMarkers() {
265
- this.data.routingMarkers?.forEach((marker, index) => {
227
+ this.mapData.routingMarkers?.forEach((marker, index) => {
266
228
  marker.icon = {
267
229
  url: marker.icon.url,
268
230
  labelOrigin: marker.icon.labelOrigin,
@@ -271,12 +233,12 @@ export class CaMapComponent {
271
233
  }
272
234
  onMapReady(mapInstance) {
273
235
  this.map = mapInstance;
274
- if (this.data.stateBoundariesUrl) {
275
- const stateBoundariesUrl = this.data.stateBoundariesUrl.url;
236
+ if (this.mapData.stateBoundariesUrl) {
237
+ const stateBoundariesUrl = this.mapData.stateBoundariesUrl.url;
276
238
  this.maps.googleMap?.data.loadGeoJson(stateBoundariesUrl);
277
239
  this.maps.googleMap?.data.setStyle((feature) => {
278
240
  const stateDensity = feature.getProperty('density');
279
- const { fillColor, fillOpacity } = MapHelper.getFillColorForState(stateDensity, this.data.view || '');
241
+ const { fillColor, fillOpacity } = MapHelper.getFillColorForState(stateDensity, this.mapData.view || '');
280
242
  return {
281
243
  fillColor: fillColor,
282
244
  strokeColor: '#EEEEEE',
@@ -285,22 +247,144 @@ export class CaMapComponent {
285
247
  };
286
248
  });
287
249
  }
250
+ this.sendBoundsChangedEvent();
288
251
  this.setMapStyles();
252
+ this.getMapIdleEvent(mapInstance);
289
253
  }
290
254
  setMapStyles() {
291
- if (this.data?.darkMode)
255
+ if (this.mapData?.darkMode)
292
256
  this.mapOptions = {
293
257
  ...this.mapOptions,
294
258
  styles: MapConstants.GOOGLE_MAP_DARK_STYLES,
295
259
  };
296
260
  const allMarkersCombined = [
297
- ...(this.data.routingMarkers ?? []),
298
- ...(this.data.clusterMarkers ?? []),
299
- ...(this.data.markers ?? []),
261
+ ...(this.mapData.routingMarkers ?? []),
262
+ ...(this.mapData.clusterMarkers ?? []),
263
+ ...(this.mapData.markers ?? []),
300
264
  ];
301
- const mapCenterAndBounds = MapHelper.getMapCenterAndZoom(allMarkersCombined);
302
- this.mapCenter = mapCenterAndBounds.mapCenter;
303
- this.map?.fitBounds(mapCenterAndBounds.bounds);
265
+ if (allMarkersCombined?.length) {
266
+ const mapCenterAndBounds = MapHelper.getMapCenterAndZoom(allMarkersCombined);
267
+ this.map.panTo(mapCenterAndBounds.mapCenter);
268
+ this.map?.fitBounds(mapCenterAndBounds.bounds);
269
+ this.isMapCenterSet = true;
270
+ }
271
+ }
272
+ getMapIdleEvent(map) {
273
+ map.addListener('idle', () => {
274
+ this.sendBoundsChangedEvent();
275
+ });
276
+ }
277
+ sendBoundsChangedEvent() {
278
+ if (this.map) {
279
+ const mapBounds = this.map.getBounds();
280
+ const mapZoom = this.map.getZoom();
281
+ if (mapBounds && mapZoom) {
282
+ const boundsObject = { bounds: mapBounds, zoom: mapZoom };
283
+ this.boundsChanged.emit(boundsObject);
284
+ }
285
+ }
286
+ }
287
+ onClusterBackButtonClick() {
288
+ this.resetSelectedMarkerItem.emit(true);
289
+ }
290
+ getNewData(data) {
291
+ const newMarkers = data?.markers?.map((marker) => {
292
+ const isSelectedMarker = this.checkInfoWindowPosition(marker, this.openedInfoWindowData);
293
+ if (isSelectedMarker) {
294
+ const newMarkerData = {
295
+ ...marker,
296
+ icon: {
297
+ ...marker.icon,
298
+ scaledSize: MapOptionsConstants.largeMarkerSize,
299
+ },
300
+ options: { zIndex: 999 },
301
+ };
302
+ return newMarkerData;
303
+ }
304
+ return marker;
305
+ });
306
+ return {
307
+ ...data,
308
+ markers: newMarkers,
309
+ };
310
+ }
311
+ openMarkerInfoWindow(markerItem) {
312
+ const isInfoWindowOpened = this.checkInfoWindowPosition(markerItem, this.openedInfoWindowData);
313
+ const isClusterItemChanged = this.checkClusterDataChanges(markerItem, this.openedInfoWindowData);
314
+ if (this.infoWindowsView && (!isInfoWindowOpened || isClusterItemChanged)) {
315
+ this.mapData.markers.map((item, index) => {
316
+ const isSelectedMarker = this.checkInfoWindowPosition(item, markerItem);
317
+ if (isSelectedMarker) {
318
+ item.icon = {
319
+ ...item.icon,
320
+ scaledSize: MapOptionsConstants.largeMarkerSize,
321
+ };
322
+ item.options = { zIndex: 999 };
323
+ }
324
+ else {
325
+ item.icon = {
326
+ ...item.icon,
327
+ scaledSize: MapOptionsConstants.defaultMarkerSize,
328
+ };
329
+ item.options = { zIndex: index + 1 };
330
+ }
331
+ });
332
+ this.currentlyOpenWindow = this.infoWindowsView;
333
+ this.openedInfoWindowData = markerItem;
334
+ if (!isInfoWindowOpened) {
335
+ this.map.panTo(markerItem.position);
336
+ setTimeout(() => {
337
+ this.infoWindowOptions = {
338
+ ...this.infoWindowOptions,
339
+ position: markerItem.position,
340
+ };
341
+ this.infoWindowsView.open();
342
+ }, 0);
343
+ }
344
+ }
345
+ }
346
+ checkInfoWindowPosition(markerItem, markerItem2) {
347
+ return (markerItem.position.lat === markerItem2?.position?.lat &&
348
+ markerItem.position.lng === markerItem2?.position?.lng);
349
+ }
350
+ closeInfoWindow() {
351
+ this.resetMarkersIcons();
352
+ this.openedInfoWindowData = null;
353
+ this.currentlyOpenWindow = null;
354
+ this.infoWindowsView.close();
355
+ this.resetSelectedMarkerItem.emit();
356
+ }
357
+ handleMapData(newData) {
358
+ this.mapData = this.getNewData(newData);
359
+ if (this.mapData.selectedMarkerData)
360
+ this.openMarkerInfoWindow(this.mapData.selectedMarkerData);
361
+ else if (this.currentlyOpenWindow)
362
+ this.closeInfoWindow();
363
+ if (newData && !this.isMapCenterSet && this.map) {
364
+ if (newData.markers?.length ||
365
+ newData.clusterMarkers?.length ||
366
+ newData.routingMarkers?.length)
367
+ this.setMapStyles();
368
+ }
369
+ this.cd.detectChanges();
370
+ }
371
+ onClusterListScrollToEnd() {
372
+ if (this.openedInfoWindowData)
373
+ this.clusterListScrollEvent.emit(this.openedInfoWindowData);
374
+ }
375
+ checkClusterDataChanges(newData, previousData) {
376
+ return newData.infoWindowContent?.clusterData
377
+ ? newData.infoWindowContent?.selectedClusterItemData?.data?.id !==
378
+ previousData?.infoWindowContent?.selectedClusterItemData?.data?.id ||
379
+ newData.infoWindowContent?.clusterData?.length !==
380
+ previousData?.infoWindowContent?.clusterData?.length
381
+ : false;
382
+ }
383
+ trackById(index, marker) {
384
+ return marker.data.id;
385
+ }
386
+ trackByPosition(index, marker) {
387
+ return marker.position.lat + marker.position.lng;
304
388
  }
305
389
  identity(index) {
306
390
  return index;
@@ -309,40 +393,39 @@ export class CaMapComponent {
309
393
  this.directionsRenderers.forEach((renderer) => renderer.setMap(null));
310
394
  }
311
395
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CaMapComponent, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); }
312
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: CaMapComponent, isStandalone: true, selector: "app-ca-map", inputs: { data: "data" }, outputs: { markerClick: "markerClick" }, viewQueries: [{ propertyName: "maps", first: true, predicate: GoogleMap, descendants: true }, { propertyName: "marker", predicate: ["marker"], descendants: true }, { propertyName: "infoWindowsView", predicate: MapInfoWindow, descendants: true }, { propertyName: "markerRouting", predicate: ["markerRouting"], descendants: true }, { propertyName: "infoWindowsViewRouting", predicate: MapInfoWindow, descendants: true }], usesOnChanges: true, ngImport: i0, template: "<google-map\n height=\"100%\"\n width=\"100%\"\n [zoom]=\"mapZoom\"\n [center]=\"mapCenter\"\n [options]=\"mapOptions\"\n (mapInitialized)=\"onMapReady($event)\"\n>\n <map-marker\n #marker=\"mapMarker\"\n *ngFor=\"let markeritem of data.markers; let i = index; trackBy: identity\"\n [position]=\"markeritem.position\"\n [icon]=\"markeritem.icon!\"\n [label]=\"focusedIcon !== i ? markeritem.label! : ''\"\n [title]=\"markeritem.title!\"\n [options]=\"markeritem.options!\"\n (mapClick)=\"onMarkerClick(i, $event, markeritem)\"\n >\n <map-info-window\n #infoWindowsView=\"mapInfoWindow\"\n [options]=\"infoWindowOptions\"\n >\n <app-ca-map-dropdown\n [item]=\"data?.viewData?.[i]\"\n [isAccidentMap]=\"data.isAccidentMap ?? false\"\n ></app-ca-map-dropdown>\n </map-info-window>\n </map-marker>\n <map-marker\n *ngFor=\"let marker of data.clusterMarkers; let i = index; trackBy: identity\"\n [position]=\"marker.position\"\n [icon]=\"marker.icon\"\n [label]=\"marker.label!\"\n [title]=\"marker?.title!\"\n >\n </map-marker>\n\n <map-marker\n #markerRouting=\"mapMarker\"\n *ngFor=\"\n let markeritem of data.routingMarkers;\n let i = index;\n trackBy: identity\n \"\n [position]=\"markeritem.position\"\n [icon]=\"markeritem.icon!\"\n [label]=\"focusedIconRouting !== i ? markeritem.label! : ''\"\n [title]=\"markeritem.title!\"\n [options]=\"markeritem.options!\"\n (mapClick)=\"onRoutingMarkerClick(i, $event, markeritem)\"\n >\n <map-info-window #infoWindowsViewRouting=\"mapInfoWindow\">\n <app-ca-map-dropdown [isAccidentMap]=\"false\"></app-ca-map-dropdown>\n </map-info-window>\n </map-marker>\n</google-map>\n", styles: [".gm-style-iw-a .gm-style-iw-t .gm-style-iw.gm-style-iw-c{padding:0!important;border-radius:3px!important;top:70px!important;transform:translate(-50%)!important}.gm-style-iw-a .gm-style-iw-t .gm-style-iw-tc{display:none!important}\n"], dependencies: [{ kind: "ngmodule", type:
313
- //Modules
314
- GoogleMapsModule }, { kind: "component", type: i1.GoogleMap, selector: "google-map", inputs: ["height", "width", "mapTypeId", "center", "zoom", "options"], outputs: ["mapInitialized", "authFailure", "boundsChanged", "centerChanged", "mapClick", "mapDblclick", "mapDrag", "mapDragend", "mapDragstart", "headingChanged", "idle", "maptypeidChanged", "mapMousemove", "mapMouseout", "mapMouseover", "projectionChanged", "mapRightclick", "tilesloaded", "tiltChanged", "zoomChanged"], exportAs: ["googleMap"] }, { kind: "directive", type: i1.MapInfoWindow, selector: "map-info-window", inputs: ["options", "position"], outputs: ["closeclick", "contentChanged", "domready", "positionChanged", "zindexChanged"], exportAs: ["mapInfoWindow"] }, { kind: "directive", type: i1.MapMarker, selector: "map-marker", inputs: ["title", "position", "label", "clickable", "options", "icon", "visible"], outputs: ["animationChanged", "mapClick", "clickableChanged", "cursorChanged", "mapDblclick", "mapDrag", "mapDragend", "draggableChanged", "mapDragstart", "flatChanged", "iconChanged", "mapMousedown", "mapMouseout", "mapMouseover", "mapMouseup", "positionChanged", "mapRightclick", "shapeChanged", "titleChanged", "visibleChanged", "zindexChanged"], exportAs: ["mapMarker"] }, { kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "ngmodule", type: AngularSvgIconModule }, { kind: "component", type:
315
- //Components
316
- CaMapDropdownComponent, selector: "app-ca-map-dropdown", inputs: ["isAccidentMap", "item"], outputs: ["bodyActions"] }], encapsulation: i0.ViewEncapsulation.None }); }
396
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: CaMapComponent, isStandalone: true, selector: "app-ca-map", inputs: { data: "data" }, outputs: { resetSelectedMarkerItem: "resetSelectedMarkerItem", clusterMarkerClick: "clusterMarkerClick", clusterListScrollEvent: "clusterListScrollEvent", getInfoWindowData: "getInfoWindowData", boundsChanged: "boundsChanged" }, viewQueries: [{ propertyName: "maps", first: true, predicate: GoogleMap, descendants: true }, { propertyName: "infoWindowsView", first: true, predicate: MapInfoWindow, descendants: true }], ngImport: i0, template: "<google-map\n height=\"100%\"\n width=\"100%\"\n [zoom]=\"mapZoom\"\n [center]=\"mapCenter\"\n [options]=\"mapOptions\"\n (mapInitialized)=\"onMapReady($event)\"\n>\n <map-marker\n #marker=\"mapMarker\"\n *ngFor=\"let markeritem of mapData.markers; let i = index; trackBy: trackById\"\n [position]=\"markeritem.position\"\n [icon]=\"markeritem.icon!\"\n [label]=\"\n openedInfoWindowData?.position?.lat === markeritem?.position?.lat &&\n openedInfoWindowData?.position?.lng === markeritem?.position?.lng\n ? ''\n : markeritem.label!\n \"\n [options]=\"markeritem.options!\"\n (mapClick)=\"onMarkerClick(markeritem)\"\n >\n </map-marker>\n\n <map-info-window\n #infoWindowsView=\"mapInfoWindow\"\n [options]=\"infoWindowOptions\"\n >\n <ng-container *ngIf=\"openedInfoWindowData !== null\">\n <app-ca-map-dropdown\n [infoWindowContent]=\"openedInfoWindowData.infoWindowContent\"\n [markerData]=\"openedInfoWindowData.data\"\n (onClusterItemClick)=\"getMarkerInfoWindow($event)\"\n (onClusterListScrollToEnd)=\"onClusterListScrollToEnd()\"\n (onBackButtonClick)=\"onClusterBackButtonClick()\"\n ></app-ca-map-dropdown>\n </ng-container>\n </map-info-window>\n\n <map-marker\n #markerCluster=\"mapMarker\"\n *ngFor=\"\n let marker of mapData.clusterMarkers;\n let i = index;\n trackBy: trackByPosition\n \"\n [position]=\"marker.position\"\n [icon]=\"marker.icon\"\n (mapClick)=\"onClusterMarkerClick(marker)\"\n >\n </map-marker>\n\n <ng-container *ngIf=\"isAreaFilterActive\">\n <map-circle\n [options]=\"areaFilterData.options\"\n [center]=\"areaFilterData.center\"\n [radius]=\"areaFilterData.radius\"\n ></map-circle>\n </ng-container>\n\n <map-marker\n #markerRouting=\"mapMarker\"\n *ngFor=\"\n let markeritem of mapData.routingMarkers;\n let i = index;\n trackBy: identity\n \"\n [position]=\"markeritem.position\"\n [icon]=\"markeritem.icon!\"\n [label]=\"focusedIconRouting !== i ? markeritem.label! : ''\"\n [options]=\"markeritem.options!\"\n (mapClick)=\"onRoutingMarkerClick(i, $event, markeritem)\"\n >\n <map-info-window #infoWindowsViewRouting=\"mapInfoWindow\">\n <app-ca-map-dropdown></app-ca-map-dropdown>\n </map-info-window>\n </map-marker>\n</google-map>\n", styles: ["@keyframes dropdown{0%{margin-top:20px;visibility:hidden;opacity:0}to{opacity:1;margin-top:10px;visibility:visible!important}}@keyframes dropup{0%{margin-top:-19px;visibility:hidden;opacity:0}to{margin-top:inherit;visibility:visible!important}}.gm-style-iw-a .gm-style-iw-t .gm-style-iw.gm-style-iw-c{padding:0!important;border-radius:3px!important;top:70px!important;transform:translate(-50%)!important}.gm-style-iw-a .gm-style-iw-t .gm-style-iw-tc{display:none!important}.gm-style div[aria-hidden=true]{width:90px;text-shadow:1px 1px 0px #ffffff,1px -1px 0px #ffffff,-1px -1px 0px #ffffff,-1px 1px 0px #ffffff;text-transform:uppercase;font-size:11px;line-height:12px;text-align:left;font-weight:500;font-family:Montserrat,sans-serif;color:#424242;white-space:nowrap;text-overflow:ellipsis;overflow:hidden;-webkit-user-select:none;user-select:none}@supports (-webkit-line-clamp: 2){.gm-style div[aria-hidden=true]{overflow:hidden;text-overflow:ellipsis;white-space:initial;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}}\n"], dependencies: [{ kind: "ngmodule", type:
397
+ // Modules
398
+ GoogleMapsModule }, { kind: "component", type: i1.GoogleMap, selector: "google-map", inputs: ["height", "width", "mapTypeId", "center", "zoom", "options"], outputs: ["mapInitialized", "authFailure", "boundsChanged", "centerChanged", "mapClick", "mapDblclick", "mapDrag", "mapDragend", "mapDragstart", "headingChanged", "idle", "maptypeidChanged", "mapMousemove", "mapMouseout", "mapMouseover", "projectionChanged", "mapRightclick", "tilesloaded", "tiltChanged", "zoomChanged"], exportAs: ["googleMap"] }, { kind: "directive", type: i1.MapCircle, selector: "map-circle", inputs: ["options", "center", "radius"], outputs: ["centerChanged", "circleClick", "circleDblclick", "circleDrag", "circleDragend", "circleDragstart", "circleMousedown", "circleMousemove", "circleMouseout", "circleMouseover", "circleMouseup", "radiusChanged", "circleRightclick"], exportAs: ["mapCircle"] }, { kind: "directive", type: i1.MapInfoWindow, selector: "map-info-window", inputs: ["options", "position"], outputs: ["closeclick", "contentChanged", "domready", "positionChanged", "zindexChanged"], exportAs: ["mapInfoWindow"] }, { kind: "directive", type: i1.MapMarker, selector: "map-marker", inputs: ["title", "position", "label", "clickable", "options", "icon", "visible"], outputs: ["animationChanged", "mapClick", "clickableChanged", "cursorChanged", "mapDblclick", "mapDrag", "mapDragend", "draggableChanged", "mapDragstart", "flatChanged", "iconChanged", "mapMousedown", "mapMouseout", "mapMouseover", "mapMouseup", "positionChanged", "mapRightclick", "shapeChanged", "titleChanged", "visibleChanged", "zindexChanged"], exportAs: ["mapMarker"] }, { kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "ngmodule", type: AngularSvgIconModule }, { kind: "component", type:
399
+ // Components
400
+ CaMapDropdownComponent, selector: "app-ca-map-dropdown", inputs: ["infoWindowContent", "markerData"], outputs: ["onClusterItemClick", "onClusterListScrollToEnd", "onBackButtonClick", "bodyActions"] }], encapsulation: i0.ViewEncapsulation.None }); }
317
401
  }
318
402
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: CaMapComponent, decorators: [{
319
403
  type: Component,
320
404
  args: [{ selector: 'app-ca-map', standalone: true, imports: [
321
- //Modules
405
+ // Modules
322
406
  GoogleMapsModule,
323
407
  CommonModule,
324
408
  AngularSvgIconModule,
325
- //Components
409
+ // Components
326
410
  CaMapDropdownComponent,
327
- ], encapsulation: ViewEncapsulation.None, template: "<google-map\n height=\"100%\"\n width=\"100%\"\n [zoom]=\"mapZoom\"\n [center]=\"mapCenter\"\n [options]=\"mapOptions\"\n (mapInitialized)=\"onMapReady($event)\"\n>\n <map-marker\n #marker=\"mapMarker\"\n *ngFor=\"let markeritem of data.markers; let i = index; trackBy: identity\"\n [position]=\"markeritem.position\"\n [icon]=\"markeritem.icon!\"\n [label]=\"focusedIcon !== i ? markeritem.label! : ''\"\n [title]=\"markeritem.title!\"\n [options]=\"markeritem.options!\"\n (mapClick)=\"onMarkerClick(i, $event, markeritem)\"\n >\n <map-info-window\n #infoWindowsView=\"mapInfoWindow\"\n [options]=\"infoWindowOptions\"\n >\n <app-ca-map-dropdown\n [item]=\"data?.viewData?.[i]\"\n [isAccidentMap]=\"data.isAccidentMap ?? false\"\n ></app-ca-map-dropdown>\n </map-info-window>\n </map-marker>\n <map-marker\n *ngFor=\"let marker of data.clusterMarkers; let i = index; trackBy: identity\"\n [position]=\"marker.position\"\n [icon]=\"marker.icon\"\n [label]=\"marker.label!\"\n [title]=\"marker?.title!\"\n >\n </map-marker>\n\n <map-marker\n #markerRouting=\"mapMarker\"\n *ngFor=\"\n let markeritem of data.routingMarkers;\n let i = index;\n trackBy: identity\n \"\n [position]=\"markeritem.position\"\n [icon]=\"markeritem.icon!\"\n [label]=\"focusedIconRouting !== i ? markeritem.label! : ''\"\n [title]=\"markeritem.title!\"\n [options]=\"markeritem.options!\"\n (mapClick)=\"onRoutingMarkerClick(i, $event, markeritem)\"\n >\n <map-info-window #infoWindowsViewRouting=\"mapInfoWindow\">\n <app-ca-map-dropdown [isAccidentMap]=\"false\"></app-ca-map-dropdown>\n </map-info-window>\n </map-marker>\n</google-map>\n", styles: [".gm-style-iw-a .gm-style-iw-t .gm-style-iw.gm-style-iw-c{padding:0!important;border-radius:3px!important;top:70px!important;transform:translate(-50%)!important}.gm-style-iw-a .gm-style-iw-t .gm-style-iw-tc{display:none!important}\n"] }]
411
+ ], encapsulation: ViewEncapsulation.None, template: "<google-map\n height=\"100%\"\n width=\"100%\"\n [zoom]=\"mapZoom\"\n [center]=\"mapCenter\"\n [options]=\"mapOptions\"\n (mapInitialized)=\"onMapReady($event)\"\n>\n <map-marker\n #marker=\"mapMarker\"\n *ngFor=\"let markeritem of mapData.markers; let i = index; trackBy: trackById\"\n [position]=\"markeritem.position\"\n [icon]=\"markeritem.icon!\"\n [label]=\"\n openedInfoWindowData?.position?.lat === markeritem?.position?.lat &&\n openedInfoWindowData?.position?.lng === markeritem?.position?.lng\n ? ''\n : markeritem.label!\n \"\n [options]=\"markeritem.options!\"\n (mapClick)=\"onMarkerClick(markeritem)\"\n >\n </map-marker>\n\n <map-info-window\n #infoWindowsView=\"mapInfoWindow\"\n [options]=\"infoWindowOptions\"\n >\n <ng-container *ngIf=\"openedInfoWindowData !== null\">\n <app-ca-map-dropdown\n [infoWindowContent]=\"openedInfoWindowData.infoWindowContent\"\n [markerData]=\"openedInfoWindowData.data\"\n (onClusterItemClick)=\"getMarkerInfoWindow($event)\"\n (onClusterListScrollToEnd)=\"onClusterListScrollToEnd()\"\n (onBackButtonClick)=\"onClusterBackButtonClick()\"\n ></app-ca-map-dropdown>\n </ng-container>\n </map-info-window>\n\n <map-marker\n #markerCluster=\"mapMarker\"\n *ngFor=\"\n let marker of mapData.clusterMarkers;\n let i = index;\n trackBy: trackByPosition\n \"\n [position]=\"marker.position\"\n [icon]=\"marker.icon\"\n (mapClick)=\"onClusterMarkerClick(marker)\"\n >\n </map-marker>\n\n <ng-container *ngIf=\"isAreaFilterActive\">\n <map-circle\n [options]=\"areaFilterData.options\"\n [center]=\"areaFilterData.center\"\n [radius]=\"areaFilterData.radius\"\n ></map-circle>\n </ng-container>\n\n <map-marker\n #markerRouting=\"mapMarker\"\n *ngFor=\"\n let markeritem of mapData.routingMarkers;\n let i = index;\n trackBy: identity\n \"\n [position]=\"markeritem.position\"\n [icon]=\"markeritem.icon!\"\n [label]=\"focusedIconRouting !== i ? markeritem.label! : ''\"\n [options]=\"markeritem.options!\"\n (mapClick)=\"onRoutingMarkerClick(i, $event, markeritem)\"\n >\n <map-info-window #infoWindowsViewRouting=\"mapInfoWindow\">\n <app-ca-map-dropdown></app-ca-map-dropdown>\n </map-info-window>\n </map-marker>\n</google-map>\n", styles: ["@keyframes dropdown{0%{margin-top:20px;visibility:hidden;opacity:0}to{opacity:1;margin-top:10px;visibility:visible!important}}@keyframes dropup{0%{margin-top:-19px;visibility:hidden;opacity:0}to{margin-top:inherit;visibility:visible!important}}.gm-style-iw-a .gm-style-iw-t .gm-style-iw.gm-style-iw-c{padding:0!important;border-radius:3px!important;top:70px!important;transform:translate(-50%)!important}.gm-style-iw-a .gm-style-iw-t .gm-style-iw-tc{display:none!important}.gm-style div[aria-hidden=true]{width:90px;text-shadow:1px 1px 0px #ffffff,1px -1px 0px #ffffff,-1px -1px 0px #ffffff,-1px 1px 0px #ffffff;text-transform:uppercase;font-size:11px;line-height:12px;text-align:left;font-weight:500;font-family:Montserrat,sans-serif;color:#424242;white-space:nowrap;text-overflow:ellipsis;overflow:hidden;-webkit-user-select:none;user-select:none}@supports (-webkit-line-clamp: 2){.gm-style div[aria-hidden=true]{overflow:hidden;text-overflow:ellipsis;white-space:initial;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}}\n"] }]
328
412
  }], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }]; }, propDecorators: { data: [{
329
413
  type: Input
330
- }], markerClick: [{
414
+ }], resetSelectedMarkerItem: [{
415
+ type: Output
416
+ }], clusterMarkerClick: [{
417
+ type: Output
418
+ }], clusterListScrollEvent: [{
419
+ type: Output
420
+ }], getInfoWindowData: [{
421
+ type: Output
422
+ }], boundsChanged: [{
331
423
  type: Output
332
424
  }], maps: [{
333
425
  type: ViewChild,
334
426
  args: [GoogleMap, { static: false }]
335
- }], marker: [{
336
- type: ViewChildren,
337
- args: ['marker']
338
427
  }], infoWindowsView: [{
339
- type: ViewChildren,
340
- args: [MapInfoWindow]
341
- }], markerRouting: [{
342
- type: ViewChildren,
343
- args: ['markerRouting']
344
- }], infoWindowsViewRouting: [{
345
- type: ViewChildren,
428
+ type: ViewChild,
346
429
  args: [MapInfoWindow]
347
430
  }] } });
348
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ca-map.component.js","sourceRoot":"","sources":["../../../../../../projects/ca-components/src/lib/components/ca-map/ca-map.component.ts","../../../../../../projects/ca-components/src/lib/components/ca-map/ca-map.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport {\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  Input,\n  Output,\n  QueryList,\n  SimpleChanges,\n  ViewChild,\n  ViewChildren,\n  ViewEncapsulation,\n} from '@angular/core';\n\n//Modules\nimport {\n  GoogleMap,\n  GoogleMapsModule,\n  MapInfoWindow,\n  MapMarker,\n} from '@angular/google-maps';\n\n//icon\nimport { AngularSvgIconModule } from 'angular-svg-icon';\n\n//Components\nimport { CaMapDropdownComponent } from '../ca-map-dropdown/ca-map-dropdown.component';\n\n//Enums\nimport { GoogleMapEnum } from '../ca-map/enums/google-map.enum';\n//models\nimport {\n  IMapMarkers,\n  IMapRoutePath,\n  ICaMapProps,\n  IMapOptions,\n  IRoutePath,\n} from '../ca-map/models/map.model';\n//HelperFuntion\nimport { MapHelper } from '../ca-map/utils/helpers/map.helper';\n//svg-routes\nimport { MapSvgRoutes } from '../ca-map/utils/map-svg-routes/map-svg-routes';\n\n// Constants\nimport {\n  MapInfoWindowOptionsConstants,\n  MapOptionsConstants,\n} from './utils/constants';\nimport { MapConstants } from '../../constants/map.constant';\n\n@Component({\n  selector: 'app-ca-map',\n  templateUrl: './ca-map.component.html',\n  styleUrls: ['./ca-map.component.scss'],\n  standalone: true,\n  imports: [\n    //Modules\n    GoogleMapsModule,\n    CommonModule,\n    AngularSvgIconModule,\n    //Components\n    CaMapDropdownComponent,\n  ],\n  encapsulation: ViewEncapsulation.None,\n})\nexport class CaMapComponent {\n  constructor(public cd: ChangeDetectorRef) {}\n  @Input() data!: ICaMapProps | any;\n  @Output() markerClick = new EventEmitter<google.maps.MapMouseEvent>();\n  @ViewChild(GoogleMap, { static: false }) maps!: GoogleMap;\n  @ViewChildren('marker') marker!: QueryList<MapMarker>;\n  @ViewChildren(MapInfoWindow) infoWindowsView!: QueryList<MapInfoWindow>;\n  @ViewChildren('markerRouting') markerRouting!: QueryList<MapMarker>;\n  @ViewChildren(MapInfoWindow)\n  public infoWindowsViewRouting!: QueryList<MapInfoWindow>;\n  public currentlyOpenWindow!: MapInfoWindow | null;\n  public currentlyOpenWindowIndex: number | null = null;\n  public currentlyOpenWindowRouting!: MapInfoWindow | null;\n  public currentlyOpenWindowIndexRouting: number | null = null;\n  public showLabel: boolean = true;\n  public previousIconUrl!: string;\n  public focusedIcon: number | null = null;\n  public previousIconUrlRouting!: string;\n  public focusedIconRouting!: number;\n  private directionService = new google.maps.DirectionsService();\n  public directionsRenderers: google.maps.DirectionsRenderer[] = [];\n  public initialIcons: {\n    url: string;\n    labelOrigin?: google.maps.Point;\n  }[] = [];\n  public initialMarkerIcons: {\n    url: string;\n    labelOrigin?: google.maps.Point;\n  }[] = [];\n  public infoWindowOptions: google.maps.InfoWindowOptions =\n    MapInfoWindowOptionsConstants.mapInfoWindowOptions;\n  public mapOptions: IMapOptions = MapOptionsConstants.defaultMapOptions;\n  public mapZoom: number = MapOptionsConstants.defaultMapZoom;\n  public mapCenter: IRoutePath = MapOptionsConstants.defaultMapCenter;\n  public map: google.maps.Map | null = null;\n\n  ngOnInit() {\n    this.storeInitialIconForMarker();\n    this.storeInitialIconForRoutingMarker();\n    // Reset all icons to their initial state on page load\n    this.resetMarkersIcons();\n    this.resetRoutingMarkers();\n    //Display routes for routingMarkers\n    this.calculateAndDisplayRoute();\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (changes['routingMarkers']) {\n      this.data.routingMarkers = changes['routingMarkers'].currentValue;\n    }\n  }\n\n  public storeInitialIconForMarker(): void {\n    this.data!.markers?.forEach((marker: IMapMarkers, index: number) => {\n      this.initialMarkerIcons[index] = {\n        url: marker.icon!.url,\n        labelOrigin: marker.icon!.labelOrigin,\n      };\n    });\n  }\n\n  public storeInitialIconForRoutingMarker(): void {\n    this.data.routingMarkers?.forEach((marker: IMapMarkers, index: number) => {\n      this.initialIcons[index] = {\n        url: marker.icon!.url,\n        labelOrigin: marker.icon!.labelOrigin,\n      };\n    });\n  }\n\n  public onMarkerClick(\n    i: number,\n    event: google.maps.MapMouseEvent,\n    markeritem: IMapMarkers\n  ): void {\n    if (markeritem?.infoWindowContent) {\n      if (this.currentlyOpenWindowIndex === i && this.currentlyOpenWindow) {\n        const infoWindow = this.infoWindowsView.toArray()[i];\n        // Close the currently open info window and reset the index\n        this.data.markers!.map((item: IMapMarkers, index: number) => {\n          if (index === i) {\n            item.icon = {\n              url: this.initialMarkerIcons[index]!.url,\n              labelOrigin: this.initialMarkerIcons[index]!.labelOrigin!,\n            };\n          }\n        });\n\n        infoWindow.close();\n        this.currentlyOpenWindowIndex = null;\n        this.focusedIcon = null;\n      } else {\n        const markerIndex = this.marker.toArray()[i];\n        const infoWindow = this.infoWindowsView.toArray()[i];\n        if (this.currentlyOpenWindow) {\n          this.currentlyOpenWindow.close();\n        }\n        if (infoWindow) {\n          this.data.markers!.map((item: IMapMarkers, index: number) => {\n            if (index === i) {\n              this.focusedIcon = i;\n              this.showLabel = false;\n              item.icon = {\n                url: this.initialMarkerIcons[index]!.url,\n                scaledSize: new google.maps.Size(55, 55),\n              };\n            } else {\n              this.showLabel = true;\n              item.icon = {\n                url: this.initialMarkerIcons[index]!.url,\n                labelOrigin: this.initialMarkerIcons[index]!.labelOrigin,\n              };\n            }\n          });\n\n          infoWindow.open(markerIndex);\n          this.currentlyOpenWindow = infoWindow;\n          this.currentlyOpenWindowIndex = i;\n          this.markerClick.emit(event);\n        }\n      }\n    } else {\n      return;\n    }\n  }\n\n  public setDirectionsOnMap(): void {\n    if (this.maps?.googleMap) {\n      this.directionsRenderers.forEach((renderer) =>\n        renderer.setMap(this.maps?.googleMap!)\n      );\n    }\n  }\n\n  public calculateAndDisplayRoute(): void {\n    if (this.data.routePaths) {\n      // Clear previous directions renderers\n      this.directionsRenderers.forEach((renderer) => renderer.setMap(null));\n      this.directionsRenderers = [];\n\n      this.data.routePaths!.forEach((route: IMapRoutePath) => {\n        const request: google.maps.DirectionsRequest = {\n          origin: route.path[0],\n          destination: route.path[route.path.length - 1],\n          waypoints: route.path\n            .slice(1, route.path.length - 1)\n            .map((position) => ({ location: position })),\n          travelMode: google.maps.TravelMode.BICYCLING,\n        };\n\n        this.directionService.route(request, (result, status) => {\n          if (status === google.maps.DirectionsStatus.OK && result?.routes[0]) {\n            const directionsRenderer = new google.maps.DirectionsRenderer({\n              suppressInfoWindows: true,\n              suppressMarkers: true,\n              preserveViewport: true,\n              polylineOptions: {\n                strokeColor: route.strokeColor || GoogleMapEnum.STROKE_COLOR,\n                strokeOpacity:\n                  route.strokeOpacity || GoogleMapEnum.STROKE_OPACITY,\n                strokeWeight: route.strokeWeight || GoogleMapEnum.STROKE_WEIGHT,\n              },\n            });\n            directionsRenderer.setDirections(result);\n            this.directionsRenderers.push(directionsRenderer);\n            this.setDirectionsOnMap();\n          }\n        });\n      });\n    } else {\n      return;\n    }\n  }\n\n  public onRoutingMarkerClick(\n    i: number,\n    event: google.maps.MapMouseEvent,\n    markeritem: IMapMarkers\n  ): void {\n    if (markeritem?.infoWindowContent) {\n      if (\n        this.currentlyOpenWindowIndexRouting === i &&\n        this.currentlyOpenWindowRouting\n      ) {\n        const infoWindow = this.infoWindowsViewRouting.toArray()[i];\n        // Close the currently open info window and reset the index\n        this.data.routingMarkers!.map((item: IMapMarkers, index: number) => {\n          if (index === i) {\n            item.icon = {\n              url: this.initialIcons[index]!.url,\n              labelOrigin: this.initialIcons[index]!.labelOrigin,\n            };\n          }\n        });\n\n        infoWindow.close();\n        this.currentlyOpenWindowIndexRouting = null;\n      } else {\n        const markerIndex = this.markerRouting.toArray()[i];\n        const infoWindow = this.infoWindowsViewRouting.toArray()[i];\n        if (this.currentlyOpenWindowRouting) {\n          this.currentlyOpenWindowRouting.close();\n        }\n        if (infoWindow) {\n          // Restore the previous icon for the previously focused routing marker\n          if (\n            this.focusedIconRouting !== undefined &&\n            this.focusedIconRouting !== i\n          ) {\n            const previousFocusedItem =\n              this.data.routingMarkers![this.focusedIconRouting];\n            if (previousFocusedItem) {\n              previousFocusedItem.icon = {\n                url: this.initialIcons[this.focusedIconRouting].url,\n                labelOrigin:\n                  this.initialIcons[this.focusedIconRouting].labelOrigin,\n              };\n            }\n          }\n\n          // Update the current marker\n          this.data.routingMarkers!.map((item: IMapMarkers, index: number) => {\n            if (index === i) {\n              this.previousIconUrlRouting = item.icon ? item.icon.url : '';\n              this.focusedIconRouting = i;\n              this.showLabel = false;\n              item.icon = {\n                url:\n                  this.data.isUnitViewStops || this.data.isDriverMiles\n                    ? item.icon!.url\n                    : MapSvgRoutes.markerSvgRoute,\n              };\n            } else {\n              this.showLabel = true;\n            }\n          });\n\n          infoWindow.open(markerIndex);\n          this.currentlyOpenWindowRouting = infoWindow;\n          this.currentlyOpenWindowIndexRouting = i;\n          this.markerClick.emit(event);\n        }\n      }\n    } else {\n      return;\n    }\n  }\n\n  ngAfterViewInit() {\n    this.maps.googleMap?.addListener('click', () => {\n      this.infoWindowsView.forEach((window: MapInfoWindow) => {\n        window.close();\n        this.currentlyOpenWindow = null;\n      });\n      this.infoWindowsViewRouting.forEach((window: MapInfoWindow) => {\n        window.close();\n        this.currentlyOpenWindowRouting = null;\n      });\n      this.data.markers?.forEach((item: IMapMarkers, i: number) => {\n        if (i === this.focusedIcon) {\n          item.icon = {\n            url: this.initialMarkerIcons[i].url,\n            labelOrigin: this.initialMarkerIcons[i].labelOrigin,\n          };\n          this.focusedIcon = null;\n          this.cd.detectChanges();\n        }\n      });\n\n      this.data.routingMarkers?.map((item: IMapMarkers, i: number) => {\n        if (i === this.focusedIconRouting) {\n          item.icon = {\n            url: this.initialIcons[i].url,\n          };\n          this.cd.detectChanges();\n        }\n      });\n    });\n  }\n\n  public resetMarkersIcons(): void {\n    this.data.markers?.forEach((marker: IMapMarkers, index: number) => {\n      marker.icon = {\n        url: this.initialMarkerIcons[index].url,\n        labelOrigin: this.initialMarkerIcons[index].labelOrigin,\n      };\n    });\n    this.cd.detectChanges();\n  }\n\n  public resetRoutingMarkers(): void {\n    this.data.routingMarkers?.forEach((marker: IMapMarkers, index: number) => {\n      marker.icon = {\n        url: marker.icon!.url,\n        labelOrigin: marker.icon!.labelOrigin,\n      };\n    });\n  }\n\n  public onMapReady(mapInstance: google.maps.Map): {\n    fillColor?: string;\n    strokeColor?: string;\n    strokeWeight?: number;\n    fillOpacity?: number;\n  } | void {\n    this.map = mapInstance;\n\n    if (this.data.stateBoundariesUrl) {\n      const stateBoundariesUrl = this.data.stateBoundariesUrl.url;\n      this.maps.googleMap?.data.loadGeoJson(stateBoundariesUrl);\n\n      this.maps.googleMap?.data.setStyle((feature) => {\n        const stateDensity = feature.getProperty('density');\n        const { fillColor, fillOpacity } = MapHelper.getFillColorForState(\n          stateDensity as number,\n          this.data.view || ''\n        );\n        return {\n          fillColor: fillColor,\n          strokeColor: '#EEEEEE',\n          strokeWeight: 0.6,\n          fillOpacity: fillOpacity,\n        };\n      });\n    }\n\n    this.setMapStyles();\n  }\n\n  public setMapStyles(): void {\n    if (this.data?.darkMode)\n      this.mapOptions = {\n        ...this.mapOptions,\n        styles: MapConstants.GOOGLE_MAP_DARK_STYLES,\n      };\n\n    const allMarkersCombined = [\n      ...(this.data.routingMarkers ?? []),\n      ...(this.data.clusterMarkers ?? []),\n      ...(this.data.markers ?? []),\n    ];\n\n    const mapCenterAndBounds =\n      MapHelper.getMapCenterAndZoom(allMarkersCombined);\n\n    this.mapCenter = mapCenterAndBounds.mapCenter;\n    this.map?.fitBounds(mapCenterAndBounds.bounds);\n  }\n\n  public identity(index: number): number {\n    return index;\n  }\n\n  ngOnDestroy() {\n    this.directionsRenderers.forEach((renderer) => renderer.setMap(null));\n  }\n}\n","<google-map\n  height=\"100%\"\n  width=\"100%\"\n  [zoom]=\"mapZoom\"\n  [center]=\"mapCenter\"\n  [options]=\"mapOptions\"\n  (mapInitialized)=\"onMapReady($event)\"\n>\n  <map-marker\n    #marker=\"mapMarker\"\n    *ngFor=\"let markeritem of data.markers; let i = index; trackBy: identity\"\n    [position]=\"markeritem.position\"\n    [icon]=\"markeritem.icon!\"\n    [label]=\"focusedIcon !== i ? markeritem.label! : ''\"\n    [title]=\"markeritem.title!\"\n    [options]=\"markeritem.options!\"\n    (mapClick)=\"onMarkerClick(i, $event, markeritem)\"\n  >\n    <map-info-window\n      #infoWindowsView=\"mapInfoWindow\"\n      [options]=\"infoWindowOptions\"\n    >\n      <app-ca-map-dropdown\n        [item]=\"data?.viewData?.[i]\"\n        [isAccidentMap]=\"data.isAccidentMap ?? false\"\n      ></app-ca-map-dropdown>\n    </map-info-window>\n  </map-marker>\n  <map-marker\n    *ngFor=\"let marker of data.clusterMarkers; let i = index; trackBy: identity\"\n    [position]=\"marker.position\"\n    [icon]=\"marker.icon\"\n    [label]=\"marker.label!\"\n    [title]=\"marker?.title!\"\n  >\n  </map-marker>\n\n  <map-marker\n    #markerRouting=\"mapMarker\"\n    *ngFor=\"\n      let markeritem of data.routingMarkers;\n      let i = index;\n      trackBy: identity\n    \"\n    [position]=\"markeritem.position\"\n    [icon]=\"markeritem.icon!\"\n    [label]=\"focusedIconRouting !== i ? markeritem.label! : ''\"\n    [title]=\"markeritem.title!\"\n    [options]=\"markeritem.options!\"\n    (mapClick)=\"onRoutingMarkerClick(i, $event, markeritem)\"\n  >\n    <map-info-window #infoWindowsViewRouting=\"mapInfoWindow\">\n      <app-ca-map-dropdown [isAccidentMap]=\"false\"></app-ca-map-dropdown>\n    </map-info-window>\n  </map-marker>\n</google-map>\n"]}
431
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ca-map.component.js","sourceRoot":"","sources":["../../../../../../projects/ca-components/src/lib/components/ca-map/ca-map.component.ts","../../../../../../projects/ca-components/src/lib/components/ca-map/ca-map.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport {\n  ChangeDetectorRef,\n  Component,\n  EventEmitter,\n  Input,\n  Output,\n  QueryList,\n  ViewChild,\n  ViewChildren,\n  ViewEncapsulation,\n} from '@angular/core';\nimport {\n  GoogleMap,\n  GoogleMapsModule,\n  MapInfoWindow,\n  MapMarker,\n  MapCircle,\n} from '@angular/google-maps';\nimport { AngularSvgIconModule } from 'angular-svg-icon';\n\n// Components\nimport { CaMapDropdownComponent } from '../ca-map-dropdown/ca-map-dropdown.component';\n\n// Enums\nimport { GoogleMapEnum } from '../ca-map/enums/google-map.enum';\n\n// Models\nimport {\n  IMapMarkers,\n  IMapRoutePath,\n  ICaMapProps,\n  IMapOptions,\n  IRoutePath,\n  IMapBoundsZoom,\n  IMapSelectedMarkerData,\n} from '../ca-map/models/map.model';\n\n// Helpers\nimport { MapHelper } from '../ca-map/utils/helpers/map.helper';\n\n// Svg-routes\nimport { MapSvgRoutes } from '../ca-map/utils/map-svg-routes/map-svg-routes';\n\n// Constants\nimport {\n  MapInfoWindowOptionsConstants,\n  MapOptionsConstants,\n} from './utils/constants';\nimport { MapConstants } from '../../constants/map.constant';\n\n@Component({\n  selector: 'app-ca-map',\n  templateUrl: './ca-map.component.html',\n  styleUrls: ['./ca-map.component.scss'],\n  standalone: true,\n  imports: [\n    // Modules\n    GoogleMapsModule,\n    CommonModule,\n    AngularSvgIconModule,\n\n    // Components\n    CaMapDropdownComponent,\n  ],\n  encapsulation: ViewEncapsulation.None,\n})\nexport class CaMapComponent {\n  constructor(public cd: ChangeDetectorRef) {}\n  @Input() set data(values: ICaMapProps) {\n    this.handleMapData(values);\n  }\n  @Output() resetSelectedMarkerItem = new EventEmitter<boolean>();\n  @Output() clusterMarkerClick = new EventEmitter<IMapMarkers>();\n  @Output() clusterListScrollEvent = new EventEmitter<IMapMarkers>();\n  @Output() getInfoWindowData = new EventEmitter<number>();\n  @Output() boundsChanged = new EventEmitter<IMapBoundsZoom>();\n  @ViewChild(GoogleMap, { static: false }) maps!: GoogleMap;\n  @ViewChild(MapInfoWindow) infoWindowsView!: MapInfoWindow;\n  public currentlyOpenWindow!: MapInfoWindow | null;\n  public currentlyOpenWindowRouting!: MapInfoWindow | null;\n  public previousIconUrl!: string;\n  public previousIconUrlRouting!: string;\n  public focusedIconRouting!: number;\n  private directionService = new google.maps.DirectionsService();\n  public directionsRenderers: google.maps.DirectionsRenderer[] = [];\n  public initialIcons: {\n    url: string;\n    labelOrigin?: google.maps.Point;\n  }[] = [];\n  public initialMarkerIcons: {\n    url: string;\n    labelOrigin?: google.maps.Point;\n    zIndex?: number;\n  }[] = [];\n  public infoWindowOptions: google.maps.InfoWindowOptions =\n    MapInfoWindowOptionsConstants.mapInfoWindowOptions;\n  public mapOptions: IMapOptions = MapOptionsConstants.defaultMapOptions;\n  public mapZoom: number = MapOptionsConstants.defaultMapZoom;\n  public mapCenter: IRoutePath = MapOptionsConstants.defaultMapCenter;\n  public map: google.maps.Map | null = null;\n  public isMapCenterSet: boolean = false;\n  public clusterMarkersData: IMapMarkers[] = [];\n  public markersData: IMapMarkers[] = [];\n  public mapData: ICaMapProps = {};\n  public openedInfoWindowData: IMapMarkers | null = null;\n  public areaFilterData = MapOptionsConstants.areaFilterData;\n  public isAreaFilterActive: boolean = false;\n\n  ngOnInit() {\n    this.storeInitialIconForMarker();\n    this.storeInitialIconForRoutingMarker();\n    // Reset all icons to their initial state on page load\n    this.resetMarkersIcons();\n    this.resetRoutingMarkers();\n    //Display routes for routingMarkers\n    this.calculateAndDisplayRoute();\n  }\n\n  public storeInitialIconForMarker(): void {\n    this.initialMarkerIcons = [];\n\n    this.mapData!.markers?.forEach((marker: IMapMarkers, index: number) => {\n      this.initialMarkerIcons[index] = {\n        url: marker.icon!.url,\n        labelOrigin: marker.icon!.labelOrigin,\n        zIndex: marker.options?.zIndex ?? 1,\n      };\n    });\n  }\n\n  public storeInitialIconForRoutingMarker(): void {\n    this.mapData.routingMarkers?.forEach(\n      (marker: IMapMarkers, index: number) => {\n        this.initialIcons[index] = {\n          url: marker.icon!.url,\n          labelOrigin: marker.icon!.labelOrigin,\n        };\n      }\n    );\n  }\n\n  public onClusterMarkerClick(markerItem: IMapMarkers): void {\n    const isInfoWindowOpened = this.checkInfoWindowPosition(\n      markerItem,\n      this.openedInfoWindowData\n    );\n\n    if (!isInfoWindowOpened) this.clusterMarkerClick.emit(markerItem);\n    else this.closeInfoWindow();\n  }\n\n  public getMarkerInfoWindow(markerId: number): void {\n    if (markerId) this.getInfoWindowData.emit(markerId);\n  }\n\n  public onMarkerClick(markerItem: IMapMarkers): void {\n    const isInfoWindowOpened = this.checkInfoWindowPosition(\n      markerItem,\n      this.openedInfoWindowData\n    );\n\n    if (!isInfoWindowOpened) this.getMarkerInfoWindow(markerItem.data.id);\n    else this.closeInfoWindow();\n  }\n\n  public setDirectionsOnMap(): void {\n    if (this.maps?.googleMap) {\n      this.directionsRenderers.forEach((renderer) =>\n        renderer.setMap(this.maps?.googleMap!)\n      );\n    }\n  }\n\n  public calculateAndDisplayRoute(): void {\n    if (this.mapData.routePaths) {\n      // Clear previous directions renderers\n      this.directionsRenderers.forEach((renderer) => renderer.setMap(null));\n      this.directionsRenderers = [];\n\n      this.mapData.routePaths!.forEach((route: IMapRoutePath) => {\n        const request: google.maps.DirectionsRequest = {\n          origin: route.path[0],\n          destination: route.path[route.path.length - 1],\n          waypoints: route.path\n            .slice(1, route.path.length - 1)\n            .map((position) => ({ location: position })),\n          travelMode: google.maps.TravelMode.BICYCLING,\n        };\n\n        this.directionService.route(request, (result, status) => {\n          if (status === google.maps.DirectionsStatus.OK && result?.routes[0]) {\n            const directionsRenderer = new google.maps.DirectionsRenderer({\n              suppressInfoWindows: true,\n              suppressMarkers: true,\n              preserveViewport: true,\n              polylineOptions: {\n                strokeColor: route.strokeColor || GoogleMapEnum.STROKE_COLOR,\n                strokeOpacity:\n                  route.strokeOpacity || GoogleMapEnum.STROKE_OPACITY,\n                strokeWeight: route.strokeWeight || GoogleMapEnum.STROKE_WEIGHT,\n              },\n            });\n            directionsRenderer.setDirections(result);\n            this.directionsRenderers.push(directionsRenderer);\n            this.setDirectionsOnMap();\n          }\n        });\n      });\n    } else {\n      return;\n    }\n  }\n\n  public onRoutingMarkerClick(\n    i: number,\n    event: google.maps.MapMouseEvent,\n    markeritem: IMapMarkers\n  ): void {\n    // if (markeritem?.infoWindowContent) {\n    //   if (\n    //     this.currentlyOpenWindowIndexRouting === i &&\n    //     this.currentlyOpenWindowRouting\n    //   ) {\n    //     const infoWindow = this.infoWindowsViewRouting.toArray()[i];\n    //     // Close the currently open info window and reset the index\n    //     this.mapData.routingMarkers!.map((item: IMapMarkers, index: number) => {\n    //       if (index === i) {\n    //         item.icon = {\n    //           url: this.initialIcons[index]!.url,\n    //           labelOrigin: this.initialIcons[index]!.labelOrigin,\n    //         };\n    //       }\n    //     });\n    //     infoWindow.close();\n    //     this.currentlyOpenWindowIndexRouting = null;\n    //   } else {\n    //     const markerIndex = this.markerRouting.toArray()[i];\n    //     const infoWindow = this.infoWindowsViewRouting.toArray()[i];\n    //     if (this.currentlyOpenWindowRouting) {\n    //       this.currentlyOpenWindowRouting.close();\n    //     }\n    //     if (infoWindow) {\n    //       // Restore the previous icon for the previously focused routing marker\n    //       if (\n    //         this.focusedIconRouting !== undefined &&\n    //         this.focusedIconRouting !== i\n    //       ) {\n    //         const previousFocusedItem =\n    //           this.mapData.routingMarkers![this.focusedIconRouting];\n    //         if (previousFocusedItem) {\n    //           previousFocusedItem.icon = {\n    //             url: this.initialIcons[this.focusedIconRouting].url,\n    //             labelOrigin:\n    //               this.initialIcons[this.focusedIconRouting].labelOrigin,\n    //           };\n    //         }\n    //       }\n    //       // Update the current marker\n    //       this.mapData.routingMarkers!.map(\n    //         (item: IMapMarkers, index: number) => {\n    //           if (index === i) {\n    //             this.previousIconUrlRouting = item.icon ? item.icon.url : '';\n    //             this.focusedIconRouting = i;\n    //             this.showLabel = false;\n    //             item.icon = {\n    //               url:\n    //                 this.mapData.isUnitViewStops || this.mapData.isDriverMiles\n    //                   ? item.icon!.url\n    //                   : MapSvgRoutes.markerSvgRoute,\n    //             };\n    //           } else {\n    //             this.showLabel = true;\n    //           }\n    //         }\n    //       );\n    //       infoWindow.open(markerIndex);\n    //       this.currentlyOpenWindowRouting = infoWindow;\n    //       this.currentlyOpenWindowIndexRouting = i;\n    //     }\n    //   }\n    //   this.markerClick.emit(markeritem);\n    // } else {\n    //   return;\n    // }\n  }\n\n  ngAfterViewInit() {\n    this.maps.googleMap?.addListener('click', () => {\n      this.closeInfoWindow();\n\n      this.mapData.routingMarkers?.map((item: IMapMarkers, i: number) => {\n        if (i === this.focusedIconRouting) {\n          item.icon = {\n            url: this.initialIcons[i].url,\n          };\n          this.cd.detectChanges();\n        }\n      });\n    });\n  }\n\n  public resetMarkersIcons(): void {\n    this.mapData.markers?.map((marker: IMapMarkers, index: number) => {\n      return {\n        ...marker,\n        icon: {\n          ...marker.icon,\n          scaledSize: MapOptionsConstants.defaultMarkerSize,\n        },\n        options: { zIndex: index + 1 },\n      };\n    });\n\n    this.cd.detectChanges();\n  }\n\n  public resetRoutingMarkers(): void {\n    this.mapData.routingMarkers?.forEach(\n      (marker: IMapMarkers, index: number) => {\n        marker.icon = {\n          url: marker.icon!.url,\n          labelOrigin: marker.icon!.labelOrigin,\n        };\n      }\n    );\n  }\n\n  public onMapReady(mapInstance: google.maps.Map): {\n    fillColor?: string;\n    strokeColor?: string;\n    strokeWeight?: number;\n    fillOpacity?: number;\n  } | void {\n    this.map = mapInstance;\n\n    if (this.mapData.stateBoundariesUrl) {\n      const stateBoundariesUrl = this.mapData.stateBoundariesUrl.url;\n      this.maps.googleMap?.data.loadGeoJson(stateBoundariesUrl);\n\n      this.maps.googleMap?.data.setStyle((feature) => {\n        const stateDensity = feature.getProperty('density');\n        const { fillColor, fillOpacity } = MapHelper.getFillColorForState(\n          stateDensity as number,\n          this.mapData.view || ''\n        );\n        return {\n          fillColor: fillColor,\n          strokeColor: '#EEEEEE',\n          strokeWeight: 0.6,\n          fillOpacity: fillOpacity,\n        };\n      });\n    }\n\n    this.sendBoundsChangedEvent();\n    this.setMapStyles();\n    this.getMapIdleEvent(mapInstance);\n  }\n\n  public setMapStyles(): void {\n    if (this.mapData?.darkMode)\n      this.mapOptions = {\n        ...this.mapOptions,\n        styles: MapConstants.GOOGLE_MAP_DARK_STYLES,\n      };\n\n    const allMarkersCombined = [\n      ...(this.mapData.routingMarkers ?? []),\n      ...(this.mapData.clusterMarkers ?? []),\n      ...(this.mapData.markers ?? []),\n    ];\n\n    if (allMarkersCombined?.length) {\n      const mapCenterAndBounds =\n        MapHelper.getMapCenterAndZoom(allMarkersCombined);\n\n      this.map!.panTo(mapCenterAndBounds.mapCenter);\n      this.map?.fitBounds(mapCenterAndBounds.bounds);\n      this.isMapCenterSet = true;\n    }\n  }\n\n  public getMapIdleEvent(map: google.maps.Map): void {\n    map.addListener('idle', () => {\n      this.sendBoundsChangedEvent();\n    });\n  }\n\n  public sendBoundsChangedEvent(): void {\n    if (this.map) {\n      const mapBounds = this.map.getBounds();\n      const mapZoom = this.map.getZoom();\n\n      if (mapBounds && mapZoom) {\n        const boundsObject = { bounds: mapBounds, zoom: mapZoom };\n        this.boundsChanged.emit(boundsObject);\n      }\n    }\n  }\n\n  public onClusterBackButtonClick(): void {\n    this.resetSelectedMarkerItem.emit(true);\n  }\n\n  private getNewData(data: ICaMapProps): ICaMapProps {\n    const newMarkers = data?.markers?.map((marker: IMapMarkers) => {\n      const isSelectedMarker = this.checkInfoWindowPosition(\n        marker,\n        this.openedInfoWindowData\n      );\n\n      if (isSelectedMarker) {\n        const newMarkerData = {\n          ...marker,\n          icon: {\n            ...marker.icon,\n            scaledSize: MapOptionsConstants.largeMarkerSize,\n          },\n          options: { zIndex: 999 },\n        };\n\n        return newMarkerData;\n      }\n\n      return marker;\n    });\n\n    return {\n      ...data,\n      markers: newMarkers,\n    };\n  }\n\n  public openMarkerInfoWindow(markerItem: IMapSelectedMarkerData): void {\n    const isInfoWindowOpened = this.checkInfoWindowPosition(\n      markerItem,\n      this.openedInfoWindowData\n    );\n\n    const isClusterItemChanged = this.checkClusterDataChanges(\n      markerItem,\n      this.openedInfoWindowData\n    );\n\n    if (this.infoWindowsView && (!isInfoWindowOpened || isClusterItemChanged)) {\n      this.mapData.markers!.map((item: IMapMarkers, index: number) => {\n        const isSelectedMarker = this.checkInfoWindowPosition(item, markerItem);\n        if (isSelectedMarker) {\n          item.icon = {\n            ...item.icon,\n            scaledSize: MapOptionsConstants.largeMarkerSize,\n          };\n          item.options = { zIndex: 999 };\n        } else {\n          item.icon = {\n            ...item.icon,\n            scaledSize: MapOptionsConstants.defaultMarkerSize,\n          };\n          item.options = { zIndex: index + 1 };\n        }\n      });\n\n      this.currentlyOpenWindow = this.infoWindowsView;\n      this.openedInfoWindowData = markerItem;\n\n      if (!isInfoWindowOpened) {\n        this.map!.panTo(markerItem.position);\n\n        setTimeout(() => {\n          this.infoWindowOptions = {\n            ...this.infoWindowOptions,\n            position: markerItem.position,\n          };\n          this.infoWindowsView.open();\n        }, 0);\n      }\n    }\n  }\n\n  public checkInfoWindowPosition(\n    markerItem: IMapMarkers,\n    markerItem2?: IMapMarkers | null\n  ): boolean {\n    return (\n      markerItem.position.lat === markerItem2?.position?.lat &&\n      markerItem.position.lng === markerItem2?.position?.lng\n    );\n  }\n\n  public closeInfoWindow(): void {\n    this.resetMarkersIcons();\n\n    this.openedInfoWindowData = null;\n    this.currentlyOpenWindow = null;\n    this.infoWindowsView.close();\n    this.resetSelectedMarkerItem.emit();\n  }\n\n  public handleMapData(newData: ICaMapProps): void {\n    this.mapData = this.getNewData(newData);\n\n    if (this.mapData.selectedMarkerData)\n      this.openMarkerInfoWindow(this.mapData.selectedMarkerData);\n    else if (this.currentlyOpenWindow) this.closeInfoWindow();\n\n    if (newData && !this.isMapCenterSet && this.map) {\n      if (\n        newData.markers?.length ||\n        newData.clusterMarkers?.length ||\n        newData.routingMarkers?.length\n      )\n        this.setMapStyles();\n    }\n\n    this.cd.detectChanges();\n  }\n\n  public onClusterListScrollToEnd(): void {\n    if (this.openedInfoWindowData)\n      this.clusterListScrollEvent.emit(this.openedInfoWindowData);\n  }\n\n  public checkClusterDataChanges(\n    newData: IMapMarkers,\n    previousData?: IMapMarkers | null\n  ): boolean {\n    return newData.infoWindowContent?.clusterData\n      ? newData.infoWindowContent?.selectedClusterItemData?.data?.id !==\n          previousData?.infoWindowContent?.selectedClusterItemData?.data?.id ||\n          newData.infoWindowContent?.clusterData?.length !==\n            previousData?.infoWindowContent?.clusterData?.length\n      : false;\n  }\n\n  public trackById(index: number, marker: IMapMarkers): number {\n    return marker.data.id;\n  }\n\n  public trackByPosition(index: number, marker: IMapMarkers): number {\n    return marker.position.lat + marker.position.lng;\n  }\n\n  public identity(index: number): number {\n    return index;\n  }\n\n  ngOnDestroy() {\n    this.directionsRenderers.forEach((renderer) => renderer.setMap(null));\n  }\n}\n","<google-map\n  height=\"100%\"\n  width=\"100%\"\n  [zoom]=\"mapZoom\"\n  [center]=\"mapCenter\"\n  [options]=\"mapOptions\"\n  (mapInitialized)=\"onMapReady($event)\"\n>\n  <map-marker\n    #marker=\"mapMarker\"\n    *ngFor=\"let markeritem of mapData.markers; let i = index; trackBy: trackById\"\n    [position]=\"markeritem.position\"\n    [icon]=\"markeritem.icon!\"\n    [label]=\"\n      openedInfoWindowData?.position?.lat === markeritem?.position?.lat &&\n      openedInfoWindowData?.position?.lng === markeritem?.position?.lng\n        ? ''\n        : markeritem.label!\n    \"\n    [options]=\"markeritem.options!\"\n    (mapClick)=\"onMarkerClick(markeritem)\"\n  >\n  </map-marker>\n\n  <map-info-window\n    #infoWindowsView=\"mapInfoWindow\"\n    [options]=\"infoWindowOptions\"\n  >\n    <ng-container *ngIf=\"openedInfoWindowData !== null\">\n      <app-ca-map-dropdown\n        [infoWindowContent]=\"openedInfoWindowData.infoWindowContent\"\n        [markerData]=\"openedInfoWindowData.data\"\n        (onClusterItemClick)=\"getMarkerInfoWindow($event)\"\n        (onClusterListScrollToEnd)=\"onClusterListScrollToEnd()\"\n        (onBackButtonClick)=\"onClusterBackButtonClick()\"\n      ></app-ca-map-dropdown>\n    </ng-container>\n  </map-info-window>\n\n  <map-marker\n    #markerCluster=\"mapMarker\"\n    *ngFor=\"\n      let marker of mapData.clusterMarkers;\n      let i = index;\n      trackBy: trackByPosition\n    \"\n    [position]=\"marker.position\"\n    [icon]=\"marker.icon\"\n    (mapClick)=\"onClusterMarkerClick(marker)\"\n  >\n  </map-marker>\n\n  <ng-container *ngIf=\"isAreaFilterActive\">\n    <map-circle\n      [options]=\"areaFilterData.options\"\n      [center]=\"areaFilterData.center\"\n      [radius]=\"areaFilterData.radius\"\n    ></map-circle>\n  </ng-container>\n\n  <map-marker\n    #markerRouting=\"mapMarker\"\n    *ngFor=\"\n      let markeritem of mapData.routingMarkers;\n      let i = index;\n      trackBy: identity\n    \"\n    [position]=\"markeritem.position\"\n    [icon]=\"markeritem.icon!\"\n    [label]=\"focusedIconRouting !== i ? markeritem.label! : ''\"\n    [options]=\"markeritem.options!\"\n    (mapClick)=\"onRoutingMarkerClick(i, $event, markeritem)\"\n  >\n    <map-info-window #infoWindowsViewRouting=\"mapInfoWindow\">\n      <app-ca-map-dropdown></app-ca-map-dropdown>\n    </map-info-window>\n  </map-marker>\n</google-map>\n"]}