@useinsider/guido 2.0.0-beta.1f72712 → 2.0.0-beta.200f113

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 (248) hide show
  1. package/dist/@types/config/schemas.js +53 -39
  2. package/dist/components/organisms/email-preview/PreviewContainer.vue.js +3 -3
  3. package/dist/components/organisms/email-preview/amp/AmpErrorModal.vue.js +6 -6
  4. package/dist/components/organisms/email-preview/amp/AmpErrorModal.vue2.js +17 -13
  5. package/dist/components/organisms/email-preview/amp/AmpToggle.vue.js +6 -6
  6. package/dist/components/organisms/email-preview/amp/AmpToggle.vue2.js +14 -12
  7. package/dist/components/organisms/email-preview/desktop-preview/DesktopBrowserHeader.vue.js +18 -0
  8. package/dist/components/organisms/email-preview/desktop-preview/DesktopBrowserHeader.vue2.js +15 -0
  9. package/dist/components/organisms/email-preview/desktop-preview/DesktopPreview.vue.js +10 -14
  10. package/dist/components/organisms/email-preview/desktop-preview/DesktopPreview.vue2.js +14 -22
  11. package/dist/components/organisms/email-preview/desktop-preview/EmailSizeIndicator.vue.js +3 -3
  12. package/dist/components/organisms/email-preview/mobile-preview/ContentView.vue.js +11 -10
  13. package/dist/components/organisms/email-preview/mobile-preview/InboxView.vue.js +12 -10
  14. package/dist/components/organisms/email-preview/mobile-preview/MobilePreview.vue.js +11 -10
  15. package/dist/components/organisms/email-preview/mobile-preview/MobilePreview.vue2.js +15 -14
  16. package/dist/components/organisms/header/EditorActions.vue.js +20 -0
  17. package/dist/components/organisms/header/EditorActions.vue2.js +41 -0
  18. package/dist/components/organisms/header/EditorToolbar.vue.js +18 -0
  19. package/dist/components/organisms/header/EditorToolbar.vue2.js +17 -0
  20. package/dist/components/organisms/header/HeaderWrapper.vue.js +6 -5
  21. package/dist/components/organisms/header/LeftSlot.vue.js +11 -11
  22. package/dist/components/organisms/header/LeftSlot.vue2.js +11 -12
  23. package/dist/components/organisms/header/MiddleSlot.vue.js +7 -7
  24. package/dist/components/organisms/header/MiddleSlot.vue2.js +11 -15
  25. package/dist/components/organisms/header/RightSlot.vue.js +11 -14
  26. package/dist/components/organisms/header/RightSlot.vue2.js +13 -30
  27. package/dist/components/organisms/header/version-history/VersionHistory.vue.js +5 -5
  28. package/dist/components/organisms/onboarding/NewVersionPopup.vue2.js +15 -15
  29. package/dist/components/organisms/unsubscribe/UnsubscribeTypeSelection.vue.js +1 -1
  30. package/dist/components/organisms/unsubscribe/UnsubscribeTypeSelection.vue2.js +20 -19
  31. package/dist/composables/useConfig.js +29 -27
  32. package/dist/composables/useSave.js +13 -11
  33. package/dist/config/migrator/recommendationMigrator.js +2 -2
  34. package/dist/enums/academy.js +8 -0
  35. package/dist/enums/onboarding.js +1 -2
  36. package/dist/enums/unsubscribe.js +20 -21
  37. package/dist/extensions/Blocks/Items/controls/cardComposition.js +4 -13
  38. package/dist/extensions/Blocks/Recommendation/block.js +6 -40
  39. package/dist/extensions/Blocks/Recommendation/cardCompositionControl.js +103 -0
  40. package/dist/extensions/Blocks/Recommendation/constants.js +5 -0
  41. package/dist/extensions/Blocks/Recommendation/control.js +306 -0
  42. package/dist/extensions/Blocks/Recommendation/controls/button/align.js +13 -0
  43. package/dist/extensions/Blocks/Recommendation/controls/button/border.js +13 -0
  44. package/dist/extensions/Blocks/Recommendation/controls/button/borderRadius.js +13 -0
  45. package/dist/extensions/Blocks/Recommendation/controls/button/color.js +13 -0
  46. package/dist/extensions/Blocks/Recommendation/controls/button/fitToContent.js +13 -0
  47. package/dist/extensions/Blocks/Recommendation/controls/button/fontFamily.js +13 -0
  48. package/dist/extensions/Blocks/Recommendation/controls/button/margins.js +13 -0
  49. package/dist/extensions/Blocks/Recommendation/controls/button/paddings.js +13 -0
  50. package/dist/extensions/Blocks/Recommendation/controls/button/text.js +13 -0
  51. package/dist/extensions/Blocks/Recommendation/controls/button/textSize.js +13 -0
  52. package/dist/extensions/Blocks/Recommendation/controls/button/textStyleAndFontColor.js +13 -0
  53. package/dist/extensions/Blocks/Recommendation/controls/image/margins.js +13 -0
  54. package/dist/extensions/Blocks/Recommendation/controls/image/size.js +13 -0
  55. package/dist/extensions/Blocks/Recommendation/controls/name/align.js +13 -0
  56. package/dist/extensions/Blocks/Recommendation/controls/name/background.js +13 -0
  57. package/dist/extensions/Blocks/Recommendation/controls/name/color.js +13 -0
  58. package/dist/extensions/Blocks/Recommendation/controls/name/fontFamily.js +13 -0
  59. package/dist/extensions/Blocks/Recommendation/controls/name/paddings.js +13 -0
  60. package/dist/extensions/Blocks/Recommendation/controls/name/size.js +13 -0
  61. package/dist/extensions/Blocks/Recommendation/controls/name/style.js +13 -0
  62. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/align.js +13 -0
  63. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/background.js +13 -0
  64. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/color.js +13 -0
  65. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/fontFamily.js +13 -0
  66. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/paddings.js +13 -0
  67. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/size.js +13 -0
  68. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/style.js +13 -0
  69. package/dist/extensions/Blocks/Recommendation/controls/price/align.js +13 -0
  70. package/dist/extensions/Blocks/Recommendation/controls/price/background.js +13 -0
  71. package/dist/extensions/Blocks/Recommendation/controls/price/color.js +13 -0
  72. package/dist/extensions/Blocks/Recommendation/controls/price/fontFamily.js +13 -0
  73. package/dist/extensions/Blocks/Recommendation/controls/price/paddings.js +13 -0
  74. package/dist/extensions/Blocks/Recommendation/controls/price/size.js +13 -0
  75. package/dist/extensions/Blocks/Recommendation/controls/price/style.js +13 -0
  76. package/dist/extensions/Blocks/Recommendation/extension.js +43 -40
  77. package/dist/extensions/Blocks/Recommendation/recommendation.css.js +4 -13
  78. package/dist/extensions/Blocks/Recommendation/settingsPanel.js +72 -128
  79. package/dist/extensions/Blocks/Recommendation/store/recommendation.js +34 -39
  80. package/dist/extensions/Blocks/Recommendation/templates/blockTemplate.js +160 -0
  81. package/dist/extensions/Blocks/Recommendation/templates/migrationTemplate.js +152 -0
  82. package/dist/extensions/Blocks/Recommendation/templates/templateUtils.js +180 -0
  83. package/dist/extensions/Blocks/Recommendation/utils/filterUtil.js +9 -9
  84. package/dist/extensions/Blocks/Unsubscribe/extension.js +9 -9
  85. package/dist/extensions/Blocks/common-control.js +6 -7
  86. package/dist/extensions/Blocks/controlFactories.js +121 -155
  87. package/dist/guido.css +1 -1
  88. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/esm/index.js +297 -424
  89. package/dist/package.json.js +1 -1
  90. package/dist/src/@types/config/index.d.ts +2 -2
  91. package/dist/src/@types/config/schemas.d.ts +26 -0
  92. package/dist/src/@types/config/types.d.ts +7 -1
  93. package/dist/src/components/organisms/email-preview/desktop-preview/DesktopBrowserHeader.vue.d.ts +2 -0
  94. package/dist/src/components/organisms/header/EditorActions.vue.d.ts +4 -0
  95. package/dist/src/components/organisms/header/EditorToolbar.vue.d.ts +2 -0
  96. package/dist/src/components/organisms/header/RightSlot.vue.d.ts +1 -1
  97. package/dist/src/components/wrappers/WpDrawer.vue.d.ts +1 -1
  98. package/dist/src/composables/useConfig.d.ts +6 -0
  99. package/dist/src/enums/academy.d.ts +12 -0
  100. package/dist/src/enums/onboarding.d.ts +0 -1
  101. package/dist/src/enums/unsubscribe.d.ts +0 -1
  102. package/dist/src/extensions/Blocks/Recommendation/block.d.ts +0 -34
  103. package/dist/src/extensions/Blocks/Recommendation/cardCompositionControl.d.ts +28 -0
  104. package/dist/src/extensions/Blocks/Recommendation/{constants/controlIds.d.ts → constants.d.ts} +11 -19
  105. package/dist/src/extensions/Blocks/Recommendation/control.d.ts +35 -0
  106. package/dist/src/extensions/Blocks/Recommendation/controls/button/align.d.ts +5 -0
  107. package/dist/src/extensions/Blocks/Recommendation/controls/button/border.d.ts +5 -0
  108. package/dist/src/extensions/Blocks/Recommendation/controls/button/borderRadius.d.ts +5 -0
  109. package/dist/src/extensions/Blocks/Recommendation/controls/button/color.d.ts +5 -0
  110. package/dist/src/extensions/Blocks/Recommendation/controls/button/fitToContent.d.ts +5 -0
  111. package/dist/src/extensions/Blocks/Recommendation/controls/button/fontFamily.d.ts +5 -0
  112. package/dist/src/extensions/Blocks/Recommendation/controls/button/margins.d.ts +5 -0
  113. package/dist/src/extensions/Blocks/Recommendation/controls/button/paddings.d.ts +5 -0
  114. package/dist/src/extensions/Blocks/Recommendation/controls/button/text.d.ts +5 -0
  115. package/dist/src/extensions/Blocks/Recommendation/controls/button/textSize.d.ts +5 -0
  116. package/dist/src/extensions/Blocks/Recommendation/controls/button/textStyleAndFontColor.d.ts +5 -0
  117. package/dist/src/extensions/Blocks/Recommendation/controls/image/margins.d.ts +5 -0
  118. package/dist/src/extensions/Blocks/Recommendation/controls/image/size.d.ts +5 -0
  119. package/dist/src/extensions/Blocks/Recommendation/controls/name/align.d.ts +5 -0
  120. package/dist/src/extensions/Blocks/Recommendation/controls/name/background.d.ts +5 -0
  121. package/dist/src/extensions/Blocks/Recommendation/controls/name/color.d.ts +5 -0
  122. package/dist/src/extensions/Blocks/Recommendation/controls/name/fontFamily.d.ts +5 -0
  123. package/dist/src/extensions/Blocks/Recommendation/controls/name/paddings.d.ts +5 -0
  124. package/dist/src/extensions/Blocks/Recommendation/controls/name/size.d.ts +5 -0
  125. package/dist/src/extensions/Blocks/Recommendation/controls/name/style.d.ts +5 -0
  126. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/align.d.ts +5 -0
  127. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/background.d.ts +5 -0
  128. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/color.d.ts +5 -0
  129. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/fontFamily.d.ts +5 -0
  130. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/paddings.d.ts +5 -0
  131. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/size.d.ts +5 -0
  132. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/style.d.ts +5 -0
  133. package/dist/src/extensions/Blocks/Recommendation/controls/price/align.d.ts +5 -0
  134. package/dist/src/extensions/Blocks/Recommendation/controls/price/background.d.ts +5 -0
  135. package/dist/src/extensions/Blocks/Recommendation/controls/price/color.d.ts +5 -0
  136. package/dist/src/extensions/Blocks/Recommendation/controls/price/fontFamily.d.ts +5 -0
  137. package/dist/src/extensions/Blocks/Recommendation/controls/price/paddings.d.ts +5 -0
  138. package/dist/src/extensions/Blocks/Recommendation/controls/price/size.d.ts +5 -0
  139. package/dist/src/extensions/Blocks/Recommendation/controls/price/style.d.ts +5 -0
  140. package/dist/src/extensions/Blocks/Recommendation/extension.d.ts +0 -9
  141. package/dist/src/extensions/Blocks/Recommendation/store/recommendation.d.ts +16 -17
  142. package/dist/src/extensions/Blocks/Recommendation/templates/blockTemplate.d.ts +16 -0
  143. package/dist/src/extensions/Blocks/Recommendation/templates/{vertical/migration.d.ts → migrationTemplate.d.ts} +4 -11
  144. package/dist/src/extensions/Blocks/Recommendation/templates/templateUtils.d.ts +44 -0
  145. package/dist/src/extensions/Blocks/common-control.d.ts +1 -1
  146. package/dist/src/stores/config.d.ts +147 -1
  147. package/dist/src/stores/editor.d.ts +21 -0
  148. package/dist/static/assets/desktop/desktop-mockup-center.svg.js +4 -0
  149. package/dist/static/assets/desktop/desktop-mockup-left.svg.js +4 -0
  150. package/dist/static/assets/desktop/desktop-mockup-right.svg.js +4 -0
  151. package/dist/static/assets/mobile/email-mockup.svg.js +4 -0
  152. package/dist/static/assets/mobile/inbox-mockup.svg.js +4 -0
  153. package/dist/static/styles/components/button.css.js +1 -1
  154. package/dist/static/styles/components/wide-panel.css.js +5 -1
  155. package/dist/static/styles/customEditorStyle.css.js +2 -38
  156. package/dist/stores/config.js +7 -0
  157. package/dist/stores/editor.js +1 -0
  158. package/package.json +3 -3
  159. package/dist/components/organisms/email-preview/desktop-preview/EmailHeaderInfo.vue.js +0 -17
  160. package/dist/components/organisms/email-preview/desktop-preview/EmailHeaderInfo.vue2.js +0 -20
  161. package/dist/extensions/Blocks/Recommendation/constants/blockIds.js +0 -4
  162. package/dist/extensions/Blocks/Recommendation/constants/controlIds.js +0 -4
  163. package/dist/extensions/Blocks/Recommendation/constants/defaultConfig.js +0 -64
  164. package/dist/extensions/Blocks/Recommendation/constants/layout.js +0 -12
  165. package/dist/extensions/Blocks/Recommendation/constants/selectors.js +0 -19
  166. package/dist/extensions/Blocks/Recommendation/controls/button/index.js +0 -64
  167. package/dist/extensions/Blocks/Recommendation/controls/cardBackground/index.js +0 -80
  168. package/dist/extensions/Blocks/Recommendation/controls/cardComposition/index.js +0 -232
  169. package/dist/extensions/Blocks/Recommendation/controls/image/index.js +0 -19
  170. package/dist/extensions/Blocks/Recommendation/controls/layout/index.js +0 -110
  171. package/dist/extensions/Blocks/Recommendation/controls/main/algorithm.js +0 -110
  172. package/dist/extensions/Blocks/Recommendation/controls/main/currency.js +0 -207
  173. package/dist/extensions/Blocks/Recommendation/controls/main/filters.js +0 -54
  174. package/dist/extensions/Blocks/Recommendation/controls/main/index.js +0 -148
  175. package/dist/extensions/Blocks/Recommendation/controls/main/locale.js +0 -74
  176. package/dist/extensions/Blocks/Recommendation/controls/main/productLayout.js +0 -124
  177. package/dist/extensions/Blocks/Recommendation/controls/main/shuffle.js +0 -71
  178. package/dist/extensions/Blocks/Recommendation/controls/main/utils.js +0 -124
  179. package/dist/extensions/Blocks/Recommendation/controls/name/index.js +0 -46
  180. package/dist/extensions/Blocks/Recommendation/controls/name/textTrim.js +0 -76
  181. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/index.js +0 -44
  182. package/dist/extensions/Blocks/Recommendation/controls/omnibusDiscount/index.js +0 -48
  183. package/dist/extensions/Blocks/Recommendation/controls/omnibusDiscount/textAfter.js +0 -73
  184. package/dist/extensions/Blocks/Recommendation/controls/omnibusDiscount/textBefore.js +0 -73
  185. package/dist/extensions/Blocks/Recommendation/controls/omnibusPrice/index.js +0 -48
  186. package/dist/extensions/Blocks/Recommendation/controls/omnibusPrice/textAfter.js +0 -73
  187. package/dist/extensions/Blocks/Recommendation/controls/omnibusPrice/textBefore.js +0 -73
  188. package/dist/extensions/Blocks/Recommendation/controls/price/index.js +0 -44
  189. package/dist/extensions/Blocks/Recommendation/controls/spacing/index.js +0 -222
  190. package/dist/extensions/Blocks/Recommendation/services/configService.js +0 -239
  191. package/dist/extensions/Blocks/Recommendation/templates/horizontal/elementRenderer.js +0 -181
  192. package/dist/extensions/Blocks/Recommendation/templates/horizontal/template.js +0 -71
  193. package/dist/extensions/Blocks/Recommendation/templates/index.js +0 -12
  194. package/dist/extensions/Blocks/Recommendation/templates/utils.js +0 -116
  195. package/dist/extensions/Blocks/Recommendation/templates/vertical/elementRenderer.js +0 -211
  196. package/dist/extensions/Blocks/Recommendation/templates/vertical/migration.js +0 -251
  197. package/dist/extensions/Blocks/Recommendation/templates/vertical/template.js +0 -62
  198. package/dist/extensions/Blocks/Recommendation/types/nodeConfig.js +0 -6
  199. package/dist/extensions/Blocks/Recommendation/utils/preserveTextStyles.js +0 -36
  200. package/dist/extensions/Blocks/Recommendation/utils/priceFormatter.js +0 -29
  201. package/dist/extensions/Blocks/Recommendation/utils/tagName.js +0 -46
  202. package/dist/src/extensions/Blocks/Recommendation/constants/blockIds.d.ts +0 -13
  203. package/dist/src/extensions/Blocks/Recommendation/constants/defaultConfig.d.ts +0 -49
  204. package/dist/src/extensions/Blocks/Recommendation/constants/index.d.ts +0 -13
  205. package/dist/src/extensions/Blocks/Recommendation/constants/layout.d.ts +0 -27
  206. package/dist/src/extensions/Blocks/Recommendation/constants/selectors.d.ts +0 -31
  207. package/dist/src/extensions/Blocks/Recommendation/controls/button/index.d.ts +0 -143
  208. package/dist/src/extensions/Blocks/Recommendation/controls/cardBackground/index.d.ts +0 -31
  209. package/dist/src/extensions/Blocks/Recommendation/controls/cardComposition/index.d.ts +0 -95
  210. package/dist/src/extensions/Blocks/Recommendation/controls/image/index.d.ts +0 -35
  211. package/dist/src/extensions/Blocks/Recommendation/controls/index.d.ts +0 -24
  212. package/dist/src/extensions/Blocks/Recommendation/controls/layout/index.d.ts +0 -36
  213. package/dist/src/extensions/Blocks/Recommendation/controls/main/algorithm.d.ts +0 -29
  214. package/dist/src/extensions/Blocks/Recommendation/controls/main/currency.d.ts +0 -45
  215. package/dist/src/extensions/Blocks/Recommendation/controls/main/filters.d.ts +0 -22
  216. package/dist/src/extensions/Blocks/Recommendation/controls/main/index.d.ts +0 -62
  217. package/dist/src/extensions/Blocks/Recommendation/controls/main/locale.d.ts +0 -24
  218. package/dist/src/extensions/Blocks/Recommendation/controls/main/productLayout.d.ts +0 -42
  219. package/dist/src/extensions/Blocks/Recommendation/controls/main/shuffle.d.ts +0 -23
  220. package/dist/src/extensions/Blocks/Recommendation/controls/main/utils.d.ts +0 -100
  221. package/dist/src/extensions/Blocks/Recommendation/controls/name/index.d.ts +0 -97
  222. package/dist/src/extensions/Blocks/Recommendation/controls/name/textTrim.d.ts +0 -16
  223. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/index.d.ts +0 -95
  224. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusDiscount/index.d.ts +0 -100
  225. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusDiscount/textAfter.d.ts +0 -15
  226. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusDiscount/textBefore.d.ts +0 -15
  227. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusPrice/index.d.ts +0 -100
  228. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusPrice/textAfter.d.ts +0 -15
  229. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusPrice/textBefore.d.ts +0 -15
  230. package/dist/src/extensions/Blocks/Recommendation/controls/price/index.d.ts +0 -95
  231. package/dist/src/extensions/Blocks/Recommendation/controls/spacing/index.d.ts +0 -83
  232. package/dist/src/extensions/Blocks/Recommendation/services/configService.d.ts +0 -151
  233. package/dist/src/extensions/Blocks/Recommendation/services/index.d.ts +0 -6
  234. package/dist/src/extensions/Blocks/Recommendation/templates/horizontal/elementRenderer.d.ts +0 -8
  235. package/dist/src/extensions/Blocks/Recommendation/templates/horizontal/migration.d.ts +0 -25
  236. package/dist/src/extensions/Blocks/Recommendation/templates/horizontal/template.d.ts +0 -18
  237. package/dist/src/extensions/Blocks/Recommendation/templates/index.d.ts +0 -39
  238. package/dist/src/extensions/Blocks/Recommendation/templates/utils.d.ts +0 -45
  239. package/dist/src/extensions/Blocks/Recommendation/templates/vertical/elementRenderer.d.ts +0 -7
  240. package/dist/src/extensions/Blocks/Recommendation/templates/vertical/template.d.ts +0 -33
  241. package/dist/src/extensions/Blocks/Recommendation/types/index.d.ts +0 -7
  242. package/dist/src/extensions/Blocks/Recommendation/types/nodeConfig.d.ts +0 -154
  243. package/dist/src/extensions/Blocks/Recommendation/utils/preserveTextStyles.d.ts +0 -19
  244. package/dist/src/extensions/Blocks/Recommendation/utils/priceFormatter.d.ts +0 -33
  245. package/dist/src/extensions/Blocks/Recommendation/utils/stylePreserver.d.ts +0 -113
  246. package/dist/src/extensions/Blocks/Recommendation/utils/tagName.d.ts +0 -77
  247. package/dist/static/assets/inbox-mockup.svg.js +0 -4
  248. package/dist/static/assets/phone-mockup.svg.js +0 -4
