@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
@@ -1,4 +1,4 @@
1
- const s = 20, e = 320, t = {
1
+ const e = 20, s = 320, t = "vertical", m = {
2
2
  CART_ABANDONMENT: {
3
3
  ins_apr_img_1: "https://s3-eu-west-1.amazonaws.com/web-image.useinsider.com/email-assets/dummyImages/ins_apr_img_1.png",
4
4
  ins_apr_img_2: "https://s3-eu-west-1.amazonaws.com/web-image.useinsider.com/email-assets/dummyImages/ins_apr_img_2.png",
@@ -15,7 +15,7 @@ const s = 20, e = 320, t = {
15
15
  DISCOUNT: "discount",
16
16
  OMNIBUS_DISCOUNT: "omnibus_discount",
17
17
  OMNIBUS_PRICE: "omnibus_price"
18
- }, m = {
18
+ }, _ = {
19
19
  IF: {
20
20
  discount: `{% if {${i.DISCOUNT}} != "0%" and {${i.DISCOUNT}} != "" %}`,
21
21
  omnibus_discount: `{% if {${i.DISCOUNT}} != "0%" and {${i.DISCOUNT}} != "" and {${i.OMNIBUS_DISCOUNT}} != "0%" and {${i.OMNIBUS_DISCOUNT}} != "" %}`,
@@ -23,17 +23,17 @@ const s = 20, e = 320, t = {
23
23
  },
24
24
  ELSE: "{% else %}",
25
25
  END_IF: "{% endif %}"
26
- }, _ = {
27
- ID: /ins-recommendation-v3-campaign-id="(.*?)"/gi,
28
- ATTRIBUTE_PARAGRAPH: /<p[^>]*?product-attr="(discount|omnibus_discount|omnibus_price)">[\S\s]*?<\/p>/gm,
29
- ATTRIBUTE_PARAGRAPH_START_TAG: /<p[^>]*?product-attr="(discount|omnibus_discount|omnibus_price)">/gm,
26
+ }, a = {
27
+ ID: /recommendation-id="(.*?)"/gi,
28
+ ATTRIBUTE_PARAGRAPH: /<p[^>]*?product-attr="(discount|omnibus_discount|omnibus_price)"[^>]*>[\S\s]*?<\/p>/gm,
29
+ ATTRIBUTE_PARAGRAPH_START_TAG: /<p[^>]*?product-attr="(discount|omnibus_discount|omnibus_price)"[^>]*>/gm,
30
30
  COMPOSITION: /composition="true"/gm,
31
31
  CUSTOM_FIELD: /{{[0-9]+_[0-8]_(discount|omnibus_discount|omnibus_price)}}/gm,
32
32
  CUSTOM_FIELD_INDEXES_PART: /{{[0-9]+_[0-8]_/gm,
33
33
  CUSTOM_FIELD_NAME_PART: /_(discount|omnibus_discount|omnibus_price)}}/gm
34
- }, a = {
35
- PARAGRAPH_END_TAG: "</p>"
36
34
  }, n = {
35
+ PARAGRAPH_END_TAG: "</p>"
36
+ }, o = {
37
37
  REGULAR_NAME_HEIGHT: ".ext-product-name.ins-vertical p { height:90px!important;",
38
38
  TRIMMED_NAME_HEIGHT: ".ext-product-name.ins-vertical p { height:18px!important;",
39
39
  ELLIPSIS: "text-overflow:ellipsis!important; white-space:nowrap!important;",
@@ -46,11 +46,12 @@ const s = 20, e = 320, t = {
46
46
  };
47
47
  export {
48
48
  i as ATTRIBUTES,
49
- m as CONDITIONS,
50
- n as CSS,
51
- t as DUMMY_IMAGE_MAPPINGS,
52
- s as DefaultPadding,
53
- a as HTML,
54
- e as MinDeviceViewport,
55
- _ as REGEX
49
+ _ as CONDITIONS,
50
+ o as CSS,
51
+ m as DUMMY_IMAGE_MAPPINGS,
52
+ e as DefaultPadding,
53
+ n as HTML,
54
+ s as MinDeviceViewport,
55
+ a as REGEX,
56
+ t as VerticalOrientation
56
57
  };
@@ -1,11 +1,10 @@
1
- import { useOnboardingStore as m } from "../../../stores/onboarding.js";
2
- import { Block as u, BlockCompositionType as d, ModificationDescription as i } from "../../../node_modules/@stripoinc/ui-editor-extensions/dist/esm/index.js";
3
- import { SETTINGS_ENUMS as c, DefaultConfigValues as o } from "./enums/settingsEnums.js";
4
- import { useItemsBlockStore as p } from "./store/items-block.js";
5
- import { getDefaultTemplate as f } from "./template.js";
6
- import { getItemsBlockContainer as g, getItemsBlockConfig as a, getDefaultItemsBlockConfig as C } from "./utils/nodeConfigUtils.js";
1
+ import { useOnboardingStore as d } from "../../../stores/onboarding.js";
2
+ import { Block as g, BlockCompositionType as f, ModificationDescription as o } from "../../../node_modules/@stripoinc/ui-editor-extensions/dist/esm/index.js";
3
+ import { SETTINGS_ENUMS as c, DefaultConfigValues as i } from "./enums/settingsEnums.js";
4
+ import { getDefaultTemplate as p } from "./template.js";
5
+ import { getItemsBlockContainer as u, getItemsBlockConfig as C, getDefaultItemsBlockConfig as I } from "./utils/nodeConfigUtils.js";
7
6
  const y = "items-block";
8
- class B extends u {
7
+ class B extends g {
9
8
  getId() {
10
9
  return y;
11
10
  }
@@ -13,7 +12,7 @@ class B extends u {
13
12
  return "items-icon";
14
13
  }
15
14
  getBlockCompositionType() {
16
- return d.CONTAINER;
15
+ return f.CONTAINER;
17
16
  }
18
17
  getName() {
19
18
  return this.api.translate("Items");
@@ -22,40 +21,32 @@ class B extends u {
22
21
  return this.api.translate("Items lets you display personalized products based on user behavior.");
23
22
  }
24
23
  getTemplate() {
25
- return f({
24
+ return p({
26
25
  orientation: c.ORIENTATION.VERTICAL,
27
26
  itemsType: c.ITEMS_TYPE.CART_ITEMS,
28
27
  itemId: "{{Abandoned Cart Item (1) Url}}",
29
- currencySymbol: o.productPriceCurrencySymbolControlValue,
30
- currencyLocation: o.productPriceCurrencyLocationControlValue,
31
- formattedPrice: o.productPriceFormattedControlValue === "1"
28
+ currencySymbol: i.productPriceCurrencySymbolControlValue,
29
+ currencyLocation: i.productPriceCurrencyLocationControlValue,
30
+ formattedPrice: i.productPriceFormattedControlValue === "1"
32
31
  });
33
32
  }
34
33
  allowInnerBlocksDND() {
35
34
  return !1;
36
35
  }
37
36
  onCreated(n) {
38
- const e = g(n);
37
+ const s = this.api.getDocumentModifier(), r = this.api.getDocumentRootCssNode();
38
+ r.querySelector('[product-attr="imageSrc"] img') || s.modifyCss(r).appendRule('[product-attr="imageSrc"] img {object-fit: contain;}');
39
+ const e = u(n);
39
40
  if (!e)
40
41
  return;
41
- const t = e.getNodeConfig(), l = t && Object.keys(t).length > 0, r = a(n);
42
- if (r != null && r.initialized)
43
- l ? r.blockInstanceId || this.api.getDocumentModifier().modifyHtml(e).setNodeConfig({ ...r, blockInstanceId: String(Date.now()) }).apply(new i("Assign block instance ID to block")) : this.api.getDocumentModifier().modifyHtml(e).setNodeConfig(r).apply(new i("Migrate legacy config to nodeConfig"));
42
+ const a = e.getNodeConfig(), l = a && Object.keys(a).length > 0, t = C(n);
43
+ if (t != null && t.initialized)
44
+ l ? t.blockInstanceId || this.api.getDocumentModifier().modifyHtml(e).setNodeConfig({ ...t, blockInstanceId: String(Date.now()) }).apply(new o("Assign block instance ID to block")) : this.api.getDocumentModifier().modifyHtml(e).setNodeConfig(t).apply(new o("Migrate legacy config to nodeConfig"));
44
45
  else {
45
- const s = C();
46
- this.api.getDocumentModifier().modifyHtml(e).setNodeConfig(s).apply(new i("Initialize Items block with default configuration")), m().startOnboarding("itemsOnboarding");
46
+ const m = I();
47
+ this.api.getDocumentModifier().modifyHtml(e).setNodeConfig(m).apply(new o("Initialize Items block with default configuration")), d().startOnboarding("itemsOnboarding");
47
48
  }
48
49
  }
49
- onSelect(n) {
50
- const e = p(), t = a(n);
51
- t && (e.setItemsType(t.type || o.itemsType), e.setItemIds(t.itemsSelectValue || o.cartItemsSelectControlValue), e.setOrientation(t.orientation || o.cardOrientationControlValue), e.setCurrencySymbol(
52
- t.priceCurrencySymbol || o.productPriceCurrencySymbolControlValue
53
- ), e.setCurrencyLocation(
54
- t.priceCurrencyLocation || o.productPriceCurrencyLocationControlValue
55
- ), e.setFormattedPrice(
56
- t.priceFormatted ?? o.productPriceFormattedControlValue === "1"
57
- ));
58
- }
59
50
  }
60
51
  export {
61
52
  y as BLOCK_ID,
@@ -1,52 +1,40 @@
1
- var a = Object.defineProperty;
2
- var l = (e, t, n) => t in e ? a(e, t, { enumerable: !0, configurable: !0, writable: !0, value: n }) : e[t] = n;
3
- var i = (e, t, n) => l(e, typeof t != "symbol" ? t + "" : t, n);
4
- import { CommonControl as u } from "../../../common-control.js";
5
- import { ItemsBlockControlId as d } from "../../enums/controlEnums.js";
6
- import { useItemsBlockStore as m } from "../../store/items-block.js";
7
- import { getItemsBlockConfig as L } from "../../utils/nodeConfigUtils.js";
8
- const r = d.BUTTON_LINK, s = {
1
+ import { CommonControl as r } from "../../../common-control.js";
2
+ import { ItemsBlockControlId as i } from "../../enums/controlEnums.js";
3
+ import { getItemsBlockConfig as o } from "../../utils/nodeConfigUtils.js";
4
+ const s = i.BUTTON_LINK, n = {
9
5
  LINK: "link"
10
6
  };
11
- class N extends u {
12
- constructor() {
13
- super(...arguments);
14
- i(this, "store", m());
15
- }
7
+ class m extends r {
16
8
  getId() {
17
- return r;
9
+ return s;
18
10
  }
19
11
  getTemplate() {
20
12
  return `
21
- <div class="container ${r}">
13
+ <div class="container ${s}">
22
14
  ${this._getLink()}
23
15
  </div>
24
16
  `;
25
17
  }
26
18
  onRender() {
19
+ const t = o(this.currentNode);
27
20
  this.api.updateValues({
28
- [s.LINK]: this.store.buttonLink
21
+ [n.LINK]: (t == null ? void 0 : t.buttonLink) ?? ""
29
22
  });
30
23
  }
31
- onTemplateNodeUpdated(n) {
32
- super.onTemplateNodeUpdated(n), this.handleBlockInstanceChange(
33
- () => {
34
- const o = L(this.currentNode);
35
- o != null && o.buttonLink && this.store.setButtonLink(o.buttonLink);
36
- },
37
- () => {
38
- this.api.updateValues({
39
- [s.LINK]: this.store.buttonLink
40
- });
41
- }
42
- );
24
+ onTemplateNodeUpdated(t) {
25
+ super.onTemplateNodeUpdated(t), this.handleBlockInstanceChange(() => {
26
+ const e = o(this.currentNode);
27
+ this.api.updateValues({
28
+ [n.LINK]: (e == null ? void 0 : e.buttonLink) ?? ""
29
+ });
30
+ });
43
31
  }
44
32
  _getLink() {
45
33
  return `
46
34
  ${this._GuOneColumn([
47
35
  this._GuLabel({ text: "Link" }),
48
36
  this._GuTextInput({
49
- name: s.LINK,
37
+ name: n.LINK,
50
38
  placeholder: "Enter Link",
51
39
  className: "es-100",
52
40
  disabled: !0
@@ -56,6 +44,6 @@ class N extends u {
56
44
  }
57
45
  }
58
46
  export {
59
- N as ButtonLinkControl,
60
- r as CONTROL_BLOCK_ID
47
+ m as ButtonLinkControl,
48
+ s as CONTROL_BLOCK_ID
61
49
  };
@@ -1,13 +1,12 @@
1
- var O = Object.defineProperty;
2
- var y = (a, r, t) => r in a ? O(a, r, { enumerable: !0, configurable: !0, writable: !0, value: t }) : a[r] = t;
3
- var P = (a, r, t) => y(a, typeof r != "symbol" ? r + "" : r, t);
4
- import { ModificationDescription as l } from "../../../../node_modules/@stripoinc/ui-editor-extensions/dist/esm/index.js";
5
- import { CommonControl as I } from "../../common-control.js";
6
- import { ItemsBlockId as s } from "../enums/controlEnums.js";
1
+ var I = Object.defineProperty;
2
+ var U = (d, a, t) => a in d ? I(d, a, { enumerable: !0, configurable: !0, writable: !0, value: t }) : d[a] = t;
3
+ var p = (d, a, t) => U(d, typeof a != "symbol" ? a + "" : a, t);
4
+ import { ModificationDescription as c } from "../../../../node_modules/@stripoinc/ui-editor-extensions/dist/esm/index.js";
5
+ import { CommonControl as b } from "../../common-control.js";
6
+ import { ItemsBlockId as r } from "../enums/controlEnums.js";
7
7
  import { SETTINGS_ENUMS as h } from "../enums/settingsEnums.js";
8
- import { useItemsBlockStore as p } from "../store/items-block.js";
9
- import { getItemsBlockConfig as R, setItemsBlockConfig as U } from "../utils/nodeConfigUtils.js";
10
- const b = "ui-elements-items-card-composition-block", i = {
8
+ import { getItemsBlockConfig as R, setItemsBlockConfig as m } from "../utils/nodeConfigUtils.js";
9
+ const g = "ui-elements-items-card-composition-block", i = {
11
10
  PRODUCT_IMAGE: "image",
12
11
  PRODUCT_NAME: "name",
13
12
  PRODUCT_QUANTITY: "quantity",
@@ -15,11 +14,10 @@ const b = "ui-elements-items-card-composition-block", i = {
15
14
  PRODUCT_ORIGINAL_PRICE: "originalPrice",
16
15
  PRODUCT_BUTTON: "button"
17
16
  };
18
- class S extends I {
17
+ class M extends b {
19
18
  constructor() {
20
19
  super(...arguments);
21
- P(this, "store", p());
22
- P(this, "visibilityState", {
20
+ p(this, "visibilityState", {
23
21
  [i.PRODUCT_IMAGE]: !0,
24
22
  [i.PRODUCT_NAME]: !0,
25
23
  [i.PRODUCT_QUANTITY]: !0,
@@ -29,7 +27,7 @@ class S extends I {
29
27
  });
30
28
  }
31
29
  getId() {
32
- return b;
30
+ return g;
33
31
  }
34
32
  getTemplate() {
35
33
  return `
@@ -49,14 +47,9 @@ class S extends I {
49
47
  this._syncVisibilityFromAttributes(), this._handleBrowsedItemsQuantity(), this._initializeToggles(), this._listenToFormUpdates();
50
48
  }
51
49
  onTemplateNodeUpdated(t) {
52
- super.onTemplateNodeUpdated(t), this.handleBlockInstanceChange(
53
- () => {
54
- this._syncVisibilityFromAttributes(), this._handleBrowsedItemsQuantity(), this._applyVisibilityStyles();
55
- },
56
- () => {
57
- this._updateTogglesFromState();
58
- }
59
- );
50
+ super.onTemplateNodeUpdated(t), this.handleBlockInstanceChange(() => {
51
+ this._syncVisibilityFromAttributes(), this._handleBrowsedItemsQuantity(!0), this._updateTogglesFromState();
52
+ });
60
53
  }
61
54
  _getToggleContainer({ name: t, label: e }) {
62
55
  return `
@@ -94,42 +87,45 @@ class S extends I {
94
87
  [i.PRODUCT_BUTTON]: "buttonVisible"
95
88
  };
96
89
  Object.entries(e).forEach(([o, n]) => {
97
- const c = t[n];
98
- this.visibilityState[o] = c !== !1;
90
+ const s = t[n];
91
+ this.visibilityState[o] = s !== !1;
99
92
  });
100
93
  }
101
94
  /**
102
95
  * If itemsType is not BROWSED_ITEMS, show quantity
103
96
  * If itemsType is BROWSED_ITEMS, hide quantity
104
97
  * and mark it as '0'
98
+ * @param syncOnly - If true, only sync local state and UI without modifying the document
105
99
  */
106
- _handleBrowsedItemsQuantity() {
107
- const t = this.store.itemsType !== h.ITEMS_TYPE.BROWSED_ITEMS, e = R(this.currentNode);
100
+ _handleBrowsedItemsQuantity(t = !1) {
101
+ const e = R(this.currentNode), n = ((e == null ? void 0 : e.type) ?? h.ITEMS_TYPE.CART_ITEMS) !== h.ITEMS_TYPE.BROWSED_ITEMS;
108
102
  if (!e)
109
103
  return;
110
- const o = e.quantityControlEnabled !== !1;
111
- this.visibilityState[i.PRODUCT_QUANTITY] = t && o, this.api.setVisibility(`${i.PRODUCT_QUANTITY}Container`, t), this._updateVisibilityAttribute(i.PRODUCT_QUANTITY, t && o);
112
- }
113
- _applyVisibilityStyles() {
114
- const t = {
115
- [i.PRODUCT_IMAGE]: s.IMAGE,
116
- [i.PRODUCT_NAME]: s.NAME,
117
- [i.PRODUCT_QUANTITY]: s.QUANTITY,
118
- [i.PRODUCT_PRICE]: s.PRICE,
119
- [i.PRODUCT_ORIGINAL_PRICE]: s.ORIGINAL_PRICE,
120
- [i.PRODUCT_BUTTON]: s.BUTTON
121
- };
122
- Object.entries(t).forEach(([e, o]) => {
123
- var d;
124
- const n = (d = this.currentNode) == null ? void 0 : d.querySelector(`[esd-extension-block-id="${o}"]`);
125
- if (!n)
104
+ const s = e.quantityControlEnabled !== !1;
105
+ this.visibilityState[i.PRODUCT_QUANTITY] = n && s, this.api.setVisibility(`${i.PRODUCT_QUANTITY}Container`, n), t || this._updateVisibilityAttribute(i.PRODUCT_QUANTITY, n && s);
106
+ }
107
+ _applyVisibilityStyles(t) {
108
+ const e = {
109
+ [i.PRODUCT_IMAGE]: r.IMAGE,
110
+ [i.PRODUCT_NAME]: r.NAME,
111
+ [i.PRODUCT_QUANTITY]: r.QUANTITY,
112
+ [i.PRODUCT_PRICE]: r.PRICE,
113
+ [i.PRODUCT_ORIGINAL_PRICE]: r.ORIGINAL_PRICE,
114
+ [i.PRODUCT_BUTTON]: r.BUTTON
115
+ }, o = t ?? this.api.getDocumentModifier();
116
+ Object.entries(e).forEach(([n, s]) => {
117
+ var C;
118
+ const l = (C = this.currentNode) == null ? void 0 : C.querySelectorAll(`[esd-extension-block-id="${s}"]`);
119
+ if (!l)
126
120
  return;
127
- const c = this.visibilityState[e];
128
- this.api.getDocumentModifier().modifyHtml(n).setStyle("display", c ? "table-cell" : "none").apply(new l(`Applied ${e} visibility from attributes`));
129
- }), this._updatePriceCellWidthsForVerticalLayout();
121
+ const P = this.visibilityState[n];
122
+ l.forEach((T) => {
123
+ o.modifyHtml(T).setStyle("display", P ? "table-cell" : "none");
124
+ });
125
+ }), this._updatePriceCellWidthsForVerticalLayout(o), t || o.apply(new c("Applied visibility styles"));
130
126
  }
131
- _updateVisibilityAttribute(t, e) {
132
- const n = {
127
+ _updateVisibilityAttribute(t, e, o) {
128
+ const s = {
133
129
  [i.PRODUCT_IMAGE]: "imageVisible",
134
130
  [i.PRODUCT_NAME]: "nameVisible",
135
131
  [i.PRODUCT_QUANTITY]: "quantityControlEnabled",
@@ -137,46 +133,87 @@ class S extends I {
137
133
  [i.PRODUCT_ORIGINAL_PRICE]: "originalPriceVisible",
138
134
  [i.PRODUCT_BUTTON]: "buttonVisible"
139
135
  }[t];
140
- n && U(this.currentNode, this.api, {
141
- [n]: e
142
- });
136
+ s && m(this.currentNode, this.api, {
137
+ [s]: e
138
+ }, o);
143
139
  }
144
140
  _listenToFormUpdates() {
145
- this.api.onValueChanged(i.PRODUCT_IMAGE, (t) => this._onProductImageChange(t)), this.api.onValueChanged(i.PRODUCT_NAME, (t) => this._onProductNameChange(t)), this.api.onValueChanged(i.PRODUCT_QUANTITY, (t) => this._onProductQuantityChange(t)), this.api.onValueChanged(i.PRODUCT_PRICE, (t) => this._onProductPriceChange(t)), this.api.onValueChanged(
146
- i.PRODUCT_ORIGINAL_PRICE,
147
- (t) => this._onProductOriginalPriceChange(t)
148
- ), this.api.onValueChanged(i.PRODUCT_BUTTON, (t) => this._onProductButtonChange(t));
141
+ this.api.onValueChanged(i.PRODUCT_IMAGE, (t) => {
142
+ this._onProductImageChange(t);
143
+ }), this.api.onValueChanged(i.PRODUCT_NAME, (t) => {
144
+ this._onProductNameChange(t);
145
+ }), this.api.onValueChanged(i.PRODUCT_QUANTITY, (t) => {
146
+ this._onProductQuantityChange(t);
147
+ }), this.api.onValueChanged(i.PRODUCT_PRICE, (t) => {
148
+ this._onProductPriceChange(t);
149
+ }), this.api.onValueChanged(i.PRODUCT_ORIGINAL_PRICE, (t) => {
150
+ this._onProductOriginalPriceChange(t);
151
+ }), this.api.onValueChanged(i.PRODUCT_BUTTON, (t) => {
152
+ this._onProductButtonChange(t);
153
+ });
149
154
  }
150
155
  _onProductImageChange(t) {
151
- var o;
152
- const e = (o = this.currentNode) == null ? void 0 : o.querySelector(`[esd-extension-block-id="${s.IMAGE}"]`);
153
- e && (this.visibilityState[i.PRODUCT_IMAGE] = t, this.api.getDocumentModifier().modifyHtml(e).setStyle("display", t ? "table-cell" : "none").apply(new l(`Product image visibility changed to ${t ? "visible" : "hidden"}`)), this._updateVisibilityAttribute(i.PRODUCT_IMAGE, t));
156
+ var s;
157
+ const e = (s = this.currentNode) == null ? void 0 : s.querySelector(`[esd-extension-block-id="${r.IMAGE}"]`);
158
+ if (!e)
159
+ return;
160
+ this.visibilityState[i.PRODUCT_IMAGE] = t;
161
+ const o = this.api.getDocumentModifier();
162
+ o.modifyHtml(e).setStyle("display", t ? "table-cell" : "none"), this._updateVisibilityAttribute(i.PRODUCT_IMAGE, t, o);
163
+ const n = `Product image visibility changed to ${t ? "visible" : "hidden"}`;
164
+ o.apply(new c(n));
154
165
  }
155
166
  _onProductNameChange(t) {
156
- var o;
157
- const e = (o = this.currentNode) == null ? void 0 : o.querySelector(`[esd-extension-block-id="${s.NAME}"]`);
158
- e && (this.visibilityState[i.PRODUCT_NAME] = t, this.api.getDocumentModifier().modifyHtml(e).setStyle("display", t ? "table-cell" : "none").apply(new l(`Product name visibility changed to ${t ? "visible" : "hidden"}`)), this._updateVisibilityAttribute(i.PRODUCT_NAME, t));
167
+ var s;
168
+ const e = (s = this.currentNode) == null ? void 0 : s.querySelector(`[esd-extension-block-id="${r.NAME}"]`);
169
+ if (!e)
170
+ return;
171
+ this.visibilityState[i.PRODUCT_NAME] = t;
172
+ const o = this.api.getDocumentModifier();
173
+ o.modifyHtml(e).setStyle("display", t ? "table-cell" : "none"), this._updateVisibilityAttribute(i.PRODUCT_NAME, t, o);
174
+ const n = `Product name visibility changed to ${t ? "visible" : "hidden"}`;
175
+ o.apply(new c(n));
159
176
  }
160
177
  _onProductQuantityChange(t) {
161
- var o;
162
- const e = (o = this.currentNode) == null ? void 0 : o.querySelector(`[esd-extension-block-id="${s.QUANTITY}"]`);
163
- e && (this.visibilityState[i.PRODUCT_QUANTITY] = t, this.api.getDocumentModifier().modifyHtml(e).setStyle("display", t ? "table-cell" : "none").apply(new l(
164
- `Product quantity visibility changed to ${t ? "visible" : "hidden"}`
165
- )), this._updateVisibilityAttribute(i.PRODUCT_QUANTITY, t));
178
+ var s;
179
+ const e = (s = this.currentNode) == null ? void 0 : s.querySelector(`[esd-extension-block-id="${r.QUANTITY}"]`);
180
+ if (!e)
181
+ return;
182
+ this.visibilityState[i.PRODUCT_QUANTITY] = t;
183
+ const o = this.api.getDocumentModifier();
184
+ o.modifyHtml(e).setStyle("display", t ? "table-cell" : "none"), this._updateVisibilityAttribute(i.PRODUCT_QUANTITY, t, o);
185
+ const n = `Product quantity visibility changed to ${t ? "visible" : "hidden"}`;
186
+ o.apply(new c(n));
166
187
  }
167
188
  _onProductPriceChange(t) {
168
- var o;
169
- const e = (o = this.currentNode) == null ? void 0 : o.querySelector(`[esd-extension-block-id="${s.PRICE}"]`);
170
- e && (this.visibilityState[i.PRODUCT_PRICE] = t, this.api.getDocumentModifier().modifyHtml(e).setStyle("display", t ? "table-cell" : "none").apply(new l(`Product price visibility changed to ${t ? "visible" : "hidden"}`)), this._updateVisibilityAttribute(i.PRODUCT_PRICE, t), this._updatePriceCellWidthsForVerticalLayout());
189
+ var s;
190
+ const e = (s = this.currentNode) == null ? void 0 : s.querySelectorAll(
191
+ `[esd-extension-block-id="${r.PRICE}"]`
192
+ );
193
+ if (!e)
194
+ return;
195
+ this.visibilityState[i.PRODUCT_PRICE] = t;
196
+ const o = this.api.getDocumentModifier();
197
+ e.forEach((l) => {
198
+ o.modifyHtml(l).setStyle("display", t ? "table-cell" : "none");
199
+ }), this._updateVisibilityAttribute(i.PRODUCT_PRICE, t, o), this._updatePriceCellWidthsForVerticalLayout(o);
200
+ const n = `Product price visibility changed to ${t ? "visible" : "hidden"}`;
201
+ o.apply(new c(n));
171
202
  }
172
203
  _onProductOriginalPriceChange(t) {
173
- var o;
174
- const e = (o = this.currentNode) == null ? void 0 : o.querySelector(
175
- `[esd-extension-block-id="${s.ORIGINAL_PRICE}"]`
204
+ var s;
205
+ const e = (s = this.currentNode) == null ? void 0 : s.querySelectorAll(
206
+ `[esd-extension-block-id="${r.ORIGINAL_PRICE}"]`
176
207
  );
177
- e && (this.visibilityState[i.PRODUCT_ORIGINAL_PRICE] = t, this.api.getDocumentModifier().modifyHtml(e).setStyle("display", t ? "table-cell" : "none").apply(new l(
178
- `Product original price visibility changed to ${t ? "visible" : "hidden"}`
179
- )), this._updateVisibilityAttribute(i.PRODUCT_ORIGINAL_PRICE, t), this._updatePriceCellWidthsForVerticalLayout());
208
+ if (!e)
209
+ return;
210
+ this.visibilityState[i.PRODUCT_ORIGINAL_PRICE] = t;
211
+ const o = this.api.getDocumentModifier();
212
+ e.forEach((l) => {
213
+ o.modifyHtml(l).setStyle("display", t ? "table-cell" : "none");
214
+ }), this._updateVisibilityAttribute(i.PRODUCT_ORIGINAL_PRICE, t, o), this._updatePriceCellWidthsForVerticalLayout(o);
215
+ const n = `Product original price visibility changed to ${t ? "visible" : "hidden"}`;
216
+ o.apply(new c(n));
180
217
  }
181
218
  /**
182
219
  * Updates both price cell widths in vertical layout based on priceOrientation and visibility.
@@ -186,28 +223,39 @@ class S extends I {
186
223
  * - When price is hidden, original price cell expands to 100%
187
224
  * - When both are visible, they share 50% each
188
225
  */
189
- _updatePriceCellWidthsForVerticalLayout() {
190
- var u, _;
191
- if (!(this.store.orientation === h.ORIENTATION.VERTICAL))
226
+ _updatePriceCellWidthsForVerticalLayout(t) {
227
+ var O, y;
228
+ const e = R(this.currentNode);
229
+ if (!((e == null ? void 0 : e.orientation) === h.ORIENTATION.VERTICAL))
192
230
  return;
193
- const e = (u = this.currentNode) == null ? void 0 : u.querySelector(".product-price-class"), o = (_ = this.currentNode) == null ? void 0 : _.querySelector(".product-original-price-class"), n = this.store.priceOrientation === "vertical", c = this.visibilityState[i.PRODUCT_PRICE], d = this.visibilityState[i.PRODUCT_ORIGINAL_PRICE], T = this.api.getDocumentModifier();
194
- if (e) {
195
- const C = n || !d ? "100%" : "50%";
196
- T.modifyHtml(e).setStyle("width", C);
231
+ const n = (O = this.currentNode) == null ? void 0 : O.querySelectorAll(".product-price-class"), s = (y = this.currentNode) == null ? void 0 : y.querySelectorAll(".product-original-price-class"), l = (e == null ? void 0 : e.priceOrientation) === "vertical", P = this.visibilityState[i.PRODUCT_PRICE], C = this.visibilityState[i.PRODUCT_ORIGINAL_PRICE], T = t ?? this.api.getDocumentModifier();
232
+ if (n && n.length > 0) {
233
+ const _ = l || !C ? "100%" : "50%";
234
+ n.forEach((u) => {
235
+ T.modifyHtml(u).setStyle("width", _);
236
+ });
197
237
  }
198
- if (o) {
199
- const C = n || !c ? "100%" : "50%";
200
- T.modifyHtml(o).setStyle("width", C);
238
+ if (s && s.length > 0) {
239
+ const _ = l || !P ? "100%" : "50%";
240
+ s.forEach((u) => {
241
+ T.modifyHtml(u).setStyle("width", _);
242
+ });
201
243
  }
202
- T.apply(new l("Updated price cell widths for vertical layout"));
244
+ t || T.apply(new c("Updated price cell widths for vertical layout"));
203
245
  }
204
246
  _onProductButtonChange(t) {
205
- var o;
206
- const e = (o = this.currentNode) == null ? void 0 : o.querySelector(`[esd-extension-block-id="${s.BUTTON}"]`);
207
- e && (this.visibilityState[i.PRODUCT_BUTTON] = t, this.api.getDocumentModifier().modifyHtml(e).setStyle("display", t ? "table-cell" : "none").apply(new l(`Product button visibility changed to ${t ? "visible" : "hidden"}`)), this._updateVisibilityAttribute(i.PRODUCT_BUTTON, t));
247
+ var s;
248
+ const e = (s = this.currentNode) == null ? void 0 : s.querySelector(`[esd-extension-block-id="${r.BUTTON}"]`);
249
+ if (!e)
250
+ return;
251
+ this.visibilityState[i.PRODUCT_BUTTON] = t;
252
+ const o = this.api.getDocumentModifier();
253
+ o.modifyHtml(e).setStyle("display", t ? "table-cell" : "none"), this._updateVisibilityAttribute(i.PRODUCT_BUTTON, t, o);
254
+ const n = `Product button visibility changed to ${t ? "visible" : "hidden"}`;
255
+ o.apply(new c(n));
208
256
  }
209
257
  }
210
258
  export {
211
- b as COMPOSITION_CONTROL_BLOCK_ID,
212
- S as ItemsBlockCardCompositionControl
259
+ g as COMPOSITION_CONTROL_BLOCK_ID,
260
+ M as ItemsBlockCardCompositionControl
213
261
  };
@@ -1,52 +1,40 @@
1
- var a = Object.defineProperty;
2
- var m = (t, e, n) => e in t ? a(t, e, { enumerable: !0, configurable: !0, writable: !0, value: n }) : t[e] = n;
3
- var s = (t, e, n) => m(t, typeof e != "symbol" ? e + "" : e, n);
4
- import { CommonControl as l } from "../../../common-control.js";
5
- import { ItemsBlockControlId as d } from "../../enums/controlEnums.js";
6
- import { useItemsBlockStore as L } from "../../store/items-block.js";
7
- import { getItemsBlockConfig as p } from "../../utils/nodeConfigUtils.js";
8
- const r = d.IMAGE_LINK, i = {
1
+ import { CommonControl as a } from "../../../common-control.js";
2
+ import { ItemsBlockControlId as i } from "../../enums/controlEnums.js";
3
+ import { getItemsBlockConfig as o } from "../../utils/nodeConfigUtils.js";
4
+ const s = i.IMAGE_LINK, n = {
9
5
  LINK: "link"
10
6
  };
11
- class g extends l {
12
- constructor() {
13
- super(...arguments);
14
- s(this, "store", L());
15
- }
7
+ class p extends a {
16
8
  getId() {
17
- return r;
9
+ return s;
18
10
  }
19
11
  getTemplate() {
20
12
  return `
21
- <div class="container ${r}">
13
+ <div class="container ${s}">
22
14
  ${this._getLink()}
23
15
  </div>
24
16
  `;
25
17
  }
26
18
  onRender() {
19
+ const e = o(this.currentNode);
27
20
  this.api.updateValues({
28
- [i.LINK]: this.store.imageLink
21
+ [n.LINK]: (e == null ? void 0 : e.imageLink) ?? ""
29
22
  });
30
23
  }
31
- onTemplateNodeUpdated(n) {
32
- super.onTemplateNodeUpdated(n), this.handleBlockInstanceChange(
33
- () => {
34
- const o = p(this.currentNode);
35
- o != null && o.imageLink && this.store.setImageLink(o.imageLink);
36
- },
37
- () => {
38
- this.api.updateValues({
39
- [i.LINK]: this.store.imageLink
40
- });
41
- }
42
- );
24
+ onTemplateNodeUpdated(e) {
25
+ super.onTemplateNodeUpdated(e), this.handleBlockInstanceChange(() => {
26
+ const t = o(this.currentNode);
27
+ this.api.updateValues({
28
+ [n.LINK]: (t == null ? void 0 : t.imageLink) ?? ""
29
+ });
30
+ });
43
31
  }
44
32
  _getLink() {
45
33
  return `
46
34
  ${this._GuOneColumn([
47
35
  this._GuLabel({ text: "Link" }),
48
36
  this._GuTextInput({
49
- name: i.LINK,
37
+ name: n.LINK,
50
38
  placeholder: "Enter Link",
51
39
  className: "es-100",
52
40
  disabled: !0
@@ -56,6 +44,6 @@ class g extends l {
56
44
  }
57
45
  }
58
46
  export {
59
- r as CONTROL_BLOCK_ID,
60
- g as ImageLinkControl
47
+ s as CONTROL_BLOCK_ID,
48
+ p as ImageLinkControl
61
49
  };