@useinsider/guido 2.0.0-beta.dbde199 → 2.0.0-beta.e66a90a

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 (117) hide show
  1. package/dist/@types/config/schemas.js +53 -39
  2. package/dist/components/organisms/email-preview/amp/AmpToggle.vue.js +2 -2
  3. package/dist/components/organisms/header/RightSlot.vue2.js +10 -10
  4. package/dist/composables/useConfig.js +29 -27
  5. package/dist/composables/useSave.js +13 -11
  6. package/dist/config/migrator/recommendationMigrator.js +2 -2
  7. package/dist/extensions/Blocks/Recommendation/block.js +1 -1
  8. package/dist/extensions/Blocks/Recommendation/constants/blockIds.js +4 -0
  9. package/dist/extensions/Blocks/Recommendation/constants/controlIds.js +4 -0
  10. package/dist/extensions/Blocks/Recommendation/constants/selectors.js +11 -0
  11. package/dist/extensions/Blocks/Recommendation/controls/button/index.js +64 -0
  12. package/dist/extensions/Blocks/Recommendation/controls/cardBackground/index.js +100 -0
  13. package/dist/extensions/Blocks/Recommendation/controls/cardComposition/index.js +243 -0
  14. package/dist/extensions/Blocks/Recommendation/controls/image/index.js +19 -0
  15. package/dist/extensions/Blocks/Recommendation/controls/layout/index.js +104 -0
  16. package/dist/extensions/Blocks/Recommendation/controls/main/algorithm.js +86 -0
  17. package/dist/extensions/Blocks/Recommendation/controls/main/currency.js +134 -0
  18. package/dist/extensions/Blocks/Recommendation/controls/main/filters.js +54 -0
  19. package/dist/extensions/Blocks/Recommendation/controls/main/index.js +106 -0
  20. package/dist/extensions/Blocks/Recommendation/controls/main/locale.js +64 -0
  21. package/dist/extensions/Blocks/Recommendation/controls/main/productLayout.js +123 -0
  22. package/dist/extensions/Blocks/Recommendation/controls/main/shuffle.js +60 -0
  23. package/dist/extensions/Blocks/Recommendation/controls/main/utils.js +112 -0
  24. package/dist/extensions/Blocks/Recommendation/controls/name/index.js +46 -0
  25. package/dist/extensions/Blocks/Recommendation/controls/name/textTrim.js +76 -0
  26. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/index.js +44 -0
  27. package/dist/extensions/Blocks/Recommendation/controls/omnibusDiscount/index.js +48 -0
  28. package/dist/extensions/Blocks/Recommendation/controls/{omnibusDiscountTextAfterControl.js → omnibusDiscount/textAfter.js} +15 -13
  29. package/dist/extensions/Blocks/Recommendation/controls/{omnibusDiscountTextBeforeControl.js → omnibusDiscount/textBefore.js} +15 -13
  30. package/dist/extensions/Blocks/Recommendation/controls/omnibusPrice/index.js +48 -0
  31. package/dist/extensions/Blocks/Recommendation/controls/{omnibusPriceTextAfterControl.js → omnibusPrice/textAfter.js} +16 -14
  32. package/dist/extensions/Blocks/Recommendation/controls/{omnibusPriceTextBeforeControl.js → omnibusPrice/textBefore.js} +14 -12
  33. package/dist/extensions/Blocks/Recommendation/controls/price/index.js +44 -0
  34. package/dist/extensions/Blocks/Recommendation/controls/spacing/index.js +224 -0
  35. package/dist/extensions/Blocks/Recommendation/extension.js +40 -19
  36. package/dist/extensions/Blocks/Recommendation/recommendation.css.js +5 -0
  37. package/dist/extensions/Blocks/Recommendation/settingsPanel.js +46 -43
  38. package/dist/extensions/Blocks/Recommendation/store/recommendation.js +20 -20
  39. package/dist/extensions/Blocks/Recommendation/templates/horizontal/elementRenderer.js +157 -0
  40. package/dist/extensions/Blocks/Recommendation/templates/horizontal/template.js +72 -0
  41. package/dist/extensions/Blocks/Recommendation/templates/index.js +12 -0
  42. package/dist/extensions/Blocks/Recommendation/templates/utils.js +173 -0
  43. package/dist/extensions/Blocks/Recommendation/templates/vertical/elementRenderer.js +186 -0
  44. package/dist/extensions/Blocks/Recommendation/templates/vertical/migration.js +251 -0
  45. package/dist/extensions/Blocks/Recommendation/templates/vertical/template.js +61 -0
  46. package/dist/extensions/Blocks/Unsubscribe/extension.js +9 -9
  47. package/dist/extensions/Blocks/common-control.js +6 -7
  48. package/dist/extensions/Blocks/controlFactories.js +156 -122
  49. package/dist/guido.css +1 -1
  50. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/esm/index.js +110 -113
  51. package/dist/src/@types/config/index.d.ts +2 -2
  52. package/dist/src/@types/config/schemas.d.ts +26 -0
  53. package/dist/src/@types/config/types.d.ts +7 -1
  54. package/dist/src/composables/useConfig.d.ts +6 -0
  55. package/dist/src/extensions/Blocks/Recommendation/constants/blockIds.d.ts +13 -0
  56. package/dist/src/extensions/Blocks/Recommendation/{constants.d.ts → constants/controlIds.d.ts} +1 -33
  57. package/dist/src/extensions/Blocks/Recommendation/constants/index.d.ts +11 -0
  58. package/dist/src/extensions/Blocks/Recommendation/constants/selectors.d.ts +19 -0
  59. package/dist/src/extensions/Blocks/Recommendation/controls/button/index.d.ts +143 -0
  60. package/dist/src/extensions/Blocks/Recommendation/controls/{cardBackgroundColorControl.d.ts → cardBackground/index.d.ts} +19 -3
  61. package/dist/src/extensions/Blocks/Recommendation/{cardCompositionControl.d.ts → controls/cardComposition/index.d.ts} +23 -7
  62. package/dist/src/extensions/Blocks/Recommendation/controls/image/index.d.ts +35 -0
  63. package/dist/src/extensions/Blocks/Recommendation/controls/index.d.ts +21 -651
  64. package/dist/src/extensions/Blocks/Recommendation/controls/layout/index.d.ts +34 -0
  65. package/dist/src/extensions/Blocks/Recommendation/controls/main/algorithm.d.ts +17 -0
  66. package/dist/src/extensions/Blocks/Recommendation/controls/main/currency.d.ts +16 -0
  67. package/dist/src/extensions/Blocks/Recommendation/controls/main/filters.d.ts +22 -0
  68. package/dist/src/extensions/Blocks/Recommendation/controls/main/index.d.ts +54 -0
  69. package/dist/src/extensions/Blocks/Recommendation/controls/main/locale.d.ts +15 -0
  70. package/dist/src/extensions/Blocks/Recommendation/controls/main/productLayout.d.ts +40 -0
  71. package/dist/src/extensions/Blocks/Recommendation/controls/main/shuffle.d.ts +15 -0
  72. package/dist/src/extensions/Blocks/Recommendation/controls/main/utils.d.ts +81 -0
  73. package/dist/src/extensions/Blocks/Recommendation/controls/name/index.d.ts +97 -0
  74. package/dist/src/extensions/Blocks/Recommendation/controls/{nameTextTrimControl.d.ts → name/textTrim.d.ts} +1 -1
  75. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/index.d.ts +95 -0
  76. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusDiscount/index.d.ts +100 -0
  77. package/dist/src/extensions/Blocks/Recommendation/controls/{omnibusDiscountTextAfterControl.d.ts → omnibusDiscount/textAfter.d.ts} +1 -1
  78. package/dist/src/extensions/Blocks/Recommendation/controls/{omnibusDiscountTextBeforeControl.d.ts → omnibusDiscount/textBefore.d.ts} +1 -1
  79. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusPrice/index.d.ts +100 -0
  80. package/dist/src/extensions/Blocks/Recommendation/controls/{omnibusPriceTextAfterControl.d.ts → omnibusPrice/textAfter.d.ts} +1 -1
  81. package/dist/src/extensions/Blocks/Recommendation/controls/{omnibusPriceTextBeforeControl.d.ts → omnibusPrice/textBefore.d.ts} +1 -1
  82. package/dist/src/extensions/Blocks/Recommendation/controls/price/index.d.ts +95 -0
  83. package/dist/src/extensions/Blocks/Recommendation/controls/{spacingControl.d.ts → spacing/index.d.ts} +26 -9
  84. package/dist/src/extensions/Blocks/Recommendation/extension.d.ts +9 -0
  85. package/dist/src/extensions/Blocks/Recommendation/store/recommendation.d.ts +16 -16
  86. package/dist/src/extensions/Blocks/Recommendation/templates/horizontal/elementRenderer.d.ts +8 -0
  87. package/dist/src/extensions/Blocks/Recommendation/templates/horizontal/migration.d.ts +25 -0
  88. package/dist/src/extensions/Blocks/Recommendation/templates/horizontal/template.d.ts +18 -0
  89. package/dist/src/extensions/Blocks/Recommendation/templates/index.d.ts +39 -0
  90. package/dist/src/extensions/Blocks/Recommendation/templates/utils.d.ts +45 -0
  91. package/dist/src/extensions/Blocks/Recommendation/templates/vertical/elementRenderer.d.ts +7 -0
  92. package/dist/src/extensions/Blocks/Recommendation/templates/vertical/migration.d.ts +23 -0
  93. package/dist/src/extensions/Blocks/Recommendation/templates/vertical/template.d.ts +33 -0
  94. package/dist/src/extensions/Blocks/common-control.d.ts +1 -1
  95. package/dist/src/stores/config.d.ts +147 -1
  96. package/dist/static/styles/components/button.css.js +1 -1
  97. package/dist/static/styles/customEditorStyle.css.js +25 -2
  98. package/dist/stores/config.js +7 -0
  99. package/package.json +1 -1
  100. package/dist/extensions/Blocks/Recommendation/cardCompositionControl.js +0 -193
  101. package/dist/extensions/Blocks/Recommendation/constants.js +0 -14
  102. package/dist/extensions/Blocks/Recommendation/control.js +0 -336
  103. package/dist/extensions/Blocks/Recommendation/controls/cardBackgroundColorControl.js +0 -68
  104. package/dist/extensions/Blocks/Recommendation/controls/index.js +0 -272
  105. package/dist/extensions/Blocks/Recommendation/controls/nameTextTrimControl.js +0 -74
  106. package/dist/extensions/Blocks/Recommendation/controls/priceHideControl.js +0 -60
  107. package/dist/extensions/Blocks/Recommendation/controls/priceInlineLayoutControl.js +0 -160
  108. package/dist/extensions/Blocks/Recommendation/controls/spacingControl.js +0 -188
  109. package/dist/extensions/Blocks/Recommendation/templates/blockTemplate.js +0 -184
  110. package/dist/extensions/Blocks/Recommendation/templates/migrationTemplate.js +0 -189
  111. package/dist/extensions/Blocks/Recommendation/templates/templateUtils.js +0 -209
  112. package/dist/src/extensions/Blocks/Recommendation/control.d.ts +0 -38
  113. package/dist/src/extensions/Blocks/Recommendation/controls/priceHideControl.d.ts +0 -16
  114. package/dist/src/extensions/Blocks/Recommendation/controls/priceInlineLayoutControl.d.ts +0 -50
  115. package/dist/src/extensions/Blocks/Recommendation/templates/blockTemplate.d.ts +0 -16
  116. package/dist/src/extensions/Blocks/Recommendation/templates/migrationTemplate.d.ts +0 -16
  117. package/dist/src/extensions/Blocks/Recommendation/templates/templateUtils.d.ts +0 -52
