@useinsider/guido 2.0.0-beta.fd117e6 → 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 (140) hide show
  1. package/dist/@types/config/schemas.js +17 -17
  2. package/dist/components/organisms/header/LeftSlot.vue.js +11 -11
  3. package/dist/components/organisms/header/LeftSlot.vue2.js +25 -20
  4. package/dist/config/migrator/itemsBlockMigrator.js +140 -123
  5. package/dist/extensions/Blocks/Items/block.js +22 -33
  6. package/dist/extensions/Blocks/Items/controls/button/link.js +19 -31
  7. package/dist/extensions/Blocks/Items/controls/cardComposition.js +110 -85
  8. package/dist/extensions/Blocks/Items/controls/image/link.js +19 -31
  9. package/dist/extensions/Blocks/Items/controls/name/trimming.js +28 -40
  10. package/dist/extensions/Blocks/Items/controls/price/currencyLocation.js +34 -46
  11. package/dist/extensions/Blocks/Items/controls/price/currencySymbol.js +45 -50
  12. package/dist/extensions/Blocks/Items/controls/price/formattedPrice.js +38 -43
  13. package/dist/extensions/Blocks/Items/controls/price/hideDiscount.js +23 -35
  14. package/dist/extensions/Blocks/Items/controls/price/priceOrientation.js +45 -57
  15. package/dist/extensions/Blocks/Items/controls/price/singlePrice.js +42 -62
  16. package/dist/extensions/Blocks/Items/controls/settingsControl.js +171 -178
  17. package/dist/extensions/Blocks/Items/enums/settingsEnums.js +0 -2
  18. package/dist/extensions/Blocks/Items/template.js +182 -177
  19. package/dist/extensions/Blocks/Items/utils/nodeConfigUtils.js +57 -57
  20. package/dist/extensions/Blocks/Recommendation/cardCompositionControl.js +153 -69
  21. package/dist/extensions/Blocks/Recommendation/constants.js +9 -1
  22. package/dist/extensions/Blocks/Recommendation/control.js +91 -61
  23. package/dist/extensions/Blocks/Recommendation/controls/cardBackgroundColorControl.js +68 -0
  24. package/dist/extensions/Blocks/Recommendation/controls/index.js +245 -0
  25. package/dist/extensions/Blocks/Recommendation/controls/nameTextTrimControl.js +74 -0
  26. package/dist/extensions/Blocks/Recommendation/controls/omnibusDiscountTextAfterControl.js +71 -0
  27. package/dist/extensions/Blocks/Recommendation/controls/omnibusDiscountTextBeforeControl.js +71 -0
  28. package/dist/extensions/Blocks/Recommendation/controls/omnibusPriceTextAfterControl.js +71 -0
  29. package/dist/extensions/Blocks/Recommendation/controls/omnibusPriceTextBeforeControl.js +71 -0
  30. package/dist/extensions/Blocks/Recommendation/controls/spacingControl.js +188 -0
  31. package/dist/extensions/Blocks/Recommendation/extension.js +16 -42
  32. package/dist/extensions/Blocks/Recommendation/settingsPanel.js +117 -72
  33. package/dist/extensions/Blocks/Recommendation/templates/blockTemplate.js +85 -64
  34. package/dist/extensions/Blocks/Recommendation/templates/migrationTemplate.js +54 -17
  35. package/dist/extensions/Blocks/Recommendation/templates/templateUtils.js +74 -45
  36. package/dist/extensions/Blocks/Recommendation/utils/preserveTextStyles.js +25 -0
  37. package/dist/extensions/Blocks/common-control.js +91 -92
  38. package/dist/guido.css +1 -1
  39. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/esm/index.js +39 -44
  40. package/dist/src/@types/config/schemas.d.ts +2 -2
  41. package/dist/src/extensions/Blocks/Items/block.d.ts +0 -1
  42. package/dist/src/extensions/Blocks/Items/controls/button/link.d.ts +0 -1
  43. package/dist/src/extensions/Blocks/Items/controls/cardComposition.d.ts +0 -1
  44. package/dist/src/extensions/Blocks/Items/controls/image/link.d.ts +0 -1
  45. package/dist/src/extensions/Blocks/Items/controls/name/trimming.d.ts +0 -1
  46. package/dist/src/extensions/Blocks/Items/controls/price/currencyLocation.d.ts +0 -1
  47. package/dist/src/extensions/Blocks/Items/controls/price/currencySymbol.d.ts +0 -1
  48. package/dist/src/extensions/Blocks/Items/controls/price/formattedPrice.d.ts +0 -1
  49. package/dist/src/extensions/Blocks/Items/controls/price/hideDiscount.d.ts +0 -1
  50. package/dist/src/extensions/Blocks/Items/controls/price/priceOrientation.d.ts +0 -1
  51. package/dist/src/extensions/Blocks/Items/controls/price/singlePrice.d.ts +0 -5
  52. package/dist/src/extensions/Blocks/Items/controls/settingsControl.d.ts +3 -5
  53. package/dist/src/extensions/Blocks/Recommendation/cardCompositionControl.d.ts +50 -3
  54. package/dist/src/extensions/Blocks/Recommendation/constants.d.ts +32 -0
  55. package/dist/src/extensions/Blocks/Recommendation/control.d.ts +5 -2
  56. package/dist/src/extensions/Blocks/Recommendation/controls/cardBackgroundColorControl.d.ts +25 -0
  57. package/dist/src/extensions/Blocks/Recommendation/controls/index.d.ts +592 -0
  58. package/dist/src/extensions/Blocks/Recommendation/controls/nameTextTrimControl.d.ts +16 -0
  59. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusDiscountTextAfterControl.d.ts +15 -0
  60. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusDiscountTextBeforeControl.d.ts +15 -0
  61. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusPriceTextAfterControl.d.ts +15 -0
  62. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusPriceTextBeforeControl.d.ts +15 -0
  63. package/dist/src/extensions/Blocks/Recommendation/controls/spacingControl.d.ts +60 -0
  64. package/dist/src/extensions/Blocks/Recommendation/templates/blockTemplate.d.ts +3 -3
  65. package/dist/src/extensions/Blocks/Recommendation/templates/templateUtils.d.ts +15 -7
  66. package/dist/src/extensions/Blocks/Recommendation/utils/preserveTextStyles.d.ts +19 -0
  67. package/dist/src/extensions/Blocks/common-control.d.ts +4 -5
  68. package/dist/static/styles/components/wide-panel.css.js +0 -4
  69. package/dist/static/styles/customEditorStyle.css.js +13 -0
  70. package/package.json +1 -1
  71. package/dist/extensions/Blocks/Items/store/items-block.js +0 -79
  72. package/dist/extensions/Blocks/Recommendation/controls/button/align.js +0 -13
  73. package/dist/extensions/Blocks/Recommendation/controls/button/border.js +0 -13
  74. package/dist/extensions/Blocks/Recommendation/controls/button/borderRadius.js +0 -13
  75. package/dist/extensions/Blocks/Recommendation/controls/button/color.js +0 -13
  76. package/dist/extensions/Blocks/Recommendation/controls/button/fitToContent.js +0 -13
  77. package/dist/extensions/Blocks/Recommendation/controls/button/fontFamily.js +0 -13
  78. package/dist/extensions/Blocks/Recommendation/controls/button/margins.js +0 -13
  79. package/dist/extensions/Blocks/Recommendation/controls/button/paddings.js +0 -13
  80. package/dist/extensions/Blocks/Recommendation/controls/button/text.js +0 -13
  81. package/dist/extensions/Blocks/Recommendation/controls/button/textSize.js +0 -13
  82. package/dist/extensions/Blocks/Recommendation/controls/button/textStyleAndFontColor.js +0 -13
  83. package/dist/extensions/Blocks/Recommendation/controls/image/margins.js +0 -13
  84. package/dist/extensions/Blocks/Recommendation/controls/image/size.js +0 -13
  85. package/dist/extensions/Blocks/Recommendation/controls/name/align.js +0 -13
  86. package/dist/extensions/Blocks/Recommendation/controls/name/background.js +0 -13
  87. package/dist/extensions/Blocks/Recommendation/controls/name/color.js +0 -13
  88. package/dist/extensions/Blocks/Recommendation/controls/name/fontFamily.js +0 -13
  89. package/dist/extensions/Blocks/Recommendation/controls/name/paddings.js +0 -13
  90. package/dist/extensions/Blocks/Recommendation/controls/name/size.js +0 -13
  91. package/dist/extensions/Blocks/Recommendation/controls/name/style.js +0 -13
  92. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/align.js +0 -13
  93. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/background.js +0 -13
  94. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/color.js +0 -13
  95. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/fontFamily.js +0 -13
  96. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/paddings.js +0 -13
  97. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/size.js +0 -13
  98. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/style.js +0 -13
  99. package/dist/extensions/Blocks/Recommendation/controls/price/align.js +0 -13
  100. package/dist/extensions/Blocks/Recommendation/controls/price/background.js +0 -13
  101. package/dist/extensions/Blocks/Recommendation/controls/price/color.js +0 -13
  102. package/dist/extensions/Blocks/Recommendation/controls/price/fontFamily.js +0 -13
  103. package/dist/extensions/Blocks/Recommendation/controls/price/paddings.js +0 -13
  104. package/dist/extensions/Blocks/Recommendation/controls/price/size.js +0 -13
  105. package/dist/extensions/Blocks/Recommendation/controls/price/style.js +0 -13
  106. package/dist/src/extensions/Blocks/Items/store/items-block.d.ts +0 -45
  107. package/dist/src/extensions/Blocks/Recommendation/controls/button/align.d.ts +0 -5
  108. package/dist/src/extensions/Blocks/Recommendation/controls/button/border.d.ts +0 -5
  109. package/dist/src/extensions/Blocks/Recommendation/controls/button/borderRadius.d.ts +0 -5
  110. package/dist/src/extensions/Blocks/Recommendation/controls/button/color.d.ts +0 -5
  111. package/dist/src/extensions/Blocks/Recommendation/controls/button/fitToContent.d.ts +0 -5
  112. package/dist/src/extensions/Blocks/Recommendation/controls/button/fontFamily.d.ts +0 -5
  113. package/dist/src/extensions/Blocks/Recommendation/controls/button/margins.d.ts +0 -5
  114. package/dist/src/extensions/Blocks/Recommendation/controls/button/paddings.d.ts +0 -5
  115. package/dist/src/extensions/Blocks/Recommendation/controls/button/text.d.ts +0 -5
  116. package/dist/src/extensions/Blocks/Recommendation/controls/button/textSize.d.ts +0 -5
  117. package/dist/src/extensions/Blocks/Recommendation/controls/button/textStyleAndFontColor.d.ts +0 -5
  118. package/dist/src/extensions/Blocks/Recommendation/controls/image/margins.d.ts +0 -5
  119. package/dist/src/extensions/Blocks/Recommendation/controls/image/size.d.ts +0 -5
  120. package/dist/src/extensions/Blocks/Recommendation/controls/name/align.d.ts +0 -5
  121. package/dist/src/extensions/Blocks/Recommendation/controls/name/background.d.ts +0 -5
  122. package/dist/src/extensions/Blocks/Recommendation/controls/name/color.d.ts +0 -5
  123. package/dist/src/extensions/Blocks/Recommendation/controls/name/fontFamily.d.ts +0 -5
  124. package/dist/src/extensions/Blocks/Recommendation/controls/name/paddings.d.ts +0 -5
  125. package/dist/src/extensions/Blocks/Recommendation/controls/name/size.d.ts +0 -5
  126. package/dist/src/extensions/Blocks/Recommendation/controls/name/style.d.ts +0 -5
  127. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/align.d.ts +0 -5
  128. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/background.d.ts +0 -5
  129. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/color.d.ts +0 -5
  130. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/fontFamily.d.ts +0 -5
  131. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/paddings.d.ts +0 -5
  132. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/size.d.ts +0 -5
  133. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/style.d.ts +0 -5
  134. package/dist/src/extensions/Blocks/Recommendation/controls/price/align.d.ts +0 -5
  135. package/dist/src/extensions/Blocks/Recommendation/controls/price/background.d.ts +0 -5
  136. package/dist/src/extensions/Blocks/Recommendation/controls/price/color.d.ts +0 -5
  137. package/dist/src/extensions/Blocks/Recommendation/controls/price/fontFamily.d.ts +0 -5
  138. package/dist/src/extensions/Blocks/Recommendation/controls/price/paddings.d.ts +0 -5
  139. package/dist/src/extensions/Blocks/Recommendation/controls/price/size.d.ts +0 -5
  140. package/dist/src/extensions/Blocks/Recommendation/controls/price/style.d.ts +0 -5
