@libs-ui/components-dropdown 0.1.1-1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -0,0 +1,447 @@
1
+ /* eslint-disable @typescript-eslint/no-explicit-any */
2
+ import { AsyncPipe } from '@angular/common';
3
+ import { ChangeDetectionStrategy, Component, computed, effect, inject, input, model, output, signal, untracked } from '@angular/core';
4
+ import { LibsUiComponentsAvatarComponent } from '@libs-ui/components-avatar';
5
+ import { LibsUiComponentsLabelComponent } from '@libs-ui/components-label';
6
+ import { getFieldKeyByType, LibsUiComponentsListComponent } from '@libs-ui/components-list';
7
+ import { LibsUiComponentsPopoverComponent } from '@libs-ui/components-popover';
8
+ import { LibsUiPipesSecurityTrustPipe } from '@libs-ui/pipes-security-trust';
9
+ import { LibsUiHttpRequestService } from '@libs-ui/services-http-request';
10
+ import { CHARACTER_DATA_EMPTY, cloneDeep, ERROR_MESSAGE_EMPTY_VALID, ERROR_MESSAGE_MAX_VALID, get, isEqual, isNil, set } from '@libs-ui/utils';
11
+ import { TranslateModule, TranslateService } from '@ngx-translate/core';
12
+ import { LibsUiComponentsDropdownTabsComponent } from './tabs/tabs.component';
13
+ import * as i0 from "@angular/core";
14
+ import * as i1 from "@ngx-translate/core";
15
+ export class LibsUiComponentsDropdownComponent {
16
+ // #region PROPERTY
17
+ error = signal(undefined);
18
+ showList = signal(false);
19
+ itemsSelected = signal(undefined);
20
+ loadingDetail = signal(false);
21
+ loadingList = signal(false);
22
+ items = signal([]);
23
+ popoverItemSelected = signal(undefined);
24
+ labelItemSelectedComputed = computed(this.getLabelItemSelected.bind(this));
25
+ autoSelectedFirstItemCallOutsideBefore = signal(false);
26
+ keysSelected = signal([]);
27
+ popoverFunctionControl = signal(undefined);
28
+ fieldKey = signal('id');
29
+ listFunctionControl = signal(undefined);
30
+ // #region INPUT
31
+ useXssFilter = input(false);
32
+ popoverElementRefCustom = input();
33
+ classInclude = input();
34
+ ignoreStopPropagationEvent = input(false);
35
+ flagMouse = model({ isMouseEnter: false, isMouseEnterContent: false });
36
+ flagMouseContent = model();
37
+ popoverCustomConfig = input();
38
+ isNgContent = input();
39
+ zIndex = input();
40
+ convertItemSelected = input(this.defaultConvertItemSelected.bind(this));
41
+ getPopoverItemSelected = input();
42
+ httpRequestDetailItemById = input();
43
+ lengthKeys = model(0);
44
+ textDisplayWhenNoSelect = input('i18n_select_information');
45
+ textDisplayWhenMultiSelect = input('i18n_selecting_options');
46
+ classIncludeTextDisplayWhenNoSelect = input('libs-ui-font-h5r');
47
+ fieldLabel = input('labelDisplay', { transform: (value) => value || 'labelDisplay' });
48
+ fieldGetLabel = input();
49
+ labelPopoverConfig = input();
50
+ labelPopoverFullWidth = input(true);
51
+ hasContentUnitRight = input();
52
+ listSearchNoDataTemplateRef = input();
53
+ fieldGetImage = input();
54
+ imageSize = input(16);
55
+ typeShape = input('circle');
56
+ fieldGetIcon = input();
57
+ fieldGetTextAvatar = input('username');
58
+ fieldGetColorAvatar = input();
59
+ classAvatarInclude = input('mr-[8px]', { transform: (value) => value || 'mr-[8px]' });
60
+ getLastTextAfterSpace = input();
61
+ linkImageError = input();
62
+ showError = input(true);
63
+ showBorderError = model();
64
+ disable = input();
65
+ readonly = input();
66
+ labelConfig = input();
67
+ disableLabel = input();
68
+ listSearchConfig = input({ noBorder: true }, { transform: (value) => value || { noBorder: true } });
69
+ isSearchOnline = input(false);
70
+ listHiddenInputSearch = input();
71
+ listSearchPadding = input();
72
+ listKeySearch = input();
73
+ listDividerClassInclude = input();
74
+ listConfig = input();
75
+ listButtonsOther = input();
76
+ listHasButtonUnSelectOption = input();
77
+ listClickExactly = input();
78
+ listBackgroundCustom = input();
79
+ listMaxItemShow = input(5);
80
+ listKeySelected = model();
81
+ listMultiKeySelected = model();
82
+ listKeysDisable = input(); // không dùng giá trị này kết hợp với template checkbox có config chứa configCheckboxCheckAll
83
+ listKeysHidden = input(); // không dùng giá trị này kết hợp với template checkbox có config chứa configCheckboxCheckAll
84
+ validRequired = input();
85
+ validMaxItemSelected = input();
86
+ changeValidUndefinedResetError = input();
87
+ allowSelectItemMultiple = input();
88
+ focusInputSearch = input(true);
89
+ onlyEmitDataWhenReset = input(); // true khi muốn emit sự kiện thay đổi key
90
+ resetKeyWhenSelectAllKey = input();
91
+ listConfigHasDivider = input(true);
92
+ classIncludeIcon = input('ml-[8px]', { transform: (value) => value || 'ml-[8px]' });
93
+ classIncludeContent = input();
94
+ listIgnoreClassDisableDefaultWhenUseKeysDisableItem = input(); // bỏ chế độ disable item trên html list view để disable từng phần trong rows
95
+ tabKeyActive = model();
96
+ tabsConfig = input();
97
+ ignoreBorderBottom = input();
98
+ // #region OUTPUT
99
+ outSelectKey = output(); // sử dụng cho type chọn 1.
100
+ outSelectMultiKey = output(); // sử dụng cho type cho phép chọn nhiều.
101
+ outFunctionsControl = output();
102
+ outValidEvent = output();
103
+ outChangStageFlagMouse = output();
104
+ outDataChange = output();
105
+ outClickButtonOther = output();
106
+ outShowList = output();
107
+ outChangeTabKeyActive = output();
108
+ /* INJECT*/
109
+ translate = inject(TranslateService);
110
+ httpRequestService = inject(LibsUiHttpRequestService);
111
+ constructor() {
112
+ effect(() => {
113
+ const listConfig = this.listConfig();
114
+ if (listConfig) {
115
+ untracked(() => this.fieldKey.set(getFieldKeyByType(listConfig, 'id')));
116
+ }
117
+ });
118
+ effect(() => {
119
+ if (!isNil(this.listKeySelected()) && this.listKeySelected() !== '' && !this.itemsSelected()) {
120
+ untracked(() => {
121
+ this.handlerSelectedKey({ key: this.listKeySelected(), item: undefined, isClickManual: false });
122
+ });
123
+ }
124
+ });
125
+ effect(() => {
126
+ if (this.changeValidUndefinedResetError() && this.validRequired()) {
127
+ untracked(() => this.resetError());
128
+ }
129
+ });
130
+ effect(() => {
131
+ if (this.listMultiKeySelected()) {
132
+ untracked(() => {
133
+ const previousValue = this.keysSelected() || [];
134
+ const currentValue = this.listMultiKeySelected() || [];
135
+ if (isEqual(cloneDeep(previousValue), cloneDeep(currentValue))) {
136
+ return;
137
+ }
138
+ this.handlerSelectMultiKey({ keys: currentValue, mapKeys: [], isClickManual: false });
139
+ });
140
+ }
141
+ });
142
+ }
143
+ async ngOnInit() {
144
+ const listConfig = this.listConfig();
145
+ if (this.listKeySelected() || this.listMultiKeySelected()) {
146
+ this.lengthKeys.set(this.listKeySelected() ? 1 : this.listMultiKeySelected()?.length || 0);
147
+ }
148
+ if (!this.lengthKeys() && listConfig && (listConfig.autoSelectFirstItem || listConfig.configTemplateCheckbox?.()?.autoSelectAllItem || listConfig.configTemplateGroup?.()?.flatItemsSupportAutoSelect) && listConfig.httpRequestData) {
149
+ try {
150
+ this.loadingDetail.set(true);
151
+ const httpRequestData = listConfig.httpRequestData();
152
+ const { argumentsValue, guideAutoUpdateArgumentsValue } = httpRequestData;
153
+ this.httpRequestService.updateArguments(argumentsValue, { ...this.httpRequestService.fakeResponsePagingApi(), dropdownTabKeyActive: this.tabKeyActive }, {}, '', true, false, guideAutoUpdateArgumentsValue);
154
+ const result = await this.httpRequestService.callApi(httpRequestData);
155
+ this.loadingDetail.set(false);
156
+ if (result?.data) {
157
+ this.items.set(result.data);
158
+ this.emitAutoSelectKey(result.data, listConfig.type);
159
+ this.autoSelectedFirstItemCallOutsideBefore.set(true);
160
+ }
161
+ }
162
+ catch (error) {
163
+ console.log(error);
164
+ this.items.set([]);
165
+ this.loadingDetail.set(false);
166
+ }
167
+ this.outDataChange.emit(this.items());
168
+ }
169
+ this.outFunctionsControl.emit(this.FunctionsControl);
170
+ this.checkValid(true);
171
+ }
172
+ /* FUNCTIONS */
173
+ get FunctionsControl() {
174
+ return {
175
+ reset: this.reset.bind(this),
176
+ checkIsValid: this.valid.bind(this),
177
+ resetError: this.resetError.bind(this),
178
+ setError: this.setError.bind(this),
179
+ removeList: async () => this.popoverFunctionControl()?.removePopoverOverlay(),
180
+ getDisable: async () => this.disable() ?? false,
181
+ updateLabelItemSelected: async (label) => this.itemsSelected.update((value) => ({ ...value, [this.fieldLabel()]: this.translate.instant(label) })),
182
+ refreshList: async () => this.listFunctionControl()?.refresh(),
183
+ setItemSelectedByKey: this.setItemSelectedByKey.bind(this),
184
+ };
185
+ }
186
+ defaultConvertItemSelected(item) {
187
+ if (!item) {
188
+ return;
189
+ }
190
+ const fieldGetLabel = this.fieldGetLabel();
191
+ const value = fieldGetLabel ? get(item, fieldGetLabel) : undefined;
192
+ set(item, this.fieldLabel(), value ?? get(item, 'label') ?? get(item, 'name') ?? ' ');
193
+ }
194
+ getLabelItemSelected() {
195
+ let label = ' ';
196
+ if (!this.lengthKeys()) {
197
+ label = this.textDisplayWhenNoSelect();
198
+ }
199
+ if (this.lengthKeys() > 1) {
200
+ label = this.textDisplayWhenMultiSelect();
201
+ }
202
+ if (this.lengthKeys() === 1) {
203
+ label = get(this.itemsSelected(), this.fieldLabel()) || this.textDisplayWhenNoSelect();
204
+ }
205
+ return label;
206
+ }
207
+ emitAutoSelectKey(items, type) {
208
+ const listConfig = this.listConfig();
209
+ if (!items || !items.length || !listConfig || (!listConfig.autoSelectFirstItem && !listConfig.configTemplateCheckbox?.()?.autoSelectAllItem && !listConfig.configTemplateGroup?.()?.flatItemsSupportAutoSelect)) {
210
+ return;
211
+ }
212
+ const flatItemsSupportAutoSelect = listConfig.configTemplateGroup?.()?.flatItemsSupportAutoSelect;
213
+ if (type === 'group' && flatItemsSupportAutoSelect) {
214
+ items = flatItemsSupportAutoSelect(items);
215
+ }
216
+ if (listConfig.autoSelectFirstItem) {
217
+ const item = items[0];
218
+ const key = get(item, this.fieldKey());
219
+ if (type === 'radio' || type === 'text') {
220
+ this.handlerSelectedKey({ key, item, isClickManual: false });
221
+ this.listKeySelected.set(key);
222
+ return;
223
+ }
224
+ this.handlerSelectMultiKey({ keys: [key], mapKeys: [{ key, item, isClickManual: false }], isClickManual: false });
225
+ this.listMultiKeySelected.set([key]);
226
+ return;
227
+ }
228
+ if (type !== 'checkbox' && type !== 'group') {
229
+ return;
230
+ }
231
+ const keys = [];
232
+ const mapKeys = [];
233
+ items.forEach((item) => {
234
+ const key = get(item, this.fieldKey());
235
+ if (isNil(key)) {
236
+ return;
237
+ }
238
+ keys.push(key);
239
+ mapKeys.push({ key, item, isClickManual: false });
240
+ });
241
+ this.handlerSelectMultiKey({ keys, mapKeys, isClickManual: false });
242
+ this.listMultiKeySelected.set(keys);
243
+ }
244
+ handlerEvent(type) {
245
+ if (type === 'click') {
246
+ return;
247
+ }
248
+ if (type === 'remove') {
249
+ this.showList.set(false);
250
+ this.outShowList.emit(this.showList());
251
+ return;
252
+ }
253
+ this.showList.set(true);
254
+ this.outShowList.emit(this.showList());
255
+ }
256
+ handlerDataChange(items) {
257
+ this.items.set(items);
258
+ this.popoverFunctionControl()?.updatePopoverOverlayPosition();
259
+ this.outDataChange.emit(this.items());
260
+ }
261
+ handlerChangeFlagMouse(event) {
262
+ this.flagMouseContent.set(event);
263
+ this.mergeFlagMouse();
264
+ }
265
+ handlerClickButtonOther(button) {
266
+ this.outClickButtonOther.emit(button);
267
+ this.popoverFunctionControl()?.removePopoverOverlay();
268
+ }
269
+ handlerPopoverControlEvent(event) {
270
+ this.popoverFunctionControl.set(event);
271
+ }
272
+ async handlerSelectedKey(event) {
273
+ const key = event?.key;
274
+ const item = event?.item;
275
+ const isClickManual = event?.isClickManual;
276
+ this.lengthKeys.set(!(isNil(key) || (typeof key === 'string' && key === '')) ? 1 : 0);
277
+ this.listKeySelected.set(key);
278
+ if (!this.allowSelectItemMultiple() && this.itemsSelected() && get(this.itemsSelected(), this.fieldKey()) === key) {
279
+ return;
280
+ }
281
+ if (isClickManual) {
282
+ if (!(isNil(key) || (typeof key === 'string' && key === '')) && (item || this.itemsSelected())) {
283
+ this.popoverFunctionControl()?.removePopoverOverlay();
284
+ }
285
+ }
286
+ this.checkValid();
287
+ if (this.lengthKeys() && !item && this.httpRequestDetailItemById()) {
288
+ let itemSelected = await this.setItemSelectedByKey(key);
289
+ if (!itemSelected) {
290
+ itemSelected = {
291
+ [this.fieldKey()]: key,
292
+ [this.fieldLabel()]: CHARACTER_DATA_EMPTY,
293
+ };
294
+ this.itemsSelected.set(itemSelected);
295
+ }
296
+ if (event) {
297
+ event.item = itemSelected;
298
+ }
299
+ this.outSelectKey.emit({ ...event, tabKeyActive: this.tabKeyActive() });
300
+ return;
301
+ }
302
+ this.itemsSelected.set(cloneDeep(item));
303
+ this.buildDisplay();
304
+ this.outSelectKey.emit({ ...event, tabKeyActive: this.tabKeyActive() });
305
+ }
306
+ async handlerSelectMultiKey(event, isClickManual = false) {
307
+ if (this.listConfig()?.configTemplateGroup?.()?.singleSelectItem && event?.mapKeys?.length) {
308
+ const itemClickManual = event.mapKeys.find((mapKey) => mapKey.item && mapKey.item.isCheckManual);
309
+ if (itemClickManual) {
310
+ setTimeout(() => (itemClickManual.item.isCheckManual = false));
311
+ event.keys = [itemClickManual.key];
312
+ event.mapKeys = [itemClickManual];
313
+ this.popoverFunctionControl()?.removePopoverOverlay();
314
+ }
315
+ }
316
+ this.keysSelected.set([...(event?.keys || [])]);
317
+ this.listMultiKeySelected.set([...(event?.keys || [])]);
318
+ this.lengthKeys.set(event?.keys?.length || 0);
319
+ this.checkValid();
320
+ if (this.lengthKeys() > 1) {
321
+ this.outSelectMultiKey.emit({ ...(event || {}), isClickManual, tabKeyActive: this.tabKeyActive() });
322
+ return;
323
+ }
324
+ const key = event?.keys[0];
325
+ let item = event?.mapKeys?.find((item) => item.key === key)?.item;
326
+ if (this.lengthKeys() && !item && this.httpRequestDetailItemById()) {
327
+ item = await this.setItemSelectedByKey(key);
328
+ this.outSelectMultiKey.emit({ keys: [key], mapKeys: [{ key, item }], isClickManual, tabKeyActive: this.tabKeyActive() });
329
+ return;
330
+ }
331
+ this.itemsSelected.set(cloneDeep(item));
332
+ this.buildDisplay();
333
+ this.outSelectMultiKey.emit({ ...(event || {}), isClickManual, tabKeyActive: this.tabKeyActive() });
334
+ }
335
+ async setItemSelectedByKey(key) {
336
+ const httpRequestDetailItemById = this.httpRequestDetailItemById();
337
+ if (!httpRequestDetailItemById || this.loadingDetail()) {
338
+ return;
339
+ }
340
+ try {
341
+ this.loadingDetail.set(true);
342
+ const { argumentsValue, guideAutoUpdateArgumentsValue } = httpRequestDetailItemById;
343
+ this.httpRequestService.updateArguments(argumentsValue, { key, dropdownTabKeyActive: this.tabKeyActive() }, {}, '', false, false, guideAutoUpdateArgumentsValue);
344
+ const result = await this.httpRequestService.callApi(httpRequestDetailItemById);
345
+ const item = cloneDeep(result?.data?.[0] || result?.data);
346
+ this.itemsSelected.set(item);
347
+ this.buildDisplay();
348
+ this.loadingDetail.set(false);
349
+ return item;
350
+ }
351
+ catch (error) {
352
+ console.log(error);
353
+ this.loadingDetail.set(false);
354
+ return;
355
+ }
356
+ }
357
+ handlerChangeTab() {
358
+ this.outChangeTabKeyActive.emit(this.tabKeyActive());
359
+ }
360
+ handlerLoadingList(event) {
361
+ this.loadingList.set(event);
362
+ }
363
+ async setError(error) {
364
+ this.error.set({ message: error });
365
+ this.showBorderError.set(true);
366
+ }
367
+ async valid() {
368
+ if (this.error()?.message) {
369
+ return false;
370
+ }
371
+ return this.checkValid();
372
+ }
373
+ checkValid(validateDefault) {
374
+ this.error.set(undefined);
375
+ const valid = { required: true, limitMaxItemSelect: true };
376
+ const validMaxItemSelected = this.validMaxItemSelected();
377
+ if (this.validRequired() && !this.lengthKeys()) {
378
+ valid.required = false;
379
+ }
380
+ if (validMaxItemSelected && this.lengthKeys() > validMaxItemSelected.value) {
381
+ valid.limitMaxItemSelect = false;
382
+ }
383
+ if (!validateDefault && valid.required === false) {
384
+ const validRequired = this.validRequired();
385
+ this.error.set({ ...(validRequired || {}), message: validRequired?.message || ERROR_MESSAGE_EMPTY_VALID });
386
+ }
387
+ if (!validateDefault && !this.error() && valid.limitMaxItemSelect === false) {
388
+ const validMaxItemSelected = this.validMaxItemSelected();
389
+ this.error.set({ ...(validMaxItemSelected || {}), message: validMaxItemSelected?.message || ERROR_MESSAGE_MAX_VALID, interpolateParams: { value: validMaxItemSelected?.value } });
390
+ }
391
+ this.outValidEvent.emit(valid.required && valid.limitMaxItemSelect);
392
+ return valid.required && valid.limitMaxItemSelect;
393
+ }
394
+ async resetError() {
395
+ this.error.set(undefined);
396
+ this.showBorderError.set(false);
397
+ }
398
+ handlerListFunctionsControl(event) {
399
+ this.listFunctionControl.set(event);
400
+ }
401
+ handlerChangStageFlagMouse(flag) {
402
+ this.flagMouse.set(flag);
403
+ this.mergeFlagMouse();
404
+ }
405
+ async reset() {
406
+ this.itemsSelected.set(undefined);
407
+ this.lengthKeys.set(0);
408
+ this.listFunctionControl()?.resetKeySelected();
409
+ if (!this.showList() && this.onlyEmitDataWhenReset()) {
410
+ this.outSelectKey.emit(undefined);
411
+ this.outSelectMultiKey.emit(undefined);
412
+ }
413
+ this.listKeySelected.set(undefined);
414
+ this.listMultiKeySelected.set(undefined);
415
+ this.keysSelected.set([]);
416
+ this.error.set(undefined);
417
+ }
418
+ async buildDisplay() {
419
+ if (this.itemsSelected()) {
420
+ this.convertItemSelected()(this.itemsSelected(), this.translate);
421
+ const getPopoverItemSelected = this.getPopoverItemSelected();
422
+ if (getPopoverItemSelected) {
423
+ this.popoverItemSelected.set(await getPopoverItemSelected(this.itemsSelected, this.translate));
424
+ }
425
+ }
426
+ }
427
+ mergeFlagMouse() {
428
+ const flag = { isMouseEnter: false, isMouseEnterContent: false, isContainerHasScroll: false };
429
+ if (this.flagMouseContent()?.isMouseEnter || this.flagMouse().isMouseEnter) {
430
+ flag.isMouseEnter = true;
431
+ }
432
+ if (this.flagMouseContent()?.isMouseEnterContent || this.flagMouse().isMouseEnterContent) {
433
+ flag.isMouseEnterContent = true;
434
+ }
435
+ if (this.flagMouseContent()?.isContainerHasScroll || this.flagMouse().isContainerHasScroll) {
436
+ flag.isContainerHasScroll = true;
437
+ }
438
+ this.outChangStageFlagMouse.emit(flag);
439
+ }
440
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: LibsUiComponentsDropdownComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
441
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.14", type: LibsUiComponentsDropdownComponent, isStandalone: true, selector: "libs_ui-components-dropdown", inputs: { useXssFilter: { classPropertyName: "useXssFilter", publicName: "useXssFilter", isSignal: true, isRequired: false, transformFunction: null }, popoverElementRefCustom: { classPropertyName: "popoverElementRefCustom", publicName: "popoverElementRefCustom", isSignal: true, isRequired: false, transformFunction: null }, classInclude: { classPropertyName: "classInclude", publicName: "classInclude", isSignal: true, isRequired: false, transformFunction: null }, ignoreStopPropagationEvent: { classPropertyName: "ignoreStopPropagationEvent", publicName: "ignoreStopPropagationEvent", isSignal: true, isRequired: false, transformFunction: null }, flagMouse: { classPropertyName: "flagMouse", publicName: "flagMouse", isSignal: true, isRequired: false, transformFunction: null }, flagMouseContent: { classPropertyName: "flagMouseContent", publicName: "flagMouseContent", isSignal: true, isRequired: false, transformFunction: null }, popoverCustomConfig: { classPropertyName: "popoverCustomConfig", publicName: "popoverCustomConfig", isSignal: true, isRequired: false, transformFunction: null }, isNgContent: { classPropertyName: "isNgContent", publicName: "isNgContent", isSignal: true, isRequired: false, transformFunction: null }, zIndex: { classPropertyName: "zIndex", publicName: "zIndex", isSignal: true, isRequired: false, transformFunction: null }, convertItemSelected: { classPropertyName: "convertItemSelected", publicName: "convertItemSelected", isSignal: true, isRequired: false, transformFunction: null }, getPopoverItemSelected: { classPropertyName: "getPopoverItemSelected", publicName: "getPopoverItemSelected", isSignal: true, isRequired: false, transformFunction: null }, httpRequestDetailItemById: { classPropertyName: "httpRequestDetailItemById", publicName: "httpRequestDetailItemById", isSignal: true, isRequired: false, transformFunction: null }, lengthKeys: { classPropertyName: "lengthKeys", publicName: "lengthKeys", isSignal: true, isRequired: false, transformFunction: null }, textDisplayWhenNoSelect: { classPropertyName: "textDisplayWhenNoSelect", publicName: "textDisplayWhenNoSelect", isSignal: true, isRequired: false, transformFunction: null }, textDisplayWhenMultiSelect: { classPropertyName: "textDisplayWhenMultiSelect", publicName: "textDisplayWhenMultiSelect", isSignal: true, isRequired: false, transformFunction: null }, classIncludeTextDisplayWhenNoSelect: { classPropertyName: "classIncludeTextDisplayWhenNoSelect", publicName: "classIncludeTextDisplayWhenNoSelect", isSignal: true, isRequired: false, transformFunction: null }, fieldLabel: { classPropertyName: "fieldLabel", publicName: "fieldLabel", isSignal: true, isRequired: false, transformFunction: null }, fieldGetLabel: { classPropertyName: "fieldGetLabel", publicName: "fieldGetLabel", isSignal: true, isRequired: false, transformFunction: null }, labelPopoverConfig: { classPropertyName: "labelPopoverConfig", publicName: "labelPopoverConfig", isSignal: true, isRequired: false, transformFunction: null }, labelPopoverFullWidth: { classPropertyName: "labelPopoverFullWidth", publicName: "labelPopoverFullWidth", isSignal: true, isRequired: false, transformFunction: null }, hasContentUnitRight: { classPropertyName: "hasContentUnitRight", publicName: "hasContentUnitRight", isSignal: true, isRequired: false, transformFunction: null }, listSearchNoDataTemplateRef: { classPropertyName: "listSearchNoDataTemplateRef", publicName: "listSearchNoDataTemplateRef", isSignal: true, isRequired: false, transformFunction: null }, fieldGetImage: { classPropertyName: "fieldGetImage", publicName: "fieldGetImage", isSignal: true, isRequired: false, transformFunction: null }, imageSize: { classPropertyName: "imageSize", publicName: "imageSize", isSignal: true, isRequired: false, transformFunction: null }, typeShape: { classPropertyName: "typeShape", publicName: "typeShape", isSignal: true, isRequired: false, transformFunction: null }, fieldGetIcon: { classPropertyName: "fieldGetIcon", publicName: "fieldGetIcon", isSignal: true, isRequired: false, transformFunction: null }, fieldGetTextAvatar: { classPropertyName: "fieldGetTextAvatar", publicName: "fieldGetTextAvatar", isSignal: true, isRequired: false, transformFunction: null }, fieldGetColorAvatar: { classPropertyName: "fieldGetColorAvatar", publicName: "fieldGetColorAvatar", isSignal: true, isRequired: false, transformFunction: null }, classAvatarInclude: { classPropertyName: "classAvatarInclude", publicName: "classAvatarInclude", isSignal: true, isRequired: false, transformFunction: null }, getLastTextAfterSpace: { classPropertyName: "getLastTextAfterSpace", publicName: "getLastTextAfterSpace", isSignal: true, isRequired: false, transformFunction: null }, linkImageError: { classPropertyName: "linkImageError", publicName: "linkImageError", isSignal: true, isRequired: false, transformFunction: null }, showError: { classPropertyName: "showError", publicName: "showError", isSignal: true, isRequired: false, transformFunction: null }, showBorderError: { classPropertyName: "showBorderError", publicName: "showBorderError", 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 }, labelConfig: { classPropertyName: "labelConfig", publicName: "labelConfig", isSignal: true, isRequired: false, transformFunction: null }, disableLabel: { classPropertyName: "disableLabel", publicName: "disableLabel", isSignal: true, isRequired: false, transformFunction: null }, listSearchConfig: { classPropertyName: "listSearchConfig", publicName: "listSearchConfig", isSignal: true, isRequired: false, transformFunction: null }, isSearchOnline: { classPropertyName: "isSearchOnline", publicName: "isSearchOnline", isSignal: true, isRequired: false, transformFunction: null }, listHiddenInputSearch: { classPropertyName: "listHiddenInputSearch", publicName: "listHiddenInputSearch", isSignal: true, isRequired: false, transformFunction: null }, listSearchPadding: { classPropertyName: "listSearchPadding", publicName: "listSearchPadding", isSignal: true, isRequired: false, transformFunction: null }, listKeySearch: { classPropertyName: "listKeySearch", publicName: "listKeySearch", isSignal: true, isRequired: false, transformFunction: null }, listDividerClassInclude: { classPropertyName: "listDividerClassInclude", publicName: "listDividerClassInclude", isSignal: true, isRequired: false, transformFunction: null }, listConfig: { classPropertyName: "listConfig", publicName: "listConfig", isSignal: true, isRequired: false, transformFunction: null }, listButtonsOther: { classPropertyName: "listButtonsOther", publicName: "listButtonsOther", isSignal: true, isRequired: false, transformFunction: null }, listHasButtonUnSelectOption: { classPropertyName: "listHasButtonUnSelectOption", publicName: "listHasButtonUnSelectOption", isSignal: true, isRequired: false, transformFunction: null }, listClickExactly: { classPropertyName: "listClickExactly", publicName: "listClickExactly", isSignal: true, isRequired: false, transformFunction: null }, listBackgroundCustom: { classPropertyName: "listBackgroundCustom", publicName: "listBackgroundCustom", isSignal: true, isRequired: false, transformFunction: null }, listMaxItemShow: { classPropertyName: "listMaxItemShow", publicName: "listMaxItemShow", isSignal: true, isRequired: false, transformFunction: null }, listKeySelected: { classPropertyName: "listKeySelected", publicName: "listKeySelected", isSignal: true, isRequired: false, transformFunction: null }, listMultiKeySelected: { classPropertyName: "listMultiKeySelected", publicName: "listMultiKeySelected", isSignal: true, isRequired: false, transformFunction: null }, listKeysDisable: { classPropertyName: "listKeysDisable", publicName: "listKeysDisable", isSignal: true, isRequired: false, transformFunction: null }, listKeysHidden: { classPropertyName: "listKeysHidden", publicName: "listKeysHidden", isSignal: true, isRequired: false, transformFunction: null }, validRequired: { classPropertyName: "validRequired", publicName: "validRequired", isSignal: true, isRequired: false, transformFunction: null }, validMaxItemSelected: { classPropertyName: "validMaxItemSelected", publicName: "validMaxItemSelected", isSignal: true, isRequired: false, transformFunction: null }, changeValidUndefinedResetError: { classPropertyName: "changeValidUndefinedResetError", publicName: "changeValidUndefinedResetError", isSignal: true, isRequired: false, transformFunction: null }, allowSelectItemMultiple: { classPropertyName: "allowSelectItemMultiple", publicName: "allowSelectItemMultiple", isSignal: true, isRequired: false, transformFunction: null }, focusInputSearch: { classPropertyName: "focusInputSearch", publicName: "focusInputSearch", isSignal: true, isRequired: false, transformFunction: null }, onlyEmitDataWhenReset: { classPropertyName: "onlyEmitDataWhenReset", publicName: "onlyEmitDataWhenReset", isSignal: true, isRequired: false, transformFunction: null }, resetKeyWhenSelectAllKey: { classPropertyName: "resetKeyWhenSelectAllKey", publicName: "resetKeyWhenSelectAllKey", isSignal: true, isRequired: false, transformFunction: null }, listConfigHasDivider: { classPropertyName: "listConfigHasDivider", publicName: "listConfigHasDivider", isSignal: true, isRequired: false, transformFunction: null }, classIncludeIcon: { classPropertyName: "classIncludeIcon", publicName: "classIncludeIcon", isSignal: true, isRequired: false, transformFunction: null }, classIncludeContent: { classPropertyName: "classIncludeContent", publicName: "classIncludeContent", isSignal: true, isRequired: false, transformFunction: null }, listIgnoreClassDisableDefaultWhenUseKeysDisableItem: { classPropertyName: "listIgnoreClassDisableDefaultWhenUseKeysDisableItem", publicName: "listIgnoreClassDisableDefaultWhenUseKeysDisableItem", isSignal: true, isRequired: false, transformFunction: null }, tabKeyActive: { classPropertyName: "tabKeyActive", publicName: "tabKeyActive", isSignal: true, isRequired: false, transformFunction: null }, tabsConfig: { classPropertyName: "tabsConfig", publicName: "tabsConfig", isSignal: true, isRequired: false, transformFunction: null }, ignoreBorderBottom: { classPropertyName: "ignoreBorderBottom", publicName: "ignoreBorderBottom", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { flagMouse: "flagMouseChange", flagMouseContent: "flagMouseContentChange", lengthKeys: "lengthKeysChange", showBorderError: "showBorderErrorChange", listKeySelected: "listKeySelectedChange", listMultiKeySelected: "listMultiKeySelectedChange", tabKeyActive: "tabKeyActiveChange", outSelectKey: "outSelectKey", outSelectMultiKey: "outSelectMultiKey", outFunctionsControl: "outFunctionsControl", outValidEvent: "outValidEvent", outChangStageFlagMouse: "outChangStageFlagMouse", outDataChange: "outDataChange", outClickButtonOther: "outClickButtonOther", outShowList: "outShowList", outChangeTabKeyActive: "outChangeTabKeyActive" }, ngImport: i0, template: "<div class=\"flex flex-col w-full\">\n @if (labelConfig(); as label) {\n <libs_ui-components-label\n [classInclude]=\"label.classInclude\"\n [labelLeft]=\"label.labelLeft\"\n [labelLeftClass]=\"label.labelLeftClass\"\n [required]=\"label.required\"\n [description]=\"label.description\"\n [descriptionClass]=\"label.descriptionClass\"\n [labelRight]=\"label.labelRight\"\n [labelRightClass]=\"label.labelRightClass\"\n [onlyShowCount]=\"label.onlyShowCount\"\n [buttonsLeft]=\"label.buttonsLeft\"\n [buttonsRight]=\"label.buttonsRight\"\n [disableButtonsLeft]=\"label.disableButtonsLeft || disable() || loadingDetail()\"\n [disableButtonsRight]=\"label.disableButtonsRight || disable() || loadingDetail()\"\n [hasToggle]=\"label.hasToggle\"\n [toggleActive]=\"label.toggleActive\"\n [toggleDisable]=\"label.toggleDisable || disable() || loadingDetail()\"\n [popover]=\"label.popover\"\n [iconPopoverClass]=\"label.iconPopoverClass\"\n [onlyShowCount]=\"label.onlyShowCount\"\n [limitLength]=\"label.limitLength\"\n [buttonsDescription]=\"label.buttonsDescription\"\n [disableButtonsDescription]=\"label.disableButtonsDescription || disable()\"\n [buttonsDescriptionContainerClass]=\"label.buttonsDescriptionContainerClass\"\n [count]=\"label.count\" />\n }\n <libs_ui-components-popover\n [ignoreShowPopover]=\"disable() || readonly() || loadingDetail()\"\n [class]=\"classInclude() || 'w-full'\"\n [mode]=\"'click-toggle'\"\n [flagMouse]=\"flagMouse()\"\n [ignoreHiddenPopoverContentWhenMouseLeave]=\"true\"\n [ignoreCursorPointerModeLikeClick]=\"true\"\n [ignoreStopPropagationEvent]=\"ignoreStopPropagationEvent()\"\n [elementRefCustom]=\"popoverElementRefCustom()\"\n [config]=\"{\n animationConfig: popoverCustomConfig()?.animationConfig || {},\n zIndex: zIndex() ?? 1000,\n widthByParent: popoverCustomConfig()?.widthByParent ?? true,\n parentBorderWidth: popoverCustomConfig()?.parentBorderWidth ?? 0,\n maxHeight: popoverCustomConfig()?.maxHeight ?? 2048,\n maxWidth: popoverCustomConfig()?.maxWidth ?? 2048,\n direction: popoverCustomConfig()?.direction ?? 'bottom',\n template: listViewEl,\n whiteTheme: true,\n timerDestroy: popoverCustomConfig()?.timerDestroy ?? 0,\n ignoreArrow: popoverCustomConfig()?.ignoreArrow ?? true,\n directionDistance: 2,\n classInclude: '!rounded-[4px] overflow-hidden ' + (popoverCustomConfig()?.classInclude ?? 'libs-ui-border-general '),\n position: popoverCustomConfig()?.position || { mode: 'start', distance: 0 },\n width: popoverCustomConfig()?.width,\n classIncludeOverlayBody: popoverCustomConfig()?.classIncludeOverlayBody,\n }\"\n (outFunctionsControl)=\"handlerPopoverControlEvent($event)\"\n (outEvent)=\"handlerEvent($event)\"\n (outChangStageFlagMouse)=\"handlerChangeFlagMouse($event)\">\n @if (!isNgContent()) {\n <div\n [class]=\"'libs-ui-dropdown ' + (classIncludeContent() || '')\"\n [class.libs-ui-border-general]=\"!error() && !showBorderError() && !showList()\"\n [class.libs-ui-border-primary-focus-general]=\"!error() && !showBorderError() && showList()\"\n [class.libs-ui-border-error-general]=\"error() || showBorderError()\"\n [class.libs-ui-readonly]=\"readonly()\"\n [class.libs-ui-readonly-background]=\"readonly()\"\n [class.cursor-pointer]=\"!(disable() || loadingDetail() || readonly())\"\n [class.libs-ui-disable]=\"disable() || loadingDetail()\"\n [class.libs-ui-disable-background]=\"disable() || loadingDetail()\"\n [class.pointer-events-none]=\"loadingDetail()\"\n [class.rounded-tr-0]=\"hasContentUnitRight()\"\n [class.rounded-br-0]=\"hasContentUnitRight()\">\n <div class=\"flex items-center w-full\">\n <div class=\"flex items-center w-full relative\">\n <div\n class=\"flex items-center w-full absolute\"\n [class.libs-ui-dropdown-placeholder]=\"!lengthKeys()\">\n @if (lengthKeys() === 1) {\n @if (itemsSelected(); as itemsSelected) {\n @if (fieldGetImage(); as fieldGetImage) {\n <libs_ui-components-avatar\n [classInclude]=\"classAvatarInclude()\"\n [typeShape]=\"typeShape()\"\n [size]=\"imageSize()\"\n [linkAvatar]=\"itemsSelected[fieldGetImage]\"\n [linkAvatarError]=\"linkImageError()\"\n [idGenColor]=\"itemsSelected[fieldGetColorAvatar() || fieldGetTextAvatar()]\"\n [getLastTextAfterSpace]=\"getLastTextAfterSpace()\"\n [textAvatar]=\"itemsSelected[fieldGetTextAvatar()]\" />\n }\n @if (fieldGetIcon(); as fieldGetIcon) {\n <i [class]=\"itemsSelected[fieldGetIcon] + ' mr-[8px]'\"></i>\n }\n }\n }\n <libs_ui-components-popover\n [type]=\"'text'\"\n [classInclude]=\"(labelPopoverFullWidth() ? 'w-100 ' : '') + classIncludeTextDisplayWhenNoSelect()\"\n [innerHTML]=\"labelItemSelectedComputed() | translate: { value: lengthKeys() } | LibsUiPipesSecurityTrustPipe: 'html' : useXssFilter() | async\"\n [config]=\"{ maxWidth: labelPopoverConfig()?.maxWidth || 250, direction: 'top', zIndex: labelPopoverConfig()?.zIndex, timerDestroy: labelPopoverConfig()?.timerDestroy || 0 }\"\n [ignoreStopPropagationEvent]=\"true\" />\n\n @if (popoverItemSelected(); as popoverItemSelected) {\n <libs_ui-components-popover\n [type]=\"popoverItemSelected.type || 'other'\"\n [config]=\"popoverItemSelected.config || {}\">\n @if (popoverItemSelected.dataView) {\n <div [innerHtml]=\"popoverItemSelected.dataView | translate\"></div>\n } @else {\n <i class=\"libs-ui-icon-tooltip-outline text-[16px] mx-[8px]\"></i>\n }\n </libs_ui-components-popover>\n }\n </div>\n </div>\n <i\n class=\"text-[16px] libs-ui-icon-move-right rotate-90 text-[#6a7383] {{ classIncludeIcon() }}\"\n [class.libs-ui-disable]=\"readonly() || disable()\"></i>\n </div>\n </div>\n } @else {\n <ng-content></ng-content>\n }\n </libs_ui-components-popover>\n @if (showError()) {\n @if (error(); as error) {\n @let constHtmlMessage = error.message || ' ';\n <div\n class=\"mt-[8px] libs-ui-text-error libs-ui-font-h7r\"\n [innerHtml]=\"constHtmlMessage | translate: error.interpolateParams || {}\"></div>\n }\n }\n</div>\n<ng-template #listViewEl>\n <div\n style=\"display: flex; flex-direction: column\"\n [class.h-full]=\"listMaxItemShow() === -1\">\n @if (tabsConfig(); as tabsConfig) {\n <libs_ui-components-dropdown-tabs\n [tabsConfig]=\"tabsConfig\"\n [(tabKeyActive)]=\"tabKeyActive\"\n [ignoreBorderBottom]=\"ignoreBorderBottom()\"\n [disable]=\"disable() || loadingDetail() || loadingList()\"\n (outChange)=\"handlerChangeTab()\" />\n }\n <libs_ui-components-list\n [class.h-full]=\"listMaxItemShow() === -1\"\n [searchConfig]=\"listSearchConfig()\"\n [isSearchOnline]=\"isSearchOnline()\"\n [dropdownTabKeyActive]=\"tabKeyActive()\"\n [keySearch]=\"listKeySearch()\"\n [config]=\"listConfig()\"\n [autoSelectedFirstItemCallOutsideBefore]=\"autoSelectedFirstItemCallOutsideBefore()\"\n [paddingLeftItem]=\"popoverCustomConfig()?.paddingLeftItem ?? false\"\n [disable]=\"disable() || loadingDetail()\"\n [disableLabel]=\"disableLabel()\"\n [hiddenInputSearch]=\"listHiddenInputSearch()\"\n [searchPadding]=\"listSearchPadding()\"\n [maxItemShow]=\"listMaxItemShow()\"\n [keySelected]=\"listKeySelected()\"\n [multiKeySelected]=\"listMultiKeySelected()\"\n [clickExactly]=\"popoverCustomConfig()?.clickExactly ?? false\"\n [dividerClassInclude]=\"listSearchConfig() ? listDividerClassInclude() : 'hidden'\"\n [buttonsOther]=\"listButtonsOther()\"\n [backgroundListCustom]=\"listBackgroundCustom()\"\n [keysDisableItem]=\"listKeysDisable()\"\n [keysHiddenItem]=\"listKeysHidden()\"\n [hasButtonUnSelectOption]=\"listHasButtonUnSelectOption() ?? (!popoverCustomConfig() && !labelConfig()?.required && (listConfig()?.type === 'text' || listConfig()?.type === 'radio'))\"\n [templateRefSearchNoData]=\"listSearchNoDataTemplateRef()\"\n [focusInputSearch]=\"focusInputSearch()\"\n [zIndex]=\"zIndex()\"\n [resetKeyWhenSelectAllKeyDropdown]=\"resetKeyWhenSelectAllKey()\"\n [ignoreClassDisableDefaultWhenUseKeysDisableItem]=\"listIgnoreClassDisableDefaultWhenUseKeysDisableItem()\"\n [hasDivider]=\"listConfigHasDivider()\"\n (outSelectKey)=\"handlerSelectedKey($event)\"\n (outSelectMultiKey)=\"handlerSelectMultiKey($event, true)\"\n (outChangeView)=\"handlerDataChange($event)\"\n (outClickButtonOther)=\"handlerClickButtonOther($event)\"\n (outFunctionsControl)=\"handlerListFunctionsControl($event)\"\n (outChangStageFlagMousePopover)=\"handlerChangStageFlagMouse($event)\"\n (outLoading)=\"handlerLoadingList($event)\" />\n </div>\n</ng-template>\n", styles: [":host{width:100%;display:flex;flex-direction:column}:host .libs-ui-dropdown{position:relative;width:100%;min-height:32px;display:flex;align-items:center;background-color:#fff;padding:0 16px;border-radius:4px;cursor:pointer}\n"], dependencies: [{ kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i1.TranslatePipe, name: "translate" }, { kind: "pipe", type: LibsUiPipesSecurityTrustPipe, name: "LibsUiPipesSecurityTrustPipe" }, { kind: "pipe", type: AsyncPipe, name: "async" }, { 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: "component", type: LibsUiComponentsPopoverComponent, selector: "libs_ui-components-popover,[LibsUiComponentsPopoverDirective]", inputs: ["debugId", "flagMouse", "type", "mode", "config", "ignoreShowPopover", "elementRefCustom", "initEventInElementRefCustom", "classInclude", "ignoreHiddenPopoverContentWhenMouseLeave", "ignoreStopPropagationEvent", "ignoreCursorPointerModeLikeClick", "isAddContentToParentDocument", "ignoreClickOutside"], outputs: ["outEvent", "outChangStageFlagMouse", "outEventPopoverContent", "outFunctionsControl"] }, { kind: "component", type: LibsUiComponentsAvatarComponent, selector: "libs_ui-components-avatar", inputs: ["typeShape", "classInclude", "size", "linkAvatar", "linkAvatarError", "classImageInclude", "zIndexPreviewImage", "clickPreviewImage", "idGenColor", "getLastTextAfterSpace", "textAvatar", "textAvatarClassInclude", "containertextAvatarClassInclude"], outputs: ["outAvatarError", "outEventPreviewImage"] }, { kind: "component", type: LibsUiComponentsListComponent, selector: "libs_ui-components-list", inputs: ["hiddenInputSearch", "dropdownTabKeyActive", "keySearch", "paddingLeftItem", "config", "autoSelectedFirstItemCallOutsideBefore", "isSearchOnline", "disable", "disableLabel", "labelConfig", "searchConfig", "searchPadding", "dividerClassInclude", "hasDivider", "buttonsOther", "hasButtonUnSelectOption", "clickExactly", "backgroundListCustom", "maxItemShow", "keySelected", "multiKeySelected", "keysDisableItem", "keysHiddenItem", "focusInputSearch", "skipFocusInputWhenKeySearchStoreUndefined", "functionGetItemsAutoAddList", "validRequired", "showValidateBottom", "zIndex", "loadingIconSize", "templateRefSearchNoData", "resetKeyWhenSelectAllKeyDropdown", "ignoreClassDisableDefaultWhenUseKeysDisableItem"], outputs: ["outSelectKey", "outSelectMultiKey", "outUnSelectMultiKey", "outClickButtonOther", "outFieldKey", "outChangeView", "outKeySearch", "outLoading", "outFunctionsControl", "outChangStageFlagMousePopover", "outLoadItemsComplete"] }, { kind: "component", type: LibsUiComponentsDropdownTabsComponent, selector: "libs_ui-components-dropdown-tabs", inputs: ["ignoreBorderBottom", "tabsConfig", "tabKeyActive", "disable"], outputs: ["tabKeyActiveChange", "outChange"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
442
+ }
443
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: LibsUiComponentsDropdownComponent, decorators: [{
444
+ type: Component,
445
+ args: [{ selector: 'libs_ui-components-dropdown', standalone: true, changeDetection: ChangeDetectionStrategy.OnPush, imports: [TranslateModule, LibsUiPipesSecurityTrustPipe, AsyncPipe, LibsUiComponentsLabelComponent, LibsUiComponentsPopoverComponent, LibsUiComponentsAvatarComponent, LibsUiComponentsListComponent, LibsUiComponentsDropdownTabsComponent], template: "<div class=\"flex flex-col w-full\">\n @if (labelConfig(); as label) {\n <libs_ui-components-label\n [classInclude]=\"label.classInclude\"\n [labelLeft]=\"label.labelLeft\"\n [labelLeftClass]=\"label.labelLeftClass\"\n [required]=\"label.required\"\n [description]=\"label.description\"\n [descriptionClass]=\"label.descriptionClass\"\n [labelRight]=\"label.labelRight\"\n [labelRightClass]=\"label.labelRightClass\"\n [onlyShowCount]=\"label.onlyShowCount\"\n [buttonsLeft]=\"label.buttonsLeft\"\n [buttonsRight]=\"label.buttonsRight\"\n [disableButtonsLeft]=\"label.disableButtonsLeft || disable() || loadingDetail()\"\n [disableButtonsRight]=\"label.disableButtonsRight || disable() || loadingDetail()\"\n [hasToggle]=\"label.hasToggle\"\n [toggleActive]=\"label.toggleActive\"\n [toggleDisable]=\"label.toggleDisable || disable() || loadingDetail()\"\n [popover]=\"label.popover\"\n [iconPopoverClass]=\"label.iconPopoverClass\"\n [onlyShowCount]=\"label.onlyShowCount\"\n [limitLength]=\"label.limitLength\"\n [buttonsDescription]=\"label.buttonsDescription\"\n [disableButtonsDescription]=\"label.disableButtonsDescription || disable()\"\n [buttonsDescriptionContainerClass]=\"label.buttonsDescriptionContainerClass\"\n [count]=\"label.count\" />\n }\n <libs_ui-components-popover\n [ignoreShowPopover]=\"disable() || readonly() || loadingDetail()\"\n [class]=\"classInclude() || 'w-full'\"\n [mode]=\"'click-toggle'\"\n [flagMouse]=\"flagMouse()\"\n [ignoreHiddenPopoverContentWhenMouseLeave]=\"true\"\n [ignoreCursorPointerModeLikeClick]=\"true\"\n [ignoreStopPropagationEvent]=\"ignoreStopPropagationEvent()\"\n [elementRefCustom]=\"popoverElementRefCustom()\"\n [config]=\"{\n animationConfig: popoverCustomConfig()?.animationConfig || {},\n zIndex: zIndex() ?? 1000,\n widthByParent: popoverCustomConfig()?.widthByParent ?? true,\n parentBorderWidth: popoverCustomConfig()?.parentBorderWidth ?? 0,\n maxHeight: popoverCustomConfig()?.maxHeight ?? 2048,\n maxWidth: popoverCustomConfig()?.maxWidth ?? 2048,\n direction: popoverCustomConfig()?.direction ?? 'bottom',\n template: listViewEl,\n whiteTheme: true,\n timerDestroy: popoverCustomConfig()?.timerDestroy ?? 0,\n ignoreArrow: popoverCustomConfig()?.ignoreArrow ?? true,\n directionDistance: 2,\n classInclude: '!rounded-[4px] overflow-hidden ' + (popoverCustomConfig()?.classInclude ?? 'libs-ui-border-general '),\n position: popoverCustomConfig()?.position || { mode: 'start', distance: 0 },\n width: popoverCustomConfig()?.width,\n classIncludeOverlayBody: popoverCustomConfig()?.classIncludeOverlayBody,\n }\"\n (outFunctionsControl)=\"handlerPopoverControlEvent($event)\"\n (outEvent)=\"handlerEvent($event)\"\n (outChangStageFlagMouse)=\"handlerChangeFlagMouse($event)\">\n @if (!isNgContent()) {\n <div\n [class]=\"'libs-ui-dropdown ' + (classIncludeContent() || '')\"\n [class.libs-ui-border-general]=\"!error() && !showBorderError() && !showList()\"\n [class.libs-ui-border-primary-focus-general]=\"!error() && !showBorderError() && showList()\"\n [class.libs-ui-border-error-general]=\"error() || showBorderError()\"\n [class.libs-ui-readonly]=\"readonly()\"\n [class.libs-ui-readonly-background]=\"readonly()\"\n [class.cursor-pointer]=\"!(disable() || loadingDetail() || readonly())\"\n [class.libs-ui-disable]=\"disable() || loadingDetail()\"\n [class.libs-ui-disable-background]=\"disable() || loadingDetail()\"\n [class.pointer-events-none]=\"loadingDetail()\"\n [class.rounded-tr-0]=\"hasContentUnitRight()\"\n [class.rounded-br-0]=\"hasContentUnitRight()\">\n <div class=\"flex items-center w-full\">\n <div class=\"flex items-center w-full relative\">\n <div\n class=\"flex items-center w-full absolute\"\n [class.libs-ui-dropdown-placeholder]=\"!lengthKeys()\">\n @if (lengthKeys() === 1) {\n @if (itemsSelected(); as itemsSelected) {\n @if (fieldGetImage(); as fieldGetImage) {\n <libs_ui-components-avatar\n [classInclude]=\"classAvatarInclude()\"\n [typeShape]=\"typeShape()\"\n [size]=\"imageSize()\"\n [linkAvatar]=\"itemsSelected[fieldGetImage]\"\n [linkAvatarError]=\"linkImageError()\"\n [idGenColor]=\"itemsSelected[fieldGetColorAvatar() || fieldGetTextAvatar()]\"\n [getLastTextAfterSpace]=\"getLastTextAfterSpace()\"\n [textAvatar]=\"itemsSelected[fieldGetTextAvatar()]\" />\n }\n @if (fieldGetIcon(); as fieldGetIcon) {\n <i [class]=\"itemsSelected[fieldGetIcon] + ' mr-[8px]'\"></i>\n }\n }\n }\n <libs_ui-components-popover\n [type]=\"'text'\"\n [classInclude]=\"(labelPopoverFullWidth() ? 'w-100 ' : '') + classIncludeTextDisplayWhenNoSelect()\"\n [innerHTML]=\"labelItemSelectedComputed() | translate: { value: lengthKeys() } | LibsUiPipesSecurityTrustPipe: 'html' : useXssFilter() | async\"\n [config]=\"{ maxWidth: labelPopoverConfig()?.maxWidth || 250, direction: 'top', zIndex: labelPopoverConfig()?.zIndex, timerDestroy: labelPopoverConfig()?.timerDestroy || 0 }\"\n [ignoreStopPropagationEvent]=\"true\" />\n\n @if (popoverItemSelected(); as popoverItemSelected) {\n <libs_ui-components-popover\n [type]=\"popoverItemSelected.type || 'other'\"\n [config]=\"popoverItemSelected.config || {}\">\n @if (popoverItemSelected.dataView) {\n <div [innerHtml]=\"popoverItemSelected.dataView | translate\"></div>\n } @else {\n <i class=\"libs-ui-icon-tooltip-outline text-[16px] mx-[8px]\"></i>\n }\n </libs_ui-components-popover>\n }\n </div>\n </div>\n <i\n class=\"text-[16px] libs-ui-icon-move-right rotate-90 text-[#6a7383] {{ classIncludeIcon() }}\"\n [class.libs-ui-disable]=\"readonly() || disable()\"></i>\n </div>\n </div>\n } @else {\n <ng-content></ng-content>\n }\n </libs_ui-components-popover>\n @if (showError()) {\n @if (error(); as error) {\n @let constHtmlMessage = error.message || ' ';\n <div\n class=\"mt-[8px] libs-ui-text-error libs-ui-font-h7r\"\n [innerHtml]=\"constHtmlMessage | translate: error.interpolateParams || {}\"></div>\n }\n }\n</div>\n<ng-template #listViewEl>\n <div\n style=\"display: flex; flex-direction: column\"\n [class.h-full]=\"listMaxItemShow() === -1\">\n @if (tabsConfig(); as tabsConfig) {\n <libs_ui-components-dropdown-tabs\n [tabsConfig]=\"tabsConfig\"\n [(tabKeyActive)]=\"tabKeyActive\"\n [ignoreBorderBottom]=\"ignoreBorderBottom()\"\n [disable]=\"disable() || loadingDetail() || loadingList()\"\n (outChange)=\"handlerChangeTab()\" />\n }\n <libs_ui-components-list\n [class.h-full]=\"listMaxItemShow() === -1\"\n [searchConfig]=\"listSearchConfig()\"\n [isSearchOnline]=\"isSearchOnline()\"\n [dropdownTabKeyActive]=\"tabKeyActive()\"\n [keySearch]=\"listKeySearch()\"\n [config]=\"listConfig()\"\n [autoSelectedFirstItemCallOutsideBefore]=\"autoSelectedFirstItemCallOutsideBefore()\"\n [paddingLeftItem]=\"popoverCustomConfig()?.paddingLeftItem ?? false\"\n [disable]=\"disable() || loadingDetail()\"\n [disableLabel]=\"disableLabel()\"\n [hiddenInputSearch]=\"listHiddenInputSearch()\"\n [searchPadding]=\"listSearchPadding()\"\n [maxItemShow]=\"listMaxItemShow()\"\n [keySelected]=\"listKeySelected()\"\n [multiKeySelected]=\"listMultiKeySelected()\"\n [clickExactly]=\"popoverCustomConfig()?.clickExactly ?? false\"\n [dividerClassInclude]=\"listSearchConfig() ? listDividerClassInclude() : 'hidden'\"\n [buttonsOther]=\"listButtonsOther()\"\n [backgroundListCustom]=\"listBackgroundCustom()\"\n [keysDisableItem]=\"listKeysDisable()\"\n [keysHiddenItem]=\"listKeysHidden()\"\n [hasButtonUnSelectOption]=\"listHasButtonUnSelectOption() ?? (!popoverCustomConfig() && !labelConfig()?.required && (listConfig()?.type === 'text' || listConfig()?.type === 'radio'))\"\n [templateRefSearchNoData]=\"listSearchNoDataTemplateRef()\"\n [focusInputSearch]=\"focusInputSearch()\"\n [zIndex]=\"zIndex()\"\n [resetKeyWhenSelectAllKeyDropdown]=\"resetKeyWhenSelectAllKey()\"\n [ignoreClassDisableDefaultWhenUseKeysDisableItem]=\"listIgnoreClassDisableDefaultWhenUseKeysDisableItem()\"\n [hasDivider]=\"listConfigHasDivider()\"\n (outSelectKey)=\"handlerSelectedKey($event)\"\n (outSelectMultiKey)=\"handlerSelectMultiKey($event, true)\"\n (outChangeView)=\"handlerDataChange($event)\"\n (outClickButtonOther)=\"handlerClickButtonOther($event)\"\n (outFunctionsControl)=\"handlerListFunctionsControl($event)\"\n (outChangStageFlagMousePopover)=\"handlerChangStageFlagMouse($event)\"\n (outLoading)=\"handlerLoadingList($event)\" />\n </div>\n</ng-template>\n", styles: [":host{width:100%;display:flex;flex-direction:column}:host .libs-ui-dropdown{position:relative;width:100%;min-height:32px;display:flex;align-items:center;background-color:#fff;padding:0 16px;border-radius:4px;cursor:pointer}\n"] }]
446
+ }], ctorParameters: () => [] });
447
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dropdown.component.js","sourceRoot":"","sources":["../../../../../libs-ui/components/dropdown/src/dropdown.component.ts","../../../../../libs-ui/components/dropdown/src/dropdown.component.html"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @typescript-eslint/no-explicit-any */\nimport { AsyncPipe } from '@angular/common';\nimport { ChangeDetectionStrategy, Component, computed, effect, inject, input, model, OnInit, output, signal, TemplateRef, untracked } from '@angular/core';\nimport { LibsUiComponentsAvatarComponent, TYPE_SHAPE_AVATAR, TYPE_SIZE_AVATAR_CONFIG } from '@libs-ui/components-avatar';\nimport { IButton } from '@libs-ui/components-buttons-button';\nimport { IInputSearchConfig } from '@libs-ui/components-inputs-search';\nimport { ILabel, LibsUiComponentsLabelComponent } from '@libs-ui/components-label';\nimport { getFieldKeyByType, IListDataEmitKey, IListDataEmitMultiKey, IListFunctionControlEvent, IListConfigItem, LibsUiComponentsListComponent, TYPE_TEMPLATE } from '@libs-ui/components-list';\nimport { IFlagMouse, IPopover, IPopoverFunctionControlEvent, IPopoverOverlay, LibsUiComponentsPopoverComponent, TYPE_POPOVER_EVENT } from '@libs-ui/components-popover';\nimport { LibsUiPipesSecurityTrustPipe } from '@libs-ui/pipes-security-trust';\nimport { IHttpRequestConfig, LibsUiHttpRequestService } from '@libs-ui/services-http-request';\nimport { CHARACTER_DATA_EMPTY, cloneDeep, ERROR_MESSAGE_EMPTY_VALID, ERROR_MESSAGE_MAX_VALID, get, isEqual, isNil, set } from '@libs-ui/utils';\nimport { TranslateModule, TranslateService } from '@ngx-translate/core';\nimport { IDropdownTabsItem, IEmitMultiKey, IEmitSelectKey, IPopoverCustomConfig, IValidMaxItemSelected } from './interfaces/dropdown.interface';\nimport { IDropdownFunctionControlEvent } from './interfaces/function-control-event.interface';\nimport { LibsUiComponentsDropdownTabsComponent } from './tabs/tabs.component';\nimport { IMessageTranslate } from '@libs-ui/interfaces-types';\n\n@Component({\n  // eslint-disable-next-line @angular-eslint/component-selector\n  selector: 'libs_ui-components-dropdown',\n  templateUrl: './dropdown.component.html',\n  styleUrl: './dropdown.component.scss',\n  standalone: true,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  imports: [TranslateModule, LibsUiPipesSecurityTrustPipe, AsyncPipe, LibsUiComponentsLabelComponent, LibsUiComponentsPopoverComponent, LibsUiComponentsAvatarComponent, LibsUiComponentsListComponent, LibsUiComponentsDropdownTabsComponent],\n})\nexport class LibsUiComponentsDropdownComponent implements OnInit {\n  // #region PROPERTY\n  protected error = signal<IMessageTranslate | undefined>(undefined);\n  protected showList = signal<boolean>(false);\n  protected itemsSelected = signal<any>(undefined);\n  protected loadingDetail = signal<boolean>(false);\n  protected loadingList = signal<boolean>(false);\n  protected items = signal<Array<unknown>>([]);\n  protected popoverItemSelected = signal<IPopover | undefined>(undefined);\n  protected labelItemSelectedComputed = computed(this.getLabelItemSelected.bind(this));\n  protected autoSelectedFirstItemCallOutsideBefore = signal<boolean>(false);\n\n  private keysSelected = signal<Array<unknown>>([]);\n  private popoverFunctionControl = signal<IPopoverFunctionControlEvent | undefined>(undefined);\n  private fieldKey = signal<string>('id');\n  private listFunctionControl = signal<IListFunctionControlEvent | undefined>(undefined);\n\n  // #region INPUT\n  readonly useXssFilter = input<boolean>(false);\n  readonly popoverElementRefCustom = input<HTMLElement>();\n  readonly classInclude = input<string>();\n  readonly ignoreStopPropagationEvent = input<boolean>(false);\n  readonly flagMouse = model<IFlagMouse>({ isMouseEnter: false, isMouseEnterContent: false });\n  readonly flagMouseContent = model<IFlagMouse>();\n  readonly popoverCustomConfig = input<IPopoverCustomConfig>();\n  readonly isNgContent = input<boolean>();\n  readonly zIndex = input<number>();\n  readonly convertItemSelected = input<(item: unknown, translate?: TranslateService) => void>(this.defaultConvertItemSelected.bind(this));\n  readonly getPopoverItemSelected = input<(item: unknown, translate?: TranslateService) => Promise<IPopover | undefined>>();\n  readonly httpRequestDetailItemById = input<IHttpRequestConfig>();\n  readonly lengthKeys = model<number>(0);\n  readonly textDisplayWhenNoSelect = input<string>('i18n_select_information');\n  readonly textDisplayWhenMultiSelect = input<string>('i18n_selecting_options');\n  readonly classIncludeTextDisplayWhenNoSelect = input<string>('libs-ui-font-h5r');\n  readonly fieldLabel = input<string, string | undefined>('labelDisplay', { transform: (value) => value || 'labelDisplay' });\n  readonly fieldGetLabel = input<string>();\n  readonly labelPopoverConfig = input<IPopoverOverlay>();\n  readonly labelPopoverFullWidth = input<boolean>(true);\n  readonly hasContentUnitRight = input<boolean>();\n  readonly listSearchNoDataTemplateRef = input<TemplateRef<unknown>>();\n  readonly fieldGetImage = input<string>();\n  readonly imageSize = input<TYPE_SIZE_AVATAR_CONFIG>(16);\n  readonly typeShape = input<TYPE_SHAPE_AVATAR>('circle');\n  readonly fieldGetIcon = input<string>();\n  readonly fieldGetTextAvatar = input<string>('username');\n  readonly fieldGetColorAvatar = input<string>();\n  readonly classAvatarInclude = input<string, string | undefined>('mr-[8px]', { transform: (value) => value || 'mr-[8px]' });\n  readonly getLastTextAfterSpace = input<boolean>();\n  readonly linkImageError = input<string>();\n  readonly showError = input<boolean>(true);\n  readonly showBorderError = model<boolean>();\n  readonly disable = input<boolean>();\n  readonly readonly = input<boolean>();\n  readonly labelConfig = input<ILabel>();\n  readonly disableLabel = input<boolean>();\n\n  readonly listSearchConfig = input<IInputSearchConfig, IInputSearchConfig | undefined>({ noBorder: true }, { transform: (value) => value || { noBorder: true } });\n  readonly isSearchOnline = input<boolean>(false);\n  readonly listHiddenInputSearch = input<boolean>();\n  readonly listSearchPadding = input<boolean>();\n  readonly listKeySearch = input<string>();\n  readonly listDividerClassInclude = input<string>();\n  readonly listConfig = input<IListConfigItem>();\n  readonly listButtonsOther = input<Array<IButton>>();\n  readonly listHasButtonUnSelectOption = input<boolean>();\n  readonly listClickExactly = input<boolean>();\n  readonly listBackgroundCustom = input<string>();\n  readonly listMaxItemShow = input<number>(5);\n  readonly listKeySelected = model<unknown>();\n  readonly listMultiKeySelected = model<Array<unknown>>();\n  readonly listKeysDisable = input<Array<string>>(); // không dùng giá trị này kết hợp với template checkbox có config chứa configCheckboxCheckAll\n  readonly listKeysHidden = input<Array<string>>(); // không dùng giá trị này kết hợp với template checkbox có config chứa configCheckboxCheckAll\n  readonly validRequired = input<IMessageTranslate>();\n  readonly validMaxItemSelected = input<IValidMaxItemSelected>();\n  readonly changeValidUndefinedResetError = input<boolean>();\n  readonly allowSelectItemMultiple = input<boolean>();\n  readonly focusInputSearch = input<boolean>(true);\n  readonly onlyEmitDataWhenReset = input<boolean>(); // true khi muốn emit sự kiện thay đổi key\n  readonly resetKeyWhenSelectAllKey = input<boolean>();\n  readonly listConfigHasDivider = input<boolean>(true);\n  readonly classIncludeIcon = input<string, string | undefined>('ml-[8px]', { transform: (value) => value || 'ml-[8px]' });\n  readonly classIncludeContent = input<string>();\n  readonly listIgnoreClassDisableDefaultWhenUseKeysDisableItem = input<boolean>(); // bỏ chế độ disable item trên html list view để disable từng phần trong rows\n  readonly tabKeyActive = model<string>();\n  readonly tabsConfig = input<Array<IDropdownTabsItem>>();\n  readonly ignoreBorderBottom = input<boolean>();\n\n  // #region OUTPUT\n  readonly outSelectKey = output<IEmitSelectKey | undefined>(); // sử dụng cho type chọn 1.\n  readonly outSelectMultiKey = output<IEmitMultiKey | undefined>(); // sử dụng cho type cho phép chọn nhiều.\n  readonly outFunctionsControl = output<IDropdownFunctionControlEvent>();\n  readonly outValidEvent = output<boolean>();\n  readonly outChangStageFlagMouse = output<IFlagMouse>();\n  readonly outDataChange = output<Array<unknown>>();\n  readonly outClickButtonOther = output<IButton>();\n  readonly outShowList = output<boolean>();\n  readonly outChangeTabKeyActive = output<string | undefined>();\n\n  /* INJECT*/\n  private translate = inject(TranslateService);\n  private httpRequestService = inject(LibsUiHttpRequestService);\n\n  constructor() {\n    effect(() => {\n      const listConfig = this.listConfig();\n      if (listConfig) {\n        untracked(() => this.fieldKey.set(getFieldKeyByType(listConfig, 'id')));\n      }\n    });\n    effect(() => {\n      if (!isNil(this.listKeySelected()) && this.listKeySelected() !== '' && !this.itemsSelected()) {\n        untracked(() => {\n          this.handlerSelectedKey({ key: this.listKeySelected(), item: undefined, isClickManual: false });\n        });\n      }\n    });\n    effect(() => {\n      if (this.changeValidUndefinedResetError() && this.validRequired()) {\n        untracked(() => this.resetError());\n      }\n    });\n    effect(() => {\n      if (this.listMultiKeySelected()) {\n        untracked(() => {\n          const previousValue = this.keysSelected() || [];\n          const currentValue = this.listMultiKeySelected() || [];\n\n          if (isEqual(cloneDeep(previousValue), cloneDeep(currentValue))) {\n            return;\n          }\n\n          this.handlerSelectMultiKey({ keys: currentValue, mapKeys: [], isClickManual: false });\n        });\n      }\n    });\n  }\n\n  async ngOnInit() {\n    const listConfig = this.listConfig();\n\n    if (this.listKeySelected() || this.listMultiKeySelected()) {\n      this.lengthKeys.set(this.listKeySelected() ? 1 : this.listMultiKeySelected()?.length || 0);\n    }\n\n    if (!this.lengthKeys() && listConfig && (listConfig.autoSelectFirstItem || listConfig.configTemplateCheckbox?.()?.autoSelectAllItem || listConfig.configTemplateGroup?.()?.flatItemsSupportAutoSelect) && listConfig.httpRequestData) {\n      try {\n        this.loadingDetail.set(true);\n        const httpRequestData = listConfig.httpRequestData();\n        const { argumentsValue, guideAutoUpdateArgumentsValue } = httpRequestData;\n        this.httpRequestService.updateArguments(argumentsValue, { ...this.httpRequestService.fakeResponsePagingApi(), dropdownTabKeyActive: this.tabKeyActive }, {}, '', true, false, guideAutoUpdateArgumentsValue);\n        const result = await this.httpRequestService.callApi(httpRequestData);\n        this.loadingDetail.set(false);\n        if (result?.data) {\n          this.items.set(result.data);\n          this.emitAutoSelectKey(result.data, listConfig.type);\n          this.autoSelectedFirstItemCallOutsideBefore.set(true);\n        }\n      } catch (error) {\n        console.log(error);\n        this.items.set([]);\n        this.loadingDetail.set(false);\n      }\n      this.outDataChange.emit(this.items());\n    }\n    this.outFunctionsControl.emit(this.FunctionsControl);\n    this.checkValid(true);\n  }\n\n  /* FUNCTIONS */\n  public get FunctionsControl(): IDropdownFunctionControlEvent {\n    return {\n      reset: this.reset.bind(this),\n      checkIsValid: this.valid.bind(this),\n      resetError: this.resetError.bind(this),\n      setError: this.setError.bind(this),\n      removeList: async () => this.popoverFunctionControl()?.removePopoverOverlay(),\n      getDisable: async () => this.disable() ?? false,\n      updateLabelItemSelected: async (label) => this.itemsSelected.update((value) => ({ ...value, [this.fieldLabel()]: this.translate.instant(label) })),\n      refreshList: async () => this.listFunctionControl()?.refresh(),\n      setItemSelectedByKey: this.setItemSelectedByKey.bind(this),\n    };\n  }\n\n  private defaultConvertItemSelected(item: unknown) {\n    if (!item) {\n      return;\n    }\n    const fieldGetLabel = this.fieldGetLabel();\n    const value = fieldGetLabel ? get<any>(item, fieldGetLabel) : undefined;\n    set<any>(item, this.fieldLabel(), value ?? get<any>(item, 'label') ?? get<any>(item, 'name') ?? ' ');\n  }\n\n  private getLabelItemSelected() {\n    let label = ' ';\n    if (!this.lengthKeys()) {\n      label = this.textDisplayWhenNoSelect();\n    }\n    if (this.lengthKeys() > 1) {\n      label = this.textDisplayWhenMultiSelect();\n    }\n    if (this.lengthKeys() === 1) {\n      label = get(this.itemsSelected(), this.fieldLabel()) || this.textDisplayWhenNoSelect();\n    }\n    return label;\n  }\n\n  private emitAutoSelectKey(items: Array<unknown>, type: TYPE_TEMPLATE) {\n    const listConfig = this.listConfig();\n    if (!items || !items.length || !listConfig || (!listConfig.autoSelectFirstItem && !listConfig.configTemplateCheckbox?.()?.autoSelectAllItem && !listConfig.configTemplateGroup?.()?.flatItemsSupportAutoSelect)) {\n      return;\n    }\n    const flatItemsSupportAutoSelect = listConfig.configTemplateGroup?.()?.flatItemsSupportAutoSelect;\n    if (type === 'group' && flatItemsSupportAutoSelect) {\n      items = flatItemsSupportAutoSelect(items);\n    }\n    if (listConfig.autoSelectFirstItem) {\n      const item = items[0];\n      const key = get(item, this.fieldKey());\n      if (type === 'radio' || type === 'text') {\n        this.handlerSelectedKey({ key, item, isClickManual: false });\n        this.listKeySelected.set(key);\n        return;\n      }\n      this.handlerSelectMultiKey({ keys: [key], mapKeys: [{ key, item, isClickManual: false }], isClickManual: false });\n      this.listMultiKeySelected.set([key]);\n      return;\n    }\n    if (type !== 'checkbox' && type !== 'group') {\n      return;\n    }\n    const keys: Array<string> = [];\n    const mapKeys: Array<IListDataEmitKey> = [];\n    items.forEach((item) => {\n      const key = get(item, this.fieldKey());\n      if (isNil(key)) {\n        return;\n      }\n      keys.push(key);\n      mapKeys.push({ key, item, isClickManual: false });\n    });\n    this.handlerSelectMultiKey({ keys, mapKeys, isClickManual: false });\n    this.listMultiKeySelected.set(keys);\n  }\n\n  protected handlerEvent(type: TYPE_POPOVER_EVENT) {\n    if (type === 'click') {\n      return;\n    }\n    if (type === 'remove') {\n      this.showList.set(false);\n      this.outShowList.emit(this.showList());\n      return;\n    }\n    this.showList.set(true);\n    this.outShowList.emit(this.showList());\n  }\n\n  protected handlerDataChange(items: Array<unknown>) {\n    this.items.set(items);\n    this.popoverFunctionControl()?.updatePopoverOverlayPosition();\n    this.outDataChange.emit(this.items());\n  }\n\n  protected handlerChangeFlagMouse(event: IFlagMouse) {\n    this.flagMouseContent.set(event);\n    this.mergeFlagMouse();\n  }\n\n  protected handlerClickButtonOther(button: IButton) {\n    this.outClickButtonOther.emit(button);\n    this.popoverFunctionControl()?.removePopoverOverlay();\n  }\n\n  protected handlerPopoverControlEvent(event: IPopoverFunctionControlEvent) {\n    this.popoverFunctionControl.set(event);\n  }\n\n  protected async handlerSelectedKey(event: IListDataEmitKey | undefined) {\n    const key = event?.key;\n    const item = event?.item;\n    const isClickManual = event?.isClickManual;\n    this.lengthKeys.set(!(isNil(key) || (typeof key === 'string' && key === '')) ? 1 : 0);\n    this.listKeySelected.set(key);\n    if (!this.allowSelectItemMultiple() && this.itemsSelected() && get(this.itemsSelected(), this.fieldKey()) === key) {\n      return;\n    }\n    if (isClickManual) {\n      if (!(isNil(key) || (typeof key === 'string' && key === '')) && (item || this.itemsSelected())) {\n        this.popoverFunctionControl()?.removePopoverOverlay();\n      }\n    }\n    this.checkValid();\n    if (this.lengthKeys() && !item && this.httpRequestDetailItemById()) {\n      let itemSelected = await this.setItemSelectedByKey(key);\n      if (!itemSelected) {\n        itemSelected = {\n          [this.fieldKey()]: key,\n          [this.fieldLabel()]: CHARACTER_DATA_EMPTY,\n        };\n        this.itemsSelected.set(itemSelected);\n      }\n      if (event) {\n        event.item = itemSelected;\n      }\n      this.outSelectKey.emit({ ...event, tabKeyActive: this.tabKeyActive() });\n      return;\n    }\n    this.itemsSelected.set(cloneDeep(item));\n    this.buildDisplay();\n    this.outSelectKey.emit({ ...event, tabKeyActive: this.tabKeyActive() });\n  }\n\n  protected async handlerSelectMultiKey(event: IListDataEmitMultiKey | undefined, isClickManual = false) {\n    if (this.listConfig()?.configTemplateGroup?.()?.singleSelectItem && event?.mapKeys?.length) {\n      const itemClickManual = event.mapKeys.find((mapKey) => mapKey.item && mapKey.item.isCheckManual);\n      if (itemClickManual) {\n        setTimeout(() => (itemClickManual.item.isCheckManual = false));\n        event.keys = [itemClickManual.key];\n        event.mapKeys = [itemClickManual];\n        this.popoverFunctionControl()?.removePopoverOverlay();\n      }\n    }\n    this.keysSelected.set([...(event?.keys || [])]);\n    this.listMultiKeySelected.set([...(event?.keys || [])]);\n    this.lengthKeys.set(event?.keys?.length || 0);\n    this.checkValid();\n    if (this.lengthKeys() > 1) {\n      this.outSelectMultiKey.emit({ ...(event || {}), isClickManual, tabKeyActive: this.tabKeyActive() });\n      return;\n    }\n    const key = event?.keys[0];\n    let item = event?.mapKeys?.find((item) => item.key === key)?.item;\n\n    if (this.lengthKeys() && !item && this.httpRequestDetailItemById()) {\n      item = await this.setItemSelectedByKey(key);\n      this.outSelectMultiKey.emit({ keys: [key], mapKeys: [{ key, item }], isClickManual, tabKeyActive: this.tabKeyActive() });\n      return;\n    }\n    this.itemsSelected.set(cloneDeep(item));\n    this.buildDisplay();\n    this.outSelectMultiKey.emit({ ...(event || {}), isClickManual, tabKeyActive: this.tabKeyActive() });\n  }\n\n  private async setItemSelectedByKey(key: unknown) {\n    const httpRequestDetailItemById = this.httpRequestDetailItemById();\n    if (!httpRequestDetailItemById || this.loadingDetail()) {\n      return;\n    }\n    try {\n      this.loadingDetail.set(true);\n      const { argumentsValue, guideAutoUpdateArgumentsValue } = httpRequestDetailItemById;\n      this.httpRequestService.updateArguments(argumentsValue, { key, dropdownTabKeyActive: this.tabKeyActive() }, {}, '', false, false, guideAutoUpdateArgumentsValue);\n      const result = await this.httpRequestService.callApi(httpRequestDetailItemById);\n      const item = cloneDeep(result?.data?.[0] || result?.data);\n      this.itemsSelected.set(item);\n      this.buildDisplay();\n      this.loadingDetail.set(false);\n      return item;\n    } catch (error) {\n      console.log(error);\n      this.loadingDetail.set(false);\n      return;\n    }\n  }\n\n  protected handlerChangeTab() {\n    this.outChangeTabKeyActive.emit(this.tabKeyActive());\n  }\n\n  protected handlerLoadingList(event: boolean) {\n    this.loadingList.set(event);\n  }\n\n  private async setError(error: string) {\n    this.error.set({ message: error });\n    this.showBorderError.set(true);\n  }\n\n  private async valid() {\n    if (this.error()?.message) {\n      return false;\n    }\n    return this.checkValid();\n  }\n\n  private checkValid(validateDefault?: boolean): boolean {\n    this.error.set(undefined);\n    const valid = { required: true, limitMaxItemSelect: true };\n    const validMaxItemSelected = this.validMaxItemSelected();\n    if (this.validRequired() && !this.lengthKeys()) {\n      valid.required = false;\n    }\n    if (validMaxItemSelected && this.lengthKeys() > validMaxItemSelected.value) {\n      valid.limitMaxItemSelect = false;\n    }\n    if (!validateDefault && valid.required === false) {\n      const validRequired = this.validRequired();\n      this.error.set({ ...(validRequired || {}), message: validRequired?.message || ERROR_MESSAGE_EMPTY_VALID });\n    }\n    if (!validateDefault && !this.error() && valid.limitMaxItemSelect === false) {\n      const validMaxItemSelected = this.validMaxItemSelected();\n      this.error.set({ ...(validMaxItemSelected || {}), message: validMaxItemSelected?.message || ERROR_MESSAGE_MAX_VALID, interpolateParams: { value: validMaxItemSelected?.value } });\n    }\n    this.outValidEvent.emit(valid.required && valid.limitMaxItemSelect);\n    return valid.required && valid.limitMaxItemSelect;\n  }\n\n  private async resetError() {\n    this.error.set(undefined);\n    this.showBorderError.set(false);\n  }\n\n  protected handlerListFunctionsControl(event: IListFunctionControlEvent) {\n    this.listFunctionControl.set(event);\n  }\n\n  protected handlerChangStageFlagMouse(flag: IFlagMouse) {\n    this.flagMouse.set(flag);\n    this.mergeFlagMouse();\n  }\n\n  private async reset() {\n    this.itemsSelected.set(undefined);\n    this.lengthKeys.set(0);\n    this.listFunctionControl()?.resetKeySelected();\n    if (!this.showList() && this.onlyEmitDataWhenReset()) {\n      this.outSelectKey.emit(undefined);\n      this.outSelectMultiKey.emit(undefined);\n    }\n    this.listKeySelected.set(undefined);\n    this.listMultiKeySelected.set(undefined);\n    this.keysSelected.set([]);\n    this.error.set(undefined);\n  }\n\n  private async buildDisplay() {\n    if (this.itemsSelected()) {\n      this.convertItemSelected()(this.itemsSelected(), this.translate);\n      const getPopoverItemSelected = this.getPopoverItemSelected();\n      if (getPopoverItemSelected) {\n        this.popoverItemSelected.set(await getPopoverItemSelected(this.itemsSelected, this.translate));\n      }\n    }\n  }\n\n  private mergeFlagMouse() {\n    const flag: IFlagMouse = { isMouseEnter: false, isMouseEnterContent: false, isContainerHasScroll: false };\n    if (this.flagMouseContent()?.isMouseEnter || this.flagMouse().isMouseEnter) {\n      flag.isMouseEnter = true;\n    }\n    if (this.flagMouseContent()?.isMouseEnterContent || this.flagMouse().isMouseEnterContent) {\n      flag.isMouseEnterContent = true;\n    }\n    if (this.flagMouseContent()?.isContainerHasScroll || this.flagMouse().isContainerHasScroll) {\n      flag.isContainerHasScroll = true;\n    }\n    this.outChangStageFlagMouse.emit(flag);\n  }\n}\n","<div class=\"flex flex-col w-full\">\n  @if (labelConfig(); as label) {\n    <libs_ui-components-label\n      [classInclude]=\"label.classInclude\"\n      [labelLeft]=\"label.labelLeft\"\n      [labelLeftClass]=\"label.labelLeftClass\"\n      [required]=\"label.required\"\n      [description]=\"label.description\"\n      [descriptionClass]=\"label.descriptionClass\"\n      [labelRight]=\"label.labelRight\"\n      [labelRightClass]=\"label.labelRightClass\"\n      [onlyShowCount]=\"label.onlyShowCount\"\n      [buttonsLeft]=\"label.buttonsLeft\"\n      [buttonsRight]=\"label.buttonsRight\"\n      [disableButtonsLeft]=\"label.disableButtonsLeft || disable() || loadingDetail()\"\n      [disableButtonsRight]=\"label.disableButtonsRight || disable() || loadingDetail()\"\n      [hasToggle]=\"label.hasToggle\"\n      [toggleActive]=\"label.toggleActive\"\n      [toggleDisable]=\"label.toggleDisable || disable() || loadingDetail()\"\n      [popover]=\"label.popover\"\n      [iconPopoverClass]=\"label.iconPopoverClass\"\n      [onlyShowCount]=\"label.onlyShowCount\"\n      [limitLength]=\"label.limitLength\"\n      [buttonsDescription]=\"label.buttonsDescription\"\n      [disableButtonsDescription]=\"label.disableButtonsDescription || disable()\"\n      [buttonsDescriptionContainerClass]=\"label.buttonsDescriptionContainerClass\"\n      [count]=\"label.count\" />\n  }\n  <libs_ui-components-popover\n    [ignoreShowPopover]=\"disable() || readonly() || loadingDetail()\"\n    [class]=\"classInclude() || 'w-full'\"\n    [mode]=\"'click-toggle'\"\n    [flagMouse]=\"flagMouse()\"\n    [ignoreHiddenPopoverContentWhenMouseLeave]=\"true\"\n    [ignoreCursorPointerModeLikeClick]=\"true\"\n    [ignoreStopPropagationEvent]=\"ignoreStopPropagationEvent()\"\n    [elementRefCustom]=\"popoverElementRefCustom()\"\n    [config]=\"{\n      animationConfig: popoverCustomConfig()?.animationConfig || {},\n      zIndex: zIndex() ?? 1000,\n      widthByParent: popoverCustomConfig()?.widthByParent ?? true,\n      parentBorderWidth: popoverCustomConfig()?.parentBorderWidth ?? 0,\n      maxHeight: popoverCustomConfig()?.maxHeight ?? 2048,\n      maxWidth: popoverCustomConfig()?.maxWidth ?? 2048,\n      direction: popoverCustomConfig()?.direction ?? 'bottom',\n      template: listViewEl,\n      whiteTheme: true,\n      timerDestroy: popoverCustomConfig()?.timerDestroy ?? 0,\n      ignoreArrow: popoverCustomConfig()?.ignoreArrow ?? true,\n      directionDistance: 2,\n      classInclude: '!rounded-[4px] overflow-hidden ' + (popoverCustomConfig()?.classInclude ?? 'libs-ui-border-general '),\n      position: popoverCustomConfig()?.position || { mode: 'start', distance: 0 },\n      width: popoverCustomConfig()?.width,\n      classIncludeOverlayBody: popoverCustomConfig()?.classIncludeOverlayBody,\n    }\"\n    (outFunctionsControl)=\"handlerPopoverControlEvent($event)\"\n    (outEvent)=\"handlerEvent($event)\"\n    (outChangStageFlagMouse)=\"handlerChangeFlagMouse($event)\">\n    @if (!isNgContent()) {\n      <div\n        [class]=\"'libs-ui-dropdown ' + (classIncludeContent() || '')\"\n        [class.libs-ui-border-general]=\"!error() && !showBorderError() && !showList()\"\n        [class.libs-ui-border-primary-focus-general]=\"!error() && !showBorderError() && showList()\"\n        [class.libs-ui-border-error-general]=\"error() || showBorderError()\"\n        [class.libs-ui-readonly]=\"readonly()\"\n        [class.libs-ui-readonly-background]=\"readonly()\"\n        [class.cursor-pointer]=\"!(disable() || loadingDetail() || readonly())\"\n        [class.libs-ui-disable]=\"disable() || loadingDetail()\"\n        [class.libs-ui-disable-background]=\"disable() || loadingDetail()\"\n        [class.pointer-events-none]=\"loadingDetail()\"\n        [class.rounded-tr-0]=\"hasContentUnitRight()\"\n        [class.rounded-br-0]=\"hasContentUnitRight()\">\n        <div class=\"flex items-center w-full\">\n          <div class=\"flex items-center w-full relative\">\n            <div\n              class=\"flex items-center w-full absolute\"\n              [class.libs-ui-dropdown-placeholder]=\"!lengthKeys()\">\n              @if (lengthKeys() === 1) {\n                @if (itemsSelected(); as itemsSelected) {\n                  @if (fieldGetImage(); as fieldGetImage) {\n                    <libs_ui-components-avatar\n                      [classInclude]=\"classAvatarInclude()\"\n                      [typeShape]=\"typeShape()\"\n                      [size]=\"imageSize()\"\n                      [linkAvatar]=\"itemsSelected[fieldGetImage]\"\n                      [linkAvatarError]=\"linkImageError()\"\n                      [idGenColor]=\"itemsSelected[fieldGetColorAvatar() || fieldGetTextAvatar()]\"\n                      [getLastTextAfterSpace]=\"getLastTextAfterSpace()\"\n                      [textAvatar]=\"itemsSelected[fieldGetTextAvatar()]\" />\n                  }\n                  @if (fieldGetIcon(); as fieldGetIcon) {\n                    <i [class]=\"itemsSelected[fieldGetIcon] + ' mr-[8px]'\"></i>\n                  }\n                }\n              }\n              <libs_ui-components-popover\n                [type]=\"'text'\"\n                [classInclude]=\"(labelPopoverFullWidth() ? 'w-100 ' : '') + classIncludeTextDisplayWhenNoSelect()\"\n                [innerHTML]=\"labelItemSelectedComputed() | translate: { value: lengthKeys() } | LibsUiPipesSecurityTrustPipe: 'html' : useXssFilter() | async\"\n                [config]=\"{ maxWidth: labelPopoverConfig()?.maxWidth || 250, direction: 'top', zIndex: labelPopoverConfig()?.zIndex, timerDestroy: labelPopoverConfig()?.timerDestroy || 0 }\"\n                [ignoreStopPropagationEvent]=\"true\" />\n\n              @if (popoverItemSelected(); as popoverItemSelected) {\n                <libs_ui-components-popover\n                  [type]=\"popoverItemSelected.type || 'other'\"\n                  [config]=\"popoverItemSelected.config || {}\">\n                  @if (popoverItemSelected.dataView) {\n                    <div [innerHtml]=\"popoverItemSelected.dataView | translate\"></div>\n                  } @else {\n                    <i class=\"libs-ui-icon-tooltip-outline text-[16px] mx-[8px]\"></i>\n                  }\n                </libs_ui-components-popover>\n              }\n            </div>\n          </div>\n          <i\n            class=\"text-[16px] libs-ui-icon-move-right rotate-90 text-[#6a7383] {{ classIncludeIcon() }}\"\n            [class.libs-ui-disable]=\"readonly() || disable()\"></i>\n        </div>\n      </div>\n    } @else {\n      <ng-content></ng-content>\n    }\n  </libs_ui-components-popover>\n  @if (showError()) {\n    @if (error(); as error) {\n      @let constHtmlMessage = error.message || ' ';\n      <div\n        class=\"mt-[8px] libs-ui-text-error libs-ui-font-h7r\"\n        [innerHtml]=\"constHtmlMessage | translate: error.interpolateParams || {}\"></div>\n    }\n  }\n</div>\n<ng-template #listViewEl>\n  <div\n    style=\"display: flex; flex-direction: column\"\n    [class.h-full]=\"listMaxItemShow() === -1\">\n    @if (tabsConfig(); as tabsConfig) {\n      <libs_ui-components-dropdown-tabs\n        [tabsConfig]=\"tabsConfig\"\n        [(tabKeyActive)]=\"tabKeyActive\"\n        [ignoreBorderBottom]=\"ignoreBorderBottom()\"\n        [disable]=\"disable() || loadingDetail() || loadingList()\"\n        (outChange)=\"handlerChangeTab()\" />\n    }\n    <libs_ui-components-list\n      [class.h-full]=\"listMaxItemShow() === -1\"\n      [searchConfig]=\"listSearchConfig()\"\n      [isSearchOnline]=\"isSearchOnline()\"\n      [dropdownTabKeyActive]=\"tabKeyActive()\"\n      [keySearch]=\"listKeySearch()\"\n      [config]=\"listConfig()\"\n      [autoSelectedFirstItemCallOutsideBefore]=\"autoSelectedFirstItemCallOutsideBefore()\"\n      [paddingLeftItem]=\"popoverCustomConfig()?.paddingLeftItem ?? false\"\n      [disable]=\"disable() || loadingDetail()\"\n      [disableLabel]=\"disableLabel()\"\n      [hiddenInputSearch]=\"listHiddenInputSearch()\"\n      [searchPadding]=\"listSearchPadding()\"\n      [maxItemShow]=\"listMaxItemShow()\"\n      [keySelected]=\"listKeySelected()\"\n      [multiKeySelected]=\"listMultiKeySelected()\"\n      [clickExactly]=\"popoverCustomConfig()?.clickExactly ?? false\"\n      [dividerClassInclude]=\"listSearchConfig() ? listDividerClassInclude() : 'hidden'\"\n      [buttonsOther]=\"listButtonsOther()\"\n      [backgroundListCustom]=\"listBackgroundCustom()\"\n      [keysDisableItem]=\"listKeysDisable()\"\n      [keysHiddenItem]=\"listKeysHidden()\"\n      [hasButtonUnSelectOption]=\"listHasButtonUnSelectOption() ?? (!popoverCustomConfig() && !labelConfig()?.required && (listConfig()?.type === 'text' || listConfig()?.type === 'radio'))\"\n      [templateRefSearchNoData]=\"listSearchNoDataTemplateRef()\"\n      [focusInputSearch]=\"focusInputSearch()\"\n      [zIndex]=\"zIndex()\"\n      [resetKeyWhenSelectAllKeyDropdown]=\"resetKeyWhenSelectAllKey()\"\n      [ignoreClassDisableDefaultWhenUseKeysDisableItem]=\"listIgnoreClassDisableDefaultWhenUseKeysDisableItem()\"\n      [hasDivider]=\"listConfigHasDivider()\"\n      (outSelectKey)=\"handlerSelectedKey($event)\"\n      (outSelectMultiKey)=\"handlerSelectMultiKey($event, true)\"\n      (outChangeView)=\"handlerDataChange($event)\"\n      (outClickButtonOther)=\"handlerClickButtonOther($event)\"\n      (outFunctionsControl)=\"handlerListFunctionsControl($event)\"\n      (outChangStageFlagMousePopover)=\"handlerChangStageFlagMouse($event)\"\n      (outLoading)=\"handlerLoadingList($event)\" />\n  </div>\n</ng-template>\n"]}