@useinsider/guido 2.0.0-beta.a716078 → 2.0.0-beta.a7d687e

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 (256) hide show
  1. package/dist/@types/config/schemas.js +53 -39
  2. package/dist/components/Guido.vue.js +3 -3
  3. package/dist/components/Guido.vue2.js +57 -59
  4. package/dist/components/organisms/base/Toaster.vue.js +6 -6
  5. package/dist/components/organisms/email-preview/PreviewContainer.vue.js +3 -3
  6. package/dist/components/organisms/email-preview/amp/AmpErrorModal.vue.js +6 -6
  7. package/dist/components/organisms/email-preview/amp/AmpErrorModal.vue2.js +17 -13
  8. package/dist/components/organisms/email-preview/amp/AmpToggle.vue.js +6 -6
  9. package/dist/components/organisms/email-preview/amp/AmpToggle.vue2.js +14 -12
  10. package/dist/components/organisms/email-preview/desktop-preview/DesktopBrowserHeader.vue.js +18 -0
  11. package/dist/components/organisms/email-preview/desktop-preview/DesktopBrowserHeader.vue2.js +15 -0
  12. package/dist/components/organisms/email-preview/desktop-preview/DesktopPreview.vue.js +10 -14
  13. package/dist/components/organisms/email-preview/desktop-preview/DesktopPreview.vue2.js +14 -22
  14. package/dist/components/organisms/email-preview/desktop-preview/EmailSizeIndicator.vue.js +7 -7
  15. package/dist/components/organisms/email-preview/desktop-preview/EmailSizeIndicator.vue2.js +2 -2
  16. package/dist/components/organisms/email-preview/mobile-preview/ContentView.vue.js +11 -10
  17. package/dist/components/organisms/email-preview/mobile-preview/InboxView.vue.js +12 -10
  18. package/dist/components/organisms/email-preview/mobile-preview/MobilePreview.vue.js +11 -10
  19. package/dist/components/organisms/email-preview/mobile-preview/MobilePreview.vue2.js +15 -14
  20. package/dist/components/organisms/header/EditorActions.vue.js +21 -0
  21. package/dist/components/organisms/header/EditorActions.vue2.js +41 -0
  22. package/dist/components/organisms/header/EditorToolbar.vue.js +18 -0
  23. package/dist/components/organisms/header/EditorToolbar.vue2.js +17 -0
  24. package/dist/components/organisms/header/HeaderWrapper.vue.js +6 -5
  25. package/dist/components/organisms/header/LeftSlot.vue.js +11 -11
  26. package/dist/components/organisms/header/LeftSlot.vue2.js +11 -12
  27. package/dist/components/organisms/header/MiddleSlot.vue.js +7 -7
  28. package/dist/components/organisms/header/MiddleSlot.vue2.js +11 -15
  29. package/dist/components/organisms/header/RightSlot.vue.js +11 -14
  30. package/dist/components/organisms/header/RightSlot.vue2.js +13 -30
  31. package/dist/components/organisms/header/version-history/VersionHistory.vue.js +5 -5
  32. package/dist/components/organisms/onboarding/NewVersionPopup.vue2.js +15 -15
  33. package/dist/components/organisms/unsubscribe/UnsubscribeTypeSelection.vue.js +1 -1
  34. package/dist/components/organisms/unsubscribe/UnsubscribeTypeSelection.vue2.js +20 -19
  35. package/dist/composables/useActionsApi.js +33 -30
  36. package/dist/composables/useConfig.js +29 -27
  37. package/dist/composables/useSave.js +13 -11
  38. package/dist/config/migrator/recommendationMigrator.js +2 -2
  39. package/dist/enums/academy.js +8 -0
  40. package/dist/enums/onboarding.js +1 -2
  41. package/dist/enums/unsubscribe.js +20 -21
  42. package/dist/extensions/Blocks/Items/controls/cardComposition.js +13 -4
  43. package/dist/extensions/Blocks/Recommendation/block.js +40 -6
  44. package/dist/extensions/Blocks/Recommendation/constants/blockIds.js +4 -0
  45. package/dist/extensions/Blocks/Recommendation/constants/controlIds.js +4 -0
  46. package/dist/extensions/Blocks/Recommendation/constants/defaultConfig.js +64 -0
  47. package/dist/extensions/Blocks/Recommendation/constants/layout.js +20 -0
  48. package/dist/extensions/Blocks/Recommendation/constants/selectors.js +19 -0
  49. package/dist/extensions/Blocks/Recommendation/controls/button/index.js +64 -0
  50. package/dist/extensions/Blocks/Recommendation/controls/cardBackground/index.js +80 -0
  51. package/dist/extensions/Blocks/Recommendation/controls/cardComposition/index.js +232 -0
  52. package/dist/extensions/Blocks/Recommendation/controls/image/index.js +19 -0
  53. package/dist/extensions/Blocks/Recommendation/controls/layout/index.js +94 -0
  54. package/dist/extensions/Blocks/Recommendation/controls/main/algorithm.js +110 -0
  55. package/dist/extensions/Blocks/Recommendation/controls/main/currency.js +204 -0
  56. package/dist/extensions/Blocks/Recommendation/controls/main/filters.js +54 -0
  57. package/dist/extensions/Blocks/Recommendation/controls/main/index.js +201 -0
  58. package/dist/extensions/Blocks/Recommendation/controls/main/locale.js +74 -0
  59. package/dist/extensions/Blocks/Recommendation/controls/main/productLayout.js +118 -0
  60. package/dist/extensions/Blocks/Recommendation/controls/main/shuffle.js +71 -0
  61. package/dist/extensions/Blocks/Recommendation/controls/main/utils.js +282 -0
  62. package/dist/extensions/Blocks/Recommendation/controls/name/index.js +46 -0
  63. package/dist/extensions/Blocks/Recommendation/controls/name/textTrim.js +76 -0
  64. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/index.js +44 -0
  65. package/dist/extensions/Blocks/Recommendation/controls/omnibusDiscount/index.js +48 -0
  66. package/dist/extensions/Blocks/Recommendation/controls/omnibusDiscount/textAfter.js +73 -0
  67. package/dist/extensions/Blocks/Recommendation/controls/omnibusDiscount/textBefore.js +73 -0
  68. package/dist/extensions/Blocks/Recommendation/controls/omnibusPrice/index.js +48 -0
  69. package/dist/extensions/Blocks/Recommendation/controls/omnibusPrice/textAfter.js +73 -0
  70. package/dist/extensions/Blocks/Recommendation/controls/omnibusPrice/textBefore.js +73 -0
  71. package/dist/extensions/Blocks/Recommendation/controls/price/index.js +44 -0
  72. package/dist/extensions/Blocks/Recommendation/controls/spacing/index.js +222 -0
  73. package/dist/extensions/Blocks/Recommendation/extension.js +40 -43
  74. package/dist/extensions/Blocks/Recommendation/recommendation.css.js +13 -4
  75. package/dist/extensions/Blocks/Recommendation/services/configService.js +239 -0
  76. package/dist/extensions/Blocks/Recommendation/settingsPanel.js +128 -72
  77. package/dist/extensions/Blocks/Recommendation/store/recommendation.js +40 -35
  78. package/dist/extensions/Blocks/Recommendation/templates/horizontal/elementRenderer.js +174 -0
  79. package/dist/extensions/Blocks/Recommendation/templates/horizontal/template.js +73 -0
  80. package/dist/extensions/Blocks/Recommendation/templates/index.js +12 -0
  81. package/dist/extensions/Blocks/Recommendation/templates/utils.js +121 -0
  82. package/dist/extensions/Blocks/Recommendation/templates/vertical/elementRenderer.js +233 -0
  83. package/dist/extensions/Blocks/Recommendation/templates/vertical/migration.js +251 -0
  84. package/dist/extensions/Blocks/Recommendation/templates/vertical/template.js +69 -0
  85. package/dist/extensions/Blocks/Recommendation/types/nodeConfig.js +6 -0
  86. package/dist/extensions/Blocks/Recommendation/utils/filterUtil.js +9 -9
  87. package/dist/extensions/Blocks/Recommendation/utils/preserveTextStyles.js +36 -0
  88. package/dist/extensions/Blocks/Recommendation/utils/priceFormatter.js +29 -0
  89. package/dist/extensions/Blocks/Recommendation/utils/tagName.js +46 -0
  90. package/dist/extensions/Blocks/Unsubscribe/extension.js +9 -9
  91. package/dist/extensions/Blocks/common-control.js +6 -7
  92. package/dist/extensions/Blocks/controlFactories.js +155 -121
  93. package/dist/guido.css +1 -1
  94. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/esm/index.js +424 -297
  95. package/dist/package.json.js +1 -1
  96. package/dist/services/recommendationApi.js +10 -9
  97. package/dist/src/@types/config/index.d.ts +2 -2
  98. package/dist/src/@types/config/schemas.d.ts +26 -0
  99. package/dist/src/@types/config/types.d.ts +7 -1
  100. package/dist/src/components/organisms/email-preview/desktop-preview/DesktopBrowserHeader.vue.d.ts +2 -0
  101. package/dist/src/components/organisms/header/EditorActions.vue.d.ts +4 -0
  102. package/dist/src/components/organisms/header/EditorToolbar.vue.d.ts +2 -0
  103. package/dist/src/components/organisms/header/RightSlot.vue.d.ts +1 -1
  104. package/dist/src/components/wrappers/WpDrawer.vue.d.ts +1 -1
  105. package/dist/src/composables/useActionsApi.d.ts +1 -0
  106. package/dist/src/composables/useConfig.d.ts +6 -0
  107. package/dist/src/enums/academy.d.ts +12 -0
  108. package/dist/src/enums/onboarding.d.ts +0 -1
  109. package/dist/src/enums/unsubscribe.d.ts +0 -1
  110. package/dist/src/extensions/Blocks/Recommendation/block.d.ts +34 -0
  111. package/dist/src/extensions/Blocks/Recommendation/constants/blockIds.d.ts +13 -0
  112. package/dist/src/extensions/Blocks/Recommendation/{constants.d.ts → constants/controlIds.d.ts} +19 -11
  113. package/dist/src/extensions/Blocks/Recommendation/constants/defaultConfig.d.ts +49 -0
  114. package/dist/src/extensions/Blocks/Recommendation/constants/index.d.ts +13 -0
  115. package/dist/src/extensions/Blocks/Recommendation/constants/layout.d.ts +35 -0
  116. package/dist/src/extensions/Blocks/Recommendation/constants/selectors.d.ts +31 -0
  117. package/dist/src/extensions/Blocks/Recommendation/controls/button/index.d.ts +143 -0
  118. package/dist/src/extensions/Blocks/Recommendation/controls/cardBackground/index.d.ts +31 -0
  119. package/dist/src/extensions/Blocks/Recommendation/controls/cardComposition/index.d.ts +95 -0
  120. package/dist/src/extensions/Blocks/Recommendation/controls/image/index.d.ts +35 -0
  121. package/dist/src/extensions/Blocks/Recommendation/controls/index.d.ts +24 -0
  122. package/dist/src/extensions/Blocks/Recommendation/controls/layout/index.d.ts +36 -0
  123. package/dist/src/extensions/Blocks/Recommendation/controls/main/algorithm.d.ts +29 -0
  124. package/dist/src/extensions/Blocks/Recommendation/controls/main/currency.d.ts +45 -0
  125. package/dist/src/extensions/Blocks/Recommendation/controls/main/filters.d.ts +22 -0
  126. package/dist/src/extensions/Blocks/Recommendation/controls/main/index.d.ts +56 -0
  127. package/dist/src/extensions/Blocks/Recommendation/controls/main/locale.d.ts +24 -0
  128. package/dist/src/extensions/Blocks/Recommendation/controls/main/productLayout.d.ts +42 -0
  129. package/dist/src/extensions/Blocks/Recommendation/controls/main/shuffle.d.ts +23 -0
  130. package/dist/src/extensions/Blocks/Recommendation/controls/main/utils.d.ts +209 -0
  131. package/dist/src/extensions/Blocks/Recommendation/controls/name/index.d.ts +97 -0
  132. package/dist/src/extensions/Blocks/Recommendation/controls/name/textTrim.d.ts +16 -0
  133. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/index.d.ts +95 -0
  134. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusDiscount/index.d.ts +100 -0
  135. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusDiscount/textAfter.d.ts +15 -0
  136. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusDiscount/textBefore.d.ts +15 -0
  137. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusPrice/index.d.ts +100 -0
  138. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusPrice/textAfter.d.ts +15 -0
  139. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusPrice/textBefore.d.ts +15 -0
  140. package/dist/src/extensions/Blocks/Recommendation/controls/price/index.d.ts +95 -0
  141. package/dist/src/extensions/Blocks/Recommendation/controls/spacing/index.d.ts +83 -0
  142. package/dist/src/extensions/Blocks/Recommendation/extension.d.ts +9 -0
  143. package/dist/src/extensions/Blocks/Recommendation/services/configService.d.ts +151 -0
  144. package/dist/src/extensions/Blocks/Recommendation/services/index.d.ts +6 -0
  145. package/dist/src/extensions/Blocks/Recommendation/store/recommendation.d.ts +17 -16
  146. package/dist/src/extensions/Blocks/Recommendation/templates/horizontal/elementRenderer.d.ts +8 -0
  147. package/dist/src/extensions/Blocks/Recommendation/templates/horizontal/migration.d.ts +25 -0
  148. package/dist/src/extensions/Blocks/Recommendation/templates/horizontal/template.d.ts +18 -0
  149. package/dist/src/extensions/Blocks/Recommendation/templates/index.d.ts +39 -0
  150. package/dist/src/extensions/Blocks/Recommendation/templates/utils.d.ts +54 -0
  151. package/dist/src/extensions/Blocks/Recommendation/templates/vertical/elementRenderer.d.ts +20 -0
  152. package/dist/src/extensions/Blocks/Recommendation/templates/{migrationTemplate.d.ts → vertical/migration.d.ts} +11 -4
  153. package/dist/src/extensions/Blocks/Recommendation/templates/vertical/template.d.ts +33 -0
  154. package/dist/src/extensions/Blocks/Recommendation/types/index.d.ts +7 -0
  155. package/dist/src/extensions/Blocks/Recommendation/types/nodeConfig.d.ts +154 -0
  156. package/dist/src/extensions/Blocks/Recommendation/utils/preserveTextStyles.d.ts +19 -0
  157. package/dist/src/extensions/Blocks/Recommendation/utils/priceFormatter.d.ts +33 -0
  158. package/dist/src/extensions/Blocks/Recommendation/utils/stylePreserver.d.ts +113 -0
  159. package/dist/src/extensions/Blocks/Recommendation/utils/tagName.d.ts +77 -0
  160. package/dist/src/extensions/Blocks/common-control.d.ts +1 -1
  161. package/dist/src/stores/config.d.ts +147 -1
  162. package/dist/src/stores/editor.d.ts +21 -0
  163. package/dist/static/assets/desktop/desktop-mockup-center.svg.js +4 -0
  164. package/dist/static/assets/desktop/desktop-mockup-left.svg.js +4 -0
  165. package/dist/static/assets/desktop/desktop-mockup-right.svg.js +4 -0
  166. package/dist/static/assets/mobile/email-mockup.svg.js +4 -0
  167. package/dist/static/assets/mobile/inbox-mockup.svg.js +4 -0
  168. package/dist/static/styles/components/button.css.js +1 -1
  169. package/dist/static/styles/components/wide-panel.css.js +1 -5
  170. package/dist/static/styles/customEditorStyle.css.js +38 -2
  171. package/dist/stores/config.js +7 -0
  172. package/dist/stores/editor.js +1 -0
  173. package/dist/utils/templatePreparation.js +17 -17
  174. package/package.json +3 -3
  175. package/dist/components/organisms/email-preview/desktop-preview/EmailHeaderInfo.vue.js +0 -17
  176. package/dist/components/organisms/email-preview/desktop-preview/EmailHeaderInfo.vue2.js +0 -20
  177. package/dist/extensions/Blocks/Recommendation/cardCompositionControl.js +0 -103
  178. package/dist/extensions/Blocks/Recommendation/constants.js +0 -5
  179. package/dist/extensions/Blocks/Recommendation/control.js +0 -306
  180. package/dist/extensions/Blocks/Recommendation/controls/button/align.js +0 -13
  181. package/dist/extensions/Blocks/Recommendation/controls/button/border.js +0 -13
  182. package/dist/extensions/Blocks/Recommendation/controls/button/borderRadius.js +0 -13
  183. package/dist/extensions/Blocks/Recommendation/controls/button/color.js +0 -13
  184. package/dist/extensions/Blocks/Recommendation/controls/button/fitToContent.js +0 -13
  185. package/dist/extensions/Blocks/Recommendation/controls/button/fontFamily.js +0 -13
  186. package/dist/extensions/Blocks/Recommendation/controls/button/margins.js +0 -13
  187. package/dist/extensions/Blocks/Recommendation/controls/button/paddings.js +0 -13
  188. package/dist/extensions/Blocks/Recommendation/controls/button/text.js +0 -13
  189. package/dist/extensions/Blocks/Recommendation/controls/button/textSize.js +0 -13
  190. package/dist/extensions/Blocks/Recommendation/controls/button/textStyleAndFontColor.js +0 -13
  191. package/dist/extensions/Blocks/Recommendation/controls/image/margins.js +0 -13
  192. package/dist/extensions/Blocks/Recommendation/controls/image/size.js +0 -13
  193. package/dist/extensions/Blocks/Recommendation/controls/name/align.js +0 -13
  194. package/dist/extensions/Blocks/Recommendation/controls/name/background.js +0 -13
  195. package/dist/extensions/Blocks/Recommendation/controls/name/color.js +0 -13
  196. package/dist/extensions/Blocks/Recommendation/controls/name/fontFamily.js +0 -13
  197. package/dist/extensions/Blocks/Recommendation/controls/name/paddings.js +0 -13
  198. package/dist/extensions/Blocks/Recommendation/controls/name/size.js +0 -13
  199. package/dist/extensions/Blocks/Recommendation/controls/name/style.js +0 -13
  200. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/align.js +0 -13
  201. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/background.js +0 -13
  202. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/color.js +0 -13
  203. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/fontFamily.js +0 -13
  204. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/paddings.js +0 -13
  205. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/size.js +0 -13
  206. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/style.js +0 -13
  207. package/dist/extensions/Blocks/Recommendation/controls/price/align.js +0 -13
  208. package/dist/extensions/Blocks/Recommendation/controls/price/background.js +0 -13
  209. package/dist/extensions/Blocks/Recommendation/controls/price/color.js +0 -13
  210. package/dist/extensions/Blocks/Recommendation/controls/price/fontFamily.js +0 -13
  211. package/dist/extensions/Blocks/Recommendation/controls/price/paddings.js +0 -13
  212. package/dist/extensions/Blocks/Recommendation/controls/price/size.js +0 -13
  213. package/dist/extensions/Blocks/Recommendation/controls/price/style.js +0 -13
  214. package/dist/extensions/Blocks/Recommendation/templates/blockTemplate.js +0 -160
  215. package/dist/extensions/Blocks/Recommendation/templates/migrationTemplate.js +0 -152
  216. package/dist/extensions/Blocks/Recommendation/templates/templateUtils.js +0 -180
  217. package/dist/src/extensions/Blocks/Recommendation/cardCompositionControl.d.ts +0 -28
  218. package/dist/src/extensions/Blocks/Recommendation/control.d.ts +0 -35
  219. package/dist/src/extensions/Blocks/Recommendation/controls/button/align.d.ts +0 -5
  220. package/dist/src/extensions/Blocks/Recommendation/controls/button/border.d.ts +0 -5
  221. package/dist/src/extensions/Blocks/Recommendation/controls/button/borderRadius.d.ts +0 -5
  222. package/dist/src/extensions/Blocks/Recommendation/controls/button/color.d.ts +0 -5
  223. package/dist/src/extensions/Blocks/Recommendation/controls/button/fitToContent.d.ts +0 -5
  224. package/dist/src/extensions/Blocks/Recommendation/controls/button/fontFamily.d.ts +0 -5
  225. package/dist/src/extensions/Blocks/Recommendation/controls/button/margins.d.ts +0 -5
  226. package/dist/src/extensions/Blocks/Recommendation/controls/button/paddings.d.ts +0 -5
  227. package/dist/src/extensions/Blocks/Recommendation/controls/button/text.d.ts +0 -5
  228. package/dist/src/extensions/Blocks/Recommendation/controls/button/textSize.d.ts +0 -5
  229. package/dist/src/extensions/Blocks/Recommendation/controls/button/textStyleAndFontColor.d.ts +0 -5
  230. package/dist/src/extensions/Blocks/Recommendation/controls/image/margins.d.ts +0 -5
  231. package/dist/src/extensions/Blocks/Recommendation/controls/image/size.d.ts +0 -5
  232. package/dist/src/extensions/Blocks/Recommendation/controls/name/align.d.ts +0 -5
  233. package/dist/src/extensions/Blocks/Recommendation/controls/name/background.d.ts +0 -5
  234. package/dist/src/extensions/Blocks/Recommendation/controls/name/color.d.ts +0 -5
  235. package/dist/src/extensions/Blocks/Recommendation/controls/name/fontFamily.d.ts +0 -5
  236. package/dist/src/extensions/Blocks/Recommendation/controls/name/paddings.d.ts +0 -5
  237. package/dist/src/extensions/Blocks/Recommendation/controls/name/size.d.ts +0 -5
  238. package/dist/src/extensions/Blocks/Recommendation/controls/name/style.d.ts +0 -5
  239. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/align.d.ts +0 -5
  240. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/background.d.ts +0 -5
  241. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/color.d.ts +0 -5
  242. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/fontFamily.d.ts +0 -5
  243. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/paddings.d.ts +0 -5
  244. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/size.d.ts +0 -5
  245. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/style.d.ts +0 -5
  246. package/dist/src/extensions/Blocks/Recommendation/controls/price/align.d.ts +0 -5
  247. package/dist/src/extensions/Blocks/Recommendation/controls/price/background.d.ts +0 -5
  248. package/dist/src/extensions/Blocks/Recommendation/controls/price/color.d.ts +0 -5
  249. package/dist/src/extensions/Blocks/Recommendation/controls/price/fontFamily.d.ts +0 -5
  250. package/dist/src/extensions/Blocks/Recommendation/controls/price/paddings.d.ts +0 -5
  251. package/dist/src/extensions/Blocks/Recommendation/controls/price/size.d.ts +0 -5
  252. package/dist/src/extensions/Blocks/Recommendation/controls/price/style.d.ts +0 -5
  253. package/dist/src/extensions/Blocks/Recommendation/templates/blockTemplate.d.ts +0 -16
  254. package/dist/src/extensions/Blocks/Recommendation/templates/templateUtils.d.ts +0 -44
  255. package/dist/static/assets/inbox-mockup.svg.js +0 -4
  256. package/dist/static/assets/phone-mockup.svg.js +0 -4
