mis-crystal-design-system 18.1.7-signal-16-test-2 → 18.1.7

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 (38) hide show
  1. package/async-search-dropdown/async-dropdown.component.d.ts +44 -3
  2. package/daterangepicker_v2/tz-drp-container/tz-drp-container.component.d.ts +9 -2
  3. package/esm2022/async-search-dropdown/async-dropdown.component.mjs +147 -37
  4. package/esm2022/datepicker_v2/tz-dp-container/tz-dp-container.component.mjs +35 -22
  5. package/esm2022/daterangepicker_v2/tz-drp-container/tz-drp-container.component.mjs +270 -187
  6. package/esm2022/dynamic-form/dynamic-form.component.mjs +30 -21
  7. package/esm2022/loader/loader.component.mjs +12 -6
  8. package/esm2022/slider/slider.component.mjs +2 -2
  9. package/esm2022/table/sort-icons.directive.mjs +24 -5
  10. package/esm2022/table/table.component.mjs +200 -93
  11. package/esm2022/table/table.module.mjs +7 -5
  12. package/esm2022/timepicker/timepicker.component.mjs +41 -14
  13. package/esm2022/timerangepicker/timerangepicker.component.mjs +73 -23
  14. package/fesm2022/mis-crystal-design-system-async-search-dropdown.mjs +146 -36
  15. package/fesm2022/mis-crystal-design-system-async-search-dropdown.mjs.map +1 -1
  16. package/fesm2022/mis-crystal-design-system-datepicker_v2.mjs +34 -21
  17. package/fesm2022/mis-crystal-design-system-datepicker_v2.mjs.map +1 -1
  18. package/fesm2022/mis-crystal-design-system-daterangepicker_v2.mjs +269 -186
  19. package/fesm2022/mis-crystal-design-system-daterangepicker_v2.mjs.map +1 -1
  20. package/fesm2022/mis-crystal-design-system-dynamic-form.mjs +29 -20
  21. package/fesm2022/mis-crystal-design-system-dynamic-form.mjs.map +1 -1
  22. package/fesm2022/mis-crystal-design-system-loader.mjs +11 -5
  23. package/fesm2022/mis-crystal-design-system-loader.mjs.map +1 -1
  24. package/fesm2022/mis-crystal-design-system-slider.mjs +2 -2
  25. package/fesm2022/mis-crystal-design-system-slider.mjs.map +1 -1
  26. package/fesm2022/mis-crystal-design-system-table.mjs +227 -99
  27. package/fesm2022/mis-crystal-design-system-table.mjs.map +1 -1
  28. package/fesm2022/mis-crystal-design-system-timepicker.mjs +40 -13
  29. package/fesm2022/mis-crystal-design-system-timepicker.mjs.map +1 -1
  30. package/fesm2022/mis-crystal-design-system-timerangepicker.mjs +72 -22
  31. package/fesm2022/mis-crystal-design-system-timerangepicker.mjs.map +1 -1
  32. package/loader/loader.component.d.ts +7 -1
  33. package/package.json +25 -25
  34. package/styles/mis-old-icon-styles.scss +498 -0
  35. package/table/table.component.d.ts +16 -4
  36. package/table/table.module.d.ts +2 -1
  37. package/timepicker/timepicker.component.d.ts +3 -1
  38. package/timerangepicker/timerangepicker.component.d.ts +5 -1
@@ -1,5 +1,5 @@
1
1
  import * as i0 from '@angular/core';
2
- import { input, output, signal, computed, Component, NgModule } from '@angular/core';
2
+ import { input, output, signal, computed, effect, untracked, Component, NgModule } from '@angular/core';
3
3
  import dayjs from 'dayjs';
4
4
  import timezone from 'dayjs/plugin/timezone';
5
5
  import utc from 'dayjs/plugin/utc';
