@useinsider/guido 2.0.0 → 2.1.0-beta.038f431

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 (320) hide show
  1. package/README.md +2 -0
  2. package/dist/@types/config/schemas.js +72 -54
  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 +16 -15
  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/extensions/recommendation/FilterSelectionDrawer.vue2.js +15 -14
  20. package/dist/components/organisms/header/EditorActions.vue.js +21 -0
  21. package/dist/components/organisms/header/EditorActions.vue2.js +41 -0
  22. package/dist/components/organisms/header/EditorToolbar.vue.js +18 -0
  23. package/dist/components/organisms/header/EditorToolbar.vue2.js +17 -0
  24. package/dist/components/organisms/header/HeaderWrapper.vue.js +6 -5
  25. package/dist/components/organisms/header/LeftSlot.vue.js +11 -11
  26. package/dist/components/organisms/header/LeftSlot.vue2.js +27 -23
  27. package/dist/components/organisms/header/MiddleSlot.vue.js +7 -7
  28. package/dist/components/organisms/header/MiddleSlot.vue2.js +11 -15
  29. package/dist/components/organisms/header/RightSlot.vue.js +11 -14
  30. package/dist/components/organisms/header/RightSlot.vue2.js +13 -30
  31. package/dist/components/organisms/header/version-history/VersionHistory.vue.js +5 -5
  32. package/dist/components/organisms/onboarding/NewVersionPopup.vue2.js +15 -15
  33. package/dist/components/organisms/unsubscribe/UnsubscribeTypeSelection.vue.js +1 -1
  34. package/dist/components/organisms/unsubscribe/UnsubscribeTypeSelection.vue2.js +20 -19
  35. package/dist/composables/useActionsApi.js +33 -30
  36. package/dist/composables/useConfig.js +29 -27
  37. package/dist/composables/useSave.js +13 -11
  38. package/dist/composables/useStripo.js +57 -56
  39. package/dist/config/migrator/index.js +9 -8
  40. package/dist/config/migrator/itemsBlockMigrator.js +334 -0
  41. package/dist/config/migrator/recommendationMigrator.js +2 -2
  42. package/dist/enums/academy.js +8 -0
  43. package/dist/enums/onboarding.js +1 -2
  44. package/dist/enums/unsubscribe.js +20 -21
  45. package/dist/extensions/Blocks/CouponBlock/constants.js +4 -0
  46. package/dist/extensions/Blocks/CouponBlock/controls/index.js +29 -0
  47. package/dist/extensions/Blocks/CouponBlock/extension.js +5 -4
  48. package/dist/extensions/Blocks/CouponBlock/settingsPanel.js +20 -14
  49. package/dist/extensions/Blocks/CouponBlock/template.js +22 -11
  50. package/dist/extensions/Blocks/Items/block.js +36 -40
  51. package/dist/extensions/Blocks/Items/controls/button/link.js +22 -29
  52. package/dist/extensions/Blocks/Items/controls/cardComposition.js +79 -50
  53. package/dist/extensions/Blocks/Items/controls/image/link.js +23 -30
  54. package/dist/extensions/Blocks/Items/controls/name/trimming.js +25 -25
  55. package/dist/extensions/Blocks/Items/controls/price/currencyLocation.js +19 -17
  56. package/dist/extensions/Blocks/Items/controls/price/currencySymbol.js +31 -29
  57. package/dist/extensions/Blocks/Items/controls/price/formattedPrice.js +44 -38
  58. package/dist/extensions/Blocks/Items/controls/price/hideDiscount.js +21 -19
  59. package/dist/extensions/Blocks/Items/controls/price/priceOrientation.js +29 -27
  60. package/dist/extensions/Blocks/Items/controls/price/singlePrice.js +93 -0
  61. package/dist/extensions/Blocks/Items/controls/settingsControl.js +158 -137
  62. package/dist/extensions/Blocks/Items/enums/controlEnums.js +2 -2
  63. package/dist/extensions/Blocks/Items/enums/productEnums.js +43 -45
  64. package/dist/extensions/Blocks/Items/enums/settingsEnums.js +4 -5
  65. package/dist/extensions/Blocks/Items/extension.js +11 -9
  66. package/dist/extensions/Blocks/Items/layouts/horizontal.html.js +58 -49
  67. package/dist/extensions/Blocks/Items/layouts/vertical.html.js +48 -59
  68. package/dist/extensions/Blocks/Items/settingsPanel.js +27 -26
  69. package/dist/extensions/Blocks/Items/store/items-block.js +11 -7
  70. package/dist/extensions/Blocks/Items/template.js +389 -141
  71. package/dist/extensions/Blocks/Items/utils/nodeConfigUtils.js +176 -0
  72. package/dist/extensions/Blocks/Recommendation/block.js +130 -9
  73. package/dist/extensions/Blocks/Recommendation/constants/blockIds.js +4 -0
  74. package/dist/extensions/Blocks/Recommendation/constants/controlIds.js +4 -0
  75. package/dist/extensions/Blocks/Recommendation/constants/defaultConfig.js +65 -0
  76. package/dist/extensions/Blocks/Recommendation/constants/layout.js +20 -0
  77. package/dist/extensions/Blocks/Recommendation/constants/selectors.js +19 -0
  78. package/dist/extensions/Blocks/Recommendation/controls/button/index.js +64 -0
  79. package/dist/extensions/Blocks/Recommendation/controls/cardBackground/index.js +80 -0
  80. package/dist/extensions/Blocks/Recommendation/controls/cardComposition/index.js +232 -0
  81. package/dist/extensions/Blocks/Recommendation/controls/image/index.js +19 -0
  82. package/dist/extensions/Blocks/Recommendation/controls/layout/index.js +92 -0
  83. package/dist/extensions/Blocks/Recommendation/controls/main/algorithm.js +102 -0
  84. package/dist/extensions/Blocks/Recommendation/controls/main/currency.js +209 -0
  85. package/dist/extensions/Blocks/Recommendation/controls/main/filters.js +52 -0
  86. package/dist/extensions/Blocks/Recommendation/controls/main/index.js +217 -0
  87. package/dist/extensions/Blocks/Recommendation/controls/main/locale.js +70 -0
  88. package/dist/extensions/Blocks/Recommendation/controls/main/productLayout.js +110 -0
  89. package/dist/extensions/Blocks/Recommendation/controls/main/shuffle.js +67 -0
  90. package/dist/extensions/Blocks/Recommendation/controls/main/utils.js +286 -0
  91. package/dist/extensions/Blocks/Recommendation/controls/name/index.js +46 -0
  92. package/dist/extensions/Blocks/Recommendation/controls/name/textTrim.js +108 -0
  93. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/index.js +44 -0
  94. package/dist/extensions/Blocks/Recommendation/controls/omnibusDiscount/index.js +48 -0
  95. package/dist/extensions/Blocks/Recommendation/controls/omnibusDiscount/textAfter.js +73 -0
  96. package/dist/extensions/Blocks/Recommendation/controls/omnibusDiscount/textBefore.js +73 -0
  97. package/dist/extensions/Blocks/Recommendation/controls/omnibusPrice/index.js +48 -0
  98. package/dist/extensions/Blocks/Recommendation/controls/omnibusPrice/textAfter.js +73 -0
  99. package/dist/extensions/Blocks/Recommendation/controls/omnibusPrice/textBefore.js +73 -0
  100. package/dist/extensions/Blocks/Recommendation/controls/price/index.js +44 -0
  101. package/dist/extensions/Blocks/Recommendation/controls/spacing/index.js +222 -0
  102. package/dist/extensions/Blocks/Recommendation/extension.js +40 -43
  103. package/dist/extensions/Blocks/Recommendation/iconsRegistry.js +19 -3
  104. package/dist/extensions/Blocks/Recommendation/recommendation.css.js +13 -4
  105. package/dist/extensions/Blocks/Recommendation/services/configService.js +240 -0
  106. package/dist/extensions/Blocks/Recommendation/settingsPanel.js +128 -72
  107. package/dist/extensions/Blocks/Recommendation/store/recommendation.js +230 -193
  108. package/dist/extensions/Blocks/Recommendation/templates/grid/elementRenderer.js +233 -0
  109. package/dist/extensions/Blocks/Recommendation/templates/grid/migration.js +251 -0
  110. package/dist/extensions/Blocks/Recommendation/templates/grid/template.js +69 -0
  111. package/dist/extensions/Blocks/Recommendation/templates/index.js +12 -0
  112. package/dist/extensions/Blocks/Recommendation/templates/list/elementRenderer.js +174 -0
  113. package/dist/extensions/Blocks/Recommendation/templates/list/template.js +73 -0
  114. package/dist/extensions/Blocks/Recommendation/templates/utils.js +122 -0
  115. package/dist/extensions/Blocks/Recommendation/types/nodeConfig.js +6 -0
  116. package/dist/extensions/Blocks/Recommendation/utils/filterUtil.js +9 -9
  117. package/dist/extensions/Blocks/Recommendation/utils/preserveTextStyles.js +36 -0
  118. package/dist/extensions/Blocks/Recommendation/utils/priceFormatter.js +29 -0
  119. package/dist/extensions/Blocks/Recommendation/utils/tagName.js +46 -0
  120. package/dist/extensions/Blocks/Unsubscribe/extension.js +9 -9
  121. package/dist/extensions/Blocks/common-control.js +30 -32
  122. package/dist/extensions/Blocks/controlFactories.js +171 -118
  123. package/dist/guido.css +1 -1
  124. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/esm/index.js +428 -295
  125. package/dist/package.json.js +1 -1
  126. package/dist/services/recommendationApi.js +10 -9
  127. package/dist/services/stripoApi.js +6 -10
  128. package/dist/src/@types/config/index.d.ts +2 -2
  129. package/dist/src/@types/config/schemas.d.ts +36 -2
  130. package/dist/src/@types/config/types.d.ts +7 -1
  131. package/dist/src/components/organisms/email-preview/desktop-preview/DesktopBrowserHeader.vue.d.ts +2 -0
  132. package/dist/src/components/organisms/header/EditorActions.vue.d.ts +4 -0
  133. package/dist/src/components/organisms/header/EditorToolbar.vue.d.ts +2 -0
  134. package/dist/src/components/organisms/header/RightSlot.vue.d.ts +1 -1
  135. package/dist/src/components/wrappers/WpDrawer.vue.d.ts +1 -1
  136. package/dist/src/composables/useActionsApi.d.ts +1 -0
  137. package/dist/src/composables/useConfig.d.ts +10 -0
  138. package/dist/src/config/migrator/itemsBlockMigrator.d.ts +6 -0
  139. package/dist/src/enums/academy.d.ts +12 -0
  140. package/dist/src/enums/onboarding.d.ts +0 -1
  141. package/dist/src/enums/unsubscribe.d.ts +0 -1
  142. package/dist/src/extensions/Blocks/CouponBlock/constants.d.ts +14 -0
  143. package/dist/src/extensions/Blocks/CouponBlock/controls/index.d.ts +108 -0
  144. package/dist/src/extensions/Blocks/CouponBlock/template.d.ts +1 -1
  145. package/dist/src/extensions/Blocks/Items/controls/button/link.d.ts +0 -2
  146. package/dist/src/extensions/Blocks/Items/controls/cardComposition.d.ts +9 -0
  147. package/dist/src/extensions/Blocks/Items/controls/image/link.d.ts +0 -2
  148. package/dist/src/extensions/Blocks/Items/controls/price/priceOrientation.d.ts +1 -1
  149. package/dist/src/extensions/Blocks/Items/controls/price/singlePrice.d.ts +18 -0
  150. package/dist/src/extensions/Blocks/Items/controls/settingsControl.d.ts +0 -4
  151. package/dist/src/extensions/Blocks/Items/enums/controlEnums.d.ts +1 -0
  152. package/dist/src/extensions/Blocks/Items/enums/productEnums.d.ts +24 -26
  153. package/dist/src/extensions/Blocks/Items/enums/settingsEnums.d.ts +1 -2
  154. package/dist/src/extensions/Blocks/Items/store/items-block.d.ts +2 -0
  155. package/dist/src/extensions/Blocks/Items/template.d.ts +22 -1
  156. package/dist/src/extensions/Blocks/Items/utils/nodeConfigUtils.d.ts +76 -0
  157. package/dist/src/extensions/Blocks/Recommendation/block.d.ts +67 -0
  158. package/dist/src/extensions/Blocks/Recommendation/constants/blockIds.d.ts +13 -0
  159. package/dist/src/extensions/Blocks/Recommendation/{constants.d.ts → constants/controlIds.d.ts} +19 -11
  160. package/dist/src/extensions/Blocks/Recommendation/constants/defaultConfig.d.ts +49 -0
  161. package/dist/src/extensions/Blocks/Recommendation/constants/index.d.ts +13 -0
  162. package/dist/src/extensions/Blocks/Recommendation/constants/layout.d.ts +35 -0
  163. package/dist/src/extensions/Blocks/Recommendation/constants/selectors.d.ts +31 -0
  164. package/dist/src/extensions/Blocks/Recommendation/controls/button/index.d.ts +143 -0
  165. package/dist/src/extensions/Blocks/Recommendation/controls/cardBackground/index.d.ts +31 -0
  166. package/dist/src/extensions/Blocks/Recommendation/controls/cardBackgroundColorControl.d.ts +25 -0
  167. package/dist/src/extensions/Blocks/Recommendation/controls/cardComposition/index.d.ts +95 -0
  168. package/dist/src/extensions/Blocks/Recommendation/controls/image/index.d.ts +35 -0
  169. package/dist/src/extensions/Blocks/Recommendation/controls/index.d.ts +24 -0
  170. package/dist/src/extensions/Blocks/Recommendation/controls/layout/index.d.ts +37 -0
  171. package/dist/src/extensions/Blocks/Recommendation/controls/main/algorithm.d.ts +29 -0
  172. package/dist/src/extensions/Blocks/Recommendation/controls/main/currency.d.ts +52 -0
  173. package/dist/src/extensions/Blocks/Recommendation/controls/main/filters.d.ts +22 -0
  174. package/dist/src/extensions/Blocks/Recommendation/controls/main/index.d.ts +68 -0
  175. package/dist/src/extensions/Blocks/Recommendation/controls/main/locale.d.ts +24 -0
  176. package/dist/src/extensions/Blocks/Recommendation/controls/main/productLayout.d.ts +42 -0
  177. package/dist/src/extensions/Blocks/Recommendation/controls/main/shuffle.d.ts +23 -0
  178. package/dist/src/extensions/Blocks/Recommendation/controls/main/utils.d.ts +214 -0
  179. package/dist/src/extensions/Blocks/Recommendation/controls/name/index.d.ts +97 -0
  180. package/dist/src/extensions/Blocks/Recommendation/controls/name/textTrim.d.ts +34 -0
  181. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/index.d.ts +95 -0
  182. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusDiscount/index.d.ts +100 -0
  183. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusDiscount/textAfter.d.ts +15 -0
  184. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusDiscount/textBefore.d.ts +15 -0
  185. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusDiscountTextAfterControl.d.ts +15 -0
  186. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusDiscountTextBeforeControl.d.ts +15 -0
  187. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusPrice/index.d.ts +100 -0
  188. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusPrice/textAfter.d.ts +15 -0
  189. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusPrice/textBefore.d.ts +15 -0
  190. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusPriceTextAfterControl.d.ts +15 -0
  191. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusPriceTextBeforeControl.d.ts +15 -0
  192. package/dist/src/extensions/Blocks/Recommendation/controls/price/index.d.ts +95 -0
  193. package/dist/src/extensions/Blocks/Recommendation/controls/spacing/index.d.ts +83 -0
  194. package/dist/src/extensions/Blocks/Recommendation/controls/spacingControl.d.ts +60 -0
  195. package/dist/src/extensions/Blocks/Recommendation/extension.d.ts +9 -0
  196. package/dist/src/extensions/Blocks/Recommendation/services/configService.d.ts +151 -0
  197. package/dist/src/extensions/Blocks/Recommendation/services/index.d.ts +6 -0
  198. package/dist/src/extensions/Blocks/Recommendation/store/recommendation.d.ts +131 -468
  199. package/dist/src/extensions/Blocks/Recommendation/templates/grid/elementRenderer.d.ts +20 -0
  200. package/dist/src/extensions/Blocks/Recommendation/templates/{migrationTemplate.d.ts → grid/migration.d.ts} +11 -4
  201. package/dist/src/extensions/Blocks/Recommendation/templates/grid/template.d.ts +33 -0
  202. package/dist/src/extensions/Blocks/Recommendation/templates/index.d.ts +39 -0
  203. package/dist/src/extensions/Blocks/Recommendation/templates/list/elementRenderer.d.ts +8 -0
  204. package/dist/src/extensions/Blocks/Recommendation/templates/list/migration.d.ts +25 -0
  205. package/dist/src/extensions/Blocks/Recommendation/templates/list/template.d.ts +18 -0
  206. package/dist/src/extensions/Blocks/Recommendation/templates/utils.d.ts +57 -0
  207. package/dist/src/extensions/Blocks/Recommendation/types/index.d.ts +7 -0
  208. package/dist/src/extensions/Blocks/Recommendation/types/nodeConfig.d.ts +160 -0
  209. package/dist/src/extensions/Blocks/Recommendation/utils/preserveTextStyles.d.ts +19 -0
  210. package/dist/src/extensions/Blocks/Recommendation/utils/priceFormatter.d.ts +33 -0
  211. package/dist/src/extensions/Blocks/Recommendation/utils/stylePreserver.d.ts +113 -0
  212. package/dist/src/extensions/Blocks/Recommendation/utils/tagName.d.ts +77 -0
  213. package/dist/src/extensions/Blocks/common-control.d.ts +10 -11
  214. package/dist/src/extensions/Blocks/controlFactories.d.ts +30 -7
  215. package/dist/src/stores/config.d.ts +181 -1
  216. package/dist/src/stores/editor.d.ts +21 -0
  217. package/dist/static/assets/desktop/desktop-mockup-center.svg.js +4 -0
  218. package/dist/static/assets/desktop/desktop-mockup-left.svg.js +4 -0
  219. package/dist/static/assets/desktop/desktop-mockup-right.svg.js +4 -0
  220. package/dist/static/assets/mobile/email-mockup.svg.js +4 -0
  221. package/dist/static/assets/mobile/inbox-mockup.svg.js +4 -0
  222. package/dist/static/styles/components/button.css.js +1 -1
  223. package/dist/static/styles/components/narrow-panel.css.js +0 -10
  224. package/dist/static/styles/components/wide-panel.css.js +1 -5
  225. package/dist/static/styles/customEditorStyle.css.js +38 -2
  226. package/dist/stores/config.js +7 -0
  227. package/dist/stores/editor.js +1 -0
  228. package/dist/utils/pairProductVariables.js +61 -58
  229. package/dist/utils/templatePreparation.js +17 -17
  230. package/package.json +3 -3
  231. package/dist/components/organisms/email-preview/desktop-preview/EmailHeaderInfo.vue.js +0 -17
  232. package/dist/components/organisms/email-preview/desktop-preview/EmailHeaderInfo.vue2.js +0 -20
  233. package/dist/extensions/Blocks/Items/utils/configBlockUtils.js +0 -17
  234. package/dist/extensions/Blocks/Items/utils/syncAttributeFromConfigBlock.js +0 -28
  235. package/dist/extensions/Blocks/Items/utils/syncAttributesFromConfigBlock.js +0 -76
  236. package/dist/extensions/Blocks/Items/utils/updateAttributes.js +0 -46
  237. package/dist/extensions/Blocks/Recommendation/cardCompositionControl.js +0 -103
  238. package/dist/extensions/Blocks/Recommendation/constants.js +0 -5
  239. package/dist/extensions/Blocks/Recommendation/control.js +0 -306
  240. package/dist/extensions/Blocks/Recommendation/controls/button/align.js +0 -13
  241. package/dist/extensions/Blocks/Recommendation/controls/button/border.js +0 -13
  242. package/dist/extensions/Blocks/Recommendation/controls/button/borderRadius.js +0 -13
  243. package/dist/extensions/Blocks/Recommendation/controls/button/color.js +0 -13
  244. package/dist/extensions/Blocks/Recommendation/controls/button/fitToContent.js +0 -13
  245. package/dist/extensions/Blocks/Recommendation/controls/button/fontFamily.js +0 -13
  246. package/dist/extensions/Blocks/Recommendation/controls/button/margins.js +0 -13
  247. package/dist/extensions/Blocks/Recommendation/controls/button/paddings.js +0 -13
  248. package/dist/extensions/Blocks/Recommendation/controls/button/text.js +0 -13
  249. package/dist/extensions/Blocks/Recommendation/controls/button/textSize.js +0 -13
  250. package/dist/extensions/Blocks/Recommendation/controls/button/textStyleAndFontColor.js +0 -13
  251. package/dist/extensions/Blocks/Recommendation/controls/image/margins.js +0 -13
  252. package/dist/extensions/Blocks/Recommendation/controls/image/size.js +0 -13
  253. package/dist/extensions/Blocks/Recommendation/controls/name/align.js +0 -13
  254. package/dist/extensions/Blocks/Recommendation/controls/name/background.js +0 -13
  255. package/dist/extensions/Blocks/Recommendation/controls/name/color.js +0 -13
  256. package/dist/extensions/Blocks/Recommendation/controls/name/fontFamily.js +0 -13
  257. package/dist/extensions/Blocks/Recommendation/controls/name/paddings.js +0 -13
  258. package/dist/extensions/Blocks/Recommendation/controls/name/size.js +0 -13
  259. package/dist/extensions/Blocks/Recommendation/controls/name/style.js +0 -13
  260. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/align.js +0 -13
  261. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/background.js +0 -13
  262. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/color.js +0 -13
  263. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/fontFamily.js +0 -13
  264. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/paddings.js +0 -13
  265. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/size.js +0 -13
  266. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/style.js +0 -13
  267. package/dist/extensions/Blocks/Recommendation/controls/price/align.js +0 -13
  268. package/dist/extensions/Blocks/Recommendation/controls/price/background.js +0 -13
  269. package/dist/extensions/Blocks/Recommendation/controls/price/color.js +0 -13
  270. package/dist/extensions/Blocks/Recommendation/controls/price/fontFamily.js +0 -13
  271. package/dist/extensions/Blocks/Recommendation/controls/price/paddings.js +0 -13
  272. package/dist/extensions/Blocks/Recommendation/controls/price/size.js +0 -13
  273. package/dist/extensions/Blocks/Recommendation/controls/price/style.js +0 -13
  274. package/dist/extensions/Blocks/Recommendation/templates/blockTemplate.js +0 -160
  275. package/dist/extensions/Blocks/Recommendation/templates/migrationTemplate.js +0 -152
  276. package/dist/extensions/Blocks/Recommendation/templates/templateUtils.js +0 -180
  277. package/dist/src/extensions/Blocks/Items/utils/configBlockUtils.d.ts +0 -23
  278. package/dist/src/extensions/Blocks/Items/utils/syncAttributeFromConfigBlock.d.ts +0 -32
  279. package/dist/src/extensions/Blocks/Items/utils/syncAttributesFromConfigBlock.d.ts +0 -50
  280. package/dist/src/extensions/Blocks/Items/utils/updateAttributes.d.ts +0 -8
  281. package/dist/src/extensions/Blocks/Recommendation/cardCompositionControl.d.ts +0 -28
  282. package/dist/src/extensions/Blocks/Recommendation/control.d.ts +0 -35
  283. package/dist/src/extensions/Blocks/Recommendation/controls/button/align.d.ts +0 -5
  284. package/dist/src/extensions/Blocks/Recommendation/controls/button/border.d.ts +0 -5
  285. package/dist/src/extensions/Blocks/Recommendation/controls/button/borderRadius.d.ts +0 -5
  286. package/dist/src/extensions/Blocks/Recommendation/controls/button/color.d.ts +0 -5
  287. package/dist/src/extensions/Blocks/Recommendation/controls/button/fitToContent.d.ts +0 -5
  288. package/dist/src/extensions/Blocks/Recommendation/controls/button/fontFamily.d.ts +0 -5
  289. package/dist/src/extensions/Blocks/Recommendation/controls/button/margins.d.ts +0 -5
  290. package/dist/src/extensions/Blocks/Recommendation/controls/button/paddings.d.ts +0 -5
  291. package/dist/src/extensions/Blocks/Recommendation/controls/button/text.d.ts +0 -5
  292. package/dist/src/extensions/Blocks/Recommendation/controls/button/textSize.d.ts +0 -5
  293. package/dist/src/extensions/Blocks/Recommendation/controls/button/textStyleAndFontColor.d.ts +0 -5
  294. package/dist/src/extensions/Blocks/Recommendation/controls/image/margins.d.ts +0 -5
  295. package/dist/src/extensions/Blocks/Recommendation/controls/image/size.d.ts +0 -5
  296. package/dist/src/extensions/Blocks/Recommendation/controls/name/align.d.ts +0 -5
  297. package/dist/src/extensions/Blocks/Recommendation/controls/name/background.d.ts +0 -5
  298. package/dist/src/extensions/Blocks/Recommendation/controls/name/color.d.ts +0 -5
  299. package/dist/src/extensions/Blocks/Recommendation/controls/name/fontFamily.d.ts +0 -5
  300. package/dist/src/extensions/Blocks/Recommendation/controls/name/paddings.d.ts +0 -5
  301. package/dist/src/extensions/Blocks/Recommendation/controls/name/size.d.ts +0 -5
  302. package/dist/src/extensions/Blocks/Recommendation/controls/name/style.d.ts +0 -5
  303. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/align.d.ts +0 -5
  304. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/background.d.ts +0 -5
  305. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/color.d.ts +0 -5
  306. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/fontFamily.d.ts +0 -5
  307. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/paddings.d.ts +0 -5
  308. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/size.d.ts +0 -5
  309. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/style.d.ts +0 -5
  310. package/dist/src/extensions/Blocks/Recommendation/controls/price/align.d.ts +0 -5
  311. package/dist/src/extensions/Blocks/Recommendation/controls/price/background.d.ts +0 -5
  312. package/dist/src/extensions/Blocks/Recommendation/controls/price/color.d.ts +0 -5
  313. package/dist/src/extensions/Blocks/Recommendation/controls/price/fontFamily.d.ts +0 -5
  314. package/dist/src/extensions/Blocks/Recommendation/controls/price/paddings.d.ts +0 -5
  315. package/dist/src/extensions/Blocks/Recommendation/controls/price/size.d.ts +0 -5
  316. package/dist/src/extensions/Blocks/Recommendation/controls/price/style.d.ts +0 -5
  317. package/dist/src/extensions/Blocks/Recommendation/templates/blockTemplate.d.ts +0 -16
  318. package/dist/src/extensions/Blocks/Recommendation/templates/templateUtils.d.ts +0 -44
  319. package/dist/static/assets/inbox-mockup.svg.js +0 -4
  320. package/dist/static/assets/phone-mockup.svg.js +0 -4
