@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.
Files changed (226) hide show
  1. package/README.md +26 -2
  2. package/dist/@types/generic.d.ts +30 -1
  3. package/dist/@types/save-as-template.d.ts +11 -0
  4. package/dist/components/Guido.vue.d.ts +9 -4
  5. package/dist/components/Guido.vue.js +6 -6
  6. package/dist/components/Guido.vue2.js +65 -43
  7. package/dist/components/organisms/email-preview/PreviewContainer.vue.js +19 -0
  8. package/dist/components/organisms/email-preview/PreviewContainer.vue2.js +19 -0
  9. package/dist/components/organisms/email-preview/amp/AmpErrorModal.vue.d.ts +4 -0
  10. package/dist/components/organisms/email-preview/amp/AmpErrorModal.vue.js +22 -0
  11. package/dist/components/organisms/email-preview/amp/AmpErrorModal.vue2.js +30 -0
  12. package/dist/components/organisms/email-preview/amp/AmpToggle.vue.d.ts +2 -0
  13. package/dist/components/organisms/email-preview/amp/AmpToggle.vue.js +19 -0
  14. package/dist/components/organisms/email-preview/amp/AmpToggle.vue2.js +29 -0
  15. package/dist/components/organisms/email-preview/desktop-preview/DesktopPreview.vue.d.ts +2 -0
  16. package/dist/components/organisms/email-preview/desktop-preview/DesktopPreview.vue.js +22 -0
  17. package/dist/components/organisms/email-preview/desktop-preview/DesktopPreview.vue2.js +31 -0
  18. package/dist/components/organisms/email-preview/desktop-preview/EmailHeaderInfo.vue.d.ts +2 -0
  19. package/dist/components/organisms/email-preview/desktop-preview/EmailHeaderInfo.vue.js +17 -0
  20. package/dist/components/organisms/email-preview/desktop-preview/EmailHeaderInfo.vue2.js +20 -0
  21. package/dist/components/organisms/email-preview/desktop-preview/EmailSizeIndicator.vue.d.ts +2 -0
  22. package/dist/components/organisms/email-preview/desktop-preview/EmailSizeIndicator.vue.js +18 -0
  23. package/dist/components/organisms/email-preview/desktop-preview/EmailSizeIndicator.vue2.js +25 -0
  24. package/dist/components/organisms/email-preview/mobile-preview/ContentView.vue.d.ts +4 -0
  25. package/dist/components/organisms/{design-preview/EmailView.vue.js → email-preview/mobile-preview/ContentView.vue.js} +7 -7
  26. package/dist/components/organisms/email-preview/mobile-preview/ContentView.vue2.js +23 -0
  27. package/dist/components/organisms/email-preview/mobile-preview/InboxView.vue.d.ts +4 -0
  28. package/dist/components/organisms/email-preview/mobile-preview/InboxView.vue.js +20 -0
  29. package/dist/components/organisms/email-preview/mobile-preview/InboxView.vue2.js +21 -0
  30. package/dist/components/organisms/email-preview/mobile-preview/MobilePreview.vue.d.ts +2 -0
  31. package/dist/components/organisms/email-preview/mobile-preview/MobilePreview.vue.js +17 -0
  32. package/dist/components/organisms/email-preview/mobile-preview/MobilePreview.vue2.js +22 -0
  33. package/dist/components/organisms/header/MiddleSlot.vue.js +7 -7
  34. package/dist/components/organisms/header/MiddleSlot.vue2.js +16 -20
  35. package/dist/components/organisms/header/RightSlot.vue.js +9 -8
  36. package/dist/components/organisms/header/RightSlot.vue2.js +28 -22
  37. package/dist/components/organisms/header/ViewOptions.vue.js +4 -4
  38. package/dist/components/organisms/header/ViewOptions.vue2.js +30 -10
  39. package/dist/components/organisms/header/version-history/ViewOptions.vue.js +3 -3
  40. package/dist/components/organisms/header/version-history/ViewOptions.vue2.js +34 -16
  41. package/dist/components/organisms/save-as-template/SaveAsTemplateDrawer.vue.d.ts +2 -0
  42. package/dist/components/organisms/save-as-template/SaveAsTemplateDrawer.vue.js +20 -0
  43. package/dist/components/organisms/save-as-template/SaveAsTemplateDrawer.vue2.js +63 -0
  44. package/dist/components/wrappers/WpDrawer.vue.d.ts +63 -0
  45. package/dist/components/wrappers/WpDrawer.vue.js +25 -0
  46. package/dist/components/wrappers/WpDrawer.vue2.js +23 -0
  47. package/dist/components/wrappers/WpModal.vue.d.ts +65 -0
  48. package/dist/components/wrappers/WpModal.vue.js +27 -0
  49. package/dist/components/wrappers/WpModal.vue2.js +22 -0
  50. package/dist/composables/useActionsApi.d.ts +3 -2
  51. package/dist/composables/useActionsApi.js +54 -24
  52. package/dist/composables/useCodeEditorApi.d.ts +4 -0
  53. package/dist/composables/useCodeEditorApi.js +11 -0
  54. package/dist/composables/useConfig.d.ts +4 -0
  55. package/dist/composables/useConfig.js +7 -0
  56. package/dist/composables/useHtmlCompiler.js +9 -8
  57. package/dist/composables/usePartner.d.ts +1 -1
  58. package/dist/composables/usePartner.js +9 -14
  59. package/dist/composables/usePreviewMode.d.ts +5 -0
  60. package/dist/composables/usePreviewMode.js +31 -0
  61. package/dist/composables/useResponsivePreview.d.ts +5 -0
  62. package/dist/composables/useResponsivePreview.js +86 -0
  63. package/dist/composables/useStripo.js +25 -15
  64. package/dist/composables/useToaster.d.ts +1 -1
  65. package/dist/composables/useToaster.js +11 -11
  66. package/dist/composables/useTranslations.js +3 -2
  67. package/dist/composables/useValidation.d.ts +56 -0
  68. package/dist/composables/useValidation.js +19 -0
  69. package/dist/composables/validators/saveAsTemplate.d.ts +31 -0
  70. package/dist/composables/validators/saveAsTemplate.js +24 -0
  71. package/dist/enums/defaults.d.ts +4 -1
  72. package/dist/enums/defaults.js +21 -6
  73. package/dist/enums/preview.d.ts +13 -0
  74. package/dist/enums/preview.js +23 -0
  75. package/dist/extensions/DynamicContent/dynamic-content.js +13 -15
  76. package/dist/guido.css +1 -1
  77. package/dist/mock/api/template-library.d.ts +2 -0
  78. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/Extension.js +2 -2
  79. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/ExtensionBuilder.js +2 -2
  80. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/blocks/Block.js +2 -2
  81. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/blocks/BlockRenderer.js +2 -2
  82. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/blocks/BlocksPanel.js +2 -2
  83. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/blocks/ContextAction.js +2 -2
  84. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/constants/AiAssistantValueType.js +2 -2
  85. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/constants/BlockCompositionType.js +2 -2
  86. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/constants/BlockType.js +2 -2
  87. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/constants/BuiltInControlTypes.js +2 -2
  88. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/constants/ContextActionType.js +2 -2
  89. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/constants/EditorStatePropertyType.js +2 -2
  90. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/constants/PanelPosition.js +2 -2
  91. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/constants/PreviewDeviceMode.js +2 -2
  92. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/constants/SettingsTab.js +2 -2
  93. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/constants/UIElementType.js +2 -2
  94. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/controls/BackgroundColorBuiltInControl.js +4 -4
  95. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/controls/BackgroundImageBuiltInControl.js +4 -4
  96. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/controls/BlockPaddingsBuiltInControl.js +4 -4
  97. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/controls/BuiltInControl.js +2 -2
  98. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/controls/ButtonBorderBuiltInControl.js +4 -4
  99. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/controls/ButtonColorBuiltInControl.js +4 -4
  100. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/controls/ButtonFontColorBuiltInControl.js +4 -4
  101. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/controls/ButtonInternalIndentsBuiltInControl.js +4 -4
  102. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/controls/ButtonTextBuiltInControl.js +4 -4
  103. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/controls/Control.js +2 -2
  104. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/controls/FontFamilyBuiltInControl.js +4 -4
  105. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/controls/LinkColorBuiltInControl.js +4 -4
  106. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/controls/SettingsPanelRegistry.js +2 -2
  107. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/controls/SettingsPanelTab.js +2 -2
  108. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/controls/StructureBorderBuiltInControl.js +4 -4
  109. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/controls/StructurePaddingsBuiltInControl.js +4 -4
  110. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/controls/TextColorBuiltInControl.js +4 -4
  111. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/controls/TextLineSpacingBuiltInControl.js +4 -4
  112. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/controls/TextSizeBuiltInControl.js +4 -4
  113. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/controls/TextStyleBuiltInControl.js +4 -4
  114. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/index.js +2 -2
  115. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/modifications/ModificationDescription.js +2 -2
  116. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/ui-elements/UIElement.js +2 -2
  117. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/ui-elements/UIElementTagRegistry.js +2 -2
  118. package/dist/node_modules/@vueuse/shared/index.js +45 -0
  119. package/dist/node_modules/lodash-es/_Stack.js +18 -0
  120. package/dist/node_modules/lodash-es/_Uint8Array.js +5 -0
  121. package/dist/node_modules/lodash-es/_apply.js +16 -0
  122. package/dist/node_modules/lodash-es/_arrayLikeKeys.js +19 -0
  123. package/dist/node_modules/lodash-es/_assignMergeValue.js +8 -0
  124. package/dist/node_modules/lodash-es/_assignValue.js +10 -0
  125. package/dist/node_modules/lodash-es/_baseAssignValue.js +12 -0
  126. package/dist/node_modules/lodash-es/_baseCreate.js +17 -0
  127. package/dist/node_modules/lodash-es/_baseFor.js +5 -0
  128. package/dist/node_modules/lodash-es/_baseIsArguments.js +9 -0
  129. package/dist/node_modules/lodash-es/_baseIsTypedArray.js +12 -0
  130. package/dist/node_modules/lodash-es/_baseKeysIn.js +15 -0
  131. package/dist/node_modules/lodash-es/_baseMerge.js +20 -0
  132. package/dist/node_modules/lodash-es/_baseMergeDeep.js +31 -0
  133. package/dist/node_modules/lodash-es/_baseRest.js +9 -0
  134. package/dist/node_modules/lodash-es/_baseSetToString.js +14 -0
  135. package/dist/node_modules/lodash-es/_baseTimes.js +8 -0
  136. package/dist/node_modules/lodash-es/_baseUnary.js +8 -0
  137. package/dist/node_modules/lodash-es/_cloneArrayBuffer.js +8 -0
  138. package/dist/node_modules/lodash-es/_cloneBuffer.js +9 -0
  139. package/dist/node_modules/lodash-es/_cloneTypedArray.js +8 -0
  140. package/dist/node_modules/lodash-es/_copyArray.js +9 -0
  141. package/dist/node_modules/lodash-es/_copyObject.js +14 -0
  142. package/dist/node_modules/lodash-es/_createAssigner.js +15 -0
  143. package/dist/node_modules/lodash-es/_createBaseFor.js +13 -0
  144. package/dist/node_modules/lodash-es/_defineProperty.js +11 -0
  145. package/dist/node_modules/lodash-es/_getPrototype.js +5 -0
  146. package/dist/node_modules/lodash-es/_initCloneObject.js +9 -0
  147. package/dist/node_modules/lodash-es/_isIndex.js +8 -0
  148. package/dist/node_modules/lodash-es/_isIterateeCall.js +13 -0
  149. package/dist/node_modules/lodash-es/_isMasked.js +2 -2
  150. package/dist/node_modules/lodash-es/_isPrototype.js +8 -0
  151. package/dist/node_modules/lodash-es/_nativeKeysIn.js +10 -0
  152. package/dist/node_modules/lodash-es/_nodeUtil.js +11 -0
  153. package/dist/node_modules/lodash-es/_overArg.js +8 -0
  154. package/dist/node_modules/lodash-es/_overRest.js +15 -0
  155. package/dist/node_modules/lodash-es/_safeGet.js +7 -0
  156. package/dist/node_modules/lodash-es/_setToString.js +6 -0
  157. package/dist/node_modules/lodash-es/_shortOut.js +16 -0
  158. package/dist/node_modules/lodash-es/_stackClear.js +7 -0
  159. package/dist/node_modules/lodash-es/_stackDelete.js +7 -0
  160. package/dist/node_modules/lodash-es/_stackGet.js +6 -0
  161. package/dist/node_modules/lodash-es/_stackHas.js +6 -0
  162. package/dist/node_modules/lodash-es/_stackSet.js +17 -0
  163. package/dist/node_modules/lodash-es/constant.js +8 -0
  164. package/dist/node_modules/lodash-es/identity.js +6 -0
  165. package/dist/node_modules/lodash-es/isArguments.js +10 -0
  166. package/dist/node_modules/lodash-es/isArray.js +4 -0
  167. package/dist/node_modules/lodash-es/isArrayLike.js +8 -0
  168. package/dist/node_modules/lodash-es/isArrayLikeObject.js +8 -0
  169. package/dist/node_modules/lodash-es/isBuffer.js +6 -0
  170. package/dist/node_modules/lodash-es/isLength.js +7 -0
  171. package/dist/node_modules/lodash-es/isObjectLike.js +6 -0
  172. package/dist/node_modules/lodash-es/isPlainObject.js +16 -0
  173. package/dist/node_modules/lodash-es/isTypedArray.js +7 -0
  174. package/dist/node_modules/lodash-es/keysIn.js +9 -0
  175. package/dist/node_modules/lodash-es/merge.js +8 -0
  176. package/dist/node_modules/lodash-es/stubFalse.js +6 -0
  177. package/dist/node_modules/lodash-es/toPlainObject.js +8 -0
  178. package/dist/node_modules/valibot/dist/index.js +190 -0
  179. package/dist/node_modules/vue-demi/lib/index.js +7 -0
  180. package/dist/services/templateLibraryApi.d.ts +7 -0
  181. package/dist/services/templateLibraryApi.js +86 -0
  182. package/dist/stores/dynamic-content.d.ts +27 -0
  183. package/dist/stores/dynamic-content.js +23 -0
  184. package/dist/stores/editor.d.ts +2 -3
  185. package/dist/stores/editor.js +4 -5
  186. package/dist/stores/preview.d.ts +46 -0
  187. package/dist/stores/preview.js +53 -0
  188. package/dist/stores/save-as-template.d.ts +73 -0
  189. package/dist/stores/save-as-template.js +48 -0
  190. package/dist/utils/arrayUtil.d.ts +1 -0
  191. package/dist/utils/arrayUtil.js +10 -0
  192. package/dist/utils/base64.d.ts +1 -0
  193. package/dist/utils/base64.js +7 -0
  194. package/dist/utils/genericUtil.d.ts +2 -0
  195. package/dist/utils/genericUtil.js +7 -0
  196. package/dist/utils/templatePreparation.d.ts +20 -0
  197. package/dist/utils/templatePreparation.js +31 -0
  198. package/dist/utils/tooltipUtils.d.ts +2 -0
  199. package/dist/utils/tooltipUtils.js +11 -0
  200. package/package.json +3 -3
  201. package/dist/components/organisms/design-preview/AmpErrorModal.vue.d.ts +0 -16
  202. package/dist/components/organisms/design-preview/AmpErrorModal.vue.js +0 -21
  203. package/dist/components/organisms/design-preview/AmpErrorModal.vue2.js +0 -30
  204. package/dist/components/organisms/design-preview/DesktopPreview.vue.d.ts +0 -16
  205. package/dist/components/organisms/design-preview/DesktopPreview.vue.js +0 -22
  206. package/dist/components/organisms/design-preview/DesktopPreview.vue2.js +0 -43
  207. package/dist/components/organisms/design-preview/EmailPreview.vue.d.ts +0 -16
  208. package/dist/components/organisms/design-preview/EmailPreview.vue.js +0 -17
  209. package/dist/components/organisms/design-preview/EmailPreview.vue2.js +0 -33
  210. package/dist/components/organisms/design-preview/EmailView.vue.d.ts +0 -18
  211. package/dist/components/organisms/design-preview/EmailView.vue2.js +0 -24
  212. package/dist/components/organisms/design-preview/InboxView.vue.d.ts +0 -17
  213. package/dist/components/organisms/design-preview/InboxView.vue.js +0 -19
  214. package/dist/components/organisms/design-preview/InboxView.vue2.js +0 -23
  215. package/dist/components/organisms/design-preview/MobilePreview.vue.d.ts +0 -17
  216. package/dist/components/organisms/design-preview/MobilePreview.vue.js +0 -17
  217. package/dist/components/organisms/design-preview/MobilePreview.vue2.js +0 -24
  218. package/dist/components/organisms/header/AmpToggle.vue.js +0 -17
  219. package/dist/components/organisms/header/AmpToggle.vue2.js +0 -48
  220. package/dist/composables/useMobileGmailFit.d.ts +0 -5
  221. package/dist/composables/useMobileGmailFit.js +0 -69
  222. package/dist/enums/emailPreview.d.ts +0 -3
  223. package/dist/enums/emailPreview.js +0 -4
  224. package/dist/enums/gmailMobilePreview.d.ts +0 -7
  225. package/dist/enums/gmailMobilePreview.js +0 -17
  226. /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: CompilerRule[];
