@pepperi-addons/ngx-composite-lib 0.4.2-beta.64 → 0.4.2-beta.66

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.
@@ -11,7 +11,8 @@ export class PepLayoutBuilderService {
11
11
  this.translate = translate;
12
12
  this._defaultSectionTitle = '';
13
13
  this._editorsBreadCrumb = Array();
14
- this.isEditMode = false;
14
+ this._editMode = false;
15
+ this._editableState = false;
15
16
  // This subject is for the screen size change events.
16
17
  this._screenSizeSubject = new BehaviorSubject(PepScreenSizeType.XL);
17
18
  // This subject is for demostrate the container size (Usage only in edit mode).
@@ -41,8 +42,6 @@ export class PepLayoutBuilderService {
41
42
  // This subjects is for load the available blocks to drag into map for better performance.
42
43
  this._availableBlocksForDragMap = new Map();
43
44
  this._availableBlocksForDragMapSubject = new BehaviorSubject(this.availableBlocksForDragMap);
44
- // Indicates if the pages should run on offline mode.
45
- this.isOffline = false;
46
45
  //
47
46
  }
48
47
  set defaultSectionTitle(value) {
@@ -50,6 +49,16 @@ export class PepLayoutBuilderService {
50
49
  this._defaultSectionTitle = value;
51
50
  }
52
51
  }
52
+ get editMode() {
53
+ return this._editMode;
54
+ }
55
+ setEditMode(value) {
56
+ this._editMode = value;
57
+ this.setEditableState();
58
+ }
59
+ get editableState() {
60
+ return this._editableState;
61
+ }
53
62
  get screenSizeChange$() {
54
63
  return this._screenSizeSubject.asObservable().pipe(distinctUntilChanged());
55
64
  }
@@ -96,9 +105,12 @@ export class PepLayoutBuilderService {
96
105
  get availableBlocksForDragMapChange$() {
97
106
  return this._availableBlocksForDragMapSubject.asObservable();
98
107
  }
108
+ setEditableState() {
109
+ this._editableState = this.editMode && !this._previewModeSubject.getValue();
110
+ }
99
111
  notifyLayoutViewChange(layoutViewToUpdate) {
100
112
  if (layoutViewToUpdate) {
101
- if (this.isEditMode) {
113
+ if (this.editMode) {
102
114
  this.updateLayoutEditorProperties(layoutViewToUpdate);
103
115
  }
104
116
  // Update the layout for the view.
@@ -269,6 +281,7 @@ export class PepLayoutBuilderService {
269
281
  }
270
282
  notifyPreviewModeChange(value) {
271
283
  this._previewModeSubject.next(value);
284
+ this.setEditableState();
272
285
  }
273
286
  notifyLockScreen(value) {
274
287
  this._lockScreenSubject.next(value);
@@ -582,7 +595,7 @@ export class PepLayoutBuilderService {
582
595
  this._showSkeletonSubject.next(show);
583
596
  }
584
597
  loadLayoutBuilder(layoutView) {
585
- if (this.isEditMode) {
598
+ if (this.editMode) {
586
599
  // Load the layout editor.
587
600
  this.loadDefaultEditor(layoutView);
588
601
  // Set the columns gap of the sections.
@@ -602,4 +615,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.2", ngImpor
602
615
  providedIn: 'root',
603
616
  }]
604
617
  }], ctorParameters: function () { return [{ type: i1.TranslateService }]; } });
605
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"layout-builder.service.js","sourceRoot":"","sources":["../../../../projects/ngx-composite-lib/layout-builder/layout-builder.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from \"@angular/core\";\nimport { coerceNumberProperty } from \"@angular/cdk/coercion\";\nimport { CdkDragDrop, CdkDragEnd, CdkDragStart, copyArrayItem, moveItemInArray, transferArrayItem } from \"@angular/cdk/drag-drop\";\nimport { TranslateService } from \"@ngx-translate/core\";\nimport { PepAddonService, PepGuid, PepHttpService, PepScreenSizeType, PepSessionService, PepUtilitiesService } from \"@pepperi-addons/ngx-lib\";\nimport { IPepDraggableItem } from \"@pepperi-addons/ngx-lib/draggable-items\";\nimport { DataViewScreenSize, ScreenSizeDataConfiguration } from \"@pepperi-addons/papi-sdk\";\nimport { PepSnackBarData, PepSnackBarService } from \"@pepperi-addons/ngx-lib/snack-bar\";\nimport { Observable, BehaviorSubject, Subject } from 'rxjs';\nimport { debounceTime, distinctUntilChanged, filter } from 'rxjs/operators';\nimport { LayoutEditorType, IEditor, IPepLayoutBlockAddedEvent, ILayoutEditor, IPepLayoutSection, IPepLayoutSectionColumn, IPepLayoutView, ILayoutSectionEditor, PepLayoutSizeType, IPepLayoutBlockContainer } from \"./layout-builder.model\";\n\n@Injectable({\n    providedIn: 'root',\n})\nexport class PepLayoutBuilderService {\n    static readonly AVAILABLE_BLOCKS_CONTAINER_ID = 'availableBlocks';\n    static readonly MAIN_EDITOR_ID = 'main';\n\n    private _defaultSectionTitle = '';\n    set defaultSectionTitle(value: string) {\n        if (this._defaultSectionTitle === '') {\n            this._defaultSectionTitle = value;\n        }\n    }\n\n    private _editorsBreadCrumb = Array<IEditor>();\n\n    isEditMode: boolean = false;\n\n    // This subject is for the screen size change events.\n    private _screenSizeSubject: BehaviorSubject<PepScreenSizeType> = new BehaviorSubject<PepScreenSizeType>(PepScreenSizeType.XL);\n    get screenSizeChange$(): Observable<PepScreenSizeType> {\n        return this._screenSizeSubject.asObservable().pipe(distinctUntilChanged());\n    }\n\n    // This subject is for demostrate the container size (Usage only in edit mode).\n    private _screenWidthSubject: BehaviorSubject<string> = new BehaviorSubject<string>('100%');\n    get screenWidthChange$(): Observable<string> {\n        return this._screenWidthSubject.asObservable().pipe(distinctUntilChanged());\n    }\n\n    // This subject is for load the current editor (Usage only in edit mode).\n    private _editorSubject: BehaviorSubject<IEditor | null> = new BehaviorSubject<IEditor | null>(null);\n    get editorChange$(): Observable<IEditor | null> {\n        return this._editorSubject.asObservable().pipe(distinctUntilChanged());\n    }\n\n    // This is the sections columns drop list subject.\n    private _sectionsColumnsDropListSubject: BehaviorSubject<any[]> = new BehaviorSubject<any[]>([]);\n    get sectionsColumnsDropListChange$(): Observable<any[]> {\n        return this._sectionsColumnsDropListSubject.asObservable();\n    }\n\n    // This is the sections subject (a pare from the layout view object)\n    private _sectionsViewSubject: BehaviorSubject<IPepLayoutSection[]> = new BehaviorSubject<IPepLayoutSection[]>([]);\n    get sectionsChange$(): Observable<IPepLayoutSection[]> {\n        return this._sectionsViewSubject.asObservable();\n        // (prevSections, nextSections) => JSON.stringify(prevSections) === JSON.stringify(nextSections)));\n    }\n\n    // This subject is for layout view change.\n    private _layoutViewSubject: BehaviorSubject<IPepLayoutView | null> = new BehaviorSubject<IPepLayoutView | null>(null);\n    get layoutViewChange$(): Observable<IPepLayoutView | null> {\n        return this._layoutViewSubject.asObservable().pipe(filter(layout => !!layout));\n    }\n\n    // This subject is for edit mode when block is dragging now or not.\n    private _draggingBlockKey: BehaviorSubject<string> = new BehaviorSubject('');\n    get draggingBlockKey(): Observable<string> {\n        return this._draggingBlockKey.asObservable().pipe(distinctUntilChanged());\n    }\n\n    // This subject is for edit mode when section is dragging now or not.\n    private _draggingSectionKey: BehaviorSubject<string> = new BehaviorSubject('');\n    get draggingSectionKey(): Observable<string> {\n        return this._draggingSectionKey.asObservable().pipe(distinctUntilChanged());\n    }\n\n    // This subject is for lock or unlock the screen (Usage only in edit mode).\n    private _lockScreenSubject: BehaviorSubject<boolean> = new BehaviorSubject<boolean>(false);\n    get lockScreenChange$(): Observable<boolean> {\n        return this._lockScreenSubject.asObservable().pipe(distinctUntilChanged());\n    }\n\n    // This is for control the preview mode (for load the blocks with the CPI events) \n    private _previewModeSubject: BehaviorSubject<boolean> = new BehaviorSubject<boolean>(false);\n    get previewModeChange$(): Observable<boolean> {\n        return this._previewModeSubject.asObservable().pipe(distinctUntilChanged());\n    }\n\n    // This is for editor mode for block added.\n    private _blockAddedEventSubject = new BehaviorSubject<IPepLayoutBlockAddedEvent | null>(null);\n    get blockAddedEventSubject$(): Observable<IPepLayoutBlockAddedEvent | null> {\n        return this._blockAddedEventSubject.asObservable();\n    }\n    // This is for editor mode for blocks removed.\n    private _blocksRemovedEventSubject = new BehaviorSubject<string[]>([]);\n    get blocksRemovedEventSubject$(): Observable<string[]> {\n        return this._blocksRemovedEventSubject.asObservable();\n    }\n\n    // This subject is for skeleton.\n    private _showSkeletonSubject: BehaviorSubject<boolean> = new BehaviorSubject<boolean>(true);\n    get showSkeletonChange$(): Observable<boolean> {\n        return this._showSkeletonSubject.asObservable().pipe(distinctUntilChanged());\n    }\n    \n    // This subjects is for load the available blocks to drag into map for better performance.\n    private _availableBlocksForDragMap = new Map<string, IPepDraggableItem>();\n    get availableBlocksForDragMap(): ReadonlyMap<string, IPepDraggableItem> {\n        return this._availableBlocksForDragMap;\n    }\n    private _availableBlocksForDragMapSubject = new BehaviorSubject<ReadonlyMap<string, IPepDraggableItem>>(this.availableBlocksForDragMap);\n    get availableBlocksForDragMapChange$(): Observable<ReadonlyMap<string, IPepDraggableItem>> {\n        return this._availableBlocksForDragMapSubject.asObservable();\n    }\n\n    // Indicates if the pages should run on offline mode.\n    public isOffline: boolean = false;\n\n    constructor(\n        private translate: TranslateService,\n    ) {\n        //\n    }\n    \n    private notifyLayoutViewChange(layoutViewToUpdate: IPepLayoutView | null) {\n        if (layoutViewToUpdate) {\n            if (this.isEditMode) {\n                this.updateLayoutEditorProperties(layoutViewToUpdate);\n            }\n\n            // Update the layout for the view.\n            this._layoutViewSubject.next(layoutViewToUpdate);\n            \n            // Update the sections for the view.\n            this._sectionsViewSubject.next(layoutViewToUpdate?.Layout.Sections || []);\n        }\n    }\n\n    private notifyBlockAdded(blockAddedEventData: IPepLayoutBlockAddedEvent) {\n        // Notify that the block is added (to raise the event for the client).\n        this._blockAddedEventSubject.next(blockAddedEventData);\n    }\n\n    private notifyBlocksRemoved(keys: string[] | undefined) {\n        if (keys) {\n            // Notify that the blocks are removed (to raise the event for the client).\n            this._blocksRemovedEventSubject.next(keys);\n        }\n    }\n\n    private notifyEditorChange(editor: IEditor | null) {\n        this._editorSubject.next(editor);\n    }\n\n    private notifyAvailableBlocksForDragMapChange() {\n        this._availableBlocksForDragMapSubject.next(this.availableBlocksForDragMap);\n    }\n\n    private updateLayoutEditorProperties(layoutView: IPepLayoutView) {\n        if (this._editorsBreadCrumb[0]) {\n            const layoutEditor: ILayoutEditor = {\n                // pageName: page?.Name,\n                // pageDescription: page?.Description,\n                // parameters: page.Parameters,\n                // onLoadFlow: page.OnLoadFlow,\n                // onChangeFlow: page.OnChangeFlow,\n                maxWidth: layoutView?.Layout.MaxWidth || 0,\n                verticalSpacing: layoutView?.Layout.VerticalSpacing,\n                horizontalSpacing: layoutView?.Layout.HorizontalSpacing,\n                sectionsGap: layoutView?.Layout.SectionsGap,\n                columnsGap: layoutView?.Layout.ColumnsGap,\n                // roundedCorners: layoutView?.layout.\n            };\n            \n            this._editorsBreadCrumb[0].hostObject = layoutEditor;\n        }\n    }\n\n    private loadDefaultEditor(layoutView: IPepLayoutView) {\n        this._editorsBreadCrumb = new Array<IEditor>();\n\n        if (layoutView) {\n            this._editorsBreadCrumb.push({\n                id: PepLayoutBuilderService.MAIN_EDITOR_ID,\n                type : 'layout-builder',\n                title: layoutView.Title || this.translate.instant('LAYOUT_BUILDER.DEFAULT_TITLE'),\n                // hostObject: {} // Updates in updateLayoutEditorProperties function above.\n            });\n\n            this.updateLayoutEditorProperties(layoutView);\n            this.notifyEditorChange(this._editorsBreadCrumb[0]);\n        } else {\n            this.notifyEditorChange(null);\n        }\n    }\n\n    private changeCurrentEditor() {\n        if (this._editorsBreadCrumb.length > 0) {\n            this.notifyEditorChange(this._editorsBreadCrumb[this._editorsBreadCrumb.length - 1]);\n        }\n    }\n\n    private getEditor(editorType: LayoutEditorType, id: string): IEditor | null {\n        // Build editor object.\n        let editor: IEditor | null = null;\n\n        if (editorType === 'section') {\n            editor = this.getSectionEditor(id);\n        } else if (editorType === 'block') {\n            editor = this.getBlockEditor(id);\n        }\n\n        return editor;\n    }\n\n    private getSectionEditorTitle(section: IPepLayoutSection, sectionIndex: number): string {\n        return section.Name || `${this._defaultSectionTitle} ${sectionIndex + 1}`;\n    }\n\n    private getSectionEditor(sectionId: string): IEditor | null {\n        const layoutView = this._layoutViewSubject.getValue();\n        const sections = layoutView?.Layout.Sections || [];\n        const sectionIndex = sections.findIndex(section => section.Key === sectionId);\n\n        if (sectionIndex >= 0) {\n            let section = sections[sectionIndex];\n            const sectionEditor: ILayoutSectionEditor = {\n                id: section.Key,\n                sectionName: section.Name || '',\n                split: section.Split || undefined,\n                height: section.Height || 0,\n                collapseOnTablet: section.CollapseOnTablet ?? false,\n                fillHeight: section.FillHeight ?? false\n            }\n\n            return {\n                id: sectionId,\n                type: 'section',\n                title: this.getSectionEditorTitle(section, sectionIndex),\n                hostObject: sectionEditor\n            }\n        } else {\n            return null;\n        }\n    }\n\n    private getSectionColumnByIdForEditor(sectionColumnId: string): IPepLayoutSectionColumn | null {\n        let currentColumn = null;\n\n        // Get the section and column array by the pattern of the section column key.\n        const sectionColumnPatternSeparator = this.getSectionColumnKey();\n        const sectionColumnArr = sectionColumnId.split(sectionColumnPatternSeparator);\n\n        if (sectionColumnArr.length === 2) {\n            const layoutView = this._layoutViewSubject.getValue();\n            const sections = layoutView?.Layout.Sections || [];\n            \n            // Get the section id to get the section index.\n            const sectionId = sectionColumnArr[0];\n            const sectionIndex = sections.findIndex(section => section.Key === sectionId);\n            // Get the column index.\n            const columnIndex = coerceNumberProperty(sectionColumnArr[1], -1);\n            if (sectionIndex >= 0 && columnIndex >= 0) {\n                currentColumn = sections[sectionIndex].Columns[columnIndex];\n            }\n        }\n\n        return currentColumn;\n    }\n\n    private setSectionsColumnsGap(layoutView: IPepLayoutView) {\n        if (layoutView?.Layout?.Sections) {\n            for (let index = 0; index < layoutView.Layout.Sections.length; index++) {\n                const section = layoutView.Layout.Sections[index];\n                section.ColumnsGap = layoutView.Layout.ColumnsGap;\n            }\n        }\n    }\n\n    private getCssScreenWidh(screenType: DataViewScreenSize): string {\n        let widthToSet = '100%';\n\n        if (screenType === 'Tablet') {\n            widthToSet = '720';\n        } else if (screenType === 'Phablet') {\n            widthToSet = '360';\n        }\n\n        return widthToSet;\n    }\n    \n    private getBlockContainerByBlockKey(blockKey: string): IPepLayoutBlockContainer | undefined {\n        let blockContainerToFind: IPepLayoutBlockContainer | undefined = undefined;\n\n        const layoutView = this._layoutViewSubject.getValue();\n        const sections = layoutView?.Layout.Sections || [];\n        \n        for (let sectionIndex = 0; sectionIndex < sections.length; sectionIndex++) {\n            const section = sections[sectionIndex];\n\n            // Get the block container.\n            const columnIndex = section.Columns.findIndex(column => column.BlockContainer?.BlockKey === blockKey);\n            if (columnIndex > -1) {\n                blockContainerToFind = section.Columns[columnIndex].BlockContainer\n                break;\n            }\n        }\n\n        return blockContainerToFind;\n    }\n\n    private changeCursorOnDragStart() {\n        document.body.classList.add('inheritCursors');\n        document.body.style.cursor = 'grabbing';\n    }\n\n    private changeCursorOnDragEnd() {\n        document.body.classList.remove('inheritCursors');\n        document.body.style.cursor = 'unset';\n    }\n\n    /***********************************************************************************************/\n    /*                                  Public functions\n    /***********************************************************************************************/\n\n    notifySectionsColumnsDropListChange(sectionsColumnsDropList: any[]) {\n        this._sectionsColumnsDropListSubject.next(sectionsColumnsDropList);\n    }\n\n    notifyPreviewModeChange(value: boolean) {\n        this._previewModeSubject.next(value);\n    }\n\n    notifyLockScreen(value: boolean) {\n        this._lockScreenSubject.next(value);\n    }\n\n    setAvailableBlocksToDrag(availableBlocksForDrag: Array<IPepDraggableItem>) {\n        this._availableBlocksForDragMap.clear();\n        availableBlocksForDrag.forEach(block => {\n            this._availableBlocksForDragMap.set(block.data.key, block);\n        });\n\n        this.notifyAvailableBlocksForDragMapChange();\n    }\n\n    getBlockEditor(blockKey: string): IEditor {\n        const blockContainer = this.getBlockContainerByBlockKey(blockKey);\n        const defaultTitle = this.translate.instant('LAYOUT_BUILDER.NO_TITLE')\n        let blockTitle = defaultTitle;\n\n        if (blockContainer) {\n            blockTitle = this.availableBlocksForDragMap?.get(blockContainer?.DraggableItemKey)?.title || defaultTitle;\n        }\n \n        return {\n            id: blockKey,\n            type: 'block',\n            title: blockTitle,\n            // remoteModuleOptions: remoteLoaderOptions,\n            hostObject: {} // JSON.parse(JSON.stringify(hostObject))\n        }\n    }\n\n    getScreenType(size: PepScreenSizeType): DataViewScreenSize {\n        const screenType: DataViewScreenSize =\n            size < PepScreenSizeType.MD ? 'Landscape' :\n            (size === PepScreenSizeType.MD || size === PepScreenSizeType.SM ? 'Tablet' : 'Phablet');\n\n        return screenType;\n    }\n\n    getSectionColumnKey(sectionKey: string = '', index: string = '') {\n        return `${sectionKey}_column_${index}`;\n    }\n\n    getIsHidden(hideIn: DataViewScreenSize[] | undefined, currentScreenType: DataViewScreenSize) {\n        return (hideIn && hideIn?.length > 0) ? hideIn.some(hi => hi === currentScreenType) : false;\n    }\n\n    navigateToEditor(editorType: LayoutEditorType, id: string): boolean {\n        let success = false;\n\n        // Cannot navigate into 'layout-builder' because this is first and const in the editorsBreadCrumbs.\n        if (editorType !== 'layout-builder' && id?.length > 0) {\n            // Check which editor we have now\n            const currentEditor = this._editorsBreadCrumb[this._editorsBreadCrumb.length - 1];\n\n            // Only if it's another editor.\n            if(currentEditor.id !== id) {\n                if (currentEditor.type !== 'layout-builder') {\n                    // Always pop the last and insert the current.\n                    this._editorsBreadCrumb.pop();\n                }\n\n                let editor = this.getEditor(editorType, id);\n\n                if (editor) {\n                    this._editorsBreadCrumb.push(editor);\n                    this.changeCurrentEditor();\n                    success = true;\n                } else {\n                    success = false;\n                }\n            }\n        }\n\n        return success;\n    }\n\n    navigateBackFromEditor() {\n        // Keep the layout builder editor.\n        if (this._editorsBreadCrumb.length > 1) {\n            // Maybe we want to compare the last editor for validation ?\n            const lastEditor = this._editorsBreadCrumb.pop();\n            this.changeCurrentEditor();\n        }\n    }\n\n    updateLayoutFromEditor(editorData: ILayoutEditor) {\n        const layoutView = this._layoutViewSubject.getValue();\n\n        if (layoutView) {\n            layoutView.Layout.MaxWidth = editorData.maxWidth;\n            layoutView.Layout.HorizontalSpacing = editorData.horizontalSpacing;\n            layoutView.Layout.VerticalSpacing = editorData.verticalSpacing;\n            layoutView.Layout.SectionsGap = editorData.sectionsGap;\n            layoutView.Layout.ColumnsGap = editorData.columnsGap;\n            // layoutView.layout.RoundedCorners = editorData.roundedCorners;\n\n            this.setSectionsColumnsGap(layoutView);\n            \n            this.notifyLayoutViewChange(layoutView);\n        }\n    }\n    \n    updateSectionFromEditor(sectionData: ILayoutSectionEditor) {\n        const layoutView = this._layoutViewSubject.getValue();\n        const sections = layoutView?.Layout.Sections || [];\n        const sectionIndex = sections.findIndex(section => section.Key === sectionData.id);\n\n        // Update section details.\n        if (sectionIndex >= 0) {\n            const blocksIdsToRemove = [];\n\n            const currentSection = sections[sectionIndex];\n            currentSection.Name = sectionData.sectionName;\n            currentSection.Split = sectionData.split;\n            currentSection.Height = sectionData.height;\n            currentSection.CollapseOnTablet = sectionData.collapseOnTablet;\n            currentSection.FillHeight = sectionData.fillHeight;\n\n            // Get the new columns number from currentSection.Split, if its undefined put a default 1.\n            const newColumnsLength = currentSection.Split?.split(' ').length || 1;\n            if (newColumnsLength > currentSection.Columns.length) {\n                while (newColumnsLength > currentSection.Columns.length) {\n                    currentSection.Columns.push({});\n                }\n            } else if (newColumnsLength < currentSection.Columns.length) {\n                while (newColumnsLength < currentSection.Columns.length) {\n                    const colunm = currentSection.Columns.pop();\n                    // If there is block in this column delete it.\n                    if (colunm && colunm.BlockContainer) {\n                        blocksIdsToRemove.push(colunm.BlockContainer.BlockKey);\n                    }\n                }\n            }\n\n            // Update editor title\n            const currentEditor = this._editorSubject.getValue();\n            if (currentEditor && currentEditor.type === 'section' && currentEditor.id === currentSection.Key) {\n                currentEditor.title = this.getSectionEditorTitle(currentSection, sectionIndex);\n                this.notifyEditorChange(currentEditor);\n            }\n\n            // Update sections change.\n            this.notifyLayoutViewChange(layoutView);\n\n            // If there are blocks to remove, notify the blocks removed.\n            if (blocksIdsToRemove.length > 0) {\n                this.notifyBlocksRemoved(blocksIdsToRemove);\n            }\n        }\n    }\n\n    addSection(section: IPepLayoutSection | null = null) {\n        // Create new section\n        if (!section) {\n            section = {\n                Key: PepGuid.newGuid(),\n                Columns: [{}], // Add empty section column\n                Hide: []\n            }\n        }\n\n        // Add the new section to layout view.\n        const layoutView = this._layoutViewSubject.getValue();\n        const sections = layoutView?.Layout.Sections || [];\n        sections.push(section);\n        this.notifyLayoutViewChange(layoutView);\n    }\n\n    removeSection(sectionId: string) {\n        const layoutView = this._layoutViewSubject.getValue();\n        const sections = layoutView?.Layout.Sections || [];\n        const index = sections.findIndex(section => section.Key === sectionId);\n        if (index > -1) {\n            // Get the blocks id's to remove.\n            const blocksIdsToRemove: any = sections[index].Columns.map(column => column?.BlockContainer?.BlockKey);\n\n            // Remove section.\n            sections.splice(index, 1);\n            this.notifyLayoutViewChange(layoutView);\n\n            // If there are blocks to remove, notify the blocks removed.\n            if (blocksIdsToRemove.length > 0) {\n                this.notifyBlocksRemoved(blocksIdsToRemove)\n            }\n        }\n    }\n\n    hideSection(sectionId: string, hideIn: DataViewScreenSize[]) {\n        const layoutView = this._layoutViewSubject.getValue();\n        const sections = layoutView?.Layout.Sections || [];\n        const index = sections.findIndex(section => section.Key === sectionId);\n        if (index > -1) {\n            sections[index].Hide = hideIn;\n            this.notifyLayoutViewChange(layoutView);\n        }\n    }\n\n    onSectionDropped(event: CdkDragDrop<any[]>) {\n        const layoutView = this._layoutViewSubject.getValue();\n        const sections = layoutView?.Layout.Sections || [];\n        moveItemInArray(sections, event.previousIndex, event.currentIndex);\n        this.notifyLayoutViewChange(layoutView);\n    }\n\n    onSectionDragStart(event: CdkDragStart) {\n        this.changeCursorOnDragStart();\n        this._draggingSectionKey.next(event.source.data);\n    }\n\n    onSectionDragEnd(event: CdkDragEnd) {\n        this.changeCursorOnDragEnd();\n        this._draggingSectionKey.next('');\n    }\n\n    removeBlockFromSection(blockId: string) {\n        let blockRemoved = false;\n\n        // Remove the block from section column.\n        const layoutView = this._layoutViewSubject.getValue();\n        const sections = layoutView?.Layout.Sections || [];\n        \n        for (let sectionIndex = 0; sectionIndex < sections.length; sectionIndex++) {\n            const section = sections[sectionIndex];\n\n            // Remove the block container.\n            const columnIndex = section.Columns.findIndex(column => column.BlockContainer?.BlockKey === blockId);\n            if (columnIndex > -1) {\n                delete section.Columns[columnIndex].BlockContainer;\n                this.notifyLayoutViewChange(layoutView);\n                blockRemoved = true;\n\n                break;\n            }\n        }\n\n        // If the block was removed, notify the block removed.\n        if (blockRemoved) {\n            this.notifyBlocksRemoved([blockId]);\n        }\n    }\n\n    hideBlock(sectionId: string, blockId: string, hideIn: DataViewScreenSize[]) {\n        const layoutView = this._layoutViewSubject.getValue();\n        const sections = layoutView?.Layout.Sections || [];\n        \n        const index = sections.findIndex(section => section.Key === sectionId);\n        if (index > -1) {\n            const columnIndex = sections[index].Columns.findIndex(column => column.BlockContainer?.BlockKey === blockId);\n            if (columnIndex > -1) {\n                const blockContainer = sections[index].Columns[columnIndex].BlockContainer;\n                if (blockContainer) {\n                    blockContainer.Hide = hideIn;\n                    this.notifyLayoutViewChange(layoutView);\n                }\n            }\n        }\n    }\n\n    onBlockDropped(event: CdkDragDrop<IPepLayoutSectionColumn, any, any>, sectionId: string) {\n        const layoutView = this._layoutViewSubject.getValue();\n\n        if (event.previousContainer.id === PepLayoutBuilderService.AVAILABLE_BLOCKS_CONTAINER_ID) {\n            // Get the block relation (previousContainer.data is IPepDraggableItem and inside we have AvailableBlock object).\n            const draggableItem: IPepDraggableItem = event.previousContainer.data[event.previousIndex] as IPepDraggableItem;\n\n            if (draggableItem) {\n                // lock the screen untill the editor will be loaded.\n                // this._lockScreenSubject.next(true);\n\n                // Get the column.\n                const currentColumn = this.getSectionColumnByIdForEditor(event.container.id);\n\n                // Set the block key in the section block only if there is a blank column.\n                if (currentColumn && !currentColumn.BlockContainer) {\n                     // Generate the block uuid.\n                    const blockKey = PepGuid.newGuid();\n\n                    currentColumn.BlockContainer = {\n                        BlockKey: blockKey,\n                        DraggableItemKey: draggableItem.data.key,\n                    };\n\n                    // Here we update the layout view cause the layout is updated.\n                    this.notifyLayoutViewChange(layoutView);\n\n                    // Raise block added event.\n                    const blockAddedEventData: IPepLayoutBlockAddedEvent = {\n                        BlockKey: blockKey,\n                        DraggableItem: draggableItem,\n                    }\n                    this.notifyBlockAdded(blockAddedEventData);\n                }\n            } else {\n                console.log(\"draggableItem is not a IPepDraggableItem type\");\n            }\n        } else {\n            // If the block moved between columns in the same section or between different sections but not in the same column.\n            if (event.container.id !== event.previousContainer.id) {\n                // Get the column.\n                const currentColumn = this.getSectionColumnByIdForEditor(event.container.id);\n                // Get the previous column.\n                const previuosColumn = this.getSectionColumnByIdForEditor(event.previousContainer.id);\n\n                if (currentColumn && previuosColumn) {\n                    currentColumn.BlockContainer = previuosColumn.BlockContainer;\n                    delete previuosColumn.BlockContainer;\n                    this.notifyLayoutViewChange(layoutView);\n                }\n            }\n        }\n    }\n\n    onBlockDragStart(event: CdkDragStart) {\n        this.changeCursorOnDragStart();\n        // Take the block key if exist, else take the available block key (relation key).\n        const blockKey = event.source.data?.BlockKey || event.source.data?.Key;\n        this._draggingBlockKey.next(blockKey);\n    }\n\n    onBlockDragEnd(event: CdkDragEnd) {\n        this.changeCursorOnDragEnd();\n        this._draggingBlockKey.next('');\n    }\n    \n    doesColumnContainBlock(sectionId: string, columnIndex: number): boolean {\n        let res = false;\n        const layoutView = this._layoutViewSubject.getValue();\n        const section = layoutView?.Layout.Sections.find(section => section.Key === sectionId);\n\n        if (section && columnIndex >= 0 && section.Columns.length > columnIndex) {\n            res = !!section.Columns[columnIndex].BlockContainer;\n        }\n\n        return res;\n    }\n\n    setScreenWidth(screenType: DataViewScreenSize) {\n        const value = this.getCssScreenWidh(screenType)\n\n        let width = coerceNumberProperty(value, 0);\n        if (width === 0) {\n            this._screenWidthSubject.next('100%');\n            this._screenSizeSubject.next(PepScreenSizeType.XL);\n        } else {\n            this._screenWidthSubject.next(`${width}px`);\n\n            // Change the size according the width.\n            if (width >= 1920) {\n                this._screenSizeSubject.next(PepScreenSizeType.XL);\n            } else if (width >= 1280 && width < 1920) {\n                this._screenSizeSubject.next(PepScreenSizeType.LG);\n            } else if (width >= 960 && width < 1280) {\n                this._screenSizeSubject.next(PepScreenSizeType.MD);\n            } else if (width >= 600 && width < 960) {\n                this._screenSizeSubject.next(PepScreenSizeType.SM);\n            } else if (width < 600) {\n                this._screenSizeSubject.next(PepScreenSizeType.XS);\n            }\n        }\n    }\n\n    showSkeleton(show: boolean) {\n        this._showSkeletonSubject.next(show);\n    }\n    \n    loadLayoutBuilder(layoutView: IPepLayoutView): void {\n        if (this.isEditMode) {\n            // Load the layout editor.\n            this.loadDefaultEditor(layoutView);\n\n            // Set the columns gap of the sections.\n            this.setSectionsColumnsGap(layoutView);\n        }\n\n        // Load only the layout view.\n        this.notifyLayoutViewChange(layoutView);\n    }\n}\n"]}
618
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"layout-builder.service.js","sourceRoot":"","sources":["../../../../projects/ngx-composite-lib/layout-builder/layout-builder.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from \"@angular/core\";\nimport { coerceNumberProperty } from \"@angular/cdk/coercion\";\nimport { CdkDragDrop, CdkDragEnd, CdkDragStart, copyArrayItem, moveItemInArray, transferArrayItem } from \"@angular/cdk/drag-drop\";\nimport { TranslateService } from \"@ngx-translate/core\";\nimport { PepAddonService, PepGuid, PepHttpService, PepScreenSizeType, PepSessionService, PepUtilitiesService } from \"@pepperi-addons/ngx-lib\";\nimport { IPepDraggableItem } from \"@pepperi-addons/ngx-lib/draggable-items\";\nimport { DataViewScreenSize, ScreenSizeDataConfiguration } from \"@pepperi-addons/papi-sdk\";\nimport { PepSnackBarData, PepSnackBarService } from \"@pepperi-addons/ngx-lib/snack-bar\";\nimport { Observable, BehaviorSubject, Subject } from 'rxjs';\nimport { debounceTime, distinctUntilChanged, filter } from 'rxjs/operators';\nimport { LayoutEditorType, IEditor, IPepLayoutBlockAddedEvent, ILayoutEditor, IPepLayoutSection, IPepLayoutSectionColumn, IPepLayoutView, ILayoutSectionEditor, PepLayoutSizeType, IPepLayoutBlockContainer } from \"./layout-builder.model\";\n\n@Injectable({\n    providedIn: 'root',\n})\nexport class PepLayoutBuilderService {\n    static readonly AVAILABLE_BLOCKS_CONTAINER_ID = 'availableBlocks';\n    static readonly MAIN_EDITOR_ID = 'main';\n\n    private _defaultSectionTitle = '';\n    set defaultSectionTitle(value: string) {\n        if (this._defaultSectionTitle === '') {\n            this._defaultSectionTitle = value;\n        }\n    }\n\n    private _editorsBreadCrumb = Array<IEditor>();\n\n    private _editMode: boolean = false;\n    get editMode(): boolean {\n        return this._editMode;\n    }\n    setEditMode(value: boolean) {\n        this._editMode = value;\n        this.setEditableState();\n    }\n\n    private _editableState: boolean = false;\n    get editableState(): boolean {\n        return this._editableState;\n    }\n\n    // This subject is for the screen size change events.\n    protected _screenSizeSubject: BehaviorSubject<PepScreenSizeType> = new BehaviorSubject<PepScreenSizeType>(PepScreenSizeType.XL);\n    get screenSizeChange$(): Observable<PepScreenSizeType> {\n        return this._screenSizeSubject.asObservable().pipe(distinctUntilChanged());\n    }\n\n    // This subject is for demostrate the container size (Usage only in edit mode).\n    private _screenWidthSubject: BehaviorSubject<string> = new BehaviorSubject<string>('100%');\n    get screenWidthChange$(): Observable<string> {\n        return this._screenWidthSubject.asObservable().pipe(distinctUntilChanged());\n    }\n\n    // This subject is for load the current editor (Usage only in edit mode).\n    private _editorSubject: BehaviorSubject<IEditor | null> = new BehaviorSubject<IEditor | null>(null);\n    get editorChange$(): Observable<IEditor | null> {\n        return this._editorSubject.asObservable().pipe(distinctUntilChanged());\n    }\n\n    // This is the sections columns drop list subject.\n    private _sectionsColumnsDropListSubject: BehaviorSubject<any[]> = new BehaviorSubject<any[]>([]);\n    get sectionsColumnsDropListChange$(): Observable<any[]> {\n        return this._sectionsColumnsDropListSubject.asObservable();\n    }\n\n    // This is the sections subject (a pare from the layout view object)\n    private _sectionsViewSubject: BehaviorSubject<IPepLayoutSection[]> = new BehaviorSubject<IPepLayoutSection[]>([]);\n    get sectionsChange$(): Observable<IPepLayoutSection[]> {\n        return this._sectionsViewSubject.asObservable();\n        // (prevSections, nextSections) => JSON.stringify(prevSections) === JSON.stringify(nextSections)));\n    }\n\n    // This subject is for layout view change.\n    private _layoutViewSubject: BehaviorSubject<IPepLayoutView | null> = new BehaviorSubject<IPepLayoutView | null>(null);\n    get layoutViewChange$(): Observable<IPepLayoutView | null> {\n        return this._layoutViewSubject.asObservable().pipe(filter(layout => !!layout));\n    }\n\n    // This subject is for edit mode when block is dragging now or not.\n    private _draggingBlockKey: BehaviorSubject<string> = new BehaviorSubject('');\n    get draggingBlockKey(): Observable<string> {\n        return this._draggingBlockKey.asObservable().pipe(distinctUntilChanged());\n    }\n\n    // This subject is for edit mode when section is dragging now or not.\n    private _draggingSectionKey: BehaviorSubject<string> = new BehaviorSubject('');\n    get draggingSectionKey(): Observable<string> {\n        return this._draggingSectionKey.asObservable().pipe(distinctUntilChanged());\n    }\n\n    // This subject is for lock or unlock the screen (Usage only in edit mode).\n    private _lockScreenSubject: BehaviorSubject<boolean> = new BehaviorSubject<boolean>(false);\n    get lockScreenChange$(): Observable<boolean> {\n        return this._lockScreenSubject.asObservable().pipe(distinctUntilChanged());\n    }\n\n    // This is for control the preview mode (for load the blocks with the CPI events) \n    private _previewModeSubject: BehaviorSubject<boolean> = new BehaviorSubject<boolean>(false);\n    get previewModeChange$(): Observable<boolean> {\n        return this._previewModeSubject.asObservable().pipe(distinctUntilChanged());\n    }\n\n    // This is for editor mode for block added.\n    private _blockAddedEventSubject = new BehaviorSubject<IPepLayoutBlockAddedEvent | null>(null);\n    get blockAddedEventSubject$(): Observable<IPepLayoutBlockAddedEvent | null> {\n        return this._blockAddedEventSubject.asObservable();\n    }\n    // This is for editor mode for blocks removed.\n    private _blocksRemovedEventSubject = new BehaviorSubject<string[]>([]);\n    get blocksRemovedEventSubject$(): Observable<string[]> {\n        return this._blocksRemovedEventSubject.asObservable();\n    }\n\n    // This subject is for skeleton.\n    private _showSkeletonSubject: BehaviorSubject<boolean> = new BehaviorSubject<boolean>(true);\n    get showSkeletonChange$(): Observable<boolean> {\n        return this._showSkeletonSubject.asObservable().pipe(distinctUntilChanged());\n    }\n    \n    // This subjects is for load the available blocks to drag into map for better performance.\n    private _availableBlocksForDragMap = new Map<string, IPepDraggableItem>();\n    get availableBlocksForDragMap(): ReadonlyMap<string, IPepDraggableItem> {\n        return this._availableBlocksForDragMap;\n    }\n    private _availableBlocksForDragMapSubject = new BehaviorSubject<ReadonlyMap<string, IPepDraggableItem>>(this.availableBlocksForDragMap);\n    get availableBlocksForDragMapChange$(): Observable<ReadonlyMap<string, IPepDraggableItem>> {\n        return this._availableBlocksForDragMapSubject.asObservable();\n    }\n\n    constructor(\n        protected translate: TranslateService,\n    ) {\n        //\n    }\n    \n    private setEditableState() {\n        this._editableState = this.editMode && !this._previewModeSubject.getValue();\n    }\n\n    private notifyLayoutViewChange(layoutViewToUpdate: IPepLayoutView | null) {\n        if (layoutViewToUpdate) {\n            if (this.editMode) {\n                this.updateLayoutEditorProperties(layoutViewToUpdate);\n            }\n\n            // Update the layout for the view.\n            this._layoutViewSubject.next(layoutViewToUpdate);\n            \n            // Update the sections for the view.\n            this._sectionsViewSubject.next(layoutViewToUpdate?.Layout.Sections || []);\n        }\n    }\n\n    private notifyBlockAdded(blockAddedEventData: IPepLayoutBlockAddedEvent) {\n        // Notify that the block is added (to raise the event for the client).\n        this._blockAddedEventSubject.next(blockAddedEventData);\n    }\n\n    private notifyBlocksRemoved(keys: string[] | undefined) {\n        if (keys) {\n            // Notify that the blocks are removed (to raise the event for the client).\n            this._blocksRemovedEventSubject.next(keys);\n        }\n    }\n\n    private notifyEditorChange(editor: IEditor | null) {\n        this._editorSubject.next(editor);\n    }\n\n    private notifyAvailableBlocksForDragMapChange() {\n        this._availableBlocksForDragMapSubject.next(this.availableBlocksForDragMap);\n    }\n\n    private updateLayoutEditorProperties(layoutView: IPepLayoutView) {\n        if (this._editorsBreadCrumb[0]) {\n            const layoutEditor: ILayoutEditor = {\n                // pageName: page?.Name,\n                // pageDescription: page?.Description,\n                // parameters: page.Parameters,\n                // onLoadFlow: page.OnLoadFlow,\n                // onChangeFlow: page.OnChangeFlow,\n                maxWidth: layoutView?.Layout.MaxWidth || 0,\n                verticalSpacing: layoutView?.Layout.VerticalSpacing,\n                horizontalSpacing: layoutView?.Layout.HorizontalSpacing,\n                sectionsGap: layoutView?.Layout.SectionsGap,\n                columnsGap: layoutView?.Layout.ColumnsGap,\n                // roundedCorners: layoutView?.layout.\n            };\n            \n            this._editorsBreadCrumb[0].hostObject = layoutEditor;\n        }\n    }\n\n    private loadDefaultEditor(layoutView: IPepLayoutView) {\n        this._editorsBreadCrumb = new Array<IEditor>();\n\n        if (layoutView) {\n            this._editorsBreadCrumb.push({\n                id: PepLayoutBuilderService.MAIN_EDITOR_ID,\n                type : 'layout-builder',\n                title: layoutView.Title || this.translate.instant('LAYOUT_BUILDER.DEFAULT_TITLE'),\n                // hostObject: {} // Updates in updateLayoutEditorProperties function above.\n            });\n\n            this.updateLayoutEditorProperties(layoutView);\n            this.notifyEditorChange(this._editorsBreadCrumb[0]);\n        } else {\n            this.notifyEditorChange(null);\n        }\n    }\n\n    private changeCurrentEditor() {\n        if (this._editorsBreadCrumb.length > 0) {\n            this.notifyEditorChange(this._editorsBreadCrumb[this._editorsBreadCrumb.length - 1]);\n        }\n    }\n\n    private getEditor(editorType: LayoutEditorType, id: string): IEditor | null {\n        // Build editor object.\n        let editor: IEditor | null = null;\n\n        if (editorType === 'section') {\n            editor = this.getSectionEditor(id);\n        } else if (editorType === 'block') {\n            editor = this.getBlockEditor(id);\n        }\n\n        return editor;\n    }\n\n    private getSectionEditorTitle(section: IPepLayoutSection, sectionIndex: number): string {\n        return section.Name || `${this._defaultSectionTitle} ${sectionIndex + 1}`;\n    }\n\n    private getSectionEditor(sectionId: string): IEditor | null {\n        const layoutView = this._layoutViewSubject.getValue();\n        const sections = layoutView?.Layout.Sections || [];\n        const sectionIndex = sections.findIndex(section => section.Key === sectionId);\n\n        if (sectionIndex >= 0) {\n            let section = sections[sectionIndex];\n            const sectionEditor: ILayoutSectionEditor = {\n                id: section.Key,\n                sectionName: section.Name || '',\n                split: section.Split || undefined,\n                height: section.Height || 0,\n                collapseOnTablet: section.CollapseOnTablet ?? false,\n                fillHeight: section.FillHeight ?? false\n            }\n\n            return {\n                id: sectionId,\n                type: 'section',\n                title: this.getSectionEditorTitle(section, sectionIndex),\n                hostObject: sectionEditor\n            }\n        } else {\n            return null;\n        }\n    }\n\n    private getSectionColumnByIdForEditor(sectionColumnId: string): IPepLayoutSectionColumn | null {\n        let currentColumn = null;\n\n        // Get the section and column array by the pattern of the section column key.\n        const sectionColumnPatternSeparator = this.getSectionColumnKey();\n        const sectionColumnArr = sectionColumnId.split(sectionColumnPatternSeparator);\n\n        if (sectionColumnArr.length === 2) {\n            const layoutView = this._layoutViewSubject.getValue();\n            const sections = layoutView?.Layout.Sections || [];\n            \n            // Get the section id to get the section index.\n            const sectionId = sectionColumnArr[0];\n            const sectionIndex = sections.findIndex(section => section.Key === sectionId);\n            // Get the column index.\n            const columnIndex = coerceNumberProperty(sectionColumnArr[1], -1);\n            if (sectionIndex >= 0 && columnIndex >= 0) {\n                currentColumn = sections[sectionIndex].Columns[columnIndex];\n            }\n        }\n\n        return currentColumn;\n    }\n\n    private setSectionsColumnsGap(layoutView: IPepLayoutView) {\n        if (layoutView?.Layout?.Sections) {\n            for (let index = 0; index < layoutView.Layout.Sections.length; index++) {\n                const section = layoutView.Layout.Sections[index];\n                section.ColumnsGap = layoutView.Layout.ColumnsGap;\n            }\n        }\n    }\n\n    private getCssScreenWidh(screenType: DataViewScreenSize): string {\n        let widthToSet = '100%';\n\n        if (screenType === 'Tablet') {\n            widthToSet = '720';\n        } else if (screenType === 'Phablet') {\n            widthToSet = '360';\n        }\n\n        return widthToSet;\n    }\n    \n    private getBlockContainerByBlockKey(blockKey: string): IPepLayoutBlockContainer | undefined {\n        let blockContainerToFind: IPepLayoutBlockContainer | undefined = undefined;\n\n        const layoutView = this._layoutViewSubject.getValue();\n        const sections = layoutView?.Layout.Sections || [];\n        \n        for (let sectionIndex = 0; sectionIndex < sections.length; sectionIndex++) {\n            const section = sections[sectionIndex];\n\n            // Get the block container.\n            const columnIndex = section.Columns.findIndex(column => column.BlockContainer?.BlockKey === blockKey);\n            if (columnIndex > -1) {\n                blockContainerToFind = section.Columns[columnIndex].BlockContainer\n                break;\n            }\n        }\n\n        return blockContainerToFind;\n    }\n\n    private changeCursorOnDragStart() {\n        document.body.classList.add('inheritCursors');\n        document.body.style.cursor = 'grabbing';\n    }\n\n    private changeCursorOnDragEnd() {\n        document.body.classList.remove('inheritCursors');\n        document.body.style.cursor = 'unset';\n    }\n\n    /***********************************************************************************************/\n    /*                                  Public functions\n    /***********************************************************************************************/\n\n    notifySectionsColumnsDropListChange(sectionsColumnsDropList: any[]) {\n        this._sectionsColumnsDropListSubject.next(sectionsColumnsDropList);\n    }\n\n    notifyPreviewModeChange(value: boolean) {\n        this._previewModeSubject.next(value);\n        this.setEditableState();\n    }\n\n    notifyLockScreen(value: boolean) {\n        this._lockScreenSubject.next(value);\n    }\n\n    setAvailableBlocksToDrag(availableBlocksForDrag: Array<IPepDraggableItem>) {\n        this._availableBlocksForDragMap.clear();\n        availableBlocksForDrag.forEach(block => {\n            this._availableBlocksForDragMap.set(block.data.key, block);\n        });\n\n        this.notifyAvailableBlocksForDragMapChange();\n    }\n\n    getBlockEditor(blockKey: string): IEditor {\n        const blockContainer = this.getBlockContainerByBlockKey(blockKey);\n        const defaultTitle = this.translate.instant('LAYOUT_BUILDER.NO_TITLE')\n        let blockTitle = defaultTitle;\n\n        if (blockContainer) {\n            blockTitle = this.availableBlocksForDragMap?.get(blockContainer?.DraggableItemKey)?.title || defaultTitle;\n        }\n \n        return {\n            id: blockKey,\n            type: 'block',\n            title: blockTitle,\n            // remoteModuleOptions: remoteLoaderOptions,\n            hostObject: {} // JSON.parse(JSON.stringify(hostObject))\n        }\n    }\n\n    getScreenType(size: PepScreenSizeType): DataViewScreenSize {\n        const screenType: DataViewScreenSize =\n            size < PepScreenSizeType.MD ? 'Landscape' :\n            (size === PepScreenSizeType.MD || size === PepScreenSizeType.SM ? 'Tablet' : 'Phablet');\n\n        return screenType;\n    }\n\n    getSectionColumnKey(sectionKey: string = '', index: string = '') {\n        return `${sectionKey}_column_${index}`;\n    }\n\n    getIsHidden(hideIn: DataViewScreenSize[] | undefined, currentScreenType: DataViewScreenSize) {\n        return (hideIn && hideIn?.length > 0) ? hideIn.some(hi => hi === currentScreenType) : false;\n    }\n\n    navigateToEditor(editorType: LayoutEditorType, id: string): boolean {\n        let success = false;\n\n        // Cannot navigate into 'layout-builder' because this is first and const in the editorsBreadCrumbs.\n        if (editorType !== 'layout-builder' && id?.length > 0) {\n            // Check which editor we have now\n            const currentEditor = this._editorsBreadCrumb[this._editorsBreadCrumb.length - 1];\n\n            // Only if it's another editor.\n            if(currentEditor.id !== id) {\n                if (currentEditor.type !== 'layout-builder') {\n                    // Always pop the last and insert the current.\n                    this._editorsBreadCrumb.pop();\n                }\n\n                let editor = this.getEditor(editorType, id);\n\n                if (editor) {\n                    this._editorsBreadCrumb.push(editor);\n                    this.changeCurrentEditor();\n                    success = true;\n                } else {\n                    success = false;\n                }\n            }\n        }\n\n        return success;\n    }\n\n    navigateBackFromEditor() {\n        // Keep the layout builder editor.\n        if (this._editorsBreadCrumb.length > 1) {\n            // Maybe we want to compare the last editor for validation ?\n            const lastEditor = this._editorsBreadCrumb.pop();\n            this.changeCurrentEditor();\n        }\n    }\n\n    updateLayoutFromEditor(editorData: ILayoutEditor) {\n        const layoutView = this._layoutViewSubject.getValue();\n\n        if (layoutView) {\n            layoutView.Layout.MaxWidth = editorData.maxWidth;\n            layoutView.Layout.HorizontalSpacing = editorData.horizontalSpacing;\n            layoutView.Layout.VerticalSpacing = editorData.verticalSpacing;\n            layoutView.Layout.SectionsGap = editorData.sectionsGap;\n            layoutView.Layout.ColumnsGap = editorData.columnsGap;\n            // layoutView.layout.RoundedCorners = editorData.roundedCorners;\n\n            this.setSectionsColumnsGap(layoutView);\n            \n            this.notifyLayoutViewChange(layoutView);\n        }\n    }\n    \n    updateSectionFromEditor(sectionData: ILayoutSectionEditor) {\n        const layoutView = this._layoutViewSubject.getValue();\n        const sections = layoutView?.Layout.Sections || [];\n        const sectionIndex = sections.findIndex(section => section.Key === sectionData.id);\n\n        // Update section details.\n        if (sectionIndex >= 0) {\n            const blocksIdsToRemove = [];\n\n            const currentSection = sections[sectionIndex];\n            currentSection.Name = sectionData.sectionName;\n            currentSection.Split = sectionData.split;\n            currentSection.Height = sectionData.height;\n            currentSection.CollapseOnTablet = sectionData.collapseOnTablet;\n            currentSection.FillHeight = sectionData.fillHeight;\n\n            // Get the new columns number from currentSection.Split, if its undefined put a default 1.\n            const newColumnsLength = currentSection.Split?.split(' ').length || 1;\n            if (newColumnsLength > currentSection.Columns.length) {\n                while (newColumnsLength > currentSection.Columns.length) {\n                    currentSection.Columns.push({});\n                }\n            } else if (newColumnsLength < currentSection.Columns.length) {\n                while (newColumnsLength < currentSection.Columns.length) {\n                    const colunm = currentSection.Columns.pop();\n                    // If there is block in this column delete it.\n                    if (colunm && colunm.BlockContainer) {\n                        blocksIdsToRemove.push(colunm.BlockContainer.BlockKey);\n                    }\n                }\n            }\n\n            // Update editor title\n            const currentEditor = this._editorSubject.getValue();\n            if (currentEditor && currentEditor.type === 'section' && currentEditor.id === currentSection.Key) {\n                currentEditor.title = this.getSectionEditorTitle(currentSection, sectionIndex);\n                this.notifyEditorChange(currentEditor);\n            }\n\n            // Update sections change.\n            this.notifyLayoutViewChange(layoutView);\n\n            // If there are blocks to remove, notify the blocks removed.\n            if (blocksIdsToRemove.length > 0) {\n                this.notifyBlocksRemoved(blocksIdsToRemove);\n            }\n        }\n    }\n\n    addSection(section: IPepLayoutSection | null = null) {\n        // Create new section\n        if (!section) {\n            section = {\n                Key: PepGuid.newGuid(),\n                Columns: [{}], // Add empty section column\n                Hide: []\n            }\n        }\n\n        // Add the new section to layout view.\n        const layoutView = this._layoutViewSubject.getValue();\n        const sections = layoutView?.Layout.Sections || [];\n        sections.push(section);\n        this.notifyLayoutViewChange(layoutView);\n    }\n\n    removeSection(sectionId: string) {\n        const layoutView = this._layoutViewSubject.getValue();\n        const sections = layoutView?.Layout.Sections || [];\n        const index = sections.findIndex(section => section.Key === sectionId);\n        if (index > -1) {\n            // Get the blocks id's to remove.\n            const blocksIdsToRemove: any = sections[index].Columns.map(column => column?.BlockContainer?.BlockKey);\n\n            // Remove section.\n            sections.splice(index, 1);\n            this.notifyLayoutViewChange(layoutView);\n\n            // If there are blocks to remove, notify the blocks removed.\n            if (blocksIdsToRemove.length > 0) {\n                this.notifyBlocksRemoved(blocksIdsToRemove)\n            }\n        }\n    }\n\n    hideSection(sectionId: string, hideIn: DataViewScreenSize[]) {\n        const layoutView = this._layoutViewSubject.getValue();\n        const sections = layoutView?.Layout.Sections || [];\n        const index = sections.findIndex(section => section.Key === sectionId);\n        if (index > -1) {\n            sections[index].Hide = hideIn;\n            this.notifyLayoutViewChange(layoutView);\n        }\n    }\n\n    onSectionDropped(event: CdkDragDrop<any[]>) {\n        const layoutView = this._layoutViewSubject.getValue();\n        const sections = layoutView?.Layout.Sections || [];\n        moveItemInArray(sections, event.previousIndex, event.currentIndex);\n        this.notifyLayoutViewChange(layoutView);\n    }\n\n    onSectionDragStart(event: CdkDragStart) {\n        this.changeCursorOnDragStart();\n        this._draggingSectionKey.next(event.source.data);\n    }\n\n    onSectionDragEnd(event: CdkDragEnd) {\n        this.changeCursorOnDragEnd();\n        this._draggingSectionKey.next('');\n    }\n\n    removeBlockFromSection(blockId: string) {\n        let blockRemoved = false;\n\n        // Remove the block from section column.\n        const layoutView = this._layoutViewSubject.getValue();\n        const sections = layoutView?.Layout.Sections || [];\n        \n        for (let sectionIndex = 0; sectionIndex < sections.length; sectionIndex++) {\n            const section = sections[sectionIndex];\n\n            // Remove the block container.\n            const columnIndex = section.Columns.findIndex(column => column.BlockContainer?.BlockKey === blockId);\n            if (columnIndex > -1) {\n                delete section.Columns[columnIndex].BlockContainer;\n                this.notifyLayoutViewChange(layoutView);\n                blockRemoved = true;\n\n                break;\n            }\n        }\n\n        // If the block was removed, notify the block removed.\n        if (blockRemoved) {\n            this.notifyBlocksRemoved([blockId]);\n        }\n    }\n\n    hideBlock(sectionId: string, blockId: string, hideIn: DataViewScreenSize[]) {\n        const layoutView = this._layoutViewSubject.getValue();\n        const sections = layoutView?.Layout.Sections || [];\n        \n        const index = sections.findIndex(section => section.Key === sectionId);\n        if (index > -1) {\n            const columnIndex = sections[index].Columns.findIndex(column => column.BlockContainer?.BlockKey === blockId);\n            if (columnIndex > -1) {\n                const blockContainer = sections[index].Columns[columnIndex].BlockContainer;\n                if (blockContainer) {\n                    blockContainer.Hide = hideIn;\n                    this.notifyLayoutViewChange(layoutView);\n                }\n            }\n        }\n    }\n\n    onBlockDropped(event: CdkDragDrop<IPepLayoutSectionColumn, any, any>, sectionId: string) {\n        const layoutView = this._layoutViewSubject.getValue();\n\n        if (event.previousContainer.id === PepLayoutBuilderService.AVAILABLE_BLOCKS_CONTAINER_ID) {\n            // Get the block relation (previousContainer.data is IPepDraggableItem and inside we have AvailableBlock object).\n            const draggableItem: IPepDraggableItem = event.previousContainer.data[event.previousIndex] as IPepDraggableItem;\n\n            if (draggableItem) {\n                // lock the screen untill the editor will be loaded.\n                // this._lockScreenSubject.next(true);\n\n                // Get the column.\n                const currentColumn = this.getSectionColumnByIdForEditor(event.container.id);\n\n                // Set the block key in the section block only if there is a blank column.\n                if (currentColumn && !currentColumn.BlockContainer) {\n                     // Generate the block uuid.\n                    const blockKey = PepGuid.newGuid();\n\n                    currentColumn.BlockContainer = {\n                        BlockKey: blockKey,\n                        DraggableItemKey: draggableItem.data.key,\n                    };\n\n                    // Here we update the layout view cause the layout is updated.\n                    this.notifyLayoutViewChange(layoutView);\n\n                    // Raise block added event.\n                    const blockAddedEventData: IPepLayoutBlockAddedEvent = {\n                        BlockKey: blockKey,\n                        DraggableItem: draggableItem,\n                    }\n                    this.notifyBlockAdded(blockAddedEventData);\n                }\n            } else {\n                console.log(\"draggableItem is not a IPepDraggableItem type\");\n            }\n        } else {\n            // If the block moved between columns in the same section or between different sections but not in the same column.\n            if (event.container.id !== event.previousContainer.id) {\n                // Get the column.\n                const currentColumn = this.getSectionColumnByIdForEditor(event.container.id);\n                // Get the previous column.\n                const previuosColumn = this.getSectionColumnByIdForEditor(event.previousContainer.id);\n\n                if (currentColumn && previuosColumn) {\n                    currentColumn.BlockContainer = previuosColumn.BlockContainer;\n                    delete previuosColumn.BlockContainer;\n                    this.notifyLayoutViewChange(layoutView);\n                }\n            }\n        }\n    }\n\n    onBlockDragStart(event: CdkDragStart) {\n        this.changeCursorOnDragStart();\n        // Take the block key if exist, else take the available block key (relation key).\n        const blockKey = event.source.data?.BlockKey || event.source.data?.Key;\n        this._draggingBlockKey.next(blockKey);\n    }\n\n    onBlockDragEnd(event: CdkDragEnd) {\n        this.changeCursorOnDragEnd();\n        this._draggingBlockKey.next('');\n    }\n    \n    doesColumnContainBlock(sectionId: string, columnIndex: number): boolean {\n        let res = false;\n        const layoutView = this._layoutViewSubject.getValue();\n        const section = layoutView?.Layout.Sections.find(section => section.Key === sectionId);\n\n        if (section && columnIndex >= 0 && section.Columns.length > columnIndex) {\n            res = !!section.Columns[columnIndex].BlockContainer;\n        }\n\n        return res;\n    }\n\n    setScreenWidth(screenType: DataViewScreenSize) {\n        const value = this.getCssScreenWidh(screenType)\n\n        let width = coerceNumberProperty(value, 0);\n        if (width === 0) {\n            this._screenWidthSubject.next('100%');\n            this._screenSizeSubject.next(PepScreenSizeType.XL);\n        } else {\n            this._screenWidthSubject.next(`${width}px`);\n\n            // Change the size according the width.\n            if (width >= 1920) {\n                this._screenSizeSubject.next(PepScreenSizeType.XL);\n            } else if (width >= 1280 && width < 1920) {\n                this._screenSizeSubject.next(PepScreenSizeType.LG);\n            } else if (width >= 960 && width < 1280) {\n                this._screenSizeSubject.next(PepScreenSizeType.MD);\n            } else if (width >= 600 && width < 960) {\n                this._screenSizeSubject.next(PepScreenSizeType.SM);\n            } else if (width < 600) {\n                this._screenSizeSubject.next(PepScreenSizeType.XS);\n            }\n        }\n    }\n\n    showSkeleton(show: boolean) {\n        this._showSkeletonSubject.next(show);\n    }\n    \n    loadLayoutBuilder(layoutView: IPepLayoutView): void {\n        if (this.editMode) {\n            // Load the layout editor.\n            this.loadDefaultEditor(layoutView);\n\n            // Set the columns gap of the sections.\n            this.setSectionsColumnsGap(layoutView);\n        }\n\n        // Load only the layout view.\n        this.notifyLayoutViewChange(layoutView);\n    }\n}\n"]}
@@ -25,7 +25,6 @@ export class SectionComponent extends BaseDestroyerDirective {
25
25
  this.styleMaxHeight = 'unset';
26
26
  this.styleHeight = 'unset';
27
27
  this.sectionsColumnsDropList = [];
28
- this._editable = false;
29
28
  // PepScreenSizeType = PepScreenSizeType;
30
29
  this.sectionColumnKeyPrefix = '';
31
30
  this.isMainEditorState = false;
@@ -75,12 +74,14 @@ export class SectionComponent extends BaseDestroyerDirective {
75
74
  get hideIn() {
76
75
  return this._hideIn;
77
76
  }
78
- set editable(value) {
79
- this._editable = value;
80
- this.refreshSplit();
81
- }
77
+ // private _editable = false;
78
+ // protected set editable(value: boolean) {
79
+ // this._editable = value;
80
+ // this.refreshSplit();
81
+ // }
82
82
  get editable() {
83
- return this._editable;
83
+ return this.layoutBuilderService.editableState;
84
+ ;
84
85
  }
85
86
  set screenSize(value) {
86
87
  this._screenSize = value;
@@ -179,9 +180,8 @@ export class SectionComponent extends BaseDestroyerDirective {
179
180
  return this.layoutBuilderService.getIsHidden(hideIn, currentScreenType);
180
181
  }
181
182
  ngOnInit() {
182
- this.editable = this.layoutBuilderService.isEditMode;
183
183
  this.layoutBuilderService.previewModeChange$.pipe(this.getDestroyer()).subscribe(previewMode => {
184
- this.editable = this.layoutBuilderService.isEditMode && !previewMode;
184
+ this.refreshSplit();
185
185
  });
186
186
  // Just to calculate if sections contains blocks
187
187
  this.layoutBuilderService.sectionsChange$.pipe(this.getDestroyer()).subscribe(res => {
@@ -309,4 +309,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.2", ngImpor
309
309
  type: HostBinding,
310
310
  args: ['style.height']
311
311
  }] } });
312
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"section.component.js","sourceRoot":"","sources":["../../../../../projects/ngx-composite-lib/layout-builder/section/section.component.ts","../../../../../projects/ngx-composite-lib/layout-builder/section/section.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, HostBinding, HostListener, Input, OnChanges, OnInit, QueryList, Renderer2, SimpleChanges, TemplateRef, ViewChild, ViewChildren } from '@angular/core';\nimport { CdkDrag, CdkDragDrop, CdkDragEnd, CdkDragEnter, CdkDragExit, CdkDragStart, CdkDropList } from '@angular/cdk/drag-drop';\nimport { DataViewScreenSize, SplitType } from '@pepperi-addons/papi-sdk';\nimport { BaseDestroyerDirective, PepLayoutService, PepScreenSizeType } from '@pepperi-addons/ngx-lib';\nimport { PepLayoutBuilderService } from '../layout-builder.service';\nimport { IEditor, IPepLayoutSectionColumn, PepLayoutSizeType } from '../layout-builder.model';\n\n@Component({\n    selector: 'section',\n    templateUrl: './section.component.html',\n    styleUrls: ['./section.component.scss', './section.component.theme.scss']\n})\nexport class SectionComponent extends BaseDestroyerDirective implements OnInit {\n    @ViewChild('sectionContainer') sectionContainerRef!: ElementRef;\n    @ViewChildren('columnsWrapper') columnsElementRef!: QueryList<ElementRef>;\n\n    @Input() blockTemplate: TemplateRef<any> | undefined;\n\n    @Input() key: string = '';\n    @Input() name: string = '';\n\n    private _split: SplitType | undefined = undefined;\n    @Input()\n    set split(value: SplitType | undefined ) {\n        this._split = value;\n        this.refreshSplit();\n    }\n    get split(): SplitType | undefined {\n        return this._split;\n    }\n\n    private _height: number | undefined = undefined;\n    @Input()\n    set height(value: number | undefined) {\n        this._height = value;\n        this.setStyleHeight();\n    }\n    get height(): number | undefined {\n        return this._height;\n    }\n\n    private _collapseOnTablet: boolean = false;\n    @Input()\n    set collapseOnTablet(value: boolean) {\n        this._collapseOnTablet = value;\n        this.pepScreenSizeToFlipToVertical = value ? PepScreenSizeType.MD : PepScreenSizeType.SM;\n        this.refreshSplit();\n    }\n    get collapseOnTablet(): boolean {\n        return this._collapseOnTablet;\n    }\n\n    private _columns: Array<IPepLayoutSectionColumn> = [];\n    @Input()\n    set columns(value: Array<IPepLayoutSectionColumn>) {\n        this._columns = value || [];\n    }\n    get columns(): Array<IPepLayoutSectionColumn> {\n        return this._columns;\n    }\n    \n    private _hideIn: DataViewScreenSize[] = [];\n    @Input()\n    set hideIn(value: DataViewScreenSize[]) {\n        this._hideIn = value;\n        this.setIfHideForCurrentScreenType();\n    }\n    get hideIn(): DataViewScreenSize[] {\n        return this._hideIn;\n    }\n\n    @Input() columnsGap!: PepLayoutSizeType;\n        \n    @HostBinding('style.max-height')\n    styleMaxHeight = 'unset';\n    \n    @HostBinding('style.height')\n    styleHeight = 'unset';\n    \n    protected sectionsColumnsDropList: string[] = [];\n\n    private _editable = false;\n    protected set editable(value: boolean) {\n        this._editable = value;\n        this.refreshSplit();\n    }\n    protected get editable(): boolean {\n        return this._editable;\n    }\n\n    private _screenSize!: PepScreenSizeType;\n    protected set screenSize(value: PepScreenSizeType) {\n        this._screenSize = value;\n        this.refreshSplit();\n        this.setScreenType();\n    }\n    protected get screenSize(): PepScreenSizeType {\n        return this._screenSize;\n    }\n\n    // PepScreenSizeType = PepScreenSizeType;\n    protected sectionColumnKeyPrefix = '';\n    \n    protected isMainEditorState = false;\n    protected isEditing = false;\n    protected selectedSectionKey = '';\n    protected selectedBlockKey = '';\n    \n    protected containsBlocks = false;\n    protected shouldSetDefaultHeight = false;\n    protected pepScreenSizeToFlipToVertical = PepScreenSizeType.SM;\n    protected screenType!: DataViewScreenSize;\n    protected hideForCurrentScreenType = false;\n    protected draggingBlockKey: string = '';\n    protected draggingSectionKey: string = '';\n    protected hoverState = false;\n\n    constructor(\n        private renderer: Renderer2,\n        private layoutBuilderService: PepLayoutBuilderService,\n        private layoutService: PepLayoutService,\n    ) { \n        super();\n    }\n\n    private calculateIfSectionContainsBlocks() {\n        this.containsBlocks = this.columns.some(column => column.BlockContainer);\n\n        if (this.editable) {\n            this.shouldSetDefaultHeight = !this.containsBlocks;\n        }\n    }\n\n    private setScreenType() {\n        this.screenType = this.layoutBuilderService.getScreenType(this.screenSize);\n        this.setIfHideForCurrentScreenType();\n        this.setStyleHeight();\n    }\n\n    private setIfHideForCurrentScreenType(): void {\n        this.hideForCurrentScreenType = this.layoutBuilderService.getIsHidden(this.hideIn, this.screenType);\n    }\n    \n    private getCssSplitString() {\n        switch (this.split) {\n            case '1/2 1/2':\n                return '1fr 1fr';\n            case '1/2 1/4 1/4':\n                return '2fr 1fr 1fr';\n            case '1/3 1/3 1/3':\n                return '1fr 1fr 1fr';\n            case '1/3 2/3':\n                return '1fr 2fr';\n            case '1/4 1/2 1/4':\n                return '1fr 2fr 1fr';\n            case '1/4 1/4 1/2':\n                return '1fr 1fr 2fr';\n            case '1/4 1/4 1/4 1/4':\n                return '1fr 1fr 1fr 1fr';\n            case '1/4 3/4':\n                return '1fr 3fr';\n            case '2/3 1/3':\n                return '2fr 1fr';\n            case '3/4 1/4':\n                return '3fr 1fr';\n            default: // For one column.\n                return '1fr';\n        }\n    }\n\n    private refreshSplit() {\n        setTimeout(() => {\n            if (this.sectionContainerRef) {\n                let cssSplitString = this.getCssSplitString();\n                \n                // Go for all the columns in the columnsWrapper\n                this.columnsElementRef.toArray().map((section, sectionIndex) => {\n                    // Horizontal (true) for large screens, false for small screens.\n                    const isHorizontalView = this.screenSize <= this.pepScreenSizeToFlipToVertical;\n\n                    if (isHorizontalView) {\n                        this.renderer.setStyle(section.nativeElement, 'grid-auto-flow', 'column');\n                        this.renderer.setStyle(section.nativeElement, 'grid-template-rows', 'unset');\n                        this.renderer.setStyle(section.nativeElement, 'grid-template-columns', cssSplitString);\n                    } else {\n                        this.renderer.setStyle(section.nativeElement, 'grid-auto-flow', 'row');\n                        this.renderer.setStyle(section.nativeElement, 'grid-template-columns', 'unset');\n                        this.renderer.setStyle(section.nativeElement, 'grid-template-rows', cssSplitString);\n                        \n                        // In runtime (or preview mode).\n                        if (!this.editable) {\n                            const cssSplitArray = cssSplitString.split(' ');\n                            \n                            // If there are some hidden columns change the column width to 0 (for cut the spacing in the grid-template-rows).\n                            this.columns.forEach((column, index) => {\n                                if (!column.BlockContainer) {\n                                    cssSplitArray[index] = '0';\n                                }\n                            });\n                            this.renderer.setStyle(section.nativeElement, 'grid-template-rows', 'auto');\n                            //this.renderer.setStyle(section.nativeElement, 'grid-template-rows', cssSplitArray.join(' '));\n                        }\n                    }\n                });\n            }\n        }, 0);\n    }\n\n    private setStyleHeight() {\n        if (this.height && this.height > 0 && this.screenType !== 'Phablet') {\n            this.styleHeight = this.styleMaxHeight = `${this.height}px`;\n        } else {\n            this.styleHeight = this.styleMaxHeight = 'unset';\n        }\n    }\n\n    getIsDragging(): boolean {\n        return this.draggingBlockKey.length > 0 && this.draggingSectionKey.length > 0;\n    }\n\n    getIsHidden(hideIn: DataViewScreenSize[] | undefined, currentScreenType: DataViewScreenSize) {\n        return this.layoutBuilderService.getIsHidden(hideIn, currentScreenType);\n    }\n\n    ngOnInit(): void {\n        this.editable = this.layoutBuilderService.isEditMode;\n\n        this.layoutBuilderService.previewModeChange$.pipe(this.getDestroyer()).subscribe(previewMode => {\n            this.editable = this.layoutBuilderService.isEditMode && !previewMode;\n        });\n\n        // Just to calculate if sections contains blocks\n        this.layoutBuilderService.sectionsChange$.pipe(this.getDestroyer()).subscribe(res => {\n            this.calculateIfSectionContainsBlocks();\n        });\n\n        this.layoutService.onResize$.pipe(this.getDestroyer()).subscribe((size: any) => {\n            this.screenSize = size;\n        });\n\n        this.layoutBuilderService.screenSizeChange$.pipe(this.getDestroyer()).subscribe((size: any) => {\n            this.screenSize = size;\n        });\n\n        if (this.editable) {\n            this.layoutBuilderService.sectionsColumnsDropListChange$.pipe(this.getDestroyer()).subscribe((sectionsColumnsDropList: any) => {\n                this.sectionsColumnsDropList = sectionsColumnsDropList;\n            });\n\n            this.layoutBuilderService.editorChange$.pipe(this.getDestroyer()).subscribe((editor: any) => {\n                this.isMainEditorState = editor && editor.type === 'layout-builder';\n                this.isEditing = editor && editor.type === 'section' && editor.id === this.key;\n                this.selectedSectionKey = editor && editor.type === 'section' ? editor.id : '';\n                this.selectedBlockKey = editor && editor.type === 'block' ? editor.id : '';\n            });\n            \n            this.layoutBuilderService.draggingBlockKey.pipe(this.getDestroyer()).subscribe((draggingBlockKey: any) => {\n                this.draggingBlockKey = draggingBlockKey;\n\n                if (draggingBlockKey === '') {\n                    this.calculateIfSectionContainsBlocks();\n                } else {\n                    // If there is only one block in the section and now it's this block that the user is dragging.\n                    const blocksLength = this.columns.filter(column => column.BlockContainer).length;\n                    if (blocksLength === 1 && this.columns.find(c => c.BlockContainer?.BlockKey === this.draggingBlockKey)) {\n                        this.shouldSetDefaultHeight = true;\n                    }\n                }\n\n            });\n\n            this.layoutBuilderService.draggingSectionKey.pipe(this.getDestroyer()).subscribe((draggingSectionKey: any) => {\n                this.draggingSectionKey = draggingSectionKey;\n            });\n        }\n\n        this.sectionColumnKeyPrefix = this.layoutBuilderService.getSectionColumnKey(this.key);\n    }\n\n    onEditSectionClick() {\n        this.layoutBuilderService.navigateToEditor('section', this.key);\n    }\n\n    onRemoveSectionClick() {\n        this.layoutBuilderService.removeSection(this.key);\n    }\n\n    onHideSectionChange(hideIn: DataViewScreenSize[]) {\n        this.layoutBuilderService.hideSection(this.key, hideIn);\n    }\n\n    onHideInMenuOpened() {\n        this.hoverState = true;\n    }\n\n    onHideInMenuClosed() {\n        this.hoverState = false;\n    }\n\n    onBlockDropped(event: CdkDragDrop<IPepLayoutSectionColumn, any, any>) {\n        this.layoutBuilderService.onBlockDropped(event, this.key);\n    }\n\n    canDropPredicate(columnIndex: number) {\n        return (drag: CdkDrag, drop: CdkDropList) => {\n            const res = !this.layoutBuilderService.doesColumnContainBlock(this.key, columnIndex);\n            return res;\n        };\n    }\n\n    onDragStart(event: CdkDragStart) {\n        this.layoutBuilderService.onSectionDragStart(event);\n    }\n\n    onDragEnd(event: CdkDragEnd) {\n        this.layoutBuilderService.onSectionDragEnd(event);\n    }\n\n    onSectionBlockDragExited(event: CdkDragExit) {\n        // TODO: Remove this.\n        // // If the block is exit from his container and it's the only block in this section.\n        // if (this.containsBlocks) {\n        //     const blocksLength = this.columns.filter(column => column.BlockContainer).length;\n\n        //     if (blocksLength === 1) {\n        //         this.containsBlocks = false;\n        //         this.shouldSetDefaultHeight = true;\n        //     }\n        // }\n    }\n\n    onSectionBlockDragEntered(event: CdkDragEnter) {\n        // TODO: Remove this.\n        // // Only in case that the block entered back to his container and it's the only block in this section.\n        // if (event.container.id === event.item.dropContainer.id) {\n        //     if (!this.containsBlocks) {\n        //         this.containsBlocks = true;\n        //     }\n        // }\n    }\n}\n","<div #sectionContainer *ngIf=\"editable || (containsBlocks && !hideForCurrentScreenType)\" class=\"section-container \"\n    [ngClass]=\"{ \n        'mobile': screenType === 'Phablet',\n        'editable-state': editable, 'main-editor-state': isMainEditorState, 'default-height': shouldSetDefaultHeight, 'active-section': isEditing,\n        'section-hidden-state': hideForCurrentScreenType, 'section-is-dragging': draggingSectionKey !== '', 'show-hover-state': hoverState }\" \n        cdkDragBoundary=\".layout-builder-wrapper\" cdkDrag [cdkDragData]=\"key\" [cdkDragDisabled]=\"!editable || selectedSectionKey.length > 0 || selectedBlockKey.length > 0\" (cdkDragStarted)=\"onDragStart($event)\" (cdkDragEnded)=\"onDragEnd($event)\" \n    >\n    <pep-draggable-item *ngIf=\"editable && isMainEditorState && draggingSectionKey === ''\" cdkDragHandle style=\"cursor: grab;\"\n        class=\"section-toolbar\" [ngClass]=\"{ 'hide-toolbar': !hoverState }\" [title]=\"name\">\n        <ng-container pep-actions>\n            <pep-button classNames=\"caution\" sizeType=\"xs\" iconName=\"system_bin\" (buttonClick)=\"onRemoveSectionClick();\"></pep-button>\n            <hide-in [hideIn]=\"hideIn\" (hideInChange)=\"onHideSectionChange($event)\" (menuClosed)=\"onHideInMenuClosed()\" (menuOpened)=\"onHideInMenuOpened()\"></hide-in>\n            <pep-button sizeType=\"xs\" iconName=\"system_edit\" (buttonClick)=\"onEditSectionClick();\"></pep-button>\n        </ng-container>\n    </pep-draggable-item>\n\n    <div *ngIf=\"editable\" class=\"section-background\">\n        <div class=\"back-template\" *ngFor=\"let number of [0,1,2,3,4,5,6,7,8,9,10,11]\"></div>\n    </div>\n    <div #columnsWrapper class=\"columns-wrapper gap-{{ columnsGap }}\" \n        [ngClass]=\"{ 'mobile': screenType === 'Phablet', 'is-dragging': editable && getIsDragging }\">\n        <div [id]=\"sectionColumnKeyPrefix + i\" \n            *ngFor=\"let column of columns; let i=index;\"\n            class=\"section-column {{screenSize <= pepScreenSizeToFlipToVertical ? 'horizontal' : 'vertical'}}\"\n            [ngClass]=\"{ 'active-column': selectedBlockKey === column.BlockContainer?.BlockKey, \n                'is-hidden': getIsHidden(column?.BlockContainer?.Hide, screenType),\n                'already-contains-block': editable && column.BlockContainer && column.BlockContainer.BlockKey && column.BlockContainer.BlockKey.length > 0 && \n                    draggingBlockKey && draggingBlockKey.length > 0 && column.BlockContainer.BlockKey !== draggingBlockKey }\"\n            cdkDropList\n            [cdkDropListData]=\"column\"\n            [cdkDropListOrientation]=\"screenSize <= pepScreenSizeToFlipToVertical ? 'horizontal' : 'vertical'\" \n            [cdkDropListConnectedTo]=\"sectionsColumnsDropList\"\n            (cdkDropListDropped)=\"onBlockDropped($event)\"\n            [cdkDropListEnterPredicate]=\"canDropPredicate(i)\"\n        >\n            <section-block *ngIf=\"column.BlockContainer?.BlockKey\" class=\"section-block\" [sectionKey]=\"key\" [blockTemplate]=\"blockTemplate\"\n                [blockContainer]=\"column.BlockContainer\" [editable]=\"editable\" [isMainEditorState]=\"isMainEditorState\" [sectionHeight]=\"styleHeight\"\n                [active]=\"selectedBlockKey === column.BlockContainer?.BlockKey\" [screenType]=\"screenType\"\n                (dragExited)=\"onSectionBlockDragExited($event)\" (dragEntered)=\"onSectionBlockDragEntered($event)\"></section-block>\n        </div>\n    </div>\n</div>\n"]}
312
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"section.component.js","sourceRoot":"","sources":["../../../../../projects/ngx-composite-lib/layout-builder/section/section.component.ts","../../../../../projects/ngx-composite-lib/layout-builder/section/section.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, HostBinding, HostListener, Input, OnChanges, OnInit, QueryList, Renderer2, SimpleChanges, TemplateRef, ViewChild, ViewChildren } from '@angular/core';\nimport { CdkDrag, CdkDragDrop, CdkDragEnd, CdkDragEnter, CdkDragExit, CdkDragStart, CdkDropList } from '@angular/cdk/drag-drop';\nimport { DataViewScreenSize, SplitType } from '@pepperi-addons/papi-sdk';\nimport { BaseDestroyerDirective, PepLayoutService, PepScreenSizeType } from '@pepperi-addons/ngx-lib';\nimport { PepLayoutBuilderService } from '../layout-builder.service';\nimport { IEditor, IPepLayoutSectionColumn, PepLayoutSizeType } from '../layout-builder.model';\n\n@Component({\n    selector: 'section',\n    templateUrl: './section.component.html',\n    styleUrls: ['./section.component.scss', './section.component.theme.scss']\n})\nexport class SectionComponent extends BaseDestroyerDirective implements OnInit {\n    @ViewChild('sectionContainer') sectionContainerRef!: ElementRef;\n    @ViewChildren('columnsWrapper') columnsElementRef!: QueryList<ElementRef>;\n\n    @Input() blockTemplate: TemplateRef<any> | undefined;\n\n    @Input() key: string = '';\n    @Input() name: string = '';\n\n    private _split: SplitType | undefined = undefined;\n    @Input()\n    set split(value: SplitType | undefined ) {\n        this._split = value;\n        this.refreshSplit();\n    }\n    get split(): SplitType | undefined {\n        return this._split;\n    }\n\n    private _height: number | undefined = undefined;\n    @Input()\n    set height(value: number | undefined) {\n        this._height = value;\n        this.setStyleHeight();\n    }\n    get height(): number | undefined {\n        return this._height;\n    }\n\n    private _collapseOnTablet: boolean = false;\n    @Input()\n    set collapseOnTablet(value: boolean) {\n        this._collapseOnTablet = value;\n        this.pepScreenSizeToFlipToVertical = value ? PepScreenSizeType.MD : PepScreenSizeType.SM;\n        this.refreshSplit();\n    }\n    get collapseOnTablet(): boolean {\n        return this._collapseOnTablet;\n    }\n\n    private _columns: Array<IPepLayoutSectionColumn> = [];\n    @Input()\n    set columns(value: Array<IPepLayoutSectionColumn>) {\n        this._columns = value || [];\n    }\n    get columns(): Array<IPepLayoutSectionColumn> {\n        return this._columns;\n    }\n    \n    private _hideIn: DataViewScreenSize[] = [];\n    @Input()\n    set hideIn(value: DataViewScreenSize[]) {\n        this._hideIn = value;\n        this.setIfHideForCurrentScreenType();\n    }\n    get hideIn(): DataViewScreenSize[] {\n        return this._hideIn;\n    }\n\n    @Input() columnsGap!: PepLayoutSizeType;\n        \n    @HostBinding('style.max-height')\n    styleMaxHeight = 'unset';\n    \n    @HostBinding('style.height')\n    styleHeight = 'unset';\n    \n    protected sectionsColumnsDropList: string[] = [];\n\n    // private _editable = false;\n    // protected set editable(value: boolean) {\n    //     this._editable = value;\n    //     this.refreshSplit();\n    // }\n    protected get editable(): boolean {\n        return this.layoutBuilderService.editableState;;\n    }\n\n    private _screenSize!: PepScreenSizeType;\n    protected set screenSize(value: PepScreenSizeType) {\n        this._screenSize = value;\n        this.refreshSplit();\n        this.setScreenType();\n    }\n    protected get screenSize(): PepScreenSizeType {\n        return this._screenSize;\n    }\n\n    // PepScreenSizeType = PepScreenSizeType;\n    protected sectionColumnKeyPrefix = '';\n    \n    protected isMainEditorState = false;\n    protected isEditing = false;\n    protected selectedSectionKey = '';\n    protected selectedBlockKey = '';\n    \n    protected containsBlocks = false;\n    protected shouldSetDefaultHeight = false;\n    protected pepScreenSizeToFlipToVertical = PepScreenSizeType.SM;\n    protected screenType!: DataViewScreenSize;\n    protected hideForCurrentScreenType = false;\n    protected draggingBlockKey: string = '';\n    protected draggingSectionKey: string = '';\n    protected hoverState = false;\n\n    constructor(\n        private renderer: Renderer2,\n        private layoutBuilderService: PepLayoutBuilderService,\n        private layoutService: PepLayoutService,\n    ) { \n        super();\n    }\n\n    private calculateIfSectionContainsBlocks() {\n        this.containsBlocks = this.columns.some(column => column.BlockContainer);\n\n        if (this.editable) {\n            this.shouldSetDefaultHeight = !this.containsBlocks;\n        }\n    }\n\n    private setScreenType() {\n        this.screenType = this.layoutBuilderService.getScreenType(this.screenSize);\n        this.setIfHideForCurrentScreenType();\n        this.setStyleHeight();\n    }\n\n    private setIfHideForCurrentScreenType(): void {\n        this.hideForCurrentScreenType = this.layoutBuilderService.getIsHidden(this.hideIn, this.screenType);\n    }\n    \n    private getCssSplitString() {\n        switch (this.split) {\n            case '1/2 1/2':\n                return '1fr 1fr';\n            case '1/2 1/4 1/4':\n                return '2fr 1fr 1fr';\n            case '1/3 1/3 1/3':\n                return '1fr 1fr 1fr';\n            case '1/3 2/3':\n                return '1fr 2fr';\n            case '1/4 1/2 1/4':\n                return '1fr 2fr 1fr';\n            case '1/4 1/4 1/2':\n                return '1fr 1fr 2fr';\n            case '1/4 1/4 1/4 1/4':\n                return '1fr 1fr 1fr 1fr';\n            case '1/4 3/4':\n                return '1fr 3fr';\n            case '2/3 1/3':\n                return '2fr 1fr';\n            case '3/4 1/4':\n                return '3fr 1fr';\n            default: // For one column.\n                return '1fr';\n        }\n    }\n\n    private refreshSplit() {\n        setTimeout(() => {\n            if (this.sectionContainerRef) {\n                let cssSplitString = this.getCssSplitString();\n                \n                // Go for all the columns in the columnsWrapper\n                this.columnsElementRef.toArray().map((section, sectionIndex) => {\n                    // Horizontal (true) for large screens, false for small screens.\n                    const isHorizontalView = this.screenSize <= this.pepScreenSizeToFlipToVertical;\n\n                    if (isHorizontalView) {\n                        this.renderer.setStyle(section.nativeElement, 'grid-auto-flow', 'column');\n                        this.renderer.setStyle(section.nativeElement, 'grid-template-rows', 'unset');\n                        this.renderer.setStyle(section.nativeElement, 'grid-template-columns', cssSplitString);\n                    } else {\n                        this.renderer.setStyle(section.nativeElement, 'grid-auto-flow', 'row');\n                        this.renderer.setStyle(section.nativeElement, 'grid-template-columns', 'unset');\n                        this.renderer.setStyle(section.nativeElement, 'grid-template-rows', cssSplitString);\n                        \n                        // In runtime (or preview mode).\n                        if (!this.editable) {\n                            const cssSplitArray = cssSplitString.split(' ');\n                            \n                            // If there are some hidden columns change the column width to 0 (for cut the spacing in the grid-template-rows).\n                            this.columns.forEach((column, index) => {\n                                if (!column.BlockContainer) {\n                                    cssSplitArray[index] = '0';\n                                }\n                            });\n                            this.renderer.setStyle(section.nativeElement, 'grid-template-rows', 'auto');\n                            //this.renderer.setStyle(section.nativeElement, 'grid-template-rows', cssSplitArray.join(' '));\n                        }\n                    }\n                });\n            }\n        }, 0);\n    }\n\n    private setStyleHeight() {\n        if (this.height && this.height > 0 && this.screenType !== 'Phablet') {\n            this.styleHeight = this.styleMaxHeight = `${this.height}px`;\n        } else {\n            this.styleHeight = this.styleMaxHeight = 'unset';\n        }\n    }\n\n    getIsDragging(): boolean {\n        return this.draggingBlockKey.length > 0 && this.draggingSectionKey.length > 0;\n    }\n\n    getIsHidden(hideIn: DataViewScreenSize[] | undefined, currentScreenType: DataViewScreenSize) {\n        return this.layoutBuilderService.getIsHidden(hideIn, currentScreenType);\n    }\n\n    ngOnInit(): void {\n        this.layoutBuilderService.previewModeChange$.pipe(this.getDestroyer()).subscribe(previewMode => {\n            this.refreshSplit();\n        });\n\n        // Just to calculate if sections contains blocks\n        this.layoutBuilderService.sectionsChange$.pipe(this.getDestroyer()).subscribe(res => {\n            this.calculateIfSectionContainsBlocks();\n        });\n\n        this.layoutService.onResize$.pipe(this.getDestroyer()).subscribe((size: any) => {\n            this.screenSize = size;\n        });\n\n        this.layoutBuilderService.screenSizeChange$.pipe(this.getDestroyer()).subscribe((size: any) => {\n            this.screenSize = size;\n        });\n\n        if (this.editable) {\n            this.layoutBuilderService.sectionsColumnsDropListChange$.pipe(this.getDestroyer()).subscribe((sectionsColumnsDropList: any) => {\n                this.sectionsColumnsDropList = sectionsColumnsDropList;\n            });\n\n            this.layoutBuilderService.editorChange$.pipe(this.getDestroyer()).subscribe((editor: any) => {\n                this.isMainEditorState = editor && editor.type === 'layout-builder';\n                this.isEditing = editor && editor.type === 'section' && editor.id === this.key;\n                this.selectedSectionKey = editor && editor.type === 'section' ? editor.id : '';\n                this.selectedBlockKey = editor && editor.type === 'block' ? editor.id : '';\n            });\n            \n            this.layoutBuilderService.draggingBlockKey.pipe(this.getDestroyer()).subscribe((draggingBlockKey: any) => {\n                this.draggingBlockKey = draggingBlockKey;\n\n                if (draggingBlockKey === '') {\n                    this.calculateIfSectionContainsBlocks();\n                } else {\n                    // If there is only one block in the section and now it's this block that the user is dragging.\n                    const blocksLength = this.columns.filter(column => column.BlockContainer).length;\n                    if (blocksLength === 1 && this.columns.find(c => c.BlockContainer?.BlockKey === this.draggingBlockKey)) {\n                        this.shouldSetDefaultHeight = true;\n                    }\n                }\n\n            });\n\n            this.layoutBuilderService.draggingSectionKey.pipe(this.getDestroyer()).subscribe((draggingSectionKey: any) => {\n                this.draggingSectionKey = draggingSectionKey;\n            });\n        }\n\n        this.sectionColumnKeyPrefix = this.layoutBuilderService.getSectionColumnKey(this.key);\n    }\n\n    onEditSectionClick() {\n        this.layoutBuilderService.navigateToEditor('section', this.key);\n    }\n\n    onRemoveSectionClick() {\n        this.layoutBuilderService.removeSection(this.key);\n    }\n\n    onHideSectionChange(hideIn: DataViewScreenSize[]) {\n        this.layoutBuilderService.hideSection(this.key, hideIn);\n    }\n\n    onHideInMenuOpened() {\n        this.hoverState = true;\n    }\n\n    onHideInMenuClosed() {\n        this.hoverState = false;\n    }\n\n    onBlockDropped(event: CdkDragDrop<IPepLayoutSectionColumn, any, any>) {\n        this.layoutBuilderService.onBlockDropped(event, this.key);\n    }\n\n    canDropPredicate(columnIndex: number) {\n        return (drag: CdkDrag, drop: CdkDropList) => {\n            const res = !this.layoutBuilderService.doesColumnContainBlock(this.key, columnIndex);\n            return res;\n        };\n    }\n\n    onDragStart(event: CdkDragStart) {\n        this.layoutBuilderService.onSectionDragStart(event);\n    }\n\n    onDragEnd(event: CdkDragEnd) {\n        this.layoutBuilderService.onSectionDragEnd(event);\n    }\n\n    onSectionBlockDragExited(event: CdkDragExit) {\n        // TODO: Remove this.\n        // // If the block is exit from his container and it's the only block in this section.\n        // if (this.containsBlocks) {\n        //     const blocksLength = this.columns.filter(column => column.BlockContainer).length;\n\n        //     if (blocksLength === 1) {\n        //         this.containsBlocks = false;\n        //         this.shouldSetDefaultHeight = true;\n        //     }\n        // }\n    }\n\n    onSectionBlockDragEntered(event: CdkDragEnter) {\n        // TODO: Remove this.\n        // // Only in case that the block entered back to his container and it's the only block in this section.\n        // if (event.container.id === event.item.dropContainer.id) {\n        //     if (!this.containsBlocks) {\n        //         this.containsBlocks = true;\n        //     }\n        // }\n    }\n}\n","<div #sectionContainer *ngIf=\"editable || (containsBlocks && !hideForCurrentScreenType)\" class=\"section-container \"\n    [ngClass]=\"{ \n        'mobile': screenType === 'Phablet',\n        'editable-state': editable, 'main-editor-state': isMainEditorState, 'default-height': shouldSetDefaultHeight, 'active-section': isEditing,\n        'section-hidden-state': hideForCurrentScreenType, 'section-is-dragging': draggingSectionKey !== '', 'show-hover-state': hoverState }\" \n        cdkDragBoundary=\".layout-builder-wrapper\" cdkDrag [cdkDragData]=\"key\" [cdkDragDisabled]=\"!editable || selectedSectionKey.length > 0 || selectedBlockKey.length > 0\" (cdkDragStarted)=\"onDragStart($event)\" (cdkDragEnded)=\"onDragEnd($event)\" \n    >\n    <pep-draggable-item *ngIf=\"editable && isMainEditorState && draggingSectionKey === ''\" cdkDragHandle style=\"cursor: grab;\"\n        class=\"section-toolbar\" [ngClass]=\"{ 'hide-toolbar': !hoverState }\" [title]=\"name\">\n        <ng-container pep-actions>\n            <pep-button classNames=\"caution\" sizeType=\"xs\" iconName=\"system_bin\" (buttonClick)=\"onRemoveSectionClick();\"></pep-button>\n            <hide-in [hideIn]=\"hideIn\" (hideInChange)=\"onHideSectionChange($event)\" (menuClosed)=\"onHideInMenuClosed()\" (menuOpened)=\"onHideInMenuOpened()\"></hide-in>\n            <pep-button sizeType=\"xs\" iconName=\"system_edit\" (buttonClick)=\"onEditSectionClick();\"></pep-button>\n        </ng-container>\n    </pep-draggable-item>\n\n    <div *ngIf=\"editable\" class=\"section-background\">\n        <div class=\"back-template\" *ngFor=\"let number of [0,1,2,3,4,5,6,7,8,9,10,11]\"></div>\n    </div>\n    <div #columnsWrapper class=\"columns-wrapper gap-{{ columnsGap }}\" \n        [ngClass]=\"{ 'mobile': screenType === 'Phablet', 'is-dragging': editable && getIsDragging }\">\n        <div [id]=\"sectionColumnKeyPrefix + i\" \n            *ngFor=\"let column of columns; let i=index;\"\n            class=\"section-column {{screenSize <= pepScreenSizeToFlipToVertical ? 'horizontal' : 'vertical'}}\"\n            [ngClass]=\"{ 'active-column': selectedBlockKey === column.BlockContainer?.BlockKey, \n                'is-hidden': getIsHidden(column?.BlockContainer?.Hide, screenType),\n                'already-contains-block': editable && column.BlockContainer && column.BlockContainer.BlockKey && column.BlockContainer.BlockKey.length > 0 && \n                    draggingBlockKey && draggingBlockKey.length > 0 && column.BlockContainer.BlockKey !== draggingBlockKey }\"\n            cdkDropList\n            [cdkDropListData]=\"column\"\n            [cdkDropListOrientation]=\"screenSize <= pepScreenSizeToFlipToVertical ? 'horizontal' : 'vertical'\" \n            [cdkDropListConnectedTo]=\"sectionsColumnsDropList\"\n            (cdkDropListDropped)=\"onBlockDropped($event)\"\n            [cdkDropListEnterPredicate]=\"canDropPredicate(i)\"\n        >\n            <section-block *ngIf=\"column.BlockContainer?.BlockKey\" class=\"section-block\" [sectionKey]=\"key\" [blockTemplate]=\"blockTemplate\"\n                [blockContainer]=\"column.BlockContainer\" [editable]=\"editable\" [isMainEditorState]=\"isMainEditorState\" [sectionHeight]=\"styleHeight\"\n                [active]=\"selectedBlockKey === column.BlockContainer?.BlockKey\" [screenType]=\"screenType\"\n                (dragExited)=\"onSectionBlockDragExited($event)\" (dragEntered)=\"onSectionBlockDragEntered($event)\"></section-block>\n        </div>\n    </div>\n</div>\n"]}