@useinsider/guido 2.1.0-beta.bc18abc → 2.1.0-beta.bcfc012

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 (213) hide show
  1. package/README.md +36 -0
  2. package/dist/@types/config/schemas.js +70 -65
  3. package/dist/components/Guido.vue.js +1 -1
  4. package/dist/components/Guido.vue2.js +69 -58
  5. package/dist/components/organisms/extensions/recommendation/FilterSelectionDrawer.vue2.js +15 -14
  6. package/dist/components/organisms/header/EditorActions.vue.js +12 -10
  7. package/dist/components/organisms/header/EditorActions.vue2.js +41 -31
  8. package/dist/components/organisms/header/HeaderWrapper.vue.js +9 -9
  9. package/dist/components/organisms/header/MigrationConfirmModal.vue.js +21 -0
  10. package/dist/components/organisms/header/MigrationConfirmModal.vue2.js +38 -0
  11. package/dist/composables/useActionsApi.js +15 -13
  12. package/dist/composables/useBlocksConfig.js +26 -16
  13. package/dist/composables/useHtmlValidator.js +114 -104
  14. package/dist/composables/useRecommendation.js +54 -21
  15. package/dist/composables/useStripo.js +25 -23
  16. package/dist/composables/useVersionHistoryApi.js +1 -1
  17. package/dist/config/compiler/recommendationCompilerRules.js +45 -39
  18. package/dist/config/compiler/utils/recommendationCompilerUtils.js +121 -0
  19. package/dist/config/i18n/en/index.js +11 -0
  20. package/dist/config/i18n/en/labels.json.js +12 -0
  21. package/dist/config/i18n/en/toasters.json.js +56 -0
  22. package/dist/config/i18n/en/tooltips.json.js +82 -0
  23. package/dist/config/i18n/index.js +7 -0
  24. package/dist/config/migrator/itemsBlockMigrator.js +142 -119
  25. package/dist/config/migrator/recommendationMigrator.js +42 -40
  26. package/dist/enums/defaults.js +8 -4
  27. package/dist/enums/extensions/recommendationBlock.js +1 -1
  28. package/dist/enums/recommendation.js +16 -15
  29. package/dist/extensions/Blocks/Items/block.js +46 -35
  30. package/dist/extensions/Blocks/Items/controls/button/link.js +19 -31
  31. package/dist/extensions/Blocks/Items/controls/cardComposition.js +124 -85
  32. package/dist/extensions/Blocks/Items/controls/image/link.js +19 -31
  33. package/dist/extensions/Blocks/Items/controls/name/trimming.js +28 -40
  34. package/dist/extensions/Blocks/Items/controls/price/currencyLocation.js +35 -47
  35. package/dist/extensions/Blocks/Items/controls/price/currencySymbol.js +49 -54
  36. package/dist/extensions/Blocks/Items/controls/price/formattedPrice.js +42 -51
  37. package/dist/extensions/Blocks/Items/controls/price/hideDiscount.js +23 -36
  38. package/dist/extensions/Blocks/Items/controls/price/priceOrientation.js +45 -57
  39. package/dist/extensions/Blocks/Items/controls/price/singlePrice.js +42 -60
  40. package/dist/extensions/Blocks/Items/controls/settingsControl.js +189 -196
  41. package/dist/extensions/Blocks/Items/enums/settingsEnums.js +0 -2
  42. package/dist/extensions/Blocks/Items/extension.js +8 -9
  43. package/dist/extensions/Blocks/Items/iconsRegistry.js +40 -5
  44. package/dist/extensions/Blocks/Items/items.css.js +48 -0
  45. package/dist/extensions/Blocks/Items/settingsPanel.js +10 -15
  46. package/dist/extensions/Blocks/Items/template.js +181 -175
  47. package/dist/extensions/Blocks/Items/utils/nodeConfigUtils.js +65 -65
  48. package/dist/extensions/Blocks/Recommendation/block.js +153 -9
  49. package/dist/extensions/Blocks/Recommendation/constants/blockIds.js +4 -0
  50. package/dist/extensions/Blocks/Recommendation/constants/controlIds.js +4 -0
  51. package/dist/extensions/Blocks/Recommendation/constants/defaultConfig.js +66 -0
  52. package/dist/extensions/Blocks/Recommendation/constants/layout.js +22 -0
  53. package/dist/extensions/Blocks/Recommendation/constants/selectors.js +21 -0
  54. package/dist/extensions/Blocks/Recommendation/controls/button/index.js +64 -0
  55. package/dist/extensions/Blocks/Recommendation/controls/cardBackground/index.js +80 -0
  56. package/dist/extensions/Blocks/Recommendation/controls/cardComposition/index.js +232 -0
  57. package/dist/extensions/Blocks/Recommendation/controls/image/index.js +19 -0
  58. package/dist/extensions/Blocks/Recommendation/controls/layout/index.js +92 -0
  59. package/dist/extensions/Blocks/Recommendation/controls/main/algorithm.js +102 -0
  60. package/dist/extensions/Blocks/Recommendation/controls/main/currency.js +209 -0
  61. package/dist/extensions/Blocks/Recommendation/controls/main/filters.js +52 -0
  62. package/dist/extensions/Blocks/Recommendation/controls/main/index.js +250 -0
  63. package/dist/extensions/Blocks/Recommendation/controls/main/locale.js +70 -0
  64. package/dist/extensions/Blocks/Recommendation/controls/main/productLayout.js +160 -0
  65. package/dist/extensions/Blocks/Recommendation/controls/main/shuffle.js +67 -0
  66. package/dist/extensions/Blocks/Recommendation/controls/main/utils.js +307 -0
  67. package/dist/extensions/Blocks/Recommendation/controls/mobileLayout/cssRules.js +21 -0
  68. package/dist/extensions/Blocks/Recommendation/controls/name/index.js +46 -0
  69. package/dist/extensions/Blocks/Recommendation/controls/name/textTrim.js +108 -0
  70. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/index.js +44 -0
  71. package/dist/extensions/Blocks/Recommendation/controls/omnibusDiscount/index.js +48 -0
  72. package/dist/extensions/Blocks/Recommendation/controls/{omnibusDiscountTextAfterControl.js → omnibusDiscount/textAfter.js} +16 -14
  73. package/dist/extensions/Blocks/Recommendation/controls/{omnibusDiscountTextBeforeControl.js → omnibusDiscount/textBefore.js} +16 -14
  74. package/dist/extensions/Blocks/Recommendation/controls/omnibusPrice/index.js +48 -0
  75. package/dist/extensions/Blocks/Recommendation/controls/{omnibusPriceTextAfterControl.js → omnibusPrice/textAfter.js} +16 -14
  76. package/dist/extensions/Blocks/Recommendation/controls/{omnibusPriceTextBeforeControl.js → omnibusPrice/textBefore.js} +14 -12
  77. package/dist/extensions/Blocks/Recommendation/controls/price/index.js +44 -0
  78. package/dist/extensions/Blocks/Recommendation/controls/spacing/index.js +222 -0
  79. package/dist/extensions/Blocks/Recommendation/extension.js +40 -17
  80. package/dist/extensions/Blocks/Recommendation/iconsRegistry.js +54 -3
  81. package/dist/extensions/Blocks/Recommendation/recommendation.css.js +61 -4
  82. package/dist/extensions/Blocks/Recommendation/services/configService.js +240 -0
  83. package/dist/extensions/Blocks/Recommendation/settingsPanel.js +21 -10
  84. package/dist/extensions/Blocks/Recommendation/store/recommendation.js +254 -207
  85. package/dist/extensions/Blocks/Recommendation/templates/grid/elementRenderer.js +228 -0
  86. package/dist/extensions/Blocks/Recommendation/templates/grid/migration.js +251 -0
  87. package/dist/extensions/Blocks/Recommendation/templates/grid/template.js +66 -0
  88. package/dist/extensions/Blocks/Recommendation/templates/index.js +12 -0
  89. package/dist/extensions/Blocks/Recommendation/templates/list/elementRenderer.js +169 -0
  90. package/dist/extensions/Blocks/Recommendation/templates/list/template.js +73 -0
  91. package/dist/extensions/Blocks/Recommendation/templates/utils.js +134 -0
  92. package/dist/extensions/Blocks/Recommendation/types/nodeConfig.js +6 -0
  93. package/dist/extensions/Blocks/Recommendation/utils/filterUtil.js +9 -9
  94. package/dist/extensions/Blocks/Recommendation/utils/preserveTextStyles.js +26 -15
  95. package/dist/extensions/Blocks/Recommendation/utils/priceFormatter.js +29 -0
  96. package/dist/extensions/Blocks/Recommendation/utils/tagName.js +46 -0
  97. package/dist/extensions/Blocks/common-control.js +101 -94
  98. package/dist/extensions/Blocks/controlFactories.js +125 -93
  99. package/dist/extensions/ModulesTabIcons/extension.js +17 -0
  100. package/dist/guido.css +1 -1
  101. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/esm/index.js +317 -193
  102. package/dist/services/recommendationApi.js +11 -8
  103. package/dist/services/stripoApi.js +20 -17
  104. package/dist/services/templateLibraryApi.js +16 -13
  105. package/dist/src/@types/config/schemas.d.ts +8 -0
  106. package/dist/src/components/Guido.vue.d.ts +1 -1
  107. package/dist/src/components/organisms/header/EditorActions.vue.d.ts +1 -1
  108. package/dist/src/components/organisms/header/HeaderWrapper.vue.d.ts +1 -1
  109. package/dist/src/components/organisms/header/MigrationConfirmModal.vue.d.ts +5 -0
  110. package/dist/src/components/organisms/header/RightSlot.vue.d.ts +1 -1
  111. package/dist/src/components/wrappers/WpDrawer.vue.d.ts +1 -1
  112. package/dist/src/components/wrappers/WpModal.vue.d.ts +2 -2
  113. package/dist/src/composables/useConfig.d.ts +4 -0
  114. package/dist/src/composables/useRecommendation.d.ts +1 -0
  115. package/dist/src/config/compiler/utils/recommendationCompilerUtils.d.ts +17 -0
  116. package/dist/src/config/i18n/en/index.d.ts +1 -0
  117. package/dist/src/config/i18n/index.d.ts +16 -0
  118. package/dist/src/enums/defaults.d.ts +4 -0
  119. package/dist/src/extensions/Blocks/Items/block.d.ts +1 -1
  120. package/dist/src/extensions/Blocks/Items/controls/button/link.d.ts +0 -1
  121. package/dist/src/extensions/Blocks/Items/controls/cardComposition.d.ts +5 -5
  122. package/dist/src/extensions/Blocks/Items/controls/image/link.d.ts +0 -1
  123. package/dist/src/extensions/Blocks/Items/controls/name/trimming.d.ts +0 -1
  124. package/dist/src/extensions/Blocks/Items/controls/price/currencyLocation.d.ts +0 -1
  125. package/dist/src/extensions/Blocks/Items/controls/price/currencySymbol.d.ts +0 -1
  126. package/dist/src/extensions/Blocks/Items/controls/price/formattedPrice.d.ts +0 -1
  127. package/dist/src/extensions/Blocks/Items/controls/price/hideDiscount.d.ts +0 -1
  128. package/dist/src/extensions/Blocks/Items/controls/price/priceOrientation.d.ts +0 -1
  129. package/dist/src/extensions/Blocks/Items/controls/price/singlePrice.d.ts +0 -5
  130. package/dist/src/extensions/Blocks/Items/controls/settingsControl.d.ts +10 -12
  131. package/dist/src/extensions/Blocks/Items/utils/nodeConfigUtils.d.ts +2 -1
  132. package/dist/src/extensions/Blocks/Recommendation/block.d.ts +68 -0
  133. package/dist/src/extensions/Blocks/Recommendation/constants/blockIds.d.ts +13 -0
  134. package/dist/src/extensions/Blocks/Recommendation/{constants.d.ts → constants/controlIds.d.ts} +0 -24
  135. package/dist/src/extensions/Blocks/Recommendation/constants/defaultConfig.d.ts +49 -0
  136. package/dist/src/extensions/Blocks/Recommendation/constants/index.d.ts +13 -0
  137. package/dist/src/extensions/Blocks/Recommendation/constants/layout.d.ts +41 -0
  138. package/dist/src/extensions/Blocks/Recommendation/constants/selectors.d.ts +35 -0
  139. package/dist/src/extensions/Blocks/Recommendation/controls/button/index.d.ts +143 -0
  140. package/dist/src/extensions/Blocks/Recommendation/controls/cardBackground/index.d.ts +31 -0
  141. package/dist/src/extensions/Blocks/Recommendation/{cardCompositionControl.d.ts → controls/cardComposition/index.d.ts} +23 -3
  142. package/dist/src/extensions/Blocks/Recommendation/controls/image/index.d.ts +35 -0
  143. package/dist/src/extensions/Blocks/Recommendation/controls/index.d.ts +21 -589
  144. package/dist/src/extensions/Blocks/Recommendation/controls/layout/index.d.ts +37 -0
  145. package/dist/src/extensions/Blocks/Recommendation/controls/main/algorithm.d.ts +29 -0
  146. package/dist/src/extensions/Blocks/Recommendation/controls/main/currency.d.ts +52 -0
  147. package/dist/src/extensions/Blocks/Recommendation/controls/main/filters.d.ts +22 -0
  148. package/dist/src/extensions/Blocks/Recommendation/controls/main/index.d.ts +79 -0
  149. package/dist/src/extensions/Blocks/Recommendation/controls/main/locale.d.ts +24 -0
  150. package/dist/src/extensions/Blocks/Recommendation/controls/main/productLayout.d.ts +60 -0
  151. package/dist/src/extensions/Blocks/Recommendation/controls/main/shuffle.d.ts +23 -0
  152. package/dist/src/extensions/Blocks/Recommendation/controls/main/utils.d.ts +221 -0
  153. package/dist/src/extensions/Blocks/Recommendation/controls/mobileLayout/cssRules.d.ts +29 -0
  154. package/dist/src/extensions/Blocks/Recommendation/controls/name/index.d.ts +97 -0
  155. package/dist/src/extensions/Blocks/Recommendation/controls/name/textTrim.d.ts +34 -0
  156. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/index.d.ts +95 -0
  157. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusDiscount/index.d.ts +100 -0
  158. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusDiscount/textAfter.d.ts +15 -0
  159. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusDiscount/textBefore.d.ts +15 -0
  160. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusPrice/index.d.ts +100 -0
  161. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusPrice/textAfter.d.ts +15 -0
  162. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusPrice/textBefore.d.ts +15 -0
  163. package/dist/src/extensions/Blocks/Recommendation/controls/price/index.d.ts +95 -0
  164. package/dist/src/extensions/Blocks/Recommendation/controls/spacing/index.d.ts +83 -0
  165. package/dist/src/extensions/Blocks/Recommendation/extension.d.ts +9 -0
  166. package/dist/src/extensions/Blocks/Recommendation/services/configService.d.ts +151 -0
  167. package/dist/src/extensions/Blocks/Recommendation/services/index.d.ts +6 -0
  168. package/dist/src/extensions/Blocks/Recommendation/store/recommendation.d.ts +138 -468
  169. package/dist/src/extensions/Blocks/Recommendation/templates/grid/elementRenderer.d.ts +20 -0
  170. package/dist/src/extensions/Blocks/Recommendation/templates/{migrationTemplate.d.ts → grid/migration.d.ts} +11 -4
  171. package/dist/src/extensions/Blocks/Recommendation/templates/grid/template.d.ts +33 -0
  172. package/dist/src/extensions/Blocks/Recommendation/templates/index.d.ts +41 -0
  173. package/dist/src/extensions/Blocks/Recommendation/templates/list/elementRenderer.d.ts +8 -0
  174. package/dist/src/extensions/Blocks/Recommendation/templates/list/migration.d.ts +25 -0
  175. package/dist/src/extensions/Blocks/Recommendation/templates/list/template.d.ts +18 -0
  176. package/dist/src/extensions/Blocks/Recommendation/templates/utils.d.ts +66 -0
  177. package/dist/src/extensions/Blocks/Recommendation/types/index.d.ts +7 -0
  178. package/dist/src/extensions/Blocks/Recommendation/types/nodeConfig.d.ts +166 -0
  179. package/dist/src/extensions/Blocks/Recommendation/utils/priceFormatter.d.ts +33 -0
  180. package/dist/src/extensions/Blocks/Recommendation/utils/stylePreserver.d.ts +113 -0
  181. package/dist/src/extensions/Blocks/Recommendation/utils/tagName.d.ts +77 -0
  182. package/dist/src/extensions/Blocks/common-control.d.ts +9 -5
  183. package/dist/src/extensions/ModulesTabIcons/extension.d.ts +2 -0
  184. package/dist/src/stores/config.d.ts +36 -0
  185. package/dist/src/stores/template.d.ts +3 -0
  186. package/dist/static/styles/components/notification.css.js +19 -0
  187. package/dist/static/styles/components/tools.css.js +6 -2
  188. package/dist/static/styles/components/version-history.css.js +10 -2
  189. package/dist/static/styles/components/wide-panel.css.js +18 -2
  190. package/dist/static/styles/customEditorStyle.css.js +35 -11
  191. package/dist/static/styles/variables.css.js +2 -0
  192. package/dist/static/templates/empty/index.html.js +74 -0
  193. package/dist/static/templates/empty/style.css.js +779 -0
  194. package/dist/stores/template.js +9 -0
  195. package/dist/utils/pairProductVariables.js +57 -56
  196. package/dist/utils/templatePreparation.js +15 -14
  197. package/package.json +1 -1
  198. package/dist/extensions/Blocks/Items/store/items-block.js +0 -79
  199. package/dist/extensions/Blocks/Recommendation/cardCompositionControl.js +0 -187
  200. package/dist/extensions/Blocks/Recommendation/constants.js +0 -13
  201. package/dist/extensions/Blocks/Recommendation/control.js +0 -336
  202. package/dist/extensions/Blocks/Recommendation/controls/cardBackgroundColorControl.js +0 -68
  203. package/dist/extensions/Blocks/Recommendation/controls/index.js +0 -245
  204. package/dist/extensions/Blocks/Recommendation/controls/nameTextTrimControl.js +0 -74
  205. package/dist/extensions/Blocks/Recommendation/controls/spacingControl.js +0 -188
  206. package/dist/extensions/Blocks/Recommendation/templates/blockTemplate.js +0 -181
  207. package/dist/extensions/Blocks/Recommendation/templates/migrationTemplate.js +0 -189
  208. package/dist/extensions/Blocks/Recommendation/templates/templateUtils.js +0 -209
  209. package/dist/src/extensions/Blocks/Items/store/items-block.d.ts +0 -45
  210. package/dist/src/extensions/Blocks/Recommendation/control.d.ts +0 -38
  211. package/dist/src/extensions/Blocks/Recommendation/controls/nameTextTrimControl.d.ts +0 -16
  212. package/dist/src/extensions/Blocks/Recommendation/templates/blockTemplate.d.ts +0 -16
  213. package/dist/src/extensions/Blocks/Recommendation/templates/templateUtils.d.ts +0 -52
