@useinsider/guido 1.0.3-beta.9dbb968 → 1.0.3-beta.9f7b494
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 +144 -3
- package/dist/components/Guido.vue.js +11 -9
- package/dist/components/Guido.vue2.js +73 -65
- package/dist/components/organisms/extensions/recommendation/FilterItem.vue.js +28 -0
- package/dist/components/organisms/extensions/recommendation/FilterItem.vue2.js +38 -0
- package/dist/components/organisms/extensions/recommendation/FilterSelectionDrawer.vue.js +17 -0
- package/dist/components/organisms/extensions/recommendation/FilterSelectionDrawer.vue2.js +37 -0
- package/dist/components/organisms/extensions/recommendation/Filters.vue.js +20 -0
- package/dist/components/organisms/extensions/recommendation/Filters.vue2.js +44 -0
- package/dist/components/organisms/extensions/recommendation/LogicAdapter.vue.js +17 -0
- package/dist/components/organisms/extensions/recommendation/LogicAdapter.vue2.js +27 -0
- package/dist/components/organisms/header/LeftSlot.vue.js +1 -1
- package/dist/components/organisms/header/LeftSlot.vue2.js +16 -15
- package/dist/components/organisms/header/RightSlot.vue.js +11 -11
- package/dist/components/organisms/header/RightSlot.vue2.js +23 -22
- 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 +19 -18
- package/dist/components/organisms/unsubscribe/UnsubscribeTypeSelection.vue.js +1 -1
- package/dist/components/organisms/unsubscribe/UnsubscribeTypeSelection.vue2.js +15 -14
- package/dist/composables/useBlocksConfig.js +49 -0
- package/dist/composables/useGuidoActions.js +19 -9
- package/dist/composables/useStripo.js +48 -52
- package/dist/config/compiler/unsubscribeCompilerRules.js +41 -33
- package/dist/config/migrator/couponBlockMigrator.js +67 -0
- package/dist/config/migrator/index.js +7 -5
- package/dist/config/migrator/recommendationMigrator.js +293 -0
- package/dist/config/migrator/unsubscribeMigrator.js +61 -49
- package/dist/enums/date.js +6 -0
- package/dist/enums/defaults.js +16 -8
- package/dist/enums/extensions/recommendationBlock.js +80 -0
- package/dist/enums/onboarding.js +2 -1
- package/dist/enums/unsubscribe.js +29 -23
- package/dist/extensions/Blocks/Checkbox/control.js +55 -53
- package/dist/extensions/Blocks/Checkbox/extension.js +2 -2
- package/dist/extensions/Blocks/CouponBlock/block.js +33 -0
- package/dist/extensions/Blocks/CouponBlock/extension.js +8 -0
- package/dist/extensions/Blocks/CouponBlock/iconsRegistry.js +33 -0
- package/dist/extensions/Blocks/CouponBlock/settingsPanel.js +24 -0
- package/dist/extensions/Blocks/CouponBlock/template.js +18 -0
- package/dist/extensions/Blocks/RadioButton/control.js +44 -42
- package/dist/extensions/Blocks/RadioButton/template.js +6 -6
- package/dist/extensions/Blocks/Recommendation/block.js +30 -0
- 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 +306 -0
- 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 +45 -0
- package/dist/extensions/Blocks/Recommendation/iconsRegistry.js +51 -0
- package/dist/extensions/Blocks/Recommendation/recommendation.css.js +19 -0
- package/dist/extensions/Blocks/Recommendation/settingsPanel.js +117 -0
- package/dist/extensions/Blocks/Recommendation/store/recommendation.js +266 -0
- 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/Recommendation/utils/filterUtil.js +28 -0
- package/dist/extensions/Blocks/common-control.js +184 -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 +311 -93
- package/dist/package.json.js +7 -0
- package/dist/services/recommendationApi.js +43 -0
- package/dist/services/stripoApi.js +1 -1
- package/dist/src/@types/generic.d.ts +98 -0
- package/dist/{components → src/components}/Guido.vue.d.ts +4 -2
- package/dist/src/components/organisms/extensions/recommendation/FilterItem.vue.d.ts +19 -0
- package/dist/src/components/organisms/extensions/recommendation/LogicAdapter.vue.d.ts +16 -0
- package/dist/src/components/organisms/onboarding/NewVersionPopup.vue.d.ts +4 -0
- package/dist/src/components/organisms/onboarding/OnboardingWrapper.vue.d.ts +4 -0
- package/dist/src/composables/useBlocksConfig.d.ts +11 -0
- package/dist/{composables → src/composables}/useGuidoActions.d.ts +9 -0
- package/dist/src/config/migrator/couponBlockMigrator.d.ts +1 -0
- package/dist/src/config/migrator/recommendationMigrator.d.ts +1 -0
- package/dist/src/enums/date.d.ts +4 -0
- package/dist/src/enums/extensions/recommendationBlock.d.ts +16 -0
- package/dist/src/enums/onboarding.d.ts +2 -0
- package/dist/{enums → src/enums}/unsubscribe.d.ts +4 -0
- package/dist/src/extensions/Blocks/CouponBlock/block.d.ts +12 -0
- package/dist/src/extensions/Blocks/CouponBlock/iconsRegistry.d.ts +4 -0
- package/dist/src/extensions/Blocks/CouponBlock/settingsPanel.d.ts +4 -0
- package/dist/src/extensions/Blocks/CouponBlock/template.d.ts +3 -0
- package/dist/src/extensions/Blocks/Recommendation/block.d.ts +11 -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 +35 -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/iconsRegistry.d.ts +4 -0
- package/dist/src/extensions/Blocks/Recommendation/store/recommendation.d.ts +555 -0
- 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/Recommendation/utils/filterUtil.d.ts +7 -0
- package/dist/src/extensions/Blocks/_Boilerplate/extension.d.ts +2 -0
- package/dist/src/extensions/Blocks/_Boilerplate/settingsPanel.d.ts +4 -0
- package/dist/src/extensions/Blocks/common-control.d.ts +87 -0
- package/dist/src/extensions/DynamicContent/dynamic-content-modal.d.ts +13 -0
- package/dist/src/extensions/DynamicContent/dynamic-content.d.ts +66 -0
- package/dist/src/extensions/DynamicContent/extension.d.ts +2 -0
- package/dist/src/mock/api/validator.d.ts +2 -0
- package/dist/src/services/recommendationApi.d.ts +6 -0
- package/dist/src/stores/config.d.ts +104 -0
- package/dist/{stores → src/stores}/dynamic-content.d.ts +3 -3
- package/dist/{stores → src/stores}/editor.d.ts +22 -1
- package/dist/{stores → src/stores}/onboarding.d.ts +1 -1
- package/dist/{stores → src/stores}/preview.d.ts +1 -1
- package/dist/{stores → src/stores}/recommendation.d.ts +1 -1
- package/dist/{stores → src/stores}/save-as-template.d.ts +1 -1
- package/dist/{stores → src/stores}/toaster.d.ts +1 -1
- package/dist/{stores → src/stores}/unsubscribe.d.ts +1 -1
- package/dist/{stores → src/stores}/version-history.d.ts +1 -1
- package/dist/src/utils/dateUtil.d.ts +22 -0
- package/dist/src/utils/environmentUtil.d.ts +5 -0
- package/dist/{utils → src/utils}/genericUtil.d.ts +2 -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 +17 -0
- package/dist/stores/dynamic-content.js +2 -2
- package/dist/stores/editor.js +3 -2
- package/dist/stores/onboarding.js +27 -27
- 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 +23 -11
- package/package.json +9 -4
- package/dist/@types/generic.d.ts +0 -57
- package/dist/enums/onboarding.d.ts +0 -1
- package/dist/extensions/DynamicContent/dynamic-content-modal.d.ts +0 -6
- package/dist/extensions/DynamicContent/dynamic-content.d.ts +0 -16
- package/dist/utils/dateUtil.d.ts +0 -1
- package/dist/{@types → src/@types}/events.d.ts +0 -0
- package/dist/{@types → src/@types}/save-as-template.d.ts +0 -0
- package/dist/{App.vue.d.ts → src/App.vue.d.ts} +0 -0
- package/dist/{components → src/components}/organisms/LoadingWrapper.vue.d.ts +0 -0
- package/dist/{components → src/components}/organisms/base/Toaster.vue.d.ts +0 -0
- package/dist/{components → src/components}/organisms/email-preview/PreviewContainer.vue.d.ts +0 -0
- package/dist/{components → src/components}/organisms/email-preview/amp/AmpErrorModal.vue.d.ts +0 -0
- package/dist/{components → src/components}/organisms/email-preview/amp/AmpToggle.vue.d.ts +0 -0
- package/dist/{components → src/components}/organisms/email-preview/desktop-preview/DesktopPreview.vue.d.ts +0 -0
- package/dist/{components → src/components}/organisms/email-preview/desktop-preview/EmailHeaderInfo.vue.d.ts +0 -0
- package/dist/{components → src/components}/organisms/email-preview/desktop-preview/EmailSizeIndicator.vue.d.ts +0 -0
- package/dist/{components → src/components}/organisms/email-preview/mobile-preview/ContentView.vue.d.ts +0 -0
- package/dist/{components → src/components}/organisms/email-preview/mobile-preview/InboxView.vue.d.ts +0 -0
- package/dist/{components → src/components}/organisms/email-preview/mobile-preview/MobilePreview.vue.d.ts +0 -0
- package/dist/{components/organisms/header/LeftSlot.vue.d.ts → src/components/organisms/extensions/recommendation/FilterSelectionDrawer.vue.d.ts} +0 -0
- package/dist/{components/organisms/header/MiddleSlot.vue.d.ts → src/components/organisms/extensions/recommendation/Filters.vue.d.ts} +0 -0
- package/dist/{components → src/components}/organisms/header/HeaderWrapper.vue.d.ts +0 -0
- package/dist/{components/organisms/header/ViewOptions.vue.d.ts → src/components/organisms/header/LeftSlot.vue.d.ts} +0 -0
- package/dist/{components/organisms/header/version-history/RestoreButton.vue.d.ts → src/components/organisms/header/MiddleSlot.vue.d.ts} +0 -0
- package/dist/{components → src/components}/organisms/header/RightSlot.vue.d.ts +0 -0
- package/dist/{components/organisms/header/version-history → src/components/organisms/header}/ViewOptions.vue.d.ts +0 -0
- package/dist/{components/organisms/onboarding/AMPOnboarding.vue.d.ts → src/components/organisms/header/version-history/RestoreButton.vue.d.ts} +0 -0
- package/dist/{components → src/components}/organisms/header/version-history/VersionHistory.vue.d.ts +0 -0
- package/dist/{components → src/components}/organisms/header/version-history/VersionHistoryItem.vue.d.ts +0 -0
- package/dist/{components/organisms/onboarding/GenericOnboarding.vue.d.ts → src/components/organisms/header/version-history/ViewOptions.vue.d.ts} +0 -0
- package/dist/{components/organisms/onboarding/NewVersionPopup.vue.d.ts → src/components/organisms/onboarding/AMPOnboarding.vue.d.ts} +0 -0
- package/dist/{components/organisms/onboarding/OnboardingWrapper.vue.d.ts → src/components/organisms/onboarding/GenericOnboarding.vue.d.ts} +0 -0
- package/dist/{components → src/components}/organisms/onboarding/TextBlockOnboarding.vue.d.ts +0 -0
- package/dist/{components → src/components}/organisms/onboarding/VersionHistoryOnboarding.vue.d.ts +0 -0
- package/dist/{components → src/components}/organisms/save-as-template/SaveAsTemplateDrawer.vue.d.ts +0 -0
- package/dist/{components → src/components}/organisms/unsubscribe/UnsubscribeBreadcrumb.vue.d.ts +0 -0
- package/dist/{components → src/components}/organisms/unsubscribe/UnsubscribePageSelection.vue.d.ts +0 -0
- package/dist/{components → src/components}/organisms/unsubscribe/UnsubscribeTypeSelection.vue.d.ts +0 -0
- package/dist/{components → src/components}/organisms/unsubscribe/UnsubscribeWrapper.vue.d.ts +0 -0
- package/dist/{components → src/components}/wrappers/WpDrawer.vue.d.ts +0 -0
- package/dist/{components → src/components}/wrappers/WpModal.vue.d.ts +1 -1
- /package/dist/{composables → src/composables}/useActionsApi.d.ts +0 -0
- /package/dist/{composables → src/composables}/useApiExample.d.ts +0 -0
- /package/dist/{composables → src/composables}/useCodeEditorApi.d.ts +0 -0
- /package/dist/{composables → src/composables}/useConfig.d.ts +0 -0
- /package/dist/{composables → src/composables}/useCustomInterfaceAppearance.d.ts +0 -0
- /package/dist/{composables → src/composables}/useDebounce.d.ts +0 -0
- /package/dist/{composables → src/composables}/useExport.d.ts +0 -0
- /package/dist/{composables → src/composables}/useHtmlCompiler.d.ts +0 -0
- /package/dist/{composables → src/composables}/useHtmlValidator.d.ts +0 -0
- /package/dist/{composables → src/composables}/useHttp.d.ts +0 -0
- /package/dist/{composables → src/composables}/usePartner.d.ts +0 -0
- /package/dist/{composables → src/composables}/usePreviewMode.d.ts +0 -0
- /package/dist/{composables → src/composables}/useProvideInject.d.ts +0 -0
- /package/dist/{composables → src/composables}/useRecommendation.d.ts +0 -0
- /package/dist/{composables → src/composables}/useResponsivePreview.d.ts +0 -0
- /package/dist/{composables → src/composables}/useSave.d.ts +0 -0
- /package/dist/{composables → src/composables}/useStripo.d.ts +0 -0
- /package/dist/{composables → src/composables}/useStripoEventHandler.d.ts +0 -0
- /package/dist/{composables → src/composables}/useToaster.d.ts +0 -0
- /package/dist/{composables → src/composables}/useTranslations.d.ts +0 -0
- /package/dist/{composables → src/composables}/useValidation.d.ts +0 -0
- /package/dist/{composables → src/composables}/useVersionHistoryApi.d.ts +0 -0
- /package/dist/{composables → src/composables}/validators/saveAsTemplate.d.ts +0 -0
- /package/dist/{config → src/config}/compiler/htmlCompilerRules.d.ts +0 -0
- /package/dist/{config → src/config}/compiler/outlookCompilerRules.d.ts +0 -0
- /package/dist/{config → src/config}/compiler/recommendationCompilerRules.d.ts +0 -0
- /package/dist/{config → src/config}/compiler/socialCompilerRules.d.ts +0 -0
- /package/dist/{config → src/config}/compiler/unsubscribeCompilerRules.d.ts +0 -0
- /package/dist/{config → src/config}/migrator/checkboxMigrator.d.ts +0 -0
- /package/dist/{config → src/config}/migrator/index.d.ts +0 -0
- /package/dist/{config → src/config}/migrator/radioButtonMigrator.d.ts +0 -0
- /package/dist/{config → src/config}/migrator/unsubscribeMigrator.d.ts +0 -0
- /package/dist/{enums → src/enums}/defaults.d.ts +0 -0
- /package/dist/{enums → src/enums}/displayConditions.d.ts +0 -0
- /package/dist/{enums → src/enums}/html-validator.d.ts +0 -0
- /package/dist/{enums → src/enums}/preview.d.ts +0 -0
- /package/dist/{enums → src/enums}/recommendation.d.ts +0 -0
- /package/dist/{enums → src/enums}/toaster.d.ts +0 -0
- /package/dist/{extensions → src/extensions}/Blocks/Checkbox/block.d.ts +0 -0
- /package/dist/{extensions → src/extensions}/Blocks/Checkbox/control.d.ts +0 -0
- /package/dist/{extensions → src/extensions}/Blocks/Checkbox/extension.d.ts +0 -0
- /package/dist/{extensions → src/extensions}/Blocks/Checkbox/iconsRegistry.d.ts +0 -0
- /package/dist/{extensions → src/extensions}/Blocks/Checkbox/settingsPanel.d.ts +0 -0
- /package/dist/{extensions → src/extensions}/Blocks/Checkbox/template.d.ts +0 -0
- /package/dist/{extensions/Blocks/RadioButton → src/extensions/Blocks/CouponBlock}/extension.d.ts +0 -0
- /package/dist/{extensions → src/extensions}/Blocks/RadioButton/block.d.ts +0 -0
- /package/dist/{extensions → src/extensions}/Blocks/RadioButton/control.d.ts +0 -0
- /package/dist/{extensions/Blocks/Unsubscribe → src/extensions/Blocks/RadioButton}/extension.d.ts +0 -0
- /package/dist/{extensions → src/extensions}/Blocks/RadioButton/iconsRegistry.d.ts +0 -0
- /package/dist/{extensions → src/extensions}/Blocks/RadioButton/settingsPanel.d.ts +0 -0
- /package/dist/{extensions → src/extensions}/Blocks/RadioButton/template.d.ts +0 -0
- /package/dist/{extensions/Blocks/_Boilerplate → src/extensions/Blocks/Recommendation}/extension.d.ts +0 -0
- /package/dist/{extensions/Blocks/Unsubscribe → src/extensions/Blocks/Recommendation}/settingsPanel.d.ts +0 -0
- /package/dist/{extensions → src/extensions}/Blocks/Unsubscribe/block.d.ts +0 -0
- /package/dist/{extensions → src/extensions}/Blocks/Unsubscribe/control.d.ts +0 -0
- /package/dist/{extensions → src/extensions}/Blocks/Unsubscribe/elements/preview.d.ts +0 -0
- /package/dist/{extensions/DynamicContent → src/extensions/Blocks/Unsubscribe}/extension.d.ts +0 -0
- /package/dist/{extensions → src/extensions}/Blocks/Unsubscribe/iconsRegistry.d.ts +0 -0
- /package/dist/{extensions/Blocks/_Boilerplate → src/extensions/Blocks/Unsubscribe}/settingsPanel.d.ts +0 -0
- /package/dist/{extensions → src/extensions}/Blocks/Unsubscribe/tagRegistry.d.ts +0 -0
- /package/dist/{extensions → src/extensions}/Blocks/Unsubscribe/template.d.ts +0 -0
- /package/dist/{extensions → src/extensions}/Blocks/Unsubscribe/utils/constants.d.ts +0 -0
- /package/dist/{extensions → src/extensions}/Blocks/Unsubscribe/utils/utils.d.ts +0 -0
- /package/dist/{extensions → src/extensions}/Blocks/_Boilerplate/block.d.ts +0 -0
- /package/dist/{extensions → src/extensions}/Blocks/_Boilerplate/control.d.ts +0 -0
- /package/dist/{extensions → src/extensions}/Blocks/_Boilerplate/iconsRegistry.d.ts +0 -0
- /package/dist/{extensions → src/extensions}/Blocks/_Boilerplate/template.d.ts +0 -0
- /package/dist/{library.d.ts → src/library.d.ts} +0 -0
- /package/dist/{main.d.ts → src/main.d.ts} +0 -0
- /package/dist/{mock → src/mock}/api/auth.d.ts +0 -0
- /package/dist/{mock → src/mock}/api/custom-fonts.d.ts +0 -0
- /package/dist/{mock → src/mock}/api/default-template.d.ts +0 -0
- /package/dist/{mock/api/template-library.d.ts → src/mock/api/recommendation.d.ts} +0 -0
- /package/dist/{mock/api/unsubscribe.d.ts → src/mock/api/template-library.d.ts} +0 -0
- /package/dist/{mock/api/user-modal-state.d.ts → src/mock/api/unsubscribe.d.ts} +0 -0
- /package/dist/{mock/api/validator.d.ts → src/mock/api/user-modal-state.d.ts} +0 -0
- /package/dist/{mock → src/mock}/browser.d.ts +0 -0
- /package/dist/{mock → src/mock}/handlers.d.ts +0 -0
- /package/dist/{services → src/services}/onboardingApi.d.ts +0 -0
- /package/dist/{services → src/services}/stripoApi.d.ts +0 -0
- /package/dist/{services → src/services}/templateLibraryApi.d.ts +0 -0
- /package/dist/{services → src/services}/unsubscribeApi.d.ts +0 -0
- /package/dist/{utils → src/utils}/arrayUtil.d.ts +0 -0
- /package/dist/{utils → src/utils}/base64.d.ts +0 -0
- /package/dist/{utils → src/utils}/htmlCompiler.d.ts +0 -0
- /package/dist/{utils → src/utils}/templatePreparation.d.ts +0 -0
- /package/dist/{utils → src/utils}/tooltipUtils.d.ts +0 -0
|
@@ -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
|
+
};
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
function l(t) {
|
|
2
|
+
if (t.length === 0)
|
|
3
|
+
return "";
|
|
4
|
+
const o = t.sort((r, e) => r.filterNumber - e.filterNumber), n = o.map((r) => `[${r.attribute}][${r.operatorReplace}][${r.value}]`), [s, ...p] = n;
|
|
5
|
+
let u = s;
|
|
6
|
+
for (let r = 0; r < p.length; r++) {
|
|
7
|
+
const e = o[r + 1].innerGroupOperator;
|
|
8
|
+
u += `${e}${p[r]}`;
|
|
9
|
+
}
|
|
10
|
+
return `(${u})`;
|
|
11
|
+
}
|
|
12
|
+
function m(t) {
|
|
13
|
+
if (!t || t.length === 0)
|
|
14
|
+
return "";
|
|
15
|
+
const o = t.reduce((r, e) => (r[e.filterGroup] || (r[e.filterGroup] = []), r[e.filterGroup].push(e), r), {}), n = Object.keys(o).map(Number).sort((r, e) => r - e), s = n.map((r) => {
|
|
16
|
+
const e = o[r];
|
|
17
|
+
return l(e);
|
|
18
|
+
}), [p, ...u] = s;
|
|
19
|
+
let i = p;
|
|
20
|
+
for (let r = 0; r < u.length; r++) {
|
|
21
|
+
const e = n[r + 1], c = o[e][0].outerGroupOperator;
|
|
22
|
+
i += `${c}${u[r]}`;
|
|
23
|
+
}
|
|
24
|
+
return console.debug("🎉 Complete query generated:", i), i.trim();
|
|
25
|
+
}
|
|
26
|
+
export {
|
|
27
|
+
m as generateCompleteFilterQuery
|
|
28
|
+
};
|
|
@@ -0,0 +1,184 @@
|
|
|
1
|
+
var u = Object.defineProperty;
|
|
2
|
+
var C = (o, n, E) => n in o ? u(o, n, { enumerable: !0, configurable: !0, writable: !0, value: E }) : o[n] = E;
|
|
3
|
+
var a = (o, n, E) => C(o, typeof n != "symbol" ? n + "" : n, E);
|
|
4
|
+
import { Control as R, UIElementType as $, UEAttr as e } from "../../node_modules/@stripoinc/ui-editor-extensions/dist/esm/index.js";
|
|
5
|
+
class N extends R {
|
|
6
|
+
constructor() {
|
|
7
|
+
super(...arguments);
|
|
8
|
+
a(this, "currentNode");
|
|
9
|
+
}
|
|
10
|
+
getContainer() {
|
|
11
|
+
var E;
|
|
12
|
+
return (E = document.querySelector("ui-editor")) == null ? void 0 : E.shadowRoot;
|
|
13
|
+
}
|
|
14
|
+
onTemplateNodeUpdated(E) {
|
|
15
|
+
this.currentNode = E;
|
|
16
|
+
}
|
|
17
|
+
_GuLabel({ text: E, name: t = "", position: T = "top" }) {
|
|
18
|
+
return `
|
|
19
|
+
<${$.LABEL}
|
|
20
|
+
style="${T === "top" ? "margin-bottom: 8px;" : ""}"
|
|
21
|
+
${e.LABEL.text}="${E}"
|
|
22
|
+
${e.LABEL.name}="${t || `${E} Label`}">
|
|
23
|
+
</${$.LABEL}>
|
|
24
|
+
`;
|
|
25
|
+
}
|
|
26
|
+
_GuToggle(E) {
|
|
27
|
+
return `
|
|
28
|
+
<${$.SWITCHER}
|
|
29
|
+
${e.SWITCHER.name}="${E}">
|
|
30
|
+
</${$.SWITCHER}>
|
|
31
|
+
`;
|
|
32
|
+
}
|
|
33
|
+
_GuSelectItem({ text: E, value: t }) {
|
|
34
|
+
return `
|
|
35
|
+
<${$.SELECT_ITEM}
|
|
36
|
+
${e.SELECT_ITEM.text}="${E}"
|
|
37
|
+
${e.SELECT_ITEM.value}="${t}">
|
|
38
|
+
</${$.SELECT_ITEM}>`;
|
|
39
|
+
}
|
|
40
|
+
_GuSelect({ name: E, placeholder: t, options: T, className: r = "es-180w" }) {
|
|
41
|
+
return `
|
|
42
|
+
<${$.SELECTPICKER}
|
|
43
|
+
class="${r}"
|
|
44
|
+
${e.SELECTPICKER.name}="${E}"
|
|
45
|
+
${e.SELECTPICKER.placeholder}="${t}">
|
|
46
|
+
${T.map((O) => this._GuSelectItem(O)).join("")}
|
|
47
|
+
</${$.SELECTPICKER}>
|
|
48
|
+
`;
|
|
49
|
+
}
|
|
50
|
+
_GuTextInput({ name: E, placeholder: t, className: T = "" }) {
|
|
51
|
+
return `
|
|
52
|
+
<${$.TEXT}
|
|
53
|
+
class=${T}
|
|
54
|
+
${e.TEXT.name}="${E}"
|
|
55
|
+
placeholder="${t || E}">
|
|
56
|
+
</${$.TEXT}>
|
|
57
|
+
`;
|
|
58
|
+
}
|
|
59
|
+
_GuCounter({ name: E, maxValue: t, minValue: T = 1, step: r = 1 }) {
|
|
60
|
+
return `
|
|
61
|
+
<${$.COUNTER}
|
|
62
|
+
${e.COUNTER.name}="${E}"
|
|
63
|
+
${e.COUNTER.minValue}="${T}"
|
|
64
|
+
${e.COUNTER.maxValue}="${t}"
|
|
65
|
+
${e.COUNTER.step}="${r}">
|
|
66
|
+
</${$.COUNTER}>
|
|
67
|
+
`;
|
|
68
|
+
}
|
|
69
|
+
_GuButton({ name: E, label: t, id: T = "" }) {
|
|
70
|
+
return `
|
|
71
|
+
<${$.BUTTON}
|
|
72
|
+
${e.BUTTON.name}="${E}"
|
|
73
|
+
${T ? `id="${T}"` : ""}
|
|
74
|
+
${e.BUTTON.caption}="${t}"}>
|
|
75
|
+
</${$.BUTTON}>
|
|
76
|
+
`;
|
|
77
|
+
}
|
|
78
|
+
/**
|
|
79
|
+
*
|
|
80
|
+
* @param param0
|
|
81
|
+
* @returns It returns a button with an icon.
|
|
82
|
+
*/
|
|
83
|
+
_GuIconButton({ name: E, icon: t, className: T = "" }) {
|
|
84
|
+
return `
|
|
85
|
+
<${$.BUTTON}
|
|
86
|
+
class="${T}"
|
|
87
|
+
${e.BUTTON.name}="${E}"
|
|
88
|
+
${e.BUTTON.icon}="${t}">
|
|
89
|
+
</${$.BUTTON}>
|
|
90
|
+
`;
|
|
91
|
+
}
|
|
92
|
+
_GuTwoColumns(E) {
|
|
93
|
+
return `
|
|
94
|
+
<div class="checkbox-select-container container two-columns">
|
|
95
|
+
${E.join("")}
|
|
96
|
+
</div>
|
|
97
|
+
`;
|
|
98
|
+
}
|
|
99
|
+
/**
|
|
100
|
+
* Creates an orderable (sortable) list control
|
|
101
|
+
* @param name - The control name for value binding
|
|
102
|
+
* @param items - Array of item keys/values
|
|
103
|
+
* @param itemLabels - Optional array of objects with key and label properties for display
|
|
104
|
+
* @returns HTML string for the orderable control
|
|
105
|
+
*/
|
|
106
|
+
_GuOrderable(E, t) {
|
|
107
|
+
let T = "";
|
|
108
|
+
t.forEach((O) => {
|
|
109
|
+
const L = e.ORDERABLE_ITEM && "name" in e.ORDERABLE_ITEM ? e.ORDERABLE_ITEM.name : "name";
|
|
110
|
+
T += `
|
|
111
|
+
<${$.ORDERABLE_ITEM} ${L}="${O.key}">
|
|
112
|
+
${O.content}
|
|
113
|
+
</${$.ORDERABLE_ITEM}>
|
|
114
|
+
`;
|
|
115
|
+
});
|
|
116
|
+
const r = e.ORDERABLE && "name" in e.ORDERABLE ? e.ORDERABLE.name : "name";
|
|
117
|
+
return `
|
|
118
|
+
<${$.ORDERABLE} ${r}="${E}">
|
|
119
|
+
${T}
|
|
120
|
+
</${$.ORDERABLE}>
|
|
121
|
+
`;
|
|
122
|
+
}
|
|
123
|
+
_GuNestedControl(E, t) {
|
|
124
|
+
return `
|
|
125
|
+
<${$.NESTED_CONTROL} ${e.NESTED_CONTROL.controlId}="${E}">
|
|
126
|
+
${t}
|
|
127
|
+
</${$.NESTED_CONTROL}>
|
|
128
|
+
`;
|
|
129
|
+
}
|
|
130
|
+
_GuExpandable(E, t) {
|
|
131
|
+
return `
|
|
132
|
+
<${$.EXPANDABLE}>
|
|
133
|
+
<${$.EXPANDABLE_HEADER}>
|
|
134
|
+
<${$.LABEL} ${e.LABEL.text}="${E}"></${$.LABEL}>
|
|
135
|
+
</${$.EXPANDABLE_HEADER}>
|
|
136
|
+
<${$.EXPANDABLE_CONTENT}>
|
|
137
|
+
|
|
138
|
+
${t}
|
|
139
|
+
|
|
140
|
+
</${$.EXPANDABLE_CONTENT}>
|
|
141
|
+
</${$.EXPANDABLE}>
|
|
142
|
+
`;
|
|
143
|
+
}
|
|
144
|
+
_GuColorPicker(E) {
|
|
145
|
+
return `
|
|
146
|
+
<${$.COLOR}
|
|
147
|
+
${e.COLOR.name}="${E}">
|
|
148
|
+
</${$.COLOR}>
|
|
149
|
+
`;
|
|
150
|
+
}
|
|
151
|
+
_GuFontFamily(E, t = "Select Font") {
|
|
152
|
+
return `
|
|
153
|
+
<${$.FONT_FAMILY_SELECT}
|
|
154
|
+
${e.FONT_FAMILY_SELECT.name}="${E}"
|
|
155
|
+
${e.FONT_FAMILY_SELECT.placeholder}="${t}">
|
|
156
|
+
</${$.FONT_FAMILY_SELECT}>
|
|
157
|
+
`;
|
|
158
|
+
}
|
|
159
|
+
_GuRadioButtons(E, t) {
|
|
160
|
+
const T = t.map((r) => `
|
|
161
|
+
<${$.RADIO_ITEM}
|
|
162
|
+
${e.RADIO_ITEM.text}="${r.text}"
|
|
163
|
+
${e.RADIO_ITEM.value}="${r.value}">
|
|
164
|
+
</${$.RADIO_ITEM}>
|
|
165
|
+
`).join("");
|
|
166
|
+
return `
|
|
167
|
+
<${$.RADIO_BUTTONS}
|
|
168
|
+
${e.RADIO_BUTTONS.name}="${E}">
|
|
169
|
+
${T}
|
|
170
|
+
</${$.RADIO_BUTTONS}>
|
|
171
|
+
`;
|
|
172
|
+
}
|
|
173
|
+
_GuCheckbox(E, t) {
|
|
174
|
+
return `
|
|
175
|
+
<${$.CHECKBOX}
|
|
176
|
+
${e.CHECKBOX.name}="${E}"
|
|
177
|
+
${e.CHECKBOX.caption}="${t}">
|
|
178
|
+
</${$.CHECKBOX}>
|
|
179
|
+
`;
|
|
180
|
+
}
|
|
181
|
+
}
|
|
182
|
+
export {
|
|
183
|
+
N as CommonControl
|
|
184
|
+
};
|
|
@@ -1,27 +1,33 @@
|
|
|
1
|
-
var
|
|
2
|
-
var
|
|
3
|
-
var
|
|
4
|
-
class
|
|
1
|
+
var d = Object.defineProperty;
|
|
2
|
+
var m = (t, e, n) => e in t ? d(t, e, { enumerable: !0, configurable: !0, writable: !0, value: n }) : t[e] = n;
|
|
3
|
+
var c = (t, e, n) => m(t, typeof e != "symbol" ? e + "" : e, n);
|
|
4
|
+
class C {
|
|
5
5
|
constructor() {
|
|
6
|
-
|
|
7
|
-
|
|
6
|
+
c(this, "selectedDynamicContent", null);
|
|
7
|
+
c(this, "dataSelectCallback", () => {
|
|
8
8
|
});
|
|
9
|
+
c(this, "closeDynamicContentHandler", null);
|
|
9
10
|
}
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
11
|
+
/**
|
|
12
|
+
* Opens the merge tags library modal
|
|
13
|
+
* @param dynamicContent - Currently selected dynamic content (if any)
|
|
14
|
+
* @param onDataSelectCallback - Callback invoked when user selects a merge tag
|
|
15
|
+
* @param position - Optional position data to place the modal
|
|
16
|
+
*/
|
|
17
|
+
openMergeTagsLibrary(e, n, l) {
|
|
18
|
+
this.closeDynamicContentHandler && (document.removeEventListener("dynamic-content:close", this.closeDynamicContentHandler), this.closeDynamicContentHandler = null), this.dataSelectCallback = n, this.selectedDynamicContent = e;
|
|
19
|
+
const o = {
|
|
20
|
+
attribute: e,
|
|
21
|
+
position: l
|
|
22
|
+
}, s = new CustomEvent("dynamic-content:open", {
|
|
23
|
+
detail: o
|
|
16
24
|
});
|
|
17
|
-
document.dispatchEvent(s)
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
};
|
|
22
|
-
document.addEventListener("dynamic-content:close", o);
|
|
25
|
+
document.dispatchEvent(s), this.closeDynamicContentHandler = (i) => {
|
|
26
|
+
const a = i.detail;
|
|
27
|
+
this.selectedDynamicContent = a, a.text && a.value && this.dataSelectCallback(a);
|
|
28
|
+
}, document.addEventListener("dynamic-content:close", this.closeDynamicContentHandler);
|
|
23
29
|
}
|
|
24
30
|
}
|
|
25
31
|
export {
|
|
26
|
-
|
|
32
|
+
C as ExternalMergeTagsLibrary
|
|
27
33
|
};
|
|
@@ -1,61 +1,156 @@
|
|
|
1
|
-
var
|
|
2
|
-
var g = (
|
|
3
|
-
var
|
|
4
|
-
import { dynamicContentToMergeTags as m } from "../../utils/genericUtil.js";
|
|
5
|
-
import { UIElement as
|
|
6
|
-
import { ExternalMergeTagsLibrary as
|
|
7
|
-
const
|
|
8
|
-
class p extends
|
|
9
|
-
registerUiElements(
|
|
10
|
-
|
|
1
|
+
var c = Object.defineProperty;
|
|
2
|
+
var g = (o, s, t) => s in o ? c(o, s, { enumerable: !0, configurable: !0, writable: !0, value: t }) : o[s] = t;
|
|
3
|
+
var r = (o, s, t) => g(o, typeof s != "symbol" ? s + "" : s, t);
|
|
4
|
+
import { mergeTagToDynamicContent as d, dynamicContentToMergeTags as m } from "../../utils/genericUtil.js";
|
|
5
|
+
import { UIElement as u, UIElementType as a, UEAttr as h, UIElementTagRegistry as T } from "../../node_modules/@stripoinc/ui-editor-extensions/dist/esm/index.js";
|
|
6
|
+
import { ExternalMergeTagsLibrary as y } from "./dynamic-content-modal.js";
|
|
7
|
+
const l = "external-dynamic-content-ui-element", C = "button-add-dynamic-content";
|
|
8
|
+
class p extends T {
|
|
9
|
+
registerUiElements(s) {
|
|
10
|
+
s[a.MERGETAGS] = l;
|
|
11
11
|
}
|
|
12
12
|
}
|
|
13
|
-
class
|
|
13
|
+
class b extends u {
|
|
14
14
|
constructor() {
|
|
15
15
|
super(...arguments);
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
16
|
+
r(this, "mergeTagsButton", null);
|
|
17
|
+
r(this, "mergeTagsLibrary", null);
|
|
18
|
+
r(this, "clickListener", null);
|
|
19
|
+
r(this, "lastClickedElement", null);
|
|
20
|
+
r(this, "lastClickedFrame", null);
|
|
21
|
+
r(this, "mousedownListener", null);
|
|
21
22
|
}
|
|
22
23
|
getId() {
|
|
23
|
-
return
|
|
24
|
+
return l;
|
|
24
25
|
}
|
|
25
|
-
onRender(
|
|
26
|
-
var
|
|
27
|
-
this.
|
|
26
|
+
onRender(t) {
|
|
27
|
+
var e;
|
|
28
|
+
this.mergeTagsButton = t.querySelector("#guido__btn-add-dynamic-content"), this.clickListener = this._onClick.bind(this), (e = this.mergeTagsButton) == null || e.addEventListener("click", this.clickListener), this._setupCoordinateTracking();
|
|
28
29
|
}
|
|
29
30
|
onDestroy() {
|
|
30
|
-
var
|
|
31
|
-
(
|
|
31
|
+
var t;
|
|
32
|
+
this.clickListener && ((t = this.mergeTagsButton) == null || t.removeEventListener("click", this.clickListener)), this._cleanupCoordinateTracking(), this.mergeTagsButton = null, this.clickListener = null, this.lastClickedElement = null, this.lastClickedFrame = null;
|
|
32
33
|
}
|
|
33
34
|
_onClick() {
|
|
34
35
|
this.openMergeTagLibrary();
|
|
35
36
|
}
|
|
37
|
+
/**
|
|
38
|
+
* Called when Stripo detects merge tag interactions
|
|
39
|
+
* This is the key method that receives notifications about merge tag clicks
|
|
40
|
+
* @param name - Attribute name (e.g., 'mergeTag')
|
|
41
|
+
* @param value - MergeTag object with label, value, selStart, selEnd, etc.
|
|
42
|
+
*/
|
|
43
|
+
onAttributeUpdated(t, e) {
|
|
44
|
+
if (t !== "mergeTag" || !(e != null && e.value))
|
|
45
|
+
return;
|
|
46
|
+
const n = d(e), i = this._getLastClickedPosition();
|
|
47
|
+
this.lastClickedElement = null, this.lastClickedFrame = null, this._openDynamicContentLibrary(n, i);
|
|
48
|
+
}
|
|
36
49
|
openMergeTagLibrary() {
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
50
|
+
const t = this._getButtonPosition(), e = { value: "", text: "" };
|
|
51
|
+
this._openDynamicContentLibrary(e, t);
|
|
52
|
+
}
|
|
53
|
+
/**
|
|
54
|
+
* Opens the dynamic content library for external apps
|
|
55
|
+
* Dispatches event with dynamic content data and position
|
|
56
|
+
*/
|
|
57
|
+
_openDynamicContentLibrary(t, e) {
|
|
58
|
+
this.mergeTagsLibrary || (this.mergeTagsLibrary = new y()), this.mergeTagsLibrary.openMergeTagsLibrary(
|
|
59
|
+
t,
|
|
60
|
+
(n) => {
|
|
61
|
+
n.text && n.value ? this.api.triggerValueChange(m([n])[0]) : this.api.triggerValueChange(null);
|
|
62
|
+
},
|
|
63
|
+
e
|
|
42
64
|
);
|
|
43
65
|
}
|
|
66
|
+
/**
|
|
67
|
+
* Gets the button's position on the screen
|
|
68
|
+
* Used to position the modal or anything else near the button
|
|
69
|
+
*/
|
|
70
|
+
_getButtonPosition() {
|
|
71
|
+
if (!this.mergeTagsButton)
|
|
72
|
+
return { x: 0, y: 0, width: 0, height: 0 };
|
|
73
|
+
const { x: t, y: e, width: n, height: i } = this.mergeTagsButton.getBoundingClientRect();
|
|
74
|
+
return { x: t, y: e, width: n, height: i };
|
|
75
|
+
}
|
|
76
|
+
/**
|
|
77
|
+
* Sets up coordinate tracking for merge tag clicks in the iframe
|
|
78
|
+
* Workaround from Stripo intercepting click events - tracks mousedown events instead
|
|
79
|
+
*/
|
|
80
|
+
_setupCoordinateTracking() {
|
|
81
|
+
var e;
|
|
82
|
+
const t = this._getEditorFrame();
|
|
83
|
+
(e = t == null ? void 0 : t.contentWindow) != null && e.document && (this.mousedownListener = (n) => {
|
|
84
|
+
const i = this._findMergeTagElement(n.target);
|
|
85
|
+
i && (this.lastClickedElement = i, this.lastClickedFrame = t);
|
|
86
|
+
}, t.contentWindow.document.addEventListener("mousedown", this.mousedownListener));
|
|
87
|
+
}
|
|
88
|
+
/**
|
|
89
|
+
* Gets the editor iframe element
|
|
90
|
+
*/
|
|
91
|
+
_getEditorFrame() {
|
|
92
|
+
var n;
|
|
93
|
+
const t = document.querySelector("ui-editor");
|
|
94
|
+
if (!(t != null && t.shadowRoot))
|
|
95
|
+
return null;
|
|
96
|
+
const e = t.shadowRoot.querySelector("iframe");
|
|
97
|
+
return (n = e == null ? void 0 : e.contentWindow) != null && n.document ? e : null;
|
|
98
|
+
}
|
|
99
|
+
/**
|
|
100
|
+
* Finds merge tag element in the element tree
|
|
101
|
+
*/
|
|
102
|
+
_findMergeTagElement(t) {
|
|
103
|
+
return t.closest(".target, .esd-merge-tag");
|
|
104
|
+
}
|
|
105
|
+
/**
|
|
106
|
+
* Gets the position of the last clicked element, calculated on-demand
|
|
107
|
+
* This ensures we always use the correct element's position even with rapid clicks
|
|
108
|
+
*/
|
|
109
|
+
_getLastClickedPosition() {
|
|
110
|
+
if (!(!this.lastClickedElement || !this.lastClickedFrame))
|
|
111
|
+
return this._calculateAbsolutePosition(this.lastClickedFrame, this.lastClickedElement);
|
|
112
|
+
}
|
|
113
|
+
/**
|
|
114
|
+
* Calculates absolute position of element relative to page
|
|
115
|
+
*/
|
|
116
|
+
_calculateAbsolutePosition(t, e) {
|
|
117
|
+
const n = t.getBoundingClientRect(), i = e.getBoundingClientRect();
|
|
118
|
+
return {
|
|
119
|
+
x: n.x + i.x,
|
|
120
|
+
y: n.y + i.y,
|
|
121
|
+
width: i.width,
|
|
122
|
+
height: i.height
|
|
123
|
+
};
|
|
124
|
+
}
|
|
125
|
+
/**
|
|
126
|
+
* Cleans up the coordinate tracking event listener
|
|
127
|
+
*/
|
|
128
|
+
_cleanupCoordinateTracking() {
|
|
129
|
+
var e;
|
|
130
|
+
if (!this.mousedownListener)
|
|
131
|
+
return;
|
|
132
|
+
const t = this._getEditorFrame();
|
|
133
|
+
(e = t == null ? void 0 : t.contentWindow) != null && e.document && t.contentWindow.document.removeEventListener("mousedown", this.mousedownListener), this.mousedownListener = null;
|
|
134
|
+
}
|
|
135
|
+
/**
|
|
136
|
+
* Returns the HTML template for the "Add Dynamic Content" button
|
|
137
|
+
* This button is placed in the merge tags selector UI
|
|
138
|
+
*/
|
|
44
139
|
getTemplate() {
|
|
45
140
|
return `
|
|
46
141
|
<div>
|
|
47
|
-
<${
|
|
142
|
+
<${a.BUTTON}
|
|
48
143
|
id="guido__btn-add-dynamic-content"
|
|
49
144
|
class="btn btn-primary"
|
|
50
|
-
${
|
|
51
|
-
<${
|
|
52
|
-
</${
|
|
145
|
+
${h.BUTTON.name}="${C}">
|
|
146
|
+
<${a.ICON} src="plus" class="icon icon-button color-primary">
|
|
147
|
+
</${a.ICON}>
|
|
53
148
|
${this.api.translate("Add Dynamic Content")}
|
|
54
|
-
</${
|
|
149
|
+
</${a.BUTTON}>
|
|
55
150
|
</div>`;
|
|
56
151
|
}
|
|
57
152
|
}
|
|
58
153
|
export {
|
|
59
154
|
p as DynamicContentTagRegistry,
|
|
60
|
-
|
|
155
|
+
b as DynamicContentUiElementExtension
|
|
61
156
|
};
|
package/dist/guido.css
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
[data-v-
|
|
1
|
+
.gap-16[data-v-6562e38c],.gap-16[data-v-1ccb6d4a]{gap:16px}[data-v-0502bceb] .in-button-v2__wrapper{line-height:0}[data-v-b5997368] .in-segments-wrapper .in-tooltip-wrapper__box{text-align:left}.version-history-item[data-v-ee4b9c3f]{flex-basis:200px}.version-history-wrapper[data-v-52a77eec]{gap:8px}.view-options-wrapper[data-v-d405ca59]{position:relative;display:inline-block}.new-tag[data-v-d405ca59]{position:absolute;top:-8px;right:-16px;z-index:10}[data-v-d405ca59] .guido__verion-history-view-option-selection-desktop svg,[data-v-d405ca59] .guido__verion-history-view-option-selection-mobile svg{margin:0 0 0 2px}[data-v-d405ca59] .in-segments-wrapper__button_selected,[data-v-d405ca59] .in-segments-wrapper__button_selected:hover{background-color:#dae1fb}[data-v-d405ca59] .in-tooltip-wrapper__icon{cursor:pointer}.view-options-wrapper[data-v-195ab6d4]{position:relative;display:inline-block}.new-tag[data-v-195ab6d4]{position:absolute;top:-8px;right:-16px;z-index:10}[data-v-195ab6d4] .guido__view-option-selection-desktop svg,[data-v-195ab6d4] .guido__view-option-selection-mobile svg{margin:0 0 0 2px}[data-v-195ab6d4] .in-segments-wrapper__button_selected,[data-v-195ab6d4] .in-segments-wrapper__button_selected:hover{background-color:#dae1fb}[data-v-195ab6d4] .in-tooltip-wrapper__icon{cursor:pointer}.guido-loading__wrapper[data-v-dced5582]{height:100%;top:75px}.guido-editor__wrapper[data-v-23c413c9],.guido-editor__container[data-v-23c413c9]{width:100%;height:calc(100vh - 128px)}.guido-editor__no-header[data-v-23c413c9]{height:calc(100vh - 75px)}[data-v-70835920] .in-breadcrumb-wrapper__links{cursor:pointer}.templates-wrapper[data-v-a86fc486]{gap:16px;grid-template-columns:repeat(3,1fr)}.templates-wrapper .template-wrapper[data-v-a86fc486]{cursor:pointer}.templates-wrapper .template-wrapper .template-container[data-v-a86fc486]{height:274px;padding:2px;transition:none}.templates-wrapper .template-wrapper .template-container.selected[data-v-a86fc486]{padding:1px}.templates-wrapper .template-wrapper .template-container .thumbnail[data-v-a86fc486]{object-fit:cover;transform:scale(1)}[data-v-dd57102d] .guido__verion-history-view-option-selection-desktop svg,[data-v-dd57102d] .guido__verion-history-view-option-selection-mobile svg{margin:0 0 0 2px}[data-v-dd57102d] .in-segments-wrapper__button_selected,[data-v-dd57102d] .in-segments-wrapper__button_selected:hover{background-color:#dae1fb}.error-list[data-v-7a09985c]{gap:16px}[data-v-c2adc57d] .in-progress-wrapper__progress p span:last-child{display:none!important}.desktop-preview-container[data-v-2dd60b0c],[data-v-2dd60b0c] .desktop-preview-container .in-container{min-height:720px!important;height:100%}.cropped-text[data-v-f20b3a9b]{width:220px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}[data-v-d3c52b44] .vueperslides__bullets,[data-v-a408dcea] .vueperslides__bullets{pointer-events:none!important}[data-v-a408dcea] .vueperslides__parallax-wrapper{height:110px!important}
|