@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,29 +1,20 @@
1
- var M = Object.defineProperty;
2
- var D = (h, p, e) => p in h ? M(h, p, { enumerable: !0, configurable: !0, writable: !0, value: e }) : h[p] = e;
3
- var b = (h, p, e) => D(h, typeof p != "symbol" ? p + "" : p, e);
4
- import { UEAttr as A, ModificationDescription as d } from "../../../../node_modules/@stripoinc/ui-editor-extensions/dist/esm/index.js";
5
- import { CommonControl as x } from "../../common-control.js";
6
- import { ItemsBlockId as l } from "../enums/controlEnums.js";
7
- import { productPairs as T, templateFirstLine as R } from "../enums/productEnums.js";
8
- import { ItemTypeOptions as P, OrientationOptions as L, ItemInCartOptions as N, SETTINGS_ENUMS as S, DefaultConfigValues as H } from "../enums/settingsEnums.js";
9
- import U from "../layouts/horizontal.html.js";
1
+ import { UEAttr as P, ModificationDescription as h } from "../../../../node_modules/@stripoinc/ui-editor-extensions/dist/esm/index.js";
2
+ import { CommonControl as U } from "../../common-control.js";
3
+ import { ItemsBlockId as I } from "../enums/controlEnums.js";
4
+ import { productPairs as S, templateFirstLine as M } from "../enums/productEnums.js";
5
+ import { SETTINGS_ENUMS as d, ItemTypeOptions as b, OrientationOptions as f, ItemInCartOptions as R, DefaultConfigValues as L } from "../enums/settingsEnums.js";
6
+ import H from "../layouts/horizontal.html.js";
10
7
  import F from "../layouts/vertical.html.js";