@@ -1,28 +1,20 @@
1
- var x = Object.defineProperty;
2
- var H = (I, h, e) => h in I ? x(I, h, { enumerable: !0, configurable: !0, writable: !0, value: e }) : I[h] = e;
3
- var O = (I, h, e) => H(I, typeof h != "symbol" ? h + "" : h, e);
4
- import { UEAttr as C, ModificationDescription as p } from "../../../../node_modules/@stripoinc/ui-editor-extensions/dist/esm/index.js";
5
- import { CommonControl as k } from "../../common-control.js";
6
- import { ItemsBlockId as m } from "../enums/controlEnums.js";
7
- import { productPairs as T, templateFirstLine as b } from "../enums/productEnums.js";
8
- import { ItemTypeOptions as R, OrientationOptions as U, ItemInCartOptions as N, SETTINGS_ENUMS as S, DefaultConfigValues as P } from "../enums/settingsEnums.js";
9
- import F from "../layouts/horizontal.html.js";
10
- import $ from "../layouts/vertical.html.js";
11
- import { useItemsBlockStore as q } from "../store/items-block.js";
12
- import { getDefaultTemplate as w } from "../template.js";
13
- import { getItemsBlockConfig as A, setItemsBlockConfig as f, escapeReplacement as L } from "../utils/nodeConfigUtils.js";
14
- const B = "ui-elements-items-block", a = {
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";
7
+ import F from "../layouts/vertical.html.js";
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 = {
15
11
  ITEMS_TYPE: "itemsType",
16
12
  ORIENTATION: "orientation",
17
13
  ITEM_IDS: "itemIds"
18
14
  };
19
- class J extends k {
20
- constructor() {
21
- super(...arguments);
22
- O(this, "store", q());
23
- }
15
+ class X extends U {
24
16
  getId() {
25
- return B;
17
+ return $;
26
18
  }
27
19
  getTemplate() {
28
20
  return `
@@ -34,40 +26,32 @@ class J extends k {
34
26
  `;
35
27
  }
36
28
  onRender() {
29
+ const e = E(this.currentNode);
37
30
  this.api.updateValues({
38
- [a.ORIENTATION]: this.store.orientation,
39
- [a.ITEMS_TYPE]: this.store.itemsType,
40
- [a.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) ?? ""
41
34
  }), this._listenToFormUpdates();
42
35
  }
43
36
  onTemplateNodeUpdated(e) {
44
- super.onTemplateNodeUpdated(e), console.debug("Items Block Config", e.getNodeConfig()), this.handleBlockInstanceChange(
45
- () => {
46
- const t = A(this.currentNode);
47
- t && (this.store.setItemsType(t.type), this.store.setItemIds(t.itemsSelectValue), this.store.setOrientation(t.orientation), this.store.setCurrencySymbol(t.priceCurrencySymbol), this.store.setCurrencyLocation(t.priceCurrencyLocation), this.store.setFormattedPrice(t.priceFormatted), this.store.setImageLink(t.imageLink), this.store.setButtonLink(t.buttonLink));
48
- },
49
- () => {
50
- this.api.updateValues({
51
- [a.ORIENTATION]: this.store.orientation,
52
- [a.ITEMS_TYPE]: this.store.itemsType,
53
- [a.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: a.ITEMS_TYPE,
51
+ name: l.ITEMS_TYPE,
68
52
  className: "es-100",
69
53
  placeholder: "Select Item Type",
70
- options: R
54
+ options: b
71
55
  })
72
56
  ])}
73
57
  `;
@@ -77,8 +61,8 @@ class J extends k {
77
61
  ${this._GuTwoColumns([
78
62
  this._GuLabel({ text: "Orientation" }),
79
63
  this._GuRadioButton({
80
- name: a.ORIENTATION,
81
- buttons: U
64
+ name: l.ORIENTATION,
65
+ buttons: f
82
66
  })
83
67
  ])}
84
68
  `;
@@ -88,7 +72,7 @@ class J extends k {
88
72
  ${this._GuTwoColumns([
89
73
  this._GuLabel({ text: "Item in Cart" }),
90
74
  this._GuSelect({
91
- name: a.ITEM_IDS,
75
+ name: l.ITEM_IDS,
92
76
  className: "es-100",
93
77
  placeholder: "Select Item In Cart",
94
78
  options: []
@@ -97,7 +81,7 @@ class J extends k {
97
81
  `;
98
82
  }
99
83
  _onOrientationChange(e) {
100
- this.store.setOrientation(e), this.store.setPriceOrientation("horizontal"), this.api.updateValues({ [a.ORIENTATION]: e }), f(this.currentNode, this.api, {
84
+ this.api.updateValues({ [l.ORIENTATION]: e }), O(this.currentNode, this.api, {
101
85
  orientation: e,
102
86
  priceOrientation: "horizontal"
103
87
  }), this._reOrderTemplate(), setTimeout(() => {
@@ -105,196 +89,205 @@ class J extends k {
105
89
  }, 50);
106
90
  }
107
91
  _onItemsTypeChange(e) {
108
- const t = S.ITEMS_TYPE[e], i = N[e], r = i == null ? void 0 : i[0];
109
- !t || !r || (this.store.setItemsType(t), this.store.setItemIds(r.value), f(this.currentNode, this.api, {
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, {
110
97
  source: t,
111
98
  type: t,
112
- itemsSelectValue: r.value,
113
- imageLink: this.store.imageLink,
114
- buttonLink: this.store.buttonLink
115
- }), this._updateDataTypeAttributes(t), this._initializeSelectItems(), this._reFillTemplate());
99
+ itemsSelectValue: i.value,
100
+ imageLink: o,
101
+ buttonLink: n
102
+ }), this._updateDataTypeAttributes(t), this._initializeSelectItems(), this._reFillTemplate(t);
116
103
  }
117
104
  _onItemIdsChange(e) {
118
- this.store.setItemIds(e), this.api.updateValues({ [a.ITEM_IDS]: e }), f(this.currentNode, this.api, {
105
+ this.api.updateValues({ [l.ITEM_IDS]: e });
106
+ const t = e, r = e.replace("Url}}", "Image}}");
107
+ O(this.currentNode, this.api, {
119
108
  itemsSelectValue: e,
120
- imageLink: this.store.imageLink,
121
- buttonLink: this.store.buttonLink
109
+ imageLink: r,
110
+ buttonLink: t
122
111
  }), this._updateDataNumberAttributes(e), this._reFillTemplate();
123
112
  }
124
113
  _initializeSelectItems() {
125
114
  this.api.setUIEAttribute(
126
- a.ITEMS_TYPE,
127
- C.SELECTPICKER.items,
128
- R
115
+ l.ITEMS_TYPE,
116
+ P.SELECTPICKER.items,
117
+ b
129
118
  );
130
- const { itemsType: e, itemIds: t } = 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) ?? "";
131
120
  this.api.updateValues({
132
- [a.ITEMS_TYPE]: e
121
+ [l.ITEMS_TYPE]: t
133
122
  });
134
- const i = N[e];
123
+ const i = R[t];
135
124
  this.api.setUIEAttribute(
136
- a.ITEM_IDS,
137
- C.SELECTPICKER.items,
125
+ l.ITEM_IDS,
126
+ P.SELECTPICKER.items,
138
127
  i
139
128
  ), this.api.updateValues({
140
- [a.ITEM_IDS]: t
129
+ [l.ITEM_IDS]: r
141
130
  });
142
131
  }
143
132
  _listenToFormUpdates() {
144
133
  this.api.onValueChanged(
145
- a.ITEMS_TYPE,
134
+ l.ITEMS_TYPE,
146
135
  (e) => this._onItemsTypeChange(e)
147
136
  ), this.api.onValueChanged(
148
- a.ORIENTATION,
137
+ l.ORIENTATION,
149
138
  (e) => this._onOrientationChange(e)
150
139
  ), this.api.onValueChanged(
151
- a.ITEM_IDS,
140
+ l.ITEM_IDS,
152
141
  (e) => this._onItemIdsChange(e)
153
142
  );
154
143
  }
155
144
  _renderTemplate() {
156
- const {
157
- orientation: e,
158
- itemsType: t,
159
- itemIds: i,
160
- currencySymbol: r,
161
- currencyLocation: n,
162
- formattedPrice: o
163
- } = this.store;
164
- this.api.getDocumentModifier().modifyHtml(this.currentNode).setInnerHtml(w({
165
- orientation: e,
166
- itemsType: t,
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,
167
149
  itemId: i,
168
- currencySymbol: r,
169
- currencyLocation: n,
170
- formattedPrice: o
171
- })).apply(new p("Updated template"));
150
+ currencySymbol: n,
151
+ currencyLocation: o,
152
+ formattedPrice: a
153
+ })).apply(new h("Updated template"));
172
154
  }
173
- _getTemplateData() {
174
- const { itemsType: e, itemIds: t, formattedPrice: i } = this.store, r = N[e].findIndex((o) => o.value === t), n = r > -1 ? r : 0;
175
- return {
176
- imageSrc: T.PAIRS_FOR_EXTENSION.imageSrc[e].DEFAULT[n],
177
- name: T.PAIRS_FOR_EXTENSION.name[e].DEFAULT[n],
178
- price: i ? T.PAIRS_FOR_EXTENSION.price[e].DEFAULT_PRICE_FORMATTED : T.PAIRS_FOR_EXTENSION.price[e].DEFAULT_PRICE,
179
- originalPrice: i ? T.PAIRS_FOR_EXTENSION.originalPrice[e].DEFAULT_PRICE_FORMATTED : T.PAIRS_FOR_EXTENSION.originalPrice[e].DEFAULT_PRICE,
180
- quantity: T.PAIRS_FOR_EXTENSION.quantity[e].DEFAULT,
181
- 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
182
165
  };
183
166
  }
184
167
  _updateImageSrc(e) {
185
- var i;
186
- const t = (i = this.currentNode) == null ? void 0 : i.querySelector(`[esd-extension-block-id="${m.IMAGE}"] img`);
187
- t && this.api.getDocumentModifier().modifyHtml(t).setAttribute("src", e).apply(new p("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"));
188
171
  }
189
172
  _updateName(e) {
190
173
  var n;
191
- const t = (n = this.currentNode) == null ? void 0 : n.querySelector(`[esd-extension-block-id="${m.NAME}"]`);
174
+ const t = (n = this.currentNode) == null ? void 0 : n.querySelector(`[esd-extension-block-id="${I.NAME}"]`);
192
175
  if (!t)
193
176
  return;
194
- const i = t.getInnerText().trim();
195
- let r = t.getInnerHTML();
196
- r = r.replace(i, e), this.api.getDocumentModifier().modifyHtml(t).setInnerHtml(r).apply(new p("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"));
197
180
  }
198
181
  _updatePrice(e) {
199
- var g;
200
- const t = (g = this.currentNode) == null ? void 0 : g.querySelector(`[esd-extension-block-id="${m.PRICE}"]`);
201
- if (!t)
202
- return;
203
- const i = this._getParagraphFromBlock(t);
204
- if (!i)
205
- return;
206
- const r = i.getInnerHTML() || "", n = i.getInnerText() || "", { currencySymbol: o, currencyLocation: l } = this.store, c = (o == null ? void 0 : o.trim()) || "", s = this._removeCurrencySymbol(n, c), u = this._replacePriceNumber(s, e), d = this._buildPriceContent(u, c, l), _ = r.replace(n, d);
207
- this.api.getDocumentModifier().modifyHtml(i).setInnerHtml(_).apply(new p("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
+ });
208
193
  }
209
194
  _updateOriginalPrice(e) {
210
- var y;
211
- const t = (y = this.currentNode) == null ? void 0 : y.querySelector(
212
- `[esd-extension-block-id="${m.ORIGINAL_PRICE}"]`
213
- );
214
- if (!t)
215
- return;
216
- const i = this._getParagraphFromBlock(t);
217
- if (!i)
218
- return;
219
- const r = i.querySelector("s");
220
- if (!r)
221
- return;
222
- const n = r.getInnerHTML() || "", o = r.getInnerText() || "", { currencySymbol: l, currencyLocation: c } = this.store, s = (l == null ? void 0 : l.trim()) || "", u = this._removeCurrencySymbol(o, s), d = this._replacePriceNumber(u, e), _ = this._buildPriceContent(d, s, c), E = `<s>${n.replace(o, _)}</s>`;
223
- this.api.getDocumentModifier().modifyHtml(i).setInnerHtml(E).apply(new p("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
+ });
224
209
  }
225
- _updateQuantity(e) {
226
- var d;
227
- const t = this.store.itemsType !== S.ITEMS_TYPE.BROWSED_ITEMS, i = A(this.currentNode), r = (i == null ? void 0 : i.quantityControlEnabled) !== !1, n = t && r, o = (d = this.currentNode) == null ? void 0 : d.querySelector(`[esd-extension-block-id="${m.QUANTITY}"]`);
228
- if (!o)
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)
229
214
  return;
230
- const l = this._getParagraphFromBlock(o);
231
- if (!l)
215
+ const s = this._getParagraphFromBlock(c);
216
+ if (!s)
232
217
  return;
233
- const c = l.getInnerText().trim();
234
- let s = l.getInnerHTML();
235
- s = s.replace(c, e);
236
- const u = this.api.getDocumentModifier();
237
- u.modifyHtml(l).setInnerHtml(s), u.modifyHtml(o).setStyle("display", n ? "table-cell" : "none"), u.apply(new p("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"));
238
229
  }
239
230
  _reOrderTemplate() {
240
- var u, d, _, g, E, y;
241
- const e = (u = this.currentNode) == null ? void 0 : u.querySelector(`[esd-extension-block-id="${m.IMAGE}"]`), t = (d = this.currentNode) == null ? void 0 : d.querySelector(`[esd-extension-block-id="${m.NAME}"]`), i = (_ = this.currentNode) == null ? void 0 : _.querySelector(`[esd-extension-block-id="${m.PRICE}"]`), r = (g = this.currentNode) == null ? void 0 : g.querySelector(
242
- `[esd-extension-block-id="${m.ORIGINAL_PRICE}"]`
243
- ), n = (E = this.currentNode) == null ? void 0 : E.querySelector(`[esd-extension-block-id="${m.QUANTITY}"]`), o = (y = this.currentNode) == null ? void 0 : y.querySelector(`[esd-extension-block-id="${m.BUTTON}"]`);
244
- if (!e || !t || !i || !r || !n || !o)
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)
245
238
  return;
246
- const { orientation: l } = this.store, c = l === S.ORIENTATION.VERTICAL;
247
- let s = c ? $ : F;
248
- this.api.getDocumentModifier().modifyHtml(e.querySelector("img")).setAttribute("width", P.productImageWidth).setAttribute("height", P.productImageWidth).apply(new p("Updated image width")), setTimeout(() => {
249
- const M = L(i.getOuterHTML()), D = L(r.getOuterHTML());
250
- s = s.replace("{-{-TEMPLATE_FIRST_LINE-}-}", c ? b : "").replace("{-{-PRODUCT_IMAGE-}-}", e.getOuterHTML()).replace("{-{-PRODUCT_NAME-}-}", t.getOuterHTML()).replaceAll("{-{-PRODUCT_PRICE-}-}", M).replaceAll("{-{-PRODUCT_ORIGINAL_PRICE-}-}", D).replace("{-{-PRODUCT_QUANTITY-}-}", n.getOuterHTML()).replace("{-{-PRODUCT_BUTTON-}-}", o.getOuterHTML()), s = s.trim().replace(b, "").slice(0, -5), this.api.getDocumentModifier().modifyHtml(this.currentNode).setInnerHtml(s).apply(new p("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"));
251
244
  }, 50);
252
245
  }
253
246
  _updateDataTypeAttributes(e) {
254
247
  if (!this.currentNode)
255
248
  return;
256
- const t = this.currentNode.closest(".ins-product-td"), i = this.api.getDocumentModifier();
257
- t && i.modifyHtml(t).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) => {
258
251
  const o = n;
259
- i.modifyHtml(o).setAttribute("data-type", e);
260
- }), i.apply(new p("Updated data-type attribute"));
252
+ r.modifyHtml(o).setAttribute("data-type", e);
253
+ }), r.apply(new h("Updated data-type attribute"));
261
254
  }
262
255
  _updateDataNumberAttributes(e) {
263
256
  if (!this.currentNode)
264
257
  return;
265
- const { itemsType: t } = this.store, i = N[t].findIndex((c) => c.value === e);
266
- let r = "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";
267
260
  if (i >= 0)
268
- r = String(i + 1);
261
+ n = String(i + 1);
269
262
  else if (e) {
270
- const c = e.match(/\((\d+)\)/);
271
- if (c) {
272
- const [, s] = c;
273
- r = s;
263
+ const s = e.match(/\((\d+)\)/);
264
+ if (s) {
265
+ const [, m] = s;
266
+ n = m;
274
267
  }
275
268
  }
276
- const n = this.currentNode.closest(".ins-product-td"), o = this.api.getDocumentModifier();
277
- n && o.modifyHtml(n).setAttribute("data-number", r), this.currentNode.querySelectorAll("[data-number]").forEach((c) => {
278
- const s = c;
279
- o.modifyHtml(s).setAttribute("data-number", r);
280
- }), o.apply(new p("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"));
281
274
  }
282
- _reFillTemplate() {
283
- const e = this._getTemplateData();
284
- 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);
285
278
  }
286
279
  _recalculateTrimming() {
287
- var n;
280
+ var o;
288
281
  if (!this.currentNode)
289
282
  return;
290
- const e = (n = this.currentNode) == null ? void 0 : n.querySelector(`[esd-extension-block-id="${m.NAME}"]`);
283
+ const e = (o = this.currentNode) == null ? void 0 : o.querySelector(`[esd-extension-block-id="${I.NAME}"]`);
291
284
  if (!e)
292
285
  return;
293
286
  const t = e.querySelector("p > a");
294
287
  if (!t)
295
288
  return;
296
- const i = this.store.orientation === S.ORIENTATION.HORIZONTAL, r = this.store.nameTrimming;
297
- this.api.getDocumentModifier().modifyHtml(t).setStyle("overflow", "hidden").setStyle("white-space", r ? "nowrap" : "normal").setStyle("text-overflow", r ? "ellipsis" : "unset").setStyle("max-width", i ? "130px" : "520px").setStyle("width", i ? "130px" : "520px").apply(new p("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"));
298
291
  }
299
292
  _getParagraphFromBlock(e) {
300
293
  return e.querySelector("p");
@@ -303,29 +296,29 @@ class J extends k {
303
296
  return e.replace(/[-\\^$*+?().|[\]{}]/g, "\\$&");
304
297
  }
305
298
  _removeCurrencySymbol(e, t) {
306
- const i = e || "";
307
- let r = i;
299
+ const r = e || "";
300
+ let i = r;
308
301
  if (t) {
309
302
  const n = new RegExp(`\\s*${this._escapeRegex(t)}\\s*`);
310
- r = i.replace(n, "").trim();
303
+ i = r.replace(n, "").trim();
311
304
  } else {
312
- const n = i.match(/([^0-9.,\s]+)/);
305
+ const n = r.match(/([^0-9.,\s]+)/);
313
306
  if (n && n[1]) {
314
- const o = n[1].trim(), l = new RegExp(`\\s*${this._escapeRegex(o)}\\s*`);
315
- r = i.replace(l, "").trim();
307
+ const o = n[1].trim(), a = new RegExp(`\\s*${this._escapeRegex(o)}\\s*`);
308
+ i = r.replace(a, "").trim();
316
309
  }
317
310
  }
318
- return r;
311
+ return i;
319
312
  }
320
313
  _replacePriceNumber(e, t) {
321
- const i = /([0-9][0-9,.]*)/;
322
- return e.replace(i, t).trim();
314
+ const r = /([0-9][0-9,.]*)/;
315
+ return e.replace(r, t).trim();
323
316
  }
324
- _buildPriceContent(e, t, i) {
325
- return t ? i === "1" ? `${e}&nbsp;${t}` : `${t}&nbsp;${e}` : e;
317
+ _buildPriceContent(e, t, r) {
318
+ return t ? r === "1" ? `${e}&nbsp;${t}` : `${t}&nbsp;${e}` : e;
326
319
  }
327
320
  }
328
321
  export {
329
- B as CONTROL_BLOCK_ID,
330
- J as ItemsBlockControl
322
+ $ as CONTROL_BLOCK_ID,
323
+ X as ItemsBlockControl
331
324
  };
@@ -16,9 +16,7 @@ const e = {
16
16
  { icon: "vertical-orientation", value: e.ORIENTATION.VERTICAL },
17
17
  { icon: "horizontal-orientation", value: e.ORIENTATION.HORIZONTAL }
18
18
  ], a = {
19
- itemsType: e.ITEMS_TYPE.CART_ITEMS,
20
19
  cartItemsSelectControlValue: "{{Abandoned Cart Item (1) Url}}",
21
- cardOrientationControlValue: e.ORIENTATION.VERTICAL,
22
20
  productNameTrimmingControlValue: "1",
23
21
  productPriceHideDiscountControlValue: "1",
24
22
  productPriceFormattedControlValue: "1",