@useinsider/guido 2.1.0-beta.425dfd0 → 2.1.0-beta.42f5dfa

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 (166) hide show
  1. package/dist/components/organisms/extensions/recommendation/FilterSelectionDrawer.vue2.js +15 -14
  2. package/dist/composables/useActionsApi.js +15 -13
  3. package/dist/composables/useHtmlValidator.js +106 -84
  4. package/dist/composables/useRecommendation.js +54 -21
  5. package/dist/config/compiler/recommendationCompilerRules.js +45 -39
  6. package/dist/config/compiler/utils/recommendationCompilerUtils.js +116 -0
  7. package/dist/config/migrator/itemsBlockMigrator.js +140 -123
  8. package/dist/config/migrator/recommendationMigrator.js +2 -2
  9. package/dist/enums/extensions/recommendationBlock.js +1 -1
  10. package/dist/enums/recommendation.js +16 -15
  11. package/dist/extensions/Blocks/Items/block.js +19 -28
  12. package/dist/extensions/Blocks/Items/controls/button/link.js +19 -31
  13. package/dist/extensions/Blocks/Items/controls/cardComposition.js +124 -85
  14. package/dist/extensions/Blocks/Items/controls/image/link.js +19 -31
  15. package/dist/extensions/Blocks/Items/controls/name/trimming.js +28 -40
  16. package/dist/extensions/Blocks/Items/controls/price/currencyLocation.js +35 -47
  17. package/dist/extensions/Blocks/Items/controls/price/currencySymbol.js +49 -54
  18. package/dist/extensions/Blocks/Items/controls/price/formattedPrice.js +42 -51
  19. package/dist/extensions/Blocks/Items/controls/price/hideDiscount.js +23 -36
  20. package/dist/extensions/Blocks/Items/controls/price/priceOrientation.js +45 -57
  21. package/dist/extensions/Blocks/Items/controls/price/singlePrice.js +42 -60
  22. package/dist/extensions/Blocks/Items/controls/settingsControl.js +189 -196
  23. package/dist/extensions/Blocks/Items/enums/settingsEnums.js +0 -2
  24. package/dist/extensions/Blocks/Items/extension.js +8 -9
  25. package/dist/extensions/Blocks/Items/settingsPanel.js +10 -15
  26. package/dist/extensions/Blocks/Items/template.js +181 -175
  27. package/dist/extensions/Blocks/Items/utils/nodeConfigUtils.js +65 -65
  28. package/dist/extensions/Blocks/Recommendation/block.js +130 -9
  29. package/dist/extensions/Blocks/Recommendation/constants/blockIds.js +4 -0
  30. package/dist/extensions/Blocks/Recommendation/constants/controlIds.js +4 -0
  31. package/dist/extensions/Blocks/Recommendation/constants/defaultConfig.js +65 -0
  32. package/dist/extensions/Blocks/Recommendation/constants/layout.js +20 -0
  33. package/dist/extensions/Blocks/Recommendation/constants/selectors.js +19 -0
  34. package/dist/extensions/Blocks/Recommendation/controls/button/index.js +64 -0
  35. package/dist/extensions/Blocks/Recommendation/controls/cardBackground/index.js +80 -0
  36. package/dist/extensions/Blocks/Recommendation/controls/cardComposition/index.js +232 -0
  37. package/dist/extensions/Blocks/Recommendation/controls/image/index.js +19 -0
  38. package/dist/extensions/Blocks/Recommendation/controls/layout/index.js +92 -0
  39. package/dist/extensions/Blocks/Recommendation/controls/main/algorithm.js +102 -0
  40. package/dist/extensions/Blocks/Recommendation/controls/main/currency.js +209 -0
  41. package/dist/extensions/Blocks/Recommendation/controls/main/filters.js +52 -0
  42. package/dist/extensions/Blocks/Recommendation/controls/main/index.js +217 -0
  43. package/dist/extensions/Blocks/Recommendation/controls/main/locale.js +70 -0
  44. package/dist/extensions/Blocks/Recommendation/controls/main/productLayout.js +110 -0
  45. package/dist/extensions/Blocks/Recommendation/controls/main/shuffle.js +67 -0
  46. package/dist/extensions/Blocks/Recommendation/controls/main/utils.js +286 -0
  47. package/dist/extensions/Blocks/Recommendation/controls/name/index.js +46 -0
  48. package/dist/extensions/Blocks/Recommendation/controls/name/textTrim.js +108 -0
  49. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/index.js +44 -0
  50. package/dist/extensions/Blocks/Recommendation/controls/omnibusDiscount/index.js +48 -0
  51. package/dist/extensions/Blocks/Recommendation/controls/{omnibusDiscountTextAfterControl.js → omnibusDiscount/textAfter.js} +16 -14
  52. package/dist/extensions/Blocks/Recommendation/controls/{omnibusDiscountTextBeforeControl.js → omnibusDiscount/textBefore.js} +16 -14
  53. package/dist/extensions/Blocks/Recommendation/controls/omnibusPrice/index.js +48 -0
  54. package/dist/extensions/Blocks/Recommendation/controls/{omnibusPriceTextAfterControl.js → omnibusPrice/textAfter.js} +16 -14
  55. package/dist/extensions/Blocks/Recommendation/controls/{omnibusPriceTextBeforeControl.js → omnibusPrice/textBefore.js} +14 -12
  56. package/dist/extensions/Blocks/Recommendation/controls/price/index.js +44 -0
  57. package/dist/extensions/Blocks/Recommendation/controls/spacing/index.js +222 -0
  58. package/dist/extensions/Blocks/Recommendation/extension.js +40 -17
  59. package/dist/extensions/Blocks/Recommendation/iconsRegistry.js +19 -3
  60. package/dist/extensions/Blocks/Recommendation/recommendation.css.js +13 -4
  61. package/dist/extensions/Blocks/Recommendation/services/configService.js +240 -0
  62. package/dist/extensions/Blocks/Recommendation/settingsPanel.js +21 -10
  63. package/dist/extensions/Blocks/Recommendation/store/recommendation.js +230 -193
  64. package/dist/extensions/Blocks/Recommendation/templates/grid/elementRenderer.js +233 -0
  65. package/dist/extensions/Blocks/Recommendation/templates/grid/migration.js +251 -0
  66. package/dist/extensions/Blocks/Recommendation/templates/grid/template.js +69 -0
  67. package/dist/extensions/Blocks/Recommendation/templates/index.js +12 -0
  68. package/dist/extensions/Blocks/Recommendation/templates/list/elementRenderer.js +174 -0
  69. package/dist/extensions/Blocks/Recommendation/templates/list/template.js +73 -0
  70. package/dist/extensions/Blocks/Recommendation/templates/utils.js +122 -0
  71. package/dist/extensions/Blocks/Recommendation/types/nodeConfig.js +6 -0
  72. package/dist/extensions/Blocks/Recommendation/utils/filterUtil.js +9 -9
  73. package/dist/extensions/Blocks/Recommendation/utils/preserveTextStyles.js +26 -15
  74. package/dist/extensions/Blocks/Recommendation/utils/priceFormatter.js +29 -0
  75. package/dist/extensions/Blocks/Recommendation/utils/tagName.js +46 -0
  76. package/dist/extensions/Blocks/common-control.js +91 -92
  77. package/dist/extensions/Blocks/controlFactories.js +125 -93
  78. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/esm/index.js +223 -169
  79. package/dist/services/recommendationApi.js +10 -9
  80. package/dist/services/templateLibraryApi.js +16 -13
  81. package/dist/src/components/wrappers/WpDrawer.vue.d.ts +1 -1
  82. package/dist/src/composables/useRecommendation.d.ts +1 -0
  83. package/dist/src/config/compiler/utils/recommendationCompilerUtils.d.ts +17 -0
  84. package/dist/src/extensions/Blocks/Items/block.d.ts +0 -1
  85. package/dist/src/extensions/Blocks/Items/controls/button/link.d.ts +0 -1
  86. package/dist/src/extensions/Blocks/Items/controls/cardComposition.d.ts +5 -5
  87. package/dist/src/extensions/Blocks/Items/controls/image/link.d.ts +0 -1
  88. package/dist/src/extensions/Blocks/Items/controls/name/trimming.d.ts +0 -1
  89. package/dist/src/extensions/Blocks/Items/controls/price/currencyLocation.d.ts +0 -1
  90. package/dist/src/extensions/Blocks/Items/controls/price/currencySymbol.d.ts +0 -1
  91. package/dist/src/extensions/Blocks/Items/controls/price/formattedPrice.d.ts +0 -1
  92. package/dist/src/extensions/Blocks/Items/controls/price/hideDiscount.d.ts +0 -1
  93. package/dist/src/extensions/Blocks/Items/controls/price/priceOrientation.d.ts +0 -1
  94. package/dist/src/extensions/Blocks/Items/controls/price/singlePrice.d.ts +0 -5
  95. package/dist/src/extensions/Blocks/Items/controls/settingsControl.d.ts +10 -12
  96. package/dist/src/extensions/Blocks/Items/utils/nodeConfigUtils.d.ts +2 -1
  97. package/dist/src/extensions/Blocks/Recommendation/block.d.ts +67 -0
  98. package/dist/src/extensions/Blocks/Recommendation/constants/blockIds.d.ts +13 -0
  99. package/dist/src/extensions/Blocks/Recommendation/{constants.d.ts → constants/controlIds.d.ts} +0 -24
  100. package/dist/src/extensions/Blocks/Recommendation/constants/defaultConfig.d.ts +49 -0
  101. package/dist/src/extensions/Blocks/Recommendation/constants/index.d.ts +13 -0
  102. package/dist/src/extensions/Blocks/Recommendation/constants/layout.d.ts +35 -0
  103. package/dist/src/extensions/Blocks/Recommendation/constants/selectors.d.ts +31 -0
  104. package/dist/src/extensions/Blocks/Recommendation/controls/button/index.d.ts +143 -0
  105. package/dist/src/extensions/Blocks/Recommendation/controls/cardBackground/index.d.ts +31 -0
  106. package/dist/src/extensions/Blocks/Recommendation/{cardCompositionControl.d.ts → controls/cardComposition/index.d.ts} +23 -3
  107. package/dist/src/extensions/Blocks/Recommendation/controls/image/index.d.ts +35 -0
  108. package/dist/src/extensions/Blocks/Recommendation/controls/index.d.ts +21 -589
  109. package/dist/src/extensions/Blocks/Recommendation/controls/layout/index.d.ts +37 -0
  110. package/dist/src/extensions/Blocks/Recommendation/controls/main/algorithm.d.ts +29 -0
  111. package/dist/src/extensions/Blocks/Recommendation/controls/main/currency.d.ts +52 -0
  112. package/dist/src/extensions/Blocks/Recommendation/controls/main/filters.d.ts +22 -0
  113. package/dist/src/extensions/Blocks/Recommendation/controls/main/index.d.ts +68 -0
  114. package/dist/src/extensions/Blocks/Recommendation/controls/main/locale.d.ts +24 -0
  115. package/dist/src/extensions/Blocks/Recommendation/controls/main/productLayout.d.ts +42 -0
  116. package/dist/src/extensions/Blocks/Recommendation/controls/main/shuffle.d.ts +23 -0
  117. package/dist/src/extensions/Blocks/Recommendation/controls/main/utils.d.ts +214 -0
  118. package/dist/src/extensions/Blocks/Recommendation/controls/name/index.d.ts +97 -0
  119. package/dist/src/extensions/Blocks/Recommendation/controls/name/textTrim.d.ts +34 -0
  120. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/index.d.ts +95 -0
  121. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusDiscount/index.d.ts +100 -0
  122. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusDiscount/textAfter.d.ts +15 -0
  123. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusDiscount/textBefore.d.ts +15 -0
  124. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusPrice/index.d.ts +100 -0
  125. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusPrice/textAfter.d.ts +15 -0
  126. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusPrice/textBefore.d.ts +15 -0
  127. package/dist/src/extensions/Blocks/Recommendation/controls/price/index.d.ts +95 -0
  128. package/dist/src/extensions/Blocks/Recommendation/controls/spacing/index.d.ts +83 -0
  129. package/dist/src/extensions/Blocks/Recommendation/extension.d.ts +9 -0
  130. package/dist/src/extensions/Blocks/Recommendation/services/configService.d.ts +151 -0
  131. package/dist/src/extensions/Blocks/Recommendation/services/index.d.ts +6 -0
  132. package/dist/src/extensions/Blocks/Recommendation/store/recommendation.d.ts +131 -468
  133. package/dist/src/extensions/Blocks/Recommendation/templates/grid/elementRenderer.d.ts +20 -0
  134. package/dist/src/extensions/Blocks/Recommendation/templates/{migrationTemplate.d.ts → grid/migration.d.ts} +11 -4
  135. package/dist/src/extensions/Blocks/Recommendation/templates/grid/template.d.ts +33 -0
  136. package/dist/src/extensions/Blocks/Recommendation/templates/index.d.ts +39 -0
  137. package/dist/src/extensions/Blocks/Recommendation/templates/list/elementRenderer.d.ts +8 -0
  138. package/dist/src/extensions/Blocks/Recommendation/templates/list/migration.d.ts +25 -0
  139. package/dist/src/extensions/Blocks/Recommendation/templates/list/template.d.ts +18 -0
  140. package/dist/src/extensions/Blocks/Recommendation/templates/utils.d.ts +57 -0
  141. package/dist/src/extensions/Blocks/Recommendation/types/index.d.ts +7 -0
  142. package/dist/src/extensions/Blocks/Recommendation/types/nodeConfig.d.ts +160 -0
  143. package/dist/src/extensions/Blocks/Recommendation/utils/priceFormatter.d.ts +33 -0
  144. package/dist/src/extensions/Blocks/Recommendation/utils/stylePreserver.d.ts +113 -0
  145. package/dist/src/extensions/Blocks/Recommendation/utils/tagName.d.ts +77 -0
  146. package/dist/src/extensions/Blocks/common-control.d.ts +4 -5
  147. package/dist/static/styles/customEditorStyle.css.js +25 -2
  148. package/dist/utils/pairProductVariables.js +57 -56
  149. package/dist/utils/templatePreparation.js +15 -14
  150. package/package.json +1 -1
  151. package/dist/extensions/Blocks/Items/store/items-block.js +0 -79
  152. package/dist/extensions/Blocks/Recommendation/cardCompositionControl.js +0 -187
  153. package/dist/extensions/Blocks/Recommendation/constants.js +0 -13
  154. package/dist/extensions/Blocks/Recommendation/control.js +0 -336
  155. package/dist/extensions/Blocks/Recommendation/controls/cardBackgroundColorControl.js +0 -68
  156. package/dist/extensions/Blocks/Recommendation/controls/index.js +0 -245
  157. package/dist/extensions/Blocks/Recommendation/controls/nameTextTrimControl.js +0 -74
  158. package/dist/extensions/Blocks/Recommendation/controls/spacingControl.js +0 -188
  159. package/dist/extensions/Blocks/Recommendation/templates/blockTemplate.js +0 -181
  160. package/dist/extensions/Blocks/Recommendation/templates/migrationTemplate.js +0 -189
  161. package/dist/extensions/Blocks/Recommendation/templates/templateUtils.js +0 -209
  162. package/dist/src/extensions/Blocks/Items/store/items-block.d.ts +0 -45
  163. package/dist/src/extensions/Blocks/Recommendation/control.d.ts +0 -38
  164. package/dist/src/extensions/Blocks/Recommendation/controls/nameTextTrimControl.d.ts +0 -16
  165. package/dist/src/extensions/Blocks/Recommendation/templates/blockTemplate.d.ts +0 -16
  166. package/dist/src/extensions/Blocks/Recommendation/templates/templateUtils.d.ts +0 -52