@@ -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,19 +1,19 @@
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";
7
- const y = "items-block";
8
- class B extends u {
1
+ import { useOnboardingStore as g } from "../../../stores/onboarding.js";
2
+ import { useTemplateStore as f } from "../../../stores/template.js";
3
+ import { Block as u, BlockCompositionType as I, UIElementType as c, UEAttr as C, ModificationDescription as r } from "../../../node_modules/@stripoinc/ui-editor-extensions/dist/esm/index.js";
4
+ import { SETTINGS_ENUMS as l, DefaultConfigValues as s } from "./enums/settingsEnums.js";
5
+ import { getDefaultTemplate as y } from "./template.js";
6
+ import { getItemsBlockContainer as b, getItemsBlockConfig as k, getDefaultItemsBlockConfig as N } from "./utils/nodeConfigUtils.js";
7
+ const m = "items-block";
8
+ class M extends u {
9
9
  getId() {
10
- return y;
10
+ return m;
11
11
  }
12
12
  getIcon() {
13
13
  return "items-icon";
14
14
  }
15
15
  getBlockCompositionType() {
16
- return d.CONTAINER;
16
+ return I.CONTAINER;
17
17
  }
18
18
  getName() {
19
19
  return this.api.translate("Items");
@@ -21,43 +21,54 @@ class B extends u {
21
21
  getDescription() {
22
22
  return this.api.translate("Items lets you display personalized products based on user behavior.");
23
23
  }
24
+ getSettingsPanelTitleHtml() {
25
+ if (f().migrations[m] === 0)
26
+ return "";
27
+ const n = this.api.translate("Items"), o = this.api.translate("This block is switched from the Old Version to the New Version. We recommend you check the Items block and test your message to ensure it works properly.");
28
+ return `<div>
29
+ <div style="display: flex; align-items: center;">
30
+ <span>${n}</span>
31
+ </div>
32
+ <div class="items-migration-info">
33
+ <${c.ICON}
34
+ ${C.ICON.src}="migration-info-icon"
35
+ class="items-migration-info__icon">
36
+ </${c.ICON}>
37
+ <p class="items-migration-info__text">
38
+ ${o}
39
+ </p>
40
+ </div>
41
+ </div>`;
42
+ }
24
43
  getTemplate() {
25
- return f({
26
- orientation: c.ORIENTATION.VERTICAL,
27
- itemsType: c.ITEMS_TYPE.CART_ITEMS,
44
+ return y({
45
+ orientation: l.ORIENTATION.VERTICAL,
46
+ itemsType: l.ITEMS_TYPE.CART_ITEMS,
28
47
  itemId: "{{Abandoned Cart Item (1) Url}}",
29
- currencySymbol: o.productPriceCurrencySymbolControlValue,
30
- currencyLocation: o.productPriceCurrencyLocationControlValue,
31
- formattedPrice: o.productPriceFormattedControlValue === "1"
48
+ currencySymbol: s.productPriceCurrencySymbolControlValue,
49
+ currencyLocation: s.productPriceCurrencyLocationControlValue,
50
+ formattedPrice: s.productPriceFormattedControlValue === "1"
32
51
  });
33
52
  }
34
53
  allowInnerBlocksDND() {
35
54
  return !1;
36
55
  }
37
- onCreated(n) {
38
- const e = g(n);
56
+ onCreated(i) {
57
+ const n = this.api.getDocumentModifier(), o = this.api.getDocumentRootCssNode();
58
+ o.querySelector('[product-attr="imageSrc"] img') || n.modifyCss(o).appendRule('[product-attr="imageSrc"] img {object-fit: contain;}');
59
+ const e = b(i);
39
60
  if (!e)
40
61
  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"));
62
+ const a = e.getNodeConfig(), d = a && Object.keys(a).length > 0, t = k(i);
63
+ if (t != null && t.initialized)
64
+ d ? t.blockInstanceId || this.api.getDocumentModifier().modifyHtml(e).setNodeConfig({ ...t, blockInstanceId: String(Date.now()) }).apply(new r("Assign block instance ID to block")) : this.api.getDocumentModifier().modifyHtml(e).setNodeConfig(t).apply(new r("Migrate legacy config to nodeConfig"));
44
65
  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");
66
+ const p = N();
67
+ this.api.getDocumentModifier().modifyHtml(e).setNodeConfig(p).apply(new r("Initialize Items block with default configuration")), g().startOnboarding("itemsOnboarding");
47
68
  }
48
69
  }
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
70
  }
60
71
  export {
61
- y as BLOCK_ID,
62
- B as ItemsBlock
72
+ m as BLOCK_ID,
73
+ M as ItemsBlock
63
74
  };
@@ -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,9 +133,9 @@ 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
141
  this.api.onValueChanged(i.PRODUCT_IMAGE, (t) => {
@@ -157,35 +153,67 @@ class S extends I {
157
153
  });
158
154
  }
159
155
  _onProductImageChange(t) {
160
- var o;
161
- const e = (o = this.currentNode) == null ? void 0 : o.querySelector(`[esd-extension-block-id="${s.IMAGE}"]`);
162
- 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));
163
165
  }
164
166
  _onProductNameChange(t) {
165
- var o;
166
- const e = (o = this.currentNode) == null ? void 0 : o.querySelector(`[esd-extension-block-id="${s.NAME}"]`);
167
- 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));
168
176
  }
169
177
  _onProductQuantityChange(t) {
170
- var o;
171
- const e = (o = this.currentNode) == null ? void 0 : o.querySelector(`[esd-extension-block-id="${s.QUANTITY}"]`);
172
- e && (this.visibilityState[i.PRODUCT_QUANTITY] = t, this.api.getDocumentModifier().modifyHtml(e).setStyle("display", t ? "table-cell" : "none").apply(new l(
173
- `Product quantity visibility changed to ${t ? "visible" : "hidden"}`
174
- )), 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));
175
187
  }