142
- ignoreDefaultHtmlCompilerRules: boolean;
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
@@ -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 EmailData {
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 {};
@@ -0,0 +1,11 @@
1
+ export interface MappedCategory {
2
+ value: string;
3
+ text: string;
4
+ }
5
+ export interface Category {
6
+ id: number;
7
+ name: string;
8
+ partnerId: number;
9
+ isStripo: boolean;
10
+ templatesCount: number;
11
+ }
@@ -1,26 +1,31 @@
1
- import type { DynamicContent, GuidoConfig, EmailData } from '@@/Types/generic';
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?: string;
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": (template: Omit<Template, "forceRecreate">) => void;
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, r = i._self._c, e = i._self._setupProxy;
6
- return r("div", { staticClass: "guido-editor__wrapper" }, [r(e.HeaderWrapper), r(e.EmailPreview, { directives: [{ name: "show", rawName: "v-show", value: e.editorStore.isPreviewModeOpen, expression: "editorStore.isPreviewModeOpen" }], attrs: { "email-data": i.emailData, "is-visible": e.editorStore.isPreviewModeOpen } }), r("div", { directives: [{ name: "show", rawName: "v-show", value: !e.editorStore.isPreviewModeOpen, expression: "!editorStore.isPreviewModeOpen" }], staticClass: "guido-editor__container", attrs: { id: "guido-editor" } })], 1);
7
- }, a = [], d = /* @__PURE__ */ t(
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
- "7836f831"
13
+ "3ae5b820"
14
14
  );
