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

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 (111) hide show
  1. package/dist/extensions/Blocks/Items/controls/cardComposition.js +13 -4
  2. package/dist/extensions/Blocks/Recommendation/cardCompositionControl.js +158 -68
  3. package/dist/extensions/Blocks/Recommendation/constants.js +10 -1
  4. package/dist/extensions/Blocks/Recommendation/control.js +91 -61
  5. package/dist/extensions/Blocks/Recommendation/controls/cardBackgroundColorControl.js +68 -0
  6. package/dist/extensions/Blocks/Recommendation/controls/index.js +272 -0
  7. package/dist/extensions/Blocks/Recommendation/controls/nameTextTrimControl.js +74 -0
  8. package/dist/extensions/Blocks/Recommendation/controls/omnibusDiscountTextAfterControl.js +71 -0
  9. package/dist/extensions/Blocks/Recommendation/controls/omnibusDiscountTextBeforeControl.js +71 -0
  10. package/dist/extensions/Blocks/Recommendation/controls/omnibusPriceTextAfterControl.js +71 -0
  11. package/dist/extensions/Blocks/Recommendation/controls/omnibusPriceTextBeforeControl.js +71 -0
  12. package/dist/extensions/Blocks/Recommendation/controls/priceHideControl.js +60 -0
  13. package/dist/extensions/Blocks/Recommendation/controls/priceInlineLayoutControl.js +160 -0
  14. package/dist/extensions/Blocks/Recommendation/controls/spacingControl.js +188 -0
  15. package/dist/extensions/Blocks/Recommendation/extension.js +16 -40
  16. package/dist/extensions/Blocks/Recommendation/settingsPanel.js +124 -71
  17. package/dist/extensions/Blocks/Recommendation/templates/blockTemplate.js +89 -65
  18. package/dist/extensions/Blocks/Recommendation/templates/migrationTemplate.js +56 -19
  19. package/dist/extensions/Blocks/Recommendation/templates/templateUtils.js +74 -45
  20. package/dist/extensions/Blocks/Recommendation/utils/preserveTextStyles.js +25 -0
  21. package/dist/extensions/Blocks/controlFactories.js +70 -70
  22. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/esm/index.js +363 -290
  23. package/dist/package.json.js +1 -1
  24. package/dist/src/extensions/Blocks/Recommendation/cardCompositionControl.d.ts +54 -3
  25. package/dist/src/extensions/Blocks/Recommendation/constants.d.ts +41 -1
  26. package/dist/src/extensions/Blocks/Recommendation/control.d.ts +5 -2
  27. package/dist/src/extensions/Blocks/Recommendation/controls/cardBackgroundColorControl.d.ts +25 -0
  28. package/dist/src/extensions/Blocks/Recommendation/controls/index.d.ts +654 -0
  29. package/dist/src/extensions/Blocks/Recommendation/controls/nameTextTrimControl.d.ts +16 -0
  30. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusDiscountTextAfterControl.d.ts +15 -0
  31. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusDiscountTextBeforeControl.d.ts +15 -0
  32. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusPriceTextAfterControl.d.ts +15 -0
  33. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusPriceTextBeforeControl.d.ts +15 -0
  34. package/dist/src/extensions/Blocks/Recommendation/controls/priceHideControl.d.ts +16 -0
  35. package/dist/src/extensions/Blocks/Recommendation/controls/priceInlineLayoutControl.d.ts +50 -0
  36. package/dist/src/extensions/Blocks/Recommendation/controls/spacingControl.d.ts +60 -0
  37. package/dist/src/extensions/Blocks/Recommendation/templates/blockTemplate.d.ts +3 -3
  38. package/dist/src/extensions/Blocks/Recommendation/templates/migrationTemplate.d.ts +1 -1
  39. package/dist/src/extensions/Blocks/Recommendation/templates/templateUtils.d.ts +15 -7
  40. package/dist/src/extensions/Blocks/Recommendation/utils/preserveTextStyles.d.ts +19 -0
  41. package/dist/static/styles/components/wide-panel.css.js +0 -4
  42. package/dist/static/styles/customEditorStyle.css.js +13 -0
  43. package/package.json +3 -3
  44. package/dist/extensions/Blocks/Recommendation/controls/button/align.js +0 -13
  45. package/dist/extensions/Blocks/Recommendation/controls/button/border.js +0 -13
  46. package/dist/extensions/Blocks/Recommendation/controls/button/borderRadius.js +0 -13
  47. package/dist/extensions/Blocks/Recommendation/controls/button/color.js +0 -13
  48. package/dist/extensions/Blocks/Recommendation/controls/button/fitToContent.js +0 -13
  49. package/dist/extensions/Blocks/Recommendation/controls/button/fontFamily.js +0 -13
  50. package/dist/extensions/Blocks/Recommendation/controls/button/margins.js +0 -13
  51. package/dist/extensions/Blocks/Recommendation/controls/button/paddings.js +0 -13
  52. package/dist/extensions/Blocks/Recommendation/controls/button/text.js +0 -13
  53. package/dist/extensions/Blocks/Recommendation/controls/button/textSize.js +0 -13
  54. package/dist/extensions/Blocks/Recommendation/controls/button/textStyleAndFontColor.js +0 -13
  55. package/dist/extensions/Blocks/Recommendation/controls/image/margins.js +0 -13
  56. package/dist/extensions/Blocks/Recommendation/controls/image/size.js +0 -13
  57. package/dist/extensions/Blocks/Recommendation/controls/name/align.js +0 -13
  58. package/dist/extensions/Blocks/Recommendation/controls/name/background.js +0 -13
  59. package/dist/extensions/Blocks/Recommendation/controls/name/color.js +0 -13
  60. package/dist/extensions/Blocks/Recommendation/controls/name/fontFamily.js +0 -13
  61. package/dist/extensions/Blocks/Recommendation/controls/name/paddings.js +0 -13
  62. package/dist/extensions/Blocks/Recommendation/controls/name/size.js +0 -13
  63. package/dist/extensions/Blocks/Recommendation/controls/name/style.js +0 -13
  64. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/align.js +0 -13
  65. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/background.js +0 -13
  66. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/color.js +0 -13
  67. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/fontFamily.js +0 -13
  68. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/paddings.js +0 -13
  69. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/size.js +0 -13
  70. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/style.js +0 -13
  71. package/dist/extensions/Blocks/Recommendation/controls/price/align.js +0 -13
  72. package/dist/extensions/Blocks/Recommendation/controls/price/background.js +0 -13
  73. package/dist/extensions/Blocks/Recommendation/controls/price/color.js +0 -13
  74. package/dist/extensions/Blocks/Recommendation/controls/price/fontFamily.js +0 -13
  75. package/dist/extensions/Blocks/Recommendation/controls/price/paddings.js +0 -13
  76. package/dist/extensions/Blocks/Recommendation/controls/price/size.js +0 -13
  77. package/dist/extensions/Blocks/Recommendation/controls/price/style.js +0 -13
  78. package/dist/src/extensions/Blocks/Recommendation/controls/button/align.d.ts +0 -5
  79. package/dist/src/extensions/Blocks/Recommendation/controls/button/border.d.ts +0 -5
  80. package/dist/src/extensions/Blocks/Recommendation/controls/button/borderRadius.d.ts +0 -5
  81. package/dist/src/extensions/Blocks/Recommendation/controls/button/color.d.ts +0 -5
  82. package/dist/src/extensions/Blocks/Recommendation/controls/button/fitToContent.d.ts +0 -5
  83. package/dist/src/extensions/Blocks/Recommendation/controls/button/fontFamily.d.ts +0 -5
  84. package/dist/src/extensions/Blocks/Recommendation/controls/button/margins.d.ts +0 -5
  85. package/dist/src/extensions/Blocks/Recommendation/controls/button/paddings.d.ts +0 -5
  86. package/dist/src/extensions/Blocks/Recommendation/controls/button/text.d.ts +0 -5
  87. package/dist/src/extensions/Blocks/Recommendation/controls/button/textSize.d.ts +0 -5
  88. package/dist/src/extensions/Blocks/Recommendation/controls/button/textStyleAndFontColor.d.ts +0 -5
  89. package/dist/src/extensions/Blocks/Recommendation/controls/image/margins.d.ts +0 -5
  90. package/dist/src/extensions/Blocks/Recommendation/controls/image/size.d.ts +0 -5
  91. package/dist/src/extensions/Blocks/Recommendation/controls/name/align.d.ts +0 -5
  92. package/dist/src/extensions/Blocks/Recommendation/controls/name/background.d.ts +0 -5
  93. package/dist/src/extensions/Blocks/Recommendation/controls/name/color.d.ts +0 -5
  94. package/dist/src/extensions/Blocks/Recommendation/controls/name/fontFamily.d.ts +0 -5
  95. package/dist/src/extensions/Blocks/Recommendation/controls/name/paddings.d.ts +0 -5
  96. package/dist/src/extensions/Blocks/Recommendation/controls/name/size.d.ts +0 -5
  97. package/dist/src/extensions/Blocks/Recommendation/controls/name/style.d.ts +0 -5
  98. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/align.d.ts +0 -5
  99. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/background.d.ts +0 -5
  100. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/color.d.ts +0 -5
  101. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/fontFamily.d.ts +0 -5
  102. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/paddings.d.ts +0 -5
  103. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/size.d.ts +0 -5
  104. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/style.d.ts +0 -5
  105. package/dist/src/extensions/Blocks/Recommendation/controls/price/align.d.ts +0 -5
  106. package/dist/src/extensions/Blocks/Recommendation/controls/price/background.d.ts +0 -5
  107. package/dist/src/extensions/Blocks/Recommendation/controls/price/color.d.ts +0 -5
  108. package/dist/src/extensions/Blocks/Recommendation/controls/price/fontFamily.d.ts +0 -5
  109. package/dist/src/extensions/Blocks/Recommendation/controls/price/paddings.d.ts +0 -5
  110. package/dist/src/extensions/Blocks/Recommendation/controls/price/size.d.ts +0 -5
  111. package/dist/src/extensions/Blocks/Recommendation/controls/price/style.d.ts +0 -5
