@useinsider/guido 2.1.0-beta.29e4650 → 2.1.0-beta.2d0ecb3

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 (98) hide show
  1. package/README.md +36 -0
  2. package/dist/@types/config/schemas.js +70 -65
  3. package/dist/components/Guido.vue.js +1 -1
  4. package/dist/components/Guido.vue2.js +69 -58
  5. package/dist/components/organisms/base/Toaster.vue.js +4 -4
  6. package/dist/components/organisms/base/Toaster.vue2.js +12 -9
  7. package/dist/components/organisms/email-preview/desktop-preview/EmailSizeIndicator.vue.js +5 -5
  8. package/dist/components/organisms/email-preview/desktop-preview/EmailSizeIndicator.vue2.js +2 -2
  9. package/dist/components/organisms/unsubscribe/UnsubscribePageSelection.vue.js +1 -1
  10. package/dist/components/organisms/unsubscribe/UnsubscribePageSelection.vue2.js +19 -19
  11. package/dist/composables/useBlocksConfig.js +26 -16
  12. package/dist/composables/useHtmlValidator.js +107 -119
  13. package/dist/composables/useRecommendation.js +9 -9
  14. package/dist/composables/useStripo.js +25 -23
  15. package/dist/composables/useVersionHistoryApi.js +1 -1
  16. package/dist/config/compiler/utils/recommendationCompilerUtils.js +28 -23
  17. package/dist/config/i18n/en/index.js +11 -0
  18. package/dist/config/i18n/en/labels.json.js +7 -0
  19. package/dist/config/i18n/en/toasters.json.js +56 -0
  20. package/dist/config/i18n/en/tooltips.json.js +82 -0
  21. package/dist/config/i18n/index.js +7 -0
  22. package/dist/config/migrator/itemsBlockMigrator.js +127 -122
  23. package/dist/config/migrator/recommendationMigrator.js +1 -1
  24. package/dist/enums/defaults.js +8 -4
  25. package/dist/extensions/Blocks/Recommendation/block.js +24 -23
  26. package/dist/extensions/Blocks/Recommendation/constants/defaultConfig.js +37 -33
  27. package/dist/extensions/Blocks/Recommendation/constants/layout.js +16 -12
  28. package/dist/extensions/Blocks/Recommendation/constants/selectors.js +15 -11
  29. package/dist/extensions/Blocks/Recommendation/controls/button/index.js +9 -9
  30. package/dist/extensions/Blocks/Recommendation/controls/image/index.js +1 -1
  31. package/dist/extensions/Blocks/Recommendation/controls/layout/index.js +41 -29
  32. package/dist/extensions/Blocks/Recommendation/controls/main/algorithm.js +16 -16
  33. package/dist/extensions/Blocks/Recommendation/controls/main/currency.js +30 -32
  34. package/dist/extensions/Blocks/Recommendation/controls/main/index.js +203 -99
  35. package/dist/extensions/Blocks/Recommendation/controls/main/locale.js +9 -9
  36. package/dist/extensions/Blocks/Recommendation/controls/main/productLayout.js +97 -39
  37. package/dist/extensions/Blocks/Recommendation/controls/main/shuffle.js +16 -16
  38. package/dist/extensions/Blocks/Recommendation/controls/main/utils.js +304 -209
  39. package/dist/extensions/Blocks/Recommendation/controls/mobileLayout/cssRules.js +21 -0
  40. package/dist/extensions/Blocks/Recommendation/controls/name/index.js +10 -10
  41. package/dist/extensions/Blocks/Recommendation/controls/name/textTrim.js +5 -5
  42. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/index.js +14 -14
  43. package/dist/extensions/Blocks/Recommendation/controls/omnibusDiscount/index.js +9 -9
  44. package/dist/extensions/Blocks/Recommendation/controls/omnibusDiscount/textAfter.js +3 -3
  45. package/dist/extensions/Blocks/Recommendation/controls/omnibusDiscount/textBefore.js +1 -1
  46. package/dist/extensions/Blocks/Recommendation/controls/omnibusPrice/index.js +9 -9
  47. package/dist/extensions/Blocks/Recommendation/controls/omnibusPrice/textAfter.js +3 -3
  48. package/dist/extensions/Blocks/Recommendation/controls/omnibusPrice/textBefore.js +3 -3
  49. package/dist/extensions/Blocks/Recommendation/controls/price/index.js +3 -3
  50. package/dist/extensions/Blocks/Recommendation/controls/spacing/index.js +223 -99
  51. package/dist/extensions/Blocks/Recommendation/store/recommendation.js +94 -55
  52. package/dist/extensions/Blocks/Recommendation/templates/grid/elementRenderer.js +25 -30
  53. package/dist/extensions/Blocks/Recommendation/templates/grid/migration.js +1 -1
  54. package/dist/extensions/Blocks/Recommendation/templates/grid/template.js +27 -30
  55. package/dist/extensions/Blocks/Recommendation/templates/list/elementRenderer.js +20 -25
  56. package/dist/extensions/Blocks/Recommendation/templates/utils.js +47 -31
  57. package/dist/extensions/Blocks/Unsubscribe/block.js +29 -29
  58. package/dist/extensions/Blocks/Unsubscribe/control.js +12 -9
  59. package/dist/extensions/Blocks/Unsubscribe/elements/preview.js +13 -11
  60. package/dist/extensions/Blocks/Unsubscribe/styles.css.js +31 -1
  61. package/dist/extensions/ModulesTabIcons/extension.js +17 -0
  62. package/dist/guido.css +1 -1
  63. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/esm/index.js +257 -187
  64. package/dist/services/stripoApi.js +20 -17
  65. package/dist/src/@types/config/schemas.d.ts +8 -0
  66. package/dist/src/composables/useConfig.d.ts +4 -0
  67. package/dist/src/config/i18n/en/index.d.ts +1 -0
  68. package/dist/src/config/i18n/index.d.ts +16 -0
  69. package/dist/src/enums/defaults.d.ts +4 -0
  70. package/dist/src/extensions/Blocks/Recommendation/constants/defaultConfig.d.ts +6 -0
  71. package/dist/src/extensions/Blocks/Recommendation/constants/index.d.ts +3 -3
  72. package/dist/src/extensions/Blocks/Recommendation/constants/layout.d.ts +12 -2
  73. package/dist/src/extensions/Blocks/Recommendation/constants/selectors.d.ts +12 -1
  74. package/dist/src/extensions/Blocks/Recommendation/controls/main/index.d.ts +45 -10
  75. package/dist/src/extensions/Blocks/Recommendation/controls/main/productLayout.d.ts +22 -4
  76. package/dist/src/extensions/Blocks/Recommendation/controls/main/utils.d.ts +36 -16
  77. package/dist/src/extensions/Blocks/Recommendation/controls/mobileLayout/cssRules.d.ts +29 -0
  78. package/dist/src/extensions/Blocks/Recommendation/controls/spacing/index.d.ts +50 -17
  79. package/dist/src/extensions/Blocks/Recommendation/store/recommendation.d.ts +1 -0
  80. package/dist/src/extensions/Blocks/Recommendation/templates/grid/migration.d.ts +1 -1
  81. package/dist/src/extensions/Blocks/Recommendation/templates/grid/template.d.ts +1 -1
  82. package/dist/src/extensions/Blocks/Recommendation/templates/index.d.ts +4 -0
  83. package/dist/src/extensions/Blocks/Recommendation/templates/list/migration.d.ts +1 -1
  84. package/dist/src/extensions/Blocks/Recommendation/templates/utils.d.ts +11 -2
  85. package/dist/src/extensions/Blocks/Recommendation/types/nodeConfig.d.ts +14 -0
  86. package/dist/src/extensions/Blocks/Unsubscribe/control.d.ts +1 -0
  87. package/dist/src/extensions/ModulesTabIcons/extension.d.ts +2 -0
  88. package/dist/src/stores/config.d.ts +36 -0
  89. package/dist/static/styles/components/notification.css.js +19 -0
  90. package/dist/static/styles/components/tools.css.js +6 -2
  91. package/dist/static/styles/components/version-history.css.js +10 -2
  92. package/dist/static/styles/components/wide-panel.css.js +18 -2
  93. package/dist/static/styles/customEditorStyle.css.js +59 -31
  94. package/dist/static/styles/variables.css.js +2 -0
  95. package/dist/static/templates/empty/index.html.js +74 -0
  96. package/dist/static/templates/empty/style.css.js +779 -0
  97. package/dist/stores/unsubscribe.js +37 -34
  98. package/package.json +1 -1
