ca-components 0.0.3 → 0.0.5
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/animations/in-out.animation.mjs +73 -0
- package/esm2022/lib/animations/state-header.animation.mjs +17 -0
- package/esm2022/lib/components/ca-app-tooltip-v2/ca-app-tooltip-v2.component.mjs +1 -1
- package/esm2022/lib/components/ca-details-dropdown/ca-details-dropdown.component.mjs +14 -14
- package/esm2022/lib/components/ca-details-dropdown/models/detail-dropdown.model.mjs +1 -1
- package/esm2022/lib/components/ca-dropdown/ca-dropdown.component.mjs +6 -6
- package/esm2022/lib/components/ca-filters/ca-filter.component.mjs +119 -55
- package/esm2022/lib/components/ca-filters/components/ca-money-filter/ca-money-filter.component.mjs +127 -111
- package/esm2022/lib/components/ca-filters/components/ca-money-filter/config/ca-money-filter.config.mjs +1 -1
- package/esm2022/lib/components/ca-filters/components/ca-state-filter/ca-state-filter.component.mjs +242 -0
- package/esm2022/lib/components/ca-filters/components/ca-status-filter/ca-status-filter.component.mjs +35 -34
- package/esm2022/lib/components/ca-filters/components/ca-time-filter/ca-time-filter.component.mjs +26 -25
- package/esm2022/lib/components/ca-filters/components/ca-trailer-type-filter/ca-trailer-type-filter.component.mjs +178 -0
- package/esm2022/lib/components/ca-filters/components/ca-truck-type-filter/ca-truck-type-filter.component.mjs +178 -0
- package/esm2022/lib/components/ca-filters/components/ca-user-filter/ca-user-filter.component.mjs +247 -0
- package/esm2022/lib/components/ca-filters/components/ca-user-filter/config/ca-user-filter.config.mjs +15 -0
- package/esm2022/lib/components/ca-filters/pipes/filter-conditions-clear.pipe.mjs +39 -0
- package/esm2022/lib/components/ca-filters/pipes/filter-conditions-set.pipe.mjs +47 -0
- package/esm2022/lib/components/ca-filters/pipes/filter-trailer-color.pipe.mjs +45 -0
- package/esm2022/lib/components/ca-filters/utils/constants/directive.constants.mjs +548 -0
- package/esm2022/lib/components/ca-filters/utils/constants/filter-icons-routes.constants.mjs +7 -0
- package/esm2022/lib/components/ca-input/ca-input.component.mjs +59 -45
- package/esm2022/lib/components/ca-input/components/ca-input-clear/ca-input-clear.component.mjs +3 -3
- package/esm2022/lib/components/ca-input/components/ca-input-commands/ca-input-commands.component.mjs +45 -0
- package/esm2022/lib/components/ca-input/components/ca-input-password/ca-input-password.component.mjs +4 -4
- package/esm2022/lib/components/ca-input/components/ca-input-placeholder-icon/ca-input-placeholder-icon.component.mjs +4 -4
- package/esm2022/lib/components/ca-input/enums/input-commands-action.enum.mjs +11 -0
- package/esm2022/lib/components/ca-input/enums/input-commands-type.enum.mjs +7 -0
- package/esm2022/lib/components/ca-input/models/command-click.model.mjs +2 -0
- package/esm2022/lib/components/ca-input/models/commands-event.model.mjs +2 -0
- package/esm2022/lib/components/ca-input/pipes/input-class.pipe.mjs +1 -1
- package/esm2022/lib/components/ca-input/pipes/input-clear-class.pipe.mjs +1 -1
- package/esm2022/lib/components/ca-input/pipes/input-container-class.pipe.mjs +1 -1
- package/esm2022/lib/components/ca-input/pipes/input-password-eye-class.pipe.mjs +1 -1
- package/esm2022/lib/components/ca-input/pipes/input-placeholder-icon.class.pipe.mjs +1 -1
- package/esm2022/lib/components/ca-input/pipes/label-class.pipe.mjs +1 -1
- package/esm2022/lib/components/ca-input/pipes/show-clear.pipe.mjs +1 -1
- package/esm2022/lib/components/ca-input/pipes/show-invalid-danger-mark.pipe.mjs +1 -1
- package/esm2022/lib/components/ca-input/pipes/show-valid-check.pipe.mjs +1 -1
- package/esm2022/lib/components/ca-input/services/ca-input-state.service.mjs +225 -7
- package/esm2022/lib/components/ca-input/utils/input-svg-routes.mjs +4 -2
- package/esm2022/lib/components/ca-map/ca-map.component.mjs +6 -5
- package/esm2022/lib/components/ca-map/models/map.model.mjs +1 -1
- package/esm2022/lib/components/ca-map-dropdown/ca-map-dropdown.component.mjs +11 -13
- package/esm2022/lib/components/ca-note/ca-note.component.mjs +34 -32
- package/esm2022/lib/components/ca-note-container/ca-note-container.component.mjs +17 -17
- package/esm2022/lib/components/ca-note-container/utils/constants/note-config.constant.mjs +25 -25
- package/esm2022/lib/components/ca-payroll-list-summary-overview/ca-payroll-list-summary-overview.component.mjs +12 -12
- package/esm2022/lib/components/ca-payroll-list-summary-overview-table/ca-payroll-list-summary-overview-table.component.mjs +7 -7
- package/esm2022/lib/components/ca-pickup-delivery-block/ca-pickup-delivery-block.component.mjs +7 -7
- package/esm2022/lib/components/ca-pickup-delivery-block/components/ca-load/ca-load.component.mjs +18 -17
- package/esm2022/lib/components/ca-pickup-delivery-block/components/ca-load/components/ca-load-list/ca-load-list.component.mjs +24 -19
- package/esm2022/lib/components/ca-pickup-delivery-block/components/ca-load/components/ca-load-single/ca-load-single.component.mjs +21 -18
- package/esm2022/lib/components/ca-pickup-delivery-block/models/animation-model.mjs +1 -1
- package/esm2022/lib/components/ca-pickup-delivery-block/models/broker-short-response.mjs +1 -1
- package/esm2022/lib/components/ca-pickup-delivery-block/models/dispatch-assigned-load-list-response.mjs +1 -1
- package/esm2022/lib/components/ca-pickup-delivery-block/models/load-short-response.mjs +1 -1
- package/esm2022/lib/components/ca-pickup-delivery-block/models/load-stop-short-response.mjs +1 -1
- package/esm2022/lib/components/ca-pickup-delivery-block/models/shipper-short-response.mjs +1 -1
- package/esm2022/lib/components/ca-pickup-delivery-block/utils/constants/animation-object-default.constants.mjs +3 -3
- package/esm2022/lib/components/ca-pickup-delivery-block/utils/helpers/pickup-delivery.helper.mjs +6 -3
- package/esm2022/lib/components/ca-profile-image/ca-profile-image.component.mjs +3 -3
- package/esm2022/lib/components/ca-progress-bar/ca-progress-bar.component.mjs +31 -31
- package/esm2022/lib/components/ca-search-multiple-states/ca-search-multiple-states.component.mjs +20 -20
- package/esm2022/lib/components/ca-search-multiple-states/utils/config/input-config.mjs +1 -1
- package/esm2022/lib/components/ca-spinner/ca-spinner.component.mjs +2 -2
- package/esm2022/lib/components/ca-truck-trailer-progress-bar/ca-truck-trailer-progress-bar.component.mjs +24 -20
- package/esm2022/lib/components/ca-truck-trailer-progress-bar/models/progress-dropdown-data.model.mjs +1 -1
- package/esm2022/lib/enums/trailer-name-string.enum.mjs +18 -0
- package/esm2022/lib/models/card-models/card-table-data.model.mjs +1 -1
- package/esm2022/lib/models/table-models/all-table-animation.model.mjs +2 -0
- package/esm2022/lib/models/trailer-minimal-response.mjs +1 -1
- package/esm2022/lib/models/truck-minimal-response.mjs +1 -1
- package/esm2022/lib/models/user-selected.model.mjs +2 -0
- package/esm2022/lib/pipes/thousand-separator.pipe.mjs +2 -2
- package/esm2022/lib/pipes/thousand-to-short-format-pipe.mjs +4 -4
- package/esm2022/lib/services/truckassist-table.service.mjs +3 -1
- package/fesm2022/ca-components.mjs +6032 -527
- package/fesm2022/ca-components.mjs.map +1 -1
- package/lib/animations/state-header.animation.d.ts +1 -0
- package/lib/components/ca-app-tooltip-v2/ca-app-tooltip-v2.component.d.ts +2 -2
- package/lib/components/ca-details-dropdown/ca-details-dropdown.component.d.ts +7 -7
- package/lib/components/ca-details-dropdown/models/detail-dropdown.model.d.ts +5 -5
- package/lib/components/ca-dropdown/ca-dropdown.component.d.ts +2 -2
- package/lib/components/ca-filters/ca-filter.component.d.ts +20 -14
- package/lib/components/ca-filters/components/ca-money-filter/ca-money-filter.component.d.ts +10 -10
- package/lib/components/ca-filters/components/ca-money-filter/config/ca-money-filter.config.d.ts +1 -1
- package/lib/components/ca-filters/components/ca-state-filter/ca-state-filter.component.d.ts +52 -0
- package/lib/components/ca-filters/components/ca-status-filter/ca-status-filter.component.d.ts +9 -9
- package/lib/components/ca-filters/components/ca-time-filter/ca-time-filter.component.d.ts +6 -6
- package/lib/components/ca-filters/components/ca-trailer-type-filter/ca-trailer-type-filter.component.d.ts +35 -0
- package/lib/components/ca-filters/components/ca-truck-type-filter/ca-truck-type-filter.component.d.ts +35 -0
- package/lib/components/ca-filters/components/ca-user-filter/ca-user-filter.component.d.ts +46 -0
- package/lib/components/ca-filters/components/ca-user-filter/config/ca-user-filter.config.d.ts +4 -0
- package/lib/components/ca-filters/pipes/filter-conditions-clear.pipe.d.ts +14 -0
- package/lib/components/ca-filters/pipes/filter-conditions-set.pipe.d.ts +14 -0
- package/lib/components/ca-filters/pipes/filter-trailer-color.pipe.d.ts +7 -0
- package/lib/components/ca-filters/utils/constants/directive.constants.d.ts +8 -0
- package/lib/components/ca-filters/utils/constants/filter-icons-routes.constants.d.ts +6 -0
- package/lib/components/ca-input/ca-input.component.d.ts +16 -8
- package/lib/components/ca-input/components/ca-input-clear/ca-input-clear.component.d.ts +3 -3
- package/lib/components/ca-input/components/ca-input-commands/ca-input-commands.component.d.ts +14 -0
- package/lib/components/ca-input/components/ca-input-password/ca-input-password.component.d.ts +2 -2
- package/lib/components/ca-input/components/ca-input-placeholder-icon/ca-input-placeholder-icon.component.d.ts +2 -2
- package/lib/components/ca-input/enums/input-commands-action.enum.d.ts +9 -0
- package/lib/components/ca-input/enums/input-commands-type.enum.d.ts +5 -0
- package/lib/components/ca-input/models/command-click.model.d.ts +5 -0
- package/lib/components/ca-input/models/commands-event.model.d.ts +5 -0
- package/lib/components/ca-input/pipes/input-class.pipe.d.ts +1 -1
- package/lib/components/ca-input/pipes/input-clear-class.pipe.d.ts +1 -1
- package/lib/components/ca-input/pipes/input-container-class.pipe.d.ts +1 -1
- package/lib/components/ca-input/pipes/input-password-eye-class.pipe.d.ts +1 -1
- package/lib/components/ca-input/pipes/input-placeholder-icon.class.pipe.d.ts +2 -2
- package/lib/components/ca-input/pipes/label-class.pipe.d.ts +1 -1
- package/lib/components/ca-input/pipes/show-clear.pipe.d.ts +1 -1
- package/lib/components/ca-input/pipes/show-invalid-danger-mark.pipe.d.ts +1 -1
- package/lib/components/ca-input/pipes/show-valid-check.pipe.d.ts +1 -1
- package/lib/components/ca-input/services/ca-input-state.service.d.ts +31 -5
- package/lib/components/ca-input/utils/input-svg-routes.d.ts +2 -0
- package/lib/components/ca-map/ca-map.component.d.ts +1 -1
- package/lib/components/ca-map/models/map.model.d.ts +2 -2
- package/lib/components/ca-map-dropdown/ca-map-dropdown.component.d.ts +4 -29
- package/lib/components/ca-note/ca-note.component.d.ts +5 -5
- package/lib/components/ca-note-container/ca-note-container.component.d.ts +4 -4
- package/lib/components/ca-note-container/utils/constants/note-config.constant.d.ts +2 -2
- package/lib/components/ca-payroll-list-summary-overview/ca-payroll-list-summary-overview.component.d.ts +3 -3
- package/lib/components/ca-payroll-list-summary-overview-table/ca-payroll-list-summary-overview-table.component.d.ts +1 -1
- package/lib/components/ca-pickup-delivery-block/ca-pickup-delivery-block.component.d.ts +5 -5
- package/lib/components/ca-pickup-delivery-block/components/ca-load/ca-load.component.d.ts +4 -4
- package/lib/components/ca-pickup-delivery-block/components/ca-load/components/ca-load-list/ca-load-list.component.d.ts +6 -6
- package/lib/components/ca-pickup-delivery-block/components/ca-load/components/ca-load-single/ca-load-single.component.d.ts +5 -5
- package/lib/components/ca-pickup-delivery-block/models/animation-model.d.ts +1 -1
- package/lib/components/ca-pickup-delivery-block/models/broker-short-response.d.ts +1 -1
- package/lib/components/ca-pickup-delivery-block/models/dispatch-assigned-load-list-response.d.ts +1 -1
- package/lib/components/ca-pickup-delivery-block/models/load-short-response.d.ts +3 -3
- package/lib/components/ca-pickup-delivery-block/models/load-stop-short-response.d.ts +2 -2
- package/lib/components/ca-pickup-delivery-block/models/shipper-short-response.d.ts +1 -1
- package/lib/components/ca-pickup-delivery-block/utils/constants/animation-object-default.constants.d.ts +1 -1
- package/lib/components/ca-pickup-delivery-block/utils/helpers/pickup-delivery.helper.d.ts +3 -3
- package/lib/components/ca-progress-bar/ca-progress-bar.component.d.ts +3 -3
- package/lib/components/ca-search-multiple-states/ca-search-multiple-states.component.d.ts +3 -3
- package/lib/components/ca-search-multiple-states/utils/config/input-config.d.ts +1 -1
- package/lib/components/ca-truck-trailer-progress-bar/ca-truck-trailer-progress-bar.component.d.ts +2 -2
- package/lib/components/ca-truck-trailer-progress-bar/models/progress-dropdown-data.model.d.ts +1 -1
- package/lib/enums/trailer-name-string.enum.d.ts +16 -0
- package/lib/models/card-models/card-table-data.model.d.ts +3 -3
- package/lib/models/table-models/all-table-animation.model.d.ts +10 -0
- package/lib/models/trailer-minimal-response.d.ts +1 -1
- package/lib/models/truck-minimal-response.d.ts +2 -2
- package/lib/models/user-selected.model.d.ts +8 -0
- package/lib/pipes/thousand-to-short-format-pipe.d.ts +1 -1
- package/lib/services/truckassist-table.service.d.ts +2 -0
- package/package.json +1 -1
- package/src/assets/global_style/styles.scss +1 -0
- package/src/assets/scss/input-dropdown.scss +1876 -0
- package/src/assets/scss/popover.scss +89 -89
- package/src/assets/svg/common/trailers/ic_carhauler_stinger.svg +6 -0
- package/src/assets/svg/common/trailers/ic_trailer_carhauler.svg +1 -0
- package/src/assets/svg/common/trailers/ic_trailer_chassis.svg +1 -0
- package/src/assets/svg/common/trailers/ic_trailer_conestoga.svg +1 -0
- package/src/assets/svg/common/trailers/ic_trailer_container.svg +1 -0
- package/src/assets/svg/common/trailers/ic_trailer_dryvan.svg +1 -0
- package/src/assets/svg/common/trailers/ic_trailer_dumper.svg +1 -0
- package/src/assets/svg/common/trailers/ic_trailer_flatbed.svg +1 -0
- package/src/assets/svg/common/trailers/ic_trailer_low-boy.svg +1 -0
- package/src/assets/svg/common/trailers/ic_trailer_reefer.svg +1 -0
- package/src/assets/svg/common/trailers/ic_trailer_side-kit.svg +1 -0
- package/src/assets/svg/common/trailers/ic_trailer_step-deck.svg +1 -0
- package/src/assets/svg/common/trailers/ic_trailer_tanker.svg +6 -0
- package/src/assets/svg/common/trailers/ic_trailer_tanker_pneumatic.svg +6 -0
- package/src/assets/svg/common/trucks/ic_truck_box-truck.svg +1 -0
- package/src/assets/svg/common/trucks/ic_truck_bus.svg +7 -0
- package/src/assets/svg/common/trucks/ic_truck_car-hauler.svg +1 -0
- package/src/assets/svg/common/trucks/ic_truck_cargo-van.svg +1 -0
- package/src/assets/svg/common/trucks/ic_truck_semi-truck.svg +1 -0
- package/src/assets/svg/common/trucks/ic_truck_semi-wSleeper.svg +9 -0
- package/src/assets/svg/common/trucks/ic_truck_spotter.svg +1 -0
- package/src/assets/svg/common/trucks/ic_truck_tow-truck.svg +1 -0
- package/src/assets/svg/input/ic_dollar.svg +6 -0
- package/src/assets/svg/input/ic_pm_decrement.svg +4 -0
- package/src/assets/svg/input/ic_pm_increment.svg +4 -0
- package/esm2022/lib/animation/in-out.animation.mjs +0 -73
- /package/lib/{animation → animations}/in-out.animation.d.ts +0 -0
- /package/src/assets/svg/{common → input}/ic_search.svg +0 -0
|
@@ -1,5 +1,10 @@
|
|
|
1
1
|
import { Injectable } from "@angular/core";
|
|
2
|
-
import { BehaviorSubject } from "rxjs";
|
|
2
|
+
import { BehaviorSubject, combineLatest, Subject } from "rxjs";
|
|
3
|
+
// helpers
|
|
4
|
+
import { MethodsCalculationsHelper } from "../../../utils/helpers/methods-calculations.helper";
|
|
5
|
+
// enums
|
|
6
|
+
import { InputCommandsAction } from "../enums/input-commands-action.enum";
|
|
7
|
+
import { InputCommandsType } from "../enums/input-commands-type.enum";
|
|
3
8
|
import * as i0 from "@angular/core";
|
|
4
9
|
export class InputStateService {
|
|
5
10
|
constructor() {
|
|
@@ -7,15 +12,28 @@ export class InputStateService {
|
|
|
7
12
|
this.isFocusInput$ = this.isFocusInputSubject.asObservable();
|
|
8
13
|
this.isTouchedInputSubject = new BehaviorSubject(false);
|
|
9
14
|
this.isTouchedInput$ = this.isTouchedInputSubject.asObservable();
|
|
15
|
+
this.isVisibleCommandsSubject = new BehaviorSubject(false);
|
|
16
|
+
this.isVisibleCommands$ = this.isVisibleCommandsSubject.asObservable();
|
|
17
|
+
this.commandEventSubject = new Subject();
|
|
18
|
+
this.commandEvent$ = this.commandEventSubject.asObservable();
|
|
19
|
+
this.combinedVariables$ = combineLatest([
|
|
20
|
+
this.isFocusInput$,
|
|
21
|
+
this.isTouchedInput$,
|
|
22
|
+
this.isVisibleCommands$,
|
|
23
|
+
]);
|
|
10
24
|
}
|
|
11
|
-
|
|
25
|
+
setIsFocusInput(value) {
|
|
12
26
|
this.isFocusInputSubject.next(value);
|
|
13
27
|
}
|
|
14
|
-
|
|
28
|
+
setIsTouchedInput(value) {
|
|
15
29
|
this.isTouchedInputSubject.next(value);
|
|
16
30
|
}
|
|
17
|
-
|
|
31
|
+
setIsVisibleCommands(value) {
|
|
32
|
+
this.isVisibleCommandsSubject.next(value);
|
|
33
|
+
}
|
|
34
|
+
setInputElementRef(input, cdRef) {
|
|
18
35
|
this.input = input;
|
|
36
|
+
this.cdRef = cdRef;
|
|
19
37
|
}
|
|
20
38
|
setSuperControl(superControl) {
|
|
21
39
|
this.superControl = superControl;
|
|
@@ -23,6 +41,9 @@ export class InputStateService {
|
|
|
23
41
|
setInputConfig(config) {
|
|
24
42
|
this.inputConfig = config;
|
|
25
43
|
}
|
|
44
|
+
setCommandEvent(value) {
|
|
45
|
+
this.commandEventSubject.next(value);
|
|
46
|
+
}
|
|
26
47
|
clearInput(event) {
|
|
27
48
|
event.preventDefault();
|
|
28
49
|
event.stopPropagation();
|
|
@@ -45,8 +66,8 @@ export class InputStateService {
|
|
|
45
66
|
// this.numberOfPoints = 0;
|
|
46
67
|
// this.oneSpaceOnlyCounter = 0;
|
|
47
68
|
// this.inputConfig.dropdownImageInput = null;
|
|
48
|
-
this.
|
|
49
|
-
this.
|
|
69
|
+
this.setIsTouchedInput(true);
|
|
70
|
+
this.setIsFocusInput(false);
|
|
50
71
|
// this.isTouchedInput = true;
|
|
51
72
|
// this.isFocusInput = false;
|
|
52
73
|
if (["datepicker", "timepicker", "datepickerBankCard"].includes(this.inputConfig.name)) {
|
|
@@ -80,6 +101,203 @@ export class InputStateService {
|
|
|
80
101
|
}
|
|
81
102
|
}
|
|
82
103
|
}
|
|
104
|
+
onCommands(event, type, action) {
|
|
105
|
+
event.stopPropagation();
|
|
106
|
+
event.preventDefault();
|
|
107
|
+
switch (type) {
|
|
108
|
+
case InputCommandsType.PM_INCREMENT_DECREMENT:
|
|
109
|
+
this.handlePmIncrementDecrement(action);
|
|
110
|
+
break;
|
|
111
|
+
case InputCommandsType.CONFIRM_CANCEL:
|
|
112
|
+
this.handleConfirmCancel(action);
|
|
113
|
+
break;
|
|
114
|
+
case InputCommandsType.MONTHS:
|
|
115
|
+
this.handleMonths(action);
|
|
116
|
+
break;
|
|
117
|
+
default:
|
|
118
|
+
break;
|
|
119
|
+
}
|
|
120
|
+
}
|
|
121
|
+
handlePmIncrementDecrement(action) {
|
|
122
|
+
const value = MethodsCalculationsHelper.convertThousanSepInNumber(this.superControl.control?.value);
|
|
123
|
+
switch (action) {
|
|
124
|
+
case InputCommandsAction.DECREMENT:
|
|
125
|
+
this.decrementPmValue(value);
|
|
126
|
+
break;
|
|
127
|
+
case InputCommandsAction.INCREMENT:
|
|
128
|
+
this.incrementPmValue(value);
|
|
129
|
+
break;
|
|
130
|
+
case InputCommandsAction.RESET:
|
|
131
|
+
this.resetPmValue();
|
|
132
|
+
break;
|
|
133
|
+
default:
|
|
134
|
+
break;
|
|
135
|
+
}
|
|
136
|
+
this.setInputCursorAtTheEnd(this.input.nativeElement);
|
|
137
|
+
}
|
|
138
|
+
decrementPmValue(value) {
|
|
139
|
+
if (value >= 10000 && value < 20000) {
|
|
140
|
+
this.superControl.control?.patchValue(MethodsCalculationsHelper.convertNumberInThousandSep(value - 1000));
|
|
141
|
+
}
|
|
142
|
+
else if (value >= 20001 && value < 50000) {
|
|
143
|
+
this.superControl.control?.patchValue(MethodsCalculationsHelper.convertNumberInThousandSep(value - 3000));
|
|
144
|
+
}
|
|
145
|
+
else if (value >= 50001 && value < 100000) {
|
|
146
|
+
this.superControl.control?.patchValue(MethodsCalculationsHelper.convertNumberInThousandSep(value - 5000));
|
|
147
|
+
}
|
|
148
|
+
else if (value >= 10000) {
|
|
149
|
+
this.superControl.control?.patchValue(MethodsCalculationsHelper.convertNumberInThousandSep(value - 10000));
|
|
150
|
+
}
|
|
151
|
+
else if (value >= 1000) {
|
|
152
|
+
this.superControl.control?.patchValue(MethodsCalculationsHelper.convertNumberInThousandSep(value - 500));
|
|
153
|
+
}
|
|
154
|
+
}
|
|
155
|
+
incrementPmValue(value) {
|
|
156
|
+
if (value > 10000 && value < 20000) {
|
|
157
|
+
this.superControl.control?.patchValue(MethodsCalculationsHelper.convertNumberInThousandSep(value + 1000));
|
|
158
|
+
}
|
|
159
|
+
else if (value >= 20001 && value < 50000) {
|
|
160
|
+
this.superControl.control?.patchValue(MethodsCalculationsHelper.convertNumberInThousandSep(value + 3000));
|
|
161
|
+
}
|
|
162
|
+
else if (value >= 50001 && value < 100000) {
|
|
163
|
+
this.superControl.control?.patchValue(MethodsCalculationsHelper.convertNumberInThousandSep(value + 5000));
|
|
164
|
+
}
|
|
165
|
+
else if (value >= 10000) {
|
|
166
|
+
this.superControl.control?.patchValue(MethodsCalculationsHelper.convertNumberInThousandSep(value + 10000));
|
|
167
|
+
}
|
|
168
|
+
else {
|
|
169
|
+
this.superControl.control?.patchValue(MethodsCalculationsHelper.convertNumberInThousandSep(value + 500));
|
|
170
|
+
}
|
|
171
|
+
}
|
|
172
|
+
resetPmValue() {
|
|
173
|
+
if (this.inputConfig?.defaultValue) {
|
|
174
|
+
this.superControl.control?.patchValue(this.inputConfig?.defaultValue);
|
|
175
|
+
}
|
|
176
|
+
}
|
|
177
|
+
handleConfirmCancel(action) {
|
|
178
|
+
switch (action) {
|
|
179
|
+
case InputCommandsAction.CONFIRM:
|
|
180
|
+
this.confirmCommand();
|
|
181
|
+
break;
|
|
182
|
+
case InputCommandsAction.CANCEL:
|
|
183
|
+
this.cancelCommand();
|
|
184
|
+
break;
|
|
185
|
+
default:
|
|
186
|
+
break;
|
|
187
|
+
}
|
|
188
|
+
this.superControl.control?.setErrors(null);
|
|
189
|
+
this.inputConfig.dropdownLabelNew = false;
|
|
190
|
+
this.inputConfig.commands.active = false;
|
|
191
|
+
this.inputConfig.blackInput = false;
|
|
192
|
+
// TODO: this.editInputMode = false;
|
|
193
|
+
this.setIsVisibleCommands(false);
|
|
194
|
+
this.setIsFocusInput(false);
|
|
195
|
+
}
|
|
196
|
+
confirmCommand() {
|
|
197
|
+
this.setCommandEvent({
|
|
198
|
+
data: this.superControl.control?.value,
|
|
199
|
+
action: InputCommandsAction.CONFIRM,
|
|
200
|
+
mode: !this.inputConfig.dropdownLabelNew &&
|
|
201
|
+
this.inputConfig.name !== "Input Dropdown Bank Name"
|
|
202
|
+
? "edit"
|
|
203
|
+
: "new",
|
|
204
|
+
});
|
|
205
|
+
}
|
|
206
|
+
cancelCommand() {
|
|
207
|
+
this.setCommandEvent({ action: InputCommandsAction.CANCEL });
|
|
208
|
+
}
|
|
209
|
+
handleMonths(action) {
|
|
210
|
+
clearTimeout(this.inputCommandsTimeout);
|
|
211
|
+
switch (action) {
|
|
212
|
+
case InputCommandsAction.MINUS:
|
|
213
|
+
this.decrementMonth();
|
|
214
|
+
break;
|
|
215
|
+
case InputCommandsAction.PLUS:
|
|
216
|
+
this.incrementMonth();
|
|
217
|
+
break;
|
|
218
|
+
default:
|
|
219
|
+
break;
|
|
220
|
+
}
|
|
221
|
+
if (parseInt(this.superControl.control?.value) < 1 ||
|
|
222
|
+
parseInt(this.superControl.control?.value) > 12) {
|
|
223
|
+
this.superControl.control?.setErrors({ invalid: true });
|
|
224
|
+
}
|
|
225
|
+
else {
|
|
226
|
+
this.superControl.control?.setErrors(null);
|
|
227
|
+
}
|
|
228
|
+
this.setInputCursorAtTheEnd(this.input.nativeElement);
|
|
229
|
+
}
|
|
230
|
+
decrementMonth() {
|
|
231
|
+
if (parseInt(this.superControl.control?.value) === 1 ||
|
|
232
|
+
!this.superControl.control?.value) {
|
|
233
|
+
this.blurOnCommands();
|
|
234
|
+
return;
|
|
235
|
+
}
|
|
236
|
+
this.superControl.control?.patchValue((this.superControl.control?.value
|
|
237
|
+
? parseInt(this.superControl.control?.value)
|
|
238
|
+
: 0) - 1);
|
|
239
|
+
}
|
|
240
|
+
incrementMonth() {
|
|
241
|
+
if (parseInt(this.superControl.control?.value) === 12) {
|
|
242
|
+
this.blurOnCommands();
|
|
243
|
+
return;
|
|
244
|
+
}
|
|
245
|
+
this.superControl.control?.patchValue((this.superControl.control?.value
|
|
246
|
+
? parseInt(this.superControl.control?.value)
|
|
247
|
+
: 0) + 1);
|
|
248
|
+
}
|
|
249
|
+
onFocus(event) {
|
|
250
|
+
// Commands
|
|
251
|
+
if (this.inputConfig.commands && !this.inputConfig.isDisabled) {
|
|
252
|
+
if (this.inputConfig.commands.type === InputCommandsType.MONTHS) {
|
|
253
|
+
if (!this.inputConfig.blueInput)
|
|
254
|
+
this.inputConfig.blackInput = true;
|
|
255
|
+
this.inputConfig.commands.active = true;
|
|
256
|
+
this.setIsVisibleCommands(true);
|
|
257
|
+
}
|
|
258
|
+
if (this.inputConfig.commands.type ===
|
|
259
|
+
InputCommandsType.PM_INCREMENT_DECREMENT) {
|
|
260
|
+
this.inputConfig.blackInput = false;
|
|
261
|
+
this.inputConfig.commands.active = true;
|
|
262
|
+
this.setIsVisibleCommands(true);
|
|
263
|
+
}
|
|
264
|
+
}
|
|
265
|
+
this.setIsFocusInput(true);
|
|
266
|
+
}
|
|
267
|
+
onBlur(event) {
|
|
268
|
+
let selection = window.getSelection();
|
|
269
|
+
selection?.removeAllRanges();
|
|
270
|
+
// Input Commands
|
|
271
|
+
if (this.inputConfig.commands) {
|
|
272
|
+
this.blurOnCommands();
|
|
273
|
+
}
|
|
274
|
+
// Password
|
|
275
|
+
if (this.inputConfig.type === "password") {
|
|
276
|
+
// this.blurOnPassword();
|
|
277
|
+
}
|
|
278
|
+
// Normal focus out
|
|
279
|
+
else {
|
|
280
|
+
this.setIsFocusInput(false);
|
|
281
|
+
}
|
|
282
|
+
this.setIsTouchedInput(true);
|
|
283
|
+
}
|
|
284
|
+
blurOnCommands() {
|
|
285
|
+
this.inputCommandsTimeout = setTimeout(() => {
|
|
286
|
+
this.inputConfig.commands.active = false;
|
|
287
|
+
this.setIsVisibleCommands(false);
|
|
288
|
+
this.inputConfig.blackInput = false;
|
|
289
|
+
this.cdRef.detectChanges();
|
|
290
|
+
}, 200);
|
|
291
|
+
}
|
|
292
|
+
setInputCursorAtTheEnd(input, time = 120) {
|
|
293
|
+
const selectionEnd = input.selectionEnd;
|
|
294
|
+
if (input.setSelectionRange) {
|
|
295
|
+
input.setSelectionRange(selectionEnd, selectionEnd);
|
|
296
|
+
}
|
|
297
|
+
setTimeout(() => {
|
|
298
|
+
input.focus();
|
|
299
|
+
}, time);
|
|
300
|
+
}
|
|
83
301
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: InputStateService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
|
|
84
302
|
static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: InputStateService, providedIn: "root" }); }
|
|
85
303
|
}
|
|
@@ -89,4 +307,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
89
307
|
providedIn: "root",
|
|
90
308
|
}]
|
|
91
309
|
}], ctorParameters: function () { return []; } });
|
|
92
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ca-input-state.service.js","sourceRoot":"","sources":["../../../../../../../projects/ca-components/src/lib/components/ca-input/services/ca-input-state.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { ElementRef, Injectable } from \"@angular/core\";\nimport { BehaviorSubject, Observable } from \"rxjs\";\nimport { ICaInput } from '@shared/components/ca-input/config/ca-input.config';\nimport { NgControl } from \"@angular/forms\";\n\n@Injectable({\n  providedIn: \"root\",\n})\nexport class InputStateService {\n  private isFocusInputSubject = new BehaviorSubject<boolean>(false);\n  public isFocusInput$: Observable<boolean> =\n    this.isFocusInputSubject.asObservable();\n\n  private isTouchedInputSubject = new BehaviorSubject<boolean>(false);\n  public isTouchedInput$: Observable<boolean> =\n    this.isTouchedInputSubject.asObservable();\n\n  private inputConfig!: ICaInput;\n\n  private input!: ElementRef;\n  private superControl!: NgControl;\n\n  constructor() {}\n\n  public setisFocusInput(value: boolean): void {\n    this.isFocusInputSubject.next(value);\n  }\n\n  public setisTouchedInput(value: boolean): void {\n    this.isTouchedInputSubject.next(value);\n  }\n\n  public setInputElementRef(input: ElementRef): void {\n    this.input = input;\n  }\n\n  public setSuperControl(superControl: NgControl): void {\n    this.superControl = superControl;\n  }\n\n  public setInputConfig(config: ICaInput): void {\n    this.inputConfig = config;\n  }\n\n  public clearInput(event: Event): void {\n    event.preventDefault();\n    event.stopPropagation();\n    // Clear whole input\n    if (this.inputConfig.removeInput) {\n      // this.clearInputEvent.emit(true);\n      return;\n    }\n    // Incorrect Input\n    if (this.inputConfig.incorrectInput) {\n      //this.incorrectValue = !this.incorrectValue;\n      // this.incorrectInput.emit(this.incorrectValue);\n    }\n    // Native clear\n    else {\n      this.input.nativeElement.value = null;\n      this.superControl.control?.setValue(null);\n      // this.numberOfConsecutivelySpaces = 0;\n      // this.numberOfConsecutivelyPoints = 0;\n      // this.numberOfPoints = 0;\n      // this.oneSpaceOnlyCounter = 0;\n      // this.inputConfig.dropdownImageInput = null;\n      this.setisTouchedInput(true);\n      this.setisFocusInput(false);\n      // this.isTouchedInput = true;\n      // this.isFocusInput = false;\n      if (\n        [\"datepicker\", \"timepicker\", \"datepickerBankCard\"].includes(\n          this.inputConfig.name\n        )\n      ) {\n        // this.resetDateTimeInputs();\n      }\n\n      // this.clearInputEvent.emit(true);\n    }\n  }\n\n  public transformText(event: Event): void {\n    const value = (event.target as HTMLInputElement).value;\n\n    if (value) {\n      this.input.nativeElement.value = value;\n    }\n\n    switch (this.inputConfig.textTransform) {\n      case \"capitalize\": {\n        this.input.nativeElement.value =\n          this.input.nativeElement.value.charAt(0)?.toUpperCase() +\n          this.input.nativeElement.value.substring(1).toLowerCase();\n        this.superControl.control?.patchValue(this.input.nativeElement.value);\n        break;\n      }\n      case \"uppercase\": {\n        this.input.nativeElement.value =\n          this.input.nativeElement.value.toLocaleUpperCase(\"en-US\");\n        this.superControl.control?.patchValue(this.input.nativeElement.value);\n        break;\n      }\n      default: {\n        this.superControl.control?.patchValue(this.input.nativeElement.value);\n        break;\n      }\n    }\n  }\n}\n"]}
|
|
310
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ca-input-state.service.js","sourceRoot":"","sources":["../../../../../../../projects/ca-components/src/lib/components/ca-input/services/ca-input-state.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectorRef, ElementRef, Injectable } from \"@angular/core\";\nimport { BehaviorSubject, combineLatest, Observable, Subject } from \"rxjs\";\nimport { NgControl } from \"@angular/forms\";\n\n// models\nimport { ICaInput } from \"../config/ca-input.config\";\nimport { CommandsEvent } from \"../models/commands-event.model\";\n\n// helpers\nimport { MethodsCalculationsHelper } from \"../../../utils/helpers/methods-calculations.helper\";\n\n// enums\nimport { InputCommandsAction } from \"../enums/input-commands-action.enum\";\nimport { InputCommandsType } from \"../enums/input-commands-type.enum\";\n\n\n@Injectable({\n  providedIn: \"root\",\n})\nexport class InputStateService {\n  private isFocusInputSubject = new BehaviorSubject<boolean>(false);\n  public isFocusInput$: Observable<boolean> =\n    this.isFocusInputSubject.asObservable();\n\n  private isTouchedInputSubject = new BehaviorSubject<boolean>(false);\n  public isTouchedInput$: Observable<boolean> =\n    this.isTouchedInputSubject.asObservable();\n\n  private isVisibleCommandsSubject = new BehaviorSubject<boolean>(false);\n  public isVisibleCommands$: Observable<boolean> =\n    this.isVisibleCommandsSubject.asObservable();\n\n  private commandEventSubject = new Subject<CommandsEvent>();\n  public commandEvent$: Observable<CommandsEvent> =\n    this.commandEventSubject.asObservable();\n\n  public combinedVariables$ = combineLatest([\n    this.isFocusInput$,\n    this.isTouchedInput$,\n    this.isVisibleCommands$,\n  ]);\n\n  private cdRef!: ChangeDetectorRef;\n\n  private inputConfig!: ICaInput;\n\n  private input!: ElementRef;\n  private superControl!: NgControl;\n\n  inputCommandsTimeout!: NodeJS.Timeout | number;\n\n  constructor() {}\n\n  public setIsFocusInput(value: boolean): void {\n    this.isFocusInputSubject.next(value);\n  }\n\n  public setIsTouchedInput(value: boolean): void {\n    this.isTouchedInputSubject.next(value);\n  }\n\n  public setIsVisibleCommands(value: boolean): void {\n    this.isVisibleCommandsSubject.next(value);\n  }\n\n  public setInputElementRef(input: ElementRef, cdRef: ChangeDetectorRef): void {\n    this.input = input;\n    this.cdRef = cdRef;\n  }\n\n  public setSuperControl(superControl: NgControl): void {\n    this.superControl = superControl;\n  }\n\n  public setInputConfig(config: ICaInput): void {\n    this.inputConfig = config;\n  }\n\n  public setCommandEvent(value: CommandsEvent): void {\n    this.commandEventSubject.next(value);\n  }\n\n  public clearInput(event: Event): void {\n    event.preventDefault();\n    event.stopPropagation();\n    // Clear whole input\n    if (this.inputConfig.removeInput) {\n      // this.clearInputEvent.emit(true);\n      return;\n    }\n    // Incorrect Input\n    if (this.inputConfig.incorrectInput) {\n      //this.incorrectValue = !this.incorrectValue;\n      // this.incorrectInput.emit(this.incorrectValue);\n    }\n    // Native clear\n    else {\n      this.input.nativeElement.value = null;\n      this.superControl.control?.setValue(null);\n      // this.numberOfConsecutivelySpaces = 0;\n      // this.numberOfConsecutivelyPoints = 0;\n      // this.numberOfPoints = 0;\n      // this.oneSpaceOnlyCounter = 0;\n      // this.inputConfig.dropdownImageInput = null;\n      this.setIsTouchedInput(true);\n      this.setIsFocusInput(false);\n      // this.isTouchedInput = true;\n      // this.isFocusInput = false;\n      if (\n        [\"datepicker\", \"timepicker\", \"datepickerBankCard\"].includes(\n          this.inputConfig.name\n        )\n      ) {\n        // this.resetDateTimeInputs();\n      }\n\n      // this.clearInputEvent.emit(true);\n    }\n  }\n\n  public transformText(event: Event): void {\n    const value = (event.target as HTMLInputElement).value;\n\n    if (value) {\n      this.input.nativeElement.value = value;\n    }\n\n    switch (this.inputConfig.textTransform) {\n      case \"capitalize\": {\n        this.input.nativeElement.value =\n          this.input.nativeElement.value.charAt(0)?.toUpperCase() +\n          this.input.nativeElement.value.substring(1).toLowerCase();\n        this.superControl.control?.patchValue(this.input.nativeElement.value);\n        break;\n      }\n      case \"uppercase\": {\n        this.input.nativeElement.value =\n          this.input.nativeElement.value.toLocaleUpperCase(\"en-US\");\n        this.superControl.control?.patchValue(this.input.nativeElement.value);\n        break;\n      }\n      default: {\n        this.superControl.control?.patchValue(this.input.nativeElement.value);\n        break;\n      }\n    }\n  }\n\n  public onCommands(event: Event, type: string, action: string): void {\n    event.stopPropagation();\n    event.preventDefault();\n\n    switch (type) {\n      case InputCommandsType.PM_INCREMENT_DECREMENT:\n        this.handlePmIncrementDecrement(action);\n        break;\n      case InputCommandsType.CONFIRM_CANCEL:\n        this.handleConfirmCancel(action);\n        break;\n      case InputCommandsType.MONTHS:\n        this.handleMonths(action);\n        break;\n      default:\n        break;\n    }\n  }\n\n  private handlePmIncrementDecrement(action: string): void {\n    const value = MethodsCalculationsHelper.convertThousanSepInNumber(\n      this.superControl.control?.value\n    );\n\n    switch (action) {\n      case InputCommandsAction.DECREMENT:\n        this.decrementPmValue(value);\n        break;\n      case InputCommandsAction.INCREMENT:\n        this.incrementPmValue(value);\n        break;\n      case InputCommandsAction.RESET:\n        this.resetPmValue();\n        break;\n      default:\n        break;\n    }\n\n    this.setInputCursorAtTheEnd(this.input.nativeElement);\n  }\n\n  private decrementPmValue(value: number): void {\n    if (value >= 10000 && value < 20000) {\n      this.superControl.control?.patchValue(\n        MethodsCalculationsHelper.convertNumberInThousandSep(value - 1000)\n      );\n    } else if (value >= 20001 && value < 50000) {\n      this.superControl.control?.patchValue(\n        MethodsCalculationsHelper.convertNumberInThousandSep(value - 3000)\n      );\n    } else if (value >= 50001 && value < 100000) {\n      this.superControl.control?.patchValue(\n        MethodsCalculationsHelper.convertNumberInThousandSep(value - 5000)\n      );\n    } else if (value >= 10000) {\n      this.superControl.control?.patchValue(\n        MethodsCalculationsHelper.convertNumberInThousandSep(value - 10000)\n      );\n    } else if (value >= 1000) {\n      this.superControl.control?.patchValue(\n        MethodsCalculationsHelper.convertNumberInThousandSep(value - 500)\n      );\n    }\n  }\n\n  private incrementPmValue(value: number): void {\n    if (value > 10000 && value < 20000) {\n      this.superControl.control?.patchValue(\n        MethodsCalculationsHelper.convertNumberInThousandSep(value + 1000)\n      );\n    } else if (value >= 20001 && value < 50000) {\n      this.superControl.control?.patchValue(\n        MethodsCalculationsHelper.convertNumberInThousandSep(value + 3000)\n      );\n    } else if (value >= 50001 && value < 100000) {\n      this.superControl.control?.patchValue(\n        MethodsCalculationsHelper.convertNumberInThousandSep(value + 5000)\n      );\n    } else if (value >= 10000) {\n      this.superControl.control?.patchValue(\n        MethodsCalculationsHelper.convertNumberInThousandSep(value + 10000)\n      );\n    } else {\n      this.superControl.control?.patchValue(\n        MethodsCalculationsHelper.convertNumberInThousandSep(value + 500)\n      );\n    }\n  }\n\n  private resetPmValue(): void {\n    if (this.inputConfig?.defaultValue) {\n      this.superControl.control?.patchValue(this.inputConfig?.defaultValue);\n    }\n  }\n\n  private handleConfirmCancel(action: string): void {\n    switch (action) {\n      case InputCommandsAction.CONFIRM:\n        this.confirmCommand();\n        break;\n      case InputCommandsAction.CANCEL:\n        this.cancelCommand();\n        break;\n      default:\n        break;\n    }\n\n    this.superControl.control?.setErrors(null);\n    this.inputConfig.dropdownLabelNew = false;\n    this.inputConfig.commands!.active = false;\n    this.inputConfig.blackInput = false;\n    // TODO: this.editInputMode = false;\n    this.setIsVisibleCommands(false);\n    this.setIsFocusInput(false);\n  }\n\n  private confirmCommand(): void {\n    this.setCommandEvent({\n      data: this.superControl.control?.value,\n      action: InputCommandsAction.CONFIRM,\n      mode:\n        !this.inputConfig.dropdownLabelNew &&\n        this.inputConfig.name !== \"Input Dropdown Bank Name\"\n          ? \"edit\"\n          : \"new\",\n    });\n  }\n\n  private cancelCommand(): void {\n    this.setCommandEvent({ action: InputCommandsAction.CANCEL });\n  }\n\n  private handleMonths(action: string): void {\n    clearTimeout(this.inputCommandsTimeout);\n\n    switch (action) {\n      case InputCommandsAction.MINUS:\n        this.decrementMonth();\n        break;\n      case InputCommandsAction.PLUS:\n        this.incrementMonth();\n        break;\n      default:\n        break;\n    }\n\n    if (\n      parseInt(this.superControl.control?.value) < 1 ||\n      parseInt(this.superControl.control?.value) > 12\n    ) {\n      this.superControl.control?.setErrors({ invalid: true });\n    } else {\n      this.superControl.control?.setErrors(null);\n    }\n\n    this.setInputCursorAtTheEnd(this.input.nativeElement);\n  }\n\n  private decrementMonth(): void {\n    if (\n      parseInt(this.superControl.control?.value) === 1 ||\n      !this.superControl.control?.value\n    ) {\n      this.blurOnCommands();\n      return;\n    }\n\n    this.superControl.control?.patchValue(\n      (this.superControl.control?.value\n        ? parseInt(this.superControl.control?.value)\n        : 0) - 1\n    );\n  }\n\n  private incrementMonth(): void {\n    if (parseInt(this.superControl.control?.value) === 12) {\n      this.blurOnCommands();\n      return;\n    }\n\n    this.superControl.control?.patchValue(\n      (this.superControl.control?.value\n        ? parseInt(this.superControl.control?.value)\n        : 0) + 1\n    );\n  }\n\n  public onFocus(event?: FocusEvent) {\n    // Commands\n    if (this.inputConfig.commands && !this.inputConfig.isDisabled) {\n      if (this.inputConfig.commands.type === InputCommandsType.MONTHS) {\n        if (!this.inputConfig.blueInput) this.inputConfig.blackInput = true;\n        this.inputConfig.commands.active = true;\n        this.setIsVisibleCommands(true);\n      }\n\n      if (\n        this.inputConfig.commands.type ===\n        InputCommandsType.PM_INCREMENT_DECREMENT\n      ) {\n        this.inputConfig.blackInput = false;\n        this.inputConfig.commands.active = true;\n        this.setIsVisibleCommands(true);\n      }\n    }\n\n    this.setIsFocusInput(true);\n  }\n\n  public onBlur(event?: FocusEvent): void {\n    let selection = window.getSelection();\n    selection?.removeAllRanges();\n\n    // Input Commands\n    if (this.inputConfig.commands) {\n      this.blurOnCommands();\n    }\n\n    // Password\n    if (this.inputConfig.type === \"password\") {\n      // this.blurOnPassword();\n    }\n    // Normal focus out\n    else {\n      this.setIsFocusInput(false);\n    }\n\n    this.setIsTouchedInput(true);\n  }\n\n  private blurOnCommands() {\n    this.inputCommandsTimeout = setTimeout(() => {\n      this.inputConfig.commands!.active = false;\n      this.setIsVisibleCommands(false);\n      this.inputConfig.blackInput = false;\n      this.cdRef.detectChanges();\n    }, 200);\n  }\n\n  public setInputCursorAtTheEnd(input: any, time: number = 120): void {\n    const selectionEnd = input.selectionEnd;\n    if (input.setSelectionRange) {\n      input.setSelectionRange(selectionEnd, selectionEnd);\n    }\n    setTimeout(() => {\n      input.focus();\n    }, time);\n  }\n}\n"]}
|
|
@@ -1,9 +1,11 @@
|
|
|
1
1
|
export class InputSvgRoutes {
|
|
2
2
|
static { this.removeInputSvg = "svg/input/ic_remove_input.svg"; }
|
|
3
3
|
static { this.xClearSvg = "svg/input/ic_x.svg"; }
|
|
4
|
-
static { this.confirmSvg = "
|
|
4
|
+
static { this.confirmSvg = "svg/input/ic_confirm.svg"; }
|
|
5
5
|
static { this.dangerSvg = "svg/input/ic_danger.svg"; }
|
|
6
6
|
static { this.eyeVisibleSvg = "svg/input/ic_eye-visible.svg"; }
|
|
7
7
|
static { this.eyeHiddenSvg = "svg/input/ic_eye-hidden.svg"; }
|
|
8
|
+
static { this.decrementSvg = 'svg/input/ic_pm_decrement.svg'; }
|
|
9
|
+
static { this.incrementSvg = 'svg/input/ic_pm_increment.svg'; }
|
|
8
10
|
}
|
|
9
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
11
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5wdXQtc3ZnLXJvdXRlcy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2NhLWNvbXBvbmVudHMvc3JjL2xpYi9jb21wb25lbnRzL2NhLWlucHV0L3V0aWxzL2lucHV0LXN2Zy1yb3V0ZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsTUFBTSxPQUFPLGNBQWM7YUFDbEIsbUJBQWMsR0FBVywrQkFBK0IsQ0FBQzthQUN6RCxjQUFTLEdBQVcsb0JBQW9CLENBQUM7YUFDekMsZUFBVSxHQUFXLDBCQUEwQixDQUFDO2FBQ2hELGNBQVMsR0FBVyx5QkFBeUIsQ0FBQzthQUM5QyxrQkFBYSxHQUFXLDhCQUE4QixDQUFDO2FBQ3ZELGlCQUFZLEdBQVcsNkJBQTZCLENBQUM7YUFDckQsaUJBQVksR0FBVywrQkFBK0IsQ0FBQzthQUN2RCxpQkFBWSxHQUFXLCtCQUErQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGNsYXNzIElucHV0U3ZnUm91dGVzIHtcbiAgc3RhdGljIHJlbW92ZUlucHV0U3ZnOiBzdHJpbmcgPSBcInN2Zy9pbnB1dC9pY19yZW1vdmVfaW5wdXQuc3ZnXCI7XG4gIHN0YXRpYyB4Q2xlYXJTdmc6IHN0cmluZyA9IFwic3ZnL2lucHV0L2ljX3guc3ZnXCI7XG4gIHN0YXRpYyBjb25maXJtU3ZnOiBzdHJpbmcgPSBcInN2Zy9pbnB1dC9pY19jb25maXJtLnN2Z1wiO1xuICBzdGF0aWMgZGFuZ2VyU3ZnOiBzdHJpbmcgPSBcInN2Zy9pbnB1dC9pY19kYW5nZXIuc3ZnXCI7XG4gIHN0YXRpYyBleWVWaXNpYmxlU3ZnOiBzdHJpbmcgPSBcInN2Zy9pbnB1dC9pY19leWUtdmlzaWJsZS5zdmdcIjtcbiAgc3RhdGljIGV5ZUhpZGRlblN2Zzogc3RyaW5nID0gXCJzdmcvaW5wdXQvaWNfZXllLWhpZGRlbi5zdmdcIjtcbiAgc3RhdGljIGRlY3JlbWVudFN2Zzogc3RyaW5nID0gJ3N2Zy9pbnB1dC9pY19wbV9kZWNyZW1lbnQuc3ZnJztcbiAgc3RhdGljIGluY3JlbWVudFN2Zzogc3RyaW5nID0gJ3N2Zy9pbnB1dC9pY19wbV9pbmNyZW1lbnQuc3ZnJztcbn0iXX0=
|
|
@@ -5,12 +5,13 @@ import { GoogleMap, GoogleMapsModule, MapInfoWindow, } from '@angular/google-map
|
|
|
5
5
|
//icon
|
|
6
6
|
import { AngularSvgIconModule } from 'angular-svg-icon';
|
|
7
7
|
//Components
|
|
8
|
-
import { CaMapDropdownComponent } from '
|
|
8
|
+
import { CaMapDropdownComponent } from '../ca-map-dropdown/ca-map-dropdown.component';
|
|
9
9
|
//Enums
|
|
10
|
-
import { GoogleMapEnum } from '
|
|
10
|
+
import { GoogleMapEnum } from '../ca-map/enums/google-map.enum';
|
|
11
11
|
//HelperFuntion
|
|
12
|
-
import { MapHelper } from '
|
|
13
|
-
|
|
12
|
+
import { MapHelper } from '../ca-map/utils/helpers/map.helper';
|
|
13
|
+
//svg-routes
|
|
14
|
+
import { MapSvgRoutes } from '../ca-map/utils/map-svg-routes/map-svg-routes';
|
|
14
15
|
import * as i0 from "@angular/core";
|
|
15
16
|
import * as i1 from "@angular/google-maps";
|
|
16
17
|
import * as i2 from "@angular/common";
|
|
@@ -326,4 +327,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
326
327
|
type: ViewChildren,
|
|
327
328
|
args: [MapInfoWindow]
|
|
328
329
|
}] } });
|
|
329
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ca-map.component.js","sourceRoot":"","sources":["../../../../../../projects/ca-components/src/lib/components/ca-map/ca-map.component.ts","../../../../../../projects/ca-components/src/lib/components/ca-map/ca-map.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport {\n    ChangeDetectorRef,\n    Component,\n    EventEmitter,\n    Input,\n    Output,\n    QueryList,\n    SimpleChanges,\n    ViewChild,\n    ViewChildren,\n} from '@angular/core';\n\n//Modules\nimport {\n    GoogleMap,\n    GoogleMapsModule,\n    MapInfoWindow,\n    MapMarker,\n} from '@angular/google-maps';\n\n//icon\nimport { AngularSvgIconModule } from 'angular-svg-icon';\n\n//Components\nimport { CaMapDropdownComponent } from '@shared/components/ca-map-dropdown/ca-map-dropdown.component';\n\n//Enums\nimport { GoogleMapEnum } from '@shared/components/ca-map/enums/google-map.enum';\n//models\nimport {\n    IMapMarkers,\n    IRoutePath,\n} from '@shared/components/ca-map/models/map.model';\n//HelperFuntion\nimport { MapHelper } from '@shared/components/ca-map/utils/helpers/map.helper';\nimport { MapSvgRoutes } from '@shared/components/ca-map/utils/map-svg-routes/map-svg-routes';\n\n@Component({\n    selector: 'app-ca-map',\n    templateUrl: './ca-map.component.html',\n    styleUrls: ['./ca-map.component.scss'],\n    standalone: true,\n    imports: [\n        //Modules\n        GoogleMapsModule,\n        CommonModule,\n        AngularSvgIconModule,\n        //Components\n        CaMapDropdownComponent,\n    ],\n})\nexport class CaMapComponent {\n    constructor(public cd: ChangeDetectorRef) {}\n    @Input() data: any; //leave this as any for now\n    @Output() markerClick = new EventEmitter<google.maps.MapMouseEvent>();\n    @ViewChild(GoogleMap, { static: false }) maps!: GoogleMap;\n    @ViewChildren('marker') marker!: QueryList<MapMarker>;\n    @ViewChildren(MapInfoWindow) infoWindowsView!: QueryList<MapInfoWindow>;\n    @ViewChildren('markerRouting') markerRouting!: QueryList<MapMarker>;\n    @ViewChildren(MapInfoWindow)\n    public infoWindowsViewRouting!: QueryList<MapInfoWindow>;\n    public currentlyOpenWindow!: MapInfoWindow | null;\n    public currentlyOpenWindowIndex: number | null = null;\n    public currentlyOpenWindowRouting!: MapInfoWindow | null;\n    public currentlyOpenWindowIndexRouting: number | null = null;\n    public showLabel: boolean = true;\n    public previousIconUrl!: string;\n    public focusedIcon!: number;\n    public previousIconUrlRouting!: string;\n    public focusedIconRouting!: number;\n    private directionService = new google.maps.DirectionsService();\n    public directionsRenderers: google.maps.DirectionsRenderer[] = [];\n    public initialIcons: {\n        url: string;\n        labelOrigin: google.maps.Point | null;\n    }[] = [];\n    public initialMarkerIcons: {\n        url: string;\n        labelOrigin: google.maps.Point | null;\n    }[] = [];\n\n    ngOnInit() {\n        this.storeInitialIconForMarker();\n        this.storeInitialIconForRoutingMarker();\n        // Reset all icons to their initial state on page load\n        this.resetMarkersIcons();\n        this.resetRoutingMarkers();\n        //Display routes for routingMarkers\n        this.calculateAndDisplayRoute();\n    }\n\n    ngOnChanges(changes: SimpleChanges) {\n        if (changes['routingMarkers']) {\n            this.data.routingMarkers = changes['routingMarkers'].currentValue;\n        }\n    }\n\n    public storeInitialIconForMarker(): void {\n        this.data!.markers?.forEach(\n            (\n                marker: {\n                    icon: { url: string; labelOrigin: google.maps.Point };\n                },\n                index: number\n            ) => {\n                this.initialMarkerIcons[index] = {\n                    url: marker.icon!.url,\n                    labelOrigin: marker.icon!.labelOrigin || null,\n                };\n            }\n        );\n    }\n\n    public storeInitialIconForRoutingMarker(): void {\n        this.data.routingMarkers?.forEach(\n            (\n                marker: {\n                    icon: { url: string; labelOrigin?: google.maps.Point };\n                },\n                index: number\n            ) => {\n                this.initialIcons[index] = {\n                    url: marker.icon!.url,\n                    labelOrigin: marker.icon!.labelOrigin || null,\n                };\n            }\n        );\n    }\n\n    public onMarkerClick(\n        i: number,\n        event: google.maps.MapMouseEvent,\n        markeritem: IMapMarkers\n    ): void {\n        if (markeritem?.infoWindowContent) {\n            if (\n                this.currentlyOpenWindowIndex === i &&\n                this.currentlyOpenWindow\n            ) {\n                const infoWindow = this.infoWindowsView.toArray()[i];\n                // Close the currently open info window and reset the index\n                this.data.markers.map(\n                    (\n                        item: {\n                            icon: {\n                                url: string;\n                                labelOrigin: google.maps.Point | null;\n                            };\n                        },\n                        index: number\n                    ) => {\n                        if (index === i) {\n                            item.icon = {\n                                url: this.initialMarkerIcons[index]!.url,\n                                labelOrigin:\n                                    this.initialMarkerIcons[index]!.labelOrigin,\n                            };\n                        }\n                    }\n                );\n\n                infoWindow.close();\n                this.currentlyOpenWindowIndex = null;\n            } else {\n                const markerIndex = this.marker.toArray()[i];\n                const infoWindow = this.infoWindowsView.toArray()[i];\n                if (this.currentlyOpenWindow) {\n                    this.currentlyOpenWindow.close();\n                }\n                if (infoWindow) {\n                    this.data.markers.map(\n                        (\n                            item: {\n                                icon: {\n                                    url: string;\n                                    scaledSize?: google.maps.Size;\n                                    labelOrigin?: google.maps.Point | null;\n                                };\n                            },\n                            index: number\n                        ) => {\n                            if (index === i) {\n                                this.focusedIcon = i;\n                                this.showLabel = false;\n                                item.icon = {\n                                    url: this.initialMarkerIcons[index]!.url,\n                                    scaledSize: new google.maps.Size(70, 70),\n                                };\n                            } else {\n                                this.showLabel = true;\n                                item.icon = {\n                                    url: this.initialMarkerIcons[index]!.url,\n                                    labelOrigin:\n                                        this.initialMarkerIcons[index]!\n                                            .labelOrigin,\n                                };\n                            }\n                        }\n                    );\n\n                    infoWindow.open(markerIndex);\n                    this.currentlyOpenWindow = infoWindow;\n                    this.currentlyOpenWindowIndex = i;\n                    this.markerClick.emit(event);\n                }\n            }\n        } else {\n            return;\n        }\n    }\n\n    public setDirectionsOnMap(): void {\n        if (this.maps?.googleMap) {\n            this.directionsRenderers.forEach((renderer) =>\n                renderer.setMap(this.maps?.googleMap!)\n            );\n        }\n    }\n\n    public calculateAndDisplayRoute(): void {\n        if (this.data.routePaths) {\n            // Clear any previous directions renderers\n            this.directionsRenderers.forEach((renderer) =>\n                renderer.setMap(null)\n            );\n            this.directionsRenderers = [];\n\n            this.data.routePaths!.forEach(\n                (route: {\n                    path: IRoutePath[];\n                    strokeColor: string;\n                    strokeOpacity: number;\n                }) => {\n                    const request: google.maps.DirectionsRequest = {\n                        origin: route.path[0],\n                        destination: route.path[route.path.length - 1],\n                        waypoints: route.path\n                            .slice(1, route.path.length - 1)\n                            .map((position) => ({ location: position })),\n                        travelMode: google.maps.TravelMode.BICYCLING,\n                    };\n\n                    this.directionService.route(request, (result, status) => {\n                        if (\n                            status === google.maps.DirectionsStatus.OK &&\n                            result?.routes[0]\n                        ) {\n                            const directionsRenderer =\n                                new google.maps.DirectionsRenderer({\n                                    suppressInfoWindows: true,\n                                    suppressMarkers: true,\n                                    preserveViewport: true,\n                                    polylineOptions: {\n                                        strokeColor:\n                                            route.strokeColor ||\n                                            GoogleMapEnum.STROKE_COLOR,\n                                        strokeOpacity:\n                                            route.strokeOpacity ||\n                                            GoogleMapEnum.STROKE_OPACITY,\n                                    },\n                                });\n                            directionsRenderer.setDirections(result);\n                            this.directionsRenderers.push(directionsRenderer);\n                            this.setDirectionsOnMap();\n                        }\n                    });\n                }\n            );\n        } else {\n            return;\n        }\n    }\n\n    public onRoutingMarkerClick(\n        i: number,\n        event: google.maps.MapMouseEvent,\n        markeritem: IMapMarkers\n    ): void {\n        if (markeritem?.infoWindowContent) {\n            if (\n                this.currentlyOpenWindowIndexRouting === i &&\n                this.currentlyOpenWindowRouting\n            ) {\n                const infoWindow = this.infoWindowsViewRouting.toArray()[i];\n                // Close the currently open info window and reset the index\n                this.data.routingMarkers.map(\n                    (\n                        item: {\n                            icon: {\n                                url: string;\n                                labelOrigin?: google.maps.Point | null;\n                            };\n                        },\n                        index: number\n                    ) => {\n                        if (index === i) {\n                            item.icon = {\n                                url: this.initialIcons[index]!.url,\n                                labelOrigin:\n                                    this.initialIcons[index]!.labelOrigin,\n                            };\n                        }\n                    }\n                );\n\n                infoWindow.close();\n                this.currentlyOpenWindowIndexRouting = null;\n            } else {\n                const markerIndex = this.markerRouting.toArray()[i];\n                const infoWindow = this.infoWindowsViewRouting.toArray()[i];\n                if (this.currentlyOpenWindowRouting) {\n                    this.currentlyOpenWindowRouting.close();\n                }\n                if (infoWindow) {\n                    // Restore the previous icon for the previously focused routing marker\n                    if (\n                        this.focusedIconRouting !== undefined &&\n                        this.focusedIconRouting !== i\n                    ) {\n                        const previousFocusedItem =\n                            this.data.routingMarkers[this.focusedIconRouting];\n                        if (previousFocusedItem) {\n                            previousFocusedItem.icon = {\n                                url: this.initialIcons[this.focusedIconRouting]\n                                    .url,\n                                labelOrigin:\n                                    this.initialIcons[this.focusedIconRouting]\n                                        .labelOrigin,\n                            };\n                        }\n                    }\n\n                    // Update the current marker\n                    this.data.routingMarkers.map(\n                        (item: { icon: { url: string } }, index: number) => {\n                            if (index === i) {\n                                this.previousIconUrlRouting = item.icon\n                                    ? item.icon.url\n                                    : '';\n                                this.focusedIconRouting = i;\n                                this.showLabel = false;\n                                item.icon = {\n                                    url:\n                                        this.data.isUnitViewStops ||\n                                        this.data.isDriverMiles\n                                            ? item.icon.url\n                                            : MapSvgRoutes.markerSvgRoute,\n                                };\n                            } else {\n                                this.showLabel = true;\n                            }\n                        }\n                    );\n\n                    infoWindow.open(markerIndex);\n                    this.currentlyOpenWindowRouting = infoWindow;\n                    this.currentlyOpenWindowIndexRouting = i;\n                    this.markerClick.emit(event);\n                }\n            }\n        } else {\n            return;\n        }\n    }\n\n    ngAfterViewInit() {\n        this.maps.googleMap?.addListener('click', () => {\n            this.infoWindowsView.forEach((window: MapInfoWindow) => {\n                window.close();\n                this.currentlyOpenWindow = null;\n            });\n            this.infoWindowsViewRouting.forEach((window: MapInfoWindow) => {\n                window.close();\n                this.currentlyOpenWindowRouting = null;\n            });\n            this.data.markers?.map(\n                (item: { icon: { url: string } }, i: number) => {\n                    if (i === this.focusedIcon) {\n                        item.icon = { url: item.icon ? item.icon.url : '' };\n                        this.cd.detectChanges();\n                    }\n                }\n            );\n\n            this.data.routingMarkers?.map(\n                (item: { icon: { url: string } }, i: number) => {\n                    if (i === this.focusedIconRouting) {\n                        item.icon = {\n                            url: this.initialIcons[i].url,\n                        };\n                        this.cd.detectChanges();\n                    }\n                }\n            );\n        });\n    }\n\n    public resetMarkersIcons(): void {\n        this.data.markers?.forEach(\n            (\n                marker: {\n                    icon: {\n                        url: string;\n                        labelOrigin: google.maps.Point | null;\n                    };\n                },\n                index: number\n            ) => {\n                marker.icon = {\n                    url: this.initialMarkerIcons[index].url,\n                    labelOrigin: this.initialMarkerIcons[index].labelOrigin,\n                };\n            }\n        );\n        this.cd.detectChanges();\n    }\n\n    public resetRoutingMarkers(): void {\n        this.data.routingMarkers?.forEach(\n            (\n                marker: {\n                    icon: { url: string; labelOrigin?: google.maps.Point };\n                },\n                index: number\n            ) => {\n                marker.icon = {\n                    url: marker.icon!.url,\n                    labelOrigin: marker.icon!.labelOrigin,\n                };\n            }\n        );\n    }\n\n    public onMapReady(): {\n        fillColor?: string;\n        strokeColor?: string;\n        strokeWeight?: number;\n        fillOpacity?: number;\n    } | void {\n        if (this.data.stateBoundariesUrl) {\n            const stateBoundariesUrl = this.data.stateBoundariesUrl.url;\n            this.maps.googleMap?.data.loadGeoJson(stateBoundariesUrl);\n\n            this.maps.googleMap?.data.setStyle((feature) => {\n                //leave this as any for now\n                const stateDensity = feature.getProperty('density');\n                const { fillColor, fillOpacity } =\n                    MapHelper.getFillColorForState(\n                        stateDensity as number,\n                        this.data.view\n                    );\n                return {\n                    fillColor: fillColor,\n                    strokeColor: '#EEEEEE',\n                    strokeWeight: 0.6,\n                    fillOpacity: fillOpacity,\n                };\n            });\n        } else {\n            return;\n        }\n    }\n\n    public identity(index: number): number {\n        return index;\n    }\n\n    ngOnDestroy() {\n        this.directionsRenderers.forEach((renderer) => renderer.setMap(null));\n    }\n}\n","<google-map\n  height=\"500px\"\n  width=\"100%\"\n  [zoom]=\"data.mapZoom\"\n  [center]=\"data.center\"\n  [options]=\"data.mapOptions\"\n  (idle)=\"onMapReady()\"\n>\n  <map-marker\n    #marker=\"mapMarker\"\n    *ngFor=\"let markeritem of data.markers; let i = index; trackBy: identity\"\n    [position]=\"markeritem.position\"\n    [icon]=\"markeritem.icon!\"\n    [label]=\"focusedIcon !== i ? markeritem.label! : ''\"\n    [title]=\"markeritem.title!\"\n    [options]=\"markeritem.options!\"\n    (mapClick)=\"onMarkerClick(i, $event, markeritem)\"\n  >\n    <map-info-window #infoWindowsView=\"mapInfoWindow\">\n      <app-ca-map-dropdown\n        [isAccidentMap]=\"data.isAccidentMap ?? false\"\n      ></app-ca-map-dropdown>\n    </map-info-window>\n  </map-marker>\n  <map-marker\n    *ngFor=\"let marker of data.clustermarkers; let i = index; trackBy: identity\"\n    [position]=\"marker.position\"\n    [icon]=\"marker.icon\"\n    [label]=\"marker.label!\"\n    [title]=\"marker.title!\"\n  >\n  </map-marker>\n\n  <map-marker\n    #markerRouting=\"mapMarker\"\n    *ngFor=\"\n      let markeritem of data.routingMarkers;\n      let i = index;\n      trackBy: identity\n    \"\n    [position]=\"markeritem.position\"\n    [icon]=\"markeritem.icon!\"\n    [label]=\"focusedIconRouting !== i ? markeritem.label! : ''\"\n    [title]=\"markeritem.title!\"\n    [options]=\"markeritem.options!\"\n    (mapClick)=\"onRoutingMarkerClick(i, $event, markeritem)\"\n  >\n    <map-info-window #infoWindowsViewRouting=\"mapInfoWindow\">\n      <app-ca-map-dropdown [isAccidentMap]=\"false\"></app-ca-map-dropdown>\n    </map-info-window>\n  </map-marker>\n</google-map>\n"]}
|
|
330
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ca-map.component.js","sourceRoot":"","sources":["../../../../../../projects/ca-components/src/lib/components/ca-map/ca-map.component.ts","../../../../../../projects/ca-components/src/lib/components/ca-map/ca-map.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport {\n    ChangeDetectorRef,\n    Component,\n    EventEmitter,\n    Input,\n    Output,\n    QueryList,\n    SimpleChanges,\n    ViewChild,\n    ViewChildren,\n} from '@angular/core';\n\n//Modules\nimport {\n    GoogleMap,\n    GoogleMapsModule,\n    MapInfoWindow,\n    MapMarker,\n} from '@angular/google-maps';\n\n//icon\nimport { AngularSvgIconModule } from 'angular-svg-icon';\n\n//Components\nimport { CaMapDropdownComponent } from '../ca-map-dropdown/ca-map-dropdown.component';\n\n//Enums\nimport { GoogleMapEnum } from '../ca-map/enums/google-map.enum';\n//models\nimport { IMapMarkers, IRoutePath } from '../ca-map/models/map.model';\n//HelperFuntion\nimport { MapHelper } from '../ca-map/utils/helpers/map.helper';\n//svg-routes\nimport { MapSvgRoutes } from '../ca-map/utils/map-svg-routes/map-svg-routes';\n\n@Component({\n    selector: 'app-ca-map',\n    templateUrl: './ca-map.component.html',\n    styleUrls: ['./ca-map.component.scss'],\n    standalone: true,\n    imports: [\n        //Modules\n        GoogleMapsModule,\n        CommonModule,\n        AngularSvgIconModule,\n        //Components\n        CaMapDropdownComponent,\n    ],\n})\nexport class CaMapComponent {\n    constructor(public cd: ChangeDetectorRef) {}\n    @Input() data: any; //leave this as any for now\n    @Output() markerClick = new EventEmitter<google.maps.MapMouseEvent>();\n    @ViewChild(GoogleMap, { static: false }) maps!: GoogleMap;\n    @ViewChildren('marker') marker!: QueryList<MapMarker>;\n    @ViewChildren(MapInfoWindow) infoWindowsView!: QueryList<MapInfoWindow>;\n    @ViewChildren('markerRouting') markerRouting!: QueryList<MapMarker>;\n    @ViewChildren(MapInfoWindow)\n    public infoWindowsViewRouting!: QueryList<MapInfoWindow>;\n    public currentlyOpenWindow!: MapInfoWindow | null;\n    public currentlyOpenWindowIndex: number | null = null;\n    public currentlyOpenWindowRouting!: MapInfoWindow | null;\n    public currentlyOpenWindowIndexRouting: number | null = null;\n    public showLabel: boolean = true;\n    public previousIconUrl!: string;\n    public focusedIcon!: number;\n    public previousIconUrlRouting!: string;\n    public focusedIconRouting!: number;\n    private directionService = new google.maps.DirectionsService();\n    public directionsRenderers: google.maps.DirectionsRenderer[] = [];\n    public initialIcons: {\n        url: string;\n        labelOrigin: google.maps.Point | null;\n    }[] = [];\n    public initialMarkerIcons: {\n        url: string;\n        labelOrigin: google.maps.Point | null;\n    }[] = [];\n\n    ngOnInit() {\n        this.storeInitialIconForMarker();\n        this.storeInitialIconForRoutingMarker();\n        // Reset all icons to their initial state on page load\n        this.resetMarkersIcons();\n        this.resetRoutingMarkers();\n        //Display routes for routingMarkers\n        this.calculateAndDisplayRoute();\n    }\n\n    ngOnChanges(changes: SimpleChanges) {\n        if (changes['routingMarkers']) {\n            this.data.routingMarkers = changes['routingMarkers'].currentValue;\n        }\n    }\n\n    public storeInitialIconForMarker(): void {\n        this.data!.markers?.forEach(\n            (\n                marker: {\n                    icon: { url: string; labelOrigin: google.maps.Point };\n                },\n                index: number\n            ) => {\n                this.initialMarkerIcons[index] = {\n                    url: marker.icon!.url,\n                    labelOrigin: marker.icon!.labelOrigin || null,\n                };\n            }\n        );\n    }\n\n    public storeInitialIconForRoutingMarker(): void {\n        this.data.routingMarkers?.forEach(\n            (\n                marker: {\n                    icon: { url: string; labelOrigin?: google.maps.Point };\n                },\n                index: number\n            ) => {\n                this.initialIcons[index] = {\n                    url: marker.icon!.url,\n                    labelOrigin: marker.icon!.labelOrigin || null,\n                };\n            }\n        );\n    }\n\n    public onMarkerClick(\n        i: number,\n        event: google.maps.MapMouseEvent,\n        markeritem: IMapMarkers\n    ): void {\n        if (markeritem?.infoWindowContent) {\n            if (\n                this.currentlyOpenWindowIndex === i &&\n                this.currentlyOpenWindow\n            ) {\n                const infoWindow = this.infoWindowsView.toArray()[i];\n                // Close the currently open info window and reset the index\n                this.data.markers.map(\n                    (\n                        item: {\n                            icon: {\n                                url: string;\n                                labelOrigin: google.maps.Point | null;\n                            };\n                        },\n                        index: number\n                    ) => {\n                        if (index === i) {\n                            item.icon = {\n                                url: this.initialMarkerIcons[index]!.url,\n                                labelOrigin:\n                                    this.initialMarkerIcons[index]!.labelOrigin,\n                            };\n                        }\n                    }\n                );\n\n                infoWindow.close();\n                this.currentlyOpenWindowIndex = null;\n            } else {\n                const markerIndex = this.marker.toArray()[i];\n                const infoWindow = this.infoWindowsView.toArray()[i];\n                if (this.currentlyOpenWindow) {\n                    this.currentlyOpenWindow.close();\n                }\n                if (infoWindow) {\n                    this.data.markers.map(\n                        (\n                            item: {\n                                icon: {\n                                    url: string;\n                                    scaledSize?: google.maps.Size;\n                                    labelOrigin?: google.maps.Point | null;\n                                };\n                            },\n                            index: number\n                        ) => {\n                            if (index === i) {\n                                this.focusedIcon = i;\n                                this.showLabel = false;\n                                item.icon = {\n                                    url: this.initialMarkerIcons[index]!.url,\n                                    scaledSize: new google.maps.Size(70, 70),\n                                };\n                            } else {\n                                this.showLabel = true;\n                                item.icon = {\n                                    url: this.initialMarkerIcons[index]!.url,\n                                    labelOrigin:\n                                        this.initialMarkerIcons[index]!\n                                            .labelOrigin,\n                                };\n                            }\n                        }\n                    );\n\n                    infoWindow.open(markerIndex);\n                    this.currentlyOpenWindow = infoWindow;\n                    this.currentlyOpenWindowIndex = i;\n                    this.markerClick.emit(event);\n                }\n            }\n        } else {\n            return;\n        }\n    }\n\n    public setDirectionsOnMap(): void {\n        if (this.maps?.googleMap) {\n            this.directionsRenderers.forEach((renderer) =>\n                renderer.setMap(this.maps?.googleMap!)\n            );\n        }\n    }\n\n    public calculateAndDisplayRoute(): void {\n        if (this.data.routePaths) {\n            // Clear any previous directions renderers\n            this.directionsRenderers.forEach((renderer) =>\n                renderer.setMap(null)\n            );\n            this.directionsRenderers = [];\n\n            this.data.routePaths!.forEach(\n                (route: {\n                    path: IRoutePath[];\n                    strokeColor: string;\n                    strokeOpacity: number;\n                }) => {\n                    const request: google.maps.DirectionsRequest = {\n                        origin: route.path[0],\n                        destination: route.path[route.path.length - 1],\n                        waypoints: route.path\n                            .slice(1, route.path.length - 1)\n                            .map((position) => ({ location: position })),\n                        travelMode: google.maps.TravelMode.BICYCLING,\n                    };\n\n                    this.directionService.route(request, (result, status) => {\n                        if (\n                            status === google.maps.DirectionsStatus.OK &&\n                            result?.routes[0]\n                        ) {\n                            const directionsRenderer =\n                                new google.maps.DirectionsRenderer({\n                                    suppressInfoWindows: true,\n                                    suppressMarkers: true,\n                                    preserveViewport: true,\n                                    polylineOptions: {\n                                        strokeColor:\n                                            route.strokeColor ||\n                                            GoogleMapEnum.STROKE_COLOR,\n                                        strokeOpacity:\n                                            route.strokeOpacity ||\n                                            GoogleMapEnum.STROKE_OPACITY,\n                                    },\n                                });\n                            directionsRenderer.setDirections(result);\n                            this.directionsRenderers.push(directionsRenderer);\n                            this.setDirectionsOnMap();\n                        }\n                    });\n                }\n            );\n        } else {\n            return;\n        }\n    }\n\n    public onRoutingMarkerClick(\n        i: number,\n        event: google.maps.MapMouseEvent,\n        markeritem: IMapMarkers\n    ): void {\n        if (markeritem?.infoWindowContent) {\n            if (\n                this.currentlyOpenWindowIndexRouting === i &&\n                this.currentlyOpenWindowRouting\n            ) {\n                const infoWindow = this.infoWindowsViewRouting.toArray()[i];\n                // Close the currently open info window and reset the index\n                this.data.routingMarkers.map(\n                    (\n                        item: {\n                            icon: {\n                                url: string;\n                                labelOrigin?: google.maps.Point | null;\n                            };\n                        },\n                        index: number\n                    ) => {\n                        if (index === i) {\n                            item.icon = {\n                                url: this.initialIcons[index]!.url,\n                                labelOrigin:\n                                    this.initialIcons[index]!.labelOrigin,\n                            };\n                        }\n                    }\n                );\n\n                infoWindow.close();\n                this.currentlyOpenWindowIndexRouting = null;\n            } else {\n                const markerIndex = this.markerRouting.toArray()[i];\n                const infoWindow = this.infoWindowsViewRouting.toArray()[i];\n                if (this.currentlyOpenWindowRouting) {\n                    this.currentlyOpenWindowRouting.close();\n                }\n                if (infoWindow) {\n                    // Restore the previous icon for the previously focused routing marker\n                    if (\n                        this.focusedIconRouting !== undefined &&\n                        this.focusedIconRouting !== i\n                    ) {\n                        const previousFocusedItem =\n                            this.data.routingMarkers[this.focusedIconRouting];\n                        if (previousFocusedItem) {\n                            previousFocusedItem.icon = {\n                                url: this.initialIcons[this.focusedIconRouting]\n                                    .url,\n                                labelOrigin:\n                                    this.initialIcons[this.focusedIconRouting]\n                                        .labelOrigin,\n                            };\n                        }\n                    }\n\n                    // Update the current marker\n                    this.data.routingMarkers.map(\n                        (item: { icon: { url: string } }, index: number) => {\n                            if (index === i) {\n                                this.previousIconUrlRouting = item.icon\n                                    ? item.icon.url\n                                    : '';\n                                this.focusedIconRouting = i;\n                                this.showLabel = false;\n                                item.icon = {\n                                    url:\n                                        this.data.isUnitViewStops ||\n                                        this.data.isDriverMiles\n                                            ? item.icon.url\n                                            : MapSvgRoutes.markerSvgRoute,\n                                };\n                            } else {\n                                this.showLabel = true;\n                            }\n                        }\n                    );\n\n                    infoWindow.open(markerIndex);\n                    this.currentlyOpenWindowRouting = infoWindow;\n                    this.currentlyOpenWindowIndexRouting = i;\n                    this.markerClick.emit(event);\n                }\n            }\n        } else {\n            return;\n        }\n    }\n\n    ngAfterViewInit() {\n        this.maps.googleMap?.addListener('click', () => {\n            this.infoWindowsView.forEach((window: MapInfoWindow) => {\n                window.close();\n                this.currentlyOpenWindow = null;\n            });\n            this.infoWindowsViewRouting.forEach((window: MapInfoWindow) => {\n                window.close();\n                this.currentlyOpenWindowRouting = null;\n            });\n            this.data.markers?.map(\n                (item: { icon: { url: string } }, i: number) => {\n                    if (i === this.focusedIcon) {\n                        item.icon = { url: item.icon ? item.icon.url : '' };\n                        this.cd.detectChanges();\n                    }\n                }\n            );\n\n            this.data.routingMarkers?.map(\n                (item: { icon: { url: string } }, i: number) => {\n                    if (i === this.focusedIconRouting) {\n                        item.icon = {\n                            url: this.initialIcons[i].url,\n                        };\n                        this.cd.detectChanges();\n                    }\n                }\n            );\n        });\n    }\n\n    public resetMarkersIcons(): void {\n        this.data.markers?.forEach(\n            (\n                marker: {\n                    icon: {\n                        url: string;\n                        labelOrigin: google.maps.Point | null;\n                    };\n                },\n                index: number\n            ) => {\n                marker.icon = {\n                    url: this.initialMarkerIcons[index].url,\n                    labelOrigin: this.initialMarkerIcons[index].labelOrigin,\n                };\n            }\n        );\n        this.cd.detectChanges();\n    }\n\n    public resetRoutingMarkers(): void {\n        this.data.routingMarkers?.forEach(\n            (\n                marker: {\n                    icon: { url: string; labelOrigin?: google.maps.Point };\n                },\n                index: number\n            ) => {\n                marker.icon = {\n                    url: marker.icon!.url,\n                    labelOrigin: marker.icon!.labelOrigin,\n                };\n            }\n        );\n    }\n\n    public onMapReady(): {\n        fillColor?: string;\n        strokeColor?: string;\n        strokeWeight?: number;\n        fillOpacity?: number;\n    } | void {\n        if (this.data.stateBoundariesUrl) {\n            const stateBoundariesUrl = this.data.stateBoundariesUrl.url;\n            this.maps.googleMap?.data.loadGeoJson(stateBoundariesUrl);\n\n            this.maps.googleMap?.data.setStyle((feature) => {\n                //leave this as any for now\n                const stateDensity = feature.getProperty('density');\n                const { fillColor, fillOpacity } =\n                    MapHelper.getFillColorForState(\n                        stateDensity as number,\n                        this.data.view\n                    );\n                return {\n                    fillColor: fillColor,\n                    strokeColor: '#EEEEEE',\n                    strokeWeight: 0.6,\n                    fillOpacity: fillOpacity,\n                };\n            });\n        } else {\n            return;\n        }\n    }\n\n    public identity(index: number): number {\n        return index;\n    }\n\n    ngOnDestroy() {\n        this.directionsRenderers.forEach((renderer) => renderer.setMap(null));\n    }\n}\n","<google-map\n  height=\"500px\"\n  width=\"100%\"\n  [zoom]=\"data.mapZoom\"\n  [center]=\"data.center\"\n  [options]=\"data.mapOptions\"\n  (idle)=\"onMapReady()\"\n>\n  <map-marker\n    #marker=\"mapMarker\"\n    *ngFor=\"let markeritem of data.markers; let i = index; trackBy: identity\"\n    [position]=\"markeritem.position\"\n    [icon]=\"markeritem.icon!\"\n    [label]=\"focusedIcon !== i ? markeritem.label! : ''\"\n    [title]=\"markeritem.title!\"\n    [options]=\"markeritem.options!\"\n    (mapClick)=\"onMarkerClick(i, $event, markeritem)\"\n  >\n    <map-info-window #infoWindowsView=\"mapInfoWindow\">\n      <app-ca-map-dropdown\n        [isAccidentMap]=\"data.isAccidentMap ?? false\"\n      ></app-ca-map-dropdown>\n    </map-info-window>\n  </map-marker>\n  <map-marker\n    *ngFor=\"let marker of data.clustermarkers; let i = index; trackBy: identity\"\n    [position]=\"marker.position\"\n    [icon]=\"marker.icon\"\n    [label]=\"marker.label!\"\n    [title]=\"marker.title!\"\n  >\n  </map-marker>\n\n  <map-marker\n    #markerRouting=\"mapMarker\"\n    *ngFor=\"\n      let markeritem of data.routingMarkers;\n      let i = index;\n      trackBy: identity\n    \"\n    [position]=\"markeritem.position\"\n    [icon]=\"markeritem.icon!\"\n    [label]=\"focusedIconRouting !== i ? markeritem.label! : ''\"\n    [title]=\"markeritem.title!\"\n    [options]=\"markeritem.options!\"\n    (mapClick)=\"onRoutingMarkerClick(i, $event, markeritem)\"\n  >\n    <map-info-window #infoWindowsViewRouting=\"mapInfoWindow\">\n      <app-ca-map-dropdown [isAccidentMap]=\"false\"></app-ca-map-dropdown>\n    </map-info-window>\n  </map-marker>\n</google-map>\n"]}
|
|
@@ -1,2 +1,2 @@
|
|
|
1
1
|
export {};
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWFwLm1vZGVsLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY2EtY29tcG9uZW50cy9zcmMvbGliL2NvbXBvbmVudHMvY2EtbWFwL21vZGVscy9tYXAubW9kZWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBpbnRlcmZhY2UgSVJvdXRlUGF0aCB7XG4gIGxhdDogbnVtYmVyO1xuICBsbmc6IG51bWJlcjtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBJTWFwU3RvcmllcyB7XG4gIGRhdGE6IHtcbiAgICBjZW50ZXI6IElSb3V0ZVBhdGg7XG4gICAgbWFwWm9vbTogbnVtYmVyO1xuICAgIG1hcE9wdGlvbnM6IElNYXBPcHRpb25zO1xuICAgIGNsdXN0ZXJtYXJrZXJzPzogSU1hcE1hcmtlcnNbXTtcbiAgICByb3V0aW5nTWFya2Vycz86IElNYXBNYXJrZXJzW107XG4gICAgcm91dGVQYXRoPzogSU1hcFJvdXRlUGF0aFtdO1xuICAgIGlzQWNjaWRlbnRNYXA/OiBib29sZWFuO1xuICAgIHN0YXRlQm91bmRhcmllc1VybD86IHsgdXJsOiBzdHJpbmcgfTtcbiAgICBtYXJrZXJzPzogSU1hcE1hcmtlcnNbXTtcbiAgICB2aWV3Pzogc3RyaW5nO1xuICAgIGlzVW5pdFZpZXdTdG9wcz86IGJvb2xlYW47XG4gICAgaXNEcml2ZXJNaWxlcz86IGJvb2xlYW47XG4gIH07XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgSU1hcE9wdGlvbnMge1xuICBtYXBPcHRpb25zOiB7XG4gICAgcmVzdHJpY3Rpb246IHtcbiAgICAgIGxhdExuZ0JvdW5kczoge1xuICAgICAgICBub3J0aDogbnVtYmVyO1xuICAgICAgICBzb3V0aDogbnVtYmVyO1xuICAgICAgICBlYXN0OiBudW1iZXI7XG4gICAgICAgIHdlc3Q6IG51bWJlcjtcbiAgICAgIH07XG4gICAgICBzdHJpY3RCb3VuZHM6IGJvb2xlYW47XG4gICAgfTtcbiAgICBzdHJlZXRWaWV3Q29udHJvbDogYm9vbGVhbjtcbiAgICBzdHlsZXM6IElNYXBTdHlsZXNbXTtcbiAgICBrZXlib2FyZFNob3J0Y3V0czogYm9vbGVhbjtcbiAgICBwYW5Db250cm9sOiBib29sZWFuO1xuICAgIGdlc3R1cmVIYW5kbGluZzogc3RyaW5nO1xuICB9O1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIElNYXBTdHlsZXMge1xuICBlbGVtZW50VHlwZTogc3RyaW5nO1xuICBzdHlsZXJzOiBJTWFwQ29sb3JbXTtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBJTWFwQ29sb3Ige1xuICBjb2xvcjogc3RyaW5nO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIElNYXBNYXJrZXJzIHtcbiAgcG9zaXRpb246IElSb3V0ZVBhdGg7XG4gIGljb24/OiBJTWFwTWFya2Vyc0ljb247XG4gIGluZm9XaW5kb3dDb250ZW50Pzogc3RyaW5nO1xuICBsYWJlbD86IElNYXJrZXJMYWJlbDtcbiAgbGFiZWxPcmlnaW4/OiB7IHg6IG51bWJlcjsgeTogbnVtYmVyIH07XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgSU1hcE1hcmtlcnNJY29uIHtcbiAgdXJsOiBzdHJpbmc7XG4gIGxhYmVsT3JpZ2luPzogeyB4OiBudW1iZXI7IHk6IG51bWJlciB9O1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIElNYXJrZXJMYWJlbCB7XG4gIHRleHQ6IHN0cmluZztcbiAgZm9udFNpemU/OiBzdHJpbmc7XG4gIGNvbG9yPzogc3RyaW5nO1xuICBmb250V2VpZ2h0Pzogc3RyaW5nO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIElNYXBSb3V0ZVBhdGgge1xuICBwYXRoOiBJUm91dGVQYXRoW107XG4gIHN0cm9rZUNvbG9yOiBzdHJpbmc7XG59XG4iXX0=
|