@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,59 +1,67 @@
1
- import { useOnboardingApi as t } from "../services/onboardingApi.js";
2
- import { defineStore as s } from "pinia";
3
- const e = () => ({
1
+ import { useOnboardingApi as r } from "../services/onboardingApi.js";
2
+ import { defineStore as e } from "pinia";
3
+ const t = () => ({
4
4
  cardIndex: 0,
5
5
  isActive: !1,
6
6
  config: []
7
7
  }), a = () => ({
8
8
  onboardings: {
9
- newVersionPopup: e(),
10
- genericOnboarding: e(),
11
- textBlockOnboarding: e(),
12
- versionHistoryOnboarding: e(),
13
- ampOnboarding: e()
9
+ newVersionPopup: t(),
10
+ genericOnboarding: t(),
11
+ textBlockOnboarding: t(),
12
+ versionHistoryOnboarding: t(),
13
+ ampOnboarding: t(),
14
+ itemsOnboarding: t()
14
15
  },
15
16
  userModalState: {},
16
17
  isFetched: !1
17
- }), g = s("onboarding", {
18
+ }), c = e("guidoOnboarding", {
18
19
  state: () => a(),
19
20
  getters: {
20
- getOnboarding: (n) => (o) => n.onboardings[o],
21
- isActive: (n) => (o) => n.onboardings[o].isActive,
22
- getCurrentCard: (n) => (o) => {
23
- const i = n.onboardings[o];
24
- return i.config[i.cardIndex];
21
+ getOnboarding: (n) => (i) => n.onboardings[i],
22
+ isActive: (n) => (i) => n.onboardings[i].isActive,
23
+ getCurrentCard: (n) => (i) => {
24
+ const o = n.onboardings[i];
25
+ return o.config[o.cardIndex];
25
26
  },
26
27
  getGenericCurrentCard: (n) => {
27
- const { genericOnboarding: o } = n.onboardings;
28
- return o.config[o.cardIndex];
28
+ const { genericOnboarding: i } = n.onboardings;
29
+ return i.config[i.cardIndex];
29
30
  },
30
31
  getTextBlockCurrentCard: (n) => {
31
- const { textBlockOnboarding: o } = n.onboardings;
32
- return o.config[o.cardIndex];
32
+ const { textBlockOnboarding: i } = n.onboardings;
33
+ return i.config[i.cardIndex];
33
34
  },
34
35
  getVersionHistoryCurrentCard: (n) => {
35
- const { versionHistoryOnboarding: o } = n.onboardings;
36
- return o.config[o.cardIndex];
36
+ const { versionHistoryOnboarding: i } = n.onboardings;
37
+ return i.config[i.cardIndex];
37
38
  },
38
39
  getAmpCurrentCard: (n) => {
39
- const { ampOnboarding: o } = n.onboardings;
40
- return o.config[o.cardIndex];
40
+ const { ampOnboarding: i } = n.onboardings;
41
+ return i.config[i.cardIndex];
41
42
  },
42
- shouldShowOnboarding: (n) => (o) => {
43
- const i = n.userModalState.Guido;
44
- return o === "newVersionPopup" && (i != null && i.genericOnboarding) ? !1 : i ? !i[o] : !0;
43
+ getItemsCurrentCard: (n) => {
44
+ const { itemsOnboarding: i } = n.onboardings;
45
+ return i.config[i.cardIndex];
46
+ },
47
+ shouldShowOnboarding: (n) => (i) => {
48
+ const o = n.userModalState.Guido;
49
+ return i === "newVersionPopup" && (o != null && o.genericOnboarding) ? !1 : o ? !o[i] : !0;
45
50
  }
46
51
  },
47
52
  actions: {
48
53
  closeOtherOnboardings(n) {
49
- Object.keys(this.onboardings).forEach((o) => {
50
- const i = o;
51
- i !== n && this.onboardings[i].isActive && (this.onboardings[i].isActive = !1, this.onboardings[i].cardIndex = 0, this.onboardings[i].config = []);
54
+ Object.keys(this.onboardings).forEach((i) => {
55
+ const o = i;
56
+ o !== n && this.onboardings[o].isActive && (this.onboardings[o].isActive = !1, this.onboardings[o].cardIndex = 0, this.onboardings[o].config = []);
52
57
  });
53
58
  },
54
59
  start(n) {
55
60
  this.closeOtherOnboardings(n), this.onboardings[n].cardIndex = 0, this.onboardings[n].isActive = !0;
56
61
  },
62
+ startOnboarding(n) {
63
+ this.shouldShowOnboarding(n) && !this.isActive(n) && this.start(n);
64
+ },
57
65
  async close(n) {
58
66
  await this.setUserModalState(n, "true", "Guido"), this.onboardings[n].isActive = !1, this.onboardings[n].cardIndex = 0, this.onboardings[n].config = [];
59
67
  },
@@ -63,8 +71,8 @@ const e = () => ({
63
71
  previous(n) {
64
72
  this.onboardings[n].cardIndex > 0 && this.onboardings[n].cardIndex--;
65
73
  },
66
- setConfig(n, o) {
67
- this.onboardings[n].config = o ?? [], this.onboardings[n].cardIndex >= this.onboardings[n].config.length && (this.onboardings[n].cardIndex = 0);
74
+ setConfig(n, i) {
75
+ this.onboardings[n].config = i ?? [], this.onboardings[n].cardIndex >= this.onboardings[n].config.length && (this.onboardings[n].cardIndex = 0);
68
76
  },
69
77
  async onDiscoverNowClicked() {
70
78
  await this.setUserModalState("newVersionPopup", "true", "Guido"), await this.setUserModalState("genericOnboarding", "true", "Guido"), this.start("genericOnboarding");
@@ -81,15 +89,15 @@ const e = () => ({
81
89
  async fetchUserModalState() {
82
90
  if (this.isFetched)
83
91
  return;
84
- const { fetchUserModalState: n } = t(), o = await n();
85
- this.userModalState = o, this.isFetched = !0;
92
+ const { fetchUserModalState: n } = r(), i = await n();
93
+ this.userModalState = i, this.isFetched = !0;
86
94
  },
87
- async setUserModalState(n, o, i) {
88
- const { setUserModalState: r } = t();
89
- await r(n, o, i), this.isFetched = !1, await this.fetchUserModalState();
95
+ async setUserModalState(n, i, o) {
96
+ const { setUserModalState: s } = r();
97
+ await s(n, i, o), this.isFetched = !1, await this.fetchUserModalState();
90
98
  }
91
99
  }
92
100
  });
93
101
  export {
94
- g as useOnboardingStore
102
+ c as useOnboardingStore
95
103
  };
@@ -6,7 +6,7 @@ const s = () => ({
6
6
  templateHtml: "",
7
7
  isLoaded: !1,
8
8
  isAMPErrorModalVisible: !1
9
- }), a = e("preview", {
9
+ }), a = e("guidoPreview", {
10
10
  state: () => s(),
11
11
  getters: {
12
12
  isAMPModeEnabled: (t) => t.emailFormat === "AMP",
@@ -1,8 +1,8 @@
1
1
  import { defineStore as e } from "pinia";
2
- const t = () => ({
2
+ const o = () => ({
3
3
  recommendationConfigs: []
4
- }), n = e("recommendation", {
5
- state: () => t()
4
+ }), n = e("guidoRecommendation", {
5
+ state: () => o()
6
6
  });
7
7
  export {
8
8
  n as useRecommendationStore
@@ -17,7 +17,7 @@ const r = () => ({
17
17
  editor: 2,
18
18
  message: 1
19
19
  }
20
- }), n = i("saveAsTemplate", {
20
+ }), g = i("guidoSaveAsTemplate", {
21
21
  state: () => r(),
22
22
  getters: {
23
23
  getTemplateName: (e) => e.templateName.trim(),
@@ -44,5 +44,5 @@ const r = () => ({
44
44
  }
45
45
  });
46
46
  export {
47
- n as useSaveAsTemplateStore
47
+ g as useSaveAsTemplateStore
48
48
  };
@@ -8,7 +8,7 @@ const a = () => ({
8
8
  withIcon: !0,
9
9
  withoutLeftMargin: !1,
10
10
  actionButton: void 0
11
- }), u = i("toaster", {
11
+ }), u = i("guidoToaster", {
12
12
  state: () => a(),
13
13
  getters: {
14
14
  shouldAutoHide: (t) => t.status && !!t.text
@@ -12,7 +12,7 @@ const p = () => ({
12
12
  typeSelectionDrawerStatus: !1,
13
13
  isGlobalUnsubscribeDisabled: !1,
14
14
  isSubscriptionPreferencesCenterDisabled: !1
15
- }), g = d("unsubscribe", {
15
+ }), g = d("guidoUnsubscribe", {
16
16
  state: () => p(),
17
17
  getters: {
18
18
  getSelectedCollection: (e) => i[e.selectedCollectionType],
@@ -5,13 +5,13 @@ const e = () => ({
5
5
  description: "",
6
6
  authorId: "",
7
7
  authorName: ""
8
- }), r = () => ({
8
+ }), i = () => ({
9
9
  previousPatch: e(),
10
10
  currentPatch: e(),
11
11
  nextPatch: e(),
12
12
  editorVisualMode: "desktop"
13
- }), o = a("versionHistory", {
14
- state: () => r(),
13
+ }), r = a("guidoVersionHistory", {
14
+ state: () => i(),
15
15
  getters: {
16
16
  hasPreviousPatch: (t) => !!t.previousPatch.id,
17
17
  hasCurrentPatch: (t) => !!t.currentPatch.id,
@@ -24,5 +24,5 @@ const e = () => ({
24
24
  }
25
25
  });
26
26
  export {
27
- o as useVersionHistoryStore
27
+ r as useVersionHistoryStore
28
28
  };
@@ -1,4 +1,19 @@
1
- const o = (t) => {
1
+ import { DEFAULT_LOCALE as r, DEFAULT as a, DEFAULT_TZ as c } from "../enums/date.js";
2
+ const m = (t) => t ? t instanceof Date ? t : typeof t == "string" ? t.length === 10 ? new Date(Number(t) * 1e3) : new Date(t) : typeof t == "number" ? t.toString().length === 10 ? new Date(t * 1e3) : new Date(t) : /* @__PURE__ */ new Date() : /* @__PURE__ */ new Date(), s = () => {
3
+ const t = window.l10n;
4
+ return (t == null ? void 0 : t.locale) === a ? r : (t == null ? void 0 : t.locale) || r;
5
+ }, u = new Intl.DateTimeFormat().resolvedOptions().timeZone, f = () => {
6
+ const t = window.l10n;
7
+ return (t == null ? void 0 : t.timezone) || u || c;
8
+ }, D = (t, e = s(), n = f()) => {
9
+ const o = {
10
+ year: "numeric",
11
+ month: "2-digit",
12
+ day: "2-digit",
13
+ timeZone: n
14
+ }, i = m(t);
15
+ return new Intl.DateTimeFormat(e, o).format(i);
16
+ }, T = (t) => {
2
17
  if (!t)
3
18
  return "";
4
19
  const e = new Date(t);
@@ -10,7 +25,13 @@ const o = (t) => {
10
25
  second: "2-digit",
11
26
  hour12: !1
12
27
  }).format(e);
13
- };
28
+ }, h = (t) => t ? Math.floor(Date.now() / 1e3) >= t : !1;
14
29
  export {
15
- o as formatPatchDate
30
+ m as convertToDateObject,
31
+ T as formatPatchDate,
32
+ D as formatShortDate,
33
+ h as isAfterDate,
34
+ u as localTz,
35
+ s as locale,
36
+ f as timezone
16
37
  };
@@ -0,0 +1,4 @@
1
+ const n = () => window.location.hostname.split(".")[2];
2
+ export {
3
+ n as getEnvironmentPrefix
4
+ };
@@ -1,15 +1,25 @@
1
- const o = (e) => e.map((a) => a.format ? {
1
+ const f = (t) => {
2
+ const n = t.value.match(/\{\{([^}]+)\}\}/)[1].split("|").map((l) => l.trim()), [r] = n, e = {
3
+ text: t.label,
4
+ value: r || ""
5
+ };
6
+ if (n.length >= 2) {
7
+ const [, l, o] = n, c = l.includes("=") ? { key: l.split("=")[0].trim(), value: l.split("=")[1].trim() } : null;
8
+ c ? e.format = c : o || (e.fallback = l), o && (e.fallback = o);
9
+ }
10
+ return e;
11
+ }, s = (t) => t.map((a) => a.format ? {
2
12
  label: `${a.text} | ${a.format.key}=${a.format.value}`,
3
13
  value: `{{${a.value}|${a.format.key}=${a.format.value}}}`
4
14
  } : {
5
15
  label: a.fallback ? `${a.text} | ${a.fallback}` : a.text,
6
16
  value: a.fallback ? `{{${a.value}|${a.fallback}}}` : `{{${a.value}}}`
7
- }), f = () => {
8
- var e;
9
- return ((e = document.head.querySelector('meta[name="csrf-token"]')) == null ? void 0 : e.getAttribute("content")) ?? "";
10
- }, $ = (e = "", a = {}, n = !1) => Object.entries(a).reduce((l, [t, r]) => n && (r === "" || r === null || r === void 0) ? l.replace(`&${t}={${t}}`, "") : l.replace(`{${t}}`, String(r)), e);
17
+ }), u = () => {
18
+ var t;
19
+ return ((t = document.head.querySelector('meta[name="csrf-token"]')) == null ? void 0 : t.getAttribute("content")) ?? "";
20
+ };
11
21
  export {
12
- o as dynamicContentToMergeTags,
13
- f as getCsrfToken,
14
- $ as replaceString
22
+ s as dynamicContentToMergeTags,
23
+ u as getCsrfToken,
24
+ f as mergeTagToDynamicContent
15
25
  };
@@ -0,0 +1,136 @@
1
+ import { productPairs as w } from "../extensions/Blocks/Items/enums/productEnums.js";
2
+ function M(H) {
3
+ const m = H.replaceAll("{%", "<!--{%").replaceAll("%}", "%}-->"), $ = new DOMParser().parseFromString(m, "text/html"), C = w.PAIRS_FOR_EXTENSION;
4
+ Object.entries(C).forEach(([n, d]) => {
5
+ $.querySelectorAll(".ins-product-td").forEach((o) => {
6
+ const h = o.getAttribute("data-number") || "1", _ = o.getAttribute("data-type") || "CART_ITEMS";
7
+ o.querySelectorAll(`[product-attr="${n}"]`).forEach((e) => {
8
+ var y;
9
+ const b = e.getAttribute("data-type") || _, u = e.getAttribute("data-number") || h, p = d[b];
10
+ if (p)
11
+ switch (n) {
12
+ case "imageSrc": {
13
+ let t = null, i = null;
14
+ if (e.tagName === "IMG" ? (t = e, i = t.closest("a")) : (t = e.querySelector("img"), i = e.querySelector("a") || e.closest("a")), !t)
15
+ break;
16
+ const c = p.DEFAULT, a = p.ATTR;
17
+ if (c && t.src) {
18
+ const r = t.src;
19
+ c.some((l) => {
20
+ const s = l.split("/").pop() || "", F = r.split("/").pop() || "";
21
+ return r.includes(l) || r.includes(s) || F === s;
22
+ }) && (t.src = `{{${a}_${u}}}`);
23
+ }
24
+ if (i) {
25
+ const r = (y = C.itemLink) == null ? void 0 : y[b];
26
+ if (r) {
27
+ const f = r.HREF, l = r.DEFAULT_HREF || "#!", s = i.href;
28
+ (s === "#" || s === "" || s.endsWith("#!") || s.endsWith(l) || s === `${window.location.href}${l}` || !s || s === window.location.href) && (i.href = `{{${f}_${u}}}`);
29
+ }
30
+ }
31
+ break;
32
+ }
33
+ case "name": {
34
+ const t = p, i = t.ATTR, c = t.DEFAULT_HREF || "#!", a = t.HREF;
35
+ e.textContent && (e.textContent = `{{${i}_${u}}}`);
36
+ const r = e.closest("a") || (e.tagName === "A" ? e : null);
37
+ if (r && a) {
38
+ const f = r.href, l = `${window.location.href}${c}`;
39
+ (f === l || f.endsWith(c)) && (r.href = `{{${a}_${u}}}`);
40
+ }
41
+ break;
42
+ }
43
+ case "price":
44
+ case "originalPrice": {
45
+ const t = p, c = e.getAttribute("data-formated") === "true", a = e.getAttribute("data-curency") || "before", r = c ? t.PRICE_FORMATTED : t.PRICE, f = t.CURRENCY;
46
+ let l = `{{${r}_${u}}}`;
47
+ if (f) {
48
+ const s = `{{${f}_${u}}}`;
49
+ l = a === "after" ? `${l} ${s}` : `${s} ${l}`;
50
+ }
51
+ e.textContent = l;
52
+ break;
53
+ }
54
+ case "quantity": {
55
+ const t = p, i = t.ATTR, c = t.DEFAULT;
56
+ e.textContent && e.textContent.trim() === c && (e.textContent = `{{${i}_${u}}}`);
57
+ break;
58
+ }
59
+ case "button": {
60
+ const t = p, i = t.HREF, c = t.DEFAULT_HREF || "#!", a = e.tagName === "A" ? e : e.querySelector("a");
61
+ if (a) {
62
+ const r = a.href || "", f = `${window.location.href}${c}`;
63
+ (r === "" || r === "#" || r === f || r.endsWith(c) || r.endsWith("#!") || r === window.location.href) && (a.href = `{{${i}_${u}}}`);
64
+ }
65
+ break;
66
+ }
67
+ case "itemLink": {
68
+ const t = p, i = t.HREF, c = t.DEFAULT_HREF || "#!", a = e;
69
+ if (a.href) {
70
+ const r = a.href, f = `${window.location.href}${c}`;
71
+ (r === f || r.endsWith(c)) && (a.href = `{{${i}_${u}}}`);
72
+ }
73
+ break;
74
+ }
75
+ default: {
76
+ if ("ATTR" in p) {
77
+ const t = p.ATTR;
78
+ e.textContent && (e.textContent = `{{${t}_${u}}}`);
79
+ }
80
+ break;
81
+ }
82
+ }
83
+ });
84
+ });
85
+ });
86
+ const S = $.querySelectorAll(".ins-product-td"), R = [];
87
+ S.forEach((n) => {
88
+ const d = n.getAttribute("data-type") || "CART_ITEMS", A = n.getAttribute("data-number") || "1", o = n.getAttribute("data-nodup"), h = n.outerHTML;
89
+ R.push({
90
+ element: n,
91
+ outerHtml: h,
92
+ type: d,
93
+ number: A,
94
+ nodup: o || void 0
95
+ });
96
+ });
97
+ let E = $.body.innerHTML;
98
+ R.reverse().forEach(({ outerHtml: n, type: d, number: A }) => {
99
+ let o = "";
100
+ switch (d) {
101
+ case "CART_ITEMS":
102
+ o = "ins_apr_total_product_kind";
103
+ break;
104
+ case "BROWSED_ITEMS":
105
+ o = "browsed_item_total_product_kind";
106
+ break;
107
+ case "PURCHASED_ITEMS":
108
+ o = "purchased_item_total_product_kind";
109
+ break;
110
+ }
111
+ if (o) {
112
+ const _ = parseInt(A) - 1, b = `${`{% if ${o} > ${_} %}`}${n}{% endif %}`;
113
+ E = E.replace(n, b);
114
+ }
115
+ });
116
+ const k = $.querySelectorAll('[product-attr="originalPrice"][data-type="CART_ITEMS"]'), T = [];
117
+ return k.forEach((n) => {
118
+ const d = n.getAttribute("data-number"), A = n.getAttribute("data-type");
119
+ if (!d || A !== "CART_ITEMS")
120
+ return;
121
+ const o = n.closest(".product-original-price-class");
122
+ if (o) {
123
+ const h = o.outerHTML;
124
+ T.some((g) => g.tdOuterHtml === h) || T.push({ tdOuterHtml: h, number: d });
125
+ }
126
+ }), T.reverse().forEach(({ tdOuterHtml: n, number: d }) => {
127
+ const A = `{% if ins_apr_price_${d} != ins_apr_originalprice_${d} %}`;
128
+ if (!E.includes(A) && !n.includes("{% if")) {
129
+ const h = `${A}${n}{% endif %}`;
130
+ E = E.replace(n, h);
131
+ }
132
+ }), E.replaceAll("<!--{%", "{%").replaceAll("%}-->", "%}").replaceAll("&lt;!--{%", "{%").replaceAll("%}--&gt;", "%}");
133
+ }
134
+ export {
135
+ M as pairProductVariables
136
+ };
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@useinsider/guido",
3
- "version": "1.0.3-beta.1cd6abc",
3
+ "version": "1.0.3-beta.1d07a49",
4
4
  "description": "Guido is a Vue + TypeScript wrapper for Email Plugin. Easily embed the email editor in your Vue applications.",
5
5
  "main": "./dist/guido.umd.cjs",
6
6
  "module": "./dist/library.js",
@@ -31,7 +31,7 @@
31
31
  "author": "",
32
32
  "license": "ISC",
33
33
  "dependencies": {
34
- "@stripoinc/ui-editor-extensions": "3.0.0",
34
+ "@stripoinc/ui-editor-extensions": "3.3.0",
35
35
  "@useinsider/design-system-vue": "0.14.20",
36
36
  "@vueuse/core": "11.3.0",
37
37
  "lodash-es": "4.17.21",
@@ -44,7 +44,7 @@
44
44
  "@cspell/eslint-plugin": "8.17.5",
45
45
  "@eslint/eslintrc": "3.3.0",
46
46
  "@eslint/js": "8.57.1",
47
- "@playwright/test": "1.55.0",
47
+ "@playwright/test": "1.57.0",
48
48
  "@stylistic/eslint-plugin": "3.1.0",
49
49
  "@stylistic/eslint-plugin-migrate": "3.1.0",
50
50
  "@types/eslint": "8.56.12",
@@ -83,7 +83,7 @@
83
83
  },
84
84
  "guido": {
85
85
  "stripo": {
86
- "version": "2.42.0"
86
+ "version": "2.47.0"
87
87
  }
88
88
  }
89
89
  }
@@ -1,200 +0,0 @@
1
- const g = {
2
- TITLE: "You May Also Like!"
3
- }, h = `
4
- <td align="left" class="ins-recommendation-v3-block-v2 esd-block-recommendation-v3-block">
5
- <table width="100%" cellpadding="0" cellspacing="0" border="0">
6
- <tr>
7
- <td align="center" style="padding: 20px 0;">
8
- <!-- Email Content Container -->
9
- <table class="container"
10
- width="600"
11
- cellpadding="0"
12
- cellspacing="0"
13
- border="0"
14
- style="max-width: 600px; width: 100%; background-color: #ffffff;">
15
- <!-- Heading -->
16
- <tr>
17
- <td class="heading"
18
- style="
19
- font-size: 28px;
20
- font-weight: bold;
21
- color: #333333;
22
- text-align: center;
23
- padding: 30px 20px;">
24
- {-{-TITLE-}-}
25
- </td>
26
- </tr>
27
-
28
- <!-- Product Rows -->
29
- {-{-PRODUCT_ROWS-}-}
30
- </table>
31
- <!-- End Email Content Container -->
32
- </td>
33
- </tr>
34
- </table>
35
- </td>
36
- `, u = `
37
- <tr>
38
- <td style="padding: 0 20px;">
39
- <table width="100%" height="100%" cellpadding="0" cellspacing="0" border="0">
40
- {-{-PRODUCTS-}-}
41
- </table>
42
- </td>
43
- </tr>
44
- `, m = `
45
- <td width="{-{-COLUMN_WIDTH-}-}" style="padding: 0 5px;" valign="top" height="100%">
46
- <table width="100%"
47
- height="100%"
48
- cellpadding="0"
49
- cellspacing="0"
50
- border="0"
51
- class="product-card-wrapper"
52
- style="background-color: #f8f8f8;">
53
- <tr>
54
- <td class="product-image-cell"
55
- valign="top"
56
- style="background-color: #e8f0f2; padding: 30px; text-align: center;">
57
- <img src="{-{-PRODUCT_IMAGE-}-}"
58
- alt="{-{-PRODUCT_NAME-}-}" width="120" style="max-width: 100%; height: auto; margin: 0 auto;">
59
- </td>
60
- </tr>
61
- </table>
62
- </td>
63
- `, b = `
64
- <td width="{-{-COLUMN_WIDTH-}-}" style="padding: 0 5px;" valign="top" height="100%">
65
- <table width="100%"
66
- height="100%"
67
- cellpadding="0"
68
- cellspacing="0"
69
- border="0"
70
- class="product-card-wrapper"
71
- style="background-color: #f8f8f8;">
72
- <tr>
73
- <td class="product-name-cell"
74
- valign="top"
75
- style="font-size: 16px; color: #333333; font-weight: 600; padding: 15px 10px; text-align: center;">
76
- {-{-PRODUCT_NAME-}-}
77
- </td>
78
- </tr>
79
- </table>
80
- </td>
81
- `, x = `
82
- <td width="{-{-COLUMN_WIDTH-}-}" style="padding: 0 5px;" valign="top" height="100%">
83
- <table width="100%"
84
- height="100%"
85
- cellpadding="0"
86
- cellspacing="0"
87
- border="0"
88
- class="product-card-wrapper"
89
- style="background-color: #f8f8f8;">
90
- <tr>
91
- <td class="price-cell" valign="top" style="padding: 10px; text-align: center;">
92
- <span class="current-price" style="font-size: 16px; color: #333333; font-weight: bold;">
93
- 18,00 TRY
94
- </span>
95
- <span class="old-price" style="font-size: 14px; color: #999999; text-decoration: line-through;">
96
- 20,00 TRY
97
- </span>
98
- </td>
99
- </tr>
100
- </table>
101
- </td>
102
- `, w = `
103
- <td width="{-{-COLUMN_WIDTH-}-}" style="padding: 0 5px;" valign="top" height="100%">
104
- <table width="100%"
105
- height="100%"
106
- cellpadding="0"
107
- cellspacing="0"
108
- border="0"
109
- class="product-card-wrapper"
110
- style="background-color: #f8f8f8;">
111
- <tr>
112
- <td class="button-cell" valign="top" style="padding: 15px 10px 20px 10px; text-align: center;">
113
- <a href="#"
114
- class="buy-button"
115
- style="
116
- display: inline-block;
117
- width: 90%;
118
- max-width: 150px;
119
- padding: 12px 20px;
120
- background-color: #ffffff;
121
- color: #333333;
122
- text-decoration: none;
123
- border: 2px solid #cccccc;
124
- font-size: 16px;
125
- box-sizing: border-box;">
126
- Buy
127
- </a>
128
- </td>
129
- </tr>
130
- </table>
131
- </td>
132
- `, f = `
133
- <tr>
134
- <td class="spacer" style="height: 20px;"></td>
135
- </tr>
136
- `;
137
- function T() {
138
- const c = [
139
- {
140
- name: "Beanie with Logo",
141
- image: "https://inshoppingcart.com/ins-html/wp-content/uploads/2018/08/beanie-with-logo-1.jpg",
142
- price: "18,00 TRY",
143
- oldPrice: "20,00 TRY",
144
- url: "https://example.com/product/1"
145
- },
146
- {
147
- name: "Belt",
148
- image: "https://inshoppingcart.com/ins-html/wp-content/uploads/2018/09/belt-2.jpg",
149
- price: "55,00 TRY",
150
- oldPrice: "65,00 TRY",
151
- url: "https://example.com/product/2"
152
- },
153
- {
154
- name: "Beanie",
155
- image: "https://inshoppingcart.com/ins-html/wp-content/uploads/2018/08/beanie-with-logo-1.jpg",
156
- price: "18,00 TRY",
157
- oldPrice: "20,00 TRY",
158
- url: "https://example.com/product/3"
159
- },
160
- {
161
- name: "Album",
162
- image: "https://inshoppingcart.com/ins-html/wp-content/uploads/2018/12/poster_2_up.jpg",
163
- price: "15,00 TRY",
164
- oldPrice: "15,00 TRY",
165
- url: "https://example.com/product/4"
166
- },
167
- {
168
- name: "Flying Ninja with a very long product name",
169
- image: "https://inshoppingcart.com/ins-html/wp-content/uploads/2018/09/belt-2.jpg",
170
- price: "12,00 TRY",
171
- oldPrice: "15,00 TRY",
172
- url: "https://example.com/product/5"
173
- },
174
- {
175
- name: "Single",
176
- image: "https://inshoppingcart.com/ins-html/wp-content/uploads/2018/12/poster_2_up.jpg",
177
- price: "22.555,00 TRY",
178
- oldPrice: "33.989,00 TRY",
179
- url: "https://example.com/product/6"
180
- }
181
- ], l = 3, d = (100 / l).toFixed(2), a = [];
182
- for (let t = 0; t < c.length; t += l)
183
- a.push(c.slice(t, t + l));
184
- let e = "";
185
- return a.forEach((t, s) => {
186
- s > 0 && (e += f);
187
- let p = "", r = "", n = "", i = "";
188
- t.forEach((o) => {
189
- p += m.replace("{-{-PRODUCT_IMAGE-}-}", o.image).replace("{-{-PRODUCT_NAME-}-}", o.name), r += b.replace("{-{-PRODUCT_NAME-}-}", o.name), n += x, i += w;
190
- }), e += u.replace("{-{-PRODUCTS-}-}", `
191
- <tr>${p}</tr>
192
- <tr>${r}</tr>
193
- <tr>${n}</tr>
194
- <tr>${i}</tr>
195
- `), e = e.replaceAll("{-{-COLUMN_WIDTH-}-}", `${d}%`);
196
- }), h.replace("{-{-TITLE-}-}", g.TITLE).replace("{-{-PRODUCT_ROWS-}-}", e);
197
- }
198
- export {
199
- T as getDefaultTemplate
200
- };
@@ -1,6 +0,0 @@
1
- declare const migrationTemplate = "ADD YOUR MIGRATION HERE";
2
- /**
3
- * @returns The template for the default checkbox block
4
- */
5
- export declare function getDefaultTemplate(): string;
6
- export default migrationTemplate;