@@ -1,8 +1,8 @@
1
- var B = Object.defineProperty;
2
- var U = (r, t, e) => t in r ? B(r, t, { enumerable: !0, configurable: !0, writable: !0, value: e }) : r[t] = e;
3
- var M = (r, t, e) => U(r, typeof t != "symbol" ? t + "" : t, e);
4
- import { productPairs as v } from "../../extensions/Blocks/Items/enums/productEnums.js";
5
- import { ItemInCartOptions as E, DefaultConfigValues as g, SETTINGS_ENUMS as d } from "../../extensions/Blocks/Items/enums/settingsEnums.js";
1
+ var v = Object.defineProperty;
2
+ var B = (e, t, r) => t in e ? v(e, t, { enumerable: !0, configurable: !0, writable: !0, value: r }) : e[t] = r;
3
+ var M = (e, t, r) => B(e, typeof t != "symbol" ? t + "" : t, r);
4
+ import { productPairs as U } from "../../extensions/Blocks/Items/enums/productEnums.js";
5
+ import { ItemInCartOptions as T, DefaultConfigValues as g, SETTINGS_ENUMS as u } from "../../extensions/Blocks/Items/enums/settingsEnums.js";
6
6
  import { getDefaultTemplate as K } from "../../extensions/Blocks/Items/template.js";
