@useinsider/guido 2.0.0-beta.061e9c9 → 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 (192) hide show
  1. package/dist/@types/config/schemas.js +53 -39
  2. package/dist/components/organisms/email-preview/PreviewContainer.vue.js +3 -3
  3. package/dist/components/organisms/email-preview/amp/AmpErrorModal.vue.js +6 -6
  4. package/dist/components/organisms/email-preview/amp/AmpErrorModal.vue2.js +17 -13
  5. package/dist/components/organisms/email-preview/amp/AmpToggle.vue.js +6 -6
  6. package/dist/components/organisms/email-preview/amp/AmpToggle.vue2.js +14 -12
  7. package/dist/components/organisms/email-preview/desktop-preview/DesktopBrowserHeader.vue.js +18 -0
  8. package/dist/components/organisms/email-preview/desktop-preview/DesktopBrowserHeader.vue2.js +15 -0
  9. package/dist/components/organisms/email-preview/desktop-preview/DesktopPreview.vue.js +10 -14
  10. package/dist/components/organisms/email-preview/desktop-preview/DesktopPreview.vue2.js +14 -22
  11. package/dist/components/organisms/email-preview/desktop-preview/EmailSizeIndicator.vue.js +3 -3
  12. package/dist/components/organisms/email-preview/mobile-preview/ContentView.vue.js +11 -10
  13. package/dist/components/organisms/email-preview/mobile-preview/InboxView.vue.js +12 -10
  14. package/dist/components/organisms/email-preview/mobile-preview/MobilePreview.vue.js +11 -10
  15. package/dist/components/organisms/email-preview/mobile-preview/MobilePreview.vue2.js +15 -14
  16. package/dist/components/organisms/header/EditorActions.vue.js +21 -0
  17. package/dist/components/organisms/header/EditorActions.vue2.js +41 -0
  18. package/dist/components/organisms/header/EditorToolbar.vue.js +18 -0
  19. package/dist/components/organisms/header/EditorToolbar.vue2.js +17 -0
  20. package/dist/components/organisms/header/HeaderWrapper.vue.js +6 -5
  21. package/dist/components/organisms/header/LeftSlot.vue.js +11 -11
  22. package/dist/components/organisms/header/LeftSlot.vue2.js +11 -12
  23. package/dist/components/organisms/header/MiddleSlot.vue.js +7 -7
  24. package/dist/components/organisms/header/MiddleSlot.vue2.js +11 -15
  25. package/dist/components/organisms/header/RightSlot.vue.js +11 -14
  26. package/dist/components/organisms/header/RightSlot.vue2.js +13 -30
  27. package/dist/components/organisms/header/version-history/VersionHistory.vue.js +5 -5
  28. package/dist/components/organisms/onboarding/NewVersionPopup.vue2.js +15 -15
  29. package/dist/components/organisms/unsubscribe/UnsubscribeTypeSelection.vue.js +1 -1
  30. package/dist/components/organisms/unsubscribe/UnsubscribeTypeSelection.vue2.js +20 -19
  31. package/dist/composables/useActionsApi.js +33 -30
  32. package/dist/composables/useConfig.js +29 -27
  33. package/dist/composables/useSave.js +13 -11
  34. package/dist/config/migrator/recommendationMigrator.js +2 -2
  35. package/dist/enums/academy.js +8 -0
  36. package/dist/enums/onboarding.js +1 -2
  37. package/dist/enums/unsubscribe.js +20 -21
  38. package/dist/extensions/Blocks/Items/controls/cardComposition.js +13 -4
  39. package/dist/extensions/Blocks/Recommendation/block.js +40 -6
  40. package/dist/extensions/Blocks/Recommendation/constants/blockIds.js +4 -0
  41. package/dist/extensions/Blocks/Recommendation/constants/controlIds.js +4 -0
  42. package/dist/extensions/Blocks/Recommendation/constants/defaultConfig.js +64 -0
  43. package/dist/extensions/Blocks/Recommendation/constants/layout.js +20 -0
  44. package/dist/extensions/Blocks/Recommendation/constants/selectors.js +19 -0
  45. package/dist/extensions/Blocks/Recommendation/controls/button/index.js +64 -0
  46. package/dist/extensions/Blocks/Recommendation/controls/cardBackground/index.js +80 -0
  47. package/dist/extensions/Blocks/Recommendation/controls/cardComposition/index.js +232 -0
  48. package/dist/extensions/Blocks/Recommendation/controls/image/index.js +19 -0
  49. package/dist/extensions/Blocks/Recommendation/controls/layout/index.js +96 -0
  50. package/dist/extensions/Blocks/Recommendation/controls/main/algorithm.js +110 -0
  51. package/dist/extensions/Blocks/Recommendation/controls/main/currency.js +204 -0
  52. package/dist/extensions/Blocks/Recommendation/controls/main/filters.js +54 -0
  53. package/dist/extensions/Blocks/Recommendation/controls/main/index.js +205 -0
  54. package/dist/extensions/Blocks/Recommendation/controls/main/locale.js +74 -0
  55. package/dist/extensions/Blocks/Recommendation/controls/main/productLayout.js +118 -0
  56. package/dist/extensions/Blocks/Recommendation/controls/main/shuffle.js +71 -0
  57. package/dist/extensions/Blocks/Recommendation/controls/main/utils.js +286 -0
  58. package/dist/extensions/Blocks/Recommendation/controls/name/index.js +46 -0
  59. package/dist/extensions/Blocks/Recommendation/controls/name/textTrim.js +76 -0
  60. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/index.js +44 -0
  61. package/dist/extensions/Blocks/Recommendation/controls/omnibusDiscount/index.js +48 -0
  62. package/dist/extensions/Blocks/Recommendation/controls/{omnibusDiscountTextAfterControl.js → omnibusDiscount/textAfter.js} +16 -14
  63. package/dist/extensions/Blocks/Recommendation/controls/{omnibusDiscountTextBeforeControl.js → omnibusDiscount/textBefore.js} +16 -14
  64. package/dist/extensions/Blocks/Recommendation/controls/omnibusPrice/index.js +48 -0
  65. package/dist/extensions/Blocks/Recommendation/controls/{omnibusPriceTextAfterControl.js → omnibusPrice/textAfter.js} +16 -14
  66. package/dist/extensions/Blocks/Recommendation/controls/{omnibusPriceTextBeforeControl.js → omnibusPrice/textBefore.js} +14 -12
  67. package/dist/extensions/Blocks/Recommendation/controls/price/index.js +44 -0
  68. package/dist/extensions/Blocks/Recommendation/controls/spacing/index.js +222 -0
  69. package/dist/extensions/Blocks/Recommendation/extension.js +40 -19
  70. package/dist/extensions/Blocks/Recommendation/iconsRegistry.js +19 -3
  71. package/dist/extensions/Blocks/Recommendation/recommendation.css.js +13 -4
  72. package/dist/extensions/Blocks/Recommendation/services/configService.js +239 -0
  73. package/dist/extensions/Blocks/Recommendation/settingsPanel.js +46 -43
  74. package/dist/extensions/Blocks/Recommendation/store/recommendation.js +41 -36
  75. package/dist/extensions/Blocks/Recommendation/templates/grid/elementRenderer.js +233 -0
  76. package/dist/extensions/Blocks/Recommendation/templates/grid/migration.js +251 -0
  77. package/dist/extensions/Blocks/Recommendation/templates/grid/template.js +69 -0
  78. package/dist/extensions/Blocks/Recommendation/templates/index.js +12 -0
  79. package/dist/extensions/Blocks/Recommendation/templates/list/elementRenderer.js +174 -0
  80. package/dist/extensions/Blocks/Recommendation/templates/list/template.js +73 -0
  81. package/dist/extensions/Blocks/Recommendation/templates/utils.js +121 -0
  82. package/dist/extensions/Blocks/Recommendation/types/nodeConfig.js +6 -0
  83. package/dist/extensions/Blocks/Recommendation/utils/filterUtil.js +9 -9
  84. package/dist/extensions/Blocks/Recommendation/utils/preserveTextStyles.js +27 -16
  85. package/dist/extensions/Blocks/Recommendation/utils/priceFormatter.js +29 -0
  86. package/dist/extensions/Blocks/Recommendation/utils/tagName.js +46 -0
  87. package/dist/extensions/Blocks/Unsubscribe/extension.js +9 -9
  88. package/dist/extensions/Blocks/common-control.js +6 -7
  89. package/dist/extensions/Blocks/controlFactories.js +156 -122
  90. package/dist/guido.css +1 -1
  91. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/esm/index.js +423 -291
  92. package/dist/package.json.js +1 -1
  93. package/dist/services/recommendationApi.js +10 -9
  94. package/dist/src/@types/config/index.d.ts +2 -2
  95. package/dist/src/@types/config/schemas.d.ts +26 -0
  96. package/dist/src/@types/config/types.d.ts +7 -1
  97. package/dist/src/components/organisms/email-preview/desktop-preview/DesktopBrowserHeader.vue.d.ts +2 -0
  98. package/dist/src/components/organisms/header/EditorActions.vue.d.ts +4 -0
  99. package/dist/src/components/organisms/header/EditorToolbar.vue.d.ts +2 -0
  100. package/dist/src/components/organisms/header/RightSlot.vue.d.ts +1 -1
  101. package/dist/src/components/wrappers/WpDrawer.vue.d.ts +1 -1
  102. package/dist/src/composables/useActionsApi.d.ts +1 -0
  103. package/dist/src/composables/useConfig.d.ts +6 -0
  104. package/dist/src/enums/academy.d.ts +12 -0
  105. package/dist/src/enums/onboarding.d.ts +0 -1
  106. package/dist/src/enums/unsubscribe.d.ts +0 -1
  107. package/dist/src/extensions/Blocks/Recommendation/block.d.ts +34 -0
  108. package/dist/src/extensions/Blocks/Recommendation/constants/blockIds.d.ts +13 -0
  109. package/dist/src/extensions/Blocks/Recommendation/{constants.d.ts → constants/controlIds.d.ts} +1 -33
  110. package/dist/src/extensions/Blocks/Recommendation/constants/defaultConfig.d.ts +49 -0
  111. package/dist/src/extensions/Blocks/Recommendation/constants/index.d.ts +13 -0
  112. package/dist/src/extensions/Blocks/Recommendation/constants/layout.d.ts +35 -0
  113. package/dist/src/extensions/Blocks/Recommendation/constants/selectors.d.ts +31 -0
  114. package/dist/src/extensions/Blocks/Recommendation/controls/button/index.d.ts +143 -0
  115. package/dist/src/extensions/Blocks/Recommendation/controls/{cardBackgroundColorControl.d.ts → cardBackground/index.d.ts} +9 -3
  116. package/dist/src/extensions/Blocks/Recommendation/{cardCompositionControl.d.ts → controls/cardComposition/index.d.ts} +23 -7
  117. package/dist/src/extensions/Blocks/Recommendation/controls/image/index.d.ts +35 -0
  118. package/dist/src/extensions/Blocks/Recommendation/controls/index.d.ts +21 -651
  119. package/dist/src/extensions/Blocks/Recommendation/controls/layout/index.d.ts +37 -0
  120. package/dist/src/extensions/Blocks/Recommendation/controls/main/algorithm.d.ts +29 -0
  121. package/dist/src/extensions/Blocks/Recommendation/controls/main/currency.d.ts +45 -0
  122. package/dist/src/extensions/Blocks/Recommendation/controls/main/filters.d.ts +22 -0
  123. package/dist/src/extensions/Blocks/Recommendation/controls/main/index.d.ts +57 -0
  124. package/dist/src/extensions/Blocks/Recommendation/controls/main/locale.d.ts +24 -0
  125. package/dist/src/extensions/Blocks/Recommendation/controls/main/productLayout.d.ts +42 -0
  126. package/dist/src/extensions/Blocks/Recommendation/controls/main/shuffle.d.ts +23 -0
  127. package/dist/src/extensions/Blocks/Recommendation/controls/main/utils.d.ts +214 -0
  128. package/dist/src/extensions/Blocks/Recommendation/controls/name/index.d.ts +97 -0
  129. package/dist/src/extensions/Blocks/Recommendation/controls/{nameTextTrimControl.d.ts → name/textTrim.d.ts} +1 -1
  130. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/index.d.ts +95 -0
  131. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusDiscount/index.d.ts +100 -0
  132. package/dist/src/extensions/Blocks/Recommendation/controls/{omnibusDiscountTextAfterControl.d.ts → omnibusDiscount/textAfter.d.ts} +1 -1
  133. package/dist/src/extensions/Blocks/Recommendation/controls/{omnibusDiscountTextBeforeControl.d.ts → omnibusDiscount/textBefore.d.ts} +1 -1
  134. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusPrice/index.d.ts +100 -0
  135. package/dist/src/extensions/Blocks/Recommendation/controls/{omnibusPriceTextAfterControl.d.ts → omnibusPrice/textAfter.d.ts} +1 -1
  136. package/dist/src/extensions/Blocks/Recommendation/controls/{omnibusPriceTextBeforeControl.d.ts → omnibusPrice/textBefore.d.ts} +1 -1
  137. package/dist/src/extensions/Blocks/Recommendation/controls/price/index.d.ts +95 -0
  138. package/dist/src/extensions/Blocks/Recommendation/controls/{spacingControl.d.ts → spacing/index.d.ts} +33 -10
  139. package/dist/src/extensions/Blocks/Recommendation/extension.d.ts +9 -0
  140. package/dist/src/extensions/Blocks/Recommendation/services/configService.d.ts +151 -0
  141. package/dist/src/extensions/Blocks/Recommendation/services/index.d.ts +6 -0
  142. package/dist/src/extensions/Blocks/Recommendation/store/recommendation.d.ts +17 -16
  143. package/dist/src/extensions/Blocks/Recommendation/templates/grid/elementRenderer.d.ts +20 -0
  144. package/dist/src/extensions/Blocks/Recommendation/templates/grid/migration.d.ts +23 -0
  145. package/dist/src/extensions/Blocks/Recommendation/templates/grid/template.d.ts +33 -0
  146. package/dist/src/extensions/Blocks/Recommendation/templates/index.d.ts +39 -0
  147. package/dist/src/extensions/Blocks/Recommendation/templates/list/elementRenderer.d.ts +8 -0
  148. package/dist/src/extensions/Blocks/Recommendation/templates/list/migration.d.ts +25 -0
  149. package/dist/src/extensions/Blocks/Recommendation/templates/list/template.d.ts +18 -0
  150. package/dist/src/extensions/Blocks/Recommendation/templates/utils.d.ts +54 -0
  151. package/dist/src/extensions/Blocks/Recommendation/types/index.d.ts +7 -0
  152. package/dist/src/extensions/Blocks/Recommendation/types/nodeConfig.d.ts +154 -0
  153. package/dist/src/extensions/Blocks/Recommendation/utils/priceFormatter.d.ts +33 -0
  154. package/dist/src/extensions/Blocks/Recommendation/utils/stylePreserver.d.ts +113 -0
  155. package/dist/src/extensions/Blocks/Recommendation/utils/tagName.d.ts +77 -0
  156. package/dist/src/extensions/Blocks/common-control.d.ts +1 -1
  157. package/dist/src/stores/config.d.ts +147 -1
  158. package/dist/src/stores/editor.d.ts +21 -0
  159. package/dist/static/assets/desktop/desktop-mockup-center.svg.js +4 -0
  160. package/dist/static/assets/desktop/desktop-mockup-left.svg.js +4 -0
  161. package/dist/static/assets/desktop/desktop-mockup-right.svg.js +4 -0
  162. package/dist/static/assets/mobile/email-mockup.svg.js +4 -0
  163. package/dist/static/assets/mobile/inbox-mockup.svg.js +4 -0
  164. package/dist/static/styles/components/button.css.js +1 -1
  165. package/dist/static/styles/components/wide-panel.css.js +1 -1
  166. package/dist/static/styles/customEditorStyle.css.js +25 -2
  167. package/dist/stores/config.js +7 -0
  168. package/dist/stores/editor.js +1 -0
  169. package/dist/utils/templatePreparation.js +17 -17
  170. package/package.json +3 -3
  171. package/dist/components/organisms/email-preview/desktop-preview/EmailHeaderInfo.vue.js +0 -17
  172. package/dist/components/organisms/email-preview/desktop-preview/EmailHeaderInfo.vue2.js +0 -20
  173. package/dist/extensions/Blocks/Recommendation/cardCompositionControl.js +0 -193
  174. package/dist/extensions/Blocks/Recommendation/constants.js +0 -14
  175. package/dist/extensions/Blocks/Recommendation/control.js +0 -321
  176. package/dist/extensions/Blocks/Recommendation/controls/cardBackgroundColorControl.js +0 -68
  177. package/dist/extensions/Blocks/Recommendation/controls/index.js +0 -272
  178. package/dist/extensions/Blocks/Recommendation/controls/nameTextTrimControl.js +0 -74
  179. package/dist/extensions/Blocks/Recommendation/controls/priceHideControl.js +0 -60
  180. package/dist/extensions/Blocks/Recommendation/controls/priceInlineLayoutControl.js +0 -160
  181. package/dist/extensions/Blocks/Recommendation/controls/spacingControl.js +0 -188
  182. package/dist/extensions/Blocks/Recommendation/templates/blockTemplate.js +0 -184
  183. package/dist/extensions/Blocks/Recommendation/templates/migrationTemplate.js +0 -189
  184. package/dist/extensions/Blocks/Recommendation/templates/templateUtils.js +0 -209
  185. package/dist/src/extensions/Blocks/Recommendation/control.d.ts +0 -38
  186. package/dist/src/extensions/Blocks/Recommendation/controls/priceHideControl.d.ts +0 -16
  187. package/dist/src/extensions/Blocks/Recommendation/controls/priceInlineLayoutControl.d.ts +0 -50
  188. package/dist/src/extensions/Blocks/Recommendation/templates/blockTemplate.d.ts +0 -16
  189. package/dist/src/extensions/Blocks/Recommendation/templates/migrationTemplate.d.ts +0 -16
  190. package/dist/src/extensions/Blocks/Recommendation/templates/templateUtils.d.ts +0 -52
  191. package/dist/static/assets/inbox-mockup.svg.js +0 -4
  192. package/dist/static/assets/phone-mockup.svg.js +0 -4
