@useinsider/guido 2.0.0-beta.e68b206 → 2.0.0-beta.e73ba15

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 (232) hide show
  1. package/dist/@types/config/schemas.js +39 -53
  2. package/dist/components/organisms/email-preview/desktop-preview/DesktopPreview.vue.js +2 -2
  3. package/dist/components/organisms/email-preview/mobile-preview/ContentView.vue.js +5 -5
  4. package/dist/components/organisms/header/LeftSlot.vue.js +12 -12
  5. package/dist/components/organisms/header/LeftSlot.vue2.js +6 -6
  6. package/dist/components/organisms/header/RightSlot.vue2.js +10 -10
  7. package/dist/composables/useConfig.js +27 -29
  8. package/dist/composables/useSave.js +11 -13
  9. package/dist/config/migrator/index.js +8 -9
  10. package/dist/config/migrator/recommendationMigrator.js +2 -2
  11. package/dist/extensions/Blocks/Items/block.js +40 -39
  12. package/dist/extensions/Blocks/Items/controls/button/link.js +29 -22
  13. package/dist/extensions/Blocks/Items/controls/cardComposition.js +59 -70
  14. package/dist/extensions/Blocks/Items/controls/image/link.js +30 -23
  15. package/dist/extensions/Blocks/Items/controls/name/trimming.js +25 -25
  16. package/dist/extensions/Blocks/Items/controls/price/currencyLocation.js +17 -19
  17. package/dist/extensions/Blocks/Items/controls/price/currencySymbol.js +29 -31
  18. package/dist/extensions/Blocks/Items/controls/price/formattedPrice.js +36 -36
  19. package/dist/extensions/Blocks/Items/controls/price/hideDiscount.js +19 -21
  20. package/dist/extensions/Blocks/Items/controls/price/priceOrientation.js +27 -29
  21. package/dist/extensions/Blocks/Items/controls/settingsControl.js +144 -159
  22. package/dist/extensions/Blocks/Items/enums/controlEnums.js +2 -2
  23. package/dist/extensions/Blocks/Items/enums/productEnums.js +45 -43
  24. package/dist/extensions/Blocks/Items/enums/settingsEnums.js +3 -4
  25. package/dist/extensions/Blocks/Items/extension.js +6 -7
  26. package/dist/extensions/Blocks/Items/layouts/horizontal.html.js +49 -58
  27. package/dist/extensions/Blocks/Items/layouts/vertical.html.js +59 -48
  28. package/dist/extensions/Blocks/Items/settingsPanel.js +26 -27
  29. package/dist/extensions/Blocks/Items/store/items-block.js +7 -11
  30. package/dist/extensions/Blocks/Items/template.js +129 -366
  31. package/dist/extensions/Blocks/Items/utils/configBlockUtils.js +17 -0
  32. package/dist/extensions/Blocks/Items/utils/syncAttributeFromConfigBlock.js +28 -0
  33. package/dist/extensions/Blocks/Items/utils/syncAttributesFromConfigBlock.js +76 -0
  34. package/dist/extensions/Blocks/Items/utils/updateAttributes.js +46 -0
  35. package/dist/extensions/Blocks/Recommendation/block.js +1 -1
  36. package/dist/extensions/Blocks/Recommendation/constants/blockIds.js +4 -0
  37. package/dist/extensions/Blocks/Recommendation/constants/controlIds.js +4 -0
  38. package/dist/extensions/Blocks/Recommendation/constants/layout.js +7 -0
  39. package/dist/extensions/Blocks/Recommendation/constants/selectors.js +11 -0
  40. package/dist/extensions/Blocks/Recommendation/controls/button/index.js +64 -0
  41. package/dist/extensions/Blocks/Recommendation/controls/cardBackground/index.js +100 -0
  42. package/dist/extensions/Blocks/Recommendation/controls/cardComposition/index.js +243 -0
  43. package/dist/extensions/Blocks/Recommendation/controls/image/index.js +19 -0
  44. package/dist/extensions/Blocks/Recommendation/controls/layout/index.js +104 -0
  45. package/dist/extensions/Blocks/Recommendation/controls/main/algorithm.js +86 -0
  46. package/dist/extensions/Blocks/Recommendation/controls/main/currency.js +134 -0
  47. package/dist/extensions/Blocks/Recommendation/controls/main/filters.js +54 -0
  48. package/dist/extensions/Blocks/Recommendation/controls/main/index.js +106 -0
  49. package/dist/extensions/Blocks/Recommendation/controls/main/locale.js +64 -0
  50. package/dist/extensions/Blocks/Recommendation/controls/main/productLayout.js +124 -0
  51. package/dist/extensions/Blocks/Recommendation/controls/main/shuffle.js +60 -0
  52. package/dist/extensions/Blocks/Recommendation/controls/main/utils.js +112 -0
  53. package/dist/extensions/Blocks/Recommendation/controls/name/index.js +46 -0
  54. package/dist/extensions/Blocks/Recommendation/controls/name/textTrim.js +76 -0
  55. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/index.js +44 -0
  56. package/dist/extensions/Blocks/Recommendation/controls/omnibusDiscount/index.js +48 -0
  57. package/dist/extensions/Blocks/Recommendation/controls/omnibusDiscount/textAfter.js +73 -0
  58. package/dist/extensions/Blocks/Recommendation/controls/omnibusDiscount/textBefore.js +73 -0
  59. package/dist/extensions/Blocks/Recommendation/controls/omnibusPrice/index.js +48 -0
  60. package/dist/extensions/Blocks/Recommendation/controls/omnibusPrice/textAfter.js +73 -0
  61. package/dist/extensions/Blocks/Recommendation/controls/omnibusPrice/textBefore.js +73 -0
  62. package/dist/extensions/Blocks/Recommendation/controls/price/index.js +44 -0
  63. package/dist/extensions/Blocks/Recommendation/controls/spacing/index.js +224 -0
  64. package/dist/extensions/Blocks/Recommendation/extension.js +40 -43
  65. package/dist/extensions/Blocks/Recommendation/recommendation.css.js +5 -0
  66. package/dist/extensions/Blocks/Recommendation/settingsPanel.js +128 -72
  67. package/dist/extensions/Blocks/Recommendation/store/recommendation.js +22 -21
  68. package/dist/extensions/Blocks/Recommendation/templates/horizontal/elementRenderer.js +157 -0
  69. package/dist/extensions/Blocks/Recommendation/templates/horizontal/template.js +72 -0
  70. package/dist/extensions/Blocks/Recommendation/templates/index.js +12 -0
  71. package/dist/extensions/Blocks/Recommendation/templates/utils.js +173 -0
  72. package/dist/extensions/Blocks/Recommendation/templates/vertical/elementRenderer.js +186 -0
  73. package/dist/extensions/Blocks/Recommendation/templates/vertical/migration.js +251 -0
  74. package/dist/extensions/Blocks/Recommendation/templates/vertical/template.js +62 -0
  75. package/dist/extensions/Blocks/Recommendation/utils/filterUtil.js +9 -9
  76. package/dist/extensions/Blocks/Recommendation/utils/preserveTextStyles.js +25 -0
  77. package/dist/extensions/Blocks/Unsubscribe/extension.js +9 -9
  78. package/dist/extensions/Blocks/common-control.js +30 -29
  79. package/dist/extensions/Blocks/controlFactories.js +130 -106
  80. package/dist/guido.css +1 -1
  81. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/esm/index.js +116 -125
  82. package/dist/src/@types/config/index.d.ts +2 -2
  83. package/dist/src/@types/config/schemas.d.ts +0 -26
  84. package/dist/src/@types/config/types.d.ts +1 -7
  85. package/dist/src/composables/useConfig.d.ts +0 -6
  86. package/dist/src/extensions/Blocks/Items/controls/button/link.d.ts +2 -0
  87. package/dist/src/extensions/Blocks/Items/controls/cardComposition.d.ts +0 -9
  88. package/dist/src/extensions/Blocks/Items/controls/image/link.d.ts +2 -0
  89. package/dist/src/extensions/Blocks/Items/controls/price/priceOrientation.d.ts +1 -1
  90. package/dist/src/extensions/Blocks/Items/controls/settingsControl.d.ts +4 -0
  91. package/dist/src/extensions/Blocks/Items/enums/controlEnums.d.ts +0 -1
  92. package/dist/src/extensions/Blocks/Items/enums/productEnums.d.ts +26 -24
  93. package/dist/src/extensions/Blocks/Items/enums/settingsEnums.d.ts +0 -1
  94. package/dist/src/extensions/Blocks/Items/store/items-block.d.ts +0 -2
  95. package/dist/src/extensions/Blocks/Items/template.d.ts +1 -22
  96. package/dist/src/extensions/Blocks/Items/utils/configBlockUtils.d.ts +23 -0
  97. package/dist/src/extensions/Blocks/Items/utils/syncAttributeFromConfigBlock.d.ts +32 -0
  98. package/dist/src/extensions/Blocks/Items/utils/syncAttributesFromConfigBlock.d.ts +50 -0
  99. package/dist/src/extensions/Blocks/Items/utils/updateAttributes.d.ts +8 -0
  100. package/dist/src/extensions/Blocks/Recommendation/constants/blockIds.d.ts +13 -0
  101. package/dist/src/extensions/Blocks/Recommendation/{constants.d.ts → constants/controlIds.d.ts} +19 -11
  102. package/dist/src/extensions/Blocks/Recommendation/constants/index.d.ts +12 -0
  103. package/dist/src/extensions/Blocks/Recommendation/constants/layout.d.ts +17 -0
  104. package/dist/src/extensions/Blocks/Recommendation/constants/selectors.d.ts +19 -0
  105. package/dist/src/extensions/Blocks/Recommendation/controls/button/index.d.ts +143 -0
  106. package/dist/src/extensions/Blocks/Recommendation/controls/cardBackground/index.d.ts +41 -0
  107. package/dist/src/extensions/Blocks/Recommendation/controls/cardComposition/index.d.ts +95 -0
  108. package/dist/src/extensions/Blocks/Recommendation/controls/image/index.d.ts +35 -0
  109. package/dist/src/extensions/Blocks/Recommendation/controls/index.d.ts +24 -0
  110. package/dist/src/extensions/Blocks/Recommendation/controls/layout/index.d.ts +34 -0
  111. package/dist/src/extensions/Blocks/Recommendation/controls/main/algorithm.d.ts +17 -0
  112. package/dist/src/extensions/Blocks/Recommendation/controls/main/currency.d.ts +16 -0
  113. package/dist/src/extensions/Blocks/Recommendation/controls/main/filters.d.ts +22 -0
  114. package/dist/src/extensions/Blocks/Recommendation/controls/main/index.d.ts +54 -0
  115. package/dist/src/extensions/Blocks/Recommendation/controls/main/locale.d.ts +15 -0
  116. package/dist/src/extensions/Blocks/Recommendation/controls/main/productLayout.d.ts +40 -0
  117. package/dist/src/extensions/Blocks/Recommendation/controls/main/shuffle.d.ts +15 -0
  118. package/dist/src/extensions/Blocks/Recommendation/controls/main/utils.d.ts +81 -0
  119. package/dist/src/extensions/Blocks/Recommendation/controls/name/index.d.ts +97 -0
  120. package/dist/src/extensions/Blocks/Recommendation/controls/name/textTrim.d.ts +16 -0
  121. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/index.d.ts +95 -0
  122. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusDiscount/index.d.ts +100 -0
  123. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusDiscount/textAfter.d.ts +15 -0
  124. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusDiscount/textBefore.d.ts +15 -0
  125. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusPrice/index.d.ts +100 -0
  126. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusPrice/textAfter.d.ts +15 -0
  127. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusPrice/textBefore.d.ts +15 -0
  128. package/dist/src/extensions/Blocks/Recommendation/controls/price/index.d.ts +95 -0
  129. package/dist/src/extensions/Blocks/Recommendation/controls/spacing/index.d.ts +77 -0
  130. package/dist/src/extensions/Blocks/Recommendation/extension.d.ts +9 -0
  131. package/dist/src/extensions/Blocks/Recommendation/store/recommendation.d.ts +16 -16
  132. package/dist/src/extensions/Blocks/Recommendation/templates/horizontal/elementRenderer.d.ts +8 -0
  133. package/dist/src/extensions/Blocks/Recommendation/templates/horizontal/migration.d.ts +25 -0
  134. package/dist/src/extensions/Blocks/Recommendation/templates/horizontal/template.d.ts +18 -0
  135. package/dist/src/extensions/Blocks/Recommendation/templates/index.d.ts +39 -0
  136. package/dist/src/extensions/Blocks/Recommendation/templates/utils.d.ts +45 -0
  137. package/dist/src/extensions/Blocks/Recommendation/templates/vertical/elementRenderer.d.ts +7 -0
  138. package/dist/src/extensions/Blocks/Recommendation/templates/{migrationTemplate.d.ts → vertical/migration.d.ts} +11 -4
  139. package/dist/src/extensions/Blocks/Recommendation/templates/vertical/template.d.ts +33 -0
  140. package/dist/src/extensions/Blocks/Recommendation/utils/preserveTextStyles.d.ts +19 -0
  141. package/dist/src/extensions/Blocks/common-control.d.ts +10 -9
  142. package/dist/src/stores/config.d.ts +1 -147
  143. package/dist/static/styles/components/button.css.js +1 -1
  144. package/dist/static/styles/components/wide-panel.css.js +0 -4
  145. package/dist/static/styles/customEditorStyle.css.js +38 -2
  146. package/dist/stores/config.js +0 -7
  147. package/dist/utils/pairProductVariables.js +58 -61
  148. package/package.json +1 -1
  149. package/dist/config/migrator/itemsBlockMigrator.js +0 -342
  150. package/dist/extensions/Blocks/Items/controls/price/singlePrice.js +0 -93
  151. package/dist/extensions/Blocks/Items/utils/nodeConfigUtils.js +0 -184
  152. package/dist/extensions/Blocks/Recommendation/cardCompositionControl.js +0 -103
  153. package/dist/extensions/Blocks/Recommendation/constants.js +0 -5
  154. package/dist/extensions/Blocks/Recommendation/control.js +0 -306
  155. package/dist/extensions/Blocks/Recommendation/controls/button/align.js +0 -13
  156. package/dist/extensions/Blocks/Recommendation/controls/button/border.js +0 -13
  157. package/dist/extensions/Blocks/Recommendation/controls/button/borderRadius.js +0 -13
  158. package/dist/extensions/Blocks/Recommendation/controls/button/color.js +0 -13
  159. package/dist/extensions/Blocks/Recommendation/controls/button/fitToContent.js +0 -13
  160. package/dist/extensions/Blocks/Recommendation/controls/button/fontFamily.js +0 -13
  161. package/dist/extensions/Blocks/Recommendation/controls/button/margins.js +0 -13
  162. package/dist/extensions/Blocks/Recommendation/controls/button/paddings.js +0 -13
  163. package/dist/extensions/Blocks/Recommendation/controls/button/text.js +0 -13
  164. package/dist/extensions/Blocks/Recommendation/controls/button/textSize.js +0 -13
  165. package/dist/extensions/Blocks/Recommendation/controls/button/textStyleAndFontColor.js +0 -13
  166. package/dist/extensions/Blocks/Recommendation/controls/image/margins.js +0 -13
  167. package/dist/extensions/Blocks/Recommendation/controls/image/size.js +0 -13
  168. package/dist/extensions/Blocks/Recommendation/controls/name/align.js +0 -13
  169. package/dist/extensions/Blocks/Recommendation/controls/name/background.js +0 -13
  170. package/dist/extensions/Blocks/Recommendation/controls/name/color.js +0 -13
  171. package/dist/extensions/Blocks/Recommendation/controls/name/fontFamily.js +0 -13
  172. package/dist/extensions/Blocks/Recommendation/controls/name/paddings.js +0 -13
  173. package/dist/extensions/Blocks/Recommendation/controls/name/size.js +0 -13
  174. package/dist/extensions/Blocks/Recommendation/controls/name/style.js +0 -13
  175. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/align.js +0 -13
  176. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/background.js +0 -13
  177. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/color.js +0 -13
  178. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/fontFamily.js +0 -13
  179. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/paddings.js +0 -13
  180. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/size.js +0 -13
  181. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/style.js +0 -13
  182. package/dist/extensions/Blocks/Recommendation/controls/price/align.js +0 -13
  183. package/dist/extensions/Blocks/Recommendation/controls/price/background.js +0 -13
  184. package/dist/extensions/Blocks/Recommendation/controls/price/color.js +0 -13
  185. package/dist/extensions/Blocks/Recommendation/controls/price/fontFamily.js +0 -13
  186. package/dist/extensions/Blocks/Recommendation/controls/price/paddings.js +0 -13
  187. package/dist/extensions/Blocks/Recommendation/controls/price/size.js +0 -13
  188. package/dist/extensions/Blocks/Recommendation/controls/price/style.js +0 -13
  189. package/dist/extensions/Blocks/Recommendation/templates/blockTemplate.js +0 -160
  190. package/dist/extensions/Blocks/Recommendation/templates/migrationTemplate.js +0 -152
  191. package/dist/extensions/Blocks/Recommendation/templates/templateUtils.js +0 -180
  192. package/dist/src/config/migrator/itemsBlockMigrator.d.ts +0 -6
  193. package/dist/src/extensions/Blocks/Items/controls/price/singlePrice.d.ts +0 -18
  194. package/dist/src/extensions/Blocks/Items/utils/nodeConfigUtils.d.ts +0 -73
  195. package/dist/src/extensions/Blocks/Recommendation/cardCompositionControl.d.ts +0 -28
  196. package/dist/src/extensions/Blocks/Recommendation/control.d.ts +0 -35
  197. package/dist/src/extensions/Blocks/Recommendation/controls/button/align.d.ts +0 -5
  198. package/dist/src/extensions/Blocks/Recommendation/controls/button/border.d.ts +0 -5
  199. package/dist/src/extensions/Blocks/Recommendation/controls/button/borderRadius.d.ts +0 -5
  200. package/dist/src/extensions/Blocks/Recommendation/controls/button/color.d.ts +0 -5
  201. package/dist/src/extensions/Blocks/Recommendation/controls/button/fitToContent.d.ts +0 -5
  202. package/dist/src/extensions/Blocks/Recommendation/controls/button/fontFamily.d.ts +0 -5
  203. package/dist/src/extensions/Blocks/Recommendation/controls/button/margins.d.ts +0 -5
  204. package/dist/src/extensions/Blocks/Recommendation/controls/button/paddings.d.ts +0 -5
  205. package/dist/src/extensions/Blocks/Recommendation/controls/button/text.d.ts +0 -5
  206. package/dist/src/extensions/Blocks/Recommendation/controls/button/textSize.d.ts +0 -5
  207. package/dist/src/extensions/Blocks/Recommendation/controls/button/textStyleAndFontColor.d.ts +0 -5
  208. package/dist/src/extensions/Blocks/Recommendation/controls/image/margins.d.ts +0 -5
  209. package/dist/src/extensions/Blocks/Recommendation/controls/image/size.d.ts +0 -5
  210. package/dist/src/extensions/Blocks/Recommendation/controls/name/align.d.ts +0 -5
  211. package/dist/src/extensions/Blocks/Recommendation/controls/name/background.d.ts +0 -5
  212. package/dist/src/extensions/Blocks/Recommendation/controls/name/color.d.ts +0 -5
  213. package/dist/src/extensions/Blocks/Recommendation/controls/name/fontFamily.d.ts +0 -5
  214. package/dist/src/extensions/Blocks/Recommendation/controls/name/paddings.d.ts +0 -5
  215. package/dist/src/extensions/Blocks/Recommendation/controls/name/size.d.ts +0 -5
  216. package/dist/src/extensions/Blocks/Recommendation/controls/name/style.d.ts +0 -5
  217. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/align.d.ts +0 -5
  218. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/background.d.ts +0 -5
  219. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/color.d.ts +0 -5
  220. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/fontFamily.d.ts +0 -5
  221. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/paddings.d.ts +0 -5
  222. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/size.d.ts +0 -5
  223. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/style.d.ts +0 -5
  224. package/dist/src/extensions/Blocks/Recommendation/controls/price/align.d.ts +0 -5
  225. package/dist/src/extensions/Blocks/Recommendation/controls/price/background.d.ts +0 -5
  226. package/dist/src/extensions/Blocks/Recommendation/controls/price/color.d.ts +0 -5
  227. package/dist/src/extensions/Blocks/Recommendation/controls/price/fontFamily.d.ts +0 -5
  228. package/dist/src/extensions/Blocks/Recommendation/controls/price/paddings.d.ts +0 -5
  229. package/dist/src/extensions/Blocks/Recommendation/controls/price/size.d.ts +0 -5
  230. package/dist/src/extensions/Blocks/Recommendation/controls/price/style.d.ts +0 -5
  231. package/dist/src/extensions/Blocks/Recommendation/templates/blockTemplate.d.ts +0 -16
  232. package/dist/src/extensions/Blocks/Recommendation/templates/templateUtils.d.ts +0 -44
