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