@pobuca/email-builder 1.0.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 (150) hide show
  1. package/README.md +1 -0
  2. package/assets/icons/dribbble.png +0 -0
  3. package/assets/icons/facebook.png +0 -0
  4. package/assets/icons/github.png +0 -0
  5. package/assets/icons/instagram.png +0 -0
  6. package/assets/icons/linkedin.png +0 -0
  7. package/assets/icons/medium.png +0 -0
  8. package/assets/icons/pinterest.png +0 -0
  9. package/assets/icons/snapchat.png +0 -0
  10. package/assets/icons/soundcloud.png +0 -0
  11. package/assets/icons/tumblr.png +0 -0
  12. package/assets/icons/twitter.png +0 -0
  13. package/assets/icons/vimeo.png +0 -0
  14. package/assets/icons/web.png +0 -0
  15. package/assets/icons/xing.png +0 -0
  16. package/assets/icons/youtube.png +0 -0
  17. package/bundles/pobuca-email-builder.umd.js +4664 -0
  18. package/bundles/pobuca-email-builder.umd.js.map +1 -0
  19. package/bundles/pobuca-email-builder.umd.min.js +2 -0
  20. package/bundles/pobuca-email-builder.umd.min.js.map +1 -0
  21. package/esm2015/lib/classes/DefaultEmail.js +53 -0
  22. package/esm2015/lib/classes/Elements.js +229 -0
  23. package/esm2015/lib/classes/Structure.js +89 -0
  24. package/esm2015/lib/components/block/block.component.js +89 -0
  25. package/esm2015/lib/components/block-settings/block-settings.component.js +53 -0
  26. package/esm2015/lib/components/builder-container/builder-container.component.js +114 -0
  27. package/esm2015/lib/components/dialog.component.js +30 -0
  28. package/esm2015/lib/components/general-settings/general-settings.component.js +25 -0
  29. package/esm2015/lib/components/import-dialog/import-dialog.component.js +62 -0
  30. package/esm2015/lib/components/preview.component.js +89 -0
  31. package/esm2015/lib/components/structure/structure.component.js +163 -0
  32. package/esm2015/lib/components/structure-settings/structure-settings.component.js +31 -0
  33. package/esm2015/lib/components/template-list-dialog/template-list-dialog.component.js +45 -0
  34. package/esm2015/lib/directives/dynamic-component.directive.js +46 -0
  35. package/esm2015/lib/elements/abstract-block.js +23 -0
  36. package/esm2015/lib/elements/button/button.component.js +29 -0
  37. package/esm2015/lib/elements/divider/divider.component.js +30 -0
  38. package/esm2015/lib/elements/image/image.component.js +54 -0
  39. package/esm2015/lib/elements/social/social.component.js +42 -0
  40. package/esm2015/lib/elements/spacer/spacer.component.js +30 -0
  41. package/esm2015/lib/elements/text-element/text-element.component.js +80 -0
  42. package/esm2015/lib/groups/align.js +79 -0
  43. package/esm2015/lib/groups/back-repeat.js +55 -0
  44. package/esm2015/lib/groups/border.js +102 -0
  45. package/esm2015/lib/groups/color.js +139 -0
  46. package/esm2015/lib/groups/direction.js +63 -0
  47. package/esm2015/lib/groups/font-styles.js +112 -0
  48. package/esm2015/lib/groups/gaps.js +45 -0
  49. package/esm2015/lib/groups/line-height.js +68 -0
  50. package/esm2015/lib/groups/link.js +67 -0
  51. package/esm2015/lib/groups/margin.js +45 -0
  52. package/esm2015/lib/groups/padding.js +53 -0
  53. package/esm2015/lib/groups/upload-image.js +112 -0
  54. package/esm2015/lib/groups/width-height.js +94 -0
  55. package/esm2015/lib/interceptors/pb-interceptor.interceptor.js +51 -0
  56. package/esm2015/lib/interfaces/interfaces.js +13 -0
  57. package/esm2015/lib/pb-email-builder.component.js +246 -0
  58. package/esm2015/lib/pb-email-builder.module.js +291 -0
  59. package/esm2015/lib/pb-email-builder.service.js +134 -0
  60. package/esm2015/lib/pipes/slugify.pipe.js +39 -0
  61. package/esm2015/lib/services/internals/pb-email-object-store/pb-email-object-store.service.js +165 -0
  62. package/esm2015/lib/services/internals/user-interfaces/user-interface.service.js +122 -0
  63. package/esm2015/lib/services/pb-storage/FreeUsersStorage.class.js +11 -0
  64. package/esm2015/lib/services/pb-storage/index.js +7 -0
  65. package/esm2015/lib/services/pb-storage/pb-storage.service.js +79 -0
  66. package/esm2015/lib/services/user-image-uploader-service/free-users-image-uploader.service.js +26 -0
  67. package/esm2015/lib/services/user-image-uploader-service/index.js +8 -0
  68. package/esm2015/lib/services/user-image-uploader-service/paid-users-image-uploader.service.js +30 -0
  69. package/esm2015/lib/services/user-image-uploader-service/upload-bottom-sheet-dialog/upload-bottom-sheet-dialog.component.js +112 -0
  70. package/esm2015/lib/services/user-image-uploader-service/upload-image-gallery/upload-image-gallery.component.js +91 -0
  71. package/esm2015/lib/services/user-image-uploader-service/user-image-uploader.service.js +26 -0
  72. package/esm2015/lib/services/user-middleware-service/FreeUsersMiddleware.js +31 -0
  73. package/esm2015/lib/services/user-middleware-service/PaidUsersMiddleware.js +12 -0
  74. package/esm2015/lib/services/user-middleware-service/index.js +8 -0
  75. package/esm2015/lib/services/user-middleware-service/pb-middlewares.service.js +195 -0
  76. package/esm2015/lib/services/user-rest-api-service/free-users-rest-api.service.js +16 -0
  77. package/esm2015/lib/services/user-rest-api-service/index.js +7 -0
  78. package/esm2015/lib/services/user-rest-api-service/user-rest-api.service.js +116 -0
  79. package/esm2015/lib/tokens/private-tokens.js +17 -0
  80. package/esm2015/lib/tokens/tokens.js +159 -0
  81. package/esm2015/lib/utils.js +147 -0
  82. package/esm2015/pobuca-email-builder.js +43 -0
  83. package/esm2015/public_api.js +26 -0
  84. package/fesm2015/pobuca-email-builder.js +4335 -0
  85. package/fesm2015/pobuca-email-builder.js.map +1 -0
  86. package/lib/classes/DefaultEmail.d.ts +9 -0
  87. package/lib/classes/Elements.d.ts +62 -0
  88. package/lib/classes/Structure.d.ts +11 -0
  89. package/lib/components/block/block.component.d.ts +25 -0
  90. package/lib/components/block-settings/block-settings.component.d.ts +18 -0
  91. package/lib/components/builder-container/builder-container.component.d.ts +36 -0
  92. package/lib/components/dialog.component.d.ts +10 -0
  93. package/lib/components/general-settings/general-settings.component.d.ts +6 -0
  94. package/lib/components/import-dialog/import-dialog.component.d.ts +16 -0
  95. package/lib/components/preview.component.d.ts +18 -0
  96. package/lib/components/structure/structure.component.d.ts +43 -0
  97. package/lib/components/structure-settings/structure-settings.component.d.ts +9 -0
  98. package/lib/components/template-list-dialog/template-list-dialog.component.d.ts +15 -0
  99. package/lib/directives/dynamic-component.directive.d.ts +13 -0
  100. package/lib/elements/abstract-block.d.ts +8 -0
  101. package/lib/elements/button/button.component.d.ts +18 -0
  102. package/lib/elements/divider/divider.component.d.ts +10 -0
  103. package/lib/elements/image/image.component.d.ts +19 -0
  104. package/lib/elements/social/social.component.d.ts +21 -0
  105. package/lib/elements/spacer/spacer.component.d.ts +5 -0
  106. package/lib/elements/text-element/text-element.component.d.ts +52 -0
  107. package/lib/groups/align.d.ts +17 -0
  108. package/lib/groups/back-repeat.d.ts +8 -0
  109. package/lib/groups/border.d.ts +13 -0
  110. package/lib/groups/color.d.ts +26 -0
  111. package/lib/groups/direction.d.ts +13 -0
  112. package/lib/groups/font-styles.d.ts +17 -0
  113. package/lib/groups/gaps.d.ts +7 -0
  114. package/lib/groups/line-height.d.ts +12 -0
  115. package/lib/groups/link.d.ts +11 -0
  116. package/lib/groups/margin.d.ts +8 -0
  117. package/lib/groups/padding.d.ts +8 -0
  118. package/lib/groups/upload-image.d.ts +19 -0
  119. package/lib/groups/width-height.d.ts +19 -0
  120. package/lib/interceptors/pb-interceptor.interceptor.d.ts +10 -0
  121. package/lib/interfaces/interfaces.d.ts +422 -0
  122. package/lib/pb-email-builder.component.d.ts +67 -0
  123. package/lib/pb-email-builder.module.d.ts +51 -0
  124. package/lib/pb-email-builder.service.d.ts +83 -0
  125. package/lib/pipes/slugify.pipe.d.ts +9 -0
  126. package/lib/services/internals/pb-email-object-store/pb-email-object-store.service.d.ts +50 -0
  127. package/lib/services/internals/user-interfaces/user-interface.service.d.ts +46 -0
  128. package/lib/services/pb-storage/FreeUsersStorage.class.d.ts +6 -0
  129. package/lib/services/pb-storage/index.d.ts +2 -0
  130. package/lib/services/pb-storage/pb-storage.service.d.ts +54 -0
  131. package/lib/services/user-image-uploader-service/free-users-image-uploader.service.d.ts +12 -0
  132. package/lib/services/user-image-uploader-service/index.d.ts +3 -0
  133. package/lib/services/user-image-uploader-service/paid-users-image-uploader.service.d.ts +14 -0
  134. package/lib/services/user-image-uploader-service/upload-bottom-sheet-dialog/upload-bottom-sheet-dialog.component.d.ts +28 -0
  135. package/lib/services/user-image-uploader-service/upload-image-gallery/upload-image-gallery.component.d.ts +27 -0
  136. package/lib/services/user-image-uploader-service/user-image-uploader.service.d.ts +26 -0
  137. package/lib/services/user-middleware-service/FreeUsersMiddleware.d.ts +15 -0
  138. package/lib/services/user-middleware-service/PaidUsersMiddleware.d.ts +7 -0
  139. package/lib/services/user-middleware-service/index.d.ts +3 -0
  140. package/lib/services/user-middleware-service/pb-middlewares.service.d.ts +190 -0
  141. package/lib/services/user-rest-api-service/free-users-rest-api.service.d.ts +10 -0
  142. package/lib/services/user-rest-api-service/index.d.ts +2 -0
  143. package/lib/services/user-rest-api-service/user-rest-api.service.d.ts +82 -0
  144. package/lib/tokens/private-tokens.d.ts +5 -0
  145. package/lib/tokens/tokens.d.ts +70 -0
  146. package/lib/utils.d.ts +88 -0
  147. package/package.json +37 -0
  148. package/pobuca-email-builder.d.ts +42 -0
  149. package/pobuca-email-builder.metadata.json +1 -0
  150. package/public_api.d.ts +16 -0