@@ -48,6 +48,8 @@ class TimeRangePickerComponent {
48
48
  this.gap = input('1rem');
49
49
  this.disableStartTime = input(false);
50
50
  this.disableEndTime = input(false);
51
+ this.fontSize = input("14px");
52
+ this.disableUserInput = input(false);
51
53
  // --- Output Signal ---
52
54
  this.timeRangeEmitter = output();
53
55
  // --- Internal Writable Signals ---
@@ -57,13 +59,55 @@ class TimeRangePickerComponent {
57
59
  this.triggerChange = signal(true);
58
60
  this._firstIntervals = signal({ start: 0, end: 0 });
59
61
  this._isInitializing = false;
62
+ this._previousStartDateEpoch = null;
63
+ this._previousEndDateEpoch = null;
60
64
  // --- Computed Signals (Derived State) ---
61
65
  this.firstIntervals = computed(() => this._firstIntervals()); // A public computed signal to access the writable one
62
- // Simple constructor - no effects here
66
+ // Effect to watch for changes in startDateEpoch and endDateEpoch
67
+ effect(() => {
68
+ // ONLY track these two signals - this is the only line that creates dependencies
69
+ const currentStartDate = this.startDateEpoch();
70
+ const currentEndDate = this.endDateEpoch();
71
+ // Use untracked() for everything else to prevent infinite loops
72
+ untracked(() => {
73
+ // Skip if component is initializing
74
+ if (this._isInitializing) {
75
+ return;
76
+ }
77
+ // Skip if component hasn't been initialized yet
78
+ if (!this.startTime() || !this.endTime()) {
79
+ return;
80
+ }
81
+ // Skip if dates haven't actually changed (prevents initial double-run)
82
+ if (this._previousStartDateEpoch === currentStartDate &&
83
+ this._previousEndDateEpoch === currentEndDate) {
84
+ return;
85
+ }
86
+ // Update previous values
87
+ this._previousStartDateEpoch = currentStartDate;
88
+ this._previousEndDateEpoch = currentEndDate;
89
+ // Reinitialize and emit when date inputs change
90
+ this.initializeComponent();
91
+ // Emit the updated time range
92
+ const validity = this.checkTimeValidity(this.startTime().time.trim(), this.startDateEpoch()) &&
93
+ this.checkTimeValidity(this.endTime().time.trim(), this.endDateEpoch());
94
+ this.rangeValidation(validity);
95
+ this.emitTimeRange({
96
+ valid: validity && this.rangeValidity(),
97
+ startTime: this.startTime().time,
98
+ endTime: this.endTime().time,
99
+ startEpoch: dayjs.tz(`${this.getStartDate()} ${this.startTime().time}`, `DD-MM-YYYY ${this.getTimeFormat()}`, this.timezone()).valueOf(),
100
+ endEpoch: dayjs.tz(`${this.getEndDate()} ${this.endTime().time}`, `DD-MM-YYYY ${this.getTimeFormat()}`, this.timezone()).valueOf()
101
+ });
102
+ });
103
+ }, { allowSignalWrites: true });
63
104
  }
64
105
  ngOnInit() {
65
106
  // Initialize the component once
66
107
  this.initializeComponent();
108
+ // Store initial values to prevent effect from running on first load
109
+ this._previousStartDateEpoch = this.startDateEpoch();
110
+ this._previousEndDateEpoch = this.endDateEpoch();
67
111
  }
68
112
  initializeComponent() {
69
113
  this._isInitializing = true;
@@ -155,15 +199,16 @@ class TimeRangePickerComponent {
155
199
  // Calculate start time epoch for comparison
156
200
  const startTimeEpoch = dayjs.tz(`${this.getStartDate()} ${this.startTime().time}`, `DD-MM-YYYY ${this.getTimeFormat()}`, this.timezone()).valueOf();
157
201
  const endTimeEpoch = dayjs.tz(`${this.getEndDate()} ${this.endTime().time}`, `DD-MM-YYYY ${this.getTimeFormat()}`, this.timezone()).valueOf();
158
- // Auto-adjust end time if start time >= end time (for both same and different dates)
159
- if (startTimeEpoch >= endTimeEpoch) {
202
+ // Auto-adjust end time if start time > end time (for both same and different dates)
203
+ // This ensures end time is always after start time
204
+ if (startTimeEpoch > endTimeEpoch) {
160
205
  // Calculate new end time as start time + interval
161
206
  let newEndTimeEpoch = dayjs.tz(startTimeEpoch, this.timezone()).add(this.interval(), "m").valueOf();
162
207
  // If same date, check if the new end time would go beyond end of day
163
208
  if (this.getStartDate() === this.getEndDate()) {
164
209
  const endOfDay = dayjs.tz(this.startDateEpoch(), this.timezone()).endOf("d").valueOf();
165
210
  if (newEndTimeEpoch > endOfDay) {
166
- // NEW: Set end time to 11:59 PM (end of day) when start time is last interval
211
+ // Set end time to 11:59 PM (end of day) when start time is last interval
167
212
  newEndTimeEpoch = endOfDay;
168
213
  }
169
214
  }
@@ -178,26 +223,37 @@ class TimeRangePickerComponent {
178
223
  start: this._firstIntervals().start,
179
224
  end: newEndTimeEpoch
180
225
  });
226
+ // Trigger change to force end timepicker to update its display with the new end time
227
+ // This is necessary when we reset the end time due to conflict
228
+ this.triggerChange.update(value => !value);
181
229
  }
182
- // NEW: Update end timepicker's firstInterval when both timepickers are on the same day
183
- // BUT only if there was a conflict (start >= end) or if we need to adjust for end of day
230
+ // Update end timepicker's firstInterval when both timepickers are on the same day
231
+ // ALWAYS update to ensure dropdown starts from next interval after start time
232
+ // This fixes the bug where selecting an earlier start time doesn't update end picker intervals
233
+ // NOTE: We only update firstInterval (dropdown options), NOT the selected end time value
234
+ // The timepicker component now handles firstInterval changes separately and won't reset chosenTime
184
235
  if (this.getStartDate() === this.getEndDate()) {
185
- // Only update firstInterval if there was a conflict or if we're at end of day
186
- if (startTimeEpoch >= endTimeEpoch) {
236
+ // Only update firstInterval if there's no conflict (start < end)
237
+ // If there's a conflict, it's already handled above and firstInterval was updated there
238
+ if (startTimeEpoch < endTimeEpoch) {
187
239
  // Calculate the next interval after the selected start time
188
240
  let nextIntervalAfterStart = dayjs.tz(startTimeEpoch, this.timezone()).add(this.interval(), "m").valueOf();
189
- // NEW: If next interval would go beyond end of day, use end of day instead
241
+ // If next interval would go beyond end of day, use end of day instead
190
242
  const endOfDay = dayjs.tz(this.startDateEpoch(), this.timezone()).endOf("d").valueOf();
191
243
  if (nextIntervalAfterStart > endOfDay) {
192
244
  nextIntervalAfterStart = endOfDay;
193
245
  }
194
246
  // Update the firstIntervals to make end timepicker dropdown start from next interval after start time
247
+ // This ensures users can always select times between the new start time and the current end time
248
+ // The timepicker component will update the dropdown but preserve the selected end time value
195
249
  this._firstIntervals.set({
196
250
  start: this._firstIntervals().start,
197
251
  end: nextIntervalAfterStart
198
252
  });
253
+ // NOTE: We don't call triggerChange here because we only want to update the dropdown,
254
+ // not reset the selected end time. The timepicker's separate effect for firstInterval
255
+ // will handle updating the dropdown without resetting chosenTime.
199
256
  }
200
- // If start < end, don't update firstIntervals - let the end timepicker keep its current dropdown
201
257
  }
202
258
  // Always validate and emit the time range
203
259
  const validity = this.checkTimeValidity(this.startTime().time.trim(), this.startDateEpoch()) &&
@@ -210,12 +266,6 @@ class TimeRangePickerComponent {
210
266
  startEpoch: dayjs.tz(`${this.getStartDate()} ${this.startTime().time}`, `DD-MM-YYYY ${this.getTimeFormat()}`, this.timezone()).valueOf(),
211
267
  endEpoch: dayjs.tz(`${this.getEndDate()} ${this.endTime().time}`, `DD-MM-YYYY ${this.getTimeFormat()}`, this.timezone()).valueOf()
212
268
  });
213
- // FIXED: Only trigger change when there was a conflict (start >= end) that required end time update
214
- const currentStartTimeEpoch = dayjs.tz(`${this.getStartDate()} ${this.startTime().time}`, `DD-MM-YYYY ${this.getTimeFormat()}`, this.timezone()).valueOf();
215
- const currentEndTimeEpoch = dayjs.tz(`${this.getEndDate()} ${this.endTime().time}`, `DD-MM-YYYY ${this.getTimeFormat()}`, this.timezone()).valueOf();
216
- if (currentStartTimeEpoch >= currentEndTimeEpoch) {
217
- this.triggerChange.update(value => !value);
218
- }
219
269
  }
220
270
  endPickerHandler(time) {
221
271
  this.endTime.set(time);
@@ -256,7 +306,7 @@ class TimeRangePickerComponent {
256
306
  }
257
307
  }
258
308
  static { this.ɵfac = function TimeRangePickerComponent_Factory(__ngFactoryType__) { return new (__ngFactoryType__ || TimeRangePickerComponent)(); }; }
259
- 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) {
309
+ 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"], fontSize: [1, "fontSize"], disableUserInput: [1, "disableUserInput"] }, outputs: { timeRangeEmitter: "timeRangeEmitter" }, decls: 4, vars: 33, consts: [[1, "rangepicker-container", 3, "ngStyle"], [3, "timeEmitter", "clockFormat", "interval", "dateAsEpoch", "firstInterval", "timezone", "height", "inputWidth", "dropdownWidth", "showTooltip", "givenTime", "disable", "disableUserInput", "fontSize"], [4, "ngIf"], [3, "timeEmitter", "clockFormat", "interval", "dateAsEpoch", "firstInterval", "rangeValidity", "timezone", "height", "inputWidth", "dropdownWidth", "showTooltip", "givenTime", "triggerChange", "disable", "disableUserInput", "fontSize"]], template: function TimeRangePickerComponent_Template(rf, ctx) { if (rf & 1) {
260
310
  i0.ɵɵelementStart(0, "div", 0)(1, "mis-timepicker", 1);
261
311
  i0.ɵɵlistener("timeEmitter", function TimeRangePickerComponent_Template_mis_timepicker_timeEmitter_1_listener($event) { return ctx.startPickerHandler($event); });
262
312
  i0.ɵɵelementEnd();
@@ -265,18 +315,18 @@ class TimeRangePickerComponent {
265
315
  i0.ɵɵlistener("timeEmitter", function TimeRangePickerComponent_Template_mis_timepicker_timeEmitter_3_listener($event) { return ctx.endPickerHandler($event); });
266
316
  i0.ɵɵelementEnd()();
267
317
  } if (rf & 2) {
268
- i0.ɵɵproperty("ngStyle", i0.ɵɵpureFunction2(26, _c0, ctx.direction(), ctx.gap()));
318
+ i0.ɵɵproperty("ngStyle", i0.ɵɵpureFunction2(30, _c0, ctx.direction(), ctx.gap()));
269
319
  i0.ɵɵadvance();
270
- 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());
320
+ 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())("disableUserInput", ctx.disableUserInput())("fontSize", ctx.fontSize());
271
321
  i0.ɵɵadvance();
272
322
  i0.ɵɵproperty("ngIf", ctx.direction() === "row");
273
323
  i0.ɵɵadvance();
274
- 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());
324
+ 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())("disableUserInput", ctx.disableUserInput())("fontSize", ctx.fontSize());
275
325
  } }, 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}"] }); }
