@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.
Files changed (325) hide show
  1. package/README.md +144 -3
  2. package/dist/components/Guido.vue.js +11 -9
  3. package/dist/components/Guido.vue2.js +73 -65
  4. package/dist/components/organisms/extensions/recommendation/FilterItem.vue.js +28 -0
  5. package/dist/components/organisms/extensions/recommendation/FilterItem.vue2.js +38 -0
  6. package/dist/components/organisms/extensions/recommendation/FilterSelectionDrawer.vue.js +17 -0
  7. package/dist/components/organisms/extensions/recommendation/FilterSelectionDrawer.vue2.js +37 -0
  8. package/dist/components/organisms/extensions/recommendation/Filters.vue.js +20 -0
  9. package/dist/components/organisms/extensions/recommendation/Filters.vue2.js +44 -0
  10. package/dist/components/organisms/extensions/recommendation/LogicAdapter.vue.js +17 -0
  11. package/dist/components/organisms/extensions/recommendation/LogicAdapter.vue2.js +27 -0
  12. package/dist/components/organisms/header/LeftSlot.vue.js +1 -1
  13. package/dist/components/organisms/header/LeftSlot.vue2.js +16 -15
  14. package/dist/components/organisms/header/RightSlot.vue.js +11 -11
  15. package/dist/components/organisms/header/RightSlot.vue2.js +23 -22
  16. package/dist/components/organisms/onboarding/NewVersionPopup.vue.js +9 -9
  17. package/dist/components/organisms/onboarding/NewVersionPopup.vue2.js +30 -17
  18. package/dist/components/organisms/onboarding/OnboardingWrapper.vue.js +12 -10
  19. package/dist/components/organisms/onboarding/OnboardingWrapper.vue2.js +19 -18
  20. package/dist/components/organisms/unsubscribe/UnsubscribeTypeSelection.vue.js +1 -1
  21. package/dist/components/organisms/unsubscribe/UnsubscribeTypeSelection.vue2.js +15 -14
  22. package/dist/composables/useBlocksConfig.js +49 -0
  23. package/dist/composables/useGuidoActions.js +19 -9
  24. package/dist/composables/useStripo.js +48 -52
  25. package/dist/config/compiler/unsubscribeCompilerRules.js +41 -33
  26. package/dist/config/migrator/couponBlockMigrator.js +67 -0
  27. package/dist/config/migrator/index.js +7 -5
  28. package/dist/config/migrator/recommendationMigrator.js +293 -0
  29. package/dist/config/migrator/unsubscribeMigrator.js +61 -49
  30. package/dist/enums/date.js +6 -0
  31. package/dist/enums/defaults.js +16 -8
  32. package/dist/enums/extensions/recommendationBlock.js +80 -0
  33. package/dist/enums/onboarding.js +2 -1
  34. package/dist/enums/unsubscribe.js +29 -23
  35. package/dist/extensions/Blocks/Checkbox/control.js +55 -53
  36. package/dist/extensions/Blocks/Checkbox/extension.js +2 -2
  37. package/dist/extensions/Blocks/CouponBlock/block.js +33 -0
  38. package/dist/extensions/Blocks/CouponBlock/extension.js +8 -0
  39. package/dist/extensions/Blocks/CouponBlock/iconsRegistry.js +33 -0
  40. package/dist/extensions/Blocks/CouponBlock/settingsPanel.js +24 -0
  41. package/dist/extensions/Blocks/CouponBlock/template.js +18 -0
  42. package/dist/extensions/Blocks/RadioButton/control.js +44 -42
  43. package/dist/extensions/Blocks/RadioButton/template.js +6 -6
  44. package/dist/extensions/Blocks/Recommendation/block.js +30 -0
  45. package/dist/extensions/Blocks/Recommendation/cardCompositionControl.js +103 -0
  46. package/dist/extensions/Blocks/Recommendation/constants.js +5 -0
  47. package/dist/extensions/Blocks/Recommendation/control.js +306 -0
  48. package/dist/extensions/Blocks/Recommendation/controls/button/align.js +13 -0
  49. package/dist/extensions/Blocks/Recommendation/controls/button/border.js +13 -0
  50. package/dist/extensions/Blocks/Recommendation/controls/button/borderRadius.js +13 -0
  51. package/dist/extensions/Blocks/Recommendation/controls/button/color.js +13 -0
  52. package/dist/extensions/Blocks/Recommendation/controls/button/fitToContent.js +13 -0
  53. package/dist/extensions/Blocks/Recommendation/controls/button/fontFamily.js +13 -0
  54. package/dist/extensions/Blocks/Recommendation/controls/button/margins.js +13 -0
  55. package/dist/extensions/Blocks/Recommendation/controls/button/paddings.js +13 -0
  56. package/dist/extensions/Blocks/Recommendation/controls/button/text.js +13 -0
  57. package/dist/extensions/Blocks/Recommendation/controls/button/textSize.js +13 -0
  58. package/dist/extensions/Blocks/Recommendation/controls/button/textStyleAndFontColor.js +13 -0
  59. package/dist/extensions/Blocks/Recommendation/controls/image/margins.js +13 -0
  60. package/dist/extensions/Blocks/Recommendation/controls/image/size.js +13 -0
  61. package/dist/extensions/Blocks/Recommendation/controls/name/align.js +13 -0
  62. package/dist/extensions/Blocks/Recommendation/controls/name/background.js +13 -0
  63. package/dist/extensions/Blocks/Recommendation/controls/name/color.js +13 -0
  64. package/dist/extensions/Blocks/Recommendation/controls/name/fontFamily.js +13 -0
  65. package/dist/extensions/Blocks/Recommendation/controls/name/paddings.js +13 -0
  66. package/dist/extensions/Blocks/Recommendation/controls/name/size.js +13 -0
  67. package/dist/extensions/Blocks/Recommendation/controls/name/style.js +13 -0
  68. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/align.js +13 -0
  69. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/background.js +13 -0
  70. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/color.js +13 -0
  71. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/fontFamily.js +13 -0
  72. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/paddings.js +13 -0
  73. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/size.js +13 -0
  74. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/style.js +13 -0
  75. package/dist/extensions/Blocks/Recommendation/controls/price/align.js +13 -0
  76. package/dist/extensions/Blocks/Recommendation/controls/price/background.js +13 -0
  77. package/dist/extensions/Blocks/Recommendation/controls/price/color.js +13 -0
  78. package/dist/extensions/Blocks/Recommendation/controls/price/fontFamily.js +13 -0
  79. package/dist/extensions/Blocks/Recommendation/controls/price/paddings.js +13 -0
  80. package/dist/extensions/Blocks/Recommendation/controls/price/size.js +13 -0
  81. package/dist/extensions/Blocks/Recommendation/controls/price/style.js +13 -0
  82. package/dist/extensions/Blocks/Recommendation/extension.js +45 -0
  83. package/dist/extensions/Blocks/Recommendation/iconsRegistry.js +51 -0
  84. package/dist/extensions/Blocks/Recommendation/recommendation.css.js +19 -0
  85. package/dist/extensions/Blocks/Recommendation/settingsPanel.js +117 -0
  86. package/dist/extensions/Blocks/Recommendation/store/recommendation.js +266 -0
  87. package/dist/extensions/Blocks/Recommendation/templates/blockTemplate.js +160 -0
  88. package/dist/extensions/Blocks/Recommendation/templates/migrationTemplate.js +152 -0
  89. package/dist/extensions/Blocks/Recommendation/templates/templateUtils.js +180 -0
  90. package/dist/extensions/Blocks/Recommendation/utils/filterUtil.js +28 -0
  91. package/dist/extensions/Blocks/common-control.js +184 -0
  92. package/dist/extensions/DynamicContent/dynamic-content-modal.js +25 -19
  93. package/dist/extensions/DynamicContent/dynamic-content.js +128 -33
  94. package/dist/guido.css +1 -1
  95. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/esm/index.js +311 -93
  96. package/dist/package.json.js +7 -0
  97. package/dist/services/recommendationApi.js +43 -0
  98. package/dist/services/stripoApi.js +1 -1
  99. package/dist/src/@types/generic.d.ts +98 -0
  100. package/dist/{components → src/components}/Guido.vue.d.ts +4 -2
  101. package/dist/src/components/organisms/extensions/recommendation/FilterItem.vue.d.ts +19 -0
  102. package/dist/src/components/organisms/extensions/recommendation/LogicAdapter.vue.d.ts +16 -0
  103. package/dist/src/components/organisms/onboarding/NewVersionPopup.vue.d.ts +4 -0
  104. package/dist/src/components/organisms/onboarding/OnboardingWrapper.vue.d.ts +4 -0
  105. package/dist/src/composables/useBlocksConfig.d.ts +11 -0
  106. package/dist/{composables → src/composables}/useGuidoActions.d.ts +9 -0
  107. package/dist/src/config/migrator/couponBlockMigrator.d.ts +1 -0
  108. package/dist/src/config/migrator/recommendationMigrator.d.ts +1 -0
  109. package/dist/src/enums/date.d.ts +4 -0
  110. package/dist/src/enums/extensions/recommendationBlock.d.ts +16 -0
  111. package/dist/src/enums/onboarding.d.ts +2 -0
  112. package/dist/{enums → src/enums}/unsubscribe.d.ts +4 -0
  113. package/dist/src/extensions/Blocks/CouponBlock/block.d.ts +12 -0
  114. package/dist/src/extensions/Blocks/CouponBlock/iconsRegistry.d.ts +4 -0
  115. package/dist/src/extensions/Blocks/CouponBlock/settingsPanel.d.ts +4 -0
  116. package/dist/src/extensions/Blocks/CouponBlock/template.d.ts +3 -0
  117. package/dist/src/extensions/Blocks/Recommendation/block.d.ts +11 -0
  118. package/dist/src/extensions/Blocks/Recommendation/cardCompositionControl.d.ts +28 -0
  119. package/dist/src/extensions/Blocks/Recommendation/constants.d.ts +51 -0
  120. package/dist/src/extensions/Blocks/Recommendation/control.d.ts +35 -0
  121. package/dist/src/extensions/Blocks/Recommendation/controls/button/align.d.ts +5 -0
  122. package/dist/src/extensions/Blocks/Recommendation/controls/button/border.d.ts +5 -0
  123. package/dist/src/extensions/Blocks/Recommendation/controls/button/borderRadius.d.ts +5 -0
  124. package/dist/src/extensions/Blocks/Recommendation/controls/button/color.d.ts +5 -0
  125. package/dist/src/extensions/Blocks/Recommendation/controls/button/fitToContent.d.ts +5 -0
  126. package/dist/src/extensions/Blocks/Recommendation/controls/button/fontFamily.d.ts +5 -0
  127. package/dist/src/extensions/Blocks/Recommendation/controls/button/margins.d.ts +5 -0
  128. package/dist/src/extensions/Blocks/Recommendation/controls/button/paddings.d.ts +5 -0
  129. package/dist/src/extensions/Blocks/Recommendation/controls/button/text.d.ts +5 -0
  130. package/dist/src/extensions/Blocks/Recommendation/controls/button/textSize.d.ts +5 -0
  131. package/dist/src/extensions/Blocks/Recommendation/controls/button/textStyleAndFontColor.d.ts +5 -0
  132. package/dist/src/extensions/Blocks/Recommendation/controls/image/margins.d.ts +5 -0
  133. package/dist/src/extensions/Blocks/Recommendation/controls/image/size.d.ts +5 -0
  134. package/dist/src/extensions/Blocks/Recommendation/controls/name/align.d.ts +5 -0
  135. package/dist/src/extensions/Blocks/Recommendation/controls/name/background.d.ts +5 -0
  136. package/dist/src/extensions/Blocks/Recommendation/controls/name/color.d.ts +5 -0
  137. package/dist/src/extensions/Blocks/Recommendation/controls/name/fontFamily.d.ts +5 -0
  138. package/dist/src/extensions/Blocks/Recommendation/controls/name/paddings.d.ts +5 -0
  139. package/dist/src/extensions/Blocks/Recommendation/controls/name/size.d.ts +5 -0
  140. package/dist/src/extensions/Blocks/Recommendation/controls/name/style.d.ts +5 -0
  141. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/align.d.ts +5 -0
  142. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/background.d.ts +5 -0
  143. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/color.d.ts +5 -0
  144. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/fontFamily.d.ts +5 -0
  145. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/paddings.d.ts +5 -0
  146. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/size.d.ts +5 -0
  147. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/style.d.ts +5 -0
  148. package/dist/src/extensions/Blocks/Recommendation/controls/price/align.d.ts +5 -0
  149. package/dist/src/extensions/Blocks/Recommendation/controls/price/background.d.ts +5 -0
  150. package/dist/src/extensions/Blocks/Recommendation/controls/price/color.d.ts +5 -0
  151. package/dist/src/extensions/Blocks/Recommendation/controls/price/fontFamily.d.ts +5 -0
  152. package/dist/src/extensions/Blocks/Recommendation/controls/price/paddings.d.ts +5 -0
  153. package/dist/src/extensions/Blocks/Recommendation/controls/price/size.d.ts +5 -0
  154. package/dist/src/extensions/Blocks/Recommendation/controls/price/style.d.ts +5 -0
  155. package/dist/src/extensions/Blocks/Recommendation/iconsRegistry.d.ts +4 -0
  156. package/dist/src/extensions/Blocks/Recommendation/store/recommendation.d.ts +555 -0
  157. package/dist/src/extensions/Blocks/Recommendation/templates/blockTemplate.d.ts +16 -0
  158. package/dist/src/extensions/Blocks/Recommendation/templates/migrationTemplate.d.ts +16 -0
  159. package/dist/src/extensions/Blocks/Recommendation/templates/templateUtils.d.ts +44 -0
  160. package/dist/src/extensions/Blocks/Recommendation/utils/filterUtil.d.ts +7 -0
  161. package/dist/src/extensions/Blocks/_Boilerplate/extension.d.ts +2 -0
  162. package/dist/src/extensions/Blocks/_Boilerplate/settingsPanel.d.ts +4 -0
  163. package/dist/src/extensions/Blocks/common-control.d.ts +87 -0
  164. package/dist/src/extensions/DynamicContent/dynamic-content-modal.d.ts +13 -0
  165. package/dist/src/extensions/DynamicContent/dynamic-content.d.ts +66 -0
  166. package/dist/src/extensions/DynamicContent/extension.d.ts +2 -0
  167. package/dist/src/mock/api/validator.d.ts +2 -0
  168. package/dist/src/services/recommendationApi.d.ts +6 -0
  169. package/dist/src/stores/config.d.ts +104 -0
  170. package/dist/{stores → src/stores}/dynamic-content.d.ts +3 -3
  171. package/dist/{stores → src/stores}/editor.d.ts +22 -1
  172. package/dist/{stores → src/stores}/onboarding.d.ts +1 -1
  173. package/dist/{stores → src/stores}/preview.d.ts +1 -1
  174. package/dist/{stores → src/stores}/recommendation.d.ts +1 -1
  175. package/dist/{stores → src/stores}/save-as-template.d.ts +1 -1
  176. package/dist/{stores → src/stores}/toaster.d.ts +1 -1
  177. package/dist/{stores → src/stores}/unsubscribe.d.ts +1 -1
  178. package/dist/{stores → src/stores}/version-history.d.ts +1 -1
  179. package/dist/src/utils/dateUtil.d.ts +22 -0
  180. package/dist/src/utils/environmentUtil.d.ts +5 -0
  181. package/dist/{utils → src/utils}/genericUtil.d.ts +2 -0
  182. package/dist/static/styles/components/narrow-panel.css.js +10 -0
  183. package/dist/static/styles/customEditorStyle.css.js +5 -0
  184. package/dist/stores/config.js +17 -0
  185. package/dist/stores/dynamic-content.js +2 -2
  186. package/dist/stores/editor.js +3 -2
  187. package/dist/stores/onboarding.js +27 -27
  188. package/dist/stores/preview.js +1 -1
  189. package/dist/stores/recommendation.js +3 -3
  190. package/dist/stores/save-as-template.js +2 -2
  191. package/dist/stores/toaster.js +1 -1
  192. package/dist/stores/unsubscribe.js +1 -1
  193. package/dist/stores/version-history.js +4 -4
  194. package/dist/utils/dateUtil.js +24 -3
  195. package/dist/utils/environmentUtil.js +4 -0
  196. package/dist/utils/genericUtil.js +23 -11
  197. package/package.json +9 -4
  198. package/dist/@types/generic.d.ts +0 -57
  199. package/dist/enums/onboarding.d.ts +0 -1
  200. package/dist/extensions/DynamicContent/dynamic-content-modal.d.ts +0 -6
  201. package/dist/extensions/DynamicContent/dynamic-content.d.ts +0 -16
  202. package/dist/utils/dateUtil.d.ts +0 -1
  203. package/dist/{@types → src/@types}/events.d.ts +0 -0
  204. package/dist/{@types → src/@types}/save-as-template.d.ts +0 -0
  205. package/dist/{App.vue.d.ts → src/App.vue.d.ts} +0 -0
  206. package/dist/{components → src/components}/organisms/LoadingWrapper.vue.d.ts +0 -0
  207. package/dist/{components → src/components}/organisms/base/Toaster.vue.d.ts +0 -0
  208. package/dist/{components → src/components}/organisms/email-preview/PreviewContainer.vue.d.ts +0 -0
  209. package/dist/{components → src/components}/organisms/email-preview/amp/AmpErrorModal.vue.d.ts +0 -0
  210. package/dist/{components → src/components}/organisms/email-preview/amp/AmpToggle.vue.d.ts +0 -0
  211. package/dist/{components → src/components}/organisms/email-preview/desktop-preview/DesktopPreview.vue.d.ts +0 -0
  212. package/dist/{components → src/components}/organisms/email-preview/desktop-preview/EmailHeaderInfo.vue.d.ts +0 -0
  213. package/dist/{components → src/components}/organisms/email-preview/desktop-preview/EmailSizeIndicator.vue.d.ts +0 -0
  214. package/dist/{components → src/components}/organisms/email-preview/mobile-preview/ContentView.vue.d.ts +0 -0
  215. package/dist/{components → src/components}/organisms/email-preview/mobile-preview/InboxView.vue.d.ts +0 -0
  216. package/dist/{components → src/components}/organisms/email-preview/mobile-preview/MobilePreview.vue.d.ts +0 -0
  217. package/dist/{components/organisms/header/LeftSlot.vue.d.ts → src/components/organisms/extensions/recommendation/FilterSelectionDrawer.vue.d.ts} +0 -0
  218. package/dist/{components/organisms/header/MiddleSlot.vue.d.ts → src/components/organisms/extensions/recommendation/Filters.vue.d.ts} +0 -0
  219. package/dist/{components → src/components}/organisms/header/HeaderWrapper.vue.d.ts +0 -0
  220. package/dist/{components/organisms/header/ViewOptions.vue.d.ts → src/components/organisms/header/LeftSlot.vue.d.ts} +0 -0
  221. package/dist/{components/organisms/header/version-history/RestoreButton.vue.d.ts → src/components/organisms/header/MiddleSlot.vue.d.ts} +0 -0
  222. package/dist/{components → src/components}/organisms/header/RightSlot.vue.d.ts +0 -0
  223. package/dist/{components/organisms/header/version-history → src/components/organisms/header}/ViewOptions.vue.d.ts +0 -0
  224. package/dist/{components/organisms/onboarding/AMPOnboarding.vue.d.ts → src/components/organisms/header/version-history/RestoreButton.vue.d.ts} +0 -0
  225. package/dist/{components → src/components}/organisms/header/version-history/VersionHistory.vue.d.ts +0 -0
  226. package/dist/{components → src/components}/organisms/header/version-history/VersionHistoryItem.vue.d.ts +0 -0
  227. package/dist/{components/organisms/onboarding/GenericOnboarding.vue.d.ts → src/components/organisms/header/version-history/ViewOptions.vue.d.ts} +0 -0
  228. package/dist/{components/organisms/onboarding/NewVersionPopup.vue.d.ts → src/components/organisms/onboarding/AMPOnboarding.vue.d.ts} +0 -0
  229. package/dist/{components/organisms/onboarding/OnboardingWrapper.vue.d.ts → src/components/organisms/onboarding/GenericOnboarding.vue.d.ts} +0 -0
  230. package/dist/{components → src/components}/organisms/onboarding/TextBlockOnboarding.vue.d.ts +0 -0
  231. package/dist/{components → src/components}/organisms/onboarding/VersionHistoryOnboarding.vue.d.ts +0 -0
  232. package/dist/{components → src/components}/organisms/save-as-template/SaveAsTemplateDrawer.vue.d.ts +0 -0
  233. package/dist/{components → src/components}/organisms/unsubscribe/UnsubscribeBreadcrumb.vue.d.ts +0 -0
  234. package/dist/{components → src/components}/organisms/unsubscribe/UnsubscribePageSelection.vue.d.ts +0 -0
  235. package/dist/{components → src/components}/organisms/unsubscribe/UnsubscribeTypeSelection.vue.d.ts +0 -0
  236. package/dist/{components → src/components}/organisms/unsubscribe/UnsubscribeWrapper.vue.d.ts +0 -0
  237. package/dist/{components → src/components}/wrappers/WpDrawer.vue.d.ts +0 -0
  238. package/dist/{components → src/components}/wrappers/WpModal.vue.d.ts +1 -1
  239. /package/dist/{composables → src/composables}/useActionsApi.d.ts +0 -0
  240. /package/dist/{composables → src/composables}/useApiExample.d.ts +0 -0
  241. /package/dist/{composables → src/composables}/useCodeEditorApi.d.ts +0 -0
  242. /package/dist/{composables → src/composables}/useConfig.d.ts +0 -0
  243. /package/dist/{composables → src/composables}/useCustomInterfaceAppearance.d.ts +0 -0
  244. /package/dist/{composables → src/composables}/useDebounce.d.ts +0 -0
  245. /package/dist/{composables → src/composables}/useExport.d.ts +0 -0
  246. /package/dist/{composables → src/composables}/useHtmlCompiler.d.ts +0 -0
  247. /package/dist/{composables → src/composables}/useHtmlValidator.d.ts +0 -0
  248. /package/dist/{composables → src/composables}/useHttp.d.ts +0 -0
  249. /package/dist/{composables → src/composables}/usePartner.d.ts +0 -0
  250. /package/dist/{composables → src/composables}/usePreviewMode.d.ts +0 -0
  251. /package/dist/{composables → src/composables}/useProvideInject.d.ts +0 -0
  252. /package/dist/{composables → src/composables}/useRecommendation.d.ts +0 -0
  253. /package/dist/{composables → src/composables}/useResponsivePreview.d.ts +0 -0
  254. /package/dist/{composables → src/composables}/useSave.d.ts +0 -0
  255. /package/dist/{composables → src/composables}/useStripo.d.ts +0 -0
  256. /package/dist/{composables → src/composables}/useStripoEventHandler.d.ts +0 -0
  257. /package/dist/{composables → src/composables}/useToaster.d.ts +0 -0
  258. /package/dist/{composables → src/composables}/useTranslations.d.ts +0 -0
  259. /package/dist/{composables → src/composables}/useValidation.d.ts +0 -0
  260. /package/dist/{composables → src/composables}/useVersionHistoryApi.d.ts +0 -0
  261. /package/dist/{composables → src/composables}/validators/saveAsTemplate.d.ts +0 -0
  262. /package/dist/{config → src/config}/compiler/htmlCompilerRules.d.ts +0 -0
  263. /package/dist/{config → src/config}/compiler/outlookCompilerRules.d.ts +0 -0
  264. /package/dist/{config → src/config}/compiler/recommendationCompilerRules.d.ts +0 -0
  265. /package/dist/{config → src/config}/compiler/socialCompilerRules.d.ts +0 -0
  266. /package/dist/{config → src/config}/compiler/unsubscribeCompilerRules.d.ts +0 -0
  267. /package/dist/{config → src/config}/migrator/checkboxMigrator.d.ts +0 -0
  268. /package/dist/{config → src/config}/migrator/index.d.ts +0 -0
  269. /package/dist/{config → src/config}/migrator/radioButtonMigrator.d.ts +0 -0
  270. /package/dist/{config → src/config}/migrator/unsubscribeMigrator.d.ts +0 -0
  271. /package/dist/{enums → src/enums}/defaults.d.ts +0 -0
  272. /package/dist/{enums → src/enums}/displayConditions.d.ts +0 -0
  273. /package/dist/{enums → src/enums}/html-validator.d.ts +0 -0
  274. /package/dist/{enums → src/enums}/preview.d.ts +0 -0
  275. /package/dist/{enums → src/enums}/recommendation.d.ts +0 -0
  276. /package/dist/{enums → src/enums}/toaster.d.ts +0 -0
  277. /package/dist/{extensions → src/extensions}/Blocks/Checkbox/block.d.ts +0 -0
  278. /package/dist/{extensions → src/extensions}/Blocks/Checkbox/control.d.ts +0 -0
  279. /package/dist/{extensions → src/extensions}/Blocks/Checkbox/extension.d.ts +0 -0
  280. /package/dist/{extensions → src/extensions}/Blocks/Checkbox/iconsRegistry.d.ts +0 -0
  281. /package/dist/{extensions → src/extensions}/Blocks/Checkbox/settingsPanel.d.ts +0 -0
  282. /package/dist/{extensions → src/extensions}/Blocks/Checkbox/template.d.ts +0 -0
  283. /package/dist/{extensions/Blocks/RadioButton → src/extensions/Blocks/CouponBlock}/extension.d.ts +0 -0
  284. /package/dist/{extensions → src/extensions}/Blocks/RadioButton/block.d.ts +0 -0
  285. /package/dist/{extensions → src/extensions}/Blocks/RadioButton/control.d.ts +0 -0
  286. /package/dist/{extensions/Blocks/Unsubscribe → src/extensions/Blocks/RadioButton}/extension.d.ts +0 -0
  287. /package/dist/{extensions → src/extensions}/Blocks/RadioButton/iconsRegistry.d.ts +0 -0
  288. /package/dist/{extensions → src/extensions}/Blocks/RadioButton/settingsPanel.d.ts +0 -0
  289. /package/dist/{extensions → src/extensions}/Blocks/RadioButton/template.d.ts +0 -0
  290. /package/dist/{extensions/Blocks/_Boilerplate → src/extensions/Blocks/Recommendation}/extension.d.ts +0 -0
  291. /package/dist/{extensions/Blocks/Unsubscribe → src/extensions/Blocks/Recommendation}/settingsPanel.d.ts +0 -0
  292. /package/dist/{extensions → src/extensions}/Blocks/Unsubscribe/block.d.ts +0 -0
  293. /package/dist/{extensions → src/extensions}/Blocks/Unsubscribe/control.d.ts +0 -0
  294. /package/dist/{extensions → src/extensions}/Blocks/Unsubscribe/elements/preview.d.ts +0 -0
  295. /package/dist/{extensions/DynamicContent → src/extensions/Blocks/Unsubscribe}/extension.d.ts +0 -0
  296. /package/dist/{extensions → src/extensions}/Blocks/Unsubscribe/iconsRegistry.d.ts +0 -0
  297. /package/dist/{extensions/Blocks/_Boilerplate → src/extensions/Blocks/Unsubscribe}/settingsPanel.d.ts +0 -0
  298. /package/dist/{extensions → src/extensions}/Blocks/Unsubscribe/tagRegistry.d.ts +0 -0
  299. /package/dist/{extensions → src/extensions}/Blocks/Unsubscribe/template.d.ts +0 -0
  300. /package/dist/{extensions → src/extensions}/Blocks/Unsubscribe/utils/constants.d.ts +0 -0
  301. /package/dist/{extensions → src/extensions}/Blocks/Unsubscribe/utils/utils.d.ts +0 -0
  302. /package/dist/{extensions → src/extensions}/Blocks/_Boilerplate/block.d.ts +0 -0
  303. /package/dist/{extensions → src/extensions}/Blocks/_Boilerplate/control.d.ts +0 -0
  304. /package/dist/{extensions → src/extensions}/Blocks/_Boilerplate/iconsRegistry.d.ts +0 -0
  305. /package/dist/{extensions → src/extensions}/Blocks/_Boilerplate/template.d.ts +0 -0
  306. /package/dist/{library.d.ts → src/library.d.ts} +0 -0
  307. /package/dist/{main.d.ts → src/main.d.ts} +0 -0
  308. /package/dist/{mock → src/mock}/api/auth.d.ts +0 -0
  309. /package/dist/{mock → src/mock}/api/custom-fonts.d.ts +0 -0
  310. /package/dist/{mock → src/mock}/api/default-template.d.ts +0 -0
  311. /package/dist/{mock/api/template-library.d.ts → src/mock/api/recommendation.d.ts} +0 -0
  312. /package/dist/{mock/api/unsubscribe.d.ts → src/mock/api/template-library.d.ts} +0 -0
  313. /package/dist/{mock/api/user-modal-state.d.ts → src/mock/api/unsubscribe.d.ts} +0 -0
  314. /package/dist/{mock/api/validator.d.ts → src/mock/api/user-modal-state.d.ts} +0 -0
  315. /package/dist/{mock → src/mock}/browser.d.ts +0 -0
  316. /package/dist/{mock → src/mock}/handlers.d.ts +0 -0
  317. /package/dist/{services → src/services}/onboardingApi.d.ts +0 -0
  318. /package/dist/{services → src/services}/stripoApi.d.ts +0 -0
  319. /package/dist/{services → src/services}/templateLibraryApi.d.ts +0 -0
  320. /package/dist/{services → src/services}/unsubscribeApi.d.ts +0 -0
  321. /package/dist/{utils → src/utils}/arrayUtil.d.ts +0 -0
  322. /package/dist/{utils → src/utils}/base64.d.ts +0 -0
  323. /package/dist/{utils → src/utils}/htmlCompiler.d.ts +0 -0
  324. /package/dist/{utils → src/utils}/templatePreparation.d.ts +0 -0
  325. /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 i = Object.defineProperty;