@@ -0,0 +1,114 @@
1
+ /*
2
+ * Copyright (c) 2024 Pobuca.
3
+ * All rights reserved.
4
+ */
5
+ import { ChangeDetectionStrategy, Component, HostListener, Inject } from '@angular/core';
6
+ import { DomSanitizer } from '@angular/platform-browser';
7
+ import { catchError, exhaustMap, finalize, map, switchMap, take, tap } from 'rxjs/operators';
8
+ import { EMPTY, iif, throwError } from 'rxjs';
9
+ import { createBorder, createMargin, createPadding, createWidthHeight, deferOf } from '../../utils';
10
+ import { PBEmail } from '../../classes/DefaultEmail';
11
+ import { PbUserMiddlewaresService } from '../../services/user-middleware-service/pb-middlewares.service';
12
+ import { PbUserInterfaceService } from '../../services/internals/user-interfaces/user-interface.service';
13
+ import { PbEmailObjectStoreService } from '../../services/internals/pb-email-object-store/pb-email-object-store.service';
14
+ import { PbUserRestApiService } from '../../services/user-rest-api-service/user-rest-api.service';
15
+ import { PB_CONFIG } from '../../tokens/tokens';
16
+ import { PbStorageService } from '../../services/pb-storage/pb-storage.service';
17
+ // import { IpUserRestApiProvider } from '../providers';
18
+ export class BuilderContainerComponent {
19
+ constructor(userInterfaceService, emailObjectStore, userRestApi, pbStorage, pbMiddlewaresService, sanitizer, userConfig) {
20
+ var _a;
21
+ this.userInterfaceService = userInterfaceService;
22
+ this.emailObjectStore = emailObjectStore;
23
+ this.userRestApi = userRestApi;
24
+ this.pbStorage = pbStorage;
25
+ this.pbMiddlewaresService = pbMiddlewaresService;
26
+ this.sanitizer = sanitizer;
27
+ this.userConfig = userConfig;
28
+ this.showTemplateList = (_a = this.userConfig.templateListIfEmpty) !== null && _a !== void 0 ? _a : true;
29
+ this.getStructures$ = this.emailObjectStore.emailStructuresAsObservable$;
30
+ this.activeMatProgress$ = this.userInterfaceService.activeMatProgress$;
31
+ }
32
+ onHostClick() {
33
+ this.userInterfaceService.editGeneralSettings();
34
+ }
35
+ trackBy(structure) {
36
+ return structure.id;
37
+ }
38
+ disableStructureDrag$(structure) {
39
+ return this.pbMiddlewaresService.disableStructureDragWithinEmailBody(structure).pipe(take(1));
40
+ }
41
+ openTemplateDialog(ev) {
42
+ ev.stopImmediatePropagation();
43
+ this.userInterfaceService.activeMatProgress$.next(true);
44
+ const cachedTemplates = this.pbStorage.getCachedTemplateList();
45
+ return iif(() => cachedTemplates.length > 0, deferOf(cachedTemplates), this.userRestApi.getAllUserTemplates$.pipe(tap(list => this.pbStorage.cacheTemplateList(list))))
46
+ .pipe(
47
+ // map(() => []),
48
+ map(templates => {
49
+ return [...templates, { category: 'latest', templates: this.pbStorage.getLatestUsedTemplates() }];
50
+ }), finalize(() => this.userInterfaceService.activeMatProgress$.next(false)), exhaustMap(list => (list === null || list === void 0 ? void 0 : list.length) > 0 ? this.userInterfaceService.templatesListDialog$(list) : throwError(new Error('The template list is empty'))), switchMap(({ category, template }) => this.pbMiddlewaresService.chooseTemplate(category, template)), exhaustMap(({ category, template }) => this.userRestApi.getUserTemplateData$(category, template).pipe(tap(choosedTemplate => {
51
+ if (category !== 'latest') {
52
+ this.pbStorage.addTemplateToLatestUsed(choosedTemplate);
53
+ }
54
+ }))), catchError((error) => this.pbMiddlewaresService.catchError(error).pipe(switchMap(() => {
55
+ this.userInterfaceService.notify(error.message);
56
+ return EMPTY;
57
+ }))), take(1))
58
+ .subscribe((result) => {
59
+ if (result) {
60
+ this.emailObjectStore.setEmail(new PBEmail(result.templateData));
61
+ }
62
+ else {
63
+ this.userInterfaceService.notify('No template was chosen');
64
+ }
65
+ });
66
+ }
67
+ dropNewStructure(event) {
68
+ if (event.previousContainer === event.container) {
69
+ this.emailObjectStore.changeStructureOrder(event);
70
+ }
71
+ else {
72
+ this.pbMiddlewaresService
73
+ .addStructure(event)
74
+ .pipe(tap(newEvent => this.emailObjectStore.addStructure(newEvent)), take(1))
75
+ .subscribe();
76
+ }
77
+ }
78
+ getStructureStyles(structure) {
79
+ const { border, background, padding, margin, columnsWidth, fullWidth } = structure.options;
80
+ return Object.assign(Object.assign(Object.assign({
81
+ // direction,
82
+ width: fullWidth ? '100%' : `${this.emailObjectStore.Email.general.width.value}px`, backgroundRepeat: background.repeat, backgroundColor: background.color, backgroundSize: createWidthHeight(background.size), backgroundPosition: 'top center', gridTemplateColumns: columnsWidth.map(fr => `${fr}fr`).join(' ') }, createBorder(border)), createPadding(padding)), createMargin(margin));
83
+ }
84
+ getBackgroundImage(structure) {
85
+ const { background: { url } } = structure.options;
86
+ return this.sanitizer.bypassSecurityTrustStyle(url && `url(${url})`);
87
+ }
88
+ }
89
+ BuilderContainerComponent.decorators = [
90
+ { type: Component, args: [{
91
+ selector: 'pb-builder-container',
92
+ template: "<!--\n ~ Copyright (c) 2024 Pobuca.\n ~ All rights reserved.\n -->\n\n<ng-container *ngIf=\"getStructures$ | async as structures\">\n <div cdkDropList [cdkDropListData]=\"structures\"\n cdkDropListConnectedTo=\"structures-drop-list\" id=\"structures-drop-list\"\n (cdkDropListDropped)=\"dropNewStructure($event)\" fxFlex fxLayout=\"column\" fxLayoutAlign=\"start center\">\n <pb-structure cdkDrag\n *ngFor=\"let structure of structures; trackBy: trackBy; let index = index\" [id]=\"structure.id\"\n [index]=\"index\" [ngClass]=\"structure.type\" [structure]=\"structure\"\n [ngStyle]=\"getStructureStyles(structure)\"\n [style.backgroundImage]=\"getBackgroundImage(structure)\"\n [cdkDragDisabled]=\"disableStructureDrag$(structure) | async\">\n <button cdkDragHandle mat-icon-button class=\"move\" *ngIf=\"!(disableStructureDrag$(structure) | async)\"\n i18n-matTooltip=\"structure|Move Structure\" matTooltip=\"Move Structure\">\n <mat-icon i18n-aria-label=\"structure|Move Structure\" aria-label=\"Move structure\" inline>pan_tool</mat-icon>\n </button>\n </pb-structure>\n\n <div class=\"empty-email mat-typography\" *ngIf=\"!structures.length\">\n <ng-content></ng-content>\n <div class=\"default-empty-email\" *ngIf=\"showTemplateList\">\n <h1 i18n=\"templates|First header\">Choose template from list</h1>\n <p i18n=\"templates|Description\">Or create one from scratch by dragging structures and blocks here!</p>\n <button type=\"button\" color=\"primary\" [disabled]=\"activeMatProgress$ | async\"\n (click)=\"openTemplateDialog($event)\" mat-flat-button i18n=\"templates|Choose a template button\">\n Choose template\n </button>\n </div>\n </div>\n </div>\n</ng-container>\n",
93
+ providers: [
94
+ // IpUserRestApiProvider
95
+ ],
96
+ changeDetection: ChangeDetectionStrategy.OnPush
97
+ // encapsulation: ViewEncapsulation.None
98
+ ,
99
+ styles: ["/*!\n * Copyright (c) 2024 Pobuca.\n * All rights reserved.\n */pb-structure>.cdk-drag-handle{position:absolute;cursor:move;border-radius:50% 50% 0 0;height:30px;width:30px;font-size:smaller;line-height:0;top:-30px;right:0;background-color:#ff4081;color:#fff;opacity:0}pb-structure.cdk-drag-preview>.cdk-drag-handle,pb-structure:hover>.cdk-drag-handle{opacity:.8}pb-structure.cdk-drag-preview>.cdk-drag-handle:hover,pb-structure:hover>.cdk-drag-handle:hover{opacity:1}pb-structure ::ng-deep .cdk-drag-placeholder{background-color:#3f51b5;opacity:.6;cursor:move;border-radius:0}pb-structure ::ng-deep .cdk-drag-placeholder ::ng-deep :not(mat-icon){display:none}pb-structure ::ng-deep .cdk-drag-placeholder ::ng-deep mat-icon{padding:5px;color:#fff}:host{background-color:#f2f2f2;overflow-x:hidden;overflow-y:auto;position:relative;height:100%}:host #structures-drop-list{height:-moz-fit-content;height:fit-content;max-width:100%;padding-bottom:3rem;will-change:box-shadow}:host #structures-drop-list .empty-email{display:flex;justify-content:center;align-items:center;flex-direction:column;flex:1 1 100%;margin-top:10%}:host #structures-drop-list .empty-email .default-empty-email{text-align:center}:host #structures-drop-list.cdk-drop-list-dragging .empty-email{display:none}"]
100
+ },] }
101
+ ];
102
+ BuilderContainerComponent.ctorParameters = () => [
103
+ { type: PbUserInterfaceService },
104
+ { type: PbEmailObjectStoreService },
105
+ { type: PbUserRestApiService },
106
+ { type: PbStorageService },
107
+ { type: PbUserMiddlewaresService },
108
+ { type: DomSanitizer },
109
+ { type: undefined, decorators: [{ type: Inject, args: [PB_CONFIG,] }] }
110
+ ];
111
+ BuilderContainerComponent.propDecorators = {
112
+ onHostClick: [{ type: HostListener, args: ['click',] }]
113
+ };
114
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"builder-container.component.js","sourceRoot":"","sources":["../../../../../../projects/pb-email-builder/src/lib/components/builder-container/builder-container.component.ts"],"names":[],"mappings":"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","sourcesContent":["/*\n * Copyright (c) 2024 Pobuca.\n * All rights reserved.\n */\n\nimport { ChangeDetectionStrategy, Component, HostListener, Inject } from '@angular/core';\nimport { HttpErrorResponse } from '@angular/common/http';\nimport { DomSanitizer, SafeStyle } from '@angular/platform-browser';\nimport { catchError, exhaustMap, finalize, map, switchMap, take, tap } from 'rxjs/operators';\nimport { EMPTY, iif, throwError } from 'rxjs';\n\nimport { createBorder, createMargin, createPadding, createWidthHeight, deferOf } from '../../utils';\nimport { IForRootConf, IStructure, IUserTemplate } from '../../interfaces/interfaces';\nimport { PBEmail } from '../../classes/DefaultEmail';\nimport { IAddStructureEvent, 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';\nimport { PbUserRestApiService } from '../../services/user-rest-api-service/user-rest-api.service';\nimport { PB_CONFIG } from '../../tokens/tokens';\nimport { PbStorageService } from '../../services/pb-storage/pb-storage.service';\n\n// import { IpUserRestApiProvider } from '../providers';\n\n@Component({\n  selector: 'pb-builder-container',\n  templateUrl: './builder-container.component.html',\n  styleUrls: ['./builder-container.scss'],\n  providers: [\n    // IpUserRestApiProvider\n  ],\n  changeDetection: ChangeDetectionStrategy.OnPush\n  // encapsulation: ViewEncapsulation.None\n})\nexport class BuilderContainerComponent {\n  showTemplateList = this.userConfig.templateListIfEmpty ?? true;\n  getStructures$ = this.emailObjectStore.emailStructuresAsObservable$;\n  activeMatProgress$ = this.userInterfaceService.activeMatProgress$;\n\n  constructor(\n    private userInterfaceService: PbUserInterfaceService,\n    private emailObjectStore: PbEmailObjectStoreService,\n    private userRestApi: PbUserRestApiService,\n    private pbStorage: PbStorageService,\n    private pbMiddlewaresService: PbUserMiddlewaresService,\n    private sanitizer: DomSanitizer,\n    @Inject(PB_CONFIG) private userConfig: IForRootConf\n  ) {}\n\n  @HostListener('click') onHostClick() {\n    this.userInterfaceService.editGeneralSettings();\n  }\n\n  trackBy(structure: IStructure): number {\n    return structure.id;\n  }\n\n  disableStructureDrag$(structure: IStructure) {\n    return this.pbMiddlewaresService.disableStructureDragWithinEmailBody(structure).pipe(take(1));\n  }\n\n  openTemplateDialog(ev: Event) {\n    ev.stopImmediatePropagation();\n    this.userInterfaceService.activeMatProgress$.next(true);\n    const cachedTemplates = this.pbStorage.getCachedTemplateList();\n    return iif(\n      () => cachedTemplates.length > 0,\n      deferOf(cachedTemplates),\n      this.userRestApi.getAllUserTemplates$.pipe(tap(list => this.pbStorage.cacheTemplateList(list)))\n    )\n      .pipe(\n        // map(() => []),\n        map(templates => {\n          return [...templates, { category: 'latest', templates: this.pbStorage.getLatestUsedTemplates() }];\n        }),\n        finalize(() => this.userInterfaceService.activeMatProgress$.next(false)),\n        exhaustMap(list =>\n          list?.length > 0 ? this.userInterfaceService.templatesListDialog$(list) : throwError(new Error('The template list is empty'))\n        ),\n        switchMap(({ category, template }) => this.pbMiddlewaresService.chooseTemplate(category, template)),\n        exhaustMap(({ category, template }) =>\n          this.userRestApi.getUserTemplateData$(category, template).pipe(\n            tap(choosedTemplate => {\n              if (category !== 'latest') {\n                this.pbStorage.addTemplateToLatestUsed(choosedTemplate);\n              }\n            })\n          )\n        ),\n        catchError((error: Error | HttpErrorResponse) =>\n          this.pbMiddlewaresService.catchError(error).pipe(\n            switchMap(() => {\n              this.userInterfaceService.notify(error.message);\n              return EMPTY;\n            })\n          )\n        ),\n        take(1)\n      )\n      .subscribe((result: IUserTemplate) => {\n        if (result) {\n          this.emailObjectStore.setEmail(new PBEmail(result.templateData));\n        } else {\n          this.userInterfaceService.notify('No template was chosen');\n        }\n      });\n  }\n\n  dropNewStructure(event: IAddStructureEvent) {\n    if (event.previousContainer === event.container) {\n      this.emailObjectStore.changeStructureOrder(event);\n    } else {\n      this.pbMiddlewaresService\n        .addStructure(event)\n        .pipe(\n          tap(newEvent => this.emailObjectStore.addStructure(newEvent)),\n          take(1)\n        )\n        .subscribe();\n    }\n  }\n\n  getStructureStyles(structure: IStructure) {\n    const { border, background, padding, margin, columnsWidth, fullWidth } = structure.options;\n\n    return {\n      // direction,\n      width: fullWidth ? '100%' : `${this.emailObjectStore.Email.general.width.value}px`,\n      backgroundRepeat: background.repeat,\n      backgroundColor: background.color,\n      backgroundSize: createWidthHeight(background.size),\n      backgroundPosition: 'top center',\n      gridTemplateColumns: columnsWidth.map(fr => `${fr}fr`).join(' '),\n      ...createBorder(border),\n      ...createPadding(padding),\n      ...createMargin(margin)\n    };\n  }\n\n  getBackgroundImage(structure: IStructure): SafeStyle {\n    const {\n      background: { url }\n    } = structure.options;\n    return this.sanitizer.bypassSecurityTrustStyle(url && `url(${url})`);\n  }\n}\n"]}
@@ -0,0 +1,30 @@
1
+ /*
2
+ * Copyright (c) 2024 Pobuca.
3
+ * All rights reserved.
4
+ */
5
+ import { Component, Inject } from '@angular/core';
6
+ import { MatDialogRef, MAT_DIALOG_DATA } from '@angular/material/dialog';
7
+ // @dynamic
8
+ export class ConfirmDialogComponent {
9
+ constructor(dialogRef, data) {
10
+ this.dialogRef = dialogRef;
11
+ this.data = data;
12
+ }
13
+ }
14
+ ConfirmDialogComponent.decorators = [
15
+ { type: Component, args: [{
16
+ selector: 'pb-confirm-dialog',
17
+ template: `
18
+ <h2 mat-dialog-title>Are you sure?</h2>
19
+ <mat-dialog-actions fxLayout fxLayoutAlign="space-between center" fxLayoutGap="1rem">
20
+ <button mat-stroked-button mat-dialog-close="0">No</button>
21
+ <button mat-stroked-button color="warn" mat-dialog-close="1">Yes</button>
22
+ </mat-dialog-actions>
23
+ `
24
+ },] }
25
+ ];
26
+ ConfirmDialogComponent.ctorParameters = () => [
27
+ { type: MatDialogRef },
28
+ { type: undefined, decorators: [{ type: Inject, args: [MAT_DIALOG_DATA,] }] }
29
+ ];
30
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZGlhbG9nLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3BiLWVtYWlsLWJ1aWxkZXIvc3JjL2xpYi9jb21wb25lbnRzL2RpYWxvZy5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7OztHQUdHO0FBRUgsT0FBTyxFQUFFLFNBQVMsRUFBRSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDbEQsT0FBTyxFQUFFLFlBQVksRUFBRSxlQUFlLEVBQUUsTUFBTSwwQkFBMEIsQ0FBQztBQUV6RSxXQUFXO0FBV1gsTUFBTSxPQUFPLHNCQUFzQjtJQUNqQyxZQUNTLFNBQStDLEVBQ3RCLElBQXlCO1FBRGxELGNBQVMsR0FBVCxTQUFTLENBQXNDO1FBQ3RCLFNBQUksR0FBSixJQUFJLENBQXFCO0lBQ3ZELENBQUM7OztZQWROLFNBQVMsU0FBQztnQkFDVCxRQUFRLEVBQUUsbUJBQW1CO2dCQUM3QixRQUFRLEVBQUU7Ozs7OztHQU1UO2FBQ0Y7OztZQVpRLFlBQVk7NENBZ0JoQixNQUFNLFNBQUMsZUFBZSIsInNvdXJjZXNDb250ZW50IjpbIi8qXG4gKiBDb3B5cmlnaHQgKGMpIDIwMjQgUG9idWNhLlxuICogQWxsIHJpZ2h0cyByZXNlcnZlZC5cbiAqL1xuXG5pbXBvcnQgeyBDb21wb25lbnQsIEluamVjdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgTWF0RGlhbG9nUmVmLCBNQVRfRElBTE9HX0RBVEEgfSBmcm9tICdAYW5ndWxhci9tYXRlcmlhbC9kaWFsb2cnO1xuXG4vLyBAZHluYW1pY1xuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAncGItY29uZmlybS1kaWFsb2cnLFxuICB0ZW1wbGF0ZTogYFxuICAgIDxoMiBtYXQtZGlhbG9nLXRpdGxlPkFyZSB5b3Ugc3VyZT88L2gyPlxuICAgIDxtYXQtZGlhbG9nLWFjdGlvbnMgZnhMYXlvdXQgZnhMYXlvdXRBbGlnbj1cInNwYWNlLWJldHdlZW4gY2VudGVyXCIgZnhMYXlvdXRHYXA9XCIxcmVtXCI+XG4gICAgICA8YnV0dG9uIG1hdC1zdHJva2VkLWJ1dHRvbiBtYXQtZGlhbG9nLWNsb3NlPVwiMFwiPk5vPC9idXR0b24+XG4gICAgICA8YnV0dG9uIG1hdC1zdHJva2VkLWJ1dHRvbiBjb2xvcj1cIndhcm5cIiBtYXQtZGlhbG9nLWNsb3NlPVwiMVwiPlllczwvYnV0dG9uPlxuICAgIDwvbWF0LWRpYWxvZy1hY3Rpb25zPlxuICBgXG59KVxuZXhwb3J0IGNsYXNzIENvbmZpcm1EaWFsb2dDb21wb25lbnQge1xuICBjb25zdHJ1Y3RvcihcbiAgICBwdWJsaWMgZGlhbG9nUmVmOiBNYXREaWFsb2dSZWY8Q29uZmlybURpYWxvZ0NvbXBvbmVudD4sXG4gICAgQEluamVjdChNQVRfRElBTE9HX0RBVEEpIHB1YmxpYyBkYXRhOiB7IG1lc3NhZ2U6IHN0cmluZyB9XG4gICkgeyB9XG59XG4iXX0=
@@ -0,0 +1,25 @@
1
+ /*
2
+ * Copyright (c) 2024 Pobuca.
3
+ * All rights reserved.
4
+ */
5
+ import { Component, ViewEncapsulation, ChangeDetectionStrategy } from '@angular/core';
6
+ import { PbEmailObjectStoreService } from '../../services/internals/pb-email-object-store/pb-email-object-store.service';
7
+ export class GeneralSettingsComponent {
8
+ constructor(pbEmailObject) {
9
+ this.pbEmailObject = pbEmailObject;
10
+ this.generalOptions$ = this.pbEmailObject.generalEmailOptionsAsObservable$;
11
+ }
12
+ }
13
+ GeneralSettingsComponent.decorators = [
14
+ { type: Component, args: [{
15
+ selector: 'pb-general-settings',
16
+ template: "<!--\n ~ Copyright (c) 2024 Pobuca.\n ~ All rights reserved.\n -->\n\n<ng-container *ngIf=\"generalOptions$ | async as general\">\n <div class=\"mat-expansion-panel-body\" style=\"margin: 24px 0\">\n <mat-form-field appearance=\"outline\" style=\"width: 100%\">\n <mat-label i18n=\"General Settings|Email Name\">Email Name</mat-label>\n <input matInput [(ngModel)]=\"general.name\">\n </mat-form-field>\n <mat-form-field appearance=\"outline\" style=\"width: 100%\">\n <mat-label i18n=\"General Settings|Email Preview Text\">Preview Text</mat-label>\n <textarea matInput [(ngModel)]=\"general.previewText\"></textarea>\n <mat-hint i18n=\"General Settings|Email Preview Text Hint\">\n This text is displayed in the inbox of the recipient.\n </mat-hint>\n </mat-form-field>\n </div>\n\n <mat-accordion>\n <mat-expansion-panel>\n <mat-expansion-panel-header i18n=\"General Settings|Email Background\">\n Background\n </mat-expansion-panel-header>\n <ng-template matExpansionPanelContent>\n <pb-color [options]=\"general.background\" key=\"color\"></pb-color>\n <!-- <pb-image-upload [block]=\"structure.options.background\" key=\"url\" style=\"margin-bottom: 1em\"></pb-image-upload>\n <pb-back-repeat [disabled]=\"!structure.options.background.url\" [model]=\"structure.options.background\">\n </pb-back-repeat>\n <pb-width-height [model]=\"structure.options.background.size\" label=\"Background Size\"></pb-width-height> -->\n </ng-template>\n </mat-expansion-panel>\n\n <mat-expansion-panel>\n <mat-expansion-panel-header i18n=\"General Settings|Email Attributes\">\n Attributes\n </mat-expansion-panel-header>\n <ng-template matExpansionPanelContent>\n <pb-width-height [model]=\"general.width\" label=\"width\"></pb-width-height>\n <pb-direction [model]=\"general\"></pb-direction>\n </ng-template>\n </mat-expansion-panel>\n\n <mat-expansion-panel>\n <mat-expansion-panel-header i18n=\"General Settings|Email Padding\">\n Padding\n </mat-expansion-panel-header>\n <ng-template matExpansionPanelContent>\n <pb-padding [padding]=\"general.padding\"></pb-padding>\n </ng-template>\n </mat-expansion-panel>\n </mat-accordion>\n</ng-container>\n",
17
+ changeDetection: ChangeDetectionStrategy.OnPush,
18
+ encapsulation: ViewEncapsulation.None,
19
+ styles: [""]
20
+ },] }
21
+ ];
22
+ GeneralSettingsComponent.ctorParameters = () => [
23
+ { type: PbEmailObjectStoreService }
24
+ ];
25
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ2VuZXJhbC1zZXR0aW5ncy5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9wYi1lbWFpbC1idWlsZGVyL3NyYy9saWIvY29tcG9uZW50cy9nZW5lcmFsLXNldHRpbmdzL2dlbmVyYWwtc2V0dGluZ3MuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOzs7R0FHRztBQUVILE9BQU8sRUFBRSxTQUFTLEVBQUUsaUJBQWlCLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDdEYsT0FBTyxFQUFFLHlCQUF5QixFQUFFLE1BQU0sOEVBQThFLENBQUM7QUFTekgsTUFBTSxPQUFPLHdCQUF3QjtJQUduQyxZQUFvQixhQUF3QztRQUF4QyxrQkFBYSxHQUFiLGFBQWEsQ0FBMkI7UUFGNUQsb0JBQWUsR0FBRyxJQUFJLENBQUMsYUFBYSxDQUFDLGdDQUFnQyxDQUFDO0lBRVAsQ0FBQzs7O1lBVmpFLFNBQVMsU0FBQztnQkFDVCxRQUFRLEVBQUUscUJBQXFCO2dCQUMvQiw4ekVBQWdEO2dCQUVoRCxlQUFlLEVBQUUsdUJBQXVCLENBQUMsTUFBTTtnQkFDL0MsYUFBYSxFQUFFLGlCQUFpQixDQUFDLElBQUk7O2FBQ3RDOzs7WUFSUSx5QkFBeUIiLCJzb3VyY2VzQ29udGVudCI6WyIvKlxuICogQ29weXJpZ2h0IChjKSAyMDI0IFBvYnVjYS5cbiAqIEFsbCByaWdodHMgcmVzZXJ2ZWQuXG4gKi9cblxuaW1wb3J0IHsgQ29tcG9uZW50LCBWaWV3RW5jYXBzdWxhdGlvbiwgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IFBiRW1haWxPYmplY3RTdG9yZVNlcnZpY2UgfSBmcm9tICcuLi8uLi9zZXJ2aWNlcy9pbnRlcm5hbHMvcGItZW1haWwtb2JqZWN0LXN0b3JlL3BiLWVtYWlsLW9iamVjdC1zdG9yZS5zZXJ2aWNlJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAncGItZ2VuZXJhbC1zZXR0aW5ncycsXG4gIHRlbXBsYXRlVXJsOiAnLi9nZW5lcmFsLXNldHRpbmdzLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vZ2VuZXJhbC1zZXR0aW5ncy5jb21wb25lbnQuY3NzJ10sXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxuICBlbmNhcHN1bGF0aW9uOiBWaWV3RW5jYXBzdWxhdGlvbi5Ob25lXG59KVxuZXhwb3J0IGNsYXNzIEdlbmVyYWxTZXR0aW5nc0NvbXBvbmVudCB7XG4gIGdlbmVyYWxPcHRpb25zJCA9IHRoaXMucGJFbWFpbE9iamVjdC5nZW5lcmFsRW1haWxPcHRpb25zQXNPYnNlcnZhYmxlJDtcblxuICBjb25zdHJ1Y3Rvcihwcml2YXRlIHBiRW1haWxPYmplY3Q6IFBiRW1haWxPYmplY3RTdG9yZVNlcnZpY2UpIHt9XG59XG4iXX0=
@@ -0,0 +1,62 @@
1
+ /*
2
+ * Copyright (c) 2024 Pobuca.
3
+ * All rights reserved.
4
+ */
5
+ import { Component, ViewChild, ElementRef } from '@angular/core';
6
+ import { MatBottomSheetRef } from '@angular/material/bottom-sheet';
7
+ import { take, catchError, switchMap } from 'rxjs/operators';
8
+ import { EMPTY } from 'rxjs';
9
+ import { PbUserMiddlewaresService } from '../../services/user-middleware-service/pb-middlewares.service';
10
+ export class ImportDialogComponent {
11
+ constructor(pbMiddlewares, bottomSheetRef) {
12
+ this.pbMiddlewares = pbMiddlewares;
13
+ this.bottomSheetRef = bottomSheetRef;
14
+ this.importing = false;
15
+ this.fileReader = new FileReader();
16
+ }
17
+ openBrowserModal(event) {
18
+ event.preventDefault();
19
+ this.uploadInput.nativeElement.click();
20
+ }
21
+ startImporting() {
22
+ this.importing = true;
23
+ this.pbMiddlewares
24
+ .importFile(this.uploadInput.nativeElement.files.item(0))
25
+ .pipe(take(1), catchError(error => this.pbMiddlewares.catchError(error).pipe(switchMap(() => {
26
+ this.bottomSheetRef.dismiss(error);
27
+ return EMPTY;
28
+ }))))
29
+ .subscribe(file => {
30
+ this.fileReader.readAsText(file, 'utf-8');
31
+ });
32
+ }
33
+ ngOnInit() {
34
+ this.fileReader.addEventListener('loadend', () => {
35
+ this.importing = false;
36
+ try {
37
+ const email = JSON.parse(this.fileReader.result);
38
+ this.bottomSheetRef.dismiss(email);
39
+ }
40
+ catch (error) {
41
+ this.bottomSheetRef.dismiss(null);
42
+ throw new Error(error);
43
+ }
44
+ });
45
+ }
46
+ ngOnDestroy() { }
47
+ }
48
+ ImportDialogComponent.decorators = [
49
+ { type: Component, args: [{
50
+ selector: 'pb-import-dialog',
51
+ template: "<!--\n ~ Copyright (c) 2024 Pobuca.\n ~ All rights reserved.\n -->\n\n<mat-nav-list>\n <mat-list-item (click)=\"openBrowserModal($event)\">\n <div *ngIf=\"!importing\">\n <span mat-line i18n=\"import|Import JSON file\">Import JSON file</span>\n </div>\n <ng-container *ngIf=\"importing\">\n <span mat-line i18n=\"import|Importing in progress\">Importing in progress ...</span>\n <!-- <span mat-line>{{ imageInfo }}</span> -->\n </ng-container>\n </mat-list-item>\n <mat-progress-bar *ngIf=\"importing\" mode=\"buffer\" value=\"100\"></mat-progress-bar>\n</mat-nav-list>\n<input type=\"file\" accept=\"application/json\" fxHide #uploadInput (change)=\"startImporting()\" />\n",
52
+ styles: ["/*!\n * Copyright (c) 2024 Pobuca.\n * All rights reserved.\n */"]
53
+ },] }
54
+ ];
55
+ ImportDialogComponent.ctorParameters = () => [
56
+ { type: PbUserMiddlewaresService },
57
+ { type: MatBottomSheetRef }
58
+ ];
59
+ ImportDialogComponent.propDecorators = {
60
+ uploadInput: [{ type: ViewChild, args: ['uploadInput', { read: ElementRef, static: true },] }]
61
+ };
62
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW1wb3J0LWRpYWxvZy5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9wYi1lbWFpbC1idWlsZGVyL3NyYy9saWIvY29tcG9uZW50cy9pbXBvcnQtZGlhbG9nL2ltcG9ydC1kaWFsb2cuY29tcG9uZW50LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOzs7R0FHRztBQUVILE9BQU8sRUFBRSxTQUFTLEVBQVUsU0FBUyxFQUFFLFVBQVUsRUFBYSxNQUFNLGVBQWUsQ0FBQztBQUNwRixPQUFPLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxnQ0FBZ0MsQ0FBQztBQUNuRSxPQUFPLEVBQUUsSUFBSSxFQUFFLFVBQVUsRUFBRSxTQUFTLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUM3RCxPQUFPLEVBQUUsS0FBSyxFQUFFLE1BQU0sTUFBTSxDQUFDO0FBRTdCLE9BQU8sRUFBRSx3QkFBd0IsRUFBRSxNQUFNLCtEQUErRCxDQUFDO0FBUXpHLE1BQU0sT0FBTyxxQkFBcUI7SUFPaEMsWUFBb0IsYUFBdUMsRUFBVSxjQUFpRTtRQUFsSCxrQkFBYSxHQUFiLGFBQWEsQ0FBMEI7UUFBVSxtQkFBYyxHQUFkLGNBQWMsQ0FBbUQ7UUFIL0gsY0FBUyxHQUFHLEtBQUssQ0FBQztRQUNqQixlQUFVLEdBQUcsSUFBSSxVQUFVLEVBQUUsQ0FBQztJQUVtRyxDQUFDO0lBRTFJLGdCQUFnQixDQUFDLEtBQWlCO1FBQ2hDLEtBQUssQ0FBQyxjQUFjLEVBQUUsQ0FBQztRQUN2QixJQUFJLENBQUMsV0FBVyxDQUFDLGFBQWEsQ0FBQyxLQUFLLEVBQUUsQ0FBQztJQUN6QyxDQUFDO0lBRUQsY0FBYztRQUNaLElBQUksQ0FBQyxTQUFTLEdBQUcsSUFBSSxDQUFDO1FBRXRCLElBQUksQ0FBQyxhQUFhO2FBQ2YsVUFBVSxDQUFDLElBQUksQ0FBQyxXQUFXLENBQUMsYUFBYSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUM7YUFDeEQsSUFBSSxDQUNILElBQUksQ0FBQyxDQUFDLENBQUMsRUFDUCxVQUFVLENBQUMsS0FBSyxDQUFDLEVBQUUsQ0FDakIsSUFBSSxDQUFDLGFBQWEsQ0FBQyxVQUFVLENBQUMsS0FBSyxDQUFDLENBQUMsSUFBSSxDQUN2QyxTQUFTLENBQUMsR0FBRyxFQUFFO1lBQ2IsSUFBSSxDQUFDLGNBQWMsQ0FBQyxPQUFPLENBQUMsS0FBSyxDQUFDLENBQUM7WUFDbkMsT0FBTyxLQUFLLENBQUM7UUFDZixDQUFDLENBQUMsQ0FDSCxDQUNGLENBQ0Y7YUFDQSxTQUFTLENBQUMsSUFBSSxDQUFDLEVBQUU7WUFDaEIsSUFBSSxDQUFDLFVBQVUsQ0FBQyxVQUFVLENBQUMsSUFBSSxFQUFFLE9BQU8sQ0FBQyxDQUFDO1FBQzVDLENBQUMsQ0FBQyxDQUFDO0lBQ1AsQ0FBQztJQUVELFFBQVE7UUFDTixJQUFJLENBQUMsVUFBVSxDQUFDLGdCQUFnQixDQUFDLFNBQVMsRUFBRSxHQUFHLEVBQUU7WUFDL0MsSUFBSSxDQUFDLFNBQVMsR0FBRyxLQUFLLENBQUM7WUFDdkIsSUFBSTtnQkFDRixNQUFNLEtBQUssR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxVQUFVLENBQUMsTUFBZ0IsQ0FBQyxDQUFDO2dCQUMzRCxJQUFJLENBQUMsY0FBYyxDQUFDLE9BQU8sQ0FBQyxLQUFLLENBQUMsQ0FBQzthQUNwQztZQUFDLE9BQU8sS0FBSyxFQUFFO2dCQUNkLElBQUksQ0FBQyxjQUFjLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxDQUFDO2dCQUNsQyxNQUFNLElBQUksS0FBSyxDQUFDLEtBQUssQ0FBQyxDQUFDO2FBQ3hCO1FBQ0gsQ0FBQyxDQUFDLENBQUM7SUFDTCxDQUFDO0lBRUQsV0FBVyxLQUFJLENBQUM7OztZQXJEakIsU0FBUyxTQUFDO2dCQUNULFFBQVEsRUFBRSxrQkFBa0I7Z0JBQzVCLHV2QkFBNkM7O2FBRTlDOzs7WUFQUSx3QkFBd0I7WUFKeEIsaUJBQWlCOzs7MEJBYXZCLFNBQVMsU0FBQyxhQUFhLEVBQUUsRUFBRSxJQUFJLEVBQUUsVUFBVSxFQUFFLE1BQU0sRUFBRSxJQUFJLEVBQUUiLCJzb3VyY2VzQ29udGVudCI6WyIvKlxuICogQ29weXJpZ2h0IChjKSAyMDI0IFBvYnVjYS5cbiAqIEFsbCByaWdodHMgcmVzZXJ2ZWQuXG4gKi9cblxuaW1wb3J0IHsgQ29tcG9uZW50LCBPbkluaXQsIFZpZXdDaGlsZCwgRWxlbWVudFJlZiwgT25EZXN0cm95IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBNYXRCb3R0b21TaGVldFJlZiB9IGZyb20gJ0Bhbmd1bGFyL21hdGVyaWFsL2JvdHRvbS1zaGVldCc7XG5pbXBvcnQgeyB0YWtlLCBjYXRjaEVycm9yLCBzd2l0Y2hNYXAgfSBmcm9tICdyeGpzL29wZXJhdG9ycyc7XG5pbXBvcnQgeyBFTVBUWSB9IGZyb20gJ3J4anMnO1xuXG5pbXBvcnQgeyBQYlVzZXJNaWRkbGV3YXJlc1NlcnZpY2UgfSBmcm9tICcuLi8uLi9zZXJ2aWNlcy91c2VyLW1pZGRsZXdhcmUtc2VydmljZS9wYi1taWRkbGV3YXJlcy5zZXJ2aWNlJztcbmltcG9ydCB7IFBCRW1haWwgfSBmcm9tICcuLi8uLi9jbGFzc2VzL0RlZmF1bHRFbWFpbCc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ3BiLWltcG9ydC1kaWFsb2cnLFxuICB0ZW1wbGF0ZVVybDogJy4vaW1wb3J0LWRpYWxvZy5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsczogWycuL2ltcG9ydC1kaWFsb2cuY29tcG9uZW50LnNjc3MnXVxufSlcbmV4cG9ydCBjbGFzcyBJbXBvcnREaWFsb2dDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQsIE9uRGVzdHJveSB7XG4gIEBWaWV3Q2hpbGQoJ3VwbG9hZElucHV0JywgeyByZWFkOiBFbGVtZW50UmVmLCBzdGF0aWM6IHRydWUgfSlcbiAgcHJpdmF0ZSB1cGxvYWRJbnB1dDogRWxlbWVudFJlZjxIVE1MSW5wdXRFbGVtZW50PjtcblxuICBwdWJsaWMgaW1wb3J0aW5nID0gZmFsc2U7XG4gIHByaXZhdGUgZmlsZVJlYWRlciA9IG5ldyBGaWxlUmVhZGVyKCk7XG5cbiAgY29uc3RydWN0b3IocHJpdmF0ZSBwYk1pZGRsZXdhcmVzOiBQYlVzZXJNaWRkbGV3YXJlc1NlcnZpY2UsIHByaXZhdGUgYm90dG9tU2hlZXRSZWY6IE1hdEJvdHRvbVNoZWV0UmVmPEltcG9ydERpYWxvZ0NvbXBvbmVudCwgUEJFbWFpbD4pIHt9XG5cbiAgb3BlbkJyb3dzZXJNb2RhbChldmVudDogTW91c2VFdmVudCkge1xuICAgIGV2ZW50LnByZXZlbnREZWZhdWx0KCk7XG4gICAgdGhpcy51cGxvYWRJbnB1dC5uYXRpdmVFbGVtZW50LmNsaWNrKCk7XG4gIH1cblxuICBzdGFydEltcG9ydGluZygpIHtcbiAgICB0aGlzLmltcG9ydGluZyA9IHRydWU7XG5cbiAgICB0aGlzLnBiTWlkZGxld2FyZXNcbiAgICAgIC5pbXBvcnRGaWxlKHRoaXMudXBsb2FkSW5wdXQubmF0aXZlRWxlbWVudC5maWxlcy5pdGVtKDApKVxuICAgICAgLnBpcGUoXG4gICAgICAgIHRha2UoMSksXG4gICAgICAgIGNhdGNoRXJyb3IoZXJyb3IgPT5cbiAgICAgICAgICB0aGlzLnBiTWlkZGxld2FyZXMuY2F0Y2hFcnJvcihlcnJvcikucGlwZShcbiAgICAgICAgICAgIHN3aXRjaE1hcCgoKSA9PiB7XG4gICAgICAgICAgICAgIHRoaXMuYm90dG9tU2hlZXRSZWYuZGlzbWlzcyhlcnJvcik7XG4gICAgICAgICAgICAgIHJldHVybiBFTVBUWTtcbiAgICAgICAgICAgIH0pXG4gICAgICAgICAgKVxuICAgICAgICApXG4gICAgICApXG4gICAgICAuc3Vic2NyaWJlKGZpbGUgPT4ge1xuICAgICAgICB0aGlzLmZpbGVSZWFkZXIucmVhZEFzVGV4dChmaWxlLCAndXRmLTgnKTtcbiAgICAgIH0pO1xuICB9XG5cbiAgbmdPbkluaXQoKSB7XG4gICAgdGhpcy5maWxlUmVhZGVyLmFkZEV2ZW50TGlzdGVuZXIoJ2xvYWRlbmQnLCAoKSA9PiB7XG4gICAgICB0aGlzLmltcG9ydGluZyA9IGZhbHNlO1xuICAgICAgdHJ5IHtcbiAgICAgICAgY29uc3QgZW1haWwgPSBKU09OLnBhcnNlKHRoaXMuZmlsZVJlYWRlci5yZXN1bHQgYXMgc3RyaW5nKTtcbiAgICAgICAgdGhpcy5ib3R0b21TaGVldFJlZi5kaXNtaXNzKGVtYWlsKTtcbiAgICAgIH0gY2F0Y2ggKGVycm9yKSB7XG4gICAgICAgIHRoaXMuYm90dG9tU2hlZXRSZWYuZGlzbWlzcyhudWxsKTtcbiAgICAgICAgdGhyb3cgbmV3IEVycm9yKGVycm9yKTtcbiAgICAgIH1cbiAgICB9KTtcbiAgfVxuXG4gIG5nT25EZXN0cm95KCkge31cbn1cbiJdfQ==
@@ -0,0 +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==
@@ -0,0 +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"]}