276
326
  }
277
327
  (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(TimeRangePickerComponent, [{
278
328
  type: Component,
279
- 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"] }]
329
+ 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 [disableUserInput]=\"disableUserInput()\"\n [fontSize]=\"fontSize()\"\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 [disableUserInput]=\"disableUserInput()\"\n [fontSize]=\"fontSize()\"\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"] }]
280
330
  }], () => [], null); })();
281
331
  (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(TimeRangePickerComponent, { className: "TimeRangePickerComponent" }); })();
282
332
 
@@ -1 +1 @@
1
- {"version":3,"file":"mis-crystal-design-system-timerangepicker.mjs","sources":["../../../projects/mis-components/timerangepicker/timerangepicker.component.html","../../../projects/mis-components/timerangepicker/timerangepicker.component.ts","../../../projects/mis-components/timerangepicker/timerangepicker.module.ts","../../../projects/mis-components/timerangepicker/mis-crystal-design-system-timerangepicker.ts"],"sourcesContent":["<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","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","import { NgModule, ModuleWithProviders } from \"@angular/core\";\nimport { CommonModule } from '@angular/common';\nimport { FormsModule } from '@angular/forms';\nimport { TimeRangePickerComponent } from \"./timerangepicker.component\";\nimport { TimePickerModule } from \"mis-crystal-design-system/timepicker\";\n\n@NgModule({\n declarations: [TimeRangePickerComponent],\n imports: [CommonModule, FormsModule, TimePickerModule],\n exports: [TimeRangePickerComponent]\n})\nexport class TimeRangePickerModule {\n static forRoot(): ModuleWithProviders<TimeRangePickerModule> {\n return { ngModule: TimeRangePickerModule, providers: [] };\n }\n}","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"mis-crystal-design-system-timerangepicker.mjs","sources":["../../../projects/mis-components/timerangepicker/timerangepicker.component.html","../../../projects/mis-components/timerangepicker/timerangepicker.component.ts","../../../projects/mis-components/timerangepicker/timerangepicker.module.ts","../../../projects/mis-components/timerangepicker/mis-crystal-design-system-timerangepicker.ts"],"sourcesContent":["<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 [disableUserInput]=\"disableUserInput()\"\n [fontSize]=\"fontSize()\"\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 [disableUserInput]=\"disableUserInput()\"\n [fontSize]=\"fontSize()\"\n ></mis-timepicker>\n</div>\n\n","import { Component, input, output, signal, computed, effect, untracked, 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 fontSize = input<string>(\"14px\");\n disableUserInput = 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 private _previousStartDateEpoch: number | null = null;\n private _previousEndDateEpoch: number | null = null;\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 // Effect to watch for changes in startDateEpoch and endDateEpoch\n effect(() => {\n // ONLY track these two signals - this is the only line that creates dependencies\n const currentStartDate = this.startDateEpoch();\n const currentEndDate = this.endDateEpoch();\n \n // Use untracked() for everything else to prevent infinite loops\n untracked(() => {\n // Skip if component is initializing\n if (this._isInitializing) {\n return;\n }\n \n // Skip if component hasn't been initialized yet\n if (!this.startTime() || !this.endTime()) {\n return;\n }\n \n // Skip if dates haven't actually changed (prevents initial double-run)\n if (this._previousStartDateEpoch === currentStartDate && \n this._previousEndDateEpoch === currentEndDate) {\n return;\n }\n \n // Update previous values\n this._previousStartDateEpoch = currentStartDate;\n this._previousEndDateEpoch = currentEndDate;\n \n // Reinitialize and emit when date inputs change\n this.initializeComponent();\n \n // Emit the updated 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 }, { allowSignalWrites: true });\n }\n\n ngOnInit(): void {\n // Initialize the component once\n this.initializeComponent();\n \n // Store initial values to prevent effect from running on first load\n this._previousStartDateEpoch = this.startDateEpoch();\n this._previousEndDateEpoch = this.endDateEpoch();\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 // This ensures end time is always after start time\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 // 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 // Trigger change to force end timepicker to update its display with the new end time\n // This is necessary when we reset the end time due to conflict\n this.triggerChange.update(value => !value);\n }\n\n // Update end timepicker's firstInterval when both timepickers are on the same day\n // ALWAYS update to ensure dropdown starts from next interval after start time\n // This fixes the bug where selecting an earlier start time doesn't update end picker intervals\n // NOTE: We only update firstInterval (dropdown options), NOT the selected end time value\n // The timepicker component now handles firstInterval changes separately and won't reset chosenTime\n if (this.getStartDate() === this.getEndDate()) {\n // Only update firstInterval if there's no conflict (start < end)\n // If there's a conflict, it's already handled above and firstInterval was updated there\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 // 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 ensures users can always select times between the new start time and the current end time\n // The timepicker component will update the dropdown but preserve the selected end time value\n this._firstIntervals.set({ \n start: this._firstIntervals().start, \n end: nextIntervalAfterStart \n });\n // NOTE: We don't call triggerChange here because we only want to update the dropdown,\n // not reset the selected end time. The timepicker's separate effect for firstInterval\n // will handle updating the dropdown without resetting chosenTime.\n }\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\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","import { NgModule, ModuleWithProviders } from \"@angular/core\";\nimport { CommonModule } from '@angular/common';\nimport { FormsModule } from '@angular/forms';\nimport { TimeRangePickerComponent } from \"./timerangepicker.component\";\nimport { TimePickerModule } from \"mis-crystal-design-system/timepicker\";\n\n@NgModule({\n declarations: [TimeRangePickerComponent],\n imports: [CommonModule, FormsModule, TimePickerModule],\n exports: [TimeRangePickerComponent]\n})\nexport class TimeRangePickerModule {\n static forRoot(): ModuleWithProviders<TimeRangePickerModule> {\n return { ngModule: TimeRangePickerModule, providers: [] };\n }\n}","/**\n * Generated bundle index. Do not edit.\n */\n\nexport * from './index';\n"],"names":[],"mappings":"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"}
@@ -2,6 +2,12 @@ import * as i0 from "@angular/core";
2
2
  export declare class LoaderComponent {
3
3
  /** Controls loader size */
4
4
  mobileView: import("@angular/core").InputSignal<boolean>;
5
+ color: import("@angular/core").InputSignal<string>;
6
+ height: import("@angular/core").InputSignal<string>;
7
+ width: import("@angular/core").InputSignal<string>;
8
+ borderTopColor: import("@angular/core").InputSignal<string>;
9
+ constructor();
10
+ ngOnInit(): void;
5
11
  static ɵfac: i0.ɵɵFactoryDeclaration<LoaderComponent, never>;
6
- static ɵcmp: i0.ɵɵComponentDeclaration<LoaderComponent, "mis-loader", never, { "mobileView": { "alias": "mobileView"; "required": false; "isSignal": true; }; }, {}, never, never, false, never>;
12
+ static ɵcmp: i0.ɵɵComponentDeclaration<LoaderComponent, "mis-loader", never, { "mobileView": { "alias": "mobileView"; "required": false; "isSignal": true; }; "color": { "alias": "color"; "required": false; "isSignal": true; }; "height": { "alias": "height"; "required": false; "isSignal": true; }; "width": { "alias": "width"; "required": false; "isSignal": true; }; "borderTopColor": { "alias": "borderTopColor"; "required": false; "isSignal": true; }; }, {}, never, never, false, never>;
7
13
  }
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "mis-crystal-design-system",
3
- "version": "18.1.7-signal-16-test-2",
3
+ "version": "18.1.7",
4
4
  "peerDependencies": {
5
5
  "@angular/common": "*",
6
6
  "@angular/core": "*",
@@ -40,48 +40,48 @@
40
40
  "esm": "./esm2022/async-search-dropdown/mis-crystal-design-system-async-search-dropdown.mjs",
41
41
  "default": "./fesm2022/mis-crystal-design-system-async-search-dropdown.mjs"
42
42
  },