@@ -1,5 +1,5 @@
1
- import { object as o, number as p, optional as e, string as t, pipe as m, picklist as n, boolean as c, array as a, minLength as u, literal as r, custom as b, variant as S } from "../../node_modules/valibot/dist/index.js";
2
- const i = {
1
+ import { object as o, number as b, optional as e, string as t, pipe as u, picklist as n, custom as d, boolean as c, array as a, minLength as p, literal as r, variant as S } from "../../node_modules/valibot/dist/index.js";
2
+ const m = {
3
3
  /** Promotional/marketing emails */
4
4
  PROMOTIONAL: 1,
5
5
  /** Transactional/system emails */
@@ -13,22 +13,22 @@ const i = {
13
13
  UNSUBSCRIBE_PAGES: 97
14
14
  }, h = o({
15
15
  /** Unique identifier for the template being edited */
16
- templateId: m(
16
+ templateId: u(
17
17
  t(),
18
- u(1, "templateId is required")
18
+ p(1, "templateId is required")
19
19
  ),
20
20
  /** Unique identifier for the user editing the template */
21
- userId: m(
21
+ userId: u(
22
22
  t(),
23
- u(1, "userId is required")
23
+ p(1, "userId is required")
24
24
  ),
25
25
  /** Optional variation ID for A/B testing */
26
26
  variationId: e(t())
27
27
  }), k = o({
28
28
  /** Partner/organization name (required) */
29
- name: m(
29
+ name: u(
30
30
  t(),
31
- u(1, "partner.name is required")
31
+ p(1, "partner.name is required")
32
32
  ),
33
33
  /** Product type identifier */
34
34
  productType: e(
@@ -41,8 +41,8 @@ const i = {
41
41
  ),
42
42
  /** Message type (promotional or transactional) */
43
43
  messageType: e(
44
- n([i.PROMOTIONAL, i.TRANSACTIONAL]),
45
- i.PROMOTIONAL
44
+ n([m.PROMOTIONAL, m.TRANSACTIONAL]),
45
+ m.PROMOTIONAL
46
46
  ),
47
47
  /** Display name for the current user */
48
48
  username: e(t(), "Guido User")
@@ -71,29 +71,29 @@ const i = {
71
71
  []
72
72
  ),
73
73
  /** Selected unsubscribe page IDs */
74
- selectedUnsubscribePages: e(a(p()), []),
74
+ selectedUnsubscribePages: e(a(b()), []),
75
75
  /** Force recreate template in Stripo storage (use true when updating externally modified templates) */
76
76
  forceRecreate: e(c(), !1)
77
- }), C = o({
77
+ }), f = o({
78
78
  /** Sender display name */
79
79
  senderName: e(t(), ""),
80
80
  /** Email subject line */
81
81
  subject: e(t(), "")
82
- }), I = o({
82
+ }), C = o({
83
83
  /** Locale for the editor UI */
84
84
  locale: e(t(), "en"),
85
85
  /** Path to translations object */
86
86
  translationsPath: e(t(), "window.trans.en"),
87
87
  /** Migration date for template compatibility */
88
- migrationDate: e(p(), 1759696858),
88
+ migrationDate: e(b(), 1759696858),
89
89
  /** Email header settings */
90
- emailHeader: e(C, { senderName: "", subject: "" })
91
- }), T = o({
90
+ emailHeader: e(f, { senderName: "", subject: "" })
91
+ }), I = o({
92
92
  /** Whether to show the header bar */
93
93
  showHeader: e(c(), !0),
94
94
  /** Custom label for back button (if shown) */
95
95
  backButtonLabel: e(t())
96
- }), A = o({
96
+ }), T = o({
97
97
  /** Enable dynamic content insertion */
98
98
  dynamicContent: e(c(), !0),
99
99
  /** Enable save as template functionality */
@@ -108,7 +108,7 @@ const i = {
108
108
  unsubscribe: e(c(), !0),
109
109
  /** Disable modules panel in the editor */
110
110
  modulesDisabled: e(c(), !1)
111
- }), f = n([
111
+ }), A = n([
112
112
  "amp-accordion",
113
113
  "amp-carousel",
114
114
  "amp-form-controls",
@@ -133,7 +133,7 @@ const i = {
133
133
  ]), E = o({
134
134
  /** Default blocks to exclude from the editor */
135
135
  excludeDefaults: e(
136
- a(f),
136
+ a(A),
137
137
  []
138
138
  ),
139
139
  /** Custom blocks to include in the editor */
@@ -147,7 +147,7 @@ const i = {
147
147
  /** Human-readable description */
148
148
  description: e(t()),
149
149
  /** Priority for rule ordering (lower = earlier) */
150
- priority: p()
150
+ priority: b()
151
151
  }), N = o({
152
152
  ...l.entries,
153
153
  type: r("replace"),
@@ -175,21 +175,32 @@ const i = {
175
175
  ...l.entries,
176
176
  type: r("custom"),
177
177
  /** Custom processor function */
178
- processor: b(
179
- (d) => typeof d == "function",
178
+ processor: d(
179
+ (i) => typeof i == "function",
180
180
  "processor must be a function"
181
181
  )
182
- }), B = S("type", [
182
+ }), x = S("type", [
183
183
  N,
184
184
  O,
185
185
  L,
186
186
  v
187
- ]), P = o({
187
+ ]), B = o({
188
188
  /** Custom compiler rules to apply */
189
- customRules: e(a(B), []),
189
+ customRules: e(a(x), []),
190
190
  /** Skip default compiler rules */
191
191
  ignoreDefaultRules: e(c(), !1)
192
- }), x = o({
192
+ }), P = o({
193
+ /**
194
+ * External validation handler called before save completes.
195
+ * Return false to cancel the save operation.
196
+ */
197
+ externalValidation: e(
198
+ d(
199
+ (i) => typeof i == "function",
200
+ "externalValidation must be a function"
201
+ )
202
+ )
203
+ }), D = o({
193
204
  // Required sections
194
205
  /** Identity configuration (required) */
195
206
  identity: h,
@@ -199,35 +210,38 @@ const i = {
199
210
  /** Template content and presets */
200
211
  template: e(R, {}),
201
212
  /** Editor settings */
202
- editor: e(I, {}),
213
+ editor: e(C, {}),
203
214
  /** UI configuration */
204
- ui: e(T, {}),
215
+ ui: e(I, {}),
205
216
  /** Feature toggles */
206
- features: e(A, {}),
217
+ features: e(T, {}),
207
218
  /** Block configuration */
208
219
  blocks: e(E, {}),
209
220
  /** Compiler configuration */
210
- compiler: e(P, {})
221
+ compiler: e(B, {}),
222
+ /** Callbacks and event handlers */
223
+ callbacks: e(P, {})
211
224
  });
212
225
  export {
213
226
  E as BlocksSchema,
214
- B as CompilerRuleSchema,
215
- P as CompilerSchema,
227
+ P as CallbacksSchema,
228
+ x as CompilerRuleSchema,
229
+ B as CompilerSchema,
216
230
  g as CustomBlockTypeSchema,
217
231
  v as CustomRuleSchema,
218
- f as DefaultBlockTypeSchema,
232
+ A as DefaultBlockTypeSchema,
219
233
  y as DynamicContentSchema,
220
- I as EditorSchema,
221
- C as EmailHeaderSchema,
222
- A as FeaturesSchema,
223
- x as GuidoConfigSchema,
234
+ C as EditorSchema,
235
+ f as EmailHeaderSchema,
236
+ T as FeaturesSchema,
237
+ D as GuidoConfigSchema,
224
238
  h as IdentitySchema,
225
- i as MessageType,
239
+ m as MessageType,
226
240
  k as PartnerSchema,
227
241
  s as ProductType,
228
242
  O as RegexRuleSchema,
229
243
  L as RemoveRuleSchema,
230
244
  N as ReplaceRuleSchema,
231
245
  R as TemplateSchema,
232
- T as UISchema
246
+ I as UISchema
233
247
  };
@@ -12,9 +12,9 @@ var t = function() {
12
12
  n,
13
13
  !1,
14
14
  null,
15
- "2f1f7b92"
15
+ "890b5336"
16
16
  );
17
- const u = s.exports;
17
+ const v = s.exports;
18
18
  export {
19
- u as default
19
+ v as default
20
20
  };
@@ -1,55 +1,54 @@
1
- import { defineComponent as q, defineAsyncComponent as U, ref as W, computed as I, watch as z, onMounted as K, onUnmounted as M } from "vue";
2
- import { provideGuidoActions as j } from "../composables/useGuidoActions.js";
3
- import { usePartner as J } from "../composables/usePartner.js";
4
- import { useStripo as Q } from "../composables/useStripo.js";
5
- import { useTimerClone as V } from "../composables/useTimerClone.js";
6
- import { migrate as L } from "../config/migrator/index.js";
7
- import X from "./organisms/base/Toaster.vue.js";
8
- import Y from "./organisms/extensions/recommendation/FilterSelectionDrawer.vue.js";
9
- import Z from "./organisms/header/HeaderWrapper.vue.js";
10
- import $ from "./organisms/LoadingWrapper.vue.js";
11
- import ee from "./organisms/save-as-template/SaveAsTemplateDrawer.vue.js";
12
- import oe from "./organisms/unsubscribe/UnsubscribeWrapper.vue.js";
13
- import { useStripoApi as te } from "../services/stripoApi.js";
14
- import { useConfigStore as ne } from "../stores/config.js";
15
- import { useDynamicContentStore as re } from "../stores/dynamic-content.js";
16
- import { useEditorStore as se } from "../stores/editor.js";
17
- import { usePreviewStore as ce } from "../stores/preview.js";
18
- import { useToasterStore as ie } from "../stores/toaster.js";
19
- import { useUnsubscribeStore as ae } from "../stores/unsubscribe.js";
20
- const Pe = /* @__PURE__ */ q({
1
+ import { defineComponent as B, defineAsyncComponent as P, ref as N, computed as U, watch as R, onMounted as z, onUnmounted as K } from "vue";
2
+ import { provideGuidoActions as M } from "../composables/useGuidoActions.js";
3
+ import { usePartner as j } from "../composables/usePartner.js";
4
+ import { useStripo as q } from "../composables/useStripo.js";
5
+ import { useTimerClone as J } from "../composables/useTimerClone.js";
6
+ import { migrate as W } from "../config/migrator/index.js";
7
+ import Q from "./organisms/base/Toaster.vue.js";
8
+ import V from "./organisms/extensions/recommendation/FilterSelectionDrawer.vue.js";
9
+ import X from "./organisms/header/HeaderWrapper.vue.js";
10
+ import Y from "./organisms/LoadingWrapper.vue.js";
11
+ import Z from "./organisms/save-as-template/SaveAsTemplateDrawer.vue.js";
12
+ import $ from "./organisms/unsubscribe/UnsubscribeWrapper.vue.js";
13
+ import { useStripoApi as ee } from "../services/stripoApi.js";
14
+ import { useConfigStore as oe } from "../stores/config.js";
15
+ import { useDynamicContentStore as te } from "../stores/dynamic-content.js";
16
+ import { useEditorStore as ne } from "../stores/editor.js";
17
+ import { usePreviewStore as re } from "../stores/preview.js";
18
+ import { useUnsubscribeStore as se } from "../stores/unsubscribe.js";
19
+ const Ee = /* @__PURE__ */ B({
21
20
  __name: "Guido",
22
21
  props: {
23
22
  config: null
24
23
  },
25
24
  emits: ["dynamic-content:open", "back", "save:start", "save:complete", "on-change", "ready", "onboarding:finished", "test-email:click"],
26
- setup(A, { expose: F, emit: t }) {
27
- const u = A, G = U(
25
+ setup(_, { expose: I, emit: t }) {
26
+ const l = _, L = P(
28
27
  () => import("./organisms/email-preview/PreviewContainer.vue.js")
29
- ), H = U(
28
+ ), A = P(
30
29
  () => import("./organisms/onboarding/OnboardingWrapper.vue.js")
31
- ), p = W(), i = re(), v = ae(), y = ie(), n = ne();
32
- n.init(u.config);
33
- const a = se(), O = ce(), r = I(() => a.hasChanges), { isTestPartner: R } = J(), f = () => {
30
+ ), p = N(), c = te(), u = se(), n = oe();
31
+ n.init(l.config);
32
+ const i = ne(), F = re(), r = U(() => i.hasChanges), { isTestPartner: G } = j(), v = () => {
34
33
  var e;
35
34
  return (e = p.value) == null ? void 0 : e.handleSave(!0);
36
- }, { templateId: m, userId: h, partnerName: b, productType: g, username: S, template: o } = n, s = (o == null ? void 0 : o.html) || "", w = (o == null ? void 0 : o.css) || "", d = (o == null ? void 0 : o.preselectedDynamicContent) || [];
37
- a.templateId = m;
38
- const c = W(!1), { initPlugin: C } = Q({
39
- emailId: m,
40
- userId: h,
41
- username: S,
42
- partnerName: b,
43
- productType: g,
44
- preselectedDynamicContentList: d,
35
+ }, { templateId: a, userId: y, partnerName: h, productType: b, username: f, template: o } = n, s = (o == null ? void 0 : o.html) || "", g = (o == null ? void 0 : o.css) || "", m = (o == null ? void 0 : o.preselectedDynamicContent) || [];
36
+ i.templateId = a;
37
+ const { initPlugin: S } = q({
38
+ emailId: a,
39
+ userId: y,
40
+ username: f,
41
+ partnerName: h,
42
+ productType: b,
43
+ preselectedDynamicContentList: m,
45
44
  onReady: () => {
46
45
  console.debug("guido:ready"), t("ready");
47
46
  }
48
- }), { getDefaultTemplate: D } = te(), { cloneTimersOnSave: E, hasTimerBlocks: T } = V(), x = I(() => {
47
+ }), { getDefaultTemplate: w } = ee(), { cloneTimersOnSave: C, hasTimerBlocks: D } = J(), H = U(() => {
49
48
  var e;
50
49
  return !((e = n.ui) != null && e.showHeader);
51
50
  });
52
- j({
51
+ M({
53
52
  onBack: () => {
54
53
  console.debug("guido:back"), t("back");
55
54
  },
@@ -63,50 +62,49 @@ const Pe = /* @__PURE__ */ q({
63
62
  console.debug("guido:test-email:click"), t("test-email:click");
64
63
  }
65
64
  });
66
- const k = (e) => {
67
- console.debug("dynamic-content:close", e), i.setSelectedDynamicContent(e), document.dispatchEvent(new CustomEvent("dynamic-content:close", { detail: e }));
68
- }, _ = () => {
65
+ const E = (e) => {
66
+ console.debug("dynamic-content:close", e), c.setSelectedDynamicContent(e), document.dispatchEvent(new CustomEvent("dynamic-content:close", { detail: e }));
67
+ }, k = () => {
69
68
  console.debug("dynamic-content:close", "Without Data"), document.dispatchEvent(new CustomEvent("dynamic-content:close", { detail: { text: "", value: "" } }));
70
69
  };
71
- z(() => r.value, () => {
70
+ R(() => r.value, () => {
72
71
  t("on-change", r.value);
73
72
  });
74
- const l = (e) => {
75
- const P = e, { attribute: B, position: N } = P.detail;
76
- console.debug("dynamic-content:open", P.detail), t("dynamic-content:open", B, N);
73
+ const d = (e) => {
74
+ const T = e, { attribute: O, position: x } = T.detail;
75
+ console.debug("dynamic-content:open", T.detail), t("dynamic-content:open", O, x);
77
76
  };
78
- return K(async () => {
77
+ return z(async () => {
79
78
  console.debug("Guido says happy coding 🎉"), console.debug("🚗 Ka-Chow");
80
79
  try {
81
- v.selectedUnsubscribePages = (o == null ? void 0 : o.selectedUnsubscribePages) || [];
80
+ u.selectedUnsubscribePages = (o == null ? void 0 : o.selectedUnsubscribePages) || [];
82
81
  let e = {
83
- html: s && await L(s),
84
- css: w
82
+ html: s && await W(s),
83
+ css: g
85
84
  };
86
- e.html || (e = await D(), e.html = await L(e.html)), T(e.html) && (e.html = await E(e.html)), await C(e), i.selectedDynamicContentList = d;
85
+ e.html || (e = await w(), e.html = await W(e.html)), D(e.html) && (e.html = await C(e.html)), await S(e), c.selectedDynamicContentList = m;
87
86
  } catch (e) {
88
87
  console.error("Failed to initialize Stripo editor:", e);
89
88
  }
90
- document.addEventListener("dynamic-content:open", l), c.value = !0;
91
- }), M(() => {
92
- var e;
93
- c.value && (y.hideToaster(), (e = document.querySelector("#guido__toaster")) == null || e.remove()), c.value = !1, document.removeEventListener("dynamic-content:open", l);
89
+ document.addEventListener("dynamic-content:open", d);
90
+ }), K(() => {
91
+ document.removeEventListener("dynamic-content:open", d);
94
92
  try {
95
93
  window.UIEditor.removeEditor();
96
94
  } catch {
97
95
  console.debug("Failed to remove Stripo editor: No editor found");
98
96
  }
99
97
  n.reset();
100
- }), F({
98
+ }), I({
101
99
  dynamicContent: {
102
- insert: k,
103
- close: _
100
+ insert: E,
101
+ close: k
104
102
  },
105
103
  hasChanges: r,
106
- saveSilent: f
107
- }), { __sfc: !0, PreviewContainer: G, OnboardingWrapper: H, headerWrapperRef: p, dynamicContentStore: i, unsubscribeStore: v, toasterStore: y, props: u, configStore: n, editorStore: a, previewStore: O, hasChanges: r, isTestPartner: R, saveSilent: f, templateId: m, userId: h, partnerName: b, productType: g, username: S, templateConfig: o, html: s, css: w, preselectedDynamicContentList: d, editorReady: c, emit: t, initPlugin: C, getDefaultTemplate: D, cloneTimersOnSave: E, hasTimerBlocks: T, noHeader: x, insertDynamicContent: k, closeDynamicContent: _, handleDynamicContentOpen: l, Toaster: X, FilterSelectionDrawer: Y, HeaderWrapper: Z, LoadingWrapper: $, SaveAsTemplateDrawer: ee, UnsubscribeWrapper: oe };
104
+ saveSilent: v
105
+ }), { __sfc: !0, PreviewContainer: L, OnboardingWrapper: A, headerWrapperRef: p, dynamicContentStore: c, unsubscribeStore: u, props: l, configStore: n, editorStore: i, previewStore: F, hasChanges: r, isTestPartner: G, saveSilent: v, templateId: a, userId: y, partnerName: h, productType: b, username: f, templateConfig: o, html: s, css: g, preselectedDynamicContentList: m, emit: t, initPlugin: S, getDefaultTemplate: w, cloneTimersOnSave: C, hasTimerBlocks: D, noHeader: H, insertDynamicContent: E, closeDynamicContent: k, handleDynamicContentOpen: d, Toaster: Q, FilterSelectionDrawer: V, HeaderWrapper: X, LoadingWrapper: Y, SaveAsTemplateDrawer: Z, UnsubscribeWrapper: $ };
108
106
  }
109
107
  });
110
108
  export {
111
- Pe as default
109
+ Ee as default
112
110
  };
@@ -1,17 +1,17 @@
1
- import n from "./Toaster.vue2.js";
1
+ import e from "./Toaster.vue2.js";
2
2
  import s from "../../../_virtual/_plugin-vue2_normalizer.js";
3
3
  var r = function() {
4
- var o = this, e = o._self._c, t = o._self._setupProxy;
5
- return e(t.InToasts, { attrs: { id: "guido__toaster", "action-buttons-config": t.actionButtonsConfig, status: t.store.status, text: t.store.text, type: t.store.type }, on: { actionButtonClick0: t.handleActionClick } });
4
+ var o = this, n = o._self._c, t = o._self._setupProxy;
5
+ return n(t.InToasts, { attrs: { "action-buttons-config": t.actionButtonsConfig, status: t.store.status, text: t.store.text, type: t.store.type }, on: { actionButtonClick0: t.handleActionClick } });
6
6
  }, a = [], _ = /* @__PURE__ */ s(
7
- n,
7
+ e,
8
8
  r,
9
9
  a,
10
10
  !1,
11
11
  null,
12
12
  null
13
13
  );
14
- const f = _.exports;
14
+ const l = _.exports;
15
15
  export {
16
- f as default
16
+ l as default
17
17
  };
@@ -2,7 +2,7 @@ import s from "./PreviewContainer.vue2.js";
2
2
  import t from "../../../_virtual/_plugin-vue2_normalizer.js";
3
3
  var i = function() {
4
4
  var o = this, r = o._self._c, e = o._self._setupProxy;
5
- return e.previewStore.isLoaded ? r("div", { staticClass: "d-f f-d-c h-1 b-c-5 bor-r-2 pb-5" }, [r("div", { staticClass: "f-g-1 d-f p-5 o-a g-4 min-h-600" }, [r(e.DesktopPreview, { staticClass: "f-g-1 min-w-0" }), r(e.MobilePreview, { staticClass: "f-0 min-w-a" })], 1), e.previewStore.isAMPErrorModalVisible ? r(e.AmpErrorModal, { on: { close: function(_) {
5
+ return e.previewStore.isLoaded ? r("div", { staticClass: "d-f f-d-c h-1 b-c-5 bor-r-2" }, [r("div", { staticClass: "f-g-1 d-f p-5 o-a g-4 min-h-600" }, [r(e.DesktopPreview, { staticClass: "f-g-1 min-w-0" }), r(e.MobilePreview, { staticClass: "f-0 min-w-a" })], 1), e.previewStore.isAMPErrorModalVisible ? r(e.AmpErrorModal, { on: { close: function(_) {
6
6
  return e.previewStore.closeErrorModal();
7
7
  } } }) : o._e()], 1) : o._e();
8
8
  }, n = [], a = /* @__PURE__ */ t(
@@ -13,7 +13,7 @@ var i = function() {
13
13
  null,
14
14
  null
15
15
  );
16
- const p = a.exports;
16
+ const d = a.exports;
17
17
  export {
18
- p as default
18
+ d as default
19
19
  };
@@ -1,20 +1,20 @@
1
- import s from "./AmpErrorModal.vue2.js";
1
+ import i from "./AmpErrorModal.vue2.js";
2
2
  /* empty css */
3
3
  import a from "../../../../_virtual/_plugin-vue2_normalizer.js";
4
4
  var n = function() {
5
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) {
6
+ return r(t.WpModal, { attrs: { id: "amp-error-modal", size: "small", description: t.ampValidationDescription, "footer-button-options": t.footerButtonOptions, title: t.trans("email-editor.amp-validation-title") }, on: { close: function(o) {
7
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 } });
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 error-list" }, e._l(t.previewStore.ampErrors, function(o, s) {
9
+ return r(t.InOnPageMessage, { key: s, attrs: { icon: "filled-error-box", size: "small", type: "alert", text: o } });
10
10
  }), 1)])]);
11
11
  }, l = [], d = /* @__PURE__ */ a(
12
- s,
12
+ i,
13
13
  n,
14
14
  l,
15
15
  !1,
16
16
  null,
17
- "7a09985c"
17
+ "c3fd5d4b"
18
18
  );
19
19
  const _ = d.exports;
20
20
  export {
@@ -1,15 +1,16 @@
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";
1
+ import { defineComponent as m, ref as c, computed as d } from "vue";
2
+ import l from "../../../wrappers/WpModal.vue.js";
3
+ import { useCodeEditorApi as f } from "../../../../composables/useCodeEditorApi.js";
4
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({
5
+ import { useTranslations as _ } from "../../../../composables/useTranslations.js";
6
+ import { ACADEMY_LINKS as M } from "../../../../enums/academy.js";
7
+ import { usePreviewStore as y } from "../../../../stores/preview.js";
8
+ import { InOnPageMessage as E } from "@useinsider/design-system-vue";
9
+ const O = /* @__PURE__ */ m({
9
10
  __name: "AmpErrorModal",
10
11
  emits: ["close"],
11
- setup(x, { emit: e }) {
12
- const o = f(), { closePreviewMode: r } = u(), { openCodeEditor: t } = l(), n = _(), s = m({
12
+ setup(g, { emit: e }) {
13
+ const o = _(), { closePreviewMode: r } = u(), { openCodeEditor: t } = f(), i = y(), n = c({
13
14
  cancelOrBackButton: {
14
15
  type: "secondary",
15
16
  labelText: o("campaign-builder.cancel"),
@@ -19,12 +20,15 @@ const P = /* @__PURE__ */ p({
19
20
  type: "primary",
20
21
  labelText: o("email-editor.amp-validation-fix")
21
22
  }
22
- }), i = () => {
23
+ }), a = () => {
23
24
  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 };
25
+ }, s = o(
26
+ "email-editor.amp-validation-description",
27
+ { academyLink: M.AMP_FOR_EMAILS }
28
+ ), p = d(() => `${o("products.errors")} (${i.ampErrors.length})`);
29
+ return { __sfc: !0, emit: e, trans: o, closePreviewMode: r, openCodeEditor: t, previewStore: i, footerButtonOptions: n, handleFixInCodeEditor: a, ampValidationDescription: s, errorCountText: p, WpModal: l, InOnPageMessage: E };
26
30
  }
27
31
  });
28
32
  export {
29
- P as default
33
+ O as default
30
34
  };
@@ -1,20 +1,20 @@
1
1
  import o from "./AmpToggle.vue2.js";
2
2
  /* empty css */
3
3
  import n from "../../../../_virtual/_plugin-vue2_normalizer.js";
4
- var s = function() {
4
+ var i = function() {
5
5
  var r = this, t = r._self._c, e = r._self._setupProxy;
6
- 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(l) {
6
+ return t("div", [t("div", { staticClass: "d-f a-i-c ml-3" }, [t(e.InSegments, { attrs: { id: "guido__amp-toggle", "with-icon": "", "segment-list": e.segmentList, selected: e.previewStore.emailFormat }, on: { click: e.handleFormatChange } }), e.previewStore.showAMPErrorButton ? t(e.InButtonV2, { staticClass: "ml-3", attrs: { id: "guido__amp-error-button", "left-icon": "filled-amp", type: "danger", "label-text": e.trans("email-editor.check-amp-errors", { count: e.previewStore.ampErrors.length }) }, on: { click: function(m) {
7
7
  return e.previewStore.openErrorModal();
8
8
  } } }) : r._e()], 1)]);
9
- }, a = [], i = /* @__PURE__ */ n(
9
+ }, a = [], s = /* @__PURE__ */ n(
10
10
  o,
11
- s,
11
+ i,
12
12
  a,
13
13
  !1,
14
14
  null,
15
- "b5997368"
15
+ "22226124"
16
16
  );
17
- const d = i.exports;
17
+ const d = s.exports;
18
18
  export {
19
19
  d as default
20
20
  };
@@ -1,26 +1,28 @@
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";
1
+ import { defineComponent as n, computed as i } from "vue";
2
+ import { useTranslations as m } from "../../../../composables/useTranslations.js";
3
+ import { usePreviewStore as r } from "../../../../stores/preview.js";
4
4
  import { InButtonV2 as s, InSegments as l } from "@useinsider/design-system-vue";
5
- const _ = /* @__PURE__ */ m({
5
+ const _ = /* @__PURE__ */ n({
6
6
  __name: "AmpToggle",
7
7
  setup(p) {
8
- const t = i(), e = r(), o = n(() => [
8
+ const e = r(), t = m(), o = i(() => [
9
9
  {
10
- text: e("dynamic-creatives.html"),
11
- value: "html"
10
+ text: t("dynamic-creatives.html"),
11
+ value: "html",
12
+ icon: "line-code"
12
13
  },
13
14
  {
14
- text: e("email-editor.amp-html"),
15
+ text: t("email-editor.amp-html"),
15
16
  value: "AMP",
16
- tooltipText: t.hasAMP ? "" : e("email-editor.preview-amp-unavailable-tooltip"),
17
+ icon: "filled-amp",
18
+ tooltipText: e.hasAMP ? "" : t("email-editor.preview-amp-unavailable-tooltip"),
17
19
  position: "bottom",
18
20
  align: "center",
19
- disable: !t.hasAMP
21
+ disable: !e.hasAMP
20
22
  }
21
23
  ]);
22
- return { __sfc: !0, previewStore: t, trans: e, segmentList: o, handleFormatChange: (a) => {
23
- t.setEmailFormat(a);
24
+ return { __sfc: !0, previewStore: e, trans: t, segmentList: o, handleFormatChange: (a) => {
25
+ e.setEmailFormat(a);
24
26
  }, InSegments: l, InButtonV2: s };
25
27
  }
26
28
  });
@@ -0,0 +1,18 @@
1
+ import r from "./DesktopBrowserHeader.vue2.js";
2
+ /* empty css */
3
+ import o from "../../../../_virtual/_plugin-vue2_normalizer.js";
4
+ var a = function() {
5
+ var t = this, e = t._self._c, s = t._self._setupProxy;
6
+ return e("div", { staticClass: "desktop-browser-header d-f w-1 f-sh-0" }, [e("img", { staticClass: "desktop-browser-header__left f-sh-0", attrs: { alt: "", src: s.desktopMockupLeft } }), e("div", { staticClass: "desktop-browser-header__center f-g-1", style: s.centerBackgroundStyle }), e("img", { staticClass: "desktop-browser-header__right f-sh-0", attrs: { alt: "", src: s.desktopMockupRight } })]);
7
+ }, _ = [], c = /* @__PURE__ */ o(
8
+ r,
9
+ a,
10
+ _,
11
+ !1,
12
+ null,
13
+ "d86c5af5"
14
+ );
15
+ const p = c.exports;
16
+ export {
17
+ p as default
18
+ };
@@ -0,0 +1,15 @@
1
+ import { defineComponent as e, computed as o } from "vue";
2
+ import t from "../../../../static/assets/desktop/desktop-mockup-center.svg.js";
3
+ import r from "../../../../static/assets/desktop/desktop-mockup-left.svg.js";
4
+ import p from "../../../../static/assets/desktop/desktop-mockup-right.svg.js";
5
+ const k = /* @__PURE__ */ e({
6
+ __name: "DesktopBrowserHeader",
7
+ setup(n) {
8
+ return { __sfc: !0, centerBackgroundStyle: o(() => ({
9
+ backgroundImage: `url("${t}")`
10
+ })), desktopMockupLeft: r, desktopMockupRight: p };
11
+ }
12
+ });
13
+ export {
14
+ k as default
15
+ };