@libs-ui/components-tabs 0.2.356-25 → 0.2.356-26
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/esm2022/interfaces/tab.interface.mjs +1 -1
- package/esm2022/item/item.component.mjs +25 -3
- package/esm2022/tabs.component.mjs +184 -7
- package/fesm2022/libs-ui-components-tabs.mjs +207 -8
- package/fesm2022/libs-ui-components-tabs.mjs.map +1 -1
- package/interfaces/tab.interface.d.ts +1 -0
- package/item/item.component.d.ts +8 -3
- package/package.json +10 -10
- package/tabs.component.d.ts +33 -3
|
@@ -1,4 +1,5 @@
|
|
|
1
|
-
import { ChangeDetectionStrategy, Component, computed, effect, inject, input, model, output, signal, untracked, viewChild } from '@angular/core';
|
|
1
|
+
import { ChangeDetectionStrategy, Component, computed, DestroyRef, effect, inject, input, model, output, signal, untracked, viewChild } from '@angular/core';
|
|
2
|
+
import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
|
|
2
3
|
import { LibsUiComponentsButtonsButtonComponent } from '@libs-ui/components-buttons-button';
|
|
3
4
|
import { LibsUiComponentsDragContainerDirective, LibsUiDragItemDirective } from '@libs-ui/components-drag-drop';
|
|
4
5
|
import { LibsUiComponentsListComponent } from '@libs-ui/components-list';
|
|
@@ -18,8 +19,24 @@ export class LibsUiComponentsTabsComponent {
|
|
|
18
19
|
changeViewTab = new Subject();
|
|
19
20
|
groupName = signal(uuid());
|
|
20
21
|
stylesDragDropOverrideComputed = computed(() => this.updateStylesDragDropOverride());
|
|
22
|
+
/**
|
|
23
|
+
* V2 — số item đang hiển thị (specificDisplay !== false). Dùng cho mode `space-between`
|
|
24
|
+
* tính width đều cho các item visible (item hidden ở `position: absolute` không chiếm chỗ).
|
|
25
|
+
*/
|
|
26
|
+
displayedCount = computed(() => {
|
|
27
|
+
if (!this.useCalculatorV2())
|
|
28
|
+
return this.itemsDisplay().length || 1;
|
|
29
|
+
const count = this.itemsDisplay().filter((s) => s().specificDisplay !== false).length;
|
|
30
|
+
return count || 1;
|
|
31
|
+
});
|
|
32
|
+
/** V2 — kích thước container do ResizeObserver cập nhật, dùng để compute synchronous. */
|
|
33
|
+
containerWidthV2 = signal(0);
|
|
34
|
+
headerLeftWidthV2 = signal(0);
|
|
35
|
+
headerRightWidthV2 = signal(0);
|
|
36
|
+
resizeObserverV2;
|
|
21
37
|
popoverFunctionControlEvent = signal(undefined);
|
|
22
38
|
onDestroy = new Subject();
|
|
39
|
+
destroyRef = inject(DestroyRef);
|
|
23
40
|
// #region INPUT
|
|
24
41
|
tabs = input.required();
|
|
25
42
|
keySelected = model.required();
|
|
@@ -37,6 +54,14 @@ export class LibsUiComponentsTabsComponent {
|
|
|
37
54
|
popoverShowMoreTabItem = input();
|
|
38
55
|
checkCanChangeTabSelected = input();
|
|
39
56
|
useEffectUpdateItems = input();
|
|
57
|
+
/**
|
|
58
|
+
* V2 mode — khi `true`:
|
|
59
|
+
* - Bỏ container đo song song (không render 2 lần).
|
|
60
|
+
* - Dùng ResizeObserver thay MutationObserver/setTimeout/debounce.
|
|
61
|
+
* - Compute synchronous, không reorder items → không flicker.
|
|
62
|
+
* Mặc định `false` để giữ 100% behavior cũ (backward compatible).
|
|
63
|
+
*/
|
|
64
|
+
useCalculatorV2 = input(false);
|
|
40
65
|
// #region OUTPUT
|
|
41
66
|
outKeySelected = output();
|
|
42
67
|
outFunctionsControl = output();
|
|
@@ -58,6 +83,20 @@ export class LibsUiComponentsTabsComponent {
|
|
|
58
83
|
this.updateItemsDisplay(items);
|
|
59
84
|
});
|
|
60
85
|
});
|
|
86
|
+
// V2 — effect tự động recompute khi container/headerLeft/headerRight đổi kích thước hoặc selected đổi.
|
|
87
|
+
effect(() => {
|
|
88
|
+
if (!this.useCalculatorV2())
|
|
89
|
+
return;
|
|
90
|
+
const containerWidth = this.containerWidthV2();
|
|
91
|
+
// Đọc cả các signal phụ thuộc để effect tự re-run khi chúng đổi.
|
|
92
|
+
this.headerLeftWidthV2();
|
|
93
|
+
this.headerRightWidthV2();
|
|
94
|
+
this.keySelected();
|
|
95
|
+
const items = this.tabs()?.items();
|
|
96
|
+
if (!containerWidth || !items?.length)
|
|
97
|
+
return;
|
|
98
|
+
untracked(() => this.computeDisplayItemsV2(items));
|
|
99
|
+
});
|
|
61
100
|
}
|
|
62
101
|
ngOnInit() {
|
|
63
102
|
this.updateTabsCssConfig();
|
|
@@ -71,10 +110,67 @@ export class LibsUiComponentsTabsComponent {
|
|
|
71
110
|
if (!this.tabs().items().length) {
|
|
72
111
|
return;
|
|
73
112
|
}
|
|
113
|
+
// V2 không cần xử lý resize ở đây — ResizeObserver tự fire.
|
|
114
|
+
if (this.useCalculatorV2()) {
|
|
115
|
+
return;
|
|
116
|
+
}
|
|
74
117
|
this.displayMoreItem.set(false);
|
|
75
118
|
this.calculatorTabsItemDisplay();
|
|
76
119
|
});
|
|
77
|
-
|
|
120
|
+
// V1 path: preserve old behavior với debounce(20).
|
|
121
|
+
this.changeViewTab.pipe(debounceTime(20), takeUntil(this.onDestroy)).subscribe(() => {
|
|
122
|
+
if (this.useCalculatorV2())
|
|
123
|
+
return;
|
|
124
|
+
this.calculatorTabsItemDisplay();
|
|
125
|
+
});
|
|
126
|
+
// V2 path: chạy sync (không debounce) — ResizeObserver đã batch theo frame.
|
|
127
|
+
this.changeViewTab.pipe(takeUntilDestroyed(this.destroyRef)).subscribe(() => {
|
|
128
|
+
if (!this.useCalculatorV2())
|
|
129
|
+
return;
|
|
130
|
+
const items = this.tabs()?.items();
|
|
131
|
+
if (items?.length)
|
|
132
|
+
this.computeDisplayItemsV2(items);
|
|
133
|
+
});
|
|
134
|
+
}
|
|
135
|
+
ngAfterViewInit() {
|
|
136
|
+
if (this.useCalculatorV2()) {
|
|
137
|
+
this.setupResizeObserverV2();
|
|
138
|
+
}
|
|
139
|
+
}
|
|
140
|
+
setupResizeObserverV2() {
|
|
141
|
+
if (this.resizeObserverV2 || typeof ResizeObserver === 'undefined') {
|
|
142
|
+
return;
|
|
143
|
+
}
|
|
144
|
+
const headerEl = this.headerEl()?.nativeElement;
|
|
145
|
+
const headerLeftEl = this.headerLeftEl()?.nativeElement;
|
|
146
|
+
const headerRightEl = this.headerRightEl()?.nativeElement;
|
|
147
|
+
if (!headerEl)
|
|
148
|
+
return;
|
|
149
|
+
this.resizeObserverV2 = new ResizeObserver((entries) => {
|
|
150
|
+
for (const entry of entries) {
|
|
151
|
+
const target = entry.target;
|
|
152
|
+
const width = target.clientWidth || 0;
|
|
153
|
+
switch (target) {
|
|
154
|
+
case headerEl:
|
|
155
|
+
if (this.containerWidthV2() !== width)
|
|
156
|
+
this.containerWidthV2.set(width);
|
|
157
|
+
break;
|
|
158
|
+
case headerLeftEl:
|
|
159
|
+
if (this.headerLeftWidthV2() !== width)
|
|
160
|
+
this.headerLeftWidthV2.set(width);
|
|
161
|
+
break;
|
|
162
|
+
case headerRightEl:
|
|
163
|
+
if (this.headerRightWidthV2() !== width)
|
|
164
|
+
this.headerRightWidthV2.set(width);
|
|
165
|
+
break;
|
|
166
|
+
}
|
|
167
|
+
}
|
|
168
|
+
});
|
|
169
|
+
this.resizeObserverV2.observe(headerEl);
|
|
170
|
+
if (headerLeftEl)
|
|
171
|
+
this.resizeObserverV2.observe(headerLeftEl);
|
|
172
|
+
if (headerRightEl)
|
|
173
|
+
this.resizeObserverV2.observe(headerRightEl);
|
|
78
174
|
}
|
|
79
175
|
updateItemsDisplay(items) {
|
|
80
176
|
if (!items)
|
|
@@ -85,6 +181,16 @@ export class LibsUiComponentsTabsComponent {
|
|
|
85
181
|
this.itemsDisplay.set(items);
|
|
86
182
|
return;
|
|
87
183
|
}
|
|
184
|
+
if (this.useCalculatorV2()) {
|
|
185
|
+
// V2: itemsDisplay chứa toàn bộ items (không filter). ResizeObserver sẽ đo width
|
|
186
|
+
// và compute sẽ set specificDisplay flag — style binding ẩn item overflow.
|
|
187
|
+
items.forEach((item) => item.update((data) => ({ ...data, specificDisplay: true })));
|
|
188
|
+
this.itemsDisplay.set([...items]);
|
|
189
|
+
if (this.containerWidthV2()) {
|
|
190
|
+
this.computeDisplayItemsV2(items);
|
|
191
|
+
}
|
|
192
|
+
return;
|
|
193
|
+
}
|
|
88
194
|
this.calculatorTabsItemDisplay();
|
|
89
195
|
});
|
|
90
196
|
}
|
|
@@ -92,7 +198,7 @@ export class LibsUiComponentsTabsComponent {
|
|
|
92
198
|
get FunctionsControl() {
|
|
93
199
|
return {
|
|
94
200
|
addTabsItem: this.addTabsItem.bind(this),
|
|
95
|
-
calculatorTabsItemsDisplay: this.
|
|
201
|
+
calculatorTabsItemsDisplay: this.calculatorTabsItemDisplayDispatch.bind(this),
|
|
96
202
|
selectedTabsItem: this.handlerSelectedTabsItem.bind(this),
|
|
97
203
|
};
|
|
98
204
|
}
|
|
@@ -216,7 +322,7 @@ export class LibsUiComponentsTabsComponent {
|
|
|
216
322
|
this.keySelected.set(item()[this.fieldKey()]);
|
|
217
323
|
this.outKeySelected.emit(this.keySelected());
|
|
218
324
|
this.popoverFunctionControlEvent()?.removePopoverOverlay();
|
|
219
|
-
this.
|
|
325
|
+
this.calculatorTabsItemDisplayDispatch();
|
|
220
326
|
}
|
|
221
327
|
async handlerAction(event) {
|
|
222
328
|
this.outAction.emit(event);
|
|
@@ -237,6 +343,16 @@ export class LibsUiComponentsTabsComponent {
|
|
|
237
343
|
this.handlerClickItem(item);
|
|
238
344
|
}
|
|
239
345
|
}
|
|
346
|
+
/** Dispatch sang nhánh V1 hoặc V2 dựa theo flag. Public API giữ nguyên signature. */
|
|
347
|
+
async calculatorTabsItemDisplayDispatch() {
|
|
348
|
+
if (this.useCalculatorV2()) {
|
|
349
|
+
const items = this.tabs()?.items();
|
|
350
|
+
if (items?.length)
|
|
351
|
+
this.computeDisplayItemsV2(items);
|
|
352
|
+
return;
|
|
353
|
+
}
|
|
354
|
+
await this.calculatorTabsItemDisplay();
|
|
355
|
+
}
|
|
240
356
|
async calculatorTabsItemDisplay() {
|
|
241
357
|
let items = this.tabs().items();
|
|
242
358
|
const indexItemSelected = items.findIndex((item) => item()[this.fieldKey()] === this.keySelected());
|
|
@@ -281,15 +397,76 @@ export class LibsUiComponentsTabsComponent {
|
|
|
281
397
|
.filter((item) => item().specificDisplay);
|
|
282
398
|
this.itemsDisplay.set(newItemsDisplay);
|
|
283
399
|
}
|
|
400
|
+
/**
|
|
401
|
+
* V2 — Tính displayItems synchronous, không reorder, không setTimeout.
|
|
402
|
+
*
|
|
403
|
+
* Why: tránh flicker do reorder DOM + bỏ thuật toán "cảm tính" debounce.
|
|
404
|
+
* How to apply: gọi mỗi khi container width / headerLeft / headerRight / item widths / selected key đổi.
|
|
405
|
+
*/
|
|
406
|
+
computeDisplayItemsV2(items) {
|
|
407
|
+
if (this.mode() !== 'left' || this.ignoreCalculatorTab()) {
|
|
408
|
+
items.forEach((item) => item.update((data) => ({ ...data, specificDisplay: true })));
|
|
409
|
+
this.itemsDisplay.set([...items]);
|
|
410
|
+
this.displayMoreItem.set(false);
|
|
411
|
+
this.outDisplayMoreItem.emit(false);
|
|
412
|
+
return;
|
|
413
|
+
}
|
|
414
|
+
const headerWidth = this.containerWidthV2();
|
|
415
|
+
if (!headerWidth)
|
|
416
|
+
return;
|
|
417
|
+
const indexItemSelected = items.findIndex((item) => item()[this.fieldKey()] === this.keySelected());
|
|
418
|
+
if (indexItemSelected < 0)
|
|
419
|
+
return;
|
|
420
|
+
const itemSelected = items[indexItemSelected];
|
|
421
|
+
const itemSelectedWidth = itemSelected().specificWidth || 0;
|
|
422
|
+
const reservedWidth = this.headerLeftWidthV2() + this.headerRightWidthV2() + 32;
|
|
423
|
+
let totalWidth = reservedWidth;
|
|
424
|
+
let displayMoreItem = false;
|
|
425
|
+
items.forEach((item, index) => {
|
|
426
|
+
const itemWidth = item().specificWidth || 0;
|
|
427
|
+
if (!itemWidth) {
|
|
428
|
+
// Chưa có width — tạm hiển thị để ResizeObserver có element mà đo.
|
|
429
|
+
item.update((data) => ({ ...data, specificDisplay: true }));
|
|
430
|
+
return;
|
|
431
|
+
}
|
|
432
|
+
// Reserve space cho selected nếu item này nằm trước selected.
|
|
433
|
+
const projected = totalWidth + itemWidth + (index < indexItemSelected ? itemSelectedWidth : 0);
|
|
434
|
+
totalWidth += itemWidth;
|
|
435
|
+
if (projected > headerWidth) {
|
|
436
|
+
item.update((data) => ({ ...data, specificDisplay: false }));
|
|
437
|
+
displayMoreItem = true;
|
|
438
|
+
return;
|
|
439
|
+
}
|
|
440
|
+
item.update((data) => ({ ...data, specificDisplay: true }));
|
|
441
|
+
});
|
|
442
|
+
// Selected luôn hiển thị.
|
|
443
|
+
itemSelected.update((data) => ({ ...data, specificDisplay: true }));
|
|
444
|
+
// V2: itemsDisplay chứa TẤT CẢ items — không filter. Item overflow được ẩn qua style binding
|
|
445
|
+
// (visibility: hidden + position: absolute) để giữ DOM stable, tránh mount/unmount gây flicker.
|
|
446
|
+
// ResizeObserver luôn đo được width vì mọi item luôn có DOM.
|
|
447
|
+
const allItems = [...items];
|
|
448
|
+
const currentDisplay = this.itemsDisplay();
|
|
449
|
+
// Chỉ set khi nội dung array thực sự đổi (tránh CD thừa).
|
|
450
|
+
const arrayChanged = allItems.length !== currentDisplay.length || allItems.some((it, i) => it !== currentDisplay[i]);
|
|
451
|
+
if (arrayChanged) {
|
|
452
|
+
this.itemsDisplay.set(allItems);
|
|
453
|
+
}
|
|
454
|
+
if (this.displayMoreItem() !== displayMoreItem) {
|
|
455
|
+
this.displayMoreItem.set(displayMoreItem);
|
|
456
|
+
this.outDisplayMoreItem.emit(displayMoreItem);
|
|
457
|
+
}
|
|
458
|
+
}
|
|
284
459
|
ngOnDestroy() {
|
|
460
|
+
this.resizeObserverV2?.disconnect();
|
|
461
|
+
this.resizeObserverV2 = undefined;
|
|
285
462
|
this.onDestroy.next();
|
|
286
463
|
this.onDestroy.complete();
|
|
287
464
|
}
|
|
288
465
|
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: LibsUiComponentsTabsComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
289
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.14", type: LibsUiComponentsTabsComponent, isStandalone: true, selector: "libs_ui-components-tabs", inputs: { tabs: { classPropertyName: "tabs", publicName: "tabs", isSignal: true, isRequired: true, transformFunction: null }, keySelected: { classPropertyName: "keySelected", publicName: "keySelected", isSignal: true, isRequired: true, transformFunction: null }, mode: { classPropertyName: "mode", publicName: "mode", isSignal: true, isRequired: false, transformFunction: null }, fieldKey: { classPropertyName: "fieldKey", publicName: "fieldKey", isSignal: true, isRequired: false, transformFunction: null }, fieldLabel: { classPropertyName: "fieldLabel", publicName: "fieldLabel", isSignal: true, isRequired: false, transformFunction: null }, disable: { classPropertyName: "disable", publicName: "disable", isSignal: true, isRequired: false, transformFunction: null }, disableLabel: { classPropertyName: "disableLabel", publicName: "disableLabel", isSignal: true, isRequired: false, transformFunction: null }, heightTabItem: { classPropertyName: "heightTabItem", publicName: "heightTabItem", isSignal: true, isRequired: false, transformFunction: null }, ignoreCalculatorTab: { classPropertyName: "ignoreCalculatorTab", publicName: "ignoreCalculatorTab", isSignal: true, isRequired: false, transformFunction: null }, size: { classPropertyName: "size", publicName: "size", isSignal: true, isRequired: false, transformFunction: null }, allowDragDropPosition: { classPropertyName: "allowDragDropPosition", publicName: "allowDragDropPosition", isSignal: true, isRequired: false, transformFunction: null }, zIndex: { classPropertyName: "zIndex", publicName: "zIndex", isSignal: true, isRequired: false, transformFunction: null }, configCss: { classPropertyName: "configCss", publicName: "configCss", isSignal: true, isRequired: false, transformFunction: null }, popoverShowMoreTabItem: { classPropertyName: "popoverShowMoreTabItem", publicName: "popoverShowMoreTabItem", isSignal: true, isRequired: false, transformFunction: null }, checkCanChangeTabSelected: { classPropertyName: "checkCanChangeTabSelected", publicName: "checkCanChangeTabSelected", isSignal: true, isRequired: false, transformFunction: null }, useEffectUpdateItems: { classPropertyName: "useEffectUpdateItems", publicName: "useEffectUpdateItems", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { keySelected: "keySelectedChange", configCss: "configCssChange", outKeySelected: "outKeySelected", outFunctionsControl: "outFunctionsControl", outDragTabChange: "outDragTabChange", outDisplayMoreItem: "outDisplayMoreItem", outAction: "outAction" }, viewQueries: [{ propertyName: "headerEl", first: true, predicate: ["headerEl"], descendants: true, isSignal: true }, { propertyName: "headerLeftEl", first: true, predicate: ["headerLeftEl"], descendants: true, isSignal: true }, { propertyName: "headerRightEl", first: true, predicate: ["headerRightEl"], descendants: true, isSignal: true }], ngImport: i0, template: "<div class=\"libs-ui-tab\">\n <div\n #headerEl\n class=\"libs-ui-tab-header z-[1] {{ configCss()?.header || '' }} {{ tabs().classIncludeHeader || '' }}\"\n [style.minHeight.px]=\"heightTabItem()\">\n <div\n #headerLeftEl\n class=\"libs-ui-tab-header-left\">\n <ng-content select=\"div.libs-ui-tab-header-left\"></ng-content>\n </div>\n <div class=\"libs-ui-tab-header-center {{ configCss()?.headerCenter || '' }} {{ tabs().classIncludeHeaderCenter || '' }}\">\n <div\n class=\"!flex w-full\"\n #elementContainerEl\n LibsUiComponentsDragContainerDirective\n [stylesOverride]=\"stylesDragDropOverrideComputed()\"\n [groupName]=\"groupName()\"\n [(items)]=\"itemsDisplay\"\n [directionDrag]=\"'horizontal'\"\n [disableDragContainer]=\"!allowDragDropPosition()\"\n [acceptDragSameGroup]=\"allowDragDropPosition()\"\n (outDroppedContainer)=\"handlerDropContainer($event)\">\n @for (item of itemsDisplay(); track item) {\n <div\n LibsUiDragItemDirective\n [disable]=\"disable() || !allowDragDropPosition()\"\n [elementContainer]=\"elementContainerEl\"\n [dragBoundary]=\"true\"\n [dragBoundaryAcceptMouseLeaveContainer]=\"true\"\n class=\"relative libs-ui-tab-item-container\"\n [style.width.px]=\"mode() === 'space-between' ? elementContainerEl.clientWidth / (itemsDisplay().length || 1) : undefined\"\n [class.flex]=\"mode() === 'center-has-line'\"\n [class.items-center]=\"mode() === 'center-has-line'\">\n @if (allowDragDropPosition() && !disable()) {\n <span class=\"libs-ui-icon-arrange text-[#9ca2ad] absolute top-[14px] left-[4px]\"></span>\n }\n <libs_ui-components-tabs-item\n class=\"h-full w-full {{ tabs().classIncludeItem || '' }}\"\n [tabs]=\"tabs()\"\n [size]=\"size()\"\n [(item)]=\"item\"\n [step]=\"$index + 1\"\n [class.!pointer-events-none]=\"item().disable || disable()\"\n [disable]=\"item().disable || disable()\"\n [disableLabel]=\"disableLabel()\"\n [keySelected]=\"keySelected()\"\n [fieldLabel]=\"fieldLabel()\"\n [fieldKey]=\"fieldKey()\"\n [cssDefault]=\"($first ? configCss()?.first : configCss()?.other) || ''\"\n [zIndex]=\"zIndex()\"\n [mode]=\"mode()\"\n [ignoreCalculatorTab]=\"true\"\n [changeViewTab]=\"changeViewTab\"\n (click)=\"handlerClickItem(item)\"\n (outAction)=\"handlerAction($event)\" />\n @if (mode() === 'center-has-line' && !$last) {\n <div class=\"w-[40px] h-[1px] bg-[#e6e7ea]\"></div>\n }\n </div>\n }\n </div>\n </div>\n <div\n class=\"flex items-center\"\n [class.ml-auto]=\"displayMoreItem() && !tabs().viewMoreIgnoreMarginLeft\">\n @if (displayMoreItem()) {\n <libs_ui-components-popover\n class=\"w-full h-full flex items-center\"\n [mode]=\"'click-toggle'\"\n [ignoreHiddenPopoverContentWhenMouseLeave]=\"true\"\n [config]=\"{\n zIndex: popoverShowMoreTabItem()?.config?.zIndex || 1000,\n maxHeight: popoverShowMoreTabItem()?.config?.maxHeight || 287,\n maxWidth: popoverShowMoreTabItem()?.config?.maxWidth || 2048,\n width: popoverShowMoreTabItem()?.config?.width || 277,\n direction: popoverShowMoreTabItem()?.config?.direction || 'bottom',\n template: popoverShowMoreTabItem()?.config?.template || menuEl,\n whiteTheme: true,\n ignoreArrow: true,\n position: popoverShowMoreTabItem()?.config?.position || { mode: 'end', distance: 0 },\n }\"\n (outFunctionsControl)=\"handlerPopoverFunctionControlEvent($event)\">\n <libs_ui-components-buttons-button\n [type]=\"'button-link-third'\"\n [classInclude]=\"'!p-[8px]'\"\n [iconOnlyType]=\"true\"\n [classIconLeft]=\"'libs-ui-icon-more-vertical rotate-90 text-[16px] mr-0'\"\n [popover]=\"{ config: { content: popoverShowMoreTabItem()?.config?.content || 'i18n_view_more' } }\"\n [ignoreStopPropagationEvent]=\"true\" />\n </libs_ui-components-popover>\n }\n </div>\n <div\n #headerRightEl\n class=\"libs-ui-tab-header-right {{ tabs().classIncludeHeaderRight || '' }}\">\n <ng-content select=\"div.libs-ui-tab-header-right\"></ng-content>\n </div>\n </div>\n <div class=\"absolute top-0 z-0 w-full\">\n <div\n class=\"libs-ui-tab-header {{ configCss()?.header || '' }} {{ tabs().classIncludeHeader || '' }}\"\n [style.minHeight.px]=\"heightTabItem()\">\n <div class=\"libs-ui-tab-header-center {{ configCss()?.headerCenter || '' }} {{ tabs().classIncludeHeaderCenter || '' }}\">\n @for (item of tabs().items(); track item) {\n <libs_ui-components-tabs-item\n class=\"h-full w-full {{ tabs().classIncludeItem || '' }}\"\n [tabs]=\"tabs()\"\n [size]=\"size()\"\n [(item)]=\"item\"\n [step]=\"$index + 1\"\n [disable]=\"disable()\"\n [disableLabel]=\"disableLabel()\"\n [keySelected]=\"keySelected()\"\n [fieldLabel]=\"fieldLabel()\"\n [fieldKey]=\"fieldKey()\"\n [cssDefault]=\"($first ? configCss()?.first : configCss()?.other) || ''\"\n [zIndex]=\"zIndex()\"\n [mode]=\"mode()\"\n [changeViewTab]=\"changeViewTab\"\n [ignoreCalculatorTab]=\"ignoreCalculatorTab()\" />\n }\n </div>\n </div>\n </div>\n</div>\n<ng-template #menuEl>\n <libs_ui-components-list\n [config]=\"tabMoreListConfig()\"\n [maxItemShow]=\"5\"\n [hiddenInputSearch]=\"true\"\n [paddingLeftItem]=\"true\"\n (outSelectKey)=\"handlerSelectedKey($event)\" />\n</ng-template>\n", styles: [".libs-ui-tab{position:relative;display:flex;width:100%}.libs-ui-tab .libs-ui-tab-header{position:relative;background-color:#fff;display:flex;flex-wrap:nowrap;width:100%;overflow:hidden;flex-shrink:0}.libs-ui-tab .libs-ui-tab-header .libs-ui-tab-header-center{display:flex;flex-wrap:nowrap}.libs-ui-tab .libs-ui-tab-header .libs-ui-tab-item-container .libs-ui-icon-arrange{display:none}.libs-ui-tab .libs-ui-tab-header .libs-ui-tab-item-container:hover .libs-ui-icon-arrange{display:block}.libs-ui-tab .libs-ui-tab-content-container{width:100%;height:100%}\n"], dependencies: [{ kind: "directive", type: LibsUiComponentsDragContainerDirective, selector: "[LibsUiComponentsDragContainerDirective]", inputs: ["disableDragContainer", "mode", "directionDrag", "viewEncapsulation", "acceptDragSameGroup", "placeholder", "groupName", "dropToGroupName", "items", "stylesOverride"], outputs: ["itemsChange", "outDragStartContainer", "outDragOverContainer", "outDragLeaveContainer", "outDragEndContainer", "outDroppedContainer", "outDroppedContainerEmpty", "outFunctionControl"] }, { kind: "directive", type: LibsUiDragItemDirective, selector: "[LibsUiDragItemDirective]", inputs: ["fieldId", "item", "itemInContainerVirtualScroll", "throttleTimeHandlerDraggingEvent", "ignoreStopEvent", "onlyMouseDownStopEvent", "dragRootElement", "dragBoundary", "dragBoundaryAcceptMouseLeaveContainer", "elementContainer", "zIndex", "disable", "ignoreUserSelectNone"], outputs: ["outDragStart", "outDragOver", "outDragLeave", "outDragEnd", "outDropped"] }, { 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: LibsUiComponentsButtonsButtonComponent, selector: "libs_ui-components-buttons-button", inputs: ["flagMouse", "type", "buttonCustom", "sizeButton", "label", "disable", "isPending", "imageLeft", "classInclude", "classIconLeft", "classIconRight", "classLabel", "iconOnlyType", "popover", "ignoreStopPropagationEvent", "zIndex", "widthLabelPopover", "styleIconLeft", "styleButton", "ignoreFocusWhenInputTab", "ignoreSetClickWhenShowPopover", "ignorePointerEvent", "isActive", "isHandlerEnterDocumentClickButton"], outputs: ["outClick", "outPopoverEvent", "outFunctionsControl"] }, { kind: "component", type: LibsUiComponentsTabsItemComponent, selector: "libs_ui-components-tabs-item", inputs: ["ignoreCalculatorTab", "step", "mode", "tabs", "item", "keySelected", "fieldLabel", "fieldKey", "cssDefault", "size", "disable", "disableLabel", "zIndex", "changeViewTab"], outputs: ["itemChange", "outAction"] }, { 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", "templateRefNotSearchNoData", "resetKeyWhenSelectAllKeyDropdown", "ignoreClassDisableDefaultWhenUseKeysDisableItem"], outputs: ["outSelectKey", "outSelectMultiKey", "outUnSelectMultiKey", "outClickButtonOther", "outFieldKey", "outChangeView", "outKeySearch", "outLoading", "outFunctionsControl", "outChangStageFlagMousePopover", "outLoadItemsComplete"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
466
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.14", type: LibsUiComponentsTabsComponent, isStandalone: true, selector: "libs_ui-components-tabs", inputs: { tabs: { classPropertyName: "tabs", publicName: "tabs", isSignal: true, isRequired: true, transformFunction: null }, keySelected: { classPropertyName: "keySelected", publicName: "keySelected", isSignal: true, isRequired: true, transformFunction: null }, mode: { classPropertyName: "mode", publicName: "mode", isSignal: true, isRequired: false, transformFunction: null }, fieldKey: { classPropertyName: "fieldKey", publicName: "fieldKey", isSignal: true, isRequired: false, transformFunction: null }, fieldLabel: { classPropertyName: "fieldLabel", publicName: "fieldLabel", isSignal: true, isRequired: false, transformFunction: null }, disable: { classPropertyName: "disable", publicName: "disable", isSignal: true, isRequired: false, transformFunction: null }, disableLabel: { classPropertyName: "disableLabel", publicName: "disableLabel", isSignal: true, isRequired: false, transformFunction: null }, heightTabItem: { classPropertyName: "heightTabItem", publicName: "heightTabItem", isSignal: true, isRequired: false, transformFunction: null }, ignoreCalculatorTab: { classPropertyName: "ignoreCalculatorTab", publicName: "ignoreCalculatorTab", isSignal: true, isRequired: false, transformFunction: null }, size: { classPropertyName: "size", publicName: "size", isSignal: true, isRequired: false, transformFunction: null }, allowDragDropPosition: { classPropertyName: "allowDragDropPosition", publicName: "allowDragDropPosition", isSignal: true, isRequired: false, transformFunction: null }, zIndex: { classPropertyName: "zIndex", publicName: "zIndex", isSignal: true, isRequired: false, transformFunction: null }, configCss: { classPropertyName: "configCss", publicName: "configCss", isSignal: true, isRequired: false, transformFunction: null }, popoverShowMoreTabItem: { classPropertyName: "popoverShowMoreTabItem", publicName: "popoverShowMoreTabItem", isSignal: true, isRequired: false, transformFunction: null }, checkCanChangeTabSelected: { classPropertyName: "checkCanChangeTabSelected", publicName: "checkCanChangeTabSelected", isSignal: true, isRequired: false, transformFunction: null }, useEffectUpdateItems: { classPropertyName: "useEffectUpdateItems", publicName: "useEffectUpdateItems", isSignal: true, isRequired: false, transformFunction: null }, useCalculatorV2: { classPropertyName: "useCalculatorV2", publicName: "useCalculatorV2", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { keySelected: "keySelectedChange", configCss: "configCssChange", outKeySelected: "outKeySelected", outFunctionsControl: "outFunctionsControl", outDragTabChange: "outDragTabChange", outDisplayMoreItem: "outDisplayMoreItem", outAction: "outAction" }, viewQueries: [{ propertyName: "headerEl", first: true, predicate: ["headerEl"], descendants: true, isSignal: true }, { propertyName: "headerLeftEl", first: true, predicate: ["headerLeftEl"], descendants: true, isSignal: true }, { propertyName: "headerRightEl", first: true, predicate: ["headerRightEl"], descendants: true, isSignal: true }], ngImport: i0, template: "<div class=\"libs-ui-tab\">\n <div\n #headerEl\n class=\"libs-ui-tab-header z-[1] {{ configCss()?.header || '' }} {{ tabs().classIncludeHeader || '' }}\"\n [style.minHeight.px]=\"heightTabItem()\">\n <div\n #headerLeftEl\n class=\"libs-ui-tab-header-left\">\n <ng-content select=\"div.libs-ui-tab-header-left\"></ng-content>\n </div>\n <div class=\"libs-ui-tab-header-center {{ configCss()?.headerCenter || '' }} {{ tabs().classIncludeHeaderCenter || '' }}\">\n <div\n class=\"!flex w-full\"\n #elementContainerEl\n LibsUiComponentsDragContainerDirective\n [stylesOverride]=\"stylesDragDropOverrideComputed()\"\n [groupName]=\"groupName()\"\n [(items)]=\"itemsDisplay\"\n [directionDrag]=\"'horizontal'\"\n [disableDragContainer]=\"!allowDragDropPosition()\"\n [acceptDragSameGroup]=\"allowDragDropPosition()\"\n (outDroppedContainer)=\"handlerDropContainer($event)\">\n @for (item of itemsDisplay(); track item) {\n <div\n LibsUiDragItemDirective\n [disable]=\"disable() || !allowDragDropPosition() || (useCalculatorV2() && item().specificDisplay === false)\"\n [elementContainer]=\"elementContainerEl\"\n [dragBoundary]=\"true\"\n [dragBoundaryAcceptMouseLeaveContainer]=\"true\"\n class=\"relative libs-ui-tab-item-container\"\n [style.width.px]=\"mode() === 'space-between' ? elementContainerEl.clientWidth / displayedCount() : undefined\"\n [class.flex]=\"mode() === 'center-has-line'\"\n [class.items-center]=\"mode() === 'center-has-line'\"\n [style.visibility]=\"useCalculatorV2() && item().specificDisplay === false ? 'hidden' : null\"\n [style.position]=\"useCalculatorV2() && item().specificDisplay === false ? 'absolute' : null\"\n [style.pointer-events]=\"useCalculatorV2() && item().specificDisplay === false ? 'none' : null\"\n [attr.aria-hidden]=\"useCalculatorV2() && item().specificDisplay === false ? 'true' : null\">\n @if (allowDragDropPosition() && !disable()) {\n <span class=\"libs-ui-icon-arrange text-[#9ca2ad] absolute top-[14px] left-[4px]\"></span>\n }\n <libs_ui-components-tabs-item\n class=\"h-full w-full {{ tabs().classIncludeItem || '' }}\"\n [tabs]=\"tabs()\"\n [size]=\"size()\"\n [(item)]=\"item\"\n [step]=\"$index + 1\"\n [class.!pointer-events-none]=\"item().disable || disable()\"\n [disable]=\"item().disable || disable()\"\n [disableLabel]=\"disableLabel()\"\n [keySelected]=\"keySelected()\"\n [fieldLabel]=\"fieldLabel()\"\n [fieldKey]=\"fieldKey()\"\n [cssDefault]=\"($first ? configCss()?.first : configCss()?.other) || ''\"\n [zIndex]=\"zIndex()\"\n [mode]=\"mode()\"\n [ignoreCalculatorTab]=\"ignoreCalculatorTab() || !useCalculatorV2()\"\n [useCalculatorV2]=\"useCalculatorV2()\"\n [changeViewTab]=\"changeViewTab\"\n (click)=\"handlerClickItem(item)\"\n (outAction)=\"handlerAction($event)\" />\n @if (mode() === 'center-has-line' && !$last) {\n <div class=\"w-[40px] h-[1px] bg-[#e6e7ea]\"></div>\n }\n </div>\n }\n </div>\n </div>\n <div\n class=\"flex items-center\"\n [class.ml-auto]=\"displayMoreItem() && !tabs().viewMoreIgnoreMarginLeft\">\n @if (displayMoreItem()) {\n <libs_ui-components-popover\n class=\"w-full h-full flex items-center\"\n [mode]=\"'click-toggle'\"\n [ignoreHiddenPopoverContentWhenMouseLeave]=\"true\"\n [config]=\"{\n zIndex: popoverShowMoreTabItem()?.config?.zIndex || 1000,\n maxHeight: popoverShowMoreTabItem()?.config?.maxHeight || 287,\n maxWidth: popoverShowMoreTabItem()?.config?.maxWidth || 2048,\n width: popoverShowMoreTabItem()?.config?.width || 277,\n direction: popoverShowMoreTabItem()?.config?.direction || 'bottom',\n template: popoverShowMoreTabItem()?.config?.template || menuEl,\n whiteTheme: true,\n ignoreArrow: true,\n position: popoverShowMoreTabItem()?.config?.position || { mode: 'end', distance: 0 },\n }\"\n (outFunctionsControl)=\"handlerPopoverFunctionControlEvent($event)\">\n <libs_ui-components-buttons-button\n [type]=\"'button-link-third'\"\n [classInclude]=\"'!p-[8px]'\"\n [iconOnlyType]=\"true\"\n [classIconLeft]=\"'libs-ui-icon-more-vertical rotate-90 text-[16px] mr-0'\"\n [popover]=\"{ config: { content: popoverShowMoreTabItem()?.config?.content || 'i18n_view_more' } }\"\n [ignoreStopPropagationEvent]=\"true\" />\n </libs_ui-components-popover>\n }\n </div>\n <div\n #headerRightEl\n class=\"libs-ui-tab-header-right {{ tabs().classIncludeHeaderRight || '' }}\">\n <ng-content select=\"div.libs-ui-tab-header-right\"></ng-content>\n </div>\n </div>\n @if (!useCalculatorV2()) {\n <div class=\"absolute top-0 z-0 w-full\">\n <div\n class=\"libs-ui-tab-header {{ configCss()?.header || '' }} {{ tabs().classIncludeHeader || '' }}\"\n [style.minHeight.px]=\"heightTabItem()\">\n <div class=\"libs-ui-tab-header-center {{ configCss()?.headerCenter || '' }} {{ tabs().classIncludeHeaderCenter || '' }}\">\n @for (item of tabs().items(); track item) {\n <libs_ui-components-tabs-item\n class=\"h-full w-full {{ tabs().classIncludeItem || '' }}\"\n [tabs]=\"tabs()\"\n [size]=\"size()\"\n [(item)]=\"item\"\n [step]=\"$index + 1\"\n [disable]=\"disable()\"\n [disableLabel]=\"disableLabel()\"\n [keySelected]=\"keySelected()\"\n [fieldLabel]=\"fieldLabel()\"\n [fieldKey]=\"fieldKey()\"\n [cssDefault]=\"($first ? configCss()?.first : configCss()?.other) || ''\"\n [zIndex]=\"zIndex()\"\n [mode]=\"mode()\"\n [changeViewTab]=\"changeViewTab\"\n [ignoreCalculatorTab]=\"ignoreCalculatorTab()\" />\n }\n </div>\n </div>\n </div>\n }\n</div>\n<ng-template #menuEl>\n <libs_ui-components-list\n [config]=\"tabMoreListConfig()\"\n [maxItemShow]=\"5\"\n [hiddenInputSearch]=\"true\"\n [paddingLeftItem]=\"true\"\n (outSelectKey)=\"handlerSelectedKey($event)\" />\n</ng-template>\n", styles: [".libs-ui-tab{position:relative;display:flex;width:100%}.libs-ui-tab .libs-ui-tab-header{position:relative;background-color:#fff;display:flex;flex-wrap:nowrap;width:100%;overflow:hidden;flex-shrink:0}.libs-ui-tab .libs-ui-tab-header .libs-ui-tab-header-center{display:flex;flex-wrap:nowrap}.libs-ui-tab .libs-ui-tab-header .libs-ui-tab-item-container .libs-ui-icon-arrange{display:none}.libs-ui-tab .libs-ui-tab-header .libs-ui-tab-item-container:hover .libs-ui-icon-arrange{display:block}.libs-ui-tab .libs-ui-tab-content-container{width:100%;height:100%}\n"], dependencies: [{ kind: "directive", type: LibsUiComponentsDragContainerDirective, selector: "[LibsUiComponentsDragContainerDirective]", inputs: ["disableDragContainer", "mode", "directionDrag", "viewEncapsulation", "acceptDragSameGroup", "placeholder", "groupName", "dropToGroupName", "items", "stylesOverride"], outputs: ["itemsChange", "outDragStartContainer", "outDragOverContainer", "outDragLeaveContainer", "outDragEndContainer", "outDroppedContainer", "outDroppedContainerEmpty", "outFunctionControl"] }, { kind: "directive", type: LibsUiDragItemDirective, selector: "[LibsUiDragItemDirective]", inputs: ["fieldId", "item", "itemInContainerVirtualScroll", "throttleTimeHandlerDraggingEvent", "ignoreStopEvent", "onlyMouseDownStopEvent", "dragRootElement", "dragBoundary", "dragBoundaryAcceptMouseLeaveContainer", "elementContainer", "zIndex", "disable", "ignoreUserSelectNone"], outputs: ["outDragStart", "outDragOver", "outDragLeave", "outDragEnd", "outDropped"] }, { 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: LibsUiComponentsButtonsButtonComponent, selector: "libs_ui-components-buttons-button", inputs: ["flagMouse", "type", "buttonCustom", "sizeButton", "label", "disable", "isPending", "imageLeft", "classInclude", "classIconLeft", "classIconRight", "classLabel", "iconOnlyType", "popover", "ignoreStopPropagationEvent", "zIndex", "widthLabelPopover", "styleIconLeft", "styleButton", "ignoreFocusWhenInputTab", "ignoreSetClickWhenShowPopover", "ignorePointerEvent", "isActive", "isHandlerEnterDocumentClickButton"], outputs: ["outClick", "outPopoverEvent", "outFunctionsControl"] }, { kind: "component", type: LibsUiComponentsTabsItemComponent, selector: "libs_ui-components-tabs-item", inputs: ["ignoreCalculatorTab", "step", "mode", "tabs", "item", "keySelected", "fieldLabel", "fieldKey", "cssDefault", "size", "disable", "disableLabel", "zIndex", "changeViewTab", "useCalculatorV2"], outputs: ["itemChange", "outAction"] }, { 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", "templateRefNotSearchNoData", "resetKeyWhenSelectAllKeyDropdown", "ignoreClassDisableDefaultWhenUseKeysDisableItem"], outputs: ["outSelectKey", "outSelectMultiKey", "outUnSelectMultiKey", "outClickButtonOther", "outFieldKey", "outChangeView", "outKeySearch", "outLoading", "outFunctionsControl", "outChangStageFlagMousePopover", "outLoadItemsComplete"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
|
|
290
467
|
}
|
|
291
468
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: LibsUiComponentsTabsComponent, decorators: [{
|
|
292
469
|
type: Component,
|
|
293
|
-
args: [{ selector: 'libs_ui-components-tabs', standalone: true, changeDetection: ChangeDetectionStrategy.OnPush, imports: [LibsUiComponentsDragContainerDirective, LibsUiDragItemDirective, LibsUiComponentsPopoverComponent, LibsUiComponentsButtonsButtonComponent, LibsUiComponentsTabsItemComponent, LibsUiComponentsListComponent], template: "<div class=\"libs-ui-tab\">\n <div\n #headerEl\n class=\"libs-ui-tab-header z-[1] {{ configCss()?.header || '' }} {{ tabs().classIncludeHeader || '' }}\"\n [style.minHeight.px]=\"heightTabItem()\">\n <div\n #headerLeftEl\n class=\"libs-ui-tab-header-left\">\n <ng-content select=\"div.libs-ui-tab-header-left\"></ng-content>\n </div>\n <div class=\"libs-ui-tab-header-center {{ configCss()?.headerCenter || '' }} {{ tabs().classIncludeHeaderCenter || '' }}\">\n <div\n class=\"!flex w-full\"\n #elementContainerEl\n LibsUiComponentsDragContainerDirective\n [stylesOverride]=\"stylesDragDropOverrideComputed()\"\n [groupName]=\"groupName()\"\n [(items)]=\"itemsDisplay\"\n [directionDrag]=\"'horizontal'\"\n [disableDragContainer]=\"!allowDragDropPosition()\"\n [acceptDragSameGroup]=\"allowDragDropPosition()\"\n (outDroppedContainer)=\"handlerDropContainer($event)\">\n @for (item of itemsDisplay(); track item) {\n <div\n LibsUiDragItemDirective\n [disable]=\"disable() || !allowDragDropPosition()\"\n [elementContainer]=\"elementContainerEl\"\n [dragBoundary]=\"true\"\n [dragBoundaryAcceptMouseLeaveContainer]=\"true\"\n class=\"relative libs-ui-tab-item-container\"\n [style.width.px]=\"mode() === 'space-between' ? elementContainerEl.clientWidth / (
|
|
470
|
+
args: [{ selector: 'libs_ui-components-tabs', standalone: true, changeDetection: ChangeDetectionStrategy.OnPush, imports: [LibsUiComponentsDragContainerDirective, LibsUiDragItemDirective, LibsUiComponentsPopoverComponent, LibsUiComponentsButtonsButtonComponent, LibsUiComponentsTabsItemComponent, LibsUiComponentsListComponent], template: "<div class=\"libs-ui-tab\">\n <div\n #headerEl\n class=\"libs-ui-tab-header z-[1] {{ configCss()?.header || '' }} {{ tabs().classIncludeHeader || '' }}\"\n [style.minHeight.px]=\"heightTabItem()\">\n <div\n #headerLeftEl\n class=\"libs-ui-tab-header-left\">\n <ng-content select=\"div.libs-ui-tab-header-left\"></ng-content>\n </div>\n <div class=\"libs-ui-tab-header-center {{ configCss()?.headerCenter || '' }} {{ tabs().classIncludeHeaderCenter || '' }}\">\n <div\n class=\"!flex w-full\"\n #elementContainerEl\n LibsUiComponentsDragContainerDirective\n [stylesOverride]=\"stylesDragDropOverrideComputed()\"\n [groupName]=\"groupName()\"\n [(items)]=\"itemsDisplay\"\n [directionDrag]=\"'horizontal'\"\n [disableDragContainer]=\"!allowDragDropPosition()\"\n [acceptDragSameGroup]=\"allowDragDropPosition()\"\n (outDroppedContainer)=\"handlerDropContainer($event)\">\n @for (item of itemsDisplay(); track item) {\n <div\n LibsUiDragItemDirective\n [disable]=\"disable() || !allowDragDropPosition() || (useCalculatorV2() && item().specificDisplay === false)\"\n [elementContainer]=\"elementContainerEl\"\n [dragBoundary]=\"true\"\n [dragBoundaryAcceptMouseLeaveContainer]=\"true\"\n class=\"relative libs-ui-tab-item-container\"\n [style.width.px]=\"mode() === 'space-between' ? elementContainerEl.clientWidth / displayedCount() : undefined\"\n [class.flex]=\"mode() === 'center-has-line'\"\n [class.items-center]=\"mode() === 'center-has-line'\"\n [style.visibility]=\"useCalculatorV2() && item().specificDisplay === false ? 'hidden' : null\"\n [style.position]=\"useCalculatorV2() && item().specificDisplay === false ? 'absolute' : null\"\n [style.pointer-events]=\"useCalculatorV2() && item().specificDisplay === false ? 'none' : null\"\n [attr.aria-hidden]=\"useCalculatorV2() && item().specificDisplay === false ? 'true' : null\">\n @if (allowDragDropPosition() && !disable()) {\n <span class=\"libs-ui-icon-arrange text-[#9ca2ad] absolute top-[14px] left-[4px]\"></span>\n }\n <libs_ui-components-tabs-item\n class=\"h-full w-full {{ tabs().classIncludeItem || '' }}\"\n [tabs]=\"tabs()\"\n [size]=\"size()\"\n [(item)]=\"item\"\n [step]=\"$index + 1\"\n [class.!pointer-events-none]=\"item().disable || disable()\"\n [disable]=\"item().disable || disable()\"\n [disableLabel]=\"disableLabel()\"\n [keySelected]=\"keySelected()\"\n [fieldLabel]=\"fieldLabel()\"\n [fieldKey]=\"fieldKey()\"\n [cssDefault]=\"($first ? configCss()?.first : configCss()?.other) || ''\"\n [zIndex]=\"zIndex()\"\n [mode]=\"mode()\"\n [ignoreCalculatorTab]=\"ignoreCalculatorTab() || !useCalculatorV2()\"\n [useCalculatorV2]=\"useCalculatorV2()\"\n [changeViewTab]=\"changeViewTab\"\n (click)=\"handlerClickItem(item)\"\n (outAction)=\"handlerAction($event)\" />\n @if (mode() === 'center-has-line' && !$last) {\n <div class=\"w-[40px] h-[1px] bg-[#e6e7ea]\"></div>\n }\n </div>\n }\n </div>\n </div>\n <div\n class=\"flex items-center\"\n [class.ml-auto]=\"displayMoreItem() && !tabs().viewMoreIgnoreMarginLeft\">\n @if (displayMoreItem()) {\n <libs_ui-components-popover\n class=\"w-full h-full flex items-center\"\n [mode]=\"'click-toggle'\"\n [ignoreHiddenPopoverContentWhenMouseLeave]=\"true\"\n [config]=\"{\n zIndex: popoverShowMoreTabItem()?.config?.zIndex || 1000,\n maxHeight: popoverShowMoreTabItem()?.config?.maxHeight || 287,\n maxWidth: popoverShowMoreTabItem()?.config?.maxWidth || 2048,\n width: popoverShowMoreTabItem()?.config?.width || 277,\n direction: popoverShowMoreTabItem()?.config?.direction || 'bottom',\n template: popoverShowMoreTabItem()?.config?.template || menuEl,\n whiteTheme: true,\n ignoreArrow: true,\n position: popoverShowMoreTabItem()?.config?.position || { mode: 'end', distance: 0 },\n }\"\n (outFunctionsControl)=\"handlerPopoverFunctionControlEvent($event)\">\n <libs_ui-components-buttons-button\n [type]=\"'button-link-third'\"\n [classInclude]=\"'!p-[8px]'\"\n [iconOnlyType]=\"true\"\n [classIconLeft]=\"'libs-ui-icon-more-vertical rotate-90 text-[16px] mr-0'\"\n [popover]=\"{ config: { content: popoverShowMoreTabItem()?.config?.content || 'i18n_view_more' } }\"\n [ignoreStopPropagationEvent]=\"true\" />\n </libs_ui-components-popover>\n }\n </div>\n <div\n #headerRightEl\n class=\"libs-ui-tab-header-right {{ tabs().classIncludeHeaderRight || '' }}\">\n <ng-content select=\"div.libs-ui-tab-header-right\"></ng-content>\n </div>\n </div>\n @if (!useCalculatorV2()) {\n <div class=\"absolute top-0 z-0 w-full\">\n <div\n class=\"libs-ui-tab-header {{ configCss()?.header || '' }} {{ tabs().classIncludeHeader || '' }}\"\n [style.minHeight.px]=\"heightTabItem()\">\n <div class=\"libs-ui-tab-header-center {{ configCss()?.headerCenter || '' }} {{ tabs().classIncludeHeaderCenter || '' }}\">\n @for (item of tabs().items(); track item) {\n <libs_ui-components-tabs-item\n class=\"h-full w-full {{ tabs().classIncludeItem || '' }}\"\n [tabs]=\"tabs()\"\n [size]=\"size()\"\n [(item)]=\"item\"\n [step]=\"$index + 1\"\n [disable]=\"disable()\"\n [disableLabel]=\"disableLabel()\"\n [keySelected]=\"keySelected()\"\n [fieldLabel]=\"fieldLabel()\"\n [fieldKey]=\"fieldKey()\"\n [cssDefault]=\"($first ? configCss()?.first : configCss()?.other) || ''\"\n [zIndex]=\"zIndex()\"\n [mode]=\"mode()\"\n [changeViewTab]=\"changeViewTab\"\n [ignoreCalculatorTab]=\"ignoreCalculatorTab()\" />\n }\n </div>\n </div>\n </div>\n }\n</div>\n<ng-template #menuEl>\n <libs_ui-components-list\n [config]=\"tabMoreListConfig()\"\n [maxItemShow]=\"5\"\n [hiddenInputSearch]=\"true\"\n [paddingLeftItem]=\"true\"\n (outSelectKey)=\"handlerSelectedKey($event)\" />\n</ng-template>\n", styles: [".libs-ui-tab{position:relative;display:flex;width:100%}.libs-ui-tab .libs-ui-tab-header{position:relative;background-color:#fff;display:flex;flex-wrap:nowrap;width:100%;overflow:hidden;flex-shrink:0}.libs-ui-tab .libs-ui-tab-header .libs-ui-tab-header-center{display:flex;flex-wrap:nowrap}.libs-ui-tab .libs-ui-tab-header .libs-ui-tab-item-container .libs-ui-icon-arrange{display:none}.libs-ui-tab .libs-ui-tab-header .libs-ui-tab-item-container:hover .libs-ui-icon-arrange{display:block}.libs-ui-tab .libs-ui-tab-content-container{width:100%;height:100%}\n"] }]
|
|
294
471
|
}], ctorParameters: () => [] });
|
|
295
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tabs.component.js","sourceRoot":"","sources":["../../../../../libs-ui/components/tabs/src/tabs.component.ts","../../../../../libs-ui/components/tabs/src/tabs.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ChangeDetectionStrategy, Component, computed, effect, ElementRef, inject, input, model, OnDestroy, OnInit, output, signal, untracked, viewChild, WritableSignal } from '@angular/core';\nimport { LibsUiComponentsButtonsButtonComponent } from '@libs-ui/components-buttons-button';\nimport { IDrop, LibsUiComponentsDragContainerDirective, LibsUiDragItemDirective } from '@libs-ui/components-drag-drop';\nimport { IListDataEmitKey, LibsUiComponentsListComponent } from '@libs-ui/components-list';\nimport { IPopover, IPopoverFunctionControlEvent, LibsUiComponentsPopoverComponent } from '@libs-ui/components-popover';\nimport { convertObjectToSignal, isNil, uuid } from '@libs-ui/utils';\nimport { TranslateService } from '@ngx-translate/core';\nimport { fromEvent, Subject } from 'rxjs';\nimport { debounceTime, takeUntil } from 'rxjs/operators';\nimport { ITabCssConfig, ITabs, ITabsFunctionControlEvent, ITabsItem, ITabsItemEvent, TYPE_TAB_MODE } from './interfaces/tab.interface';\nimport { LibsUiComponentsTabsItemComponent } from './item/item.component';\nimport { tabMoreListConfig } from './utils/tabs';\n\n@Component({\n  // eslint-disable-next-line @angular-eslint/component-selector\n  selector: 'libs_ui-components-tabs',\n  templateUrl: './tabs.component.html',\n  styleUrls: ['./tabs.component.scss'],\n  standalone: true,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  imports: [LibsUiComponentsDragContainerDirective, LibsUiDragItemDirective, LibsUiComponentsPopoverComponent, LibsUiComponentsButtonsButtonComponent, LibsUiComponentsTabsItemComponent, LibsUiComponentsListComponent],\n})\nexport class LibsUiComponentsTabsComponent implements OnInit, OnDestroy {\n  // #region PROPERTY\n  protected itemsDisplay = signal<Array<WritableSignal<ITabsItem>>>([]);\n  protected displayMoreItem = signal<boolean>(false);\n  protected tabMoreListConfig = computed(() => tabMoreListConfig(this.translate, this.fieldKey(), this.fieldLabel(), this.tabs(), this.disable()));\n  protected changeViewTab = new Subject<void>();\n  protected groupName = signal<string>(uuid());\n  protected stylesDragDropOverrideComputed = computed(() => this.updateStylesDragDropOverride());\n\n  private popoverFunctionControlEvent = signal<IPopoverFunctionControlEvent | undefined>(undefined);\n  private onDestroy = new Subject<void>();\n\n  // #region INPUT\n  readonly tabs = input.required<ITabs>();\n  readonly keySelected = model.required<string>();\n  readonly mode = input<TYPE_TAB_MODE>('left');\n  readonly fieldKey = input<string>('key');\n  readonly fieldLabel = input<string>('label');\n  readonly disable = input<boolean>();\n  readonly disableLabel = input<boolean>();\n  readonly heightTabItem = input<number>(40);\n  readonly ignoreCalculatorTab = input<boolean>(false);\n  readonly size = input<'langer' | 'medium'>('medium');\n  readonly allowDragDropPosition = input<boolean>();\n  readonly zIndex = input<number>();\n  readonly configCss = model<ITabCssConfig>();\n  readonly popoverShowMoreTabItem = input<IPopover>();\n  readonly checkCanChangeTabSelected = input<() => boolean | Promise<boolean>>();\n  readonly useEffectUpdateItems = input<boolean>();\n\n  // #region OUTPUT\n  readonly outKeySelected = output<string>();\n  readonly outFunctionsControl = output<ITabsFunctionControlEvent>();\n  readonly outDragTabChange = output<void>();\n  readonly outDisplayMoreItem = output<boolean>();\n  readonly outAction = output<ITabsItemEvent>();\n\n  /* VIEW CHILD */\n  private readonly headerEl = viewChild.required<ElementRef>('headerEl');\n  private readonly headerLeftEl = viewChild.required<ElementRef>('headerLeftEl');\n  private readonly headerRightEl = viewChild.required<ElementRef>('headerRightEl');\n\n  /* INJECT*/\n  private translate = inject(TranslateService);\n\n  constructor() {\n    effect(() => {\n      const items = this.tabs()?.items();\n      if (!this.useEffectUpdateItems()) return;\n      untracked(() => {\n        this.updateItemsDisplay(items);\n      });\n    });\n  }\n\n  ngOnInit() {\n    this.updateTabsCssConfig();\n    this.outFunctionsControl.emit(this.FunctionsControl);\n    if (!this.useEffectUpdateItems()) {\n      this.updateItemsDisplay(this.tabs()?.items());\n    }\n    fromEvent(window, 'resize')\n      .pipe(debounceTime(250), takeUntil(this.onDestroy))\n      .subscribe(() => {\n        if (!this.tabs().items().length) {\n          return;\n        }\n        this.displayMoreItem.set(false);\n        this.calculatorTabsItemDisplay();\n      });\n    this.changeViewTab.pipe(debounceTime(20), takeUntil(this.onDestroy)).subscribe(() => this.calculatorTabsItemDisplay());\n  }\n\n  private updateItemsDisplay(items: Array<WritableSignal<ITabsItem>>) {\n    if (!items) return;\n    untracked(() => {\n      if (this.mode() !== 'left' || this.ignoreCalculatorTab()) {\n        items.forEach((item) => item.update((data) => ({ ...data, specificDisplay: true })));\n        this.itemsDisplay.set(items);\n        return;\n      }\n      this.calculatorTabsItemDisplay();\n    });\n  }\n\n  /* FUNCTIONS */\n  public get FunctionsControl(): ITabsFunctionControlEvent {\n    return {\n      addTabsItem: this.addTabsItem.bind(this),\n      calculatorTabsItemsDisplay: this.calculatorTabsItemDisplay.bind(this),\n      selectedTabsItem: this.handlerSelectedTabsItem.bind(this),\n    };\n  }\n\n  private updateTabsCssConfig() {\n    if (this.configCss()) {\n      return;\n    }\n    switch (this.mode()) {\n      case 'left':\n        this.configCss.set({\n          first: 'ml-[20px] mr-[16px]',\n          other: 'ml-[20px] mr-[16px]',\n        });\n        break;\n      case 'center':\n        this.configCss.set({\n          first: 'px-[12px] ml-[18px] mr-[18px]',\n          other: 'px-[12px] mx-[18px]',\n          header: 'flex justify-center',\n        });\n        break;\n      case 'center-has-line':\n        this.configCss.set({\n          first: 'px-[16px]',\n          other: 'px-[16px]',\n          headerCenter: 'items-center',\n        });\n        break;\n      case 'space-between':\n        this.configCss.set({\n          first: 'mx-auto',\n          other: 'mx-auto',\n          headerCenter: 'w-full',\n        });\n        break;\n    }\n  }\n\n  private updateStylesDragDropOverride() {\n    if (this.allowDragDropPosition()) {\n      return [\n        {\n          className: 'libs-ui-drag-drop-item-placeholder',\n          styles: '',\n        },\n        {\n          className: 'libs-ui-drag-drop-item',\n          styles: 'cursor: move;',\n        },\n        {\n          className: 'libs-ui-drag-drop-item-dragging',\n          styles: 'cursor: move; background: #dddddd;',\n        },\n      ];\n    }\n    return [\n      {\n        className: 'libs-ui-drag-drop-item',\n        styles: '',\n      },\n      {\n        className: 'libs-ui-drag-drop-item-disable',\n        styles: '',\n      },\n    ];\n  }\n\n  protected handlerDropContainer(event: IDrop) {\n    const { itemDragInfo } = event;\n    if (!itemDragInfo) {\n      return;\n    }\n    const items = this.tabs().items;\n    const { indexDrag, indexDrop } = itemDragInfo;\n    if (isNil(indexDrag) || isNil(indexDrop) || indexDrop === indexDrag) {\n      return;\n    }\n    const itemDrag = items()[indexDrag as number];\n    items.update((items) => {\n      items.splice(indexDrag as number, 1);\n      items.splice(indexDrop as number, 0, itemDrag);\n      return [...items];\n    });\n    this.outDragTabChange.emit();\n  }\n\n  protected handlerPopoverFunctionControlEvent(event: IPopoverFunctionControlEvent) {\n    this.popoverFunctionControlEvent.set(event);\n  }\n\n  private async handlerSelectedTabsItem(key: string, resetDisable = true) {\n    const itemSelected = this.tabs()\n      .items()\n      .find((item) => item()[this.fieldKey()] === key);\n    if (!itemSelected) {\n      return;\n    }\n    if (resetDisable) {\n      itemSelected.update((item) => ({ ...item, disable: false }));\n    }\n    this.handlerClickItem(itemSelected);\n  }\n\n  protected handlerSelectedKey(event: IListDataEmitKey | undefined) {\n    if (!event) {\n      return;\n    }\n    this.handlerClickItem(convertObjectToSignal(event.item));\n    this.outDragTabChange.emit();\n  }\n\n  protected async handlerClickItem(item: WritableSignal<ITabsItem>) {\n    if (item().disable || this.disable()) {\n      return;\n    }\n    const checkCanChangeTabSelected = this.checkCanChangeTabSelected();\n    if (checkCanChangeTabSelected) {\n      const state = await checkCanChangeTabSelected();\n      if (state) {\n        this.changeItemSelected(item);\n      }\n      return;\n    }\n    this.changeItemSelected(item);\n  }\n\n  private changeItemSelected(item: WritableSignal<ITabsItem>) {\n    this.keySelected.set(item()[this.fieldKey()]);\n    this.outKeySelected.emit(this.keySelected());\n    this.popoverFunctionControlEvent()?.removePopoverOverlay();\n    this.calculatorTabsItemDisplay();\n  }\n\n  protected async handlerAction(event: ITabsItemEvent) {\n    this.outAction.emit(event);\n  }\n\n  private async addTabsItem(item: WritableSignal<ITabsItem>, selected = true, addFirst?: boolean, indexAdd?: number) {\n    const items = this.tabs().items;\n    items.update((items) => {\n      if (addFirst) {\n        return [item, ...items];\n      }\n      if (indexAdd) {\n        items.splice(indexAdd, 0, item);\n        return items;\n      }\n      return [...items, item];\n    });\n    if (selected) {\n      this.handlerClickItem(item);\n    }\n  }\n\n  protected async calculatorTabsItemDisplay() {\n    let items = this.tabs().items();\n    const indexItemSelected = items.findIndex((item) => item()[this.fieldKey()] === this.keySelected());\n    if (indexItemSelected < 0) {\n      return;\n    }\n    this.displayMoreItem.set(false);\n    let displayMoreItem = false;\n    const headerWidth = this.headerEl().nativeElement.clientWidth || 0;\n    const itemSelected = items[indexItemSelected];\n    const itemSelectedWidth = itemSelected().specificWidth;\n    let totalWidthItemsDisplay = (this.headerLeftEl().nativeElement.clientWidth || 0) + (this.headerRightEl().nativeElement.clientWidth || 0) + 32;\n    items.forEach((item, index) => {\n      if (!item().specificWidth) {\n        return;\n      }\n      item.update((data) => ({ ...data, specificDisplay: false }));\n      const itemWidth = item().specificWidth || 0;\n      const width = totalWidthItemsDisplay + itemWidth + (index < indexItemSelected ? itemSelectedWidth : 0);\n      totalWidthItemsDisplay += itemWidth;\n      if (width > headerWidth) {\n        displayMoreItem = true;\n        return;\n      }\n      item.update((data) => ({ ...data, specificDisplay: true }));\n    });\n    itemSelected.update((data) => ({ ...data, specificDisplay: true }));\n    const display = items.filter((item) => item().specificDisplay === true);\n    const notDisplay = items.filter((item) => item().specificDisplay === false);\n    items = display.concat(notDisplay);\n    items.forEach((item, index) => item.update((data) => ({ ...data, order: index })));\n    const sortedItems = [...items].sort((prev, next) => (prev().order || 0) - (next().order || 0));\n    // Check if order actually changed before setting to avoid triggering redundant cycles\n    const orderChanged = items.some((item, index) => item()[this.fieldKey()] !== sortedItems[index]()[this.fieldKey()]);\n\n    if (orderChanged) {\n      this.tabs().items.set(sortedItems);\n    }\n\n    this.displayMoreItem.set(displayMoreItem);\n    this.outDisplayMoreItem.emit(this.displayMoreItem());\n\n    const newItemsDisplay = this.tabs()\n      .items()\n      .filter((item) => item().specificDisplay);\n    this.itemsDisplay.set(newItemsDisplay);\n  }\n\n  ngOnDestroy() {\n    this.onDestroy.next();\n    this.onDestroy.complete();\n  }\n}\n","<div class=\"libs-ui-tab\">\n  <div\n    #headerEl\n    class=\"libs-ui-tab-header z-[1] {{ configCss()?.header || '' }} {{ tabs().classIncludeHeader || '' }}\"\n    [style.minHeight.px]=\"heightTabItem()\">\n    <div\n      #headerLeftEl\n      class=\"libs-ui-tab-header-left\">\n      <ng-content select=\"div.libs-ui-tab-header-left\"></ng-content>\n    </div>\n    <div class=\"libs-ui-tab-header-center {{ configCss()?.headerCenter || '' }} {{ tabs().classIncludeHeaderCenter || '' }}\">\n      <div\n        class=\"!flex w-full\"\n        #elementContainerEl\n        LibsUiComponentsDragContainerDirective\n        [stylesOverride]=\"stylesDragDropOverrideComputed()\"\n        [groupName]=\"groupName()\"\n        [(items)]=\"itemsDisplay\"\n        [directionDrag]=\"'horizontal'\"\n        [disableDragContainer]=\"!allowDragDropPosition()\"\n        [acceptDragSameGroup]=\"allowDragDropPosition()\"\n        (outDroppedContainer)=\"handlerDropContainer($event)\">\n        @for (item of itemsDisplay(); track item) {\n          <div\n            LibsUiDragItemDirective\n            [disable]=\"disable() || !allowDragDropPosition()\"\n            [elementContainer]=\"elementContainerEl\"\n            [dragBoundary]=\"true\"\n            [dragBoundaryAcceptMouseLeaveContainer]=\"true\"\n            class=\"relative libs-ui-tab-item-container\"\n            [style.width.px]=\"mode() === 'space-between' ? elementContainerEl.clientWidth / (itemsDisplay().length || 1) : undefined\"\n            [class.flex]=\"mode() === 'center-has-line'\"\n            [class.items-center]=\"mode() === 'center-has-line'\">\n            @if (allowDragDropPosition() && !disable()) {\n              <span class=\"libs-ui-icon-arrange text-[#9ca2ad] absolute top-[14px] left-[4px]\"></span>\n            }\n            <libs_ui-components-tabs-item\n              class=\"h-full w-full  {{ tabs().classIncludeItem || '' }}\"\n              [tabs]=\"tabs()\"\n              [size]=\"size()\"\n              [(item)]=\"item\"\n              [step]=\"$index + 1\"\n              [class.!pointer-events-none]=\"item().disable || disable()\"\n              [disable]=\"item().disable || disable()\"\n              [disableLabel]=\"disableLabel()\"\n              [keySelected]=\"keySelected()\"\n              [fieldLabel]=\"fieldLabel()\"\n              [fieldKey]=\"fieldKey()\"\n              [cssDefault]=\"($first ? configCss()?.first : configCss()?.other) || ''\"\n              [zIndex]=\"zIndex()\"\n              [mode]=\"mode()\"\n              [ignoreCalculatorTab]=\"true\"\n              [changeViewTab]=\"changeViewTab\"\n              (click)=\"handlerClickItem(item)\"\n              (outAction)=\"handlerAction($event)\" />\n            @if (mode() === 'center-has-line' && !$last) {\n              <div class=\"w-[40px] h-[1px] bg-[#e6e7ea]\"></div>\n            }\n          </div>\n        }\n      </div>\n    </div>\n    <div\n      class=\"flex items-center\"\n      [class.ml-auto]=\"displayMoreItem() && !tabs().viewMoreIgnoreMarginLeft\">\n      @if (displayMoreItem()) {\n        <libs_ui-components-popover\n          class=\"w-full h-full flex items-center\"\n          [mode]=\"'click-toggle'\"\n          [ignoreHiddenPopoverContentWhenMouseLeave]=\"true\"\n          [config]=\"{\n            zIndex: popoverShowMoreTabItem()?.config?.zIndex || 1000,\n            maxHeight: popoverShowMoreTabItem()?.config?.maxHeight || 287,\n            maxWidth: popoverShowMoreTabItem()?.config?.maxWidth || 2048,\n            width: popoverShowMoreTabItem()?.config?.width || 277,\n            direction: popoverShowMoreTabItem()?.config?.direction || 'bottom',\n            template: popoverShowMoreTabItem()?.config?.template || menuEl,\n            whiteTheme: true,\n            ignoreArrow: true,\n            position: popoverShowMoreTabItem()?.config?.position || { mode: 'end', distance: 0 },\n          }\"\n          (outFunctionsControl)=\"handlerPopoverFunctionControlEvent($event)\">\n          <libs_ui-components-buttons-button\n            [type]=\"'button-link-third'\"\n            [classInclude]=\"'!p-[8px]'\"\n            [iconOnlyType]=\"true\"\n            [classIconLeft]=\"'libs-ui-icon-more-vertical rotate-90 text-[16px] mr-0'\"\n            [popover]=\"{ config: { content: popoverShowMoreTabItem()?.config?.content || 'i18n_view_more' } }\"\n            [ignoreStopPropagationEvent]=\"true\" />\n        </libs_ui-components-popover>\n      }\n    </div>\n    <div\n      #headerRightEl\n      class=\"libs-ui-tab-header-right {{ tabs().classIncludeHeaderRight || '' }}\">\n      <ng-content select=\"div.libs-ui-tab-header-right\"></ng-content>\n    </div>\n  </div>\n  <div class=\"absolute top-0 z-0 w-full\">\n    <div\n      class=\"libs-ui-tab-header {{ configCss()?.header || '' }} {{ tabs().classIncludeHeader || '' }}\"\n      [style.minHeight.px]=\"heightTabItem()\">\n      <div class=\"libs-ui-tab-header-center {{ configCss()?.headerCenter || '' }} {{ tabs().classIncludeHeaderCenter || '' }}\">\n        @for (item of tabs().items(); track item) {\n          <libs_ui-components-tabs-item\n            class=\"h-full w-full {{ tabs().classIncludeItem || '' }}\"\n            [tabs]=\"tabs()\"\n            [size]=\"size()\"\n            [(item)]=\"item\"\n            [step]=\"$index + 1\"\n            [disable]=\"disable()\"\n            [disableLabel]=\"disableLabel()\"\n            [keySelected]=\"keySelected()\"\n            [fieldLabel]=\"fieldLabel()\"\n            [fieldKey]=\"fieldKey()\"\n            [cssDefault]=\"($first ? configCss()?.first : configCss()?.other) || ''\"\n            [zIndex]=\"zIndex()\"\n            [mode]=\"mode()\"\n            [changeViewTab]=\"changeViewTab\"\n            [ignoreCalculatorTab]=\"ignoreCalculatorTab()\" />\n        }\n      </div>\n    </div>\n  </div>\n</div>\n<ng-template #menuEl>\n  <libs_ui-components-list\n    [config]=\"tabMoreListConfig()\"\n    [maxItemShow]=\"5\"\n    [hiddenInputSearch]=\"true\"\n    [paddingLeftItem]=\"true\"\n    (outSelectKey)=\"handlerSelectedKey($event)\" />\n</ng-template>\n"]}
|
|
472
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tabs.component.js","sourceRoot":"","sources":["../../../../../libs-ui/components/tabs/src/tabs.component.ts","../../../../../libs-ui/components/tabs/src/tabs.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, ChangeDetectionStrategy, Component, computed, DestroyRef, effect, ElementRef, inject, input, model, OnDestroy, OnInit, output, signal, untracked, viewChild, WritableSignal } from '@angular/core';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport { LibsUiComponentsButtonsButtonComponent } from '@libs-ui/components-buttons-button';\nimport { IDrop, LibsUiComponentsDragContainerDirective, LibsUiDragItemDirective } from '@libs-ui/components-drag-drop';\nimport { IListDataEmitKey, LibsUiComponentsListComponent } from '@libs-ui/components-list';\nimport { IPopover, IPopoverFunctionControlEvent, LibsUiComponentsPopoverComponent } from '@libs-ui/components-popover';\nimport { convertObjectToSignal, isNil, uuid } from '@libs-ui/utils';\nimport { TranslateService } from '@ngx-translate/core';\nimport { fromEvent, Subject } from 'rxjs';\nimport { debounceTime, takeUntil } from 'rxjs/operators';\nimport { ITabCssConfig, ITabs, ITabsFunctionControlEvent, ITabsItem, ITabsItemEvent, TYPE_TAB_MODE } from './interfaces/tab.interface';\nimport { LibsUiComponentsTabsItemComponent } from './item/item.component';\nimport { tabMoreListConfig } from './utils/tabs';\n\n@Component({\n  // eslint-disable-next-line @angular-eslint/component-selector\n  selector: 'libs_ui-components-tabs',\n  templateUrl: './tabs.component.html',\n  styleUrls: ['./tabs.component.scss'],\n  standalone: true,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  imports: [LibsUiComponentsDragContainerDirective, LibsUiDragItemDirective, LibsUiComponentsPopoverComponent, LibsUiComponentsButtonsButtonComponent, LibsUiComponentsTabsItemComponent, LibsUiComponentsListComponent],\n})\nexport class LibsUiComponentsTabsComponent implements OnInit, AfterViewInit, OnDestroy {\n  // #region PROPERTY\n  protected itemsDisplay = signal<Array<WritableSignal<ITabsItem>>>([]);\n  protected displayMoreItem = signal<boolean>(false);\n  protected tabMoreListConfig = computed(() => tabMoreListConfig(this.translate, this.fieldKey(), this.fieldLabel(), this.tabs(), this.disable()));\n  protected changeViewTab = new Subject<void>();\n  protected groupName = signal<string>(uuid());\n  protected stylesDragDropOverrideComputed = computed(() => this.updateStylesDragDropOverride());\n  /**\n   * V2 — số item đang hiển thị (specificDisplay !== false). Dùng cho mode `space-between`\n   * tính width đều cho các item visible (item hidden ở `position: absolute` không chiếm chỗ).\n   */\n  protected displayedCount = computed(() => {\n    if (!this.useCalculatorV2()) return this.itemsDisplay().length || 1;\n    const count = this.itemsDisplay().filter((s) => s().specificDisplay !== false).length;\n    return count || 1;\n  });\n\n  /** V2 — kích thước container do ResizeObserver cập nhật, dùng để compute synchronous. */\n  private containerWidthV2 = signal<number>(0);\n  private headerLeftWidthV2 = signal<number>(0);\n  private headerRightWidthV2 = signal<number>(0);\n  private resizeObserverV2: ResizeObserver | undefined;\n\n  private popoverFunctionControlEvent = signal<IPopoverFunctionControlEvent | undefined>(undefined);\n  private onDestroy = new Subject<void>();\n  private destroyRef = inject(DestroyRef);\n\n  // #region INPUT\n  readonly tabs = input.required<ITabs>();\n  readonly keySelected = model.required<string>();\n  readonly mode = input<TYPE_TAB_MODE>('left');\n  readonly fieldKey = input<string>('key');\n  readonly fieldLabel = input<string>('label');\n  readonly disable = input<boolean>();\n  readonly disableLabel = input<boolean>();\n  readonly heightTabItem = input<number>(40);\n  readonly ignoreCalculatorTab = input<boolean>(false);\n  readonly size = input<'langer' | 'medium'>('medium');\n  readonly allowDragDropPosition = input<boolean>();\n  readonly zIndex = input<number>();\n  readonly configCss = model<ITabCssConfig>();\n  readonly popoverShowMoreTabItem = input<IPopover>();\n  readonly checkCanChangeTabSelected = input<() => boolean | Promise<boolean>>();\n  readonly useEffectUpdateItems = input<boolean>();\n  /**\n   * V2 mode — khi `true`:\n   * - Bỏ container đo song song (không render 2 lần).\n   * - Dùng ResizeObserver thay MutationObserver/setTimeout/debounce.\n   * - Compute synchronous, không reorder items → không flicker.\n   * Mặc định `false` để giữ 100% behavior cũ (backward compatible).\n   */\n  readonly useCalculatorV2 = input<boolean>(false);\n\n  // #region OUTPUT\n  readonly outKeySelected = output<string>();\n  readonly outFunctionsControl = output<ITabsFunctionControlEvent>();\n  readonly outDragTabChange = output<void>();\n  readonly outDisplayMoreItem = output<boolean>();\n  readonly outAction = output<ITabsItemEvent>();\n\n  /* VIEW CHILD */\n  private readonly headerEl = viewChild.required<ElementRef>('headerEl');\n  private readonly headerLeftEl = viewChild.required<ElementRef>('headerLeftEl');\n  private readonly headerRightEl = viewChild.required<ElementRef>('headerRightEl');\n\n  /* INJECT*/\n  private translate = inject(TranslateService);\n\n  constructor() {\n    effect(() => {\n      const items = this.tabs()?.items();\n      if (!this.useEffectUpdateItems()) return;\n      untracked(() => {\n        this.updateItemsDisplay(items);\n      });\n    });\n\n    // V2 — effect tự động recompute khi container/headerLeft/headerRight đổi kích thước hoặc selected đổi.\n    effect(() => {\n      if (!this.useCalculatorV2()) return;\n      const containerWidth = this.containerWidthV2();\n      // Đọc cả các signal phụ thuộc để effect tự re-run khi chúng đổi.\n      this.headerLeftWidthV2();\n      this.headerRightWidthV2();\n      this.keySelected();\n      const items = this.tabs()?.items();\n      if (!containerWidth || !items?.length) return;\n      untracked(() => this.computeDisplayItemsV2(items));\n    });\n  }\n\n  ngOnInit() {\n    this.updateTabsCssConfig();\n    this.outFunctionsControl.emit(this.FunctionsControl);\n    if (!this.useEffectUpdateItems()) {\n      this.updateItemsDisplay(this.tabs()?.items());\n    }\n    fromEvent(window, 'resize')\n      .pipe(debounceTime(250), takeUntil(this.onDestroy))\n      .subscribe(() => {\n        if (!this.tabs().items().length) {\n          return;\n        }\n        // V2 không cần xử lý resize ở đây — ResizeObserver tự fire.\n        if (this.useCalculatorV2()) {\n          return;\n        }\n        this.displayMoreItem.set(false);\n        this.calculatorTabsItemDisplay();\n      });\n    // V1 path: preserve old behavior với debounce(20).\n    this.changeViewTab.pipe(debounceTime(20), takeUntil(this.onDestroy)).subscribe(() => {\n      if (this.useCalculatorV2()) return;\n      this.calculatorTabsItemDisplay();\n    });\n    // V2 path: chạy sync (không debounce) — ResizeObserver đã batch theo frame.\n    this.changeViewTab.pipe(takeUntilDestroyed(this.destroyRef)).subscribe(() => {\n      if (!this.useCalculatorV2()) return;\n      const items = this.tabs()?.items();\n      if (items?.length) this.computeDisplayItemsV2(items);\n    });\n  }\n\n  ngAfterViewInit() {\n    if (this.useCalculatorV2()) {\n      this.setupResizeObserverV2();\n    }\n  }\n\n  private setupResizeObserverV2() {\n    if (this.resizeObserverV2 || typeof ResizeObserver === 'undefined') {\n      return;\n    }\n    const headerEl = this.headerEl()?.nativeElement;\n    const headerLeftEl = this.headerLeftEl()?.nativeElement;\n    const headerRightEl = this.headerRightEl()?.nativeElement;\n    if (!headerEl) return;\n\n    this.resizeObserverV2 = new ResizeObserver((entries) => {\n      for (const entry of entries) {\n        const target = entry.target;\n        const width = (target as HTMLElement).clientWidth || 0;\n        switch (target) {\n          case headerEl:\n            if (this.containerWidthV2() !== width) this.containerWidthV2.set(width);\n            break;\n          case headerLeftEl:\n            if (this.headerLeftWidthV2() !== width) this.headerLeftWidthV2.set(width);\n            break;\n          case headerRightEl:\n            if (this.headerRightWidthV2() !== width) this.headerRightWidthV2.set(width);\n            break;\n        }\n      }\n    });\n    this.resizeObserverV2.observe(headerEl);\n    if (headerLeftEl) this.resizeObserverV2.observe(headerLeftEl);\n    if (headerRightEl) this.resizeObserverV2.observe(headerRightEl);\n  }\n\n  private updateItemsDisplay(items: Array<WritableSignal<ITabsItem>>) {\n    if (!items) return;\n    untracked(() => {\n      if (this.mode() !== 'left' || this.ignoreCalculatorTab()) {\n        items.forEach((item) => item.update((data) => ({ ...data, specificDisplay: true })));\n        this.itemsDisplay.set(items);\n        return;\n      }\n      if (this.useCalculatorV2()) {\n        // V2: itemsDisplay chứa toàn bộ items (không filter). ResizeObserver sẽ đo width\n        // và compute sẽ set specificDisplay flag — style binding ẩn item overflow.\n        items.forEach((item) => item.update((data) => ({ ...data, specificDisplay: true })));\n        this.itemsDisplay.set([...items]);\n        if (this.containerWidthV2()) {\n          this.computeDisplayItemsV2(items);\n        }\n        return;\n      }\n      this.calculatorTabsItemDisplay();\n    });\n  }\n\n  /* FUNCTIONS */\n  public get FunctionsControl(): ITabsFunctionControlEvent {\n    return {\n      addTabsItem: this.addTabsItem.bind(this),\n      calculatorTabsItemsDisplay: this.calculatorTabsItemDisplayDispatch.bind(this),\n      selectedTabsItem: this.handlerSelectedTabsItem.bind(this),\n    };\n  }\n\n  private updateTabsCssConfig() {\n    if (this.configCss()) {\n      return;\n    }\n    switch (this.mode()) {\n      case 'left':\n        this.configCss.set({\n          first: 'ml-[20px] mr-[16px]',\n          other: 'ml-[20px] mr-[16px]',\n        });\n        break;\n      case 'center':\n        this.configCss.set({\n          first: 'px-[12px] ml-[18px] mr-[18px]',\n          other: 'px-[12px] mx-[18px]',\n          header: 'flex justify-center',\n        });\n        break;\n      case 'center-has-line':\n        this.configCss.set({\n          first: 'px-[16px]',\n          other: 'px-[16px]',\n          headerCenter: 'items-center',\n        });\n        break;\n      case 'space-between':\n        this.configCss.set({\n          first: 'mx-auto',\n          other: 'mx-auto',\n          headerCenter: 'w-full',\n        });\n        break;\n    }\n  }\n\n  private updateStylesDragDropOverride() {\n    if (this.allowDragDropPosition()) {\n      return [\n        {\n          className: 'libs-ui-drag-drop-item-placeholder',\n          styles: '',\n        },\n        {\n          className: 'libs-ui-drag-drop-item',\n          styles: 'cursor: move;',\n        },\n        {\n          className: 'libs-ui-drag-drop-item-dragging',\n          styles: 'cursor: move; background: #dddddd;',\n        },\n      ];\n    }\n    return [\n      {\n        className: 'libs-ui-drag-drop-item',\n        styles: '',\n      },\n      {\n        className: 'libs-ui-drag-drop-item-disable',\n        styles: '',\n      },\n    ];\n  }\n\n  protected handlerDropContainer(event: IDrop) {\n    const { itemDragInfo } = event;\n    if (!itemDragInfo) {\n      return;\n    }\n    const items = this.tabs().items;\n    const { indexDrag, indexDrop } = itemDragInfo;\n    if (isNil(indexDrag) || isNil(indexDrop) || indexDrop === indexDrag) {\n      return;\n    }\n    const itemDrag = items()[indexDrag as number];\n    items.update((items) => {\n      items.splice(indexDrag as number, 1);\n      items.splice(indexDrop as number, 0, itemDrag);\n      return [...items];\n    });\n    this.outDragTabChange.emit();\n  }\n\n  protected handlerPopoverFunctionControlEvent(event: IPopoverFunctionControlEvent) {\n    this.popoverFunctionControlEvent.set(event);\n  }\n\n  private async handlerSelectedTabsItem(key: string, resetDisable = true) {\n    const itemSelected = this.tabs()\n      .items()\n      .find((item) => item()[this.fieldKey()] === key);\n    if (!itemSelected) {\n      return;\n    }\n    if (resetDisable) {\n      itemSelected.update((item) => ({ ...item, disable: false }));\n    }\n    this.handlerClickItem(itemSelected);\n  }\n\n  protected handlerSelectedKey(event: IListDataEmitKey | undefined) {\n    if (!event) {\n      return;\n    }\n    this.handlerClickItem(convertObjectToSignal(event.item));\n    this.outDragTabChange.emit();\n  }\n\n  protected async handlerClickItem(item: WritableSignal<ITabsItem>) {\n    if (item().disable || this.disable()) {\n      return;\n    }\n    const checkCanChangeTabSelected = this.checkCanChangeTabSelected();\n    if (checkCanChangeTabSelected) {\n      const state = await checkCanChangeTabSelected();\n      if (state) {\n        this.changeItemSelected(item);\n      }\n      return;\n    }\n    this.changeItemSelected(item);\n  }\n\n  private changeItemSelected(item: WritableSignal<ITabsItem>) {\n    this.keySelected.set(item()[this.fieldKey()]);\n    this.outKeySelected.emit(this.keySelected());\n    this.popoverFunctionControlEvent()?.removePopoverOverlay();\n    this.calculatorTabsItemDisplayDispatch();\n  }\n\n  protected async handlerAction(event: ITabsItemEvent) {\n    this.outAction.emit(event);\n  }\n\n  private async addTabsItem(item: WritableSignal<ITabsItem>, selected = true, addFirst?: boolean, indexAdd?: number) {\n    const items = this.tabs().items;\n    items.update((items) => {\n      if (addFirst) {\n        return [item, ...items];\n      }\n      if (indexAdd) {\n        items.splice(indexAdd, 0, item);\n        return items;\n      }\n      return [...items, item];\n    });\n    if (selected) {\n      this.handlerClickItem(item);\n    }\n  }\n\n  /** Dispatch sang nhánh V1 hoặc V2 dựa theo flag. Public API giữ nguyên signature. */\n  private async calculatorTabsItemDisplayDispatch() {\n    if (this.useCalculatorV2()) {\n      const items = this.tabs()?.items();\n      if (items?.length) this.computeDisplayItemsV2(items);\n      return;\n    }\n    await this.calculatorTabsItemDisplay();\n  }\n\n  protected async calculatorTabsItemDisplay() {\n    let items = this.tabs().items();\n    const indexItemSelected = items.findIndex((item) => item()[this.fieldKey()] === this.keySelected());\n    if (indexItemSelected < 0) {\n      return;\n    }\n    this.displayMoreItem.set(false);\n    let displayMoreItem = false;\n    const headerWidth = this.headerEl().nativeElement.clientWidth || 0;\n    const itemSelected = items[indexItemSelected];\n    const itemSelectedWidth = itemSelected().specificWidth;\n    let totalWidthItemsDisplay = (this.headerLeftEl().nativeElement.clientWidth || 0) + (this.headerRightEl().nativeElement.clientWidth || 0) + 32;\n    items.forEach((item, index) => {\n      if (!item().specificWidth) {\n        return;\n      }\n      item.update((data) => ({ ...data, specificDisplay: false }));\n      const itemWidth = item().specificWidth || 0;\n      const width = totalWidthItemsDisplay + itemWidth + (index < indexItemSelected ? itemSelectedWidth : 0);\n      totalWidthItemsDisplay += itemWidth;\n      if (width > headerWidth) {\n        displayMoreItem = true;\n        return;\n      }\n      item.update((data) => ({ ...data, specificDisplay: true }));\n    });\n    itemSelected.update((data) => ({ ...data, specificDisplay: true }));\n    const display = items.filter((item) => item().specificDisplay === true);\n    const notDisplay = items.filter((item) => item().specificDisplay === false);\n    items = display.concat(notDisplay);\n    items.forEach((item, index) => item.update((data) => ({ ...data, order: index })));\n    const sortedItems = [...items].sort((prev, next) => (prev().order || 0) - (next().order || 0));\n    // Check if order actually changed before setting to avoid triggering redundant cycles\n    const orderChanged = items.some((item, index) => item()[this.fieldKey()] !== sortedItems[index]()[this.fieldKey()]);\n\n    if (orderChanged) {\n      this.tabs().items.set(sortedItems);\n    }\n\n    this.displayMoreItem.set(displayMoreItem);\n    this.outDisplayMoreItem.emit(this.displayMoreItem());\n\n    const newItemsDisplay = this.tabs()\n      .items()\n      .filter((item) => item().specificDisplay);\n    this.itemsDisplay.set(newItemsDisplay);\n  }\n\n  /**\n   * V2 — Tính displayItems synchronous, không reorder, không setTimeout.\n   *\n   * Why: tránh flicker do reorder DOM + bỏ thuật toán \"cảm tính\" debounce.\n   * How to apply: gọi mỗi khi container width / headerLeft / headerRight / item widths / selected key đổi.\n   */\n  private computeDisplayItemsV2(items: Array<WritableSignal<ITabsItem>>) {\n    if (this.mode() !== 'left' || this.ignoreCalculatorTab()) {\n      items.forEach((item) => item.update((data) => ({ ...data, specificDisplay: true })));\n      this.itemsDisplay.set([...items]);\n      this.displayMoreItem.set(false);\n      this.outDisplayMoreItem.emit(false);\n      return;\n    }\n\n    const headerWidth = this.containerWidthV2();\n    if (!headerWidth) return;\n\n    const indexItemSelected = items.findIndex((item) => item()[this.fieldKey()] === this.keySelected());\n    if (indexItemSelected < 0) return;\n\n    const itemSelected = items[indexItemSelected];\n    const itemSelectedWidth = itemSelected().specificWidth || 0;\n    const reservedWidth = this.headerLeftWidthV2() + this.headerRightWidthV2() + 32;\n\n    let totalWidth = reservedWidth;\n    let displayMoreItem = false;\n\n    items.forEach((item, index) => {\n      const itemWidth = item().specificWidth || 0;\n      if (!itemWidth) {\n        // Chưa có width — tạm hiển thị để ResizeObserver có element mà đo.\n        item.update((data) => ({ ...data, specificDisplay: true }));\n        return;\n      }\n      // Reserve space cho selected nếu item này nằm trước selected.\n      const projected = totalWidth + itemWidth + (index < indexItemSelected ? itemSelectedWidth : 0);\n      totalWidth += itemWidth;\n      if (projected > headerWidth) {\n        item.update((data) => ({ ...data, specificDisplay: false }));\n        displayMoreItem = true;\n        return;\n      }\n      item.update((data) => ({ ...data, specificDisplay: true }));\n    });\n    // Selected luôn hiển thị.\n    itemSelected.update((data) => ({ ...data, specificDisplay: true }));\n\n    // V2: itemsDisplay chứa TẤT CẢ items — không filter. Item overflow được ẩn qua style binding\n    // (visibility: hidden + position: absolute) để giữ DOM stable, tránh mount/unmount gây flicker.\n    // ResizeObserver luôn đo được width vì mọi item luôn có DOM.\n    const allItems = [...items];\n    const currentDisplay = this.itemsDisplay();\n    // Chỉ set khi nội dung array thực sự đổi (tránh CD thừa).\n    const arrayChanged = allItems.length !== currentDisplay.length || allItems.some((it, i) => it !== currentDisplay[i]);\n    if (arrayChanged) {\n      this.itemsDisplay.set(allItems);\n    }\n\n    if (this.displayMoreItem() !== displayMoreItem) {\n      this.displayMoreItem.set(displayMoreItem);\n      this.outDisplayMoreItem.emit(displayMoreItem);\n    }\n  }\n\n  ngOnDestroy() {\n    this.resizeObserverV2?.disconnect();\n    this.resizeObserverV2 = undefined;\n    this.onDestroy.next();\n    this.onDestroy.complete();\n  }\n}\n","<div class=\"libs-ui-tab\">\n  <div\n    #headerEl\n    class=\"libs-ui-tab-header z-[1] {{ configCss()?.header || '' }} {{ tabs().classIncludeHeader || '' }}\"\n    [style.minHeight.px]=\"heightTabItem()\">\n    <div\n      #headerLeftEl\n      class=\"libs-ui-tab-header-left\">\n      <ng-content select=\"div.libs-ui-tab-header-left\"></ng-content>\n    </div>\n    <div class=\"libs-ui-tab-header-center {{ configCss()?.headerCenter || '' }} {{ tabs().classIncludeHeaderCenter || '' }}\">\n      <div\n        class=\"!flex w-full\"\n        #elementContainerEl\n        LibsUiComponentsDragContainerDirective\n        [stylesOverride]=\"stylesDragDropOverrideComputed()\"\n        [groupName]=\"groupName()\"\n        [(items)]=\"itemsDisplay\"\n        [directionDrag]=\"'horizontal'\"\n        [disableDragContainer]=\"!allowDragDropPosition()\"\n        [acceptDragSameGroup]=\"allowDragDropPosition()\"\n        (outDroppedContainer)=\"handlerDropContainer($event)\">\n        @for (item of itemsDisplay(); track item) {\n          <div\n            LibsUiDragItemDirective\n            [disable]=\"disable() || !allowDragDropPosition() || (useCalculatorV2() && item().specificDisplay === false)\"\n            [elementContainer]=\"elementContainerEl\"\n            [dragBoundary]=\"true\"\n            [dragBoundaryAcceptMouseLeaveContainer]=\"true\"\n            class=\"relative libs-ui-tab-item-container\"\n            [style.width.px]=\"mode() === 'space-between' ? elementContainerEl.clientWidth / displayedCount() : undefined\"\n            [class.flex]=\"mode() === 'center-has-line'\"\n            [class.items-center]=\"mode() === 'center-has-line'\"\n            [style.visibility]=\"useCalculatorV2() && item().specificDisplay === false ? 'hidden' : null\"\n            [style.position]=\"useCalculatorV2() && item().specificDisplay === false ? 'absolute' : null\"\n            [style.pointer-events]=\"useCalculatorV2() && item().specificDisplay === false ? 'none' : null\"\n            [attr.aria-hidden]=\"useCalculatorV2() && item().specificDisplay === false ? 'true' : null\">\n            @if (allowDragDropPosition() && !disable()) {\n              <span class=\"libs-ui-icon-arrange text-[#9ca2ad] absolute top-[14px] left-[4px]\"></span>\n            }\n            <libs_ui-components-tabs-item\n              class=\"h-full w-full  {{ tabs().classIncludeItem || '' }}\"\n              [tabs]=\"tabs()\"\n              [size]=\"size()\"\n              [(item)]=\"item\"\n              [step]=\"$index + 1\"\n              [class.!pointer-events-none]=\"item().disable || disable()\"\n              [disable]=\"item().disable || disable()\"\n              [disableLabel]=\"disableLabel()\"\n              [keySelected]=\"keySelected()\"\n              [fieldLabel]=\"fieldLabel()\"\n              [fieldKey]=\"fieldKey()\"\n              [cssDefault]=\"($first ? configCss()?.first : configCss()?.other) || ''\"\n              [zIndex]=\"zIndex()\"\n              [mode]=\"mode()\"\n              [ignoreCalculatorTab]=\"ignoreCalculatorTab() || !useCalculatorV2()\"\n              [useCalculatorV2]=\"useCalculatorV2()\"\n              [changeViewTab]=\"changeViewTab\"\n              (click)=\"handlerClickItem(item)\"\n              (outAction)=\"handlerAction($event)\" />\n            @if (mode() === 'center-has-line' && !$last) {\n              <div class=\"w-[40px] h-[1px] bg-[#e6e7ea]\"></div>\n            }\n          </div>\n        }\n      </div>\n    </div>\n    <div\n      class=\"flex items-center\"\n      [class.ml-auto]=\"displayMoreItem() && !tabs().viewMoreIgnoreMarginLeft\">\n      @if (displayMoreItem()) {\n        <libs_ui-components-popover\n          class=\"w-full h-full flex items-center\"\n          [mode]=\"'click-toggle'\"\n          [ignoreHiddenPopoverContentWhenMouseLeave]=\"true\"\n          [config]=\"{\n            zIndex: popoverShowMoreTabItem()?.config?.zIndex || 1000,\n            maxHeight: popoverShowMoreTabItem()?.config?.maxHeight || 287,\n            maxWidth: popoverShowMoreTabItem()?.config?.maxWidth || 2048,\n            width: popoverShowMoreTabItem()?.config?.width || 277,\n            direction: popoverShowMoreTabItem()?.config?.direction || 'bottom',\n            template: popoverShowMoreTabItem()?.config?.template || menuEl,\n            whiteTheme: true,\n            ignoreArrow: true,\n            position: popoverShowMoreTabItem()?.config?.position || { mode: 'end', distance: 0 },\n          }\"\n          (outFunctionsControl)=\"handlerPopoverFunctionControlEvent($event)\">\n          <libs_ui-components-buttons-button\n            [type]=\"'button-link-third'\"\n            [classInclude]=\"'!p-[8px]'\"\n            [iconOnlyType]=\"true\"\n            [classIconLeft]=\"'libs-ui-icon-more-vertical rotate-90 text-[16px] mr-0'\"\n            [popover]=\"{ config: { content: popoverShowMoreTabItem()?.config?.content || 'i18n_view_more' } }\"\n            [ignoreStopPropagationEvent]=\"true\" />\n        </libs_ui-components-popover>\n      }\n    </div>\n    <div\n      #headerRightEl\n      class=\"libs-ui-tab-header-right {{ tabs().classIncludeHeaderRight || '' }}\">\n      <ng-content select=\"div.libs-ui-tab-header-right\"></ng-content>\n    </div>\n  </div>\n  @if (!useCalculatorV2()) {\n    <div class=\"absolute top-0 z-0 w-full\">\n      <div\n        class=\"libs-ui-tab-header {{ configCss()?.header || '' }} {{ tabs().classIncludeHeader || '' }}\"\n        [style.minHeight.px]=\"heightTabItem()\">\n        <div class=\"libs-ui-tab-header-center {{ configCss()?.headerCenter || '' }} {{ tabs().classIncludeHeaderCenter || '' }}\">\n          @for (item of tabs().items(); track item) {\n            <libs_ui-components-tabs-item\n              class=\"h-full w-full {{ tabs().classIncludeItem || '' }}\"\n              [tabs]=\"tabs()\"\n              [size]=\"size()\"\n              [(item)]=\"item\"\n              [step]=\"$index + 1\"\n              [disable]=\"disable()\"\n              [disableLabel]=\"disableLabel()\"\n              [keySelected]=\"keySelected()\"\n              [fieldLabel]=\"fieldLabel()\"\n              [fieldKey]=\"fieldKey()\"\n              [cssDefault]=\"($first ? configCss()?.first : configCss()?.other) || ''\"\n              [zIndex]=\"zIndex()\"\n              [mode]=\"mode()\"\n              [changeViewTab]=\"changeViewTab\"\n              [ignoreCalculatorTab]=\"ignoreCalculatorTab()\" />\n          }\n        </div>\n      </div>\n    </div>\n  }\n</div>\n<ng-template #menuEl>\n  <libs_ui-components-list\n    [config]=\"tabMoreListConfig()\"\n    [maxItemShow]=\"5\"\n    [hiddenInputSearch]=\"true\"\n    [paddingLeftItem]=\"true\"\n    (outSelectKey)=\"handlerSelectedKey($event)\" />\n</ng-template>\n"]}
|