@useinsider/guido 2.0.0 → 2.1.0-beta.01eaf27

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 (239) hide show
  1. package/README.md +2 -0
  2. package/dist/@types/config/schemas.js +72 -54
  3. package/dist/components/Guido.vue.js +1 -1
  4. package/dist/components/Guido.vue2.js +15 -17
  5. package/dist/components/organisms/email-preview/PreviewContainer.vue.js +3 -3
  6. package/dist/components/organisms/email-preview/amp/AmpErrorModal.vue.js +6 -6
  7. package/dist/components/organisms/email-preview/amp/AmpErrorModal.vue2.js +17 -13
  8. package/dist/components/organisms/email-preview/amp/AmpToggle.vue.js +6 -6
  9. package/dist/components/organisms/email-preview/amp/AmpToggle.vue2.js +14 -12
  10. package/dist/components/organisms/email-preview/desktop-preview/DesktopBrowserHeader.vue.js +18 -0
  11. package/dist/components/organisms/email-preview/desktop-preview/DesktopBrowserHeader.vue2.js +15 -0
  12. package/dist/components/organisms/email-preview/desktop-preview/DesktopPreview.vue.js +16 -15
  13. package/dist/components/organisms/email-preview/desktop-preview/DesktopPreview.vue2.js +14 -22
  14. package/dist/components/organisms/email-preview/desktop-preview/EmailSizeIndicator.vue.js +3 -3
  15. package/dist/components/organisms/email-preview/mobile-preview/ContentView.vue.js +12 -11
  16. package/dist/components/organisms/email-preview/mobile-preview/InboxView.vue.js +12 -10
  17. package/dist/components/organisms/email-preview/mobile-preview/MobilePreview.vue.js +11 -10
  18. package/dist/components/organisms/email-preview/mobile-preview/MobilePreview.vue2.js +15 -14
  19. package/dist/components/organisms/header/EditorActions.vue.js +21 -0
  20. package/dist/components/organisms/header/EditorActions.vue2.js +41 -0
  21. package/dist/components/organisms/header/EditorToolbar.vue.js +18 -0
  22. package/dist/components/organisms/header/EditorToolbar.vue2.js +17 -0
  23. package/dist/components/organisms/header/HeaderWrapper.vue.js +6 -5
  24. package/dist/components/organisms/header/LeftSlot.vue.js +11 -11
  25. package/dist/components/organisms/header/LeftSlot.vue2.js +27 -23
  26. package/dist/components/organisms/header/MiddleSlot.vue.js +7 -7
  27. package/dist/components/organisms/header/MiddleSlot.vue2.js +11 -15
  28. package/dist/components/organisms/header/RightSlot.vue.js +11 -14
  29. package/dist/components/organisms/header/RightSlot.vue2.js +13 -30
  30. package/dist/components/organisms/header/version-history/VersionHistory.vue.js +5 -5
  31. package/dist/components/organisms/onboarding/NewVersionPopup.vue2.js +15 -15
  32. package/dist/components/organisms/unsubscribe/UnsubscribeTypeSelection.vue.js +1 -1
  33. package/dist/components/organisms/unsubscribe/UnsubscribeTypeSelection.vue2.js +20 -19
  34. package/dist/composables/useActionsApi.js +33 -30
  35. package/dist/composables/useConfig.js +29 -27
  36. package/dist/composables/useSave.js +13 -11
  37. package/dist/composables/useStripo.js +57 -56
  38. package/dist/config/migrator/index.js +9 -8
  39. package/dist/config/migrator/itemsBlockMigrator.js +351 -0
  40. package/dist/enums/academy.js +8 -0
  41. package/dist/enums/onboarding.js +1 -2
  42. package/dist/enums/unsubscribe.js +20 -21
  43. package/dist/extensions/Blocks/CouponBlock/constants.js +4 -0
  44. package/dist/extensions/Blocks/CouponBlock/controls/index.js +29 -0
  45. package/dist/extensions/Blocks/CouponBlock/extension.js +5 -4
  46. package/dist/extensions/Blocks/CouponBlock/settingsPanel.js +20 -14
  47. package/dist/extensions/Blocks/CouponBlock/template.js +22 -11
  48. package/dist/extensions/Blocks/Items/block.js +26 -41
  49. package/dist/extensions/Blocks/Items/controls/button/link.js +18 -37
  50. package/dist/extensions/Blocks/Items/controls/cardComposition.js +138 -93
  51. package/dist/extensions/Blocks/Items/controls/image/link.js +16 -35
  52. package/dist/extensions/Blocks/Items/controls/name/trimming.js +30 -42
  53. package/dist/extensions/Blocks/Items/controls/price/currencyLocation.js +34 -44
  54. package/dist/extensions/Blocks/Items/controls/price/currencySymbol.js +53 -56
  55. package/dist/extensions/Blocks/Items/controls/price/formattedPrice.js +45 -50
  56. package/dist/extensions/Blocks/Items/controls/price/hideDiscount.js +24 -34
  57. package/dist/extensions/Blocks/Items/controls/price/priceOrientation.js +47 -57
  58. package/dist/extensions/Blocks/Items/controls/price/singlePrice.js +73 -0
  59. package/dist/extensions/Blocks/Items/controls/settingsControl.js +187 -179
  60. package/dist/extensions/Blocks/Items/enums/controlEnums.js +2 -2
  61. package/dist/extensions/Blocks/Items/enums/productEnums.js +43 -45
  62. package/dist/extensions/Blocks/Items/enums/settingsEnums.js +3 -6
  63. package/dist/extensions/Blocks/Items/extension.js +11 -9
  64. package/dist/extensions/Blocks/Items/layouts/horizontal.html.js +58 -49
  65. package/dist/extensions/Blocks/Items/layouts/vertical.html.js +48 -59
  66. package/dist/extensions/Blocks/Items/settingsPanel.js +27 -26
  67. package/dist/extensions/Blocks/Items/template.js +396 -143
  68. package/dist/extensions/Blocks/Items/utils/nodeConfigUtils.js +176 -0
  69. package/dist/extensions/Blocks/Recommendation/cardCompositionControl.js +153 -69
  70. package/dist/extensions/Blocks/Recommendation/constants.js +9 -1
  71. package/dist/extensions/Blocks/Recommendation/control.js +91 -61
  72. package/dist/extensions/Blocks/Recommendation/controls/cardBackgroundColorControl.js +68 -0
  73. package/dist/extensions/Blocks/Recommendation/controls/index.js +245 -0
  74. package/dist/extensions/Blocks/Recommendation/controls/nameTextTrimControl.js +74 -0
  75. package/dist/extensions/Blocks/Recommendation/controls/omnibusDiscountTextAfterControl.js +71 -0
  76. package/dist/extensions/Blocks/Recommendation/controls/omnibusDiscountTextBeforeControl.js +71 -0
  77. package/dist/extensions/Blocks/Recommendation/controls/omnibusPriceTextAfterControl.js +71 -0
  78. package/dist/extensions/Blocks/Recommendation/controls/omnibusPriceTextBeforeControl.js +71 -0
  79. package/dist/extensions/Blocks/Recommendation/controls/spacingControl.js +188 -0
  80. package/dist/extensions/Blocks/Recommendation/extension.js +16 -42
  81. package/dist/extensions/Blocks/Recommendation/settingsPanel.js +117 -72
  82. package/dist/extensions/Blocks/Recommendation/templates/blockTemplate.js +85 -64
  83. package/dist/extensions/Blocks/Recommendation/templates/migrationTemplate.js +54 -17
  84. package/dist/extensions/Blocks/Recommendation/templates/templateUtils.js +74 -45
  85. package/dist/extensions/Blocks/Recommendation/utils/preserveTextStyles.js +25 -0
  86. package/dist/extensions/Blocks/Unsubscribe/extension.js +9 -9
  87. package/dist/extensions/Blocks/common-control.js +107 -110
  88. package/dist/extensions/Blocks/controlFactories.js +139 -118
  89. package/dist/guido.css +1 -1
  90. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/esm/index.js +370 -291
  91. package/dist/package.json.js +1 -1
  92. package/dist/services/stripoApi.js +6 -10
  93. package/dist/src/@types/config/index.d.ts +2 -2
  94. package/dist/src/@types/config/schemas.d.ts +36 -2
  95. package/dist/src/@types/config/types.d.ts +7 -1
  96. package/dist/src/components/organisms/email-preview/desktop-preview/DesktopBrowserHeader.vue.d.ts +2 -0
  97. package/dist/src/components/organisms/header/EditorActions.vue.d.ts +4 -0
  98. package/dist/src/components/organisms/header/EditorToolbar.vue.d.ts +2 -0
  99. package/dist/src/components/organisms/header/RightSlot.vue.d.ts +1 -1
  100. package/dist/src/composables/useActionsApi.d.ts +1 -0
  101. package/dist/src/composables/useConfig.d.ts +10 -0
  102. package/dist/src/config/migrator/itemsBlockMigrator.d.ts +6 -0
  103. package/dist/src/enums/academy.d.ts +12 -0
  104. package/dist/src/enums/onboarding.d.ts +0 -1
  105. package/dist/src/enums/unsubscribe.d.ts +0 -1
  106. package/dist/src/extensions/Blocks/CouponBlock/constants.d.ts +14 -0
  107. package/dist/src/extensions/Blocks/CouponBlock/controls/index.d.ts +108 -0
  108. package/dist/src/extensions/Blocks/CouponBlock/template.d.ts +1 -1
  109. package/dist/src/extensions/Blocks/Items/block.d.ts +0 -1
  110. package/dist/src/extensions/Blocks/Items/controls/button/link.d.ts +0 -3
  111. package/dist/src/extensions/Blocks/Items/controls/cardComposition.d.ts +9 -1
  112. package/dist/src/extensions/Blocks/Items/controls/image/link.d.ts +0 -3
  113. package/dist/src/extensions/Blocks/Items/controls/name/trimming.d.ts +0 -1
  114. package/dist/src/extensions/Blocks/Items/controls/price/currencyLocation.d.ts +0 -1
  115. package/dist/src/extensions/Blocks/Items/controls/price/currencySymbol.d.ts +0 -1
  116. package/dist/src/extensions/Blocks/Items/controls/price/formattedPrice.d.ts +0 -1
  117. package/dist/src/extensions/Blocks/Items/controls/price/hideDiscount.d.ts +0 -1
  118. package/dist/src/extensions/Blocks/Items/controls/price/priceOrientation.d.ts +1 -2
  119. package/dist/src/extensions/Blocks/Items/controls/price/singlePrice.d.ts +13 -0
  120. package/dist/src/extensions/Blocks/Items/controls/settingsControl.d.ts +3 -9
  121. package/dist/src/extensions/Blocks/Items/enums/controlEnums.d.ts +1 -0
  122. package/dist/src/extensions/Blocks/Items/enums/productEnums.d.ts +24 -26
  123. package/dist/src/extensions/Blocks/Items/enums/settingsEnums.d.ts +1 -2
  124. package/dist/src/extensions/Blocks/Items/template.d.ts +22 -1
  125. package/dist/src/extensions/Blocks/Items/utils/nodeConfigUtils.d.ts +76 -0
  126. package/dist/src/extensions/Blocks/Recommendation/cardCompositionControl.d.ts +50 -3
  127. package/dist/src/extensions/Blocks/Recommendation/constants.d.ts +32 -0
  128. package/dist/src/extensions/Blocks/Recommendation/control.d.ts +5 -2
  129. package/dist/src/extensions/Blocks/Recommendation/controls/cardBackgroundColorControl.d.ts +25 -0
  130. package/dist/src/extensions/Blocks/Recommendation/controls/index.d.ts +592 -0
  131. package/dist/src/extensions/Blocks/Recommendation/controls/nameTextTrimControl.d.ts +16 -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/omnibusPriceTextAfterControl.d.ts +15 -0
  135. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusPriceTextBeforeControl.d.ts +15 -0
  136. package/dist/src/extensions/Blocks/Recommendation/controls/spacingControl.d.ts +60 -0
  137. package/dist/src/extensions/Blocks/Recommendation/templates/blockTemplate.d.ts +3 -3
  138. package/dist/src/extensions/Blocks/Recommendation/templates/templateUtils.d.ts +15 -7
  139. package/dist/src/extensions/Blocks/Recommendation/utils/preserveTextStyles.d.ts +19 -0
  140. package/dist/src/extensions/Blocks/common-control.d.ts +11 -13
  141. package/dist/src/extensions/Blocks/controlFactories.d.ts +30 -7
  142. package/dist/src/stores/config.d.ts +181 -1
  143. package/dist/src/stores/editor.d.ts +21 -0
  144. package/dist/static/assets/desktop/desktop-mockup-center.svg.js +4 -0
  145. package/dist/static/assets/desktop/desktop-mockup-left.svg.js +4 -0
  146. package/dist/static/assets/desktop/desktop-mockup-right.svg.js +4 -0
  147. package/dist/static/assets/mobile/email-mockup.svg.js +4 -0
  148. package/dist/static/assets/mobile/inbox-mockup.svg.js +4 -0
  149. package/dist/static/styles/components/button.css.js +1 -1
  150. package/dist/static/styles/components/narrow-panel.css.js +0 -10
  151. package/dist/static/styles/components/wide-panel.css.js +1 -5
  152. package/dist/static/styles/customEditorStyle.css.js +13 -0
  153. package/dist/stores/config.js +7 -0
  154. package/dist/stores/editor.js +1 -0
  155. package/dist/utils/pairProductVariables.js +61 -58
  156. package/dist/utils/templatePreparation.js +17 -17
  157. package/package.json +3 -3
  158. package/dist/components/organisms/email-preview/desktop-preview/EmailHeaderInfo.vue.js +0 -17
  159. package/dist/components/organisms/email-preview/desktop-preview/EmailHeaderInfo.vue2.js +0 -20
  160. package/dist/extensions/Blocks/Items/store/items-block.js +0 -75
  161. package/dist/extensions/Blocks/Items/utils/configBlockUtils.js +0 -17
  162. package/dist/extensions/Blocks/Items/utils/syncAttributeFromConfigBlock.js +0 -28
  163. package/dist/extensions/Blocks/Items/utils/syncAttributesFromConfigBlock.js +0 -76
  164. package/dist/extensions/Blocks/Items/utils/updateAttributes.js +0 -46
  165. package/dist/extensions/Blocks/Recommendation/controls/button/align.js +0 -13
  166. package/dist/extensions/Blocks/Recommendation/controls/button/border.js +0 -13
  167. package/dist/extensions/Blocks/Recommendation/controls/button/borderRadius.js +0 -13
  168. package/dist/extensions/Blocks/Recommendation/controls/button/color.js +0 -13
  169. package/dist/extensions/Blocks/Recommendation/controls/button/fitToContent.js +0 -13
  170. package/dist/extensions/Blocks/Recommendation/controls/button/fontFamily.js +0 -13
  171. package/dist/extensions/Blocks/Recommendation/controls/button/margins.js +0 -13
  172. package/dist/extensions/Blocks/Recommendation/controls/button/paddings.js +0 -13
  173. package/dist/extensions/Blocks/Recommendation/controls/button/text.js +0 -13
  174. package/dist/extensions/Blocks/Recommendation/controls/button/textSize.js +0 -13
  175. package/dist/extensions/Blocks/Recommendation/controls/button/textStyleAndFontColor.js +0 -13
  176. package/dist/extensions/Blocks/Recommendation/controls/image/margins.js +0 -13
  177. package/dist/extensions/Blocks/Recommendation/controls/image/size.js +0 -13
  178. package/dist/extensions/Blocks/Recommendation/controls/name/align.js +0 -13
  179. package/dist/extensions/Blocks/Recommendation/controls/name/background.js +0 -13
  180. package/dist/extensions/Blocks/Recommendation/controls/name/color.js +0 -13
  181. package/dist/extensions/Blocks/Recommendation/controls/name/fontFamily.js +0 -13
  182. package/dist/extensions/Blocks/Recommendation/controls/name/paddings.js +0 -13
  183. package/dist/extensions/Blocks/Recommendation/controls/name/size.js +0 -13
  184. package/dist/extensions/Blocks/Recommendation/controls/name/style.js +0 -13
  185. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/align.js +0 -13
  186. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/background.js +0 -13
  187. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/color.js +0 -13
  188. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/fontFamily.js +0 -13
  189. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/paddings.js +0 -13
  190. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/size.js +0 -13
  191. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/style.js +0 -13
  192. package/dist/extensions/Blocks/Recommendation/controls/price/align.js +0 -13
  193. package/dist/extensions/Blocks/Recommendation/controls/price/background.js +0 -13
  194. package/dist/extensions/Blocks/Recommendation/controls/price/color.js +0 -13
  195. package/dist/extensions/Blocks/Recommendation/controls/price/fontFamily.js +0 -13
  196. package/dist/extensions/Blocks/Recommendation/controls/price/paddings.js +0 -13
  197. package/dist/extensions/Blocks/Recommendation/controls/price/size.js +0 -13
  198. package/dist/extensions/Blocks/Recommendation/controls/price/style.js +0 -13
  199. package/dist/src/extensions/Blocks/Items/store/items-block.d.ts +0 -43
  200. package/dist/src/extensions/Blocks/Items/utils/configBlockUtils.d.ts +0 -23
  201. package/dist/src/extensions/Blocks/Items/utils/syncAttributeFromConfigBlock.d.ts +0 -32
  202. package/dist/src/extensions/Blocks/Items/utils/syncAttributesFromConfigBlock.d.ts +0 -50
  203. package/dist/src/extensions/Blocks/Items/utils/updateAttributes.d.ts +0 -8
  204. package/dist/src/extensions/Blocks/Recommendation/controls/button/align.d.ts +0 -5
  205. package/dist/src/extensions/Blocks/Recommendation/controls/button/border.d.ts +0 -5
  206. package/dist/src/extensions/Blocks/Recommendation/controls/button/borderRadius.d.ts +0 -5
  207. package/dist/src/extensions/Blocks/Recommendation/controls/button/color.d.ts +0 -5
  208. package/dist/src/extensions/Blocks/Recommendation/controls/button/fitToContent.d.ts +0 -5
  209. package/dist/src/extensions/Blocks/Recommendation/controls/button/fontFamily.d.ts +0 -5
  210. package/dist/src/extensions/Blocks/Recommendation/controls/button/margins.d.ts +0 -5
  211. package/dist/src/extensions/Blocks/Recommendation/controls/button/paddings.d.ts +0 -5
  212. package/dist/src/extensions/Blocks/Recommendation/controls/button/text.d.ts +0 -5
  213. package/dist/src/extensions/Blocks/Recommendation/controls/button/textSize.d.ts +0 -5
  214. package/dist/src/extensions/Blocks/Recommendation/controls/button/textStyleAndFontColor.d.ts +0 -5
  215. package/dist/src/extensions/Blocks/Recommendation/controls/image/margins.d.ts +0 -5
  216. package/dist/src/extensions/Blocks/Recommendation/controls/image/size.d.ts +0 -5
  217. package/dist/src/extensions/Blocks/Recommendation/controls/name/align.d.ts +0 -5
  218. package/dist/src/extensions/Blocks/Recommendation/controls/name/background.d.ts +0 -5
  219. package/dist/src/extensions/Blocks/Recommendation/controls/name/color.d.ts +0 -5
  220. package/dist/src/extensions/Blocks/Recommendation/controls/name/fontFamily.d.ts +0 -5
  221. package/dist/src/extensions/Blocks/Recommendation/controls/name/paddings.d.ts +0 -5
  222. package/dist/src/extensions/Blocks/Recommendation/controls/name/size.d.ts +0 -5
  223. package/dist/src/extensions/Blocks/Recommendation/controls/name/style.d.ts +0 -5
  224. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/align.d.ts +0 -5
  225. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/background.d.ts +0 -5
  226. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/color.d.ts +0 -5
  227. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/fontFamily.d.ts +0 -5
  228. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/paddings.d.ts +0 -5
  229. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/size.d.ts +0 -5
  230. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/style.d.ts +0 -5
  231. package/dist/src/extensions/Blocks/Recommendation/controls/price/align.d.ts +0 -5
  232. package/dist/src/extensions/Blocks/Recommendation/controls/price/background.d.ts +0 -5
  233. package/dist/src/extensions/Blocks/Recommendation/controls/price/color.d.ts +0 -5
  234. package/dist/src/extensions/Blocks/Recommendation/controls/price/fontFamily.d.ts +0 -5
  235. package/dist/src/extensions/Blocks/Recommendation/controls/price/paddings.d.ts +0 -5
  236. package/dist/src/extensions/Blocks/Recommendation/controls/price/size.d.ts +0 -5
  237. package/dist/src/extensions/Blocks/Recommendation/controls/price/style.d.ts +0 -5
  238. package/dist/static/assets/inbox-mockup.svg.js +0 -4
  239. package/dist/static/assets/phone-mockup.svg.js +0 -4
