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.
Files changed (163) hide show
  1. package/action-list/action-list.component.d.ts +17 -15
  2. package/async-search-dropdown/async-dropdown.component.d.ts +43 -61
  3. package/button/button.component.d.ts +35 -13
  4. package/button/button.directive.d.ts +10 -8
  5. package/checkbox/checkbox.component.d.ts +15 -12
  6. package/chip/chip.component.d.ts +9 -11
  7. package/datepicker_v2/models/dp-config.model.d.ts +1 -0
  8. package/datepicker_v2/tz-datepicker.directive.d.ts +15 -18
  9. package/datepicker_v2/tz-dp-container/tz-dp-container.component.d.ts +42 -21
  10. package/daterangepicker_v2/tz-daterangepicker.directive.d.ts +12 -14
  11. package/daterangepicker_v2/tz-drp-container/tz-drp-container.component.d.ts +46 -23
  12. package/drawer/drawer-body/drawer-body.component.d.ts +2 -2
  13. package/dropdown/calculate-container-height.directive.d.ts +7 -8
  14. package/dropdown/dropdown.component.d.ts +41 -49
  15. package/dynamic-form/dynamic-form.component.d.ts +20 -16
  16. package/esm2022/action-list/action-list.component.mjs +112 -89
  17. package/esm2022/async-search-dropdown/async-dropdown.component.mjs +256 -326
  18. package/esm2022/button/button.component.mjs +55 -48
  19. package/esm2022/button/button.directive.mjs +36 -40
  20. package/esm2022/checkbox/checkbox.component.mjs +75 -70
  21. package/esm2022/chip/chip.component.mjs +20 -33
  22. package/esm2022/datepicker_v2/models/dp-config.model.mjs +1 -1
  23. package/esm2022/datepicker_v2/tz-datepicker.directive.mjs +42 -71
  24. package/esm2022/datepicker_v2/tz-dp-container/tz-dp-container.component.mjs +202 -172
  25. package/esm2022/datepicker_v2/utils/index.mjs +2 -1
  26. package/esm2022/daterangepicker_v2/tz-daterangepicker.directive.mjs +26 -51
  27. package/esm2022/daterangepicker_v2/tz-drp-container/tz-drp-container.component.mjs +282 -235
  28. package/esm2022/drawer/drawer-body/drawer-body.component.mjs +8 -7
  29. package/esm2022/dropdown/calculate-container-height.directive.mjs +25 -22
  30. package/esm2022/dropdown/dropdown.component.mjs +162 -186
  31. package/esm2022/dynamic-form/dynamic-form.component.mjs +118 -72
  32. package/esm2022/fab/fab.component.mjs +29 -33
  33. package/esm2022/filter/filter-panel/filter-panel.component.mjs +60 -58
  34. package/esm2022/input/directives/input/input.directive.mjs +22 -26
  35. package/esm2022/input/mis-input.component.mjs +41 -45
  36. package/esm2022/input-stepper/input-stepper/input-stepper.component.mjs +40 -50
  37. package/esm2022/loader/loader.component.mjs +8 -11
  38. package/esm2022/mobile-filter/mobile-filter.component.mjs +61 -61
  39. package/esm2022/modal/module-wrapper/module-wrapper.component.mjs +11 -9
  40. package/esm2022/multi-select-dropdown/multi-select-dropdown.component.mjs +235 -281
  41. package/esm2022/nested-multi-select-dropdown/nested-multi-select-dropdown.component.mjs +250 -287
  42. package/esm2022/phone-input/phone-input.component.mjs +21 -43
  43. package/esm2022/radio-button/radio-button.component.mjs +15 -27
  44. package/esm2022/ske-loader/ske-loader.component.mjs +15 -29
  45. package/esm2022/slider/slider.component.mjs +23 -33
  46. package/esm2022/slider/slider.module.mjs +4 -11
  47. package/esm2022/snackbar/snackbar/snackbar.component.mjs +21 -15
  48. package/esm2022/snackbar/snackbar.service.mjs +3 -2
  49. package/esm2022/specificdatepicker/tz-sdp-container/tz-sdp-container.component.mjs +230 -343
  50. package/esm2022/specificdatepicker/tz-specificdatepicker.directive.mjs +77 -105
  51. package/esm2022/star-rating/star-rating.component.mjs +57 -71
  52. package/esm2022/switch/switch.component.mjs +34 -36
  53. package/esm2022/table/actions-cell/actions-cell.component.mjs +55 -54
  54. package/esm2022/table/custom-table-cell.directive.mjs +22 -18
  55. package/esm2022/table/filter/filter.component.mjs +60 -42
  56. package/esm2022/table/sort-icons.directive.mjs +16 -8
  57. package/esm2022/table/sub-table/sub-table.component.mjs +41 -44
  58. package/esm2022/table/table.component.mjs +181 -165
  59. package/esm2022/timepicker/timepicker.component.mjs +244 -159
  60. package/esm2022/timepicker/timepicker.directive.mjs +3 -2
  61. package/esm2022/timerangepicker/timerangepicker.component.mjs +200 -159
  62. package/esm2022/toast/toast.component.mjs +6 -7
  63. package/esm2022/toast/toast.data.service.mjs +15 -9
  64. package/esm2022/tooltip/tooltip-container/tooltip.component.mjs +12 -12
  65. package/esm2022/tooltip/tooltip.directive.mjs +4 -4
  66. package/esm2022/virtual-scroll/virtual-scroll.component.mjs +57 -59
  67. package/fab/fab.component.d.ts +12 -8
  68. package/fesm2022/mis-crystal-design-system-action-list.mjs +111 -88
  69. package/fesm2022/mis-crystal-design-system-action-list.mjs.map +1 -1
  70. package/fesm2022/mis-crystal-design-system-async-search-dropdown.mjs +253 -324
  71. package/fesm2022/mis-crystal-design-system-async-search-dropdown.mjs.map +1 -1
  72. package/fesm2022/mis-crystal-design-system-button.mjs +88 -85
  73. package/fesm2022/mis-crystal-design-system-button.mjs.map +1 -1
  74. package/fesm2022/mis-crystal-design-system-checkbox.mjs +74 -69
  75. package/fesm2022/mis-crystal-design-system-checkbox.mjs.map +1 -1
  76. package/fesm2022/mis-crystal-design-system-chip.mjs +19 -32
  77. package/fesm2022/mis-crystal-design-system-chip.mjs.map +1 -1
  78. package/fesm2022/mis-crystal-design-system-datepicker_v2.mjs +242 -240
  79. package/fesm2022/mis-crystal-design-system-datepicker_v2.mjs.map +1 -1
  80. package/fesm2022/mis-crystal-design-system-daterangepicker_v2.mjs +305 -283
  81. package/fesm2022/mis-crystal-design-system-daterangepicker_v2.mjs.map +1 -1
  82. package/fesm2022/mis-crystal-design-system-drawer.mjs +7 -6
  83. package/fesm2022/mis-crystal-design-system-drawer.mjs.map +1 -1
  84. package/fesm2022/mis-crystal-design-system-dropdown.mjs +183 -204
  85. package/fesm2022/mis-crystal-design-system-dropdown.mjs.map +1 -1
  86. package/fesm2022/mis-crystal-design-system-dynamic-form.mjs +118 -72
  87. package/fesm2022/mis-crystal-design-system-dynamic-form.mjs.map +1 -1
  88. package/fesm2022/mis-crystal-design-system-fab.mjs +28 -32
  89. package/fesm2022/mis-crystal-design-system-fab.mjs.map +1 -1
  90. package/fesm2022/mis-crystal-design-system-filter.mjs +59 -57
  91. package/fesm2022/mis-crystal-design-system-filter.mjs.map +1 -1
  92. package/fesm2022/mis-crystal-design-system-input-stepper.mjs +39 -49
  93. package/fesm2022/mis-crystal-design-system-input-stepper.mjs.map +1 -1
  94. package/fesm2022/mis-crystal-design-system-input.mjs +62 -71
  95. package/fesm2022/mis-crystal-design-system-input.mjs.map +1 -1
  96. package/fesm2022/mis-crystal-design-system-loader.mjs +7 -10
  97. package/fesm2022/mis-crystal-design-system-loader.mjs.map +1 -1
  98. package/fesm2022/mis-crystal-design-system-mobile-filter.mjs +60 -60
  99. package/fesm2022/mis-crystal-design-system-mobile-filter.mjs.map +1 -1
  100. package/fesm2022/mis-crystal-design-system-modal.mjs +10 -8
  101. package/fesm2022/mis-crystal-design-system-modal.mjs.map +1 -1
  102. package/fesm2022/mis-crystal-design-system-multi-select-dropdown.mjs +233 -279
  103. package/fesm2022/mis-crystal-design-system-multi-select-dropdown.mjs.map +1 -1
  104. package/fesm2022/mis-crystal-design-system-nested-multi-select-dropdown.mjs +249 -286
  105. package/fesm2022/mis-crystal-design-system-nested-multi-select-dropdown.mjs.map +1 -1
  106. package/fesm2022/mis-crystal-design-system-phone-input.mjs +20 -42
  107. package/fesm2022/mis-crystal-design-system-phone-input.mjs.map +1 -1
  108. package/fesm2022/mis-crystal-design-system-radio-button.mjs +14 -26
  109. package/fesm2022/mis-crystal-design-system-radio-button.mjs.map +1 -1
  110. package/fesm2022/mis-crystal-design-system-ske-loader.mjs +14 -28
  111. package/fesm2022/mis-crystal-design-system-ske-loader.mjs.map +1 -1
  112. package/fesm2022/mis-crystal-design-system-slider.mjs +25 -42
  113. package/fesm2022/mis-crystal-design-system-slider.mjs.map +1 -1
  114. package/fesm2022/mis-crystal-design-system-snackbar.mjs +22 -15
  115. package/fesm2022/mis-crystal-design-system-snackbar.mjs.map +1 -1
  116. package/fesm2022/mis-crystal-design-system-specificdatepicker.mjs +304 -445
  117. package/fesm2022/mis-crystal-design-system-specificdatepicker.mjs.map +1 -1
  118. package/fesm2022/mis-crystal-design-system-star-rating.mjs +56 -70
  119. package/fesm2022/mis-crystal-design-system-star-rating.mjs.map +1 -1
  120. package/fesm2022/mis-crystal-design-system-switch.mjs +33 -35
  121. package/fesm2022/mis-crystal-design-system-switch.mjs.map +1 -1
  122. package/fesm2022/mis-crystal-design-system-table.mjs +365 -321
  123. package/fesm2022/mis-crystal-design-system-table.mjs.map +1 -1
  124. package/fesm2022/mis-crystal-design-system-timepicker.mjs +245 -159
  125. package/fesm2022/mis-crystal-design-system-timepicker.mjs.map +1 -1
  126. package/fesm2022/mis-crystal-design-system-timerangepicker.mjs +199 -158
  127. package/fesm2022/mis-crystal-design-system-timerangepicker.mjs.map +1 -1
  128. package/fesm2022/mis-crystal-design-system-toast.mjs +18 -13
  129. package/fesm2022/mis-crystal-design-system-toast.mjs.map +1 -1
  130. package/fesm2022/mis-crystal-design-system-tooltip.mjs +14 -14
  131. package/fesm2022/mis-crystal-design-system-tooltip.mjs.map +1 -1
  132. package/fesm2022/mis-crystal-design-system-virtual-scroll.mjs +57 -59
  133. package/fesm2022/mis-crystal-design-system-virtual-scroll.mjs.map +1 -1
  134. package/filter/filter-panel/filter-panel.component.d.ts +14 -14
  135. package/input/directives/input/input.directive.d.ts +6 -10
  136. package/input/mis-input.component.d.ts +12 -13
  137. package/input-stepper/input-stepper/input-stepper.component.d.ts +8 -7
  138. package/loader/loader.component.d.ts +3 -6
  139. package/mobile-filter/mobile-filter.component.d.ts +15 -15
  140. package/modal/module-wrapper/module-wrapper.component.d.ts +2 -3
  141. package/multi-select-dropdown/multi-select-dropdown.component.d.ts +89 -51
  142. package/nested-multi-select-dropdown/nested-multi-select-dropdown.component.d.ts +99 -56
  143. package/package.json +17 -17
  144. package/phone-input/phone-input.component.d.ts +16 -18
  145. package/radio-button/radio-button.component.d.ts +9 -11
  146. package/ske-loader/ske-loader.component.d.ts +8 -11
  147. package/slider/slider.component.d.ts +8 -11
  148. package/slider/slider.module.d.ts +1 -2
  149. package/snackbar/snackbar/snackbar.component.d.ts +3 -3
  150. package/specificdatepicker/tz-sdp-container/tz-sdp-container.component.d.ts +35 -35
  151. package/specificdatepicker/tz-specificdatepicker.directive.d.ts +24 -28
  152. package/star-rating/star-rating.component.d.ts +18 -18
  153. package/switch/switch.component.d.ts +8 -10
  154. package/table/actions-cell/actions-cell.component.d.ts +14 -14
  155. package/table/custom-table-cell.directive.d.ts +3 -3
  156. package/table/filter/filter.component.d.ts +9 -9
  157. package/table/sub-table/sub-table.component.d.ts +5 -5
  158. package/table/table.component.d.ts +38 -35
  159. package/timepicker/timepicker.component.d.ts +29 -28
  160. package/timerangepicker/timerangepicker.component.d.ts +36 -33
  161. package/toast/toast.data.service.d.ts +1 -1
  162. package/tooltip/tooltip-container/tooltip.component.d.ts +4 -4
  163. package/virtual-scroll/virtual-scroll.component.d.ts +8 -9
