@libs-ui/components-datetime-dropdown 0.2.77 → 0.2.78
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/defines/date-dropdown.define.d.ts +40 -0
- package/directive/date-dropdown.directive.d.ts +11 -0
- package/dropdown.component.d.ts +88 -0
- package/esm2022/defines/date-dropdown.define.mjs +248 -0
- package/esm2022/directive/date-dropdown.directive.mjs +33 -0
- package/esm2022/dropdown.component.mjs +272 -0
- package/esm2022/index.mjs +2 -2
- package/esm2022/interfaces/date-dropdown.interface.mjs +7 -0
- package/esm2022/interfaces/emit-dropdown.interface.mjs +2 -0
- package/esm2022/interfaces/functions-control-event.interface.mjs +2 -0
- package/esm2022/interfaces/valid.interface.mjs +3 -0
- package/esm2022/item/child/child.component.mjs +124 -0
- package/esm2022/item/item.component.mjs +216 -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 +910 -9
- package/fesm2022/libs-ui-components-datetime-dropdown.mjs.map +1 -1
- package/index.d.ts +1 -1
- package/interfaces/date-dropdown.interface.d.ts +47 -0
- package/interfaces/emit-dropdown.interface.d.ts +11 -0
- package/interfaces/functions-control-event.interface.d.ts +11 -0
- package/interfaces/valid.interface.d.ts +10 -0
- package/item/child/child.component.d.ts +51 -0
- package/item/item.component.d.ts +59 -0
- package/package.json +1 -1
- package/pipes/build-list-by-date-type-.pipe.d.ts +15 -0
- package/pipes/build-width.pipe.d.ts +7 -0
- package/esm2022/lib/datetime-dropdown/datetime-dropdown.component.mjs +0 -12
- package/lib/datetime-dropdown/datetime-dropdown.component.d.ts +0 -5
|
@@ -0,0 +1,272 @@
|
|
|
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(undefined);
|
|
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
|
+
if (widthElementParent < width) {
|
|
109
|
+
this.isResponsive.set(true);
|
|
110
|
+
}
|
|
111
|
+
}
|
|
112
|
+
handlerChangeSelectedKey(event, type) {
|
|
113
|
+
this.chooseDate.update(current => {
|
|
114
|
+
if (current) {
|
|
115
|
+
current[type].set(event);
|
|
116
|
+
}
|
|
117
|
+
return current;
|
|
118
|
+
});
|
|
119
|
+
if (this.isEmitAfterChanged()) {
|
|
120
|
+
const dataEmit = this.isMultiple() ? this.chooseDate() : this.chooseDate()?.from();
|
|
121
|
+
if (dataEmit) {
|
|
122
|
+
this.outSelectedDropdown.emit(dataEmit);
|
|
123
|
+
}
|
|
124
|
+
}
|
|
125
|
+
this.applyDate();
|
|
126
|
+
}
|
|
127
|
+
async resetDropdown() {
|
|
128
|
+
this.functionsControl.forEach(control => control.resetDropdown());
|
|
129
|
+
}
|
|
130
|
+
async resetError() {
|
|
131
|
+
this.functionsControl.forEach(control => control.resetError());
|
|
132
|
+
}
|
|
133
|
+
setWidthDate() {
|
|
134
|
+
if (!this.containerRef() || !this.containerRef()?.nativeElement) {
|
|
135
|
+
return;
|
|
136
|
+
}
|
|
137
|
+
timer(0).pipe().subscribe(() => {
|
|
138
|
+
this.checkResponsive();
|
|
139
|
+
});
|
|
140
|
+
}
|
|
141
|
+
handlerFunctionControl(event, type) {
|
|
142
|
+
this.functionsControl.set(type, event);
|
|
143
|
+
}
|
|
144
|
+
async checkValid() {
|
|
145
|
+
let valid = true;
|
|
146
|
+
for (const control of this.functionsControl.values()) {
|
|
147
|
+
if (!(await control.checkIsValid())) {
|
|
148
|
+
valid = false;
|
|
149
|
+
}
|
|
150
|
+
}
|
|
151
|
+
if (this.compareDate()) {
|
|
152
|
+
valid = false;
|
|
153
|
+
}
|
|
154
|
+
return valid;
|
|
155
|
+
}
|
|
156
|
+
setError(error) {
|
|
157
|
+
this.functionsControl.forEach(control => control.setError(error));
|
|
158
|
+
}
|
|
159
|
+
compareDate() {
|
|
160
|
+
const type = this.typeFormat().split('-');
|
|
161
|
+
const dateCompare = [];
|
|
162
|
+
type.forEach(item => {
|
|
163
|
+
const from = this.chooseDate()?.from()[item];
|
|
164
|
+
const to = this.chooseDate()?.to()[item];
|
|
165
|
+
dateCompare.push({ from: from, to: to });
|
|
166
|
+
});
|
|
167
|
+
if (this.ignoreValidTimeCompare() || !this.checkCondition(true)) {
|
|
168
|
+
this.isErrorCompareDate.set(false);
|
|
169
|
+
return false;
|
|
170
|
+
}
|
|
171
|
+
if (CompareDate(dateCompare, this.ignoreAllowTimeEqual())) {
|
|
172
|
+
this.setError(true);
|
|
173
|
+
this.isErrorCompareDate.set(true);
|
|
174
|
+
return true;
|
|
175
|
+
}
|
|
176
|
+
this.isErrorCompareDate.set(false);
|
|
177
|
+
return false;
|
|
178
|
+
}
|
|
179
|
+
async validate() {
|
|
180
|
+
let valid = true;
|
|
181
|
+
if (!this.validRequired()) {
|
|
182
|
+
if (!this.checkCondition(false) && !this.ignoreRequiredValueSecondWhenNotValidRequired()) {
|
|
183
|
+
valid = await this.checkValid();
|
|
184
|
+
}
|
|
185
|
+
return valid;
|
|
186
|
+
}
|
|
187
|
+
return await this.checkValid();
|
|
188
|
+
}
|
|
189
|
+
checkCondition(hasValue) {
|
|
190
|
+
let checkValue = true;
|
|
191
|
+
const type = this.typeFormat().split('-');
|
|
192
|
+
type.forEach(item => {
|
|
193
|
+
if (hasValue && (!this.chooseDate()?.from()[item] || !this.chooseDate()?.to()[item])) {
|
|
194
|
+
checkValue = false;
|
|
195
|
+
}
|
|
196
|
+
if (!hasValue && (this.chooseDate()?.from()[item] || this.chooseDate()?.to()[item])) {
|
|
197
|
+
checkValue = false;
|
|
198
|
+
}
|
|
199
|
+
});
|
|
200
|
+
return checkValue;
|
|
201
|
+
}
|
|
202
|
+
applyDate() {
|
|
203
|
+
this.setError(false);
|
|
204
|
+
this.isErrorCompareDate.set(false);
|
|
205
|
+
if (this.isCheckErrorWhenSelectItem() && !this.validate()) {
|
|
206
|
+
return;
|
|
207
|
+
}
|
|
208
|
+
const from = this.chooseDate()?.from;
|
|
209
|
+
const to = this.chooseDate()?.to;
|
|
210
|
+
if (this.isMultiple()) {
|
|
211
|
+
if (this.compareDate()) {
|
|
212
|
+
return;
|
|
213
|
+
}
|
|
214
|
+
let dataSelected = { from: signal({}), to: signal({}) };
|
|
215
|
+
this.arrayFormat().forEach(key => {
|
|
216
|
+
if (!from?.()?.[key] || !to?.()?.[key]) {
|
|
217
|
+
dataSelected = undefined;
|
|
218
|
+
}
|
|
219
|
+
if (dataSelected) {
|
|
220
|
+
dataSelected.from.update(current => {
|
|
221
|
+
current[key] = Number(from?.()[key]);
|
|
222
|
+
return current;
|
|
223
|
+
});
|
|
224
|
+
dataSelected.to.update(current => {
|
|
225
|
+
current[key] = Number(to?.()[key]);
|
|
226
|
+
return current;
|
|
227
|
+
});
|
|
228
|
+
}
|
|
229
|
+
});
|
|
230
|
+
if (dataSelected) {
|
|
231
|
+
this.outChooseMultiDate.emit(dataSelected);
|
|
232
|
+
}
|
|
233
|
+
return;
|
|
234
|
+
}
|
|
235
|
+
let dataSelected = {};
|
|
236
|
+
this.arrayFormat().forEach(key => {
|
|
237
|
+
if (!from?.()?.[key]) {
|
|
238
|
+
dataSelected = undefined;
|
|
239
|
+
}
|
|
240
|
+
if (dataSelected) {
|
|
241
|
+
dataSelected[key] = Number(from?.()?.[key]);
|
|
242
|
+
}
|
|
243
|
+
});
|
|
244
|
+
if (dataSelected) {
|
|
245
|
+
this.outChooseSingleDate.emit(dataSelected);
|
|
246
|
+
}
|
|
247
|
+
}
|
|
248
|
+
handlerChangeWidthLabel(width) {
|
|
249
|
+
this.cacheWidthLabel.set(width < (this.cacheWidthLabel() || 0) ? this.cacheWidthLabel() : Math.ceil(width));
|
|
250
|
+
if (this.timeOut()) {
|
|
251
|
+
clearTimeout(this.timeOut());
|
|
252
|
+
}
|
|
253
|
+
this.timeOut.set(setTimeout(() => {
|
|
254
|
+
this.widthLabel.set(this.cacheWidthLabel());
|
|
255
|
+
}, 100));
|
|
256
|
+
}
|
|
257
|
+
handlerChangStageFlagMouse(flagMouse) {
|
|
258
|
+
this.outChangStageFlagMouse.emit(flagMouse);
|
|
259
|
+
}
|
|
260
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: LibsUiComponentsDatetimeDropdownComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
261
|
+
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\">{{ 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 });
|
|
262
|
+
}
|
|
263
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: LibsUiComponentsDatetimeDropdownComponent, decorators: [{
|
|
264
|
+
type: Component,
|
|
265
|
+
args: [{ selector: 'libs_ui-components-datetime-dropdown', standalone: true, changeDetection: ChangeDetectionStrategy.OnPush, imports: [
|
|
266
|
+
TranslateModule,
|
|
267
|
+
LibsUiComponentsLabelComponent,
|
|
268
|
+
LibsUiComponentsDatetimeDropdownDirective,
|
|
269
|
+
LibsUiComponentsDatetimeDropdownItemComponent
|
|
270
|
+
], 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\">{{ validRequired()?.messageValidCompareTime || \"i18n_invalid_end_date_selected\" | translate:validRequired()?.interpolateParamsCompareTime }}</span>\n </div>\n}\n" }]
|
|
271
|
+
}], ctorParameters: () => [] });
|
|
272
|
+
//# 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: [\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>(undefined);\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    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    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      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\">{{ validRequired()?.messageValidCompareTime || \"i18n_invalid_end_date_selected\" | translate:validRequired()?.interpolateParamsCompareTime }}</span>\n  </div>\n}\n"]}
|
package/esm2022/index.mjs
CHANGED
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
export * from './
|
|
2
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
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() && this.listConfig().httpRequestData?.()) {\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-message-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() && this.listConfig().httpRequestData?.()) {\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-message-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() && this.listConfig().httpRequestData?.()) {\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-message-error libs-ui-font-h7r\"\n        [innerHtml]=\"(validRequired()?.message || 'i18n_valid_empty_message')| translate:validRequired()?.interpolateParams\"></span>\n    </div>\n  }\n"]}
|