@@ -1,20 +1,18 @@
1
- import { useOnboardingStore as y } from "../../../stores/onboarding.js";
2
- import { Block as R, BlockCompositionType as L, ModificationDescription as a } from "../../../node_modules/@stripoinc/ui-editor-extensions/dist/esm/index.js";
3
- import { configAttributes as t } from "./enums/productEnums.js";
4
- import { DefaultConfigValues as e, SETTINGS_ENUMS as l } from "./enums/settingsEnums.js";
5
- import { useItemsBlockStore as S } from "./store/items-block.js";
6
- import { getDefaultTemplate as V } from "./template.js";
7
- import { syncCurrencySymbolFromAttributes as B, syncCurrencyLocationFromAttributes as U, syncFormattedPriceFromAttributes as k } from "./utils/syncAttributesFromConfigBlock.js";
8
- const M = "items-block";
9
- class x extends R {
1
+ import { useOnboardingStore as l } from "../../../stores/onboarding.js";
2
+ import { Block as m, BlockCompositionType as d, ModificationDescription as o } from "../../../node_modules/@stripoinc/ui-editor-extensions/dist/esm/index.js";
3
+ import { SETTINGS_ENUMS as a, DefaultConfigValues as n } from "./enums/settingsEnums.js";
4
+ import { getDefaultTemplate as f } from "./template.js";
5
+ import { getItemsBlockContainer as g, getItemsBlockConfig as p, getDefaultItemsBlockConfig as u } from "./utils/nodeConfigUtils.js";
6
+ const I = "items-block";
7
+ class S extends m {
10
8
  getId() {
11
- return M;
9
+ return I;
12
10
  }
13
11
  getIcon() {
14
12
  return "items-icon";
15
13
  }
16
14
  getBlockCompositionType() {
17
- return L.CONTAINER;
15
+ return d.CONTAINER;
18
16
  }
19
17
  getName() {
20
18
  return this.api.translate("Items");
@@ -23,45 +21,32 @@ class x extends R {
23
21
  return this.api.translate("Items lets you display personalized products based on user behavior.");
24
22
  }
25
23
  getTemplate() {
26
- return V({
27
- orientation: l.ORIENTATION.HORIZONTAL,
28
- itemsType: l.ITEMS_TYPE.CART_ITEMS,
24
+ return f({
25
+ orientation: a.ORIENTATION.VERTICAL,
26
+ itemsType: a.ITEMS_TYPE.CART_ITEMS,
29
27
  itemId: "{{Abandoned Cart Item (1) Url}}",
30
- currencySymbol: e.productPriceCurrencySymbolControlValue,
31
- currencyLocation: e.productPriceCurrencyLocationControlValue,
32
- formattedPrice: e.productPriceFormattedControlValue === "1"
28
+ currencySymbol: n.productPriceCurrencySymbolControlValue,
29
+ currencyLocation: n.productPriceCurrencyLocationControlValue,
30
+ formattedPrice: n.productPriceFormattedControlValue === "1"
33
31
  });
34
32
  }
35
33
  allowInnerBlocksDND() {
36
34
  return !1;
37
35
  }
38
- onCreated(r) {
39
- const n = r.querySelector("esd-config-block");
40
- if (!n)
36
+ onCreated(i) {
37
+ const t = g(i);
38
+ if (!t)
41
39
  return;
42
- const o = n, s = o.getAttribute("data-initialized") || "0", u = o.getAttribute(t.BLOCK_INSTANCE_ID), c = () => String(Date.now() + Math.floor(Math.random() * 1e3));
43
- if (Number(s)) {
44
- if (!u) {
45
- const i = c();
46
- this.api.getDocumentModifier().modifyHtml(o).setAttribute(t.BLOCK_INSTANCE_ID, i).apply(new a("Assign block instance ID to legacy block"));
47
- }
48
- } else {
49
- const i = e.itemsType, I = e.cartItemsSelectControlValue, d = e.cardOrientationControlValue, m = e.productNameTrimmingControlValue, C = e.productPriceHideDiscountControlValue, b = e.productPriceFormattedControlValue, T = e.productPriceCurrencySymbolControlValue, A = e.productPriceCurrencyLocationControlValue, E = e.productButtonLinkControlValue, O = e.productImageLinkControlValue, _ = e.productImageVisible, p = e.productNameVisible, N = e.productQuantityVisible, f = e.productPriceVisible, g = e.productOriginalPriceVisible, D = e.productButtonVisible, P = c();
50
- this.api.getDocumentModifier().modifyHtml(o).setAttribute("data-source", i).setAttribute(t.TYPE, i).setAttribute(t.ITEMS_INDEX_SELECT_CONTROL_VALUE, I).setAttribute(t.ORIENTATION, d).setAttribute(t.PRODUCT_NAME_TRIMMING, m).setAttribute(t.PRODUCT_PRICE_HIDE_DISCOUNT, C).setAttribute(t.PRODUCT_PRICE_FORMATTED, b).setAttribute(t.PRODUCT_PRICE_CURRENCY_SYMBOL, T).setAttribute(t.PRODUCT_PRICE_CURRENCY_LOCATION, A).setAttribute(t.PRODUCT_BUTTON_LINK, E).setAttribute(t.PRODUCT_IMAGE_LINK, O).setAttribute(t.BLOCK_INSTANCE_ID, P).setAttribute("data-initialized", "1").setAttribute(t.NAME_CONTROL_ENABLED, e.productNameControlEnabled).setAttribute(
51
- t.QUANTITY_CONTROL_ENABLED,
52
- e.productQuantityControlEnabled
53
- ).setAttribute(t.PRICE_CONTROL_OPENED, e.productPriceControlOpened).setAttribute(t.PRODUCT_IMAGE_VISIBLE, _).setAttribute(t.PRODUCT_NAME_VISIBLE, p).setAttribute(t.PRODUCT_QUANTITY_VISIBLE, N).setAttribute(t.PRODUCT_PRICE_VISIBLE, f).setAttribute(t.PRODUCT_ORIGINAL_PRICE_VISIBLE, g).setAttribute(t.PRODUCT_BUTTON_VISIBLE, D).apply(new a("Initialize config block attributes with defaults")), y().startOnboarding("itemsOnboarding");
40
+ const r = t.getNodeConfig(), c = r && Object.keys(r).length > 0, e = p(i);
41
+ if (e != null && e.initialized)
42
+ c ? e.blockInstanceId || this.api.getDocumentModifier().modifyHtml(t).setNodeConfig({ ...e, blockInstanceId: String(Date.now()) }).apply(new o("Assign block instance ID to block")) : this.api.getDocumentModifier().modifyHtml(t).setNodeConfig(e).apply(new o("Migrate legacy config to nodeConfig"));
43
+ else {
44
+ const s = u();
45
+ this.api.getDocumentModifier().modifyHtml(t).setNodeConfig(s).apply(new o("Initialize Items block with default configuration")), l().startOnboarding("itemsOnboarding");
54
46
  }
55
47
  }
56
- onSelect(r) {
57
- const n = r.querySelector("esd-config-block"), o = S();
58
- if (!n)
59
- return;
60
- const s = n, u = s.getAttribute(t.TYPE) || e.itemsType, c = s.getAttribute(t.ITEMS_INDEX_SELECT_CONTROL_VALUE) || e.cartItemsSelectControlValue, i = s.getAttribute(t.ORIENTATION) || e.cardOrientationControlValue;
61
- o.setItemsType(u), o.setItemIds(c), o.setOrientation(i), B(r), U(r), k(r);
62
- }
63
48
  }
64
49
  export {
65
- M as BLOCK_ID,
66
- x as ItemsBlock
50
+ I as BLOCK_ID,
51
+ S as ItemsBlock
67
52
  };
@@ -1,52 +1,33 @@
1
- var r = Object.defineProperty;
2
- var a = (o, e, t) => e in o ? r(o, e, { enumerable: !0, configurable: !0, writable: !0, value: t }) : o[e] = t;
3
- var s = (o, e, t) => a(o, typeof e != "symbol" ? e + "" : e, t);
4
- import { CommonControl as u } 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 { syncButtonLinkFromAttributes as h } from "../../utils/syncAttributesFromConfigBlock.js";
8
- import { updateConfigBlockAttributes as m } from "../../utils/updateAttributes.js";
9
- const i = d.BUTTON_LINK, n = {
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 = {
10
5
  LINK: "link"
11
6
  };
12
- class C extends u {
13
- constructor() {
14
- super(...arguments);
15
- s(this, "store", l());
16
- }
7
+ class m extends r {
17
8
  getId() {
18
- return i;
9
+ return s;
19
10
  }
20
11
  getTemplate() {
21
12
  return `
22
- <div class="${i}">
13
+ <div class="container ${s}">
23
14
  ${this._getLink()}
24
15
  </div>
25
16
  `;
26
17
  }
27
18
  onRender() {
19
+ const t = o(this.currentNode);
28
20
  this.api.updateValues({
29
- [n.LINK]: this.store.buttonLink
30
- }), this._listenToFormUpdates();
21
+ [n.LINK]: (t == null ? void 0 : t.buttonLink) ?? ""
22
+ });
31
23
  }
32
24
  onTemplateNodeUpdated(t) {
33
- super.onTemplateNodeUpdated(t), this.handleBlockInstanceChange(
34
- () => h(this.currentNode),
35
- () => {
36
- this.api.updateValues({
37
- [n.LINK]: this.store.buttonLink
38
- });
39
- }
40
- );
41
- }
42
- _listenToFormUpdates() {
43
- this.api.onValueChanged(
44
- n.LINK,
45
- (t) => this._onLinkChange(t)
46
- );
47
- }
48
- _onLinkChange(t) {
49
- console.debug("Button link changed to: ", t), this.store.setButtonLink(t), m(this.currentNode, this.api);
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
+ });
50
31
  }
51
32
  _getLink() {
52
33
  return `
@@ -63,6 +44,6 @@ class C extends u {
63
44
  }
64
45
  }
65
46
  export {
66
- C as ButtonLinkControl,
67
- i as CONTROL_BLOCK_ID
47
+ m as ButtonLinkControl,
48
+ s as CONTROL_BLOCK_ID
68
49
  };
@@ -1,14 +1,12 @@
1
- var c = Object.defineProperty;
2
- var I = (a, n, t) => n in a ? c(a, n, { enumerable: !0, configurable: !0, writable: !0, value: t }) : a[n] = t;
3
- var _ = (a, n, t) => I(a, typeof n != "symbol" ? n + "" : n, t);
4
- import { ModificationDescription as l } from "../../../../node_modules/@stripoinc/ui-editor-extensions/dist/esm/index.js";
5
- import { CommonControl as R } from "../../common-control.js";
6
- import { ItemsBlockId as s } from "../enums/controlEnums.js";
7
- import { configAttributes as C } from "../enums/productEnums.js";
1
+ var I = Object.defineProperty;
2
+ var p = (c, r, t) => r in c ? I(c, r, { enumerable: !0, configurable: !0, writable: !0, value: t }) : c[r] = t;
3
+ var y = (c, r, t) => p(c, typeof r != "symbol" ? r + "" : r, t);
4
+ import { ModificationDescription as a } from "../../../../node_modules/@stripoinc/ui-editor-extensions/dist/esm/index.js";
5
+ import { CommonControl as U } from "../../common-control.js";
6
+ import { ItemsBlockId as n } from "../enums/controlEnums.js";
8
7
  import { SETTINGS_ENUMS as u } from "../enums/settingsEnums.js";
9
- import { useItemsBlockStore as O } from "../store/items-block.js";
10
- import { getConfigBlock as P, attributeToBoolean as U } from "../utils/configBlockUtils.js";
11
- const h = "ui-elements-items-card-composition-block", i = {
8
+ import { getItemsBlockConfig as h, setItemsBlockConfig as b } from "../utils/nodeConfigUtils.js";
9
+ const m = "ui-elements-items-card-composition-block", i = {
12
10
  PRODUCT_IMAGE: "image",
13
11
  PRODUCT_NAME: "name",
14
12
  PRODUCT_QUANTITY: "quantity",
@@ -16,11 +14,10 @@ const h = "ui-elements-items-card-composition-block", i = {
16
14
  PRODUCT_ORIGINAL_PRICE: "originalPrice",
17
15
  PRODUCT_BUTTON: "button"
18
16
  };
19
- class g extends R {
17
+ class S extends U {
20
18
  constructor() {
21
19
  super(...arguments);
22
- _(this, "store", O());
23
- _(this, "visibilityState", {
20
+ y(this, "visibilityState", {
24
21
  [i.PRODUCT_IMAGE]: !0,
25
22
  [i.PRODUCT_NAME]: !0,
26
23
  [i.PRODUCT_QUANTITY]: !0,
@@ -30,7 +27,7 @@ class g extends R {
30
27
  });
31
28
  }
32
29
  getId() {
33
- return h;
30
+ return m;
34
31
  }
35
32
  getTemplate() {
36
33
  return `
@@ -42,7 +39,7 @@ class g extends R {
42
39
  { name: i.PRODUCT_PRICE, label: "Product Price" },
43
40
  { name: i.PRODUCT_ORIGINAL_PRICE, label: "Product Original Price" },
44
41
  { name: i.PRODUCT_BUTTON, label: "Product Button" }
45
- ].map((e) => this._getToggleContainer(e)).join("")}
42
+ ].map((o) => this._getToggleContainer(o)).join("")}
46
43
  </div>
47
44
  `;
48
45
  }
@@ -50,20 +47,15 @@ class g extends R {
50
47
  this._syncVisibilityFromAttributes(), this._handleBrowsedItemsQuantity(), this._initializeToggles(), this._listenToFormUpdates();
51
48
  }
52
49
  onTemplateNodeUpdated(t) {
53
- super.onTemplateNodeUpdated(t), this.handleBlockInstanceChange(
54
- () => {
55
- this._syncVisibilityFromAttributes(), this._handleBrowsedItemsQuantity(), this._applyVisibilityStyles();
56
- },
57
- () => {
58
- this._updateTogglesFromState();
59
- }
60
- );
50
+ super.onTemplateNodeUpdated(t), this.handleBlockInstanceChange(() => {
51
+ this._syncVisibilityFromAttributes(), this._handleBrowsedItemsQuantity(), this._applyVisibilityStyles(), this._updateTogglesFromState();
52
+ });
61
53
  }
62
- _getToggleContainer({ name: t, label: e }) {
54
+ _getToggleContainer({ name: t, label: o }) {
63
55
  return `
64
56
  <div class="container" name="${t}Container">
65
57
  <div class="display-flex align-items-center justify-content-between">
66
- ${this._GuLabel({ text: e, name: `${t}Label` })}
58
+ ${this._GuLabel({ text: o, name: `${t}Label` })}
67
59
  ${this._GuToggle(t)}
68
60
  </div>
69
61
  </div>
@@ -83,20 +75,20 @@ class g extends R {
83
75
  });
84
76
  }
85
77
  _syncVisibilityFromAttributes() {
86
- const t = P(this.currentNode);
78
+ const t = h(this.currentNode);
87
79
  if (!t)
88
80
  return;
89
- const e = {
90
- [i.PRODUCT_IMAGE]: "PRODUCT_IMAGE_VISIBLE",
91
- [i.PRODUCT_NAME]: "PRODUCT_NAME_VISIBLE",
92
- [i.PRODUCT_QUANTITY]: "PRODUCT_QUANTITY_VISIBLE",
93
- [i.PRODUCT_PRICE]: "PRODUCT_PRICE_VISIBLE",
94
- [i.PRODUCT_ORIGINAL_PRICE]: "PRODUCT_ORIGINAL_PRICE_VISIBLE",
95
- [i.PRODUCT_BUTTON]: "PRODUCT_BUTTON_VISIBLE"
81
+ const o = {
82
+ [i.PRODUCT_IMAGE]: "imageVisible",
83
+ [i.PRODUCT_NAME]: "nameVisible",
84
+ [i.PRODUCT_QUANTITY]: "quantityControlEnabled",
85
+ [i.PRODUCT_PRICE]: "priceVisible",
86
+ [i.PRODUCT_ORIGINAL_PRICE]: "originalPriceVisible",
87
+ [i.PRODUCT_BUTTON]: "buttonVisible"
96
88
  };
97
- Object.entries(e).forEach(([o, r]) => {
98
- const T = t.getAttribute(C[r]);
99
- this.visibilityState[o] = U(T, !0);
89
+ Object.entries(o).forEach(([e, s]) => {
90
+ const l = t[s];
91
+ this.visibilityState[e] = l !== !1;
100
92
  });
101
93
  }
102
94
  /**
@@ -105,89 +97,142 @@ class g extends R {
105
97
  * and mark it as '0'
106
98
  */
107
99
  _handleBrowsedItemsQuantity() {
108
- var r;
109
- const t = this.store.itemsType !== u.ITEMS_TYPE.BROWSED_ITEMS, e = (r = this.currentNode) == null ? void 0 : r.querySelector("esd-config-block");
110
- if (!e)
100
+ const t = h(this.currentNode), e = ((t == null ? void 0 : t.type) ?? u.ITEMS_TYPE.CART_ITEMS) !== u.ITEMS_TYPE.BROWSED_ITEMS;
101
+ if (!t)
111
102
  return;
112
- const o = e.getAttribute(C.PRODUCT_QUANTITY_VISIBLE) === "1";
113
- this.visibilityState[i.PRODUCT_QUANTITY] = t && o, this.api.setVisibility(`${i.PRODUCT_QUANTITY}Container`, t), this._updateVisibilityAttribute(i.PRODUCT_QUANTITY, t && o);
103
+ const s = t.quantityControlEnabled !== !1;
104
+ this.visibilityState[i.PRODUCT_QUANTITY] = e && s, this.api.setVisibility(`${i.PRODUCT_QUANTITY}Container`, e), this._updateVisibilityAttribute(i.PRODUCT_QUANTITY, e && s);
114
105
  }
115
106
  _applyVisibilityStyles() {
116
107
  const t = {
117
- [i.PRODUCT_IMAGE]: s.IMAGE,
118
- [i.PRODUCT_NAME]: s.NAME,
119
- [i.PRODUCT_QUANTITY]: s.QUANTITY,
120
- [i.PRODUCT_PRICE]: s.PRICE,
121
- [i.PRODUCT_ORIGINAL_PRICE]: s.ORIGINAL_PRICE,
122
- [i.PRODUCT_BUTTON]: s.BUTTON
108
+ [i.PRODUCT_IMAGE]: n.IMAGE,
109
+ [i.PRODUCT_NAME]: n.NAME,
110
+ [i.PRODUCT_QUANTITY]: n.QUANTITY,
111
+ [i.PRODUCT_PRICE]: n.PRICE,
112
+ [i.PRODUCT_ORIGINAL_PRICE]: n.ORIGINAL_PRICE,
113
+ [i.PRODUCT_BUTTON]: n.BUTTON
123
114
  };
124
- Object.entries(t).forEach(([e, o]) => {
125
- var d;
126
- const r = (d = this.currentNode) == null ? void 0 : d.querySelector(`[esd-extension-block-id="${o}"]`);
127
- if (!r)
115
+ Object.entries(t).forEach(([o, e]) => {
116
+ var C;
117
+ const s = (C = this.currentNode) == null ? void 0 : C.querySelectorAll(`[esd-extension-block-id="${e}"]`);
118
+ if (!s)
128
119
  return;
129
- const T = this.visibilityState[e];
130
- this.api.getDocumentModifier().modifyHtml(r).setStyle("display", T ? "table-cell" : "none").apply(new l(`Applied ${e} visibility from attributes`));
131
- });
132
- }
133
- _updateVisibilityAttribute(t, e) {
134
- const o = P(this.currentNode);
135
- if (!o)
136
- return;
137
- const T = {
138
- [i.PRODUCT_IMAGE]: "PRODUCT_IMAGE_VISIBLE",
139
- [i.PRODUCT_NAME]: "PRODUCT_NAME_VISIBLE",
140
- [i.PRODUCT_QUANTITY]: "PRODUCT_QUANTITY_VISIBLE",
141
- [i.PRODUCT_PRICE]: "PRODUCT_PRICE_VISIBLE",
142
- [i.PRODUCT_ORIGINAL_PRICE]: "PRODUCT_ORIGINAL_PRICE_VISIBLE",
143
- [i.PRODUCT_BUTTON]: "PRODUCT_BUTTON_VISIBLE"
120
+ const l = this.visibilityState[o], T = this.api.getDocumentModifier();
121
+ s.forEach((d) => {
122
+ T.modifyHtml(d).setStyle("display", l ? "table-cell" : "none");
123
+ }), T.apply(new a("Applied visibility from attributes"));
124
+ }), this._updatePriceCellWidthsForVerticalLayout();
125
+ }
126
+ _updateVisibilityAttribute(t, o) {
127
+ const s = {
128
+ [i.PRODUCT_IMAGE]: "imageVisible",
129
+ [i.PRODUCT_NAME]: "nameVisible",
130
+ [i.PRODUCT_QUANTITY]: "quantityControlEnabled",
131
+ [i.PRODUCT_PRICE]: "priceVisible",
132
+ [i.PRODUCT_ORIGINAL_PRICE]: "originalPriceVisible",
133
+ [i.PRODUCT_BUTTON]: "buttonVisible"
144
134
  }[t];
145
- T && this.api.getDocumentModifier().modifyHtml(o).setAttribute(C[T], e ? "1" : "0").apply(new l(`Updated ${t} visibility attribute`));
135
+ s && b(this.currentNode, this.api, {
136
+ [s]: o
137
+ });
146
138
  }
147
139
  _listenToFormUpdates() {
148
- 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(
149
- i.PRODUCT_ORIGINAL_PRICE,
150
- (t) => this._onProductOriginalPriceChange(t)
151
- ), this.api.onValueChanged(i.PRODUCT_BUTTON, (t) => this._onProductButtonChange(t));
140
+ this.api.onValueChanged(i.PRODUCT_IMAGE, (t) => {
141
+ this._onProductImageChange(t);
142
+ }), this.api.onValueChanged(i.PRODUCT_NAME, (t) => {
143
+ this._onProductNameChange(t);
144
+ }), this.api.onValueChanged(i.PRODUCT_QUANTITY, (t) => {
145
+ this._onProductQuantityChange(t);
146
+ }), this.api.onValueChanged(i.PRODUCT_PRICE, (t) => {
147
+ this._onProductPriceChange(t);
148
+ }), this.api.onValueChanged(i.PRODUCT_ORIGINAL_PRICE, (t) => {
149
+ this._onProductOriginalPriceChange(t);
150
+ }), this.api.onValueChanged(i.PRODUCT_BUTTON, (t) => {
151
+ this._onProductButtonChange(t);
152
+ });
152
153
  }
153
154
  _onProductImageChange(t) {
154
- var o;
155
- const e = (o = this.currentNode) == null ? void 0 : o.querySelector(`[esd-extension-block-id="${s.IMAGE}"]`);
156
- 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));
155
+ var e;
156
+ const o = (e = this.currentNode) == null ? void 0 : e.querySelector(`[esd-extension-block-id="${n.IMAGE}"]`);
157
+ o && (this.visibilityState[i.PRODUCT_IMAGE] = t, this.api.getDocumentModifier().modifyHtml(o).setStyle("display", t ? "table-cell" : "none").apply(new a(`Product image visibility changed to ${t ? "visible" : "hidden"}`)), this._updateVisibilityAttribute(i.PRODUCT_IMAGE, t));
157
158
  }
158
159
  _onProductNameChange(t) {
159
- var o;
160
- const e = (o = this.currentNode) == null ? void 0 : o.querySelector(`[esd-extension-block-id="${s.NAME}"]`);
161
- 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));
160
+ var e;
161
+ const o = (e = this.currentNode) == null ? void 0 : e.querySelector(`[esd-extension-block-id="${n.NAME}"]`);
162
+ o && (this.visibilityState[i.PRODUCT_NAME] = t, this.api.getDocumentModifier().modifyHtml(o).setStyle("display", t ? "table-cell" : "none").apply(new a(`Product name visibility changed to ${t ? "visible" : "hidden"}`)), this._updateVisibilityAttribute(i.PRODUCT_NAME, t));
162
163
  }
163
164
  _onProductQuantityChange(t) {
164
- var o;
165
- const e = (o = this.currentNode) == null ? void 0 : o.querySelector(`[esd-extension-block-id="${s.QUANTITY}"]`);
166
- e && (this.visibilityState[i.PRODUCT_QUANTITY] = t, this.api.getDocumentModifier().modifyHtml(e).setStyle("display", t ? "table-cell" : "none").apply(new l(
165
+ var e;
166
+ const o = (e = this.currentNode) == null ? void 0 : e.querySelector(`[esd-extension-block-id="${n.QUANTITY}"]`);
167
+ o && (this.visibilityState[i.PRODUCT_QUANTITY] = t, this.api.getDocumentModifier().modifyHtml(o).setStyle("display", t ? "table-cell" : "none").apply(new a(
167
168
  `Product quantity visibility changed to ${t ? "visible" : "hidden"}`
168
169
  )), this._updateVisibilityAttribute(i.PRODUCT_QUANTITY, t));
169
170
  }
170
171
  _onProductPriceChange(t) {
171
- var o;
172
- const e = (o = this.currentNode) == null ? void 0 : o.querySelector(`[esd-extension-block-id="${s.PRICE}"]`);
173
- 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));
172
+ var s;
173
+ const o = (s = this.currentNode) == null ? void 0 : s.querySelectorAll(
174
+ `[esd-extension-block-id="${n.PRICE}"]`
175
+ );
176
+ if (!o)
177
+ return;
178
+ this.visibilityState[i.PRODUCT_PRICE] = t;
179
+ const e = this.api.getDocumentModifier();
180
+ o.forEach((l) => {
181
+ e.modifyHtml(l).setStyle("display", t ? "table-cell" : "none");
182
+ }), e.apply(
183
+ new a(`Product price visibility changed to ${t ? "visible" : "hidden"}`)
184
+ ), this._updateVisibilityAttribute(i.PRODUCT_PRICE, t), this._updatePriceCellWidthsForVerticalLayout();
174
185
  }
175
186
  _onProductOriginalPriceChange(t) {
176
- var o;
177
- const e = (o = this.currentNode) == null ? void 0 : o.querySelector(
178
- `[esd-extension-block-id="${s.ORIGINAL_PRICE}"]`
187
+ var s;
188
+ const o = (s = this.currentNode) == null ? void 0 : s.querySelectorAll(
189
+ `[esd-extension-block-id="${n.ORIGINAL_PRICE}"]`
179
190
  );
180
- e && (this.visibilityState[i.PRODUCT_ORIGINAL_PRICE] = t, this.api.getDocumentModifier().modifyHtml(e).setStyle("display", t ? "table-cell" : "none").apply(new l(
191
+ if (!o)
192
+ return;
193
+ this.visibilityState[i.PRODUCT_ORIGINAL_PRICE] = t;
194
+ const e = this.api.getDocumentModifier();
195
+ o.forEach((l) => {
196
+ e.modifyHtml(l).setStyle("display", t ? "table-cell" : "none");
197
+ }), e.apply(new a(
181
198
  `Product original price visibility changed to ${t ? "visible" : "hidden"}`
182
- )), this._updateVisibilityAttribute(i.PRODUCT_ORIGINAL_PRICE, t));
199
+ )), this._updateVisibilityAttribute(i.PRODUCT_ORIGINAL_PRICE, t), this._updatePriceCellWidthsForVerticalLayout();
200
+ }
201
+ /**
202
+ * Updates both price cell widths in vertical layout based on priceOrientation and visibility.
203
+ * - When priceOrientation is 'vertical': both cells are 100% (stacked layout)
204
+ * - When priceOrientation is 'horizontal':
205
+ * - When original price is hidden, price cell expands to 100%
206
+ * - When price is hidden, original price cell expands to 100%
207
+ * - When both are visible, they share 50% each
208
+ */
209
+ _updatePriceCellWidthsForVerticalLayout() {
210
+ var R, O;
211
+ const t = h(this.currentNode);
212
+ if (!((t == null ? void 0 : t.orientation) === u.ORIENTATION.VERTICAL))
213
+ return;
214
+ const e = (R = this.currentNode) == null ? void 0 : R.querySelectorAll(".product-price-class"), s = (O = this.currentNode) == null ? void 0 : O.querySelectorAll(".product-original-price-class"), l = (t == null ? void 0 : t.priceOrientation) === "vertical", T = this.visibilityState[i.PRODUCT_PRICE], C = this.visibilityState[i.PRODUCT_ORIGINAL_PRICE], d = this.api.getDocumentModifier();
215
+ if (e && e.length > 0) {
216
+ const P = l || !C ? "100%" : "50%";
217
+ e.forEach((_) => {
218
+ d.modifyHtml(_).setStyle("width", P);
219
+ });
220
+ }
221
+ if (s && s.length > 0) {
222
+ const P = l || !T ? "100%" : "50%";
223
+ s.forEach((_) => {
224
+ d.modifyHtml(_).setStyle("width", P);
225
+ });
226
+ }
227
+ d.apply(new a("Updated price cell widths for vertical layout"));
183
228
  }
184
229
  _onProductButtonChange(t) {
185
- var o;
186
- const e = (o = this.currentNode) == null ? void 0 : o.querySelector(`[esd-extension-block-id="${s.BUTTON}"]`);
187
- 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));
230
+ var e;
231
+ const o = (e = this.currentNode) == null ? void 0 : e.querySelector(`[esd-extension-block-id="${n.BUTTON}"]`);
232
+ o && (this.visibilityState[i.PRODUCT_BUTTON] = t, this.api.getDocumentModifier().modifyHtml(o).setStyle("display", t ? "table-cell" : "none").apply(new a(`Product button visibility changed to ${t ? "visible" : "hidden"}`)), this._updateVisibilityAttribute(i.PRODUCT_BUTTON, t));
188
233
  }
189
234
  }
