ca-components 1.0.77 → 1.0.78

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 (31) hide show
  1. package/esm2022/lib/components/ca-input/ca-input.component.mjs +1 -1
  2. package/esm2022/lib/components/ca-map/ca-map.component.mjs +137 -210
  3. package/esm2022/lib/components/ca-map/enums/google-map.enum.mjs +2 -1
  4. package/esm2022/lib/components/ca-map/enums/map-marker-string.enum.mjs +2 -1
  5. package/esm2022/lib/components/ca-map/models/map.model.mjs +1 -1
  6. package/esm2022/lib/components/ca-map/utils/constants/index.mjs +2 -1
  7. package/esm2022/lib/components/ca-map/utils/constants/map-marker-icons.constants.mjs +119 -0
  8. package/esm2022/lib/components/ca-map/utils/constants/map-options.constants.mjs +1 -2
  9. package/esm2022/lib/components/ca-map/utils/helpers/map-marker-icon.helper.mjs +50 -12
  10. package/esm2022/lib/components/ca-map/utils/services/index.mjs +2 -0
  11. package/esm2022/lib/components/ca-map/utils/services/map-marker-icon.service.mjs +137 -0
  12. package/esm2022/lib/components/ca-map-dropdown/ca-map-dropdown.component.mjs +25 -11
  13. package/esm2022/lib/components/ca-progress-bar/ca-progress-bar.component.mjs +15 -15
  14. package/esm2022/lib/constants/map.constant.mjs +131 -131
  15. package/esm2022/public-api.mjs +2 -1
  16. package/fesm2022/ca-components.mjs +717 -491
  17. package/fesm2022/ca-components.mjs.map +1 -1
  18. package/lib/components/ca-filters/ca-filter.component.d.ts +2 -2
  19. package/lib/components/ca-map/ca-map.component.d.ts +22 -25
  20. package/lib/components/ca-map/enums/google-map.enum.d.ts +2 -1
  21. package/lib/components/ca-map/enums/map-marker-string.enum.d.ts +2 -1
  22. package/lib/components/ca-map/models/map.model.d.ts +8 -3
  23. package/lib/components/ca-map/utils/constants/index.d.ts +1 -0
  24. package/lib/components/ca-map/utils/constants/map-marker-icons.constants.d.ts +6 -0
  25. package/lib/components/ca-map/utils/helpers/map-marker-icon.helper.d.ts +2 -0
  26. package/lib/components/ca-map/utils/services/index.d.ts +1 -0
  27. package/lib/components/ca-map/utils/services/map-marker-icon.service.d.ts +23 -0
  28. package/lib/components/ca-map-dropdown/ca-map-dropdown.component.d.ts +5 -3
  29. package/lib/components/ca-progress-bar/ca-progress-bar.component.d.ts +3 -1
  30. package/package.json +1 -1
  31. package/public-api.d.ts +1 -0
