@libs-ui/components-tabs 0.2.306-4 → 0.2.307-0

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.
@@ -50,17 +50,19 @@ export class LibsUiComponentsTabsComponent {
50
50
  translate = inject(TranslateService);
51
51
  ngOnInit() {
52
52
  this.updateTabsCssConfig();
53
- this.outFunctionsControl.emit({
54
- addTabsItem: this.addTabsItem.bind(this),
55
- calculatorTabsItemsDisplay: this.calculatorTabsItemDisplay.bind(this),
56
- selectedTabsItem: this.handlerSelectedTabsItem.bind(this)
57
- });
53
+ this.outFunctionsControl.emit(this.FunctionsControl);
58
54
  if (this.mode() !== 'left' || this.ignoreCalculatorTab()) {
59
- this.tabs().items().map(item => item.update(data => ({ ...data, specificDisplay: true })));
60
- this.itemsDisplay.set(this.tabs().items().filter(item => item().specificDisplay));
55
+ this.tabs()
56
+ .items()
57
+ .map((item) => item.update((data) => ({ ...data, specificDisplay: true })));
58
+ this.itemsDisplay.set(this.tabs()
59
+ .items()
60
+ .filter((item) => item().specificDisplay));
61
61
  return;
62
62
  }
63
- fromEvent(window, 'resize').pipe(debounceTime(250), takeUntil(this.onDestroy)).subscribe(() => {
63
+ fromEvent(window, 'resize')
64
+ .pipe(debounceTime(250), takeUntil(this.onDestroy))
65
+ .subscribe(() => {
64
66
  if (!this.tabs().items().length) {
65
67
  return;
66
68
  }
@@ -70,6 +72,13 @@ export class LibsUiComponentsTabsComponent {
70
72
  this.changeViewTab.pipe(debounceTime(20), takeUntil(this.onDestroy)).subscribe(() => this.calculatorTabsItemDisplay());
71
73
  }
72
74
  /* FUNCTIONS */
75
+ get FunctionsControl() {
76
+ return {
77
+ addTabsItem: this.addTabsItem.bind(this),
78
+ calculatorTabsItemsDisplay: this.calculatorTabsItemDisplay.bind(this),
79
+ selectedTabsItem: this.handlerSelectedTabsItem.bind(this),
80
+ };
81
+ }
73
82
  updateTabsCssConfig() {
74
83
  if (this.configCss()) {
75
84
  return;
@@ -78,28 +87,28 @@ export class LibsUiComponentsTabsComponent {
78
87
  case 'left':
79
88
  this.configCss.set({
80
89
  first: 'ml-[20px] mr-[16px]',
81
- other: 'ml-[20px] mr-[16px]'
90
+ other: 'ml-[20px] mr-[16px]',
82
91
  });
83
92
  break;
84
93
  case 'center':
85
94
  this.configCss.set({
86
95
  first: 'px-[12px] ml-[18px] mr-[18px]',
87
96
  other: 'px-[12px] mx-[18px]',
88
- header: 'flex justify-center'
97
+ header: 'flex justify-center',
89
98
  });
90
99
  break;
91
100
  case 'center-has-line':
92
101
  this.configCss.set({
93
102
  first: 'px-[16px]',
94
103
  other: 'px-[16px]',
95
- headerCenter: 'items-center'
104
+ headerCenter: 'items-center',
96
105
  });
97
106
  break;
98
107
  case 'space-between':
99
108
  this.configCss.set({
100
109
  first: 'mx-auto',
101
110
  other: 'mx-auto',
102
- headerCenter: 'w-full'
111
+ headerCenter: 'w-full',
103
112
  });
104
113
  break;
105
114
  }
@@ -109,27 +118,27 @@ export class LibsUiComponentsTabsComponent {
109
118
  return [
110
119
  {
111
120
  className: 'libs-ui-drag-drop-item-placeholder',
112
- styles: ''
121
+ styles: '',
113
122
  },
114
123
  {
115
124
  className: 'libs-ui-drag-drop-item',
116
- styles: 'cursor: move;'
125
+ styles: 'cursor: move;',
117
126
  },
118
127
  {
119
128
  className: 'libs-ui-drag-drop-item-dragging',
120
- styles: 'cursor: move; background: #dddddd;'
121
- }
129
+ styles: 'cursor: move; background: #dddddd;',
130
+ },
122
131
  ];
123
132
  }
124
133
  return [
125
134
  {
126
135
  className: 'libs-ui-drag-drop-item',
127
- styles: ''
136
+ styles: '',
128
137
  },
129
138
  {
130
139
  className: 'libs-ui-drag-drop-item-disable',
131
- styles: ''
132
- }
140
+ styles: '',
141
+ },
133
142
  ];
134
143
  }
135
144
  handlerDropContainer(event) {
@@ -143,7 +152,7 @@ export class LibsUiComponentsTabsComponent {
143
152
  return;
144
153
  }
145
154
  const itemDrag = items()[indexDrag];
146
- items.update(items => {
155
+ items.update((items) => {
147
156
  items.splice(indexDrag, 1);
148
157
  items.splice(indexDrop, 0, itemDrag);
149
158
  return [...items];
@@ -154,12 +163,14 @@ export class LibsUiComponentsTabsComponent {
154
163
  this.popoverFunctionControlEvent.set(event);
155
164
  }
156
165
  async handlerSelectedTabsItem(key, resetDisable = true) {
157
- const itemSelected = this.tabs().items().find(item => item()[this.fieldKey()] === key);
166
+ const itemSelected = this.tabs()
167
+ .items()
168
+ .find((item) => item()[this.fieldKey()] === key);
158
169
  if (!itemSelected) {
159
170
  return;
160
171
  }
161
172
  if (resetDisable) {
162
- itemSelected.update(item => ({ ...item, disable: false }));
173
+ itemSelected.update((item) => ({ ...item, disable: false }));
163
174
  }
164
175
  this.handlerClickItem(itemSelected);
165
176
  }
@@ -195,7 +206,7 @@ export class LibsUiComponentsTabsComponent {
195
206
  }
196
207
  async addTabsItem(item, selected = true, addFirst) {
197
208
  const items = this.tabs().items;
198
- items.update(items => {
209
+ items.update((items) => {
199
210
  if (addFirst) {
200
211
  return [item, ...items];
201
212
  }
@@ -207,7 +218,7 @@ export class LibsUiComponentsTabsComponent {
207
218
  }
208
219
  async calculatorTabsItemDisplay() {
209
220
  let items = this.tabs().items();
210
- const indexItemSelected = items.findIndex(item => item()[this.fieldKey()] === this.keySelected());
221
+ const indexItemSelected = items.findIndex((item) => item()[this.fieldKey()] === this.keySelected());
211
222
  if (indexItemSelected < 0) {
212
223
  return;
213
224
  }
@@ -221,7 +232,7 @@ export class LibsUiComponentsTabsComponent {
221
232
  if (!item().specificWidth) {
222
233
  return;
223
234
  }
224
- item.update(data => ({ ...data, specificDisplay: false }));
235
+ item.update((data) => ({ ...data, specificDisplay: false }));
225
236
  const itemWidth = item().specificWidth || 0;
226
237
  const width = totalWidthItemsDisplay + itemWidth + (index < indexItemSelected ? itemSelectedWidth : 0);
227
238
  totalWidthItemsDisplay += itemWidth;
@@ -229,34 +240,29 @@ export class LibsUiComponentsTabsComponent {
229
240
  displayMoreItem = true;
230
241
  return;
231
242
  }
232
- item.update(data => ({ ...data, specificDisplay: true }));
243
+ item.update((data) => ({ ...data, specificDisplay: true }));
233
244
  });
234
- itemSelected.update(data => ({ ...data, specificDisplay: true }));
235
- const display = items.filter(item => item().specificDisplay === true);
236
- const notDisplay = items.filter(item => item().specificDisplay === false);
245
+ itemSelected.update((data) => ({ ...data, specificDisplay: true }));
246
+ const display = items.filter((item) => item().specificDisplay === true);
247
+ const notDisplay = items.filter((item) => item().specificDisplay === false);
237
248
  items = display.concat(notDisplay);
238
- items.forEach((item, index) => item.update(data => ({ ...data, order: index })));
249
+ items.forEach((item, index) => item.update((data) => ({ ...data, order: index })));
239
250
  this.tabs().items.set(items.sort((prev, next) => (prev().order || 0) - (next().order || 0)));
240
251
  this.displayMoreItem.set(displayMoreItem);
241
252
  this.outDisplayMoreItem.emit(this.displayMoreItem());
242
- this.itemsDisplay.set(this.tabs().items().filter(item => item().specificDisplay));
253
+ this.itemsDisplay.set(this.tabs()
254
+ .items()
255
+ .filter((item) => item().specificDisplay));
243
256
  }
244
257
  ngOnDestroy() {
245
258
  this.onDestroy.next();
246
259
  this.onDestroy.complete();
247
260
  }
248
261
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: LibsUiComponentsTabsComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
249
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", 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 } }, 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 #headerEl\n class=\"libs-ui-tab-header z-[1] {{ configCss()?.header || '' }} {{ tabs().classIncludeHeader || '' }}\"\n [style.minHeight.px]=\"heightTabItem()\">\n <div #headerLeftEl\n class='libs-ui-tab-header-left'>\n <ng-content select=\"div.libs-ui-tab-header-left\"></ng-content>\n </div>\n <div\n class=\"libs-ui-tab-header-center {{ configCss()?.headerCenter || '' }} {{ tabs().classIncludeHeaderCenter || '' }}\">\n <div 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 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 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 class=\"flex items-center\"\n [class.ml-auto]=\"displayMoreItem() && !tabs().viewMoreIgnoreMarginLeft\">\n @if (displayMoreItem()) {\n <libs_ui-components-popover 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 [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 #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 class=\"libs-ui-tab-header {{ configCss()?.header || '' }} {{ tabs().classIncludeHeader || '' }}\"\n [style.minHeight.px]=\"heightTabItem()\">\n <div\n class=\"libs-ui-tab-header-center {{ configCss()?.headerCenter || '' }} {{ tabs().classIncludeHeaderCenter || '' }}\">\n @for (item of tabs().items(); track item) {\n <libs_ui-components-tabs-item 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 [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"], 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", "resetKeyWhenSelectAllKeyDropdown", "ignoreClassDisableDefaultWhenUseKeysDisableItem"], outputs: ["outSelectKey", "outSelectMultiKey", "outUnSelectMultiKey", "outClickButtonOther", "outFieldKey", "outChangeView", "outKeySearch", "outLoading", "outFunctionsControl", "outChangStageFlagMousePopover", "outLoadItemsComplete"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
262
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", 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 } }, 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"], 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", "resetKeyWhenSelectAllKeyDropdown", "ignoreClassDisableDefaultWhenUseKeysDisableItem"], outputs: ["outSelectKey", "outSelectMultiKey", "outUnSelectMultiKey", "outClickButtonOther", "outFieldKey", "outChangeView", "outKeySearch", "outLoading", "outFunctionsControl", "outChangStageFlagMousePopover", "outLoadItemsComplete"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
250
263
  }
251
264
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: LibsUiComponentsTabsComponent, decorators: [{
252
265
  type: Component,
253
- args: [{ selector: 'libs_ui-components-tabs', standalone: true, changeDetection: ChangeDetectionStrategy.OnPush, imports: [
254
- LibsUiComponentsDragContainerDirective,
255
- LibsUiDragItemDirective,
256
- LibsUiComponentsPopoverComponent,
257
- LibsUiComponentsButtonsButtonComponent,
258
- LibsUiComponentsTabsItemComponent,
259
- LibsUiComponentsListComponent
260
- ], template: "<div class=\"libs-ui-tab\">\n <div #headerEl\n class=\"libs-ui-tab-header z-[1] {{ configCss()?.header || '' }} {{ tabs().classIncludeHeader || '' }}\"\n [style.minHeight.px]=\"heightTabItem()\">\n <div #headerLeftEl\n class='libs-ui-tab-header-left'>\n <ng-content select=\"div.libs-ui-tab-header-left\"></ng-content>\n </div>\n <div\n class=\"libs-ui-tab-header-center {{ configCss()?.headerCenter || '' }} {{ tabs().classIncludeHeaderCenter || '' }}\">\n <div 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 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 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 class=\"flex items-center\"\n [class.ml-auto]=\"displayMoreItem() && !tabs().viewMoreIgnoreMarginLeft\">\n @if (displayMoreItem()) {\n <libs_ui-components-popover 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 [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 #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 class=\"libs-ui-tab-header {{ configCss()?.header || '' }} {{ tabs().classIncludeHeader || '' }}\"\n [style.minHeight.px]=\"heightTabItem()\">\n <div\n class=\"libs-ui-tab-header-center {{ configCss()?.headerCenter || '' }} {{ tabs().classIncludeHeaderCenter || '' }}\">\n @for (item of tabs().items(); track item) {\n <libs_ui-components-tabs-item 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 [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"] }]
266
+ 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 / (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"] }]
261
267
  }] });
262
- //# 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, ElementRef, inject, input, model, OnDestroy, OnInit, output, signal, 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: [\n    LibsUiComponentsDragContainerDirective,\n    LibsUiDragItemDirective,\n    LibsUiComponentsPopoverComponent,\n    LibsUiComponentsButtonsButtonComponent,\n    LibsUiComponentsTabsItemComponent,\n    LibsUiComponentsListComponent\n  ]\n})\nexport class LibsUiComponentsTabsComponent implements OnInit, OnDestroy {\n\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\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  ngOnInit() {\n    this.updateTabsCssConfig();\n    this.outFunctionsControl.emit({\n      addTabsItem: this.addTabsItem.bind(this),\n      calculatorTabsItemsDisplay: this.calculatorTabsItemDisplay.bind(this),\n      selectedTabsItem: this.handlerSelectedTabsItem.bind(this)\n    });\n    if (this.mode() !== 'left' || this.ignoreCalculatorTab()) {\n      this.tabs().items().map(item => item.update(data => ({ ...data, specificDisplay: true })));\n      this.itemsDisplay.set(this.tabs().items().filter(item => item().specificDisplay));\n      return;\n    }\n    fromEvent(window, 'resize').pipe(debounceTime(250), takeUntil(this.onDestroy)).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  /* FUNCTIONS */\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().items().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) {\n    const items = this.tabs().items;\n    items.update(items => {\n      if (addFirst) {\n        return [item, ...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    this.tabs().items.set(items.sort((prev, next) => (prev().order || 0) - (next().order || 0)));\n    this.displayMoreItem.set(displayMoreItem);\n    this.outDisplayMoreItem.emit(this.displayMoreItem());\n    this.itemsDisplay.set(this.tabs().items().filter(item => item().specificDisplay));\n  }\n\n  ngOnDestroy() {\n    this.onDestroy.next();\n    this.onDestroy.complete();\n  }\n\n}","<div class=\"libs-ui-tab\">\n  <div #headerEl\n    class=\"libs-ui-tab-header z-[1] {{ configCss()?.header || '' }} {{ tabs().classIncludeHeader || '' }}\"\n    [style.minHeight.px]=\"heightTabItem()\">\n    <div #headerLeftEl\n      class='libs-ui-tab-header-left'>\n      <ng-content select=\"div.libs-ui-tab-header-left\"></ng-content>\n    </div>\n    <div\n      class=\"libs-ui-tab-header-center {{ configCss()?.headerCenter || '' }} {{ tabs().classIncludeHeaderCenter || '' }}\">\n      <div 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 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 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 class=\"flex items-center\"\n      [class.ml-auto]=\"displayMoreItem() && !tabs().viewMoreIgnoreMarginLeft\">\n      @if (displayMoreItem()) {\n        <libs_ui-components-popover 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 [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 #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 class=\"libs-ui-tab-header {{ configCss()?.header || '' }} {{ tabs().classIncludeHeader || '' }}\"\n      [style.minHeight.px]=\"heightTabItem()\">\n      <div\n        class=\"libs-ui-tab-header-center {{ configCss()?.headerCenter || '' }} {{ tabs().classIncludeHeaderCenter || '' }}\">\n        @for (item of tabs().items(); track item) {\n          <libs_ui-components-tabs-item 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 [config]=\"tabMoreListConfig()\"\n    [maxItemShow]=\"5\"\n    [hiddenInputSearch]=\"true\"\n    [paddingLeftItem]=\"true\"\n    (outSelectKey)=\"handlerSelectedKey($event)\" />\n</ng-template>\n"]}
268
+ //# 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":"AAAA,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAE,QAAQ,EAAc,MAAM,EAAE,KAAK,EAAE,KAAK,EAAqB,MAAM,EAAE,MAAM,EAAE,SAAS,EAAkB,MAAM,eAAe,CAAC;AAC7K,OAAO,EAAE,sCAAsC,EAAE,MAAM,oCAAoC,CAAC;AAC5F,OAAO,EAAS,sCAAsC,EAAE,uBAAuB,EAAE,MAAM,+BAA+B,CAAC;AACvH,OAAO,EAAoB,6BAA6B,EAAE,MAAM,0BAA0B,CAAC;AAC3F,OAAO,EAA0C,gCAAgC,EAAE,MAAM,6BAA6B,CAAC;AACvH,OAAO,EAAE,qBAAqB,EAAE,KAAK,EAAE,IAAI,EAAE,MAAM,gBAAgB,CAAC;AACpE,OAAO,EAAE,gBAAgB,EAAE,MAAM,qBAAqB,CAAC;AACvD,OAAO,EAAE,SAAS,EAAE,OAAO,EAAE,MAAM,MAAM,CAAC;AAC1C,OAAO,EAAE,YAAY,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAEzD,OAAO,EAAE,iCAAiC,EAAE,MAAM,uBAAuB,CAAC;AAC1E,OAAO,EAAE,iBAAiB,EAAE,MAAM,cAAc,CAAC;;AAWjD,MAAM,OAAO,6BAA6B;IACxC,mBAAmB;IACT,YAAY,GAAG,MAAM,CAAmC,EAAE,CAAC,CAAC;IAC5D,eAAe,GAAG,MAAM,CAAU,KAAK,CAAC,CAAC;IACzC,iBAAiB,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC,iBAAiB,CAAC,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,QAAQ,EAAE,EAAE,IAAI,CAAC,UAAU,EAAE,EAAE,IAAI,CAAC,IAAI,EAAE,EAAE,IAAI,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC;IACvI,aAAa,GAAG,IAAI,OAAO,EAAQ,CAAC;IACpC,SAAS,GAAG,MAAM,CAAS,IAAI,EAAE,CAAC,CAAC;IACnC,8BAA8B,GAAG,QAAQ,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,4BAA4B,EAAE,CAAC,CAAC;IAEvF,2BAA2B,GAAG,MAAM,CAA2C,SAAS,CAAC,CAAC;IAC1F,SAAS,GAAG,IAAI,OAAO,EAAQ,CAAC;IAExC,gBAAgB;IACP,IAAI,GAAG,KAAK,CAAC,QAAQ,EAAS,CAAC;IAC/B,WAAW,GAAG,KAAK,CAAC,QAAQ,EAAU,CAAC;IACvC,IAAI,GAAG,KAAK,CAAgB,MAAM,CAAC,CAAC;IACpC,QAAQ,GAAG,KAAK,CAAS,KAAK,CAAC,CAAC;IAChC,UAAU,GAAG,KAAK,CAAS,OAAO,CAAC,CAAC;IACpC,OAAO,GAAG,KAAK,EAAW,CAAC;IAC3B,YAAY,GAAG,KAAK,EAAW,CAAC;IAChC,aAAa,GAAG,KAAK,CAAS,EAAE,CAAC,CAAC;IAClC,mBAAmB,GAAG,KAAK,CAAU,KAAK,CAAC,CAAC;IAC5C,IAAI,GAAG,KAAK,CAAsB,QAAQ,CAAC,CAAC;IAC5C,qBAAqB,GAAG,KAAK,EAAW,CAAC;IACzC,MAAM,GAAG,KAAK,EAAU,CAAC;IACzB,SAAS,GAAG,KAAK,EAAiB,CAAC;IACnC,sBAAsB,GAAG,KAAK,EAAY,CAAC;IAC3C,yBAAyB,GAAG,KAAK,EAAoC,CAAC;IAE/E,iBAAiB;IACR,cAAc,GAAG,MAAM,EAAU,CAAC;IAClC,mBAAmB,GAAG,MAAM,EAA6B,CAAC;IAC1D,gBAAgB,GAAG,MAAM,EAAQ,CAAC;IAClC,kBAAkB,GAAG,MAAM,EAAW,CAAC;IACvC,SAAS,GAAG,MAAM,EAAkB,CAAC;IAE9C,gBAAgB;IACC,QAAQ,GAAG,SAAS,CAAC,QAAQ,CAAa,UAAU,CAAC,CAAC;IACtD,YAAY,GAAG,SAAS,CAAC,QAAQ,CAAa,cAAc,CAAC,CAAC;IAC9D,aAAa,GAAG,SAAS,CAAC,QAAQ,CAAa,eAAe,CAAC,CAAC;IAEjF,WAAW;IACH,SAAS,GAAG,MAAM,CAAC,gBAAgB,CAAC,CAAC;IAE7C,QAAQ;QACN,IAAI,CAAC,mBAAmB,EAAE,CAAC;QAC3B,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC;QACrD,IAAI,IAAI,CAAC,IAAI,EAAE,KAAK,MAAM,IAAI,IAAI,CAAC,mBAAmB,EAAE,EAAE,CAAC;YACzD,IAAI,CAAC,IAAI,EAAE;iBACR,KAAK,EAAE;iBACP,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC,EAAE,GAAG,IAAI,EAAE,eAAe,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC;YAC9E,IAAI,CAAC,YAAY,CAAC,GAAG,CACnB,IAAI,CAAC,IAAI,EAAE;iBACR,KAAK,EAAE;iBACP,MAAM,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,EAAE,CAAC,eAAe,CAAC,CAC5C,CAAC;YACF,OAAO;QACT,CAAC;QACD,SAAS,CAAC,MAAM,EAAE,QAAQ,CAAC;aACxB,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,EAAE,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;aAClD,SAAS,CAAC,GAAG,EAAE;YACd,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,CAAC,KAAK,EAAE,CAAC,MAAM,EAAE,CAAC;gBAChC,OAAO;YACT,CAAC;YACD,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;YAChC,IAAI,CAAC,yBAAyB,EAAE,CAAC;QACnC,CAAC,CAAC,CAAC;QACL,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,YAAY,CAAC,EAAE,CAAC,EAAE,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,SAAS,CAAC,GAAG,EAAE,CAAC,IAAI,CAAC,yBAAyB,EAAE,CAAC,CAAC;IACzH,CAAC;IAED,eAAe;IACf,IAAW,gBAAgB;QACzB,OAAO;YACL,WAAW,EAAE,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,IAAI,CAAC;YACxC,0BAA0B,EAAE,IAAI,CAAC,yBAAyB,CAAC,IAAI,CAAC,IAAI,CAAC;YACrE,gBAAgB,EAAE,IAAI,CAAC,uBAAuB,CAAC,IAAI,CAAC,IAAI,CAAC;SAC1D,CAAC;IACJ,CAAC;IAEO,mBAAmB;QACzB,IAAI,IAAI,CAAC,SAAS,EAAE,EAAE,CAAC;YACrB,OAAO;QACT,CAAC;QACD,QAAQ,IAAI,CAAC,IAAI,EAAE,EAAE,CAAC;YACpB,KAAK,MAAM;gBACT,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC;oBACjB,KAAK,EAAE,qBAAqB;oBAC5B,KAAK,EAAE,qBAAqB;iBAC7B,CAAC,CAAC;gBACH,MAAM;YACR,KAAK,QAAQ;gBACX,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC;oBACjB,KAAK,EAAE,+BAA+B;oBACtC,KAAK,EAAE,qBAAqB;oBAC5B,MAAM,EAAE,qBAAqB;iBAC9B,CAAC,CAAC;gBACH,MAAM;YACR,KAAK,iBAAiB;gBACpB,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC;oBACjB,KAAK,EAAE,WAAW;oBAClB,KAAK,EAAE,WAAW;oBAClB,YAAY,EAAE,cAAc;iBAC7B,CAAC,CAAC;gBACH,MAAM;YACR,KAAK,eAAe;gBAClB,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC;oBACjB,KAAK,EAAE,SAAS;oBAChB,KAAK,EAAE,SAAS;oBAChB,YAAY,EAAE,QAAQ;iBACvB,CAAC,CAAC;gBACH,MAAM;QACV,CAAC;IACH,CAAC;IAEO,4BAA4B;QAClC,IAAI,IAAI,CAAC,qBAAqB,EAAE,EAAE,CAAC;YACjC,OAAO;gBACL;oBACE,SAAS,EAAE,oCAAoC;oBAC/C,MAAM,EAAE,EAAE;iBACX;gBACD;oBACE,SAAS,EAAE,wBAAwB;oBACnC,MAAM,EAAE,eAAe;iBACxB;gBACD;oBACE,SAAS,EAAE,iCAAiC;oBAC5C,MAAM,EAAE,oCAAoC;iBAC7C;aACF,CAAC;QACJ,CAAC;QACD,OAAO;YACL;gBACE,SAAS,EAAE,wBAAwB;gBACnC,MAAM,EAAE,EAAE;aACX;YACD;gBACE,SAAS,EAAE,gCAAgC;gBAC3C,MAAM,EAAE,EAAE;aACX;SACF,CAAC;IACJ,CAAC;IAES,oBAAoB,CAAC,KAAY;QACzC,MAAM,EAAE,YAAY,EAAE,GAAG,KAAK,CAAC;QAC/B,IAAI,CAAC,YAAY,EAAE,CAAC;YAClB,OAAO;QACT,CAAC;QACD,MAAM,KAAK,GAAG,IAAI,CAAC,IAAI,EAAE,CAAC,KAAK,CAAC;QAChC,MAAM,EAAE,SAAS,EAAE,SAAS,EAAE,GAAG,YAAY,CAAC;QAC9C,IAAI,KAAK,CAAC,SAAS,CAAC,IAAI,KAAK,CAAC,SAAS,CAAC,IAAI,SAAS,KAAK,SAAS,EAAE,CAAC;YACpE,OAAO;QACT,CAAC;QACD,MAAM,QAAQ,GAAG,KAAK,EAAE,CAAC,SAAmB,CAAC,CAAC;QAC9C,KAAK,CAAC,MAAM,CAAC,CAAC,KAAK,EAAE,EAAE;YACrB,KAAK,CAAC,MAAM,CAAC,SAAmB,EAAE,CAAC,CAAC,CAAC;YACrC,KAAK,CAAC,MAAM,CAAC,SAAmB,EAAE,CAAC,EAAE,QAAQ,CAAC,CAAC;YAC/C,OAAO,CAAC,GAAG,KAAK,CAAC,CAAC;QACpB,CAAC,CAAC,CAAC;QACH,IAAI,CAAC,gBAAgB,CAAC,IAAI,EAAE,CAAC;IAC/B,CAAC;IAES,kCAAkC,CAAC,KAAmC;QAC9E,IAAI,CAAC,2BAA2B,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;IAC9C,CAAC;IAEO,KAAK,CAAC,uBAAuB,CAAC,GAAW,EAAE,YAAY,GAAG,IAAI;QACpE,MAAM,YAAY,GAAG,IAAI,CAAC,IAAI,EAAE;aAC7B,KAAK,EAAE;aACP,IAAI,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,EAAE,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC,KAAK,GAAG,CAAC,CAAC;QACnD,IAAI,CAAC,YAAY,EAAE,CAAC;YAClB,OAAO;QACT,CAAC;QACD,IAAI,YAAY,EAAE,CAAC;YACjB,YAAY,CAAC,MAAM,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC,EAAE,GAAG,IAAI,EAAE,OAAO,EAAE,KAAK,EAAE,CAAC,CAAC,CAAC;QAC/D,CAAC;QACD,IAAI,CAAC,gBAAgB,CAAC,YAAY,CAAC,CAAC;IACtC,CAAC;IAES,kBAAkB,CAAC,KAAmC;QAC9D,IAAI,CAAC,KAAK,EAAE,CAAC;YACX,OAAO;QACT,CAAC;QACD,IAAI,CAAC,gBAAgB,CAAC,qBAAqB,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC;QACzD,IAAI,CAAC,gBAAgB,CAAC,IAAI,EAAE,CAAC;IAC/B,CAAC;IAES,KAAK,CAAC,gBAAgB,CAAC,IAA+B;QAC9D,IAAI,IAAI,EAAE,CAAC,OAAO,IAAI,IAAI,CAAC,OAAO,EAAE,EAAE,CAAC;YACrC,OAAO;QACT,CAAC;QACD,MAAM,yBAAyB,GAAG,IAAI,CAAC,yBAAyB,EAAE,CAAC;QACnE,IAAI,yBAAyB,EAAE,CAAC;YAC9B,MAAM,KAAK,GAAG,MAAM,yBAAyB,EAAE,CAAC;YAChD,IAAI,KAAK,EAAE,CAAC;gBACV,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,CAAC;YAChC,CAAC;YACD,OAAO;QACT,CAAC;QACD,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,CAAC;IAChC,CAAC;IAEO,kBAAkB,CAAC,IAA+B;QACxD,IAAI,CAAC,WAAW,CAAC,GAAG,CAAC,IAAI,EAAE,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC,CAAC,CAAC;QAC9C,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,IAAI,CAAC,WAAW,EAAE,CAAC,CAAC;QAC7C,IAAI,CAAC,2BAA2B,EAAE,EAAE,oBAAoB,EAAE,CAAC;QAC3D,IAAI,CAAC,yBAAyB,EAAE,CAAC;IACnC,CAAC;IAES,KAAK,CAAC,aAAa,CAAC,KAAqB;QACjD,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;IAC7B,CAAC;IAEO,KAAK,CAAC,WAAW,CAAC,IAA+B,EAAE,QAAQ,GAAG,IAAI,EAAE,QAAkB;QAC5F,MAAM,KAAK,GAAG,IAAI,CAAC,IAAI,EAAE,CAAC,KAAK,CAAC;QAChC,KAAK,CAAC,MAAM,CAAC,CAAC,KAAK,EAAE,EAAE;YACrB,IAAI,QAAQ,EAAE,CAAC;gBACb,OAAO,CAAC,IAAI,EAAE,GAAG,KAAK,CAAC,CAAC;YAC1B,CAAC;YACD,OAAO,CAAC,GAAG,KAAK,EAAE,IAAI,CAAC,CAAC;QAC1B,CAAC,CAAC,CAAC;QACH,IAAI,QAAQ,EAAE,CAAC;YACb,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAC;QAC9B,CAAC;IACH,CAAC;IAES,KAAK,CAAC,yBAAyB;QACvC,IAAI,KAAK,GAAG,IAAI,CAAC,IAAI,EAAE,CAAC,KAAK,EAAE,CAAC;QAChC,MAAM,iBAAiB,GAAG,KAAK,CAAC,SAAS,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,EAAE,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC,KAAK,IAAI,CAAC,WAAW,EAAE,CAAC,CAAC;QACpG,IAAI,iBAAiB,GAAG,CAAC,EAAE,CAAC;YAC1B,OAAO;QACT,CAAC;QACD,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;QAChC,IAAI,eAAe,GAAG,KAAK,CAAC;QAC5B,MAAM,WAAW,GAAG,IAAI,CAAC,QAAQ,EAAE,CAAC,aAAa,CAAC,WAAW,IAAI,CAAC,CAAC;QACnE,MAAM,YAAY,GAAG,KAAK,CAAC,iBAAiB,CAAC,CAAC;QAC9C,MAAM,iBAAiB,GAAG,YAAY,EAAE,CAAC,aAAa,CAAC;QACvD,IAAI,sBAAsB,GAAG,CAAC,IAAI,CAAC,YAAY,EAAE,CAAC,aAAa,CAAC,WAAW,IAAI,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,aAAa,EAAE,CAAC,aAAa,CAAC,WAAW,IAAI,CAAC,CAAC,GAAG,EAAE,CAAC;QAC/I,KAAK,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,KAAK,EAAE,EAAE;YAC5B,IAAI,CAAC,IAAI,EAAE,CAAC,aAAa,EAAE,CAAC;gBAC1B,OAAO;YACT,CAAC;YACD,IAAI,CAAC,MAAM,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC,EAAE,GAAG,IAAI,EAAE,eAAe,EAAE,KAAK,EAAE,CAAC,CAAC,CAAC;YAC7D,MAAM,SAAS,GAAG,IAAI,EAAE,CAAC,aAAa,IAAI,CAAC,CAAC;YAC5C,MAAM,KAAK,GAAG,sBAAsB,GAAG,SAAS,GAAG,CAAC,KAAK,GAAG,iBAAiB,CAAC,CAAC,CAAC,iBAAiB,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;YACvG,sBAAsB,IAAI,SAAS,CAAC;YACpC,IAAI,KAAK,GAAG,WAAW,EAAE,CAAC;gBACxB,eAAe,GAAG,IAAI,CAAC;gBACvB,OAAO;YACT,CAAC;YACD,IAAI,CAAC,MAAM,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC,EAAE,GAAG,IAAI,EAAE,eAAe,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC;QAC9D,CAAC,CAAC,CAAC;QACH,YAAY,CAAC,MAAM,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC,EAAE,GAAG,IAAI,EAAE,eAAe,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC;QACpE,MAAM,OAAO,GAAG,KAAK,CAAC,MAAM,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,EAAE,CAAC,eAAe,KAAK,IAAI,CAAC,CAAC;QACxE,MAAM,UAAU,GAAG,KAAK,CAAC,MAAM,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,EAAE,CAAC,eAAe,KAAK,KAAK,CAAC,CAAC;QAC5E,KAAK,GAAG,OAAO,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC;QACnC,KAAK,CAAC,OAAO,CAAC,CAAC,IAAI,EAAE,KAAK,EAAE,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC,EAAE,GAAG,IAAI,EAAE,KAAK,EAAE,KAAK,EAAE,CAAC,CAAC,CAAC,CAAC;QACnF,IAAI,CAAC,IAAI,EAAE,CAAC,KAAK,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,IAAI,EAAE,IAAI,EAAE,EAAE,CAAC,CAAC,IAAI,EAAE,CAAC,KAAK,IAAI,CAAC,CAAC,GAAG,CAAC,IAAI,EAAE,CAAC,KAAK,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;QAC7F,IAAI,CAAC,eAAe,CAAC,GAAG,CAAC,eAAe,CAAC,CAAC;QAC1C,IAAI,CAAC,kBAAkB,CAAC,IAAI,CAAC,IAAI,CAAC,eAAe,EAAE,CAAC,CAAC;QACrD,IAAI,CAAC,YAAY,CAAC,GAAG,CACnB,IAAI,CAAC,IAAI,EAAE;aACR,KAAK,EAAE;aACP,MAAM,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,EAAE,CAAC,eAAe,CAAC,CAC5C,CAAC;IACJ,CAAC;IAED,WAAW;QACT,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,CAAC;QACtB,IAAI,CAAC,SAAS,CAAC,QAAQ,EAAE,CAAC;IAC5B,CAAC;wGA9QU,6BAA6B;4FAA7B,6BAA6B,0uFCtB1C,o/LAqIA,umBDjHY,sCAAsC,0cAAE,uBAAuB,+ZAAE,gCAAgC,ogBAAE,sCAAsC,sjBAAE,iCAAiC,qSAAE,6BAA6B;;4FAE1M,6BAA6B;kBATzC,SAAS;+BAEE,yBAAyB,cAGvB,IAAI,mBACC,uBAAuB,CAAC,MAAM,WACtC,CAAC,sCAAsC,EAAE,uBAAuB,EAAE,gCAAgC,EAAE,sCAAsC,EAAE,iCAAiC,EAAE,6BAA6B,CAAC","sourcesContent":["import { ChangeDetectionStrategy, Component, computed, ElementRef, inject, input, model, OnDestroy, OnInit, output, signal, 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\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  ngOnInit() {\n    this.updateTabsCssConfig();\n    this.outFunctionsControl.emit(this.FunctionsControl);\n    if (this.mode() !== 'left' || this.ignoreCalculatorTab()) {\n      this.tabs()\n        .items()\n        .map((item) => item.update((data) => ({ ...data, specificDisplay: true })));\n      this.itemsDisplay.set(\n        this.tabs()\n          .items()\n          .filter((item) => item().specificDisplay)\n      );\n      return;\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  /* 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) {\n    const items = this.tabs().items;\n    items.update((items) => {\n      if (addFirst) {\n        return [item, ...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    this.tabs().items.set(items.sort((prev, next) => (prev().order || 0) - (next().order || 0)));\n    this.displayMoreItem.set(displayMoreItem);\n    this.outDisplayMoreItem.emit(this.displayMoreItem());\n    this.itemsDisplay.set(\n      this.tabs()\n        .items()\n        .filter((item) => item().specificDisplay)\n    );\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"]}
@@ -1,21 +1,25 @@
1
- import { convertObjectToSignal, escapeHtml, isNil } from "@libs-ui/utils";
2
- import { of } from "rxjs";
3
- import { returnListObject } from "@libs-ui/services-http-request";
4
- import { signal } from "@angular/core";
1
+ import { convertObjectToSignal, escapeHtml, isNil } from '@libs-ui/utils';
2
+ import { of } from 'rxjs';
3
+ import { returnListObject } from '@libs-ui/services-http-request';
4
+ import { signal } from '@angular/core';
5
5
  export const tabMoreListConfig = (translate, fieldKey, fieldLabel, tabs, disable) => {
6
6
  return {
7
7
  type: 'text',
8
8
  httpRequestData: signal({
9
- serviceOther: returnListObject(tabs.items().filter(item => !item().specificDisplay).map(item => item())),
9
+ serviceOther: returnListObject(tabs
10
+ .items()
11
+ .filter((item) => !item().specificDisplay)
12
+ .map((item) => item())),
10
13
  functionName: 'listObservable',
11
- argumentsValue: []
14
+ argumentsValue: [],
12
15
  }),
13
16
  configTemplateText: signal({
14
17
  fieldKey: fieldKey || 'key',
15
18
  getClassItem: () => '!py-[12px]',
16
19
  classRows: 'w-full',
17
20
  notUseVirtualScroll: true,
18
- rows: convertObjectToSignal([{
21
+ rows: convertObjectToSignal([
22
+ {
19
23
  classCols: 'flex items-center',
20
24
  cols: [
21
25
  {
@@ -35,24 +39,24 @@ export const tabMoreListConfig = (translate, fieldKey, fieldLabel, tabs, disable
35
39
  classInclude: 'flex',
36
40
  dataView: `
37
41
  <div class="libs-ui-font-h6m rounded-full min-w-[24px] min-h-[24px] flex items-center justify-center mr-[8px] ${classStep}">
38
- ${(step <= (tabs.stepCompleted || -1)) ? `<i class="libs-ui-icon-check text-[#ffffff]"></i>` : `${step}`}
42
+ ${step <= (tabs.stepCompleted || -1) ? `<i class="libs-ui-icon-check text-[#ffffff]"></i>` : `${step}`}
39
43
  </div>
40
- `
44
+ `,
41
45
  };
42
- }
46
+ },
43
47
  },
44
48
  {
45
- getPopover: (item) => item.iconLeft ? { classInclude: 'flex', dataView: `<i class="${item.iconLeft} text-[16px] mr-[8px]"></i>` } : undefined
49
+ getPopover: (item) => (item.iconLeft ? { classInclude: 'flex', dataView: `<i class="${item.iconLeft} text-[16px] mr-[8px]"></i>` } : undefined),
46
50
  },
47
51
  {
48
52
  getClassCol: (item) => `libs-ui-font-h6m ${item.invalid ? '!text-[#f15767]' : 'text-[#6a7383]'}`,
49
- getValue: (data) => of(escapeHtml(translate.instant(data.item[fieldLabel] || ' ')))
53
+ getValue: (data) => of(escapeHtml(translate.instant(data.item[fieldLabel] || ' '))),
50
54
  },
51
55
  {
52
- getPopover: (item) => item.popover ? { config: item.popover } : undefined
56
+ getPopover: (item) => (item.popover ? { config: item.popover } : undefined),
53
57
  },
54
58
  {
55
- getPopover: (item) => item.iconRight ? { classInclude: 'flex', dataView: `<i class="${item.iconRight} text-[16px] ml-[8px]"></i>` } : undefined
59
+ getPopover: (item) => (item.iconRight ? { classInclude: 'flex', dataView: `<i class="${item.iconRight} text-[16px] ml-[8px]"></i>` } : undefined),
56
60
  },
57
61
  {
58
62
  getConfigBadge: (item) => {
@@ -63,13 +67,14 @@ export const tabMoreListConfig = (translate, fieldKey, fieldLabel, tabs, disable
63
67
  mode: item.modeCount || 'x+',
64
68
  count: item.count,
65
69
  maxCount: item.maxCount || 99,
66
- classCircle: (item.classCircle || 'libs-ui-font-h5r') + (item.invalid ? ' !text-[#f15767] !bg-[#fdeaec]' : '')
70
+ classCircle: (item.classCircle || 'libs-ui-font-h5r') + (item.invalid ? ' !text-[#f15767] !bg-[#fdeaec]' : ''),
67
71
  };
68
- }
69
- }
70
- ]
71
- }])
72
- })
72
+ },
73
+ },
74
+ ],
75
+ },
76
+ ]),
77
+ }),
73
78
  };
74
79
  };
75
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tabs.js","sourceRoot":"","sources":["../../../../../../libs-ui/components/tabs/src/utils/tabs.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,qBAAqB,EAAE,UAAU,EAAE,KAAK,EAAE,MAAM,gBAAgB,CAAC;AAE1E,OAAO,EAAE,EAAE,EAAE,MAAM,MAAM,CAAC;AAE1B,OAAO,EAAE,gBAAgB,EAAE,MAAM,gCAAgC,CAAC;AAClE,OAAO,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AAEvC,MAAM,CAAC,MAAM,iBAAiB,GAAG,CAAC,SAA2B,EAAE,QAAgB,EAAE,UAAkB,EAAE,IAAW,EAAE,OAA4B,EAAmB,EAAE;IACjK,OAAO;QACL,IAAI,EAAE,MAAM;QACZ,eAAe,EAAE,MAAM,CAAC;YACtB,YAAY,EAAE,gBAAgB,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,IAAI,EAAE,CAAC,eAAe,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,EAAE,CAAC,CAAC;YACxG,YAAY,EAAE,gBAAgB;YAC9B,cAAc,EAAE,EAAE;SACnB,CAAC;QACF,kBAAkB,EAAE,MAAM,CAAC;YACzB,QAAQ,EAAE,QAAQ,IAAI,KAAK;YAC3B,YAAY,EAAE,GAAG,EAAE,CAAC,YAAY;YAChC,SAAS,EAAE,QAAQ;YACnB,mBAAmB,EAAE,IAAI;YACzB,IAAI,EAAE,qBAAqB,CAAC,CAAC;oBAC3B,SAAS,EAAE,mBAAmB;oBAC9B,IAAI,EAAE;wBACJ;4BACE,UAAU,EAAE,CAAC,IAAe,EAAE,EAAE;gCAC9B,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC;oCAClB,OAAO;gCACT,CAAC;gCACD,MAAM,IAAI,GAAG,CAAC,IAAI,CAAC,KAAK,IAAI,CAAC,CAAC,GAAG,CAAC,CAAC;gCACnC,IAAI,SAAS,GAAG,6BAA6B,CAAC;gCAC9C,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC;oCACjB,SAAS,GAAG,+BAA+B,CAAC;gCAC9C,CAAC;gCACD,IAAI,IAAI,CAAC,OAAO,IAAI,OAAO,EAAE,CAAC;oCAC5B,SAAS,GAAG,6BAA6B,CAAC;gCAC5C,CAAC;gCACD,OAAO;oCACL,YAAY,EAAE,MAAM;oCACpB,QAAQ,EAAE;kIACwG,SAAS;sBACrH,CAAC,IAAI,IAAI,CAAC,IAAI,CAAC,aAAa,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,mDAAmD,CAAC,CAAC,CAAC,GAAG,IAAI,EAAE;;mBAEzG;iCACJ,CAAA;4BACH,CAAC;yBACF;wBACD;4BACE,UAAU,EAAE,CAAC,IAAe,EAAE,EAAE,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,EAAE,YAAY,EAAE,MAAM,EAAE,QAAQ,EAAE,aAAa,IAAI,CAAC,QAAQ,6BAA6B,EAAE,CAAC,CAAC,CAAC,SAAS;yBACzJ;wBACD;4BACE,WAAW,EAAE,CAAC,IAAe,EAAE,EAAE,CAAC,oBAAoB,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,iBAAiB,CAAC,CAAC,CAAC,gBAAgB,EAAE;4BAC3G,QAAQ,EAAE,CAAC,IAA+B,EAAE,EAAE,CAAC,EAAE,CAAC,UAAU,CAAC,SAAS,CAAC,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,IAAI,GAAG,CAAC,CAAC,CAAC;yBAC/G;wBACD;4BACE,UAAU,EAAE,CAAC,IAAe,EAAE,EAAE,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,MAAM,EAAE,IAAI,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC,SAAS;yBACrF;wBACD;4BACE,UAAU,EAAE,CAAC,IAAe,EAAE,EAAE,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,YAAY,EAAE,MAAM,EAAE,QAAQ,EAAE,aAAa,IAAI,CAAC,SAAS,6BAA6B,EAAE,CAAC,CAAC,CAAC,SAAS;yBAC3J;wBACD;4BACE,cAAc,EAAE,CAAC,IAAe,EAAE,EAAE;gCAClC,IAAI,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC;oCACtB,OAAO;gCACT,CAAC;gCACD,OAAO;oCACL,IAAI,EAAE,IAAI,CAAC,SAAS,IAAI,IAAI;oCAC5B,KAAK,EAAE,IAAI,CAAC,KAAK;oCACjB,QAAQ,EAAE,IAAI,CAAC,QAAQ,IAAI,EAAE;oCAC7B,WAAW,EAAE,CAAC,IAAI,CAAC,WAAW,IAAI,kBAAkB,CAAC,GAAG,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,gCAAgC,CAAC,CAAC,CAAC,EAAE,CAAC;iCAC/G,CAAC;4BACJ,CAAC;yBACF;qBACF;iBACF,CAAC,CAAC;SACJ,CAAC;KACH,CAAC;AACJ,CAAC,CAAA","sourcesContent":["import { IDataFunctionCallInConfig, IListConfigItem } from \"@libs-ui/components-list\";\nimport { convertObjectToSignal, escapeHtml, isNil } from \"@libs-ui/utils\";\nimport { TranslateService } from \"@ngx-translate/core\";\nimport { of } from \"rxjs\";\nimport { ITabs, ITabsItem } from \"../interfaces/tab.interface\";\nimport { returnListObject } from \"@libs-ui/services-http-request\";\nimport { signal } from \"@angular/core\";\n\nexport const tabMoreListConfig = (translate: TranslateService, fieldKey: string, fieldLabel: string, tabs: ITabs, disable: boolean | undefined): IListConfigItem => {\n  return {\n    type: 'text',\n    httpRequestData: signal({\n      serviceOther: returnListObject(tabs.items().filter(item => !item().specificDisplay).map(item => item())),\n      functionName: 'listObservable',\n      argumentsValue: []\n    }),\n    configTemplateText: signal({\n      fieldKey: fieldKey || 'key',\n      getClassItem: () => '!py-[12px]',\n      classRows: 'w-full',\n      notUseVirtualScroll: true,\n      rows: convertObjectToSignal([{\n        classCols: 'flex items-center',\n        cols: [\n          {\n            getPopover: (item: ITabsItem) => {\n              if (!tabs.hasStep) {\n                return;\n              }\n              const step = (item.order || 0) + 1;\n              let classStep = 'bg-[#f8f9fa] text-[#9ca2ad]';\n              if (item.invalid) {\n                classStep = '!text-[#f15767] !bg-[#fdeaec]';\n              }\n              if (item.disable || disable) {\n                classStep = 'bg-[#f8f9fa] text-[#cdd0d6]';\n              }\n              return {\n                classInclude: 'flex',\n                dataView: `\n                  <div class=\"libs-ui-font-h6m rounded-full min-w-[24px] min-h-[24px] flex items-center justify-center mr-[8px] ${classStep}\">\n                    ${(step <= (tabs.stepCompleted || -1)) ? `<i class=\"libs-ui-icon-check text-[#ffffff]\"></i>` : `${step}`}\n                  </div>\n                  `\n              }\n            }\n          },\n          {\n            getPopover: (item: ITabsItem) => item.iconLeft ? { classInclude: 'flex', dataView: `<i class=\"${item.iconLeft} text-[16px] mr-[8px]\"></i>` } : undefined\n          },\n          {\n            getClassCol: (item: ITabsItem) => `libs-ui-font-h6m ${item.invalid ? '!text-[#f15767]' : 'text-[#6a7383]'}`,\n            getValue: (data: IDataFunctionCallInConfig) => of(escapeHtml(translate.instant(data.item[fieldLabel] || ' ')))\n          },\n          {\n            getPopover: (item: ITabsItem) => item.popover ? { config: item.popover } : undefined\n          },\n          {\n            getPopover: (item: ITabsItem) => item.iconRight ? { classInclude: 'flex', dataView: `<i class=\"${item.iconRight} text-[16px] ml-[8px]\"></i>` } : undefined\n          },\n          {\n            getConfigBadge: (item: ITabsItem) => {\n              if (isNil(item.count)) {\n                return;\n              }\n              return {\n                mode: item.modeCount || 'x+',\n                count: item.count,\n                maxCount: item.maxCount || 99,\n                classCircle: (item.classCircle || 'libs-ui-font-h5r') + (item.invalid ? ' !text-[#f15767] !bg-[#fdeaec]' : '')\n              };\n            }\n          }\n        ]\n      }])\n    })\n  };\n}"]}
80
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tabs.js","sourceRoot":"","sources":["../../../../../../libs-ui/components/tabs/src/utils/tabs.ts"],"names":[],"mappings":"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","sourcesContent":["import { IDataFunctionCallInConfig, IListConfigItem } from '@libs-ui/components-list';\nimport { convertObjectToSignal, escapeHtml, isNil } from '@libs-ui/utils';\nimport { TranslateService } from '@ngx-translate/core';\nimport { of } from 'rxjs';\nimport { ITabs, ITabsItem } from '../interfaces/tab.interface';\nimport { returnListObject } from '@libs-ui/services-http-request';\nimport { signal } from '@angular/core';\n\nexport const tabMoreListConfig = (translate: TranslateService, fieldKey: string, fieldLabel: string, tabs: ITabs, disable: boolean | undefined): IListConfigItem => {\n  return {\n    type: 'text',\n    httpRequestData: signal({\n      serviceOther: returnListObject(\n        tabs\n          .items()\n          .filter((item) => !item().specificDisplay)\n          .map((item) => item())\n      ),\n      functionName: 'listObservable',\n      argumentsValue: [],\n    }),\n    configTemplateText: signal({\n      fieldKey: fieldKey || 'key',\n      getClassItem: () => '!py-[12px]',\n      classRows: 'w-full',\n      notUseVirtualScroll: true,\n      rows: convertObjectToSignal([\n        {\n          classCols: 'flex items-center',\n          cols: [\n            {\n              getPopover: (item: ITabsItem) => {\n                if (!tabs.hasStep) {\n                  return;\n                }\n                const step = (item.order || 0) + 1;\n                let classStep = 'bg-[#f8f9fa] text-[#9ca2ad]';\n                if (item.invalid) {\n                  classStep = '!text-[#f15767] !bg-[#fdeaec]';\n                }\n                if (item.disable || disable) {\n                  classStep = 'bg-[#f8f9fa] text-[#cdd0d6]';\n                }\n                return {\n                  classInclude: 'flex',\n                  dataView: `\n                  <div class=\"libs-ui-font-h6m rounded-full min-w-[24px] min-h-[24px] flex items-center justify-center mr-[8px] ${classStep}\">\n                    ${step <= (tabs.stepCompleted || -1) ? `<i class=\"libs-ui-icon-check text-[#ffffff]\"></i>` : `${step}`}\n                  </div>\n                  `,\n                };\n              },\n            },\n            {\n              getPopover: (item: ITabsItem) => (item.iconLeft ? { classInclude: 'flex', dataView: `<i class=\"${item.iconLeft} text-[16px] mr-[8px]\"></i>` } : undefined),\n            },\n            {\n              getClassCol: (item: ITabsItem) => `libs-ui-font-h6m ${item.invalid ? '!text-[#f15767]' : 'text-[#6a7383]'}`,\n              getValue: (data: IDataFunctionCallInConfig) => of(escapeHtml(translate.instant(data.item[fieldLabel] || ' '))),\n            },\n            {\n              getPopover: (item: ITabsItem) => (item.popover ? { config: item.popover } : undefined),\n            },\n            {\n              getPopover: (item: ITabsItem) => (item.iconRight ? { classInclude: 'flex', dataView: `<i class=\"${item.iconRight} text-[16px] ml-[8px]\"></i>` } : undefined),\n            },\n            {\n              getConfigBadge: (item: ITabsItem) => {\n                if (isNil(item.count)) {\n                  return;\n                }\n                return {\n                  mode: item.modeCount || 'x+',\n                  count: item.count,\n                  maxCount: item.maxCount || 99,\n                  classCircle: (item.classCircle || 'libs-ui-font-h5r') + (item.invalid ? ' !text-[#f15767] !bg-[#fdeaec]' : ''),\n                };\n              },\n            },\n          ],\n        },\n      ]),\n    }),\n  };\n};\n"]}