@useinsider/guido 2.0.0-beta.087a24f → 2.0.0-beta.0941bcd

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 (284) hide show
  1. package/README.md +2 -0
  2. package/dist/@types/config/schemas.js +55 -39
  3. package/dist/components/Guido.vue.js +1 -1
  4. package/dist/components/Guido.vue2.js +15 -17
  5. package/dist/components/organisms/email-preview/PreviewContainer.vue.js +3 -3
  6. package/dist/components/organisms/email-preview/amp/AmpErrorModal.vue.js +6 -6
  7. package/dist/components/organisms/email-preview/amp/AmpErrorModal.vue2.js +17 -13
  8. package/dist/components/organisms/email-preview/amp/AmpToggle.vue.js +6 -6
  9. package/dist/components/organisms/email-preview/amp/AmpToggle.vue2.js +14 -12
  10. package/dist/components/organisms/email-preview/desktop-preview/DesktopBrowserHeader.vue.js +18 -0
  11. package/dist/components/organisms/email-preview/desktop-preview/DesktopBrowserHeader.vue2.js +15 -0
  12. package/dist/components/organisms/email-preview/desktop-preview/DesktopPreview.vue.js +10 -14
  13. package/dist/components/organisms/email-preview/desktop-preview/DesktopPreview.vue2.js +14 -22
  14. package/dist/components/organisms/email-preview/desktop-preview/EmailSizeIndicator.vue.js +3 -3
  15. package/dist/components/organisms/email-preview/mobile-preview/ContentView.vue.js +12 -11
  16. package/dist/components/organisms/email-preview/mobile-preview/InboxView.vue.js +12 -10
  17. package/dist/components/organisms/email-preview/mobile-preview/MobilePreview.vue.js +11 -10
  18. package/dist/components/organisms/email-preview/mobile-preview/MobilePreview.vue2.js +15 -14
  19. package/dist/components/organisms/header/EditorActions.vue.js +21 -0
  20. package/dist/components/organisms/header/EditorActions.vue2.js +41 -0
  21. package/dist/components/organisms/header/EditorToolbar.vue.js +18 -0
  22. package/dist/components/organisms/header/EditorToolbar.vue2.js +17 -0
  23. package/dist/components/organisms/header/HeaderWrapper.vue.js +6 -5
  24. package/dist/components/organisms/header/LeftSlot.vue.js +11 -11
  25. package/dist/components/organisms/header/LeftSlot.vue2.js +11 -12
  26. package/dist/components/organisms/header/MiddleSlot.vue.js +7 -7
  27. package/dist/components/organisms/header/MiddleSlot.vue2.js +11 -15
  28. package/dist/components/organisms/header/RightSlot.vue.js +11 -14
  29. package/dist/components/organisms/header/RightSlot.vue2.js +13 -30
  30. package/dist/components/organisms/header/version-history/VersionHistory.vue.js +5 -5
  31. package/dist/components/organisms/onboarding/NewVersionPopup.vue2.js +15 -15
  32. package/dist/components/organisms/unsubscribe/UnsubscribeTypeSelection.vue.js +1 -1
  33. package/dist/components/organisms/unsubscribe/UnsubscribeTypeSelection.vue2.js +20 -19
  34. package/dist/composables/useActionsApi.js +33 -30
  35. package/dist/composables/useConfig.js +29 -27
  36. package/dist/composables/useSave.js +13 -11
  37. package/dist/composables/useStripo.js +42 -40
  38. package/dist/config/migrator/index.js +8 -9
  39. package/dist/config/migrator/recommendationMigrator.js +2 -2
  40. package/dist/enums/academy.js +8 -0
  41. package/dist/enums/onboarding.js +1 -2
  42. package/dist/enums/unsubscribe.js +20 -21
  43. package/dist/extensions/Blocks/CouponBlock/constants.js +4 -0
  44. package/dist/extensions/Blocks/CouponBlock/controls/index.js +29 -0
  45. package/dist/extensions/Blocks/CouponBlock/extension.js +5 -4
  46. package/dist/extensions/Blocks/CouponBlock/settingsPanel.js +20 -14
  47. package/dist/extensions/Blocks/CouponBlock/template.js +22 -11
  48. package/dist/extensions/Blocks/Items/block.js +40 -39
  49. package/dist/extensions/Blocks/Items/controls/cardComposition.js +62 -50
  50. package/dist/extensions/Blocks/Items/controls/price/priceOrientation.js +26 -28
  51. package/dist/extensions/Blocks/Items/controls/settingsControl.js +127 -132
  52. package/dist/extensions/Blocks/Items/enums/settingsEnums.js +2 -2
  53. package/dist/extensions/Blocks/Items/layouts/horizontal.html.js +48 -58
  54. package/dist/extensions/Blocks/Items/layouts/vertical.html.js +58 -48
  55. package/dist/extensions/Blocks/Items/store/items-block.js +2 -2
  56. package/dist/extensions/Blocks/Items/template.js +123 -296
  57. package/dist/extensions/Blocks/Items/utils/syncAttributesFromConfigBlock.js +20 -11
  58. package/dist/extensions/Blocks/Recommendation/block.js +40 -6
  59. package/dist/extensions/Blocks/Recommendation/constants/blockIds.js +4 -0
  60. package/dist/extensions/Blocks/Recommendation/constants/controlIds.js +4 -0
  61. package/dist/extensions/Blocks/Recommendation/constants/defaultConfig.js +64 -0
  62. package/dist/extensions/Blocks/Recommendation/constants/layout.js +20 -0
  63. package/dist/extensions/Blocks/Recommendation/constants/selectors.js +19 -0
  64. package/dist/extensions/Blocks/Recommendation/controls/button/index.js +64 -0
  65. package/dist/extensions/Blocks/Recommendation/controls/cardBackground/index.js +80 -0
  66. package/dist/extensions/Blocks/Recommendation/controls/cardComposition/index.js +232 -0
  67. package/dist/extensions/Blocks/Recommendation/controls/image/index.js +19 -0
  68. package/dist/extensions/Blocks/Recommendation/controls/layout/index.js +96 -0
  69. package/dist/extensions/Blocks/Recommendation/controls/main/algorithm.js +110 -0
  70. package/dist/extensions/Blocks/Recommendation/controls/main/currency.js +204 -0
  71. package/dist/extensions/Blocks/Recommendation/controls/main/filters.js +54 -0
  72. package/dist/extensions/Blocks/Recommendation/controls/main/index.js +205 -0
  73. package/dist/extensions/Blocks/Recommendation/controls/main/locale.js +74 -0
  74. package/dist/extensions/Blocks/Recommendation/controls/main/productLayout.js +118 -0
  75. package/dist/extensions/Blocks/Recommendation/controls/main/shuffle.js +71 -0
  76. package/dist/extensions/Blocks/Recommendation/controls/main/utils.js +286 -0
  77. package/dist/extensions/Blocks/Recommendation/controls/name/index.js +46 -0
  78. package/dist/extensions/Blocks/Recommendation/controls/name/textTrim.js +76 -0
  79. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/index.js +44 -0
  80. package/dist/extensions/Blocks/Recommendation/controls/omnibusDiscount/index.js +48 -0
  81. package/dist/extensions/Blocks/Recommendation/controls/omnibusDiscount/textAfter.js +73 -0
  82. package/dist/extensions/Blocks/Recommendation/controls/omnibusDiscount/textBefore.js +73 -0
  83. package/dist/extensions/Blocks/Recommendation/controls/omnibusPrice/index.js +48 -0
  84. package/dist/extensions/Blocks/Recommendation/controls/omnibusPrice/textAfter.js +73 -0
  85. package/dist/extensions/Blocks/Recommendation/controls/omnibusPrice/textBefore.js +73 -0
  86. package/dist/extensions/Blocks/Recommendation/controls/price/index.js +44 -0
  87. package/dist/extensions/Blocks/Recommendation/controls/spacing/index.js +222 -0
  88. package/dist/extensions/Blocks/Recommendation/extension.js +40 -43
  89. package/dist/extensions/Blocks/Recommendation/iconsRegistry.js +19 -3
  90. package/dist/extensions/Blocks/Recommendation/recommendation.css.js +13 -4
  91. package/dist/extensions/Blocks/Recommendation/services/configService.js +239 -0
  92. package/dist/extensions/Blocks/Recommendation/settingsPanel.js +128 -72
  93. package/dist/extensions/Blocks/Recommendation/store/recommendation.js +41 -36
  94. package/dist/extensions/Blocks/Recommendation/templates/grid/elementRenderer.js +233 -0
  95. package/dist/extensions/Blocks/Recommendation/templates/grid/migration.js +251 -0
  96. package/dist/extensions/Blocks/Recommendation/templates/grid/template.js +69 -0
  97. package/dist/extensions/Blocks/Recommendation/templates/index.js +12 -0
  98. package/dist/extensions/Blocks/Recommendation/templates/list/elementRenderer.js +174 -0
  99. package/dist/extensions/Blocks/Recommendation/templates/list/template.js +73 -0
  100. package/dist/extensions/Blocks/Recommendation/templates/utils.js +121 -0
  101. package/dist/extensions/Blocks/Recommendation/types/nodeConfig.js +6 -0
  102. package/dist/extensions/Blocks/Recommendation/utils/filterUtil.js +9 -9
  103. package/dist/extensions/Blocks/Recommendation/utils/preserveTextStyles.js +36 -0
  104. package/dist/extensions/Blocks/Recommendation/utils/priceFormatter.js +29 -0
  105. package/dist/extensions/Blocks/Recommendation/utils/tagName.js +46 -0
  106. package/dist/extensions/Blocks/Unsubscribe/extension.js +9 -9
  107. package/dist/extensions/Blocks/common-control.js +55 -67
  108. package/dist/extensions/Blocks/controlFactories.js +162 -117
  109. package/dist/guido.css +1 -1
  110. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/esm/index.js +229 -176
  111. package/dist/package.json.js +7 -0
  112. package/dist/services/recommendationApi.js +10 -9
  113. package/dist/services/stripoApi.js +6 -10
  114. package/dist/src/@types/config/index.d.ts +2 -2
  115. package/dist/src/@types/config/schemas.d.ts +30 -0
  116. package/dist/src/@types/config/types.d.ts +7 -1
  117. package/dist/src/components/organisms/email-preview/desktop-preview/DesktopBrowserHeader.vue.d.ts +2 -0
  118. package/dist/src/components/organisms/header/EditorActions.vue.d.ts +4 -0
  119. package/dist/src/components/organisms/header/EditorToolbar.vue.d.ts +2 -0
  120. package/dist/src/components/organisms/header/RightSlot.vue.d.ts +1 -1
  121. package/dist/src/components/wrappers/WpDrawer.vue.d.ts +1 -1
  122. package/dist/src/composables/useActionsApi.d.ts +1 -0
  123. package/dist/src/composables/useConfig.d.ts +8 -0
  124. package/dist/src/enums/academy.d.ts +12 -0
  125. package/dist/src/enums/onboarding.d.ts +0 -1
  126. package/dist/src/enums/unsubscribe.d.ts +0 -1
  127. package/dist/src/extensions/Blocks/CouponBlock/constants.d.ts +14 -0
  128. package/dist/src/extensions/Blocks/CouponBlock/controls/index.d.ts +108 -0
  129. package/dist/src/extensions/Blocks/CouponBlock/template.d.ts +1 -1
  130. package/dist/src/extensions/Blocks/Items/controls/price/priceOrientation.d.ts +1 -1
  131. package/dist/src/extensions/Blocks/Items/controls/settingsControl.d.ts +4 -0
  132. package/dist/src/extensions/Blocks/Items/template.d.ts +1 -20
  133. package/dist/src/extensions/Blocks/Recommendation/block.d.ts +34 -0
  134. package/dist/src/extensions/Blocks/Recommendation/constants/blockIds.d.ts +13 -0
  135. package/dist/src/extensions/Blocks/Recommendation/{constants.d.ts → constants/controlIds.d.ts} +19 -11
  136. package/dist/src/extensions/Blocks/Recommendation/constants/defaultConfig.d.ts +49 -0
  137. package/dist/src/extensions/Blocks/Recommendation/constants/index.d.ts +13 -0
  138. package/dist/src/extensions/Blocks/Recommendation/constants/layout.d.ts +35 -0
  139. package/dist/src/extensions/Blocks/Recommendation/constants/selectors.d.ts +31 -0
  140. package/dist/src/extensions/Blocks/Recommendation/controls/button/index.d.ts +143 -0
  141. package/dist/src/extensions/Blocks/Recommendation/controls/cardBackground/index.d.ts +31 -0
  142. package/dist/src/extensions/Blocks/Recommendation/controls/cardComposition/index.d.ts +95 -0
  143. package/dist/src/extensions/Blocks/Recommendation/controls/image/index.d.ts +35 -0
  144. package/dist/src/extensions/Blocks/Recommendation/controls/index.d.ts +24 -0
  145. package/dist/src/extensions/Blocks/Recommendation/controls/layout/index.d.ts +37 -0
  146. package/dist/src/extensions/Blocks/Recommendation/controls/main/algorithm.d.ts +29 -0
  147. package/dist/src/extensions/Blocks/Recommendation/controls/main/currency.d.ts +45 -0
  148. package/dist/src/extensions/Blocks/Recommendation/controls/main/filters.d.ts +22 -0
  149. package/dist/src/extensions/Blocks/Recommendation/controls/main/index.d.ts +57 -0
  150. package/dist/src/extensions/Blocks/Recommendation/controls/main/locale.d.ts +24 -0
  151. package/dist/src/extensions/Blocks/Recommendation/controls/main/productLayout.d.ts +42 -0
  152. package/dist/src/extensions/Blocks/Recommendation/controls/main/shuffle.d.ts +23 -0
  153. package/dist/src/extensions/Blocks/Recommendation/controls/main/utils.d.ts +214 -0
  154. package/dist/src/extensions/Blocks/Recommendation/controls/name/index.d.ts +97 -0
  155. package/dist/src/extensions/Blocks/Recommendation/controls/name/textTrim.d.ts +16 -0
  156. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/index.d.ts +95 -0
  157. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusDiscount/index.d.ts +100 -0
  158. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusDiscount/textAfter.d.ts +15 -0
  159. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusDiscount/textBefore.d.ts +15 -0
  160. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusPrice/index.d.ts +100 -0
  161. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusPrice/textAfter.d.ts +15 -0
  162. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusPrice/textBefore.d.ts +15 -0
  163. package/dist/src/extensions/Blocks/Recommendation/controls/price/index.d.ts +95 -0
  164. package/dist/src/extensions/Blocks/Recommendation/controls/spacing/index.d.ts +83 -0
  165. package/dist/src/extensions/Blocks/Recommendation/extension.d.ts +9 -0
  166. package/dist/src/extensions/Blocks/Recommendation/services/configService.d.ts +151 -0
  167. package/dist/src/extensions/Blocks/Recommendation/services/index.d.ts +6 -0
  168. package/dist/src/extensions/Blocks/Recommendation/store/recommendation.d.ts +17 -16
  169. package/dist/src/extensions/Blocks/Recommendation/templates/grid/elementRenderer.d.ts +20 -0
  170. package/dist/src/extensions/Blocks/Recommendation/templates/{migrationTemplate.d.ts → grid/migration.d.ts} +11 -4
  171. package/dist/src/extensions/Blocks/Recommendation/templates/grid/template.d.ts +33 -0
  172. package/dist/src/extensions/Blocks/Recommendation/templates/index.d.ts +39 -0
  173. package/dist/src/extensions/Blocks/Recommendation/templates/list/elementRenderer.d.ts +8 -0
  174. package/dist/src/extensions/Blocks/Recommendation/templates/list/migration.d.ts +25 -0
  175. package/dist/src/extensions/Blocks/Recommendation/templates/list/template.d.ts +18 -0
  176. package/dist/src/extensions/Blocks/Recommendation/templates/utils.d.ts +54 -0
  177. package/dist/src/extensions/Blocks/Recommendation/types/index.d.ts +7 -0
  178. package/dist/src/extensions/Blocks/Recommendation/types/nodeConfig.d.ts +154 -0
  179. package/dist/src/extensions/Blocks/Recommendation/utils/preserveTextStyles.d.ts +19 -0
  180. package/dist/src/extensions/Blocks/Recommendation/utils/priceFormatter.d.ts +33 -0
  181. package/dist/src/extensions/Blocks/Recommendation/utils/stylePreserver.d.ts +113 -0
  182. package/dist/src/extensions/Blocks/Recommendation/utils/tagName.d.ts +77 -0
  183. package/dist/src/extensions/Blocks/common-control.d.ts +9 -14
  184. package/dist/src/extensions/Blocks/controlFactories.d.ts +30 -7
  185. package/dist/src/stores/config.d.ts +164 -1
  186. package/dist/src/stores/editor.d.ts +21 -0
  187. package/dist/static/assets/desktop/desktop-mockup-center.svg.js +4 -0
  188. package/dist/static/assets/desktop/desktop-mockup-left.svg.js +4 -0
  189. package/dist/static/assets/desktop/desktop-mockup-right.svg.js +4 -0
  190. package/dist/static/assets/mobile/email-mockup.svg.js +4 -0
  191. package/dist/static/assets/mobile/inbox-mockup.svg.js +4 -0
  192. package/dist/static/styles/components/button.css.js +1 -1
  193. package/dist/static/styles/components/wide-panel.css.js +1 -5
  194. package/dist/static/styles/customEditorStyle.css.js +38 -2
  195. package/dist/stores/config.js +7 -0
  196. package/dist/stores/editor.js +1 -0
  197. package/dist/utils/templatePreparation.js +17 -17
  198. package/package.json +1 -1
  199. package/dist/components/organisms/email-preview/desktop-preview/EmailHeaderInfo.vue.js +0 -17
  200. package/dist/components/organisms/email-preview/desktop-preview/EmailHeaderInfo.vue2.js +0 -20
  201. package/dist/config/migrator/itemsBlockMigrator.js +0 -283
  202. package/dist/extensions/Blocks/Items/utils/nodeConfigUtils.js +0 -172
  203. package/dist/extensions/Blocks/Recommendation/cardCompositionControl.js +0 -103
  204. package/dist/extensions/Blocks/Recommendation/constants.js +0 -5
  205. package/dist/extensions/Blocks/Recommendation/control.js +0 -306
  206. package/dist/extensions/Blocks/Recommendation/controls/button/align.js +0 -13
  207. package/dist/extensions/Blocks/Recommendation/controls/button/border.js +0 -13
  208. package/dist/extensions/Blocks/Recommendation/controls/button/borderRadius.js +0 -13
  209. package/dist/extensions/Blocks/Recommendation/controls/button/color.js +0 -13
  210. package/dist/extensions/Blocks/Recommendation/controls/button/fitToContent.js +0 -13
  211. package/dist/extensions/Blocks/Recommendation/controls/button/fontFamily.js +0 -13
  212. package/dist/extensions/Blocks/Recommendation/controls/button/margins.js +0 -13
  213. package/dist/extensions/Blocks/Recommendation/controls/button/paddings.js +0 -13
  214. package/dist/extensions/Blocks/Recommendation/controls/button/text.js +0 -13
  215. package/dist/extensions/Blocks/Recommendation/controls/button/textSize.js +0 -13
  216. package/dist/extensions/Blocks/Recommendation/controls/button/textStyleAndFontColor.js +0 -13
  217. package/dist/extensions/Blocks/Recommendation/controls/image/margins.js +0 -13
  218. package/dist/extensions/Blocks/Recommendation/controls/image/size.js +0 -13
  219. package/dist/extensions/Blocks/Recommendation/controls/name/align.js +0 -13
  220. package/dist/extensions/Blocks/Recommendation/controls/name/background.js +0 -13
  221. package/dist/extensions/Blocks/Recommendation/controls/name/color.js +0 -13
  222. package/dist/extensions/Blocks/Recommendation/controls/name/fontFamily.js +0 -13
  223. package/dist/extensions/Blocks/Recommendation/controls/name/paddings.js +0 -13
  224. package/dist/extensions/Blocks/Recommendation/controls/name/size.js +0 -13
  225. package/dist/extensions/Blocks/Recommendation/controls/name/style.js +0 -13
  226. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/align.js +0 -13
  227. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/background.js +0 -13
  228. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/color.js +0 -13
  229. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/fontFamily.js +0 -13
  230. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/paddings.js +0 -13
  231. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/size.js +0 -13
  232. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/style.js +0 -13
  233. package/dist/extensions/Blocks/Recommendation/controls/price/align.js +0 -13
  234. package/dist/extensions/Blocks/Recommendation/controls/price/background.js +0 -13
  235. package/dist/extensions/Blocks/Recommendation/controls/price/color.js +0 -13
  236. package/dist/extensions/Blocks/Recommendation/controls/price/fontFamily.js +0 -13
  237. package/dist/extensions/Blocks/Recommendation/controls/price/paddings.js +0 -13
  238. package/dist/extensions/Blocks/Recommendation/controls/price/size.js +0 -13
  239. package/dist/extensions/Blocks/Recommendation/controls/price/style.js +0 -13
  240. package/dist/extensions/Blocks/Recommendation/templates/blockTemplate.js +0 -160
  241. package/dist/extensions/Blocks/Recommendation/templates/migrationTemplate.js +0 -152
  242. package/dist/extensions/Blocks/Recommendation/templates/templateUtils.js +0 -180
  243. package/dist/src/config/migrator/itemsBlockMigrator.d.ts +0 -6
  244. package/dist/src/extensions/Blocks/Items/utils/nodeConfigUtils.d.ts +0 -71
  245. package/dist/src/extensions/Blocks/Recommendation/cardCompositionControl.d.ts +0 -28
  246. package/dist/src/extensions/Blocks/Recommendation/control.d.ts +0 -35
  247. package/dist/src/extensions/Blocks/Recommendation/controls/button/align.d.ts +0 -5
  248. package/dist/src/extensions/Blocks/Recommendation/controls/button/border.d.ts +0 -5
  249. package/dist/src/extensions/Blocks/Recommendation/controls/button/borderRadius.d.ts +0 -5
  250. package/dist/src/extensions/Blocks/Recommendation/controls/button/color.d.ts +0 -5
  251. package/dist/src/extensions/Blocks/Recommendation/controls/button/fitToContent.d.ts +0 -5
  252. package/dist/src/extensions/Blocks/Recommendation/controls/button/fontFamily.d.ts +0 -5
  253. package/dist/src/extensions/Blocks/Recommendation/controls/button/margins.d.ts +0 -5
  254. package/dist/src/extensions/Blocks/Recommendation/controls/button/paddings.d.ts +0 -5
  255. package/dist/src/extensions/Blocks/Recommendation/controls/button/text.d.ts +0 -5
  256. package/dist/src/extensions/Blocks/Recommendation/controls/button/textSize.d.ts +0 -5
  257. package/dist/src/extensions/Blocks/Recommendation/controls/button/textStyleAndFontColor.d.ts +0 -5
  258. package/dist/src/extensions/Blocks/Recommendation/controls/image/margins.d.ts +0 -5
  259. package/dist/src/extensions/Blocks/Recommendation/controls/image/size.d.ts +0 -5
  260. package/dist/src/extensions/Blocks/Recommendation/controls/name/align.d.ts +0 -5
  261. package/dist/src/extensions/Blocks/Recommendation/controls/name/background.d.ts +0 -5
  262. package/dist/src/extensions/Blocks/Recommendation/controls/name/color.d.ts +0 -5
  263. package/dist/src/extensions/Blocks/Recommendation/controls/name/fontFamily.d.ts +0 -5
  264. package/dist/src/extensions/Blocks/Recommendation/controls/name/paddings.d.ts +0 -5
  265. package/dist/src/extensions/Blocks/Recommendation/controls/name/size.d.ts +0 -5
  266. package/dist/src/extensions/Blocks/Recommendation/controls/name/style.d.ts +0 -5
  267. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/align.d.ts +0 -5
  268. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/background.d.ts +0 -5
  269. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/color.d.ts +0 -5
  270. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/fontFamily.d.ts +0 -5
  271. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/paddings.d.ts +0 -5
  272. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/size.d.ts +0 -5
  273. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/style.d.ts +0 -5
  274. package/dist/src/extensions/Blocks/Recommendation/controls/price/align.d.ts +0 -5
  275. package/dist/src/extensions/Blocks/Recommendation/controls/price/background.d.ts +0 -5
  276. package/dist/src/extensions/Blocks/Recommendation/controls/price/color.d.ts +0 -5
  277. package/dist/src/extensions/Blocks/Recommendation/controls/price/fontFamily.d.ts +0 -5
  278. package/dist/src/extensions/Blocks/Recommendation/controls/price/paddings.d.ts +0 -5
  279. package/dist/src/extensions/Blocks/Recommendation/controls/price/size.d.ts +0 -5
  280. package/dist/src/extensions/Blocks/Recommendation/controls/price/style.d.ts +0 -5
  281. package/dist/src/extensions/Blocks/Recommendation/templates/blockTemplate.d.ts +0 -16
  282. package/dist/src/extensions/Blocks/Recommendation/templates/templateUtils.d.ts +0 -44
  283. package/dist/static/assets/inbox-mockup.svg.js +0 -4
  284. package/dist/static/assets/phone-mockup.svg.js +0 -4
