@useinsider/guido 2.0.0-beta.5ccd854 → 2.0.0-beta.5da4dde

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 (138) hide show
  1. package/dist/components/organisms/email-preview/desktop-preview/DesktopPreview.vue.js +2 -2
  2. package/dist/components/organisms/email-preview/mobile-preview/ContentView.vue.js +5 -5
  3. package/dist/composables/useStripo.js +37 -35
  4. package/dist/config/migrator/index.js +8 -9
  5. package/dist/extensions/Blocks/CouponBlock/constants.js +4 -0
  6. package/dist/extensions/Blocks/CouponBlock/controls/index.js +29 -0
  7. package/dist/extensions/Blocks/CouponBlock/extension.js +5 -4
  8. package/dist/extensions/Blocks/CouponBlock/settingsPanel.js +20 -14
  9. package/dist/extensions/Blocks/CouponBlock/template.js +22 -11
  10. package/dist/extensions/Blocks/Items/block.js +40 -39
  11. package/dist/extensions/Blocks/Items/controls/cardComposition.js +49 -46
  12. package/dist/extensions/Blocks/Items/controls/price/priceOrientation.js +26 -28
  13. package/dist/extensions/Blocks/Items/controls/settingsControl.js +127 -132
  14. package/dist/extensions/Blocks/Items/enums/settingsEnums.js +2 -2
  15. package/dist/extensions/Blocks/Items/layouts/horizontal.html.js +48 -58
  16. package/dist/extensions/Blocks/Items/layouts/vertical.html.js +58 -48
  17. package/dist/extensions/Blocks/Items/store/items-block.js +2 -2
  18. package/dist/extensions/Blocks/Items/template.js +123 -296
  19. package/dist/extensions/Blocks/Items/utils/syncAttributesFromConfigBlock.js +20 -11
  20. package/dist/extensions/Blocks/Recommendation/cardCompositionControl.js +153 -69
  21. package/dist/extensions/Blocks/Recommendation/constants.js +9 -1
  22. package/dist/extensions/Blocks/Recommendation/control.js +74 -59
  23. package/dist/extensions/Blocks/Recommendation/controls/cardBackgroundColorControl.js +68 -0
  24. package/dist/extensions/Blocks/Recommendation/controls/index.js +245 -0
  25. package/dist/extensions/Blocks/Recommendation/controls/nameTextTrimControl.js +74 -0
  26. package/dist/extensions/Blocks/Recommendation/controls/omnibusDiscountTextAfterControl.js +71 -0
  27. package/dist/extensions/Blocks/Recommendation/controls/omnibusDiscountTextBeforeControl.js +71 -0
  28. package/dist/extensions/Blocks/Recommendation/controls/omnibusPriceTextAfterControl.js +71 -0
  29. package/dist/extensions/Blocks/Recommendation/controls/omnibusPriceTextBeforeControl.js +71 -0
  30. package/dist/extensions/Blocks/Recommendation/controls/spacingControl.js +188 -0
  31. package/dist/extensions/Blocks/Recommendation/extension.js +16 -42
  32. package/dist/extensions/Blocks/Recommendation/settingsPanel.js +117 -72
  33. package/dist/extensions/Blocks/Recommendation/templates/blockTemplate.js +85 -64
  34. package/dist/extensions/Blocks/Recommendation/templates/migrationTemplate.js +54 -17
  35. package/dist/extensions/Blocks/Recommendation/templates/templateUtils.js +74 -45
  36. package/dist/extensions/Blocks/Recommendation/utils/preserveTextStyles.js +25 -0
  37. package/dist/extensions/Blocks/common-control.js +53 -64
  38. package/dist/extensions/Blocks/controlFactories.js +122 -111
  39. package/dist/guido.css +1 -1
  40. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/esm/index.js +289 -368
  41. package/dist/package.json.js +7 -0
  42. package/dist/src/extensions/Blocks/CouponBlock/constants.d.ts +14 -0
  43. package/dist/src/extensions/Blocks/CouponBlock/controls/index.d.ts +108 -0
  44. package/dist/src/extensions/Blocks/CouponBlock/template.d.ts +1 -1
  45. package/dist/src/extensions/Blocks/Items/controls/price/priceOrientation.d.ts +1 -1
  46. package/dist/src/extensions/Blocks/Items/controls/settingsControl.d.ts +4 -0
  47. package/dist/src/extensions/Blocks/Items/template.d.ts +1 -20
  48. package/dist/src/extensions/Blocks/Recommendation/cardCompositionControl.d.ts +50 -3
  49. package/dist/src/extensions/Blocks/Recommendation/constants.d.ts +32 -0
  50. package/dist/src/extensions/Blocks/Recommendation/control.d.ts +5 -2
  51. package/dist/src/extensions/Blocks/Recommendation/controls/cardBackgroundColorControl.d.ts +25 -0
  52. package/dist/src/extensions/Blocks/Recommendation/controls/index.d.ts +592 -0
  53. package/dist/src/extensions/Blocks/Recommendation/controls/nameTextTrimControl.d.ts +16 -0
  54. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusDiscountTextAfterControl.d.ts +15 -0
  55. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusDiscountTextBeforeControl.d.ts +15 -0
  56. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusPriceTextAfterControl.d.ts +15 -0
  57. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusPriceTextBeforeControl.d.ts +15 -0
  58. package/dist/src/extensions/Blocks/Recommendation/controls/spacingControl.d.ts +60 -0
  59. package/dist/src/extensions/Blocks/Recommendation/templates/blockTemplate.d.ts +3 -3
  60. package/dist/src/extensions/Blocks/Recommendation/templates/templateUtils.d.ts +15 -7
  61. package/dist/src/extensions/Blocks/Recommendation/utils/preserveTextStyles.d.ts +19 -0
  62. package/dist/src/extensions/Blocks/common-control.d.ts +8 -13
  63. package/dist/src/extensions/Blocks/controlFactories.d.ts +30 -7
  64. package/dist/static/styles/components/wide-panel.css.js +0 -4
  65. package/dist/static/styles/customEditorStyle.css.js +13 -0
  66. package/package.json +3 -3
  67. package/dist/config/migrator/itemsBlockMigrator.js +0 -283
  68. package/dist/extensions/Blocks/Items/utils/nodeConfigUtils.js +0 -172
  69. package/dist/extensions/Blocks/Recommendation/controls/button/align.js +0 -13
  70. package/dist/extensions/Blocks/Recommendation/controls/button/border.js +0 -13
  71. package/dist/extensions/Blocks/Recommendation/controls/button/borderRadius.js +0 -13
  72. package/dist/extensions/Blocks/Recommendation/controls/button/color.js +0 -13
  73. package/dist/extensions/Blocks/Recommendation/controls/button/fitToContent.js +0 -13
  74. package/dist/extensions/Blocks/Recommendation/controls/button/fontFamily.js +0 -13
  75. package/dist/extensions/Blocks/Recommendation/controls/button/margins.js +0 -13
  76. package/dist/extensions/Blocks/Recommendation/controls/button/paddings.js +0 -13
  77. package/dist/extensions/Blocks/Recommendation/controls/button/text.js +0 -13
  78. package/dist/extensions/Blocks/Recommendation/controls/button/textSize.js +0 -13
  79. package/dist/extensions/Blocks/Recommendation/controls/button/textStyleAndFontColor.js +0 -13
  80. package/dist/extensions/Blocks/Recommendation/controls/image/margins.js +0 -13
  81. package/dist/extensions/Blocks/Recommendation/controls/image/size.js +0 -13
  82. package/dist/extensions/Blocks/Recommendation/controls/name/align.js +0 -13
  83. package/dist/extensions/Blocks/Recommendation/controls/name/background.js +0 -13
  84. package/dist/extensions/Blocks/Recommendation/controls/name/color.js +0 -13
  85. package/dist/extensions/Blocks/Recommendation/controls/name/fontFamily.js +0 -13
  86. package/dist/extensions/Blocks/Recommendation/controls/name/paddings.js +0 -13
  87. package/dist/extensions/Blocks/Recommendation/controls/name/size.js +0 -13
  88. package/dist/extensions/Blocks/Recommendation/controls/name/style.js +0 -13
  89. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/align.js +0 -13
  90. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/background.js +0 -13
  91. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/color.js +0 -13
  92. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/fontFamily.js +0 -13
  93. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/paddings.js +0 -13
  94. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/size.js +0 -13
  95. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/style.js +0 -13
  96. package/dist/extensions/Blocks/Recommendation/controls/price/align.js +0 -13
  97. package/dist/extensions/Blocks/Recommendation/controls/price/background.js +0 -13
  98. package/dist/extensions/Blocks/Recommendation/controls/price/color.js +0 -13
  99. package/dist/extensions/Blocks/Recommendation/controls/price/fontFamily.js +0 -13
  100. package/dist/extensions/Blocks/Recommendation/controls/price/paddings.js +0 -13
  101. package/dist/extensions/Blocks/Recommendation/controls/price/size.js +0 -13
  102. package/dist/extensions/Blocks/Recommendation/controls/price/style.js +0 -13
  103. package/dist/src/config/migrator/itemsBlockMigrator.d.ts +0 -6
  104. package/dist/src/extensions/Blocks/Items/utils/nodeConfigUtils.d.ts +0 -71
  105. package/dist/src/extensions/Blocks/Recommendation/controls/button/align.d.ts +0 -5
  106. package/dist/src/extensions/Blocks/Recommendation/controls/button/border.d.ts +0 -5
  107. package/dist/src/extensions/Blocks/Recommendation/controls/button/borderRadius.d.ts +0 -5
  108. package/dist/src/extensions/Blocks/Recommendation/controls/button/color.d.ts +0 -5
  109. package/dist/src/extensions/Blocks/Recommendation/controls/button/fitToContent.d.ts +0 -5
  110. package/dist/src/extensions/Blocks/Recommendation/controls/button/fontFamily.d.ts +0 -5
  111. package/dist/src/extensions/Blocks/Recommendation/controls/button/margins.d.ts +0 -5
  112. package/dist/src/extensions/Blocks/Recommendation/controls/button/paddings.d.ts +0 -5
  113. package/dist/src/extensions/Blocks/Recommendation/controls/button/text.d.ts +0 -5
  114. package/dist/src/extensions/Blocks/Recommendation/controls/button/textSize.d.ts +0 -5
  115. package/dist/src/extensions/Blocks/Recommendation/controls/button/textStyleAndFontColor.d.ts +0 -5
  116. package/dist/src/extensions/Blocks/Recommendation/controls/image/margins.d.ts +0 -5
  117. package/dist/src/extensions/Blocks/Recommendation/controls/image/size.d.ts +0 -5
  118. package/dist/src/extensions/Blocks/Recommendation/controls/name/align.d.ts +0 -5
  119. package/dist/src/extensions/Blocks/Recommendation/controls/name/background.d.ts +0 -5
  120. package/dist/src/extensions/Blocks/Recommendation/controls/name/color.d.ts +0 -5
  121. package/dist/src/extensions/Blocks/Recommendation/controls/name/fontFamily.d.ts +0 -5
  122. package/dist/src/extensions/Blocks/Recommendation/controls/name/paddings.d.ts +0 -5
  123. package/dist/src/extensions/Blocks/Recommendation/controls/name/size.d.ts +0 -5
  124. package/dist/src/extensions/Blocks/Recommendation/controls/name/style.d.ts +0 -5
  125. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/align.d.ts +0 -5
  126. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/background.d.ts +0 -5
  127. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/color.d.ts +0 -5
  128. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/fontFamily.d.ts +0 -5
  129. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/paddings.d.ts +0 -5
  130. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/size.d.ts +0 -5
  131. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/style.d.ts +0 -5
  132. package/dist/src/extensions/Blocks/Recommendation/controls/price/align.d.ts +0 -5
  133. package/dist/src/extensions/Blocks/Recommendation/controls/price/background.d.ts +0 -5
  134. package/dist/src/extensions/Blocks/Recommendation/controls/price/color.d.ts +0 -5
  135. package/dist/src/extensions/Blocks/Recommendation/controls/price/fontFamily.d.ts +0 -5
  136. package/dist/src/extensions/Blocks/Recommendation/controls/price/paddings.d.ts +0 -5
  137. package/dist/src/extensions/Blocks/Recommendation/controls/price/size.d.ts +0 -5
  138. package/dist/src/extensions/Blocks/Recommendation/controls/price/style.d.ts +0 -5
