@libs-ui/components-pages-template-full-screen 0.2.356-1 → 0.2.356-10

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -0,0 +1,151 @@
1
+ import { AsyncPipe, NgComponentOutlet, NgTemplateOutlet } from '@angular/common';
2
+ import { ChangeDetectionStrategy, Component, computed, DestroyRef, inject, input, output, signal } from '@angular/core';
3
+ import { takeUntilDestroyed } from '@angular/core/rxjs-interop';
4
+ import { LibsUiComponentsButtonsButtonComponent } from '@libs-ui/components-buttons-button';
5
+ import { LibsUiComponentsButtonsStatusComponent } from '@libs-ui/components-buttons-status';
6
+ import { LibsUiComponentsDropdownComponent } from '@libs-ui/components-dropdown';
7
+ import { LibsUiComponentsLabelComponent } from '@libs-ui/components-label';
8
+ import { LibsUiComponentsPopoverComponent } from '@libs-ui/components-popover';
9
+ import { LibsUiComponentsSkeletonComponent } from '@libs-ui/components-skeleton';
10
+ import { LibsUiComponentsSwitchComponent } from '@libs-ui/components-switch';
11
+ import { LibsUiPipesCallFunctionInTemplatePipe } from '@libs-ui/pipes-call-function-in-template';
12
+ import { LibsUiPipesEscapeHtmlPipe } from '@libs-ui/pipes-escape-html';
13
+ import { get, getDayjs, UtilsCommunicateMicro, UtilsCommunicateMicroKeyGlobal, uuid } from '@libs-ui/utils';
14
+ import { TranslateModule } from '@ngx-translate/core';
15
+ import { interval } from 'rxjs';
16
+ import * as i0 from "@angular/core";
17
+ /**
18
+ * Full Screen Template V2 — Kế thừa toàn bộ V1, bổ sung lazy loading cho body.
19
+ * Header giữ nguyên 100%. Body hỗ trợ dynamic component injection với skeleton tự động.
20
+ */
21
+ export class LibsUiComponentsPagesTemplateFullScreenV2Component {
22
+ // #region --- INPUTS (kế thừa từ V1) ---
23
+ classHeaderInclude = input();
24
+ labelLeft = input('i18n_back_to_list', { transform: (val) => val ?? 'i18n_back_to_list' });
25
+ title = input();
26
+ buttonCenter = input();
27
+ buttonRight = input();
28
+ hasEdit = input(false);
29
+ menuDropDownConfigs = input();
30
+ zIndex = input(1000, { transform: (val) => val ?? 1000 });
31
+ ignoreClosePageFullEvent = input(false, { transform: (val) => val ?? false });
32
+ ignoreBackgroundColor = input();
33
+ divideClassHeader = input();
34
+ centerTemplate = input();
35
+ templateRight = input();
36
+ leftTemplate = input();
37
+ disable = input(false, { transform: (val) => val ?? false });
38
+ // #endregion
39
+ // #region --- INPUTS (mới trong V2) ---
40
+ /** Config lazy load component vào body. Nếu không truyền getComponentOutlet → tự động dùng ng-content. */
41
+ bodyConfig = input({}, { transform: (v) => v || {} });
42
+ // #endregion
43
+ // #region --- OUTPUTS ---
44
+ outClose = output();
45
+ outEdit = output();
46
+ outSelectedMenuDropdown = output();
47
+ outClickButton = output();
48
+ // #endregion
49
+ // #region --- INTERNAL STATE ---
50
+ idOverlay = signal(uuid()).asReadonly();
51
+ destroyRef = inject(DestroyRef);
52
+ functionControlMenu;
53
+ // #endregion
54
+ // #region --- COMPUTED ---
55
+ /** State reactive để truyền vào component outlet */
56
+ sectionData = computed(() => ({
57
+ disable: this.disable(),
58
+ }));
59
+ /** Skeleton body — fallback về config mặc định nếu không được truyền */
60
+ resolvedSkeletonBody = computed(() => {
61
+ return (get(this.bodyConfig, 'skeletonConfig') ?? {
62
+ repeat: 3,
63
+ styleMarginBottom: 16,
64
+ rows: [{ item: { classInclude: 'w-full h-[120px] rounded-[8px]' } }],
65
+ });
66
+ });
67
+ // #endregion
68
+ ngOnInit() {
69
+ if (!this.ignoreClosePageFullEvent()) {
70
+ const data = {
71
+ type: UtilsCommunicateMicroKeyGlobal.KEY_MESSAGE_MODAL,
72
+ response: {
73
+ message: 'open',
74
+ state: true,
75
+ idOverlay: this.idOverlay(),
76
+ timeLiveUpdate: getDayjs().unix(),
77
+ ignoreIntervalUpdateTimeLiveEvent: UtilsCommunicateMicroKeyGlobal.IGNORE_INTERVAL_UPDATE_TIME_LIVE_EVENT_MODAL,
78
+ },
79
+ };
80
+ UtilsCommunicateMicro.PostMessageToParent(data);
81
+ if (!UtilsCommunicateMicroKeyGlobal.IGNORE_INTERVAL_UPDATE_TIME_LIVE_EVENT_MODAL) {
82
+ interval(2000)
83
+ .pipe(takeUntilDestroyed(this.destroyRef))
84
+ .subscribe(() => {
85
+ data.response.timeLiveUpdate = getDayjs().unix();
86
+ UtilsCommunicateMicro.PostMessageToParent(data);
87
+ });
88
+ }
89
+ }
90
+ }
91
+ // #region --- EVENT HANDLERS ---
92
+ handlerEdit() {
93
+ this.outEdit.emit();
94
+ }
95
+ cancel() {
96
+ this.outClose.emit();
97
+ }
98
+ async handlerClickButton(button) {
99
+ if (button && button.action) {
100
+ await button.action();
101
+ }
102
+ this.outClickButton.emit(button);
103
+ }
104
+ async handlerSwitch(event, button) {
105
+ if (button && button.action) {
106
+ await button.action(event);
107
+ }
108
+ }
109
+ handlerSelectedKey(event) {
110
+ this.outSelectedMenuDropdown.emit(event);
111
+ this.functionControlMenu?.reset();
112
+ }
113
+ handlerControlDropdownMenu(event) {
114
+ this.functionControlMenu = event;
115
+ }
116
+ // #endregion
117
+ ngOnDestroy() {
118
+ if (!this.ignoreClosePageFullEvent()) {
119
+ const data = {
120
+ type: UtilsCommunicateMicroKeyGlobal.KEY_MESSAGE_MODAL,
121
+ response: {
122
+ message: 'close',
123
+ state: false,
124
+ idOverlay: this.idOverlay(),
125
+ },
126
+ };
127
+ UtilsCommunicateMicro.PostMessageToParent(data);
128
+ }
129
+ }
130
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: LibsUiComponentsPagesTemplateFullScreenV2Component, deps: [], target: i0.ɵɵFactoryTarget.Component });
131
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.14", type: LibsUiComponentsPagesTemplateFullScreenV2Component, isStandalone: true, selector: "libs_ui-components-pages_template_full_screen_v2", inputs: { classHeaderInclude: { classPropertyName: "classHeaderInclude", publicName: "classHeaderInclude", isSignal: true, isRequired: false, transformFunction: null }, labelLeft: { classPropertyName: "labelLeft", publicName: "labelLeft", isSignal: true, isRequired: false, transformFunction: null }, title: { classPropertyName: "title", publicName: "title", isSignal: true, isRequired: false, transformFunction: null }, buttonCenter: { classPropertyName: "buttonCenter", publicName: "buttonCenter", isSignal: true, isRequired: false, transformFunction: null }, buttonRight: { classPropertyName: "buttonRight", publicName: "buttonRight", isSignal: true, isRequired: false, transformFunction: null }, hasEdit: { classPropertyName: "hasEdit", publicName: "hasEdit", isSignal: true, isRequired: false, transformFunction: null }, menuDropDownConfigs: { classPropertyName: "menuDropDownConfigs", publicName: "menuDropDownConfigs", isSignal: true, isRequired: false, transformFunction: null }, zIndex: { classPropertyName: "zIndex", publicName: "zIndex", isSignal: true, isRequired: false, transformFunction: null }, ignoreClosePageFullEvent: { classPropertyName: "ignoreClosePageFullEvent", publicName: "ignoreClosePageFullEvent", isSignal: true, isRequired: false, transformFunction: null }, ignoreBackgroundColor: { classPropertyName: "ignoreBackgroundColor", publicName: "ignoreBackgroundColor", isSignal: true, isRequired: false, transformFunction: null }, divideClassHeader: { classPropertyName: "divideClassHeader", publicName: "divideClassHeader", isSignal: true, isRequired: false, transformFunction: null }, centerTemplate: { classPropertyName: "centerTemplate", publicName: "centerTemplate", isSignal: true, isRequired: false, transformFunction: null }, templateRight: { classPropertyName: "templateRight", publicName: "templateRight", isSignal: true, isRequired: false, transformFunction: null }, leftTemplate: { classPropertyName: "leftTemplate", publicName: "leftTemplate", isSignal: true, isRequired: false, transformFunction: null }, disable: { classPropertyName: "disable", publicName: "disable", isSignal: true, isRequired: false, transformFunction: null }, bodyConfig: { classPropertyName: "bodyConfig", publicName: "bodyConfig", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { outClose: "outClose", outEdit: "outEdit", outSelectedMenuDropdown: "outSelectedMenuDropdown", outClickButton: "outClickButton" }, ngImport: i0, template: "<div\n class=\"libs-ui-components-page_full overflow-hidden\"\n [style.zIndex]=\"zIndex()\"\n [style.background-color]=\"ignoreBackgroundColor() ? 'transparent' : '#f2f5f7'\">\n <!-- ===================== HEADER (gi\u1EEF nguy\u00EAn 100% t\u1EEB V1) ===================== -->\n <div [class]=\"'libs-ui-components-page_full-header ' + classHeaderInclude()\">\n <div class=\"{{ divideClassHeader()?.classButtonCancel || 'w-[25%]' }}\">\n @if (leftTemplate(); as leftTemplate) {\n <ng-container *ngTemplateOutlet=\"leftTemplate\" />\n }\n @if (labelLeft(); as labelLeft) {\n <libs_ui-components-buttons-button\n [label]=\"labelLeft\"\n [type]=\"'button-link-primary'\"\n [classIconLeft]=\"'libs-ui-icon-chevron-right rotate-[180deg] before:text-[16px]'\"\n [classLabel]=\"'libs-ui-font-h4r'\"\n (outClick)=\"cancel()\" />\n }\n </div>\n\n @if (centerTemplate(); as centerTemplate) {\n <div class=\"{{ divideClassHeader()?.classButtonCenter || 'w-[40%]' }} flex items-center justify-center\">\n <ng-container *ngTemplateOutlet=\"centerTemplate\" />\n </div>\n } @else {\n <div class=\"{{ divideClassHeader()?.classButtonCenter || 'w-[40%]' }} flex items-center justify-center\">\n <libs_ui-components-popover\n type=\"text\"\n [config]=\"{ maxWidth: 250, zIndex: zIndex() + 1 }\"\n [classInclude]=\"'libs-ui-font-h2s'\"\n [innerHtml]=\"title() ? (title() | LibsUiPipesEscapeHtmlPipe) : '&mdash;'\" />\n @if (hasEdit(); as hasEdit) {\n <libs_ui-components-buttons-button\n [type]=\"'button-link-primary'\"\n (outClick)=\"handlerEdit()\"\n [iconOnlyType]=\"true\"\n [classIconLeft]=\"'libs-ui-icon-edit-line'\"\n [classInclude]=\"'ml-[4px]'\" />\n }\n @for (button of buttonCenter(); track button.key) {\n <div class=\"ml-[12px] flex items-center\">\n @if (button.key === 'button') {\n <libs_ui-components-buttons-button\n [label]=\"button.label || ''\"\n [classLabel]=\"(button.classLabel || '') + ' libs-ui-font-head-4s'\"\n [type]=\"button.type || 'button-primary'\"\n [classInclude]=\"button.classInclude || ''\"\n [classIconLeft]=\"button.classIconLeft || ''\"\n [classIconRight]=\"button.classIconRight || ''\"\n [popover]=\"button.popover || {}\"\n [disable]=\"button.disable || disable()\"\n [isPending]=\"button.isPending || false\"\n (outClick)=\"handlerClickButton(button)\" />\n }\n @if (button.key === 'button-status' && button.configButtonStatus) {\n <libs_ui-components-buttons-status\n [class]=\"button.classInclude\"\n [config]=\"button.configButtonStatus\" />\n }\n @if (button.key === 'switch') {\n <libs_ui-components-switch\n [active]=\"button.active || false\"\n [disable]=\"button.disable || disable()\"\n class=\"{{ button.classInclude }}\"\n (outSwitch)=\"handlerSwitch($event, button)\" />\n }\n @if (button.key === 'label' && button.labelConfig) {\n <libs_ui-components-label\n [classInclude]=\"button.labelConfig.classInclude + ' pb-0 text-white'\"\n [labelLeft]=\"button.labelConfig.labelLeft\"\n [labelLeftClass]=\"button.labelConfig.labelLeftClass\"\n [required]=\"button.labelConfig.required\"\n [description]=\"button.labelConfig.description\"\n [labelRight]=\"button.labelConfig.labelRight\"\n [labelRightClass]=\"button.labelConfig.labelRightClass\"\n [onlyShowCount]=\"button.labelConfig.onlyShowCount\"\n [buttonsLeft]=\"button.labelConfig.buttonsLeft\"\n [disableButtonsLeft]=\"button.labelConfig.disableButtonsLeft\"\n [buttonsRight]=\"button.labelConfig.buttonsRight\"\n [disableButtonsRight]=\"button.labelConfig.disableButtonsRight\"\n [hasToggle]=\"button.labelConfig.hasToggle\"\n [toggleActive]=\"button.labelConfig.toggleActive\"\n [toggleDisable]=\"button.labelConfig.toggleDisable\"\n [popover]=\"button.labelConfig.popover\"\n [iconPopoverClass]=\"button.labelConfig.iconPopoverClass\"\n [limitLength]=\"button.labelConfig.limitLength\"\n [buttonsDescription]=\"button.labelConfig.buttonsDescription\"\n [disableButtonsDescription]=\"button.labelConfig.disableButtonsDescription\"\n [buttonsDescriptionContainerClass]=\"button.labelConfig.buttonsDescriptionContainerClass\"\n [count]=\"button.labelConfig.count\" />\n }\n </div>\n }\n </div>\n }\n\n <div class=\"{{ divideClassHeader()?.classButtonRight || 'w-[35%]' }} flex justify-end items-center\">\n @for (button of buttonRight(); track button.key) {\n <div [class.ml-[12px]]=\"!$first\">\n @if (button.key === 'label' && button.labelConfig) {\n <libs_ui-components-label\n [classInclude]=\"button.labelConfig.classInclude + ' pb-0'\"\n [labelLeft]=\"button.labelConfig.labelLeft\"\n [labelLeftClass]=\"button.labelConfig.labelLeftClass\"\n [required]=\"button.labelConfig.required\"\n [description]=\"button.labelConfig.description\"\n [labelRight]=\"button.labelConfig.labelRight\"\n [labelRightClass]=\"button.labelConfig.labelRightClass\"\n [onlyShowCount]=\"button.labelConfig.onlyShowCount\"\n [buttonsLeft]=\"button.labelConfig.buttonsLeft\"\n [disableButtonsLeft]=\"button.labelConfig.disableButtonsLeft\"\n [buttonsRight]=\"button.labelConfig.buttonsRight\"\n [disableButtonsRight]=\"button.labelConfig.disableButtonsRight\"\n [hasToggle]=\"button.labelConfig.hasToggle\"\n [toggleActive]=\"button.labelConfig.toggleActive\"\n [toggleDisable]=\"button.labelConfig.toggleDisable\"\n [popover]=\"button.labelConfig.popover\"\n [iconPopoverClass]=\"button.labelConfig.iconPopoverClass\"\n [limitLength]=\"button.labelConfig.limitLength\"\n [buttonsDescription]=\"button.labelConfig.buttonsDescription\"\n [disableButtonsDescription]=\"button.labelConfig.disableButtonsDescription\"\n [buttonsDescriptionContainerClass]=\"button.labelConfig.buttonsDescriptionContainerClass\"\n [count]=\"button.labelConfig.count\" />\n }\n @if (button.key === 'switch') {\n <libs_ui-components-switch\n [active]=\"button.active || false\"\n [disable]=\"button.disable || disable()\"\n class=\"{{ button.classInclude }}\"\n (outSwitch)=\"handlerSwitch($event, button)\" />\n }\n @if (button.key === 'button') {\n <libs_ui-components-buttons-button\n [label]=\"button?.label || ''\"\n [classLabel]=\"(button.classLabel || '') + ' libs-ui-font-h4s'\"\n [type]=\"button.type || 'button-primary'\"\n [classInclude]=\"button.classInclude || ''\"\n [classIconLeft]=\"button.classIconLeft || ''\"\n [classIconRight]=\"button.classIconRight || ''\"\n [popover]=\"button.popover || {}\"\n [disable]=\"button.disable || disable()\"\n [isPending]=\"button.isPending || false\"\n [iconOnlyType]=\"button.iconOnlyType || false\"\n (outClick)=\"handlerClickButton(button)\" />\n }\n @if (button.key === 'line-space') {\n <div\n class=\"bg-[#666b79] w-[1px] h-[28px]\"\n [class]=\"button.classInclude\">\n &nbsp;\n </div>\n }\n </div>\n }\n @if (menuDropDownConfigs(); as menuDropDownConfigs) {\n <div class=\"ml-[12px]\">\n <libs_ui-components-dropdown\n [isNgContent]=\"true\"\n [zIndex]=\"zIndex() + 1\"\n [listConfig]=\"menuDropDownConfigs.listConfig\"\n [listHiddenInputSearch]=\"true\"\n [popoverCustomConfig]=\"menuDropDownConfigs.popoverCustomConfig\"\n (outFunctionsControl)=\"handlerControlDropdownMenu($event)\"\n (outSelectKey)=\"handlerSelectedKey($event)\">\n <libs_ui-components-buttons-button\n [classInclude]=\"'p-[8px]'\"\n [type]=\"'button-third'\"\n [iconOnlyType]=\"true\"\n [classIconLeft]=\"'libs-ui-icon-more-vertical text-[#333333] text-[12px]'\"\n [popover]=\"{ config: { content: 'i18n_4x_other_operations' } }\"\n [ignoreStopPropagationEvent]=\"true\" />\n </libs_ui-components-dropdown>\n </div>\n }\n @if (templateRight(); as templateRight) {\n <ng-container *ngTemplateOutlet=\"templateRight\" />\n }\n </div>\n </div>\n\n <!-- ===================== BODY (V2: Lazy Load ho\u1EB7c ng-content) ===================== -->\n @if (bodyConfig().getComponentOutlet; as getBodyComponentOutlet) {\n <!-- Lazy load mode -->\n <div [class]=\"'libs-ui-components-page_full-body ' + (bodyConfig().classInclude || '')\">\n @let constHtmlCompBody = undefined | LibsUiPipesCallFunctionInTemplatePipe: getBodyComponentOutlet : sectionData() : null : { valueIsEmpty: null } | async;\n @let constHtmlInputsBody = undefined | LibsUiPipesCallFunctionInTemplatePipe: bodyConfig().getDataComponentOutlet : sectionData() : null : { valueIsEmpty: null } | async;\n @if (constHtmlCompBody) {\n @defer {\n <ng-container *ngComponentOutlet=\"constHtmlCompBody; inputs: constHtmlInputsBody\" />\n } @loading {\n <libs_ui-components-skeleton [config]=\"resolvedSkeletonBody()\" />\n }\n } @else {\n <libs_ui-components-skeleton [config]=\"resolvedSkeletonBody()\" />\n }\n </div>\n }\n</div>\n", styles: ["@-webkit-keyframes animation-slide-to-left{0%{right:-200px;opacity:0}to{right:12px;opacity:1}}@keyframes animation-slide-to-left{0%{right:-200px;opacity:0}to{right:0;opacity:1}}.libs-ui-components-page_full{position:absolute;width:100vw;height:100vh;left:0;top:0;display:flex;flex-direction:column;animation:animation-slide-to-left ease-out .3s}.libs-ui-components-page_full .libs-ui-components-page_full-header{height:50px;padding:14px 16px;border-bottom:solid 1px #e6e7ea;background-color:#fff;width:100%;display:flex;align-items:center}.libs-ui-components-page_full .libs-ui-components-page_full-body{height:100%}\n"], dependencies: [{ kind: "pipe", type: AsyncPipe, name: "async" }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "ngmodule", type: TranslateModule }, { 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", "fieldLabel", "fieldGetLabel", "labelPopoverConfig", "labelPopoverFullWidth", "hasContentUnitRight", "listSearchNoDataTemplateRef", "dropdownTemplateRefNotSearchNoData", "fieldGetImage", "imageSize", "typeShape", "fieldGetIcon", "fieldGetTextAvatar", "fieldGetColorAvatar", "classAvatarInclude", "getLastTextAfterSpace", "linkImageError", "showError", "showBorderError", "disable", "readonly", "labelConfig", "disableLabel", "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: LibsUiComponentsSwitchComponent, selector: "libs_ui-components-switch", inputs: ["size", "disable", "active"], outputs: ["activeChange", "outSwitch"] }, { 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: LibsUiComponentsButtonsStatusComponent, selector: "libs_ui-components-buttons-status", inputs: ["config"] }, { 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: LibsUiComponentsSkeletonComponent, selector: "libs_ui-components-skeleton", inputs: ["config"] }, { kind: "pipe", type: LibsUiPipesCallFunctionInTemplatePipe, name: "LibsUiPipesCallFunctionInTemplatePipe" }, { kind: "pipe", type: LibsUiPipesEscapeHtmlPipe, name: "LibsUiPipesEscapeHtmlPipe" }, { kind: "component", type: LibsUiComponentsLabelComponent, selector: "libs_ui-components-label", inputs: ["iconPopoverClass", "classInclude", "labelLeft", "labelLeftClass", "labelLeftBehindToggleButton", "popover", "required", "buttonsLeft", "disableButtonsLeft", "buttonsRight", "disableButtonsRight", "labelRight", "labelRightClass", "labelRightRequired", "hasToggle", "toggleSize", "toggleActive", "toggleDisable", "description", "descriptionClass", "buttonsDescription", "disableButtonsDescription", "buttonsDescriptionContainerClass", "onlyShowCount", "zIndexPopover", "timerDestroyPopover", "count", "limitLength"], outputs: ["outClickButton", "outSwitchEvent", "outLabelRightClick", "outLabelLeftClick"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, deferBlockDependencies: [() => [NgComponentOutlet]] });
132
+ }
133
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: LibsUiComponentsPagesTemplateFullScreenV2Component, decorators: [{
134
+ type: Component,
135
+ args: [{ selector: 'libs_ui-components-pages_template_full_screen_v2', standalone: true, changeDetection: ChangeDetectionStrategy.OnPush, imports: [
136
+ AsyncPipe,
137
+ NgComponentOutlet,
138
+ NgTemplateOutlet,
139
+ TranslateModule,
140
+ LibsUiComponentsDropdownComponent,
141
+ LibsUiComponentsSwitchComponent,
142
+ LibsUiComponentsButtonsButtonComponent,
143
+ LibsUiComponentsButtonsStatusComponent,
144
+ LibsUiComponentsPopoverComponent,
145
+ LibsUiComponentsSkeletonComponent,
146
+ LibsUiPipesCallFunctionInTemplatePipe,
147
+ LibsUiPipesEscapeHtmlPipe,
148
+ LibsUiComponentsLabelComponent,
149
+ ], template: "<div\n class=\"libs-ui-components-page_full overflow-hidden\"\n [style.zIndex]=\"zIndex()\"\n [style.background-color]=\"ignoreBackgroundColor() ? 'transparent' : '#f2f5f7'\">\n <!-- ===================== HEADER (gi\u1EEF nguy\u00EAn 100% t\u1EEB V1) ===================== -->\n <div [class]=\"'libs-ui-components-page_full-header ' + classHeaderInclude()\">\n <div class=\"{{ divideClassHeader()?.classButtonCancel || 'w-[25%]' }}\">\n @if (leftTemplate(); as leftTemplate) {\n <ng-container *ngTemplateOutlet=\"leftTemplate\" />\n }\n @if (labelLeft(); as labelLeft) {\n <libs_ui-components-buttons-button\n [label]=\"labelLeft\"\n [type]=\"'button-link-primary'\"\n [classIconLeft]=\"'libs-ui-icon-chevron-right rotate-[180deg] before:text-[16px]'\"\n [classLabel]=\"'libs-ui-font-h4r'\"\n (outClick)=\"cancel()\" />\n }\n </div>\n\n @if (centerTemplate(); as centerTemplate) {\n <div class=\"{{ divideClassHeader()?.classButtonCenter || 'w-[40%]' }} flex items-center justify-center\">\n <ng-container *ngTemplateOutlet=\"centerTemplate\" />\n </div>\n } @else {\n <div class=\"{{ divideClassHeader()?.classButtonCenter || 'w-[40%]' }} flex items-center justify-center\">\n <libs_ui-components-popover\n type=\"text\"\n [config]=\"{ maxWidth: 250, zIndex: zIndex() + 1 }\"\n [classInclude]=\"'libs-ui-font-h2s'\"\n [innerHtml]=\"title() ? (title() | LibsUiPipesEscapeHtmlPipe) : '&mdash;'\" />\n @if (hasEdit(); as hasEdit) {\n <libs_ui-components-buttons-button\n [type]=\"'button-link-primary'\"\n (outClick)=\"handlerEdit()\"\n [iconOnlyType]=\"true\"\n [classIconLeft]=\"'libs-ui-icon-edit-line'\"\n [classInclude]=\"'ml-[4px]'\" />\n }\n @for (button of buttonCenter(); track button.key) {\n <div class=\"ml-[12px] flex items-center\">\n @if (button.key === 'button') {\n <libs_ui-components-buttons-button\n [label]=\"button.label || ''\"\n [classLabel]=\"(button.classLabel || '') + ' libs-ui-font-head-4s'\"\n [type]=\"button.type || 'button-primary'\"\n [classInclude]=\"button.classInclude || ''\"\n [classIconLeft]=\"button.classIconLeft || ''\"\n [classIconRight]=\"button.classIconRight || ''\"\n [popover]=\"button.popover || {}\"\n [disable]=\"button.disable || disable()\"\n [isPending]=\"button.isPending || false\"\n (outClick)=\"handlerClickButton(button)\" />\n }\n @if (button.key === 'button-status' && button.configButtonStatus) {\n <libs_ui-components-buttons-status\n [class]=\"button.classInclude\"\n [config]=\"button.configButtonStatus\" />\n }\n @if (button.key === 'switch') {\n <libs_ui-components-switch\n [active]=\"button.active || false\"\n [disable]=\"button.disable || disable()\"\n class=\"{{ button.classInclude }}\"\n (outSwitch)=\"handlerSwitch($event, button)\" />\n }\n @if (button.key === 'label' && button.labelConfig) {\n <libs_ui-components-label\n [classInclude]=\"button.labelConfig.classInclude + ' pb-0 text-white'\"\n [labelLeft]=\"button.labelConfig.labelLeft\"\n [labelLeftClass]=\"button.labelConfig.labelLeftClass\"\n [required]=\"button.labelConfig.required\"\n [description]=\"button.labelConfig.description\"\n [labelRight]=\"button.labelConfig.labelRight\"\n [labelRightClass]=\"button.labelConfig.labelRightClass\"\n [onlyShowCount]=\"button.labelConfig.onlyShowCount\"\n [buttonsLeft]=\"button.labelConfig.buttonsLeft\"\n [disableButtonsLeft]=\"button.labelConfig.disableButtonsLeft\"\n [buttonsRight]=\"button.labelConfig.buttonsRight\"\n [disableButtonsRight]=\"button.labelConfig.disableButtonsRight\"\n [hasToggle]=\"button.labelConfig.hasToggle\"\n [toggleActive]=\"button.labelConfig.toggleActive\"\n [toggleDisable]=\"button.labelConfig.toggleDisable\"\n [popover]=\"button.labelConfig.popover\"\n [iconPopoverClass]=\"button.labelConfig.iconPopoverClass\"\n [limitLength]=\"button.labelConfig.limitLength\"\n [buttonsDescription]=\"button.labelConfig.buttonsDescription\"\n [disableButtonsDescription]=\"button.labelConfig.disableButtonsDescription\"\n [buttonsDescriptionContainerClass]=\"button.labelConfig.buttonsDescriptionContainerClass\"\n [count]=\"button.labelConfig.count\" />\n }\n </div>\n }\n </div>\n }\n\n <div class=\"{{ divideClassHeader()?.classButtonRight || 'w-[35%]' }} flex justify-end items-center\">\n @for (button of buttonRight(); track button.key) {\n <div [class.ml-[12px]]=\"!$first\">\n @if (button.key === 'label' && button.labelConfig) {\n <libs_ui-components-label\n [classInclude]=\"button.labelConfig.classInclude + ' pb-0'\"\n [labelLeft]=\"button.labelConfig.labelLeft\"\n [labelLeftClass]=\"button.labelConfig.labelLeftClass\"\n [required]=\"button.labelConfig.required\"\n [description]=\"button.labelConfig.description\"\n [labelRight]=\"button.labelConfig.labelRight\"\n [labelRightClass]=\"button.labelConfig.labelRightClass\"\n [onlyShowCount]=\"button.labelConfig.onlyShowCount\"\n [buttonsLeft]=\"button.labelConfig.buttonsLeft\"\n [disableButtonsLeft]=\"button.labelConfig.disableButtonsLeft\"\n [buttonsRight]=\"button.labelConfig.buttonsRight\"\n [disableButtonsRight]=\"button.labelConfig.disableButtonsRight\"\n [hasToggle]=\"button.labelConfig.hasToggle\"\n [toggleActive]=\"button.labelConfig.toggleActive\"\n [toggleDisable]=\"button.labelConfig.toggleDisable\"\n [popover]=\"button.labelConfig.popover\"\n [iconPopoverClass]=\"button.labelConfig.iconPopoverClass\"\n [limitLength]=\"button.labelConfig.limitLength\"\n [buttonsDescription]=\"button.labelConfig.buttonsDescription\"\n [disableButtonsDescription]=\"button.labelConfig.disableButtonsDescription\"\n [buttonsDescriptionContainerClass]=\"button.labelConfig.buttonsDescriptionContainerClass\"\n [count]=\"button.labelConfig.count\" />\n }\n @if (button.key === 'switch') {\n <libs_ui-components-switch\n [active]=\"button.active || false\"\n [disable]=\"button.disable || disable()\"\n class=\"{{ button.classInclude }}\"\n (outSwitch)=\"handlerSwitch($event, button)\" />\n }\n @if (button.key === 'button') {\n <libs_ui-components-buttons-button\n [label]=\"button?.label || ''\"\n [classLabel]=\"(button.classLabel || '') + ' libs-ui-font-h4s'\"\n [type]=\"button.type || 'button-primary'\"\n [classInclude]=\"button.classInclude || ''\"\n [classIconLeft]=\"button.classIconLeft || ''\"\n [classIconRight]=\"button.classIconRight || ''\"\n [popover]=\"button.popover || {}\"\n [disable]=\"button.disable || disable()\"\n [isPending]=\"button.isPending || false\"\n [iconOnlyType]=\"button.iconOnlyType || false\"\n (outClick)=\"handlerClickButton(button)\" />\n }\n @if (button.key === 'line-space') {\n <div\n class=\"bg-[#666b79] w-[1px] h-[28px]\"\n [class]=\"button.classInclude\">\n &nbsp;\n </div>\n }\n </div>\n }\n @if (menuDropDownConfigs(); as menuDropDownConfigs) {\n <div class=\"ml-[12px]\">\n <libs_ui-components-dropdown\n [isNgContent]=\"true\"\n [zIndex]=\"zIndex() + 1\"\n [listConfig]=\"menuDropDownConfigs.listConfig\"\n [listHiddenInputSearch]=\"true\"\n [popoverCustomConfig]=\"menuDropDownConfigs.popoverCustomConfig\"\n (outFunctionsControl)=\"handlerControlDropdownMenu($event)\"\n (outSelectKey)=\"handlerSelectedKey($event)\">\n <libs_ui-components-buttons-button\n [classInclude]=\"'p-[8px]'\"\n [type]=\"'button-third'\"\n [iconOnlyType]=\"true\"\n [classIconLeft]=\"'libs-ui-icon-more-vertical text-[#333333] text-[12px]'\"\n [popover]=\"{ config: { content: 'i18n_4x_other_operations' } }\"\n [ignoreStopPropagationEvent]=\"true\" />\n </libs_ui-components-dropdown>\n </div>\n }\n @if (templateRight(); as templateRight) {\n <ng-container *ngTemplateOutlet=\"templateRight\" />\n }\n </div>\n </div>\n\n <!-- ===================== BODY (V2: Lazy Load ho\u1EB7c ng-content) ===================== -->\n @if (bodyConfig().getComponentOutlet; as getBodyComponentOutlet) {\n <!-- Lazy load mode -->\n <div [class]=\"'libs-ui-components-page_full-body ' + (bodyConfig().classInclude || '')\">\n @let constHtmlCompBody = undefined | LibsUiPipesCallFunctionInTemplatePipe: getBodyComponentOutlet : sectionData() : null : { valueIsEmpty: null } | async;\n @let constHtmlInputsBody = undefined | LibsUiPipesCallFunctionInTemplatePipe: bodyConfig().getDataComponentOutlet : sectionData() : null : { valueIsEmpty: null } | async;\n @if (constHtmlCompBody) {\n @defer {\n <ng-container *ngComponentOutlet=\"constHtmlCompBody; inputs: constHtmlInputsBody\" />\n } @loading {\n <libs_ui-components-skeleton [config]=\"resolvedSkeletonBody()\" />\n }\n } @else {\n <libs_ui-components-skeleton [config]=\"resolvedSkeletonBody()\" />\n }\n </div>\n }\n</div>\n", styles: ["@-webkit-keyframes animation-slide-to-left{0%{right:-200px;opacity:0}to{right:12px;opacity:1}}@keyframes animation-slide-to-left{0%{right:-200px;opacity:0}to{right:0;opacity:1}}.libs-ui-components-page_full{position:absolute;width:100vw;height:100vh;left:0;top:0;display:flex;flex-direction:column;animation:animation-slide-to-left ease-out .3s}.libs-ui-components-page_full .libs-ui-components-page_full-header{height:50px;padding:14px 16px;border-bottom:solid 1px #e6e7ea;background-color:#fff;width:100%;display:flex;align-items:center}.libs-ui-components-page_full .libs-ui-components-page_full-body{height:100%}\n"] }]
150
+ }] });
151
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"full-screen-v2.component.js","sourceRoot":"","sources":["../../../../../../../libs-ui/components/pages-template/full-screen/src/full-screen-v2/full-screen-v2.component.ts","../../../../../../../libs-ui/components/pages-template/full-screen/src/full-screen-v2/full-screen-v2.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AsyncPipe, NgComponentOutlet, NgTemplateOutlet } from '@angular/common';\nimport { ChangeDetectionStrategy, Component, computed, DestroyRef, inject, input, OnDestroy, OnInit, output, Signal, signal, TemplateRef } from '@angular/core';\nimport { takeUntilDestroyed } from '@angular/core/rxjs-interop';\nimport { LibsUiComponentsButtonsButtonComponent } from '@libs-ui/components-buttons-button';\nimport { LibsUiComponentsButtonsStatusComponent } from '@libs-ui/components-buttons-status';\nimport { IDropdown, IDropdownFunctionControlEvent, IEmitSelectKey, LibsUiComponentsDropdownComponent } from '@libs-ui/components-dropdown';\nimport { LibsUiComponentsLabelComponent } from '@libs-ui/components-label';\nimport { LibsUiComponentsPopoverComponent } from '@libs-ui/components-popover';\nimport { ISkeletonConfig, LibsUiComponentsSkeletonComponent } from '@libs-ui/components-skeleton';\nimport { ISwitchEvent, LibsUiComponentsSwitchComponent } from '@libs-ui/components-switch';\nimport { TYPE_TEMPLATE_REF } from '@libs-ui/interfaces-types';\nimport { LibsUiPipesCallFunctionInTemplatePipe } from '@libs-ui/pipes-call-function-in-template';\nimport { LibsUiPipesEscapeHtmlPipe } from '@libs-ui/pipes-escape-html';\nimport { get, getDayjs, UtilsCommunicateMicro, UtilsCommunicateMicroKeyGlobal, uuid } from '@libs-ui/utils';\nimport { TranslateModule } from '@ngx-translate/core';\nimport { interval } from 'rxjs';\nimport { IPagesTemplateFullScreenButton } from '../interfaces/config.interface';\nimport { IFullScreenV2BodyConfig, IFullScreenV2SectionData } from './interfaces/full-screen-v2.interface';\n\n/**\n * Full Screen Template V2 — Kế thừa toàn bộ V1, bổ sung lazy loading cho body.\n * Header giữ nguyên 100%. Body hỗ trợ dynamic component injection với skeleton tự động.\n */\n@Component({\n  // eslint-disable-next-line @angular-eslint/component-selector\n  selector: 'libs_ui-components-pages_template_full_screen_v2',\n  templateUrl: './full-screen-v2.component.html',\n  styleUrls: ['./full-screen-v2.component.scss'],\n  standalone: true,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  imports: [\n    AsyncPipe,\n    NgComponentOutlet,\n    NgTemplateOutlet,\n    TranslateModule,\n    LibsUiComponentsDropdownComponent,\n    LibsUiComponentsSwitchComponent,\n    LibsUiComponentsButtonsButtonComponent,\n    LibsUiComponentsButtonsStatusComponent,\n    LibsUiComponentsPopoverComponent,\n    LibsUiComponentsSkeletonComponent,\n    LibsUiPipesCallFunctionInTemplatePipe,\n    LibsUiPipesEscapeHtmlPipe,\n    LibsUiComponentsLabelComponent,\n  ],\n})\nexport class LibsUiComponentsPagesTemplateFullScreenV2Component implements OnInit, OnDestroy {\n  // #region --- INPUTS (kế thừa từ V1) ---\n  readonly classHeaderInclude = input<string>();\n  readonly labelLeft = input<string, string | undefined>('i18n_back_to_list', { transform: (val) => val ?? 'i18n_back_to_list' });\n  readonly title = input<string>();\n  readonly buttonCenter = input<Array<IPagesTemplateFullScreenButton> | undefined>();\n  readonly buttonRight = input<Array<IPagesTemplateFullScreenButton>>();\n  readonly hasEdit = input<boolean>(false);\n  readonly menuDropDownConfigs = input<IDropdown>();\n  readonly zIndex = input<number, number | undefined>(1000, { transform: (val) => val ?? 1000 });\n  readonly ignoreClosePageFullEvent = input<boolean, boolean | undefined>(false, { transform: (val) => val ?? false });\n  readonly ignoreBackgroundColor = input<boolean>();\n  readonly divideClassHeader = input<{ classButtonCancel: string; classButtonCenter: string; classButtonRight: string } | undefined>();\n  readonly centerTemplate = input<TemplateRef<TYPE_TEMPLATE_REF> | undefined>();\n  readonly templateRight = input<TemplateRef<TYPE_TEMPLATE_REF> | undefined>();\n  readonly leftTemplate = input<TemplateRef<TYPE_TEMPLATE_REF> | undefined>();\n  readonly disable = input<boolean, boolean | undefined>(false, { transform: (val) => val ?? false });\n  // #endregion\n\n  // #region --- INPUTS (mới trong V2) ---\n  /** Config lazy load component vào body. Nếu không truyền getComponentOutlet → tự động dùng ng-content. */\n  readonly bodyConfig = input<IFullScreenV2BodyConfig, IFullScreenV2BodyConfig | undefined>({}, { transform: (v) => v || {} });\n  // #endregion\n\n  // #region --- OUTPUTS ---\n  readonly outClose = output<void>();\n  readonly outEdit = output<void>();\n  readonly outSelectedMenuDropdown = output<IEmitSelectKey | undefined>();\n  readonly outClickButton = output<IPagesTemplateFullScreenButton>();\n  // #endregion\n\n  // #region --- INTERNAL STATE ---\n  private readonly idOverlay = signal<string>(uuid()).asReadonly();\n  private readonly destroyRef = inject(DestroyRef);\n  private functionControlMenu: IDropdownFunctionControlEvent | undefined;\n  // #endregion\n\n  // #region --- COMPUTED ---\n  /** State reactive để truyền vào component outlet */\n  protected readonly sectionData = computed<IFullScreenV2SectionData>(() => ({\n    disable: this.disable(),\n  }));\n\n  /** Skeleton body — fallback về config mặc định nếu không được truyền */\n  protected readonly resolvedSkeletonBody: Signal<ISkeletonConfig> = computed(() => {\n    return (\n      get(this.bodyConfig, 'skeletonConfig') ?? {\n        repeat: 3,\n        styleMarginBottom: 16,\n        rows: [{ item: { classInclude: 'w-full h-[120px] rounded-[8px]' } }],\n      }\n    );\n  });\n  // #endregion\n\n  ngOnInit(): void {\n    if (!this.ignoreClosePageFullEvent()) {\n      const data = {\n        type: UtilsCommunicateMicroKeyGlobal.KEY_MESSAGE_MODAL,\n        response: {\n          message: 'open',\n          state: true,\n          idOverlay: this.idOverlay(),\n          timeLiveUpdate: getDayjs().unix(),\n          ignoreIntervalUpdateTimeLiveEvent: UtilsCommunicateMicroKeyGlobal.IGNORE_INTERVAL_UPDATE_TIME_LIVE_EVENT_MODAL,\n        },\n      };\n\n      UtilsCommunicateMicro.PostMessageToParent(data);\n\n      if (!UtilsCommunicateMicroKeyGlobal.IGNORE_INTERVAL_UPDATE_TIME_LIVE_EVENT_MODAL) {\n        interval(2000)\n          .pipe(takeUntilDestroyed(this.destroyRef))\n          .subscribe(() => {\n            data.response.timeLiveUpdate = getDayjs().unix();\n            UtilsCommunicateMicro.PostMessageToParent(data);\n          });\n      }\n    }\n  }\n\n  // #region --- EVENT HANDLERS ---\n  protected handlerEdit() {\n    this.outEdit.emit();\n  }\n\n  protected cancel() {\n    this.outClose.emit();\n  }\n\n  protected async handlerClickButton(button: IPagesTemplateFullScreenButton) {\n    if (button && button.action) {\n      await button.action();\n    }\n    this.outClickButton.emit(button);\n  }\n\n  protected async handlerSwitch(event: ISwitchEvent, button: IPagesTemplateFullScreenButton) {\n    if (button && button.action) {\n      await button.action(event);\n    }\n  }\n\n  protected handlerSelectedKey(event: IEmitSelectKey | undefined) {\n    this.outSelectedMenuDropdown.emit(event);\n    this.functionControlMenu?.reset();\n  }\n\n  protected handlerControlDropdownMenu(event: IDropdownFunctionControlEvent) {\n    this.functionControlMenu = event;\n  }\n  // #endregion\n\n  ngOnDestroy(): void {\n    if (!this.ignoreClosePageFullEvent()) {\n      const data = {\n        type: UtilsCommunicateMicroKeyGlobal.KEY_MESSAGE_MODAL,\n        response: {\n          message: 'close',\n          state: false,\n          idOverlay: this.idOverlay(),\n        },\n      };\n      UtilsCommunicateMicro.PostMessageToParent(data);\n    }\n  }\n}\n","<div\n  class=\"libs-ui-components-page_full overflow-hidden\"\n  [style.zIndex]=\"zIndex()\"\n  [style.background-color]=\"ignoreBackgroundColor() ? 'transparent' : '#f2f5f7'\">\n  <!-- ===================== HEADER (giữ nguyên 100% từ V1) ===================== -->\n  <div [class]=\"'libs-ui-components-page_full-header ' + classHeaderInclude()\">\n    <div class=\"{{ divideClassHeader()?.classButtonCancel || 'w-[25%]' }}\">\n      @if (leftTemplate(); as leftTemplate) {\n        <ng-container *ngTemplateOutlet=\"leftTemplate\" />\n      }\n      @if (labelLeft(); as labelLeft) {\n        <libs_ui-components-buttons-button\n          [label]=\"labelLeft\"\n          [type]=\"'button-link-primary'\"\n          [classIconLeft]=\"'libs-ui-icon-chevron-right rotate-[180deg] before:text-[16px]'\"\n          [classLabel]=\"'libs-ui-font-h4r'\"\n          (outClick)=\"cancel()\" />\n      }\n    </div>\n\n    @if (centerTemplate(); as centerTemplate) {\n      <div class=\"{{ divideClassHeader()?.classButtonCenter || 'w-[40%]' }} flex items-center justify-center\">\n        <ng-container *ngTemplateOutlet=\"centerTemplate\" />\n      </div>\n    } @else {\n      <div class=\"{{ divideClassHeader()?.classButtonCenter || 'w-[40%]' }} flex items-center justify-center\">\n        <libs_ui-components-popover\n          type=\"text\"\n          [config]=\"{ maxWidth: 250, zIndex: zIndex() + 1 }\"\n          [classInclude]=\"'libs-ui-font-h2s'\"\n          [innerHtml]=\"title() ? (title() | LibsUiPipesEscapeHtmlPipe) : '&mdash;'\" />\n        @if (hasEdit(); as hasEdit) {\n          <libs_ui-components-buttons-button\n            [type]=\"'button-link-primary'\"\n            (outClick)=\"handlerEdit()\"\n            [iconOnlyType]=\"true\"\n            [classIconLeft]=\"'libs-ui-icon-edit-line'\"\n            [classInclude]=\"'ml-[4px]'\" />\n        }\n        @for (button of buttonCenter(); track button.key) {\n          <div class=\"ml-[12px] flex items-center\">\n            @if (button.key === 'button') {\n              <libs_ui-components-buttons-button\n                [label]=\"button.label || ''\"\n                [classLabel]=\"(button.classLabel || '') + ' libs-ui-font-head-4s'\"\n                [type]=\"button.type || 'button-primary'\"\n                [classInclude]=\"button.classInclude || ''\"\n                [classIconLeft]=\"button.classIconLeft || ''\"\n                [classIconRight]=\"button.classIconRight || ''\"\n                [popover]=\"button.popover || {}\"\n                [disable]=\"button.disable || disable()\"\n                [isPending]=\"button.isPending || false\"\n                (outClick)=\"handlerClickButton(button)\" />\n            }\n            @if (button.key === 'button-status' && button.configButtonStatus) {\n              <libs_ui-components-buttons-status\n                [class]=\"button.classInclude\"\n                [config]=\"button.configButtonStatus\" />\n            }\n            @if (button.key === 'switch') {\n              <libs_ui-components-switch\n                [active]=\"button.active || false\"\n                [disable]=\"button.disable || disable()\"\n                class=\"{{ button.classInclude }}\"\n                (outSwitch)=\"handlerSwitch($event, button)\" />\n            }\n            @if (button.key === 'label' && button.labelConfig) {\n              <libs_ui-components-label\n                [classInclude]=\"button.labelConfig.classInclude + ' pb-0 text-white'\"\n                [labelLeft]=\"button.labelConfig.labelLeft\"\n                [labelLeftClass]=\"button.labelConfig.labelLeftClass\"\n                [required]=\"button.labelConfig.required\"\n                [description]=\"button.labelConfig.description\"\n                [labelRight]=\"button.labelConfig.labelRight\"\n                [labelRightClass]=\"button.labelConfig.labelRightClass\"\n                [onlyShowCount]=\"button.labelConfig.onlyShowCount\"\n                [buttonsLeft]=\"button.labelConfig.buttonsLeft\"\n                [disableButtonsLeft]=\"button.labelConfig.disableButtonsLeft\"\n                [buttonsRight]=\"button.labelConfig.buttonsRight\"\n                [disableButtonsRight]=\"button.labelConfig.disableButtonsRight\"\n                [hasToggle]=\"button.labelConfig.hasToggle\"\n                [toggleActive]=\"button.labelConfig.toggleActive\"\n                [toggleDisable]=\"button.labelConfig.toggleDisable\"\n                [popover]=\"button.labelConfig.popover\"\n                [iconPopoverClass]=\"button.labelConfig.iconPopoverClass\"\n                [limitLength]=\"button.labelConfig.limitLength\"\n                [buttonsDescription]=\"button.labelConfig.buttonsDescription\"\n                [disableButtonsDescription]=\"button.labelConfig.disableButtonsDescription\"\n                [buttonsDescriptionContainerClass]=\"button.labelConfig.buttonsDescriptionContainerClass\"\n                [count]=\"button.labelConfig.count\" />\n            }\n          </div>\n        }\n      </div>\n    }\n\n    <div class=\"{{ divideClassHeader()?.classButtonRight || 'w-[35%]' }} flex justify-end items-center\">\n      @for (button of buttonRight(); track button.key) {\n        <div [class.ml-[12px]]=\"!$first\">\n          @if (button.key === 'label' && button.labelConfig) {\n            <libs_ui-components-label\n              [classInclude]=\"button.labelConfig.classInclude + ' pb-0'\"\n              [labelLeft]=\"button.labelConfig.labelLeft\"\n              [labelLeftClass]=\"button.labelConfig.labelLeftClass\"\n              [required]=\"button.labelConfig.required\"\n              [description]=\"button.labelConfig.description\"\n              [labelRight]=\"button.labelConfig.labelRight\"\n              [labelRightClass]=\"button.labelConfig.labelRightClass\"\n              [onlyShowCount]=\"button.labelConfig.onlyShowCount\"\n              [buttonsLeft]=\"button.labelConfig.buttonsLeft\"\n              [disableButtonsLeft]=\"button.labelConfig.disableButtonsLeft\"\n              [buttonsRight]=\"button.labelConfig.buttonsRight\"\n              [disableButtonsRight]=\"button.labelConfig.disableButtonsRight\"\n              [hasToggle]=\"button.labelConfig.hasToggle\"\n              [toggleActive]=\"button.labelConfig.toggleActive\"\n              [toggleDisable]=\"button.labelConfig.toggleDisable\"\n              [popover]=\"button.labelConfig.popover\"\n              [iconPopoverClass]=\"button.labelConfig.iconPopoverClass\"\n              [limitLength]=\"button.labelConfig.limitLength\"\n              [buttonsDescription]=\"button.labelConfig.buttonsDescription\"\n              [disableButtonsDescription]=\"button.labelConfig.disableButtonsDescription\"\n              [buttonsDescriptionContainerClass]=\"button.labelConfig.buttonsDescriptionContainerClass\"\n              [count]=\"button.labelConfig.count\" />\n          }\n          @if (button.key === 'switch') {\n            <libs_ui-components-switch\n              [active]=\"button.active || false\"\n              [disable]=\"button.disable || disable()\"\n              class=\"{{ button.classInclude }}\"\n              (outSwitch)=\"handlerSwitch($event, button)\" />\n          }\n          @if (button.key === 'button') {\n            <libs_ui-components-buttons-button\n              [label]=\"button?.label || ''\"\n              [classLabel]=\"(button.classLabel || '') + ' libs-ui-font-h4s'\"\n              [type]=\"button.type || 'button-primary'\"\n              [classInclude]=\"button.classInclude || ''\"\n              [classIconLeft]=\"button.classIconLeft || ''\"\n              [classIconRight]=\"button.classIconRight || ''\"\n              [popover]=\"button.popover || {}\"\n              [disable]=\"button.disable || disable()\"\n              [isPending]=\"button.isPending || false\"\n              [iconOnlyType]=\"button.iconOnlyType || false\"\n              (outClick)=\"handlerClickButton(button)\" />\n          }\n          @if (button.key === 'line-space') {\n            <div\n              class=\"bg-[#666b79] w-[1px] h-[28px]\"\n              [class]=\"button.classInclude\">\n              &nbsp;\n            </div>\n          }\n        </div>\n      }\n      @if (menuDropDownConfigs(); as menuDropDownConfigs) {\n        <div class=\"ml-[12px]\">\n          <libs_ui-components-dropdown\n            [isNgContent]=\"true\"\n            [zIndex]=\"zIndex() + 1\"\n            [listConfig]=\"menuDropDownConfigs.listConfig\"\n            [listHiddenInputSearch]=\"true\"\n            [popoverCustomConfig]=\"menuDropDownConfigs.popoverCustomConfig\"\n            (outFunctionsControl)=\"handlerControlDropdownMenu($event)\"\n            (outSelectKey)=\"handlerSelectedKey($event)\">\n            <libs_ui-components-buttons-button\n              [classInclude]=\"'p-[8px]'\"\n              [type]=\"'button-third'\"\n              [iconOnlyType]=\"true\"\n              [classIconLeft]=\"'libs-ui-icon-more-vertical text-[#333333] text-[12px]'\"\n              [popover]=\"{ config: { content: 'i18n_4x_other_operations' } }\"\n              [ignoreStopPropagationEvent]=\"true\" />\n          </libs_ui-components-dropdown>\n        </div>\n      }\n      @if (templateRight(); as templateRight) {\n        <ng-container *ngTemplateOutlet=\"templateRight\" />\n      }\n    </div>\n  </div>\n\n  <!-- ===================== BODY (V2: Lazy Load hoặc ng-content) ===================== -->\n  @if (bodyConfig().getComponentOutlet; as getBodyComponentOutlet) {\n    <!-- Lazy load mode -->\n    <div [class]=\"'libs-ui-components-page_full-body ' + (bodyConfig().classInclude || '')\">\n      @let constHtmlCompBody = undefined | LibsUiPipesCallFunctionInTemplatePipe: getBodyComponentOutlet : sectionData() : null : { valueIsEmpty: null } | async;\n      @let constHtmlInputsBody = undefined | LibsUiPipesCallFunctionInTemplatePipe: bodyConfig().getDataComponentOutlet : sectionData() : null : { valueIsEmpty: null } | async;\n      @if (constHtmlCompBody) {\n        @defer {\n          <ng-container *ngComponentOutlet=\"constHtmlCompBody; inputs: constHtmlInputsBody\" />\n        } @loading {\n          <libs_ui-components-skeleton [config]=\"resolvedSkeletonBody()\" />\n        }\n      } @else {\n        <libs_ui-components-skeleton [config]=\"resolvedSkeletonBody()\" />\n      }\n    </div>\n  }\n</div>\n"]}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZnVsbC1zY3JlZW4tdjIuaW50ZXJmYWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vLi4vbGlicy11aS9jb21wb25lbnRzL3BhZ2VzLXRlbXBsYXRlL2Z1bGwtc2NyZWVuL3NyYy9mdWxsLXNjcmVlbi12Mi9pbnRlcmZhY2VzL2Z1bGwtc2NyZWVuLXYyLmludGVyZmFjZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiLyogZXNsaW50LWRpc2FibGUgQHR5cGVzY3JpcHQtZXNsaW50L25vLWV4cGxpY2l0LWFueSAqL1xuaW1wb3J0IHsgV3JpdGFibGVTaWduYWwgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IElTa2VsZXRvbkNvbmZpZyB9IGZyb20gJ0BsaWJzLXVpL2NvbXBvbmVudHMtc2tlbGV0b24nO1xuaW1wb3J0IHsgVFlQRV9GVU5DVElPTiB9IGZyb20gJ0BsaWJzLXVpL2ludGVyZmFjZXMtdHlwZXMnO1xuXG4vKipcbiAqIENvbmZpZyBkw6BuaCByacOqbmcgY2hvIHbDuW5nIGJvZHkgVjIg4oCUIGjhu5cgdHLhu6MgbGF6eSBsb2FkIGNvbXBvbmVudCDEkeG7mW5nLlxuICovXG5leHBvcnQgaW50ZXJmYWNlIElGdWxsU2NyZWVuVjJCb2R5Q29uZmlnIHtcbiAgLyoqIEjDoG0gdHLhuqMgduG7gSBPYnNlcnZhYmxlPFR5cGU8YW55Pj4gxJHhu4MgbGF6eSBsb2FkIGNvbXBvbmVudCB2w6BvIGJvZHkgKi9cbiAgZ2V0Q29tcG9uZW50T3V0bGV0PzogVFlQRV9GVU5DVElPTjxhbnk+O1xuICAvKiogSMOgbSB0cuG6oyB24buBIE9ic2VydmFibGU8UmVjb3JkPiDEkeG7gyB0cnV54buBbiBk4buvIGxp4buHdSAoaW5wdXRzKSB2w6BvIGNvbXBvbmVudCDEkcaw4bujYyBsb2FkICovXG4gIGdldERhdGFDb21wb25lbnRPdXRsZXQ/OiBUWVBFX0ZVTkNUSU9OPFJlY29yZDxzdHJpbmcsIHVua25vd24+PjtcbiAgLyoqIFNrZWxldG9uIHTDuXkgY2jhu4luaCB0cm9uZyBsw7pjIE9ic2VydmFibGUgY2jhu50gcmVzb2x2ZSDigJQgZMO5bmcgV3JpdGFibGVTaWduYWwgxJHhu4MgcmVhY3RpdmUgKi9cbiAgc2tlbGV0b25Db25maWc/OiBXcml0YWJsZVNpZ25hbDxJU2tlbGV0b25Db25maWc+O1xuICAvKiogQ2xhc3MgdGjDqm0gdsOgbyB2w7luZyBib2R5IHdyYXBwZXIgbmdvw6BpICovXG4gIGNsYXNzSW5jbHVkZT86IHN0cmluZztcbn1cblxuLyoqIEThu68gbGnhu4d1IHJlYWN0aXZlIHRydXnhu4FuIHbDoG8gQ29tcG9uZW50IE91dGxldCBib2R5ICovXG5leHBvcnQgaW50ZXJmYWNlIElGdWxsU2NyZWVuVjJTZWN0aW9uRGF0YSB7XG4gIGRpc2FibGU6IGJvb2xlYW47XG59XG4iXX0=
@@ -0,0 +1,2 @@
1
+ export * from './full-screen-v2.interface';
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi8uLi9saWJzLXVpL2NvbXBvbmVudHMvcGFnZXMtdGVtcGxhdGUvZnVsbC1zY3JlZW4vc3JjL2Z1bGwtc2NyZWVuLXYyL2ludGVyZmFjZXMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYyw0QkFBNEIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vZnVsbC1zY3JlZW4tdjIuaW50ZXJmYWNlJztcbiJdfQ==
@@ -44,6 +44,7 @@ export class LibsUiComponentsPagesTemplateFullScreenComponent {
44
44
  state: true,
45
45
  idOverlay: this.idOverlay(),
46
46
  timeLiveUpdate: getDayjs().unix(),
47
+ ignoreIntervalUpdateTimeLiveEvent: UtilsCommunicateMicroKeyGlobal.IGNORE_INTERVAL_UPDATE_TIME_LIVE_EVENT_MODAL,
47
48
  },
