@pobuca/email-builder 1.0.1 → 1.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +1 -1
- package/bundles/pobuca-email-builder.umd.js +4464 -4414
- package/bundles/pobuca-email-builder.umd.js.map +1 -1
- package/bundles/pobuca-email-builder.umd.min.js +1 -1
- package/bundles/pobuca-email-builder.umd.min.js.map +1 -1
- package/esm2015/lib/classes/DefaultEmail.js +54 -53
- package/esm2015/lib/classes/Elements.js +229 -229
- package/esm2015/lib/classes/Structure.js +89 -89
- package/esm2015/lib/components/block/block.component.js +89 -89
- package/esm2015/lib/components/block-settings/block-settings.component.js +53 -53
- package/esm2015/lib/components/builder-container/builder-container.component.js +114 -114
- package/esm2015/lib/components/dialog.component.js +30 -30
- package/esm2015/lib/components/general-settings/general-settings.component.js +25 -25
- package/esm2015/lib/components/import-dialog/import-dialog.component.js +62 -62
- package/esm2015/lib/components/preview.component.js +89 -89
- package/esm2015/lib/components/structure/structure.component.js +163 -163
- package/esm2015/lib/components/structure-settings/structure-settings.component.js +31 -31
- package/esm2015/lib/components/template-list-dialog/template-list-dialog.component.js +45 -45
- package/esm2015/lib/directives/dynamic-component.directive.js +46 -46
- package/esm2015/lib/elements/abstract-block.js +23 -23
- package/esm2015/lib/elements/button/button.component.js +29 -29
- package/esm2015/lib/elements/divider/divider.component.js +30 -30
- package/esm2015/lib/elements/image/image.component.js +54 -54
- package/esm2015/lib/elements/social/social.component.js +42 -42
- package/esm2015/lib/elements/spacer/spacer.component.js +30 -30
- package/esm2015/lib/elements/text-element/text-element.component.js +80 -80
- package/esm2015/lib/groups/align.js +79 -79
- package/esm2015/lib/groups/back-repeat.js +55 -55
- package/esm2015/lib/groups/border.js +102 -102
- package/esm2015/lib/groups/color.js +139 -139
- package/esm2015/lib/groups/direction.js +63 -63
- package/esm2015/lib/groups/font-styles.js +127 -112
- package/esm2015/lib/groups/gaps.js +45 -45
- package/esm2015/lib/groups/line-height.js +68 -68
- package/esm2015/lib/groups/link.js +67 -67
- package/esm2015/lib/groups/margin.js +45 -45
- package/esm2015/lib/groups/padding.js +53 -53
- package/esm2015/lib/groups/upload-image.js +112 -112
- package/esm2015/lib/groups/width-height.js +94 -94
- package/esm2015/lib/interceptors/pb-interceptor.interceptor.js +51 -51
- package/esm2015/lib/interfaces/interfaces.js +13 -13
- package/esm2015/lib/pb-email-builder.component.js +258 -246
- package/esm2015/lib/pb-email-builder.module.js +291 -291
- package/esm2015/lib/pb-email-builder.service.js +134 -134
- package/esm2015/lib/pipes/slugify.pipe.js +39 -39
- package/esm2015/lib/services/internals/pb-email-object-store/pb-email-object-store.service.js +175 -165
- package/esm2015/lib/services/internals/user-interfaces/user-interface.service.js +122 -122
- package/esm2015/lib/services/pb-storage/FreeUsersStorage.class.js +11 -11
- package/esm2015/lib/services/pb-storage/index.js +7 -7
- package/esm2015/lib/services/pb-storage/pb-storage.service.js +79 -79
- package/esm2015/lib/services/user-image-uploader-service/free-users-image-uploader.service.js +26 -26
- package/esm2015/lib/services/user-image-uploader-service/index.js +8 -8
- package/esm2015/lib/services/user-image-uploader-service/paid-users-image-uploader.service.js +30 -30
- package/esm2015/lib/services/user-image-uploader-service/upload-bottom-sheet-dialog/upload-bottom-sheet-dialog.component.js +112 -112
- package/esm2015/lib/services/user-image-uploader-service/upload-image-gallery/upload-image-gallery.component.js +91 -91
- package/esm2015/lib/services/user-image-uploader-service/user-image-uploader.service.js +26 -26
- package/esm2015/lib/services/user-middleware-service/FreeUsersMiddleware.js +31 -31
- package/esm2015/lib/services/user-middleware-service/PaidUsersMiddleware.js +12 -12
- package/esm2015/lib/services/user-middleware-service/index.js +8 -8
- package/esm2015/lib/services/user-middleware-service/pb-middlewares.service.js +195 -195
- package/esm2015/lib/services/user-rest-api-service/free-users-rest-api.service.js +16 -16
- package/esm2015/lib/services/user-rest-api-service/index.js +7 -7
- package/esm2015/lib/services/user-rest-api-service/user-rest-api.service.js +116 -116
- package/esm2015/lib/tokens/private-tokens.js +17 -17
- package/esm2015/lib/tokens/tokens.js +159 -159
- package/esm2015/lib/utils.js +147 -147
- package/esm2015/pobuca-email-builder.js +42 -42
- package/esm2015/public_api.js +26 -26
- package/fesm2015/pobuca-email-builder.js +4206 -4168
- package/fesm2015/pobuca-email-builder.js.map +1 -1
- package/lib/classes/DefaultEmail.d.ts +10 -9
- package/lib/classes/Elements.d.ts +62 -62
- package/lib/classes/Structure.d.ts +11 -11
- package/lib/components/block/block.component.d.ts +25 -25
- package/lib/components/block-settings/block-settings.component.d.ts +18 -18
- package/lib/components/builder-container/builder-container.component.d.ts +36 -36
- package/lib/components/dialog.component.d.ts +10 -10
- package/lib/components/general-settings/general-settings.component.d.ts +6 -6
- package/lib/components/import-dialog/import-dialog.component.d.ts +16 -16
- package/lib/components/preview.component.d.ts +18 -18
- package/lib/components/structure/structure.component.d.ts +43 -43
- package/lib/components/structure-settings/structure-settings.component.d.ts +9 -9
- package/lib/components/template-list-dialog/template-list-dialog.component.d.ts +15 -15
- package/lib/directives/dynamic-component.directive.d.ts +13 -13
- package/lib/elements/abstract-block.d.ts +8 -8
- package/lib/elements/button/button.component.d.ts +18 -18
- package/lib/elements/divider/divider.component.d.ts +10 -10
- package/lib/elements/image/image.component.d.ts +19 -19
- package/lib/elements/social/social.component.d.ts +21 -21
- package/lib/elements/spacer/spacer.component.d.ts +5 -5
- package/lib/elements/text-element/text-element.component.d.ts +52 -52
- package/lib/groups/align.d.ts +17 -17
- package/lib/groups/back-repeat.d.ts +8 -8
- package/lib/groups/border.d.ts +13 -13
- package/lib/groups/color.d.ts +26 -26
- package/lib/groups/direction.d.ts +13 -13
- package/lib/groups/font-styles.d.ts +21 -17
- package/lib/groups/gaps.d.ts +7 -7
- package/lib/groups/line-height.d.ts +12 -12
- package/lib/groups/link.d.ts +11 -11
- package/lib/groups/margin.d.ts +8 -8
- package/lib/groups/padding.d.ts +8 -8
- package/lib/groups/upload-image.d.ts +19 -19
- package/lib/groups/width-height.d.ts +19 -19
- package/lib/interceptors/pb-interceptor.interceptor.d.ts +10 -10
- package/lib/interfaces/interfaces.d.ts +430 -422
- package/lib/pb-email-builder.component.d.ts +67 -67
- package/lib/pb-email-builder.module.d.ts +51 -51
- package/lib/pb-email-builder.service.d.ts +83 -83
- package/lib/pipes/slugify.pipe.d.ts +9 -9
- package/lib/services/internals/pb-email-object-store/pb-email-object-store.service.d.ts +50 -50
- package/lib/services/internals/user-interfaces/user-interface.service.d.ts +46 -46
- package/lib/services/pb-storage/FreeUsersStorage.class.d.ts +6 -6
- package/lib/services/pb-storage/index.d.ts +2 -2
- package/lib/services/pb-storage/pb-storage.service.d.ts +54 -54
- package/lib/services/user-image-uploader-service/free-users-image-uploader.service.d.ts +12 -12
- package/lib/services/user-image-uploader-service/index.d.ts +3 -3
- package/lib/services/user-image-uploader-service/paid-users-image-uploader.service.d.ts +14 -14
- package/lib/services/user-image-uploader-service/upload-bottom-sheet-dialog/upload-bottom-sheet-dialog.component.d.ts +28 -28
- package/lib/services/user-image-uploader-service/upload-image-gallery/upload-image-gallery.component.d.ts +27 -27
- package/lib/services/user-image-uploader-service/user-image-uploader.service.d.ts +26 -26
- package/lib/services/user-middleware-service/FreeUsersMiddleware.d.ts +15 -15
- package/lib/services/user-middleware-service/PaidUsersMiddleware.d.ts +7 -7
- package/lib/services/user-middleware-service/index.d.ts +3 -3
- package/lib/services/user-middleware-service/pb-middlewares.service.d.ts +190 -190
- package/lib/services/user-rest-api-service/free-users-rest-api.service.d.ts +10 -10
- package/lib/services/user-rest-api-service/index.d.ts +2 -2
- package/lib/services/user-rest-api-service/user-rest-api.service.d.ts +82 -82
- package/lib/tokens/private-tokens.d.ts +5 -5
- package/lib/tokens/tokens.d.ts +70 -70
- package/lib/utils.d.ts +88 -88
- package/package.json +8 -3
- package/pobuca-email-builder.d.ts +42 -42
- package/pobuca-email-builder.metadata.json +1 -1
- package/public_api.d.ts +16 -16
|
@@ -1,134 +1,134 @@
|
|
|
1
|
-
/*
|
|
2
|
-
* Copyright (c) 2024 Pobuca.
|
|
3
|
-
* All rights reserved.
|
|
4
|
-
*/
|
|
5
|
-
import { Injectable, Inject } from '@angular/core';
|
|
6
|
-
import { EMPTY } from 'rxjs';
|
|
7
|
-
import { catchError, switchMap, shareReplay, tap, finalize } from 'rxjs/operators';
|
|
8
|
-
import { PB_CONFIG, PB_DEFAULT_CONFIG } from './tokens/tokens';
|
|
9
|
-
import { PbEmailObjectStoreService } from './services/internals/pb-email-object-store/pb-email-object-store.service';
|
|
10
|
-
import { PbUserMiddlewaresService } from './services/user-middleware-service/pb-middlewares.service';
|
|
11
|
-
import { PbUserInterfaceService } from './services/internals/user-interfaces/user-interface.service';
|
|
12
|
-
/**
|
|
13
|
-
* @deprecated Soon it will be removed
|
|
14
|
-
* @internal
|
|
15
|
-
*/
|
|
16
|
-
export class PbEmailBuilderService {
|
|
17
|
-
constructor(config,
|
|
18
|
-
// @Inject(PB_GOOGLE_FONTS) private googleFonts: string[],
|
|
19
|
-
emailObjectStore, pbMiddleWares, pbUserInterface // private _http: HttpClient,
|
|
20
|
-
) {
|
|
21
|
-
this.config = config;
|
|
22
|
-
this.emailObjectStore = emailObjectStore;
|
|
23
|
-
this.pbMiddleWares = pbMiddleWares;
|
|
24
|
-
this.pbUserInterface = pbUserInterface;
|
|
25
|
-
// private _template = new BehaviorSubject<string>('');
|
|
26
|
-
// private _mjml = new BehaviorSubject<string>('');
|
|
27
|
-
// private readonly _onSave$ = new Subject();
|
|
28
|
-
/**
|
|
29
|
-
* @deprecated Please use the new service "UserRestApiService" instead
|
|
30
|
-
*/
|
|
31
|
-
this.modules = new Set();
|
|
32
|
-
/**
|
|
33
|
-
* @deprecated Please use the new service "UserRestApiService" instead
|
|
34
|
-
*/
|
|
35
|
-
this.customTemplates = new Set();
|
|
36
|
-
/**
|
|
37
|
-
* @deprecated Please use the new service "UserRestApiService" instead
|
|
38
|
-
*/
|
|
39
|
-
this._mergeTags = new Set();
|
|
40
|
-
this.onTemplateCreated$ = this.emailObjectStore.onTemplateCreated$.pipe(shareReplay());
|
|
41
|
-
/**
|
|
42
|
-
* @deprecated Use onTemplateCreated$ instead
|
|
43
|
-
*/
|
|
44
|
-
this.onSave$ = this.onTemplateCreated$;
|
|
45
|
-
/**
|
|
46
|
-
* @deprecated Use isLoading$ instead
|
|
47
|
-
*/
|
|
48
|
-
this.isLoading = this.pbUserInterface.activeMatProgress$.asObservable();
|
|
49
|
-
this.isLoading$ = this.pbUserInterface.activeMatProgress$.asObservable();
|
|
50
|
-
this.config = Object.assign(Object.assign({}, PB_DEFAULT_CONFIG), this.config);
|
|
51
|
-
}
|
|
52
|
-
/**
|
|
53
|
-
* Save current Email Template
|
|
54
|
-
*/
|
|
55
|
-
createHTMLTemplate$() {
|
|
56
|
-
this.pbUserInterface.activeMatProgress$.next(true);
|
|
57
|
-
return this.emailObjectStore.createHTMLTemplate$().pipe(tap(() => this.pbUserInterface.activeMatProgress$.next(false)), catchError((error) => this.pbMiddleWares.catchError(error).pipe(switchMap(() => {
|
|
58
|
-
this.pbUserInterface.notify(error.message);
|
|
59
|
-
this.pbUserInterface.activeMatProgress$.next(false);
|
|
60
|
-
return EMPTY;
|
|
61
|
-
}))), finalize(() => this.pbUserInterface.activeMatProgress$.next(false)));
|
|
62
|
-
}
|
|
63
|
-
/**
|
|
64
|
-
* @deprecated Please use ngb.createHTMLTemplate$() instead
|
|
65
|
-
*/
|
|
66
|
-
saveEmail() {
|
|
67
|
-
return this.createHTMLTemplate$();
|
|
68
|
-
}
|
|
69
|
-
/**
|
|
70
|
-
* Get Email as object
|
|
71
|
-
*/
|
|
72
|
-
get Email() {
|
|
73
|
-
return this.emailObjectStore.Email;
|
|
74
|
-
}
|
|
75
|
-
/**
|
|
76
|
-
* Set Email saved from database or created with new PBEmail()
|
|
77
|
-
*/
|
|
78
|
-
set Email(newEmail) {
|
|
79
|
-
this.emailObjectStore.setEmail(newEmail);
|
|
80
|
-
}
|
|
81
|
-
/**
|
|
82
|
-
* @deprecated Use getTemplateAsObservable$() instead
|
|
83
|
-
*/
|
|
84
|
-
get Template() {
|
|
85
|
-
return null;
|
|
86
|
-
}
|
|
87
|
-
/**
|
|
88
|
-
* Set HTML output
|
|
89
|
-
*/
|
|
90
|
-
// set Template(template: string) {
|
|
91
|
-
// this._template.next(template);
|
|
92
|
-
// }
|
|
93
|
-
/**
|
|
94
|
-
* @deprecated Use getMjmlAsObservable$() instead
|
|
95
|
-
*/
|
|
96
|
-
get Mjml() {
|
|
97
|
-
return null;
|
|
98
|
-
}
|
|
99
|
-
/**
|
|
100
|
-
* Listen Email changes
|
|
101
|
-
*/
|
|
102
|
-
getEmailAsObservable$() {
|
|
103
|
-
return this.emailObjectStore.emailAsObservable$;
|
|
104
|
-
}
|
|
105
|
-
/**
|
|
106
|
-
* Listen Template changes
|
|
107
|
-
*/
|
|
108
|
-
getTemplateAsObservable$() {
|
|
109
|
-
return this.emailObjectStore.templateAsObservable$;
|
|
110
|
-
}
|
|
111
|
-
/**
|
|
112
|
-
* Listen MJML changes
|
|
113
|
-
*/
|
|
114
|
-
getMjmlAsObservable$() {
|
|
115
|
-
return this.emailObjectStore.mjmlAsObservable$;
|
|
116
|
-
}
|
|
117
|
-
/**
|
|
118
|
-
* Listen Email and Template changes
|
|
119
|
-
* @deprecated Use onTemplateCreated$ instead
|
|
120
|
-
*/
|
|
121
|
-
onChanges$() {
|
|
122
|
-
return this.onTemplateCreated$;
|
|
123
|
-
}
|
|
124
|
-
}
|
|
125
|
-
PbEmailBuilderService.decorators = [
|
|
126
|
-
{ type: Injectable }
|
|
127
|
-
];
|
|
128
|
-
PbEmailBuilderService.ctorParameters = () => [
|
|
129
|
-
{ type: undefined, decorators: [{ type: Inject, args: [PB_CONFIG,] }] },
|
|
130
|
-
{ type: PbEmailObjectStoreService },
|
|
131
|
-
{ type: PbUserMiddlewaresService },
|
|
132
|
-
{ type: PbUserInterfaceService }
|
|
133
|
-
];
|
|
134
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pb-email-builder.service.js","sourceRoot":"","sources":["../../../../projects/pb-email-builder/src/lib/pb-email-builder.service.ts"],"names":[],"mappings":"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","sourcesContent":["/*\n * Copyright (c) 2024 Pobuca.\n * All rights reserved.\n */\n\nimport { Injectable, Inject } from '@angular/core';\nimport { HttpErrorResponse } from '@angular/common/http';\nimport { Observable, EMPTY } from 'rxjs';\nimport { catchError, switchMap, shareReplay, tap, finalize } from 'rxjs/operators';\n\nimport { IForRootConf, IUserModule, IUserTemplate } from './interfaces/interfaces';\nimport { PBEmail } from './classes/DefaultEmail';\n\nimport { PB_CONFIG, PB_DEFAULT_CONFIG } from './tokens/tokens';\nimport { PbEmailObjectStoreService } from './services/internals/pb-email-object-store/pb-email-object-store.service';\nimport { PbUserMiddlewaresService } from './services/user-middleware-service/pb-middlewares.service';\nimport { PbUserInterfaceService } from './services/internals/user-interfaces/user-interface.service';\n\n/**\n * @deprecated Soon it will be removed\n * @internal\n */\n@Injectable()\nexport class PbEmailBuilderService {\n  // private _template = new BehaviorSubject<string>('');\n  // private _mjml = new BehaviorSubject<string>('');\n  // private readonly _onSave$ = new Subject();\n\n  /**\n   * @deprecated Please use the new service \"UserRestApiService\" instead\n   */\n  public modules = new Set<IUserModule>();\n  /**\n   * @deprecated Please use the new service \"UserRestApiService\" instead\n   */\n  public readonly customTemplates = new Set<IUserTemplate>();\n  /**\n   * @deprecated Please use the new service \"UserRestApiService\" instead\n   */\n  private _mergeTags = new Set<string>();\n\n  public readonly onTemplateCreated$ = this.emailObjectStore.onTemplateCreated$.pipe(shareReplay());\n\n  /**\n   * @deprecated Use onTemplateCreated$ instead\n   */\n  public readonly onSave$ = this.onTemplateCreated$;\n\n  /**\n   * @deprecated Use isLoading$ instead\n   */\n  public readonly isLoading = this.pbUserInterface.activeMatProgress$.asObservable();\n  public readonly isLoading$ = this.pbUserInterface.activeMatProgress$.asObservable();\n\n  constructor(\n    @Inject(PB_CONFIG) public config: IForRootConf,\n    // @Inject(PB_GOOGLE_FONTS) private googleFonts: string[],\n    private emailObjectStore: PbEmailObjectStoreService,\n    private pbMiddleWares: PbUserMiddlewaresService,\n    private pbUserInterface: PbUserInterfaceService // private _http: HttpClient,\n  ) {\n    this.config = { ...PB_DEFAULT_CONFIG, ...this.config };\n  }\n\n  /**\n   * Save current Email Template\n   */\n  createHTMLTemplate$() {\n    this.pbUserInterface.activeMatProgress$.next(true);\n    return this.emailObjectStore.createHTMLTemplate$().pipe(\n      tap(() => this.pbUserInterface.activeMatProgress$.next(false)),\n      catchError((error: HttpErrorResponse) =>\n        this.pbMiddleWares.catchError(error).pipe(\n          switchMap(() => {\n            this.pbUserInterface.notify(error.message);\n            this.pbUserInterface.activeMatProgress$.next(false);\n            return EMPTY;\n          })\n        )\n      ),\n      finalize(() => this.pbUserInterface.activeMatProgress$.next(false))\n    );\n  }\n\n  /**\n   *  @deprecated Please use ngb.createHTMLTemplate$() instead\n   */\n  saveEmail() {\n    return this.createHTMLTemplate$();\n  }\n\n  /**\n   * Get Email as object\n   */\n  get Email() {\n    return this.emailObjectStore.Email;\n  }\n\n  /**\n   * Set Email saved from database or created with new PBEmail()\n   */\n  set Email(newEmail: PBEmail) {\n    this.emailObjectStore.setEmail(newEmail);\n  }\n\n  /**\n   * @deprecated Use getTemplateAsObservable$() instead\n   */\n  get Template() {\n    return null;\n  }\n  /**\n   * Set HTML output\n   */\n  // set Template(template: string) {\n  //   this._template.next(template);\n  // }\n\n  /**\n   * @deprecated Use getMjmlAsObservable$() instead\n   */\n  get Mjml() {\n    return null;\n  }\n\n  /**\n   * Listen Email changes\n   */\n  getEmailAsObservable$(): Observable<PBEmail> {\n    return this.emailObjectStore.emailAsObservable$;\n  }\n\n  /**\n   * Listen Template changes\n   */\n  getTemplateAsObservable$(): Observable<string> {\n    return this.emailObjectStore.templateAsObservable$;\n  }\n\n  /**\n   * Listen MJML changes\n   */\n  getMjmlAsObservable$() {\n    return this.emailObjectStore.mjmlAsObservable$;\n  }\n\n  /**\n   * Listen Email and Template changes\n   * @deprecated Use onTemplateCreated$ instead\n   */\n  onChanges$(): Observable<[PBEmail, string, string]> {\n    return this.onTemplateCreated$;\n  }\n\n  /**\n   * Get Set of Structures from aside\n   */\n  // getSideStructures(): Set<IStructure> {\n  //   return this._structures;\n  // }\n\n  /**\n   * Get Set of Blocks from aside\n   */\n  // getSideBlocks(): Set<TBlocks> {\n  //   return this._blocks;\n  // }\n\n  /**\n   * Get a Set of fonts family\n   */\n  // get Fonts(): IFontFamily {\n  //   return this._fontFamily;\n  // }\n  // set Fonts(fonts: IFontFamily) {\n  //   this._fontFamily = fonts;\n  // }\n\n  // get FallbackFonts(): IFontFamily {\n  //   return this._fallbackFamily;\n  // }\n  // set FallbackFonts(fonts: IFontFamily) {\n  //   this._fallbackFamily = fonts;\n  // }\n\n  /**\n   * @deprecated Please use the new service \"UserRestApiService\" instead\n   */\n  // get MergeTags(): Set<string> {\n  //   return this._mergeTags;\n  // }\n\n  // set MergeTags(tags: Set<string>) {\n  //   this._mergeTags = tags;\n  // }\n}\n"]}
|
|
1
|
+
/*
|
|
2
|
+
* Copyright (c) 2024 Pobuca.
|
|
3
|
+
* All rights reserved.
|
|
4
|
+
*/
|
|
5
|
+
import { Injectable, Inject } from '@angular/core';
|
|
6
|
+
import { EMPTY } from 'rxjs';
|
|
7
|
+
import { catchError, switchMap, shareReplay, tap, finalize } from 'rxjs/operators';
|
|
8
|
+
import { PB_CONFIG, PB_DEFAULT_CONFIG } from './tokens/tokens';
|
|
9
|
+
import { PbEmailObjectStoreService } from './services/internals/pb-email-object-store/pb-email-object-store.service';
|
|
10
|
+
import { PbUserMiddlewaresService } from './services/user-middleware-service/pb-middlewares.service';
|
|
11
|
+
import { PbUserInterfaceService } from './services/internals/user-interfaces/user-interface.service';
|
|
12
|
+
/**
|
|
13
|
+
* @deprecated Soon it will be removed
|
|
14
|
+
* @internal
|
|
15
|
+
*/
|
|
16
|
+
export class PbEmailBuilderService {
|
|
17
|
+
constructor(config,
|
|
18
|
+
// @Inject(PB_GOOGLE_FONTS) private googleFonts: string[],
|
|
19
|
+
emailObjectStore, pbMiddleWares, pbUserInterface // private _http: HttpClient,
|
|
20
|
+
) {
|
|
21
|
+
this.config = config;
|
|
22
|
+
this.emailObjectStore = emailObjectStore;
|
|
23
|
+
this.pbMiddleWares = pbMiddleWares;
|
|
24
|
+
this.pbUserInterface = pbUserInterface;
|
|
25
|
+
// private _template = new BehaviorSubject<string>('');
|
|
26
|
+
// private _mjml = new BehaviorSubject<string>('');
|
|
27
|
+
// private readonly _onSave$ = new Subject();
|
|
28
|
+
/**
|
|
29
|
+
* @deprecated Please use the new service "UserRestApiService" instead
|
|
30
|
+
*/
|
|
31
|
+
this.modules = new Set();
|
|
32
|
+
/**
|
|
33
|
+
* @deprecated Please use the new service "UserRestApiService" instead
|
|
34
|
+
*/
|
|
35
|
+
this.customTemplates = new Set();
|
|
36
|
+
/**
|
|
37
|
+
* @deprecated Please use the new service "UserRestApiService" instead
|
|
38
|
+
*/
|
|
39
|
+
this._mergeTags = new Set();
|
|
40
|
+
this.onTemplateCreated$ = this.emailObjectStore.onTemplateCreated$.pipe(shareReplay());
|
|
41
|
+
/**
|
|
42
|
+
* @deprecated Use onTemplateCreated$ instead
|
|
43
|
+
*/
|
|
44
|
+
this.onSave$ = this.onTemplateCreated$;
|
|
45
|
+
/**
|
|
46
|
+
* @deprecated Use isLoading$ instead
|
|
47
|
+
*/
|
|
48
|
+
this.isLoading = this.pbUserInterface.activeMatProgress$.asObservable();
|
|
49
|
+
this.isLoading$ = this.pbUserInterface.activeMatProgress$.asObservable();
|
|
50
|
+
this.config = Object.assign(Object.assign({}, PB_DEFAULT_CONFIG), this.config);
|
|
51
|
+
}
|
|
52
|
+
/**
|
|
53
|
+
* Save current Email Template
|
|
54
|
+
*/
|
|
55
|
+
createHTMLTemplate$() {
|
|
56
|
+
this.pbUserInterface.activeMatProgress$.next(true);
|
|
57
|
+
return this.emailObjectStore.createHTMLTemplate$().pipe(tap(() => this.pbUserInterface.activeMatProgress$.next(false)), catchError((error) => this.pbMiddleWares.catchError(error).pipe(switchMap(() => {
|
|
58
|
+
this.pbUserInterface.notify(error.message);
|
|
59
|
+
this.pbUserInterface.activeMatProgress$.next(false);
|
|
60
|
+
return EMPTY;
|
|
61
|
+
}))), finalize(() => this.pbUserInterface.activeMatProgress$.next(false)));
|
|
62
|
+
}
|
|
63
|
+
/**
|
|
64
|
+
* @deprecated Please use ngb.createHTMLTemplate$() instead
|
|
65
|
+
*/
|
|
66
|
+
saveEmail() {
|
|
67
|
+
return this.createHTMLTemplate$();
|
|
68
|
+
}
|
|
69
|
+
/**
|
|
70
|
+
* Get Email as object
|
|
71
|
+
*/
|
|
72
|
+
get Email() {
|
|
73
|
+
return this.emailObjectStore.Email;
|
|
74
|
+
}
|
|
75
|
+
/**
|
|
76
|
+
* Set Email saved from database or created with new PBEmail()
|
|
77
|
+
*/
|
|
78
|
+
set Email(newEmail) {
|
|
79
|
+
this.emailObjectStore.setEmail(newEmail);
|
|
80
|
+
}
|
|
81
|
+
/**
|
|
82
|
+
* @deprecated Use getTemplateAsObservable$() instead
|
|
83
|
+
*/
|
|
84
|
+
get Template() {
|
|
85
|
+
return null;
|
|
86
|
+
}
|
|
87
|
+
/**
|
|
88
|
+
* Set HTML output
|
|
89
|
+
*/
|
|
90
|
+
// set Template(template: string) {
|
|
91
|
+
// this._template.next(template);
|
|
92
|
+
// }
|
|
93
|
+
/**
|
|
94
|
+
* @deprecated Use getMjmlAsObservable$() instead
|
|
95
|
+
*/
|
|
96
|
+
get Mjml() {
|
|
97
|
+
return null;
|
|
98
|
+
}
|
|
99
|
+
/**
|
|
100
|
+
* Listen Email changes
|
|
101
|
+
*/
|
|
102
|
+
getEmailAsObservable$() {
|
|
103
|
+
return this.emailObjectStore.emailAsObservable$;
|
|
104
|
+
}
|
|
105
|
+
/**
|
|
106
|
+
* Listen Template changes
|
|
107
|
+
*/
|
|
108
|
+
getTemplateAsObservable$() {
|
|
109
|
+
return this.emailObjectStore.templateAsObservable$;
|
|
110
|
+
}
|
|
111
|
+
/**
|
|
112
|
+
* Listen MJML changes
|
|
113
|
+
*/
|
|
114
|
+
getMjmlAsObservable$() {
|
|
115
|
+
return this.emailObjectStore.mjmlAsObservable$;
|
|
116
|
+
}
|
|
117
|
+
/**
|
|
118
|
+
* Listen Email and Template changes
|
|
119
|
+
* @deprecated Use onTemplateCreated$ instead
|
|
120
|
+
*/
|
|
121
|
+
onChanges$() {
|
|
122
|
+
return this.onTemplateCreated$;
|
|
123
|
+
}
|
|
124
|
+
}
|
|
125
|
+
PbEmailBuilderService.decorators = [
|
|
126
|
+
{ type: Injectable }
|
|
127
|
+
];
|
|
128
|
+
PbEmailBuilderService.ctorParameters = () => [
|
|
129
|
+
{ type: undefined, decorators: [{ type: Inject, args: [PB_CONFIG,] }] },
|
|
130
|
+
{ type: PbEmailObjectStoreService },
|
|
131
|
+
{ type: PbUserMiddlewaresService },
|
|
132
|
+
{ type: PbUserInterfaceService }
|
|
133
|
+
];
|
|
134
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pb-email-builder.service.js","sourceRoot":"","sources":["../../../../projects/pb-email-builder/src/lib/pb-email-builder.service.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 { Injectable, Inject } from '@angular/core';\r\nimport { HttpErrorResponse } from '@angular/common/http';\r\nimport { Observable, EMPTY } from 'rxjs';\r\nimport { catchError, switchMap, shareReplay, tap, finalize } from 'rxjs/operators';\r\n\r\nimport { IForRootConf, IUserModule, IUserTemplate } from './interfaces/interfaces';\r\nimport { PBEmail } from './classes/DefaultEmail';\r\n\r\nimport { PB_CONFIG, PB_DEFAULT_CONFIG } from './tokens/tokens';\r\nimport { PbEmailObjectStoreService } from './services/internals/pb-email-object-store/pb-email-object-store.service';\r\nimport { PbUserMiddlewaresService } from './services/user-middleware-service/pb-middlewares.service';\r\nimport { PbUserInterfaceService } from './services/internals/user-interfaces/user-interface.service';\r\n\r\n/**\r\n * @deprecated Soon it will be removed\r\n * @internal\r\n */\r\n@Injectable()\r\nexport class PbEmailBuilderService {\r\n  // private _template = new BehaviorSubject<string>('');\r\n  // private _mjml = new BehaviorSubject<string>('');\r\n  // private readonly _onSave$ = new Subject();\r\n\r\n  /**\r\n   * @deprecated Please use the new service \"UserRestApiService\" instead\r\n   */\r\n  public modules = new Set<IUserModule>();\r\n  /**\r\n   * @deprecated Please use the new service \"UserRestApiService\" instead\r\n   */\r\n  public readonly customTemplates = new Set<IUserTemplate>();\r\n  /**\r\n   * @deprecated Please use the new service \"UserRestApiService\" instead\r\n   */\r\n  private _mergeTags = new Set<string>();\r\n\r\n  public readonly onTemplateCreated$ = this.emailObjectStore.onTemplateCreated$.pipe(shareReplay());\r\n\r\n  /**\r\n   * @deprecated Use onTemplateCreated$ instead\r\n   */\r\n  public readonly onSave$ = this.onTemplateCreated$;\r\n\r\n  /**\r\n   * @deprecated Use isLoading$ instead\r\n   */\r\n  public readonly isLoading = this.pbUserInterface.activeMatProgress$.asObservable();\r\n  public readonly isLoading$ = this.pbUserInterface.activeMatProgress$.asObservable();\r\n\r\n  constructor(\r\n    @Inject(PB_CONFIG) public config: IForRootConf,\r\n    // @Inject(PB_GOOGLE_FONTS) private googleFonts: string[],\r\n    private emailObjectStore: PbEmailObjectStoreService,\r\n    private pbMiddleWares: PbUserMiddlewaresService,\r\n    private pbUserInterface: PbUserInterfaceService // private _http: HttpClient,\r\n  ) {\r\n    this.config = { ...PB_DEFAULT_CONFIG, ...this.config };\r\n  }\r\n\r\n  /**\r\n   * Save current Email Template\r\n   */\r\n  createHTMLTemplate$() {\r\n    this.pbUserInterface.activeMatProgress$.next(true);\r\n    return this.emailObjectStore.createHTMLTemplate$().pipe(\r\n      tap(() => this.pbUserInterface.activeMatProgress$.next(false)),\r\n      catchError((error: HttpErrorResponse) =>\r\n        this.pbMiddleWares.catchError(error).pipe(\r\n          switchMap(() => {\r\n            this.pbUserInterface.notify(error.message);\r\n            this.pbUserInterface.activeMatProgress$.next(false);\r\n            return EMPTY;\r\n          })\r\n        )\r\n      ),\r\n      finalize(() => this.pbUserInterface.activeMatProgress$.next(false))\r\n    );\r\n  }\r\n\r\n  /**\r\n   *  @deprecated Please use ngb.createHTMLTemplate$() instead\r\n   */\r\n  saveEmail() {\r\n    return this.createHTMLTemplate$();\r\n  }\r\n\r\n  /**\r\n   * Get Email as object\r\n   */\r\n  get Email() {\r\n    return this.emailObjectStore.Email;\r\n  }\r\n\r\n  /**\r\n   * Set Email saved from database or created with new PBEmail()\r\n   */\r\n  set Email(newEmail: PBEmail) {\r\n    this.emailObjectStore.setEmail(newEmail);\r\n  }\r\n\r\n  /**\r\n   * @deprecated Use getTemplateAsObservable$() instead\r\n   */\r\n  get Template() {\r\n    return null;\r\n  }\r\n  /**\r\n   * Set HTML output\r\n   */\r\n  // set Template(template: string) {\r\n  //   this._template.next(template);\r\n  // }\r\n\r\n  /**\r\n   * @deprecated Use getMjmlAsObservable$() instead\r\n   */\r\n  get Mjml() {\r\n    return null;\r\n  }\r\n\r\n  /**\r\n   * Listen Email changes\r\n   */\r\n  getEmailAsObservable$(): Observable<PBEmail> {\r\n    return this.emailObjectStore.emailAsObservable$;\r\n  }\r\n\r\n  /**\r\n   * Listen Template changes\r\n   */\r\n  getTemplateAsObservable$(): Observable<string> {\r\n    return this.emailObjectStore.templateAsObservable$;\r\n  }\r\n\r\n  /**\r\n   * Listen MJML changes\r\n   */\r\n  getMjmlAsObservable$() {\r\n    return this.emailObjectStore.mjmlAsObservable$;\r\n  }\r\n\r\n  /**\r\n   * Listen Email and Template changes\r\n   * @deprecated Use onTemplateCreated$ instead\r\n   */\r\n  onChanges$(): Observable<[PBEmail, string, string]> {\r\n    return this.onTemplateCreated$;\r\n  }\r\n\r\n  /**\r\n   * Get Set of Structures from aside\r\n   */\r\n  // getSideStructures(): Set<IStructure> {\r\n  //   return this._structures;\r\n  // }\r\n\r\n  /**\r\n   * Get Set of Blocks from aside\r\n   */\r\n  // getSideBlocks(): Set<TBlocks> {\r\n  //   return this._blocks;\r\n  // }\r\n\r\n  /**\r\n   * Get a Set of fonts family\r\n   */\r\n  // get Fonts(): IFontFamily {\r\n  //   return this._fontFamily;\r\n  // }\r\n  // set Fonts(fonts: IFontFamily) {\r\n  //   this._fontFamily = fonts;\r\n  // }\r\n\r\n  // get FallbackFonts(): IFontFamily {\r\n  //   return this._fallbackFamily;\r\n  // }\r\n  // set FallbackFonts(fonts: IFontFamily) {\r\n  //   this._fallbackFamily = fonts;\r\n  // }\r\n\r\n  /**\r\n   * @deprecated Please use the new service \"UserRestApiService\" instead\r\n   */\r\n  // get MergeTags(): Set<string> {\r\n  //   return this._mergeTags;\r\n  // }\r\n\r\n  // set MergeTags(tags: Set<string>) {\r\n  //   this._mergeTags = tags;\r\n  // }\r\n}\r\n"]}
|
|
@@ -1,39 +1,39 @@
|
|
|
1
|
-
/*
|
|
2
|
-
* Copyright (c) 2024 Pobuca.
|
|
3
|
-
* All rights reserved.
|
|
4
|
-
*/
|
|
5
|
-
import { Pipe } from '@angular/core';
|
|
6
|
-
/**
|
|
7
|
-
* @ignore
|
|
8
|
-
*
|
|
9
|
-
* Soon will be removed.
|
|
10
|
-
*/
|
|
11
|
-
export class SlugifyPipe {
|
|
12
|
-
transform(input) {
|
|
13
|
-
const trChars = {
|
|
14
|
-
áÁ: 'a',
|
|
15
|
-
éÉ: 'e',
|
|
16
|
-
íÍ: 'i',
|
|
17
|
-
óÓ: 'o',
|
|
18
|
-
úÚ: 'u',
|
|
19
|
-
ñÑ: 'n'
|
|
20
|
-
};
|
|
21
|
-
for (const key of Object.keys(trChars)) {
|
|
22
|
-
input = input.replace(new RegExp('[' + key + ']', 'g'), trChars[key]);
|
|
23
|
-
}
|
|
24
|
-
return input
|
|
25
|
-
.toString()
|
|
26
|
-
.toLowerCase()
|
|
27
|
-
.replace(/\s+/g, '-') // Replace spaces with -
|
|
28
|
-
.replace(/[^\w\-]+/g, '') // Remove all non-word chars
|
|
29
|
-
.replace(/\-\-+/g, '-') // Replace multiple - with single -
|
|
30
|
-
.replace(/^-+/, '') // Trim - from start of text
|
|
31
|
-
.replace(/-+$/, ''); // Trim - from end of text
|
|
32
|
-
}
|
|
33
|
-
}
|
|
34
|
-
SlugifyPipe.decorators = [
|
|
35
|
-
{ type: Pipe, args: [{
|
|
36
|
-
name: 'slugify'
|
|
37
|
-
},] }
|
|
38
|
-
];
|
|
39
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
1
|
+
/*
|
|
2
|
+
* Copyright (c) 2024 Pobuca.
|
|
3
|
+
* All rights reserved.
|
|
4
|
+
*/
|
|
5
|
+
import { Pipe } from '@angular/core';
|
|
6
|
+
/**
|
|
7
|
+
* @ignore
|
|
8
|
+
*
|
|
9
|
+
* Soon will be removed.
|
|
10
|
+
*/
|
|
11
|
+
export class SlugifyPipe {
|
|
12
|
+
transform(input) {
|
|
13
|
+
const trChars = {
|
|
14
|
+
áÁ: 'a',
|
|
15
|
+
éÉ: 'e',
|
|
16
|
+
íÍ: 'i',
|
|
17
|
+
óÓ: 'o',
|
|
18
|
+
úÚ: 'u',
|
|
19
|
+
ñÑ: 'n'
|
|
20
|
+
};
|
|
21
|
+
for (const key of Object.keys(trChars)) {
|
|
22
|
+
input = input.replace(new RegExp('[' + key + ']', 'g'), trChars[key]);
|
|
23
|
+
}
|
|
24
|
+
return input
|
|
25
|
+
.toString()
|
|
26
|
+
.toLowerCase()
|
|
27
|
+
.replace(/\s+/g, '-') // Replace spaces with -
|
|
28
|
+
.replace(/[^\w\-]+/g, '') // Remove all non-word chars
|
|
29
|
+
.replace(/\-\-+/g, '-') // Replace multiple - with single -
|
|
30
|
+
.replace(/^-+/, '') // Trim - from start of text
|
|
31
|
+
.replace(/-+$/, ''); // Trim - from end of text
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
SlugifyPipe.decorators = [
|
|
35
|
+
{ type: Pipe, args: [{
|
|
36
|
+
name: 'slugify'
|
|
37
|
+
},] }
|
|
38
|
+
];
|
|
39
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2x1Z2lmeS5waXBlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvcGItZW1haWwtYnVpbGRlci9zcmMvbGliL3BpcGVzL3NsdWdpZnkucGlwZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7O0dBR0c7QUFFSCxPQUFPLEVBQUUsSUFBSSxFQUFpQixNQUFNLGVBQWUsQ0FBQztBQUVwRDs7OztHQUlHO0FBSUgsTUFBTSxPQUFPLFdBQVc7SUFDdEIsU0FBUyxDQUFDLEtBQWE7UUFDckIsTUFBTSxPQUFPLEdBQUc7WUFDZCxFQUFFLEVBQUUsR0FBRztZQUNQLEVBQUUsRUFBRSxHQUFHO1lBQ1AsRUFBRSxFQUFFLEdBQUc7WUFDUCxFQUFFLEVBQUUsR0FBRztZQUNQLEVBQUUsRUFBRSxHQUFHO1lBQ1AsRUFBRSxFQUFFLEdBQUc7U0FDUixDQUFDO1FBQ0YsS0FBSyxNQUFNLEdBQUcsSUFBSSxNQUFNLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxFQUFFO1lBQ3RDLEtBQUssR0FBRyxLQUFLLENBQUMsT0FBTyxDQUFDLElBQUksTUFBTSxDQUFDLEdBQUcsR0FBRyxHQUFHLEdBQUcsR0FBRyxFQUFFLEdBQUcsQ0FBQyxFQUFFLE9BQU8sQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDO1NBQ3ZFO1FBQ0QsT0FBTyxLQUFLO2FBQ1QsUUFBUSxFQUFFO2FBQ1YsV0FBVyxFQUFFO2FBQ2IsT0FBTyxDQUFDLE1BQU0sRUFBRSxHQUFHLENBQUMsQ0FBQyx3QkFBd0I7YUFDN0MsT0FBTyxDQUFDLFdBQVcsRUFBRSxFQUFFLENBQUMsQ0FBQyw0QkFBNEI7YUFDckQsT0FBTyxDQUFDLFFBQVEsRUFBRSxHQUFHLENBQUMsQ0FBQyxtQ0FBbUM7YUFDMUQsT0FBTyxDQUFDLEtBQUssRUFBRSxFQUFFLENBQUMsQ0FBQyw0QkFBNEI7YUFDL0MsT0FBTyxDQUFDLEtBQUssRUFBRSxFQUFFLENBQUMsQ0FBQyxDQUFDLDBCQUEwQjtJQUNuRCxDQUFDOzs7WUF4QkYsSUFBSSxTQUFDO2dCQUNKLElBQUksRUFBRSxTQUFTO2FBQ2hCIiwic291cmNlc0NvbnRlbnQiOlsiLypcclxuICogQ29weXJpZ2h0IChjKSAyMDI0IFBvYnVjYS5cclxuICogQWxsIHJpZ2h0cyByZXNlcnZlZC5cclxuICovXHJcblxyXG5pbXBvcnQgeyBQaXBlLCBQaXBlVHJhbnNmb3JtIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcblxyXG4vKipcclxuICogQGlnbm9yZVxyXG4gKlxyXG4gKiBTb29uIHdpbGwgYmUgcmVtb3ZlZC5cclxuICovXHJcbkBQaXBlKHtcclxuICBuYW1lOiAnc2x1Z2lmeSdcclxufSlcclxuZXhwb3J0IGNsYXNzIFNsdWdpZnlQaXBlIGltcGxlbWVudHMgUGlwZVRyYW5zZm9ybSB7XHJcbiAgdHJhbnNmb3JtKGlucHV0OiBzdHJpbmcpOiBzdHJpbmcge1xyXG4gICAgY29uc3QgdHJDaGFycyA9IHtcclxuICAgICAgw6HDgTogJ2EnLFxyXG4gICAgICDDqcOJOiAnZScsXHJcbiAgICAgIMOtw406ICdpJyxcclxuICAgICAgw7PDkzogJ28nLFxyXG4gICAgICDDusOaOiAndScsXHJcbiAgICAgIMOxw5E6ICduJ1xyXG4gICAgfTtcclxuICAgIGZvciAoY29uc3Qga2V5IG9mIE9iamVjdC5rZXlzKHRyQ2hhcnMpKSB7XHJcbiAgICAgIGlucHV0ID0gaW5wdXQucmVwbGFjZShuZXcgUmVnRXhwKCdbJyArIGtleSArICddJywgJ2cnKSwgdHJDaGFyc1trZXldKTtcclxuICAgIH1cclxuICAgIHJldHVybiBpbnB1dFxyXG4gICAgICAudG9TdHJpbmcoKVxyXG4gICAgICAudG9Mb3dlckNhc2UoKVxyXG4gICAgICAucmVwbGFjZSgvXFxzKy9nLCAnLScpIC8vIFJlcGxhY2Ugc3BhY2VzIHdpdGggLVxyXG4gICAgICAucmVwbGFjZSgvW15cXHdcXC1dKy9nLCAnJykgLy8gUmVtb3ZlIGFsbCBub24td29yZCBjaGFyc1xyXG4gICAgICAucmVwbGFjZSgvXFwtXFwtKy9nLCAnLScpIC8vIFJlcGxhY2UgbXVsdGlwbGUgLSB3aXRoIHNpbmdsZSAtXHJcbiAgICAgIC5yZXBsYWNlKC9eLSsvLCAnJykgLy8gVHJpbSAtIGZyb20gc3RhcnQgb2YgdGV4dFxyXG4gICAgICAucmVwbGFjZSgvLSskLywgJycpOyAvLyBUcmltIC0gZnJvbSBlbmQgb2YgdGV4dFxyXG4gIH1cclxufVxyXG4iXX0=
|