@useinsider/guido 2.0.0-beta.c948eab → 2.0.0-beta.c9db5fd

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 (201) hide show
  1. package/README.md +2 -0
  2. package/dist/@types/config/schemas.js +55 -39
  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 +11 -11
  19. package/dist/components/organisms/header/LeftSlot.vue2.js +12 -11
  20. package/dist/components/organisms/header/MiddleSlot.vue.js +4 -5
  21. package/dist/components/organisms/header/MiddleSlot.vue2.js +13 -14
  22. package/dist/components/organisms/header/RightSlot.vue.js +12 -12
  23. package/dist/components/organisms/header/RightSlot.vue2.js +20 -26
  24. package/dist/components/organisms/onboarding/NewVersionPopup.vue2.js +15 -15
  25. package/dist/components/organisms/unsubscribe/UnsubscribeTypeSelection.vue.js +1 -1
  26. package/dist/components/organisms/unsubscribe/UnsubscribeTypeSelection.vue2.js +19 -20
  27. package/dist/components/wrappers/WpModal.vue.js +3 -4
  28. package/dist/composables/useConfig.js +29 -27
  29. package/dist/composables/useSave.js +13 -11
  30. package/dist/composables/useStripo.js +40 -40
  31. package/dist/config/migrator/recommendationMigrator.js +1 -1
  32. package/dist/enums/onboarding.js +2 -1
  33. package/dist/enums/unsubscribe.js +21 -20
  34. package/dist/extensions/Blocks/Items/controls/cardComposition.js +13 -4
  35. package/dist/extensions/Blocks/Recommendation/block.js +1 -1
  36. package/dist/extensions/Blocks/Recommendation/constants/blockIds.js +4 -0
  37. package/dist/extensions/Blocks/Recommendation/constants/controlIds.js +4 -0
  38. package/dist/extensions/Blocks/Recommendation/constants/selectors.js +11 -0
  39. package/dist/extensions/Blocks/Recommendation/controls/button/index.js +64 -0
  40. package/dist/extensions/Blocks/Recommendation/controls/cardBackground/index.js +100 -0
  41. package/dist/extensions/Blocks/Recommendation/controls/cardComposition/index.js +243 -0
  42. package/dist/extensions/Blocks/Recommendation/controls/image/index.js +19 -0
  43. package/dist/extensions/Blocks/Recommendation/controls/layout/index.js +152 -0
  44. package/dist/extensions/Blocks/Recommendation/controls/main/index.js +370 -0
  45. package/dist/extensions/Blocks/Recommendation/controls/name/index.js +46 -0
  46. package/dist/extensions/Blocks/Recommendation/controls/name/textTrim.js +76 -0
  47. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/index.js +44 -0
  48. package/dist/extensions/Blocks/Recommendation/controls/omnibusDiscount/index.js +48 -0
  49. package/dist/extensions/Blocks/Recommendation/controls/omnibusDiscount/textAfter.js +73 -0
  50. package/dist/extensions/Blocks/Recommendation/controls/omnibusDiscount/textBefore.js +73 -0
  51. package/dist/extensions/Blocks/Recommendation/controls/omnibusPrice/index.js +48 -0
  52. package/dist/extensions/Blocks/Recommendation/controls/omnibusPrice/textAfter.js +73 -0
  53. package/dist/extensions/Blocks/Recommendation/controls/omnibusPrice/textBefore.js +73 -0
  54. package/dist/extensions/Blocks/Recommendation/controls/price/index.js +44 -0
  55. package/dist/extensions/Blocks/Recommendation/controls/spacing/index.js +224 -0
  56. package/dist/extensions/Blocks/Recommendation/extension.js +39 -43
  57. package/dist/extensions/Blocks/Recommendation/recommendation.css.js +5 -0
  58. package/dist/extensions/Blocks/Recommendation/settingsPanel.js +127 -72
  59. package/dist/extensions/Blocks/Recommendation/store/recommendation.js +20 -20
  60. package/dist/extensions/Blocks/Recommendation/templates/horizontalElementRenderer.js +157 -0
  61. package/dist/extensions/Blocks/Recommendation/templates/horizontalTemplate.js +78 -0
  62. package/dist/extensions/Blocks/Recommendation/templates/templateUtils.js +67 -88
  63. package/dist/extensions/Blocks/Recommendation/templates/verticalElementRenderer.js +186 -0
  64. package/dist/extensions/Blocks/Recommendation/templates/verticalMigrationTemplate.js +256 -0
  65. package/dist/extensions/Blocks/Recommendation/templates/verticalTemplate.js +81 -0
  66. package/dist/extensions/Blocks/Recommendation/utils/preserveTextStyles.js +25 -0
  67. package/dist/extensions/Blocks/Unsubscribe/extension.js +9 -9
  68. package/dist/extensions/Blocks/common-control.js +6 -7
  69. package/dist/extensions/Blocks/controlFactories.js +155 -121
  70. package/dist/guido.css +1 -1
  71. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/esm/index.js +361 -291
  72. package/dist/package.json.js +1 -1
  73. package/dist/services/stripoApi.js +6 -10
  74. package/dist/src/@types/config/index.d.ts +2 -2
  75. package/dist/src/@types/config/schemas.d.ts +30 -0
  76. package/dist/src/@types/config/types.d.ts +7 -1
  77. package/dist/src/components/organisms/header/RightSlot.vue.d.ts +1 -1
  78. package/dist/src/composables/useConfig.d.ts +8 -0
  79. package/dist/src/enums/onboarding.d.ts +1 -0
  80. package/dist/src/enums/unsubscribe.d.ts +1 -0
  81. package/dist/src/extensions/Blocks/Recommendation/constants/blockIds.d.ts +13 -0
  82. package/dist/src/extensions/Blocks/Recommendation/{constants.d.ts → constants/controlIds.d.ts} +19 -11
  83. package/dist/src/extensions/Blocks/Recommendation/constants/index.d.ts +11 -0
  84. package/dist/src/extensions/Blocks/Recommendation/constants/selectors.d.ts +19 -0
  85. package/dist/src/extensions/Blocks/Recommendation/controls/button/index.d.ts +143 -0
  86. package/dist/src/extensions/Blocks/Recommendation/controls/cardBackground/index.d.ts +41 -0
  87. package/dist/src/extensions/Blocks/Recommendation/controls/cardComposition/index.d.ts +95 -0
  88. package/dist/src/extensions/Blocks/Recommendation/controls/image/index.d.ts +35 -0
  89. package/dist/src/extensions/Blocks/Recommendation/controls/index.d.ts +23 -0
  90. package/dist/src/extensions/Blocks/Recommendation/controls/layout/index.d.ts +50 -0
  91. package/dist/src/extensions/Blocks/Recommendation/{control.d.ts → controls/main/index.d.ts} +19 -3
  92. package/dist/src/extensions/Blocks/Recommendation/controls/name/index.d.ts +97 -0
  93. package/dist/src/extensions/Blocks/Recommendation/controls/name/textTrim.d.ts +16 -0
  94. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/index.d.ts +95 -0
  95. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusDiscount/index.d.ts +100 -0
  96. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusDiscount/textAfter.d.ts +15 -0
  97. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusDiscount/textBefore.d.ts +15 -0
  98. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusPrice/index.d.ts +100 -0
  99. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusPrice/textAfter.d.ts +15 -0
  100. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusPrice/textBefore.d.ts +15 -0
  101. package/dist/src/extensions/Blocks/Recommendation/controls/price/index.d.ts +95 -0
  102. package/dist/src/extensions/Blocks/Recommendation/controls/spacing/index.d.ts +77 -0
  103. package/dist/src/extensions/Blocks/Recommendation/extension.d.ts +9 -0
  104. package/dist/src/extensions/Blocks/Recommendation/templates/horizontalElementRenderer.d.ts +8 -0
  105. package/dist/src/extensions/Blocks/Recommendation/templates/horizontalMigrationTemplate.d.ts +25 -0
  106. package/dist/src/extensions/Blocks/Recommendation/templates/horizontalTemplate.d.ts +28 -0
  107. package/dist/src/extensions/Blocks/Recommendation/templates/templateUtils.d.ts +59 -21
  108. package/dist/src/extensions/Blocks/Recommendation/templates/verticalElementRenderer.d.ts +7 -0
  109. package/dist/src/extensions/Blocks/Recommendation/templates/{migrationTemplate.d.ts → verticalMigrationTemplate.d.ts} +11 -4
  110. package/dist/src/extensions/Blocks/Recommendation/templates/{blockTemplate.d.ts → verticalTemplate.d.ts} +13 -9
  111. package/dist/src/extensions/Blocks/Recommendation/utils/preserveTextStyles.d.ts +19 -0
  112. package/dist/src/extensions/Blocks/common-control.d.ts +1 -1
  113. package/dist/src/stores/config.d.ts +164 -1
  114. package/dist/static/assets/inbox-mockup.svg.js +4 -0
  115. package/dist/static/assets/phone-mockup.svg.js +4 -0
  116. package/dist/static/styles/components/button.css.js +1 -1
  117. package/dist/static/styles/components/wide-panel.css.js +0 -4
  118. package/dist/static/styles/customEditorStyle.css.js +38 -2
  119. package/dist/stores/config.js +7 -0
  120. package/package.json +3 -3
  121. package/dist/enums/academy.js +0 -8
  122. package/dist/extensions/Blocks/Recommendation/cardCompositionControl.js +0 -103
  123. package/dist/extensions/Blocks/Recommendation/constants.js +0 -5
  124. package/dist/extensions/Blocks/Recommendation/control.js +0 -306
  125. package/dist/extensions/Blocks/Recommendation/controls/button/align.js +0 -13
  126. package/dist/extensions/Blocks/Recommendation/controls/button/border.js +0 -13
  127. package/dist/extensions/Blocks/Recommendation/controls/button/borderRadius.js +0 -13
  128. package/dist/extensions/Blocks/Recommendation/controls/button/color.js +0 -13
  129. package/dist/extensions/Blocks/Recommendation/controls/button/fitToContent.js +0 -13
  130. package/dist/extensions/Blocks/Recommendation/controls/button/fontFamily.js +0 -13
  131. package/dist/extensions/Blocks/Recommendation/controls/button/margins.js +0 -13
  132. package/dist/extensions/Blocks/Recommendation/controls/button/paddings.js +0 -13
  133. package/dist/extensions/Blocks/Recommendation/controls/button/text.js +0 -13
  134. package/dist/extensions/Blocks/Recommendation/controls/button/textSize.js +0 -13
  135. package/dist/extensions/Blocks/Recommendation/controls/button/textStyleAndFontColor.js +0 -13
  136. package/dist/extensions/Blocks/Recommendation/controls/image/margins.js +0 -13
  137. package/dist/extensions/Blocks/Recommendation/controls/image/size.js +0 -13
  138. package/dist/extensions/Blocks/Recommendation/controls/name/align.js +0 -13
  139. package/dist/extensions/Blocks/Recommendation/controls/name/background.js +0 -13
  140. package/dist/extensions/Blocks/Recommendation/controls/name/color.js +0 -13
  141. package/dist/extensions/Blocks/Recommendation/controls/name/fontFamily.js +0 -13
  142. package/dist/extensions/Blocks/Recommendation/controls/name/paddings.js +0 -13
  143. package/dist/extensions/Blocks/Recommendation/controls/name/size.js +0 -13
  144. package/dist/extensions/Blocks/Recommendation/controls/name/style.js +0 -13
  145. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/align.js +0 -13
  146. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/background.js +0 -13
  147. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/color.js +0 -13
  148. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/fontFamily.js +0 -13
  149. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/paddings.js +0 -13
  150. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/size.js +0 -13
  151. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/style.js +0 -13
  152. package/dist/extensions/Blocks/Recommendation/controls/price/align.js +0 -13
  153. package/dist/extensions/Blocks/Recommendation/controls/price/background.js +0 -13
  154. package/dist/extensions/Blocks/Recommendation/controls/price/color.js +0 -13
  155. package/dist/extensions/Blocks/Recommendation/controls/price/fontFamily.js +0 -13
  156. package/dist/extensions/Blocks/Recommendation/controls/price/paddings.js +0 -13
  157. package/dist/extensions/Blocks/Recommendation/controls/price/size.js +0 -13
  158. package/dist/extensions/Blocks/Recommendation/controls/price/style.js +0 -13
  159. package/dist/extensions/Blocks/Recommendation/templates/blockTemplate.js +0 -160
  160. package/dist/extensions/Blocks/Recommendation/templates/migrationTemplate.js +0 -152
  161. package/dist/src/enums/academy.d.ts +0 -12
  162. package/dist/src/extensions/Blocks/Recommendation/cardCompositionControl.d.ts +0 -28
  163. package/dist/src/extensions/Blocks/Recommendation/controls/button/align.d.ts +0 -5
  164. package/dist/src/extensions/Blocks/Recommendation/controls/button/border.d.ts +0 -5
  165. package/dist/src/extensions/Blocks/Recommendation/controls/button/borderRadius.d.ts +0 -5
  166. package/dist/src/extensions/Blocks/Recommendation/controls/button/color.d.ts +0 -5
  167. package/dist/src/extensions/Blocks/Recommendation/controls/button/fitToContent.d.ts +0 -5
  168. package/dist/src/extensions/Blocks/Recommendation/controls/button/fontFamily.d.ts +0 -5
  169. package/dist/src/extensions/Blocks/Recommendation/controls/button/margins.d.ts +0 -5
  170. package/dist/src/extensions/Blocks/Recommendation/controls/button/paddings.d.ts +0 -5
  171. package/dist/src/extensions/Blocks/Recommendation/controls/button/text.d.ts +0 -5
  172. package/dist/src/extensions/Blocks/Recommendation/controls/button/textSize.d.ts +0 -5
  173. package/dist/src/extensions/Blocks/Recommendation/controls/button/textStyleAndFontColor.d.ts +0 -5
  174. package/dist/src/extensions/Blocks/Recommendation/controls/image/margins.d.ts +0 -5
  175. package/dist/src/extensions/Blocks/Recommendation/controls/image/size.d.ts +0 -5
  176. package/dist/src/extensions/Blocks/Recommendation/controls/name/align.d.ts +0 -5
  177. package/dist/src/extensions/Blocks/Recommendation/controls/name/background.d.ts +0 -5
  178. package/dist/src/extensions/Blocks/Recommendation/controls/name/color.d.ts +0 -5
  179. package/dist/src/extensions/Blocks/Recommendation/controls/name/fontFamily.d.ts +0 -5
  180. package/dist/src/extensions/Blocks/Recommendation/controls/name/paddings.d.ts +0 -5
  181. package/dist/src/extensions/Blocks/Recommendation/controls/name/size.d.ts +0 -5
  182. package/dist/src/extensions/Blocks/Recommendation/controls/name/style.d.ts +0 -5
  183. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/align.d.ts +0 -5
  184. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/background.d.ts +0 -5
  185. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/color.d.ts +0 -5
  186. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/fontFamily.d.ts +0 -5
  187. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/paddings.d.ts +0 -5
  188. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/size.d.ts +0 -5
  189. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/style.d.ts +0 -5
  190. package/dist/src/extensions/Blocks/Recommendation/controls/price/align.d.ts +0 -5
  191. package/dist/src/extensions/Blocks/Recommendation/controls/price/background.d.ts +0 -5
  192. package/dist/src/extensions/Blocks/Recommendation/controls/price/color.d.ts +0 -5
  193. package/dist/src/extensions/Blocks/Recommendation/controls/price/fontFamily.d.ts +0 -5
  194. package/dist/src/extensions/Blocks/Recommendation/controls/price/paddings.d.ts +0 -5
  195. package/dist/src/extensions/Blocks/Recommendation/controls/price/size.d.ts +0 -5
  196. package/dist/src/extensions/Blocks/Recommendation/controls/price/style.d.ts +0 -5
  197. package/dist/static/assets/desktop/desktop-mockup-center.svg.js +0 -4
  198. package/dist/static/assets/desktop/desktop-mockup-left.svg.js +0 -4
  199. package/dist/static/assets/desktop/desktop-mockup-right.svg.js +0 -4
  200. package/dist/static/assets/mobile/email-mockup.svg.js +0 -4
  201. package/dist/static/assets/mobile/inbox-mockup.svg.js +0 -4
