@useinsider/guido 1.0.3-beta.1cd6abc → 1.0.3-beta.1d07a49

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (308) hide show
  1. package/README.md +22 -7
  2. package/dist/components/Guido.vue.js +11 -9
  3. package/dist/components/Guido.vue2.js +76 -70
  4. package/dist/components/organisms/header/LeftSlot.vue.js +1 -1
  5. package/dist/components/organisms/header/LeftSlot.vue2.js +15 -15
  6. package/dist/components/organisms/header/RightSlot.vue.js +10 -10
  7. package/dist/components/organisms/header/RightSlot.vue2.js +18 -18
  8. package/dist/components/organisms/onboarding/ItemsOnboarding.vue.js +21 -0
  9. package/dist/components/organisms/onboarding/ItemsOnboarding.vue2.js +99 -0
  10. package/dist/components/organisms/onboarding/NewVersionPopup.vue.js +9 -9
  11. package/dist/components/organisms/onboarding/NewVersionPopup.vue2.js +30 -17
  12. package/dist/components/organisms/onboarding/OnboardingWrapper.vue.js +12 -10
  13. package/dist/components/organisms/onboarding/OnboardingWrapper.vue2.js +23 -20
  14. package/dist/composables/useActionsApi.js +33 -24
  15. package/dist/composables/useBlocksConfig.js +21 -31
  16. package/dist/composables/useGuidoActions.js +19 -9
  17. package/dist/composables/useHtmlCompiler.js +15 -13
  18. package/dist/composables/useHtmlValidator.js +36 -35
  19. package/dist/composables/usePartner.js +10 -11
  20. package/dist/composables/useSave.js +11 -10
  21. package/dist/composables/useStripo.js +63 -55
  22. package/dist/composables/useTimerClone.js +75 -0
  23. package/dist/config/compiler/itemsCompilerRules.js +14 -0
  24. package/dist/config/compiler/unsubscribeCompilerRules.js +33 -28
  25. package/dist/config/migrator/index.js +7 -6
  26. package/dist/config/migrator/recommendationMigrator.js +293 -0
  27. package/dist/enums/date.js +6 -0
  28. package/dist/enums/defaults.js +6 -4
  29. package/dist/enums/extensions/recommendationBlock.js +2 -2
  30. package/dist/enums/onboarding.js +7 -2
  31. package/dist/enums/unsubscribe.js +27 -25
  32. package/dist/extensions/Blocks/Checkbox/block.js +5 -2
  33. package/dist/extensions/Blocks/Checkbox/control.js +15 -14
  34. package/dist/extensions/Blocks/Checkbox/extension.js +2 -2
  35. package/dist/extensions/Blocks/Checkbox/template.js +14 -9
  36. package/dist/extensions/Blocks/CouponBlock/extension.js +2 -2
  37. package/dist/extensions/Blocks/Items/block.js +67 -0
  38. package/dist/extensions/Blocks/Items/controls/button/link.js +68 -0
  39. package/dist/extensions/Blocks/Items/controls/cardComposition.js +193 -0
  40. package/dist/extensions/Blocks/Items/controls/image/link.js +68 -0
  41. package/dist/extensions/Blocks/Items/controls/index.js +217 -0
  42. package/dist/extensions/Blocks/Items/controls/name/trimming.js +70 -0
  43. package/dist/extensions/Blocks/Items/controls/price/currencyLocation.js +107 -0
  44. package/dist/extensions/Blocks/Items/controls/price/currencySymbol.js +123 -0
  45. package/dist/extensions/Blocks/Items/controls/price/formattedPrice.js +76 -0
  46. package/dist/extensions/Blocks/Items/controls/price/hideDiscount.js +61 -0
  47. package/dist/extensions/Blocks/Items/controls/settingsControl.js +312 -0
  48. package/dist/extensions/Blocks/Items/enums/controlEnums.js +5 -0
  49. package/dist/extensions/Blocks/Items/enums/productEnums.js +273 -0
  50. package/dist/extensions/Blocks/Items/enums/settingsEnums.js +76 -0
  51. package/dist/extensions/Blocks/Items/extension.js +19 -0
  52. package/dist/extensions/Blocks/Items/iconsRegistry.js +32 -0
  53. package/dist/extensions/Blocks/Items/items.css.js +23 -0
  54. package/dist/extensions/Blocks/Items/layouts/horizontal.html.js +62 -0
  55. package/dist/extensions/Blocks/Items/layouts/vertical.html.js +60 -0
  56. package/dist/extensions/Blocks/Items/settingsPanel.js +131 -0
  57. package/dist/extensions/Blocks/Items/store/items-block.js +71 -0
  58. package/dist/extensions/Blocks/Items/template.js +189 -0
  59. package/dist/extensions/Blocks/Items/utils/configBlockUtils.js +17 -0
  60. package/dist/extensions/Blocks/Items/utils/syncAttributeFromConfigBlock.js +28 -0
  61. package/dist/extensions/Blocks/Items/utils/syncAttributesFromConfigBlock.js +67 -0
  62. package/dist/extensions/Blocks/Items/utils/updateAttributes.js +44 -0
  63. package/dist/extensions/Blocks/RadioButton/block.js +5 -2
  64. package/dist/extensions/Blocks/RadioButton/control.js +18 -17
  65. package/dist/extensions/Blocks/RadioButton/template.js +18 -9
  66. package/dist/extensions/Blocks/Recommendation/block.js +6 -3
  67. package/dist/extensions/Blocks/Recommendation/cardCompositionControl.js +103 -0
  68. package/dist/extensions/Blocks/Recommendation/constants.js +5 -0
  69. package/dist/extensions/Blocks/Recommendation/control.js +69 -40
  70. package/dist/extensions/Blocks/Recommendation/controls/button/align.js +13 -0
  71. package/dist/extensions/Blocks/Recommendation/controls/button/border.js +13 -0
  72. package/dist/extensions/Blocks/Recommendation/controls/button/borderRadius.js +13 -0
  73. package/dist/extensions/Blocks/Recommendation/controls/button/color.js +13 -0
  74. package/dist/extensions/Blocks/Recommendation/controls/button/fitToContent.js +13 -0
  75. package/dist/extensions/Blocks/Recommendation/controls/button/fontFamily.js +13 -0
  76. package/dist/extensions/Blocks/Recommendation/controls/button/margins.js +13 -0
  77. package/dist/extensions/Blocks/Recommendation/controls/button/paddings.js +13 -0
  78. package/dist/extensions/Blocks/Recommendation/controls/button/text.js +13 -0
  79. package/dist/extensions/Blocks/Recommendation/controls/button/textSize.js +13 -0
  80. package/dist/extensions/Blocks/Recommendation/controls/button/textStyleAndFontColor.js +13 -0
  81. package/dist/extensions/Blocks/Recommendation/controls/image/margins.js +13 -0
  82. package/dist/extensions/Blocks/Recommendation/controls/image/size.js +13 -0
  83. package/dist/extensions/Blocks/Recommendation/controls/name/align.js +13 -0
  84. package/dist/extensions/Blocks/Recommendation/controls/name/background.js +13 -0
  85. package/dist/extensions/Blocks/Recommendation/controls/name/color.js +13 -0
  86. package/dist/extensions/Blocks/Recommendation/controls/name/fontFamily.js +13 -0
  87. package/dist/extensions/Blocks/Recommendation/controls/name/paddings.js +13 -0
  88. package/dist/extensions/Blocks/Recommendation/controls/name/size.js +13 -0
  89. package/dist/extensions/Blocks/Recommendation/controls/name/style.js +13 -0
  90. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/align.js +13 -0
  91. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/background.js +13 -0
  92. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/color.js +13 -0
  93. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/fontFamily.js +13 -0
  94. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/paddings.js +13 -0
  95. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/size.js +13 -0
  96. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/style.js +13 -0
  97. package/dist/extensions/Blocks/Recommendation/controls/price/align.js +13 -0
  98. package/dist/extensions/Blocks/Recommendation/controls/price/background.js +13 -0
  99. package/dist/extensions/Blocks/Recommendation/controls/price/color.js +13 -0
  100. package/dist/extensions/Blocks/Recommendation/controls/price/fontFamily.js +13 -0
  101. package/dist/extensions/Blocks/Recommendation/controls/price/paddings.js +13 -0
  102. package/dist/extensions/Blocks/Recommendation/controls/price/size.js +13 -0
  103. package/dist/extensions/Blocks/Recommendation/controls/price/style.js +13 -0
  104. package/dist/extensions/Blocks/Recommendation/extension.js +42 -7
  105. package/dist/extensions/Blocks/Recommendation/iconsRegistry.js +43 -43
  106. package/dist/extensions/Blocks/Recommendation/settingsPanel.js +107 -22
  107. package/dist/extensions/Blocks/Recommendation/store/recommendation.js +1 -1
  108. package/dist/extensions/Blocks/Recommendation/templates/blockTemplate.js +160 -0
  109. package/dist/extensions/Blocks/Recommendation/templates/migrationTemplate.js +152 -0
  110. package/dist/extensions/Blocks/Recommendation/templates/templateUtils.js +180 -0
  111. package/dist/extensions/Blocks/Unsubscribe/block.js +27 -27
  112. package/dist/extensions/Blocks/common-control.js +201 -55
  113. package/dist/extensions/Blocks/controlFactories.js +223 -0
  114. package/dist/extensions/DynamicContent/dynamic-content-modal.js +25 -19
  115. package/dist/extensions/DynamicContent/dynamic-content.js +128 -33
  116. package/dist/guido.css +1 -1
  117. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/esm/index.js +353 -101
  118. package/dist/node_modules/lodash-es/_DataView.js +6 -0
  119. package/dist/node_modules/lodash-es/_Promise.js +6 -0
  120. package/dist/node_modules/lodash-es/_Set.js +6 -0
  121. package/dist/node_modules/lodash-es/_SetCache.js +13 -0
  122. package/dist/node_modules/lodash-es/_WeakMap.js +6 -0
  123. package/dist/node_modules/lodash-es/_arrayFilter.js +10 -0
  124. package/dist/node_modules/lodash-es/_arrayLikeKeys.js +13 -12
  125. package/dist/node_modules/lodash-es/_arrayMap.js +8 -0
  126. package/dist/node_modules/lodash-es/_arrayPush.js +8 -0
  127. package/dist/node_modules/lodash-es/_arraySome.js +9 -0
  128. package/dist/node_modules/lodash-es/_baseEach.js +6 -0
  129. package/dist/node_modules/lodash-es/_baseFlatten.js +13 -0
  130. package/dist/node_modules/lodash-es/_baseForOwn.js +8 -0
  131. package/dist/node_modules/lodash-es/_baseGet.js +11 -0
  132. package/dist/node_modules/lodash-es/_baseGetAllKeys.js +9 -0
  133. package/dist/node_modules/lodash-es/_baseHasIn.js +6 -0
  134. package/dist/node_modules/lodash-es/_baseIsEqual.js +8 -0
  135. package/dist/node_modules/lodash-es/_baseIsEqualDeep.js +32 -0
  136. package/dist/node_modules/lodash-es/_baseIsMatch.js +29 -0
  137. package/dist/node_modules/lodash-es/_baseIteratee.js +11 -0
  138. package/dist/node_modules/lodash-es/_baseKeys.js +14 -0
  139. package/dist/node_modules/lodash-es/_baseMap.js +11 -0
  140. package/dist/node_modules/lodash-es/_baseMatches.js +12 -0
  141. package/dist/node_modules/lodash-es/_baseMatchesProperty.js +17 -0
  142. package/dist/node_modules/lodash-es/_baseProperty.js +8 -0
  143. package/dist/node_modules/lodash-es/_basePropertyDeep.js +9 -0
  144. package/dist/node_modules/lodash-es/_baseRange.js +9 -0
  145. package/dist/node_modules/lodash-es/_baseToString.js +18 -0
  146. package/dist/node_modules/lodash-es/_baseTrim.js +8 -0
  147. package/dist/node_modules/lodash-es/_cacheHas.js +6 -0
  148. package/dist/node_modules/lodash-es/_castPath.js +10 -0
  149. package/dist/node_modules/lodash-es/_createBaseEach.js +15 -0
  150. package/dist/node_modules/lodash-es/_createRange.js +11 -0
  151. package/dist/node_modules/lodash-es/_equalArrays.js +40 -0
  152. package/dist/node_modules/lodash-es/_equalByTag.js +45 -0
  153. package/dist/node_modules/lodash-es/_equalObjects.js +36 -0
  154. package/dist/node_modules/lodash-es/_getAllKeys.js +9 -0
  155. package/dist/node_modules/lodash-es/_getMatchData.js +12 -0
  156. package/dist/node_modules/lodash-es/_getSymbols.js +10 -0
  157. package/dist/node_modules/lodash-es/_getTag.js +28 -0
  158. package/dist/node_modules/lodash-es/_hasPath.js +19 -0
  159. package/dist/node_modules/lodash-es/_isFlattenable.js +10 -0
  160. package/dist/node_modules/lodash-es/_isKey.js +12 -0
  161. package/dist/node_modules/lodash-es/_isStrictComparable.js +7 -0
  162. package/dist/node_modules/lodash-es/_mapToArray.js +9 -0
  163. package/dist/node_modules/lodash-es/_matchesStrictComparable.js +8 -0
  164. package/dist/node_modules/lodash-es/_memoizeCapped.js +11 -0
  165. package/dist/node_modules/lodash-es/_nativeKeys.js +5 -0
  166. package/dist/node_modules/lodash-es/_setCacheAdd.js +7 -0
  167. package/dist/node_modules/lodash-es/_setCacheHas.js +6 -0
  168. package/dist/node_modules/lodash-es/_setToArray.js +9 -0
  169. package/dist/node_modules/lodash-es/_stringToPath.js +10 -0
  170. package/dist/node_modules/lodash-es/_toKey.js +10 -0
  171. package/dist/node_modules/lodash-es/_trimmedEndIndex.js +9 -0
  172. package/dist/node_modules/lodash-es/flatMap.js +8 -0
  173. package/dist/node_modules/lodash-es/get.js +8 -0
  174. package/dist/node_modules/lodash-es/hasIn.js +8 -0
  175. package/dist/node_modules/lodash-es/isSymbol.js +9 -0
  176. package/dist/node_modules/lodash-es/keys.js +9 -0
  177. package/dist/node_modules/lodash-es/keysIn.js +3 -3
  178. package/dist/node_modules/lodash-es/map.js +11 -0
  179. package/dist/node_modules/lodash-es/property.js +10 -0
  180. package/dist/node_modules/lodash-es/range.js +5 -0
  181. package/dist/node_modules/lodash-es/stubArray.js +6 -0
  182. package/dist/node_modules/lodash-es/toFinite.js +14 -0
  183. package/dist/node_modules/lodash-es/toNumber.js +22 -0
  184. package/dist/node_modules/lodash-es/toString.js +7 -0
  185. package/dist/package.json.js +1 -1
  186. package/dist/services/recommendationApi.js +13 -19
  187. package/dist/services/stripoApi.js +1 -1
  188. package/dist/src/@types/generic.d.ts +35 -6
  189. package/dist/src/components/Guido.vue.d.ts +4 -2
  190. package/dist/src/components/organisms/onboarding/ItemsOnboarding.vue.d.ts +2 -0
  191. package/dist/src/components/organisms/onboarding/NewVersionPopup.vue.d.ts +3 -1
  192. package/dist/src/components/organisms/onboarding/OnboardingWrapper.vue.d.ts +3 -1
  193. package/dist/src/composables/useActionsApi.d.ts +1 -0
  194. package/dist/src/composables/useBlocksConfig.d.ts +2 -2
  195. package/dist/src/composables/useGuidoActions.d.ts +9 -0
  196. package/dist/src/composables/usePartner.d.ts +0 -1
  197. package/dist/src/composables/useTimerClone.d.ts +6 -0
  198. package/dist/src/config/compiler/itemsCompilerRules.d.ts +2 -0
  199. package/dist/src/config/migrator/recommendationMigrator.d.ts +1 -0
  200. package/dist/src/enums/date.d.ts +4 -0
  201. package/dist/src/enums/defaults.d.ts +1 -1
  202. package/dist/src/enums/onboarding.d.ts +5 -0
  203. package/dist/src/extensions/Blocks/Checkbox/block.d.ts +1 -0
  204. package/dist/src/extensions/Blocks/Checkbox/template.d.ts +1 -1
  205. package/dist/src/extensions/Blocks/Items/block.d.ts +27 -0
  206. package/dist/src/extensions/Blocks/Items/controls/button/link.d.ts +14 -0
  207. package/dist/src/extensions/Blocks/Items/controls/cardComposition.d.ts +33 -0
  208. package/dist/src/extensions/Blocks/Items/controls/image/link.d.ts +14 -0
  209. package/dist/src/extensions/Blocks/Items/controls/index.d.ts +501 -0
  210. package/dist/src/extensions/Blocks/Items/controls/name/trimming.d.ts +14 -0
  211. package/dist/src/extensions/Blocks/Items/controls/price/currencyLocation.d.ts +19 -0
  212. package/dist/src/extensions/Blocks/Items/controls/price/currencySymbol.d.ts +21 -0
  213. package/dist/src/extensions/Blocks/Items/controls/price/formattedPrice.d.ts +14 -0
  214. package/dist/src/extensions/Blocks/Items/controls/price/hideDiscount.d.ts +13 -0
  215. package/dist/src/extensions/Blocks/Items/controls/settingsControl.d.ts +48 -0
  216. package/dist/src/extensions/Blocks/Items/enums/controlEnums.d.ts +61 -0
  217. package/dist/src/extensions/Blocks/Items/enums/productEnums.d.ts +162 -0
  218. package/dist/src/extensions/Blocks/Items/enums/settingsEnums.d.ts +49 -0
  219. package/dist/src/extensions/Blocks/Items/extension.d.ts +2 -0
  220. package/dist/src/extensions/Blocks/Items/iconsRegistry.d.ts +4 -0
  221. package/dist/src/extensions/Blocks/Items/settingsPanel.d.ts +4 -0
  222. package/dist/src/extensions/Blocks/Items/store/items-block.d.ts +41 -0
  223. package/dist/src/extensions/Blocks/Items/template.d.ts +24 -0
  224. package/dist/src/extensions/Blocks/Items/utils/configBlockUtils.d.ts +23 -0
  225. package/dist/src/extensions/Blocks/Items/utils/syncAttributeFromConfigBlock.d.ts +32 -0
  226. package/dist/src/extensions/Blocks/Items/utils/syncAttributesFromConfigBlock.d.ts +44 -0
  227. package/dist/src/extensions/Blocks/Items/utils/updateAttributes.d.ts +8 -0
  228. package/dist/src/extensions/Blocks/RadioButton/block.d.ts +1 -0
  229. package/dist/src/extensions/Blocks/RadioButton/template.d.ts +1 -1
  230. package/dist/src/extensions/Blocks/Recommendation/block.d.ts +1 -0
  231. package/dist/src/extensions/Blocks/Recommendation/cardCompositionControl.d.ts +28 -0
  232. package/dist/src/extensions/Blocks/Recommendation/constants.d.ts +51 -0
  233. package/dist/src/extensions/Blocks/Recommendation/control.d.ts +6 -0
  234. package/dist/src/extensions/Blocks/Recommendation/controls/button/align.d.ts +5 -0
  235. package/dist/src/extensions/Blocks/Recommendation/controls/button/border.d.ts +5 -0
  236. package/dist/src/extensions/Blocks/Recommendation/controls/button/borderRadius.d.ts +5 -0
  237. package/dist/src/extensions/Blocks/Recommendation/controls/button/color.d.ts +5 -0
  238. package/dist/src/extensions/Blocks/Recommendation/controls/button/fitToContent.d.ts +5 -0
  239. package/dist/src/extensions/Blocks/Recommendation/controls/button/fontFamily.d.ts +5 -0
  240. package/dist/src/extensions/Blocks/Recommendation/controls/button/margins.d.ts +5 -0
  241. package/dist/src/extensions/Blocks/Recommendation/controls/button/paddings.d.ts +5 -0
  242. package/dist/src/extensions/Blocks/Recommendation/controls/button/text.d.ts +5 -0
  243. package/dist/src/extensions/Blocks/Recommendation/controls/button/textSize.d.ts +5 -0
  244. package/dist/src/extensions/Blocks/Recommendation/controls/button/textStyleAndFontColor.d.ts +5 -0
  245. package/dist/src/extensions/Blocks/Recommendation/controls/image/margins.d.ts +5 -0
  246. package/dist/src/extensions/Blocks/Recommendation/controls/image/size.d.ts +5 -0
  247. package/dist/src/extensions/Blocks/Recommendation/controls/name/align.d.ts +5 -0
  248. package/dist/src/extensions/Blocks/Recommendation/controls/name/background.d.ts +5 -0
  249. package/dist/src/extensions/Blocks/Recommendation/controls/name/color.d.ts +5 -0
  250. package/dist/src/extensions/Blocks/Recommendation/controls/name/fontFamily.d.ts +5 -0
  251. package/dist/src/extensions/Blocks/Recommendation/controls/name/paddings.d.ts +5 -0
  252. package/dist/src/extensions/Blocks/Recommendation/controls/name/size.d.ts +5 -0
  253. package/dist/src/extensions/Blocks/Recommendation/controls/name/style.d.ts +5 -0
  254. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/align.d.ts +5 -0
  255. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/background.d.ts +5 -0
  256. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/color.d.ts +5 -0
  257. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/fontFamily.d.ts +5 -0
  258. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/paddings.d.ts +5 -0
  259. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/size.d.ts +5 -0
  260. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/style.d.ts +5 -0
  261. package/dist/src/extensions/Blocks/Recommendation/controls/price/align.d.ts +5 -0
  262. package/dist/src/extensions/Blocks/Recommendation/controls/price/background.d.ts +5 -0
  263. package/dist/src/extensions/Blocks/Recommendation/controls/price/color.d.ts +5 -0
  264. package/dist/src/extensions/Blocks/Recommendation/controls/price/fontFamily.d.ts +5 -0
  265. package/dist/src/extensions/Blocks/Recommendation/controls/price/paddings.d.ts +5 -0
  266. package/dist/src/extensions/Blocks/Recommendation/controls/price/size.d.ts +5 -0
  267. package/dist/src/extensions/Blocks/Recommendation/controls/price/style.d.ts +5 -0
  268. package/dist/src/extensions/Blocks/Recommendation/store/recommendation.d.ts +1 -1
  269. package/dist/src/extensions/Blocks/Recommendation/templates/blockTemplate.d.ts +16 -0
  270. package/dist/src/extensions/Blocks/Recommendation/templates/migrationTemplate.d.ts +16 -0
  271. package/dist/src/extensions/Blocks/Recommendation/templates/templateUtils.d.ts +44 -0
  272. package/dist/src/extensions/Blocks/common-control.d.ts +65 -7
  273. package/dist/src/extensions/Blocks/controlFactories.d.ts +312 -0
  274. package/dist/src/extensions/DynamicContent/dynamic-content-modal.d.ts +9 -2
  275. package/dist/src/extensions/DynamicContent/dynamic-content.d.ts +52 -2
  276. package/dist/src/stores/config.d.ts +6 -2
  277. package/dist/src/stores/dynamic-content.d.ts +3 -3
  278. package/dist/src/stores/editor.d.ts +1 -1
  279. package/dist/src/stores/onboarding.d.ts +335 -1
  280. package/dist/src/stores/preview.d.ts +1 -1
  281. package/dist/src/stores/recommendation.d.ts +1 -1
  282. package/dist/src/stores/save-as-template.d.ts +1 -1
  283. package/dist/src/stores/toaster.d.ts +1 -1
  284. package/dist/src/stores/unsubscribe.d.ts +1 -1
  285. package/dist/src/stores/version-history.d.ts +1 -1
  286. package/dist/src/utils/dateUtil.d.ts +21 -0
  287. package/dist/src/utils/environmentUtil.d.ts +5 -0
  288. package/dist/src/utils/genericUtil.d.ts +1 -0
  289. package/dist/src/utils/pairProductVariables.d.ts +7 -0
  290. package/dist/static/styles/components/narrow-panel.css.js +10 -0
  291. package/dist/static/styles/customEditorStyle.css.js +5 -0
  292. package/dist/stores/config.js +5 -5
  293. package/dist/stores/dynamic-content.js +2 -2
  294. package/dist/stores/editor.js +1 -1
  295. package/dist/stores/onboarding.js +44 -36
  296. package/dist/stores/preview.js +1 -1
  297. package/dist/stores/recommendation.js +3 -3
  298. package/dist/stores/save-as-template.js +2 -2
  299. package/dist/stores/toaster.js +1 -1
  300. package/dist/stores/unsubscribe.js +1 -1
  301. package/dist/stores/version-history.js +4 -4
  302. package/dist/utils/dateUtil.js +24 -3
  303. package/dist/utils/environmentUtil.js +4 -0
  304. package/dist/utils/genericUtil.js +18 -8
  305. package/dist/utils/pairProductVariables.js +136 -0
  306. package/package.json +4 -4
  307. package/dist/extensions/Blocks/Recommendation/template.js +0 -200
  308. package/dist/src/extensions/Blocks/Recommendation/template.d.ts +0 -6
@@ -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
- .gap-16[data-v-6562e38c],.gap-16[data-v-1ccb6d4a]{gap:16px}[data-v-244e7935] .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-e8d51dec],.guido-editor__container[data-v-e8d51dec]{width:100%;height:calc(100vh - 128px)}.guido-editor__no-header[data-v-e8d51dec]{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}
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-dd1a237a] .vueperslides__bullets{pointer-events:none!important}[data-v-dd1a237a] .vueperslides__parallax-wrapper{height:110px!important}[data-v-a408dcea] .vueperslides__bullets{pointer-events:none!important}[data-v-a408dcea] .vueperslides__parallax-wrapper{height:110px!important}