mis-crystal-design-system 18.0.24 → 18.1.0-signal-test
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/action-list/action-list.component.d.ts +17 -15
- package/async-search-dropdown/async-dropdown.component.d.ts +43 -61
- package/button/button.component.d.ts +35 -13
- package/button/button.directive.d.ts +10 -8
- package/checkbox/checkbox.component.d.ts +15 -12
- package/chip/chip.component.d.ts +9 -11
- package/datepicker_v2/models/dp-config.model.d.ts +1 -0
- package/datepicker_v2/tz-datepicker.directive.d.ts +15 -18
- package/datepicker_v2/tz-dp-container/tz-dp-container.component.d.ts +42 -21
- package/daterangepicker_v2/tz-daterangepicker.directive.d.ts +12 -14
- package/daterangepicker_v2/tz-drp-container/tz-drp-container.component.d.ts +46 -23
- package/drawer/drawer-body/drawer-body.component.d.ts +2 -2
- package/dropdown/calculate-container-height.directive.d.ts +7 -8
- package/dropdown/dropdown.component.d.ts +41 -49
- package/dynamic-form/dynamic-form.component.d.ts +20 -16
- package/esm2022/action-list/action-list.component.mjs +112 -89
- package/esm2022/async-search-dropdown/async-dropdown.component.mjs +256 -326
- package/esm2022/button/button.component.mjs +55 -48
- package/esm2022/button/button.directive.mjs +36 -40
- package/esm2022/checkbox/checkbox.component.mjs +75 -70
- package/esm2022/chip/chip.component.mjs +20 -33
- package/esm2022/datepicker_v2/models/dp-config.model.mjs +1 -1
- package/esm2022/datepicker_v2/tz-datepicker.directive.mjs +42 -71
- package/esm2022/datepicker_v2/tz-dp-container/tz-dp-container.component.mjs +202 -172
- package/esm2022/datepicker_v2/utils/index.mjs +2 -1
- package/esm2022/daterangepicker_v2/tz-daterangepicker.directive.mjs +26 -51
- package/esm2022/daterangepicker_v2/tz-drp-container/tz-drp-container.component.mjs +282 -235
- package/esm2022/drawer/drawer-body/drawer-body.component.mjs +8 -7
- package/esm2022/dropdown/calculate-container-height.directive.mjs +25 -22
- package/esm2022/dropdown/dropdown.component.mjs +162 -186
- package/esm2022/dynamic-form/dynamic-form.component.mjs +118 -72
- package/esm2022/fab/fab.component.mjs +29 -33
- package/esm2022/filter/filter-panel/filter-panel.component.mjs +60 -58
- package/esm2022/input/directives/input/input.directive.mjs +22 -26
- package/esm2022/input/mis-input.component.mjs +41 -45
- package/esm2022/input-stepper/input-stepper/input-stepper.component.mjs +40 -50
- package/esm2022/loader/loader.component.mjs +8 -11
- package/esm2022/mobile-filter/mobile-filter.component.mjs +61 -61
- package/esm2022/modal/module-wrapper/module-wrapper.component.mjs +11 -9
- package/esm2022/multi-select-dropdown/multi-select-dropdown.component.mjs +235 -281
- package/esm2022/nested-multi-select-dropdown/nested-multi-select-dropdown.component.mjs +250 -287
- package/esm2022/phone-input/phone-input.component.mjs +21 -43
- package/esm2022/radio-button/radio-button.component.mjs +15 -27
- package/esm2022/ske-loader/ske-loader.component.mjs +15 -29
- package/esm2022/slider/slider.component.mjs +23 -33
- package/esm2022/slider/slider.module.mjs +4 -11
- package/esm2022/snackbar/snackbar/snackbar.component.mjs +21 -15
- package/esm2022/snackbar/snackbar.service.mjs +3 -2
- package/esm2022/specificdatepicker/tz-sdp-container/tz-sdp-container.component.mjs +230 -343
- package/esm2022/specificdatepicker/tz-specificdatepicker.directive.mjs +77 -105
- package/esm2022/star-rating/star-rating.component.mjs +57 -71
- package/esm2022/switch/switch.component.mjs +34 -36
- package/esm2022/table/actions-cell/actions-cell.component.mjs +55 -54
- package/esm2022/table/custom-table-cell.directive.mjs +22 -18
- package/esm2022/table/filter/filter.component.mjs +60 -42
- package/esm2022/table/sort-icons.directive.mjs +16 -8
- package/esm2022/table/sub-table/sub-table.component.mjs +41 -44
- package/esm2022/table/table.component.mjs +181 -165
- package/esm2022/timepicker/timepicker.component.mjs +244 -159
- package/esm2022/timepicker/timepicker.directive.mjs +3 -2
- package/esm2022/timerangepicker/timerangepicker.component.mjs +200 -159
- package/esm2022/toast/toast.component.mjs +6 -7
- package/esm2022/toast/toast.data.service.mjs +15 -9
- package/esm2022/tooltip/tooltip-container/tooltip.component.mjs +12 -12
- package/esm2022/tooltip/tooltip.directive.mjs +4 -4
- package/esm2022/virtual-scroll/virtual-scroll.component.mjs +57 -59
- package/fab/fab.component.d.ts +12 -8
- package/fesm2022/mis-crystal-design-system-action-list.mjs +111 -88
- package/fesm2022/mis-crystal-design-system-action-list.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-async-search-dropdown.mjs +253 -324
- package/fesm2022/mis-crystal-design-system-async-search-dropdown.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-button.mjs +88 -85
- package/fesm2022/mis-crystal-design-system-button.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-checkbox.mjs +74 -69
- package/fesm2022/mis-crystal-design-system-checkbox.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-chip.mjs +19 -32
- package/fesm2022/mis-crystal-design-system-chip.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-datepicker_v2.mjs +242 -240
- package/fesm2022/mis-crystal-design-system-datepicker_v2.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-daterangepicker_v2.mjs +305 -283
- package/fesm2022/mis-crystal-design-system-daterangepicker_v2.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-drawer.mjs +7 -6
- package/fesm2022/mis-crystal-design-system-drawer.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-dropdown.mjs +183 -204
- package/fesm2022/mis-crystal-design-system-dropdown.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-dynamic-form.mjs +118 -72
- package/fesm2022/mis-crystal-design-system-dynamic-form.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-fab.mjs +28 -32
- package/fesm2022/mis-crystal-design-system-fab.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-filter.mjs +59 -57
- package/fesm2022/mis-crystal-design-system-filter.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-input-stepper.mjs +39 -49
- package/fesm2022/mis-crystal-design-system-input-stepper.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-input.mjs +62 -71
- package/fesm2022/mis-crystal-design-system-input.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-loader.mjs +7 -10
- package/fesm2022/mis-crystal-design-system-loader.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-mobile-filter.mjs +60 -60
- package/fesm2022/mis-crystal-design-system-mobile-filter.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-modal.mjs +10 -8
- package/fesm2022/mis-crystal-design-system-modal.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-multi-select-dropdown.mjs +233 -279
- package/fesm2022/mis-crystal-design-system-multi-select-dropdown.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-nested-multi-select-dropdown.mjs +249 -286
- package/fesm2022/mis-crystal-design-system-nested-multi-select-dropdown.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-phone-input.mjs +20 -42
- package/fesm2022/mis-crystal-design-system-phone-input.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-radio-button.mjs +14 -26
- package/fesm2022/mis-crystal-design-system-radio-button.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-ske-loader.mjs +14 -28
- package/fesm2022/mis-crystal-design-system-ske-loader.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-slider.mjs +25 -42
- package/fesm2022/mis-crystal-design-system-slider.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-snackbar.mjs +22 -15
- package/fesm2022/mis-crystal-design-system-snackbar.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-specificdatepicker.mjs +304 -445
- package/fesm2022/mis-crystal-design-system-specificdatepicker.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-star-rating.mjs +56 -70
- package/fesm2022/mis-crystal-design-system-star-rating.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-switch.mjs +33 -35
- package/fesm2022/mis-crystal-design-system-switch.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-table.mjs +365 -321
- package/fesm2022/mis-crystal-design-system-table.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-timepicker.mjs +245 -159
- package/fesm2022/mis-crystal-design-system-timepicker.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-timerangepicker.mjs +199 -158
- package/fesm2022/mis-crystal-design-system-timerangepicker.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-toast.mjs +18 -13
- package/fesm2022/mis-crystal-design-system-toast.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-tooltip.mjs +14 -14
- package/fesm2022/mis-crystal-design-system-tooltip.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-virtual-scroll.mjs +57 -59
- package/fesm2022/mis-crystal-design-system-virtual-scroll.mjs.map +1 -1
- package/filter/filter-panel/filter-panel.component.d.ts +14 -14
- package/input/directives/input/input.directive.d.ts +6 -10
- package/input/mis-input.component.d.ts +12 -13
- package/input-stepper/input-stepper/input-stepper.component.d.ts +8 -7
- package/loader/loader.component.d.ts +3 -6
- package/mobile-filter/mobile-filter.component.d.ts +15 -15
- package/modal/module-wrapper/module-wrapper.component.d.ts +2 -3
- package/multi-select-dropdown/multi-select-dropdown.component.d.ts +89 -51
- package/nested-multi-select-dropdown/nested-multi-select-dropdown.component.d.ts +99 -56
- package/package.json +17 -17
- package/phone-input/phone-input.component.d.ts +16 -18
- package/radio-button/radio-button.component.d.ts +9 -11
- package/ske-loader/ske-loader.component.d.ts +8 -11
- package/slider/slider.component.d.ts +8 -11
- package/slider/slider.module.d.ts +1 -2
- package/snackbar/snackbar/snackbar.component.d.ts +3 -3
- package/specificdatepicker/tz-sdp-container/tz-sdp-container.component.d.ts +35 -35
- package/specificdatepicker/tz-specificdatepicker.directive.d.ts +24 -28
- package/star-rating/star-rating.component.d.ts +18 -18
- package/switch/switch.component.d.ts +8 -10
- package/table/actions-cell/actions-cell.component.d.ts +14 -14
- package/table/custom-table-cell.directive.d.ts +3 -3
- package/table/filter/filter.component.d.ts +9 -9
- package/table/sub-table/sub-table.component.d.ts +5 -5
- package/table/table.component.d.ts +38 -35
- package/timepicker/timepicker.component.d.ts +29 -28
- package/timerangepicker/timerangepicker.component.d.ts +36 -33
- package/toast/toast.data.service.d.ts +1 -1
- package/tooltip/tooltip-container/tooltip.component.d.ts +4 -4
- package/virtual-scroll/virtual-scroll.component.d.ts +8 -9
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import { Component,
|
|
1
|
+
import { Component, ViewChild, ViewChildren, input, output, signal, effect, untracked } from "@angular/core";
|
|
2
2
|
import { TimepickerDirective } from "./timepicker.directive";
|
|
3
3
|
import { ToolTipDirective } from "mis-crystal-design-system/tooltip";
|
|
4
4
|
import dayjs from 'dayjs';
|
|
@@ -32,11 +32,11 @@ function TimePickerComponent_ng_template_3_div_0_li_3_Template(rf, ctx) { if (rf
|
|
|
32
32
|
const interval_r3 = ctx.$implicit;
|
|
33
33
|
const i_r5 = ctx.index;
|
|
34
34
|
const ctx_r3 = i0.ɵɵnextContext(3);
|
|
35
|
-
i0.ɵɵproperty("ngClass", i0.ɵɵpureFunction1(3, _c6, i_r5 === ctx_r3.isHighlighted));
|
|
35
|
+
i0.ɵɵproperty("ngClass", i0.ɵɵpureFunction1(3, _c6, i_r5 === ctx_r3.isHighlighted()));
|
|
36
36
|
i0.ɵɵadvance(2);
|
|
37
37
|
i0.ɵɵtextInterpolate1(" ", interval_r3, " ");
|
|
38
38
|
i0.ɵɵadvance();
|
|
39
|
-
i0.ɵɵproperty("ngIf", interval_r3 === ctx_r3.chosenTime);
|
|
39
|
+
i0.ɵɵproperty("ngIf", interval_r3 === ctx_r3.chosenTime());
|
|
40
40
|
} }
|
|
41
41
|
function TimePickerComponent_ng_template_3_div_0_Template(rf, ctx) { if (rf & 1) {
|
|
42
42
|
i0.ɵɵelementStart(0, "div", 8)(1, "ul", null, 2);
|
|
@@ -44,15 +44,15 @@ function TimePickerComponent_ng_template_3_div_0_Template(rf, ctx) { if (rf & 1)
|
|
|
44
44
|
i0.ɵɵelementEnd()();
|
|
45
45
|
} if (rf & 2) {
|
|
46
46
|
const ctx_r3 = i0.ɵɵnextContext(2);
|
|
47
|
-
i0.ɵɵproperty("ngStyle", i0.ɵɵpureFunction1(2, _c5, ctx_r3.dropdownWidth || ctx_r3.inputWidth));
|
|
47
|
+
i0.ɵɵproperty("ngStyle", i0.ɵɵpureFunction1(2, _c5, ctx_r3.dropdownWidth() || ctx_r3.inputWidth()));
|
|
48
48
|
i0.ɵɵadvance(3);
|
|
49
|
-
i0.ɵɵproperty("ngForOf", ctx_r3.timeIntervals);
|
|
49
|
+
i0.ɵɵproperty("ngForOf", ctx_r3.timeIntervals());
|
|
50
50
|
} }
|
|
51
51
|
function TimePickerComponent_ng_template_3_Template(rf, ctx) { if (rf & 1) {
|
|
52
52
|
i0.ɵɵtemplate(0, TimePickerComponent_ng_template_3_div_0_Template, 4, 4, "div", 7);
|
|
53
53
|
} if (rf & 2) {
|
|
54
54
|
const ctx_r3 = i0.ɵɵnextContext();
|
|
55
|
-
i0.ɵɵproperty("ngIf", ctx_r3.openStatus);
|
|
55
|
+
i0.ɵɵproperty("ngIf", ctx_r3.openStatus());
|
|
56
56
|
} }
|
|
57
57
|
dayjs.extend(utc);
|
|
58
58
|
dayjs.extend(timezone);
|
|
@@ -68,64 +68,152 @@ export class TimePickerComponent {
|
|
|
68
68
|
});
|
|
69
69
|
}
|
|
70
70
|
constructor() {
|
|
71
|
-
|
|
72
|
-
this.
|
|
73
|
-
this.
|
|
74
|
-
this.
|
|
75
|
-
this.
|
|
76
|
-
this.
|
|
77
|
-
this.
|
|
78
|
-
this.
|
|
79
|
-
this.
|
|
80
|
-
this.
|
|
81
|
-
|
|
82
|
-
this.
|
|
83
|
-
this.
|
|
84
|
-
this.
|
|
85
|
-
this.
|
|
86
|
-
this.
|
|
87
|
-
this.
|
|
88
|
-
this.
|
|
89
|
-
this.
|
|
71
|
+
// Convert to signals for better performance and change detection
|
|
72
|
+
this.currTime = signal('');
|
|
73
|
+
this.chosenTime = signal('');
|
|
74
|
+
this.openStatus = signal(false);
|
|
75
|
+
this.isHighlighted = signal(0);
|
|
76
|
+
this.isInvalid = signal(false);
|
|
77
|
+
this.timeIntervals = signal([]);
|
|
78
|
+
this.shouldScroll = signal(false);
|
|
79
|
+
this.userInputFlag = signal(false);
|
|
80
|
+
this.givenTimeFlag = signal(true);
|
|
81
|
+
// Signal-based inputs with backward compatibility
|
|
82
|
+
this.clockFormat = input(12);
|
|
83
|
+
this.timezone = input("Asia/Kolkata");
|
|
84
|
+
this.height = input("max-content");
|
|
85
|
+
this.inputWidth = input("100px");
|
|
86
|
+
this.dropdownWidth = input(undefined);
|
|
87
|
+
this.interval = input(15);
|
|
88
|
+
this.dateAsEpoch = input(dayjs.tz(dayjs(), "Asia/Kolkata").valueOf());
|
|
89
|
+
this.firstInterval = input();
|
|
90
|
+
this.rangeValidity = input(true);
|
|
91
|
+
this.showTooltip = input(true);
|
|
92
|
+
this.dispayToolTip = this.showTooltip();
|
|
93
|
+
this.givenTime = input();
|
|
94
|
+
this.minTime = input(undefined);
|
|
95
|
+
this.triggerChange = input(true);
|
|
96
|
+
this.disable = input(false);
|
|
97
|
+
// Internal state for computed first interval
|
|
98
|
+
this.computedFirstInterval = null;
|
|
99
|
+
this._isInitializing = false;
|
|
100
|
+
// Signal-based output with backward compatibility
|
|
101
|
+
this.timeEmitter = output();
|
|
102
|
+
// Effect to handle triggerChange from parent component (timerangepicker)
|
|
103
|
+
effect(() => {
|
|
104
|
+
const triggerValue = this.triggerChange();
|
|
105
|
+
const firstIntervalValue = this.firstInterval();
|
|
106
|
+
// Only update if not during user input and firstInterval is provided
|
|
107
|
+
if (!untracked(() => this.userInputFlag()) && firstIntervalValue && !this._isInitializing) {
|
|
108
|
+
const newTime = dayjs.tz(firstIntervalValue, untracked(() => this.timezone())).format(this.timeFormat);
|
|
109
|
+
// Only update if the time actually changed
|
|
110
|
+
if (untracked(() => this.chosenTime()) !== newTime) {
|
|
111
|
+
// Use setTimeout to defer signal writes and avoid circular dependencies
|
|
112
|
+
setTimeout(() => {
|
|
113
|
+
this.chosenTime.set(newTime);
|
|
114
|
+
this.isInvalid.set(!this.checkTimeValidity(newTime.trim()));
|
|
115
|
+
// CRITICAL FIX: Repopulate dropdown when firstInterval changes
|
|
116
|
+
this.populateDropdown();
|
|
117
|
+
// Recalculate closest interval
|
|
118
|
+
this.calculateClosestInterval(newTime);
|
|
119
|
+
// Emit the updated time
|
|
120
|
+
const timedayjs = this.getdayjs(newTime);
|
|
121
|
+
this.emitTime({
|
|
122
|
+
valid: !this.isInvalid(),
|
|
123
|
+
time: newTime,
|
|
124
|
+
epoch: timedayjs.valueOf()
|
|
125
|
+
});
|
|
126
|
+
}, 0);
|
|
127
|
+
}
|
|
128
|
+
}
|
|
129
|
+
});
|
|
90
130
|
}
|
|
91
131
|
ngOnInit() {
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
100
|
-
|
|
101
|
-
}
|
|
102
|
-
ngOnChanges() {
|
|
103
|
-
this.timeFormat = this.clockFormat === 12 ? "hh:mm a" : "HH:mm";
|
|
104
|
-
if (this.timeFormat) {
|
|
105
|
-
let chosenTimedayjs = this.getdayjs(this.chosenTime);
|
|
106
|
-
// if the first interval is >= the chosen time
|
|
107
|
-
// then only update the value of chosen time
|
|
108
|
-
// else it remains the same
|
|
109
|
-
if (this.firstInterval >= chosenTimedayjs.valueOf() && this.rangeValidity && !this.userInputFlag) {
|
|
110
|
-
this.chosenTime = dayjs.tz(this.firstInterval, this.timezone).format(this.timeFormat);
|
|
111
|
-
chosenTimedayjs = this.getdayjs(this.chosenTime);
|
|
132
|
+
this._isInitializing = true;
|
|
133
|
+
// Ensure timeFormat is set before initialization
|
|
134
|
+
this.timeFormat = this.clockFormat() === 12 ? "hh:mm a" : "HH:mm";
|
|
135
|
+
// Initialize chosenTime - use firstInterval from parent if available, otherwise calculate
|
|
136
|
+
if (!this.givenTime() && !this.minTime()) {
|
|
137
|
+
let initialTime;
|
|
138
|
+
// If firstInterval is provided by parent (timerangepicker), use it
|
|
139
|
+
if (this.firstInterval()) {
|
|
140
|
+
initialTime = dayjs.tz(this.firstInterval(), this.timezone()).format(this.timeFormat);
|
|
112
141
|
}
|
|
113
|
-
|
|
114
|
-
|
|
142
|
+
else {
|
|
143
|
+
// Get current time and round to nearest interval using original logic
|
|
144
|
+
const now = dayjs.tz(dayjs(), this.timezone());
|
|
145
|
+
const interval = this.interval();
|
|
146
|
+
const minutes = now.minute();
|
|
147
|
+
const offset = interval - (minutes % interval);
|
|
148
|
+
// Round to next interval if we're past halfway point
|
|
149
|
+
const roundedTime = offset >= interval / 2
|
|
150
|
+
? now.add(offset, "m").second(0).millisecond(0)
|
|
151
|
+
: now.subtract(interval - offset, "m").second(0).millisecond(0);
|
|
152
|
+
initialTime = roundedTime.format(this.timeFormat);
|
|
115
153
|
}
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
154
|
+
this.chosenTime.set(initialTime);
|
|
155
|
+
// Set userInputFlag to false to avoid validation issues during initialization
|
|
156
|
+
this.userInputFlag.set(false);
|
|
157
|
+
// Populate dropdown first to compute the first interval
|
|
158
|
+
this.populateDropdown();
|
|
159
|
+
// Now validate with the computed first interval
|
|
160
|
+
this.isInvalid.set(!this.checkTimeValidity(this.chosenTime().trim()));
|
|
161
|
+
let chosenTimedayjs = this.getdayjs(this.chosenTime());
|
|
162
|
+
// Defer emission to avoid ExpressionChangedAfterItHasBeenCheckedError
|
|
163
|
+
setTimeout(() => {
|
|
122
164
|
this.emitTime({
|
|
123
|
-
valid: !this.isInvalid,
|
|
124
|
-
time: this.chosenTime,
|
|
165
|
+
valid: !this.isInvalid(),
|
|
166
|
+
time: this.chosenTime(),
|
|
125
167
|
epoch: chosenTimedayjs.valueOf()
|
|
126
168
|
});
|
|
127
|
-
|
|
128
|
-
|
|
169
|
+
}, 0);
|
|
170
|
+
// Calculate closest interval
|
|
171
|
+
this.calculateClosestInterval(this.chosenTime());
|
|
172
|
+
this._isInitializing = false;
|
|
173
|
+
}
|
|
174
|
+
else if (this.givenTime()) {
|
|
175
|
+
// When givenTime is present, use the given time as the initial value
|
|
176
|
+
// but the dropdown will start from 12:00 AM
|
|
177
|
+
this.chosenTime.set(dayjs.tz(this.givenTime(), this.timezone()).format(this.timeFormat));
|
|
178
|
+
this.userInputFlag.set(false);
|
|
179
|
+
// Populate dropdown first to compute the first interval
|
|
180
|
+
this.populateDropdown();
|
|
181
|
+
// Now validate with the computed first interval
|
|
182
|
+
this.isInvalid.set(!this.checkTimeValidity(this.chosenTime().trim()));
|
|
183
|
+
let chosenTimedayjs = this.getdayjs(this.chosenTime());
|
|
184
|
+
// Defer emission to avoid ExpressionChangedAfterItHasBeenCheckedError
|
|
185
|
+
setTimeout(() => {
|
|
186
|
+
this.emitTime({
|
|
187
|
+
valid: !this.isInvalid(),
|
|
188
|
+
time: this.chosenTime(),
|
|
189
|
+
epoch: chosenTimedayjs.valueOf()
|
|
190
|
+
});
|
|
191
|
+
}, 0);
|
|
192
|
+
// Calculate closest interval
|
|
193
|
+
this.calculateClosestInterval(this.chosenTime());
|
|
194
|
+
this._isInitializing = false;
|
|
195
|
+
}
|
|
196
|
+
else if (this.minTime()) {
|
|
197
|
+
// Use min time directly - this matches original behavior
|
|
198
|
+
this.chosenTime.set(dayjs.tz(this.minTime(), this.timezone()).format(this.timeFormat));
|
|
199
|
+
this.userInputFlag.set(false);
|
|
200
|
+
// Populate dropdown first to compute the first interval
|
|
201
|
+
this.populateDropdown();
|
|
202
|
+
// For minTime, validation should only check format, not time comparison
|
|
203
|
+
// This matches the original logic where minTime bypasses time validation
|
|
204
|
+
this.isInvalid.set(!this.checkTimeValidity(this.chosenTime().trim()));
|
|
205
|
+
let chosenTimedayjs = this.getdayjs(this.chosenTime());
|
|
206
|
+
// Defer emission to avoid ExpressionChangedAfterItHasBeenCheckedError
|
|
207
|
+
setTimeout(() => {
|
|
208
|
+
this.emitTime({
|
|
209
|
+
valid: !this.isInvalid(),
|
|
210
|
+
time: this.chosenTime(),
|
|
211
|
+
epoch: chosenTimedayjs.valueOf()
|
|
212
|
+
});
|
|
213
|
+
}, 0);
|
|
214
|
+
// Calculate closest interval
|
|
215
|
+
this.calculateClosestInterval(this.chosenTime());
|
|
216
|
+
this._isInitializing = false;
|
|
129
217
|
}
|
|
130
218
|
}
|
|
131
219
|
emitTime(data) {
|
|
@@ -133,13 +221,12 @@ export class TimePickerComponent {
|
|
|
133
221
|
}
|
|
134
222
|
// function to get dayjs object when time is given in string
|
|
135
223
|
getdayjs(time = '00:00') {
|
|
136
|
-
;
|
|
137
224
|
if (!time || typeof time !== 'string') {
|
|
138
225
|
throw new Error('Time must be a string');
|
|
139
226
|
}
|
|
140
227
|
let hours;
|
|
141
228
|
let minutes;
|
|
142
|
-
if (this.clockFormat === 24) {
|
|
229
|
+
if (this.clockFormat() === 24) {
|
|
143
230
|
hours = parseInt(time.split(':')[0]);
|
|
144
231
|
minutes = parseInt(time.split(':')[1]);
|
|
145
232
|
}
|
|
@@ -155,70 +242,88 @@ export class TimePickerComponent {
|
|
|
155
242
|
hours = 0;
|
|
156
243
|
}
|
|
157
244
|
}
|
|
158
|
-
|
|
245
|
+
// Use the date from dateAsEpoch but set the time to the parsed hours and minutes
|
|
246
|
+
const baseDate = dayjs.tz(this.dateAsEpoch(), this.timezone());
|
|
247
|
+
const result = baseDate.hour(hours).minute(minutes).second(0).millisecond(0);
|
|
248
|
+
return result;
|
|
159
249
|
}
|
|
160
250
|
closeDropdown() {
|
|
161
251
|
this.dispayToolTip = false;
|
|
162
|
-
this.userInputFlag
|
|
163
|
-
this.openStatus
|
|
252
|
+
this.userInputFlag.set(false);
|
|
253
|
+
this.openStatus.set(false);
|
|
164
254
|
if (this.timepickerDirective)
|
|
165
255
|
this.timepickerDirective.destroyOverlay();
|
|
166
256
|
}
|
|
167
257
|
// toggle timepicker dropdown
|
|
168
258
|
openDropdown() {
|
|
169
259
|
this.dispayToolTip = true;
|
|
170
|
-
this.openStatus
|
|
260
|
+
this.openStatus.set(true);
|
|
171
261
|
}
|
|
172
262
|
checkTimeValidity(time) {
|
|
173
263
|
const RE12 = /^(([0][1-9]|1[0-2]):([0-5][0-9])( )?(am|pm|AM|PM))$/i;
|
|
174
264
|
const RE24 = /^([01][0-9]|2[0-3]):[0-5][0-9]$/;
|
|
175
|
-
const RE = this.clockFormat === 12 ? RE12 : RE24;
|
|
265
|
+
const RE = this.clockFormat() === 12 ? RE12 : RE24;
|
|
266
|
+
// Check if the time format is valid first
|
|
267
|
+
if (!time.match(RE)) {
|
|
268
|
+
return false;
|
|
269
|
+
}
|
|
270
|
+
// Restore proper validation logic
|
|
176
271
|
const timedayjs = this.getdayjs(time);
|
|
177
272
|
let flag = false;
|
|
178
|
-
//
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
|
|
182
|
-
|
|
183
|
-
|
|
184
|
-
dayjs.tz(this.firstInterval, this.timezone).format(this.timeFormat).valueOf() === dayjs.tz(dayjs(), this.timezone).startOf("day").format(this.timeFormat).valueOf())) {
|
|
273
|
+
// Original logic: if minTime, givenTime, or firstInterval is start of day, only check format
|
|
274
|
+
if (this.minTime() ||
|
|
275
|
+
this.givenTime() ||
|
|
276
|
+
(this.firstInterval() &&
|
|
277
|
+
dayjs.tz(this.firstInterval(), this.timezone()).format(this.timeFormat).valueOf() === dayjs.tz(dayjs(), this.timezone()).startOf("day").format(this.timeFormat).valueOf())) {
|
|
278
|
+
// Only check format validation, not time comparison
|
|
185
279
|
flag = time.match(RE) ? true : false;
|
|
186
280
|
}
|
|
187
281
|
else {
|
|
188
|
-
|
|
282
|
+
// Check against current time for normal cases
|
|
283
|
+
const currentTime = dayjs.tz(dayjs(), this.timezone());
|
|
284
|
+
const timeDiff = timedayjs.diff(currentTime, "m");
|
|
285
|
+
flag = timeDiff >= 0;
|
|
189
286
|
}
|
|
190
287
|
return flag;
|
|
191
288
|
}
|
|
192
289
|
// update chosen time as soon as the user clicks on an interval
|
|
193
290
|
onTimeSelect(time) {
|
|
194
|
-
this.isInvalid
|
|
195
|
-
if (!this.isInvalid) {
|
|
196
|
-
this.chosenTime
|
|
197
|
-
this.calculateClosestInterval(this.chosenTime);
|
|
291
|
+
this.isInvalid.set(!this.checkTimeValidity(time.trim()));
|
|
292
|
+
if (!this.isInvalid()) {
|
|
293
|
+
this.chosenTime.set(time);
|
|
294
|
+
this.calculateClosestInterval(this.chosenTime());
|
|
198
295
|
}
|
|
199
296
|
const timedayjs = this.getdayjs(time);
|
|
200
297
|
this.emitTime({
|
|
201
|
-
valid: !this.isInvalid,
|
|
298
|
+
valid: !this.isInvalid(),
|
|
202
299
|
time: time,
|
|
203
300
|
epoch: timedayjs.valueOf()
|
|
204
301
|
});
|
|
205
|
-
this.openStatus
|
|
302
|
+
this.openStatus.set(false);
|
|
206
303
|
if (this.timepickerDirective)
|
|
207
304
|
this.timepickerDirective.destroyOverlay();
|
|
208
305
|
}
|
|
209
306
|
// checks validity of time on input change and calculates the closest interval
|
|
210
307
|
onTimeChange(time) {
|
|
211
|
-
|
|
212
|
-
|
|
213
|
-
|
|
214
|
-
|
|
308
|
+
// Set user input flag to prevent effects from overriding
|
|
309
|
+
this.userInputFlag.set(true);
|
|
310
|
+
// Update the chosenTime signal
|
|
311
|
+
this.chosenTime.set(time);
|
|
312
|
+
const isValid = this.checkTimeValidity(time.trim());
|
|
313
|
+
this.isInvalid.set(!isValid);
|
|
314
|
+
// Clear user input flag after a delay to allow effects to work again
|
|
315
|
+
setTimeout(() => {
|
|
316
|
+
this.userInputFlag.set(false);
|
|
317
|
+
}, 1000); // 1 second delay
|
|
318
|
+
if (!this.isInvalid()) {
|
|
319
|
+
this.openStatus.set(false);
|
|
215
320
|
if (this.timepickerDirective)
|
|
216
321
|
this.timepickerDirective.destroyOverlay();
|
|
217
322
|
this.calculateClosestInterval(time);
|
|
218
323
|
}
|
|
219
324
|
const timedayjs = this.getdayjs(time);
|
|
220
325
|
this.emitTime({
|
|
221
|
-
valid: !this.isInvalid,
|
|
326
|
+
valid: !this.isInvalid(),
|
|
222
327
|
time: time,
|
|
223
328
|
epoch: timedayjs.valueOf()
|
|
224
329
|
});
|
|
@@ -226,67 +331,79 @@ export class TimePickerComponent {
|
|
|
226
331
|
calculateClosestInterval(time) {
|
|
227
332
|
let roundedEpoch;
|
|
228
333
|
// Converting time and date to a dayjs object
|
|
229
|
-
const chosenDate = dayjs.tz(this.dateAsEpoch, this.timezone).format("DD-MM-YYYY"); // 05-01-2024
|
|
230
|
-
const parsedTimeWithDate = dayjs.tz(`${chosenDate} ${time}`, `DD-MM-YYYY ${this.timeFormat}`, this.timezone);
|
|
334
|
+
const chosenDate = dayjs.tz(this.dateAsEpoch(), this.timezone()).format("DD-MM-YYYY"); // 05-01-2024
|
|
335
|
+
const parsedTimeWithDate = dayjs.tz(`${chosenDate} ${time}`, `DD-MM-YYYY ${this.timeFormat}`, this.timezone());
|
|
231
336
|
// Converting dayjs object to epoch
|
|
232
337
|
const chosenTimeEpoch = parsedTimeWithDate.valueOf();
|
|
233
|
-
const offset = this.interval - (dayjs.tz(chosenTimeEpoch, this.timezone).minute() % this.interval);
|
|
234
|
-
if (this.minTime && !this.givenTime) {
|
|
235
|
-
this.isHighlighted
|
|
338
|
+
const offset = this.interval() - (dayjs.tz(chosenTimeEpoch, this.timezone()).minute() % this.interval());
|
|
339
|
+
if (this.minTime() && !this.givenTime()) {
|
|
340
|
+
this.isHighlighted.set(0);
|
|
236
341
|
return;
|
|
237
342
|
}
|
|
238
|
-
roundedEpoch = offset >= this.interval / 2 ? (dayjs.tz(chosenTimeEpoch, this.timezone).subtract(this.interval - offset, "m")).valueOf() : (dayjs.tz(chosenTimeEpoch, this.timezone).add(offset, "m")).valueOf();
|
|
343
|
+
roundedEpoch = offset >= this.interval() / 2 ? (dayjs.tz(chosenTimeEpoch, this.timezone()).subtract(this.interval() - offset, "m")).valueOf() : (dayjs.tz(chosenTimeEpoch, this.timezone()).add(offset, "m")).valueOf();
|
|
239
344
|
// finding the index of element that needs to be highlighted
|
|
240
|
-
if (chosenTimeEpoch > dayjs.tz(this.dateAsEpoch, this.timezone).endOf("day").subtract(this.interval, "m").valueOf()) {
|
|
241
|
-
this.isHighlighted
|
|
345
|
+
if (chosenTimeEpoch > dayjs.tz(this.dateAsEpoch(), this.timezone()).endOf("day").subtract(this.interval(), "m").valueOf()) {
|
|
346
|
+
this.isHighlighted.set(this.timeIntervals().length - 1);
|
|
242
347
|
}
|
|
243
348
|
else {
|
|
244
|
-
const roundedEpochdayjs = dayjs.tz(roundedEpoch, this.timezone);
|
|
245
|
-
this.isHighlighted
|
|
246
|
-
const intervalObj = dayjs.tz(`${chosenDate} ${interval}`, `DD-MM-YYYY ${this.timeFormat}`, this.timezone);
|
|
349
|
+
const roundedEpochdayjs = dayjs.tz(roundedEpoch, this.timezone());
|
|
350
|
+
this.isHighlighted.set(this.timeIntervals().findIndex(interval => {
|
|
351
|
+
const intervalObj = dayjs.tz(`${chosenDate} ${interval}`, `DD-MM-YYYY ${this.timeFormat}`, this.timezone());
|
|
247
352
|
return intervalObj.isSame(roundedEpochdayjs);
|
|
248
|
-
});
|
|
353
|
+
}));
|
|
249
354
|
}
|
|
250
355
|
}
|
|
251
356
|
// populates the dropdown according to the first interval received
|
|
252
357
|
populateDropdown() {
|
|
253
|
-
this.timeIntervals
|
|
358
|
+
this.timeIntervals.set([]);
|
|
359
|
+
// Compute the effective first interval
|
|
360
|
+
let effectiveFirstInterval = this.firstInterval();
|
|
254
361
|
// if picker is used as an individual component
|
|
255
|
-
if (!
|
|
362
|
+
if (!effectiveFirstInterval) {
|
|
256
363
|
// firstInterval is initialised according to the current time
|
|
257
364
|
// if the date is same as the current date
|
|
258
|
-
if (dayjs.tz(this.dateAsEpoch, this.timezone).format("DD-MM-YYYY") === dayjs.tz(dayjs(), this.timezone).format("DD-MM-YYYY") && !this.minTime) {
|
|
259
|
-
const offset = this.interval - (dayjs.tz(dayjs(), this.timezone).minute() % this.interval);
|
|
260
|
-
|
|
365
|
+
if (dayjs.tz(this.dateAsEpoch(), this.timezone()).format("DD-MM-YYYY") === dayjs.tz(dayjs(), this.timezone()).format("DD-MM-YYYY") && !this.minTime()) {
|
|
366
|
+
const offset = this.interval() - (dayjs.tz(dayjs(), this.timezone()).minute() % this.interval());
|
|
367
|
+
effectiveFirstInterval = dayjs.tz(dayjs(), this.timezone()).add(offset, "m").valueOf();
|
|
261
368
|
}
|
|
262
369
|
// if minimum time to show is provided
|
|
263
|
-
else if (this.minTime) {
|
|
264
|
-
const
|
|
265
|
-
|
|
370
|
+
else if (this.minTime()) {
|
|
371
|
+
const minTimeDayjs = dayjs.tz(this.minTime(), this.timezone());
|
|
372
|
+
const offset = this.interval() - (minTimeDayjs.minute() % this.interval());
|
|
373
|
+
effectiveFirstInterval = minTimeDayjs.add(offset, "m").valueOf();
|
|
266
374
|
}
|
|
267
375
|
// else the firstInterval is initialised as start of day
|
|
268
376
|
else {
|
|
269
|
-
|
|
377
|
+
effectiveFirstInterval = dayjs.tz(dayjs(), this.timezone()).startOf("day").valueOf();
|
|
270
378
|
}
|
|
271
379
|
}
|
|
272
|
-
if (this.givenTime
|
|
273
|
-
|
|
274
|
-
|
|
380
|
+
if (this.givenTime()) {
|
|
381
|
+
// When givenTime is present, always start from 12:00 AM (start of day)
|
|
382
|
+
// regardless of whether the time has passed or not
|
|
383
|
+
effectiveFirstInterval = dayjs.tz(this.dateAsEpoch(), this.timezone()).startOf('day').valueOf();
|
|
384
|
+
this.givenTimeFlag.set(false);
|
|
275
385
|
}
|
|
276
|
-
|
|
277
|
-
|
|
278
|
-
|
|
279
|
-
const
|
|
386
|
+
// Store the computed first interval for later use
|
|
387
|
+
this.computedFirstInterval = effectiveFirstInterval;
|
|
388
|
+
const dateAsString = dayjs.tz(this.dateAsEpoch(), this.timezone()).format('DD-MM-YYYY');
|
|
389
|
+
const intervalAsString = dayjs.tz(effectiveFirstInterval, this.timezone()).format(this.timeFormat);
|
|
390
|
+
let start = dayjs.tz(`${dateAsString} ${intervalAsString}`, `DD-MM-YYYY ${this.timeFormat}`, this.timezone());
|
|
391
|
+
const end = dayjs.tz(this.dateAsEpoch(), this.timezone()).endOf('d');
|
|
280
392
|
while (start.valueOf() < end.valueOf()) {
|
|
281
|
-
this.timeIntervals.
|
|
282
|
-
start = start.add(this.interval, "m");
|
|
393
|
+
this.timeIntervals.update(intervals => [...intervals, start.format(this.timeFormat)]);
|
|
394
|
+
start = start.add(this.interval(), "m");
|
|
283
395
|
}
|
|
284
|
-
//
|
|
285
|
-
// and the
|
|
286
|
-
|
|
287
|
-
|
|
288
|
-
|
|
289
|
-
|
|
396
|
+
// NEW: Handle end-of-day case - if firstInterval is at or very close to end of day
|
|
397
|
+
// and we're on the same date, show only 11:59 PM
|
|
398
|
+
const endOfDay = dayjs.tz(this.dateAsEpoch(), this.timezone()).endOf("d");
|
|
399
|
+
const firstIntervalDayjs = dayjs.tz(effectiveFirstInterval, this.timezone());
|
|
400
|
+
// Check if firstInterval is at or very close to end of day (within 1 minute)
|
|
401
|
+
const isAtEndOfDay = firstIntervalDayjs.isSame(endOfDay, 'day') &&
|
|
402
|
+
firstIntervalDayjs.diff(endOfDay, 'minute') >= -1;
|
|
403
|
+
if (isAtEndOfDay || this.timeIntervals().length === 0) {
|
|
404
|
+
// Clear existing intervals and add only 11:59 PM
|
|
405
|
+
this.timeIntervals.set([]);
|
|
406
|
+
this.timeIntervals.update(intervals => [...intervals, endOfDay.format(this.timeFormat)]);
|
|
290
407
|
}
|
|
291
408
|
}
|
|
292
409
|
ngOnDestroy() {
|
|
@@ -305,59 +422,27 @@ export class TimePickerComponent {
|
|
|
305
422
|
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.timepickerDirective = _t.first);
|
|
306
423
|
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.tooltipDirective = _t.first);
|
|
307
424
|
i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.timeIntervalRefs = _t);
|
|
308
|
-
} }, inputs: { clockFormat: "clockFormat", timezone: "timezone", height: "height", inputWidth: "inputWidth", dropdownWidth: "dropdownWidth", interval: "interval", dateAsEpoch: "dateAsEpoch", firstInterval: "firstInterval", rangeValidity: "rangeValidity", showTooltip: "showTooltip", givenTime: "givenTime", minTime: "minTime", triggerChange: "triggerChange", disable: "disable" }, outputs: { timeEmitter: "timeEmitter" },
|
|
425
|
+
} }, inputs: { clockFormat: [1, "clockFormat"], timezone: [1, "timezone"], height: [1, "height"], inputWidth: [1, "inputWidth"], dropdownWidth: [1, "dropdownWidth"], interval: [1, "interval"], dateAsEpoch: [1, "dateAsEpoch"], firstInterval: [1, "firstInterval"], rangeValidity: [1, "rangeValidity"], showTooltip: [1, "showTooltip"], givenTime: [1, "givenTime"], minTime: [1, "minTime"], triggerChange: [1, "triggerChange"], disable: [1, "disable"] }, outputs: { timeEmitter: "timeEmitter" }, decls: 5, vars: 19, consts: [["input", ""], ["dropdownContainer", ""], ["dropdown", ""], ["timeInterval", ""], [1, "timepicker-container", 3, "ngStyle", "ngClass"], ["type", "text", "misToolTip", "", "cdkOverlayOrigin", "", 1, "h7", 3, "ngModelChange", "click", "ngModel", "ngClass", "ngStyle", "showToolTip", "text", "position", "showOnHover"], ["libTimepicker", "", 3, "statusEmitter", "originEl", "openStatus"], ["class", "timepicker-dropdown", 3, "ngStyle", 4, "ngIf"], [1, "timepicker-dropdown", 3, "ngStyle"], [3, "ngClass", "click", 4, "ngFor", "ngForOf"], [3, "click", "ngClass"], ["class", "ic-ui-check-24 selected-icon", 4, "ngIf"], [1, "ic-ui-check-24", "selected-icon"]], template: function TimePickerComponent_Template(rf, ctx) { if (rf & 1) {
|
|
309
426
|
const _r1 = i0.ɵɵgetCurrentView();
|
|
310
427
|
i0.ɵɵelementStart(0, "div", 4)(1, "input", 5, 0);
|
|
311
|
-
i0.ɵɵ
|
|
312
|
-
i0.ɵɵlistener("ngModelChange", function TimePickerComponent_Template_input_ngModelChange_1_listener() { i0.ɵɵrestoreView(_r1); return i0.ɵɵresetView(ctx.onTimeChange(ctx.chosenTime)); })("click", function TimePickerComponent_Template_input_click_1_listener() { i0.ɵɵrestoreView(_r1); return i0.ɵɵresetView(ctx.openDropdown()); });
|
|
428
|
+
i0.ɵɵlistener("ngModelChange", function TimePickerComponent_Template_input_ngModelChange_1_listener($event) { i0.ɵɵrestoreView(_r1); return i0.ɵɵresetView(ctx.onTimeChange($event)); })("click", function TimePickerComponent_Template_input_click_1_listener() { i0.ɵɵrestoreView(_r1); return i0.ɵɵresetView(ctx.openDropdown()); });
|
|
313
429
|
i0.ɵɵelementEnd();
|
|
314
430
|
i0.ɵɵtemplate(3, TimePickerComponent_ng_template_3_Template, 1, 1, "ng-template", 6, 1, i0.ɵɵtemplateRefExtractor);
|
|
315
431
|
i0.ɵɵlistener("statusEmitter", function TimePickerComponent_Template_ng_template_statusEmitter_3_listener() { i0.ɵɵrestoreView(_r1); return i0.ɵɵresetView(ctx.closeDropdown()); });
|
|
316
432
|
i0.ɵɵelementEnd();
|
|
317
433
|
} if (rf & 2) {
|
|
318
434
|
const input_r6 = i0.ɵɵreference(2);
|
|
319
|
-
i0.ɵɵproperty("ngStyle", i0.ɵɵpureFunction1(11, _c2, ctx.height))("ngClass", i0.ɵɵpureFunction1(13, _c3, ctx.disable));
|
|
435
|
+
i0.ɵɵproperty("ngStyle", i0.ɵɵpureFunction1(11, _c2, ctx.height()))("ngClass", i0.ɵɵpureFunction1(13, _c3, ctx.disable()));
|
|
320
436
|
i0.ɵɵadvance();
|
|
321
|
-
i0.ɵɵ
|
|
322
|
-
i0.ɵɵproperty("ngClass", i0.ɵɵpureFunction1(15, _c4, ctx.isInvalid || !ctx.rangeValidity))("ngStyle", i0.ɵɵpureFunction1(17, _c5, ctx.inputWidth))("showToolTip", ctx.showTooltip && (ctx.isInvalid || !ctx.rangeValidity) && ctx.dispayToolTip)("text", "Invalid Time")("position", "top")("showOnHover", false);
|
|
437
|
+
i0.ɵɵproperty("ngModel", ctx.chosenTime())("ngClass", i0.ɵɵpureFunction1(15, _c4, ctx.isInvalid() || !ctx.rangeValidity()))("ngStyle", i0.ɵɵpureFunction1(17, _c5, ctx.inputWidth()))("showToolTip", ctx.showTooltip() && (ctx.isInvalid() || !ctx.rangeValidity()) && ctx.dispayToolTip)("text", "Invalid Time")("position", "top")("showOnHover", false);
|
|
323
438
|
i0.ɵɵadvance(2);
|
|
324
|
-
i0.ɵɵproperty("originEl", input_r6)("openStatus", ctx.openStatus);
|
|
439
|
+
i0.ɵɵproperty("originEl", input_r6)("openStatus", ctx.openStatus());
|
|
325
440
|
} }, dependencies: [i1.NgClass, i1.NgForOf, i1.NgIf, i1.NgStyle, i2.DefaultValueAccessor, i2.NgControlStatus, i2.NgModel, i3.ToolTipDirective, i4.CdkOverlayOrigin, i5.TimepickerDirective], styles: [".h1[_ngcontent-%COMP%]{font-size:40px;font-weight:400;letter-spacing:0px;line-height:48px}.h2[_ngcontent-%COMP%]{font-size:32px;font-weight:400;letter-spacing:0px;line-height:40px}.h3[_ngcontent-%COMP%]{font-size:28px;font-weight:400;letter-spacing:0px;line-height:36px}.h4[_ngcontent-%COMP%]{font-size:24px;font-weight:400;letter-spacing:0px;line-height:32px}.h5-b[_ngcontent-%COMP%]{font-size:20px;font-weight:700;letter-spacing:.25px;line-height:28px}.h5[_ngcontent-%COMP%]{font-size:20px;font-weight:400;letter-spacing:.15px;line-height:28px}.h6-b[_ngcontent-%COMP%]{font-size:16px;font-weight:700;letter-spacing:0px;line-height:24px}.h6[_ngcontent-%COMP%]{font-size:16px;font-weight:400;letter-spacing:0px;line-height:24px}.p[_ngcontent-%COMP%]{font-size:16px;font-weight:400;letter-spacing:0px;line-height:180%}.h7-b[_ngcontent-%COMP%]{font-size:14px;font-weight:700;letter-spacing:.25px;line-height:20px}.h7[_ngcontent-%COMP%]{font-size:14px;font-weight:400;letter-spacing:.2px;line-height:20px}.h8-b[_ngcontent-%COMP%]{font-size:12px;font-weight:700;letter-spacing:.25px;line-height:18px}.h8[_ngcontent-%COMP%]{font-size:12px;font-weight:400;letter-spacing:.2px;line-height:18px}.h9[_ngcontent-%COMP%]{font-size:10px;font-weight:400;letter-spacing:0px;line-height:15px}.btn-lg-b[_ngcontent-%COMP%]{font-size:16px;font-weight:700;letter-spacing:.5px;line-height:24px}.btn-lg[_ngcontent-%COMP%]{font-size:16px;font-weight:400;letter-spacing:.2px;line-height:24px}.btn-sm[_ngcontent-%COMP%]{font-size:14px;font-weight:400;letter-spacing:.25px;line-height:20px}.btn-link[_ngcontent-%COMP%]{font-size:16px;font-weight:400;letter-spacing:0px;line-height:24px}.display-1[_ngcontent-%COMP%]{font-size:48px;font-weight:400;letter-spacing:0px;line-height:56px}.display-2[_ngcontent-%COMP%]{font-size:14px;font-weight:400;letter-spacing:.5px;line-height:20px}*[_ngcontent-%COMP%]{box-sizing:border-box;font-family:Lato}.timepicker-container[_ngcontent-%COMP%]{display:inline-block;position:relative}input[_ngcontent-%COMP%]{text-align:center;border:none;border-bottom:1px solid #e0e0e0;outline:none;height:100%;width:100px;padding:4px 16px}input[_ngcontent-%COMP%]:hover{background:#f5f7fc}input[_ngcontent-%COMP%]:focus, input[_ngcontent-%COMP%]:active{background:#e6ebf7;border-bottom:1px solid #0937b2}.timepicker-dropdown[_ngcontent-%COMP%]{position:absolute;top:calc(100% + 4px);left:0;max-height:200px;overflow-y:auto;border:1px solid #e0e0e0;box-shadow:0 12px 24px #0000001f,0 4px 8px #0000001f;border-radius:4px;padding:8px;background:#fff}.timepicker-dropdown[_ngcontent-%COMP%]::-webkit-scrollbar{display:none}.timepicker-dropdown[_ngcontent-%COMP%] ul[_ngcontent-%COMP%]{margin:0;padding:0}.timepicker-dropdown[_ngcontent-%COMP%] li[_ngcontent-%COMP%]{text-align:start;list-style:none;padding:6px 12px;cursor:pointer;font-size:14px;color:#181f33;display:flex;justify-content:space-between;align-items:center}.timepicker-dropdown[_ngcontent-%COMP%] li[_ngcontent-%COMP%]:hover{background:#f5f7fc;border-radius:6px}.timepicker-dropdown[_ngcontent-%COMP%] li[_ngcontent-%COMP%] .selected-icon[_ngcontent-%COMP%]{font-weight:900}.highlight[_ngcontent-%COMP%]{background-color:#f5f7fc;border-radius:6px}.invalid[_ngcontent-%COMP%]{background:#fae1ea!important;border-bottom:1px solid #b00020!important}.disable[_ngcontent-%COMP%]{pointer-events:none!important;opacity:.5!important}"] }); }
|
|
326
441
|
}
|
|
327
442
|
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(TimePickerComponent, [{
|
|
328
443
|
type: Component,
|
|
329
|
-
args: [{ selector: "mis-timepicker", template: "<div class=\"timepicker-container\" [ngStyle]=\"{ height: height }\" [ngClass]=\"{'disable': disable}\">\n <input\n type=\"text\"\n [
|
|
330
|
-
}], () => [], {
|
|
331
|
-
type: Input
|
|
332
|
-
}], timezone: [{
|
|
333
|
-
type: Input
|
|
334
|
-
}], height: [{
|
|
335
|
-
type: Input
|
|
336
|
-
}], inputWidth: [{
|
|
337
|
-
type: Input
|
|
338
|
-
}], dropdownWidth: [{
|
|
339
|
-
type: Input
|
|
340
|
-
}], interval: [{
|
|
341
|
-
type: Input
|
|
342
|
-
}], dateAsEpoch: [{
|
|
343
|
-
type: Input
|
|
344
|
-
}], firstInterval: [{
|
|
345
|
-
type: Input
|
|
346
|
-
}], rangeValidity: [{
|
|
347
|
-
type: Input
|
|
348
|
-
}], showTooltip: [{
|
|
349
|
-
type: Input
|
|
350
|
-
}], givenTime: [{
|
|
351
|
-
type: Input
|
|
352
|
-
}], minTime: [{
|
|
353
|
-
type: Input
|
|
354
|
-
}], triggerChange: [{
|
|
355
|
-
type: Input
|
|
356
|
-
}], disable: [{
|
|
357
|
-
type: Input
|
|
358
|
-
}], timeEmitter: [{
|
|
359
|
-
type: Output
|
|
360
|
-
}], input: [{
|
|
444
|
+
args: [{ selector: "mis-timepicker", template: "<div class=\"timepicker-container\" [ngStyle]=\"{ height: height() }\" [ngClass]=\"{'disable': disable()}\">\n <input\n type=\"text\"\n [ngModel]=\"chosenTime()\"\n (ngModelChange)=\"onTimeChange($event)\"\n [ngClass]=\"{ invalid: isInvalid() || !rangeValidity() }\"\n [ngStyle]=\"{ width: inputWidth() }\"\n (click)=\"openDropdown()\"\n misToolTip\n [showToolTip]=\"showTooltip() && (isInvalid() || !rangeValidity()) && dispayToolTip\"\n [text]=\"'Invalid Time'\"\n [position]=\"'top'\"\n [showOnHover]=\"false\"\n #input\n cdkOverlayOrigin\n class=\"h7\"\n />\n\n <ng-template #dropdownContainer libTimepicker [originEl]=\"input\" [openStatus]=\"openStatus()\" (statusEmitter)=\"closeDropdown()\">\n <div *ngIf=\"openStatus()\" class=\"timepicker-dropdown\" [ngStyle]=\"{ width: dropdownWidth() || inputWidth() }\">\n <ul #dropdown>\n <li #timeInterval (click)=\"onTimeSelect(interval)\" *ngFor=\"let interval of timeIntervals(); index as i\" [ngClass]=\"{ highlight: i === isHighlighted() }\">\n {{ interval }}\n <div class=\"ic-ui-check-24 selected-icon\" *ngIf=\"interval === chosenTime()\"></div>\n </li>\n </ul>\n </div>\n </ng-template>\n</div>\n", styles: [".h1{font-size:40px;font-weight:400;letter-spacing:0px;line-height:48px}.h2{font-size:32px;font-weight:400;letter-spacing:0px;line-height:40px}.h3{font-size:28px;font-weight:400;letter-spacing:0px;line-height:36px}.h4{font-size:24px;font-weight:400;letter-spacing:0px;line-height:32px}.h5-b{font-size:20px;font-weight:700;letter-spacing:.25px;line-height:28px}.h5{font-size:20px;font-weight:400;letter-spacing:.15px;line-height:28px}.h6-b{font-size:16px;font-weight:700;letter-spacing:0px;line-height:24px}.h6{font-size:16px;font-weight:400;letter-spacing:0px;line-height:24px}.p{font-size:16px;font-weight:400;letter-spacing:0px;line-height:180%}.h7-b{font-size:14px;font-weight:700;letter-spacing:.25px;line-height:20px}.h7{font-size:14px;font-weight:400;letter-spacing:.2px;line-height:20px}.h8-b{font-size:12px;font-weight:700;letter-spacing:.25px;line-height:18px}.h8{font-size:12px;font-weight:400;letter-spacing:.2px;line-height:18px}.h9{font-size:10px;font-weight:400;letter-spacing:0px;line-height:15px}.btn-lg-b{font-size:16px;font-weight:700;letter-spacing:.5px;line-height:24px}.btn-lg{font-size:16px;font-weight:400;letter-spacing:.2px;line-height:24px}.btn-sm{font-size:14px;font-weight:400;letter-spacing:.25px;line-height:20px}.btn-link{font-size:16px;font-weight:400;letter-spacing:0px;line-height:24px}.display-1{font-size:48px;font-weight:400;letter-spacing:0px;line-height:56px}.display-2{font-size:14px;font-weight:400;letter-spacing:.5px;line-height:20px}*{box-sizing:border-box;font-family:Lato}.timepicker-container{display:inline-block;position:relative}input{text-align:center;border:none;border-bottom:1px solid #e0e0e0;outline:none;height:100%;width:100px;padding:4px 16px}input:hover{background:#f5f7fc}input:focus,input:active{background:#e6ebf7;border-bottom:1px solid #0937b2}.timepicker-dropdown{position:absolute;top:calc(100% + 4px);left:0;max-height:200px;overflow-y:auto;border:1px solid #e0e0e0;box-shadow:0 12px 24px #0000001f,0 4px 8px #0000001f;border-radius:4px;padding:8px;background:#fff}.timepicker-dropdown::-webkit-scrollbar{display:none}.timepicker-dropdown ul{margin:0;padding:0}.timepicker-dropdown li{text-align:start;list-style:none;padding:6px 12px;cursor:pointer;font-size:14px;color:#181f33;display:flex;justify-content:space-between;align-items:center}.timepicker-dropdown li:hover{background:#f5f7fc;border-radius:6px}.timepicker-dropdown li .selected-icon{font-weight:900}.highlight{background-color:#f5f7fc;border-radius:6px}.invalid{background:#fae1ea!important;border-bottom:1px solid #b00020!important}.disable{pointer-events:none!important;opacity:.5!important}\n"] }]
|
|
445
|
+
}], () => [], { input: [{
|
|
361
446
|
type: ViewChild,
|
|
362
447
|
args: ["input", { static: true }]
|
|
363
448
|
}], timepickerDirective: [{
|
|
@@ -371,4 +456,4 @@ export class TimePickerComponent {
|
|
|
371
456
|
args: ["timeInterval"]
|
|
372
457
|
}] }); })();
|
|
373
458
|
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(TimePickerComponent, { className: "TimePickerComponent" }); })();
|
|
374
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"timepicker.component.js","sourceRoot":"","sources":["../../../../projects/mis-components/timepicker/timepicker.component.ts","../../../../projects/mis-components/timepicker/timepicker.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAc,YAAY,EAAE,KAAK,EAAgC,MAAM,EAAE,SAAS,EAAE,YAAY,EAAE,MAAM,eAAe,CAAC;AAE1I,OAAO,EAAE,mBAAmB,EAAE,MAAM,wBAAwB,CAAC;AAC7D,OAAO,EAAE,gBAAgB,EAAE,MAAM,mCAAmC,CAAC;AAErE,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,QAAQ,MAAM,uBAAuB,CAAC;AAC7C,OAAO,GAAG,MAAM,kBAAkB,CAAC;AACnC,OAAO,iBAAiB,MAAM,gCAAgC,CAAA;;;;;;;;;;;;;;;ICepD,0BAAgF;;;;IAFlF,iCAAqJ;IAAnI,6NAAS,gCAAsB,KAAC;IAChD,YACA;IAAA,8FAA0E;IAC5E,iBAAK;;;;;IAHiG,mFAA8C;IAClJ,eACA;IADA,4CACA;IAA2C,cAA6B;IAA7B,wDAA6B;;;IAH5E,AADF,8BAAuG,kBACvF;IACZ,sFAAqJ;IAKzJ,AADE,iBAAK,EACD;;;IAP8C,+FAAkD;IAE1B,eAAkB;IAAlB,8CAAkB;;;IAF9F,kFAAuG;;;IAAjG,wCAAgB;;ADT1B,KAAK,CAAC,MAAM,CAAC,GAAG,CAAC,CAAC;AAClB,KAAK,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAC;AACvB,KAAK,CAAC,MAAM,CAAC,iBAAiB,CAAC,CAAC;AAQhC,MAAM,OAAO,mBAAmB;IAgC9B,oFAAoF;IACpF,IAAkC,gBAAgB,CAAC,SAAS;QAC1D,SAAS,CAAC,OAAO,CAAC,QAAQ,CAAC,EAAE;YAC3B,IAAI,QAAQ,CAAC,aAAa,CAAC,SAAS,CAAC,CAAC,CAAC,KAAK,WAAW,EAAE,CAAC;gBACxD,MAAM,WAAW,GAAG,QAAQ,CAAC,aAAa,CAAC;gBAC3C,UAAU,CAAC,GAAG,EAAE,CAAC,WAAW,CAAC,cAAc,CAAC,EAAE,KAAK,EAAE,QAAQ,EAAE,CAAC,CAAC,CAAC;YACpE,CAAC;QACH,CAAC,CAAC,CAAC;IACL,CAAC;IAED;QAvCA,eAAU,GAAY,KAAK,CAAC;QAC5B,kBAAa,GAAW,CAAC,CAAC;QAC1B,cAAS,GAAY,KAAK,CAAC;QAC3B,kBAAa,GAAa,EAAE,CAAC;QAC7B,iBAAY,GAAY,KAAK,CAAC;QAC9B,kBAAa,GAAY,KAAK,CAAC;QAC/B,kBAAa,GAAY,IAAI,CAAC;QACrB,gBAAW,GAAW,EAAE,CAAC;QAGzB,aAAQ,GAAW,cAAc,CAAC;QAClC,WAAM,GAAW,aAAa,CAAC;QAC/B,eAAU,GAAW,OAAO,CAAC;QAE7B,aAAQ,GAAW,EAAE,CAAC;QACtB,gBAAW,GAAW,KAAK,CAAC,EAAE,CAAC,KAAK,EAAE,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC,OAAO,EAAE,CAAC;QAEjE,kBAAa,GAAY,IAAI,CAAC;QAC9B,gBAAW,GAAY,IAAI,CAAC;QACrC,kBAAa,GAAY,IAAI,CAAC,WAAW,CAAC;QAGjC,kBAAa,GAAY,IAAI,CAAC;QAC9B,YAAO,GAAY,KAAK,CAAC;QACxB,gBAAW,GAAG,IAAI,YAAY,EAAS,CAAC;IAepC,CAAC;IACf,QAAQ;QACN,IAAG,CAAC,IAAI,CAAC,SAAS,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC;YACpC,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC,EAAE,CAAC,IAAI,CAAC,aAAa,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;YACtF,IAAI,eAAe,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;YACrD,IAAI,CAAC,QAAQ,CAAC;gBACZ,KAAK,EAAE,CAAC,IAAI,CAAC,SAAS;gBACtB,IAAI,EAAE,IAAI,CAAC,UAAU;gBACrB,KAAK,EAAE,eAAe,CAAC,OAAO,EAAE;aACjC,CAAC,CAAC;QACL,CAAC;IACH,CAAC;IAED,WAAW;QACT,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,WAAW,KAAK,EAAE,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,OAAO,CAAC;QAEhE,IAAI,IAAI,CAAC,UAAU,EAAE,CAAC;YACpB,IAAI,eAAe,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;YAErD,8CAA8C;YAC9C,4CAA4C;YAC5C,2BAA2B;YAC3B,IAAI,IAAI,CAAC,aAAa,IAAI,eAAe,CAAC,OAAO,EAAE,IAAI,IAAI,CAAC,aAAa,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE,CAAC;gBACjG,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC,EAAE,CAAC,IAAI,CAAC,aAAa,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;gBACtF,eAAe,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,UAAU,CAAC,CAAA;YAClD,CAAC;YAED,IAAG,CAAC,IAAI,CAAC,aAAa,IAAI,IAAI,CAAC,SAAS,CAAC,IAAI,IAAI,CAAC,OAAO,EAAG,CAAC;gBAC3D,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC,EAAE,CAAC,IAAI,CAAC,OAAO,IAAI,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;YACpG,CAAC;YACD,eAAe,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,UAAU,CAAC,CAAA;YAEhD,IAAI,CAAC,IAAI,CAAC,aAAa;gBAAE,IAAI,CAAC,gBAAgB,EAAE,CAAC;YACjD,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC;YAE3B,IAAG,IAAI,CAAC,UAAU,EAAE,CAAC;gBACnB,IAAI,CAAC,SAAS,GAAG,CAAC,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,UAAU,CAAC,IAAI,EAAE,CAAC,CAAC;gBACjE,IAAI,CAAC,QAAQ,CAAC;oBACZ,KAAK,EAAE,CAAC,IAAI,CAAC,SAAS;oBACtB,IAAI,EAAE,IAAI,CAAC,UAAU;oBACrB,KAAK,EAAE,eAAe,CAAC,OAAO,EAAE;iBACjC,CAAC,CAAC;gBACH,IAAI,CAAC,wBAAwB,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;YACjD,CAAC;QACH,CAAC;IACH,CAAC;IAED,QAAQ,CAAC,IAAW;QAClB,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;IAC9B,CAAC;IAED,4DAA4D;IAC5D,QAAQ,CAAC,OAAe,OAAO;QAAE,CAAC;QAChC,IAAG,CAAC,IAAI,IAAI,OAAO,IAAI,KAAK,QAAQ,EAAE,CAAC;YACrC,MAAM,IAAI,KAAK,CAAC,uBAAuB,CAAC,CAAC;QAC3C,CAAC;QAED,IAAI,KAAa,CAAC;QAClB,IAAI,OAAe,CAAC;QAEpB,IAAG,IAAI,CAAC,WAAW,KAAK,EAAE,EAAE,CAAC;YAC3B,KAAK,GAAG,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;YACrC,OAAO,GAAG,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QACzC,CAAC;aAAM,CAAC;YACN,MAAM,SAAS,GAAG,IAAI,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;YAClC,MAAM,KAAK,GAAG,SAAS,EAAE,CAAC,CAAC,CAAC,CAAC;YAC7B,KAAK,GAAI,QAAQ,CAAC,SAAS,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;YACnD,OAAO,GAAG,QAAQ,CAAC,SAAS,EAAE,CAAC,CAAC,CAAC,EAAE,KAAK,CAAC,GAAG,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;YAEpD,IAAG,KAAK,EAAE,WAAW,EAAE,KAAK,IAAI,IAAI,KAAK,KAAK,EAAE,EAAE,CAAC;gBACjD,KAAK,IAAI,EAAE,CAAC;YACd,CAAC;iBAAM,IAAG,KAAK,EAAE,WAAW,EAAE,KAAK,IAAI,IAAI,KAAK,KAAK,EAAE,EAAE,CAAC;gBACxD,KAAK,GAAG,CAAC,CAAC;YACZ,CAAC;QACH,CAAC;QAED,OAAO,KAAK,CAAC,EAAE,CAAC,IAAI,CAAC,WAAW,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC,GAAG,CAAC,KAAK,EAAE,GAAG,CAAC,CAAC,GAAG,CAAC,OAAO,EAAE,GAAG,CAAC,CAAC;IACrF,CAAC;IAED,aAAa;QACX,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC;QAC3B,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC;QAC3B,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;QACxB,IAAI,IAAI,CAAC,mBAAmB;YAAE,IAAI,CAAC,mBAAmB,CAAC,cAAc,EAAE,CAAC;IAC1E,CAAC;IAED,6BAA6B;IAC7B,YAAY;QACV,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC;QAC1B,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;IACzB,CAAC;IAED,iBAAiB,CAAC,IAAY;QAC5B,MAAM,IAAI,GAAG,sDAAsD,CAAC;QACpE,MAAM,IAAI,GAAG,iCAAiC,CAAC;QAC/C,MAAM,EAAE,GAAG,IAAI,CAAC,WAAW,KAAK,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC;QAEjD,MAAM,SAAS,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;QACtC,IAAI,IAAI,GAAY,KAAK,CAAC;QAE1B,uDAAuD;QACvD,yDAAyD;QACzD,4DAA4D;QAC5D,IACE,IAAI,CAAC,OAAO;YACZ,IAAI,CAAC,SAAS;YACd,CAAC,IAAI,CAAC,aAAa;gBACnB,KAAK,CAAC,EAAE,CAAC,IAAI,CAAC,aAAa,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,OAAO,EAAE,KAAK,KAAK,CAAC,EAAE,CAAC,KAAK,EAAE,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,OAAO,EAAE,CAAC,EACpK,CAAC;YACD,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,CAAC;QACvC,CAAC;aAAM,CAAC;YACN,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,IAAI,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,KAAK,EAAE,EAAE,IAAI,CAAC,QAAQ,CAAC,EAAE,GAAG,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,IAAI,CAAA,CAAC,CAAC,KAAK,CAAC;QACpG,CAAC;QAED,OAAO,IAAI,CAAC;IACd,CAAC;IAED,+DAA+D;IAC/D,YAAY,CAAC,IAAY;QACvB,IAAI,CAAC,SAAS,GAAG,CAAC,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC;QACtD,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE,CAAC;YACpB,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;YACvB,IAAI,CAAC,wBAAwB,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QACjD,CAAC;QAED,MAAM,SAAS,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;QACtC,IAAI,CAAC,QAAQ,CAAC;YACZ,KAAK,EAAE,CAAC,IAAI,CAAC,SAAS;YACtB,IAAI,EAAE,IAAI;YACV,KAAK,EAAE,SAAS,CAAC,OAAO,EAAE;SAC3B,CAAC,CAAC;QACH,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;QACxB,IAAI,IAAI,CAAC,mBAAmB;YAAE,IAAI,CAAC,mBAAmB,CAAC,cAAc,EAAE,CAAC;IAC1E,CAAC;IAED,8EAA8E;IAC9E,YAAY,CAAC,IAAY;QACvB,IAAI,CAAC,SAAS,GAAG,CAAC,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC,CAAC;QAEtD,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE,CAAC;YACpB,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC;YAC1B,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;YACxB,IAAI,IAAI,CAAC,mBAAmB;gBAAE,IAAI,CAAC,mBAAmB,CAAC,cAAc,EAAE,CAAC;YACxE,IAAI,CAAC,wBAAwB,CAAC,IAAI,CAAC,CAAC;QACtC,CAAC;QACD,MAAM,SAAS,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;QACtC,IAAI,CAAC,QAAQ,CAAC;YACZ,KAAK,EAAE,CAAC,IAAI,CAAC,SAAS;YACtB,IAAI,EAAE,IAAI;YACV,KAAK,EAAE,SAAS,CAAC,OAAO,EAAE;SAC3B,CAAC,CAAC;IACL,CAAC;IAED,wBAAwB,CAAC,IAAY;QACnC,IAAI,YAAoB,CAAC;QACzB,8CAA8C;QAC9C,MAAM,UAAU,GAAG,KAAK,CAAC,EAAE,CAAC,IAAI,CAAC,WAAW,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC,MAAM,CAAC,YAAY,CAAC,CAAC,CAAC,aAAa;QAChG,MAAM,kBAAkB,GAAG,KAAK,CAAC,EAAE,CAAC,GAAG,UAAU,IAAI,IAAI,EAAE,EAAE,cAAc,IAAI,CAAC,UAAU,EAAE,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC;QAC7G,mCAAmC;QACnC,MAAM,eAAe,GAAG,kBAAkB,CAAC,OAAO,EAAE,CAAC;QACrD,MAAM,MAAM,GAAG,IAAI,CAAC,QAAQ,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC,eAAe,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC,MAAM,EAAE,GAAG,IAAI,CAAC,QAAQ,CAAC,CAAC;QAEnG,IAAI,IAAI,CAAC,OAAO,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE,CAAC;YACpC,IAAI,CAAC,aAAa,GAAG,CAAC,CAAC;YACvB,OAAO;QACT,CAAC;QACD,YAAY,GAAG,MAAM,IAAI,IAAI,CAAC,QAAQ,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,EAAE,CAAC,eAAe,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,QAAQ,GAAG,MAAM,EAAE,GAAG,CAAC,CAAC,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,EAAE,CAAC,eAAe,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC,GAAG,CAAE,MAAM,EAAE,GAAG,CAAC,CAAC,CAAC,OAAO,EAAE,CAAC;QAEjN,4DAA4D;QAC5D,IAAK,eAAe,GAAG,KAAK,CAAC,EAAE,CAAC,IAAI,CAAC,WAAW,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC,KAAK,CAAC,KAAK,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,QAAQ,EAAE,GAAG,CAAC,CAAC,OAAO,EAAE,EAAE,CAAC;YACrH,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,aAAa,CAAC,MAAM,GAAG,CAAC,CAAC;QACrD,CAAC;aAAM,CAAC;YACN,MAAM,iBAAiB,GAAG,KAAK,CAAC,EAAE,CAAC,YAAY,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC;YAChE,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,aAAa,CAAC,SAAS,CAAC,QAAQ,CAAC,EAAE;gBAC3D,MAAM,WAAW,GAAG,KAAK,CAAC,EAAE,CAAC,GAAG,UAAU,IAAI,QAAQ,EAAE,EAAE,cAAc,IAAI,CAAC,UAAU,EAAE,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC;gBAC1G,OAAO,WAAW,CAAC,MAAM,CAAC,iBAAiB,CAAC,CAAC;YAC/C,CAAC,CAAC,CAAC;QACL,CAAC;IACH,CAAC;IAGD,kEAAkE;IAClE,gBAAgB;QACd,IAAI,CAAC,aAAa,GAAG,EAAE,CAAC;QAExB,+CAA+C;QAC/C,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE,CAAC;YACxB,6DAA6D;YAC7D,0CAA0C;YAC1C,IAAI,KAAK,CAAC,EAAE,CAAC,IAAI,CAAC,WAAW,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC,MAAM,CAAC,YAAY,CAAC,KAAK,KAAK,CAAC,EAAE,CAAC,KAAK,EAAE,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC,MAAM,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC;gBAC9I,MAAM,MAAM,GAAG,IAAI,CAAC,QAAQ,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC,KAAK,EAAE,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC,MAAM,EAAE,GAAG,IAAI,CAAC,QAAQ,CAAC,CAAC;gBAC3F,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC,EAAE,CAAC,KAAK,EAAE,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC,GAAG,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC,OAAO,EAAE,CAAC;YACnF,CAAC;YACD,sCAAsC;iBACjC,IAAG,IAAI,CAAC,OAAO,EAAC,CAAC;gBACpB,MAAM,MAAM,GAAG,IAAI,CAAC,QAAQ,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC,MAAM,EAAE,GAAG,IAAI,CAAC,QAAQ,CAAC,CAAC;gBAChG,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC,EAAE,CAAC,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC,GAAG,CAAC,MAAM,EAAE,GAAG,CAAC,CAAC,OAAO,EAAE,CAAC;YACxF,CAAC;YACD,wDAAwD;iBACnD,CAAC;gBACJ,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC,EAAE,CAAC,KAAK,EAAE,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,OAAO,EAAE,CAAC;YACjF,CAAC;QACH,CAAC;QAED,IAAG,IAAI,CAAC,SAAS,IAAI,IAAI,CAAC,aAAa,EAAC,CAAC;YACvC,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC,EAAE,CAAC,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC,OAAO,EAAE,CAAC;YACpF,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC;QAC7B,CAAC;QAED,MAAM,YAAY,GAAG,KAAK,CAAC,EAAE,CAAC,IAAI,CAAC,WAAW,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC,MAAM,CAAC,YAAY,CAAC,CAAC;QACpF,MAAM,gBAAgB,GAAG,KAAK,CAAC,EAAE,CAAC,IAAI,CAAC,aAAa,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QAC7F,IAAI,KAAK,GAAG,KAAK,CAAC,EAAE,CAAC,GAAG,YAAY,IAAI,gBAAgB,EAAE,EAAE,cAAc,IAAI,CAAC,UAAU,EAAE,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC;QAC5G,MAAM,GAAG,GAAG,KAAK,CAAC,EAAE,CAAC,IAAI,CAAC,WAAW,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;QACjE,OAAO,KAAK,CAAC,OAAO,EAAE,GAAG,GAAG,CAAC,OAAO,EAAE,EAAE,CAAC;YACvC,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC;YACvD,KAAK,GAAG,KAAK,CAAC,GAAG,CAAC,IAAI,CAAC,QAAQ,EAAE,GAAG,CAAC,CAAC;QACxC,CAAC;QAED,kEAAkE;QAClE,gCAAgC;QAChC,oBAAoB;QACpB,IAAI,IAAI,CAAC,aAAa,CAAC,MAAM,KAAK,CAAC,EAAE,CAAC;YACpC,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC,EAAE,CAAC,KAAK,EAAE,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;YACtF,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,KAAK,EAAE,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC;QAC/F,CAAC;IACH,CAAC;IAED,WAAW;QACT,IAAI,IAAI,CAAC,gBAAgB;YAAE,IAAI,CAAC,gBAAgB,CAAC,WAAW,EAAE,CAAC;IACjE,CAAC;oHA/QU,mBAAmB;oEAAnB,mBAAmB;;2BA6BnB,mBAAmB;2BACnB,gBAAgB;;;;;;;;;;YCjD3B,AADF,8BAAkG,kBAgB9F;YAbA,wPAAwB;YAIxB,AAHA,qJAAiB,gCAAwB,KAAC,wHAGjC,kBAAc,KAAC;YAN1B,iBAeE;YAEF,kHAA+I;YAAlC,2JAAiB,mBAAe,KAAC;YAUhJ,iBAAM;;;YA5B2D,AAA/B,iEAA8B,qDAAiC;YAG7F,cAAwB;YAAxB,8CAAwB;YASxB,AADA,AADA,AADA,AAHA,AADA,0FAAoD,wDACnB,8FAG4C,wBACtD,mBACL,sBACG;YAMyC,eAAkB;YAAC,AAAnB,mCAAkB,8BAA0B;;;iFDEjG,mBAAmB;cAL/B,SAAS;2BACE,gBAAgB;oBAcjB,WAAW;kBAAnB,KAAK;YAGG,QAAQ;kBAAhB,KAAK;YACG,MAAM;kBAAd,KAAK;YACG,UAAU;kBAAlB,KAAK;YACG,aAAa;kBAArB,KAAK;YACG,QAAQ;kBAAhB,KAAK;YACG,WAAW;kBAAnB,KAAK;YACG,aAAa;kBAArB,KAAK;YACG,aAAa;kBAArB,KAAK;YACG,WAAW;kBAAnB,KAAK;YAEG,SAAS;kBAAjB,KAAK;YACG,OAAO;kBAAf,KAAK;YACG,aAAa;kBAArB,KAAK;YACG,OAAO;kBAAf,KAAK;YACI,WAAW;kBAApB,MAAM;YAC+B,KAAK;kBAA1C,SAAS;mBAAC,OAAO,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE;YACJ,mBAAmB;kBAAlD,SAAS;mBAAC,mBAAmB;YACD,gBAAgB;kBAA5C,SAAS;mBAAC,gBAAgB;YAGO,gBAAgB;kBAAjD,YAAY;mBAAC,cAAc;;kFAjCjB,mBAAmB","sourcesContent":["import { Component, ElementRef, EventEmitter, Input, OnChanges, OnDestroy, OnInit, Output, ViewChild, ViewChildren } from \"@angular/core\";\nimport { ITime } from \"./time.namespace\";\nimport { TimepickerDirective } from \"./timepicker.directive\";\nimport { ToolTipDirective } from \"mis-crystal-design-system/tooltip\";\n\nimport dayjs from 'dayjs';\nimport timezone from 'dayjs/plugin/timezone';\nimport utc from 'dayjs/plugin/utc';\nimport customParseFormat from 'dayjs/plugin/customParseFormat'\n\ndayjs.extend(utc);\ndayjs.extend(timezone);\ndayjs.extend(customParseFormat);\n\n\n@Component({\n  selector: \"mis-timepicker\",\n  templateUrl: \"./timepicker.component.html\",\n  styleUrls: [\"./timepicker.component.scss\"]\n})\nexport class TimePickerComponent implements OnInit, OnChanges, OnDestroy {\n  currTime!: string;\n  chosenTime: string;\n  openStatus: boolean = false;\n  isHighlighted: number = 0;\n  isInvalid: boolean = false;\n  timeIntervals: string[] = [];\n  shouldScroll: boolean = false;\n  userInputFlag: boolean = false;\n  givenTimeFlag: boolean = true;\n  @Input() clockFormat: number = 12;\n  timeFormat!: string;\n  \n  @Input() timezone: string = \"Asia/Kolkata\";\n  @Input() height: string = \"max-content\";\n  @Input() inputWidth: string = \"100px\";\n  @Input() dropdownWidth?: string;\n  @Input() interval: number = 15;\n  @Input() dateAsEpoch: number = dayjs.tz(dayjs(), this.timezone).valueOf();\n  @Input() firstInterval!: number;\n  @Input() rangeValidity: boolean = true;\n  @Input() showTooltip: boolean = true;\n  dispayToolTip: boolean = this.showTooltip;\n  @Input() givenTime: number;\n  @Input() minTime?: number;\n  @Input() triggerChange: boolean = true;\n  @Input() disable: boolean = false;\n  @Output() timeEmitter = new EventEmitter<ITime>();\n  @ViewChild(\"input\", { static: true }) input: ElementRef;\n  @ViewChild(TimepickerDirective) timepickerDirective: TimepickerDirective;\n  @ViewChild(ToolTipDirective) tooltipDirective: ToolTipDirective;\n\n  // gets all the li elements from the dropdown and scrolls to the highlighted element\n  @ViewChildren(\"timeInterval\") set timeIntervalRefs(intervals) {\n    intervals.forEach(interval => {\n      if (interval.nativeElement.classList[0] === \"highlight\") {\n        const highlighted = interval.nativeElement;\n        setTimeout(() => highlighted.scrollIntoView({ block: \"center\" }));\n      }\n    });\n  }\n\n  constructor(){}\n  ngOnInit(): void {\n    if(!this.givenTime && !this.minTime) {\n      this.chosenTime = dayjs.tz(this.firstInterval, this.timezone).format(this.timeFormat);\n      let chosenTimedayjs = this.getdayjs(this.chosenTime);\n      this.emitTime({\n        valid: !this.isInvalid,\n        time: this.chosenTime,\n        epoch: chosenTimedayjs.valueOf()\n      });\n    }\n  }\n\n  ngOnChanges(): void {\n    this.timeFormat = this.clockFormat === 12 ? \"hh:mm a\" : \"HH:mm\";\n\n    if (this.timeFormat) {\n      let chosenTimedayjs = this.getdayjs(this.chosenTime);\n    \n      // if the first interval is >= the chosen time\n      // then only update the value of chosen time\n      // else it remains the same\n      if (this.firstInterval >= chosenTimedayjs.valueOf() && this.rangeValidity && !this.userInputFlag) {\n        this.chosenTime = dayjs.tz(this.firstInterval, this.timezone).format(this.timeFormat);\n        chosenTimedayjs = this.getdayjs(this.chosenTime)\n      }\n\n      if((this.givenTimeFlag && this.givenTime) || this.minTime ) {\n        this.chosenTime = dayjs.tz(this.minTime || this.givenTime, this.timezone).format(this.timeFormat);\n      }\n      chosenTimedayjs = this.getdayjs(this.chosenTime)\n\n      if (!this.userInputFlag) this.populateDropdown();\n      this.userInputFlag = false;\n      \n      if(this.chosenTime) {\n        this.isInvalid = !this.checkTimeValidity(this.chosenTime.trim());\n        this.emitTime({\n          valid: !this.isInvalid,\n          time: this.chosenTime,\n          epoch: chosenTimedayjs.valueOf()\n        });\n        this.calculateClosestInterval(this.chosenTime);\n      }\n    }\n  }\n\n  emitTime(data: ITime): void {\n    this.timeEmitter.emit(data);\n  }\n\n  // function to get dayjs object when time is given in string\n  getdayjs(time: string = '00:00'){;\n    if(!time || typeof time !== 'string') {\n      throw new Error('Time must be a string');\n    }\n\n    let hours: number;\n    let minutes: number;\n\n    if(this.clockFormat === 24) {\n      hours = parseInt(time.split(':')[0]);\n      minutes = parseInt(time.split(':')[1]);\n    } else {\n      const timeParts = time.split(' ');\n      const AM_PM = timeParts?.[1];\n      hours =  parseInt(timeParts?.[0]?.split(':')?.[0]);\n      minutes = parseInt(timeParts?.[0]?.split(':')?.[1]);\n\n      if(AM_PM?.toUpperCase() === 'PM' && hours !== 12) {\n        hours += 12;\n      } else if(AM_PM?.toUpperCase() === 'AM' && hours === 12) {\n        hours = 0;\n      }\n    }\n\n    return dayjs.tz(this.dateAsEpoch, this.timezone).add(hours, 'h').add(minutes, 'm');\n  }\n\n  closeDropdown() {\n    this.dispayToolTip = false;\n    this.userInputFlag = false;\n    this.openStatus = false;\n    if (this.timepickerDirective) this.timepickerDirective.destroyOverlay();\n  }\n\n  // toggle timepicker dropdown\n  openDropdown(): void {\n    this.dispayToolTip = true;\n    this.openStatus = true;\n  }\n\n  checkTimeValidity(time: string): boolean {\n    const RE12 = /^(([0][1-9]|1[0-2]):([0-5][0-9])( )?(am|pm|AM|PM))$/i;\n    const RE24 = /^([01][0-9]|2[0-3]):[0-5][0-9]$/;\n    const RE = this.clockFormat === 12 ? RE12 : RE24;\n\n    const timedayjs = this.getdayjs(time);\n    let flag: boolean = false;\n\n    // if the first interval is set to the start of the day\n    // or a time is already provided to the component to show\n    // then we don't check its validity against the current time\n    if (\n      this.minTime || \n      this.givenTime ||\n      (this.firstInterval &&\n      dayjs.tz(this.firstInterval, this.timezone).format(this.timeFormat).valueOf() === dayjs.tz(dayjs(), this.timezone).startOf(\"day\").format(this.timeFormat).valueOf())\n    ) {\n      flag = time.match(RE) ? true : false;\n    } else {\n      flag = time.match(RE) && timedayjs.diff(dayjs.tz(dayjs(), this.timezone), \"m\") >= 0 ? true: false;\n    }\n\n    return flag;\n  }\n\n  // update chosen time as soon as the user clicks on an interval\n  onTimeSelect(time: string): void {\n    this.isInvalid = !this.checkTimeValidity(time.trim());\n    if (!this.isInvalid) {\n      this.chosenTime = time;\n      this.calculateClosestInterval(this.chosenTime);\n    }\n\n    const timedayjs = this.getdayjs(time);\n    this.emitTime({\n      valid: !this.isInvalid,\n      time: time,\n      epoch: timedayjs.valueOf() \n    });\n    this.openStatus = false;\n    if (this.timepickerDirective) this.timepickerDirective.destroyOverlay();\n  }\n\n  // checks validity of time on input change and calculates the closest interval\n  onTimeChange(time: string): void {\n    this.isInvalid = !this.checkTimeValidity(time.trim());\n\n    if (!this.isInvalid) {\n      this.userInputFlag = true;\n      this.openStatus = false;\n      if (this.timepickerDirective) this.timepickerDirective.destroyOverlay();\n      this.calculateClosestInterval(time);\n    }\n    const timedayjs = this.getdayjs(time);\n    this.emitTime({\n      valid: !this.isInvalid,\n      time: time,\n      epoch: timedayjs.valueOf() \n    });\n  }\n\n  calculateClosestInterval(time: string): void {\n    let roundedEpoch: number;\n    // Converting time and date to a dayjs object \n    const chosenDate = dayjs.tz(this.dateAsEpoch, this.timezone).format(\"DD-MM-YYYY\"); // 05-01-2024\n    const parsedTimeWithDate = dayjs.tz(`${chosenDate} ${time}`, `DD-MM-YYYY ${this.timeFormat}`, this.timezone);\n    // Converting dayjs object to epoch\n    const chosenTimeEpoch = parsedTimeWithDate.valueOf();\n    const offset = this.interval - (dayjs.tz(chosenTimeEpoch, this.timezone).minute() % this.interval);\n\n    if (this.minTime && !this.givenTime) {\n      this.isHighlighted = 0;\n      return;\n    }\n    roundedEpoch = offset >= this.interval / 2 ? (dayjs.tz(chosenTimeEpoch, this.timezone).subtract(this.interval - offset, \"m\")).valueOf() : (dayjs.tz(chosenTimeEpoch, this.timezone).add( offset, \"m\")).valueOf();\n\n    // finding the index of element that needs to be highlighted\n    if ( chosenTimeEpoch > dayjs.tz(this.dateAsEpoch, this.timezone).endOf(\"day\").subtract(this.interval, \"m\").valueOf()) {\n      this.isHighlighted = this.timeIntervals.length - 1;\n    } else {\n      const roundedEpochdayjs = dayjs.tz(roundedEpoch, this.timezone);\n      this.isHighlighted = this.timeIntervals.findIndex(interval => {\n        const intervalObj = dayjs.tz(`${chosenDate} ${interval}`, `DD-MM-YYYY ${this.timeFormat}`, this.timezone);\n        return intervalObj.isSame(roundedEpochdayjs);\n      });\n    }\n  }\n\n\n  // populates the dropdown according to the first interval received\n  populateDropdown(): void {\n    this.timeIntervals = [];\n\n    // if picker is used as an individual component\n    if (!this.firstInterval) {\n      // firstInterval is initialised according to the current time\n      // if the date is same as the current date\n      if (dayjs.tz(this.dateAsEpoch, this.timezone).format(\"DD-MM-YYYY\") === dayjs.tz(dayjs(), this.timezone).format(\"DD-MM-YYYY\") && !this.minTime) {\n        const offset = this.interval - (dayjs.tz(dayjs(), this.timezone).minute() % this.interval);\n        this.firstInterval = dayjs.tz(dayjs(), this.timezone).add(offset, \"m\").valueOf();\n      }\n      // if minimum time to show is provided\n      else if(this.minTime){\n        const offset = this.interval - (dayjs.tz(this.minTime, this.timezone).minute() % this.interval);\n        this.firstInterval = dayjs.tz(this.minTime, this.timezone).add(offset, \"m\").valueOf();\n      }\n      // else the firstInterval is initialised as start of day\n      else {\n        this.firstInterval = dayjs.tz(dayjs(), this.timezone).startOf(\"day\").valueOf();\n      }\n    }\n\n    if(this.givenTime && this.givenTimeFlag){\n      this.firstInterval = dayjs.tz(this.givenTime, this.timezone).startOf('d').valueOf();\n      this.givenTimeFlag = false;\n    }\n\n    const dateAsString = dayjs.tz(this.dateAsEpoch, this.timezone).format('DD-MM-YYYY');\n    const intervalAsString = dayjs.tz(this.firstInterval, this.timezone).format(this.timeFormat);\n    let start = dayjs.tz(`${dateAsString} ${intervalAsString}`, `DD-MM-YYYY ${this.timeFormat}`, this.timezone);\n    const end = dayjs.tz(this.dateAsEpoch, this.timezone).endOf('d');\n    while (start.valueOf() < end.valueOf()) {\n      this.timeIntervals.push(start.format(this.timeFormat));\n      start = start.add(this.interval, \"m\");\n    }\n\n    // if the start time is equal to the interval just before midnight\n    // and the start date = end date\n    // push 11:59pm only\n    if (this.timeIntervals.length === 0) {\n      this.chosenTime = dayjs.tz(dayjs(), this.timezone).endOf(\"d\").format(this.timeFormat);\n      this.timeIntervals.push(dayjs.tz(dayjs(), this.timezone).endOf(\"d\").format(this.timeFormat));\n    }\n  }\n\n  ngOnDestroy() {\n    if (this.tooltipDirective) this.tooltipDirective.hideToolTip();\n  }\n}\n\n","<div class=\"timepicker-container\" [ngStyle]=\"{ height: height }\" [ngClass]=\"{'disable': disable}\">\n  <input\n    type=\"text\"\n    [(ngModel)]=\"chosenTime\"\n    (ngModelChange)=\"onTimeChange(chosenTime)\"\n    [ngClass]=\"{ invalid: isInvalid || !rangeValidity }\"\n    [ngStyle]=\"{ width: inputWidth }\"\n    (click)=\"openDropdown()\"\n    misToolTip\n    [showToolTip]=\"showTooltip && (isInvalid || !rangeValidity) && dispayToolTip\"\n    [text]=\"'Invalid Time'\"\n    [position]=\"'top'\"\n    [showOnHover]=\"false\"\n    #input\n    cdkOverlayOrigin\n    class=\"h7\"\n  />\n\n  <ng-template #dropdownContainer libDropdownScroll libTimepicker [originEl]=\"input\" [openStatus]=\"openStatus\" (statusEmitter)=\"closeDropdown()\">\n    <div *ngIf=\"openStatus\" class=\"timepicker-dropdown\" [ngStyle]=\"{ width: dropdownWidth || inputWidth }\">\n      <ul #dropdown>\n        <li #timeInterval (click)=\"onTimeSelect(interval)\" *ngFor=\"let interval of timeIntervals; index as i\" [ngClass]=\"{ highlight: i === isHighlighted }\">\n          {{ interval }}\n          <div class=\"ic-ui-check-24 selected-icon\" *ngIf=\"interval === chosenTime\"></div>\n        </li>\n      </ul>\n    </div>\n  </ng-template>\n</div>\n"]}
|
|
459
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"timepicker.component.js","sourceRoot":"","sources":["../../../../projects/mis-components/timepicker/timepicker.component.ts","../../../../projects/mis-components/timepicker/timepicker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, EventEmitter, Input, OnDestroy, OnInit, Output, ViewChild, ViewChildren, input, output, signal, computed, effect, untracked } from \"@angular/core\";\nimport { ITime } from \"./time.namespace\";\nimport { TimepickerDirective } from \"./timepicker.directive\";\nimport { ToolTipDirective } from \"mis-crystal-design-system/tooltip\";\n\nimport dayjs from 'dayjs';\nimport timezone from 'dayjs/plugin/timezone';\nimport utc from 'dayjs/plugin/utc';\nimport customParseFormat from 'dayjs/plugin/customParseFormat'\n\ndayjs.extend(utc);\ndayjs.extend(timezone);\ndayjs.extend(customParseFormat);\n\n\n@Component({\n  selector: \"mis-timepicker\",\n  templateUrl: \"./timepicker.component.html\",\n  styleUrls: [\"./timepicker.component.scss\"]\n})\nexport class TimePickerComponent implements OnInit, OnDestroy {\n  // Convert to signals for better performance and change detection\n  currTime = signal<string>('');\n  chosenTime = signal<string>('');\n  openStatus = signal<boolean>(false);\n  isHighlighted = signal<number>(0);\n  isInvalid = signal<boolean>(false);\n  timeIntervals = signal<string[]>([]);\n  shouldScroll = signal<boolean>(false);\n  userInputFlag = signal<boolean>(false);\n  givenTimeFlag = signal<boolean>(true);\n  // Signal-based inputs with backward compatibility\n  clockFormat = input<number>(12);\n  timeFormat!: string;\n  \n  timezone = input<string>(\"Asia/Kolkata\");\n  height = input<string>(\"max-content\");\n  inputWidth = input<string>(\"100px\");\n  dropdownWidth = input<string | undefined>(undefined);\n  interval = input<number>(15);\n  dateAsEpoch = input<number>(dayjs.tz(dayjs(), \"Asia/Kolkata\").valueOf());\n  firstInterval = input<number>();\n  rangeValidity = input<boolean>(true);\n  showTooltip = input<boolean>(true);\n  dispayToolTip: boolean = this.showTooltip();\n  givenTime = input<number>();\n  minTime = input<number | undefined>(undefined);\n  triggerChange = input<boolean>(true);\n  disable = input<boolean>(false);\n  \n  // Internal state for computed first interval\n  private computedFirstInterval: number | null = null;\n  private _isInitializing = false;\n  \n  // Signal-based output with backward compatibility\n  timeEmitter = output<ITime>();\n  @ViewChild(\"input\", { static: true }) input: ElementRef;\n  @ViewChild(TimepickerDirective) timepickerDirective: TimepickerDirective;\n  @ViewChild(ToolTipDirective) tooltipDirective: ToolTipDirective;\n\n  // gets all the li elements from the dropdown and scrolls to the highlighted element\n  @ViewChildren(\"timeInterval\") set timeIntervalRefs(intervals) {\n    intervals.forEach(interval => {\n      if (interval.nativeElement.classList[0] === \"highlight\") {\n        const highlighted = interval.nativeElement;\n        setTimeout(() => highlighted.scrollIntoView({ block: \"center\" }));\n      }\n    });\n  }\n\n  constructor(){\n    // Effect to handle triggerChange from parent component (timerangepicker)\n    effect(() => {\n      const triggerValue = this.triggerChange();\n      const firstIntervalValue = this.firstInterval();\n      \n      // Only update if not during user input and firstInterval is provided\n      if (!untracked(() => this.userInputFlag()) && firstIntervalValue && !this._isInitializing) {\n        const newTime = dayjs.tz(firstIntervalValue, untracked(() => this.timezone())).format(this.timeFormat);\n        \n        // Only update if the time actually changed\n        if (untracked(() => this.chosenTime()) !== newTime) {\n          // Use setTimeout to defer signal writes and avoid circular dependencies\n          setTimeout(() => {\n            this.chosenTime.set(newTime);\n            this.isInvalid.set(!this.checkTimeValidity(newTime.trim()));\n            \n            // CRITICAL FIX: Repopulate dropdown when firstInterval changes\n            this.populateDropdown();\n            \n            // Recalculate closest interval\n            this.calculateClosestInterval(newTime);\n            \n            // Emit the updated time\n            const timedayjs = this.getdayjs(newTime);\n            this.emitTime({\n              valid: !this.isInvalid(),\n              time: newTime,\n              epoch: timedayjs.valueOf()\n            });\n          }, 0);\n        }\n      }\n    });\n  }\n  \n  ngOnInit(): void {\n    this._isInitializing = true;\n    // Ensure timeFormat is set before initialization\n    this.timeFormat = this.clockFormat() === 12 ? \"hh:mm a\" : \"HH:mm\";\n    \n    // Initialize chosenTime - use firstInterval from parent if available, otherwise calculate\n    if (!this.givenTime() && !this.minTime()) {\n      let initialTime;\n      \n      // If firstInterval is provided by parent (timerangepicker), use it\n      if (this.firstInterval()) {\n        initialTime = dayjs.tz(this.firstInterval(), this.timezone()).format(this.timeFormat);\n      } else {\n        // Get current time and round to nearest interval using original logic\n        const now = dayjs.tz(dayjs(), this.timezone());\n        const interval = this.interval();\n        const minutes = now.minute();\n        const offset = interval - (minutes % interval);\n        \n        // Round to next interval if we're past halfway point\n        const roundedTime = offset >= interval / 2 \n          ? now.add(offset, \"m\").second(0).millisecond(0)\n          : now.subtract(interval - offset, \"m\").second(0).millisecond(0);\n        \n        initialTime = roundedTime.format(this.timeFormat);\n      }\n      \n      this.chosenTime.set(initialTime);\n      \n      // Set userInputFlag to false to avoid validation issues during initialization\n      this.userInputFlag.set(false);\n      \n      // Populate dropdown first to compute the first interval\n      this.populateDropdown();\n      \n      // Now validate with the computed first interval\n      this.isInvalid.set(!this.checkTimeValidity(this.chosenTime().trim()));\n      \n      let chosenTimedayjs = this.getdayjs(this.chosenTime());\n      // Defer emission to avoid ExpressionChangedAfterItHasBeenCheckedError\n      setTimeout(() => {\n        this.emitTime({\n          valid: !this.isInvalid(),\n          time: this.chosenTime(),\n          epoch: chosenTimedayjs.valueOf()\n        });\n      }, 0);\n      \n      // Calculate closest interval\n      this.calculateClosestInterval(this.chosenTime());\n      \n      this._isInitializing = false;\n    } else if (this.givenTime()) {\n      // When givenTime is present, use the given time as the initial value\n      // but the dropdown will start from 12:00 AM\n      this.chosenTime.set(dayjs.tz(this.givenTime(), this.timezone()).format(this.timeFormat));\n      this.userInputFlag.set(false);\n      \n      // Populate dropdown first to compute the first interval\n      this.populateDropdown();\n      \n      // Now validate with the computed first interval\n      this.isInvalid.set(!this.checkTimeValidity(this.chosenTime().trim()));\n      \n      let chosenTimedayjs = this.getdayjs(this.chosenTime());\n      // Defer emission to avoid ExpressionChangedAfterItHasBeenCheckedError\n      setTimeout(() => {\n        this.emitTime({\n          valid: !this.isInvalid(),\n          time: this.chosenTime(),\n          epoch: chosenTimedayjs.valueOf()\n        });\n      }, 0);\n      \n      // Calculate closest interval\n      this.calculateClosestInterval(this.chosenTime());\n      \n      this._isInitializing = false;\n    } else if (this.minTime()) {\n      // Use min time directly - this matches original behavior\n      this.chosenTime.set(dayjs.tz(this.minTime(), this.timezone()).format(this.timeFormat));\n      this.userInputFlag.set(false);\n      \n      // Populate dropdown first to compute the first interval\n      this.populateDropdown();\n      \n      // For minTime, validation should only check format, not time comparison\n      // This matches the original logic where minTime bypasses time validation\n      this.isInvalid.set(!this.checkTimeValidity(this.chosenTime().trim()));\n      \n      let chosenTimedayjs = this.getdayjs(this.chosenTime());\n      // Defer emission to avoid ExpressionChangedAfterItHasBeenCheckedError\n      setTimeout(() => {\n        this.emitTime({\n          valid: !this.isInvalid(),\n          time: this.chosenTime(),\n          epoch: chosenTimedayjs.valueOf()\n        });\n      }, 0);\n      \n      // Calculate closest interval\n      this.calculateClosestInterval(this.chosenTime());\n      \n      this._isInitializing = false;\n    }\n  }\n\n\n  emitTime(data: ITime): void {\n    this.timeEmitter.emit(data);\n  }\n\n  // function to get dayjs object when time is given in string\n  getdayjs(time: string = '00:00'){\n    if(!time || typeof time !== 'string') {\n      throw new Error('Time must be a string');\n    }\n\n    let hours: number;\n    let minutes: number;\n\n    if(this.clockFormat() === 24) {\n      hours = parseInt(time.split(':')[0]);\n      minutes = parseInt(time.split(':')[1]);\n    } else {\n      const timeParts = time.split(' ');\n      const AM_PM = timeParts?.[1];\n      hours =  parseInt(timeParts?.[0]?.split(':')?.[0]);\n      minutes = parseInt(timeParts?.[0]?.split(':')?.[1]);\n\n      if(AM_PM?.toUpperCase() === 'PM' && hours !== 12) {\n        hours += 12;\n      } else if(AM_PM?.toUpperCase() === 'AM' && hours === 12) {\n        hours = 0;\n      }\n    }\n\n    // Use the date from dateAsEpoch but set the time to the parsed hours and minutes\n    const baseDate = dayjs.tz(this.dateAsEpoch(), this.timezone());\n    const result = baseDate.hour(hours).minute(minutes).second(0).millisecond(0);\n    return result;\n  }\n\n  closeDropdown() {\n    this.dispayToolTip = false;\n    this.userInputFlag.set(false);\n    this.openStatus.set(false);\n    if (this.timepickerDirective) this.timepickerDirective.destroyOverlay();\n  }\n\n  // toggle timepicker dropdown\n  openDropdown(): void {\n    this.dispayToolTip = true;\n    this.openStatus.set(true);\n  }\n\n  checkTimeValidity(time: string): boolean {\n    const RE12 = /^(([0][1-9]|1[0-2]):([0-5][0-9])( )?(am|pm|AM|PM))$/i;\n    const RE24 = /^([01][0-9]|2[0-3]):[0-5][0-9]$/;\n    const RE = this.clockFormat() === 12 ? RE12 : RE24;\n\n    // Check if the time format is valid first\n    if (!time.match(RE)) {\n      return false;\n    }\n\n    // Restore proper validation logic\n    const timedayjs = this.getdayjs(time);\n    let flag: boolean = false;\n\n    // Original logic: if minTime, givenTime, or firstInterval is start of day, only check format\n    if (\n      this.minTime() || \n      this.givenTime() ||\n      (this.firstInterval() &&\n      dayjs.tz(this.firstInterval(), this.timezone()).format(this.timeFormat).valueOf() === dayjs.tz(dayjs(), this.timezone()).startOf(\"day\").format(this.timeFormat).valueOf())                                        \n    ) {\n      // Only check format validation, not time comparison\n      flag = time.match(RE) ? true : false;\n    } else {\n      // Check against current time for normal cases\n      const currentTime = dayjs.tz(dayjs(), this.timezone());\n      const timeDiff = timedayjs.diff(currentTime, \"m\");\n      flag = timeDiff >= 0;\n    }\n\n    return flag;\n  }\n\n  // update chosen time as soon as the user clicks on an interval\n  onTimeSelect(time: string): void {\n    this.isInvalid.set(!this.checkTimeValidity(time.trim()));\n    if (!this.isInvalid()) {\n      this.chosenTime.set(time);\n      this.calculateClosestInterval(this.chosenTime());\n    }\n\n    const timedayjs = this.getdayjs(time);\n    this.emitTime({\n      valid: !this.isInvalid(),\n      time: time,\n      epoch: timedayjs.valueOf() \n    });\n    this.openStatus.set(false);\n    if (this.timepickerDirective) this.timepickerDirective.destroyOverlay();\n  }\n\n  // checks validity of time on input change and calculates the closest interval\n  onTimeChange(time: string): void {\n    // Set user input flag to prevent effects from overriding\n    this.userInputFlag.set(true);\n    \n    // Update the chosenTime signal\n    this.chosenTime.set(time);\n    const isValid = this.checkTimeValidity(time.trim());\n    this.isInvalid.set(!isValid);\n\n    // Clear user input flag after a delay to allow effects to work again\n    setTimeout(() => {\n      this.userInputFlag.set(false);\n    }, 1000); // 1 second delay\n\n    if (!this.isInvalid()) {\n      this.openStatus.set(false);\n      if (this.timepickerDirective) this.timepickerDirective.destroyOverlay();\n      this.calculateClosestInterval(time);\n    }\n    const timedayjs = this.getdayjs(time);\n    this.emitTime({\n      valid: !this.isInvalid(),\n      time: time,\n      epoch: timedayjs.valueOf() \n    });\n  }\n\n  calculateClosestInterval(time: string): void {\n    let roundedEpoch: number;\n    // Converting time and date to a dayjs object \n    const chosenDate = dayjs.tz(this.dateAsEpoch(), this.timezone()).format(\"DD-MM-YYYY\"); // 05-01-2024\n    const parsedTimeWithDate = dayjs.tz(`${chosenDate} ${time}`, `DD-MM-YYYY ${this.timeFormat}`, this.timezone());\n    // Converting dayjs object to epoch\n    const chosenTimeEpoch = parsedTimeWithDate.valueOf();\n    const offset = this.interval() - (dayjs.tz(chosenTimeEpoch, this.timezone()).minute() % this.interval());\n\n    if (this.minTime() && !this.givenTime()) {\n      this.isHighlighted.set(0);\n      return;\n    }\n    roundedEpoch = offset >= this.interval() / 2 ? (dayjs.tz(chosenTimeEpoch, this.timezone()).subtract(this.interval() - offset, \"m\")).valueOf() : (dayjs.tz(chosenTimeEpoch, this.timezone()).add( offset, \"m\")).valueOf();\n\n    // finding the index of element that needs to be highlighted\n    if ( chosenTimeEpoch > dayjs.tz(this.dateAsEpoch(), this.timezone()).endOf(\"day\").subtract(this.interval(), \"m\").valueOf()) {\n      this.isHighlighted.set(this.timeIntervals().length - 1);\n    } else {\n      const roundedEpochdayjs = dayjs.tz(roundedEpoch, this.timezone());\n      this.isHighlighted.set(this.timeIntervals().findIndex(interval => {\n        const intervalObj = dayjs.tz(`${chosenDate} ${interval}`, `DD-MM-YYYY ${this.timeFormat}`, this.timezone());\n        return intervalObj.isSame(roundedEpochdayjs);\n      }));\n    }\n  }\n\n\n  // populates the dropdown according to the first interval received\n  populateDropdown(): void {\n    this.timeIntervals.set([]);\n\n    // Compute the effective first interval\n    let effectiveFirstInterval = this.firstInterval();\n\n    // if picker is used as an individual component\n    if (!effectiveFirstInterval) {\n      // firstInterval is initialised according to the current time\n      // if the date is same as the current date\n      if (dayjs.tz(this.dateAsEpoch(), this.timezone()).format(\"DD-MM-YYYY\") === dayjs.tz(dayjs(), this.timezone()).format(\"DD-MM-YYYY\") && !this.minTime()) {\n        const offset = this.interval() - (dayjs.tz(dayjs(), this.timezone()).minute() % this.interval());\n        effectiveFirstInterval = dayjs.tz(dayjs(), this.timezone()).add(offset, \"m\").valueOf();\n      }\n      // if minimum time to show is provided\n      else if(this.minTime()){\n        const minTimeDayjs = dayjs.tz(this.minTime(), this.timezone());\n        const offset = this.interval() - (minTimeDayjs.minute() % this.interval());\n        effectiveFirstInterval = minTimeDayjs.add(offset, \"m\").valueOf();\n      }\n      // else the firstInterval is initialised as start of day\n      else {\n        effectiveFirstInterval = dayjs.tz(dayjs(), this.timezone()).startOf(\"day\").valueOf();\n      }\n    }\n\n    if(this.givenTime()){\n      // When givenTime is present, always start from 12:00 AM (start of day)\n      // regardless of whether the time has passed or not\n      effectiveFirstInterval = dayjs.tz(this.dateAsEpoch(), this.timezone()).startOf('day').valueOf();\n      this.givenTimeFlag.set(false);\n    }\n\n    // Store the computed first interval for later use\n    this.computedFirstInterval = effectiveFirstInterval;\n\n    const dateAsString = dayjs.tz(this.dateAsEpoch(), this.timezone()).format('DD-MM-YYYY');\n    const intervalAsString = dayjs.tz(effectiveFirstInterval, this.timezone()).format(this.timeFormat);\n    let start = dayjs.tz(`${dateAsString} ${intervalAsString}`, `DD-MM-YYYY ${this.timeFormat}`, this.timezone());\n    const end = dayjs.tz(this.dateAsEpoch(), this.timezone()).endOf('d');\n    \n    while (start.valueOf() < end.valueOf()) {\n      this.timeIntervals.update(intervals => [...intervals, start.format(this.timeFormat)]);\n      start = start.add(this.interval(), \"m\");\n    }\n\n    // NEW: Handle end-of-day case - if firstInterval is at or very close to end of day\n    // and we're on the same date, show only 11:59 PM\n    const endOfDay = dayjs.tz(this.dateAsEpoch(), this.timezone()).endOf(\"d\");\n    const firstIntervalDayjs = dayjs.tz(effectiveFirstInterval, this.timezone());\n    \n    // Check if firstInterval is at or very close to end of day (within 1 minute)\n    const isAtEndOfDay = firstIntervalDayjs.isSame(endOfDay, 'day') && \n                        firstIntervalDayjs.diff(endOfDay, 'minute') >= -1;\n    \n    if (isAtEndOfDay || this.timeIntervals().length === 0) {\n      // Clear existing intervals and add only 11:59 PM\n      this.timeIntervals.set([]);\n      this.timeIntervals.update(intervals => [...intervals, endOfDay.format(this.timeFormat)]);\n    }\n  }\n\n  ngOnDestroy() {\n    if (this.tooltipDirective) this.tooltipDirective.hideToolTip();\n  }\n}\n\n","<div class=\"timepicker-container\" [ngStyle]=\"{ height: height() }\" [ngClass]=\"{'disable': disable()}\">\n  <input\n    type=\"text\"\n    [ngModel]=\"chosenTime()\"\n    (ngModelChange)=\"onTimeChange($event)\"\n    [ngClass]=\"{ invalid: isInvalid() || !rangeValidity() }\"\n    [ngStyle]=\"{ width: inputWidth() }\"\n    (click)=\"openDropdown()\"\n    misToolTip\n    [showToolTip]=\"showTooltip() && (isInvalid() || !rangeValidity()) && dispayToolTip\"\n    [text]=\"'Invalid Time'\"\n    [position]=\"'top'\"\n    [showOnHover]=\"false\"\n    #input\n    cdkOverlayOrigin\n    class=\"h7\"\n  />\n\n  <ng-template #dropdownContainer libTimepicker [originEl]=\"input\" [openStatus]=\"openStatus()\" (statusEmitter)=\"closeDropdown()\">\n    <div *ngIf=\"openStatus()\" class=\"timepicker-dropdown\" [ngStyle]=\"{ width: dropdownWidth() || inputWidth() }\">\n      <ul #dropdown>\n        <li #timeInterval (click)=\"onTimeSelect(interval)\" *ngFor=\"let interval of timeIntervals(); index as i\" [ngClass]=\"{ highlight: i === isHighlighted() }\">\n          {{ interval }}\n          <div class=\"ic-ui-check-24 selected-icon\" *ngIf=\"interval === chosenTime()\"></div>\n        </li>\n      </ul>\n    </div>\n  </ng-template>\n</div>\n"]}
|