7
7
  const w = {
8
8
  img: {
@@ -74,76 +74,77 @@ const w = {
74
74
  function F() {
75
75
  return String(Date.now() + Math.floor(Math.random() * 1e3));
76
76
  }
77
- function q(r) {
78
- return r ? {
79
- CartItems: d.ITEMS_TYPE.CART_ITEMS,
80
- BrowsedItems: d.ITEMS_TYPE.BROWSED_ITEMS,
81
- PurchasedItems: d.ITEMS_TYPE.PURCHASED_ITEMS,
82
- CART_ITEMS: d.ITEMS_TYPE.CART_ITEMS,
83
- BROWSED_ITEMS: d.ITEMS_TYPE.BROWSED_ITEMS,
84
- PURCHASED_ITEMS: d.ITEMS_TYPE.PURCHASED_ITEMS
85
- }[r] || d.ITEMS_TYPE.CART_ITEMS : d.ITEMS_TYPE.CART_ITEMS;
77
+ function q(e) {
78
+ return e ? {
79
+ CartItems: u.ITEMS_TYPE.CART_ITEMS,
80
+ BrowsedItems: u.ITEMS_TYPE.BROWSED_ITEMS,
81
+ PurchasedItems: u.ITEMS_TYPE.PURCHASED_ITEMS,
82
+ CART_ITEMS: u.ITEMS_TYPE.CART_ITEMS,
83
+ BROWSED_ITEMS: u.ITEMS_TYPE.BROWSED_ITEMS,
84
+ PURCHASED_ITEMS: u.ITEMS_TYPE.PURCHASED_ITEMS
85
+ }[e] || u.ITEMS_TYPE.CART_ITEMS : u.ITEMS_TYPE.CART_ITEMS;
86
86
  }
87
- function R(r) {
88
- const t = (a, o) => a == null ? o : a === "1" || a === "true", e = (a, o) => a || o, i = r["data-type"] || r["data-source"], l = q(i);
89
- let n = r["data-cart_items_select_control_value"] || g.cartItemsSelectControlValue;
90
- if (n && !n.includes("{{") && /^\d+$/.test(n)) {
91
- const a = parseInt(n) - 1, o = E[l];
92
- o && o[a] && (n = o[a].value);
87
+ function R(e) {
88
+ var a;
89
+ const t = (_, c) => _ == null ? c : _ === "1" || _ === "true", r = (_, c) => _ || c, l = e["data-type"] || e["data-source"], i = q(l), n = T[i];
90
+ let o = e["data-cart_items_select_control_value"] || ((a = n == null ? void 0 : n[0]) == null ? void 0 : a.value) || g.cartItemsSelectControlValue;
91
+ if (o && !o.includes("{{") && /^\d+$/.test(o)) {
92
+ const _ = parseInt(o) - 1, c = T[i];
93
+ c && c[_] && (o = c[_].value);
93
94
  }
94
95
  return {
95
96
  initialized: !0,
96
- blockInstanceId: e(r["data-block-instance-id"], F()),
97
- source: l,
98
- type: l,
99
- itemsSelectValue: n,
100
- orientation: r["data-card_orientation_control_value"] || d.ORIENTATION.VERTICAL,
101
- nameTrimming: t(r["data-product_name_control_trim"], !0),
102
- priceHideDiscount: t(r["data-product_price_control_nodup"], !0),
103
- priceFormatted: t(r["data-product_price_control_formated"], !0),
104
- priceSinglePrice: t(r["data-product_price_control_single_price"], !1),
105
- priceCurrencySymbol: e(
106
- r["data-product_price_control_currency_symbol"],
97
+ blockInstanceId: r(e["data-block-instance-id"], F()),
98
+ source: i,
99
+ type: i,
100
+ itemsSelectValue: o,
101
+ orientation: e["data-card_orientation_control_value"] || u.ORIENTATION.VERTICAL,
102
+ nameTrimming: t(e["data-product_name_control_trim"], !0),
103
+ priceHideDiscount: t(e["data-product_price_control_nodup"], !0),
104
+ priceFormatted: t(e["data-product_price_control_formated"], !0),
105
+ priceSinglePrice: t(e["data-product_price_control_single_price"], !1),
106
+ priceCurrencySymbol: r(
107
+ e["data-product_price_control_currency_symbol"],
107
108
  g.productPriceCurrencySymbolControlValue
108
109
  ),
109
- priceCurrencyLocation: e(
110
- r["data-product_price_currency_location"],
110
+ priceCurrencyLocation: r(
111
+ e["data-product_price_currency_location"],
111
112
  g.productPriceCurrencyLocationControlValue
112
113
  ),
113
- priceOrientation: r["data-product_original_price_control_orientation"] || "horizontal",
114
- quantityControlEnabled: t(r["data-product_quantity_control_enabled"], !0),
115
- buttonLink: e(r["data-product_button_link"], g.productButtonLinkControlValue),
116
- imageLink: e(r["data-product_image_link"], g.productImageLinkControlValue),
117
- buttonLabel: e(r["data-product_button_control_label"], "Buy"),
118
- buttonFullWidth: t(r["data-product_button_control_atw"], !0),
119
- imageVisible: t(r["data-product_image_control_enabled"], !0),
120
- nameVisible: t(r["data-product_name_control_enabled"], !0),
121
- quantityVisible: t(r["data-product_quantity_control_enabled"], !0),
122
- priceVisible: t(r["data-product_price_control_enabled"], !0),
123
- originalPriceVisible: t(r["data-product_original_price_control_enabled"], !0),
124
- buttonVisible: t(r["data-product_button_control_enabled"], !0)
114
+ priceOrientation: e["data-product_original_price_control_orientation"] || "horizontal",
115
+ quantityControlEnabled: t(e["data-product_quantity_control_enabled"], !0),
116
+ buttonLink: r(e["data-product_button_link"], g.productButtonLinkControlValue),
117
+ imageLink: r(e["data-product_image_link"], g.productImageLinkControlValue),
118
+ buttonLabel: r(e["data-product_button_control_label"], "Buy"),
119
+ buttonFullWidth: t(e["data-product_button_control_atw"], !0),
120
+ imageVisible: t(e["data-product_image_control_enabled"], !0),
121
+ nameVisible: t(e["data-product_name_control_enabled"], !0),
122
+ quantityVisible: t(e["data-product_quantity_control_enabled"], !0),
123
+ priceVisible: t(e["data-product_price_control_enabled"], !0),
124
+ originalPriceVisible: t(e["data-product_original_price_control_enabled"], !0),
125
+ buttonVisible: t(e["data-product_button_control_enabled"], !0)
125
126
  };
126
127
  }
127
- const $ = {
128
+ const O = {
128
129
  ins_apr: "CART_ITEMS",
129
130
  browsed_item: "BROWSED_ITEMS",
130
131
  purchased_item: "PURCHASED_ITEMS"
131
132
  };
132
- function x(r, t) {
133
- const e = {
133
+ function $(e, t) {
134
+ const r = {
134
135
  CART_ITEMS: `{{Abandoned Cart Item (${t}) Image}}`,
135
136
  BROWSED_ITEMS: `{{Browsed Item (${t}) Image}}`,
136
137
  PURCHASED_ITEMS: `{{Purchased Item (${t}) Image}}`
137
138
  };
138
- return e[r] || e.CART_ITEMS;
139
+ return r[e] || r.CART_ITEMS;
139
140
  }
140
- function O(r, t) {
141
- const e = {
141
+ function x(e, t) {
142
+ const r = {
142
143
  CART_ITEMS: `{{Abandoned Cart Item (${t}) Url}}`,
143
144
  BROWSED_ITEMS: `{{Browsed Item (${t}) Url}}`,
144
145
  PURCHASED_ITEMS: `{{Purchased Item (${t}) Url}}`
145
146
  };
146
- return e[r] || e.CART_ITEMS;
147
+ return r[e] || r.CART_ITEMS;
147
148
  }
148
149
  class V {
149
150
  constructor() {
@@ -152,40 +153,40 @@ class V {
152
153
  }
153
154
  migrate(t) {
154
155
  try {
155
- let e = this.removeJinjaConditionals(t);
156
- e = this.replaceTemplateVariables(e);
157
- const i = this.parser.parseFromString(e, "text/html"), l = i.querySelectorAll(
156
+ let r = this.removeJinjaConditionals(t);
157
+ r = this.replaceTemplateVariables(r);
158
+ const l = this.parser.parseFromString(r, "text/html"), i = l.querySelectorAll(
158
159
  "td.esd-cart-items-block, td.esd-browsed-items-block, td.esd-purchased-items-block"
159
160
  );
160
- return l.length === 0 ? (console.warn("ItemsBlockMigrator: No blocks found with items block selectors"), e) : (l.forEach((n) => {
161
- const a = this.extractConfiguration(n), o = K({
162
- orientation: a.orientation,
163
- itemsType: a.itemsType,
164
- itemId: a.itemId,
165
- currencySymbol: a.currencySymbol,
166
- currencyLocation: a.currencyLocation,
167
- formattedPrice: a.formattedPrice,
168
- configBlockAttributes: a.configBlockAttributes,
161
+ return i.length === 0 ? (console.warn("ItemsBlockMigrator: No blocks found with items block selectors"), r) : (i.forEach((n) => {
162
+ const o = this.extractConfiguration(n), a = K({
163
+ orientation: o.orientation,
164
+ itemsType: o.itemsType,
165
+ itemId: o.itemId,
166
+ currencySymbol: o.currencySymbol,
167
+ currencyLocation: o.currencyLocation,
168
+ formattedPrice: o.formattedPrice,
169
+ configBlockAttributes: o.configBlockAttributes,
169
170
  migrate: !0,
170
- nameStyles: a.nameStyles,
171
- buttonStyles: a.buttonStyles,
172
- priceStyles: a.priceStyles,
173
- originalPriceStyles: a.originalPriceStyles,
174
- quantityStyles: a.quantityStyles,
175
- nodeConfig: R(a.configBlockAttributes)
171
+ nameStyles: o.nameStyles,
172
+ buttonStyles: o.buttonStyles,
173
+ priceStyles: o.priceStyles,
174
+ originalPriceStyles: o.originalPriceStyles,
175
+ quantityStyles: o.quantityStyles,
176
+ nodeConfig: R(o.configBlockAttributes)
176
177
  }), c = this.parser.parseFromString(
177
- `<table><tbody><tr>${o}</tr></tbody></table>`,
178
+ `<table><tbody><tr>${a}</tr></tbody></table>`,
178
179
  "text/html"
179
180
  ).querySelector("td");
180
181
  if (c && n.parentNode) {
181
- const f = R(a.configBlockAttributes);
182
+ const f = R(o.configBlockAttributes);
182
183
  c.setAttribute("esd-ext-config", JSON.stringify(f));
183
- const u = c.querySelector("esd-config-block");
184
- u && u.remove(), n.parentNode.replaceChild(c, n);
184
+ const d = c.querySelector("esd-config-block");
185
+ d && d.remove(), n.parentNode.replaceChild(c, n);
185
186
  }
186
- }), i.documentElement.outerHTML);
187
- } catch (e) {
188
- return console.error("ItemsBlockMigrator failed:", e), t;
187
+ }), l.documentElement.outerHTML);
188
+ } catch (r) {
189
+ return console.error("ItemsBlockMigrator failed:", r), t;
189
190
  }
190
191
  }
191
192
  /**
@@ -196,22 +197,22 @@ class V {
196
197
  */
197
198
  extractConfiguration(t) {
198
199
  var C, D, P;
199
- const e = ((C = t.querySelector("[data-type]")) == null ? void 0 : C.getAttribute("data-type")) || "CART_ITEMS", i = ((D = t.querySelector("[data-number]")) == null ? void 0 : D.getAttribute("data-number")) || "1", l = parseInt(i) - 1, n = E[e], a = ((P = n == null ? void 0 : n[l]) == null ? void 0 : P.value) || n[0].value, o = t.querySelector('[product-attr="price"]'), _ = (o == null ? void 0 : o.getAttribute("data-currency_symbol")) || "USD", f = ((o == null ? void 0 : o.getAttribute("data-curency")) || "before") === "after" ? "1" : "0", u = (o == null ? void 0 : o.getAttribute("data-formated")) !== "false", s = this.extractConfigBlockAttributes(t, e, i), b = s["data-card_orientation_control_value"];
200
- let S;
201
- b ? S = b === "horizontal" ? "horizontal" : "vertical" : S = t.querySelector('[colspan="2"]') !== null ? "vertical" : "horizontal";
202
- const p = t.querySelector('a[product-attr="name"]'), T = (p == null ? void 0 : p.getAttribute("style")) || void 0, y = t.querySelector('a[product-attr="button"]'), m = (y == null ? void 0 : y.getAttribute("style")) || void 0, k = (o == null ? void 0 : o.getAttribute("style")) || void 0, I = t.querySelector("p.original-price"), h = (I == null ? void 0 : I.getAttribute("style")) || void 0, A = t.querySelector('[product-attr="quantity"]'), L = (A == null ? void 0 : A.getAttribute("style")) || void 0;
200
+ const r = ((C = t.querySelector("[data-type]")) == null ? void 0 : C.getAttribute("data-type")) || "CART_ITEMS", l = ((D = t.querySelector("[data-number]")) == null ? void 0 : D.getAttribute("data-number")) || "1", i = parseInt(l) - 1, n = T[r], o = ((P = n == null ? void 0 : n[i]) == null ? void 0 : P.value) || n[0].value, a = t.querySelector('[product-attr="price"]'), _ = (a == null ? void 0 : a.getAttribute("data-currency_symbol")) || "USD", f = ((a == null ? void 0 : a.getAttribute("data-curency")) || "before") === "after" ? "1" : "0", d = (a == null ? void 0 : a.getAttribute("data-formated")) !== "false", s = this.extractConfigBlockAttributes(t, r, l), S = s["data-card_orientation_control_value"];
201
+ let b;
202
+ S ? b = S === "horizontal" ? "horizontal" : "vertical" : b = t.querySelector('[colspan="2"]') !== null ? "vertical" : "horizontal";
203
+ const p = t.querySelector('a[product-attr="name"]'), I = (p == null ? void 0 : p.getAttribute("style")) || void 0, y = t.querySelector('a[product-attr="button"]'), m = (y == null ? void 0 : y.getAttribute("style")) || void 0, h = (a == null ? void 0 : a.getAttribute("style")) || void 0, A = t.querySelector("p.original-price"), k = (A == null ? void 0 : A.getAttribute("style")) || void 0, E = t.querySelector('[product-attr="quantity"]'), L = (E == null ? void 0 : E.getAttribute("style")) || void 0;
203
204
  return {
204
- orientation: S,
205
- itemsType: e,
206
- itemId: a,
205
+ orientation: b,
206
+ itemsType: r,
207
+ itemId: o,
207
208
  currencySymbol: _,
208
209
  currencyLocation: f,
209
- formattedPrice: u,
210
+ formattedPrice: d,
210
211
  configBlockAttributes: s,
211
- nameStyles: T,
212
+ nameStyles: I,
212
213
  buttonStyles: m,
213
- priceStyles: k,
214
- originalPriceStyles: h,
214
+ priceStyles: h,
215
+ originalPriceStyles: k,
215
216
  quantityStyles: L
216
217
  };
217
218
  }
@@ -222,27 +223,27 @@ class V {
222
223
  * @param itemsType - The type of items (CART_ITEMS, BROWSED_ITEMS, PURCHASED_ITEMS)
223
224
  * @param itemNumber - The item number (1-based index)
224
225
  */
225
- extractConfigBlockAttributes(t, e, i) {
226
- const l = t.querySelector("esd-config-block"), n = {};
227
- if (!l)
226
+ extractConfigBlockAttributes(t, r, l) {
227
+ const i = t.querySelector("esd-config-block"), n = {};
228
+ if (!i)
228
229
  return this.getDefaultConfigBlockAttributes();
229
- if (Array.from(l.attributes).forEach((o) => {
230
- o.name.startsWith("data-") && (n[o.name] = o.value);
230
+ if (Array.from(i.attributes).forEach((a) => {
231
+ a.name.startsWith("data-") && (n[a.name] = a.value);
231
232
  }), n["data-cart_items_select_control_value"]) {
232
- const o = n["data-cart_items_select_control_value"];
233
- if (/^\d+$/.test(o)) {
234
- const _ = parseInt(o) - 1, c = E[e];
233
+ const a = n["data-cart_items_select_control_value"];
234
+ if (/^\d+$/.test(a)) {
235
+ const _ = parseInt(a) - 1, c = T[r];
235
236
  c && c[_] && (n["data-cart_items_select_control_value"] = c[_].value);
236
237
  }
237
238
  }
238
239
  if (n["data-product_price_control_curency"]) {
239
- const o = n["data-product_price_control_curency"];
240
- let _ = o;
241
- o === "before" ? _ = "0" : o === "after" && (_ = "1"), n["data-product_price_control_curency"] = _, n["data-product_price_currency_location"] = _;
240
+ const a = n["data-product_price_control_curency"];
241
+ let _ = a;
242
+ a === "before" ? _ = "0" : a === "after" && (_ = "1"), n["data-product_price_control_curency"] = _, n["data-product_price_currency_location"] = _;
242
243
  }
243
244
  (!n["data-product_price_control_currency_symbol"] || n["data-product_price_control_currency_symbol"].trim() === "") && (n["data-product_price_control_currency_symbol"] = "USD");
244
- const a = { ...this.getDefaultConfigBlockAttributes(), ...n };
245
- return a["data-type"] = e, a["data-source"] = e, a["data-product_image_link"] = x(e, i), a["data-product_button_link"] = O(e, i), a;
245
+ const o = { ...this.getDefaultConfigBlockAttributes(), ...n };
246
+ return o["data-type"] = r, o["data-source"] = r, o["data-product_image_link"] = $(r, l), o["data-product_button_link"] = x(r, l), o;
246
247
  }
247
248
  /**
248
249
  * Returns default esd-config-block attributes based on the old template structure
@@ -297,18 +298,22 @@ class V {
297
298
  * - Cart Items: ins_apr_total_product_kind, ins_apr_price_N, ins_apr_originalprice_N
298
299
  * - Browsed Items: browsed_item_total_product_kind, browsed_item_price_N, browsed_item_originalprice_N
299
300
  * - Purchased Items: purchased_item_total_product_kind, purchased_item_price_N, purchased_item_originalprice_N
301
+ *
302
+ * IMPORTANT: Preserves the esd-custom-display-conditions attribute on <body> which
303
+ * contains display condition Jinja scripts that should NOT be removed.
300
304
  */
301
305
  removeJinjaConditionals(t) {
302
- let e = t.replace(
306
+ const r = "__ESD_DISPLAY_CONDITIONS_PLACEHOLDER__", l = t.match(/esd-custom-display-conditions="[^"]*"/);
307
+ let i = l ? t.replace(l[0], r) : t;
308
+ return i = i.replace(
303
309
  /\{%\s*if\s+(ins_apr|browsed_item|purchased_item)_total_product_kind\s*(&gt;|>)\s*\d+\s*%\}/g,
304
310
  ""
305
- );
306
- return e = e.replace(
311
+ ), i = i.replace(
307
312
  /\{%\s*if\s+(ins_apr|browsed_item|purchased_item)_price_\d+\s*(!&#61;|!=)\s*\1_originalprice_\d+\s*%\}/g,
308
313
  ""
309
- ), e = e.replace(/\{%\s*endif\s*%\}/g, ""), e = e.replace(/\n\s*\n\s*\n/g, `
314
+ ), i = i.replace(/\{%\s*endif\s*%\}/g, ""), l && (i = i.replace(r, l[0])), i = i.replace(/\n\s*\n\s*\n/g, `
310
315
 
311
- `), e;
316
+ `), i;
312
317
  }
313
318
  /**
314
319
  * Replaces template variables with default values from productPairs
@@ -320,31 +325,31 @@ class V {
320
325
  * - {{purchased_item_formattedprice_5}} → '1,490.49' (PURCHASED_ITEMS)
321
326
  */
322
327
  replaceTemplateVariables(t) {
323
- const { PAIRS_FOR_EXTENSION: e } = v;
324
- return t.replace(/{{([^}]+)}}/g, (i, l) => {
325
- const n = l.match(/^(ins_apr|browsed_item|purchased_item)_([a-z_]+)_(\d+)$/);
328
+ const { PAIRS_FOR_EXTENSION: r } = U;
329
+ return t.replace(/{{([^}]+)}}/g, (l, i) => {
330
+ const n = i.match(/^(ins_apr|browsed_item|purchased_item)_([a-z_]+)_(\d+)$/);
326
331
  if (!n)
327
- return i;
328
- const [, a, o, _] = n, c = $[a];
332
+ return l;
333
+ const [, o, a, _] = n, c = O[o];
329
334
  if (!c)
330
- return console.warn(`Unknown variable prefix: ${a}`), i;
331
- const f = w[o];
335
+ return console.warn(`Unknown variable prefix: ${o}`), l;
336
+ const f = w[a];
332
337
  if (!f)
333
- return console.warn(`Unknown variable suffix mapping for: ${o}`), i;
334
- const { pairsKey: u, defaultKey: s, isArray: b } = f, p = e[u][c];
338
+ return console.warn(`Unknown variable suffix mapping for: ${a}`), l;
339
+ const { pairsKey: d, defaultKey: s, isArray: S } = f, p = r[d][c];
335
340
  if (!p)
336
- return console.warn(`No data found for: ${u}.${c}`), i;
337
- if (b) {
341
+ return console.warn(`No data found for: ${d}.${c}`), l;
342
+ if (S) {
338
343
  const y = parseInt(_) - 1, m = p[s];
339
- return Array.isArray(m) && m[y] ? m[y] : (console.warn(`Array value not found: ${u}.${c}.${s}[${y}]`), i);
344
+ return Array.isArray(m) && m[y] ? m[y] : (console.warn(`Array value not found: ${d}.${c}.${s}[${y}]`), l);
340
345
  }
341
- const T = p[s];
342
- return T !== void 0 ? String(T) : (console.warn(`Default value not found: ${u}.${c}.${s}`), i);
346
+ const I = p[s];
347
+ return I !== void 0 ? String(I) : (console.warn(`Default value not found: ${d}.${c}.${s}`), l);
343
348
  });
344
349
  }
345
350
  }
346
- function G(r) {
347
- return new V().migrate(r);
351
+ function G(e) {
352
+ return new V().migrate(e);
348
353
  }
349
354
  export {
350
355
  G as migrateItemsBlock
@@ -17,7 +17,7 @@ class w {
17
17
  const l = o.getAttribute("id"), r = this.extractBgColor(o), i = this.extractTitle(o), u = this.extractProductRows(o), c = P.replace("{-{-TITLE-}-}", i).replace("{-{-PRODUCT_ROWS-}-}", u), a = this.parser.parseFromString(
18
18
  `<table id="tempDoc"><tbody><tr>${c}</tr></tbody></table>`,
19
19
  "text/html"
20
- ).querySelector(".ins-recommendation-v3-block-v2");
20
+ ).querySelector(".recommendation-block-v2");
21
21
  a && o.parentNode && (l && a.setAttribute("id", l), r && a.setAttribute("bgcolor", r), o.parentNode.replaceChild(a, o));
22
22
  }), t.documentElement.outerHTML);
23
23
  } catch (t) {
@@ -1,8 +1,12 @@
1
- const t = {
1
+ const e = {
2
2
  transactional: 2
3
- }, o = 2, T = 13;
3
+ }, o = 2, t = 13, s = {
4
+ SAVED_MODULES: "savedModules",
5
+ DEFAULT_MODULES: "defaultModules"
6
+ };
4
7
  export {
5
8
  o as EditorType,
6
- T as MAX_DEFAULT_TEMPLATE_ID,
7
- t as TemplateTypes
9
+ t as MAX_DEFAULT_TEMPLATE_ID,
10
+ s as ModuleFolderDefaults,
11
+ e as TemplateTypes
8
12
  };
@@ -1,12 +1,13 @@
1
- var u = Object.defineProperty;
2
- var p = (r, o, t) => o in r ? u(r, o, { enumerable: !0, configurable: !0, writable: !0, value: t }) : r[o] = t;
3
- var g = (r, o, t) => p(r, typeof o != "symbol" ? o + "" : o, t);
4
- import { Block as f, BlockCompositionType as I, ModificationDescription as h } from "../../../node_modules/@stripoinc/ui-editor-extensions/dist/esm/index.js";
5
- import { RecommendationConfigService as c } from "./services/configService.js";
6
- import { useRecommendationExtensionStore as d } from "./store/recommendation.js";
7
- import { getDefaultTemplate as _ } from "./templates/grid/template.js";
8
- const k = "recommendation-block", s = "ins-recommendation-v3-block-v2", a = "recommendation-id";
9
- class b extends f {
1
+ var p = Object.defineProperty;
2
+ var f = (r, o, t) => o in r ? p(r, o, { enumerable: !0, configurable: !0, writable: !0, value: t }) : r[o] = t;
3
+ var g = (r, o, t) => f(r, typeof o != "symbol" ? o + "" : o, t);
4
+ import { Block as h, BlockCompositionType as I, ModificationDescription as _ } from "../../../node_modules/@stripoinc/ui-editor-extensions/dist/esm/index.js";
5
+ import { ensureMobileCssRulesExist as d } from "./controls/mobileLayout/cssRules.js";
6
+ import { RecommendationConfigService as s } from "./services/configService.js";
7
+ import { useRecommendationExtensionStore as u } from "./store/recommendation.js";
8
+ import { getDefaultTemplate as k } from "./templates/grid/template.js";
9
+ const B = "recommendation-block", c = "recommendation-block-v2", a = "recommendation-id";
10
+ class y extends h {
10
11
  constructor() {
11
12
  super();
12
13
  /**
@@ -16,7 +17,7 @@ class b extends f {
16
17
  g(this, "_pendingBlockId", null);
17
18
  }
18
19
  getId() {
19
- return k;
20
+ return B;
20
21
  }
21
22
  getIcon() {
22
23
  return "recommendation-icon";
@@ -39,7 +40,7 @@ class b extends f {
39
40
  */
40
41
  getTemplate() {
41
42
  const t = this._generateNextId();
42
- return this._pendingBlockId = t, _(t);
43
+ return this._pendingBlockId = t, k(t);
43
44
  }
44
45
  /**
45
46
  * Called when a new block is dropped into the template
@@ -51,8 +52,8 @@ class b extends f {
51
52
  onCreated(t) {
52
53
  const e = this._pendingBlockId ?? this._generateNextId();
53
54
  this._pendingBlockId = null, this._assignRecommendationId(t, e);
54
- const n = c.initializeConfig(this.api, t, { recommendationId: e }), i = d();
55
- i.setCurrentBlock(e), i.patchCurrentBlockConfig({ language: n.language }, { triggerRefetch: !1 });
55
+ const n = s.initializeConfig(this.api, t, { recommendationId: e }), i = u();
56
+ i.setCurrentBlock(e), d(this.api), i.patchCurrentBlockConfig({ language: n.language }, { triggerRefetch: !1 });
56
57
  }
57
58
  /**
58
59
  * Called when the document changes or template is loaded
@@ -65,14 +66,14 @@ class b extends f {
65
66
  if (!(!t || !("getNodeConfig" in t))) {
66
67
  if (!this._getRecommendationId(t)) {
67
68
  const e = this._generateNextId();
68
- this._assignRecommendationId(t, e), c.hasConfig(t) && c.updateConfig(
69
+ this._assignRecommendationId(t, e), s.hasConfig(t) && s.updateConfig(
69
70
  this.api,
70
71
  t,
71
72
  { recommendationId: e },
72
73
  "Assign recommendation ID to legacy block"
73
74
  );
74
75
  }
75
- c.needsMigration(t) && this._migrateFromLegacy(t);
76
+ s.needsMigration(t) && this._migrateFromLegacy(t), d(this.api);
76
77
  }
77
78
  }
78
79
  /**
@@ -83,7 +84,7 @@ class b extends f {
83
84
  */
84
85
  onDelete(t) {
85
86
  const e = this._getRecommendationId(t);
86
- e && d().removeBlockState(e);
87
+ e && u().removeBlockState(e);
87
88
  }
88
89
  /**
89
90
  * Generates the next unique recommendation ID by scanning all existing blocks
@@ -93,7 +94,7 @@ class b extends f {
93
94
  let t = 0;
94
95
  try {
95
96
  const e = this.api.getDocumentRoot();
96
- e && "querySelectorAll" in e && e.querySelectorAll(`.${s}`).forEach((i) => {
97
+ e && "querySelectorAll" in e && e.querySelectorAll(`.${c}`).forEach((i) => {
97
98
  if ("getAttribute" in i) {
98
99
  const m = i.getAttribute(a), l = m ? parseInt(m) : 0;
99
100
  l > t && (t = l);
@@ -114,7 +115,7 @@ class b extends f {
114
115
  if (!n)
115
116
  return;
116
117
  const i = this.api.getDocumentModifier();
117
- i.modifyHtml(n).setAttribute(a, e.toString()), i.apply(new h(`Assign recommendation ID ${e}`));
118
+ i.modifyHtml(n).setAttribute(a, e.toString()), i.apply(new _(`Assign recommendation ID ${e}`));
118
119
  }
119
120
  /**
120
121
  * Gets the recommendation-id from a block node
@@ -135,19 +136,19 @@ class b extends f {
135
136
  _getBlockElement(t) {
136
137
  if ("getAttribute" in t) {
137
138
  const e = t.getAttribute("class");
138
- if (e && e.includes(s))
139
+ if (e && e.includes(c))
139
140
  return t;
140
141
  }
141
- return "querySelector" in t ? t.querySelector(`.${s}`) : null;
142
+ return "querySelector" in t ? t.querySelector(`.${c}`) : null;
142
143
  }
143
144
  /**
144
145
  * Migrate configuration from legacy format
145
146
  */
146
147
  _migrateFromLegacy(t) {
147
- c.migrateFromDataAttributes(this.api, t);
148
+ s.migrateFromDataAttributes(this.api, t);
148
149
  }
149
150
  }
150
151
  export {
151
- k as BLOCK_ID,
152
- b as RecommendationBlock
152
+ B as BLOCK_ID,
153
+ y as RecommendationBlock
153
154
  };
@@ -1,65 +1,69 @@
1
- import { DEFAULT_ROW_SPACING as n, DEFAULT_COLUMN_SPACING as s, DEFAULT_CARDS_IN_ROW as R } from "./layout.js";
2
- import { ATTR_PRODUCT_IMAGE as t, ATTR_PRODUCT_NAME as e, ATTR_PRODUCT_OLD_PRICE as o, ATTR_PRODUCT_PRICE as T, ATTR_PRODUCT_OMNIBUS_PRICE as _, ATTR_PRODUCT_OMNIBUS_DISCOUNT as r, ATTR_PRODUCT_BUTTON as U } from "./selectors.js";
3
- const I = {
1
+ import { DEFAULT_MOBILE_ROW_SPACING as U, DEFAULT_MOBILE_COLUMN_SPACING as R, DEFAULT_ROW_SPACING as n, DEFAULT_COLUMN_SPACING as O, DEFAULT_MOBILE_CARDS_IN_ROW as C, DEFAULT_CARDS_IN_ROW as D } from "./layout.js";
2
+ import { ATTR_PRODUCT_IMAGE as _, ATTR_PRODUCT_NAME as o, ATTR_PRODUCT_OLD_PRICE as t, ATTR_PRODUCT_PRICE as e, ATTR_PRODUCT_OMNIBUS_PRICE as T, ATTR_PRODUCT_OMNIBUS_DISCOUNT as I, ATTR_PRODUCT_BUTTON as r } from "./selectors.js";
3
+ const i = {
4
4
  code: "USD",
5
5
  symbol: "USD",
6
6
  alignment: "after",
7
7
  decimalCount: 2,
8
8
  decimalSeparator: ".",
9
9
  thousandSeparator: ","
10
- }, i = {
10
+ }, A = {
11
11
  textBefore: "",
12
12
  textAfter: ""
13
- }, O = {
13
+ }, s = {
14
14
  textBefore: "",
15
15
  textAfter: ""
16
- }, C = [
16
+ }, E = [
17
+ _,
18
+ o,
17
19
  t,
18
20
  e,
19
- o,
20
21
  T,
21
- _,
22
- r,
23
- U
24
- ], D = {
25
- [t]: !0,
26
- [e]: !0,
27
- [T]: !0,
22
+ I,
23
+ r
24
+ ], c = {
25
+ [_]: !0,
28
26
  [o]: !0,
29
- [_]: !1,
30
- [r]: !1,
31
- [U]: !0
32
- }, a = {
27
+ [e]: !0,
28
+ [t]: !0,
29
+ [T]: !1,
30
+ [I]: !1,
31
+ [r]: !0
32
+ }, N = {
33
33
  // Settings
34
34
  strategy: "mostPopular",
35
35
  productIds: [],
36
36
  size: "6",
37
37
  shuffleProducts: !1,
38
38
  language: "en_US",
39
- currency: I,
39
+ currency: i,
40
40
  filters: [],
41
41
  // Layout
42
42
  layout: "grid",
43
- cardsInRow: R,
44
- columnSpacing: s,
43
+ cardsInRow: D,
44
+ mobileCardsInRow: C,
45
+ columnSpacing: O,
45
46
  rowSpacing: n,
47
+ mobileColumnSpacing: R,
48
+ mobileRowSpacing: U,
46
49
  // Composition
47
- composition: C,
48
- visibility: D,
50
+ composition: E,
51
+ visibility: c,
49
52
  // Element settings
50
- omnibusPrice: i,
51
- omnibusDiscount: O,
53
+ omnibusPrice: A,
54
+ omnibusDiscount: s,
52
55
  textTrimming: !1,
53
56
  // Meta
54
57
  configVersion: 1,
55
58
  recommendationId: 0
56
- }, E = 1;
59
+ }, m = [11, 12], L = 1;
57
60
  export {
58
- E as CURRENT_CONFIG_VERSION,
59
- C as DEFAULT_COMPOSITION,
60
- I as DEFAULT_CURRENCY,
61
- a as DEFAULT_NODE_CONFIG,
62
- O as DEFAULT_OMNIBUS_DISCOUNT,
63
- i as DEFAULT_OMNIBUS_PRICE,
64
- D as DEFAULT_VISIBILITY
61
+ L as CURRENT_CONFIG_VERSION,
62
+ E as DEFAULT_COMPOSITION,
63
+ i as DEFAULT_CURRENCY,
64
+ N as DEFAULT_NODE_CONFIG,
65
+ s as DEFAULT_OMNIBUS_DISCOUNT,
66
+ A as DEFAULT_OMNIBUS_PRICE,
67
+ c as DEFAULT_VISIBILITY,
68
+ m as EXCLUDED_ALGORITHM_IDS
65
69
  };