@@ -0,0 +1,160 @@
1
+ import { BlockType as t, BlockAttr as n } from "../../../../node_modules/@stripoinc/ui-editor-extensions/dist/esm/index.js";
2
+ import { RecommendationBlockId as o } from "../constants.js";
3
+ import { generateTemplate as l, prepareProductRows as s, spacer as d, DEFAULTS as p, getDefaultProducts as i } from "./templateUtils.js";
4
+ import { DEFAULT_CARD_COMPOSITION as $ } from "./templateUtils.js";
5
+ const g = `
6
+ <td align="left" class="ins-recommendation-v3-block-v2 esd-block-recommendation-v3-block es-p20">
7
+ <table width="100%" cellpadding="0" cellspacing="0" border="0">
8
+ <tr>
9
+ <td align="center">
10
+ <table
11
+ class="container"
12
+ width="100%"
13
+ cellpadding="0"
14
+ cellspacing="0"
15
+ border="0">
16
+ <tbody>
17
+ <tr>
18
+ <td>
19
+ <table
20
+ width="100%"
21
+ cellpadding="0"
22
+ cellspacing="0"
23
+ border="0">
24
+ <tbody>
25
+ <${t.BLOCK_TEXT}
26
+ class="es-p10t es-p10b es-p20l es-p20r"
27
+ align="center">
28
+ <p path="1" style="font-size: 28px; color: #333333;">
29
+ <strong path="1,0">{-{-TITLE-}-}</strong>
30
+ </p>
31
+ </${t.BLOCK_TEXT}>
32
+ </tbody>
33
+ </table>
34
+ </td>
35
+ </tr>
36
+ ${d}
37
+ <tr>
38
+ <td>
39
+ <table
40
+ class="ins-recommendation-product-container"
41
+ width="100%"
42
+ cellpadding="0"
43
+ cellspacing="0"
44
+ border="0"
45
+ >
46
+ {-{-PRODUCT_ROWS-}-}
47
+ </table>
48
+ </td>
49
+ </tr>
50
+ </tbody>
51
+ </table>
52
+ </td>
53
+ </tr>
54
+ </table>
55
+ </td>
56
+ `, a = {
57
+ productImage: (e) => `
58
+ <${t.BLOCK_IMAGE}
59
+ ${n.BLOCK_IMAGE.src}="${e.image_url}"
60
+ ${n.BLOCK_IMAGE.alt}="${e.name}"
61
+ ${n.BLOCK_IMAGE.href}="#"
62
+ class="product-image"
63
+ align="center"
64
+ style="max-width: 100%; height: auto; margin: 0 auto;"
65
+ esd-extension-block-id="${o.IMAGE}">
66
+ </${t.BLOCK_IMAGE}>
67
+ `,
68
+ productName: (e) => `
69
+ <${t.BLOCK_TEXT}
70
+ class="product-name"
71
+ align="center"
72
+ style="font-size: 16px; color: #333333; font-weight: 600; padding: 15px 10px; text-align: center;"
73
+ esd-extension-block-id="${o.NAME}">
74
+ <p path="1" contenteditable="false">
75
+ <strong path="1,0">${e.name}</strong>
76
+ </p>
77
+ </${t.BLOCK_TEXT}>
78
+ `,
79
+ productPrice: () => `
80
+ <${t.BLOCK_TEXT}
81
+ class="product-price"
82
+ align="center"
83
+ style="padding: 10px; text-align: center;"
84
+ esd-extension-block-id="${o.PRICE}">
85
+ <p path="1" contenteditable="false">
86
+ <span class="current-price" style="font-size: 16px; color: #333333; font-weight: bold;">
87
+ <strong path="1,0">18,00 TRY</strong>
88
+ </span>
89
+ </p>
90
+ </${t.BLOCK_TEXT}>
91
+ `,
92
+ productOldPrice: () => `
93
+ <${t.BLOCK_TEXT}
94
+ class="product-old-price"
95
+ align="center"
96
+ style="padding: 10px; text-align: center;"
97
+ esd-extension-block-id="${o.OLD_PRICE}">
98
+ <p path="1" contenteditable="false">
99
+ <span class="old-price" style="font-size: 14px; color: #999999; text-decoration: line-through;">
100
+ <s path="1,0">20,00 TRY</s>
101
+ </span>
102
+ </p>
103
+ </${t.BLOCK_TEXT}>
104
+ `,
105
+ productButton: () => `
106
+ <${t.BLOCK_BUTTON}
107
+ ${n.BLOCK_BUTTON.href}="#"
108
+ class="product-button"
109
+ align="center"
110
+ style="padding: 15px 10px 20px 10px; text-align: center;"
111
+ esd-extension-block-id="${o.BUTTON}">
112
+ <span class="es-button-border">
113
+ <a
114
+ href="#"
115
+ class="es-button buy-button"
116
+ target="_blank"
117
+ style="
118
+ display: inline-block;
119
+ width: 90%;
120
+ max-width: 150px;
121
+ padding: 12px 20px;
122
+ background-color: #ffffff;
123
+ color: #333333;
124
+ text-decoration: none;
125
+ border: 2px solid #cccccc;
126
+ font-size: 16px;
127
+ box-sizing: border-box;
128
+ ">
129
+ Buy
130
+ </a>
131
+ </span>
132
+ </${t.BLOCK_BUTTON}>
133
+ `
134
+ };
135
+ function x() {
136
+ const e = i();
137
+ return l(
138
+ g,
139
+ e,
140
+ 3,
141
+ a,
142
+ p.TITLE
143
+ );
144
+ }
145
+ function f(e, r, c) {
146
+ return s(
147
+ e,
148
+ r,
149
+ a,
150
+ c
151
+ );
152
+ }
153
+ export {
154
+ p as DEFAULTS,
155
+ $ as DEFAULT_CARD_COMPOSITION,
156
+ g as default,
157
+ i as getDefaultProducts,
158
+ x as getDefaultTemplate,
159
+ f as prepareProductRows
160
+ };
@@ -0,0 +1,152 @@
1
+ import { prepareProductRows as n } from "./templateUtils.js";
2
+ import { DEFAULTS as i, getDefaultProducts as p } from "./templateUtils.js";
3
+ const a = `
4
+ <td
5
+ align="left"
6
+ esd-extension-block-id="recommendation-block"
7
+ esd-handler-name="esd-extension-RecommendationBlock"
8
+ class="ins-recommendation-v3-block-v2 esd-block-recommendation-v3-block esd-extension-block es-p20"
9
+ >
10
+ <table width="100%" cellpadding="0" cellspacing="0" border="0">
11
+ <tr>
12
+ <td align="center">
13
+ <table
14
+ class="container"
15
+ width="100%"
16
+ cellpadding="0"
17
+ cellspacing="0"
18
+ border="0">
19
+ <tbody>
20
+ <tr>
21
+ <td>
22
+ <table
23
+ width="100%"
24
+ cellpadding="0"
25
+ cellspacing="0"
26
+ border="0">
27
+ <tbody>
28
+ <tr>
29
+ {-{-TITLE-}-}
30
+ </tr>
31
+ </tbody>
32
+ </table>
33
+ </td>
34
+ </tr>
35
+ <tr>
36
+ <td class="spacer" style="height: 20px;"></td>
37
+ </tr>
38
+ <tr>
39
+ <td>
40
+ <table
41
+ class="ins-recommendation-product-container"
42
+ width="100%"
43
+ cellpadding="0"
44
+ cellspacing="0"
45
+ border="0"
46
+ >
47
+ {-{-PRODUCT_ROWS-}-}
48
+ </table>
49
+ </td>
50
+ </tr>
51
+ </tbody>
52
+ </table>
53
+ </td>
54
+ </tr>
55
+ </table>
56
+ </td>
57
+ `, l = {
58
+ productImage: (t) => `
59
+ <tr>
60
+ <td
61
+ class="esd-block-image product-image"
62
+ esd-extension-block-id="recommendation-block-image"
63
+ align="center"
64
+ style="font-size: 0px;">
65
+ <a target="_blank" href="${t.url}">
66
+ <img
67
+ src="${t.image_url}"
68
+ alt="${t.name}"
69
+ width="120"
70
+ style="display: block; max-width: 100%; height: auto;"
71
+ class="adapt-img">
72
+ </a>
73
+ </td>
74
+ </tr>
75
+ `,
76
+ productName: (t) => `
77
+ <tr>
78
+ <td
79
+ class="esd-block-text product-name"
80
+ esd-extension-block-id="recommendation-block-name"
81
+ align="center">
82
+ <p
83
+ path="1"
84
+ contenteditable="false"
85
+ style="font-size: 16px; color: #333333; font-weight: 600; text-align: center;">
86
+ <strong path="1,0">${t.name}</strong>
87
+ </p>
88
+ </td>
89
+ </tr>
90
+ `,
91
+ productPrice: () => `
92
+ <tr>
93
+ <td
94
+ class="esd-block-text product-price"
95
+ esd-extension-block-id="recommendation-block-price"
96
+ align="center">
97
+ <p
98
+ path="1"
99
+ contenteditable="false"
100
+ style="font-size: 16px; color: #333333; font-weight: bold; text-align: center;">
101
+ <strong path="1,0">18,00 TRY</strong>
102
+ </p>
103
+ </td>
104
+ </tr>
105
+ `,
106
+ productOldPrice: () => `
107
+ <tr>
108
+ <td
109
+ class="esd-block-text product-old-price"
110
+ esd-extension-block-id="recommendation-block-old-price"
111
+ align="center">
112
+ <p
113
+ path="1"
114
+ contenteditable="false"
115
+ style="font-size: 14px; color: #999999; text-decoration: line-through; text-align: center;">
116
+ <s path="1,0">20,00 TRY</s>
117
+ </p>
118
+ </td>
119
+ </tr>
120
+ `,
121
+ productButton: (t) => `
122
+ <tr>
123
+ <td
124
+ class="esd-block-button product-button"
125
+ esd-extension-block-id="recommendation-block-button"
126
+ align="center">
127
+ <span class="es-button-border" style="display: block;">
128
+ <a
129
+ href="${t.url}"
130
+ target="_blank"
131
+ class="es-button">
132
+ {-{-PRODUCT_BUTTON_TEXT-}-}
133
+ </a>
134
+ </span>
135
+ </td>
136
+ </tr>
137
+ `
138
+ };
139
+ function d(t, e, o) {
140
+ return n(
141
+ t,
142
+ e,
143
+ l,
144
+ o
145
+ );
146
+ }
147
+ export {
148
+ i as DEFAULTS,
149
+ a as default,
150
+ p as getDefaultProducts,
151
+ d as prepareProductRows
152
+ };
@@ -0,0 +1,180 @@
1
+ const R = {
2
+ TITLE: "You May Also Like!"
3
+ }, O = `
4
+ <tr>
5
+ <td class="spacer" style="height: 20px;"></td>
6
+ </tr>
7
+ `, w = `
8
+ <tr>
9
+ <td>
10
+ <table width="100%" height="100%" cellpadding="0" cellspacing="0" border="0">
11
+ {-{-PRODUCTS-}-}
12
+ </table>
13
+ </td>
14
+ </tr>
15
+ `, i = `
16
+ <td width="{-{-COLUMN_WIDTH-}-}" style="padding: 0 5px;" valign="top" height="100%">
17
+ <table
18
+ width="100%"
19
+ height="100%"
20
+ cellpadding="0"
21
+ cellspacing="0"
22
+ border="0"
23
+ class="product-card-wrapper">
24
+ <tr>
25
+ <td
26
+ class="product-attribute-cell"
27
+ valign="top">
28
+ <table cellpadding="0" cellspacing="0" role="presentation" width="100%">
29
+ <tbody>
30
+ {-{-PRODUCT_CONTENT-}-}
31
+ </tbody>
32
+ </table>
33
+ </td>
34
+ </tr>
35
+ </table>
36
+ </td>
37
+ `, b = [
38
+ "productImage",
39
+ "productName",
40
+ "productOldPrice",
41
+ "productPrice",
42
+ "productButton"
43
+ ];
44
+ function C() {
45
+ return [
46
+ {
47
+ name: "Product Name",
48
+ image_url: "https://email-static.useinsider.com/stripo/modules/email-recommendation-v3/assets/images/image-placeholder.png",
49
+ price: { USD: 18 },
50
+ original_price: { USD: 20 },
51
+ discount: { USD: 2 },
52
+ url: "https://example.com/product/1",
53
+ item_id: "1",
54
+ in_stock: 1,
55
+ locale: "en",
56
+ product_attributes: {},
57
+ category: []
58
+ },
59
+ {
60
+ name: "Belt",
61
+ image_url: "https://inshoppingcart.com/ins-html/wp-content/uploads/2018/09/belt-2.jpg",
62
+ price: { TRY: 55 },
63
+ original_price: { TRY: 65 },
64
+ discount: { TRY: 10 },
65
+ url: "https://example.com/product/2",
66
+ item_id: "2",
67
+ in_stock: 1,
68
+ locale: "tr",
69
+ product_attributes: {},
70
+ category: []
71
+ },
72
+ {
73
+ name: "Beanie",
74
+ image_url: "https://inshoppingcart.com/ins-html/wp-content/uploads/2018/08/beanie-with-logo-1.jpg",
75
+ price: { TRY: 18 },
76
+ original_price: { TRY: 20 },
77
+ discount: { TRY: 2 },
78
+ url: "https://example.com/product/3",
79
+ item_id: "3",
80
+ in_stock: 1,
81
+ locale: "tr",
82
+ product_attributes: {},
83
+ category: []
84
+ },
85
+ {
86
+ name: "Album",
87
+ image_url: "https://inshoppingcart.com/ins-html/wp-content/uploads/2018/12/poster_2_up.jpg",
88
+ price: { TRY: 15 },
89
+ original_price: { TRY: 15 },
90
+ discount: { TRY: 0 },
91
+ url: "https://example.com/product/4",
92
+ item_id: "4",
93
+ in_stock: 1,
94
+ locale: "tr",
95
+ product_attributes: {},
96
+ category: []
97
+ },
98
+ {
99
+ name: "Flying Ninja with a very long product name",
100
+ image_url: "https://inshoppingcart.com/ins-html/wp-content/uploads/2018/09/belt-2.jpg",
101
+ price: { TRY: 12 },
102
+ original_price: { TRY: 15 },
103
+ discount: { TRY: 3 },
104
+ url: "https://example.com/product/5",
105
+ item_id: "5",
106
+ in_stock: 1,
107
+ locale: "tr",
108
+ product_attributes: {},
109
+ category: []
110
+ },
111
+ {
112
+ name: "Single",
113
+ image_url: "https://inshoppingcart.com/ins-html/wp-content/uploads/2018/12/poster_2_up.jpg",
114
+ price: { TRY: 22555 },
115
+ original_price: { TRY: 33989 },
116
+ discount: { TRY: 11434 },
117
+ url: "https://example.com/product/6",
118
+ item_id: "6",
119
+ in_stock: 1,
120
+ locale: "tr",
121
+ product_attributes: {},
122
+ category: []
123
+ }
124
+ ];
125
+ }
126
+ function N(p, r, e, l = b) {
127
+ const n = (100 / r).toFixed(2), a = [];
128
+ for (let o = 0; o < p.length; o += r)
129
+ a.push(p.slice(o, o + r));
130
+ let c = "";
131
+ return a.forEach((o, _) => {
132
+ _ > 0 && (c += O);
133
+ let s = "", u = "", d = "", m = "", g = "";
134
+ o.forEach((t) => {
135
+ s += i.replace(
136
+ "{-{-PRODUCT_CONTENT-}-}",
137
+ e.productImage(t)
138
+ ), u += i.replace(
139
+ "{-{-PRODUCT_CONTENT-}-}",
140
+ e.productName(t)
141
+ ), d += i.replace(
142
+ "{-{-PRODUCT_CONTENT-}-}",
143
+ e.productPrice(t)
144
+ ), m += i.replace(
145
+ "{-{-PRODUCT_CONTENT-}-}",
146
+ e.productOldPrice(t)
147
+ ), g += i.replace(
148
+ "{-{-PRODUCT_CONTENT-}-}",
149
+ e.productButton(t)
150
+ );
151
+ });
152
+ const T = {
153
+ productImage: s,
154
+ productName: u,
155
+ productPrice: d,
156
+ productOldPrice: m,
157
+ productButton: g
158
+ }, h = l.filter((t) => !!T[t]).map((t) => `<tr>${T[t]}</tr>`).join("");
159
+ c += w.replace("{-{-PRODUCTS-}-}", h);
160
+ }), c.replaceAll("{-{-COLUMN_WIDTH-}-}", `${n}%`);
161
+ }
162
+ function P(p, r, e, l, n = R.TITLE, a) {
163
+ const c = N(
164
+ r,
165
+ e,
166
+ l,
167
+ a
168
+ );
169
+ return p.replace("{-{-TITLE-}-}", n).replace("{-{-PRODUCT_ROWS-}-}", c);
170
+ }
171
+ export {
172
+ R as DEFAULTS,
173
+ b as DEFAULT_CARD_COMPOSITION,
174
+ P as generateTemplate,
175
+ C as getDefaultProducts,
176
+ N as prepareProductRows,
177
+ i as productCardWrapper,
178
+ w as productRow,
179
+ O as spacer
180
+ };
@@ -1,28 +1,28 @@
1
1
  function l(t) {
2
2
  if (t.length === 0)
3
3
  return "";
4
- const o = t.sort((r, e) => r.filterNumber - e.filterNumber), n = o.map((r) => `[${r.attribute}][${r.operatorReplace}][${r.value}]`), [i, ...p] = n;
5
- let u = i;
4
+ const o = t.sort((r, e) => r.filterNumber - e.filterNumber), n = o.map((r) => `[${r.attribute}][${r.operatorReplace}][${r.value}]`), [s, ...p] = n;
5
+ let u = s;
6
6
  for (let r = 0; r < p.length; r++) {
7
7
  const e = o[r + 1].innerGroupOperator;
8
8
  u += `${e}${p[r]}`;
9
9
  }
10
10
  return `(${u})`;
11
11
  }
