@libs-ui/components-datetime-dropdown 0.1.1-1
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/README.md +3 -0
- package/defines/date-dropdown.define.d.ts +40 -0
- package/directive/date-dropdown.directive.d.ts +11 -0
- package/dropdown.component.d.ts +89 -0
- package/esm2022/defines/date-dropdown.define.mjs +246 -0
- package/esm2022/directive/date-dropdown.directive.mjs +33 -0
- package/esm2022/dropdown.component.mjs +280 -0
- package/esm2022/index.mjs +3 -0
- package/esm2022/interfaces/date-dropdown.interface.mjs +3 -0
- package/esm2022/interfaces/emit-dropdown.interface.mjs +2 -0
- package/esm2022/interfaces/functions-control-event.interface.mjs +2 -0
- package/esm2022/interfaces/index.mjs +5 -0
- package/esm2022/interfaces/valid.interface.mjs +2 -0
- package/esm2022/item/child/child.component.mjs +124 -0
- package/esm2022/item/item.component.mjs +216 -0
- package/esm2022/libs-ui-components-datetime-dropdown.mjs +5 -0
- package/esm2022/pipes/build-list-by-date-type-.pipe.mjs +19 -0
- package/esm2022/pipes/build-width.pipe.mjs +23 -0
- package/fesm2022/libs-ui-components-datetime-dropdown.mjs +928 -0
- package/fesm2022/libs-ui-components-datetime-dropdown.mjs.map +1 -0
- package/index.d.ts +2 -0
- package/interfaces/date-dropdown.interface.d.ts +43 -0
- package/interfaces/emit-dropdown.interface.d.ts +11 -0
- package/interfaces/functions-control-event.interface.d.ts +11 -0
- package/interfaces/index.d.ts +4 -0
- package/interfaces/valid.interface.d.ts +10 -0
- package/item/child/child.component.d.ts +51 -0
- package/item/item.component.d.ts +60 -0
- package/package.json +33 -0
- package/pipes/build-list-by-date-type-.pipe.d.ts +15 -0
- package/pipes/build-width.pipe.d.ts +7 -0
|
@@ -0,0 +1,280 @@
|
|
|
1
|
+
import { ChangeDetectionStrategy, Component, computed, effect, inject, input, output, signal, untracked, viewChild } from '@angular/core';
|
|
2
|
+
import { LibsUiComponentsLabelComponent } from '@libs-ui/components-label';
|
|
3
|
+
import { TranslateModule, TranslateService } from '@ngx-translate/core';
|
|
4
|
+
import { fromEvent, Subject, takeUntil, timer } from 'rxjs';
|
|
5
|
+
import { CompareDate } from './defines/date-dropdown.define';
|
|
6
|
+
import { LibsUiComponentsDatetimeDropdownDirective } from './directive/date-dropdown.directive';
|
|
7
|
+
import { LibsUiComponentsDatetimeDropdownItemComponent } from './item/item.component';
|
|
8
|
+
import * as i0 from "@angular/core";
|
|
9
|
+
import * as i1 from "@ngx-translate/core";
|
|
10
|
+
export class LibsUiComponentsDatetimeDropdownComponent {
|
|
11
|
+
// #region PROPERTY
|
|
12
|
+
width = signal(0);
|
|
13
|
+
widthElement = signal(undefined);
|
|
14
|
+
widthLabel = signal(undefined);
|
|
15
|
+
widthLabelFrom = signal(0);
|
|
16
|
+
widthLabelTo = signal(0);
|
|
17
|
+
isErrorCompareDate = signal(undefined);
|
|
18
|
+
chooseDate = signal({ from: signal({}), to: signal({}) });
|
|
19
|
+
isResponsive = signal(undefined);
|
|
20
|
+
arrayFormat = computed(() => {
|
|
21
|
+
return this.typeFormat().split('-');
|
|
22
|
+
});
|
|
23
|
+
changeType = signal(undefined);
|
|
24
|
+
cacheWidthLabel = signal(undefined);
|
|
25
|
+
timeOut = signal(undefined);
|
|
26
|
+
onDestroy = new Subject();
|
|
27
|
+
functionsControl = new Map();
|
|
28
|
+
// #region INPUT
|
|
29
|
+
labelConfig = input(undefined);
|
|
30
|
+
widthDropdown = input(136, { transform: (value) => value ?? 136 });
|
|
31
|
+
zIndex = input(1200, { transform: (value) => value ?? 1200 });
|
|
32
|
+
maxYear = input(0);
|
|
33
|
+
minYear = input(0);
|
|
34
|
+
minWidth = input(undefined);
|
|
35
|
+
disable = input(false);
|
|
36
|
+
readonly = input(false);
|
|
37
|
+
isMultiple = input(false);
|
|
38
|
+
reverseYear = input(undefined);
|
|
39
|
+
isBorderError = input(false);
|
|
40
|
+
ignoreWidth100 = input(false);
|
|
41
|
+
widthByElement = input(false);
|
|
42
|
+
disableSecond = input(false);
|
|
43
|
+
typeFormat = input('month-day', { transform: (value) => value ?? 'month-day' });
|
|
44
|
+
fromAndToDateLabel = input({ from: 'i18n_label_from', to: 'i18n_to' });
|
|
45
|
+
listHasButtonUnSelectOption = input(false);
|
|
46
|
+
selectedDateTime = input(undefined);
|
|
47
|
+
isEmitAfterChanged = input(false); // dùng để emit mỗi lần chọn giá trị và lần đầu init
|
|
48
|
+
getItemYearDisplay = input();
|
|
49
|
+
ignoreFromAndToDateLabel = input(false);
|
|
50
|
+
classIncludeTextDisplayWhenNoSelect = input(undefined);
|
|
51
|
+
hiddenDate = input();
|
|
52
|
+
listMaxItemShow = input(undefined);
|
|
53
|
+
ignoreConvertYearSelected = input(false);
|
|
54
|
+
listKeysDisable = input(undefined);
|
|
55
|
+
ignoreAllowTimeEqual = input(true, { transform: (value) => value ?? true });
|
|
56
|
+
ignoreValidTimeCompare = input(false, { transform: (value) => value ?? false });
|
|
57
|
+
isCheckErrorWhenSelectItem = input(true, { transform: (value) => value ?? true });
|
|
58
|
+
ignoreRequiredValueSecondWhenNotValidRequired = input(false); // có validate giá trị thứ 2 khi validRequired không?
|
|
59
|
+
validRequired = input();
|
|
60
|
+
// #region OUTPUT
|
|
61
|
+
outFunctionsControl = output();
|
|
62
|
+
outSelectedDropdown = output(); // dùng cho trường hợp emit mỗi một lần chọn giá trị nên khi sử dụng phải check kĩ undefined
|
|
63
|
+
outChooseMultiDate = output();
|
|
64
|
+
outChooseSingleDate = output();
|
|
65
|
+
outChangStageFlagMouse = output();
|
|
66
|
+
/* VIEW CHILD */
|
|
67
|
+
containerRef = viewChild('parent');
|
|
68
|
+
labelFromRef = viewChild('labelFrom');
|
|
69
|
+
labelToRef = viewChild('labelTo');
|
|
70
|
+
// #region INJECT
|
|
71
|
+
translate = inject(TranslateService);
|
|
72
|
+
constructor() {
|
|
73
|
+
effect(() => {
|
|
74
|
+
const isMultiple = this.isMultiple();
|
|
75
|
+
if (!isMultiple) {
|
|
76
|
+
return;
|
|
77
|
+
}
|
|
78
|
+
untracked(() => {
|
|
79
|
+
this.changeType.set(true);
|
|
80
|
+
this.functionsControl.clear();
|
|
81
|
+
timer(0)
|
|
82
|
+
.pipe()
|
|
83
|
+
.subscribe(() => {
|
|
84
|
+
this.checkResponsive();
|
|
85
|
+
this.changeType.set(false);
|
|
86
|
+
});
|
|
87
|
+
});
|
|
88
|
+
});
|
|
89
|
+
}
|
|
90
|
+
ngOnInit() {
|
|
91
|
+
this.outFunctionsControl.emit(this.FunctionsControl);
|
|
92
|
+
if (this.selectedDateTime()) {
|
|
93
|
+
this.chooseDate.set(this.selectedDateTime());
|
|
94
|
+
}
|
|
95
|
+
}
|
|
96
|
+
ngAfterViewInit() {
|
|
97
|
+
fromEvent(window, 'resize').pipe(takeUntil(this.onDestroy)).subscribe(this.setWidthDate.bind(this));
|
|
98
|
+
this.widthLabel.set(undefined);
|
|
99
|
+
timer(0)
|
|
100
|
+
.pipe()
|
|
101
|
+
.subscribe(() => {
|
|
102
|
+
this.checkResponsive();
|
|
103
|
+
});
|
|
104
|
+
}
|
|
105
|
+
get FunctionsControl() {
|
|
106
|
+
return {
|
|
107
|
+
checkIsValid: this.validate.bind(this),
|
|
108
|
+
resetError: this.resetError.bind(this),
|
|
109
|
+
resetTime: this.resetDropdown.bind(this),
|
|
110
|
+
};
|
|
111
|
+
}
|
|
112
|
+
checkResponsive() {
|
|
113
|
+
this.isResponsive.set(false);
|
|
114
|
+
const widthElementParent = this.containerRef()?.nativeElement?.getBoundingClientRect().width || 0;
|
|
115
|
+
this.widthLabelFrom.set(this.labelFromRef()?.nativeElement?.getBoundingClientRect().width || 0);
|
|
116
|
+
this.widthLabelTo.set(this.labelToRef()?.nativeElement?.getBoundingClientRect().width || 0);
|
|
117
|
+
const spaceBetweenDate = this.arrayFormat().length * 2 + (this.fromAndToDateLabel().from ? 1 : 0);
|
|
118
|
+
const width = this.widthDropdown() * 4 + 8 * spaceBetweenDate + this.widthLabelFrom() + this.widthLabelTo();
|
|
119
|
+
if (widthElementParent < width) {
|
|
120
|
+
this.isResponsive.set(true);
|
|
121
|
+
}
|
|
122
|
+
}
|
|
123
|
+
handlerChangeSelectedKey(event, type) {
|
|
124
|
+
this.chooseDate.update((current) => {
|
|
125
|
+
if (current) {
|
|
126
|
+
current[type].set(event);
|
|
127
|
+
}
|
|
128
|
+
return current;
|
|
129
|
+
});
|
|
130
|
+
if (this.isEmitAfterChanged()) {
|
|
131
|
+
const dataEmit = this.isMultiple() ? this.chooseDate() : this.chooseDate()?.from();
|
|
132
|
+
if (dataEmit) {
|
|
133
|
+
this.outSelectedDropdown.emit(dataEmit);
|
|
134
|
+
}
|
|
135
|
+
}
|
|
136
|
+
this.applyDate();
|
|
137
|
+
}
|
|
138
|
+
async resetDropdown() {
|
|
139
|
+
this.functionsControl.forEach((control) => control.resetDropdown());
|
|
140
|
+
}
|
|
141
|
+
async resetError() {
|
|
142
|
+
this.functionsControl.forEach((control) => control.resetError());
|
|
143
|
+
}
|
|
144
|
+
setWidthDate() {
|
|
145
|
+
if (!this.containerRef() || !this.containerRef()?.nativeElement) {
|
|
146
|
+
return;
|
|
147
|
+
}
|
|
148
|
+
timer(0)
|
|
149
|
+
.pipe()
|
|
150
|
+
.subscribe(() => {
|
|
151
|
+
this.checkResponsive();
|
|
152
|
+
});
|
|
153
|
+
}
|
|
154
|
+
handlerFunctionControl(event, type) {
|
|
155
|
+
this.functionsControl.set(type, event);
|
|
156
|
+
}
|
|
157
|
+
async checkValid() {
|
|
158
|
+
let valid = true;
|
|
159
|
+
for (const control of this.functionsControl.values()) {
|
|
160
|
+
if (!(await control.checkIsValid())) {
|
|
161
|
+
valid = false;
|
|
162
|
+
}
|
|
163
|
+
}
|
|
164
|
+
if (this.compareDate()) {
|
|
165
|
+
valid = false;
|
|
166
|
+
}
|
|
167
|
+
return valid;
|
|
168
|
+
}
|
|
169
|
+
setError(error) {
|
|
170
|
+
this.functionsControl.forEach((control) => control.setError(error));
|
|
171
|
+
}
|
|
172
|
+
compareDate() {
|
|
173
|
+
const type = this.typeFormat().split('-');
|
|
174
|
+
const dateCompare = [];
|
|
175
|
+
type.forEach((item) => {
|
|
176
|
+
const from = this.chooseDate()?.from()[item];
|
|
177
|
+
const to = this.chooseDate()?.to()[item];
|
|
178
|
+
dateCompare.push({ from: from, to: to });
|
|
179
|
+
});
|
|
180
|
+
if (this.ignoreValidTimeCompare() || !this.checkCondition(true)) {
|
|
181
|
+
this.isErrorCompareDate.set(false);
|
|
182
|
+
return false;
|
|
183
|
+
}
|
|
184
|
+
if (CompareDate(dateCompare, this.ignoreAllowTimeEqual())) {
|
|
185
|
+
this.setError(true);
|
|
186
|
+
this.isErrorCompareDate.set(true);
|
|
187
|
+
return true;
|
|
188
|
+
}
|
|
189
|
+
this.isErrorCompareDate.set(false);
|
|
190
|
+
return false;
|
|
191
|
+
}
|
|
192
|
+
async validate() {
|
|
193
|
+
let valid = true;
|
|
194
|
+
if (!this.validRequired()) {
|
|
195
|
+
if (!this.checkCondition(false) && !this.ignoreRequiredValueSecondWhenNotValidRequired()) {
|
|
196
|
+
valid = await this.checkValid();
|
|
197
|
+
}
|
|
198
|
+
return valid;
|
|
199
|
+
}
|
|
200
|
+
return await this.checkValid();
|
|
201
|
+
}
|
|
202
|
+
checkCondition(hasValue) {
|
|
203
|
+
let checkValue = true;
|
|
204
|
+
const type = this.typeFormat().split('-');
|
|
205
|
+
type.forEach((item) => {
|
|
206
|
+
if (hasValue && (!this.chooseDate()?.from()[item] || !this.chooseDate()?.to()[item])) {
|
|
207
|
+
checkValue = false;
|
|
208
|
+
}
|
|
209
|
+
if (!hasValue && (this.chooseDate()?.from()[item] || this.chooseDate()?.to()[item])) {
|
|
210
|
+
checkValue = false;
|
|
211
|
+
}
|
|
212
|
+
});
|
|
213
|
+
return checkValue;
|
|
214
|
+
}
|
|
215
|
+
applyDate() {
|
|
216
|
+
this.setError(false);
|
|
217
|
+
this.isErrorCompareDate.set(false);
|
|
218
|
+
if (this.isCheckErrorWhenSelectItem() && !this.validate()) {
|
|
219
|
+
return;
|
|
220
|
+
}
|
|
221
|
+
const from = this.chooseDate()?.from;
|
|
222
|
+
const to = this.chooseDate()?.to;
|
|
223
|
+
if (this.isMultiple()) {
|
|
224
|
+
if (this.compareDate()) {
|
|
225
|
+
return;
|
|
226
|
+
}
|
|
227
|
+
let dataSelected = { from: signal({}), to: signal({}) };
|
|
228
|
+
this.arrayFormat().forEach((key) => {
|
|
229
|
+
if (!from?.()?.[key] || !to?.()?.[key]) {
|
|
230
|
+
dataSelected = undefined;
|
|
231
|
+
}
|
|
232
|
+
if (dataSelected) {
|
|
233
|
+
dataSelected.from.update((current) => {
|
|
234
|
+
current[key] = Number(from?.()[key]);
|
|
235
|
+
return current;
|
|
236
|
+
});
|
|
237
|
+
dataSelected.to.update((current) => {
|
|
238
|
+
current[key] = Number(to?.()[key]);
|
|
239
|
+
return current;
|
|
240
|
+
});
|
|
241
|
+
}
|
|
242
|
+
});
|
|
243
|
+
if (dataSelected) {
|
|
244
|
+
this.outChooseMultiDate.emit(dataSelected);
|
|
245
|
+
}
|
|
246
|
+
return;
|
|
247
|
+
}
|
|
248
|
+
let dataSelected = {};
|
|
249
|
+
this.arrayFormat().forEach((key) => {
|
|
250
|
+
if (!from?.()?.[key]) {
|
|
251
|
+
dataSelected = undefined;
|
|
252
|
+
}
|
|
253
|
+
if (dataSelected) {
|
|
254
|
+
dataSelected[key] = Number(from?.()?.[key]);
|
|
255
|
+
}
|
|
256
|
+
});
|
|
257
|
+
if (dataSelected) {
|
|
258
|
+
this.outChooseSingleDate.emit(dataSelected);
|
|
259
|
+
}
|
|
260
|
+
}
|
|
261
|
+
handlerChangeWidthLabel(width) {
|
|
262
|
+
this.cacheWidthLabel.set(width < (this.cacheWidthLabel() || 0) ? this.cacheWidthLabel() : Math.ceil(width));
|
|
263
|
+
if (this.timeOut()) {
|
|
264
|
+
clearTimeout(this.timeOut());
|
|
265
|
+
}
|
|
266
|
+
this.timeOut.set(setTimeout(() => {
|
|
267
|
+
this.widthLabel.set(this.cacheWidthLabel());
|
|
268
|
+
}, 100));
|
|
269
|
+
}
|
|
270
|
+
handlerChangStageFlagMouse(flagMouse) {
|
|
271
|
+
this.outChangStageFlagMouse.emit(flagMouse);
|
|
272
|
+
}
|
|
273
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: LibsUiComponentsDatetimeDropdownComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
274
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.14", type: LibsUiComponentsDatetimeDropdownComponent, isStandalone: true, selector: "libs_ui-components-datetime-dropdown", inputs: { labelConfig: { classPropertyName: "labelConfig", publicName: "labelConfig", isSignal: true, isRequired: false, transformFunction: null }, widthDropdown: { classPropertyName: "widthDropdown", publicName: "widthDropdown", isSignal: true, isRequired: false, transformFunction: null }, zIndex: { classPropertyName: "zIndex", publicName: "zIndex", isSignal: true, isRequired: false, transformFunction: null }, maxYear: { classPropertyName: "maxYear", publicName: "maxYear", isSignal: true, isRequired: false, transformFunction: null }, minYear: { classPropertyName: "minYear", publicName: "minYear", isSignal: true, isRequired: false, transformFunction: null }, minWidth: { classPropertyName: "minWidth", publicName: "minWidth", isSignal: true, isRequired: false, transformFunction: null }, disable: { classPropertyName: "disable", publicName: "disable", isSignal: true, isRequired: false, transformFunction: null }, readonly: { classPropertyName: "readonly", publicName: "readonly", isSignal: true, isRequired: false, transformFunction: null }, isMultiple: { classPropertyName: "isMultiple", publicName: "isMultiple", isSignal: true, isRequired: false, transformFunction: null }, reverseYear: { classPropertyName: "reverseYear", publicName: "reverseYear", isSignal: true, isRequired: false, transformFunction: null }, isBorderError: { classPropertyName: "isBorderError", publicName: "isBorderError", isSignal: true, isRequired: false, transformFunction: null }, ignoreWidth100: { classPropertyName: "ignoreWidth100", publicName: "ignoreWidth100", isSignal: true, isRequired: false, transformFunction: null }, widthByElement: { classPropertyName: "widthByElement", publicName: "widthByElement", isSignal: true, isRequired: false, transformFunction: null }, disableSecond: { classPropertyName: "disableSecond", publicName: "disableSecond", isSignal: true, isRequired: false, transformFunction: null }, typeFormat: { classPropertyName: "typeFormat", publicName: "typeFormat", isSignal: true, isRequired: false, transformFunction: null }, fromAndToDateLabel: { classPropertyName: "fromAndToDateLabel", publicName: "fromAndToDateLabel", isSignal: true, isRequired: false, transformFunction: null }, listHasButtonUnSelectOption: { classPropertyName: "listHasButtonUnSelectOption", publicName: "listHasButtonUnSelectOption", isSignal: true, isRequired: false, transformFunction: null }, selectedDateTime: { classPropertyName: "selectedDateTime", publicName: "selectedDateTime", isSignal: true, isRequired: false, transformFunction: null }, isEmitAfterChanged: { classPropertyName: "isEmitAfterChanged", publicName: "isEmitAfterChanged", isSignal: true, isRequired: false, transformFunction: null }, getItemYearDisplay: { classPropertyName: "getItemYearDisplay", publicName: "getItemYearDisplay", isSignal: true, isRequired: false, transformFunction: null }, ignoreFromAndToDateLabel: { classPropertyName: "ignoreFromAndToDateLabel", publicName: "ignoreFromAndToDateLabel", isSignal: true, isRequired: false, transformFunction: null }, classIncludeTextDisplayWhenNoSelect: { classPropertyName: "classIncludeTextDisplayWhenNoSelect", publicName: "classIncludeTextDisplayWhenNoSelect", isSignal: true, isRequired: false, transformFunction: null }, hiddenDate: { classPropertyName: "hiddenDate", publicName: "hiddenDate", isSignal: true, isRequired: false, transformFunction: null }, listMaxItemShow: { classPropertyName: "listMaxItemShow", publicName: "listMaxItemShow", isSignal: true, isRequired: false, transformFunction: null }, ignoreConvertYearSelected: { classPropertyName: "ignoreConvertYearSelected", publicName: "ignoreConvertYearSelected", isSignal: true, isRequired: false, transformFunction: null }, listKeysDisable: { classPropertyName: "listKeysDisable", publicName: "listKeysDisable", isSignal: true, isRequired: false, transformFunction: null }, ignoreAllowTimeEqual: { classPropertyName: "ignoreAllowTimeEqual", publicName: "ignoreAllowTimeEqual", isSignal: true, isRequired: false, transformFunction: null }, ignoreValidTimeCompare: { classPropertyName: "ignoreValidTimeCompare", publicName: "ignoreValidTimeCompare", isSignal: true, isRequired: false, transformFunction: null }, isCheckErrorWhenSelectItem: { classPropertyName: "isCheckErrorWhenSelectItem", publicName: "isCheckErrorWhenSelectItem", isSignal: true, isRequired: false, transformFunction: null }, ignoreRequiredValueSecondWhenNotValidRequired: { classPropertyName: "ignoreRequiredValueSecondWhenNotValidRequired", publicName: "ignoreRequiredValueSecondWhenNotValidRequired", isSignal: true, isRequired: false, transformFunction: null }, validRequired: { classPropertyName: "validRequired", publicName: "validRequired", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { outFunctionsControl: "outFunctionsControl", outSelectedDropdown: "outSelectedDropdown", outChooseMultiDate: "outChooseMultiDate", outChooseSingleDate: "outChooseSingleDate", outChangStageFlagMouse: "outChangStageFlagMouse" }, viewQueries: [{ propertyName: "containerRef", first: true, predicate: ["parent"], descendants: true, isSignal: true }, { propertyName: "labelFromRef", first: true, predicate: ["labelFrom"], descendants: true, isSignal: true }, { propertyName: "labelToRef", first: true, predicate: ["labelTo"], descendants: true, isSignal: true }], ngImport: i0, template: "@if (labelConfig(); as labelConfig) {\n <libs_ui-components-label\n [classInclude]=\"labelConfig.classInclude\"\n [labelLeft]=\"labelConfig.labelLeft\"\n [labelLeftClass]=\"labelConfig.labelLeftClass\"\n [required]=\"labelConfig.required\"\n [description]=\"labelConfig.description\"\n [labelRight]=\"labelConfig.labelRight\"\n [labelRightClass]=\"labelConfig.labelRightClass\"\n [onlyShowCount]=\"labelConfig.onlyShowCount\"\n [buttonsLeft]=\"labelConfig.buttonsLeft\"\n [buttonsRight]=\"labelConfig.buttonsRight\"\n [buttonsDescription]=\"labelConfig.buttonsDescription\"\n [descriptionClass]=\"labelConfig.descriptionClass\"\n [disableButtonsLeft]=\"labelConfig.disableButtonsLeft\"\n [disableButtonsRight]=\"labelConfig.disableButtonsRight\"\n [hasToggle]=\"labelConfig.hasToggle\"\n [toggleActive]=\"labelConfig.toggleActive\"\n [toggleDisable]=\"labelConfig.toggleDisable || disable()\"\n [popover]=\"labelConfig.popover\"\n [iconPopoverClass]=\"labelConfig.iconPopoverClass\"\n [limitLength]=\"labelConfig.limitLength\"\n [count]=\"labelConfig.count\" />\n}\n<div\n #parent\n class=\"flex items-start\"\n [class.!w-full]=\"widthByElement()\"\n [class.!column]=\"isResponsive() && isMultiple()\">\n <div\n #childFrom\n class=\"flex items-start\"\n [class.w-[50%]]=\"widthByElement() && !isResponsive()\"\n [class.!mb-[8px]]=\"isResponsive() && isMultiple()\"\n [class.!mr-[8px]]=\"!isResponsive() && isMultiple()\"\n [class.w-full]=\"(!isMultiple() && !widthByElement()) || isResponsive()\"\n [style.width.px]=\"!widthByElement() && isMultiple() && !isResponsive() ? widthDropdown() * arrayFormat().length + 8 * arrayFormat().length + widthLabelFrom() : undefined\">\n @if (isMultiple() && !ignoreFromAndToDateLabel() && fromAndToDateLabel().from) {\n <div\n class=\"mr-[8px] flex-shrink-0 h-[32px] flex items-center\"\n [style.width.px]=\"isResponsive() ? widthLabel() || undefined : undefined\">\n <span\n #labelFrom\n LibsUiComponentsDatetimeDropdownDirective\n [class.!opacity-[0.5]]=\"disable()\"\n class=\"libs-ui-font-h5r text-nowrap {{ fromAndToDateLabel().classLabelFrom || '' }}\"\n (outChangeWidth)=\"handlerChangeWidthLabel($event)\">\n @let constHtmlFrom = fromAndToDateLabel().from || ' ';\n {{ constHtmlFrom | translate }}\n </span>\n </div>\n }\n <div\n class=\"flex\"\n [class.!w-full]=\"widthByElement()\">\n @if (!changeType()) {\n <libs_ui-components-datetime-dropdown-item\n [class.!w-full]=\"widthByElement()\"\n [disableSecond]=\"disableSecond()\"\n [typeDate]=\"typeFormat()\"\n [zIndex]=\"zIndex()\"\n [maxYear]=\"maxYear()\"\n [disable]=\"disable()\"\n [minYear]=\"minYear()\"\n [readonly]=\"readonly()\"\n [isMultiple]=\"isMultiple() ? (isResponsive() ? true : false) : true\"\n [reverseYear]=\"reverseYear()\"\n [selectedDate]=\"selectedDateTime()?.from() || {}\"\n [widthDropdown]=\"widthDropdown()\"\n [widthByElement]=\"widthByElement()\"\n [getItemYearDisplay]=\"getItemYearDisplay()\"\n [listMaxItemShow]=\"listMaxItemShow()\"\n [listKeysDisable]=\"listKeysDisable()?.from()\"\n [listHasButtonUnSelectOption]=\"listHasButtonUnSelectOption()\"\n [isEmitSelectedDropDown]=\"isEmitAfterChanged()\"\n [classIncludeTextDisplayWhenNoSelect]=\"'libs-ui-font-h5r ' + classIncludeTextDisplayWhenNoSelect()\"\n (outSelectedData)=\"handlerChangeSelectedKey($event, 'from')\"\n (outFunctionControl)=\"handlerFunctionControl($event, 'from')\"\n (outChangStageFlagMouse)=\"handlerChangStageFlagMouse($event)\" />\n }\n </div>\n </div>\n @if (isMultiple()) {\n <div\n #childTo\n [class.!w-[50%]]=\"widthByElement()\"\n [class.!w-full]=\"!widthByElement() || isResponsive()\"\n class=\"flex items-start\">\n <div\n class=\"mr-[8px] h-[32px] flex-shrink-0 flex items-center\"\n [style.width.px]=\"isResponsive() ? widthLabel() : undefined\">\n @if (!ignoreFromAndToDateLabel()) {\n <span\n #labelTo\n LibsUiComponentsDatetimeDropdownDirective\n [class.!opacity-[0.5]]=\"disable()\"\n class=\"libs-ui-font-h5r text-nowrap {{ fromAndToDateLabel().classLabelTo || '' }}\"\n (outChangeWidth)=\"handlerChangeWidthLabel($event)\">\n @let constHtmlTo = fromAndToDateLabel().to || ' ';\n {{ constHtmlTo | translate }}\n </span>\n }\n @if (ignoreFromAndToDateLabel()) {\n <span\n [class.!opacity-[0.5]]=\"disable()\"\n class=\"libs-ui-font-h5r\">\n -\n </span>\n }\n </div>\n <div\n class=\"flex\"\n [class.!w-full]=\"widthByElement()\">\n @if (!changeType()) {\n <libs_ui-components-datetime-dropdown-item\n [class.w-full]=\"widthByElement()\"\n [disableSecond]=\"disableSecond()\"\n [typeDate]=\"typeFormat()\"\n [zIndex]=\"zIndex()\"\n [maxYear]=\"maxYear()\"\n [disable]=\"disable()\"\n [minYear]=\"minYear()\"\n [readonly]=\"readonly()\"\n [isMultiple]=\"isMultiple()\"\n [reverseYear]=\"reverseYear()\"\n [selectedDate]=\"selectedDateTime()?.to() || {}\"\n [widthDropdown]=\"widthDropdown()\"\n [widthByElement]=\"widthByElement()\"\n [getItemYearDisplay]=\"getItemYearDisplay()\"\n [listMaxItemShow]=\"listMaxItemShow()\"\n [listKeysDisable]=\"listKeysDisable()?.to()\"\n [listHasButtonUnSelectOption]=\"listHasButtonUnSelectOption()\"\n [classIncludeTextDisplayWhenNoSelect]=\"'libs-ui-font-h5r ' + classIncludeTextDisplayWhenNoSelect\"\n [isEmitSelectedDropDown]=\"isEmitAfterChanged()\"\n (outSelectedData)=\"handlerChangeSelectedKey($event, 'to')\"\n (outFunctionControl)=\"handlerFunctionControl($event, 'to')\"\n (outChangStageFlagMouse)=\"handlerChangStageFlagMouse($event)\" />\n }\n </div>\n </div>\n }\n</div>\n\n@if (isErrorCompareDate()) {\n <div class=\"flex items-center mt-[4px]\">\n <span class=\"libs-ui-message-error libs-ui-font-h7r libs-ui-text-error\">\n @let constHtmlMessage = validRequired()?.messageValidCompareTime || 'i18n_invalid_end_date_selected';\n {{ constHtmlMessage | translate: validRequired()?.interpolateParamsCompareTime }}\n </span>\n </div>\n}\n", styles: [""], dependencies: [{ kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i1.TranslatePipe, name: "translate" }, { kind: "component", type: LibsUiComponentsLabelComponent, selector: "libs_ui-components-label", inputs: ["iconPopoverClass", "classInclude", "labelLeft", "labelLeftClass", "labelLeftBehindToggleButton", "popover", "required", "buttonsLeft", "disableButtonsLeft", "buttonsRight", "disableButtonsRight", "labelRight", "labelRightClass", "labelRightRequired", "hasToggle", "toggleSize", "toggleActive", "toggleDisable", "description", "descriptionClass", "buttonsDescription", "disableButtonsDescription", "buttonsDescriptionContainerClass", "onlyShowCount", "zIndexPopover", "timerDestroyPopover", "count", "limitLength"], outputs: ["outClickButton", "outSwitchEvent", "outLabelRightClick", "outLabelLeftClick"] }, { kind: "directive", type: LibsUiComponentsDatetimeDropdownDirective, selector: "[LibsUiComponentsDatetimeDropdownDirective]", outputs: ["outChangeWidth"] }, { kind: "component", type: LibsUiComponentsDatetimeDropdownItemComponent, selector: "libs_ui-components-datetime-dropdown-item", inputs: ["typeDate", "disableSecond", "selectedDate", "widthDropdown", "widthByElement", "getItemYearDisplay", "listHasButtonUnSelectOption", "readonly", "disable", "zIndex", "isMultiple", "classIncludeTextDisplayWhenNoSelect", "isCheckErrorWhenSelectItem", "maxYear", "minYear", "reverseYear", "listKeysDisable", "ignoreConvertYearSelected", "validRequired", "isEmitSelectedDropDown", "listMaxItemShow"], outputs: ["outSelectedData", "outFunctionControl", "outChangStageFlagMouse"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
275
|
+
}
|
|
276
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: LibsUiComponentsDatetimeDropdownComponent, decorators: [{
|
|
277
|
+
type: Component,
|
|
278
|
+
args: [{ selector: 'libs_ui-components-datetime-dropdown', standalone: true, changeDetection: ChangeDetectionStrategy.OnPush, imports: [TranslateModule, LibsUiComponentsLabelComponent, LibsUiComponentsDatetimeDropdownDirective, LibsUiComponentsDatetimeDropdownItemComponent], template: "@if (labelConfig(); as labelConfig) {\n <libs_ui-components-label\n [classInclude]=\"labelConfig.classInclude\"\n [labelLeft]=\"labelConfig.labelLeft\"\n [labelLeftClass]=\"labelConfig.labelLeftClass\"\n [required]=\"labelConfig.required\"\n [description]=\"labelConfig.description\"\n [labelRight]=\"labelConfig.labelRight\"\n [labelRightClass]=\"labelConfig.labelRightClass\"\n [onlyShowCount]=\"labelConfig.onlyShowCount\"\n [buttonsLeft]=\"labelConfig.buttonsLeft\"\n [buttonsRight]=\"labelConfig.buttonsRight\"\n [buttonsDescription]=\"labelConfig.buttonsDescription\"\n [descriptionClass]=\"labelConfig.descriptionClass\"\n [disableButtonsLeft]=\"labelConfig.disableButtonsLeft\"\n [disableButtonsRight]=\"labelConfig.disableButtonsRight\"\n [hasToggle]=\"labelConfig.hasToggle\"\n [toggleActive]=\"labelConfig.toggleActive\"\n [toggleDisable]=\"labelConfig.toggleDisable || disable()\"\n [popover]=\"labelConfig.popover\"\n [iconPopoverClass]=\"labelConfig.iconPopoverClass\"\n [limitLength]=\"labelConfig.limitLength\"\n [count]=\"labelConfig.count\" />\n}\n<div\n #parent\n class=\"flex items-start\"\n [class.!w-full]=\"widthByElement()\"\n [class.!column]=\"isResponsive() && isMultiple()\">\n <div\n #childFrom\n class=\"flex items-start\"\n [class.w-[50%]]=\"widthByElement() && !isResponsive()\"\n [class.!mb-[8px]]=\"isResponsive() && isMultiple()\"\n [class.!mr-[8px]]=\"!isResponsive() && isMultiple()\"\n [class.w-full]=\"(!isMultiple() && !widthByElement()) || isResponsive()\"\n [style.width.px]=\"!widthByElement() && isMultiple() && !isResponsive() ? widthDropdown() * arrayFormat().length + 8 * arrayFormat().length + widthLabelFrom() : undefined\">\n @if (isMultiple() && !ignoreFromAndToDateLabel() && fromAndToDateLabel().from) {\n <div\n class=\"mr-[8px] flex-shrink-0 h-[32px] flex items-center\"\n [style.width.px]=\"isResponsive() ? widthLabel() || undefined : undefined\">\n <span\n #labelFrom\n LibsUiComponentsDatetimeDropdownDirective\n [class.!opacity-[0.5]]=\"disable()\"\n class=\"libs-ui-font-h5r text-nowrap {{ fromAndToDateLabel().classLabelFrom || '' }}\"\n (outChangeWidth)=\"handlerChangeWidthLabel($event)\">\n @let constHtmlFrom = fromAndToDateLabel().from || ' ';\n {{ constHtmlFrom | translate }}\n </span>\n </div>\n }\n <div\n class=\"flex\"\n [class.!w-full]=\"widthByElement()\">\n @if (!changeType()) {\n <libs_ui-components-datetime-dropdown-item\n [class.!w-full]=\"widthByElement()\"\n [disableSecond]=\"disableSecond()\"\n [typeDate]=\"typeFormat()\"\n [zIndex]=\"zIndex()\"\n [maxYear]=\"maxYear()\"\n [disable]=\"disable()\"\n [minYear]=\"minYear()\"\n [readonly]=\"readonly()\"\n [isMultiple]=\"isMultiple() ? (isResponsive() ? true : false) : true\"\n [reverseYear]=\"reverseYear()\"\n [selectedDate]=\"selectedDateTime()?.from() || {}\"\n [widthDropdown]=\"widthDropdown()\"\n [widthByElement]=\"widthByElement()\"\n [getItemYearDisplay]=\"getItemYearDisplay()\"\n [listMaxItemShow]=\"listMaxItemShow()\"\n [listKeysDisable]=\"listKeysDisable()?.from()\"\n [listHasButtonUnSelectOption]=\"listHasButtonUnSelectOption()\"\n [isEmitSelectedDropDown]=\"isEmitAfterChanged()\"\n [classIncludeTextDisplayWhenNoSelect]=\"'libs-ui-font-h5r ' + classIncludeTextDisplayWhenNoSelect()\"\n (outSelectedData)=\"handlerChangeSelectedKey($event, 'from')\"\n (outFunctionControl)=\"handlerFunctionControl($event, 'from')\"\n (outChangStageFlagMouse)=\"handlerChangStageFlagMouse($event)\" />\n }\n </div>\n </div>\n @if (isMultiple()) {\n <div\n #childTo\n [class.!w-[50%]]=\"widthByElement()\"\n [class.!w-full]=\"!widthByElement() || isResponsive()\"\n class=\"flex items-start\">\n <div\n class=\"mr-[8px] h-[32px] flex-shrink-0 flex items-center\"\n [style.width.px]=\"isResponsive() ? widthLabel() : undefined\">\n @if (!ignoreFromAndToDateLabel()) {\n <span\n #labelTo\n LibsUiComponentsDatetimeDropdownDirective\n [class.!opacity-[0.5]]=\"disable()\"\n class=\"libs-ui-font-h5r text-nowrap {{ fromAndToDateLabel().classLabelTo || '' }}\"\n (outChangeWidth)=\"handlerChangeWidthLabel($event)\">\n @let constHtmlTo = fromAndToDateLabel().to || ' ';\n {{ constHtmlTo | translate }}\n </span>\n }\n @if (ignoreFromAndToDateLabel()) {\n <span\n [class.!opacity-[0.5]]=\"disable()\"\n class=\"libs-ui-font-h5r\">\n -\n </span>\n }\n </div>\n <div\n class=\"flex\"\n [class.!w-full]=\"widthByElement()\">\n @if (!changeType()) {\n <libs_ui-components-datetime-dropdown-item\n [class.w-full]=\"widthByElement()\"\n [disableSecond]=\"disableSecond()\"\n [typeDate]=\"typeFormat()\"\n [zIndex]=\"zIndex()\"\n [maxYear]=\"maxYear()\"\n [disable]=\"disable()\"\n [minYear]=\"minYear()\"\n [readonly]=\"readonly()\"\n [isMultiple]=\"isMultiple()\"\n [reverseYear]=\"reverseYear()\"\n [selectedDate]=\"selectedDateTime()?.to() || {}\"\n [widthDropdown]=\"widthDropdown()\"\n [widthByElement]=\"widthByElement()\"\n [getItemYearDisplay]=\"getItemYearDisplay()\"\n [listMaxItemShow]=\"listMaxItemShow()\"\n [listKeysDisable]=\"listKeysDisable()?.to()\"\n [listHasButtonUnSelectOption]=\"listHasButtonUnSelectOption()\"\n [classIncludeTextDisplayWhenNoSelect]=\"'libs-ui-font-h5r ' + classIncludeTextDisplayWhenNoSelect\"\n [isEmitSelectedDropDown]=\"isEmitAfterChanged()\"\n (outSelectedData)=\"handlerChangeSelectedKey($event, 'to')\"\n (outFunctionControl)=\"handlerFunctionControl($event, 'to')\"\n (outChangStageFlagMouse)=\"handlerChangStageFlagMouse($event)\" />\n }\n </div>\n </div>\n }\n</div>\n\n@if (isErrorCompareDate()) {\n <div class=\"flex items-center mt-[4px]\">\n <span class=\"libs-ui-message-error libs-ui-font-h7r libs-ui-text-error\">\n @let constHtmlMessage = validRequired()?.messageValidCompareTime || 'i18n_invalid_end_date_selected';\n {{ constHtmlMessage | translate: validRequired()?.interpolateParamsCompareTime }}\n </span>\n </div>\n}\n" }]
|
|
279
|
+
}], ctorParameters: () => [] });
|
|
280
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dropdown.component.js","sourceRoot":"","sources":["../../../../../../libs-ui/components/datetime/dropdown/src/dropdown.component.ts","../../../../../../libs-ui/components/datetime/dropdown/src/dropdown.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, ChangeDetectionStrategy, Component, computed, effect, ElementRef, inject, input, OnInit, output, signal, untracked, viewChild } from '@angular/core';\nimport { ILabel, LibsUiComponentsLabelComponent } from '@libs-ui/components-label';\nimport { IFlagMouse } from '@libs-ui/components-popover';\nimport { TranslateModule, TranslateService } from '@ngx-translate/core';\nimport { fromEvent, Subject, takeUntil, timer } from 'rxjs';\nimport { CompareDate } from './defines/date-dropdown.define';\nimport { LibsUiComponentsDatetimeDropdownDirective } from './directive/date-dropdown.directive';\nimport { IDateDropdownDisableKeys, IFromAndToDateLabel, IHiddenDate, TYPE_DATE_DROPDOWN_FORMAT, TYPE_DATE_FORMAT } from './interfaces/date-dropdown.interface';\nimport { IEmitMultiDateDropdown, IEmitSingleDateDropdown } from './interfaces/emit-dropdown.interface';\nimport { IDateDropdownFunctionControlEvent, IDateDropdownItemFunctionControlEvent } from './interfaces/functions-control-event.interface';\nimport { IValidDateDropdown } from './interfaces/valid.interface';\nimport { LibsUiComponentsDatetimeDropdownItemComponent } from './item/item.component';\n\n@Component({\n  // eslint-disable-next-line @angular-eslint/component-selector\n  selector: 'libs_ui-components-datetime-dropdown',\n  templateUrl: './dropdown.component.html',\n  styleUrls: ['./dropdown.component.scss'],\n  standalone: true,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  imports: [TranslateModule, LibsUiComponentsLabelComponent, LibsUiComponentsDatetimeDropdownDirective, LibsUiComponentsDatetimeDropdownItemComponent],\n})\nexport class LibsUiComponentsDatetimeDropdownComponent implements OnInit, AfterViewInit {\n  // #region PROPERTY\n  protected width = signal<number>(0);\n  protected widthElement = signal<number | undefined>(undefined);\n  protected widthLabel = signal<number | undefined>(undefined);\n  protected widthLabelFrom = signal<number>(0);\n  protected widthLabelTo = signal<number>(0);\n  protected isErrorCompareDate = signal<boolean | undefined>(undefined);\n  protected chooseDate = signal<IEmitMultiDateDropdown | undefined>({ from: signal({}), to: signal({}) });\n  protected isResponsive = signal<boolean | undefined>(undefined);\n  protected arrayFormat = computed(() => {\n    return this.typeFormat().split('-') as Array<TYPE_DATE_FORMAT>;\n  });\n  protected changeType = signal<boolean | undefined>(undefined);\n\n  private cacheWidthLabel = signal<number | undefined>(undefined);\n  private timeOut = signal<number | undefined>(undefined);\n  private onDestroy = new Subject<void>();\n  private functionsControl = new Map<string, IDateDropdownItemFunctionControlEvent>();\n\n  // #region INPUT\n  readonly labelConfig = input<ILabel | undefined>(undefined);\n  readonly widthDropdown = input<number, number>(136, { transform: (value) => value ?? 136 });\n  readonly zIndex = input<number, number>(1200, { transform: (value) => value ?? 1200 });\n  readonly maxYear = input<number>(0);\n  readonly minYear = input<number>(0);\n  readonly minWidth = input<number | undefined>(undefined);\n  readonly disable = input<boolean>(false);\n  readonly readonly = input<boolean>(false);\n  readonly isMultiple = input<boolean>(false);\n  readonly reverseYear = input<boolean | undefined>(undefined);\n  readonly isBorderError = input<boolean>(false);\n  readonly ignoreWidth100 = input<boolean>(false);\n  readonly widthByElement = input<boolean>(false);\n  readonly disableSecond = input<boolean>(false);\n  readonly typeFormat = input<TYPE_DATE_DROPDOWN_FORMAT, TYPE_DATE_DROPDOWN_FORMAT>('month-day', { transform: (value) => value ?? 'month-day' });\n  readonly fromAndToDateLabel = input<IFromAndToDateLabel>({ from: 'i18n_label_from', to: 'i18n_to' });\n  readonly listHasButtonUnSelectOption = input<boolean>(false);\n  readonly selectedDateTime = input<IEmitMultiDateDropdown | undefined>(undefined);\n  readonly isEmitAfterChanged = input<boolean>(false); // dùng để emit mỗi lần chọn giá trị và lần đầu init\n  readonly getItemYearDisplay = input<(year: string) => string>();\n  readonly ignoreFromAndToDateLabel = input<boolean>(false);\n  readonly classIncludeTextDisplayWhenNoSelect = input<string | undefined>(undefined);\n  readonly hiddenDate = input<IHiddenDate | undefined>();\n  readonly listMaxItemShow = input<{ year?: number; month?: number; quarter?: number; day?: number } | undefined>(undefined);\n  readonly ignoreConvertYearSelected = input<boolean>(false);\n  readonly listKeysDisable = input<IDateDropdownDisableKeys | undefined>(undefined);\n\n  readonly ignoreAllowTimeEqual = input<boolean, boolean>(true, { transform: (value) => value ?? true });\n  readonly ignoreValidTimeCompare = input<boolean, boolean>(false, { transform: (value) => value ?? false });\n  readonly isCheckErrorWhenSelectItem = input<boolean, boolean>(true, { transform: (value) => value ?? true });\n  readonly ignoreRequiredValueSecondWhenNotValidRequired = input<boolean>(false); // có validate giá trị thứ 2 khi validRequired không?\n  readonly validRequired = input<IValidDateDropdown>();\n\n  // #region OUTPUT\n  readonly outFunctionsControl = output<IDateDropdownFunctionControlEvent>();\n  readonly outSelectedDropdown = output<IEmitSingleDateDropdown | IEmitMultiDateDropdown>(); // dùng cho trường hợp emit mỗi một lần chọn giá trị nên khi sử dụng phải check kĩ undefined\n  readonly outChooseMultiDate = output<IEmitMultiDateDropdown>();\n  readonly outChooseSingleDate = output<IEmitSingleDateDropdown>();\n  readonly outChangStageFlagMouse = output<IFlagMouse>();\n\n  /* VIEW CHILD */\n  private containerRef = viewChild<ElementRef>('parent');\n  private labelFromRef = viewChild<ElementRef>('labelFrom');\n  private labelToRef = viewChild<ElementRef>('labelTo');\n\n  // #region INJECT\n  private translate = inject(TranslateService);\n\n  constructor() {\n    effect(() => {\n      const isMultiple = this.isMultiple();\n\n      if (!isMultiple) {\n        return;\n      }\n\n      untracked(() => {\n        this.changeType.set(true);\n        this.functionsControl.clear();\n        timer(0)\n          .pipe()\n          .subscribe(() => {\n            this.checkResponsive();\n            this.changeType.set(false);\n          });\n      });\n    });\n  }\n\n  ngOnInit() {\n    this.outFunctionsControl.emit(this.FunctionsControl);\n    if (this.selectedDateTime()) {\n      this.chooseDate.set(this.selectedDateTime());\n    }\n  }\n\n  ngAfterViewInit() {\n    fromEvent(window, 'resize').pipe(takeUntil(this.onDestroy)).subscribe(this.setWidthDate.bind(this));\n    this.widthLabel.set(undefined);\n    timer(0)\n      .pipe()\n      .subscribe(() => {\n        this.checkResponsive();\n      });\n  }\n\n  public get FunctionsControl(): IDateDropdownFunctionControlEvent {\n    return {\n      checkIsValid: this.validate.bind(this),\n      resetError: this.resetError.bind(this),\n      resetTime: this.resetDropdown.bind(this),\n    };\n  }\n\n  protected checkResponsive() {\n    this.isResponsive.set(false);\n    const widthElementParent = this.containerRef()?.nativeElement?.getBoundingClientRect().width || 0;\n\n    this.widthLabelFrom.set(this.labelFromRef()?.nativeElement?.getBoundingClientRect().width || 0);\n    this.widthLabelTo.set(this.labelToRef()?.nativeElement?.getBoundingClientRect().width || 0);\n\n    const spaceBetweenDate = this.arrayFormat().length * 2 + (this.fromAndToDateLabel().from ? 1 : 0);\n    const width = this.widthDropdown() * 4 + 8 * spaceBetweenDate + this.widthLabelFrom() + this.widthLabelTo();\n\n    if (widthElementParent < width) {\n      this.isResponsive.set(true);\n    }\n  }\n\n  protected handlerChangeSelectedKey(event: IEmitSingleDateDropdown, type: 'from' | 'to') {\n    this.chooseDate.update((current) => {\n      if (current) {\n        current[type].set(event);\n      }\n\n      return current;\n    });\n    if (this.isEmitAfterChanged()) {\n      const dataEmit = this.isMultiple() ? this.chooseDate() : this.chooseDate()?.from();\n\n      if (dataEmit) {\n        this.outSelectedDropdown.emit(dataEmit);\n      }\n    }\n    this.applyDate();\n  }\n\n  private async resetDropdown() {\n    this.functionsControl.forEach((control) => control.resetDropdown());\n  }\n\n  private async resetError() {\n    this.functionsControl.forEach((control) => control.resetError());\n  }\n\n  private setWidthDate() {\n    if (!this.containerRef() || !this.containerRef()?.nativeElement) {\n      return;\n    }\n    timer(0)\n      .pipe()\n      .subscribe(() => {\n        this.checkResponsive();\n      });\n  }\n\n  protected handlerFunctionControl(event: IDateDropdownItemFunctionControlEvent, type: 'from' | 'to') {\n    this.functionsControl.set(type, event);\n  }\n\n  protected async checkValid() {\n    let valid = true;\n\n    for (const control of this.functionsControl.values()) {\n      if (!(await control.checkIsValid())) {\n        valid = false;\n      }\n    }\n    if (this.compareDate()) {\n      valid = false;\n    }\n\n    return valid;\n  }\n\n  private setError(error: boolean) {\n    this.functionsControl.forEach((control) => control.setError(error));\n  }\n\n  private compareDate() {\n    const type = this.typeFormat().split('-') as Array<TYPE_DATE_FORMAT>;\n    const dateCompare: Array<{ from: number | undefined; to: number | undefined }> = [];\n\n    type.forEach((item) => {\n      const from = this.chooseDate()?.from()[item];\n      const to = this.chooseDate()?.to()[item];\n\n      dateCompare.push({ from: from, to: to });\n    });\n    if (this.ignoreValidTimeCompare() || !this.checkCondition(true)) {\n      this.isErrorCompareDate.set(false);\n\n      return false;\n    }\n    if (CompareDate(dateCompare, this.ignoreAllowTimeEqual())) {\n      this.setError(true);\n      this.isErrorCompareDate.set(true);\n\n      return true;\n    }\n    this.isErrorCompareDate.set(false);\n\n    return false;\n  }\n\n  private async validate() {\n    let valid = true;\n\n    if (!this.validRequired()) {\n      if (!this.checkCondition(false) && !this.ignoreRequiredValueSecondWhenNotValidRequired()) {\n        valid = await this.checkValid();\n      }\n\n      return valid;\n    }\n\n    return await this.checkValid();\n  }\n\n  private checkCondition(hasValue: boolean) {\n    let checkValue = true;\n    const type = this.typeFormat().split('-') as Array<TYPE_DATE_FORMAT>;\n\n    type.forEach((item) => {\n      if (hasValue && (!this.chooseDate()?.from()[item] || !this.chooseDate()?.to()[item])) {\n        checkValue = false;\n      }\n      if (!hasValue && (this.chooseDate()?.from()[item] || this.chooseDate()?.to()[item])) {\n        checkValue = false;\n      }\n    });\n\n    return checkValue;\n  }\n\n  protected applyDate() {\n    this.setError(false);\n    this.isErrorCompareDate.set(false);\n    if (this.isCheckErrorWhenSelectItem() && !this.validate()) {\n      return;\n    }\n    const from = this.chooseDate()?.from;\n    const to = this.chooseDate()?.to;\n\n    if (this.isMultiple()) {\n      if (this.compareDate()) {\n        return;\n      }\n      let dataSelected: IEmitMultiDateDropdown | undefined = { from: signal({}), to: signal({}) };\n\n      this.arrayFormat().forEach((key) => {\n        if (!from?.()?.[key] || !to?.()?.[key]) {\n          dataSelected = undefined;\n        }\n        if (dataSelected) {\n          dataSelected.from.update((current) => {\n            current[key] = Number(from?.()[key]);\n\n            return current;\n          });\n          dataSelected.to.update((current) => {\n            current[key] = Number(to?.()[key]);\n\n            return current;\n          });\n        }\n      });\n\n      if (dataSelected) {\n        this.outChooseMultiDate.emit(dataSelected);\n      }\n\n      return;\n    }\n    let dataSelected: IEmitSingleDateDropdown | undefined = {};\n\n    this.arrayFormat().forEach((key) => {\n      if (!from?.()?.[key]) {\n        dataSelected = undefined;\n      }\n      if (dataSelected) {\n        dataSelected[key] = Number(from?.()?.[key]);\n      }\n    });\n    if (dataSelected) {\n      this.outChooseSingleDate.emit(dataSelected);\n    }\n  }\n\n  protected handlerChangeWidthLabel(width: number) {\n    this.cacheWidthLabel.set(width < (this.cacheWidthLabel() || 0) ? this.cacheWidthLabel() : Math.ceil(width));\n    if (this.timeOut()) {\n      clearTimeout(this.timeOut());\n    }\n    this.timeOut.set(\n      setTimeout(() => {\n        this.widthLabel.set(this.cacheWidthLabel());\n      }, 100) as unknown as number\n    );\n  }\n\n  protected handlerChangStageFlagMouse(flagMouse: IFlagMouse) {\n    this.outChangStageFlagMouse.emit(flagMouse);\n  }\n}\n","@if (labelConfig(); as labelConfig) {\n  <libs_ui-components-label\n    [classInclude]=\"labelConfig.classInclude\"\n    [labelLeft]=\"labelConfig.labelLeft\"\n    [labelLeftClass]=\"labelConfig.labelLeftClass\"\n    [required]=\"labelConfig.required\"\n    [description]=\"labelConfig.description\"\n    [labelRight]=\"labelConfig.labelRight\"\n    [labelRightClass]=\"labelConfig.labelRightClass\"\n    [onlyShowCount]=\"labelConfig.onlyShowCount\"\n    [buttonsLeft]=\"labelConfig.buttonsLeft\"\n    [buttonsRight]=\"labelConfig.buttonsRight\"\n    [buttonsDescription]=\"labelConfig.buttonsDescription\"\n    [descriptionClass]=\"labelConfig.descriptionClass\"\n    [disableButtonsLeft]=\"labelConfig.disableButtonsLeft\"\n    [disableButtonsRight]=\"labelConfig.disableButtonsRight\"\n    [hasToggle]=\"labelConfig.hasToggle\"\n    [toggleActive]=\"labelConfig.toggleActive\"\n    [toggleDisable]=\"labelConfig.toggleDisable || disable()\"\n    [popover]=\"labelConfig.popover\"\n    [iconPopoverClass]=\"labelConfig.iconPopoverClass\"\n    [limitLength]=\"labelConfig.limitLength\"\n    [count]=\"labelConfig.count\" />\n}\n<div\n  #parent\n  class=\"flex items-start\"\n  [class.!w-full]=\"widthByElement()\"\n  [class.!column]=\"isResponsive() && isMultiple()\">\n  <div\n    #childFrom\n    class=\"flex items-start\"\n    [class.w-[50%]]=\"widthByElement() && !isResponsive()\"\n    [class.!mb-[8px]]=\"isResponsive() && isMultiple()\"\n    [class.!mr-[8px]]=\"!isResponsive() && isMultiple()\"\n    [class.w-full]=\"(!isMultiple() && !widthByElement()) || isResponsive()\"\n    [style.width.px]=\"!widthByElement() && isMultiple() && !isResponsive() ? widthDropdown() * arrayFormat().length + 8 * arrayFormat().length + widthLabelFrom() : undefined\">\n    @if (isMultiple() && !ignoreFromAndToDateLabel() && fromAndToDateLabel().from) {\n      <div\n        class=\"mr-[8px] flex-shrink-0 h-[32px] flex items-center\"\n        [style.width.px]=\"isResponsive() ? widthLabel() || undefined : undefined\">\n        <span\n          #labelFrom\n          LibsUiComponentsDatetimeDropdownDirective\n          [class.!opacity-[0.5]]=\"disable()\"\n          class=\"libs-ui-font-h5r text-nowrap {{ fromAndToDateLabel().classLabelFrom || '' }}\"\n          (outChangeWidth)=\"handlerChangeWidthLabel($event)\">\n          @let constHtmlFrom = fromAndToDateLabel().from || ' ';\n          {{ constHtmlFrom | translate }}\n        </span>\n      </div>\n    }\n    <div\n      class=\"flex\"\n      [class.!w-full]=\"widthByElement()\">\n      @if (!changeType()) {\n        <libs_ui-components-datetime-dropdown-item\n          [class.!w-full]=\"widthByElement()\"\n          [disableSecond]=\"disableSecond()\"\n          [typeDate]=\"typeFormat()\"\n          [zIndex]=\"zIndex()\"\n          [maxYear]=\"maxYear()\"\n          [disable]=\"disable()\"\n          [minYear]=\"minYear()\"\n          [readonly]=\"readonly()\"\n          [isMultiple]=\"isMultiple() ? (isResponsive() ? true : false) : true\"\n          [reverseYear]=\"reverseYear()\"\n          [selectedDate]=\"selectedDateTime()?.from() || {}\"\n          [widthDropdown]=\"widthDropdown()\"\n          [widthByElement]=\"widthByElement()\"\n          [getItemYearDisplay]=\"getItemYearDisplay()\"\n          [listMaxItemShow]=\"listMaxItemShow()\"\n          [listKeysDisable]=\"listKeysDisable()?.from()\"\n          [listHasButtonUnSelectOption]=\"listHasButtonUnSelectOption()\"\n          [isEmitSelectedDropDown]=\"isEmitAfterChanged()\"\n          [classIncludeTextDisplayWhenNoSelect]=\"'libs-ui-font-h5r ' + classIncludeTextDisplayWhenNoSelect()\"\n          (outSelectedData)=\"handlerChangeSelectedKey($event, 'from')\"\n          (outFunctionControl)=\"handlerFunctionControl($event, 'from')\"\n          (outChangStageFlagMouse)=\"handlerChangStageFlagMouse($event)\" />\n      }\n    </div>\n  </div>\n  @if (isMultiple()) {\n    <div\n      #childTo\n      [class.!w-[50%]]=\"widthByElement()\"\n      [class.!w-full]=\"!widthByElement() || isResponsive()\"\n      class=\"flex items-start\">\n      <div\n        class=\"mr-[8px] h-[32px] flex-shrink-0 flex items-center\"\n        [style.width.px]=\"isResponsive() ? widthLabel() : undefined\">\n        @if (!ignoreFromAndToDateLabel()) {\n          <span\n            #labelTo\n            LibsUiComponentsDatetimeDropdownDirective\n            [class.!opacity-[0.5]]=\"disable()\"\n            class=\"libs-ui-font-h5r text-nowrap {{ fromAndToDateLabel().classLabelTo || '' }}\"\n            (outChangeWidth)=\"handlerChangeWidthLabel($event)\">\n            @let constHtmlTo = fromAndToDateLabel().to || ' ';\n            {{ constHtmlTo | translate }}\n          </span>\n        }\n        @if (ignoreFromAndToDateLabel()) {\n          <span\n            [class.!opacity-[0.5]]=\"disable()\"\n            class=\"libs-ui-font-h5r\">\n            -\n          </span>\n        }\n      </div>\n      <div\n        class=\"flex\"\n        [class.!w-full]=\"widthByElement()\">\n        @if (!changeType()) {\n          <libs_ui-components-datetime-dropdown-item\n            [class.w-full]=\"widthByElement()\"\n            [disableSecond]=\"disableSecond()\"\n            [typeDate]=\"typeFormat()\"\n            [zIndex]=\"zIndex()\"\n            [maxYear]=\"maxYear()\"\n            [disable]=\"disable()\"\n            [minYear]=\"minYear()\"\n            [readonly]=\"readonly()\"\n            [isMultiple]=\"isMultiple()\"\n            [reverseYear]=\"reverseYear()\"\n            [selectedDate]=\"selectedDateTime()?.to() || {}\"\n            [widthDropdown]=\"widthDropdown()\"\n            [widthByElement]=\"widthByElement()\"\n            [getItemYearDisplay]=\"getItemYearDisplay()\"\n            [listMaxItemShow]=\"listMaxItemShow()\"\n            [listKeysDisable]=\"listKeysDisable()?.to()\"\n            [listHasButtonUnSelectOption]=\"listHasButtonUnSelectOption()\"\n            [classIncludeTextDisplayWhenNoSelect]=\"'libs-ui-font-h5r ' + classIncludeTextDisplayWhenNoSelect\"\n            [isEmitSelectedDropDown]=\"isEmitAfterChanged()\"\n            (outSelectedData)=\"handlerChangeSelectedKey($event, 'to')\"\n            (outFunctionControl)=\"handlerFunctionControl($event, 'to')\"\n            (outChangStageFlagMouse)=\"handlerChangStageFlagMouse($event)\" />\n        }\n      </div>\n    </div>\n  }\n</div>\n\n@if (isErrorCompareDate()) {\n  <div class=\"flex items-center mt-[4px]\">\n    <span class=\"libs-ui-message-error libs-ui-font-h7r libs-ui-text-error\">\n      @let constHtmlMessage = validRequired()?.messageValidCompareTime || 'i18n_invalid_end_date_selected';\n      {{ constHtmlMessage | translate: validRequired()?.interpolateParamsCompareTime }}\n    </span>\n  </div>\n}\n"]}
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
export * from './dropdown.component';
|
|
2
|
+
export * from './interfaces';
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzLXVpL2NvbXBvbmVudHMvZGF0ZXRpbWUvZHJvcGRvd24vc3JjL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsc0JBQXNCLENBQUM7QUFDckMsY0FBYyxjQUFjLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2Ryb3Bkb3duLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2ludGVyZmFjZXMnO1xuIl19
|
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
/* eslint-disable @typescript-eslint/no-explicit-any */
|
|
2
|
+
export {};
|
|
3
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0ZS1kcm9wZG93bi5pbnRlcmZhY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzLXVpL2NvbXBvbmVudHMvZGF0ZXRpbWUvZHJvcGRvd24vc3JjL2ludGVyZmFjZXMvZGF0ZS1kcm9wZG93bi5pbnRlcmZhY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsdURBQXVEIiwic291cmNlc0NvbnRlbnQiOlsiLyogZXNsaW50LWRpc2FibGUgQHR5cGVzY3JpcHQtZXNsaW50L25vLWV4cGxpY2l0LWFueSAqL1xuXG5pbXBvcnQgeyBXcml0YWJsZVNpZ25hbCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgSURyb3Bkb3duRnVuY3Rpb25Db250cm9sRXZlbnQgfSBmcm9tICdAbGlicy11aS9jb21wb25lbnRzLWRyb3Bkb3duJztcblxuZXhwb3J0IHR5cGUgVFlQRV9EUk9QRE9XTl9NT05USF9JRCA9IDEgfCAyIHwgMyB8IDQgfCA1IHwgNiB8IDcgfCA4IHwgOSB8IDEwIHwgMTEgfCAxMjtcbmV4cG9ydCB0eXBlIFRZUEVfREFURV9EUk9QRE9XTl9GT1JNQVQgPSAneWVhcicgfCAnbW9udGgnIHwgJ3F1YXJ0ZXInIHwgJ3llYXItbW9udGgnIHwgJ21vbnRoLWRheScgfCAneWVhci1xdWFydGVyJyB8IHN0cmluZztcbmV4cG9ydCB0eXBlIFRZUEVfREFURV9GT1JNQVQgPSAneWVhcicgfCAnbW9udGgnIHwgJ3F1YXJ0ZXInIHwgJ2RheSc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgSVR5cGVEYXRlIHtcbiAgaWQ6IFRZUEVfREFURV9GT1JNQVQ7XG4gIGtleVNlbGVjdGVkOiBhbnk7XG4gIGRpc2FibGU/OiBib29sZWFuO1xuICBzaG93Qm9yZGVyRXJyb3I/OiBib29sZWFuO1xuICBpc0Vycm9yPzogYm9vbGVhbjtcbiAgZnVuY3Rpb25Db250cm9sPzogSURyb3Bkb3duRnVuY3Rpb25Db250cm9sRXZlbnQ7XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgSURhdGVEcm9wZG93bkRpc2FibGVLZXlzIHtcbiAgZnJvbT86IFdyaXRhYmxlU2lnbmFsPElEYXRlRHJvcGRvd25EaXNhYmxlPjtcbiAgdG8/OiBXcml0YWJsZVNpZ25hbDxJRGF0ZURyb3Bkb3duRGlzYWJsZT47XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgSURhdGVEcm9wZG93bkRpc2FibGUge1xuICB5ZWFyPzogV3JpdGFibGVTaWduYWw8QXJyYXk8bnVtYmVyPj47XG4gIG1vbnRoPzogV3JpdGFibGVTaWduYWw8QXJyYXk8bnVtYmVyPj47XG4gIHF1YXJ0ZXI/OiBXcml0YWJsZVNpZ25hbDxBcnJheTxudW1iZXI+PjtcbiAgZGF5PzogV3JpdGFibGVTaWduYWw8QXJyYXk8bnVtYmVyPj47XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgSUhpZGRlbkRhdGUge1xuICBmb3JtYXREYXRlOiBUWVBFX0RBVEVfRFJPUERPV05fRk9STUFUO1xuICB5ZWFyTW9udGg/OiBXcml0YWJsZVNpZ25hbDxBcnJheTxXcml0YWJsZVNpZ25hbDxJSGlkZGVuRGF0ZVllYXJNb250aD4+PjtcbiAgbW9udGhEYXk/OiBXcml0YWJsZVNpZ25hbDxBcnJheTxXcml0YWJsZVNpZ25hbDxJSGlkZGVuRGF0ZU1vbnRoRGF5Pj4+O1xufVxuXG5pbnRlcmZhY2UgSUhpZGRlbkRhdGVNb250aERheSB7XG4gIGhpZGRlbk1vbnRoOiBudW1iZXI7XG4gIGhpZGRlbkRheXM6IEFycmF5PG51bWJlcj47XG59XG5pbnRlcmZhY2UgSUhpZGRlbkRhdGVZZWFyTW9udGgge1xuICBoaWRkZW5ZZWFyOiBudW1iZXI7XG4gIGhpZGRlbk1vbnRoczogQXJyYXk8bnVtYmVyPjtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBJRnJvbUFuZFRvRGF0ZUxhYmVsIHtcbiAgdG8/OiBzdHJpbmc7XG4gIGZyb20/OiBzdHJpbmc7XG4gIGNsYXNzTGFiZWxUbz86IHN0cmluZztcbiAgY2xhc3NMYWJlbEZyb20/OiBzdHJpbmc7XG59XG4iXX0=
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZW1pdC1kcm9wZG93bi5pbnRlcmZhY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzLXVpL2NvbXBvbmVudHMvZGF0ZXRpbWUvZHJvcGRvd24vc3JjL2ludGVyZmFjZXMvZW1pdC1kcm9wZG93bi5pbnRlcmZhY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFdyaXRhYmxlU2lnbmFsIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbmV4cG9ydCBpbnRlcmZhY2UgSUVtaXRNdWx0aURhdGVEcm9wZG93biB7XG4gIGZyb206IFdyaXRhYmxlU2lnbmFsPElFbWl0U2luZ2xlRGF0ZURyb3Bkb3duPjtcbiAgdG86IFdyaXRhYmxlU2lnbmFsPElFbWl0U2luZ2xlRGF0ZURyb3Bkb3duPjtcbn1cblxuZXhwb3J0IGludGVyZmFjZSBJRW1pdFNpbmdsZURhdGVEcm9wZG93biB7XG4gIHllYXI/OiBudW1iZXI7XG4gIG1vbnRoPzogbnVtYmVyO1xuICBxdWFydGVyPzogbnVtYmVyO1xuICBkYXk/OiBudW1iZXI7XG59XG4iXX0=
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZnVuY3Rpb25zLWNvbnRyb2wtZXZlbnQuaW50ZXJmYWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy11aS9jb21wb25lbnRzL2RhdGV0aW1lL2Ryb3Bkb3duL3NyYy9pbnRlcmZhY2VzL2Z1bmN0aW9ucy1jb250cm9sLWV2ZW50LmludGVyZmFjZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGludGVyZmFjZSBJRGF0ZURyb3Bkb3duSXRlbUZ1bmN0aW9uQ29udHJvbEV2ZW50IHtcbiAgY2hlY2tJc1ZhbGlkOiAoKSA9PiBQcm9taXNlPGJvb2xlYW4+O1xuICByZXNldERyb3Bkb3duOiAoKSA9PiBQcm9taXNlPHZvaWQ+O1xuICByZXNldEVycm9yOiAoKSA9PiBQcm9taXNlPHZvaWQ+O1xuICBzZXRFcnJvcjogKGVycm9yOiBib29sZWFuKSA9PiBQcm9taXNlPHZvaWQ+O1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIElEYXRlRHJvcGRvd25GdW5jdGlvbkNvbnRyb2xFdmVudCB7XG4gIGNoZWNrSXNWYWxpZDogKCkgPT4gUHJvbWlzZTxib29sZWFuPjtcbiAgcmVzZXRFcnJvcj86ICgpID0+IFByb21pc2U8dm9pZD47XG4gIHJlc2V0VGltZT86ICgpID0+IFByb21pc2U8dm9pZD47XG59XG4iXX0=
|
|
@@ -0,0 +1,5 @@
|
|
|
1
|
+
export * from './date-dropdown.interface';
|
|
2
|
+
export * from './emit-dropdown.interface';
|
|
3
|
+
export * from './functions-control-event.interface';
|
|
4
|
+
export * from './valid.interface';
|
|
5
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzLXVpL2NvbXBvbmVudHMvZGF0ZXRpbWUvZHJvcGRvd24vc3JjL2ludGVyZmFjZXMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYywyQkFBMkIsQ0FBQztBQUMxQyxjQUFjLDJCQUEyQixDQUFDO0FBQzFDLGNBQWMscUNBQXFDLENBQUM7QUFDcEQsY0FBYyxtQkFBbUIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vZGF0ZS1kcm9wZG93bi5pbnRlcmZhY2UnO1xuZXhwb3J0ICogZnJvbSAnLi9lbWl0LWRyb3Bkb3duLmludGVyZmFjZSc7XG5leHBvcnQgKiBmcm9tICcuL2Z1bmN0aW9ucy1jb250cm9sLWV2ZW50LmludGVyZmFjZSc7XG5leHBvcnQgKiBmcm9tICcuL3ZhbGlkLmludGVyZmFjZSc7XG4iXX0=
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
export {};
|
|
2
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmFsaWQuaW50ZXJmYWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy11aS9jb21wb25lbnRzL2RhdGV0aW1lL2Ryb3Bkb3duL3NyYy9pbnRlcmZhY2VzL3ZhbGlkLmludGVyZmFjZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGludGVyZmFjZSBJVmFsaWREYXRlRHJvcGRvd24ge1xuICBtZXNzYWdlPzogc3RyaW5nO1xuICBpbnRlcnBvbGF0ZVBhcmFtcz86IHsgYW55OiBvYmplY3QgfTtcbiAgbWVzc2FnZVZhbGlkQ29tcGFyZVRpbWU/OiBzdHJpbmc7XG4gIGludGVycG9sYXRlUGFyYW1zQ29tcGFyZVRpbWU/OiB7IGFueTogb2JqZWN0IH07XG59XG4iXX0=
|