@@ -0,0 +1,7 @@
1
+ const o = { stripo: { version: "2.47.0" } }, s = {
2
+ guido: o
3
+ };
4
+ export {
5
+ s as default,
6
+ o as guido
7
+ };
@@ -0,0 +1,14 @@
1
+ /**
2
+ * Control IDs used in the CouponBlock Extension
3
+ * These IDs are returned by the getId() method of each control
4
+ */
5
+ export declare enum CouponControlId {
6
+ TEXT_ALIGN = "coupon-block-text-align-control",
7
+ TEXT_COLOR = "coupon-block-text-color-control",
8
+ TEXT_SIZE = "coupon-block-text-size-control",
9
+ TEXT_STYLE = "coupon-block-text-style-control",
10
+ TEXT_FONT_FAMILY = "coupon-block-text-font-family-control",
11
+ TEXT_BACKGROUND = "coupon-block-text-background-control",
12
+ TEXT_PADDINGS = "coupon-block-text-paddings-control",
13
+ TEXT_LINE_SPACING = "coupon-block-text-line-spacing-control"
14
+ }
@@ -0,0 +1,108 @@
1
+ /**
2
+ * CouponBlock Control Instances
3
+ *
4
+ * This file generates all control instances for the CouponBlock
5
+ * using the reusable factory functions from controlFactories.ts
6
+ *
7
+ * Note: Factory-generated controls use runtime class generation which TypeScript
8
+ * cannot fully type-check. The controls are type-safe at runtime.
9
+ *
10
+ * These controls apply directly to the selected root element (no targetBlockId/containerSelector)
11
+ * to ensure styles are applied correctly regardless of nested element structure.
12
+ */
13
+ export declare const TextAlignControl: {
14
+ new (): {
15
+ getId(): string;
16
+ getTargetNodes(root: import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode): import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode[];
17
+ getParentControlId(): string;
18
+ api: import("@stripoinc/ui-editor-extensions").ControlApi;
19
+ getLabels(): import("@stripoinc/ui-editor-extensions").ControlLabels | undefined;
20
+ getModificationDescription(): import("@stripoinc/ui-editor-extensions").ModificationDescription | undefined;
21
+ 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;
22
+ isVisible(_node: import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode): boolean;
23
+ };
24
+ };
25
+ export declare const TextColorControl: {
26
+ new (): {
27
+ getId(): string;
28
+ getTargetNodes(root: import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode): import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode[];
29
+ getParentControlId(): string;
30
+ api: import("@stripoinc/ui-editor-extensions").ControlApi;
31
+ getLabels(): import("@stripoinc/ui-editor-extensions").ControlLabels | undefined;
32
+ getModificationDescription(): import("@stripoinc/ui-editor-extensions").ModificationDescription | undefined;
33
+ 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;
34
+ isVisible(_node: import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode): boolean;
35
+ };
36
+ };
37
+ export declare const TextSizeControl: {
38
+ new (): {
39
+ getId(): string;
40
+ getTargetNodes(root: import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode): import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode[];
41
+ getParentControlId(): string;
42
+ api: import("@stripoinc/ui-editor-extensions").ControlApi;
43
+ getLabels(): import("@stripoinc/ui-editor-extensions").ControlLabels | undefined;
44
+ getModificationDescription(): import("@stripoinc/ui-editor-extensions").ModificationDescription | undefined;
45
+ 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;
46
+ isVisible(_node: import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode): boolean;
47
+ };
48
+ };
49
+ export declare const TextStyleControl: {
50
+ new (): {
51
+ getId(): string;
52
+ getTargetNodes(root: import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode): import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode[];
53
+ getParentControlId(): string;
54
+ api: import("@stripoinc/ui-editor-extensions").ControlApi;
55
+ getLabels(): import("@stripoinc/ui-editor-extensions").ControlLabels | undefined;
56
+ getModificationDescription(): import("@stripoinc/ui-editor-extensions").ModificationDescription | undefined;
57
+ 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;
58
+ isVisible(_node: import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode): boolean;
59
+ };
60
+ };
61
+ export declare const TextFontFamilyControl: {
62
+ new (): {
63
+ getId(): string;
64
+ getTargetNodes(root: import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode): import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode[];
65
+ getParentControlId(): string;
66
+ api: import("@stripoinc/ui-editor-extensions").ControlApi;
67
+ getLabels(): import("@stripoinc/ui-editor-extensions").ControlLabels | undefined;
68
+ getModificationDescription(): import("@stripoinc/ui-editor-extensions").ModificationDescription | undefined;
69
+ 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;
70
+ isVisible(_node: import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode): boolean;
71
+ };
72
+ };
73
+ export declare const TextBackgroundControl: {
74
+ new (): {
75
+ getId(): string;
76
+ getTargetNodes(root: import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode): import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode[];
77
+ getParentControlId(): string;
78
+ api: import("@stripoinc/ui-editor-extensions").ControlApi;
79
+ getLabels(): import("@stripoinc/ui-editor-extensions").ControlLabels | undefined;
80
+ getModificationDescription(): import("@stripoinc/ui-editor-extensions").ModificationDescription | undefined;
81
+ 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;
82
+ isVisible(_node: import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode): boolean;
83
+ };
84
+ };
85
+ export declare const TextPaddingsControl: {
86
+ new (): {
87
+ getId(): string;
88
+ getTargetNodes(root: import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode): import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode[];
89
+ getParentControlId(): string;
90
+ api: import("@stripoinc/ui-editor-extensions").ControlApi;
91
+ getLabels(): import("@stripoinc/ui-editor-extensions").ControlLabels | undefined;
92
+ getModificationDescription(): import("@stripoinc/ui-editor-extensions").ModificationDescription | undefined;
93
+ 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;
94
+ isVisible(_node: import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode): boolean;
95
+ };
96
+ };
97
+ export declare const TextLineSpacingControl: {
98
+ new (): {
99
+ getId(): string;
100
+ getTargetNodes(root: import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode): import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode[];
101
+ getParentControlId(): string;
102
+ api: import("@stripoinc/ui-editor-extensions").ControlApi;
103
+ getLabels(): import("@stripoinc/ui-editor-extensions").ControlLabels | undefined;
104
+ getModificationDescription(): import("@stripoinc/ui-editor-extensions").ModificationDescription | undefined;
105
+ 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;
106
+ isVisible(_node: import("@stripoinc/ui-editor-extensions").ImmutableHtmlNode): boolean;
107
+ };
108
+ };
@@ -1,3 +1,3 @@
1
- declare const migrationTemplate = "\n <td \n class=\"coupon-block coupon-block-v2 ins-coupon-code esd-block-text esd-extension-block\" \n esd-extension-block-id=\"coupon-block\"\n >\n <p class=\"ins-title\" contenteditable=\"false\">{@COUPON_CODE}</p>\n </td>\n";
1
+ declare const migrationTemplate = "\n <td\n class=\"coupon-block coupon-block-v2 ins-coupon-code esd-block-text esd-extension-block\"\n esd-extension-block-id=\"coupon-block\"\n >\n <p class=\"ins-title\" contenteditable=\"false\">{@COUPON_CODE}</p>\n </td>\n";
2
2
  export declare function getDefaultTemplate(): string;
