@libs-ui/components-table 0.2.78

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (35) hide show
  1. package/README.md +3 -0
  2. package/esm2022/index.mjs +4 -0
  3. package/esm2022/interfaces/button-action-event.interface.mjs +3 -0
  4. package/esm2022/interfaces/button-bar-event.interface.mjs +3 -0
  5. package/esm2022/interfaces/function-control-event.interface.mjs +2 -0
  6. package/esm2022/interfaces/hover-button-action-event.interface.mjs +2 -0
  7. package/esm2022/interfaces/index.mjs +11 -0
  8. package/esm2022/interfaces/load-more-event.interface.mjs +2 -0
  9. package/esm2022/interfaces/no-data-config.interface.mjs +2 -0
  10. package/esm2022/interfaces/sort-event.interface.mjs +2 -0
  11. package/esm2022/interfaces/table-config.interface.mjs +2 -0
  12. package/esm2022/interfaces/table.type.mjs +2 -0
  13. package/esm2022/interfaces/template-config.interface.mjs +3 -0
  14. package/esm2022/libs-ui-components-table.mjs +5 -0
  15. package/esm2022/table.component.mjs +608 -0
  16. package/esm2022/templates/template.abstract.component.mjs +16 -0
  17. package/esm2022/templates/templates.component.mjs +111 -0
  18. package/fesm2022/libs-ui-components-table.mjs +735 -0
  19. package/fesm2022/libs-ui-components-table.mjs.map +1 -0
  20. package/index.d.ts +3 -0
  21. package/interfaces/button-action-event.interface.d.ts +12 -0
  22. package/interfaces/button-bar-event.interface.d.ts +7 -0
  23. package/interfaces/function-control-event.interface.d.ts +13 -0
  24. package/interfaces/hover-button-action-event.interface.d.ts +4 -0
  25. package/interfaces/index.d.ts +10 -0
  26. package/interfaces/load-more-event.interface.d.ts +4 -0
  27. package/interfaces/no-data-config.interface.d.ts +8 -0
  28. package/interfaces/sort-event.interface.d.ts +5 -0
  29. package/interfaces/table-config.interface.d.ts +88 -0
  30. package/interfaces/table.type.d.ts +12 -0
  31. package/interfaces/template-config.interface.d.ts +60 -0
  32. package/package.json +25 -0
  33. package/table.component.d.ts +137 -0
  34. package/templates/template.abstract.component.d.ts +7 -0
  35. package/templates/templates.component.d.ts +25 -0