@@ -0,0 +1,137 @@
1
+ import { Injectable } from '@angular/core';
2
+ import { BehaviorSubject } from 'rxjs';
3
+ // Helpers
4
+ import { MapMarkerIconHelper } from '../helpers';
5
+ // Constants
6
+ import { MapMarkerIconsConstants } from '../constants';
7
+ import * as i0 from "@angular/core";
8
+ export class MapMarkerIconService {
9
+ constructor(rendererFactory) {
10
+ this.clusterMarkerIds = new BehaviorSubject([]);
11
+ this.clusterMarkerIds$ = this.clusterMarkerIds.asObservable();
12
+ this.routingMarkerIds = new BehaviorSubject([]);
13
+ this.routingMarkerIds$ = this.routingMarkerIds.asObservable();
14
+ this.markerElements = new BehaviorSubject([]);
15
+ this.clusterElements = new BehaviorSubject([]);
16
+ this.routingElements = new BehaviorSubject([]);
17
+ this.renderer = rendererFactory.createRenderer(null, null);
18
+ }
19
+ getMarkerIcon(markerId, labelName, isClosed, isFavorite, isAlwaysSelected) {
20
+ const markerElements = this.markerElements.getValue();
21
+ const previousMarkerIcon = markerElements.find((icon) => icon.id === 'marker-' + markerId);
22
+ if (previousMarkerIcon)
23
+ return previousMarkerIcon;
24
+ else {
25
+ const markerElement = this.renderer.createElement('div');
26
+ this.renderer.setAttribute(markerElement, 'id', 'marker-' + markerId);
27
+ this.renderer.addClass(markerElement, 'marker-icon');
28
+ const markerSvg = isClosed
29
+ ? MapMarkerIconsConstants.closedMarker
30
+ : isFavorite
31
+ ? MapMarkerIconsConstants.favoriteMarker
32
+ : MapMarkerIconsConstants.defaultMarker;
33
+ this.renderer.setProperty(markerElement, 'innerHTML', markerSvg);
34
+ if (labelName) {
35
+ const markerLabelElement = this.renderer.createElement('div');
36
+ this.renderer.addClass(markerLabelElement, 'marker-label');
37
+ this.renderer.setProperty(markerLabelElement, 'innerHTML', labelName.toUpperCase());
38
+ this.renderer.appendChild(markerElement, markerLabelElement);
39
+ }
40
+ if (isAlwaysSelected)
41
+ this.renderer.addClass(markerElement, 'selected-permanently');
42
+ markerElements.push(markerElement);
43
+ this.markerElements.next(markerElements);
44
+ return markerElement;
45
+ }
46
+ }
47
+ getClusterMarkerIcon(markerData) {
48
+ const clusterElements = this.clusterElements.getValue();
49
+ const clusterId = this.createClusterId(markerData);
50
+ const previousClusterIcon = clusterElements.find((icon) => icon.id === 'cluster-' + clusterId);
51
+ if (previousClusterIcon)
52
+ return previousClusterIcon;
53
+ else {
54
+ const markerElement = this.renderer.createElement('div');
55
+ this.renderer.setAttribute(markerElement, 'id', 'cluster-' + clusterId);
56
+ this.renderer.addClass(markerElement, 'cluster-icon');
57
+ const markerSvg = MapMarkerIconHelper.getClusterMarker(markerData.data.count, false);
58
+ this.renderer.setProperty(markerElement, 'innerHTML', markerSvg);
59
+ clusterElements.push(markerElement);
60
+ this.clusterElements.next(clusterElements);
61
+ return markerElement;
62
+ }
63
+ }
64
+ getRoutingMarkerIcon(markerData, stopNumber, stopType, isStopChecked, isLightMode, labelName) {
65
+ const routingElements = this.routingElements.getValue();
66
+ const routingId = this.createRoutingId(markerData);
67
+ const previousClusterIcon = routingElements.find((icon) => icon.id === 'routingMarker-' + routingId);
68
+ if (previousClusterIcon)
69
+ return previousClusterIcon;
70
+ else {
71
+ const markerElement = this.renderer.createElement('div');
72
+ this.renderer.setAttribute(markerElement, 'id', 'routingMarker-' + routingId);
73
+ this.renderer.addClass(markerElement, 'routing-icon');
74
+ const markerSvg = MapMarkerIconHelper.getRoutingMarkerIcon(stopNumber, stopType, isStopChecked, isLightMode);
75
+ this.renderer.setProperty(markerElement, 'innerHTML', markerSvg);
76
+ if (labelName) {
77
+ const markerLabelElement = this.renderer.createElement('div');
78
+ this.renderer.addClass(markerLabelElement, 'marker-label');
79
+ this.renderer.setProperty(markerLabelElement, 'innerHTML', labelName.toUpperCase());
80
+ this.renderer.appendChild(markerElement, markerLabelElement);
81
+ }
82
+ routingElements.push(markerElement);
83
+ this.routingElements.next(routingElements);
84
+ return markerElement;
85
+ }
86
+ }
87
+ createClusterId(clusterData) {
88
+ const clusterMarkers = this.clusterMarkerIds.getValue();
89
+ const clusterId = clusterMarkers.find((item) => clusterData.position.lat === item.position.lat &&
90
+ clusterData.position.lng === item.position.lng)?.id;
91
+ if (clusterId)
92
+ return clusterId;
93
+ else {
94
+ const newId = clusterMarkers.length + 1;
95
+ const newData = {
96
+ ...clusterData,
97
+ id: newId,
98
+ };
99
+ clusterMarkers.push(newData);
100
+ this.clusterMarkerIds.next(clusterMarkers);
101
+ return newId;
102
+ }
103
+ }
104
+ createRoutingId(markerData) {
105
+ const routingMarkers = this.routingMarkerIds.getValue();
106
+ const routingId = routingMarkers.find((item) => markerData.position.lat === item.position.lat &&
107
+ markerData.position.lng === item.position.lng)?.id;
108
+ if (routingId)
109
+ return routingId;
110
+ else {
111
+ const newId = routingMarkers.length + 1;
112
+ const newData = {
113
+ ...markerData,
114
+ id: newId,
115
+ };
116
+ routingMarkers.push(newData);
117
+ this.routingMarkerIds.next(routingMarkers);
118
+ return newId;
119
+ }
120
+ }
121
+ resetMarkersData() {
122
+ this.clusterMarkerIds.next([]);
123
+ this.routingMarkerIds.next([]);
124
+ this.markerElements.next([]);
125
+ this.clusterElements.next([]);
126
+ this.routingElements.next([]);
127
+ }
128
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MapMarkerIconService, deps: [{ token: i0.RendererFactory2 }], target: i0.ɵɵFactoryTarget.Injectable }); }
129
+ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MapMarkerIconService, providedIn: 'root' }); }
130
+ }
131
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: MapMarkerIconService, decorators: [{
132
+ type: Injectable,
133
+ args: [{
134
+ providedIn: 'root',
135
+ }]
136
+ }], ctorParameters: () => [{ type: i0.RendererFactory2 }] });
137
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"map-marker-icon.service.js","sourceRoot":"","sources":["../../../../../../../../projects/ca-components/src/lib/components/ca-map/utils/services/map-marker-icon.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable, Renderer2, RendererFactory2 } from '@angular/core';\nimport { BehaviorSubject, Observable } from 'rxjs';\n\n// Helpers\nimport { MapMarkerIconHelper } from '../helpers';\n\n// Constants\nimport { MapMarkerIconsConstants } from '../constants';\n\n// Models\nimport { IMapMarkers } from '../../models/map.model';\n\n@Injectable({\n  providedIn: 'root',\n})\nexport class MapMarkerIconService {\n  private renderer: Renderer2;\n  private clusterMarkerIds = new BehaviorSubject<IMapMarkers[]>([]);\n  public clusterMarkerIds$: Observable<IMapMarkers[]> =\n    this.clusterMarkerIds.asObservable();\n  private routingMarkerIds = new BehaviorSubject<IMapMarkers[]>([]);\n  public routingMarkerIds$: Observable<IMapMarkers[]> =\n    this.routingMarkerIds.asObservable();\n  private markerElements = new BehaviorSubject<HTMLElement[]>([]);\n  private clusterElements = new BehaviorSubject<HTMLElement[]>([]);\n  private routingElements = new BehaviorSubject<HTMLElement[]>([]);\n\n  constructor(rendererFactory: RendererFactory2) {\n    this.renderer = rendererFactory.createRenderer(null, null);\n  }\n\n  public getMarkerIcon(\n    markerId: number,\n    labelName?: string,\n    isClosed?: boolean,\n    isFavorite?: boolean,\n    isAlwaysSelected?: boolean\n  ): HTMLElement {\n    const markerElements = this.markerElements.getValue();\n\n    const previousMarkerIcon = markerElements.find(\n      (icon) => icon.id === 'marker-' + markerId\n    );\n\n    if (previousMarkerIcon) return previousMarkerIcon;\n    else {\n      const markerElement = this.renderer.createElement('div');\n      this.renderer.setAttribute(markerElement, 'id', 'marker-' + markerId);\n      this.renderer.addClass(markerElement, 'marker-icon');\n\n      const markerSvg = isClosed\n        ? MapMarkerIconsConstants.closedMarker\n        : isFavorite\n        ? MapMarkerIconsConstants.favoriteMarker\n        : MapMarkerIconsConstants.defaultMarker;\n\n      this.renderer.setProperty(markerElement, 'innerHTML', markerSvg);\n\n      if (labelName) {\n        const markerLabelElement = this.renderer.createElement('div');\n        this.renderer.addClass(markerLabelElement, 'marker-label');\n        this.renderer.setProperty(\n          markerLabelElement,\n          'innerHTML',\n          labelName.toUpperCase()\n        );\n        this.renderer.appendChild(markerElement, markerLabelElement);\n      }\n\n      if (isAlwaysSelected)\n        this.renderer.addClass(markerElement, 'selected-permanently');\n\n      markerElements.push(markerElement);\n\n      this.markerElements.next(markerElements);\n\n      return markerElement;\n    }\n  }\n\n  public getClusterMarkerIcon(markerData: IMapMarkers): HTMLElement {\n    const clusterElements = this.clusterElements.getValue();\n\n    const clusterId = this.createClusterId(markerData);\n\n    const previousClusterIcon = clusterElements.find(\n      (icon) => icon.id === 'cluster-' + clusterId\n    );\n\n    if (previousClusterIcon) return previousClusterIcon;\n    else {\n      const markerElement = this.renderer.createElement('div');\n      this.renderer.setAttribute(markerElement, 'id', 'cluster-' + clusterId);\n      this.renderer.addClass(markerElement, 'cluster-icon');\n\n      const markerSvg = MapMarkerIconHelper.getClusterMarker(\n        markerData.data.count,\n        false\n      );\n      this.renderer.setProperty(markerElement, 'innerHTML', markerSvg);\n      clusterElements.push(markerElement);\n\n      this.clusterElements.next(clusterElements);\n\n      return markerElement;\n    }\n  }\n\n  public getRoutingMarkerIcon(\n    markerData: IMapMarkers,\n    stopNumber: number,\n    stopType: string,\n    isStopChecked?: boolean,\n    isLightMode?: boolean,\n    labelName?: string\n  ): HTMLElement {\n    const routingElements = this.routingElements.getValue();\n\n    const routingId = this.createRoutingId(markerData);\n\n    const previousClusterIcon = routingElements.find(\n      (icon) => icon.id === 'routingMarker-' + routingId\n    );\n\n    if (previousClusterIcon) return previousClusterIcon;\n    else {\n      const markerElement = this.renderer.createElement('div');\n      this.renderer.setAttribute(\n        markerElement,\n        'id',\n        'routingMarker-' + routingId\n      );\n      this.renderer.addClass(markerElement, 'routing-icon');\n\n      const markerSvg = MapMarkerIconHelper.getRoutingMarkerIcon(\n        stopNumber,\n        stopType,\n        isStopChecked,\n        isLightMode\n      );\n      this.renderer.setProperty(markerElement, 'innerHTML', markerSvg);\n\n      if (labelName) {\n        const markerLabelElement = this.renderer.createElement('div');\n        this.renderer.addClass(markerLabelElement, 'marker-label');\n        this.renderer.setProperty(\n          markerLabelElement,\n          'innerHTML',\n          labelName.toUpperCase()\n        );\n        this.renderer.appendChild(markerElement, markerLabelElement);\n      }\n\n      routingElements.push(markerElement);\n\n      this.routingElements.next(routingElements);\n\n      return markerElement;\n    }\n  }\n\n  public createClusterId(clusterData: IMapMarkers): number {\n    const clusterMarkers = this.clusterMarkerIds.getValue();\n\n    const clusterId = clusterMarkers.find(\n      (item) =>\n        clusterData.position.lat === item.position.lat &&\n        clusterData.position.lng === item.position.lng\n    )?.id;\n\n    if (clusterId) return clusterId;\n    else {\n      const newId = clusterMarkers.length + 1;\n\n      const newData = {\n        ...clusterData,\n        id: newId,\n      };\n\n      clusterMarkers.push(newData);\n      this.clusterMarkerIds.next(clusterMarkers);\n\n      return newId;\n    }\n  }\n\n  public createRoutingId(markerData: IMapMarkers): number {\n    const routingMarkers = this.routingMarkerIds.getValue();\n\n    const routingId = routingMarkers.find(\n      (item) =>\n        markerData.position.lat === item.position.lat &&\n        markerData.position.lng === item.position.lng\n    )?.id;\n\n    if (routingId) return routingId;\n    else {\n      const newId = routingMarkers.length + 1;\n\n      const newData = {\n        ...markerData,\n        id: newId,\n      };\n\n      routingMarkers.push(newData);\n      this.routingMarkerIds.next(routingMarkers);\n\n      return newId;\n    }\n  }\n\n  public resetMarkersData(): void {\n    this.clusterMarkerIds.next([]);\n    this.routingMarkerIds.next([]);\n    this.markerElements.next([]);\n    this.clusterElements.next([]);\n    this.routingElements.next([]);\n  }\n}\n"]}