43
- "./checkbox": {
44
- "types": "./checkbox/index.d.ts",
45
- "esm2022": "./esm2022/checkbox/mis-crystal-design-system-checkbox.mjs",
46
- "esm": "./esm2022/checkbox/mis-crystal-design-system-checkbox.mjs",
47
- "default": "./fesm2022/mis-crystal-design-system-checkbox.mjs"
48
- },
49
- "./button": {
50
- "types": "./button/index.d.ts",
51
- "esm2022": "./esm2022/button/mis-crystal-design-system-button.mjs",
52
- "esm": "./esm2022/button/mis-crystal-design-system-button.mjs",
53
- "default": "./fesm2022/mis-crystal-design-system-button.mjs"
54
- },
55
43
  "./chip": {
56
44
  "types": "./chip/index.d.ts",
57
45
  "esm2022": "./esm2022/chip/mis-crystal-design-system-chip.mjs",
58
46
  "esm": "./esm2022/chip/mis-crystal-design-system-chip.mjs",
59
47
  "default": "./fesm2022/mis-crystal-design-system-chip.mjs"
60
48
  },
49
+ "./checkbox": {
50
+ "types": "./checkbox/index.d.ts",
51
+ "esm2022": "./esm2022/checkbox/mis-crystal-design-system-checkbox.mjs",
52
+ "esm": "./esm2022/checkbox/mis-crystal-design-system-checkbox.mjs",
53
+ "default": "./fesm2022/mis-crystal-design-system-checkbox.mjs"
54
+ },
61
55
  "./datepicker_v2": {
62
56
  "types": "./datepicker_v2/index.d.ts",
63
57
  "esm2022": "./esm2022/datepicker_v2/mis-crystal-design-system-datepicker_v2.mjs",
64
58
  "esm": "./esm2022/datepicker_v2/mis-crystal-design-system-datepicker_v2.mjs",
65
59
  "default": "./fesm2022/mis-crystal-design-system-datepicker_v2.mjs"
66
60
  },