@@ -1,52 +1,59 @@
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);
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
4
  import { CommonControl as u } from "../../../common-control.js";
5
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 = {
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 = {
9
10
  LINK: "link"
10
11
  };
11
- class N extends u {
12
+ class C extends u {
12
13
  constructor() {
13
14
  super(...arguments);
14
- i(this, "store", m());
15
+ s(this, "store", l());
15
16
  }
16
17
  getId() {
17
- return r;
18
+ return i;
18
19
  }
19
20
  getTemplate() {
20
21
  return `
21
- <div class="container ${r}">
22
+ <div class="${i}">
22
23
  ${this._getLink()}
23
24
  </div>
24
25
  `;
25
26
  }
26
27
  onRender() {
27
28
  this.api.updateValues({
28
- [s.LINK]: this.store.buttonLink
29
- });
29
+ [n.LINK]: this.store.buttonLink
30
+ }), this._listenToFormUpdates();
30
31
  }
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
- },
32
+ onTemplateNodeUpdated(t) {
33
+ super.onTemplateNodeUpdated(t), this.handleBlockInstanceChange(
34
+ () => h(this.currentNode),
37
35
  () => {
38
36
  this.api.updateValues({
39
- [s.LINK]: this.store.buttonLink
37
+ [n.LINK]: this.store.buttonLink
40
38
  });
41
39
  }
42
40
  );
43
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);
50
+ }
44
51
  _getLink() {
45
52
  return `
46
53
  ${this._GuOneColumn([
47
54
  this._GuLabel({ text: "Link" }),
48
55
  this._GuTextInput({
49
- name: s.LINK,
56
+ name: n.LINK,
50
57
  placeholder: "Enter Link",
51
58
  className: "es-100",
52
59
  disabled: !0
@@ -56,6 +63,6 @@ class N extends u {
56
63
  }
57
64
  }
58
65
  export {
59
- N as ButtonLinkControl,
60
- r as CONTROL_BLOCK_ID
66
+ C as ButtonLinkControl,
67
+ i as CONTROL_BLOCK_ID
61
68
  };
@@ -1,13 +1,14 @@
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);
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
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";
5
+ import { CommonControl as R } from "../../common-control.js";
6
6
  import { ItemsBlockId as s } from "../enums/controlEnums.js";
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 = {
7
+ import { configAttributes as C } from "../enums/productEnums.js";
8
+ 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 = {
11
12
  PRODUCT_IMAGE: "image",
12
13
  PRODUCT_NAME: "name",
13
14
  PRODUCT_QUANTITY: "quantity",
@@ -15,11 +16,11 @@ const b = "ui-elements-items-card-composition-block", i = {
15
16
  PRODUCT_ORIGINAL_PRICE: "originalPrice",
16
17
  PRODUCT_BUTTON: "button"
17
18
  };
18
- class S extends I {
19
+ class g extends R {
19
20
  constructor() {
20
21
  super(...arguments);
21
- P(this, "store", p());
22
- P(this, "visibilityState", {
22
+ _(this, "store", O());
23
+ _(this, "visibilityState", {
23
24
  [i.PRODUCT_IMAGE]: !0,
24
25
  [i.PRODUCT_NAME]: !0,
25
26
  [i.PRODUCT_QUANTITY]: !0,
@@ -29,7 +30,7 @@ class S extends I {
29
30
  });
30
31
  }
31
32
  getId() {
32
- return b;
33
+ return h;
33
34
  }
34
35
  getTemplate() {
35
36
  return `
@@ -82,20 +83,20 @@ class S extends I {
82
83
  });
