@useinsider/guido 2.0.0-beta.af0a69f → 2.0.0-beta.b0493eb

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 (229) hide show
  1. package/README.md +2 -0
  2. package/dist/@types/config/schemas.js +3 -1
  3. package/dist/components/Guido.vue.js +1 -1
  4. package/dist/components/Guido.vue2.js +15 -17
  5. package/dist/components/organisms/email-preview/PreviewContainer.vue.js +3 -3
  6. package/dist/components/organisms/email-preview/amp/AmpErrorModal.vue.js +8 -8
  7. package/dist/components/organisms/email-preview/amp/AmpErrorModal.vue2.js +11 -12
  8. package/dist/components/organisms/email-preview/amp/AmpToggle.vue.js +8 -7
  9. package/dist/components/organisms/email-preview/amp/AmpToggle.vue2.js +12 -14
  10. package/dist/components/organisms/email-preview/desktop-preview/DesktopPreview.vue.js +14 -10
  11. package/dist/components/organisms/email-preview/desktop-preview/DesktopPreview.vue2.js +22 -18
  12. package/dist/components/organisms/email-preview/desktop-preview/EmailHeaderInfo.vue.js +17 -0
  13. package/dist/components/organisms/email-preview/desktop-preview/EmailHeaderInfo.vue2.js +20 -0
  14. package/dist/components/organisms/email-preview/desktop-preview/EmailSizeIndicator.vue.js +3 -3
  15. package/dist/components/organisms/email-preview/mobile-preview/ContentView.vue.js +10 -11
  16. package/dist/components/organisms/email-preview/mobile-preview/MobilePreview.vue.js +10 -11
  17. package/dist/components/organisms/email-preview/mobile-preview/MobilePreview.vue2.js +14 -15
  18. package/dist/components/organisms/header/LeftSlot.vue.js +9 -9
  19. package/dist/components/organisms/header/MiddleSlot.vue.js +4 -5
  20. package/dist/components/organisms/header/MiddleSlot.vue2.js +13 -14
  21. package/dist/components/organisms/header/RightSlot.vue.js +7 -7
  22. package/dist/components/organisms/onboarding/NewVersionPopup.vue2.js +15 -15
  23. package/dist/components/organisms/unsubscribe/UnsubscribeTypeSelection.vue.js +1 -1
  24. package/dist/components/organisms/unsubscribe/UnsubscribeTypeSelection.vue2.js +19 -20
  25. package/dist/components/wrappers/WpModal.vue.js +3 -4
  26. package/dist/composables/useStripo.js +40 -40
  27. package/dist/config/migrator/recommendationMigrator.js +2 -2
  28. package/dist/enums/onboarding.js +2 -1
  29. package/dist/enums/unsubscribe.js +21 -20
  30. package/dist/extensions/Blocks/Items/controls/cardComposition.js +13 -4
  31. package/dist/extensions/Blocks/Recommendation/block.js +40 -6
  32. package/dist/extensions/Blocks/Recommendation/constants/blockIds.js +4 -0
  33. package/dist/extensions/Blocks/Recommendation/constants/controlIds.js +4 -0
  34. package/dist/extensions/Blocks/Recommendation/constants/defaultConfig.js +64 -0
  35. package/dist/extensions/Blocks/Recommendation/constants/layout.js +20 -0
  36. package/dist/extensions/Blocks/Recommendation/constants/selectors.js +19 -0
  37. package/dist/extensions/Blocks/Recommendation/controls/button/index.js +64 -0
  38. package/dist/extensions/Blocks/Recommendation/controls/cardBackground/index.js +80 -0
  39. package/dist/extensions/Blocks/Recommendation/controls/cardComposition/index.js +232 -0
  40. package/dist/extensions/Blocks/Recommendation/controls/image/index.js +19 -0
  41. package/dist/extensions/Blocks/Recommendation/controls/layout/index.js +108 -0
  42. package/dist/extensions/Blocks/Recommendation/controls/main/algorithm.js +110 -0
  43. package/dist/extensions/Blocks/Recommendation/controls/main/currency.js +207 -0
  44. package/dist/extensions/Blocks/Recommendation/controls/main/filters.js +54 -0
  45. package/dist/extensions/Blocks/Recommendation/controls/main/index.js +148 -0
  46. package/dist/extensions/Blocks/Recommendation/controls/main/locale.js +74 -0
  47. package/dist/extensions/Blocks/Recommendation/controls/main/productLayout.js +124 -0
  48. package/dist/extensions/Blocks/Recommendation/controls/main/shuffle.js +71 -0
  49. package/dist/extensions/Blocks/Recommendation/controls/main/utils.js +124 -0
  50. package/dist/extensions/Blocks/Recommendation/controls/name/index.js +46 -0
  51. package/dist/extensions/Blocks/Recommendation/controls/name/textTrim.js +76 -0
  52. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/index.js +44 -0
  53. package/dist/extensions/Blocks/Recommendation/controls/omnibusDiscount/index.js +48 -0
  54. package/dist/extensions/Blocks/Recommendation/controls/omnibusDiscount/textAfter.js +73 -0
  55. package/dist/extensions/Blocks/Recommendation/controls/omnibusDiscount/textBefore.js +73 -0
  56. package/dist/extensions/Blocks/Recommendation/controls/omnibusPrice/index.js +48 -0
  57. package/dist/extensions/Blocks/Recommendation/controls/omnibusPrice/textAfter.js +73 -0
  58. package/dist/extensions/Blocks/Recommendation/controls/omnibusPrice/textBefore.js +73 -0
  59. package/dist/extensions/Blocks/Recommendation/controls/price/index.js +44 -0
  60. package/dist/extensions/Blocks/Recommendation/controls/spacing/index.js +222 -0
  61. package/dist/extensions/Blocks/Recommendation/extension.js +40 -43
  62. package/dist/extensions/Blocks/Recommendation/recommendation.css.js +13 -4
  63. package/dist/extensions/Blocks/Recommendation/services/configService.js +239 -0
  64. package/dist/extensions/Blocks/Recommendation/settingsPanel.js +128 -72
  65. package/dist/extensions/Blocks/Recommendation/store/recommendation.js +39 -34
  66. package/dist/extensions/Blocks/Recommendation/templates/horizontal/elementRenderer.js +181 -0
  67. package/dist/extensions/Blocks/Recommendation/templates/horizontal/template.js +71 -0
  68. package/dist/extensions/Blocks/Recommendation/templates/index.js +12 -0
  69. package/dist/extensions/Blocks/Recommendation/templates/utils.js +116 -0
  70. package/dist/extensions/Blocks/Recommendation/templates/vertical/elementRenderer.js +211 -0
  71. package/dist/extensions/Blocks/Recommendation/templates/vertical/migration.js +251 -0
  72. package/dist/extensions/Blocks/Recommendation/templates/vertical/template.js +62 -0
  73. package/dist/extensions/Blocks/Recommendation/types/nodeConfig.js +6 -0
  74. package/dist/extensions/Blocks/Recommendation/utils/filterUtil.js +9 -9
  75. package/dist/extensions/Blocks/Recommendation/utils/preserveTextStyles.js +36 -0
  76. package/dist/extensions/Blocks/Recommendation/utils/priceFormatter.js +29 -0
  77. package/dist/extensions/Blocks/Recommendation/utils/tagName.js +46 -0
  78. package/dist/extensions/Blocks/common-control.js +1 -1
  79. package/dist/extensions/Blocks/controlFactories.js +155 -121
  80. package/dist/guido.css +1 -1
  81. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/esm/index.js +424 -297
  82. package/dist/package.json.js +1 -1
  83. package/dist/services/stripoApi.js +6 -10
  84. package/dist/src/@types/config/schemas.d.ts +4 -0
  85. package/dist/src/components/wrappers/WpDrawer.vue.d.ts +1 -1
  86. package/dist/src/composables/useConfig.d.ts +2 -0
  87. package/dist/src/enums/onboarding.d.ts +1 -0
  88. package/dist/src/enums/unsubscribe.d.ts +1 -0
  89. package/dist/src/extensions/Blocks/Recommendation/block.d.ts +34 -0
  90. package/dist/src/extensions/Blocks/Recommendation/constants/blockIds.d.ts +13 -0
  91. package/dist/src/extensions/Blocks/Recommendation/{constants.d.ts → constants/controlIds.d.ts} +19 -11
  92. package/dist/src/extensions/Blocks/Recommendation/constants/defaultConfig.d.ts +49 -0
  93. package/dist/src/extensions/Blocks/Recommendation/constants/index.d.ts +13 -0
  94. package/dist/src/extensions/Blocks/Recommendation/constants/layout.d.ts +35 -0
  95. package/dist/src/extensions/Blocks/Recommendation/constants/selectors.d.ts +31 -0
  96. package/dist/src/extensions/Blocks/Recommendation/controls/button/index.d.ts +143 -0
  97. package/dist/src/extensions/Blocks/Recommendation/controls/cardBackground/index.d.ts +31 -0
  98. package/dist/src/extensions/Blocks/Recommendation/controls/cardComposition/index.d.ts +95 -0
  99. package/dist/src/extensions/Blocks/Recommendation/controls/image/index.d.ts +35 -0
  100. package/dist/src/extensions/Blocks/Recommendation/controls/index.d.ts +24 -0
  101. package/dist/src/extensions/Blocks/Recommendation/controls/layout/index.d.ts +36 -0
  102. package/dist/src/extensions/Blocks/Recommendation/controls/main/algorithm.d.ts +29 -0
  103. package/dist/src/extensions/Blocks/Recommendation/controls/main/currency.d.ts +45 -0
  104. package/dist/src/extensions/Blocks/Recommendation/controls/main/filters.d.ts +22 -0
  105. package/dist/src/extensions/Blocks/Recommendation/controls/main/index.d.ts +62 -0
  106. package/dist/src/extensions/Blocks/Recommendation/controls/main/locale.d.ts +24 -0
  107. package/dist/src/extensions/Blocks/Recommendation/controls/main/productLayout.d.ts +42 -0
  108. package/dist/src/extensions/Blocks/Recommendation/controls/main/shuffle.d.ts +23 -0
  109. package/dist/src/extensions/Blocks/Recommendation/controls/main/utils.d.ts +100 -0
  110. package/dist/src/extensions/Blocks/Recommendation/controls/name/index.d.ts +97 -0
  111. package/dist/src/extensions/Blocks/Recommendation/controls/name/textTrim.d.ts +16 -0
  112. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/index.d.ts +95 -0
  113. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusDiscount/index.d.ts +100 -0
  114. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusDiscount/textAfter.d.ts +15 -0
  115. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusDiscount/textBefore.d.ts +15 -0
  116. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusPrice/index.d.ts +100 -0
  117. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusPrice/textAfter.d.ts +15 -0
  118. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusPrice/textBefore.d.ts +15 -0
  119. package/dist/src/extensions/Blocks/Recommendation/controls/price/index.d.ts +95 -0
  120. package/dist/src/extensions/Blocks/Recommendation/controls/spacing/index.d.ts +83 -0
  121. package/dist/src/extensions/Blocks/Recommendation/extension.d.ts +9 -0
  122. package/dist/src/extensions/Blocks/Recommendation/services/configService.d.ts +151 -0
  123. package/dist/src/extensions/Blocks/Recommendation/services/index.d.ts +6 -0
  124. package/dist/src/extensions/Blocks/Recommendation/store/recommendation.d.ts +17 -16
  125. package/dist/src/extensions/Blocks/Recommendation/templates/horizontal/elementRenderer.d.ts +8 -0
  126. package/dist/src/extensions/Blocks/Recommendation/templates/horizontal/migration.d.ts +25 -0
  127. package/dist/src/extensions/Blocks/Recommendation/templates/horizontal/template.d.ts +18 -0
  128. package/dist/src/extensions/Blocks/Recommendation/templates/index.d.ts +39 -0
  129. package/dist/src/extensions/Blocks/Recommendation/templates/utils.d.ts +45 -0
  130. package/dist/src/extensions/Blocks/Recommendation/templates/vertical/elementRenderer.d.ts +7 -0
  131. package/dist/src/extensions/Blocks/Recommendation/templates/{migrationTemplate.d.ts → vertical/migration.d.ts} +11 -4
  132. package/dist/src/extensions/Blocks/Recommendation/templates/vertical/template.d.ts +33 -0
  133. package/dist/src/extensions/Blocks/Recommendation/types/index.d.ts +7 -0
  134. package/dist/src/extensions/Blocks/Recommendation/types/nodeConfig.d.ts +154 -0
  135. package/dist/src/extensions/Blocks/Recommendation/utils/preserveTextStyles.d.ts +19 -0
  136. package/dist/src/extensions/Blocks/Recommendation/utils/priceFormatter.d.ts +33 -0
  137. package/dist/src/extensions/Blocks/Recommendation/utils/stylePreserver.d.ts +113 -0
  138. package/dist/src/extensions/Blocks/Recommendation/utils/tagName.d.ts +77 -0
  139. package/dist/src/stores/config.d.ts +17 -0
  140. package/dist/static/assets/inbox-mockup.svg.js +4 -0
  141. package/dist/static/assets/phone-mockup.svg.js +4 -0
  142. package/dist/static/styles/components/wide-panel.css.js +0 -4
  143. package/dist/static/styles/customEditorStyle.css.js +38 -2
  144. package/package.json +3 -3
  145. package/dist/enums/academy.js +0 -8
  146. package/dist/extensions/Blocks/Recommendation/cardCompositionControl.js +0 -103
  147. package/dist/extensions/Blocks/Recommendation/constants.js +0 -5
  148. package/dist/extensions/Blocks/Recommendation/control.js +0 -306
  149. package/dist/extensions/Blocks/Recommendation/controls/button/align.js +0 -13
  150. package/dist/extensions/Blocks/Recommendation/controls/button/border.js +0 -13
  151. package/dist/extensions/Blocks/Recommendation/controls/button/borderRadius.js +0 -13
  152. package/dist/extensions/Blocks/Recommendation/controls/button/color.js +0 -13
  153. package/dist/extensions/Blocks/Recommendation/controls/button/fitToContent.js +0 -13
  154. package/dist/extensions/Blocks/Recommendation/controls/button/fontFamily.js +0 -13
  155. package/dist/extensions/Blocks/Recommendation/controls/button/margins.js +0 -13
  156. package/dist/extensions/Blocks/Recommendation/controls/button/paddings.js +0 -13
  157. package/dist/extensions/Blocks/Recommendation/controls/button/text.js +0 -13
  158. package/dist/extensions/Blocks/Recommendation/controls/button/textSize.js +0 -13
  159. package/dist/extensions/Blocks/Recommendation/controls/button/textStyleAndFontColor.js +0 -13
  160. package/dist/extensions/Blocks/Recommendation/controls/image/margins.js +0 -13
  161. package/dist/extensions/Blocks/Recommendation/controls/image/size.js +0 -13
  162. package/dist/extensions/Blocks/Recommendation/controls/name/align.js +0 -13
  163. package/dist/extensions/Blocks/Recommendation/controls/name/background.js +0 -13
  164. package/dist/extensions/Blocks/Recommendation/controls/name/color.js +0 -13
  165. package/dist/extensions/Blocks/Recommendation/controls/name/fontFamily.js +0 -13
  166. package/dist/extensions/Blocks/Recommendation/controls/name/paddings.js +0 -13
  167. package/dist/extensions/Blocks/Recommendation/controls/name/size.js +0 -13
  168. package/dist/extensions/Blocks/Recommendation/controls/name/style.js +0 -13
  169. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/align.js +0 -13
  170. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/background.js +0 -13
  171. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/color.js +0 -13
  172. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/fontFamily.js +0 -13
  173. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/paddings.js +0 -13
  174. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/size.js +0 -13
  175. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/style.js +0 -13
  176. package/dist/extensions/Blocks/Recommendation/controls/price/align.js +0 -13
  177. package/dist/extensions/Blocks/Recommendation/controls/price/background.js +0 -13
  178. package/dist/extensions/Blocks/Recommendation/controls/price/color.js +0 -13
  179. package/dist/extensions/Blocks/Recommendation/controls/price/fontFamily.js +0 -13
  180. package/dist/extensions/Blocks/Recommendation/controls/price/paddings.js +0 -13
  181. package/dist/extensions/Blocks/Recommendation/controls/price/size.js +0 -13
  182. package/dist/extensions/Blocks/Recommendation/controls/price/style.js +0 -13
  183. package/dist/extensions/Blocks/Recommendation/templates/blockTemplate.js +0 -160
  184. package/dist/extensions/Blocks/Recommendation/templates/migrationTemplate.js +0 -152
  185. package/dist/extensions/Blocks/Recommendation/templates/templateUtils.js +0 -180
  186. package/dist/src/enums/academy.d.ts +0 -12
  187. package/dist/src/extensions/Blocks/Recommendation/cardCompositionControl.d.ts +0 -28
  188. package/dist/src/extensions/Blocks/Recommendation/control.d.ts +0 -35
  189. package/dist/src/extensions/Blocks/Recommendation/controls/button/align.d.ts +0 -5
  190. package/dist/src/extensions/Blocks/Recommendation/controls/button/border.d.ts +0 -5
  191. package/dist/src/extensions/Blocks/Recommendation/controls/button/borderRadius.d.ts +0 -5
  192. package/dist/src/extensions/Blocks/Recommendation/controls/button/color.d.ts +0 -5
  193. package/dist/src/extensions/Blocks/Recommendation/controls/button/fitToContent.d.ts +0 -5
  194. package/dist/src/extensions/Blocks/Recommendation/controls/button/fontFamily.d.ts +0 -5
  195. package/dist/src/extensions/Blocks/Recommendation/controls/button/margins.d.ts +0 -5
  196. package/dist/src/extensions/Blocks/Recommendation/controls/button/paddings.d.ts +0 -5
  197. package/dist/src/extensions/Blocks/Recommendation/controls/button/text.d.ts +0 -5
  198. package/dist/src/extensions/Blocks/Recommendation/controls/button/textSize.d.ts +0 -5
  199. package/dist/src/extensions/Blocks/Recommendation/controls/button/textStyleAndFontColor.d.ts +0 -5
  200. package/dist/src/extensions/Blocks/Recommendation/controls/image/margins.d.ts +0 -5
  201. package/dist/src/extensions/Blocks/Recommendation/controls/image/size.d.ts +0 -5
  202. package/dist/src/extensions/Blocks/Recommendation/controls/name/align.d.ts +0 -5
  203. package/dist/src/extensions/Blocks/Recommendation/controls/name/background.d.ts +0 -5
  204. package/dist/src/extensions/Blocks/Recommendation/controls/name/color.d.ts +0 -5
  205. package/dist/src/extensions/Blocks/Recommendation/controls/name/fontFamily.d.ts +0 -5
  206. package/dist/src/extensions/Blocks/Recommendation/controls/name/paddings.d.ts +0 -5
  207. package/dist/src/extensions/Blocks/Recommendation/controls/name/size.d.ts +0 -5
  208. package/dist/src/extensions/Blocks/Recommendation/controls/name/style.d.ts +0 -5
  209. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/align.d.ts +0 -5
  210. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/background.d.ts +0 -5
  211. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/color.d.ts +0 -5
  212. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/fontFamily.d.ts +0 -5
  213. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/paddings.d.ts +0 -5
  214. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/size.d.ts +0 -5
  215. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/style.d.ts +0 -5
  216. package/dist/src/extensions/Blocks/Recommendation/controls/price/align.d.ts +0 -5
  217. package/dist/src/extensions/Blocks/Recommendation/controls/price/background.d.ts +0 -5
  218. package/dist/src/extensions/Blocks/Recommendation/controls/price/color.d.ts +0 -5
  219. package/dist/src/extensions/Blocks/Recommendation/controls/price/fontFamily.d.ts +0 -5
  220. package/dist/src/extensions/Blocks/Recommendation/controls/price/paddings.d.ts +0 -5
  221. package/dist/src/extensions/Blocks/Recommendation/controls/price/size.d.ts +0 -5
  222. package/dist/src/extensions/Blocks/Recommendation/controls/price/style.d.ts +0 -5
  223. package/dist/src/extensions/Blocks/Recommendation/templates/blockTemplate.d.ts +0 -16
  224. package/dist/src/extensions/Blocks/Recommendation/templates/templateUtils.d.ts +0 -44
  225. package/dist/static/assets/desktop/desktop-mockup-center.svg.js +0 -4
  226. package/dist/static/assets/desktop/desktop-mockup-left.svg.js +0 -4
  227. package/dist/static/assets/desktop/desktop-mockup-right.svg.js +0 -4
  228. package/dist/static/assets/mobile/email-mockup.svg.js +0 -4
  229. package/dist/static/assets/mobile/inbox-mockup.svg.js +0 -4
@@ -0,0 +1,181 @@
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
+ };
@@ -0,0 +1,71 @@
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
+ };
@@ -0,0 +1,12 @@
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
+ };
@@ -0,0 +1,116 @@
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
+ };
@@ -0,0 +1,211 @@
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
+ };