@@ -0,0 +1,251 @@
1
+ import { ATTR_PRODUCT_BUTTON as s, ATTR_PRODUCT_OMNIBUS_DISCOUNT as d, ATTR_PRODUCT_OMNIBUS_PRICE as c, ATTR_PRODUCT_OLD_PRICE as o, ATTR_PRODUCT_PRICE as i, ATTR_PRODUCT_NAME as r, ATTR_PRODUCT_IMAGE as p } from "../../constants/selectors.js";
2
+ import { prepareVerticalProductRows as b } from "./template.js";
3
+ const u = `
4
+ <td
5
+ align="left"
6
+ esd-extension-block-id="recommendation-block"
7
+ esd-handler-name="esd-extension-RecommendationBlock"
8
+ class="ins-recommendation-v3-block-v2 esd-block-recommendation-v3-block esd-extension-block es-p20"
9
+ >
10
+ <table width="100%" cellpadding="0" cellspacing="0" border="0">
11
+ <tr>
12
+ <td align="center">
13
+ <table
14
+ class="container"
15
+ width="100%"
16
+ cellpadding="0"
17
+ cellspacing="0"
18
+ border="0">
19
+ <tbody>
20
+ <tr>
21
+ <td>
22
+ <table
23
+ width="100%"
24
+ cellpadding="0"
25
+ cellspacing="0"
26
+ border="0">
27
+ <tbody>
28
+ <tr>
29
+ {-{-TITLE-}-}
30
+ </tr>
31
+ </tbody>
32
+ </table>
33
+ </td>
34
+ </tr>
35
+ <tr>
36
+ <td class="spacer" style="height: 20px;"></td>
37
+ </tr>
38
+ <tr>
39
+ <td>
40
+ <table
41
+ class="ins-recommendation-product-container"
42
+ width="100%"
43
+ cellpadding="0"
44
+ cellspacing="0"
45
+ border="0"
46
+ >
47
+ {-{-PRODUCT_ROWS-}-}
48
+ </table>
49
+ </td>
50
+ </tr>
51
+ </tbody>
52
+ </table>
53
+ </td>
54
+ </tr>
55
+ </table>
56
+ </td>
57
+ `, e = "0 5px", a = "attribute-cell", g = {
58
+ [p]: (t) => `
59
+ <td class="${a}" style="padding: ${e}; height: 100%;" valign="top">
60
+ <table
61
+ class="product-card-segment"
62
+ width="100%"
63
+ height="100%"
64
+ cellpadding="0"
65
+ cellspacing="0"
66
+ border="0">
67
+ <tr>
68
+ <td
69
+ class="esd-block-image product-image"
70
+ esd-extension-block-id="recommendation-block-image"
71
+ align="center"
72
+ style="font-size: 0px;">
73
+ <a target="_blank" href="${t.url}">
74
+ <img
75
+ src="${t.image_url}"
76
+ alt="${t.name}"
77
+ width="120"
78
+ style="display: block; max-width: 100%; height: auto;"
79
+ class="adapt-img">
80
+ </a>
81
+ </td>
82
+ </tr>
83
+ </table>
84
+ </td>
85
+ `,
86
+ [r]: (t) => `
87
+ <td class="${a}" style="padding: ${e}; height: 100%;" valign="top">
88
+ <table
89
+ class="product-card-segment"
90
+ width="100%"
91
+ height="100%"
92
+ cellpadding="0"
93
+ cellspacing="0"
94
+ border="0">
95
+ <tr>
96
+ <td
97
+ class="esd-block-text product-name"
98
+ esd-extension-block-id="recommendation-block-name"
99
+ align="center">
100
+ <p
101
+ path="1"
102
+ contenteditable="false"
103
+ style="font-size: 16px; color: #333333; font-weight: 600; text-align: center;">
104
+ <strong path="1,0">${t.name}</strong>
105
+ </p>
106
+ </td>
107
+ </tr>
108
+ </table>
109
+ </td>
110
+ `,
111
+ [i]: () => `
112
+ <td class="${a}" style="padding: ${e}; height: 100%;" valign="top">
113
+ <table
114
+ class="product-card-segment"
115
+ width="100%"
116
+ height="100%"
117
+ cellpadding="0"
118
+ cellspacing="0"
119
+ border="0">
120
+ <tr>
121
+ <td
122
+ class="esd-block-text product-price"
123
+ esd-extension-block-id="recommendation-block-price"
124
+ align="center">
125
+ <p
126
+ path="1"
127
+ contenteditable="false"
128
+ style="font-size: 16px; color: #333333; font-weight: bold; text-align: center;">
129
+ <strong path="1,0">18,00 TRY</strong>
130
+ </p>
131
+ </td>
132
+ </tr>
133
+ </table>
134
+ </td>
135
+ `,
136
+ [o]: () => `
137
+ <td class="${a}" style="padding: ${e}; height: 100%;" valign="top">
138
+ <table
139
+ class="product-card-segment"
140
+ width="100%"
141
+ height="100%"
142
+ cellpadding="0"
143
+ cellspacing="0"
144
+ border="0">
145
+ <tr>
146
+ <td
147
+ class="esd-block-text product-old-price"
148
+ esd-extension-block-id="recommendation-block-old-price"
149
+ align="center">
150
+ <p
151
+ path="1"
152
+ contenteditable="false"
153
+ style="font-size: 14px; color: #999999; text-decoration: line-through; text-align: center;">
154
+ <s path="1,0">20,00 TRY</s>
155
+ </p>
156
+ </td>
157
+ </tr>
158
+ </table>
159
+ </td>
160
+ `,
161
+ [c]: () => `
162
+ <td class="${a}" style="padding: ${e}; height: 100%;" valign="top">
163
+ <table
164
+ class="product-card-segment"
165
+ width="100%"
166
+ height="100%"
167
+ cellpadding="0"
168
+ cellspacing="0"
169
+ border="0">
170
+ <tr>
171
+ <td
172
+ class="esd-block-text product-omnibus-price"
173
+ esd-extension-block-id="recommendation-block-omnibus-price"
174
+ data-text-before="Lowest 30-day price: "
175
+ data-text-after=""
176
+ align="center">
177
+ <p
178
+ path="1"
179
+ contenteditable="false"
180
+ style="font-size: 14px; color: #666666; text-align: center;"><span
181
+ class="omnibus-text-before">Lowest 30-day price: </span><span
182
+ class="omnibus-price-value">17,00 TRY</span><span
183
+ class="omnibus-text-after"></span></p>
184
+ </td>
185
+ </tr>
186
+ </table>
187
+ </td>
188
+ `,
189
+ [d]: () => `
190
+ <td class="${a}" style="padding: ${e}; height: 100%;" valign="top">
191
+ <table
192
+ class="product-card-segment"
193
+ width="100%"
194
+ height="100%"
195
+ cellpadding="0"
196
+ cellspacing="0"
197
+ border="0">
198
+ <tr>
199
+ <td
200
+ class="esd-block-text product-omnibus-discount"
201
+ esd-extension-block-id="recommendation-block-omnibus-discount"
202
+ data-text-before=""
203
+ data-text-after=""
204
+ align="center">
205
+ <p
206
+ path="1"
207
+ contenteditable="false"
208
+ style="font-size: 14px; color: #666666; text-align: center;"><span
209
+ class="omnibus-text-before"></span><span
210
+ class="omnibus-discount-value">-6%</span><span
211
+ class="omnibus-text-after"></span></p>
212
+ </td>
213
+ </tr>
214
+ </table>
215
+ </td>
216
+ `,
217
+ [s]: (t) => `
218
+ <td class="${a}" style="padding: ${e}; height: 100%;" valign="top">
219
+ <table
220
+ class="product-card-segment"
221
+ width="100%"
222
+ height="100%"
223
+ cellpadding="0"
224
+ cellspacing="0"
225
+ border="0">
226
+ <tr>
227
+ <td
228
+ class="esd-block-button product-button"
229
+ esd-extension-block-id="recommendation-block-button"
230
+ align="center">
231
+ <span class="es-button-border" style="display: block;">
232
+ <a
233
+ href="${t.url}"
234
+ target="_blank"
235
+ class="es-button">
236
+ {-{-PRODUCT_BUTTON_TEXT-}-}
237
+ </a>
238
+ </span>
239
+ </td>
240
+ </tr>
241
+ </table>
242
+ </td>
243
+ `
244
+ };
245
+ function T(t, l, n) {
246
+ return b(t, l, g, n);
247
+ }
248
+ export {
249
+ u as default,
250
+ T as prepareProductRows
251
+ };
@@ -0,0 +1,69 @@
1
+ import { DEFAULT_PRODUCTS_PER_ROW as T } from "../../constants/layout.js";
2
+ import { DEFAULT_CARD_COMPOSITION as d, spacer as m, createBlockTemplate as R, DEFAULTS as I, getDefaultProducts as L, DEFAULT_CARD_VISIBILITY as b } from "../utils.js";
3
+ import { verticalElementRenderer as w } from "./elementRenderer.js";
4
+ const E = `
5
+ <tr class="recommendation-product-row">
6
+ <td>
7
+ <table
8
+ width="100%"
9
+ height="100%"
10
+ cellpadding="0"
11
+ cellspacing="0"
12
+ border="0"
13
+ class="product-card-wrapper"
14
+ style="table-layout: fixed;">
15
+ <tbody>
16
+ {-{-ATTRIBUTE_ROWS-}-}
17
+ </tbody>
18
+ </table>
19
+ </td>
20
+ </tr>
21
+ `, S = `
22
+ <tr
23
+ class="recommendation-attribute-row"
24
+ data-attribute-type="{-{-ATTR_TYPE-}-}"
25
+ data-visibility="{-{-VISIBILITY-}-}"
26
+ {-{-DISPLAY_STYLE-}-}>
27
+ {-{-CELLS-}-}
28
+ </tr>
29
+ `;
30
+ function _(r, e, o, i = d) {
31
+ const c = (100 / e).toFixed(2);
32
+ return i.filter((t) => o[t]).map((t) => {
33
+ const l = b[t] ?? !0, n = l ? "" : 'style="display: none;"', a = r.map((p) => {
34
+ const u = o[t];
35
+ return u(p).replace("<td", `<td width="${c}%"`);
36
+ }).join("");
37
+ return S.replace("{-{-ATTR_TYPE-}-}", t).replace("{-{-VISIBILITY-}-}", l ? "1" : "0").replace("{-{-DISPLAY_STYLE-}-}", n).replace("{-{-CELLS-}-}", a);
38
+ }).join("");
39
+ }
40
+ function A(r, e, o, i) {
41
+ const c = [];
42
+ for (let t = 0; t < r.length; t += e)
43
+ c.push(r.slice(t, t + e));
44
+ return c.map((t, l) => {
45
+ const n = _(
46
+ t,
47
+ e,
48
+ o,
49
+ i
50
+ ), a = E.replace("{-{-ATTRIBUTE_ROWS-}-}", n);
51
+ return l > 0 ? m + a : a;
52
+ }).join("");
53
+ }
54
+ function f(r, e, o) {
55
+ return A(r, e, w, o);
56
+ }
57
+ function y() {
58
+ const r = R("grid"), e = f(
59
+ L(),
60
+ T
61
+ );
62
+ return r.replace("{-{-TITLE-}-}", I.TITLE).replace("{-{-PRODUCT_ROWS-}-}", e);
63
+ }
64
+ export {
65
+ y as getDefaultTemplate,
66
+ f as prepareProductRows,
67
+ _ as prepareVerticalAttributeRows,
68
+ A as prepareVerticalProductRows
69
+ };
@@ -0,0 +1,12 @@
1
+ import { DEFAULT_PRODUCTS_PER_ROW as s } from "../constants/layout.js";
2
+ import { prepareProductRows as R } from "./grid/template.js";
3
+ import { prepareProductRows as c } from "./list/template.js";
4
+ function a(r, o, p = {}) {
5
+ if (o === "list")
6
+ return c(r);
7
+ const { productsPerRow: t = s, composition: e } = p;
8
+ return R(r, t, e);
9
+ }
10
+ export {
11
+ a as prepareProductRows
12
+ };
@@ -0,0 +1,174 @@
1
+ import { RecommendationBlockId as o } from "../../constants/blockIds.js";
2
+ import { ATTR_PRODUCT_BUTTON as l, ATTR_PRODUCT_IMAGE as d, ATTR_PRODUCT_OMNIBUS_DISCOUNT as m, ATTR_PRODUCT_OMNIBUS_PRICE as u, ATTR_PRODUCT_OLD_PRICE as g, ATTR_PRODUCT_PRICE as f, ATTR_PRODUCT_NAME as x } from "../../constants/selectors.js";
3
+ import { useRecommendationExtensionStore as T } from "../../store/recommendation.js";
4
+ import { formatPrice as _ } from "../../utils/priceFormatter.js";
5
+ import { sanitizeImageUrl as y } from "../utils.js";
6
+ function p() {
7
+ const t = T(), { currencySettings: e } = t.recommendationConfigs;
8
+ return {
9
+ code: e.value,
10
+ symbol: e.symbol,
11
+ alignment: e.alignment === "0" ? "before" : "after",
12
+ decimalCount: parseInt(e.decimalCount) || 2,
13
+ decimalSeparator: e.decimalSeparator,
14
+ thousandSeparator: e.thousandSeparator
15
+ };
16
+ }
17
+ function a(t, e = "price") {
18
+ const n = p(), r = t[e], i = (r == null ? void 0 : r[n.code]) ?? Object.values(r ?? {})[0] ?? 0;
19
+ return _({
20
+ price: i,
21
+ currency: n
22
+ });
23
+ }
24
+ const P = {
25
+ /**
26
+ * Image cell - left column (120px fixed width)
27
+ * Has recommendation-attribute-row class and data attributes for Card Composition control
28
+ */
29
+ [d]: (t) => `
30
+ <td
31
+ width="120"
32
+ class="esd-block-image product-image-cell recommendation-attribute-row es-p5"
33
+ esd-extension-block-id="${o.IMAGE}"
34
+ data-attribute-type="${d}"
35
+ data-visibility="1"
36
+ align="center"
37
+ valign="middle">
38
+ <div style="position: relative; width: 100%; padding-bottom: 100%; overflow: hidden;">
39
+ <a
40
+ target="_blank"
41
+ href="${t.url}"
42
+ style="position: absolute; top: 0; left: 0; width: 100%; height: 100%;">
43
+ <img
44
+ src="${y(t.image_url)}"
45
+ alt="${t.name}"
46
+ style="max-width: 100%; max-height: 100%; object-fit: contain; display: block;"
47
+ class="adapt-img product-image">
48
+ </a>
49
+ </div>
50
+ </td>
51
+ `,
52
+ /**
53
+ * Name element - row for info cell table
54
+ */
55
+ [x]: (t) => `
56
+ <tr>
57
+ <td
58
+ class="esd-block-text product-name"
59
+ esd-extension-block-id="${o.NAME}"
60
+ align="left">
61
+ <p contenteditable="false" style="font-size: 16px; color: #333333; font-weight: 600; margin: 0;">
62
+ <strong>${t.name}</strong>
63
+ </p>
64
+ </td>
65
+ </tr>
66
+ `,
67
+ /**
68
+ * Price element - row for info cell table
69
+ */
70
+ [f]: (t) => `
71
+ <tr>
72
+ <td
73
+ class="esd-block-text product-price"
74
+ esd-extension-block-id="${o.PRICE}"
75
+ align="left">
76
+ <p contenteditable="false" style="font-size: 16px; color: #333333; font-weight: bold; margin: 0;">
77
+ <strong>${a(t, "price")}</strong>
78
+ </p>
79
+ </td>
80
+ </tr>
81
+ `,
82
+ /**
83
+ * Old price element - row for info cell table
84
+ */
85
+ [g]: (t) => `
86
+ <tr>
87
+ <td
88
+ class="esd-block-text product-old-price"
89
+ esd-extension-block-id="${o.OLD_PRICE}"
90
+ align="left">
91
+ <p
92
+ contenteditable="false"
93
+ style="font-size: 14px; color: #999999; text-decoration: line-through; margin: 0;">
94
+ <strong>${a(t, "original_price")}</strong>
95
+ </p>
96
+ </td>
97
+ </tr>
98
+ `,
99
+ /**
100
+ * Omnibus price element - row for info cell table
101
+ */
102
+ [u]: (t) => `
103
+ <tr>
104
+ <td
105
+ class="esd-block-text product-omnibus-price"
106
+ data-text-before="Lowest 30-day price: "
107
+ data-text-after=""
108
+ esd-extension-block-id="${o.OMNIBUS_PRICE}"
109
+ align="left">
110
+ <p style="font-size: 12px; color: #666666; margin: 0;">
111
+ <span class="omnibus-text-before">Lowest 30-day price: </span>
112
+ <span class="omnibus-price-value">${a(t, "original_price")}</span>
113
+ <span class="omnibus-text-after"></span>
114
+ </p>
115
+ </td>
116
+ </tr>
117
+ `,
118
+ /**
119
+ * Omnibus discount element - row for info cell table
120
+ */
121
+ [m]: (t) => {
122
+ var s, c;
123
+ const e = p(), n = ((s = t.original_price) == null ? void 0 : s[e.code]) ?? Object.values(t.original_price ?? {})[0] ?? 0, r = ((c = t.price) == null ? void 0 : c[e.code]) ?? Object.values(t.price ?? {})[0] ?? 0, i = n > 0 ? Math.round((n - r) / n * 100) : 0, b = i > 0 ? `-${i}%` : "0%";
124
+ return `
125
+ <tr>
126
+ <td
127
+ class="esd-block-text product-omnibus-discount"
128
+ data-text-before=""
129
+ data-text-after=""
130
+ esd-extension-block-id="${o.OMNIBUS_DISCOUNT}"
131
+ align="left">
132
+ <p style="font-size: 12px; color: #666666; margin: 0;">
133
+ <span class="omnibus-text-before"></span>
134
+ <span class="omnibus-discount-value">${b}</span>
135
+ <span class="omnibus-text-after"></span>
136
+ </p>
137
+ </td>
138
+ </tr>
139
+ `;
140
+ },
141
+ /**
142
+ * Button cell - right column (100px fixed width)
143
+ * Has recommendation-attribute-row class and data attributes for Card Composition control
144
+ */
145
+ [l]: (t) => `
146
+ <td
147
+ width="100"
148
+ class="esd-block-button button-cell recommendation-attribute-row product-button es-p5l es-p5r"
149
+ esd-extension-block-id="${o.BUTTON}"
150
+ data-attribute-type="${l}"
151
+ data-visibility="1"
152
+ align="center"
153
+ valign="middle">
154
+ <span
155
+ class="es-button-border"
156
+ style="
157
+ border-width: 1px;
158
+ background: rgb(217, 234, 211);
159
+ border-color: rgb(106, 168, 79);
160
+ ">
161
+ <a
162
+ href="${t.url}"
163
+ target="_blank"
164
+ class="es-button buy-button"
165
+ style="color: rgb(56, 118, 29); background: rgb(217, 234, 211); padding: 5px 30px;">
166
+ Buy
167
+ </a>
168
+ </span>
169
+ </td>
170
+ `
171
+ };
172
+ export {
173
+ P as horizontalElementRenderer
174
+ };
@@ -0,0 +1,73 @@
1
+ import { ATTR_PRODUCT_IMAGE as E, ATTR_PRODUCT_NAME as s, ATTR_PRODUCT_OLD_PRICE as c, ATTR_PRODUCT_PRICE as a, ATTR_PRODUCT_OMNIBUS_PRICE as d, ATTR_PRODUCT_OMNIBUS_DISCOUNT as T, ATTR_PRODUCT_BUTTON as N } from "../../constants/selectors.js";
2
+ import { spacer as $, DEFAULT_CARD_VISIBILITY as n } from "../utils.js";
3
+ import { horizontalElementRenderer as o } from "./elementRenderer.js";
4
+ const f = `
5
+ <tr class="recommendation-product-row">
6
+ <td style="padding: 0 5px;">
7
+ <table
8
+ width="100%"
9
+ cellpadding="0"
10
+ cellspacing="0"
11
+ border="0"
12
+ class="product-card-wrapper">
13
+ <tbody>
14
+ <tr>
15
+ {-{-PRODUCT_CONTENT-}-}
16
+ </tr>
17
+ </tbody>
18
+ </table>
19
+ </td>
20
+ </tr>
21
+ `;
22
+ function V(t) {
23
+ const i = o[E](t), l = n[s], r = n[c], R = n[a], C = n[d], b = n[T], e = (w, A, p) => {
24
+ const I = p ? "" : ' style="display: none;"', g = w.replace(/<tr>/, "").replace(/<\/tr>/, "");
25
+ return `<tr
26
+ class="recommendation-attribute-row"
27
+ data-attribute-type="${A}"
28
+ data-visibility="${p ? "1" : "0"}"${I}>${g}</tr>`;
29
+ }, m = e(
30
+ o[s](t),
31
+ s,
32
+ l
33
+ ), _ = e(
34
+ o[c](t),
35
+ c,
36
+ r
37
+ ), O = e(
38
+ o[a](t),
39
+ a,
40
+ R
41
+ ), P = e(
42
+ o[d](t),
43
+ d,
44
+ C
45
+ ), u = e(
46
+ o[T](t),
47
+ T,
48
+ b
49
+ ), D = `
50
+ <td class="product-info-cell" valign="middle" style="padding: 15px;">
51
+ <table cellpadding="0" cellspacing="0" role="presentation" width="100%">
52
+ <tbody>
53
+ ${m}
54
+ ${_}
55
+ ${O}
56
+ ${P}
57
+ ${u}
58
+ </tbody>
59
+ </table>
60
+ </td>
61
+ `, U = o[N](t), y = i + D + U;
62
+ return f.replace("{-{-PRODUCT_CONTENT-}-}", y);
63
+ }
64
+ function M(t) {
65
+ return t.map((i, l) => {
66
+ const r = V(i);
67
+ return l > 0 ? $ + r : r;
68
+ }).join("");
69
+ }
70
+ export {
71
+ V as getHorizontalProductCard,
72
+ M as prepareProductRows
73
+ };