mis-crystal-design-system 18.0.25 → 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 (185) 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/button/button.directive.scss +13 -15
  6. package/checkbox/checkbox.component.d.ts +15 -12
  7. package/chip/chip.component.d.ts +9 -11
  8. package/datepicker_v2/models/dp-config.model.d.ts +1 -0
  9. package/datepicker_v2/tz-datepicker.directive.d.ts +15 -18
  10. package/datepicker_v2/tz-dp-container/tz-dp-container.component.d.ts +42 -21
  11. package/daterangepicker_v2/tz-daterangepicker.directive.d.ts +12 -14
  12. package/daterangepicker_v2/tz-drp-container/tz-drp-container.component.d.ts +46 -23
  13. package/drawer/drawer-body/drawer-body.component.d.ts +2 -2
  14. package/drawer/drawer.scss +1 -1
  15. package/dropdown/calculate-container-height.directive.d.ts +7 -8
  16. package/dropdown/dropdown.component.d.ts +41 -49
  17. package/dynamic-form/dynamic-form.component.d.ts +20 -16
  18. package/esm2022/action-list/action-list.component.mjs +113 -90
  19. package/esm2022/async-search-dropdown/async-dropdown.component.mjs +257 -327
  20. package/esm2022/button/button.component.mjs +56 -49
  21. package/esm2022/button/button.directive.mjs +36 -40
  22. package/esm2022/checkbox/checkbox.component.mjs +75 -70
  23. package/esm2022/chip/chip.component.mjs +20 -33
  24. package/esm2022/datepicker_v2/models/dp-config.model.mjs +1 -1
  25. package/esm2022/datepicker_v2/tz-datepicker.directive.mjs +42 -71
  26. package/esm2022/datepicker_v2/tz-dp-container/tz-dp-container.component.mjs +203 -173
  27. package/esm2022/datepicker_v2/utils/index.mjs +2 -1
  28. package/esm2022/daterangepicker_v2/tz-daterangepicker.directive.mjs +26 -51
  29. package/esm2022/daterangepicker_v2/tz-drp-container/tz-drp-container.component.mjs +283 -236
  30. package/esm2022/drawer/drawer-body/drawer-body.component.mjs +8 -7
  31. package/esm2022/dropdown/calculate-container-height.directive.mjs +25 -22
  32. package/esm2022/dropdown/dropdown.component.mjs +163 -187
  33. package/esm2022/dynamic-form/dynamic-form.component.mjs +119 -73
  34. package/esm2022/fab/fab.component.mjs +30 -34
  35. package/esm2022/filter/filter-panel/filter-panel.component.mjs +61 -59
  36. package/esm2022/input/directives/input/input.directive.mjs +22 -26
  37. package/esm2022/input/mis-input.component.mjs +42 -46
  38. package/esm2022/input-stepper/input-stepper/input-stepper.component.mjs +42 -52
  39. package/esm2022/loader/loader.component.mjs +8 -11
  40. package/esm2022/mobile-filter/mobile-filter.component.mjs +62 -62
  41. package/esm2022/modal/module-wrapper/module-wrapper.component.mjs +11 -9
  42. package/esm2022/multi-select-dropdown/multi-select-dropdown.component.mjs +235 -281
  43. package/esm2022/nested-multi-select-dropdown/nested-multi-select-dropdown.component.mjs +250 -287
  44. package/esm2022/phone-input/phone-input.component.mjs +21 -43
  45. package/esm2022/public-api.mjs +1 -1
  46. package/esm2022/radio-button/radio-button.component.mjs +15 -27
  47. package/esm2022/ske-loader/ske-loader.component.mjs +15 -29
  48. package/esm2022/slider/slider.component.mjs +23 -33
  49. package/esm2022/slider/slider.module.mjs +4 -11
  50. package/esm2022/snackbar/snackbar/snackbar.component.mjs +21 -15
  51. package/esm2022/snackbar/snackbar.service.mjs +3 -2
  52. package/esm2022/specificdatepicker/tz-sdp-container/tz-sdp-container.component.mjs +231 -344
  53. package/esm2022/specificdatepicker/tz-specificdatepicker.directive.mjs +77 -105
  54. package/esm2022/star-rating/star-rating.component.mjs +58 -72
  55. package/esm2022/switch/switch.component.mjs +34 -36
  56. package/esm2022/table/actions-cell/actions-cell.component.mjs +56 -55
  57. package/esm2022/table/custom-table-cell.directive.mjs +22 -18
  58. package/esm2022/table/filter/filter.component.mjs +60 -42
  59. package/esm2022/table/sort-icons.directive.mjs +16 -8
  60. package/esm2022/table/sub-table/sub-table.component.mjs +42 -45
  61. package/esm2022/table/table.component.mjs +182 -166
  62. package/esm2022/timepicker/timepicker.component.mjs +245 -160
  63. package/esm2022/timepicker/timepicker.directive.mjs +3 -2
  64. package/esm2022/timerangepicker/timerangepicker.component.mjs +200 -159
  65. package/esm2022/toast/toast.component.mjs +7 -8
  66. package/esm2022/toast/toast.data.service.mjs +15 -9
  67. package/esm2022/tooltip/tooltip-container/tooltip.component.mjs +12 -12
  68. package/esm2022/tooltip/tooltip.directive.mjs +4 -4
  69. package/esm2022/virtual-scroll/virtual-scroll.component.mjs +57 -59
  70. package/fab/fab.component.d.ts +12 -8
  71. package/fesm2022/mis-crystal-design-system-action-list.mjs +112 -89
  72. package/fesm2022/mis-crystal-design-system-action-list.mjs.map +1 -1
  73. package/fesm2022/mis-crystal-design-system-async-search-dropdown.mjs +254 -325
  74. package/fesm2022/mis-crystal-design-system-async-search-dropdown.mjs.map +1 -1
  75. package/fesm2022/mis-crystal-design-system-button.mjs +89 -86
  76. package/fesm2022/mis-crystal-design-system-button.mjs.map +1 -1
  77. package/fesm2022/mis-crystal-design-system-checkbox.mjs +74 -69
  78. package/fesm2022/mis-crystal-design-system-checkbox.mjs.map +1 -1
  79. package/fesm2022/mis-crystal-design-system-chip.mjs +19 -32
  80. package/fesm2022/mis-crystal-design-system-chip.mjs.map +1 -1
  81. package/fesm2022/mis-crystal-design-system-datepicker_v2.mjs +243 -241
  82. package/fesm2022/mis-crystal-design-system-datepicker_v2.mjs.map +1 -1
  83. package/fesm2022/mis-crystal-design-system-daterangepicker_v2.mjs +306 -284
  84. package/fesm2022/mis-crystal-design-system-daterangepicker_v2.mjs.map +1 -1
  85. package/fesm2022/mis-crystal-design-system-drawer.mjs +7 -6
  86. package/fesm2022/mis-crystal-design-system-drawer.mjs.map +1 -1
  87. package/fesm2022/mis-crystal-design-system-dropdown.mjs +184 -205
  88. package/fesm2022/mis-crystal-design-system-dropdown.mjs.map +1 -1
  89. package/fesm2022/mis-crystal-design-system-dynamic-form.mjs +119 -73
  90. package/fesm2022/mis-crystal-design-system-dynamic-form.mjs.map +1 -1
  91. package/fesm2022/mis-crystal-design-system-fab.mjs +29 -33
  92. package/fesm2022/mis-crystal-design-system-fab.mjs.map +1 -1
  93. package/fesm2022/mis-crystal-design-system-filter.mjs +60 -58
  94. package/fesm2022/mis-crystal-design-system-filter.mjs.map +1 -1
  95. package/fesm2022/mis-crystal-design-system-input-stepper.mjs +41 -51
  96. package/fesm2022/mis-crystal-design-system-input-stepper.mjs.map +1 -1
  97. package/fesm2022/mis-crystal-design-system-input.mjs +62 -71
  98. package/fesm2022/mis-crystal-design-system-input.mjs.map +1 -1
  99. package/fesm2022/mis-crystal-design-system-loader.mjs +7 -10
  100. package/fesm2022/mis-crystal-design-system-loader.mjs.map +1 -1
  101. package/fesm2022/mis-crystal-design-system-mobile-filter.mjs +61 -61
  102. package/fesm2022/mis-crystal-design-system-mobile-filter.mjs.map +1 -1
  103. package/fesm2022/mis-crystal-design-system-modal.mjs +10 -8
  104. package/fesm2022/mis-crystal-design-system-modal.mjs.map +1 -1
  105. package/fesm2022/mis-crystal-design-system-multi-select-dropdown.mjs +233 -279
  106. package/fesm2022/mis-crystal-design-system-multi-select-dropdown.mjs.map +1 -1
  107. package/fesm2022/mis-crystal-design-system-nested-multi-select-dropdown.mjs +249 -286
  108. package/fesm2022/mis-crystal-design-system-nested-multi-select-dropdown.mjs.map +1 -1
  109. package/fesm2022/mis-crystal-design-system-phone-input.mjs +20 -42
  110. package/fesm2022/mis-crystal-design-system-phone-input.mjs.map +1 -1
  111. package/fesm2022/mis-crystal-design-system-radio-button.mjs +14 -26
  112. package/fesm2022/mis-crystal-design-system-radio-button.mjs.map +1 -1
  113. package/fesm2022/mis-crystal-design-system-ske-loader.mjs +14 -28
  114. package/fesm2022/mis-crystal-design-system-ske-loader.mjs.map +1 -1
  115. package/fesm2022/mis-crystal-design-system-slider.mjs +25 -42
  116. package/fesm2022/mis-crystal-design-system-slider.mjs.map +1 -1
  117. package/fesm2022/mis-crystal-design-system-snackbar.mjs +22 -15
  118. package/fesm2022/mis-crystal-design-system-snackbar.mjs.map +1 -1
  119. package/fesm2022/mis-crystal-design-system-specificdatepicker.mjs +305 -446
  120. package/fesm2022/mis-crystal-design-system-specificdatepicker.mjs.map +1 -1
  121. package/fesm2022/mis-crystal-design-system-star-rating.mjs +57 -71
  122. package/fesm2022/mis-crystal-design-system-star-rating.mjs.map +1 -1
  123. package/fesm2022/mis-crystal-design-system-switch.mjs +33 -35
  124. package/fesm2022/mis-crystal-design-system-switch.mjs.map +1 -1
  125. package/fesm2022/mis-crystal-design-system-table.mjs +368 -324
  126. package/fesm2022/mis-crystal-design-system-table.mjs.map +1 -1
  127. package/fesm2022/mis-crystal-design-system-timepicker.mjs +246 -160
  128. package/fesm2022/mis-crystal-design-system-timepicker.mjs.map +1 -1
  129. package/fesm2022/mis-crystal-design-system-timerangepicker.mjs +199 -158
  130. package/fesm2022/mis-crystal-design-system-timerangepicker.mjs.map +1 -1
  131. package/fesm2022/mis-crystal-design-system-toast.mjs +19 -14
  132. package/fesm2022/mis-crystal-design-system-toast.mjs.map +1 -1
  133. package/fesm2022/mis-crystal-design-system-tooltip.mjs +14 -14
  134. package/fesm2022/mis-crystal-design-system-tooltip.mjs.map +1 -1
  135. package/fesm2022/mis-crystal-design-system-virtual-scroll.mjs +57 -59
  136. package/fesm2022/mis-crystal-design-system-virtual-scroll.mjs.map +1 -1
  137. package/fesm2022/mis-crystal-design-system.mjs.map +1 -1
  138. package/filter/filter-panel/filter-panel.component.d.ts +14 -14
  139. package/input/directives/input/input.directive.d.ts +6 -10
  140. package/input/mis-input.component.d.ts +12 -13
  141. package/input/mis-input.component.scss +18 -18
  142. package/input-stepper/input-stepper/input-stepper.component.d.ts +8 -7
  143. package/loader/loader.component.d.ts +3 -6
  144. package/mobile-filter/mobile-filter.component.d.ts +15 -15
  145. package/modal/modal.scss +1 -1
  146. package/modal/module-wrapper/module-wrapper.component.d.ts +2 -3
  147. package/multi-select-dropdown/multi-select-dropdown.component.d.ts +89 -51
  148. package/nested-multi-select-dropdown/nested-multi-select-dropdown.component.d.ts +99 -56
  149. package/package.json +17 -23
  150. package/phone-input/phone-input.component.d.ts +16 -18
  151. package/radio-button/radio-button.component.d.ts +9 -11
  152. package/ske-loader/ske-loader.component.d.ts +8 -11
  153. package/slider/slider.component.d.ts +8 -11
  154. package/slider/slider.module.d.ts +1 -2
  155. package/snackbar/snackbar/snackbar.component.d.ts +3 -3
  156. package/specificdatepicker/tz-sdp-container/tz-sdp-container.component.d.ts +35 -35
  157. package/specificdatepicker/tz-specificdatepicker.directive.d.ts +24 -28
  158. package/star-rating/star-rating.component.d.ts +18 -18
  159. package/styles/mis-color-constants.scss +0 -204
  160. package/styles/mis-icons.scss +56 -56
  161. package/styles/mis-old-icon-styles.scss +21 -21
  162. package/switch/switch.component.d.ts +8 -10
  163. package/table/actions-cell/actions-cell.component.d.ts +14 -14
  164. package/table/custom-table-cell.directive.d.ts +3 -3
  165. package/table/filter/filter.component.d.ts +9 -9
  166. package/table/sub-table/sub-table.component.d.ts +5 -5
  167. package/table/table.component.d.ts +38 -35
  168. package/timepicker/timepicker.component.d.ts +29 -28
  169. package/timerangepicker/timerangepicker.component.d.ts +36 -33
  170. package/toast/toast.data.service.d.ts +1 -1
  171. package/tooltip/tooltip-container/tooltip.component.d.ts +4 -4
  172. package/virtual-scroll/virtual-scroll.component.d.ts +8 -9
  173. package/dynamic-theme/branding.types.d.ts +0 -84
  174. package/dynamic-theme/dynamic-theme.module.d.ts +0 -9
  175. package/dynamic-theme/dynamic-theme.service.d.ts +0 -89
  176. package/dynamic-theme/index.d.ts +0 -1
  177. package/dynamic-theme/public_api.d.ts +0 -3
  178. package/esm2022/dynamic-theme/branding.types.mjs +0 -93
  179. package/esm2022/dynamic-theme/dynamic-theme.module.mjs +0 -25
  180. package/esm2022/dynamic-theme/dynamic-theme.service.mjs +0 -193
  181. package/esm2022/dynamic-theme/index.mjs +0 -2
  182. package/esm2022/dynamic-theme/mis-crystal-design-system-dynamic-theme.mjs +0 -5
  183. package/esm2022/dynamic-theme/public_api.mjs +0 -4
  184. package/fesm2022/mis-crystal-design-system-dynamic-theme.mjs +0 -313
  185. package/fesm2022/mis-crystal-design-system-dynamic-theme.mjs.map +0 -1
