@useinsider/guido 2.1.0-beta.febc521 → 2.1.0-beta.ff1bc98

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 (247) hide show
  1. package/dist/@types/config/schemas.js +17 -17
  2. package/dist/components/organisms/extensions/recommendation/FilterSelectionDrawer.vue2.js +15 -14
  3. package/dist/components/organisms/header/HeaderWrapper.vue.js +9 -9
  4. package/dist/composables/useActionsApi.js +15 -13
  5. package/dist/composables/useHtmlValidator.js +114 -104
  6. package/dist/composables/useRecommendation.js +54 -21
  7. package/dist/config/compiler/recommendationCompilerRules.js +45 -39
  8. package/dist/config/compiler/utils/recommendationCompilerUtils.js +116 -0
  9. package/dist/config/migrator/itemsBlockMigrator.js +140 -123
  10. package/dist/config/migrator/recommendationMigrator.js +2 -2
  11. package/dist/enums/extensions/recommendationBlock.js +1 -1
  12. package/dist/enums/recommendation.js +16 -15
  13. package/dist/extensions/Blocks/Items/block.js +19 -28
  14. package/dist/extensions/Blocks/Items/controls/button/link.js +19 -31
  15. package/dist/extensions/Blocks/Items/controls/cardComposition.js +137 -89
  16. package/dist/extensions/Blocks/Items/controls/image/link.js +19 -31
  17. package/dist/extensions/Blocks/Items/controls/name/trimming.js +28 -40
  18. package/dist/extensions/Blocks/Items/controls/price/currencyLocation.js +35 -47
  19. package/dist/extensions/Blocks/Items/controls/price/currencySymbol.js +49 -54
  20. package/dist/extensions/Blocks/Items/controls/price/formattedPrice.js +42 -51
  21. package/dist/extensions/Blocks/Items/controls/price/hideDiscount.js +23 -36
  22. package/dist/extensions/Blocks/Items/controls/price/priceOrientation.js +45 -57
  23. package/dist/extensions/Blocks/Items/controls/price/singlePrice.js +42 -60
  24. package/dist/extensions/Blocks/Items/controls/settingsControl.js +189 -196
  25. package/dist/extensions/Blocks/Items/enums/settingsEnums.js +0 -2
  26. package/dist/extensions/Blocks/Items/extension.js +8 -9
  27. package/dist/extensions/Blocks/Items/settingsPanel.js +10 -15
  28. package/dist/extensions/Blocks/Items/template.js +181 -175
  29. package/dist/extensions/Blocks/Items/utils/nodeConfigUtils.js +65 -65
  30. package/dist/extensions/Blocks/Recommendation/block.js +133 -9
  31. package/dist/extensions/Blocks/Recommendation/constants/blockIds.js +4 -0
  32. package/dist/extensions/Blocks/Recommendation/constants/controlIds.js +4 -0
  33. package/dist/extensions/Blocks/Recommendation/constants/defaultConfig.js +66 -0
  34. package/dist/extensions/Blocks/Recommendation/constants/layout.js +22 -0
  35. package/dist/extensions/Blocks/Recommendation/constants/selectors.js +21 -0
  36. package/dist/extensions/Blocks/Recommendation/controls/button/index.js +64 -0
  37. package/dist/extensions/Blocks/Recommendation/controls/cardBackground/index.js +80 -0
  38. package/dist/extensions/Blocks/Recommendation/controls/cardComposition/index.js +232 -0
  39. package/dist/extensions/Blocks/Recommendation/controls/image/index.js +19 -0
  40. package/dist/extensions/Blocks/Recommendation/controls/layout/index.js +92 -0
  41. package/dist/extensions/Blocks/Recommendation/controls/main/algorithm.js +102 -0
  42. package/dist/extensions/Blocks/Recommendation/controls/main/currency.js +209 -0
  43. package/dist/extensions/Blocks/Recommendation/controls/main/filters.js +52 -0
  44. package/dist/extensions/Blocks/Recommendation/controls/main/index.js +250 -0
  45. package/dist/extensions/Blocks/Recommendation/controls/main/locale.js +70 -0
  46. package/dist/extensions/Blocks/Recommendation/controls/main/productLayout.js +160 -0
  47. package/dist/extensions/Blocks/Recommendation/controls/main/shuffle.js +67 -0
  48. package/dist/extensions/Blocks/Recommendation/controls/main/utils.js +307 -0
  49. package/dist/extensions/Blocks/Recommendation/controls/mobileLayout/cssRules.js +21 -0
  50. package/dist/extensions/Blocks/Recommendation/controls/name/index.js +46 -0
  51. package/dist/extensions/Blocks/Recommendation/controls/name/textTrim.js +108 -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/iconsRegistry.js +19 -3
  63. package/dist/extensions/Blocks/Recommendation/recommendation.css.js +13 -4
  64. package/dist/extensions/Blocks/Recommendation/services/configService.js +240 -0
  65. package/dist/extensions/Blocks/Recommendation/settingsPanel.js +128 -72
  66. package/dist/extensions/Blocks/Recommendation/store/recommendation.js +254 -207
  67. package/dist/extensions/Blocks/Recommendation/templates/grid/elementRenderer.js +233 -0
  68. package/dist/extensions/Blocks/Recommendation/templates/grid/migration.js +251 -0
  69. package/dist/extensions/Blocks/Recommendation/templates/grid/template.js +66 -0
  70. package/dist/extensions/Blocks/Recommendation/templates/index.js +12 -0
  71. package/dist/extensions/Blocks/Recommendation/templates/list/elementRenderer.js +174 -0
  72. package/dist/extensions/Blocks/Recommendation/templates/list/template.js +73 -0
  73. package/dist/extensions/Blocks/Recommendation/templates/utils.js +134 -0
  74. package/dist/extensions/Blocks/Recommendation/types/nodeConfig.js +6 -0
  75. package/dist/extensions/Blocks/Recommendation/utils/filterUtil.js +9 -9
  76. package/dist/extensions/Blocks/Recommendation/utils/preserveTextStyles.js +36 -0
  77. package/dist/extensions/Blocks/Recommendation/utils/priceFormatter.js +29 -0
  78. package/dist/extensions/Blocks/Recommendation/utils/tagName.js +46 -0
  79. package/dist/extensions/Blocks/common-control.js +91 -92
  80. package/dist/extensions/Blocks/controlFactories.js +125 -93
  81. package/dist/guido.css +1 -1
  82. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/esm/index.js +220 -169
  83. package/dist/package.json.js +1 -1
  84. package/dist/services/recommendationApi.js +11 -8
  85. package/dist/services/templateLibraryApi.js +16 -13
  86. package/dist/src/@types/config/schemas.d.ts +2 -2
  87. package/dist/src/components/wrappers/WpDrawer.vue.d.ts +1 -1
  88. package/dist/src/composables/useRecommendation.d.ts +1 -0
  89. package/dist/src/config/compiler/utils/recommendationCompilerUtils.d.ts +17 -0
  90. package/dist/src/extensions/Blocks/Items/block.d.ts +0 -1
  91. package/dist/src/extensions/Blocks/Items/controls/button/link.d.ts +0 -1
  92. package/dist/src/extensions/Blocks/Items/controls/cardComposition.d.ts +5 -5
  93. package/dist/src/extensions/Blocks/Items/controls/image/link.d.ts +0 -1
  94. package/dist/src/extensions/Blocks/Items/controls/name/trimming.d.ts +0 -1
  95. package/dist/src/extensions/Blocks/Items/controls/price/currencyLocation.d.ts +0 -1
  96. package/dist/src/extensions/Blocks/Items/controls/price/currencySymbol.d.ts +0 -1
  97. package/dist/src/extensions/Blocks/Items/controls/price/formattedPrice.d.ts +0 -1
  98. package/dist/src/extensions/Blocks/Items/controls/price/hideDiscount.d.ts +0 -1
  99. package/dist/src/extensions/Blocks/Items/controls/price/priceOrientation.d.ts +0 -1
  100. package/dist/src/extensions/Blocks/Items/controls/price/singlePrice.d.ts +0 -5
  101. package/dist/src/extensions/Blocks/Items/controls/settingsControl.d.ts +10 -12
  102. package/dist/src/extensions/Blocks/Items/utils/nodeConfigUtils.d.ts +2 -1
  103. package/dist/src/extensions/Blocks/Recommendation/block.d.ts +67 -0
  104. package/dist/src/extensions/Blocks/Recommendation/constants/blockIds.d.ts +13 -0
  105. package/dist/src/extensions/Blocks/Recommendation/{constants.d.ts → constants/controlIds.d.ts} +19 -11
  106. package/dist/src/extensions/Blocks/Recommendation/constants/defaultConfig.d.ts +49 -0
  107. package/dist/src/extensions/Blocks/Recommendation/constants/index.d.ts +13 -0
  108. package/dist/src/extensions/Blocks/Recommendation/constants/layout.d.ts +41 -0
  109. package/dist/src/extensions/Blocks/Recommendation/constants/selectors.d.ts +35 -0
  110. package/dist/src/extensions/Blocks/Recommendation/controls/button/index.d.ts +143 -0
  111. package/dist/src/extensions/Blocks/Recommendation/controls/cardBackground/index.d.ts +31 -0
  112. package/dist/src/extensions/Blocks/Recommendation/controls/cardBackgroundColorControl.d.ts +25 -0
  113. package/dist/src/extensions/Blocks/Recommendation/controls/cardComposition/index.d.ts +95 -0
  114. package/dist/src/extensions/Blocks/Recommendation/controls/image/index.d.ts +35 -0
  115. package/dist/src/extensions/Blocks/Recommendation/controls/index.d.ts +24 -0
  116. package/dist/src/extensions/Blocks/Recommendation/controls/layout/index.d.ts +37 -0
  117. package/dist/src/extensions/Blocks/Recommendation/controls/main/algorithm.d.ts +29 -0
  118. package/dist/src/extensions/Blocks/Recommendation/controls/main/currency.d.ts +52 -0
  119. package/dist/src/extensions/Blocks/Recommendation/controls/main/filters.d.ts +22 -0
  120. package/dist/src/extensions/Blocks/Recommendation/controls/main/index.d.ts +79 -0
  121. package/dist/src/extensions/Blocks/Recommendation/controls/main/locale.d.ts +24 -0
  122. package/dist/src/extensions/Blocks/Recommendation/controls/main/productLayout.d.ts +60 -0
  123. package/dist/src/extensions/Blocks/Recommendation/controls/main/shuffle.d.ts +23 -0
  124. package/dist/src/extensions/Blocks/Recommendation/controls/main/utils.d.ts +221 -0
  125. package/dist/src/extensions/Blocks/Recommendation/controls/mobileLayout/cssRules.d.ts +29 -0
  126. package/dist/src/extensions/Blocks/Recommendation/controls/name/index.d.ts +97 -0
  127. package/dist/src/extensions/Blocks/Recommendation/controls/name/textTrim.d.ts +34 -0
  128. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/index.d.ts +95 -0
  129. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusDiscount/index.d.ts +100 -0
  130. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusDiscount/textAfter.d.ts +15 -0
  131. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusDiscount/textBefore.d.ts +15 -0
  132. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusDiscountTextAfterControl.d.ts +15 -0
  133. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusDiscountTextBeforeControl.d.ts +15 -0
  134. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusPrice/index.d.ts +100 -0
  135. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusPrice/textAfter.d.ts +15 -0
  136. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusPrice/textBefore.d.ts +15 -0
  137. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusPriceTextAfterControl.d.ts +15 -0
  138. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusPriceTextBeforeControl.d.ts +15 -0
  139. package/dist/src/extensions/Blocks/Recommendation/controls/price/index.d.ts +95 -0
  140. package/dist/src/extensions/Blocks/Recommendation/controls/spacing/index.d.ts +83 -0
  141. package/dist/src/extensions/Blocks/Recommendation/controls/spacingControl.d.ts +60 -0
  142. package/dist/src/extensions/Blocks/Recommendation/extension.d.ts +9 -0
  143. package/dist/src/extensions/Blocks/Recommendation/services/configService.d.ts +151 -0
  144. package/dist/src/extensions/Blocks/Recommendation/services/index.d.ts +6 -0
  145. package/dist/src/extensions/Blocks/Recommendation/store/recommendation.d.ts +138 -468
  146. package/dist/src/extensions/Blocks/Recommendation/templates/grid/elementRenderer.d.ts +20 -0
  147. package/dist/src/extensions/Blocks/Recommendation/templates/{migrationTemplate.d.ts → grid/migration.d.ts} +11 -4
  148. package/dist/src/extensions/Blocks/Recommendation/templates/grid/template.d.ts +33 -0
  149. package/dist/src/extensions/Blocks/Recommendation/templates/index.d.ts +41 -0
  150. package/dist/src/extensions/Blocks/Recommendation/templates/list/elementRenderer.d.ts +8 -0
  151. package/dist/src/extensions/Blocks/Recommendation/templates/list/migration.d.ts +25 -0
  152. package/dist/src/extensions/Blocks/Recommendation/templates/list/template.d.ts +18 -0
  153. package/dist/src/extensions/Blocks/Recommendation/templates/utils.d.ts +66 -0
  154. package/dist/src/extensions/Blocks/Recommendation/types/index.d.ts +7 -0
  155. package/dist/src/extensions/Blocks/Recommendation/types/nodeConfig.d.ts +166 -0
  156. package/dist/src/extensions/Blocks/Recommendation/utils/preserveTextStyles.d.ts +19 -0
  157. package/dist/src/extensions/Blocks/Recommendation/utils/priceFormatter.d.ts +33 -0
  158. package/dist/src/extensions/Blocks/Recommendation/utils/stylePreserver.d.ts +113 -0
  159. package/dist/src/extensions/Blocks/Recommendation/utils/tagName.d.ts +77 -0
  160. package/dist/src/extensions/Blocks/common-control.d.ts +4 -5
  161. package/dist/static/styles/components/notification.css.js +1 -0
  162. package/dist/static/styles/components/version-history.css.js +10 -2
  163. package/dist/static/styles/components/wide-panel.css.js +18 -6
  164. package/dist/static/styles/customEditorStyle.css.js +39 -2
  165. package/dist/utils/pairProductVariables.js +57 -56
  166. package/dist/utils/templatePreparation.js +15 -14
  167. package/package.json +2 -2
  168. package/dist/extensions/Blocks/Items/store/items-block.js +0 -79
  169. package/dist/extensions/Blocks/Recommendation/cardCompositionControl.js +0 -103
  170. package/dist/extensions/Blocks/Recommendation/constants.js +0 -5
  171. package/dist/extensions/Blocks/Recommendation/control.js +0 -306
  172. package/dist/extensions/Blocks/Recommendation/controls/button/align.js +0 -13
  173. package/dist/extensions/Blocks/Recommendation/controls/button/border.js +0 -13
  174. package/dist/extensions/Blocks/Recommendation/controls/button/borderRadius.js +0 -13
  175. package/dist/extensions/Blocks/Recommendation/controls/button/color.js +0 -13
  176. package/dist/extensions/Blocks/Recommendation/controls/button/fitToContent.js +0 -13
  177. package/dist/extensions/Blocks/Recommendation/controls/button/fontFamily.js +0 -13
  178. package/dist/extensions/Blocks/Recommendation/controls/button/margins.js +0 -13
  179. package/dist/extensions/Blocks/Recommendation/controls/button/paddings.js +0 -13
  180. package/dist/extensions/Blocks/Recommendation/controls/button/text.js +0 -13
  181. package/dist/extensions/Blocks/Recommendation/controls/button/textSize.js +0 -13
  182. package/dist/extensions/Blocks/Recommendation/controls/button/textStyleAndFontColor.js +0 -13
  183. package/dist/extensions/Blocks/Recommendation/controls/image/margins.js +0 -13
  184. package/dist/extensions/Blocks/Recommendation/controls/image/size.js +0 -13
  185. package/dist/extensions/Blocks/Recommendation/controls/name/align.js +0 -13
  186. package/dist/extensions/Blocks/Recommendation/controls/name/background.js +0 -13
  187. package/dist/extensions/Blocks/Recommendation/controls/name/color.js +0 -13
  188. package/dist/extensions/Blocks/Recommendation/controls/name/fontFamily.js +0 -13
  189. package/dist/extensions/Blocks/Recommendation/controls/name/paddings.js +0 -13
  190. package/dist/extensions/Blocks/Recommendation/controls/name/size.js +0 -13
  191. package/dist/extensions/Blocks/Recommendation/controls/name/style.js +0 -13
  192. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/align.js +0 -13
  193. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/background.js +0 -13
  194. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/color.js +0 -13
  195. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/fontFamily.js +0 -13
  196. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/paddings.js +0 -13
  197. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/size.js +0 -13
  198. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/style.js +0 -13
  199. package/dist/extensions/Blocks/Recommendation/controls/price/align.js +0 -13
  200. package/dist/extensions/Blocks/Recommendation/controls/price/background.js +0 -13
  201. package/dist/extensions/Blocks/Recommendation/controls/price/color.js +0 -13
  202. package/dist/extensions/Blocks/Recommendation/controls/price/fontFamily.js +0 -13
  203. package/dist/extensions/Blocks/Recommendation/controls/price/paddings.js +0 -13
  204. package/dist/extensions/Blocks/Recommendation/controls/price/size.js +0 -13
  205. package/dist/extensions/Blocks/Recommendation/controls/price/style.js +0 -13
  206. package/dist/extensions/Blocks/Recommendation/templates/blockTemplate.js +0 -160
  207. package/dist/extensions/Blocks/Recommendation/templates/migrationTemplate.js +0 -152
  208. package/dist/extensions/Blocks/Recommendation/templates/templateUtils.js +0 -180
  209. package/dist/src/extensions/Blocks/Items/store/items-block.d.ts +0 -45
  210. package/dist/src/extensions/Blocks/Recommendation/cardCompositionControl.d.ts +0 -28
  211. package/dist/src/extensions/Blocks/Recommendation/control.d.ts +0 -35
  212. package/dist/src/extensions/Blocks/Recommendation/controls/button/align.d.ts +0 -5
  213. package/dist/src/extensions/Blocks/Recommendation/controls/button/border.d.ts +0 -5
  214. package/dist/src/extensions/Blocks/Recommendation/controls/button/borderRadius.d.ts +0 -5
  215. package/dist/src/extensions/Blocks/Recommendation/controls/button/color.d.ts +0 -5
  216. package/dist/src/extensions/Blocks/Recommendation/controls/button/fitToContent.d.ts +0 -5
  217. package/dist/src/extensions/Blocks/Recommendation/controls/button/fontFamily.d.ts +0 -5
  218. package/dist/src/extensions/Blocks/Recommendation/controls/button/margins.d.ts +0 -5
  219. package/dist/src/extensions/Blocks/Recommendation/controls/button/paddings.d.ts +0 -5
  220. package/dist/src/extensions/Blocks/Recommendation/controls/button/text.d.ts +0 -5
  221. package/dist/src/extensions/Blocks/Recommendation/controls/button/textSize.d.ts +0 -5
  222. package/dist/src/extensions/Blocks/Recommendation/controls/button/textStyleAndFontColor.d.ts +0 -5
  223. package/dist/src/extensions/Blocks/Recommendation/controls/image/margins.d.ts +0 -5
  224. package/dist/src/extensions/Blocks/Recommendation/controls/image/size.d.ts +0 -5
  225. package/dist/src/extensions/Blocks/Recommendation/controls/name/align.d.ts +0 -5
  226. package/dist/src/extensions/Blocks/Recommendation/controls/name/background.d.ts +0 -5
  227. package/dist/src/extensions/Blocks/Recommendation/controls/name/color.d.ts +0 -5
  228. package/dist/src/extensions/Blocks/Recommendation/controls/name/fontFamily.d.ts +0 -5
  229. package/dist/src/extensions/Blocks/Recommendation/controls/name/paddings.d.ts +0 -5
  230. package/dist/src/extensions/Blocks/Recommendation/controls/name/size.d.ts +0 -5
  231. package/dist/src/extensions/Blocks/Recommendation/controls/name/style.d.ts +0 -5
  232. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/align.d.ts +0 -5
  233. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/background.d.ts +0 -5
  234. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/color.d.ts +0 -5
  235. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/fontFamily.d.ts +0 -5
  236. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/paddings.d.ts +0 -5
  237. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/size.d.ts +0 -5
  238. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/style.d.ts +0 -5
  239. package/dist/src/extensions/Blocks/Recommendation/controls/price/align.d.ts +0 -5
  240. package/dist/src/extensions/Blocks/Recommendation/controls/price/background.d.ts +0 -5
  241. package/dist/src/extensions/Blocks/Recommendation/controls/price/color.d.ts +0 -5
  242. package/dist/src/extensions/Blocks/Recommendation/controls/price/fontFamily.d.ts +0 -5
  243. package/dist/src/extensions/Blocks/Recommendation/controls/price/paddings.d.ts +0 -5
  244. package/dist/src/extensions/Blocks/Recommendation/controls/price/size.d.ts +0 -5
  245. package/dist/src/extensions/Blocks/Recommendation/controls/price/style.d.ts +0 -5
  246. package/dist/src/extensions/Blocks/Recommendation/templates/blockTemplate.d.ts +0 -16
  247. package/dist/src/extensions/Blocks/Recommendation/templates/templateUtils.d.ts +0 -44
