@useinsider/guido 3.2.0-beta.e69fb3b → 3.2.0-beta.ecc7c6c
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/dist/@types/config/schemas.js +1 -1
- package/dist/@types/config/validator.js +34 -27
- package/dist/components/Guido.vue.js +1 -1
- package/dist/components/Guido.vue2.js +81 -76
- package/dist/components/organisms/base/Toaster.vue2.js +11 -10
- package/dist/components/organisms/email-preview/desktop-preview/DesktopPreview.vue2.js +12 -12
- package/dist/components/organisms/email-preview/mobile-preview/ContentView.vue2.js +6 -6
- package/dist/components/organisms/email-preview/mobile-preview/InboxView.vue2.js +15 -9
- package/dist/components/organisms/extensions/recommendation/FilterItem.vue2.js +40 -31
- package/dist/components/organisms/extensions/recommendation/FilterSelectionDrawer.vue2.js +20 -19
- package/dist/components/organisms/extensions/recommendation/Filters.vue2.js +14 -11
- package/dist/components/organisms/header/EditorActions.vue.js +12 -11
- package/dist/components/organisms/header/EditorActions.vue2.js +22 -18
- package/dist/components/organisms/header/HeaderWrapper.vue2.js +15 -12
- package/dist/components/organisms/header/LeftSlot.vue2.js +19 -16
- package/dist/components/organisms/header/MiddleSlot.vue2.js +11 -14
- package/dist/components/organisms/header/RightSlot.vue2.js +17 -14
- package/dist/components/organisms/onboarding/AMPOnboarding.vue.js +12 -11
- package/dist/components/organisms/onboarding/AMPOnboarding.vue2.js +26 -24
- package/dist/components/organisms/onboarding/GenericOnboarding.vue.js +12 -11
- package/dist/components/organisms/onboarding/GenericOnboarding.vue2.js +44 -41
- package/dist/components/organisms/onboarding/ItemsOnboarding.vue.js +12 -11
- package/dist/components/organisms/onboarding/ItemsOnboarding.vue2.js +38 -36
- package/dist/components/organisms/onboarding/NewVersionPopup.vue2.js +21 -18
- package/dist/components/organisms/onboarding/OnboardingWrapper.vue2.js +31 -27
- package/dist/components/organisms/onboarding/TextBlockOnboarding.vue.js +12 -11
- package/dist/components/organisms/onboarding/TextBlockOnboarding.vue2.js +32 -30
- package/dist/components/organisms/onboarding/VersionHistoryOnboarding.vue.js +12 -11
- package/dist/components/organisms/onboarding/VersionHistoryOnboarding.vue2.js +23 -21
- package/dist/components/organisms/save-as-template/SaveAsTemplateDrawer.vue2.js +9 -8
- package/dist/components/organisms/unsubscribe/UnsubscribeWrapper.vue.js +10 -9
- package/dist/composables/useActionsApi.js +38 -37
- package/dist/composables/useBlocksConfig.js +26 -26
- package/dist/composables/useFullStoryBridge.js +9 -8
- package/dist/composables/useHtmlCompiler.js +26 -34
- package/dist/composables/useHtmlValidator.js +114 -101
- package/dist/composables/useHttp.js +30 -30
- package/dist/composables/usePartner.js +1 -1
- package/dist/composables/useRecommendation.js +15 -14
- package/dist/composables/useRibbonOffset.js +15 -15
- package/dist/composables/useSave.js +23 -19
- package/dist/composables/useStripo.js +48 -53
- package/dist/composables/useSyncModuleExtractor.js +29 -31
- package/dist/composables/useTimerClone.js +25 -24
- package/dist/composables/useTranslations.js +3 -2
- package/dist/composables/useValidation.js +8 -7
- package/dist/composables/validators/useCouponBlockValidator.js +24 -0
- package/dist/composables/validators/useLiquidValidator.js +13 -13
- package/dist/config/compiler/recommendationCompilerRules.js +27 -27
- package/dist/config/compiler/unsubscribeCompilerRules.js +19 -17
- package/dist/config/compiler/utils/recommendationCompilerUtils.js +11 -10
- package/dist/config/migrator/checkboxMigrator.js +21 -20
- package/dist/config/migrator/couponBlockMigrator.js +19 -18
- package/dist/config/migrator/itemsBlockMigrator.js +89 -87
- package/dist/config/migrator/radioButtonMigrator.js +63 -42
- package/dist/config/migrator/recommendationMigrator.js +109 -106
- package/dist/config/migrator/unsubscribeMigrator.js +11 -10
- package/dist/enums/unsubscribe.js +19 -18
- package/dist/extensions/Blocks/Items/block.js +9 -9
- package/dist/extensions/Blocks/Items/controls/button/link.js +14 -14
- package/dist/extensions/Blocks/Items/controls/cardComposition.js +97 -89
- package/dist/extensions/Blocks/Items/controls/image/link.js +14 -14
- package/dist/extensions/Blocks/Items/controls/name/trimming.js +24 -23
- package/dist/extensions/Blocks/Items/controls/price/currencyLocation.js +14 -13
- package/dist/extensions/Blocks/Items/controls/price/currencySymbol.js +47 -44
- package/dist/extensions/Blocks/Items/controls/price/formattedPrice.js +38 -38
- package/dist/extensions/Blocks/Items/controls/price/hideDiscount.js +11 -11
- package/dist/extensions/Blocks/Items/controls/price/priceOrientation.js +40 -38
- package/dist/extensions/Blocks/Items/controls/price/singlePrice.js +35 -35
- package/dist/extensions/Blocks/Items/controls/settingsControl.js +162 -155
- package/dist/extensions/Blocks/Items/enums/productEnums.js +14 -9
- package/dist/extensions/Blocks/Items/template.js +210 -210
- package/dist/extensions/Blocks/RadioButton/template.js +1 -1
- package/dist/extensions/Blocks/Recommendation/controls/button/index.js +36 -36
- package/dist/extensions/Blocks/Recommendation/controls/cardComposition/index.js +133 -128
- package/dist/extensions/Blocks/Recommendation/controls/customAttribute/index.js +9 -9
- package/dist/extensions/Blocks/Recommendation/controls/customAttribute/textTrim.js +10 -10
- package/dist/extensions/Blocks/Recommendation/controls/image/index.js +9 -9
- package/dist/extensions/Blocks/Recommendation/controls/main/algorithm.js +18 -17
- package/dist/extensions/Blocks/Recommendation/controls/main/filters.js +6 -4
- package/dist/extensions/Blocks/Recommendation/controls/main/index.js +90 -82
- package/dist/extensions/Blocks/Recommendation/controls/main/layoutOrientation.js +18 -18
- package/dist/extensions/Blocks/Recommendation/controls/main/productCount.js +4 -4
- package/dist/extensions/Blocks/Recommendation/controls/main/productLayout.js +36 -35
- package/dist/extensions/Blocks/Recommendation/controls/main/utils.js +135 -134
- package/dist/extensions/Blocks/Recommendation/controls/name/index.js +24 -24
- package/dist/extensions/Blocks/Recommendation/controls/name/textTrim.js +10 -10
- package/dist/extensions/Blocks/Recommendation/controls/oldPrice/index.js +24 -24
- package/dist/extensions/Blocks/Recommendation/controls/omnibusDiscount/index.js +24 -24
- package/dist/extensions/Blocks/Recommendation/controls/omnibusDiscount/textAfter.js +4 -4
- package/dist/extensions/Blocks/Recommendation/controls/omnibusDiscount/textBefore.js +4 -4
- package/dist/extensions/Blocks/Recommendation/controls/omnibusPrice/index.js +24 -24
- package/dist/extensions/Blocks/Recommendation/controls/omnibusPrice/textAfter.js +4 -4
- package/dist/extensions/Blocks/Recommendation/controls/omnibusPrice/textBefore.js +4 -4
- package/dist/extensions/Blocks/Recommendation/controls/price/index.js +24 -24
- package/dist/extensions/Blocks/Recommendation/controls/spacing/index.js +32 -32
- package/dist/extensions/Blocks/Recommendation/controls/syncInfoMessage.js +20 -18
- package/dist/extensions/Blocks/Recommendation/extension.js +32 -31
- package/dist/extensions/Blocks/Recommendation/settingsPanel.js +16 -8
- package/dist/extensions/Blocks/Recommendation/store/recommendation.js +64 -54
- package/dist/extensions/Blocks/Recommendation/templates/grid/elementRenderer.js +23 -22
- package/dist/extensions/Blocks/Recommendation/templates/grid/migration.js +10 -10
- package/dist/extensions/Blocks/Recommendation/templates/grid/template.js +10 -10
- package/dist/extensions/Blocks/Recommendation/templates/index.js +6 -6
- package/dist/extensions/Blocks/Recommendation/templates/list/elementRenderer.js +25 -24
- package/dist/extensions/Blocks/Recommendation/templates/list/template.js +1 -1
- package/dist/extensions/Blocks/Recommendation/templates/utils.js +47 -45
- package/dist/extensions/Blocks/Recommendation/validation/filterSchema.js +16 -13
- package/dist/extensions/Blocks/Recommendation/validation/requiredFields.js +33 -0
- package/dist/extensions/Blocks/Unsubscribe/control.js +13 -11
- package/dist/extensions/Blocks/Unsubscribe/elements/preview.js +18 -16
- package/dist/extensions/Blocks/common-control.js +26 -25
- package/dist/extensions/DynamicContent/dynamic-content.js +58 -53
- package/dist/guido.css +1 -1
- package/dist/library.js +12 -11
- package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/esm/index.js +234 -233
- package/dist/node_modules/lodash-es/_DataView.js +6 -0
- package/dist/node_modules/lodash-es/_Promise.js +6 -0
- package/dist/node_modules/lodash-es/_Set.js +6 -0
- package/dist/node_modules/lodash-es/_SetCache.js +13 -0
- package/dist/node_modules/lodash-es/_Stack.js +18 -0
- package/dist/node_modules/lodash-es/_Uint8Array.js +5 -0
- package/dist/node_modules/lodash-es/_WeakMap.js +6 -0
- package/dist/node_modules/lodash-es/_arrayFilter.js +10 -0
- package/dist/node_modules/lodash-es/_arrayLikeKeys.js +20 -0
- package/dist/node_modules/lodash-es/_arrayMap.js +8 -0
- package/dist/node_modules/lodash-es/_arrayPush.js +8 -0
- package/dist/node_modules/lodash-es/_arraySome.js +9 -0
- package/dist/node_modules/lodash-es/_baseEach.js +6 -0
- package/dist/node_modules/lodash-es/_baseFlatten.js +13 -0
- package/dist/node_modules/lodash-es/_baseFor.js +5 -0
- package/dist/node_modules/lodash-es/_baseForOwn.js +8 -0
- package/dist/node_modules/lodash-es/_baseGet.js +11 -0
- package/dist/node_modules/lodash-es/_baseGetAllKeys.js +9 -0
- package/dist/node_modules/lodash-es/_baseHasIn.js +6 -0
- package/dist/node_modules/lodash-es/_baseIsArguments.js +9 -0
- package/dist/node_modules/lodash-es/_baseIsEqual.js +8 -0
- package/dist/node_modules/lodash-es/_baseIsEqualDeep.js +32 -0
- package/dist/node_modules/lodash-es/_baseIsMatch.js +29 -0
- package/dist/node_modules/lodash-es/_baseIsTypedArray.js +12 -0
- package/dist/node_modules/lodash-es/_baseIteratee.js +11 -0
- package/dist/node_modules/lodash-es/_baseKeys.js +14 -0
- package/dist/node_modules/lodash-es/_baseMap.js +11 -0
- package/dist/node_modules/lodash-es/_baseMatches.js +12 -0
- package/dist/node_modules/lodash-es/_baseMatchesProperty.js +17 -0
- package/dist/node_modules/lodash-es/_baseProperty.js +8 -0
- package/dist/node_modules/lodash-es/_basePropertyDeep.js +9 -0
- package/dist/node_modules/lodash-es/_baseRange.js +9 -0
- package/dist/node_modules/lodash-es/_baseTimes.js +8 -0
- package/dist/node_modules/lodash-es/_baseToString.js +18 -0
- package/dist/node_modules/lodash-es/_baseTrim.js +8 -0
- package/dist/node_modules/lodash-es/_baseUnary.js +8 -0
- package/dist/node_modules/lodash-es/_cacheHas.js +6 -0
- package/dist/node_modules/lodash-es/_castPath.js +10 -0
- package/dist/node_modules/lodash-es/_createBaseEach.js +15 -0
- package/dist/node_modules/lodash-es/_createBaseFor.js +13 -0
- package/dist/node_modules/lodash-es/_createRange.js +11 -0
- package/dist/node_modules/lodash-es/_equalArrays.js +40 -0
- package/dist/node_modules/lodash-es/_equalByTag.js +45 -0
- package/dist/node_modules/lodash-es/_equalObjects.js +36 -0
- package/dist/node_modules/lodash-es/_getAllKeys.js +9 -0
- package/dist/node_modules/lodash-es/_getMatchData.js +12 -0
- package/dist/node_modules/lodash-es/_getSymbols.js +10 -0
- package/dist/node_modules/lodash-es/_getTag.js +28 -0
- package/dist/node_modules/lodash-es/_getValue.js +1 -1
- package/dist/node_modules/lodash-es/_hasPath.js +19 -0
- package/dist/node_modules/lodash-es/_isFlattenable.js +10 -0
- package/dist/node_modules/lodash-es/_isIndex.js +8 -0
- package/dist/node_modules/lodash-es/_isIterateeCall.js +13 -0
- package/dist/node_modules/lodash-es/_isKey.js +12 -0
- package/dist/node_modules/lodash-es/_isPrototype.js +8 -0
- package/dist/node_modules/lodash-es/_isStrictComparable.js +7 -0
- package/dist/node_modules/lodash-es/_mapToArray.js +9 -0
- package/dist/node_modules/lodash-es/_matchesStrictComparable.js +8 -0
- package/dist/node_modules/lodash-es/_memoizeCapped.js +11 -0
- package/dist/node_modules/lodash-es/_nativeKeys.js +5 -0
- package/dist/node_modules/lodash-es/_nodeUtil.js +11 -0
- package/dist/node_modules/lodash-es/_overArg.js +8 -0
- package/dist/node_modules/lodash-es/_setCacheAdd.js +7 -0
- package/dist/node_modules/lodash-es/_setCacheHas.js +6 -0
- package/dist/node_modules/lodash-es/_setToArray.js +9 -0
- package/dist/node_modules/lodash-es/_stackClear.js +7 -0
- package/dist/node_modules/lodash-es/_stackDelete.js +7 -0
- package/dist/node_modules/lodash-es/_stackGet.js +6 -0
- package/dist/node_modules/lodash-es/_stackHas.js +6 -0
- package/dist/node_modules/lodash-es/_stackSet.js +17 -0
- package/dist/node_modules/lodash-es/_stringToPath.js +10 -0
- package/dist/node_modules/lodash-es/_toKey.js +10 -0
- package/dist/node_modules/lodash-es/_trimmedEndIndex.js +9 -0
- package/dist/node_modules/lodash-es/flatMap.js +8 -0
- package/dist/node_modules/lodash-es/get.js +8 -0
- package/dist/node_modules/lodash-es/hasIn.js +8 -0
- package/dist/node_modules/lodash-es/identity.js +6 -0
- package/dist/node_modules/lodash-es/isArguments.js +10 -0
- package/dist/node_modules/lodash-es/isArray.js +4 -0
- package/dist/node_modules/lodash-es/isArrayLike.js +8 -0
- package/dist/node_modules/lodash-es/isBuffer.js +6 -0
- package/dist/node_modules/lodash-es/isLength.js +7 -0
- package/dist/node_modules/lodash-es/isObjectLike.js +6 -0
- package/dist/node_modules/lodash-es/isSymbol.js +9 -0
- package/dist/node_modules/lodash-es/isTypedArray.js +7 -0
- package/dist/node_modules/lodash-es/keys.js +9 -0
- package/dist/node_modules/lodash-es/map.js +11 -0
- package/dist/node_modules/lodash-es/property.js +10 -0
- package/dist/node_modules/lodash-es/range.js +5 -0
- package/dist/node_modules/lodash-es/stubArray.js +6 -0
- package/dist/node_modules/lodash-es/stubFalse.js +6 -0
- package/dist/node_modules/lodash-es/toFinite.js +14 -0
- package/dist/node_modules/lodash-es/toNumber.js +22 -0
- package/dist/node_modules/lodash-es/toString.js +7 -0
- package/dist/node_modules/valibot/dist/index.js +126 -122
- package/dist/services/recommendationApi.js +17 -14
- package/dist/services/templateLibraryApi.js +40 -38
- package/dist/src/components/wrappers/WpModal.vue.d.ts +1 -1
- package/dist/src/composables/useHtmlCompiler.d.ts +2 -1
- package/dist/src/composables/validators/useCouponBlockValidator.d.ts +3 -0
- package/dist/src/extensions/Blocks/RadioButton/template.d.ts +1 -1
- package/dist/src/extensions/Blocks/Recommendation/store/recommendation.d.ts +7 -1
- package/dist/src/extensions/Blocks/Recommendation/validation/requiredFields.d.ts +21 -0
- package/dist/src/stores/dynamic-content.d.ts +3 -3
- package/dist/stores/config.js +81 -25
- package/dist/stores/dynamic-content.js +11 -6
- package/dist/stores/onboarding.js +1 -1
- package/dist/stores/preview.js +9 -6
- package/dist/stores/unsubscribe.js +4 -1
- package/dist/utils/dateUtil.js +10 -7
- package/dist/utils/genericUtil.js +13 -10
- package/dist/utils/pairProductVariables.js +89 -87
- package/package.json +1 -6
- package/dist/enums/displayConditions.js +0 -80
- package/dist/src/enums/displayConditions.d.ts +0 -2
|
@@ -4,25 +4,25 @@ var A = (d, e, t) => T(d, typeof e != "symbol" ? e + "" : e, t);
|
|
|
4
4
|
import { BLOCK_ID as S } from "../../extensions/Blocks/Recommendation/block.js";
|
|
5
5
|
import P, { prepareProductRows as q } from "../../extensions/Blocks/Recommendation/templates/grid/migration.js";
|
|
6
6
|
import { useTemplateStore as w } from "../../stores/template.js";
|
|
7
|
-
import { getDefaultProducts as
|
|
8
|
-
class
|
|
7
|
+
import { getDefaultProducts as $ } from "../../extensions/Blocks/Recommendation/templates/utils.js";
|
|
8
|
+
class B {
|
|
9
9
|
constructor() {
|
|
10
10
|
A(this, "parser");
|
|
11
11
|
this.parser = new DOMParser();
|
|
12
12
|
}
|
|
13
13
|
migrate(e) {
|
|
14
14
|
try {
|
|
15
|
-
const t = this.parser.parseFromString(e, "text/html"),
|
|
15
|
+
const t = this.parser.parseFromString(e, "text/html"), s = t.querySelectorAll(
|
|
16
16
|
'td.ins-recommendation-v3-block-1:not(.recommendation-block-v2), td.product-block[esd-handler-name*="EmailRecommendationV3"]:not(.recommendation-block-v2)'
|
|
17
17
|
);
|
|
18
|
-
return w().$patch((
|
|
19
|
-
|
|
20
|
-
}),
|
|
21
|
-
const r =
|
|
22
|
-
`<table id="tempDoc"><tbody><tr>${
|
|
18
|
+
return w().$patch((i) => {
|
|
19
|
+
i.migrations = { ...i.migrations, [S]: s.length };
|
|
20
|
+
}), s.length === 0 ? e : (s.forEach((i) => {
|
|
21
|
+
const r = i.getAttribute("id"), n = this.extractBgColor(i), u = this.extractTitle(i), c = this.extractProductRows(i), l = P.replace("{-{-TITLE-}-}", u).replace("{-{-PRODUCT_ROWS-}-}", c), a = this.parser.parseFromString(
|
|
22
|
+
`<table id="tempDoc"><tbody><tr>${l}</tr></tbody></table>`,
|
|
23
23
|
"text/html"
|
|
24
24
|
).querySelector(".recommendation-block-v2");
|
|
25
|
-
|
|
25
|
+
a && i.parentNode && (r && a.setAttribute("id", r), n && a.setAttribute("bgcolor", n), i.parentNode.replaceChild(a, i));
|
|
26
26
|
}), t.documentElement.outerHTML);
|
|
27
27
|
} catch (t) {
|
|
28
28
|
return console.error("RecommendationMigrator failed:", t), e;
|
|
@@ -37,11 +37,11 @@ class $ {
|
|
|
37
37
|
const t = e.getAttribute("bgcolor");
|
|
38
38
|
if (t)
|
|
39
39
|
return t.trim();
|
|
40
|
-
const
|
|
41
|
-
if (
|
|
42
|
-
const
|
|
43
|
-
if (
|
|
44
|
-
return
|
|
40
|
+
const s = e.getAttribute("style");
|
|
41
|
+
if (s) {
|
|
42
|
+
const o = s.match(/background-color\s*:\s*([^;]+)/i);
|
|
43
|
+
if (o && o[1])
|
|
44
|
+
return o[1].trim();
|
|
45
45
|
}
|
|
46
46
|
return "";
|
|
47
47
|
}
|
|
@@ -54,11 +54,11 @@ class $ {
|
|
|
54
54
|
const t = e.getAttribute("bgcolor");
|
|
55
55
|
if (t)
|
|
56
56
|
return t.trim();
|
|
57
|
-
const
|
|
58
|
-
if (
|
|
59
|
-
const
|
|
60
|
-
if (
|
|
61
|
-
return
|
|
57
|
+
const s = e.getAttribute("style");
|
|
58
|
+
if (s) {
|
|
59
|
+
const o = s.match(/background-color\s*:\s*([^;]+)/i);
|
|
60
|
+
if (o && o[1])
|
|
61
|
+
return o[1].trim();
|
|
62
62
|
}
|
|
63
63
|
return "";
|
|
64
64
|
}
|
|
@@ -68,6 +68,7 @@ class $ {
|
|
|
68
68
|
* @returns HTML string for the title block
|
|
69
69
|
*/
|
|
70
70
|
extractTitle(e) {
|
|
71
|
+
var g, a;
|
|
71
72
|
const t = e.querySelector(".ext-recommendation-title");
|
|
72
73
|
if (!t)
|
|
73
74
|
return this.buildTitleBlock({
|
|
@@ -77,24 +78,24 @@ class $ {
|
|
|
77
78
|
align: "center",
|
|
78
79
|
styles: "font-size: 28px; color: #333333;"
|
|
79
80
|
});
|
|
80
|
-
const
|
|
81
|
-
if (!
|
|
82
|
-
const
|
|
81
|
+
const s = t.querySelector("p");
|
|
82
|
+
if (!s) {
|
|
83
|
+
const p = ((g = t.textContent) == null ? void 0 : g.trim()) || "You May Also Like!", b = t.getAttribute("align") || "center";
|
|
83
84
|
return this.buildTitleBlock({
|
|
84
|
-
text:
|
|
85
|
+
text: p,
|
|
85
86
|
isBold: !0,
|
|
86
87
|
isItalic: !1,
|
|
87
|
-
align:
|
|
88
|
+
align: b,
|
|
88
89
|
styles: "font-size: 28px; color: #333333;"
|
|
89
90
|
});
|
|
90
91
|
}
|
|
91
|
-
const
|
|
92
|
+
const o = ((a = s.textContent) == null ? void 0 : a.trim()) || "You May Also Like!", i = t.getAttribute("align") || s.getAttribute("align") || "center", r = s.getAttribute("style") || "", n = /font-weight\s*:\s*bold/i.test(r) || !!s.querySelector("b, strong"), u = /font-style\s*:\s*italic/i.test(r) || !!s.querySelector("i, em"), c = this.removeStyleProperties(r, ["font-weight", "font-style"]), l = this.convertInlineToBlock(c);
|
|
92
93
|
return this.buildTitleBlock({
|
|
93
|
-
text:
|
|
94
|
-
isBold:
|
|
95
|
-
isItalic:
|
|
96
|
-
align:
|
|
97
|
-
styles:
|
|
94
|
+
text: o,
|
|
95
|
+
isBold: n,
|
|
96
|
+
isItalic: u,
|
|
97
|
+
align: i,
|
|
98
|
+
styles: l
|
|
98
99
|
});
|
|
99
100
|
}
|
|
100
101
|
/**
|
|
@@ -106,8 +107,8 @@ class $ {
|
|
|
106
107
|
const t = this.extractProductConfig(e);
|
|
107
108
|
if (!t)
|
|
108
109
|
return console.warn("[RecommendationMigrator] No product config found, using defaults"), this.generateProductRows(6, 3, {});
|
|
109
|
-
const { totalCount:
|
|
110
|
-
return this.generateProductRows(
|
|
110
|
+
const { totalCount: s, productsPerRow: o } = t, i = this.extractProductStyles(e);
|
|
111
|
+
return this.generateProductRows(s, o, i);
|
|
111
112
|
}
|
|
112
113
|
/**
|
|
113
114
|
* Extracts Stripo padding/margin utility classes from a class string
|
|
@@ -115,7 +116,7 @@ class $ {
|
|
|
115
116
|
* @returns Filtered Stripo utility classes as a space-separated string
|
|
116
117
|
*/
|
|
117
118
|
extractStripoClasses(e) {
|
|
118
|
-
return e ? e.split(/\s+/).filter((
|
|
119
|
+
return e ? e.split(/\s+/).filter((o) => /^es-(p\d+|m[-\d])/.test(o)).join(" ") : "";
|
|
119
120
|
}
|
|
120
121
|
/**
|
|
121
122
|
* Extracts product configuration from old block
|
|
@@ -127,15 +128,15 @@ class $ {
|
|
|
127
128
|
if (!t)
|
|
128
129
|
return null;
|
|
129
130
|
try {
|
|
130
|
-
const
|
|
131
|
+
const s = this.unescapeJsonString(t), o = JSON.parse(s);
|
|
131
132
|
return {
|
|
132
|
-
totalCount:
|
|
133
|
-
productsPerRow:
|
|
133
|
+
totalCount: o.totalCount ?? 6,
|
|
134
|
+
productsPerRow: o.rowCount ?? 3
|
|
134
135
|
};
|
|
135
|
-
} catch (
|
|
136
|
-
return console.error("[RecommendationMigrator] Failed to parse product config:",
|
|
136
|
+
} catch (s) {
|
|
137
|
+
return console.error("[RecommendationMigrator] Failed to parse product config:", s), console.error(
|
|
137
138
|
"[RecommendationMigrator] Error details:",
|
|
138
|
-
|
|
139
|
+
s instanceof Error ? s.message : String(s)
|
|
139
140
|
), null;
|
|
140
141
|
}
|
|
141
142
|
}
|
|
@@ -154,14 +155,14 @@ class $ {
|
|
|
154
155
|
* @param extractedStyles - Styles extracted from old product elements
|
|
155
156
|
* @returns HTML string for product rows with applied styles
|
|
156
157
|
*/
|
|
157
|
-
generateProductRows(e, t,
|
|
158
|
-
const
|
|
159
|
-
for (let
|
|
160
|
-
const
|
|
161
|
-
|
|
158
|
+
generateProductRows(e, t, s) {
|
|
159
|
+
const o = $(), i = [];
|
|
160
|
+
for (let n = 0; n < e; n++) {
|
|
161
|
+
const u = o[n % o.length];
|
|
162
|
+
i.push({ ...u });
|
|
162
163
|
}
|
|
163
|
-
let r = q(
|
|
164
|
-
return r = this.applyExtractedStyles(r,
|
|
164
|
+
let r = q(i, t);
|
|
165
|
+
return r = this.applyExtractedStyles(r, s), r;
|
|
165
166
|
}
|
|
166
167
|
/**
|
|
167
168
|
* Extracts styles from old product elements
|
|
@@ -169,35 +170,35 @@ class $ {
|
|
|
169
170
|
* @returns Object with extracted styles for each element type
|
|
170
171
|
*/
|
|
171
172
|
extractProductStyles(e) {
|
|
172
|
-
const t = {},
|
|
173
|
-
if (!
|
|
173
|
+
const t = {}, s = e.querySelector(".product-card");
|
|
174
|
+
if (!s)
|
|
174
175
|
return console.warn("[RecommendationMigrator] No product card found, using default styles"), t;
|
|
175
|
-
const
|
|
176
|
-
|
|
177
|
-
const
|
|
178
|
-
if (
|
|
179
|
-
const
|
|
180
|
-
t.imageWidth =
|
|
176
|
+
const o = this.extractCardBgColor(s);
|
|
177
|
+
o && (t.cardBgColor = o);
|
|
178
|
+
const i = s.querySelector(".ext-product-image");
|
|
179
|
+
if (i) {
|
|
180
|
+
const l = i.querySelector("img"), g = l == null ? void 0 : l.getAttribute("width"), a = i.getAttribute("style") || "", p = i.getAttribute("align") || "center", b = i.getAttribute("class") || "", m = this.extractStripoClasses(b);
|
|
181
|
+
t.imageWidth = g || "120", t.imageAlign = p, t.imageTdStyle = a, t.imageClasses = m;
|
|
181
182
|
}
|
|
182
|
-
const r =
|
|
183
|
+
const r = s.querySelector(".ext-product-name");
|
|
183
184
|
if (r) {
|
|
184
|
-
const
|
|
185
|
-
t.nameStyle =
|
|
185
|
+
const l = r.querySelector("p"), g = (l == null ? void 0 : l.getAttribute("style")) || "", a = r.getAttribute("align") || "center", p = r.getAttribute("style") || "", b = r.getAttribute("class") || "", m = this.extractStripoClasses(b);
|
|
186
|
+
t.nameStyle = g, t.nameAlign = a, t.nameTdStyle = p, t.nameClasses = m;
|
|
186
187
|
}
|
|
187
|
-
const
|
|
188
|
-
if (
|
|
189
|
-
const
|
|
190
|
-
t.priceStyle =
|
|
188
|
+
const n = s.querySelector(".ext-product-price");
|
|
189
|
+
if (n) {
|
|
190
|
+
const l = n.querySelector("p"), g = (l == null ? void 0 : l.getAttribute("style")) || "", a = n.getAttribute("align") || "center", p = n.getAttribute("style") || "", b = n.getAttribute("class") || "", m = this.extractStripoClasses(b);
|
|
191
|
+
t.priceStyle = g, t.priceAlign = a, t.priceTdStyle = p, t.priceClasses = m;
|
|
191
192
|
}
|
|
192
|
-
const
|
|
193
|
-
if (
|
|
194
|
-
const
|
|
195
|
-
t.oldPriceStyle =
|
|
193
|
+
const u = s.querySelector(".ext-product-original-price");
|
|
194
|
+
if (u) {
|
|
195
|
+
const l = u.querySelector("p"), g = (l == null ? void 0 : l.getAttribute("style")) || "", a = u.getAttribute("align") || "center", p = u.getAttribute("style") || "", b = u.getAttribute("class") || "", m = this.extractStripoClasses(b);
|
|
196
|
+
t.oldPriceStyle = g, t.oldPriceAlign = a, t.oldPriceTdStyle = p, t.oldPriceClasses = m;
|
|
196
197
|
}
|
|
197
|
-
const
|
|
198
|
-
if (
|
|
199
|
-
const
|
|
200
|
-
t.buttonBorderStyle =
|
|
198
|
+
const c = s.querySelector(".ext-product-button");
|
|
199
|
+
if (c) {
|
|
200
|
+
const l = c.querySelector(".es-button-border"), g = c.querySelector("a.es-button"), a = (l == null ? void 0 : l.getAttribute("style")) || "", p = (g == null ? void 0 : g.getAttribute("style")) || "", b = c.getAttribute("align") || "center", m = c.getAttribute("style") || "", f = c.getAttribute("class") || "", C = this.extractStripoClasses(f), y = ((c == null ? void 0 : c.textContent) || "").trim();
|
|
201
|
+
t.buttonBorderStyle = a, t.buttonLinkStyle = p, t.buttonAlign = b, t.buttonTdStyle = m, t.buttonClasses = C, t.buttonText = y;
|
|
201
202
|
}
|
|
202
203
|
return t;
|
|
203
204
|
}
|
|
@@ -210,47 +211,49 @@ class $ {
|
|
|
210
211
|
applyExtractedStyles(e, t) {
|
|
211
212
|
if (!t || Object.keys(t).length === 0)
|
|
212
213
|
return e;
|
|
213
|
-
const
|
|
214
|
-
|
|
214
|
+
const s = this.parser.parseFromString(`<table>${e}</table>`, "text/html");
|
|
215
|
+
t.cardBgColor && s.querySelectorAll(".product-attribute-cell").forEach((r) => {
|
|
215
216
|
r.setAttribute("bgcolor", t.cardBgColor);
|
|
216
|
-
}), (t.imageWidth || t.imageAlign || t.imageTdStyle || t.imageClasses) &&
|
|
217
|
+
}), (t.imageWidth || t.imageAlign || t.imageTdStyle || t.imageClasses) && s.querySelectorAll(".product-image").forEach((r) => {
|
|
217
218
|
if (t.imageAlign && r.setAttribute("align", t.imageAlign), t.imageTdStyle && r.setAttribute("style", t.imageTdStyle), t.imageClasses) {
|
|
218
|
-
const
|
|
219
|
-
r.setAttribute("class",
|
|
219
|
+
const c = `${r.getAttribute("class") || ""} ${t.imageClasses}`.trim();
|
|
220
|
+
r.setAttribute("class", c);
|
|
220
221
|
}
|
|
221
|
-
const
|
|
222
|
-
|
|
223
|
-
}), (t.nameStyle || t.nameAlign || t.nameTdStyle || t.nameClasses) &&
|
|
222
|
+
const n = r.querySelector("img");
|
|
223
|
+
n && t.imageWidth && n.setAttribute("width", t.imageWidth);
|
|
224
|
+
}), (t.nameStyle || t.nameAlign || t.nameTdStyle || t.nameClasses) && s.querySelectorAll(".product-name").forEach((r) => {
|
|
224
225
|
if (t.nameAlign && r.setAttribute("align", t.nameAlign), t.nameTdStyle && r.setAttribute("style", t.nameTdStyle), t.nameClasses) {
|
|
225
|
-
const
|
|
226
|
-
r.setAttribute("class",
|
|
226
|
+
const c = `${r.getAttribute("class") || ""} ${t.nameClasses}`.trim();
|
|
227
|
+
r.setAttribute("class", c);
|
|
227
228
|
}
|
|
228
|
-
const
|
|
229
|
-
|
|
230
|
-
}), (t.priceStyle || t.priceAlign || t.priceTdStyle || t.priceClasses) &&
|
|
229
|
+
const n = r.querySelector("p");
|
|
230
|
+
n && t.nameStyle && n.setAttribute("style", t.nameStyle);
|
|
231
|
+
}), (t.priceStyle || t.priceAlign || t.priceTdStyle || t.priceClasses) && s.querySelectorAll(".product-price").forEach((r) => {
|
|
231
232
|
if (t.priceAlign && r.setAttribute("align", t.priceAlign), t.priceTdStyle && r.setAttribute("style", t.priceTdStyle), t.priceClasses) {
|
|
232
|
-
const
|
|
233
|
-
r.setAttribute("class",
|
|
233
|
+
const c = `${r.getAttribute("class") || ""} ${t.priceClasses}`.trim();
|
|
234
|
+
r.setAttribute("class", c);
|
|
234
235
|
}
|
|
235
|
-
const
|
|
236
|
-
|
|
237
|
-
}), (t.oldPriceStyle || t.oldPriceAlign || t.oldPriceTdStyle || t.oldPriceClasses) &&
|
|
236
|
+
const n = r.querySelector("p");
|
|
237
|
+
n && t.priceStyle && n.setAttribute("style", t.priceStyle);
|
|
238
|
+
}), (t.oldPriceStyle || t.oldPriceAlign || t.oldPriceTdStyle || t.oldPriceClasses) && s.querySelectorAll(".product-old-price").forEach((r) => {
|
|
238
239
|
if (t.oldPriceAlign && r.setAttribute("align", t.oldPriceAlign), t.oldPriceTdStyle && r.setAttribute("style", t.oldPriceTdStyle), t.oldPriceClasses) {
|
|
239
|
-
const
|
|
240
|
-
r.setAttribute("class",
|
|
240
|
+
const c = `${r.getAttribute("class") || ""} ${t.oldPriceClasses}`.trim();
|
|
241
|
+
r.setAttribute("class", c);
|
|
241
242
|
}
|
|
242
|
-
const
|
|
243
|
-
|
|
244
|
-
}), (t.buttonBorderStyle || t.buttonLinkStyle || t.buttonAlign || t.buttonTdStyle || t.buttonClasses) &&
|
|
243
|
+
const n = r.querySelector("p");
|
|
244
|
+
n && t.oldPriceStyle && n.setAttribute("style", t.oldPriceStyle);
|
|
245
|
+
}), (t.buttonBorderStyle || t.buttonLinkStyle || t.buttonAlign || t.buttonTdStyle || t.buttonClasses) && s.querySelectorAll(".product-button").forEach((r) => {
|
|
245
246
|
if (t.buttonAlign && r.setAttribute("align", t.buttonAlign), t.buttonTdStyle && r.setAttribute("style", t.buttonTdStyle), t.buttonClasses) {
|
|
246
|
-
const
|
|
247
|
-
r.setAttribute("class",
|
|
247
|
+
const l = `${r.getAttribute("class") || ""} ${t.buttonClasses}`.trim();
|
|
248
|
+
r.setAttribute("class", l);
|
|
248
249
|
}
|
|
249
|
-
const
|
|
250
|
-
|
|
251
|
-
const
|
|
252
|
-
|
|
253
|
-
})
|
|
250
|
+
const n = r.querySelector(".es-button-border");
|
|
251
|
+
n && t.buttonBorderStyle && n.setAttribute("style", t.buttonBorderStyle);
|
|
252
|
+
const u = r.querySelector("a.es-button");
|
|
253
|
+
u && (t.buttonLinkStyle && u.setAttribute("style", t.buttonLinkStyle), t.buttonText && (u.textContent = t.buttonText));
|
|
254
|
+
});
|
|
255
|
+
const o = s.querySelector("table");
|
|
256
|
+
return (o == null ? void 0 : o.innerHTML) || e;
|
|
254
257
|
}
|
|
255
258
|
/**
|
|
256
259
|
* Builds title block with proper structure
|
|
@@ -258,10 +261,10 @@ class $ {
|
|
|
258
261
|
buildTitleBlock(e) {
|
|
259
262
|
let t = e.text;
|
|
260
263
|
e.isBold && e.isItalic ? t = `<strong path="1,0"><em path="1,0,0">${t}</em></strong>` : e.isBold ? t = `<strong path="1,0">${t}</strong>` : e.isItalic && (t = `<em path="1,0">${t}</em>`);
|
|
261
|
-
const
|
|
264
|
+
const s = e.align ? ` align="${e.align}"` : "", o = e.styles ? ` style="${e.styles}"` : "";
|
|
262
265
|
return `
|
|
263
|
-
<td class="esd-block-text es-p10t es-p10b es-p20l es-p20r"${
|
|
264
|
-
<p path="1"${
|
|
266
|
+
<td class="esd-block-text es-p10t es-p10b es-p20l es-p20r"${s}>
|
|
267
|
+
<p path="1"${o}>
|
|
265
268
|
${t}
|
|
266
269
|
</p>
|
|
267
270
|
</td>
|
|
@@ -271,9 +274,9 @@ class $ {
|
|
|
271
274
|
* Removes specified style properties from a style string
|
|
272
275
|
*/
|
|
273
276
|
removeStyleProperties(e, t) {
|
|
274
|
-
return e ? t.reduce((
|
|
275
|
-
const r = new RegExp(`${
|
|
276
|
-
return
|
|
277
|
+
return e ? t.reduce((o, i) => {
|
|
278
|
+
const r = new RegExp(`${i}\\s*:\\s*[^;]*;?`, "gi");
|
|
279
|
+
return o.replace(r, "");
|
|
277
280
|
}, e).replace(/;\s*;/g, ";").replace(/^;|;$/g, "").trim() : "";
|
|
278
281
|
}
|
|
279
282
|
/**
|
|
@@ -287,7 +290,7 @@ class $ {
|
|
|
287
290
|
}
|
|
288
291
|
}
|
|
289
292
|
function v(d) {
|
|
290
|
-
return new
|
|
293
|
+
return new B().migrate(d);
|
|
291
294
|
}
|
|
292
295
|
export {
|
|
293
296
|
v as migrateRecommendation
|
|
@@ -1,12 +1,12 @@
|
|
|
1
1
|
var h = Object.defineProperty;
|
|
2
2
|
var x = (l, e, t) => e in l ? h(l, e, { enumerable: !0, configurable: !0, writable: !0, value: t }) : l[e] = t;
|
|
3
|
-
var
|
|
4
|
-
import { MERGE_TAGS as
|
|
5
|
-
import { DATA_ATTRIBUTES as
|
|
3
|
+
var S = (l, e, t) => x(l, typeof e != "symbol" ? e + "" : e, t);
|
|
4
|
+
import { MERGE_TAGS as k, PAGE_TYPES as p } from "../../enums/unsubscribe.js";
|
|
5
|
+
import { DATA_ATTRIBUTES as A } from "../../extensions/Blocks/Unsubscribe/utils/constants.js";
|
|
6
6
|
import { useUnsubscribeStore as T } from "../../stores/unsubscribe.js";
|
|
7
7
|
class C {
|
|
8
8
|
constructor() {
|
|
9
|
-
|
|
9
|
+
S(this, "parser");
|
|
10
10
|
this.parser = new DOMParser();
|
|
11
11
|
}
|
|
12
12
|
async migrate(e) {
|
|
@@ -45,6 +45,7 @@ class C {
|
|
|
45
45
|
return i ? i[0] : "";
|
|
46
46
|
}
|
|
47
47
|
extractUnsubscribeContent(e) {
|
|
48
|
+
var m;
|
|
48
49
|
const t = e.querySelector("p");
|
|
49
50
|
if (!t)
|
|
50
51
|
return {
|
|
@@ -71,7 +72,7 @@ class C {
|
|
|
71
72
|
align: i,
|
|
72
73
|
paragraphStyle: o
|
|
73
74
|
};
|
|
74
|
-
const c = r.textContent
|
|
75
|
+
const c = ((m = r.textContent) == null ? void 0 : m.trim()) || "unsubscribe", g = r.getAttribute("href") || "{{ins-unsubscribe-link}}", u = r.getAttribute("style") || "", n = t.textContent || "", s = n.indexOf(c), b = s >= 0 ? n.substring(0, s).trim() : "You can ", f = s >= 0 ? n.substring(s + c.length).trim() : " from our emails, if you need to.", d = !!t.querySelector("b, strong"), a = !!t.querySelector("i, em");
|
|
75
76
|
return {
|
|
76
77
|
textBefore: b,
|
|
77
78
|
linkText: c,
|
|
@@ -89,13 +90,13 @@ class C {
|
|
|
89
90
|
e.textBefore && n.push(e.textBefore), n.push(u), e.textAfter && n.push(e.textAfter);
|
|
90
91
|
let s = n.join(" ");
|
|
91
92
|
e.isBold && e.isItalic ? s = `<strong path="1,0"><em path="1,0,0">${s}</em></strong>` : e.isBold ? s = `<strong path="1,0">${s}</strong>` : e.isItalic && (s = `<em path="1,0">${s}</em>`);
|
|
92
|
-
const b = e.align ? ` align="${e.align}"` : "", f = r ? ` bgcolor="${r}"` : "", d = e.paragraphStyle ? ` style="${e.paragraphStyle}"` : "", a = i.length > 0 ? ` ${
|
|
93
|
+
const b = e.align ? ` align="${e.align}"` : "", f = r ? ` bgcolor="${r}"` : "", d = e.paragraphStyle ? ` style="${e.paragraphStyle}"` : "", a = i.length > 0 ? ` ${A.PAGE_LIST}="${i.join(",")}"` : "", m = ` ${A.PAGE_TYPE}="${t}"`, y = "esd-block-text unsubscribe-block-v2 esd-block-unsubscribe esd-unsubscribe-block esd-extension-block";
|
|
93
94
|
return `
|
|
94
95
|
<td
|
|
95
96
|
data-migration="true"
|
|
96
97
|
esd-extension-block-id="unsubscribe-block"
|
|
97
|
-
class="${o ? `${
|
|
98
|
-
${b}${f}${
|
|
98
|
+
class="${o ? `${y} ${o}` : y}"
|
|
99
|
+
${b}${f}${m}${a}
|
|
99
100
|
>
|
|
100
101
|
<p path="1"${d}>
|
|
101
102
|
${s}
|
|
@@ -104,10 +105,10 @@ class C {
|
|
|
104
105
|
`;
|
|
105
106
|
}
|
|
106
107
|
getCollectionTypeFromMergeTag(e) {
|
|
107
|
-
return e ===
|
|
108
|
+
return e === k[p.SUBSCRIPTION_PREFERENCE_CENTER] ? p.SUBSCRIPTION_PREFERENCE_CENTER : e === k[p.GLOBAL_UNSUBSCRIBE] ? p.GLOBAL_UNSUBSCRIBE : p.GLOBAL_UNSUBSCRIBE;
|
|
108
109
|
}
|
|
109
110
|
normalizeUnsubscribeHref(e) {
|
|
110
|
-
if (Object.values(
|
|
111
|
+
if (Object.values(k).includes(e))
|
|
111
112
|
return e;
|
|
112
113
|
const i = e.match(/{{ins-(?:global-)?(?:preferences-)?unsubscribe-link}}/);
|
|
113
114
|
return i ? i[0] : e.includes("unsubscribe") || e.includes("unsub") ? (console.warn(
|
|
@@ -1,10 +1,11 @@
|
|
|
1
1
|
import { useTranslations as R } from "../composables/useTranslations.js";
|
|
2
|
-
import { getEnvironmentPrefix as S } from "../utils/environmentUtil.js";
|
|
3
2
|
import { ProductType as s } from "../@types/config/schemas.js";
|
|
4
|
-
|
|
3
|
+
import "../@types/config/defaults.js";
|
|
4
|
+
import { getEnvironmentPrefix as S } from "../utils/environmentUtil.js";
|
|
5
|
+
const B = {
|
|
5
6
|
UNSUBSCRIBE_LINK_TYPE: 1,
|
|
6
7
|
PREFERENCES_LINK_TYPE: 3
|
|
7
|
-
},
|
|
8
|
+
}, i = {
|
|
8
9
|
UNSUBSCRIBE_LINK_REGEX: /{{ins-unsubscribe-link}}/g,
|
|
9
10
|
DATA_OGSB_BUTTON_CSS_REGEX: "\\[data-ogsb\\]\\s*\\.es-button\\.es-button-[0-9]+\\s*\\{(?:[^\\}]*)\\}",
|
|
10
11
|
GLOBAL_UNSUBSCRIBE_LINK_REGEX: /{{ins-global-unsubscribe-link}}/g,
|
|
@@ -12,11 +13,11 @@ const r = {
|
|
|
12
13
|
}, n = S(), C = {
|
|
13
14
|
UNSUBSCRIBE_URL: `https://mail.${n}.com/user/v1/unsub`,
|
|
14
15
|
PREFERENCES_URL: `https://mail.${n}.com/user/v1/prefs`
|
|
15
|
-
},
|
|
16
|
+
}, U = {
|
|
16
17
|
[s.EMAIL]: "email",
|
|
17
18
|
[s.ARCHITECT]: "journey",
|
|
18
19
|
[s.UNSUBSCRIBE_PAGES]: "email"
|
|
19
|
-
},
|
|
20
|
+
}, t = "iid", o = {
|
|
20
21
|
name: "Global Unsubscribe",
|
|
21
22
|
sendGridId: "G"
|
|
22
23
|
}, c = "/email/unsubscribe-pages", E = {
|
|
@@ -25,10 +26,10 @@ const r = {
|
|
|
25
26
|
SUBSCRIPTION_PREFERENCE_CENTER: 3,
|
|
26
27
|
SUBSCRIPTION_PREFERENCE_CONFIRMATION: 4,
|
|
27
28
|
RESUBSCRIBE: 5
|
|
28
|
-
},
|
|
29
|
+
}, u = {
|
|
29
30
|
[E.GLOBAL_UNSUBSCRIBE]: "custom-unsubscribe",
|
|
30
31
|
[E.SUBSCRIPTION_PREFERENCE_CENTER]: "custom-preferences"
|
|
31
|
-
},
|
|
32
|
+
}, T = {
|
|
32
33
|
[E.GLOBAL_UNSUBSCRIBE]: [
|
|
33
34
|
E.GLOBAL_UNSUBSCRIBE,
|
|
34
35
|
E.GLOBAL_UNSUBSCRIBE_CONFIRMATION_PAGE,
|
|
@@ -38,7 +39,7 @@ const r = {
|
|
|
38
39
|
E.SUBSCRIPTION_PREFERENCE_CENTER,
|
|
39
40
|
E.SUBSCRIPTION_PREFERENCE_CONFIRMATION
|
|
40
41
|
]
|
|
41
|
-
},
|
|
42
|
+
}, b = () => {
|
|
42
43
|
const e = R();
|
|
43
44
|
return {
|
|
44
45
|
[E.GLOBAL_UNSUBSCRIBE]: e("unsubscription-preference.type-global-unsubscribe"),
|
|
@@ -47,22 +48,22 @@ const r = {
|
|
|
47
48
|
[E.SUBSCRIPTION_PREFERENCE_CENTER]: e("unsubscription-preference.type-subscription-preferences-center"),
|
|
48
49
|
[E.SUBSCRIPTION_PREFERENCE_CONFIRMATION]: e("unsubscription-preference.type-subscription-preferences-confirmation")
|
|
49
50
|
};
|
|
50
|
-
},
|
|
51
|
+
}, P = {
|
|
51
52
|
default: "{{ins-unsubscribe-link}}",
|
|
52
53
|
[E.GLOBAL_UNSUBSCRIBE]: "{{ins-global-unsubscribe-link}}",
|
|
53
54
|
[E.SUBSCRIPTION_PREFERENCE_CENTER]: "{{ins-preferences-unsubscribe-link}}"
|
|
54
55
|
};
|
|
55
56
|
export {
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
57
|
+
o as DEFAULT_UNSUBSCRIBE_GROUP,
|
|
58
|
+
t as INSIDER_ID,
|
|
59
|
+
i as LINK_REGEXES,
|
|
60
|
+
B as LINK_TYPES,
|
|
61
|
+
P as MERGE_TAGS,
|
|
61
62
|
E as PAGE_TYPES,
|
|
62
|
-
|
|
63
|
-
|
|
63
|
+
U as PRODUCT_TYPE_URL_SEGMENTS,
|
|
64
|
+
T as TYPE_COLLECTIONS,
|
|
64
65
|
c as UNSUBSCRIBE_PAGES_LINK,
|
|
65
|
-
|
|
66
|
+
u as UNSUBSCRIBE_SYNC_MODULE_TYPES,
|
|
66
67
|
C as URLS,
|
|
67
|
-
|
|
68
|
+
b as getTypeTranslations
|
|
68
69
|
};
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { BlockId as g } from "../../../enums/block.js";
|
|
2
|
-
import { useOnboardingStore as
|
|
3
|
-
import { getMigrationBannerHtml as
|
|
2
|
+
import { useOnboardingStore as p } from "../../../stores/onboarding.js";
|
|
3
|
+
import { getMigrationBannerHtml as f } from "../../../utils/migrationBannerHtml.js";
|
|
4
4
|
import { Block as u, BlockCompositionType as I, ModificationDescription as o } from "../../../node_modules/@stripoinc/ui-editor-extensions/dist/esm/index.js";
|
|
5
5
|
import { SETTINGS_ENUMS as a, DefaultConfigValues as i } from "./enums/settingsEnums.js";
|
|
6
6
|
import { getDefaultTemplate as C } from "./template.js";
|
|
@@ -23,7 +23,7 @@ class E extends u {
|
|
|
23
23
|
return this.api.translate("Items lets you display personalized products based on user behavior.");
|
|
24
24
|
}
|
|
25
25
|
getSettingsPanelTitleHtml() {
|
|
26
|
-
return
|
|
26
|
+
return f(
|
|
27
27
|
c,
|
|
28
28
|
this.api.translate("Items"),
|
|
29
29
|
this.api.translate("This block is switched from the Old Version to the New Version. We recommend you check the Items block and test your message to ensure it works properly.")
|
|
@@ -45,15 +45,15 @@ class E extends u {
|
|
|
45
45
|
onCreated(n) {
|
|
46
46
|
const l = this.api.getDocumentModifier(), r = this.api.getDocumentRootCssNode();
|
|
47
47
|
r.querySelector('[product-attr="imageSrc"] img') || l.modifyCss(r).appendRule('[product-attr="imageSrc"] img {object-fit: contain;}');
|
|
48
|
-
const
|
|
49
|
-
if (!
|
|
48
|
+
const e = y(n);
|
|
49
|
+
if (!e)
|
|
50
50
|
return;
|
|
51
|
-
const s =
|
|
52
|
-
if (
|
|
53
|
-
m ?
|
|
51
|
+
const s = e.getNodeConfig(), m = s && Object.keys(s).length > 0, t = b(n);
|
|
52
|
+
if (t != null && t.initialized)
|
|
53
|
+
m ? t.blockInstanceId || this.api.getDocumentModifier().modifyHtml(e).setNodeConfig({ ...t, blockInstanceId: String(Date.now()) }).apply(new o("Assign block instance ID to block")) : this.api.getDocumentModifier().modifyHtml(e).setNodeConfig(t).apply(new o("Migrate legacy config to nodeConfig"));
|
|
54
54
|
else {
|
|
55
55
|
const d = h();
|
|
56
|
-
this.api.getDocumentModifier().modifyHtml(
|
|
56
|
+
this.api.getDocumentModifier().modifyHtml(e).setNodeConfig(d).apply(new o("Initialize Items block with default configuration")), p().startOnboarding("itemsOnboarding");
|
|
57
57
|
}
|
|
58
58
|
}
|
|
59
59
|
}
|
|
@@ -1,31 +1,31 @@
|
|
|
1
|
-
import { CommonControl as
|
|
2
|
-
import { ItemsBlockControlId as
|
|
3
|
-
import { getItemsBlockConfig as
|
|
4
|
-
const
|
|
1
|
+
import { CommonControl as r } from "../../../common-control.js";
|
|
2
|
+
import { ItemsBlockControlId as i } from "../../enums/controlEnums.js";
|
|
3
|
+
import { getItemsBlockConfig as o } from "../../utils/nodeConfigUtils.js";
|
|
4
|
+
const s = i.BUTTON_LINK, n = {
|
|
5
5
|
LINK: "link"
|
|
6
6
|
};
|
|
7
|
-
class
|
|
7
|
+
class m extends r {
|
|
8
8
|
getId() {
|
|
9
|
-
return
|
|
9
|
+
return s;
|
|
10
10
|
}
|
|
11
11
|
getTemplate() {
|
|
12
12
|
return `
|
|
13
|
-
<div class="container ${
|
|
13
|
+
<div class="container ${s}">
|
|
14
14
|
${this._getLink()}
|
|
15
15
|
</div>
|
|
16
16
|
`;
|
|
17
17
|
}
|
|
18
18
|
onRender() {
|
|
19
|
-
const t =
|
|
19
|
+
const t = o(this.currentNode);
|
|
20
20
|
this.api.updateValues({
|
|
21
|
-
[
|
|
21
|
+
[n.LINK]: (t == null ? void 0 : t.buttonLink) ?? ""
|
|
22
22
|
});
|
|
23
23
|
}
|
|
24
24
|
onTemplateNodeUpdated(t) {
|
|
25
25
|
super.onTemplateNodeUpdated(t), this.handleBlockInstanceChange(() => {
|
|
26
|
-
const
|
|
26
|
+
const e = o(this.currentNode);
|
|
27
27
|
this.api.updateValues({
|
|
28
|
-
[
|
|
28
|
+
[n.LINK]: (e == null ? void 0 : e.buttonLink) ?? ""
|
|
29
29
|
});
|
|
30
30
|
});
|
|
31
31
|
}
|
|
@@ -34,7 +34,7 @@ class c extends s {
|
|
|
34
34
|
${this._GuOneColumn([
|
|
35
35
|
this._GuLabel({ text: "Link" }),
|
|
36
36
|
this._GuTextInput({
|
|
37
|
-
name:
|
|
37
|
+
name: n.LINK,
|
|
38
38
|
placeholder: "Enter Link",
|
|
39
39
|
className: "es-100",
|
|
40
40
|
disabled: !0
|
|
@@ -44,6 +44,6 @@ class c extends s {
|
|
|
44
44
|
}
|
|
45
45
|
}
|
|
46
46
|
export {
|
|
47
|
-
|
|
48
|
-
|
|
47
|
+
m as ButtonLinkControl,
|
|
48
|
+
s as CONTROL_BLOCK_ID
|
|
49
49
|
};
|