@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.
Files changed (135) hide show
  1. package/README.md +1 -1
  2. package/bundles/pobuca-email-builder.umd.js +4464 -4414
  3. package/bundles/pobuca-email-builder.umd.js.map +1 -1
  4. package/bundles/pobuca-email-builder.umd.min.js +1 -1
  5. package/bundles/pobuca-email-builder.umd.min.js.map +1 -1
  6. package/esm2015/lib/classes/DefaultEmail.js +54 -53
  7. package/esm2015/lib/classes/Elements.js +229 -229
  8. package/esm2015/lib/classes/Structure.js +89 -89
  9. package/esm2015/lib/components/block/block.component.js +89 -89
  10. package/esm2015/lib/components/block-settings/block-settings.component.js +53 -53
  11. package/esm2015/lib/components/builder-container/builder-container.component.js +114 -114
  12. package/esm2015/lib/components/dialog.component.js +30 -30
  13. package/esm2015/lib/components/general-settings/general-settings.component.js +25 -25
  14. package/esm2015/lib/components/import-dialog/import-dialog.component.js +62 -62
  15. package/esm2015/lib/components/preview.component.js +89 -89
  16. package/esm2015/lib/components/structure/structure.component.js +163 -163
  17. package/esm2015/lib/components/structure-settings/structure-settings.component.js +31 -31
  18. package/esm2015/lib/components/template-list-dialog/template-list-dialog.component.js +45 -45
  19. package/esm2015/lib/directives/dynamic-component.directive.js +46 -46
  20. package/esm2015/lib/elements/abstract-block.js +23 -23
  21. package/esm2015/lib/elements/button/button.component.js +29 -29
  22. package/esm2015/lib/elements/divider/divider.component.js +30 -30
  23. package/esm2015/lib/elements/image/image.component.js +54 -54
  24. package/esm2015/lib/elements/social/social.component.js +42 -42
  25. package/esm2015/lib/elements/spacer/spacer.component.js +30 -30
  26. package/esm2015/lib/elements/text-element/text-element.component.js +80 -80
  27. package/esm2015/lib/groups/align.js +79 -79
  28. package/esm2015/lib/groups/back-repeat.js +55 -55
  29. package/esm2015/lib/groups/border.js +102 -102
  30. package/esm2015/lib/groups/color.js +139 -139
  31. package/esm2015/lib/groups/direction.js +63 -63
  32. package/esm2015/lib/groups/font-styles.js +127 -112
  33. package/esm2015/lib/groups/gaps.js +45 -45
  34. package/esm2015/lib/groups/line-height.js +68 -68
  35. package/esm2015/lib/groups/link.js +67 -67
  36. package/esm2015/lib/groups/margin.js +45 -45
  37. package/esm2015/lib/groups/padding.js +53 -53
  38. package/esm2015/lib/groups/upload-image.js +112 -112
  39. package/esm2015/lib/groups/width-height.js +94 -94
  40. package/esm2015/lib/interceptors/pb-interceptor.interceptor.js +51 -51
  41. package/esm2015/lib/interfaces/interfaces.js +13 -13
  42. package/esm2015/lib/pb-email-builder.component.js +258 -246
  43. package/esm2015/lib/pb-email-builder.module.js +291 -291
  44. package/esm2015/lib/pb-email-builder.service.js +134 -134
  45. package/esm2015/lib/pipes/slugify.pipe.js +39 -39
  46. package/esm2015/lib/services/internals/pb-email-object-store/pb-email-object-store.service.js +175 -165
  47. package/esm2015/lib/services/internals/user-interfaces/user-interface.service.js +122 -122
  48. package/esm2015/lib/services/pb-storage/FreeUsersStorage.class.js +11 -11
  49. package/esm2015/lib/services/pb-storage/index.js +7 -7
  50. package/esm2015/lib/services/pb-storage/pb-storage.service.js +79 -79
  51. package/esm2015/lib/services/user-image-uploader-service/free-users-image-uploader.service.js +26 -26
  52. package/esm2015/lib/services/user-image-uploader-service/index.js +8 -8
  53. package/esm2015/lib/services/user-image-uploader-service/paid-users-image-uploader.service.js +30 -30
  54. package/esm2015/lib/services/user-image-uploader-service/upload-bottom-sheet-dialog/upload-bottom-sheet-dialog.component.js +112 -112
  55. package/esm2015/lib/services/user-image-uploader-service/upload-image-gallery/upload-image-gallery.component.js +91 -91
  56. package/esm2015/lib/services/user-image-uploader-service/user-image-uploader.service.js +26 -26
  57. package/esm2015/lib/services/user-middleware-service/FreeUsersMiddleware.js +31 -31
  58. package/esm2015/lib/services/user-middleware-service/PaidUsersMiddleware.js +12 -12
  59. package/esm2015/lib/services/user-middleware-service/index.js +8 -8
  60. package/esm2015/lib/services/user-middleware-service/pb-middlewares.service.js +195 -195
  61. package/esm2015/lib/services/user-rest-api-service/free-users-rest-api.service.js +16 -16
  62. package/esm2015/lib/services/user-rest-api-service/index.js +7 -7
  63. package/esm2015/lib/services/user-rest-api-service/user-rest-api.service.js +116 -116
  64. package/esm2015/lib/tokens/private-tokens.js +17 -17
  65. package/esm2015/lib/tokens/tokens.js +159 -159
  66. package/esm2015/lib/utils.js +147 -147
  67. package/esm2015/pobuca-email-builder.js +42 -42
  68. package/esm2015/public_api.js +26 -26
  69. package/fesm2015/pobuca-email-builder.js +4206 -4168
  70. package/fesm2015/pobuca-email-builder.js.map +1 -1
  71. package/lib/classes/DefaultEmail.d.ts +10 -9
  72. package/lib/classes/Elements.d.ts +62 -62
  73. package/lib/classes/Structure.d.ts +11 -11
  74. package/lib/components/block/block.component.d.ts +25 -25
  75. package/lib/components/block-settings/block-settings.component.d.ts +18 -18
  76. package/lib/components/builder-container/builder-container.component.d.ts +36 -36
  77. package/lib/components/dialog.component.d.ts +10 -10
  78. package/lib/components/general-settings/general-settings.component.d.ts +6 -6
  79. package/lib/components/import-dialog/import-dialog.component.d.ts +16 -16
  80. package/lib/components/preview.component.d.ts +18 -18
  81. package/lib/components/structure/structure.component.d.ts +43 -43
  82. package/lib/components/structure-settings/structure-settings.component.d.ts +9 -9
  83. package/lib/components/template-list-dialog/template-list-dialog.component.d.ts +15 -15
  84. package/lib/directives/dynamic-component.directive.d.ts +13 -13
  85. package/lib/elements/abstract-block.d.ts +8 -8
  86. package/lib/elements/button/button.component.d.ts +18 -18
  87. package/lib/elements/divider/divider.component.d.ts +10 -10
  88. package/lib/elements/image/image.component.d.ts +19 -19
  89. package/lib/elements/social/social.component.d.ts +21 -21
  90. package/lib/elements/spacer/spacer.component.d.ts +5 -5
  91. package/lib/elements/text-element/text-element.component.d.ts +52 -52
  92. package/lib/groups/align.d.ts +17 -17
  93. package/lib/groups/back-repeat.d.ts +8 -8
  94. package/lib/groups/border.d.ts +13 -13
  95. package/lib/groups/color.d.ts +26 -26
  96. package/lib/groups/direction.d.ts +13 -13
  97. package/lib/groups/font-styles.d.ts +21 -17
  98. package/lib/groups/gaps.d.ts +7 -7
  99. package/lib/groups/line-height.d.ts +12 -12
  100. package/lib/groups/link.d.ts +11 -11
  101. package/lib/groups/margin.d.ts +8 -8
  102. package/lib/groups/padding.d.ts +8 -8
  103. package/lib/groups/upload-image.d.ts +19 -19
  104. package/lib/groups/width-height.d.ts +19 -19
  105. package/lib/interceptors/pb-interceptor.interceptor.d.ts +10 -10
  106. package/lib/interfaces/interfaces.d.ts +430 -422
  107. package/lib/pb-email-builder.component.d.ts +67 -67
  108. package/lib/pb-email-builder.module.d.ts +51 -51
  109. package/lib/pb-email-builder.service.d.ts +83 -83
  110. package/lib/pipes/slugify.pipe.d.ts +9 -9
  111. package/lib/services/internals/pb-email-object-store/pb-email-object-store.service.d.ts +50 -50
  112. package/lib/services/internals/user-interfaces/user-interface.service.d.ts +46 -46
  113. package/lib/services/pb-storage/FreeUsersStorage.class.d.ts +6 -6
  114. package/lib/services/pb-storage/index.d.ts +2 -2
  115. package/lib/services/pb-storage/pb-storage.service.d.ts +54 -54
  116. package/lib/services/user-image-uploader-service/free-users-image-uploader.service.d.ts +12 -12
  117. package/lib/services/user-image-uploader-service/index.d.ts +3 -3
  118. package/lib/services/user-image-uploader-service/paid-users-image-uploader.service.d.ts +14 -14
  119. package/lib/services/user-image-uploader-service/upload-bottom-sheet-dialog/upload-bottom-sheet-dialog.component.d.ts +28 -28
  120. package/lib/services/user-image-uploader-service/upload-image-gallery/upload-image-gallery.component.d.ts +27 -27
  121. package/lib/services/user-image-uploader-service/user-image-uploader.service.d.ts +26 -26
  122. package/lib/services/user-middleware-service/FreeUsersMiddleware.d.ts +15 -15
  123. package/lib/services/user-middleware-service/PaidUsersMiddleware.d.ts +7 -7
  124. package/lib/services/user-middleware-service/index.d.ts +3 -3
  125. package/lib/services/user-middleware-service/pb-middlewares.service.d.ts +190 -190
  126. package/lib/services/user-rest-api-service/free-users-rest-api.service.d.ts +10 -10
  127. package/lib/services/user-rest-api-service/index.d.ts +2 -2
  128. package/lib/services/user-rest-api-service/user-rest-api.service.d.ts +82 -82
  129. package/lib/tokens/private-tokens.d.ts +5 -5
  130. package/lib/tokens/tokens.d.ts +70 -70
  131. package/lib/utils.d.ts +88 -88
  132. package/package.json +8 -3
  133. package/pobuca-email-builder.d.ts +42 -42
  134. package/pobuca-email-builder.metadata.json +1 -1
  135. 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,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJldmlldy5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9wYi1lbWFpbC1idWlsZGVyL3NyYy9saWIvY29tcG9uZW50cy9wcmV2aWV3LmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7O0dBR0c7QUFFSCxPQUFPLEVBQUUsU0FBUyxFQUFVLEtBQUssRUFBRSx1QkFBdUIsRUFBYSxNQUFNLGVBQWUsQ0FBQztBQUU3RixPQUFPLEVBQUUsWUFBWSxFQUFtQixNQUFNLDJCQUEyQixDQUFDO0FBQzFFLE9BQU8sRUFBRSxJQUFJLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUV0QyxPQUFPLEVBQUUsd0JBQXdCLEVBQUUsTUFBTSw0REFBNEQsQ0FBQztBQUl0RyxNQUFNLFVBQVUsR0FBRyxJQUFJLEdBQUcsQ0FBQztJQUN6QixDQUFDLFNBQVMsRUFBRSxVQUFVLENBQUM7SUFDdkIsQ0FBQyxZQUFZLEVBQUUsV0FBVyxDQUFDO0lBQzNCLENBQUMsUUFBUSxFQUFFLFdBQVcsQ0FBQztDQUN4QixDQUFDLENBQUM7QUEyQ0gsTUFBTSxPQUFPLHdCQUF3QjtJQU1uQyxZQUFvQixXQUFxQyxFQUFVLFNBQXVCO1FBQXRFLGdCQUFXLEdBQVgsV0FBVyxDQUEwQjtRQUFVLGNBQVMsR0FBVCxTQUFTLENBQWM7UUFIbEYsV0FBTSxHQUFtQixTQUFTLENBQUM7SUFHa0QsQ0FBQztJQUU5RixZQUFZLENBQUMsTUFBNkI7UUFDeEMsT0FBTyxJQUFJLENBQUMsV0FBVzthQUNwQixtQkFBbUIsQ0FBQyxNQUFNLENBQUM7YUFDM0IsSUFBSSxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQzthQUNiLFNBQVMsQ0FBQyxNQUFNLENBQUMsRUFBRTtZQUNsQixJQUFJLENBQUMsTUFBTSxHQUFHLE1BQU0sQ0FBQztRQUN2QixDQUFDLENBQUMsQ0FBQztJQUNQLENBQUM7SUFFRCxZQUFZO1FBQ1YsT0FBTyxVQUFVLENBQUMsR0FBRyxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsQ0FBQztJQUNyQyxDQUFDO0lBRUQsUUFBUTtRQUNOLElBQUksQ0FBQyxHQUFHLEdBQUcsR0FBRyxDQUFDLGVBQWUsQ0FBQyxJQUFJLElBQUksQ0FBQyxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsRUFBRSxFQUFFLElBQUksRUFBRSxXQUFXLEVBQUUsQ0FBQyxDQUFDLENBQUM7UUFDakYsSUFBSSxDQUFDLFdBQVcsR0FBRyxJQUFJLENBQUMsU0FBUyxDQUFDLDhCQUE4QixDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQztJQUM3RSxDQUFDO0lBRUQsV0FBVztRQUNULElBQUksSUFBSSxDQUFDLEdBQUcsRUFBRTtZQUNaLEdBQUcsQ0FBQyxlQUFlLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDO1NBQy9CO0lBQ0gsQ0FBQzs7O1lBdkVGLFNBQVMsU0FBQztnQkFDVCxRQUFRLEVBQUUscUJBQXFCO2dCQUMvQixRQUFRLEVBQUU7Ozs7Ozs7Ozs7Ozs7R0FhVDtnQkF3QkQsZUFBZSxFQUFFLHVCQUF1QixDQUFDLE1BQU07eUJBdEI3Qzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7S0FvQkM7YUFHSjs7O1lBbERRLHdCQUF3QjtZQUh4QixZQUFZOzs7dUJBdURsQixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiLypcbiAqIENvcHlyaWdodCAoYykgMjAyNCBQb2J1Y2EuXG4gKiBBbGwgcmlnaHRzIHJlc2VydmVkLlxuICovXG5cbmltcG9ydCB7IENvbXBvbmVudCwgT25Jbml0LCBJbnB1dCwgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIE9uRGVzdHJveSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgTWF0QnV0dG9uVG9nZ2xlQ2hhbmdlIH0gZnJvbSAnQGFuZ3VsYXIvbWF0ZXJpYWwvYnV0dG9uLXRvZ2dsZSc7XG5pbXBvcnQgeyBEb21TYW5pdGl6ZXIsIFNhZmVSZXNvdXJjZVVybCB9IGZyb20gJ0Bhbmd1bGFyL3BsYXRmb3JtLWJyb3dzZXInO1xuaW1wb3J0IHsgdGFrZSB9IGZyb20gJ3J4anMvb3BlcmF0b3JzJztcblxuaW1wb3J0IHsgUGJVc2VyTWlkZGxld2FyZXNTZXJ2aWNlIH0gZnJvbSAnLi4vc2VydmljZXMvdXNlci1taWRkbGV3YXJlLXNlcnZpY2UvcGItbWlkZGxld2FyZXMuc2VydmljZSc7XG5cbmV4cG9ydCB0eXBlIFRQcmV2aWV3RGV2aWNlID0gJ2Rlc2t0b3AnIHwgJ3NtYXJ0cGhvbmUnIHwgJ3RhYmxldCc7XG5cbmNvbnN0IGRldmljZXNNYXAgPSBuZXcgTWFwKFtcbiAgWydkZXNrdG9wJywgJzEgMSAxMDAlJ10sXG4gIFsnc21hcnRwaG9uZScsICcxIDEgMzYwcHgnXSxcbiAgWyd0YWJsZXQnLCAnMSAxIDc2OHB4J11cbl0pO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdwYi1wcmV2aWV3LXRlbXBsYXRlJyxcbiAgdGVtcGxhdGU6IGBcbiAgICA8aWZyYW1lIFtzcmNdPVwidGVtcGxhdGVTcmNcIiBbZnhGbGV4XT1cImdldEZsZXhXaWR0aCgpXCI+PC9pZnJhbWU+XG4gICAgPG1hdC1idXR0b24tdG9nZ2xlLWdyb3VwIHZhbHVlPVwiZGVza3RvcFwiIChjaGFuZ2UpPVwiY2hhbmdlRGV2aWNlKCRldmVudClcIiB2ZXJ0aWNhbD5cbiAgICAgIDxtYXQtYnV0dG9uLXRvZ2dsZSB2YWx1ZT1cImRlc2t0b3BcIiBtYXRUb29sdGlwPVwiRGVza3RvcCAvIDEwMCVcIiBtYXRUb29sdGlwUG9zaXRpb249XCJsZWZ0XCI+XG4gICAgICAgIDxtYXQtaWNvbj5kZXNrdG9wX3dpbmRvd3M8L21hdC1pY29uPlxuICAgICAgPC9tYXQtYnV0dG9uLXRvZ2dsZT5cbiAgICAgIDxtYXQtYnV0dG9uLXRvZ2dsZSB2YWx1ZT1cInRhYmxldFwiIG1hdFRvb2x0aXA9XCJUYWJsZXQgLyA3NjhweFwiIG1hdFRvb2x0aXBQb3NpdGlvbj1cImxlZnRcIj5cbiAgICAgICAgPG1hdC1pY29uPnRhYmxldDwvbWF0LWljb24+XG4gICAgICA8L21hdC1idXR0b24tdG9nZ2xlPlxuICAgICAgPG1hdC1idXR0b24tdG9nZ2xlIHZhbHVlPVwic21hcnRwaG9uZVwiIG1hdFRvb2x0aXA9XCJTbWFydHBob25lIC8gMzYwcHhcIiBtYXRUb29sdGlwUG9zaXRpb249XCJsZWZ0XCI+XG4gICAgICAgIDxtYXQtaWNvbj5zbWFydHBob25lPC9tYXQtaWNvbj5cbiAgICAgIDwvbWF0LWJ1dHRvbi10b2dnbGU+XG4gICAgPC9tYXQtYnV0dG9uLXRvZ2dsZS1ncm91cD5cbiAgYCxcbiAgc3R5bGVzOiBbXG4gICAgYFxuICAgICAgaWZyYW1lIHtcbiAgICAgICAgYm9yZGVyOiAwO1xuICAgICAgICB3aWxsLWNoYW5nZTogd2lkdGg7XG4gICAgICAgIHRyYW5zaXRpb246IGFsbCA1MDBtcyBlYXNlLWluLW91dDtcbiAgICAgIH1cblxuICAgICAgLyogaWZyYW1lIGFbaHJlZl0ge1xuICAgICAgICBwb2ludGVyLWV2ZW50czogbm9uZTtcbiAgICAgIH0gKi9cblxuICAgICAgLyogaWZyYW1lLmFjdGl2ZSB7XG4gICAgICAgIG9wYWNpdHk6IDE7XG4gICAgICB9ICovXG5cbiAgICAgIG1hdC1idXR0b24tdG9nZ2xlLWdyb3VwIHtcbiAgICAgICAgcG9zaXRpb246IGFic29sdXRlO1xuICAgICAgICByaWdodDogMDtcbiAgICAgICAgYmFja2dyb3VuZDogd2hpdGU7XG4gICAgICB9XG4gICAgYFxuICBdLFxuICBjaGFuZ2VEZXRlY3Rpb246IENoYW5nZURldGVjdGlvblN0cmF0ZWd5Lk9uUHVzaFxufSlcbmV4cG9ydCBjbGFzcyBQcmV2aWV3VGVtcGxhdGVDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQsIE9uRGVzdHJveSB7XG4gIEBJbnB1dCgpIHRlbXBsYXRlOiBzdHJpbmc7XG4gIHByaXZhdGUgc3JjOiBzdHJpbmc7XG4gIHByaXZhdGUgZGV2aWNlOiBUUHJldmlld0RldmljZSA9ICdkZXNrdG9wJztcbiAgdGVtcGxhdGVTcmM6IFNhZmVSZXNvdXJjZVVybDtcblxuICBjb25zdHJ1Y3Rvcihwcml2YXRlIG1pZGRsZXdhcmVzOiBQYlVzZXJNaWRkbGV3YXJlc1NlcnZpY2UsIHByaXZhdGUgc2FuaXRpemVyOiBEb21TYW5pdGl6ZXIpIHt9XG5cbiAgY2hhbmdlRGV2aWNlKGJ1dHRvbjogTWF0QnV0dG9uVG9nZ2xlQ2hhbmdlKSB7XG4gICAgcmV0dXJuIHRoaXMubWlkZGxld2FyZXNcbiAgICAgIC50b2dnbGVQcmV2aWV3RGV2aWNlKGJ1dHRvbilcbiAgICAgIC5waXBlKHRha2UoMSkpXG4gICAgICAuc3Vic2NyaWJlKGRldmljZSA9PiB7XG4gICAgICAgIHRoaXMuZGV2aWNlID0gZGV2aWNlO1xuICAgICAgfSk7XG4gIH1cblxuICBnZXRGbGV4V2lkdGgoKSB7XG4gICAgcmV0dXJuIGRldmljZXNNYXAuZ2V0KHRoaXMuZGV2aWNlKTtcbiAgfVxuXG4gIG5nT25Jbml0KCkge1xuICAgIHRoaXMuc3JjID0gVVJMLmNyZWF0ZU9iamVjdFVSTChuZXcgQmxvYihbdGhpcy50ZW1wbGF0ZV0sIHsgdHlwZTogJ3RleHQvaHRtbCcgfSkpO1xuICAgIHRoaXMudGVtcGxhdGVTcmMgPSB0aGlzLnNhbml0aXplci5ieXBhc3NTZWN1cml0eVRydXN0UmVzb3VyY2VVcmwodGhpcy5zcmMpO1xuICB9XG5cbiAgbmdPbkRlc3Ryb3koKSB7XG4gICAgaWYgKHRoaXMuc3JjKSB7XG4gICAgICBVUkwucmV2b2tlT2JqZWN0VVJMKHRoaXMuc3JjKTtcbiAgICB9XG4gIH1cbn1cbiJdfQ==
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"]}