@libs-ui/components-datetime-picker 0.2.72

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 (29) hide show
  1. package/README.md +3 -0
  2. package/custom-ranges/calendar/calendar.component.d.ts +140 -0
  3. package/custom-ranges/custom-ranges.component.d.ts +59 -0
  4. package/defines/calendar.define.d.ts +13 -0
  5. package/defines/date-options.define.d.ts +20 -0
  6. package/esm2022/custom-ranges/calendar/calendar.component.mjs +1256 -0
  7. package/esm2022/custom-ranges/custom-ranges.component.mjs +266 -0
  8. package/esm2022/defines/calendar.define.mjs +135 -0
  9. package/esm2022/defines/date-options.define.mjs +55 -0
  10. package/esm2022/index.mjs +2 -0
  11. package/esm2022/interfaces/calendar-emit.interface.mjs +2 -0
  12. package/esm2022/interfaces/calendar-variables.interface.mjs +6 -0
  13. package/esm2022/interfaces/function-control.interface.mjs +2 -0
  14. package/esm2022/interfaces/picker.interface.mjs +2 -0
  15. package/esm2022/interfaces/time-variables.interface.mjs +4 -0
  16. package/esm2022/interfaces/valid.interface.mjs +2 -0
  17. package/esm2022/libs-ui-components-datetime-picker.mjs +5 -0
  18. package/esm2022/picker.component.mjs +180 -0
  19. package/fesm2022/libs-ui-components-datetime-picker.mjs +1882 -0
  20. package/fesm2022/libs-ui-components-datetime-picker.mjs.map +1 -0
  21. package/index.d.ts +1 -0
  22. package/interfaces/calendar-emit.interface.d.ts +25 -0
  23. package/interfaces/calendar-variables.interface.d.ts +80 -0
  24. package/interfaces/function-control.interface.d.ts +8 -0
  25. package/interfaces/picker.interface.d.ts +26 -0
  26. package/interfaces/time-variables.interface.d.ts +36 -0
  27. package/interfaces/valid.interface.d.ts +5 -0
  28. package/package.json +25 -0
  29. package/picker.component.d.ts +77 -0