48
49
  };
49
50
  UtilsCommunicateMicro.PostMessageToParent(data);
@@ -98,7 +99,7 @@ export class LibsUiComponentsPagesTemplateFullScreenComponent {
98
99
  }
99
100
  }
100
101
  static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: LibsUiComponentsPagesTemplateFullScreenComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
101
- static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.14", type: LibsUiComponentsPagesTemplateFullScreenComponent, isStandalone: true, selector: "libs_ui-components-pages_template_full_screen", inputs: { classHeaderInclude: { classPropertyName: "classHeaderInclude", publicName: "classHeaderInclude", isSignal: true, isRequired: false, transformFunction: null }, labelLeft: { classPropertyName: "labelLeft", publicName: "labelLeft", isSignal: true, isRequired: false, transformFunction: null }, classBodyInclude: { classPropertyName: "classBodyInclude", publicName: "classBodyInclude", isSignal: true, isRequired: false, transformFunction: null }, title: { classPropertyName: "title", publicName: "title", isSignal: true, isRequired: false, transformFunction: null }, buttonCenter: { classPropertyName: "buttonCenter", publicName: "buttonCenter", isSignal: true, isRequired: false, transformFunction: null }, buttonRight: { classPropertyName: "buttonRight", publicName: "buttonRight", isSignal: true, isRequired: false, transformFunction: null }, hasEdit: { classPropertyName: "hasEdit", publicName: "hasEdit", isSignal: true, isRequired: false, transformFunction: null }, menuDropDownConfigs: { classPropertyName: "menuDropDownConfigs", publicName: "menuDropDownConfigs", isSignal: true, isRequired: false, transformFunction: null }, zIndex: { classPropertyName: "zIndex", publicName: "zIndex", isSignal: true, isRequired: false, transformFunction: null }, ignoreClosePageFullEvent: { classPropertyName: "ignoreClosePageFullEvent", publicName: "ignoreClosePageFullEvent", isSignal: true, isRequired: false, transformFunction: null }, ignoreBackgroundColor: { classPropertyName: "ignoreBackgroundColor", publicName: "ignoreBackgroundColor", isSignal: true, isRequired: false, transformFunction: null }, divideClassHeader: { classPropertyName: "divideClassHeader", publicName: "divideClassHeader", isSignal: true, isRequired: false, transformFunction: null }, centerTemplate: { classPropertyName: "centerTemplate", publicName: "centerTemplate", isSignal: true, isRequired: false, transformFunction: null }, templateRight: { classPropertyName: "templateRight", publicName: "templateRight", isSignal: true, isRequired: false, transformFunction: null }, leftTemplate: { classPropertyName: "leftTemplate", publicName: "leftTemplate", isSignal: true, isRequired: false, transformFunction: null }, disable: { classPropertyName: "disable", publicName: "disable", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { outClose: "outClose", outEdit: "outEdit", outSelectedMenuDropdown: "outSelectedMenuDropdown", outClickButton: "outClickButton" }, providers: [], ngImport: i0, template: "<div\n class=\"libs-ui-components-page_full overflow-hidden\"\n [style.zIndex]=\"zIndex()\"\n [style.background-color]=\"ignoreBackgroundColor() ? 'transparent' : '#f2f5f7'\">\n <div [class]=\"'libs-ui-components-page_full-header ' + classHeaderInclude()\">\n <div class=\"{{ divideClassHeader()?.classButtonCancel || 'w-[25%]' }}\">\n @if (leftTemplate(); as leftTemplate) {\n <ng-container *ngTemplateOutlet=\"leftTemplate\" />\n }\n @if (labelLeft(); as labelLeft) {\n <libs_ui-components-buttons-button\n [label]=\"labelLeft\"\n [type]=\"'button-link-primary'\"\n [classIconLeft]=\"'libs-ui-icon-chevron-right rotate-[180deg] before:text-[16px]'\"\n [classLabel]=\"'libs-ui-font-h4r'\"\n (outClick)=\"cancel()\" />\n }\n </div>\n\n @if (centerTemplate(); as centerTemplate) {\n <div class=\"{{ divideClassHeader()?.classButtonCenter || 'w-[40%]' }} flex items-center justify-center\">\n <ng-container *ngTemplateOutlet=\"centerTemplate\" />\n </div>\n } @else {\n <div class=\"{{ divideClassHeader()?.classButtonCenter || 'w-[40%]' }} flex items-center justify-center\">\n <libs_ui-components-popover\n type=\"text\"\n [config]=\"{\n maxWidth: 250,\n zIndex: zIndex() + 1,\n }\"\n [classInclude]=\"'libs-ui-font-h2s'\"\n [innerHtml]=\"title() ? (title() | LibsUiPipesEscapeHtmlPipe) : '&mdash;'\" />\n\n @if (hasEdit(); as hasEdit) {\n <libs_ui-components-buttons-button\n [type]=\"'button-link-primary'\"\n (outClick)=\"handlerEdit()\"\n [iconOnlyType]=\"true\"\n [classIconLeft]=\"'libs-ui-icon-edit-line'\"\n [classInclude]=\"'ml-[4px]'\" />\n }\n @for (button of buttonCenter(); track button.key) {\n <div class=\"ml-[12px] flex items-center\">\n @if (button.key === 'button') {\n <libs_ui-components-buttons-button\n [label]=\"button.label || ''\"\n [classLabel]=\"(button.classLabel || '') + ' libs-ui-font-head-4s'\"\n [type]=\"button.type || 'button-primary'\"\n [classInclude]=\"button.classInclude || ''\"\n [classIconLeft]=\"button.classIconLeft || ''\"\n [classIconRight]=\"button.classIconRight || ''\"\n [popover]=\"button.popover || {}\"\n [disable]=\"button.disable || disable()\"\n [isPending]=\"button.isPending || false\"\n (outClick)=\"handlerClickButton(button)\" />\n }\n @if (button.key === 'button-status' && button.configButtonStatus) {\n <libs_ui-components-buttons-status\n [class]=\"button.classInclude\"\n [config]=\"button.configButtonStatus\" />\n }\n @if (button.key === 'switch') {\n <libs_ui-components-switch\n [active]=\"button.active || false\"\n [disable]=\"button.disable || disable()\"\n class=\"{{ button.classInclude }}\"\n (outSwitch)=\"handlerSwitch($event, button)\" />\n }\n @if (button.key === 'label' && button.labelConfig) {\n <libs_ui-components-label\n [classInclude]=\"button.labelConfig.classInclude + ' pb-0 text-white'\"\n [labelLeft]=\"button.labelConfig.labelLeft\"\n [labelLeftClass]=\"button.labelConfig.labelLeftClass\"\n [required]=\"button.labelConfig.required\"\n [description]=\"button.labelConfig.description\"\n [labelRight]=\"button.labelConfig.labelRight\"\n [labelRightClass]=\"button.labelConfig.labelRightClass\"\n [onlyShowCount]=\"button.labelConfig.onlyShowCount\"\n [buttonsLeft]=\"button.labelConfig.buttonsLeft\"\n [disableButtonsLeft]=\"button.labelConfig.disableButtonsLeft\"\n [buttonsRight]=\"button.labelConfig.buttonsRight\"\n [disableButtonsRight]=\"button.labelConfig.disableButtonsRight\"\n [hasToggle]=\"button.labelConfig.hasToggle\"\n [toggleActive]=\"button.labelConfig.toggleActive\"\n [toggleDisable]=\"button.labelConfig.toggleDisable\"\n [popover]=\"button.labelConfig.popover\"\n [iconPopoverClass]=\"button.labelConfig.iconPopoverClass\"\n [onlyShowCount]=\"button.labelConfig.onlyShowCount\"\n [limitLength]=\"button.labelConfig.limitLength\"\n [buttonsDescription]=\"button.labelConfig.buttonsDescription\"\n [disableButtonsDescription]=\"button.labelConfig.disableButtonsDescription\"\n [buttonsDescriptionContainerClass]=\"button.labelConfig.buttonsDescriptionContainerClass\"\n [count]=\"button.labelConfig.count\" />\n }\n </div>\n }\n </div>\n }\n\n <div class=\"{{ divideClassHeader()?.classButtonRight || 'w-[35%]' }} flex justify-end items-center\">\n @for (button of buttonRight(); track button.key) {\n <div [class.ml-[12px]]=\"!$first\">\n @if (button.key === 'label' && button.labelConfig) {\n <libs_ui-components-label\n [classInclude]=\"button.labelConfig.classInclude + ' pb-0'\"\n [labelLeft]=\"button.labelConfig.labelLeft\"\n [labelLeftClass]=\"button.labelConfig.labelLeftClass\"\n [required]=\"button.labelConfig.required\"\n [description]=\"button.labelConfig.description\"\n [labelRight]=\"button.labelConfig.labelRight\"\n [labelRightClass]=\"button.labelConfig.labelRightClass\"\n [onlyShowCount]=\"button.labelConfig.onlyShowCount\"\n [buttonsLeft]=\"button.labelConfig.buttonsLeft\"\n [disableButtonsLeft]=\"button.labelConfig.disableButtonsLeft\"\n [buttonsRight]=\"button.labelConfig.buttonsRight\"\n [disableButtonsRight]=\"button.labelConfig.disableButtonsRight\"\n [hasToggle]=\"button.labelConfig.hasToggle\"\n [toggleActive]=\"button.labelConfig.toggleActive\"\n [toggleDisable]=\"button.labelConfig.toggleDisable\"\n [popover]=\"button.labelConfig.popover\"\n [iconPopoverClass]=\"button.labelConfig.iconPopoverClass\"\n [onlyShowCount]=\"button.labelConfig.onlyShowCount\"\n [limitLength]=\"button.labelConfig.limitLength\"\n [buttonsDescription]=\"button.labelConfig.buttonsDescription\"\n [disableButtonsDescription]=\"button.labelConfig.disableButtonsDescription\"\n [buttonsDescriptionContainerClass]=\"button.labelConfig.buttonsDescriptionContainerClass\"\n [count]=\"button.labelConfig.count\" />\n }\n @if (button.key === 'switch') {\n <libs_ui-components-switch\n [active]=\"button.active || false\"\n [disable]=\"button.disable || disable()\"\n class=\"{{ button.classInclude }}\"\n (outSwitch)=\"handlerSwitch($event, button)\" />\n }\n\n @if (button.key === 'button') {\n <libs_ui-components-buttons-button\n [label]=\"button?.label || ''\"\n [classLabel]=\"(button.classLabel || '') + ' libs-ui-font-h4s'\"\n [type]=\"button.type || 'button-primary'\"\n [classInclude]=\"button.classInclude || ''\"\n [classIconLeft]=\"button.classIconLeft || ''\"\n [classIconRight]=\"button.classIconRight || ''\"\n [popover]=\"button.popover || {}\"\n [disable]=\"button.disable || disable()\"\n [isPending]=\"button.isPending || false\"\n [iconOnlyType]=\"button.iconOnlyType || false\"\n (outClick)=\"handlerClickButton(button)\" />\n }\n <!-- th\u00EAm \u0111\u01B0\u1EDDng ph\u00E2n c\u00E1ch -->\n @if (button.key === 'line-space') {\n <div\n class=\"bg-[#666b79] w-[1px] h-[28px]\"\n [class]=\"button.classInclude\">\n &nbsp;\n </div>\n }\n </div>\n }\n @if (menuDropDownConfigs(); as menuDropDownConfigs) {\n <div class=\"ml-[12px]\">\n <libs_ui-components-dropdown\n [isNgContent]=\"true\"\n [zIndex]=\"zIndex() + 1\"\n [listConfig]=\"menuDropDownConfigs.listConfig\"\n [listHiddenInputSearch]=\"true\"\n [popoverCustomConfig]=\"menuDropDownConfigs.popoverCustomConfig\"\n (outFunctionsControl)=\"handlerControlDropdownMenu($event)\"\n (outSelectKey)=\"handlerSelectedKey($event)\">\n <libs_ui-components-buttons-button\n [classInclude]=\"'p-[8px]'\"\n [type]=\"'button-third'\"\n [iconOnlyType]=\"true\"\n [classIconLeft]=\"'libs-ui-icon-more-vertical text-[#333333] text-[12px]'\"\n [popover]=\"{\n config: {\n content: 'i18n_4x_other_operations',\n },\n }\"\n [ignoreStopPropagationEvent]=\"true\" />\n </libs_ui-components-dropdown>\n </div>\n }\n @if (templateRight(); as templateRight) {\n <ng-container *ngTemplateOutlet=\"templateRight\" />\n }\n </div>\n </div>\n <div [class]=\"'libs-ui-components-page_full-body ' + classBodyInclude()\">\n <ng-content />\n </div>\n</div>\n", styles: ["@-webkit-keyframes animation-slide-to-left{0%{right:-200px;opacity:0}to{right:12px;opacity:1}}@keyframes animation-slide-to-left{0%{right:-200px;opacity:0}to{right:0;opacity:1}}.libs-ui-components-page_full{position:absolute;width:100vw;height:100vh;left:0;top:0;display:flex;flex-direction:column;animation:animation-slide-to-left ease-out .3s}.libs-ui-components-page_full .libs-ui-components-page_full-header{height:50px;padding:14px 16px;border-bottom:solid 1px #e6e7ea;background-color:#fff;width:100%;display:flex;align-items:center}.libs-ui-components-page_full .libs-ui-components-page_full-body{height:100%}\n"], dependencies: [{ kind: "ngmodule", type: TranslateModule }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { 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", "fieldLabel", "fieldGetLabel", "labelPopoverConfig", "labelPopoverFullWidth", "hasContentUnitRight", "listSearchNoDataTemplateRef", "fieldGetImage", "imageSize", "typeShape", "fieldGetIcon", "fieldGetTextAvatar", "fieldGetColorAvatar", "classAvatarInclude", "getLastTextAfterSpace", "linkImageError", "showError", "showBorderError", "disable", "readonly", "labelConfig", "disableLabel", "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: LibsUiComponentsSwitchComponent, selector: "libs_ui-components-switch", inputs: ["size", "disable", "active"], outputs: ["activeChange", "outSwitch"] }, { 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: LibsUiComponentsButtonsStatusComponent, selector: "libs_ui-components-buttons-status", inputs: ["config"] }, { 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: "pipe", type: LibsUiPipesEscapeHtmlPipe, name: "LibsUiPipesEscapeHtmlPipe" }, { kind: "component", type: LibsUiComponentsLabelComponent, selector: "libs_ui-components-label", inputs: ["iconPopoverClass", "classInclude", "labelLeft", "labelLeftClass", "labelLeftBehindToggleButton", "popover", "required", "buttonsLeft", "disableButtonsLeft", "buttonsRight", "disableButtonsRight", "labelRight", "labelRightClass", "labelRightRequired", "hasToggle", "toggleSize", "toggleActive", "toggleDisable", "description", "descriptionClass", "buttonsDescription", "disableButtonsDescription", "buttonsDescriptionContainerClass", "onlyShowCount", "zIndexPopover", "timerDestroyPopover", "count", "limitLength"], outputs: ["outClickButton", "outSwitchEvent", "outLabelRightClick", "outLabelLeftClick"] }] });
102
+ static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.14", type: LibsUiComponentsPagesTemplateFullScreenComponent, isStandalone: true, selector: "libs_ui-components-pages_template_full_screen", inputs: { classHeaderInclude: { classPropertyName: "classHeaderInclude", publicName: "classHeaderInclude", isSignal: true, isRequired: false, transformFunction: null }, labelLeft: { classPropertyName: "labelLeft", publicName: "labelLeft", isSignal: true, isRequired: false, transformFunction: null }, classBodyInclude: { classPropertyName: "classBodyInclude", publicName: "classBodyInclude", isSignal: true, isRequired: false, transformFunction: null }, title: { classPropertyName: "title", publicName: "title", isSignal: true, isRequired: false, transformFunction: null }, buttonCenter: { classPropertyName: "buttonCenter", publicName: "buttonCenter", isSignal: true, isRequired: false, transformFunction: null }, buttonRight: { classPropertyName: "buttonRight", publicName: "buttonRight", isSignal: true, isRequired: false, transformFunction: null }, hasEdit: { classPropertyName: "hasEdit", publicName: "hasEdit", isSignal: true, isRequired: false, transformFunction: null }, menuDropDownConfigs: { classPropertyName: "menuDropDownConfigs", publicName: "menuDropDownConfigs", isSignal: true, isRequired: false, transformFunction: null }, zIndex: { classPropertyName: "zIndex", publicName: "zIndex", isSignal: true, isRequired: false, transformFunction: null }, ignoreClosePageFullEvent: { classPropertyName: "ignoreClosePageFullEvent", publicName: "ignoreClosePageFullEvent", isSignal: true, isRequired: false, transformFunction: null }, ignoreBackgroundColor: { classPropertyName: "ignoreBackgroundColor", publicName: "ignoreBackgroundColor", isSignal: true, isRequired: false, transformFunction: null }, divideClassHeader: { classPropertyName: "divideClassHeader", publicName: "divideClassHeader", isSignal: true, isRequired: false, transformFunction: null }, centerTemplate: { classPropertyName: "centerTemplate", publicName: "centerTemplate", isSignal: true, isRequired: false, transformFunction: null }, templateRight: { classPropertyName: "templateRight", publicName: "templateRight", isSignal: true, isRequired: false, transformFunction: null }, leftTemplate: { classPropertyName: "leftTemplate", publicName: "leftTemplate", isSignal: true, isRequired: false, transformFunction: null }, disable: { classPropertyName: "disable", publicName: "disable", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { outClose: "outClose", outEdit: "outEdit", outSelectedMenuDropdown: "outSelectedMenuDropdown", outClickButton: "outClickButton" }, providers: [], ngImport: i0, template: "<div\n class=\"libs-ui-components-page_full overflow-hidden\"\n [style.zIndex]=\"zIndex()\"\n [style.background-color]=\"ignoreBackgroundColor() ? 'transparent' : '#f2f5f7'\">\n <div [class]=\"'libs-ui-components-page_full-header ' + classHeaderInclude()\">\n <div class=\"{{ divideClassHeader()?.classButtonCancel || 'w-[25%]' }}\">\n @if (leftTemplate(); as leftTemplate) {\n <ng-container *ngTemplateOutlet=\"leftTemplate\" />\n }\n @if (labelLeft(); as labelLeft) {\n <libs_ui-components-buttons-button\n [label]=\"labelLeft\"\n [type]=\"'button-link-primary'\"\n [classIconLeft]=\"'libs-ui-icon-chevron-right rotate-[180deg] before:text-[16px]'\"\n [classLabel]=\"'libs-ui-font-h4r'\"\n (outClick)=\"cancel()\" />\n }\n </div>\n\n @if (centerTemplate(); as centerTemplate) {\n <div class=\"{{ divideClassHeader()?.classButtonCenter || 'w-[40%]' }} flex items-center justify-center\">\n <ng-container *ngTemplateOutlet=\"centerTemplate\" />\n </div>\n } @else {\n <div class=\"{{ divideClassHeader()?.classButtonCenter || 'w-[40%]' }} flex items-center justify-center\">\n <libs_ui-components-popover\n type=\"text\"\n [config]=\"{\n maxWidth: 250,\n zIndex: zIndex() + 1,\n }\"\n [classInclude]=\"'libs-ui-font-h2s'\"\n [innerHtml]=\"title() ? (title() | LibsUiPipesEscapeHtmlPipe) : '&mdash;'\" />\n\n @if (hasEdit(); as hasEdit) {\n <libs_ui-components-buttons-button\n [type]=\"'button-link-primary'\"\n (outClick)=\"handlerEdit()\"\n [iconOnlyType]=\"true\"\n [classIconLeft]=\"'libs-ui-icon-edit-line'\"\n [classInclude]=\"'ml-[4px]'\" />\n }\n @for (button of buttonCenter(); track button.key) {\n <div class=\"ml-[12px] flex items-center\">\n @if (button.key === 'button') {\n <libs_ui-components-buttons-button\n [label]=\"button.label || ''\"\n [classLabel]=\"(button.classLabel || '') + ' libs-ui-font-head-4s'\"\n [type]=\"button.type || 'button-primary'\"\n [classInclude]=\"button.classInclude || ''\"\n [classIconLeft]=\"button.classIconLeft || ''\"\n [classIconRight]=\"button.classIconRight || ''\"\n [popover]=\"button.popover || {}\"\n [disable]=\"button.disable || disable()\"\n [isPending]=\"button.isPending || false\"\n (outClick)=\"handlerClickButton(button)\" />\n }\n @if (button.key === 'button-status' && button.configButtonStatus) {\n <libs_ui-components-buttons-status\n [class]=\"button.classInclude\"\n [config]=\"button.configButtonStatus\" />\n }\n @if (button.key === 'switch') {\n <libs_ui-components-switch\n [active]=\"button.active || false\"\n [disable]=\"button.disable || disable()\"\n class=\"{{ button.classInclude }}\"\n (outSwitch)=\"handlerSwitch($event, button)\" />\n }\n @if (button.key === 'label' && button.labelConfig) {\n <libs_ui-components-label\n [classInclude]=\"button.labelConfig.classInclude + ' pb-0 text-white'\"\n [labelLeft]=\"button.labelConfig.labelLeft\"\n [labelLeftClass]=\"button.labelConfig.labelLeftClass\"\n [required]=\"button.labelConfig.required\"\n [description]=\"button.labelConfig.description\"\n [labelRight]=\"button.labelConfig.labelRight\"\n [labelRightClass]=\"button.labelConfig.labelRightClass\"\n [onlyShowCount]=\"button.labelConfig.onlyShowCount\"\n [buttonsLeft]=\"button.labelConfig.buttonsLeft\"\n [disableButtonsLeft]=\"button.labelConfig.disableButtonsLeft\"\n [buttonsRight]=\"button.labelConfig.buttonsRight\"\n [disableButtonsRight]=\"button.labelConfig.disableButtonsRight\"\n [hasToggle]=\"button.labelConfig.hasToggle\"\n [toggleActive]=\"button.labelConfig.toggleActive\"\n [toggleDisable]=\"button.labelConfig.toggleDisable\"\n [popover]=\"button.labelConfig.popover\"\n [iconPopoverClass]=\"button.labelConfig.iconPopoverClass\"\n [onlyShowCount]=\"button.labelConfig.onlyShowCount\"\n [limitLength]=\"button.labelConfig.limitLength\"\n [buttonsDescription]=\"button.labelConfig.buttonsDescription\"\n [disableButtonsDescription]=\"button.labelConfig.disableButtonsDescription\"\n [buttonsDescriptionContainerClass]=\"button.labelConfig.buttonsDescriptionContainerClass\"\n [count]=\"button.labelConfig.count\" />\n }\n </div>\n }\n </div>\n }\n\n <div class=\"{{ divideClassHeader()?.classButtonRight || 'w-[35%]' }} flex justify-end items-center\">\n @for (button of buttonRight(); track button.key) {\n <div [class.ml-[12px]]=\"!$first\">\n @if (button.key === 'label' && button.labelConfig) {\n <libs_ui-components-label\n [classInclude]=\"button.labelConfig.classInclude + ' pb-0'\"\n [labelLeft]=\"button.labelConfig.labelLeft\"\n [labelLeftClass]=\"button.labelConfig.labelLeftClass\"\n [required]=\"button.labelConfig.required\"\n [description]=\"button.labelConfig.description\"\n [labelRight]=\"button.labelConfig.labelRight\"\n [labelRightClass]=\"button.labelConfig.labelRightClass\"\n [onlyShowCount]=\"button.labelConfig.onlyShowCount\"\n [buttonsLeft]=\"button.labelConfig.buttonsLeft\"\n [disableButtonsLeft]=\"button.labelConfig.disableButtonsLeft\"\n [buttonsRight]=\"button.labelConfig.buttonsRight\"\n [disableButtonsRight]=\"button.labelConfig.disableButtonsRight\"\n [hasToggle]=\"button.labelConfig.hasToggle\"\n [toggleActive]=\"button.labelConfig.toggleActive\"\n [toggleDisable]=\"button.labelConfig.toggleDisable\"\n [popover]=\"button.labelConfig.popover\"\n [iconPopoverClass]=\"button.labelConfig.iconPopoverClass\"\n [onlyShowCount]=\"button.labelConfig.onlyShowCount\"\n [limitLength]=\"button.labelConfig.limitLength\"\n [buttonsDescription]=\"button.labelConfig.buttonsDescription\"\n [disableButtonsDescription]=\"button.labelConfig.disableButtonsDescription\"\n [buttonsDescriptionContainerClass]=\"button.labelConfig.buttonsDescriptionContainerClass\"\n [count]=\"button.labelConfig.count\" />\n }\n @if (button.key === 'switch') {\n <libs_ui-components-switch\n [active]=\"button.active || false\"\n [disable]=\"button.disable || disable()\"\n class=\"{{ button.classInclude }}\"\n (outSwitch)=\"handlerSwitch($event, button)\" />\n }\n\n @if (button.key === 'button') {\n <libs_ui-components-buttons-button\n [label]=\"button?.label || ''\"\n [classLabel]=\"(button.classLabel || '') + ' libs-ui-font-h4s'\"\n [type]=\"button.type || 'button-primary'\"\n [classInclude]=\"button.classInclude || ''\"\n [classIconLeft]=\"button.classIconLeft || ''\"\n [classIconRight]=\"button.classIconRight || ''\"\n [popover]=\"button.popover || {}\"\n [disable]=\"button.disable || disable()\"\n [isPending]=\"button.isPending || false\"\n [iconOnlyType]=\"button.iconOnlyType || false\"\n (outClick)=\"handlerClickButton(button)\" />\n }\n <!-- th\u00EAm \u0111\u01B0\u1EDDng ph\u00E2n c\u00E1ch -->\n @if (button.key === 'line-space') {\n <div\n class=\"bg-[#666b79] w-[1px] h-[28px]\"\n [class]=\"button.classInclude\">\n &nbsp;\n </div>\n }\n </div>\n }\n @if (menuDropDownConfigs(); as menuDropDownConfigs) {\n <div class=\"ml-[12px]\">\n <libs_ui-components-dropdown\n [isNgContent]=\"true\"\n [zIndex]=\"zIndex() + 1\"\n [listConfig]=\"menuDropDownConfigs.listConfig\"\n [listHiddenInputSearch]=\"true\"\n [popoverCustomConfig]=\"menuDropDownConfigs.popoverCustomConfig\"\n (outFunctionsControl)=\"handlerControlDropdownMenu($event)\"\n (outSelectKey)=\"handlerSelectedKey($event)\">\n <libs_ui-components-buttons-button\n [classInclude]=\"'p-[8px]'\"\n [type]=\"'button-third'\"\n [iconOnlyType]=\"true\"\n [classIconLeft]=\"'libs-ui-icon-more-vertical text-[#333333] text-[12px]'\"\n [popover]=\"{\n config: {\n content: 'i18n_4x_other_operations',\n },\n }\"\n [ignoreStopPropagationEvent]=\"true\" />\n </libs_ui-components-dropdown>\n </div>\n }\n @if (templateRight(); as templateRight) {\n <ng-container *ngTemplateOutlet=\"templateRight\" />\n }\n </div>\n </div>\n <div [class]=\"'libs-ui-components-page_full-body ' + classBodyInclude()\">\n <ng-content />\n </div>\n</div>\n", styles: ["@-webkit-keyframes animation-slide-to-left{0%{right:-200px;opacity:0}to{right:12px;opacity:1}}@keyframes animation-slide-to-left{0%{right:-200px;opacity:0}to{right:0;opacity:1}}.libs-ui-components-page_full{position:absolute;width:100vw;height:100vh;left:0;top:0;display:flex;flex-direction:column;animation:animation-slide-to-left ease-out .3s}.libs-ui-components-page_full .libs-ui-components-page_full-header{height:50px;padding:14px 16px;border-bottom:solid 1px #e6e7ea;background-color:#fff;width:100%;display:flex;align-items:center}.libs-ui-components-page_full .libs-ui-components-page_full-body{height:100%}\n"], dependencies: [{ kind: "ngmodule", type: TranslateModule }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { 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", "fieldLabel", "fieldGetLabel", "labelPopoverConfig", "labelPopoverFullWidth", "hasContentUnitRight", "listSearchNoDataTemplateRef", "dropdownTemplateRefNotSearchNoData", "fieldGetImage", "imageSize", "typeShape", "fieldGetIcon", "fieldGetTextAvatar", "fieldGetColorAvatar", "classAvatarInclude", "getLastTextAfterSpace", "linkImageError", "showError", "showBorderError", "disable", "readonly", "labelConfig", "disableLabel", "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: LibsUiComponentsSwitchComponent, selector: "libs_ui-components-switch", inputs: ["size", "disable", "active"], outputs: ["activeChange", "outSwitch"] }, { 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: LibsUiComponentsButtonsStatusComponent, selector: "libs_ui-components-buttons-status", inputs: ["config"] }, { 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: "pipe", type: LibsUiPipesEscapeHtmlPipe, name: "LibsUiPipesEscapeHtmlPipe" }, { kind: "component", type: LibsUiComponentsLabelComponent, selector: "libs_ui-components-label", inputs: ["iconPopoverClass", "classInclude", "labelLeft", "labelLeftClass", "labelLeftBehindToggleButton", "popover", "required", "buttonsLeft", "disableButtonsLeft", "buttonsRight", "disableButtonsRight", "labelRight", "labelRightClass", "labelRightRequired", "hasToggle", "toggleSize", "toggleActive", "toggleDisable", "description", "descriptionClass", "buttonsDescription", "disableButtonsDescription", "buttonsDescriptionContainerClass", "onlyShowCount", "zIndexPopover", "timerDestroyPopover", "count", "limitLength"], outputs: ["outClickButton", "outSwitchEvent", "outLabelRightClick", "outLabelLeftClick"] }] });
102
103
  }
