@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
@@ -1,181 +0,0 @@
1
- import { RecommendationBlockId as o } from "../../constants/blockIds.js";
2
- import { ATTR_PRODUCT_BUTTON as l, ATTR_PRODUCT_IMAGE as d, ATTR_PRODUCT_OMNIBUS_DISCOUNT as u, ATTR_PRODUCT_OMNIBUS_PRICE as m, ATTR_PRODUCT_OLD_PRICE as g, ATTR_PRODUCT_PRICE as f, ATTR_PRODUCT_NAME as x } from "../../constants/selectors.js";
3
- import { useRecommendationExtensionStore as T } from "../../store/recommendation.js";
4
- import { formatPrice as _ } from "../../utils/priceFormatter.js";
5
- function p() {
6
- const t = T(), { currencySettings: e } = t.recommendationConfigs;
7
- return {
8
- code: e.value,
9
- symbol: e.symbol,
10
- alignment: e.alignment === "0" ? "before" : "after",
11
- decimalCount: parseInt(e.decimalCount) || 2,
12
- decimalSeparator: e.decimalSeparator,
13
- thousandSeparator: e.thousandSeparator
14
- };
15
- }
16
- function s(t, e = "price") {
17
- const n = p(), a = t[e], r = (a == null ? void 0 : a[n.code]) ?? Object.values(a ?? {})[0] ?? 0;
18
- return _({
19
- price: r,
20
- currency: n
21
- });
22
- }
23
- const k = {
24
- /**
25
- * Image cell - left column (120px fixed width)
26
- * Has recommendation-attribute-row class and data attributes for Card Composition control
27
- */
28
- [d]: (t) => `
29
- <td
30
- width="120"
31
- class="esd-block-image product-image-cell recommendation-attribute-row es-p5"
32
- esd-extension-block-id="${o.IMAGE}"
33
- data-attribute-type="${d}"
34
- data-visibility="1"
35
- align=center
36
- valign="middle">
37
- <a target="_blank" href="${t.url}">
38
- <img
39
- src="${t.image_url}"
40
- alt="${t.name}"
41
- style="display: block; max-width: 100%;"
42
- class="adapt-img product-image">
43
- </a>
44
- </td>
45
- `,
46
- /**
47
- * Name element - row for info cell table
48
- */
49
- [x]: (t) => `
50
- <tr>
51
- <td
52
- class="esd-block-text product-name"
53
- esd-extension-block-id="${o.NAME}"
54
- align="left">
55
- <p
56
- path="1"
57
- contenteditable="false"
58
- style="font-size: 16px; color: #333333; font-weight: 600; margin: 0;">
59
- <strong path="1,0">${t.name}</strong>
60
- </p>
61
- </td>
62
- </tr>
63
- `,
64
- /**
65
- * Price element - row for info cell table
66
- */
67
- [f]: (t) => `
68
- <tr>
69
- <td
70
- class="esd-block-text product-price"
71
- esd-extension-block-id="${o.PRICE}"
72
- align="left">
73
- <p
74
- path="1"
75
- contenteditable="false"
76
- style="font-size: 16px; color: #333333; font-weight: bold; margin: 0;">
77
- <strong path="1,0">${s(t, "price")}</strong>
78
- </p>
79
- </td>
80
- </tr>
81
- `,
82
- /**
83
- * Old price element - row for info cell table
84
- */
85
- [g]: (t) => `
86
- <tr>
87
- <td
88
- class="esd-block-text product-old-price"
89
- esd-extension-block-id="${o.OLD_PRICE}"
90
- align="left">
91
- <p
92
- path="1"
93
- contenteditable="false"
94
- style="font-size: 14px; color: #999999; text-decoration: line-through; margin: 0;">
95
- <s path="1,0">${s(t, "original_price")}</s>
96
- </p>
97
- </td>
98
- </tr>
99
- `,
100
- /**
101
- * Omnibus price element - row for info cell table
102
- */
103
- [m]: (t) => `
104
- <tr>
105
- <td
106
- class="esd-block-text product-omnibus-price"
107
- data-text-before="Lowest 30-day price: "
108
- data-text-after=""
109
- esd-extension-block-id="${o.OMNIBUS_PRICE}"
110
- align="left">
111
- <p
112
- path="1"
113
- contenteditable="false"
114
- style="font-size: 12px; color: #666666; margin: 0;">
115
- <span class="omnibus-text-before">Lowest 30-day price: </span>
116
- <span class="omnibus-price-value">${s(t, "original_price")}</span>
117
- <span class="omnibus-text-after"></span>
118
- </p>
119
- </td>
120
- </tr>
121
- `,
122
- /**
123
- * Omnibus discount element - row for info cell table
124
- */
125
- [u]: (t) => {
126
- var i, c;
127
- const e = p(), n = ((i = t.original_price) == null ? void 0 : i[e.code]) ?? Object.values(t.original_price ?? {})[0] ?? 0, a = ((c = t.price) == null ? void 0 : c[e.code]) ?? Object.values(t.price ?? {})[0] ?? 0, r = n > 0 ? Math.round((n - a) / n * 100) : 0, b = r > 0 ? `-${r}%` : "0%";
128
- return `
129
- <tr>
130
- <td
131
- class="esd-block-text product-omnibus-discount"
132
- data-text-before=""
133
- data-text-after=""
134
- esd-extension-block-id="${o.OMNIBUS_DISCOUNT}"
135
- align="left">
136
- <p
137
- path="1"
138
- contenteditable="false"
139
- style="font-size: 12px; color: #666666; margin: 0;">
140
- <span class="omnibus-text-before"></span>
141
- <span class="omnibus-discount-value">${b}</span>
142
- <span class="omnibus-text-after"></span>
143
- </p>
144
- </td>
145
- </tr>
146
- `;
147
- },
148
- /**
149
- * Button cell - right column (100px fixed width)
150
- * Has recommendation-attribute-row class and data attributes for Card Composition control
151
- */
152
- [l]: (t) => `
153
- <td
154
- width="100"
155
- class="esd-block-button button-cell recommendation-attribute-row product-button es-p5l es-p5r"
156
- esd-extension-block-id="${o.BUTTON}"
157
- data-attribute-type="${l}"
158
- data-visibility="1"
159
- align="center"
160
- valign="middle">
161
- <span
162
- class="es-button-border"
163
- style="
164
- border-width: 1px;
165
- background: rgb(217, 234, 211);
166
- border-color: rgb(106, 168, 79);
167
- ">
168
- <a
169
- href="${t.url}"
170
- target="_blank"
171
- class="es-button buy-button"
172
- style="color: rgb(56, 118, 29); background: rgb(217, 234, 211); padding: 5px 30px;">
173
- Buy
174
- </a>
175
- </span>
176
- </td>
177
- `
178
- };
179
- export {
180
- k as horizontalElementRenderer
181
- };
@@ -1,71 +0,0 @@
1
- import { ATTR_PRODUCT_IMAGE as E, ATTR_PRODUCT_NAME as s, ATTR_PRODUCT_OLD_PRICE as c, ATTR_PRODUCT_PRICE as a, ATTR_PRODUCT_OMNIBUS_PRICE as d, ATTR_PRODUCT_OMNIBUS_DISCOUNT as T, ATTR_PRODUCT_BUTTON as N } from "../../constants/selectors.js";
2
- import { spacer as $, DEFAULT_CARD_VISIBILITY as n } from "../utils.js";
3
- import { horizontalElementRenderer as o } from "./elementRenderer.js";
4
- const f = `
5
- <tr class="recommendation-product-row">
6
- <td style="padding: 0 5px;">
7
- <table
8
- width="100%"
9
- cellpadding="0"
10
- cellspacing="0"
11
- border="0"
12
- class="product-card-wrapper">
13
- <tr>
14
- {-{-PRODUCT_CONTENT-}-}
15
- </tr>
16
- </table>
17
- </td>
18
- </tr>
19
- `;
20
- function V(t) {
21
- const i = o[E](t), l = n[s], r = n[c], R = n[a], C = n[d], m = n[T], e = (y, A, p) => {
22
- const I = p ? "" : ' style="display: none;"', g = y.replace(/<tr>/, "").replace(/<\/tr>/, "");
23
- return `<tr
24
- class="recommendation-attribute-row"
25
- data-attribute-type="${A}"
26
- data-visibility="${p ? "1" : "0"}"${I}>${g}</tr>`;
27
- }, _ = e(
28
- o[s](t),
29
- s,
30
- l
31
- ), b = e(
32
- o[c](t),
33
- c,
34
- r
35
- ), O = e(
36
- o[a](t),
37
- a,
38
- R
39
- ), P = e(
40
- o[d](t),
41
- d,
42
- C
43
- ), u = e(
44
- o[T](t),
45
- T,
46
- m
47
- ), D = `
48
- <td class="product-info-cell" valign="middle" style="padding: 15px;">
49
- <table cellpadding="0" cellspacing="0" role="presentation" width="100%">
50
- <tbody>
51
- ${_}
52
- ${b}
53
- ${O}
54
- ${P}
55
- ${u}
56
- </tbody>
57
- </table>
58
- </td>
59
- `, U = o[N](t), w = i + D + U;
60
- return f.replace("{-{-PRODUCT_CONTENT-}-}", w);
61
- }
62
- function M(t) {
63
- return t.map((i, l) => {
64
- const r = V(i);
65
- return l > 0 ? $ + r : r;
66
- }).join("");
67
- }
68
- export {
69
- V as getHorizontalProductCard,
70
- M as prepareProductRows
71
- };
@@ -1,12 +0,0 @@
1
- import { DEFAULT_PRODUCTS_PER_ROW as s } from "../constants/layout.js";
2
- import { prepareProductRows as R } from "./horizontal/template.js";
3
- import { prepareProductRows as a } from "./vertical/template.js";
4
- function P(r, o, p = {}) {
5
- if (o === "horizontal")
6
- return R(r);
7
- const { productsPerRow: t = s, composition: e } = p;
8
- return a(r, t, e);
9
- }
10
- export {
11
- P as prepareProductRows
12
- };
@@ -1,116 +0,0 @@
1
- import { ATTR_PRODUCT_IMAGE as r, ATTR_PRODUCT_NAME as l, ATTR_PRODUCT_OLD_PRICE as o, ATTR_PRODUCT_PRICE as a, ATTR_PRODUCT_OMNIBUS_PRICE as c, ATTR_PRODUCT_OMNIBUS_DISCOUNT as n, ATTR_PRODUCT_BUTTON as s } from "../constants/selectors.js";
2
- const u = {
3
- TITLE: "You May Also Like!"
4
- }, _ = [
5
- r,
6
- l,
7
- o,
8
- a,
9
- c,
10
- n,
11
- s
12
- ], m = {
13
- [r]: !0,
14
- [l]: !0,
15
- [a]: !0,
16
- [o]: !0,
17
- [c]: !1,
18
- [n]: !1,
19
- [s]: !0
20
- }, d = `
21
- <tr>
22
- <td class="spacer" style="height: 10px;"></td>
23
- </tr>
24
- `, i = "https://email-static.useinsider.com/stripo/modules/email-recommendation-v3/assets/images/image-placeholder.png";
25
- function t(e) {
26
- return {
27
- name: "Product Name",
28
- image_url: i,
29
- price: { USD: 18 },
30
- original_price: { USD: 20 },
31
- discount: { USD: 2 },
32
- url: `https://example.com/product/${e}`,
33
- item_id: e,
34
- in_stock: 1,
35
- locale: "en",
36
- product_attributes: {},
37
- category: []
38
- };
39
- }
40
- function b() {
41
- return [
42
- t("1"),
43
- t("2"),
44
- t("3"),
45
- t("4"),
46
- t("5"),
47
- t("6")
48
- ];
49
- }
50
- function R(e = "vertical") {
51
- return `
52
- <td
53
- align="left"
54
- class="ins-recommendation-v3-block-v2 esd-block-recommendation-v3-block es-p20"${e === "horizontal" ? `
55
- data-layout="horizontal"` : ""}>
56
- <table width="100%" cellpadding="0" cellspacing="0" border="0">
57
- <tr>
58
- <td align="center">
59
- <table
60
- class="container"
61
- width="100%"
62
- cellpadding="0"
63
- cellspacing="0"
64
- border="0">
65
- <tbody>
66
- <tr>
67
- <td>
68
- <table
69
- width="100%"
70
- cellpadding="0"
71
- cellspacing="0"
72
- border="0">
73
- <tbody>
74
- <tr>
75
- <td
76
- class="esd-block-text es-p10t es-p10b es-p20l es-p20r"
77
- align="center">
78
- <p path="1" style="font-size: 28px; color: #333333;">
79
- <strong path="1,0">{-{-TITLE-}-}</strong>
80
- </p>
81
- </td>
82
- </tr>
83
- </tbody>
84
- </table>
85
- </td>
86
- </tr>
87
- ${d}
88
- <tr>
89
- <td>
90
- <table
91
- class="ins-recommendation-product-container"
92
- width="100%"
93
- cellpadding="0"
94
- cellspacing="0"
95
- border="0"
96
- >
97
- {-{-PRODUCT_ROWS-}-}
98
- </table>
99
- </td>
100
- </tr>
101
- </tbody>
102
- </table>
103
- </td>
104
- </tr>
105
- </table>
106
- </td>
107
- `;
108
- }
109
- export {
110
- u as DEFAULTS,
111
- _ as DEFAULT_CARD_COMPOSITION,
112
- m as DEFAULT_CARD_VISIBILITY,
113
- R as createBlockTemplate,
114
- b as getDefaultProducts,
115
- d as spacer
116
- };
@@ -1,211 +0,0 @@
1
- import { RecommendationBlockId as a } from "../../constants/blockIds.js";
2
- import { ATTR_PRODUCT_BUTTON as b, ATTR_PRODUCT_OMNIBUS_DISCOUNT as u, ATTR_PRODUCT_OMNIBUS_PRICE as h, ATTR_PRODUCT_OLD_PRICE as m, ATTR_PRODUCT_PRICE as f, ATTR_PRODUCT_NAME as T, ATTR_PRODUCT_IMAGE as x } from "../../constants/selectors.js";
3
- import { useRecommendationExtensionStore as _ } from "../../store/recommendation.js";
4
- import { formatPrice as $ } from "../../utils/priceFormatter.js";
5
- const s = "0 5px", n = "attribute-cell";
6
- function p() {
7
- const t = _(), { currencySettings: e } = t.recommendationConfigs;
8
- return {
9
- code: e.value,
10
- symbol: e.symbol,
11
- alignment: e.alignment === "0" ? "before" : "after",
12
- decimalCount: parseInt(e.decimalCount) || 2,
13
- decimalSeparator: e.decimalSeparator,
14
- thousandSeparator: e.thousandSeparator
15
- };
16
- }
17
- function r(t, e = "price") {
18
- const l = p(), o = t[e], c = (o == null ? void 0 : o[l.code]) ?? Object.values(o ?? {})[0] ?? 0;
19
- return $({
20
- price: c,
21
- currency: l
22
- });
23
- }
24
- const k = {
25
- [x]: (t) => `
26
- <td class="${n}" style="padding: ${s}; height: 100%;" valign="top">
27
- <table
28
- class="product-card-segment"
29
- width="100%"
30
- height="100%"
31
- cellpadding="0"
32
- cellspacing="0"
33
- border="0">
34
- <tr valign="top">
35
- <td
36
- class="esd-block-image product-image"
37
- align="center"
38
- esd-extension-block-id="${a.IMAGE}">
39
- <a target="_blank" href="${t.url}">
40
- <img
41
- src="${t.image_url}"
42
- alt="${t.name}"
43
- style="max-width: 100%; height: auto; margin: 0 auto; display: block;"
44
- class="adapt-img">
45
- </a>
46
- </td>
47
- </tr>
48
- </table>
49
- </td>
50
- `,
51
- [T]: (t) => `
52
- <td class="${n}" style="padding: ${s}; height: 100%;" valign="top">
53
- <table
54
- class="product-card-segment"
55
- width="100%"
56
- height="100%"
57
- cellpadding="0"
58
- cellspacing="0"
59
- border="0">
60
- <tr valign="top">
61
- <td
62
- class="esd-block-text product-name es-p10t es-p10b es-p15l es-p15r"
63
- align="center"
64
- esd-extension-block-id="${a.NAME}">
65
- <p path="1" contenteditable="false" style="font-size: 16px; color: #333333;">
66
- <strong path="1,0">${t.name}</strong>
67
- </p>
68
- </td>
69
- </tr>
70
- </table>
71
- </td>
72
- `,
73
- [f]: (t) => `
74
- <td class="${n}" style="padding: ${s}; height: 100%;" valign="top">
75
- <table
76
- class="product-card-segment"
77
- width="100%"
78
- height="100%"
79
- cellpadding="0"
80
- cellspacing="0"
81
- border="0">
82
- <tr valign="top">
83
- <td
84
- class="esd-block-text product-price es-p15l es-p15r"
85
- align="center"
86
- esd-extension-block-id="${a.PRICE}">
87
- <p path="1" contenteditable="false" style="font-size: 16px; color: #333333;">
88
- <strong path="1,0">${r(t, "price")}</strong>
89
- </p>
90
- </td>
91
- </tr>
92
- </table>
93
- </td>
94
- `,
95
- [m]: (t) => `
96
- <td class="${n}" style="padding: ${s}; height: 100%;" valign="top">
97
- <table
98
- class="product-card-segment"
99
- width="100%"
100
- height="100%"
101
- cellpadding="0"
102
- cellspacing="0"
103
- border="0">
104
- <tr valign="top">
105
- <td
106
- class="esd-block-text product-old-price es-p15l es-p15r"
107
- align="center"
108
- esd-extension-block-id="${a.OLD_PRICE}">
109
- <p path="1" contenteditable="false" style="font-size: 14px; color: #999999;">
110
- <s path="1,0">${r(t, "original_price")}</s>
111
- </p>
112
- </td>
113
- </tr>
114
- </table>
115
- </td>
116
- `,
117
- [h]: (t) => `
118
- <td class="${n}" style="padding: ${s}; height: 100%;" valign="top">
119
- <table
120
- class="product-card-segment"
121
- width="100%"
122
- height="100%"
123
- cellpadding="0"
124
- cellspacing="0"
125
- border="0">
126
- <tr valign="top">
127
- <td
128
- class="esd-block-text product-omnibus-price es-p15l es-p15r"
129
- align="center"
130
- data-text-before="Lowest 30-day price: "
131
- data-text-after=""
132
- esd-extension-block-id="${a.OMNIBUS_PRICE}">
133
- <p path="1" contenteditable="false" style="font-size: 12px; color: #666666;">
134
- <span class="omnibus-text-before">Lowest 30-day price: </span>
135
- <span class="omnibus-price-value">${r(t, "original_price")}</span>
136
- <span class="omnibus-text-after"></span>
137
- </p>
138
- </td>
139
- </tr>
140
- </table>
141
- </td>
142
- `,
143
- [u]: (t) => {
144
- var i, d;
145
- const e = p(), l = ((i = t.original_price) == null ? void 0 : i[e.code]) ?? Object.values(t.original_price ?? {})[0] ?? 0, o = ((d = t.price) == null ? void 0 : d[e.code]) ?? Object.values(t.price ?? {})[0] ?? 0, c = l > 0 ? Math.round((l - o) / l * 100) : 0, g = c > 0 ? `-${c}%` : "0%";
146
- return `
147
- <td class="${n}" style="padding: ${s}; height: 100%;" valign="top">
148
- <table
149
- class="product-card-segment"
150
- width="100%"
151
- height="100%"
152
- cellpadding="0"
153
- cellspacing="0"
154
- border="0">
155
- <tr valign="top">
156
- <td
157
- class="esd-block-text product-omnibus-discount es-p15l es-p15r"
158
- align="center"
159
- data-text-before=""
160
- data-text-after=""
161
- esd-extension-block-id="${a.OMNIBUS_DISCOUNT}">
162
- <p path="1" contenteditable="false" style="font-size: 12px; color: #666666;">
163
- <span class="omnibus-text-before"></span>
164
- <span class="omnibus-discount-value">${g}</span>
165
- <span class="omnibus-text-after"></span>
166
- </p>
167
- </td>
168
- </tr>
169
- </table>
170
- </td>
171
- `;
172
- },
173
- [b]: () => `
174
- <td class="${n}" style="padding: ${s}; height: 100%;" valign="top">
175
- <table
176
- class="product-card-segment"
177
- width="100%"
178
- height="100%"
179
- cellpadding="0"
180
- cellspacing="0"
181
- border="0">
182
- <tr valign="top">
183
- <td
184
- class="esd-block-button product-button es-p10t es-p10b"
185
- align="center"
186
- esd-extension-block-id="${a.BUTTON}">
187
- <span
188
- class="es-button-border"
189
- style="
190
- border-width: 1px;
191
- background: rgb(217, 234, 211);
192
- border-color: rgb(106, 168, 79);
193
- ">
194
- <a
195
- href="#"
196
- class="es-button buy-button"
197
- target="_blank"
198
- style="color: rgb(56, 118, 29); background: rgb(217, 234, 211);">
199
- Buy
200
- </a>
201
- </span>
202
- </td>
203
- </tr>
204
- </table>
205
- </td>
206
- `
207
- };
208
- export {
209
- n as ATTRIBUTE_CELL_CLASS,
210
- k as verticalElementRenderer
211
- };