@@ -1,47 +1,46 @@
1
- const R = {
1
+ import { ATTR_PRODUCT_IMAGE as s, ATTR_PRODUCT_NAME as n, ATTR_PRODUCT_OLD_PRICE as u, ATTR_PRODUCT_PRICE as m, ATTR_PRODUCT_OMNIBUS_PRICE as d, ATTR_PRODUCT_OMNIBUS_DISCOUNT as T, ATTR_PRODUCT_BUTTON as _ } from "../constants/selectors.js";
2
+ const E = {
2
3
  TITLE: "You May Also Like!"
3
- }, O = `
4
+ }, I = [
5
+ s,
6
+ n,
7
+ u,
8
+ m,
9
+ d,
10
+ T,
11
+ _
12
+ ], Y = {
13
+ [s]: !0,
14
+ [n]: !0,
15
+ [m]: !0,
16
+ [u]: !0,
17
+ [d]: !1,
18
+ [T]: !1,
19
+ [_]: !0
20
+ }, b = `
4
21
  <tr>
5
- <td class="spacer" style="height: 20px;"></td>
22
+ <td class="spacer" style="height: 10px;"></td>
6
23
  </tr>
7
- `, w = `
8
- <tr>
24
+ `, A = `
25
+ <tr class="recommendation-product-row">
9
26
  <td>
10
- <table width="100%" height="100%" cellpadding="0" cellspacing="0" border="0">
11
- {-{-PRODUCTS-}-}
27
+ <table width="100%" height="100%" cellpadding="0" cellspacing="0" border="0" class="product-card-wrapper">
28
+ <tbody>
29
+ {-{-ATTRIBUTE_ROWS-}-}
30
+ </tbody>
12
31
  </table>
13
32
  </td>
14
33
  </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() {
34
+ `, w = `
35
+ <tr
36
+ class="recommendation-attribute-row"
37
+ data-attribute-type="{-{-ATTR_TYPE-}-}"
38
+ data-visibility="{-{-VISIBILITY-}-}"
39
+ {-{-DISPLAY_STYLE-}-}>
40
+ {-{-CELLS-}-}
41
+ </tr>
42
+ `;
43
+ function L() {
45
44
  return [
46
45
  {
47
46
  name: "Product Name",
@@ -123,58 +122,38 @@ function C() {
123
122
  }
124
123
  ];
125
124
  }
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}%`);
125
+ function S(r, e, o, l = I) {
126
+ const i = (100 / e).toFixed(2);
127
+ return l.filter((t) => o[t]).map((t) => {
128
+ const c = Y[t] ?? !0, p = c ? "" : 'style="display: none;"', a = r.map((g) => {
129
+ const h = o[t];
130
+ return h(g).replace("<td", `<td width="${i}%"`);
131
+ }).join("");
132
+ return w.replace("{-{-ATTR_TYPE-}-}", t).replace("{-{-VISIBILITY-}-}", c ? "1" : "0").replace("{-{-DISPLAY_STYLE-}-}", p).replace("{-{-CELLS-}-}", a);
133
+ }).join("");
161
134
  }
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);
135
+ function O(r, e, o, l) {
136
+ const i = [];
137
+ for (let t = 0; t < r.length; t += e)
138
+ i.push(r.slice(t, t + e));
139
+ return i.map((t, c) => {
140
+ const p = S(
141
+ t,
142
+ e,
143
+ o,
144
+ l
145
+ ), a = A.replace("{-{-ATTRIBUTE_ROWS-}-}", p);
146
+ return c > 0 ? b + a : a;
147
+ }).join("");
170
148
  }