@@ -0,0 +1,266 @@
1
+ import { ChangeDetectionStrategy, Component, effect, input, model, output, signal, untracked } from "@angular/core";
2
+ import { LibsUiComponentsPopoverComponent } from "@libs-ui/components-popover";
3
+ import { TranslateModule } from "@ngx-translate/core";
4
+ import dayjs from 'dayjs';
5
+ import { defaultLocaleConfig, getDateOptions, getDateRangeDefault } from "../defines/date-options.define";
6
+ import { LibsUiComponentsDatetimePickerCustomRangesCalendarComponent } from "./calendar/calendar.component";
7
+ import { LibsUiComponentsButtonsButtonComponent } from "@libs-ui/components-buttons-button";
8
+ import * as i0 from "@angular/core";
9
+ export class LibsUiComponentsDatetimePickerCustomRangesComponent {
10
+ /** PROPERTY */
11
+ showCalTableInRanges = signal(false);
12
+ quickRangesArray = signal([]);
13
+ selectedQuickRange = signal(''); // quick range đã được lưu trước đó
14
+ chosenQuickRange = signal(undefined); // quick range đang được chọn
15
+ calendarShowing = signal(false);
16
+ timeouts = signal([]);
17
+ calendarFunctionControlEvent = signal(undefined);
18
+ chosenSingleDate = signal(undefined);
19
+ chosenDateRange = signal(undefined);
20
+ /** INPUT */
21
+ // readonly SelectedQuickRange = input<string>('');
22
+ zIndex = input(1200, { transform: (value) => value ?? 1200 });
23
+ classInclude = input('');
24
+ extendRanges = input([]);
25
+ widthByParent = input(false);
26
+ autoApply = input(false);
27
+ positionQuickRanges = input('left', { transform: (value) => value ?? 'left' });
28
+ isSingle = input(false, { transform: (value) => value ?? false });
29
+ hasTimePicker = input(true);
30
+ flagMouse = input({ isMouseEnter: false, isMouseEnterContent: false });
31
+ dateOptions = input({ ...defaultLocaleConfig(), ...getDateOptions() });
32
+ alwaysShowCalendars = input(false);
33
+ startDate = model(dayjs().startOf('day'));
34
+ endDate = model(dayjs().endOf('day'));
35
+ showCustomRangeLabel = input(undefined);
36
+ keepCalendarOpeningWithRange = input(undefined);
37
+ singleDateSelected = input();
38
+ dateRangeSelected = input(undefined, {
39
+ transform: (value) => {
40
+ if (!value) {
41
+ return;
42
+ }
43
+ let startDate = value.startDate;
44
+ let endDate = value.endDate;
45
+ if (typeof startDate === 'string') {
46
+ startDate = dayjs(startDate);
47
+ }
48
+ if (typeof endDate === 'string') {
49
+ endDate = dayjs(endDate);
50
+ }
51
+ return {
52
+ ...value,
53
+ startDate,
54
+ endDate
55
+ };
56
+ }
57
+ });
58
+ /** OUTPUT */
59
+ outChangStageFlagMouse = output();
60
+ outUpdateWidth = output();
61
+ outCancel = output();
62
+ outSelectSingleDate = output();
63
+ outSelectDateRange = output();
64
+ outClickRange = output();
65
+ constructor() {
66
+ effect(() => untracked(this.onAfterViewInit.bind(this)));
67
+ }
68
+ ngOnInit() {
69
+ throw new Error("Method not implemented.");
70
+ }
71
+ onAfterViewInit() {
72
+ if (!this.startDate()) {
73
+ this.startDate.set(dayjs().startOf('day'));
74
+ }
75
+ if (!this.endDate()) {
76
+ this.endDate.set(dayjs().endOf('day'));
77
+ }
78
+ const dateRangeSelected = this.dateRangeSelected();
79
+ const customRange = {
80
+ id: this.dateOptions()?.customRangeLabel || '',
81
+ label: this.dateOptions()?.customRangeLabel || ''
82
+ };
83
+ if (dateRangeSelected) {
84
+ this.selectedQuickRange.set(dateRangeSelected.quickRangeId ? dateRangeSelected.quickRangeId : customRange.id);
85
+ this.chosenQuickRange.set(dateRangeSelected.quickRangeId ?? customRange.id);
86
+ this.startDate.set(dateRangeSelected.startDate);
87
+ this.endDate.set(dateRangeSelected.endDate);
88
+ }
89
+ if (this.hasTimePicker()) {
90
+ this.selectedQuickRange.set(customRange.id);
91
+ this.chosenQuickRange.set(customRange.id);
92
+ }
93
+ if (this.selectedQuickRange() === this.dateOptions()?.customRangeLabel) {
94
+ this.showCalTableInRanges.set(true);
95
+ }
96
+ this.renderRanges();
97
+ }
98
+ updateWidth() {
99
+ const timeoutId = setTimeout(() => {
100
+ this.outUpdateWidth.emit(1);
101
+ });
102
+ this.timeouts.update(ids => [...ids, timeoutId]);
103
+ }
104
+ renderRanges() {
105
+ if (this.isSingle()) {
106
+ return;
107
+ }
108
+ const rangesDefault = getDateRangeDefault();
109
+ const ranges = this.isSingle() ? {} : this.dateOptions()?.ranges;
110
+ this.quickRangesArray.set([]);
111
+ for (const key in ranges) {
112
+ const rangeValue = rangesDefault[key];
113
+ const start = dayjs(rangeValue[0]);
114
+ const end = dayjs(rangeValue[1]);
115
+ this.quickRangesArray.update(current => {
116
+ current.push({
117
+ id: key,
118
+ label: ranges[key],
119
+ values: [start, end]
120
+ });
121
+ return current;
122
+ });
123
+ }
124
+ if (this.showCustomRangeLabel() && this.dateOptions()?.customRangeLabel) {
125
+ this.quickRangesArray.update(current => {
126
+ current.push({
127
+ id: this.dateOptions()?.customRangeLabel || '',
128
+ label: this.dateOptions()?.customRangeLabel || ''
129
+ });
130
+ return current;
131
+ });
132
+ }
133
+ if (this.extendRanges()) {
134
+ this.quickRangesArray.update(current => {
135
+ current.unshift(...this.extendRanges());
136
+ return current;
137
+ });
138
+ }
139
+ if (!this.quickRangesArray().length) {
140
+ this.showCalTableInRanges.set(true);
141
+ }
142
+ }
143
+ handlerCancel() {
144
+ this.outCancel.emit('');
145
+ }
146
+ handlerPickerDate(event) {
147
+ console.log('handlerPickerDate', event);
148
+ this.chosenSingleDate.set({
149
+ displayLabel: event.displayLabel,
150
+ date: event.startDate,
151
+ values: event.detailDatePicker.start()
152
+ });
153
+ // if (!this.isSingle() && event.startDate && !event.endDate) {
154
+ // const endTime = event.detailDatePicker.end();
155
+ // event.endDate = event.startDate.clone().hour(endTime.hour as number).minute(endTime.minute as number).second(59);
156
+ // }
157
+ this.chosenDateRange.set({
158
+ quickRangeId: this.chosenQuickRange(),
159
+ ...event
160
+ });
161
+ const chosenSingleDate = this.chosenSingleDate();
162
+ const chosenDateRange = this.chosenDateRange();
163
+ if (this.isSingle() && chosenSingleDate) {
164
+ this.outSelectSingleDate.emit(chosenSingleDate);
165
+ return;
166
+ }
167
+ if (!chosenDateRange || (!chosenDateRange.startDate && !chosenDateRange.endDate)) {
168
+ return;
169
+ }
170
+ this.outSelectDateRange.emit(chosenDateRange);
171
+ }
172
+ handlerClickRange(e, range) {
173
+ e.stopPropagation();
174
+ this.updateWidth();
175
+ this.chosenQuickRange.set(range.id);
176
+ if (range.id === this.dateOptions()?.customRangeLabel) {
177
+ this.calendarShowing.set(true);
178
+ this.showCalTableInRanges.set(true);
179
+ return;
180
+ }
181
+ if (this.extendRanges()) {
182
+ const findExternalRange = this.extendRanges().find(item => item.label === range.id);
183
+ if (findExternalRange && range.id === findExternalRange.label) {
184
+ if (findExternalRange.values) {
185
+ this.outSelectDateRange.emit({ quickRangeId: findExternalRange.id, displayLabel: findExternalRange.label, startDate: findExternalRange.values[0], endDate: findExternalRange.values[1] });
186
+ return;
187
+ }
188
+ this.outSelectDateRange.emit({ quickRangeId: findExternalRange.id, displayLabel: findExternalRange.label, startDate: undefined, endDate: undefined });
189
+ return;
190
+ }
191
+ }
192
+ const dates = range.values ?? [];
193
+ // this.startDate.set(dates[0].clone().hour(0).minute(0).second(0));
194
+ // this.endDate.set(dates[1].clone().hour(23).minute(59).second(59));
195
+ // this.timeValue = { hour: 0, toHour: 0, minute: 23, toMinute: 59 };
196
+ // this.timepickerVariables.left.selectedHour = 0;
197
+ // this.timepickerVariables.left.selectedMinute = 0;
198
+ // this.timepickerVariables.right.selectedHour = 23;
199
+ // this.timepickerVariables.right.selectedMinute = 59;
200
+ // this.showRangeLabelOnInput && label !== this.localeDay.customRangeLabel ? this.chosenLabel = label : this.calculateChosenLabel();
201
+ // // this.autoApply.set(true);
202
+ // if (!this.hasTimePicker()) {
203
+ // if(this.startDate()) {
204
+ // this.startDate.set(this.startDate()?.startOf('day'));
205
+ // }
206
+ // if(this.endDate()) {
207
+ // this.endDate.set(this.endDate()?.endOf('day'));
208
+ // }
209
+ // }
210
+ // if (!this.alwaysShowCalendars()) {
211
+ // this.calendarShowing.set(false);
212
+ // }
213
+ // this.outClickRange.emit(range);
214
+ if (!this.keepCalendarOpeningWithRange() || !this.alwaysShowCalendars()) {
215
+ this.outSelectDateRange.emit({ quickRangeId: range.id, displayLabel: range.label, startDate: range.values?.[0], endDate: range.values?.[1] });
216
+ return;
217
+ }
218
+ // if (this.timePicker) {
219
+ // this.renderTimePicker(SideEnum.left);
220
+ // this.renderTimePicker(SideEnum.right);
221
+ // }
222
+ // if (this.getMaxDate() && this.getMaxDate().isSame(dates[0], 'month')) {
223
+ // this.rightCalendar.month = this.rightCalendar.month && this.rightCalendar.month.month(dates[0].month());
224
+ // this.rightCalendar.month = this.rightCalendar.month && this.rightCalendar.month.year(dates[0].year());
225
+ // this.leftCalendar.month = this.leftCalendar.month && this.leftCalendar.month.month(dates[0].month() - 1);
226
+ // this.leftCalendar.month = this.leftCalendar.month && this.leftCalendar.month.year(dates[1].year());
227
+ // return this.updateCalendars();
228
+ // }
229
+ // this.leftCalendar.month = this.leftCalendar.month && this.leftCalendar.month.month(dates[0].month());
230
+ // this.leftCalendar.month = this.leftCalendar.month && this.leftCalendar.month.year(dates[0].year());
231
+ // const nextMonth = dates[0].clone().add(1, 'month');
232
+ // this.rightCalendar.month = this.rightCalendar.month && this.rightCalendar.month.month(nextMonth.month());
233
+ // this.rightCalendar.month = this.rightCalendar.month && this.rightCalendar.month.year(nextMonth.year());
234
+ // this.updateCalendars();
235
+ return;
236
+ }
237
+ handlerClickCancel(event) {
238
+ event.stopPropagation();
239
+ // this.startDate.set(dayjs(0));
240
+ // this.endDate.set(dayjs(0));
241
+ this.outCancel.emit('');
242
+ }
243
+ handlerChangeFlagMouse(flagMouse) {
244
+ this.outChangStageFlagMouse.emit(flagMouse);
245
+ }
246
+ handlerFunctionsControl(event) {
247
+ this.calendarFunctionControlEvent.set(event);
248
+ }
249
+ ngOnDestroy() {
250
+ this.timeouts().forEach(item => clearTimeout(item));
251
+ // this.onDestroy.next();
252
+ // this.onDestroy.complete();
253
+ }
254
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: LibsUiComponentsDatetimePickerCustomRangesComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
255
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: LibsUiComponentsDatetimePickerCustomRangesComponent, isStandalone: true, selector: "libs_ui-components-datetime-picker-custom_ranges", inputs: { zIndex: { classPropertyName: "zIndex", publicName: "zIndex", isSignal: true, isRequired: false, transformFunction: null }, classInclude: { classPropertyName: "classInclude", publicName: "classInclude", isSignal: true, isRequired: false, transformFunction: null }, extendRanges: { classPropertyName: "extendRanges", publicName: "extendRanges", isSignal: true, isRequired: false, transformFunction: null }, widthByParent: { classPropertyName: "widthByParent", publicName: "widthByParent", isSignal: true, isRequired: false, transformFunction: null }, autoApply: { classPropertyName: "autoApply", publicName: "autoApply", isSignal: true, isRequired: false, transformFunction: null }, positionQuickRanges: { classPropertyName: "positionQuickRanges", publicName: "positionQuickRanges", isSignal: true, isRequired: false, transformFunction: null }, isSingle: { classPropertyName: "isSingle", publicName: "isSingle", isSignal: true, isRequired: false, transformFunction: null }, hasTimePicker: { classPropertyName: "hasTimePicker", publicName: "hasTimePicker", isSignal: true, isRequired: false, transformFunction: null }, flagMouse: { classPropertyName: "flagMouse", publicName: "flagMouse", isSignal: true, isRequired: false, transformFunction: null }, dateOptions: { classPropertyName: "dateOptions", publicName: "dateOptions", isSignal: true, isRequired: false, transformFunction: null }, alwaysShowCalendars: { classPropertyName: "alwaysShowCalendars", publicName: "alwaysShowCalendars", isSignal: true, isRequired: false, transformFunction: null }, startDate: { classPropertyName: "startDate", publicName: "startDate", isSignal: true, isRequired: false, transformFunction: null }, endDate: { classPropertyName: "endDate", publicName: "endDate", isSignal: true, isRequired: false, transformFunction: null }, showCustomRangeLabel: { classPropertyName: "showCustomRangeLabel", publicName: "showCustomRangeLabel", isSignal: true, isRequired: false, transformFunction: null }, keepCalendarOpeningWithRange: { classPropertyName: "keepCalendarOpeningWithRange", publicName: "keepCalendarOpeningWithRange", isSignal: true, isRequired: false, transformFunction: null }, singleDateSelected: { classPropertyName: "singleDateSelected", publicName: "singleDateSelected", isSignal: true, isRequired: false, transformFunction: null }, dateRangeSelected: { classPropertyName: "dateRangeSelected", publicName: "dateRangeSelected", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { startDate: "startDateChange", endDate: "endDateChange", outChangStageFlagMouse: "outChangStageFlagMouse", outUpdateWidth: "outUpdateWidth", outCancel: "outCancel", outSelectSingleDate: "outSelectSingleDate", outSelectDateRange: "outSelectDateRange", outClickRange: "outClickRange" }, ngImport: i0, template: "<div #pickerContainer\n class=\"libs-ui-component-custom_ranges flex rounded-[4px] bg-[#ffffff] z-[1000] overflow-[hidden] relative inline\"\n [class.flex-row-reverse]=\"positionQuickRanges() === 'right'\">\n @if (!isSingle()) {\n <div class=\"libs-ui-component-custom_ranges-ranges {{ classInclude() || '' }}\"\n [class.border-l-[#e6e8ed]]=\"positionQuickRanges() === 'right' && showCalTableInRanges()\"\n [class.border-l]=\"positionQuickRanges() === 'right' && showCalTableInRanges()\"\n [class.border-r-[#e6e8ed]]=\"positionQuickRanges() === 'left' && showCalTableInRanges()\"\n [class.border-r]=\"positionQuickRanges() === 'left' && showCalTableInRanges()\"\n [class.!min-h-[260px]]=\"showCalTableInRanges() && !isSingle()\"\n [class.!min-h-[300px]]=\"hasTimePicker() && !isSingle()\"\n [class.!w-[160px]]=\"!widthByParent()\"\n [class.!w-full]=\"widthByParent()\">\n @for (range of quickRangesArray(); track range.id) {\n <div class=\"flex items-center hover:bg-[var(--libs-ui-color-light-3)] cursor-pointer px-[16px] py-[8px]\"\n [class.libs-ui-selected-range]=\"range.id === chosenQuickRange() && showCustomRangeLabel()\"\n [class.bg-[var(--libs-ui-color-light-3)]]=\"range.id === chosenQuickRange() || range.id === selectedQuickRange()\"\n (click)=\"handlerClickRange($event, range)\">\n <div class=\"libs-ui-font-h5r flex text-[#333333] min-w-0 w-full\">\n <div LibsUiComponentsPopoverDirective\n type=\"text\"\n [config]=\"{maxWidth:160,direction:'top',zIndex:(zIndex() ||1000) + 1}\"\n [innerHTML]=\"range.label\"\n (click)=\"handlerClickRange($event, range)\">\n </div>\n </div>\n <i class=\"text-[12px] ml-[16px]\"\n [class.libs-ui-icon-check]=\"range.id === selectedQuickRange()\"\n [class.text-[var(--libs-ui-color-default)]]=\"range.id === selectedQuickRange()\"></i>\n </div>\n }\n </div>\n }\n @if (showCalTableInRanges()) {\n <div class=\"m-[16px] w-full\">\n <libs_ui-components-datetime-picker-custom_ranges-calendar [isSingle]=\"isSingle()\"\n [autoApply]=\"autoApply()\"\n [zIndex]=\"zIndex()\"\n [flagMouse]=\"flagMouse()\"\n [dateOptions]=\"dateOptions()\"\n [hasTimePicker]=\"hasTimePicker()\"\n [quickRangesArray]=\"quickRangesArray()\"\n [startDate]=\"startDate()\"\n [endDate]=\"endDate()\"\n [classInclude]=\"'w-full'\"\n (outCancel)=\"handlerCancel()\"\n (outPickerDate)=\"handlerPickerDate($event)\"\n (outFunctionsControl)=\"handlerFunctionsControl($event)\"\n (outChangStageFlagMouse)=\"handlerChangeFlagMouse($event)\" />\n </div>\n }\n</div>\n", styles: [".libs-ui-component-custom_ranges{position:absolute;box-shadow:0 2px 4px #00000029,0 2px 8px #0000001f}.libs-ui-component-custom_ranges .libs-ui-component-custom_ranges-ranges{width:159px;flex-shrink:0}.libs-ui-component-custom_ranges .libs-ui-component-custom_ranges-ranges .libs-ui-selected-range{position:relative}.libs-ui-component-custom_ranges .libs-ui-component-custom_ranges-ranges .libs-ui-selected-range:after{content:\"\";position:absolute;right:0;top:0;bottom:0;width:2px;background-color:var(--libs-ui-color-default)!important}@media (min-width: 564px){.libs-ui-component-custom_ranges{width:auto}}\n"], dependencies: [{ kind: "ngmodule", type: TranslateModule }, { kind: "component", type: LibsUiComponentsDatetimePickerCustomRangesCalendarComponent, selector: "libs_ui-components-datetime-picker-custom_ranges-calendar", inputs: ["quickRangesArray", "zIndex", "classInclude", "isSingle", "showDropdownsSelect", "hasTimePicker", "flagMouse", "dateOptions", "autoApply", "hasSecondPicker", "showRangeLabelOnInput", "startDate", "endDate", "minDate", "maxDate"], outputs: ["startDateChange", "endDateChange", "outChangStageFlagMouse", "outPickerDate", "outCancel", "outUpdateWidth", "outFunctionsControl"] }, { kind: "component", type: LibsUiComponentsPopoverComponent, selector: "libs_ui-components-popover,[LibsUiComponentsPopoverDirective]", inputs: ["debugId", "flagMouse", "type", "mode", "config", "ignoreShowPopover", "elementRefCustom", "classInclude", "ignoreHiddenPopoverContentWhenMouseLeave", "ignoreStopPropagationEvent", "ignoreCursorPointerModeLikeClick", "isAddContentToParentDocument", "ignoreClickOutside"], outputs: ["outEvent", "outChangStageFlagMouse", "outEventPopoverContent", "outFunctionsControl"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
256
+ }
257
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: LibsUiComponentsDatetimePickerCustomRangesComponent, decorators: [{
258
+ type: Component,
259
+ args: [{ selector: 'libs_ui-components-datetime-picker-custom_ranges', standalone: true, changeDetection: ChangeDetectionStrategy.OnPush, imports: [
260
+ TranslateModule,
261
+ LibsUiComponentsDatetimePickerCustomRangesCalendarComponent,
262
+ LibsUiComponentsPopoverComponent,
263
+ LibsUiComponentsButtonsButtonComponent
264
+ ], template: "<div #pickerContainer\n class=\"libs-ui-component-custom_ranges flex rounded-[4px] bg-[#ffffff] z-[1000] overflow-[hidden] relative inline\"\n [class.flex-row-reverse]=\"positionQuickRanges() === 'right'\">\n @if (!isSingle()) {\n <div class=\"libs-ui-component-custom_ranges-ranges {{ classInclude() || '' }}\"\n [class.border-l-[#e6e8ed]]=\"positionQuickRanges() === 'right' && showCalTableInRanges()\"\n [class.border-l]=\"positionQuickRanges() === 'right' && showCalTableInRanges()\"\n [class.border-r-[#e6e8ed]]=\"positionQuickRanges() === 'left' && showCalTableInRanges()\"\n [class.border-r]=\"positionQuickRanges() === 'left' && showCalTableInRanges()\"\n [class.!min-h-[260px]]=\"showCalTableInRanges() && !isSingle()\"\n [class.!min-h-[300px]]=\"hasTimePicker() && !isSingle()\"\n [class.!w-[160px]]=\"!widthByParent()\"\n [class.!w-full]=\"widthByParent()\">\n @for (range of quickRangesArray(); track range.id) {\n <div class=\"flex items-center hover:bg-[var(--libs-ui-color-light-3)] cursor-pointer px-[16px] py-[8px]\"\n [class.libs-ui-selected-range]=\"range.id === chosenQuickRange() && showCustomRangeLabel()\"\n [class.bg-[var(--libs-ui-color-light-3)]]=\"range.id === chosenQuickRange() || range.id === selectedQuickRange()\"\n (click)=\"handlerClickRange($event, range)\">\n <div class=\"libs-ui-font-h5r flex text-[#333333] min-w-0 w-full\">\n <div LibsUiComponentsPopoverDirective\n type=\"text\"\n [config]=\"{maxWidth:160,direction:'top',zIndex:(zIndex() ||1000) + 1}\"\n [innerHTML]=\"range.label\"\n (click)=\"handlerClickRange($event, range)\">\n </div>\n </div>\n <i class=\"text-[12px] ml-[16px]\"\n [class.libs-ui-icon-check]=\"range.id === selectedQuickRange()\"\n [class.text-[var(--libs-ui-color-default)]]=\"range.id === selectedQuickRange()\"></i>\n </div>\n }\n </div>\n }\n @if (showCalTableInRanges()) {\n <div class=\"m-[16px] w-full\">\n <libs_ui-components-datetime-picker-custom_ranges-calendar [isSingle]=\"isSingle()\"\n [autoApply]=\"autoApply()\"\n [zIndex]=\"zIndex()\"\n [flagMouse]=\"flagMouse()\"\n [dateOptions]=\"dateOptions()\"\n [hasTimePicker]=\"hasTimePicker()\"\n [quickRangesArray]=\"quickRangesArray()\"\n [startDate]=\"startDate()\"\n [endDate]=\"endDate()\"\n [classInclude]=\"'w-full'\"\n (outCancel)=\"handlerCancel()\"\n (outPickerDate)=\"handlerPickerDate($event)\"\n (outFunctionsControl)=\"handlerFunctionsControl($event)\"\n (outChangStageFlagMouse)=\"handlerChangeFlagMouse($event)\" />\n </div>\n }\n</div>\n", styles: [".libs-ui-component-custom_ranges{position:absolute;box-shadow:0 2px 4px #00000029,0 2px 8px #0000001f}.libs-ui-component-custom_ranges .libs-ui-component-custom_ranges-ranges{width:159px;flex-shrink:0}.libs-ui-component-custom_ranges .libs-ui-component-custom_ranges-ranges .libs-ui-selected-range{position:relative}.libs-ui-component-custom_ranges .libs-ui-component-custom_ranges-ranges .libs-ui-selected-range:after{content:\"\";position:absolute;right:0;top:0;bottom:0;width:2px;background-color:var(--libs-ui-color-default)!important}@media (min-width: 564px){.libs-ui-component-custom_ranges{width:auto}}\n"] }]
265
+ }], ctorParameters: () => [] });
266
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"custom-ranges.component.js","sourceRoot":"","sources":["../../../../../../../libs-ui/components/datetime/picker/src/custom-ranges/custom-ranges.component.ts","../../../../../../../libs-ui/components/datetime/picker/src/custom-ranges/custom-ranges.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, effect, input, model, OnDestroy, OnInit, output, signal, untracked } from \"@angular/core\";\nimport { IFlagMouse, LibsUiComponentsPopoverComponent } from \"@libs-ui/components-popover\";\nimport { TranslateModule } from \"@ngx-translate/core\";\nimport dayjs from 'dayjs';\nimport { defaultLocaleConfig, getDateOptions, getDateRangeDefault } from \"../defines/date-options.define\";\nimport { IEmitDateCalendar, IEmitDateRange, IEmitSingleDate } from \"../interfaces/calendar-emit.interface\";\nimport { IDateRange } from \"../interfaces/calendar-variables.interface\";\nimport { ICalendarFunctionControlEvent } from \"../interfaces/function-control.interface\";\nimport { LocalizationConfig } from \"../interfaces/picker.interface\";\nimport { LibsUiComponentsDatetimePickerCustomRangesCalendarComponent } from \"./calendar/calendar.component\";\nimport { LibsUiComponentsButtonsButtonComponent } from \"@libs-ui/components-buttons-button\";\n\n@Component({\n  // eslint-disable-next-line @angular-eslint/component-selector\n  selector: 'libs_ui-components-datetime-picker-custom_ranges',\n  templateUrl: './custom-ranges.component.html',\n  styleUrls: ['./custom-ranges.component.scss'],\n  standalone: true,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  imports: [\n    TranslateModule,\n    LibsUiComponentsDatetimePickerCustomRangesCalendarComponent,\n    LibsUiComponentsPopoverComponent,\n    LibsUiComponentsButtonsButtonComponent\n  ]\n})\nexport class LibsUiComponentsDatetimePickerCustomRangesComponent implements OnInit, OnDestroy {\n  /** PROPERTY */\n  protected showCalTableInRanges = signal<boolean>(false);\n  protected quickRangesArray = signal<Array<IDateRange>>([]);\n  protected selectedQuickRange = signal<string>(''); // quick range đã được lưu trước đó\n  protected chosenQuickRange = signal<string | undefined>(undefined); // quick range đang được chọn\n\n  private calendarShowing = signal<boolean>(false);\n  private timeouts = signal<Array<number>>([]);\n  private calendarFunctionControlEvent = signal<ICalendarFunctionControlEvent | undefined>(undefined);\n  private chosenSingleDate = signal<IEmitSingleDate | undefined>(undefined);\n  private chosenDateRange = signal<IEmitDateRange | undefined>(undefined);\n\n  /** INPUT */\n  // readonly SelectedQuickRange = input<string>('');\n  readonly zIndex = input<number, number>(1200, { transform: (value) => value ?? 1200 });\n  readonly classInclude = input<string>('');\n  readonly extendRanges = input<Array<IDateRange>>([]);\n  readonly widthByParent = input<boolean>(false);\n  readonly autoApply = input<boolean>(false);\n\n  readonly positionQuickRanges = input<'left' | 'right', 'left' | 'right'>('left', { transform: (value) => value ?? 'left' });\n  readonly isSingle = input<boolean, boolean>(false, { transform: (value) => value ?? false });\n  readonly hasTimePicker = input<boolean>(true);\n  readonly flagMouse = input<IFlagMouse>({ isMouseEnter: false, isMouseEnterContent: false });\n  readonly dateOptions = input<LocalizationConfig>({ ...defaultLocaleConfig(), ...getDateOptions() });\n  readonly alwaysShowCalendars = input<boolean>(false);\n  readonly startDate = model<dayjs.Dayjs | undefined>(dayjs().startOf('day'));\n  readonly endDate = model<dayjs.Dayjs | undefined>(dayjs().endOf('day'));\n  readonly showCustomRangeLabel = input<boolean | undefined>(undefined);\n  readonly keepCalendarOpeningWithRange = input<boolean | undefined>(undefined);\n\n  readonly singleDateSelected = input<IEmitSingleDate>();\n  readonly dateRangeSelected = input<IEmitDateRange | undefined, IEmitDateRange | undefined>(undefined, {\n    transform: (value) => {\n      if (!value) {\n        return;\n      }\n      let startDate = value.startDate;\n      let endDate = value.endDate;\n\n      if (typeof startDate === 'string') {\n        startDate = dayjs(startDate);\n      }\n\n      if (typeof endDate === 'string') {\n        endDate = dayjs(endDate);\n      }\n\n      return {\n        ...value,\n        startDate,\n        endDate\n      };\n    }\n  });\n\n  /** OUTPUT */\n  readonly outChangStageFlagMouse = output<IFlagMouse>();\n  readonly outUpdateWidth = output<number>();\n  readonly outCancel = output<string>();\n  readonly outSelectSingleDate = output<IEmitSingleDate>();\n  readonly outSelectDateRange = output<IEmitDateRange>();\n  readonly outClickRange = output<IDateRange>();\n\n  constructor() {\n    effect(() => untracked(this.onAfterViewInit.bind(this)));\n  }\n  ngOnInit() {\n    throw new Error(\"Method not implemented.\");\n  }\n\n  private onAfterViewInit() {\n    if (!this.startDate()) {\n      this.startDate.set(dayjs().startOf('day'));\n    }\n    if (!this.endDate()) {\n      this.endDate.set(dayjs().endOf('day'));\n    }\n    const dateRangeSelected = this.dateRangeSelected();\n    const customRange = {\n      id: this.dateOptions()?.customRangeLabel || '',\n      label: this.dateOptions()?.customRangeLabel || ''\n    };\n\n    if (dateRangeSelected) {\n      this.selectedQuickRange.set(dateRangeSelected.quickRangeId ? dateRangeSelected.quickRangeId : customRange.id);\n      this.chosenQuickRange.set(dateRangeSelected.quickRangeId ?? customRange.id);\n\n      this.startDate.set(dateRangeSelected.startDate as dayjs.Dayjs);\n      this.endDate.set(dateRangeSelected.endDate as dayjs.Dayjs);\n    }\n    if (this.hasTimePicker()) {\n      this.selectedQuickRange.set(customRange.id);\n      this.chosenQuickRange.set(customRange.id);\n    }\n    if (this.selectedQuickRange() === this.dateOptions()?.customRangeLabel) {\n      this.showCalTableInRanges.set(true);\n    }\n    this.renderRanges();\n  }\n\n  private updateWidth() {\n    const timeoutId = setTimeout(() => {\n      this.outUpdateWidth.emit(1);\n    }) as unknown as number;\n\n    this.timeouts.update(ids => [...ids, timeoutId]);\n  }\n\n  private renderRanges() {\n    if (this.isSingle()) {\n      return;\n    }\n    const rangesDefault = getDateRangeDefault();\n    const ranges = this.isSingle() ? {} : this.dateOptions()?.ranges;\n\n    this.quickRangesArray.set([]);\n\n    for (const key in ranges) {\n      const rangeValue = rangesDefault[key];\n      const start = dayjs(rangeValue[0]);\n      const end = dayjs(rangeValue[1]);\n\n      this.quickRangesArray.update(current => {\n        current.push({\n          id: key,\n          label: ranges[key],\n          values: [start, end]\n        });\n\n        return current;\n      });\n    }\n    if (this.showCustomRangeLabel() && this.dateOptions()?.customRangeLabel) {\n      this.quickRangesArray.update(current => {\n        current.push({\n          id: this.dateOptions()?.customRangeLabel || '',\n          label: this.dateOptions()?.customRangeLabel || ''\n        });\n\n        return current;\n      });\n    }\n    if (this.extendRanges()) {\n      this.quickRangesArray.update(current => {\n        current.unshift(...this.extendRanges());\n\n        return current;\n      });\n    }\n    if (!this.quickRangesArray().length) {\n      this.showCalTableInRanges.set(true);\n    }\n  }\n\n  protected handlerCancel() {\n    this.outCancel.emit('');\n  }\n\n  protected handlerPickerDate(event: IEmitDateCalendar) {\n    console.log('handlerPickerDate', event);\n\n    this.chosenSingleDate.set({\n      displayLabel: event.displayLabel,\n      date: event.startDate,\n      values: event.detailDatePicker.start()\n    });\n    // if (!this.isSingle() && event.startDate && !event.endDate) {\n    //   const endTime = event.detailDatePicker.end();\n    //   event.endDate = event.startDate.clone().hour(endTime.hour as number).minute(endTime.minute as number).second(59);\n    // }\n    this.chosenDateRange.set({\n      quickRangeId: this.chosenQuickRange(),\n      ...event\n    });\n    const chosenSingleDate = this.chosenSingleDate();\n    const chosenDateRange = this.chosenDateRange();\n    if (this.isSingle() && chosenSingleDate) {\n      this.outSelectSingleDate.emit(chosenSingleDate);\n\n      return;\n    }\n    if (!chosenDateRange || (!chosenDateRange.startDate && !chosenDateRange.endDate)) {\n      return;\n    }\n    this.outSelectDateRange.emit(chosenDateRange);\n  }\n\n  protected handlerClickRange(e: Event, range: IDateRange) {\n    e.stopPropagation();\n    this.updateWidth();\n    this.chosenQuickRange.set(range.id);\n\n    if (range.id === this.dateOptions()?.customRangeLabel) {\n      this.calendarShowing.set(true);\n      this.showCalTableInRanges.set(true);\n\n      return;\n    }\n    if (this.extendRanges()) {\n      const findExternalRange = this.extendRanges().find(item => item.label === range.id);\n\n      if (findExternalRange && range.id === findExternalRange.label) {\n        if (findExternalRange.values) {\n          this.outSelectDateRange.emit({ quickRangeId: findExternalRange.id, displayLabel: findExternalRange.label, startDate: findExternalRange.values[0], endDate: findExternalRange.values[1] });\n\n          return;\n        }\n        this.outSelectDateRange.emit({ quickRangeId: findExternalRange.id, displayLabel: findExternalRange.label, startDate: undefined, endDate: undefined });\n\n        return;\n      }\n    }\n    const dates = range.values ?? [];\n\n    // this.startDate.set(dates[0].clone().hour(0).minute(0).second(0));\n    // this.endDate.set(dates[1].clone().hour(23).minute(59).second(59));\n    // this.timeValue = { hour: 0, toHour: 0, minute: 23, toMinute: 59 };\n    // this.timepickerVariables.left.selectedHour = 0;\n    // this.timepickerVariables.left.selectedMinute = 0;\n    // this.timepickerVariables.right.selectedHour = 23;\n    // this.timepickerVariables.right.selectedMinute = 59;\n\n    // this.showRangeLabelOnInput && label !== this.localeDay.customRangeLabel ? this.chosenLabel = label : this.calculateChosenLabel();\n\n    // // this.autoApply.set(true);\n    // if (!this.hasTimePicker()) {\n    //   if(this.startDate()) {\n    //     this.startDate.set(this.startDate()?.startOf('day'));\n    //   }\n    //   if(this.endDate()) {\n    //     this.endDate.set(this.endDate()?.endOf('day'));\n    //   }\n    // }\n    // if (!this.alwaysShowCalendars()) {\n    //   this.calendarShowing.set(false);\n    // }\n    // this.outClickRange.emit(range);\n\n    if (!this.keepCalendarOpeningWithRange() || !this.alwaysShowCalendars()) {\n      this.outSelectDateRange.emit({ quickRangeId: range.id, displayLabel: range.label, startDate: range.values?.[0], endDate: range.values?.[1] });\n\n      return;\n    }\n    // if (this.timePicker) {\n    //   this.renderTimePicker(SideEnum.left);\n    //   this.renderTimePicker(SideEnum.right);\n    // }\n    // if (this.getMaxDate() && this.getMaxDate().isSame(dates[0], 'month')) {\n    //   this.rightCalendar.month = this.rightCalendar.month && this.rightCalendar.month.month(dates[0].month());\n    //   this.rightCalendar.month = this.rightCalendar.month && this.rightCalendar.month.year(dates[0].year());\n    //   this.leftCalendar.month = this.leftCalendar.month && this.leftCalendar.month.month(dates[0].month() - 1);\n    //   this.leftCalendar.month = this.leftCalendar.month && this.leftCalendar.month.year(dates[1].year());\n\n    //   return this.updateCalendars();\n    // }\n    // this.leftCalendar.month = this.leftCalendar.month && this.leftCalendar.month.month(dates[0].month());\n    // this.leftCalendar.month = this.leftCalendar.month && this.leftCalendar.month.year(dates[0].year());\n    // const nextMonth = dates[0].clone().add(1, 'month');\n\n    // this.rightCalendar.month = this.rightCalendar.month && this.rightCalendar.month.month(nextMonth.month());\n    // this.rightCalendar.month = this.rightCalendar.month && this.rightCalendar.month.year(nextMonth.year());\n    // this.updateCalendars();\n\n    return;\n  }\n\n  protected handlerClickCancel(event: Event) {\n    event.stopPropagation();\n    // this.startDate.set(dayjs(0));\n    // this.endDate.set(dayjs(0));\n    this.outCancel.emit('');\n  }\n\n  protected handlerChangeFlagMouse(flagMouse: IFlagMouse) {\n    this.outChangStageFlagMouse.emit(flagMouse);\n  }\n\n  protected handlerFunctionsControl(event: ICalendarFunctionControlEvent) {\n    this.calendarFunctionControlEvent.set(event);\n  }\n\n  ngOnDestroy() {\n    this.timeouts().forEach(item => clearTimeout(item));\n    // this.onDestroy.next();\n    // this.onDestroy.complete();\n  }\n}\n","<div #pickerContainer\n  class=\"libs-ui-component-custom_ranges flex rounded-[4px] bg-[#ffffff] z-[1000] overflow-[hidden] relative inline\"\n  [class.flex-row-reverse]=\"positionQuickRanges() === 'right'\">\n  @if (!isSingle()) {\n    <div class=\"libs-ui-component-custom_ranges-ranges {{ classInclude() || '' }}\"\n      [class.border-l-[#e6e8ed]]=\"positionQuickRanges() === 'right' && showCalTableInRanges()\"\n      [class.border-l]=\"positionQuickRanges() === 'right' && showCalTableInRanges()\"\n      [class.border-r-[#e6e8ed]]=\"positionQuickRanges() === 'left' && showCalTableInRanges()\"\n      [class.border-r]=\"positionQuickRanges() === 'left' && showCalTableInRanges()\"\n      [class.!min-h-[260px]]=\"showCalTableInRanges() && !isSingle()\"\n      [class.!min-h-[300px]]=\"hasTimePicker() && !isSingle()\"\n      [class.!w-[160px]]=\"!widthByParent()\"\n      [class.!w-full]=\"widthByParent()\">\n      @for (range of quickRangesArray(); track range.id) {\n        <div class=\"flex items-center hover:bg-[var(--libs-ui-color-light-3)] cursor-pointer px-[16px] py-[8px]\"\n          [class.libs-ui-selected-range]=\"range.id === chosenQuickRange() && showCustomRangeLabel()\"\n          [class.bg-[var(--libs-ui-color-light-3)]]=\"range.id === chosenQuickRange() || range.id === selectedQuickRange()\"\n          (click)=\"handlerClickRange($event, range)\">\n          <div class=\"libs-ui-font-h5r flex text-[#333333] min-w-0 w-full\">\n            <div LibsUiComponentsPopoverDirective\n              type=\"text\"\n              [config]=\"{maxWidth:160,direction:'top',zIndex:(zIndex() ||1000) + 1}\"\n              [innerHTML]=\"range.label\"\n              (click)=\"handlerClickRange($event, range)\">\n            </div>\n          </div>\n          <i class=\"text-[12px] ml-[16px]\"\n            [class.libs-ui-icon-check]=\"range.id === selectedQuickRange()\"\n            [class.text-[var(--libs-ui-color-default)]]=\"range.id === selectedQuickRange()\"></i>\n        </div>\n      }\n    </div>\n  }\n  @if (showCalTableInRanges()) {\n    <div class=\"m-[16px] w-full\">\n      <libs_ui-components-datetime-picker-custom_ranges-calendar [isSingle]=\"isSingle()\"\n        [autoApply]=\"autoApply()\"\n        [zIndex]=\"zIndex()\"\n        [flagMouse]=\"flagMouse()\"\n        [dateOptions]=\"dateOptions()\"\n        [hasTimePicker]=\"hasTimePicker()\"\n        [quickRangesArray]=\"quickRangesArray()\"\n        [startDate]=\"startDate()\"\n        [endDate]=\"endDate()\"\n        [classInclude]=\"'w-full'\"\n        (outCancel)=\"handlerCancel()\"\n        (outPickerDate)=\"handlerPickerDate($event)\"\n        (outFunctionsControl)=\"handlerFunctionsControl($event)\"\n        (outChangStageFlagMouse)=\"handlerChangeFlagMouse($event)\" />\n    </div>\n  }\n</div>\n"]}
@@ -0,0 +1,135 @@
1
+ import { signal } from "@angular/core";
2
+ import { UtilsHttpParamsRequestInstance, UtilsCache, UtilsLanguageConstants } from "@libs-ui/utils";
3
+ import { returnDetailObject, returnListObject } from "@libs-ui/services-http-request";
4
+ const getMonthsDefault = () => {
5
+ return [
6
+ {
7
+ id: 1,
8
+ label: 'i18n_january',
9
+ maxDays: 31
10
+ },
11
+ {
12
+ id: 2,
13
+ label: 'i18n_february',
14
+ maxDays: 29
15
+ },
16
+ {
17
+ id: 3,
18
+ label: 'i18n_march',
19
+ maxDays: 31
20
+ },
21
+ {
22
+ id: 4,
23
+ label: 'i18n_april',
24
+ maxDays: 30
25
+ },
26
+ {
27
+ id: 5,
28
+ label: 'i18n_may',
29
+ maxDays: 31
30
+ },
31
+ {
32
+ id: 6,
33
+ label: 'i18n_june',
34
+ maxDays: 30
35
+ },
36
+ {
37
+ id: 7,
38
+ label: 'i18n_july',
39
+ maxDays: 31
40
+ },
41
+ {
42
+ id: 8,
43
+ label: 'i18n_august',
44
+ maxDays: 31
45
+ },
46
+ {
47
+ id: 9,
48
+ label: 'i18n_september',
49
+ maxDays: 30
50
+ },
51
+ {
52
+ id: 10,
53
+ label: 'i18n_october',
54
+ maxDays: 31
55
+ },
56
+ {
57
+ id: 11,
58
+ label: 'i18n_november',
59
+ maxDays: 30
60
+ },
61
+ {
62
+ id: 12,
63
+ label: 'i18n_december',
64
+ maxDays: 31
65
+ }
66
+ ];
67
+ };
68
+ export const getMonthsListConfig = (translate) => {
69
+ return {
70
+ type: 'text',
71
+ httpRequestData: signal({
72
+ serviceOther: returnListObject(getMonthsDefault()),
73
+ functionName: 'list',
74
+ argumentsValue: []
75
+ }),
76
+ configTemplateText: signal({
77
+ fieldKey: 'id',
78
+ autoScrollToItemSelected: true,
79
+ getValue: (item) => {
80
+ const label = translate.instant(item.label || ' ', { year: '&#32;' });
81
+ return label.substring(0, UtilsCache.getLang() === UtilsLanguageConstants.VI ? label.length : 3);
82
+ },
83
+ getClassIncludePopover: () => 'libs-ui-font-h5r'
84
+ })
85
+ };
86
+ };
87
+ export const getMonthsDetailById = () => {
88
+ return {
89
+ serviceOther: returnDetailObject(UtilsHttpParamsRequestInstance(), getMonthsDefault()),
90
+ functionName: 'detailByData',
91
+ argumentsValue: [],
92
+ guideAutoUpdateArgumentsValue: {
93
+ paging: {},
94
+ detailById: {
95
+ fieldUpdate: '[0]',
96
+ fieldGetValue: '',
97
+ subFieldUpdate: 'keys'
98
+ }
99
+ }
100
+ };
101
+ };
102
+ export const getYearsListConfig = (listOfYears = []) => {
103
+ return {
104
+ type: 'text',
105
+ httpRequestData: signal({
106
+ serviceOther: returnListObject(listOfYears),
107
+ functionName: 'list',
108
+ argumentsValue: []
109
+ }),
110
+ configTemplateText: signal({
111
+ fieldKey: 'id',
112
+ autoScrollToItemSelected: true,
113
+ getValue: (item) => {
114
+ return item.label;
115
+ },
116
+ getClassIncludeTooltip: () => 'libs-ui-font-h5r'
117
+ })
118
+ };
119
+ };
120
+ export const getYearsDetailById = (listOfYears = []) => {
121
+ return {
122
+ serviceOther: returnDetailObject(UtilsHttpParamsRequestInstance(), listOfYears),
123
+ functionName: 'detailByData',
124
+ argumentsValue: [],
125
+ guideAutoUpdateArgumentsValue: {
126
+ paging: {},
127
+ detailById: {
128
+ fieldUpdate: '[0]',
129
+ fieldGetValue: '',
130
+ subFieldUpdate: 'keys'
131
+ }
132
+ }
133
+ };
134
+ };
135
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"calendar.define.js","sourceRoot":"","sources":["../../../../../../../libs-ui/components/datetime/picker/src/defines/calendar.define.ts"],"names":[],"mappings":"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","sourcesContent":["import { IListConfigItem } from \"@libs-ui/components-list\";\nimport { ICalendarMonthItem } from \"../interfaces/calendar-variables.interface\";\nimport { signal } from \"@angular/core\";\nimport { UtilsHttpParamsRequestInstance, UtilsCache, UtilsLanguageConstants } from \"@libs-ui/utils\";\nimport { TranslateService } from \"@ngx-translate/core\";\nimport { IHttpRequestConfig, returnDetailObject, returnListObject } from \"@libs-ui/services-http-request\";\n\nconst getMonthsDefault = (): Array<ICalendarMonthItem> => {\n  return [\n    {\n      id: 1,\n      label: 'i18n_january',\n      maxDays: 31\n    },\n    {\n      id: 2,\n      label: 'i18n_february',\n      maxDays: 29\n    },\n    {\n      id: 3,\n      label: 'i18n_march',\n      maxDays: 31\n    },\n    {\n      id: 4,\n      label: 'i18n_april',\n      maxDays: 30\n    },\n    {\n      id: 5,\n      label: 'i18n_may',\n      maxDays: 31\n    },\n    {\n      id: 6,\n      label: 'i18n_june',\n      maxDays: 30\n    },\n    {\n      id: 7,\n      label: 'i18n_july',\n      maxDays: 31\n    },\n    {\n      id: 8,\n      label: 'i18n_august',\n      maxDays: 31\n    },\n    {\n      id: 9,\n      label: 'i18n_september',\n      maxDays: 30\n    },\n    {\n      id: 10,\n      label: 'i18n_october',\n      maxDays: 31\n    },\n    {\n      id: 11,\n      label: 'i18n_november',\n      maxDays: 30\n    },\n    {\n      id: 12,\n      label: 'i18n_december',\n      maxDays: 31\n    }\n  ];\n};\n\nexport const getMonthsListConfig = (translate: TranslateService): IListConfigItem => {\n  return {\n    type: 'text',\n    httpRequestData: signal({\n      serviceOther: returnListObject(getMonthsDefault()),\n      functionName: 'list',\n      argumentsValue: []\n    }),\n    configTemplateText: signal({\n      fieldKey: 'id',\n      autoScrollToItemSelected: true,\n      getValue: (item: { id: string, label: string }) => {\n        const label = translate.instant(item.label || ' ', { year: '&#32;' });\n\n        return label.substring(0, UtilsCache.getLang() === UtilsLanguageConstants.VI ? label.length : 3);\n      },\n      getClassIncludePopover: () => 'libs-ui-font-h5r'\n    })\n  };\n};\n\nexport const getMonthsDetailById = (): IHttpRequestConfig => {\n  return {\n    serviceOther: returnDetailObject(UtilsHttpParamsRequestInstance(), getMonthsDefault()),\n    functionName: 'detailByData',\n    argumentsValue: [],\n    guideAutoUpdateArgumentsValue: {\n      paging: {},\n      detailById: {\n        fieldUpdate: '[0]',\n        fieldGetValue: '',\n        subFieldUpdate: 'keys'\n      }\n    }\n  };\n};\n\nexport const getYearsListConfig = (listOfYears: Array<{ id: number, label: string }> = []): IListConfigItem => {\n  return {\n    type: 'text',\n    httpRequestData: signal({\n      serviceOther: returnListObject(listOfYears),\n      functionName: 'list',\n      argumentsValue: []\n    }),\n    configTemplateText: signal({\n      fieldKey: 'id',\n      autoScrollToItemSelected: true,\n      getValue: (item: { id: string, label: string }) => {\n        return item.label;\n      },\n      getClassIncludeTooltip: () => 'libs-ui-font-h5r'\n    })\n  };\n};\n\nexport const getYearsDetailById = (listOfYears: Array<{ id: number, label: string }> = []): IHttpRequestConfig => {\n  return {\n    serviceOther: returnDetailObject(UtilsHttpParamsRequestInstance(), listOfYears),\n    functionName: 'detailByData',\n    argumentsValue: [],\n    guideAutoUpdateArgumentsValue: {\n      paging: {},\n      detailById: {\n        fieldUpdate: '[0]',\n        fieldGetValue: '',\n        subFieldUpdate: 'keys'\n      }\n    }\n  };\n};\n"]}
@@ -0,0 +1,55 @@
1
+ import { get, UtilsCache, UtilsLanguageConstants } from "@libs-ui/utils";
2
+ import dayjs from 'dayjs';
3
+ export const getDateOptions = () => {
4
+ const dateOptions = {
5
+ [UtilsLanguageConstants.VI]: {
6
+ "monthNames": ["Tháng 1", "Tháng 2", "Tháng 3", "Tháng 4", "Tháng 5", "Tháng 6", "Tháng 7", "Tháng 8", "Tháng 9", "Tháng 10", "Tháng 11", "Tháng 12"],
7
+ "ranges": { "today": "Hôm nay", "yesterday": "Hôm qua", "_7days_ago": "7 ngày trước", "_30days_ago": "30 ngày trước", "this_month": "Tháng này", "last_month": "Tháng trước", "_3months_ago": "90 ngày trước" },
8
+ "daysOfWeek": ["T2", "T3", "T4", "T5", "T6", "T7", "CN"],
9
+ "applyLabel": "Lưu",
10
+ "cancelLabel": "Huỷ bỏ",
11
+ "fromLabel": "Từ",
12
+ "toLabel": "Đến",
13
+ "customRangeLabel": "Tùy Chỉnh"
14
+ },
15
+ [UtilsLanguageConstants.EN]: {
16
+ "monthNames": ["Jan", "Feb", "Mar", "Apr", "May", "Jun", "Jul", "Aug", "Sep", "Oct", "Nov", "Dec"],
17
+ "ranges": { "today": "Today", "yesterday": "Yesterday", "_7days_ago": "7 days ago", "_30days_ago": "30 days ago", "this_month": "This month", "last_month": "Last month", "_3months_ago": "90 days ago" },
18
+ "daysOfWeek": ["Mo", "Tu", "We", "Th", "Fr", "Sa", "Su"],
19
+ "applyLabel": "Apply",
20
+ "cancelLabel": "Cancel",
21
+ "fromLabel": "From",
22
+ "toLabel": "To",
23
+ "customRangeLabel": "Customize"
24
+ }
25
+ };
26
+ return get(dateOptions, UtilsCache.getLang());
27
+ };
28
+ export const defaultLocaleConfig = () => {
29
+ return {
30
+ direction: 'ltr',
31
+ separator: ' - ',
32
+ weekLabel: 'W',
33
+ applyLabel: 'Apply',
34
+ cancelLabel: 'Cancel',
35
+ clearLabel: 'Clear',
36
+ customRangeLabel: 'customRangeLabel',
37
+ daysOfWeek: [],
38
+ monthNames: [],
39
+ firstDay: 1
40
+ };
41
+ };
42
+ export const getDateRangeDefault = () => {
43
+ return {
44
+ today: [dayjs().hour(0).minute(0).second(0).millisecond(0), dayjs().hour(23).minute(59).second(59)],
45
+ yesterday: [dayjs().subtract(1, 'days').hour(0).minute(0).second(0).millisecond(0), dayjs().subtract(1, 'days').hour(23).minute(59).second(59)],
46
+ _7days_ago: [dayjs().subtract(6, 'days').hour(0).second(0).minute(0).millisecond(0), dayjs().hour(23).minute(59).second(59)],
47
+ _30days_ago: [dayjs().subtract(29, 'days').hour(0).second(0).minute(0).millisecond(0), dayjs().hour(23).minute(59).second(59)],
48
+ this_month: [dayjs().startOf('month'), dayjs().endOf('month')],
49
+ last_month: [dayjs().subtract(1, 'month').startOf('month'), dayjs().subtract(1, 'month').endOf('month')],
50
+ _3months_ago: [dayjs().subtract(89, 'days').hour(0).second(0).minute(0).millisecond(0), dayjs().hour(23).minute(59).second(59)],
51
+ };
52
+ };
53
+ export const DEFAULT_MIN_YEAR = 1945;
54
+ export const DEFAULT_MAX_YEAR = 2100;
55
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"date-options.define.js","sourceRoot":"","sources":["../../../../../../../libs-ui/components/datetime/picker/src/defines/date-options.define.ts"],"names":[],"mappings":"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","sourcesContent":["import { get, UtilsCache, UtilsLanguageConstants } from \"@libs-ui/utils\";\nimport { LocalizationConfig } from \"../interfaces/picker.interface\";\nimport dayjs from 'dayjs';\n\nexport const getDateOptions = (): LocalizationConfig => {\n  const dateOptions = {\n    [UtilsLanguageConstants.VI]: {\n      \"monthNames\": [\"Tháng 1\", \"Tháng 2\", \"Tháng 3\", \"Tháng 4\", \"Tháng 5\", \"Tháng 6\", \"Tháng 7\", \"Tháng 8\", \"Tháng 9\", \"Tháng 10\", \"Tháng 11\", \"Tháng 12\"],\n      \"ranges\": { \"today\": \"Hôm nay\", \"yesterday\": \"Hôm qua\", \"_7days_ago\": \"7 ngày trước\", \"_30days_ago\": \"30 ngày trước\", \"this_month\": \"Tháng này\", \"last_month\": \"Tháng trước\", \"_3months_ago\": \"90 ngày trước\" },\n      \"daysOfWeek\": [\"T2\", \"T3\", \"T4\", \"T5\", \"T6\", \"T7\", \"CN\"],\n      \"applyLabel\": \"Lưu\",\n      \"cancelLabel\": \"Huỷ bỏ\",\n      \"fromLabel\": \"Từ\",\n      \"toLabel\": \"Đến\",\n      \"customRangeLabel\": \"Tùy Chỉnh\"\n    },\n    [UtilsLanguageConstants.EN]: {\n      \"monthNames\": [\"Jan\", \"Feb\", \"Mar\", \"Apr\", \"May\", \"Jun\", \"Jul\", \"Aug\", \"Sep\", \"Oct\", \"Nov\", \"Dec\"],\n      \"ranges\": { \"today\": \"Today\", \"yesterday\": \"Yesterday\", \"_7days_ago\": \"7 days ago\", \"_30days_ago\": \"30 days ago\", \"this_month\": \"This month\", \"last_month\": \"Last month\", \"_3months_ago\": \"90 days ago\" },\n      \"daysOfWeek\": [\"Mo\", \"Tu\", \"We\", \"Th\", \"Fr\", \"Sa\", \"Su\"],\n      \"applyLabel\": \"Apply\",\n      \"cancelLabel\": \"Cancel\",\n      \"fromLabel\": \"From\",\n      \"toLabel\": \"To\",\n      \"customRangeLabel\": \"Customize\"\n    }\n  };\n\n  return get(dateOptions, UtilsCache.getLang());\n};\n\nexport const defaultLocaleConfig = () => {\n  return {\n    direction: 'ltr',\n    separator: ' - ',\n    weekLabel: 'W',\n    applyLabel: 'Apply',\n    cancelLabel: 'Cancel',\n    clearLabel: 'Clear',\n    customRangeLabel: 'customRangeLabel',\n    daysOfWeek: [],\n    monthNames: [],\n    firstDay: 1\n  }\n};\n\nexport const getDateRangeDefault = (): { [key: string]: Array<dayjs.Dayjs> } => {\n  return {\n    today: [dayjs().hour(0).minute(0).second(0).millisecond(0), dayjs().hour(23).minute(59).second(59)],\n    yesterday: [dayjs().subtract(1, 'days').hour(0).minute(0).second(0).millisecond(0), dayjs().subtract(1, 'days').hour(23).minute(59).second(59)],\n    _7days_ago: [dayjs().subtract(6, 'days').hour(0).second(0).minute(0).millisecond(0), dayjs().hour(23).minute(59).second(59)],\n    _30days_ago: [dayjs().subtract(29, 'days').hour(0).second(0).minute(0).millisecond(0), dayjs().hour(23).minute(59).second(59)],\n    this_month: [dayjs().startOf('month'), dayjs().endOf('month')],\n    last_month: [dayjs().subtract(1, 'month').startOf('month'), dayjs().subtract(1, 'month').endOf('month')],\n    _3months_ago: [dayjs().subtract(89, 'days').hour(0).second(0).minute(0).millisecond(0), dayjs().hour(23).minute(59).second(59)],\n  };\n};\n\nexport const DEFAULT_MIN_YEAR = 1945;\nexport const DEFAULT_MAX_YEAR = 2100;"]}
@@ -0,0 +1,2 @@
1
+ export * from './picker.component';
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzLXVpL2NvbXBvbmVudHMvZGF0ZXRpbWUvcGlja2VyL3NyYy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxjQUFjLG9CQUFvQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0ICogZnJvbSAnLi9waWNrZXIuY29tcG9uZW50JztcbiJdfQ==
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FsZW5kYXItZW1pdC5pbnRlcmZhY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzLXVpL2NvbXBvbmVudHMvZGF0ZXRpbWUvcGlja2VyL3NyYy9pbnRlcmZhY2VzL2NhbGVuZGFyLWVtaXQuaW50ZXJmYWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgKiBhcyBkYXlqcyBmcm9tIFwiZGF5anNcIjtcbmltcG9ydCB7IElTcGxpdFBpY2tlckRhdGUgfSBmcm9tIFwiLi9jYWxlbmRhci12YXJpYWJsZXMuaW50ZXJmYWNlXCI7XG5cbmV4cG9ydCBpbnRlcmZhY2UgSUVtaXREYXRlQ2FsZW5kYXIge1xuICBkaXNwbGF5TGFiZWw/OiBzdHJpbmc7XG4gIHN0YXJ0RGF0ZTogZGF5anMuRGF5anMgfCB1bmRlZmluZWQ7XG4gIGVuZERhdGU6IGRheWpzLkRheWpzIHwgdW5kZWZpbmVkO1xuICBkZXRhaWxEYXRlUGlja2VyOiBJU3BsaXRQaWNrZXJEYXRlO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIElFbWl0U2luZ2xlRGF0ZSB7XG4gIGRpc3BsYXlMYWJlbD86IHN0cmluZzsgLy8gbGFiZWwgaGnhu4NuIHRo4buLIG5nb8OgaSBkYXRlIHBpY2tlciBmb3JtXG4gIGRhdGU6IHN0cmluZyB8IGRheWpzLkRheWpzIHwgdW5kZWZpbmVkO1xuICB2YWx1ZXM6IHtcbiAgICBtb250aDogc3RyaW5nIHwgbnVtYmVyO1xuICAgIHllYXI6IHN0cmluZyB8IG51bWJlcjtcbiAgICBkYXk6IHN0cmluZyB8IG51bWJlcjtcbiAgICBob3VyPzogc3RyaW5nIHwgbnVtYmVyO1xuICAgIG1pbnV0ZT86IHN0cmluZyB8IG51bWJlcjtcbiAgfTtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBJRW1pdERhdGVSYW5nZSB7XG4gIHF1aWNrUmFuZ2VJZD86IHN0cmluZzsgLy8gaWQgcXVpY2sgcmFuZ2VcbiAgZGlzcGxheUxhYmVsPzogc3RyaW5nOyAvLyBsYWJlbCBoaeG7g24gdGjhu4sgbmdvw6BpIGRhdGUgcGlja2VyIGZvcm1cbiAgc3RhcnREYXRlOiBzdHJpbmcgfCBkYXlqcy5EYXlqcyB8IHVuZGVmaW5lZDtcbiAgZW5kRGF0ZTogc3RyaW5nIHwgZGF5anMuRGF5anMgfCB1bmRlZmluZWQ7XG59XG4iXX0=
@@ -0,0 +1,6 @@
1
+ export var SideEnum;
2
+ (function (SideEnum) {
3
+ SideEnum["left"] = "left";
4
+ SideEnum["right"] = "right";
5
+ })(SideEnum || (SideEnum = {}));
6
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FsZW5kYXItdmFyaWFibGVzLmludGVyZmFjZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMtdWkvY29tcG9uZW50cy9kYXRldGltZS9waWNrZXIvc3JjL2ludGVyZmFjZXMvY2FsZW5kYXItdmFyaWFibGVzLmludGVyZmFjZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUF3REEsTUFBTSxDQUFOLElBQVksUUFHWDtBQUhELFdBQVksUUFBUTtJQUNsQix5QkFBYSxDQUFBO0lBQ2IsMkJBQWUsQ0FBQTtBQUNqQixDQUFDLEVBSFcsUUFBUSxLQUFSLFFBQVEsUUFHbkIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBXcml0YWJsZVNpZ25hbCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0ICogYXMgZGF5anMgZnJvbSAnZGF5anMnO1xuXG5leHBvcnQgaW50ZXJmYWNlIElDYWxlbmRhclZhcmlhYmxlcyB7XG4gIGxlZnQ6IFdyaXRhYmxlU2lnbmFsPElDYWxlbmRhclZhcmlhYmxlc1NpZGU+O1xuICByaWdodDogV3JpdGFibGVTaWduYWw8SUNhbGVuZGFyVmFyaWFibGVzU2lkZT47XG59XG5pbnRlcmZhY2UgSUNhbGVuZGFyVmFyaWFibGVzU2lkZSB7XG4gIGNhbENvbHM/OiBXcml0YWJsZVNpZ25hbDxBcnJheTxudW1iZXI+PjtcbiAgY2FsUm93cz86IFdyaXRhYmxlU2lnbmFsPEFycmF5PG51bWJlcj4+O1xuICBjYWxlbmRhcj86IElDYWxlbmRhcjtcbiAgY2xhc3Nlcz86IElDYWxlbmRhclZhcmlhYmxlc0NsYXNzZXM7XG4gIGRheU9mV2Vlaz86IG51bWJlcjtcbiAgZGF5c0luTGFzdE1vbnRoPzogbnVtYmVyO1xuICBkYXlzSW5Nb250aD86IG51bWJlcjtcbiAgZHJvcGRvd25zPzogV3JpdGFibGVTaWduYWw8SUNhbGVuZGFyVmFyaWFibGVzRHJvcGRvd25zPjtcbiAgZmlyc3REYXk/OiBkYXlqcy5EYXlqcztcbiAgaG91cj86IG51bWJlcjtcbiAgbGFzdERheT86IGRheWpzLkRheWpzO1xuICBsYXN0TW9udGg/OiBudW1iZXI7XG4gIGxhc3RZZWFyPzogbnVtYmVyO1xuICBtYXhEYXRlPzogZGF5anMuRGF5anM7XG4gIG1pbkRhdGU/OiBkYXlqcy5EYXlqcztcbiAgbWludXRlPzogbnVtYmVyO1xuICBtb250aD86IG51bWJlcjtcbiAgc2Vjb25kPzogbnVtYmVyO1xuICB5ZWFyPzogbnVtYmVyO1xufVxuaW50ZXJmYWNlIElDYWxlbmRhclZhcmlhYmxlc0NsYXNzZXMge1xuICBbaW5kZXg6IG51bWJlcl06IHsgW2luZGV4OiBudW1iZXJdOiBzdHJpbmcsIGNsYXNzTGlzdD86IHN0cmluZyB9O1xufVxuaW50ZXJmYWNlIElDYWxlbmRhclZhcmlhYmxlc0Ryb3Bkb3ducyB7XG4gIGN1cnJlbnRNb250aD86IG51bWJlcjtcbiAgY3VycmVudFllYXI/OiBudW1iZXI7XG4gIGluTWF4WWVhcj86IGJvb2xlYW47XG4gIGluTWluWWVhcj86IGJvb2xlYW47XG4gIG1heFllYXI/OiBudW1iZXI7XG4gIG1pblllYXI/OiBudW1iZXI7XG4gIG1vbnRoQXJyYXlzPzogV3JpdGFibGVTaWduYWw8QXJyYXk8bnVtYmVyPj47XG4gIHllYXJBcnJheXM/OiBXcml0YWJsZVNpZ25hbDxBcnJheTxudW1iZXI+Pjtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBJQ2FsZW5kYXIge1xuICBbaW5kZXg6IG51bWJlcl06IEFycmF5PGRheWpzLkRheWpzPjtcbiAgZmlyc3REYXk/OiBkYXlqcy5EYXlqcztcbiAgbGFzdERheT86IGRheWpzLkRheWpzO1xufVxuXG50eXBlIFRZUEVfRFJPUERPV05fTU9OVEhfSUQgPSAxIHwgMiB8IDMgfCA0IHwgNSB8IDYgfCA3IHwgOCB8IDkgfCAxMCB8IDExIHwgMTI7XG5cbmV4cG9ydCBpbnRlcmZhY2UgSUNhbGVuZGFyTW9udGhJdGVtIHtcbiAgaWQ6IFRZUEVfRFJPUERPV05fTU9OVEhfSUQ7XG4gIGxhYmVsOiBzdHJpbmc7XG4gIG1heERheXM6IG51bWJlcjtcbn1cblxuZXhwb3J0IGVudW0gU2lkZUVudW0ge1xuICBsZWZ0ID0gJ2xlZnQnLFxuICByaWdodCA9ICdyaWdodCdcbn1cblxuZXhwb3J0IGludGVyZmFjZSBJRGF0ZVJhbmdlIHtcbiAgaWQ6IHN0cmluZztcbiAgbGFiZWw6IHN0cmluZztcbiAgdmFsdWVzPzogQXJyYXk8ZGF5anMuRGF5anM+XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgSVNwbGl0UGlja2VyRGF0ZSB7XG4gIHN0YXJ0OiBXcml0YWJsZVNpZ25hbDx7XG4gICAgbW9udGg6IHN0cmluZyB8IG51bWJlcjtcbiAgICB5ZWFyOiBzdHJpbmcgfCBudW1iZXI7XG4gICAgZGF5OiBzdHJpbmcgfCBudW1iZXI7XG4gICAgaG91cjogc3RyaW5nIHwgbnVtYmVyO1xuICAgIG1pbnV0ZTogc3RyaW5nIHwgbnVtYmVyO1xuICB9PjtcbiAgZW5kOiBXcml0YWJsZVNpZ25hbDx7XG4gICAgbW9udGg6IHN0cmluZyB8IG51bWJlcjtcbiAgICB5ZWFyOiBzdHJpbmcgfCBudW1iZXI7XG4gICAgZGF5OiBzdHJpbmcgfCBudW1iZXI7XG4gICAgaG91cjogc3RyaW5nIHwgbnVtYmVyO1xuICAgIG1pbnV0ZTogc3RyaW5nIHwgbnVtYmVyO1xuICB9Pjtcbn0iXX0=
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZnVuY3Rpb24tY29udHJvbC5pbnRlcmZhY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzLXVpL2NvbXBvbmVudHMvZGF0ZXRpbWUvcGlja2VyL3NyYy9pbnRlcmZhY2VzL2Z1bmN0aW9uLWNvbnRyb2wuaW50ZXJmYWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgZGF5anMgZnJvbSAnZGF5anMnO1xuXG5leHBvcnQgaW50ZXJmYWNlIElEYXRlVGltZVBpY2tlckZ1bmN0aW9uQ29udHJvbEV2ZW50IHtcbiAgY2hlY2tJc1ZhbGlkOiAoKSA9PiBQcm9taXNlPGJvb2xlYW4+O1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIElDYWxlbmRhckZ1bmN0aW9uQ29udHJvbEV2ZW50IHtcbiAgYnVpbGREZWZhdWx0UmFuZ2U6IChzdGFydERhdGU6IGRheWpzLkRheWpzLCBlbmREYXRlOiBkYXlqcy5EYXlqcykgPT4gUHJvbWlzZTx2b2lkPjtcbiAgYXBwbHlUb1NlbGVjdDogKCkgPT4gUHJvbWlzZTx2b2lkPjtcbn0iXX0=
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGlja2VyLmludGVyZmFjZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL2xpYnMtdWkvY29tcG9uZW50cy9kYXRldGltZS9waWNrZXIvc3JjL2ludGVyZmFjZXMvcGlja2VyLmludGVyZmFjZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0ICogYXMgZGF5anMgZnJvbSBcImRheWpzXCI7XG5cbmV4cG9ydCBpbnRlcmZhY2UgSUNob3NlbkRhdGUge1xuICBzZWxlY3RlZExhYmVsPzogc3RyaW5nO1xuICBzdGFydERhdGU/OiBkYXlqcy5EYXlqcztcbiAgZW5kRGF0ZT86IGRheWpzLkRheWpzO1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIExvY2FsaXphdGlvbkNvbmZpZyB7XG4gIG1vbnRoTmFtZXM6IHN0cmluZ1tdO1xuICByYW5nZXM6IHsgW2tleTogc3RyaW5nXTogc3RyaW5nIH07XG4gIGRheXNPZldlZWs6IHN0cmluZ1tdO1xuICBhcHBseUxhYmVsOiBzdHJpbmc7XG4gIGNhbmNlbExhYmVsOiBzdHJpbmc7XG4gIGZyb21MYWJlbDogc3RyaW5nO1xuICB0b0xhYmVsOiBzdHJpbmc7XG4gIGN1c3RvbVJhbmdlTGFiZWw6IHN0cmluZztcbiAgZm9ybWF0Pzogc3RyaW5nO1xuICBkaXJlY3Rpb24/OiBzdHJpbmc7XG4gIHNlcGFyYXRvcj86IHN0cmluZztcbiAgd2Vla0xhYmVsPzogc3RyaW5nO1xuICBjbGVhckxhYmVsPzogc3RyaW5nO1xuICBmaXJzdERheT86IG51bWJlcjtcbiAgZGlzcGxheUZvcm1hdD86IHN0cmluZztcbn1cblxuZXhwb3J0IHR5cGUgVFlQRV9SQU5HRV9LRVkgPSAndG9kYXknIHwgJ3llc3RlcmRheScgfCAnXzdkYXlzX2FnbycgfCAnXzMwZGF5c19hZ28nIHwgJ3RoaXNfbW9udGgnIHwgJ2xhc3RfbW9udGgnIHwgJ18zbW9udGhzX2Fnbyc7XG4iXX0=
@@ -0,0 +1,4 @@
1
+ ;
2
+ ;
3
+ export {};
4
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGltZS12YXJpYWJsZXMuaW50ZXJmYWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy11aS9jb21wb25lbnRzL2RhdGV0aW1lL3BpY2tlci9zcmMvaW50ZXJmYWNlcy90aW1lLXZhcmlhYmxlcy5pbnRlcmZhY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBNEJDLENBQUM7QUFNRCxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgV3JpdGFibGVTaWduYWwgfSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xuaW1wb3J0ICogYXMgZGF5anMgZnJvbSBcImRheWpzXCI7XG5cbmV4cG9ydCBpbnRlcmZhY2UgSVRpbWVwaWNrZXJWYXJpYWJsZXMge1xuICBsZWZ0OiBXcml0YWJsZVNpZ25hbDxJVGltZXBpY2tlclZhcmlhYmxlc1NpZGU+O1xuICByaWdodDogV3JpdGFibGVTaWduYWw8SVRpbWVwaWNrZXJWYXJpYWJsZXNTaWRlPjtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBJVGltZXBpY2tlclZhcmlhYmxlc1NpZGUge1xuICBzZWxlY3RlZEhvdXI6IG51bWJlcjtcbiAgc2VsZWN0ZWRNaW51dGU6IG51bWJlcjtcbiAgaG91cnM/OiBBcnJheTxudW1iZXI+O1xuICBtaW51dGVzPzogQXJyYXk8bnVtYmVyPjtcbiAgbWludXRlc0xhYmVsPzogQXJyYXk8c3RyaW5nPjtcbiAgc2Vjb25kcz86IEFycmF5PG51bWJlcj47XG4gIHNlY29uZHNMYWJlbD86IEFycmF5PG51bWJlcj47XG4gIGRpc2FibGVkSG91cnM/OiBBcnJheTxudW1iZXI+O1xuICBkaXNhYmxlZE1pbnV0ZXM/OiBBcnJheTxudW1iZXI+O1xuICBkaXNhYmxlZFNlY29uZHM/OiBBcnJheTxudW1iZXI+O1xuICBzZWxlY3RlZFNlY29uZD86IG51bWJlcjtcbiAgc2VsZWN0ZWQ/OiBkYXlqcy5EYXlqcztcbn1cblxuZXhwb3J0IGludGVyZmFjZSBJVGltZXBpY2tlckl0ZW1WYWx1ZSB7XG4gIGxlZnRob3VyOiBXcml0YWJsZVNpZ25hbDxudW1iZXI+O1xuICBsZWZ0bWludXRlOiBXcml0YWJsZVNpZ25hbDxudW1iZXI+O1xuICByaWdodGhvdXI6IFdyaXRhYmxlU2lnbmFsPG51bWJlcj47XG4gIHJpZ2h0bWludXRlOiBXcml0YWJsZVNpZ25hbDxudW1iZXI+O1xufTtcbmV4cG9ydCBpbnRlcmZhY2UgSUNoZWNrVGltZXBpY2tlclNlbGVjdGVkIHtcbiAgbGVmdG1vbnRoOiBib29sZWFuO1xuICBsZWZ0eWVhcjogYm9vbGVhbjtcbiAgcmlnaHRtb250aDogYm9vbGVhbjtcbiAgcmlnaHR5ZWFyOiBib29sZWFuXG59O1xuZXhwb3J0IGludGVyZmFjZSBJU2VsZWN0ZWRPbGQge1xuICBzdGFydD86IGRheWpzLkRheWpzIHwgdW5kZWZpbmVkLFxuICBlbmQ/OiBkYXlqcy5EYXlqcyB8IHVuZGVmaW5lZFxufSJdfQ==