@@ -0,0 +1,233 @@
1
+ import { RecommendationBlockId as s } from "../../constants/blockIds.js";
2
+ import { ATTR_PRODUCT_BUTTON as b, ATTR_PRODUCT_OMNIBUS_DISCOUNT as u, ATTR_PRODUCT_OMNIBUS_PRICE as m, ATTR_PRODUCT_OLD_PRICE as h, ATTR_PRODUCT_PRICE as y, ATTR_PRODUCT_NAME as f, ATTR_PRODUCT_IMAGE as x } from "../../constants/selectors.js";
3
+ import { useRecommendationExtensionStore as T } from "../../store/recommendation.js";
4
+ import { formatPrice as _ } from "../../utils/priceFormatter.js";
5
+ import { sanitizeImageUrl as $ } from "../utils.js";
6
+ const o = "0 5px", a = "attribute-cell";
7
+ function p() {
8
+ const t = T(), { currencySettings: e } = t.recommendationConfigs;
9
+ return {
10
+ code: e.value,
11
+ symbol: e.symbol,
12
+ alignment: e.alignment === "0" ? "before" : "after",
13
+ decimalCount: parseInt(e.decimalCount) || 2,
14
+ decimalSeparator: e.decimalSeparator,
15
+ thousandSeparator: e.thousandSeparator
16
+ };
17
+ }
18
+ function r(t, e = "price") {
19
+ const n = p(), l = t[e], i = (l == null ? void 0 : l[n.code]) ?? Object.values(l ?? {})[0] ?? 0;
20
+ return _({
21
+ price: i,
22
+ currency: n
23
+ });
24
+ }
25
+ const P = {
26
+ [x]: (t) => `
27
+ <td class="${a}" style="padding: ${o}; height: 100%;" valign="top">
28
+ <table
29
+ class="product-card-segment"
30
+ width="100%"
31
+ height="100%"
32
+ cellpadding="0"
33
+ cellspacing="0"
34
+ border="0">
35
+ <tbody>
36
+ <tr valign="top">
37
+ <td
38
+ class="esd-block-image product-image"
39
+ align="center"
40
+ esd-extension-block-id="${s.IMAGE}">
41
+ <div style="position: relative; width: 100%; padding-bottom: 100%; overflow: hidden;">
42
+ <a
43
+ target="_blank"
44
+ href="${t.url}"
45
+ style="position: absolute; top: 0; left: 0; width: 100%; height: 100%;">
46
+ <img
47
+ src="${$(t.image_url)}"
48
+ alt="${t.name}"
49
+ style="max-width: 100%; max-height: 100%; object-fit: contain; display: block;"
50
+ class="adapt-img">
51
+ </a>
52
+ </div>
53
+ </td>
54
+ </tr>
55
+ </tbody>
56
+ </table>
57
+ </td>
58
+ `,
59
+ [f]: (t) => `
60
+ <td class="${a}" style="padding: ${o}; height: 100%;" valign="middle">
61
+ <table
62
+ class="product-card-segment"
63
+ width="100%"
64
+ height="100%"
65
+ cellpadding="0"
66
+ cellspacing="0"
67
+ border="0"
68
+ style="table-layout: fixed;">
69
+ <tbody>
70
+ <tr valign="top">
71
+ <td
72
+ class="esd-block-text product-name es-p10t es-p10b es-p15l es-p15r"
73
+ align="center"
74
+ esd-extension-block-id="${s.NAME}">
75
+ <p contenteditable="false" style="font-size: 16px; color: #333333;">
76
+ <strong>${t.name}</strong>
77
+ </p>
78
+ </td>
79
+ </tr>
80
+ </tbody>
81
+ </table>
82
+ </td>
83
+ `,
84
+ [y]: (t) => `
85
+ <td class="${a}" style="padding: ${o}; height: 100%;" valign="top">
86
+ <table
87
+ class="product-card-segment"
88
+ width="100%"
89
+ height="100%"
90
+ cellpadding="0"
91
+ cellspacing="0"
92
+ border="0">
93
+ <tbody>
94
+ <tr valign="top">
95
+ <td
96
+ class="esd-block-text product-price es-p15l es-p15r"
97
+ align="center"
98
+ esd-extension-block-id="${s.PRICE}">
99
+ <p contenteditable="false" style="font-size: 16px; color: #333333;">
100
+ <strong>${r(t, "price")}</strong>
101
+ </p>
102
+ </td>
103
+ </tr>
104
+ </tbody>
105
+ </table>
106
+ </td>
107
+ `,
108
+ [h]: (t) => `
109
+ <td class="${a}" style="padding: ${o}; height: 100%;" valign="top">
110
+ <table
111
+ class="product-card-segment"
112
+ width="100%"
113
+ height="100%"
114
+ cellpadding="0"
115
+ cellspacing="0"
116
+ border="0">
117
+ <tbody>
118
+ <tr valign="top">
119
+ <td
120
+ class="esd-block-text product-old-price es-p15l es-p15r"
121
+ align="center"
122
+ esd-extension-block-id="${s.OLD_PRICE}">
123
+ <p contenteditable="false" style="font-size: 14px; color: #999999;">
124
+ <strong>${r(t, "original_price")}</strong>
125
+ </p>
126
+ </td>
127
+ </tr>
128
+ </tbody>
129
+ </table>
130
+ </td>
131
+ `,
132
+ [m]: (t) => `
133
+ <td class="${a}" style="padding: ${o}; height: 100%;" valign="top">
134
+ <table
135
+ class="product-card-segment"
136
+ width="100%"
137
+ height="100%"
138
+ cellpadding="0"
139
+ cellspacing="0"
140
+ border="0">
141
+ <tbody>
142
+ <tr valign="top">
143
+ <td
144
+ class="esd-block-text product-omnibus-price es-p15l es-p15r"
145
+ align="center"
146
+ data-text-before="Lowest 30-day price: "
147
+ data-text-after=""
148
+ esd-extension-block-id="${s.OMNIBUS_PRICE}">
149
+ <p style="font-size: 12px; color: #666666;">
150
+ <span class="omnibus-text-before">Lowest 30-day price: </span>
151
+ <span class="omnibus-price-value">${r(t, "original_price")}</span>
152
+ <span class="omnibus-text-after"></span>
153
+ </p>
154
+ </td>
155
+ </tr>
156
+ </tbody>
157
+ </table>
158
+ </td>
159
+ `,
160
+ [u]: (t) => {
161
+ var d, c;
162
+ const e = p(), n = ((d = t.original_price) == null ? void 0 : d[e.code]) ?? Object.values(t.original_price ?? {})[0] ?? 0, l = ((c = t.price) == null ? void 0 : c[e.code]) ?? Object.values(t.price ?? {})[0] ?? 0, i = n > 0 ? Math.round((n - l) / n * 100) : 0, g = i > 0 ? `-${i}%` : "0%";
163
+ return `
164
+ <td class="${a}" style="padding: ${o}; height: 100%;" valign="top">
165
+ <table
166
+ class="product-card-segment"
167
+ width="100%"
168
+ height="100%"
169
+ cellpadding="0"
170
+ cellspacing="0"
171
+ border="0">
172
+ <tbody>
173
+ <tr valign="top">
174
+ <td
175
+ class="esd-block-text product-omnibus-discount es-p15l es-p15r"
176
+ align="center"
177
+ data-text-before=""
178
+ data-text-after=""
179
+ esd-extension-block-id="${s.OMNIBUS_DISCOUNT}">
180
+ <p style="font-size: 12px; color: #666666;">
181
+ <span class="omnibus-text-before"></span>
182
+ <span class="omnibus-discount-value">${g}</span>
183
+ <span class="omnibus-text-after"></span>
184
+ </p>
185
+ </td>
186
+ </tr>
187
+ </tbody>
188
+ </table>
189
+ </td>
190
+ `;
191
+ },
192
+ [b]: () => `
193
+ <td class="${a}" style="padding: ${o}; height: 100%;" valign="top">
194
+ <table
195
+ class="product-card-segment"
196
+ width="100%"
197
+ height="100%"
198
+ cellpadding="0"
199
+ cellspacing="0"
200
+ border="0">
201
+ <tbody>
202
+ <tr valign="top">
203
+ <td
204
+ class="esd-block-button product-button es-p10t es-p10b"
205
+ align="center"
206
+ esd-extension-block-id="${s.BUTTON}">
207
+ <span
208
+ class="es-button-border"
209
+ style="
210
+ border-width: 1px;
211
+ background: rgb(217, 234, 211);
212
+ border-color: rgb(106, 168, 79);
213
+ ">
214
+ <a
215
+ href="#"
216
+ class="es-button buy-button"
217
+ target="_blank"
218
+ style="color: rgb(56, 118, 29); background: rgb(217, 234, 211);">
219
+ Buy
220
+ </a>
221
+ </span>
222
+ </td>
223
+ </tr>
224
+ </tbody>
225
+ </table>
226
+ </td>
227
+ `
228
+ };
229
+ export {
230
+ a as ATTRIBUTE_CELL_CLASS,
231
+ o as DEFAULT_CELL_PADDING,
232
+ P as gridElementRenderer
233
+ };
@@ -0,0 +1,251 @@
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 { prepareGridProductRows as b } from "./template.js";
3
+ const u = `
4
+ <td
5
+ align="left"
6
+ esd-extension-block-id="recommendation-block"
7
+ esd-handler-name="esd-extension-RecommendationBlock"
8
+ class="ins-recommendation-v3-block-v2 esd-block-recommendation-v3-block esd-extension-block es-p20"
9
+ >
10
+ <table width="100%" cellpadding="0" cellspacing="0" border="0">
11
+ <tr>
12
+ <td align="center">
13
+ <table
14
+ class="container"
15
+ width="100%"
16
+ cellpadding="0"
17
+ cellspacing="0"
18
+ border="0">
19
+ <tbody>
20
+ <tr>
21
+ <td>
22
+ <table
23
+ width="100%"
24
+ cellpadding="0"
25
+ cellspacing="0"
26
+ border="0">
27
+ <tbody>
28
+ <tr>
29
+ {-{-TITLE-}-}
30
+ </tr>
31
+ </tbody>
32
+ </table>
33
+ </td>
34
+ </tr>
35
+ <tr>
36
+ <td class="spacer" style="height: 20px;"></td>
37
+ </tr>
38
+ <tr>
39
+ <td>
40
+ <table
41
+ class="ins-recommendation-product-container"
42
+ width="100%"
43
+ cellpadding="0"
44
+ cellspacing="0"
45
+ border="0"
46
+ >
47
+ {-{-PRODUCT_ROWS-}-}
48
+ </table>
49
+ </td>
50
+ </tr>
51
+ </tbody>
52
+ </table>
53
+ </td>
54
+ </tr>
55
+ </table>
56
+ </td>
57
+ `, e = "0 5px", a = "attribute-cell", g = {
58
+ [p]: (t) => `
59
+ <td class="${a}" style="padding: ${e}; height: 100%;" valign="top">
60
+ <table
61
+ class="product-card-segment"
62
+ width="100%"
63
+ height="100%"
64
+ cellpadding="0"
65
+ cellspacing="0"
66
+ border="0">
67
+ <tr>
68
+ <td
69
+ class="esd-block-image product-image"
70
+ esd-extension-block-id="recommendation-block-image"
71
+ align="center"
72
+ style="font-size: 0px;">
73
+ <a target="_blank" href="${t.url}">
74
+ <img
75
+ src="${t.image_url}"
76
+ alt="${t.name}"
77
+ width="120"
78
+ style="display: block; max-width: 100%; height: auto;"
79
+ class="adapt-img">
80
+ </a>
81
+ </td>
82
+ </tr>
83
+ </table>
84
+ </td>
85
+ `,
86
+ [r]: (t) => `
87
+ <td class="${a}" style="padding: ${e}; height: 100%;" valign="top">
88
+ <table
89
+ class="product-card-segment"
90
+ width="100%"
91
+ height="100%"
92
+ cellpadding="0"
93
+ cellspacing="0"
94
+ border="0">
95
+ <tr>
96
+ <td
97
+ class="esd-block-text product-name"
98
+ esd-extension-block-id="recommendation-block-name"
99
+ align="center">
100
+ <p
101
+ path="1"
102
+ contenteditable="false"
103
+ style="font-size: 16px; color: #333333; font-weight: 600; text-align: center;">
104
+ <strong path="1,0">${t.name}</strong>
105
+ </p>
106
+ </td>
107
+ </tr>
108
+ </table>
109
+ </td>
110
+ `,
111
+ [i]: () => `
112
+ <td class="${a}" style="padding: ${e}; height: 100%;" valign="top">
113
+ <table
114
+ class="product-card-segment"
115
+ width="100%"
116
+ height="100%"
117
+ cellpadding="0"
118
+ cellspacing="0"
119
+ border="0">
120
+ <tr>
121
+ <td
122
+ class="esd-block-text product-price"
123
+ esd-extension-block-id="recommendation-block-price"
124
+ align="center">
125
+ <p
126
+ path="1"
127
+ contenteditable="false"
128
+ style="font-size: 16px; color: #333333; font-weight: bold; text-align: center;">
129
+ <strong path="1,0">18,00 TRY</strong>
130
+ </p>
131
+ </td>
132
+ </tr>
133
+ </table>
134
+ </td>
135
+ `,
136
+ [o]: () => `
137
+ <td class="${a}" style="padding: ${e}; height: 100%;" valign="top">
138
+ <table
139
+ class="product-card-segment"
140
+ width="100%"
141
+ height="100%"
142
+ cellpadding="0"
143
+ cellspacing="0"
144
+ border="0">
145
+ <tr>
146
+ <td
147
+ class="esd-block-text product-old-price"
148
+ esd-extension-block-id="recommendation-block-old-price"
149
+ align="center">
150
+ <p
151
+ path="1"
152
+ contenteditable="false"
153
+ style="font-size: 14px; color: #999999; text-decoration: line-through; text-align: center;">
154
+ <s path="1,0">20,00 TRY</s>
155
+ </p>
156
+ </td>
157
+ </tr>
158
+ </table>
159
+ </td>
160
+ `,
161
+ [c]: () => `
162
+ <td class="${a}" style="padding: ${e}; height: 100%;" valign="top">
163
+ <table
164
+ class="product-card-segment"
165
+ width="100%"
166
+ height="100%"
167
+ cellpadding="0"
168
+ cellspacing="0"
169
+ border="0">
170
+ <tr>
171
+ <td
172
+ class="esd-block-text product-omnibus-price"
173
+ esd-extension-block-id="recommendation-block-omnibus-price"
174
+ data-text-before="Lowest 30-day price: "
175
+ data-text-after=""
176
+ align="center">
177
+ <p
178
+ path="1"
179
+ contenteditable="false"
180
+ style="font-size: 14px; color: #666666; text-align: center;"><span
181
+ class="omnibus-text-before">Lowest 30-day price: </span><span
182
+ class="omnibus-price-value">17,00 TRY</span><span
183
+ class="omnibus-text-after"></span></p>
184
+ </td>
185
+ </tr>
186
+ </table>
187
+ </td>
188
+ `,
189
+ [d]: () => `
190
+ <td class="${a}" style="padding: ${e}; height: 100%;" valign="top">
191
+ <table
192
+ class="product-card-segment"
193
+ width="100%"
194
+ height="100%"
195
+ cellpadding="0"
196
+ cellspacing="0"
197
+ border="0">
198
+ <tr>
199
+ <td
200
+ class="esd-block-text product-omnibus-discount"
201
+ esd-extension-block-id="recommendation-block-omnibus-discount"
202
+ data-text-before=""
203
+ data-text-after=""
204
+ align="center">
205
+ <p
206
+ path="1"
207
+ contenteditable="false"
208
+ style="font-size: 14px; color: #666666; text-align: center;"><span
209
+ class="omnibus-text-before"></span><span
210
+ class="omnibus-discount-value">-6%</span><span
211
+ class="omnibus-text-after"></span></p>
212
+ </td>
213
+ </tr>
214
+ </table>
215
+ </td>
216
+ `,
217
+ [s]: (t) => `
218
+ <td class="${a}" style="padding: ${e}; height: 100%;" valign="top">
219
+ <table
220
+ class="product-card-segment"
221
+ width="100%"
222
+ height="100%"
223
+ cellpadding="0"
224
+ cellspacing="0"
225
+ border="0">
226
+ <tr>
227
+ <td
228
+ class="esd-block-button product-button"
229
+ esd-extension-block-id="recommendation-block-button"
230
+ align="center">
231
+ <span class="es-button-border" style="display: block;">
232
+ <a
233
+ href="${t.url}"
234
+ target="_blank"
235
+ class="es-button">
236
+ {-{-PRODUCT_BUTTON_TEXT-}-}
237
+ </a>
238
+ </span>
239
+ </td>
240
+ </tr>
241
+ </table>
242
+ </td>
243
+ `
244
+ };
245
+ function T(t, l, n) {
246
+ return b(t, l, g, n);
247
+ }
248
+ export {
249
+ u as default,
250
+ T as prepareProductRows
251
+ };
@@ -0,0 +1,69 @@
1
+ import { DEFAULT_PRODUCTS_PER_ROW as L } from "../../constants/layout.js";
2
+ import { DEFAULT_CARD_COMPOSITION as R, spacer as I, createBlockTemplate as E, DEFAULTS as S, getDefaultProducts as _, DEFAULT_CARD_VISIBILITY as b } from "../utils.js";
3
+ import { gridElementRenderer as A, ATTRIBUTE_CELL_CLASS as w, DEFAULT_CELL_PADDING as f } from "./elementRenderer.js";
4
+ const D = `
5
+ <tr class="recommendation-product-row">
6
+ <td>
7
+ <table
8
+ width="100%"
9
+ height="100%"
10
+ cellpadding="0"
11
+ cellspacing="0"
12
+ border="0"
13
+ class="product-card-wrapper"
14
+ style="table-layout: fixed;">
15
+ <tbody>
16
+ {-{-ATTRIBUTE_ROWS-}-}
17
+ </tbody>
18
+ </table>
19
+ </td>
20
+ </tr>
21
+ `, C = `
22
+ <tr
23
+ class="recommendation-attribute-row"
24
+ data-attribute-type="{-{-ATTR_TYPE-}-}"
25
+ data-visibility="{-{-VISIBILITY-}-}"
26
+ {-{-DISPLAY_STYLE-}-}>
27
+ {-{-CELLS-}-}
28
+ </tr>
29
+ `;
30
+ function g(t, e, r, c = R) {
31
+ const n = (100 / e).toFixed(2), i = e - t.length, o = `<td class="${w}" style="padding: ${f};" width="${n}%"></td>`, a = i > 0 ? o.repeat(i) : "";
32
+ return c.filter((l) => r[l]).map((l) => {
33
+ const d = b[l] ?? !0, p = d ? "" : 'style="display: none;"', T = t.map((u) => {
34
+ const m = r[l];
35
+ return m(u).replace("<td", `<td width="${n}%"`);
36
+ }).join("");
37
+ return C.replace("{-{-ATTR_TYPE-}-}", l).replace("{-{-VISIBILITY-}-}", d ? "1" : "0").replace("{-{-DISPLAY_STYLE-}-}", p).replace("{-{-CELLS-}-}", T + a);
38
+ }).join("");
39
+ }
40
+ function P(t, e, r, c) {
41
+ const n = [];
42
+ for (let o = 0; o < t.length; o += e)
43
+ n.push(t.slice(o, o + e));
44
+ return n.map((o, a) => {
45
+ const s = g(
46
+ o,
47
+ e,
48
+ r,
49
+ c
50
+ ), l = D.replace("{-{-ATTRIBUTE_ROWS-}-}", s);
51
+ return a > 0 ? I + l : l;
52
+ }).join("");
53
+ }
54
+ function U(t, e, r) {
55
+ return P(t, e, A, r);
56
+ }
57
+ function B(t) {
58
+ const e = t ? `ins-recommendation-v3-block-${t}` : void 0, r = E("grid", e), c = U(
59
+ _(),
60
+ L
61
+ );
62
+ return r.replace("{-{-TITLE-}-}", S.TITLE).replace("{-{-PRODUCT_ROWS-}-}", c);
63
+ }
64
+ export {
65
+ B as getDefaultTemplate,
66
+ g as prepareGridAttributeRows,
67
+ P as prepareGridProductRows,
68
+ U as prepareProductRows
69
+ };
@@ -0,0 +1,12 @@
1
+ import { DEFAULT_PRODUCTS_PER_ROW as s } from "../constants/layout.js";
2
+ import { prepareProductRows as R } from "./grid/template.js";
3
+ import { prepareProductRows as c } from "./list/template.js";
4
+ function a(r, o, p = {}) {
5
+ if (o === "list")
6
+ return c(r);
7
+ const { productsPerRow: t = s, composition: e } = p;
8
+ return R(r, t, e);
9
+ }
10
+ export {
11
+ a as prepareProductRows
12
+ };