ca-components 1.3.95 → 1.3.97
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/components/ca-map/ca-map.component.mjs +6 -6
- package/esm2022/lib/components/ca-map/enums/map-marker-string.enum.mjs +5 -1
- package/esm2022/lib/components/ca-map/models/map.model.mjs +1 -1
- package/esm2022/lib/components/ca-map/utils/constants/map-options.constants.mjs +27 -18
- package/esm2022/lib/components/ca-map/utils/helpers/map-marker-icon.helper.mjs +51 -10
- package/esm2022/lib/components/ca-period-content/ca-period-content.component.mjs +3 -3
- package/esm2022/lib/components/ca-period-content/components/ca-period-content-payment/ca-period-content-payment.component.mjs +3 -3
- package/esm2022/lib/components/ca-progress-bar/ca-progress-bar.component.mjs +4 -5
- package/esm2022/lib/components/ca-upload-files/components/ca-upload-file/ca-upload-file.component.mjs +3 -3
- package/fesm2022/ca-components.mjs +94 -41
- package/fesm2022/ca-components.mjs.map +1 -1
- package/lib/components/ca-map/ca-map.component.d.ts +1 -15
- package/lib/components/ca-map/enums/map-marker-string.enum.d.ts +4 -0
- package/lib/components/ca-map/models/map.model.d.ts +14 -0
- package/lib/components/ca-map/utils/constants/map-options.constants.d.ts +15 -68
- package/lib/components/ca-map/utils/helpers/map-marker-icon.helper.d.ts +1 -0
- package/package.json +1 -1
|
@@ -81,9 +81,8 @@ export class ProgressBarComponent {
|
|
|
81
81
|
path: [],
|
|
82
82
|
decodedShape: loadStop.routeShape,
|
|
83
83
|
strokeColor: index === 1
|
|
84
|
-
? MapOptionsConstants.
|
|
85
|
-
|
|
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.
|
|
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"]}
|