103
104
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImport: i0, type: LibsUiComponentsPagesTemplateFullScreenComponent, decorators: [{
104
105
  type: Component,
@@ -114,4 +115,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.14", ngImpo
114
115
  LibsUiComponentsLabelComponent,
115
116
  ], providers: [], template: "<div\n class=\"libs-ui-components-page_full overflow-hidden\"\n [style.zIndex]=\"zIndex()\"\n [style.background-color]=\"ignoreBackgroundColor() ? 'transparent' : '#f2f5f7'\">\n <div [class]=\"'libs-ui-components-page_full-header ' + classHeaderInclude()\">\n <div class=\"{{ divideClassHeader()?.classButtonCancel || 'w-[25%]' }}\">\n @if (leftTemplate(); as leftTemplate) {\n <ng-container *ngTemplateOutlet=\"leftTemplate\" />\n }\n @if (labelLeft(); as labelLeft) {\n <libs_ui-components-buttons-button\n [label]=\"labelLeft\"\n [type]=\"'button-link-primary'\"\n [classIconLeft]=\"'libs-ui-icon-chevron-right rotate-[180deg] before:text-[16px]'\"\n [classLabel]=\"'libs-ui-font-h4r'\"\n (outClick)=\"cancel()\" />\n }\n </div>\n\n @if (centerTemplate(); as centerTemplate) {\n <div class=\"{{ divideClassHeader()?.classButtonCenter || 'w-[40%]' }} flex items-center justify-center\">\n <ng-container *ngTemplateOutlet=\"centerTemplate\" />\n </div>\n } @else {\n <div class=\"{{ divideClassHeader()?.classButtonCenter || 'w-[40%]' }} flex items-center justify-center\">\n <libs_ui-components-popover\n type=\"text\"\n [config]=\"{\n maxWidth: 250,\n zIndex: zIndex() + 1,\n }\"\n [classInclude]=\"'libs-ui-font-h2s'\"\n [innerHtml]=\"title() ? (title() | LibsUiPipesEscapeHtmlPipe) : '&mdash;'\" />\n\n @if (hasEdit(); as hasEdit) {\n <libs_ui-components-buttons-button\n [type]=\"'button-link-primary'\"\n (outClick)=\"handlerEdit()\"\n [iconOnlyType]=\"true\"\n [classIconLeft]=\"'libs-ui-icon-edit-line'\"\n [classInclude]=\"'ml-[4px]'\" />\n }\n @for (button of buttonCenter(); track button.key) {\n <div class=\"ml-[12px] flex items-center\">\n @if (button.key === 'button') {\n <libs_ui-components-buttons-button\n [label]=\"button.label || ''\"\n [classLabel]=\"(button.classLabel || '') + ' libs-ui-font-head-4s'\"\n [type]=\"button.type || 'button-primary'\"\n [classInclude]=\"button.classInclude || ''\"\n [classIconLeft]=\"button.classIconLeft || ''\"\n [classIconRight]=\"button.classIconRight || ''\"\n [popover]=\"button.popover || {}\"\n [disable]=\"button.disable || disable()\"\n [isPending]=\"button.isPending || false\"\n (outClick)=\"handlerClickButton(button)\" />\n }\n @if (button.key === 'button-status' && button.configButtonStatus) {\n <libs_ui-components-buttons-status\n [class]=\"button.classInclude\"\n [config]=\"button.configButtonStatus\" />\n }\n @if (button.key === 'switch') {\n <libs_ui-components-switch\n [active]=\"button.active || false\"\n [disable]=\"button.disable || disable()\"\n class=\"{{ button.classInclude }}\"\n (outSwitch)=\"handlerSwitch($event, button)\" />\n }\n @if (button.key === 'label' && button.labelConfig) {\n <libs_ui-components-label\n [classInclude]=\"button.labelConfig.classInclude + ' pb-0 text-white'\"\n [labelLeft]=\"button.labelConfig.labelLeft\"\n [labelLeftClass]=\"button.labelConfig.labelLeftClass\"\n [required]=\"button.labelConfig.required\"\n [description]=\"button.labelConfig.description\"\n [labelRight]=\"button.labelConfig.labelRight\"\n [labelRightClass]=\"button.labelConfig.labelRightClass\"\n [onlyShowCount]=\"button.labelConfig.onlyShowCount\"\n [buttonsLeft]=\"button.labelConfig.buttonsLeft\"\n [disableButtonsLeft]=\"button.labelConfig.disableButtonsLeft\"\n [buttonsRight]=\"button.labelConfig.buttonsRight\"\n [disableButtonsRight]=\"button.labelConfig.disableButtonsRight\"\n [hasToggle]=\"button.labelConfig.hasToggle\"\n [toggleActive]=\"button.labelConfig.toggleActive\"\n [toggleDisable]=\"button.labelConfig.toggleDisable\"\n [popover]=\"button.labelConfig.popover\"\n [iconPopoverClass]=\"button.labelConfig.iconPopoverClass\"\n [onlyShowCount]=\"button.labelConfig.onlyShowCount\"\n [limitLength]=\"button.labelConfig.limitLength\"\n [buttonsDescription]=\"button.labelConfig.buttonsDescription\"\n [disableButtonsDescription]=\"button.labelConfig.disableButtonsDescription\"\n [buttonsDescriptionContainerClass]=\"button.labelConfig.buttonsDescriptionContainerClass\"\n [count]=\"button.labelConfig.count\" />\n }\n </div>\n }\n </div>\n }\n\n <div class=\"{{ divideClassHeader()?.classButtonRight || 'w-[35%]' }} flex justify-end items-center\">\n @for (button of buttonRight(); track button.key) {\n <div [class.ml-[12px]]=\"!$first\">\n @if (button.key === 'label' && button.labelConfig) {\n <libs_ui-components-label\n [classInclude]=\"button.labelConfig.classInclude + ' pb-0'\"\n [labelLeft]=\"button.labelConfig.labelLeft\"\n [labelLeftClass]=\"button.labelConfig.labelLeftClass\"\n [required]=\"button.labelConfig.required\"\n [description]=\"button.labelConfig.description\"\n [labelRight]=\"button.labelConfig.labelRight\"\n [labelRightClass]=\"button.labelConfig.labelRightClass\"\n [onlyShowCount]=\"button.labelConfig.onlyShowCount\"\n [buttonsLeft]=\"button.labelConfig.buttonsLeft\"\n [disableButtonsLeft]=\"button.labelConfig.disableButtonsLeft\"\n [buttonsRight]=\"button.labelConfig.buttonsRight\"\n [disableButtonsRight]=\"button.labelConfig.disableButtonsRight\"\n [hasToggle]=\"button.labelConfig.hasToggle\"\n [toggleActive]=\"button.labelConfig.toggleActive\"\n [toggleDisable]=\"button.labelConfig.toggleDisable\"\n [popover]=\"button.labelConfig.popover\"\n [iconPopoverClass]=\"button.labelConfig.iconPopoverClass\"\n [onlyShowCount]=\"button.labelConfig.onlyShowCount\"\n [limitLength]=\"button.labelConfig.limitLength\"\n [buttonsDescription]=\"button.labelConfig.buttonsDescription\"\n [disableButtonsDescription]=\"button.labelConfig.disableButtonsDescription\"\n [buttonsDescriptionContainerClass]=\"button.labelConfig.buttonsDescriptionContainerClass\"\n [count]=\"button.labelConfig.count\" />\n }\n @if (button.key === 'switch') {\n <libs_ui-components-switch\n [active]=\"button.active || false\"\n [disable]=\"button.disable || disable()\"\n class=\"{{ button.classInclude }}\"\n (outSwitch)=\"handlerSwitch($event, button)\" />\n }\n\n @if (button.key === 'button') {\n <libs_ui-components-buttons-button\n [label]=\"button?.label || ''\"\n [classLabel]=\"(button.classLabel || '') + ' libs-ui-font-h4s'\"\n [type]=\"button.type || 'button-primary'\"\n [classInclude]=\"button.classInclude || ''\"\n [classIconLeft]=\"button.classIconLeft || ''\"\n [classIconRight]=\"button.classIconRight || ''\"\n [popover]=\"button.popover || {}\"\n [disable]=\"button.disable || disable()\"\n [isPending]=\"button.isPending || false\"\n [iconOnlyType]=\"button.iconOnlyType || false\"\n (outClick)=\"handlerClickButton(button)\" />\n }\n <!-- th\u00EAm \u0111\u01B0\u1EDDng ph\u00E2n c\u00E1ch -->\n @if (button.key === 'line-space') {\n <div\n class=\"bg-[#666b79] w-[1px] h-[28px]\"\n [class]=\"button.classInclude\">\n &nbsp;\n </div>\n }\n </div>\n }\n @if (menuDropDownConfigs(); as menuDropDownConfigs) {\n <div class=\"ml-[12px]\">\n <libs_ui-components-dropdown\n [isNgContent]=\"true\"\n [zIndex]=\"zIndex() + 1\"\n [listConfig]=\"menuDropDownConfigs.listConfig\"\n [listHiddenInputSearch]=\"true\"\n [popoverCustomConfig]=\"menuDropDownConfigs.popoverCustomConfig\"\n (outFunctionsControl)=\"handlerControlDropdownMenu($event)\"\n (outSelectKey)=\"handlerSelectedKey($event)\">\n <libs_ui-components-buttons-button\n [classInclude]=\"'p-[8px]'\"\n [type]=\"'button-third'\"\n [iconOnlyType]=\"true\"\n [classIconLeft]=\"'libs-ui-icon-more-vertical text-[#333333] text-[12px]'\"\n [popover]=\"{\n config: {\n content: 'i18n_4x_other_operations',\n },\n }\"\n [ignoreStopPropagationEvent]=\"true\" />\n </libs_ui-components-dropdown>\n </div>\n }\n @if (templateRight(); as templateRight) {\n <ng-container *ngTemplateOutlet=\"templateRight\" />\n }\n </div>\n </div>\n <div [class]=\"'libs-ui-components-page_full-body ' + classBodyInclude()\">\n <ng-content />\n </div>\n</div>\n", styles: ["@-webkit-keyframes animation-slide-to-left{0%{right:-200px;opacity:0}to{right:12px;opacity:1}}@keyframes animation-slide-to-left{0%{right:-200px;opacity:0}to{right:0;opacity:1}}.libs-ui-components-page_full{position:absolute;width:100vw;height:100vh;left:0;top:0;display:flex;flex-direction:column;animation:animation-slide-to-left ease-out .3s}.libs-ui-components-page_full .libs-ui-components-page_full-header{height:50px;padding:14px 16px;border-bottom:solid 1px #e6e7ea;background-color:#fff;width:100%;display:flex;align-items:center}.libs-ui-components-page_full .libs-ui-components-page_full-body{height:100%}\n"] }]
