@pobuca/email-builder 1.0.0 → 1.1.0
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/README.md +1 -1
- package/bundles/pobuca-email-builder.umd.js +4464 -4414
- package/bundles/pobuca-email-builder.umd.js.map +1 -1
- package/bundles/pobuca-email-builder.umd.min.js +1 -1
- package/bundles/pobuca-email-builder.umd.min.js.map +1 -1
- package/esm2015/lib/classes/DefaultEmail.js +54 -53
- package/esm2015/lib/classes/Elements.js +229 -229
- package/esm2015/lib/classes/Structure.js +89 -89
- package/esm2015/lib/components/block/block.component.js +89 -89
- package/esm2015/lib/components/block-settings/block-settings.component.js +53 -53
- package/esm2015/lib/components/builder-container/builder-container.component.js +114 -114
- package/esm2015/lib/components/dialog.component.js +30 -30
- package/esm2015/lib/components/general-settings/general-settings.component.js +25 -25
- package/esm2015/lib/components/import-dialog/import-dialog.component.js +62 -62
- package/esm2015/lib/components/preview.component.js +89 -89
- package/esm2015/lib/components/structure/structure.component.js +163 -163
- package/esm2015/lib/components/structure-settings/structure-settings.component.js +31 -31
- package/esm2015/lib/components/template-list-dialog/template-list-dialog.component.js +45 -45
- package/esm2015/lib/directives/dynamic-component.directive.js +46 -46
- package/esm2015/lib/elements/abstract-block.js +23 -23
- package/esm2015/lib/elements/button/button.component.js +29 -29
- package/esm2015/lib/elements/divider/divider.component.js +30 -30
- package/esm2015/lib/elements/image/image.component.js +54 -54
- package/esm2015/lib/elements/social/social.component.js +42 -42
- package/esm2015/lib/elements/spacer/spacer.component.js +30 -30
- package/esm2015/lib/elements/text-element/text-element.component.js +80 -80
- package/esm2015/lib/groups/align.js +79 -79
- package/esm2015/lib/groups/back-repeat.js +55 -55
- package/esm2015/lib/groups/border.js +102 -102
- package/esm2015/lib/groups/color.js +139 -139
- package/esm2015/lib/groups/direction.js +63 -63
- package/esm2015/lib/groups/font-styles.js +127 -112
- package/esm2015/lib/groups/gaps.js +45 -45
- package/esm2015/lib/groups/line-height.js +68 -68
- package/esm2015/lib/groups/link.js +67 -67
- package/esm2015/lib/groups/margin.js +45 -45
- package/esm2015/lib/groups/padding.js +53 -53
- package/esm2015/lib/groups/upload-image.js +112 -112
- package/esm2015/lib/groups/width-height.js +94 -94
- package/esm2015/lib/interceptors/pb-interceptor.interceptor.js +51 -51
- package/esm2015/lib/interfaces/interfaces.js +13 -13
- package/esm2015/lib/pb-email-builder.component.js +258 -246
- package/esm2015/lib/pb-email-builder.module.js +291 -291
- package/esm2015/lib/pb-email-builder.service.js +134 -134
- package/esm2015/lib/pipes/slugify.pipe.js +39 -39
- package/esm2015/lib/services/internals/pb-email-object-store/pb-email-object-store.service.js +175 -165
- package/esm2015/lib/services/internals/user-interfaces/user-interface.service.js +122 -122
- package/esm2015/lib/services/pb-storage/FreeUsersStorage.class.js +11 -11
- package/esm2015/lib/services/pb-storage/index.js +7 -7
- package/esm2015/lib/services/pb-storage/pb-storage.service.js +79 -79
- package/esm2015/lib/services/user-image-uploader-service/free-users-image-uploader.service.js +26 -26
- package/esm2015/lib/services/user-image-uploader-service/index.js +8 -8
- package/esm2015/lib/services/user-image-uploader-service/paid-users-image-uploader.service.js +30 -30
- package/esm2015/lib/services/user-image-uploader-service/upload-bottom-sheet-dialog/upload-bottom-sheet-dialog.component.js +112 -112
- package/esm2015/lib/services/user-image-uploader-service/upload-image-gallery/upload-image-gallery.component.js +91 -91
- package/esm2015/lib/services/user-image-uploader-service/user-image-uploader.service.js +26 -26
- package/esm2015/lib/services/user-middleware-service/FreeUsersMiddleware.js +31 -31
- package/esm2015/lib/services/user-middleware-service/PaidUsersMiddleware.js +12 -12
- package/esm2015/lib/services/user-middleware-service/index.js +8 -8
- package/esm2015/lib/services/user-middleware-service/pb-middlewares.service.js +195 -195
- package/esm2015/lib/services/user-rest-api-service/free-users-rest-api.service.js +16 -16
- package/esm2015/lib/services/user-rest-api-service/index.js +7 -7
- package/esm2015/lib/services/user-rest-api-service/user-rest-api.service.js +116 -116
- package/esm2015/lib/tokens/private-tokens.js +17 -17
- package/esm2015/lib/tokens/tokens.js +159 -159
- package/esm2015/lib/utils.js +147 -147
- package/esm2015/pobuca-email-builder.js +42 -42
- package/esm2015/public_api.js +26 -26
- package/fesm2015/pobuca-email-builder.js +4206 -4168
- package/fesm2015/pobuca-email-builder.js.map +1 -1
- package/lib/classes/DefaultEmail.d.ts +10 -9
- package/lib/classes/Elements.d.ts +62 -62
- package/lib/classes/Structure.d.ts +11 -11
- package/lib/components/block/block.component.d.ts +25 -25
- package/lib/components/block-settings/block-settings.component.d.ts +18 -18
- package/lib/components/builder-container/builder-container.component.d.ts +36 -36
- package/lib/components/dialog.component.d.ts +10 -10
- package/lib/components/general-settings/general-settings.component.d.ts +6 -6
- package/lib/components/import-dialog/import-dialog.component.d.ts +16 -16
- package/lib/components/preview.component.d.ts +18 -18
- package/lib/components/structure/structure.component.d.ts +43 -43
- package/lib/components/structure-settings/structure-settings.component.d.ts +9 -9
- package/lib/components/template-list-dialog/template-list-dialog.component.d.ts +15 -15
- package/lib/directives/dynamic-component.directive.d.ts +13 -13
- package/lib/elements/abstract-block.d.ts +8 -8
- package/lib/elements/button/button.component.d.ts +18 -18
- package/lib/elements/divider/divider.component.d.ts +10 -10
- package/lib/elements/image/image.component.d.ts +19 -19
- package/lib/elements/social/social.component.d.ts +21 -21
- package/lib/elements/spacer/spacer.component.d.ts +5 -5
- package/lib/elements/text-element/text-element.component.d.ts +52 -52
- package/lib/groups/align.d.ts +17 -17
- package/lib/groups/back-repeat.d.ts +8 -8
- package/lib/groups/border.d.ts +13 -13
- package/lib/groups/color.d.ts +26 -26
- package/lib/groups/direction.d.ts +13 -13
- package/lib/groups/font-styles.d.ts +21 -17
- package/lib/groups/gaps.d.ts +7 -7
- package/lib/groups/line-height.d.ts +12 -12
- package/lib/groups/link.d.ts +11 -11
- package/lib/groups/margin.d.ts +8 -8
- package/lib/groups/padding.d.ts +8 -8
- package/lib/groups/upload-image.d.ts +19 -19
- package/lib/groups/width-height.d.ts +19 -19
- package/lib/interceptors/pb-interceptor.interceptor.d.ts +10 -10
- package/lib/interfaces/interfaces.d.ts +430 -422
- package/lib/pb-email-builder.component.d.ts +67 -67
- package/lib/pb-email-builder.module.d.ts +51 -51
- package/lib/pb-email-builder.service.d.ts +83 -83
- package/lib/pipes/slugify.pipe.d.ts +9 -9
- package/lib/services/internals/pb-email-object-store/pb-email-object-store.service.d.ts +50 -50
- package/lib/services/internals/user-interfaces/user-interface.service.d.ts +46 -46
- package/lib/services/pb-storage/FreeUsersStorage.class.d.ts +6 -6
- package/lib/services/pb-storage/index.d.ts +2 -2
- package/lib/services/pb-storage/pb-storage.service.d.ts +54 -54
- package/lib/services/user-image-uploader-service/free-users-image-uploader.service.d.ts +12 -12
- package/lib/services/user-image-uploader-service/index.d.ts +3 -3
- package/lib/services/user-image-uploader-service/paid-users-image-uploader.service.d.ts +14 -14
- package/lib/services/user-image-uploader-service/upload-bottom-sheet-dialog/upload-bottom-sheet-dialog.component.d.ts +28 -28
- package/lib/services/user-image-uploader-service/upload-image-gallery/upload-image-gallery.component.d.ts +27 -27
- package/lib/services/user-image-uploader-service/user-image-uploader.service.d.ts +26 -26
- package/lib/services/user-middleware-service/FreeUsersMiddleware.d.ts +15 -15
- package/lib/services/user-middleware-service/PaidUsersMiddleware.d.ts +7 -7
- package/lib/services/user-middleware-service/index.d.ts +3 -3
- package/lib/services/user-middleware-service/pb-middlewares.service.d.ts +190 -190
- package/lib/services/user-rest-api-service/free-users-rest-api.service.d.ts +10 -10
- package/lib/services/user-rest-api-service/index.d.ts +2 -2
- package/lib/services/user-rest-api-service/user-rest-api.service.d.ts +82 -82
- package/lib/tokens/private-tokens.d.ts +5 -5
- package/lib/tokens/tokens.d.ts +70 -70
- package/lib/utils.d.ts +88 -88
- package/package.json +8 -3
- package/pobuca-email-builder.d.ts +42 -42
- package/pobuca-email-builder.metadata.json +1 -1
- package/public_api.d.ts +16 -16
|
@@ -1,89 +1,89 @@
|
|
|
1
|
-
/*
|
|
2
|
-
* Copyright (c) 2024 Pobuca.
|
|
3
|
-
* All rights reserved.
|
|
4
|
-
*/
|
|
5
|
-
import { Component, Input, ChangeDetectionStrategy } from '@angular/core';
|
|
6
|
-
import { DomSanitizer } from '@angular/platform-browser';
|
|
7
|
-
import { take } from 'rxjs/operators';
|
|
8
|
-
import { PbUserMiddlewaresService } from '../services/user-middleware-service/pb-middlewares.service';
|
|
9
|
-
const devicesMap = new Map([
|
|
10
|
-
['desktop', '1 1 100%'],
|
|
11
|
-
['smartphone', '1 1 360px'],
|
|
12
|
-
['tablet', '1 1 768px']
|
|
13
|
-
]);
|
|
14
|
-
export class PreviewTemplateComponent {
|
|
15
|
-
constructor(middlewares, sanitizer) {
|
|
16
|
-
this.middlewares = middlewares;
|
|
17
|
-
this.sanitizer = sanitizer;
|
|
18
|
-
this.device = 'desktop';
|
|
19
|
-
}
|
|
20
|
-
changeDevice(button) {
|
|
21
|
-
return this.middlewares
|
|
22
|
-
.togglePreviewDevice(button)
|
|
23
|
-
.pipe(take(1))
|
|
24
|
-
.subscribe(device => {
|
|
25
|
-
this.device = device;
|
|
26
|
-
});
|
|
27
|
-
}
|
|
28
|
-
getFlexWidth() {
|
|
29
|
-
return devicesMap.get(this.device);
|
|
30
|
-
}
|
|
31
|
-
ngOnInit() {
|
|
32
|
-
this.src = URL.createObjectURL(new Blob([this.template], { type: 'text/html' }));
|
|
33
|
-
this.templateSrc = this.sanitizer.bypassSecurityTrustResourceUrl(this.src);
|
|
34
|
-
}
|
|
35
|
-
ngOnDestroy() {
|
|
36
|
-
if (this.src) {
|
|
37
|
-
URL.revokeObjectURL(this.src);
|
|
38
|
-
}
|
|
39
|
-
}
|
|
40
|
-
}
|
|
41
|
-
PreviewTemplateComponent.decorators = [
|
|
42
|
-
{ type: Component, args: [{
|
|
43
|
-
selector: 'pb-preview-template',
|
|
44
|
-
template: `
|
|
45
|
-
<iframe [src]="templateSrc" [fxFlex]="getFlexWidth()"></iframe>
|
|
46
|
-
<mat-button-toggle-group value="desktop" (change)="changeDevice($event)" vertical>
|
|
47
|
-
<mat-button-toggle value="desktop" matTooltip="Desktop / 100%" matTooltipPosition="left">
|
|
48
|
-
<mat-icon>desktop_windows</mat-icon>
|
|
49
|
-
</mat-button-toggle>
|
|
50
|
-
<mat-button-toggle value="tablet" matTooltip="Tablet / 768px" matTooltipPosition="left">
|
|
51
|
-
<mat-icon>tablet</mat-icon>
|
|
52
|
-
</mat-button-toggle>
|
|
53
|
-
<mat-button-toggle value="smartphone" matTooltip="Smartphone / 360px" matTooltipPosition="left">
|
|
54
|
-
<mat-icon>smartphone</mat-icon>
|
|
55
|
-
</mat-button-toggle>
|
|
56
|
-
</mat-button-toggle-group>
|
|
57
|
-
`,
|
|
58
|
-
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
59
|
-
styles: [`
|
|
60
|
-
iframe {
|
|
61
|
-
border: 0;
|
|
62
|
-
will-change: width;
|
|
63
|
-
transition: all 500ms ease-in-out;
|
|
64
|
-
}
|
|
65
|
-
|
|
66
|
-
/* iframe a[href] {
|
|
67
|
-
pointer-events: none;
|
|
68
|
-
} */
|
|
69
|
-
|
|
70
|
-
/* iframe.active {
|
|
71
|
-
opacity: 1;
|
|
72
|
-
} */
|
|
73
|
-
|
|
74
|
-
mat-button-toggle-group {
|
|
75
|
-
position: absolute;
|
|
76
|
-
right: 0;
|
|
77
|
-
background: white;
|
|
78
|
-
}
|
|
79
|
-
`]
|
|
80
|
-
},] }
|
|
81
|
-
];
|
|
82
|
-
PreviewTemplateComponent.ctorParameters = () => [
|
|
83
|
-
{ type: PbUserMiddlewaresService },
|
|
84
|
-
{ type: DomSanitizer }
|
|
85
|
-
];
|
|
86
|
-
PreviewTemplateComponent.propDecorators = {
|
|
87
|
-
template: [{ type: Input }]
|
|
88
|
-
};
|
|
89
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
1
|
+
/*
|
|
2
|
+
* Copyright (c) 2024 Pobuca.
|
|
3
|
+
* All rights reserved.
|
|
4
|
+
*/
|
|
5
|
+
import { Component, Input, ChangeDetectionStrategy } from '@angular/core';
|
|
6
|
+
import { DomSanitizer } from '@angular/platform-browser';
|
|
7
|
+
import { take } from 'rxjs/operators';
|
|
8
|
+
import { PbUserMiddlewaresService } from '../services/user-middleware-service/pb-middlewares.service';
|
|
9
|
+
const devicesMap = new Map([
|
|
10
|
+
['desktop', '1 1 100%'],
|
|
11
|
+
['smartphone', '1 1 360px'],
|
|
12
|
+
['tablet', '1 1 768px']
|
|
13
|
+
]);
|
|
14
|
+
export class PreviewTemplateComponent {
|
|
15
|
+
constructor(middlewares, sanitizer) {
|
|
16
|
+
this.middlewares = middlewares;
|
|
17
|
+
this.sanitizer = sanitizer;
|
|
18
|
+
this.device = 'desktop';
|
|
19
|
+
}
|
|
20
|
+
changeDevice(button) {
|
|
21
|
+
return this.middlewares
|
|
22
|
+
.togglePreviewDevice(button)
|
|
23
|
+
.pipe(take(1))
|
|
24
|
+
.subscribe(device => {
|
|
25
|
+
this.device = device;
|
|
26
|
+
});
|
|
27
|
+
}
|
|
28
|
+
getFlexWidth() {
|
|
29
|
+
return devicesMap.get(this.device);
|
|
30
|
+
}
|
|
31
|
+
ngOnInit() {
|
|
32
|
+
this.src = URL.createObjectURL(new Blob([this.template], { type: 'text/html' }));
|
|
33
|
+
this.templateSrc = this.sanitizer.bypassSecurityTrustResourceUrl(this.src);
|
|
34
|
+
}
|
|
35
|
+
ngOnDestroy() {
|
|
36
|
+
if (this.src) {
|
|
37
|
+
URL.revokeObjectURL(this.src);
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
PreviewTemplateComponent.decorators = [
|
|
42
|
+
{ type: Component, args: [{
|
|
43
|
+
selector: 'pb-preview-template',
|
|
44
|
+
template: `
|
|
45
|
+
<iframe [src]="templateSrc" [fxFlex]="getFlexWidth()"></iframe>
|
|
46
|
+
<mat-button-toggle-group value="desktop" (change)="changeDevice($event)" vertical>
|
|
47
|
+
<mat-button-toggle value="desktop" matTooltip="Desktop / 100%" matTooltipPosition="left">
|
|
48
|
+
<mat-icon>desktop_windows</mat-icon>
|
|
49
|
+
</mat-button-toggle>
|
|
50
|
+
<mat-button-toggle value="tablet" matTooltip="Tablet / 768px" matTooltipPosition="left">
|
|
51
|
+
<mat-icon>tablet</mat-icon>
|
|
52
|
+
</mat-button-toggle>
|
|
53
|
+
<mat-button-toggle value="smartphone" matTooltip="Smartphone / 360px" matTooltipPosition="left">
|
|
54
|
+
<mat-icon>smartphone</mat-icon>
|
|
55
|
+
</mat-button-toggle>
|
|
56
|
+
</mat-button-toggle-group>
|
|
57
|
+
`,
|
|
58
|
+
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
59
|
+
styles: [`
|
|
60
|
+
iframe {
|
|
61
|
+
border: 0;
|
|
62
|
+
will-change: width;
|
|
63
|
+
transition: all 500ms ease-in-out;
|
|
64
|
+
}
|
|
65
|
+
|
|
66
|
+
/* iframe a[href] {
|
|
67
|
+
pointer-events: none;
|
|
68
|
+
} */
|
|
69
|
+
|
|
70
|
+
/* iframe.active {
|
|
71
|
+
opacity: 1;
|
|
72
|
+
} */
|
|
73
|
+
|
|
74
|
+
mat-button-toggle-group {
|
|
75
|
+
position: absolute;
|
|
76
|
+
right: 0;
|
|
77
|
+
background: white;
|
|
78
|
+
}
|
|
79
|
+
`]
|
|
80
|
+
},] }
|
|
81
|
+
];
|
|
82
|
+
PreviewTemplateComponent.ctorParameters = () => [
|
|
83
|
+
{ type: PbUserMiddlewaresService },
|
|
84
|
+
{ type: DomSanitizer }
|
|
85
|
+
];
|
|
86
|
+
PreviewTemplateComponent.propDecorators = {
|
|
87
|
+
template: [{ type: Input }]
|
|
88
|
+
};
|
|
89
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJldmlldy5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9wYi1lbWFpbC1idWlsZGVyL3NyYy9saWIvY29tcG9uZW50cy9wcmV2aWV3LmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7O0dBR0c7QUFFSCxPQUFPLEVBQUUsU0FBUyxFQUFVLEtBQUssRUFBRSx1QkFBdUIsRUFBYSxNQUFNLGVBQWUsQ0FBQztBQUU3RixPQUFPLEVBQUUsWUFBWSxFQUFtQixNQUFNLDJCQUEyQixDQUFDO0FBQzFFLE9BQU8sRUFBRSxJQUFJLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUV0QyxPQUFPLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSw0REFBNEQsQ0FBQztBQUl0RyxNQUFNLFVBQVUsR0FBRyxJQUFJLEdBQUcsQ0FBQztJQUN6QixDQUFDLFNBQVMsRUFBRSxVQUFVLENBQUM7SUFDdkIsQ0FBQyxZQUFZLEVBQUUsV0FBVyxDQUFDO0lBQzNCLENBQUMsUUFBUSxFQUFFLFdBQVcsQ0FBQztDQUN4QixDQUFDLENBQUM7QUEyQ0gsTUFBTSxPQUFPLHdCQUF3QjtJQU1uQyxZQUFvQixXQUFxQyxFQUFVLFNBQXVCO1FBQXRFLGdCQUFXLEdBQVgsV0FBVyxDQUEwQjtRQUFVLGNBQVMsR0FBVCxTQUFTLENBQWM7UUFIbEYsV0FBTSxHQUFtQixTQUFTLENBQUM7SUFHa0QsQ0FBQztJQUU5RixZQUFZLENBQUMsTUFBNkI7UUFDeEMsT0FBTyxJQUFJLENBQUMsV0FBVzthQUNwQixtQkFBbUIsQ0FBQyxNQUFNLENBQUM7YUFDM0IsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQzthQUNiLFNBQVMsQ0FBQyxNQUFNLENBQUMsRUFBRTtZQUNsQixJQUFJLENBQUMsTUFBTSxHQUFHLE1BQU0sQ0FBQztRQUN2QixDQUFDLENBQUMsQ0FBQztJQUNQLENBQUM7SUFFRCxZQUFZO1FBQ1YsT0FBTyxVQUFVLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsQ0FBQztJQUNyQyxDQUFDO0lBRUQsUUFBUTtRQUNOLElBQUksQ0FBQyxHQUFHLEdBQUcsR0FBRyxDQUFDLGVBQWUsQ0FBQyxJQUFJLElBQUksQ0FBQyxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsRUFBRSxFQUFFLElBQUksRUFBRSxXQUFXLEVBQUUsQ0FBQyxDQUFDLENBQUM7UUFDakYsSUFBSSxDQUFDLFdBQVcsR0FBRyxJQUFJLENBQUMsU0FBUyxDQUFDLDhCQUE4QixDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQztJQUM3RSxDQUFDO0lBRUQsV0FBVztRQUNULElBQUksSUFBSSxDQUFDLEdBQUcsRUFBRTtZQUNaLEdBQUcsQ0FBQyxlQUFlLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDO1NBQy9CO0lBQ0gsQ0FBQzs7O1lBdkVGLFNBQVMsU0FBQztnQkFDVCxRQUFRLEVBQUUscUJBQXFCO2dCQUMvQixRQUFRLEVBQUU7Ozs7Ozs7Ozs7Ozs7R0FhVDtnQkF3QkQsZUFBZSxFQUFFLHVCQUF1QixDQUFDLE1BQU07eUJBdEI3Qzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7S0FvQkM7YUFHSjs7O1lBbERRLHdCQUF3QjtZQUh4QixZQUFZOzs7dUJBdURsQixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiLypcclxuICogQ29weXJpZ2h0IChjKSAyMDI0IFBvYnVjYS5cclxuICogQWxsIHJpZ2h0cyByZXNlcnZlZC5cclxuICovXHJcblxyXG5pbXBvcnQgeyBDb21wb25lbnQsIE9uSW5pdCwgSW5wdXQsIENoYW5nZURldGVjdGlvblN0cmF0ZWd5LCBPbkRlc3Ryb3kgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgTWF0QnV0dG9uVG9nZ2xlQ2hhbmdlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvYnV0dG9uLXRvZ2dsZSc7XHJcbmltcG9ydCB7IERvbVNhbml0aXplciwgU2FmZVJlc291cmNlVXJsIH0gZnJvbSAnQGFuZ3VsYXIvcGxhdGZvcm0tYnJvd3Nlcic7XHJcbmltcG9ydCB7IHRha2UgfSBmcm9tICdyeGpzL29wZXJhdG9ycyc7XHJcblxyXG5pbXBvcnQgeyBQYlVzZXJNaWRkbGV3YXJlc1NlcnZpY2UgfSBmcm9tICcuLi9zZXJ2aWNlcy91c2VyLW1pZGRsZXdhcmUtc2VydmljZS9wYi1taWRkbGV3YXJlcy5zZXJ2aWNlJztcclxuXHJcbmV4cG9ydCB0eXBlIFRQcmV2aWV3RGV2aWNlID0gJ2Rlc2t0b3AnIHwgJ3NtYXJ0cGhvbmUnIHwgJ3RhYmxldCc7XHJcblxyXG5jb25zdCBkZXZpY2VzTWFwID0gbmV3IE1hcChbXHJcbiAgWydkZXNrdG9wJywgJzEgMSAxMDAlJ10sXHJcbiAgWydzbWFydHBob25lJywgJzEgMSAzNjBweCddLFxyXG4gIFsndGFibGV0JywgJzEgMSA3NjhweCddXHJcbl0pO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICdwYi1wcmV2aWV3LXRlbXBsYXRlJyxcclxuICB0ZW1wbGF0ZTogYFxyXG4gICAgPGlmcmFtZSBbc3JjXT1cInRlbXBsYXRlU3JjXCIgW2Z4RmxleF09XCJnZXRGbGV4V2lkdGgoKVwiPjwvaWZyYW1lPlxyXG4gICAgPG1hdC1idXR0b24tdG9nZ2xlLWdyb3VwIHZhbHVlPVwiZGVza3RvcFwiIChjaGFuZ2UpPVwiY2hhbmdlRGV2aWNlKCRldmVudClcIiB2ZXJ0aWNhbD5cclxuICAgICAgPG1hdC1idXR0b24tdG9nZ2xlIHZhbHVlPVwiZGVza3RvcFwiIG1hdFRvb2x0aXA9XCJEZXNrdG9wIC8gMTAwJVwiIG1hdFRvb2x0aXBQb3NpdGlvbj1cImxlZnRcIj5cclxuICAgICAgICA8bWF0LWljb24+ZGVza3RvcF93aW5kb3dzPC9tYXQtaWNvbj5cclxuICAgICAgPC9tYXQtYnV0dG9uLXRvZ2dsZT5cclxuICAgICAgPG1hdC1idXR0b24tdG9nZ2xlIHZhbHVlPVwidGFibGV0XCIgbWF0VG9vbHRpcD1cIlRhYmxldCAvIDc2OHB4XCIgbWF0VG9vbHRpcFBvc2l0aW9uPVwibGVmdFwiPlxyXG4gICAgICAgIDxtYXQtaWNvbj50YWJsZXQ8L21hdC1pY29uPlxyXG4gICAgICA8L21hdC1idXR0b24tdG9nZ2xlPlxyXG4gICAgICA8bWF0LWJ1dHRvbi10b2dnbGUgdmFsdWU9XCJzbWFydHBob25lXCIgbWF0VG9vbHRpcD1cIlNtYXJ0cGhvbmUgLyAzNjBweFwiIG1hdFRvb2x0aXBQb3NpdGlvbj1cImxlZnRcIj5cclxuICAgICAgICA8bWF0LWljb24+c21hcnRwaG9uZTwvbWF0LWljb24+XHJcbiAgICAgIDwvbWF0LWJ1dHRvbi10b2dnbGU+XHJcbiAgICA8L21hdC1idXR0b24tdG9nZ2xlLWdyb3VwPlxyXG4gIGAsXHJcbiAgc3R5bGVzOiBbXHJcbiAgICBgXHJcbiAgICAgIGlmcmFtZSB7XHJcbiAgICAgICAgYm9yZGVyOiAwO1xyXG4gICAgICAgIHdpbGwtY2hhbmdlOiB3aWR0aDtcclxuICAgICAgICB0cmFuc2l0aW9uOiBhbGwgNTAwbXMgZWFzZS1pbi1vdXQ7XHJcbiAgICAgIH1cclxuXHJcbiAgICAgIC8qIGlmcmFtZSBhW2hyZWZdIHtcclxuICAgICAgICBwb2ludGVyLWV2ZW50czogbm9uZTtcclxuICAgICAgfSAqL1xyXG5cclxuICAgICAgLyogaWZyYW1lLmFjdGl2ZSB7XHJcbiAgICAgICAgb3BhY2l0eTogMTtcclxuICAgICAgfSAqL1xyXG5cclxuICAgICAgbWF0LWJ1dHRvbi10b2dnbGUtZ3JvdXAge1xyXG4gICAgICAgIHBvc2l0aW9uOiBhYnNvbHV0ZTtcclxuICAgICAgICByaWdodDogMDtcclxuICAgICAgICBiYWNrZ3JvdW5kOiB3aGl0ZTtcclxuICAgICAgfVxyXG4gICAgYFxyXG4gIF0sXHJcbiAgY2hhbmdlRGV0ZWN0aW9uOiBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneS5PblB1c2hcclxufSlcclxuZXhwb3J0IGNsYXNzIFByZXZpZXdUZW1wbGF0ZUNvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCwgT25EZXN0cm95IHtcclxuICBASW5wdXQoKSB0ZW1wbGF0ZTogc3RyaW5nO1xyXG4gIHByaXZhdGUgc3JjOiBzdHJpbmc7XHJcbiAgcHJpdmF0ZSBkZXZpY2U6IFRQcmV2aWV3RGV2aWNlID0gJ2Rlc2t0b3AnO1xyXG4gIHRlbXBsYXRlU3JjOiBTYWZlUmVzb3VyY2VVcmw7XHJcblxyXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgbWlkZGxld2FyZXM6IFBiVXNlck1pZGRsZXdhcmVzU2VydmljZSwgcHJpdmF0ZSBzYW5pdGl6ZXI6IERvbVNhbml0aXplcikge31cclxuXHJcbiAgY2hhbmdlRGV2aWNlKGJ1dHRvbjogTWF0QnV0dG9uVG9nZ2xlQ2hhbmdlKSB7XHJcbiAgICByZXR1cm4gdGhpcy5taWRkbGV3YXJlc1xyXG4gICAgICAudG9nZ2xlUHJldmlld0RldmljZShidXR0b24pXHJcbiAgICAgIC5waXBlKHRha2UoMSkpXHJcbiAgICAgIC5zdWJzY3JpYmUoZGV2aWNlID0+IHtcclxuICAgICAgICB0aGlzLmRldmljZSA9IGRldmljZTtcclxuICAgICAgfSk7XHJcbiAgfVxyXG5cclxuICBnZXRGbGV4V2lkdGgoKSB7XHJcbiAgICByZXR1cm4gZGV2aWNlc01hcC5nZXQodGhpcy5kZXZpY2UpO1xyXG4gIH1cclxuXHJcbiAgbmdPbkluaXQoKSB7XHJcbiAgICB0aGlzLnNyYyA9IFVSTC5jcmVhdGVPYmplY3RVUkwobmV3IEJsb2IoW3RoaXMudGVtcGxhdGVdLCB7IHR5cGU6ICd0ZXh0L2h0bWwnIH0pKTtcclxuICAgIHRoaXMudGVtcGxhdGVTcmMgPSB0aGlzLnNhbml0aXplci5ieXBhc3NTZWN1cml0eVRydXN0UmVzb3VyY2VVcmwodGhpcy5zcmMpO1xyXG4gIH1cclxuXHJcbiAgbmdPbkRlc3Ryb3koKSB7XHJcbiAgICBpZiAodGhpcy5zcmMpIHtcclxuICAgICAgVVJMLnJldm9rZU9iamVjdFVSTCh0aGlzLnNyYyk7XHJcbiAgICB9XHJcbiAgfVxyXG59XHJcbiJdfQ==
|
|
@@ -1,163 +1,163 @@
|
|
|
1
|
-
/*
|
|
2
|
-
* Copyright (c) 2024 Pobuca.
|
|
3
|
-
* All rights reserved.
|
|
4
|
-
*/
|
|
5
|
-
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, HostBinding, HostListener, Input, ViewEncapsulation } from '@angular/core';
|
|
6
|
-
import { exhaustMap, filter, map, take, takeUntil } from 'rxjs/operators';
|
|
7
|
-
import { Subject } from 'rxjs';
|
|
8
|
-
import { defaultColumnsOptions, Structure } from '../../classes/Structure';
|
|
9
|
-
import { createBorder } from '../../utils';
|
|
10
|
-
import { PbUserMiddlewaresService } from '../../services/user-middleware-service/pb-middlewares.service';
|
|
11
|
-
import { PbUserInterfaceService } from '../../services/internals/user-interfaces/user-interface.service';
|
|
12
|
-
import { PbEmailObjectStoreService } from '../../services/internals/pb-email-object-store/pb-email-object-store.service';
|
|
13
|
-
export class StructureComponent {
|
|
14
|
-
constructor(userInterfaceService, emailObjectStore, chRef, pbMiddlewaresService) {
|
|
15
|
-
this.userInterfaceService = userInterfaceService;
|
|
16
|
-
this.emailObjectStore = emailObjectStore;
|
|
17
|
-
this.chRef = chRef;
|
|
18
|
-
this.pbMiddlewaresService = pbMiddlewaresService;
|
|
19
|
-
this.structure = new Structure();
|
|
20
|
-
this.cdkDropListConnectedTo$ = this.userInterfaceService.cdkDropListConnectedTo$;
|
|
21
|
-
this.validate = function ({ rectangle }) {
|
|
22
|
-
const colFr = +(rectangle.width / this.fr).toFixed(2);
|
|
23
|
-
return colFr > 1 && colFr <= 10 - this.structure.columns;
|
|
24
|
-
}.bind(this);
|
|
25
|
-
// sectionWidth$ = this.userInterfaceService.currentEditingStructure$.pipe(
|
|
26
|
-
// withLatestFrom(this.emailObjectStore.emailBodyWidth$),
|
|
27
|
-
// map(([{ options }, width]) => {
|
|
28
|
-
// return options.fullWidth ? '100%' : width;
|
|
29
|
-
// })
|
|
30
|
-
// );
|
|
31
|
-
this.componentIsDestroyed$ = new Subject();
|
|
32
|
-
}
|
|
33
|
-
get isStructureActive() {
|
|
34
|
-
return this.isActive;
|
|
35
|
-
}
|
|
36
|
-
// @HostBinding('style.width') get sectionWidth(): string | number {
|
|
37
|
-
// console.log(this.emailObjectStore.Email.general.width.value);
|
|
38
|
-
// return this.structure.options.fullWidth ? '100%' : this.emailObjectStore.Email.general.width.value;
|
|
39
|
-
// }
|
|
40
|
-
// Don't close right panel on structure click
|
|
41
|
-
onHostClick(event) {
|
|
42
|
-
event.stopImmediatePropagation();
|
|
43
|
-
this.editStructure();
|
|
44
|
-
}
|
|
45
|
-
removeStructure(event) {
|
|
46
|
-
event.stopPropagation();
|
|
47
|
-
this.pbMiddlewaresService
|
|
48
|
-
.removeStructure(this.index, this.structure)
|
|
49
|
-
.pipe(exhaustMap(() => this.userInterfaceService.confirmDialog$()), filter(removeAllowed => removeAllowed), take(1))
|
|
50
|
-
.subscribe(() => {
|
|
51
|
-
this.emailObjectStore.removeStructure(this.index);
|
|
52
|
-
this.userInterfaceService.resetElements();
|
|
53
|
-
});
|
|
54
|
-
}
|
|
55
|
-
duplicateStructure(event) {
|
|
56
|
-
event.stopPropagation();
|
|
57
|
-
this.pbMiddlewaresService
|
|
58
|
-
.duplicateStructure(this.index, this.structure)
|
|
59
|
-
.pipe(map(() => this.emailObjectStore.duplicateStructure(this.index)), take(1))
|
|
60
|
-
.subscribe(newStructure => {
|
|
61
|
-
this.editStructure(newStructure);
|
|
62
|
-
});
|
|
63
|
-
}
|
|
64
|
-
dropNewBlock(event, column) {
|
|
65
|
-
if (event.previousContainer === event.container) {
|
|
66
|
-
this.emailObjectStore.addBlock(event, column);
|
|
67
|
-
}
|
|
68
|
-
else {
|
|
69
|
-
this.pbMiddlewaresService
|
|
70
|
-
.addBlock(event, column)
|
|
71
|
-
.pipe(map(newData => this.emailObjectStore.addBlock(newData.event, newData.column)))
|
|
72
|
-
.subscribe(() => {
|
|
73
|
-
// this.userInterfaceService.editBlock(newBlock);
|
|
74
|
-
this.chRef.markForCheck();
|
|
75
|
-
});
|
|
76
|
-
}
|
|
77
|
-
}
|
|
78
|
-
disableBlockDrag$(block) {
|
|
79
|
-
return this.pbMiddlewaresService.disableBlockDragWithinEmailBody(block).pipe(take(1));
|
|
80
|
-
}
|
|
81
|
-
editStructure(structure = this.structure) {
|
|
82
|
-
this.pbMiddlewaresService
|
|
83
|
-
.editStructure(structure)
|
|
84
|
-
.pipe(take(1))
|
|
85
|
-
.subscribe(strctr => {
|
|
86
|
-
this.userInterfaceService.editStructure(strctr);
|
|
87
|
-
});
|
|
88
|
-
}
|
|
89
|
-
getResizeEdges(columnKey) {
|
|
90
|
-
return {
|
|
91
|
-
right: columnKey + 1 !== this.structure.columns,
|
|
92
|
-
left: columnKey !== 0
|
|
93
|
-
};
|
|
94
|
-
}
|
|
95
|
-
createColumnId(columnKey) {
|
|
96
|
-
return `column-droplist-${columnKey}-${this.index}`;
|
|
97
|
-
}
|
|
98
|
-
getColumnStyles(columnKey) {
|
|
99
|
-
const { options: { gaps = [4, 4], columns = [] } } = this.structure;
|
|
100
|
-
const column = columns[columnKey] || defaultColumnsOptions;
|
|
101
|
-
let verticalAlign = 'center';
|
|
102
|
-
if (column.verticalAlign === 'bottom') {
|
|
103
|
-
verticalAlign = 'flex-end';
|
|
104
|
-
}
|
|
105
|
-
else if (column.verticalAlign === 'top') {
|
|
106
|
-
verticalAlign = 'flex-start';
|
|
107
|
-
}
|
|
108
|
-
return Object.assign({ padding: gaps.map(gap => `${gap}px`).join(' '), backgroundColor: column.background.color, placeSelf: `${verticalAlign} stretch` }, createBorder(column.border)
|
|
109
|
-
// ...createBackground(column.background)
|
|
110
|
-
);
|
|
111
|
-
}
|
|
112
|
-
onResizeEnd({ rectangle }, key) {
|
|
113
|
-
this.structure.options.columnsWidth[key] = +(rectangle.width / this.fr).toFixed(2);
|
|
114
|
-
}
|
|
115
|
-
ngDoCheck() {
|
|
116
|
-
if (this.isActive || this.userInterfaceService.currentStructureContainsActiveBlock(this.structure)) {
|
|
117
|
-
this.chRef.markForCheck();
|
|
118
|
-
}
|
|
119
|
-
}
|
|
120
|
-
ngOnInit() {
|
|
121
|
-
// Add columns options in case of old template
|
|
122
|
-
const { columns, columnsWidth } = this.structure.options;
|
|
123
|
-
if (!columns || !columnsWidth) {
|
|
124
|
-
const { type, elements, options } = this.structure;
|
|
125
|
-
this.editStructure(new Structure(type, elements, options));
|
|
126
|
-
}
|
|
127
|
-
const width = this.emailObjectStore.Email.general.width.value;
|
|
128
|
-
const [, horizontalGap] = this.structure.options.gaps;
|
|
129
|
-
this.fr = (width - horizontalGap * this.structure.columns) / 10;
|
|
130
|
-
this.userInterfaceService.currentEditingStructure$
|
|
131
|
-
.pipe(map(currentEditingStructure => currentEditingStructure === this.structure), takeUntil(this.componentIsDestroyed$))
|
|
132
|
-
.subscribe(isActive => {
|
|
133
|
-
this.isActive = isActive;
|
|
134
|
-
});
|
|
135
|
-
}
|
|
136
|
-
ngOnDestroy() {
|
|
137
|
-
this.componentIsDestroyed$.next('');
|
|
138
|
-
this.componentIsDestroyed$.complete();
|
|
139
|
-
}
|
|
140
|
-
}
|
|
141
|
-
StructureComponent.decorators = [
|
|
142
|
-
{ type: Component, args: [{
|
|
143
|
-
selector: 'pb-structure',
|
|
144
|
-
template: "<!--\n ~ Copyright (c) 2024 Pobuca.\n ~ All rights reserved.\n -->\n\n<div class=\"column\" *ngFor=\"let column of structure.elements; let index = index\" cdkDropList mwlResizable\n [enableGhostResize]=\"false\" [resizeSnapGrid]=\"{ left: fr, right: fr }\" [resizeEdges]=\"getResizeEdges(index)\"\n [validateResize]=\"validate\" (resizing)=\"onResizeEnd($event, index)\"\n (cdkDropListDropped)=\"dropNewBlock($event, column)\" [class.empty]=\"!column.length\" [ngStyle]=\"getColumnStyles(index)\"\n [cdkDropListConnectedTo]=\"cdkDropListConnectedTo$ | async\" [cdkDropListData]=\"column\" [id]=\"createColumnId(index)\">\n\n <div *ngIf=\"!column.length\" class=\"empty-block\" i18n=\"structure|Inside empty block\">DnD blocks</div>\n\n <pb-block *ngFor=\"let block of column; let index = index\" cdkDrag [cdkDragData]=\"block\" [block]=\"block\"\n [index]=\"index\" [column]=\"column\" [cdkDragDisabled]=\"disableBlockDrag$(block) | async\">\n <button mat-icon-button class=\"move\" cdkDragHandle i18n-matTooltip=\"block|Change Block order\"\n matTooltip=\"Change Block order\" *ngIf=\"!(disableBlockDrag$(block) | async)\">\n <mat-icon i18n-aria-label=\"block|Move block\" aria-label=\"Move block\" inline>pan_tool</mat-icon>\n </button>\n </pb-block>\n</div>\n\n<ng-content select=\".move\"></ng-content>\n<div class=\"tools\" fxLayoutGap=\"0.25rem\">\n <button mat-icon-button class=\"edit\" color=\"primary\" i18n-matTooltip=\"structure|Change structure settings\"\n matTooltip=\"Change structure settings\">\n <mat-icon i18n-aria-label=\"structure|Edit structure\" aria-label=\"Edit structure\" inline>edit</mat-icon>\n </button>\n <button mat-icon-button (click)=\"duplicateStructure($event)\" i18n-matTooltip=\"structure|Duplicate structure\"\n matTooltip=\"Duplicate structure\">\n <mat-icon i18n-aria-label=\"structure|Duplicate structure\" aria-label=\"Duplicate structure\" inline>file_copy\n </mat-icon>\n </button>\n <button mat-icon-button color=\"warn\" (click)=\"removeStructure($event)\" i18n-matTooltip=\"structure|Delete structure\"\n matTooltip=\"Delete structure\">\n <mat-icon i18n-aria-label=\"structure|Remove Structure\" aria-label=\"Remove Structure\" inline>delete_forever\n </mat-icon>\n </button>\n</div>\n",
|
|
145
|
-
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
146
|
-
encapsulation: ViewEncapsulation.Emulated,
|
|
147
|
-
exportAs: 'structure',
|
|
148
|
-
styles: ["/*!\n * Copyright (c) 2024 Pobuca.\n * All rights reserved.\n */pb-block>.cdk-drag-handle{position:absolute;top:-30px;right:0;cursor:move;background-color:rgba(63,81,181,.5);color:#fff;border-radius:50% 50% 0 0;opacity:0;height:30px;width:30px;font-size:smaller}pb-block>.cdk-drag-handle mat-icon{margin-top:-8px}pb-block>.cdk-drag-handle:hover{background-color:#3f51b5}pb-block.cdk-drag-preview .cdk-drag-handle,pb-block:hover .cdk-drag-handle{opacity:1}:host{display:grid;border:1px solid #ccc;position:relative;grid-template-columns:1fr}:host>.tools{direction:ltr;position:absolute;opacity:0;left:0;bottom:-25px;color:#ff4081}:host>.tools button{background-color:#fff;border-radius:0 0 3px 3px;height:25px;width:25px;line-height:0}:host.active,:host.cdk-drag-placeholder,:host.cdk-drag-preview,:host:hover{box-shadow:0 0 1px 2px #ff4081;z-index:1}:host:hover>.tools{opacity:1}:host:hover>.tools button{background-color:#ff4081;color:#fff}:host.active>.tools>.edit{display:none}:host.cols_2{grid-template-columns:repeat(2,6fr)}:host.cols_3{grid-template-columns:repeat(3,4fr)}:host.cols_4{grid-template-columns:repeat(4,3fr)}:host.cols_12{grid-template-columns:7fr 5fr}:host.cols_21{grid-template-columns:5fr 7fr}:host .cdk-drop-list-dragging,:host .cdk-drop-list-receiving{height:100%}:host>.column{box-sizing:border-box}:host>.column.empty{height:60px}:host>.column.empty .empty-block{background-color:rgba(101,99,99,.21);height:100%;display:flex;justify-content:center;place-items:center;flex-direction:column;color:rgba(101,99,99,.3);font-size:small}:host>.column.empty.cdk-drop-list-dragging .empty-block{display:none}:host>.column.empty>.cdk-drag-placeholder{min-height:60px!important}"]
|
|
149
|
-
},] }
|
|
150
|
-
];
|
|
151
|
-
StructureComponent.ctorParameters = () => [
|
|
152
|
-
{ type: PbUserInterfaceService },
|
|
153
|
-
{ type: PbEmailObjectStoreService },
|
|
154
|
-
{ type: ChangeDetectorRef },
|
|
155
|
-
{ type: PbUserMiddlewaresService }
|
|
156
|
-
];
|
|
157
|
-
StructureComponent.propDecorators = {
|
|
158
|
-
structure: [{ type: Input }],
|
|
159
|
-
index: [{ type: Input }],
|
|
160
|
-
isStructureActive: [{ type: HostBinding, args: ['class.active',] }],
|
|
161
|
-
onHostClick: [{ type: HostListener, args: ['click', ['$event'],] }]
|
|
162
|
-
};
|
|
163
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"structure.component.js","sourceRoot":"","sources":["../../../../../../projects/pb-email-builder/src/lib/components/structure/structure.component.ts"],"names":[],"mappings":"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","sourcesContent":["/*\n * Copyright (c) 2024 Pobuca.\n * All rights reserved.\n */\n\nimport {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  DoCheck,\n  HostBinding,\n  HostListener,\n  Input,\n  OnDestroy,\n  OnInit,\n  ViewEncapsulation\n} from '@angular/core';\nimport { ResizeEvent } from 'angular-resizable-element';\nimport { exhaustMap, filter, map, take, takeUntil } from 'rxjs/operators';\nimport { Subject } from 'rxjs';\n\nimport { defaultColumnsOptions, Structure } from '../../classes/Structure';\nimport { TBlocks } from '../../classes/Elements';\nimport { createBorder } from '../../utils';\nimport { IAddBlockEvent, PbUserMiddlewaresService } from '../../services/user-middleware-service/pb-middlewares.service';\nimport { PbUserInterfaceService } from '../../services/internals/user-interfaces/user-interface.service';\nimport { PbEmailObjectStoreService } from '../../services/internals/pb-email-object-store/pb-email-object-store.service';\n\n@Component({\n  selector: 'pb-structure',\n  templateUrl: './structure.component.html',\n  styleUrls: ['./structure.component.scss'],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.Emulated,\n  exportAs: 'structure'\n})\nexport class StructureComponent implements DoCheck, OnInit, OnDestroy {\n  @Input() structure = new Structure();\n  @Input() index: number;\n  public isActive: boolean;\n  public cdkDropListConnectedTo$ = this.userInterfaceService.cdkDropListConnectedTo$;\n  public fr: number;\n  public validate = function ({ rectangle }: ResizeEvent) {\n    const colFr = +(rectangle.width / this.fr).toFixed(2);\n    return colFr > 1 && colFr <= 10 - this.structure.columns;\n  }.bind(this);\n  // sectionWidth$ = this.userInterfaceService.currentEditingStructure$.pipe(\n  //   withLatestFrom(this.emailObjectStore.emailBodyWidth$),\n  //   map(([{ options }, width]) => {\n  //     return options.fullWidth ? '100%' : width;\n  //   })\n  // );\n  private readonly componentIsDestroyed$ = new Subject();\n\n  constructor(\n    private userInterfaceService: PbUserInterfaceService,\n    private emailObjectStore: PbEmailObjectStoreService,\n    private chRef: ChangeDetectorRef,\n    private pbMiddlewaresService: PbUserMiddlewaresService\n  ) {}\n\n  @HostBinding('class.active') get isStructureActive() {\n    return this.isActive;\n  }\n\n  // @HostBinding('style.width') get sectionWidth(): string | number {\n  //   console.log(this.emailObjectStore.Email.general.width.value);\n  //   return this.structure.options.fullWidth ? '100%' : this.emailObjectStore.Email.general.width.value;\n  // }\n\n  // Don't close right panel on structure click\n  @HostListener('click', ['$event']) onHostClick(event: MouseEvent) {\n    event.stopImmediatePropagation();\n    this.editStructure();\n  }\n\n  removeStructure(event: Event) {\n    event.stopPropagation();\n    this.pbMiddlewaresService\n      .removeStructure(this.index, this.structure)\n      .pipe(\n        exhaustMap(() => this.userInterfaceService.confirmDialog$()),\n        filter(removeAllowed => removeAllowed),\n        take(1)\n      )\n      .subscribe(() => {\n        this.emailObjectStore.removeStructure(this.index);\n        this.userInterfaceService.resetElements();\n      });\n  }\n\n  duplicateStructure(event: Event) {\n    event.stopPropagation();\n    this.pbMiddlewaresService\n      .duplicateStructure(this.index, this.structure)\n      .pipe(\n        map(() => this.emailObjectStore.duplicateStructure(this.index)),\n        take(1)\n      )\n      .subscribe(newStructure => {\n        this.editStructure(newStructure);\n      });\n  }\n\n  dropNewBlock(event: IAddBlockEvent, column: TBlocks[]) {\n    if (event.previousContainer === event.container) {\n      this.emailObjectStore.addBlock(event, column);\n    } else {\n      this.pbMiddlewaresService\n        .addBlock(event, column)\n        .pipe(map(newData => this.emailObjectStore.addBlock(newData.event, newData.column)))\n        .subscribe(() => {\n          // this.userInterfaceService.editBlock(newBlock);\n          this.chRef.markForCheck();\n        });\n    }\n  }\n\n  disableBlockDrag$(block: TBlocks) {\n    return this.pbMiddlewaresService.disableBlockDragWithinEmailBody(block).pipe(take(1));\n  }\n\n  editStructure(structure = this.structure) {\n    this.pbMiddlewaresService\n      .editStructure(structure)\n      .pipe(take(1))\n      .subscribe(strctr => {\n        this.userInterfaceService.editStructure(strctr);\n      });\n  }\n\n  getResizeEdges(columnKey: number) {\n    return {\n      right: columnKey + 1 !== this.structure.columns,\n      left: columnKey !== 0\n    };\n  }\n\n  createColumnId(columnKey: number) {\n    return `column-droplist-${columnKey}-${this.index}`;\n  }\n\n  getColumnStyles(columnKey: number) {\n    const {\n      options: { gaps = [4, 4], columns = [] }\n    } = this.structure;\n    const column = columns[columnKey] || defaultColumnsOptions;\n\n    let verticalAlign = 'center';\n    if (column.verticalAlign === 'bottom') {\n      verticalAlign = 'flex-end';\n    } else if (column.verticalAlign === 'top') {\n      verticalAlign = 'flex-start';\n    }\n\n    return {\n      padding: gaps.map(gap => `${gap}px`).join(' '),\n      backgroundColor: column.background.color,\n      placeSelf: `${verticalAlign} stretch`,\n      ...createBorder(column.border)\n      // ...createBackground(column.background)\n    };\n  }\n\n  onResizeEnd({ rectangle }: ResizeEvent, key: number) {\n    this.structure.options.columnsWidth[key] = +(rectangle.width / this.fr).toFixed(2);\n  }\n\n  ngDoCheck() {\n    if (this.isActive || this.userInterfaceService.currentStructureContainsActiveBlock(this.structure)) {\n      this.chRef.markForCheck();\n    }\n  }\n\n  ngOnInit() {\n    // Add columns options in case of old template\n    const { columns, columnsWidth } = this.structure.options;\n    if (!columns || !columnsWidth) {\n      const { type, elements, options } = this.structure;\n      this.editStructure(new Structure(type, elements, options));\n    }\n\n    const width = this.emailObjectStore.Email.general.width.value;\n    const [, horizontalGap] = this.structure.options.gaps;\n    this.fr = (width - horizontalGap * this.structure.columns) / 10;\n\n    this.userInterfaceService.currentEditingStructure$\n      .pipe(\n        map(currentEditingStructure => currentEditingStructure === this.structure),\n        takeUntil(this.componentIsDestroyed$)\n      )\n      .subscribe(isActive => {\n        this.isActive = isActive;\n      });\n  }\n\n  ngOnDestroy() {\n    this.componentIsDestroyed$.next('');\n    this.componentIsDestroyed$.complete();\n  }\n}\n"]}
|
|
1
|
+
/*
|
|
2
|
+
* Copyright (c) 2024 Pobuca.
|
|
3
|
+
* All rights reserved.
|
|
4
|
+
*/
|
|
5
|
+
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, HostBinding, HostListener, Input, ViewEncapsulation } from '@angular/core';
|
|
6
|
+
import { exhaustMap, filter, map, take, takeUntil } from 'rxjs/operators';
|
|
7
|
+
import { Subject } from 'rxjs';
|
|
8
|
+
import { defaultColumnsOptions, Structure } from '../../classes/Structure';
|
|
9
|
+
import { createBorder } from '../../utils';
|
|
10
|
+
import { PbUserMiddlewaresService } from '../../services/user-middleware-service/pb-middlewares.service';
|
|
11
|
+
import { PbUserInterfaceService } from '../../services/internals/user-interfaces/user-interface.service';
|
|
12
|
+
import { PbEmailObjectStoreService } from '../../services/internals/pb-email-object-store/pb-email-object-store.service';
|
|
13
|
+
export class StructureComponent {
|
|
14
|
+
constructor(userInterfaceService, emailObjectStore, chRef, pbMiddlewaresService) {
|
|
15
|
+
this.userInterfaceService = userInterfaceService;
|
|
16
|
+
this.emailObjectStore = emailObjectStore;
|
|
17
|
+
this.chRef = chRef;
|
|
18
|
+
this.pbMiddlewaresService = pbMiddlewaresService;
|
|
19
|
+
this.structure = new Structure();
|
|
20
|
+
this.cdkDropListConnectedTo$ = this.userInterfaceService.cdkDropListConnectedTo$;
|
|
21
|
+
this.validate = function ({ rectangle }) {
|
|
22
|
+
const colFr = +(rectangle.width / this.fr).toFixed(2);
|
|
23
|
+
return colFr > 1 && colFr <= 10 - this.structure.columns;
|
|
24
|
+
}.bind(this);
|
|
25
|
+
// sectionWidth$ = this.userInterfaceService.currentEditingStructure$.pipe(
|
|
26
|
+
// withLatestFrom(this.emailObjectStore.emailBodyWidth$),
|
|
27
|
+
// map(([{ options }, width]) => {
|
|
28
|
+
// return options.fullWidth ? '100%' : width;
|
|
29
|
+
// })
|
|
30
|
+
// );
|
|
31
|
+
this.componentIsDestroyed$ = new Subject();
|
|
32
|
+
}
|
|
33
|
+
get isStructureActive() {
|
|
34
|
+
return this.isActive;
|
|
35
|
+
}
|
|
36
|
+
// @HostBinding('style.width') get sectionWidth(): string | number {
|
|
37
|
+
// console.log(this.emailObjectStore.Email.general.width.value);
|
|
38
|
+
// return this.structure.options.fullWidth ? '100%' : this.emailObjectStore.Email.general.width.value;
|
|
39
|
+
// }
|
|
40
|
+
// Don't close right panel on structure click
|
|
41
|
+
onHostClick(event) {
|
|
42
|
+
event.stopImmediatePropagation();
|
|
43
|
+
this.editStructure();
|
|
44
|
+
}
|
|
45
|
+
removeStructure(event) {
|
|
46
|
+
event.stopPropagation();
|
|
47
|
+
this.pbMiddlewaresService
|
|
48
|
+
.removeStructure(this.index, this.structure)
|
|
49
|
+
.pipe(exhaustMap(() => this.userInterfaceService.confirmDialog$()), filter(removeAllowed => removeAllowed), take(1))
|
|
50
|
+
.subscribe(() => {
|
|
51
|
+
this.emailObjectStore.removeStructure(this.index);
|
|
52
|
+
this.userInterfaceService.resetElements();
|
|
53
|
+
});
|
|
54
|
+
}
|
|
55
|
+
duplicateStructure(event) {
|
|
56
|
+
event.stopPropagation();
|
|
57
|
+
this.pbMiddlewaresService
|
|
58
|
+
.duplicateStructure(this.index, this.structure)
|
|
59
|
+
.pipe(map(() => this.emailObjectStore.duplicateStructure(this.index)), take(1))
|
|
60
|
+
.subscribe(newStructure => {
|
|
61
|
+
this.editStructure(newStructure);
|
|
62
|
+
});
|
|
63
|
+
}
|
|
64
|
+
dropNewBlock(event, column) {
|
|
65
|
+
if (event.previousContainer === event.container) {
|
|
66
|
+
this.emailObjectStore.addBlock(event, column);
|
|
67
|
+
}
|
|
68
|
+
else {
|
|
69
|
+
this.pbMiddlewaresService
|
|
70
|
+
.addBlock(event, column)
|
|
71
|
+
.pipe(map(newData => this.emailObjectStore.addBlock(newData.event, newData.column)))
|
|
72
|
+
.subscribe(() => {
|
|
73
|
+
// this.userInterfaceService.editBlock(newBlock);
|
|
74
|
+
this.chRef.markForCheck();
|
|
75
|
+
});
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
disableBlockDrag$(block) {
|
|
79
|
+
return this.pbMiddlewaresService.disableBlockDragWithinEmailBody(block).pipe(take(1));
|
|
80
|
+
}
|
|
81
|
+
editStructure(structure = this.structure) {
|
|
82
|
+
this.pbMiddlewaresService
|
|
83
|
+
.editStructure(structure)
|
|
84
|
+
.pipe(take(1))
|
|
85
|
+
.subscribe(strctr => {
|
|
86
|
+
this.userInterfaceService.editStructure(strctr);
|
|
87
|
+
});
|
|
88
|
+
}
|
|
89
|
+
getResizeEdges(columnKey) {
|
|
90
|
+
return {
|
|
91
|
+
right: columnKey + 1 !== this.structure.columns,
|
|
92
|
+
left: columnKey !== 0
|
|
93
|
+
};
|
|
94
|
+
}
|
|
95
|
+
createColumnId(columnKey) {
|
|
96
|
+
return `column-droplist-${columnKey}-${this.index}`;
|
|
97
|
+
}
|
|
98
|
+
getColumnStyles(columnKey) {
|
|
99
|
+
const { options: { gaps = [4, 4], columns = [] } } = this.structure;
|
|
100
|
+
const column = columns[columnKey] || defaultColumnsOptions;
|
|
101
|
+
let verticalAlign = 'center';
|
|
102
|
+
if (column.verticalAlign === 'bottom') {
|
|
103
|
+
verticalAlign = 'flex-end';
|
|
104
|
+
}
|
|
105
|
+
else if (column.verticalAlign === 'top') {
|
|
106
|
+
verticalAlign = 'flex-start';
|
|
107
|
+
}
|
|
108
|
+
return Object.assign({ padding: gaps.map(gap => `${gap}px`).join(' '), backgroundColor: column.background.color, placeSelf: `${verticalAlign} stretch` }, createBorder(column.border)
|
|
109
|
+
// ...createBackground(column.background)
|
|
110
|
+
);
|
|
111
|
+
}
|
|
112
|
+
onResizeEnd({ rectangle }, key) {
|
|
113
|
+
this.structure.options.columnsWidth[key] = +(rectangle.width / this.fr).toFixed(2);
|
|
114
|
+
}
|
|
115
|
+
ngDoCheck() {
|
|
116
|
+
if (this.isActive || this.userInterfaceService.currentStructureContainsActiveBlock(this.structure)) {
|
|
117
|
+
this.chRef.markForCheck();
|
|
118
|
+
}
|
|
119
|
+
}
|
|
120
|
+
ngOnInit() {
|
|
121
|
+
// Add columns options in case of old template
|
|
122
|
+
const { columns, columnsWidth } = this.structure.options;
|
|
123
|
+
if (!columns || !columnsWidth) {
|
|
124
|
+
const { type, elements, options } = this.structure;
|
|
125
|
+
this.editStructure(new Structure(type, elements, options));
|
|
126
|
+
}
|
|
127
|
+
const width = this.emailObjectStore.Email.general.width.value;
|
|
128
|
+
const [, horizontalGap] = this.structure.options.gaps;
|
|
129
|
+
this.fr = (width - horizontalGap * this.structure.columns) / 10;
|
|
130
|
+
this.userInterfaceService.currentEditingStructure$
|
|
131
|
+
.pipe(map(currentEditingStructure => currentEditingStructure === this.structure), takeUntil(this.componentIsDestroyed$))
|
|
132
|
+
.subscribe(isActive => {
|
|
133
|
+
this.isActive = isActive;
|
|
134
|
+
});
|
|
135
|
+
}
|
|
136
|
+
ngOnDestroy() {
|
|
137
|
+
this.componentIsDestroyed$.next('');
|
|
138
|
+
this.componentIsDestroyed$.complete();
|
|
139
|
+
}
|
|
140
|
+
}
|
|
141
|
+
StructureComponent.decorators = [
|
|
142
|
+
{ type: Component, args: [{
|
|
143
|
+
selector: 'pb-structure',
|
|
144
|
+
template: "<!--\r\n ~ Copyright (c) 2024 Pobuca.\r\n ~ All rights reserved.\r\n -->\r\n\r\n<div class=\"column\" *ngFor=\"let column of structure.elements; let index = index\" cdkDropList mwlResizable\r\n [enableGhostResize]=\"false\" [resizeSnapGrid]=\"{ left: fr, right: fr }\" [resizeEdges]=\"getResizeEdges(index)\"\r\n [validateResize]=\"validate\" (resizing)=\"onResizeEnd($event, index)\"\r\n (cdkDropListDropped)=\"dropNewBlock($event, column)\" [class.empty]=\"!column.length\" [ngStyle]=\"getColumnStyles(index)\"\r\n [cdkDropListConnectedTo]=\"cdkDropListConnectedTo$ | async\" [cdkDropListData]=\"column\" [id]=\"createColumnId(index)\">\r\n\r\n <div *ngIf=\"!column.length\" class=\"empty-block\" i18n=\"structure|Inside empty block\">DnD blocks</div>\r\n\r\n <pb-block *ngFor=\"let block of column; let index = index\" cdkDrag [cdkDragData]=\"block\" [block]=\"block\"\r\n [index]=\"index\" [column]=\"column\" [cdkDragDisabled]=\"disableBlockDrag$(block) | async\">\r\n <button mat-icon-button class=\"move\" cdkDragHandle i18n-matTooltip=\"block|Change Block order\"\r\n matTooltip=\"Change Block order\" *ngIf=\"!(disableBlockDrag$(block) | async)\">\r\n <mat-icon i18n-aria-label=\"block|Move block\" aria-label=\"Move block\" inline>pan_tool</mat-icon>\r\n </button>\r\n </pb-block>\r\n</div>\r\n\r\n<ng-content select=\".move\"></ng-content>\r\n<div class=\"tools\" fxLayoutGap=\"0.25rem\">\r\n <button mat-icon-button class=\"edit\" color=\"primary\" i18n-matTooltip=\"structure|Change structure settings\"\r\n matTooltip=\"Change structure settings\">\r\n <mat-icon i18n-aria-label=\"structure|Edit structure\" aria-label=\"Edit structure\" inline>edit</mat-icon>\r\n </button>\r\n <button mat-icon-button (click)=\"duplicateStructure($event)\" i18n-matTooltip=\"structure|Duplicate structure\"\r\n matTooltip=\"Duplicate structure\">\r\n <mat-icon i18n-aria-label=\"structure|Duplicate structure\" aria-label=\"Duplicate structure\" inline>file_copy\r\n </mat-icon>\r\n </button>\r\n <button mat-icon-button color=\"warn\" (click)=\"removeStructure($event)\" i18n-matTooltip=\"structure|Delete structure\"\r\n matTooltip=\"Delete structure\">\r\n <mat-icon i18n-aria-label=\"structure|Remove Structure\" aria-label=\"Remove Structure\" inline>delete_forever\r\n </mat-icon>\r\n </button>\r\n</div>\r\n",
|
|
145
|
+
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
146
|
+
encapsulation: ViewEncapsulation.Emulated,
|
|
147
|
+
exportAs: 'structure',
|
|
148
|
+
styles: ["/*!\n * Copyright (c) 2024 Pobuca.\n * All rights reserved.\n */pb-block>.cdk-drag-handle{position:absolute;top:-30px;right:0;cursor:move;background-color:rgba(63,81,181,.5);color:#fff;border-radius:50% 50% 0 0;opacity:0;height:30px;width:30px;font-size:smaller}pb-block>.cdk-drag-handle mat-icon{margin-top:-8px}pb-block>.cdk-drag-handle:hover{background-color:#3f51b5}pb-block.cdk-drag-preview .cdk-drag-handle,pb-block:hover .cdk-drag-handle{opacity:1}:host{display:grid;border:1px solid #ccc;position:relative;grid-template-columns:1fr}:host>.tools{direction:ltr;position:absolute;opacity:0;left:0;bottom:-25px;color:#ff4081}:host>.tools button{background-color:#fff;border-radius:0 0 3px 3px;height:25px;width:25px;line-height:0}:host.active,:host.cdk-drag-placeholder,:host.cdk-drag-preview,:host:hover{box-shadow:0 0 1px 2px #ff4081;z-index:1}:host:hover>.tools{opacity:1}:host:hover>.tools button{background-color:#ff4081;color:#fff}:host.active>.tools>.edit{display:none}:host.cols_2{grid-template-columns:repeat(2,6fr)}:host.cols_3{grid-template-columns:repeat(3,4fr)}:host.cols_4{grid-template-columns:repeat(4,3fr)}:host.cols_12{grid-template-columns:7fr 5fr}:host.cols_21{grid-template-columns:5fr 7fr}:host .cdk-drop-list-dragging,:host .cdk-drop-list-receiving{height:100%}:host>.column{box-sizing:border-box}:host>.column.empty{height:60px}:host>.column.empty .empty-block{background-color:rgba(101,99,99,.21);height:100%;display:flex;justify-content:center;place-items:center;flex-direction:column;color:rgba(101,99,99,.3);font-size:small}:host>.column.empty.cdk-drop-list-dragging .empty-block{display:none}:host>.column.empty>.cdk-drag-placeholder{min-height:60px!important}"]
|
|
149
|
+
},] }
|
|
150
|
+
];
|
|
151
|
+
StructureComponent.ctorParameters = () => [
|
|
152
|
+
{ type: PbUserInterfaceService },
|
|
153
|
+
{ type: PbEmailObjectStoreService },
|
|
154
|
+
{ type: ChangeDetectorRef },
|
|
155
|
+
{ type: PbUserMiddlewaresService }
|
|
156
|
+
];
|
|
157
|
+
StructureComponent.propDecorators = {
|
|
158
|
+
structure: [{ type: Input }],
|
|
159
|
+
index: [{ type: Input }],
|
|
160
|
+
isStructureActive: [{ type: HostBinding, args: ['class.active',] }],
|
|
161
|
+
onHostClick: [{ type: HostListener, args: ['click', ['$event'],] }]
|
|
162
|
+
};
|
|
163
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"structure.component.js","sourceRoot":"","sources":["../../../../../../projects/pb-email-builder/src/lib/components/structure/structure.component.ts"],"names":[],"mappings":"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","sourcesContent":["/*\r\n * Copyright (c) 2024 Pobuca.\r\n * All rights reserved.\r\n */\r\n\r\nimport {\r\n  ChangeDetectionStrategy,\r\n  ChangeDetectorRef,\r\n  Component,\r\n  DoCheck,\r\n  HostBinding,\r\n  HostListener,\r\n  Input,\r\n  OnDestroy,\r\n  OnInit,\r\n  ViewEncapsulation\r\n} from '@angular/core';\r\nimport { ResizeEvent } from 'angular-resizable-element';\r\nimport { exhaustMap, filter, map, take, takeUntil } from 'rxjs/operators';\r\nimport { Subject } from 'rxjs';\r\n\r\nimport { defaultColumnsOptions, Structure } from '../../classes/Structure';\r\nimport { TBlocks } from '../../classes/Elements';\r\nimport { createBorder } from '../../utils';\r\nimport { IAddBlockEvent, PbUserMiddlewaresService } from '../../services/user-middleware-service/pb-middlewares.service';\r\nimport { PbUserInterfaceService } from '../../services/internals/user-interfaces/user-interface.service';\r\nimport { PbEmailObjectStoreService } from '../../services/internals/pb-email-object-store/pb-email-object-store.service';\r\n\r\n@Component({\r\n  selector: 'pb-structure',\r\n  templateUrl: './structure.component.html',\r\n  styleUrls: ['./structure.component.scss'],\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  encapsulation: ViewEncapsulation.Emulated,\r\n  exportAs: 'structure'\r\n})\r\nexport class StructureComponent implements DoCheck, OnInit, OnDestroy {\r\n  @Input() structure = new Structure();\r\n  @Input() index: number;\r\n  public isActive: boolean;\r\n  public cdkDropListConnectedTo$ = this.userInterfaceService.cdkDropListConnectedTo$;\r\n  public fr: number;\r\n  public validate = function ({ rectangle }: ResizeEvent) {\r\n    const colFr = +(rectangle.width / this.fr).toFixed(2);\r\n    return colFr > 1 && colFr <= 10 - this.structure.columns;\r\n  }.bind(this);\r\n  // sectionWidth$ = this.userInterfaceService.currentEditingStructure$.pipe(\r\n  //   withLatestFrom(this.emailObjectStore.emailBodyWidth$),\r\n  //   map(([{ options }, width]) => {\r\n  //     return options.fullWidth ? '100%' : width;\r\n  //   })\r\n  // );\r\n  private readonly componentIsDestroyed$ = new Subject();\r\n\r\n  constructor(\r\n    private userInterfaceService: PbUserInterfaceService,\r\n    private emailObjectStore: PbEmailObjectStoreService,\r\n    private chRef: ChangeDetectorRef,\r\n    private pbMiddlewaresService: PbUserMiddlewaresService\r\n  ) {}\r\n\r\n  @HostBinding('class.active') get isStructureActive() {\r\n    return this.isActive;\r\n  }\r\n\r\n  // @HostBinding('style.width') get sectionWidth(): string | number {\r\n  //   console.log(this.emailObjectStore.Email.general.width.value);\r\n  //   return this.structure.options.fullWidth ? '100%' : this.emailObjectStore.Email.general.width.value;\r\n  // }\r\n\r\n  // Don't close right panel on structure click\r\n  @HostListener('click', ['$event']) onHostClick(event: MouseEvent) {\r\n    event.stopImmediatePropagation();\r\n    this.editStructure();\r\n  }\r\n\r\n  removeStructure(event: Event) {\r\n    event.stopPropagation();\r\n    this.pbMiddlewaresService\r\n      .removeStructure(this.index, this.structure)\r\n      .pipe(\r\n        exhaustMap(() => this.userInterfaceService.confirmDialog$()),\r\n        filter(removeAllowed => removeAllowed),\r\n        take(1)\r\n      )\r\n      .subscribe(() => {\r\n        this.emailObjectStore.removeStructure(this.index);\r\n        this.userInterfaceService.resetElements();\r\n      });\r\n  }\r\n\r\n  duplicateStructure(event: Event) {\r\n    event.stopPropagation();\r\n    this.pbMiddlewaresService\r\n      .duplicateStructure(this.index, this.structure)\r\n      .pipe(\r\n        map(() => this.emailObjectStore.duplicateStructure(this.index)),\r\n        take(1)\r\n      )\r\n      .subscribe(newStructure => {\r\n        this.editStructure(newStructure);\r\n      });\r\n  }\r\n\r\n  dropNewBlock(event: IAddBlockEvent, column: TBlocks[]) {\r\n    if (event.previousContainer === event.container) {\r\n      this.emailObjectStore.addBlock(event, column);\r\n    } else {\r\n      this.pbMiddlewaresService\r\n        .addBlock(event, column)\r\n        .pipe(map(newData => this.emailObjectStore.addBlock(newData.event, newData.column)))\r\n        .subscribe(() => {\r\n          // this.userInterfaceService.editBlock(newBlock);\r\n          this.chRef.markForCheck();\r\n        });\r\n    }\r\n  }\r\n\r\n  disableBlockDrag$(block: TBlocks) {\r\n    return this.pbMiddlewaresService.disableBlockDragWithinEmailBody(block).pipe(take(1));\r\n  }\r\n\r\n  editStructure(structure = this.structure) {\r\n    this.pbMiddlewaresService\r\n      .editStructure(structure)\r\n      .pipe(take(1))\r\n      .subscribe(strctr => {\r\n        this.userInterfaceService.editStructure(strctr);\r\n      });\r\n  }\r\n\r\n  getResizeEdges(columnKey: number) {\r\n    return {\r\n      right: columnKey + 1 !== this.structure.columns,\r\n      left: columnKey !== 0\r\n    };\r\n  }\r\n\r\n  createColumnId(columnKey: number) {\r\n    return `column-droplist-${columnKey}-${this.index}`;\r\n  }\r\n\r\n  getColumnStyles(columnKey: number) {\r\n    const {\r\n      options: { gaps = [4, 4], columns = [] }\r\n    } = this.structure;\r\n    const column = columns[columnKey] || defaultColumnsOptions;\r\n\r\n    let verticalAlign = 'center';\r\n    if (column.verticalAlign === 'bottom') {\r\n      verticalAlign = 'flex-end';\r\n    } else if (column.verticalAlign === 'top') {\r\n      verticalAlign = 'flex-start';\r\n    }\r\n\r\n    return {\r\n      padding: gaps.map(gap => `${gap}px`).join(' '),\r\n      backgroundColor: column.background.color,\r\n      placeSelf: `${verticalAlign} stretch`,\r\n      ...createBorder(column.border)\r\n      // ...createBackground(column.background)\r\n    };\r\n  }\r\n\r\n  onResizeEnd({ rectangle }: ResizeEvent, key: number) {\r\n    this.structure.options.columnsWidth[key] = +(rectangle.width / this.fr).toFixed(2);\r\n  }\r\n\r\n  ngDoCheck() {\r\n    if (this.isActive || this.userInterfaceService.currentStructureContainsActiveBlock(this.structure)) {\r\n      this.chRef.markForCheck();\r\n    }\r\n  }\r\n\r\n  ngOnInit() {\r\n    // Add columns options in case of old template\r\n    const { columns, columnsWidth } = this.structure.options;\r\n    if (!columns || !columnsWidth) {\r\n      const { type, elements, options } = this.structure;\r\n      this.editStructure(new Structure(type, elements, options));\r\n    }\r\n\r\n    const width = this.emailObjectStore.Email.general.width.value;\r\n    const [, horizontalGap] = this.structure.options.gaps;\r\n    this.fr = (width - horizontalGap * this.structure.columns) / 10;\r\n\r\n    this.userInterfaceService.currentEditingStructure$\r\n      .pipe(\r\n        map(currentEditingStructure => currentEditingStructure === this.structure),\r\n        takeUntil(this.componentIsDestroyed$)\r\n      )\r\n      .subscribe(isActive => {\r\n        this.isActive = isActive;\r\n      });\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    this.componentIsDestroyed$.next('');\r\n    this.componentIsDestroyed$.complete();\r\n  }\r\n}\r\n"]}
|