@@ -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,66 @@
1
+ import { DEFAULT_PRODUCTS_PER_ROW as m, DEFAULT_MOBILE_CARDS_IN_ROW as I } from "../../constants/layout.js";
2
+ import { DEFAULT_CARD_COMPOSITION as _, spacer as E, getDefaultProducts as S, createBlockTemplate as A, DEFAULTS as b, DEFAULT_CARD_VISIBILITY as D } from "../utils.js";
3
+ import { gridElementRenderer as w, ATTRIBUTE_CELL_CLASS as C, DEFAULT_CELL_PADDING as f } from "./elementRenderer.js";
4
+ const O = `
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
+ `, U = `
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, n = _) {
31
+ const c = (100 / e).toFixed(2), s = e - t.length, o = `<td class="${C}" style="padding: ${f};" width="${c}%"></td>`, i = s > 0 ? o.repeat(s) : "";
32
+ return n.filter((l) => r[l]).map((l) => {
33
+ const p = D[l] ?? !0, T = p ? "" : 'style="display: none;"', u = t.map((R) => {
34
+ const L = r[l];
35
+ return L(R).replace("<td", `<td width="${c}%"`);
36
+ }).join("");
37
+ return U.replace("{-{-ATTR_TYPE-}-}", l).replace("{-{-VISIBILITY-}-}", p ? "1" : "0").replace("{-{-DISPLAY_STYLE-}-}", T).replace("{-{-CELLS-}-}", u + i);
38
+ }).join("");
39
+ }
40
+ function P(t, e, r, n) {
41
+ const c = [];
42
+ for (let o = 0; o < t.length; o += e)
43
+ c.push(t.slice(o, o + e));
44
+ return c.map((o, i) => {
45
+ const a = g(
46
+ o,
47
+ e,
48
+ r,
49
+ n
50
+ ), l = O.replace("{-{-ATTRIBUTE_ROWS-}-}", a);
51
+ return i > 0 ? E + l : l;
52
+ }).join("");
53
+ }
54
+ function d(t, e, r) {
55
+ return P(t, e, w, r);
56
+ }
57
+ function W(t) {
58
+ const e = t ? `ins-recommendation-v3-block-${t}` : void 0, r = A("grid", e), n = S(), c = d(n, m), s = d(n, I);
59
+ return r.replace("{-{-TITLE-}-}", b.TITLE).replace("{-{-PRODUCT_ROWS-}-}", c).replace("{-{-MOBILE_PRODUCT_ROWS-}-}", s);
60
+ }
61
+ export {
62
+ W as getDefaultTemplate,
63
+ g as prepareGridAttributeRows,
64
+ P as prepareGridProductRows,
65
+ d as prepareProductRows
66
+ };
@@ -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
+ };