116
117
  }] });
117
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"full-screen.component.js","sourceRoot":"","sources":["../../../../../../libs-ui/components/pages-template/full-screen/src/full-screen.component.ts","../../../../../../libs-ui/components/pages-template/full-screen/src/full-screen.component.html"],"names":[],"mappings":"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","sourcesContent":["import { NgTemplateOutlet } from '@angular/common';\nimport { Component, input, OnDestroy, OnInit, output, signal, TemplateRef } from '@angular/core';\nimport { LibsUiComponentsButtonsButtonComponent } from '@libs-ui/components-buttons-button';\nimport { LibsUiComponentsButtonsStatusComponent } from '@libs-ui/components-buttons-status';\nimport { IDropdown, IDropdownFunctionControlEvent, IEmitSelectKey, LibsUiComponentsDropdownComponent } from '@libs-ui/components-dropdown';\nimport { LibsUiComponentsLabelComponent } from '@libs-ui/components-label';\nimport { LibsUiComponentsPopoverComponent } from '@libs-ui/components-popover';\nimport { ISwitchEvent, LibsUiComponentsSwitchComponent } from '@libs-ui/components-switch';\nimport { TYPE_TEMPLATE_REF } from '@libs-ui/interfaces-types';\nimport { LibsUiPipesEscapeHtmlPipe } from '@libs-ui/pipes-escape-html';\nimport { getDayjs, UtilsCommunicateMicro, UtilsCommunicateMicroKeyGlobal, uuid } from '@libs-ui/utils';\nimport { TranslateModule } from '@ngx-translate/core';\nimport { interval, Subject, takeUntil } from 'rxjs';\nimport { IPagesTemplateFullScreenButton } from './interfaces/config.interface';\n\n@Component({\n  // eslint-disable-next-line @angular-eslint/component-selector\n  selector: 'libs_ui-components-pages_template_full_screen',\n  templateUrl: './full-screen.component.html',\n  styleUrls: ['./full-screen.component.scss'],\n  standalone: true,\n  imports: [\n    TranslateModule,\n    NgTemplateOutlet,\n    LibsUiComponentsDropdownComponent,\n    LibsUiComponentsSwitchComponent,\n    LibsUiComponentsButtonsButtonComponent,\n    LibsUiComponentsButtonsStatusComponent,\n    LibsUiComponentsPopoverComponent,\n    LibsUiPipesEscapeHtmlPipe,\n    LibsUiComponentsLabelComponent,\n  ],\n  providers: [],\n})\nexport class LibsUiComponentsPagesTemplateFullScreenComponent implements OnInit, OnDestroy {\n  private idOverlay = signal<string>(uuid());\n  private functionControlMenu: IDropdownFunctionControlEvent | undefined;\n  private onDestroy = new Subject<void>();\n\n  readonly classHeaderInclude = input<string>();\n  readonly labelLeft = input<string, string | undefined>('i18n_back_to_list', { transform: (val) => val ?? 'i18n_back_to_list' });\n  readonly classBodyInclude = input<string>();\n  readonly title = input<string>();\n  readonly buttonCenter = input<Array<IPagesTemplateFullScreenButton> | undefined>();\n  readonly buttonRight = input<Array<IPagesTemplateFullScreenButton>>();\n  readonly hasEdit = input<boolean>(false);\n  readonly menuDropDownConfigs = input<IDropdown>();\n  readonly zIndex = input<number, number | undefined>(1000, { transform: (val) => val ?? 1000 });\n  readonly ignoreClosePageFullEvent = input<boolean, boolean | undefined>(false, { transform: (val) => val ?? false });\n  readonly ignoreBackgroundColor = input<boolean>();\n  readonly divideClassHeader = input<{ classButtonCancel: string; classButtonCenter: string; classButtonRight: string } | undefined>();\n  readonly centerTemplate = input<TemplateRef<TYPE_TEMPLATE_REF> | undefined>();\n  readonly templateRight = input<TemplateRef<TYPE_TEMPLATE_REF> | undefined>();\n  readonly leftTemplate = input<TemplateRef<TYPE_TEMPLATE_REF> | undefined>();\n  readonly disable = input<boolean, boolean | undefined>(false, { transform: (val) => val ?? false });\n\n  readonly outClose = output<void>();\n  readonly outEdit = output<void>();\n  readonly outSelectedMenuDropdown = output<IEmitSelectKey | undefined>();\n  readonly outClickButton = output<IPagesTemplateFullScreenButton>();\n\n  ngOnInit(): void {\n    if (!this.ignoreClosePageFullEvent()) {\n      const data = {\n        type: UtilsCommunicateMicroKeyGlobal.KEY_MESSAGE_MODAL,\n        response: {\n          message: 'open',\n          state: true,\n          idOverlay: this.idOverlay(),\n          timeLiveUpdate: getDayjs().unix(),\n        },\n      };\n\n      UtilsCommunicateMicro.PostMessageToParent(data);\n\n      if (UtilsCommunicateMicroKeyGlobal.IGNORE_INTERVAL_UPDATE_TIME_LIVE_EVENT_MODAL) {\n        return;\n      }\n\n      interval(2000)\n        .pipe(takeUntil(this.onDestroy))\n        .subscribe(() => {\n          data.response.timeLiveUpdate = getDayjs().unix();\n\n          UtilsCommunicateMicro.PostMessageToParent(data);\n        });\n    }\n  }\n\n  protected handlerEdit() {\n    this.outEdit.emit();\n  }\n\n  protected cancel() {\n    this.outClose.emit();\n  }\n\n  protected async handlerClickButton(button: IPagesTemplateFullScreenButton) {\n    if (button && button.action) {\n      await button.action();\n    }\n    this.outClickButton.emit(button);\n  }\n\n  protected async handlerSwitch(event: ISwitchEvent, button: IPagesTemplateFullScreenButton) {\n    if (button && button.action) {\n      await button.action(event);\n    }\n  }\n\n  protected handlerSelectedKey(event: IEmitSelectKey | undefined) {\n    this.outSelectedMenuDropdown.emit(event);\n    this.functionControlMenu?.reset();\n  }\n\n  protected handlerControlDropdownMenu(event: IDropdownFunctionControlEvent) {\n    this.functionControlMenu = event;\n  }\n\n  ngOnDestroy(): void {\n    this.onDestroy.next();\n    this.onDestroy.complete();\n    if (!this.ignoreClosePageFullEvent()) {\n      const data = {\n        type: UtilsCommunicateMicroKeyGlobal.KEY_MESSAGE_MODAL,\n        response: {\n          message: 'close',\n          state: false,\n          idOverlay: this.idOverlay(),\n        },\n      };\n\n      UtilsCommunicateMicro.PostMessageToParent(data);\n    }\n  }\n}\n","<div\n  class=\"libs-ui-components-page_full overflow-hidden\"\n  [style.zIndex]=\"zIndex()\"\n  [style.background-color]=\"ignoreBackgroundColor() ? 'transparent' : '#f2f5f7'\">\n  <div [class]=\"'libs-ui-components-page_full-header ' + classHeaderInclude()\">\n    <div class=\"{{ divideClassHeader()?.classButtonCancel || 'w-[25%]' }}\">\n      @if (leftTemplate(); as leftTemplate) {\n        <ng-container *ngTemplateOutlet=\"leftTemplate\" />\n      }\n      @if (labelLeft(); as labelLeft) {\n        <libs_ui-components-buttons-button\n          [label]=\"labelLeft\"\n          [type]=\"'button-link-primary'\"\n          [classIconLeft]=\"'libs-ui-icon-chevron-right rotate-[180deg] before:text-[16px]'\"\n          [classLabel]=\"'libs-ui-font-h4r'\"\n          (outClick)=\"cancel()\" />\n      }\n    </div>\n\n    @if (centerTemplate(); as centerTemplate) {\n      <div class=\"{{ divideClassHeader()?.classButtonCenter || 'w-[40%]' }} flex items-center justify-center\">\n        <ng-container *ngTemplateOutlet=\"centerTemplate\" />\n      </div>\n    } @else {\n      <div class=\"{{ divideClassHeader()?.classButtonCenter || 'w-[40%]' }} flex items-center justify-center\">\n        <libs_ui-components-popover\n          type=\"text\"\n          [config]=\"{\n            maxWidth: 250,\n            zIndex: zIndex() + 1,\n          }\"\n          [classInclude]=\"'libs-ui-font-h2s'\"\n          [innerHtml]=\"title() ? (title() | LibsUiPipesEscapeHtmlPipe) : '&mdash;'\" />\n\n        @if (hasEdit(); as hasEdit) {\n          <libs_ui-components-buttons-button\n            [type]=\"'button-link-primary'\"\n            (outClick)=\"handlerEdit()\"\n            [iconOnlyType]=\"true\"\n            [classIconLeft]=\"'libs-ui-icon-edit-line'\"\n            [classInclude]=\"'ml-[4px]'\" />\n        }\n        @for (button of buttonCenter(); track button.key) {\n          <div class=\"ml-[12px] flex items-center\">\n            @if (button.key === 'button') {\n              <libs_ui-components-buttons-button\n                [label]=\"button.label || ''\"\n                [classLabel]=\"(button.classLabel || '') + ' libs-ui-font-head-4s'\"\n                [type]=\"button.type || 'button-primary'\"\n                [classInclude]=\"button.classInclude || ''\"\n                [classIconLeft]=\"button.classIconLeft || ''\"\n                [classIconRight]=\"button.classIconRight || ''\"\n                [popover]=\"button.popover || {}\"\n                [disable]=\"button.disable || disable()\"\n                [isPending]=\"button.isPending || false\"\n                (outClick)=\"handlerClickButton(button)\" />\n            }\n            @if (button.key === 'button-status' && button.configButtonStatus) {\n              <libs_ui-components-buttons-status\n                [class]=\"button.classInclude\"\n                [config]=\"button.configButtonStatus\" />\n            }\n            @if (button.key === 'switch') {\n              <libs_ui-components-switch\n                [active]=\"button.active || false\"\n                [disable]=\"button.disable || disable()\"\n                class=\"{{ button.classInclude }}\"\n                (outSwitch)=\"handlerSwitch($event, button)\" />\n            }\n            @if (button.key === 'label' && button.labelConfig) {\n              <libs_ui-components-label\n                [classInclude]=\"button.labelConfig.classInclude + ' pb-0 text-white'\"\n                [labelLeft]=\"button.labelConfig.labelLeft\"\n                [labelLeftClass]=\"button.labelConfig.labelLeftClass\"\n                [required]=\"button.labelConfig.required\"\n                [description]=\"button.labelConfig.description\"\n                [labelRight]=\"button.labelConfig.labelRight\"\n                [labelRightClass]=\"button.labelConfig.labelRightClass\"\n                [onlyShowCount]=\"button.labelConfig.onlyShowCount\"\n                [buttonsLeft]=\"button.labelConfig.buttonsLeft\"\n                [disableButtonsLeft]=\"button.labelConfig.disableButtonsLeft\"\n                [buttonsRight]=\"button.labelConfig.buttonsRight\"\n                [disableButtonsRight]=\"button.labelConfig.disableButtonsRight\"\n                [hasToggle]=\"button.labelConfig.hasToggle\"\n                [toggleActive]=\"button.labelConfig.toggleActive\"\n                [toggleDisable]=\"button.labelConfig.toggleDisable\"\n                [popover]=\"button.labelConfig.popover\"\n                [iconPopoverClass]=\"button.labelConfig.iconPopoverClass\"\n                [onlyShowCount]=\"button.labelConfig.onlyShowCount\"\n                [limitLength]=\"button.labelConfig.limitLength\"\n                [buttonsDescription]=\"button.labelConfig.buttonsDescription\"\n                [disableButtonsDescription]=\"button.labelConfig.disableButtonsDescription\"\n                [buttonsDescriptionContainerClass]=\"button.labelConfig.buttonsDescriptionContainerClass\"\n                [count]=\"button.labelConfig.count\" />\n            }\n          </div>\n        }\n      </div>\n    }\n\n    <div class=\"{{ divideClassHeader()?.classButtonRight || 'w-[35%]' }} flex justify-end items-center\">\n      @for (button of buttonRight(); track button.key) {\n        <div [class.ml-[12px]]=\"!$first\">\n          @if (button.key === 'label' && button.labelConfig) {\n            <libs_ui-components-label\n              [classInclude]=\"button.labelConfig.classInclude + ' pb-0'\"\n              [labelLeft]=\"button.labelConfig.labelLeft\"\n              [labelLeftClass]=\"button.labelConfig.labelLeftClass\"\n              [required]=\"button.labelConfig.required\"\n              [description]=\"button.labelConfig.description\"\n              [labelRight]=\"button.labelConfig.labelRight\"\n              [labelRightClass]=\"button.labelConfig.labelRightClass\"\n              [onlyShowCount]=\"button.labelConfig.onlyShowCount\"\n              [buttonsLeft]=\"button.labelConfig.buttonsLeft\"\n              [disableButtonsLeft]=\"button.labelConfig.disableButtonsLeft\"\n              [buttonsRight]=\"button.labelConfig.buttonsRight\"\n              [disableButtonsRight]=\"button.labelConfig.disableButtonsRight\"\n              [hasToggle]=\"button.labelConfig.hasToggle\"\n              [toggleActive]=\"button.labelConfig.toggleActive\"\n              [toggleDisable]=\"button.labelConfig.toggleDisable\"\n              [popover]=\"button.labelConfig.popover\"\n              [iconPopoverClass]=\"button.labelConfig.iconPopoverClass\"\n              [onlyShowCount]=\"button.labelConfig.onlyShowCount\"\n              [limitLength]=\"button.labelConfig.limitLength\"\n              [buttonsDescription]=\"button.labelConfig.buttonsDescription\"\n              [disableButtonsDescription]=\"button.labelConfig.disableButtonsDescription\"\n              [buttonsDescriptionContainerClass]=\"button.labelConfig.buttonsDescriptionContainerClass\"\n              [count]=\"button.labelConfig.count\" />\n          }\n          @if (button.key === 'switch') {\n            <libs_ui-components-switch\n              [active]=\"button.active || false\"\n              [disable]=\"button.disable || disable()\"\n              class=\"{{ button.classInclude }}\"\n              (outSwitch)=\"handlerSwitch($event, button)\" />\n          }\n\n          @if (button.key === 'button') {\n            <libs_ui-components-buttons-button\n              [label]=\"button?.label || ''\"\n              [classLabel]=\"(button.classLabel || '') + ' libs-ui-font-h4s'\"\n              [type]=\"button.type || 'button-primary'\"\n              [classInclude]=\"button.classInclude || ''\"\n              [classIconLeft]=\"button.classIconLeft || ''\"\n              [classIconRight]=\"button.classIconRight || ''\"\n              [popover]=\"button.popover || {}\"\n              [disable]=\"button.disable || disable()\"\n              [isPending]=\"button.isPending || false\"\n              [iconOnlyType]=\"button.iconOnlyType || false\"\n              (outClick)=\"handlerClickButton(button)\" />\n          }\n          <!--  thêm đường phân cách -->\n          @if (button.key === 'line-space') {\n            <div\n              class=\"bg-[#666b79] w-[1px] h-[28px]\"\n              [class]=\"button.classInclude\">\n              &nbsp;\n            </div>\n          }\n        </div>\n      }\n      @if (menuDropDownConfigs(); as menuDropDownConfigs) {\n        <div class=\"ml-[12px]\">\n          <libs_ui-components-dropdown\n            [isNgContent]=\"true\"\n            [zIndex]=\"zIndex() + 1\"\n            [listConfig]=\"menuDropDownConfigs.listConfig\"\n            [listHiddenInputSearch]=\"true\"\n            [popoverCustomConfig]=\"menuDropDownConfigs.popoverCustomConfig\"\n            (outFunctionsControl)=\"handlerControlDropdownMenu($event)\"\n            (outSelectKey)=\"handlerSelectedKey($event)\">\n            <libs_ui-components-buttons-button\n              [classInclude]=\"'p-[8px]'\"\n              [type]=\"'button-third'\"\n              [iconOnlyType]=\"true\"\n              [classIconLeft]=\"'libs-ui-icon-more-vertical text-[#333333] text-[12px]'\"\n              [popover]=\"{\n                config: {\n                  content: 'i18n_4x_other_operations',\n                },\n              }\"\n              [ignoreStopPropagationEvent]=\"true\" />\n          </libs_ui-components-dropdown>\n        </div>\n      }\n      @if (templateRight(); as templateRight) {\n        <ng-container *ngTemplateOutlet=\"templateRight\" />\n      }\n    </div>\n  </div>\n  <div [class]=\"'libs-ui-components-page_full-body ' + classBodyInclude()\">\n    <ng-content />\n  </div>\n</div>\n"]}
118
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"full-screen.component.js","sourceRoot":"","sources":["../../../../../../libs-ui/components/pages-template/full-screen/src/full-screen.component.ts","../../../../../../libs-ui/components/pages-template/full-screen/src/full-screen.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,gBAAgB,EAAE,MAAM,iBAAiB,CAAC;AACnD,OAAO,EAAE,SAAS,EAAE,KAAK,EAAqB,MAAM,EAAE,MAAM,EAAe,MAAM,eAAe,CAAC;AACjG,OAAO,EAAE,sCAAsC,EAAE,MAAM,oCAAoC,CAAC;AAC5F,OAAO,EAAE,sCAAsC,EAAE,MAAM,oCAAoC,CAAC;AAC5F,OAAO,EAA4D,iCAAiC,EAAE,MAAM,8BAA8B,CAAC;AAC3I,OAAO,EAAE,8BAA8B,EAAE,MAAM,2BAA2B,CAAC;AAC3E,OAAO,EAAE,gCAAgC,EAAE,MAAM,6BAA6B,CAAC;AAC/E,OAAO,EAAgB,+BAA+B,EAAE,MAAM,4BAA4B,CAAC;AAE3F,OAAO,EAAE,yBAAyB,EAAE,MAAM,4BAA4B,CAAC;AACvE,OAAO,EAAE,QAAQ,EAAE,qBAAqB,EAAE,8BAA8B,EAAE,IAAI,EAAE,MAAM,gBAAgB,CAAC;AACvG,OAAO,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAC;AACtD,OAAO,EAAE,QAAQ,EAAE,OAAO,EAAE,SAAS,EAAE,MAAM,MAAM,CAAC;;AAsBpD,MAAM,OAAO,gDAAgD;IACnD,SAAS,GAAG,MAAM,CAAS,IAAI,EAAE,CAAC,CAAC;IACnC,mBAAmB,CAA4C;IAC/D,SAAS,GAAG,IAAI,OAAO,EAAQ,CAAC;IAE/B,kBAAkB,GAAG,KAAK,EAAU,CAAC;IACrC,SAAS,GAAG,KAAK,CAA6B,mBAAmB,EAAE,EAAE,SAAS,EAAE,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,IAAI,mBAAmB,EAAE,CAAC,CAAC;IACvH,gBAAgB,GAAG,KAAK,EAAU,CAAC;IACnC,KAAK,GAAG,KAAK,EAAU,CAAC;IACxB,YAAY,GAAG,KAAK,EAAqD,CAAC;IAC1E,WAAW,GAAG,KAAK,EAAyC,CAAC;IAC7D,OAAO,GAAG,KAAK,CAAU,KAAK,CAAC,CAAC;IAChC,mBAAmB,GAAG,KAAK,EAAa,CAAC;IACzC,MAAM,GAAG,KAAK,CAA6B,IAAI,EAAE,EAAE,SAAS,EAAE,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,IAAI,IAAI,EAAE,CAAC,CAAC;IACtF,wBAAwB,GAAG,KAAK,CAA+B,KAAK,EAAE,EAAE,SAAS,EAAE,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,IAAI,KAAK,EAAE,CAAC,CAAC;IAC5G,qBAAqB,GAAG,KAAK,EAAW,CAAC;IACzC,iBAAiB,GAAG,KAAK,EAAkG,CAAC;IAC5H,cAAc,GAAG,KAAK,EAA8C,CAAC;IACrE,aAAa,GAAG,KAAK,EAA8C,CAAC;IACpE,YAAY,GAAG,KAAK,EAA8C,CAAC;IACnE,OAAO,GAAG,KAAK,CAA+B,KAAK,EAAE,EAAE,SAAS,EAAE,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,IAAI,KAAK,EAAE,CAAC,CAAC;IAE3F,QAAQ,GAAG,MAAM,EAAQ,CAAC;IAC1B,OAAO,GAAG,MAAM,EAAQ,CAAC;IACzB,uBAAuB,GAAG,MAAM,EAA8B,CAAC;IAC/D,cAAc,GAAG,MAAM,EAAkC,CAAC;IAEnE,QAAQ;QACN,IAAI,CAAC,IAAI,CAAC,wBAAwB,EAAE,EAAE,CAAC;YACrC,MAAM,IAAI,GAAG;gBACX,IAAI,EAAE,8BAA8B,CAAC,iBAAiB;gBACtD,QAAQ,EAAE;oBACR,OAAO,EAAE,MAAM;oBACf,KAAK,EAAE,IAAI;oBACX,SAAS,EAAE,IAAI,CAAC,SAAS,EAAE;oBAC3B,cAAc,EAAE,QAAQ,EAAE,CAAC,IAAI,EAAE;oBACjC,iCAAiC,EAAE,8BAA8B,CAAC,4CAA4C;iBAC/G;aACF,CAAC;YAEF,qBAAqB,CAAC,mBAAmB,CAAC,IAAI,CAAC,CAAC;YAEhD,IAAI,8BAA8B,CAAC,4CAA4C,EAAE,CAAC;gBAChF,OAAO;YACT,CAAC;YAED,QAAQ,CAAC,IAAI,CAAC;iBACX,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;iBAC/B,SAAS,CAAC,GAAG,EAAE;gBACd,IAAI,CAAC,QAAQ,CAAC,cAAc,GAAG,QAAQ,EAAE,CAAC,IAAI,EAAE,CAAC;gBAEjD,qBAAqB,CAAC,mBAAmB,CAAC,IAAI,CAAC,CAAC;YAClD,CAAC,CAAC,CAAC;QACP,CAAC;IACH,CAAC;IAES,WAAW;QACnB,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE,CAAC;IACtB,CAAC;IAES,MAAM;QACd,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;IACvB,CAAC;IAES,KAAK,CAAC,kBAAkB,CAAC,MAAsC;QACvE,IAAI,MAAM,IAAI,MAAM,CAAC,MAAM,EAAE,CAAC;YAC5B,MAAM,MAAM,CAAC,MAAM,EAAE,CAAC;QACxB,CAAC;QACD,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;IACnC,CAAC;IAES,KAAK,CAAC,aAAa,CAAC,KAAmB,EAAE,MAAsC;QACvF,IAAI,MAAM,IAAI,MAAM,CAAC,MAAM,EAAE,CAAC;YAC5B,MAAM,MAAM,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;QAC7B,CAAC;IACH,CAAC;IAES,kBAAkB,CAAC,KAAiC;QAC5D,IAAI,CAAC,uBAAuB,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACzC,IAAI,CAAC,mBAAmB,EAAE,KAAK,EAAE,CAAC;IACpC,CAAC;IAES,0BAA0B,CAAC,KAAoC;QACvE,IAAI,CAAC,mBAAmB,GAAG,KAAK,CAAC;IACnC,CAAC;IAED,WAAW;QACT,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,CAAC;QACtB,IAAI,CAAC,SAAS,CAAC,QAAQ,EAAE,CAAC;QAC1B,IAAI,CAAC,IAAI,CAAC,wBAAwB,EAAE,EAAE,CAAC;YACrC,MAAM,IAAI,GAAG;gBACX,IAAI,EAAE,8BAA8B,CAAC,iBAAiB;gBACtD,QAAQ,EAAE;oBACR,OAAO,EAAE,OAAO;oBAChB,KAAK,EAAE,KAAK;oBACZ,SAAS,EAAE,IAAI,CAAC,SAAS,EAAE;iBAC5B;aACF,CAAC;YAEF,qBAAqB,CAAC,mBAAmB,CAAC,IAAI,CAAC,CAAC;QAClD,CAAC;IACH,CAAC;wGArGU,gDAAgD;4FAAhD,gDAAgD,8/EAFhD,EAAE,0BChCf,0hTAkMA,mqBD5KI,eAAe,+BACf,gBAAgB,oJAChB,iCAAiC,u3DACjC,+BAA+B,qJAC/B,sCAAsC,sjBACtC,sCAAsC,kGACtC,gCAAgC,+fAChC,yBAAyB,kEACzB,8BAA8B;;4FAIrB,gDAAgD;kBAnB5D,SAAS;+BAEE,+CAA+C,cAG7C,IAAI,WACP;wBACP,eAAe;wBACf,gBAAgB;wBAChB,iCAAiC;wBACjC,+BAA+B;wBAC/B,sCAAsC;wBACtC,sCAAsC;wBACtC,gCAAgC;wBAChC,yBAAyB;wBACzB,8BAA8B;qBAC/B,aACU,EAAE","sourcesContent":["import { NgTemplateOutlet } from '@angular/common';\nimport { Component, input, OnDestroy, OnInit, output, signal, TemplateRef } from '@angular/core';\nimport { LibsUiComponentsButtonsButtonComponent } from '@libs-ui/components-buttons-button';\nimport { LibsUiComponentsButtonsStatusComponent } from '@libs-ui/components-buttons-status';\nimport { IDropdown, IDropdownFunctionControlEvent, IEmitSelectKey, LibsUiComponentsDropdownComponent } from '@libs-ui/components-dropdown';\nimport { LibsUiComponentsLabelComponent } from '@libs-ui/components-label';\nimport { LibsUiComponentsPopoverComponent } from '@libs-ui/components-popover';\nimport { ISwitchEvent, LibsUiComponentsSwitchComponent } from '@libs-ui/components-switch';\nimport { TYPE_TEMPLATE_REF } from '@libs-ui/interfaces-types';\nimport { LibsUiPipesEscapeHtmlPipe } from '@libs-ui/pipes-escape-html';\nimport { getDayjs, UtilsCommunicateMicro, UtilsCommunicateMicroKeyGlobal, uuid } from '@libs-ui/utils';\nimport { TranslateModule } from '@ngx-translate/core';\nimport { interval, Subject, takeUntil } from 'rxjs';\nimport { IPagesTemplateFullScreenButton } from './interfaces/config.interface';\n\n@Component({\n  // eslint-disable-next-line @angular-eslint/component-selector\n  selector: 'libs_ui-components-pages_template_full_screen',\n  templateUrl: './full-screen.component.html',\n  styleUrls: ['./full-screen.component.scss'],\n  standalone: true,\n  imports: [\n    TranslateModule,\n    NgTemplateOutlet,\n    LibsUiComponentsDropdownComponent,\n    LibsUiComponentsSwitchComponent,\n    LibsUiComponentsButtonsButtonComponent,\n    LibsUiComponentsButtonsStatusComponent,\n    LibsUiComponentsPopoverComponent,\n    LibsUiPipesEscapeHtmlPipe,\n    LibsUiComponentsLabelComponent,\n  ],\n  providers: [],\n})\nexport class LibsUiComponentsPagesTemplateFullScreenComponent implements OnInit, OnDestroy {\n  private idOverlay = signal<string>(uuid());\n  private functionControlMenu: IDropdownFunctionControlEvent | undefined;\n  private onDestroy = new Subject<void>();\n\n  readonly classHeaderInclude = input<string>();\n  readonly labelLeft = input<string, string | undefined>('i18n_back_to_list', { transform: (val) => val ?? 'i18n_back_to_list' });\n  readonly classBodyInclude = input<string>();\n  readonly title = input<string>();\n  readonly buttonCenter = input<Array<IPagesTemplateFullScreenButton> | undefined>();\n  readonly buttonRight = input<Array<IPagesTemplateFullScreenButton>>();\n  readonly hasEdit = input<boolean>(false);\n  readonly menuDropDownConfigs = input<IDropdown>();\n  readonly zIndex = input<number, number | undefined>(1000, { transform: (val) => val ?? 1000 });\n  readonly ignoreClosePageFullEvent = input<boolean, boolean | undefined>(false, { transform: (val) => val ?? false });\n  readonly ignoreBackgroundColor = input<boolean>();\n  readonly divideClassHeader = input<{ classButtonCancel: string; classButtonCenter: string; classButtonRight: string } | undefined>();\n  readonly centerTemplate = input<TemplateRef<TYPE_TEMPLATE_REF> | undefined>();\n  readonly templateRight = input<TemplateRef<TYPE_TEMPLATE_REF> | undefined>();\n  readonly leftTemplate = input<TemplateRef<TYPE_TEMPLATE_REF> | undefined>();\n  readonly disable = input<boolean, boolean | undefined>(false, { transform: (val) => val ?? false });\n\n  readonly outClose = output<void>();\n  readonly outEdit = output<void>();\n  readonly outSelectedMenuDropdown = output<IEmitSelectKey | undefined>();\n  readonly outClickButton = output<IPagesTemplateFullScreenButton>();\n\n  ngOnInit(): void {\n    if (!this.ignoreClosePageFullEvent()) {\n      const data = {\n        type: UtilsCommunicateMicroKeyGlobal.KEY_MESSAGE_MODAL,\n        response: {\n          message: 'open',\n          state: true,\n          idOverlay: this.idOverlay(),\n          timeLiveUpdate: getDayjs().unix(),\n          ignoreIntervalUpdateTimeLiveEvent: UtilsCommunicateMicroKeyGlobal.IGNORE_INTERVAL_UPDATE_TIME_LIVE_EVENT_MODAL,\n        },\n      };\n\n      UtilsCommunicateMicro.PostMessageToParent(data);\n\n      if (UtilsCommunicateMicroKeyGlobal.IGNORE_INTERVAL_UPDATE_TIME_LIVE_EVENT_MODAL) {\n        return;\n      }\n\n      interval(2000)\n        .pipe(takeUntil(this.onDestroy))\n        .subscribe(() => {\n          data.response.timeLiveUpdate = getDayjs().unix();\n\n          UtilsCommunicateMicro.PostMessageToParent(data);\n        });\n    }\n  }\n\n  protected handlerEdit() {\n    this.outEdit.emit();\n  }\n\n  protected cancel() {\n    this.outClose.emit();\n  }\n\n  protected async handlerClickButton(button: IPagesTemplateFullScreenButton) {\n    if (button && button.action) {\n      await button.action();\n    }\n    this.outClickButton.emit(button);\n  }\n\n  protected async handlerSwitch(event: ISwitchEvent, button: IPagesTemplateFullScreenButton) {\n    if (button && button.action) {\n      await button.action(event);\n    }\n  }\n\n  protected handlerSelectedKey(event: IEmitSelectKey | undefined) {\n    this.outSelectedMenuDropdown.emit(event);\n    this.functionControlMenu?.reset();\n  }\n\n  protected handlerControlDropdownMenu(event: IDropdownFunctionControlEvent) {\n    this.functionControlMenu = event;\n  }\n\n  ngOnDestroy(): void {\n    this.onDestroy.next();\n    this.onDestroy.complete();\n    if (!this.ignoreClosePageFullEvent()) {\n      const data = {\n        type: UtilsCommunicateMicroKeyGlobal.KEY_MESSAGE_MODAL,\n        response: {\n          message: 'close',\n          state: false,\n          idOverlay: this.idOverlay(),\n        },\n      };\n\n      UtilsCommunicateMicro.PostMessageToParent(data);\n    }\n  }\n}\n","<div\n  class=\"libs-ui-components-page_full overflow-hidden\"\n  [style.zIndex]=\"zIndex()\"\n  [style.background-color]=\"ignoreBackgroundColor() ? 'transparent' : '#f2f5f7'\">\n  <div [class]=\"'libs-ui-components-page_full-header ' + classHeaderInclude()\">\n    <div class=\"{{ divideClassHeader()?.classButtonCancel || 'w-[25%]' }}\">\n      @if (leftTemplate(); as leftTemplate) {\n        <ng-container *ngTemplateOutlet=\"leftTemplate\" />\n      }\n      @if (labelLeft(); as labelLeft) {\n        <libs_ui-components-buttons-button\n          [label]=\"labelLeft\"\n          [type]=\"'button-link-primary'\"\n          [classIconLeft]=\"'libs-ui-icon-chevron-right rotate-[180deg] before:text-[16px]'\"\n          [classLabel]=\"'libs-ui-font-h4r'\"\n          (outClick)=\"cancel()\" />\n      }\n    </div>\n\n    @if (centerTemplate(); as centerTemplate) {\n      <div class=\"{{ divideClassHeader()?.classButtonCenter || 'w-[40%]' }} flex items-center justify-center\">\n        <ng-container *ngTemplateOutlet=\"centerTemplate\" />\n      </div>\n    } @else {\n      <div class=\"{{ divideClassHeader()?.classButtonCenter || 'w-[40%]' }} flex items-center justify-center\">\n        <libs_ui-components-popover\n          type=\"text\"\n          [config]=\"{\n            maxWidth: 250,\n            zIndex: zIndex() + 1,\n          }\"\n          [classInclude]=\"'libs-ui-font-h2s'\"\n          [innerHtml]=\"title() ? (title() | LibsUiPipesEscapeHtmlPipe) : '&mdash;'\" />\n\n        @if (hasEdit(); as hasEdit) {\n          <libs_ui-components-buttons-button\n            [type]=\"'button-link-primary'\"\n            (outClick)=\"handlerEdit()\"\n            [iconOnlyType]=\"true\"\n            [classIconLeft]=\"'libs-ui-icon-edit-line'\"\n            [classInclude]=\"'ml-[4px]'\" />\n        }\n        @for (button of buttonCenter(); track button.key) {\n          <div class=\"ml-[12px] flex items-center\">\n            @if (button.key === 'button') {\n              <libs_ui-components-buttons-button\n                [label]=\"button.label || ''\"\n                [classLabel]=\"(button.classLabel || '') + ' libs-ui-font-head-4s'\"\n                [type]=\"button.type || 'button-primary'\"\n                [classInclude]=\"button.classInclude || ''\"\n                [classIconLeft]=\"button.classIconLeft || ''\"\n                [classIconRight]=\"button.classIconRight || ''\"\n                [popover]=\"button.popover || {}\"\n                [disable]=\"button.disable || disable()\"\n                [isPending]=\"button.isPending || false\"\n                (outClick)=\"handlerClickButton(button)\" />\n            }\n            @if (button.key === 'button-status' && button.configButtonStatus) {\n              <libs_ui-components-buttons-status\n                [class]=\"button.classInclude\"\n                [config]=\"button.configButtonStatus\" />\n            }\n            @if (button.key === 'switch') {\n              <libs_ui-components-switch\n                [active]=\"button.active || false\"\n                [disable]=\"button.disable || disable()\"\n                class=\"{{ button.classInclude }}\"\n                (outSwitch)=\"handlerSwitch($event, button)\" />\n            }\n            @if (button.key === 'label' && button.labelConfig) {\n              <libs_ui-components-label\n                [classInclude]=\"button.labelConfig.classInclude + ' pb-0 text-white'\"\n                [labelLeft]=\"button.labelConfig.labelLeft\"\n                [labelLeftClass]=\"button.labelConfig.labelLeftClass\"\n                [required]=\"button.labelConfig.required\"\n                [description]=\"button.labelConfig.description\"\n                [labelRight]=\"button.labelConfig.labelRight\"\n                [labelRightClass]=\"button.labelConfig.labelRightClass\"\n                [onlyShowCount]=\"button.labelConfig.onlyShowCount\"\n                [buttonsLeft]=\"button.labelConfig.buttonsLeft\"\n                [disableButtonsLeft]=\"button.labelConfig.disableButtonsLeft\"\n                [buttonsRight]=\"button.labelConfig.buttonsRight\"\n                [disableButtonsRight]=\"button.labelConfig.disableButtonsRight\"\n                [hasToggle]=\"button.labelConfig.hasToggle\"\n                [toggleActive]=\"button.labelConfig.toggleActive\"\n                [toggleDisable]=\"button.labelConfig.toggleDisable\"\n                [popover]=\"button.labelConfig.popover\"\n                [iconPopoverClass]=\"button.labelConfig.iconPopoverClass\"\n                [onlyShowCount]=\"button.labelConfig.onlyShowCount\"\n                [limitLength]=\"button.labelConfig.limitLength\"\n                [buttonsDescription]=\"button.labelConfig.buttonsDescription\"\n                [disableButtonsDescription]=\"button.labelConfig.disableButtonsDescription\"\n                [buttonsDescriptionContainerClass]=\"button.labelConfig.buttonsDescriptionContainerClass\"\n                [count]=\"button.labelConfig.count\" />\n            }\n          </div>\n        }\n      </div>\n    }\n\n    <div class=\"{{ divideClassHeader()?.classButtonRight || 'w-[35%]' }} flex justify-end items-center\">\n      @for (button of buttonRight(); track button.key) {\n        <div [class.ml-[12px]]=\"!$first\">\n          @if (button.key === 'label' && button.labelConfig) {\n            <libs_ui-components-label\n              [classInclude]=\"button.labelConfig.classInclude + ' pb-0'\"\n              [labelLeft]=\"button.labelConfig.labelLeft\"\n              [labelLeftClass]=\"button.labelConfig.labelLeftClass\"\n              [required]=\"button.labelConfig.required\"\n              [description]=\"button.labelConfig.description\"\n              [labelRight]=\"button.labelConfig.labelRight\"\n              [labelRightClass]=\"button.labelConfig.labelRightClass\"\n              [onlyShowCount]=\"button.labelConfig.onlyShowCount\"\n              [buttonsLeft]=\"button.labelConfig.buttonsLeft\"\n              [disableButtonsLeft]=\"button.labelConfig.disableButtonsLeft\"\n              [buttonsRight]=\"button.labelConfig.buttonsRight\"\n              [disableButtonsRight]=\"button.labelConfig.disableButtonsRight\"\n              [hasToggle]=\"button.labelConfig.hasToggle\"\n              [toggleActive]=\"button.labelConfig.toggleActive\"\n              [toggleDisable]=\"button.labelConfig.toggleDisable\"\n              [popover]=\"button.labelConfig.popover\"\n              [iconPopoverClass]=\"button.labelConfig.iconPopoverClass\"\n              [onlyShowCount]=\"button.labelConfig.onlyShowCount\"\n              [limitLength]=\"button.labelConfig.limitLength\"\n              [buttonsDescription]=\"button.labelConfig.buttonsDescription\"\n              [disableButtonsDescription]=\"button.labelConfig.disableButtonsDescription\"\n              [buttonsDescriptionContainerClass]=\"button.labelConfig.buttonsDescriptionContainerClass\"\n              [count]=\"button.labelConfig.count\" />\n          }\n          @if (button.key === 'switch') {\n            <libs_ui-components-switch\n              [active]=\"button.active || false\"\n              [disable]=\"button.disable || disable()\"\n              class=\"{{ button.classInclude }}\"\n              (outSwitch)=\"handlerSwitch($event, button)\" />\n          }\n\n          @if (button.key === 'button') {\n            <libs_ui-components-buttons-button\n              [label]=\"button?.label || ''\"\n              [classLabel]=\"(button.classLabel || '') + ' libs-ui-font-h4s'\"\n              [type]=\"button.type || 'button-primary'\"\n              [classInclude]=\"button.classInclude || ''\"\n              [classIconLeft]=\"button.classIconLeft || ''\"\n              [classIconRight]=\"button.classIconRight || ''\"\n              [popover]=\"button.popover || {}\"\n              [disable]=\"button.disable || disable()\"\n              [isPending]=\"button.isPending || false\"\n              [iconOnlyType]=\"button.iconOnlyType || false\"\n              (outClick)=\"handlerClickButton(button)\" />\n          }\n          <!--  thêm đường phân cách -->\n          @if (button.key === 'line-space') {\n            <div\n              class=\"bg-[#666b79] w-[1px] h-[28px]\"\n              [class]=\"button.classInclude\">\n              &nbsp;\n            </div>\n          }\n        </div>\n      }\n      @if (menuDropDownConfigs(); as menuDropDownConfigs) {\n        <div class=\"ml-[12px]\">\n          <libs_ui-components-dropdown\n            [isNgContent]=\"true\"\n            [zIndex]=\"zIndex() + 1\"\n            [listConfig]=\"menuDropDownConfigs.listConfig\"\n            [listHiddenInputSearch]=\"true\"\n            [popoverCustomConfig]=\"menuDropDownConfigs.popoverCustomConfig\"\n            (outFunctionsControl)=\"handlerControlDropdownMenu($event)\"\n            (outSelectKey)=\"handlerSelectedKey($event)\">\n            <libs_ui-components-buttons-button\n              [classInclude]=\"'p-[8px]'\"\n              [type]=\"'button-third'\"\n              [iconOnlyType]=\"true\"\n              [classIconLeft]=\"'libs-ui-icon-more-vertical text-[#333333] text-[12px]'\"\n              [popover]=\"{\n                config: {\n                  content: 'i18n_4x_other_operations',\n                },\n              }\"\n              [ignoreStopPropagationEvent]=\"true\" />\n          </libs_ui-components-dropdown>\n        </div>\n      }\n      @if (templateRight(); as templateRight) {\n        <ng-container *ngTemplateOutlet=\"templateRight\" />\n      }\n    </div>\n  </div>\n  <div [class]=\"'libs-ui-components-page_full-body ' + classBodyInclude()\">\n    <ng-content />\n  </div>\n</div>\n"]}
package/esm2022/index.mjs CHANGED
@@ -1,3 +1,5 @@
1
+ export * from './full-screen-v2/full-screen-v2.component';
2
+ export * from './full-screen-v2/interfaces';
1
3
  export * from './full-screen.component';