190
235
  export {
191
- h as COMPOSITION_CONTROL_BLOCK_ID,
192
- g as ItemsBlockCardCompositionControl
236
+ m as COMPOSITION_CONTROL_BLOCK_ID,
237
+ S as ItemsBlockCardCompositionControl
193
238
  };
@@ -1,52 +1,33 @@
1
- var r = Object.defineProperty;
2
- var a = (o, t, e) => t in o ? r(o, t, { enumerable: !0, configurable: !0, writable: !0, value: e }) : o[t] = e;
3
- var i = (o, t, e) => a(o, typeof t != "symbol" ? t + "" : t, e);
4
- import { CommonControl as m } 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 { syncImageLinkFromAttributes as h } from "../../utils/syncAttributesFromConfigBlock.js";
8
- import { updateConfigBlockAttributes as p } from "../../utils/updateAttributes.js";
9
- const s = d.IMAGE_LINK, n = {
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 = {
10
5
  LINK: "link"
11
6
  };
12
- class N extends m {
13
- constructor() {
14
- super(...arguments);
15
- i(this, "store", l());
16
- }
7
+ class p extends a {
17
8
  getId() {
18
9
  return s;
19
10
  }
20
11
  getTemplate() {
21
12
  return `
22
- <div class="${s}">
13
+ <div class="container ${s}">
23
14
  ${this._getLink()}
24
15
  </div>
25
16
  `;
26
17
  }
27
18
  onRender() {
19
+ const e = o(this.currentNode);
28
20
  this.api.updateValues({
29
- [n.LINK]: this.store.imageLink
30
- }), this._listenToFormUpdates();
21
+ [n.LINK]: (e == null ? void 0 : e.imageLink) ?? ""
22
+ });
31
23
  }
32
24
  onTemplateNodeUpdated(e) {
33
- super.onTemplateNodeUpdated(e), this.handleBlockInstanceChange(
34
- () => h(this.currentNode),
35
- () => {
36
- this.api.updateValues({
37
- [n.LINK]: this.store.imageLink
38
- });
39
- }
40
- );
41
- }
42
- _listenToFormUpdates() {
43
- this.api.onValueChanged(
44
- n.LINK,
45
- (e) => this._onLinkChange(e)
46
- );
47
- }
48
- _onLinkChange(e) {
49
- console.debug("Image link changed to: ", e), this.store.setImageLink(e), p(this.currentNode, this.api);
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
+ });
50
31
  }
51
32
  _getLink() {
52
33
  return `
@@ -64,5 +45,5 @@ class N extends m {
64
45
  }
65
46
  export {
66
47
  s as CONTROL_BLOCK_ID,
67
- N as ImageLinkControl
48
+ p as ImageLinkControl
68
49
  };