11
- import { useItemsBlockStore as $ } from "../store/items-block.js";
12
- import { getDefaultTemplate as q } from "../template.js";
13
- import { syncCurrencySymbolFromAttributes as k, syncCurrencyLocationFromAttributes as w, syncFormattedPriceFromAttributes as B } from "../utils/syncAttributesFromConfigBlock.js";
14
- import { updateConfigBlockAttributes as f } from "../utils/updateAttributes.js";
15
- const G = "ui-elements-items-block", s = {
8
+ import { getDefaultTemplate as k } from "../template.js";
9
+ import { getItemsBlockConfig as E, setItemsBlockConfig as O, escapeReplacement as A } from "../utils/nodeConfigUtils.js";
10
+ const $ = "ui-elements-items-block", l = {
16
11
  ITEMS_TYPE: "itemsType",
17
12
  ORIENTATION: "orientation",
18
13
  ITEM_IDS: "itemIds"
19
14
  };
20
- class te extends x {
21
- constructor() {
22
- super(...arguments);
23
- b(this, "store", $());
24
- }
15
+ class X extends U {
25
16
  getId() {
26
- return G;
17
+ return $;
27
18
  }
28
19
  getTemplate() {
29
20
  return `
@@ -35,39 +26,32 @@ class te extends x {
35
26
  `;
36
27
  }
37
28
  onRender() {
29
+ const e = E(this.currentNode);
38
30
  this.api.updateValues({
39
- [s.ORIENTATION]: this.store.orientation,
40
- [s.ITEMS_TYPE]: this.store.itemsType,
41
- [s.ITEM_IDS]: this.store.itemIds
31
+ [l.ORIENTATION]: (e == null ? void 0 : e.orientation) ?? d.ORIENTATION.VERTICAL,
32
+ [l.ITEMS_TYPE]: (e == null ? void 0 : e.type) ?? d.ITEMS_TYPE.CART_ITEMS,
33
+ [l.ITEM_IDS]: (e == null ? void 0 : e.itemsSelectValue) ?? ""
42
34
  }), this._listenToFormUpdates();
43
35
  }
44
36
  onTemplateNodeUpdated(e) {
45
- super.onTemplateNodeUpdated(e), this.handleBlockInstanceChange(
46
- () => {
47
- k(this.currentNode), w(this.currentNode), B(this.currentNode);
48
- },
49
- () => {
50
- this.api.updateValues({
51
- [s.ORIENTATION]: this.store.orientation,
52
- [s.ITEMS_TYPE]: this.store.itemsType,
53
- [s.ITEM_IDS]: this.store.itemIds
54
- }), this._initializeSelectItems();
55
- }
56
- );
57
- }
58
- onDestroy() {
59
- const e = this._getTemplateData();
60
- this.store.setTemplateData(e);
37
+ super.onTemplateNodeUpdated(e), console.debug("Items Block Config", e.getNodeConfig()), this.handleBlockInstanceChange(() => {
38
+ const t = E(this.currentNode);
39
+ this.api.updateValues({
40
+ [l.ORIENTATION]: (t == null ? void 0 : t.orientation) ?? d.ORIENTATION.VERTICAL,
41
+ [l.ITEMS_TYPE]: (t == null ? void 0 : t.type) ?? d.ITEMS_TYPE.CART_ITEMS,
42
+ [l.ITEM_IDS]: (t == null ? void 0 : t.itemsSelectValue) ?? ""
43
+ }), this._initializeSelectItems();
44
+ });
61
45
  }
62
46
  _getItemsType() {
63
47
  return `
64
48
  ${this._GuOneColumn([
65
49
  this._GuLabel({ text: "Item Type" }),
66
50
  this._GuSelect({
67
- name: s.ITEMS_TYPE,
51
+ name: l.ITEMS_TYPE,
68
52
  className: "es-100",
69
53
  placeholder: "Select Item Type",
70
- options: P
54
+ options: b
71
55
  })
72
56
  ])}
73
57
  `;
@@ -77,8 +61,8 @@ class te extends x {
77
61
  ${this._GuTwoColumns([
78
62
  this._GuLabel({ text: "Orientation" }),
79
63
  this._GuRadioButton({
80
- name: s.ORIENTATION,
81
- buttons: L
64
+ name: l.ORIENTATION,
65
+ buttons: f
82
66
  })
83
67
  ])}
84
68
  `;
@@ -88,7 +72,7 @@ class te extends x {
88
72
  ${this._GuTwoColumns([
89
73
  this._GuLabel({ text: "Item in Cart" }),
90
74
  this._GuSelect({
91
- name: s.ITEM_IDS,
75
+ name: l.ITEM_IDS,
92
76
  className: "es-100",
93
77
  placeholder: "Select Item In Cart",
94
78
  options: []
@@ -97,189 +81,213 @@ class te extends x {
97
81
  `;
98
82
  }
99
83
  _onOrientationChange(e) {
100
- console.debug("Orientation changed to: ", e), this.store.setOrientation(e), this.store.setPriceOrientation("horizontal"), this.api.updateValues({ [s.ORIENTATION]: e }), f(this.currentNode, this.api), this._reOrderTemplate(), setTimeout(() => {
84
+ this.api.updateValues({ [l.ORIENTATION]: e }), O(this.currentNode, this.api, {
85
+ orientation: e,
86
+ priceOrientation: "horizontal"
87
+ }), this._reOrderTemplate(), setTimeout(() => {
101
88
  this._recalculateTrimming();
102
89
  }, 50);
103
90
  }
104
91
  _onItemsTypeChange(e) {
105
- const i = S.ITEMS_TYPE[e], t = N[e], r = t == null ? void 0 : t[0];
106
- !i || !r || (this.store.setItemsType(i), this.store.setItemIds(r.value), f(this.currentNode, this.api), this._updateDataTypeAttributes(i), this._initializeSelectItems(), this._reFillTemplate());
92
+ const t = d.ITEMS_TYPE[e], r = R[e], i = r == null ? void 0 : r[0];
93
+ if (!t || !i)
94
+ return;
95
+ const n = i.value, o = i.value.replace("Url}}", "Image}}");
96
+ O(this.currentNode, this.api, {
97
+ source: t,
98
+ type: t,
99
+ itemsSelectValue: i.value,
100
+ imageLink: o,
101
+ buttonLink: n
102
+ }), this._updateDataTypeAttributes(t), this._initializeSelectItems(), this._reFillTemplate(t);
107
103
  }
108
104
  _onItemIdsChange(e) {
109
- console.debug("Item ids changed to: ", e), this.store.setItemIds(e), this.api.updateValues({ [s.ITEM_IDS]: e }), f(this.currentNode, this.api), this._updateDataNumberAttributes(e), this._reFillTemplate();
105
+ this.api.updateValues({ [l.ITEM_IDS]: e });
106
+ const t = e, r = e.replace("Url}}", "Image}}");
107
+ O(this.currentNode, this.api, {
108
+ itemsSelectValue: e,
109
+ imageLink: r,
110
+ buttonLink: t
111
+ }), this._updateDataNumberAttributes(e), this._reFillTemplate();
110
112
  }
111
113
  _initializeSelectItems() {
112
114
  this.api.setUIEAttribute(
113
- s.ITEMS_TYPE,
114
- A.SELECTPICKER.items,
115
- P
115
+ l.ITEMS_TYPE,
116
+ P.SELECTPICKER.items,
117
+ b
116
118
  );
117
- const { itemsType: e, itemIds: i } = this.store;
119
+ const e = E(this.currentNode), t = (e == null ? void 0 : e.type) ?? d.ITEMS_TYPE.CART_ITEMS, r = (e == null ? void 0 : e.itemsSelectValue) ?? "";
118
120
  this.api.updateValues({
119
- [s.ITEMS_TYPE]: e
121
+ [l.ITEMS_TYPE]: t
120
122
  });
121
- const t = N[e];
123
+ const i = R[t];
122
124
  this.api.setUIEAttribute(
123
- s.ITEM_IDS,
124
- A.SELECTPICKER.items,
125
- t
125
+ l.ITEM_IDS,
126
+ P.SELECTPICKER.items,
127
+ i
126
128
  ), this.api.updateValues({
127
- [s.ITEM_IDS]: i
129
+ [l.ITEM_IDS]: r
128
130
  });
129
131
  }
130
132
  _listenToFormUpdates() {
131
133
  this.api.onValueChanged(
132
- s.ITEMS_TYPE,
134
+ l.ITEMS_TYPE,
133
135
  (e) => this._onItemsTypeChange(e)
134
136
  ), this.api.onValueChanged(
135
- s.ORIENTATION,
137
+ l.ORIENTATION,
136
138
  (e) => this._onOrientationChange(e)
137
139
  ), this.api.onValueChanged(
138
- s.ITEM_IDS,
140
+ l.ITEM_IDS,
139
141
  (e) => this._onItemIdsChange(e)
140
142
  );
141
143
  }
142
144
  _renderTemplate() {
143
- const {
144
- orientation: e,
145
- itemsType: i,
146
- itemIds: t,
147
- currencySymbol: r,
148
- currencyLocation: n,
149
- formattedPrice: o
150
- } = this.store;
151
- this.api.getDocumentModifier().modifyHtml(this.currentNode).setInnerHtml(q({
152
- orientation: e,
153
- itemsType: i,
154
- itemId: t,
155
- currencySymbol: r,
156
- currencyLocation: n,
157
- formattedPrice: o
158
- })).apply(new d("Updated template"));
145
+ const e = E(this.currentNode), t = (e == null ? void 0 : e.orientation) ?? d.ORIENTATION.VERTICAL, r = (e == null ? void 0 : e.type) ?? d.ITEMS_TYPE.CART_ITEMS, i = (e == null ? void 0 : e.itemsSelectValue) ?? "", n = (e == null ? void 0 : e.priceCurrencySymbol) ?? "", o = (e == null ? void 0 : e.priceCurrencyLocation) ?? "0", a = (e == null ? void 0 : e.priceFormatted) ?? !1;
146
+ this.api.getDocumentModifier().modifyHtml(this.currentNode).setInnerHtml(k({
147
+ orientation: t,
148
+ itemsType: r,
149
+ itemId: i,
150
+ currencySymbol: n,
151
+ currencyLocation: o,
152
+ formattedPrice: a
153
+ })).apply(new h("Updated template"));
159
154
  }
160
- _getTemplateData() {
161
- const { itemsType: e, itemIds: i, formattedPrice: t } = this.store, r = N[e].findIndex((o) => o.value === i), n = r > -1 ? r : 0;
162
- return {
163
- imageSrc: T.PAIRS_FOR_EXTENSION.imageSrc[e].DEFAULT[n],
164
- name: T.PAIRS_FOR_EXTENSION.name[e].DEFAULT[n],
165
- price: t ? T.PAIRS_FOR_EXTENSION.price[e].DEFAULT_PRICE_FORMATTED : T.PAIRS_FOR_EXTENSION.price[e].DEFAULT_PRICE,
166
- originalPrice: t ? T.PAIRS_FOR_EXTENSION.originalPrice[e].DEFAULT_PRICE_FORMATTED : T.PAIRS_FOR_EXTENSION.originalPrice[e].DEFAULT_PRICE,
167
- quantity: T.PAIRS_FOR_EXTENSION.quantity[e].DEFAULT,
168
- button: T.PAIRS_FOR_EXTENSION.button[e].DEFAULT_LABEL
155
+ _getTemplateData(e) {
156
+ const t = E(this.currentNode), r = e ?? (t == null ? void 0 : t.type) ?? d.ITEMS_TYPE.CART_ITEMS, i = (t == null ? void 0 : t.itemsSelectValue) ?? "", n = (t == null ? void 0 : t.priceFormatted) ?? !1, o = (t == null ? void 0 : t.priceSinglePrice) ?? !1, a = R[r].findIndex((T) => T.value === i), c = a > -1 ? a : 0, s = S.PAIRS_FOR_EXTENSION.price[r], m = S.PAIRS_FOR_EXTENSION.originalPrice[r];
157
+ let u, p;
158
+ return o ? (u = n ? s.DEFAULT_SINGLE_PRICE_FORMATTED : s.DEFAULT_SINGLE_PRICE, p = n ? m.DEFAULT_SINGLE_PRICE_FORMATTED : m.DEFAULT_SINGLE_PRICE) : (u = n ? s.DEFAULT_PRICE_FORMATTED : s.DEFAULT_PRICE, p = n ? m.DEFAULT_PRICE_FORMATTED : m.DEFAULT_PRICE), {
159
+ imageSrc: S.PAIRS_FOR_EXTENSION.imageSrc[r].DEFAULT[c],
160
+ name: S.PAIRS_FOR_EXTENSION.name[r].DEFAULT[c],
161
+ price: u,
162
+ originalPrice: p,
163
+ quantity: S.PAIRS_FOR_EXTENSION.quantity[r].DEFAULT,
164
+ button: S.PAIRS_FOR_EXTENSION.button[r].DEFAULT_LABEL
169
165
  };
170
166
  }
171
167
  _updateImageSrc(e) {
172
- var t;
173
- const i = (t = this.currentNode) == null ? void 0 : t.querySelector(`[esd-extension-block-id="${l.IMAGE}"] img`);
174
- i && this.api.getDocumentModifier().modifyHtml(i).setAttribute("src", e).apply(new d("Updated image src"));
168
+ var r;
169
+ const t = (r = this.currentNode) == null ? void 0 : r.querySelector(`[esd-extension-block-id="${I.IMAGE}"] img`);
170
+ t && this.api.getDocumentModifier().modifyHtml(t).setAttribute("src", e).apply(new h("Updated image src"));
175
171
  }
176
172
  _updateName(e) {
177
173
  var n;
178
- const i = (n = this.currentNode) == null ? void 0 : n.querySelector(`[esd-extension-block-id="${l.NAME}"]`);
179
- if (!i)
174
+ const t = (n = this.currentNode) == null ? void 0 : n.querySelector(`[esd-extension-block-id="${I.NAME}"]`);
175
+ if (!t)
180
176
  return;
181
- const t = i.getInnerText().trim();
182
- let r = i.getInnerHTML();
183
- r = r.replace(t, e), this.api.getDocumentModifier().modifyHtml(i).setInnerHtml(r).apply(new d("Updated name"));
177
+ const r = t.getInnerText().trim();
178
+ let i = t.getInnerHTML().trim();
179
+ i = i.replace(r, A(e)), this.api.getDocumentModifier().modifyHtml(t).setInnerHtml(i).apply(new h("Updated name"));
184
180
  }
185
181
  _updatePrice(e) {
186
- var g;
187
- const i = (g = this.currentNode) == null ? void 0 : g.querySelector(`[esd-extension-block-id="${l.PRICE}"]`);
188
- if (!i)
189
- return;
190
- const t = this._getParagraphFromBlock(i);
191
- if (!t)
192
- return;
193
- const r = t.getInnerHTML() || "", n = t.getInnerText() || "", { currencySymbol: o, currencyLocation: a } = this.store, c = (o == null ? void 0 : o.trim()) || "", m = this._removeCurrencySymbol(n, c), u = this._replacePriceNumber(m, e), I = this._buildPriceContent(u, c, a), _ = r.replace(n, I);
194
- this.api.getDocumentModifier().modifyHtml(t).setInnerHtml(_).apply(new d("Updated price"));
182
+ var o;
183
+ const t = ((o = this.currentNode) == null ? void 0 : o.querySelectorAll(
184
+ `[esd-extension-block-id="${I.PRICE}"]`
185
+ )) || [], r = E(this.currentNode), i = (r == null ? void 0 : r.priceCurrencySymbol) ?? "", n = (r == null ? void 0 : r.priceCurrencyLocation) ?? "0";
186
+ t.forEach((a) => {
187
+ const c = this._getParagraphFromBlock(a);
188
+ if (!c)
189
+ return;
190
+ const s = c.getInnerHTML().trim() || "", m = c.getInnerText().trim() || "", u = (i == null ? void 0 : i.trim()) || "", p = this._removeCurrencySymbol(m, u), T = this._replacePriceNumber(p, e), _ = this._buildPriceContent(T, u, n), y = s.replace(m, A(_));
191
+ this.api.getDocumentModifier().modifyHtml(c).setInnerHtml(y).apply(new h("Updated price"));
192
+ });
195
193
  }
196
194
  _updateOriginalPrice(e) {
197
- var y;
198
- const i = (y = this.currentNode) == null ? void 0 : y.querySelector(
199
- `[esd-extension-block-id="${l.ORIGINAL_PRICE}"]`
200
- );
201
- if (!i)
202
- return;
203
- const t = this._getParagraphFromBlock(i);
204
- if (!t)
205
- return;
206
- const r = t.querySelector("s");
207
- if (!r)
208
- return;
209
- const n = r.getInnerHTML() || "", o = r.getInnerText() || "", { currencySymbol: a, currencyLocation: c } = this.store, m = (a == null ? void 0 : a.trim()) || "", u = this._removeCurrencySymbol(o, m), I = this._replacePriceNumber(u, e), _ = this._buildPriceContent(I, m, c), E = `<s>${n.replace(o, _)}</s>`;
210
- this.api.getDocumentModifier().modifyHtml(t).setInnerHtml(E).apply(new d("Updated original price"));
195
+ var o;
196
+ const t = ((o = this.currentNode) == null ? void 0 : o.querySelectorAll(
197
+ `[esd-extension-block-id="${I.ORIGINAL_PRICE}"]`
198
+ )) || [], r = E(this.currentNode), i = (r == null ? void 0 : r.priceCurrencySymbol) ?? "", n = (r == null ? void 0 : r.priceCurrencyLocation) ?? "0";
199
+ t.forEach((a) => {
200
+ const c = this._getParagraphFromBlock(a);
201
+ if (!c)
202
+ return;
203
+ const s = c.querySelector("s");
204
+ if (!s)
205
+ return;
206
+ const m = s.getInnerHTML().trim() || "", u = s.getInnerText().trim() || "", p = (i == null ? void 0 : i.trim()) || "", T = this._removeCurrencySymbol(u, p), _ = this._replacePriceNumber(T, e), y = this._buildPriceContent(_, p, n), N = `<s>${m.replace(u, A(y))}</s>`;
207
+ this.api.getDocumentModifier().modifyHtml(c).setInnerHtml(N).apply(new h("Updated original price"));
208
+ });
211
209
  }
212
- _updateQuantity(e) {
213
- var a;
214
- const i = this.store.itemsType !== S.ITEMS_TYPE.BROWSED_ITEMS, t = (a = this.currentNode) == null ? void 0 : a.querySelector(`[esd-extension-block-id="${l.QUANTITY}"]`);
215
- if (!t)
210
+ _updateQuantity(e, t) {
211
+ var _;
212
+ const r = E(this.currentNode), n = (t ?? (r == null ? void 0 : r.type) ?? d.ITEMS_TYPE.CART_ITEMS) !== d.ITEMS_TYPE.BROWSED_ITEMS, o = (r == null ? void 0 : r.quantityControlEnabled) !== !1, a = n && o, c = (_ = this.currentNode) == null ? void 0 : _.querySelector(`[esd-extension-block-id="${I.QUANTITY}"]`);
213
+ if (!c)
214
+ return;
215
+ const s = this._getParagraphFromBlock(c);
216
+ if (!s)
216
217
  return;
217
- const r = t.getStyle("display") === "none", n = t.getInnerText().trim();
218
- let o = t.getInnerHTML();
219
- o = o.replace(n, e), this.api.getDocumentModifier().modifyHtml(t).setInnerHtml(o).setStyle("display", i && !r ? "table-cell" : "none").apply(new d("Updated quantity"));
218
+ const m = s.getInnerText().trim();
219
+ let u = s.getInnerHTML().trim();
220
+ function p(y, C, N) {
221
+ return y.replace(
222
+ new RegExp(`(>\\s*)?${C}(\\s*<)?`, "g"),
223
+ `$1${N}$2`
224
+ );
225
+ }
226
+ u = p(u, m, e);
227
+ const T = this.api.getDocumentModifier();
228
+ T.modifyHtml(s).setInnerHtml(u), T.modifyHtml(c).setStyle("display", a ? "table-cell" : "none"), T.apply(new h("Updated quantity"));
220
229
  }
221
- /**
222
- * @todo Optimize template reordering for performance.
223
- * @description Reorders the template structure based on current orientation and visibility settings.
224
- */
225
230
  _reOrderTemplate() {
226
- var I, _, g, E, y, O, C;
227
- const e = (I = this.currentNode) == null ? void 0 : I.querySelector(`[esd-extension-block-id="${l.IMAGE}"]`), i = (_ = this.currentNode) == null ? void 0 : _.querySelector(`[esd-extension-block-id="${l.NAME}"]`), t = (g = this.currentNode) == null ? void 0 : g.querySelector(`[esd-extension-block-id="${l.PRICE}"]`), r = (E = this.currentNode) == null ? void 0 : E.querySelector(
228
- `[esd-extension-block-id="${l.ORIGINAL_PRICE}"]`
229
- ), n = (y = this.currentNode) == null ? void 0 : y.querySelector(`[esd-extension-block-id="${l.QUANTITY}"]`), o = (O = this.currentNode) == null ? void 0 : O.querySelector(`[esd-extension-block-id="${l.BUTTON}"]`), a = (C = this.currentNode) == null ? void 0 : C.querySelector("esd-config-block");
230
- if (!e || !i || !t || !r || !n || !o || !a)
231
+ var T, _, y, C, N, g;
232
+ const e = (T = this.currentNode) == null ? void 0 : T.querySelector(`[esd-extension-block-id="${I.IMAGE}"]`), t = (_ = this.currentNode) == null ? void 0 : _.querySelector(`[esd-extension-block-id="${I.NAME}"]`), r = ((y = this.currentNode) == null ? void 0 : y.querySelectorAll(
233
+ `[esd-extension-block-id="${I.PRICE}"]`
234
+ )) || [], i = ((C = this.currentNode) == null ? void 0 : C.querySelectorAll(
235
+ `[esd-extension-block-id="${I.ORIGINAL_PRICE}"]`
236
+ )) || [], [n] = r, [o] = i, a = (N = this.currentNode) == null ? void 0 : N.querySelector(`[esd-extension-block-id="${I.QUANTITY}"]`), c = (g = this.currentNode) == null ? void 0 : g.querySelector(`[esd-extension-block-id="${I.BUTTON}"]`);
237
+ if (!e || !t || !n || !o || !a || !c)
231
238
  return;
232
- const { orientation: c } = this.store, m = c === S.ORIENTATION.VERTICAL;
233
- let u = m ? F : U;
234
- this.api.getDocumentModifier().modifyHtml(e.querySelector("img")).setAttribute("width", H.productImageWidth).apply(new d("Updated image width")), setTimeout(() => {
235
- u = u.replace("{-{-TEMPLATE_FIRST_LINE-}-}", m ? R : "").replace("{-{-PRODUCT_IMAGE-}-}", e.getOuterHTML()).replace("{-{-PRODUCT_NAME-}-}", i.getOuterHTML()).replaceAll("{-{-PRODUCT_PRICE-}-}", t.getOuterHTML()).replaceAll("{-{-PRODUCT_ORIGINAL_PRICE-}-}", r.getOuterHTML()).replace("{-{-PRODUCT_QUANTITY-}-}", n.getOuterHTML()).replace("{-{-PRODUCT_BUTTON-}-}", o.getOuterHTML()).replace("{-{-CONFIG_BLOCK-}-}", a.getOuterHTML()), u = u.trim().replace(R, "").slice(0, -5), this.api.getDocumentModifier().modifyHtml(this.currentNode).setInnerHtml(u).apply(new d("Reordered template"));
239
+ const s = E(this.currentNode), u = ((s == null ? void 0 : s.orientation) ?? d.ORIENTATION.VERTICAL) === d.ORIENTATION.VERTICAL;
240
+ let p = u ? F : H;
241
+ this.api.getDocumentModifier().modifyHtml(e.querySelector("img")).setAttribute("width", L.productImageWidth).setAttribute("height", L.productImageWidth).apply(new h("Updated image width")), setTimeout(() => {
242
+ const D = A(n.getOuterHTML()), x = A(o.getOuterHTML());
243
+ p = p.replace("{-{-TEMPLATE_FIRST_LINE-}-}", u ? M : "").replace("{-{-PRODUCT_IMAGE-}-}", e.getOuterHTML()).replace("{-{-PRODUCT_NAME-}-}", t.getOuterHTML()).replaceAll("{-{-PRODUCT_PRICE-}-}", D).replaceAll("{-{-PRODUCT_ORIGINAL_PRICE-}-}", x).replace("{-{-PRODUCT_QUANTITY-}-}", a.getOuterHTML()).replace("{-{-PRODUCT_BUTTON-}-}", c.getOuterHTML()), p = p.trim().replace(M, "").slice(0, -5), this.api.getDocumentModifier().modifyHtml(this.currentNode).setInnerHtml(p).apply(new h("Reordered template"));
236
244
  }, 50);
237
245
  }
238
246
  _updateDataTypeAttributes(e) {
239
247
  if (!this.currentNode)
240
248
  return;
241
- const i = this.currentNode.closest(".ins-product-td"), t = this.api.getDocumentModifier();
242
- i && t.modifyHtml(i).setAttribute("data-type", e), this.currentNode.querySelectorAll("[data-type]").forEach((n) => {
249
+ const t = this.currentNode.closest(".ins-product-td"), r = this.api.getDocumentModifier();
250
+ t && r.modifyHtml(t).setAttribute("data-type", e), this.currentNode.querySelectorAll("[data-type]").forEach((n) => {
243
251
  const o = n;
244
- t.modifyHtml(o).setAttribute("data-type", e);
245
- }), t.apply(new d("Updated data-type attribute"));
252
+ r.modifyHtml(o).setAttribute("data-type", e);
253
+ }), r.apply(new h("Updated data-type attribute"));
246
254
  }
247
255
  _updateDataNumberAttributes(e) {
248
256
  if (!this.currentNode)
249
257
  return;
250
- const { itemsType: i } = this.store, t = N[i].findIndex((c) => c.value === e);
251
- let r = "1";
252
- if (t >= 0)
253
- r = String(t + 1);
258
+ const t = E(this.currentNode), r = (t == null ? void 0 : t.type) ?? d.ITEMS_TYPE.CART_ITEMS, i = R[r].findIndex((s) => s.value === e);
259
+ let n = "1";
260
+ if (i >= 0)
261
+ n = String(i + 1);
254
262
  else if (e) {
255
- const c = e.match(/\((\d+)\)/);
256
- if (c) {
257
- const [, m] = c;
258
- r = m;
263
+ const s = e.match(/\((\d+)\)/);
264
+ if (s) {
265
+ const [, m] = s;
266
+ n = m;
259
267
  }
260
268
  }
261
- const n = this.currentNode.closest(".ins-product-td"), o = this.api.getDocumentModifier();
262
- n && o.modifyHtml(n).setAttribute("data-number", r), this.currentNode.querySelectorAll("[data-number]").forEach((c) => {
263
- const m = c;
264
- o.modifyHtml(m).setAttribute("data-number", r);
265
- }), o.apply(new d("Updated data-number attribute"));
269
+ const o = this.currentNode.closest(".ins-product-td"), a = this.api.getDocumentModifier();
270
+ o && a.modifyHtml(o).setAttribute("data-number", n), this.currentNode.querySelectorAll("[data-number]").forEach((s) => {
271
+ const m = s;
272
+ a.modifyHtml(m).setAttribute("data-number", n);
273
+ }), a.apply(new h("Updated data-number attribute"));
266
274
  }
267
- _reFillTemplate() {
268
- const e = this._getTemplateData();
269
- this._updateImageSrc(e.imageSrc), this._updateName(e.name), this._updatePrice(e.price), this._updateOriginalPrice(e.originalPrice), this._updateQuantity(e.quantity);
275
+ _reFillTemplate(e) {
276
+ const t = this._getTemplateData(e);
277
+ this._updateImageSrc(t.imageSrc), this._updateName(t.name), this._updatePrice(t.price), this._updateOriginalPrice(t.originalPrice), this._updateQuantity(t.quantity, e);
270
278
  }
271
279
  _recalculateTrimming() {
272
- var n;
280
+ var o;
273
281
  if (!this.currentNode)
274
282
  return;
275
- const e = (n = this.currentNode) == null ? void 0 : n.querySelector(`[esd-extension-block-id="${l.NAME}"]`);
283
+ const e = (o = this.currentNode) == null ? void 0 : o.querySelector(`[esd-extension-block-id="${I.NAME}"]`);
276
284
  if (!e)
277
285
  return;
278
- const i = e.querySelector("p > a");
279
- if (!i)
286
+ const t = e.querySelector("p > a");
287
+ if (!t)
280
288
  return;
281
- const t = this.store.orientation === S.ORIENTATION.VERTICAL, r = this.store.nameTrimming;
282
- this.api.getDocumentModifier().modifyHtml(i).setStyle("overflow", "hidden").setStyle("white-space", r ? "nowrap" : "normal").setStyle("text-overflow", r ? "ellipsis" : "unset").setStyle("max-width", t ? "130px" : "520px").setStyle("width", t ? "130px" : "520px").apply(new d("Recalculated trimming after orientation change"));
289
+ const r = E(this.currentNode), i = (r == null ? void 0 : r.orientation) === d.ORIENTATION.HORIZONTAL, n = (r == null ? void 0 : r.nameTrimming) ?? !0;
290
+ this.api.getDocumentModifier().modifyHtml(t).setStyle("overflow", "hidden").setStyle("white-space", n ? "nowrap" : "normal").setStyle("text-overflow", n ? "ellipsis" : "unset").setStyle("max-width", i ? "130px" : "520px").setStyle("width", i ? "130px" : "520px").apply(new h("Recalculated trimming after orientation change"));
283
291
  }
284
292
  _getParagraphFromBlock(e) {
285
293
  return e.querySelector("p");
@@ -287,30 +295,30 @@ class te extends x {
287
295
  _escapeRegex(e) {
288
296
  return e.replace(/[-\\^$*+?().|[\]{}]/g, "\\$&");
289
297
  }
290
- _removeCurrencySymbol(e, i) {
291
- const t = e || "";
292
- let r = t;
293
- if (i) {
294
- const n = new RegExp(`\\s*${this._escapeRegex(i)}\\s*`);
295
- r = t.replace(n, "").trim();
298
+ _removeCurrencySymbol(e, t) {
299
+ const r = e || "";
300
+ let i = r;
301
+ if (t) {
302
+ const n = new RegExp(`\\s*${this._escapeRegex(t)}\\s*`);
303
+ i = r.replace(n, "").trim();
296
304
  } else {
297
- const n = t.match(/([^0-9.,\s]+)/);
305
+ const n = r.match(/([^0-9.,\s]+)/);
298
306
  if (n && n[1]) {
299
307
  const o = n[1].trim(), a = new RegExp(`\\s*${this._escapeRegex(o)}\\s*`);
300
- r = t.replace(a, "").trim();
308
+ i = r.replace(a, "").trim();
301
309
  }
302
310
  }
303
- return r;
311
+ return i;
304
312
  }
305
- _replacePriceNumber(e, i) {
306
- const t = /([0-9][0-9,.]*)/;
307
- return e.replace(t, i).trim();
313
+ _replacePriceNumber(e, t) {
314
+ const r = /([0-9][0-9,.]*)/;
315
+ return e.replace(r, t).trim();
308
316
  }
309
- _buildPriceContent(e, i, t) {
310
- return i ? t === "1" ? `${e}&nbsp;${i}&nbsp;` : `${i}&nbsp;${e}` : e;
317
+ _buildPriceContent(e, t, r) {
318
+ return t ? r === "1" ? `${e}&nbsp;${t}` : `${t}&nbsp;${e}` : e;
311
319
  }
312
320
  }
313
321
  export {
314
- G as CONTROL_BLOCK_ID,
315
- te as ItemsBlockControl
322
+ $ as CONTROL_BLOCK_ID,
323
+ X as ItemsBlockControl
316
324
  };
@@ -1,5 +1,5 @@
1
- var c = /* @__PURE__ */ ((i) => (i.BUTTON = "items-block-button", i.IMAGE = "items-block-image", i.ORIGINAL_PRICE = "items-block-original-price", i.PRICE = "items-block-price", i.QUANTITY = "items-block-quantity", i.NAME = "items-block-name", i))(c || {}), t = /* @__PURE__ */ ((i) => (i.BUTTON_ALIGN = "items-block-button-align-control", i.BUTTON_BORDER = "items-block-button-border-control", i.BUTTON_BORDER_RADIUS = "items-block-button-border-radius-control", i.BUTTON_COLOR = "items-block-button-color-control", i.BUTTON_FIT_TO_CONTENT = "items-block-button-fit-to-content-control", i.BUTTON_FONT_FAMILY = "items-block-button-font-family-control", i.BUTTON_MARGINS = "items-block-button-margins-control", i.BUTTON_PADDINGS = "items-block-button-paddings-control", i.BUTTON_TEXT = "items-block-button-text-control", i.BUTTON_TEXT_SIZE = "items-block-button-text-size-control", i.BUTTON_TEXT_STYLE_AND_FONT_COLOR = "items-block-button-text-style-and-font-color-control", i.BUTTON_LINK = "items-block-button-link-control", i.IMAGE_SIZE = "items-block-image-size-control", i.IMAGE_MARGINS = "items-block-image-margins-control", i.IMAGE_LINK = "items-block-image-link-control", i.ORIGINAL_PRICE_ALIGN = "items-block-original-price-align-control", i.ORIGINAL_PRICE_COLOR = "items-block-original-price-color-control", i.ORIGINAL_PRICE_SIZE = "items-block-original-price-size-control", i.ORIGINAL_PRICE_STYLE = "items-block-original-price-style-control", i.ORIGINAL_PRICE_FONT_FAMILY = "items-block-original-price-font-family-control", i.ORIGINAL_PRICE_BACKGROUND = "items-block-original-price-background-control", i.ORIGINAL_PRICE_PADDINGS = "items-block-original-price-paddings-control", i.PRICE_ALIGN = "items-block-price-align-control", i.PRICE_COLOR = "items-block-price-color-control", i.PRICE_SIZE = "items-block-price-size-control", i.PRICE_STYLE = "items-block-price-style-control", i.PRICE_FONT_FAMILY = "items-block-price-font-family-control", i.PRICE_BACKGROUND = "items-block-price-background-control", i.PRICE_PADDINGS = "items-block-price-paddings-control", i.PRICE_HIDE_DISCOUNT = "items-block-price-hide-discount-control", i.PRICE_FORMATTED_PRICE = "items-block-price-formatted-price-control", i.PRICE_CURRENCY_SYMBOL = "items-block-price-currency-symbol-control", i.PRICE_CURRENCY_LOCATION = "items-block-price-currency-location-control", i.PRICE_ORIENTATION = "items-block-price-orientation-control", i.NAME_ALIGN = "items-block-name-align-control", i.NAME_COLOR = "items-block-name-color-control", i.NAME_SIZE = "items-block-name-size-control", i.NAME_STYLE = "items-block-name-style-control", i.NAME_FONT_FAMILY = "items-block-name-font-family-control", i.NAME_BACKGROUND = "items-block-name-background-control", i.NAME_TRIMMING = "items-block-name-trimming-control", i.NAME_PADDINGS = "items-block-name-paddings-control", i.QUANTITY_ALIGN = "items-block-quantity-align-control", i.QUANTITY_COLOR = "items-block-quantity-color-control", i.QUANTITY_FONT_FAMILY = "items-block-quantity-font-family-control", i.QUANTITY_PADDINGS = "items-block-quantity-paddings-control", i.QUANTITY_SIZE = "items-block-quantity-size-control", i.QUANTITY_STYLE = "items-block-quantity-style-control", i))(t || {});
1
+ var c = /* @__PURE__ */ ((i) => (i.BUTTON = "items-block-button", i.IMAGE = "items-block-image", i.ORIGINAL_PRICE = "items-block-original-price", i.PRICE = "items-block-price", i.QUANTITY = "items-block-quantity", i.NAME = "items-block-name", i))(c || {}), _ = /* @__PURE__ */ ((i) => (i.BUTTON_ALIGN = "items-block-button-align-control", i.BUTTON_BORDER = "items-block-button-border-control", i.BUTTON_BORDER_RADIUS = "items-block-button-border-radius-control", i.BUTTON_COLOR = "items-block-button-color-control", i.BUTTON_FIT_TO_CONTENT = "items-block-button-fit-to-content-control", i.BUTTON_FONT_FAMILY = "items-block-button-font-family-control", i.BUTTON_MARGINS = "items-block-button-margins-control", i.BUTTON_PADDINGS = "items-block-button-paddings-control", i.BUTTON_TEXT = "items-block-button-text-control", i.BUTTON_TEXT_SIZE = "items-block-button-text-size-control", i.BUTTON_TEXT_STYLE_AND_FONT_COLOR = "items-block-button-text-style-and-font-color-control", i.BUTTON_LINK = "items-block-button-link-control", i.IMAGE_SIZE = "items-block-image-size-control", i.IMAGE_MARGINS = "items-block-image-margins-control", i.IMAGE_LINK = "items-block-image-link-control", i.ORIGINAL_PRICE_ALIGN = "items-block-original-price-align-control", i.ORIGINAL_PRICE_COLOR = "items-block-original-price-color-control", i.ORIGINAL_PRICE_SIZE = "items-block-original-price-size-control", i.ORIGINAL_PRICE_STYLE = "items-block-original-price-style-control", i.ORIGINAL_PRICE_FONT_FAMILY = "items-block-original-price-font-family-control", i.ORIGINAL_PRICE_BACKGROUND = "items-block-original-price-background-control", i.ORIGINAL_PRICE_PADDINGS = "items-block-original-price-paddings-control", i.PRICE_ALIGN = "items-block-price-align-control", i.PRICE_COLOR = "items-block-price-color-control", i.PRICE_SIZE = "items-block-price-size-control", i.PRICE_STYLE = "items-block-price-style-control", i.PRICE_FONT_FAMILY = "items-block-price-font-family-control", i.PRICE_BACKGROUND = "items-block-price-background-control", i.PRICE_PADDINGS = "items-block-price-paddings-control", i.PRICE_HIDE_DISCOUNT = "items-block-price-hide-discount-control", i.PRICE_FORMATTED_PRICE = "items-block-price-formatted-price-control", i.PRICE_SINGLE_PRICE = "items-block-price-single-price-control", i.PRICE_CURRENCY_SYMBOL = "items-block-price-currency-symbol-control", i.PRICE_CURRENCY_LOCATION = "items-block-price-currency-location-control", i.PRICE_ORIENTATION = "items-block-price-orientation-control", i.NAME_ALIGN = "items-block-name-align-control", i.NAME_COLOR = "items-block-name-color-control", i.NAME_SIZE = "items-block-name-size-control", i.NAME_STYLE = "items-block-name-style-control", i.NAME_FONT_FAMILY = "items-block-name-font-family-control", i.NAME_BACKGROUND = "items-block-name-background-control", i.NAME_TRIMMING = "items-block-name-trimming-control", i.NAME_PADDINGS = "items-block-name-paddings-control", i.QUANTITY_ALIGN = "items-block-quantity-align-control", i.QUANTITY_COLOR = "items-block-quantity-color-control", i.QUANTITY_FONT_FAMILY = "items-block-quantity-font-family-control", i.QUANTITY_PADDINGS = "items-block-quantity-paddings-control", i.QUANTITY_SIZE = "items-block-quantity-size-control", i.QUANTITY_STYLE = "items-block-quantity-style-control", i))(_ || {});
2
2
  export {
3
- t as ItemsBlockControlId,
3
+ _ as ItemsBlockControlId,
4
4
  c as ItemsBlockId
5
5
  };