2
4
  export * from './interfaces/config.interface';
3
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzLXVpL2NvbXBvbmVudHMvcGFnZXMtdGVtcGxhdGUvZnVsbC1zY3JlZW4vc3JjL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMseUJBQXlCLENBQUM7QUFDeEMsY0FBYywrQkFBK0IsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gJy4vZnVsbC1zY3JlZW4uY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vaW50ZXJmYWNlcy9jb25maWcuaW50ZXJmYWNlJztcbiJdfQ==
5
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9saWJzLXVpL2NvbXBvbmVudHMvcGFnZXMtdGVtcGxhdGUvZnVsbC1zY3JlZW4vc3JjL2luZGV4LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsMkNBQTJDLENBQUM7QUFDMUQsY0FBYyw2QkFBNkIsQ0FBQztBQUM1QyxjQUFjLHlCQUF5QixDQUFDO0FBQ3hDLGNBQWMsK0JBQStCLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyJleHBvcnQgKiBmcm9tICcuL2Z1bGwtc2NyZWVuLXYyL2Z1bGwtc2NyZWVuLXYyLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2Z1bGwtc2NyZWVuLXYyL2ludGVyZmFjZXMnO1xuZXhwb3J0ICogZnJvbSAnLi9mdWxsLXNjcmVlbi5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9pbnRlcmZhY2VzL2NvbmZpZy5pbnRlcmZhY2UnO1xuIl19