@libs-ui/components-datetime-dropdown 0.2.10-6.2

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/defines/date-dropdown.define.d.ts +40 -0
  3. package/directive/date-dropdown.directive.d.ts +11 -0
  4. package/dropdown.component.d.ts +88 -0
  5. package/esm2022/defines/date-dropdown.define.mjs +248 -0
  6. package/esm2022/directive/date-dropdown.directive.mjs +33 -0
  7. package/esm2022/dropdown.component.mjs +274 -0
  8. package/esm2022/index.mjs +2 -0
  9. package/esm2022/interfaces/date-dropdown.interface.mjs +7 -0
  10. package/esm2022/interfaces/emit-dropdown.interface.mjs +2 -0
  11. package/esm2022/interfaces/functions-control-event.interface.mjs +2 -0
  12. package/esm2022/interfaces/valid.interface.mjs +3 -0
  13. package/esm2022/item/child/child.component.mjs +124 -0
  14. package/esm2022/item/item.component.mjs +216 -0
  15. package/esm2022/libs-ui-components-datetime-dropdown.mjs +5 -0
  16. package/esm2022/pipes/build-list-by-date-type-.pipe.mjs +19 -0
  17. package/esm2022/pipes/build-width.pipe.mjs +23 -0
  18. package/fesm2022/libs-ui-components-datetime-dropdown.mjs +922 -0
  19. package/fesm2022/libs-ui-components-datetime-dropdown.mjs.map +1 -0
  20. package/index.d.ts +1 -0
  21. package/interfaces/date-dropdown.interface.d.ts +47 -0
  22. package/interfaces/emit-dropdown.interface.d.ts +11 -0
  23. package/interfaces/functions-control-event.interface.d.ts +11 -0
  24. package/interfaces/valid.interface.d.ts +10 -0
  25. package/item/child/child.component.d.ts +51 -0
  26. package/item/item.component.d.ts +59 -0
  27. package/package.json +25 -0
  28. package/pipes/build-list-by-date-type-.pipe.d.ts +15 -0
  29. package/pipes/build-width.pipe.d.ts +7 -0