@@ -1,4 +1,4 @@
1
- import { Component, EventEmitter, Input, Output, ViewChild, ViewChildren } from "@angular/core";
1
+ import { Component, ViewChild, ViewChildren, input, output, signal, effect, untracked } from "@angular/core";
2
2
  import { TimepickerDirective } from "./timepicker.directive";
3
3
  import { ToolTipDirective } from "mis-crystal-design-system/tooltip";
4
4
  import dayjs from 'dayjs';
@@ -32,11 +32,11 @@ function TimePickerComponent_ng_template_3_div_0_li_3_Template(rf, ctx) { if (rf
32
32
  const interval_r3 = ctx.$implicit;
33
33
  const i_r5 = ctx.index;
34
34
  const ctx_r3 = i0.ɵɵnextContext(3);
35
- i0.ɵɵproperty("ngClass", i0.ɵɵpureFunction1(3, _c6, i_r5 === ctx_r3.isHighlighted));
35
+ i0.ɵɵproperty("ngClass", i0.ɵɵpureFunction1(3, _c6, i_r5 === ctx_r3.isHighlighted()));
36
36
  i0.ɵɵadvance(2);
37
37
  i0.ɵɵtextInterpolate1(" ", interval_r3, " ");
38
38
  i0.ɵɵadvance();
39
- i0.ɵɵproperty("ngIf", interval_r3 === ctx_r3.chosenTime);
39
+ i0.ɵɵproperty("ngIf", interval_r3 === ctx_r3.chosenTime());
40
40
  } }
41
41
  function TimePickerComponent_ng_template_3_div_0_Template(rf, ctx) { if (rf & 1) {
42
42
  i0.ɵɵelementStart(0, "div", 8)(1, "ul", null, 2);
@@ -44,15 +44,15 @@ function TimePickerComponent_ng_template_3_div_0_Template(rf, ctx) { if (rf & 1)
44
44
  i0.ɵɵelementEnd()();
45
45
  } if (rf & 2) {
46
46
  const ctx_r3 = i0.ɵɵnextContext(2);
47
- i0.ɵɵproperty("ngStyle", i0.ɵɵpureFunction1(2, _c5, ctx_r3.dropdownWidth || ctx_r3.inputWidth));
47
+ i0.ɵɵproperty("ngStyle", i0.ɵɵpureFunction1(2, _c5, ctx_r3.dropdownWidth() || ctx_r3.inputWidth()));
48
48
  i0.ɵɵadvance(3);
49
- i0.ɵɵproperty("ngForOf", ctx_r3.timeIntervals);
49
+ i0.ɵɵproperty("ngForOf", ctx_r3.timeIntervals());
50
50
  } }
51
51
  function TimePickerComponent_ng_template_3_Template(rf, ctx) { if (rf & 1) {
52
52
  i0.ɵɵtemplate(0, TimePickerComponent_ng_template_3_div_0_Template, 4, 4, "div", 7);
53
53
  } if (rf & 2) {
54
54
  const ctx_r3 = i0.ɵɵnextContext();
55
- i0.ɵɵproperty("ngIf", ctx_r3.openStatus);
55
+ i0.ɵɵproperty("ngIf", ctx_r3.openStatus());
56
56
  } }
57
57
  dayjs.extend(utc);
58
58
  dayjs.extend(timezone);
@@ -68,64 +68,152 @@ export class TimePickerComponent {
68
68
  });
69
69
  }
70
70
  constructor() {
71
- this.openStatus = false;
72
- this.isHighlighted = 0;
73
- this.isInvalid = false;
74
- this.timeIntervals = [];
75
- this.shouldScroll = false;
76
- this.userInputFlag = false;
77
- this.givenTimeFlag = true;
78
- this.clockFormat = 12;
79
- this.timezone = "Asia/Kolkata";
80
- this.height = "max-content";
81
- this.inputWidth = "100px";
82
- this.interval = 15;
83
- this.dateAsEpoch = dayjs.tz(dayjs(), this.timezone).valueOf();
84
- this.rangeValidity = true;
85
- this.showTooltip = true;
86
- this.dispayToolTip = this.showTooltip;
87
- this.triggerChange = true;
88
- this.disable = false;
89
- this.timeEmitter = new EventEmitter();
71
+ // Convert to signals for better performance and change detection
72
+ this.currTime = signal('');
73
+ this.chosenTime = signal('');
74
+ this.openStatus = signal(false);
75
+ this.isHighlighted = signal(0);
76
+ this.isInvalid = signal(false);
77
+ this.timeIntervals = signal([]);
78
+ this.shouldScroll = signal(false);
79
+ this.userInputFlag = signal(false);
80
+ this.givenTimeFlag = signal(true);
81
+ // Signal-based inputs with backward compatibility
82
+ this.clockFormat = input(12);
83
+ this.timezone = input("Asia/Kolkata");
84
+ this.height = input("max-content");
85
+ this.inputWidth = input("100px");
86
+ this.dropdownWidth = input(undefined);
87
+ this.interval = input(15);
88
+ this.dateAsEpoch = input(dayjs.tz(dayjs(), "Asia/Kolkata").valueOf());
89
+ this.firstInterval = input();
90
+ this.rangeValidity = input(true);
91
+ this.showTooltip = input(true);
92
+ this.dispayToolTip = this.showTooltip();
93
+ this.givenTime = input();
94
+ this.minTime = input(undefined);
95
+ this.triggerChange = input(true);
96
+ this.disable = input(false);
97
+ // Internal state for computed first interval
98
+ this.computedFirstInterval = null;
99
+ this._isInitializing = false;
100
+ // Signal-based output with backward compatibility
101
+ this.timeEmitter = output();
102
+ // Effect to handle triggerChange from parent component (timerangepicker)
103
+ effect(() => {
104
+ const triggerValue = this.triggerChange();
105
+ const firstIntervalValue = this.firstInterval();
106
+ // Only update if not during user input and firstInterval is provided
107
+ if (!untracked(() => this.userInputFlag()) && firstIntervalValue && !this._isInitializing) {
108
+ const newTime = dayjs.tz(firstIntervalValue, untracked(() => this.timezone())).format(this.timeFormat);
109
+ // Only update if the time actually changed
110
+ if (untracked(() => this.chosenTime()) !== newTime) {
111
+ // Use setTimeout to defer signal writes and avoid circular dependencies
112
+ setTimeout(() => {
113
+ this.chosenTime.set(newTime);
114
+ this.isInvalid.set(!this.checkTimeValidity(newTime.trim()));
115
+ // CRITICAL FIX: Repopulate dropdown when firstInterval changes
116
+ this.populateDropdown();
117
+ // Recalculate closest interval
118
+ this.calculateClosestInterval(newTime);
119
+ // Emit the updated time
120
+ const timedayjs = this.getdayjs(newTime);
121
+ this.emitTime({
122
+ valid: !this.isInvalid(),
123
+ time: newTime,
124
+ epoch: timedayjs.valueOf()
125
+ });
126
+ }, 0);
127
+ }
128
+ }
129
+ });
90
130
  }
