@useinsider/guido 2.2.0-beta.1696353 → 2.2.0-beta.39b37ff

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 (161) hide show
  1. package/dist/components/organisms/base/Toaster.vue.js +4 -4
  2. package/dist/components/organisms/base/Toaster.vue2.js +12 -9
  3. package/dist/components/organisms/email-preview/desktop-preview/EmailSizeIndicator.vue.js +5 -5
  4. package/dist/components/organisms/email-preview/desktop-preview/EmailSizeIndicator.vue2.js +2 -2
  5. package/dist/components/organisms/extensions/recommendation/FilterSelectionDrawer.vue2.js +15 -14
  6. package/dist/components/organisms/unsubscribe/UnsubscribePageSelection.vue.js +1 -1
  7. package/dist/components/organisms/unsubscribe/UnsubscribePageSelection.vue2.js +19 -19
  8. package/dist/composables/useHtmlValidator.js +114 -104
  9. package/dist/composables/useRecommendation.js +54 -21
  10. package/dist/composables/useStripo.js +25 -23
  11. package/dist/composables/useVersionHistoryApi.js +1 -1
  12. package/dist/config/compiler/recommendationCompilerRules.js +45 -39
  13. package/dist/config/compiler/utils/recommendationCompilerUtils.js +121 -0
  14. package/dist/config/i18n/en/index.js +11 -0
  15. package/dist/config/i18n/en/labels.json.js +7 -0
  16. package/dist/config/i18n/en/toasters.json.js +56 -0
  17. package/dist/config/i18n/en/tooltips.json.js +82 -0
  18. package/dist/config/i18n/index.js +7 -0
  19. package/dist/config/migrator/itemsBlockMigrator.js +127 -122
  20. package/dist/config/migrator/recommendationMigrator.js +2 -2
  21. package/dist/enums/extensions/recommendationBlock.js +1 -1
  22. package/dist/enums/recommendation.js +16 -15
  23. package/dist/extensions/Blocks/Recommendation/block.js +133 -9
  24. package/dist/extensions/Blocks/Recommendation/constants/blockIds.js +4 -0
  25. package/dist/extensions/Blocks/Recommendation/constants/controlIds.js +4 -0
  26. package/dist/extensions/Blocks/Recommendation/constants/defaultConfig.js +66 -0
  27. package/dist/extensions/Blocks/Recommendation/constants/layout.js +22 -0
  28. package/dist/extensions/Blocks/Recommendation/constants/selectors.js +21 -0
  29. package/dist/extensions/Blocks/Recommendation/controls/button/index.js +64 -0
  30. package/dist/extensions/Blocks/Recommendation/controls/cardBackground/index.js +80 -0
  31. package/dist/extensions/Blocks/Recommendation/controls/cardComposition/index.js +232 -0
  32. package/dist/extensions/Blocks/Recommendation/controls/image/index.js +19 -0
  33. package/dist/extensions/Blocks/Recommendation/controls/layout/index.js +92 -0
  34. package/dist/extensions/Blocks/Recommendation/controls/main/algorithm.js +102 -0
  35. package/dist/extensions/Blocks/Recommendation/controls/main/currency.js +209 -0
  36. package/dist/extensions/Blocks/Recommendation/controls/main/filters.js +52 -0
  37. package/dist/extensions/Blocks/Recommendation/controls/main/index.js +250 -0
  38. package/dist/extensions/Blocks/Recommendation/controls/main/locale.js +70 -0
  39. package/dist/extensions/Blocks/Recommendation/controls/main/productLayout.js +160 -0
  40. package/dist/extensions/Blocks/Recommendation/controls/main/shuffle.js +67 -0
  41. package/dist/extensions/Blocks/Recommendation/controls/main/utils.js +307 -0
  42. package/dist/extensions/Blocks/Recommendation/controls/mobileLayout/cssRules.js +21 -0
  43. package/dist/extensions/Blocks/Recommendation/controls/name/index.js +46 -0
  44. package/dist/extensions/Blocks/Recommendation/controls/name/textTrim.js +108 -0
  45. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/index.js +44 -0
  46. package/dist/extensions/Blocks/Recommendation/controls/omnibusDiscount/index.js +48 -0
  47. package/dist/extensions/Blocks/Recommendation/controls/{omnibusDiscountTextAfterControl.js → omnibusDiscount/textAfter.js} +16 -14
  48. package/dist/extensions/Blocks/Recommendation/controls/{omnibusDiscountTextBeforeControl.js → omnibusDiscount/textBefore.js} +16 -14
  49. package/dist/extensions/Blocks/Recommendation/controls/omnibusPrice/index.js +48 -0
  50. package/dist/extensions/Blocks/Recommendation/controls/{omnibusPriceTextAfterControl.js → omnibusPrice/textAfter.js} +16 -14
  51. package/dist/extensions/Blocks/Recommendation/controls/{omnibusPriceTextBeforeControl.js → omnibusPrice/textBefore.js} +14 -12
  52. package/dist/extensions/Blocks/Recommendation/controls/price/index.js +44 -0
  53. package/dist/extensions/Blocks/Recommendation/controls/spacing/index.js +222 -0
  54. package/dist/extensions/Blocks/Recommendation/extension.js +40 -17
  55. package/dist/extensions/Blocks/Recommendation/iconsRegistry.js +19 -3
  56. package/dist/extensions/Blocks/Recommendation/recommendation.css.js +13 -4
  57. package/dist/extensions/Blocks/Recommendation/services/configService.js +240 -0
  58. package/dist/extensions/Blocks/Recommendation/settingsPanel.js +21 -10
  59. package/dist/extensions/Blocks/Recommendation/store/recommendation.js +254 -207
  60. package/dist/extensions/Blocks/Recommendation/templates/grid/elementRenderer.js +228 -0
  61. package/dist/extensions/Blocks/Recommendation/templates/grid/migration.js +251 -0
  62. package/dist/extensions/Blocks/Recommendation/templates/grid/template.js +66 -0
  63. package/dist/extensions/Blocks/Recommendation/templates/index.js +12 -0
  64. package/dist/extensions/Blocks/Recommendation/templates/list/elementRenderer.js +169 -0
  65. package/dist/extensions/Blocks/Recommendation/templates/list/template.js +73 -0
  66. package/dist/extensions/Blocks/Recommendation/templates/utils.js +134 -0
  67. package/dist/extensions/Blocks/Recommendation/types/nodeConfig.js +6 -0
  68. package/dist/extensions/Blocks/Recommendation/utils/filterUtil.js +9 -9
  69. package/dist/extensions/Blocks/Recommendation/utils/preserveTextStyles.js +26 -15
  70. package/dist/extensions/Blocks/Recommendation/utils/priceFormatter.js +29 -0
  71. package/dist/extensions/Blocks/Recommendation/utils/tagName.js +46 -0
  72. package/dist/extensions/Blocks/Unsubscribe/block.js +29 -29
  73. package/dist/extensions/Blocks/Unsubscribe/control.js +12 -9
  74. package/dist/extensions/Blocks/Unsubscribe/elements/preview.js +13 -11
  75. package/dist/extensions/Blocks/Unsubscribe/styles.css.js +31 -1
  76. package/dist/extensions/Blocks/controlFactories.js +125 -93
  77. package/dist/guido.css +1 -1
  78. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/esm/index.js +242 -186
  79. package/dist/services/recommendationApi.js +11 -8
  80. package/dist/services/stripoApi.js +20 -17
  81. package/dist/services/templateLibraryApi.js +16 -13
  82. package/dist/src/components/wrappers/WpDrawer.vue.d.ts +1 -1
  83. package/dist/src/composables/useRecommendation.d.ts +1 -0
  84. package/dist/src/config/compiler/utils/recommendationCompilerUtils.d.ts +17 -0
  85. package/dist/src/config/i18n/en/index.d.ts +1 -0
  86. package/dist/src/config/i18n/index.d.ts +16 -0
  87. package/dist/src/extensions/Blocks/Recommendation/block.d.ts +67 -0
  88. package/dist/src/extensions/Blocks/Recommendation/constants/blockIds.d.ts +13 -0
  89. package/dist/src/extensions/Blocks/Recommendation/{constants.d.ts → constants/controlIds.d.ts} +0 -24
  90. package/dist/src/extensions/Blocks/Recommendation/constants/defaultConfig.d.ts +49 -0
  91. package/dist/src/extensions/Blocks/Recommendation/constants/index.d.ts +13 -0
  92. package/dist/src/extensions/Blocks/Recommendation/constants/layout.d.ts +41 -0
  93. package/dist/src/extensions/Blocks/Recommendation/constants/selectors.d.ts +35 -0
  94. package/dist/src/extensions/Blocks/Recommendation/controls/button/index.d.ts +143 -0
  95. package/dist/src/extensions/Blocks/Recommendation/controls/cardBackground/index.d.ts +31 -0
  96. package/dist/src/extensions/Blocks/Recommendation/{cardCompositionControl.d.ts → controls/cardComposition/index.d.ts} +23 -3
  97. package/dist/src/extensions/Blocks/Recommendation/controls/image/index.d.ts +35 -0
  98. package/dist/src/extensions/Blocks/Recommendation/controls/index.d.ts +21 -589
  99. package/dist/src/extensions/Blocks/Recommendation/controls/layout/index.d.ts +37 -0
  100. package/dist/src/extensions/Blocks/Recommendation/controls/main/algorithm.d.ts +29 -0
  101. package/dist/src/extensions/Blocks/Recommendation/controls/main/currency.d.ts +52 -0
  102. package/dist/src/extensions/Blocks/Recommendation/controls/main/filters.d.ts +22 -0
  103. package/dist/src/extensions/Blocks/Recommendation/controls/main/index.d.ts +79 -0
  104. package/dist/src/extensions/Blocks/Recommendation/controls/main/locale.d.ts +24 -0
  105. package/dist/src/extensions/Blocks/Recommendation/controls/main/productLayout.d.ts +60 -0
  106. package/dist/src/extensions/Blocks/Recommendation/controls/main/shuffle.d.ts +23 -0
  107. package/dist/src/extensions/Blocks/Recommendation/controls/main/utils.d.ts +221 -0
  108. package/dist/src/extensions/Blocks/Recommendation/controls/mobileLayout/cssRules.d.ts +29 -0
  109. package/dist/src/extensions/Blocks/Recommendation/controls/name/index.d.ts +97 -0
  110. package/dist/src/extensions/Blocks/Recommendation/controls/name/textTrim.d.ts +34 -0
  111. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/index.d.ts +95 -0
  112. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusDiscount/index.d.ts +100 -0
  113. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusDiscount/textAfter.d.ts +15 -0
  114. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusDiscount/textBefore.d.ts +15 -0
  115. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusPrice/index.d.ts +100 -0
  116. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusPrice/textAfter.d.ts +15 -0
  117. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusPrice/textBefore.d.ts +15 -0
  118. package/dist/src/extensions/Blocks/Recommendation/controls/price/index.d.ts +95 -0
  119. package/dist/src/extensions/Blocks/Recommendation/controls/spacing/index.d.ts +83 -0
  120. package/dist/src/extensions/Blocks/Recommendation/extension.d.ts +9 -0
  121. package/dist/src/extensions/Blocks/Recommendation/services/configService.d.ts +151 -0
  122. package/dist/src/extensions/Blocks/Recommendation/services/index.d.ts +6 -0
  123. package/dist/src/extensions/Blocks/Recommendation/store/recommendation.d.ts +138 -468
  124. package/dist/src/extensions/Blocks/Recommendation/templates/grid/elementRenderer.d.ts +20 -0
  125. package/dist/src/extensions/Blocks/Recommendation/templates/{migrationTemplate.d.ts → grid/migration.d.ts} +11 -4
  126. package/dist/src/extensions/Blocks/Recommendation/templates/grid/template.d.ts +33 -0
  127. package/dist/src/extensions/Blocks/Recommendation/templates/index.d.ts +41 -0
  128. package/dist/src/extensions/Blocks/Recommendation/templates/list/elementRenderer.d.ts +8 -0
  129. package/dist/src/extensions/Blocks/Recommendation/templates/list/migration.d.ts +25 -0
  130. package/dist/src/extensions/Blocks/Recommendation/templates/list/template.d.ts +18 -0
  131. package/dist/src/extensions/Blocks/Recommendation/templates/utils.d.ts +66 -0
  132. package/dist/src/extensions/Blocks/Recommendation/types/index.d.ts +7 -0
  133. package/dist/src/extensions/Blocks/Recommendation/types/nodeConfig.d.ts +166 -0
  134. package/dist/src/extensions/Blocks/Recommendation/utils/priceFormatter.d.ts +33 -0
  135. package/dist/src/extensions/Blocks/Recommendation/utils/stylePreserver.d.ts +113 -0
  136. package/dist/src/extensions/Blocks/Recommendation/utils/tagName.d.ts +77 -0
  137. package/dist/src/extensions/Blocks/Unsubscribe/control.d.ts +1 -0
  138. package/dist/static/styles/components/notification.css.js +18 -0
  139. package/dist/static/styles/components/tools.css.js +6 -2
  140. package/dist/static/styles/customEditorStyle.css.js +35 -11
  141. package/dist/static/styles/variables.css.js +2 -0
  142. package/dist/static/templates/empty/index.html.js +74 -0
  143. package/dist/static/templates/empty/style.css.js +779 -0
  144. package/dist/stores/unsubscribe.js +37 -34
  145. package/dist/utils/pairProductVariables.js +57 -56
  146. package/dist/utils/templatePreparation.js +15 -14
  147. package/package.json +1 -1
  148. package/dist/extensions/Blocks/Recommendation/cardCompositionControl.js +0 -187
  149. package/dist/extensions/Blocks/Recommendation/constants.js +0 -13
  150. package/dist/extensions/Blocks/Recommendation/control.js +0 -336
  151. package/dist/extensions/Blocks/Recommendation/controls/cardBackgroundColorControl.js +0 -68
  152. package/dist/extensions/Blocks/Recommendation/controls/index.js +0 -245
  153. package/dist/extensions/Blocks/Recommendation/controls/nameTextTrimControl.js +0 -74
  154. package/dist/extensions/Blocks/Recommendation/controls/spacingControl.js +0 -188
  155. package/dist/extensions/Blocks/Recommendation/templates/blockTemplate.js +0 -181
  156. package/dist/extensions/Blocks/Recommendation/templates/migrationTemplate.js +0 -189
  157. package/dist/extensions/Blocks/Recommendation/templates/templateUtils.js +0 -209
  158. package/dist/src/extensions/Blocks/Recommendation/control.d.ts +0 -38
  159. package/dist/src/extensions/Blocks/Recommendation/controls/nameTextTrimControl.d.ts +0 -16
  160. package/dist/src/extensions/Blocks/Recommendation/templates/blockTemplate.d.ts +0 -16
  161. package/dist/src/extensions/Blocks/Recommendation/templates/templateUtils.d.ts +0 -52