15
- const m = d.exports;
15
+ const c = n.exports;
16
16
  export {
17
- m as default
17
+ c as default
18
18
  };
@@ -1,43 +1,58 @@
1
- import { defineComponent as w, onMounted as E } from "vue";
2
- import { provideGuidoActions as S } from "../composables/useGuidoActions.js";
3
- import { usePartner as D } from "../composables/usePartner.js";
4
- import { useStripo as _ } from "../composables/useStripo.js";
5
- import { DefaultUsername as G, DefaultGuidoConfig as I } from "../enums/defaults.js";
6
- import P from "./organisms/design-preview/EmailPreview.vue.js";
7
- import k from "./organisms/header/HeaderWrapper.vue.js";
8
- import { useStripoApi as T } from "../services/stripoApi.js";
9
- import { useEditorStore as N } from "../stores/editor.js";
10
- const M = /* @__PURE__ */ w({
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
- guidoConfig: null,
21
- emailData: null
24
+ preselectedDynamicContentList: null,
25
+ guidoConfig: null
22
26
  },
23
27
  emits: ["dynamic-content:open", "back", "save:start", "save:complete"],
24
- setup(C, { expose: b, emit: t }) {
25
- const o = C, { getPartnerName: n, getProductType: a } = D(), {
26
- templateId: c,
27
- userId: r,
28
- guidoConfig: i,
29
- html: s = "",
30
- css: l = "",
31
- partnerName: d = n(),
32
- productType: u = a(),
33
- username: m = G
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
- ...I,
37
- ...i
42
+ window.GuidoConfig = U(W, p), window.GuidoConfig.partner = {
43
+ partnerName: i,
44
+ productType: c,
45
+ messageType: f
38
46
  };
39
- const { initPlugin: p } = _({ emailId: c, userId: r, username: m, partnerName: d, productType: u }), { getDefaultTemplate: f } = T(), h = N();
40
- S({
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", e), t("save:complete", e);
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 g = (e) => {
52
- console.debug("dynamic-content:close", e), document.dispatchEvent(new CustomEvent("dynamic-content:close", { detail: e }));
53
- }, y = () => {
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 E(async () => {
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: s,
61
- css: l,
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 f()), await p(e);
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 v = e;
71
- console.debug("dynamic-content:open", v.detail), t("dynamic-content:open", v.detail);
91
+ const w = e;
92
+ console.debug("dynamic-content:open", w.detail), t("dynamic-content:open", w.detail);
72
93
  });
73
- }), b({
94
+ }), L({
74
95
  dynamicContent: {
75
- insert: g,
76
- close: y
77
- }
78
- }), { __sfc: !0, props: o, getPartnerName: n, getProductType: a, templateId: c, userId: r, guidoConfig: i, html: s, css: l, partnerName: d, productType: u, username: m, emit: t, initPlugin: p, getDefaultTemplate: f, editorStore: h, insertDynamicContent: g, closeDynamicContent: y, EmailPreview: P, HeaderWrapper: k };
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
- M as default
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
+ };