@pepperi-addons/ngx-composite-lib 0.4.2-beta.9 → 0.4.2-beta.90
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.
- package/color-settings/color-settings.component.d.ts +3 -2
- package/core/common/services/dimx.service.d.ts +4 -0
- package/esm2020/color-settings/color-settings.component.mjs +6 -3
- package/esm2020/core/common/directives/reset-configuration-field.directive.mjs +5 -4
- package/esm2020/core/common/services/dimx.service.mjs +1 -1
- package/esm2020/data-view-builder/menu-data-view/menu-data-view.component.mjs +2 -2
- package/esm2020/file-status-panel/file-status-panel.module.mjs +23 -3
- package/esm2020/flow-picker-button/flow-picker-button.component.mjs +94 -0
- package/esm2020/flow-picker-button/flow-picker-button.module.mjs +36 -0
- package/esm2020/flow-picker-button/flow-picker-button.service.mjs +21 -0
- package/esm2020/flow-picker-button/pepperi-addons-ngx-composite-lib-flow-picker-button.mjs +5 -0
- package/esm2020/flow-picker-button/public-api.mjs +6 -0
- package/esm2020/generic-list/generic-list.component.mjs +50 -7
- package/esm2020/generic-list/generic-list.service.mjs +6 -2
- package/esm2020/group-buttons-settings/group-buttons-settings.component.mjs +17 -4
- package/esm2020/group-buttons-settings/group-buttons-settings.model.mjs +1 -1
- package/esm2020/group-buttons-settings/public-api.mjs +2 -2
- package/esm2020/icon-picker/icon-picker.component.mjs +79 -0
- package/esm2020/icon-picker/icon-picker.module.mjs +44 -0
- package/esm2020/icon-picker/icon-picker.service.mjs +17 -0
- package/esm2020/icon-picker/pepperi-addons-ngx-composite-lib-icon-picker.mjs +5 -0
- package/esm2020/icon-picker/public-api.mjs +6 -0
- package/esm2020/layout-builder/hide-in/hide-in.component.mjs +54 -0
- package/esm2020/layout-builder/hide-in/hide-in.module.mjs +81 -0
- package/esm2020/layout-builder/layout/layout.component.mjs +204 -0
- package/esm2020/layout-builder/layout/layout.module.mjs +54 -0
- package/esm2020/layout-builder/layout-builder-editor/layout-builder-editor.component.mjs +25 -0
- package/esm2020/layout-builder/layout-builder-editor/layout-builder-editor.module.mjs +45 -0
- package/esm2020/layout-builder/layout-builder-internal.service.mjs +628 -0
- package/esm2020/layout-builder/layout-builder.component.mjs +201 -0
- package/esm2020/layout-builder/layout-builder.model.mjs +2 -0
- package/esm2020/layout-builder/layout-builder.module.mjs +143 -0
- package/esm2020/layout-builder/layout-builder.service.mjs +36 -0
- package/esm2020/layout-builder/main-editor/main-editor.component.mjs +130 -0
- package/esm2020/layout-builder/main-editor/main-editor.module.mjs +99 -0
- package/esm2020/layout-builder/pepperi-addons-ngx-composite-lib-layout-builder.mjs +5 -0
- package/esm2020/layout-builder/public-api.mjs +12 -0
- package/esm2020/layout-builder/section/section.component.mjs +349 -0
- package/esm2020/layout-builder/section/section.module.mjs +44 -0
- package/esm2020/layout-builder/section-block/section-block.component.mjs +113 -0
- package/esm2020/layout-builder/section-block/section-block.module.mjs +34 -0
- package/esm2020/layout-builder/section-editor/section-editor.component.mjs +192 -0
- package/esm2020/layout-builder/section-editor/section-editor.module.mjs +44 -0
- package/esm2020/manage-parameters/manage-parameter/manage-parameter.component.mjs +82 -0
- package/esm2020/manage-parameters/manage-parameters.component.mjs +153 -0
- package/esm2020/manage-parameters/manage-parameters.model.mjs +24 -0
- package/esm2020/manage-parameters/manage-parameters.module.mjs +45 -0
- package/esm2020/manage-parameters/manage-parameters.service.mjs +142 -0
- package/esm2020/manage-parameters/pepperi-addons-ngx-composite-lib-manage-parameters.mjs +5 -0
- package/esm2020/manage-parameters/public-api.mjs +8 -0
- package/esm2020/rich-text/pepperi-addons-ngx-composite-lib-rich-text.mjs +5 -0
- package/esm2020/rich-text/public-api.mjs +6 -0
- package/esm2020/rich-text/rich-text.component.mjs +154 -0
- package/esm2020/rich-text/rich-text.module.mjs +52 -0
- package/esm2020/rich-text/rich-text.service.mjs +21 -0
- package/esm2020/shadow-settings/shadow-settings.component.mjs +7 -4
- package/esm2020/show-if-badge/pepperi-addons-ngx-composite-lib-show-if-badge.mjs +5 -0
- package/esm2020/show-if-badge/public-api.mjs +6 -0
- package/esm2020/show-if-badge/show-if-badge.component.mjs +44 -0
- package/esm2020/show-if-badge/show-if-badge.module.mjs +50 -0
- package/fesm2015/pepperi-addons-ngx-composite-lib-color-settings.mjs +5 -2
- package/fesm2015/pepperi-addons-ngx-composite-lib-color-settings.mjs.map +1 -1
- package/fesm2015/pepperi-addons-ngx-composite-lib-data-view-builder.mjs +2 -2
- package/fesm2015/pepperi-addons-ngx-composite-lib-file-status-panel.mjs +22 -3
- package/fesm2015/pepperi-addons-ngx-composite-lib-file-status-panel.mjs.map +1 -1
- package/fesm2015/pepperi-addons-ngx-composite-lib-flow-picker-button.mjs +161 -0
- package/fesm2015/pepperi-addons-ngx-composite-lib-flow-picker-button.mjs.map +1 -0
- package/fesm2015/pepperi-addons-ngx-composite-lib-generic-list.mjs +55 -7
- package/fesm2015/pepperi-addons-ngx-composite-lib-generic-list.mjs.map +1 -1
- package/fesm2015/pepperi-addons-ngx-composite-lib-group-buttons-settings.mjs +17 -4
- package/fesm2015/pepperi-addons-ngx-composite-lib-group-buttons-settings.mjs.map +1 -1
- package/fesm2015/pepperi-addons-ngx-composite-lib-icon-picker.mjs +146 -0
- package/fesm2015/pepperi-addons-ngx-composite-lib-icon-picker.mjs.map +1 -0
- package/fesm2015/pepperi-addons-ngx-composite-lib-layout-builder.mjs +2343 -0
- package/fesm2015/pepperi-addons-ngx-composite-lib-layout-builder.mjs.map +1 -0
- package/fesm2015/pepperi-addons-ngx-composite-lib-manage-parameters.mjs +441 -0
- package/fesm2015/pepperi-addons-ngx-composite-lib-manage-parameters.mjs.map +1 -0
- package/fesm2015/pepperi-addons-ngx-composite-lib-rich-text.mjs +234 -0
- package/fesm2015/pepperi-addons-ngx-composite-lib-rich-text.mjs.map +1 -0
- package/fesm2015/pepperi-addons-ngx-composite-lib-shadow-settings.mjs +6 -3
- package/fesm2015/pepperi-addons-ngx-composite-lib-shadow-settings.mjs.map +1 -1
- package/fesm2015/pepperi-addons-ngx-composite-lib-show-if-badge.mjs +100 -0
- package/fesm2015/pepperi-addons-ngx-composite-lib-show-if-badge.mjs.map +1 -0
- package/fesm2015/pepperi-addons-ngx-composite-lib.mjs +4 -3
- package/fesm2015/pepperi-addons-ngx-composite-lib.mjs.map +1 -1
- package/fesm2020/pepperi-addons-ngx-composite-lib-color-settings.mjs +5 -2
- package/fesm2020/pepperi-addons-ngx-composite-lib-color-settings.mjs.map +1 -1
- package/fesm2020/pepperi-addons-ngx-composite-lib-data-view-builder.mjs +2 -2
- package/fesm2020/pepperi-addons-ngx-composite-lib-file-status-panel.mjs +22 -3
- package/fesm2020/pepperi-addons-ngx-composite-lib-file-status-panel.mjs.map +1 -1
- package/fesm2020/pepperi-addons-ngx-composite-lib-flow-picker-button.mjs +155 -0
- package/fesm2020/pepperi-addons-ngx-composite-lib-flow-picker-button.mjs.map +1 -0
- package/fesm2020/pepperi-addons-ngx-composite-lib-generic-list.mjs +54 -7
- package/fesm2020/pepperi-addons-ngx-composite-lib-generic-list.mjs.map +1 -1
- package/fesm2020/pepperi-addons-ngx-composite-lib-group-buttons-settings.mjs +17 -4
- package/fesm2020/pepperi-addons-ngx-composite-lib-group-buttons-settings.mjs.map +1 -1
- package/fesm2020/pepperi-addons-ngx-composite-lib-icon-picker.mjs +145 -0
- package/fesm2020/pepperi-addons-ngx-composite-lib-icon-picker.mjs.map +1 -0
- package/fesm2020/pepperi-addons-ngx-composite-lib-layout-builder.mjs +2320 -0
- package/fesm2020/pepperi-addons-ngx-composite-lib-layout-builder.mjs.map +1 -0
- package/fesm2020/pepperi-addons-ngx-composite-lib-manage-parameters.mjs +438 -0
- package/fesm2020/pepperi-addons-ngx-composite-lib-manage-parameters.mjs.map +1 -0
- package/fesm2020/pepperi-addons-ngx-composite-lib-rich-text.mjs +230 -0
- package/fesm2020/pepperi-addons-ngx-composite-lib-rich-text.mjs.map +1 -0
- package/fesm2020/pepperi-addons-ngx-composite-lib-shadow-settings.mjs +6 -3
- package/fesm2020/pepperi-addons-ngx-composite-lib-shadow-settings.mjs.map +1 -1
- package/fesm2020/pepperi-addons-ngx-composite-lib-show-if-badge.mjs +100 -0
- package/fesm2020/pepperi-addons-ngx-composite-lib-show-if-badge.mjs.map +1 -0
- package/fesm2020/pepperi-addons-ngx-composite-lib.mjs +4 -3
- package/fesm2020/pepperi-addons-ngx-composite-lib.mjs.map +1 -1
- package/flow-picker-button/flow-picker-button.component.d.ts +27 -0
- package/flow-picker-button/flow-picker-button.module.d.ts +11 -0
- package/flow-picker-button/flow-picker-button.service.d.ts +9 -0
- package/flow-picker-button/index.d.ts +5 -0
- package/flow-picker-button/public-api.d.ts +2 -0
- package/generic-list/generic-list.component.d.ts +13 -4
- package/generic-list/generic-list.service.d.ts +2 -1
- package/group-buttons-settings/group-buttons-settings.component.d.ts +5 -2
- package/group-buttons-settings/group-buttons-settings.model.d.ts +1 -1
- package/icon-picker/icon-picker.component.d.ts +24 -0
- package/icon-picker/icon-picker.module.d.ts +13 -0
- package/icon-picker/icon-picker.service.d.ts +8 -0
- package/icon-picker/index.d.ts +5 -0
- package/icon-picker/public-api.d.ts +2 -0
- package/layout-builder/hide-in/hide-in.component.d.ts +25 -0
- package/layout-builder/hide-in/hide-in.component.theme.scss +9 -0
- package/layout-builder/hide-in/hide-in.module.d.ts +20 -0
- package/layout-builder/index.d.ts +5 -0
- package/layout-builder/layout/layout.component.d.ts +49 -0
- package/layout-builder/layout/layout.module.d.ts +16 -0
- package/layout-builder/layout-builder-editor/layout-builder-editor.component.d.ts +12 -0
- package/layout-builder/layout-builder-editor/layout-builder-editor.module.d.ts +14 -0
- package/layout-builder/layout-builder-internal.service.d.ts +120 -0
- package/layout-builder/layout-builder.component.d.ts +51 -0
- package/layout-builder/layout-builder.component.theme.scss +57 -0
- package/layout-builder/layout-builder.model.d.ts +43 -0
- package/layout-builder/layout-builder.module.d.ts +32 -0
- package/layout-builder/layout-builder.service.d.ts +15 -0
- package/layout-builder/main-editor/main-editor.component.d.ts +46 -0
- package/layout-builder/main-editor/main-editor.module.d.ts +27 -0
- package/layout-builder/public-api.d.ts +8 -0
- package/layout-builder/section/section.component.d.ts +76 -0
- package/layout-builder/section/section.component.theme.scss +115 -0
- package/layout-builder/section/section.module.d.ts +14 -0
- package/layout-builder/section-block/section-block.component.d.ts +38 -0
- package/layout-builder/section-block/section-block.component.theme.scss +13 -0
- package/layout-builder/section-block/section-block.module.d.ts +11 -0
- package/layout-builder/section-editor/section-editor.component.d.ts +53 -0
- package/layout-builder/section-editor/section-editor.module.d.ts +14 -0
- package/manage-parameters/index.d.ts +5 -0
- package/manage-parameters/manage-parameter/manage-parameter.component.d.ts +28 -0
- package/manage-parameters/manage-parameters.component.d.ts +33 -0
- package/manage-parameters/manage-parameters.model.d.ts +21 -0
- package/manage-parameters/manage-parameters.module.d.ts +14 -0
- package/manage-parameters/manage-parameters.service.d.ts +16 -0
- package/manage-parameters/public-api.d.ts +3 -0
- package/package.json +49 -1
- package/rich-text/index.d.ts +5 -0
- package/rich-text/public-api.d.ts +2 -0
- package/rich-text/rich-text.component.d.ts +43 -0
- package/rich-text/rich-text.module.d.ts +16 -0
- package/rich-text/rich-text.service.d.ts +9 -0
- package/shadow-settings/shadow-settings.component.d.ts +2 -1
- package/show-if-badge/index.d.ts +5 -0
- package/show-if-badge/public-api.d.ts +2 -0
- package/show-if-badge/show-if-badge.component.d.ts +20 -0
- package/show-if-badge/show-if-badge.module.d.ts +16 -0
- package/src/assets/i18n/en.ngx-composite-lib.json +80 -4
- package/pepperi-addons-ngx-composite-lib-0.4.2-beta.8.tgz +0 -0
- package/src/assets/images/brand-leaf-full@1x.png +0 -0
- package/src/assets/images/brand-leaf-full@2x.png +0 -0
- package/src/assets/images/brand-leaf-round.png +0 -0
- package/src/assets/images/brand-leaf-round@2x.png +0 -0
- package/src/assets/images/brand-leaf-skiny@1x.png +0 -0
- package/src/assets/images/brand-leaf-skiny@2x.png +0 -0
|
@@ -0,0 +1,113 @@
|
|
|
1
|
+
import { Component, EventEmitter, Input, Output } from '@angular/core';
|
|
2
|
+
import { BaseDestroyerDirective } from '@pepperi-addons/ngx-lib';
|
|
3
|
+
import * as i0 from "@angular/core";
|
|
4
|
+
import * as i1 from "../layout-builder-internal.service";
|
|
5
|
+
import * as i2 from "@angular/common";
|
|
6
|
+
import * as i3 from "@angular/cdk/drag-drop";
|
|
7
|
+
import * as i4 from "@pepperi-addons/ngx-lib/button";
|
|
8
|
+
import * as i5 from "@pepperi-addons/ngx-lib/draggable-items";
|
|
9
|
+
export class SectionBlockComponent extends BaseDestroyerDirective {
|
|
10
|
+
constructor(layoutBuilderInternalService) {
|
|
11
|
+
super();
|
|
12
|
+
this.layoutBuilderInternalService = layoutBuilderInternalService;
|
|
13
|
+
this.sectionKey = '';
|
|
14
|
+
this.sectionHeight = '';
|
|
15
|
+
this.isMainEditorState = false;
|
|
16
|
+
this.editable = false;
|
|
17
|
+
this.active = false;
|
|
18
|
+
this.dragExited = new EventEmitter();
|
|
19
|
+
this.dragEntered = new EventEmitter();
|
|
20
|
+
this.hideForCurrentScreenType = false;
|
|
21
|
+
// protected remoteLoaderOptions: PepRemoteLoaderOptions;
|
|
22
|
+
// protected availableBlock: IPepDraggableItem | undefined;
|
|
23
|
+
this.blockTitle = '';
|
|
24
|
+
}
|
|
25
|
+
set blockContainer(value) {
|
|
26
|
+
this._blockContainer = value;
|
|
27
|
+
// if (this._blockContainer) {
|
|
28
|
+
// this.availableBlock = this.layoutBuilderInternalService.availableBlocksForDragMap?.get(this._blockContainer?.DraggableItemKey);
|
|
29
|
+
// }
|
|
30
|
+
this.setIfHideForCurrentScreenType();
|
|
31
|
+
}
|
|
32
|
+
get blockContainer() {
|
|
33
|
+
return this._blockContainer;
|
|
34
|
+
}
|
|
35
|
+
set screenType(value) {
|
|
36
|
+
this._screenType = value;
|
|
37
|
+
this.setIfHideForCurrentScreenType();
|
|
38
|
+
}
|
|
39
|
+
get screenType() {
|
|
40
|
+
return this._screenType;
|
|
41
|
+
}
|
|
42
|
+
setIfHideForCurrentScreenType() {
|
|
43
|
+
this.hideForCurrentScreenType = this.blockContainer ?
|
|
44
|
+
this.layoutBuilderInternalService.getIsHidden(this.blockContainer.Hide, this.screenType) : false;
|
|
45
|
+
}
|
|
46
|
+
ngOnInit() {
|
|
47
|
+
this.blockTitle = this.layoutBuilderInternalService.getBlockTitle(this.blockContainer?.BlockKey || '');
|
|
48
|
+
//
|
|
49
|
+
// this.layoutBuilderInternalService.availableBlocksForDragMapChange$.pipe(this.getDestroyer()).subscribe((availableBlocksForDragMap) => {
|
|
50
|
+
// if (availableBlocksForDragMap && this.blockContainer) {
|
|
51
|
+
// this.availableBlock = (availableBlocksForDragMap as ReadonlyMap<string, IPepDraggableItem>).get(this.blockContainer.DraggableItemKey);
|
|
52
|
+
// }
|
|
53
|
+
// });
|
|
54
|
+
}
|
|
55
|
+
onEditBlockClick() {
|
|
56
|
+
if (this.blockContainer?.BlockKey) {
|
|
57
|
+
this.layoutBuilderInternalService.navigateToEditor('block', this.blockContainer.BlockKey, this.blockTitle);
|
|
58
|
+
}
|
|
59
|
+
}
|
|
60
|
+
onRemoveBlockClick() {
|
|
61
|
+
if (this.blockContainer?.BlockKey) {
|
|
62
|
+
this.layoutBuilderInternalService.removeBlockFromSection(this.blockContainer.BlockKey);
|
|
63
|
+
}
|
|
64
|
+
}
|
|
65
|
+
onHideBlockChange(hideIn) {
|
|
66
|
+
if (this.blockContainer?.BlockKey) {
|
|
67
|
+
this.layoutBuilderInternalService.hideBlock(this.sectionKey, this.blockContainer.BlockKey, hideIn);
|
|
68
|
+
this.setIfHideForCurrentScreenType();
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
// onBlockLoad(event: any) {
|
|
72
|
+
// this.layoutBuilderService.updateBlockLoaded(this.blockContainer.BlockKey);
|
|
73
|
+
// }
|
|
74
|
+
onDragStart(event) {
|
|
75
|
+
this.layoutBuilderInternalService.onBlockDragStart(event);
|
|
76
|
+
}
|
|
77
|
+
onDragEnd(event) {
|
|
78
|
+
this.layoutBuilderInternalService.onBlockDragEnd(event);
|
|
79
|
+
}
|
|
80
|
+
onDragExited(event) {
|
|
81
|
+
this.dragExited.emit(event);
|
|
82
|
+
}
|
|
83
|
+
onDragEntered(event) {
|
|
84
|
+
this.dragEntered.emit(event);
|
|
85
|
+
}
|
|
86
|
+
}
|
|
87
|
+
SectionBlockComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: SectionBlockComponent, deps: [{ token: i1.LayoutBuilderInternalService }], target: i0.ɵɵFactoryTarget.Component });
|
|
88
|
+
SectionBlockComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.0.2", type: SectionBlockComponent, selector: "section-block", inputs: { blockTemplate: "blockTemplate", sectionKey: "sectionKey", sectionHeight: "sectionHeight", isMainEditorState: "isMainEditorState", editable: "editable", active: "active", blockContainer: "blockContainer", screenType: "screenType" }, outputs: { dragExited: "dragExited", dragEntered: "dragEntered" }, usesInheritance: true, ngImport: i0, template: "<div *ngIf=\"blockContainer?.BlockKey && (editable || !hideForCurrentScreenType)\" \n class=\"section-block-container\"\n [ngClass]=\"{ 'editable-state': editable, 'block-hidden-state': hideForCurrentScreenType, 'active-block': active }\"\n cdkDrag [cdkDragData]=\"blockContainer\" [cdkDragDisabled]=\"!editable || !isMainEditorState\" \n (cdkDragStarted)=\"onDragStart($event)\" (cdkDragEnded)=\"onDragEnd($event)\"\n (cdkDragExited)=\"onDragExited($event)\" (cdkDragEntered)=\"onDragEntered($event)\">\n \n <pep-draggable-item *ngIf=\"editable && isMainEditorState\" cdkDragHandle style=\"cursor: grab;\"\n class=\"block-toolbar\" [title]=\"blockTitle\" >\n <ng-container pep-actions>\n <pep-button classNames=\"caution\" sizeType=\"xs\" iconName=\"system_bin\" (buttonClick)=\"onRemoveBlockClick();\"></pep-button>\n <!-- <hide-in [hideIn]=\"blockContainer.Hide\" (hideInChange)=\"onHideBlockChange($event)\"></hide-in> -->\n <pep-button sizeType=\"xs\" iconName=\"system_edit\" (buttonClick)=\"onEditBlockClick();\"></pep-button>\n </ng-container>\n </pep-draggable-item>\n <div class=\"block-template-wrapper\" [ngStyle]=\"{ 'overflow': (sectionHeight === 'unset' ? 'unset' : 'auto') }\">\n <div *ngIf=\"blockTemplate\" class=\"block-template\">\n <ng-container *ngTemplateOutlet=\"blockTemplate; context: { blockKey: blockContainer?.BlockKey }\">\n </ng-container>\n </div>\n </div>\n</div>\n", styles: [".section-block-container{height:100%;width:100%}.section-block-container.editable-state:not(.active-block) .block-template-wrapper .block-template{pointer-events:none;opacity:.5}.section-block-container.editable-state.cdk-drag-preview .block-template-wrapper,.section-block-container.editable-state.cdk-drag-placeholder .block-toolbar{opacity:0}.section-block-container.editable-state .block-toolbar{position:absolute;top:50%;left:50%;width:95%;max-width:240px;transform:translate(-50%,-50%);z-index:3}.section-block-container.editable-state .block-toolbar:hover{z-index:12!important}.section-block-container .block-template-wrapper{height:100%;position:relative}.section-block-container .block-template-wrapper .block-template{display:block;height:100%;width:100%}\n", ".section-block-container.editable-state.block-hidden-state:not(.active-block){background:repeating-linear-gradient(45deg,hsla(var(--pep-color-system-caution-h, 360),var(--pep-color-system-caution-s, 100%),var(--pep-color-system-caution-l, 45%),0),hsla(var(--pep-color-system-caution-h, 360),var(--pep-color-system-caution-s, 100%),var(--pep-color-system-caution-l, 45%),0) .65rem,hsla(var(--pep-color-system-caution-h, 360),var(--pep-color-system-caution-s, 100%),var(--pep-color-system-caution-l, 45%),.32) .65rem,hsla(var(--pep-color-system-caution-h, 360),var(--pep-color-system-caution-s, 100%),var(--pep-color-system-caution-l, 45%),.32) .8rem),repeating-linear-gradient(-45deg,hsla(var(--pep-color-system-caution-h, 360),var(--pep-color-system-caution-s, 100%),var(--pep-color-system-caution-l, 45%),0),hsla(var(--pep-color-system-caution-h, 360),var(--pep-color-system-caution-s, 100%),var(--pep-color-system-caution-l, 45%),0) .65rem,hsla(var(--pep-color-system-caution-h, 360),var(--pep-color-system-caution-s, 100%),var(--pep-color-system-caution-l, 45%),.32) .65rem,hsla(var(--pep-color-system-caution-h, 360),var(--pep-color-system-caution-s, 100%),var(--pep-color-system-caution-l, 45%),.32) .8rem)}\n"], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i2.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "directive", type: i3.CdkDrag, selector: "[cdkDrag]", inputs: ["cdkDragData", "cdkDragLockAxis", "cdkDragRootElement", "cdkDragBoundary", "cdkDragStartDelay", "cdkDragFreeDragPosition", "cdkDragDisabled", "cdkDragConstrainPosition", "cdkDragPreviewClass", "cdkDragPreviewContainer"], outputs: ["cdkDragStarted", "cdkDragReleased", "cdkDragEnded", "cdkDragEntered", "cdkDragExited", "cdkDragDropped", "cdkDragMoved"], exportAs: ["cdkDrag"] }, { kind: "directive", type: i3.CdkDragHandle, selector: "[cdkDragHandle]", inputs: ["cdkDragHandleDisabled"] }, { kind: "component", type: i4.PepButtonComponent, selector: "pep-button", inputs: ["key", "value", "styleType", "styleStateType", "sizeType", "classNames", "disabled", "iconName", "iconPosition", "visible"], outputs: ["buttonClick"] }, { kind: "component", type: i5.DraggableItemComponent, selector: "pep-draggable-item", inputs: ["title", "titlePrefix", "titleClassNames", "data", "disabled", "shadow", "styleType", "toggleContent", "isToggleContentOpen", "actionsMenu", "menuStyleType"], outputs: ["contentToggle", "actionsMenuItemClick"] }] });
|
|
89
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: SectionBlockComponent, decorators: [{
|
|
90
|
+
type: Component,
|
|
91
|
+
args: [{ selector: 'section-block', template: "<div *ngIf=\"blockContainer?.BlockKey && (editable || !hideForCurrentScreenType)\" \n class=\"section-block-container\"\n [ngClass]=\"{ 'editable-state': editable, 'block-hidden-state': hideForCurrentScreenType, 'active-block': active }\"\n cdkDrag [cdkDragData]=\"blockContainer\" [cdkDragDisabled]=\"!editable || !isMainEditorState\" \n (cdkDragStarted)=\"onDragStart($event)\" (cdkDragEnded)=\"onDragEnd($event)\"\n (cdkDragExited)=\"onDragExited($event)\" (cdkDragEntered)=\"onDragEntered($event)\">\n \n <pep-draggable-item *ngIf=\"editable && isMainEditorState\" cdkDragHandle style=\"cursor: grab;\"\n class=\"block-toolbar\" [title]=\"blockTitle\" >\n <ng-container pep-actions>\n <pep-button classNames=\"caution\" sizeType=\"xs\" iconName=\"system_bin\" (buttonClick)=\"onRemoveBlockClick();\"></pep-button>\n <!-- <hide-in [hideIn]=\"blockContainer.Hide\" (hideInChange)=\"onHideBlockChange($event)\"></hide-in> -->\n <pep-button sizeType=\"xs\" iconName=\"system_edit\" (buttonClick)=\"onEditBlockClick();\"></pep-button>\n </ng-container>\n </pep-draggable-item>\n <div class=\"block-template-wrapper\" [ngStyle]=\"{ 'overflow': (sectionHeight === 'unset' ? 'unset' : 'auto') }\">\n <div *ngIf=\"blockTemplate\" class=\"block-template\">\n <ng-container *ngTemplateOutlet=\"blockTemplate; context: { blockKey: blockContainer?.BlockKey }\">\n </ng-container>\n </div>\n </div>\n</div>\n", styles: [".section-block-container{height:100%;width:100%}.section-block-container.editable-state:not(.active-block) .block-template-wrapper .block-template{pointer-events:none;opacity:.5}.section-block-container.editable-state.cdk-drag-preview .block-template-wrapper,.section-block-container.editable-state.cdk-drag-placeholder .block-toolbar{opacity:0}.section-block-container.editable-state .block-toolbar{position:absolute;top:50%;left:50%;width:95%;max-width:240px;transform:translate(-50%,-50%);z-index:3}.section-block-container.editable-state .block-toolbar:hover{z-index:12!important}.section-block-container .block-template-wrapper{height:100%;position:relative}.section-block-container .block-template-wrapper .block-template{display:block;height:100%;width:100%}\n", ".section-block-container.editable-state.block-hidden-state:not(.active-block){background:repeating-linear-gradient(45deg,hsla(var(--pep-color-system-caution-h, 360),var(--pep-color-system-caution-s, 100%),var(--pep-color-system-caution-l, 45%),0),hsla(var(--pep-color-system-caution-h, 360),var(--pep-color-system-caution-s, 100%),var(--pep-color-system-caution-l, 45%),0) .65rem,hsla(var(--pep-color-system-caution-h, 360),var(--pep-color-system-caution-s, 100%),var(--pep-color-system-caution-l, 45%),.32) .65rem,hsla(var(--pep-color-system-caution-h, 360),var(--pep-color-system-caution-s, 100%),var(--pep-color-system-caution-l, 45%),.32) .8rem),repeating-linear-gradient(-45deg,hsla(var(--pep-color-system-caution-h, 360),var(--pep-color-system-caution-s, 100%),var(--pep-color-system-caution-l, 45%),0),hsla(var(--pep-color-system-caution-h, 360),var(--pep-color-system-caution-s, 100%),var(--pep-color-system-caution-l, 45%),0) .65rem,hsla(var(--pep-color-system-caution-h, 360),var(--pep-color-system-caution-s, 100%),var(--pep-color-system-caution-l, 45%),.32) .65rem,hsla(var(--pep-color-system-caution-h, 360),var(--pep-color-system-caution-s, 100%),var(--pep-color-system-caution-l, 45%),.32) .8rem)}\n"] }]
|
|
92
|
+
}], ctorParameters: function () { return [{ type: i1.LayoutBuilderInternalService }]; }, propDecorators: { blockTemplate: [{
|
|
93
|
+
type: Input
|
|
94
|
+
}], sectionKey: [{
|
|
95
|
+
type: Input
|
|
96
|
+
}], sectionHeight: [{
|
|
97
|
+
type: Input
|
|
98
|
+
}], isMainEditorState: [{
|
|
99
|
+
type: Input
|
|
100
|
+
}], editable: [{
|
|
101
|
+
type: Input
|
|
102
|
+
}], active: [{
|
|
103
|
+
type: Input
|
|
104
|
+
}], blockContainer: [{
|
|
105
|
+
type: Input
|
|
106
|
+
}], screenType: [{
|
|
107
|
+
type: Input
|
|
108
|
+
}], dragExited: [{
|
|
109
|
+
type: Output
|
|
110
|
+
}], dragEntered: [{
|
|
111
|
+
type: Output
|
|
112
|
+
}] } });
|
|
113
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"section-block.component.js","sourceRoot":"","sources":["../../../../../projects/ngx-composite-lib/layout-builder/section-block/section-block.component.ts","../../../../../projects/ngx-composite-lib/layout-builder/section-block/section-block.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnDestroy, OnInit, Output, TemplateRef } from '@angular/core';\nimport { CdkDragEnd, CdkDragEnter, CdkDragExit, CdkDragStart } from '@angular/cdk/drag-drop';\n\nimport { DataViewScreenSize } from '@pepperi-addons/papi-sdk';\nimport { BaseDestroyerDirective } from '@pepperi-addons/ngx-lib';\nimport { IPepDraggableItem } from '@pepperi-addons/ngx-lib/draggable-items';\nimport { PepRemoteLoaderOptions } from '@pepperi-addons/ngx-lib/remote-loader';\nimport { LayoutBuilderInternalService } from '../layout-builder-internal.service';\nimport { IPepLayoutBlockContainer } from '../layout-builder.model';\n\n@Component({\n    selector: 'section-block',\n    templateUrl: './section-block.component.html',\n    styleUrls: ['./section-block.component.scss', './section-block.component.theme.scss']\n})\nexport class SectionBlockComponent extends BaseDestroyerDirective implements OnInit {\n    \n    @Input() blockTemplate: TemplateRef<any> | undefined;\n    @Input() sectionKey = '';\n    @Input() sectionHeight = '';\n    @Input() isMainEditorState = false;\n    @Input() editable = false;\n    @Input() active = false;\n    \n    private _blockContainer: IPepLayoutBlockContainer | undefined;\n    @Input()\n    set blockContainer(value: IPepLayoutBlockContainer | undefined) {\n        this._blockContainer = value;\n        // if (this._blockContainer) {\n        //     this.availableBlock = this.layoutBuilderInternalService.availableBlocksForDragMap?.get(this._blockContainer?.DraggableItemKey);\n        // }\n        \n        this.setIfHideForCurrentScreenType();\n    }\n    get blockContainer(): IPepLayoutBlockContainer | undefined {\n        return this._blockContainer;\n    }\n\n    private _screenType!: DataViewScreenSize;\n    @Input()\n    set screenType(value: DataViewScreenSize) {\n        this._screenType = value;\n        this.setIfHideForCurrentScreenType();\n    }\n    get screenType(): DataViewScreenSize {\n        return this._screenType;\n    }\n    \n    @Output() dragExited: EventEmitter<CdkDragExit> = new EventEmitter();\n    @Output() dragEntered: EventEmitter<CdkDragEnter> = new EventEmitter();\n\n    protected hideForCurrentScreenType = false;\n    // protected remoteLoaderOptions: PepRemoteLoaderOptions;\n    // protected availableBlock: IPepDraggableItem | undefined;\n    protected blockTitle = '';\n\n    constructor(\n        private layoutBuilderInternalService: LayoutBuilderInternalService,\n    ) {\n        super();\n    }\n    \n    private setIfHideForCurrentScreenType(): void {\n        this.hideForCurrentScreenType = this.blockContainer ? \n            this.layoutBuilderInternalService.getIsHidden(this.blockContainer.Hide, this.screenType) : false;\n    }\n    \n    ngOnInit(): void {\n        this.blockTitle = this.layoutBuilderInternalService.getBlockTitle(this.blockContainer?.BlockKey || '');\n        // \n        // this.layoutBuilderInternalService.availableBlocksForDragMapChange$.pipe(this.getDestroyer()).subscribe((availableBlocksForDragMap) => {\n        //     if (availableBlocksForDragMap && this.blockContainer) {\n        //         this.availableBlock = (availableBlocksForDragMap as ReadonlyMap<string, IPepDraggableItem>).get(this.blockContainer.DraggableItemKey);\n        //     }\n        // });\n    }\n\n    onEditBlockClick() {\n        if (this.blockContainer?.BlockKey) {\n            this.layoutBuilderInternalService.navigateToEditor('block', this.blockContainer.BlockKey, this.blockTitle);\n        }\n    }\n\n    onRemoveBlockClick() {\n        if (this.blockContainer?.BlockKey) {\n            this.layoutBuilderInternalService.removeBlockFromSection(this.blockContainer.BlockKey);\n        }\n    }\n\n    onHideBlockChange(hideIn: DataViewScreenSize[]) {\n        if (this.blockContainer?.BlockKey) {\n            this.layoutBuilderInternalService.hideBlock(this.sectionKey, this.blockContainer.BlockKey, hideIn);\n            this.setIfHideForCurrentScreenType();\n        }\n    }\n\n    // onBlockLoad(event: any) {\n    //     this.layoutBuilderService.updateBlockLoaded(this.blockContainer.BlockKey);\n    // }\n\n    onDragStart(event: CdkDragStart) {\n        this.layoutBuilderInternalService.onBlockDragStart(event);\n    }\n\n    onDragEnd(event: CdkDragEnd) {\n        this.layoutBuilderInternalService.onBlockDragEnd(event);\n    }\n\n    onDragExited(event: CdkDragExit) {\n        this.dragExited.emit(event);\n    }\n\n    onDragEntered(event: CdkDragEnter) {\n        this.dragEntered.emit(event);\n    }\n}\n","<div *ngIf=\"blockContainer?.BlockKey && (editable || !hideForCurrentScreenType)\" \n    class=\"section-block-container\"\n    [ngClass]=\"{ 'editable-state': editable, 'block-hidden-state': hideForCurrentScreenType, 'active-block': active }\"\n    cdkDrag [cdkDragData]=\"blockContainer\" [cdkDragDisabled]=\"!editable || !isMainEditorState\" \n    (cdkDragStarted)=\"onDragStart($event)\" (cdkDragEnded)=\"onDragEnd($event)\"\n    (cdkDragExited)=\"onDragExited($event)\" (cdkDragEntered)=\"onDragEntered($event)\">\n   \n    <pep-draggable-item *ngIf=\"editable && isMainEditorState\" cdkDragHandle style=\"cursor: grab;\"\n        class=\"block-toolbar\" [title]=\"blockTitle\" >\n        <ng-container pep-actions>\n            <pep-button classNames=\"caution\" sizeType=\"xs\" iconName=\"system_bin\" (buttonClick)=\"onRemoveBlockClick();\"></pep-button>\n            <!-- <hide-in [hideIn]=\"blockContainer.Hide\" (hideInChange)=\"onHideBlockChange($event)\"></hide-in> -->\n            <pep-button sizeType=\"xs\" iconName=\"system_edit\" (buttonClick)=\"onEditBlockClick();\"></pep-button>\n        </ng-container>\n    </pep-draggable-item>\n    <div class=\"block-template-wrapper\" [ngStyle]=\"{ 'overflow': (sectionHeight === 'unset' ? 'unset' : 'auto') }\">\n        <div *ngIf=\"blockTemplate\" class=\"block-template\">\n            <ng-container *ngTemplateOutlet=\"blockTemplate; context: { blockKey: blockContainer?.BlockKey }\">\n            </ng-container>\n        </div>\n    </div>\n</div>\n"]}
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
import { NgModule } from '@angular/core';
|
|
2
|
+
import { CommonModule } from '@angular/common';
|
|
3
|
+
import { SectionBlockComponent } from './section-block.component';
|
|
4
|
+
import { DragDropModule } from '@angular/cdk/drag-drop';
|
|
5
|
+
import { PepButtonModule } from '@pepperi-addons/ngx-lib/button';
|
|
6
|
+
import { PepDraggableItemsModule } from '@pepperi-addons/ngx-lib/draggable-items';
|
|
7
|
+
import * as i0 from "@angular/core";
|
|
8
|
+
export class SectionBlockModule {
|
|
9
|
+
}
|
|
10
|
+
SectionBlockModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: SectionBlockModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
11
|
+
SectionBlockModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.0.2", ngImport: i0, type: SectionBlockModule, declarations: [SectionBlockComponent], imports: [CommonModule,
|
|
12
|
+
DragDropModule,
|
|
13
|
+
PepButtonModule,
|
|
14
|
+
PepDraggableItemsModule], exports: [SectionBlockComponent] });
|
|
15
|
+
SectionBlockModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: SectionBlockModule, imports: [CommonModule,
|
|
16
|
+
DragDropModule,
|
|
17
|
+
PepButtonModule,
|
|
18
|
+
PepDraggableItemsModule] });
|
|
19
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: SectionBlockModule, decorators: [{
|
|
20
|
+
type: NgModule,
|
|
21
|
+
args: [{
|
|
22
|
+
declarations: [
|
|
23
|
+
SectionBlockComponent,
|
|
24
|
+
],
|
|
25
|
+
imports: [
|
|
26
|
+
CommonModule,
|
|
27
|
+
DragDropModule,
|
|
28
|
+
PepButtonModule,
|
|
29
|
+
PepDraggableItemsModule,
|
|
30
|
+
],
|
|
31
|
+
exports: [SectionBlockComponent]
|
|
32
|
+
}]
|
|
33
|
+
}] });
|
|
34
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VjdGlvbi1ibG9jay5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtY29tcG9zaXRlLWxpYi9sYXlvdXQtYnVpbGRlci9zZWN0aW9uLWJsb2NrL3NlY3Rpb24tYmxvY2subW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxxQkFBcUIsRUFBRSxNQUFNLDJCQUEyQixDQUFBO0FBQ2pFLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUN4RCxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sZ0NBQWdDLENBQUM7QUFDakUsT0FBTyxFQUFFLHVCQUF1QixFQUFFLE1BQU0seUNBQXlDLENBQUM7O0FBY2xGLE1BQU0sT0FBTyxrQkFBa0I7OytHQUFsQixrQkFBa0I7Z0hBQWxCLGtCQUFrQixpQkFWdkIscUJBQXFCLGFBR3JCLFlBQVk7UUFDWixjQUFjO1FBQ2QsZUFBZTtRQUNmLHVCQUF1QixhQUVqQixxQkFBcUI7Z0hBRXRCLGtCQUFrQixZQVB2QixZQUFZO1FBQ1osY0FBYztRQUNkLGVBQWU7UUFDZix1QkFBdUI7MkZBSWxCLGtCQUFrQjtrQkFaOUIsUUFBUTttQkFBQztvQkFDTixZQUFZLEVBQUU7d0JBQ1YscUJBQXFCO3FCQUN4QjtvQkFDRCxPQUFPLEVBQUU7d0JBQ0wsWUFBWTt3QkFDWixjQUFjO3dCQUNkLGVBQWU7d0JBQ2YsdUJBQXVCO3FCQUMxQjtvQkFDRCxPQUFPLEVBQUUsQ0FBQyxxQkFBcUIsQ0FBQztpQkFDbkMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcbmltcG9ydCB7IFNlY3Rpb25CbG9ja0NvbXBvbmVudCB9IGZyb20gJy4vc2VjdGlvbi1ibG9jay5jb21wb25lbnQnXG5pbXBvcnQgeyBEcmFnRHJvcE1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2Nkay9kcmFnLWRyb3AnO1xuaW1wb3J0IHsgUGVwQnV0dG9uTW9kdWxlIH0gZnJvbSAnQHBlcHBlcmktYWRkb25zL25neC1saWIvYnV0dG9uJztcbmltcG9ydCB7IFBlcERyYWdnYWJsZUl0ZW1zTW9kdWxlIH0gZnJvbSAnQHBlcHBlcmktYWRkb25zL25neC1saWIvZHJhZ2dhYmxlLWl0ZW1zJztcblxuQE5nTW9kdWxlKHtcbiAgICBkZWNsYXJhdGlvbnM6IFtcbiAgICAgICAgU2VjdGlvbkJsb2NrQ29tcG9uZW50LFxuICAgIF0sXG4gICAgaW1wb3J0czogW1xuICAgICAgICBDb21tb25Nb2R1bGUsXG4gICAgICAgIERyYWdEcm9wTW9kdWxlLFxuICAgICAgICBQZXBCdXR0b25Nb2R1bGUsXG4gICAgICAgIFBlcERyYWdnYWJsZUl0ZW1zTW9kdWxlLFxuICAgIF0sXG4gICAgZXhwb3J0czogW1NlY3Rpb25CbG9ja0NvbXBvbmVudF1cbn0pXG5leHBvcnQgY2xhc3MgU2VjdGlvbkJsb2NrTW9kdWxlIHsgfVxuIl19
|
|
@@ -0,0 +1,192 @@
|
|
|
1
|
+
import { coerceNumberProperty } from '@angular/cdk/coercion';
|
|
2
|
+
import { Component, EventEmitter, Input, Output } from '@angular/core';
|
|
3
|
+
import { PepDialogActionButton, PepDialogData } from '@pepperi-addons/ngx-lib/dialog';
|
|
4
|
+
import * as i0 from "@angular/core";
|
|
5
|
+
import * as i1 from "@ngx-translate/core";
|
|
6
|
+
import * as i2 from "@pepperi-addons/ngx-lib/dialog";
|
|
7
|
+
import * as i3 from "@pepperi-addons/ngx-lib/textbox";
|
|
8
|
+
import * as i4 from "@pepperi-addons/ngx-lib/select";
|
|
9
|
+
import * as i5 from "@pepperi-addons/ngx-lib/checkbox";
|
|
10
|
+
import * as i6 from "../layout-builder-editor/layout-builder-editor.component";
|
|
11
|
+
export class SectionEditorComponent {
|
|
12
|
+
constructor(translate, dialog) {
|
|
13
|
+
this.translate = translate;
|
|
14
|
+
this.dialog = dialog;
|
|
15
|
+
this.MIN_HEIGHT = 40;
|
|
16
|
+
this.sectionName = '';
|
|
17
|
+
this.isAutoHeight = true;
|
|
18
|
+
this.height = this.MIN_HEIGHT;
|
|
19
|
+
this.hostObjectChange = new EventEmitter();
|
|
20
|
+
this.collapseOnTablet = false;
|
|
21
|
+
this.fillHeight = false;
|
|
22
|
+
this.subSections = false;
|
|
23
|
+
this.partsNumber = "2";
|
|
24
|
+
this.partsNumberOptions = Array();
|
|
25
|
+
this.splitOptions = Array();
|
|
26
|
+
this.allSplitOptions = Array();
|
|
27
|
+
this.initData();
|
|
28
|
+
}
|
|
29
|
+
set hostObject(value) {
|
|
30
|
+
this._hostObject = value;
|
|
31
|
+
this.sectionName = value.sectionName;
|
|
32
|
+
this.split = value.split;
|
|
33
|
+
this.isAutoHeight = !value.height || value.height === 0;
|
|
34
|
+
this.height = this.isAutoHeight ? this.MIN_HEIGHT : value.height;
|
|
35
|
+
this.collapseOnTablet = value.collapseOnTablet ?? false;
|
|
36
|
+
this.fillHeight = value.fillHeight ?? false;
|
|
37
|
+
}
|
|
38
|
+
get hostObject() {
|
|
39
|
+
return this._hostObject;
|
|
40
|
+
}
|
|
41
|
+
set split(value) {
|
|
42
|
+
this._split = value;
|
|
43
|
+
this.subSections = (this._split && this._split.length > 0) ? true : false;
|
|
44
|
+
// Check how many parts we have.
|
|
45
|
+
const arr = value?.split(' ');
|
|
46
|
+
if (arr && arr.length > 1 && arr.length <= 4) {
|
|
47
|
+
this.partsNumber = arr.length.toString();
|
|
48
|
+
}
|
|
49
|
+
else {
|
|
50
|
+
this.partsNumber = "2";
|
|
51
|
+
}
|
|
52
|
+
this.loadSplitOptions();
|
|
53
|
+
}
|
|
54
|
+
get split() {
|
|
55
|
+
return this._split;
|
|
56
|
+
}
|
|
57
|
+
initData() {
|
|
58
|
+
this.partsNumberOptions = [
|
|
59
|
+
{ 'key': '2', 'value': '2 Parts' },
|
|
60
|
+
{ 'key': '3', 'value': '3 Parts' },
|
|
61
|
+
{ 'key': '4', 'value': '4 Parts' }
|
|
62
|
+
];
|
|
63
|
+
this.allSplitOptions = [
|
|
64
|
+
{ 'key': '2', 'value': [
|
|
65
|
+
{ 'key': '1/4 3/4', 'value': '1/4-3/4' },
|
|
66
|
+
{ 'key': '1/3 2/3', 'value': '1/3-2/3' },
|
|
67
|
+
{ 'key': '1/2 1/2', 'value': '1/2-1/2' },
|
|
68
|
+
{ 'key': '2/3 1/3', 'value': '2/3-1/3' },
|
|
69
|
+
{ 'key': '3/4 1/4', 'value': '3/4-1/4' },
|
|
70
|
+
] },
|
|
71
|
+
{ 'key': '3', 'value': [
|
|
72
|
+
{ 'key': '1/3 1/3 1/3', 'value': '1/3-1/3-1/3' },
|
|
73
|
+
{ 'key': '1/2 1/4 1/4', 'value': '1/2-1/4-1/4' },
|
|
74
|
+
{ 'key': '1/4 1/2 1/4', 'value': '1/4-1/2-1/4' },
|
|
75
|
+
{ 'key': '1/4 1/4 1/2', 'value': '1/4-1/4-1/2' },
|
|
76
|
+
] },
|
|
77
|
+
{ 'key': '4', 'value': [
|
|
78
|
+
{ 'key': '1/4 1/4 1/4 1/4', 'value': '1/4-1/4-1/4-1/4' },
|
|
79
|
+
] }
|
|
80
|
+
];
|
|
81
|
+
}
|
|
82
|
+
loadSplitOptions() {
|
|
83
|
+
const splitOptions = this.allSplitOptions.find((option) => option.key === this.partsNumber);
|
|
84
|
+
if (splitOptions) {
|
|
85
|
+
this.splitOptions = splitOptions.value;
|
|
86
|
+
}
|
|
87
|
+
else {
|
|
88
|
+
this.splitOptions = this.allSplitOptions[0].value;
|
|
89
|
+
}
|
|
90
|
+
if (!this._split) {
|
|
91
|
+
this._split = this.splitOptions[0].key;
|
|
92
|
+
}
|
|
93
|
+
}
|
|
94
|
+
updateHostObject() {
|
|
95
|
+
this._hostObject.sectionName = this.sectionName;
|
|
96
|
+
this._hostObject.split = this.subSections ? this.split : undefined;
|
|
97
|
+
this._hostObject.height = this.isAutoHeight ? 0 : this.height;
|
|
98
|
+
this._hostObject.collapseOnTablet = this.collapseOnTablet;
|
|
99
|
+
this._hostObject.fillHeight = this.fillHeight;
|
|
100
|
+
this.hostObjectChange.emit(this.hostObject);
|
|
101
|
+
}
|
|
102
|
+
ngOnInit() {
|
|
103
|
+
this.loadSplitOptions();
|
|
104
|
+
}
|
|
105
|
+
isAutoHeightChange(isChecked) {
|
|
106
|
+
this.isAutoHeight = isChecked;
|
|
107
|
+
this.updateHostObject();
|
|
108
|
+
}
|
|
109
|
+
onHeightChange(height) {
|
|
110
|
+
if (height >= this.MIN_HEIGHT) {
|
|
111
|
+
this.height = coerceNumberProperty(height, this.height);
|
|
112
|
+
this.updateHostObject();
|
|
113
|
+
}
|
|
114
|
+
}
|
|
115
|
+
onSectionNameChange(value) {
|
|
116
|
+
this.sectionName = value;
|
|
117
|
+
this.updateHostObject();
|
|
118
|
+
}
|
|
119
|
+
onCollapseOnTabletChange(value) {
|
|
120
|
+
this.collapseOnTablet = value;
|
|
121
|
+
this.updateHostObject();
|
|
122
|
+
}
|
|
123
|
+
onFillHeightChange(value) {
|
|
124
|
+
this.fillHeight = value;
|
|
125
|
+
this.updateHostObject();
|
|
126
|
+
}
|
|
127
|
+
onSubSectionsChange(value) {
|
|
128
|
+
const oldValue = this.subSections;
|
|
129
|
+
// Check if cancel the sub sections ( change from any -> 1 section ), if true need to show confirm message
|
|
130
|
+
if (value === false) {
|
|
131
|
+
this.subSections = value;
|
|
132
|
+
this.showDeleteSectionMsg(() => {
|
|
133
|
+
this.updateHostObject();
|
|
134
|
+
}, () => {
|
|
135
|
+
this.subSections = oldValue;
|
|
136
|
+
});
|
|
137
|
+
}
|
|
138
|
+
else {
|
|
139
|
+
this.subSections = value;
|
|
140
|
+
this.updateHostObject();
|
|
141
|
+
}
|
|
142
|
+
}
|
|
143
|
+
onPartsNumberChange(key) {
|
|
144
|
+
const oldKey = this.partsNumber;
|
|
145
|
+
// Check if decrease on sub sections number, if true need to show confirm message
|
|
146
|
+
if (key && parseInt(key) < parseInt(this.partsNumber)) {
|
|
147
|
+
this.partsNumber = key;
|
|
148
|
+
this.showDeleteSectionMsg(() => {
|
|
149
|
+
this.loadSplitOptions();
|
|
150
|
+
this._split = this.splitOptions[0].key;
|
|
151
|
+
this.updateHostObject();
|
|
152
|
+
}, () => {
|
|
153
|
+
this.partsNumber = oldKey;
|
|
154
|
+
});
|
|
155
|
+
}
|
|
156
|
+
else {
|
|
157
|
+
this.partsNumber = key;
|
|
158
|
+
this.loadSplitOptions();
|
|
159
|
+
this._split = this.splitOptions[0].key;
|
|
160
|
+
this.updateHostObject();
|
|
161
|
+
}
|
|
162
|
+
}
|
|
163
|
+
showDeleteSectionMsg(continueCB, cancelCB) {
|
|
164
|
+
const actionButtons = [
|
|
165
|
+
new PepDialogActionButton(this.translate.instant('ACTIONS.CANCEL'), '', () => {
|
|
166
|
+
cancelCB();
|
|
167
|
+
}),
|
|
168
|
+
new PepDialogActionButton(this.translate.instant('ACTIONS.CONTINUE'), 'strong caution', () => {
|
|
169
|
+
continueCB();
|
|
170
|
+
})
|
|
171
|
+
];
|
|
172
|
+
const content = this.translate.instant('LAYOUT_BUILDER.DELETE_SECTION_MSG');
|
|
173
|
+
const title = this.translate.instant('LAYOUT_BUILDER.DELETE_SECTION_TITLE');
|
|
174
|
+
const dataMsg = new PepDialogData({ title, actionsType: 'custom', content, actionButtons });
|
|
175
|
+
this.dialog.openDefaultDialog(dataMsg);
|
|
176
|
+
}
|
|
177
|
+
onSplitChange(key) {
|
|
178
|
+
this._split = key;
|
|
179
|
+
this.updateHostObject();
|
|
180
|
+
}
|
|
181
|
+
}
|
|
182
|
+
SectionEditorComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: SectionEditorComponent, deps: [{ token: i1.TranslateService }, { token: i2.PepDialogService }], target: i0.ɵɵFactoryTarget.Component });
|
|
183
|
+
SectionEditorComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.0.2", type: SectionEditorComponent, selector: "section-editor", inputs: { hostObject: "hostObject" }, outputs: { hostObjectChange: "hostObjectChange" }, ngImport: i0, template: "<pep-layout-builder-editor class=\"section-editor-container\">\n <div>\n <pep-textbox [value]=\"sectionName\" [label]=\"'LAYOUT_BUILDER.SECTION_NAME_TITLE' | translate\" (valueChange)=\"onSectionNameChange($event)\"></pep-textbox>\n </div>\n <!-- \n <div>\n <pep-checkbox class=\"checkbox-as-title\" [value]=\"isAutoHeight\" [label]=\"'LAYOUT_BUILDER.AUTO_HEIGHT_TITLE' | translate\" [renderTitle]=\"false\" (valueChange)=\"isAutoHeightChange($event)\"></pep-checkbox>\n <pep-textbox [label]=\"'LAYOUT_BUILDER.HEIGHT_TITLE' | translate\" type=\"int\" [minValue]=\"MIN_HEIGHT\" [disabled]=\"isAutoHeight\" [value]=\"height\" (valueChange)=\"onHeightChange($event)\"></pep-textbox> \n </div>\n -->\n <div class=\"editor-separator\"></div>\n <div>\n <pep-checkbox class=\"checkbox-as-title\" [value]=\"subSections\" [label]=\"'LAYOUT_BUILDER.SUB_SECTION_TITLE' | translate\" [renderTitle]=\"false\" (valueChange)=\"onSubSectionsChange($event)\"></pep-checkbox>\n <div class=\"split-area\">\n <pep-select [label]=\"'LAYOUT_BUILDER.SECTIONS_TITLE' | translate\" [value]=\"partsNumber\" [options]=\"partsNumberOptions\" \n (valueChange)=\"onPartsNumberChange($event)\" [emptyOption]=\"false\" [disabled]=\"!subSections\"></pep-select>\n <pep-select [label]=\"'LAYOUT_BUILDER.SPLIT_TITLE' | translate\" [value]=\"split || ''\" [options]=\"splitOptions\"\n (valueChange)=\"onSplitChange($event)\" [emptyOption]=\"false\" [disabled]=\"!subSections\"></pep-select>\n </div>\n </div>\n <div class=\"editor-separator\"></div>\n <div>\n <pep-checkbox class=\"checkbox-as-title\" [value]=\"collapseOnTablet\" [label]=\"'LAYOUT_BUILDER.COLLAPSE_ON_TABLET_TITLE' | translate\" [renderTitle]=\"false\" (valueChange)=\"onCollapseOnTabletChange($event)\"></pep-checkbox>\n <span class=\"header-title body-xs\">{{('LAYOUT_BUILDER.COLLAPSE_ON_TABLET_DESCRIPTION' | translate)}}</span>\n </div>\n <div class=\"editor-separator\"></div>\n <div>\n <pep-checkbox class=\"checkbox-as-title\" [value]=\"fillHeight\" [label]=\"'LAYOUT_BUILDER.FILL_HEIGHT_SECTION_TITLE' | translate\" [renderTitle]=\"false\" (valueChange)=\"onFillHeightChange($event)\"></pep-checkbox>\n <span class=\"header-title body-xs\">{{('LAYOUT_BUILDER.FILL_HEIGHT_SECTION_DESCRIPTION' | translate)}}</span>\n </div>\n</pep-layout-builder-editor>\n\n<!-- <div class=\"section-editor-container layout-builder-editor-container\">\n <div>\n <pep-textbox [value]=\"sectionName\" [label]=\"'LAYOUT_BUILDER.SECTION_NAME_TITLE' | translate\" (valueChange)=\"onSectionNameChange($event)\"></pep-textbox>\n </div>\n <div class=\"editor-separator\"></div>\n <div>\n <pep-checkbox class=\"checkbox-as-title\" [value]=\"subSections\" [label]=\"'LAYOUT_BUILDER.SUB_SECTION_TITLE' | translate\" [renderTitle]=\"false\" (valueChange)=\"onSubSectionsChange($event)\"></pep-checkbox>\n <div class=\"split-area\">\n <pep-select [label]=\"'LAYOUT_BUILDER.SECTIONS_TITLE' | translate\" [value]=\"partsNumber\" [options]=\"partsNumberOptions\" \n (valueChange)=\"onPartsNumberChange($event)\" [emptyOption]=\"false\" [disabled]=\"!subSections\"></pep-select>\n <pep-select [label]=\"'LAYOUT_BUILDER.SPLIT_TITLE' | translate\" [value]=\"split || ''\" [options]=\"splitOptions\"\n (valueChange)=\"onSplitChange($event)\" [emptyOption]=\"false\" [disabled]=\"!subSections\"></pep-select>\n </div>\n </div>\n <div class=\"editor-separator\"></div>\n <div>\n <pep-checkbox class=\"checkbox-as-title\" [value]=\"collapseOnTablet\" [label]=\"'LAYOUT_BUILDER.COLLAPSE_ON_TABLET_TITLE' | translate\" [renderTitle]=\"false\" (valueChange)=\"onCollapseOnTabletChange($event)\"></pep-checkbox>\n <span class=\"header-title body-xs\">{{('LAYOUT_BUILDER.COLLAPSE_ON_TABLET_DESCRIPTION' | translate)}}</span>\n </div>\n <div class=\"editor-separator\"></div>\n <div>\n <pep-checkbox class=\"checkbox-as-title\" [value]=\"fillHeight\" [label]=\"'LAYOUT_BUILDER.FILL_HEIGHT_SECTION_TITLE' | translate\" [renderTitle]=\"false\" (valueChange)=\"onFillHeightChange($event)\"></pep-checkbox>\n <span class=\"header-title body-xs\">{{('LAYOUT_BUILDER.FILL_HEIGHT_SECTION_DESCRIPTION' | translate)}}</span>\n </div>\n</div> -->\n", styles: [".section-editor-container .split-area{display:grid;grid-template-columns:1fr 1fr;gap:var(--pep-spacing-lg, 1rem)}\n"], dependencies: [{ kind: "component", type: i3.PepTextboxComponent, selector: "pep-textbox", inputs: ["key", "value", "minFractionDigits", "maxFractionDigits", "accessory", "label", "placeholder", "type", "mandatory", "disabled", "readonly", "maxFieldCharacters", "hint", "textColor", "xAlignment", "rowSpan", "minValue", "maxValue", "visible", "form", "isActive", "showTitle", "renderTitle", "renderError", "renderSymbol", "layoutType", "parentFieldKey", "regex", "regexError", "isInFocus"], outputs: ["valueChange", "keyup"] }, { kind: "component", type: i4.PepSelectComponent, selector: "pep-select", inputs: ["key", "value", "label", "type", "mandatory", "disabled", "readonly", "xAlignment", "rowSpan", "placeholder", "placeholderWhenDisabled", "options", "visible", "emptyOption", "form", "layoutType", "parentFieldKey", "isActive", "showTitle", "renderTitle", "typeaheadDebounceInterval", "addValueToOptionsIfNotExist"], outputs: ["valueChange"] }, { kind: "component", type: i5.PepCheckboxComponent, selector: "pep-checkbox", inputs: ["key", "value", "label", "type", "mandatory", "disabled", "readonly", "xAlignment", "rowSpan", "additionalValue", "form", "isActive", "showTitle", "renderTitle", "layoutType", "visible"], outputs: ["valueChange"] }, { kind: "component", type: i6.PepLayoutBuilderEditorComponent, selector: "pep-layout-builder-editor", inputs: ["editorTabs"] }, { kind: "pipe", type: i1.TranslatePipe, name: "translate" }] });
|
|
184
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: SectionEditorComponent, decorators: [{
|
|
185
|
+
type: Component,
|
|
186
|
+
args: [{ selector: 'section-editor', template: "<pep-layout-builder-editor class=\"section-editor-container\">\n <div>\n <pep-textbox [value]=\"sectionName\" [label]=\"'LAYOUT_BUILDER.SECTION_NAME_TITLE' | translate\" (valueChange)=\"onSectionNameChange($event)\"></pep-textbox>\n </div>\n <!-- \n <div>\n <pep-checkbox class=\"checkbox-as-title\" [value]=\"isAutoHeight\" [label]=\"'LAYOUT_BUILDER.AUTO_HEIGHT_TITLE' | translate\" [renderTitle]=\"false\" (valueChange)=\"isAutoHeightChange($event)\"></pep-checkbox>\n <pep-textbox [label]=\"'LAYOUT_BUILDER.HEIGHT_TITLE' | translate\" type=\"int\" [minValue]=\"MIN_HEIGHT\" [disabled]=\"isAutoHeight\" [value]=\"height\" (valueChange)=\"onHeightChange($event)\"></pep-textbox> \n </div>\n -->\n <div class=\"editor-separator\"></div>\n <div>\n <pep-checkbox class=\"checkbox-as-title\" [value]=\"subSections\" [label]=\"'LAYOUT_BUILDER.SUB_SECTION_TITLE' | translate\" [renderTitle]=\"false\" (valueChange)=\"onSubSectionsChange($event)\"></pep-checkbox>\n <div class=\"split-area\">\n <pep-select [label]=\"'LAYOUT_BUILDER.SECTIONS_TITLE' | translate\" [value]=\"partsNumber\" [options]=\"partsNumberOptions\" \n (valueChange)=\"onPartsNumberChange($event)\" [emptyOption]=\"false\" [disabled]=\"!subSections\"></pep-select>\n <pep-select [label]=\"'LAYOUT_BUILDER.SPLIT_TITLE' | translate\" [value]=\"split || ''\" [options]=\"splitOptions\"\n (valueChange)=\"onSplitChange($event)\" [emptyOption]=\"false\" [disabled]=\"!subSections\"></pep-select>\n </div>\n </div>\n <div class=\"editor-separator\"></div>\n <div>\n <pep-checkbox class=\"checkbox-as-title\" [value]=\"collapseOnTablet\" [label]=\"'LAYOUT_BUILDER.COLLAPSE_ON_TABLET_TITLE' | translate\" [renderTitle]=\"false\" (valueChange)=\"onCollapseOnTabletChange($event)\"></pep-checkbox>\n <span class=\"header-title body-xs\">{{('LAYOUT_BUILDER.COLLAPSE_ON_TABLET_DESCRIPTION' | translate)}}</span>\n </div>\n <div class=\"editor-separator\"></div>\n <div>\n <pep-checkbox class=\"checkbox-as-title\" [value]=\"fillHeight\" [label]=\"'LAYOUT_BUILDER.FILL_HEIGHT_SECTION_TITLE' | translate\" [renderTitle]=\"false\" (valueChange)=\"onFillHeightChange($event)\"></pep-checkbox>\n <span class=\"header-title body-xs\">{{('LAYOUT_BUILDER.FILL_HEIGHT_SECTION_DESCRIPTION' | translate)}}</span>\n </div>\n</pep-layout-builder-editor>\n\n<!-- <div class=\"section-editor-container layout-builder-editor-container\">\n <div>\n <pep-textbox [value]=\"sectionName\" [label]=\"'LAYOUT_BUILDER.SECTION_NAME_TITLE' | translate\" (valueChange)=\"onSectionNameChange($event)\"></pep-textbox>\n </div>\n <div class=\"editor-separator\"></div>\n <div>\n <pep-checkbox class=\"checkbox-as-title\" [value]=\"subSections\" [label]=\"'LAYOUT_BUILDER.SUB_SECTION_TITLE' | translate\" [renderTitle]=\"false\" (valueChange)=\"onSubSectionsChange($event)\"></pep-checkbox>\n <div class=\"split-area\">\n <pep-select [label]=\"'LAYOUT_BUILDER.SECTIONS_TITLE' | translate\" [value]=\"partsNumber\" [options]=\"partsNumberOptions\" \n (valueChange)=\"onPartsNumberChange($event)\" [emptyOption]=\"false\" [disabled]=\"!subSections\"></pep-select>\n <pep-select [label]=\"'LAYOUT_BUILDER.SPLIT_TITLE' | translate\" [value]=\"split || ''\" [options]=\"splitOptions\"\n (valueChange)=\"onSplitChange($event)\" [emptyOption]=\"false\" [disabled]=\"!subSections\"></pep-select>\n </div>\n </div>\n <div class=\"editor-separator\"></div>\n <div>\n <pep-checkbox class=\"checkbox-as-title\" [value]=\"collapseOnTablet\" [label]=\"'LAYOUT_BUILDER.COLLAPSE_ON_TABLET_TITLE' | translate\" [renderTitle]=\"false\" (valueChange)=\"onCollapseOnTabletChange($event)\"></pep-checkbox>\n <span class=\"header-title body-xs\">{{('LAYOUT_BUILDER.COLLAPSE_ON_TABLET_DESCRIPTION' | translate)}}</span>\n </div>\n <div class=\"editor-separator\"></div>\n <div>\n <pep-checkbox class=\"checkbox-as-title\" [value]=\"fillHeight\" [label]=\"'LAYOUT_BUILDER.FILL_HEIGHT_SECTION_TITLE' | translate\" [renderTitle]=\"false\" (valueChange)=\"onFillHeightChange($event)\"></pep-checkbox>\n <span class=\"header-title body-xs\">{{('LAYOUT_BUILDER.FILL_HEIGHT_SECTION_DESCRIPTION' | translate)}}</span>\n </div>\n</div> -->\n", styles: [".section-editor-container .split-area{display:grid;grid-template-columns:1fr 1fr;gap:var(--pep-spacing-lg, 1rem)}\n"] }]
|
|
187
|
+
}], ctorParameters: function () { return [{ type: i1.TranslateService }, { type: i2.PepDialogService }]; }, propDecorators: { hostObject: [{
|
|
188
|
+
type: Input
|
|
189
|
+
}], hostObjectChange: [{
|
|
190
|
+
type: Output
|
|
191
|
+
}] } });
|
|
192
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"section-editor.component.js","sourceRoot":"","sources":["../../../../../projects/ngx-composite-lib/layout-builder/section-editor/section-editor.component.ts","../../../../../projects/ngx-composite-lib/layout-builder/section-editor/section-editor.component.html"],"names":[],"mappings":"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","sourcesContent":["import { coerceNumberProperty } from '@angular/cdk/coercion';\nimport { Component, EventEmitter, Input, OnInit, Output } from '@angular/core';\nimport { TranslateService } from '@ngx-translate/core';\nimport { IPepOption } from '@pepperi-addons/ngx-lib';\nimport { SplitType } from '@pepperi-addons/papi-sdk';\nimport { PepDialogActionButton, PepDialogData, PepDialogService } from '@pepperi-addons/ngx-lib/dialog';\nimport { ILayoutSectionEditor } from '../layout-builder-internal.service';\n\nexport interface ISplitOption {\n    key: SplitType; \n    value: string;\n}\nexport interface IAllSplitOption {\n    key: string;\n    value: Array<ISplitOption>;\n}\n\n@Component({\n    selector: 'section-editor',\n    templateUrl: './section-editor.component.html',\n    styleUrls: ['./section-editor.component.scss']\n})\nexport class SectionEditorComponent implements OnInit {\n    readonly MIN_HEIGHT = 40;\n    \n    private _hostObject!: ILayoutSectionEditor;\n    @Input()\n    set hostObject(value: ILayoutSectionEditor) {\n        this._hostObject = value;\n\n        this.sectionName = value.sectionName;\n        this.split = value.split;\n        this.isAutoHeight = !value.height || value.height === 0;\n        this.height = this.isAutoHeight ? this.MIN_HEIGHT : value.height;\n        this.collapseOnTablet = value.collapseOnTablet ?? false;\n        this.fillHeight = value.fillHeight ?? false;\n    }\n    get hostObject(): ILayoutSectionEditor {\n        return this._hostObject;\n    }\n\n    sectionName = '';\n    \n    private _split: SplitType | undefined;\n    set split(value: SplitType | undefined) {\n        this._split = value;\n        \n        this.subSections = (this._split && this._split.length > 0) ? true : false;\n\n        // Check how many parts we have.\n        const arr = value?.split(' ');\n        if (arr && arr.length > 1 && arr.length <= 4) {\n            this.partsNumber = arr.length.toString();\n        } else {\n            this.partsNumber = \"2\";\n        }\n        \n        this.loadSplitOptions();\n    }\n    get split(): SplitType | undefined {\n        return this._split;\n    }\n    \n    isAutoHeight = true;\n    height: number = this.MIN_HEIGHT;\n\n    @Output() hostObjectChange: EventEmitter<ILayoutSectionEditor> = new EventEmitter<ILayoutSectionEditor>();\n    \n    collapseOnTablet = false;\n    fillHeight = false;\n    subSections = false;\n    partsNumber = \"2\";\n    partsNumberOptions = Array<IPepOption>();\n    splitOptions = Array<ISplitOption>();\n    allSplitOptions = Array<IAllSplitOption>();\n\n    constructor(private translate: TranslateService, private dialog: PepDialogService) {\n        this.initData();\n    }\n\n    private initData() {\n        this.partsNumberOptions = [\n            { 'key': '2', 'value': '2 Parts' }, \n            { 'key': '3', 'value': '3 Parts' },\n            { 'key': '4', 'value': '4 Parts' }\n        ];\n        \n        this.allSplitOptions = [\n            { 'key': '2', 'value': [\n                { 'key': '1/4 3/4', 'value': '1/4-3/4' },\n                { 'key': '1/3 2/3', 'value': '1/3-2/3' },\n                { 'key': '1/2 1/2', 'value': '1/2-1/2' },\n                { 'key': '2/3 1/3', 'value': '2/3-1/3' },\n                { 'key': '3/4 1/4', 'value': '3/4-1/4' },\n            ]}, \n            { 'key': '3', 'value': [\n                { 'key': '1/3 1/3 1/3', 'value': '1/3-1/3-1/3' },\n                { 'key': '1/2 1/4 1/4', 'value': '1/2-1/4-1/4' },\n                { 'key': '1/4 1/2 1/4', 'value': '1/4-1/2-1/4' },\n                { 'key': '1/4 1/4 1/2', 'value': '1/4-1/4-1/2' },\n            ]},\n            { 'key': '4', 'value': [\n                { 'key': '1/4 1/4 1/4 1/4', 'value': '1/4-1/4-1/4-1/4' },\n            ]}\n        ];\n    }\n\n    private loadSplitOptions() {\n        const splitOptions = this.allSplitOptions.find((option) => option.key === this.partsNumber);\n        if (splitOptions) {\n            this.splitOptions = splitOptions.value;\n        } else {\n            this.splitOptions = this.allSplitOptions[0].value;\n        }\n\n        if (!this._split) {\n            this._split = this.splitOptions[0].key;\n        }\n    }\n\n    private updateHostObject() {\n        this._hostObject.sectionName = this.sectionName;\n        this._hostObject.split = this.subSections ? this.split : undefined;\n        this._hostObject.height = this.isAutoHeight ? 0 : this.height;\n        this._hostObject.collapseOnTablet = this.collapseOnTablet;\n        this._hostObject.fillHeight = this.fillHeight;\n\n        this.hostObjectChange.emit(this.hostObject);\n    }\n\n    ngOnInit(): void {\n        this.loadSplitOptions();\n    }\n    \n    isAutoHeightChange(isChecked: boolean) {\n        this.isAutoHeight = isChecked;\n        this.updateHostObject();\n    }\n\n    onHeightChange(height: number) {\n        if (height >= this.MIN_HEIGHT) {\n            this.height = coerceNumberProperty(height, this.height);\n            this.updateHostObject();\n        }\n    }\n    \n    onSectionNameChange(value: string) {\n        this.sectionName = value;\n        this.updateHostObject();\n    }\n\n    onCollapseOnTabletChange(value: boolean){\n        this.collapseOnTablet = value;\n        this.updateHostObject();\n    }\n\n    onFillHeightChange(value: boolean){\n        this.fillHeight = value;\n        this.updateHostObject();\n    }\n\n    onSubSectionsChange(value: boolean) {\n        const oldValue = this.subSections;\n        // Check if cancel the sub sections ( change from any -> 1 section ), if true need to show confirm message\n        if (value === false) {\n            this.subSections = value;\n            this.showDeleteSectionMsg(() => {\n                this.updateHostObject();\n            }, () => {\n                this.subSections = oldValue;\n            });\n        } else {\n            this.subSections = value;\n            this.updateHostObject();\n        }\n    }\n  \n    onPartsNumberChange(key: string) {\n        const oldKey = this.partsNumber;\n        // Check if decrease on sub sections number, if true need to show confirm message\n        if (key && parseInt(key) < parseInt(this.partsNumber)) {\n            this.partsNumber = key;\n            this.showDeleteSectionMsg(() => {\n                this.loadSplitOptions();\n                this._split = this.splitOptions[0].key;\n                this.updateHostObject();\n            }, () => {\n                this.partsNumber = oldKey;\n            })\n        } else {\n            this.partsNumber = key;\n            this.loadSplitOptions();\n            this._split = this.splitOptions[0].key;\n            this.updateHostObject();\n        }\n    }\n\n    showDeleteSectionMsg(continueCB: () => void, cancelCB: () => void){\n        const actionButtons = [\n            new PepDialogActionButton(\n                this.translate.instant('ACTIONS.CANCEL'),\n                '',\n                () => {\n                    cancelCB();\n                }\n            ),\n            new PepDialogActionButton(\n                this.translate.instant('ACTIONS.CONTINUE'),\n                'strong caution',\n                () => {\n                    continueCB();\n                }\n            )\n        ];\n        \n        const content = this.translate.instant('LAYOUT_BUILDER.DELETE_SECTION_MSG');\n        const title = this.translate.instant('LAYOUT_BUILDER.DELETE_SECTION_TITLE');\n        const dataMsg = new PepDialogData({title, actionsType: 'custom', content, actionButtons});\n\n        this.dialog.openDefaultDialog(dataMsg);\n    }\n\n\n    onSplitChange(key: string) {\n        this._split = key as SplitType;\n        this.updateHostObject();\n    }\n}\n","<pep-layout-builder-editor class=\"section-editor-container\">\n    <div>\n        <pep-textbox [value]=\"sectionName\" [label]=\"'LAYOUT_BUILDER.SECTION_NAME_TITLE' | translate\" (valueChange)=\"onSectionNameChange($event)\"></pep-textbox>\n    </div>\n    <!-- \n    <div>\n        <pep-checkbox class=\"checkbox-as-title\" [value]=\"isAutoHeight\" [label]=\"'LAYOUT_BUILDER.AUTO_HEIGHT_TITLE' | translate\" [renderTitle]=\"false\" (valueChange)=\"isAutoHeightChange($event)\"></pep-checkbox>\n        <pep-textbox [label]=\"'LAYOUT_BUILDER.HEIGHT_TITLE' | translate\" type=\"int\" [minValue]=\"MIN_HEIGHT\" [disabled]=\"isAutoHeight\" [value]=\"height\" (valueChange)=\"onHeightChange($event)\"></pep-textbox> \n    </div>\n    -->\n    <div class=\"editor-separator\"></div>\n    <div>\n        <pep-checkbox class=\"checkbox-as-title\" [value]=\"subSections\" [label]=\"'LAYOUT_BUILDER.SUB_SECTION_TITLE' | translate\" [renderTitle]=\"false\" (valueChange)=\"onSubSectionsChange($event)\"></pep-checkbox>\n        <div class=\"split-area\">\n            <pep-select [label]=\"'LAYOUT_BUILDER.SECTIONS_TITLE' | translate\" [value]=\"partsNumber\" [options]=\"partsNumberOptions\" \n                (valueChange)=\"onPartsNumberChange($event)\" [emptyOption]=\"false\" [disabled]=\"!subSections\"></pep-select>\n            <pep-select [label]=\"'LAYOUT_BUILDER.SPLIT_TITLE' | translate\" [value]=\"split || ''\" [options]=\"splitOptions\"\n                (valueChange)=\"onSplitChange($event)\" [emptyOption]=\"false\" [disabled]=\"!subSections\"></pep-select>\n        </div>\n    </div>\n    <div class=\"editor-separator\"></div>\n    <div>\n        <pep-checkbox class=\"checkbox-as-title\" [value]=\"collapseOnTablet\" [label]=\"'LAYOUT_BUILDER.COLLAPSE_ON_TABLET_TITLE' | translate\" [renderTitle]=\"false\" (valueChange)=\"onCollapseOnTabletChange($event)\"></pep-checkbox>\n        <span class=\"header-title body-xs\">{{('LAYOUT_BUILDER.COLLAPSE_ON_TABLET_DESCRIPTION' | translate)}}</span>\n    </div>\n    <div class=\"editor-separator\"></div>\n    <div>\n        <pep-checkbox class=\"checkbox-as-title\" [value]=\"fillHeight\" [label]=\"'LAYOUT_BUILDER.FILL_HEIGHT_SECTION_TITLE' | translate\" [renderTitle]=\"false\" (valueChange)=\"onFillHeightChange($event)\"></pep-checkbox>\n        <span class=\"header-title body-xs\">{{('LAYOUT_BUILDER.FILL_HEIGHT_SECTION_DESCRIPTION' | translate)}}</span>\n    </div>\n</pep-layout-builder-editor>\n\n<!-- <div class=\"section-editor-container layout-builder-editor-container\">\n    <div>\n        <pep-textbox [value]=\"sectionName\" [label]=\"'LAYOUT_BUILDER.SECTION_NAME_TITLE' | translate\" (valueChange)=\"onSectionNameChange($event)\"></pep-textbox>\n    </div>\n    <div class=\"editor-separator\"></div>\n    <div>\n        <pep-checkbox class=\"checkbox-as-title\" [value]=\"subSections\" [label]=\"'LAYOUT_BUILDER.SUB_SECTION_TITLE' | translate\" [renderTitle]=\"false\" (valueChange)=\"onSubSectionsChange($event)\"></pep-checkbox>\n        <div class=\"split-area\">\n            <pep-select [label]=\"'LAYOUT_BUILDER.SECTIONS_TITLE' | translate\" [value]=\"partsNumber\" [options]=\"partsNumberOptions\" \n                (valueChange)=\"onPartsNumberChange($event)\" [emptyOption]=\"false\" [disabled]=\"!subSections\"></pep-select>\n            <pep-select [label]=\"'LAYOUT_BUILDER.SPLIT_TITLE' | translate\" [value]=\"split || ''\" [options]=\"splitOptions\"\n                (valueChange)=\"onSplitChange($event)\" [emptyOption]=\"false\" [disabled]=\"!subSections\"></pep-select>\n        </div>\n    </div>\n    <div class=\"editor-separator\"></div>\n    <div>\n        <pep-checkbox class=\"checkbox-as-title\" [value]=\"collapseOnTablet\" [label]=\"'LAYOUT_BUILDER.COLLAPSE_ON_TABLET_TITLE' | translate\" [renderTitle]=\"false\" (valueChange)=\"onCollapseOnTabletChange($event)\"></pep-checkbox>\n        <span class=\"header-title body-xs\">{{('LAYOUT_BUILDER.COLLAPSE_ON_TABLET_DESCRIPTION' | translate)}}</span>\n    </div>\n    <div class=\"editor-separator\"></div>\n    <div>\n        <pep-checkbox class=\"checkbox-as-title\" [value]=\"fillHeight\" [label]=\"'LAYOUT_BUILDER.FILL_HEIGHT_SECTION_TITLE' | translate\" [renderTitle]=\"false\" (valueChange)=\"onFillHeightChange($event)\"></pep-checkbox>\n        <span class=\"header-title body-xs\">{{('LAYOUT_BUILDER.FILL_HEIGHT_SECTION_DESCRIPTION' | translate)}}</span>\n    </div>\n</div> -->\n"]}
|
|
@@ -0,0 +1,44 @@
|
|
|
1
|
+
import { NgModule } from '@angular/core';
|
|
2
|
+
import { CommonModule } from '@angular/common';
|
|
3
|
+
import { SectionEditorComponent } from './section-editor.component';
|
|
4
|
+
import { PepButtonModule } from '@pepperi-addons/ngx-lib/button';
|
|
5
|
+
import { PepTextboxModule } from '@pepperi-addons/ngx-lib/textbox';
|
|
6
|
+
import { PepCheckboxModule } from '@pepperi-addons/ngx-lib/checkbox';
|
|
7
|
+
import { PepSelectModule } from '@pepperi-addons/ngx-lib/select';
|
|
8
|
+
import { TranslateModule } from '@ngx-translate/core';
|
|
9
|
+
import { PepLayoutBuilderEditorModule } from '../layout-builder-editor/layout-builder-editor.module';
|
|
10
|
+
import * as i0 from "@angular/core";
|
|
11
|
+
import * as i1 from "@ngx-translate/core";
|
|
12
|
+
export class SectionEditorModule {
|
|
13
|
+
}
|
|
14
|
+
SectionEditorModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: SectionEditorModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
15
|
+
SectionEditorModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.0.2", ngImport: i0, type: SectionEditorModule, declarations: [SectionEditorComponent], imports: [CommonModule,
|
|
16
|
+
PepButtonModule,
|
|
17
|
+
PepTextboxModule,
|
|
18
|
+
PepSelectModule,
|
|
19
|
+
PepCheckboxModule,
|
|
20
|
+
PepLayoutBuilderEditorModule, i1.TranslateModule], exports: [SectionEditorComponent] });
|
|
21
|
+
SectionEditorModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: SectionEditorModule, imports: [CommonModule,
|
|
22
|
+
PepButtonModule,
|
|
23
|
+
PepTextboxModule,
|
|
24
|
+
PepSelectModule,
|
|
25
|
+
PepCheckboxModule,
|
|
26
|
+
PepLayoutBuilderEditorModule,
|
|
27
|
+
TranslateModule.forChild()] });
|
|
28
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.0.2", ngImport: i0, type: SectionEditorModule, decorators: [{
|
|
29
|
+
type: NgModule,
|
|
30
|
+
args: [{
|
|
31
|
+
declarations: [SectionEditorComponent],
|
|
32
|
+
imports: [
|
|
33
|
+
CommonModule,
|
|
34
|
+
PepButtonModule,
|
|
35
|
+
PepTextboxModule,
|
|
36
|
+
PepSelectModule,
|
|
37
|
+
PepCheckboxModule,
|
|
38
|
+
PepLayoutBuilderEditorModule,
|
|
39
|
+
TranslateModule.forChild()
|
|
40
|
+
],
|
|
41
|
+
exports: [SectionEditorComponent]
|
|
42
|
+
}]
|
|
43
|
+
}] });
|
|
44
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VjdGlvbi1lZGl0b3IubW9kdWxlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LWNvbXBvc2l0ZS1saWIvbGF5b3V0LWJ1aWxkZXIvc2VjdGlvbi1lZGl0b3Ivc2VjdGlvbi1lZGl0b3IubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxRQUFRLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDekMsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBQy9DLE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLDRCQUE0QixDQUFBO0FBQ25FLE9BQU8sRUFBRSxlQUFlLEVBQUUsTUFBTSxnQ0FBZ0MsQ0FBQztBQUNqRSxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxpQ0FBaUMsQ0FBQztBQUNuRSxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQztBQUNyRSxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0sZ0NBQWdDLENBQUM7QUFDakUsT0FBTyxFQUFFLGVBQWUsRUFBRSxNQUFNLHFCQUFxQixDQUFDO0FBQ3RELE9BQU8sRUFBRSw0QkFBNEIsRUFBRSxNQUFNLHVEQUF1RCxDQUFDOzs7QUFlckcsTUFBTSxPQUFPLG1CQUFtQjs7Z0hBQW5CLG1CQUFtQjtpSEFBbkIsbUJBQW1CLGlCQVpiLHNCQUFzQixhQUVqQyxZQUFZO1FBQ1osZUFBZTtRQUNmLGdCQUFnQjtRQUNoQixlQUFlO1FBQ2YsaUJBQWlCO1FBQ2pCLDRCQUE0QixpQ0FHdEIsc0JBQXNCO2lIQUV2QixtQkFBbUIsWUFWeEIsWUFBWTtRQUNaLGVBQWU7UUFDZixnQkFBZ0I7UUFDaEIsZUFBZTtRQUNmLGlCQUFpQjtRQUNqQiw0QkFBNEI7UUFDNUIsZUFBZSxDQUFDLFFBQVEsRUFBRTsyRkFJckIsbUJBQW1CO2tCQWIvQixRQUFRO21CQUFDO29CQUNOLFlBQVksRUFBRSxDQUFDLHNCQUFzQixDQUFDO29CQUN0QyxPQUFPLEVBQUU7d0JBQ0wsWUFBWTt3QkFDWixlQUFlO3dCQUNmLGdCQUFnQjt3QkFDaEIsZUFBZTt3QkFDZixpQkFBaUI7d0JBQ2pCLDRCQUE0Qjt3QkFDNUIsZUFBZSxDQUFDLFFBQVEsRUFBRTtxQkFDN0I7b0JBQ0QsT0FBTyxFQUFFLENBQUMsc0JBQXNCLENBQUM7aUJBQ3BDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBTZWN0aW9uRWRpdG9yQ29tcG9uZW50IH0gZnJvbSAnLi9zZWN0aW9uLWVkaXRvci5jb21wb25lbnQnXG5pbXBvcnQgeyBQZXBCdXR0b25Nb2R1bGUgfSBmcm9tICdAcGVwcGVyaS1hZGRvbnMvbmd4LWxpYi9idXR0b24nO1xuaW1wb3J0IHsgUGVwVGV4dGJveE1vZHVsZSB9IGZyb20gJ0BwZXBwZXJpLWFkZG9ucy9uZ3gtbGliL3RleHRib3gnO1xuaW1wb3J0IHsgUGVwQ2hlY2tib3hNb2R1bGUgfSBmcm9tICdAcGVwcGVyaS1hZGRvbnMvbmd4LWxpYi9jaGVja2JveCc7XG5pbXBvcnQgeyBQZXBTZWxlY3RNb2R1bGUgfSBmcm9tICdAcGVwcGVyaS1hZGRvbnMvbmd4LWxpYi9zZWxlY3QnO1xuaW1wb3J0IHsgVHJhbnNsYXRlTW9kdWxlIH0gZnJvbSAnQG5neC10cmFuc2xhdGUvY29yZSc7XG5pbXBvcnQgeyBQZXBMYXlvdXRCdWlsZGVyRWRpdG9yTW9kdWxlIH0gZnJvbSAnLi4vbGF5b3V0LWJ1aWxkZXItZWRpdG9yL2xheW91dC1idWlsZGVyLWVkaXRvci5tb2R1bGUnO1xuXG5ATmdNb2R1bGUoe1xuICAgIGRlY2xhcmF0aW9uczogW1NlY3Rpb25FZGl0b3JDb21wb25lbnRdLFxuICAgIGltcG9ydHM6IFtcbiAgICAgICAgQ29tbW9uTW9kdWxlLFxuICAgICAgICBQZXBCdXR0b25Nb2R1bGUsXG4gICAgICAgIFBlcFRleHRib3hNb2R1bGUsXG4gICAgICAgIFBlcFNlbGVjdE1vZHVsZSxcbiAgICAgICAgUGVwQ2hlY2tib3hNb2R1bGUsXG4gICAgICAgIFBlcExheW91dEJ1aWxkZXJFZGl0b3JNb2R1bGUsXG4gICAgICAgIFRyYW5zbGF0ZU1vZHVsZS5mb3JDaGlsZCgpXG4gICAgXSxcbiAgICBleHBvcnRzOiBbU2VjdGlvbkVkaXRvckNvbXBvbmVudF1cbn0pXG5leHBvcnQgY2xhc3MgU2VjdGlvbkVkaXRvck1vZHVsZSB7IH1cbiJdfQ==
|