@@ -1,4 +1,4 @@
1
- import { Component, Input, Output, EventEmitter } from "@angular/core";
1
+ import { Component, input, output, signal, computed } from "@angular/core";
2
2
  import dayjs from 'dayjs';
3
3
  import timezone from 'dayjs/plugin/timezone';
4
4
  import utc from 'dayjs/plugin/utc';
@@ -14,172 +14,245 @@ function TimeRangePickerComponent_p_2_Template(rf, ctx) { if (rf & 1) {
14
14
  dayjs.extend(utc);
15
15
  dayjs.extend(timezone);
16
16
  export class TimeRangePickerComponent {
17
- constructor(cdr) {
18
- this.cdr = cdr;
19
- this.inputWidth = "100px";
20
- this.height = "46px";
21
- this.timezone = "Asia/Kolkata";
22
- this.startDateEpoch = dayjs.tz(dayjs(), this.timezone).valueOf();
23
- this.endDateEpoch = dayjs.tz(dayjs(), this.timezone).valueOf();
24
- this.clockFormat = 12;
25
- this.interval = 15;
26
- this.showTooltip = true;
27
- this.direction = 'row';
28
- this.gap = '1rem';
29
- this.disableStartTime = false;
30
- this.disableEndTime = false;
31
- this.timeRangeEmitter = new EventEmitter();
32
- this.firstIntervalForStartPicker = dayjs().valueOf();
33
- this.firstIntervalForEndPicker = dayjs().valueOf();
34
- this.rangeValidity = true;
35
- this.triggerChange = true;
17
+ // Helper methods instead of computed signals to avoid signal write conflicts
18
+ getTimeFormat() {
19
+ return this.clockFormat() === 12 ? "hh:mm a" : "HH:mm";
36
20
  }
37
- ngOnInit() { }
38
- ngOnChanges() {
39
- this.timeFormat = this.clockFormat === 12 ? "hh:mm a" : "HH:mm";
40
- this.startDate = dayjs.tz(this.startDateEpoch, this.timezone).format("DD-MM-YYYY");
41
- this.endDate = dayjs.tz(this.endDateEpoch, this.timezone).format("DD-MM-YYYY");
42
- this.currDate = dayjs.tz(dayjs(), this.timezone).format("DD-MM-YYYY");
21
+ getStartDate() {
22
+ return dayjs.tz(this.startDateEpoch(), this.timezone()).format("DD-MM-YYYY");
23
+ }
24
+ getEndDate() {
25
+ return dayjs.tz(this.endDateEpoch(), this.timezone()).format("DD-MM-YYYY");
26
+ }
27
+ getCurrDate() {
28
+ return dayjs.tz(dayjs(), this.timezone()).format("DD-MM-YYYY");
29
+ }
30
+ constructor() {
31
+ // --- Input Signals (read-only) ---
32
+ this.inputWidth = input("100px");
33
+ this.dropdownWidth = input(undefined);
34
+ this.height = input("46px");
35
+ this.timezone = input("Asia/Kolkata");
36
+ this.startDateEpoch = input(dayjs.tz(dayjs(), this.timezone()).valueOf());
37
+ this.endDateEpoch = input(dayjs.tz(dayjs(), this.timezone()).valueOf());
38
+ this.givenStartTime = input(undefined);
39
+ this.givenEndTime = input(undefined);
40
+ this.clockFormat = input(12);
41
+ this.interval = input(15);
42
+ this.showTooltip = input(true);
43
+ this.direction = input('row');
44
+ this.gap = input('1rem');
45
+ this.disableStartTime = input(false);
46
+ this.disableEndTime = input(false);
47
+ // --- Output Signal ---
48
+ this.timeRangeEmitter = output();
49
+ // --- Internal Writable Signals ---
50
+ this.startTime = signal(null);
51
+ this.endTime = signal(null);
52
+ this.rangeValidity = signal(true);
53
+ this.triggerChange = signal(true);
54
+ this._firstIntervals = signal({ start: 0, end: 0 });
55
+ this._isInitializing = false;
56
+ // --- Computed Signals (Derived State) ---
57
+ this.firstIntervals = computed(() => this._firstIntervals()); // A public computed signal to access the writable one
58
+ // Simple constructor - no effects here
59
+ }
60
+ ngOnInit() {
61
+ // Initialize the component once
62
+ this.initializeComponent();
63
+ }
64
+ initializeComponent() {
65
+ this._isInitializing = true;
43
66
  this.setFirstIntervals();
67
+ const firstIntervals = this._firstIntervals();
68
+ this.startTime.set({
69
+ valid: true,
70
+ time: dayjs.tz(firstIntervals.start, this.timezone()).format(this.getTimeFormat()),
71
+ epoch: dayjs.tz(firstIntervals.start, this.timezone()).valueOf()
72
+ });
73
+ // Ensure end time is always after start time
74
+ let endTimeEpoch = firstIntervals.end;
75
+ const startTimeEpoch = firstIntervals.start;
76
+ // If end time is same or before start time, add one interval to end time
77
+ if (endTimeEpoch <= startTimeEpoch) {
78
+ endTimeEpoch = dayjs.tz(startTimeEpoch, this.timezone()).add(this.interval(), 'm').valueOf();
79
+ // Update the firstIntervals to reflect the adjusted end time
80
+ this._firstIntervals.set({
81
+ start: firstIntervals.start,
82
+ end: endTimeEpoch
83
+ });
84
+ }
85
+ this.endTime.set({
86
+ valid: true,
87
+ time: dayjs.tz(endTimeEpoch, this.timezone()).format(this.getTimeFormat()),
88
+ epoch: endTimeEpoch
89
+ });
90
+ this._isInitializing = false;
44
91
  }
45
92
  // calculate the first interval of the picker
46
93
  setFirstIntervals() {
47
- const minutes = dayjs.tz(dayjs(), this.timezone).minute();
48
- const offset = this.interval - (minutes % this.interval);
49
- // start date, 22 MAY === current date, 22 MAY
50
- if (this.startDate === this.currDate) {
51
- const currentTime = dayjs.tz(dayjs(), this.timezone).valueOf();
52
- // start date, 22 MAY === current date, 22 MAY === end date, 22 MAY
53
- if (this.startDate === this.endDate) {
54
- // current time is in last interval
55
- if (currentTime >= dayjs.tz(this.startDateEpoch, this.timezone).endOf("d").subtract(this.interval, "m").valueOf()) {
56
- this.firstIntervalForStartPicker = currentTime;
57
- this.firstIntervalForEndPicker = dayjs.tz(this.endDateEpoch, this.timezone).endOf("d").valueOf();
94
+ let firstIntervalForStartPicker;
95
+ let firstIntervalForEndPicker;
96
+ const minutes = dayjs.tz(dayjs(), this.timezone()).minute();
97
+ const offset = this.interval() - (minutes % this.interval());
98
+ const currentTime = dayjs.tz(dayjs(), this.timezone()).valueOf();
99
+ if (this.getStartDate() === this.getCurrDate()) {
100
+ if (this.getStartDate() === this.getEndDate()) {
101
+ if (currentTime >= dayjs.tz(this.startDateEpoch(), this.timezone()).endOf("d").subtract(this.interval(), "m").valueOf()) {
102
+ firstIntervalForStartPicker = currentTime;
103
+ firstIntervalForEndPicker = dayjs.tz(this.endDateEpoch(), this.timezone()).endOf("d").valueOf();
58
104
  }
59
- // current time isn't in last interval
60
105
  else {
61
- this.firstIntervalForStartPicker = dayjs.tz(dayjs(), this.timezone).add(offset, "m").valueOf();
62
- this.firstIntervalForEndPicker = dayjs.tz(dayjs(), this.timezone).add(offset, "m").add(this.interval, "m").valueOf();
106
+ firstIntervalForStartPicker = dayjs.tz(dayjs(), this.timezone()).add(offset, "m").valueOf();
107
+ // For same date, end picker should start from beginning of day to avoid validation issues
108
+ firstIntervalForEndPicker = dayjs.tz(this.endDateEpoch(), this.timezone()).startOf("d").valueOf();
63
109
  }
64
110
  }
65
- // start date, 22 MAY === current date, 22 MAY !== end date, 30 MAY
66
111
  else {
67
- // current time is in last interval
68
- if (currentTime >= dayjs.tz(this.startDateEpoch, this.timezone).endOf("d").subtract(this.interval, "m").valueOf()) {
69
- this.firstIntervalForStartPicker = currentTime;
70
- this.firstIntervalForEndPicker = dayjs.tz(this.endDateEpoch, this.timezone).endOf("d").valueOf();
112
+ if (currentTime >= dayjs.tz(this.startDateEpoch(), this.timezone()).endOf("d").subtract(this.interval(), "m").valueOf()) {
113
+ firstIntervalForStartPicker = currentTime;
114
+ firstIntervalForEndPicker = dayjs.tz(this.endDateEpoch(), this.timezone()).endOf("d").valueOf();
71
115
  }
72
- // current time isn't in last interval
73
116
  else {
74
- this.firstIntervalForStartPicker = dayjs.tz(dayjs(), this.timezone).add(offset, "m").valueOf();
75
- this.firstIntervalForEndPicker = dayjs.tz(this.endDateEpoch, this.timezone).valueOf();
117
+ firstIntervalForStartPicker = dayjs.tz(dayjs(), this.timezone()).add(offset, "m").valueOf();
118
+ firstIntervalForEndPicker = dayjs.tz(this.endDateEpoch(), this.timezone()).startOf("d").valueOf();
76
119
  }
77
120
  }
78
121
  }
79
- // start date, 30 MAY !== current date, 22 MAY
80
122
  else {
81
- // start date === end Date
82
- if (this.startDate === this.endDate) {
83
- this.firstIntervalForStartPicker = dayjs.tz(this.startDateEpoch, this.timezone).startOf("d").valueOf();
84
- this.firstIntervalForEndPicker = dayjs.tz(this.endDateEpoch, this.timezone).add(this.interval, "m").valueOf();
123
+ if (this.getStartDate() === this.getEndDate()) {
124
+ firstIntervalForStartPicker = dayjs.tz(this.startDateEpoch(), this.timezone()).startOf("d").valueOf();
125
+ firstIntervalForEndPicker = dayjs.tz(this.endDateEpoch(), this.timezone()).add(this.interval(), "m").valueOf();
85
126
  }
86
- // start date !== end date
87
127
  else {
88
- this.firstIntervalForStartPicker = dayjs.tz(this.startDateEpoch, this.timezone).startOf("d").valueOf();
89
- this.firstIntervalForEndPicker = dayjs.tz(this.startDateEpoch, this.timezone).startOf("d").valueOf();
128
+ firstIntervalForStartPicker = dayjs.tz(this.startDateEpoch(), this.timezone()).startOf("d").valueOf();
129
+ firstIntervalForEndPicker = dayjs.tz(this.endDateEpoch(), this.timezone()).startOf("d").valueOf();
90
130
  }
91
131
  }
92
- if (this.givenStartTime)
93
- this.firstIntervalForStartPicker = this.givenStartTime;
94
- if (this.givenEndTime)
95
- this.firstIntervalForEndPicker = this.givenEndTime;
96
- this.startTime = {
97
- valid: true,
98
- time: dayjs.tz(this.firstIntervalForStartPicker, this.timezone).format(this.timeFormat),
99
- epoch: dayjs.tz(this.firstIntervalForStartPicker, this.timezone).valueOf()
100
- };
101
- this.endTime = {
102
- valid: true,
103
- time: dayjs.tz(this.firstIntervalForEndPicker, this.timezone).format(this.timeFormat),
104
- epoch: dayjs.tz(this.firstIntervalForEndPicker, this.timezone).valueOf()
105
- };
132
+ if (this.givenStartTime()) {
133
+ firstIntervalForStartPicker = this.givenStartTime();
134
+ }
135
+ if (this.givenEndTime()) {
136
+ firstIntervalForEndPicker = this.givenEndTime();
137
+ }
138
+ this._firstIntervals.set({ start: firstIntervalForStartPicker, end: firstIntervalForEndPicker });
106
139
  }
140
+ // --- Public Methods ---
107
141
  emitTimeRange(data) {
108
142
  this.timeRangeEmitter.emit(data);
109
143
  }
110
- //handlers catch the emitted values and run validation
111
144
  startPickerHandler(time) {
112
- this.startTime = time;
113
- this.rangeValidity = true;
114
- // if the start time changes and the start date is the same as the end date
115
- // and the start time >= end time
116
- // update the first interval of end picker according to the time set in start picker
117
- if (this.startDate === this.endDate) {
118
- let minutes = dayjs.tz(this.startTime.time, this.timeFormat, this.timezone).minute();
119
- let offset = this.interval - (minutes % this.interval);
120
- this.firstIntervalForEndPicker = dayjs.tz(`${this.startDate} ${this.startTime.time}`, `'DD-MM-YYYY' ${this.timeFormat}`, this.timezone)
121
- .add(offset, "m")
122
- .valueOf();
123
- // if the first interval == 12:00am, set it as 11:59pm
124
- const intervalAsString = dayjs.tz(this.firstIntervalForEndPicker, this.timezone).format(this.timeFormat);
125
- const endOfDayAsString = dayjs.tz(`${this.startDate}`, `DD-MM-YYYY`, this.timezone).endOf("d").add(1, "m").format(this.timeFormat);
126
- if (intervalAsString === endOfDayAsString) {
127
- this.firstIntervalForEndPicker = dayjs.tz(`${this.startDate} ${this.startTime.time}`, `'DD-MM-YYYY' ${this.timeFormat}`, this.timezone).endOf("d").valueOf();
128
- }
145
+ this.startTime.set(time);
146
+ this.rangeValidity.set(true);
147
+ // Don't emit during initialization
148
+ if (this._isInitializing) {
149
+ return;
129
150
  }
130
- else {
131
- const validity = this.checkTimeValidity(this.startTime.time.trim(), this.startDateEpoch) &&
132
- this.checkTimeValidity(this.endTime.time.trim(), this.endDateEpoch);
133
- this.rangeValidation(validity);
134
- this.emitTimeRange({
135
- valid: validity && this.rangeValidity,
136
- startTime: this.startTime.time,
137
- endTime: this.endTime.time,
138
- startEpoch: dayjs.tz(`${this.startDate} ${this.startTime.time}`, `DD-MM-YYYY ${this.timeFormat}`, this.timezone).valueOf(),
139
- endEpoch: dayjs.tz(`${this.endDate} ${this.endTime.time}`, `DD-MM-YYYY ${this.timeFormat}`, this.timezone).valueOf()
151
+ // Calculate start time epoch for comparison
152
+ const startTimeEpoch = dayjs.tz(`${this.getStartDate()} ${this.startTime().time}`, `DD-MM-YYYY ${this.getTimeFormat()}`, this.timezone()).valueOf();
153
+ const endTimeEpoch = dayjs.tz(`${this.getEndDate()} ${this.endTime().time}`, `DD-MM-YYYY ${this.getTimeFormat()}`, this.timezone()).valueOf();
154
+ // Auto-adjust end time if start time >= end time (for both same and different dates)
155
+ if (startTimeEpoch >= endTimeEpoch) {
156
+ // Calculate new end time as start time + interval
157
+ let newEndTimeEpoch = dayjs.tz(startTimeEpoch, this.timezone()).add(this.interval(), "m").valueOf();
158
+ // If same date, check if the new end time would go beyond end of day
159
+ if (this.getStartDate() === this.getEndDate()) {
160
+ const endOfDay = dayjs.tz(this.startDateEpoch(), this.timezone()).endOf("d").valueOf();
161
+ if (newEndTimeEpoch > endOfDay) {
162
+ // NEW: Set end time to 11:59 PM (end of day) when start time is last interval
163
+ newEndTimeEpoch = endOfDay;
164
+ }
165
+ }
166
+ // Update the end time signal
167
+ this.endTime.set({
168
+ valid: true,
169
+ time: dayjs.tz(newEndTimeEpoch, this.timezone()).format(this.getTimeFormat()),
170
+ epoch: newEndTimeEpoch
171
+ });
172
+ // Update the firstIntervals to reflect the new end time
173
+ this._firstIntervals.set({
174
+ start: this._firstIntervals().start,
175
+ end: newEndTimeEpoch
140
176
  });
141
177
  }
142
- this.triggerChange = !this.triggerChange;
178
+ // NEW: Update end timepicker's firstInterval when both timepickers are on the same day
179
+ // BUT only if there was a conflict (start >= end) or if we need to adjust for end of day
180
+ if (this.getStartDate() === this.getEndDate()) {
181
+ // Only update firstInterval if there was a conflict or if we're at end of day
182
+ if (startTimeEpoch >= endTimeEpoch) {
183
+ // Calculate the next interval after the selected start time
184
+ let nextIntervalAfterStart = dayjs.tz(startTimeEpoch, this.timezone()).add(this.interval(), "m").valueOf();
185
+ // NEW: If next interval would go beyond end of day, use end of day instead
186
+ const endOfDay = dayjs.tz(this.startDateEpoch(), this.timezone()).endOf("d").valueOf();
187
+ if (nextIntervalAfterStart > endOfDay) {
188
+ nextIntervalAfterStart = endOfDay;
189
+ }
190
+ // Update the firstIntervals to make end timepicker dropdown start from next interval after start time
191
+ this._firstIntervals.set({
192
+ start: this._firstIntervals().start,
193
+ end: nextIntervalAfterStart
194
+ });
195
+ }
196
+ // If start < end, don't update firstIntervals - let the end timepicker keep its current dropdown
197
+ }
198
+ // Always validate and emit the time range
199
+ const validity = this.checkTimeValidity(this.startTime().time.trim(), this.startDateEpoch()) &&
200
+ this.checkTimeValidity(this.endTime().time.trim(), this.endDateEpoch());
201
+ this.rangeValidation(validity);
202
+ this.emitTimeRange({
203
+ valid: validity && this.rangeValidity(),
204
+ startTime: this.startTime().time,
205
+ endTime: this.endTime().time,
206
+ startEpoch: dayjs.tz(`${this.getStartDate()} ${this.startTime().time}`, `DD-MM-YYYY ${this.getTimeFormat()}`, this.timezone()).valueOf(),
207
+ endEpoch: dayjs.tz(`${this.getEndDate()} ${this.endTime().time}`, `DD-MM-YYYY ${this.getTimeFormat()}`, this.timezone()).valueOf()
208
+ });
209
+ // FIXED: Only trigger change when there was a conflict (start >= end) that required end time update
210
+ const currentStartTimeEpoch = dayjs.tz(`${this.getStartDate()} ${this.startTime().time}`, `DD-MM-YYYY ${this.getTimeFormat()}`, this.timezone()).valueOf();
211
+ const currentEndTimeEpoch = dayjs.tz(`${this.getEndDate()} ${this.endTime().time}`, `DD-MM-YYYY ${this.getTimeFormat()}`, this.timezone()).valueOf();
212
+ if (currentStartTimeEpoch >= currentEndTimeEpoch) {
213
+ this.triggerChange.update(value => !value);
214
+ }
143
215
  }
144
216
  endPickerHandler(time) {
145
- this.endTime = time;
146
- const validity = this.checkTimeValidity(this.startTime.time.trim(), this.startDateEpoch) && this.checkTimeValidity(this.endTime.time.trim(), this.endDateEpoch);
217
+ this.endTime.set(time);
218
+ // Don't emit during initialization
219
+ if (this._isInitializing) {
220
+ return;
221
+ }
222
+ const validity = this.checkTimeValidity(this.startTime().time.trim(), this.startDateEpoch()) &&
223
+ this.checkTimeValidity(this.endTime().time.trim(), this.endDateEpoch());
147
224
  this.rangeValidation(validity);
148
225
  this.emitTimeRange({
149
- valid: validity && this.rangeValidity,
150
- startTime: this.startTime.time,
151
- endTime: this.endTime.time,
152
- startEpoch: dayjs.tz(`${this.startDate} ${this.startTime.time}`, `DD-MM-YYYY ${this.timeFormat}`, this.timezone).valueOf(),
153
- endEpoch: dayjs.tz(`${this.endDate} ${this.endTime.time}`, `DD-MM-YYYY ${this.timeFormat}`, this.timezone).valueOf()
226
+ valid: validity && this.rangeValidity(),
227
+ startTime: this.startTime().time,
228
+ endTime: this.endTime().time,
229
+ startEpoch: dayjs.tz(`${this.getStartDate()} ${this.startTime().time}`, `DD-MM-YYYY ${this.getTimeFormat()}`, this.timezone()).valueOf(),
230
+ endEpoch: dayjs.tz(`${this.getEndDate()} ${this.endTime().time}`, `DD-MM-YYYY ${this.getTimeFormat()}`, this.timezone()).valueOf()
154
231
  });
155
232
  }
156
233
  checkTimeValidity(time, date) {
157
234
  const RE12 = /^(([0][1-9]|1[0-2]):([0-5][0-9])( )?(am|pm|AM|PM))$/i;
158
235
  const RE24 = /^([01][0-9]|2[0-3]):[0-5][0-9]$/;
159
- const RE = this.clockFormat === 12 ? RE12 : RE24;
160
- const timedayjs = dayjs.tz(`${dayjs.tz(date, this.timezone).format("DD-MM-YYYY")} ${time}`, `'DD-MM-YYYY' ${this.timeFormat}`, this.timezone);
236
+ const RE = this.clockFormat() === 12 ? RE12 : RE24;
237
+ const timedayjs = dayjs.tz(`${dayjs.tz(date, this.timezone()).format("DD-MM-YYYY")} ${time}`, `'DD-MM-YYYY' ${this.getTimeFormat()}`, this.timezone());
161
238
  let flag = false;
162
- // if the first interval is set to the start of the day
163
- // then we don't check its validity against the current time
164
- if ((this.givenStartTime && this.givenEndTime) || (this.startDate !== this.endDate && this.startDate !== this.currDate)) {
239
+ if ((this.givenStartTime() && this.givenEndTime()) || (this.getStartDate() !== this.getEndDate() && this.getStartDate() !== this.getCurrDate())) {
165
240
  flag = time.match(RE) ? true : false;
166
241
  }
167
242
  else {
168
- flag = time.match(RE) && timedayjs.diff(dayjs.tz(dayjs(), this.timezone), "m") >= 0 ? true : false;
243
+ flag = time.match(RE) && timedayjs.diff(dayjs.tz(dayjs(), this.timezone()), "m") >= 0 ? true : false;
169
244
  }
170
245
  return flag;
171
246
  }
172
- // validates end picker's input according to the start picker's input
173
247
  rangeValidation(validity) {
174
- if (validity && this.startDate === this.endDate) {
175
- const startdayjs = dayjs.tz(this.startTime.time, this.timeFormat, this.timezone);
176
- const enddayjs = dayjs.tz(this.endTime.time, this.timeFormat, this.timezone);
177
- this.rangeValidity = enddayjs.diff(startdayjs, "m") >= 1 ? true : false;
178
- this.cdr.detectChanges();
248
+ if (validity && this.getStartDate() === this.getEndDate()) {
249
+ const startdayjs = dayjs.tz(this.startTime().time, this.getTimeFormat(), this.timezone());
250
+ const enddayjs = dayjs.tz(this.endTime().time, this.getTimeFormat(), this.timezone());
251
+ this.rangeValidity.set(enddayjs.diff(startdayjs, "m") >= 1);
179
252
  }
180
253
  }
181
- static { this.ɵfac = function TimeRangePickerComponent_Factory(__ngFactoryType__) { return new (__ngFactoryType__ || TimeRangePickerComponent)(i0.ɵɵdirectiveInject(i0.ChangeDetectorRef)); }; }
182
- static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: TimeRangePickerComponent, selectors: [["mis-timerangepicker"]], inputs: { inputWidth: "inputWidth", dropdownWidth: "dropdownWidth", height: "height", timezone: "timezone", startDateEpoch: "startDateEpoch", endDateEpoch: "endDateEpoch", givenStartTime: "givenStartTime", givenEndTime: "givenEndTime", clockFormat: "clockFormat", interval: "interval", showTooltip: "showTooltip", direction: "direction", gap: "gap", disableStartTime: "disableStartTime", disableEndTime: "disableEndTime" }, outputs: { timeRangeEmitter: "timeRangeEmitter" }, features: [i0.ɵɵNgOnChangesFeature], decls: 4, vars: 29, consts: [[1, "rangepicker-container", 3, "ngStyle"], [3, "timeEmitter", "clockFormat", "interval", "dateAsEpoch", "firstInterval", "timezone", "height", "inputWidth", "dropdownWidth", "showTooltip", "givenTime", "disable"], [4, "ngIf"], [3, "timeEmitter", "clockFormat", "interval", "dateAsEpoch", "firstInterval", "rangeValidity", "timezone", "height", "inputWidth", "dropdownWidth", "showTooltip", "givenTime", "triggerChange", "disable"]], template: function TimeRangePickerComponent_Template(rf, ctx) { if (rf & 1) {
254
+ static { this.ɵfac = function TimeRangePickerComponent_Factory(__ngFactoryType__) { return new (__ngFactoryType__ || TimeRangePickerComponent)(); }; }
255
+ static { this.ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: TimeRangePickerComponent, selectors: [["mis-timerangepicker"]], inputs: { inputWidth: [1, "inputWidth"], dropdownWidth: [1, "dropdownWidth"], height: [1, "height"], timezone: [1, "timezone"], startDateEpoch: [1, "startDateEpoch"], endDateEpoch: [1, "endDateEpoch"], givenStartTime: [1, "givenStartTime"], givenEndTime: [1, "givenEndTime"], clockFormat: [1, "clockFormat"], interval: [1, "interval"], showTooltip: [1, "showTooltip"], direction: [1, "direction"], gap: [1, "gap"], disableStartTime: [1, "disableStartTime"], disableEndTime: [1, "disableEndTime"] }, outputs: { timeRangeEmitter: "timeRangeEmitter" }, decls: 4, vars: 29, consts: [[1, "rangepicker-container", 3, "ngStyle"], [3, "timeEmitter", "clockFormat", "interval", "dateAsEpoch", "firstInterval", "timezone", "height", "inputWidth", "dropdownWidth", "showTooltip", "givenTime", "disable"], [4, "ngIf"], [3, "timeEmitter", "clockFormat", "interval", "dateAsEpoch", "firstInterval", "rangeValidity", "timezone", "height", "inputWidth", "dropdownWidth", "showTooltip", "givenTime", "triggerChange", "disable"]], template: function TimeRangePickerComponent_Template(rf, ctx) { if (rf & 1) {
183
256
  i0.ɵɵelementStart(0, "div", 0)(1, "mis-timepicker", 1);
184
257
  i0.ɵɵlistener("timeEmitter", function TimeRangePickerComponent_Template_mis_timepicker_timeEmitter_1_listener($event) { return ctx.startPickerHandler($event); });
185
258
  i0.ɵɵelementEnd();
@@ -188,50 +261,18 @@ export class TimeRangePickerComponent {
188
261
  i0.ɵɵlistener("timeEmitter", function TimeRangePickerComponent_Template_mis_timepicker_timeEmitter_3_listener($event) { return ctx.endPickerHandler($event); });
189
262
  i0.ɵɵelementEnd()();
190
263
  } if (rf & 2) {
191
- i0.ɵɵproperty("ngStyle", i0.ɵɵpureFunction2(26, _c0, ctx.direction, ctx.gap));
264
+ i0.ɵɵproperty("ngStyle", i0.ɵɵpureFunction2(26, _c0, ctx.direction(), ctx.gap()));
192
265
  i0.ɵɵadvance();
193
- i0.ɵɵproperty("clockFormat", ctx.clockFormat)("interval", ctx.interval)("dateAsEpoch", ctx.startDateEpoch)("firstInterval", ctx.firstIntervalForStartPicker)("timezone", ctx.timezone)("height", ctx.height)("inputWidth", ctx.inputWidth)("dropdownWidth", ctx.dropdownWidth)("showTooltip", ctx.showTooltip)("givenTime", ctx.givenStartTime)("disable", ctx.disableStartTime);
266
+ i0.ɵɵproperty("clockFormat", ctx.clockFormat())("interval", ctx.interval())("dateAsEpoch", ctx.startDateEpoch())("firstInterval", ctx.firstIntervals().start)("timezone", ctx.timezone())("height", ctx.height())("inputWidth", ctx.inputWidth())("dropdownWidth", ctx.dropdownWidth())("showTooltip", ctx.showTooltip())("givenTime", ctx.givenStartTime())("disable", ctx.disableStartTime());
194
267
  i0.ɵɵadvance();
195
- i0.ɵɵproperty("ngIf", ctx.direction === "row");
268
+ i0.ɵɵproperty("ngIf", ctx.direction() === "row");
196
269
  i0.ɵɵadvance();
197
- i0.ɵɵproperty("clockFormat", ctx.clockFormat)("interval", ctx.interval)("dateAsEpoch", ctx.endDateEpoch)("firstInterval", ctx.firstIntervalForEndPicker)("rangeValidity", ctx.rangeValidity)("timezone", ctx.timezone)("height", ctx.height)("inputWidth", ctx.inputWidth)("dropdownWidth", ctx.dropdownWidth)("showTooltip", ctx.showTooltip)("givenTime", ctx.givenEndTime)("triggerChange", ctx.triggerChange)("disable", ctx.disableEndTime);
270
+ i0.ɵɵproperty("clockFormat", ctx.clockFormat())("interval", ctx.interval())("dateAsEpoch", ctx.endDateEpoch())("firstInterval", ctx.firstIntervals().end)("rangeValidity", ctx.rangeValidity())("timezone", ctx.timezone())("height", ctx.height())("inputWidth", ctx.inputWidth())("dropdownWidth", ctx.dropdownWidth())("showTooltip", ctx.showTooltip())("givenTime", ctx.givenEndTime())("triggerChange", ctx.triggerChange())("disable", ctx.disableEndTime());
198
271
  } }, dependencies: [i1.NgIf, i1.NgStyle, i2.TimePickerComponent], styles: [".rangepicker-container[_ngcontent-%COMP%]{display:flex;gap:1rem;align-items:center}p[_ngcontent-%COMP%]{margin:0;display:inline-flex;align-items:center}"] }); }
199
272
  }
200
273
  (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(TimeRangePickerComponent, [{
201
274
  type: Component,
202
- args: [{ selector: "mis-timerangepicker", template: "<div class=\"rangepicker-container\" [ngStyle]=\"{'flexDirection': direction, 'gap': gap}\">\n <mis-timepicker\n [clockFormat]=\"clockFormat\"\n [interval]=\"interval\"\n [dateAsEpoch]=\"startDateEpoch\"\n [firstInterval]=\"firstIntervalForStartPicker\"\n (timeEmitter)=\"startPickerHandler($event)\"\n [timezone]=\"timezone\"\n [height]=\"height\"\n [inputWidth]=\"inputWidth\"\n [dropdownWidth]=\"dropdownWidth\"\n [showTooltip]=\"showTooltip\"\n [givenTime]=\"givenStartTime\"\n [disable]=\"disableStartTime\"\n ></mis-timepicker>\n <p *ngIf=\"direction === 'row'\">-</p>\n <mis-timepicker\n [clockFormat]=\"clockFormat\"\n [interval]=\"interval\"\n [dateAsEpoch]=\"endDateEpoch\"\n [firstInterval]=\"firstIntervalForEndPicker\"\n (timeEmitter)=\"endPickerHandler($event)\"\n [rangeValidity]=\"rangeValidity\"\n [timezone]=\"timezone\"\n [height]=\"height\"\n [inputWidth]=\"inputWidth\"\n [dropdownWidth]=\"dropdownWidth\"\n [showTooltip]=\"showTooltip\"\n [givenTime]=\"givenEndTime\"\n [triggerChange]=\"triggerChange\"\n [disable]=\"disableEndTime\"\n ></mis-timepicker>\n</div>\n", styles: [".rangepicker-container{display:flex;gap:1rem;align-items:center}p{margin:0;display:inline-flex;align-items:center}\n"] }]
203
- }], () => [{ type: i0.ChangeDetectorRef }], { inputWidth: [{
204
- type: Input
205
- }], dropdownWidth: [{
206
- type: Input
207
- }], height: [{
208
- type: Input
209
- }], timezone: [{
210
- type: Input
211
- }], startDateEpoch: [{
212
- type: Input
213
- }], endDateEpoch: [{
214
- type: Input
215
- }], givenStartTime: [{
216
- type: Input
217
- }], givenEndTime: [{
218
- type: Input
219
- }], clockFormat: [{
220
- type: Input
221
- }], interval: [{
222
- type: Input
223
- }], showTooltip: [{
224
- type: Input
225
- }], direction: [{
226
- type: Input
227
- }], gap: [{
228
- type: Input
229
- }], disableStartTime: [{
230
- type: Input
231
- }], disableEndTime: [{
232
- type: Input
233
- }], timeRangeEmitter: [{
234
- type: Output
235
- }] }); })();
275
+ args: [{ selector: "mis-timerangepicker", template: "<div class=\"rangepicker-container\" [ngStyle]=\"{'flexDirection': direction(), 'gap': gap()}\">\n <mis-timepicker\n [clockFormat]=\"clockFormat()\"\n [interval]=\"interval()\"\n [dateAsEpoch]=\"startDateEpoch()\"\n [firstInterval]=\"firstIntervals().start\"\n (timeEmitter)=\"startPickerHandler($event)\"\n [timezone]=\"timezone()\"\n [height]=\"height()\"\n [inputWidth]=\"inputWidth()\"\n [dropdownWidth]=\"dropdownWidth()\"\n [showTooltip]=\"showTooltip()\"\n [givenTime]=\"givenStartTime()\"\n [disable]=\"disableStartTime()\"\n ></mis-timepicker>\n <p *ngIf=\"direction() === 'row'\">-</p>\n <mis-timepicker\n [clockFormat]=\"clockFormat()\"\n [interval]=\"interval()\"\n [dateAsEpoch]=\"endDateEpoch()\"\n [firstInterval]=\"firstIntervals().end\"\n (timeEmitter)=\"endPickerHandler($event)\"\n [rangeValidity]=\"rangeValidity()\"\n [timezone]=\"timezone()\"\n [height]=\"height()\"\n [inputWidth]=\"inputWidth()\"\n [dropdownWidth]=\"dropdownWidth()\"\n [showTooltip]=\"showTooltip()\"\n [givenTime]=\"givenEndTime()\"\n [triggerChange]=\"triggerChange()\"\n [disable]=\"disableEndTime()\"\n ></mis-timepicker>\n</div>\n\n", styles: [".rangepicker-container{display:flex;gap:1rem;align-items:center}p{margin:0;display:inline-flex;align-items:center}\n"] }]
276
+ }], () => [], null); })();
236
277
  (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(TimeRangePickerComponent, { className: "TimeRangePickerComponent" }); })();
237
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"timerangepicker.component.js","sourceRoot":"","sources":["../../../../projects/mis-components/timerangepicker/timerangepicker.component.ts","../../../../projects/mis-components/timerangepicker/timerangepicker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, ChangeDetectorRef, Output, EventEmitter } from \"@angular/core\";\nimport { ITimeRange, ITime, TDirection } from \"./timerange.namespace\";\nimport dayjs from 'dayjs';\nimport timezone from 'dayjs/plugin/timezone';\nimport utc from 'dayjs/plugin/utc';\n\ndayjs.extend(utc);\ndayjs.extend(timezone);\n@Component({\n  selector: \"mis-timerangepicker\",\n  templateUrl: \"./timerangepicker.component.html\",\n  styleUrls: [\"./timerangepicker.component.scss\"]\n})\nexport class TimeRangePickerComponent {\n  @Input() inputWidth: string = \"100px\";\n  @Input() dropdownWidth?: string;\n  @Input() height: string = \"46px\";\n  @Input() timezone: string = \"Asia/Kolkata\";\n  @Input() startDateEpoch: number = dayjs.tz(dayjs(), this.timezone).valueOf();\n  @Input() endDateEpoch: number = dayjs.tz(dayjs(), this.timezone).valueOf();\n  @Input() givenStartTime: number;\n  @Input() givenEndTime: number;\n  @Input() clockFormat: number = 12;\n  @Input() interval: number = 15;\n  @Input() showTooltip: boolean = true;\n  @Input() direction: TDirection = 'row';\n  @Input() gap: string = '1rem';\n  @Input() disableStartTime: boolean = false;\n  @Input() disableEndTime: boolean = false;\n  @Output() timeRangeEmitter = new EventEmitter<ITimeRange>();\n\n  startDate!: string;\n  endDate!: string;\n  currDate!: string;\n  timeFormat!: string;\n  firstIntervalForStartPicker: number = dayjs().valueOf();\n  firstIntervalForEndPicker: number = dayjs().valueOf();\n  startTime!: ITime;\n  endTime!: ITime;\n  rangeValidity: boolean = true;\n  triggerChange: boolean = true;\n\n  constructor(private cdr: ChangeDetectorRef) {}\n\n  ngOnInit() {}\n\n  ngOnChanges() {\n    this.timeFormat = this.clockFormat === 12 ? \"hh:mm a\" : \"HH:mm\";\n    this.startDate = dayjs.tz(this.startDateEpoch, this.timezone).format(\"DD-MM-YYYY\");\n    this.endDate = dayjs.tz(this.endDateEpoch, this.timezone).format(\"DD-MM-YYYY\");\n    this.currDate = dayjs.tz(dayjs(), this.timezone).format(\"DD-MM-YYYY\");\n    this.setFirstIntervals();\n  }\n\n  // calculate the first interval of the picker\n  setFirstIntervals(): void {\n    const minutes = dayjs.tz(dayjs(), this.timezone).minute();\n    const offset = this.interval - (minutes % this.interval);\n\n    // start date, 22 MAY ===  current date, 22 MAY\n    if( this.startDate === this.currDate ){\n      const currentTime = dayjs.tz(dayjs(), this.timezone).valueOf();\n\n      // start date, 22 MAY  === current date, 22 MAY === end date, 22 MAY\n      if(this.startDate === this.endDate){\n\n        // current time is in last interval\n        if(currentTime >= dayjs.tz(this.startDateEpoch, this.timezone).endOf(\"d\").subtract(this.interval,\"m\").valueOf()){\n          this.firstIntervalForStartPicker = currentTime;\n          this.firstIntervalForEndPicker =  dayjs.tz(this.endDateEpoch, this.timezone).endOf(\"d\").valueOf();\n        }\n        // current time isn't in last interval\n        else {\n          this.firstIntervalForStartPicker = dayjs.tz(dayjs(), this.timezone).add(offset, \"m\").valueOf();\n          this.firstIntervalForEndPicker =  dayjs.tz(dayjs(), this.timezone).add(offset, \"m\").add(this.interval, \"m\").valueOf();\n        }\n      } \n      // start date, 22 MAY === current date, 22 MAY !== end date, 30 MAY\n      else {\n        // current time is in last interval\n        if(currentTime >= dayjs.tz(this.startDateEpoch, this.timezone).endOf(\"d\").subtract(this.interval,\"m\").valueOf()){\n          this.firstIntervalForStartPicker = currentTime;\n          this.firstIntervalForEndPicker =  dayjs.tz(this.endDateEpoch, this.timezone).endOf(\"d\").valueOf();\n        }\n        // current time isn't in last interval\n        else {\n          this.firstIntervalForStartPicker = dayjs.tz(dayjs(), this.timezone).add(offset, \"m\").valueOf();\n          this.firstIntervalForEndPicker =  dayjs.tz(this.endDateEpoch, this.timezone).valueOf();\n        }\n      }\n    }\n    // start date, 30 MAY !== current date, 22 MAY\n    else {\n      // start date === end Date\n      if(this.startDate === this.endDate){\n        this.firstIntervalForStartPicker = dayjs.tz(this.startDateEpoch, this.timezone).startOf(\"d\").valueOf();\n        this.firstIntervalForEndPicker =  dayjs.tz(this.endDateEpoch, this.timezone).add(this.interval, \"m\").valueOf();\n      } \n      // start date !== end date\n      else {\n        this.firstIntervalForStartPicker = dayjs.tz(this.startDateEpoch, this.timezone).startOf(\"d\").valueOf();\n        this.firstIntervalForEndPicker =  dayjs.tz(this.startDateEpoch, this.timezone).startOf(\"d\").valueOf();\n      }\n    }\n\n    if(this.givenStartTime)\n      this.firstIntervalForStartPicker = this.givenStartTime;\n   \n    if(this.givenEndTime)\n      this.firstIntervalForEndPicker = this.givenEndTime;\n      \n    this.startTime = {\n      valid: true,\n      time: dayjs.tz(this.firstIntervalForStartPicker, this.timezone).format(this.timeFormat),\n      epoch: dayjs.tz(this.firstIntervalForStartPicker, this.timezone).valueOf()\n    };\n\n    this.endTime = {\n      valid: true,\n      time: dayjs.tz(this.firstIntervalForEndPicker, this.timezone).format(this.timeFormat),\n      epoch: dayjs.tz(this.firstIntervalForEndPicker, this.timezone).valueOf()\n    };\n  }\n\n  emitTimeRange(data: ITimeRange): void {\n    this.timeRangeEmitter.emit(data);\n  }\n\n  //handlers catch the emitted values and run validation\n  startPickerHandler(time: ITime): void {\n    this.startTime = time;\n    this.rangeValidity = true;\n    // if the start time changes and the start date is the same as the end date\n    // and the start time >=  end time\n    // update the first interval of end picker according to the time set in start picker\n    if (this.startDate === this.endDate) {\n      let minutes = dayjs.tz(this.startTime.time, this.timeFormat, this.timezone).minute();\n      let offset = this.interval - (minutes % this.interval);\n      this.firstIntervalForEndPicker = dayjs.tz(`${this.startDate} ${this.startTime.time}`, `'DD-MM-YYYY' ${this.timeFormat}`, this.timezone)\n        .add(offset, \"m\")\n        .valueOf();\n\n      // if the first interval == 12:00am, set it as 11:59pm\n      const intervalAsString = dayjs.tz(this.firstIntervalForEndPicker, this.timezone).format(this.timeFormat);\n      const endOfDayAsString = dayjs.tz(`${this.startDate}`, `DD-MM-YYYY`, this.timezone).endOf(\"d\").add(1, \"m\").format(this.timeFormat);\n      if (intervalAsString === endOfDayAsString) {\n        this.firstIntervalForEndPicker = dayjs.tz(`${this.startDate} ${this.startTime.time}`, `'DD-MM-YYYY' ${this.timeFormat}`, this.timezone).endOf(\"d\").valueOf();\n      }\n\n    } else {\n        const validity =\n        this.checkTimeValidity(this.startTime.time.trim(), this.startDateEpoch) &&\n        this.checkTimeValidity(this.endTime.time.trim(), this.endDateEpoch);\n\n        this.rangeValidation(validity);\n        this.emitTimeRange({\n          valid: validity && this.rangeValidity,\n          startTime: this.startTime.time,\n          endTime: this.endTime.time,\n          startEpoch: dayjs.tz(`${this.startDate} ${this.startTime.time}`, `DD-MM-YYYY ${this.timeFormat}`, this.timezone).valueOf(),\n          endEpoch: dayjs.tz(`${this.endDate} ${this.endTime.time}`, `DD-MM-YYYY ${this.timeFormat}`, this.timezone).valueOf()\n        });\n    }\n\n    this.triggerChange = !this.triggerChange;\n  }\n\n  endPickerHandler(time: ITime): void {\n    this.endTime = time;\n\n    const validity =\n      this.checkTimeValidity(this.startTime.time.trim(), this.startDateEpoch) && this.checkTimeValidity(this.endTime.time.trim(), this.endDateEpoch);\n\n    this.rangeValidation(validity);\n    this.emitTimeRange({\n      valid: validity && this.rangeValidity,\n      startTime: this.startTime.time,\n      endTime: this.endTime.time,\n      startEpoch: dayjs.tz(`${this.startDate} ${this.startTime.time}`, `DD-MM-YYYY ${this.timeFormat}`, this.timezone).valueOf(),\n      endEpoch: dayjs.tz(`${this.endDate} ${this.endTime.time}`, `DD-MM-YYYY ${this.timeFormat}`, this.timezone).valueOf()\n    });\n  }\n\n  checkTimeValidity(time: string, date: number): 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 = dayjs.tz(`${dayjs.tz(date, this.timezone).format(\"DD-MM-YYYY\")} ${time}`, `'DD-MM-YYYY' ${this.timeFormat}`, this.timezone);\n    let flag: boolean = false;\n\n    // if the first interval is set to the start of the day\n    // then we don't check its validity against the current time\n    if ((this.givenStartTime && this.givenEndTime) || (this.startDate !== this.endDate && this.startDate !== this.currDate)) {\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  // validates end picker's input according to the start picker's input\n  rangeValidation(validity: boolean) {\n    if (validity && this.startDate === this.endDate) {\n      const startdayjs = dayjs.tz(this.startTime.time, this.timeFormat, this.timezone);\n      const enddayjs = dayjs.tz(this.endTime.time, this.timeFormat, this.timezone);\n      this.rangeValidity = enddayjs.diff(startdayjs, \"m\") >= 1 ? true : false;\n      this.cdr.detectChanges();\n    }\n  }\n}\n\n","<div class=\"rangepicker-container\" [ngStyle]=\"{'flexDirection': direction, 'gap': gap}\">\n  <mis-timepicker\n    [clockFormat]=\"clockFormat\"\n    [interval]=\"interval\"\n    [dateAsEpoch]=\"startDateEpoch\"\n    [firstInterval]=\"firstIntervalForStartPicker\"\n    (timeEmitter)=\"startPickerHandler($event)\"\n    [timezone]=\"timezone\"\n    [height]=\"height\"\n    [inputWidth]=\"inputWidth\"\n    [dropdownWidth]=\"dropdownWidth\"\n    [showTooltip]=\"showTooltip\"\n    [givenTime]=\"givenStartTime\"\n    [disable]=\"disableStartTime\"\n  ></mis-timepicker>\n  <p *ngIf=\"direction === 'row'\">-</p>\n  <mis-timepicker\n    [clockFormat]=\"clockFormat\"\n    [interval]=\"interval\"\n    [dateAsEpoch]=\"endDateEpoch\"\n    [firstInterval]=\"firstIntervalForEndPicker\"\n    (timeEmitter)=\"endPickerHandler($event)\"\n    [rangeValidity]=\"rangeValidity\"\n    [timezone]=\"timezone\"\n    [height]=\"height\"\n    [inputWidth]=\"inputWidth\"\n    [dropdownWidth]=\"dropdownWidth\"\n    [showTooltip]=\"showTooltip\"\n    [givenTime]=\"givenEndTime\"\n    [triggerChange]=\"triggerChange\"\n    [disable]=\"disableEndTime\"\n  ></mis-timepicker>\n</div>\n"]}
278
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"timerangepicker.component.js","sourceRoot":"","sources":["../../../../projects/mis-components/timerangepicker/timerangepicker.component.ts","../../../../projects/mis-components/timerangepicker/timerangepicker.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, input, output, signal, computed, effect, OnInit } from \"@angular/core\";\nimport { ITimeRange, ITime, TDirection } from \"./timerange.namespace\";\nimport dayjs from 'dayjs';\nimport timezone from 'dayjs/plugin/timezone';\nimport utc from 'dayjs/plugin/utc';\n\ndayjs.extend(utc);\ndayjs.extend(timezone);\n\n@Component({\n  selector: \"mis-timerangepicker\",\n  templateUrl: \"./timerangepicker.component.html\", // Corrected file name\n  styleUrls: [\"./timerangepicker.component.scss\"]\n})\nexport class TimeRangePickerComponent implements OnInit {\n  // --- Input Signals (read-only) ---\n  inputWidth = input<string>(\"100px\");\n  dropdownWidth = input<string | undefined>(undefined);\n  height = input<string>(\"46px\");\n  timezone = input<string>(\"Asia/Kolkata\");\n  startDateEpoch = input<number>(dayjs.tz(dayjs(), this.timezone()).valueOf());\n  endDateEpoch = input<number>(dayjs.tz(dayjs(), this.timezone()).valueOf());\n  givenStartTime = input<number | undefined>(undefined);\n  givenEndTime = input<number | undefined>(undefined);\n  clockFormat = input<number>(12);\n  interval = input<number>(15);\n  showTooltip = input<boolean>(true);\n  direction = input<TDirection>('row');\n  gap = input<string>('1rem');\n  disableStartTime = input<boolean>(false);\n  disableEndTime = input<boolean>(false);\n  \n  // --- Output Signal ---\n  timeRangeEmitter = output<ITimeRange>();\n\n  // --- Internal Writable Signals ---\n  startTime = signal<ITime | null>(null);\n  endTime = signal<ITime | null>(null);\n  rangeValidity = signal<boolean>(true);\n  triggerChange = signal<boolean>(true);\n  private _firstIntervals = signal<{ start: number, end: number }>({ start: 0, end: 0 });\n  private _isInitializing = false;\n\n  // --- Computed Signals (Derived State) ---\n  firstIntervals = computed(() => this._firstIntervals()); // A public computed signal to access the writable one\n  \n  // Helper methods instead of computed signals to avoid signal write conflicts\n  private getTimeFormat(): string {\n    return this.clockFormat() === 12 ? \"hh:mm a\" : \"HH:mm\";\n  }\n  \n  private getStartDate(): string {\n    return dayjs.tz(this.startDateEpoch(), this.timezone()).format(\"DD-MM-YYYY\");\n  }\n  \n  private getEndDate(): string {\n    return dayjs.tz(this.endDateEpoch(), this.timezone()).format(\"DD-MM-YYYY\");\n  }\n  \n  private getCurrDate(): string {\n    return dayjs.tz(dayjs(), this.timezone()).format(\"DD-MM-YYYY\");\n  }\n  \n  constructor() {\n    // Simple constructor - no effects here\n  }\n\n  ngOnInit(): void {\n    // Initialize the component once\n    this.initializeComponent();\n  }\n\n  private initializeComponent(): void {\n    this._isInitializing = true;\n    \n    this.setFirstIntervals();\n    const firstIntervals = this._firstIntervals();\n\n    this.startTime.set({\n      valid: true,\n      time: dayjs.tz(firstIntervals.start, this.timezone()).format(this.getTimeFormat()),\n      epoch: dayjs.tz(firstIntervals.start, this.timezone()).valueOf()\n    });\n    \n    // Ensure end time is always after start time\n    let endTimeEpoch = firstIntervals.end;\n    const startTimeEpoch = firstIntervals.start;\n    \n    // If end time is same or before start time, add one interval to end time\n    if (endTimeEpoch <= startTimeEpoch) {\n      endTimeEpoch = dayjs.tz(startTimeEpoch, this.timezone()).add(this.interval(), 'm').valueOf();\n      \n      // Update the firstIntervals to reflect the adjusted end time\n      this._firstIntervals.set({\n        start: firstIntervals.start,\n        end: endTimeEpoch\n      });\n    }\n    \n    this.endTime.set({\n      valid: true,\n      time: dayjs.tz(endTimeEpoch, this.timezone()).format(this.getTimeFormat()),\n      epoch: endTimeEpoch\n    });\n    \n    this._isInitializing = false;\n  }\n\n  // calculate the first interval of the picker\n  private setFirstIntervals(): void {\n    let firstIntervalForStartPicker: number;\n    let firstIntervalForEndPicker: number;\n\n    const minutes = dayjs.tz(dayjs(), this.timezone()).minute();\n    const offset = this.interval() - (minutes % this.interval());\n    const currentTime = dayjs.tz(dayjs(), this.timezone()).valueOf();\n\n    if( this.getStartDate() === this.getCurrDate() ){\n      if(this.getStartDate() === this.getEndDate()){\n        if(currentTime >= dayjs.tz(this.startDateEpoch(), this.timezone()).endOf(\"d\").subtract(this.interval(),\"m\").valueOf()){\n          firstIntervalForStartPicker = currentTime;\n          firstIntervalForEndPicker = dayjs.tz(this.endDateEpoch(), this.timezone()).endOf(\"d\").valueOf();\n        } else {\n          firstIntervalForStartPicker = dayjs.tz(dayjs(), this.timezone()).add(offset, \"m\").valueOf();\n          // For same date, end picker should start from beginning of day to avoid validation issues\n          firstIntervalForEndPicker = dayjs.tz(this.endDateEpoch(), this.timezone()).startOf(\"d\").valueOf();\n        }\n      } else {\n        if(currentTime >= dayjs.tz(this.startDateEpoch(), this.timezone()).endOf(\"d\").subtract(this.interval(),\"m\").valueOf()){\n          firstIntervalForStartPicker = currentTime;\n          firstIntervalForEndPicker = dayjs.tz(this.endDateEpoch(), this.timezone()).endOf(\"d\").valueOf();\n        } else {\n          firstIntervalForStartPicker = dayjs.tz(dayjs(), this.timezone()).add(offset, \"m\").valueOf();\n          firstIntervalForEndPicker = dayjs.tz(this.endDateEpoch(), this.timezone()).startOf(\"d\").valueOf();\n        }\n      }\n      } else {\n        if(this.getStartDate() === this.getEndDate()){\n        firstIntervalForStartPicker = dayjs.tz(this.startDateEpoch(), this.timezone()).startOf(\"d\").valueOf();\n        firstIntervalForEndPicker = dayjs.tz(this.endDateEpoch(), this.timezone()).add(this.interval(), \"m\").valueOf();\n      } else {\n        firstIntervalForStartPicker = dayjs.tz(this.startDateEpoch(), this.timezone()).startOf(\"d\").valueOf();\n        firstIntervalForEndPicker = dayjs.tz(this.endDateEpoch(), this.timezone()).startOf(\"d\").valueOf();\n      }\n    }\n\n    if(this.givenStartTime()) {\n      firstIntervalForStartPicker = this.givenStartTime()!;\n    }\n    \n    if(this.givenEndTime()) {\n      firstIntervalForEndPicker = this.givenEndTime()!;\n    }\n      \n    this._firstIntervals.set({ start: firstIntervalForStartPicker, end: firstIntervalForEndPicker });\n  }\n\n  // --- Public Methods ---\n  emitTimeRange(data: ITimeRange): void {\n    this.timeRangeEmitter.emit(data);\n  }\n\n  startPickerHandler(time: ITime): void {\n    this.startTime.set(time);\n    this.rangeValidity.set(true);\n    \n    // Don't emit during initialization\n    if (this._isInitializing) {\n      return;\n    }\n\n    // Calculate start time epoch for comparison\n    const startTimeEpoch = dayjs.tz(`${this.getStartDate()} ${this.startTime()!.time}`, `DD-MM-YYYY ${this.getTimeFormat()}`, this.timezone()).valueOf();\n    const endTimeEpoch = dayjs.tz(`${this.getEndDate()} ${this.endTime()!.time}`, `DD-MM-YYYY ${this.getTimeFormat()}`, this.timezone()).valueOf();\n\n    // Auto-adjust end time if start time >= end time (for both same and different dates)\n    if (startTimeEpoch >= endTimeEpoch) {\n      // Calculate new end time as start time + interval\n      let newEndTimeEpoch = dayjs.tz(startTimeEpoch, this.timezone()).add(this.interval(), \"m\").valueOf();\n      \n      // If same date, check if the new end time would go beyond end of day\n      if (this.getStartDate() === this.getEndDate()) {\n        const endOfDay = dayjs.tz(this.startDateEpoch(), this.timezone()).endOf(\"d\").valueOf();\n        if (newEndTimeEpoch > endOfDay) {\n          // NEW: Set end time to 11:59 PM (end of day) when start time is last interval\n          newEndTimeEpoch = endOfDay;\n        }\n      }\n      \n      // Update the end time signal\n      this.endTime.set({\n        valid: true,\n        time: dayjs.tz(newEndTimeEpoch, this.timezone()).format(this.getTimeFormat()),\n        epoch: newEndTimeEpoch\n      });\n      \n      // Update the firstIntervals to reflect the new end time\n      this._firstIntervals.set({ \n        start: this._firstIntervals().start, \n        end: newEndTimeEpoch \n      });\n    }\n\n    // NEW: Update end timepicker's firstInterval when both timepickers are on the same day\n    // BUT only if there was a conflict (start >= end) or if we need to adjust for end of day\n    if (this.getStartDate() === this.getEndDate()) {\n      // Only update firstInterval if there was a conflict or if we're at end of day\n      if (startTimeEpoch >= endTimeEpoch) {\n        // Calculate the next interval after the selected start time\n        let nextIntervalAfterStart = dayjs.tz(startTimeEpoch, this.timezone()).add(this.interval(), \"m\").valueOf();\n        \n        // NEW: If next interval would go beyond end of day, use end of day instead\n        const endOfDay = dayjs.tz(this.startDateEpoch(), this.timezone()).endOf(\"d\").valueOf();\n        if (nextIntervalAfterStart > endOfDay) {\n          nextIntervalAfterStart = endOfDay;\n        }\n        \n        // Update the firstIntervals to make end timepicker dropdown start from next interval after start time\n        this._firstIntervals.set({ \n          start: this._firstIntervals().start, \n          end: nextIntervalAfterStart \n        });\n      }\n      // If start < end, don't update firstIntervals - let the end timepicker keep its current dropdown\n    }\n\n    // Always validate and emit the time range\n    const validity =\n      this.checkTimeValidity(this.startTime()!.time.trim(), this.startDateEpoch()) &&\n      this.checkTimeValidity(this.endTime()!.time.trim(), this.endDateEpoch());\n\n    this.rangeValidation(validity);\n    this.emitTimeRange({\n      valid: validity && this.rangeValidity(),\n      startTime: this.startTime()!.time,\n      endTime: this.endTime()!.time,\n      startEpoch: dayjs.tz(`${this.getStartDate()} ${this.startTime()!.time}`, `DD-MM-YYYY ${this.getTimeFormat()}`, this.timezone()).valueOf(),\n      endEpoch: dayjs.tz(`${this.getEndDate()} ${this.endTime()!.time}`, `DD-MM-YYYY ${this.getTimeFormat()}`, this.timezone()).valueOf()\n    });\n\n    // FIXED: Only trigger change when there was a conflict (start >= end) that required end time update\n    const currentStartTimeEpoch = dayjs.tz(`${this.getStartDate()} ${this.startTime()!.time}`, `DD-MM-YYYY ${this.getTimeFormat()}`, this.timezone()).valueOf();\n    const currentEndTimeEpoch = dayjs.tz(`${this.getEndDate()} ${this.endTime()!.time}`, `DD-MM-YYYY ${this.getTimeFormat()}`, this.timezone()).valueOf();\n    \n    if (currentStartTimeEpoch >= currentEndTimeEpoch) {\n      this.triggerChange.update(value => !value);\n    }\n  }\n\n  endPickerHandler(time: ITime): void {\n    this.endTime.set(time);\n    \n    // Don't emit during initialization\n    if (this._isInitializing) {\n      return;\n    }\n\n    const validity =\n      this.checkTimeValidity(this.startTime()!.time.trim(), this.startDateEpoch()) && \n      this.checkTimeValidity(this.endTime()!.time.trim(), this.endDateEpoch());\n\n    this.rangeValidation(validity);\n    this.emitTimeRange({\n      valid: validity && this.rangeValidity(),\n      startTime: this.startTime()!.time,\n      endTime: this.endTime()!.time,\n      startEpoch: dayjs.tz(`${this.getStartDate()} ${this.startTime()!.time}`, `DD-MM-YYYY ${this.getTimeFormat()}`, this.timezone()).valueOf(),\n      endEpoch: dayjs.tz(`${this.getEndDate()} ${this.endTime()!.time}`, `DD-MM-YYYY ${this.getTimeFormat()}`, this.timezone()).valueOf()\n    });\n  }\n\n  checkTimeValidity(time: string, date: number): 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 = dayjs.tz(`${dayjs.tz(date, this.timezone()).format(\"DD-MM-YYYY\")} ${time}`, `'DD-MM-YYYY' ${this.getTimeFormat()}`, this.timezone());\n    let flag: boolean = false;\n\n    if ((this.givenStartTime() && this.givenEndTime()) || (this.getStartDate() !== this.getEndDate() && this.getStartDate() !== this.getCurrDate())) {\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    return flag;\n  }\n\n  rangeValidation(validity: boolean) {\n    if (validity && this.getStartDate() === this.getEndDate()) {\n      const startdayjs = dayjs.tz(this.startTime()!.time, this.getTimeFormat(), this.timezone());\n      const enddayjs = dayjs.tz(this.endTime()!.time, this.getTimeFormat(), this.timezone());\n      this.rangeValidity.set(enddayjs.diff(startdayjs, \"m\") >= 1);\n    }\n  }\n}\n\n\n","<div class=\"rangepicker-container\" [ngStyle]=\"{'flexDirection': direction(), 'gap': gap()}\">\n  <mis-timepicker\n    [clockFormat]=\"clockFormat()\"\n    [interval]=\"interval()\"\n    [dateAsEpoch]=\"startDateEpoch()\"\n    [firstInterval]=\"firstIntervals().start\"\n    (timeEmitter)=\"startPickerHandler($event)\"\n    [timezone]=\"timezone()\"\n    [height]=\"height()\"\n    [inputWidth]=\"inputWidth()\"\n    [dropdownWidth]=\"dropdownWidth()\"\n    [showTooltip]=\"showTooltip()\"\n    [givenTime]=\"givenStartTime()\"\n    [disable]=\"disableStartTime()\"\n  ></mis-timepicker>\n  <p *ngIf=\"direction() === 'row'\">-</p>\n  <mis-timepicker\n    [clockFormat]=\"clockFormat()\"\n    [interval]=\"interval()\"\n    [dateAsEpoch]=\"endDateEpoch()\"\n    [firstInterval]=\"firstIntervals().end\"\n    (timeEmitter)=\"endPickerHandler($event)\"\n    [rangeValidity]=\"rangeValidity()\"\n    [timezone]=\"timezone()\"\n    [height]=\"height()\"\n    [inputWidth]=\"inputWidth()\"\n    [dropdownWidth]=\"dropdownWidth()\"\n    [showTooltip]=\"showTooltip()\"\n    [givenTime]=\"givenEndTime()\"\n    [triggerChange]=\"triggerChange()\"\n    [disable]=\"disableEndTime()\"\n  ></mis-timepicker>\n</div>\n\n"]}