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.
- package/esm2022/lib/ca-components.module.mjs +12 -6
- package/esm2022/lib/components/ca-dots-menu/ca-dots-menu.component.mjs +33 -0
- package/esm2022/lib/components/ca-dropdown/ca-dropdown.component.mjs +3 -3
- package/esm2022/lib/components/ca-input/components/ca-input-placeholder-icon/ca-input-placeholder-icon.component.mjs +3 -3
- package/esm2022/lib/components/ca-map/ca-map.component.mjs +270 -187
- package/esm2022/lib/components/ca-map/models/map.model.mjs +1 -1
- package/esm2022/lib/components/ca-map/utils/constants/map-info-window-options.constants.mjs +2 -2
- package/esm2022/lib/components/ca-map/utils/constants/map-options.constants.mjs +15 -1
- package/esm2022/lib/components/ca-map-dropdown/ca-map-dropdown.component.mjs +43 -14
- package/esm2022/lib/components/ca-map-dropdown/models/index.mjs +2 -0
- package/esm2022/lib/components/ca-map-dropdown/models/map-dropdown-content.model.mjs +2 -0
- package/esm2022/lib/components/ca-map-dropdown/pipes/index.mjs +3 -0
- package/esm2022/lib/components/ca-map-dropdown/pipes/map-dropdown-cluster-content-type.pipe.mjs +19 -0
- package/esm2022/lib/components/ca-map-dropdown/pipes/map-dropdown-content-type.pipe.mjs +19 -0
- package/esm2022/lib/components/ca-map-dropdown/utils/svg-routes/map-dropdown-svg-routes.mjs +4 -1
- package/esm2022/lib/components/ca-period-content/components/ca-period-content-payment/ca-period-content-payment.component.mjs +8 -4
- package/esm2022/lib/components/ca-progress-bar/ca-progress-bar.component.mjs +1 -1
- package/esm2022/public-api.mjs +2 -1
- package/fesm2022/ca-components.mjs +403 -212
- package/fesm2022/ca-components.mjs.map +1 -1
- package/lib/ca-components.module.d.ts +2 -1
- package/lib/components/ca-dots-menu/ca-dots-menu.component.d.ts +12 -0
- package/lib/components/ca-map/ca-map.component.d.ts +48 -16
- package/lib/components/ca-map/models/map.model.d.ts +15 -3
- package/lib/components/ca-map/utils/constants/map-options.constants.d.ts +18 -0
- package/lib/components/ca-map-dropdown/ca-map-dropdown.component.d.ts +13 -6
- package/lib/components/ca-map-dropdown/models/index.d.ts +1 -0
- package/lib/components/ca-map-dropdown/models/map-dropdown-content.model.d.ts +28 -0
- package/lib/components/ca-map-dropdown/pipes/index.d.ts +2 -0
- package/lib/components/ca-map-dropdown/pipes/map-dropdown-cluster-content-type.pipe.d.ts +8 -0
- package/lib/components/ca-map-dropdown/pipes/map-dropdown-content-type.pipe.d.ts +8 -0
- package/lib/components/ca-map-dropdown/utils/svg-routes/map-dropdown-svg-routes.d.ts +3 -0
- package/package.json +1 -1
- package/public-api.d.ts +1 -0
- package/src/assets/ca-components/svg/map/ic_date_checked.svg +1 -0
- package/src/assets/ca-components/svg/map/ic_date_deactivated.svg +3 -0
- package/src/assets/ca-components/svg/map/ic_favorite.svg +3 -0
- 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,
|
|
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
|
-
//
|
|
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.
|
|
25
|
-
this.
|
|
26
|
-
this.
|
|
27
|
-
this.
|
|
28
|
-
this.
|
|
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.
|
|
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.
|
|
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
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
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.
|
|
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.
|
|
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
|
-
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
|
|
176
|
-
|
|
177
|
-
|
|
178
|
-
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
|
|
190
|
-
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
|
|
203
|
-
|
|
204
|
-
|
|
205
|
-
|
|
206
|
-
|
|
207
|
-
|
|
208
|
-
|
|
209
|
-
|
|
210
|
-
|
|
211
|
-
|
|
212
|
-
|
|
213
|
-
|
|
214
|
-
|
|
215
|
-
|
|
216
|
-
|
|
217
|
-
|
|
218
|
-
|
|
219
|
-
|
|
220
|
-
|
|
221
|
-
|
|
222
|
-
|
|
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.
|
|
228
|
-
|
|
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.
|
|
257
|
-
|
|
258
|
-
|
|
259
|
-
|
|
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.
|
|
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.
|
|
275
|
-
const stateBoundariesUrl = this.
|
|
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.
|
|
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.
|
|
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.
|
|
298
|
-
...(this.
|
|
299
|
-
...(this.
|
|
261
|
+
...(this.mapData.routingMarkers ?? []),
|
|
262
|
+
...(this.mapData.clusterMarkers ?? []),
|
|
263
|
+
...(this.mapData.markers ?? []),
|
|
300
264
|
];
|
|
301
|
-
|
|
302
|
-
|
|
303
|
-
|
|
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: {
|
|
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: ["
|
|
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
|
|
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
|
-
}],
|
|
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:
|
|
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"]}
|