@pepperi-addons/ngx-composite-lib 0.4.2-beta.62 → 0.4.2-beta.63

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (52) hide show
  1. package/esm2020/group-buttons-settings/group-buttons-settings.component.mjs +3 -3
  2. package/esm2020/layout-builder/hide-in/hide-in.component.mjs +54 -0
  3. package/esm2020/layout-builder/hide-in/hide-in.module.mjs +81 -0
  4. package/esm2020/layout-builder/layout/layout.component.mjs +190 -0
  5. package/esm2020/layout-builder/layout/layout.module.mjs +58 -0
  6. package/esm2020/layout-builder/layout-builder.component.mjs +188 -0
  7. package/esm2020/layout-builder/layout-builder.model.mjs +6 -0
  8. package/esm2020/layout-builder/layout-builder.module.mjs +129 -0
  9. package/esm2020/layout-builder/layout-builder.service.mjs +605 -0
  10. package/esm2020/layout-builder/layout-editor/layout-editor.component.mjs +156 -0
  11. package/esm2020/layout-builder/layout-editor/layout-editor.module.mjs +109 -0
  12. package/esm2020/layout-builder/pepperi-addons-ngx-composite-lib-layout-builder.mjs +5 -0
  13. package/esm2020/layout-builder/public-api.mjs +10 -0
  14. package/esm2020/layout-builder/section/section.component.mjs +313 -0
  15. package/esm2020/layout-builder/section/section.module.mjs +45 -0
  16. package/esm2020/layout-builder/section-block/section-block.component.mjs +109 -0
  17. package/esm2020/layout-builder/section-block/section-block.module.mjs +48 -0
  18. package/esm2020/layout-builder/section-editor/section-editor.component.mjs +191 -0
  19. package/esm2020/layout-builder/section-editor/section-editor.module.mjs +40 -0
  20. package/fesm2015/pepperi-addons-ngx-composite-lib-group-buttons-settings.mjs +2 -2
  21. package/fesm2015/pepperi-addons-ngx-composite-lib-group-buttons-settings.mjs.map +1 -1
  22. package/fesm2015/pepperi-addons-ngx-composite-lib-layout-builder.mjs +2206 -0
  23. package/fesm2015/pepperi-addons-ngx-composite-lib-layout-builder.mjs.map +1 -0
  24. package/fesm2020/pepperi-addons-ngx-composite-lib-group-buttons-settings.mjs +2 -2
  25. package/fesm2020/pepperi-addons-ngx-composite-lib-group-buttons-settings.mjs.map +1 -1
  26. package/fesm2020/pepperi-addons-ngx-composite-lib-layout-builder.mjs +2186 -0
  27. package/fesm2020/pepperi-addons-ngx-composite-lib-layout-builder.mjs.map +1 -0
  28. package/group-buttons-settings/group-buttons-settings.component.d.ts +1 -1
  29. package/layout-builder/hide-in/hide-in.component.d.ts +25 -0
  30. package/layout-builder/hide-in/hide-in.component.theme.scss +9 -0
  31. package/layout-builder/hide-in/hide-in.module.d.ts +20 -0
  32. package/layout-builder/index.d.ts +5 -0
  33. package/layout-builder/layout/layout.component.d.ts +49 -0
  34. package/layout-builder/layout/layout.module.d.ts +17 -0
  35. package/layout-builder/layout-builder.component.d.ts +45 -0
  36. package/layout-builder/layout-builder.component.theme.scss +56 -0
  37. package/layout-builder/layout-builder.model.d.ts +51 -0
  38. package/layout-builder/layout-builder.module.d.ts +32 -0
  39. package/layout-builder/layout-builder.service.d.ts +96 -0
  40. package/layout-builder/layout-editor/layout-editor.component.d.ts +49 -0
  41. package/layout-builder/layout-editor/layout-editor.module.d.ts +28 -0
  42. package/layout-builder/public-api.d.ts +6 -0
  43. package/layout-builder/section/section.component.d.ts +78 -0
  44. package/layout-builder/section/section.component.theme.scss +115 -0
  45. package/layout-builder/section/section.module.d.ts +14 -0
  46. package/layout-builder/section-block/section-block.component.d.ts +39 -0
  47. package/layout-builder/section-block/section-block.component.theme.scss +13 -0
  48. package/layout-builder/section-block/section-block.module.d.ts +13 -0
  49. package/layout-builder/section-editor/section-editor.component.d.ts +53 -0
  50. package/layout-builder/section-editor/section-editor.module.d.ts +13 -0
  51. package/package.json +9 -1
  52. package/src/assets/i18n/en.ngx-composite-lib.json +40 -2