83
84
  }
84
85
  _syncVisibilityFromAttributes() {
85
- const t = R(this.currentNode);
86
+ const t = P(this.currentNode);
86
87
  if (!t)
87
88
  return;
88
89
  const e = {
89
- [i.PRODUCT_IMAGE]: "imageVisible",
90
- [i.PRODUCT_NAME]: "nameVisible",
91
- [i.PRODUCT_QUANTITY]: "quantityControlEnabled",
92
- [i.PRODUCT_PRICE]: "priceVisible",
93
- [i.PRODUCT_ORIGINAL_PRICE]: "originalPriceVisible",
94
- [i.PRODUCT_BUTTON]: "buttonVisible"
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"
95
96
  };
96
- Object.entries(e).forEach(([o, n]) => {
97
- const c = t[n];
98
- this.visibilityState[o] = c !== !1;
97
+ Object.entries(e).forEach(([o, r]) => {
98
+ const T = t.getAttribute(C[r]);
99
+ this.visibilityState[o] = U(T, !0);
99
100
  });
100
101
  }
101
102
  /**
@@ -104,10 +105,11 @@ class S extends I {
104
105
  * and mark it as '0'
105
106
  */
106
107
  _handleBrowsedItemsQuantity() {
107
- const t = this.store.itemsType !== h.ITEMS_TYPE.BROWSED_ITEMS, e = R(this.currentNode);
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");
108
110
  if (!e)
109
111
  return;
110
- const o = e.quantityControlEnabled !== !1;
112
+ const o = e.getAttribute(C.PRODUCT_QUANTITY_VISIBLE) === "1";
111
113
  this.visibilityState[i.PRODUCT_QUANTITY] = t && o, this.api.setVisibility(`${i.PRODUCT_QUANTITY}Container`, t), this._updateVisibilityAttribute(i.PRODUCT_QUANTITY, t && o);
112
114
  }
113
115
  _applyVisibilityStyles() {
@@ -121,31 +123,41 @@ class S extends I {
121
123
  };
122
124
  Object.entries(t).forEach(([e, o]) => {
123
125
  var d;
124
- const n = (d = this.currentNode) == null ? void 0 : d.querySelector(`[esd-extension-block-id="${o}"]`);
125
- if (!n)
126
+ const r = (d = this.currentNode) == null ? void 0 : d.querySelector(`[esd-extension-block-id="${o}"]`);
127
+ if (!r)
126
128
  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();
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
+ });
130
132
  }
131
133
  _updateVisibilityAttribute(t, e) {
132
- const n = {
133
- [i.PRODUCT_IMAGE]: "imageVisible",
134
- [i.PRODUCT_NAME]: "nameVisible",
135
- [i.PRODUCT_QUANTITY]: "quantityControlEnabled",
136
- [i.PRODUCT_PRICE]: "priceVisible",
137
- [i.PRODUCT_ORIGINAL_PRICE]: "originalPriceVisible",
138
- [i.PRODUCT_BUTTON]: "buttonVisible"
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"
139
144
  }[t];
140
- n && U(this.currentNode, this.api, {
141
- [n]: e
142
- });
145
+ T && this.api.getDocumentModifier().modifyHtml(o).setAttribute(C[T], e ? "1" : "0").apply(new l(`Updated ${t} visibility attribute`));
143
146
  }
144
147
  _listenToFormUpdates() {
145
- this.api.onValueChanged(i.PRODUCT_IMAGE, (t) => this._onProductImageChange(t)), this.api.onValueChanged(i.PRODUCT_NAME, (t) => this._onProductNameChange(t)), this.api.onValueChanged(i.PRODUCT_QUANTITY, (t) => this._onProductQuantityChange(t)), this.api.onValueChanged(i.PRODUCT_PRICE, (t) => this._onProductPriceChange(t)), this.api.onValueChanged(
146
- i.PRODUCT_ORIGINAL_PRICE,
147
- (t) => this._onProductOriginalPriceChange(t)
148
- ), this.api.onValueChanged(i.PRODUCT_BUTTON, (t) => this._onProductButtonChange(t));
148
+ this.api.onValueChanged(i.PRODUCT_IMAGE, (t) => {
149
+ this._onProductImageChange(t);
150
+ }), this.api.onValueChanged(i.PRODUCT_NAME, (t) => {
151
+ this._onProductNameChange(t);
152
+ }), this.api.onValueChanged(i.PRODUCT_QUANTITY, (t) => {
153
+ this._onProductQuantityChange(t);
154
+ }), this.api.onValueChanged(i.PRODUCT_PRICE, (t) => {
155
+ this._onProductPriceChange(t);
156
+ }), this.api.onValueChanged(i.PRODUCT_ORIGINAL_PRICE, (t) => {
157
+ this._onProductOriginalPriceChange(t);
158
+ }), this.api.onValueChanged(i.PRODUCT_BUTTON, (t) => {
159
+ this._onProductButtonChange(t);
160
+ });
149
161
  }
150
162
  _onProductImageChange(t) {
151
163
  var o;
@@ -167,7 +179,7 @@ class S extends I {
167
179
  _onProductPriceChange(t) {
168
180
  var o;
169
181
  const e = (o = this.currentNode) == null ? void 0 : o.querySelector(`[esd-extension-block-id="${s.PRICE}"]`);
170
- e && (this.visibilityState[i.PRODUCT_PRICE] = t, this.api.getDocumentModifier().modifyHtml(e).setStyle("display", t ? "table-cell" : "none").apply(new l(`Product price visibility changed to ${t ? "visible" : "hidden"}`)), this._updateVisibilityAttribute(i.PRODUCT_PRICE, t), this._updatePriceCellWidthsForVerticalLayout());
182
+ 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));
171
183
  }
172
184
  _onProductOriginalPriceChange(t) {
173
185
  var o;
@@ -176,30 +188,7 @@ class S extends I {
176
188
  );
177
189
  e && (this.visibilityState[i.PRODUCT_ORIGINAL_PRICE] = t, this.api.getDocumentModifier().modifyHtml(e).setStyle("display", t ? "table-cell" : "none").apply(new l(
178
190
  `Product original price visibility changed to ${t ? "visible" : "hidden"}`
179
- )), this._updateVisibilityAttribute(i.PRODUCT_ORIGINAL_PRICE, t), this._updatePriceCellWidthsForVerticalLayout());
180
- }
181
- /**
182
- * Updates both price cell widths in vertical layout based on priceOrientation and visibility.
183
- * - When priceOrientation is 'vertical': both cells are 100% (stacked layout)
184
- * - When priceOrientation is 'horizontal':
185
- * - When original price is hidden, price cell expands to 100%
186
- * - When price is hidden, original price cell expands to 100%
187
- * - When both are visible, they share 50% each
188
- */
189
- _updatePriceCellWidthsForVerticalLayout() {
190
- var u, _;
191
- if (!(this.store.orientation === h.ORIENTATION.VERTICAL))
192
- return;
193
- const e = (u = this.currentNode) == null ? void 0 : u.querySelector(".product-price-class"), o = (_ = this.currentNode) == null ? void 0 : _.querySelector(".product-original-price-class"), n = this.store.priceOrientation === "vertical", c = this.visibilityState[i.PRODUCT_PRICE], d = this.visibilityState[i.PRODUCT_ORIGINAL_PRICE], T = this.api.getDocumentModifier();
194
- if (e) {
195
- const C = n || !d ? "100%" : "50%";
196
- T.modifyHtml(e).setStyle("width", C);
197
- }
198
- if (o) {
199
- const C = n || !c ? "100%" : "50%";
200
- T.modifyHtml(o).setStyle("width", C);
201
- }
202
- T.apply(new l("Updated price cell widths for vertical layout"));
191
+ )), this._updateVisibilityAttribute(i.PRODUCT_ORIGINAL_PRICE, t));
203
192
  }
