@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,94 +1,94 @@
|
|
|
1
|
-
/*
|
|
2
|
-
* Copyright (c) 2024 Pobuca.
|
|
3
|
-
* All rights reserved.
|
|
4
|
-
*/
|
|
5
|
-
import { ChangeDetectionStrategy, Component, Input } from '@angular/core';
|
|
6
|
-
import { PbEmailObjectStoreService } from '../services/internals/pb-email-object-store/pb-email-object-store.service';
|
|
7
|
-
export class WidthHeightComponent {
|
|
8
|
-
constructor(emailObject) {
|
|
9
|
-
this.emailObject = emailObject;
|
|
10
|
-
this.disabled = false;
|
|
11
|
-
this.units = new Map([
|
|
12
|
-
['%', $localize `:@@unit_percent:Percent`],
|
|
13
|
-
['px', $localize `:@@unit_pixels:Pixels`],
|
|
14
|
-
['contain', $localize `:@@unit_contain:Contain`],
|
|
15
|
-
['cover', $localize `:@@unit_cover:Cover`]
|
|
16
|
-
]);
|
|
17
|
-
}
|
|
18
|
-
markForCheck() {
|
|
19
|
-
this.emailObject.markForCheck();
|
|
20
|
-
}
|
|
21
|
-
getLabel() {
|
|
22
|
-
return this.label;
|
|
23
|
-
}
|
|
24
|
-
toggleChange({ checked }) {
|
|
25
|
-
this.model.auto = checked;
|
|
26
|
-
this.markForCheck();
|
|
27
|
-
}
|
|
28
|
-
getUnits() {
|
|
29
|
-
return this.model.units || ['%', 'px'];
|
|
30
|
-
}
|
|
31
|
-
disableValueField() {
|
|
32
|
-
return this.model.auto || ['%', 'px'].indexOf(this.model.unit) === -1;
|
|
33
|
-
}
|
|
34
|
-
showAutoSlider() {
|
|
35
|
-
return this.model.hasOwnProperty('auto');
|
|
36
|
-
}
|
|
37
|
-
getUnitLabel(unit) {
|
|
38
|
-
return this.units.get(unit);
|
|
39
|
-
}
|
|
40
|
-
}
|
|
41
|
-
WidthHeightComponent.decorators = [
|
|
42
|
-
{ type: Component, args: [{
|
|
43
|
-
selector: 'pb-width-height',
|
|
44
|
-
template: `
|
|
45
|
-
<div class="group" [ngClass]="{ three: showAutoSlider() }">
|
|
46
|
-
<mat-form-field appearance="outline">
|
|
47
|
-
<mat-label>{{ getLabel() }}</mat-label>
|
|
48
|
-
<input
|
|
49
|
-
matInput
|
|
50
|
-
[(ngModel)]="model.value"
|
|
51
|
-
[disabled]="disableValueField() || disabled"
|
|
52
|
-
type="number"
|
|
53
|
-
[placeholder]="getLabel()"
|
|
54
|
-
(input)="markForCheck()"
|
|
55
|
-
/>
|
|
56
|
-
</mat-form-field>
|
|
57
|
-
<mat-form-field appearance="outline">
|
|
58
|
-
<mat-label i18n="Size Settings|Size Unit">Unit</mat-label>
|
|
59
|
-
<mat-select [disabled]="model.auto || disabled" [(value)]="model.unit" (selectionChange)="markForCheck()" disableRipple>
|
|
60
|
-
<mat-option *ngFor="let unit of getUnits()" [value]="unit" i18n>
|
|
61
|
-
{{ getUnitLabel(unit) }}
|
|
62
|
-
</mat-option>
|
|
63
|
-
</mat-select>
|
|
64
|
-
</mat-form-field>
|
|
65
|
-
<mat-slide-toggle
|
|
66
|
-
style="margin-top: -20px;"
|
|
67
|
-
*ngIf="showAutoSlider()"
|
|
68
|
-
[checked]="model.auto"
|
|
69
|
-
(change)="toggleChange($event)"
|
|
70
|
-
[disabled]="disabled"
|
|
71
|
-
i18n="Size Settings|Size Auto"
|
|
72
|
-
>
|
|
73
|
-
Auto
|
|
74
|
-
</mat-slide-toggle>
|
|
75
|
-
</div>
|
|
76
|
-
`,
|
|
77
|
-
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
78
|
-
styles: [`
|
|
79
|
-
:host {
|
|
80
|
-
display: block;
|
|
81
|
-
width: 100%;
|
|
82
|
-
}
|
|
83
|
-
`]
|
|
84
|
-
},] }
|
|
85
|
-
];
|
|
86
|
-
WidthHeightComponent.ctorParameters = () => [
|
|
87
|
-
{ type: PbEmailObjectStoreService }
|
|
88
|
-
];
|
|
89
|
-
WidthHeightComponent.propDecorators = {
|
|
90
|
-
model: [{ type: Input }],
|
|
91
|
-
label: [{ type: Input }],
|
|
92
|
-
disabled: [{ type: Input }]
|
|
93
|
-
};
|
|
94
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
1
|
+
/*
|
|
2
|
+
* Copyright (c) 2024 Pobuca.
|
|
3
|
+
* All rights reserved.
|
|
4
|
+
*/
|
|
5
|
+
import { ChangeDetectionStrategy, Component, Input } from '@angular/core';
|
|
6
|
+
import { PbEmailObjectStoreService } from '../services/internals/pb-email-object-store/pb-email-object-store.service';
|
|
7
|
+
export class WidthHeightComponent {
|
|
8
|
+
constructor(emailObject) {
|
|
9
|
+
this.emailObject = emailObject;
|
|
10
|
+
this.disabled = false;
|
|
11
|
+
this.units = new Map([
|
|
12
|
+
['%', $localize `:@@unit_percent:Percent`],
|
|
13
|
+
['px', $localize `:@@unit_pixels:Pixels`],
|
|
14
|
+
['contain', $localize `:@@unit_contain:Contain`],
|
|
15
|
+
['cover', $localize `:@@unit_cover:Cover`]
|
|
16
|
+
]);
|
|
17
|
+
}
|
|
18
|
+
markForCheck() {
|
|
19
|
+
this.emailObject.markForCheck();
|
|
20
|
+
}
|
|
21
|
+
getLabel() {
|
|
22
|
+
return this.label;
|
|
23
|
+
}
|
|
24
|
+
toggleChange({ checked }) {
|
|
25
|
+
this.model.auto = checked;
|
|
26
|
+
this.markForCheck();
|
|
27
|
+
}
|
|
28
|
+
getUnits() {
|
|
29
|
+
return this.model.units || ['%', 'px'];
|
|
30
|
+
}
|
|
31
|
+
disableValueField() {
|
|
32
|
+
return this.model.auto || ['%', 'px'].indexOf(this.model.unit) === -1;
|
|
33
|
+
}
|
|
34
|
+
showAutoSlider() {
|
|
35
|
+
return this.model.hasOwnProperty('auto');
|
|
36
|
+
}
|
|
37
|
+
getUnitLabel(unit) {
|
|
38
|
+
return this.units.get(unit);
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
WidthHeightComponent.decorators = [
|
|
42
|
+
{ type: Component, args: [{
|
|
43
|
+
selector: 'pb-width-height',
|
|
44
|
+
template: `
|
|
45
|
+
<div class="group" [ngClass]="{ three: showAutoSlider() }">
|
|
46
|
+
<mat-form-field appearance="outline">
|
|
47
|
+
<mat-label>{{ getLabel() }}</mat-label>
|
|
48
|
+
<input
|
|
49
|
+
matInput
|
|
50
|
+
[(ngModel)]="model.value"
|
|
51
|
+
[disabled]="disableValueField() || disabled"
|
|
52
|
+
type="number"
|
|
53
|
+
[placeholder]="getLabel()"
|
|
54
|
+
(input)="markForCheck()"
|
|
55
|
+
/>
|
|
56
|
+
</mat-form-field>
|
|
57
|
+
<mat-form-field appearance="outline">
|
|
58
|
+
<mat-label i18n="Size Settings|Size Unit">Unit</mat-label>
|
|
59
|
+
<mat-select [disabled]="model.auto || disabled" [(value)]="model.unit" (selectionChange)="markForCheck()" disableRipple>
|
|
60
|
+
<mat-option *ngFor="let unit of getUnits()" [value]="unit" i18n>
|
|
61
|
+
{{ getUnitLabel(unit) }}
|
|
62
|
+
</mat-option>
|
|
63
|
+
</mat-select>
|
|
64
|
+
</mat-form-field>
|
|
65
|
+
<mat-slide-toggle
|
|
66
|
+
style="margin-top: -20px;"
|
|
67
|
+
*ngIf="showAutoSlider()"
|
|
68
|
+
[checked]="model.auto"
|
|
69
|
+
(change)="toggleChange($event)"
|
|
70
|
+
[disabled]="disabled"
|
|
71
|
+
i18n="Size Settings|Size Auto"
|
|
72
|
+
>
|
|
73
|
+
Auto
|
|
74
|
+
</mat-slide-toggle>
|
|
75
|
+
</div>
|
|
76
|
+
`,
|
|
77
|
+
changeDetection: ChangeDetectionStrategy.OnPush,
|
|
78
|
+
styles: [`
|
|
79
|
+
:host {
|
|
80
|
+
display: block;
|
|
81
|
+
width: 100%;
|
|
82
|
+
}
|
|
83
|
+
`]
|
|
84
|
+
},] }
|
|
85
|
+
];
|
|
86
|
+
WidthHeightComponent.ctorParameters = () => [
|
|
87
|
+
{ type: PbEmailObjectStoreService }
|
|
88
|
+
];
|
|
89
|
+
WidthHeightComponent.propDecorators = {
|
|
90
|
+
model: [{ type: Input }],
|
|
91
|
+
label: [{ type: Input }],
|
|
92
|
+
disabled: [{ type: Input }]
|
|
93
|
+
};
|
|
94
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid2lkdGgtaGVpZ2h0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvcGItZW1haWwtYnVpbGRlci9zcmMvbGliL2dyb3Vwcy93aWR0aC1oZWlnaHQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7OztHQUdHO0FBRUgsT0FBTyxFQUFFLHVCQUF1QixFQUFFLFNBQVMsRUFBRSxLQUFLLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFFMUUsT0FBTyxFQUFFLHlCQUF5QixFQUFFLE1BQU0sMkVBQTJFLENBQUM7QUErQ3RILE1BQU0sT0FBTyxvQkFBb0I7SUFXL0IsWUFBb0IsV0FBc0M7UUFBdEMsZ0JBQVcsR0FBWCxXQUFXLENBQTJCO1FBUmpELGFBQVEsR0FBRyxLQUFLLENBQUM7UUFDbEIsVUFBSyxHQUF3QixJQUFJLEdBQUcsQ0FBQztZQUMzQyxDQUFDLEdBQUcsRUFBRSxTQUFTLENBQUEseUJBQXlCLENBQUM7WUFDekMsQ0FBQyxJQUFJLEVBQUUsU0FBUyxDQUFBLHVCQUF1QixDQUFDO1lBQ3hDLENBQUMsU0FBUyxFQUFFLFNBQVMsQ0FBQSx5QkFBeUIsQ0FBQztZQUMvQyxDQUFDLE9BQU8sRUFBRSxTQUFTLENBQUEscUJBQXFCLENBQUM7U0FDMUMsQ0FBQyxDQUFDO0lBRTBELENBQUM7SUFFOUQsWUFBWTtRQUNWLElBQUksQ0FBQyxXQUFXLENBQUMsWUFBWSxFQUFFLENBQUM7SUFDbEMsQ0FBQztJQUVELFFBQVE7UUFDTixPQUFPLElBQUksQ0FBQyxLQUFLLENBQUM7SUFDcEIsQ0FBQztJQUVELFlBQVksQ0FBQyxFQUFFLE9BQU8sRUFBRTtRQUN0QixJQUFJLENBQUMsS0FBSyxDQUFDLElBQUksR0FBRyxPQUFPLENBQUM7UUFDMUIsSUFBSSxDQUFDLFlBQVksRUFBRSxDQUFDO0lBQ3RCLENBQUM7SUFFRCxRQUFRO1FBQ04sT0FBTyxJQUFJLENBQUMsS0FBSyxDQUFDLEtBQUssSUFBSSxDQUFDLEdBQUcsRUFBRSxJQUFJLENBQUMsQ0FBQztJQUN6QyxDQUFDO0lBRUQsaUJBQWlCO1FBQ2YsT0FBTyxJQUFJLENBQUMsS0FBSyxDQUFDLElBQUksSUFBSSxDQUFDLEdBQUcsRUFBRSxJQUFJLENBQUMsQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUMsQ0FBQztJQUN4RSxDQUFDO0lBRUQsY0FBYztRQUNaLE9BQU8sSUFBSSxDQUFDLEtBQUssQ0FBQyxjQUFjLENBQUMsTUFBTSxDQUFDLENBQUM7SUFDM0MsQ0FBQztJQUVELFlBQVksQ0FBQyxJQUFZO1FBQ3ZCLE9BQU8sSUFBSSxDQUFDLEtBQUssQ0FBQyxHQUFHLENBQUMsSUFBSSxDQUFDLENBQUM7SUFDOUIsQ0FBQzs7O1lBckZGLFNBQVMsU0FBQztnQkFDVCxRQUFRLEVBQUUsaUJBQWlCO2dCQUMzQixRQUFRLEVBQUU7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0dBZ0NUO2dCQVNELGVBQWUsRUFBRSx1QkFBdUIsQ0FBQyxNQUFNO3lCQVA3Qzs7Ozs7S0FLQzthQUdKOzs7WUE5Q1EseUJBQXlCOzs7b0JBZ0QvQixLQUFLO29CQUNMLEtBQUs7dUJBQ0wsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbIi8qXHJcbiAqIENvcHlyaWdodCAoYykgMjAyNCBQb2J1Y2EuXHJcbiAqIEFsbCByaWdodHMgcmVzZXJ2ZWQuXHJcbiAqL1xyXG5cclxuaW1wb3J0IHsgQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3ksIENvbXBvbmVudCwgSW5wdXQgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgSVdpZHRoSGVpZ2h0IH0gZnJvbSAnLi4vaW50ZXJmYWNlcy9pbnRlcmZhY2VzJztcclxuaW1wb3J0IHsgUGJFbWFpbE9iamVjdFN0b3JlU2VydmljZSB9IGZyb20gJy4uL3NlcnZpY2VzL2ludGVybmFscy9wYi1lbWFpbC1vYmplY3Qtc3RvcmUvcGItZW1haWwtb2JqZWN0LXN0b3JlLnNlcnZpY2UnO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6ICdwYi13aWR0aC1oZWlnaHQnLFxyXG4gIHRlbXBsYXRlOiBgXHJcbiAgICA8ZGl2IGNsYXNzPVwiZ3JvdXBcIiBbbmdDbGFzc109XCJ7IHRocmVlOiBzaG93QXV0b1NsaWRlcigpIH1cIj5cclxuICAgICAgPG1hdC1mb3JtLWZpZWxkIGFwcGVhcmFuY2U9XCJvdXRsaW5lXCI+XHJcbiAgICAgICAgPG1hdC1sYWJlbD57eyBnZXRMYWJlbCgpIH19PC9tYXQtbGFiZWw+XHJcbiAgICAgICAgPGlucHV0XHJcbiAgICAgICAgICBtYXRJbnB1dFxyXG4gICAgICAgICAgWyhuZ01vZGVsKV09XCJtb2RlbC52YWx1ZVwiXHJcbiAgICAgICAgICBbZGlzYWJsZWRdPVwiZGlzYWJsZVZhbHVlRmllbGQoKSB8fCBkaXNhYmxlZFwiXHJcbiAgICAgICAgICB0eXBlPVwibnVtYmVyXCJcclxuICAgICAgICAgIFtwbGFjZWhvbGRlcl09XCJnZXRMYWJlbCgpXCJcclxuICAgICAgICAgIChpbnB1dCk9XCJtYXJrRm9yQ2hlY2soKVwiXHJcbiAgICAgICAgLz5cclxuICAgICAgPC9tYXQtZm9ybS1maWVsZD5cclxuICAgICAgPG1hdC1mb3JtLWZpZWxkIGFwcGVhcmFuY2U9XCJvdXRsaW5lXCI+XHJcbiAgICAgICAgPG1hdC1sYWJlbCBpMThuPVwiU2l6ZSBTZXR0aW5nc3xTaXplIFVuaXRcIj5Vbml0PC9tYXQtbGFiZWw+XHJcbiAgICAgICAgPG1hdC1zZWxlY3QgW2Rpc2FibGVkXT1cIm1vZGVsLmF1dG8gfHwgZGlzYWJsZWRcIiBbKHZhbHVlKV09XCJtb2RlbC51bml0XCIgKHNlbGVjdGlvbkNoYW5nZSk9XCJtYXJrRm9yQ2hlY2soKVwiIGRpc2FibGVSaXBwbGU+XHJcbiAgICAgICAgICA8bWF0LW9wdGlvbiAqbmdGb3I9XCJsZXQgdW5pdCBvZiBnZXRVbml0cygpXCIgW3ZhbHVlXT1cInVuaXRcIiBpMThuPlxyXG4gICAgICAgICAgICB7eyBnZXRVbml0TGFiZWwodW5pdCkgfX1cclxuICAgICAgICAgIDwvbWF0LW9wdGlvbj5cclxuICAgICAgICA8L21hdC1zZWxlY3Q+XHJcbiAgICAgIDwvbWF0LWZvcm0tZmllbGQ+XHJcbiAgICAgIDxtYXQtc2xpZGUtdG9nZ2xlXHJcbiAgICAgICAgc3R5bGU9XCJtYXJnaW4tdG9wOiAtMjBweDtcIlxyXG4gICAgICAgICpuZ0lmPVwic2hvd0F1dG9TbGlkZXIoKVwiXHJcbiAgICAgICAgW2NoZWNrZWRdPVwibW9kZWwuYXV0b1wiXHJcbiAgICAgICAgKGNoYW5nZSk9XCJ0b2dnbGVDaGFuZ2UoJGV2ZW50KVwiXHJcbiAgICAgICAgW2Rpc2FibGVkXT1cImRpc2FibGVkXCJcclxuICAgICAgICBpMThuPVwiU2l6ZSBTZXR0aW5nc3xTaXplIEF1dG9cIlxyXG4gICAgICA+XHJcbiAgICAgICAgQXV0b1xyXG4gICAgICA8L21hdC1zbGlkZS10b2dnbGU+XHJcbiAgICA8L2Rpdj5cclxuICBgLFxyXG4gIHN0eWxlczogW1xyXG4gICAgYFxyXG4gICAgICA6aG9zdCB7XHJcbiAgICAgICAgZGlzcGxheTogYmxvY2s7XHJcbiAgICAgICAgd2lkdGg6IDEwMCU7XHJcbiAgICAgIH1cclxuICAgIGBcclxuICBdLFxyXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBXaWR0aEhlaWdodENvbXBvbmVudCB7XHJcbiAgQElucHV0KCkgbW9kZWw6IElXaWR0aEhlaWdodDtcclxuICBASW5wdXQoKSBsYWJlbDogc3RyaW5nO1xyXG4gIEBJbnB1dCgpIGRpc2FibGVkID0gZmFsc2U7XHJcbiAgcHJpdmF0ZSB1bml0czogTWFwPHN0cmluZywgc3RyaW5nPiA9IG5ldyBNYXAoW1xyXG4gICAgWyclJywgJGxvY2FsaXplYDpAQHVuaXRfcGVyY2VudDpQZXJjZW50YF0sXHJcbiAgICBbJ3B4JywgJGxvY2FsaXplYDpAQHVuaXRfcGl4ZWxzOlBpeGVsc2BdLFxyXG4gICAgWydjb250YWluJywgJGxvY2FsaXplYDpAQHVuaXRfY29udGFpbjpDb250YWluYF0sXHJcbiAgICBbJ2NvdmVyJywgJGxvY2FsaXplYDpAQHVuaXRfY292ZXI6Q292ZXJgXVxyXG4gIF0pO1xyXG5cclxuICBjb25zdHJ1Y3Rvcihwcml2YXRlIGVtYWlsT2JqZWN0OiBQYkVtYWlsT2JqZWN0U3RvcmVTZXJ2aWNlKSB7fVxyXG5cclxuICBtYXJrRm9yQ2hlY2soKSB7XHJcbiAgICB0aGlzLmVtYWlsT2JqZWN0Lm1hcmtGb3JDaGVjaygpO1xyXG4gIH1cclxuXHJcbiAgZ2V0TGFiZWwoKSB7XHJcbiAgICByZXR1cm4gdGhpcy5sYWJlbDtcclxuICB9XHJcblxyXG4gIHRvZ2dsZUNoYW5nZSh7IGNoZWNrZWQgfSkge1xyXG4gICAgdGhpcy5tb2RlbC5hdXRvID0gY2hlY2tlZDtcclxuICAgIHRoaXMubWFya0ZvckNoZWNrKCk7XHJcbiAgfVxyXG5cclxuICBnZXRVbml0cygpIHtcclxuICAgIHJldHVybiB0aGlzLm1vZGVsLnVuaXRzIHx8IFsnJScsICdweCddO1xyXG4gIH1cclxuXHJcbiAgZGlzYWJsZVZhbHVlRmllbGQoKSB7XHJcbiAgICByZXR1cm4gdGhpcy5tb2RlbC5hdXRvIHx8IFsnJScsICdweCddLmluZGV4T2YodGhpcy5tb2RlbC51bml0KSA9PT0gLTE7XHJcbiAgfVxyXG5cclxuICBzaG93QXV0b1NsaWRlcigpIHtcclxuICAgIHJldHVybiB0aGlzLm1vZGVsLmhhc093blByb3BlcnR5KCdhdXRvJyk7XHJcbiAgfVxyXG5cclxuICBnZXRVbml0TGFiZWwodW5pdDogc3RyaW5nKTogc3RyaW5nIHtcclxuICAgIHJldHVybiB0aGlzLnVuaXRzLmdldCh1bml0KTtcclxuICB9XHJcbn1cclxuIl19
|
|
@@ -1,51 +1,51 @@
|
|
|
1
|
-
/*
|
|
2
|
-
* Copyright (c) 2024 Pobuca.
|
|
3
|
-
* All rights reserved.
|
|
4
|
-
*/
|
|
5
|
-
import { Injectable, Inject } from '@angular/core';
|
|
6
|
-
import { HttpEventType } from '@angular/common/http';
|
|
7
|
-
import { tap } from 'rxjs/operators';
|
|
8
|
-
import { PB_CONFIG, PB_DEFAULT_CONFIG } from '../tokens/tokens';
|
|
9
|
-
import { PbUserInterfaceService } from '../services/internals/user-interfaces/user-interface.service';
|
|
10
|
-
import * as i0 from "@angular/core";
|
|
11
|
-
import * as i1 from "../tokens/tokens";
|
|
12
|
-
import * as i2 from "../services/internals/user-interfaces/user-interface.service";
|
|
13
|
-
export class IpInterceptorInterceptor {
|
|
14
|
-
constructor(userConfig, userInterface) {
|
|
15
|
-
this.userConfig = userConfig;
|
|
16
|
-
this.userInterface = userInterface;
|
|
17
|
-
}
|
|
18
|
-
intercept(request, next) {
|
|
19
|
-
if (request.url.startsWith('https://ngb-api.wlocalhost.org')) {
|
|
20
|
-
const notify = this.userInterface.notify('Loading, please wait ...', null, null);
|
|
21
|
-
const { xApiKey } = Object.assign(Object.assign({}, PB_DEFAULT_CONFIG), this.userConfig);
|
|
22
|
-
return next
|
|
23
|
-
.handle(request.clone({
|
|
24
|
-
setHeaders: {
|
|
25
|
-
'Content-Type': 'application/json',
|
|
26
|
-
'X-Api-Key': xApiKey
|
|
27
|
-
},
|
|
28
|
-
responseType: 'json'
|
|
29
|
-
}))
|
|
30
|
-
.pipe(tap((res) => {
|
|
31
|
-
if (res.type === HttpEventType.Response) {
|
|
32
|
-
notify.dismiss();
|
|
33
|
-
}
|
|
34
|
-
}));
|
|
35
|
-
}
|
|
36
|
-
else {
|
|
37
|
-
return next.handle(request);
|
|
38
|
-
}
|
|
39
|
-
}
|
|
40
|
-
}
|
|
41
|
-
IpInterceptorInterceptor.ɵprov = i0.ɵɵdefineInjectable({ factory: function IpInterceptorInterceptor_Factory() { return new IpInterceptorInterceptor(i0.ɵɵinject(i1.PB_CONFIG), i0.ɵɵinject(i2.PbUserInterfaceService)); }, token: IpInterceptorInterceptor, providedIn: "root" });
|
|
42
|
-
IpInterceptorInterceptor.decorators = [
|
|
43
|
-
{ type: Injectable, args: [{
|
|
44
|
-
providedIn: 'root'
|
|
45
|
-
},] }
|
|
46
|
-
];
|
|
47
|
-
IpInterceptorInterceptor.ctorParameters = () => [
|
|
48
|
-
{ type: undefined, decorators: [{ type: Inject, args: [PB_CONFIG,] }] },
|
|
49
|
-
{ type: PbUserInterfaceService }
|
|
50
|
-
];
|
|
51
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
1
|
+
/*
|
|
2
|
+
* Copyright (c) 2024 Pobuca.
|
|
3
|
+
* All rights reserved.
|
|
4
|
+
*/
|
|
5
|
+
import { Injectable, Inject } from '@angular/core';
|
|
6
|
+
import { HttpEventType } from '@angular/common/http';
|
|
7
|
+
import { tap } from 'rxjs/operators';
|
|
8
|
+
import { PB_CONFIG, PB_DEFAULT_CONFIG } from '../tokens/tokens';
|
|
9
|
+
import { PbUserInterfaceService } from '../services/internals/user-interfaces/user-interface.service';
|
|
10
|
+
import * as i0 from "@angular/core";
|
|
11
|
+
import * as i1 from "../tokens/tokens";
|
|
12
|
+
import * as i2 from "../services/internals/user-interfaces/user-interface.service";
|
|
13
|
+
export class IpInterceptorInterceptor {
|
|
14
|
+
constructor(userConfig, userInterface) {
|
|
15
|
+
this.userConfig = userConfig;
|
|
16
|
+
this.userInterface = userInterface;
|
|
17
|
+
}
|
|
18
|
+
intercept(request, next) {
|
|
19
|
+
if (request.url.startsWith('https://ngb-api.wlocalhost.org')) {
|
|
20
|
+
const notify = this.userInterface.notify('Loading, please wait ...', null, null);
|
|
21
|
+
const { xApiKey } = Object.assign(Object.assign({}, PB_DEFAULT_CONFIG), this.userConfig);
|
|
22
|
+
return next
|
|
23
|
+
.handle(request.clone({
|
|
24
|
+
setHeaders: {
|
|
25
|
+
'Content-Type': 'application/json',
|
|
26
|
+
'X-Api-Key': xApiKey
|
|
27
|
+
},
|
|
28
|
+
responseType: 'json'
|
|
29
|
+
}))
|
|
30
|
+
.pipe(tap((res) => {
|
|
31
|
+
if (res.type === HttpEventType.Response) {
|
|
32
|
+
notify.dismiss();
|
|
33
|
+
}
|
|
34
|
+
}));
|
|
35
|
+
}
|
|
36
|
+
else {
|
|
37
|
+
return next.handle(request);
|
|
38
|
+
}
|
|
39
|
+
}
|
|
40
|
+
}
|
|
41
|
+
IpInterceptorInterceptor.ɵprov = i0.ɵɵdefineInjectable({ factory: function IpInterceptorInterceptor_Factory() { return new IpInterceptorInterceptor(i0.ɵɵinject(i1.PB_CONFIG), i0.ɵɵinject(i2.PbUserInterfaceService)); }, token: IpInterceptorInterceptor, providedIn: "root" });
|
|
42
|
+
IpInterceptorInterceptor.decorators = [
|
|
43
|
+
{ type: Injectable, args: [{
|
|
44
|
+
providedIn: 'root'
|
|
45
|
+
},] }
|
|
46
|
+
];
|
|
47
|
+
IpInterceptorInterceptor.ctorParameters = () => [
|
|
48
|
+
{ type: undefined, decorators: [{ type: Inject, args: [PB_CONFIG,] }] },
|
|
49
|
+
{ type: PbUserInterfaceService }
|
|
50
|
+
];
|
|
51
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicGItaW50ZXJjZXB0b3IuaW50ZXJjZXB0b3IuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9wYi1lbWFpbC1idWlsZGVyL3NyYy9saWIvaW50ZXJjZXB0b3JzL3BiLWludGVyY2VwdG9yLmludGVyY2VwdG9yLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOzs7R0FHRztBQUVILE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ25ELE9BQU8sRUFBc0UsYUFBYSxFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFFekgsT0FBTyxFQUFFLEdBQUcsRUFBRSxNQUFNLGdCQUFnQixDQUFDO0FBRXJDLE9BQU8sRUFBRSxTQUFTLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQztBQUVoRSxPQUFPLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSw4REFBOEQsQ0FBQzs7OztBQUt0RyxNQUFNLE9BQU8sd0JBQXdCO0lBQ25DLFlBQXVDLFVBQXdCLEVBQVUsYUFBcUM7UUFBdkUsZUFBVSxHQUFWLFVBQVUsQ0FBYztRQUFVLGtCQUFhLEdBQWIsYUFBYSxDQUF3QjtJQUFHLENBQUM7SUFFbEgsU0FBUyxDQUFDLE9BQTZCLEVBQUUsSUFBaUI7UUFDeEQsSUFBSSxPQUFPLENBQUMsR0FBRyxDQUFDLFVBQVUsQ0FBQyxnQ0FBZ0MsQ0FBQyxFQUFFO1lBQzVELE1BQU0sTUFBTSxHQUFHLElBQUksQ0FBQyxhQUFhLENBQUMsTUFBTSxDQUFDLDBCQUEwQixFQUFFLElBQUksRUFBRSxJQUFJLENBQUMsQ0FBQztZQUNqRixNQUFNLEVBQUUsT0FBTyxFQUFFLG1DQUFRLGlCQUFpQixHQUFLLElBQUksQ0FBQyxVQUFVLENBQUUsQ0FBQztZQUNqRSxPQUFPLElBQUk7aUJBQ1IsTUFBTSxDQUNMLE9BQU8sQ0FBQyxLQUFLLENBQUM7Z0JBQ1osVUFBVSxFQUFFO29CQUNWLGNBQWMsRUFBRSxrQkFBa0I7b0JBQ2xDLFdBQVcsRUFBRSxPQUFPO2lCQUNyQjtnQkFDRCxZQUFZLEVBQUUsTUFBTTthQUNyQixDQUFDLENBQ0g7aUJBQ0EsSUFBSSxDQUNILEdBQUcsQ0FBQyxDQUFDLEdBQXNCLEVBQUUsRUFBRTtnQkFDN0IsSUFBSSxHQUFHLENBQUMsSUFBSSxLQUFLLGFBQWEsQ0FBQyxRQUFRLEVBQUU7b0JBQ3ZDLE1BQU0sQ0FBQyxPQUFPLEVBQUUsQ0FBQztpQkFDbEI7WUFDSCxDQUFDLENBQUMsQ0FDSCxDQUFDO1NBQ0w7YUFBTTtZQUNMLE9BQU8sSUFBSSxDQUFDLE1BQU0sQ0FBQyxPQUFPLENBQUMsQ0FBQztTQUM3QjtJQUNILENBQUM7Ozs7WUE5QkYsVUFBVSxTQUFDO2dCQUNWLFVBQVUsRUFBRSxNQUFNO2FBQ25COzs7NENBRWMsTUFBTSxTQUFDLFNBQVM7WUFOdEIsc0JBQXNCIiwic291cmNlc0NvbnRlbnQiOlsiLypcclxuICogQ29weXJpZ2h0IChjKSAyMDI0IFBvYnVjYS5cclxuICogQWxsIHJpZ2h0cyByZXNlcnZlZC5cclxuICovXHJcblxyXG5pbXBvcnQgeyBJbmplY3RhYmxlLCBJbmplY3QgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgSHR0cFJlcXVlc3QsIEh0dHBIYW5kbGVyLCBIdHRwRXZlbnQsIEh0dHBJbnRlcmNlcHRvciwgSHR0cFJlc3BvbnNlLCBIdHRwRXZlbnRUeXBlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uL2h0dHAnO1xyXG5pbXBvcnQgeyBPYnNlcnZhYmxlIH0gZnJvbSAncnhqcyc7XHJcbmltcG9ydCB7IHRhcCB9IGZyb20gJ3J4anMvb3BlcmF0b3JzJztcclxuXHJcbmltcG9ydCB7IFBCX0NPTkZJRywgUEJfREVGQVVMVF9DT05GSUcgfSBmcm9tICcuLi90b2tlbnMvdG9rZW5zJztcclxuaW1wb3J0IHsgSUZvclJvb3RDb25mIH0gZnJvbSAnLi4vaW50ZXJmYWNlcy9pbnRlcmZhY2VzJztcclxuaW1wb3J0IHsgUGJVc2VySW50ZXJmYWNlU2VydmljZSB9IGZyb20gJy4uL3NlcnZpY2VzL2ludGVybmFscy91c2VyLWludGVyZmFjZXMvdXNlci1pbnRlcmZhY2Uuc2VydmljZSc7XHJcblxyXG5ASW5qZWN0YWJsZSh7XHJcbiAgcHJvdmlkZWRJbjogJ3Jvb3QnXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBJcEludGVyY2VwdG9ySW50ZXJjZXB0b3IgaW1wbGVtZW50cyBIdHRwSW50ZXJjZXB0b3Ige1xyXG4gIGNvbnN0cnVjdG9yKEBJbmplY3QoUEJfQ09ORklHKSBwcml2YXRlIHVzZXJDb25maWc6IElGb3JSb290Q29uZiwgcHJpdmF0ZSB1c2VySW50ZXJmYWNlOiBQYlVzZXJJbnRlcmZhY2VTZXJ2aWNlKSB7fVxyXG5cclxuICBpbnRlcmNlcHQocmVxdWVzdDogSHR0cFJlcXVlc3Q8dW5rbm93bj4sIG5leHQ6IEh0dHBIYW5kbGVyKTogT2JzZXJ2YWJsZTxIdHRwRXZlbnQ8dW5rbm93bj4+IHtcclxuICAgIGlmIChyZXF1ZXN0LnVybC5zdGFydHNXaXRoKCdodHRwczovL25nYi1hcGkud2xvY2FsaG9zdC5vcmcnKSkge1xyXG4gICAgICBjb25zdCBub3RpZnkgPSB0aGlzLnVzZXJJbnRlcmZhY2Uubm90aWZ5KCdMb2FkaW5nLCBwbGVhc2Ugd2FpdCAuLi4nLCBudWxsLCBudWxsKTtcclxuICAgICAgY29uc3QgeyB4QXBpS2V5IH0gPSB7IC4uLlBCX0RFRkFVTFRfQ09ORklHLCAuLi50aGlzLnVzZXJDb25maWcgfTtcclxuICAgICAgcmV0dXJuIG5leHRcclxuICAgICAgICAuaGFuZGxlKFxyXG4gICAgICAgICAgcmVxdWVzdC5jbG9uZSh7XHJcbiAgICAgICAgICAgIHNldEhlYWRlcnM6IHtcclxuICAgICAgICAgICAgICAnQ29udGVudC1UeXBlJzogJ2FwcGxpY2F0aW9uL2pzb24nLFxyXG4gICAgICAgICAgICAgICdYLUFwaS1LZXknOiB4QXBpS2V5XHJcbiAgICAgICAgICAgIH0sXHJcbiAgICAgICAgICAgIHJlc3BvbnNlVHlwZTogJ2pzb24nXHJcbiAgICAgICAgICB9KVxyXG4gICAgICAgIClcclxuICAgICAgICAucGlwZShcclxuICAgICAgICAgIHRhcCgocmVzOiBIdHRwUmVzcG9uc2U8YW55PikgPT4ge1xyXG4gICAgICAgICAgICBpZiAocmVzLnR5cGUgPT09IEh0dHBFdmVudFR5cGUuUmVzcG9uc2UpIHtcclxuICAgICAgICAgICAgICBub3RpZnkuZGlzbWlzcygpO1xyXG4gICAgICAgICAgICB9XHJcbiAgICAgICAgICB9KVxyXG4gICAgICAgICk7XHJcbiAgICB9IGVsc2Uge1xyXG4gICAgICByZXR1cm4gbmV4dC5oYW5kbGUocmVxdWVzdCk7XHJcbiAgICB9XHJcbiAgfVxyXG59XHJcbiJdfQ==
|
|
@@ -1,13 +1,13 @@
|
|
|
1
|
-
/*
|
|
2
|
-
* Copyright (c) 2024 Pobuca.
|
|
3
|
-
* All rights reserved.
|
|
4
|
-
*/
|
|
5
|
-
/**
|
|
6
|
-
* Template Storage/Cache keys.
|
|
7
|
-
*/
|
|
8
|
-
export var ETemplatesStorage;
|
|
9
|
-
(function (ETemplatesStorage) {
|
|
10
|
-
ETemplatesStorage["LATEST_USED"] = "NGB_LATEST_USED_TEMPLATES";
|
|
11
|
-
ETemplatesStorage["STORAGE"] = "NGB_TEMP_TEMPLATES_STORAGE";
|
|
12
|
-
})(ETemplatesStorage || (ETemplatesStorage = {}));
|
|
13
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"interfaces.js","sourceRoot":"","sources":["../../../../../projects/pb-email-builder/src/lib/interfaces/interfaces.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAudH;;GAEG;AACH,MAAM,CAAN,IAAY,iBAGX;AAHD,WAAY,iBAAiB;IAC3B,8DAAyC,CAAA;IACzC,2DAAsC,CAAA;AACxC,CAAC,EAHW,iBAAiB,KAAjB,iBAAiB,QAG5B","sourcesContent":["/*\n * Copyright (c) 2024 Pobuca.\n * All rights reserved.\n */\n\nimport { TBlocks } from '../classes/Elements';\n\n/**\n * Main builder configuration Interface. See also {@link PbEmailBuilderModule#withConfig}.\n */\nexport interface IForRootConf {\n  /**\n   *  Either an [Extended or Commercial License]{@link} key if any, otherwise leave it empty.\n   *  @default t7HdQfZjGp6R96fOV4P8v18ggf6LLTQZ1puUI2tz\n   */\n  xApiKey?: string;\n\n  /**\n   * @deprecated Rewrite PbUserRestApiService in providers instead\n   * @ignore\n   */\n  uploadImagePath?: string;\n  /**\n   * @deprecated Rewrite PbUserRestApiService in providers instead\n   * @ignore\n   */\n  uploadImageName?: string;\n  /**\n   * @deprecated Rewrite PbUserRestApiService in providers instead\n   * @ignore\n   */\n  csrf?: { name: string; token: string };\n  /**\n   * Custom convertor path\n   */\n  apiPath?: string;\n\n  /**\n   * Show download button on builder top bar.\n   * @default true\n   */\n  useDownloadButton?: boolean;\n  /**\n   * Show preview button  on builder top bar.\n   * @default true\n   */\n  usePreviewButton?: boolean;\n  /**\n   * Show save button on builder top bar.\n   * @default true\n   */\n  useSaveButton?: boolean;\n  /**\n   * Show a button that opens template gallery in case email body is empty.\n   * @default true\n   */\n  templateListIfEmpty?: boolean;\n}\n\n/**\n * Convertor errors response interface, id any.\n */\nexport interface IMjmlServerResponseErrors {\n  /**\n   * Error message.\n   */\n  message: string;\n  /**\n   * MJML TagName error occurred.\n   */\n  tagName: string;\n}\n\n/**\n * Convertor response interface.\n */\nexport interface IMjmlServerResponse {\n  /**\n   * Converted HTML Template based on {@link IPBEmail}.\n   */\n  html: string;\n  /**\n   * Converted MJML Template based on {@link IPBEmail}.\n   */\n  mjml: string;\n  /**\n   * Error representation if any. See {@link IMjmlServerResponseErrors}.\n   */\n  errors: IMjmlServerResponseErrors[];\n}\n\n/**\n * Builder structure types.\n * @default cols_1\n */\nexport type TStructureTypes = 'cols_1' | 'cols_2' | 'cols_3' | 'cols_4' | 'cols_12' | 'cols_21';\n/**\n * Builder direction types.\n * @default ltr\n */\nexport type TDirection = 'ltr' | 'rtl';\n/**\n * Builder units types.\n * @default px\n */\nexport type TUnits = '%' | 'px' | 'cover' | 'contain';\n/**\n * Builder align types.\n * @default left\n */\nexport type TAlign = 'left' | 'center' | 'right';\n/**\n * Builder vertical align types.\n * @default middle\n */\nexport type TVerticalAlign = 'top' | 'middle' | 'bottom';\n/**\n * Builder Line-height types.\n * @default none\n */\nexport type TLineHeight = '%' | 'px' | 'none';\n/**\n * Builder Link target.\n * @default _blank\n */\nexport type TLinkTarget = '_blank' | '_self' | '_parent' | '_top';\n/**\n * Builder font style types.\n * @default normal\n */\nexport type TFontStyle = 'italic' | 'normal' | 'oblique';\n/**\n * Builder font weight types.\n * @default inherit\n */\nexport type TFontWeight = number | 'bold' | 'bolder' | 'inherit' | 'initial' | 'light' | 'normal';\n/**\n * Builder background-repeat types.\n * @default no-repeat\n */\nexport type TBackgroundRepeat = 'no-repeat' | 'repeat' | 'repeat-x' | 'repeat-y';\n\n/**\n * Builder border styles interface.\n */\nexport interface IBorder {\n  /* Border color */\n  color?: string;\n  /**\n   * Border style.\n   * @default solid\n   */\n  style?: 'solid' | 'dotted' | 'dashed' | 'double' | 'groove';\n  /**\n   * Border width\n   */\n  width?: number;\n  /**\n   * Border radius\n   */\n  radius?: number;\n}\n\n/**\n * Builder padding styles interface.\n */\nexport interface IPadding {\n  top?: number;\n  right?: number;\n  bottom?: number;\n  left?: number;\n}\n\n/**\n * Builder margin styles interface.\n */\nexport interface IMargin {\n  top?: number;\n  bottom?: number;\n}\n\n/**\n * Builder Width and Height styles interface.\n */\nexport interface IWidthHeight {\n  value: number;\n  /**\n   * Width and Height unit type.\n   * @default px\n   */\n  unit: TUnits;\n  // Either full width or full height styles.\n  auto?: boolean;\n  // Units to be shown as options.\n  units?: TUnits[];\n}\n\n/**\n * Builder background styles interface.\n */\nexport interface IBackground {\n  color?: string;\n  url?: string;\n  repeat?: TBackgroundRepeat;\n  size?: IWidthHeight;\n}\n\n/**\n * Builder font styles interface.\n */\nexport interface IFont {\n  family?: string;\n  fallback?: string;\n  size?: number;\n  style?: TFontStyle;\n  weight?: TFontWeight;\n}\n\nexport type IFontFamily = Set<string>;\n\n/**\n * Builder line-height styles interface.\n */\nexport interface ILineHeight {\n  value?: number;\n  unit?: TLineHeight;\n}\n\n/**\n * Builder link styles interface.\n */\nexport interface ILink {\n  href: string;\n  target: TLinkTarget;\n}\n\n/**\n * Builder structure columns' styles interface.\n */\nexport interface IStructureColumnOptions {\n  background?: IBackground;\n  border?: IBorder;\n  verticalAlign?: TVerticalAlign;\n}\n\n/**\n * Builder structure styles interface.\n */\nexport interface IStructureOptions {\n  border?: IBorder;\n  background?: IBackground;\n  padding?: IPadding;\n  margin?: IMargin;\n  /**\n   * Disable responsive for entire structure\n   */\n  disableResponsive?: boolean;\n  /**\n   * Mame section full width\n   */\n  fullWidth?: boolean;\n  /**\n   * Mind the GAPS! Gaps between structure's columns.\n   */\n  gaps?: [number, number];\n  columnsWidth?: number[];\n  columns?: IStructureColumnOptions[];\n}\n\n/**\n * Builder structure interface.\n */\nexport interface IStructure {\n  readonly type: TStructureTypes;\n  // unique IDs for unique class attribute\n  readonly id: number;\n  /**\n   * If it's module, it can't be edited within email body.\n   * @default false\n   */\n  isModule?: boolean;\n  options: IStructureOptions;\n  // Structure columns.\n  elements: TBlocks[][];\n  readonly columns: number;\n}\n\n/**\n * Builder block state interface. If `disabled: true` it can't be dragged from left sidebar.\n */\nexport interface IBlockState {\n  /**\n   * @default false\n   */\n  disabled: boolean;\n  /**\n   * Show a message in case it's disabled.\n   */\n  message: string;\n}\n\n/**\n * Builder {@link TextElementComponent} options interface.\n */\nexport interface ITextBlockOptions {\n  color?: string;\n  font?: IFont;\n  lineHeight?: ILineHeight;\n  padding?: IPadding;\n}\n\n/**\n * Builder {@link ImageComponent} options interface.\n */\nexport interface IImageBLockOptions {\n  border?: IBorder;\n  width?: IWidthHeight;\n  height?: IWidthHeight;\n  link?: ILink;\n  align?: TAlign;\n  title?: string;\n  padding?: IPadding;\n}\n\n/**\n * Builder {@link ButtonComponent} options interface.\n */\nexport interface IButtonBlockOptions {\n  backgroundColor?: string;\n  border?: IBorder;\n  color?: string;\n  font?: IFont;\n  align?: TAlign;\n  fullWidth?: boolean;\n  lineHeight?: ILineHeight;\n  link?: ILink;\n  innerPadding?: IPadding;\n  padding?: IPadding;\n}\n\n/**\n * Builder {@link DividerComponent} options interface.\n */\nexport interface IDividerBlockOptions {\n  border?: IBorder;\n  padding?: IPadding;\n}\n\n/**\n * Builder {@link SpacerComponent} options interface.\n */\nexport interface ISpacerBlockOptions {\n  height?: IWidthHeight;\n  width?: IWidthHeight;\n}\n\n/**\n * Builder {@link SocialComponent} options interface.\n */\nexport interface ISocialBlockOptions {\n  align?: TAlign;\n  mode?: 'vertical' | 'horizontal';\n  font?: IFont;\n  iconSize?: ILineHeight;\n  lineHeight?: ILineHeight;\n  color?: string;\n  innerPadding?: IPadding;\n  padding?: IPadding;\n}\n\n/**\n * Builder {@link SocialComponent} network options interface.\n */\nexport interface ISocialNetwork {\n  href: string;\n  // target?: string;\n  label?: string;\n  name:\n    | 'github'\n    | 'instagram'\n    | 'web'\n    | 'snapchat'\n    | 'youtube'\n    | 'vimeo'\n    | 'medium'\n    | 'soundcloud'\n    | 'dribbble'\n    | 'facebook'\n    | 'twitter'\n    | 'pinterest'\n    | 'linkedin'\n    | 'tumblr'\n    | 'xing'\n    | 'tiktok';\n  padding?: IPadding;\n}\n\n/**\n * Builder {@link IPBEmail} general options interface.\n */\nexport interface IGeneralOptions {\n  width?: IWidthHeight;\n  background?: IBackground;\n  padding?: IPadding;\n  direction?: TDirection;\n  name?: string;\n  previewText: string;\n  global?: {\n    fonts?: string[];\n    padding?: IPadding;\n  };\n}\n\n/**\n * Main builder Email Object interface.\n */\nexport interface IPBEmail {\n  general?: IGeneralOptions;\n  structures?: IStructure[];\n}\n\n/**\n * Builder module interface.\n */\nexport interface IUserModule {\n  /**\n   * @deprecated Add name instead\n   * @ignore\n   */\n  thumb?: string;\n  name?: string;\n  module: IStructure;\n}\n\n/**\n * @deprecated use IUserModule instead\n * @internal\n */\n// tslint:disable-next-line: no-empty-interface\nexport interface ICustomModule extends IUserModule {}\n\n/**\n * Builder predefined template interface.\n */\nexport interface IUserTemplate {\n  id?: string;\n  title: string;\n  thumbPath: string;\n  templateData: IPBEmail;\n}\n\n/**\n * @deprecated use IUserTemplate instead\n * @internal\n */\n// tslint:disable-next-line: no-empty-interface\nexport interface ICustomTemplate extends IUserTemplate {}\n\n/**\n * Builder Template Gallery templates interface.\n */\nexport interface IUserTemplateCategory {\n  category: string;\n  templates: IUserTemplate[];\n}\n\n/**\n * Builder IMage Gallery images interface.\n */\nexport interface IUserImageCategory {\n  category: string;\n  images: string[];\n}\n\n/**\n * Template Storage/Cache keys.\n */\nexport enum ETemplatesStorage {\n  LATEST_USED = 'NGB_LATEST_USED_TEMPLATES',\n  STORAGE = 'NGB_TEMP_TEMPLATES_STORAGE'\n}\n"]}
|
|
1
|
+
/*
|
|
2
|
+
* Copyright (c) 2024 Pobuca.
|
|
3
|
+
* All rights reserved.
|
|
4
|
+
*/
|
|
5
|
+
/**
|
|
6
|
+
* Template Storage/Cache keys.
|
|
7
|
+
*/
|
|
8
|
+
export var ETemplatesStorage;
|
|
9
|
+
(function (ETemplatesStorage) {
|
|
10
|
+
ETemplatesStorage["LATEST_USED"] = "NGB_LATEST_USED_TEMPLATES";
|
|
11
|
+
ETemplatesStorage["STORAGE"] = "NGB_TEMP_TEMPLATES_STORAGE";
|
|
12
|
+
})(ETemplatesStorage || (ETemplatesStorage = {}));
|
|
13
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"interfaces.js","sourceRoot":"","sources":["../../../../../projects/pb-email-builder/src/lib/interfaces/interfaces.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAieH;;GAEG;AACH,MAAM,CAAN,IAAY,iBAGX;AAHD,WAAY,iBAAiB;IAC3B,8DAAyC,CAAA;IACzC,2DAAsC,CAAA;AACxC,CAAC,EAHW,iBAAiB,KAAjB,iBAAiB,QAG5B","sourcesContent":["/*\r\n * Copyright (c) 2024 Pobuca.\r\n * All rights reserved.\r\n */\r\n\r\nimport { TBlocks } from '../classes/Elements';\r\n\r\n/**\r\n * Main builder configuration Interface. See also {@link PbEmailBuilderModule#withConfig}.\r\n */\r\nexport interface IForRootConf {\r\n  /**\r\n   *  Either an [Extended or Commercial License]{@link} key if any, otherwise leave it empty.\r\n   *  @default t7HdQfZjGp6R96fOV4P8v18ggf6LLTQZ1puUI2tz\r\n   */\r\n  xApiKey?: string;\r\n\r\n  /**\r\n   * @deprecated Rewrite PbUserRestApiService in providers instead\r\n   * @ignore\r\n   */\r\n  uploadImagePath?: string;\r\n  /**\r\n   * @deprecated Rewrite PbUserRestApiService in providers instead\r\n   * @ignore\r\n   */\r\n  uploadImageName?: string;\r\n  /**\r\n   * @deprecated Rewrite PbUserRestApiService in providers instead\r\n   * @ignore\r\n   */\r\n  csrf?: { name: string; token: string };\r\n  /**\r\n   * Custom convertor path\r\n   */\r\n  apiPath?: string;\r\n\r\n  /**\r\n   * Show download button on builder top bar.\r\n   * @default true\r\n   */\r\n  useDownloadButton?: boolean;\r\n  /**\r\n   * Show preview button  on builder top bar.\r\n   * @default true\r\n   */\r\n  usePreviewButton?: boolean;\r\n  /**\r\n   * Show save button on builder top bar.\r\n   * @default true\r\n   */\r\n  useSaveButton?: boolean;\r\n  /**\r\n   * Show a button that opens template gallery in case email body is empty.\r\n   * @default true\r\n   */\r\n  templateListIfEmpty?: boolean;\r\n}\r\n\r\n/**\r\n * Convertor errors response interface, id any.\r\n */\r\nexport interface IMjmlServerResponseErrors {\r\n  /**\r\n   * Error message.\r\n   */\r\n  message: string;\r\n  /**\r\n   * MJML TagName error occurred.\r\n   */\r\n  tagName: string;\r\n}\r\n\r\n/**\r\n * Convertor response interface.\r\n */\r\nexport interface IMjmlServerResponse {\r\n  /**\r\n   * Converted HTML Template based on {@link IPBEmail}.\r\n   */\r\n  html: string;\r\n  /**\r\n   * Converted MJML Template based on {@link IPBEmail}.\r\n   */\r\n  mjml: string;\r\n  /**\r\n   * Error representation if any. See {@link IMjmlServerResponseErrors}.\r\n   */\r\n  errors: IMjmlServerResponseErrors[];\r\n}\r\n\r\n/**\r\n * Builder structure types.\r\n * @default cols_1\r\n */\r\nexport type TStructureTypes = 'cols_1' | 'cols_2' | 'cols_3' | 'cols_4' | 'cols_12' | 'cols_21';\r\n/**\r\n * Builder direction types.\r\n * @default ltr\r\n */\r\nexport type TDirection = 'ltr' | 'rtl';\r\n/**\r\n * Builder units types.\r\n * @default px\r\n */\r\nexport type TUnits = '%' | 'px' | 'cover' | 'contain';\r\n/**\r\n * Builder align types.\r\n * @default left\r\n */\r\nexport type TAlign = 'left' | 'center' | 'right';\r\n/**\r\n * Builder vertical align types.\r\n * @default middle\r\n */\r\nexport type TVerticalAlign = 'top' | 'middle' | 'bottom';\r\n/**\r\n * Builder Line-height types.\r\n * @default none\r\n */\r\nexport type TLineHeight = '%' | 'px' | 'none';\r\n/**\r\n * Builder Link target.\r\n * @default _blank\r\n */\r\nexport type TLinkTarget = '_blank' | '_self' | '_parent' | '_top';\r\n/**\r\n * Builder font style types.\r\n * @default normal\r\n */\r\nexport type TFontStyle = 'italic' | 'normal' | 'oblique';\r\n/**\r\n * Builder font weight types.\r\n * @default inherit\r\n */\r\nexport type TFontWeight = number | 'bold' | 'bolder' | 'inherit' | 'initial' | 'light' | 'normal';\r\n/**\r\n * Builder background-repeat types.\r\n * @default no-repeat\r\n */\r\nexport type TBackgroundRepeat = 'no-repeat' | 'repeat' | 'repeat-x' | 'repeat-y';\r\n\r\n/**\r\n * Builder border styles interface.\r\n */\r\nexport interface IBorder {\r\n  /* Border color */\r\n  color?: string;\r\n  /**\r\n   * Border style.\r\n   * @default solid\r\n   */\r\n  style?: 'solid' | 'dotted' | 'dashed' | 'double' | 'groove';\r\n  /**\r\n   * Border width\r\n   */\r\n  width?: number;\r\n  /**\r\n   * Border radius\r\n   */\r\n  radius?: number;\r\n}\r\n\r\n/**\r\n * Builder padding styles interface.\r\n */\r\nexport interface IPadding {\r\n  top?: number;\r\n  right?: number;\r\n  bottom?: number;\r\n  left?: number;\r\n}\r\n\r\n/**\r\n * Builder margin styles interface.\r\n */\r\nexport interface IMargin {\r\n  top?: number;\r\n  bottom?: number;\r\n}\r\n\r\n/**\r\n * Builder Width and Height styles interface.\r\n */\r\nexport interface IWidthHeight {\r\n  value: number;\r\n  /**\r\n   * Width and Height unit type.\r\n   * @default px\r\n   */\r\n  unit: TUnits;\r\n  // Either full width or full height styles.\r\n  auto?: boolean;\r\n  // Units to be shown as options.\r\n  units?: TUnits[];\r\n}\r\n\r\n/**\r\n * Builder background styles interface.\r\n */\r\nexport interface IBackground {\r\n  color?: string;\r\n  url?: string;\r\n  repeat?: TBackgroundRepeat;\r\n  size?: IWidthHeight;\r\n}\r\n\r\n/**\r\n * Builder font styles interface.\r\n */\r\nexport interface IFont {\r\n  family?: string;\r\n  fallback?: string;\r\n  size?: number;\r\n  style?: TFontStyle;\r\n  weight?: TFontWeight;\r\n}\r\n\r\nexport type IFontFamily = Set<string>;\r\n\r\n/**\r\n * Builder line-height styles interface.\r\n */\r\nexport interface ILineHeight {\r\n  value?: number;\r\n  unit?: TLineHeight;\r\n}\r\n\r\n/**\r\n * Builder link styles interface.\r\n */\r\nexport interface ILink {\r\n  href: string;\r\n  target: TLinkTarget;\r\n}\r\n\r\n/**\r\n * Builder structure columns' styles interface.\r\n */\r\nexport interface IStructureColumnOptions {\r\n  background?: IBackground;\r\n  border?: IBorder;\r\n  verticalAlign?: TVerticalAlign;\r\n}\r\n\r\n/**\r\n * Builder structure styles interface.\r\n */\r\nexport interface IStructureOptions {\r\n  border?: IBorder;\r\n  background?: IBackground;\r\n  padding?: IPadding;\r\n  margin?: IMargin;\r\n  /**\r\n   * Disable responsive for entire structure\r\n   */\r\n  disableResponsive?: boolean;\r\n  /**\r\n   * Mame section full width\r\n   */\r\n  fullWidth?: boolean;\r\n  /**\r\n   * Mind the GAPS! Gaps between structure's columns.\r\n   */\r\n  gaps?: [number, number];\r\n  columnsWidth?: number[];\r\n  columns?: IStructureColumnOptions[];\r\n}\r\n\r\n/**\r\n * Builder structure interface.\r\n */\r\nexport interface IStructure {\r\n  readonly type: TStructureTypes;\r\n  // unique IDs for unique class attribute\r\n  readonly id: number;\r\n  /**\r\n   * If it's module, it can't be edited within email body.\r\n   * @default false\r\n   */\r\n  isModule?: boolean;\r\n  options: IStructureOptions;\r\n  // Structure columns.\r\n  elements: TBlocks[][];\r\n  readonly columns: number;\r\n}\r\n\r\n/**\r\n * Builder block state interface. If `disabled: true` it can't be dragged from left sidebar.\r\n */\r\nexport interface IBlockState {\r\n  /**\r\n   * @default false\r\n   */\r\n  disabled: boolean;\r\n  /**\r\n   * Show a message in case it's disabled.\r\n   */\r\n  message: string;\r\n}\r\n\r\n/**\r\n * Builder {@link TextElementComponent} options interface.\r\n */\r\nexport interface ITextBlockOptions {\r\n  color?: string;\r\n  font?: IFont;\r\n  lineHeight?: ILineHeight;\r\n  padding?: IPadding;\r\n}\r\n\r\n/**\r\n * Builder {@link ImageComponent} options interface.\r\n */\r\nexport interface IImageBLockOptions {\r\n  border?: IBorder;\r\n  width?: IWidthHeight;\r\n  height?: IWidthHeight;\r\n  link?: ILink;\r\n  align?: TAlign;\r\n  title?: string;\r\n  padding?: IPadding;\r\n}\r\n\r\n/**\r\n * Builder {@link ButtonComponent} options interface.\r\n */\r\nexport interface IButtonBlockOptions {\r\n  backgroundColor?: string;\r\n  border?: IBorder;\r\n  color?: string;\r\n  font?: IFont;\r\n  align?: TAlign;\r\n  fullWidth?: boolean;\r\n  lineHeight?: ILineHeight;\r\n  link?: ILink;\r\n  innerPadding?: IPadding;\r\n  padding?: IPadding;\r\n}\r\n\r\n/**\r\n * Builder {@link DividerComponent} options interface.\r\n */\r\nexport interface IDividerBlockOptions {\r\n  border?: IBorder;\r\n  padding?: IPadding;\r\n}\r\n\r\n/**\r\n * Builder {@link SpacerComponent} options interface.\r\n */\r\nexport interface ISpacerBlockOptions {\r\n  height?: IWidthHeight;\r\n  width?: IWidthHeight;\r\n}\r\n\r\n/**\r\n * Builder {@link SocialComponent} options interface.\r\n */\r\nexport interface ISocialBlockOptions {\r\n  align?: TAlign;\r\n  mode?: 'vertical' | 'horizontal';\r\n  font?: IFont;\r\n  iconSize?: ILineHeight;\r\n  lineHeight?: ILineHeight;\r\n  color?: string;\r\n  innerPadding?: IPadding;\r\n  padding?: IPadding;\r\n}\r\n\r\n/**\r\n * Builder {@link SocialComponent} network options interface.\r\n */\r\nexport interface ISocialNetwork {\r\n  href: string;\r\n  // target?: string;\r\n  label?: string;\r\n  name:\r\n  | 'github'\r\n  | 'instagram'\r\n  | 'web'\r\n  | 'snapchat'\r\n  | 'youtube'\r\n  | 'vimeo'\r\n  | 'medium'\r\n  | 'soundcloud'\r\n  | 'dribbble'\r\n  | 'facebook'\r\n  | 'twitter'\r\n  | 'pinterest'\r\n  | 'linkedin'\r\n  | 'tumblr'\r\n  | 'xing'\r\n  | 'tiktok';\r\n  padding?: IPadding;\r\n}\r\n\r\n/**\r\n * Builder {@link IPBEmail} general options interface.\r\n */\r\nexport interface IGeneralOptions {\r\n  width?: IWidthHeight;\r\n  background?: IBackground;\r\n  padding?: IPadding;\r\n  direction?: TDirection;\r\n  name?: string;\r\n  previewText: string;\r\n  global?: {\r\n    fonts?: string[];\r\n    padding?: IPadding;\r\n  };\r\n}\r\n\r\n/**\r\n * Main builder Email Object interface.\r\n */\r\nexport interface IPBEmail {\r\n  general?: IGeneralOptions;\r\n  structures?: IStructure[];\r\n  customFonts?: ICustomFont[];\r\n}\r\n\r\n/**\r\n * Custom font interface\r\n */\r\nexport interface ICustomFont {\r\n  family: string;\r\n  url: string;\r\n}\r\n\r\n\r\n/**\r\n * Builder module interface.\r\n */\r\nexport interface IUserModule {\r\n  /**\r\n   * @deprecated Add name instead\r\n   * @ignore\r\n   */\r\n  thumb?: string;\r\n  name?: string;\r\n  module: IStructure;\r\n}\r\n\r\n/**\r\n * @deprecated use IUserModule instead\r\n * @internal\r\n */\r\n// tslint:disable-next-line: no-empty-interface\r\nexport interface ICustomModule extends IUserModule { }\r\n\r\n/**\r\n * Builder predefined template interface.\r\n */\r\nexport interface IUserTemplate {\r\n  id?: string;\r\n  title: string;\r\n  thumbPath: string;\r\n  templateData: IPBEmail;\r\n}\r\n\r\n/**\r\n * @deprecated use IUserTemplate instead\r\n * @internal\r\n */\r\n// tslint:disable-next-line: no-empty-interface\r\nexport interface ICustomTemplate extends IUserTemplate { }\r\n\r\n/**\r\n * Builder Template Gallery templates interface.\r\n */\r\nexport interface IUserTemplateCategory {\r\n  category: string;\r\n  templates: IUserTemplate[];\r\n}\r\n\r\n/**\r\n * Builder IMage Gallery images interface.\r\n */\r\nexport interface IUserImageCategory {\r\n  category: string;\r\n  images: string[];\r\n}\r\n\r\n/**\r\n * Template Storage/Cache keys.\r\n */\r\nexport enum ETemplatesStorage {\r\n  LATEST_USED = 'NGB_LATEST_USED_TEMPLATES',\r\n  STORAGE = 'NGB_TEMP_TEMPLATES_STORAGE'\r\n}\r\n"]}
|