3
3
  export default migrationTemplate;
@@ -9,7 +9,7 @@ export declare class PriceOrientationControl extends CommonControl {
9
9
  onRender(): void;
10
10
  onTemplateNodeUpdated(node: ImmutableHtmlNode): void;
11
11
  _onPriceOrientationChange(value: string): void;
12
- private _updateVerticalLayout;
13
12
  private _updateHorizontalLayout;
13
+ private _updateVerticalLayout;
14
14
  _getPriceOrientation(): string;
15
15
  }
@@ -31,6 +31,10 @@ export declare class ItemsBlockControl extends CommonControl {
31
31
  _updatePrice(price: string): void;
32
32
  _updateOriginalPrice(originalPrice: string): void;
33
33
  _updateQuantity(quantity: string): void;
34
+ /**
35
+ * @todo Optimize template reordering for performance.
36
+ * @description Reorders the template structure based on current orientation and visibility settings.
37
+ */
34
38
  _reOrderTemplate(): void;
35
39
  _updateDataTypeAttributes(itemsType: ProductType): void;
36
40
  _updateDataNumberAttributes(itemId: string): void;
@@ -1,8 +1,6 @@
1
- import type { ItemsBlockConfig } from './utils/nodeConfigUtils';
2
1
  declare const migrationTemplate = "ADD YOUR MIGRATION HERE";
3
2
  type ProductType = 'CART_ITEMS' | 'BROWSED_ITEMS' | 'PURCHASED_ITEMS';
4
3
  type OrientationType = 'vertical' | 'horizontal';
5
- type PriceOrientationType = 'vertical' | 'horizontal';
6
4
  type TemplateParameters = {
7
5
  orientation: OrientationType;
8
6
  itemsType: ProductType;
@@ -10,23 +8,6 @@ type TemplateParameters = {
10
8
  currencySymbol?: string;
11
9
  currencyLocation?: string;
12
10
  formattedPrice?: boolean;
13
- migrate?: boolean;
14
- /** Legacy config format (data-* attributes from esd-config-block) */
15
- configBlockAttributes?: Record<string, string>;
16
- /** New config format (Stripo V2 nodeConfig from esd-ext-config) */
17
- nodeConfig?: Partial<ItemsBlockConfig>;
18
- /** Extracted styles from a[product-attr="name"] for migration */
19
- nameStyles?: string;
20
- /** Extracted styles from a.es-button for migration */
21
- buttonStyles?: string;
22
- /** Extracted styles from p[product-attr="price"] for migration */
23
- priceStyles?: string;
24
- /** Extracted styles from p[product-attr="originalPrice"] for migration */
25
- originalPriceStyles?: string;
26
- /** Extracted styles from p[product-attr="quantity"] for migration */
27
- quantityStyles?: string;
28
- /** Price orientation within the card ('vertical' = stacked, 'horizontal' = side-by-side) */
29
- priceOrientation?: PriceOrientationType;
30
11
  };
31
12
  /**
32
13
  * Generates the default template for the Items Block.
@@ -39,5 +20,5 @@ type TemplateParameters = {
39
20
  * @param params.formattedPrice - Whether to use formatted price display
40
21
  * @returns HTML template string for the Items Block
41
22
  */
42
- export declare function getDefaultTemplate({ orientation, itemsType, itemId, currencySymbol, currencyLocation, migrate, formattedPrice, configBlockAttributes, nodeConfig, nameStyles, buttonStyles, priceStyles, originalPriceStyles, quantityStyles, priceOrientation, }: TemplateParameters): string;
23
+ export declare function getDefaultTemplate({ orientation, itemsType, itemId, currencySymbol, currencyLocation, formattedPrice, }: TemplateParameters): string;
43
24
  export default migrationTemplate;
@@ -7,22 +7,69 @@ export interface CardCompositionItem {
7
7
  visible: boolean;
8
8
  }
9
9
  export declare class RecommendationCardCompositionControl extends CommonControl {
10
- private currentComposition;
11
- private currentVisibility;
12
10
  getId(): string;
13
11
  getTemplate(): string;
14
12
  onRender(): void;
15
13
  onTemplateNodeUpdated(node: ImmutableHtmlNode): void;
16
14
  /**
17
- * Initialize the composition order and visibility from the block or use defaults
15
+ * Creates the HTML content for an orderable item with label and toggle
16
+ */
17
+ private _createItemContent;
18
+ /**
19
+ * Registers event listeners for composition and visibility changes
20
+ */
21
+ private _registerValueChangeListeners;
22
+ /**
23
+ * Initializes composition order and visibility state from the current node
18
24
  */
19
25
  private _initializeComposition;
26
+ /**
27
+ * Reads composition order from node's data-card-composition attribute
28
+ * Falls back to default order if attribute is not present
29
+ */
30
+ private _readCompositionFromNode;
31
+ /**
32
+ * Builds visibility values object from the visibility map
33
+ */
34
+ private _buildVisibilityValues;
35
+ /**
36
+ * Read visibility state from individual row elements' data-visibility attributes
37
+ * This ensures toggles reflect the actual DOM state
38
+ */
39
+ private _readVisibilityFromRows;
40
+ /**
41
+ * Returns default visibility values for all items
42
+ */
43
+ private _getDefaultVisibilities;
44
+ /**
45
+ * Extracts visibility values from DOM nodes
46
+ */
47
+ private _extractVisibilityFromRows;
48
+ /**
49
+ * Parses visibility value from string to boolean
50
+ * Accepts "1", "true" as true, everything else as false
51
+ */
52
+ private _parseVisibilityValue;
53
+ /**
54
+ * Merges extracted visibilities with default values for missing keys
55
+ */
56
+ private _mergeWithDefaults;
20
57
  /**
21
58
  * Apply the reordered composition to the block's HTML structure
59
+ * Updates the data-card-composition attribute and reorders product attributes
22
60
  */
23
61
  private _applyCompositionToBlock;
62
+ /**
63
+ * Reorders attribute rows within each product row based on composition order
64
+ */
65
+ private _reorderProductAttributes;
66
+ /**
67
+ * Builds HTML string with attributes ordered according to composition
68
+ */
69
+ private _buildCompositionHtml;
24
70
  /**
25
71
  * Apply visibility changes to the block's HTML structure
72
+ * Updates display style and data-visibility attribute for all matching rows
26
73
  */
27
74
  private _applyVisibilityToBlock;
28
75
  }
@@ -1,3 +1,14 @@
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";
1
12
  /**
2
13
  * Block IDs used in the Recommendation Extension
3
14
  * These IDs are used in the esd-extension-block-id attribute to identify specific blocks
@@ -7,6 +18,8 @@ export declare enum RecommendationBlockId {
7
18
  NAME = "recommendation-block-name",
8
19
  PRICE = "recommendation-block-price",
9
20
  OLD_PRICE = "recommendation-block-old-price",
21
+ OMNIBUS_PRICE = "recommendation-block-omnibus-price",
22
+ OMNIBUS_DISCOUNT = "recommendation-block-omnibus-discount",
10
23
  IMAGE = "recommendation-block-image"
11
24
  }
12
25
  /**
@@ -32,6 +45,7 @@ export declare enum RecommendationControlId {
32
45
  NAME_PADDINGS = "recommendation-block-name-paddings-control",
33
46
  NAME_SIZE = "recommendation-block-name-size-control",
34
47
  NAME_STYLE = "recommendation-block-name-style-control",
48
+ NAME_TEXT_TRIM = "recommendation-block-name-text-trim-control",
35
49
  PRICE_ALIGN = "recommendation-block-price-align-control",
36
50
  PRICE_BACKGROUND = "recommendation-block-price-background-control",
37
51
  PRICE_COLOR = "recommendation-block-price-color-control",
@@ -46,6 +60,24 @@ export declare enum RecommendationControlId {
46
60
  OLD_PRICE_PADDINGS = "recommendation-block-old-price-paddings-control",
47
61
  OLD_PRICE_SIZE = "recommendation-block-old-price-size-control",
48
62
  OLD_PRICE_STYLE = "recommendation-block-old-price-style-control",
63
+ OMNIBUS_PRICE_ALIGN = "recommendation-block-omnibus-price-align-control",
64
+ OMNIBUS_PRICE_BACKGROUND = "recommendation-block-omnibus-price-background-control",
65
+ OMNIBUS_PRICE_COLOR = "recommendation-block-omnibus-price-color-control",
66
+ OMNIBUS_PRICE_FONT_FAMILY = "recommendation-block-omnibus-price-font-family-control",
67
+ OMNIBUS_PRICE_PADDINGS = "recommendation-block-omnibus-price-paddings-control",
68
+ OMNIBUS_PRICE_SIZE = "recommendation-block-omnibus-price-size-control",
69
+ OMNIBUS_PRICE_STYLE = "recommendation-block-omnibus-price-style-control",
70
+ OMNIBUS_PRICE_TEXT_BEFORE = "recommendation-block-omnibus-price-text-before-control",
71
+ OMNIBUS_PRICE_TEXT_AFTER = "recommendation-block-omnibus-price-text-after-control",
72
+ OMNIBUS_DISCOUNT_ALIGN = "recommendation-block-omnibus-discount-align-control",
73
+ OMNIBUS_DISCOUNT_BACKGROUND = "recommendation-block-omnibus-discount-background-control",
74
+ OMNIBUS_DISCOUNT_COLOR = "recommendation-block-omnibus-discount-color-control",
75
+ OMNIBUS_DISCOUNT_FONT_FAMILY = "recommendation-block-omnibus-discount-font-family-control",
76
+ OMNIBUS_DISCOUNT_PADDINGS = "recommendation-block-omnibus-discount-paddings-control",
77
+ OMNIBUS_DISCOUNT_SIZE = "recommendation-block-omnibus-discount-size-control",
78
+ OMNIBUS_DISCOUNT_STYLE = "recommendation-block-omnibus-discount-style-control",
79
+ OMNIBUS_DISCOUNT_TEXT_BEFORE = "recommendation-block-omnibus-discount-text-before-control",
80
+ OMNIBUS_DISCOUNT_TEXT_AFTER = "recommendation-block-omnibus-discount-text-after-control",
49
81
  IMAGE_SIZE = "recommendation-block-image-size-control",
50
82
  IMAGE_MARGINS = "recommendation-block-image-margins-control"
51
83
  }
@@ -17,8 +17,6 @@ export declare class RecommendationBlockControl extends CommonControl {
17
17
  _getProductLayout(): string;
18
18
  _getFilterStatus(): string;
19
19
  _getShuffleProducts(): string;
20
- _getResponsive(): string;
21
- _onFilterChange(value: boolean): void;
22
20
  _onFilterSelectClick(): void;
23
21
  _onDataChange(item: string, value: string | number | string[]): void;
24
22
  /**
@@ -26,6 +24,11 @@ export declare class RecommendationBlockControl extends CommonControl {
26
24
  */
27
25
  _getCardComposition(): string[];
28
26
  _regenerateProductRows(): void;
27
+ /**
28
+ * Reapply spacing values after product regeneration
29
+ * This ensures spacing persists when products are regenerated
30
+ */
31
+ _reapplySpacing(): void;
29
32
  _debouncedRegenerateProductRows: import("@vueuse/shared").PromisifyFn<() => void>;
30
33
  _onCurrencyConfigChange(item: string, value: string | number): void;
31
34
  _onCurrencyChange(value: string): void;
@@ -0,0 +1,25 @@
1
+ import { ImmutableHtmlNode } from '@stripoinc/ui-editor-extensions';
2
+ import { CommonControl } from '../../common-control';
3
+ export declare const CARD_BACKGROUND_COLOR_CONTROL_ID = "recommendation-card-background-color-control";
4
+ /**
5
+ * Control for managing recommendation card background color
6
+ * This control is displayed in the Styles tab
7
+ */
8
+ export declare class CardBackgroundColorControl extends CommonControl {
9
+ getId(): string;
10
+ getTemplate(): string;
11
+ onRender(): void;
12
+ onTemplateNodeUpdated(node: ImmutableHtmlNode): void;
13
+ _setFormValues(): void;
14
+ /**
15
+ * Reads the current background color from the first product card wrapper
16
+ * @returns The background color value or 'transparent' if not found
17
+ */
18
+ _getCurrentCardBackgroundColor(): string;
19
+ /**
20
+ * Handles card background color changes
21
+ * Applies the color to all product card wrapper elements
22
+ */
23
+ _onCardBackgroundColorChange(color: string): void;
24
+ _listenToFormUpdates(): void;
25
+ }