@@ -1,28 +1,3 @@
1
- /**
2
- * Attribute type constants used in templates
3
- * These are used as keys in ElementRenderer and composition arrays
4
- */
5
- export declare const ATTR_PRODUCT_IMAGE = "productImage";
6
- export declare const ATTR_PRODUCT_NAME = "productName";
7
- export declare const ATTR_PRODUCT_PRICE = "productPrice";
8
- export declare const ATTR_PRODUCT_OLD_PRICE = "productOldPrice";
9
- export declare const ATTR_PRODUCT_OMNIBUS_PRICE = "productOmnibusPrice";
10
- export declare const ATTR_PRODUCT_OMNIBUS_DISCOUNT = "productOmnibusDiscount";
11
- export declare const ATTR_PRODUCT_BUTTON = "productButton";
12
- export declare const ATTR_DATA_PRICE_INLINE = "data-price-inline";
13
- /**
14
- * Block IDs used in the Recommendation Extension
15
- * These IDs are used in the esd-extension-block-id attribute to identify specific blocks
16
- */
17
- export declare enum RecommendationBlockId {
18
- BUTTON = "recommendation-block-button",
19
- NAME = "recommendation-block-name",
20
- PRICE = "recommendation-block-price",
21
- OLD_PRICE = "recommendation-block-old-price",
22
- OMNIBUS_PRICE = "recommendation-block-omnibus-price",
23
- OMNIBUS_DISCOUNT = "recommendation-block-omnibus-discount",
24
- IMAGE = "recommendation-block-image"
25
- }
26
1
  /**
27
2
  * Control IDs used in the Recommendation Extension
28
3
  * These IDs are returned by the getId() method of each control
@@ -43,7 +18,6 @@ export declare enum RecommendationControlId {
43
18
  NAME_BACKGROUND = "recommendation-block-name-background-control",
44
19
  NAME_COLOR = "recommendation-block-name-color-control",
45
20
  NAME_FONT_FAMILY = "recommendation-block-name-font-family-control",
46
- NAME_LINE_SPACING = "recommendation-block-name-line-spacing-control",
47
21
  NAME_PADDINGS = "recommendation-block-name-paddings-control",
48
22
  NAME_SIZE = "recommendation-block-name-size-control",
49
23
  NAME_STYLE = "recommendation-block-name-style-control",
@@ -52,8 +26,6 @@ export declare enum RecommendationControlId {
52
26
  PRICE_BACKGROUND = "recommendation-block-price-background-control",
53
27
  PRICE_COLOR = "recommendation-block-price-color-control",
54
28
  PRICE_FONT_FAMILY = "recommendation-block-price-font-family-control",
55
- PRICE_HIDE_IF_SAME = "recommendation-block-price-hide-if-same-control",
56
- PRICE_LINE_SPACING = "recommendation-block-price-line-spacing-control",
57
29
  PRICE_PADDINGS = "recommendation-block-price-paddings-control",
58
30
  PRICE_SIZE = "recommendation-block-price-size-control",
59
31
  PRICE_STYLE = "recommendation-block-price-style-control",
@@ -61,7 +33,6 @@ export declare enum RecommendationControlId {
61
33
  OLD_PRICE_BACKGROUND = "recommendation-block-old-price-background-control",
62
34
  OLD_PRICE_COLOR = "recommendation-block-old-price-color-control",
63
35
  OLD_PRICE_FONT_FAMILY = "recommendation-block-old-price-font-family-control",
64
- OLD_PRICE_LINE_SPACING = "recommendation-block-old-price-line-spacing-control",
65
36
  OLD_PRICE_PADDINGS = "recommendation-block-old-price-paddings-control",
66
37
  OLD_PRICE_SIZE = "recommendation-block-old-price-size-control",
67
38
  OLD_PRICE_STYLE = "recommendation-block-old-price-style-control",
@@ -69,7 +40,6 @@ export declare enum RecommendationControlId {
69
40
  OMNIBUS_PRICE_BACKGROUND = "recommendation-block-omnibus-price-background-control",
70
41
  OMNIBUS_PRICE_COLOR = "recommendation-block-omnibus-price-color-control",
71
42
  OMNIBUS_PRICE_FONT_FAMILY = "recommendation-block-omnibus-price-font-family-control",
72
- OMNIBUS_PRICE_LINE_SPACING = "recommendation-block-omnibus-price-line-spacing-control",
73
43
  OMNIBUS_PRICE_PADDINGS = "recommendation-block-omnibus-price-paddings-control",
74
44
  OMNIBUS_PRICE_SIZE = "recommendation-block-omnibus-price-size-control",
75
45
  OMNIBUS_PRICE_STYLE = "recommendation-block-omnibus-price-style-control",
@@ -79,13 +49,11 @@ export declare enum RecommendationControlId {
79
49
  OMNIBUS_DISCOUNT_BACKGROUND = "recommendation-block-omnibus-discount-background-control",
80
50
  OMNIBUS_DISCOUNT_COLOR = "recommendation-block-omnibus-discount-color-control",
81
51
  OMNIBUS_DISCOUNT_FONT_FAMILY = "recommendation-block-omnibus-discount-font-family-control",
82
- OMNIBUS_DISCOUNT_LINE_SPACING = "recommendation-block-omnibus-discount-line-spacing-control",
83
52
  OMNIBUS_DISCOUNT_PADDINGS = "recommendation-block-omnibus-discount-paddings-control",
84
53
  OMNIBUS_DISCOUNT_SIZE = "recommendation-block-omnibus-discount-size-control",
85
54
  OMNIBUS_DISCOUNT_STYLE = "recommendation-block-omnibus-discount-style-control",
86
55
  OMNIBUS_DISCOUNT_TEXT_BEFORE = "recommendation-block-omnibus-discount-text-before-control",
87
56
  OMNIBUS_DISCOUNT_TEXT_AFTER = "recommendation-block-omnibus-discount-text-after-control",
88
57
  IMAGE_SIZE = "recommendation-block-image-size-control",
89
- IMAGE_MARGINS = "recommendation-block-image-margins-control",
90
- PRICE_INLINE_LAYOUT = "recommendation-block-price-inline-layout-control"
58
+ IMAGE_MARGINS = "recommendation-block-image-margins-control"
91
59
  }
@@ -0,0 +1,11 @@
1
+ /**
2
+ * Recommendation Extension Constants
3
+ *
4
+ * This module re-exports all constants for the Recommendation extension.
5
+ * Import from this file for cleaner imports.
6
+ * @example
7
+ * import { RecommendationBlockId, CONTAINER_SELECTOR } from './constants';
8
+ */
9
+ export { RecommendationBlockId } from './blockIds';
10
+ export { RecommendationControlId } from './controlIds';
11
+ export { CONTAINER_SELECTOR, ATTR_PRODUCT_IMAGE, ATTR_PRODUCT_NAME, ATTR_PRODUCT_PRICE, ATTR_PRODUCT_OLD_PRICE, ATTR_PRODUCT_OMNIBUS_PRICE, ATTR_PRODUCT_OMNIBUS_DISCOUNT, ATTR_PRODUCT_BUTTON, } from './selectors';
@@ -0,0 +1,19 @@
1
+ /**
2
+ * CSS selectors and data attributes used across the Recommendation extension
3
+ */
4
+ /**
5
+ * Container selector for the product container element
6
+ * Used across controls to target elements within the recommendation block
7
+ */
8
+ export declare const CONTAINER_SELECTOR = ".ins-recommendation-product-container";
9
+ /**
10
+ * Attribute type constants used in templates
11
+ * These are used as keys in ElementRenderer and composition arrays
12
+ */
13
+ export declare const ATTR_PRODUCT_IMAGE = "productImage";
14
+ export declare const ATTR_PRODUCT_NAME = "productName";
15
+ export declare const ATTR_PRODUCT_PRICE = "productPrice";
16
+ export declare const ATTR_PRODUCT_OLD_PRICE = "productOldPrice";
17
+ export declare const ATTR_PRODUCT_OMNIBUS_PRICE = "productOmnibusPrice";
18
+ export declare const ATTR_PRODUCT_OMNIBUS_DISCOUNT = "productOmnibusDiscount";
19
+ export declare const ATTR_PRODUCT_BUTTON = "productButton";
@@ -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,6 @@
1
+ import type { Orientation } from '@@/Types/recommendation';
1
2
  import { ImmutableHtmlNode } from '@stripoinc/ui-editor-extensions';