12
- function f(t) {
12
+ function m(t) {
13
13
  if (!t || t.length === 0)
14
14
  return "";
15
- const o = t.reduce((r, e) => (r[e.filterGroup] || (r[e.filterGroup] = []), r[e.filterGroup].push(e), r), {}), n = Object.keys(o).map(Number).sort((r, e) => r - e), i = n.map((r) => {
15
+ const o = t.reduce((r, e) => (r[e.filterGroup] || (r[e.filterGroup] = []), r[e.filterGroup].push(e), r), {}), n = Object.keys(o).map(Number).sort((r, e) => r - e), s = n.map((r) => {
16
16
  const e = o[r];
17
17
  return l(e);
18
- }), [p, ...u] = i;
19
- let s = p;
18
+ }), [p, ...u] = s;
19
+ let i = p;
20
20
  for (let r = 0; r < u.length; r++) {
21
21
  const e = n[r + 1], c = o[e][0].outerGroupOperator;
22
- s += `${c}${u[r]}`;
22
+ i += `${c}${u[r]}`;
23
23
  }
24
- return s.trim();
24
+ return console.debug("🎉 Complete query generated:", i), i.trim();
25
25
  }
26
26
  export {
27
- f as generateCompleteFilterQuery
27
+ m as generateCompleteFilterQuery
28
28
  };
@@ -1,21 +1,21 @@
1
1
  import { ExtensionBuilder as e } from "../../../node_modules/@stripoinc/ui-editor-extensions/dist/esm/index.js";
2
2
  import { UnsubscribeBlock as i } from "./block.js";
3
3
  import { UnsubscribeControl as t } from "./control.js";
4
- import { PreviewUIElement as o } from "./elements/preview.js";
5
- import { UnsubscribeIconsRegistry as r } from "./iconsRegistry.js";
6
- import { SettingsPanel as s } from "./settingsPanel.js";
4
+ import { PreviewUIElement as s } from "./elements/preview.js";
5
+ import { UnsubscribeIconsRegistry as o } from "./iconsRegistry.js";
6
+ import { SettingsPanel as r } from "./settingsPanel.js";
7
7
  import n from "./styles.css.js";
8
- import { UnsubscribeTagRegistry as l } from "./tagRegistry.js";
9
- const f = new e().addBlock(i).withSettingsPanelRegistry(s).addControl(t).addUiElement(o).addStyles(n).withLocalization({
8
+ import { UnsubscribeTagRegistry as c } from "./tagRegistry.js";
9
+ const g = new e().addBlock(i).withSettingsPanelRegistry(r).addControl(t).addUiElement(s).addStyles(n).withLocalization({
10
10
  en: {
11
- "Unsubscribe Block": "Unsubscribe Block",
12
- "Unsubscribe Block Description": "Add an unsubscribe link to your email",
11
+ "Unsubscribe Block": "Unsubscribe",
12
+ "Unsubscribe Block Description": "Unsubscribe lets you add an Unsubscribe Link to direct users to opt out of receiving your messages.",
13
13
  "Select Template": "Select Template",
14
14
  "Unsubscribe Template": "Unsubscribe Template",
15
15
  Showing: "Showing",
16
16
  of: "of"
17
17
  }
18
- }).withUiElementTagRegistry(l).withIconsRegistry(r).build();
18
+ }).withUiElementTagRegistry(c).withIconsRegistry(o).build();
19
19
  export {
20
- f as default
20
+ g as default
21
21
  };
@@ -1,12 +1,12 @@
1
1
  var c = Object.defineProperty;
2
2
  var I = (a, r, e) => r in a ? c(a, r, { enumerable: !0, configurable: !0, writable: !0, value: e }) : a[r] = e;
3
- var l = (a, r, e) => I(a, typeof r != "symbol" ? r + "" : r, e);
3
+ var u = (a, r, e) => I(a, typeof r != "symbol" ? r + "" : r, e);
4
4
  import { Control as O, UIElementType as t, UEAttr as $ } from "../../node_modules/@stripoinc/ui-editor-extensions/dist/esm/index.js";
5
5
  class _ extends O {
6
6
  constructor() {
7
7
  super(...arguments);
8
- l(this, "currentNode");
9
- l(this, "lastBlockInstanceId", null);
8
+ u(this, "currentNode");
9
+ u(this, "lastBlockInstanceId", null);
10
10
  }
11
11
  getContainer() {
12
12
  var e;
@@ -52,10 +52,9 @@ class _ extends O {
52
52
  const T = o !== this.lastBlockInstanceId;
53
53
  return T ? (this.currentNode && e(this.currentNode), n(), this.lastBlockInstanceId = o) : n(), T;
54
54
  }
55
- _GuLabel({ text: e, name: n = "", position: E = "left" }) {
55
+ _GuLabel({ text: e, name: n = "" }) {
56
56
  return `
57
57
  <${t.LABEL}
58
- style="${E === "top" ? "margin-bottom: 8px;" : ""}"
59
58
  ${$.LABEL.text}="${e}"
60
59
  ${$.LABEL.name}="${n || `${e} Label`}">
61
60
  </${t.LABEL}>
@@ -170,9 +169,9 @@ class _ extends O {
170
169
  _GuOrderable(e, n) {
171
170
  let E = "";
172
171
  n.forEach((T) => {
173
- const u = $.ORDERABLE_ITEM && "name" in $.ORDERABLE_ITEM ? $.ORDERABLE_ITEM.name : "name";
172
+ const l = $.ORDERABLE_ITEM && "name" in $.ORDERABLE_ITEM ? $.ORDERABLE_ITEM.name : "name";
174
173
  E += `
175
- <${t.ORDERABLE_ITEM} ${u}="${T.key}">
174
+ <${t.ORDERABLE_ITEM} ${l}="${T.key}">
176
175
  ${T.content}
177
176
  </${t.ORDERABLE_ITEM}>
178
177
  `;