@@ -0,0 +1,23 @@
1
+ /**
2
+ * Shuffle Products Control
3
+ *
4
+ * Handles the toggle for shuffling/randomizing recommended products.
5
+ * Configuration is stored via node config (persists with template).
6
+ */
7
+ import type { ImmutableHtmlNode } from '@stripoinc/ui-editor-extensions';
8
+ import { CommonControl } from '../../../common-control';
9
+ export declare const SHUFFLE_CONTROL_ID = "recommendation-shuffle-control";
10
+ /**
11
+ * Control for toggling product shuffle/randomization
12
+ */
13
+ export declare class ShuffleControl extends CommonControl {
14
+ private store;
15
+ getId(): string;
16
+ getTemplate(): string;
17
+ onRender(): void;
18
+ onTemplateNodeUpdated(node: ImmutableHtmlNode): void;
19
+ _setFormValues(): void;
20
+ _initializeToggle(): void;
21
+ _onShuffleChange(value: boolean): void;
22
+ _listenToFormUpdates(): void;
23
+ }
@@ -0,0 +1,214 @@
1
+ /**
2
+ * Shared utilities for Recommendation block controls
3
+ *
4
+ * Provides common functionality used across multiple controls:
5
+ * - Layout detection from DOM
6
+ * - Card composition retrieval
7
+ * - Product row regeneration
8
+ * - Spacing reapplication
9
+ * - In-place content updates (style-preserving)
10
+ */
11
+ import type { CurrencyConfig } from '../../types/nodeConfig';
12
+ import type { RecommendationProduct } from '@@/Types/recommendation';
13
+ import type { ImmutableHtmlNode } from '@stripoinc/ui-editor-extensions';
14
+ import { ModificationDescription } from '@stripoinc/ui-editor-extensions';
15
+ import { type Orientation } from '../../templates';
16
+ /**
17
+ * Type for document modifier returned by api.getDocumentModifier()
18
+ *
19
+ * Uses `any` for the modifyHtml return type because:
20
+ * 1. Stripo's actual API uses complex generics (TemplateModifier<HtmlNodeModifier, CssNodeModifier>)
21
+ * 2. Multiple files define their own DocumentModifier with different methods
22
+ * 3. The methods (setStyle, setInnerHtml, setAttribute) chain and return the same object
23
+ *
24
+ * The actual chaining like modifier.modifyHtml(node).setStyle(...).setAttribute(...).apply()
25
+ * works correctly at runtime - this is just a TypeScript compatibility issue.
26
+ */
27
+ interface DocumentModifier {
28
+ modifyHtml: (node: ImmutableHtmlNode) => any;
29
+ apply: (description: ModificationDescription) => void;
30
+ }
31
+ /**
32
+ * Gets the block element from the current node
33
+ * The currentNode could BE the block element or contain it
34
+ * @param currentNode - The current template node
35
+ * @returns The block element or null if not found
36
+ */
37
+ export declare function getBlockElement(currentNode: ImmutableHtmlNode | null | undefined): ImmutableHtmlNode | null;
38
+ /**
39
+ * Gets the current layout orientation from the block's data attribute
40
+ * Supports both old (horizontal/vertical) and new (list/grid) values for backward compatibility
41
+ * @param currentNode - The current template node
42
+ * @returns The layout value ('grid' or 'list'), defaults to 'grid'
43
+ */
44
+ export declare function getCurrentLayout(currentNode: ImmutableHtmlNode | null | undefined): Orientation;
45
+ /**
46
+ * Gets the current card composition from block data attribute or use default
47
+ * @param currentNode - The current template node
48
+ * @returns Array of card element types in order
49
+ */
50
+ export declare function getCardComposition(currentNode: ImmutableHtmlNode | null | undefined): string[];
51
+ export interface RegenerateProductRowsOptions {
52
+ currentNode: ImmutableHtmlNode | null | undefined;
53
+ documentModifier: DocumentModifier;
54
+ afterRegenerate?: () => void;
55
+ /** Optional: pass products directly instead of reading from store */
56
+ products?: RecommendationProduct[];
57
+ /** Optional: pass layout directly to avoid stale DOM reads after setAttribute */
58
+ layout?: Orientation;
59
+ }
60
+ /**
61
+ * Regenerates product rows based on current store configuration
62
+ * Reads products, layout, and composition from store/DOM and rebuilds the HTML
63
+ * @param options - Configuration options for regeneration
64
+ */
65
+ export declare function regenerateProductRows(options: RegenerateProductRowsOptions): void;
66
+ export interface ReapplySpacingOptions {
67
+ currentNode: ImmutableHtmlNode | null | undefined;
68
+ documentModifier: DocumentModifier;
69
+ }
70
+ /**
71
+ * Reapplies spacing values from data attributes after product regeneration
72
+ * This ensures spacing persists when products are regenerated
73
+ * @param options - Configuration options
74
+ */
75
+ export declare function reapplySpacing(options: ReapplySpacingOptions): void;
76
+ export interface RegenerateWithStylesOptions extends Omit<RegenerateProductRowsOptions, 'products' | 'layout'> {
77
+ /** Skip style capture/restore if styles were already handled externally */
78
+ skipStylePreservation?: boolean;
79
+ /** Optional: pass products directly instead of reading from store */
80
+ products?: RecommendationProduct[];
81
+ /** Optional: pass layout directly to avoid stale DOM reads after setAttribute */
82
+ layout?: Orientation;
83
+ }
84
+ /**
85
+ * Regenerates product rows while preserving user-applied styles
86
+ *
87
+ * This unified function handles the complete regeneration flow:
88
+ * 1. Captures existing styles (fonts, colors, button styles, etc.)
89
+ * 2. Regenerates HTML with new products/layout
90
+ * 3. Restores captured styles to new elements
91
+ * 4. Reapplies spacing from data attributes
92
+ *
93
+ * NOTE: Style restoration is temporarily disabled due to Stripo selection bug.
94
+ * Multiple apply() calls (setInnerHtml + restoreStyles + reapplySpacing) cause
95
+ * Stripo's internal cursor/selection tracking to lose node references, resulting in
96
+ * "Cannot read properties of undefined (reading 'textContent')" errors.
97
+ *
98
+ * Use this instead of `regenerateProductRows` when styles must be preserved.
99
+ * @example
100
+ * // When products change (API response, count change, layout change)
101
+ * regenerateProductRowsWithStyles({
102
+ * currentNode: this.currentNode,
103
+ * documentModifier: this.api.getDocumentModifier(),
104
+ * });
105
+ * @param options - Configuration options for regeneration
106
+ */
107
+ export declare function regenerateProductRowsWithStyles(options: RegenerateWithStylesOptions): void;
108
+ type PriceKey = 'price' | 'original_price' | 'discount';
109
+ /**
110
+ * Formats a product price using current currency settings
111
+ * @param product - The product containing price data
112
+ * @param priceKey - Which price to use ('price', 'original_price', or 'discount')
113
+ * @returns Formatted price string
114
+ */
115
+ export declare function formatProductPrice(product: RecommendationProduct, priceKey?: PriceKey): string;
116
+ interface UpdateSingleProductContentOptions {
117
+ documentModifier: DocumentModifier;
118
+ product: RecommendationProduct;
119
+ imageEl: ImmutableHtmlNode | null;
120
+ nameEl: ImmutableHtmlNode | null;
121
+ priceEl: ImmutableHtmlNode | null;
122
+ oldPriceEl: ImmutableHtmlNode | null;
123
+ omnibusPriceEl: ImmutableHtmlNode | null;
124
+ omnibusDiscountEl: ImmutableHtmlNode | null;
125
+ buttonEl: ImmutableHtmlNode | null;
126
+ }
127
+ /**
128
+ * Updates a single product's dynamic content (image, name, prices, button URL)
129
+ * without touching the styled container elements.
130
+ *
131
+ * Uses setText() on text nodes instead of setInnerHtml() to preserve Stripo's
132
+ * internal node references and avoid cursor/selection tracking issues.
133
+ * @returns true if any modifications were made
134
+ */
135
+ export declare function updateSingleProductContent(options: UpdateSingleProductContentOptions): boolean;
136
+ export interface UpdateProductContentInPlaceOptions {
137
+ currentNode: ImmutableHtmlNode | null | undefined;
138
+ documentModifier: DocumentModifier;
139
+ products: RecommendationProduct[];
140
+ }
141
+ /**
142
+ * Updates product content in-place without regenerating HTML structure.
143
+ * Preserves all user-applied styles by only touching dynamic content.
144
+ *
145
+ * This is the preferred method when:
146
+ * - Product data changed but count remains the same
147
+ * - Currency/locale changed (prices need reformatting)
148
+ *
149
+ * Uses setText() on text nodes instead of setInnerHtml() to preserve
150
+ * Stripo's internal node references and avoid cursor/selection tracking issues.
151
+ *
152
+ * Falls back to false when:
153
+ * - Product count changed (need to add/remove elements)
154
+ * - Cannot find required elements
155
+ * @param options - Configuration options
156
+ * @returns true if in-place update was successful, false to fall back to full regeneration
157
+ */
158
+ export declare function updateProductContentInPlace(options: UpdateProductContentInPlaceOptions): boolean;
159
+ export interface UpdatePricesInPlaceOptions {
160
+ currentNode: ImmutableHtmlNode | null | undefined;
161
+ documentModifier: DocumentModifier;
162
+ }
163
+ /**
164
+ * Updates only price displays in-place (for currency changes).
165
+ * This is a lightweight update when only formatting changes, not product data.
166
+ *
167
+ * Perfect for:
168
+ * - Currency symbol change
169
+ * - Currency alignment change
170
+ * - Decimal/thousand separator changes
171
+ *
172
+ * Uses setText() on text nodes instead of setInnerHtml() to preserve
173
+ * Stripo's internal node references and avoid cursor/selection tracking issues.
174
+ * @param options - Configuration options
175
+ * @returns true if update was successful, false otherwise
176
+ */
177
+ export declare function updatePricesInPlace(options: UpdatePricesInPlaceOptions): boolean;
178
+ /**
179
+ * Gets current card background color from existing elements
180
+ * Checks both grid (.product-card-segment) and list (.product-card-wrapper) selectors
181
+ * @param currentNode - The current template node
182
+ * @returns Background color string or null if not found
183
+ */
184
+ export declare function getCurrentCardBackgroundColor(currentNode: ImmutableHtmlNode | null | undefined): string | null;
185
+ export interface ApplyCardBackgroundColorOptions {
186
+ currentNode: ImmutableHtmlNode | null | undefined;
187
+ documentModifier: DocumentModifier;
188
+ bgColor: string | null;
189
+ layout: Orientation;
190
+ }
191
+ /**
192
+ * Applies card background color to appropriate elements based on layout
193
+ * @param options - Configuration options
194
+ */
195
+ export declare function applyCardBackgroundColor(options: ApplyCardBackgroundColorOptions): void;
196
+ export interface SetCurrencyAttributesOptions {
197
+ currentNode: ImmutableHtmlNode | null | undefined;
198
+ documentModifier: DocumentModifier;
199
+ currency: CurrencyConfig;
200
+ }
201
+ /**
202
+ * Sets currency configuration as HTML attributes on the block element
203
+ * These attributes are read by the HTML compiler at runtime to format prices
204
+ * @param options - Configuration options
205
+ */
206
+ export declare function setCurrencyAttributes(options: SetCurrencyAttributesOptions): void;
207
+ /**
208
+ * Reads currency configuration from block HTML attributes
209
+ * Used to restore settings when loading a template
210
+ * @param currentNode - The current template node
211
+ * @returns CurrencyConfig or null if attributes not found
212
+ */
213
+ export declare function getCurrencyAttributesFromBlock(currentNode: ImmutableHtmlNode | null | undefined): Partial<CurrencyConfig> | null;
214
+ export {};
@@ -0,0 +1,97 @@
1
+ /**
2
+ * Name Element Controls
3
+ *
4
+ * Controls for styling the product name element in recommendation cards.
5
+ */
6
+ import { NameTextTrimControl } from './textTrim';
7
+ /**
8
+ * Grouped Name Controls
9
+ * Use this object for cleaner imports in extension.ts
10
+ */
11
+ export declare const NameControls: {
12
+ readonly align: {
13
+ new (): {
14
+ getId(): string;
15
+ getTargetNodes(root: import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode): import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode[];
16
+ getParentControlId(): string;
17
+ api: import("@stripoinc/ui-editor-extensions").ControlApi;
18
+ getLabels(): import("@stripoinc/ui-editor-extensions").ControlLabels | undefined;
19
+ getModificationDescription(): import("@stripoinc/ui-editor-extensions").ModificationDescription | undefined;
20
+ getAdditionalModifications(_root: import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode): import("@stripoinc/ui-editor-extensions").TemplateModifier<import("@stripoinc/ui-editor-extensions").HtmlNodeModifier, import("@stripoinc/ui-editor-extensions").CssNodeModifier> | undefined;
21
+ isVisible(_node: import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode): boolean;
22
+ };
23
+ };
24
+ readonly color: {
25
+ new (): {
26
+ getId(): string;
27
+ getTargetNodes(root: import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode): import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode[];
28
+ getParentControlId(): string;
29
+ api: import("@stripoinc/ui-editor-extensions").ControlApi;
30
+ getLabels(): import("@stripoinc/ui-editor-extensions").ControlLabels | undefined;
31
+ getModificationDescription(): import("@stripoinc/ui-editor-extensions").ModificationDescription | undefined;
32
+ getAdditionalModifications(_root: import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode): import("@stripoinc/ui-editor-extensions").TemplateModifier<import("@stripoinc/ui-editor-extensions").HtmlNodeModifier, import("@stripoinc/ui-editor-extensions").CssNodeModifier> | undefined;
33
+ isVisible(_node: import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode): boolean;
34
+ };
35
+ };
36
+ readonly size: {
37
+ new (): {
38
+ getId(): string;
39
+ getTargetNodes(root: import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode): import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode[];
40
+ getParentControlId(): string;
41
+ api: import("@stripoinc/ui-editor-extensions").ControlApi;
42
+ getLabels(): import("@stripoinc/ui-editor-extensions").ControlLabels | undefined;
43
+ getModificationDescription(): import("@stripoinc/ui-editor-extensions").ModificationDescription | undefined;
44
+ getAdditionalModifications(_root: import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode): import("@stripoinc/ui-editor-extensions").TemplateModifier<import("@stripoinc/ui-editor-extensions").HtmlNodeModifier, import("@stripoinc/ui-editor-extensions").CssNodeModifier> | undefined;
45
+ isVisible(_node: import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode): boolean;
46
+ };
47
+ };
48
+ readonly style: {
49
+ new (): {
50
+ getId(): string;
51
+ getTargetNodes(root: import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode): import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode[];
52
+ getParentControlId(): string;
53
+ api: import("@stripoinc/ui-editor-extensions").ControlApi;
54
+ getLabels(): import("@stripoinc/ui-editor-extensions").ControlLabels | undefined;
55
+ getModificationDescription(): import("@stripoinc/ui-editor-extensions").ModificationDescription | undefined;
56
+ getAdditionalModifications(_root: import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode): import("@stripoinc/ui-editor-extensions").TemplateModifier<import("@stripoinc/ui-editor-extensions").HtmlNodeModifier, import("@stripoinc/ui-editor-extensions").CssNodeModifier> | undefined;
57
+ isVisible(_node: import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode): boolean;
58
+ };
59
+ };
60
+ readonly fontFamily: {
61
+ new (): {
62
+ getId(): string;
63
+ getTargetNodes(root: import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode): import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode[];
64
+ getParentControlId(): string;
65
+ api: import("@stripoinc/ui-editor-extensions").ControlApi;
66
+ getLabels(): import("@stripoinc/ui-editor-extensions").ControlLabels | undefined;
67
+ getModificationDescription(): import("@stripoinc/ui-editor-extensions").ModificationDescription | undefined;
68
+ getAdditionalModifications(_root: import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode): import("@stripoinc/ui-editor-extensions").TemplateModifier<import("@stripoinc/ui-editor-extensions").HtmlNodeModifier, import("@stripoinc/ui-editor-extensions").CssNodeModifier> | undefined;
69
+ isVisible(_node: import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode): boolean;
70
+ };
71
+ };
72
+ readonly background: {
73
+ new (): {
74
+ getId(): string;
75
+ getTargetNodes(root: import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode): import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode[];
76
+ getParentControlId(): string;
77
+ api: import("@stripoinc/ui-editor-extensions").ControlApi;
78
+ getLabels(): import("@stripoinc/ui-editor-extensions").ControlLabels | undefined;
79
+ getModificationDescription(): import("@stripoinc/ui-editor-extensions").ModificationDescription | undefined;
80
+ getAdditionalModifications(_root: import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode): import("@stripoinc/ui-editor-extensions").TemplateModifier<import("@stripoinc/ui-editor-extensions").HtmlNodeModifier, import("@stripoinc/ui-editor-extensions").CssNodeModifier> | undefined;
81
+ isVisible(_node: import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode): boolean;
82
+ };
83
+ };
84
+ readonly paddings: {
85
+ new (): {
86
+ getId(): string;
87
+ getTargetNodes(root: import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode): import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode[];
88
+ getParentControlId(): string;
89
+ api: import("@stripoinc/ui-editor-extensions").ControlApi;
90
+ getLabels(): import("@stripoinc/ui-editor-extensions").ControlLabels | undefined;
91
+ getModificationDescription(): import("@stripoinc/ui-editor-extensions").ModificationDescription | undefined;
92
+ getAdditionalModifications(_root: import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode): import("@stripoinc/ui-editor-extensions").TemplateModifier<import("@stripoinc/ui-editor-extensions").HtmlNodeModifier, import("@stripoinc/ui-editor-extensions").CssNodeModifier> | undefined;
93
+ isVisible(_node: import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode): boolean;
94
+ };
95
+ };
96
+ readonly textTrim: typeof NameTextTrimControl;
97
+ };
@@ -0,0 +1,34 @@
1
+ import { ImmutableCssNode, ImmutableHtmlNode } from '@stripoinc/ui-editor-extensions';
2
+ import { CommonControl } from '../../../common-control';
3
+ /**
4
+ * Control for enabling/disabling text trimming on product names
5
+ * When enabled, adds a CSS class that applies text-overflow: ellipsis
6
+ * and injects the required CSS rules into the document stylesheet
7
+ */
8
+ export declare class NameTextTrimControl extends CommonControl {
9
+ getId(): string;
10
+ getTemplate(): string;
11
+ onRender(): void;
12
+ onTemplateNodeUpdated(node: ImmutableHtmlNode): void;
13
+ _setFormValues(): void;
14
+ _getCurrentTrimState(): boolean;
15
+ /**
16
+ * Finds an existing CSS rule in the document stylesheet by exact query
17
+ * @param query - The CSS query to search for (uses Stripo's CSS query syntax)
18
+ * @returns The CSS rule node if found, undefined otherwise
19
+ */
20
+ _findCssRule(query: string): ImmutableCssNode | undefined;
21
+ /**
22
+ * Finds the .text-trim-enabled p rule by searching all text-trim rules and comparing selectors
23
+ * This is needed because Stripo's CSS query syntax interprets spaces as path separators
24
+ * @returns true if the rule exists
25
+ */
26
+ _hasParagraphRule(): boolean;
27
+ /**
28
+ * Ensures the text-trim CSS rules exist in the document stylesheet
29
+ * Only adds rules if they don't already exist (prevents duplicates across multiple blocks)
30
+ */
31
+ _ensureCssRulesExist(): void;
32
+ _onTextTrimChange(enabled: boolean): void;
33
+ _listenToFormUpdates(): void;
34
+ }
@@ -0,0 +1,95 @@
1
+ /**
2
+ * Old Price Element Controls
3
+ *
4
+ * Controls for styling the original/old price element in recommendation cards.
5
+ */
6
+ /**
7
+ * Grouped Old Price Controls
8
+ * Use this object for cleaner imports in extension.ts
9
+ */
10
+ export declare const OldPriceControls: {
11
+ readonly align: {
12
+ new (): {
13
+ getId(): string;
14
+ getTargetNodes(root: import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode): import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode[];
15
+ getParentControlId(): string;
16
+ api: import("@stripoinc/ui-editor-extensions").ControlApi;
17
+ getLabels(): import("@stripoinc/ui-editor-extensions").ControlLabels | undefined;
18
+ getModificationDescription(): import("@stripoinc/ui-editor-extensions").ModificationDescription | undefined;
19
+ getAdditionalModifications(_root: import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode): import("@stripoinc/ui-editor-extensions").TemplateModifier<import("@stripoinc/ui-editor-extensions").HtmlNodeModifier, import("@stripoinc/ui-editor-extensions").CssNodeModifier> | undefined;
20
+ isVisible(_node: import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode): boolean;
21
+ };
22
+ };
23
+ readonly color: {
24
+ new (): {
25
+ getId(): string;
26
+ getTargetNodes(root: import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode): import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode[];
27
+ getParentControlId(): string;
28
+ api: import("@stripoinc/ui-editor-extensions").ControlApi;
29
+ getLabels(): import("@stripoinc/ui-editor-extensions").ControlLabels | undefined;
30
+ getModificationDescription(): import("@stripoinc/ui-editor-extensions").ModificationDescription | undefined;
31
+ getAdditionalModifications(_root: import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode): import("@stripoinc/ui-editor-extensions").TemplateModifier<import("@stripoinc/ui-editor-extensions").HtmlNodeModifier, import("@stripoinc/ui-editor-extensions").CssNodeModifier> | undefined;
32
+ isVisible(_node: import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode): boolean;
33
+ };
34
+ };
35
+ readonly size: {
36
+ new (): {
37
+ getId(): string;
38
+ getTargetNodes(root: import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode): import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode[];
39
+ getParentControlId(): string;
40
+ api: import("@stripoinc/ui-editor-extensions").ControlApi;
41
+ getLabels(): import("@stripoinc/ui-editor-extensions").ControlLabels | undefined;
42
+ getModificationDescription(): import("@stripoinc/ui-editor-extensions").ModificationDescription | undefined;
43
+ getAdditionalModifications(_root: import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode): import("@stripoinc/ui-editor-extensions").TemplateModifier<import("@stripoinc/ui-editor-extensions").HtmlNodeModifier, import("@stripoinc/ui-editor-extensions").CssNodeModifier> | undefined;
44
+ isVisible(_node: import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode): boolean;
45
+ };
46
+ };
47
+ readonly style: {
48
+ new (): {
49
+ getId(): string;
50
+ getTargetNodes(root: import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode): import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode[];
51
+ getParentControlId(): string;
52
+ api: import("@stripoinc/ui-editor-extensions").ControlApi;
53
+ getLabels(): import("@stripoinc/ui-editor-extensions").ControlLabels | undefined;
54
+ getModificationDescription(): import("@stripoinc/ui-editor-extensions").ModificationDescription | undefined;
55
+ getAdditionalModifications(_root: import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode): import("@stripoinc/ui-editor-extensions").TemplateModifier<import("@stripoinc/ui-editor-extensions").HtmlNodeModifier, import("@stripoinc/ui-editor-extensions").CssNodeModifier> | undefined;
56
+ isVisible(_node: import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode): boolean;
57
+ };
58
+ };
59
+ readonly fontFamily: {
60
+ new (): {
61
+ getId(): string;
62
+ getTargetNodes(root: import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode): import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode[];
63
+ getParentControlId(): string;
64
+ api: import("@stripoinc/ui-editor-extensions").ControlApi;
65
+ getLabels(): import("@stripoinc/ui-editor-extensions").ControlLabels | undefined;
66
+ getModificationDescription(): import("@stripoinc/ui-editor-extensions").ModificationDescription | undefined;
67
+ getAdditionalModifications(_root: import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode): import("@stripoinc/ui-editor-extensions").TemplateModifier<import("@stripoinc/ui-editor-extensions").HtmlNodeModifier, import("@stripoinc/ui-editor-extensions").CssNodeModifier> | undefined;
68
+ isVisible(_node: import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode): boolean;
69
+ };
70
+ };
71
+ readonly background: {
72
+ new (): {
73
+ getId(): string;
74
+ getTargetNodes(root: import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode): import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode[];
75
+ getParentControlId(): string;
76
+ api: import("@stripoinc/ui-editor-extensions").ControlApi;
77
+ getLabels(): import("@stripoinc/ui-editor-extensions").ControlLabels | undefined;
78
+ getModificationDescription(): import("@stripoinc/ui-editor-extensions").ModificationDescription | undefined;
79
+ getAdditionalModifications(_root: import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode): import("@stripoinc/ui-editor-extensions").TemplateModifier<import("@stripoinc/ui-editor-extensions").HtmlNodeModifier, import("@stripoinc/ui-editor-extensions").CssNodeModifier> | undefined;
80
+ isVisible(_node: import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode): boolean;
81
+ };
82
+ };
83
+ readonly paddings: {
84
+ new (): {
85
+ getId(): string;
86
+ getTargetNodes(root: import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode): import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode[];
87
+ getParentControlId(): string;
88
+ api: import("@stripoinc/ui-editor-extensions").ControlApi;
89
+ getLabels(): import("@stripoinc/ui-editor-extensions").ControlLabels | undefined;
90
+ getModificationDescription(): import("@stripoinc/ui-editor-extensions").ModificationDescription | undefined;
91
+ getAdditionalModifications(_root: import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode): import("@stripoinc/ui-editor-extensions").TemplateModifier<import("@stripoinc/ui-editor-extensions").HtmlNodeModifier, import("@stripoinc/ui-editor-extensions").CssNodeModifier> | undefined;
92
+ isVisible(_node: import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode): boolean;
93
+ };
94
+ };
95
+ };
@@ -0,0 +1,100 @@
1
+ /**
2
+ * Omnibus Discount Element Controls
3
+ *
4
+ * Controls for styling the omnibus discount element in recommendation cards.
5
+ * Includes text before/after controls for compliance text.
6
+ */
7
+ import { OmnibusDiscountTextAfterControl } from './textAfter';
8
+ import { OmnibusDiscountTextBeforeControl } from './textBefore';
9
+ /**
10
+ * Grouped Omnibus Discount Controls
11
+ * Use this object for cleaner imports in extension.ts
12
+ */
13
+ export declare const OmnibusDiscountControls: {
14
+ readonly align: {
15
+ new (): {
16
+ getId(): string;
17
+ getTargetNodes(root: import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode): import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode[];
18
+ getParentControlId(): string;
19
+ api: import("@stripoinc/ui-editor-extensions").ControlApi;
20
+ getLabels(): import("@stripoinc/ui-editor-extensions").ControlLabels | undefined;
21
+ getModificationDescription(): import("@stripoinc/ui-editor-extensions").ModificationDescription | undefined;
22
+ getAdditionalModifications(_root: import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode): import("@stripoinc/ui-editor-extensions").TemplateModifier<import("@stripoinc/ui-editor-extensions").HtmlNodeModifier, import("@stripoinc/ui-editor-extensions").CssNodeModifier> | undefined;
23
+ isVisible(_node: import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode): boolean;
24
+ };
25
+ };
26
+ readonly color: {
27
+ new (): {
28
+ getId(): string;
29
+ getTargetNodes(root: import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode): import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode[];
30
+ getParentControlId(): string;
31
+ api: import("@stripoinc/ui-editor-extensions").ControlApi;
32
+ getLabels(): import("@stripoinc/ui-editor-extensions").ControlLabels | undefined;
33
+ getModificationDescription(): import("@stripoinc/ui-editor-extensions").ModificationDescription | undefined;
34
+ getAdditionalModifications(_root: import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode): import("@stripoinc/ui-editor-extensions").TemplateModifier<import("@stripoinc/ui-editor-extensions").HtmlNodeModifier, import("@stripoinc/ui-editor-extensions").CssNodeModifier> | undefined;
35
+ isVisible(_node: import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode): boolean;
36
+ };
37
+ };
38
+ readonly size: {
39
+ new (): {
40
+ getId(): string;
41
+ getTargetNodes(root: import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode): import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode[];
42
+ getParentControlId(): string;
43
+ api: import("@stripoinc/ui-editor-extensions").ControlApi;
44
+ getLabels(): import("@stripoinc/ui-editor-extensions").ControlLabels | undefined;
45
+ getModificationDescription(): import("@stripoinc/ui-editor-extensions").ModificationDescription | undefined;
46
+ getAdditionalModifications(_root: import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode): import("@stripoinc/ui-editor-extensions").TemplateModifier<import("@stripoinc/ui-editor-extensions").HtmlNodeModifier, import("@stripoinc/ui-editor-extensions").CssNodeModifier> | undefined;
47
+ isVisible(_node: import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode): boolean;
48
+ };
49
+ };
50
+ readonly style: {
51
+ new (): {
52
+ getId(): string;
53
+ getTargetNodes(root: import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode): import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode[];
54
+ getParentControlId(): string;
55
+ api: import("@stripoinc/ui-editor-extensions").ControlApi;
56
+ getLabels(): import("@stripoinc/ui-editor-extensions").ControlLabels | undefined;
57
+ getModificationDescription(): import("@stripoinc/ui-editor-extensions").ModificationDescription | undefined;
58
+ getAdditionalModifications(_root: import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode): import("@stripoinc/ui-editor-extensions").TemplateModifier<import("@stripoinc/ui-editor-extensions").HtmlNodeModifier, import("@stripoinc/ui-editor-extensions").CssNodeModifier> | undefined;
59
+ isVisible(_node: import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode): boolean;
60
+ };
61
+ };
62
+ readonly fontFamily: {
63
+ new (): {
64
+ getId(): string;
65
+ getTargetNodes(root: import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode): import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode[];
66
+ getParentControlId(): string;
67
+ api: import("@stripoinc/ui-editor-extensions").ControlApi;
68
+ getLabels(): import("@stripoinc/ui-editor-extensions").ControlLabels | undefined;
69
+ getModificationDescription(): import("@stripoinc/ui-editor-extensions").ModificationDescription | undefined;
70
+ getAdditionalModifications(_root: import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode): import("@stripoinc/ui-editor-extensions").TemplateModifier<import("@stripoinc/ui-editor-extensions").HtmlNodeModifier, import("@stripoinc/ui-editor-extensions").CssNodeModifier> | undefined;
71
+ isVisible(_node: import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode): boolean;
72
+ };
73
+ };
74
+ readonly background: {
75
+ new (): {
76
+ getId(): string;
77
+ getTargetNodes(root: import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode): import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode[];
78
+ getParentControlId(): string;
79
+ api: import("@stripoinc/ui-editor-extensions").ControlApi;
80
+ getLabels(): import("@stripoinc/ui-editor-extensions").ControlLabels | undefined;
81
+ getModificationDescription(): import("@stripoinc/ui-editor-extensions").ModificationDescription | undefined;
82
+ getAdditionalModifications(_root: import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode): import("@stripoinc/ui-editor-extensions").TemplateModifier<import("@stripoinc/ui-editor-extensions").HtmlNodeModifier, import("@stripoinc/ui-editor-extensions").CssNodeModifier> | undefined;
83
+ isVisible(_node: import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode): boolean;
84
+ };
85
+ };
86
+ readonly paddings: {
87
+ new (): {
88
+ getId(): string;
89
+ getTargetNodes(root: import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode): import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode[];
90
+ getParentControlId(): string;
91
+ api: import("@stripoinc/ui-editor-extensions").ControlApi;
92
+ getLabels(): import("@stripoinc/ui-editor-extensions").ControlLabels | undefined;
93
+ getModificationDescription(): import("@stripoinc/ui-editor-extensions").ModificationDescription | undefined;
94
+ getAdditionalModifications(_root: import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode): import("@stripoinc/ui-editor-extensions").TemplateModifier<import("@stripoinc/ui-editor-extensions").HtmlNodeModifier, import("@stripoinc/ui-editor-extensions").CssNodeModifier> | undefined;
95
+ isVisible(_node: import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode): boolean;
96
+ };
97
+ };
98
+ readonly textBefore: typeof OmnibusDiscountTextBeforeControl;
99
+ readonly textAfter: typeof OmnibusDiscountTextAfterControl;
100
+ };
@@ -0,0 +1,15 @@
1
+ import { ImmutableHtmlNode } from '@stripoinc/ui-editor-extensions';
2
+ import { CommonControl } from '../../../common-control';
3
+ /**
4
+ * Control for setting text after Omnibus Discount value
5
+ */
6
+ export declare class OmnibusDiscountTextAfterControl extends CommonControl {
7
+ getId(): string;
8
+ getTemplate(): string;
9
+ onRender(): void;
10
+ onTemplateNodeUpdated(node: ImmutableHtmlNode): void;
11
+ _setFormValues(): void;
12
+ _getCurrentText(): string;
13
+ _onTextChange(newText: string): void;
14
+ _listenToFormUpdates(): void;
15
+ }
@@ -0,0 +1,15 @@
1
+ import { ImmutableHtmlNode } from '@stripoinc/ui-editor-extensions';
2
+ import { CommonControl } from '../../../common-control';
3
+ /**
4
+ * Control for setting text before Omnibus Discount value
5
+ */
6
+ export declare class OmnibusDiscountTextBeforeControl extends CommonControl {
7
+ getId(): string;
8
+ getTemplate(): string;
9
+ onRender(): void;
10
+ onTemplateNodeUpdated(node: ImmutableHtmlNode): void;
11
+ _setFormValues(): void;
12
+ _getCurrentText(): string;
13
+ _onTextChange(newText: string): void;
14
+ _listenToFormUpdates(): void;
15
+ }
@@ -0,0 +1,15 @@
1
+ import { ImmutableHtmlNode } from '@stripoinc/ui-editor-extensions';
2
+ import { CommonControl } from '../../common-control';
3
+ /**
4
+ * Control for setting text after Omnibus Discount value
5
+ */
6
+ export declare class OmnibusDiscountTextAfterControl extends CommonControl {
7
+ getId(): string;
8
+ getTemplate(): string;
9
+ onRender(): void;
10
+ onTemplateNodeUpdated(node: ImmutableHtmlNode): void;
11
+ _setFormValues(): void;
12
+ _getCurrentText(): string;
13
+ _onTextChange(newText: string): void;
14
+ _listenToFormUpdates(): void;
15
+ }
@@ -0,0 +1,15 @@
1
+ import { ImmutableHtmlNode } from '@stripoinc/ui-editor-extensions';
2
+ import { CommonControl } from '../../common-control';
3
+ /**
4
+ * Control for setting text before Omnibus Discount value
5
+ */
6
+ export declare class OmnibusDiscountTextBeforeControl extends CommonControl {
7
+ getId(): string;
8
+ getTemplate(): string;
9
+ onRender(): void;
10
+ onTemplateNodeUpdated(node: ImmutableHtmlNode): void;
11
+ _setFormValues(): void;
12
+ _getCurrentText(): string;
13
+ _onTextChange(newText: string): void;
14
+ _listenToFormUpdates(): void;
15
+ }