61
+ "./button": {
62
+ "types": "./button/index.d.ts",
63
+ "esm2022": "./esm2022/button/mis-crystal-design-system-button.mjs",
64
+ "esm": "./esm2022/button/mis-crystal-design-system-button.mjs",
65
+ "default": "./fesm2022/mis-crystal-design-system-button.mjs"
66
+ },
67
67
  "./daterangepicker_v2": {
68
68
  "types": "./daterangepicker_v2/index.d.ts",
69
69
  "esm2022": "./esm2022/daterangepicker_v2/mis-crystal-design-system-daterangepicker_v2.mjs",
70
70
  "esm": "./esm2022/daterangepicker_v2/mis-crystal-design-system-daterangepicker_v2.mjs",
71
71
  "default": "./fesm2022/mis-crystal-design-system-daterangepicker_v2.mjs"
72
72
  },
73
- "./dropdown": {
74
- "types": "./dropdown/index.d.ts",
75
- "esm2022": "./esm2022/dropdown/mis-crystal-design-system-dropdown.mjs",
76
- "esm": "./esm2022/dropdown/mis-crystal-design-system-dropdown.mjs",
77
- "default": "./fesm2022/mis-crystal-design-system-dropdown.mjs"
78
- },
79
73
  "./drawer": {
80
74
  "types": "./drawer/index.d.ts",
81
75
  "esm2022": "./esm2022/drawer/mis-crystal-design-system-drawer.mjs",
82
76
  "esm": "./esm2022/drawer/mis-crystal-design-system-drawer.mjs",
83
77
  "default": "./fesm2022/mis-crystal-design-system-drawer.mjs"
84
78
  },