91
131
  ngOnInit() {
92
- if (!this.givenTime && !this.minTime) {
93
- this.chosenTime = dayjs.tz(this.firstInterval, this.timezone).format(this.timeFormat);
94
- let chosenTimedayjs = this.getdayjs(this.chosenTime);
95
- this.emitTime({
96
- valid: !this.isInvalid,
97
- time: this.chosenTime,
98
- epoch: chosenTimedayjs.valueOf()
99
- });
100
- }
101
- }
102
- ngOnChanges() {
103
- this.timeFormat = this.clockFormat === 12 ? "hh:mm a" : "HH:mm";
104
- if (this.timeFormat) {
105
- let chosenTimedayjs = this.getdayjs(this.chosenTime);
106
- // if the first interval is >= the chosen time
107
- // then only update the value of chosen time
108
- // else it remains the same
109
- if (this.firstInterval >= chosenTimedayjs.valueOf() && this.rangeValidity && !this.userInputFlag) {
110
- this.chosenTime = dayjs.tz(this.firstInterval, this.timezone).format(this.timeFormat);
111
- chosenTimedayjs = this.getdayjs(this.chosenTime);
132
+ this._isInitializing = true;
133
+ // Ensure timeFormat is set before initialization
134
+ this.timeFormat = this.clockFormat() === 12 ? "hh:mm a" : "HH:mm";
135
+ // Initialize chosenTime - use firstInterval from parent if available, otherwise calculate
136
+ if (!this.givenTime() && !this.minTime()) {
137
+ let initialTime;
138
+ // If firstInterval is provided by parent (timerangepicker), use it
139
+ if (this.firstInterval()) {
140
+ initialTime = dayjs.tz(this.firstInterval(), this.timezone()).format(this.timeFormat);
112
141
  }
113
- if ((this.givenTimeFlag && this.givenTime) || this.minTime) {
114
- this.chosenTime = dayjs.tz(this.minTime || this.givenTime, this.timezone).format(this.timeFormat);
142
+ else {
143
+ // Get current time and round to nearest interval using original logic
144
+ const now = dayjs.tz(dayjs(), this.timezone());
145
+ const interval = this.interval();
146
+ const minutes = now.minute();
147
+ const offset = interval - (minutes % interval);
148
+ // Round to next interval if we're past halfway point
149
+ const roundedTime = offset >= interval / 2
150
+ ? now.add(offset, "m").second(0).millisecond(0)
151
+ : now.subtract(interval - offset, "m").second(0).millisecond(0);
152
+ initialTime = roundedTime.format(this.timeFormat);
115
153
  }
116
- chosenTimedayjs = this.getdayjs(this.chosenTime);
117
- if (!this.userInputFlag)
118
- this.populateDropdown();
119
- this.userInputFlag = false;
120
- if (this.chosenTime) {
121
- this.isInvalid = !this.checkTimeValidity(this.chosenTime.trim());
154
+ this.chosenTime.set(initialTime);
155
+ // Set userInputFlag to false to avoid validation issues during initialization
156
+ this.userInputFlag.set(false);
157
+ // Populate dropdown first to compute the first interval
158
+ this.populateDropdown();
159
+ // Now validate with the computed first interval
160
+ this.isInvalid.set(!this.checkTimeValidity(this.chosenTime().trim()));
161
+ let chosenTimedayjs = this.getdayjs(this.chosenTime());
162
+ // Defer emission to avoid ExpressionChangedAfterItHasBeenCheckedError
163
+ setTimeout(() => {
122
164
  this.emitTime({
123
- valid: !this.isInvalid,
124
- time: this.chosenTime,
165
+ valid: !this.isInvalid(),
166
+ time: this.chosenTime(),
125
167
  epoch: chosenTimedayjs.valueOf()
126
168
  });
127
- this.calculateClosestInterval(this.chosenTime);
128
- }
169
+ }, 0);
170
+ // Calculate closest interval
171
+ this.calculateClosestInterval(this.chosenTime());
172
+ this._isInitializing = false;
173
+ }
174
+ else if (this.givenTime()) {
175
+ // When givenTime is present, use the given time as the initial value
176
+ // but the dropdown will start from 12:00 AM
177
+ this.chosenTime.set(dayjs.tz(this.givenTime(), this.timezone()).format(this.timeFormat));
178
+ this.userInputFlag.set(false);
179
+ // Populate dropdown first to compute the first interval
180
+ this.populateDropdown();
181
+ // Now validate with the computed first interval
182
+ this.isInvalid.set(!this.checkTimeValidity(this.chosenTime().trim()));
183
+ let chosenTimedayjs = this.getdayjs(this.chosenTime());
184
+ // Defer emission to avoid ExpressionChangedAfterItHasBeenCheckedError
185
+ setTimeout(() => {
186
+ this.emitTime({
187
+ valid: !this.isInvalid(),
188
+ time: this.chosenTime(),
189
+ epoch: chosenTimedayjs.valueOf()
190
+ });
191
+ }, 0);
192
+ // Calculate closest interval
193
+ this.calculateClosestInterval(this.chosenTime());
194
+ this._isInitializing = false;
195
+ }
196
+ else if (this.minTime()) {
197
+ // Use min time directly - this matches original behavior
198
+ this.chosenTime.set(dayjs.tz(this.minTime(), this.timezone()).format(this.timeFormat));
199
+ this.userInputFlag.set(false);
200
+ // Populate dropdown first to compute the first interval
201
+ this.populateDropdown();
202
+ // For minTime, validation should only check format, not time comparison
203
+ // This matches the original logic where minTime bypasses time validation
204
+ this.isInvalid.set(!this.checkTimeValidity(this.chosenTime().trim()));
205
+ let chosenTimedayjs = this.getdayjs(this.chosenTime());
206
+ // Defer emission to avoid ExpressionChangedAfterItHasBeenCheckedError
207
+ setTimeout(() => {
208
+ this.emitTime({
209
+ valid: !this.isInvalid(),
210
+ time: this.chosenTime(),
211
+ epoch: chosenTimedayjs.valueOf()
212
+ });
213
+ }, 0);
214
+ // Calculate closest interval
215
+ this.calculateClosestInterval(this.chosenTime());
216
+ this._isInitializing = false;
129
217
  }
130
218
  }
131
219
  emitTime(data) {
@@ -133,13 +221,12 @@ export class TimePickerComponent {
133
221
  }
134
222
  // function to get dayjs object when time is given in string
135
223
  getdayjs(time = '00:00') {
136
- ;
137
224
  if (!time || typeof time !== 'string') {
138
225
  throw new Error('Time must be a string');
139
226
  }
140
227
  let hours;
141
228
  let minutes;
142
- if (this.clockFormat === 24) {
229
+ if (this.clockFormat() === 24) {
143
230
  hours = parseInt(time.split(':')[0]);
144
231
  minutes = parseInt(time.split(':')[1]);
145
232
  }
@@ -155,70 +242,88 @@ export class TimePickerComponent {
155
242
  hours = 0;
156
243
  }
157
244
  }
158
- return dayjs.tz(this.dateAsEpoch, this.timezone).add(hours, 'h').add(minutes, 'm');
245
+ // Use the date from dateAsEpoch but set the time to the parsed hours and minutes
246
+ const baseDate = dayjs.tz(this.dateAsEpoch(), this.timezone());
247
+ const result = baseDate.hour(hours).minute(minutes).second(0).millisecond(0);
248
+ return result;
159
249
  }
160
250
  closeDropdown() {
161
251
  this.dispayToolTip = false;
162
- this.userInputFlag = false;
163
- this.openStatus = false;
252
+ this.userInputFlag.set(false);
253
+ this.openStatus.set(false);
164
254
  if (this.timepickerDirective)
165
255
  this.timepickerDirective.destroyOverlay();
166
256
  }
167
257
  // toggle timepicker dropdown
168
258
  openDropdown() {
169
259
  this.dispayToolTip = true;
170
- this.openStatus = true;
260
+ this.openStatus.set(true);
171
261
  }
172
262
  checkTimeValidity(time) {
173
263
  const RE12 = /^(([0][1-9]|1[0-2]):([0-5][0-9])( )?(am|pm|AM|PM))$/i;
174
264
  const RE24 = /^([01][0-9]|2[0-3]):[0-5][0-9]$/;
175
- const RE = this.clockFormat === 12 ? RE12 : RE24;
265
+ const RE = this.clockFormat() === 12 ? RE12 : RE24;
266
+ // Check if the time format is valid first
267
+ if (!time.match(RE)) {
268
+ return false;
269
+ }
270
+ // Restore proper validation logic
176
271
  const timedayjs = this.getdayjs(time);
177
272
  let flag = false;
178
- // if the first interval is set to the start of the day
179
- // or a time is already provided to the component to show
180
- // then we don't check its validity against the current time
181
- if (this.minTime ||
182
- this.givenTime ||
183
- (this.firstInterval &&
184
- dayjs.tz(this.firstInterval, this.timezone).format(this.timeFormat).valueOf() === dayjs.tz(dayjs(), this.timezone).startOf("day").format(this.timeFormat).valueOf())) {
273
+ // Original logic: if minTime, givenTime, or firstInterval is start of day, only check format
274
+ if (this.minTime() ||
275
+ this.givenTime() ||
276
+ (this.firstInterval() &&
277
+ dayjs.tz(this.firstInterval(), this.timezone()).format(this.timeFormat).valueOf() === dayjs.tz(dayjs(), this.timezone()).startOf("day").format(this.timeFormat).valueOf())) {
278
+ // Only check format validation, not time comparison
185
279
  flag = time.match(RE) ? true : false;
186
280
  }
187
281
  else {
188
- flag = time.match(RE) && timedayjs.diff(dayjs.tz(dayjs(), this.timezone), "m") >= 0 ? true : false;
282
+ // Check against current time for normal cases
283
+ const currentTime = dayjs.tz(dayjs(), this.timezone());
284
+ const timeDiff = timedayjs.diff(currentTime, "m");
285
+ flag = timeDiff >= 0;
189
286
  }
190
287
  return flag;
191
288
  }
192
289
  // update chosen time as soon as the user clicks on an interval
193
290
  onTimeSelect(time) {
194
- this.isInvalid = !this.checkTimeValidity(time.trim());
195
- if (!this.isInvalid) {
196
- this.chosenTime = time;
197
- this.calculateClosestInterval(this.chosenTime);
291
+ this.isInvalid.set(!this.checkTimeValidity(time.trim()));
292
+ if (!this.isInvalid()) {
293
+ this.chosenTime.set(time);
294
+ this.calculateClosestInterval(this.chosenTime());
198
295
  }
199
296
  const timedayjs = this.getdayjs(time);
200
297
  this.emitTime({
201
- valid: !this.isInvalid,
298
+ valid: !this.isInvalid(),
202
299
  time: time,
203
300
  epoch: timedayjs.valueOf()
204
301
  });
205
- this.openStatus = false;
302
+ this.openStatus.set(false);
206
303
  if (this.timepickerDirective)
207
304
  this.timepickerDirective.destroyOverlay();
208
305
  }
209
306
  // checks validity of time on input change and calculates the closest interval
210
307
  onTimeChange(time) {
211
- this.isInvalid = !this.checkTimeValidity(time.trim());
212
- if (!this.isInvalid) {
213
- this.userInputFlag = true;
214
- this.openStatus = false;
308
+ // Set user input flag to prevent effects from overriding
309
+ this.userInputFlag.set(true);
310
+ // Update the chosenTime signal
311
+ this.chosenTime.set(time);
312
+ const isValid = this.checkTimeValidity(time.trim());
313
+ this.isInvalid.set(!isValid);
314
+ // Clear user input flag after a delay to allow effects to work again
315
+ setTimeout(() => {
316
+ this.userInputFlag.set(false);
317
+ }, 1000); // 1 second delay
318
+ if (!this.isInvalid()) {
319
+ this.openStatus.set(false);
215
320
  if (this.timepickerDirective)
216
321
  this.timepickerDirective.destroyOverlay();
217
322
  this.calculateClosestInterval(time);
218
323
  }
219
324
  const timedayjs = this.getdayjs(time);
220
325
  this.emitTime({
221
- valid: !this.isInvalid,
326
+ valid: !this.isInvalid(),
222
327
  time: time,
223
328
  epoch: timedayjs.valueOf()
224
329
  });
@@ -226,67 +331,79 @@ export class TimePickerComponent {
226
331
  calculateClosestInterval(time) {
227
332
  let roundedEpoch;
228
333
  // Converting time and date to a dayjs object
229
- const chosenDate = dayjs.tz(this.dateAsEpoch, this.timezone).format("DD-MM-YYYY"); // 05-01-2024
230
- const parsedTimeWithDate = dayjs.tz(`${chosenDate} ${time}`, `DD-MM-YYYY ${this.timeFormat}`, this.timezone);
334
+ const chosenDate = dayjs.tz(this.dateAsEpoch(), this.timezone()).format("DD-MM-YYYY"); // 05-01-2024
335
+ const parsedTimeWithDate = dayjs.tz(`${chosenDate} ${time}`, `DD-MM-YYYY ${this.timeFormat}`, this.timezone());
231
336
  // Converting dayjs object to epoch
232
337
  const chosenTimeEpoch = parsedTimeWithDate.valueOf();
233
- const offset = this.interval - (dayjs.tz(chosenTimeEpoch, this.timezone).minute() % this.interval);
234
- if (this.minTime && !this.givenTime) {
235
- this.isHighlighted = 0;
338
+ const offset = this.interval() - (dayjs.tz(chosenTimeEpoch, this.timezone()).minute() % this.interval());
339
+ if (this.minTime() && !this.givenTime()) {
340
+ this.isHighlighted.set(0);
236
341
  return;
237
342
  }
238
- roundedEpoch = offset >= this.interval / 2 ? (dayjs.tz(chosenTimeEpoch, this.timezone).subtract(this.interval - offset, "m")).valueOf() : (dayjs.tz(chosenTimeEpoch, this.timezone).add(offset, "m")).valueOf();
343
+ roundedEpoch = offset >= this.interval() / 2 ? (dayjs.tz(chosenTimeEpoch, this.timezone()).subtract(this.interval() - offset, "m")).valueOf() : (dayjs.tz(chosenTimeEpoch, this.timezone()).add(offset, "m")).valueOf();
239
344
  // finding the index of element that needs to be highlighted
240
- if (chosenTimeEpoch > dayjs.tz(this.dateAsEpoch, this.timezone).endOf("day").subtract(this.interval, "m").valueOf()) {
241
- this.isHighlighted = this.timeIntervals.length - 1;
345
+ if (chosenTimeEpoch > dayjs.tz(this.dateAsEpoch(), this.timezone()).endOf("day").subtract(this.interval(), "m").valueOf()) {
346
+ this.isHighlighted.set(this.timeIntervals().length - 1);
242
347
  }
243
348
  else {
244
- const roundedEpochdayjs = dayjs.tz(roundedEpoch, this.timezone);
245
- this.isHighlighted = this.timeIntervals.findIndex(interval => {
246
- const intervalObj = dayjs.tz(`${chosenDate} ${interval}`, `DD-MM-YYYY ${this.timeFormat}`, this.timezone);
349
+ const roundedEpochdayjs = dayjs.tz(roundedEpoch, this.timezone());
350
+ this.isHighlighted.set(this.timeIntervals().findIndex(interval => {
351
+ const intervalObj = dayjs.tz(`${chosenDate} ${interval}`, `DD-MM-YYYY ${this.timeFormat}`, this.timezone());
247
352
  return intervalObj.isSame(roundedEpochdayjs);
248
- });
353
+ }));
249
354
  }
250
355
  }
251
356
  // populates the dropdown according to the first interval received
252
357
  populateDropdown() {
253
- this.timeIntervals = [];
358
+ this.timeIntervals.set([]);
359
+ // Compute the effective first interval
360
+ let effectiveFirstInterval = this.firstInterval();
254
361
  // if picker is used as an individual component
255
- if (!this.firstInterval) {
362
+ if (!effectiveFirstInterval) {
256
363
  // firstInterval is initialised according to the current time
257
364
  // if the date is same as the current date
258
- if (dayjs.tz(this.dateAsEpoch, this.timezone).format("DD-MM-YYYY") === dayjs.tz(dayjs(), this.timezone).format("DD-MM-YYYY") && !this.minTime) {
259
- const offset = this.interval - (dayjs.tz(dayjs(), this.timezone).minute() % this.interval);
260
- this.firstInterval = dayjs.tz(dayjs(), this.timezone).add(offset, "m").valueOf();
365
+ if (dayjs.tz(this.dateAsEpoch(), this.timezone()).format("DD-MM-YYYY") === dayjs.tz(dayjs(), this.timezone()).format("DD-MM-YYYY") && !this.minTime()) {
366
+ const offset = this.interval() - (dayjs.tz(dayjs(), this.timezone()).minute() % this.interval());
367
+ effectiveFirstInterval = dayjs.tz(dayjs(), this.timezone()).add(offset, "m").valueOf();
261
368
  }
262
369
  // if minimum time to show is provided
263
- else if (this.minTime) {
264
- const offset = this.interval - (dayjs.tz(this.minTime, this.timezone).minute() % this.interval);
265
- this.firstInterval = dayjs.tz(this.minTime, this.timezone).add(offset, "m").valueOf();
370
+ else if (this.minTime()) {
371
+ const minTimeDayjs = dayjs.tz(this.minTime(), this.timezone());
372
+ const offset = this.interval() - (minTimeDayjs.minute() % this.interval());
373
+ effectiveFirstInterval = minTimeDayjs.add(offset, "m").valueOf();
266
374
  }
267
375
  // else the firstInterval is initialised as start of day
268
376
  else {
269
- this.firstInterval = dayjs.tz(dayjs(), this.timezone).startOf("day").valueOf();
377
+ effectiveFirstInterval = dayjs.tz(dayjs(), this.timezone()).startOf("day").valueOf();
270
378
  }
271
379
  }
272
- if (this.givenTime && this.givenTimeFlag) {
273
- this.firstInterval = dayjs.tz(this.givenTime, this.timezone).startOf('d').valueOf();
274
- this.givenTimeFlag = false;
380
+ if (this.givenTime()) {
381
+ // When givenTime is present, always start from 12:00 AM (start of day)
382
+ // regardless of whether the time has passed or not
383
+ effectiveFirstInterval = dayjs.tz(this.dateAsEpoch(), this.timezone()).startOf('day').valueOf();
384
+ this.givenTimeFlag.set(false);
275
385
  }
276
- const dateAsString = dayjs.tz(this.dateAsEpoch, this.timezone).format('DD-MM-YYYY');
277
- const intervalAsString = dayjs.tz(this.firstInterval, this.timezone).format(this.timeFormat);
278
- let start = dayjs.tz(`${dateAsString} ${intervalAsString}`, `DD-MM-YYYY ${this.timeFormat}`, this.timezone);
279
- const end = dayjs.tz(this.dateAsEpoch, this.timezone).endOf('d');
386
+ // Store the computed first interval for later use
387
+ this.computedFirstInterval = effectiveFirstInterval;
388
+ const dateAsString = dayjs.tz(this.dateAsEpoch(), this.timezone()).format('DD-MM-YYYY');
389
+ const intervalAsString = dayjs.tz(effectiveFirstInterval, this.timezone()).format(this.timeFormat);
390
+ let start = dayjs.tz(`${dateAsString} ${intervalAsString}`, `DD-MM-YYYY ${this.timeFormat}`, this.timezone());
391
+ const end = dayjs.tz(this.dateAsEpoch(), this.timezone()).endOf('d');
280
392
  while (start.valueOf() < end.valueOf()) {
281
- this.timeIntervals.push(start.format(this.timeFormat));
282
- start = start.add(this.interval, "m");
393
+ this.timeIntervals.update(intervals => [...intervals, start.format(this.timeFormat)]);
394
+ start = start.add(this.interval(), "m");
283
395
  }
284
- // if the start time is equal to the interval just before midnight
285
- // and the start date = end date
286
- // push 11:59pm only
287
- if (this.timeIntervals.length === 0) {
288
- this.chosenTime = dayjs.tz(dayjs(), this.timezone).endOf("d").format(this.timeFormat);
289
- this.timeIntervals.push(dayjs.tz(dayjs(), this.timezone).endOf("d").format(this.timeFormat));
396
+ // NEW: Handle end-of-day case - if firstInterval is at or very close to end of day
397
+ // and we're on the same date, show only 11:59 PM
398
+ const endOfDay = dayjs.tz(this.dateAsEpoch(), this.timezone()).endOf("d");
399
+ const firstIntervalDayjs = dayjs.tz(effectiveFirstInterval, this.timezone());
400
+ // Check if firstInterval is at or very close to end of day (within 1 minute)
401
+ const isAtEndOfDay = firstIntervalDayjs.isSame(endOfDay, 'day') &&
402
+ firstIntervalDayjs.diff(endOfDay, 'minute') >= -1;
403
+ if (isAtEndOfDay || this.timeIntervals().length === 0) {
404
+ // Clear existing intervals and add only 11:59 PM
405
+ this.timeIntervals.set([]);
406
+ this.timeIntervals.update(intervals => [...intervals, endOfDay.format(this.timeFormat)]);
290
407
  }
291
408
  }
292
409
  ngOnDestroy() {
@@ -305,59 +422,27 @@ export class TimePickerComponent {
305
422
  i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.timepickerDirective = _t.first);
306
423
  i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.tooltipDirective = _t.first);
307
424
  i0.ɵɵqueryRefresh(_t = i0.ɵɵloadQuery()) && (ctx.timeIntervalRefs = _t);
308
- } }, inputs: { clockFormat: "clockFormat", timezone: "timezone", height: "height", inputWidth: "inputWidth", dropdownWidth: "dropdownWidth", interval: "interval", dateAsEpoch: "dateAsEpoch", firstInterval: "firstInterval", rangeValidity: "rangeValidity", showTooltip: "showTooltip", givenTime: "givenTime", minTime: "minTime", triggerChange: "triggerChange", disable: "disable" }, outputs: { timeEmitter: "timeEmitter" }, features: [i0.ɵɵNgOnChangesFeature], decls: 5, vars: 19, consts: [["input", ""], ["dropdownContainer", ""], ["dropdown", ""], ["timeInterval", ""], [1, "timepicker-container", 3, "ngStyle", "ngClass"], ["type", "text", "misToolTip", "", "cdkOverlayOrigin", "", 1, "h7", 3, "ngModelChange", "click", "ngModel", "ngClass", "ngStyle", "showToolTip", "text", "position", "showOnHover"], ["libDropdownScroll", "", "libTimepicker", "", 3, "statusEmitter", "originEl", "openStatus"], ["class", "timepicker-dropdown", 3, "ngStyle", 4, "ngIf"], [1, "timepicker-dropdown", 3, "ngStyle"], [3, "ngClass", "click", 4, "ngFor", "ngForOf"], [3, "click", "ngClass"], ["class", "ic-ui-check-24 selected-icon", 4, "ngIf"], [1, "ic-ui-check-24", "selected-icon"]], template: function TimePickerComponent_Template(rf, ctx) { if (rf & 1) {
425
+ } }, inputs: { clockFormat: [1, "clockFormat"], timezone: [1, "timezone"], height: [1, "height"], inputWidth: [1, "inputWidth"], dropdownWidth: [1, "dropdownWidth"], interval: [1, "interval"], dateAsEpoch: [1, "dateAsEpoch"], firstInterval: [1, "firstInterval"], rangeValidity: [1, "rangeValidity"], showTooltip: [1, "showTooltip"], givenTime: [1, "givenTime"], minTime: [1, "minTime"], triggerChange: [1, "triggerChange"], disable: [1, "disable"] }, outputs: { timeEmitter: "timeEmitter" }, decls: 5, vars: 19, consts: [["input", ""], ["dropdownContainer", ""], ["dropdown", ""], ["timeInterval", ""], [1, "timepicker-container", 3, "ngStyle", "ngClass"], ["type", "text", "misToolTip", "", "cdkOverlayOrigin", "", 1, "h7", 3, "ngModelChange", "click", "ngModel", "ngClass", "ngStyle", "showToolTip", "text", "position", "showOnHover"], ["libTimepicker", "", 3, "statusEmitter", "originEl", "openStatus"], ["class", "timepicker-dropdown", 3, "ngStyle", 4, "ngIf"], [1, "timepicker-dropdown", 3, "ngStyle"], [3, "ngClass", "click", 4, "ngFor", "ngForOf"], [3, "click", "ngClass"], ["class", "ic-ui-check-24 selected-icon", 4, "ngIf"], [1, "ic-ui-check-24", "selected-icon"]], template: function TimePickerComponent_Template(rf, ctx) { if (rf & 1) {
309
426
  const _r1 = i0.ɵɵgetCurrentView();
310
427
  i0.ɵɵelementStart(0, "div", 4)(1, "input", 5, 0);
311
- i0.ɵɵtwoWayListener("ngModelChange", function TimePickerComponent_Template_input_ngModelChange_1_listener($event) { i0.ɵɵrestoreView(_r1); i0.ɵɵtwoWayBindingSet(ctx.chosenTime, $event) || (ctx.chosenTime = $event); return i0.ɵɵresetView($event); });
312
- i0.ɵɵlistener("ngModelChange", function TimePickerComponent_Template_input_ngModelChange_1_listener() { i0.ɵɵrestoreView(_r1); return i0.ɵɵresetView(ctx.onTimeChange(ctx.chosenTime)); })("click", function TimePickerComponent_Template_input_click_1_listener() { i0.ɵɵrestoreView(_r1); return i0.ɵɵresetView(ctx.openDropdown()); });
428
+ i0.ɵɵlistener("ngModelChange", function TimePickerComponent_Template_input_ngModelChange_1_listener($event) { i0.ɵɵrestoreView(_r1); return i0.ɵɵresetView(ctx.onTimeChange($event)); })("click", function TimePickerComponent_Template_input_click_1_listener() { i0.ɵɵrestoreView(_r1); return i0.ɵɵresetView(ctx.openDropdown()); });
313
429
  i0.ɵɵelementEnd();
314
430
  i0.ɵɵtemplate(3, TimePickerComponent_ng_template_3_Template, 1, 1, "ng-template", 6, 1, i0.ɵɵtemplateRefExtractor);
315
431
  i0.ɵɵlistener("statusEmitter", function TimePickerComponent_Template_ng_template_statusEmitter_3_listener() { i0.ɵɵrestoreView(_r1); return i0.ɵɵresetView(ctx.closeDropdown()); });
316
432
  i0.ɵɵelementEnd();
317
433
  } if (rf & 2) {
318
434
  const input_r6 = i0.ɵɵreference(2);
319
- i0.ɵɵproperty("ngStyle", i0.ɵɵpureFunction1(11, _c2, ctx.height))("ngClass", i0.ɵɵpureFunction1(13, _c3, ctx.disable));
435
+ i0.ɵɵproperty("ngStyle", i0.ɵɵpureFunction1(11, _c2, ctx.height()))("ngClass", i0.ɵɵpureFunction1(13, _c3, ctx.disable()));
320
436
  i0.ɵɵadvance();
321
- i0.ɵɵtwoWayProperty("ngModel", ctx.chosenTime);
322
- i0.ɵɵproperty("ngClass", i0.ɵɵpureFunction1(15, _c4, ctx.isInvalid || !ctx.rangeValidity))("ngStyle", i0.ɵɵpureFunction1(17, _c5, ctx.inputWidth))("showToolTip", ctx.showTooltip && (ctx.isInvalid || !ctx.rangeValidity) && ctx.dispayToolTip)("text", "Invalid Time")("position", "top")("showOnHover", false);
437
+ i0.ɵɵproperty("ngModel", ctx.chosenTime())("ngClass", i0.ɵɵpureFunction1(15, _c4, ctx.isInvalid() || !ctx.rangeValidity()))("ngStyle", i0.ɵɵpureFunction1(17, _c5, ctx.inputWidth()))("showToolTip", ctx.showTooltip() && (ctx.isInvalid() || !ctx.rangeValidity()) && ctx.dispayToolTip)("text", "Invalid Time")("position", "top")("showOnHover", false);
323
438
  i0.ɵɵadvance(2);
324
- i0.ɵɵproperty("originEl", input_r6)("openStatus", ctx.openStatus);
439
+ i0.ɵɵproperty("originEl", input_r6)("openStatus", ctx.openStatus());
325
440
  } }, dependencies: [i1.NgClass, i1.NgForOf, i1.NgIf, i1.NgStyle, i2.DefaultValueAccessor, i2.NgControlStatus, i2.NgModel, i3.ToolTipDirective, i4.CdkOverlayOrigin, i5.TimepickerDirective], styles: [".h1[_ngcontent-%COMP%]{font-size:40px;font-weight:400;letter-spacing:0px;line-height:48px}.h2[_ngcontent-%COMP%]{font-size:32px;font-weight:400;letter-spacing:0px;line-height:40px}.h3[_ngcontent-%COMP%]{font-size:28px;font-weight:400;letter-spacing:0px;line-height:36px}.h4[_ngcontent-%COMP%]{font-size:24px;font-weight:400;letter-spacing:0px;line-height:32px}.h5-b[_ngcontent-%COMP%]{font-size:20px;font-weight:700;letter-spacing:.25px;line-height:28px}.h5[_ngcontent-%COMP%]{font-size:20px;font-weight:400;letter-spacing:.15px;line-height:28px}.h6-b[_ngcontent-%COMP%]{font-size:16px;font-weight:700;letter-spacing:0px;line-height:24px}.h6[_ngcontent-%COMP%]{font-size:16px;font-weight:400;letter-spacing:0px;line-height:24px}.p[_ngcontent-%COMP%]{font-size:16px;font-weight:400;letter-spacing:0px;line-height:180%}.h7-b[_ngcontent-%COMP%]{font-size:14px;font-weight:700;letter-spacing:.25px;line-height:20px}.h7[_ngcontent-%COMP%]{font-size:14px;font-weight:400;letter-spacing:.2px;line-height:20px}.h8-b[_ngcontent-%COMP%]{font-size:12px;font-weight:700;letter-spacing:.25px;line-height:18px}.h8[_ngcontent-%COMP%]{font-size:12px;font-weight:400;letter-spacing:.2px;line-height:18px}.h9[_ngcontent-%COMP%]{font-size:10px;font-weight:400;letter-spacing:0px;line-height:15px}.btn-lg-b[_ngcontent-%COMP%]{font-size:16px;font-weight:700;letter-spacing:.5px;line-height:24px}.btn-lg[_ngcontent-%COMP%]{font-size:16px;font-weight:400;letter-spacing:.2px;line-height:24px}.btn-sm[_ngcontent-%COMP%]{font-size:14px;font-weight:400;letter-spacing:.25px;line-height:20px}.btn-link[_ngcontent-%COMP%]{font-size:16px;font-weight:400;letter-spacing:0px;line-height:24px}.display-1[_ngcontent-%COMP%]{font-size:48px;font-weight:400;letter-spacing:0px;line-height:56px}.display-2[_ngcontent-%COMP%]{font-size:14px;font-weight:400;letter-spacing:.5px;line-height:20px}*[_ngcontent-%COMP%]{box-sizing:border-box;font-family:Lato}.timepicker-container[_ngcontent-%COMP%]{display:inline-block;position:relative}input[_ngcontent-%COMP%]{text-align:center;border:none;border-bottom:1px solid #e0e0e0;outline:none;height:100%;width:100px;padding:4px 16px}input[_ngcontent-%COMP%]:hover{background:#f5f7fc}input[_ngcontent-%COMP%]:focus, input[_ngcontent-%COMP%]:active{background:#e6ebf7;border-bottom:1px solid #0937b2}.timepicker-dropdown[_ngcontent-%COMP%]{position:absolute;top:calc(100% + 4px);left:0;max-height:200px;overflow-y:auto;border:1px solid #e0e0e0;box-shadow:0 12px 24px #0000001f,0 4px 8px #0000001f;border-radius:4px;padding:8px;background:#fff}.timepicker-dropdown[_ngcontent-%COMP%]::-webkit-scrollbar{display:none}.timepicker-dropdown[_ngcontent-%COMP%] ul[_ngcontent-%COMP%]{margin:0;padding:0}.timepicker-dropdown[_ngcontent-%COMP%] li[_ngcontent-%COMP%]{text-align:start;list-style:none;padding:6px 12px;cursor:pointer;font-size:14px;color:#181f33;display:flex;justify-content:space-between;align-items:center}.timepicker-dropdown[_ngcontent-%COMP%] li[_ngcontent-%COMP%]:hover{background:#f5f7fc;border-radius:6px}.timepicker-dropdown[_ngcontent-%COMP%] li[_ngcontent-%COMP%] .selected-icon[_ngcontent-%COMP%]{font-weight:900}.highlight[_ngcontent-%COMP%]{background-color:#f5f7fc;border-radius:6px}.invalid[_ngcontent-%COMP%]{background:#fae1ea!important;border-bottom:1px solid #b00020!important}.disable[_ngcontent-%COMP%]{pointer-events:none!important;opacity:.5!important}"] }); }
326
441
  }
327
442
  (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(TimePickerComponent, [{
328
443
  type: Component,
329
- args: [{ selector: "mis-timepicker", template: "<div class=\"timepicker-container\" [ngStyle]=\"{ height: height }\" [ngClass]=\"{'disable': disable}\">\n <input\n type=\"text\"\n [(ngModel)]=\"chosenTime\"\n (ngModelChange)=\"onTimeChange(chosenTime)\"\n [ngClass]=\"{ invalid: isInvalid || !rangeValidity }\"\n [ngStyle]=\"{ width: inputWidth }\"\n (click)=\"openDropdown()\"\n misToolTip\n [showToolTip]=\"showTooltip && (isInvalid || !rangeValidity) && dispayToolTip\"\n [text]=\"'Invalid Time'\"\n [position]=\"'top'\"\n [showOnHover]=\"false\"\n #input\n cdkOverlayOrigin\n class=\"h7\"\n />\n\n <ng-template #dropdownContainer libDropdownScroll libTimepicker [originEl]=\"input\" [openStatus]=\"openStatus\" (statusEmitter)=\"closeDropdown()\">\n <div *ngIf=\"openStatus\" class=\"timepicker-dropdown\" [ngStyle]=\"{ width: dropdownWidth || inputWidth }\">\n <ul #dropdown>\n <li #timeInterval (click)=\"onTimeSelect(interval)\" *ngFor=\"let interval of timeIntervals; index as i\" [ngClass]=\"{ highlight: i === isHighlighted }\">\n {{ interval }}\n <div class=\"ic-ui-check-24 selected-icon\" *ngIf=\"interval === chosenTime\"></div>\n </li>\n </ul>\n </div>\n </ng-template>\n</div>\n", styles: [".h1{font-size:40px;font-weight:400;letter-spacing:0px;line-height:48px}.h2{font-size:32px;font-weight:400;letter-spacing:0px;line-height:40px}.h3{font-size:28px;font-weight:400;letter-spacing:0px;line-height:36px}.h4{font-size:24px;font-weight:400;letter-spacing:0px;line-height:32px}.h5-b{font-size:20px;font-weight:700;letter-spacing:.25px;line-height:28px}.h5{font-size:20px;font-weight:400;letter-spacing:.15px;line-height:28px}.h6-b{font-size:16px;font-weight:700;letter-spacing:0px;line-height:24px}.h6{font-size:16px;font-weight:400;letter-spacing:0px;line-height:24px}.p{font-size:16px;font-weight:400;letter-spacing:0px;line-height:180%}.h7-b{font-size:14px;font-weight:700;letter-spacing:.25px;line-height:20px}.h7{font-size:14px;font-weight:400;letter-spacing:.2px;line-height:20px}.h8-b{font-size:12px;font-weight:700;letter-spacing:.25px;line-height:18px}.h8{font-size:12px;font-weight:400;letter-spacing:.2px;line-height:18px}.h9{font-size:10px;font-weight:400;letter-spacing:0px;line-height:15px}.btn-lg-b{font-size:16px;font-weight:700;letter-spacing:.5px;line-height:24px}.btn-lg{font-size:16px;font-weight:400;letter-spacing:.2px;line-height:24px}.btn-sm{font-size:14px;font-weight:400;letter-spacing:.25px;line-height:20px}.btn-link{font-size:16px;font-weight:400;letter-spacing:0px;line-height:24px}.display-1{font-size:48px;font-weight:400;letter-spacing:0px;line-height:56px}.display-2{font-size:14px;font-weight:400;letter-spacing:.5px;line-height:20px}*{box-sizing:border-box;font-family:Lato}.timepicker-container{display:inline-block;position:relative}input{text-align:center;border:none;border-bottom:1px solid #e0e0e0;outline:none;height:100%;width:100px;padding:4px 16px}input:hover{background:#f5f7fc}input:focus,input:active{background:#e6ebf7;border-bottom:1px solid #0937b2}.timepicker-dropdown{position:absolute;top:calc(100% + 4px);left:0;max-height:200px;overflow-y:auto;border:1px solid #e0e0e0;box-shadow:0 12px 24px #0000001f,0 4px 8px #0000001f;border-radius:4px;padding:8px;background:#fff}.timepicker-dropdown::-webkit-scrollbar{display:none}.timepicker-dropdown ul{margin:0;padding:0}.timepicker-dropdown li{text-align:start;list-style:none;padding:6px 12px;cursor:pointer;font-size:14px;color:#181f33;display:flex;justify-content:space-between;align-items:center}.timepicker-dropdown li:hover{background:#f5f7fc;border-radius:6px}.timepicker-dropdown li .selected-icon{font-weight:900}.highlight{background-color:#f5f7fc;border-radius:6px}.invalid{background:#fae1ea!important;border-bottom:1px solid #b00020!important}.disable{pointer-events:none!important;opacity:.5!important}\n"] }]
330
- }], () => [], { clockFormat: [{
331
- type: Input
332
- }], timezone: [{
333
- type: Input
334
- }], height: [{
335
- type: Input
336
- }], inputWidth: [{
337
- type: Input
338
- }], dropdownWidth: [{
339
- type: Input
340
- }], interval: [{
341
- type: Input
342
- }], dateAsEpoch: [{
343
- type: Input
344
- }], firstInterval: [{
345
- type: Input
346
- }], rangeValidity: [{
347
- type: Input
348
- }], showTooltip: [{
349
- type: Input
350
- }], givenTime: [{
351
- type: Input
352
- }], minTime: [{
353
- type: Input
354
- }], triggerChange: [{
355
- type: Input
356
- }], disable: [{
357
- type: Input
358
- }], timeEmitter: [{
359
- type: Output
360
- }], input: [{
444
+ args: [{ selector: "mis-timepicker", template: "<div class=\"timepicker-container\" [ngStyle]=\"{ height: height() }\" [ngClass]=\"{'disable': disable()}\">\n <input\n type=\"text\"\n [ngModel]=\"chosenTime()\"\n (ngModelChange)=\"onTimeChange($event)\"\n [ngClass]=\"{ invalid: isInvalid() || !rangeValidity() }\"\n [ngStyle]=\"{ width: inputWidth() }\"\n (click)=\"openDropdown()\"\n misToolTip\n [showToolTip]=\"showTooltip() && (isInvalid() || !rangeValidity()) && dispayToolTip\"\n [text]=\"'Invalid Time'\"\n [position]=\"'top'\"\n [showOnHover]=\"false\"\n #input\n cdkOverlayOrigin\n class=\"h7\"\n />\n\n <ng-template #dropdownContainer libTimepicker [originEl]=\"input\" [openStatus]=\"openStatus()\" (statusEmitter)=\"closeDropdown()\">\n <div *ngIf=\"openStatus()\" class=\"timepicker-dropdown\" [ngStyle]=\"{ width: dropdownWidth() || inputWidth() }\">\n <ul #dropdown>\n <li #timeInterval (click)=\"onTimeSelect(interval)\" *ngFor=\"let interval of timeIntervals(); index as i\" [ngClass]=\"{ highlight: i === isHighlighted() }\">\n {{ interval }}\n <div class=\"ic-ui-check-24 selected-icon\" *ngIf=\"interval === chosenTime()\"></div>\n </li>\n </ul>\n </div>\n </ng-template>\n</div>\n", styles: [".h1{font-size:40px;font-weight:400;letter-spacing:0px;line-height:48px}.h2{font-size:32px;font-weight:400;letter-spacing:0px;line-height:40px}.h3{font-size:28px;font-weight:400;letter-spacing:0px;line-height:36px}.h4{font-size:24px;font-weight:400;letter-spacing:0px;line-height:32px}.h5-b{font-size:20px;font-weight:700;letter-spacing:.25px;line-height:28px}.h5{font-size:20px;font-weight:400;letter-spacing:.15px;line-height:28px}.h6-b{font-size:16px;font-weight:700;letter-spacing:0px;line-height:24px}.h6{font-size:16px;font-weight:400;letter-spacing:0px;line-height:24px}.p{font-size:16px;font-weight:400;letter-spacing:0px;line-height:180%}.h7-b{font-size:14px;font-weight:700;letter-spacing:.25px;line-height:20px}.h7{font-size:14px;font-weight:400;letter-spacing:.2px;line-height:20px}.h8-b{font-size:12px;font-weight:700;letter-spacing:.25px;line-height:18px}.h8{font-size:12px;font-weight:400;letter-spacing:.2px;line-height:18px}.h9{font-size:10px;font-weight:400;letter-spacing:0px;line-height:15px}.btn-lg-b{font-size:16px;font-weight:700;letter-spacing:.5px;line-height:24px}.btn-lg{font-size:16px;font-weight:400;letter-spacing:.2px;line-height:24px}.btn-sm{font-size:14px;font-weight:400;letter-spacing:.25px;line-height:20px}.btn-link{font-size:16px;font-weight:400;letter-spacing:0px;line-height:24px}.display-1{font-size:48px;font-weight:400;letter-spacing:0px;line-height:56px}.display-2{font-size:14px;font-weight:400;letter-spacing:.5px;line-height:20px}*{box-sizing:border-box;font-family:Lato}.timepicker-container{display:inline-block;position:relative}input{text-align:center;border:none;border-bottom:1px solid #e0e0e0;outline:none;height:100%;width:100px;padding:4px 16px}input:hover{background:#f5f7fc}input:focus,input:active{background:#e6ebf7;border-bottom:1px solid #0937b2}.timepicker-dropdown{position:absolute;top:calc(100% + 4px);left:0;max-height:200px;overflow-y:auto;border:1px solid #e0e0e0;box-shadow:0 12px 24px #0000001f,0 4px 8px #0000001f;border-radius:4px;padding:8px;background:#fff}.timepicker-dropdown::-webkit-scrollbar{display:none}.timepicker-dropdown ul{margin:0;padding:0}.timepicker-dropdown li{text-align:start;list-style:none;padding:6px 12px;cursor:pointer;font-size:14px;color:#181f33;display:flex;justify-content:space-between;align-items:center}.timepicker-dropdown li:hover{background:#f5f7fc;border-radius:6px}.timepicker-dropdown li .selected-icon{font-weight:900}.highlight{background-color:#f5f7fc;border-radius:6px}.invalid{background:#fae1ea!important;border-bottom:1px solid #b00020!important}.disable{pointer-events:none!important;opacity:.5!important}\n"] }]
445
+ }], () => [], { input: [{
361
446
  type: ViewChild,
362
447
  args: ["input", { static: true }]
363
448
  }], timepickerDirective: [{
@@ -371,4 +456,4 @@ export class TimePickerComponent {
371
456
  args: ["timeInterval"]
372
457
  }] }); })();
373
458
  (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(TimePickerComponent, { className: "TimePickerComponent" }); })();
374
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"timepicker.component.js","sourceRoot":"","sources":["../../../../projects/mis-components/timepicker/timepicker.component.ts","../../../../projects/mis-components/timepicker/timepicker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, EventEmitter, Input, OnChanges, OnDestroy, OnInit, Output, ViewChild, ViewChildren } from \"@angular/core\";\nimport { ITime } from \"./time.namespace\";\nimport { TimepickerDirective } from \"./timepicker.directive\";\nimport { ToolTipDirective } from \"mis-crystal-design-system/tooltip\";\n\nimport dayjs from 'dayjs';\nimport timezone from 'dayjs/plugin/timezone';\nimport utc from 'dayjs/plugin/utc';\nimport customParseFormat from 'dayjs/plugin/customParseFormat'\n\ndayjs.extend(utc);\ndayjs.extend(timezone);\ndayjs.extend(customParseFormat);\n\n\n@Component({\n  selector: \"mis-timepicker\",\n  templateUrl: \"./timepicker.component.html\",\n  styleUrls: [\"./timepicker.component.scss\"]\n})\nexport class TimePickerComponent implements OnInit, OnChanges, OnDestroy {\n  currTime!: string;\n  chosenTime: string;\n  openStatus: boolean = false;\n  isHighlighted: number = 0;\n  isInvalid: boolean = false;\n  timeIntervals: string[] = [];\n  shouldScroll: boolean = false;\n  userInputFlag: boolean = false;\n  givenTimeFlag: boolean = true;\n  @Input() clockFormat: number = 12;\n  timeFormat!: string;\n  \n  @Input() timezone: string = \"Asia/Kolkata\";\n  @Input() height: string = \"max-content\";\n  @Input() inputWidth: string = \"100px\";\n  @Input() dropdownWidth?: string;\n  @Input() interval: number = 15;\n  @Input() dateAsEpoch: number = dayjs.tz(dayjs(), this.timezone).valueOf();\n  @Input() firstInterval!: number;\n  @Input() rangeValidity: boolean = true;\n  @Input() showTooltip: boolean = true;\n  dispayToolTip: boolean = this.showTooltip;\n  @Input() givenTime: number;\n  @Input() minTime?: number;\n  @Input() triggerChange: boolean = true;\n  @Input() disable: boolean = false;\n  @Output() timeEmitter = new EventEmitter<ITime>();\n  @ViewChild(\"input\", { static: true }) input: ElementRef;\n  @ViewChild(TimepickerDirective) timepickerDirective: TimepickerDirective;\n  @ViewChild(ToolTipDirective) tooltipDirective: ToolTipDirective;\n\n  // gets all the li elements from the dropdown and scrolls to the highlighted element\n  @ViewChildren(\"timeInterval\") set timeIntervalRefs(intervals) {\n    intervals.forEach(interval => {\n      if (interval.nativeElement.classList[0] === \"highlight\") {\n        const highlighted = interval.nativeElement;\n        setTimeout(() => highlighted.scrollIntoView({ block: \"center\" }));\n      }\n    });\n  }\n\n  constructor(){}\n  ngOnInit(): void {\n    if(!this.givenTime && !this.minTime) {\n      this.chosenTime = dayjs.tz(this.firstInterval, this.timezone).format(this.timeFormat);\n      let chosenTimedayjs = this.getdayjs(this.chosenTime);\n      this.emitTime({\n        valid: !this.isInvalid,\n        time: this.chosenTime,\n        epoch: chosenTimedayjs.valueOf()\n      });\n    }\n  }\n\n  ngOnChanges(): void {\n    this.timeFormat = this.clockFormat === 12 ? \"hh:mm a\" : \"HH:mm\";\n\n    if (this.timeFormat) {\n      let chosenTimedayjs = this.getdayjs(this.chosenTime);\n    \n      // if the first interval is >= the chosen time\n      // then only update the value of chosen time\n      // else it remains the same\n      if (this.firstInterval >= chosenTimedayjs.valueOf() && this.rangeValidity && !this.userInputFlag) {\n        this.chosenTime = dayjs.tz(this.firstInterval, this.timezone).format(this.timeFormat);\n        chosenTimedayjs = this.getdayjs(this.chosenTime)\n      }\n\n      if((this.givenTimeFlag && this.givenTime) || this.minTime ) {\n        this.chosenTime = dayjs.tz(this.minTime || this.givenTime, this.timezone).format(this.timeFormat);\n      }\n      chosenTimedayjs = this.getdayjs(this.chosenTime)\n\n      if (!this.userInputFlag) this.populateDropdown();\n      this.userInputFlag = false;\n      \n      if(this.chosenTime) {\n        this.isInvalid = !this.checkTimeValidity(this.chosenTime.trim());\n        this.emitTime({\n          valid: !this.isInvalid,\n          time: this.chosenTime,\n          epoch: chosenTimedayjs.valueOf()\n        });\n        this.calculateClosestInterval(this.chosenTime);\n      }\n    }\n  }\n\n  emitTime(data: ITime): void {\n    this.timeEmitter.emit(data);\n  }\n\n  // function to get dayjs object when time is given in string\n  getdayjs(time: string = '00:00'){;\n    if(!time || typeof time !== 'string') {\n      throw new Error('Time must be a string');\n    }\n\n    let hours: number;\n    let minutes: number;\n\n    if(this.clockFormat === 24) {\n      hours = parseInt(time.split(':')[0]);\n      minutes = parseInt(time.split(':')[1]);\n    } else {\n      const timeParts = time.split(' ');\n      const AM_PM = timeParts?.[1];\n      hours =  parseInt(timeParts?.[0]?.split(':')?.[0]);\n      minutes = parseInt(timeParts?.[0]?.split(':')?.[1]);\n\n      if(AM_PM?.toUpperCase() === 'PM' && hours !== 12) {\n        hours += 12;\n      } else if(AM_PM?.toUpperCase() === 'AM' && hours === 12) {\n        hours = 0;\n      }\n    }\n\n    return dayjs.tz(this.dateAsEpoch, this.timezone).add(hours, 'h').add(minutes, 'm');\n  }\n\n  closeDropdown() {\n    this.dispayToolTip = false;\n    this.userInputFlag = false;\n    this.openStatus = false;\n    if (this.timepickerDirective) this.timepickerDirective.destroyOverlay();\n  }\n\n  // toggle timepicker dropdown\n  openDropdown(): void {\n    this.dispayToolTip = true;\n    this.openStatus = true;\n  }\n\n  checkTimeValidity(time: string): boolean {\n    const RE12 = /^(([0][1-9]|1[0-2]):([0-5][0-9])( )?(am|pm|AM|PM))$/i;\n    const RE24 = /^([01][0-9]|2[0-3]):[0-5][0-9]$/;\n    const RE = this.clockFormat === 12 ? RE12 : RE24;\n\n    const timedayjs = this.getdayjs(time);\n    let flag: boolean = false;\n\n    // if the first interval is set to the start of the day\n    // or a time is already provided to the component to show\n    // then we don't check its validity against the current time\n    if (\n      this.minTime || \n      this.givenTime ||\n      (this.firstInterval &&\n      dayjs.tz(this.firstInterval, this.timezone).format(this.timeFormat).valueOf() === dayjs.tz(dayjs(), this.timezone).startOf(\"day\").format(this.timeFormat).valueOf())\n    ) {\n      flag = time.match(RE) ? true : false;\n    } else {\n      flag = time.match(RE) && timedayjs.diff(dayjs.tz(dayjs(), this.timezone), \"m\") >= 0 ? true: false;\n    }\n\n    return flag;\n  }\n\n  // update chosen time as soon as the user clicks on an interval\n  onTimeSelect(time: string): void {\n    this.isInvalid = !this.checkTimeValidity(time.trim());\n    if (!this.isInvalid) {\n      this.chosenTime = time;\n      this.calculateClosestInterval(this.chosenTime);\n    }\n\n    const timedayjs = this.getdayjs(time);\n    this.emitTime({\n      valid: !this.isInvalid,\n      time: time,\n      epoch: timedayjs.valueOf() \n    });\n    this.openStatus = false;\n    if (this.timepickerDirective) this.timepickerDirective.destroyOverlay();\n  }\n\n  // checks validity of time on input change and calculates the closest interval\n  onTimeChange(time: string): void {\n    this.isInvalid = !this.checkTimeValidity(time.trim());\n\n    if (!this.isInvalid) {\n      this.userInputFlag = true;\n      this.openStatus = false;\n      if (this.timepickerDirective) this.timepickerDirective.destroyOverlay();\n      this.calculateClosestInterval(time);\n    }\n    const timedayjs = this.getdayjs(time);\n    this.emitTime({\n      valid: !this.isInvalid,\n      time: time,\n      epoch: timedayjs.valueOf() \n    });\n  }\n\n  calculateClosestInterval(time: string): void {\n    let roundedEpoch: number;\n    // Converting time and date to a dayjs object \n    const chosenDate = dayjs.tz(this.dateAsEpoch, this.timezone).format(\"DD-MM-YYYY\"); // 05-01-2024\n    const parsedTimeWithDate = dayjs.tz(`${chosenDate} ${time}`, `DD-MM-YYYY ${this.timeFormat}`, this.timezone);\n    // Converting dayjs object to epoch\n    const chosenTimeEpoch = parsedTimeWithDate.valueOf();\n    const offset = this.interval - (dayjs.tz(chosenTimeEpoch, this.timezone).minute() % this.interval);\n\n    if (this.minTime && !this.givenTime) {\n      this.isHighlighted = 0;\n      return;\n    }\n    roundedEpoch = offset >= this.interval / 2 ? (dayjs.tz(chosenTimeEpoch, this.timezone).subtract(this.interval - offset, \"m\")).valueOf() : (dayjs.tz(chosenTimeEpoch, this.timezone).add( offset, \"m\")).valueOf();\n\n    // finding the index of element that needs to be highlighted\n    if ( chosenTimeEpoch > dayjs.tz(this.dateAsEpoch, this.timezone).endOf(\"day\").subtract(this.interval, \"m\").valueOf()) {\n      this.isHighlighted = this.timeIntervals.length - 1;\n    } else {\n      const roundedEpochdayjs = dayjs.tz(roundedEpoch, this.timezone);\n      this.isHighlighted = this.timeIntervals.findIndex(interval => {\n        const intervalObj = dayjs.tz(`${chosenDate} ${interval}`, `DD-MM-YYYY ${this.timeFormat}`, this.timezone);\n        return intervalObj.isSame(roundedEpochdayjs);\n      });\n    }\n  }\n\n\n  // populates the dropdown according to the first interval received\n  populateDropdown(): void {\n    this.timeIntervals = [];\n\n    // if picker is used as an individual component\n    if (!this.firstInterval) {\n      // firstInterval is initialised according to the current time\n      // if the date is same as the current date\n      if (dayjs.tz(this.dateAsEpoch, this.timezone).format(\"DD-MM-YYYY\") === dayjs.tz(dayjs(), this.timezone).format(\"DD-MM-YYYY\") && !this.minTime) {\n        const offset = this.interval - (dayjs.tz(dayjs(), this.timezone).minute() % this.interval);\n        this.firstInterval = dayjs.tz(dayjs(), this.timezone).add(offset, \"m\").valueOf();\n      }\n      // if minimum time to show is provided\n      else if(this.minTime){\n        const offset = this.interval - (dayjs.tz(this.minTime, this.timezone).minute() % this.interval);\n        this.firstInterval = dayjs.tz(this.minTime, this.timezone).add(offset, \"m\").valueOf();\n      }\n      // else the firstInterval is initialised as start of day\n      else {\n        this.firstInterval = dayjs.tz(dayjs(), this.timezone).startOf(\"day\").valueOf();\n      }\n    }\n\n    if(this.givenTime && this.givenTimeFlag){\n      this.firstInterval = dayjs.tz(this.givenTime, this.timezone).startOf('d').valueOf();\n      this.givenTimeFlag = false;\n    }\n\n    const dateAsString = dayjs.tz(this.dateAsEpoch, this.timezone).format('DD-MM-YYYY');\n    const intervalAsString = dayjs.tz(this.firstInterval, this.timezone).format(this.timeFormat);\n    let start = dayjs.tz(`${dateAsString} ${intervalAsString}`, `DD-MM-YYYY ${this.timeFormat}`, this.timezone);\n    const end = dayjs.tz(this.dateAsEpoch, this.timezone).endOf('d');\n    while (start.valueOf() < end.valueOf()) {\n      this.timeIntervals.push(start.format(this.timeFormat));\n      start = start.add(this.interval, \"m\");\n    }\n\n    // if the start time is equal to the interval just before midnight\n    // and the start date = end date\n    // push 11:59pm only\n    if (this.timeIntervals.length === 0) {\n      this.chosenTime = dayjs.tz(dayjs(), this.timezone).endOf(\"d\").format(this.timeFormat);\n      this.timeIntervals.push(dayjs.tz(dayjs(), this.timezone).endOf(\"d\").format(this.timeFormat));\n    }\n  }\n\n  ngOnDestroy() {\n    if (this.tooltipDirective) this.tooltipDirective.hideToolTip();\n  }\n}\n\n","<div class=\"timepicker-container\" [ngStyle]=\"{ height: height }\" [ngClass]=\"{'disable': disable}\">\n  <input\n    type=\"text\"\n    [(ngModel)]=\"chosenTime\"\n    (ngModelChange)=\"onTimeChange(chosenTime)\"\n    [ngClass]=\"{ invalid: isInvalid || !rangeValidity }\"\n    [ngStyle]=\"{ width: inputWidth }\"\n    (click)=\"openDropdown()\"\n    misToolTip\n    [showToolTip]=\"showTooltip && (isInvalid || !rangeValidity) && dispayToolTip\"\n    [text]=\"'Invalid Time'\"\n    [position]=\"'top'\"\n    [showOnHover]=\"false\"\n    #input\n    cdkOverlayOrigin\n    class=\"h7\"\n  />\n\n  <ng-template #dropdownContainer libDropdownScroll libTimepicker [originEl]=\"input\" [openStatus]=\"openStatus\" (statusEmitter)=\"closeDropdown()\">\n    <div *ngIf=\"openStatus\" class=\"timepicker-dropdown\" [ngStyle]=\"{ width: dropdownWidth || inputWidth }\">\n      <ul #dropdown>\n        <li #timeInterval (click)=\"onTimeSelect(interval)\" *ngFor=\"let interval of timeIntervals; index as i\" [ngClass]=\"{ highlight: i === isHighlighted }\">\n          {{ interval }}\n          <div class=\"ic-ui-check-24 selected-icon\" *ngIf=\"interval === chosenTime\"></div>\n        </li>\n      </ul>\n    </div>\n  </ng-template>\n</div>\n"]}
459
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"timepicker.component.js","sourceRoot":"","sources":["../../../../projects/mis-components/timepicker/timepicker.component.ts","../../../../projects/mis-components/timepicker/timepicker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, EventEmitter, Input, OnDestroy, OnInit, Output, ViewChild, ViewChildren, input, output, signal, computed, effect, untracked } from \"@angular/core\";\nimport { ITime } from \"./time.namespace\";\nimport { TimepickerDirective } from \"./timepicker.directive\";\nimport { ToolTipDirective } from \"mis-crystal-design-system/tooltip\";\n\nimport dayjs from 'dayjs';\nimport timezone from 'dayjs/plugin/timezone';\nimport utc from 'dayjs/plugin/utc';\nimport customParseFormat from 'dayjs/plugin/customParseFormat'\n\ndayjs.extend(utc);\ndayjs.extend(timezone);\ndayjs.extend(customParseFormat);\n\n\n@Component({\n  selector: \"mis-timepicker\",\n  templateUrl: \"./timepicker.component.html\",\n  styleUrls: [\"./timepicker.component.scss\"]\n})\nexport class TimePickerComponent implements OnInit, OnDestroy {\n  // Convert to signals for better performance and change detection\n  currTime = signal<string>('');\n  chosenTime = signal<string>('');\n  openStatus = signal<boolean>(false);\n  isHighlighted = signal<number>(0);\n  isInvalid = signal<boolean>(false);\n  timeIntervals = signal<string[]>([]);\n  shouldScroll = signal<boolean>(false);\n  userInputFlag = signal<boolean>(false);\n  givenTimeFlag = signal<boolean>(true);\n  // Signal-based inputs with backward compatibility\n  clockFormat = input<number>(12);\n  timeFormat!: string;\n  \n  timezone = input<string>(\"Asia/Kolkata\");\n  height = input<string>(\"max-content\");\n  inputWidth = input<string>(\"100px\");\n  dropdownWidth = input<string | undefined>(undefined);\n  interval = input<number>(15);\n  dateAsEpoch = input<number>(dayjs.tz(dayjs(), \"Asia/Kolkata\").valueOf());\n  firstInterval = input<number>();\n  rangeValidity = input<boolean>(true);\n  showTooltip = input<boolean>(true);\n  dispayToolTip: boolean = this.showTooltip();\n  givenTime = input<number>();\n  minTime = input<number | undefined>(undefined);\n  triggerChange = input<boolean>(true);\n  disable = input<boolean>(false);\n  \n  // Internal state for computed first interval\n  private computedFirstInterval: number | null = null;\n  private _isInitializing = false;\n  \n  // Signal-based output with backward compatibility\n  timeEmitter = output<ITime>();\n  @ViewChild(\"input\", { static: true }) input: ElementRef;\n  @ViewChild(TimepickerDirective) timepickerDirective: TimepickerDirective;\n  @ViewChild(ToolTipDirective) tooltipDirective: ToolTipDirective;\n\n  // gets all the li elements from the dropdown and scrolls to the highlighted element\n  @ViewChildren(\"timeInterval\") set timeIntervalRefs(intervals) {\n    intervals.forEach(interval => {\n      if (interval.nativeElement.classList[0] === \"highlight\") {\n        const highlighted = interval.nativeElement;\n        setTimeout(() => highlighted.scrollIntoView({ block: \"center\" }));\n      }\n    });\n  }\n\n  constructor(){\n    // Effect to handle triggerChange from parent component (timerangepicker)\n    effect(() => {\n      const triggerValue = this.triggerChange();\n      const firstIntervalValue = this.firstInterval();\n      \n      // Only update if not during user input and firstInterval is provided\n      if (!untracked(() => this.userInputFlag()) && firstIntervalValue && !this._isInitializing) {\n        const newTime = dayjs.tz(firstIntervalValue, untracked(() => this.timezone())).format(this.timeFormat);\n        \n        // Only update if the time actually changed\n        if (untracked(() => this.chosenTime()) !== newTime) {\n          // Use setTimeout to defer signal writes and avoid circular dependencies\n          setTimeout(() => {\n            this.chosenTime.set(newTime);\n            this.isInvalid.set(!this.checkTimeValidity(newTime.trim()));\n            \n            // CRITICAL FIX: Repopulate dropdown when firstInterval changes\n            this.populateDropdown();\n            \n            // Recalculate closest interval\n            this.calculateClosestInterval(newTime);\n            \n            // Emit the updated time\n            const timedayjs = this.getdayjs(newTime);\n            this.emitTime({\n              valid: !this.isInvalid(),\n              time: newTime,\n              epoch: timedayjs.valueOf()\n            });\n          }, 0);\n        }\n      }\n    });\n  }\n  \n  ngOnInit(): void {\n    this._isInitializing = true;\n    // Ensure timeFormat is set before initialization\n    this.timeFormat = this.clockFormat() === 12 ? \"hh:mm a\" : \"HH:mm\";\n    \n    // Initialize chosenTime - use firstInterval from parent if available, otherwise calculate\n    if (!this.givenTime() && !this.minTime()) {\n      let initialTime;\n      \n      // If firstInterval is provided by parent (timerangepicker), use it\n      if (this.firstInterval()) {\n        initialTime = dayjs.tz(this.firstInterval(), this.timezone()).format(this.timeFormat);\n      } else {\n        // Get current time and round to nearest interval using original logic\n        const now = dayjs.tz(dayjs(), this.timezone());\n        const interval = this.interval();\n        const minutes = now.minute();\n        const offset = interval - (minutes % interval);\n        \n        // Round to next interval if we're past halfway point\n        const roundedTime = offset >= interval / 2 \n          ? now.add(offset, \"m\").second(0).millisecond(0)\n          : now.subtract(interval - offset, \"m\").second(0).millisecond(0);\n        \n        initialTime = roundedTime.format(this.timeFormat);\n      }\n      \n      this.chosenTime.set(initialTime);\n      \n      // Set userInputFlag to false to avoid validation issues during initialization\n      this.userInputFlag.set(false);\n      \n      // Populate dropdown first to compute the first interval\n      this.populateDropdown();\n      \n      // Now validate with the computed first interval\n      this.isInvalid.set(!this.checkTimeValidity(this.chosenTime().trim()));\n      \n      let chosenTimedayjs = this.getdayjs(this.chosenTime());\n      // Defer emission to avoid ExpressionChangedAfterItHasBeenCheckedError\n      setTimeout(() => {\n        this.emitTime({\n          valid: !this.isInvalid(),\n          time: this.chosenTime(),\n          epoch: chosenTimedayjs.valueOf()\n        });\n      }, 0);\n      \n      // Calculate closest interval\n      this.calculateClosestInterval(this.chosenTime());\n      \n      this._isInitializing = false;\n    } else if (this.givenTime()) {\n      // When givenTime is present, use the given time as the initial value\n      // but the dropdown will start from 12:00 AM\n      this.chosenTime.set(dayjs.tz(this.givenTime(), this.timezone()).format(this.timeFormat));\n      this.userInputFlag.set(false);\n      \n      // Populate dropdown first to compute the first interval\n      this.populateDropdown();\n      \n      // Now validate with the computed first interval\n      this.isInvalid.set(!this.checkTimeValidity(this.chosenTime().trim()));\n      \n      let chosenTimedayjs = this.getdayjs(this.chosenTime());\n      // Defer emission to avoid ExpressionChangedAfterItHasBeenCheckedError\n      setTimeout(() => {\n        this.emitTime({\n          valid: !this.isInvalid(),\n          time: this.chosenTime(),\n          epoch: chosenTimedayjs.valueOf()\n        });\n      }, 0);\n      \n      // Calculate closest interval\n      this.calculateClosestInterval(this.chosenTime());\n      \n      this._isInitializing = false;\n    } else if (this.minTime()) {\n      // Use min time directly - this matches original behavior\n      this.chosenTime.set(dayjs.tz(this.minTime(), this.timezone()).format(this.timeFormat));\n      this.userInputFlag.set(false);\n      \n      // Populate dropdown first to compute the first interval\n      this.populateDropdown();\n      \n      // For minTime, validation should only check format, not time comparison\n      // This matches the original logic where minTime bypasses time validation\n      this.isInvalid.set(!this.checkTimeValidity(this.chosenTime().trim()));\n      \n      let chosenTimedayjs = this.getdayjs(this.chosenTime());\n      // Defer emission to avoid ExpressionChangedAfterItHasBeenCheckedError\n      setTimeout(() => {\n        this.emitTime({\n          valid: !this.isInvalid(),\n          time: this.chosenTime(),\n          epoch: chosenTimedayjs.valueOf()\n        });\n      }, 0);\n      \n      // Calculate closest interval\n      this.calculateClosestInterval(this.chosenTime());\n      \n      this._isInitializing = false;\n    }\n  }\n\n\n  emitTime(data: ITime): void {\n    this.timeEmitter.emit(data);\n  }\n\n  // function to get dayjs object when time is given in string\n  getdayjs(time: string = '00:00'){\n    if(!time || typeof time !== 'string') {\n      throw new Error('Time must be a string');\n    }\n\n    let hours: number;\n    let minutes: number;\n\n    if(this.clockFormat() === 24) {\n      hours = parseInt(time.split(':')[0]);\n      minutes = parseInt(time.split(':')[1]);\n    } else {\n      const timeParts = time.split(' ');\n      const AM_PM = timeParts?.[1];\n      hours =  parseInt(timeParts?.[0]?.split(':')?.[0]);\n      minutes = parseInt(timeParts?.[0]?.split(':')?.[1]);\n\n      if(AM_PM?.toUpperCase() === 'PM' && hours !== 12) {\n        hours += 12;\n      } else if(AM_PM?.toUpperCase() === 'AM' && hours === 12) {\n        hours = 0;\n      }\n    }\n\n    // Use the date from dateAsEpoch but set the time to the parsed hours and minutes\n    const baseDate = dayjs.tz(this.dateAsEpoch(), this.timezone());\n    const result = baseDate.hour(hours).minute(minutes).second(0).millisecond(0);\n    return result;\n  }\n\n  closeDropdown() {\n    this.dispayToolTip = false;\n    this.userInputFlag.set(false);\n    this.openStatus.set(false);\n    if (this.timepickerDirective) this.timepickerDirective.destroyOverlay();\n  }\n\n  // toggle timepicker dropdown\n  openDropdown(): void {\n    this.dispayToolTip = true;\n    this.openStatus.set(true);\n  }\n\n  checkTimeValidity(time: string): boolean {\n    const RE12 = /^(([0][1-9]|1[0-2]):([0-5][0-9])( )?(am|pm|AM|PM))$/i;\n    const RE24 = /^([01][0-9]|2[0-3]):[0-5][0-9]$/;\n    const RE = this.clockFormat() === 12 ? RE12 : RE24;\n\n    // Check if the time format is valid first\n    if (!time.match(RE)) {\n      return false;\n    }\n\n    // Restore proper validation logic\n    const timedayjs = this.getdayjs(time);\n    let flag: boolean = false;\n\n    // Original logic: if minTime, givenTime, or firstInterval is start of day, only check format\n    if (\n      this.minTime() || \n      this.givenTime() ||\n      (this.firstInterval() &&\n      dayjs.tz(this.firstInterval(), this.timezone()).format(this.timeFormat).valueOf() === dayjs.tz(dayjs(), this.timezone()).startOf(\"day\").format(this.timeFormat).valueOf())                                        \n    ) {\n      // Only check format validation, not time comparison\n      flag = time.match(RE) ? true : false;\n    } else {\n      // Check against current time for normal cases\n      const currentTime = dayjs.tz(dayjs(), this.timezone());\n      const timeDiff = timedayjs.diff(currentTime, \"m\");\n      flag = timeDiff >= 0;\n    }\n\n    return flag;\n  }\n\n  // update chosen time as soon as the user clicks on an interval\n  onTimeSelect(time: string): void {\n    this.isInvalid.set(!this.checkTimeValidity(time.trim()));\n    if (!this.isInvalid()) {\n      this.chosenTime.set(time);\n      this.calculateClosestInterval(this.chosenTime());\n    }\n\n    const timedayjs = this.getdayjs(time);\n    this.emitTime({\n      valid: !this.isInvalid(),\n      time: time,\n      epoch: timedayjs.valueOf() \n    });\n    this.openStatus.set(false);\n    if (this.timepickerDirective) this.timepickerDirective.destroyOverlay();\n  }\n\n  // checks validity of time on input change and calculates the closest interval\n  onTimeChange(time: string): void {\n    // Set user input flag to prevent effects from overriding\n    this.userInputFlag.set(true);\n    \n    // Update the chosenTime signal\n    this.chosenTime.set(time);\n    const isValid = this.checkTimeValidity(time.trim());\n    this.isInvalid.set(!isValid);\n\n    // Clear user input flag after a delay to allow effects to work again\n    setTimeout(() => {\n      this.userInputFlag.set(false);\n    }, 1000); // 1 second delay\n\n    if (!this.isInvalid()) {\n      this.openStatus.set(false);\n      if (this.timepickerDirective) this.timepickerDirective.destroyOverlay();\n      this.calculateClosestInterval(time);\n    }\n    const timedayjs = this.getdayjs(time);\n    this.emitTime({\n      valid: !this.isInvalid(),\n      time: time,\n      epoch: timedayjs.valueOf() \n    });\n  }\n\n  calculateClosestInterval(time: string): void {\n    let roundedEpoch: number;\n    // Converting time and date to a dayjs object \n    const chosenDate = dayjs.tz(this.dateAsEpoch(), this.timezone()).format(\"DD-MM-YYYY\"); // 05-01-2024\n    const parsedTimeWithDate = dayjs.tz(`${chosenDate} ${time}`, `DD-MM-YYYY ${this.timeFormat}`, this.timezone());\n    // Converting dayjs object to epoch\n    const chosenTimeEpoch = parsedTimeWithDate.valueOf();\n    const offset = this.interval() - (dayjs.tz(chosenTimeEpoch, this.timezone()).minute() % this.interval());\n\n    if (this.minTime() && !this.givenTime()) {\n      this.isHighlighted.set(0);\n      return;\n    }\n    roundedEpoch = offset >= this.interval() / 2 ? (dayjs.tz(chosenTimeEpoch, this.timezone()).subtract(this.interval() - offset, \"m\")).valueOf() : (dayjs.tz(chosenTimeEpoch, this.timezone()).add( offset, \"m\")).valueOf();\n\n    // finding the index of element that needs to be highlighted\n    if ( chosenTimeEpoch > dayjs.tz(this.dateAsEpoch(), this.timezone()).endOf(\"day\").subtract(this.interval(), \"m\").valueOf()) {\n      this.isHighlighted.set(this.timeIntervals().length - 1);\n    } else {\n      const roundedEpochdayjs = dayjs.tz(roundedEpoch, this.timezone());\n      this.isHighlighted.set(this.timeIntervals().findIndex(interval => {\n        const intervalObj = dayjs.tz(`${chosenDate} ${interval}`, `DD-MM-YYYY ${this.timeFormat}`, this.timezone());\n        return intervalObj.isSame(roundedEpochdayjs);\n      }));\n    }\n  }\n\n\n  // populates the dropdown according to the first interval received\n  populateDropdown(): void {\n    this.timeIntervals.set([]);\n\n    // Compute the effective first interval\n    let effectiveFirstInterval = this.firstInterval();\n\n    // if picker is used as an individual component\n    if (!effectiveFirstInterval) {\n      // firstInterval is initialised according to the current time\n      // if the date is same as the current date\n      if (dayjs.tz(this.dateAsEpoch(), this.timezone()).format(\"DD-MM-YYYY\") === dayjs.tz(dayjs(), this.timezone()).format(\"DD-MM-YYYY\") && !this.minTime()) {\n        const offset = this.interval() - (dayjs.tz(dayjs(), this.timezone()).minute() % this.interval());\n        effectiveFirstInterval = dayjs.tz(dayjs(), this.timezone()).add(offset, \"m\").valueOf();\n      }\n      // if minimum time to show is provided\n      else if(this.minTime()){\n        const minTimeDayjs = dayjs.tz(this.minTime(), this.timezone());\n        const offset = this.interval() - (minTimeDayjs.minute() % this.interval());\n        effectiveFirstInterval = minTimeDayjs.add(offset, \"m\").valueOf();\n      }\n      // else the firstInterval is initialised as start of day\n      else {\n        effectiveFirstInterval = dayjs.tz(dayjs(), this.timezone()).startOf(\"day\").valueOf();\n      }\n    }\n\n    if(this.givenTime()){\n      // When givenTime is present, always start from 12:00 AM (start of day)\n      // regardless of whether the time has passed or not\n      effectiveFirstInterval = dayjs.tz(this.dateAsEpoch(), this.timezone()).startOf('day').valueOf();\n      this.givenTimeFlag.set(false);\n    }\n\n    // Store the computed first interval for later use\n    this.computedFirstInterval = effectiveFirstInterval;\n\n    const dateAsString = dayjs.tz(this.dateAsEpoch(), this.timezone()).format('DD-MM-YYYY');\n    const intervalAsString = dayjs.tz(effectiveFirstInterval, this.timezone()).format(this.timeFormat);\n    let start = dayjs.tz(`${dateAsString} ${intervalAsString}`, `DD-MM-YYYY ${this.timeFormat}`, this.timezone());\n    const end = dayjs.tz(this.dateAsEpoch(), this.timezone()).endOf('d');\n    \n    while (start.valueOf() < end.valueOf()) {\n      this.timeIntervals.update(intervals => [...intervals, start.format(this.timeFormat)]);\n      start = start.add(this.interval(), \"m\");\n    }\n\n    // NEW: Handle end-of-day case - if firstInterval is at or very close to end of day\n    // and we're on the same date, show only 11:59 PM\n    const endOfDay = dayjs.tz(this.dateAsEpoch(), this.timezone()).endOf(\"d\");\n    const firstIntervalDayjs = dayjs.tz(effectiveFirstInterval, this.timezone());\n    \n    // Check if firstInterval is at or very close to end of day (within 1 minute)\n    const isAtEndOfDay = firstIntervalDayjs.isSame(endOfDay, 'day') && \n                        firstIntervalDayjs.diff(endOfDay, 'minute') >= -1;\n    \n    if (isAtEndOfDay || this.timeIntervals().length === 0) {\n      // Clear existing intervals and add only 11:59 PM\n      this.timeIntervals.set([]);\n      this.timeIntervals.update(intervals => [...intervals, endOfDay.format(this.timeFormat)]);\n    }\n  }\n\n  ngOnDestroy() {\n    if (this.tooltipDirective) this.tooltipDirective.hideToolTip();\n  }\n}\n\n","<div class=\"timepicker-container\" [ngStyle]=\"{ height: height() }\" [ngClass]=\"{'disable': disable()}\">\n  <input\n    type=\"text\"\n    [ngModel]=\"chosenTime()\"\n    (ngModelChange)=\"onTimeChange($event)\"\n    [ngClass]=\"{ invalid: isInvalid() || !rangeValidity() }\"\n    [ngStyle]=\"{ width: inputWidth() }\"\n    (click)=\"openDropdown()\"\n    misToolTip\n    [showToolTip]=\"showTooltip() && (isInvalid() || !rangeValidity()) && dispayToolTip\"\n    [text]=\"'Invalid Time'\"\n    [position]=\"'top'\"\n    [showOnHover]=\"false\"\n    #input\n    cdkOverlayOrigin\n    class=\"h7\"\n  />\n\n  <ng-template #dropdownContainer libTimepicker [originEl]=\"input\" [openStatus]=\"openStatus()\" (statusEmitter)=\"closeDropdown()\">\n    <div *ngIf=\"openStatus()\" class=\"timepicker-dropdown\" [ngStyle]=\"{ width: dropdownWidth() || inputWidth() }\">\n      <ul #dropdown>\n        <li #timeInterval (click)=\"onTimeSelect(interval)\" *ngFor=\"let interval of timeIntervals(); index as i\" [ngClass]=\"{ highlight: i === isHighlighted() }\">\n          {{ interval }}\n          <div class=\"ic-ui-check-24 selected-icon\" *ngIf=\"interval === chosenTime()\"></div>\n        </li>\n      </ul>\n    </div>\n  </ng-template>\n</div>\n"]}