@@ -0,0 +1,188 @@
1
+ import { ElementRef, ViewChild, Component, EventEmitter, Input, Output, HostListener } from '@angular/core';
2
+ import { BaseDestroyerDirective } from '@pepperi-addons/ngx-lib';
3
+ import { pepIconDeviceDesktop, pepIconDeviceMobile, pepIconDeviceTablet } from '@pepperi-addons/ngx-lib/icon';
4
+ import { PepSideBarComponent } from '@pepperi-addons/ngx-lib/side-bar';
5
+ import { coerceNumberProperty } from '@angular/cdk/coercion';
6
+ import * as i0 from "@angular/core";
7
+ import * as i1 from "@ngx-translate/core";
8
+ import * as i2 from "./layout-builder.service";
9
+ import * as i3 from "@pepperi-addons/ngx-lib";
10
+ import * as i4 from "@angular/common";
11
+ import * as i5 from "@pepperi-addons/ngx-lib/page-layout";
12
+ import * as i6 from "@pepperi-addons/ngx-lib/side-bar";
13
+ import * as i7 from "@pepperi-addons/ngx-lib/button";
14
+ import * as i8 from "@pepperi-addons/ngx-lib/group-buttons";
15
+ import * as i9 from "./layout-editor/layout-editor.component";
16
+ import * as i10 from "./section-editor/section-editor.component";
17
+ export class PepLayoutBuilderComponent extends BaseDestroyerDirective {
18
+ constructor(renderer, hostElement, translate, layoutBuilderService, pepAddonService) {
19
+ super();
20
+ this.renderer = renderer;
21
+ this.hostElement = hostElement;
22
+ this.translate = translate;
23
+ this.layoutBuilderService = layoutBuilderService;
24
+ this.pepAddonService = pepAddonService;
25
+ this._availableBlocksForDrag = [];
26
+ this.backClick = new EventEmitter();
27
+ this.blockEditorChange = new EventEmitter(); // blockKey
28
+ this.blockAdded = new EventEmitter();
29
+ this.blocksRemoved = new EventEmitter();
30
+ // screenSize: PepScreenSizeType;
31
+ this.lockScreen = false;
32
+ this.previewMode = false;
33
+ this.currentEditor = null;
34
+ this.viewportWidth = 0;
35
+ this.renderer.addClass(this.hostElement.nativeElement, 'pep-layout-builder');
36
+ this.layoutBuilderService.isEditMode = true;
37
+ this.pepAddonService.setShellRouterData({ showSidebar: false, addPadding: false });
38
+ }
39
+ set availableBlocksForDrag(value) {
40
+ this._availableBlocksForDrag = value;
41
+ this.layoutBuilderService.setAvailableBlocksToDrag(value);
42
+ }
43
+ get availableBlocksForDrag() {
44
+ return this._availableBlocksForDrag;
45
+ }
46
+ setScreenWidth(screenType) {
47
+ this.layoutBuilderService.setScreenWidth(screenType);
48
+ }
49
+ updateViewportWidth() {
50
+ if (this.layoutBuilderWrapper?.nativeElement) {
51
+ setTimeout(() => {
52
+ this.viewportWidth = this.layoutBuilderWrapper.nativeElement.clientWidth;
53
+ });
54
+ }
55
+ }
56
+ subscribeEvents() {
57
+ /***********************************************************************************************/
58
+ /* Internal Events - for code usage
59
+ /***********************************************************************************************/
60
+ this.layoutBuilderService.previewModeChange$.pipe(this.getDestroyer()).subscribe((previewMode) => {
61
+ this.previewMode = previewMode;
62
+ });
63
+ this.layoutBuilderService.lockScreenChange$.pipe(this.getDestroyer()).subscribe((lockScreen) => {
64
+ this.lockScreen = lockScreen;
65
+ });
66
+ this.layoutBuilderService.screenSizeChange$.pipe(this.getDestroyer()).subscribe((size) => {
67
+ // this.screenSize = size;
68
+ const screenType = this.layoutBuilderService.getScreenType(size);
69
+ this.selectedScreenType = screenType;
70
+ // TODO: Raise event to update the screen size maybe there is data in editor that need to update??
71
+ });
72
+ // For update the layout data
73
+ this.layoutBuilderService.layoutViewChange$.pipe(this.getDestroyer()).subscribe((layoutView) => {
74
+ if (layoutView) {
75
+ if (this.layoutBuilderWrapper?.nativeElement) {
76
+ let maxWidth = coerceNumberProperty(layoutView.Layout.MaxWidth, 0);
77
+ const maxWidthToSet = maxWidth === 0 ? '100%' : `${maxWidth}px`;
78
+ this.renderer.setStyle(this.layoutBuilderWrapper.nativeElement, 'max-width', maxWidthToSet);
79
+ this.updateViewportWidth();
80
+ }
81
+ }
82
+ });
83
+ this.layoutBuilderService.screenWidthChange$.pipe(this.getDestroyer()).subscribe((width) => {
84
+ if (this.layoutBuilderWrapper?.nativeElement) {
85
+ this.renderer.setStyle(this.layoutBuilderWrapper.nativeElement, 'width', width);
86
+ this.updateViewportWidth();
87
+ }
88
+ });
89
+ // Get the sections id's into sectionsColumnsDropList for the drag & drop.
90
+ this.layoutBuilderService.sectionsChange$.pipe(this.getDestroyer()).subscribe((sections) => {
91
+ // Concat all results into one array.
92
+ const sectionsColumnsDropList = [].concat(...sections.map((section) => {
93
+ return section.Columns.map((column, index) => this.layoutBuilderService.getSectionColumnKey(section.Key, index.toString()));
94
+ }));
95
+ this.layoutBuilderService.notifySectionsColumnsDropListChange(sectionsColumnsDropList);
96
+ });
97
+ /***********************************************************************************************/
98
+ /* External Events - for raise to the client
99
+ /***********************************************************************************************/
100
+ // For update editor.
101
+ this.layoutBuilderService.editorChange$.pipe(this.getDestroyer()).subscribe((editor) => {
102
+ if (editor) {
103
+ // Init the side bar scroll top to 0.
104
+ if (this.sideBarComponent) {
105
+ const sideLayout = this.sideBarComponent.nativeElement.querySelector('.side-layout');
106
+ sideLayout?.scrollTo(0, 0);
107
+ }
108
+ this.currentEditor = editor;
109
+ // Raise event to let the user set the block editor in the UI.
110
+ if (editor.type === 'block') {
111
+ this.blockEditorChange.emit(editor.id);
112
+ }
113
+ }
114
+ });
115
+ this.layoutBuilderService.blockAddedEventSubject$.pipe(this.getDestroyer()).subscribe((event) => {
116
+ if (event) {
117
+ this.blockAdded.emit(event);
118
+ }
119
+ });
120
+ this.layoutBuilderService.blocksRemovedEventSubject$.pipe(this.getDestroyer()).subscribe((event) => {
121
+ if (event?.length > 0) {
122
+ this.blocksRemoved.emit(event);
123
+ }
124
+ });
125
+ }
126
+ ngOnInit() {
127
+ // Get the first translation for load all translations.
128
+ this.translate.get('LAYOUT_BUILDER.DESKTOP').subscribe((res) => {
129
+ this.layoutBuilderService.defaultSectionTitle = this.translate.instant('LAYOUT_BUILDER.SECTION');
130
+ this.screenTypes = [
131
+ { key: 'Landscape', value: this.translate.instant('LAYOUT_BUILDER.DESKTOP'), callback: () => this.setScreenWidth('Landscape'), iconName: pepIconDeviceDesktop.name, iconPosition: 'end' },
132
+ { key: 'Tablet', value: this.translate.instant('LAYOUT_BUILDER.TABLET'), callback: () => this.setScreenWidth('Tablet'), iconName: pepIconDeviceTablet.name, iconPosition: 'end' },
133
+ { key: 'Phablet', value: this.translate.instant('LAYOUT_BUILDER.MOBILE'), callback: () => this.setScreenWidth('Phablet'), iconName: pepIconDeviceMobile.name, iconPosition: 'end' }
134
+ ];
135
+ });
136
+ this.subscribeEvents();
137
+ }
138
+ onResize(event) {
139
+ this.updateViewportWidth();
140
+ }
141
+ togglePreviewMode() {
142
+ this.layoutBuilderService.notifyPreviewModeChange(!this.previewMode);
143
+ this.updateViewportWidth();
144
+ }
145
+ onSidebarStateChange(event) {
146
+ this.updateViewportWidth();
147
+ }
148
+ onLayoutEditorObjectChange(pageEditor) {
149
+ this.layoutBuilderService.updateLayoutFromEditor(pageEditor);
150
+ }
151
+ onSectionEditorObjectChange(sectionEditor) {
152
+ this.layoutBuilderService.updateSectionFromEditor(sectionEditor);
153
+ }
154
+ onNavigateBackFromEditor() {
155
+ if (!this.currentEditor || this.currentEditor?.type === 'layout-builder') {
156
+ this.backClick.emit();
157
+ }
158
+ else {
159
+ this.layoutBuilderService.navigateBackFromEditor();
160
+ }
161
+ }
162
+ }
163
+ PepLayoutBuilderComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: PepLayoutBuilderComponent, deps: [{ token: i0.Renderer2 }, { token: i0.ElementRef }, { token: i1.TranslateService }, { token: i2.PepLayoutBuilderService }, { token: i3.PepAddonService }], target: i0.ɵɵFactoryTarget.Component });
164
+ PepLayoutBuilderComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.0.2", type: PepLayoutBuilderComponent, selector: "pep-layout-builder", inputs: { availableBlocksForDrag: "availableBlocksForDrag" }, outputs: { backClick: "backClick", blockEditorChange: "blockEditorChange", blockAdded: "blockAdded", blocksRemoved: "blocksRemoved" }, host: { listeners: { "window:resize": "onResize($event)" } }, viewQueries: [{ propertyName: "layoutBuilderWrapper", first: true, predicate: ["layoutBuilderWrapper"], descendants: true, static: true }, { propertyName: "sideBarComponent", first: true, predicate: PepSideBarComponent, descendants: true, read: ElementRef }], usesInheritance: true, ngImport: i0, template: "<div *ngIf=\"lockScreen\" class=\"cdk-overlay-backdrop cdk-overlay-dark-backdrop cdk-overlay-backdrop-showing\"></div>\n\n<pep-page-layout [showShadow]=\"!previewMode && currentEditor !== null\" >\n <div pep-side-area *ngIf=\"!previewMode && currentEditor\" style=\"height: inherit;\">\n <pep-side-bar #sideBar [ignoreResize]=\"true\" (stateChange)=\"onSidebarStateChange($event)\">\n <div header-content class=\"side-bar-title\">\n <pep-button class=\"back-button\" sizeType=\"sm\" iconName=\"arrow_left_alt\" (buttonClick)=\"onNavigateBackFromEditor();\"></pep-button>\n <div class=\"title title-lg ellipsis\" [title]=\"currentEditor?.title\">\n <span>{{ currentEditor?.title }}</span>\n </div>\n </div>\n <div class=\"layout-builder-editor-wrapper\">\n <pep-layout-editor *ngIf=\"currentEditor?.type === 'layout-builder'\" [availableBlocksForDrag]=\"availableBlocksForDrag\"\n [hostObject]=\"currentEditor?.hostObject\" (hostObjectChange)=\"onLayoutEditorObjectChange($event)\"\n >\n <ng-container layout-editor-top-content>\n <ng-content select=\"[layout-editor-top-content]\"></ng-content>\n </ng-container>\n <ng-container layout-editor-bottom-content>\n <ng-content select=\"[layout-editor-bottom-content]\"></ng-content>\n </ng-container>\n </pep-layout-editor>\n \n <section-editor *ngIf=\"currentEditor?.type === 'section'\" \n [hostObject]=\"currentEditor?.hostObject\" (hostObjectChange)=\"onSectionEditorObjectChange($event)\"></section-editor>\n \n <div *ngIf=\"currentEditor?.type === 'block'\" class=\"layout-builder-editor-container\">\n <ng-content select=\"[block-editor-content]\"></ng-content>\n </div>\n </div>\n </pep-side-bar>\n </div>\n <ng-container pep-main-area>\n <div class=\"main-area-container\" [ngClass]=\"{'preview-mode': previewMode }\">\n <div class=\"header-container\" >\n <ng-container *ngIf=\"!previewMode; then editorTitleTemplate; else previewTitleTemplate\"></ng-container>\n <ng-template #editorTitleTemplate>\n <div>\n <span class=\"header-title body-xs\">{{('LAYOUT_BUILDER.VIEWPORT_WIDTH' | translate)}}:&nbsp;</span>\n <span class=\"body-xs\"><b>{{viewportWidth}}</b></span>\n </div>\n </ng-template>\n <ng-template #previewTitleTemplate>\n <div class=\"preview-title body-sm\">\n <span>{{('LAYOUT_BUILDER.PREVIEW_TITLE' | translate)}}</span>\n </div>\n </ng-template>\n\n <div class=\"header-group-btn\">\n <pep-group-buttons [buttons]=\"screenTypes\" [selectedButtonKey]=\"selectedScreenType\" sizeType=\"sm\" viewType=\"toggle\" >\n </pep-group-buttons>\n </div>\n\n <ng-container *ngIf=\"!previewMode; then editorButtonsTemplate; else previewButtonsTemplate\"></ng-container>\n <ng-template #editorButtonsTemplate>\n <div class=\"header-end\">\n <pep-button key='Preview' [value]=\"'ACTIONS.PREVIEW' | translate\" sizeType=\"sm\" classNames=\"pep-spacing-element\" (buttonClick)=\"togglePreviewMode()\"></pep-button>\n <ng-content select=\"[header-end-content]\"></ng-content>\n </div>\n </ng-template>\n <ng-template #previewButtonsTemplate>\n <a class=\"color-link body-sm\" (click)=\"togglePreviewMode()\" href=\"javascript:void(0)\">{{('LAYOUT_BUILDER.PREVIEW_CLICK_HERE' | translate)}}</a> \n </ng-template>\n </div>\n <div #layoutBuilderWrapper class=\"layout-builder-wrapper\" [ngClass]=\"{'limit-min-width': selectedScreenType === 'Landscape' }\">\n <ng-content select=\"pep-layout\"></ng-content>\n <!-- <pep-layout [editMode]=\"!previewMode\" [screenSize]=\"screenSize\"></pep-layout> -->\n\n <div *ngIf=\"!previewMode\" class=\"backdrop\" [ngClass]=\"{'show-backdrop': currentEditor?.type === 'section' || currentEditor?.type === 'block'}\"></div>\n </div>\n </div>\n </ng-container>\n</pep-page-layout>", styles: [".side-bar-title{display:flex;padding-top:var(--pep-spacing-sm, .5rem)}.side-bar-title .back-button{margin-inline-end:var(--pep-spacing-sm, .5rem)}.side-bar-title .title{display:flex;align-items:center}.layout-builder-editor-wrapper ::ng-deep .layout-builder-editor-tabs{height:100%}.layout-builder-editor-wrapper ::ng-deep .layout-builder-editor-tabs .mat-tab-header{position:sticky;top:calc(var(--pep-top-bar-spacing-top, 1.5rem) + var(--pep-top-bar-spacing-bottom, .5rem) + var(--pep-top-bar-field-height, 2.5rem));z-index:2}.layout-builder-editor-wrapper ::ng-deep .layout-builder-editor-tabs .mat-tab-header-pagination{display:none}.layout-builder-editor-wrapper ::ng-deep .layout-builder-editor-tabs .mat-tab-labels{display:grid;grid-template-columns:1fr 1fr}.layout-builder-editor-wrapper ::ng-deep .layout-builder-editor-tabs .mat-tab-labels .mat-tab-label{padding:0 var(--pep-spacing-md, .75rem)!important}.layout-builder-editor-wrapper ::ng-deep .layout-builder-editor-tabs .mat-tab-body-wrapper{overflow:unset;margin:0;display:block}.layout-builder-editor-wrapper ::ng-deep .layout-builder-editor-tabs .mat-tab-body-wrapper .mat-tab-body.mat-tab-body-active{overflow:unset}.layout-builder-editor-wrapper ::ng-deep .layout-builder-editor-tabs .mat-tab-body-wrapper .mat-tab-body.mat-tab-body-active .mat-tab-body-content{overflow:unset;display:flex;flex-direction:column;padding-inline:0!important}.layout-builder-editor-wrapper ::ng-deep .layout-builder-editor-tabs .layout-builder-editor-tab{overflow:inherit;display:inherit;flex-direction:inherit;gap:var(--pep-spacing-lg, 1rem)}.layout-builder-editor-wrapper ::ng-deep .layout-builder-editor-tabs .layout-builder-editor-tab .group-buttons-container .toggle-buttons{width:100%}.layout-builder-editor-wrapper ::ng-deep .layout-builder-editor-tabs .layout-builder-editor-tab pep-checkbox,.layout-builder-editor-wrapper ::ng-deep .layout-builder-editor-tabs .layout-builder-editor-tab pep-color,.layout-builder-editor-wrapper ::ng-deep .layout-builder-editor-tabs .layout-builder-editor-tab pep-select,.layout-builder-editor-wrapper ::ng-deep .layout-builder-editor-tabs .layout-builder-editor-tab pep-textarea,.layout-builder-editor-wrapper ::ng-deep .layout-builder-editor-tabs .layout-builder-editor-tab pep-textbox{margin-bottom:0!important}.layout-builder-editor-wrapper ::ng-deep .layout-builder-editor-container{padding-top:var(--pep-spacing-lg, 1rem);padding-bottom:var(--pep-spacing-lg, 1rem)}.layout-builder-editor-wrapper ::ng-deep .layout-builder-editor-container,.layout-builder-editor-wrapper ::ng-deep .layout-builder-editor-group{overflow:inherit;display:inherit;flex-direction:inherit;gap:var(--pep-spacing-lg, 1rem);display:flex;flex-direction:column}.layout-builder-editor-wrapper ::ng-deep .layout-builder-editor-container .group-buttons-container .toggle-buttons,.layout-builder-editor-wrapper ::ng-deep .layout-builder-editor-group .group-buttons-container .toggle-buttons{width:100%}.layout-builder-editor-wrapper ::ng-deep .layout-builder-editor-container pep-checkbox,.layout-builder-editor-wrapper ::ng-deep .layout-builder-editor-container pep-color,.layout-builder-editor-wrapper ::ng-deep .layout-builder-editor-container pep-select,.layout-builder-editor-wrapper ::ng-deep .layout-builder-editor-container pep-textarea,.layout-builder-editor-wrapper ::ng-deep .layout-builder-editor-container pep-textbox,.layout-builder-editor-wrapper ::ng-deep .layout-builder-editor-group pep-checkbox,.layout-builder-editor-wrapper ::ng-deep .layout-builder-editor-group pep-color,.layout-builder-editor-wrapper ::ng-deep .layout-builder-editor-group pep-select,.layout-builder-editor-wrapper ::ng-deep .layout-builder-editor-group pep-textarea,.layout-builder-editor-wrapper ::ng-deep .layout-builder-editor-group pep-textbox{margin-bottom:0!important}.layout-builder-editor-wrapper ::ng-deep .editor-title{display:block;font-family:var(--pep-font-family-body, Inter),-apple-system,BlinkMacSystemFont,\"Segoe UI\",Roboto,Oxygen-Sans,Ubuntu,Cantarell,\"Helvetica Neue\",sans-serif!important;font-weight:var(--pep-font-weight-bold, 600)!important;font-size:var(--pep-font-size-xl, 1.25rem)!important;line-height:var(--pep-line-height-xl, 1.5625rem)!important;text-overflow:ellipsis;overflow:hidden;white-space:nowrap}.layout-builder-editor-wrapper ::ng-deep .editor-sub-title{display:block;font-family:var(--pep-font-family-body, Inter),-apple-system,BlinkMacSystemFont,\"Segoe UI\",Roboto,Oxygen-Sans,Ubuntu,Cantarell,\"Helvetica Neue\",sans-serif!important;font-weight:var(--pep-font-weight-normal, 400)!important;font-size:var(--pep-font-size-md, 1rem)!important;line-height:var(--pep-line-height-md, 1.25rem)!important;text-overflow:ellipsis;overflow:hidden;white-space:nowrap}.layout-builder-editor-wrapper ::ng-deep .editor-separator{margin-top:var(--pep-spacing-lg, 1rem);border-bottom:1px solid hsla(var(--pep-color-system-primary-h, 0),var(--pep-color-system-primary-s, 0%),var(--pep-color-system-primary-l, 10%),.24)}.layout-builder-editor-wrapper ::ng-deep .checkbox-as-sub-title,.layout-builder-editor-wrapper ::ng-deep .checkbox-as-title{margin-bottom:.5rem!important;min-height:unset!important}.layout-builder-editor-wrapper ::ng-deep .checkbox-as-sub-title .pep-checkbox-container,.layout-builder-editor-wrapper ::ng-deep .checkbox-as-title .pep-checkbox-container{background:unset!important;padding-left:unset!important;padding-right:unset!important}.layout-builder-editor-wrapper ::ng-deep .checkbox-as-sub-title .pep-checkbox-container .mat-checkbox-inner-container,.layout-builder-editor-wrapper ::ng-deep .checkbox-as-title .pep-checkbox-container .mat-checkbox-inner-container{margin-left:0!important;margin-right:0!important}.layout-builder-editor-wrapper ::ng-deep .checkbox-as-sub-title .pep-checkbox-container .mat-checkbox-layout,.layout-builder-editor-wrapper ::ng-deep .checkbox-as-title .pep-checkbox-container .mat-checkbox-layout{font-family:var(--pep-font-family-body, Inter),-apple-system,BlinkMacSystemFont,\"Segoe UI\",Roboto,Oxygen-Sans,Ubuntu,Cantarell,\"Helvetica Neue\",sans-serif!important;font-weight:var(--pep-font-weight-normal, 400);font-size:var(--pep-font-size-lg, 1.125rem)!important;line-height:var(--pep-line-height-lg, 1.40625rem)!important;font-weight:var(--pep-font-weight-bold, 600)!important}.layout-builder-editor-wrapper ::ng-deep .checkbox-as-sub-title .pep-checkbox-container .mat-checkbox-layout .mat-checkbox-label span,.layout-builder-editor-wrapper ::ng-deep .checkbox-as-title .pep-checkbox-container .mat-checkbox-layout .mat-checkbox-label span{margin:0 .5rem}.layout-builder-editor-wrapper ::ng-deep .checkbox-as-sub-title .pep-checkbox-container .mat-checkbox-layout{font-family:var(--pep-font-family-body, Inter),-apple-system,BlinkMacSystemFont,\"Segoe UI\",Roboto,Oxygen-Sans,Ubuntu,Cantarell,\"Helvetica Neue\",sans-serif!important;font-weight:var(--pep-font-weight-normal, 400);font-size:var(--pep-font-size-md, 1rem)!important;line-height:var(--pep-line-height-md, 1.25rem)!important;font-weight:var(--pep-font-weight-normal, 400)!important}.main-area-container{min-height:100%;display:grid;grid-template-rows:auto 1fr}.main-area-container .header-container{display:flex;position:sticky;top:0;z-index:100;height:3rem;align-items:center;justify-content:space-between;padding:0 var(--pep-spacing-sm, .5rem)}.main-area-container .header-container .header-group-btn{display:flex;justify-content:space-around;align-items:center}.main-area-container .header-container .header-end{display:flex;justify-content:flex-end;gap:var(--pep-spacing-sm, .5rem)}.main-area-container .header-container ::ng-deep .group-buttons-container .toggle-buttons{width:16rem}.main-area-container .layout-builder-wrapper{width:100%;margin:0 auto;position:relative}.main-area-container .layout-builder-wrapper.limit-min-width{min-width:800px}.main-area-container .layout-builder-wrapper .backdrop{position:absolute;width:100%;height:100%;top:0;z-index:10;display:none}.main-area-container .layout-builder-wrapper .backdrop.show-backdrop{display:block}\n", ".layout-builder-editor-wrapper ::ng-deep .layout-builder-editor-tabs .mat-tab-header{background:hsl(var(--pep-color-system-primary-invert-h, 255),var(--pep-color-system-primary-invert-s, 100%),var(--pep-color-system-primary-invert-l, 100%))}.main-area-container{background:hsla(var(--pep-color-system-primary-h, 0),var(--pep-color-system-primary-s, 0%),var(--pep-color-system-primary-l, 10%),.04)}.main-area-container .header-container{background:hsl(var(--pep-color-system-primary-invert-h, 255),var(--pep-color-system-primary-invert-s, 100%),var(--pep-color-system-primary-invert-l, 100%));box-shadow:var(--pep-shadow-sm-offset, 0 .25rem .5rem 0) hsla(var(--pep-color-system-primary-h, 0),var(--pep-color-system-primary-s, 0%),var(--pep-color-system-primary-l, 10%),.16)}.main-area-container .header-container .header-title{color:hsla(var(--pep-color-system-primary-h, 0),var(--pep-color-system-primary-s, 0%),var(--pep-color-system-primary-l, 10%),.7)}.main-area-container .header-container .size-limit-container{background:hsla(var(--pep-color-weak-h, 0),var(--pep-color-weak-s, 0%),var(--pep-color-weak-l, 10%),.12)}.main-area-container.preview-mode .header-container{background:unset;background-color:hsl(var(--pep-color-system-caution-h, 360),var(--pep-color-system-caution-s, 100%),var(--pep-color-system-caution-l, 45%))}.main-area-container.preview-mode .header-container .preview-title,.main-area-container.preview-mode .header-container .color-link{color:hsl(var(--pep-color-system-primary-invert-h, 255),var(--pep-color-system-primary-invert-s, 100%),var(--pep-color-system-primary-invert-l, 100%))}.main-area-container.preview-mode .layout-builder-wrapper{overflow:auto}.main-area-container .layout-builder-wrapper{background:hsl(var(--pep-color-system-primary-invert-h, 255),var(--pep-color-system-primary-invert-s, 100%),var(--pep-color-system-primary-invert-l, 100%));box-shadow:var(--pep-shadow-md-offset, 0 .5rem 1rem 0) hsla(var(--pep-color-system-primary-h, 0),var(--pep-color-system-primary-s, 0%),var(--pep-color-system-primary-l, 10%),.16)}.main-area-container .layout-builder-wrapper .backdrop{background:hsla(var(--pep-color-system-primary-h, 0),var(--pep-color-system-primary-s, 0%),var(--pep-color-system-primary-l, 10%),.5)}\n"], dependencies: [{ kind: "directive", type: i4.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i4.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i5.PepPageLayoutComponent, selector: "pep-page-layout", inputs: ["addPadding", "showShadow"] }, { kind: "component", type: i6.PepSideBarComponent, selector: "pep-side-bar", inputs: ["position", "ignoreResize", "showHeader", "showFooter", "showToggle", "useAsWebComponent"], outputs: ["stateChange"] }, { kind: "component", type: i7.PepButtonComponent, selector: "pep-button", inputs: ["key", "value", "styleType", "styleStateType", "sizeType", "classNames", "disabled", "iconName", "iconPosition", "visible"], outputs: ["buttonClick"] }, { kind: "component", type: i8.PepGroupButtonsComponent, selector: "pep-group-buttons", inputs: ["viewType", "styleType", "sizeType", "buttons", "buttonsDisabled", "supportUnselect", "selectedButtonKey", "stretch"], outputs: ["buttonClick"] }, { kind: "component", type: i9.PepLayoutEditorComponent, selector: "pep-layout-editor", inputs: ["availableBlocksForDrag", "hostObject"], outputs: ["hostObjectChange"] }, { kind: "component", type: i10.SectionEditorComponent, selector: "section-editor", inputs: ["hostObject"], outputs: ["hostObjectChange"] }, { kind: "pipe", type: i1.TranslatePipe, name: "translate" }] });
165
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: PepLayoutBuilderComponent, decorators: [{
166
+ type: Component,
167
+ args: [{ selector: 'pep-layout-builder', template: "<div *ngIf=\"lockScreen\" class=\"cdk-overlay-backdrop cdk-overlay-dark-backdrop cdk-overlay-backdrop-showing\"></div>\n\n<pep-page-layout [showShadow]=\"!previewMode && currentEditor !== null\" >\n <div pep-side-area *ngIf=\"!previewMode && currentEditor\" style=\"height: inherit;\">\n <pep-side-bar #sideBar [ignoreResize]=\"true\" (stateChange)=\"onSidebarStateChange($event)\">\n <div header-content class=\"side-bar-title\">\n <pep-button class=\"back-button\" sizeType=\"sm\" iconName=\"arrow_left_alt\" (buttonClick)=\"onNavigateBackFromEditor();\"></pep-button>\n <div class=\"title title-lg ellipsis\" [title]=\"currentEditor?.title\">\n <span>{{ currentEditor?.title }}</span>\n </div>\n </div>\n <div class=\"layout-builder-editor-wrapper\">\n <pep-layout-editor *ngIf=\"currentEditor?.type === 'layout-builder'\" [availableBlocksForDrag]=\"availableBlocksForDrag\"\n [hostObject]=\"currentEditor?.hostObject\" (hostObjectChange)=\"onLayoutEditorObjectChange($event)\"\n >\n <ng-container layout-editor-top-content>\n <ng-content select=\"[layout-editor-top-content]\"></ng-content>\n </ng-container>\n <ng-container layout-editor-bottom-content>\n <ng-content select=\"[layout-editor-bottom-content]\"></ng-content>\n </ng-container>\n </pep-layout-editor>\n \n <section-editor *ngIf=\"currentEditor?.type === 'section'\" \n [hostObject]=\"currentEditor?.hostObject\" (hostObjectChange)=\"onSectionEditorObjectChange($event)\"></section-editor>\n \n <div *ngIf=\"currentEditor?.type === 'block'\" class=\"layout-builder-editor-container\">\n <ng-content select=\"[block-editor-content]\"></ng-content>\n </div>\n </div>\n </pep-side-bar>\n </div>\n <ng-container pep-main-area>\n <div class=\"main-area-container\" [ngClass]=\"{'preview-mode': previewMode }\">\n <div class=\"header-container\" >\n <ng-container *ngIf=\"!previewMode; then editorTitleTemplate; else previewTitleTemplate\"></ng-container>\n <ng-template #editorTitleTemplate>\n <div>\n <span class=\"header-title body-xs\">{{('LAYOUT_BUILDER.VIEWPORT_WIDTH' | translate)}}:&nbsp;</span>\n <span class=\"body-xs\"><b>{{viewportWidth}}</b></span>\n </div>\n </ng-template>\n <ng-template #previewTitleTemplate>\n <div class=\"preview-title body-sm\">\n <span>{{('LAYOUT_BUILDER.PREVIEW_TITLE' | translate)}}</span>\n </div>\n </ng-template>\n\n <div class=\"header-group-btn\">\n <pep-group-buttons [buttons]=\"screenTypes\" [selectedButtonKey]=\"selectedScreenType\" sizeType=\"sm\" viewType=\"toggle\" >\n </pep-group-buttons>\n </div>\n\n <ng-container *ngIf=\"!previewMode; then editorButtonsTemplate; else previewButtonsTemplate\"></ng-container>\n <ng-template #editorButtonsTemplate>\n <div class=\"header-end\">\n <pep-button key='Preview' [value]=\"'ACTIONS.PREVIEW' | translate\" sizeType=\"sm\" classNames=\"pep-spacing-element\" (buttonClick)=\"togglePreviewMode()\"></pep-button>\n <ng-content select=\"[header-end-content]\"></ng-content>\n </div>\n </ng-template>\n <ng-template #previewButtonsTemplate>\n <a class=\"color-link body-sm\" (click)=\"togglePreviewMode()\" href=\"javascript:void(0)\">{{('LAYOUT_BUILDER.PREVIEW_CLICK_HERE' | translate)}}</a> \n </ng-template>\n </div>\n <div #layoutBuilderWrapper class=\"layout-builder-wrapper\" [ngClass]=\"{'limit-min-width': selectedScreenType === 'Landscape' }\">\n <ng-content select=\"pep-layout\"></ng-content>\n <!-- <pep-layout [editMode]=\"!previewMode\" [screenSize]=\"screenSize\"></pep-layout> -->\n\n <div *ngIf=\"!previewMode\" class=\"backdrop\" [ngClass]=\"{'show-backdrop': currentEditor?.type === 'section' || currentEditor?.type === 'block'}\"></div>\n </div>\n </div>\n </ng-container>\n</pep-page-layout>", styles: [".side-bar-title{display:flex;padding-top:var(--pep-spacing-sm, .5rem)}.side-bar-title .back-button{margin-inline-end:var(--pep-spacing-sm, .5rem)}.side-bar-title .title{display:flex;align-items:center}.layout-builder-editor-wrapper ::ng-deep .layout-builder-editor-tabs{height:100%}.layout-builder-editor-wrapper ::ng-deep .layout-builder-editor-tabs .mat-tab-header{position:sticky;top:calc(var(--pep-top-bar-spacing-top, 1.5rem) + var(--pep-top-bar-spacing-bottom, .5rem) + var(--pep-top-bar-field-height, 2.5rem));z-index:2}.layout-builder-editor-wrapper ::ng-deep .layout-builder-editor-tabs .mat-tab-header-pagination{display:none}.layout-builder-editor-wrapper ::ng-deep .layout-builder-editor-tabs .mat-tab-labels{display:grid;grid-template-columns:1fr 1fr}.layout-builder-editor-wrapper ::ng-deep .layout-builder-editor-tabs .mat-tab-labels .mat-tab-label{padding:0 var(--pep-spacing-md, .75rem)!important}.layout-builder-editor-wrapper ::ng-deep .layout-builder-editor-tabs .mat-tab-body-wrapper{overflow:unset;margin:0;display:block}.layout-builder-editor-wrapper ::ng-deep .layout-builder-editor-tabs .mat-tab-body-wrapper .mat-tab-body.mat-tab-body-active{overflow:unset}.layout-builder-editor-wrapper ::ng-deep .layout-builder-editor-tabs .mat-tab-body-wrapper .mat-tab-body.mat-tab-body-active .mat-tab-body-content{overflow:unset;display:flex;flex-direction:column;padding-inline:0!important}.layout-builder-editor-wrapper ::ng-deep .layout-builder-editor-tabs .layout-builder-editor-tab{overflow:inherit;display:inherit;flex-direction:inherit;gap:var(--pep-spacing-lg, 1rem)}.layout-builder-editor-wrapper ::ng-deep .layout-builder-editor-tabs .layout-builder-editor-tab .group-buttons-container .toggle-buttons{width:100%}.layout-builder-editor-wrapper ::ng-deep .layout-builder-editor-tabs .layout-builder-editor-tab pep-checkbox,.layout-builder-editor-wrapper ::ng-deep .layout-builder-editor-tabs .layout-builder-editor-tab pep-color,.layout-builder-editor-wrapper ::ng-deep .layout-builder-editor-tabs .layout-builder-editor-tab pep-select,.layout-builder-editor-wrapper ::ng-deep .layout-builder-editor-tabs .layout-builder-editor-tab pep-textarea,.layout-builder-editor-wrapper ::ng-deep .layout-builder-editor-tabs .layout-builder-editor-tab pep-textbox{margin-bottom:0!important}.layout-builder-editor-wrapper ::ng-deep .layout-builder-editor-container{padding-top:var(--pep-spacing-lg, 1rem);padding-bottom:var(--pep-spacing-lg, 1rem)}.layout-builder-editor-wrapper ::ng-deep .layout-builder-editor-container,.layout-builder-editor-wrapper ::ng-deep .layout-builder-editor-group{overflow:inherit;display:inherit;flex-direction:inherit;gap:var(--pep-spacing-lg, 1rem);display:flex;flex-direction:column}.layout-builder-editor-wrapper ::ng-deep .layout-builder-editor-container .group-buttons-container .toggle-buttons,.layout-builder-editor-wrapper ::ng-deep .layout-builder-editor-group .group-buttons-container .toggle-buttons{width:100%}.layout-builder-editor-wrapper ::ng-deep .layout-builder-editor-container pep-checkbox,.layout-builder-editor-wrapper ::ng-deep .layout-builder-editor-container pep-color,.layout-builder-editor-wrapper ::ng-deep .layout-builder-editor-container pep-select,.layout-builder-editor-wrapper ::ng-deep .layout-builder-editor-container pep-textarea,.layout-builder-editor-wrapper ::ng-deep .layout-builder-editor-container pep-textbox,.layout-builder-editor-wrapper ::ng-deep .layout-builder-editor-group pep-checkbox,.layout-builder-editor-wrapper ::ng-deep .layout-builder-editor-group pep-color,.layout-builder-editor-wrapper ::ng-deep .layout-builder-editor-group pep-select,.layout-builder-editor-wrapper ::ng-deep .layout-builder-editor-group pep-textarea,.layout-builder-editor-wrapper ::ng-deep .layout-builder-editor-group pep-textbox{margin-bottom:0!important}.layout-builder-editor-wrapper ::ng-deep .editor-title{display:block;font-family:var(--pep-font-family-body, Inter),-apple-system,BlinkMacSystemFont,\"Segoe UI\",Roboto,Oxygen-Sans,Ubuntu,Cantarell,\"Helvetica Neue\",sans-serif!important;font-weight:var(--pep-font-weight-bold, 600)!important;font-size:var(--pep-font-size-xl, 1.25rem)!important;line-height:var(--pep-line-height-xl, 1.5625rem)!important;text-overflow:ellipsis;overflow:hidden;white-space:nowrap}.layout-builder-editor-wrapper ::ng-deep .editor-sub-title{display:block;font-family:var(--pep-font-family-body, Inter),-apple-system,BlinkMacSystemFont,\"Segoe UI\",Roboto,Oxygen-Sans,Ubuntu,Cantarell,\"Helvetica Neue\",sans-serif!important;font-weight:var(--pep-font-weight-normal, 400)!important;font-size:var(--pep-font-size-md, 1rem)!important;line-height:var(--pep-line-height-md, 1.25rem)!important;text-overflow:ellipsis;overflow:hidden;white-space:nowrap}.layout-builder-editor-wrapper ::ng-deep .editor-separator{margin-top:var(--pep-spacing-lg, 1rem);border-bottom:1px solid hsla(var(--pep-color-system-primary-h, 0),var(--pep-color-system-primary-s, 0%),var(--pep-color-system-primary-l, 10%),.24)}.layout-builder-editor-wrapper ::ng-deep .checkbox-as-sub-title,.layout-builder-editor-wrapper ::ng-deep .checkbox-as-title{margin-bottom:.5rem!important;min-height:unset!important}.layout-builder-editor-wrapper ::ng-deep .checkbox-as-sub-title .pep-checkbox-container,.layout-builder-editor-wrapper ::ng-deep .checkbox-as-title .pep-checkbox-container{background:unset!important;padding-left:unset!important;padding-right:unset!important}.layout-builder-editor-wrapper ::ng-deep .checkbox-as-sub-title .pep-checkbox-container .mat-checkbox-inner-container,.layout-builder-editor-wrapper ::ng-deep .checkbox-as-title .pep-checkbox-container .mat-checkbox-inner-container{margin-left:0!important;margin-right:0!important}.layout-builder-editor-wrapper ::ng-deep .checkbox-as-sub-title .pep-checkbox-container .mat-checkbox-layout,.layout-builder-editor-wrapper ::ng-deep .checkbox-as-title .pep-checkbox-container .mat-checkbox-layout{font-family:var(--pep-font-family-body, Inter),-apple-system,BlinkMacSystemFont,\"Segoe UI\",Roboto,Oxygen-Sans,Ubuntu,Cantarell,\"Helvetica Neue\",sans-serif!important;font-weight:var(--pep-font-weight-normal, 400);font-size:var(--pep-font-size-lg, 1.125rem)!important;line-height:var(--pep-line-height-lg, 1.40625rem)!important;font-weight:var(--pep-font-weight-bold, 600)!important}.layout-builder-editor-wrapper ::ng-deep .checkbox-as-sub-title .pep-checkbox-container .mat-checkbox-layout .mat-checkbox-label span,.layout-builder-editor-wrapper ::ng-deep .checkbox-as-title .pep-checkbox-container .mat-checkbox-layout .mat-checkbox-label span{margin:0 .5rem}.layout-builder-editor-wrapper ::ng-deep .checkbox-as-sub-title .pep-checkbox-container .mat-checkbox-layout{font-family:var(--pep-font-family-body, Inter),-apple-system,BlinkMacSystemFont,\"Segoe UI\",Roboto,Oxygen-Sans,Ubuntu,Cantarell,\"Helvetica Neue\",sans-serif!important;font-weight:var(--pep-font-weight-normal, 400);font-size:var(--pep-font-size-md, 1rem)!important;line-height:var(--pep-line-height-md, 1.25rem)!important;font-weight:var(--pep-font-weight-normal, 400)!important}.main-area-container{min-height:100%;display:grid;grid-template-rows:auto 1fr}.main-area-container .header-container{display:flex;position:sticky;top:0;z-index:100;height:3rem;align-items:center;justify-content:space-between;padding:0 var(--pep-spacing-sm, .5rem)}.main-area-container .header-container .header-group-btn{display:flex;justify-content:space-around;align-items:center}.main-area-container .header-container .header-end{display:flex;justify-content:flex-end;gap:var(--pep-spacing-sm, .5rem)}.main-area-container .header-container ::ng-deep .group-buttons-container .toggle-buttons{width:16rem}.main-area-container .layout-builder-wrapper{width:100%;margin:0 auto;position:relative}.main-area-container .layout-builder-wrapper.limit-min-width{min-width:800px}.main-area-container .layout-builder-wrapper .backdrop{position:absolute;width:100%;height:100%;top:0;z-index:10;display:none}.main-area-container .layout-builder-wrapper .backdrop.show-backdrop{display:block}\n", ".layout-builder-editor-wrapper ::ng-deep .layout-builder-editor-tabs .mat-tab-header{background:hsl(var(--pep-color-system-primary-invert-h, 255),var(--pep-color-system-primary-invert-s, 100%),var(--pep-color-system-primary-invert-l, 100%))}.main-area-container{background:hsla(var(--pep-color-system-primary-h, 0),var(--pep-color-system-primary-s, 0%),var(--pep-color-system-primary-l, 10%),.04)}.main-area-container .header-container{background:hsl(var(--pep-color-system-primary-invert-h, 255),var(--pep-color-system-primary-invert-s, 100%),var(--pep-color-system-primary-invert-l, 100%));box-shadow:var(--pep-shadow-sm-offset, 0 .25rem .5rem 0) hsla(var(--pep-color-system-primary-h, 0),var(--pep-color-system-primary-s, 0%),var(--pep-color-system-primary-l, 10%),.16)}.main-area-container .header-container .header-title{color:hsla(var(--pep-color-system-primary-h, 0),var(--pep-color-system-primary-s, 0%),var(--pep-color-system-primary-l, 10%),.7)}.main-area-container .header-container .size-limit-container{background:hsla(var(--pep-color-weak-h, 0),var(--pep-color-weak-s, 0%),var(--pep-color-weak-l, 10%),.12)}.main-area-container.preview-mode .header-container{background:unset;background-color:hsl(var(--pep-color-system-caution-h, 360),var(--pep-color-system-caution-s, 100%),var(--pep-color-system-caution-l, 45%))}.main-area-container.preview-mode .header-container .preview-title,.main-area-container.preview-mode .header-container .color-link{color:hsl(var(--pep-color-system-primary-invert-h, 255),var(--pep-color-system-primary-invert-s, 100%),var(--pep-color-system-primary-invert-l, 100%))}.main-area-container.preview-mode .layout-builder-wrapper{overflow:auto}.main-area-container .layout-builder-wrapper{background:hsl(var(--pep-color-system-primary-invert-h, 255),var(--pep-color-system-primary-invert-s, 100%),var(--pep-color-system-primary-invert-l, 100%));box-shadow:var(--pep-shadow-md-offset, 0 .5rem 1rem 0) hsla(var(--pep-color-system-primary-h, 0),var(--pep-color-system-primary-s, 0%),var(--pep-color-system-primary-l, 10%),.16)}.main-area-container .layout-builder-wrapper .backdrop{background:hsla(var(--pep-color-system-primary-h, 0),var(--pep-color-system-primary-s, 0%),var(--pep-color-system-primary-l, 10%),.5)}\n"] }]
168
+ }], ctorParameters: function () { return [{ type: i0.Renderer2 }, { type: i0.ElementRef }, { type: i1.TranslateService }, { type: i2.PepLayoutBuilderService }, { type: i3.PepAddonService }]; }, propDecorators: { layoutBuilderWrapper: [{
169
+ type: ViewChild,
170
+ args: ['layoutBuilderWrapper', { static: true }]
171
+ }], sideBarComponent: [{
172
+ type: ViewChild,
173
+ args: [PepSideBarComponent, { read: ElementRef }]
174
+ }], availableBlocksForDrag: [{
175
+ type: Input
176
+ }], backClick: [{
177
+ type: Output
178
+ }], blockEditorChange: [{
179
+ type: Output
180
+ }], blockAdded: [{
181
+ type: Output
182
+ }], blocksRemoved: [{
183
+ type: Output
184
+ }], onResize: [{
185
+ type: HostListener,
186
+ args: ['window:resize', ['$event']]
187
+ }] } });
188
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"layout-builder.component.js","sourceRoot":"","sources":["../../../../projects/ngx-composite-lib/layout-builder/layout-builder.component.ts","../../../../projects/ngx-composite-lib/layout-builder/layout-builder.component.html"],"names":[],"mappings":"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","sourcesContent":["import { ElementRef, Renderer2, ViewChild, OnInit, Component, EventEmitter, Input, Output, HostListener } from '@angular/core';\nimport { BaseDestroyerDirective, PepAddonService, PepLayoutService, PepScreenSizeType } from '@pepperi-addons/ngx-lib';\nimport { DataViewScreenSize } from '@pepperi-addons/papi-sdk';\nimport { TranslateService } from '@ngx-translate/core';\nimport { PepButton } from '@pepperi-addons/ngx-lib/button';\nimport { pepIconDeviceDesktop, pepIconDeviceMobile, pepIconDeviceTablet } from '@pepperi-addons/ngx-lib/icon';\nimport { IPepSideBarStateChangeEvent, PepSideBarComponent } from '@pepperi-addons/ngx-lib/side-bar';\nimport { IPepDraggableItem } from '@pepperi-addons/ngx-lib/draggable-items';\n\nimport { IEditor, ILayoutEditor, IPepLayoutSection, IPepLayoutView, ILayoutSectionEditor, IPepLayoutBlockAddedEvent } from './layout-builder.model';\nimport { PepLayoutBuilderService } from './layout-builder.service';\nimport { coerceNumberProperty } from '@angular/cdk/coercion';\n\n@Component({\n    selector: 'pep-layout-builder',\n    templateUrl: './layout-builder.component.html',\n    styleUrls: ['./layout-builder.component.scss', './layout-builder.component.theme.scss'],\n})\nexport class PepLayoutBuilderComponent extends BaseDestroyerDirective implements OnInit {\n    @ViewChild('layoutBuilderWrapper', { static: true }) layoutBuilderWrapper!: ElementRef;\n    @ViewChild(PepSideBarComponent, { read: ElementRef }) private sideBarComponent!: ElementRef;\n    \n    private _availableBlocksForDrag: Array<IPepDraggableItem> = [];\n    @Input() \n    set availableBlocksForDrag(value: Array<IPepDraggableItem>) {\n        this._availableBlocksForDrag = value;\n        this.layoutBuilderService.setAvailableBlocksToDrag(value);\n    }\n    get availableBlocksForDrag(): Array<IPepDraggableItem> {\n        return this._availableBlocksForDrag;\n    }\n\n    @Output() backClick: EventEmitter<void> = new EventEmitter();\n    @Output() blockEditorChange: EventEmitter<string> = new EventEmitter(); // blockKey\n    @Output() blockAdded: EventEmitter<IPepLayoutBlockAddedEvent> = new EventEmitter();\n    @Output() blocksRemoved: EventEmitter<string[]> = new EventEmitter();\n\n    // screenSize: PepScreenSizeType;\n    protected lockScreen = false;\n    protected previewMode = false;\n    protected currentEditor: IEditor | null = null;\n    protected viewportWidth: number = 0;\n    protected screenTypes!: Array<PepButton>;\n\n    protected selectedScreenType!: DataViewScreenSize;\n    \n    constructor(\n        private renderer: Renderer2,\n        private hostElement: ElementRef,\n        private translate: TranslateService,\n        private layoutBuilderService: PepLayoutBuilderService,\n        private pepAddonService: PepAddonService,\n    ) {\n        super();\n\n        this.renderer.addClass(this.hostElement.nativeElement, 'pep-layout-builder');\n        this.layoutBuilderService.isEditMode = true;\n\n        this.pepAddonService.setShellRouterData({ showSidebar: false, addPadding: false});\n    }\n\n    private setScreenWidth(screenType: DataViewScreenSize) {\n        this.layoutBuilderService.setScreenWidth(screenType);\n    }\n\n    private updateViewportWidth() {\n        if (this.layoutBuilderWrapper?.nativeElement) {\n            setTimeout(() => {\n                this.viewportWidth = this.layoutBuilderWrapper.nativeElement.clientWidth;\n            });\n        }\n    }\n    \n    private subscribeEvents() {\n        /***********************************************************************************************/\n        /*                          Internal Events - for code usage\n        /***********************************************************************************************/\n\n        this.layoutBuilderService.previewModeChange$.pipe(this.getDestroyer()).subscribe((previewMode: any) => {\n            this.previewMode = previewMode;\n        });\n\n        this.layoutBuilderService.lockScreenChange$.pipe(this.getDestroyer()).subscribe((lockScreen: any) => {\n            this.lockScreen = lockScreen;\n        });\n\n        this.layoutBuilderService.screenSizeChange$.pipe(this.getDestroyer()).subscribe((size: any) => {\n            // this.screenSize = size;\n            const screenType = this.layoutBuilderService.getScreenType(size);\n            this.selectedScreenType = screenType;\n            // TODO: Raise event to update the screen size maybe there is data in editor that need to update??\n        });\n\n        // For update the layout data\n        this.layoutBuilderService.layoutViewChange$.pipe(this.getDestroyer()).subscribe((layoutView: any) => {\n            if (layoutView) {\n                if (this.layoutBuilderWrapper?.nativeElement) {\n                    let maxWidth = coerceNumberProperty(layoutView.Layout.MaxWidth, 0);\n                    const maxWidthToSet = maxWidth === 0 ? '100%' : `${maxWidth}px`;\n                    this.renderer.setStyle(this.layoutBuilderWrapper.nativeElement, 'max-width', maxWidthToSet);\n                    this.updateViewportWidth();\n                }\n            }\n        });\n\n        this.layoutBuilderService.screenWidthChange$.pipe(this.getDestroyer()).subscribe((width: any) => {\n            if (this.layoutBuilderWrapper?.nativeElement) {\n                this.renderer.setStyle(this.layoutBuilderWrapper.nativeElement, 'width', width);\n                this.updateViewportWidth();\n            }\n        });\n\n        // Get the sections id's into sectionsColumnsDropList for the drag & drop.\n        this.layoutBuilderService.sectionsChange$.pipe(this.getDestroyer()).subscribe((sections: any) => {\n            // Concat all results into one array.\n            const sectionsColumnsDropList = [].concat(...sections.map((section: IPepLayoutSection) => {\n                return section.Columns.map((column, index) => \n                    this.layoutBuilderService.getSectionColumnKey(section.Key, index.toString())\n                )\n            }));\n\n            this.layoutBuilderService.notifySectionsColumnsDropListChange(sectionsColumnsDropList);\n        });\n\n\n        /***********************************************************************************************/\n        /*                          External Events - for raise to the client\n        /***********************************************************************************************/\n\n        // For update editor.\n        this.layoutBuilderService.editorChange$.pipe(this.getDestroyer()).subscribe((editor: any) => {\n            if (editor) {\n                // Init the side bar scroll top to 0.\n                if (this.sideBarComponent) {\n                    const sideLayout = this.sideBarComponent.nativeElement.querySelector('.side-layout');\n                    sideLayout?.scrollTo(0, 0);\n                }\n    \n                this.currentEditor = editor;\n    \n                // Raise event to let the user set the block editor in the UI.\n                if (editor.type === 'block') {\n                    this.blockEditorChange.emit(editor.id);\n                }\n            }\n        });\n\n        this.layoutBuilderService.blockAddedEventSubject$.pipe(this.getDestroyer()).subscribe((event: any) => {\n            if (event) {\n                this.blockAdded.emit(event);\n            }\n        });\n\n        this.layoutBuilderService.blocksRemovedEventSubject$.pipe(this.getDestroyer()).subscribe((event: any) => {\n            if (event?.length > 0) {\n                this.blocksRemoved.emit(event);\n            }\n        });\n    }\n\n    ngOnInit() {\n        // Get the first translation for load all translations.\n        this.translate.get('LAYOUT_BUILDER.DESKTOP').subscribe((res) => {\n            this.layoutBuilderService.defaultSectionTitle = this.translate.instant('LAYOUT_BUILDER.SECTION');\n    \n            this.screenTypes = [\n                { key: 'Landscape', value: this.translate.instant('LAYOUT_BUILDER.DESKTOP'), callback: () => this.setScreenWidth('Landscape'), iconName: pepIconDeviceDesktop.name, iconPosition: 'end' },\n                { key: 'Tablet', value: this.translate.instant('LAYOUT_BUILDER.TABLET'), callback: () => this.setScreenWidth('Tablet'), iconName: pepIconDeviceTablet.name, iconPosition: 'end' },\n                { key: 'Phablet', value: this.translate.instant('LAYOUT_BUILDER.MOBILE'), callback: () => this.setScreenWidth('Phablet'), iconName: pepIconDeviceMobile.name, iconPosition: 'end' }\n            ];\n        });\n        \n        this.subscribeEvents();\n    }\n\n    @HostListener('window:resize', ['$event'])\n    onResize(event: any): void {\n        this.updateViewportWidth();\n    }\n\n    togglePreviewMode() {\n        this.layoutBuilderService.notifyPreviewModeChange(!this.previewMode);\n        this.updateViewportWidth();\n    }\n\n    onSidebarStateChange(event: IPepSideBarStateChangeEvent) {\n        this.updateViewportWidth();\n    }\n\n    onLayoutEditorObjectChange(pageEditor: ILayoutEditor) {\n        this.layoutBuilderService.updateLayoutFromEditor(pageEditor);\n    }\n\n    onSectionEditorObjectChange(sectionEditor: ILayoutSectionEditor) {\n        this.layoutBuilderService.updateSectionFromEditor(sectionEditor);\n    }\n\n    onNavigateBackFromEditor() {\n        if (!this.currentEditor || this.currentEditor?.type === 'layout-builder') {\n            this.backClick.emit();\n        } else {\n            this.layoutBuilderService.navigateBackFromEditor();\n        }\n    }\n}\n","<div *ngIf=\"lockScreen\" class=\"cdk-overlay-backdrop cdk-overlay-dark-backdrop cdk-overlay-backdrop-showing\"></div>\n\n<pep-page-layout [showShadow]=\"!previewMode && currentEditor !== null\" >\n    <div pep-side-area *ngIf=\"!previewMode && currentEditor\" style=\"height: inherit;\">\n        <pep-side-bar #sideBar [ignoreResize]=\"true\" (stateChange)=\"onSidebarStateChange($event)\">\n            <div header-content class=\"side-bar-title\">\n                <pep-button class=\"back-button\" sizeType=\"sm\" iconName=\"arrow_left_alt\" (buttonClick)=\"onNavigateBackFromEditor();\"></pep-button>\n                <div class=\"title title-lg ellipsis\" [title]=\"currentEditor?.title\">\n                    <span>{{ currentEditor?.title }}</span>\n                </div>\n            </div>\n            <div class=\"layout-builder-editor-wrapper\">\n                <pep-layout-editor *ngIf=\"currentEditor?.type === 'layout-builder'\" [availableBlocksForDrag]=\"availableBlocksForDrag\"\n                    [hostObject]=\"currentEditor?.hostObject\" (hostObjectChange)=\"onLayoutEditorObjectChange($event)\"\n                    >\n                    <ng-container layout-editor-top-content>\n                        <ng-content select=\"[layout-editor-top-content]\"></ng-content>\n                    </ng-container>\n                    <ng-container layout-editor-bottom-content>\n                        <ng-content select=\"[layout-editor-bottom-content]\"></ng-content>\n                    </ng-container>\n                </pep-layout-editor>\n            \n                <section-editor *ngIf=\"currentEditor?.type === 'section'\" \n                    [hostObject]=\"currentEditor?.hostObject\" (hostObjectChange)=\"onSectionEditorObjectChange($event)\"></section-editor>\n            \n                <div *ngIf=\"currentEditor?.type === 'block'\" class=\"layout-builder-editor-container\">\n                    <ng-content select=\"[block-editor-content]\"></ng-content>\n                </div>\n            </div>\n        </pep-side-bar>\n    </div>\n    <ng-container pep-main-area>\n        <div class=\"main-area-container\" [ngClass]=\"{'preview-mode': previewMode }\">\n            <div class=\"header-container\" >\n                <ng-container *ngIf=\"!previewMode; then editorTitleTemplate; else previewTitleTemplate\"></ng-container>\n                <ng-template #editorTitleTemplate>\n                    <div>\n                        <span class=\"header-title body-xs\">{{('LAYOUT_BUILDER.VIEWPORT_WIDTH' | translate)}}:&nbsp;</span>\n                        <span class=\"body-xs\"><b>{{viewportWidth}}</b></span>\n                    </div>\n                </ng-template>\n                <ng-template #previewTitleTemplate>\n                    <div class=\"preview-title body-sm\">\n                        <span>{{('LAYOUT_BUILDER.PREVIEW_TITLE' | translate)}}</span>\n                    </div>\n                </ng-template>\n\n                <div class=\"header-group-btn\">\n                    <pep-group-buttons [buttons]=\"screenTypes\" [selectedButtonKey]=\"selectedScreenType\" sizeType=\"sm\" viewType=\"toggle\" >\n                    </pep-group-buttons>\n                </div>\n\n                <ng-container *ngIf=\"!previewMode; then editorButtonsTemplate; else previewButtonsTemplate\"></ng-container>\n                <ng-template #editorButtonsTemplate>\n                    <div class=\"header-end\">\n                        <pep-button key='Preview' [value]=\"'ACTIONS.PREVIEW' | translate\" sizeType=\"sm\" classNames=\"pep-spacing-element\" (buttonClick)=\"togglePreviewMode()\"></pep-button>\n                        <ng-content select=\"[header-end-content]\"></ng-content>\n                    </div>\n                </ng-template>\n                <ng-template #previewButtonsTemplate>\n                    <a class=\"color-link body-sm\" (click)=\"togglePreviewMode()\" href=\"javascript:void(0)\">{{('LAYOUT_BUILDER.PREVIEW_CLICK_HERE' | translate)}}</a>    \n                </ng-template>\n            </div>\n            <div #layoutBuilderWrapper class=\"layout-builder-wrapper\" [ngClass]=\"{'limit-min-width': selectedScreenType === 'Landscape' }\">\n                <ng-content select=\"pep-layout\"></ng-content>\n                <!-- <pep-layout [editMode]=\"!previewMode\" [screenSize]=\"screenSize\"></pep-layout> -->\n\n                <div *ngIf=\"!previewMode\" class=\"backdrop\" [ngClass]=\"{'show-backdrop': currentEditor?.type === 'section' || currentEditor?.type === 'block'}\"></div>\n            </div>\n        </div>\n    </ng-container>\n</pep-page-layout>"]}
@@ -0,0 +1,6 @@
1
+ export {};
2
+ // export interface IBlockEditor {
3
+ // id: string,
4
+ // [key: string]: any
5
+ // }
6
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGF5b3V0LWJ1aWxkZXIubW9kZWwuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtY29tcG9zaXRlLWxpYi9sYXlvdXQtYnVpbGRlci9sYXlvdXQtYnVpbGRlci5tb2RlbC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBb0VBLGtDQUFrQztBQUNsQyxrQkFBa0I7QUFDbEIseUJBQXlCO0FBQ3pCLElBQUkiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBQYWdlQmxvY2tDb250YWluZXIsIFBhZ2VMYXlvdXQsIFBhZ2VTZWN0aW9uLCBQYWdlU2VjdGlvbkNvbHVtbiwgUGFnZVNpemVUeXBlLCBTcGxpdFR5cGUgfSBmcm9tIFwiQHBlcHBlcmktYWRkb25zL3BhcGktc2RrXCI7XG5pbXBvcnQgeyBJUGVwRHJhZ2dhYmxlSXRlbSB9IGZyb20gXCJAcGVwcGVyaS1hZGRvbnMvbmd4LWxpYi9kcmFnZ2FibGUtaXRlbXNcIjtcblxuZXhwb3J0IHR5cGUgUGVwTGF5b3V0U2l6ZVR5cGUgPSBQYWdlU2l6ZVR5cGU7XG5cbmV4cG9ydCBpbnRlcmZhY2UgSVBlcExheW91dCBleHRlbmRzIFBhZ2VMYXlvdXQge1xuICAgIFNlY3Rpb25zOiBJUGVwTGF5b3V0U2VjdGlvbltdO1xuICAgIFZlcnRpY2FsU3BhY2luZz86IFBlcExheW91dFNpemVUeXBlO1xuICAgIEhvcml6b250YWxTcGFjaW5nPzogUGVwTGF5b3V0U2l6ZVR5cGU7XG4gICAgU2VjdGlvbnNHYXA/OiBQZXBMYXlvdXRTaXplVHlwZTtcbiAgICBDb2x1bW5zR2FwPzogUGVwTGF5b3V0U2l6ZVR5cGU7XG59XG5leHBvcnQgaW50ZXJmYWNlIElQZXBMYXlvdXRTZWN0aW9uIGV4dGVuZHMgUGFnZVNlY3Rpb24geyBcbiAgICBDb2x1bW5zOiBJUGVwTGF5b3V0U2VjdGlvbkNvbHVtbltdO1xuICAgIENvbHVtbnNHYXA/OiBQZXBMYXlvdXRTaXplVHlwZTtcbn1cbmV4cG9ydCBpbnRlcmZhY2UgSVBlcExheW91dFNlY3Rpb25Db2x1bW4gZXh0ZW5kcyBQYWdlU2VjdGlvbkNvbHVtbiB7XG4gICAgQmxvY2tDb250YWluZXI/OiBJUGVwTGF5b3V0QmxvY2tDb250YWluZXI7XG59XG5leHBvcnQgaW50ZXJmYWNlIElQZXBMYXlvdXRCbG9ja0NvbnRhaW5lciBleHRlbmRzIFBhZ2VCbG9ja0NvbnRhaW5lciB7IFxuICAgIERyYWdnYWJsZUl0ZW1LZXk6IHN0cmluZyxcbn1cblxuZXhwb3J0IGludGVyZmFjZSBJUGVwTGF5b3V0QmxvY2tBZGRlZEV2ZW50IHtcbiAgICBCbG9ja0tleTogc3RyaW5nLFxuICAgIERyYWdnYWJsZUl0ZW06IElQZXBEcmFnZ2FibGVJdGVtLFxufVxuICAgIFxuZXhwb3J0IGludGVyZmFjZSBJUGVwTGF5b3V0VmlldyB7XG4gICAgLy8gSWQ6IHN0cmluZyxcbiAgICBUaXRsZTogc3RyaW5nLFxuICAgIExheW91dDogSVBlcExheW91dCxcbn1cblxuZXhwb3J0IHR5cGUgTGF5b3V0RWRpdG9yVHlwZSA9ICdsYXlvdXQtYnVpbGRlcicgfCAnc2VjdGlvbicgfCAnYmxvY2snO1xuXG5leHBvcnQgaW50ZXJmYWNlIElFZGl0b3Ige1xuICAgIGlkOiBzdHJpbmcsXG4gICAgdGl0bGU6IHN0cmluZyxcbiAgICB0eXBlOiBMYXlvdXRFZGl0b3JUeXBlLFxuICAgIC8vIHJlbW90ZU1vZHVsZU9wdGlvbnM/OiBQZXBSZW1vdGVMb2FkZXJPcHRpb25zLFxuICAgIGhvc3RPYmplY3Q/OiBhbnlcbn1cblxuZXhwb3J0IGludGVyZmFjZSBJTGF5b3V0RWRpdG9yIHtcbiAgICAvLyBpZDogc3RyaW5nLFxuICAgIC8vIHBhZ2VOYW1lOiBzdHJpbmcsXG4gICAgLy8gcGFnZURlc2NyaXB0aW9uOiBzdHJpbmcsXG4gICAgLy8gcGFyYW1ldGVyczogSVBhcmFtZW1ldGVyW10sXG4gICAgLy8gb25Mb2FkRmxvdzogYW55LFxuICAgIC8vIG9uQ2hhbmdlRmxvdzogYW55LFxuICAgIG1heFdpZHRoOiBudW1iZXIsXG4gICAgaG9yaXpvbnRhbFNwYWNpbmc/OiBQZXBMYXlvdXRTaXplVHlwZSxcbiAgICB2ZXJ0aWNhbFNwYWNpbmc/OiBQZXBMYXlvdXRTaXplVHlwZSxcbiAgICBzZWN0aW9uc0dhcD86IFBlcExheW91dFNpemVUeXBlLFxuICAgIGNvbHVtbnNHYXA/OiBQZXBMYXlvdXRTaXplVHlwZSxcbiAgICByb3VuZGVkQ29ybmVycz86IFBlcExheW91dFNpemVUeXBlLFxufVxuXG5leHBvcnQgaW50ZXJmYWNlIElMYXlvdXRTZWN0aW9uRWRpdG9yIHtcbiAgICBpZDogc3RyaW5nLFxuICAgIHNlY3Rpb25OYW1lOiBzdHJpbmcsXG4gICAgc3BsaXQ6IFNwbGl0VHlwZSB8IHVuZGVmaW5lZCxcbiAgICBoZWlnaHQ6IG51bWJlcixcbiAgICBjb2xsYXBzZU9uVGFibGV0OiBib29sZWFuLFxuICAgIGZpbGxIZWlnaHQ6IGJvb2xlYW5cbn1cblxuLy8gZXhwb3J0IGludGVyZmFjZSBJQmxvY2tFZGl0b3Ige1xuLy8gICAgIGlkOiBzdHJpbmcsXG4vLyAgICAgW2tleTogc3RyaW5nXTogYW55XG4vLyB9Il19
@@ -0,0 +1,129 @@
1
+ import { NgModule } from '@angular/core';
2
+ import { CommonModule } from '@angular/common';
3
+ import { DragDropModule } from '@angular/cdk/drag-drop';
4
+ import { MatCommonModule } from '@angular/material/core';
5
+ import { MatTabsModule } from '@angular/material/tabs';
6
+ import { PepNgxLibModule } from '@pepperi-addons/ngx-lib';
7
+ import { PepSizeDetectorModule } from '@pepperi-addons/ngx-lib/size-detector';
8
+ import { PepSkeletonLoaderModule } from '@pepperi-addons/ngx-lib/skeleton-loader';
9
+ import { PepButtonModule } from '@pepperi-addons/ngx-lib/button';
10
+ import { PepDialogModule } from '@pepperi-addons/ngx-lib/dialog';
11
+ import { PepGroupButtonsModule } from '@pepperi-addons/ngx-lib/group-buttons';
12
+ import { PepPageLayoutModule } from '@pepperi-addons/ngx-lib/page-layout';
13
+ import { PepSideBarModule } from '@pepperi-addons/ngx-lib/side-bar';
14
+ import { PepDraggableItemsModule } from '@pepperi-addons/ngx-lib/draggable-items';
15
+ import { PepCheckboxModule } from '@pepperi-addons/ngx-lib/checkbox';
16
+ import { PepSelectModule } from '@pepperi-addons/ngx-lib/select';
17
+ import { PepTextboxModule } from '@pepperi-addons/ngx-lib/textbox';
18
+ import { PepGroupButtonsSettingsModule } from '@pepperi-addons/ngx-composite-lib/group-buttons-settings';
19
+ import { PepHideInModule } from './hide-in/hide-in.module';
20
+ import { PepLayoutModule } from './layout/layout.module';
21
+ import { PepLayoutEditorModule } from './layout-editor/layout-editor.module';
22
+ import { SectionEditorModule } from './section-editor/section-editor.module';
23
+ import { PepLayoutBuilderService } from './layout-builder.service';
24
+ import { PepLayoutBuilderComponent } from './layout-builder.component';
25
+ // import { SectionBlockModule } from './layout/section-block/section-block.module';
26
+ import { PepIconModule, pepIconDeviceDesktop, pepIconDeviceTablet, pepIconDeviceMobile, } from '@pepperi-addons/ngx-lib/icon';
27
+ import * as i0 from "@angular/core";
28
+ import * as i1 from "@pepperi-addons/ngx-lib/icon";
29
+ export class PepLayoutBuilderModule {
30
+ constructor(pepIconRegistry) {
31
+ this.pepIconRegistry = pepIconRegistry;
32
+ this.pepIconRegistry.registerIcons([
33
+ pepIconDeviceDesktop,
34
+ pepIconDeviceTablet,
35
+ pepIconDeviceMobile,
36
+ ]);
37
+ }
38
+ }
39
+ PepLayoutBuilderModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: PepLayoutBuilderModule, deps: [{ token: i1.PepIconRegistry }], target: i0.ɵɵFactoryTarget.NgModule });
40
+ PepLayoutBuilderModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.0.2", ngImport: i0, type: PepLayoutBuilderModule, declarations: [PepLayoutBuilderComponent], imports: [CommonModule,
41
+ DragDropModule,
42
+ // Material modules,
43
+ MatCommonModule,
44
+ MatTabsModule,
45
+ // ngx-lib modules
46
+ PepNgxLibModule,
47
+ PepDialogModule,
48
+ PepIconModule,
49
+ PepPageLayoutModule,
50
+ PepSideBarModule,
51
+ PepButtonModule,
52
+ PepCheckboxModule,
53
+ PepTextboxModule,
54
+ PepSelectModule,
55
+ PepSizeDetectorModule,
56
+ PepGroupButtonsModule,
57
+ PepSkeletonLoaderModule,
58
+ PepDraggableItemsModule,
59
+ PepGroupButtonsSettingsModule,
60
+ PepHideInModule,
61
+ PepLayoutModule,
62
+ PepLayoutEditorModule,
63
+ SectionEditorModule], exports: [PepLayoutBuilderComponent,
64
+ PepLayoutModule] });
65
+ PepLayoutBuilderModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: PepLayoutBuilderModule, providers: [PepLayoutBuilderService], imports: [CommonModule,
66
+ DragDropModule,
67
+ // Material modules,
68
+ MatCommonModule,
69
+ MatTabsModule,
70
+ // ngx-lib modules
71
+ PepNgxLibModule,
72
+ PepDialogModule,
73
+ PepIconModule,
74
+ PepPageLayoutModule,
75
+ PepSideBarModule,
76
+ PepButtonModule,
77
+ PepCheckboxModule,
78
+ PepTextboxModule,
79
+ PepSelectModule,
80
+ PepSizeDetectorModule,
81
+ PepGroupButtonsModule,
82
+ PepSkeletonLoaderModule,
83
+ PepDraggableItemsModule,
84
+ PepGroupButtonsSettingsModule,
85
+ PepHideInModule,
86
+ PepLayoutModule,
87
+ PepLayoutEditorModule,
88
+ SectionEditorModule, PepLayoutModule] });
89
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: PepLayoutBuilderModule, decorators: [{
90
+ type: NgModule,
91
+ args: [{
92
+ declarations: [
93
+ PepLayoutBuilderComponent,
94
+ ],
95
+ imports: [
96
+ CommonModule,
97
+ DragDropModule,
98
+ // Material modules,
99
+ MatCommonModule,
100
+ MatTabsModule,
101
+ // ngx-lib modules
102
+ PepNgxLibModule,
103
+ PepDialogModule,
104
+ PepIconModule,
105
+ PepPageLayoutModule,
106
+ PepSideBarModule,
107
+ PepButtonModule,
108
+ PepCheckboxModule,
109
+ PepTextboxModule,
110
+ PepSelectModule,
111
+ PepSizeDetectorModule,
112
+ PepGroupButtonsModule,
113
+ PepSkeletonLoaderModule,
114
+ PepDraggableItemsModule,
115
+ PepGroupButtonsSettingsModule,
116
+ PepHideInModule,
117
+ PepLayoutModule,
118
+ PepLayoutEditorModule,
119
+ SectionEditorModule,
120
+ // SectionBlockModule
121
+ ],
122
+ exports: [
123
+ PepLayoutBuilderComponent,
124
+ PepLayoutModule,
125
+ ],
126
+ providers: [PepLayoutBuilderService]
127
+ }]
128
+ }], ctorParameters: function () { return [{ type: i1.PepIconRegistry }]; } });
129
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibGF5b3V0LWJ1aWxkZXIubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LWNvbXBvc2l0ZS1saWIvbGF5b3V0LWJ1aWxkZXIvbGF5b3V0LWJ1aWxkZXIubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUV4RCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDekQsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBRXZELE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUMxRCxPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSx1Q0FBdUMsQ0FBQztBQUM5RSxPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSx5Q0FBeUMsQ0FBQztBQUNsRixPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sZ0NBQWdDLENBQUM7QUFDakUsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLGdDQUFnQyxDQUFDO0FBQ2pFLE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLHVDQUF1QyxDQUFDO0FBQzlFLE9BQU8sRUFBRSxtQkFBbUIsRUFBRSxNQUFNLHFDQUFxQyxDQUFDO0FBQzFFLE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLGtDQUFrQyxDQUFDO0FBQ3BFLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxNQUFNLHlDQUF5QyxDQUFDO0FBQ2xGLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxNQUFNLGtDQUFrQyxDQUFDO0FBQ3JFLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxnQ0FBZ0MsQ0FBQztBQUNqRSxPQUFPLEVBQUUsZ0JBQWdC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Z01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IERyYWdEcm9wTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY2RrL2RyYWctZHJvcCc7XG5cbmltcG9ydCB7IE1hdENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2NvcmUnO1xuaW1wb3J0IHsgTWF0VGFic01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL3RhYnMnO1xuXG5pbXBvcnQgeyBQZXBOZ3hMaWJNb2R1bGUgfSBmcm9tICdAcGVwcGVyaS1hZGRvbnMvbmd4LWxpYic7XG5pbXBvcnQgeyBQZXBTaXplRGV0ZWN0b3JNb2R1bGUgfSBmcm9tICdAcGVwcGVyaS1hZGRvbnMvbmd4LWxpYi9zaXplLWRldGVjdG9yJztcbmltcG9ydCB7IFBlcFNrZWxldG9uTG9hZGVyTW9kdWxlIH0gZnJvbSAnQHBlcHBlcmktYWRkb25zL25neC1saWIvc2tlbGV0b24tbG9hZGVyJztcbmltcG9ydCB7IFBlcEJ1dHRvbk1vZHVsZSB9IGZyb20gJ0BwZXBwZXJpLWFkZG9ucy9uZ3gtbGliL2J1dHRvbic7XG5pbXBvcnQgeyBQZXBEaWFsb2dNb2R1bGUgfSBmcm9tICdAcGVwcGVyaS1hZGRvbnMvbmd4LWxpYi9kaWFsb2cnO1xuaW1wb3J0IHsgUGVwR3JvdXBCdXR0b25zTW9kdWxlIH0gZnJvbSAnQHBlcHBlcmktYWRkb25zL25neC1saWIvZ3JvdXAtYnV0dG9ucyc7XG5pbXBvcnQgeyBQZXBQYWdlTGF5b3V0TW9kdWxlIH0gZnJvbSAnQHBlcHBlcmktYWRkb25zL25neC1saWIvcGFnZS1sYXlvdXQnO1xuaW1wb3J0IHsgUGVwU2lkZUJhck1vZHVsZSB9IGZyb20gJ0BwZXBwZXJpLWFkZG9ucy9uZ3gtbGliL3NpZGUtYmFyJztcbmltcG9ydCB7IFBlcERyYWdnYWJsZUl0ZW1zTW9kdWxlIH0gZnJvbSAnQHBlcHBlcmktYWRkb25zL25neC1saWIvZHJhZ2dhYmxlLWl0ZW1zJztcbmltcG9ydCB7IFBlcENoZWNrYm94TW9kdWxlIH0gZnJvbSAnQHBlcHBlcmktYWRkb25zL25neC1saWIvY2hlY2tib3gnO1xuaW1wb3J0IHsgUGVwU2VsZWN0TW9kdWxlIH0gZnJvbSAnQHBlcHBlcmktYWRkb25zL25neC1saWIvc2VsZWN0JztcbmltcG9ydCB7IFBlcFRleHRib3hNb2R1bGUgfSBmcm9tICdAcGVwcGVyaS1hZGRvbnMvbmd4LWxpYi90ZXh0Ym94JztcblxuaW1wb3J0IHsgUGVwR3JvdXBCdXR0b25zU2V0dGluZ3NNb2R1bGUgfSBmcm9tICdAcGVwcGVyaS1hZGRvbnMvbmd4LWNvbXBvc2l0ZS1saWIvZ3JvdXAtYnV0dG9ucy1zZXR0aW5ncyc7XG5cbmltcG9ydCB7IFBlcEhpZGVJbk1vZHVsZSB9IGZyb20gJy4vaGlkZS1pbi9oaWRlLWluLm1vZHVsZSc7XG5pbXBvcnQgeyBQZXBMYXlvdXRNb2R1bGUgfSBmcm9tICcuL2xheW91dC9sYXlvdXQubW9kdWxlJztcbmltcG9ydCB7IFBlcExheW91dEVkaXRvck1vZHVsZSB9IGZyb20gJy4vbGF5b3V0LWVkaXRvci9sYXlvdXQtZWRpdG9yLm1vZHVsZSc7XG5pbXBvcnQgeyBTZWN0aW9uRWRpdG9yTW9kdWxlIH0gZnJvbSAnLi9zZWN0aW9uLWVkaXRvci9zZWN0aW9uLWVkaXRvci5tb2R1bGUnO1xuXG5pbXBvcnQgeyBQZXBMYXlvdXRCdWlsZGVyU2VydmljZSB9IGZyb20gJy4vbGF5b3V0LWJ1aWxkZXIuc2VydmljZSc7XG5pbXBvcnQgeyBQZXBMYXlvdXRCdWlsZGVyQ29tcG9uZW50IH0gZnJvbSAnLi9sYXlvdXQtYnVpbGRlci5jb21wb25lbnQnO1xuXG4vLyBpbXBvcnQgeyBTZWN0aW9uQmxvY2tNb2R1bGUgfSBmcm9tICcuL2xheW91dC9zZWN0aW9uLWJsb2NrL3NlY3Rpb24tYmxvY2subW9kdWxlJztcblxuaW1wb3J0IHtcbiAgICBQZXBJY29uTW9kdWxlLFxuICAgIFBlcEljb25SZWdpc3RyeSxcbiAgICBwZXBJY29uRGV2aWNlRGVza3RvcCxcbiAgICBwZXBJY29uRGV2aWNlVGFibGV0LFxuICAgIHBlcEljb25EZXZpY2VNb2JpbGUsXG59IGZyb20gJ0BwZXBwZXJpLWFkZG9ucy9uZ3gtbGliL2ljb24nO1xuXG5ATmdNb2R1bGUoe1xuICAgIGRlY2xhcmF0aW9uczogW1xuICAgICAgICBQZXBMYXlvdXRCdWlsZGVyQ29tcG9uZW50LFxuICAgIF0sXG4gICAgaW1wb3J0czogW1xuICAgICAgICBDb21tb25Nb2R1bGUsXG4gICAgICAgIERyYWdEcm9wTW9kdWxlLFxuICAgICAgICAvLyBNYXRlcmlhbCBtb2R1bGVzLFxuICAgICAgICBNYXRDb21tb25Nb2R1bGUsXG4gICAgICAgIE1hdFRhYnNNb2R1bGUsXG4gICAgICAgIC8vIG5neC1saWIgbW9kdWxlc1xuICAgICAgICBQZXBOZ3hMaWJNb2R1bGUsXG4gICAgICAgIFBlcERpYWxvZ01vZHVsZSxcbiAgICAgICAgUGVwSWNvbk1vZHVsZSxcbiAgICAgICAgUGVwUGFnZUxheW91dE1vZHVsZSxcbiAgICAgICAgUGVwU2lkZUJhck1vZHVsZSxcbiAgICAgICAgUGVwQnV0dG9uTW9kdWxlLFxuICAgICAgICBQZXBDaGVja2JveE1vZHVsZSxcbiAgICAgICAgUGVwVGV4dGJveE1vZHVsZSxcbiAgICAgICAgUGVwU2VsZWN0TW9kdWxlLFxuICAgICAgICBQZXBTaXplRGV0ZWN0b3JNb2R1bGUsXG4gICAgICAgIFBlcEdyb3VwQnV0dG9uc01vZHVsZSxcbiAgICAgICAgUGVwU2tlbGV0b25Mb2FkZXJNb2R1bGUsXG4gICAgICAgIFBlcERyYWdnYWJsZUl0ZW1zTW9kdWxlLFxuICAgICAgICBQZXBHcm91cEJ1dHRvbnNTZXR0aW5nc01vZHVsZSxcbiAgICAgICAgUGVwSGlkZUluTW9kdWxlLFxuICAgICAgICBQZXBMYXlvdXRNb2R1bGUsXG4gICAgICAgIFBlcExheW91dEVkaXRvck1vZHVsZSxcbiAgICAgICAgU2VjdGlvbkVkaXRvck1vZHVsZSxcbiAgICAgICAgLy8gU2VjdGlvbkJsb2NrTW9kdWxlXG4gICAgXSxcbiAgICBleHBvcnRzOiBbXG4gICAgICAgIFBlcExheW91dEJ1aWxkZXJDb21wb25lbnQsXG4gICAgICAgIFBlcExheW91dE1vZHVsZSxcbiAgICBdLFxuICAgIHByb3ZpZGVyczogW1BlcExheW91dEJ1aWxkZXJTZXJ2aWNlXVxufSlcbmV4cG9ydCBjbGFzcyBQZXBMYXlvdXRCdWlsZGVyTW9kdWxlIHsgXG4gICAgY29uc3RydWN0b3IocHJpdmF0ZSBwZXBJY29uUmVnaXN0cnk6IFBlcEljb25SZWdpc3RyeSkge1xuICAgICAgICB0aGlzLnBlcEljb25SZWdpc3RyeS5yZWdpc3Rlckljb25zKFtcbiAgICAgICAgICAgIHBlcEljb25EZXZpY2VEZXNrdG9wLFxuICAgICAgICAgICAgcGVwSWNvbkRldmljZVRhYmxldCxcbiAgICAgICAgICAgIHBlcEljb25EZXZpY2VNb2JpbGUsXG4gICAgICAgIF0pO1xuICAgIH1cbn1cbiJdfQ==