79
+ "./dropdown": {
80
+ "types": "./dropdown/index.d.ts",
81
+ "esm2022": "./esm2022/dropdown/mis-crystal-design-system-dropdown.mjs",
82
+ "esm": "./esm2022/dropdown/mis-crystal-design-system-dropdown.mjs",
83
+ "default": "./fesm2022/mis-crystal-design-system-dropdown.mjs"
84
+ },
85
85
  "./dynamic-form": {
86
86
  "types": "./dynamic-form/index.d.ts",
87
87
  "esm2022": "./esm2022/dynamic-form/mis-crystal-design-system-dynamic-form.mjs",
@@ -202,18 +202,18 @@
202
202
  "esm": "./esm2022/styles/mis-crystal-design-system-styles.mjs",
203
203
  "default": "./fesm2022/mis-crystal-design-system-styles.mjs"
204
204
  },
205
- "./switch": {
206
- "types": "./switch/index.d.ts",
207
- "esm2022": "./esm2022/switch/mis-crystal-design-system-switch.mjs",
208
- "esm": "./esm2022/switch/mis-crystal-design-system-switch.mjs",
209
- "default": "./fesm2022/mis-crystal-design-system-switch.mjs"
210
- },
211
205
  "./table": {
212
206
  "types": "./table/index.d.ts",
213
207
  "esm2022": "./esm2022/table/mis-crystal-design-system-table.mjs",
214
208
  "esm": "./esm2022/table/mis-crystal-design-system-table.mjs",
215
209
  "default": "./fesm2022/mis-crystal-design-system-table.mjs"
216
210
  },
211
+ "./switch": {
212
+ "types": "./switch/index.d.ts",
213
+ "esm2022": "./esm2022/switch/mis-crystal-design-system-switch.mjs",
214
+ "esm": "./esm2022/switch/mis-crystal-design-system-switch.mjs",
215
+ "default": "./fesm2022/mis-crystal-design-system-switch.mjs"
216
+ },
217
217
  "./timepicker": {
218
218
  "types": "./timepicker/index.d.ts",
219
219
  "esm2022": "./esm2022/timepicker/mis-crystal-design-system-timepicker.mjs",