@useinsider/guido 2.1.0-beta.c1e85ba → 2.1.0-beta.c2eabd2
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.
- package/README.md +1 -3
- package/dist/components/Guido.vue.js +1 -1
- package/dist/components/Guido.vue2.js +39 -36
- package/dist/components/organisms/email-preview/desktop-preview/EmailSizeIndicator.vue.js +5 -5
- package/dist/components/organisms/email-preview/desktop-preview/EmailSizeIndicator.vue2.js +2 -2
- package/dist/components/organisms/extensions/recommendation/FilterSelectionDrawer.vue2.js +15 -14
- package/dist/composables/useHtmlValidator.js +114 -104
- package/dist/composables/useRecommendation.js +54 -21
- package/dist/composables/useSave.js +12 -16
- package/dist/composables/useStripo.js +54 -58
- package/dist/composables/useStripoEventHandler.js +12 -27
- package/dist/config/compiler/recommendationCompilerRules.js +45 -39
- package/dist/config/compiler/utils/recommendationCompilerUtils.js +121 -0
- package/dist/config/migrator/itemsBlockMigrator.js +101 -97
- package/dist/config/migrator/recommendationMigrator.js +2 -2
- package/dist/enums/extensions/recommendationBlock.js +1 -1
- package/dist/enums/recommendation.js +16 -15
- package/dist/enums/unsubscribe.js +21 -25
- package/dist/extensions/Blocks/Recommendation/block.js +133 -9
- package/dist/extensions/Blocks/Recommendation/constants/blockIds.js +4 -0
- package/dist/extensions/Blocks/Recommendation/constants/controlIds.js +4 -0
- package/dist/extensions/Blocks/Recommendation/constants/defaultConfig.js +66 -0
- package/dist/extensions/Blocks/Recommendation/constants/layout.js +22 -0
- package/dist/extensions/Blocks/Recommendation/constants/selectors.js +21 -0
- package/dist/extensions/Blocks/Recommendation/controls/button/index.js +64 -0
- package/dist/extensions/Blocks/Recommendation/controls/cardBackground/index.js +80 -0
- package/dist/extensions/Blocks/Recommendation/controls/cardComposition/index.js +232 -0
- package/dist/extensions/Blocks/Recommendation/controls/image/index.js +19 -0
- package/dist/extensions/Blocks/Recommendation/controls/layout/index.js +92 -0
- package/dist/extensions/Blocks/Recommendation/controls/main/algorithm.js +102 -0
- package/dist/extensions/Blocks/Recommendation/controls/main/currency.js +209 -0
- package/dist/extensions/Blocks/Recommendation/controls/main/filters.js +52 -0
- package/dist/extensions/Blocks/Recommendation/controls/main/index.js +250 -0
- package/dist/extensions/Blocks/Recommendation/controls/main/locale.js +70 -0
- package/dist/extensions/Blocks/Recommendation/controls/main/productLayout.js +160 -0
- package/dist/extensions/Blocks/Recommendation/controls/main/shuffle.js +67 -0
- package/dist/extensions/Blocks/Recommendation/controls/main/utils.js +307 -0
- package/dist/extensions/Blocks/Recommendation/controls/mobileLayout/cssRules.js +21 -0
- package/dist/extensions/Blocks/Recommendation/controls/name/index.js +46 -0
- package/dist/extensions/Blocks/Recommendation/controls/name/textTrim.js +108 -0
- package/dist/extensions/Blocks/Recommendation/controls/oldPrice/index.js +44 -0
- package/dist/extensions/Blocks/Recommendation/controls/omnibusDiscount/index.js +48 -0
- package/dist/extensions/Blocks/Recommendation/controls/{omnibusDiscountTextAfterControl.js → omnibusDiscount/textAfter.js} +16 -14
- package/dist/extensions/Blocks/Recommendation/controls/{omnibusDiscountTextBeforeControl.js → omnibusDiscount/textBefore.js} +16 -14
- package/dist/extensions/Blocks/Recommendation/controls/omnibusPrice/index.js +48 -0
- package/dist/extensions/Blocks/Recommendation/controls/{omnibusPriceTextAfterControl.js → omnibusPrice/textAfter.js} +16 -14
- package/dist/extensions/Blocks/Recommendation/controls/{omnibusPriceTextBeforeControl.js → omnibusPrice/textBefore.js} +14 -12
- package/dist/extensions/Blocks/Recommendation/controls/price/index.js +44 -0
- package/dist/extensions/Blocks/Recommendation/controls/spacing/index.js +222 -0
- package/dist/extensions/Blocks/Recommendation/extension.js +40 -17
- package/dist/extensions/Blocks/Recommendation/iconsRegistry.js +19 -3
- package/dist/extensions/Blocks/Recommendation/recommendation.css.js +13 -4
- package/dist/extensions/Blocks/Recommendation/services/configService.js +240 -0
- package/dist/extensions/Blocks/Recommendation/settingsPanel.js +21 -10
- package/dist/extensions/Blocks/Recommendation/store/recommendation.js +254 -207
- package/dist/extensions/Blocks/Recommendation/templates/grid/elementRenderer.js +228 -0
- package/dist/extensions/Blocks/Recommendation/templates/grid/migration.js +251 -0
- package/dist/extensions/Blocks/Recommendation/templates/grid/template.js +66 -0
- package/dist/extensions/Blocks/Recommendation/templates/index.js +12 -0
- package/dist/extensions/Blocks/Recommendation/templates/list/elementRenderer.js +169 -0
- package/dist/extensions/Blocks/Recommendation/templates/list/template.js +73 -0
- package/dist/extensions/Blocks/Recommendation/templates/utils.js +134 -0
- package/dist/extensions/Blocks/Recommendation/types/nodeConfig.js +6 -0
- package/dist/extensions/Blocks/Recommendation/utils/filterUtil.js +9 -9
- package/dist/extensions/Blocks/Recommendation/utils/preserveTextStyles.js +26 -15
- package/dist/extensions/Blocks/Recommendation/utils/priceFormatter.js +29 -0
- package/dist/extensions/Blocks/Recommendation/utils/tagName.js +46 -0
- package/dist/extensions/Blocks/controlFactories.js +125 -93
- package/dist/guido.css +1 -1
- package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/esm/index.js +242 -186
- package/dist/services/recommendationApi.js +11 -8
- package/dist/services/stripoApi.js +12 -48
- package/dist/services/templateLibraryApi.js +16 -13
- package/dist/src/@types/events.d.ts +2 -38
- package/dist/src/components/wrappers/WpDrawer.vue.d.ts +1 -1
- package/dist/src/composables/useRecommendation.d.ts +1 -0
- package/dist/src/config/compiler/utils/recommendationCompilerUtils.d.ts +17 -0
- package/dist/src/enums/unsubscribe.d.ts +0 -3
- package/dist/src/extensions/Blocks/Recommendation/block.d.ts +67 -0
- package/dist/src/extensions/Blocks/Recommendation/constants/blockIds.d.ts +13 -0
- package/dist/src/extensions/Blocks/Recommendation/{constants.d.ts → constants/controlIds.d.ts} +0 -24
- package/dist/src/extensions/Blocks/Recommendation/constants/defaultConfig.d.ts +49 -0
- package/dist/src/extensions/Blocks/Recommendation/constants/index.d.ts +13 -0
- package/dist/src/extensions/Blocks/Recommendation/constants/layout.d.ts +41 -0
- package/dist/src/extensions/Blocks/Recommendation/constants/selectors.d.ts +35 -0
- package/dist/src/extensions/Blocks/Recommendation/controls/button/index.d.ts +143 -0
- package/dist/src/extensions/Blocks/Recommendation/controls/cardBackground/index.d.ts +31 -0
- package/dist/src/extensions/Blocks/Recommendation/{cardCompositionControl.d.ts → controls/cardComposition/index.d.ts} +23 -3
- package/dist/src/extensions/Blocks/Recommendation/controls/image/index.d.ts +35 -0
- package/dist/src/extensions/Blocks/Recommendation/controls/index.d.ts +21 -589
- package/dist/src/extensions/Blocks/Recommendation/controls/layout/index.d.ts +37 -0
- package/dist/src/extensions/Blocks/Recommendation/controls/main/algorithm.d.ts +29 -0
- package/dist/src/extensions/Blocks/Recommendation/controls/main/currency.d.ts +52 -0
- package/dist/src/extensions/Blocks/Recommendation/controls/main/filters.d.ts +22 -0
- package/dist/src/extensions/Blocks/Recommendation/controls/main/index.d.ts +79 -0
- package/dist/src/extensions/Blocks/Recommendation/controls/main/locale.d.ts +24 -0
- package/dist/src/extensions/Blocks/Recommendation/controls/main/productLayout.d.ts +60 -0
- package/dist/src/extensions/Blocks/Recommendation/controls/main/shuffle.d.ts +23 -0
- package/dist/src/extensions/Blocks/Recommendation/controls/main/utils.d.ts +221 -0
- package/dist/src/extensions/Blocks/Recommendation/controls/mobileLayout/cssRules.d.ts +29 -0
- package/dist/src/extensions/Blocks/Recommendation/controls/name/index.d.ts +97 -0
- package/dist/src/extensions/Blocks/Recommendation/controls/name/textTrim.d.ts +34 -0
- package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/index.d.ts +95 -0
- package/dist/src/extensions/Blocks/Recommendation/controls/omnibusDiscount/index.d.ts +100 -0
- package/dist/src/extensions/Blocks/Recommendation/controls/omnibusDiscount/textAfter.d.ts +15 -0
- package/dist/src/extensions/Blocks/Recommendation/controls/omnibusDiscount/textBefore.d.ts +15 -0
- package/dist/src/extensions/Blocks/Recommendation/controls/omnibusPrice/index.d.ts +100 -0
- package/dist/src/extensions/Blocks/Recommendation/controls/omnibusPrice/textAfter.d.ts +15 -0
- package/dist/src/extensions/Blocks/Recommendation/controls/omnibusPrice/textBefore.d.ts +15 -0
- package/dist/src/extensions/Blocks/Recommendation/controls/price/index.d.ts +95 -0
- package/dist/src/extensions/Blocks/Recommendation/controls/spacing/index.d.ts +83 -0
- package/dist/src/extensions/Blocks/Recommendation/extension.d.ts +9 -0
- package/dist/src/extensions/Blocks/Recommendation/services/configService.d.ts +151 -0
- package/dist/src/extensions/Blocks/Recommendation/services/index.d.ts +6 -0
- package/dist/src/extensions/Blocks/Recommendation/store/recommendation.d.ts +138 -468
- package/dist/src/extensions/Blocks/Recommendation/templates/grid/elementRenderer.d.ts +20 -0
- package/dist/src/extensions/Blocks/Recommendation/templates/{migrationTemplate.d.ts → grid/migration.d.ts} +11 -4
- package/dist/src/extensions/Blocks/Recommendation/templates/grid/template.d.ts +33 -0
- package/dist/src/extensions/Blocks/Recommendation/templates/index.d.ts +41 -0
- package/dist/src/extensions/Blocks/Recommendation/templates/list/elementRenderer.d.ts +8 -0
- package/dist/src/extensions/Blocks/Recommendation/templates/list/migration.d.ts +25 -0
- package/dist/src/extensions/Blocks/Recommendation/templates/list/template.d.ts +18 -0
- package/dist/src/extensions/Blocks/Recommendation/templates/utils.d.ts +66 -0
- package/dist/src/extensions/Blocks/Recommendation/types/index.d.ts +7 -0
- package/dist/src/extensions/Blocks/Recommendation/types/nodeConfig.d.ts +166 -0
- package/dist/src/extensions/Blocks/Recommendation/utils/priceFormatter.d.ts +33 -0
- package/dist/src/extensions/Blocks/Recommendation/utils/stylePreserver.d.ts +113 -0
- package/dist/src/extensions/Blocks/Recommendation/utils/tagName.d.ts +77 -0
- package/dist/src/services/stripoApi.d.ts +0 -5
- package/dist/src/stores/editor.d.ts +0 -23
- package/dist/static/styles/customEditorStyle.css.js +35 -11
- package/dist/stores/editor.js +1 -2
- package/dist/utils/pairProductVariables.js +57 -56
- package/dist/utils/templatePreparation.js +15 -14
- package/package.json +1 -1
- package/dist/composables/useSyncModuleExtractor.js +0 -45
- package/dist/extensions/Blocks/Recommendation/cardCompositionControl.js +0 -187
- package/dist/extensions/Blocks/Recommendation/constants.js +0 -13
- package/dist/extensions/Blocks/Recommendation/control.js +0 -336
- package/dist/extensions/Blocks/Recommendation/controls/cardBackgroundColorControl.js +0 -68
- package/dist/extensions/Blocks/Recommendation/controls/index.js +0 -245
- package/dist/extensions/Blocks/Recommendation/controls/nameTextTrimControl.js +0 -74
- package/dist/extensions/Blocks/Recommendation/controls/spacingControl.js +0 -188
- package/dist/extensions/Blocks/Recommendation/templates/blockTemplate.js +0 -181
- package/dist/extensions/Blocks/Recommendation/templates/migrationTemplate.js +0 -189
- package/dist/extensions/Blocks/Recommendation/templates/templateUtils.js +0 -209
- package/dist/src/composables/useSyncModuleExtractor.d.ts +0 -4
- package/dist/src/extensions/Blocks/Recommendation/control.d.ts +0 -38
- package/dist/src/extensions/Blocks/Recommendation/controls/nameTextTrimControl.d.ts +0 -16
- package/dist/src/extensions/Blocks/Recommendation/templates/blockTemplate.d.ts +0 -16
- package/dist/src/extensions/Blocks/Recommendation/templates/templateUtils.d.ts +0 -52
- package/dist/src/mock/api/settings.d.ts +0 -2
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
var B = Object.defineProperty;
|
|
2
|
-
var U = (
|
|
3
|
-
var M = (
|
|
2
|
+
var U = (e, t, r) => t in e ? B(e, t, { enumerable: !0, configurable: !0, writable: !0, value: r }) : e[t] = r;
|
|
3
|
+
var M = (e, t, r) => U(e, typeof t != "symbol" ? t + "" : t, r);
|
|
4
4
|
import { productPairs as v } from "../../extensions/Blocks/Items/enums/productEnums.js";
|
|
5
|
-
import { ItemInCartOptions as E, DefaultConfigValues as g, SETTINGS_ENUMS as
|
|
5
|
+
import { ItemInCartOptions as E, 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,76 @@ const w = {
|
|
|
74
74
|
function F() {
|
|
75
75
|
return String(Date.now() + Math.floor(Math.random() * 1e3));
|
|
76
76
|
}
|
|
77
|
-
function q(
|
|
78
|
-
return
|
|
79
|
-
CartItems:
|
|
80
|
-
BrowsedItems:
|
|
81
|
-
PurchasedItems:
|
|
82
|
-
CART_ITEMS:
|
|
83
|
-
BROWSED_ITEMS:
|
|
84
|
-
PURCHASED_ITEMS:
|
|
85
|
-
}[
|
|
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(
|
|
88
|
-
const t = (a, o) => a == null ? o : a === "1" || a === "true",
|
|
89
|
-
let n =
|
|
87
|
+
function R(e) {
|
|
88
|
+
const t = (a, o) => a == null ? o : a === "1" || a === "true", r = (a, o) => a || o, c = e["data-type"] || e["data-source"], i = q(c);
|
|
89
|
+
let n = e["data-cart_items_select_control_value"] || g.cartItemsSelectControlValue;
|
|
90
90
|
if (n && !n.includes("{{") && /^\d+$/.test(n)) {
|
|
91
|
-
const a = parseInt(n) - 1, o = E[
|
|
91
|
+
const a = parseInt(n) - 1, o = E[i];
|
|
92
92
|
o && o[a] && (n = o[a].value);
|
|
93
93
|
}
|
|
94
94
|
return {
|
|
95
95
|
initialized: !0,
|
|
96
|
-
blockInstanceId: e
|
|
97
|
-
source:
|
|
98
|
-
type:
|
|
96
|
+
blockInstanceId: r(e["data-block-instance-id"], F()),
|
|
97
|
+
source: i,
|
|
98
|
+
type: i,
|
|
99
99
|
itemsSelectValue: n,
|
|
100
|
-
orientation:
|
|
101
|
-
nameTrimming: t(
|
|
102
|
-
priceHideDiscount: t(
|
|
103
|
-
priceFormatted: t(
|
|
104
|
-
priceSinglePrice: t(
|
|
105
|
-
priceCurrencySymbol:
|
|
106
|
-
|
|
100
|
+
orientation: e["data-card_orientation_control_value"] || u.ORIENTATION.VERTICAL,
|
|
101
|
+
nameTrimming: t(e["data-product_name_control_trim"], !0),
|
|
102
|
+
priceHideDiscount: t(e["data-product_price_control_nodup"], !0),
|
|
103
|
+
priceFormatted: t(e["data-product_price_control_formated"], !0),
|
|
104
|
+
priceSinglePrice: t(e["data-product_price_control_single_price"], !1),
|
|
105
|
+
priceCurrencySymbol: r(
|
|
106
|
+
e["data-product_price_control_currency_symbol"],
|
|
107
107
|
g.productPriceCurrencySymbolControlValue
|
|
108
108
|
),
|
|
109
|
-
priceCurrencyLocation:
|
|
110
|
-
|
|
109
|
+
priceCurrencyLocation: r(
|
|
110
|
+
e["data-product_price_currency_location"],
|
|
111
111
|
g.productPriceCurrencyLocationControlValue
|
|
112
112
|
),
|
|
113
|
-
priceOrientation:
|
|
114
|
-
quantityControlEnabled: t(
|
|
115
|
-
buttonLink: e
|
|
116
|
-
imageLink: e
|
|
117
|
-
buttonLabel: e
|
|
118
|
-
buttonFullWidth: t(
|
|
119
|
-
imageVisible: t(
|
|
120
|
-
nameVisible: t(
|
|
121
|
-
quantityVisible: t(
|
|
122
|
-
priceVisible: t(
|
|
123
|
-
originalPriceVisible: t(
|
|
124
|
-
buttonVisible: t(
|
|
113
|
+
priceOrientation: e["data-product_original_price_control_orientation"] || "horizontal",
|
|
114
|
+
quantityControlEnabled: t(e["data-product_quantity_control_enabled"], !0),
|
|
115
|
+
buttonLink: r(e["data-product_button_link"], g.productButtonLinkControlValue),
|
|
116
|
+
imageLink: r(e["data-product_image_link"], g.productImageLinkControlValue),
|
|
117
|
+
buttonLabel: r(e["data-product_button_control_label"], "Buy"),
|
|
118
|
+
buttonFullWidth: t(e["data-product_button_control_atw"], !0),
|
|
119
|
+
imageVisible: t(e["data-product_image_control_enabled"], !0),
|
|
120
|
+
nameVisible: t(e["data-product_name_control_enabled"], !0),
|
|
121
|
+
quantityVisible: t(e["data-product_quantity_control_enabled"], !0),
|
|
122
|
+
priceVisible: t(e["data-product_price_control_enabled"], !0),
|
|
123
|
+
originalPriceVisible: t(e["data-product_original_price_control_enabled"], !0),
|
|
124
|
+
buttonVisible: t(e["data-product_button_control_enabled"], !0)
|
|
125
125
|
};
|
|
126
126
|
}
|
|
127
|
-
const
|
|
127
|
+
const O = {
|
|
128
128
|
ins_apr: "CART_ITEMS",
|
|
129
129
|
browsed_item: "BROWSED_ITEMS",
|
|
130
130
|
purchased_item: "PURCHASED_ITEMS"
|
|
131
131
|
};
|
|
132
|
-
function
|
|
133
|
-
const
|
|
132
|
+
function $(e, t) {
|
|
133
|
+
const r = {
|
|
134
134
|
CART_ITEMS: `{{Abandoned Cart Item (${t}) Image}}`,
|
|
135
135
|
BROWSED_ITEMS: `{{Browsed Item (${t}) Image}}`,
|
|
136
136
|
PURCHASED_ITEMS: `{{Purchased Item (${t}) Image}}`
|
|
137
137
|
};
|
|
138
|
-
return e
|
|
138
|
+
return r[e] || r.CART_ITEMS;
|
|
139
139
|
}
|
|
140
|
-
function
|
|
141
|
-
const
|
|
140
|
+
function x(e, t) {
|
|
141
|
+
const r = {
|
|
142
142
|
CART_ITEMS: `{{Abandoned Cart Item (${t}) Url}}`,
|
|
143
143
|
BROWSED_ITEMS: `{{Browsed Item (${t}) Url}}`,
|
|
144
144
|
PURCHASED_ITEMS: `{{Purchased Item (${t}) Url}}`
|
|
145
145
|
};
|
|
146
|
-
return e
|
|
146
|
+
return r[e] || r.CART_ITEMS;
|
|
147
147
|
}
|
|
148
148
|
class V {
|
|
149
149
|
constructor() {
|
|
@@ -152,12 +152,12 @@ class V {
|
|
|
152
152
|
}
|
|
153
153
|
migrate(t) {
|
|
154
154
|
try {
|
|
155
|
-
let
|
|
156
|
-
|
|
157
|
-
const
|
|
155
|
+
let r = this.removeJinjaConditionals(t);
|
|
156
|
+
r = this.replaceTemplateVariables(r);
|
|
157
|
+
const c = this.parser.parseFromString(r, "text/html"), i = c.querySelectorAll(
|
|
158
158
|
"td.esd-cart-items-block, td.esd-browsed-items-block, td.esd-purchased-items-block"
|
|
159
159
|
);
|
|
160
|
-
return
|
|
160
|
+
return i.length === 0 ? (console.warn("ItemsBlockMigrator: No blocks found with items block selectors"), r) : (i.forEach((n) => {
|
|
161
161
|
const a = this.extractConfiguration(n), o = K({
|
|
162
162
|
orientation: a.orientation,
|
|
163
163
|
itemsType: a.itemsType,
|
|
@@ -173,19 +173,19 @@ class V {
|
|
|
173
173
|
originalPriceStyles: a.originalPriceStyles,
|
|
174
174
|
quantityStyles: a.quantityStyles,
|
|
175
175
|
nodeConfig: R(a.configBlockAttributes)
|
|
176
|
-
}),
|
|
176
|
+
}), l = this.parser.parseFromString(
|
|
177
177
|
`<table><tbody><tr>${o}</tr></tbody></table>`,
|
|
178
178
|
"text/html"
|
|
179
179
|
).querySelector("td");
|
|
180
|
-
if (
|
|
180
|
+
if (l && n.parentNode) {
|
|
181
181
|
const f = R(a.configBlockAttributes);
|
|
182
|
-
|
|
183
|
-
const
|
|
184
|
-
|
|
182
|
+
l.setAttribute("esd-ext-config", JSON.stringify(f));
|
|
183
|
+
const d = l.querySelector("esd-config-block");
|
|
184
|
+
d && d.remove(), n.parentNode.replaceChild(l, n);
|
|
185
185
|
}
|
|
186
|
-
}),
|
|
187
|
-
} catch (
|
|
188
|
-
return console.error("ItemsBlockMigrator failed:",
|
|
186
|
+
}), c.documentElement.outerHTML);
|
|
187
|
+
} catch (r) {
|
|
188
|
+
return console.error("ItemsBlockMigrator failed:", r), t;
|
|
189
189
|
}
|
|
190
190
|
}
|
|
191
191
|
/**
|
|
@@ -196,22 +196,22 @@ class V {
|
|
|
196
196
|
*/
|
|
197
197
|
extractConfiguration(t) {
|
|
198
198
|
var C, D, P;
|
|
199
|
-
const
|
|
200
|
-
let
|
|
201
|
-
|
|
202
|
-
const p = t.querySelector('a[product-attr="name"]'),
|
|
199
|
+
const r = ((C = t.querySelector("[data-type]")) == null ? void 0 : C.getAttribute("data-type")) || "CART_ITEMS", c = ((D = t.querySelector("[data-number]")) == null ? void 0 : D.getAttribute("data-number")) || "1", i = parseInt(c) - 1, n = E[r], a = ((P = n == null ? void 0 : n[i]) == 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", d = (o == null ? void 0 : o.getAttribute("data-formated")) !== "false", s = this.extractConfigBlockAttributes(t, r, c), S = s["data-card_orientation_control_value"];
|
|
200
|
+
let b;
|
|
201
|
+
S ? b = S === "horizontal" ? "horizontal" : "vertical" : b = t.querySelector('[colspan="2"]') !== null ? "vertical" : "horizontal";
|
|
202
|
+
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 = (o == null ? void 0 : o.getAttribute("style")) || void 0, T = t.querySelector("p.original-price"), k = (T == null ? void 0 : T.getAttribute("style")) || void 0, A = t.querySelector('[product-attr="quantity"]'), L = (A == null ? void 0 : A.getAttribute("style")) || void 0;
|
|
203
203
|
return {
|
|
204
|
-
orientation:
|
|
205
|
-
itemsType:
|
|
204
|
+
orientation: b,
|
|
205
|
+
itemsType: r,
|
|
206
206
|
itemId: a,
|
|
207
207
|
currencySymbol: _,
|
|
208
208
|
currencyLocation: f,
|
|
209
|
-
formattedPrice:
|
|
209
|
+
formattedPrice: d,
|
|
210
210
|
configBlockAttributes: s,
|
|
211
|
-
nameStyles:
|
|
211
|
+
nameStyles: I,
|
|
212
212
|
buttonStyles: m,
|
|
213
|
-
priceStyles:
|
|
214
|
-
originalPriceStyles:
|
|
213
|
+
priceStyles: h,
|
|
214
|
+
originalPriceStyles: k,
|
|
215
215
|
quantityStyles: L
|
|
216
216
|
};
|
|
217
217
|
}
|
|
@@ -222,17 +222,17 @@ class V {
|
|
|
222
222
|
* @param itemsType - The type of items (CART_ITEMS, BROWSED_ITEMS, PURCHASED_ITEMS)
|
|
223
223
|
* @param itemNumber - The item number (1-based index)
|
|
224
224
|
*/
|
|
225
|
-
extractConfigBlockAttributes(t,
|
|
226
|
-
const
|
|
227
|
-
if (!
|
|
225
|
+
extractConfigBlockAttributes(t, r, c) {
|
|
226
|
+
const i = t.querySelector("esd-config-block"), n = {};
|
|
227
|
+
if (!i)
|
|
228
228
|
return this.getDefaultConfigBlockAttributes();
|
|
229
|
-
if (Array.from(
|
|
229
|
+
if (Array.from(i.attributes).forEach((o) => {
|
|
230
230
|
o.name.startsWith("data-") && (n[o.name] = o.value);
|
|
231
231
|
}), n["data-cart_items_select_control_value"]) {
|
|
232
232
|
const o = n["data-cart_items_select_control_value"];
|
|
233
233
|
if (/^\d+$/.test(o)) {
|
|
234
|
-
const _ = parseInt(o) - 1,
|
|
235
|
-
|
|
234
|
+
const _ = parseInt(o) - 1, l = E[r];
|
|
235
|
+
l && l[_] && (n["data-cart_items_select_control_value"] = l[_].value);
|
|
236
236
|
}
|
|
237
237
|
}
|
|
238
238
|
if (n["data-product_price_control_curency"]) {
|
|
@@ -242,7 +242,7 @@ class V {
|
|
|
242
242
|
}
|
|
243
243
|
(!n["data-product_price_control_currency_symbol"] || n["data-product_price_control_currency_symbol"].trim() === "") && (n["data-product_price_control_currency_symbol"] = "USD");
|
|
244
244
|
const a = { ...this.getDefaultConfigBlockAttributes(), ...n };
|
|
245
|
-
return a["data-type"] =
|
|
245
|
+
return a["data-type"] = r, a["data-source"] = r, a["data-product_image_link"] = $(r, c), a["data-product_button_link"] = x(r, c), a;
|
|
246
246
|
}
|
|
247
247
|
/**
|
|
248
248
|
* Returns default esd-config-block attributes based on the old template structure
|
|
@@ -297,18 +297,22 @@ class V {
|
|
|
297
297
|
* - Cart Items: ins_apr_total_product_kind, ins_apr_price_N, ins_apr_originalprice_N
|
|
298
298
|
* - Browsed Items: browsed_item_total_product_kind, browsed_item_price_N, browsed_item_originalprice_N
|
|
299
299
|
* - Purchased Items: purchased_item_total_product_kind, purchased_item_price_N, purchased_item_originalprice_N
|
|
300
|
+
*
|
|
301
|
+
* IMPORTANT: Preserves the esd-custom-display-conditions attribute on <body> which
|
|
302
|
+
* contains display condition Jinja scripts that should NOT be removed.
|
|
300
303
|
*/
|
|
301
304
|
removeJinjaConditionals(t) {
|
|
302
|
-
|
|
305
|
+
const r = "__ESD_DISPLAY_CONDITIONS_PLACEHOLDER__", c = t.match(/esd-custom-display-conditions="[^"]*"/);
|
|
306
|
+
let i = c ? t.replace(c[0], r) : t;
|
|
307
|
+
return i = i.replace(
|
|
303
308
|
/\{%\s*if\s+(ins_apr|browsed_item|purchased_item)_total_product_kind\s*(>|>)\s*\d+\s*%\}/g,
|
|
304
309
|
""
|
|
305
|
-
)
|
|
306
|
-
return e = e.replace(
|
|
310
|
+
), i = i.replace(
|
|
307
311
|
/\{%\s*if\s+(ins_apr|browsed_item|purchased_item)_price_\d+\s*(!=|!=)\s*\1_originalprice_\d+\s*%\}/g,
|
|
308
312
|
""
|
|
309
|
-
),
|
|
313
|
+
), i = i.replace(/\{%\s*endif\s*%\}/g, ""), c && (i = i.replace(r, c[0])), i = i.replace(/\n\s*\n\s*\n/g, `
|
|
310
314
|
|
|
311
|
-
`),
|
|
315
|
+
`), i;
|
|
312
316
|
}
|
|
313
317
|
/**
|
|
314
318
|
* Replaces template variables with default values from productPairs
|
|
@@ -320,31 +324,31 @@ class V {
|
|
|
320
324
|
* - {{purchased_item_formattedprice_5}} → '1,490.49' (PURCHASED_ITEMS)
|
|
321
325
|
*/
|
|
322
326
|
replaceTemplateVariables(t) {
|
|
323
|
-
const { PAIRS_FOR_EXTENSION:
|
|
324
|
-
return t.replace(/{{([^}]+)}}/g, (
|
|
325
|
-
const n =
|
|
327
|
+
const { PAIRS_FOR_EXTENSION: r } = v;
|
|
328
|
+
return t.replace(/{{([^}]+)}}/g, (c, i) => {
|
|
329
|
+
const n = i.match(/^(ins_apr|browsed_item|purchased_item)_([a-z_]+)_(\d+)$/);
|
|
326
330
|
if (!n)
|
|
327
|
-
return
|
|
328
|
-
const [, a, o, _] = n,
|
|
329
|
-
if (!
|
|
330
|
-
return console.warn(`Unknown variable prefix: ${a}`),
|
|
331
|
+
return c;
|
|
332
|
+
const [, a, o, _] = n, l = O[a];
|
|
333
|
+
if (!l)
|
|
334
|
+
return console.warn(`Unknown variable prefix: ${a}`), c;
|
|
331
335
|
const f = w[o];
|
|
332
336
|
if (!f)
|
|
333
|
-
return console.warn(`Unknown variable suffix mapping for: ${o}`),
|
|
334
|
-
const { pairsKey:
|
|
337
|
+
return console.warn(`Unknown variable suffix mapping for: ${o}`), c;
|
|
338
|
+
const { pairsKey: d, defaultKey: s, isArray: S } = f, p = r[d][l];
|
|
335
339
|
if (!p)
|
|
336
|
-
return console.warn(`No data found for: ${
|
|
337
|
-
if (
|
|
340
|
+
return console.warn(`No data found for: ${d}.${l}`), c;
|
|
341
|
+
if (S) {
|
|
338
342
|
const y = parseInt(_) - 1, m = p[s];
|
|
339
|
-
return Array.isArray(m) && m[y] ? m[y] : (console.warn(`Array value not found: ${
|
|
343
|
+
return Array.isArray(m) && m[y] ? m[y] : (console.warn(`Array value not found: ${d}.${l}.${s}[${y}]`), c);
|
|
340
344
|
}
|
|
341
|
-
const
|
|
342
|
-
return
|
|
345
|
+
const I = p[s];
|
|
346
|
+
return I !== void 0 ? String(I) : (console.warn(`Default value not found: ${d}.${l}.${s}`), c);
|
|
343
347
|
});
|
|
344
348
|
}
|
|
345
349
|
}
|
|
346
|
-
function G(
|
|
347
|
-
return new V().migrate(
|
|
350
|
+
function G(e) {
|
|
351
|
+
return new V().migrate(e);
|
|
348
352
|
}
|
|
349
353
|
export {
|
|
350
354
|
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/
|
|
5
|
-
import { getDefaultProducts as q } from "../../extensions/Blocks/Recommendation/templates/
|
|
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: "
|
|
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
|
|
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
|
-
},
|
|
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: /
|
|
28
|
-
ATTRIBUTE_PARAGRAPH: /<p[^>]*?product-attr="(discount|omnibus_discount|omnibus_price)"
|
|
29
|
-
ATTRIBUTE_PARAGRAPH_START_TAG: /<p[^>]*?product-attr="(discount|omnibus_discount|omnibus_price)"
|
|
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
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
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,17 +1,17 @@
|
|
|
1
1
|
import { useTranslations as e } from "../composables/useTranslations.js";
|
|
2
2
|
import { getEnvironmentPrefix as R } from "../utils/environmentUtil.js";
|
|
3
|
-
const
|
|
3
|
+
const I = {
|
|
4
4
|
UNSUBSCRIBE_LINK_TYPE: 1,
|
|
5
5
|
PREFERENCES_LINK_TYPE: 3
|
|
6
|
-
},
|
|
6
|
+
}, r = {
|
|
7
7
|
UNSUBSCRIBE_LINK_REGEX: /{{ins-unsubscribe-link}}/g,
|
|
8
8
|
DATA_OGSB_BUTTON_CSS_REGEX: "\\[data-ogsb\\]\\s*\\.es-button\\.es-button-[0-9]+\\s*\\{(?:[^\\}]*)\\}",
|
|
9
9
|
GLOBAL_UNSUBSCRIBE_LINK_REGEX: /{{ins-global-unsubscribe-link}}/g,
|
|
10
10
|
PREFERENCES_UNSUBSCRIBE_LINK_REGEX: /{{ins-preferences-unsubscribe-link}}/g
|
|
11
|
-
},
|
|
12
|
-
UNSUBSCRIBE_URL: `https://mail.${
|
|
13
|
-
PREFERENCES_URL: `https://mail.${
|
|
14
|
-
},
|
|
11
|
+
}, s = R(), _ = {
|
|
12
|
+
UNSUBSCRIBE_URL: `https://mail.${s}.com/user/v1/unsub`,
|
|
13
|
+
PREFERENCES_URL: `https://mail.${s}.com/user/v1/prefs`
|
|
14
|
+
}, i = "iid", B = {
|
|
15
15
|
name: "Global Unsubscribe",
|
|
16
16
|
sendGridId: "G"
|
|
17
17
|
}, C = "/email/unsubscribe-pages", E = {
|
|
@@ -20,9 +20,6 @@ const _ = {
|
|
|
20
20
|
SUBSCRIPTION_PREFERENCE_CENTER: 3,
|
|
21
21
|
SUBSCRIPTION_PREFERENCE_CONFIRMATION: 4,
|
|
22
22
|
RESUBSCRIBE: 5
|
|
23
|
-
}, U = {
|
|
24
|
-
[E.GLOBAL_UNSUBSCRIBE]: "custom-unsubscribe",
|
|
25
|
-
[E.SUBSCRIPTION_PREFERENCE_CENTER]: "custom-preferences"
|
|
26
23
|
}, t = {
|
|
27
24
|
[E.GLOBAL_UNSUBSCRIBE]: [
|
|
28
25
|
E.GLOBAL_UNSUBSCRIBE,
|
|
@@ -33,30 +30,29 @@ const _ = {
|
|
|
33
30
|
E.SUBSCRIPTION_PREFERENCE_CENTER,
|
|
34
31
|
E.SUBSCRIPTION_PREFERENCE_CONFIRMATION
|
|
35
32
|
]
|
|
36
|
-
},
|
|
37
|
-
const
|
|
33
|
+
}, U = () => {
|
|
34
|
+
const n = e();
|
|
38
35
|
return {
|
|
39
|
-
[E.GLOBAL_UNSUBSCRIBE]:
|
|
40
|
-
[E.GLOBAL_UNSUBSCRIBE_CONFIRMATION_PAGE]:
|
|
41
|
-
[E.RESUBSCRIBE]:
|
|
42
|
-
[E.SUBSCRIPTION_PREFERENCE_CENTER]:
|
|
43
|
-
[E.SUBSCRIPTION_PREFERENCE_CONFIRMATION]:
|
|
36
|
+
[E.GLOBAL_UNSUBSCRIBE]: n("unsubscription-preference.type-global-unsubscribe"),
|
|
37
|
+
[E.GLOBAL_UNSUBSCRIBE_CONFIRMATION_PAGE]: n("unsubscription-preference.type-global-unsubscription-confirmation"),
|
|
38
|
+
[E.RESUBSCRIBE]: n("unsubscription-preference.type-resubscribe"),
|
|
39
|
+
[E.SUBSCRIPTION_PREFERENCE_CENTER]: n("unsubscription-preference.type-subscription-preferences-center"),
|
|
40
|
+
[E.SUBSCRIPTION_PREFERENCE_CONFIRMATION]: n("unsubscription-preference.type-subscription-preferences-confirmation")
|
|
44
41
|
};
|
|
45
|
-
},
|
|
42
|
+
}, c = {
|
|
46
43
|
default: "{{ins-unsubscribe-link}}",
|
|
47
44
|
[E.GLOBAL_UNSUBSCRIBE]: "{{ins-global-unsubscribe-link}}",
|
|
48
45
|
[E.SUBSCRIPTION_PREFERENCE_CENTER]: "{{ins-preferences-unsubscribe-link}}"
|
|
49
46
|
};
|
|
50
47
|
export {
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
48
|
+
B as DEFAULT_UNSUBSCRIBE_GROUP,
|
|
49
|
+
i as INSIDER_ID,
|
|
50
|
+
r as LINK_REGEXES,
|
|
51
|
+
I as LINK_TYPES,
|
|
52
|
+
c as MERGE_TAGS,
|
|
56
53
|
E as PAGE_TYPES,
|
|
57
54
|
t as TYPE_COLLECTIONS,
|
|
58
55
|
C as UNSUBSCRIBE_PAGES_LINK,
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
c as getTypeTranslations
|
|
56
|
+
_ as URLS,
|
|
57
|
+
U as getTypeTranslations
|
|
62
58
|
};
|
|
@@ -1,18 +1,29 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
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
|
|
20
|
+
return B;
|
|
10
21
|
}
|
|
11
22
|
getIcon() {
|
|
12
23
|
return "recommendation-icon";
|
|
13
24
|
}
|
|
14
25
|
getBlockCompositionType() {
|
|
15
|
-
return
|
|
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
|
-
|
|
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
|
-
|
|
29
|
-
|
|
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
|
+
};
|