176
188
  _onProductPriceChange(t) {
177
- var o;
178
- const e = (o = this.currentNode) == null ? void 0 : o.querySelector(`[esd-extension-block-id="${s.PRICE}"]`);
179
- 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));
180
202
  }
181
203
  _onProductOriginalPriceChange(t) {
182
- var o;
183
- const e = (o = this.currentNode) == null ? void 0 : o.querySelector(
184
- `[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}"]`
185
207
  );
186
- e && (this.visibilityState[i.PRODUCT_ORIGINAL_PRICE] = t, this.api.getDocumentModifier().modifyHtml(e).setStyle("display", t ? "table-cell" : "none").apply(new l(
187
- `Product original price visibility changed to ${t ? "visible" : "hidden"}`
188
- )), 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));
189
217
  }
190
218
  /**
191
219
  * Updates both price cell widths in vertical layout based on priceOrientation and visibility.
@@ -195,28 +223,39 @@ class S extends I {
195
223
  * - When price is hidden, original price cell expands to 100%
196
224
  * - When both are visible, they share 50% each
197
225
  */
198
- _updatePriceCellWidthsForVerticalLayout() {
199
- var u, _;
200
- 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))
201
230
  return;
202
- 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();
203
- if (e) {
204
- const C = n || !d ? "100%" : "50%";
205
- 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
+ });
206
237
  }
207
- if (o) {
208
- const C = n || !c ? "100%" : "50%";
209
- 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
+ });
210
243
  }
211
- T.apply(new l("Updated price cell widths for vertical layout"));
244
+ t || T.apply(new c("Updated price cell widths for vertical layout"));
212
245
  }
213
246
  _onProductButtonChange(t) {
214
- var o;
215
- const e = (o = this.currentNode) == null ? void 0 : o.querySelector(`[esd-extension-block-id="${s.BUTTON}"]`);
216
- 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));
217
256
  }
218
257
  }
219
258
  export {
220
- b as COMPOSITION_CONTROL_BLOCK_ID,
221
- S as ItemsBlockCardCompositionControl
259
+ g as COMPOSITION_CONTROL_BLOCK_ID,
260
+ M as ItemsBlockCardCompositionControl
222
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
  };