ca-components 1.3.96 → 1.3.98

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.
@@ -7,7 +7,17 @@ import { MapSvgRoutes } from '../svg-routes';
7
7
  export class MapMarkerIconHelper {
8
8
  static { this.getRoutingMarkerElement = (stopNumber, stopType, isStopChecked, isLightMode, labelName) => {
9
9
  const markerElement = document.createElement('div');
10
- const markerSvg = MapMarkerIconHelper.getRoutingMarkerIcon(stopNumber, stopType, isStopChecked, isLightMode);
10
+ let markerSvg = '';
11
+ if ([
12
+ MapMarkerStringEnum.DEADHEAD,
13
+ MapMarkerStringEnum.REPAIR,
14
+ MapMarkerStringEnum.FUEL,
15
+ MapMarkerStringEnum.TOWING,
16
+ MapMarkerStringEnum.PARKING,
17
+ ].includes(stopType))
18
+ markerSvg = this.getRoutingMarkerIconSvg(stopType);
19
+ else
20
+ markerSvg = MapMarkerIconHelper.getRoutingMarkerIcon(stopNumber, stopType, isStopChecked, isLightMode);
11
21
  markerElement.innerHTML = markerSvg;
12
22
  if (labelName) {
13
23
  const markerLabelElement = document.createElement('div');
@@ -29,12 +39,14 @@ export class MapMarkerIconHelper {
29
39
  }; }
30
40
  static { this.getRoutingMarkerSvg = (stopNumber, stopType, isLightMode) => {
31
41
  const markerColor = isLightMode
32
- ? MapOptionsConstants.routingMarkerLightColors[stopType]
33
- : MapOptionsConstants.routingMarkerDarkColors[stopType];
34
- const markerOutlineColor = MapOptionsConstants.routingMarkerOutlineColors[isLightMode
42
+ ? MapOptionsConstants.ROUTING_MARKER_LIGHT_COLORS[stopType]
43
+ : MapOptionsConstants.ROUTING_MARKER_DARK_COLORS[stopType];
44
+ const markerOutlineColor = MapOptionsConstants.ROUTING_MARKER_OUTLINE_COLORS[isLightMode
35
45
  ? MapMarkerStringEnum.WHITE
36
46
  : stopType];
37
- const markerDotColor = MapOptionsConstants.routingMarkerDotColors[isLightMode ? MapMarkerStringEnum.LIGHT : MapMarkerStringEnum.DARK];
47
+ const markerDotColor = MapOptionsConstants.ROUTING_MARKER_DOT_COLORS[isLightMode
48
+ ? MapMarkerStringEnum.LIGHT
49
+ : MapMarkerStringEnum.DARK];
38
50
  const markerSvg = `<svg xmlns="http://www.w3.org/2000/svg" width="30" height="33" viewBox="0 0 30 33" fill="none">
39
51
  <circle cx="15" cy="29" r="3" fill="${markerColor}" stroke="${markerDotColor}" stroke-width="2"/>
40
52
  <g filter="url(#filter0_d_24060_59090)">
@@ -63,12 +75,14 @@ export class MapMarkerIconHelper {
63
75
  }; }
64
76
  static { this.getRoutingCheckedMarkerSvg = (stopType, isLightMode) => {
65
77
  const checkedMarkerColor = isLightMode
66
- ? MapOptionsConstants.routingMarkerLightColors[stopType]
67
- : MapOptionsConstants.routingMarkerDarkColors[stopType];
68
- const checkedMarkerOutlineColor = MapOptionsConstants.routingMarkerOutlineColors[isLightMode
78
+ ? MapOptionsConstants.ROUTING_MARKER_LIGHT_COLORS[stopType]
79
+ : MapOptionsConstants.ROUTING_MARKER_DARK_COLORS[stopType];
80
+ const checkedMarkerOutlineColor = MapOptionsConstants.ROUTING_MARKER_OUTLINE_COLORS[isLightMode
69
81
  ? MapMarkerStringEnum.WHITE
70
82
  : stopType];
71
- const checkedMarkerDotColor = MapOptionsConstants.routingMarkerDotColors[isLightMode ? MapMarkerStringEnum.LIGHT : MapMarkerStringEnum.DARK];
83
+ const checkedMarkerDotColor = MapOptionsConstants.ROUTING_MARKER_DOT_COLORS[isLightMode
84
+ ? MapMarkerStringEnum.LIGHT
85
+ : MapMarkerStringEnum.DARK];
72
86
  const checkedMarkerSvg = `<svg width="30" height="33" viewBox="0 0 30 33" fill="none" xmlns="http://www.w3.org/2000/svg">
73
87
  <circle cx="15" cy="29" r="3" fill="${checkedMarkerColor}" stroke="${checkedMarkerDotColor}" stroke-width="2"/>
74
88
  <g filter="url(#filter0_d_18055_34238)">
@@ -93,6 +107,33 @@ export class MapMarkerIconHelper {
93
107
  </svg>`;
94
108
  return checkedMarkerSvg;
95
109
  }; }
110
+ static { this.getRoutingMarkerIconSvg = (stopType) => {
111
+ const markerSvgPath = MapOptionsConstants.ROUTING_MARKER_ICON_PATHS[stopType];
112
+ const checkedMarkerColor = MapOptionsConstants.ROUTING_MARKER_LIGHT_COLORS[stopType];
113
+ const checkedMarkerOutlineColor = MapOptionsConstants.ROUTING_MARKER_OUTLINE_COLORS[MapMarkerStringEnum.WHITE];
114
+ const checkedMarkerDotColor = MapOptionsConstants.ROUTING_MARKER_DOT_COLORS[MapMarkerStringEnum.LIGHT];
115
+ const routingMarkerSvg = `<svg width="30" height="33" viewBox="0 0 30 33" fill="none" xmlns="http://www.w3.org/2000/svg">
116
+ <circle cx="15" cy="29" r="3" fill="${checkedMarkerColor}" stroke="${checkedMarkerDotColor}" stroke-width="2"/>
117
+ <g filter="url(#filter0_d_9268_79834)">
118
+ <path d="M26 14.9732C25.9991 16.7715 25.5554 18.542 24.708 20.1289C23.8606 21.7157 22.6355 23.0702 21.1405 24.0732C21.1165 24.0912 20.7609 24.3102 20.6207 24.4022C17.2485 26.5422 15.8954 27.9872 15.3505 28.8022C15.2859 28.8991 15.1854 28.9665 15.0712 28.9897C14.9569 29.0129 14.8381 28.9901 14.7406 28.9262C14.6916 28.8932 14.6494 28.8511 14.6164 28.8022C14.0716 27.9912 12.7135 26.5462 9.34626 24.4022C9.19302 24.3072 8.8515 24.0912 8.82646 24.0732C7.25656 23.0103 5.9886 21.5601 5.14572 19.8635C4.30285 18.1669 3.91368 16.2815 4.01603 14.3904C4.11837 12.4993 4.70874 10.6667 5.72981 9.0707C6.75088 7.47466 8.16796 6.16936 9.84342 5.28155C11.5189 4.39375 13.3958 3.95361 15.292 4.00387C17.1881 4.05413 19.039 4.5931 20.6649 5.56842C22.2908 6.54374 23.6365 7.92228 24.5713 9.57017C25.5062 11.2181 25.9983 13.0793 26 14.9732Z" fill="white"/>
119
+ </g>
120
+ <circle cx="15" cy="15" r="9" fill="${checkedMarkerColor}"/>
121
+ <path d="${markerSvgPath}" fill="white"/>
122
+ <defs>
123
+ <filter id="filter0_d_9268_79834" x="0" y="0" width="30" height="32.9985" filterUnits="userSpaceOnUse" color-interpolation-filters="sRGB">
124
+ <feFlood flood-opacity="0" result="BackgroundImageFix"/>
125
+ <feColorMatrix in="SourceAlpha" type="matrix" values="0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 127 0" result="hardAlpha"/>
126
+ <feOffset/>
127
+ <feGaussianBlur stdDeviation="2"/>
128
+ <feComposite in2="hardAlpha" operator="out"/>
129
+ <feColorMatrix type="matrix" values="0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0.15 0"/>
130
+ <feBlend mode="normal" in2="BackgroundImageFix" result="effect1_dropShadow_9268_79834"/>
131
+ <feBlend mode="normal" in="SourceGraphic" in2="effect1_dropShadow_9268_79834" result="shape"/>
132
+ </filter>
133
+ </defs>
134
+ </svg>`;
135
+ return routingMarkerSvg;
136
+ }; }
96
137
  static getMapMarker(isFavorite, isClosed) {
97
138
  let markerIconRoute = MapSvgRoutes.defaultMarkerIcon;
98
139
  if (isClosed)
@@ -150,4 +191,4 @@ export class MapMarkerIconHelper {
150
191
  return markerSvg;
151
192
  }
152
193
  }
153
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"map-marker-icon.helper.js","sourceRoot":"","sources":["../../../../../../../../projects/ca-components/src/lib/components/ca-map/utils/helpers/map-marker-icon.helper.ts"],"names":[],"mappings":"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","sourcesContent":["// Constants\nimport { MapOptionsConstants } from '../constants';\n\n// Enums\nimport { MapMarkerStringEnum } from '../../enums';\n\n// Svg Routes\nimport { MapSvgRoutes } from '../svg-routes';\n\nexport class MapMarkerIconHelper {\n  static getRoutingMarkerElement = (\n    stopNumber: number,\n    stopType: string,\n    isStopChecked?: boolean,\n    isLightMode?: boolean,\n    labelName?: string\n  ): HTMLElement => {\n    const markerElement = document.createElement('div');\n\n    const markerSvg = MapMarkerIconHelper.getRoutingMarkerIcon(\n      stopNumber,\n      stopType,\n      isStopChecked,\n      isLightMode\n    );\n\n    markerElement.innerHTML = markerSvg;\n\n    if (labelName) {\n      const markerLabelElement = document.createElement('div');\n      markerLabelElement.classList.add('marker-label');\n      markerLabelElement.innerHTML = labelName.toUpperCase();\n      markerElement.appendChild(markerLabelElement);\n    }\n\n    return markerElement;\n  };\n\n  static getRoutingMarkerIcon = (\n    stopNumber: number,\n    stopType: string,\n    isStopChecked?: boolean,\n    isLightMode?: boolean\n  ): string => {\n    if (!isStopChecked) {\n      const markerSvg = this.getRoutingMarkerSvg(\n        stopNumber,\n        stopType,\n        isLightMode\n      );\n\n      return markerSvg;\n    } else {\n      const checkedMarkerSvg = this.getRoutingCheckedMarkerSvg(\n        stopType,\n        isLightMode\n      );\n\n      return checkedMarkerSvg;\n    }\n  };\n\n  static getRoutingMarkerSvg = (\n    stopNumber: number,\n    stopType: string,\n    isLightMode?: boolean\n  ): string => {\n    const markerColor = isLightMode\n      ? MapOptionsConstants.routingMarkerLightColors[\n          stopType as keyof typeof MapOptionsConstants.routingMarkerLightColors\n        ]\n      : MapOptionsConstants.routingMarkerDarkColors[\n          stopType as keyof typeof MapOptionsConstants.routingMarkerDarkColors\n        ];\n\n    const markerOutlineColor =\n      MapOptionsConstants.routingMarkerOutlineColors[\n        isLightMode\n          ? MapMarkerStringEnum.WHITE\n          : (stopType as keyof typeof MapOptionsConstants.routingMarkerOutlineColors)\n      ];\n\n    const markerDotColor =\n      MapOptionsConstants.routingMarkerDotColors[\n        isLightMode ? MapMarkerStringEnum.LIGHT : MapMarkerStringEnum.DARK\n      ];\n\n    const markerSvg = `<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"30\" height=\"33\" viewBox=\"0 0 30 33\" fill=\"none\">\n                        <circle cx=\"15\" cy=\"29\" r=\"3\" fill=\"${markerColor}\" stroke=\"${markerDotColor}\" stroke-width=\"2\"/>\n                        <g filter=\"url(#filter0_d_24060_59090)\">\n                            <path d=\"M26 14.9732C25.9991 16.7715 25.5554 18.542 24.708 20.1289C23.8606 21.7157 22.6355 23.0702 21.1405 24.0732C21.1165 24.0912 20.7609 24.3102 20.6207 24.4022C17.2485 26.5422 15.8954 27.9872 15.3505 28.8022C15.2859 28.8991 15.1854 28.9665 15.0712 28.9897C14.9569 29.0129 14.8381 28.9901 14.7406 28.9262C14.6916 28.8932 14.6494 28.8511 14.6164 28.8022C14.0716 27.9912 12.7135 26.5462 9.34626 24.4022C9.19302 24.3072 8.8515 24.0912 8.82646 24.0732C7.25656 23.0103 5.9886 21.5601 5.14572 19.8635C4.30285 18.1669 3.91368 16.2815 4.01603 14.3904C4.11837 12.4993 4.70874 10.6667 5.72981 9.0707C6.75088 7.47466 8.16796 6.16936 9.84342 5.28155C11.5189 4.39375 13.3958 3.95361 15.292 4.00387C17.1881 4.05413 19.039 4.5931 20.6649 5.56842C22.2908 6.54374 23.6365 7.92228 24.5713 9.57017C25.5062 11.2181 25.9983 13.0793 26 14.9732Z\" \n                              fill=\"${markerOutlineColor}\"\n                            />\n                        </g>\n                        <circle xmlns=\"http://www.w3.org/2000/svg\" cx=\"15\" cy=\"15\" r=\"9\" fill=\"${markerColor}\"/>\n                        <text xmlns=\"http://www.w3.org/2000/svg\" id=\"_4\" data-name=\"4\" transform=\"translate(15 16)\" fill=\"#fff\" font-size=\"11\" font-family=\"Montserrat, sans-serif\" font-weight=\"700\" dominant-baseline=\"middle\" text-anchor=\"middle\" y=\"0\">\n                            <tspan>${stopNumber ?? 0}</tspan>\n                        </text>\n                        <defs>\n                            <filter id=\"filter0_d_24060_59090\" x=\"0\" y=\"0\" width=\"30\" height=\"32.9985\" filterUnits=\"userSpaceOnUse\" color-interpolation-filters=\"sRGB\">\n                                <feFlood flood-opacity=\"0\" result=\"BackgroundImageFix\"/>\n                                <feColorMatrix in=\"SourceAlpha\" type=\"matrix\" values=\"0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 127 0\" result=\"hardAlpha\"/>\n                                <feOffset/>\n                                <feGaussianBlur stdDeviation=\"2\"/>\n                                <feComposite in2=\"hardAlpha\" operator=\"out\"/>\n                                <feColorMatrix type=\"matrix\" values=\"0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0.15 0\"/>\n                                <feBlend mode=\"normal\" in2=\"BackgroundImageFix\" result=\"effect1_dropShadow_24060_59090\"/>\n                                <feBlend mode=\"normal\" in=\"SourceGraphic\" in2=\"effect1_dropShadow_24060_59090\" result=\"shape\"/>\n                            </filter>\n                        </defs>\n                      </svg>`;\n\n    return markerSvg;\n  };\n\n  static getRoutingCheckedMarkerSvg = (\n    stopType: string,\n    isLightMode?: boolean\n  ) => {\n    const checkedMarkerColor = isLightMode\n      ? MapOptionsConstants.routingMarkerLightColors[\n          stopType as keyof typeof MapOptionsConstants.routingMarkerLightColors\n        ]\n      : MapOptionsConstants.routingMarkerDarkColors[\n          stopType as keyof typeof MapOptionsConstants.routingMarkerDarkColors\n        ];\n\n    const checkedMarkerOutlineColor =\n      MapOptionsConstants.routingMarkerOutlineColors[\n        isLightMode\n          ? MapMarkerStringEnum.WHITE\n          : (stopType as keyof typeof MapOptionsConstants.routingMarkerOutlineColors)\n      ];\n\n    const checkedMarkerDotColor =\n      MapOptionsConstants.routingMarkerDotColors[\n        isLightMode ? MapMarkerStringEnum.LIGHT : MapMarkerStringEnum.DARK\n      ];\n\n    const checkedMarkerSvg = `<svg width=\"30\" height=\"33\" viewBox=\"0 0 30 33\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n                                <circle cx=\"15\" cy=\"29\" r=\"3\" fill=\"${checkedMarkerColor}\" stroke=\"${checkedMarkerDotColor}\" stroke-width=\"2\"/>\n                                <g filter=\"url(#filter0_d_18055_34238)\">\n                                  <path d=\"M26 14.9732C25.9991 16.7715 25.5554 18.542 24.708 20.1289C23.8606 21.7157 22.6355 23.0702 21.1405 24.0732C21.1165 24.0912 20.7609 24.3102 20.6207 24.4022C17.2485 26.5422 15.8954 27.9872 15.3505 28.8022C15.2859 28.8991 15.1854 28.9665 15.0712 28.9897C14.9569 29.0129 14.8381 28.9901 14.7406 28.9262C14.6916 28.8932 14.6494 28.8511 14.6164 28.8022C14.0716 27.9912 12.7135 26.5462 9.34626 24.4022C9.19302 24.3072 8.8515 24.0912 8.82646 24.0732C7.25656 23.0103 5.9886 21.5601 5.14572 19.8635C4.30285 18.1669 3.91368 16.2815 4.01603 14.3904C4.11837 12.4993 4.70874 10.6667 5.72981 9.0707C6.75088 7.47466 8.16796 6.16936 9.84342 5.28155C11.5189 4.39375 13.3958 3.95361 15.292 4.00387C17.1881 4.05413 19.039 4.5931 20.6649 5.56842C22.2908 6.54374 23.6365 7.92228 24.5713 9.57017C25.5062 11.2181 25.9983 13.0793 26 14.9732Z\" \n                                    fill=\"${checkedMarkerOutlineColor}\"\n                                  />\n                                </g>\n                                <circle cx=\"15\" cy=\"15\" r=\"9\" fill=\"${checkedMarkerColor}\"/>\n                                <path d=\"M13.0462 19.0477L9.71291 15.7144C9.65718 15.6587 9.61297 15.5925 9.5828 15.5197C9.55264 15.4469 9.53711 15.3689 9.53711 15.2901C9.53711 15.2112 9.55264 15.1332 9.5828 15.0604C9.61297 14.9876 9.65718 14.9214 9.71291 14.8657L10.5629 14.0184C10.6186 13.9627 10.6848 13.9184 10.7576 13.8883C10.8304 13.8581 10.9084 13.8426 10.9872 13.8426C11.0661 13.8426 11.1441 13.8581 11.2169 13.8883C11.2897 13.9184 11.3559 13.9627 11.4116 14.0184L13.4702 16.0771L18.5869 10.9571C18.6426 10.9013 18.7088 10.8571 18.7816 10.8269C18.8544 10.7968 18.9324 10.7812 19.0112 10.7812C19.0901 10.7812 19.1681 10.7968 19.2409 10.8269C19.3137 10.8571 19.3799 10.9013 19.4356 10.9571L20.2842 11.8057C20.34 11.8614 20.3842 11.9276 20.4144 12.0004C20.4445 12.0732 20.4601 12.1512 20.4601 12.2301C20.4601 12.3089 20.4445 12.3869 20.4144 12.4597C20.3842 12.5325 20.34 12.5987 20.2842 12.6544L13.8949 19.0451C13.8392 19.1008 13.773 19.145 13.7002 19.1752C13.6274 19.2053 13.5494 19.2209 13.4706 19.2209C13.3918 19.2209 13.3137 19.2053 13.2409 19.1752C13.1681 19.145 13.102 19.1008 13.0462 19.0451V19.0477Z\" fill=\"white\"/>\n                                <defs>\n                                  <filter id=\"filter0_d_18055_34238\" x=\"0\" y=\"0\" width=\"30\" height=\"32.9985\" filterUnits=\"userSpaceOnUse\" color-interpolation-filters=\"sRGB\">\n                                    <feFlood flood-opacity=\"0\" result=\"BackgroundImageFix\"/>\n                                    <feColorMatrix in=\"SourceAlpha\" type=\"matrix\" values=\"0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 127 0\" result=\"hardAlpha\"/>\n                                    <feOffset/>\n                                    <feGaussianBlur stdDeviation=\"2\"/>\n                                    <feComposite in2=\"hardAlpha\" operator=\"out\"/>\n                                    <feColorMatrix type=\"matrix\" values=\"0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0.15 0\"/>\n                                    <feBlend mode=\"normal\" in2=\"BackgroundImageFix\" result=\"effect1_dropShadow_18055_34238\"/>\n                                    <feBlend mode=\"normal\" in=\"SourceGraphic\" in2=\"effect1_dropShadow_18055_34238\" result=\"shape\"/>\n                                  </filter>\n                                </defs>\n                              </svg>`;\n\n    return checkedMarkerSvg;\n  };\n\n  static getMapMarker(isFavorite?: boolean, isClosed?: boolean): string {\n    let markerIconRoute = MapSvgRoutes.defaultMarkerIcon;\n\n    if (isClosed) markerIconRoute = MapSvgRoutes.closedMarkerIcon;\n    else if (isFavorite) markerIconRoute = MapSvgRoutes.favoriteMarkerIcon;\n\n    return markerIconRoute;\n  }\n\n  static getClusterMarker(count: number, isSelected?: boolean): string {\n    const markerSvg = `<svg class=\"marker-svg\" width=\"52\" height=\"52\" viewBox=\"0 0 52 52\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n                          <g filter=\"url(#filter0_d_2631_274104)\">\n                              <circle cx=\"26\" cy=\"26\" r=\"16\" fill=\"white\"/>\n                          </g>\n                          <circle cx=\"26\" cy=\"26\" r=\"14\" fill=\"#FAB15C\"/>\n                          <text\n                              id=\"_4\"\n                              data-name=\"4\"\n                              transform=\"translate(26 27)\"\n                              fill=\"#fff\"\n                              font-size=\"14\"\n                              font-family=\"Montserrat, sans-serif\"\n                              font-weight=\"700\"\n                              dominant-baseline=\"middle\"\n                              text-anchor=\"middle\"\n                          >\n                              <tspan> ${count} </tspan>\n                          </text>\n                          <g opacity=\"0.7\" filter=\"url(#filter1_d_2631_274104)\">\n                              <path d=\"M36.781 7.65002L35.461 9.89302C35.3705 10.0502 35.3446 10.2363 35.3886 10.4122C35.4326 10.5881 35.5432 10.74 35.697 10.836C37.8917 12.2409 39.7555 14.1051 41.16 16.3C41.256 16.4538 41.408 16.5644 41.5838 16.6084C41.7597 16.6524 41.9458 16.6265 42.103 16.536L44.346 15.216C44.4275 15.1691 44.4988 15.1061 44.5554 15.031C44.6121 14.9559 44.653 14.8702 44.6758 14.7789C44.6986 14.6876 44.7027 14.5926 44.688 14.4997C44.6732 14.4068 44.6399 14.3178 44.59 14.238C42.8426 11.4867 40.5103 9.15436 37.759 7.40702C37.6792 7.35709 37.5902 7.32376 37.4973 7.30901C37.4044 7.29427 37.3094 7.2984 37.2181 7.32118C37.1268 7.34396 37.0411 7.38491 36.966 7.44158C36.8909 7.49825 36.8279 7.56848 36.781 7.65002ZM46.601 20.651L44.073 21.309C43.8985 21.3562 43.749 21.469 43.6558 21.6239C43.5626 21.7788 43.5329 21.9637 43.573 22.14C44.1343 24.6827 44.1343 27.3173 43.573 29.86C43.5329 30.0363 43.5626 30.2212 43.6558 30.3761C43.749 30.531 43.8985 30.6439 44.073 30.691L46.601 31.349C46.6917 31.3735 46.7864 31.3794 46.8795 31.3665C46.9725 31.3536 47.0621 31.3221 47.1427 31.2738C47.2233 31.2256 47.2934 31.1616 47.3488 31.0857C47.4041 31.0098 47.4437 30.9235 47.465 30.832C48.173 27.6496 48.173 24.3504 47.465 21.168C47.4437 21.0765 47.4041 20.9902 47.3488 20.9143C47.2934 20.8384 47.2233 20.7744 47.1427 20.7262C47.0621 20.678 46.9725 20.6464 46.8795 20.6335C46.7864 20.6206 46.6917 20.6266 46.601 20.651ZM30.696 44.079C30.6502 43.9037 30.5376 43.7532 30.3823 43.6598C30.227 43.5663 30.0414 43.5374 29.865 43.579C27.3192 44.1397 24.6818 44.1397 22.136 43.579C21.9597 43.5389 21.7748 43.5686 21.6199 43.6618C21.465 43.755 21.3521 43.9045 21.305 44.079L20.647 46.6C20.6225 46.6907 20.6166 46.7854 20.6295 46.8785C20.6424 46.9716 20.6739 47.0611 20.7222 47.1417C20.7704 47.2223 20.8344 47.2924 20.9103 47.3478C20.9862 47.4032 21.0725 47.4427 21.164 47.464C24.3471 48.172 27.6469 48.172 30.83 47.464C30.9214 47.4427 31.0076 47.4032 31.0834 47.3479C31.1592 47.2926 31.2231 47.2226 31.2714 47.1421C31.3196 47.0616 31.3512 46.9722 31.3641 46.8792C31.3771 46.7863 31.3713 46.6917 31.347 46.601L30.696 44.079ZM15.21 7.64902C15.163 7.56762 15.1002 7.49651 15.0251 7.43993C14.9501 7.38335 14.8644 7.34245 14.7733 7.31968C14.6821 7.29691 14.5873 7.29273 14.4945 7.30739C14.4016 7.32205 14.3127 7.35526 14.233 7.40502C11.4742 9.14543 9.13842 11.4795 7.39599 14.237C7.34623 14.3167 7.31303 14.4057 7.29837 14.4985C7.28371 14.5913 7.28789 14.6861 7.31066 14.7773C7.33343 14.8685 7.37432 14.9541 7.4309 15.0292C7.48748 15.1042 7.55859 15.1671 7.63999 15.214L9.88599 16.533C10.0436 16.6246 10.2308 16.6511 10.4076 16.6068C10.5845 16.5626 10.7371 16.4511 10.833 16.296C12.237 14.1021 14.101 12.2394 16.296 10.837C16.451 10.7411 16.5625 10.5885 16.6068 10.4116C16.6511 10.2348 16.6246 10.0476 16.533 9.89002L15.21 7.64902ZM7.90999 21.308L5.39599 20.652C5.30528 20.6274 5.21053 20.6213 5.11741 20.6341C5.02428 20.6468 4.93468 20.6782 4.85396 20.7264C4.77323 20.7746 4.70303 20.8385 4.64754 20.9143C4.59205 20.9902 4.55242 21.0765 4.53099 21.168C3.823 24.3504 3.823 27.6496 4.53099 30.832C4.55231 30.9235 4.59184 31.0098 4.64721 31.0857C4.70258 31.1616 4.77267 31.2256 4.8533 31.2738C4.93392 31.3221 5.02343 31.3536 5.1165 31.3665C5.20956 31.3794 5.30428 31.3735 5.39499 31.349L7.92299 30.691C8.09751 30.6439 8.24702 30.531 8.34022 30.3761C8.43342 30.2212 8.46308 30.0363 8.42299 29.86C8.13992 28.5928 7.99673 27.2984 7.99599 26C7.99593 24.7027 8.13439 23.409 8.40899 22.141C8.44966 21.9645 8.42028 21.779 8.32703 21.6237C8.23379 21.4683 8.08494 21.3552 7.90999 21.308ZM9.88899 35.465L7.64599 36.785C7.56446 36.832 7.49322 36.8949 7.43655 36.97C7.37988 37.0451 7.33893 37.1309 7.31616 37.2222C7.29338 37.3135 7.28924 37.4084 7.30399 37.5013C7.31874 37.5943 7.35207 37.6833 7.40199 37.763C9.14933 40.5143 11.4817 42.8467 14.233 44.594C14.3127 44.6439 14.4017 44.6773 14.4947 44.692C14.5876 44.7068 14.6826 44.7026 14.7738 44.6799C14.8651 44.6571 14.9509 44.6161 15.026 44.5595C15.1011 44.5028 15.164 44.4316 15.211 44.35L16.531 42.107C16.6214 41.9499 16.6474 41.7638 16.6034 41.5879C16.5594 41.412 16.4488 41.26 16.295 41.164C14.1003 39.7592 12.2365 37.895 10.832 35.7C10.736 35.5462 10.584 35.4357 10.4081 35.3916C10.2322 35.3476 10.0461 35.3746 9.88899 35.465ZM41.16 35.7C39.7552 37.8951 37.891 39.7593 35.696 41.164C35.5422 41.26 35.4316 41.412 35.3876 41.5879C35.3436 41.7638 35.3695 41.9499 35.46 42.107L36.78 44.35C36.827 44.4316 36.8899 44.5028 36.965 44.5595C37.0401 44.6161 37.1258 44.6571 37.2171 44.6799C37.3084 44.7026 37.4034 44.7068 37.4963 44.692C37.5892 44.6773 37.6782 44.6439 37.758 44.594C40.5093 42.8467 42.8416 40.5143 44.589 37.763C44.6389 37.6833 44.6722 37.5943 44.687 37.5013C44.7017 37.4084 44.6976 37.3135 44.6748 37.2222C44.6521 37.1309 44.6111 37.0451 44.5544 36.97C44.4978 36.8949 44.4265 36.832 44.345 36.785L42.102 35.465C41.9448 35.3746 41.7587 35.3486 41.5828 35.3926C41.407 35.4367 41.255 35.5472 41.159 35.701M25.996 4.00002C24.3707 3.99798 22.7501 4.17607 21.164 4.53102C21.0725 4.55244 20.9862 4.59208 20.9103 4.64757C20.8344 4.70305 20.7705 4.77325 20.7224 4.85398C20.6742 4.93471 20.6428 5.02431 20.63 5.11743C20.6173 5.21056 20.6234 5.3053 20.648 5.39602L21.304 7.91202C21.3511 8.08696 21.4643 8.23681 21.6196 8.33006C21.775 8.4233 21.9604 8.45268 22.137 8.41202C23.405 8.13775 24.6987 7.99963 25.996 8.00002C27.2971 7.99907 28.5944 8.1399 29.865 8.42002C30.0414 8.46168 30.227 8.43269 30.3823 8.33926C30.5376 8.24583 30.6502 8.09536 30.696 7.92002L31.347 5.39302C31.3713 5.30237 31.3771 5.20776 31.3641 5.11481C31.3512 5.02186 31.3196 4.93247 31.2714 4.85196C31.2231 4.77145 31.1592 4.70146 31.0834 4.64615C31.0076 4.59084 30.9214 4.55135 30.83 4.53002C29.2431 4.17581 27.6219 3.99806 25.996 4.00002Z\" fill=\"${\n                                isSelected ? '#FAB15C' : '#FFFFFF'\n                              }\"/>\n                          </g>\n                          <defs>\n                              <filter id=\"filter0_d_2631_274104\" x=\"6\" y=\"6\" width=\"40\" height=\"40\" filterUnits=\"userSpaceOnUse\" color-interpolation-filters=\"sRGB\">\n                                  <feFlood flood-opacity=\"0\" result=\"BackgroundImageFix\"/>\n                                  <feColorMatrix in=\"SourceAlpha\" type=\"matrix\" values=\"0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 127 0\" result=\"hardAlpha\"/>\n                                  <feOffset/>\n                                  <feGaussianBlur stdDeviation=\"2\"/>\n                                  <feComposite in2=\"hardAlpha\" operator=\"out\"/>\n                                  <feColorMatrix type=\"matrix\" values=\"0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0.15 0\"/>\n                                  <feBlend mode=\"normal\" in2=\"BackgroundImageFix\" result=\"effect1_dropShadow_2631_274104\"/>\n                                  <feBlend mode=\"normal\" in=\"SourceGraphic\" in2=\"effect1_dropShadow_2631_274104\" result=\"shape\"/>\n                              </filter>\n                              <filter id=\"filter1_d_2631_274104\" x=\"0\" y=\"0\" width=\"51.9961\" height=\"51.995\" filterUnits=\"userSpaceOnUse\" color-interpolation-filters=\"sRGB\">\n                                  <feFlood flood-opacity=\"0\" result=\"BackgroundImageFix\"/>\n                                  <feColorMatrix in=\"SourceAlpha\" type=\"matrix\" values=\"0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 127 0\" result=\"hardAlpha\"/>\n                                  <feOffset/>\n                                  <feGaussianBlur stdDeviation=\"2\"/>\n                                  <feComposite in2=\"hardAlpha\" operator=\"out\"/>\n                                  <feColorMatrix type=\"matrix\" values=\"0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0.15 0\"/>\n                                  <feBlend mode=\"normal\" in2=\"BackgroundImageFix\" result=\"effect1_dropShadow_2631_274104\"/>\n                                  <feBlend mode=\"normal\" in=\"SourceGraphic\" in2=\"effect1_dropShadow_2631_274104\" result=\"shape\"/>\n                              </filter>\n                          </defs>\n                        </svg>`;\n\n    const markerIconRoute =\n      'data:image/svg+xml;charset=UTF-8;base64,' + btoa(markerSvg);\n\n    return markerSvg;\n  }\n}\n"]}
194
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"map-marker-icon.helper.js","sourceRoot":"","sources":["../../../../../../../../projects/ca-components/src/lib/components/ca-map/utils/helpers/map-marker-icon.helper.ts"],"names":[],"mappings":"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","sourcesContent":["// Constants\nimport { MapOptionsConstants } from '../constants';\n\n// Enums\nimport { MapMarkerStringEnum } from '../../enums';\n\n// Svg Routes\nimport { MapSvgRoutes } from '../svg-routes';\n\nexport class MapMarkerIconHelper {\n    static getRoutingMarkerElement = (\n        stopNumber: number,\n        stopType: string,\n        isStopChecked?: boolean,\n        isLightMode?: boolean,\n        labelName?: string\n    ): HTMLElement => {\n        const markerElement = document.createElement('div');\n\n        let markerSvg = '';\n\n        if (\n            [\n                MapMarkerStringEnum.DEADHEAD,\n                MapMarkerStringEnum.REPAIR,\n                MapMarkerStringEnum.FUEL,\n                MapMarkerStringEnum.TOWING,\n                MapMarkerStringEnum.PARKING,\n            ].includes(stopType as MapMarkerStringEnum)\n        )\n            markerSvg = this.getRoutingMarkerIconSvg(stopType);\n        else\n            markerSvg = MapMarkerIconHelper.getRoutingMarkerIcon(\n                stopNumber,\n                stopType,\n                isStopChecked,\n                isLightMode\n            );\n\n        markerElement.innerHTML = markerSvg;\n\n        if (labelName) {\n            const markerLabelElement = document.createElement('div');\n            markerLabelElement.classList.add('marker-label');\n            markerLabelElement.innerHTML = labelName.toUpperCase();\n            markerElement.appendChild(markerLabelElement);\n        }\n\n        return markerElement;\n    };\n\n    static getRoutingMarkerIcon = (\n        stopNumber: number,\n        stopType: string,\n        isStopChecked?: boolean,\n        isLightMode?: boolean\n    ): string => {\n        if (!isStopChecked) {\n            const markerSvg = this.getRoutingMarkerSvg(\n                stopNumber,\n                stopType,\n                isLightMode\n            );\n\n            return markerSvg;\n        } else {\n            const checkedMarkerSvg = this.getRoutingCheckedMarkerSvg(\n                stopType,\n                isLightMode\n            );\n\n            return checkedMarkerSvg;\n        }\n    };\n\n    static getRoutingMarkerSvg = (\n        stopNumber: number,\n        stopType: string,\n        isLightMode?: boolean\n    ): string => {\n        const markerColor = isLightMode\n            ? MapOptionsConstants.ROUTING_MARKER_LIGHT_COLORS[\n                  stopType as keyof typeof MapOptionsConstants.ROUTING_MARKER_LIGHT_COLORS\n              ]\n            : MapOptionsConstants.ROUTING_MARKER_DARK_COLORS[\n                  stopType as keyof typeof MapOptionsConstants.ROUTING_MARKER_DARK_COLORS\n              ];\n\n        const markerOutlineColor =\n            MapOptionsConstants.ROUTING_MARKER_OUTLINE_COLORS[\n                isLightMode\n                    ? MapMarkerStringEnum.WHITE\n                    : (stopType as keyof typeof MapOptionsConstants.ROUTING_MARKER_OUTLINE_COLORS)\n            ];\n\n        const markerDotColor =\n            MapOptionsConstants.ROUTING_MARKER_DOT_COLORS[\n                isLightMode\n                    ? MapMarkerStringEnum.LIGHT\n                    : MapMarkerStringEnum.DARK\n            ];\n\n        const markerSvg = `<svg xmlns=\"http://www.w3.org/2000/svg\" width=\"30\" height=\"33\" viewBox=\"0 0 30 33\" fill=\"none\">\n                        <circle cx=\"15\" cy=\"29\" r=\"3\" fill=\"${markerColor}\" stroke=\"${markerDotColor}\" stroke-width=\"2\"/>\n                        <g filter=\"url(#filter0_d_24060_59090)\">\n                            <path d=\"M26 14.9732C25.9991 16.7715 25.5554 18.542 24.708 20.1289C23.8606 21.7157 22.6355 23.0702 21.1405 24.0732C21.1165 24.0912 20.7609 24.3102 20.6207 24.4022C17.2485 26.5422 15.8954 27.9872 15.3505 28.8022C15.2859 28.8991 15.1854 28.9665 15.0712 28.9897C14.9569 29.0129 14.8381 28.9901 14.7406 28.9262C14.6916 28.8932 14.6494 28.8511 14.6164 28.8022C14.0716 27.9912 12.7135 26.5462 9.34626 24.4022C9.19302 24.3072 8.8515 24.0912 8.82646 24.0732C7.25656 23.0103 5.9886 21.5601 5.14572 19.8635C4.30285 18.1669 3.91368 16.2815 4.01603 14.3904C4.11837 12.4993 4.70874 10.6667 5.72981 9.0707C6.75088 7.47466 8.16796 6.16936 9.84342 5.28155C11.5189 4.39375 13.3958 3.95361 15.292 4.00387C17.1881 4.05413 19.039 4.5931 20.6649 5.56842C22.2908 6.54374 23.6365 7.92228 24.5713 9.57017C25.5062 11.2181 25.9983 13.0793 26 14.9732Z\" \n                              fill=\"${markerOutlineColor}\"\n                            />\n                        </g>\n                        <circle xmlns=\"http://www.w3.org/2000/svg\" cx=\"15\" cy=\"15\" r=\"9\" fill=\"${markerColor}\"/>\n                        <text xmlns=\"http://www.w3.org/2000/svg\" id=\"_4\" data-name=\"4\" transform=\"translate(15 16)\" fill=\"#fff\" font-size=\"11\" font-family=\"Montserrat, sans-serif\" font-weight=\"700\" dominant-baseline=\"middle\" text-anchor=\"middle\" y=\"0\">\n                            <tspan>${stopNumber ?? 0}</tspan>\n                        </text>\n                        <defs>\n                            <filter id=\"filter0_d_24060_59090\" x=\"0\" y=\"0\" width=\"30\" height=\"32.9985\" filterUnits=\"userSpaceOnUse\" color-interpolation-filters=\"sRGB\">\n                                <feFlood flood-opacity=\"0\" result=\"BackgroundImageFix\"/>\n                                <feColorMatrix in=\"SourceAlpha\" type=\"matrix\" values=\"0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 127 0\" result=\"hardAlpha\"/>\n                                <feOffset/>\n                                <feGaussianBlur stdDeviation=\"2\"/>\n                                <feComposite in2=\"hardAlpha\" operator=\"out\"/>\n                                <feColorMatrix type=\"matrix\" values=\"0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0.15 0\"/>\n                                <feBlend mode=\"normal\" in2=\"BackgroundImageFix\" result=\"effect1_dropShadow_24060_59090\"/>\n                                <feBlend mode=\"normal\" in=\"SourceGraphic\" in2=\"effect1_dropShadow_24060_59090\" result=\"shape\"/>\n                            </filter>\n                        </defs>\n                      </svg>`;\n\n        return markerSvg;\n    };\n\n    static getRoutingCheckedMarkerSvg = (\n        stopType: string,\n        isLightMode?: boolean\n    ) => {\n        const checkedMarkerColor = isLightMode\n            ? MapOptionsConstants.ROUTING_MARKER_LIGHT_COLORS[\n                  stopType as keyof typeof MapOptionsConstants.ROUTING_MARKER_LIGHT_COLORS\n              ]\n            : MapOptionsConstants.ROUTING_MARKER_DARK_COLORS[\n                  stopType as keyof typeof MapOptionsConstants.ROUTING_MARKER_DARK_COLORS\n              ];\n\n        const checkedMarkerOutlineColor =\n            MapOptionsConstants.ROUTING_MARKER_OUTLINE_COLORS[\n                isLightMode\n                    ? MapMarkerStringEnum.WHITE\n                    : (stopType as keyof typeof MapOptionsConstants.ROUTING_MARKER_OUTLINE_COLORS)\n            ];\n\n        const checkedMarkerDotColor =\n            MapOptionsConstants.ROUTING_MARKER_DOT_COLORS[\n                isLightMode\n                    ? MapMarkerStringEnum.LIGHT\n                    : MapMarkerStringEnum.DARK\n            ];\n\n        const checkedMarkerSvg = `<svg width=\"30\" height=\"33\" viewBox=\"0 0 30 33\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n                                <circle cx=\"15\" cy=\"29\" r=\"3\" fill=\"${checkedMarkerColor}\" stroke=\"${checkedMarkerDotColor}\" stroke-width=\"2\"/>\n                                <g filter=\"url(#filter0_d_18055_34238)\">\n                                  <path d=\"M26 14.9732C25.9991 16.7715 25.5554 18.542 24.708 20.1289C23.8606 21.7157 22.6355 23.0702 21.1405 24.0732C21.1165 24.0912 20.7609 24.3102 20.6207 24.4022C17.2485 26.5422 15.8954 27.9872 15.3505 28.8022C15.2859 28.8991 15.1854 28.9665 15.0712 28.9897C14.9569 29.0129 14.8381 28.9901 14.7406 28.9262C14.6916 28.8932 14.6494 28.8511 14.6164 28.8022C14.0716 27.9912 12.7135 26.5462 9.34626 24.4022C9.19302 24.3072 8.8515 24.0912 8.82646 24.0732C7.25656 23.0103 5.9886 21.5601 5.14572 19.8635C4.30285 18.1669 3.91368 16.2815 4.01603 14.3904C4.11837 12.4993 4.70874 10.6667 5.72981 9.0707C6.75088 7.47466 8.16796 6.16936 9.84342 5.28155C11.5189 4.39375 13.3958 3.95361 15.292 4.00387C17.1881 4.05413 19.039 4.5931 20.6649 5.56842C22.2908 6.54374 23.6365 7.92228 24.5713 9.57017C25.5062 11.2181 25.9983 13.0793 26 14.9732Z\" \n                                    fill=\"${checkedMarkerOutlineColor}\"\n                                  />\n                                </g>\n                                <circle cx=\"15\" cy=\"15\" r=\"9\" fill=\"${checkedMarkerColor}\"/>\n                                <path d=\"M13.0462 19.0477L9.71291 15.7144C9.65718 15.6587 9.61297 15.5925 9.5828 15.5197C9.55264 15.4469 9.53711 15.3689 9.53711 15.2901C9.53711 15.2112 9.55264 15.1332 9.5828 15.0604C9.61297 14.9876 9.65718 14.9214 9.71291 14.8657L10.5629 14.0184C10.6186 13.9627 10.6848 13.9184 10.7576 13.8883C10.8304 13.8581 10.9084 13.8426 10.9872 13.8426C11.0661 13.8426 11.1441 13.8581 11.2169 13.8883C11.2897 13.9184 11.3559 13.9627 11.4116 14.0184L13.4702 16.0771L18.5869 10.9571C18.6426 10.9013 18.7088 10.8571 18.7816 10.8269C18.8544 10.7968 18.9324 10.7812 19.0112 10.7812C19.0901 10.7812 19.1681 10.7968 19.2409 10.8269C19.3137 10.8571 19.3799 10.9013 19.4356 10.9571L20.2842 11.8057C20.34 11.8614 20.3842 11.9276 20.4144 12.0004C20.4445 12.0732 20.4601 12.1512 20.4601 12.2301C20.4601 12.3089 20.4445 12.3869 20.4144 12.4597C20.3842 12.5325 20.34 12.5987 20.2842 12.6544L13.8949 19.0451C13.8392 19.1008 13.773 19.145 13.7002 19.1752C13.6274 19.2053 13.5494 19.2209 13.4706 19.2209C13.3918 19.2209 13.3137 19.2053 13.2409 19.1752C13.1681 19.145 13.102 19.1008 13.0462 19.0451V19.0477Z\" fill=\"white\"/>\n                                <defs>\n                                  <filter id=\"filter0_d_18055_34238\" x=\"0\" y=\"0\" width=\"30\" height=\"32.9985\" filterUnits=\"userSpaceOnUse\" color-interpolation-filters=\"sRGB\">\n                                    <feFlood flood-opacity=\"0\" result=\"BackgroundImageFix\"/>\n                                    <feColorMatrix in=\"SourceAlpha\" type=\"matrix\" values=\"0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 127 0\" result=\"hardAlpha\"/>\n                                    <feOffset/>\n                                    <feGaussianBlur stdDeviation=\"2\"/>\n                                    <feComposite in2=\"hardAlpha\" operator=\"out\"/>\n                                    <feColorMatrix type=\"matrix\" values=\"0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0.15 0\"/>\n                                    <feBlend mode=\"normal\" in2=\"BackgroundImageFix\" result=\"effect1_dropShadow_18055_34238\"/>\n                                    <feBlend mode=\"normal\" in=\"SourceGraphic\" in2=\"effect1_dropShadow_18055_34238\" result=\"shape\"/>\n                                  </filter>\n                                </defs>\n                              </svg>`;\n\n        return checkedMarkerSvg;\n    };\n\n    static getRoutingMarkerIconSvg = (stopType: string): string => {\n        const markerSvgPath =\n            MapOptionsConstants.ROUTING_MARKER_ICON_PATHS[\n                stopType as keyof typeof MapOptionsConstants.ROUTING_MARKER_ICON_PATHS\n            ];\n\n        const checkedMarkerColor =\n            MapOptionsConstants.ROUTING_MARKER_LIGHT_COLORS[\n                stopType as keyof typeof MapOptionsConstants.ROUTING_MARKER_LIGHT_COLORS\n            ];\n\n        const checkedMarkerOutlineColor =\n            MapOptionsConstants.ROUTING_MARKER_OUTLINE_COLORS[\n                MapMarkerStringEnum.WHITE\n            ];\n\n        const checkedMarkerDotColor =\n            MapOptionsConstants.ROUTING_MARKER_DOT_COLORS[\n                MapMarkerStringEnum.LIGHT\n            ];\n\n        const routingMarkerSvg = `<svg width=\"30\" height=\"33\" viewBox=\"0 0 30 33\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n                                      <circle cx=\"15\" cy=\"29\" r=\"3\" fill=\"${checkedMarkerColor}\" stroke=\"${checkedMarkerDotColor}\" stroke-width=\"2\"/>\n                                      <g filter=\"url(#filter0_d_9268_79834)\">\n                                        <path d=\"M26 14.9732C25.9991 16.7715 25.5554 18.542 24.708 20.1289C23.8606 21.7157 22.6355 23.0702 21.1405 24.0732C21.1165 24.0912 20.7609 24.3102 20.6207 24.4022C17.2485 26.5422 15.8954 27.9872 15.3505 28.8022C15.2859 28.8991 15.1854 28.9665 15.0712 28.9897C14.9569 29.0129 14.8381 28.9901 14.7406 28.9262C14.6916 28.8932 14.6494 28.8511 14.6164 28.8022C14.0716 27.9912 12.7135 26.5462 9.34626 24.4022C9.19302 24.3072 8.8515 24.0912 8.82646 24.0732C7.25656 23.0103 5.9886 21.5601 5.14572 19.8635C4.30285 18.1669 3.91368 16.2815 4.01603 14.3904C4.11837 12.4993 4.70874 10.6667 5.72981 9.0707C6.75088 7.47466 8.16796 6.16936 9.84342 5.28155C11.5189 4.39375 13.3958 3.95361 15.292 4.00387C17.1881 4.05413 19.039 4.5931 20.6649 5.56842C22.2908 6.54374 23.6365 7.92228 24.5713 9.57017C25.5062 11.2181 25.9983 13.0793 26 14.9732Z\" fill=\"white\"/>\n                                      </g>\n                                      <circle cx=\"15\" cy=\"15\" r=\"9\" fill=\"${checkedMarkerColor}\"/>\n                                      <path d=\"${markerSvgPath}\" fill=\"white\"/>\n                                      <defs>\n                                        <filter id=\"filter0_d_9268_79834\" x=\"0\" y=\"0\" width=\"30\" height=\"32.9985\" filterUnits=\"userSpaceOnUse\" color-interpolation-filters=\"sRGB\">\n                                          <feFlood flood-opacity=\"0\" result=\"BackgroundImageFix\"/>\n                                          <feColorMatrix in=\"SourceAlpha\" type=\"matrix\" values=\"0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 127 0\" result=\"hardAlpha\"/>\n                                          <feOffset/>\n                                          <feGaussianBlur stdDeviation=\"2\"/>\n                                          <feComposite in2=\"hardAlpha\" operator=\"out\"/>\n                                          <feColorMatrix type=\"matrix\" values=\"0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0.15 0\"/>\n                                          <feBlend mode=\"normal\" in2=\"BackgroundImageFix\" result=\"effect1_dropShadow_9268_79834\"/>\n                                          <feBlend mode=\"normal\" in=\"SourceGraphic\" in2=\"effect1_dropShadow_9268_79834\" result=\"shape\"/>\n                                        </filter>\n                                      </defs>\n                                    </svg>`;\n\n        return routingMarkerSvg;\n    };\n\n    static getMapMarker(isFavorite?: boolean, isClosed?: boolean): string {\n        let markerIconRoute = MapSvgRoutes.defaultMarkerIcon;\n\n        if (isClosed) markerIconRoute = MapSvgRoutes.closedMarkerIcon;\n        else if (isFavorite) markerIconRoute = MapSvgRoutes.favoriteMarkerIcon;\n\n        return markerIconRoute;\n    }\n\n    static getClusterMarker(count: number, isSelected?: boolean): string {\n        const markerSvg = `<svg class=\"marker-svg\" width=\"52\" height=\"52\" viewBox=\"0 0 52 52\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n                          <g filter=\"url(#filter0_d_2631_274104)\">\n                              <circle cx=\"26\" cy=\"26\" r=\"16\" fill=\"white\"/>\n                          </g>\n                          <circle cx=\"26\" cy=\"26\" r=\"14\" fill=\"#FAB15C\"/>\n                          <text\n                              id=\"_4\"\n                              data-name=\"4\"\n                              transform=\"translate(26 27)\"\n                              fill=\"#fff\"\n                              font-size=\"14\"\n                              font-family=\"Montserrat, sans-serif\"\n                              font-weight=\"700\"\n                              dominant-baseline=\"middle\"\n                              text-anchor=\"middle\"\n                          >\n                              <tspan> ${count} </tspan>\n                          </text>\n                          <g opacity=\"0.7\" filter=\"url(#filter1_d_2631_274104)\">\n                              <path d=\"M36.781 7.65002L35.461 9.89302C35.3705 10.0502 35.3446 10.2363 35.3886 10.4122C35.4326 10.5881 35.5432 10.74 35.697 10.836C37.8917 12.2409 39.7555 14.1051 41.16 16.3C41.256 16.4538 41.408 16.5644 41.5838 16.6084C41.7597 16.6524 41.9458 16.6265 42.103 16.536L44.346 15.216C44.4275 15.1691 44.4988 15.1061 44.5554 15.031C44.6121 14.9559 44.653 14.8702 44.6758 14.7789C44.6986 14.6876 44.7027 14.5926 44.688 14.4997C44.6732 14.4068 44.6399 14.3178 44.59 14.238C42.8426 11.4867 40.5103 9.15436 37.759 7.40702C37.6792 7.35709 37.5902 7.32376 37.4973 7.30901C37.4044 7.29427 37.3094 7.2984 37.2181 7.32118C37.1268 7.34396 37.0411 7.38491 36.966 7.44158C36.8909 7.49825 36.8279 7.56848 36.781 7.65002ZM46.601 20.651L44.073 21.309C43.8985 21.3562 43.749 21.469 43.6558 21.6239C43.5626 21.7788 43.5329 21.9637 43.573 22.14C44.1343 24.6827 44.1343 27.3173 43.573 29.86C43.5329 30.0363 43.5626 30.2212 43.6558 30.3761C43.749 30.531 43.8985 30.6439 44.073 30.691L46.601 31.349C46.6917 31.3735 46.7864 31.3794 46.8795 31.3665C46.9725 31.3536 47.0621 31.3221 47.1427 31.2738C47.2233 31.2256 47.2934 31.1616 47.3488 31.0857C47.4041 31.0098 47.4437 30.9235 47.465 30.832C48.173 27.6496 48.173 24.3504 47.465 21.168C47.4437 21.0765 47.4041 20.9902 47.3488 20.9143C47.2934 20.8384 47.2233 20.7744 47.1427 20.7262C47.0621 20.678 46.9725 20.6464 46.8795 20.6335C46.7864 20.6206 46.6917 20.6266 46.601 20.651ZM30.696 44.079C30.6502 43.9037 30.5376 43.7532 30.3823 43.6598C30.227 43.5663 30.0414 43.5374 29.865 43.579C27.3192 44.1397 24.6818 44.1397 22.136 43.579C21.9597 43.5389 21.7748 43.5686 21.6199 43.6618C21.465 43.755 21.3521 43.9045 21.305 44.079L20.647 46.6C20.6225 46.6907 20.6166 46.7854 20.6295 46.8785C20.6424 46.9716 20.6739 47.0611 20.7222 47.1417C20.7704 47.2223 20.8344 47.2924 20.9103 47.3478C20.9862 47.4032 21.0725 47.4427 21.164 47.464C24.3471 48.172 27.6469 48.172 30.83 47.464C30.9214 47.4427 31.0076 47.4032 31.0834 47.3479C31.1592 47.2926 31.2231 47.2226 31.2714 47.1421C31.3196 47.0616 31.3512 46.9722 31.3641 46.8792C31.3771 46.7863 31.3713 46.6917 31.347 46.601L30.696 44.079ZM15.21 7.64902C15.163 7.56762 15.1002 7.49651 15.0251 7.43993C14.9501 7.38335 14.8644 7.34245 14.7733 7.31968C14.6821 7.29691 14.5873 7.29273 14.4945 7.30739C14.4016 7.32205 14.3127 7.35526 14.233 7.40502C11.4742 9.14543 9.13842 11.4795 7.39599 14.237C7.34623 14.3167 7.31303 14.4057 7.29837 14.4985C7.28371 14.5913 7.28789 14.6861 7.31066 14.7773C7.33343 14.8685 7.37432 14.9541 7.4309 15.0292C7.48748 15.1042 7.55859 15.1671 7.63999 15.214L9.88599 16.533C10.0436 16.6246 10.2308 16.6511 10.4076 16.6068C10.5845 16.5626 10.7371 16.4511 10.833 16.296C12.237 14.1021 14.101 12.2394 16.296 10.837C16.451 10.7411 16.5625 10.5885 16.6068 10.4116C16.6511 10.2348 16.6246 10.0476 16.533 9.89002L15.21 7.64902ZM7.90999 21.308L5.39599 20.652C5.30528 20.6274 5.21053 20.6213 5.11741 20.6341C5.02428 20.6468 4.93468 20.6782 4.85396 20.7264C4.77323 20.7746 4.70303 20.8385 4.64754 20.9143C4.59205 20.9902 4.55242 21.0765 4.53099 21.168C3.823 24.3504 3.823 27.6496 4.53099 30.832C4.55231 30.9235 4.59184 31.0098 4.64721 31.0857C4.70258 31.1616 4.77267 31.2256 4.8533 31.2738C4.93392 31.3221 5.02343 31.3536 5.1165 31.3665C5.20956 31.3794 5.30428 31.3735 5.39499 31.349L7.92299 30.691C8.09751 30.6439 8.24702 30.531 8.34022 30.3761C8.43342 30.2212 8.46308 30.0363 8.42299 29.86C8.13992 28.5928 7.99673 27.2984 7.99599 26C7.99593 24.7027 8.13439 23.409 8.40899 22.141C8.44966 21.9645 8.42028 21.779 8.32703 21.6237C8.23379 21.4683 8.08494 21.3552 7.90999 21.308ZM9.88899 35.465L7.64599 36.785C7.56446 36.832 7.49322 36.8949 7.43655 36.97C7.37988 37.0451 7.33893 37.1309 7.31616 37.2222C7.29338 37.3135 7.28924 37.4084 7.30399 37.5013C7.31874 37.5943 7.35207 37.6833 7.40199 37.763C9.14933 40.5143 11.4817 42.8467 14.233 44.594C14.3127 44.6439 14.4017 44.6773 14.4947 44.692C14.5876 44.7068 14.6826 44.7026 14.7738 44.6799C14.8651 44.6571 14.9509 44.6161 15.026 44.5595C15.1011 44.5028 15.164 44.4316 15.211 44.35L16.531 42.107C16.6214 41.9499 16.6474 41.7638 16.6034 41.5879C16.5594 41.412 16.4488 41.26 16.295 41.164C14.1003 39.7592 12.2365 37.895 10.832 35.7C10.736 35.5462 10.584 35.4357 10.4081 35.3916C10.2322 35.3476 10.0461 35.3746 9.88899 35.465ZM41.16 35.7C39.7552 37.8951 37.891 39.7593 35.696 41.164C35.5422 41.26 35.4316 41.412 35.3876 41.5879C35.3436 41.7638 35.3695 41.9499 35.46 42.107L36.78 44.35C36.827 44.4316 36.8899 44.5028 36.965 44.5595C37.0401 44.6161 37.1258 44.6571 37.2171 44.6799C37.3084 44.7026 37.4034 44.7068 37.4963 44.692C37.5892 44.6773 37.6782 44.6439 37.758 44.594C40.5093 42.8467 42.8416 40.5143 44.589 37.763C44.6389 37.6833 44.6722 37.5943 44.687 37.5013C44.7017 37.4084 44.6976 37.3135 44.6748 37.2222C44.6521 37.1309 44.6111 37.0451 44.5544 36.97C44.4978 36.8949 44.4265 36.832 44.345 36.785L42.102 35.465C41.9448 35.3746 41.7587 35.3486 41.5828 35.3926C41.407 35.4367 41.255 35.5472 41.159 35.701M25.996 4.00002C24.3707 3.99798 22.7501 4.17607 21.164 4.53102C21.0725 4.55244 20.9862 4.59208 20.9103 4.64757C20.8344 4.70305 20.7705 4.77325 20.7224 4.85398C20.6742 4.93471 20.6428 5.02431 20.63 5.11743C20.6173 5.21056 20.6234 5.3053 20.648 5.39602L21.304 7.91202C21.3511 8.08696 21.4643 8.23681 21.6196 8.33006C21.775 8.4233 21.9604 8.45268 22.137 8.41202C23.405 8.13775 24.6987 7.99963 25.996 8.00002C27.2971 7.99907 28.5944 8.1399 29.865 8.42002C30.0414 8.46168 30.227 8.43269 30.3823 8.33926C30.5376 8.24583 30.6502 8.09536 30.696 7.92002L31.347 5.39302C31.3713 5.30237 31.3771 5.20776 31.3641 5.11481C31.3512 5.02186 31.3196 4.93247 31.2714 4.85196C31.2231 4.77145 31.1592 4.70146 31.0834 4.64615C31.0076 4.59084 30.9214 4.55135 30.83 4.53002C29.2431 4.17581 27.6219 3.99806 25.996 4.00002Z\" fill=\"${\n                                  isSelected ? '#FAB15C' : '#FFFFFF'\n                              }\"/>\n                          </g>\n                          <defs>\n                              <filter id=\"filter0_d_2631_274104\" x=\"6\" y=\"6\" width=\"40\" height=\"40\" filterUnits=\"userSpaceOnUse\" color-interpolation-filters=\"sRGB\">\n                                  <feFlood flood-opacity=\"0\" result=\"BackgroundImageFix\"/>\n                                  <feColorMatrix in=\"SourceAlpha\" type=\"matrix\" values=\"0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 127 0\" result=\"hardAlpha\"/>\n                                  <feOffset/>\n                                  <feGaussianBlur stdDeviation=\"2\"/>\n                                  <feComposite in2=\"hardAlpha\" operator=\"out\"/>\n                                  <feColorMatrix type=\"matrix\" values=\"0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0.15 0\"/>\n                                  <feBlend mode=\"normal\" in2=\"BackgroundImageFix\" result=\"effect1_dropShadow_2631_274104\"/>\n                                  <feBlend mode=\"normal\" in=\"SourceGraphic\" in2=\"effect1_dropShadow_2631_274104\" result=\"shape\"/>\n                              </filter>\n                              <filter id=\"filter1_d_2631_274104\" x=\"0\" y=\"0\" width=\"51.9961\" height=\"51.995\" filterUnits=\"userSpaceOnUse\" color-interpolation-filters=\"sRGB\">\n                                  <feFlood flood-opacity=\"0\" result=\"BackgroundImageFix\"/>\n                                  <feColorMatrix in=\"SourceAlpha\" type=\"matrix\" values=\"0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 127 0\" result=\"hardAlpha\"/>\n                                  <feOffset/>\n                                  <feGaussianBlur stdDeviation=\"2\"/>\n                                  <feComposite in2=\"hardAlpha\" operator=\"out\"/>\n                                  <feColorMatrix type=\"matrix\" values=\"0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0.15 0\"/>\n                                  <feBlend mode=\"normal\" in2=\"BackgroundImageFix\" result=\"effect1_dropShadow_2631_274104\"/>\n                                  <feBlend mode=\"normal\" in=\"SourceGraphic\" in2=\"effect1_dropShadow_2631_274104\" result=\"shape\"/>\n                              </filter>\n                          </defs>\n                        </svg>`;\n\n        const markerIconRoute =\n            'data:image/svg+xml;charset=UTF-8;base64,' + btoa(markerSvg);\n\n        return markerSvg;\n    }\n}\n"]}
@@ -81,9 +81,8 @@ export class ProgressBarComponent {
81
81
  path: [],
82
82
  decodedShape: loadStop.routeShape,
83
83
  strokeColor: index === 1
84
- ? MapOptionsConstants.routingPathColors
85
- .currentLocation
86
- : MapOptionsConstants.routingPathColors.default,
84
+ ? MapOptionsConstants.ROUTING_PATH_COLORS['currentLocation']
85
+ : MapOptionsConstants.ROUTING_PATH_COLORS['default'],
87
86
  strokeOpacity: 1,
88
87
  strokeWeight: 4,
89
88
  };
@@ -91,7 +90,7 @@ export class ProgressBarComponent {
91
90
  if (index === 1) {
92
91
  routePaths.push({
93
92
  ...routePath,
94
- strokeColor: MapOptionsConstants.routingPathColors.deadhead,
93
+ strokeColor: MapOptionsConstants.ROUTING_PATH_COLORS['deadhead'],
95
94
  strokeOpacity: 1,
96
95
  strokeWeight: 2,
97
96
  });
@@ -170,4 +169,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
170
169
  }], onOpenMap: [{
171
170
  type: Output
172
171
  }] } });
173
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ca-progress-bar.component.js","sourceRoot":"","sources":["../../../../../../projects/ca-components/src/lib/components/ca-progress-bar/ca-progress-bar.component.ts","../../../../../../projects/ca-components/src/lib/components/ca-progress-bar/ca-progress-bar.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport { Component, EventEmitter, Input, Output } from '@angular/core';\n\n// modules\nimport { AngularSvgIconModule } from 'angular-svg-icon';\nimport { NgbModule, NgbPopover, NgbTooltip } from '@ng-bootstrap/ng-bootstrap';\n\n// Components\nimport { CaMapComponent } from '../ca-map/ca-map.component';\nimport { CaAppTooltipV2Component } from '../ca-app-tooltip-v2/ca-app-tooltip-v2.component';\n\n// Constants\nimport { ProgressBarConstants } from './utils/constants';\nimport { MapOptionsConstants } from '../ca-map/utils/constants';\n\n// models\nimport { IGpsProgress } from './models';\nimport { ICaMapProps, IMapMarkers, IMapRoutePath } from '../ca-map/models';\n\n// svg-routes\nimport { ProgressBarSvgRoutes } from './utils/svg-routes';\n\n// pipes\nimport { ThousandSeparatorPipe } from '../../pipes/thousand-separator.pipe';\nimport { ConvertMinutesToHoursPipe } from './pipes';\n\n// Enums\nimport { ProgressBarStringEnum } from './enums';\n\n// Services\nimport { MapMarkerIconService } from '../ca-map/utils/services';\n\n@Component({\n    selector: 'app-ca-progress-bar',\n    templateUrl: './ca-progress-bar.component.html',\n    styleUrls: ['./ca-progress-bar.component.scss'],\n    standalone: true,\n    imports: [\n        // Modules\n        CommonModule,\n        AngularSvgIconModule,\n        NgbModule,\n        NgbTooltip,\n        // Components\n        CaMapComponent,\n        CaAppTooltipV2Component,\n        // Pipes\n        ThousandSeparatorPipe,\n        ConvertMinutesToHoursPipe,\n    ],\n})\nexport class ProgressBarComponent {\n    @Input() set gpsProgress(values: IGpsProgress[]) {\n        this.setGpsProgress(values);\n    }\n    @Input() currentStop!: IGpsProgress;\n    @Input() currentPosition!: number;\n    @Input() totalMiles!: number;\n    @Input() mileageInfo!: string;\n    @Input() gpsTitle: string = '';\n    @Input() gpsIcon!: string;\n    @Input() gpsInfo!: {\n        gpsheading: string;\n        gpsTime: string;\n        gpsheadingColor?: string;\n    };\n    @Input() mileagesPercent!: string;\n    @Input() gpsLocationIcon!: string;\n    @Input() dispatchStatus!: string;\n    @Input() isDropdown: boolean = false;\n\n    @Output() onOpenMap = new EventEmitter();\n\n    public _gpsProgress: IGpsProgress[] = [];\n\n    public gpsIconTopPosition: number = 0;\n\n    public hoveredGpsIcon: boolean = false;\n    public hoveredGpsTitle: string | null = null;\n    public hoveredMileageInfo: string | null = null;\n\n    public staticConstant = ProgressBarConstants;\n    public progressBarSvgRoutes = ProgressBarSvgRoutes;\n\n    public mapData: ICaMapProps = {\n        markers: [],\n        clusterMarkers: [],\n        routingMarkers: [],\n        routePaths: [],\n        darkMode: true,\n    };\n\n    constructor(private markerIconService: MapMarkerIconService) {}\n\n    public hoverStop(stop: IGpsProgress, i: number): void {\n        this.hoveredGpsTitle = stop?.isAtStop\n            ? ProgressBarStringEnum.CURRENT_LOCATION\n            : stop?.heading || null;\n        this.hoveredMileageInfo = !stop?.isAtStop ? stop?.mileage : '';\n    }\n\n    public leaveStop(): void {\n        this.hoveredGpsTitle = null;\n        this.hoveredMileageInfo = null;\n    }\n\n    public showDropdownMap(t2: NgbPopover): void {\n        t2.open();\n\n        this.onOpenMap.emit();\n    }\n\n    private setGpsProgress(gpsProgressData: IGpsProgress[]): void {\n        this._gpsProgress = gpsProgressData;\n\n        this.setMapMarkers();\n\n        this.calculateGpsIconPosition();\n    }\n\n    private setMapMarkers(): void {\n        let routeMarkers: IMapMarkers[] = [];\n        let routePaths: IMapRoutePath[] = [];\n\n        this._gpsProgress.forEach((loadStop, index) => {\n            const markerData = {\n                position: { lat: loadStop.latitude, lng: loadStop.longitude },\n            };\n\n            const routeMarker: IMapMarkers = {\n                ...markerData,\n                content: this.markerIconService.getRoutingMarkerIcon(\n                    markerData,\n                    loadStop.stopNumber ?? 0,\n                    loadStop.type,\n                    this.currentPosition >= loadStop.position\n                ),\n            };\n\n            routeMarkers = [...routeMarkers, routeMarker];\n\n            if (loadStop.routeShape) {\n                const routePath: IMapRoutePath = {\n                    path: [],\n                    decodedShape: loadStop.routeShape,\n                    strokeColor:\n                        index === 1\n                            ? MapOptionsConstants.routingPathColors\n                                  .currentLocation\n                            : MapOptionsConstants.routingPathColors.default,\n                    strokeOpacity: 1,\n                    strokeWeight: 4,\n                };\n\n                routePaths = [...routePaths, routePath];\n\n                if (index === 1) {\n                    routePaths.push({\n                        ...routePath,\n                        strokeColor:\n                            MapOptionsConstants.routingPathColors.deadhead,\n                        strokeOpacity: 1,\n                        strokeWeight: 2,\n                    });\n                }\n            }\n        });\n\n        this.mapData = {\n            ...this.mapData,\n            isZoomShown: true,\n            isVerticalZoom: true,\n            routingMarkers: routeMarkers,\n            routePaths: routePaths,\n        };\n    }\n\n    private calculateGpsIconPosition(): void {\n        let topPosition = 0;\n        let currentStopPercentage = null;\n        const stopPercentage = 100 / (this._gpsProgress.length - 1);\n\n        this._gpsProgress.forEach((stop, index) => {\n            const isAtDeadhead = stop.isAtStop && !index;\n\n            if (stop.isVisited && !isAtDeadhead)\n                topPosition += index ? stopPercentage : stopPercentage / 2;\n\n            if (stop.isAtStop) currentStopPercentage = stopPercentage * index;\n        });\n\n        this.gpsIconTopPosition = currentStopPercentage ?? topPosition;\n    }\n}\n","<div class=\"gps-progress-bar\">\n    <div\n        class=\"gps-progress-holder d-flex align-items-center\"\n        #t2=\"ngbPopover\"\n        [ngbPopover]=\"gpsDropdownPopover\"\n        [autoClose]=\"'outside'\"\n        container=\"body\"\n        [placement]=\"'bottom-right'\"\n        popoverClass=\"gps_dropdown_popover\"\n        triggers=\"manual\"\n        (click)=\"showDropdownMap(t2)\"\n    >\n        <div\n            class=\"cursor-pointer\"\n            (mouseenter)=\"hoveredGpsIcon = true\"\n            (mouseleave)=\"hoveredGpsIcon = false\"\n        >\n            <svg-icon class=\"svg-size-22\" [src]=\"gpsIcon\"></svg-icon>\n        </div>\n\n        @if (!hoveredGpsIcon) {\n            <div class=\"gps-progress-text flex-1\">\n                <div class=\"mileage-gps d-flex justify-content-between\">\n                    <div\n                        class=\"user-select-none text-size-11 text-color-black-2 ca-font-bold\"\n                    >\n                        {{ hoveredGpsTitle ?? gpsTitle }}\n                    </div>\n                    <div\n                        class=\"user-select-none text-size-11 text-color-black-2 ca-font-regular\"\n                    >\n                        {{ hoveredMileageInfo ?? mileageInfo }}\n                    </div>\n                </div>\n                <div class=\"mileage-gps d-flex\">\n                    <div class=\"gps-timeline flex-1\">\n                        <div\n                            class=\"gps-timeline-active\"\n                            [ngStyle]=\"{ width: currentPosition + '%' }\"\n                        ></div>\n\n                        @for (stop of _gpsProgress; let i = $index; track i) {\n                            <div\n                                class=\"gps-stop cursor-pointer\"\n                                (mouseenter)=\"hoverStop(stop, i)\"\n                                (mouseleave)=\"leaveStop()\"\n                                [ngClass]=\"{\n                                    'pickup-stop': stop.type === 'pickup',\n                                    'delivery-stop': stop.type === 'delivery',\n                                    'visited-stop':\n                                        currentPosition >= stop.position,\n                                }\"\n                                [ngStyle]=\"{ left: stop.position + '%' }\"\n                                ngbTooltip\n                                [tooltipBackground]=\"'#424242'\"\n                                [mainCaTooltip]=\"stop?.location ?? ''\"\n                                position=\"bottom\"\n                            ></div>\n                        }\n\n                        <div\n                            class=\"current-pos cursor-pointer\"\n                            (mouseenter)=\"hoverStop(currentStop, -2)\"\n                            (mouseleave)=\"leaveStop()\"\n                            [ngStyle]=\"{ left: currentPosition + '%' }\"\n                            ngbTooltip\n                            [tooltipBackground]=\"'#424242'\"\n                            [mainCaTooltip]=\"currentStop?.location\"\n                            [disableTooltip]=\"!currentStop\"\n                            position=\"bottom\"\n                        >\n                            <svg-icon\n                                class=\"svg-size-10\"\n                                [src]=\"gpsLocationIcon\"\n                            ></svg-icon>\n                        </div>\n                    </div>\n\n                    <div\n                        class=\"user-select-none text-size-11 text-color-black-2 ca-font-bold\"\n                    >\n                        {{ mileagesPercent }}\n                    </div>\n                </div>\n            </div>\n        } @else if (gpsInfo) {\n            <div\n                class=\"gps_info_hold d-flex flex-column flex-1 justify-content-center\"\n            >\n                <div\n                    class=\"moving_side text-size-11 ca-font-bold user-select-none\"\n                    [ngStyle]=\"{ color: gpsInfo.gpsheadingColor }\"\n                >\n                    {{ gpsInfo.gpsheading }}\n                </div>\n\n                <div\n                    class=\"moving_time text-size-11 text-color-black-2 ca-font-medium\"\n                >\n                    {{ gpsInfo.gpsTime }}\n                </div>\n            </div>\n        }\n    </div>\n\n    <ng-template #gpsDropdownPopover let-data=\"data\">\n        <div class=\"main_dropdown_holder d-flex\">\n            <div class=\"flex-1\">\n                <app-ca-map [data]=\"mapData\"></app-ca-map>\n            </div>\n\n            <div class=\"gps_all_hold\">\n                <div\n                    class=\"gps_header d-flex align-items-center\"\n                    (mouseenter)=\"hoveredGpsIcon = true\"\n                    (mouseleave)=\"hoveredGpsIcon = false\"\n                >\n                    <div class=\"cursor-pointer\">\n                        <svg-icon\n                            class=\"svg-size-22\"\n                            [src]=\"gpsIcon\"\n                        ></svg-icon>\n                    </div>\n\n                    <div\n                        class=\"gps_info_hold d-flex flex-column justify-content-center\"\n                    >\n                        <div\n                            class=\"moving_side text-size-11 ca-font-bold user-select-none\"\n                            [ngStyle]=\"{ color: gpsInfo.gpsheadingColor }\"\n                        >\n                            {{ gpsInfo.gpsheading }}\n                        </div>\n                    </div>\n                </div>\n\n                <div class=\"gps_info_border\"></div>\n\n                <div class=\"gps_progress_hold\">\n                    <div\n                        class=\"gps_progress_hold_inner d-flex flex-column justify-content-between align-items-start\"\n                    >\n                        <div class=\"progress_line\">\n                            <div\n                                class=\"progress_inner_line\"\n                                [ngStyle]=\"{\n                                    height: gpsIconTopPosition + '%',\n                                }\"\n                            ></div>\n\n                            @if (!currentStop) {\n                                <ng-container\n                                    *ngTemplateOutlet=\"\n                                        gpsLocationIconTemplate;\n                                        context: {\n                                            topPosition: gpsIconTopPosition,\n                                        }\n                                    \"\n                                ></ng-container>\n                            }\n                        </div>\n\n                        @for (\n                            stop of _gpsProgress;\n                            let stopIndex = $index;\n                            track stopIndex\n                        ) {\n                            <div class=\"progress_inner\">\n                                <div class=\"progress_header d-flex\">\n                                    <div\n                                        class=\"progress_header_inside d-flex flex-1\"\n                                    >\n                                        <div\n                                            class=\"progress_icon d-flex justify-content-center align-items-center\"\n                                        >\n                                            @if (!stop.isAtStop) {\n                                                @if (\n                                                    currentPosition >=\n                                                    stop.position\n                                                ) {\n                                                    <svg-icon\n                                                        class=\"svg-size-14\"\n                                                        [ngClass]=\"\n                                                            stop.type ===\n                                                            'pickup'\n                                                                ? 'svg-fill-green'\n                                                                : stop.type ===\n                                                                    'delivery'\n                                                                  ? 'svg-fill-red-10'\n                                                                  : 'svg-fill-grey'\n                                                        \"\n                                                        [src]=\"\n                                                            progressBarSvgRoutes.checkRoute\n                                                        \"\n                                                    ></svg-icon>\n                                                } @else {\n                                                    <div\n                                                        class=\"progress-stop-number text-size-14 text-center user-select-none\"\n                                                        [ngClass]=\"\n                                                            stop.type ===\n                                                            'pickup'\n                                                                ? 'text-color-green-4'\n                                                                : 'text-color-red-13'\n                                                        \"\n                                                    >\n                                                        {{ stop.stopNumber }}\n                                                    </div>\n                                                }\n                                            } @else {\n                                                <ng-container\n                                                    *ngTemplateOutlet=\"\n                                                        gpsLocationIconTemplate\n                                                    \"\n                                                ></ng-container>\n                                            }\n                                        </div>\n\n                                        <div\n                                            class=\"progress_info_hold d-flex flex-column\"\n                                        >\n                                            <div\n                                                class=\"progress_name text-size-11 ca-font-bold\"\n                                                [ngClass]=\"\n                                                    stop.isAtStop ||\n                                                    currentPosition <\n                                                        stop.position\n                                                        ? stop.type === 'pickup'\n                                                            ? 'text-color-green-4'\n                                                            : 'text-color-red-13'\n                                                        : 'text-color-grey'\n                                                \"\n                                            >\n                                                {{ stop?.location }}\n                                            </div>\n\n                                            @if (!stop.isAtStop) {\n                                                @if (stop.date) {\n                                                    <div\n                                                        class=\"progress_time text-size-11 text-color-white-2 ca-font-regular\"\n                                                        [ngClass]=\"{\n                                                            'text-color-grey':\n                                                                currentPosition >=\n                                                                    stop.position &&\n                                                                !stop.isAtStop,\n                                                        }\"\n                                                    >\n                                                        {{ stop.date }}\n                                                    </div>\n                                                }\n\n                                                @if (stop.time) {\n                                                    <div\n                                                        class=\"progress_time text-size-11 text-color-white-2 ca-font-regular\"\n                                                        [ngClass]=\"{\n                                                            'text-color-grey':\n                                                                currentPosition >=\n                                                                    stop.position &&\n                                                                !stop.isAtStop,\n                                                        }\"\n                                                    >\n                                                        {{ stop.time }}\n                                                    </div>\n                                                }\n                                            } @else {\n                                                <div\n                                                    class=\"progress_time text-size-11 text-color-white-2 ca-font-bold\"\n                                                >\n                                                    {{ dispatchStatus }}\n                                                </div>\n\n                                                @if (stop.currentWaitTime) {\n                                                    <div\n                                                        class=\"progress_time text-size-11 text-color-white-2\"\n                                                    >\n                                                        {{\n                                                            stop.currentWaitTime\n                                                                | convertMinutesToHours\n                                                        }}\n                                                    </div>\n                                                }\n                                            }\n                                        </div>\n                                    </div>\n\n                                    <div\n                                        class=\"progress-leg-miles-text text-size-11 text-color-white\"\n                                        [ngClass]=\"{\n                                            'text-color-grey':\n                                                currentPosition >=\n                                                    stop.position &&\n                                                !stop.isAtStop,\n                                            'ca-font-bold': stopIndex === 0,\n                                        }\"\n                                    >\n                                        {{\n                                            stopIndex === 0\n                                                ? 'LEG mi'\n                                                : stop?.legMiles\n                                                  ? '+' + stop.legMiles\n                                                  : '+' + 0\n                                        }}\n                                    </div>\n                                </div>\n                            </div>\n                        }\n                    </div>\n                </div>\n\n                <div class=\"gps_info_border\"></div>\n\n                <div class=\"gps_complete_hold\">\n                    <div class=\"gps_complete_row d-flex\">\n                        <div class=\"flex-1 text-size-11 text-color-white\">\n                            {{ staticConstant.completed }}\n                        </div>\n\n                        <div class=\"text-size-11 text-color-white\">\n                            {{ staticConstant.total }}\n                        </div>\n                    </div>\n\n                    <div class=\"gps_complete_second_row d-flex\">\n                        <div\n                            class=\"flex-1 text-size-11 text-color-blue-19 ca-font-bold\"\n                        >\n                            {{ currentPosition }}{{ staticConstant.percentage }}\n                        </div>\n\n                        <div class=\"text-size-11 text-color-white ca-font-bold\">\n                            {{ totalMiles | thousandSeparator }}\n                            {{ staticConstant.miles }}\n                        </div>\n                    </div>\n                </div>\n            </div>\n        </div>\n    </ng-template>\n</div>\n\n<ng-template #gpsLocationIconTemplate let-topPosition=\"topPosition\">\n    <div\n        class=\"d-flex align-items-center justify-content-center\"\n        [class.moving-gps]=\"!!topPosition\"\n        [style.top]=\"topPosition + '%'\"\n    >\n        <svg-icon class=\"d-flex svg-size-10\" [src]=\"gpsLocationIcon\"></svg-icon>\n    </div>\n</ng-template>\n"]}
172
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ca-progress-bar.component.js","sourceRoot":"","sources":["../../../../../../projects/ca-components/src/lib/components/ca-progress-bar/ca-progress-bar.component.ts","../../../../../../projects/ca-components/src/lib/components/ca-progress-bar/ca-progress-bar.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport { Component, EventEmitter, Input, Output } from '@angular/core';\n\n// modules\nimport { AngularSvgIconModule } from 'angular-svg-icon';\nimport { NgbModule, NgbPopover, NgbTooltip } from '@ng-bootstrap/ng-bootstrap';\n\n// Components\nimport { CaMapComponent } from '../ca-map/ca-map.component';\nimport { CaAppTooltipV2Component } from '../ca-app-tooltip-v2/ca-app-tooltip-v2.component';\n\n// Constants\nimport { ProgressBarConstants } from './utils/constants';\nimport { MapOptionsConstants } from '../ca-map/utils/constants';\n\n// models\nimport { IGpsProgress } from './models';\nimport { ICaMapProps, IMapMarkers, IMapRoutePath } from '../ca-map/models';\n\n// svg-routes\nimport { ProgressBarSvgRoutes } from './utils/svg-routes';\n\n// pipes\nimport { ThousandSeparatorPipe } from '../../pipes/thousand-separator.pipe';\nimport { ConvertMinutesToHoursPipe } from './pipes';\n\n// Enums\nimport { ProgressBarStringEnum } from './enums';\n\n// Services\nimport { MapMarkerIconService } from '../ca-map/utils/services';\n\n@Component({\n    selector: 'app-ca-progress-bar',\n    templateUrl: './ca-progress-bar.component.html',\n    styleUrls: ['./ca-progress-bar.component.scss'],\n    standalone: true,\n    imports: [\n        // Modules\n        CommonModule,\n        AngularSvgIconModule,\n        NgbModule,\n        NgbTooltip,\n        // Components\n        CaMapComponent,\n        CaAppTooltipV2Component,\n        // Pipes\n        ThousandSeparatorPipe,\n        ConvertMinutesToHoursPipe,\n    ],\n})\nexport class ProgressBarComponent {\n    @Input() set gpsProgress(values: IGpsProgress[]) {\n        this.setGpsProgress(values);\n    }\n    @Input() currentStop!: IGpsProgress;\n    @Input() currentPosition!: number;\n    @Input() totalMiles!: number;\n    @Input() mileageInfo!: string;\n    @Input() gpsTitle: string = '';\n    @Input() gpsIcon!: string;\n    @Input() gpsInfo!: {\n        gpsheading: string;\n        gpsTime: string;\n        gpsheadingColor?: string;\n    };\n    @Input() mileagesPercent!: string;\n    @Input() gpsLocationIcon!: string;\n    @Input() dispatchStatus!: string;\n    @Input() isDropdown: boolean = false;\n\n    @Output() onOpenMap = new EventEmitter();\n\n    public _gpsProgress: IGpsProgress[] = [];\n\n    public gpsIconTopPosition: number = 0;\n\n    public hoveredGpsIcon: boolean = false;\n    public hoveredGpsTitle: string | null = null;\n    public hoveredMileageInfo: string | null = null;\n\n    public staticConstant = ProgressBarConstants;\n    public progressBarSvgRoutes = ProgressBarSvgRoutes;\n\n    public mapData: ICaMapProps = {\n        markers: [],\n        clusterMarkers: [],\n        routingMarkers: [],\n        routePaths: [],\n        darkMode: true,\n    };\n\n    constructor(private markerIconService: MapMarkerIconService) {}\n\n    public hoverStop(stop: IGpsProgress, i: number): void {\n        this.hoveredGpsTitle = stop?.isAtStop\n            ? ProgressBarStringEnum.CURRENT_LOCATION\n            : stop?.heading || null;\n        this.hoveredMileageInfo = !stop?.isAtStop ? stop?.mileage : '';\n    }\n\n    public leaveStop(): void {\n        this.hoveredGpsTitle = null;\n        this.hoveredMileageInfo = null;\n    }\n\n    public showDropdownMap(t2: NgbPopover): void {\n        t2.open();\n\n        this.onOpenMap.emit();\n    }\n\n    private setGpsProgress(gpsProgressData: IGpsProgress[]): void {\n        this._gpsProgress = gpsProgressData;\n\n        this.setMapMarkers();\n\n        this.calculateGpsIconPosition();\n    }\n\n    private setMapMarkers(): void {\n        let routeMarkers: IMapMarkers[] = [];\n        let routePaths: IMapRoutePath[] = [];\n\n        this._gpsProgress.forEach((loadStop, index) => {\n            const markerData = {\n                position: { lat: loadStop.latitude, lng: loadStop.longitude },\n            };\n\n            const routeMarker: IMapMarkers = {\n                ...markerData,\n                content: this.markerIconService.getRoutingMarkerIcon(\n                    markerData,\n                    loadStop.stopNumber ?? 0,\n                    loadStop.type,\n                    this.currentPosition >= loadStop.position\n                ),\n            };\n\n            routeMarkers = [...routeMarkers, routeMarker];\n\n            if (loadStop.routeShape) {\n                const routePath: IMapRoutePath = {\n                    path: [],\n                    decodedShape: loadStop.routeShape,\n                    strokeColor:\n                        index === 1\n                            ? MapOptionsConstants.ROUTING_PATH_COLORS[\n                                  'currentLocation'\n                              ]\n                            : MapOptionsConstants.ROUTING_PATH_COLORS[\n                                  'default'\n                              ],\n                    strokeOpacity: 1,\n                    strokeWeight: 4,\n                };\n\n                routePaths = [...routePaths, routePath];\n\n                if (index === 1) {\n                    routePaths.push({\n                        ...routePath,\n                        strokeColor:\n                            MapOptionsConstants.ROUTING_PATH_COLORS['deadhead'],\n                        strokeOpacity: 1,\n                        strokeWeight: 2,\n                    });\n                }\n            }\n        });\n\n        this.mapData = {\n            ...this.mapData,\n            isZoomShown: true,\n            isVerticalZoom: true,\n            routingMarkers: routeMarkers,\n            routePaths: routePaths,\n        };\n    }\n\n    private calculateGpsIconPosition(): void {\n        let topPosition = 0;\n        let currentStopPercentage = null;\n        const stopPercentage = 100 / (this._gpsProgress.length - 1);\n\n        this._gpsProgress.forEach((stop, index) => {\n            const isAtDeadhead = stop.isAtStop && !index;\n\n            if (stop.isVisited && !isAtDeadhead)\n                topPosition += index ? stopPercentage : stopPercentage / 2;\n\n            if (stop.isAtStop) currentStopPercentage = stopPercentage * index;\n        });\n\n        this.gpsIconTopPosition = currentStopPercentage ?? topPosition;\n    }\n}\n","<div class=\"gps-progress-bar\">\n    <div\n        class=\"gps-progress-holder d-flex align-items-center\"\n        #t2=\"ngbPopover\"\n        [ngbPopover]=\"gpsDropdownPopover\"\n        [autoClose]=\"'outside'\"\n        container=\"body\"\n        [placement]=\"'bottom-right'\"\n        popoverClass=\"gps_dropdown_popover\"\n        triggers=\"manual\"\n        (click)=\"showDropdownMap(t2)\"\n    >\n        <div\n            class=\"cursor-pointer\"\n            (mouseenter)=\"hoveredGpsIcon = true\"\n            (mouseleave)=\"hoveredGpsIcon = false\"\n        >\n            <svg-icon class=\"svg-size-22\" [src]=\"gpsIcon\"></svg-icon>\n        </div>\n\n        @if (!hoveredGpsIcon) {\n            <div class=\"gps-progress-text flex-1\">\n                <div class=\"mileage-gps d-flex justify-content-between\">\n                    <div\n                        class=\"user-select-none text-size-11 text-color-black-2 ca-font-bold\"\n                    >\n                        {{ hoveredGpsTitle ?? gpsTitle }}\n                    </div>\n                    <div\n                        class=\"user-select-none text-size-11 text-color-black-2 ca-font-regular\"\n                    >\n                        {{ hoveredMileageInfo ?? mileageInfo }}\n                    </div>\n                </div>\n                <div class=\"mileage-gps d-flex\">\n                    <div class=\"gps-timeline flex-1\">\n                        <div\n                            class=\"gps-timeline-active\"\n                            [ngStyle]=\"{ width: currentPosition + '%' }\"\n                        ></div>\n\n                        @for (stop of _gpsProgress; let i = $index; track i) {\n                            <div\n                                class=\"gps-stop cursor-pointer\"\n                                (mouseenter)=\"hoverStop(stop, i)\"\n                                (mouseleave)=\"leaveStop()\"\n                                [ngClass]=\"{\n                                    'pickup-stop': stop.type === 'pickup',\n                                    'delivery-stop': stop.type === 'delivery',\n                                    'visited-stop':\n                                        currentPosition >= stop.position,\n                                }\"\n                                [ngStyle]=\"{ left: stop.position + '%' }\"\n                                ngbTooltip\n                                [tooltipBackground]=\"'#424242'\"\n                                [mainCaTooltip]=\"stop?.location ?? ''\"\n                                position=\"bottom\"\n                            ></div>\n                        }\n\n                        <div\n                            class=\"current-pos cursor-pointer\"\n                            (mouseenter)=\"hoverStop(currentStop, -2)\"\n                            (mouseleave)=\"leaveStop()\"\n                            [ngStyle]=\"{ left: currentPosition + '%' }\"\n                            ngbTooltip\n                            [tooltipBackground]=\"'#424242'\"\n                            [mainCaTooltip]=\"currentStop?.location\"\n                            [disableTooltip]=\"!currentStop\"\n                            position=\"bottom\"\n                        >\n                            <svg-icon\n                                class=\"svg-size-10\"\n                                [src]=\"gpsLocationIcon\"\n                            ></svg-icon>\n                        </div>\n                    </div>\n\n                    <div\n                        class=\"user-select-none text-size-11 text-color-black-2 ca-font-bold\"\n                    >\n                        {{ mileagesPercent }}\n                    </div>\n                </div>\n            </div>\n        } @else if (gpsInfo) {\n            <div\n                class=\"gps_info_hold d-flex flex-column flex-1 justify-content-center\"\n            >\n                <div\n                    class=\"moving_side text-size-11 ca-font-bold user-select-none\"\n                    [ngStyle]=\"{ color: gpsInfo.gpsheadingColor }\"\n                >\n                    {{ gpsInfo.gpsheading }}\n                </div>\n\n                <div\n                    class=\"moving_time text-size-11 text-color-black-2 ca-font-medium\"\n                >\n                    {{ gpsInfo.gpsTime }}\n                </div>\n            </div>\n        }\n    </div>\n\n    <ng-template #gpsDropdownPopover let-data=\"data\">\n        <div class=\"main_dropdown_holder d-flex\">\n            <div class=\"flex-1\">\n                <app-ca-map [data]=\"mapData\"></app-ca-map>\n            </div>\n\n            <div class=\"gps_all_hold\">\n                <div\n                    class=\"gps_header d-flex align-items-center\"\n                    (mouseenter)=\"hoveredGpsIcon = true\"\n                    (mouseleave)=\"hoveredGpsIcon = false\"\n                >\n                    <div class=\"cursor-pointer\">\n                        <svg-icon\n                            class=\"svg-size-22\"\n                            [src]=\"gpsIcon\"\n                        ></svg-icon>\n                    </div>\n\n                    <div\n                        class=\"gps_info_hold d-flex flex-column justify-content-center\"\n                    >\n                        <div\n                            class=\"moving_side text-size-11 ca-font-bold user-select-none\"\n                            [ngStyle]=\"{ color: gpsInfo.gpsheadingColor }\"\n                        >\n                            {{ gpsInfo.gpsheading }}\n                        </div>\n                    </div>\n                </div>\n\n                <div class=\"gps_info_border\"></div>\n\n                <div class=\"gps_progress_hold\">\n                    <div\n                        class=\"gps_progress_hold_inner d-flex flex-column justify-content-between align-items-start\"\n                    >\n                        <div class=\"progress_line\">\n                            <div\n                                class=\"progress_inner_line\"\n                                [ngStyle]=\"{\n                                    height: gpsIconTopPosition + '%',\n                                }\"\n                            ></div>\n\n                            @if (!currentStop) {\n                                <ng-container\n                                    *ngTemplateOutlet=\"\n                                        gpsLocationIconTemplate;\n                                        context: {\n                                            topPosition: gpsIconTopPosition,\n                                        }\n                                    \"\n                                ></ng-container>\n                            }\n                        </div>\n\n                        @for (\n                            stop of _gpsProgress;\n                            let stopIndex = $index;\n                            track stopIndex\n                        ) {\n                            <div class=\"progress_inner\">\n                                <div class=\"progress_header d-flex\">\n                                    <div\n                                        class=\"progress_header_inside d-flex flex-1\"\n                                    >\n                                        <div\n                                            class=\"progress_icon d-flex justify-content-center align-items-center\"\n                                        >\n                                            @if (!stop.isAtStop) {\n                                                @if (\n                                                    currentPosition >=\n                                                    stop.position\n                                                ) {\n                                                    <svg-icon\n                                                        class=\"svg-size-14\"\n                                                        [ngClass]=\"\n                                                            stop.type ===\n                                                            'pickup'\n                                                                ? 'svg-fill-green'\n                                                                : stop.type ===\n                                                                    'delivery'\n                                                                  ? 'svg-fill-red-10'\n                                                                  : 'svg-fill-grey'\n                                                        \"\n                                                        [src]=\"\n                                                            progressBarSvgRoutes.checkRoute\n                                                        \"\n                                                    ></svg-icon>\n                                                } @else {\n                                                    <div\n                                                        class=\"progress-stop-number text-size-14 text-center user-select-none\"\n                                                        [ngClass]=\"\n                                                            stop.type ===\n                                                            'pickup'\n                                                                ? 'text-color-green-4'\n                                                                : 'text-color-red-13'\n                                                        \"\n                                                    >\n                                                        {{ stop.stopNumber }}\n                                                    </div>\n                                                }\n                                            } @else {\n                                                <ng-container\n                                                    *ngTemplateOutlet=\"\n                                                        gpsLocationIconTemplate\n                                                    \"\n                                                ></ng-container>\n                                            }\n                                        </div>\n\n                                        <div\n                                            class=\"progress_info_hold d-flex flex-column\"\n                                        >\n                                            <div\n                                                class=\"progress_name text-size-11 ca-font-bold\"\n                                                [ngClass]=\"\n                                                    stop.isAtStop ||\n                                                    currentPosition <\n                                                        stop.position\n                                                        ? stop.type === 'pickup'\n                                                            ? 'text-color-green-4'\n                                                            : 'text-color-red-13'\n                                                        : 'text-color-grey'\n                                                \"\n                                            >\n                                                {{ stop?.location }}\n                                            </div>\n\n                                            @if (!stop.isAtStop) {\n                                                @if (stop.date) {\n                                                    <div\n                                                        class=\"progress_time text-size-11 text-color-white-2 ca-font-regular\"\n                                                        [ngClass]=\"{\n                                                            'text-color-grey':\n                                                                currentPosition >=\n                                                                    stop.position &&\n                                                                !stop.isAtStop,\n                                                        }\"\n                                                    >\n                                                        {{ stop.date }}\n                                                    </div>\n                                                }\n\n                                                @if (stop.time) {\n                                                    <div\n                                                        class=\"progress_time text-size-11 text-color-white-2 ca-font-regular\"\n                                                        [ngClass]=\"{\n                                                            'text-color-grey':\n                                                                currentPosition >=\n                                                                    stop.position &&\n                                                                !stop.isAtStop,\n                                                        }\"\n                                                    >\n                                                        {{ stop.time }}\n                                                    </div>\n                                                }\n                                            } @else {\n                                                <div\n                                                    class=\"progress_time text-size-11 text-color-white-2 ca-font-bold\"\n                                                >\n                                                    {{ dispatchStatus }}\n                                                </div>\n\n                                                @if (stop.currentWaitTime) {\n                                                    <div\n                                                        class=\"progress_time text-size-11 text-color-white-2\"\n                                                    >\n                                                        {{\n                                                            stop.currentWaitTime\n                                                                | convertMinutesToHours\n                                                        }}\n                                                    </div>\n                                                }\n                                            }\n                                        </div>\n                                    </div>\n\n                                    <div\n                                        class=\"progress-leg-miles-text text-size-11 text-color-white\"\n                                        [ngClass]=\"{\n                                            'text-color-grey':\n                                                currentPosition >=\n                                                    stop.position &&\n                                                !stop.isAtStop,\n                                            'ca-font-bold': stopIndex === 0,\n                                        }\"\n                                    >\n                                        {{\n                                            stopIndex === 0\n                                                ? 'LEG mi'\n                                                : stop?.legMiles\n                                                  ? '+' + stop.legMiles\n                                                  : '+' + 0\n                                        }}\n                                    </div>\n                                </div>\n                            </div>\n                        }\n                    </div>\n                </div>\n\n                <div class=\"gps_info_border\"></div>\n\n                <div class=\"gps_complete_hold\">\n                    <div class=\"gps_complete_row d-flex\">\n                        <div class=\"flex-1 text-size-11 text-color-white\">\n                            {{ staticConstant.completed }}\n                        </div>\n\n                        <div class=\"text-size-11 text-color-white\">\n                            {{ staticConstant.total }}\n                        </div>\n                    </div>\n\n                    <div class=\"gps_complete_second_row d-flex\">\n                        <div\n                            class=\"flex-1 text-size-11 text-color-blue-19 ca-font-bold\"\n                        >\n                            {{ currentPosition }}{{ staticConstant.percentage }}\n                        </div>\n\n                        <div class=\"text-size-11 text-color-white ca-font-bold\">\n                            {{ totalMiles | thousandSeparator }}\n                            {{ staticConstant.miles }}\n                        </div>\n                    </div>\n                </div>\n            </div>\n        </div>\n    </ng-template>\n</div>\n\n<ng-template #gpsLocationIconTemplate let-topPosition=\"topPosition\">\n    <div\n        class=\"d-flex align-items-center justify-content-center\"\n        [class.moving-gps]=\"!!topPosition\"\n        [style.top]=\"topPosition + '%'\"\n    >\n        <svg-icon class=\"d-flex svg-size-10\" [src]=\"gpsLocationIcon\"></svg-icon>\n    </div>\n</ng-template>\n"]}