mis-crystal-design-system 18.1.7-signal-16-test → 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.
- package/async-search-dropdown/async-dropdown.component.d.ts +44 -3
- package/daterangepicker_v2/tz-drp-container/tz-drp-container.component.d.ts +9 -2
- package/esm2022/async-search-dropdown/async-dropdown.component.mjs +147 -37
- package/esm2022/datepicker_v2/tz-dp-container/tz-dp-container.component.mjs +35 -22
- package/esm2022/daterangepicker_v2/tz-daterangepicker.directive.mjs +6 -3
- package/esm2022/daterangepicker_v2/tz-drp-container/tz-drp-container.component.mjs +270 -187
- package/esm2022/dynamic-form/dynamic-form.component.mjs +30 -21
- package/esm2022/loader/loader.component.mjs +12 -6
- package/esm2022/slider/slider.component.mjs +2 -2
- package/esm2022/table/sort-icons.directive.mjs +24 -5
- package/esm2022/table/table.component.mjs +200 -93
- package/esm2022/table/table.module.mjs +7 -5
- package/esm2022/timepicker/timepicker.component.mjs +41 -14
- package/esm2022/timerangepicker/timerangepicker.component.mjs +73 -23
- package/fesm2022/mis-crystal-design-system-async-search-dropdown.mjs +146 -36
- package/fesm2022/mis-crystal-design-system-async-search-dropdown.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-datepicker_v2.mjs +34 -21
- package/fesm2022/mis-crystal-design-system-datepicker_v2.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-daterangepicker_v2.mjs +274 -188
- package/fesm2022/mis-crystal-design-system-daterangepicker_v2.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-dynamic-form.mjs +29 -20
- package/fesm2022/mis-crystal-design-system-dynamic-form.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-loader.mjs +11 -5
- package/fesm2022/mis-crystal-design-system-loader.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-slider.mjs +2 -2
- package/fesm2022/mis-crystal-design-system-slider.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-table.mjs +227 -99
- package/fesm2022/mis-crystal-design-system-table.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-timepicker.mjs +40 -13
- package/fesm2022/mis-crystal-design-system-timepicker.mjs.map +1 -1
- package/fesm2022/mis-crystal-design-system-timerangepicker.mjs +72 -22
- package/fesm2022/mis-crystal-design-system-timerangepicker.mjs.map +1 -1
- package/loader/loader.component.d.ts +7 -1
- package/package.json +18 -18
- package/table/table.component.d.ts +16 -4
- package/table/table.module.d.ts +2 -1
- package/timepicker/timepicker.component.d.ts +3 -1
- 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
|
-
//
|
|
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
|
|
159
|
-
|
|
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
|
-
//
|
|
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
|
-
//
|
|
183
|
-
//
|
|
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
|
|
186
|
-
|
|
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
|
-
//
|
|
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:
|
|
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(
|
|
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
|
|
3
|
+
"version": "18.1.7",
|
|
4
4
|
"peerDependencies": {
|
|
5
5
|
"@angular/common": "*",
|
|
6
6
|
"@angular/core": "*",
|
|
@@ -34,12 +34,6 @@
|
|
|
34
34
|
"esm": "./esm2022/analytics/mis-crystal-design-system-analytics.mjs",
|
|
35
35
|
"default": "./fesm2022/mis-crystal-design-system-analytics.mjs"
|
|
36
36
|
},
|
|
37
|
-
"./checkbox": {
|
|
38
|
-
"types": "./checkbox/index.d.ts",
|
|
39
|
-
"esm2022": "./esm2022/checkbox/mis-crystal-design-system-checkbox.mjs",
|
|
40
|
-
"esm": "./esm2022/checkbox/mis-crystal-design-system-checkbox.mjs",
|
|
41
|
-
"default": "./fesm2022/mis-crystal-design-system-checkbox.mjs"
|
|
42
|
-
},
|
|
43
37
|
"./async-search-dropdown": {
|
|
44
38
|
"types": "./async-search-dropdown/index.d.ts",
|
|
45
39
|
"esm2022": "./esm2022/async-search-dropdown/mis-crystal-design-system-async-search-dropdown.mjs",
|
|
@@ -52,11 +46,11 @@
|
|
|
52
46
|
"esm": "./esm2022/chip/mis-crystal-design-system-chip.mjs",
|
|
53
47
|
"default": "./fesm2022/mis-crystal-design-system-chip.mjs"
|
|
54
48
|
},
|
|
55
|
-
"./
|
|
56
|
-
"types": "./
|
|
57
|
-
"esm2022": "./esm2022/
|
|
58
|
-
"esm": "./esm2022/
|
|
59
|
-
"default": "./fesm2022/mis-crystal-design-system-
|
|
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"
|
|
60
54
|
},
|
|
61
55
|
"./datepicker_v2": {
|
|
62
56
|
"types": "./datepicker_v2/index.d.ts",
|
|
@@ -64,6 +58,12 @@
|
|
|
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",
|
|
@@ -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",
|
|
@@ -1,10 +1,10 @@
|
|
|
1
|
-
import { AfterViewInit, ElementRef, OnChanges, OnInit, QueryList, Renderer2
|
|
1
|
+
import { AfterViewInit, ElementRef, OnChanges, OnInit, QueryList, Renderer2 } from "@angular/core";
|
|
2
2
|
import { Filter, TableFilterComponent } from "./filter/filter.component";
|
|
3
3
|
import { SortState } from "./sort-icons.directive";
|
|
4
|
+
import { DropdownItem } from "mis-crystal-design-system/dropdown";
|
|
4
5
|
import * as i0 from "@angular/core";
|
|
5
6
|
export declare class TableComponent implements OnInit, AfterViewInit, OnChanges {
|
|
6
7
|
private renderer;
|
|
7
|
-
private cdr;
|
|
8
8
|
activeRowIndex: import("@angular/core").WritableSignal<number[]>;
|
|
9
9
|
hasCheckboxActions: import("@angular/core").WritableSignal<boolean>;
|
|
10
10
|
selectAllCheckbox: import("@angular/core").WritableSignal<boolean>;
|
|
@@ -28,7 +28,15 @@ export declare class TableComponent implements OnInit, AfterViewInit, OnChanges
|
|
|
28
28
|
colHeaders: QueryList<ElementRef> | any;
|
|
29
29
|
pages: import("@angular/core").WritableSignal<number[]>;
|
|
30
30
|
tableLength: import("@angular/core").WritableSignal<number>;
|
|
31
|
+
selectedPage: import("@angular/core").WritableSignal<number>;
|
|
31
32
|
pageSelected: import("@angular/core").OutputEmitterRef<number>;
|
|
33
|
+
pageSizeChanged: import("@angular/core").OutputEmitterRef<number>;
|
|
34
|
+
pageSizeOptions: import("@angular/core").Signal<{
|
|
35
|
+
label: string;
|
|
36
|
+
value: string;
|
|
37
|
+
}[]>;
|
|
38
|
+
showPageSizeDropdown: import("@angular/core").Signal<boolean>;
|
|
39
|
+
selectedPageSizeOption: import("@angular/core").WritableSignal<DropdownItem>;
|
|
32
40
|
tableConfig: import("@angular/core").InputSignal<TableConfig>;
|
|
33
41
|
subTableconfig: import("@angular/core").InputSignal<TableConfig>;
|
|
34
42
|
tableDataLoading: import("@angular/core").InputSignal<boolean>;
|
|
@@ -51,7 +59,7 @@ export declare class TableComponent implements OnInit, AfterViewInit, OnChanges
|
|
|
51
59
|
type: string;
|
|
52
60
|
payload?: any;
|
|
53
61
|
}>;
|
|
54
|
-
constructor(renderer: Renderer2
|
|
62
|
+
constructor(renderer: Renderer2);
|
|
55
63
|
selectRow(index: number): void;
|
|
56
64
|
ngOnInit(): void;
|
|
57
65
|
buildExpandedMap(): void;
|
|
@@ -83,8 +91,10 @@ export declare class TableComponent implements OnInit, AfterViewInit, OnChanges
|
|
|
83
91
|
} | null;
|
|
84
92
|
isRowDisabled(row: any): boolean;
|
|
85
93
|
toggleCheckbox(): void;
|
|
94
|
+
onPageSizeChange(selectedOption: DropdownItem): void;
|
|
95
|
+
shouldShowPagination(): boolean;
|
|
86
96
|
static ɵfac: i0.ɵɵFactoryDeclaration<TableComponent, never>;
|
|
87
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<TableComponent, "mis-table", never, { "tableConfig": { "alias": "tableConfig"; "required": false; "isSignal": true; }; "subTableconfig": { "alias": "subTableconfig"; "required": false; "isSignal": true; }; "tableDataLoading": { "alias": "tableDataLoading"; "required": false; "isSignal": true; }; "expandedIndex": { "alias": "expandedIndex"; "required": false; "isSignal": true; }; "tableData": { "alias": "tableData"; "required": false; "isSignal": true; }; "subTableData": { "alias": "subTableData"; "required": false; "isSignal": true; }; "subTableDataLoading": { "alias": "subTableDataLoading"; "required": false; "isSignal": true; }; "currentSort": { "alias": "currentSort"; "required": false; "isSignal": true; }; }, { "filtersUpdated": "filtersUpdated"; "pageSelected": "pageSelected"; "sortChange": "sortChange"; "headerAction": "headerAction"; }, never, never, false, never>;
|
|
97
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<TableComponent, "mis-table", never, { "tableConfig": { "alias": "tableConfig"; "required": false; "isSignal": true; }; "subTableconfig": { "alias": "subTableconfig"; "required": false; "isSignal": true; }; "tableDataLoading": { "alias": "tableDataLoading"; "required": false; "isSignal": true; }; "expandedIndex": { "alias": "expandedIndex"; "required": false; "isSignal": true; }; "tableData": { "alias": "tableData"; "required": false; "isSignal": true; }; "subTableData": { "alias": "subTableData"; "required": false; "isSignal": true; }; "subTableDataLoading": { "alias": "subTableDataLoading"; "required": false; "isSignal": true; }; "currentSort": { "alias": "currentSort"; "required": false; "isSignal": true; }; }, { "filtersUpdated": "filtersUpdated"; "pageSelected": "pageSelected"; "pageSizeChanged": "pageSizeChanged"; "sortChange": "sortChange"; "headerAction": "headerAction"; }, never, never, false, never>;
|
|
88
98
|
}
|
|
89
99
|
export interface TableConfig {
|
|
90
100
|
height: string | "100%";
|
|
@@ -106,6 +116,8 @@ export interface PaginationConfig {
|
|
|
106
116
|
totalNoOfRows: number;
|
|
107
117
|
selectedPage?: number;
|
|
108
118
|
disablePageJumping?: boolean;
|
|
119
|
+
showPageSizeDropdown?: boolean;
|
|
120
|
+
pageSizes?: number[];
|
|
109
121
|
}
|
|
110
122
|
export interface RowConfig {
|
|
111
123
|
height?: string | undefined | null;
|
package/table/table.module.d.ts
CHANGED
|
@@ -11,9 +11,10 @@ import * as i8 from "mis-crystal-design-system/checkbox";
|
|
|
11
11
|
import * as i9 from "@angular/cdk/scrolling";
|
|
12
12
|
import * as i10 from "@angular/cdk/overlay";
|
|
13
13
|
import * as i11 from "@angular/cdk/portal";
|
|
14
|
+
import * as i12 from "mis-crystal-design-system/dropdown";
|
|
14
15
|
export declare class TableModule {
|
|
15
16
|
static forRoot(): ModuleWithProviders<TableModule>;
|
|
16
17
|
static ɵfac: i0.ɵɵFactoryDeclaration<TableModule, never>;
|
|
17
|
-
static ɵmod: i0.ɵɵNgModuleDeclaration<TableModule, [typeof i1.TableComponent, typeof i2.SubTableComponent, typeof i3.TableFilterComponent, typeof i4.CustomTableCellDirective, typeof i5.SortIconsDirective, typeof i6.ActionsCellComponent], [typeof i7.CommonModule, typeof i8.CheckboxModule, typeof i9.ScrollingModule, typeof i10.OverlayModule, typeof i11.PortalModule], [typeof i1.TableComponent, typeof i2.SubTableComponent, typeof i3.TableFilterComponent, typeof i4.CustomTableCellDirective, typeof i5.SortIconsDirective, typeof i6.ActionsCellComponent]>;
|
|
18
|
+
static ɵmod: i0.ɵɵNgModuleDeclaration<TableModule, [typeof i1.TableComponent, typeof i2.SubTableComponent, typeof i3.TableFilterComponent, typeof i4.CustomTableCellDirective, typeof i5.SortIconsDirective, typeof i6.ActionsCellComponent], [typeof i7.CommonModule, typeof i8.CheckboxModule, typeof i9.ScrollingModule, typeof i10.OverlayModule, typeof i11.PortalModule, typeof i12.DropdownModule], [typeof i1.TableComponent, typeof i2.SubTableComponent, typeof i3.TableFilterComponent, typeof i4.CustomTableCellDirective, typeof i5.SortIconsDirective, typeof i6.ActionsCellComponent]>;
|
|
18
19
|
static ɵinj: i0.ɵɵInjectorDeclaration<TableModule>;
|
|
19
20
|
}
|
|
@@ -30,6 +30,8 @@ export declare class TimePickerComponent implements OnInit, OnDestroy {
|
|
|
30
30
|
minTime: import("@angular/core").InputSignal<number>;
|
|
31
31
|
triggerChange: import("@angular/core").InputSignal<boolean>;
|
|
32
32
|
disable: import("@angular/core").InputSignal<boolean>;
|
|
33
|
+
disableUserInput: import("@angular/core").InputSignal<boolean>;
|
|
34
|
+
fontSize: import("@angular/core").InputSignal<string>;
|
|
33
35
|
private computedFirstInterval;
|
|
34
36
|
private _isInitializing;
|
|
35
37
|
timeEmitter: import("@angular/core").OutputEmitterRef<ITime>;
|
|
@@ -50,5 +52,5 @@ export declare class TimePickerComponent implements OnInit, OnDestroy {
|
|
|
50
52
|
populateDropdown(): void;
|
|
51
53
|
ngOnDestroy(): void;
|
|
52
54
|
static ɵfac: i0.ɵɵFactoryDeclaration<TimePickerComponent, never>;
|
|
53
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<TimePickerComponent, "mis-timepicker", never, { "clockFormat": { "alias": "clockFormat"; "required": false; "isSignal": true; }; "timezone": { "alias": "timezone"; "required": false; "isSignal": true; }; "height": { "alias": "height"; "required": false; "isSignal": true; }; "inputWidth": { "alias": "inputWidth"; "required": false; "isSignal": true; }; "dropdownWidth": { "alias": "dropdownWidth"; "required": false; "isSignal": true; }; "interval": { "alias": "interval"; "required": false; "isSignal": true; }; "dateAsEpoch": { "alias": "dateAsEpoch"; "required": false; "isSignal": true; }; "firstInterval": { "alias": "firstInterval"; "required": false; "isSignal": true; }; "rangeValidity": { "alias": "rangeValidity"; "required": false; "isSignal": true; }; "showTooltip": { "alias": "showTooltip"; "required": false; "isSignal": true; }; "givenTime": { "alias": "givenTime"; "required": false; "isSignal": true; }; "minTime": { "alias": "minTime"; "required": false; "isSignal": true; }; "triggerChange": { "alias": "triggerChange"; "required": false; "isSignal": true; }; "disable": { "alias": "disable"; "required": false; "isSignal": true; }; }, { "timeEmitter": "timeEmitter"; }, never, never, false, never>;
|
|
55
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<TimePickerComponent, "mis-timepicker", never, { "clockFormat": { "alias": "clockFormat"; "required": false; "isSignal": true; }; "timezone": { "alias": "timezone"; "required": false; "isSignal": true; }; "height": { "alias": "height"; "required": false; "isSignal": true; }; "inputWidth": { "alias": "inputWidth"; "required": false; "isSignal": true; }; "dropdownWidth": { "alias": "dropdownWidth"; "required": false; "isSignal": true; }; "interval": { "alias": "interval"; "required": false; "isSignal": true; }; "dateAsEpoch": { "alias": "dateAsEpoch"; "required": false; "isSignal": true; }; "firstInterval": { "alias": "firstInterval"; "required": false; "isSignal": true; }; "rangeValidity": { "alias": "rangeValidity"; "required": false; "isSignal": true; }; "showTooltip": { "alias": "showTooltip"; "required": false; "isSignal": true; }; "givenTime": { "alias": "givenTime"; "required": false; "isSignal": true; }; "minTime": { "alias": "minTime"; "required": false; "isSignal": true; }; "triggerChange": { "alias": "triggerChange"; "required": false; "isSignal": true; }; "disable": { "alias": "disable"; "required": false; "isSignal": true; }; "disableUserInput": { "alias": "disableUserInput"; "required": false; "isSignal": true; }; "fontSize": { "alias": "fontSize"; "required": false; "isSignal": true; }; }, { "timeEmitter": "timeEmitter"; }, never, never, false, never>;
|
|
54
56
|
}
|
|
@@ -17,6 +17,8 @@ export declare class TimeRangePickerComponent implements OnInit {
|
|
|
17
17
|
gap: import("@angular/core").InputSignal<string>;
|
|
18
18
|
disableStartTime: import("@angular/core").InputSignal<boolean>;
|
|
19
19
|
disableEndTime: import("@angular/core").InputSignal<boolean>;
|
|
20
|
+
fontSize: import("@angular/core").InputSignal<string>;
|
|
21
|
+
disableUserInput: import("@angular/core").InputSignal<boolean>;
|
|
20
22
|
timeRangeEmitter: import("@angular/core").OutputEmitterRef<ITimeRange>;
|
|
21
23
|
startTime: import("@angular/core").WritableSignal<ITime>;
|
|
22
24
|
endTime: import("@angular/core").WritableSignal<ITime>;
|
|
@@ -24,6 +26,8 @@ export declare class TimeRangePickerComponent implements OnInit {
|
|
|
24
26
|
triggerChange: import("@angular/core").WritableSignal<boolean>;
|
|
25
27
|
private _firstIntervals;
|
|
26
28
|
private _isInitializing;
|
|
29
|
+
private _previousStartDateEpoch;
|
|
30
|
+
private _previousEndDateEpoch;
|
|
27
31
|
firstIntervals: import("@angular/core").Signal<{
|
|
28
32
|
start: number;
|
|
29
33
|
end: number;
|
|
@@ -42,5 +46,5 @@ export declare class TimeRangePickerComponent implements OnInit {
|
|
|
42
46
|
checkTimeValidity(time: string, date: number): boolean;
|
|
43
47
|
rangeValidation(validity: boolean): void;
|
|
44
48
|
static ɵfac: i0.ɵɵFactoryDeclaration<TimeRangePickerComponent, never>;
|
|
45
|
-
static ɵcmp: i0.ɵɵComponentDeclaration<TimeRangePickerComponent, "mis-timerangepicker", never, { "inputWidth": { "alias": "inputWidth"; "required": false; "isSignal": true; }; "dropdownWidth": { "alias": "dropdownWidth"; "required": false; "isSignal": true; }; "height": { "alias": "height"; "required": false; "isSignal": true; }; "timezone": { "alias": "timezone"; "required": false; "isSignal": true; }; "startDateEpoch": { "alias": "startDateEpoch"; "required": false; "isSignal": true; }; "endDateEpoch": { "alias": "endDateEpoch"; "required": false; "isSignal": true; }; "givenStartTime": { "alias": "givenStartTime"; "required": false; "isSignal": true; }; "givenEndTime": { "alias": "givenEndTime"; "required": false; "isSignal": true; }; "clockFormat": { "alias": "clockFormat"; "required": false; "isSignal": true; }; "interval": { "alias": "interval"; "required": false; "isSignal": true; }; "showTooltip": { "alias": "showTooltip"; "required": false; "isSignal": true; }; "direction": { "alias": "direction"; "required": false; "isSignal": true; }; "gap": { "alias": "gap"; "required": false; "isSignal": true; }; "disableStartTime": { "alias": "disableStartTime"; "required": false; "isSignal": true; }; "disableEndTime": { "alias": "disableEndTime"; "required": false; "isSignal": true; }; }, { "timeRangeEmitter": "timeRangeEmitter"; }, never, never, false, never>;
|
|
49
|
+
static ɵcmp: i0.ɵɵComponentDeclaration<TimeRangePickerComponent, "mis-timerangepicker", never, { "inputWidth": { "alias": "inputWidth"; "required": false; "isSignal": true; }; "dropdownWidth": { "alias": "dropdownWidth"; "required": false; "isSignal": true; }; "height": { "alias": "height"; "required": false; "isSignal": true; }; "timezone": { "alias": "timezone"; "required": false; "isSignal": true; }; "startDateEpoch": { "alias": "startDateEpoch"; "required": false; "isSignal": true; }; "endDateEpoch": { "alias": "endDateEpoch"; "required": false; "isSignal": true; }; "givenStartTime": { "alias": "givenStartTime"; "required": false; "isSignal": true; }; "givenEndTime": { "alias": "givenEndTime"; "required": false; "isSignal": true; }; "clockFormat": { "alias": "clockFormat"; "required": false; "isSignal": true; }; "interval": { "alias": "interval"; "required": false; "isSignal": true; }; "showTooltip": { "alias": "showTooltip"; "required": false; "isSignal": true; }; "direction": { "alias": "direction"; "required": false; "isSignal": true; }; "gap": { "alias": "gap"; "required": false; "isSignal": true; }; "disableStartTime": { "alias": "disableStartTime"; "required": false; "isSignal": true; }; "disableEndTime": { "alias": "disableEndTime"; "required": false; "isSignal": true; }; "fontSize": { "alias": "fontSize"; "required": false; "isSignal": true; }; "disableUserInput": { "alias": "disableUserInput"; "required": false; "isSignal": true; }; }, { "timeRangeEmitter": "timeRangeEmitter"; }, never, never, false, never>;
|
|
46
50
|
}
|