@@ -1,4 +1,4 @@
1
- const o = { stripo: { version: "2.47.0" } }, s = {
1
+ const o = { stripo: { version: "2.52.0" } }, s = {
2
2
  guido: o
3
3
  };
4
4
  export {
@@ -7,22 +7,73 @@ 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
+ * Gets default composition order
33
+ */
34
+ private _getDefaultComposition;
35
+ /**
36
+ * Builds visibility values object from the visibility map
37
+ */
38
+ private _buildVisibilityValues;
39
+ /**
40
+ * Read visibility state from individual row elements' data-visibility attributes
41
+ * This ensures toggles reflect the actual DOM state
42
+ */
43
+ private _readVisibilityFromRows;
44
+ /**
45
+ * Returns default visibility values for all items
46
+ */
47
+ private _getDefaultVisibilities;
48
+ /**
49
+ * Extracts visibility values from DOM nodes
50
+ */
51
+ private _extractVisibilityFromRows;
52
+ /**
53
+ * Parses visibility value from string to boolean
54
+ * Accepts "1", "true" as true, everything else as false
55
+ */
56
+ private _parseVisibilityValue;
57
+ /**
58
+ * Merges extracted visibilities with default values for missing keys
59
+ */
60
+ private _mergeWithDefaults;
20
61
  /**
21
62
  * Apply the reordered composition to the block's HTML structure
63
+ * Updates the data-card-composition attribute and reorders product attributes
22
64
  */
23
65
  private _applyCompositionToBlock;
66
+ /**
67
+ * Reorders attribute rows within each product row based on composition order
68
+ */
69
+ private _reorderProductAttributes;
70
+ /**
71
+ * Builds HTML string with attributes ordered according to composition
72
+ */
73
+ private _buildCompositionHtml;
24
74
  /**
25
75
  * Apply visibility changes to the block's HTML structure
76
+ * Updates display style and data-visibility attribute for all matching rows
26
77
  */
27
78
  private _applyVisibilityToBlock;
28
79
  }
@@ -1,3 +1,15 @@
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";
1
13
  /**
2
14
  * Block IDs used in the Recommendation Extension
3
15
  * These IDs are used in the esd-extension-block-id attribute to identify specific blocks
@@ -7,6 +19,8 @@ export declare enum RecommendationBlockId {
7
19
  NAME = "recommendation-block-name",
8
20
  PRICE = "recommendation-block-price",
9
21
  OLD_PRICE = "recommendation-block-old-price",
22
+ OMNIBUS_PRICE = "recommendation-block-omnibus-price",
23
+ OMNIBUS_DISCOUNT = "recommendation-block-omnibus-discount",
10
24
  IMAGE = "recommendation-block-image"
11
25
  }
12
26
  /**
@@ -29,13 +43,17 @@ export declare enum RecommendationControlId {
29
43
  NAME_BACKGROUND = "recommendation-block-name-background-control",
30
44
  NAME_COLOR = "recommendation-block-name-color-control",
31
45
  NAME_FONT_FAMILY = "recommendation-block-name-font-family-control",
46
+ NAME_LINE_SPACING = "recommendation-block-name-line-spacing-control",
32
47
  NAME_PADDINGS = "recommendation-block-name-paddings-control",
33
48
  NAME_SIZE = "recommendation-block-name-size-control",
34
49
  NAME_STYLE = "recommendation-block-name-style-control",
50
+ NAME_TEXT_TRIM = "recommendation-block-name-text-trim-control",
35
51
  PRICE_ALIGN = "recommendation-block-price-align-control",
36
52
  PRICE_BACKGROUND = "recommendation-block-price-background-control",
37
53
  PRICE_COLOR = "recommendation-block-price-color-control",
38
54
  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",
39
57
  PRICE_PADDINGS = "recommendation-block-price-paddings-control",
40
58
  PRICE_SIZE = "recommendation-block-price-size-control",
41
59
  PRICE_STYLE = "recommendation-block-price-style-control",
@@ -43,9 +61,31 @@ export declare enum RecommendationControlId {
43
61
  OLD_PRICE_BACKGROUND = "recommendation-block-old-price-background-control",
44
62
  OLD_PRICE_COLOR = "recommendation-block-old-price-color-control",
45
63
  OLD_PRICE_FONT_FAMILY = "recommendation-block-old-price-font-family-control",
64
+ OLD_PRICE_LINE_SPACING = "recommendation-block-old-price-line-spacing-control",
46
65
  OLD_PRICE_PADDINGS = "recommendation-block-old-price-paddings-control",
47
66
  OLD_PRICE_SIZE = "recommendation-block-old-price-size-control",
48
67
  OLD_PRICE_STYLE = "recommendation-block-old-price-style-control",
68
+ OMNIBUS_PRICE_ALIGN = "recommendation-block-omnibus-price-align-control",
69
+ OMNIBUS_PRICE_BACKGROUND = "recommendation-block-omnibus-price-background-control",
70
+ OMNIBUS_PRICE_COLOR = "recommendation-block-omnibus-price-color-control",
71
+ OMNIBUS_PRICE_FONT_FAMILY = "recommendation-block-omnibus-price-font-family-control",
72
+ OMNIBUS_PRICE_LINE_SPACING = "recommendation-block-omnibus-price-line-spacing-control",
73
+ OMNIBUS_PRICE_PADDINGS = "recommendation-block-omnibus-price-paddings-control",
74
+ OMNIBUS_PRICE_SIZE = "recommendation-block-omnibus-price-size-control",
75
+ OMNIBUS_PRICE_STYLE = "recommendation-block-omnibus-price-style-control",
76
+ OMNIBUS_PRICE_TEXT_BEFORE = "recommendation-block-omnibus-price-text-before-control",
77
+ OMNIBUS_PRICE_TEXT_AFTER = "recommendation-block-omnibus-price-text-after-control",
78
+ OMNIBUS_DISCOUNT_ALIGN = "recommendation-block-omnibus-discount-align-control",
79
+ OMNIBUS_DISCOUNT_BACKGROUND = "recommendation-block-omnibus-discount-background-control",
80
+ OMNIBUS_DISCOUNT_COLOR = "recommendation-block-omnibus-discount-color-control",
81
+ OMNIBUS_DISCOUNT_FONT_FAMILY = "recommendation-block-omnibus-discount-font-family-control",
82
+ OMNIBUS_DISCOUNT_LINE_SPACING = "recommendation-block-omnibus-discount-line-spacing-control",
83
+ OMNIBUS_DISCOUNT_PADDINGS = "recommendation-block-omnibus-discount-paddings-control",
84
+ OMNIBUS_DISCOUNT_SIZE = "recommendation-block-omnibus-discount-size-control",
85
+ OMNIBUS_DISCOUNT_STYLE = "recommendation-block-omnibus-discount-style-control",
86
+ OMNIBUS_DISCOUNT_TEXT_BEFORE = "recommendation-block-omnibus-discount-text-before-control",
87
+ OMNIBUS_DISCOUNT_TEXT_AFTER = "recommendation-block-omnibus-discount-text-after-control",
49
88
  IMAGE_SIZE = "recommendation-block-image-size-control",
50
- IMAGE_MARGINS = "recommendation-block-image-margins-control"
89
+ IMAGE_MARGINS = "recommendation-block-image-margins-control",
90
+ PRICE_INLINE_LAYOUT = "recommendation-block-price-inline-layout-control"
51
91
  }
@@ -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
+ }