@@ -0,0 +1,16 @@
1
+ import { Component, input } from "@angular/core";
2
+ import * as i0 from "@angular/core";
3
+ export class LibsUiComponentsTableTemplateAbstractComponent {
4
+ item = input.required();
5
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: LibsUiComponentsTableTemplateAbstractComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
6
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.1.0", version: "18.2.13", type: LibsUiComponentsTableTemplateAbstractComponent, selector: "libs_ui-components-table-templates_abstract", inputs: { item: { classPropertyName: "item", publicName: "item", isSignal: true, isRequired: true, transformFunction: null } }, ngImport: i0, template: ``, isInline: true });
7
+ }
8
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: LibsUiComponentsTableTemplateAbstractComponent, decorators: [{
9
+ type: Component,
10
+ args: [{
11
+ // eslint-disable-next-line @angular-eslint/component-selector
12
+ selector: 'libs_ui-components-table-templates_abstract',
13
+ template: ``
14
+ }]
15
+ }] });
16
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGVtcGxhdGUuYWJzdHJhY3QuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vbGlicy11aS9jb21wb25lbnRzL3RhYmxlL3NyYy90ZW1wbGF0ZXMvdGVtcGxhdGUuYWJzdHJhY3QuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLE1BQU0sZUFBZSxDQUFDOztBQVFqRCxNQUFNLE9BQU8sOENBQThDO0lBQ2hELElBQUksR0FBRyxLQUFLLENBQUMsUUFBUSxFQUF3QixDQUFDO3dHQUQ1Qyw4Q0FBOEM7NEZBQTlDLDhDQUE4QyxtTkFGL0MsRUFBRTs7NEZBRUQsOENBQThDO2tCQUwxRCxTQUFTO21CQUFDO29CQUNULDhEQUE4RDtvQkFDOUQsUUFBUSxFQUFFLDZDQUE2QztvQkFDdkQsUUFBUSxFQUFFLEVBQUU7aUJBQ2IiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIGlucHV0IH0gZnJvbSBcIkBhbmd1bGFyL2NvcmVcIjtcbmltcG9ydCB7IFRZUEVfSVRFTV9EQVRBX1RBQkxFIH0gZnJvbSBcIi4uL2ludGVyZmFjZXNcIjtcblxuQENvbXBvbmVudCh7XG4gIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAYW5ndWxhci1lc2xpbnQvY29tcG9uZW50LXNlbGVjdG9yXG4gIHNlbGVjdG9yOiAnbGlic191aS1jb21wb25lbnRzLXRhYmxlLXRlbXBsYXRlc19hYnN0cmFjdCcsXG4gIHRlbXBsYXRlOiBgYFxufSlcbmV4cG9ydCBjbGFzcyBMaWJzVWlDb21wb25lbnRzVGFibGVUZW1wbGF0ZUFic3RyYWN0Q29tcG9uZW50IHtcbiAgcmVhZG9ubHkgaXRlbSA9IGlucHV0LnJlcXVpcmVkPFRZUEVfSVRFTV9EQVRBX1RBQkxFPigpO1xufSJdfQ==
@@ -0,0 +1,111 @@
1
+ /* eslint-disable @typescript-eslint/no-explicit-any */
2
+ import { AsyncPipe, NgClass, NgComponentOutlet, NgStyle } from '@angular/common';
3
+ import { ChangeDetectionStrategy, Component, input } from '@angular/core';
4
+ import { LibsUiComponentsAvatarComponent } from '@libs-ui/components-avatar';
5
+ import { LibsUiComponentsButtonsButtonComponent } from '@libs-ui/components-buttons-button';
6
+ import { LibsUiComponentsButtonsStatusComponent } from '@libs-ui/components-buttons-status';
7
+ import { LibsUiComponentsDropdownComponent } from '@libs-ui/components-dropdown';
8
+ import { LibsUiComponentsLineClampComponent } from '@libs-ui/components-line-clamp';
9
+ import { LibsUiComponentsPopoverComponent } from '@libs-ui/components-popover';
10
+ import { LibsUiComponentsSwitchComponent } from '@libs-ui/components-switch';
11
+ import { LibsUiPipesCallFunctionInTemplatePipe } from '@libs-ui/pipes-call-function-in-template';
12
+ import { LibsUiPipesCloneObjectPipe } from '@libs-ui/pipes-clone-object';
13
+ import { LibsUiPipesSecurityTrustPipe } from '@libs-ui/pipes-security-trust';
14
+ import { convertObjectToSignal } from '@libs-ui/utils';
15
+ import { TranslateModule } from '@ngx-translate/core';
16
+ import { LibsUiComponentsBadgeComponent } from '@libs-ui/components-badge';
17
+ import * as i0 from "@angular/core";
18
+ import * as i1 from "@ngx-translate/core";
19
+ export class LibsUiComponentsTableTemplatesComponent {
20
+ lockClick;
21
+ functionControls = new Map();
22
+ isImageError;
23
+ isHover = input();
24
+ configs = input();
25
+ templateCssWrapper = input();
26
+ item = input.required();
27
+ async handlerItemClick(event, config, dataField) {
28
+ if (event instanceof Event) {
29
+ event.preventDefault();
30
+ event.stopPropagation();
31
+ }
32
+ if (typeof event === 'string' && event !== 'click') {
33
+ return;
34
+ }
35
+ if (this.lockClick) {
36
+ return;
37
+ }
38
+ this.lockClick = true;
39
+ setTimeout(() => {
40
+ this.lockClick = false;
41
+ }, 250);
42
+ if (config && config.action) {
43
+ config.action(dataField, this.item());
44
+ }
45
+ }
46
+ async clickButtonAction(button) {
47
+ if (this.lockClick) {
48
+ return;
49
+ }
50
+ this.lockClick = true;
51
+ setTimeout(() => {
52
+ this.lockClick = false;
53
+ }, 250);
54
+ button.action?.({ item: this.item() });
55
+ }
56
+ async handlerSwitch(switchItem, config) {
57
+ if (this.lockClick) {
58
+ return;
59
+ }
60
+ this.lockClick = true;
61
+ setTimeout(() => {
62
+ this.lockClick = false;
63
+ }, 250);
64
+ config?.switchAction?.(switchItem, this.item());
65
+ }
66
+ async handlerSelectItemDropdown(fieldConfig, index, data) {
67
+ if (this.lockClick || !data) {
68
+ return;
69
+ }
70
+ this.lockClick = true;
71
+ setTimeout(() => {
72
+ this.lockClick = false;
73
+ }, 250);
74
+ fieldConfig?.action?.(data.key, data.item, this.item());
75
+ this.functionControls?.get(index)?.reset();
76
+ this.functionControls?.get(index)?.removeList();
77
+ }
78
+ async handlerSelectItemsDropdown(fieldConfig, index, data) {
79
+ if (this.lockClick || !data) {
80
+ return;
81
+ }
82
+ this.lockClick = true;
83
+ setTimeout(() => {
84
+ this.lockClick = false;
85
+ }, 250);
86
+ fieldConfig?.action?.(data.keys, convertObjectToSignal(data.mapKeys, false), this.item());
87
+ this.functionControls?.get(index)?.reset();
88
+ }
89
+ async handlerImageError(event) {
90
+ event.stopPropagation();
91
+ this.isImageError = true;
92
+ }
93
+ async handlerFunctionControl(event, index) {
94
+ this.functionControls.set(index, event);
95
+ }
96
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: LibsUiComponentsTableTemplatesComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
97
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.13", type: LibsUiComponentsTableTemplatesComponent, isStandalone: true, selector: "libs_ui-components-table-templates", inputs: { isHover: { classPropertyName: "isHover", publicName: "isHover", isSignal: true, isRequired: false, transformFunction: null }, configs: { classPropertyName: "configs", publicName: "configs", isSignal: true, isRequired: false, transformFunction: null }, templateCssWrapper: { classPropertyName: "templateCssWrapper", publicName: "templateCssWrapper", isSignal: true, isRequired: false, transformFunction: null }, item: { classPropertyName: "item", publicName: "item", isSignal: true, isRequired: true, transformFunction: null } }, ngImport: i0, template: "@if (configs(); as configs) {\n @if (item(); as item) {\n <div class=\"mo-lib-table-template {{ templateCssWrapper() || '' }}\">\n @for (config of configs; track $index) {\n @if (config.fieldsConfig) {\n <div [class]=\"config.cssWrapper\">\n @for (fieldConfig of config.fieldsConfig; track index;let index = $index;) {\n\n @if (!fieldConfig.rows && !fieldConfig.getComponentOutlet) {\n @switch (fieldConfig.instance) {\n @case (\"tooltip\") {\n @if ((fieldConfig.tooltip || {}); as tooltip) {\n <span LibsUiComponentsPopoverDirective\n [type]=\"tooltip.type || 'text'\"\n [mode]=\"tooltip.mode || 'hover'\"\n [ngStyle]=\"fieldConfig.ngStyle || {}\"\n [ngClass]=\"fieldConfig.ngClass || {}\"\n [classInclude]=\"tooltip.classInclude || ' '\"\n [ignoreShowPopover]=\"tooltip.ignoreShowPopover || false\"\n [config]=\"(fieldConfig.getTooltipConfig ? (item()[fieldConfig.field] | LibsUiPipesCallFunctionInTemplatePipe:fieldConfig.getTooltipConfig:item() | async) : (tooltip.config | LibsUiPipesCloneObjectPipe)) | translate\"\n [innerHTML]=\" (fieldConfig.field ? item()[fieldConfig.field] : tooltip.dataView) | LibsUiPipesCallFunctionInTemplatePipe:fieldConfig.parseValue:item() | async | translate\"\n (outEvent)=\"handlerItemClick($event,fieldConfig,item()[fieldConfig.field])\">\n </span>\n }\n }\n @case (\"image\") {\n @if (((item()[fieldConfig.field] | LibsUiPipesCallFunctionInTemplatePipe:fieldConfig.getImageSrc:item():isImageError) | async); as linkImage) {\n @if (linkImage !== ' ') {\n <img [ngStyle]=\"fieldConfig.ngStyle || {}\"\n [ngClass]=\"fieldConfig.ngClass || {}\"\n [src]=\"linkImage\"\n (error)=\"handlerImageError($event)\"\n (click)=\"handlerItemClick($event,fieldConfig,item()[fieldConfig.field])\" />\n }\n }\n }\n\n @case (\"avatar\") {\n @if ((item()[fieldConfig.field] | LibsUiPipesCallFunctionInTemplatePipe:fieldConfig.getAvatarConfig:item()) | async ; as avatarConfig) {\n <libs_ui-components-avatar [typeShape]=\"avatarConfig.typeShape || 'circle'\"\n [classInclude]=\"avatarConfig.classInclude\"\n [ngStyle]=\"fieldConfig.ngStyle || {}\"\n [ngClass]=\"fieldConfig.ngClass || {}\"\n [size]='avatarConfig.size || 32'\n [linkAvatar]=\"avatarConfig.linkAvatar\"\n [linkAvatarError]=\"avatarConfig.linkAvatarError\"\n [idGenColor]=\"avatarConfig.idGenColor\"\n [textAvatar]=\"avatarConfig.textAvatar\"\n [getLastTextAfterSpace]=\"avatarConfig.getLastTextAfterSpace\" />\n }\n }\n\n @case (\"buttons\") {\n @if ((fieldConfig.buttons && fieldConfig.buttons.length) || fieldConfig.getButtonsByItem) {\n <div [ngStyle]=\"fieldConfig.ngStyle || {}\"\n [ngClass]=\"fieldConfig.ngClass || {}\"\n [class.invisible]=\"!isHover() && fieldConfig.showButtonHoverMode\">\n @for (button of (fieldConfig.buttons || (item()[fieldConfig.field] | LibsUiPipesCallFunctionInTemplatePipe:fieldConfig.getButtonsByItem:item() | async)); track $index) {\n\n <libs_ui-components-buttons-button [type]=\"button().type || 'button-primary'\"\n [sizeButton]=\"button().sizeButton || 'smaller'\"\n [disable]=\"button().disable ?? (item()[fieldConfig.field] | LibsUiPipesCallFunctionInTemplatePipe:fieldConfig.getDisable:item())\"\n [label]=\"button().label || ' '\"\n [classIconLeft]=\"button().classIconLeft || ''\"\n [classIconRight]=\"button().classIconRight || ''\"\n [popover]=\"button().popover || {}\"\n [classInclude]=\"button().classInclude || ''\"\n [ignorePointerEvent]=\"button().ignorePointerEvent\"\n (outClick)=\"clickButtonAction(button())\" />\n }\n </div>\n }\n }\n\n @case (\"button-status\") {\n <libs_ui-components-buttons-status\n [config]=\"(item()[fieldConfig.field] | LibsUiPipesCallFunctionInTemplatePipe:fieldConfig.parseValue:item()) | async\"\n (click)=\"handlerItemClick($event,fieldConfig,item()[fieldConfig.field])\" />\n }\n\n @case (\"switch\") {\n <libs_ui-components-switch\n [active]=\"item()[fieldConfig.field] | LibsUiPipesCallFunctionInTemplatePipe:fieldConfig.getActiveValueSwitch:item() | async\"\n [disable]=\"item()[fieldConfig.field] | LibsUiPipesCallFunctionInTemplatePipe:fieldConfig.getDisableValueSwitch:item() | async\"\n (outSwitch)=\"handlerSwitch($event,fieldConfig)\" />\n }\n\n\n @case ((fieldConfig.instance === 'other-action-show-popup' || fieldConfig.instance === 'badge' || fieldConfig.instance === 'button-action-show-popup') ? fieldConfig.instance : '') {\n @if ((item()[fieldConfig.field] | LibsUiPipesCallFunctionInTemplatePipe:fieldConfig.parseValue:item() | async) !== ' ') {\n <div [ngStyle]=\"fieldConfig.ngStyle || {}\"\n [ngClass]=\"fieldConfig.ngClass || {}\"\n [class.ml-[8px]]=\"!fieldConfig.ignoreClassMarginLeft\">\n <libs_ui-components-dropdown [isNgContent]=\"true\"\n [popoverCustomConfig]=\"{\n widthByParent:false,\n ignoreArrow: fieldConfig.dropdownConfig?.ignoreArrow || false,\n maxHeight: fieldConfig.dropdownConfig?.maxHeight || 2048,\n paddingLeftItem:fieldConfig.dropdownConfig?.paddingLeftItem ?? true,\n classInclude:fieldConfig.dropdownConfig?.classIncludePopup || 'w-[250px]',\n position: fieldConfig.dropdownConfig?.position || {\n mode:'center',\n distance:0\n }\n }\"\n [zIndex]=\"fieldConfig.dropdownConfig?.zIndex\"\n [listConfig]=\"fieldConfig.dropdownConfig?.getListViewConfig ? ((item()[fieldConfig.field] | LibsUiPipesCallFunctionInTemplatePipe:fieldConfig.dropdownConfig?.getListViewConfig:item()) | async):fieldConfig.dropdownConfig?.listViewConfig\"\n [listBackgroundCustom]=\"fieldConfig.dropdownConfig?.listViewBackgroundListCustom\"\n [listMaxItemShow]=\"fieldConfig.dropdownConfig?.listViewMaxItemShow || 5\"\n [listKeysDisable]=\"fieldConfig.dropdownConfig?.listViewKeysDisableItem\"\n (outFunctionsControl)=\"handlerFunctionControl($event, index)\"\n (outSelectKey)=\"handlerSelectItemDropdown(fieldConfig, index,$event)\"\n (outSelectMultiKey)=\"handlerSelectItemsDropdown(fieldConfig, index,$event)\">\n @if (fieldConfig.instance === 'other-action-show-popup') {\n <div\n [innerHtml]=\"(item()[fieldConfig.field] | LibsUiPipesCallFunctionInTemplatePipe:fieldConfig.parseValue:item())| async | translate\">\n </div>\n }\n @if (fieldConfig.instance === 'badge' && (item()[fieldConfig.field] | LibsUiPipesCallFunctionInTemplatePipe:fieldConfig.parseValue:item() | async) > 0) {\n <libs_ui-components-badge [active]=\"true\"\n [ignoreMarginDefault]=\"true\"\n mode=\"+x\"\n [count]=\"item()[fieldConfig.field] | LibsUiPipesCallFunctionInTemplatePipe:fieldConfig.parseValue:item() | async\"\n [maxCount]=\"99\" />\n }\n @if (fieldConfig.instance === 'button-action-show-popup') {\n <libs_ui-components-buttons-button\n [type]=\"fieldConfig?.buttonDropDown()?.type || 'button-primary'\"\n [sizeButton]=\"fieldConfig?.buttonDropDown()?.sizeButton || 'smaller'\"\n [disable]=\"fieldConfig?.buttonDropDown()?.disable ?? (item()[fieldConfig.field] | LibsUiPipesCallFunctionInTemplatePipe:fieldConfig.getDisable:item() | async)\"\n [label]=\"fieldConfig?.buttonDropDown()?.label || ' '\"\n [classIconLeft]=\"fieldConfig?.buttonDropDown()?.classIconLeft || ''\"\n [classIconRight]=\"fieldConfig?.buttonDropDown()?.classIconRight || ''\"\n [popover]=\"fieldConfig?.buttonDropDown()?.popover || {}\"\n [classInclude]=\"fieldConfig?.buttonDropDown()?.classInclude || ''\"\n [ignoreStopPropagationEvent]=\"true\" />\n }\n\n </libs_ui-components-dropdown>\n </div>\n }\n }\n\n @case (\"line-clamp\") {\n <div [ngStyle]=\"fieldConfig.ngStyle || {}\"\n [ngClass]=\"fieldConfig.ngClass || {}\">\n @if (fieldConfig.lineClampConfig; as lineClampConfig) {\n <libs_ui-components-line_clamp\n [ignoreShowButtonCollapseExpand]=\"lineClampConfig.ignoreShowButtonCollapseExpand ?? true\"\n [showTooltip]=\"lineClampConfig.showTooltip ?? true\"\n [maxHeight]=\"lineClampConfig.maxHeight || 36\"\n [maxWidthPopover]=\"lineClampConfig.maxWidthPopover || 200\"\n [maxHeightPopover]=\"lineClampConfig.maxHeightPopover || 100\"\n [ngClassObject]=\"lineClampConfig.ngClassObject ?? { 'libs-ui-line-clamp-content mo-lib-font-head-5': true }\"\n [isInnerText]=\"lineClampConfig.isInnerText || false\"\n [ignoreStopPropagationTooltipEvent]=\"true\"\n [content]=\"item()[fieldConfig.field] | LibsUiPipesCallFunctionInTemplatePipe:fieldConfig.parseValue:item() | async\"\n (click)=\"handlerItemClick($event,fieldConfig,item()[fieldConfig.field])\" />\n }\n </div>\n }\n\n @case (\"shape-style\") {\n <div [ngStyle]=\"fieldConfig.ngStyle || {}\"\n [ngClass]=\"fieldConfig.ngClass || {}\"\n [innerHTML]=\"(item()[fieldConfig.field] | LibsUiPipesCallFunctionInTemplatePipe:fieldConfig.parseValue:item())| async | translate | LibsUiPipesSecurityTrustPipe:'html':true | async\"\n (click)=\"handlerItemClick($event,fieldConfig,item()[fieldConfig.field])\">\n </div>\n }\n @default {\n @if (((item()[fieldConfig.field] | LibsUiPipesCallFunctionInTemplatePipe:fieldConfig.parseValue:item()) | async | translate); as value) {\n @if (value !==' ') {\n <div [ngStyle]=\"fieldConfig.ngStyle || {}\"\n [ngClass]=\"fieldConfig.ngClass || {}\"\n [innerHTML]=\"value | LibsUiPipesSecurityTrustPipe:'html':true|async\"\n (click)=\"handlerItemClick($event,fieldConfig,item()[fieldConfig.field])\">\n </div>\n }\n }\n }\n }\n } @else {\n @if (fieldConfig.rows) {\n <div class=\"w-full flex relative {{ fieldConfig.rowsTemplateCssWrapper }}\">\n <div class=\"w-full flex absolute {{ fieldConfig.rowsTemplateCssWrapper }}\">\n <libs_ui-components-table-templates class=\"flex w-full\"\n [item]=\"item\"\n [configs]=\"fieldConfig.rows\" />\n </div>\n </div>\n }\n @else {\n <ng-container\n *ngComponentOutlet=\"(item()[fieldConfig.field] | LibsUiPipesCallFunctionInTemplatePipe:fieldConfig.getComponentOutlet) | async; inputs:{item}\" />\n }\n }\n\n }\n </div>\n }\n }\n </div>\n }\n}\n", styles: [":host{width:100%;height:100%}:host .mo-lib-table-template{color:#071631;font-size:12px;font-weight:400;width:100%;height:inherit}:host .mo-lib-table-template .mo-lib-table-template-buttons-container{visibility:hidden!important}:host .mo-lib-table-template [is-hover=true].mo-lib-table-template-buttons-container{visibility:visible!important}\n"], dependencies: [{ kind: "component", type: LibsUiComponentsTableTemplatesComponent, selector: "libs_ui-components-table-templates", inputs: ["isHover", "configs", "templateCssWrapper", "item"] }, { kind: "directive", type: NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "directive", type: NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i1.TranslatePipe, name: "translate" }, { kind: "pipe", type: AsyncPipe, name: "async" }, { kind: "directive", type: NgComponentOutlet, selector: "[ngComponentOutlet]", inputs: ["ngComponentOutlet", "ngComponentOutletInputs", "ngComponentOutletInjector", "ngComponentOutletContent", "ngComponentOutletNgModule", "ngComponentOutletNgModuleFactory"] }, { kind: "component", type: LibsUiComponentsAvatarComponent, selector: "libs_ui-components-avatar", inputs: ["getLastTextAfterSpace", "typeShape", "classInclude", "size", "linkAvatar", "linkAvatarError", "idGenColor", "textAvatar", "classImageInclude"], outputs: ["outAvatarError"] }, { kind: "pipe", type: LibsUiPipesCallFunctionInTemplatePipe, name: "LibsUiPipesCallFunctionInTemplatePipe" }, { kind: "pipe", type: LibsUiPipesSecurityTrustPipe, name: "LibsUiPipesSecurityTrustPipe" }, { kind: "component", type: LibsUiComponentsPopoverComponent, selector: "libs_ui-components-popover,[LibsUiComponentsPopoverDirective]", inputs: ["debugId", "flagMouse", "type", "mode", "config", "ignoreShowPopover", "elementRefCustom", "classInclude", "ignoreHiddenPopoverContentWhenMouseLeave", "ignoreStopPropagationEvent", "ignoreCursorPointerModeLikeClick", "isAddContentToParentDocument", "ignoreClickOutside"], outputs: ["outEvent", "outChangStageFlagMouse", "outEventPopoverContent", "outFunctionsControl"] }, { kind: "component", type: LibsUiComponentsButtonsStatusComponent, selector: "libs_ui-components-buttons-status", inputs: ["config"] }, { kind: "component", type: LibsUiComponentsSwitchComponent, selector: "libs_ui-components-switch", inputs: ["size", "disable", "active"], outputs: ["activeChange", "outSwitch"] }, { kind: "pipe", type: LibsUiPipesCloneObjectPipe, name: "LibsUiPipesCloneObjectPipe" }, { 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"], outputs: ["outClick", "outPopoverEvent", "outFunctionsControl"] }, { kind: "component", type: LibsUiComponentsLineClampComponent, selector: "libs_ui-components-line_clamp", inputs: ["content", "lengthLimitDisplay", "maxHeight", "ignoreShowButtonCollapseExpand", "ignoreShowButtonCollapse", "showTooltip", "timeHidePopoverOnMouseout", "maxWidthPopover", "maxHeightPopover", "zIndexPopover", "isInnerText", "classClassLabelButtonCollapseExpand", "classClassIncludeButtonCollapseExpand", "ignoreStopPropagationTooltipEvent", "ngClassObject", "hasBackgroundGradient", "labelButtonViewMore", "labelButtonCollapse", "directionTooltip", "useXssFilter"], outputs: ["outDisplayLineClamp", "outAction", "outClick", "outFunctionControl"] }, { kind: "component", type: LibsUiComponentsDropdownComponent, selector: "libs_ui-components-dropdown", inputs: ["useXssFilter", "popoverElementRefCustom", "classInclude", "ignoreStopPropagationEvent", "flagMouse", "flagMouseContent", "popoverCustomConfig", "isNgContent", "zIndex", "convertItemSelected", "getPopoverItemSelected", "httpRequestDetailItemById", "lengthKeys", "textDisplayWhenNoSelect", "textDisplayWhenMultiSelect", "classIncludeTextDisplayWhenNoSelect", "fieldGetLabel", "labelPopoverConfig", "labelPopoverFullWidth", "hasContentUnitRight", "listSearchNoDataTemplateRef", "fieldGetImage", "imageSize", "typeShape", "fieldGetIcon", "fieldGetTextAvatar", "fieldGetColorAvatar", "classAvatarInclude", "getLastTextAfterSpace", "linkImageError", "showError", "showBorderError", "disable", "readonly", "labelConfig", "listSearchConfig", "isSearchOnline", "listHiddenInputSearch", "listSearchPadding", "listKeySearch", "listDividerClassInclude", "listConfig", "listButtonsOther", "listHasButtonUnSelectOption", "listClickExactly", "listBackgroundCustom", "listMaxItemShow", "listKeySelected", "listMultiKeySelected", "listKeysDisable", "listKeysHidden", "validRequired", "validMaxItemSelected", "changeValidUndefinedResetError", "allowSelectItemMultiple", "focusInputSearch", "onlyEmitDataWhenReset", "resetKeyWhenSelectAllKey", "listConfigHasDivider", "classIncludeIcon", "classIncludeContent", "listIgnoreClassDisableDefaultWhenUseKeysDisableItem", "tabKeyActive", "tabsConfig", "ignoreBorderBottom"], outputs: ["flagMouseChange", "flagMouseContentChange", "lengthKeysChange", "showBorderErrorChange", "listKeySelectedChange", "listMultiKeySelectedChange", "tabKeyActiveChange", "outSelectKey", "outSelectMultiKey", "outFunctionsControl", "outValidEvent", "outChangStageFlagMouse", "outDataChange", "outClickButtonOther", "outShowList", "outChangeTabKeyActive"] }, { kind: "component", type: LibsUiComponentsBadgeComponent, selector: "libs_ui-components-badge", inputs: ["popoverConfig", "active", "count", "mode", "maxCount", "ignoreMarginDefault", "classCircle", "ignoreStopPropagationEvent"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush });
98
+ }
99
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: LibsUiComponentsTableTemplatesComponent, decorators: [{
100
+ type: Component,
101
+ args: [{ selector: 'libs_ui-components-table-templates', standalone: true, imports: [
102
+ NgStyle, NgClass, TranslateModule, AsyncPipe, NgComponentOutlet,
103
+ LibsUiComponentsAvatarComponent, LibsUiPipesCallFunctionInTemplatePipe,
104
+ LibsUiPipesSecurityTrustPipe, LibsUiComponentsPopoverComponent,
105
+ LibsUiComponentsButtonsStatusComponent, LibsUiComponentsSwitchComponent,
106
+ LibsUiPipesCloneObjectPipe, LibsUiComponentsButtonsButtonComponent,
107
+ LibsUiComponentsLineClampComponent, LibsUiComponentsDropdownComponent,
108
+ LibsUiComponentsBadgeComponent
109
+ ], changeDetection: ChangeDetectionStrategy.OnPush, template: "@if (configs(); as configs) {\n @if (item(); as item) {\n <div class=\"mo-lib-table-template {{ templateCssWrapper() || '' }}\">\n @for (config of configs; track $index) {\n @if (config.fieldsConfig) {\n <div [class]=\"config.cssWrapper\">\n @for (fieldConfig of config.fieldsConfig; track index;let index = $index;) {\n\n @if (!fieldConfig.rows && !fieldConfig.getComponentOutlet) {\n @switch (fieldConfig.instance) {\n @case (\"tooltip\") {\n @if ((fieldConfig.tooltip || {}); as tooltip) {\n <span LibsUiComponentsPopoverDirective\n [type]=\"tooltip.type || 'text'\"\n [mode]=\"tooltip.mode || 'hover'\"\n [ngStyle]=\"fieldConfig.ngStyle || {}\"\n [ngClass]=\"fieldConfig.ngClass || {}\"\n [classInclude]=\"tooltip.classInclude || ' '\"\n [ignoreShowPopover]=\"tooltip.ignoreShowPopover || false\"\n [config]=\"(fieldConfig.getTooltipConfig ? (item()[fieldConfig.field] | LibsUiPipesCallFunctionInTemplatePipe:fieldConfig.getTooltipConfig:item() | async) : (tooltip.config | LibsUiPipesCloneObjectPipe)) | translate\"\n [innerHTML]=\" (fieldConfig.field ? item()[fieldConfig.field] : tooltip.dataView) | LibsUiPipesCallFunctionInTemplatePipe:fieldConfig.parseValue:item() | async | translate\"\n (outEvent)=\"handlerItemClick($event,fieldConfig,item()[fieldConfig.field])\">\n </span>\n }\n }\n @case (\"image\") {\n @if (((item()[fieldConfig.field] | LibsUiPipesCallFunctionInTemplatePipe:fieldConfig.getImageSrc:item():isImageError) | async); as linkImage) {\n @if (linkImage !== ' ') {\n <img [ngStyle]=\"fieldConfig.ngStyle || {}\"\n [ngClass]=\"fieldConfig.ngClass || {}\"\n [src]=\"linkImage\"\n (error)=\"handlerImageError($event)\"\n (click)=\"handlerItemClick($event,fieldConfig,item()[fieldConfig.field])\" />\n }\n }\n }\n\n @case (\"avatar\") {\n @if ((item()[fieldConfig.field] | LibsUiPipesCallFunctionInTemplatePipe:fieldConfig.getAvatarConfig:item()) | async ; as avatarConfig) {\n <libs_ui-components-avatar [typeShape]=\"avatarConfig.typeShape || 'circle'\"\n [classInclude]=\"avatarConfig.classInclude\"\n [ngStyle]=\"fieldConfig.ngStyle || {}\"\n [ngClass]=\"fieldConfig.ngClass || {}\"\n [size]='avatarConfig.size || 32'\n [linkAvatar]=\"avatarConfig.linkAvatar\"\n [linkAvatarError]=\"avatarConfig.linkAvatarError\"\n [idGenColor]=\"avatarConfig.idGenColor\"\n [textAvatar]=\"avatarConfig.textAvatar\"\n [getLastTextAfterSpace]=\"avatarConfig.getLastTextAfterSpace\" />\n }\n }\n\n @case (\"buttons\") {\n @if ((fieldConfig.buttons && fieldConfig.buttons.length) || fieldConfig.getButtonsByItem) {\n <div [ngStyle]=\"fieldConfig.ngStyle || {}\"\n [ngClass]=\"fieldConfig.ngClass || {}\"\n [class.invisible]=\"!isHover() && fieldConfig.showButtonHoverMode\">\n @for (button of (fieldConfig.buttons || (item()[fieldConfig.field] | LibsUiPipesCallFunctionInTemplatePipe:fieldConfig.getButtonsByItem:item() | async)); track $index) {\n\n <libs_ui-components-buttons-button [type]=\"button().type || 'button-primary'\"\n [sizeButton]=\"button().sizeButton || 'smaller'\"\n [disable]=\"button().disable ?? (item()[fieldConfig.field] | LibsUiPipesCallFunctionInTemplatePipe:fieldConfig.getDisable:item())\"\n [label]=\"button().label || ' '\"\n [classIconLeft]=\"button().classIconLeft || ''\"\n [classIconRight]=\"button().classIconRight || ''\"\n [popover]=\"button().popover || {}\"\n [classInclude]=\"button().classInclude || ''\"\n [ignorePointerEvent]=\"button().ignorePointerEvent\"\n (outClick)=\"clickButtonAction(button())\" />\n }\n </div>\n }\n }\n\n @case (\"button-status\") {\n <libs_ui-components-buttons-status\n [config]=\"(item()[fieldConfig.field] | LibsUiPipesCallFunctionInTemplatePipe:fieldConfig.parseValue:item()) | async\"\n (click)=\"handlerItemClick($event,fieldConfig,item()[fieldConfig.field])\" />\n }\n\n @case (\"switch\") {\n <libs_ui-components-switch\n [active]=\"item()[fieldConfig.field] | LibsUiPipesCallFunctionInTemplatePipe:fieldConfig.getActiveValueSwitch:item() | async\"\n [disable]=\"item()[fieldConfig.field] | LibsUiPipesCallFunctionInTemplatePipe:fieldConfig.getDisableValueSwitch:item() | async\"\n (outSwitch)=\"handlerSwitch($event,fieldConfig)\" />\n }\n\n\n @case ((fieldConfig.instance === 'other-action-show-popup' || fieldConfig.instance === 'badge' || fieldConfig.instance === 'button-action-show-popup') ? fieldConfig.instance : '') {\n @if ((item()[fieldConfig.field] | LibsUiPipesCallFunctionInTemplatePipe:fieldConfig.parseValue:item() | async) !== ' ') {\n <div [ngStyle]=\"fieldConfig.ngStyle || {}\"\n [ngClass]=\"fieldConfig.ngClass || {}\"\n [class.ml-[8px]]=\"!fieldConfig.ignoreClassMarginLeft\">\n <libs_ui-components-dropdown [isNgContent]=\"true\"\n [popoverCustomConfig]=\"{\n widthByParent:false,\n ignoreArrow: fieldConfig.dropdownConfig?.ignoreArrow || false,\n maxHeight: fieldConfig.dropdownConfig?.maxHeight || 2048,\n paddingLeftItem:fieldConfig.dropdownConfig?.paddingLeftItem ?? true,\n classInclude:fieldConfig.dropdownConfig?.classIncludePopup || 'w-[250px]',\n position: fieldConfig.dropdownConfig?.position || {\n mode:'center',\n distance:0\n }\n }\"\n [zIndex]=\"fieldConfig.dropdownConfig?.zIndex\"\n [listConfig]=\"fieldConfig.dropdownConfig?.getListViewConfig ? ((item()[fieldConfig.field] | LibsUiPipesCallFunctionInTemplatePipe:fieldConfig.dropdownConfig?.getListViewConfig:item()) | async):fieldConfig.dropdownConfig?.listViewConfig\"\n [listBackgroundCustom]=\"fieldConfig.dropdownConfig?.listViewBackgroundListCustom\"\n [listMaxItemShow]=\"fieldConfig.dropdownConfig?.listViewMaxItemShow || 5\"\n [listKeysDisable]=\"fieldConfig.dropdownConfig?.listViewKeysDisableItem\"\n (outFunctionsControl)=\"handlerFunctionControl($event, index)\"\n (outSelectKey)=\"handlerSelectItemDropdown(fieldConfig, index,$event)\"\n (outSelectMultiKey)=\"handlerSelectItemsDropdown(fieldConfig, index,$event)\">\n @if (fieldConfig.instance === 'other-action-show-popup') {\n <div\n [innerHtml]=\"(item()[fieldConfig.field] | LibsUiPipesCallFunctionInTemplatePipe:fieldConfig.parseValue:item())| async | translate\">\n </div>\n }\n @if (fieldConfig.instance === 'badge' && (item()[fieldConfig.field] | LibsUiPipesCallFunctionInTemplatePipe:fieldConfig.parseValue:item() | async) > 0) {\n <libs_ui-components-badge [active]=\"true\"\n [ignoreMarginDefault]=\"true\"\n mode=\"+x\"\n [count]=\"item()[fieldConfig.field] | LibsUiPipesCallFunctionInTemplatePipe:fieldConfig.parseValue:item() | async\"\n [maxCount]=\"99\" />\n }\n @if (fieldConfig.instance === 'button-action-show-popup') {\n <libs_ui-components-buttons-button\n [type]=\"fieldConfig?.buttonDropDown()?.type || 'button-primary'\"\n [sizeButton]=\"fieldConfig?.buttonDropDown()?.sizeButton || 'smaller'\"\n [disable]=\"fieldConfig?.buttonDropDown()?.disable ?? (item()[fieldConfig.field] | LibsUiPipesCallFunctionInTemplatePipe:fieldConfig.getDisable:item() | async)\"\n [label]=\"fieldConfig?.buttonDropDown()?.label || ' '\"\n [classIconLeft]=\"fieldConfig?.buttonDropDown()?.classIconLeft || ''\"\n [classIconRight]=\"fieldConfig?.buttonDropDown()?.classIconRight || ''\"\n [popover]=\"fieldConfig?.buttonDropDown()?.popover || {}\"\n [classInclude]=\"fieldConfig?.buttonDropDown()?.classInclude || ''\"\n [ignoreStopPropagationEvent]=\"true\" />\n }\n\n </libs_ui-components-dropdown>\n </div>\n }\n }\n\n @case (\"line-clamp\") {\n <div [ngStyle]=\"fieldConfig.ngStyle || {}\"\n [ngClass]=\"fieldConfig.ngClass || {}\">\n @if (fieldConfig.lineClampConfig; as lineClampConfig) {\n <libs_ui-components-line_clamp\n [ignoreShowButtonCollapseExpand]=\"lineClampConfig.ignoreShowButtonCollapseExpand ?? true\"\n [showTooltip]=\"lineClampConfig.showTooltip ?? true\"\n [maxHeight]=\"lineClampConfig.maxHeight || 36\"\n [maxWidthPopover]=\"lineClampConfig.maxWidthPopover || 200\"\n [maxHeightPopover]=\"lineClampConfig.maxHeightPopover || 100\"\n [ngClassObject]=\"lineClampConfig.ngClassObject ?? { 'libs-ui-line-clamp-content mo-lib-font-head-5': true }\"\n [isInnerText]=\"lineClampConfig.isInnerText || false\"\n [ignoreStopPropagationTooltipEvent]=\"true\"\n [content]=\"item()[fieldConfig.field] | LibsUiPipesCallFunctionInTemplatePipe:fieldConfig.parseValue:item() | async\"\n (click)=\"handlerItemClick($event,fieldConfig,item()[fieldConfig.field])\" />\n }\n </div>\n }\n\n @case (\"shape-style\") {\n <div [ngStyle]=\"fieldConfig.ngStyle || {}\"\n [ngClass]=\"fieldConfig.ngClass || {}\"\n [innerHTML]=\"(item()[fieldConfig.field] | LibsUiPipesCallFunctionInTemplatePipe:fieldConfig.parseValue:item())| async | translate | LibsUiPipesSecurityTrustPipe:'html':true | async\"\n (click)=\"handlerItemClick($event,fieldConfig,item()[fieldConfig.field])\">\n </div>\n }\n @default {\n @if (((item()[fieldConfig.field] | LibsUiPipesCallFunctionInTemplatePipe:fieldConfig.parseValue:item()) | async | translate); as value) {\n @if (value !==' ') {\n <div [ngStyle]=\"fieldConfig.ngStyle || {}\"\n [ngClass]=\"fieldConfig.ngClass || {}\"\n [innerHTML]=\"value | LibsUiPipesSecurityTrustPipe:'html':true|async\"\n (click)=\"handlerItemClick($event,fieldConfig,item()[fieldConfig.field])\">\n </div>\n }\n }\n }\n }\n } @else {\n @if (fieldConfig.rows) {\n <div class=\"w-full flex relative {{ fieldConfig.rowsTemplateCssWrapper }}\">\n <div class=\"w-full flex absolute {{ fieldConfig.rowsTemplateCssWrapper }}\">\n <libs_ui-components-table-templates class=\"flex w-full\"\n [item]=\"item\"\n [configs]=\"fieldConfig.rows\" />\n </div>\n </div>\n }\n @else {\n <ng-container\n *ngComponentOutlet=\"(item()[fieldConfig.field] | LibsUiPipesCallFunctionInTemplatePipe:fieldConfig.getComponentOutlet) | async; inputs:{item}\" />\n }\n }\n\n }\n </div>\n }\n }\n </div>\n }\n}\n", styles: [":host{width:100%;height:100%}:host .mo-lib-table-template{color:#071631;font-size:12px;font-weight:400;width:100%;height:inherit}:host .mo-lib-table-template .mo-lib-table-template-buttons-container{visibility:hidden!important}:host .mo-lib-table-template [is-hover=true].mo-lib-table-template-buttons-container{visibility:visible!important}\n"] }]
110
+ }] });
111
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"templates.component.js","sourceRoot":"","sources":["../../../../../../libs-ui/components/table/src/templates/templates.component.ts","../../../../../../libs-ui/components/table/src/templates/templates.component.html"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable @typescript-eslint/no-explicit-any */\nimport { AsyncPipe, NgClass, NgComponentOutlet, NgStyle } from '@angular/common';\nimport { ChangeDetectionStrategy, Component, input } from '@angular/core';\nimport { LibsUiComponentsAvatarComponent } from '@libs-ui/components-avatar';\nimport { IButton, LibsUiComponentsButtonsButtonComponent } from '@libs-ui/components-buttons-button';\nimport { LibsUiComponentsButtonsStatusComponent } from '@libs-ui/components-buttons-status';\nimport { IDropdownFunctionControlEvent, IEmitMultiKey, IEmitSelectKey, LibsUiComponentsDropdownComponent } from '@libs-ui/components-dropdown';\nimport { LibsUiComponentsLineClampComponent } from '@libs-ui/components-line-clamp';\nimport { LibsUiComponentsPopoverComponent, TYPE_POPOVER_EVENT } from '@libs-ui/components-popover';\nimport { ISwitchEvent, LibsUiComponentsSwitchComponent } from '@libs-ui/components-switch';\nimport { LibsUiPipesCallFunctionInTemplatePipe } from '@libs-ui/pipes-call-function-in-template';\nimport { LibsUiPipesCloneObjectPipe } from '@libs-ui/pipes-clone-object';\nimport { LibsUiPipesSecurityTrustPipe } from '@libs-ui/pipes-security-trust';\nimport { convertObjectToSignal } from '@libs-ui/utils';\nimport { TranslateModule } from '@ngx-translate/core';\nimport { TYPE_ITEM_DATA_TABLE } from '../interfaces';\nimport { ITableFieldTemplateConfig, ITableTemplateConfig } from '../interfaces/template-config.interface';\nimport { LibsUiComponentsBadgeComponent } from '@libs-ui/components-badge';\n\n@Component({\n  // eslint-disable-next-line @angular-eslint/component-selector\n  selector: 'libs_ui-components-table-templates',\n  templateUrl: './templates.component.html',\n  styleUrls: ['./templates.component.scss'],\n  standalone: true,\n  imports: [\n    NgStyle, NgClass, TranslateModule, AsyncPipe, NgComponentOutlet,\n    LibsUiComponentsAvatarComponent, LibsUiPipesCallFunctionInTemplatePipe,\n    LibsUiPipesSecurityTrustPipe, LibsUiComponentsPopoverComponent,\n    LibsUiComponentsButtonsStatusComponent, LibsUiComponentsSwitchComponent,\n    LibsUiPipesCloneObjectPipe, LibsUiComponentsButtonsButtonComponent,\n    LibsUiComponentsLineClampComponent, LibsUiComponentsDropdownComponent,\n    LibsUiComponentsBadgeComponent\n  ],\n  changeDetection: ChangeDetectionStrategy.OnPush\n})\nexport class LibsUiComponentsTableTemplatesComponent {\n  private lockClick!: boolean;\n  private functionControls = new Map<number, IDropdownFunctionControlEvent>();\n  protected isImageError: boolean | undefined;\n\n  readonly isHover = input<boolean>();\n  readonly configs = input<Array<ITableTemplateConfig>>();\n  readonly templateCssWrapper = input<string>();\n  readonly item = input.required<TYPE_ITEM_DATA_TABLE>();\n\n\n  protected async handlerItemClick(event: Event | TYPE_POPOVER_EVENT | undefined, config: ITableFieldTemplateConfig, dataField: any) {\n    if (event instanceof Event) {\n      event.preventDefault();\n      event.stopPropagation();\n    }\n    if (typeof event === 'string' && event !== 'click') {\n      return;\n    }\n    if (this.lockClick) {\n      return;\n    }\n    this.lockClick = true;\n    setTimeout(() => {\n      this.lockClick = false;\n    }, 250);\n    if (config && config.action) {\n      config.action(dataField, this.item());\n    }\n  }\n\n  protected async clickButtonAction(button: IButton) {\n    if (this.lockClick) {\n      return;\n    }\n    this.lockClick = true;\n    setTimeout(() => {\n      this.lockClick = false;\n    }, 250);\n    button.action?.({ item: this.item() });\n  }\n\n  protected async handlerSwitch(switchItem: ISwitchEvent, config: ITableFieldTemplateConfig) {\n    if (this.lockClick) {\n      return;\n    }\n    this.lockClick = true;\n    setTimeout(() => {\n      this.lockClick = false;\n    }, 250);\n    config?.switchAction?.(switchItem, this.item());\n  }\n\n  protected async handlerSelectItemDropdown(fieldConfig: ITableFieldTemplateConfig, index: number, data?: IEmitSelectKey) {\n    if (this.lockClick || !data) {\n      return;\n    }\n    this.lockClick = true;\n    setTimeout(() => {\n      this.lockClick = false;\n    }, 250);\n    fieldConfig?.action?.(data.key, data.item, this.item());\n    (this.functionControls?.get(index) as IDropdownFunctionControlEvent)?.reset();\n    (this.functionControls?.get(index) as IDropdownFunctionControlEvent)?.removeList();\n  }\n\n  protected async handlerSelectItemsDropdown(fieldConfig: ITableFieldTemplateConfig, index: number, data?: IEmitMultiKey) {\n    if (this.lockClick || !data) {\n      return;\n    }\n    this.lockClick = true;\n    setTimeout(() => {\n      this.lockClick = false;\n    }, 250);\n    fieldConfig?.action?.(data.keys, convertObjectToSignal(data.mapKeys, false), this.item());\n    (this.functionControls?.get(index) as IDropdownFunctionControlEvent)?.reset();\n  }\n\n  protected async handlerImageError(event: Event) {\n    event.stopPropagation();\n    this.isImageError = true;\n  }\n\n  protected async handlerFunctionControl(event: IDropdownFunctionControlEvent, index: number) {\n    this.functionControls.set(index, event);\n  }\n\n}\n","@if (configs(); as configs) {\n  @if (item(); as item) {\n    <div class=\"mo-lib-table-template {{ templateCssWrapper() || '' }}\">\n      @for (config of configs; track $index) {\n        @if (config.fieldsConfig) {\n          <div [class]=\"config.cssWrapper\">\n            @for (fieldConfig of config.fieldsConfig; track index;let index = $index;) {\n\n              @if (!fieldConfig.rows && !fieldConfig.getComponentOutlet) {\n                @switch (fieldConfig.instance) {\n                  @case (\"tooltip\") {\n                    @if ((fieldConfig.tooltip || {}); as tooltip) {\n                      <span LibsUiComponentsPopoverDirective\n                        [type]=\"tooltip.type || 'text'\"\n                        [mode]=\"tooltip.mode || 'hover'\"\n                        [ngStyle]=\"fieldConfig.ngStyle || {}\"\n                        [ngClass]=\"fieldConfig.ngClass || {}\"\n                        [classInclude]=\"tooltip.classInclude || ' '\"\n                        [ignoreShowPopover]=\"tooltip.ignoreShowPopover || false\"\n                        [config]=\"(fieldConfig.getTooltipConfig ? (item()[fieldConfig.field] | LibsUiPipesCallFunctionInTemplatePipe:fieldConfig.getTooltipConfig:item() | async) : (tooltip.config | LibsUiPipesCloneObjectPipe)) | translate\"\n                        [innerHTML]=\" (fieldConfig.field ? item()[fieldConfig.field] : tooltip.dataView) | LibsUiPipesCallFunctionInTemplatePipe:fieldConfig.parseValue:item() | async | translate\"\n                        (outEvent)=\"handlerItemClick($event,fieldConfig,item()[fieldConfig.field])\">\n                      </span>\n                    }\n                  }\n                  @case (\"image\") {\n                    @if (((item()[fieldConfig.field] | LibsUiPipesCallFunctionInTemplatePipe:fieldConfig.getImageSrc:item():isImageError) | async); as linkImage) {\n                      @if (linkImage !== ' ') {\n                        <img [ngStyle]=\"fieldConfig.ngStyle || {}\"\n                          [ngClass]=\"fieldConfig.ngClass || {}\"\n                          [src]=\"linkImage\"\n                          (error)=\"handlerImageError($event)\"\n                          (click)=\"handlerItemClick($event,fieldConfig,item()[fieldConfig.field])\" />\n                      }\n                    }\n                  }\n\n                  @case (\"avatar\") {\n                    @if ((item()[fieldConfig.field] | LibsUiPipesCallFunctionInTemplatePipe:fieldConfig.getAvatarConfig:item()) | async ; as avatarConfig) {\n                      <libs_ui-components-avatar [typeShape]=\"avatarConfig.typeShape || 'circle'\"\n                        [classInclude]=\"avatarConfig.classInclude\"\n                        [ngStyle]=\"fieldConfig.ngStyle || {}\"\n                        [ngClass]=\"fieldConfig.ngClass || {}\"\n                        [size]='avatarConfig.size || 32'\n                        [linkAvatar]=\"avatarConfig.linkAvatar\"\n                        [linkAvatarError]=\"avatarConfig.linkAvatarError\"\n                        [idGenColor]=\"avatarConfig.idGenColor\"\n                        [textAvatar]=\"avatarConfig.textAvatar\"\n                        [getLastTextAfterSpace]=\"avatarConfig.getLastTextAfterSpace\" />\n                    }\n                  }\n\n                  @case (\"buttons\") {\n                    @if ((fieldConfig.buttons && fieldConfig.buttons.length) || fieldConfig.getButtonsByItem) {\n                      <div [ngStyle]=\"fieldConfig.ngStyle || {}\"\n                        [ngClass]=\"fieldConfig.ngClass || {}\"\n                        [class.invisible]=\"!isHover() && fieldConfig.showButtonHoverMode\">\n                        @for (button of (fieldConfig.buttons || (item()[fieldConfig.field] | LibsUiPipesCallFunctionInTemplatePipe:fieldConfig.getButtonsByItem:item() | async)); track $index) {\n\n                          <libs_ui-components-buttons-button [type]=\"button().type || 'button-primary'\"\n                            [sizeButton]=\"button().sizeButton || 'smaller'\"\n                            [disable]=\"button().disable ?? (item()[fieldConfig.field] | LibsUiPipesCallFunctionInTemplatePipe:fieldConfig.getDisable:item())\"\n                            [label]=\"button().label || ' '\"\n                            [classIconLeft]=\"button().classIconLeft || ''\"\n                            [classIconRight]=\"button().classIconRight || ''\"\n                            [popover]=\"button().popover || {}\"\n                            [classInclude]=\"button().classInclude || ''\"\n                            [ignorePointerEvent]=\"button().ignorePointerEvent\"\n                            (outClick)=\"clickButtonAction(button())\" />\n                        }\n                      </div>\n                    }\n                  }\n\n                  @case (\"button-status\") {\n                    <libs_ui-components-buttons-status\n                      [config]=\"(item()[fieldConfig.field] | LibsUiPipesCallFunctionInTemplatePipe:fieldConfig.parseValue:item()) | async\"\n                      (click)=\"handlerItemClick($event,fieldConfig,item()[fieldConfig.field])\" />\n                  }\n\n                  @case (\"switch\") {\n                    <libs_ui-components-switch\n                      [active]=\"item()[fieldConfig.field] | LibsUiPipesCallFunctionInTemplatePipe:fieldConfig.getActiveValueSwitch:item() | async\"\n                      [disable]=\"item()[fieldConfig.field] | LibsUiPipesCallFunctionInTemplatePipe:fieldConfig.getDisableValueSwitch:item() | async\"\n                      (outSwitch)=\"handlerSwitch($event,fieldConfig)\" />\n                  }\n\n\n                  @case ((fieldConfig.instance === 'other-action-show-popup' || fieldConfig.instance === 'badge' || fieldConfig.instance === 'button-action-show-popup') ? fieldConfig.instance : '') {\n                    @if ((item()[fieldConfig.field] | LibsUiPipesCallFunctionInTemplatePipe:fieldConfig.parseValue:item() | async) !== ' ') {\n                      <div [ngStyle]=\"fieldConfig.ngStyle || {}\"\n                        [ngClass]=\"fieldConfig.ngClass || {}\"\n                        [class.ml-[8px]]=\"!fieldConfig.ignoreClassMarginLeft\">\n                        <libs_ui-components-dropdown [isNgContent]=\"true\"\n                          [popoverCustomConfig]=\"{\n                widthByParent:false,\n                ignoreArrow: fieldConfig.dropdownConfig?.ignoreArrow || false,\n                maxHeight: fieldConfig.dropdownConfig?.maxHeight || 2048,\n                paddingLeftItem:fieldConfig.dropdownConfig?.paddingLeftItem ?? true,\n                classInclude:fieldConfig.dropdownConfig?.classIncludePopup || 'w-[250px]',\n                position: fieldConfig.dropdownConfig?.position || {\n                  mode:'center',\n                  distance:0\n                }\n              }\"\n                          [zIndex]=\"fieldConfig.dropdownConfig?.zIndex\"\n                          [listConfig]=\"fieldConfig.dropdownConfig?.getListViewConfig ? ((item()[fieldConfig.field] | LibsUiPipesCallFunctionInTemplatePipe:fieldConfig.dropdownConfig?.getListViewConfig:item()) | async):fieldConfig.dropdownConfig?.listViewConfig\"\n                          [listBackgroundCustom]=\"fieldConfig.dropdownConfig?.listViewBackgroundListCustom\"\n                          [listMaxItemShow]=\"fieldConfig.dropdownConfig?.listViewMaxItemShow || 5\"\n                          [listKeysDisable]=\"fieldConfig.dropdownConfig?.listViewKeysDisableItem\"\n                          (outFunctionsControl)=\"handlerFunctionControl($event, index)\"\n                          (outSelectKey)=\"handlerSelectItemDropdown(fieldConfig, index,$event)\"\n                          (outSelectMultiKey)=\"handlerSelectItemsDropdown(fieldConfig, index,$event)\">\n                          @if (fieldConfig.instance === 'other-action-show-popup') {\n                            <div\n                              [innerHtml]=\"(item()[fieldConfig.field] | LibsUiPipesCallFunctionInTemplatePipe:fieldConfig.parseValue:item())| async | translate\">\n                            </div>\n                          }\n                          @if (fieldConfig.instance === 'badge' && (item()[fieldConfig.field] | LibsUiPipesCallFunctionInTemplatePipe:fieldConfig.parseValue:item() | async) > 0) {\n                            <libs_ui-components-badge [active]=\"true\"\n                              [ignoreMarginDefault]=\"true\"\n                              mode=\"+x\"\n                              [count]=\"item()[fieldConfig.field] | LibsUiPipesCallFunctionInTemplatePipe:fieldConfig.parseValue:item() | async\"\n                              [maxCount]=\"99\" />\n                          }\n                          @if (fieldConfig.instance === 'button-action-show-popup') {\n                            <libs_ui-components-buttons-button\n                              [type]=\"fieldConfig?.buttonDropDown()?.type || 'button-primary'\"\n                              [sizeButton]=\"fieldConfig?.buttonDropDown()?.sizeButton || 'smaller'\"\n                              [disable]=\"fieldConfig?.buttonDropDown()?.disable ?? (item()[fieldConfig.field] | LibsUiPipesCallFunctionInTemplatePipe:fieldConfig.getDisable:item() | async)\"\n                              [label]=\"fieldConfig?.buttonDropDown()?.label || ' '\"\n                              [classIconLeft]=\"fieldConfig?.buttonDropDown()?.classIconLeft || ''\"\n                              [classIconRight]=\"fieldConfig?.buttonDropDown()?.classIconRight || ''\"\n                              [popover]=\"fieldConfig?.buttonDropDown()?.popover || {}\"\n                              [classInclude]=\"fieldConfig?.buttonDropDown()?.classInclude || ''\"\n                              [ignoreStopPropagationEvent]=\"true\" />\n                          }\n\n                        </libs_ui-components-dropdown>\n                      </div>\n                    }\n                  }\n\n                  @case (\"line-clamp\") {\n                    <div [ngStyle]=\"fieldConfig.ngStyle || {}\"\n                      [ngClass]=\"fieldConfig.ngClass || {}\">\n                      @if (fieldConfig.lineClampConfig; as lineClampConfig) {\n                        <libs_ui-components-line_clamp\n                          [ignoreShowButtonCollapseExpand]=\"lineClampConfig.ignoreShowButtonCollapseExpand ?? true\"\n                          [showTooltip]=\"lineClampConfig.showTooltip ?? true\"\n                          [maxHeight]=\"lineClampConfig.maxHeight || 36\"\n                          [maxWidthPopover]=\"lineClampConfig.maxWidthPopover || 200\"\n                          [maxHeightPopover]=\"lineClampConfig.maxHeightPopover || 100\"\n                          [ngClassObject]=\"lineClampConfig.ngClassObject ?? { 'libs-ui-line-clamp-content mo-lib-font-head-5': true }\"\n                          [isInnerText]=\"lineClampConfig.isInnerText || false\"\n                          [ignoreStopPropagationTooltipEvent]=\"true\"\n                          [content]=\"item()[fieldConfig.field] | LibsUiPipesCallFunctionInTemplatePipe:fieldConfig.parseValue:item() | async\"\n                          (click)=\"handlerItemClick($event,fieldConfig,item()[fieldConfig.field])\" />\n                      }\n                    </div>\n                  }\n\n                  @case (\"shape-style\") {\n                    <div [ngStyle]=\"fieldConfig.ngStyle || {}\"\n                      [ngClass]=\"fieldConfig.ngClass || {}\"\n                      [innerHTML]=\"(item()[fieldConfig.field] | LibsUiPipesCallFunctionInTemplatePipe:fieldConfig.parseValue:item())| async | translate | LibsUiPipesSecurityTrustPipe:'html':true | async\"\n                      (click)=\"handlerItemClick($event,fieldConfig,item()[fieldConfig.field])\">\n                    </div>\n                  }\n                  @default {\n                    @if (((item()[fieldConfig.field] | LibsUiPipesCallFunctionInTemplatePipe:fieldConfig.parseValue:item()) | async | translate); as value) {\n                      @if (value !==' ') {\n                        <div [ngStyle]=\"fieldConfig.ngStyle || {}\"\n                          [ngClass]=\"fieldConfig.ngClass || {}\"\n                          [innerHTML]=\"value | LibsUiPipesSecurityTrustPipe:'html':true|async\"\n                          (click)=\"handlerItemClick($event,fieldConfig,item()[fieldConfig.field])\">\n                        </div>\n                      }\n                    }\n                  }\n                }\n              } @else {\n                @if (fieldConfig.rows) {\n                  <div class=\"w-full flex relative {{ fieldConfig.rowsTemplateCssWrapper }}\">\n                    <div class=\"w-full flex absolute  {{ fieldConfig.rowsTemplateCssWrapper }}\">\n                      <libs_ui-components-table-templates class=\"flex w-full\"\n                        [item]=\"item\"\n                        [configs]=\"fieldConfig.rows\" />\n                    </div>\n                  </div>\n                }\n                @else {\n                  <ng-container\n                    *ngComponentOutlet=\"(item()[fieldConfig.field] | LibsUiPipesCallFunctionInTemplatePipe:fieldConfig.getComponentOutlet) | async; inputs:{item}\" />\n                }\n              }\n\n            }\n          </div>\n        }\n      }\n    </div>\n  }\n}\n"]}