@@ -0,0 +1,143 @@
1
+ /**
2
+ * Button Element Controls
3
+ *
4
+ * Controls for styling the CTA button element in recommendation cards.
5
+ */
6
+ /**
7
+ * Grouped Button Controls
8
+ * Use this object for cleaner imports in extension.ts
9
+ */
10
+ export declare const ButtonControls: {
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 border: {
24
+ new (): {
25
+ getId(): string;
26
+ getTargetNodes(root: import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode): import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode[];
27
+ getParentControlId(): string;
28
+ getLabels(): import("@stripoinc/ui-editor-extensions").ButtonBorderControlLabels | undefined;
29
+ api: import("@stripoinc/ui-editor-extensions").ControlApi;
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 borderRadius: {
36
+ new (): {
37
+ getId(): string;
38
+ getTargetNodes(root: import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode): import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode[];
39
+ getParentControlId(): string;
40
+ getLabels(): import("@stripoinc/ui-editor-extensions").ButtonBorderRadiusControlLabels | undefined;
41
+ api: import("@stripoinc/ui-editor-extensions").ControlApi;
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 color: {
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 margins: {
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
+ readonly text: {
96
+ new (): {
97
+ getId(): string;
98
+ getTargetNodes(root: import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode): import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode[];
99
+ getParentControlId(): string;
100
+ api: import("@stripoinc/ui-editor-extensions").ControlApi;
101
+ getLabels(): import("@stripoinc/ui-editor-extensions").ControlLabels | undefined;
102
+ getModificationDescription(): import("@stripoinc/ui-editor-extensions").ModificationDescription | undefined;
103
+ 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;
104
+ isVisible(_node: import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode): boolean;
105
+ };
106
+ };
107
+ readonly textSize: {
108
+ new (): {
109
+ getId(): string;
110
+ getTargetNodes(root: import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode): import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode[];
111
+ getParentControlId(): string;
112
+ api: import("@stripoinc/ui-editor-extensions").ControlApi;
113
+ getLabels(): import("@stripoinc/ui-editor-extensions").ControlLabels | undefined;
114
+ getModificationDescription(): import("@stripoinc/ui-editor-extensions").ModificationDescription | undefined;
115
+ 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;
116
+ isVisible(_node: import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode): boolean;
117
+ };
118
+ };
119
+ readonly textStyleAndFontColor: {
120
+ new (): {
121
+ getId(): string;
122
+ getTargetNodes(root: import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode): import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode[];
123
+ getParentControlId(): string;
124
+ getLabels(): import("@stripoinc/ui-editor-extensions").ButtonTextStyleAndFontColorControlLabels | undefined;
125
+ api: import("@stripoinc/ui-editor-extensions").ControlApi;
126
+ getModificationDescription(): import("@stripoinc/ui-editor-extensions").ModificationDescription | undefined;
127
+ 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;
128
+ isVisible(_node: import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode): boolean;
129
+ };
130
+ };
131
+ readonly fitToContent: {
132
+ new (): {
133
+ getId(): string;
134
+ getTargetNodes(root: import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode): import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode[];
135
+ getParentControlId(): string;
136
+ api: import("@stripoinc/ui-editor-extensions").ControlApi;
137
+ getLabels(): import("@stripoinc/ui-editor-extensions").ControlLabels | undefined;
138
+ getModificationDescription(): import("@stripoinc/ui-editor-extensions").ModificationDescription | undefined;
139
+ 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;
140
+ isVisible(_node: import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode): boolean;
141
+ };
142
+ };
143
+ };
@@ -1,5 +1,5 @@
1
1
  import { ImmutableHtmlNode } from '@stripoinc/ui-editor-extensions';
2
- import { CommonControl } from '../../common-control';
2
+ import { CommonControl } from '../../../common-control';
3
3
  export declare const CARD_BACKGROUND_COLOR_CONTROL_ID = "recommendation-card-background-color-control";
4
4
  /**
5
5
  * Control for managing recommendation card background color
@@ -12,13 +12,19 @@ export declare class CardBackgroundColorControl extends CommonControl {
12
12
  onTemplateNodeUpdated(node: ImmutableHtmlNode): void;
13
13
  _setFormValues(): void;
14
14
  /**
15
- * Reads the current background color from the first product card wrapper
15
+ * Gets the appropriate selector based on layout
16
+ * Grid: .product-card-segment (inner table per product cell)
17
+ * List: .product-card-wrapper (table per product row)
18
+ */
19
+ _getCardSelector(): string;
20
+ /**
21
+ * Reads the current background color from the first product card element
16
22
  * @returns The background color value or 'transparent' if not found
17
23
  */
18
24
  _getCurrentCardBackgroundColor(): string;
19
25
  /**
20
26
  * Handles card background color changes
21
- * Applies the color to all product card wrapper elements
27
+ * Applies the color to all product card elements based on layout
22
28
  */
23
29
  _onCardBackgroundColorChange(color: string): void;
24
30
  _listenToFormUpdates(): void;
@@ -1,5 +1,5 @@
1
1
  import { ImmutableHtmlNode } from '@stripoinc/ui-editor-extensions';
2
- import { CommonControl } from '../common-control';
2
+ import { CommonControl } from '../../../common-control';
3
3
  export declare const COMPOSITION_CONTROL_BLOCK_ID = "ui-elements-recommendation-card-composition";
4
4
  export interface CardCompositionItem {
5
5
  key: string;
@@ -7,6 +7,8 @@ export interface CardCompositionItem {
7
7
  visible: boolean;
8
8
  }
9
9
  export declare class RecommendationCardCompositionControl extends CommonControl {
10
+ private store;
11
+ private unsubscribeOrientation;
10
12
  getId(): string;
11
13
  getTemplate(): string;
12
14
  onRender(): void;
@@ -28,10 +30,6 @@ export declare class RecommendationCardCompositionControl extends CommonControl
28
30
  * Falls back to default order if attribute is not present
29
31
  */
30
32
  private _readCompositionFromNode;
31
- /**
32
- * Gets default composition order
33
- */
34
- private _getDefaultComposition;
35
33
  /**
36
34
  * Builds visibility values object from the visibility map
37
35
  */
@@ -61,10 +59,12 @@ export declare class RecommendationCardCompositionControl extends CommonControl
61
59
  /**
62
60
  * Apply the reordered composition to the block's HTML structure
63
61
  * Updates the data-card-composition attribute and reorders product attributes
62
+ * Note: Reordering is only applied for grid layout
64
63
  */
65
64
  private _applyCompositionToBlock;
66
65
  /**
67
- * Reorders attribute rows within each product row based on composition order
66
+ * Reorders attribute rows within each product card based on composition order
67
+ * Targets the tbody inside each product-attribute-cell to preserve card structure
68
68
  */
69
69
  private _reorderProductAttributes;
70
70
  /**
@@ -73,7 +73,23 @@ export declare class RecommendationCardCompositionControl extends CommonControl
73
73
  private _buildCompositionHtml;
74
74
  /**
75
75
  * Apply visibility changes to the block's HTML structure
76
- * Updates display style and data-visibility attribute for all matching rows
76
+ * Updates display style and data-visibility attribute for all matching elements
77
+ * - <tr> elements: use display: none / table-row
78
+ * - <td> elements: use display: none / table-cell
77
79
  */
78
80
  private _applyVisibilityToBlock;
81
+ /**
82
+ * Gets the current layout orientation from store or DOM
83
+ */
84
+ private _getCurrentLayout;
85
+ /**
86
+ * Updates orderable state based on layout orientation
87
+ * Adds/removes disabled class to hide drag icons for list layout
88
+ */
89
+ private _updateOrderableState;
90
+ /**
91
+ * Subscribe to store orientation changes
92
+ * Updates orderable state when layout changes via the layout control
93
+ */
94
+ private _subscribeToOrientationChanges;
79
95
  }
@@ -0,0 +1,35 @@
1
+ /**
2
+ * Image Element Controls
3
+ *
4
+ * Controls for styling the product image element in recommendation cards.
5
+ */
6
+ /**
7
+ * Grouped Image Controls
8
+ * Use this object for cleaner imports in extension.ts
9
+ */
10
+ export declare const ImageControls: {
11
+ readonly size: {
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 margins: {
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
+ };