2
- var d = (t, e, n) => e in t ? i(t, e, { enumerable: !0, configurable: !0, writable: !0, value: n }) : t[e] = n;
3
- var a = (t, e, n) => d(t, typeof e != "symbol" ? e + "" : e, n);
4
- class y {
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
- a(this, "selectedDynamicContent", null);
7
- a(this, "dataSelectCallback", () => {
6
+ c(this, "selectedDynamicContent", null);
7
+ c(this, "dataSelectCallback", () => {
8
8
  });
9
+ c(this, "closeDynamicContentHandler", null);
9
10
  }
10
- openMergeTagsLibrary(e, n) {
11
- this.dataSelectCallback = n, this.selectedDynamicContent = e;
12
- const s = new CustomEvent("dynamic-content:open", {
13
- detail: {
14
- attribute: e
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
- const o = (l) => {
19
- const c = l.detail;
20
- this.selectedDynamicContent = c, c.text && c.value && this.dataSelectCallback(c), document.removeEventListener("dynamic-content:close", o);
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
- y as ExternalMergeTagsLibrary
32
+ C as ExternalMergeTagsLibrary
27
33
  };
@@ -1,61 +1,156 @@
1
- var o = Object.defineProperty;
2
- var g = (n, t, e) => t in n ? o(n, t, { enumerable: !0, configurable: !0, writable: !0, value: e }) : n[t] = e;
3
- var i = (n, t, e) => g(n, typeof t != "symbol" ? t + "" : t, e);
4
- import { dynamicContentToMergeTags as m } from "../../utils/genericUtil.js";
5
- import { UIElement as c, UIElementType as r, UEAttr as l, UIElementTagRegistry as d } from "../../node_modules/@stripoinc/ui-editor-extensions/dist/esm/index.js";
6
- import { ExternalMergeTagsLibrary as T } from "./dynamic-content-modal.js";
7
- const a = "external-dynamic-content-ui-element", y = "button-add-dynamic-content";
8
- class p extends d {
9
- registerUiElements(t) {
10
- t[r.MERGETAGS] = a;
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 C extends c {
13
+ class b extends u {
14
14
  constructor() {
15
15
  super(...arguments);
16
- i(this, "mergeTagsButton", null);
17
- i(this, "listener", () => {
18
- });
19
- i(this, "mergeTagsLibrary", null);
20
- i(this, "selectedDynamicContent", { value: "", text: "" });
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 a;
24
+ return l;
24
25
  }
25
- onRender(e) {
26
- var s;
27
- this.listener = this._onClick.bind(this), this.mergeTagsButton = e.querySelector("#guido__btn-add-dynamic-content"), (s = this.mergeTagsButton) == null || s.addEventListener("click", this.listener);
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 e;
31
- (e = this.mergeTagsButton) == null || e.removeEventListener("click", this.listener);
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
- this.mergeTagsLibrary || (this.mergeTagsLibrary = new T()), this.mergeTagsLibrary.openMergeTagsLibrary(
38
- this.selectedDynamicContent,
39
- (e) => {
40
- this.api.onValueChanged(m([e])[0]);
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
- <${r.BUTTON}
142
+ <${a.BUTTON}
48
143
  id="guido__btn-add-dynamic-content"
49
144
  class="btn btn-primary"
50
- ${l.BUTTON.name}="${y}">
51
- <${r.ICON} src="plus" class="icon icon-button color-primary">
52
- </${r.ICON}>
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
- </${r.BUTTON}>
149
+ </${a.BUTTON}>
55
150
  </div>`;
56
151
  }
57
152
  }
58
153
  export {
59
154
  p as DynamicContentTagRegistry,
60
- C as DynamicContentUiElementExtension
155
+ b as DynamicContentUiElementExtension
61
156
  };
package/dist/guido.css CHANGED
@@ -1 +1 @@
1
- [data-v-2c168944] .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-85d64228],.guido-editor__container[data-v-85d64228]{width:100%;height:calc(100vh - 128px)}.guido-editor__no-header[data-v-85d64228]{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-d89d9362] .guido__verion-history-view-option-selection-desktop svg,[data-v-d89d9362] .guido__verion-history-view-option-selection-mobile svg{margin:0 0 0 2px}[data-v-d89d9362] .in-segments-wrapper__button_selected,[data-v-d89d9362] .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}
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}