@useinsider/guido 1.0.3-beta.0d0bb85 → 1.0.3-beta.0da597d

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 (118) hide show
  1. package/README.md +172 -3
  2. package/dist/components/Guido.vue.js +1 -1
  3. package/dist/components/Guido.vue2.js +79 -73
  4. package/dist/components/organisms/header/LeftSlot.vue.js +1 -1
  5. package/dist/components/organisms/header/LeftSlot.vue2.js +16 -15
  6. package/dist/components/organisms/header/RightSlot.vue.js +11 -11
  7. package/dist/components/organisms/header/RightSlot.vue2.js +23 -22
  8. package/dist/composables/useBlocksConfig.js +48 -0
  9. package/dist/composables/useGuidoActions.js +19 -9
  10. package/dist/composables/useStripo.js +50 -59
  11. package/dist/config/compiler/unsubscribeCompilerRules.js +33 -28
  12. package/dist/enums/defaults.js +16 -9
  13. package/dist/enums/extensions/recommendationBlock.js +2 -2
  14. package/dist/enums/unsubscribe.js +10 -9
  15. package/dist/extensions/Blocks/Checkbox/block.js +5 -2
  16. package/dist/extensions/Blocks/Checkbox/extension.js +2 -2
  17. package/dist/extensions/Blocks/CouponBlock/extension.js +2 -2
  18. package/dist/extensions/Blocks/Items/block.js +66 -0
  19. package/dist/extensions/Blocks/Items/controls/button/link.js +68 -0
  20. package/dist/extensions/Blocks/Items/controls/cardComposition.js +99 -0
  21. package/dist/extensions/Blocks/Items/controls/image/link.js +68 -0
  22. package/dist/extensions/Blocks/Items/controls/index.js +217 -0
  23. package/dist/extensions/Blocks/Items/controls/name/trimming.js +70 -0
  24. package/dist/extensions/Blocks/Items/controls/price/currencyLocation.js +107 -0
  25. package/dist/extensions/Blocks/Items/controls/price/currencySymbol.js +123 -0
  26. package/dist/extensions/Blocks/Items/controls/price/formattedPrice.js +76 -0
  27. package/dist/extensions/Blocks/Items/controls/price/hideDiscount.js +61 -0
  28. package/dist/extensions/Blocks/Items/controls/settingsControl.js +280 -0
  29. package/dist/extensions/Blocks/Items/enums/controlEnums.js +5 -0
  30. package/dist/extensions/Blocks/Items/enums/productEnums.js +195 -0
  31. package/dist/extensions/Blocks/Items/enums/settingsEnums.js +70 -0
  32. package/dist/extensions/Blocks/Items/extension.js +19 -0
  33. package/dist/extensions/Blocks/Items/iconsRegistry.js +32 -0
  34. package/dist/extensions/Blocks/Items/items.css.js +23 -0
  35. package/dist/extensions/Blocks/Items/layouts/horizontal.html.js +61 -0
  36. package/dist/extensions/Blocks/Items/layouts/vertical.html.js +61 -0
  37. package/dist/extensions/Blocks/Items/settingsPanel.js +106 -0
  38. package/dist/extensions/Blocks/Items/store/items-block.js +71 -0
  39. package/dist/extensions/Blocks/Items/template.js +110 -0
  40. package/dist/extensions/Blocks/Items/utils/configBlockUtils.js +17 -0
  41. package/dist/extensions/Blocks/Items/utils/syncAttributeFromConfigBlock.js +28 -0
  42. package/dist/extensions/Blocks/Items/utils/syncAttributesFromConfigBlock.js +67 -0
  43. package/dist/extensions/Blocks/Items/utils/updateAttributes.js +44 -0
  44. package/dist/extensions/Blocks/RadioButton/block.js +5 -2
  45. package/dist/extensions/Blocks/Recommendation/extension.js +4 -4
  46. package/dist/extensions/Blocks/Recommendation/iconsRegistry.js +43 -43
  47. package/dist/extensions/Blocks/Recommendation/store/recommendation.js +1 -1
  48. package/dist/extensions/Blocks/Recommendation/templates/blockTemplate.js +4 -4
  49. package/dist/extensions/Blocks/common-control.js +174 -110
  50. package/dist/extensions/Blocks/controlFactories.js +223 -0
  51. package/dist/extensions/DynamicContent/dynamic-content-modal.js +25 -19
  52. package/dist/extensions/DynamicContent/dynamic-content.js +128 -33
  53. package/dist/guido.css +1 -1
  54. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/esm/index.js +213 -168
  55. package/dist/package.json.js +1 -1
  56. package/dist/services/recommendationApi.js +13 -19
  57. package/dist/services/stripoApi.js +1 -1
  58. package/dist/src/@types/generic.d.ts +36 -6
  59. package/dist/src/components/Guido.vue.d.ts +3 -2
  60. package/dist/src/components/wrappers/WpModal.vue.d.ts +1 -1
  61. package/dist/src/composables/useBlocksConfig.d.ts +11 -0
  62. package/dist/src/composables/useGuidoActions.d.ts +9 -0
  63. package/dist/src/extensions/Blocks/Checkbox/block.d.ts +1 -0
  64. package/dist/src/extensions/Blocks/Items/block.d.ts +13 -0
  65. package/dist/src/extensions/Blocks/Items/controls/button/link.d.ts +14 -0
  66. package/dist/src/extensions/Blocks/Items/controls/cardComposition.d.ts +20 -0
  67. package/dist/src/extensions/Blocks/Items/controls/image/link.d.ts +14 -0
  68. package/dist/src/extensions/Blocks/Items/controls/index.d.ts +501 -0
  69. package/dist/src/extensions/Blocks/Items/controls/name/trimming.d.ts +14 -0
  70. package/dist/src/extensions/Blocks/Items/controls/price/currencyLocation.d.ts +19 -0
  71. package/dist/src/extensions/Blocks/Items/controls/price/currencySymbol.d.ts +21 -0
  72. package/dist/src/extensions/Blocks/Items/controls/price/formattedPrice.d.ts +14 -0
  73. package/dist/src/extensions/Blocks/Items/controls/price/hideDiscount.d.ts +13 -0
  74. package/dist/src/extensions/Blocks/Items/controls/settingsControl.d.ts +42 -0
  75. package/dist/src/extensions/Blocks/Items/enums/controlEnums.d.ts +61 -0
  76. package/dist/src/extensions/Blocks/Items/enums/productEnums.d.ts +154 -0
  77. package/dist/src/extensions/Blocks/Items/enums/settingsEnums.d.ts +43 -0
  78. package/dist/src/extensions/Blocks/Items/extension.d.ts +2 -0
  79. package/dist/src/extensions/Blocks/Items/iconsRegistry.d.ts +4 -0
  80. package/dist/src/extensions/Blocks/Items/settingsPanel.d.ts +4 -0
  81. package/dist/src/extensions/Blocks/Items/store/items-block.d.ts +41 -0
  82. package/dist/src/extensions/Blocks/Items/template.d.ts +16 -0
  83. package/dist/src/extensions/Blocks/Items/utils/configBlockUtils.d.ts +23 -0
  84. package/dist/src/extensions/Blocks/Items/utils/syncAttributeFromConfigBlock.d.ts +32 -0
  85. package/dist/src/extensions/Blocks/Items/utils/syncAttributesFromConfigBlock.d.ts +44 -0
  86. package/dist/src/extensions/Blocks/Items/utils/updateAttributes.d.ts +8 -0
  87. package/dist/src/extensions/Blocks/RadioButton/block.d.ts +1 -0
  88. package/dist/src/extensions/Blocks/Recommendation/store/recommendation.d.ts +1 -1
  89. package/dist/src/extensions/Blocks/common-control.d.ts +44 -7
  90. package/dist/src/extensions/Blocks/controlFactories.d.ts +312 -0
  91. package/dist/src/extensions/DynamicContent/dynamic-content-modal.d.ts +9 -2
  92. package/dist/src/extensions/DynamicContent/dynamic-content.d.ts +52 -2
  93. package/dist/src/stores/config.d.ts +9 -2
  94. package/dist/src/stores/dynamic-content.d.ts +3 -3
  95. package/dist/src/stores/editor.d.ts +1 -1
  96. package/dist/src/stores/onboarding.d.ts +1 -1
  97. package/dist/src/stores/preview.d.ts +1 -1
  98. package/dist/src/stores/recommendation.d.ts +1 -1
  99. package/dist/src/stores/save-as-template.d.ts +1 -1
  100. package/dist/src/stores/toaster.d.ts +1 -1
  101. package/dist/src/stores/unsubscribe.d.ts +1 -1
  102. package/dist/src/stores/version-history.d.ts +1 -1
  103. package/dist/src/utils/arrayUtil.d.ts +0 -5
  104. package/dist/src/utils/genericUtil.d.ts +1 -0
  105. package/dist/static/styles/components/narrow-panel.css.js +10 -0
  106. package/dist/static/styles/customEditorStyle.css.js +1 -1
  107. package/dist/stores/config.js +5 -5
  108. package/dist/stores/dynamic-content.js +2 -2
  109. package/dist/stores/editor.js +1 -1
  110. package/dist/stores/onboarding.js +27 -27
  111. package/dist/stores/preview.js +1 -1
  112. package/dist/stores/recommendation.js +3 -3
  113. package/dist/stores/save-as-template.js +2 -2
  114. package/dist/stores/toaster.js +1 -1
  115. package/dist/stores/unsubscribe.js +1 -1
  116. package/dist/stores/version-history.js +4 -4
  117. package/dist/utils/genericUtil.js +18 -8
  118. package/package.json +11 -4