204
193
  _onProductButtonChange(t) {
205
194
  var o;
@@ -208,6 +197,6 @@ class S extends I {
208
197
  }
209
198
  }
210
199
  export {
211
- b as COMPOSITION_CONTROL_BLOCK_ID,
212
- S as ItemsBlockCardCompositionControl
200
+ h as COMPOSITION_CONTROL_BLOCK_ID,
201
+ g as ItemsBlockCardCompositionControl
213
202
  };
@@ -1,52 +1,59 @@
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";
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
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 = {
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 = {
9
10
  LINK: "link"
10
11
  };
11
- class g extends l {
12
+ class N extends m {
12
13
  constructor() {
13
14
  super(...arguments);
14
- s(this, "store", L());
15
+ i(this, "store", l());
15
16
  }
16
17
  getId() {
17
- return r;
18
+ return s;
18
19
  }
19
20
  getTemplate() {
20
21
  return `
21
- <div class="container ${r}">
22
+ <div class="${s}">
22
23
  ${this._getLink()}
23
24
  </div>
24
25
  `;
25
26
  }
26
27
  onRender() {
27
28
  this.api.updateValues({
28
- [i.LINK]: this.store.imageLink
29
- });
29
+ [n.LINK]: this.store.imageLink
30
+ }), this._listenToFormUpdates();
30
31
  }
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
- },
32
+ onTemplateNodeUpdated(e) {
33
+ super.onTemplateNodeUpdated(e), this.handleBlockInstanceChange(
34
+ () => h(this.currentNode),
37
35
  () => {
38
36
  this.api.updateValues({
39
- [i.LINK]: this.store.imageLink
37
+ [n.LINK]: this.store.imageLink
40
38
  });
41
39
  }
42
40
  );
43
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);
50
+ }
44
51
  _getLink() {
45
52
  return `
46
53
  ${this._GuOneColumn([
47
54
  this._GuLabel({ text: "Link" }),
48
55
  this._GuTextInput({
49
- name: i.LINK,
56
+ name: n.LINK,
50
57
  placeholder: "Enter Link",
51
58
  className: "es-100",
52
59
  disabled: !0
@@ -56,6 +63,6 @@ class g extends l {
56
63
  }
57
64
  }
58
65
  export {
59
- r as CONTROL_BLOCK_ID,
60
- g as ImageLinkControl
66
+ s as CONTROL_BLOCK_ID,
67
+ N as ImageLinkControl
61
68
  };
@@ -1,65 +1,65 @@
1
1
  var d = Object.defineProperty;
2
- var g = (i, t, e) => t in i ? d(i, t, { enumerable: !0, configurable: !0, writable: !0, value: e }) : i[t] = e;
3
- var s = (i, t, e) => g(i, typeof t != "symbol" ? t + "" : t, e);
4
- import { ModificationDescription as a, UIElementType as l, UEAttr as h } from "../../../../../node_modules/@stripoinc/ui-editor-extensions/dist/esm/index.js";
2
+ var h = (i, t, e) => t in i ? d(i, t, { enumerable: !0, configurable: !0, writable: !0, value: e }) : i[t] = e;
3
+ var n = (i, t, e) => h(i, typeof t != "symbol" ? t + "" : t, e);
4
+ import { ModificationDescription as a, UIElementType as l, UEAttr as g } from "../../../../../node_modules/@stripoinc/ui-editor-extensions/dist/esm/index.js";
5
5
  import { CommonControl as c } from "../../../common-control.js";
6
6
  import { ItemsBlockControlId as p } from "../../enums/controlEnums.js";
7
7
  import { SETTINGS_ENUMS as I } from "../../enums/settingsEnums.js";
8
8
  import { useItemsBlockStore as N } from "../../store/items-block.js";
9
- import { getItemsBlockConfig as f, setItemsBlockConfig as M } from "../../utils/nodeConfigUtils.js";
10
- const y = p.NAME_TRIMMING, m = {
9
+ import { syncNameTrimmingFromAttributes as M } from "../../utils/syncAttributesFromConfigBlock.js";
10
+ import { updateConfigBlockAttributes as u } from "../../utils/updateAttributes.js";
11
+ const y = p.NAME_TRIMMING, o = {
11
12
  TRIMMING: "trimming"
12
13
  };
13
14
  class _ extends c {
14
15
  constructor() {
15
16
  super(...arguments);
16
- s(this, "store", N());
17
+ n(this, "store", N());
17
18
  }
18
19
  getId() {
19
20
  return y;
20
21
  }
21
22
  getTemplate() {
22
23
  return `
23
- <div class="container ${p.NAME_TRIMMING}">
24
+ <div class="${p.NAME_TRIMMING}">
24
25
  ${this._getTextTrimming()}
25
26
  </div>
26
27
  `;
27
28
  }
28
29
  onRender() {
29
- this.api.updateValues({ [m.TRIMMING]: this.store.nameTrimming }), this.api.onValueChanged(m.TRIMMING, (e) => {
30
+ this.api.updateValues({ [o.TRIMMING]: this.store.nameTrimming }), this.api.onValueChanged(o.TRIMMING, (e) => {
30
31
  this._onTrimmingChange(e);
31
32
  });
32
33
  }
33
34
  onTemplateNodeUpdated(e) {
34
35
  super.onTemplateNodeUpdated(e), this.handleBlockInstanceChange(
36
+ () => M(this.currentNode),
35
37
  () => {
36
- const o = f(this.currentNode);
37
- o && this.store.setNameTrimming(o.nameTrimming ?? !0);
38
- },
39
- () => {
40
- this.api.updateValues({ [m.TRIMMING]: this.store.nameTrimming });
38
+ this.api.updateValues({ [o.TRIMMING]: this.store.nameTrimming });
41
39
  }
42
40
  );
43
41
  }
44
42
  _onTrimmingChange(e) {
45
- this.store.setNameTrimming(e), M(this.currentNode, this.api, { nameTrimming: e }), this.api.updateValues({ [m.TRIMMING]: e }), this._applyTrimmingStyles(e);
43
+ this.store.setNameTrimming(e), u(this.currentNode, this.api), this.api.updateValues({ [o.TRIMMING]: e }), this._applyTrimmingStyles(e);
46
44
  }
47
45
  _applyTrimmingStyles(e) {
48
- var r;
49
- const o = (r = this.currentNode) == null ? void 0 : r.querySelector("p > a");
50
- if (!o)
46
+ var s;
47
+ const r = (s = this.currentNode) == null ? void 0 : s.querySelector("p > a");
48
+ if (!r)
51
49
  return;
52
- const T = e !== void 0 ? e : this.store.nameTrimming, n = this.store.orientation === I.ORIENTATION.VERTICAL;
53
- T ? this.api.getDocumentModifier().modifyHtml(o).setStyle("white-space", "nowrap").setStyle("overflow", "hidden").setStyle("text-overflow", "ellipsis").setStyle("max-width", n ? "130px" : "520px").apply(new a("Text Trimming Enabled")) : this.api.getDocumentModifier().modifyHtml(o).removeStyle("white-space").removeStyle("overflow").removeStyle("text-overflow").removeStyle("max-width").setStyle("max-width", n ? "130px" : "520px").apply(new a("Text Trimming Disabled"));
50
+ const T = e !== void 0 ? e : this.store.nameTrimming, m = this.store.orientation === I.ORIENTATION.VERTICAL;
51
+ T ? this.api.getDocumentModifier().modifyHtml(r).setStyle("white-space", "nowrap").setStyle("overflow", "hidden").setStyle("text-overflow", "ellipsis").setStyle("max-width", m ? "130px" : "520px").apply(new a("Text Trimming Enabled")) : this.api.getDocumentModifier().modifyHtml(r).removeStyle("white-space").removeStyle("overflow").removeStyle("text-overflow").removeStyle("max-width").setStyle("max-width", m ? "130px" : "520px").apply(new a("Text Trimming Disabled"));
54
52
  }
55
53
  _getTextTrimming() {
56
54
  return `
57
- <div class="display-flex align-items-center justify-content-between">
58
- <${l.LABEL}
59
- ${h.LABEL.text}="${this.api.translate("Text Trimming")}"
60
- >
61
- </${l.LABEL}>
62
- ${this._GuToggle(m.TRIMMING)}
55
+ <div class="container">
56
+ <div class="display-flex align-items-center justify-content-between">
57
+ <${l.LABEL}
58
+ ${g.LABEL.text}="${this.api.translate("Text Trimming")}"
59
+ >
60
+ </${l.LABEL}>
61
+ ${this._GuToggle(o.TRIMMING)}
62
+ </div>
63
63
  </div>
64
64
  `;
65
65
  }
@@ -1,48 +1,46 @@
1
- var y = Object.defineProperty;
2
- var R = (i, o, e) => o in i ? y(i, o, { enumerable: !0, configurable: !0, writable: !0, value: e }) : i[o] = e;
1
+ var L = Object.defineProperty;
2
+ var R = (i, o, e) => o in i ? L(i, o, { enumerable: !0, configurable: !0, writable: !0, value: e }) : i[o] = e;
3
3
  var p = (i, o, e) => R(i, typeof o != "symbol" ? o + "" : o, e);
4
4
  import { currencyLocationMaps as m } from "../../../../../enums/extensions/recommendationBlock.js";
5
- import { UEAttr as I, ModificationDescription as N } from "../../../../../node_modules/@stripoinc/ui-editor-extensions/dist/esm/index.js";
5
+ import { UEAttr as N, ModificationDescription as I } from "../../../../../node_modules/@stripoinc/ui-editor-extensions/dist/esm/index.js";
6
6
  import { CommonControl as T } from "../../../common-control.js";
7
7
  import { ItemsBlockControlId as h } from "../../enums/controlEnums.js";
8
- import { useItemsBlockStore as f } from "../../store/items-block.js";
9
- import { getItemsBlockConfig as E, setItemsBlockConfig as O } from "../../utils/nodeConfigUtils.js";
8
+ import { useItemsBlockStore as E } from "../../store/items-block.js";
9
+ import { syncCurrencyLocationFromAttributes as f } from "../../utils/syncAttributesFromConfigBlock.js";
10
+ import { updateConfigBlockAttributes as O } from "../../utils/updateAttributes.js";
10
11
  const b = h.PRICE_CURRENCY_LOCATION, a = {
11
12
  CURRENCY_LOCATION: "currencyLocation"
12
13
  };
13
- class B extends T {
14
+ class Y extends T {
14
15
  constructor() {
15
16
  super(...arguments);
16
- p(this, "store", f());
17
+ p(this, "store", E());
17
18
  }
18
19
  getId() {
19
20
  return b;
20
21
  }
21
22
  getTemplate() {
22
23
  return `
23
- <div class="container ${h.PRICE_CURRENCY_LOCATION}">
24
+ <div class="${h.PRICE_CURRENCY_LOCATION}">
24
25
  ${this._getCurrencyLocation()}
25
26
  </div>
26
27
  `;
27
28
  }
28
29
  onRender() {
29
- this.api.setUIEAttribute(a.CURRENCY_LOCATION, I.SELECTPICKER.items, m), this.api.updateValues({ [a.CURRENCY_LOCATION]: this.store.currencyLocation }), this.api.onValueChanged(a.CURRENCY_LOCATION, (e) => {
30
+ this.api.setUIEAttribute(a.CURRENCY_LOCATION, N.SELECTPICKER.items, m), this.api.updateValues({ [a.CURRENCY_LOCATION]: this.store.currencyLocation }), this.api.onValueChanged(a.CURRENCY_LOCATION, (e) => {
30
31
  this._onCurrencyLocationChange(e);
31
32
  });
32
33
  }
33
34
  onTemplateNodeUpdated(e) {
34
35
  super.onTemplateNodeUpdated(e), this.handleBlockInstanceChange(
35
- () => {
36
- const t = E(this.currentNode);
37
- t && this.store.setCurrencyLocation(t.priceCurrencyLocation || "0");
38
- },
36
+ () => f(this.currentNode),
39
37
  () => {
40
38
  this.api.updateValues({ [a.CURRENCY_LOCATION]: this.store.currencyLocation });
41
39
  }
42
40
  );
43
41
  }
44
42
  _onCurrencyLocationChange(e) {
45
- if (console.debug("Currency location changed to: ", e), this.store.setCurrencyLocation(e), O(this.currentNode, this.api, { priceCurrencyLocation: e }), !this.currentNode)
43
+ if (console.debug("Currency location changed to: ", e), this.store.setCurrencyLocation(e), O(this.currentNode, this.api), !this.currentNode)
46
44
  return;
47
45
  const t = this._getPriceBlocks();
48
46
  if (!t || t.length === 0)
@@ -52,8 +50,8 @@ class B extends T {
52
50
  const s = this._getParagraph(c);
53
51
  if (!s)
54
52
  return;
55
- const C = s.getInnerHTML() || "", l = s.getInnerText() || "", u = (n == null ? void 0 : n.trim()) || "", d = this._removeCurrencySymbol(l, u), g = this._detectSymbolInText(l) || u, _ = this._buildPriceContent(d, g, r), L = C.replace(l, _);
56
- this.api.getDocumentModifier().modifyHtml(s).setInnerHtml(L).apply(new N(
53
+ const u = s.getInnerHTML() || "", l = s.getInnerText() || "", C = (n == null ? void 0 : n.trim()) || "", d = this._removeCurrencySymbol(l, C), g = this._detectSymbolInText(l) || C, _ = this._buildPriceContent(d, g, r), y = u.replace(l, _);
54
+ this.api.getDocumentModifier().modifyHtml(s).setInnerHtml(y).apply(new I(
57
55
  `Updated currency location to ${r === "1" ? "after" : "before"}`
58
56
  ));
59
57
  });
@@ -77,8 +75,8 @@ class B extends T {
77
75
  } else {
78
76
  const c = r.match(/([^0-9.,\s]+)/);
79
77
  if (c && c[1]) {
80
- const s = c[1].trim(), C = new RegExp(`\\s*${this._escapeRegex(s)}\\s*`);
81
- n = r.replace(C, "").trim();
78
+ const s = c[1].trim(), u = new RegExp(`\\s*${this._escapeRegex(s)}\\s*`);
79
+ n = r.replace(u, "").trim();
82
80
  }
83
81
  }
84
82
  return n;
@@ -105,5 +103,5 @@ class B extends T {
105
103
  }
106
104
  export {
107
105
  b as CONTROL_BLOCK_ID,
108
- B as PriceCurrencyLocationControl
106
+ Y as PriceCurrencyLocationControl
109
107
  };