@@ -0,0 +1,274 @@
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
+ /* 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
+ /* 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
+ /* 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
+ /* 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).pipe().subscribe(() => {
82
+ this.checkResponsive();
83
+ this.changeType.set(false);
84
+ });
85
+ });
86
+ });
87
+ }
88
+ ngOnInit() {
89
+ this.outFunctionsControl.emit({ checkIsValid: this.validate.bind(this), resetError: this.resetError.bind(this), resetTime: this.resetDropdown.bind(this) });
90
+ if (this.selectedDateTime()) {
91
+ this.chooseDate.set(this.selectedDateTime());
92
+ }
93
+ }
94
+ ngAfterViewInit() {
95
+ fromEvent(window, 'resize').pipe(takeUntil(this.onDestroy)).subscribe(this.setWidthDate.bind(this));
96
+ this.widthLabel.set(undefined);
97
+ timer(0).pipe().subscribe(() => {
98
+ this.checkResponsive();
99
+ });
100
+ }
101
+ checkResponsive() {
102
+ this.isResponsive.set(false);
103
+ const widthElementParent = this.containerRef()?.nativeElement?.getBoundingClientRect().width || 0;
104
+ this.widthLabelFrom.set(this.labelFromRef()?.nativeElement?.getBoundingClientRect().width || 0);
105
+ this.widthLabelTo.set(this.labelToRef()?.nativeElement?.getBoundingClientRect().width || 0);
106
+ const spaceBetweenDate = (this.arrayFormat().length * 2) + (this.fromAndToDateLabel().from ? 1 : 0);
107
+ const width = (this.widthDropdown() * 4) + (8 * spaceBetweenDate) + this.widthLabelFrom() + this.widthLabelTo();
108
+ console.log(widthElementParent);
109
+ if (widthElementParent < width) {
110
+ this.isResponsive.set(true);
111
+ }
112
+ }
113
+ handlerChangeSelectedKey(event, type) {
114
+ this.chooseDate.update(current => {
115
+ if (current) {
116
+ current[type].set(event);
117
+ }
118
+ return current;
119
+ });
120
+ if (this.isEmitAfterChanged()) {
121
+ const dataEmit = this.isMultiple() ? this.chooseDate() : this.chooseDate()?.from();
122
+ if (dataEmit) {
123
+ this.outSelectedDropdown.emit(dataEmit);
124
+ }
125
+ }
126
+ this.applyDate();
127
+ }
128
+ async resetDropdown() {
129
+ this.functionsControl.forEach(control => control.resetDropdown());
130
+ }
131
+ async resetError() {
132
+ this.functionsControl.forEach(control => control.resetError());
133
+ }
134
+ setWidthDate() {
135
+ if (!this.containerRef() || !this.containerRef()?.nativeElement) {
136
+ return;
137
+ }
138
+ timer(0).pipe().subscribe(() => {
139
+ this.checkResponsive();
140
+ });
141
+ }
142
+ handlerFunctionControl(event, type) {
143
+ this.functionsControl.set(type, event);
144
+ }
145
+ async checkValid() {
146
+ let valid = true;
147
+ for (const control of this.functionsControl.values()) {
148
+ if (!(await control.checkIsValid())) {
149
+ valid = false;
150
+ }
151
+ }
152
+ if (this.compareDate()) {
153
+ valid = false;
154
+ }
155
+ return valid;
156
+ }
157
+ setError(error) {
158
+ this.functionsControl.forEach(control => control.setError(error));
159
+ }
160
+ compareDate() {
161
+ const type = this.typeFormat().split('-');
162
+ const dateCompare = [];
163
+ type.forEach(item => {
164
+ const from = this.chooseDate()?.from()[item];
165
+ const to = this.chooseDate()?.to()[item];
166
+ dateCompare.push({ from: from, to: to });
167
+ });
168
+ if (this.ignoreValidTimeCompare() || !this.checkCondition(true)) {
169
+ this.isErrorCompareDate.set(false);
170
+ return false;
171
+ }
172
+ if (CompareDate(dateCompare, this.ignoreAllowTimeEqual())) {
173
+ this.setError(true);
174
+ this.isErrorCompareDate.set(true);
175
+ return true;
176
+ }
177
+ this.isErrorCompareDate.set(false);
178
+ return false;
179
+ }
180
+ async validate() {
181
+ let valid = true;
182
+ if (!this.validRequired()) {
183
+ if (!this.checkCondition(false) && !this.ignoreRequiredValueSecondWhenNotValidRequired()) {
184
+ valid = await this.checkValid();
185
+ }
186
+ return valid;
187
+ }
188
+ return await this.checkValid();
189
+ }
190
+ checkCondition(hasValue) {
191
+ let checkValue = true;
192
+ const type = this.typeFormat().split('-');
193
+ type.forEach(item => {
194
+ if (hasValue && (!this.chooseDate()?.from()[item] || !this.chooseDate()?.to()[item])) {
195
+ checkValue = false;
196
+ }
197
+ if (!hasValue && (this.chooseDate()?.from()[item] || this.chooseDate()?.to()[item])) {
198
+ checkValue = false;
199
+ }
200
+ });
201
+ return checkValue;
202
+ }
203
+ applyDate() {
204
+ this.setError(false);
205
+ this.isErrorCompareDate.set(false);
206
+ if (this.isCheckErrorWhenSelectItem() && !this.validate()) {
207
+ return;
208
+ }
209
+ const from = this.chooseDate()?.from;
210
+ const to = this.chooseDate()?.to;
211
+ console.log(from?.(), to?.(), this.isMultiple());
212
+ if (this.isMultiple()) {
213
+ if (this.compareDate()) {
214
+ return;
215
+ }
216
+ let dataSelected = { from: signal({}), to: signal({}) };
217
+ this.arrayFormat().forEach(key => {
218
+ if (!from?.()?.[key] || !to?.()?.[key]) {
219
+ dataSelected = undefined;
220
+ }
221
+ if (dataSelected) {
222
+ dataSelected.from.update(current => {
223
+ current[key] = Number(from?.()[key]);
224
+ return current;
225
+ });
226
+ dataSelected.to.update(current => {
227
+ current[key] = Number(to?.()[key]);
228
+ return current;
229
+ });
230
+ }
231
+ });
232
+ if (dataSelected) {
233
+ this.outChooseMultiDate.emit(dataSelected);
234
+ }
235
+ return;
236
+ }
237
+ let dataSelected = {};
238
+ this.arrayFormat().forEach(key => {
239
+ if (!from?.()?.[key]) {
240
+ dataSelected = undefined;
241
+ }
242
+ if (dataSelected) {
243
+ dataSelected[key] = Number(from?.()?.[key]);
244
+ }
245
+ });
246
+ if (dataSelected) {
247
+ this.outChooseSingleDate.emit(dataSelected);
248
+ }
249
+ }
250
+ handlerChangeWidthLabel(width) {
251
+ this.cacheWidthLabel.set(width < (this.cacheWidthLabel() || 0) ? this.cacheWidthLabel() : Math.ceil(width));
252
+ if (this.timeOut()) {
253
+ clearTimeout(this.timeOut());
254
+ }
255
+ this.timeOut.set(setTimeout(() => {
256
+ this.widthLabel.set(this.cacheWidthLabel());
257
+ }, 100));
258
+ }
259
+ handlerChangStageFlagMouse(flagMouse) {
260
+ this.outChangStageFlagMouse.emit(flagMouse);
261
+ }
262
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: LibsUiComponentsDatetimeDropdownComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
263
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", 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 [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 #parent\n class=\"flex items-start\"\n [class.!w-full]=\"widthByElement()\"\n [class.!column]=\"isResponsive() && isMultiple()\">\n <div #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\n @if (isMultiple() && !ignoreFromAndToDateLabel() && fromAndToDateLabel().from) {\n <div class=\"mr-[8px] flex-shrink-0 h-[32px] flex items-center\"\n [style.width.px]=\"isResponsive() ? (widthLabel() || undefined) : undefined\">\n <span #labelFrom\n LibsUiComponentsDatetimeDropdownDirective\n [class.!opacity-[0.5]]=\"disable()\"\n class=\"libs-ui-font-h5r text-nowrap {{ fromAndToDateLabel().classLabelFrom || '' }}\"\n (outChangeWidth)=\"handlerChangeWidthLabel($event)\">\n {{ (fromAndToDateLabel().from||' ')| translate }}\n </span>\n </div>\n }\n <div class=\"flex\"\n [class.!w-full]=\"widthByElement()\">\n @if (!changeType()) {\n <libs_ui-components-datetime-dropdown-item [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 #childTo\n [class.!w-[50%]]=\"widthByElement()\"\n [class.!w-full]=\" !widthByElement() || isResponsive()\"\n class=\"flex items-start\">\n <div class=\"mr-[8px] h-[32px] flex-shrink-0 flex items-center\"\n [style.width.px]=\"isResponsive() ? widthLabel() : undefined\">\n @if (!ignoreFromAndToDateLabel()) {\n <span #labelTo\n LibsUiComponentsDatetimeDropdownDirective\n [class.!opacity-[0.5]]=\"disable()\"\n class=\"libs-ui-font-h5r text-nowrap {{ fromAndToDateLabel().classLabelTo || '' }}\"\n (outChangeWidth)=\"handlerChangeWidthLabel($event)\">\n {{ (fromAndToDateLabel().to||' ')| translate }}\n </span>\n }\n @if (ignoreFromAndToDateLabel()) {\n <span [class.!opacity-[0.5]]=\"disable()\"\n class=\"libs-ui-font-h5r\">-</span>\n }\n </div>\n <div class=\"flex\"\n [class.!w-full]=\"widthByElement()\">\n @if (!changeType()) {\n <libs_ui-components-datetime-dropdown-item [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\">{{ validRequired()?.messageValidCompareTime || \"i18n_invalid_end_date_selected\" | translate:validRequired()?.interpolateParamsCompareTime }}</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 });
264
+ }
265
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: LibsUiComponentsDatetimeDropdownComponent, decorators: [{
266
+ type: Component,
267
+ args: [{ selector: 'libs_ui-components-datetime-dropdown', standalone: true, changeDetection: ChangeDetectionStrategy.OnPush, imports: [
268
+ TranslateModule,
269
+ LibsUiComponentsLabelComponent,
270
+ LibsUiComponentsDatetimeDropdownDirective,
271
+ LibsUiComponentsDatetimeDropdownItemComponent
272
+ ], template: "@if (labelConfig(); as labelConfig) {\n <libs_ui-components-label [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 #parent\n class=\"flex items-start\"\n [class.!w-full]=\"widthByElement()\"\n [class.!column]=\"isResponsive() && isMultiple()\">\n <div #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\n @if (isMultiple() && !ignoreFromAndToDateLabel() && fromAndToDateLabel().from) {\n <div class=\"mr-[8px] flex-shrink-0 h-[32px] flex items-center\"\n [style.width.px]=\"isResponsive() ? (widthLabel() || undefined) : undefined\">\n <span #labelFrom\n LibsUiComponentsDatetimeDropdownDirective\n [class.!opacity-[0.5]]=\"disable()\"\n class=\"libs-ui-font-h5r text-nowrap {{ fromAndToDateLabel().classLabelFrom || '' }}\"\n (outChangeWidth)=\"handlerChangeWidthLabel($event)\">\n {{ (fromAndToDateLabel().from||' ')| translate }}\n </span>\n </div>\n }\n <div class=\"flex\"\n [class.!w-full]=\"widthByElement()\">\n @if (!changeType()) {\n <libs_ui-components-datetime-dropdown-item [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 #childTo\n [class.!w-[50%]]=\"widthByElement()\"\n [class.!w-full]=\" !widthByElement() || isResponsive()\"\n class=\"flex items-start\">\n <div class=\"mr-[8px] h-[32px] flex-shrink-0 flex items-center\"\n [style.width.px]=\"isResponsive() ? widthLabel() : undefined\">\n @if (!ignoreFromAndToDateLabel()) {\n <span #labelTo\n LibsUiComponentsDatetimeDropdownDirective\n [class.!opacity-[0.5]]=\"disable()\"\n class=\"libs-ui-font-h5r text-nowrap {{ fromAndToDateLabel().classLabelTo || '' }}\"\n (outChangeWidth)=\"handlerChangeWidthLabel($event)\">\n {{ (fromAndToDateLabel().to||' ')| translate }}\n </span>\n }\n @if (ignoreFromAndToDateLabel()) {\n <span [class.!opacity-[0.5]]=\"disable()\"\n class=\"libs-ui-font-h5r\">-</span>\n }\n </div>\n <div class=\"flex\"\n [class.!w-full]=\"widthByElement()\">\n @if (!changeType()) {\n <libs_ui-components-datetime-dropdown-item [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\">{{ validRequired()?.messageValidCompareTime || \"i18n_invalid_end_date_selected\" | translate:validRequired()?.interpolateParamsCompareTime }}</span>\n </div>\n}\n" }]
273
+ }], ctorParameters: () => [] });
274
+ //# 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":"AAAA,OAAO,EAAiB,uBAAuB,EAAE,SAAS,EAAE,QAAQ,EAAE,MAAM,EAAc,MAAM,EAAE,KAAK,EAAU,MAAM,EAAE,MAAM,EAAE,SAAS,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AAC7K,OAAO,EAAU,8BAA8B,EAAE,MAAM,2BAA2B,CAAC;AAEnF,OAAO,EAAE,eAAe,EAAE,gBAAgB,EAAE,MAAM,qBAAqB,CAAC;AACxE,OAAO,EAAE,SAAS,EAAE,OAAO,EAAE,SAAS,EAAE,KAAK,EAAE,MAAM,MAAM,CAAC;AAC5D,OAAO,EAAE,WAAW,EAAE,MAAM,gCAAgC,CAAC;AAC7D,OAAO,EAAE,yCAAyC,EAAE,MAAM,qCAAqC,CAAC;AAKhG,OAAO,EAAE,6CAA6C,EAAE,MAAM,uBAAuB,CAAC;;;AAiBtF,MAAM,OAAO,yCAAyC;IACpD,cAAc;IACJ,KAAK,GAAG,MAAM,CAAS,CAAC,CAAC,CAAC;IAC1B,YAAY,GAAG,MAAM,CAAqB,SAAS,CAAC,CAAC;IACrD,UAAU,GAAG,MAAM,CAAqB,SAAS,CAAC,CAAC;IACnD,cAAc,GAAG,MAAM,CAAS,CAAC,CAAC,CAAC;IACnC,YAAY,GAAG,MAAM,CAAS,CAAC,CAAC,CAAC;IACjC,kBAAkB,GAAG,MAAM,CAAsB,SAAS,CAAC,CAAC;IAC5D,UAAU,GAAG,MAAM,CAAqC,EAAE,IAAI,EAAE,MAAM,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,MAAM,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC;IAC9F,YAAY,GAAG,MAAM,CAAsB,SAAS,CAAC,CAAC;IACtD,WAAW,GAAG,QAAQ,CAAC,GAAG,EAAE;QACpC,OAAO,IAAI,CAAC,UAAU,EAAE,CAAC,KAAK,CAAC,GAAG,CAA4B,CAAC;IACjE,CAAC,CAAC,CAAC;IACO,UAAU,GAAG,MAAM,CAAsB,SAAS,CAAC,CAAC;IAEtD,eAAe,GAAG,MAAM,CAAqB,SAAS,CAAC,CAAC;IACxD,OAAO,GAAG,MAAM,CAAqB,SAAS,CAAC,CAAC;IAChD,SAAS,GAAG,IAAI,OAAO,EAAQ,CAAC;IAChC,gBAAgB,GAAG,IAAI,GAAG,EAAiD,CAAC;IAEpF,WAAW;IACF,WAAW,GAAG,KAAK,CAAqB,SAAS,CAAC,CAAC;IACnD,aAAa,GAAG,KAAK,CAAiB,GAAG,EAAE,EAAE,SAAS,EAAE,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,IAAI,GAAG,EAAE,CAAC,CAAC;IACnF,MAAM,GAAG,KAAK,CAAiB,IAAI,EAAE,EAAE,SAAS,EAAE,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,IAAI,IAAI,EAAE,CAAC,CAAC;IAC9E,OAAO,GAAG,KAAK,CAAS,CAAC,CAAC,CAAC;IAC3B,OAAO,GAAG,KAAK,CAAS,CAAC,CAAC,CAAC;IAC3B,QAAQ,GAAG,KAAK,CAAqB,SAAS,CAAC,CAAC;IAChD,OAAO,GAAG,KAAK,CAAU,KAAK,CAAC,CAAC;IAChC,QAAQ,GAAG,KAAK,CAAU,KAAK,CAAC,CAAC;IACjC,UAAU,GAAG,KAAK,CAAU,KAAK,CAAC,CAAC;IACnC,WAAW,GAAG,KAAK,CAAsB,SAAS,CAAC,CAAC;IACpD,aAAa,GAAG,KAAK,CAAU,KAAK,CAAC,CAAC;IACtC,cAAc,GAAG,KAAK,CAAU,KAAK,CAAC,CAAC;IACvC,cAAc,GAAG,KAAK,CAAU,KAAK,CAAC,CAAC;IACvC,aAAa,GAAG,KAAK,CAAU,KAAK,CAAC,CAAC;IACtC,UAAU,GAAG,KAAK,CAAuD,WAAW,EAAE,EAAE,SAAS,EAAE,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,IAAI,WAAW,EAAE,CAAC,CAAC;IACtI,kBAAkB,GAAG,KAAK,CAAsB,EAAE,IAAI,EAAE,iBAAiB,EAAE,EAAE,EAAE,SAAS,EAAE,CAAC,CAAC;IAC5F,2BAA2B,GAAG,KAAK,CAAU,KAAK,CAAC,CAAC;IACpD,gBAAgB,GAAG,KAAK,CAAqC,SAAS,CAAC,CAAC;IACxE,kBAAkB,GAAG,KAAK,CAAU,KAAK,CAAC,CAAC,CAAC,oDAAoD;IAChG,kBAAkB,GAAG,KAAK,EAA4B,CAAC;IACvD,wBAAwB,GAAG,KAAK,CAAU,KAAK,CAAC,CAAC;IACjD,mCAAmC,GAAG,KAAK,CAAqB,SAAS,CAAC,CAAC;IAC3E,UAAU,GAAG,KAAK,EAA2B,CAAC;IAC9C,eAAe,GAAG,KAAK,CAAiF,SAAS,CAAC,CAAC;IACnH,yBAAyB,GAAG,KAAK,CAAU,KAAK,CAAC,CAAC;IAClD,eAAe,GAAG,KAAK,CAAuC,SAAS,CAAC,CAAC;IAEzE,oBAAoB,GAAG,KAAK,CAAmB,IAAI,EAAE,EAAE,SAAS,EAAE,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,IAAI,IAAI,EAAE,CAAC,CAAC;IAC9F,sBAAsB,GAAG,KAAK,CAAmB,KAAK,EAAE,EAAE,SAAS,EAAE,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,IAAI,KAAK,EAAE,CAAC,CAAC;IAClG,0BAA0B,GAAG,KAAK,CAAmB,IAAI,EAAE,EAAE,SAAS,EAAE,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,IAAI,IAAI,EAAE,CAAC,CAAC;IACpG,6CAA6C,GAAG,KAAK,CAAU,KAAK,CAAC,CAAC,CAAC,qDAAqD;IAC5H,aAAa,GAAG,KAAK,EAAsB,CAAC;IAErD,YAAY;IACH,mBAAmB,GAAG,MAAM,EAAqC,CAAC;IAClE,mBAAmB,GAAG,MAAM,EAAoD,CAAC,CAAA,4FAA4F;IAC7K,kBAAkB,GAAG,MAAM,EAA0B,CAAC;IACtD,mBAAmB,GAAG,MAAM,EAA2B,CAAC;IACxD,sBAAsB,GAAG,MAAM,EAAc,CAAC;IAEvD,gBAAgB;IACR,YAAY,GAAG,SAAS,CAAa,QAAQ,CAAC,CAAC;IAC/C,YAAY,GAAG,SAAS,CAAa,WAAW,CAAC,CAAC;IAClD,UAAU,GAAG,SAAS,CAAa,SAAS,CAAC,CAAC;IAEtD,YAAY;IACJ,SAAS,GAAG,MAAM,CAAC,gBAAgB,CAAC,CAAC;IAE7C;QACE,MAAM,CAAC,GAAG,EAAE;YACV,MAAM,UAAU,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC;YAErC,IAAI,CAAC,UAAU,EAAE,CAAC;gBAChB,OAAO;YACT,CAAC;YAED,SAAS,CAAC,GAAG,EAAE;gBACb,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;gBAC1B,IAAI,CAAC,gBAAgB,CAAC,KAAK,EAAE,CAAC;gBAC9B,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC,SAAS,CAAC,GAAG,EAAE;oBAC7B,IAAI,CAAC,eAAe,EAAE,CAAC;oBACvB,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;gBAC7B,CAAC,CAAC,CAAC;YACL,CAAC,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;IACL,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,EAAE,YAAY,EAAE,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,UAAU,EAAE,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,SAAS,EAAE,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QAC5J,IAAI,IAAI,CAAC,gBAAgB,EAAE,EAAE,CAAC;YAC5B,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,IAAI,CAAC,gBAAgB,EAAE,CAAC,CAAC;QAC/C,CAAC;IACH,CAAC;IAED,eAAe;QACb,SAAS,CAAC,MAAM,EAAE,QAAQ,CAAC,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC;QACpG,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,SAAS,CAAC,CAAC;QAC/B,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC,SAAS,CAAC,GAAG,EAAE;YAC7B,IAAI,CAAC,eAAe,EAAE,CAAC;QACzB,CAAC,CAAC,CAAC;IACL,CAAC;IAES,eAAe;QACvB,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;QAC7B,MAAM,kBAAkB,GAAG,IAAI,CAAC,YAAY,EAAE,EAAE,aAAa,EAAE,qBAAqB,EAAE,CAAC,KAAK,IAAI,CAAC,CAAC;QAElG,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,IAAI,CAAC,YAAY,EAAE,EAAE,aAAa,EAAE,qBAAqB,EAAE,CAAC,KAAK,IAAI,CAAC,CAAC,CAAC;QAChG,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,IAAI,CAAC,UAAU,EAAE,EAAE,aAAa,EAAE,qBAAqB,EAAE,CAAC,KAAK,IAAI,CAAC,CAAC,CAAC;QAE5F,MAAM,gBAAgB,GAAG,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,MAAM,GAAG,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,kBAAkB,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QACpG,MAAM,KAAK,GAAG,CAAC,IAAI,CAAC,aAAa,EAAE,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,gBAAgB,CAAC,GAAG,IAAI,CAAC,cAAc,EAAE,GAAG,IAAI,CAAC,YAAY,EAAE,CAAC;QAEhH,OAAO,CAAC,GAAG,CAAC,kBAAkB,CAAC,CAAC;QAGhC,IAAI,kBAAkB,GAAG,KAAK,EAAE,CAAC;YAC/B,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;QAC9B,CAAC;IACH,CAAC;IAES,wBAAwB,CAAC,KAA8B,EAAE,IAAmB;QACpF,IAAI,CAAC,UAAU,CAAC,MAAM,CAAC,OAAO,CAAC,EAAE;YAC/B,IAAI,OAAO,EAAE,CAAC;gBACZ,OAAO,CAAC,IAAI,CAAC,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;YAC3B,CAAC;YAED,OAAO,OAAO,CAAC;QACjB,CAAC,CAAC,CAAC;QACH,IAAI,IAAI,CAAC,kBAAkB,EAAE,EAAE,CAAC;YAC9B,MAAM,QAAQ,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,UAAU,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,UAAU,EAAE,EAAE,IAAI,EAAE,CAAC;YAEnF,IAAI,QAAQ,EAAE,CAAC;gBACb,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;YAC1C,CAAC;QACH,CAAC;QACD,IAAI,CAAC,SAAS,EAAE,CAAC;IACnB,CAAC;IAEO,KAAK,CAAC,aAAa;QACzB,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE,CAAC,OAAO,CAAC,aAAa,EAAE,CAAC,CAAC;IACpE,CAAC;IAEO,KAAK,CAAC,UAAU;QACtB,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE,CAAC,OAAO,CAAC,UAAU,EAAE,CAAC,CAAC;IACjE,CAAC;IAEO,YAAY;QAClB,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE,IAAI,CAAC,IAAI,CAAC,YAAY,EAAE,EAAE,aAAa,EAAE,CAAC;YAChE,OAAO;QACT,CAAC;QACD,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,EAAE,CAAC,SAAS,CAAC,GAAG,EAAE;YAC7B,IAAI,CAAC,eAAe,EAAE,CAAC;QACzB,CAAC,CAAC,CAAC;IACL,CAAC;IAES,sBAAsB,CAAC,KAA4C,EAAE,IAAmB;QAChG,IAAI,CAAC,gBAAgB,CAAC,GAAG,CAAC,IAAI,EAAE,KAAK,CAAC,CAAC;IACzC,CAAC;IAES,KAAK,CAAC,UAAU;QACxB,IAAI,KAAK,GAAG,IAAI,CAAC;QAEjB,KAAK,MAAM,OAAO,IAAI,IAAI,CAAC,gBAAgB,CAAC,MAAM,EAAE,EAAE,CAAC;YACrD,IAAI,CAAC,CAAC,MAAM,OAAO,CAAC,YAAY,EAAE,CAAC,EAAE,CAAC;gBACpC,KAAK,GAAG,KAAK,CAAC;YAChB,CAAC;QACH,CAAC;QACD,IAAI,IAAI,CAAC,WAAW,EAAE,EAAE,CAAC;YACvB,KAAK,GAAG,KAAK,CAAC;QAChB,CAAC;QAED,OAAO,KAAK,CAAC;IACf,CAAC;IAEO,QAAQ,CAAC,KAAc;QAC7B,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE,CAAC,OAAO,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC,CAAC;IACpE,CAAC;IAEO,WAAW;QACjB,MAAM,IAAI,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC,KAAK,CAAC,GAAG,CAA4B,CAAC;QACrE,MAAM,WAAW,GAAgE,EAAE,CAAC;QAEpF,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE;YAClB,MAAM,IAAI,GAAG,IAAI,CAAC,UAAU,EAAE,EAAE,IAAI,EAAE,CAAC,IAAI,CAAC,CAAC;YAC7C,MAAM,EAAE,GAAG,IAAI,CAAC,UAAU,EAAE,EAAE,EAAE,EAAE,CAAC,IAAI,CAAC,CAAC;YAEzC,WAAW,CAAC,IAAI,CAAC,EAAE,IAAI,EAAE,IAAI,EAAE,EAAE,EAAE,EAAE,EAAE,CAAC,CAAC;QAC3C,CAAC,CAAC,CAAC;QACH,IAAI,IAAI,CAAC,sBAAsB,EAAE,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,EAAE,CAAC;YAChE,IAAI,CAAC,kBAAkB,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;YAEnC,OAAO,KAAK,CAAC;QACf,CAAC;QACD,IAAI,WAAW,CAAC,WAAW,EAAE,IAAI,CAAC,oBAAoB,EAAE,CAAC,EAAE,CAAC;YAC1D,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;YACpB,IAAI,CAAC,kBAAkB,CAAC,GAAG,CAAC,IAAI,CAAC,CAAC;YAElC,OAAO,IAAI,CAAC;QACd,CAAC;QACD,IAAI,CAAC,kBAAkB,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;QAEnC,OAAO,KAAK,CAAC;IACf,CAAC;IAEO,KAAK,CAAC,QAAQ;QACpB,IAAI,KAAK,GAAG,IAAI,CAAC;QAEjB,IAAI,CAAC,IAAI,CAAC,aAAa,EAAE,EAAE,CAAC;YAC1B,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,6CAA6C,EAAE,EAAE,CAAC;gBACzF,KAAK,GAAG,MAAM,IAAI,CAAC,UAAU,EAAE,CAAC;YAClC,CAAC;YAED,OAAO,KAAK,CAAC;QACf,CAAC;QAED,OAAO,MAAM,IAAI,CAAC,UAAU,EAAE,CAAC;IACjC,CAAC;IAEO,cAAc,CAAC,QAAiB;QACtC,IAAI,UAAU,GAAG,IAAI,CAAC;QACtB,MAAM,IAAI,GAAG,IAAI,CAAC,UAAU,EAAE,CAAC,KAAK,CAAC,GAAG,CAA4B,CAAC;QAErE,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE;YAClB,IAAI,QAAQ,IAAI,CAAC,CAAC,IAAI,CAAC,UAAU,EAAE,EAAE,IAAI,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE,EAAE,EAAE,EAAE,CAAC,IAAI,CAAC,CAAC,EAAE,CAAC;gBACrF,UAAU,GAAG,KAAK,CAAC;YACrB,CAAC;YACD,IAAI,CAAC,QAAQ,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE,EAAE,IAAI,EAAE,CAAC,IAAI,CAAC,IAAI,IAAI,CAAC,UAAU,EAAE,EAAE,EAAE,EAAE,CAAC,IAAI,CAAC,CAAC,EAAE,CAAC;gBACpF,UAAU,GAAG,KAAK,CAAC;YACrB,CAAC;QACH,CAAC,CAAC,CAAC;QAEH,OAAO,UAAU,CAAC;IACpB,CAAC;IAES,SAAS;QACjB,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;QACrB,IAAI,CAAC,kBAAkB,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;QACnC,IAAI,IAAI,CAAC,0BAA0B,EAAE,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,EAAE,CAAC;YAC1D,OAAO;QACT,CAAC;QACD,MAAM,IAAI,GAAG,IAAI,CAAC,UAAU,EAAE,EAAE,IAAI,CAAC;QACrC,MAAM,EAAE,GAAG,IAAI,CAAC,UAAU,EAAE,EAAE,EAAE,CAAC;QAEjC,OAAO,CAAC,GAAG,CAAC,IAAI,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,EAAE,IAAI,CAAC,UAAU,EAAE,CAAC,CAAC;QAGjD,IAAI,IAAI,CAAC,UAAU,EAAE,EAAE,CAAC;YACtB,IAAI,IAAI,CAAC,WAAW,EAAE,EAAE,CAAC;gBACvB,OAAO;YACT,CAAC;YACD,IAAI,YAAY,GAAuC,EAAE,IAAI,EAAE,MAAM,CAAC,EAAE,CAAC,EAAE,EAAE,EAAE,MAAM,CAAC,EAAE,CAAC,EAAE,CAAC;YAE5F,IAAI,CAAC,WAAW,EAAE,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE;gBAC/B,IAAI,CAAC,IAAI,EAAE,EAAE,EAAE,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,EAAE,EAAE,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC;oBACvC,YAAY,GAAG,SAAS,CAAC;gBAC3B,CAAC;gBACD,IAAI,YAAY,EAAE,CAAC;oBACjB,YAAY,CAAC,IAAI,CAAC,MAAM,CAAC,OAAO,CAAC,EAAE;wBACjC,OAAO,CAAC,GAAG,CAAC,GAAG,MAAM,CAAC,IAAI,EAAE,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC;wBAErC,OAAO,OAAO,CAAC;oBACjB,CAAC,CAAC,CAAC;oBACH,YAAY,CAAC,EAAE,CAAC,MAAM,CAAC,OAAO,CAAC,EAAE;wBAC/B,OAAO,CAAC,GAAG,CAAC,GAAG,MAAM,CAAC,EAAE,EAAE,EAAE,CAAC,GAAG,CAAC,CAAC,CAAC;wBAEnC,OAAO,OAAO,CAAC;oBACjB,CAAC,CAAC,CAAC;gBACL,CAAC;YACH,CAAC,CAAC,CAAC;YAEH,IAAI,YAAY,EAAE,CAAC;gBACjB,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;YAC7C,CAAC;YAED,OAAO;QACT,CAAC;QACD,IAAI,YAAY,GAAwC,EAAE,CAAC;QAE3D,IAAI,CAAC,WAAW,EAAE,CAAC,OAAO,CAAC,GAAG,CAAC,EAAE;YAC/B,IAAI,CAAC,IAAI,EAAE,EAAE,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC;gBACrB,YAAY,GAAG,SAAS,CAAC;YAC3B,CAAC;YACD,IAAI,YAAY,EAAE,CAAC;gBACjB,YAAY,CAAC,GAAG,CAAC,GAAG,MAAM,CAAC,IAAI,EAAE,EAAE,EAAE,CAAC,GAAG,CAAC,CAAC,CAAA;YAC7C,CAAC;QACH,CAAC,CAAC,CAAC;QACH,IAAI,YAAY,EAAE,CAAC;YACjB,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;QAC9C,CAAC;IACH,CAAC;IAES,uBAAuB,CAAC,KAAa;QAC7C,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,KAAK,GAAG,CAAC,IAAI,CAAC,eAAe,EAAE,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,eAAe,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC;QAC5G,IAAI,IAAI,CAAC,OAAO,EAAE,EAAE,CAAC;YACnB,YAAY,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC,CAAC;QAC/B,CAAC;QACD,IAAI,CAAC,OAAO,CAAC,GAAG,CAAE,UAAU,CAAC,GAAG,EAAE;YAChC,IAAI,CAAC,UAAU,CAAC,GAAG,CAAC,IAAI,CAAC,eAAe,EAAE,CAAC,CAAC;QAC9C,CAAC,EAAE,GAAG,CAAuB,CAAC,CAAC;IACjC,CAAC;IAES,0BAA0B,CAAC,SAAqB;QACxD,IAAI,CAAC,sBAAsB,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;IAC9C,CAAC;wGAhTU,yCAAyC;4FAAzC,yCAAyC,qzKC5BtD,y0MAoIA,yDD/GI,eAAe,4FACf,8BAA8B,4qBAC9B,yCAAyC,qHACzC,6CAA6C;;4FAIpC,yCAAyC;kBAfrD,SAAS;+BAEE,sCAAsC,cAGpC,IAAI,mBACC,uBAAuB,CAAC,MAAM,WACtC;wBACP,eAAe;wBACf,8BAA8B;wBAC9B,yCAAyC;wBACzC,6CAA6C;qBAC9C","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: [\n    TranslateModule,\n    LibsUiComponentsLabelComponent,\n    LibsUiComponentsDatetimeDropdownDirective,\n    LibsUiComponentsDatetimeDropdownItemComponent\n  ]\n})\n\nexport class LibsUiComponentsDatetimeDropdownComponent implements OnInit, AfterViewInit {\n  /* 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  /* 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  /* 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  /* 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).pipe().subscribe(() => {\n          this.checkResponsive();\n          this.changeType.set(false);\n        });\n      });\n    });\n  }\n\n  ngOnInit() {\n    this.outFunctionsControl.emit({ checkIsValid: this.validate.bind(this), resetError: this.resetError.bind(this), resetTime: this.resetDropdown.bind(this) });\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).pipe().subscribe(() => {\n      this.checkResponsive();\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    console.log(widthElementParent);\n\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).pipe().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    console.log(from?.(), to?.(), this.isMultiple());\n\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((setTimeout(() => {\n      this.widthLabel.set(this.cacheWidthLabel());\n    }, 100) as unknown) as number);\n  }\n\n  protected handlerChangStageFlagMouse(flagMouse: IFlagMouse) {\n    this.outChangStageFlagMouse.emit(flagMouse);\n  }\n}","@if (labelConfig(); as labelConfig) {\n  <libs_ui-components-label [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 #parent\n  class=\"flex items-start\"\n  [class.!w-full]=\"widthByElement()\"\n  [class.!column]=\"isResponsive() && isMultiple()\">\n  <div #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\n    @if (isMultiple() && !ignoreFromAndToDateLabel() && fromAndToDateLabel().from) {\n      <div class=\"mr-[8px] flex-shrink-0 h-[32px] flex items-center\"\n        [style.width.px]=\"isResponsive() ? (widthLabel() || undefined) : undefined\">\n        <span #labelFrom\n          LibsUiComponentsDatetimeDropdownDirective\n          [class.!opacity-[0.5]]=\"disable()\"\n          class=\"libs-ui-font-h5r text-nowrap {{ fromAndToDateLabel().classLabelFrom || '' }}\"\n          (outChangeWidth)=\"handlerChangeWidthLabel($event)\">\n          {{ (fromAndToDateLabel().from||' ')| translate }}\n        </span>\n      </div>\n    }\n    <div class=\"flex\"\n      [class.!w-full]=\"widthByElement()\">\n      @if (!changeType()) {\n        <libs_ui-components-datetime-dropdown-item [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 #childTo\n      [class.!w-[50%]]=\"widthByElement()\"\n      [class.!w-full]=\" !widthByElement() || isResponsive()\"\n      class=\"flex items-start\">\n      <div class=\"mr-[8px] h-[32px] flex-shrink-0 flex items-center\"\n        [style.width.px]=\"isResponsive() ? widthLabel() : undefined\">\n        @if (!ignoreFromAndToDateLabel()) {\n          <span #labelTo\n            LibsUiComponentsDatetimeDropdownDirective\n            [class.!opacity-[0.5]]=\"disable()\"\n            class=\"libs-ui-font-h5r text-nowrap {{ fromAndToDateLabel().classLabelTo || '' }}\"\n            (outChangeWidth)=\"handlerChangeWidthLabel($event)\">\n            {{ (fromAndToDateLabel().to||' ')| translate }}\n          </span>\n        }\n        @if (ignoreFromAndToDateLabel()) {\n          <span [class.!opacity-[0.5]]=\"disable()\"\n            class=\"libs-ui-font-h5r\">-</span>\n        }\n      </div>\n      <div class=\"flex\"\n        [class.!w-full]=\"widthByElement()\">\n        @if (!changeType()) {\n          <libs_ui-components-datetime-dropdown-item [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\">{{ validRequired()?.messageValidCompareTime || \"i18n_invalid_end_date_selected\" | translate:validRequired()?.interpolateParamsCompareTime }}</span>\n  </div>\n}\n"]}
@@ -0,0 +1,2 @@
1
+ export * from './dropdown.component';
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzLXVpL2NvbXBvbmVudHMvZGF0ZXRpbWUvZHJvcGRvd24vc3JjL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsc0JBQXNCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2Ryb3Bkb3duLmNvbXBvbmVudCc7XG4iXX0=
@@ -0,0 +1,7 @@
1
+ /* eslint-disable @typescript-eslint/no-explicit-any */
2
+ export var SideEnum;
3
+ (function (SideEnum) {
4
+ SideEnum["from"] = "from";
5
+ SideEnum["to"] = "to";
6
+ })(SideEnum || (SideEnum = {}));
7
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGF0ZS1kcm9wZG93bi5pbnRlcmZhY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzLXVpL2NvbXBvbmVudHMvZGF0ZXRpbWUvZHJvcGRvd24vc3JjL2ludGVyZmFjZXMvZGF0ZS1kcm9wZG93bi5pbnRlcmZhY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsdURBQXVEO0FBOEJ2RCxNQUFNLENBQU4sSUFBWSxRQUdYO0FBSEQsV0FBWSxRQUFRO0lBQ2xCLHlCQUFhLENBQUE7SUFDYixxQkFBUyxDQUFBO0FBQ1gsQ0FBQyxFQUhXLFFBQVEsS0FBUixRQUFRLFFBR25CIiwic291cmNlc0NvbnRlbnQiOlsiLyogZXNsaW50LWRpc2FibGUgQHR5cGVzY3JpcHQtZXNsaW50L25vLWV4cGxpY2l0LWFueSAqL1xuXG5pbXBvcnQgeyBXcml0YWJsZVNpZ25hbCB9IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XG5pbXBvcnQgeyBJRHJvcGRvd25GdW5jdGlvbkNvbnRyb2xFdmVudCB9IGZyb20gXCJAbGlicy11aS9jb21wb25lbnRzLWRyb3Bkb3duXCI7XG5cbmV4cG9ydCB0eXBlIFRZUEVfRFJPUERPV05fTU9OVEhfSUQgPSAxIHwgMiB8IDMgfCA0IHwgNSB8IDYgfCA3IHwgOCB8IDkgfCAxMCB8IDExIHwgMTI7XG5leHBvcnQgdHlwZSBUWVBFX0RBVEVfRFJPUERPV05fRk9STUFUID0gJ3llYXInIHwgJ21vbnRoJyB8ICdxdWFydGVyJyB8ICd5ZWFyLW1vbnRoJyB8ICdtb250aC1kYXknIHwgJ3llYXItcXVhcnRlcicgfCBzdHJpbmc7XG5leHBvcnQgdHlwZSBUWVBFX0RBVEVfRk9STUFUID0gJ3llYXInIHwgJ21vbnRoJyB8ICdxdWFydGVyJyB8ICdkYXknO1xuXG5leHBvcnQgaW50ZXJmYWNlIElUeXBlRGF0ZSB7XG4gIGlkOiBUWVBFX0RBVEVfRk9STUFULFxuICBrZXlTZWxlY3RlZDogYW55LFxuICBkaXNhYmxlPzogYm9vbGVhbixcbiAgc2hvd0JvcmRlckVycm9yPzogYm9vbGVhbixcbiAgaXNFcnJvcj86IGJvb2xlYW4sXG4gIGZ1bmN0aW9uQ29udHJvbD86IElEcm9wZG93bkZ1bmN0aW9uQ29udHJvbEV2ZW50XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgSURhdGVEcm9wZG93bkRpc2FibGVLZXlzIHtcbiAgZnJvbT86IFdyaXRhYmxlU2lnbmFsPElEYXRlRHJvcGRvd25EaXNhYmxlPjtcbiAgdG8/OiBXcml0YWJsZVNpZ25hbDxJRGF0ZURyb3Bkb3duRGlzYWJsZT47XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgSURhdGVEcm9wZG93bkRpc2FibGUge1xuICB5ZWFyPzogV3JpdGFibGVTaWduYWw8QXJyYXk8bnVtYmVyPj47XG4gIG1vbnRoPzogV3JpdGFibGVTaWduYWw8QXJyYXk8bnVtYmVyPj47XG4gIHF1YXJ0ZXI/OiBXcml0YWJsZVNpZ25hbDxBcnJheTxudW1iZXI+PjtcbiAgZGF5PzogV3JpdGFibGVTaWduYWw8QXJyYXk8bnVtYmVyPj47XG59XG5cbmV4cG9ydCBlbnVtIFNpZGVFbnVtIHtcbiAgZnJvbSA9ICdmcm9tJyxcbiAgdG8gPSAndG8nXG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgSUhpZGRlbkRhdGUge1xuICBmb3JtYXREYXRlOiBUWVBFX0RBVEVfRFJPUERPV05fRk9STUFUO1xuICB5ZWFyTW9udGg/OiBXcml0YWJsZVNpZ25hbDxBcnJheTxXcml0YWJsZVNpZ25hbDxJSGlkZGVuRGF0ZVllYXJNb250aD4+PjtcbiAgbW9udGhEYXk/OiBXcml0YWJsZVNpZ25hbDxBcnJheTxXcml0YWJsZVNpZ25hbDxJSGlkZGVuRGF0ZU1vbnRoRGF5Pj4+O1xufVxuXG5pbnRlcmZhY2UgSUhpZGRlbkRhdGVNb250aERheSB7XG4gIGhpZGRlbk1vbnRoOiBudW1iZXI7XG4gIGhpZGRlbkRheXM6IEFycmF5PG51bWJlcj5cbn1cbmludGVyZmFjZSBJSGlkZGVuRGF0ZVllYXJNb250aCB7XG4gIGhpZGRlblllYXI6IG51bWJlcjtcbiAgaGlkZGVuTW9udGhzOiBBcnJheTxudW1iZXI+XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgSUZyb21BbmRUb0RhdGVMYWJlbCB7XG4gIHRvPzogc3RyaW5nLFxuICBmcm9tPzogc3RyaW5nLFxuICBjbGFzc0xhYmVsVG8/OiBzdHJpbmcsXG4gIGNsYXNzTGFiZWxGcm9tPzogc3RyaW5nO1xufSJdfQ==
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZW1pdC1kcm9wZG93bi5pbnRlcmZhY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzLXVpL2NvbXBvbmVudHMvZGF0ZXRpbWUvZHJvcGRvd24vc3JjL2ludGVyZmFjZXMvZW1pdC1kcm9wZG93bi5pbnRlcmZhY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFdyaXRhYmxlU2lnbmFsIH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcblxuZXhwb3J0IGludGVyZmFjZSBJRW1pdE11bHRpRGF0ZURyb3Bkb3duIHtcbiAgZnJvbTogV3JpdGFibGVTaWduYWw8SUVtaXRTaW5nbGVEYXRlRHJvcGRvd24+O1xuICB0bzogV3JpdGFibGVTaWduYWw8SUVtaXRTaW5nbGVEYXRlRHJvcGRvd24+O1xufVxuXG5leHBvcnQgaW50ZXJmYWNlIElFbWl0U2luZ2xlRGF0ZURyb3Bkb3duIHtcbiAgeWVhcj86IG51bWJlcjtcbiAgbW9udGg/OiBudW1iZXI7XG4gIHF1YXJ0ZXI/OiBudW1iZXI7XG4gIGRheT86IG51bWJlcjtcbn0iXX0=
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZnVuY3Rpb25zLWNvbnRyb2wtZXZlbnQuaW50ZXJmYWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy11aS9jb21wb25lbnRzL2RhdGV0aW1lL2Ryb3Bkb3duL3NyYy9pbnRlcmZhY2VzL2Z1bmN0aW9ucy1jb250cm9sLWV2ZW50LmludGVyZmFjZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGludGVyZmFjZSBJRGF0ZURyb3Bkb3duSXRlbUZ1bmN0aW9uQ29udHJvbEV2ZW50IHtcbiAgY2hlY2tJc1ZhbGlkOiAoKSA9PiBQcm9taXNlPGJvb2xlYW4+O1xuICByZXNldERyb3Bkb3duOiAoKSA9PiBQcm9taXNlPHZvaWQ+O1xuICByZXNldEVycm9yOiAoKSA9PiBQcm9taXNlPHZvaWQ+O1xuICBzZXRFcnJvcjogKGVycm9yOiBib29sZWFuKSA9PiBQcm9taXNlPHZvaWQ+XG59XG5cbmV4cG9ydCBpbnRlcmZhY2UgSURhdGVEcm9wZG93bkZ1bmN0aW9uQ29udHJvbEV2ZW50IHtcbiAgY2hlY2tJc1ZhbGlkOiAoKSA9PiBQcm9taXNlPGJvb2xlYW4+O1xuICByZXNldEVycm9yPzogKCkgPT4gUHJvbWlzZTx2b2lkPlxuICByZXNldFRpbWU/OiAoKSA9PiBQcm9taXNlPHZvaWQ+XG59XG4iXX0=
@@ -0,0 +1,3 @@
1
+ ;
2
+ export {};
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidmFsaWQuaW50ZXJmYWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy11aS9jb21wb25lbnRzL2RhdGV0aW1lL2Ryb3Bkb3duL3NyYy9pbnRlcmZhY2VzL3ZhbGlkLmludGVyZmFjZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFLQyxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGludGVyZmFjZSBJVmFsaWREYXRlRHJvcGRvd24ge1xuICBtZXNzYWdlPzogc3RyaW5nO1xuICBpbnRlcnBvbGF0ZVBhcmFtcz86IHsgYW55OiBvYmplY3QgfTtcbiAgbWVzc2FnZVZhbGlkQ29tcGFyZVRpbWU/OiBzdHJpbmc7XG4gIGludGVycG9sYXRlUGFyYW1zQ29tcGFyZVRpbWU/OiB7IGFueTogb2JqZWN0IH07XG59O1xuIl19
@@ -0,0 +1,124 @@
1
+ /* eslint-disable @typescript-eslint/no-explicit-any */
2
+ import { Component, computed, effect, inject, input, output, signal, untracked } from "@angular/core";
3
+ import { LibsUiComponentsDropdownComponent } from "@libs-ui/components-dropdown";
4
+ import { TranslateModule, TranslateService } from "@ngx-translate/core";
5
+ import { convertGetValue, convertItemSelectedDefine, getConfigHttpRequestDetailDate, getConfigHttpRequestListDate } from "../../defines/date-dropdown.define";
6
+ import * as i0 from "@angular/core";
7
+ import * as i1 from "@ngx-translate/core";
8
+ export class LibsUiComponentsDatetimeDropdownItemChildComponent {
9
+ /* PROPERTY */
10
+ httpRequestDetailItemById = signal(undefined);
11
+ listConfig = signal({
12
+ type: 'text',
13
+ configTemplateText: signal({
14
+ fieldKey: 'id',
15
+ autoScrollToItemSelected: true,
16
+ })
17
+ });
18
+ textNoSelectDisplay = computed(this.computedTextNoSelectDisplay.bind(this));
19
+ usingWidth = computed(this.computedWidth.bind(this));
20
+ /* INPUT */
21
+ typeDate = input(undefined);
22
+ getItemYearDisplay = input();
23
+ listHasButtonUnSelectOption = input();
24
+ readonly = input(false, { transform: (value) => value ?? false });
25
+ disable = input(false, { transform: (value) => value ?? false });
26
+ listData = input([]);
27
+ showBorderError = input(undefined);
28
+ listMaxItemShow = input(6, { transform: (value) => value ?? 6 });
29
+ zIndex = input(1000, { transform: (value) => value ?? 1000 });
30
+ classIncludeTextDisplayWhenNoSelect = input('');
31
+ listKeySelected = input();
32
+ widthDropdown = input(136);
33
+ first = input(undefined);
34
+ isError = input();
35
+ widthByElement = input();
36
+ ignoreConvertYearSelected = input();
37
+ listKeysDisable = input(undefined);
38
+ validRequired = input();
39
+ /* OUTPUT */
40
+ outSelectedKey = output();
41
+ outFunctionControl = output();
42
+ outChangStageFlagMouse = output();
43
+ /* INJECT */
44
+ translate = inject(TranslateService);
45
+ constructor() {
46
+ effect(() => {
47
+ const listData = this.listData();
48
+ untracked(() => {
49
+ this.httpRequestDetailItemById.set(getConfigHttpRequestDetailDate(listData));
50
+ this.listConfig.update(current => {
51
+ if (!current.httpRequestData) {
52
+ current.httpRequestData = signal(getConfigHttpRequestListDate(listData));
53
+ }
54
+ current.httpRequestData.set(getConfigHttpRequestListDate(listData));
55
+ if (!current.configTemplateText) {
56
+ current.configTemplateText = signal({
57
+ fieldKey: 'id',
58
+ autoScrollToItemSelected: true,
59
+ });
60
+ }
61
+ current.configTemplateText.set({
62
+ fieldKey: 'id',
63
+ autoScrollToItemSelected: true,
64
+ getValue: (item) => {
65
+ return convertGetValue(this.typeDate() || 'month', item, this.translate);
66
+ }
67
+ });
68
+ return current;
69
+ });
70
+ });
71
+ });
72
+ }
73
+ /* FUNCTIONS */
74
+ handlerChangeSelectedItem(event) {
75
+ if (!event || !event.key) {
76
+ this.outSelectedKey.emit(undefined);
77
+ return;
78
+ }
79
+ this.outSelectedKey.emit(event.key);
80
+ }
81
+ handlerFunctionControl(event) {
82
+ this.outFunctionControl.emit(event);
83
+ }
84
+ handlerChangFlagMouse(flagMouse) {
85
+ this.outChangStageFlagMouse.emit(flagMouse);
86
+ }
87
+ convertItemSelected = (item) => {
88
+ if (!item || !this.typeDate()) {
89
+ return;
90
+ }
91
+ item.labelDisplay = convertItemSelectedDefine(this.typeDate() ?? 'month', item, this.translate, this.getItemYearDisplay(), this.ignoreConvertYearSelected());
92
+ return item;
93
+ };
94
+ computedTextNoSelectDisplay() {
95
+ switch (this.typeDate()) {
96
+ case 'day':
97
+ return 'i18n_select_day';
98
+ case 'month':
99
+ return 'i18n_select_month';
100
+ case 'year':
101
+ return 'i18n_select_year';
102
+ case 'quarter':
103
+ return 'i18n_select_quarter';
104
+ default:
105
+ return 'month';
106
+ }
107
+ }
108
+ computedWidth() {
109
+ if (this.widthByElement()) {
110
+ return this.first() ? `${this.widthDropdown()}px` : '100%';
111
+ }
112
+ return `${this.widthDropdown()}px`;
113
+ }
114
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: LibsUiComponentsDatetimeDropdownItemChildComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
115
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: LibsUiComponentsDatetimeDropdownItemChildComponent, isStandalone: true, selector: "libs_ui-components-datetime-dropdown-item-child", inputs: { typeDate: { classPropertyName: "typeDate", publicName: "typeDate", isSignal: true, isRequired: false, transformFunction: null }, getItemYearDisplay: { classPropertyName: "getItemYearDisplay", publicName: "getItemYearDisplay", isSignal: true, isRequired: false, transformFunction: null }, listHasButtonUnSelectOption: { classPropertyName: "listHasButtonUnSelectOption", publicName: "listHasButtonUnSelectOption", isSignal: true, isRequired: false, transformFunction: null }, readonly: { classPropertyName: "readonly", publicName: "readonly", isSignal: true, isRequired: false, transformFunction: null }, disable: { classPropertyName: "disable", publicName: "disable", isSignal: true, isRequired: false, transformFunction: null }, listData: { classPropertyName: "listData", publicName: "listData", isSignal: true, isRequired: false, transformFunction: null }, showBorderError: { classPropertyName: "showBorderError", publicName: "showBorderError", isSignal: true, isRequired: false, transformFunction: null }, listMaxItemShow: { classPropertyName: "listMaxItemShow", publicName: "listMaxItemShow", isSignal: true, isRequired: false, transformFunction: null }, zIndex: { classPropertyName: "zIndex", publicName: "zIndex", isSignal: true, isRequired: false, transformFunction: null }, classIncludeTextDisplayWhenNoSelect: { classPropertyName: "classIncludeTextDisplayWhenNoSelect", publicName: "classIncludeTextDisplayWhenNoSelect", isSignal: true, isRequired: false, transformFunction: null }, listKeySelected: { classPropertyName: "listKeySelected", publicName: "listKeySelected", isSignal: true, isRequired: false, transformFunction: null }, widthDropdown: { classPropertyName: "widthDropdown", publicName: "widthDropdown", isSignal: true, isRequired: false, transformFunction: null }, first: { classPropertyName: "first", publicName: "first", isSignal: true, isRequired: false, transformFunction: null }, isError: { classPropertyName: "isError", publicName: "isError", isSignal: true, isRequired: false, transformFunction: null }, widthByElement: { classPropertyName: "widthByElement", publicName: "widthByElement", 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 }, validRequired: { classPropertyName: "validRequired", publicName: "validRequired", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { outSelectedKey: "outSelectedKey", outFunctionControl: "outFunctionControl", outChangStageFlagMouse: "outChangStageFlagMouse" }, ngImport: i0, template: " @if (typeDate()) {\n <div [style.width]=\"usingWidth()\">\n <libs_ui-components-dropdown [listHasButtonUnSelectOption]=\"listHasButtonUnSelectOption()\"\n [readonly]=\"readonly()\"\n [textDisplayWhenNoSelect]=\"textNoSelectDisplay()\"\n [disable]=\"disable()\"\n [showBorderError]=\"showBorderError()\"\n [listMaxItemShow]=\"listMaxItemShow()\"\n [listClickExactly]=\"false\"\n [zIndex]=\"zIndex()\"\n [labelPopoverConfig]=\"{ zIndex: zIndex() +1 }\"\n [listConfig]=\"listConfig()\"\n [listKeysDisable]=\"listKeysDisable()\"\n [convertItemSelected]=\"convertItemSelected\"\n [onlyEmitDataWhenReset]=\"true\"\n [classIncludeTextDisplayWhenNoSelect]=\"classIncludeTextDisplayWhenNoSelect()\"\n [httpRequestDetailItemById]=\"httpRequestDetailItemById()\"\n [listKeySelected]=\"listKeySelected()\"\n (outSelectKey)=\"handlerChangeSelectedItem($event)\"\n (outFunctionsControl)=\"handlerFunctionControl($event)\"\n (outChangStageFlagMouse)=\"handlerChangFlagMouse($event)\" />\n </div>\n }\n @if (isError()) {\n <div class=\"flex items-center mt-[4px]\">\n <span class=\"libs-ui-text-error libs-ui-font-h7r\"\n [innerHtml]=\"(validRequired()?.message || 'i18n_valid_empty_message')| translate:validRequired()?.interpolateParams\"></span>\n </div>\n }\n", dependencies: [{ kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i1.TranslatePipe, name: "translate" }, { kind: "component", type: LibsUiComponentsDropdownComponent, selector: "libs_ui-components-dropdown", inputs: ["useXssFilter", "popoverElementRefCustom", "classInclude", "ignoreStopPropagationEvent", "flagMouse", "flagMouseContent", "popoverCustomConfig", "isNgContent", "zIndex", "convertItemSelected", "getPopoverItemSelected", "httpRequestDetailItemById", "lengthKeys", "textDisplayWhenNoSelect", "textDisplayWhenMultiSelect", "classIncludeTextDisplayWhenNoSelect", "fieldGetLabel", "labelPopoverConfig", "labelPopoverFullWidth", "hasContentUnitRight", "listSearchNoDataTemplateRef", "fieldGetImage", "imageSize", "typeShape", "fieldGetIcon", "fieldGetTextAvatar", "fieldGetColorAvatar", "classAvatarInclude", "getLastTextAfterSpace", "linkImageError", "showError", "showBorderError", "disable", "readonly", "labelConfig", "listSearchConfig", "isSearchOnline", "listHiddenInputSearch", "listSearchPadding", "listKeySearch", "listDividerClassInclude", "listConfig", "listButtonsOther", "listHasButtonUnSelectOption", "listClickExactly", "listBackgroundCustom", "listMaxItemShow", "listKeySelected", "listMultiKeySelected", "listKeysDisable", "listKeysHidden", "validRequired", "validMaxItemSelected", "changeValidUndefinedResetError", "allowSelectItemMultiple", "focusInputSearch", "onlyEmitDataWhenReset", "resetKeyWhenSelectAllKey", "listConfigHasDivider", "classIncludeIcon", "classIncludeContent", "listIgnoreClassDisableDefaultWhenUseKeysDisableItem", "tabKeyActive", "tabsConfig", "ignoreBorderBottom"], outputs: ["flagMouseChange", "flagMouseContentChange", "lengthKeysChange", "showBorderErrorChange", "listKeySelectedChange", "listMultiKeySelectedChange", "tabKeyActiveChange", "outSelectKey", "outSelectMultiKey", "outFunctionsControl", "outValidEvent", "outChangStageFlagMouse", "outDataChange", "outClickButtonOther", "outShowList", "outChangeTabKeyActive"] }] });
116
+ }
117
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: LibsUiComponentsDatetimeDropdownItemChildComponent, decorators: [{
118
+ type: Component,
119
+ args: [{ selector: 'libs_ui-components-datetime-dropdown-item-child', standalone: true, imports: [
120
+ TranslateModule,
121
+ LibsUiComponentsDropdownComponent
122
+ ], template: " @if (typeDate()) {\n <div [style.width]=\"usingWidth()\">\n <libs_ui-components-dropdown [listHasButtonUnSelectOption]=\"listHasButtonUnSelectOption()\"\n [readonly]=\"readonly()\"\n [textDisplayWhenNoSelect]=\"textNoSelectDisplay()\"\n [disable]=\"disable()\"\n [showBorderError]=\"showBorderError()\"\n [listMaxItemShow]=\"listMaxItemShow()\"\n [listClickExactly]=\"false\"\n [zIndex]=\"zIndex()\"\n [labelPopoverConfig]=\"{ zIndex: zIndex() +1 }\"\n [listConfig]=\"listConfig()\"\n [listKeysDisable]=\"listKeysDisable()\"\n [convertItemSelected]=\"convertItemSelected\"\n [onlyEmitDataWhenReset]=\"true\"\n [classIncludeTextDisplayWhenNoSelect]=\"classIncludeTextDisplayWhenNoSelect()\"\n [httpRequestDetailItemById]=\"httpRequestDetailItemById()\"\n [listKeySelected]=\"listKeySelected()\"\n (outSelectKey)=\"handlerChangeSelectedItem($event)\"\n (outFunctionsControl)=\"handlerFunctionControl($event)\"\n (outChangStageFlagMouse)=\"handlerChangFlagMouse($event)\" />\n </div>\n }\n @if (isError()) {\n <div class=\"flex items-center mt-[4px]\">\n <span class=\"libs-ui-text-error libs-ui-font-h7r\"\n [innerHtml]=\"(validRequired()?.message || 'i18n_valid_empty_message')| translate:validRequired()?.interpolateParams\"></span>\n </div>\n }\n" }]
123
+ }], ctorParameters: () => [] });
124
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"child.component.js","sourceRoot":"","sources":["../../../../../../../../libs-ui/components/datetime/dropdown/src/item/child/child.component.ts","../../../../../../../../libs-ui/components/datetime/dropdown/src/item/child/child.component.html"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @typescript-eslint/no-explicit-any */\nimport { Component, computed, effect, inject, input, output, signal, untracked } from \"@angular/core\";\nimport { IDropdownFunctionControlEvent, IEmitSelectKey, LibsUiComponentsDropdownComponent } from \"@libs-ui/components-dropdown\";\nimport { IListConfigItem } from \"@libs-ui/components-list\";\nimport { IFlagMouse } from \"@libs-ui/components-popover\";\nimport { IHttpRequestConfig } from \"@libs-ui/services-http-request\";\nimport { TranslateModule, TranslateService } from \"@ngx-translate/core\";\nimport { convertGetValue, convertItemSelectedDefine, getConfigHttpRequestDetailDate, getConfigHttpRequestListDate } from \"../../defines/date-dropdown.define\";\nimport { TYPE_DATE_FORMAT } from \"../../interfaces/date-dropdown.interface\";\n\n@Component({\n  // eslint-disable-next-line @angular-eslint/component-selector\n  selector: 'libs_ui-components-datetime-dropdown-item-child',\n  templateUrl: 'child.component.html',\n  standalone: true,\n  imports: [\n    TranslateModule,\n    LibsUiComponentsDropdownComponent\n  ]\n})\n\nexport class LibsUiComponentsDatetimeDropdownItemChildComponent {\n  /* PROPERTY */\n  protected httpRequestDetailItemById = signal<IHttpRequestConfig | undefined>(undefined);\n  protected listConfig = signal<IListConfigItem>({\n    type: 'text',\n    configTemplateText: signal({\n      fieldKey: 'id',\n      autoScrollToItemSelected: true,\n    })\n  });\n  protected textNoSelectDisplay = computed(this.computedTextNoSelectDisplay.bind(this));\n  protected usingWidth = computed(this.computedWidth.bind(this));\n\n  /* INPUT */\n  readonly typeDate = input<TYPE_DATE_FORMAT | undefined>(undefined);\n  readonly getItemYearDisplay = input<(year: string) => string>();\n  readonly listHasButtonUnSelectOption = input<boolean>();\n  readonly readonly = input<boolean, boolean>(false, { transform: (value) => value ?? false });\n  readonly disable = input<boolean, boolean>(false, { transform: (value) => value ?? false });\n  readonly listData = input<Array<{ id: number, label: string }>>([]);\n  readonly showBorderError = input<boolean | undefined>(undefined);\n  readonly listMaxItemShow = input<number, number>(6, { transform: (value) => value ?? 6 });\n  readonly zIndex = input<number, number>(1000, { transform: (value) => value ?? 1000 });\n  readonly classIncludeTextDisplayWhenNoSelect = input<string>('');\n  readonly listKeySelected = input<any>();\n  readonly widthDropdown = input<number>(136);\n  readonly first = input<boolean | undefined>(undefined);\n  readonly isError = input<boolean>();\n  readonly widthByElement = input<boolean>();\n  readonly ignoreConvertYearSelected = input<boolean>();\n  readonly listKeysDisable = input<Array<any> | undefined>(undefined);\n  readonly validRequired = input<{\n    message?: string;\n    interpolateParams?: { any: object };\n  }>();\n\n  /* OUTPUT */\n  readonly outSelectedKey = output<any>();\n  readonly outFunctionControl = output<IDropdownFunctionControlEvent>();\n  readonly outChangStageFlagMouse = output<IFlagMouse>();\n\n  /* INJECT */\n  private translate = inject(TranslateService);\n\n  constructor() {\n    effect(() => {\n      const listData = this.listData();\n\n      untracked(() => {\n        this.httpRequestDetailItemById.set(getConfigHttpRequestDetailDate(listData));\n        this.listConfig.update(current => {\n          if (!current.httpRequestData) {\n            current.httpRequestData = signal<IHttpRequestConfig>(getConfigHttpRequestListDate(listData));\n          }\n          current.httpRequestData.set(getConfigHttpRequestListDate(listData));\n          if (!current.configTemplateText) {\n            current.configTemplateText = signal({\n              fieldKey: 'id',\n              autoScrollToItemSelected: true,\n            });\n          }\n          current.configTemplateText.set({\n            fieldKey: 'id',\n            autoScrollToItemSelected: true,\n            getValue: (item: { label: string }) => {\n              return convertGetValue(this.typeDate() || 'month', item, this.translate);\n            }\n          });\n\n          return current;\n        });\n      });\n    });\n  }\n\n  /* FUNCTIONS */\n  protected handlerChangeSelectedItem(event?: IEmitSelectKey) {\n    if (!event || !event.key) {\n      this.outSelectedKey.emit(undefined);\n\n      return;\n    }\n    this.outSelectedKey.emit(event.key);\n  }\n\n  protected handlerFunctionControl(event: IDropdownFunctionControlEvent) {\n    this.outFunctionControl.emit(event);\n  }\n\n  protected handlerChangFlagMouse(flagMouse: IFlagMouse) {\n    this.outChangStageFlagMouse.emit(flagMouse);\n  }\n  protected convertItemSelected = (item: any) => {\n    if (!item || !this.typeDate()) {\n      return;\n    }\n    item.labelDisplay = convertItemSelectedDefine(this.typeDate() ?? 'month', item, this.translate, this.getItemYearDisplay(), this.ignoreConvertYearSelected());\n\n    return item;\n  };\n  private computedTextNoSelectDisplay() {\n    switch (this.typeDate()) {\n      case 'day':\n        return 'i18n_select_day';\n\n      case 'month':\n        return 'i18n_select_month';\n\n      case 'year':\n        return 'i18n_select_year';\n\n      case 'quarter':\n        return 'i18n_select_quarter';\n\n      default:\n        return 'month';\n    }\n  }\n\n  private computedWidth() {\n    if (this.widthByElement()) {\n      return this.first() ? `${this.widthDropdown()}px` : '100%';\n    }\n\n    return `${this.widthDropdown()}px`;\n  }\n}","  @if (typeDate()) {\n    <div [style.width]=\"usingWidth()\">\n      <libs_ui-components-dropdown [listHasButtonUnSelectOption]=\"listHasButtonUnSelectOption()\"\n        [readonly]=\"readonly()\"\n        [textDisplayWhenNoSelect]=\"textNoSelectDisplay()\"\n        [disable]=\"disable()\"\n        [showBorderError]=\"showBorderError()\"\n        [listMaxItemShow]=\"listMaxItemShow()\"\n        [listClickExactly]=\"false\"\n        [zIndex]=\"zIndex()\"\n        [labelPopoverConfig]=\"{ zIndex: zIndex() +1 }\"\n        [listConfig]=\"listConfig()\"\n        [listKeysDisable]=\"listKeysDisable()\"\n        [convertItemSelected]=\"convertItemSelected\"\n        [onlyEmitDataWhenReset]=\"true\"\n        [classIncludeTextDisplayWhenNoSelect]=\"classIncludeTextDisplayWhenNoSelect()\"\n        [httpRequestDetailItemById]=\"httpRequestDetailItemById()\"\n        [listKeySelected]=\"listKeySelected()\"\n        (outSelectKey)=\"handlerChangeSelectedItem($event)\"\n        (outFunctionsControl)=\"handlerFunctionControl($event)\"\n        (outChangStageFlagMouse)=\"handlerChangFlagMouse($event)\" />\n    </div>\n  }\n  @if (isError()) {\n    <div class=\"flex items-center mt-[4px]\">\n      <span class=\"libs-ui-text-error libs-ui-font-h7r\"\n        [innerHtml]=\"(validRequired()?.message || 'i18n_valid_empty_message')| translate:validRequired()?.interpolateParams\"></span>\n    </div>\n  }\n"]}