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, HostListener, Inject } from "@angular/core";
|
|
1
|
+
import { Component, HostListener, Inject, signal, computed } from "@angular/core";
|
|
2
2
|
import { CONTAINER_DATA, DATE_FORMAT } from "../datepicker-constants";
|
|
3
3
|
import { getMonth } from "../utils";
|
|
4
4
|
import dayjs from 'dayjs';
|
|
@@ -28,7 +28,7 @@ function TzDpContainerComponent_div_6_Template(rf, ctx) { if (rf & 1) {
|
|
|
28
28
|
} if (rf & 2) {
|
|
29
29
|
const ctx_r1 = i0.ɵɵnextContext();
|
|
30
30
|
i0.ɵɵadvance();
|
|
31
|
-
i0.ɵɵtextInterpolate1(" ", ctx_r1.isYearSelectionFlow ? ctx_r1.selectedYear : ctx_r1.availableMonths[ctx_r1.currentMonthNumber], " ");
|
|
31
|
+
i0.ɵɵtextInterpolate1(" ", ctx_r1.isYearSelectionFlow() ? ctx_r1.selectedYear() : ctx_r1.availableMonths()[ctx_r1.currentMonthNumber()], " ");
|
|
32
32
|
} }
|
|
33
33
|
function TzDpContainerComponent_div_7_Template(rf, ctx) { if (rf & 1) {
|
|
34
34
|
const _r3 = i0.ɵɵgetCurrentView();
|
|
@@ -39,19 +39,19 @@ function TzDpContainerComponent_div_7_Template(rf, ctx) { if (rf & 1) {
|
|
|
39
39
|
} if (rf & 2) {
|
|
40
40
|
const ctx_r1 = i0.ɵɵnextContext();
|
|
41
41
|
i0.ɵɵadvance();
|
|
42
|
-
i0.ɵɵtextInterpolate1(" ", ctx_r1.isSelectingYear ? ctx_r1.yearRange : ctx_r1.currentYearNumber, " ");
|
|
42
|
+
i0.ɵɵtextInterpolate1(" ", ctx_r1.isSelectingYear() ? ctx_r1.yearRange : ctx_r1.currentYearNumber(), " ");
|
|
43
43
|
} }
|
|
44
44
|
function TzDpContainerComponent_div_12_div_2_Template(rf, ctx) { if (rf & 1) {
|
|
45
45
|
const _r4 = i0.ɵɵgetCurrentView();
|
|
46
46
|
i0.ɵɵelementStart(0, "div", 21);
|
|
47
|
-
i0.ɵɵlistener("click", function TzDpContainerComponent_div_12_div_2_Template_div_click_0_listener() { const ctx_r4 = i0.ɵɵrestoreView(_r4); const month_r6 = ctx_r4.$implicit; const i_r7 = ctx_r4.index; const ctx_r1 = i0.ɵɵnextContext(2); return i0.ɵɵresetView(!ctx_r1.disabledMonths[i_r7] && ctx_r1.selectMonth(month_r6)); });
|
|
47
|
+
i0.ɵɵlistener("click", function TzDpContainerComponent_div_12_div_2_Template_div_click_0_listener() { const ctx_r4 = i0.ɵɵrestoreView(_r4); const month_r6 = ctx_r4.$implicit; const i_r7 = ctx_r4.index; const ctx_r1 = i0.ɵɵnextContext(2); return i0.ɵɵresetView(!ctx_r1.disabledMonths()[i_r7] && ctx_r1.selectMonth(month_r6)); });
|
|
48
48
|
i0.ɵɵtext(1);
|
|
49
49
|
i0.ɵɵelementEnd();
|
|
50
50
|
} if (rf & 2) {
|
|
51
51
|
const month_r6 = ctx.$implicit;
|
|
52
52
|
const i_r7 = ctx.index;
|
|
53
53
|
const ctx_r1 = i0.ɵɵnextContext(2);
|
|
54
|
-
i0.ɵɵproperty("ngClass", i0.ɵɵpureFunction2(2, _c1, ctx_r1.disabledMonths[i_r7], !ctx_r1.disabledMonths[ctx_r1.currentMonthNumber] && month_r6 === ctx_r1.availableMonths[ctx_r1.currentMonthNumber]));
|
|
54
|
+
i0.ɵɵproperty("ngClass", i0.ɵɵpureFunction2(2, _c1, ctx_r1.disabledMonths()[i_r7], !ctx_r1.disabledMonths()[ctx_r1.currentMonthNumber()] && month_r6 === ctx_r1.availableMonths()[ctx_r1.currentMonthNumber()]));
|
|
55
55
|
i0.ɵɵadvance();
|
|
56
56
|
i0.ɵɵtextInterpolate1(" ", month_r6, " ");
|
|
57
57
|
} }
|
|
@@ -62,19 +62,19 @@ function TzDpContainerComponent_div_12_Template(rf, ctx) { if (rf & 1) {
|
|
|
62
62
|
} if (rf & 2) {
|
|
63
63
|
const ctx_r1 = i0.ɵɵnextContext();
|
|
64
64
|
i0.ɵɵadvance(2);
|
|
65
|
-
i0.ɵɵproperty("ngForOf", ctx_r1.availableMonths);
|
|
65
|
+
i0.ɵɵproperty("ngForOf", ctx_r1.availableMonths());
|
|
66
66
|
} }
|
|
67
67
|
function TzDpContainerComponent_div_13_div_2_Template(rf, ctx) { if (rf & 1) {
|
|
68
68
|
const _r8 = i0.ɵɵgetCurrentView();
|
|
69
69
|
i0.ɵɵelementStart(0, "div", 24);
|
|
70
|
-
i0.ɵɵlistener("click", function TzDpContainerComponent_div_13_div_2_Template_div_click_0_listener() { const ctx_r8 = i0.ɵɵrestoreView(_r8); const year_r10 = ctx_r8.$implicit; const i_r11 = ctx_r8.index; const ctx_r1 = i0.ɵɵnextContext(2); return i0.ɵɵresetView(!ctx_r1.disabledYears[i_r11] && ctx_r1.selectYear(year_r10)); });
|
|
70
|
+
i0.ɵɵlistener("click", function TzDpContainerComponent_div_13_div_2_Template_div_click_0_listener() { const ctx_r8 = i0.ɵɵrestoreView(_r8); const year_r10 = ctx_r8.$implicit; const i_r11 = ctx_r8.index; const ctx_r1 = i0.ɵɵnextContext(2); return i0.ɵɵresetView(!ctx_r1.disabledYears()[i_r11] && ctx_r1.selectYear(year_r10)); });
|
|
71
71
|
i0.ɵɵtext(1);
|
|
72
72
|
i0.ɵɵelementEnd();
|
|
73
73
|
} if (rf & 2) {
|
|
74
74
|
const year_r10 = ctx.$implicit;
|
|
75
75
|
const i_r11 = ctx.index;
|
|
76
76
|
const ctx_r1 = i0.ɵɵnextContext(2);
|
|
77
|
-
i0.ɵɵproperty("ngClass", i0.ɵɵpureFunction2(2, _c2, ctx_r1.disabledYears[i_r11], year_r10 === ctx_r1.currentYearNumber));
|
|
77
|
+
i0.ɵɵproperty("ngClass", i0.ɵɵpureFunction2(2, _c2, ctx_r1.disabledYears()[i_r11], year_r10 === ctx_r1.currentYearNumber()));
|
|
78
78
|
i0.ɵɵadvance();
|
|
79
79
|
i0.ɵɵtextInterpolate1(" ", year_r10, " ");
|
|
80
80
|
} }
|
|
@@ -85,7 +85,7 @@ function TzDpContainerComponent_div_13_Template(rf, ctx) { if (rf & 1) {
|
|
|
85
85
|
} if (rf & 2) {
|
|
86
86
|
const ctx_r1 = i0.ɵɵnextContext();
|
|
87
87
|
i0.ɵɵadvance(2);
|
|
88
|
-
i0.ɵɵproperty("ngForOf", ctx_r1.availableYears);
|
|
88
|
+
i0.ɵɵproperty("ngForOf", ctx_r1.availableYears());
|
|
89
89
|
} }
|
|
90
90
|
function TzDpContainerComponent_div_14_div_1_Template(rf, ctx) { if (rf & 1) {
|
|
91
91
|
i0.ɵɵelementStart(0, "div", 27)(1, "span", 28);
|
|
@@ -105,7 +105,7 @@ function TzDpContainerComponent_div_14_Template(rf, ctx) { if (rf & 1) {
|
|
|
105
105
|
} if (rf & 2) {
|
|
106
106
|
const ctx_r1 = i0.ɵɵnextContext();
|
|
107
107
|
i0.ɵɵadvance();
|
|
108
|
-
i0.ɵɵproperty("ngForOf", ctx_r1.weekDays);
|
|
108
|
+
i0.ɵɵproperty("ngForOf", ctx_r1.weekDays());
|
|
109
109
|
} }
|
|
110
110
|
function TzDpContainerComponent_div_15_div_1_span_1_Template(rf, ctx) { if (rf & 1) {
|
|
111
111
|
i0.ɵɵelementStart(0, "span", 33);
|
|
@@ -115,7 +115,7 @@ function TzDpContainerComponent_div_15_div_1_span_1_Template(rf, ctx) { if (rf &
|
|
|
115
115
|
const day_r14 = i0.ɵɵnextContext().$implicit;
|
|
116
116
|
const ctx_r1 = i0.ɵɵnextContext(2);
|
|
117
117
|
i0.ɵɵproperty("tabindex", day_r14.isDisabledDay ? -1 : 0)("ngClass", i0.ɵɵpureFunction3(4, _c5, day_r14.isCurrentDay, day_r14.isSelectedDay, day_r14.isDisabledDay));
|
|
118
|
-
i0.ɵɵattribute("aria-label", ctx_r1.retractDayMonth(day_r14.date, ctx_r1.currentMonth, ctx_r1.currentYearNumber));
|
|
118
|
+
i0.ɵɵattribute("aria-label", ctx_r1.retractDayMonth(day_r14.date, ctx_r1.currentMonth(), ctx_r1.currentYearNumber()));
|
|
119
119
|
i0.ɵɵadvance();
|
|
120
120
|
i0.ɵɵtextInterpolate1(" ", day_r14.date, " ");
|
|
121
121
|
} }
|
|
@@ -138,7 +138,7 @@ function TzDpContainerComponent_div_15_Template(rf, ctx) { if (rf & 1) {
|
|
|
138
138
|
} if (rf & 2) {
|
|
139
139
|
const ctx_r1 = i0.ɵɵnextContext();
|
|
140
140
|
i0.ɵɵadvance();
|
|
141
|
-
i0.ɵɵproperty("ngForOf", ctx_r1.currentMonthDates);
|
|
141
|
+
i0.ɵɵproperty("ngForOf", ctx_r1.currentMonthDates());
|
|
142
142
|
} }
|
|
143
143
|
function TzDpContainerComponent_div_16_div_15_Template(rf, ctx) { if (rf & 1) {
|
|
144
144
|
const _r16 = i0.ɵɵgetCurrentView();
|
|
@@ -146,7 +146,7 @@ function TzDpContainerComponent_div_16_div_15_Template(rf, ctx) { if (rf & 1) {
|
|
|
146
146
|
i0.ɵɵtext(2, "AM/PM");
|
|
147
147
|
i0.ɵɵelementEnd();
|
|
148
148
|
i0.ɵɵelementStart(3, "select", 46);
|
|
149
|
-
i0.ɵɵ
|
|
149
|
+
i0.ɵɵlistener("ngModelChange", function TzDpContainerComponent_div_16_div_15_Template_select_ngModelChange_3_listener($event) { i0.ɵɵrestoreView(_r16); const ctx_r1 = i0.ɵɵnextContext(2); return i0.ɵɵresetView(ctx_r1.selectedAmPmSignal.set($event)); });
|
|
150
150
|
i0.ɵɵelementStart(4, "option", 47);
|
|
151
151
|
i0.ɵɵtext(5, "AM");
|
|
152
152
|
i0.ɵɵelementEnd();
|
|
@@ -156,7 +156,7 @@ function TzDpContainerComponent_div_16_div_15_Template(rf, ctx) { if (rf & 1) {
|
|
|
156
156
|
} if (rf & 2) {
|
|
157
157
|
const ctx_r1 = i0.ɵɵnextContext(2);
|
|
158
158
|
i0.ɵɵadvance(3);
|
|
159
|
-
i0.ɵɵ
|
|
159
|
+
i0.ɵɵproperty("ngModel", ctx_r1.selectedAmPm());
|
|
160
160
|
} }
|
|
161
161
|
function TzDpContainerComponent_div_16_Template(rf, ctx) { if (rf & 1) {
|
|
162
162
|
const _r15 = i0.ɵɵgetCurrentView();
|
|
@@ -167,8 +167,7 @@ function TzDpContainerComponent_div_16_Template(rf, ctx) { if (rf & 1) {
|
|
|
167
167
|
i0.ɵɵtext(7, "Hour");
|
|
168
168
|
i0.ɵɵelementEnd();
|
|
169
169
|
i0.ɵɵelementStart(8, "input", 39);
|
|
170
|
-
i0.ɵɵ
|
|
171
|
-
i0.ɵɵlistener("input", function TzDpContainerComponent_div_16_Template_input_input_8_listener($event) { i0.ɵɵrestoreView(_r15); const ctx_r1 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r1.onHourInput($event)); })("blur", function TzDpContainerComponent_div_16_Template_input_blur_8_listener() { i0.ɵɵrestoreView(_r15); const ctx_r1 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r1.validateHourInput()); });
|
|
170
|
+
i0.ɵɵlistener("ngModelChange", function TzDpContainerComponent_div_16_Template_input_ngModelChange_8_listener($event) { i0.ɵɵrestoreView(_r15); const ctx_r1 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r1.selectedHourSignal.set($event)); })("input", function TzDpContainerComponent_div_16_Template_input_input_8_listener($event) { i0.ɵɵrestoreView(_r15); const ctx_r1 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r1.onHourInput($event)); })("blur", function TzDpContainerComponent_div_16_Template_input_blur_8_listener() { i0.ɵɵrestoreView(_r15); const ctx_r1 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r1.validateHourInput()); });
|
|
172
171
|
i0.ɵɵelementEnd()();
|
|
173
172
|
i0.ɵɵelementStart(9, "div", 40);
|
|
174
173
|
i0.ɵɵtext(10, ":");
|
|
@@ -177,20 +176,16 @@ function TzDpContainerComponent_div_16_Template(rf, ctx) { if (rf & 1) {
|
|
|
177
176
|
i0.ɵɵtext(13, "Minute");
|
|
178
177
|
i0.ɵɵelementEnd();
|
|
179
178
|
i0.ɵɵelementStart(14, "input", 42);
|
|
180
|
-
i0.ɵɵ
|
|
181
|
-
i0.ɵɵlistener("input", function TzDpContainerComponent_div_16_Template_input_input_14_listener($event) { i0.ɵɵrestoreView(_r15); const ctx_r1 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r1.onMinuteInput($event)); })("blur", function TzDpContainerComponent_div_16_Template_input_blur_14_listener() { i0.ɵɵrestoreView(_r15); const ctx_r1 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r1.validateMinuteInput()); });
|
|
179
|
+
i0.ɵɵlistener("ngModelChange", function TzDpContainerComponent_div_16_Template_input_ngModelChange_14_listener($event) { i0.ɵɵrestoreView(_r15); const ctx_r1 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r1.selectedMinuteSignal.set($event)); })("input", function TzDpContainerComponent_div_16_Template_input_input_14_listener($event) { i0.ɵɵrestoreView(_r15); const ctx_r1 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r1.onMinuteInput($event)); })("blur", function TzDpContainerComponent_div_16_Template_input_blur_14_listener() { i0.ɵɵrestoreView(_r15); const ctx_r1 = i0.ɵɵnextContext(); return i0.ɵɵresetView(ctx_r1.validateMinuteInput()); });
|
|
182
180
|
i0.ɵɵelementEnd()();
|
|
183
181
|
i0.ɵɵtemplate(15, TzDpContainerComponent_div_16_div_15_Template, 8, 1, "div", 43);
|
|
184
182
|
i0.ɵɵelementEnd()();
|
|
185
183
|
} if (rf & 2) {
|
|
186
184
|
const ctx_r1 = i0.ɵɵnextContext();
|
|
187
185
|
i0.ɵɵadvance(8);
|
|
188
|
-
i0.ɵɵproperty("min", ctx_r1.is12HourFormat() ? 1 : 0)("max", ctx_r1.is12HourFormat() ? 12 : 23)("step", 1);
|
|
189
|
-
i0.ɵɵtwoWayProperty("ngModel", ctx_r1.selectedHour);
|
|
190
|
-
i0.ɵɵproperty("title", ctx_r1.is12HourFormat() ? "Enter hour (1-12)" : "Enter hour (0-23)");
|
|
186
|
+
i0.ɵɵproperty("min", ctx_r1.is12HourFormat() ? 1 : 0)("max", ctx_r1.is12HourFormat() ? 12 : 23)("step", 1)("ngModel", ctx_r1.selectedHour())("title", ctx_r1.is12HourFormat() ? "Enter hour (1-12)" : "Enter hour (0-23)");
|
|
191
187
|
i0.ɵɵadvance(6);
|
|
192
|
-
i0.ɵɵproperty("step", 1);
|
|
193
|
-
i0.ɵɵtwoWayProperty("ngModel", ctx_r1.selectedMinute);
|
|
188
|
+
i0.ɵɵproperty("step", 1)("ngModel", ctx_r1.selectedMinute());
|
|
194
189
|
i0.ɵɵadvance();
|
|
195
190
|
i0.ɵɵproperty("ngIf", ctx_r1.is12HourFormat());
|
|
196
191
|
} }
|
|
@@ -205,9 +200,10 @@ function TzDpContainerComponent_div_17_Template(rf, ctx) { if (rf & 1) {
|
|
|
205
200
|
i0.ɵɵtext(4, "Apply");
|
|
206
201
|
i0.ɵɵelementEnd()();
|
|
207
202
|
} if (rf & 2) {
|
|
203
|
+
let tmp_1_0;
|
|
208
204
|
const ctx_r1 = i0.ɵɵnextContext();
|
|
209
205
|
i0.ɵɵadvance(3);
|
|
210
|
-
i0.ɵɵproperty("disabled", !(ctx_r1.data.date || ctx_r1.localSelectedDate.date));
|
|
206
|
+
i0.ɵɵproperty("disabled", !(ctx_r1.data.date || ((tmp_1_0 = ctx_r1.localSelectedDate()) == null ? null : tmp_1_0.date)));
|
|
211
207
|
} }
|
|
212
208
|
dayjs.extend(utc);
|
|
213
209
|
dayjs.extend(timezone);
|
|
@@ -221,22 +217,52 @@ export class TzDpContainerComponent {
|
|
|
221
217
|
return dayjs(...args);
|
|
222
218
|
};
|
|
223
219
|
this.rawWeekDays = ["SUN", "MON", "TUE", "WED", "THU", "FRI", "SAT"];
|
|
224
|
-
|
|
225
|
-
this.
|
|
226
|
-
this.
|
|
227
|
-
this.
|
|
228
|
-
this.
|
|
229
|
-
|
|
230
|
-
this.
|
|
231
|
-
this.
|
|
232
|
-
this.
|
|
233
|
-
this.
|
|
234
|
-
this.
|
|
235
|
-
|
|
236
|
-
this.
|
|
237
|
-
this.
|
|
238
|
-
this.
|
|
239
|
-
this.
|
|
220
|
+
// Signal-based state management
|
|
221
|
+
this.weekDaysSignal = signal([]);
|
|
222
|
+
this.currentMonthNumberSignal = signal(0);
|
|
223
|
+
this.currentMonthSignal = signal("January");
|
|
224
|
+
this.currentYearNumberSignal = signal(0);
|
|
225
|
+
this.currentMonthDatesSignal = signal([]);
|
|
226
|
+
this.isPreviousMonthDisabledSignal = signal(false);
|
|
227
|
+
this.isNextMonthDisabledSignal = signal(false);
|
|
228
|
+
this.localSelectedDateSignal = signal(null);
|
|
229
|
+
this.allowBookingOnDisabledDaySignal = signal(false);
|
|
230
|
+
this.currentSelectionSignal = signal(null);
|
|
231
|
+
// Time functionality signals
|
|
232
|
+
this.selectedHourSignal = signal(0);
|
|
233
|
+
this.selectedMinuteSignal = signal(0);
|
|
234
|
+
this.selectedAmPmSignal = signal('AM');
|
|
235
|
+
this.isSelectingMonthSignal = signal(false);
|
|
236
|
+
this.isSelectingYearSignal = signal(false);
|
|
237
|
+
this.availableYearsSignal = signal([]);
|
|
238
|
+
this.availableMonthsSignal = signal([]);
|
|
239
|
+
this.disabledMonthsSignal = signal([]);
|
|
240
|
+
this.disabledYearsSignal = signal([]);
|
|
241
|
+
this.selectedYearSignal = signal(0);
|
|
242
|
+
this.isYearSelectionFlowSignal = signal(false);
|
|
243
|
+
// Computed properties for template access
|
|
244
|
+
this.weekDays = computed(() => this.weekDaysSignal());
|
|
245
|
+
this.currentMonthNumber = computed(() => this.currentMonthNumberSignal());
|
|
246
|
+
this.currentMonth = computed(() => this.currentMonthSignal());
|
|
247
|
+
this.currentYearNumber = computed(() => this.currentYearNumberSignal());
|
|
248
|
+
this.currentMonthDates = computed(() => this.currentMonthDatesSignal());
|
|
249
|
+
this.isPreviousMonthDisabled = computed(() => this.isPreviousMonthDisabledSignal());
|
|
250
|
+
this.isNextMonthDisabled = computed(() => this.isNextMonthDisabledSignal());
|
|
251
|
+
this.localSelectedDate = computed(() => this.localSelectedDateSignal());
|
|
252
|
+
this.allowBookingOnDisabledDay = computed(() => this.allowBookingOnDisabledDaySignal());
|
|
253
|
+
this.currentSelection = computed(() => this.currentSelectionSignal());
|
|
254
|
+
// Time functionality computed properties
|
|
255
|
+
this.selectedHour = computed(() => this.selectedHourSignal());
|
|
256
|
+
this.selectedMinute = computed(() => this.selectedMinuteSignal());
|
|
257
|
+
this.selectedAmPm = computed(() => this.selectedAmPmSignal());
|
|
258
|
+
this.isSelectingMonth = computed(() => this.isSelectingMonthSignal());
|
|
259
|
+
this.isSelectingYear = computed(() => this.isSelectingYearSignal());
|
|
260
|
+
this.availableYears = computed(() => this.availableYearsSignal());
|
|
261
|
+
this.availableMonths = computed(() => this.availableMonthsSignal());
|
|
262
|
+
this.disabledMonths = computed(() => this.disabledMonthsSignal());
|
|
263
|
+
this.disabledYears = computed(() => this.disabledYearsSignal());
|
|
264
|
+
this.selectedYear = computed(() => this.selectedYearSignal());
|
|
265
|
+
this.isYearSelectionFlow = computed(() => this.isYearSelectionFlowSignal());
|
|
240
266
|
this.data = data;
|
|
241
267
|
// Initialize parseZoneInstance with better error handling
|
|
242
268
|
this.parseZoneInstance = (...args) => {
|
|
@@ -253,14 +279,14 @@ export class TzDpContainerComponent {
|
|
|
253
279
|
return dayjs(...args);
|
|
254
280
|
}
|
|
255
281
|
};
|
|
256
|
-
// Set default values safely
|
|
257
|
-
this.
|
|
258
|
-
this.
|
|
259
|
-
this.
|
|
260
|
-
this.
|
|
282
|
+
// Set default values safely using signals
|
|
283
|
+
this.currentMonthNumberSignal.set(this.parseZoneInstance().month());
|
|
284
|
+
this.currentMonthSignal.set(getMonth(this.currentMonthNumberSignal()));
|
|
285
|
+
this.currentYearNumberSignal.set(this.parseZoneInstance().year());
|
|
286
|
+
this.weekDaysSignal.set(this.rawWeekDays.map((day, index) => ({
|
|
261
287
|
label: `${day[0]}${day.slice(1).toLowerCase()}`,
|
|
262
288
|
isCurrentDay: this.parseZoneInstance().day() === index
|
|
263
|
-
}));
|
|
289
|
+
})));
|
|
264
290
|
if (!this.data?.dpConfig?.format) {
|
|
265
291
|
this.data.dpConfig = {
|
|
266
292
|
...this.data.dpConfig,
|
|
@@ -270,8 +296,8 @@ export class TzDpContainerComponent {
|
|
|
270
296
|
if (!this.data?.date) {
|
|
271
297
|
this.data.date = this.parseZoneInstance().format(this.data.dpConfig.format);
|
|
272
298
|
}
|
|
273
|
-
this.
|
|
274
|
-
this.
|
|
299
|
+
this.availableMonthsSignal.set(Array.from({ length: 12 }, (_, i) => dayjs().month(i).format('MMMM')));
|
|
300
|
+
this.availableYearsSignal.set(Array.from({ length: 12 }, (_, index) => this.currentYearNumberSignal() - 6 + index));
|
|
275
301
|
}
|
|
276
302
|
onHourInput(event) {
|
|
277
303
|
if (this.data.dpConfig.enableTime !== true)
|
|
@@ -280,12 +306,12 @@ export class TzDpContainerComponent {
|
|
|
280
306
|
if (!isNaN(value)) {
|
|
281
307
|
if (this.is12HourFormat()) {
|
|
282
308
|
if (value >= 1 && value <= 12) {
|
|
283
|
-
this.
|
|
309
|
+
this.selectedHourSignal.set(value);
|
|
284
310
|
}
|
|
285
311
|
}
|
|
286
312
|
else {
|
|
287
313
|
if (value >= 0 && value <= 23) {
|
|
288
|
-
this.
|
|
314
|
+
this.selectedHourSignal.set(value);
|
|
289
315
|
}
|
|
290
316
|
}
|
|
291
317
|
}
|
|
@@ -295,32 +321,32 @@ export class TzDpContainerComponent {
|
|
|
295
321
|
return;
|
|
296
322
|
const value = parseInt(event.target.value);
|
|
297
323
|
if (!isNaN(value) && value >= 0 && value <= 59) {
|
|
298
|
-
this.
|
|
324
|
+
this.selectedMinuteSignal.set(value);
|
|
299
325
|
}
|
|
300
326
|
}
|
|
301
327
|
validateHourInput() {
|
|
302
328
|
if (this.data.dpConfig.enableTime !== true)
|
|
303
329
|
return;
|
|
304
330
|
if (this.is12HourFormat()) {
|
|
305
|
-
if (this.
|
|
306
|
-
this.
|
|
307
|
-
if (this.
|
|
308
|
-
this.
|
|
331
|
+
if (this.selectedHourSignal() < 1)
|
|
332
|
+
this.selectedHourSignal.set(1);
|
|
333
|
+
if (this.selectedHourSignal() > 12)
|
|
334
|
+
this.selectedHourSignal.set(12);
|
|
309
335
|
}
|
|
310
336
|
else {
|
|
311
|
-
if (this.
|
|
312
|
-
this.
|
|
313
|
-
if (this.
|
|
314
|
-
this.
|
|
337
|
+
if (this.selectedHourSignal() < 0)
|
|
338
|
+
this.selectedHourSignal.set(0);
|
|
339
|
+
if (this.selectedHourSignal() > 23)
|
|
340
|
+
this.selectedHourSignal.set(23);
|
|
315
341
|
}
|
|
316
342
|
}
|
|
317
343
|
validateMinuteInput() {
|
|
318
344
|
if (this.data.dpConfig.enableTime !== true)
|
|
319
345
|
return;
|
|
320
|
-
if (this.
|
|
321
|
-
this.
|
|
322
|
-
if (this.
|
|
323
|
-
this.
|
|
346
|
+
if (this.selectedMinuteSignal() < 0)
|
|
347
|
+
this.selectedMinuteSignal.set(0);
|
|
348
|
+
if (this.selectedMinuteSignal() > 59)
|
|
349
|
+
this.selectedMinuteSignal.set(59);
|
|
324
350
|
}
|
|
325
351
|
is12HourFormat() {
|
|
326
352
|
return this.data.dpConfig.enableTime === true &&
|
|
@@ -333,14 +359,14 @@ export class TzDpContainerComponent {
|
|
|
333
359
|
this.currentDateInstance();
|
|
334
360
|
this.calculateMinMaxDays();
|
|
335
361
|
this.calculateDisabledMonthsAndYears();
|
|
336
|
-
this.generateDates(this.
|
|
362
|
+
this.currentMonthDatesSignal.set(this.generateDates(this.currentMonthNumberSignal(), this.currentYearNumberSignal()));
|
|
337
363
|
// Initialize time if enabled
|
|
338
364
|
if (this.data.dpConfig.enableTime === true) {
|
|
339
365
|
this.initializeTimeValues();
|
|
340
366
|
}
|
|
341
367
|
}
|
|
342
368
|
get yearRange() {
|
|
343
|
-
return `${this.
|
|
369
|
+
return `${this.selectedYearSignal() - 6} - ${this.selectedYearSignal() + 5}`;
|
|
344
370
|
}
|
|
345
371
|
initializeTimeValues() {
|
|
346
372
|
if (this.data.dpConfig.enableTime === true) {
|
|
@@ -350,24 +376,24 @@ export class TzDpContainerComponent {
|
|
|
350
376
|
const currentDate = this.parseZoneInstance(this.data.date, this.data.dpConfig.format);
|
|
351
377
|
if (currentDate.isValid()) {
|
|
352
378
|
let hour = currentDate.hour();
|
|
353
|
-
this.
|
|
379
|
+
this.selectedMinuteSignal.set(currentDate.minute());
|
|
354
380
|
if (this.is12HourFormat()) {
|
|
355
381
|
if (hour === 0) {
|
|
356
382
|
hour = 12;
|
|
357
|
-
this.
|
|
383
|
+
this.selectedAmPmSignal.set('AM');
|
|
358
384
|
}
|
|
359
385
|
else if (hour > 12) {
|
|
360
386
|
hour = hour - 12;
|
|
361
|
-
this.
|
|
387
|
+
this.selectedAmPmSignal.set('PM');
|
|
362
388
|
}
|
|
363
389
|
else if (hour === 12) {
|
|
364
|
-
this.
|
|
390
|
+
this.selectedAmPmSignal.set('PM');
|
|
365
391
|
}
|
|
366
392
|
else {
|
|
367
|
-
this.
|
|
393
|
+
this.selectedAmPmSignal.set('AM');
|
|
368
394
|
}
|
|
369
395
|
}
|
|
370
|
-
this.
|
|
396
|
+
this.selectedHourSignal.set(hour);
|
|
371
397
|
}
|
|
372
398
|
else {
|
|
373
399
|
// Invalid date, use defaults
|
|
@@ -409,15 +435,15 @@ export class TzDpContainerComponent {
|
|
|
409
435
|
else {
|
|
410
436
|
amPm = 'AM';
|
|
411
437
|
}
|
|
412
|
-
this.
|
|
413
|
-
this.
|
|
414
|
-
this.
|
|
438
|
+
this.selectedHourSignal.set(hour12);
|
|
439
|
+
this.selectedMinuteSignal.set(currentMinute);
|
|
440
|
+
this.selectedAmPmSignal.set(amPm);
|
|
415
441
|
}
|
|
416
442
|
else {
|
|
417
443
|
// Use current time directly for 24-hour format
|
|
418
|
-
this.
|
|
419
|
-
this.
|
|
420
|
-
this.
|
|
444
|
+
this.selectedHourSignal.set(currentHour);
|
|
445
|
+
this.selectedMinuteSignal.set(currentMinute);
|
|
446
|
+
this.selectedAmPmSignal.set('AM'); // Not used in 24-hour format but keep consistent
|
|
421
447
|
}
|
|
422
448
|
}
|
|
423
449
|
currentDateInstance() {
|
|
@@ -425,94 +451,97 @@ export class TzDpContainerComponent {
|
|
|
425
451
|
if (this.data.date) {
|
|
426
452
|
const selectedDate = dayjs(this.data.date, this.data.dpConfig.format);
|
|
427
453
|
if (selectedDate.isValid()) {
|
|
428
|
-
this.
|
|
429
|
-
this.
|
|
430
|
-
this.
|
|
431
|
-
|
|
432
|
-
|
|
454
|
+
this.selectedYearSignal.set(selectedDate.year());
|
|
455
|
+
this.currentYearNumberSignal.set(selectedDate.year());
|
|
456
|
+
this.currentMonthNumberSignal.set(selectedDate.month());
|
|
457
|
+
this.currentMonthSignal.set(getMonth(selectedDate.month()));
|
|
458
|
+
if (!this.localSelectedDateSignal()) {
|
|
459
|
+
this.localSelectedDateSignal.set({
|
|
433
460
|
date: selectedDate.date(),
|
|
434
461
|
weekDay: selectedDate.day(),
|
|
435
462
|
month: selectedDate.month(),
|
|
436
463
|
year: selectedDate.year(),
|
|
437
464
|
isSelectedDay: true
|
|
438
|
-
};
|
|
465
|
+
});
|
|
439
466
|
}
|
|
440
467
|
}
|
|
441
468
|
}
|
|
442
469
|
}
|
|
443
470
|
catch (error) {
|
|
444
|
-
this.
|
|
445
|
-
this.
|
|
446
|
-
this.
|
|
471
|
+
this.currentYearNumberSignal.set(this.parseZoneInstance().year());
|
|
472
|
+
this.currentMonthNumberSignal.set(this.parseZoneInstance().month());
|
|
473
|
+
this.currentMonthSignal.set(getMonth(this.currentMonthNumberSignal()));
|
|
447
474
|
}
|
|
448
|
-
this.
|
|
475
|
+
this.currentMonthDatesSignal.set(this.generateDates(this.currentMonthNumberSignal(), this.currentYearNumberSignal()));
|
|
449
476
|
}
|
|
450
477
|
calculateMinMaxDays() {
|
|
451
|
-
const currentInstance = this.parseZoneInstance().year(this.
|
|
478
|
+
const currentInstance = this.parseZoneInstance().year(this.currentYearNumberSignal()).month(this.currentMonthNumberSignal());
|
|
452
479
|
if (this.data.dpConfig.minDate) {
|
|
453
480
|
const minDate = this.parseZoneInstance(this.data.dpConfig.minDate, this.data.dpConfig.format);
|
|
454
481
|
if (minDate?.isValid()) {
|
|
455
|
-
this.
|
|
482
|
+
this.isPreviousMonthDisabledSignal.set(minDate.isSameOrAfter(currentInstance, "month"));
|
|
456
483
|
}
|
|
457
484
|
}
|
|
458
485
|
if (this.data.dpConfig.maxDate) {
|
|
459
486
|
const maxDate = this.parseZoneInstance(this.data.dpConfig.maxDate, this.data.dpConfig.format);
|
|
460
487
|
if (maxDate?.isValid()) {
|
|
461
|
-
this.
|
|
488
|
+
this.isNextMonthDisabledSignal.set(maxDate.isSameOrBefore(currentInstance, "month"));
|
|
462
489
|
}
|
|
463
490
|
}
|
|
464
491
|
}
|
|
465
492
|
calculateDisabledMonthsAndYears() {
|
|
466
493
|
const minDate = !!this.data.dpConfig.minDate ? this.parseZoneInstance(this.data.dpConfig.minDate, this.data.dpConfig.format) : dayjs('invalid');
|
|
467
494
|
const maxDate = !!this.data.dpConfig.maxDate ? this.parseZoneInstance(this.data.dpConfig.maxDate, this.data.dpConfig.format) : dayjs('invalid');
|
|
468
|
-
this.
|
|
469
|
-
const monthDate = this.parseZoneInstance().year(this.
|
|
495
|
+
this.disabledMonthsSignal.set(this.availableMonthsSignal().map((month, index) => {
|
|
496
|
+
const monthDate = this.parseZoneInstance().year(this.selectedYearSignal()).month(index);
|
|
470
497
|
return (minDate.isValid() && monthDate.isBefore(minDate, 'month')) ||
|
|
471
498
|
(maxDate.isValid() && monthDate.isAfter(maxDate, 'month'));
|
|
472
|
-
});
|
|
473
|
-
this.
|
|
499
|
+
}));
|
|
500
|
+
this.disabledYearsSignal.set(this.availableYearsSignal().map((year) => {
|
|
474
501
|
const yearDate = this.parseZoneInstance().year(year);
|
|
475
502
|
return (minDate.isValid() && yearDate.isBefore(minDate, 'year')) ||
|
|
476
503
|
(maxDate.isValid() && yearDate.isAfter(maxDate, 'year'));
|
|
477
|
-
});
|
|
478
|
-
if (this.
|
|
479
|
-
this.
|
|
480
|
-
this.
|
|
504
|
+
}));
|
|
505
|
+
if (this.isSelectingYearSignal()) {
|
|
506
|
+
this.isPreviousMonthDisabledSignal.set(minDate.isValid() && ((this.selectedYearSignal() - 6) <= minDate.year()));
|
|
507
|
+
this.isNextMonthDisabledSignal.set(maxDate.isValid() && ((this.selectedYearSignal() + 5) >= maxDate.year()));
|
|
481
508
|
}
|
|
482
509
|
}
|
|
483
510
|
navigateView(direction) {
|
|
484
|
-
if ((direction === 'NEXT' && (this.
|
|
485
|
-
(direction === 'PREVIOUS' && (this.
|
|
511
|
+
if ((direction === 'NEXT' && (this.isNextMonthDisabledSignal() || this.isSelectingMonthSignal())) ||
|
|
512
|
+
(direction === 'PREVIOUS' && (this.isPreviousMonthDisabledSignal() || this.isSelectingMonthSignal()))) {
|
|
486
513
|
return;
|
|
487
514
|
}
|
|
488
|
-
if (this.
|
|
489
|
-
this.
|
|
490
|
-
this.
|
|
515
|
+
if (this.isSelectingYearSignal()) {
|
|
516
|
+
const newSelectedYear = this.selectedYearSignal() + (direction === "NEXT" ? 12 : -12);
|
|
517
|
+
this.selectedYearSignal.set(newSelectedYear);
|
|
518
|
+
this.availableYearsSignal.set(Array.from({ length: 12 }, (_, index) => newSelectedYear - 6 + index));
|
|
491
519
|
}
|
|
492
520
|
else {
|
|
493
|
-
let thisMonth = this.parseZoneInstance().year(this.
|
|
521
|
+
let thisMonth = this.parseZoneInstance().year(this.currentYearNumberSignal()).month(this.currentMonthNumberSignal());
|
|
494
522
|
thisMonth = direction === "NEXT" ? thisMonth.add(1, "month") : thisMonth.subtract(1, "month");
|
|
495
|
-
this.
|
|
496
|
-
this.
|
|
497
|
-
this.
|
|
498
|
-
this.
|
|
523
|
+
this.currentMonthNumberSignal.set(thisMonth.month());
|
|
524
|
+
this.currentMonthSignal.set(getMonth(thisMonth.month()));
|
|
525
|
+
this.selectedYearSignal.set(thisMonth.year());
|
|
526
|
+
this.currentYearNumberSignal.set(thisMonth.year());
|
|
527
|
+
this.currentMonthDatesSignal.set(this.generateDates(thisMonth.month(), thisMonth.year()));
|
|
499
528
|
}
|
|
500
529
|
this.calculateMinMaxDays();
|
|
501
530
|
this.calculateDisabledMonthsAndYears();
|
|
502
531
|
}
|
|
503
532
|
navigateMonth(direction) {
|
|
504
533
|
try {
|
|
505
|
-
let thisMonth = dayjs().year(this.
|
|
534
|
+
let thisMonth = dayjs().year(this.currentYearNumberSignal()).month(this.currentMonthNumberSignal());
|
|
506
535
|
if (direction === "NEXT") {
|
|
507
536
|
thisMonth = thisMonth.add(1, "month");
|
|
508
537
|
}
|
|
509
538
|
else if (direction === "PREVIOUS") {
|
|
510
539
|
thisMonth = thisMonth.subtract(1, "month");
|
|
511
540
|
}
|
|
512
|
-
this.
|
|
513
|
-
this.
|
|
514
|
-
this.
|
|
515
|
-
this.
|
|
541
|
+
this.currentMonthNumberSignal.set(thisMonth.month());
|
|
542
|
+
this.currentMonthSignal.set(getMonth(thisMonth.month()));
|
|
543
|
+
this.currentYearNumberSignal.set(thisMonth.year());
|
|
544
|
+
this.currentMonthDatesSignal.set(this.generateDates(thisMonth.month(), thisMonth.year()));
|
|
516
545
|
this.calculateMinMaxDays();
|
|
517
546
|
}
|
|
518
547
|
catch (error) {
|
|
@@ -556,13 +585,13 @@ export class TzDpContainerComponent {
|
|
|
556
585
|
const isCurrentDay = currentDateInstance.format(this.data.dpConfig.format) === dayjs().format(this.data.dpConfig.format);
|
|
557
586
|
let isSelectedDay = false;
|
|
558
587
|
// Prioritize current selection over previously applied date
|
|
559
|
-
if (this.
|
|
560
|
-
this.
|
|
561
|
-
this.
|
|
562
|
-
this.
|
|
588
|
+
if (this.localSelectedDateSignal() &&
|
|
589
|
+
this.localSelectedDateSignal().date === currentDate &&
|
|
590
|
+
this.localSelectedDateSignal().month === month &&
|
|
591
|
+
this.localSelectedDateSignal().year === currentYearNumber) {
|
|
563
592
|
isSelectedDay = true;
|
|
564
593
|
}
|
|
565
|
-
else if (this.data.date && !this.
|
|
594
|
+
else if (this.data.date && !this.localSelectedDateSignal()) {
|
|
566
595
|
// Only check previously applied date if no current selection
|
|
567
596
|
try {
|
|
568
597
|
if (this.data.dpConfig.enableTime) {
|
|
@@ -630,21 +659,21 @@ export class TzDpContainerComponent {
|
|
|
630
659
|
return;
|
|
631
660
|
try {
|
|
632
661
|
// Create the base date selection without time
|
|
633
|
-
this.
|
|
662
|
+
this.currentSelectionSignal.set(this.parseZoneInstance().year(this.currentYearNumberSignal()).month(this.currentMonthNumberSignal()).date(day.date).hour(0).minute(0).second(0).millisecond(0));
|
|
634
663
|
// Apply the current time values to the selection
|
|
635
664
|
if (this.data.dpConfig.enableTime === true) {
|
|
636
|
-
let hour = this.
|
|
665
|
+
let hour = this.selectedHourSignal();
|
|
637
666
|
if (this.is12HourFormat()) {
|
|
638
|
-
if (this.
|
|
667
|
+
if (this.selectedAmPmSignal() === 'PM' && hour !== 12) {
|
|
639
668
|
hour += 12;
|
|
640
669
|
}
|
|
641
|
-
else if (this.
|
|
670
|
+
else if (this.selectedAmPmSignal() === 'AM' && hour === 12) {
|
|
642
671
|
hour = 0;
|
|
643
672
|
}
|
|
644
673
|
}
|
|
645
|
-
this.
|
|
674
|
+
this.currentSelectionSignal.set(this.currentSelectionSignal()
|
|
646
675
|
.hour(hour)
|
|
647
|
-
.minute(this.
|
|
676
|
+
.minute(this.selectedMinuteSignal()));
|
|
648
677
|
}
|
|
649
678
|
let maxDate = null;
|
|
650
679
|
let minDate = null;
|
|
@@ -664,17 +693,17 @@ export class TzDpContainerComponent {
|
|
|
664
693
|
// Silently handle min date parsing error
|
|
665
694
|
}
|
|
666
695
|
}
|
|
667
|
-
this.
|
|
668
|
-
if (((!minDate || this.
|
|
669
|
-
this.
|
|
696
|
+
this.allowBookingOnDisabledDaySignal.set(this.data.allowBookingOnDisabledDay);
|
|
697
|
+
if (((!minDate || this.currentSelectionSignal().isSameOrAfter(minDate)) && (!maxDate || this.currentSelectionSignal().isSameOrBefore(maxDate)) && this.allowBookingOnDisabledDaySignal()) || (!day.isDisabledDay && !this.allowBookingOnDisabledDaySignal())) {
|
|
698
|
+
this.localSelectedDateSignal.set({
|
|
670
699
|
...day,
|
|
671
|
-
month: this.
|
|
672
|
-
year: this.
|
|
673
|
-
};
|
|
700
|
+
month: this.currentMonthNumberSignal(),
|
|
701
|
+
year: this.currentYearNumberSignal()
|
|
702
|
+
});
|
|
674
703
|
// Force calendar re-render to show highlighting
|
|
675
|
-
this.
|
|
676
|
-
// Automatically
|
|
677
|
-
if (!this.data.dpConfig.enableTime) {
|
|
704
|
+
this.currentMonthDatesSignal.set(this.generateDates(this.currentMonthNumberSignal(), this.currentYearNumberSignal()));
|
|
705
|
+
// Automatically apply when neither time nor apply button is enabled, otherwise wait for user action
|
|
706
|
+
if (!this.data.dpConfig.enableTime && !this.data.dpConfig.showApplyButton) {
|
|
678
707
|
this.applyDate(day);
|
|
679
708
|
}
|
|
680
709
|
}
|
|
@@ -691,22 +720,22 @@ export class TzDpContainerComponent {
|
|
|
691
720
|
try {
|
|
692
721
|
if (this.data.dpConfig.enableTime === true) {
|
|
693
722
|
// Always use time input values when time is enabled, regardless of currentSelection
|
|
694
|
-
let hour = this.
|
|
723
|
+
let hour = this.selectedHourSignal();
|
|
695
724
|
if (this.is12HourFormat()) {
|
|
696
|
-
if (this.
|
|
725
|
+
if (this.selectedAmPmSignal() === 'PM' && hour !== 12) {
|
|
697
726
|
hour += 12;
|
|
698
727
|
}
|
|
699
|
-
else if (this.
|
|
728
|
+
else if (this.selectedAmPmSignal() === 'AM' && hour === 12) {
|
|
700
729
|
hour = 0;
|
|
701
730
|
}
|
|
702
731
|
}
|
|
703
732
|
// Create a new date instance with the selected time
|
|
704
733
|
const finalSelection = dayjs()
|
|
705
|
-
.year(this.
|
|
706
|
-
.month(this.
|
|
707
|
-
.date(this.
|
|
734
|
+
.year(this.currentYearNumberSignal())
|
|
735
|
+
.month(this.currentMonthNumberSignal())
|
|
736
|
+
.date(this.localSelectedDateSignal()?.date || day?.date || dayjs().date())
|
|
708
737
|
.hour(hour)
|
|
709
|
-
.minute(this.
|
|
738
|
+
.minute(this.selectedMinuteSignal())
|
|
710
739
|
.second(0)
|
|
711
740
|
.millisecond(0);
|
|
712
741
|
date = finalSelection.format(this.data.dpConfig.format);
|
|
@@ -714,16 +743,16 @@ export class TzDpContainerComponent {
|
|
|
714
743
|
else {
|
|
715
744
|
// Date-only format - no time
|
|
716
745
|
date = dayjs()
|
|
717
|
-
.year(this.
|
|
718
|
-
.month(this.
|
|
719
|
-
.date(day ? day.date : this.
|
|
746
|
+
.year(this.currentYearNumberSignal())
|
|
747
|
+
.month(this.currentMonthNumberSignal())
|
|
748
|
+
.date(day ? day.date : this.localSelectedDateSignal()?.date || dayjs().date())
|
|
720
749
|
.hour(0)
|
|
721
750
|
.minute(0)
|
|
722
751
|
.second(0)
|
|
723
752
|
.millisecond(0)
|
|
724
753
|
.format(this.data.dpConfig.format);
|
|
725
754
|
}
|
|
726
|
-
if (day || this.
|
|
755
|
+
if (day || this.localSelectedDateSignal() || (this.data.dpConfig.enableTime === true)) {
|
|
727
756
|
this.data.dateChange(date);
|
|
728
757
|
}
|
|
729
758
|
else {
|
|
@@ -742,44 +771,45 @@ export class TzDpContainerComponent {
|
|
|
742
771
|
this.data.dateChange("");
|
|
743
772
|
}
|
|
744
773
|
toggleMonthSelector() {
|
|
745
|
-
if (this.
|
|
774
|
+
if (this.isYearSelectionFlowSignal())
|
|
746
775
|
return;
|
|
747
|
-
this.
|
|
748
|
-
this.
|
|
776
|
+
this.isSelectingMonthSignal.set(!this.isSelectingMonthSignal());
|
|
777
|
+
this.isSelectingYearSignal.set(false);
|
|
749
778
|
this.calculateDisabledMonthsAndYears();
|
|
750
779
|
}
|
|
751
780
|
toggleYearSelector() {
|
|
752
|
-
this.
|
|
753
|
-
this.
|
|
754
|
-
this.
|
|
755
|
-
this.
|
|
781
|
+
this.isSelectingYearSignal.set(!this.isSelectingYearSignal());
|
|
782
|
+
this.selectedYearSignal.set(this.currentYearNumberSignal());
|
|
783
|
+
this.availableYearsSignal.set(Array.from({ length: 12 }, (_, index) => this.selectedYearSignal() - 6 + index));
|
|
784
|
+
this.isSelectingMonthSignal.set(false);
|
|
756
785
|
this.calculateDisabledMonthsAndYears();
|
|
757
786
|
}
|
|
758
787
|
resetDateSelection() {
|
|
759
|
-
this.
|
|
788
|
+
this.localSelectedDateSignal.set({
|
|
760
789
|
date: 0,
|
|
761
790
|
weekDay: 0,
|
|
762
791
|
isCurrentDay: false,
|
|
763
792
|
isSelectedDay: false,
|
|
764
793
|
isDisabledDay: false,
|
|
765
794
|
toastMessage: ''
|
|
766
|
-
};
|
|
795
|
+
});
|
|
767
796
|
this.data.date = '';
|
|
768
797
|
}
|
|
769
798
|
selectMonth(month) {
|
|
770
|
-
this.
|
|
771
|
-
this.
|
|
772
|
-
this.
|
|
773
|
-
this.
|
|
799
|
+
this.currentMonthNumberSignal.set(this.availableMonthsSignal().indexOf(month));
|
|
800
|
+
this.currentMonthSignal.set(getMonth(this.currentMonthNumberSignal()));
|
|
801
|
+
this.isSelectingMonthSignal.set(false);
|
|
802
|
+
this.isYearSelectionFlowSignal.set(false);
|
|
774
803
|
this.resetDateSelection();
|
|
775
|
-
this.
|
|
804
|
+
this.currentMonthDatesSignal.set(this.generateDates(this.currentMonthNumberSignal(), this.currentYearNumberSignal()));
|
|
776
805
|
this.calculateMinMaxDays();
|
|
777
806
|
}
|
|
778
807
|
selectYear(year) {
|
|
779
|
-
this.
|
|
780
|
-
this.
|
|
781
|
-
this.
|
|
782
|
-
this.
|
|
808
|
+
this.selectedYearSignal.set(year);
|
|
809
|
+
this.currentYearNumberSignal.set(year);
|
|
810
|
+
this.isSelectingYearSignal.set(false);
|
|
811
|
+
this.isSelectingMonthSignal.set(true);
|
|
812
|
+
this.isYearSelectionFlowSignal.set(true);
|
|
783
813
|
this.resetDateSelection();
|
|
784
814
|
this.calculateDisabledMonthsAndYears();
|
|
785
815
|
}
|
|
@@ -812,21 +842,21 @@ export class TzDpContainerComponent {
|
|
|
812
842
|
} if (rf & 2) {
|
|
813
843
|
i0.ɵɵproperty("ngClass", ctx.data.disableBoxShadow ? "remove-box-shadow" : "")("cdkTrapFocusAutoCapture", true);
|
|
814
844
|
i0.ɵɵadvance(3);
|
|
815
|
-
i0.ɵɵproperty("ngClass", i0.ɵɵpureFunction1(12, _c0, ctx.isPreviousMonthDisabled || ctx.isSelectingMonth));
|
|
845
|
+
i0.ɵɵproperty("ngClass", i0.ɵɵpureFunction1(12, _c0, ctx.isPreviousMonthDisabled() || ctx.isSelectingMonth()));
|
|
816
846
|
i0.ɵɵadvance(3);
|
|
817
|
-
i0.ɵɵproperty("ngIf", !ctx.isSelectingYear);
|
|
847
|
+
i0.ɵɵproperty("ngIf", !ctx.isSelectingYear());
|
|
818
848
|
i0.ɵɵadvance();
|
|
819
|
-
i0.ɵɵproperty("ngIf", !ctx.isSelectingMonth);
|
|
849
|
+
i0.ɵɵproperty("ngIf", !ctx.isSelectingMonth());
|
|
820
850
|
i0.ɵɵadvance();
|
|
821
|
-
i0.ɵɵproperty("ngClass", i0.ɵɵpureFunction1(14, _c0, ctx.isNextMonthDisabled || ctx.isSelectingMonth));
|
|
851
|
+
i0.ɵɵproperty("ngClass", i0.ɵɵpureFunction1(14, _c0, ctx.isNextMonthDisabled() || ctx.isSelectingMonth()));
|
|
822
852
|
i0.ɵɵadvance(4);
|
|
823
|
-
i0.ɵɵproperty("ngIf", ctx.isSelectingMonth && !ctx.isSelectingYear);
|
|
853
|
+
i0.ɵɵproperty("ngIf", ctx.isSelectingMonth() && !ctx.isSelectingYear());
|
|
824
854
|
i0.ɵɵadvance();
|
|
825
|
-
i0.ɵɵproperty("ngIf", ctx.isSelectingYear && !ctx.isSelectingMonth);
|
|
855
|
+
i0.ɵɵproperty("ngIf", ctx.isSelectingYear() && !ctx.isSelectingMonth());
|
|
826
856
|
i0.ɵɵadvance();
|
|
827
|
-
i0.ɵɵproperty("ngIf", !ctx.isSelectingMonth && !ctx.isSelectingYear);
|
|
857
|
+
i0.ɵɵproperty("ngIf", !ctx.isSelectingMonth() && !ctx.isSelectingYear());
|
|
828
858
|
i0.ɵɵadvance();
|
|
829
|
-
i0.ɵɵproperty("ngIf", !ctx.isSelectingMonth && !ctx.isSelectingYear);
|
|
859
|
+
i0.ɵɵproperty("ngIf", !ctx.isSelectingMonth() && !ctx.isSelectingYear());
|
|
830
860
|
i0.ɵɵadvance();
|
|
831
861
|
i0.ɵɵproperty("ngIf", ctx.data.dpConfig.enableTime === true);
|
|
832
862
|
i0.ɵɵadvance();
|
|
@@ -835,7 +865,7 @@ export class TzDpContainerComponent {
|
|
|
835
865
|
}
|
|
836
866
|
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(TzDpContainerComponent, [{
|
|
837
867
|
type: Component,
|
|
838
|
-
args: [{ selector: "mis-tz-dp", template: "<div class=\"datepicker-container\" [ngClass]=\"data.disableBoxShadow?'remove-box-shadow':''\" aria-label=\"date picker\" cdkTrapFocus [cdkTrapFocusAutoCapture]=\"true\">\n <div tabindex=\"-1\" cdkFocusInitial></div>\n <div class=\"datepicker-container__header\">\n <div\n class=\"datepicker-container__arrow__icon\"\n (click)=\"navigateView('PREVIOUS')\"\n tabindex=\"0\"\n aria-label=\"Previous Month\"\n (keyup.enter)=\"navigateView('PREVIOUS')\"\n [ngClass]=\"{\n 'disabled-month': isPreviousMonthDisabled || isSelectingMonth\n }\"\n >\n <svg width=\"20\" height=\"16\" viewBox=\"0 0 20 16\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n <path\n d=\"M19.7071 8.70711C20.0976 8.31658 20.0976 7.68342 19.7071 7.29289L13.3431 0.928933C12.9526 0.538409 12.3195 0.538409 11.9289 0.928933C11.5384 1.31946 11.5384 1.95262 11.9289 2.34315L17.5858 8L11.9289 13.6569C11.5384 14.0474 11.5384 14.6805 11.9289 15.0711C12.3195 15.4616 12.9526 15.4616 13.3431 15.0711L19.7071 8.70711ZM-8.74228e-08 9L19 9L19 7L8.74228e-08 7L-8.74228e-08 9Z\"\n fill=\"#181F33\"\n ></path>\n </svg>\n </div>\n\n <div *ngIf=\"!isSelectingYear\" (click)=\"toggleMonthSelector()\" class=\"month-header\">\n {{ isYearSelectionFlow ? selectedYear : availableMonths[currentMonthNumber] }}\n </div>\n <div *ngIf=\"!isSelectingMonth\" (click)=\"toggleYearSelector()\" class=\"year-header\">\n {{ isSelectingYear ? yearRange : currentYearNumber }}\n </div>\n\n\n <div\n class=\"datepicker-container__arrow__icon\"\n (click)=\"navigateView('NEXT')\"\n tabindex=\"0\"\n aria-label=\"Next Month\"\n (keyup.enter)=\"navigateView('NEXT')\"\n [ngClass]=\"{\n 'disabled-month': isNextMonthDisabled || isSelectingMonth\n }\"\n >\n <svg width=\"20\" height=\"16\" viewBox=\"0 0 20 16\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n <path\n d=\"M19.7071 8.70711C20.0976 8.31658 20.0976 7.68342 19.7071 7.29289L13.3431 0.928933C12.9526 0.538409 12.3195 0.538409 11.9289 0.928933C11.5384 1.31946 11.5384 1.95262 11.9289 2.34315L17.5858 8L11.9289 13.6569C11.5384 14.0474 11.5384 14.6805 11.9289 15.0711C12.3195 15.4616 12.9526 15.4616 13.3431 15.0711L19.7071 8.70711ZM-8.74228e-08 9L19 9L19 7L8.74228e-08 7L-8.74228e-08 9Z\"\n fill=\"#181F33\"\n ></path>\n </svg>\n </div>\n </div>\n <div class=\"datepicker-container__body\">\n\n <div *ngIf=\"isSelectingMonth && !isSelectingYear\" class=\"month-selector\">\n <div class=\"row\">\n <div *ngFor=\"let month of availableMonths; let i = index\" \n class=\"month\" \n (click)=\"!disabledMonths[i] && selectMonth(month)\" \n [ngClass]=\"{\n 'disable-month': disabledMonths[i],\n 'select-month': !disabledMonths[currentMonthNumber] && month === availableMonths[currentMonthNumber]\n }\">\n {{ month }}\n </div>\n </div>\n </div>\n \n <div *ngIf=\"isSelectingYear && !isSelectingMonth\" class=\"year-selector\">\n <div class=\"row\">\n <div *ngFor=\"let year of availableYears; let i = index\" \n class=\"year\" \n (click)=\"!disabledYears[i] && selectYear(year)\" \n [ngClass]=\"{\n 'disable-year': disabledYears[i],\n 'select-year': year === currentYearNumber\n }\">\n {{ year }}\n </div>\n </div>\n </div>\n\n <div *ngIf=\"!isSelectingMonth && !isSelectingYear\" class=\"datepicker-container__weekdays\">\n <div class=\"datepicker-container__weekday\" *ngFor=\"let weekDay of weekDays\">\n <span [ngClass]=\"{ 'current-day': weekDay.isCurrentDay }\">{{ weekDay.label }}</span>\n </div>\n </div>\n <div *ngIf=\"!isSelectingMonth && !isSelectingYear\" class=\"datepicker-container__days\">\n <div\n class=\"datepicker-container__day\"\n [ngClass]=\"{\n 'selected-day': day.isSelectedDay,\n 'disabled-day': day.isDisabledDay,\n 'is-valid-date': day.date > 0 && !day.isSelectedDay\n }\"\n *ngFor=\"let day of currentMonthDates\"\n (click)=\"selectDay(day)\"\n (keyup.enter)=\"selectDay(day)\"\n >\n <span\n *ngIf=\"day.date > 0\"\n [tabindex]=\"day.isDisabledDay ? -1 : 0\"\n [ngClass]=\"{\n 'current-day': day.isCurrentDay,\n 'selected-day': day.isSelectedDay,\n 'disabled-day': day.isDisabledDay\n }\"\n [attr.aria-label]=\"retractDayMonth(day.date, currentMonth, currentYearNumber)\"\n >\n {{ day.date }}\n </span>\n </div>\n </div>\n </div>\n\n <!-- Time Picker Section -->\n <div class=\"datepicker-container__time\" *ngIf=\"data.dpConfig.enableTime === true\">\n <div class=\"time-picker-header\">\n <span>Time</span>\n </div>\n <div class=\"time-picker-controls\">\n <div class=\"time-input-group\">\n <label for=\"hourInput\">Hour</label>\n <input \n id=\"hourInput\"\n type=\"number\" \n [min]=\"is12HourFormat() ? 1 : 0\"\n [max]=\"is12HourFormat() ? 12 : 23\"\n [step]=\"1\"\n [(ngModel)]=\"selectedHour\"\n (input)=\"onHourInput($event)\"\n (blur)=\"validateHourInput()\"\n class=\"time-input\"\n [title]=\"is12HourFormat() ? 'Enter hour (1-12)' : 'Enter hour (0-23)'\">\n </div>\n <div class=\"time-separator\">:</div>\n <div class=\"time-input-group\">\n <label for=\"minuteInput\">Minute</label>\n <input \n id=\"minuteInput\"\n type=\"number\" \n min=\"0\" \n max=\"59\"\n [step]=\"1\"\n [(ngModel)]=\"selectedMinute\"\n (input)=\"onMinuteInput($event)\"\n (blur)=\"validateMinuteInput()\"\n class=\"time-input\"\n title=\"Enter minute (0-59)\">\n </div>\n <div class=\"am-pm-selector\" *ngIf=\"is12HourFormat()\">\n <label for=\"amPmSelect\">AM/PM</label>\n <select \n id=\"amPmSelect\"\n [(ngModel)]=\"selectedAmPm\"\n class=\"am-pm-select\">\n <option value=\"AM\">AM</option>\n <option value=\"PM\">PM</option>\n </select>\n </div>\n </div>\n </div>\n\n <div class=\"datepicker-container__footer\" *ngIf=\"data.dpConfig.showApplyButton || data.dpConfig.enableTime\">\n <button mis-button size=\"md\" type=\"'none'\" (click)=\"cancelDatePicker()\">Cancel</button>\n <button mis-button size=\"md\" type=\"primary\" (click)=\"applyDate()\" [disabled]=\"!(data.date || localSelectedDate.date)\">Apply</button>\n </div>\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,.datepicker-container .datepicker-container__body .month,.datepicker-container .datepicker-container__body .year{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}:root{--pmry-200: #99BAF7;--pmry-100: #CBDDFB;--pmry-500: #0937B2;--pmry-400: #3C68D0;--pmry-600: #062A99;--pmry-700: #041F80;--pmry-300: #638FE7;--pmry-800: #021567;--pmry-900: #010F55;--sec-d-purple: #40447F;--sec-maroon: #6B034E;--sec-mud-red: #B23600;--sec-orange: #ED711C;--sec-purple: #815FD5;--sec-teal: #10ADAE;--sec-yellow: #D4900C;--sec-green: #547F40;--sec-bright-green: #27D22E;--sec-dark-teal: #035F6B;--sec-chocolate: #7C2F33;--sec-rube-pink: #C13D6D;--sec-cerulean: #0087B2;--sem-error: #B00020;--sem-info: #0091FF;--sem-warning: #FF9D00;--sem-success: #38AF49;--grey-bg-1: #FAFAFA;--grey-bg: #F5F5F5;--grey-seperators: #E0E0E0;--grey-disabled: #C8CDD3;--grey-hover: #F5F7FC;--grey-pressed: #E6EBF7;--grey-row: #F5F7FC;--dec-light-yellow: #F4E7C3;--dec-light-purple: #DACFF9;--dec-light-green: #E4F5E9;--dec-light-green2: #F1FFF3;--dec-light-pink: #FAE1EA;--dec-: #F4CBC1;--dec-lt-orange: #FAEFED;--dec-light-blue: #CFECF9;--dec-row-selection: #F1FDF8;--dec-row-selection2: #F2FBFF;--dec-row-lines: #D3E1E9;--text-white: #FFFFFF;--text-disabled: #929DAB;--text-muted: #6A737D;--text-black: #181F33;--MR-solid-blue2:#C8D5F6;--MR-solid-purple:#C9C3FB;--MR-solid-orange:#EEAC9F;--MR-solid-green:#ACDADA;--MR-solid-brown:#E8C8AF;--MR-solid-yellow:#FFEFC7;--MR-solid-blue:#BBE6FF;--MR-solid-pink:#FFC6F2;--tr-hover:#F0F3FA;--tr-pressed:#DAE1F3}.datepicker-container{background:#fff;border:1px solid #e0e0e0;box-shadow:0 12px 24px #0000001f,0 4px 8px #0000001f;border-radius:12px;display:flex;flex-direction:column;font-family:Lato;-webkit-user-select:none;user-select:none;box-sizing:border-box;width:290px}.datepicker-container .datepicker-container__header{display:flex;height:32px;margin:16px;justify-content:space-between;align-items:center;width:258px}.datepicker-container .datepicker-container__header span{font-size:16px;font-style:normal;font-weight:700;line-height:24px;letter-spacing:.2px;text-align:center}.datepicker-container .datepicker-container__header .month-header,.datepicker-container .datepicker-container__header .year-header{padding:8px;border-radius:10px}.datepicker-container .datepicker-container__header .month-header:hover,.datepicker-container .datepicker-container__header .year-header:hover{cursor:pointer;background-color:#e6ebf7}.datepicker-container .datepicker-container__header .datepicker-container__arrow__icon{height:20px;width:20px;display:flex;align-items:center;justify-content:center;border-radius:4px;padding:4px}.datepicker-container .datepicker-container__header .datepicker-container__arrow__icon.disabled-month{opacity:.5;cursor:not-allowed}.datepicker-container .datepicker-container__header .datepicker-container__arrow__icon:not(.disabled-month):hover{cursor:pointer;background-color:#cbddfb}.datepicker-container .datepicker-container__header .datepicker-container__arrow__icon:nth-child(1){transform:rotate(180deg)}.datepicker-container .datepicker-container__body{width:258px;height:100%;margin:0 16px 16px}.datepicker-container .datepicker-container__body .row{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:10px}.datepicker-container .datepicker-container__body .month,.datepicker-container .datepicker-container__body .year{padding:10px 6px;cursor:pointer;border-radius:5px;text-align:center;background-color:#fff}.datepicker-container .datepicker-container__body .month:hover,.datepicker-container .datepicker-container__body .year:hover{background-color:#cbddfb}.datepicker-container .datepicker-container__body .disable-month,.datepicker-container .datepicker-container__body .disable-year{cursor:default;color:#c8cdd3}.datepicker-container .datepicker-container__body .disable-month:hover,.datepicker-container .datepicker-container__body .disable-year:hover{background-color:transparent}.datepicker-container .datepicker-container__body .select-month,.datepicker-container .datepicker-container__body .select-year{background-color:#0937b2;color:#fff}.datepicker-container .datepicker-container__body .select-month:hover,.datepicker-container .datepicker-container__body .select-year:hover{cursor:pointer;background-color:#cbddfb}.datepicker-container .datepicker-container__body .datepicker-container__weekdays{width:100%;display:flex;padding-bottom:10px}.datepicker-container .datepicker-container__body .datepicker-container__weekdays .datepicker-container__weekday{width:36px;height:18px;text-align:center}.datepicker-container .datepicker-container__body .datepicker-container__weekdays .datepicker-container__weekday span{font-size:12px;font-style:normal;font-weight:400;line-height:18px;letter-spacing:.2px;text-align:center;color:#c7c7c7}.datepicker-container .datepicker-container__body .datepicker-container__weekdays .datepicker-container__weekday span.current-day{font-weight:700;letter-spacing:.25px;color:#181f33}.datepicker-container .datepicker-container__body .datepicker-container__days{display:flex;flex-wrap:wrap;gap:2px}.datepicker-container .datepicker-container__body .datepicker-container__days .datepicker-container__day{width:34px;height:34px;display:flex;align-items:center;justify-content:center;border-radius:4px}.datepicker-container .datepicker-container__body .datepicker-container__days .datepicker-container__day.selected-day{background-color:#0937b2;cursor:pointer}.datepicker-container .datepicker-container__body .datepicker-container__days .datepicker-container__day.disabled-day{cursor:default}.datepicker-container .datepicker-container__body .datepicker-container__days .datepicker-container__day.disabled-day:hover{background-color:transparent}.datepicker-container .datepicker-container__body .datepicker-container__days .datepicker-container__day.is-valid-date:not(.disabled-day):not(.selected-day):hover{background-color:#cbddfb;cursor:pointer}.datepicker-container .datepicker-container__body .datepicker-container__days .datepicker-container__day.is-valid-date:not(.disabled-day):not(.selected-day):hover span.selected-day{color:#181f33!important}.datepicker-container .datepicker-container__body .datepicker-container__days .datepicker-container__day span{font-size:14px;font-style:normal;font-weight:400;line-height:20px;letter-spacing:.2px;text-align:center;color:#181f33}.datepicker-container .datepicker-container__body .datepicker-container__days .datepicker-container__day span.current-day{font-weight:700;letter-spacing:.25px}.datepicker-container .datepicker-container__body .datepicker-container__days .datepicker-container__day span.selected-day{color:#fff}.datepicker-container .datepicker-container__body .datepicker-container__days .datepicker-container__day span.disabled-day{color:#c7c7c7}.datepicker-container .datepicker-container__time{border-top:1px solid #e0e0e0;padding:16px;margin:0 16px}.datepicker-container .datepicker-container__time .time-picker-header{margin-bottom:12px}.datepicker-container .datepicker-container__time .time-picker-header span{font-size:14px;font-weight:600;color:#181f33}.datepicker-container .datepicker-container__time .time-picker-controls{display:flex;align-items:center;gap:8px}.datepicker-container .datepicker-container__time .time-picker-controls .time-input-group{display:flex;flex-direction:column;gap:4px}.datepicker-container .datepicker-container__time .time-picker-controls .time-input-group label{font-size:12px;font-weight:500;color:#6a737d}.datepicker-container .datepicker-container__time .time-picker-controls .time-input-group .time-input{width:50px;height:32px;padding:4px 8px;border:1px solid #e0e0e0;border-radius:4px;font-size:14px;text-align:center}.datepicker-container .datepicker-container__time .time-picker-controls .time-input-group .time-input:focus{outline:none;border-color:#0937b2;box-shadow:0 0 0 2px #0937b21a}.datepicker-container .datepicker-container__time .time-picker-controls .time-input-group .time-input:invalid{border-color:#dc3545;background-color:#fff5f5}.datepicker-container .datepicker-container__time .time-picker-controls .time-input-group .time-input::-webkit-inner-spin-button,.datepicker-container .datepicker-container__time .time-picker-controls .time-input-group .time-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.datepicker-container .datepicker-container__time .time-picker-controls .time-input-group .time-input[type=number]{-moz-appearance:textfield}.datepicker-container .datepicker-container__time .time-picker-controls .time-separator{font-size:18px;font-weight:600;color:#181f33;margin-top:20px}.datepicker-container .datepicker-container__time .time-picker-controls .am-pm-selector{display:flex;flex-direction:column;gap:4px}.datepicker-container .datepicker-container__time .time-picker-controls .am-pm-selector label{font-size:12px;font-weight:500;color:#6a737d}.datepicker-container .datepicker-container__time .time-picker-controls .am-pm-selector .am-pm-select{width:60px;height:42px;padding:4px 8px;border:1px solid #e0e0e0;border-radius:4px;font-size:14px;background-color:#fff}.datepicker-container .datepicker-container__time .time-picker-controls .am-pm-selector .am-pm-select:focus{outline:none;border-color:#0937b2;box-shadow:0 0 0 2px #0937b21a}.datepicker-container .datepicker-container__footer{display:flex;justify-content:flex-end;gap:8px;bottom:0;align-items:center;position:sticky;padding:16px;border-top:1px solid #e0e0e0}.remove-box-shadow{box-shadow:none!important;border:none!important;border-radius:0!important}\n"] }]
|
|
868
|
+
args: [{ selector: "mis-tz-dp", template: "<div class=\"datepicker-container\" [ngClass]=\"data.disableBoxShadow?'remove-box-shadow':''\" aria-label=\"date picker\" cdkTrapFocus [cdkTrapFocusAutoCapture]=\"true\">\n <div tabindex=\"-1\" cdkFocusInitial></div>\n <div class=\"datepicker-container__header\">\n <div\n class=\"datepicker-container__arrow__icon\"\n (click)=\"navigateView('PREVIOUS')\"\n tabindex=\"0\"\n aria-label=\"Previous Month\"\n (keyup.enter)=\"navigateView('PREVIOUS')\"\n [ngClass]=\"{\n 'disabled-month': isPreviousMonthDisabled() || isSelectingMonth()\n }\"\n >\n <svg width=\"20\" height=\"16\" viewBox=\"0 0 20 16\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n <path\n d=\"M19.7071 8.70711C20.0976 8.31658 20.0976 7.68342 19.7071 7.29289L13.3431 0.928933C12.9526 0.538409 12.3195 0.538409 11.9289 0.928933C11.5384 1.31946 11.5384 1.95262 11.9289 2.34315L17.5858 8L11.9289 13.6569C11.5384 14.0474 11.5384 14.6805 11.9289 15.0711C12.3195 15.4616 12.9526 15.4616 13.3431 15.0711L19.7071 8.70711ZM-8.74228e-08 9L19 9L19 7L8.74228e-08 7L-8.74228e-08 9Z\"\n fill=\"#181F33\"\n ></path>\n </svg>\n </div>\n\n <div *ngIf=\"!isSelectingYear()\" (click)=\"toggleMonthSelector()\" class=\"month-header\">\n {{ isYearSelectionFlow() ? selectedYear() : availableMonths()[currentMonthNumber()] }}\n </div>\n <div *ngIf=\"!isSelectingMonth()\" (click)=\"toggleYearSelector()\" class=\"year-header\">\n {{ isSelectingYear() ? yearRange : currentYearNumber() }}\n </div>\n\n\n <div\n class=\"datepicker-container__arrow__icon\"\n (click)=\"navigateView('NEXT')\"\n tabindex=\"0\"\n aria-label=\"Next Month\"\n (keyup.enter)=\"navigateView('NEXT')\"\n [ngClass]=\"{\n 'disabled-month': isNextMonthDisabled() || isSelectingMonth()\n }\"\n >\n <svg width=\"20\" height=\"16\" viewBox=\"0 0 20 16\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n <path\n d=\"M19.7071 8.70711C20.0976 8.31658 20.0976 7.68342 19.7071 7.29289L13.3431 0.928933C12.9526 0.538409 12.3195 0.538409 11.9289 0.928933C11.5384 1.31946 11.5384 1.95262 11.9289 2.34315L17.5858 8L11.9289 13.6569C11.5384 14.0474 11.5384 14.6805 11.9289 15.0711C12.3195 15.4616 12.9526 15.4616 13.3431 15.0711L19.7071 8.70711ZM-8.74228e-08 9L19 9L19 7L8.74228e-08 7L-8.74228e-08 9Z\"\n fill=\"#181F33\"\n ></path>\n </svg>\n </div>\n </div>\n <div class=\"datepicker-container__body\">\n\n <div *ngIf=\"isSelectingMonth() && !isSelectingYear()\" class=\"month-selector\">\n <div class=\"row\">\n <div *ngFor=\"let month of availableMonths(); let i = index\" \n class=\"month\" \n (click)=\"!disabledMonths()[i] && selectMonth(month)\" \n [ngClass]=\"{\n 'disable-month': disabledMonths()[i],\n 'select-month': !disabledMonths()[currentMonthNumber()] && month === availableMonths()[currentMonthNumber()]\n }\">\n {{ month }}\n </div>\n </div>\n </div>\n \n <div *ngIf=\"isSelectingYear() && !isSelectingMonth()\" class=\"year-selector\">\n <div class=\"row\">\n <div *ngFor=\"let year of availableYears(); let i = index\" \n class=\"year\" \n (click)=\"!disabledYears()[i] && selectYear(year)\" \n [ngClass]=\"{\n 'disable-year': disabledYears()[i],\n 'select-year': year === currentYearNumber()\n }\">\n {{ year }}\n </div>\n </div>\n </div>\n\n <div *ngIf=\"!isSelectingMonth() && !isSelectingYear()\" class=\"datepicker-container__weekdays\">\n <div class=\"datepicker-container__weekday\" *ngFor=\"let weekDay of weekDays()\">\n <span [ngClass]=\"{ 'current-day': weekDay.isCurrentDay }\">{{ weekDay.label }}</span>\n </div>\n </div>\n <div *ngIf=\"!isSelectingMonth() && !isSelectingYear()\" class=\"datepicker-container__days\">\n <div\n class=\"datepicker-container__day\"\n [ngClass]=\"{\n 'selected-day': day.isSelectedDay,\n 'disabled-day': day.isDisabledDay,\n 'is-valid-date': day.date > 0 && !day.isSelectedDay\n }\"\n *ngFor=\"let day of currentMonthDates()\"\n (click)=\"selectDay(day)\"\n (keyup.enter)=\"selectDay(day)\"\n >\n <span\n *ngIf=\"day.date > 0\"\n [tabindex]=\"day.isDisabledDay ? -1 : 0\"\n [ngClass]=\"{\n 'current-day': day.isCurrentDay,\n 'selected-day': day.isSelectedDay,\n 'disabled-day': day.isDisabledDay\n }\"\n [attr.aria-label]=\"retractDayMonth(day.date, currentMonth(), currentYearNumber())\"\n >\n {{ day.date }}\n </span>\n </div>\n </div>\n </div>\n\n <!-- Time Picker Section -->\n <div class=\"datepicker-container__time\" *ngIf=\"data.dpConfig.enableTime === true\">\n <div class=\"time-picker-header\">\n <span>Time</span>\n </div>\n <div class=\"time-picker-controls\">\n <div class=\"time-input-group\">\n <label for=\"hourInput\">Hour</label>\n <input \n id=\"hourInput\"\n type=\"number\" \n [min]=\"is12HourFormat() ? 1 : 0\"\n [max]=\"is12HourFormat() ? 12 : 23\"\n [step]=\"1\"\n [ngModel]=\"selectedHour()\"\n (ngModelChange)=\"selectedHourSignal.set($event)\"\n (input)=\"onHourInput($event)\"\n (blur)=\"validateHourInput()\"\n class=\"time-input\"\n [title]=\"is12HourFormat() ? 'Enter hour (1-12)' : 'Enter hour (0-23)'\">\n </div>\n <div class=\"time-separator\">:</div>\n <div class=\"time-input-group\">\n <label for=\"minuteInput\">Minute</label>\n <input \n id=\"minuteInput\"\n type=\"number\" \n min=\"0\" \n max=\"59\"\n [step]=\"1\"\n [ngModel]=\"selectedMinute()\"\n (ngModelChange)=\"selectedMinuteSignal.set($event)\"\n (input)=\"onMinuteInput($event)\"\n (blur)=\"validateMinuteInput()\"\n class=\"time-input\"\n title=\"Enter minute (0-59)\">\n </div>\n <div class=\"am-pm-selector\" *ngIf=\"is12HourFormat()\">\n <label for=\"amPmSelect\">AM/PM</label>\n <select \n id=\"amPmSelect\"\n [ngModel]=\"selectedAmPm()\"\n (ngModelChange)=\"selectedAmPmSignal.set($event)\"\n class=\"am-pm-select\">\n <option value=\"AM\">AM</option>\n <option value=\"PM\">PM</option>\n </select>\n </div>\n </div>\n </div>\n\n <div class=\"datepicker-container__footer\" *ngIf=\"data.dpConfig.showApplyButton || data.dpConfig.enableTime\">\n <button mis-button size=\"md\" type=\"'none'\" (click)=\"cancelDatePicker()\">Cancel</button>\n <button mis-button size=\"md\" type=\"primary\" (click)=\"applyDate()\" [disabled]=\"!(data.date || localSelectedDate()?.date)\">Apply</button>\n </div>\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,.datepicker-container .datepicker-container__body .month,.datepicker-container .datepicker-container__body .year{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}:root{--pmry-200: #99BAF7;--pmry-100: #CBDDFB;--pmry-500: #0937B2;--pmry-400: #3C68D0;--pmry-600: #062A99;--pmry-700: #041F80;--pmry-300: #638FE7;--pmry-800: #021567;--pmry-900: #010F55;--sec-d-purple: #40447F;--sec-maroon: #6B034E;--sec-mud-red: #B23600;--sec-orange: #ED711C;--sec-purple: #815FD5;--sec-teal: #10ADAE;--sec-yellow: #D4900C;--sec-green: #547F40;--sec-bright-green: #27D22E;--sec-dark-teal: #035F6B;--sec-chocolate: #7C2F33;--sec-rube-pink: #C13D6D;--sec-cerulean: #0087B2;--sem-error: #B00020;--sem-info: #0091FF;--sem-warning: #FF9D00;--sem-success: #38AF49;--grey-bg-1: #FAFAFA;--grey-bg: #F5F5F5;--grey-seperators: #E0E0E0;--grey-disabled: #C8CDD3;--grey-hover: #F5F7FC;--grey-pressed: #E6EBF7;--grey-row: #F5F7FC;--dec-light-yellow: #F4E7C3;--dec-light-purple: #DACFF9;--dec-light-green: #E4F5E9;--dec-light-green2: #F1FFF3;--dec-light-pink: #FAE1EA;--dec-: #F4CBC1;--dec-lt-orange: #FAEFED;--dec-light-blue: #CFECF9;--dec-row-selection: #F1FDF8;--dec-row-selection2: #F2FBFF;--dec-row-lines: #D3E1E9;--text-white: #FFFFFF;--text-disabled: #929DAB;--text-muted: #6A737D;--text-black: #181F33;--MR-solid-blue2:#C8D5F6;--MR-solid-purple:#C9C3FB;--MR-solid-orange:#EEAC9F;--MR-solid-green:#ACDADA;--MR-solid-brown:#E8C8AF;--MR-solid-yellow:#FFEFC7;--MR-solid-blue:#BBE6FF;--MR-solid-pink:#FFC6F2;--tr-hover:#F0F3FA;--tr-pressed:#DAE1F3}.datepicker-container{background:#fff;border:1px solid #e0e0e0;box-shadow:0 12px 24px #0000001f,0 4px 8px #0000001f;border-radius:12px;display:flex;flex-direction:column;font-family:Lato;-webkit-user-select:none;user-select:none;box-sizing:border-box;width:290px}.datepicker-container .datepicker-container__header{display:flex;height:32px;margin:16px;justify-content:space-between;align-items:center;width:258px}.datepicker-container .datepicker-container__header span{font-size:16px;font-style:normal;font-weight:700;line-height:24px;letter-spacing:.2px;text-align:center}.datepicker-container .datepicker-container__header .month-header,.datepicker-container .datepicker-container__header .year-header{padding:8px;border-radius:10px}.datepicker-container .datepicker-container__header .month-header:hover,.datepicker-container .datepicker-container__header .year-header:hover{cursor:pointer;background-color:#e6ebf7}.datepicker-container .datepicker-container__header .datepicker-container__arrow__icon{height:20px;width:20px;display:flex;align-items:center;justify-content:center;border-radius:4px;padding:4px}.datepicker-container .datepicker-container__header .datepicker-container__arrow__icon.disabled-month{opacity:.5;cursor:not-allowed}.datepicker-container .datepicker-container__header .datepicker-container__arrow__icon:not(.disabled-month):hover{cursor:pointer;background-color:#cbddfb}.datepicker-container .datepicker-container__header .datepicker-container__arrow__icon:nth-child(1){transform:rotate(180deg)}.datepicker-container .datepicker-container__body{width:258px;height:100%;margin:0 16px 16px}.datepicker-container .datepicker-container__body .row{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:10px}.datepicker-container .datepicker-container__body .month,.datepicker-container .datepicker-container__body .year{padding:10px 6px;cursor:pointer;border-radius:5px;text-align:center;background-color:#fff}.datepicker-container .datepicker-container__body .month:hover,.datepicker-container .datepicker-container__body .year:hover{background-color:#cbddfb}.datepicker-container .datepicker-container__body .disable-month,.datepicker-container .datepicker-container__body .disable-year{cursor:default;color:#c8cdd3}.datepicker-container .datepicker-container__body .disable-month:hover,.datepicker-container .datepicker-container__body .disable-year:hover{background-color:transparent}.datepicker-container .datepicker-container__body .select-month,.datepicker-container .datepicker-container__body .select-year{background-color:#0937b2;color:#fff}.datepicker-container .datepicker-container__body .select-month:hover,.datepicker-container .datepicker-container__body .select-year:hover{cursor:pointer;background-color:#cbddfb}.datepicker-container .datepicker-container__body .datepicker-container__weekdays{width:100%;display:flex;padding-bottom:10px}.datepicker-container .datepicker-container__body .datepicker-container__weekdays .datepicker-container__weekday{width:36px;height:18px;text-align:center}.datepicker-container .datepicker-container__body .datepicker-container__weekdays .datepicker-container__weekday span{font-size:12px;font-style:normal;font-weight:400;line-height:18px;letter-spacing:.2px;text-align:center;color:#c7c7c7}.datepicker-container .datepicker-container__body .datepicker-container__weekdays .datepicker-container__weekday span.current-day{font-weight:700;letter-spacing:.25px;color:#181f33}.datepicker-container .datepicker-container__body .datepicker-container__days{display:flex;flex-wrap:wrap;gap:2px}.datepicker-container .datepicker-container__body .datepicker-container__days .datepicker-container__day{width:34px;height:34px;display:flex;align-items:center;justify-content:center;border-radius:4px}.datepicker-container .datepicker-container__body .datepicker-container__days .datepicker-container__day.selected-day{background-color:#0937b2;cursor:pointer}.datepicker-container .datepicker-container__body .datepicker-container__days .datepicker-container__day.disabled-day{cursor:default}.datepicker-container .datepicker-container__body .datepicker-container__days .datepicker-container__day.disabled-day:hover{background-color:transparent}.datepicker-container .datepicker-container__body .datepicker-container__days .datepicker-container__day.is-valid-date:not(.disabled-day):not(.selected-day):hover{background-color:#cbddfb;cursor:pointer}.datepicker-container .datepicker-container__body .datepicker-container__days .datepicker-container__day.is-valid-date:not(.disabled-day):not(.selected-day):hover span.selected-day{color:#181f33!important}.datepicker-container .datepicker-container__body .datepicker-container__days .datepicker-container__day span{font-size:14px;font-style:normal;font-weight:400;line-height:20px;letter-spacing:.2px;text-align:center;color:#181f33}.datepicker-container .datepicker-container__body .datepicker-container__days .datepicker-container__day span.current-day{font-weight:700;letter-spacing:.25px}.datepicker-container .datepicker-container__body .datepicker-container__days .datepicker-container__day span.selected-day{color:#fff}.datepicker-container .datepicker-container__body .datepicker-container__days .datepicker-container__day span.disabled-day{color:#c7c7c7}.datepicker-container .datepicker-container__time{border-top:1px solid #e0e0e0;padding:16px;margin:0 16px}.datepicker-container .datepicker-container__time .time-picker-header{margin-bottom:12px}.datepicker-container .datepicker-container__time .time-picker-header span{font-size:14px;font-weight:600;color:#181f33}.datepicker-container .datepicker-container__time .time-picker-controls{display:flex;align-items:center;gap:8px}.datepicker-container .datepicker-container__time .time-picker-controls .time-input-group{display:flex;flex-direction:column;gap:4px}.datepicker-container .datepicker-container__time .time-picker-controls .time-input-group label{font-size:12px;font-weight:500;color:#6a737d}.datepicker-container .datepicker-container__time .time-picker-controls .time-input-group .time-input{width:50px;height:32px;padding:4px 8px;border:1px solid #e0e0e0;border-radius:4px;font-size:14px;text-align:center}.datepicker-container .datepicker-container__time .time-picker-controls .time-input-group .time-input:focus{outline:none;border-color:#0937b2;box-shadow:0 0 0 2px #0937b21a}.datepicker-container .datepicker-container__time .time-picker-controls .time-input-group .time-input:invalid{border-color:#dc3545;background-color:#fff5f5}.datepicker-container .datepicker-container__time .time-picker-controls .time-input-group .time-input::-webkit-inner-spin-button,.datepicker-container .datepicker-container__time .time-picker-controls .time-input-group .time-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.datepicker-container .datepicker-container__time .time-picker-controls .time-input-group .time-input[type=number]{-moz-appearance:textfield}.datepicker-container .datepicker-container__time .time-picker-controls .time-separator{font-size:18px;font-weight:600;color:#181f33;margin-top:20px}.datepicker-container .datepicker-container__time .time-picker-controls .am-pm-selector{display:flex;flex-direction:column;gap:4px}.datepicker-container .datepicker-container__time .time-picker-controls .am-pm-selector label{font-size:12px;font-weight:500;color:#6a737d}.datepicker-container .datepicker-container__time .time-picker-controls .am-pm-selector .am-pm-select{width:60px;height:42px;padding:4px 8px;border:1px solid #e0e0e0;border-radius:4px;font-size:14px;background-color:#fff}.datepicker-container .datepicker-container__time .time-picker-controls .am-pm-selector .am-pm-select:focus{outline:none;border-color:#0937b2;box-shadow:0 0 0 2px #0937b21a}.datepicker-container .datepicker-container__footer{display:flex;justify-content:flex-end;gap:8px;bottom:0;align-items:center;position:sticky;padding:16px;border-top:1px solid #e0e0e0}.remove-box-shadow{box-shadow:none!important;border:none!important;border-radius:0!important}\n"] }]
|
|
839
869
|
}], () => [{ type: undefined, decorators: [{
|
|
840
870
|
type: Inject,
|
|
841
871
|
args: [CONTAINER_DATA]
|
|
@@ -844,4 +874,4 @@ export class TzDpContainerComponent {
|
|
|
844
874
|
args: ["keydown.esc"]
|
|
845
875
|
}] }); })();
|
|
846
876
|
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(TzDpContainerComponent, { className: "TzDpContainerComponent" }); })();
|
|
847
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tz-dp-container.component.js","sourceRoot":"","sources":["../../../../../projects/mis-components/datepicker_v2/tz-dp-container/tz-dp-container.component.ts","../../../../../projects/mis-components/datepicker_v2/tz-dp-container/tz-dp-container.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, HostListener, Inject, OnInit } from \"@angular/core\";\nimport { CONTAINER_DATA, DATE_FORMAT } from \"../datepicker-constants\";\nimport { ICurrentMonth, ICurrentMonthDates, IDatePickerData, IWeekDay } from \"../models/dp-config.model\";\nimport { getMonth } from \"../utils\";\nimport { ToastService } from \"mis-crystal-design-system/toast\";\nimport dayjs, { Dayjs, tz } from 'dayjs';\nimport timezone from 'dayjs/plugin/timezone';\nimport utc from 'dayjs/plugin/utc';\nimport isSameOrAfter from 'dayjs/plugin/isSameOrAfter';\nimport isSameOrBefore from 'dayjs/plugin/isSameOrBefore';\nimport customParseFormat from 'dayjs/plugin/customParseFormat'\n\ndayjs.extend(utc);\ndayjs.extend(timezone);\ndayjs.extend(customParseFormat);\ndayjs.extend(isSameOrAfter);\ndayjs.extend(isSameOrBefore);\n\n@Component({\n  selector: \"mis-tz-dp\",\n  templateUrl: \"./tz-dp-container.component.html\",\n  styleUrls: [\"./tz-dp-container.component.scss\"]\n})\nexport class TzDpContainerComponent implements OnInit {\n  data: IDatePickerData;\n  private parseZoneInstance = (...args) => {\n    return dayjs(...args);\n  };\n  private rawWeekDays: string[] = [\"SUN\", \"MON\", \"TUE\", \"WED\", \"THU\", \"FRI\", \"SAT\"];\n  weekDays: IWeekDay[] = [];\n  currentMonthNumber: number;\n  currentMonth: ICurrentMonth;\n  currentYearNumber: number;\n  currentMonthDates: ICurrentMonthDates[] = [];\n  isPreviousMonthDisabled: boolean = false;\n  isNextMonthDisabled: boolean = false;\n  localSelectedDate: ICurrentMonthDates;\n  allowBookingOnDisabledDay: boolean = false;\n  currentSelection: any;\n  \n  // Time functionality - only what's needed\n  selectedHour: number = 0;\n  selectedMinute: number = 0;\n  selectedAmPm: string = 'AM';\n\n  isSelectingMonth: boolean = false;\n  isSelectingYear: boolean = false;\n  availableYears: number[] = [];\n  availableMonths: string[] = [];\n  disabledMonths: boolean[] = [];\n  disabledYears: boolean[] = [];\n  selectedYear: number;\n  isYearSelectionFlow: boolean = false;\n\n  constructor(@Inject(CONTAINER_DATA) data: IDatePickerData, private toast: ToastService) {\n    this.data = data;\n    \n    // Initialize parseZoneInstance with better error handling\n    this.parseZoneInstance = (...args) => {\n      try {\n        if (this.data?.dpConfig?.timezone) {\n          return dayjs.tz(args[0], args[1]  || 'DD/MM/YYYY', this.data.dpConfig.timezone);\n        } else {\n          return dayjs(...args);\n        }\n      } catch (error) {\n        // Silently handle timezone parsing error, fallback to local time\n        return dayjs(...args);\n      }\n    };\n    \n    // Set default values safely\n    this.currentMonthNumber = this.parseZoneInstance().month();\n    this.currentMonth = getMonth(this.currentMonthNumber);\n    this.currentYearNumber = this.parseZoneInstance().year();\n    this.weekDays = this.rawWeekDays.map((day, index) => ({\n      label: `${day[0]}${day.slice(1).toLowerCase()}`,\n      isCurrentDay: this.parseZoneInstance().day() === index\n    }));\n    \n    if (!this.data?.dpConfig?.format) {\n      this.data.dpConfig = {\n        ...this.data.dpConfig,\n        format: DATE_FORMAT\n      };\n    }\n\n    if(!this.data?.date){\n      this.data.date = this.parseZoneInstance().format(this.data.dpConfig.format);\n    }\n\n    this.availableMonths = Array.from({ length: 12 }, (_, i) => dayjs().month(i).format('MMMM'));\n    this.availableYears = Array.from(\n      { length: 12 },\n      (_, index) => this.currentYearNumber - 6 + index\n    );\n    \n  }\n\n  onHourInput(event: any): void {\n    if (this.data.dpConfig.enableTime !== true) return;\n    \n    const value = parseInt(event.target.value);\n    if (!isNaN(value)) {\n      if (this.is12HourFormat()) {\n        if (value >= 1 && value <= 12) {\n          this.selectedHour = value;\n        }\n      } else {\n        if (value >= 0 && value <= 23) {\n          this.selectedHour = value;\n        }\n      }\n    }\n  }\n\n  onMinuteInput(event: any): void {\n    if (this.data.dpConfig.enableTime !== true) return;\n    \n    const value = parseInt(event.target.value);\n    if (!isNaN(value) && value >= 0 && value <= 59) {\n      this.selectedMinute = value;\n    }\n  }\n\n  validateHourInput(): void {\n    if (this.data.dpConfig.enableTime !== true) return;\n    \n    if (this.is12HourFormat()) {\n      if (this.selectedHour < 1) this.selectedHour = 1;\n      if (this.selectedHour > 12) this.selectedHour = 12;\n    } else {\n      if (this.selectedHour < 0) this.selectedHour = 0;\n      if (this.selectedHour > 23) this.selectedHour = 23;\n    }\n  }\n\n  validateMinuteInput(): void {\n    if (this.data.dpConfig.enableTime !== true) return;\n    \n    if (this.selectedMinute < 0) this.selectedMinute = 0;\n    if (this.selectedMinute > 59) this.selectedMinute = 59;\n  }\n\n  is12HourFormat(): boolean {\n    return this.data.dpConfig.enableTime === true && \n           (this.data.dpConfig.format.includes('A') || this.data.dpConfig.format.includes('a'));\n  }\n\n  retractDayMonth(day: any, month: any, year: any): any {\n    return `${day} ${month} ${year}`;\n  }\n\n  ngOnInit(): void {\n    this.currentDateInstance();\n    this.calculateMinMaxDays();\n    this.calculateDisabledMonthsAndYears();\n    this.generateDates(this.currentMonthNumber, this.currentYearNumber);\n    \n    // Initialize time if enabled\n    if (this.data.dpConfig.enableTime === true) {\n      this.initializeTimeValues();\n    }\n  }\n  get yearRange(): string {\n    return `${this.selectedYear - 6} - ${this.selectedYear + 5}`;\n  }\n\n  private initializeTimeValues(): void {\n    if (this.data.dpConfig.enableTime === true) {\n      if (this.data.date) {\n        // Try to parse existing date for time values\n        try {\n          const currentDate = this.parseZoneInstance(this.data.date, this.data.dpConfig.format);\n          if (currentDate.isValid()) {\n            let hour = currentDate.hour();\n            this.selectedMinute = currentDate.minute();\n            \n            if (this.is12HourFormat()) {\n              if (hour === 0) {\n                hour = 12;\n                this.selectedAmPm = 'AM';\n              } else if (hour > 12) {\n                hour = hour - 12;\n                this.selectedAmPm = 'PM';\n              } else if (hour === 12) {\n                this.selectedAmPm = 'PM';\n              } else {\n                this.selectedAmPm = 'AM';\n              }\n            }\n            \n            this.selectedHour = hour;\n          } else {\n            // Invalid date, use defaults\n            this.setDefaultTimeValues();\n          }\n        } catch (error) {\n          // Parsing error, use defaults\n          this.setDefaultTimeValues();\n        }\n      } \n     } else {\n        // No existing date, use defaults\n        this.setDefaultTimeValues();\n      }\n    \n  }\n\n  private setDefaultTimeValues(): void {\n    // Use current time as default instead of 12:00 PM\n    const now = dayjs();\n    const currentHour = now.hour();\n    const currentMinute = now.minute();\n    \n    if (this.is12HourFormat()) {\n      // Convert current time to 12-hour format\n      let hour12 = currentHour;\n      let amPm = 'AM';\n      \n      if (currentHour === 0) {\n        hour12 = 12;\n        amPm = 'AM';\n      } else if (currentHour === 12) {\n        hour12 = 12;\n        amPm = 'PM';\n      } else if (currentHour > 12) {\n        hour12 = currentHour - 12;\n        amPm = 'PM';\n      } else {\n        amPm = 'AM';\n      }\n      \n      this.selectedHour = hour12;\n      this.selectedMinute = currentMinute;\n      this.selectedAmPm = amPm;\n    } else {\n      // Use current time directly for 24-hour format\n      this.selectedHour = currentHour;\n      this.selectedMinute = currentMinute;\n      this.selectedAmPm = 'AM'; // Not used in 24-hour format but keep consistent\n    }\n  }\n\n  private currentDateInstance(): void {\n    try {\n      if (this.data.date) {\n        const selectedDate = dayjs(this.data.date, this.data.dpConfig.format);\n        if (selectedDate.isValid()) {\n      this.selectedYear = this.currentYearNumber = selectedDate.year();\n          this.currentMonthNumber = selectedDate.month();\n          this.currentMonth = getMonth(this.currentMonthNumber);\n          \n          if (!this.localSelectedDate) {\n            this.localSelectedDate = {\n              date: selectedDate.date(),\n              weekDay: selectedDate.day(),\n              month: selectedDate.month(),\n              year: selectedDate.year(),\n              isSelectedDay: true\n            };\n          }\n        }\n      }\n    } catch (error) {\n      this.currentYearNumber = this.parseZoneInstance().year();\n      this.currentMonthNumber = this.parseZoneInstance().month();\n      this.currentMonth = getMonth(this.currentMonthNumber);\n    }\n    \n    this.currentMonthDates = this.generateDates(this.currentMonthNumber, this.currentYearNumber);\n  }\n\n\n  private calculateMinMaxDays() {\n      const currentInstance = this.parseZoneInstance().year(this.currentYearNumber).month(this.currentMonthNumber);\n      \n      if (this.data.dpConfig.minDate) {\n          const minDate = this.parseZoneInstance(this.data.dpConfig.minDate, this.data.dpConfig.format);\n          if (minDate?.isValid()) {\n            this.isPreviousMonthDisabled = minDate.isSameOrAfter(currentInstance, \"month\");\n          }\n    }\n    \n    if (this.data.dpConfig.maxDate) {\n        const maxDate = this.parseZoneInstance(this.data.dpConfig.maxDate, this.data.dpConfig.format);\n        if (maxDate?.isValid()) {\n          this.isNextMonthDisabled = maxDate.isSameOrBefore(currentInstance, \"month\");\n        }\n    }\n  }\n\n  calculateDisabledMonthsAndYears() {\n    const minDate = !!this.data.dpConfig.minDate ? this.parseZoneInstance(this.data.dpConfig.minDate, this.data.dpConfig.format) : dayjs('invalid');\n    const maxDate = !!this.data.dpConfig.maxDate ? this.parseZoneInstance(this.data.dpConfig.maxDate, this.data.dpConfig.format) : dayjs('invalid');\n    \n    this.disabledMonths = this.availableMonths.map((month, index) => {\n      const monthDate = this.parseZoneInstance().year(this.selectedYear).month(index);\n      return (minDate.isValid() && monthDate.isBefore(minDate, 'month')) || \n             (maxDate.isValid() && monthDate.isAfter(maxDate, 'month'));\n    });\n  \n    this.disabledYears = this.availableYears.map((year) => {\n      const yearDate = this.parseZoneInstance().year(year);\n      return (minDate.isValid() && yearDate.isBefore(minDate, 'year')) || \n             (maxDate.isValid() && yearDate.isAfter(maxDate, 'year'));\n    });\n\n    if (this.isSelectingYear) {\n      this.isPreviousMonthDisabled = minDate.isValid() && ((this.selectedYear - 6) <= minDate.year());\n      this.isNextMonthDisabled = maxDate.isValid() && ((this.selectedYear + 5) >= maxDate.year());\n    }\n    \n  }\n\n  navigateView(direction: \"NEXT\" | \"PREVIOUS\"): void {\n    if ((direction === 'NEXT' && (this.isNextMonthDisabled || this.isSelectingMonth)) ||\n        (direction === 'PREVIOUS' && (this.isPreviousMonthDisabled || this.isSelectingMonth))) {\n      return;\n    }\n    if(this.isSelectingYear){\n      this.selectedYear += direction === \"NEXT\" ? 12 : -12;\n      this.availableYears = Array.from(\n        { length: 12 },\n        (_, index) => this.selectedYear - 6 + index\n      );\n    }\n    else{\n      let thisMonth : dayjs.Dayjs = this.parseZoneInstance().year(this.currentYearNumber).month(this.currentMonthNumber);\n      thisMonth = direction === \"NEXT\" ? thisMonth.add(1, \"month\") : thisMonth.subtract(1, \"month\");\n      this.currentMonthNumber = thisMonth.month();\n      this.currentMonth = getMonth(this.currentMonthNumber);\n      this.selectedYear = this.currentYearNumber = thisMonth.year();\n      this.currentMonthDates = this.generateDates(this.currentMonthNumber, this.currentYearNumber);\n    }\n    this.calculateMinMaxDays();\n    this.calculateDisabledMonthsAndYears();\n  }\n\n  navigateMonth(direction: \"NEXT\" | \"PREVIOUS\"): void {\n    try {\n      let thisMonth: dayjs.Dayjs = dayjs().year(this.currentYearNumber).month(this.currentMonthNumber);\n      if (direction === \"NEXT\") {\n        thisMonth = thisMonth.add(1, \"month\");\n      } else if (direction === \"PREVIOUS\") {\n        thisMonth = thisMonth.subtract(1, \"month\");\n      }\n      this.currentMonthNumber = thisMonth.month();\n      this.currentMonth = getMonth(this.currentMonthNumber);\n      this.currentYearNumber = thisMonth.year();\n      this.currentMonthDates = this.generateDates(this.currentMonthNumber, this.currentYearNumber);\n      \n      this.calculateMinMaxDays();\n    } catch (error) {\n      // Silently handle navigateMonth error\n    }\n  }\n\n  private generateDates(month: number, currentYearNumber: number): ICurrentMonthDates[] {\n    const dates: ICurrentMonthDates[] = [];\n    \n    try {\n      const daysInMonth = dayjs().year(currentYearNumber).month(month).daysInMonth();\n      \n      let minDate = null;\n      let maxDate = null;\n      \n      if (this.data.dpConfig.minDate) {\n        try {\n          minDate = this.parseZoneInstance(this.data.dpConfig.minDate, this.data.dpConfig.format);\n        } catch (error) {\n          // Silently handle min date parsing error\n        }\n      }\n      \n      if (this.data.dpConfig.maxDate) {\n        try {\n          maxDate = this.parseZoneInstance(this.data.dpConfig.maxDate, this.data.dpConfig.format);\n        } catch (error) {\n          // Silently handle max date parsing error\n        }\n      }\n      \n      for (let currentDate = 1; currentDate <= daysInMonth; currentDate++) {\n        try {\n          const date = this.parseZoneInstance().year(currentYearNumber).month(month).date(currentDate);\n          const dateString = date.format(this.data.dpConfig.format);\n          \n          let isDisabledDay = this.data.datesDisabled?.some(d => d === dateString) || false;\n          \n          if (!isDisabledDay && minDate?.isValid() && this.data.dpConfig.minDate) {\n            isDisabledDay = minDate.isAfter(date, \"day\");\n          }\n          if (!isDisabledDay && maxDate?.isValid() && this.data.dpConfig.maxDate) {\n            isDisabledDay = maxDate.isBefore(date, \"day\");\n          }\n          \n          const currentDateInstance = this.parseZoneInstance().year(currentYearNumber).month(month).date(currentDate);\n          const isCurrentDay = currentDateInstance.format(this.data.dpConfig.format) === dayjs().format(this.data.dpConfig.format);\n          \n          let isSelectedDay = false;\n          \n          // Prioritize current selection over previously applied date\n          if (this.localSelectedDate && \n              this.localSelectedDate.date === currentDate &&\n              this.localSelectedDate.month === month &&\n              this.localSelectedDate.year === currentYearNumber) {\n            isSelectedDay = true;\n          } else if (this.data.date && !this.localSelectedDate) {\n            // Only check previously applied date if no current selection\n            try {\n              if (this.data.dpConfig.enableTime) {\n                const selectedDate = this.parseZoneInstance(this.data.date, this.data.dpConfig.format);\n                if (selectedDate.isValid()) {\n                  isSelectedDay = selectedDate.isSame(currentDateInstance, 'day');\n                }\n              } else {\n                // For date-only format, compare the date parts only\n                const selectedDate = this.parseZoneInstance(this.data.date, this.data.dpConfig.format);\n                if (selectedDate.isValid()) {\n                  isSelectedDay = selectedDate.isSame(currentDateInstance, 'day');\n                } else {\n                  // Fallback to string comparison if parsing fails\n                  isSelectedDay = dateString === this.data.date;\n                }\n              }\n            } catch (error) {\n              // Silently handle date comparison error\n            }\n          }\n          \n          dates.push({\n            date: currentDate,\n            weekDay: date.day(),\n            month: month,\n            year: currentYearNumber,\n            isCurrentDay,\n            isSelectedDay,\n            toastMessage: this.data.messages?.find(q => dateString === q.date)?.message || \"\",\n            isDisabledDay\n          });\n        } catch (error) {\n          // Silently handle date processing error\n          dates.push({\n            date: currentDate,\n            weekDay: this.parseZoneInstance().year(currentYearNumber).month(month).date(currentDate).day(),\n            month: month,\n            year: currentYearNumber,\n            isDisabledDay: true\n          });\n        }\n      }\n      \n      if (dates.length > 0) {\n        for (let i = dates[0].weekDay; i > 0; i--) {\n          dates.unshift({ \n            date: 0, \n            weekDay: i - 1,\n            month: month,\n            year: currentYearNumber\n          });\n        }\n      }\n    } catch (error) {\n      // Silently handle generateDates error\n    }\n    \n    return dates;\n  }\n\n  selectDay(day: ICurrentMonthDates) {\n    if (day.date <= 0) return;\n    \n    try {\n      // Create the base date selection without time\n      this.currentSelection = this.parseZoneInstance().year(this.currentYearNumber).month(this.currentMonthNumber).date(day.date).hour(0).minute(0).second(0).millisecond(0);\n      \n      // Apply the current time values to the selection\n      if (this.data.dpConfig.enableTime === true) {\n        let hour = this.selectedHour;\n        \n        if (this.is12HourFormat()) {\n          if (this.selectedAmPm === 'PM' && hour !== 12) {\n            hour += 12;\n          } else if (this.selectedAmPm === 'AM' && hour === 12) {\n            hour = 0;\n          }\n        }\n        \n        this.currentSelection = this.currentSelection\n          .hour(hour)\n          .minute(this.selectedMinute);\n      }\n      \n      let maxDate = null;\n      let minDate = null;\n      \n      if (this.data.dpConfig.maxDate) {\n        try {\n          maxDate = this.parseZoneInstance(this.data.dpConfig.maxDate, this.data.dpConfig.format).endOf(\"day\");\n        } catch (error) {\n          // Silently handle max date parsing error\n        }\n      }\n      \n      if (this.data.dpConfig.minDate) {\n        try {\n          minDate = this.parseZoneInstance(this.data.dpConfig.minDate, this.data.dpConfig.format).startOf(\"day\");\n        } catch (error) {\n          // Silently handle min date parsing error\n        }\n      }\n      \n      this.allowBookingOnDisabledDay = this.data.allowBookingOnDisabledDay;\n      \n      if (((!minDate || this.currentSelection.isSameOrAfter(minDate)) && (!maxDate || this.currentSelection.isSameOrBefore(maxDate)) && this.allowBookingOnDisabledDay) || (!day.isDisabledDay && !this.allowBookingOnDisabledDay)) {\n        this.localSelectedDate = {\n          ...day,\n          month: this.currentMonthNumber,\n          year: this.currentYearNumber\n        };\n        \n        // Force calendar re-render to show highlighting\n        this.currentMonthDates = this.generateDates(this.currentMonthNumber, this.currentYearNumber);\n        \n        // Automatically show apply button when time is enabled, otherwise apply immediately\n        if (!this.data.dpConfig.enableTime) {\n          this.applyDate(day);\n        }\n      }\n      \n      if (day.toastMessage || (this.allowBookingOnDisabledDay && day.toastMessage)) {\n        this.toast.displayMsg(day.toastMessage, 4000);\n      }\n    } catch (error) {\n      // Silently handle selectDay error\n    }\n  }\n\n  applyDate(day?: ICurrentMonthDates) {\n    let date: string;\n    \n    try {\n      if (this.data.dpConfig.enableTime === true) {\n        // Always use time input values when time is enabled, regardless of currentSelection\n        let hour = this.selectedHour;\n        \n        if (this.is12HourFormat()) {\n          if (this.selectedAmPm === 'PM' && hour !== 12) {\n            hour += 12;\n          } else if (this.selectedAmPm === 'AM' && hour === 12) {\n            hour = 0;\n          }\n        }\n        \n        // Create a new date instance with the selected time\n        const finalSelection = dayjs()\n          .year(this.currentYearNumber)\n          .month(this.currentMonthNumber)\n          .date(this.localSelectedDate?.date || day?.date || dayjs().date())\n          .hour(hour)\n          .minute(this.selectedMinute)\n          .second(0)\n          .millisecond(0);\n        \n        date = finalSelection.format(this.data.dpConfig.format);\n      } else {\n        // Date-only format - no time\n        date = dayjs()\n          .year(this.currentYearNumber)\n          .month(this.currentMonthNumber)\n          .date(day ? day.date : this.localSelectedDate?.date || dayjs().date())\n          .hour(0)\n          .minute(0)\n          .second(0)\n          .millisecond(0)\n          .format(this.data.dpConfig.format);\n      }\n      \n      if (day || this.localSelectedDate || (this.data.dpConfig.enableTime === true)) {\n        this.data.dateChange(date);\n      } else {\n        this.cancelDatePicker();\n      }\n    } catch (error) {\n      // Silently handle applyDate error\n      this.data.dateChange(\"\");\n    }\n  }\n\n  @HostListener(\"keydown.esc\")\n  closeOnEsc() {\n    this.cancelDatePicker();\n  }\n\n  cancelDatePicker() {\n    this.data.dateChange(\"\");\n  }\n\n  toggleMonthSelector() {\n    if(this.isYearSelectionFlow) return;\n    this.isSelectingMonth = !this.isSelectingMonth;\n    this.isSelectingYear = false;\n    this.calculateDisabledMonthsAndYears();\n  }\n\n  toggleYearSelector() {\n    this.isSelectingYear = !this.isSelectingYear;\n    this.selectedYear = this.currentYearNumber;\n    this.availableYears = Array.from(\n      { length: 12 },\n      (_, index) => this.selectedYear - 6 + index\n    );\n    this.isSelectingMonth = false;\n    this.calculateDisabledMonthsAndYears();\n\n  }\n\n  resetDateSelection() {\n    this.localSelectedDate = {\n      date: 0,\n      weekDay: 0,\n      isCurrentDay: false,\n      isSelectedDay: false,\n      isDisabledDay: false,\n      toastMessage: ''\n    };\n    this.data.date = '';\n  }\n\n  selectMonth(month: string) {\n    this.currentMonthNumber = this.availableMonths.indexOf(month);\n    this.currentMonth = getMonth(this.currentMonthNumber);\n    this.isSelectingMonth = false;\n    this.isYearSelectionFlow = false;\n    this.resetDateSelection();\n    this.currentMonthDates = this.generateDates(this.currentMonthNumber, this.currentYearNumber);\n    this.calculateMinMaxDays();\n  }\n\n  selectYear(year: number) {\n    this.selectedYear = this.currentYearNumber = year;\n    this.isSelectingYear = false;\n    this.isSelectingMonth = true;\n    this.isYearSelectionFlow = true;\n    this.resetDateSelection();\n    this.calculateDisabledMonthsAndYears();\n  }\n}\n","<div class=\"datepicker-container\" [ngClass]=\"data.disableBoxShadow?'remove-box-shadow':''\" aria-label=\"date picker\" cdkTrapFocus [cdkTrapFocusAutoCapture]=\"true\">\n  <div tabindex=\"-1\" cdkFocusInitial></div>\n  <div class=\"datepicker-container__header\">\n    <div\n      class=\"datepicker-container__arrow__icon\"\n      (click)=\"navigateView('PREVIOUS')\"\n      tabindex=\"0\"\n      aria-label=\"Previous Month\"\n      (keyup.enter)=\"navigateView('PREVIOUS')\"\n      [ngClass]=\"{\n        'disabled-month': isPreviousMonthDisabled || isSelectingMonth\n      }\"\n    >\n      <svg width=\"20\" height=\"16\" viewBox=\"0 0 20 16\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n        <path\n          d=\"M19.7071 8.70711C20.0976 8.31658 20.0976 7.68342 19.7071 7.29289L13.3431 0.928933C12.9526 0.538409 12.3195 0.538409 11.9289 0.928933C11.5384 1.31946 11.5384 1.95262 11.9289 2.34315L17.5858 8L11.9289 13.6569C11.5384 14.0474 11.5384 14.6805 11.9289 15.0711C12.3195 15.4616 12.9526 15.4616 13.3431 15.0711L19.7071 8.70711ZM-8.74228e-08 9L19 9L19 7L8.74228e-08 7L-8.74228e-08 9Z\"\n          fill=\"#181F33\"\n        ></path>\n      </svg>\n    </div>\n\n    <div *ngIf=\"!isSelectingYear\" (click)=\"toggleMonthSelector()\" class=\"month-header\">\n      {{ isYearSelectionFlow ? selectedYear : availableMonths[currentMonthNumber] }}\n    </div>\n    <div *ngIf=\"!isSelectingMonth\" (click)=\"toggleYearSelector()\" class=\"year-header\">\n      {{ isSelectingYear ? yearRange : currentYearNumber }}\n    </div>\n\n\n    <div\n      class=\"datepicker-container__arrow__icon\"\n      (click)=\"navigateView('NEXT')\"\n      tabindex=\"0\"\n      aria-label=\"Next Month\"\n      (keyup.enter)=\"navigateView('NEXT')\"\n      [ngClass]=\"{\n        'disabled-month': isNextMonthDisabled || isSelectingMonth\n      }\"\n    >\n      <svg width=\"20\" height=\"16\" viewBox=\"0 0 20 16\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n        <path\n          d=\"M19.7071 8.70711C20.0976 8.31658 20.0976 7.68342 19.7071 7.29289L13.3431 0.928933C12.9526 0.538409 12.3195 0.538409 11.9289 0.928933C11.5384 1.31946 11.5384 1.95262 11.9289 2.34315L17.5858 8L11.9289 13.6569C11.5384 14.0474 11.5384 14.6805 11.9289 15.0711C12.3195 15.4616 12.9526 15.4616 13.3431 15.0711L19.7071 8.70711ZM-8.74228e-08 9L19 9L19 7L8.74228e-08 7L-8.74228e-08 9Z\"\n          fill=\"#181F33\"\n        ></path>\n      </svg>\n    </div>\n  </div>\n  <div class=\"datepicker-container__body\">\n\n    <div *ngIf=\"isSelectingMonth && !isSelectingYear\" class=\"month-selector\">\n      <div class=\"row\">\n        <div *ngFor=\"let month of availableMonths; let i = index\" \n            class=\"month\" \n            (click)=\"!disabledMonths[i] && selectMonth(month)\" \n            [ngClass]=\"{\n              'disable-month': disabledMonths[i],\n              'select-month': !disabledMonths[currentMonthNumber] && month === availableMonths[currentMonthNumber]\n            }\">\n          {{ month }}\n        </div>\n      </div>\n    </div>\n  \n    <div *ngIf=\"isSelectingYear && !isSelectingMonth\" class=\"year-selector\">\n      <div class=\"row\">\n        <div *ngFor=\"let year of availableYears; let i = index\" \n            class=\"year\" \n            (click)=\"!disabledYears[i] && selectYear(year)\" \n            [ngClass]=\"{\n              'disable-year': disabledYears[i],\n              'select-year': year === currentYearNumber\n            }\">\n          {{ year }}\n        </div>\n      </div>\n    </div>\n\n    <div *ngIf=\"!isSelectingMonth && !isSelectingYear\" class=\"datepicker-container__weekdays\">\n      <div class=\"datepicker-container__weekday\" *ngFor=\"let weekDay of weekDays\">\n        <span [ngClass]=\"{ 'current-day': weekDay.isCurrentDay }\">{{ weekDay.label }}</span>\n      </div>\n    </div>\n    <div *ngIf=\"!isSelectingMonth && !isSelectingYear\" class=\"datepicker-container__days\">\n      <div\n        class=\"datepicker-container__day\"\n        [ngClass]=\"{\n          'selected-day': day.isSelectedDay,\n          'disabled-day': day.isDisabledDay,\n          'is-valid-date': day.date > 0 && !day.isSelectedDay\n        }\"\n        *ngFor=\"let day of currentMonthDates\"\n        (click)=\"selectDay(day)\"\n        (keyup.enter)=\"selectDay(day)\"\n      >\n        <span\n          *ngIf=\"day.date > 0\"\n          [tabindex]=\"day.isDisabledDay ? -1 : 0\"\n          [ngClass]=\"{\n            'current-day': day.isCurrentDay,\n            'selected-day': day.isSelectedDay,\n            'disabled-day': day.isDisabledDay\n          }\"\n          [attr.aria-label]=\"retractDayMonth(day.date, currentMonth, currentYearNumber)\"\n        >\n          {{ day.date }}\n        </span>\n      </div>\n    </div>\n  </div>\n\n  <!-- Time Picker Section -->\n  <div class=\"datepicker-container__time\" *ngIf=\"data.dpConfig.enableTime === true\">\n    <div class=\"time-picker-header\">\n      <span>Time</span>\n    </div>\n    <div class=\"time-picker-controls\">\n      <div class=\"time-input-group\">\n        <label for=\"hourInput\">Hour</label>\n        <input \n          id=\"hourInput\"\n          type=\"number\" \n          [min]=\"is12HourFormat() ? 1 : 0\"\n          [max]=\"is12HourFormat() ? 12 : 23\"\n          [step]=\"1\"\n          [(ngModel)]=\"selectedHour\"\n          (input)=\"onHourInput($event)\"\n          (blur)=\"validateHourInput()\"\n          class=\"time-input\"\n          [title]=\"is12HourFormat() ? 'Enter hour (1-12)' : 'Enter hour (0-23)'\">\n      </div>\n      <div class=\"time-separator\">:</div>\n      <div class=\"time-input-group\">\n        <label for=\"minuteInput\">Minute</label>\n        <input \n          id=\"minuteInput\"\n          type=\"number\" \n          min=\"0\" \n          max=\"59\"\n          [step]=\"1\"\n          [(ngModel)]=\"selectedMinute\"\n          (input)=\"onMinuteInput($event)\"\n          (blur)=\"validateMinuteInput()\"\n          class=\"time-input\"\n          title=\"Enter minute (0-59)\">\n      </div>\n      <div class=\"am-pm-selector\" *ngIf=\"is12HourFormat()\">\n        <label for=\"amPmSelect\">AM/PM</label>\n        <select \n          id=\"amPmSelect\"\n          [(ngModel)]=\"selectedAmPm\"\n          class=\"am-pm-select\">\n          <option value=\"AM\">AM</option>\n          <option value=\"PM\">PM</option>\n        </select>\n      </div>\n    </div>\n  </div>\n\n  <div class=\"datepicker-container__footer\" *ngIf=\"data.dpConfig.showApplyButton || data.dpConfig.enableTime\">\n    <button mis-button size=\"md\" type=\"'none'\" (click)=\"cancelDatePicker()\">Cancel</button>\n    <button mis-button size=\"md\" type=\"primary\" (click)=\"applyDate()\" [disabled]=\"!(data.date || localSelectedDate.date)\">Apply</button>\n  </div>\n</div>\n"]}
|
|
877
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tz-dp-container.component.js","sourceRoot":"","sources":["../../../../../projects/mis-components/datepicker_v2/tz-dp-container/tz-dp-container.component.ts","../../../../../projects/mis-components/datepicker_v2/tz-dp-container/tz-dp-container.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, HostListener, Inject, OnInit, signal, computed } from \"@angular/core\";\nimport { CONTAINER_DATA, DATE_FORMAT } from \"../datepicker-constants\";\nimport { ICurrentMonth, ICurrentMonthDates, IDatePickerData, IWeekDay } from \"../models/dp-config.model\";\nimport { getMonth } from \"../utils\";\nimport { ToastService } from \"mis-crystal-design-system/toast\";\nimport dayjs, { Dayjs, tz } from 'dayjs';\nimport timezone from 'dayjs/plugin/timezone';\nimport utc from 'dayjs/plugin/utc';\nimport isSameOrAfter from 'dayjs/plugin/isSameOrAfter';\nimport isSameOrBefore from 'dayjs/plugin/isSameOrBefore';\nimport customParseFormat from 'dayjs/plugin/customParseFormat'\n\ndayjs.extend(utc);\ndayjs.extend(timezone);\ndayjs.extend(customParseFormat);\ndayjs.extend(isSameOrAfter);\ndayjs.extend(isSameOrBefore);\n\n@Component({\n  selector: \"mis-tz-dp\",\n  templateUrl: \"./tz-dp-container.component.html\",\n  styleUrls: [\"./tz-dp-container.component.scss\"]\n})\nexport class TzDpContainerComponent implements OnInit {\n  data: IDatePickerData;\n  private parseZoneInstance = (...args) => {\n    return dayjs(...args);\n  };\n  private rawWeekDays: string[] = [\"SUN\", \"MON\", \"TUE\", \"WED\", \"THU\", \"FRI\", \"SAT\"];\n  \n  // Signal-based state management\n  private readonly weekDaysSignal = signal<IWeekDay[]>([]);\n  private readonly currentMonthNumberSignal = signal<number>(0);\n  private readonly currentMonthSignal = signal<ICurrentMonth>(\"January\");\n  private readonly currentYearNumberSignal = signal<number>(0);\n  private readonly currentMonthDatesSignal = signal<ICurrentMonthDates[]>([]);\n  private readonly isPreviousMonthDisabledSignal = signal<boolean>(false);\n  private readonly isNextMonthDisabledSignal = signal<boolean>(false);\n  private readonly localSelectedDateSignal = signal<ICurrentMonthDates | null>(null);\n  private readonly allowBookingOnDisabledDaySignal = signal<boolean>(false);\n  private readonly currentSelectionSignal = signal<any>(null);\n  \n  // Time functionality signals\n  readonly selectedHourSignal = signal<number>(0);\n  readonly selectedMinuteSignal = signal<number>(0);\n  readonly selectedAmPmSignal = signal<string>('AM');\n\n  private readonly isSelectingMonthSignal = signal<boolean>(false);\n  private readonly isSelectingYearSignal = signal<boolean>(false);\n  private readonly availableYearsSignal = signal<number[]>([]);\n  private readonly availableMonthsSignal = signal<string[]>([]);\n  private readonly disabledMonthsSignal = signal<boolean[]>([]);\n  private readonly disabledYearsSignal = signal<boolean[]>([]);\n  private readonly selectedYearSignal = signal<number>(0);\n  private readonly isYearSelectionFlowSignal = signal<boolean>(false);\n  \n  // Computed properties for template access\n  weekDays = computed(() => this.weekDaysSignal());\n  currentMonthNumber = computed(() => this.currentMonthNumberSignal());\n  currentMonth = computed(() => this.currentMonthSignal());\n  currentYearNumber = computed(() => this.currentYearNumberSignal());\n  currentMonthDates = computed(() => this.currentMonthDatesSignal());\n  isPreviousMonthDisabled = computed(() => this.isPreviousMonthDisabledSignal());\n  isNextMonthDisabled = computed(() => this.isNextMonthDisabledSignal());\n  localSelectedDate = computed(() => this.localSelectedDateSignal());\n  allowBookingOnDisabledDay = computed(() => this.allowBookingOnDisabledDaySignal());\n  currentSelection = computed(() => this.currentSelectionSignal());\n  \n  // Time functionality computed properties\n  selectedHour = computed(() => this.selectedHourSignal());\n  selectedMinute = computed(() => this.selectedMinuteSignal());\n  selectedAmPm = computed(() => this.selectedAmPmSignal());\n\n  isSelectingMonth = computed(() => this.isSelectingMonthSignal());\n  isSelectingYear = computed(() => this.isSelectingYearSignal());\n  availableYears = computed(() => this.availableYearsSignal());\n  availableMonths = computed(() => this.availableMonthsSignal());\n  disabledMonths = computed(() => this.disabledMonthsSignal());\n  disabledYears = computed(() => this.disabledYearsSignal());\n  selectedYear = computed(() => this.selectedYearSignal());\n  isYearSelectionFlow = computed(() => this.isYearSelectionFlowSignal());\n\n  constructor(@Inject(CONTAINER_DATA) data: IDatePickerData, private toast: ToastService) {\n    this.data = data;\n    \n    // Initialize parseZoneInstance with better error handling\n    this.parseZoneInstance = (...args) => {\n      try {\n        if (this.data?.dpConfig?.timezone) {\n          return dayjs.tz(args[0], args[1]  || 'DD/MM/YYYY', this.data.dpConfig.timezone);\n        } else {\n          return dayjs(...args);\n        }\n      } catch (error) {\n        // Silently handle timezone parsing error, fallback to local time\n        return dayjs(...args);\n      }\n    };\n    \n    // Set default values safely using signals\n    this.currentMonthNumberSignal.set(this.parseZoneInstance().month());\n    this.currentMonthSignal.set(getMonth(this.currentMonthNumberSignal()));\n    this.currentYearNumberSignal.set(this.parseZoneInstance().year());\n    this.weekDaysSignal.set(this.rawWeekDays.map((day, index) => ({\n      label: `${day[0]}${day.slice(1).toLowerCase()}`,\n      isCurrentDay: this.parseZoneInstance().day() === index\n    })));\n    \n    if (!this.data?.dpConfig?.format) {\n      this.data.dpConfig = {\n        ...this.data.dpConfig,\n        format: DATE_FORMAT\n      };\n    }\n\n    if(!this.data?.date){\n      this.data.date = this.parseZoneInstance().format(this.data.dpConfig.format);\n    }\n\n    this.availableMonthsSignal.set(Array.from({ length: 12 }, (_, i) => dayjs().month(i).format('MMMM')));\n    this.availableYearsSignal.set(Array.from(\n      { length: 12 },\n      (_, index) => this.currentYearNumberSignal() - 6 + index\n    ));\n    \n  }\n\n  onHourInput(event: any): void {\n    if (this.data.dpConfig.enableTime !== true) return;\n    \n    const value = parseInt(event.target.value);\n    if (!isNaN(value)) {\n      if (this.is12HourFormat()) {\n        if (value >= 1 && value <= 12) {\n          this.selectedHourSignal.set(value);\n        }\n      } else {\n        if (value >= 0 && value <= 23) {\n          this.selectedHourSignal.set(value);\n        }\n      }\n    }\n  }\n\n  onMinuteInput(event: any): void {\n    if (this.data.dpConfig.enableTime !== true) return;\n    \n    const value = parseInt(event.target.value);\n    if (!isNaN(value) && value >= 0 && value <= 59) {\n      this.selectedMinuteSignal.set(value);\n    }\n  }\n\n  validateHourInput(): void {\n    if (this.data.dpConfig.enableTime !== true) return;\n    \n    if (this.is12HourFormat()) {\n      if (this.selectedHourSignal() < 1) this.selectedHourSignal.set(1);\n      if (this.selectedHourSignal() > 12) this.selectedHourSignal.set(12);\n    } else {\n      if (this.selectedHourSignal() < 0) this.selectedHourSignal.set(0);\n      if (this.selectedHourSignal() > 23) this.selectedHourSignal.set(23);\n    }\n  }\n\n  validateMinuteInput(): void {\n    if (this.data.dpConfig.enableTime !== true) return;\n    \n    if (this.selectedMinuteSignal() < 0) this.selectedMinuteSignal.set(0);\n    if (this.selectedMinuteSignal() > 59) this.selectedMinuteSignal.set(59);\n  }\n\n  is12HourFormat(): boolean {\n    return this.data.dpConfig.enableTime === true && \n           (this.data.dpConfig.format.includes('A') || this.data.dpConfig.format.includes('a'));\n  }\n\n  retractDayMonth(day: any, month: any, year: any): any {\n    return `${day} ${month} ${year}`;\n  }\n\n  ngOnInit(): void {\n    this.currentDateInstance();\n    this.calculateMinMaxDays();\n    this.calculateDisabledMonthsAndYears();\n    this.currentMonthDatesSignal.set(this.generateDates(this.currentMonthNumberSignal(), this.currentYearNumberSignal()));\n    \n    // Initialize time if enabled\n    if (this.data.dpConfig.enableTime === true) {\n      this.initializeTimeValues();\n    }\n  }\n  get yearRange(): string {\n    return `${this.selectedYearSignal() - 6} - ${this.selectedYearSignal() + 5}`;\n  }\n\n  private initializeTimeValues(): void {\n    if (this.data.dpConfig.enableTime === true) {\n      if (this.data.date) {\n        // Try to parse existing date for time values\n        try {\n          const currentDate = this.parseZoneInstance(this.data.date, this.data.dpConfig.format);\n          if (currentDate.isValid()) {\n            let hour = currentDate.hour();\n            this.selectedMinuteSignal.set(currentDate.minute());\n            \n            if (this.is12HourFormat()) {\n              if (hour === 0) {\n                hour = 12;\n                this.selectedAmPmSignal.set('AM');\n              } else if (hour > 12) {\n                hour = hour - 12;\n                this.selectedAmPmSignal.set('PM');\n              } else if (hour === 12) {\n                this.selectedAmPmSignal.set('PM');\n              } else {\n                this.selectedAmPmSignal.set('AM');\n              }\n            }\n            \n            this.selectedHourSignal.set(hour);\n          } else {\n            // Invalid date, use defaults\n            this.setDefaultTimeValues();\n          }\n        } catch (error) {\n          // Parsing error, use defaults\n          this.setDefaultTimeValues();\n        }\n      } \n     } else {\n        // No existing date, use defaults\n        this.setDefaultTimeValues();\n      }\n    \n  }\n\n  private setDefaultTimeValues(): void {\n    // Use current time as default instead of 12:00 PM\n    const now = dayjs();\n    const currentHour = now.hour();\n    const currentMinute = now.minute();\n    \n    if (this.is12HourFormat()) {\n      // Convert current time to 12-hour format\n      let hour12 = currentHour;\n      let amPm = 'AM';\n      \n      if (currentHour === 0) {\n        hour12 = 12;\n        amPm = 'AM';\n      } else if (currentHour === 12) {\n        hour12 = 12;\n        amPm = 'PM';\n      } else if (currentHour > 12) {\n        hour12 = currentHour - 12;\n        amPm = 'PM';\n      } else {\n        amPm = 'AM';\n      }\n      \n      this.selectedHourSignal.set(hour12);\n      this.selectedMinuteSignal.set(currentMinute);\n      this.selectedAmPmSignal.set(amPm);\n    } else {\n      // Use current time directly for 24-hour format\n      this.selectedHourSignal.set(currentHour);\n      this.selectedMinuteSignal.set(currentMinute);\n      this.selectedAmPmSignal.set('AM'); // Not used in 24-hour format but keep consistent\n    }\n  }\n\n  private currentDateInstance(): void {\n    try {\n      if (this.data.date) {\n        const selectedDate = dayjs(this.data.date, this.data.dpConfig.format);\n        if (selectedDate.isValid()) {\n          this.selectedYearSignal.set(selectedDate.year());\n          this.currentYearNumberSignal.set(selectedDate.year());\n          this.currentMonthNumberSignal.set(selectedDate.month());\n          this.currentMonthSignal.set(getMonth(selectedDate.month()));\n          \n          if (!this.localSelectedDateSignal()) {\n            this.localSelectedDateSignal.set({\n              date: selectedDate.date(),\n              weekDay: selectedDate.day(),\n              month: selectedDate.month(),\n              year: selectedDate.year(),\n              isSelectedDay: true\n            });\n          }\n        }\n      }\n    } catch (error) {\n      this.currentYearNumberSignal.set(this.parseZoneInstance().year());\n      this.currentMonthNumberSignal.set(this.parseZoneInstance().month());\n      this.currentMonthSignal.set(getMonth(this.currentMonthNumberSignal()));\n    }\n    \n    this.currentMonthDatesSignal.set(this.generateDates(this.currentMonthNumberSignal(), this.currentYearNumberSignal()));\n  }\n\n\n  private calculateMinMaxDays() {\n      const currentInstance = this.parseZoneInstance().year(this.currentYearNumberSignal()).month(this.currentMonthNumberSignal());\n      \n      if (this.data.dpConfig.minDate) {\n          const minDate = this.parseZoneInstance(this.data.dpConfig.minDate, this.data.dpConfig.format);\n          if (minDate?.isValid()) {\n            this.isPreviousMonthDisabledSignal.set(minDate.isSameOrAfter(currentInstance, \"month\"));\n          }\n    }\n    \n    if (this.data.dpConfig.maxDate) {\n        const maxDate = this.parseZoneInstance(this.data.dpConfig.maxDate, this.data.dpConfig.format);\n        if (maxDate?.isValid()) {\n          this.isNextMonthDisabledSignal.set(maxDate.isSameOrBefore(currentInstance, \"month\"));\n        }\n    }\n  }\n\n  calculateDisabledMonthsAndYears() {\n    const minDate = !!this.data.dpConfig.minDate ? this.parseZoneInstance(this.data.dpConfig.minDate, this.data.dpConfig.format) : dayjs('invalid');\n    const maxDate = !!this.data.dpConfig.maxDate ? this.parseZoneInstance(this.data.dpConfig.maxDate, this.data.dpConfig.format) : dayjs('invalid');\n    \n    this.disabledMonthsSignal.set(this.availableMonthsSignal().map((month, index) => {\n      const monthDate = this.parseZoneInstance().year(this.selectedYearSignal()).month(index);\n      return (minDate.isValid() && monthDate.isBefore(minDate, 'month')) || \n             (maxDate.isValid() && monthDate.isAfter(maxDate, 'month'));\n    }));\n  \n    this.disabledYearsSignal.set(this.availableYearsSignal().map((year) => {\n      const yearDate = this.parseZoneInstance().year(year);\n      return (minDate.isValid() && yearDate.isBefore(minDate, 'year')) || \n             (maxDate.isValid() && yearDate.isAfter(maxDate, 'year'));\n    }));\n\n    if (this.isSelectingYearSignal()) {\n      this.isPreviousMonthDisabledSignal.set(minDate.isValid() && ((this.selectedYearSignal() - 6) <= minDate.year()));\n      this.isNextMonthDisabledSignal.set(maxDate.isValid() && ((this.selectedYearSignal() + 5) >= maxDate.year()));\n    }\n    \n  }\n\n  navigateView(direction: \"NEXT\" | \"PREVIOUS\"): void {\n    if ((direction === 'NEXT' && (this.isNextMonthDisabledSignal() || this.isSelectingMonthSignal())) ||\n        (direction === 'PREVIOUS' && (this.isPreviousMonthDisabledSignal() || this.isSelectingMonthSignal()))) {\n      return;\n    }\n    if(this.isSelectingYearSignal()){\n      const newSelectedYear = this.selectedYearSignal() + (direction === \"NEXT\" ? 12 : -12);\n      this.selectedYearSignal.set(newSelectedYear);\n      this.availableYearsSignal.set(Array.from(\n        { length: 12 },\n        (_, index) => newSelectedYear - 6 + index\n      ));\n    }\n    else{\n      let thisMonth : dayjs.Dayjs = this.parseZoneInstance().year(this.currentYearNumberSignal()).month(this.currentMonthNumberSignal());\n      thisMonth = direction === \"NEXT\" ? thisMonth.add(1, \"month\") : thisMonth.subtract(1, \"month\");\n      this.currentMonthNumberSignal.set(thisMonth.month());\n      this.currentMonthSignal.set(getMonth(thisMonth.month()));\n      this.selectedYearSignal.set(thisMonth.year());\n      this.currentYearNumberSignal.set(thisMonth.year());\n      this.currentMonthDatesSignal.set(this.generateDates(thisMonth.month(), thisMonth.year()));\n    }\n    this.calculateMinMaxDays();\n    this.calculateDisabledMonthsAndYears();\n  }\n\n  navigateMonth(direction: \"NEXT\" | \"PREVIOUS\"): void {\n    try {\n      let thisMonth: dayjs.Dayjs = dayjs().year(this.currentYearNumberSignal()).month(this.currentMonthNumberSignal());\n      if (direction === \"NEXT\") {\n        thisMonth = thisMonth.add(1, \"month\");\n      } else if (direction === \"PREVIOUS\") {\n        thisMonth = thisMonth.subtract(1, \"month\");\n      }\n      this.currentMonthNumberSignal.set(thisMonth.month());\n      this.currentMonthSignal.set(getMonth(thisMonth.month()));\n      this.currentYearNumberSignal.set(thisMonth.year());\n      this.currentMonthDatesSignal.set(this.generateDates(thisMonth.month(), thisMonth.year()));\n      \n      this.calculateMinMaxDays();\n    } catch (error) {\n      // Silently handle navigateMonth error\n    }\n  }\n\n  private generateDates(month: number, currentYearNumber: number): ICurrentMonthDates[] {\n    const dates: ICurrentMonthDates[] = [];\n    \n    try {\n      const daysInMonth = dayjs().year(currentYearNumber).month(month).daysInMonth();\n      \n      let minDate = null;\n      let maxDate = null;\n      \n      if (this.data.dpConfig.minDate) {\n        try {\n          minDate = this.parseZoneInstance(this.data.dpConfig.minDate, this.data.dpConfig.format);\n        } catch (error) {\n          // Silently handle min date parsing error\n        }\n      }\n      \n      if (this.data.dpConfig.maxDate) {\n        try {\n          maxDate = this.parseZoneInstance(this.data.dpConfig.maxDate, this.data.dpConfig.format);\n        } catch (error) {\n          // Silently handle max date parsing error\n        }\n      }\n      \n      for (let currentDate = 1; currentDate <= daysInMonth; currentDate++) {\n        try {\n          const date = this.parseZoneInstance().year(currentYearNumber).month(month).date(currentDate);\n          const dateString = date.format(this.data.dpConfig.format);\n          \n          let isDisabledDay = this.data.datesDisabled?.some(d => d === dateString) || false;\n          \n          if (!isDisabledDay && minDate?.isValid() && this.data.dpConfig.minDate) {\n            isDisabledDay = minDate.isAfter(date, \"day\");\n          }\n          if (!isDisabledDay && maxDate?.isValid() && this.data.dpConfig.maxDate) {\n            isDisabledDay = maxDate.isBefore(date, \"day\");\n          }\n          \n          const currentDateInstance = this.parseZoneInstance().year(currentYearNumber).month(month).date(currentDate);\n          const isCurrentDay = currentDateInstance.format(this.data.dpConfig.format) === dayjs().format(this.data.dpConfig.format);\n          \n          let isSelectedDay = false;\n          \n          // Prioritize current selection over previously applied date\n          if (this.localSelectedDateSignal() && \n              this.localSelectedDateSignal()!.date === currentDate &&\n              this.localSelectedDateSignal()!.month === month &&\n              this.localSelectedDateSignal()!.year === currentYearNumber) {\n            isSelectedDay = true;\n          } else if (this.data.date && !this.localSelectedDateSignal()) {\n            // Only check previously applied date if no current selection\n            try {\n              if (this.data.dpConfig.enableTime) {\n                const selectedDate = this.parseZoneInstance(this.data.date, this.data.dpConfig.format);\n                if (selectedDate.isValid()) {\n                  isSelectedDay = selectedDate.isSame(currentDateInstance, 'day');\n                }\n              } else {\n                // For date-only format, compare the date parts only\n                const selectedDate = this.parseZoneInstance(this.data.date, this.data.dpConfig.format);\n                if (selectedDate.isValid()) {\n                  isSelectedDay = selectedDate.isSame(currentDateInstance, 'day');\n                } else {\n                  // Fallback to string comparison if parsing fails\n                  isSelectedDay = dateString === this.data.date;\n                }\n              }\n            } catch (error) {\n              // Silently handle date comparison error\n            }\n          }\n          \n          dates.push({\n            date: currentDate,\n            weekDay: date.day(),\n            month: month,\n            year: currentYearNumber,\n            isCurrentDay,\n            isSelectedDay,\n            toastMessage: this.data.messages?.find(q => dateString === q.date)?.message || \"\",\n            isDisabledDay\n          });\n        } catch (error) {\n          // Silently handle date processing error\n          dates.push({\n            date: currentDate,\n            weekDay: this.parseZoneInstance().year(currentYearNumber).month(month).date(currentDate).day(),\n            month: month,\n            year: currentYearNumber,\n            isDisabledDay: true\n          });\n        }\n      }\n      \n      if (dates.length > 0) {\n        for (let i = dates[0].weekDay; i > 0; i--) {\n          dates.unshift({ \n            date: 0, \n            weekDay: i - 1,\n            month: month,\n            year: currentYearNumber\n          });\n        }\n      }\n    } catch (error) {\n      // Silently handle generateDates error\n    }\n    \n    return dates;\n  }\n\n  selectDay(day: ICurrentMonthDates) {\n    if (day.date <= 0) return;\n    \n    try {\n      // Create the base date selection without time\n      this.currentSelectionSignal.set(this.parseZoneInstance().year(this.currentYearNumberSignal()).month(this.currentMonthNumberSignal()).date(day.date).hour(0).minute(0).second(0).millisecond(0));\n      \n      // Apply the current time values to the selection\n      if (this.data.dpConfig.enableTime === true) {\n        let hour = this.selectedHourSignal();\n        \n        if (this.is12HourFormat()) {\n          if (this.selectedAmPmSignal() === 'PM' && hour !== 12) {\n            hour += 12;\n          } else if (this.selectedAmPmSignal() === 'AM' && hour === 12) {\n            hour = 0;\n          }\n        }\n        \n        this.currentSelectionSignal.set(this.currentSelectionSignal()!\n          .hour(hour)\n          .minute(this.selectedMinuteSignal()));\n      }\n      \n      let maxDate = null;\n      let minDate = null;\n      \n      if (this.data.dpConfig.maxDate) {\n        try {\n          maxDate = this.parseZoneInstance(this.data.dpConfig.maxDate, this.data.dpConfig.format).endOf(\"day\");\n        } catch (error) {\n          // Silently handle max date parsing error\n        }\n      }\n      \n      if (this.data.dpConfig.minDate) {\n        try {\n          minDate = this.parseZoneInstance(this.data.dpConfig.minDate, this.data.dpConfig.format).startOf(\"day\");\n        } catch (error) {\n          // Silently handle min date parsing error\n        }\n      }\n      \n      this.allowBookingOnDisabledDaySignal.set(this.data.allowBookingOnDisabledDay);\n      \n      if (((!minDate || this.currentSelectionSignal()!.isSameOrAfter(minDate)) && (!maxDate || this.currentSelectionSignal()!.isSameOrBefore(maxDate)) && this.allowBookingOnDisabledDaySignal()) || (!day.isDisabledDay && !this.allowBookingOnDisabledDaySignal())) {\n        this.localSelectedDateSignal.set({\n          ...day,\n          month: this.currentMonthNumberSignal(),\n          year: this.currentYearNumberSignal()\n        });\n        \n        // Force calendar re-render to show highlighting\n        this.currentMonthDatesSignal.set(this.generateDates(this.currentMonthNumberSignal(), this.currentYearNumberSignal()));\n        \n        // Automatically apply when neither time nor apply button is enabled, otherwise wait for user action\n        if (!this.data.dpConfig.enableTime && !this.data.dpConfig.showApplyButton) {\n          this.applyDate(day);\n        }\n      }\n      \n      if (day.toastMessage || (this.allowBookingOnDisabledDay && day.toastMessage)) {\n        this.toast.displayMsg(day.toastMessage, 4000);\n      }\n    } catch (error) {\n      // Silently handle selectDay error\n    }\n  }\n\n  applyDate(day?: ICurrentMonthDates) {\n    let date: string;\n    \n    try {\n      if (this.data.dpConfig.enableTime === true) {\n        // Always use time input values when time is enabled, regardless of currentSelection\n        let hour = this.selectedHourSignal();\n        \n        if (this.is12HourFormat()) {\n          if (this.selectedAmPmSignal() === 'PM' && hour !== 12) {\n            hour += 12;\n          } else if (this.selectedAmPmSignal() === 'AM' && hour === 12) {\n            hour = 0;\n          }\n        }\n        \n        // Create a new date instance with the selected time\n        const finalSelection = dayjs()\n          .year(this.currentYearNumberSignal())\n          .month(this.currentMonthNumberSignal())\n          .date(this.localSelectedDateSignal()?.date || day?.date || dayjs().date())\n          .hour(hour)\n          .minute(this.selectedMinuteSignal())\n          .second(0)\n          .millisecond(0);\n        \n        date = finalSelection.format(this.data.dpConfig.format);\n      } else {\n        // Date-only format - no time\n        date = dayjs()\n          .year(this.currentYearNumberSignal())\n          .month(this.currentMonthNumberSignal())\n          .date(day ? day.date : this.localSelectedDateSignal()?.date || dayjs().date())\n          .hour(0)\n          .minute(0)\n          .second(0)\n          .millisecond(0)\n          .format(this.data.dpConfig.format);\n      }\n      \n      if (day || this.localSelectedDateSignal() || (this.data.dpConfig.enableTime === true)) {\n        this.data.dateChange(date);\n      } else {\n        this.cancelDatePicker();\n      }\n    } catch (error) {\n      // Silently handle applyDate error\n      this.data.dateChange(\"\");\n    }\n  }\n\n  @HostListener(\"keydown.esc\")\n  closeOnEsc() {\n    this.cancelDatePicker();\n  }\n\n  cancelDatePicker() {\n    this.data.dateChange(\"\");\n  }\n\n  toggleMonthSelector() {\n    if(this.isYearSelectionFlowSignal()) return;\n    this.isSelectingMonthSignal.set(!this.isSelectingMonthSignal());\n    this.isSelectingYearSignal.set(false);\n    this.calculateDisabledMonthsAndYears();\n  }\n\n  toggleYearSelector() {\n    this.isSelectingYearSignal.set(!this.isSelectingYearSignal());\n    this.selectedYearSignal.set(this.currentYearNumberSignal());\n    this.availableYearsSignal.set(Array.from(\n      { length: 12 },\n      (_, index) => this.selectedYearSignal() - 6 + index\n    ));\n    this.isSelectingMonthSignal.set(false);\n    this.calculateDisabledMonthsAndYears();\n\n  }\n\n  resetDateSelection() {\n    this.localSelectedDateSignal.set({\n      date: 0,\n      weekDay: 0,\n      isCurrentDay: false,\n      isSelectedDay: false,\n      isDisabledDay: false,\n      toastMessage: ''\n    });\n    this.data.date = '';\n  }\n\n  selectMonth(month: string) {\n    this.currentMonthNumberSignal.set(this.availableMonthsSignal().indexOf(month));\n    this.currentMonthSignal.set(getMonth(this.currentMonthNumberSignal()));\n    this.isSelectingMonthSignal.set(false);\n    this.isYearSelectionFlowSignal.set(false);\n    this.resetDateSelection();\n    this.currentMonthDatesSignal.set(this.generateDates(this.currentMonthNumberSignal(), this.currentYearNumberSignal()));\n    this.calculateMinMaxDays();\n  }\n\n  selectYear(year: number) {\n    this.selectedYearSignal.set(year);\n    this.currentYearNumberSignal.set(year);\n    this.isSelectingYearSignal.set(false);\n    this.isSelectingMonthSignal.set(true);\n    this.isYearSelectionFlowSignal.set(true);\n    this.resetDateSelection();\n    this.calculateDisabledMonthsAndYears();\n  }\n}\n","<div class=\"datepicker-container\" [ngClass]=\"data.disableBoxShadow?'remove-box-shadow':''\" aria-label=\"date picker\" cdkTrapFocus [cdkTrapFocusAutoCapture]=\"true\">\n  <div tabindex=\"-1\" cdkFocusInitial></div>\n  <div class=\"datepicker-container__header\">\n    <div\n      class=\"datepicker-container__arrow__icon\"\n      (click)=\"navigateView('PREVIOUS')\"\n      tabindex=\"0\"\n      aria-label=\"Previous Month\"\n      (keyup.enter)=\"navigateView('PREVIOUS')\"\n      [ngClass]=\"{\n        'disabled-month': isPreviousMonthDisabled() || isSelectingMonth()\n      }\"\n    >\n      <svg width=\"20\" height=\"16\" viewBox=\"0 0 20 16\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n        <path\n          d=\"M19.7071 8.70711C20.0976 8.31658 20.0976 7.68342 19.7071 7.29289L13.3431 0.928933C12.9526 0.538409 12.3195 0.538409 11.9289 0.928933C11.5384 1.31946 11.5384 1.95262 11.9289 2.34315L17.5858 8L11.9289 13.6569C11.5384 14.0474 11.5384 14.6805 11.9289 15.0711C12.3195 15.4616 12.9526 15.4616 13.3431 15.0711L19.7071 8.70711ZM-8.74228e-08 9L19 9L19 7L8.74228e-08 7L-8.74228e-08 9Z\"\n          fill=\"#181F33\"\n        ></path>\n      </svg>\n    </div>\n\n    <div *ngIf=\"!isSelectingYear()\" (click)=\"toggleMonthSelector()\" class=\"month-header\">\n      {{ isYearSelectionFlow() ? selectedYear() : availableMonths()[currentMonthNumber()] }}\n    </div>\n    <div *ngIf=\"!isSelectingMonth()\" (click)=\"toggleYearSelector()\" class=\"year-header\">\n      {{ isSelectingYear() ? yearRange : currentYearNumber() }}\n    </div>\n\n\n    <div\n      class=\"datepicker-container__arrow__icon\"\n      (click)=\"navigateView('NEXT')\"\n      tabindex=\"0\"\n      aria-label=\"Next Month\"\n      (keyup.enter)=\"navigateView('NEXT')\"\n      [ngClass]=\"{\n        'disabled-month': isNextMonthDisabled() || isSelectingMonth()\n      }\"\n    >\n      <svg width=\"20\" height=\"16\" viewBox=\"0 0 20 16\" fill=\"none\" xmlns=\"http://www.w3.org/2000/svg\">\n        <path\n          d=\"M19.7071 8.70711C20.0976 8.31658 20.0976 7.68342 19.7071 7.29289L13.3431 0.928933C12.9526 0.538409 12.3195 0.538409 11.9289 0.928933C11.5384 1.31946 11.5384 1.95262 11.9289 2.34315L17.5858 8L11.9289 13.6569C11.5384 14.0474 11.5384 14.6805 11.9289 15.0711C12.3195 15.4616 12.9526 15.4616 13.3431 15.0711L19.7071 8.70711ZM-8.74228e-08 9L19 9L19 7L8.74228e-08 7L-8.74228e-08 9Z\"\n          fill=\"#181F33\"\n        ></path>\n      </svg>\n    </div>\n  </div>\n  <div class=\"datepicker-container__body\">\n\n    <div *ngIf=\"isSelectingMonth() && !isSelectingYear()\" class=\"month-selector\">\n      <div class=\"row\">\n        <div *ngFor=\"let month of availableMonths(); let i = index\" \n            class=\"month\" \n            (click)=\"!disabledMonths()[i] && selectMonth(month)\" \n            [ngClass]=\"{\n              'disable-month': disabledMonths()[i],\n              'select-month': !disabledMonths()[currentMonthNumber()] && month === availableMonths()[currentMonthNumber()]\n            }\">\n          {{ month }}\n        </div>\n      </div>\n    </div>\n  \n    <div *ngIf=\"isSelectingYear() && !isSelectingMonth()\" class=\"year-selector\">\n      <div class=\"row\">\n        <div *ngFor=\"let year of availableYears(); let i = index\" \n            class=\"year\" \n            (click)=\"!disabledYears()[i] && selectYear(year)\" \n            [ngClass]=\"{\n              'disable-year': disabledYears()[i],\n              'select-year': year === currentYearNumber()\n            }\">\n          {{ year }}\n        </div>\n      </div>\n    </div>\n\n    <div *ngIf=\"!isSelectingMonth() && !isSelectingYear()\" class=\"datepicker-container__weekdays\">\n      <div class=\"datepicker-container__weekday\" *ngFor=\"let weekDay of weekDays()\">\n        <span [ngClass]=\"{ 'current-day': weekDay.isCurrentDay }\">{{ weekDay.label }}</span>\n      </div>\n    </div>\n    <div *ngIf=\"!isSelectingMonth() && !isSelectingYear()\" class=\"datepicker-container__days\">\n      <div\n        class=\"datepicker-container__day\"\n        [ngClass]=\"{\n          'selected-day': day.isSelectedDay,\n          'disabled-day': day.isDisabledDay,\n          'is-valid-date': day.date > 0 && !day.isSelectedDay\n        }\"\n        *ngFor=\"let day of currentMonthDates()\"\n        (click)=\"selectDay(day)\"\n        (keyup.enter)=\"selectDay(day)\"\n      >\n        <span\n          *ngIf=\"day.date > 0\"\n          [tabindex]=\"day.isDisabledDay ? -1 : 0\"\n          [ngClass]=\"{\n            'current-day': day.isCurrentDay,\n            'selected-day': day.isSelectedDay,\n            'disabled-day': day.isDisabledDay\n          }\"\n          [attr.aria-label]=\"retractDayMonth(day.date, currentMonth(), currentYearNumber())\"\n        >\n          {{ day.date }}\n        </span>\n      </div>\n    </div>\n  </div>\n\n  <!-- Time Picker Section -->\n  <div class=\"datepicker-container__time\" *ngIf=\"data.dpConfig.enableTime === true\">\n    <div class=\"time-picker-header\">\n      <span>Time</span>\n    </div>\n    <div class=\"time-picker-controls\">\n      <div class=\"time-input-group\">\n        <label for=\"hourInput\">Hour</label>\n        <input \n          id=\"hourInput\"\n          type=\"number\" \n          [min]=\"is12HourFormat() ? 1 : 0\"\n          [max]=\"is12HourFormat() ? 12 : 23\"\n          [step]=\"1\"\n          [ngModel]=\"selectedHour()\"\n          (ngModelChange)=\"selectedHourSignal.set($event)\"\n          (input)=\"onHourInput($event)\"\n          (blur)=\"validateHourInput()\"\n          class=\"time-input\"\n          [title]=\"is12HourFormat() ? 'Enter hour (1-12)' : 'Enter hour (0-23)'\">\n      </div>\n      <div class=\"time-separator\">:</div>\n      <div class=\"time-input-group\">\n        <label for=\"minuteInput\">Minute</label>\n        <input \n          id=\"minuteInput\"\n          type=\"number\" \n          min=\"0\" \n          max=\"59\"\n          [step]=\"1\"\n          [ngModel]=\"selectedMinute()\"\n          (ngModelChange)=\"selectedMinuteSignal.set($event)\"\n          (input)=\"onMinuteInput($event)\"\n          (blur)=\"validateMinuteInput()\"\n          class=\"time-input\"\n          title=\"Enter minute (0-59)\">\n      </div>\n      <div class=\"am-pm-selector\" *ngIf=\"is12HourFormat()\">\n        <label for=\"amPmSelect\">AM/PM</label>\n        <select \n          id=\"amPmSelect\"\n          [ngModel]=\"selectedAmPm()\"\n          (ngModelChange)=\"selectedAmPmSignal.set($event)\"\n          class=\"am-pm-select\">\n          <option value=\"AM\">AM</option>\n          <option value=\"PM\">PM</option>\n        </select>\n      </div>\n    </div>\n  </div>\n\n  <div class=\"datepicker-container__footer\" *ngIf=\"data.dpConfig.showApplyButton || data.dpConfig.enableTime\">\n    <button mis-button size=\"md\" type=\"'none'\" (click)=\"cancelDatePicker()\">Cancel</button>\n    <button mis-button size=\"md\" type=\"primary\" (click)=\"applyDate()\" [disabled]=\"!(data.date || localSelectedDate()?.date)\">Apply</button>\n  </div>\n</div>\n"]}
|