@@ -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
@@ -1,8 +1,8 @@
1
1
  var h = Object.defineProperty;
2
2
  var T = (A, e, t) => e in A ? h(A, e, { enumerable: !0, configurable: !0, writable: !0, value: t }) : A[e] = t;
3
3
  var m = (A, e, t) => T(A, typeof e != "symbol" ? e + "" : e, t);
4
- import P, { prepareProductRows as S } from "../../extensions/Blocks/Recommendation/templates/migrationTemplate.js";
5
- import { getDefaultProducts as q } from "../../extensions/Blocks/Recommendation/templates/templateUtils.js";
4
+ import P, { prepareProductRows as S } from "../../extensions/Blocks/Recommendation/templates/grid/migration.js";
5
+ import { getDefaultProducts as q } from "../../extensions/Blocks/Recommendation/templates/utils.js";
6
6
  class w {
7
7
  constructor() {
8
8
  m(this, "parser");
@@ -1,5 +1,5 @@
1
1
  const s = {
2
- RECOMMENDATION_API_URL: "http://recommendationv2.api.useinsider.com"
2
+ RECOMMENDATION_API_URL: "https://recommendationv2.api.useinsider.com"
3
3
  }, i = [
4
4
  { id: 11, key: "similarViewed", name: "Viewed Together", path: "viewed-together" },
5
5
  { id: 12, key: "similarBought", name: "Purchased Together", path: "purchased-together" },
@@ -1,4 +1,4 @@
1
- const s = 20, e = 320, t = {
1
+ const e = 20, s = 320, t = "vertical", m = {
2
2
  CART_ABANDONMENT: {
3
3
  ins_apr_img_1: "https://s3-eu-west-1.amazonaws.com/web-image.useinsider.com/email-assets/dummyImages/ins_apr_img_1.png",
4
4
  ins_apr_img_2: "https://s3-eu-west-1.amazonaws.com/web-image.useinsider.com/email-assets/dummyImages/ins_apr_img_2.png",
@@ -15,7 +15,7 @@ const s = 20, e = 320, t = {
15
15
  DISCOUNT: "discount",
16
16
  OMNIBUS_DISCOUNT: "omnibus_discount",
17
17
  OMNIBUS_PRICE: "omnibus_price"
18
- }, m = {
18
+ }, _ = {
19
19
  IF: {
20
20
  discount: `{% if {${i.DISCOUNT}} != "0%" and {${i.DISCOUNT}} != "" %}`,
21
21
  omnibus_discount: `{% if {${i.DISCOUNT}} != "0%" and {${i.DISCOUNT}} != "" and {${i.OMNIBUS_DISCOUNT}} != "0%" and {${i.OMNIBUS_DISCOUNT}} != "" %}`,
@@ -23,17 +23,17 @@ const s = 20, e = 320, t = {
23
23
  },
24
24
  ELSE: "{% else %}",
25
25
  END_IF: "{% endif %}"
26
- }, _ = {
27
- ID: /ins-recommendation-v3-campaign-id="(.*?)"/gi,
28
- ATTRIBUTE_PARAGRAPH: /<p[^>]*?product-attr="(discount|omnibus_discount|omnibus_price)">[\S\s]*?<\/p>/gm,
29
- ATTRIBUTE_PARAGRAPH_START_TAG: /<p[^>]*?product-attr="(discount|omnibus_discount|omnibus_price)">/gm,
26
+ }, a = {
27
+ ID: /recommendation-id="(.*?)"/gi,
28
+ ATTRIBUTE_PARAGRAPH: /<p[^>]*?product-attr="(discount|omnibus_discount|omnibus_price)"[^>]*>[\S\s]*?<\/p>/gm,
29
+ ATTRIBUTE_PARAGRAPH_START_TAG: /<p[^>]*?product-attr="(discount|omnibus_discount|omnibus_price)"[^>]*>/gm,
30
30
  COMPOSITION: /composition="true"/gm,
31
31
  CUSTOM_FIELD: /{{[0-9]+_[0-8]_(discount|omnibus_discount|omnibus_price)}}/gm,
32
32
  CUSTOM_FIELD_INDEXES_PART: /{{[0-9]+_[0-8]_/gm,
33
33
  CUSTOM_FIELD_NAME_PART: /_(discount|omnibus_discount|omnibus_price)}}/gm
34
- }, a = {
35
- PARAGRAPH_END_TAG: "</p>"
36
34
  }, n = {
35
+ PARAGRAPH_END_TAG: "</p>"
36
+ }, o = {
37
37
  REGULAR_NAME_HEIGHT: ".ext-product-name.ins-vertical p { height:90px!important;",
38
38
  TRIMMED_NAME_HEIGHT: ".ext-product-name.ins-vertical p { height:18px!important;",
39
39
  ELLIPSIS: "text-overflow:ellipsis!important; white-space:nowrap!important;",
@@ -46,11 +46,12 @@ const s = 20, e = 320, t = {
46
46
  };
47
47
  export {
48
48
  i as ATTRIBUTES,
49
- m as CONDITIONS,
50
- n as CSS,
51
- t as DUMMY_IMAGE_MAPPINGS,
52
- s as DefaultPadding,
53
- a as HTML,
54
- e as MinDeviceViewport,
55
- _ as REGEX
49
+ _ as CONDITIONS,
50
+ o as CSS,
51
+ m as DUMMY_IMAGE_MAPPINGS,
52
+ e as DefaultPadding,
53
+ n as HTML,
54
+ s as MinDeviceViewport,
55
+ a as REGEX,
56
+ t as VerticalOrientation
56
57
  };
@@ -1,18 +1,29 @@
1
- import { Block as e, BlockCompositionType as t } from "../../../node_modules/@stripoinc/ui-editor-extensions/dist/esm/index.js";
2
- import { getDefaultTemplate as o } from "./templates/blockTemplate.js";
3
- const n = "recommendation-block";
4
- class m extends e {
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 = "ins-recommendation-v3-block-v2", a = "recommendation-id";
10
+ class y extends h {
5
11
  constructor() {
6
12
  super();
13
+ /**
14
+ * Stores the ID generated in getTemplate() so onCreated() can reuse it.
15
+ * This avoids generating a new (different) ID in onCreated().
16
+ */
17
+ g(this, "_pendingBlockId", null);
7
18
  }
8
19
  getId() {
9
- return n;
20
+ return B;
10
21
  }
11
22
  getIcon() {
12
23
  return "recommendation-icon";
13
24
  }
14
25
  getBlockCompositionType() {
15
- return t.CONTAINER;
26
+ return I.CONTAINER;
16
27
  }
17
28
  getName() {
18
29
  return this.api.translate("Recommendation Block");
@@ -20,11 +31,124 @@ class m extends e {
20
31
  getDescription() {
21
32
  return this.api.translate("Recommendation Block Title Description");
22
33
  }
34
+ /**
35
+ * Returns the template HTML for a new recommendation block.
36
+ * Generates a unique recommendation ID and embeds the instance class
37
+ * (ins-recommendation-v3-block-{id}) directly in the template HTML.
38
+ * This is necessary because Stripo's Angular rendering manages the class
39
+ * attribute and overwrites dynamically added classes via setAttribute.
40
+ */
23
41
  getTemplate() {
24
- return o();
42
+ const t = this._generateNextId();
43
+ return this._pendingBlockId = t, k(t);
44
+ }
45
+ /**
46
+ * Called when a new block is dropped into the template
47
+ *
48
+ * Uses the ID from getTemplate() (which already embedded the instance class)
49
+ * and assigns the recommendation-id attribute + initializes configuration.
50
+ * @param node - The newly created block node
51
+ */
52
+ onCreated(t) {
53
+ const e = this._pendingBlockId ?? this._generateNextId();
54
+ this._pendingBlockId = null, this._assignRecommendationId(t, e);
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 });
57
+ }
58
+ /**
59
+ * Called when the document changes or template is loaded
60
+ *
61
+ * Handles migration from legacy templates that don't have node config
62
+ * and assigns recommendation-id to legacy blocks that lack one.
63
+ * @param node - The block node that may need migration
64
+ */
65
+ onDocumentChanged(t) {
66
+ if (!(!t || !("getNodeConfig" in t))) {
67
+ if (!this._getRecommendationId(t)) {
68
+ const e = this._generateNextId();
69
+ this._assignRecommendationId(t, e), s.hasConfig(t) && s.updateConfig(
70
+ this.api,
71
+ t,
72
+ { recommendationId: e },
73
+ "Assign recommendation ID to legacy block"
74
+ );
75
+ }
76
+ s.needsMigration(t) && this._migrateFromLegacy(t), d(this.api);
77
+ }
78
+ }
79
+ /**
80
+ * Called when a block is deleted from the template
81
+ *
82
+ * Cleans up the per-block state from the Pinia store.
83
+ * @param node - The block node being deleted
84
+ */
85
+ onDelete(t) {
86
+ const e = this._getRecommendationId(t);
87
+ e && u().removeBlockState(e);
88
+ }
89
+ /**
90
+ * Generates the next unique recommendation ID by scanning all existing blocks
91
+ * in the document and finding the maximum existing ID + 1.
92
+ */
93
+ _generateNextId() {
94
+ let t = 0;
95
+ try {
96
+ const e = this.api.getDocumentRoot();
97
+ e && "querySelectorAll" in e && e.querySelectorAll(`.${c}`).forEach((i) => {
98
+ if ("getAttribute" in i) {
99
+ const m = i.getAttribute(a), l = m ? parseInt(m) : 0;
100
+ l > t && (t = l);
101
+ }
102
+ });
103
+ } catch {
104
+ }
105
+ return t + 1;
106
+ }
107
+ /**
108
+ * Assigns a recommendation-id attribute to the block element.
109
+ * The instance class (ins-recommendation-v3-block-{id}) is embedded in the template
110
+ * HTML by getTemplate(), since Stripo's Angular rendering overwrites dynamically
111
+ * added classes via setAttribute.
112
+ */
113
+ _assignRecommendationId(t, e) {
114
+ const n = this._getBlockElement(t);
115
+ if (!n)
116
+ return;
117
+ const i = this.api.getDocumentModifier();
118
+ i.modifyHtml(n).setAttribute(a, e.toString()), i.apply(new _(`Assign recommendation ID ${e}`));
119
+ }
120
+ /**
121
+ * Gets the recommendation-id from a block node
122
+ */
123
+ _getRecommendationId(t) {
124
+ const e = this._getBlockElement(t);
125
+ if (!e || !("getAttribute" in e))
126
+ return null;
127
+ const n = e.getAttribute(a);
128
+ if (!n)
129
+ return null;
130
+ const i = parseInt(n);
131
+ return Number.isNaN(i) ? null : i;
132
+ }
133
+ /**
134
+ * Gets the block element (the element with BLOCK_CLASS)
135
+ */
136
+ _getBlockElement(t) {
137
+ if ("getAttribute" in t) {
138
+ const e = t.getAttribute("class");
139
+ if (e && e.includes(c))
140
+ return t;
141
+ }
142
+ return "querySelector" in t ? t.querySelector(`.${c}`) : null;
143
+ }
144
+ /**
145
+ * Migrate configuration from legacy format
146
+ */
147
+ _migrateFromLegacy(t) {
148
+ s.migrateFromDataAttributes(this.api, t);
25
149
  }
26
150
  }
27
151
  export {
28
- n as BLOCK_ID,
29
- m as RecommendationBlock
152
+ B as BLOCK_ID,
153
+ y as RecommendationBlock
30
154
  };
@@ -0,0 +1,4 @@
1
+ var b = /* @__PURE__ */ ((r) => (r.BUTTON = "recommendation-block-button", r.NAME = "recommendation-block-name", r.PRICE = "recommendation-block-price", r.OLD_PRICE = "recommendation-block-old-price", r.OMNIBUS_PRICE = "recommendation-block-omnibus-price", r.OMNIBUS_DISCOUNT = "recommendation-block-omnibus-discount", r.IMAGE = "recommendation-block-image", r))(b || {});
2
+ export {
3
+ b as RecommendationBlockId
4
+ };
@@ -0,0 +1,4 @@
1
+ var o = /* @__PURE__ */ ((c) => (c.BUTTON_ALIGN = "recommendation-block-button-align-control", c.BUTTON_BORDER = "recommendation-block-button-border-control", c.BUTTON_BORDER_RADIUS = "recommendation-block-button-border-radius-control", c.BUTTON_COLOR = "recommendation-block-button-color-control", c.BUTTON_FIT_TO_CONTENT = "recommendation-block-button-fit-to-content-control", c.BUTTON_FONT_FAMILY = "recommendation-block-button-font-family-control", c.BUTTON_MARGINS = "recommendation-block-button-margins-control", c.BUTTON_PADDINGS = "recommendation-block-button-paddings-control", c.BUTTON_TEXT = "recommendation-block-button-text-control", c.BUTTON_TEXT_SIZE = "recommendation-block-button-text-size-control", c.BUTTON_TEXT_STYLE_AND_FONT_COLOR = "recommendation-block-button-text-style-and-font-color-control", c.NAME_ALIGN = "recommendation-block-name-align-control", c.NAME_BACKGROUND = "recommendation-block-name-background-control", c.NAME_COLOR = "recommendation-block-name-color-control", c.NAME_FONT_FAMILY = "recommendation-block-name-font-family-control", c.NAME_PADDINGS = "recommendation-block-name-paddings-control", c.NAME_SIZE = "recommendation-block-name-size-control", c.NAME_STYLE = "recommendation-block-name-style-control", c.NAME_TEXT_TRIM = "recommendation-block-name-text-trim-control", c.PRICE_ALIGN = "recommendation-block-price-align-control", c.PRICE_BACKGROUND = "recommendation-block-price-background-control", c.PRICE_COLOR = "recommendation-block-price-color-control", c.PRICE_FONT_FAMILY = "recommendation-block-price-font-family-control", c.PRICE_PADDINGS = "recommendation-block-price-paddings-control", c.PRICE_SIZE = "recommendation-block-price-size-control", c.PRICE_STYLE = "recommendation-block-price-style-control", c.OLD_PRICE_ALIGN = "recommendation-block-old-price-align-control", c.OLD_PRICE_BACKGROUND = "recommendation-block-old-price-background-control", c.OLD_PRICE_COLOR = "recommendation-block-old-price-color-control", c.OLD_PRICE_FONT_FAMILY = "recommendation-block-old-price-font-family-control", c.OLD_PRICE_PADDINGS = "recommendation-block-old-price-paddings-control", c.OLD_PRICE_SIZE = "recommendation-block-old-price-size-control", c.OLD_PRICE_STYLE = "recommendation-block-old-price-style-control", c.OMNIBUS_PRICE_ALIGN = "recommendation-block-omnibus-price-align-control", c.OMNIBUS_PRICE_BACKGROUND = "recommendation-block-omnibus-price-background-control", c.OMNIBUS_PRICE_COLOR = "recommendation-block-omnibus-price-color-control", c.OMNIBUS_PRICE_FONT_FAMILY = "recommendation-block-omnibus-price-font-family-control", c.OMNIBUS_PRICE_PADDINGS = "recommendation-block-omnibus-price-paddings-control", c.OMNIBUS_PRICE_SIZE = "recommendation-block-omnibus-price-size-control", c.OMNIBUS_PRICE_STYLE = "recommendation-block-omnibus-price-style-control", c.OMNIBUS_PRICE_TEXT_BEFORE = "recommendation-block-omnibus-price-text-before-control", c.OMNIBUS_PRICE_TEXT_AFTER = "recommendation-block-omnibus-price-text-after-control", c.OMNIBUS_DISCOUNT_ALIGN = "recommendation-block-omnibus-discount-align-control", c.OMNIBUS_DISCOUNT_BACKGROUND = "recommendation-block-omnibus-discount-background-control", c.OMNIBUS_DISCOUNT_COLOR = "recommendation-block-omnibus-discount-color-control", c.OMNIBUS_DISCOUNT_FONT_FAMILY = "recommendation-block-omnibus-discount-font-family-control", c.OMNIBUS_DISCOUNT_PADDINGS = "recommendation-block-omnibus-discount-paddings-control", c.OMNIBUS_DISCOUNT_SIZE = "recommendation-block-omnibus-discount-size-control", c.OMNIBUS_DISCOUNT_STYLE = "recommendation-block-omnibus-discount-style-control", c.OMNIBUS_DISCOUNT_TEXT_BEFORE = "recommendation-block-omnibus-discount-text-before-control", c.OMNIBUS_DISCOUNT_TEXT_AFTER = "recommendation-block-omnibus-discount-text-after-control", c.IMAGE_SIZE = "recommendation-block-image-size-control", c.IMAGE_MARGINS = "recommendation-block-image-margins-control", c))(o || {});
2
+ export {
3
+ o as RecommendationControlId
4
+ };