@useinsider/guido 1.0.3-beta.1cd6abc → 1.0.3-beta.1d07a49
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 +22 -7
- package/dist/components/Guido.vue.js +11 -9
- package/dist/components/Guido.vue2.js +76 -70
- package/dist/components/organisms/header/LeftSlot.vue.js +1 -1
- package/dist/components/organisms/header/LeftSlot.vue2.js +15 -15
- package/dist/components/organisms/header/RightSlot.vue.js +10 -10
- package/dist/components/organisms/header/RightSlot.vue2.js +18 -18
- package/dist/components/organisms/onboarding/ItemsOnboarding.vue.js +21 -0
- package/dist/components/organisms/onboarding/ItemsOnboarding.vue2.js +99 -0
- package/dist/components/organisms/onboarding/NewVersionPopup.vue.js +9 -9
- package/dist/components/organisms/onboarding/NewVersionPopup.vue2.js +30 -17
- package/dist/components/organisms/onboarding/OnboardingWrapper.vue.js +12 -10
- package/dist/components/organisms/onboarding/OnboardingWrapper.vue2.js +23 -20
- package/dist/composables/useActionsApi.js +33 -24
- package/dist/composables/useBlocksConfig.js +21 -31
- package/dist/composables/useGuidoActions.js +19 -9
- package/dist/composables/useHtmlCompiler.js +15 -13
- package/dist/composables/useHtmlValidator.js +36 -35
- package/dist/composables/usePartner.js +10 -11
- package/dist/composables/useSave.js +11 -10
- package/dist/composables/useStripo.js +63 -55
- package/dist/composables/useTimerClone.js +75 -0
- package/dist/config/compiler/itemsCompilerRules.js +14 -0
- package/dist/config/compiler/unsubscribeCompilerRules.js +33 -28
- package/dist/config/migrator/index.js +7 -6
- package/dist/config/migrator/recommendationMigrator.js +293 -0
- package/dist/enums/date.js +6 -0
- package/dist/enums/defaults.js +6 -4
- package/dist/enums/extensions/recommendationBlock.js +2 -2
- package/dist/enums/onboarding.js +7 -2
- package/dist/enums/unsubscribe.js +27 -25
- package/dist/extensions/Blocks/Checkbox/block.js +5 -2
- package/dist/extensions/Blocks/Checkbox/control.js +15 -14
- package/dist/extensions/Blocks/Checkbox/extension.js +2 -2
- package/dist/extensions/Blocks/Checkbox/template.js +14 -9
- package/dist/extensions/Blocks/CouponBlock/extension.js +2 -2
- package/dist/extensions/Blocks/Items/block.js +67 -0
- package/dist/extensions/Blocks/Items/controls/button/link.js +68 -0
- package/dist/extensions/Blocks/Items/controls/cardComposition.js +193 -0
- package/dist/extensions/Blocks/Items/controls/image/link.js +68 -0
- package/dist/extensions/Blocks/Items/controls/index.js +217 -0
- package/dist/extensions/Blocks/Items/controls/name/trimming.js +70 -0
- package/dist/extensions/Blocks/Items/controls/price/currencyLocation.js +107 -0
- package/dist/extensions/Blocks/Items/controls/price/currencySymbol.js +123 -0
- package/dist/extensions/Blocks/Items/controls/price/formattedPrice.js +76 -0
- package/dist/extensions/Blocks/Items/controls/price/hideDiscount.js +61 -0
- package/dist/extensions/Blocks/Items/controls/settingsControl.js +312 -0
- package/dist/extensions/Blocks/Items/enums/controlEnums.js +5 -0
- package/dist/extensions/Blocks/Items/enums/productEnums.js +273 -0
- package/dist/extensions/Blocks/Items/enums/settingsEnums.js +76 -0
- package/dist/extensions/Blocks/Items/extension.js +19 -0
- package/dist/extensions/Blocks/Items/iconsRegistry.js +32 -0
- package/dist/extensions/Blocks/Items/items.css.js +23 -0
- package/dist/extensions/Blocks/Items/layouts/horizontal.html.js +62 -0
- package/dist/extensions/Blocks/Items/layouts/vertical.html.js +60 -0
- package/dist/extensions/Blocks/Items/settingsPanel.js +131 -0
- package/dist/extensions/Blocks/Items/store/items-block.js +71 -0
- package/dist/extensions/Blocks/Items/template.js +189 -0
- package/dist/extensions/Blocks/Items/utils/configBlockUtils.js +17 -0
- package/dist/extensions/Blocks/Items/utils/syncAttributeFromConfigBlock.js +28 -0
- package/dist/extensions/Blocks/Items/utils/syncAttributesFromConfigBlock.js +67 -0
- package/dist/extensions/Blocks/Items/utils/updateAttributes.js +44 -0
- package/dist/extensions/Blocks/RadioButton/block.js +5 -2
- package/dist/extensions/Blocks/RadioButton/control.js +18 -17
- package/dist/extensions/Blocks/RadioButton/template.js +18 -9
- package/dist/extensions/Blocks/Recommendation/block.js +6 -3
- package/dist/extensions/Blocks/Recommendation/cardCompositionControl.js +103 -0
- package/dist/extensions/Blocks/Recommendation/constants.js +5 -0
- package/dist/extensions/Blocks/Recommendation/control.js +69 -40
- package/dist/extensions/Blocks/Recommendation/controls/button/align.js +13 -0
- package/dist/extensions/Blocks/Recommendation/controls/button/border.js +13 -0
- package/dist/extensions/Blocks/Recommendation/controls/button/borderRadius.js +13 -0
- package/dist/extensions/Blocks/Recommendation/controls/button/color.js +13 -0
- package/dist/extensions/Blocks/Recommendation/controls/button/fitToContent.js +13 -0
- package/dist/extensions/Blocks/Recommendation/controls/button/fontFamily.js +13 -0
- package/dist/extensions/Blocks/Recommendation/controls/button/margins.js +13 -0
- package/dist/extensions/Blocks/Recommendation/controls/button/paddings.js +13 -0
- package/dist/extensions/Blocks/Recommendation/controls/button/text.js +13 -0
- package/dist/extensions/Blocks/Recommendation/controls/button/textSize.js +13 -0
- package/dist/extensions/Blocks/Recommendation/controls/button/textStyleAndFontColor.js +13 -0
- package/dist/extensions/Blocks/Recommendation/controls/image/margins.js +13 -0
- package/dist/extensions/Blocks/Recommendation/controls/image/size.js +13 -0
- package/dist/extensions/Blocks/Recommendation/controls/name/align.js +13 -0
- package/dist/extensions/Blocks/Recommendation/controls/name/background.js +13 -0
- package/dist/extensions/Blocks/Recommendation/controls/name/color.js +13 -0
- package/dist/extensions/Blocks/Recommendation/controls/name/fontFamily.js +13 -0
- package/dist/extensions/Blocks/Recommendation/controls/name/paddings.js +13 -0
- package/dist/extensions/Blocks/Recommendation/controls/name/size.js +13 -0
- package/dist/extensions/Blocks/Recommendation/controls/name/style.js +13 -0
- package/dist/extensions/Blocks/Recommendation/controls/oldPrice/align.js +13 -0
- package/dist/extensions/Blocks/Recommendation/controls/oldPrice/background.js +13 -0
- package/dist/extensions/Blocks/Recommendation/controls/oldPrice/color.js +13 -0
- package/dist/extensions/Blocks/Recommendation/controls/oldPrice/fontFamily.js +13 -0
- package/dist/extensions/Blocks/Recommendation/controls/oldPrice/paddings.js +13 -0
- package/dist/extensions/Blocks/Recommendation/controls/oldPrice/size.js +13 -0
- package/dist/extensions/Blocks/Recommendation/controls/oldPrice/style.js +13 -0
- package/dist/extensions/Blocks/Recommendation/controls/price/align.js +13 -0
- package/dist/extensions/Blocks/Recommendation/controls/price/background.js +13 -0
- package/dist/extensions/Blocks/Recommendation/controls/price/color.js +13 -0
- package/dist/extensions/Blocks/Recommendation/controls/price/fontFamily.js +13 -0
- package/dist/extensions/Blocks/Recommendation/controls/price/paddings.js +13 -0
- package/dist/extensions/Blocks/Recommendation/controls/price/size.js +13 -0
- package/dist/extensions/Blocks/Recommendation/controls/price/style.js +13 -0
- package/dist/extensions/Blocks/Recommendation/extension.js +42 -7
- package/dist/extensions/Blocks/Recommendation/iconsRegistry.js +43 -43
- package/dist/extensions/Blocks/Recommendation/settingsPanel.js +107 -22
- package/dist/extensions/Blocks/Recommendation/store/recommendation.js +1 -1
- package/dist/extensions/Blocks/Recommendation/templates/blockTemplate.js +160 -0
- package/dist/extensions/Blocks/Recommendation/templates/migrationTemplate.js +152 -0
- package/dist/extensions/Blocks/Recommendation/templates/templateUtils.js +180 -0
- package/dist/extensions/Blocks/Unsubscribe/block.js +27 -27
- package/dist/extensions/Blocks/common-control.js +201 -55
- package/dist/extensions/Blocks/controlFactories.js +223 -0
- package/dist/extensions/DynamicContent/dynamic-content-modal.js +25 -19
- package/dist/extensions/DynamicContent/dynamic-content.js +128 -33
- package/dist/guido.css +1 -1
- package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/esm/index.js +353 -101
- 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/_WeakMap.js +6 -0
- package/dist/node_modules/lodash-es/_arrayFilter.js +10 -0
- package/dist/node_modules/lodash-es/_arrayLikeKeys.js +13 -12
- 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/_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/_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/_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/_baseToString.js +18 -0
- package/dist/node_modules/lodash-es/_baseTrim.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/_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/_hasPath.js +19 -0
- package/dist/node_modules/lodash-es/_isFlattenable.js +10 -0
- package/dist/node_modules/lodash-es/_isKey.js +12 -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/_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/_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/isSymbol.js +9 -0
- package/dist/node_modules/lodash-es/keys.js +9 -0
- package/dist/node_modules/lodash-es/keysIn.js +3 -3
- 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/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/package.json.js +1 -1
- package/dist/services/recommendationApi.js +13 -19
- package/dist/services/stripoApi.js +1 -1
- package/dist/src/@types/generic.d.ts +35 -6
- package/dist/src/components/Guido.vue.d.ts +4 -2
- package/dist/src/components/organisms/onboarding/ItemsOnboarding.vue.d.ts +2 -0
- package/dist/src/components/organisms/onboarding/NewVersionPopup.vue.d.ts +3 -1
- package/dist/src/components/organisms/onboarding/OnboardingWrapper.vue.d.ts +3 -1
- package/dist/src/composables/useActionsApi.d.ts +1 -0
- package/dist/src/composables/useBlocksConfig.d.ts +2 -2
- package/dist/src/composables/useGuidoActions.d.ts +9 -0
- package/dist/src/composables/usePartner.d.ts +0 -1
- package/dist/src/composables/useTimerClone.d.ts +6 -0
- package/dist/src/config/compiler/itemsCompilerRules.d.ts +2 -0
- package/dist/src/config/migrator/recommendationMigrator.d.ts +1 -0
- package/dist/src/enums/date.d.ts +4 -0
- package/dist/src/enums/defaults.d.ts +1 -1
- package/dist/src/enums/onboarding.d.ts +5 -0
- package/dist/src/extensions/Blocks/Checkbox/block.d.ts +1 -0
- package/dist/src/extensions/Blocks/Checkbox/template.d.ts +1 -1
- package/dist/src/extensions/Blocks/Items/block.d.ts +27 -0
- package/dist/src/extensions/Blocks/Items/controls/button/link.d.ts +14 -0
- package/dist/src/extensions/Blocks/Items/controls/cardComposition.d.ts +33 -0
- package/dist/src/extensions/Blocks/Items/controls/image/link.d.ts +14 -0
- package/dist/src/extensions/Blocks/Items/controls/index.d.ts +501 -0
- package/dist/src/extensions/Blocks/Items/controls/name/trimming.d.ts +14 -0
- package/dist/src/extensions/Blocks/Items/controls/price/currencyLocation.d.ts +19 -0
- package/dist/src/extensions/Blocks/Items/controls/price/currencySymbol.d.ts +21 -0
- package/dist/src/extensions/Blocks/Items/controls/price/formattedPrice.d.ts +14 -0
- package/dist/src/extensions/Blocks/Items/controls/price/hideDiscount.d.ts +13 -0
- package/dist/src/extensions/Blocks/Items/controls/settingsControl.d.ts +48 -0
- package/dist/src/extensions/Blocks/Items/enums/controlEnums.d.ts +61 -0
- package/dist/src/extensions/Blocks/Items/enums/productEnums.d.ts +162 -0
- package/dist/src/extensions/Blocks/Items/enums/settingsEnums.d.ts +49 -0
- package/dist/src/extensions/Blocks/Items/extension.d.ts +2 -0
- package/dist/src/extensions/Blocks/Items/iconsRegistry.d.ts +4 -0
- package/dist/src/extensions/Blocks/Items/settingsPanel.d.ts +4 -0
- package/dist/src/extensions/Blocks/Items/store/items-block.d.ts +41 -0
- package/dist/src/extensions/Blocks/Items/template.d.ts +24 -0
- package/dist/src/extensions/Blocks/Items/utils/configBlockUtils.d.ts +23 -0
- package/dist/src/extensions/Blocks/Items/utils/syncAttributeFromConfigBlock.d.ts +32 -0
- package/dist/src/extensions/Blocks/Items/utils/syncAttributesFromConfigBlock.d.ts +44 -0
- package/dist/src/extensions/Blocks/Items/utils/updateAttributes.d.ts +8 -0
- package/dist/src/extensions/Blocks/RadioButton/block.d.ts +1 -0
- package/dist/src/extensions/Blocks/RadioButton/template.d.ts +1 -1
- package/dist/src/extensions/Blocks/Recommendation/block.d.ts +1 -0
- package/dist/src/extensions/Blocks/Recommendation/cardCompositionControl.d.ts +28 -0
- package/dist/src/extensions/Blocks/Recommendation/constants.d.ts +51 -0
- package/dist/src/extensions/Blocks/Recommendation/control.d.ts +6 -0
- package/dist/src/extensions/Blocks/Recommendation/controls/button/align.d.ts +5 -0
- package/dist/src/extensions/Blocks/Recommendation/controls/button/border.d.ts +5 -0
- package/dist/src/extensions/Blocks/Recommendation/controls/button/borderRadius.d.ts +5 -0
- package/dist/src/extensions/Blocks/Recommendation/controls/button/color.d.ts +5 -0
- package/dist/src/extensions/Blocks/Recommendation/controls/button/fitToContent.d.ts +5 -0
- package/dist/src/extensions/Blocks/Recommendation/controls/button/fontFamily.d.ts +5 -0
- package/dist/src/extensions/Blocks/Recommendation/controls/button/margins.d.ts +5 -0
- package/dist/src/extensions/Blocks/Recommendation/controls/button/paddings.d.ts +5 -0
- package/dist/src/extensions/Blocks/Recommendation/controls/button/text.d.ts +5 -0
- package/dist/src/extensions/Blocks/Recommendation/controls/button/textSize.d.ts +5 -0
- package/dist/src/extensions/Blocks/Recommendation/controls/button/textStyleAndFontColor.d.ts +5 -0
- package/dist/src/extensions/Blocks/Recommendation/controls/image/margins.d.ts +5 -0
- package/dist/src/extensions/Blocks/Recommendation/controls/image/size.d.ts +5 -0
- package/dist/src/extensions/Blocks/Recommendation/controls/name/align.d.ts +5 -0
- package/dist/src/extensions/Blocks/Recommendation/controls/name/background.d.ts +5 -0
- package/dist/src/extensions/Blocks/Recommendation/controls/name/color.d.ts +5 -0
- package/dist/src/extensions/Blocks/Recommendation/controls/name/fontFamily.d.ts +5 -0
- package/dist/src/extensions/Blocks/Recommendation/controls/name/paddings.d.ts +5 -0
- package/dist/src/extensions/Blocks/Recommendation/controls/name/size.d.ts +5 -0
- package/dist/src/extensions/Blocks/Recommendation/controls/name/style.d.ts +5 -0
- package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/align.d.ts +5 -0
- package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/background.d.ts +5 -0
- package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/color.d.ts +5 -0
- package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/fontFamily.d.ts +5 -0
- package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/paddings.d.ts +5 -0
- package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/size.d.ts +5 -0
- package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/style.d.ts +5 -0
- package/dist/src/extensions/Blocks/Recommendation/controls/price/align.d.ts +5 -0
- package/dist/src/extensions/Blocks/Recommendation/controls/price/background.d.ts +5 -0
- package/dist/src/extensions/Blocks/Recommendation/controls/price/color.d.ts +5 -0
- package/dist/src/extensions/Blocks/Recommendation/controls/price/fontFamily.d.ts +5 -0
- package/dist/src/extensions/Blocks/Recommendation/controls/price/paddings.d.ts +5 -0
- package/dist/src/extensions/Blocks/Recommendation/controls/price/size.d.ts +5 -0
- package/dist/src/extensions/Blocks/Recommendation/controls/price/style.d.ts +5 -0
- package/dist/src/extensions/Blocks/Recommendation/store/recommendation.d.ts +1 -1
- package/dist/src/extensions/Blocks/Recommendation/templates/blockTemplate.d.ts +16 -0
- package/dist/src/extensions/Blocks/Recommendation/templates/migrationTemplate.d.ts +16 -0
- package/dist/src/extensions/Blocks/Recommendation/templates/templateUtils.d.ts +44 -0
- package/dist/src/extensions/Blocks/common-control.d.ts +65 -7
- package/dist/src/extensions/Blocks/controlFactories.d.ts +312 -0
- package/dist/src/extensions/DynamicContent/dynamic-content-modal.d.ts +9 -2
- package/dist/src/extensions/DynamicContent/dynamic-content.d.ts +52 -2
- package/dist/src/stores/config.d.ts +6 -2
- package/dist/src/stores/dynamic-content.d.ts +3 -3
- package/dist/src/stores/editor.d.ts +1 -1
- package/dist/src/stores/onboarding.d.ts +335 -1
- package/dist/src/stores/preview.d.ts +1 -1
- package/dist/src/stores/recommendation.d.ts +1 -1
- package/dist/src/stores/save-as-template.d.ts +1 -1
- package/dist/src/stores/toaster.d.ts +1 -1
- package/dist/src/stores/unsubscribe.d.ts +1 -1
- package/dist/src/stores/version-history.d.ts +1 -1
- package/dist/src/utils/dateUtil.d.ts +21 -0
- package/dist/src/utils/environmentUtil.d.ts +5 -0
- package/dist/src/utils/genericUtil.d.ts +1 -0
- package/dist/src/utils/pairProductVariables.d.ts +7 -0
- package/dist/static/styles/components/narrow-panel.css.js +10 -0
- package/dist/static/styles/customEditorStyle.css.js +5 -0
- package/dist/stores/config.js +5 -5
- package/dist/stores/dynamic-content.js +2 -2
- package/dist/stores/editor.js +1 -1
- package/dist/stores/onboarding.js +44 -36
- package/dist/stores/preview.js +1 -1
- package/dist/stores/recommendation.js +3 -3
- package/dist/stores/save-as-template.js +2 -2
- package/dist/stores/toaster.js +1 -1
- package/dist/stores/unsubscribe.js +1 -1
- package/dist/stores/version-history.js +4 -4
- package/dist/utils/dateUtil.js +24 -3
- package/dist/utils/environmentUtil.js +4 -0
- package/dist/utils/genericUtil.js +18 -8
- package/dist/utils/pairProductVariables.js +136 -0
- package/package.json +4 -4
- package/dist/extensions/Blocks/Recommendation/template.js +0 -200
- package/dist/src/extensions/Blocks/Recommendation/template.d.ts +0 -6
|
@@ -0,0 +1,160 @@
|
|
|
1
|
+
import { BlockType as t, BlockAttr as n } from "../../../../node_modules/@stripoinc/ui-editor-extensions/dist/esm/index.js";
|
|
2
|
+
import { RecommendationBlockId as o } from "../constants.js";
|
|
3
|
+
import { generateTemplate as l, prepareProductRows as s, spacer as d, DEFAULTS as p, getDefaultProducts as i } from "./templateUtils.js";
|
|
4
|
+
import { DEFAULT_CARD_COMPOSITION as $ } from "./templateUtils.js";
|
|
5
|
+
const g = `
|
|
6
|
+
<td align="left" class="ins-recommendation-v3-block-v2 esd-block-recommendation-v3-block es-p20">
|
|
7
|
+
<table width="100%" cellpadding="0" cellspacing="0" border="0">
|
|
8
|
+
<tr>
|
|
9
|
+
<td align="center">
|
|
10
|
+
<table
|
|
11
|
+
class="container"
|
|
12
|
+
width="100%"
|
|
13
|
+
cellpadding="0"
|
|
14
|
+
cellspacing="0"
|
|
15
|
+
border="0">
|
|
16
|
+
<tbody>
|
|
17
|
+
<tr>
|
|
18
|
+
<td>
|
|
19
|
+
<table
|
|
20
|
+
width="100%"
|
|
21
|
+
cellpadding="0"
|
|
22
|
+
cellspacing="0"
|
|
23
|
+
border="0">
|
|
24
|
+
<tbody>
|
|
25
|
+
<${t.BLOCK_TEXT}
|
|
26
|
+
class="es-p10t es-p10b es-p20l es-p20r"
|
|
27
|
+
align="center">
|
|
28
|
+
<p path="1" style="font-size: 28px; color: #333333;">
|
|
29
|
+
<strong path="1,0">{-{-TITLE-}-}</strong>
|
|
30
|
+
</p>
|
|
31
|
+
</${t.BLOCK_TEXT}>
|
|
32
|
+
</tbody>
|
|
33
|
+
</table>
|
|
34
|
+
</td>
|
|
35
|
+
</tr>
|
|
36
|
+
${d}
|
|
37
|
+
<tr>
|
|
38
|
+
<td>
|
|
39
|
+
<table
|
|
40
|
+
class="ins-recommendation-product-container"
|
|
41
|
+
width="100%"
|
|
42
|
+
cellpadding="0"
|
|
43
|
+
cellspacing="0"
|
|
44
|
+
border="0"
|
|
45
|
+
>
|
|
46
|
+
{-{-PRODUCT_ROWS-}-}
|
|
47
|
+
</table>
|
|
48
|
+
</td>
|
|
49
|
+
</tr>
|
|
50
|
+
</tbody>
|
|
51
|
+
</table>
|
|
52
|
+
</td>
|
|
53
|
+
</tr>
|
|
54
|
+
</table>
|
|
55
|
+
</td>
|
|
56
|
+
`, a = {
|
|
57
|
+
productImage: (e) => `
|
|
58
|
+
<${t.BLOCK_IMAGE}
|
|
59
|
+
${n.BLOCK_IMAGE.src}="${e.image_url}"
|
|
60
|
+
${n.BLOCK_IMAGE.alt}="${e.name}"
|
|
61
|
+
${n.BLOCK_IMAGE.href}="#"
|
|
62
|
+
class="product-image"
|
|
63
|
+
align="center"
|
|
64
|
+
style="max-width: 100%; height: auto; margin: 0 auto;"
|
|
65
|
+
esd-extension-block-id="${o.IMAGE}">
|
|
66
|
+
</${t.BLOCK_IMAGE}>
|
|
67
|
+
`,
|
|
68
|
+
productName: (e) => `
|
|
69
|
+
<${t.BLOCK_TEXT}
|
|
70
|
+
class="product-name"
|
|
71
|
+
align="center"
|
|
72
|
+
style="font-size: 16px; color: #333333; font-weight: 600; padding: 15px 10px; text-align: center;"
|
|
73
|
+
esd-extension-block-id="${o.NAME}">
|
|
74
|
+
<p path="1" contenteditable="false">
|
|
75
|
+
<strong path="1,0">${e.name}</strong>
|
|
76
|
+
</p>
|
|
77
|
+
</${t.BLOCK_TEXT}>
|
|
78
|
+
`,
|
|
79
|
+
productPrice: () => `
|
|
80
|
+
<${t.BLOCK_TEXT}
|
|
81
|
+
class="product-price"
|
|
82
|
+
align="center"
|
|
83
|
+
style="padding: 10px; text-align: center;"
|
|
84
|
+
esd-extension-block-id="${o.PRICE}">
|
|
85
|
+
<p path="1" contenteditable="false">
|
|
86
|
+
<span class="current-price" style="font-size: 16px; color: #333333; font-weight: bold;">
|
|
87
|
+
<strong path="1,0">18,00 TRY</strong>
|
|
88
|
+
</span>
|
|
89
|
+
</p>
|
|
90
|
+
</${t.BLOCK_TEXT}>
|
|
91
|
+
`,
|
|
92
|
+
productOldPrice: () => `
|
|
93
|
+
<${t.BLOCK_TEXT}
|
|
94
|
+
class="product-old-price"
|
|
95
|
+
align="center"
|
|
96
|
+
style="padding: 10px; text-align: center;"
|
|
97
|
+
esd-extension-block-id="${o.OLD_PRICE}">
|
|
98
|
+
<p path="1" contenteditable="false">
|
|
99
|
+
<span class="old-price" style="font-size: 14px; color: #999999; text-decoration: line-through;">
|
|
100
|
+
<s path="1,0">20,00 TRY</s>
|
|
101
|
+
</span>
|
|
102
|
+
</p>
|
|
103
|
+
</${t.BLOCK_TEXT}>
|
|
104
|
+
`,
|
|
105
|
+
productButton: () => `
|
|
106
|
+
<${t.BLOCK_BUTTON}
|
|
107
|
+
${n.BLOCK_BUTTON.href}="#"
|
|
108
|
+
class="product-button"
|
|
109
|
+
align="center"
|
|
110
|
+
style="padding: 15px 10px 20px 10px; text-align: center;"
|
|
111
|
+
esd-extension-block-id="${o.BUTTON}">
|
|
112
|
+
<span class="es-button-border">
|
|
113
|
+
<a
|
|
114
|
+
href="#"
|
|
115
|
+
class="es-button buy-button"
|
|
116
|
+
target="_blank"
|
|
117
|
+
style="
|
|
118
|
+
display: inline-block;
|
|
119
|
+
width: 90%;
|
|
120
|
+
max-width: 150px;
|
|
121
|
+
padding: 12px 20px;
|
|
122
|
+
background-color: #ffffff;
|
|
123
|
+
color: #333333;
|
|
124
|
+
text-decoration: none;
|
|
125
|
+
border: 2px solid #cccccc;
|
|
126
|
+
font-size: 16px;
|
|
127
|
+
box-sizing: border-box;
|
|
128
|
+
">
|
|
129
|
+
Buy
|
|
130
|
+
</a>
|
|
131
|
+
</span>
|
|
132
|
+
</${t.BLOCK_BUTTON}>
|
|
133
|
+
`
|
|
134
|
+
};
|
|
135
|
+
function x() {
|
|
136
|
+
const e = i();
|
|
137
|
+
return l(
|
|
138
|
+
g,
|
|
139
|
+
e,
|
|
140
|
+
3,
|
|
141
|
+
a,
|
|
142
|
+
p.TITLE
|
|
143
|
+
);
|
|
144
|
+
}
|
|
145
|
+
function f(e, r, c) {
|
|
146
|
+
return s(
|
|
147
|
+
e,
|
|
148
|
+
r,
|
|
149
|
+
a,
|
|
150
|
+
c
|
|
151
|
+
);
|
|
152
|
+
}
|
|
153
|
+
export {
|
|
154
|
+
p as DEFAULTS,
|
|
155
|
+
$ as DEFAULT_CARD_COMPOSITION,
|
|
156
|
+
g as default,
|
|
157
|
+
i as getDefaultProducts,
|
|
158
|
+
x as getDefaultTemplate,
|
|
159
|
+
f as prepareProductRows
|
|
160
|
+
};
|
|
@@ -0,0 +1,152 @@
|
|
|
1
|
+
import { prepareProductRows as n } from "./templateUtils.js";
|
|
2
|
+
import { DEFAULTS as i, getDefaultProducts as p } from "./templateUtils.js";
|
|
3
|
+
const a = `
|
|
4
|
+
<td
|
|
5
|
+
align="left"
|
|
6
|
+
esd-extension-block-id="recommendation-block"
|
|
7
|
+
esd-handler-name="esd-extension-RecommendationBlock"
|
|
8
|
+
class="ins-recommendation-v3-block-v2 esd-block-recommendation-v3-block esd-extension-block es-p20"
|
|
9
|
+
>
|
|
10
|
+
<table width="100%" cellpadding="0" cellspacing="0" border="0">
|
|
11
|
+
<tr>
|
|
12
|
+
<td align="center">
|
|
13
|
+
<table
|
|
14
|
+
class="container"
|
|
15
|
+
width="100%"
|
|
16
|
+
cellpadding="0"
|
|
17
|
+
cellspacing="0"
|
|
18
|
+
border="0">
|
|
19
|
+
<tbody>
|
|
20
|
+
<tr>
|
|
21
|
+
<td>
|
|
22
|
+
<table
|
|
23
|
+
width="100%"
|
|
24
|
+
cellpadding="0"
|
|
25
|
+
cellspacing="0"
|
|
26
|
+
border="0">
|
|
27
|
+
<tbody>
|
|
28
|
+
<tr>
|
|
29
|
+
{-{-TITLE-}-}
|
|
30
|
+
</tr>
|
|
31
|
+
</tbody>
|
|
32
|
+
</table>
|
|
33
|
+
</td>
|
|
34
|
+
</tr>
|
|
35
|
+
<tr>
|
|
36
|
+
<td class="spacer" style="height: 20px;"></td>
|
|
37
|
+
</tr>
|
|
38
|
+
<tr>
|
|
39
|
+
<td>
|
|
40
|
+
<table
|
|
41
|
+
class="ins-recommendation-product-container"
|
|
42
|
+
width="100%"
|
|
43
|
+
cellpadding="0"
|
|
44
|
+
cellspacing="0"
|
|
45
|
+
border="0"
|
|
46
|
+
>
|
|
47
|
+
{-{-PRODUCT_ROWS-}-}
|
|
48
|
+
</table>
|
|
49
|
+
</td>
|
|
50
|
+
</tr>
|
|
51
|
+
</tbody>
|
|
52
|
+
</table>
|
|
53
|
+
</td>
|
|
54
|
+
</tr>
|
|
55
|
+
</table>
|
|
56
|
+
</td>
|
|
57
|
+
`, l = {
|
|
58
|
+
productImage: (t) => `
|
|
59
|
+
<tr>
|
|
60
|
+
<td
|
|
61
|
+
class="esd-block-image product-image"
|
|
62
|
+
esd-extension-block-id="recommendation-block-image"
|
|
63
|
+
align="center"
|
|
64
|
+
style="font-size: 0px;">
|
|
65
|
+
<a target="_blank" href="${t.url}">
|
|
66
|
+
<img
|
|
67
|
+
src="${t.image_url}"
|
|
68
|
+
alt="${t.name}"
|
|
69
|
+
width="120"
|
|
70
|
+
style="display: block; max-width: 100%; height: auto;"
|
|
71
|
+
class="adapt-img">
|
|
72
|
+
</a>
|
|
73
|
+
</td>
|
|
74
|
+
</tr>
|
|
75
|
+
`,
|
|
76
|
+
productName: (t) => `
|
|
77
|
+
<tr>
|
|
78
|
+
<td
|
|
79
|
+
class="esd-block-text product-name"
|
|
80
|
+
esd-extension-block-id="recommendation-block-name"
|
|
81
|
+
align="center">
|
|
82
|
+
<p
|
|
83
|
+
path="1"
|
|
84
|
+
contenteditable="false"
|
|
85
|
+
style="font-size: 16px; color: #333333; font-weight: 600; text-align: center;">
|
|
86
|
+
<strong path="1,0">${t.name}</strong>
|
|
87
|
+
</p>
|
|
88
|
+
</td>
|
|
89
|
+
</tr>
|
|
90
|
+
`,
|
|
91
|
+
productPrice: () => `
|
|
92
|
+
<tr>
|
|
93
|
+
<td
|
|
94
|
+
class="esd-block-text product-price"
|
|
95
|
+
esd-extension-block-id="recommendation-block-price"
|
|
96
|
+
align="center">
|
|
97
|
+
<p
|
|
98
|
+
path="1"
|
|
99
|
+
contenteditable="false"
|
|
100
|
+
style="font-size: 16px; color: #333333; font-weight: bold; text-align: center;">
|
|
101
|
+
<strong path="1,0">18,00 TRY</strong>
|
|
102
|
+
</p>
|
|
103
|
+
</td>
|
|
104
|
+
</tr>
|
|
105
|
+
`,
|
|
106
|
+
productOldPrice: () => `
|
|
107
|
+
<tr>
|
|
108
|
+
<td
|
|
109
|
+
class="esd-block-text product-old-price"
|
|
110
|
+
esd-extension-block-id="recommendation-block-old-price"
|
|
111
|
+
align="center">
|
|
112
|
+
<p
|
|
113
|
+
path="1"
|
|
114
|
+
contenteditable="false"
|
|
115
|
+
style="font-size: 14px; color: #999999; text-decoration: line-through; text-align: center;">
|
|
116
|
+
<s path="1,0">20,00 TRY</s>
|
|
117
|
+
</p>
|
|
118
|
+
</td>
|
|
119
|
+
</tr>
|
|
120
|
+
`,
|
|
121
|
+
productButton: (t) => `
|
|
122
|
+
<tr>
|
|
123
|
+
<td
|
|
124
|
+
class="esd-block-button product-button"
|
|
125
|
+
esd-extension-block-id="recommendation-block-button"
|
|
126
|
+
align="center">
|
|
127
|
+
<span class="es-button-border" style="display: block;">
|
|
128
|
+
<a
|
|
129
|
+
href="${t.url}"
|
|
130
|
+
target="_blank"
|
|
131
|
+
class="es-button">
|
|
132
|
+
{-{-PRODUCT_BUTTON_TEXT-}-}
|
|
133
|
+
</a>
|
|
134
|
+
</span>
|
|
135
|
+
</td>
|
|
136
|
+
</tr>
|
|
137
|
+
`
|
|
138
|
+
};
|
|
139
|
+
function d(t, e, o) {
|
|
140
|
+
return n(
|
|
141
|
+
t,
|
|
142
|
+
e,
|
|
143
|
+
l,
|
|
144
|
+
o
|
|
145
|
+
);
|
|
146
|
+
}
|
|
147
|
+
export {
|
|
148
|
+
i as DEFAULTS,
|
|
149
|
+
a as default,
|
|
150
|
+
p as getDefaultProducts,
|
|
151
|
+
d as prepareProductRows
|
|
152
|
+
};
|
|
@@ -0,0 +1,180 @@
|
|
|
1
|
+
const R = {
|
|
2
|
+
TITLE: "You May Also Like!"
|
|
3
|
+
}, O = `
|
|
4
|
+
<tr>
|
|
5
|
+
<td class="spacer" style="height: 20px;"></td>
|
|
6
|
+
</tr>
|
|
7
|
+
`, w = `
|
|
8
|
+
<tr>
|
|
9
|
+
<td>
|
|
10
|
+
<table width="100%" height="100%" cellpadding="0" cellspacing="0" border="0">
|
|
11
|
+
{-{-PRODUCTS-}-}
|
|
12
|
+
</table>
|
|
13
|
+
</td>
|
|
14
|
+
</tr>
|
|
15
|
+
`, i = `
|
|
16
|
+
<td width="{-{-COLUMN_WIDTH-}-}" style="padding: 0 5px;" valign="top" height="100%">
|
|
17
|
+
<table
|
|
18
|
+
width="100%"
|
|
19
|
+
height="100%"
|
|
20
|
+
cellpadding="0"
|
|
21
|
+
cellspacing="0"
|
|
22
|
+
border="0"
|
|
23
|
+
class="product-card-wrapper">
|
|
24
|
+
<tr>
|
|
25
|
+
<td
|
|
26
|
+
class="product-attribute-cell"
|
|
27
|
+
valign="top">
|
|
28
|
+
<table cellpadding="0" cellspacing="0" role="presentation" width="100%">
|
|
29
|
+
<tbody>
|
|
30
|
+
{-{-PRODUCT_CONTENT-}-}
|
|
31
|
+
</tbody>
|
|
32
|
+
</table>
|
|
33
|
+
</td>
|
|
34
|
+
</tr>
|
|
35
|
+
</table>
|
|
36
|
+
</td>
|
|
37
|
+
`, b = [
|
|
38
|
+
"productImage",
|
|
39
|
+
"productName",
|
|
40
|
+
"productOldPrice",
|
|
41
|
+
"productPrice",
|
|
42
|
+
"productButton"
|
|
43
|
+
];
|
|
44
|
+
function C() {
|
|
45
|
+
return [
|
|
46
|
+
{
|
|
47
|
+
name: "Product Name",
|
|
48
|
+
image_url: "https://email-static.useinsider.com/stripo/modules/email-recommendation-v3/assets/images/image-placeholder.png",
|
|
49
|
+
price: { USD: 18 },
|
|
50
|
+
original_price: { USD: 20 },
|
|
51
|
+
discount: { USD: 2 },
|
|
52
|
+
url: "https://example.com/product/1",
|
|
53
|
+
item_id: "1",
|
|
54
|
+
in_stock: 1,
|
|
55
|
+
locale: "en",
|
|
56
|
+
product_attributes: {},
|
|
57
|
+
category: []
|
|
58
|
+
},
|
|
59
|
+
{
|
|
60
|
+
name: "Belt",
|
|
61
|
+
image_url: "https://inshoppingcart.com/ins-html/wp-content/uploads/2018/09/belt-2.jpg",
|
|
62
|
+
price: { TRY: 55 },
|
|
63
|
+
original_price: { TRY: 65 },
|
|
64
|
+
discount: { TRY: 10 },
|
|
65
|
+
url: "https://example.com/product/2",
|
|
66
|
+
item_id: "2",
|
|
67
|
+
in_stock: 1,
|
|
68
|
+
locale: "tr",
|
|
69
|
+
product_attributes: {},
|
|
70
|
+
category: []
|
|
71
|
+
},
|
|
72
|
+
{
|
|
73
|
+
name: "Beanie",
|
|
74
|
+
image_url: "https://inshoppingcart.com/ins-html/wp-content/uploads/2018/08/beanie-with-logo-1.jpg",
|
|
75
|
+
price: { TRY: 18 },
|
|
76
|
+
original_price: { TRY: 20 },
|
|
77
|
+
discount: { TRY: 2 },
|
|
78
|
+
url: "https://example.com/product/3",
|
|
79
|
+
item_id: "3",
|
|
80
|
+
in_stock: 1,
|
|
81
|
+
locale: "tr",
|
|
82
|
+
product_attributes: {},
|
|
83
|
+
category: []
|
|
84
|
+
},
|
|
85
|
+
{
|
|
86
|
+
name: "Album",
|
|
87
|
+
image_url: "https://inshoppingcart.com/ins-html/wp-content/uploads/2018/12/poster_2_up.jpg",
|
|
88
|
+
price: { TRY: 15 },
|
|
89
|
+
original_price: { TRY: 15 },
|
|
90
|
+
discount: { TRY: 0 },
|
|
91
|
+
url: "https://example.com/product/4",
|
|
92
|
+
item_id: "4",
|
|
93
|
+
in_stock: 1,
|
|
94
|
+
locale: "tr",
|
|
95
|
+
product_attributes: {},
|
|
96
|
+
category: []
|
|
97
|
+
},
|
|
98
|
+
{
|
|
99
|
+
name: "Flying Ninja with a very long product name",
|
|
100
|
+
image_url: "https://inshoppingcart.com/ins-html/wp-content/uploads/2018/09/belt-2.jpg",
|
|
101
|
+
price: { TRY: 12 },
|
|
102
|
+
original_price: { TRY: 15 },
|
|
103
|
+
discount: { TRY: 3 },
|
|
104
|
+
url: "https://example.com/product/5",
|
|
105
|
+
item_id: "5",
|
|
106
|
+
in_stock: 1,
|
|
107
|
+
locale: "tr",
|
|
108
|
+
product_attributes: {},
|
|
109
|
+
category: []
|
|
110
|
+
},
|
|
111
|
+
{
|
|
112
|
+
name: "Single",
|
|
113
|
+
image_url: "https://inshoppingcart.com/ins-html/wp-content/uploads/2018/12/poster_2_up.jpg",
|
|
114
|
+
price: { TRY: 22555 },
|
|
115
|
+
original_price: { TRY: 33989 },
|
|
116
|
+
discount: { TRY: 11434 },
|
|
117
|
+
url: "https://example.com/product/6",
|
|
118
|
+
item_id: "6",
|
|
119
|
+
in_stock: 1,
|
|
120
|
+
locale: "tr",
|
|
121
|
+
product_attributes: {},
|
|
122
|
+
category: []
|
|
123
|
+
}
|
|
124
|
+
];
|
|
125
|
+
}
|
|
126
|
+
function N(p, r, e, l = b) {
|
|
127
|
+
const n = (100 / r).toFixed(2), a = [];
|
|
128
|
+
for (let o = 0; o < p.length; o += r)
|
|
129
|
+
a.push(p.slice(o, o + r));
|
|
130
|
+
let c = "";
|
|
131
|
+
return a.forEach((o, _) => {
|
|
132
|
+
_ > 0 && (c += O);
|
|
133
|
+
let s = "", u = "", d = "", m = "", g = "";
|
|
134
|
+
o.forEach((t) => {
|
|
135
|
+
s += i.replace(
|
|
136
|
+
"{-{-PRODUCT_CONTENT-}-}",
|
|
137
|
+
e.productImage(t)
|
|
138
|
+
), u += i.replace(
|
|
139
|
+
"{-{-PRODUCT_CONTENT-}-}",
|
|
140
|
+
e.productName(t)
|
|
141
|
+
), d += i.replace(
|
|
142
|
+
"{-{-PRODUCT_CONTENT-}-}",
|
|
143
|
+
e.productPrice(t)
|
|
144
|
+
), m += i.replace(
|
|
145
|
+
"{-{-PRODUCT_CONTENT-}-}",
|
|
146
|
+
e.productOldPrice(t)
|
|
147
|
+
), g += i.replace(
|
|
148
|
+
"{-{-PRODUCT_CONTENT-}-}",
|
|
149
|
+
e.productButton(t)
|
|
150
|
+
);
|
|
151
|
+
});
|
|
152
|
+
const T = {
|
|
153
|
+
productImage: s,
|
|
154
|
+
productName: u,
|
|
155
|
+
productPrice: d,
|
|
156
|
+
productOldPrice: m,
|
|
157
|
+
productButton: g
|
|
158
|
+
}, h = l.filter((t) => !!T[t]).map((t) => `<tr>${T[t]}</tr>`).join("");
|
|
159
|
+
c += w.replace("{-{-PRODUCTS-}-}", h);
|
|
160
|
+
}), c.replaceAll("{-{-COLUMN_WIDTH-}-}", `${n}%`);
|
|
161
|
+
}
|
|
162
|
+
function P(p, r, e, l, n = R.TITLE, a) {
|
|
163
|
+
const c = N(
|
|
164
|
+
r,
|
|
165
|
+
e,
|
|
166
|
+
l,
|
|
167
|
+
a
|
|
168
|
+
);
|
|
169
|
+
return p.replace("{-{-TITLE-}-}", n).replace("{-{-PRODUCT_ROWS-}-}", c);
|
|
170
|
+
}
|
|
171
|
+
export {
|
|
172
|
+
R as DEFAULTS,
|
|
173
|
+
b as DEFAULT_CARD_COMPOSITION,
|
|
174
|
+
P as generateTemplate,
|
|
175
|
+
C as getDefaultProducts,
|
|
176
|
+
N as prepareProductRows,
|
|
177
|
+
i as productCardWrapper,
|
|
178
|
+
w as productRow,
|
|
179
|
+
O as spacer
|
|
180
|
+
};
|
|
@@ -1,17 +1,17 @@
|
|
|
1
1
|
var _ = Object.defineProperty;
|
|
2
|
-
var
|
|
3
|
-
var u = (n, i, e) =>
|
|
2
|
+
var S = (n, i, e) => i in n ? _(n, i, { enumerable: !0, configurable: !0, writable: !0, value: e }) : n[i] = e;
|
|
3
|
+
var u = (n, i, e) => S(n, typeof i != "symbol" ? i + "" : i, e);
|
|
4
4
|
import { PAGE_TYPES as E } from "../../../enums/unsubscribe.js";
|
|
5
5
|
import { useUnsubscribeStore as c } from "../../../stores/unsubscribe.js";
|
|
6
|
-
import { Block as
|
|
7
|
-
import { getDefaultTemplate as
|
|
6
|
+
import { Block as d, BlockCompositionType as L, ModificationDescription as b } from "../../../node_modules/@stripoinc/ui-editor-extensions/dist/esm/index.js";
|
|
7
|
+
import { getDefaultTemplate as h } from "./template.js";
|
|
8
8
|
import { UNSUBSCRIBE_EVENTS as a, DATA_ATTRIBUTES as o } from "./utils/constants.js";
|
|
9
9
|
import { parsePageList as m } from "./utils/utils.js";
|
|
10
|
-
const v = "unsubscribe-block", g = 'a[data-unsubscribe-link="true"]',
|
|
10
|
+
const v = "unsubscribe-block", g = 'a[data-unsubscribe-link="true"]', T = ".unsubscribe-block-v2", f = "{{ins-unsubscribe-link}}", B = {
|
|
11
11
|
[E.GLOBAL_UNSUBSCRIBE]: "{{ins-global-unsubscribe-link}}",
|
|
12
12
|
[E.SUBSCRIPTION_PREFERENCE_CENTER]: "{{ins-preferences-unsubscribe-link}}"
|
|
13
13
|
};
|
|
14
|
-
class D extends
|
|
14
|
+
class D extends d {
|
|
15
15
|
constructor() {
|
|
16
16
|
super();
|
|
17
17
|
u(this, "selectEventListener", null);
|
|
@@ -25,7 +25,7 @@ class D extends S {
|
|
|
25
25
|
return "unsubscribe-icon";
|
|
26
26
|
}
|
|
27
27
|
getBlockCompositionType() {
|
|
28
|
-
return
|
|
28
|
+
return L.BLOCK;
|
|
29
29
|
}
|
|
30
30
|
getName() {
|
|
31
31
|
return this.api.translate("Unsubscribe Block");
|
|
@@ -34,10 +34,10 @@ class D extends S {
|
|
|
34
34
|
return this.api.translate("Unsubscribe Block Description");
|
|
35
35
|
}
|
|
36
36
|
getTemplate() {
|
|
37
|
-
return
|
|
37
|
+
return h();
|
|
38
38
|
}
|
|
39
39
|
onCreated(e) {
|
|
40
|
-
"getAttribute" in e && e.getAttribute("data-migration") || (this.currentNode = e, this._resetStoreState(), this._setupSelectEventListener(), this._setupCancelEventListener(), this._checkExistingBlocks(), this._openDrawer());
|
|
40
|
+
"getOuterHTML" in e && !e.getOuterHTML() || "getAttribute" in e && e.getAttribute("data-migration") || (this.currentNode = e, this._resetStoreState(), this._setupSelectEventListener(), this._setupCancelEventListener(), this._checkExistingBlocks(), this._openDrawer());
|
|
41
41
|
}
|
|
42
42
|
onSelect(e) {
|
|
43
43
|
this.currentNode = e, this._resetStoreState(), this._loadBlockState(e), this._setupSelectEventListener();
|
|
@@ -50,8 +50,8 @@ class D extends S {
|
|
|
50
50
|
}
|
|
51
51
|
_setupSelectEventListener() {
|
|
52
52
|
this._removeSelectEventListener(), this.selectEventListener = (e) => {
|
|
53
|
-
const
|
|
54
|
-
this._updateBlock(t,
|
|
53
|
+
const s = e, { collectionType: t, selectedPages: r } = s.detail;
|
|
54
|
+
this._updateBlock(t, r.join(","));
|
|
55
55
|
}, document.addEventListener(a.SELECT, this.selectEventListener);
|
|
56
56
|
}
|
|
57
57
|
_removeSelectEventListener() {
|
|
@@ -71,17 +71,17 @@ class D extends S {
|
|
|
71
71
|
_removeEventListeners() {
|
|
72
72
|
this._removeSelectEventListener(), this._removeCancelEventListener();
|
|
73
73
|
}
|
|
74
|
-
_updateBlock(e,
|
|
74
|
+
_updateBlock(e, s) {
|
|
75
75
|
if (!this.currentNode || !("querySelector" in this.currentNode))
|
|
76
76
|
return;
|
|
77
77
|
const t = this.currentNode.querySelector(g);
|
|
78
78
|
if (!t)
|
|
79
79
|
return;
|
|
80
|
-
const
|
|
81
|
-
this.api.getDocumentModifier().modifyHtml(t).setAttribute("href",
|
|
80
|
+
const r = this._getMergeTag(e);
|
|
81
|
+
this.api.getDocumentModifier().modifyHtml(t).setAttribute("href", r).apply(new b(`Updated unsubscribe link to ${r}`)), this.api.getDocumentModifier().modifyHtml(this.currentNode).setAttribute(o.PAGE_TYPE, e.toString()).setAttribute(o.PAGE_LIST, s).apply(new b("Updated unsubscribe block metadata"));
|
|
82
82
|
}
|
|
83
83
|
_getMergeTag(e) {
|
|
84
|
-
return
|
|
84
|
+
return B[e] ?? f;
|
|
85
85
|
}
|
|
86
86
|
_openDrawer() {
|
|
87
87
|
try {
|
|
@@ -93,11 +93,11 @@ class D extends S {
|
|
|
93
93
|
}
|
|
94
94
|
_checkExistingBlocks() {
|
|
95
95
|
const e = c();
|
|
96
|
-
e.isGlobalUnsubscribeDisabled = !1, e.isSubscriptionPreferencesCenterDisabled = !1, this.api.getDocumentRoot().querySelectorAll(
|
|
96
|
+
e.isGlobalUnsubscribeDisabled = !1, e.isSubscriptionPreferencesCenterDisabled = !1, this.api.getDocumentRoot().querySelectorAll(T).forEach((t) => {
|
|
97
97
|
if ("getAttribute" in t) {
|
|
98
|
-
const
|
|
99
|
-
if (
|
|
100
|
-
const l = Number(
|
|
98
|
+
const r = t.getAttribute(o.PAGE_TYPE);
|
|
99
|
+
if (r) {
|
|
100
|
+
const l = Number(r);
|
|
101
101
|
l === E.GLOBAL_UNSUBSCRIBE ? e.isGlobalUnsubscribeDisabled = !0 : l === E.SUBSCRIPTION_PREFERENCE_CENTER && (e.isSubscriptionPreferencesCenterDisabled = !0);
|
|
102
102
|
}
|
|
103
103
|
}
|
|
@@ -106,11 +106,11 @@ class D extends S {
|
|
|
106
106
|
_loadBlockState(e) {
|
|
107
107
|
if (!("getAttribute" in e))
|
|
108
108
|
return;
|
|
109
|
-
const
|
|
110
|
-
if (!
|
|
109
|
+
const s = e.getAttribute(o.PAGE_TYPE), t = e.getAttribute(o.PAGE_LIST);
|
|
110
|
+
if (!s || !t)
|
|
111
111
|
return;
|
|
112
|
-
const
|
|
113
|
-
|
|
112
|
+
const r = c(), l = Number(s), p = m(t);
|
|
113
|
+
r.setCollectionWithoutAutoSelection(l), r.loadSelectedTemplates(p);
|
|
114
114
|
}
|
|
115
115
|
_resetStoreState() {
|
|
116
116
|
c().$reset();
|
|
@@ -118,11 +118,11 @@ class D extends S {
|
|
|
118
118
|
_removeBlockTemplatesFromStore(e) {
|
|
119
119
|
if (!("getAttribute" in e))
|
|
120
120
|
return;
|
|
121
|
-
const
|
|
122
|
-
if (!
|
|
121
|
+
const s = e.getAttribute(o.PAGE_LIST);
|
|
122
|
+
if (!s)
|
|
123
123
|
return;
|
|
124
|
-
const t = c(),
|
|
125
|
-
t.removeUnsubscribePages(
|
|
124
|
+
const t = c(), r = m(s);
|
|
125
|
+
t.removeUnsubscribePages(r);
|
|
126
126
|
}
|
|
127
127
|
}
|
|
128
128
|
export {
|