@@ -0,0 +1,76 @@
1
+ var _ = Object.defineProperty;
2
+ var I = (r, e, t) => e in r ? _(r, e, { enumerable: !0, configurable: !0, writable: !0, value: t }) : r[e] = t;
3
+ var P = (r, e, t) => I(r, typeof e != "symbol" ? e + "" : e, t);
4
+ import { ModificationDescription as F, UIElementType as m, UEAttr as C } from "../../../../../node_modules/@stripoinc/ui-editor-extensions/dist/esm/index.js";
5
+ import { CommonControl as h } from "../../../common-control.js";
6
+ import { ItemsBlockControlId as l, ItemsBlockId as A } from "../../enums/controlEnums.js";
7
+ import { productPairs as T } from "../../enums/productEnums.js";
8
+ import { useItemsBlockStore as u } from "../../store/items-block.js";
9
+ import { syncFormattedPriceFromAttributes as g } from "../../utils/syncAttributesFromConfigBlock.js";
10
+ import { updateConfigBlockAttributes as D } from "../../utils/updateAttributes.js";
11
+ const f = l.PRICE_FORMATTED_PRICE, n = {
12
+ FORMATTED_PRICE: "formattedPrice"
13
+ };
14
+ class y extends h {
15
+ constructor() {
16
+ super(...arguments);
17
+ P(this, "store", u());
18
+ }
19
+ getId() {
20
+ return f;
21
+ }
22
+ getTemplate() {
23
+ return `
24
+ <div class="${l.PRICE_FORMATTED_PRICE}">
25
+ ${this._getFormattedPrice()}
26
+ </div>
27
+ `;
28
+ }
29
+ onRender() {
30
+ this.api.updateValues({ [n.FORMATTED_PRICE]: this.store.formattedPrice }), this.api.onValueChanged(n.FORMATTED_PRICE, (t) => {
31
+ this._onFormattedPriceChange(t);
32
+ });
33
+ }
34
+ onTemplateNodeUpdated(t) {
35
+ super.onTemplateNodeUpdated(t), this.handleBlockInstanceChange(
36
+ () => g(this.currentNode),
37
+ () => {
38
+ this.api.updateValues({ [n.FORMATTED_PRICE]: this.store.formattedPrice });
39
+ }
40
+ );
41
+ }
42
+ _onFormattedPriceChange(t) {
43
+ if (console.debug("Formatted price changed to: ", t), this.store.setFormattedPrice(t), D(this.currentNode, this.api), !this.currentNode)
44
+ return;
45
+ const { itemsType: s } = this.store, i = T.PAIRS_FOR_EXTENSION.price[s], o = T.PAIRS_FOR_EXTENSION.originalPrice[s], [c, a] = t ? [i.DEFAULT_PRICE, i.DEFAULT_PRICE_FORMATTED] : [i.DEFAULT_PRICE_FORMATTED, i.DEFAULT_PRICE], [p, R] = t ? [o.DEFAULT_PRICE, o.DEFAULT_PRICE_FORMATTED] : [o.DEFAULT_PRICE_FORMATTED, o.DEFAULT_PRICE];
46
+ this._updatePriceBlock(
47
+ this.currentNode,
48
+ c,
49
+ a,
50
+ "price"
51
+ );
52
+ const d = this.currentNode.closest(".items-block"), E = d == null ? void 0 : d.querySelector(`[esd-extension-block-id="${A.ORIGINAL_PRICE}"]`);
53
+ E && this._updatePriceBlock(E, p, R, "original price");
54
+ }
55
+ _updatePriceBlock(t, s, i, o) {
56
+ const c = t.getInnerHTML().replace(s, i), a = `Updated ${o} to ${this.store.formattedPrice ? "formatted" : "unformatted"}`;
57
+ this.api.getDocumentModifier().modifyHtml(t).setInnerHtml(c).apply(new F(a));
58
+ }
59
+ _getFormattedPrice() {
60
+ return `
61
+ <div class="container">
62
+ <div class="display-flex align-items-center justify-content-between">
63
+ <${m.LABEL}
64
+ ${C.LABEL.text}="${this.api.translate("Formatted Price (e.g. $9.90)")}"
65
+ >
66
+ </${m.LABEL}>
67
+ ${this._GuToggle(n.FORMATTED_PRICE)}
68
+ </div>
69
+ </div>
70
+ `;
71
+ }
72
+ }
73
+ export {
74
+ f as CONTROL_BLOCK_ID,
75
+ y as PriceFormattedPriceControl
76
+ };
@@ -0,0 +1,61 @@
1
+ var d = Object.defineProperty;
2
+ var a = (i, e, t) => e in i ? d(i, e, { enumerable: !0, configurable: !0, writable: !0, value: t }) : i[e] = t;
3
+ var o = (i, e, t) => a(i, typeof e != "symbol" ? e + "" : e, t);
4
+ import { UIElementType as n, UEAttr as c } from "../../../../../node_modules/@stripoinc/ui-editor-extensions/dist/esm/index.js";
5
+ import { CommonControl as u } from "../../../common-control.js";
6
+ import { ItemsBlockControlId as r } from "../../enums/controlEnums.js";
7
+ import { useItemsBlockStore as D } from "../../store/items-block.js";
8
+ import { syncHideDiscountFromAttributes as p } from "../../utils/syncAttributesFromConfigBlock.js";
9
+ import { updateConfigBlockAttributes as I } from "../../utils/updateAttributes.js";
10
+ const l = r.PRICE_HIDE_DISCOUNT, s = {
11
+ HIDE_DISCOUNT: "hideDiscount"
12
+ };
13
+ class N extends u {
14
+ constructor() {
15
+ super(...arguments);
16
+ o(this, "store", D());
17
+ }
18
+ getId() {
19
+ return l;
20
+ }
21
+ getTemplate() {
22
+ return `
23
+ <div class="${r.PRICE_HIDE_DISCOUNT}">
24
+ ${this._getHideDiscount()}
25
+ </div>
26
+ `;
27
+ }
28
+ onRender() {
29
+ this.api.updateValues({ [s.HIDE_DISCOUNT]: this.store.hideDiscount }), this.api.onValueChanged(s.HIDE_DISCOUNT, (t) => {
30
+ this._onHideDiscountChange(t);
31
+ });
32
+ }
33
+ onTemplateNodeUpdated(t) {
34
+ super.onTemplateNodeUpdated(t), this.handleBlockInstanceChange(
35
+ () => p(this.currentNode),
36
+ () => {
37
+ this.api.updateValues({ [s.HIDE_DISCOUNT]: this.store.hideDiscount });
38
+ }
39
+ );
40
+ }
41
+ _onHideDiscountChange(t) {
42
+ this.store.setHideDiscount(t), I(this.currentNode, this.api), this.api.updateValues({ [s.HIDE_DISCOUNT]: t });
43
+ }
44
+ _getHideDiscount() {
45
+ return `
46
+ <div class="container">
47
+ <div class="display-flex align-items-center justify-content-between">
48
+ <${n.LABEL}
49
+ ${c.LABEL.text}="${this.api.translate("Hide if same as discounted ")}"
50
+ >
51
+ </${n.LABEL}>
52
+ ${this._GuToggle(s.HIDE_DISCOUNT)}
53
+ </div>
54
+ </div>
55
+ `;
56
+ }
57
+ }
58
+ export {
59
+ l as CONTROL_BLOCK_ID,
60
+ N as PriceHideDiscountControl
61
+ };
@@ -0,0 +1,280 @@
1
+ var M = Object.defineProperty;
2
+ var A = (u, p, e) => p in u ? M(u, p, { enumerable: !0, configurable: !0, writable: !0, value: e }) : u[p] = e;
3
+ var R = (u, p, e) => A(u, typeof p != "symbol" ? p + "" : p, e);
4
+ import { UEAttr as f, ModificationDescription as m } from "../../../../node_modules/@stripoinc/ui-editor-extensions/dist/esm/index.js";
5
+ import { CommonControl as b } from "../../common-control.js";
6
+ import { ItemsBlockId as a } from "../enums/controlEnums.js";
7
+ import { productPairs as d } from "../enums/productEnums.js";
8
+ import { ItemTypeOptions as P, OrientationOptions as x, ItemInCartOptions as S, SETTINGS_ENUMS as y } from "../enums/settingsEnums.js";
9
+ import L from "../layouts/horizontal.html.js";
10
+ import D from "../layouts/vertical.html.js";
11
+ import { useItemsBlockStore as H } from "../store/items-block.js";
12
+ import { getDefaultTemplate as U } from "../template.js";
13
+ import { updateConfigBlockAttributes as O } from "../utils/updateAttributes.js";
14
+ const $ = "ui-elements-items-block", o = {
15
+ ITEMS_TYPE: "itemsType",
16
+ ORIENTATION: "orientation",
17
+ ITEM_IDS: "itemIds"
18
+ };
19
+ class z extends b {
20
+ constructor() {
21
+ super(...arguments);
22
+ R(this, "store", H());
23
+ }
24
+ getId() {
25
+ return $;
26
+ }
27
+ getTemplate() {
28
+ return `
29
+ <div class="items-controls-container">
30
+ ${this._getItemsType()}
31
+ ${this._getItemInCart()}
32
+ ${this._getOrientation()}
33
+ </div>
34
+ `;
35
+ }
36
+ onRender() {
37
+ this.api.updateValues({
38
+ [o.ORIENTATION]: this.store.orientation,
39
+ [o.ITEMS_TYPE]: this.store.itemsType,
40
+ [o.ITEM_IDS]: this.store.itemIds
41
+ }), this._listenToFormUpdates();
42
+ }
43
+ onTemplateNodeUpdated(e) {
44
+ this.currentNode = e, this.api.updateValues({
45
+ [o.ORIENTATION]: this.store.orientation,
46
+ [o.ITEMS_TYPE]: this.store.itemsType,
47
+ [o.ITEM_IDS]: this.store.itemIds
48
+ }), this._initializeSelectItems();
49
+ }
50
+ onDestroy() {
51
+ const e = this._getTemplateData();
52
+ this.store.setTemplateData(e);
53
+ }
54
+ _getItemsType() {
55
+ return `
56
+ ${this._GuOneColumn([
57
+ this._GuLabel({ text: "Item Type" }),
58
+ this._GuSelect({
59
+ name: o.ITEMS_TYPE,
60
+ className: "es-100",
61
+ placeholder: "Select Item Type",
62
+ options: P
63
+ })
64
+ ])}
65
+ `;
66
+ }
67
+ _getOrientation() {
68
+ return `
69
+ ${this._GuTwoColumns([
70
+ this._GuLabel({ text: "Orientation" }),
71
+ this._GuRadioButton({
72
+ name: o.ORIENTATION,
73
+ buttons: x
74
+ })
75
+ ])}
76
+ `;
77
+ }
78
+ _getItemInCart() {
79
+ return `
80
+ ${this._GuTwoColumns([
81
+ this._GuLabel({ text: "Item in Cart" }),
82
+ this._GuSelect({
83
+ name: o.ITEM_IDS,
84
+ className: "es-100",
85
+ placeholder: "Select Item In Cart",
86
+ options: []
87
+ })
88
+ ])}
89
+ `;
90
+ }
91
+ _onOrientationChange(e) {
92
+ console.debug("Orientation changed to: ", e), this.store.setOrientation(e), this.api.updateValues({ [o.ORIENTATION]: e }), O(this.currentNode, this.api), this._reOrderTemplate(), this._recalculateTrimming();
93
+ }
94
+ _onItemsTypeChange(e, t) {
95
+ const { itemIds: i } = this.store, r = y.ITEMS_TYPE[e], n = S[t].findIndex((c) => c.value === i), s = S[e][n];
96
+ r && (this.store.setItemsType(r), this.store.setItemIds(s.value), O(this.currentNode, this.api), this._initializeSelectItems(), this._reFillTemplate());
97
+ }
98
+ _onItemIdsChange(e) {
99
+ console.debug("Item ids changed to: ", e), this.store.setItemIds(e), this.api.updateValues({ [o.ITEM_IDS]: e }), O(this.currentNode, this.api), this._reFillTemplate();
100
+ }
101
+ _initializeSelectItems() {
102
+ this.api.setUIEAttribute(
103
+ o.ITEMS_TYPE,
104
+ f.SELECTPICKER.items,
105
+ P
106
+ );
107
+ const { itemsType: e, itemIds: t } = this.store;
108
+ this.api.updateValues({
109
+ [o.ITEMS_TYPE]: e
110
+ });
111
+ const i = S[e];
112
+ this.api.setUIEAttribute(
113
+ o.ITEM_IDS,
114
+ f.SELECTPICKER.items,
115
+ i
116
+ ), this.api.updateValues({
117
+ [o.ITEM_IDS]: t
118
+ });
119
+ }
120
+ _listenToFormUpdates() {
121
+ this.api.onValueChanged(
122
+ o.ITEMS_TYPE,
123
+ (e, t) => this._onItemsTypeChange(e, t)
124
+ ), this.api.onValueChanged(
125
+ o.ORIENTATION,
126
+ (e) => this._onOrientationChange(e)
127
+ ), this.api.onValueChanged(
128
+ o.ITEM_IDS,
129
+ (e) => this._onItemIdsChange(e)
130
+ );
131
+ }
132
+ _renderTemplate() {
133
+ const {
134
+ orientation: e,
135
+ itemsType: t,
136
+ itemIds: i,
137
+ currencySymbol: r,
138
+ currencyLocation: n,
139
+ formattedPrice: s
140
+ } = this.store;
141
+ this.api.getDocumentModifier().modifyHtml(this.currentNode).setInnerHtml(U({
142
+ orientation: e,
143
+ itemsType: t,
144
+ itemId: i,
145
+ currencySymbol: r,
146
+ currencyLocation: n,
147
+ formattedPrice: s
148
+ })).apply(new m("Updated template"));
149
+ }
150
+ _getTemplateData() {
151
+ const { itemsType: e, itemIds: t, formattedPrice: i } = this.store, r = S[e].findIndex((s) => s.value === t), n = r > -1 ? r : 0;
152
+ return {
153
+ imageSrc: d.PAIRS_FOR_EXTENSION.imageSrc[e].DEFAULT[n],
154
+ name: d.PAIRS_FOR_EXTENSION.name[e].DEFAULT[n],
155
+ price: i ? d.PAIRS_FOR_EXTENSION.price[e].DEFAULT_PRICE_FORMATTED : d.PAIRS_FOR_EXTENSION.price[e].DEFAULT_PRICE,
156
+ originalPrice: i ? d.PAIRS_FOR_EXTENSION.originalPrice[e].DEFAULT_PRICE_FORMATTED : d.PAIRS_FOR_EXTENSION.originalPrice[e].DEFAULT_PRICE,
157
+ quantity: d.PAIRS_FOR_EXTENSION.quantity[e].DEFAULT,
158
+ button: d.PAIRS_FOR_EXTENSION.button[e].DEFAULT_LABEL
159
+ };
160
+ }
161
+ _updateImageSrc(e) {
162
+ var i;
163
+ const t = (i = this.currentNode) == null ? void 0 : i.querySelector(`[esd-extension-block-id="${a.IMAGE}"] img`);
164
+ t && this.api.getDocumentModifier().modifyHtml(t).setAttribute("src", e).apply(new m("Updated image src"));
165
+ }
166
+ _updateName(e) {
167
+ var n;
168
+ const t = (n = this.currentNode) == null ? void 0 : n.querySelector(`[esd-extension-block-id="${a.NAME}"]`);
169
+ if (!t)
170
+ return;
171
+ const i = t.getInnerText().trim();
172
+ let r = t.getInnerHTML();
173
+ r = r.replace(i, e), this.api.getDocumentModifier().modifyHtml(t).setInnerHtml(r).apply(new m("Updated name"));
174
+ }
175
+ _updatePrice(e) {
176
+ var g;
177
+ const t = (g = this.currentNode) == null ? void 0 : g.querySelector(`[esd-extension-block-id="${a.PRICE}"]`);
178
+ if (!t)
179
+ return;
180
+ const i = this._getParagraphFromBlock(t);
181
+ if (!i)
182
+ return;
183
+ const r = i.getInnerHTML() || "", n = i.getInnerText() || "", { currencySymbol: s, currencyLocation: c } = this.store, I = (s == null ? void 0 : s.trim()) || "", l = this._removeCurrencySymbol(n, I), T = this._replacePriceNumber(l, e), h = this._buildPriceContent(T, I, c), _ = r.replace(n, h);
184
+ this.api.getDocumentModifier().modifyHtml(i).setInnerHtml(_).apply(new m("Updated price"));
185
+ }
186
+ _updateOriginalPrice(e) {
187
+ var E;
188
+ const t = (E = this.currentNode) == null ? void 0 : E.querySelector(
189
+ `[esd-extension-block-id="${a.ORIGINAL_PRICE}"]`
190
+ );
191
+ if (!t)
192
+ return;
193
+ const i = this._getParagraphFromBlock(t);
194
+ if (!i)
195
+ return;
196
+ const r = i.querySelector("s");
197
+ if (!r)
198
+ return;
199
+ const n = r.getInnerHTML() || "", s = r.getInnerText() || "", { currencySymbol: c, currencyLocation: I } = this.store, l = (c == null ? void 0 : c.trim()) || "", T = this._removeCurrencySymbol(s, l), h = this._replacePriceNumber(T, e), _ = this._buildPriceContent(h, l, I), N = `<s>${n.replace(s, _)}</s>`;
200
+ this.api.getDocumentModifier().modifyHtml(i).setInnerHtml(N).apply(new m("Updated original price"));
201
+ }
202
+ _updateQuantity(e) {
203
+ var n;
204
+ const t = (n = this.currentNode) == null ? void 0 : n.querySelector(`[esd-extension-block-id="${a.QUANTITY}"]`);
205
+ if (!t)
206
+ return;
207
+ const i = t.getInnerText().trim();
208
+ let r = t.getInnerHTML();
209
+ r = r.replace(i, e), this.api.getDocumentModifier().modifyHtml(t).setInnerHtml(r).apply(new m("Updated quantity"));
210
+ }
211
+ _updateButton(e) {
212
+ var n;
213
+ const t = (n = this.currentNode) == null ? void 0 : n.querySelector(`[esd-extension-block-id="${a.BUTTON}"]`);
214
+ if (!t)
215
+ return;
216
+ const i = t.getInnerText().trim();
217
+ let r = t.getInnerHTML();
218
+ r = r.replace(i, e), this.api.getDocumentModifier().modifyHtml(t).setInnerHtml(r).apply(new m("Updated button"));
219
+ }
220
+ _reOrderTemplate() {
221
+ var T, h, _, g, N, E, C;
222
+ const e = (T = this.currentNode) == null ? void 0 : T.querySelector(`[esd-extension-block-id="${a.IMAGE}"]`), t = (h = this.currentNode) == null ? void 0 : h.querySelector(`[esd-extension-block-id="${a.NAME}"]`), i = (_ = this.currentNode) == null ? void 0 : _.querySelector(`[esd-extension-block-id="${a.PRICE}"]`), r = (g = this.currentNode) == null ? void 0 : g.querySelector(
223
+ `[esd-extension-block-id="${a.ORIGINAL_PRICE}"]`
224
+ ), n = (N = this.currentNode) == null ? void 0 : N.querySelector(`[esd-extension-block-id="${a.QUANTITY}"]`), s = (E = this.currentNode) == null ? void 0 : E.querySelector(`[esd-extension-block-id="${a.BUTTON}"]`), c = (C = this.currentNode) == null ? void 0 : C.querySelector("esd-config-block");
225
+ if (!e || !t || !i || !r || !n || !s || !c)
226
+ return;
227
+ const { orientation: I } = this.store;
228
+ let l = I === y.ORIENTATION.VERTICAL ? D : L;
229
+ l = l.replace("{-{-PRODUCT_IMAGE-}-}", e.getOuterHTML()).replace("{-{-PRODUCT_NAME-}-}", t.getOuterHTML()).replace("{-{-PRODUCT_PRICE-}-}", i.getOuterHTML()).replace("{-{-PRODUCT_ORIGINAL_PRICE-}-}", r.getOuterHTML()).replace("{-{-PRODUCT_QUANTITY-}-}", n.getOuterHTML()).replace("{-{-PRODUCT_BUTTON-}-}", s.getOuterHTML()).replace("{-{-CONFIG_BLOCK-}-}", c.getOuterHTML()), l = l.trim().replace('<td align="center" class="ins-product-td items-block">', "").slice(0, -5), this.api.getDocumentModifier().modifyHtml(this.currentNode).setInnerHtml(l).apply(new m("Reordered template"));
230
+ }
231
+ _reFillTemplate() {
232
+ const e = this._getTemplateData();
233
+ this._updateImageSrc(e.imageSrc), this._updateName(e.name), this._updatePrice(e.price), this._updateOriginalPrice(e.originalPrice), this._updateQuantity(e.quantity), this._updateButton(e.button);
234
+ }
235
+ _recalculateTrimming() {
236
+ var r;
237
+ if (!this.store.nameTrimming || !this.currentNode)
238
+ return;
239
+ const e = (r = this.currentNode) == null ? void 0 : r.querySelector(`[esd-extension-block-id="${a.NAME}"]`);
240
+ if (!e)
241
+ return;
242
+ const t = e.querySelector("p");
243
+ if (!t)
244
+ return;
245
+ const i = this.store.orientation === y.ORIENTATION.VERTICAL;
246
+ this.api.getDocumentModifier().modifyHtml(t).setStyle("white-space", "nowrap").setStyle("overflow", "hidden").setStyle("text-overflow", "ellipsis").setStyle("max-width", i ? "130px" : "100%").apply(new m("Recalculated trimming after orientation change"));
247
+ }
248
+ _getParagraphFromBlock(e) {
249
+ return e.querySelector("p");
250
+ }
251
+ _escapeRegex(e) {
252
+ return e.replace(/[-\\^$*+?().|[\]{}]/g, "\\$&");
253
+ }
254
+ _removeCurrencySymbol(e, t) {
255
+ const i = e || "";
256
+ let r = i;
257
+ if (t) {
258
+ const n = new RegExp(`\\s*${this._escapeRegex(t)}\\s*`);
259
+ r = i.replace(n, "").trim();
260
+ } else {
261
+ const n = i.match(/([^0-9.,\s]+)/);
262
+ if (n && n[1]) {
263
+ const s = n[1].trim(), c = new RegExp(`\\s*${this._escapeRegex(s)}\\s*`);
264
+ r = i.replace(c, "").trim();
265
+ }
266
+ }
267
+ return r;
268
+ }
269
+ _replacePriceNumber(e, t) {
270
+ const i = /([0-9][0-9,.]*)/;
271
+ return e.replace(i, t).trim();
272
+ }
273
+ _buildPriceContent(e, t, i) {
274
+ return t ? i === "1" ? `${e}&nbsp;${t}&nbsp;` : `${t}&nbsp;${e}` : e;
275
+ }
276
+ }
277
+ export {
278
+ $ as CONTROL_BLOCK_ID,
279
+ z as ItemsBlockControl
280
+ };
@@ -0,0 +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 || {}), b = /* @__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.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))(b || {});
2
+ export {
3
+ b as ItemsBlockControlId,
4
+ c as ItemsBlockId
5
+ };
@@ -0,0 +1,195 @@
1
+ const e = {
2
+ TYPE: "data-type",
3
+ ITEMS_INDEX_SELECT_CONTROL_VALUE: "data-cart_items_select_control_value",
4
+ ORIENTATION: "data-card_orientation_control_value",
5
+ PRODUCT_NAME_TRIMMING: "data-product_name_trimming",
6
+ PRODUCT_PRICE_HIDE_DISCOUNT: "data-product_price_hide_discount",
7
+ PRODUCT_PRICE_FORMATTED: "data-product_price_formatted",
8
+ PRODUCT_PRICE_CURRENCY_SYMBOL: "data-product_price_currency_symbol",
9
+ PRODUCT_PRICE_CURRENCY_LOCATION: "data-product_price_currency_location",
10
+ PRODUCT_BUTTON_LINK: "data-product_button_link",
11
+ PRODUCT_IMAGE_LINK: "data-product_image_link",
12
+ PRODUCT_NAME_CONTROL_VALUE: "data-product_name_control_value",
13
+ PRODUCT_QUANTITY_CONTROL_VALUE: "data-product_quantity_control_value",
14
+ PRODUCT_PRICE_CONTROL_VALUE: "data-product_price_control_value",
15
+ BLOCK_INSTANCE_ID: "data-block-instance-id",
16
+ NAME_CONTROL_ENABLED: "data-product_name_control_enabled",
17
+ QUANTITY_CONTROL_ENABLED: "data-product_quantity_control_enabled",
18
+ PRICE_CONTROL_OPENED: "data-product_price_control_opened"
19
+ }, s = { PAIRS_FOR_EXTENSION: {
20
+ imageSrc: {
21
+ CART_ITEMS: {
22
+ ATTR: "ins_apr_img",
23
+ DEFAULT: [
24
+ "https://s3-eu-west-1.amazonaws.com/web-image.useinsider.com/email-assets/dummyImages/products/ins_apr_img_1.jpeg",
25
+ "https://s3-eu-west-1.amazonaws.com/web-image.useinsider.com/email-assets/dummyImages/products/ins_apr_img_2.webp",
26
+ "https://s3-eu-west-1.amazonaws.com/web-image.useinsider.com/email-assets/dummyImages/products/ins_apr_img_3.jpeg",
27
+ "https://s3-eu-west-1.amazonaws.com/web-image.useinsider.com/email-assets/dummyImages/products/ins_apr_img_4.jpeg",
28
+ "https://s3-eu-west-1.amazonaws.com/web-image.useinsider.com/email-assets/dummyImages/products/ins_apr_img_5.jpeg",
29
+ "https://s3-eu-west-1.amazonaws.com/web-image.useinsider.com/email-assets/dummyImages/products/ins_apr_img_6.jpeg",
30
+ "https://s3-eu-west-1.amazonaws.com/web-image.useinsider.com/email-assets/dummyImages/products/ins_apr_img_7.jpeg",
31
+ "https://s3-eu-west-1.amazonaws.com/web-image.useinsider.com/email-assets/dummyImages/products/ins_apr_img_8.jpeg"
32
+ ]
33
+ },
34
+ BROWSED_ITEMS: {
35
+ ATTR: "browsed_item_img",
36
+ DEFAULT: [
37
+ "https://s3-eu-west-1.amazonaws.com/web-image.useinsider.com/email-assets/dummyImages/products/ins_apr_img_1.jpeg",
38
+ "https://s3-eu-west-1.amazonaws.com/web-image.useinsider.com/email-assets/dummyImages/products/ins_apr_img_2.webp",
39
+ "https://s3-eu-west-1.amazonaws.com/web-image.useinsider.com/email-assets/dummyImages/products/ins_apr_img_3.jpeg",
40
+ "https://s3-eu-west-1.amazonaws.com/web-image.useinsider.com/email-assets/dummyImages/products/ins_apr_img_4.jpeg",
41
+ "https://s3-eu-west-1.amazonaws.com/web-image.useinsider.com/email-assets/dummyImages/products/ins_apr_img_5.jpeg",
42
+ "https://s3-eu-west-1.amazonaws.com/web-image.useinsider.com/email-assets/dummyImages/products/ins_apr_img_6.jpeg",
43
+ "https://s3-eu-west-1.amazonaws.com/web-image.useinsider.com/email-assets/dummyImages/products/ins_apr_img_7.jpeg",
44
+ "https://s3-eu-west-1.amazonaws.com/web-image.useinsider.com/email-assets/dummyImages/products/ins_apr_img_8.jpeg"
45
+ ]
46
+ },
47
+ PURCHASED_ITEMS: {
48
+ ATTR: "purchased_item_img",
49
+ DEFAULT: [
50
+ "https://s3-eu-west-1.amazonaws.com/web-image.useinsider.com/email-assets/dummyImages/products/ins_apr_img_1.jpeg",
51
+ "https://s3-eu-west-1.amazonaws.com/web-image.useinsider.com/email-assets/dummyImages/products/ins_apr_img_2.webp",
52
+ "https://s3-eu-west-1.amazonaws.com/web-image.useinsider.com/email-assets/dummyImages/products/ins_apr_img_3.jpeg",
53
+ "https://s3-eu-west-1.amazonaws.com/web-image.useinsider.com/email-assets/dummyImages/products/ins_apr_img_4.jpeg",
54
+ "https://s3-eu-west-1.amazonaws.com/web-image.useinsider.com/email-assets/dummyImages/products/ins_apr_img_5.jpeg",
55
+ "https://s3-eu-west-1.amazonaws.com/web-image.useinsider.com/email-assets/dummyImages/products/ins_apr_img_6.jpeg",
56
+ "https://s3-eu-west-1.amazonaws.com/web-image.useinsider.com/email-assets/dummyImages/products/ins_apr_img_7.jpeg",
57
+ "https://s3-eu-west-1.amazonaws.com/web-image.useinsider.com/email-assets/dummyImages/products/ins_apr_img_8.jpeg"
58
+ ]
59
+ }
60
+ },
61
+ name: {
62
+ CART_ITEMS: {
63
+ ATTR: "ins_apr_name",
64
+ DEFAULT: [
65
+ "Aim Analog Watch",
66
+ "Set of Sprite Yoga Straps",
67
+ "Overnight Duffle",
68
+ "Zeppelin Yoga Pant",
69
+ "Quest Lumaflex™ Band",
70
+ "Ajax Full-Zip Sweatshirt - Versus",
71
+ "Compete Track Tote",
72
+ "Miko Pullover Hoodie"
73
+ ],
74
+ HREF: "ins_apr_url",
75
+ DEFAULT_HREF: "#!"
76
+ },
77
+ BROWSED_ITEMS: {
78
+ ATTR: "browsed_item_name",
79
+ DEFAULT: [
80
+ "Aim Analog Watch",
81
+ "Set of Sprite Yoga Straps",
82
+ "Overnight Duffle",
83
+ "Zeppelin Yoga Pant",
84
+ "Quest Lumaflex™ Band",
85
+ "Ajax Full-Zip Sweatshirt - Versus",
86
+ "Compete Track Tote",
87
+ "Miko Pullover Hoodie"
88
+ ],
89
+ HREF: "browsed_item_url",
90
+ DEFAULT_HREF: "#!"
91
+ },
92
+ PURCHASED_ITEMS: {
93
+ ATTR: "purchased_item_name",
94
+ DEFAULT: [
95
+ "Aim Analog Watch",
96
+ "Set of Sprite Yoga Straps",
97
+ "Overnight Duffle",
98
+ "Zeppelin Yoga Pant",
99
+ "Quest Lumaflex™ Band",
100
+ "Ajax Full-Zip Sweatshirt - Versus",
101
+ "Compete Track Tote",
102
+ "Miko Pullover Hoodie"
103
+ ],
104
+ HREF: "purchased_item_url",
105
+ DEFAULT_HREF: "#!"
106
+ }
107
+ },
108
+ quantity: {
109
+ CART_ITEMS: {
110
+ ATTR: "ins_apr_quantity",
111
+ DEFAULT: "3"
112
+ },
113
+ BROWSED_ITEMS: {
114
+ ATTR: "browsed_item_quantity",
115
+ DEFAULT: "7"
116
+ },
117
+ PURCHASED_ITEMS: {
118
+ ATTR: "purchased_item_quantity",
119
+ DEFAULT: "10"
120
+ }
121
+ },
122
+ price: {
123
+ CART_ITEMS: {
124
+ PRICE: "ins_apr_price",
125
+ PRICE_FORMATTED: "ins_apr_formattedprice",
126
+ CURRENCY: "ins_apr_productcurrency",
127
+ DEFAULT_PRICE: "1100.00",
128
+ DEFAULT_PRICE_FORMATTED: "1,100.00",
129
+ DEFAULT_CURRENCY: "USD"
130
+ },
131
+ BROWSED_ITEMS: {
132
+ PRICE: "browsed_item_price",
133
+ PRICE_FORMATTED: "browsed_item_formattedprice",
134
+ CURRENCY: "browsed_item_productcurrency",
135
+ DEFAULT_PRICE: "1249.99",
136
+ DEFAULT_PRICE_FORMATTED: "1,249.99",
137
+ DEFAULT_CURRENCY: "USD"
138
+ },
139
+ PURCHASED_ITEMS: {
140
+ PRICE: "purchased_item_price",
141
+ PRICE_FORMATTED: "purchased_item_formattedprice",
142
+ CURRENCY: "purchased_item_productcurrency",
143
+ DEFAULT_PRICE: "1490.49",
144
+ DEFAULT_PRICE_FORMATTED: "1,490.49",
145
+ DEFAULT_CURRENCY: "USD"
146
+ }
147
+ },
148
+ originalPrice: {
149
+ CART_ITEMS: {
150
+ PRICE: "ins_apr_originalprice",
151
+ PRICE_FORMATTED: "ins_apr_originalformattedprice",
152
+ CURRENCY: "ins_apr_productcurrency",
153
+ DEFAULT_PRICE: "1600.00",
154
+ DEFAULT_PRICE_FORMATTED: "1,600.00",
155
+ DEFAULT_CURRENCY: "USD"
156
+ },
157
+ BROWSED_ITEMS: {
158
+ PRICE: "browsed_item_originalprice",
159
+ PRICE_FORMATTED: "browsed_item_originalformattedprice",
160
+ CURRENCY: "browsed_item_productcurrency",
161
+ DEFAULT_PRICE: "2049.99",
162
+ DEFAULT_PRICE_FORMATTED: "2,049.99",
163
+ DEFAULT_CURRENCY: "USD"
164
+ },
165
+ PURCHASED_ITEMS: {
166
+ PRICE: "purchased_item_originalprice",
167
+ PRICE_FORMATTED: "purchased_item_originalformattedprice",
168
+ CURRENCY: "purchased_item_productcurrency",
169
+ DEFAULT_PRICE: "1890.49",
170
+ DEFAULT_PRICE_FORMATTED: "1,890.49",
171
+ DEFAULT_CURRENCY: "USD"
172
+ }
173
+ },
174
+ button: {
175
+ CART_ITEMS: {
176
+ HREF: "ins_apr_url",
177
+ DEFAULT_HREF: "#!",
178
+ DEFAULT_LABEL: "Buy"
179
+ },
180
+ BROWSED_ITEMS: {
181
+ HREF: "browsed_item_url",
182
+ DEFAULT_HREF: "#!",
183
+ DEFAULT_LABEL: "Buy"
184
+ },
185
+ PURCHASED_ITEMS: {
186
+ HREF: "purchased_item_url",
187
+ DEFAULT_HREF: "#!",
188
+ DEFAULT_LABEL: "Buy"
189
+ }
190
+ }
191
+ } };
192
+ export {
193
+ e as configAttributes,
194
+ s as productPairs
195
+ };