@useinsider/guido 1.0.0-beta.614e7ff → 1.0.0-beta.61cf684
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 +26 -2
- package/dist/@types/generic.d.ts +30 -1
- package/dist/@types/save-as-template.d.ts +11 -0
- package/dist/components/Guido.vue.d.ts +9 -4
- package/dist/components/Guido.vue.js +6 -6
- package/dist/components/Guido.vue2.js +65 -43
- package/dist/components/organisms/email-preview/PreviewContainer.vue.js +19 -0
- package/dist/components/organisms/email-preview/PreviewContainer.vue2.js +19 -0
- package/dist/components/organisms/email-preview/amp/AmpErrorModal.vue.d.ts +4 -0
- package/dist/components/organisms/email-preview/amp/AmpErrorModal.vue.js +22 -0
- package/dist/components/organisms/email-preview/amp/AmpErrorModal.vue2.js +30 -0
- package/dist/components/organisms/email-preview/amp/AmpToggle.vue.d.ts +2 -0
- package/dist/components/organisms/email-preview/amp/AmpToggle.vue.js +19 -0
- package/dist/components/organisms/email-preview/amp/AmpToggle.vue2.js +29 -0
- package/dist/components/organisms/email-preview/desktop-preview/DesktopPreview.vue.d.ts +2 -0
- package/dist/components/organisms/email-preview/desktop-preview/DesktopPreview.vue.js +22 -0
- package/dist/components/organisms/email-preview/desktop-preview/DesktopPreview.vue2.js +31 -0
- package/dist/components/organisms/email-preview/desktop-preview/EmailHeaderInfo.vue.d.ts +2 -0
- package/dist/components/organisms/email-preview/desktop-preview/EmailHeaderInfo.vue.js +17 -0
- package/dist/components/organisms/email-preview/desktop-preview/EmailHeaderInfo.vue2.js +20 -0
- package/dist/components/organisms/email-preview/desktop-preview/EmailSizeIndicator.vue.d.ts +2 -0
- package/dist/components/organisms/email-preview/desktop-preview/EmailSizeIndicator.vue.js +18 -0
- package/dist/components/organisms/email-preview/desktop-preview/EmailSizeIndicator.vue2.js +25 -0
- package/dist/components/organisms/email-preview/mobile-preview/ContentView.vue.d.ts +4 -0
- package/dist/components/organisms/{design-preview/EmailView.vue.js → email-preview/mobile-preview/ContentView.vue.js} +7 -7
- package/dist/components/organisms/email-preview/mobile-preview/ContentView.vue2.js +23 -0
- package/dist/components/organisms/email-preview/mobile-preview/InboxView.vue.d.ts +4 -0
- package/dist/components/organisms/email-preview/mobile-preview/InboxView.vue.js +20 -0
- package/dist/components/organisms/email-preview/mobile-preview/InboxView.vue2.js +21 -0
- package/dist/components/organisms/email-preview/mobile-preview/MobilePreview.vue.d.ts +2 -0
- package/dist/components/organisms/email-preview/mobile-preview/MobilePreview.vue.js +17 -0
- package/dist/components/organisms/email-preview/mobile-preview/MobilePreview.vue2.js +22 -0
- package/dist/components/organisms/header/MiddleSlot.vue.js +7 -7
- package/dist/components/organisms/header/MiddleSlot.vue2.js +16 -20
- package/dist/components/organisms/header/RightSlot.vue.js +9 -8
- package/dist/components/organisms/header/RightSlot.vue2.js +28 -22
- package/dist/components/organisms/header/ViewOptions.vue.js +4 -4
- package/dist/components/organisms/header/ViewOptions.vue2.js +30 -10
- package/dist/components/organisms/header/version-history/ViewOptions.vue.js +3 -3
- package/dist/components/organisms/header/version-history/ViewOptions.vue2.js +34 -16
- package/dist/components/organisms/save-as-template/SaveAsTemplateDrawer.vue.d.ts +2 -0
- package/dist/components/organisms/save-as-template/SaveAsTemplateDrawer.vue.js +20 -0
- package/dist/components/organisms/save-as-template/SaveAsTemplateDrawer.vue2.js +63 -0
- package/dist/components/wrappers/WpDrawer.vue.d.ts +63 -0
- package/dist/components/wrappers/WpDrawer.vue.js +25 -0
- package/dist/components/wrappers/WpDrawer.vue2.js +23 -0
- package/dist/components/wrappers/WpModal.vue.d.ts +65 -0
- package/dist/components/wrappers/WpModal.vue.js +27 -0
- package/dist/components/wrappers/WpModal.vue2.js +22 -0
- package/dist/composables/useActionsApi.d.ts +3 -2
- package/dist/composables/useActionsApi.js +54 -24
- package/dist/composables/useCodeEditorApi.d.ts +4 -0
- package/dist/composables/useCodeEditorApi.js +11 -0
- package/dist/composables/useConfig.d.ts +4 -0
- package/dist/composables/useConfig.js +7 -0
- package/dist/composables/useHtmlCompiler.js +9 -8
- package/dist/composables/usePartner.d.ts +1 -1
- package/dist/composables/usePartner.js +9 -14
- package/dist/composables/usePreviewMode.d.ts +5 -0
- package/dist/composables/usePreviewMode.js +31 -0
- package/dist/composables/useResponsivePreview.d.ts +5 -0
- package/dist/composables/useResponsivePreview.js +86 -0
- package/dist/composables/useStripo.js +25 -15
- package/dist/composables/useToaster.d.ts +1 -1
- package/dist/composables/useToaster.js +11 -11
- package/dist/composables/useTranslations.js +3 -2
- package/dist/composables/useValidation.d.ts +56 -0
- package/dist/composables/useValidation.js +19 -0
- package/dist/composables/validators/saveAsTemplate.d.ts +31 -0
- package/dist/composables/validators/saveAsTemplate.js +24 -0
- package/dist/enums/defaults.d.ts +4 -1
- package/dist/enums/defaults.js +21 -6
- package/dist/enums/preview.d.ts +13 -0
- package/dist/enums/preview.js +23 -0
- package/dist/extensions/DynamicContent/dynamic-content.js +13 -15
- package/dist/guido.css +1 -1
- package/dist/mock/api/template-library.d.ts +2 -0
- package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/Extension.js +2 -2
- package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/ExtensionBuilder.js +2 -2
- package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/blocks/Block.js +2 -2
- package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/blocks/BlockRenderer.js +2 -2
- package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/blocks/BlocksPanel.js +2 -2
- package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/blocks/ContextAction.js +2 -2
- package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/constants/AiAssistantValueType.js +2 -2
- package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/constants/BlockCompositionType.js +2 -2
- package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/constants/BlockType.js +2 -2
- package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/constants/BuiltInControlTypes.js +2 -2
- package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/constants/ContextActionType.js +2 -2
- package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/constants/EditorStatePropertyType.js +2 -2
- package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/constants/PanelPosition.js +2 -2
- package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/constants/PreviewDeviceMode.js +2 -2
- package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/constants/SettingsTab.js +2 -2
- package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/constants/UIElementType.js +2 -2
- package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/controls/BackgroundColorBuiltInControl.js +4 -4
- package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/controls/BackgroundImageBuiltInControl.js +4 -4
- package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/controls/BlockPaddingsBuiltInControl.js +4 -4
- package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/controls/BuiltInControl.js +2 -2
- package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/controls/ButtonBorderBuiltInControl.js +4 -4
- package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/controls/ButtonColorBuiltInControl.js +4 -4
- package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/controls/ButtonFontColorBuiltInControl.js +4 -4
- package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/controls/ButtonInternalIndentsBuiltInControl.js +4 -4
- package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/controls/ButtonTextBuiltInControl.js +4 -4
- package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/controls/Control.js +2 -2
- package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/controls/FontFamilyBuiltInControl.js +4 -4
- package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/controls/LinkColorBuiltInControl.js +4 -4
- package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/controls/SettingsPanelRegistry.js +2 -2
- package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/controls/SettingsPanelTab.js +2 -2
- package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/controls/StructureBorderBuiltInControl.js +4 -4
- package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/controls/StructurePaddingsBuiltInControl.js +4 -4
- package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/controls/TextColorBuiltInControl.js +4 -4
- package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/controls/TextLineSpacingBuiltInControl.js +4 -4
- package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/controls/TextSizeBuiltInControl.js +4 -4
- package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/controls/TextStyleBuiltInControl.js +4 -4
- package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/index.js +2 -2
- package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/modifications/ModificationDescription.js +2 -2
- package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/ui-elements/UIElement.js +2 -2
- package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/ui-elements/UIElementTagRegistry.js +2 -2
- package/dist/node_modules/@vueuse/shared/index.js +45 -0
- package/dist/node_modules/lodash-es/_Stack.js +18 -0
- package/dist/node_modules/lodash-es/_Uint8Array.js +5 -0
- package/dist/node_modules/lodash-es/_apply.js +16 -0
- package/dist/node_modules/lodash-es/_arrayLikeKeys.js +19 -0
- package/dist/node_modules/lodash-es/_assignMergeValue.js +8 -0
- package/dist/node_modules/lodash-es/_assignValue.js +10 -0
- package/dist/node_modules/lodash-es/_baseAssignValue.js +12 -0
- package/dist/node_modules/lodash-es/_baseCreate.js +17 -0
- package/dist/node_modules/lodash-es/_baseFor.js +5 -0
- package/dist/node_modules/lodash-es/_baseIsArguments.js +9 -0
- package/dist/node_modules/lodash-es/_baseIsTypedArray.js +12 -0
- package/dist/node_modules/lodash-es/_baseKeysIn.js +15 -0
- package/dist/node_modules/lodash-es/_baseMerge.js +20 -0
- package/dist/node_modules/lodash-es/_baseMergeDeep.js +31 -0
- package/dist/node_modules/lodash-es/_baseRest.js +9 -0
- package/dist/node_modules/lodash-es/_baseSetToString.js +14 -0
- package/dist/node_modules/lodash-es/_baseTimes.js +8 -0
- package/dist/node_modules/lodash-es/_baseUnary.js +8 -0
- package/dist/node_modules/lodash-es/_cloneArrayBuffer.js +8 -0
- package/dist/node_modules/lodash-es/_cloneBuffer.js +9 -0
- package/dist/node_modules/lodash-es/_cloneTypedArray.js +8 -0
- package/dist/node_modules/lodash-es/_copyArray.js +9 -0
- package/dist/node_modules/lodash-es/_copyObject.js +14 -0
- package/dist/node_modules/lodash-es/_createAssigner.js +15 -0
- package/dist/node_modules/lodash-es/_createBaseFor.js +13 -0
- package/dist/node_modules/lodash-es/_defineProperty.js +11 -0
- package/dist/node_modules/lodash-es/_getPrototype.js +5 -0
- package/dist/node_modules/lodash-es/_initCloneObject.js +9 -0
- package/dist/node_modules/lodash-es/_isIndex.js +8 -0
- package/dist/node_modules/lodash-es/_isIterateeCall.js +13 -0
- package/dist/node_modules/lodash-es/_isMasked.js +2 -2
- package/dist/node_modules/lodash-es/_isPrototype.js +8 -0
- package/dist/node_modules/lodash-es/_nativeKeysIn.js +10 -0
- package/dist/node_modules/lodash-es/_nodeUtil.js +11 -0
- package/dist/node_modules/lodash-es/_overArg.js +8 -0
- package/dist/node_modules/lodash-es/_overRest.js +15 -0
- package/dist/node_modules/lodash-es/_safeGet.js +7 -0
- package/dist/node_modules/lodash-es/_setToString.js +6 -0
- package/dist/node_modules/lodash-es/_shortOut.js +16 -0
- package/dist/node_modules/lodash-es/_stackClear.js +7 -0
- package/dist/node_modules/lodash-es/_stackDelete.js +7 -0
- package/dist/node_modules/lodash-es/_stackGet.js +6 -0
- package/dist/node_modules/lodash-es/_stackHas.js +6 -0
- package/dist/node_modules/lodash-es/_stackSet.js +17 -0
- package/dist/node_modules/lodash-es/constant.js +8 -0
- package/dist/node_modules/lodash-es/identity.js +6 -0
- package/dist/node_modules/lodash-es/isArguments.js +10 -0
- package/dist/node_modules/lodash-es/isArray.js +4 -0
- package/dist/node_modules/lodash-es/isArrayLike.js +8 -0
- package/dist/node_modules/lodash-es/isArrayLikeObject.js +8 -0
- package/dist/node_modules/lodash-es/isBuffer.js +6 -0
- package/dist/node_modules/lodash-es/isLength.js +7 -0
- package/dist/node_modules/lodash-es/isObjectLike.js +6 -0
- package/dist/node_modules/lodash-es/isPlainObject.js +16 -0
- package/dist/node_modules/lodash-es/isTypedArray.js +7 -0
- package/dist/node_modules/lodash-es/keysIn.js +9 -0
- package/dist/node_modules/lodash-es/merge.js +8 -0
- package/dist/node_modules/lodash-es/stubFalse.js +6 -0
- package/dist/node_modules/lodash-es/toPlainObject.js +8 -0
- package/dist/node_modules/valibot/dist/index.js +190 -0
- package/dist/node_modules/vue-demi/lib/index.js +7 -0
- package/dist/services/templateLibraryApi.d.ts +7 -0
- package/dist/services/templateLibraryApi.js +86 -0
- package/dist/stores/dynamic-content.d.ts +27 -0
- package/dist/stores/dynamic-content.js +23 -0
- package/dist/stores/editor.d.ts +2 -3
- package/dist/stores/editor.js +4 -5
- package/dist/stores/preview.d.ts +46 -0
- package/dist/stores/preview.js +53 -0
- package/dist/stores/save-as-template.d.ts +73 -0
- package/dist/stores/save-as-template.js +48 -0
- package/dist/utils/arrayUtil.d.ts +1 -0
- package/dist/utils/arrayUtil.js +10 -0
- package/dist/utils/base64.d.ts +1 -0
- package/dist/utils/base64.js +7 -0
- package/dist/utils/genericUtil.d.ts +2 -0
- package/dist/utils/genericUtil.js +7 -0
- package/dist/utils/templatePreparation.d.ts +20 -0
- package/dist/utils/templatePreparation.js +31 -0
- package/dist/utils/tooltipUtils.d.ts +2 -0
- package/dist/utils/tooltipUtils.js +11 -0
- package/package.json +3 -3
- package/dist/components/organisms/design-preview/AmpErrorModal.vue.d.ts +0 -16
- package/dist/components/organisms/design-preview/AmpErrorModal.vue.js +0 -21
- package/dist/components/organisms/design-preview/AmpErrorModal.vue2.js +0 -30
- package/dist/components/organisms/design-preview/DesktopPreview.vue.d.ts +0 -16
- package/dist/components/organisms/design-preview/DesktopPreview.vue.js +0 -22
- package/dist/components/organisms/design-preview/DesktopPreview.vue2.js +0 -43
- package/dist/components/organisms/design-preview/EmailPreview.vue.d.ts +0 -16
- package/dist/components/organisms/design-preview/EmailPreview.vue.js +0 -17
- package/dist/components/organisms/design-preview/EmailPreview.vue2.js +0 -33
- package/dist/components/organisms/design-preview/EmailView.vue.d.ts +0 -18
- package/dist/components/organisms/design-preview/EmailView.vue2.js +0 -24
- package/dist/components/organisms/design-preview/InboxView.vue.d.ts +0 -17
- package/dist/components/organisms/design-preview/InboxView.vue.js +0 -19
- package/dist/components/organisms/design-preview/InboxView.vue2.js +0 -23
- package/dist/components/organisms/design-preview/MobilePreview.vue.d.ts +0 -17
- package/dist/components/organisms/design-preview/MobilePreview.vue.js +0 -17
- package/dist/components/organisms/design-preview/MobilePreview.vue2.js +0 -24
- package/dist/components/organisms/header/AmpToggle.vue.js +0 -17
- package/dist/components/organisms/header/AmpToggle.vue2.js +0 -48
- package/dist/composables/useMobileGmailFit.d.ts +0 -5
- package/dist/composables/useMobileGmailFit.js +0 -69
- package/dist/enums/emailPreview.d.ts +0 -3
- package/dist/enums/emailPreview.js +0 -4
- package/dist/enums/gmailMobilePreview.d.ts +0 -7
- package/dist/enums/gmailMobilePreview.js +0 -17
- /package/dist/components/organisms/{header/AmpToggle.vue.d.ts → email-preview/PreviewContainer.vue.d.ts} +0 -0
package/README.md
CHANGED
|
@@ -57,6 +57,11 @@ export default {
|
|
|
57
57
|
translationsPath: 'window.trans.en',
|
|
58
58
|
htmlCompilerRules: [],
|
|
59
59
|
ignoreDefaultHtmlCompilerRules: false,
|
|
60
|
+
features: {
|
|
61
|
+
dynamicContent: true,
|
|
62
|
+
saveAsTemplate: true,
|
|
63
|
+
versionHistory: true
|
|
64
|
+
}
|
|
60
65
|
},
|
|
61
66
|
dynamicContentModalVisible: false
|
|
62
67
|
};
|
|
@@ -138,8 +143,13 @@ dynamicContent.close();
|
|
|
138
143
|
```typescript
|
|
139
144
|
interface GuidoConfig {
|
|
140
145
|
translationsPath: string;
|
|
141
|
-
htmlCompilerRules
|
|
142
|
-
ignoreDefaultHtmlCompilerRules
|
|
146
|
+
htmlCompilerRules?: CompilerRule[];
|
|
147
|
+
ignoreDefaultHtmlCompilerRules?: boolean;
|
|
148
|
+
features: {
|
|
149
|
+
dynamicContent: boolean;
|
|
150
|
+
saveAsTemplate: boolean;
|
|
151
|
+
versionHistory: boolean;
|
|
152
|
+
};
|
|
143
153
|
}
|
|
144
154
|
```
|
|
145
155
|
|
|
@@ -148,6 +158,10 @@ interface GuidoConfig {
|
|
|
148
158
|
| `translationsPath` | `string` | `'window.trans.en'` | JavaScript path to the translations object |
|
|
149
159
|
| `htmlCompilerRules` | `CompilerRule[]` | `[]` | Additional compiler rules to apply to HTML content. See [HTML Compiler Rules](#-html-compiler-rules) section below |
|
|
150
160
|
| `ignoreDefaultHtmlCompilerRules` | `boolean` | `false` | Skip default compiler rules and only use custom rules. Default rules: `src/config/compiler/htmlCompilerRules.ts` |
|
|
161
|
+
| `features` | `Features` | `{ dynamicContent: true, saveAsTemplate: true, versionHistory: true }` | Feature flags to enable/disable editor functionality |
|
|
162
|
+
| `features.dynamicContent` | `boolean` | `true` | Enable dynamic content insertion feature |
|
|
163
|
+
| `features.saveAsTemplate` | `boolean` | `true` | Enable save as template feature |
|
|
164
|
+
| `features.versionHistory` | `boolean` | `true` | Enable version history feature |
|
|
151
165
|
|
|
152
166
|
```typescript
|
|
153
167
|
interface DynamicContent {
|
|
@@ -255,6 +269,11 @@ Define complex transformation logic with a custom processor function.
|
|
|
255
269
|
```typescript
|
|
256
270
|
const guidoConfig = {
|
|
257
271
|
translationsPath: 'window.trans.en',
|
|
272
|
+
features: {
|
|
273
|
+
dynamicContent: true,
|
|
274
|
+
saveAsTemplate: true,
|
|
275
|
+
versionHistory: false // Disable version history
|
|
276
|
+
},
|
|
258
277
|
htmlCompilerRules: [
|
|
259
278
|
{
|
|
260
279
|
id: 'replace-domain',
|
|
@@ -283,6 +302,11 @@ const guidoConfig = {
|
|
|
283
302
|
```typescript
|
|
284
303
|
const guidoConfig = {
|
|
285
304
|
translationsPath: 'window.trans.en',
|
|
305
|
+
features: {
|
|
306
|
+
dynamicContent: true,
|
|
307
|
+
saveAsTemplate: true,
|
|
308
|
+
versionHistory: true
|
|
309
|
+
},
|
|
286
310
|
ignoreDefaultHtmlCompilerRules: true, // Skip all default rules
|
|
287
311
|
htmlCompilerRules: [
|
|
288
312
|
// Only your custom rules will be applied
|
package/dist/@types/generic.d.ts
CHANGED
|
@@ -1,15 +1,44 @@
|
|
|
1
1
|
import type { CompilerRule } from './html-compiler';
|
|
2
|
+
type Features = {
|
|
3
|
+
dynamicContent?: boolean;
|
|
4
|
+
saveAsTemplate?: boolean;
|
|
5
|
+
versionHistory?: boolean;
|
|
6
|
+
};
|
|
7
|
+
type Partner = {
|
|
8
|
+
partnerName: string;
|
|
9
|
+
productType: number;
|
|
10
|
+
messageType: number;
|
|
11
|
+
};
|
|
2
12
|
export type GuidoConfig = {
|
|
3
13
|
translationsPath: string;
|
|
4
14
|
htmlCompilerRules?: CompilerRule[];
|
|
5
15
|
ignoreDefaultHtmlCompilerRules?: boolean;
|
|
16
|
+
emailHeader: EmailHeader;
|
|
17
|
+
partner?: Partner;
|
|
18
|
+
features?: Features;
|
|
6
19
|
};
|
|
7
20
|
export type DynamicContent = {
|
|
8
21
|
value: string;
|
|
9
22
|
text: string;
|
|
10
23
|
fallback?: string;
|
|
11
24
|
};
|
|
12
|
-
export interface
|
|
25
|
+
export interface EmailHeader {
|
|
13
26
|
senderName: string;
|
|
14
27
|
subject: string;
|
|
15
28
|
}
|
|
29
|
+
export interface TooltipOptions {
|
|
30
|
+
id: string;
|
|
31
|
+
dynamicPosition: boolean;
|
|
32
|
+
staticPosition: 'top center' | 'top left' | 'top right' | 'bottom center' | 'bottom left' | 'bottom right' | 'right center' | 'right top' | 'right bottom' | 'left center' | 'left top' | 'left bottom';
|
|
33
|
+
iconStatus: boolean;
|
|
34
|
+
offset?: {
|
|
35
|
+
x: number;
|
|
36
|
+
y: number;
|
|
37
|
+
};
|
|
38
|
+
preventXss?: boolean;
|
|
39
|
+
}
|
|
40
|
+
export type MergeTag = {
|
|
41
|
+
label: string;
|
|
42
|
+
value: string;
|
|
43
|
+
};
|
|
44
|
+
export {};
|
|
@@ -1,26 +1,31 @@
|
|
|
1
|
-
import type { DynamicContent, GuidoConfig
|
|
1
|
+
import type { DynamicContent, GuidoConfig } from '@@/Types/generic';
|
|
2
2
|
import type { Template } from '@@/Types/stripo';
|
|
3
3
|
type __VLS_Props = {
|
|
4
4
|
templateId: string;
|
|
5
5
|
userId: string;
|
|
6
|
+
messageType?: number;
|
|
6
7
|
partnerName?: string;
|
|
7
|
-
productType?:
|
|
8
|
+
productType?: number;
|
|
8
9
|
username?: string;
|
|
9
10
|
html?: string;
|
|
10
11
|
css?: string;
|
|
12
|
+
preselectedDynamicContentList: DynamicContent[];
|
|
11
13
|
guidoConfig: GuidoConfig;
|
|
12
|
-
emailData?: EmailData;
|
|
13
14
|
};
|
|
14
15
|
declare const _default: import("vue").DefineComponent<__VLS_TypePropsToOption<__VLS_Props>, {
|
|
15
16
|
dynamicContent: {
|
|
16
17
|
insert: (data: DynamicContent) => void;
|
|
17
18
|
close: () => void;
|
|
18
19
|
};
|
|
20
|
+
hasChanges: import("vue").ComputedRef<boolean>;
|
|
19
21
|
}, {}, {}, {}, import("vue/types/v3-component-options.js").ComponentOptionsMixin, import("vue/types/v3-component-options.js").ComponentOptionsMixin, {
|
|
20
22
|
"dynamic-content:open": (detail: DynamicContent | null) => void;
|
|
21
23
|
back: () => void;
|
|
22
24
|
"save:start": () => void;
|
|
23
|
-
"save:complete": (
|
|
25
|
+
"save:complete": (data: {
|
|
26
|
+
template: Omit<Template, "forceRecreate">;
|
|
27
|
+
dynamicContentList: DynamicContent[];
|
|
28
|
+
}) => void;
|
|
24
29
|
}, string, Readonly<import("vue").ExtractPropTypes<__VLS_TypePropsToOption<__VLS_Props>>>, {}>;
|
|
25
30
|
export default _default;
|
|
26
31
|
type __VLS_NonUndefinedable<T> = T extends undefined ? never : T;
|
|
@@ -2,17 +2,17 @@ import o from "./Guido.vue2.js";
|
|
|
2
2
|
/* empty css */
|
|
3
3
|
import t from "../_virtual/_plugin-vue2_normalizer.js";
|
|
4
4
|
var s = function() {
|
|
5
|
-
var i = this,
|
|
6
|
-
return
|
|
7
|
-
}, a = [],
|
|
5
|
+
var i = this, e = i._self._c, r = i._self._setupProxy;
|
|
6
|
+
return e("div", { staticClass: "guido-editor__wrapper" }, [e(r.HeaderWrapper), r.previewStore.isPreviewModeOpen ? e(r.PreviewContainer) : i._e(), e("div", { directives: [{ name: "show", rawName: "v-show", value: !r.previewStore.isPreviewModeOpen, expression: "!previewStore.isPreviewModeOpen" }], staticClass: "guido-editor__container", attrs: { id: "guido-editor" } }), e(r.SaveAsTemplateDrawer)], 1);
|
|
7
|
+
}, a = [], n = /* @__PURE__ */ t(
|
|
8
8
|
o,
|
|
9
9
|
s,
|
|
10
10
|
a,
|
|
11
11
|
!1,
|
|
12
12
|
null,
|
|
13
|
-
"
|
|
13
|
+
"3ae5b820"
|
|
14
14
|
);
|
|
15
|
-
const
|
|
15
|
+
const c = n.exports;
|
|
16
16
|
export {
|
|
17
|
-
|
|
17
|
+
c as default
|
|
18
18
|
};
|
|
@@ -1,43 +1,58 @@
|
|
|
1
|
-
import { defineComponent as
|
|
2
|
-
import { provideGuidoActions as
|
|
3
|
-
import { usePartner as
|
|
4
|
-
import { useStripo as
|
|
5
|
-
import { DefaultUsername as
|
|
6
|
-
import
|
|
7
|
-
import
|
|
8
|
-
import { useStripoApi as
|
|
9
|
-
import {
|
|
10
|
-
|
|
1
|
+
import { defineComponent as G, defineAsyncComponent as P, computed as _, onMounted as I } from "vue";
|
|
2
|
+
import { provideGuidoActions as k } from "../composables/useGuidoActions.js";
|
|
3
|
+
import { usePartner as A } from "../composables/usePartner.js";
|
|
4
|
+
import { useStripo as N } from "../composables/useStripo.js";
|
|
5
|
+
import { DefaultUsername as x, DefaultMessageType as M, DefaultGuidoConfig as W } from "../enums/defaults.js";
|
|
6
|
+
import z from "./organisms/header/HeaderWrapper.vue.js";
|
|
7
|
+
import B from "./organisms/save-as-template/SaveAsTemplateDrawer.vue.js";
|
|
8
|
+
import { useStripoApi as F } from "../services/stripoApi.js";
|
|
9
|
+
import { useDynamicContentStore as H } from "../stores/dynamic-content.js";
|
|
10
|
+
import { useEditorStore as K } from "../stores/editor.js";
|
|
11
|
+
import { usePreviewStore as R } from "../stores/preview.js";
|
|
12
|
+
import U from "../node_modules/lodash-es/merge.js";
|
|
13
|
+
const ne = /* @__PURE__ */ G({
|
|
11
14
|
__name: "Guido",
|
|
12
15
|
props: {
|
|
13
16
|
templateId: null,
|
|
14
17
|
userId: null,
|
|
18
|
+
messageType: null,
|
|
15
19
|
partnerName: null,
|
|
16
20
|
productType: null,
|
|
17
21
|
username: null,
|
|
18
22
|
html: null,
|
|
19
23
|
css: null,
|
|
20
|
-
|
|
21
|
-
|
|
24
|
+
preselectedDynamicContentList: null,
|
|
25
|
+
guidoConfig: null
|
|
22
26
|
},
|
|
23
27
|
emits: ["dynamic-content:open", "back", "save:start", "save:complete"],
|
|
24
|
-
setup(
|
|
25
|
-
const o =
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
28
|
+
setup(b, { expose: L, emit: t }) {
|
|
29
|
+
const o = b, T = P(
|
|
30
|
+
() => import("./organisms/email-preview/PreviewContainer.vue.js")
|
|
31
|
+
), n = H(), a = K(), r = _(() => a.hasChanges), s = o.preselectedDynamicContentList || [], { getPartnerName: m, getProductType: d } = A(), E = R(), {
|
|
32
|
+
templateId: l,
|
|
33
|
+
userId: u,
|
|
34
|
+
guidoConfig: p,
|
|
35
|
+
html: y = "",
|
|
36
|
+
css: g = "",
|
|
37
|
+
partnerName: i = m(),
|
|
38
|
+
productType: c = d(),
|
|
39
|
+
messageType: f = M,
|
|
40
|
+
username: C = x
|
|
34
41
|
} = o;
|
|
35
|
-
window.GuidoConfig = {
|
|
36
|
-
|
|
37
|
-
|
|
42
|
+
window.GuidoConfig = U(W, p), window.GuidoConfig.partner = {
|
|
43
|
+
partnerName: i,
|
|
44
|
+
productType: c,
|
|
45
|
+
messageType: f
|
|
38
46
|
};
|
|
39
|
-
const { initPlugin:
|
|
40
|
-
|
|
47
|
+
const { initPlugin: v } = N({
|
|
48
|
+
emailId: l,
|
|
49
|
+
userId: u,
|
|
50
|
+
username: C,
|
|
51
|
+
partnerName: i,
|
|
52
|
+
productType: c,
|
|
53
|
+
preselectedDynamicContentList: s
|
|
54
|
+
}), { getDefaultTemplate: D } = F();
|
|
55
|
+
k({
|
|
41
56
|
onBack: () => {
|
|
42
57
|
console.debug("guido:back"), t("back");
|
|
43
58
|
},
|
|
@@ -45,39 +60,46 @@ const M = /* @__PURE__ */ w({
|
|
|
45
60
|
console.debug("guido:save:start"), t("save:start");
|
|
46
61
|
},
|
|
47
62
|
onSaveComplete: (e) => {
|
|
48
|
-
console.debug("guido:save:complete",
|
|
63
|
+
console.debug("guido:save:complete", {
|
|
64
|
+
template: e,
|
|
65
|
+
dynamicContentList: n.getSelectedDynamicContentList
|
|
66
|
+
}), t("save:complete", {
|
|
67
|
+
template: e,
|
|
68
|
+
dynamicContentList: n.getSelectedDynamicContentList
|
|
69
|
+
});
|
|
49
70
|
}
|
|
50
71
|
});
|
|
51
|
-
const
|
|
52
|
-
console.debug("dynamic-content:close", e), document.dispatchEvent(new CustomEvent("dynamic-content:close", { detail: e }));
|
|
53
|
-
},
|
|
72
|
+
const S = (e) => {
|
|
73
|
+
console.debug("dynamic-content:close", e), n.setSelectedDynamicContent(e), document.dispatchEvent(new CustomEvent("dynamic-content:close", { detail: e }));
|
|
74
|
+
}, h = () => {
|
|
54
75
|
console.debug("dynamic-content:close", "Without Data"), document.dispatchEvent(new CustomEvent("dynamic-content:close", { detail: { text: "", value: "" } }));
|
|
55
76
|
};
|
|
56
|
-
return
|
|
77
|
+
return I(async () => {
|
|
57
78
|
console.debug("Guido says happy coding 🎉"), console.debug("🚗 Ka-Chow");
|
|
58
79
|
try {
|
|
59
80
|
let e = {
|
|
60
|
-
html:
|
|
61
|
-
css:
|
|
81
|
+
html: y,
|
|
82
|
+
css: g,
|
|
62
83
|
forceRecreate: !0
|
|
63
84
|
// TODO: It should be false for old templates. We will communicate with Stripo
|
|
64
85
|
};
|
|
65
|
-
e.html || (e = await
|
|
86
|
+
e.html || (e = await D()), await v(e), n.selectedDynamicContentList = s;
|
|
66
87
|
} catch (e) {
|
|
67
88
|
console.error("Failed to initialize Stripo editor:", e);
|
|
68
89
|
}
|
|
69
90
|
document.addEventListener("dynamic-content:open", (e) => {
|
|
70
|
-
const
|
|
71
|
-
console.debug("dynamic-content:open",
|
|
91
|
+
const w = e;
|
|
92
|
+
console.debug("dynamic-content:open", w.detail), t("dynamic-content:open", w.detail);
|
|
72
93
|
});
|
|
73
|
-
}),
|
|
94
|
+
}), L({
|
|
74
95
|
dynamicContent: {
|
|
75
|
-
insert:
|
|
76
|
-
close:
|
|
77
|
-
}
|
|
78
|
-
|
|
96
|
+
insert: S,
|
|
97
|
+
close: h
|
|
98
|
+
},
|
|
99
|
+
hasChanges: r
|
|
100
|
+
}), { __sfc: !0, PreviewContainer: T, dynamicContentStore: n, props: o, editorStore: a, hasChanges: r, preselectedDynamicContentList: s, getPartnerName: m, getProductType: d, previewStore: E, templateId: l, userId: u, guidoConfig: p, html: y, css: g, partnerName: i, productType: c, messageType: f, username: C, emit: t, initPlugin: v, getDefaultTemplate: D, insertDynamicContent: S, closeDynamicContent: h, HeaderWrapper: z, SaveAsTemplateDrawer: B };
|
|
79
101
|
}
|
|
80
102
|
});
|
|
81
103
|
export {
|
|
82
|
-
|
|
104
|
+
ne as default
|
|
83
105
|
};
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import i from "./PreviewContainer.vue2.js";
|
|
2
|
+
import o from "../../../_virtual/_plugin-vue2_normalizer.js";
|
|
3
|
+
var t = function() {
|
|
4
|
+
var s = this, e = s._self._c, r = s._self._setupProxy;
|
|
5
|
+
return e("div", { staticClass: "d-f f-d-c h-1 b-c-5 bor-r-2 pb-5" }, [e("div", { staticClass: "f-g-1 d-f p-5 o-a g-4 min-h-600" }, [r.previewStore.isLoading ? [e("div", { staticClass: "d-f a-i-c j-c-c w-1 h-1 f-g-1" }, [e(r.InLoading, { attrs: { "color-class": "i-c-1", size: "32" } })], 1)] : [e(r.DesktopPreview, { staticClass: "f-g-1 min-w-0" }), e(r.MobilePreview, { staticClass: "f-0 min-w-a" })]], 2), r.previewStore.isAMPErrorModalVisible ? e(r.AmpErrorModal, { on: { close: function(l) {
|
|
6
|
+
return r.previewStore.closeErrorModal();
|
|
7
|
+
} } }) : s._e()], 1);
|
|
8
|
+
}, a = [], n = /* @__PURE__ */ o(
|
|
9
|
+
i,
|
|
10
|
+
t,
|
|
11
|
+
a,
|
|
12
|
+
!1,
|
|
13
|
+
null,
|
|
14
|
+
null
|
|
15
|
+
);
|
|
16
|
+
const d = n.exports;
|
|
17
|
+
export {
|
|
18
|
+
d as default
|
|
19
|
+
};
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import { defineComponent as r, onMounted as t } from "vue";
|
|
2
|
+
import { usePreviewMode as i } from "../../../composables/usePreviewMode.js";
|
|
3
|
+
import { usePreviewStore as m } from "../../../stores/preview.js";
|
|
4
|
+
import { InLoading as n } from "@useinsider/design-system-vue";
|
|
5
|
+
import p from "./amp/AmpErrorModal.vue.js";
|
|
6
|
+
import f from "./desktop-preview/DesktopPreview.vue.js";
|
|
7
|
+
import s from "./mobile-preview/MobilePreview.vue.js";
|
|
8
|
+
const l = /* @__PURE__ */ r({
|
|
9
|
+
__name: "PreviewContainer",
|
|
10
|
+
setup(a) {
|
|
11
|
+
const { loadPreviewData: o } = i(), e = m();
|
|
12
|
+
return t(() => {
|
|
13
|
+
o();
|
|
14
|
+
}), { __sfc: !0, loadPreviewData: o, previewStore: e, InLoading: n, AmpErrorModal: p, DesktopPreview: f, MobilePreview: s };
|
|
15
|
+
}
|
|
16
|
+
});
|
|
17
|
+
export {
|
|
18
|
+
l as default
|
|
19
|
+
};
|
|
@@ -0,0 +1,4 @@
|
|
|
1
|
+
declare const _default: import("vue").DefineComponent<{}, {}, {}, {}, {}, import("vue/types/v3-component-options.js").ComponentOptionsMixin, import("vue/types/v3-component-options.js").ComponentOptionsMixin, {
|
|
2
|
+
close: () => void;
|
|
3
|
+
}, string, Readonly<import("vue").ExtractPropTypes<{}>>, {}>;
|
|
4
|
+
export default _default;
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import s from "./AmpErrorModal.vue2.js";
|
|
2
|
+
/* empty css */
|
|
3
|
+
import a from "../../../../_virtual/_plugin-vue2_normalizer.js";
|
|
4
|
+
var n = function() {
|
|
5
|
+
var e = this, r = e._self._c, t = e._self._setupProxy;
|
|
6
|
+
return r(t.WpModal, { attrs: { id: "amp-error-modal", size: "medium", description: t.trans("email-editor.amp-validation-description"), "footer-button-options": t.footerButtonOptions, title: t.trans("email-editor.amp-validation-title") }, on: { close: function(o) {
|
|
7
|
+
return t.emit("close");
|
|
8
|
+
}, "primary-action": t.handleFixInCodeEditor } }, [r("div", { staticClass: "d-f f-d-c" }, [r("div", { staticClass: "mb-3" }, [r("div", { staticClass: "l-s-5 f-s-1 f-w-600 t-c-55 t-t-u" }, [e._v(" " + e._s(t.errorCountText) + " ")])]), r("div", { staticClass: "d-f f-d-c g-13 max-h-21-s o-y-a error-list" }, e._l(t.previewStore.ampErrors, function(o, i) {
|
|
9
|
+
return r(t.InOnPageMessage, { key: i, attrs: { icon: "filled-error-box", size: "medium", type: "alert", text: o } });
|
|
10
|
+
}), 1)])]);
|
|
11
|
+
}, l = [], d = /* @__PURE__ */ a(
|
|
12
|
+
s,
|
|
13
|
+
n,
|
|
14
|
+
l,
|
|
15
|
+
!1,
|
|
16
|
+
null,
|
|
17
|
+
"7a09985c"
|
|
18
|
+
);
|
|
19
|
+
const _ = d.exports;
|
|
20
|
+
export {
|
|
21
|
+
_ as default
|
|
22
|
+
};
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import { defineComponent as p, ref as m, computed as c } from "vue";
|
|
2
|
+
import d from "../../../wrappers/WpModal.vue.js";
|
|
3
|
+
import { useCodeEditorApi as l } from "../../../../composables/useCodeEditorApi.js";
|
|
4
|
+
import { usePreviewMode as u } from "../../../../composables/usePreviewMode.js";
|
|
5
|
+
import { useTranslations as f } from "../../../../composables/useTranslations.js";
|
|
6
|
+
import { usePreviewStore as _ } from "../../../../stores/preview.js";
|
|
7
|
+
import { InOnPageMessage as g } from "@useinsider/design-system-vue";
|
|
8
|
+
const P = /* @__PURE__ */ p({
|
|
9
|
+
__name: "AmpErrorModal",
|
|
10
|
+
emits: ["close"],
|
|
11
|
+
setup(x, { emit: e }) {
|
|
12
|
+
const o = f(), { closePreviewMode: r } = u(), { openCodeEditor: t } = l(), n = _(), s = m({
|
|
13
|
+
cancelOrBackButton: {
|
|
14
|
+
type: "secondary",
|
|
15
|
+
labelText: o("campaign-builder.cancel"),
|
|
16
|
+
styling: "ghost"
|
|
17
|
+
},
|
|
18
|
+
primaryButton: {
|
|
19
|
+
type: "primary",
|
|
20
|
+
labelText: o("email-editor.amp-validation-fix")
|
|
21
|
+
}
|
|
22
|
+
}), i = () => {
|
|
23
|
+
e("close"), r(), t();
|
|
24
|
+
}, a = c(() => `${o("products.errors")}(${n.ampErrors.length})`);
|
|
25
|
+
return { __sfc: !0, emit: e, trans: o, closePreviewMode: r, openCodeEditor: t, previewStore: n, footerButtonOptions: s, handleFixInCodeEditor: i, errorCountText: a, WpModal: d, InOnPageMessage: g };
|
|
26
|
+
}
|
|
27
|
+
});
|
|
28
|
+
export {
|
|
29
|
+
P as default
|
|
30
|
+
};
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
declare const _default: import("vue").DefineComponent<{}, {}, {}, {}, {}, import("vue/types/v3-component-options.js").ComponentOptionsMixin, import("vue/types/v3-component-options.js").ComponentOptionsMixin, {}, string, Readonly<import("vue").ExtractPropTypes<{}>>, {}>;
|
|
2
|
+
export default _default;
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
import o from "./AmpToggle.vue2.js";
|
|
2
|
+
import n from "../../../../_virtual/_plugin-vue2_normalizer.js";
|
|
3
|
+
var s = function() {
|
|
4
|
+
var r = this, t = r._self._c, e = r._self._setupProxy;
|
|
5
|
+
return t("div", [t("div", { staticClass: "d-f a-i-c ml-3" }, [t(e.InSegments, { attrs: { id: "guido__amp-toggle", "segment-list": e.segmentList, selected: e.previewStore.emailFormat }, on: { click: e.handleFormatChange } }), e.previewStore.showAMPErrorButton ? t(e.InButtonV2, { staticClass: "ml-2 d-f a-i-c b-c-11 b-c-h-11 t-c-4 t-c-h-4 i-c-4 bor-w-1 bor-s-s bor-c-11 bor-r-2", attrs: { id: "guido__amp-error-button", "left-icon": "line-error-box", type: "danger", "label-text-status": !1 }, on: { click: function(c) {
|
|
6
|
+
return e.previewStore.openErrorModal();
|
|
7
|
+
} } }) : r._e()], 1)]);
|
|
8
|
+
}, a = [], i = /* @__PURE__ */ n(
|
|
9
|
+
o,
|
|
10
|
+
s,
|
|
11
|
+
a,
|
|
12
|
+
!1,
|
|
13
|
+
null,
|
|
14
|
+
null
|
|
15
|
+
);
|
|
16
|
+
const d = i.exports;
|
|
17
|
+
export {
|
|
18
|
+
d as default
|
|
19
|
+
};
|
|
@@ -0,0 +1,29 @@
|
|
|
1
|
+
import { defineComponent as m, computed as n } from "vue";
|
|
2
|
+
import { useTranslations as r } from "../../../../composables/useTranslations.js";
|
|
3
|
+
import { usePreviewStore as i } from "../../../../stores/preview.js";
|
|
4
|
+
import { InButtonV2 as s, InSegments as l } from "@useinsider/design-system-vue";
|
|
5
|
+
const _ = /* @__PURE__ */ m({
|
|
6
|
+
__name: "AmpToggle",
|
|
7
|
+
setup(p) {
|
|
8
|
+
const t = i(), e = r(), o = n(() => [
|
|
9
|
+
{
|
|
10
|
+
text: e("dynamic-creatives.html"),
|
|
11
|
+
value: "html"
|
|
12
|
+
},
|
|
13
|
+
{
|
|
14
|
+
text: e("email-editor.amp-html"),
|
|
15
|
+
value: "AMP",
|
|
16
|
+
tooltipText: t.hasAMP ? "" : e("email-editor.preview-amp-unavailable-tooltip"),
|
|
17
|
+
position: "bottom",
|
|
18
|
+
align: "center",
|
|
19
|
+
disable: !t.hasAMP
|
|
20
|
+
}
|
|
21
|
+
]);
|
|
22
|
+
return { __sfc: !0, previewStore: t, trans: e, segmentList: o, handleFormatChange: (a) => {
|
|
23
|
+
t.setEmailFormat(a);
|
|
24
|
+
}, InSegments: l, InButtonV2: s };
|
|
25
|
+
}
|
|
26
|
+
});
|
|
27
|
+
export {
|
|
28
|
+
_ as default
|
|
29
|
+
};
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
declare const _default: import("vue").DefineComponent<{}, {}, {}, {}, {}, import("vue/types/v3-component-options.js").ComponentOptionsMixin, import("vue/types/v3-component-options.js").ComponentOptionsMixin, {}, string, Readonly<import("vue").ExtractPropTypes<{}>>, {}>;
|
|
2
|
+
export default _default;
|
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
import o from "./DesktopPreview.vue2.js";
|
|
2
|
+
/* empty css */
|
|
3
|
+
import a from "../../../../_virtual/_plugin-vue2_normalizer.js";
|
|
4
|
+
var s = function() {
|
|
5
|
+
var r = this, t = r._self._c, e = r._self._setupProxy;
|
|
6
|
+
return t("div", { ref: "containerRef", staticStyle: { "min-height": "720px", height: "80vh" } }, [t(e.InContainer, { staticClass: "s-2 m-b-5 desktop-preview-container", attrs: { "full-width-content-status": "", "header-status": "", "border-radius": "bor-r-1", "container-type": "default", "footer-status": !1 }, scopedSlots: r._u([{ key: "headerLeftSlot", fn: function() {
|
|
7
|
+
return [t(e.EmailHeaderInfo)];
|
|
8
|
+
}, proxy: !0 }, { key: "headerRightSlot", fn: function() {
|
|
9
|
+
return [t(e.EmailSizeIndicator)];
|
|
10
|
+
}, proxy: !0 }]) }, [e.isContainerReady ? t("iframe", { staticClass: "email-iframe w-1 bor-w-0", style: { height: e.iframeHeight }, attrs: { sandbox: "allow-same-origin allow-popups allow-forms allow-scripts", srcdoc: e.previewStore.previewHtml } }) : r._e()])], 1);
|
|
11
|
+
}, i = [], n = /* @__PURE__ */ a(
|
|
12
|
+
o,
|
|
13
|
+
s,
|
|
14
|
+
i,
|
|
15
|
+
!1,
|
|
16
|
+
null,
|
|
17
|
+
"2dd60b0c"
|
|
18
|
+
);
|
|
19
|
+
const d = n.exports;
|
|
20
|
+
export {
|
|
21
|
+
d as default
|
|
22
|
+
};
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import { defineComponent as d, ref as r, onMounted as h, onBeforeUnmount as v, nextTick as g } from "vue";
|
|
2
|
+
import { usePreviewStore as _ } from "../../../../stores/preview.js";
|
|
3
|
+
import { InContainer as I } from "@useinsider/design-system-vue";
|
|
4
|
+
import R from "./EmailHeaderInfo.vue.js";
|
|
5
|
+
import C from "./EmailSizeIndicator.vue.js";
|
|
6
|
+
const B = /* @__PURE__ */ d({
|
|
7
|
+
__name: "DesktopPreview",
|
|
8
|
+
setup(H) {
|
|
9
|
+
const t = r(), i = r("400px"), a = r(!1), m = _(), n = () => {
|
|
10
|
+
if (!t.value)
|
|
11
|
+
return;
|
|
12
|
+
const o = t.value.querySelector(".in-container");
|
|
13
|
+
if (!o)
|
|
14
|
+
return;
|
|
15
|
+
const u = o.getBoundingClientRect(), s = o.querySelector(".in-container__header"), f = s ? s.getBoundingClientRect().height : 0, p = u.height - f;
|
|
16
|
+
i.value = `${p}px`;
|
|
17
|
+
};
|
|
18
|
+
let e = null;
|
|
19
|
+
const c = () => {
|
|
20
|
+
n(), t.value && (e = new ResizeObserver(n), e.observe(t.value), g(() => {
|
|
21
|
+
a.value = !0;
|
|
22
|
+
}));
|
|
23
|
+
}, l = () => {
|
|
24
|
+
e == null || e.disconnect();
|
|
25
|
+
};
|
|
26
|
+
return h(c), v(l), { __sfc: !0, containerRef: t, iframeHeight: i, isContainerReady: a, previewStore: m, calculateIframeHeight: n, resizeObserver: e, initIframe: c, cleanIframe: l, InContainer: I, EmailHeaderInfo: R, EmailSizeIndicator: C };
|
|
27
|
+
}
|
|
28
|
+
});
|
|
29
|
+
export {
|
|
30
|
+
B as default
|
|
31
|
+
};
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
declare const _default: import("vue").DefineComponent<{}, {}, {}, {}, {}, import("vue/types/v3-component-options.js").ComponentOptionsMixin, import("vue/types/v3-component-options.js").ComponentOptionsMixin, {}, string, Readonly<import("vue").ExtractPropTypes<{}>>, {}>;
|
|
2
|
+
export default _default;
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
import e from "./EmailHeaderInfo.vue2.js";
|
|
2
|
+
import c from "../../../../_virtual/_plugin-vue2_normalizer.js";
|
|
3
|
+
var r = function() {
|
|
4
|
+
var t = this, s = t._self._c, a = t._self._setupProxy;
|
|
5
|
+
return s("div", { staticClass: "d-f a-i-c j-c-s-b w-1" }, [s("div", { staticClass: "d-f a-i-c" }, [s("div", { staticClass: "b-c-49 bor-r-100 w-5-s h-5-s d-f a-i-c j-c-c" }, [s(a.InIcons, { attrs: { name: "line-menu-profile" } })], 1), s("div", { staticClass: "d-f f-d-c ml-2" }, [s("p", { staticClass: "t-c-53 f-w-600 f-s-1 l-h-1" }, [t._v(" " + t._s(a.senderName) + " ")]), s("p", { staticClass: "t-c-55 f-w-400 f-s-12 l-h-1" }, [t._v(" " + t._s(a.subject) + " ")])])])]);
|
|
6
|
+
}, i = [], n = /* @__PURE__ */ c(
|
|
7
|
+
e,
|
|
8
|
+
r,
|
|
9
|
+
i,
|
|
10
|
+
!1,
|
|
11
|
+
null,
|
|
12
|
+
null
|
|
13
|
+
);
|
|
14
|
+
const o = n.exports;
|
|
15
|
+
export {
|
|
16
|
+
o as default
|
|
17
|
+
};
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
import { defineComponent as m, computed as o } from "vue";
|
|
2
|
+
import { useConfig as a } from "../../../../composables/useConfig.js";
|
|
3
|
+
import { useTranslations as i } from "../../../../composables/useTranslations.js";
|
|
4
|
+
import { InIcons as c } from "@useinsider/design-system-vue";
|
|
5
|
+
const l = /* @__PURE__ */ m({
|
|
6
|
+
__name: "EmailHeaderInfo",
|
|
7
|
+
setup(f) {
|
|
8
|
+
const { config: t } = a(), n = i(), s = o(() => {
|
|
9
|
+
var e;
|
|
10
|
+
return ((e = t.emailHeader) == null ? void 0 : e.senderName) || n("settings.sender-name");
|
|
11
|
+
}), r = o(() => {
|
|
12
|
+
var e;
|
|
13
|
+
return ((e = t.emailHeader) == null ? void 0 : e.subject) || n("email-editor.default-subject");
|
|
14
|
+
});
|
|
15
|
+
return { __sfc: !0, config: t, trans: n, senderName: s, subject: r, InIcons: c };
|
|
16
|
+
}
|
|
17
|
+
});
|
|
18
|
+
export {
|
|
19
|
+
l as default
|
|
20
|
+
};
|
|
@@ -0,0 +1,2 @@
|
|
|
1
|
+
declare const _default: import("vue").DefineComponent<{}, {}, {}, {}, {}, import("vue/types/v3-component-options.js").ComponentOptionsMixin, import("vue/types/v3-component-options.js").ComponentOptionsMixin, {}, string, Readonly<import("vue").ExtractPropTypes<{}>>, {}>;
|
|
2
|
+
export default _default;
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
import i from "./EmailSizeIndicator.vue2.js";
|
|
2
|
+
/* empty css */
|
|
3
|
+
import r from "../../../../_virtual/_plugin-vue2_normalizer.js";
|
|
4
|
+
var o = function() {
|
|
5
|
+
var s = this, e = s._self._c, t = s._self._setupProxy;
|
|
6
|
+
return e("div", { staticClass: "d-f a-i-c j-c-c" }, [e(t.InProgress, { staticClass: "min-w-15-s", attrs: { id: "email-size-progress", "description-status": "", "description-position": "left", description: t.htmlSize, "max-value": t.MAX_EMAIL_SIZE_IN_KB, type: t.progress.type, value: t.progress.value } }), e(t.InTooltip, { staticClass: "d-f ml-1", attrs: { id: "email-size-tooltip", align: "center", position: "bottom", text: t.trans("email-editor.preview-design-size-tooltip") } })], 1);
|
|
7
|
+
}, a = [], n = /* @__PURE__ */ r(
|
|
8
|
+
i,
|
|
9
|
+
o,
|
|
10
|
+
a,
|
|
11
|
+
!1,
|
|
12
|
+
null,
|
|
13
|
+
"c2adc57d"
|
|
14
|
+
);
|
|
15
|
+
const m = n.exports;
|
|
16
|
+
export {
|
|
17
|
+
m as default
|
|
18
|
+
};
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
import { defineComponent as c, ref as n, computed as l, watch as u } from "vue";
|
|
2
|
+
import { useTranslations as p } from "../../../../composables/useTranslations.js";
|
|
3
|
+
import { usePreviewStore as _ } from "../../../../stores/preview.js";
|
|
4
|
+
import { InTooltip as v, InProgress as f } from "@useinsider/design-system-vue";
|
|
5
|
+
const S = /* @__PURE__ */ c({
|
|
6
|
+
__name: "EmailSizeIndicator",
|
|
7
|
+
setup(w) {
|
|
8
|
+
const t = _(), o = 102, e = n(0), s = n({
|
|
9
|
+
type: "success",
|
|
10
|
+
value: 0
|
|
11
|
+
}), a = l(() => `~${e.value} KB`), r = () => {
|
|
12
|
+
const m = new Blob([t.previewHtml]).size;
|
|
13
|
+
e.value = Math.round(m / 1024), s.value = {
|
|
14
|
+
type: e.value < o ? "success" : "warning",
|
|
15
|
+
value: Math.min(e.value, o)
|
|
16
|
+
};
|
|
17
|
+
}, i = p();
|
|
18
|
+
return u(() => t.previewHtml, () => {
|
|
19
|
+
r();
|
|
20
|
+
}, { immediate: !0 }), { __sfc: !0, previewStore: t, MAX_EMAIL_SIZE_IN_KB: o, htmlKB: e, progress: s, htmlSize: a, calculateProgress: r, trans: i, InProgress: f, InTooltip: v };
|
|
21
|
+
}
|
|
22
|
+
});
|
|
23
|
+
export {
|
|
24
|
+
S as default
|
|
25
|
+
};
|