2
- import { CommonControl } from '../../common-control';
3
+ import { CommonControl } from '../../../common-control';
3
4
  export declare const CARD_BACKGROUND_COLOR_CONTROL_ID = "recommendation-card-background-color-control";
4
5
  /**
5
6
  * Control for managing recommendation card background color
@@ -12,13 +13,28 @@ export declare class CardBackgroundColorControl extends CommonControl {
12
13
  onTemplateNodeUpdated(node: ImmutableHtmlNode): void;
13
14
  _setFormValues(): void;
14
15
  /**
15
- * Reads the current background color from the first product card wrapper
16
+ * Gets the block element - either currentNode itself or as a descendant
17
+ * The currentNode could BE the block element or contain it
18
+ */
19
+ _getBlockElement(): ImmutableHtmlNode | null;
20
+ /**
21
+ * Gets the current layout orientation from the block's data attribute
22
+ */
23
+ _getCurrentLayout(): Orientation;
24
+ /**
25
+ * Gets the appropriate selector based on layout
26
+ * Vertical: .product-card-segment (inner table per product cell)
27
+ * Horizontal: .product-card-wrapper (table per product row)
28
+ */
29
+ _getCardSelector(): string;
30
+ /**
31
+ * Reads the current background color from the first product card element
16
32
  * @returns The background color value or 'transparent' if not found
17
33
  */
18
34
  _getCurrentCardBackgroundColor(): string;
19
35
  /**
20
36
  * Handles card background color changes
21
- * Applies the color to all product card wrapper elements
37
+ * Applies the color to all product card elements based on layout
22
38
  */
23
39
  _onCardBackgroundColorChange(color: string): void;
24
40
  _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 vertical 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 horizontal 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
+ };