171
149
  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
150
+ E as DEFAULTS,
151
+ I as DEFAULT_CARD_COMPOSITION,
152
+ Y as DEFAULT_CARD_VISIBILITY,
153
+ w as attributeRowTemplate,
154
+ L as getDefaultProducts,
155
+ S as prepareVerticalAttributeRows,
156
+ O as prepareVerticalProductRows,
157
+ b as spacer,
158
+ A as verticalProductRowWrapper
180
159
  };
@@ -0,0 +1,186 @@
1
+ import { RecommendationBlockId as t } from "../constants/blockIds.js";
2
+ import { ATTR_PRODUCT_BUTTON as l, ATTR_PRODUCT_OMNIBUS_DISCOUNT as d, ATTR_PRODUCT_OMNIBUS_PRICE as n, ATTR_PRODUCT_OLD_PRICE as o, ATTR_PRODUCT_PRICE as c, ATTR_PRODUCT_NAME as i, ATTR_PRODUCT_IMAGE as r } from "../constants/selectors.js";
3
+ const e = "0 5px", s = "attribute-cell", b = {
4
+ [r]: (a) => `
5
+ <td class="${s}" style="padding: ${e}; height: 100%;" valign="top">
6
+ <table
7
+ class="product-card-segment"
8
+ width="100%"
9
+ height="100%"
10
+ cellpadding="0"
11
+ cellspacing="0"
12
+ border="0">
13
+ <tr valign="top">
14
+ <td
15
+ class="esd-block-image product-image"
16
+ align="center"
17
+ esd-extension-block-id="${t.IMAGE}">
18
+ <a target="_blank" href="${a.url}">
19
+ <img
20
+ src="${a.image_url}"
21
+ alt="${a.name}"
22
+ style="max-width: 100%; height: auto; margin: 0 auto; display: block;"
23
+ class="adapt-img">
24
+ </a>
25
+ </td>
26
+ </tr>
27
+ </table>
28
+ </td>
29
+ `,
30
+ [i]: (a) => `
31
+ <td class="${s}" style="padding: ${e}; height: 100%;" valign="top">
32
+ <table
33
+ class="product-card-segment"
34
+ width="100%"
35
+ height="100%"
36
+ cellpadding="0"
37
+ cellspacing="0"
38
+ border="0">
39
+ <tr valign="top">
40
+ <td
41
+ class="esd-block-text product-name es-p10t es-p10b es-p15l es-p15r"
42
+ align="center"
43
+ esd-extension-block-id="${t.NAME}">
44
+ <p path="1" contenteditable="false" style="font-size: 16px; color: #333333;">
45
+ <strong path="1,0">${a.name}</strong>
46
+ </p>
47
+ </td>
48
+ </tr>
49
+ </table>
50
+ </td>
51
+ `,
52
+ [c]: () => `
53
+ <td class="${s}" style="padding: ${e}; height: 100%;" valign="top">
54
+ <table
55
+ class="product-card-segment"
56
+ width="100%"
57
+ height="100%"
58
+ cellpadding="0"
59
+ cellspacing="0"
60
+ border="0">
61
+ <tr valign="top">
62
+ <td
63
+ class="esd-block-text product-price es-p15l es-p15r"
64
+ align="center"
65
+ esd-extension-block-id="${t.PRICE}">
66
+ <p path="1" contenteditable="false" style="font-size: 16px; color: #333333;">
67
+ <strong path="1,0">18,00 TRY</strong>
68
+ </p>
69
+ </td>
70
+ </tr>
71
+ </table>
72
+ </td>
73
+ `,
74
+ [o]: () => `
75
+ <td class="${s}" style="padding: ${e}; height: 100%;" valign="top">
76
+ <table
77
+ class="product-card-segment"
78
+ width="100%"
79
+ height="100%"
80
+ cellpadding="0"
81
+ cellspacing="0"
82
+ border="0">
83
+ <tr valign="top">
84
+ <td
85
+ class="esd-block-text product-old-price es-p15l es-p15r"
86
+ align="center"
87
+ esd-extension-block-id="${t.OLD_PRICE}">
88
+ <p path="1" contenteditable="false" style="font-size: 14px; color: #999999;">
89
+ <s path="1,0">20,00 TRY</s>
90
+ </p>
91
+ </td>
92
+ </tr>
93
+ </table>
94
+ </td>
95
+ `,
96
+ [n]: () => `
97
+ <td class="${s}" style="padding: ${e}; height: 100%;" valign="top">
98
+ <table
99
+ class="product-card-segment"
100
+ width="100%"
101
+ height="100%"
102
+ cellpadding="0"
103
+ cellspacing="0"
104
+ border="0">
105
+ <tr valign="top">
106
+ <td
107
+ class="esd-block-text product-omnibus-price es-p15l es-p15r"
108
+ align="center"
109
+ data-text-before="Lowest 30-day price: "
110
+ data-text-after=""
111
+ esd-extension-block-id="${t.OMNIBUS_PRICE}">
112
+ <p path="1" contenteditable="false" style="font-size: 12px; color: #666666;">
113
+ <span class="omnibus-text-before">Lowest 30-day price: </span>
114
+ <span class="omnibus-price-value">17,00 TRY</span>
115
+ <span class="omnibus-text-after"></span>
116
+ </p>
117
+ </td>
118
+ </tr>
119
+ </table>
120
+ </td>
121
+ `,
122
+ [d]: () => `
123
+ <td class="${s}" style="padding: ${e}; height: 100%;" valign="top">
124
+ <table
125
+ class="product-card-segment"
126
+ width="100%"
127
+ height="100%"
128
+ cellpadding="0"
129
+ cellspacing="0"
130
+ border="0">
131
+ <tr valign="top">
132
+ <td
133
+ class="esd-block-text product-omnibus-discount es-p15l es-p15r"
134
+ align="center"
135
+ data-text-before=""
136
+ data-text-after=""
137
+ esd-extension-block-id="${t.OMNIBUS_DISCOUNT}">
138
+ <p path="1" contenteditable="false" style="font-size: 12px; color: #666666;">
139
+ <span class="omnibus-text-before"></span>
140
+ <span class="omnibus-discount-value">-6%</span>
141
+ <span class="omnibus-text-after"></span>
142
+ </p>
143
+ </td>
144
+ </tr>
145
+ </table>
146
+ </td>
147
+ `,
148
+ [l]: () => `
149
+ <td class="${s}" style="padding: ${e}; height: 100%;" valign="top">
150
+ <table
151
+ class="product-card-segment"
152
+ width="100%"
153
+ height="100%"
154
+ cellpadding="0"
155
+ cellspacing="0"
156
+ border="0">
157
+ <tr valign="top">
158
+ <td
159
+ class="esd-block-button product-button es-p10t es-p10b"
160
+ align="center"
161
+ esd-extension-block-id="${t.BUTTON}">
162
+ <span
163
+ class="es-button-border"
164
+ style="
165
+ border-width: 1px;
166
+ background: rgb(217, 234, 211);
167
+ border-color: rgb(106, 168, 79);
168
+ ">
169
+ <a
170
+ href="#"
171
+ class="es-button buy-button"
172
+ target="_blank"
173
+ style="color: rgb(56, 118, 29); background: rgb(217, 234, 211);">
174
+ Buy
175
+ </a>
176
+ </span>
177
+ </td>
178
+ </tr>
179
+ </table>
180
+ </td>
181
+ `
182
+ };
183
+ export {
184
+ s as ATTRIBUTE_CELL_CLASS,
185
+ b as verticalElementRenderer
186
+ };
@@ -0,0 +1,256 @@
1
+ import { ATTR_PRODUCT_BUTTON as s, ATTR_PRODUCT_OMNIBUS_DISCOUNT as d, ATTR_PRODUCT_OMNIBUS_PRICE as c, ATTR_PRODUCT_OLD_PRICE as o, ATTR_PRODUCT_PRICE as i, ATTR_PRODUCT_NAME as r, ATTR_PRODUCT_IMAGE as p } from "../constants/selectors.js";
2
+ import { prepareVerticalProductRows as b } from "./templateUtils.js";
3
+ import { DEFAULTS as _, DEFAULT_CARD_COMPOSITION as f, DEFAULT_CARD_VISIBILITY as R, getDefaultProducts as y } from "./templateUtils.js";
4
+ const u = `
5
+ <td
6
+ align="left"
7
+ esd-extension-block-id="recommendation-block"
8
+ esd-handler-name="esd-extension-RecommendationBlock"
9
+ class="ins-recommendation-v3-block-v2 esd-block-recommendation-v3-block esd-extension-block es-p20"
10
+ >
11
+ <table width="100%" cellpadding="0" cellspacing="0" border="0">
12
+ <tr>
13
+ <td align="center">
14
+ <table
15
+ class="container"
16
+ width="100%"
17
+ cellpadding="0"
18
+ cellspacing="0"
19
+ border="0">
20
+ <tbody>
21
+ <tr>
22
+ <td>
23
+ <table
24
+ width="100%"
25
+ cellpadding="0"
26
+ cellspacing="0"
27
+ border="0">
28
+ <tbody>
29
+ <tr>
30
+ {-{-TITLE-}-}
31
+ </tr>
32
+ </tbody>
33
+ </table>
34
+ </td>
35
+ </tr>
36
+ <tr>
37
+ <td class="spacer" style="height: 20px;"></td>
38
+ </tr>
39
+ <tr>
40
+ <td>
41
+ <table
42
+ class="ins-recommendation-product-container"
43
+ width="100%"
44
+ cellpadding="0"
45
+ cellspacing="0"
46
+ border="0"
47
+ >
48
+ {-{-PRODUCT_ROWS-}-}
49
+ </table>
50
+ </td>
51
+ </tr>
52
+ </tbody>
53
+ </table>
54
+ </td>
55
+ </tr>
56
+ </table>
57
+ </td>
58
+ `, e = "0 5px", a = "attribute-cell", g = {
59
+ [p]: (t) => `
60
+ <td class="${a}" style="padding: ${e}; height: 100%;" valign="top">
61
+ <table
62
+ class="product-card-segment"
63
+ width="100%"
64
+ height="100%"
65
+ cellpadding="0"
66
+ cellspacing="0"
67
+ border="0">
68
+ <tr>
69
+ <td
70
+ class="esd-block-image product-image"
71
+ esd-extension-block-id="recommendation-block-image"
72
+ align="center"
73
+ style="font-size: 0px;">
74
+ <a target="_blank" href="${t.url}">
75
+ <img
76
+ src="${t.image_url}"
77
+ alt="${t.name}"
78
+ width="120"
79
+ style="display: block; max-width: 100%; height: auto;"
80
+ class="adapt-img">
81
+ </a>
82
+ </td>
83
+ </tr>
84
+ </table>
85
+ </td>
86
+ `,
87
+ [r]: (t) => `
88
+ <td class="${a}" style="padding: ${e}; height: 100%;" valign="top">
89
+ <table
90
+ class="product-card-segment"
91
+ width="100%"
92
+ height="100%"
93
+ cellpadding="0"
94
+ cellspacing="0"
95
+ border="0">
96
+ <tr>
97
+ <td
98
+ class="esd-block-text product-name"
99
+ esd-extension-block-id="recommendation-block-name"
100
+ align="center">
101
+ <p
102
+ path="1"
103
+ contenteditable="false"
104
+ style="font-size: 16px; color: #333333; font-weight: 600; text-align: center;">
105
+ <strong path="1,0">${t.name}</strong>
106
+ </p>
107
+ </td>
108
+ </tr>
109
+ </table>
110
+ </td>
111
+ `,
112
+ [i]: () => `
113
+ <td class="${a}" style="padding: ${e}; height: 100%;" valign="top">
114
+ <table
115
+ class="product-card-segment"
116
+ width="100%"
117
+ height="100%"
118
+ cellpadding="0"
119
+ cellspacing="0"
120
+ border="0">
121
+ <tr>
122
+ <td
123
+ class="esd-block-text product-price"
124
+ esd-extension-block-id="recommendation-block-price"
125
+ align="center">
126
+ <p
127
+ path="1"
128
+ contenteditable="false"
129
+ style="font-size: 16px; color: #333333; font-weight: bold; text-align: center;">
130
+ <strong path="1,0">18,00 TRY</strong>
131
+ </p>
132
+ </td>
133
+ </tr>
134
+ </table>
135
+ </td>
136
+ `,
137
+ [o]: () => `
138
+ <td class="${a}" style="padding: ${e}; height: 100%;" valign="top">
139
+ <table
140
+ class="product-card-segment"
141
+ width="100%"
142
+ height="100%"
143
+ cellpadding="0"
144
+ cellspacing="0"
145
+ border="0">
146
+ <tr>
147
+ <td
148
+ class="esd-block-text product-old-price"
149
+ esd-extension-block-id="recommendation-block-old-price"
150
+ align="center">
151
+ <p
152
+ path="1"
153
+ contenteditable="false"
154
+ style="font-size: 14px; color: #999999; text-decoration: line-through; text-align: center;">
155
+ <s path="1,0">20,00 TRY</s>
156
+ </p>
157
+ </td>
158
+ </tr>
159
+ </table>
160
+ </td>
161
+ `,
162
+ [c]: () => `
163
+ <td class="${a}" style="padding: ${e}; height: 100%;" valign="top">
164
+ <table
165
+ class="product-card-segment"
166
+ width="100%"
167
+ height="100%"
168
+ cellpadding="0"
169
+ cellspacing="0"
170
+ border="0">
171
+ <tr>
172
+ <td
173
+ class="esd-block-text product-omnibus-price"
174
+ esd-extension-block-id="recommendation-block-omnibus-price"
175
+ data-text-before="Lowest 30-day price: "
176
+ data-text-after=""
177
+ align="center">
178
+ <p
179
+ path="1"
180
+ contenteditable="false"
181
+ style="font-size: 14px; color: #666666; text-align: center;"><span
182
+ class="omnibus-text-before">Lowest 30-day price: </span><span
183
+ class="omnibus-price-value">17,00 TRY</span><span
184
+ class="omnibus-text-after"></span></p>
185
+ </td>
186
+ </tr>
187
+ </table>
188
+ </td>
189
+ `,
190
+ [d]: () => `
191
+ <td class="${a}" style="padding: ${e}; height: 100%;" valign="top">
192
+ <table
193
+ class="product-card-segment"
194
+ width="100%"
195
+ height="100%"
196
+ cellpadding="0"
197
+ cellspacing="0"
198
+ border="0">
199
+ <tr>
200
+ <td
201
+ class="esd-block-text product-omnibus-discount"
202
+ esd-extension-block-id="recommendation-block-omnibus-discount"
203
+ data-text-before=""
204
+ data-text-after=""
205
+ align="center">
206
+ <p
207
+ path="1"
208
+ contenteditable="false"
209
+ style="font-size: 14px; color: #666666; text-align: center;"><span
210
+ class="omnibus-text-before"></span><span
211
+ class="omnibus-discount-value">-6%</span><span
212
+ class="omnibus-text-after"></span></p>
213
+ </td>
214
+ </tr>
215
+ </table>
216
+ </td>
217
+ `,
218
+ [s]: (t) => `
219
+ <td class="${a}" style="padding: ${e}; height: 100%;" valign="top">
220
+ <table
221
+ class="product-card-segment"
222
+ width="100%"
223
+ height="100%"
224
+ cellpadding="0"
225
+ cellspacing="0"
226
+ border="0">
227
+ <tr>
228
+ <td
229
+ class="esd-block-button product-button"
230
+ esd-extension-block-id="recommendation-block-button"
231
+ align="center">
232
+ <span class="es-button-border" style="display: block;">
233
+ <a
234
+ href="${t.url}"
235
+ target="_blank"
236
+ class="es-button">
237
+ {-{-PRODUCT_BUTTON_TEXT-}-}
238
+ </a>
239
+ </span>
240
+ </td>
241
+ </tr>
242
+ </table>
243
+ </td>
244
+ `
245
+ };
246
+ function T(t, l, n) {
247
+ return b(t, l, g, n);
248
+ }
249
+ export {
250
+ _ as DEFAULTS,
251
+ f as DEFAULT_CARD_COMPOSITION,
252
+ R as DEFAULT_CARD_VISIBILITY,
253
+ u as default,
254
+ y as getDefaultProducts,
255
+ T as prepareProductRows
256
+ };