@useinsider/guido 2.0.0-beta.5b1fb5a → 2.0.0-beta.5c09f2c

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 (190) hide show
  1. package/README.md +2 -0
  2. package/dist/@types/config/schemas.js +55 -39
  3. package/dist/components/Guido.vue.js +1 -1
  4. package/dist/components/Guido.vue2.js +15 -17
  5. package/dist/components/organisms/email-preview/PreviewContainer.vue.js +3 -3
  6. package/dist/components/organisms/email-preview/amp/AmpErrorModal.vue.js +6 -6
  7. package/dist/components/organisms/email-preview/amp/AmpErrorModal.vue2.js +17 -13
  8. package/dist/components/organisms/email-preview/amp/AmpToggle.vue.js +6 -6
  9. package/dist/components/organisms/email-preview/amp/AmpToggle.vue2.js +14 -12
  10. package/dist/components/organisms/email-preview/desktop-preview/DesktopBrowserHeader.vue.js +18 -0
  11. package/dist/components/organisms/email-preview/desktop-preview/DesktopBrowserHeader.vue2.js +15 -0
  12. package/dist/components/organisms/email-preview/desktop-preview/DesktopPreview.vue.js +10 -14
  13. package/dist/components/organisms/email-preview/desktop-preview/DesktopPreview.vue2.js +14 -22
  14. package/dist/components/organisms/email-preview/desktop-preview/EmailSizeIndicator.vue.js +3 -3
  15. package/dist/components/organisms/email-preview/mobile-preview/ContentView.vue.js +11 -10
  16. package/dist/components/organisms/email-preview/mobile-preview/InboxView.vue.js +12 -10
  17. package/dist/components/organisms/email-preview/mobile-preview/MobilePreview.vue.js +11 -10
  18. package/dist/components/organisms/email-preview/mobile-preview/MobilePreview.vue2.js +15 -14
  19. package/dist/components/organisms/header/EditorActions.vue.js +21 -0
  20. package/dist/components/organisms/header/EditorActions.vue2.js +41 -0
  21. package/dist/components/organisms/header/EditorToolbar.vue.js +18 -0
  22. package/dist/components/organisms/header/EditorToolbar.vue2.js +17 -0
  23. package/dist/components/organisms/header/HeaderWrapper.vue.js +6 -5
  24. package/dist/components/organisms/header/LeftSlot.vue.js +11 -11
  25. package/dist/components/organisms/header/LeftSlot.vue2.js +11 -12
  26. package/dist/components/organisms/header/MiddleSlot.vue.js +7 -7
  27. package/dist/components/organisms/header/MiddleSlot.vue2.js +11 -15
  28. package/dist/components/organisms/header/RightSlot.vue.js +11 -14
  29. package/dist/components/organisms/header/RightSlot.vue2.js +13 -30
  30. package/dist/components/organisms/header/version-history/VersionHistory.vue.js +5 -5
  31. package/dist/components/organisms/onboarding/NewVersionPopup.vue2.js +15 -15
  32. package/dist/components/organisms/unsubscribe/UnsubscribeTypeSelection.vue.js +1 -1
  33. package/dist/components/organisms/unsubscribe/UnsubscribeTypeSelection.vue2.js +20 -19
  34. package/dist/composables/useActionsApi.js +33 -30
  35. package/dist/composables/useConfig.js +29 -27
  36. package/dist/composables/useSave.js +13 -11
  37. package/dist/composables/useStripo.js +40 -40
  38. package/dist/config/migrator/recommendationMigrator.js +2 -2
  39. package/dist/enums/academy.js +8 -0
  40. package/dist/enums/onboarding.js +1 -2
  41. package/dist/enums/unsubscribe.js +20 -21
  42. package/dist/extensions/Blocks/Recommendation/block.js +40 -6
  43. package/dist/extensions/Blocks/Recommendation/constants/blockIds.js +4 -0
  44. package/dist/extensions/Blocks/Recommendation/constants/controlIds.js +4 -0
  45. package/dist/extensions/Blocks/Recommendation/constants/defaultConfig.js +64 -0
  46. package/dist/extensions/Blocks/Recommendation/constants/layout.js +20 -0
  47. package/dist/extensions/Blocks/Recommendation/constants/selectors.js +19 -0
  48. package/dist/extensions/Blocks/Recommendation/controls/button/index.js +64 -0
  49. package/dist/extensions/Blocks/Recommendation/controls/cardBackground/index.js +80 -0
  50. package/dist/extensions/Blocks/Recommendation/controls/cardComposition/index.js +232 -0
  51. package/dist/extensions/Blocks/Recommendation/controls/image/index.js +19 -0
  52. package/dist/extensions/Blocks/Recommendation/controls/layout/index.js +96 -0
  53. package/dist/extensions/Blocks/Recommendation/controls/main/algorithm.js +110 -0
  54. package/dist/extensions/Blocks/Recommendation/controls/main/currency.js +204 -0
  55. package/dist/extensions/Blocks/Recommendation/controls/main/filters.js +54 -0
  56. package/dist/extensions/Blocks/Recommendation/controls/main/index.js +201 -0
  57. package/dist/extensions/Blocks/Recommendation/controls/main/locale.js +74 -0
  58. package/dist/extensions/Blocks/Recommendation/controls/main/productLayout.js +118 -0
  59. package/dist/extensions/Blocks/Recommendation/controls/main/shuffle.js +71 -0
  60. package/dist/extensions/Blocks/Recommendation/controls/main/utils.js +286 -0
  61. package/dist/extensions/Blocks/Recommendation/controls/name/index.js +46 -0
  62. package/dist/extensions/Blocks/Recommendation/controls/name/textTrim.js +76 -0
  63. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/index.js +44 -0
  64. package/dist/extensions/Blocks/Recommendation/controls/omnibusDiscount/index.js +48 -0
  65. package/dist/extensions/Blocks/Recommendation/controls/{omnibusDiscountTextAfterControl.js → omnibusDiscount/textAfter.js} +16 -14
  66. package/dist/extensions/Blocks/Recommendation/controls/{omnibusDiscountTextBeforeControl.js → omnibusDiscount/textBefore.js} +16 -14
  67. package/dist/extensions/Blocks/Recommendation/controls/omnibusPrice/index.js +48 -0
  68. package/dist/extensions/Blocks/Recommendation/controls/{omnibusPriceTextAfterControl.js → omnibusPrice/textAfter.js} +16 -14
  69. package/dist/extensions/Blocks/Recommendation/controls/{omnibusPriceTextBeforeControl.js → omnibusPrice/textBefore.js} +14 -12
  70. package/dist/extensions/Blocks/Recommendation/controls/price/index.js +44 -0
  71. package/dist/extensions/Blocks/Recommendation/controls/spacing/index.js +222 -0
  72. package/dist/extensions/Blocks/Recommendation/extension.js +40 -17
  73. package/dist/extensions/Blocks/Recommendation/iconsRegistry.js +19 -3
  74. package/dist/extensions/Blocks/Recommendation/recommendation.css.js +13 -4
  75. package/dist/extensions/Blocks/Recommendation/services/configService.js +239 -0
  76. package/dist/extensions/Blocks/Recommendation/settingsPanel.js +21 -10
  77. package/dist/extensions/Blocks/Recommendation/store/recommendation.js +41 -36
  78. package/dist/extensions/Blocks/Recommendation/templates/grid/elementRenderer.js +233 -0
  79. package/dist/extensions/Blocks/Recommendation/templates/grid/migration.js +251 -0
  80. package/dist/extensions/Blocks/Recommendation/templates/grid/template.js +69 -0
  81. package/dist/extensions/Blocks/Recommendation/templates/index.js +12 -0
  82. package/dist/extensions/Blocks/Recommendation/templates/list/elementRenderer.js +174 -0
  83. package/dist/extensions/Blocks/Recommendation/templates/list/template.js +73 -0
  84. package/dist/extensions/Blocks/Recommendation/templates/utils.js +121 -0
  85. package/dist/extensions/Blocks/Recommendation/types/nodeConfig.js +6 -0
  86. package/dist/extensions/Blocks/Recommendation/utils/filterUtil.js +9 -9
  87. package/dist/extensions/Blocks/Recommendation/utils/preserveTextStyles.js +27 -16
  88. package/dist/extensions/Blocks/Recommendation/utils/priceFormatter.js +29 -0
  89. package/dist/extensions/Blocks/Recommendation/utils/tagName.js +46 -0
  90. package/dist/extensions/Blocks/Unsubscribe/extension.js +9 -9
  91. package/dist/extensions/Blocks/common-control.js +6 -7
  92. package/dist/extensions/Blocks/controlFactories.js +155 -121
  93. package/dist/guido.css +1 -1
  94. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/esm/index.js +223 -169
  95. package/dist/services/recommendationApi.js +10 -9
  96. package/dist/services/stripoApi.js +6 -10
  97. package/dist/src/@types/config/index.d.ts +2 -2
  98. package/dist/src/@types/config/schemas.d.ts +30 -0
  99. package/dist/src/@types/config/types.d.ts +7 -1
  100. package/dist/src/components/organisms/email-preview/desktop-preview/DesktopBrowserHeader.vue.d.ts +2 -0
  101. package/dist/src/components/organisms/header/EditorActions.vue.d.ts +4 -0
  102. package/dist/src/components/organisms/header/EditorToolbar.vue.d.ts +2 -0
  103. package/dist/src/components/organisms/header/RightSlot.vue.d.ts +1 -1
  104. package/dist/src/components/wrappers/WpDrawer.vue.d.ts +1 -1
  105. package/dist/src/composables/useActionsApi.d.ts +1 -0
  106. package/dist/src/composables/useConfig.d.ts +8 -0
  107. package/dist/src/enums/academy.d.ts +12 -0
  108. package/dist/src/enums/onboarding.d.ts +0 -1
  109. package/dist/src/enums/unsubscribe.d.ts +0 -1
  110. package/dist/src/extensions/Blocks/Recommendation/block.d.ts +34 -0
  111. package/dist/src/extensions/Blocks/Recommendation/constants/blockIds.d.ts +13 -0
  112. package/dist/src/extensions/Blocks/Recommendation/{constants.d.ts → constants/controlIds.d.ts} +0 -24
  113. package/dist/src/extensions/Blocks/Recommendation/constants/defaultConfig.d.ts +49 -0
  114. package/dist/src/extensions/Blocks/Recommendation/constants/index.d.ts +13 -0
  115. package/dist/src/extensions/Blocks/Recommendation/constants/layout.d.ts +35 -0
  116. package/dist/src/extensions/Blocks/Recommendation/constants/selectors.d.ts +31 -0
  117. package/dist/src/extensions/Blocks/Recommendation/controls/button/index.d.ts +143 -0
  118. package/dist/src/extensions/Blocks/Recommendation/controls/{cardBackgroundColorControl.d.ts → cardBackground/index.d.ts} +9 -3
  119. package/dist/src/extensions/Blocks/Recommendation/{cardCompositionControl.d.ts → controls/cardComposition/index.d.ts} +23 -3
  120. package/dist/src/extensions/Blocks/Recommendation/controls/image/index.d.ts +35 -0
  121. package/dist/src/extensions/Blocks/Recommendation/controls/index.d.ts +21 -589
  122. package/dist/src/extensions/Blocks/Recommendation/controls/layout/index.d.ts +37 -0
  123. package/dist/src/extensions/Blocks/Recommendation/controls/main/algorithm.d.ts +29 -0
  124. package/dist/src/extensions/Blocks/Recommendation/controls/main/currency.d.ts +45 -0
  125. package/dist/src/extensions/Blocks/Recommendation/controls/main/filters.d.ts +22 -0
  126. package/dist/src/extensions/Blocks/Recommendation/controls/main/index.d.ts +56 -0
  127. package/dist/src/extensions/Blocks/Recommendation/controls/main/locale.d.ts +24 -0
  128. package/dist/src/extensions/Blocks/Recommendation/controls/main/productLayout.d.ts +42 -0
  129. package/dist/src/extensions/Blocks/Recommendation/controls/main/shuffle.d.ts +23 -0
  130. package/dist/src/extensions/Blocks/Recommendation/controls/main/utils.d.ts +214 -0
  131. package/dist/src/extensions/Blocks/Recommendation/controls/name/index.d.ts +97 -0
  132. package/dist/src/extensions/Blocks/Recommendation/controls/{nameTextTrimControl.d.ts → name/textTrim.d.ts} +1 -1
  133. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/index.d.ts +95 -0
  134. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusDiscount/index.d.ts +100 -0
  135. package/dist/src/extensions/Blocks/Recommendation/controls/{omnibusDiscountTextAfterControl.d.ts → omnibusDiscount/textAfter.d.ts} +1 -1
  136. package/dist/src/extensions/Blocks/Recommendation/controls/{omnibusDiscountTextBeforeControl.d.ts → omnibusDiscount/textBefore.d.ts} +1 -1
  137. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusPrice/index.d.ts +100 -0
  138. package/dist/src/extensions/Blocks/Recommendation/controls/{omnibusPriceTextAfterControl.d.ts → omnibusPrice/textAfter.d.ts} +1 -1
  139. package/dist/src/extensions/Blocks/Recommendation/controls/{omnibusPriceTextBeforeControl.d.ts → omnibusPrice/textBefore.d.ts} +1 -1
  140. package/dist/src/extensions/Blocks/Recommendation/controls/price/index.d.ts +95 -0
  141. package/dist/src/extensions/Blocks/Recommendation/controls/{spacingControl.d.ts → spacing/index.d.ts} +33 -10
  142. package/dist/src/extensions/Blocks/Recommendation/extension.d.ts +9 -0
  143. package/dist/src/extensions/Blocks/Recommendation/services/configService.d.ts +151 -0
  144. package/dist/src/extensions/Blocks/Recommendation/services/index.d.ts +6 -0
  145. package/dist/src/extensions/Blocks/Recommendation/store/recommendation.d.ts +17 -16
  146. package/dist/src/extensions/Blocks/Recommendation/templates/grid/elementRenderer.d.ts +20 -0
  147. package/dist/src/extensions/Blocks/Recommendation/templates/{migrationTemplate.d.ts → grid/migration.d.ts} +11 -4
  148. package/dist/src/extensions/Blocks/Recommendation/templates/grid/template.d.ts +33 -0
  149. package/dist/src/extensions/Blocks/Recommendation/templates/index.d.ts +39 -0
  150. package/dist/src/extensions/Blocks/Recommendation/templates/list/elementRenderer.d.ts +8 -0
  151. package/dist/src/extensions/Blocks/Recommendation/templates/list/migration.d.ts +25 -0
  152. package/dist/src/extensions/Blocks/Recommendation/templates/list/template.d.ts +18 -0
  153. package/dist/src/extensions/Blocks/Recommendation/templates/utils.d.ts +54 -0
  154. package/dist/src/extensions/Blocks/Recommendation/types/index.d.ts +7 -0
  155. package/dist/src/extensions/Blocks/Recommendation/types/nodeConfig.d.ts +154 -0
  156. package/dist/src/extensions/Blocks/Recommendation/utils/priceFormatter.d.ts +33 -0
  157. package/dist/src/extensions/Blocks/Recommendation/utils/stylePreserver.d.ts +113 -0
  158. package/dist/src/extensions/Blocks/Recommendation/utils/tagName.d.ts +77 -0
  159. package/dist/src/extensions/Blocks/common-control.d.ts +1 -1
  160. package/dist/src/stores/config.d.ts +164 -1
  161. package/dist/src/stores/editor.d.ts +21 -0
  162. package/dist/static/assets/desktop/desktop-mockup-center.svg.js +4 -0
  163. package/dist/static/assets/desktop/desktop-mockup-left.svg.js +4 -0
  164. package/dist/static/assets/desktop/desktop-mockup-right.svg.js +4 -0
  165. package/dist/static/assets/mobile/email-mockup.svg.js +4 -0
  166. package/dist/static/assets/mobile/inbox-mockup.svg.js +4 -0
  167. package/dist/static/styles/components/button.css.js +1 -1
  168. package/dist/static/styles/components/wide-panel.css.js +1 -1
  169. package/dist/static/styles/customEditorStyle.css.js +25 -2
  170. package/dist/stores/config.js +7 -0
  171. package/dist/stores/editor.js +1 -0
  172. package/dist/utils/templatePreparation.js +17 -17
  173. package/package.json +1 -1
  174. package/dist/components/organisms/email-preview/desktop-preview/EmailHeaderInfo.vue.js +0 -17
  175. package/dist/components/organisms/email-preview/desktop-preview/EmailHeaderInfo.vue2.js +0 -20
  176. package/dist/extensions/Blocks/Recommendation/cardCompositionControl.js +0 -187
  177. package/dist/extensions/Blocks/Recommendation/constants.js +0 -13
  178. package/dist/extensions/Blocks/Recommendation/control.js +0 -336
  179. package/dist/extensions/Blocks/Recommendation/controls/cardBackgroundColorControl.js +0 -68
  180. package/dist/extensions/Blocks/Recommendation/controls/index.js +0 -245
  181. package/dist/extensions/Blocks/Recommendation/controls/nameTextTrimControl.js +0 -74
  182. package/dist/extensions/Blocks/Recommendation/controls/spacingControl.js +0 -188
  183. package/dist/extensions/Blocks/Recommendation/templates/blockTemplate.js +0 -181
  184. package/dist/extensions/Blocks/Recommendation/templates/migrationTemplate.js +0 -189
  185. package/dist/extensions/Blocks/Recommendation/templates/templateUtils.js +0 -209
  186. package/dist/src/extensions/Blocks/Recommendation/control.d.ts +0 -38
  187. package/dist/src/extensions/Blocks/Recommendation/templates/blockTemplate.d.ts +0 -16
  188. package/dist/src/extensions/Blocks/Recommendation/templates/templateUtils.d.ts +0 -52
  189. package/dist/static/assets/inbox-mockup.svg.js +0 -4
  190. package/dist/static/assets/phone-mockup.svg.js +0 -4
@@ -0,0 +1,33 @@
1
+ /**
2
+ * Price Formatting Utilities
3
+ *
4
+ * Provides functions for formatting prices according to currency settings.
5
+ * Used to format prices displayed in recommendation product cards.
6
+ */
7
+ import type { CurrencyConfig } from '../types/nodeConfig';
8
+ /**
9
+ * Options for formatting a price
10
+ */
11
+ export interface FormatPriceOptions {
12
+ /** The numeric price value */
13
+ price: number;
14
+ /** Currency configuration */
15
+ currency: CurrencyConfig;
16
+ }
17
+ /**
18
+ * Formats a numeric price according to currency settings
19
+ * @example
20
+ * // Returns: "$ 1,999.99"
21
+ * formatPrice({ price: 1999.99, currency: currencyConfig })
22
+ * @param options - Formatting options
23
+ * @returns Formatted price string
24
+ */
25
+ export declare function formatPrice(options: FormatPriceOptions): string;
26
+ /**
27
+ * Parses a formatted price string back to a number
28
+ * Useful for extracting numeric values from formatted price displays
29
+ * @param formattedPrice - The formatted price string
30
+ * @param currency - Currency configuration for parsing
31
+ * @returns Parsed numeric value or NaN if parsing fails
32
+ */
33
+ export declare function parseFormattedPrice(formattedPrice: string, currency: CurrencyConfig): number;
@@ -0,0 +1,113 @@
1
+ /**
2
+ * Style Preserver Utility
3
+ *
4
+ * Captures and restores element styles during block regeneration.
5
+ * This ensures user styling is preserved when:
6
+ * - Layout changes (vertical <-> horizontal)
7
+ * - Cards per row changes
8
+ * - Composition order changes
9
+ *
10
+ * Works with the node config system to provide complete style persistence.
11
+ */
12
+ import type { ImmutableHtmlNode } from '@stripoinc/ui-editor-extensions';
13
+ import { ModificationDescription } from '@stripoinc/ui-editor-extensions';
14
+ /**
15
+ * Style properties that can be captured for text elements
16
+ */
17
+ export interface TextElementStyles {
18
+ fontSize?: string;
19
+ fontFamily?: string;
20
+ fontWeight?: string;
21
+ fontStyle?: string;
22
+ color?: string;
23
+ textAlign?: string;
24
+ lineHeight?: string;
25
+ textDecoration?: string;
26
+ }
27
+ /**
28
+ * Style properties for button elements
29
+ */
30
+ export interface ButtonElementStyles extends TextElementStyles {
31
+ backgroundColor?: string;
32
+ borderRadius?: string;
33
+ border?: string;
34
+ padding?: string;
35
+ }
36
+ /**
37
+ * Style properties for image elements
38
+ */
39
+ export interface ImageElementStyles {
40
+ width?: string;
41
+ height?: string;
42
+ maxWidth?: string;
43
+ }
44
+ /**
45
+ * Complete captured styles for a recommendation block
46
+ */
47
+ export interface CapturedStyles {
48
+ /** Product name text styles */
49
+ name: TextElementStyles;
50
+ /** Current price text styles */
51
+ price: TextElementStyles;
52
+ /** Original/old price text styles */
53
+ oldPrice: TextElementStyles;
54
+ /** Omnibus price text styles */
55
+ omnibusPrice: TextElementStyles;
56
+ /** Omnibus discount text styles */
57
+ omnibusDiscount: TextElementStyles;
58
+ /** CTA button styles */
59
+ button: ButtonElementStyles;
60
+ /** Product image styles */
61
+ image: ImageElementStyles;
62
+ /** Card background color */
63
+ cardBackgroundColor: string | null;
64
+ /** Column spacing in pixels */
65
+ columnSpacing: number;
66
+ /** Row spacing in pixels */
67
+ rowSpacing: number;
68
+ /** Element composition order */
69
+ composition: string[];
70
+ /** Element visibility flags */
71
+ visibility: Record<string, boolean>;
72
+ }
73
+ type DocumentModifier = {
74
+ modifyHtml: (node: ImmutableHtmlNode) => {
75
+ setStyle: (prop: string, value: string) => DocumentModifier;
76
+ };
77
+ apply: (description: ModificationDescription) => void;
78
+ };
79
+ /**
80
+ * Capture all styles from a recommendation block
81
+ *
82
+ * Call this BEFORE any operation that regenerates the block HTML.
83
+ * The captured styles can then be restored after regeneration.
84
+ * @example
85
+ * // Before layout change
86
+ * const styles = captureStyles(this.currentNode);
87
+ *
88
+ * // ... regenerate block HTML ...
89
+ *
90
+ * // After regeneration
91
+ * restoreStyles(this.currentNode, this.api.getDocumentModifier(), styles);
92
+ * @param node - The block node to capture styles from
93
+ * @returns Complete captured styles object
94
+ */
95
+ export declare function captureStyles(node: ImmutableHtmlNode | null | undefined): CapturedStyles;
96
+ /**
97
+ * Restore captured styles to a regenerated block
98
+ *
99
+ * Call this AFTER regenerating block HTML to reapply user styling.
100
+ * @example
101
+ * restoreStyles(this.currentNode, this.api.getDocumentModifier(), capturedStyles);
102
+ * @param node - The block node to restore styles to
103
+ * @param modifier - Document modifier for applying changes
104
+ * @param styles - Previously captured styles
105
+ */
106
+ export declare function restoreStyles(node: ImmutableHtmlNode | null | undefined, modifier: DocumentModifier, styles: CapturedStyles): void;
107
+ /**
108
+ * Check if styles have meaningful content worth restoring
109
+ * @param styles - Captured styles to check
110
+ * @returns True if styles contain restorable content
111
+ */
112
+ export declare function hasRestorableStyles(styles: CapturedStyles): boolean;
113
+ export {};
@@ -0,0 +1,77 @@
1
+ /**
2
+ * Node Type Guards and Tag Name Utilities
3
+ *
4
+ * Provides type-safe utilities for working with ImmutableHtmlNode.
5
+ * Handles both standard DOM properties and Stripo's custom methods.
6
+ */
7
+ import type { ImmutableHtmlNode } from '@stripoinc/ui-editor-extensions';
8
+ /** Interface for nodes with standard tagName property */
9
+ interface NodeWithTagName {
10
+ tagName: string;
11
+ }
12
+ /** Interface for nodes with getStyle method */
13
+ export interface NodeWithGetStyle {
14
+ getStyle: (property: string) => string | null | undefined;
15
+ }
16
+ /** Interface for nodes with parent method */
17
+ export interface NodeWithParent {
18
+ parent: () => ImmutableHtmlNode | null;
19
+ }
20
+ /**
21
+ * Type guard to check if a node has getStyle method
22
+ * @param node - The node to check
23
+ */
24
+ export declare function hasGetStyle(node: unknown): node is NodeWithGetStyle;
25
+ /**
26
+ * Type guard to check if a node has parent method
27
+ * @param node - The node to check
28
+ */
29
+ export declare function hasParent(node: unknown): node is NodeWithParent;
30
+ /**
31
+ * Type guard to check if a node is a TD element
32
+ * @param node - The node to check
33
+ */
34
+ export declare function isTdNode(node: unknown): node is ImmutableHtmlNode & NodeWithTagName;
35
+ /**
36
+ * Safely retrieves a style value from a node
37
+ * @param node - The node to get the style from
38
+ * @param property - The CSS property name
39
+ * @returns The style value or null if not accessible
40
+ */
41
+ export declare function safeGetStyle(node: ImmutableHtmlNode | null, property: string): string | null | undefined;
42
+ /**
43
+ * Safely retrieves the parent element of a node
44
+ * @param node - The node to get the parent from
45
+ * @returns The parent node or null if not accessible
46
+ */
47
+ export declare function safeGetParent(node: ImmutableHtmlNode | null): ImmutableHtmlNode | null;
48
+ /**
49
+ * Safely retrieves the tag name from a node.
50
+ * Handles both standard DOM tagName property and Stripo's getTagName() method.
51
+ * @param node - The node to get the tag name from
52
+ * @param defaultValue - Default value if tag name cannot be determined (default: 'UNKNOWN')
53
+ * @returns The uppercase tag name
54
+ */
55
+ export declare function getTagName(node: ImmutableHtmlNode | null | undefined, defaultValue?: string): string;
56
+ /**
57
+ * Checks if a tag name represents a table cell element.
58
+ * Includes standard TD and Stripo's custom block types (BLOCK_IMAGE, BLOCK_BUTTON).
59
+ * @param tagName - The tag name to check (case-insensitive)
60
+ * @returns True if the tag represents a table cell
61
+ */
62
+ export declare function isTableCellTag(tagName: string): boolean;
63
+ /**
64
+ * Checks if a node is a table cell element.
65
+ * Combines getTagName and isTableCellTag for convenience.
66
+ * @param node - The node to check
67
+ * @returns True if the node is a table cell element
68
+ */
69
+ export declare function isTableCellNode(node: ImmutableHtmlNode | null | undefined): boolean;
70
+ /**
71
+ * Gets the appropriate CSS display value for showing a table element.
72
+ * Table cells use 'table-cell', table rows use 'table-row'.
73
+ * @param node - The table element node
74
+ * @returns The CSS display value ('table-cell' or 'table-row')
75
+ */
76
+ export declare function getTableDisplayValue(node: ImmutableHtmlNode | null | undefined): 'table-cell' | 'table-row';
77
+ export {};
@@ -75,7 +75,7 @@ export declare abstract class CommonControl extends Control {
75
75
  * @returns true if block instance changed, false otherwise
76
76
  */
77
77
  protected handleBlockInstanceChange(syncFunction: (node: ImmutableHtmlNode) => void, updateUI: () => void, blockInstanceIdAttribute?: string): boolean;
78
- _GuLabel({ text, name, position }: LabelProps): string;
78
+ _GuLabel({ text, name }: LabelProps): string;
79
79
  _GuToggle(name: string): string;
80
80
  _GuSelectItem({ text, value }: {
81
81
  text: string;
@@ -1,4 +1,4 @@
1
- import type { GuidoConfig, GuidoConfigInput, IdentityConfig, PartnerConfig, TemplateConfig, EditorConfig, UIConfig, FeaturesConfig, BlocksConfig, CompilerConfig } from '@@/Types/config';
1
+ import type { GuidoConfig, GuidoConfigInput, IdentityConfig, PartnerConfig, TemplateConfig, EditorConfig, UIConfig, FeaturesConfig, BlocksConfig, CompilerConfig, CallbacksConfig } from '@@/Types/config';
2
2
  interface ConfigStoreState {
3
3
  /** Whether the config has been initialized */
4
4
  initialized: boolean;
@@ -36,6 +36,7 @@ export declare const useConfigStore: import("pinia").StoreDefinition<"guido-conf
36
36
  } | undefined;
37
37
  }[];
38
38
  selectedUnsubscribePages: number[];
39
+ forceRecreate: boolean;
39
40
  };
40
41
  editor: {
41
42
  locale: string;
@@ -95,6 +96,9 @@ export declare const useConfigStore: import("pinia").StoreDefinition<"guido-conf
95
96
  })[];
96
97
  ignoreDefaultRules: boolean;
97
98
  };
99
+ callbacks: {
100
+ externalValidation?: import("@@/Types/config").ExternalValidationHandler | undefined;
101
+ };
98
102
  } | null;
99
103
  } & import("pinia").PiniaCustomStateProperties<ConfigStoreState>) => IdentityConfig | null;
100
104
  /**
@@ -127,6 +131,7 @@ export declare const useConfigStore: import("pinia").StoreDefinition<"guido-conf
127
131
  } | undefined;
128
132
  }[];
129
133
  selectedUnsubscribePages: number[];
134
+ forceRecreate: boolean;
130
135
  };
131
136
  editor: {
132
137
  locale: string;
@@ -186,6 +191,9 @@ export declare const useConfigStore: import("pinia").StoreDefinition<"guido-conf
186
191
  })[];
187
192
  ignoreDefaultRules: boolean;
188
193
  };
194
+ callbacks: {
195
+ externalValidation?: import("@@/Types/config").ExternalValidationHandler | undefined;
196
+ };
189
197
  } | null;
190
198
  } & import("pinia").PiniaCustomStateProperties<ConfigStoreState>) => PartnerConfig | null;
191
199
  /**
@@ -218,6 +226,7 @@ export declare const useConfigStore: import("pinia").StoreDefinition<"guido-conf
218
226
  } | undefined;
219
227
  }[];
220
228
  selectedUnsubscribePages: number[];
229
+ forceRecreate: boolean;
221
230
  };
222
231
  editor: {
223
232
  locale: string;
@@ -277,6 +286,9 @@ export declare const useConfigStore: import("pinia").StoreDefinition<"guido-conf
277
286
  })[];
278
287
  ignoreDefaultRules: boolean;
279
288
  };
289
+ callbacks: {
290
+ externalValidation?: import("@@/Types/config").ExternalValidationHandler | undefined;
291
+ };
280
292
  } | null;
281
293
  } & import("pinia").PiniaCustomStateProperties<ConfigStoreState>) => TemplateConfig | null;
282
294
  /**
@@ -309,6 +321,7 @@ export declare const useConfigStore: import("pinia").StoreDefinition<"guido-conf
309
321
  } | undefined;
310
322
  }[];
311
323
  selectedUnsubscribePages: number[];
324
+ forceRecreate: boolean;
312
325
  };
313
326
  editor: {
314
327
  locale: string;
@@ -368,6 +381,9 @@ export declare const useConfigStore: import("pinia").StoreDefinition<"guido-conf
368
381
  })[];
369
382
  ignoreDefaultRules: boolean;
370
383
  };
384
+ callbacks: {
385
+ externalValidation?: import("@@/Types/config").ExternalValidationHandler | undefined;
386
+ };
371
387
  } | null;
372
388
  } & import("pinia").PiniaCustomStateProperties<ConfigStoreState>) => EditorConfig | null;
373
389
  /**
@@ -400,6 +416,7 @@ export declare const useConfigStore: import("pinia").StoreDefinition<"guido-conf
400
416
  } | undefined;
401
417
  }[];
402
418
  selectedUnsubscribePages: number[];
419
+ forceRecreate: boolean;
403
420
  };
404
421
  editor: {
405
422
  locale: string;
@@ -459,6 +476,9 @@ export declare const useConfigStore: import("pinia").StoreDefinition<"guido-conf
459
476
  })[];
460
477
  ignoreDefaultRules: boolean;
461
478
  };
479
+ callbacks: {
480
+ externalValidation?: import("@@/Types/config").ExternalValidationHandler | undefined;
481
+ };
462
482
  } | null;
463
483
  } & import("pinia").PiniaCustomStateProperties<ConfigStoreState>) => UIConfig | null;
464
484
  /**
@@ -491,6 +511,7 @@ export declare const useConfigStore: import("pinia").StoreDefinition<"guido-conf
491
511
  } | undefined;
492
512
  }[];
493
513
  selectedUnsubscribePages: number[];
514
+ forceRecreate: boolean;
494
515
  };
495
516
  editor: {
496
517
  locale: string;
@@ -550,6 +571,9 @@ export declare const useConfigStore: import("pinia").StoreDefinition<"guido-conf
550
571
  })[];
551
572
  ignoreDefaultRules: boolean;
552
573
  };
574
+ callbacks: {
575
+ externalValidation?: import("@@/Types/config").ExternalValidationHandler | undefined;
576
+ };
553
577
  } | null;
554
578
  } & import("pinia").PiniaCustomStateProperties<ConfigStoreState>) => FeaturesConfig | null;
555
579
  /**
@@ -582,6 +606,7 @@ export declare const useConfigStore: import("pinia").StoreDefinition<"guido-conf
582
606
  } | undefined;
583
607
  }[];
584
608
  selectedUnsubscribePages: number[];
609
+ forceRecreate: boolean;
585
610
  };
586
611
  editor: {
587
612
  locale: string;
@@ -641,6 +666,9 @@ export declare const useConfigStore: import("pinia").StoreDefinition<"guido-conf
641
666
  })[];
642
667
  ignoreDefaultRules: boolean;
643
668
  };
669
+ callbacks: {
670
+ externalValidation?: import("@@/Types/config").ExternalValidationHandler | undefined;
671
+ };
644
672
  } | null;
645
673
  } & import("pinia").PiniaCustomStateProperties<ConfigStoreState>) => BlocksConfig | null;
646
674
  /**
@@ -673,6 +701,7 @@ export declare const useConfigStore: import("pinia").StoreDefinition<"guido-conf
673
701
  } | undefined;
674
702
  }[];
675
703
  selectedUnsubscribePages: number[];
704
+ forceRecreate: boolean;
676
705
  };
677
706
  editor: {
678
707
  locale: string;
@@ -732,8 +761,106 @@ export declare const useConfigStore: import("pinia").StoreDefinition<"guido-conf
732
761
  })[];
733
762
  ignoreDefaultRules: boolean;
734
763
  };
764
+ callbacks: {
765
+ externalValidation?: import("@@/Types/config").ExternalValidationHandler | undefined;
766
+ };
735
767
  } | null;
736
768
  } & import("pinia").PiniaCustomStateProperties<ConfigStoreState>) => CompilerConfig | null;
769
+ /**
770
+ * Get the callbacks configuration
771
+ */
772
+ callbacks: (state: {
773
+ initialized: boolean;
774
+ config: {
775
+ identity: {
776
+ templateId: string;
777
+ userId: string;
778
+ variationId?: string | undefined;
779
+ };
780
+ partner: {
781
+ name: string;
782
+ productType: 60 | 49 | 97;
783
+ messageType: 1 | 2;
784
+ username: string;
785
+ };
786
+ template: {
787
+ html: string;
788
+ css: string;
789
+ preselectedDynamicContent: {
790
+ text: string;
791
+ value: string;
792
+ fallback?: string | undefined;
793
+ format?: {
794
+ key: string;
795
+ value: string;
796
+ } | undefined;
797
+ }[];
798
+ selectedUnsubscribePages: number[];
799
+ forceRecreate: boolean;
800
+ };
801
+ editor: {
802
+ locale: string;
803
+ translationsPath: string;
804
+ migrationDate: number;
805
+ emailHeader: {
806
+ senderName: string;
807
+ subject: string;
808
+ };
809
+ };
810
+ ui: {
811
+ showHeader: boolean;
812
+ backButtonLabel?: string | undefined;
813
+ };
814
+ features: {
815
+ dynamicContent: boolean;
816
+ saveAsTemplate: boolean;
817
+ versionHistory: boolean;
818
+ testMessage: boolean;
819
+ displayConditions: boolean;
820
+ unsubscribe: boolean;
821
+ modulesDisabled: boolean;
822
+ };
823
+ blocks: {
824
+ excludeDefaults: ("amp-accordion" | "amp-carousel" | "amp-form-controls" | "banner-block" | "button-block" | "html-block" | "image-block" | "menu-block" | "social-block" | "spacer-block" | "text-block" | "timer-block" | "video-block")[];
825
+ includeCustoms: ("dynamic-content" | "checkbox-block" | "radio-button-block" | "recommendation-block" | "unsubscribe-block" | "coupon-block" | "items-block")[];
826
+ };
827
+ compiler: {
828
+ customRules: ({
829
+ type: "replace";
830
+ search: string;
831
+ replacement: string;
832
+ replaceAll?: boolean | undefined;
833
+ id: string;
834
+ description?: string | undefined;
835
+ priority: number;
836
+ } | {
837
+ type: "regex";
838
+ pattern: string;
839
+ replacement: string;
840
+ flags?: string | undefined;
841
+ id: string;
842
+ description?: string | undefined;
843
+ priority: number;
844
+ } | {
845
+ type: "remove";
846
+ targets: string[];
847
+ id: string;
848
+ description?: string | undefined;
849
+ priority: number;
850
+ } | {
851
+ type: "custom";
852
+ processor: (html: string) => string;
853
+ id: string;
854
+ description?: string | undefined;
855
+ priority: number;
856
+ })[];
857
+ ignoreDefaultRules: boolean;
858
+ };
859
+ callbacks: {
860
+ externalValidation?: import("@@/Types/config").ExternalValidationHandler | undefined;
861
+ };
862
+ } | null;
863
+ } & import("pinia").PiniaCustomStateProperties<ConfigStoreState>) => CallbacksConfig | null;
737
864
  /**
738
865
  * Get the template ID
739
866
  */
@@ -764,6 +891,7 @@ export declare const useConfigStore: import("pinia").StoreDefinition<"guido-conf
764
891
  } | undefined;
765
892
  }[];
766
893
  selectedUnsubscribePages: number[];
894
+ forceRecreate: boolean;
767
895
  };
768
896
  editor: {
769
897
  locale: string;
@@ -823,6 +951,9 @@ export declare const useConfigStore: import("pinia").StoreDefinition<"guido-conf
823
951
  })[];
824
952
  ignoreDefaultRules: boolean;
825
953
  };
954
+ callbacks: {
955
+ externalValidation?: import("@@/Types/config").ExternalValidationHandler | undefined;
956
+ };
826
957
  } | null;
827
958
  } & import("pinia").PiniaCustomStateProperties<ConfigStoreState>) => string;
828
959
  /**
@@ -855,6 +986,7 @@ export declare const useConfigStore: import("pinia").StoreDefinition<"guido-conf
855
986
  } | undefined;
856
987
  }[];
857
988
  selectedUnsubscribePages: number[];
989
+ forceRecreate: boolean;
858
990
  };
859
991
  editor: {
860
992
  locale: string;
@@ -914,6 +1046,9 @@ export declare const useConfigStore: import("pinia").StoreDefinition<"guido-conf
914
1046
  })[];
915
1047
  ignoreDefaultRules: boolean;
916
1048
  };
1049
+ callbacks: {
1050
+ externalValidation?: import("@@/Types/config").ExternalValidationHandler | undefined;
1051
+ };
917
1052
  } | null;
918
1053
  } & import("pinia").PiniaCustomStateProperties<ConfigStoreState>) => string;
919
1054
  /**
@@ -946,6 +1081,7 @@ export declare const useConfigStore: import("pinia").StoreDefinition<"guido-conf
946
1081
  } | undefined;
947
1082
  }[];
948
1083
  selectedUnsubscribePages: number[];
1084
+ forceRecreate: boolean;
949
1085
  };
950
1086
  editor: {
951
1087
  locale: string;
@@ -1005,6 +1141,9 @@ export declare const useConfigStore: import("pinia").StoreDefinition<"guido-conf
1005
1141
  })[];
1006
1142
  ignoreDefaultRules: boolean;
1007
1143
  };
1144
+ callbacks: {
1145
+ externalValidation?: import("@@/Types/config").ExternalValidationHandler | undefined;
1146
+ };
1008
1147
  } | null;
1009
1148
  } & import("pinia").PiniaCustomStateProperties<ConfigStoreState>) => string;
1010
1149
  /**
@@ -1037,6 +1176,7 @@ export declare const useConfigStore: import("pinia").StoreDefinition<"guido-conf
1037
1176
  } | undefined;
1038
1177
  }[];
1039
1178
  selectedUnsubscribePages: number[];
1179
+ forceRecreate: boolean;
1040
1180
  };
1041
1181
  editor: {
1042
1182
  locale: string;
@@ -1096,6 +1236,9 @@ export declare const useConfigStore: import("pinia").StoreDefinition<"guido-conf
1096
1236
  })[];
1097
1237
  ignoreDefaultRules: boolean;
1098
1238
  };
1239
+ callbacks: {
1240
+ externalValidation?: import("@@/Types/config").ExternalValidationHandler | undefined;
1241
+ };
1099
1242
  } | null;
1100
1243
  } & import("pinia").PiniaCustomStateProperties<ConfigStoreState>) => string;
1101
1244
  /**
@@ -1128,6 +1271,7 @@ export declare const useConfigStore: import("pinia").StoreDefinition<"guido-conf
1128
1271
  } | undefined;
1129
1272
  }[];
1130
1273
  selectedUnsubscribePages: number[];
1274
+ forceRecreate: boolean;
1131
1275
  };
1132
1276
  editor: {
1133
1277
  locale: string;
@@ -1187,6 +1331,9 @@ export declare const useConfigStore: import("pinia").StoreDefinition<"guido-conf
1187
1331
  })[];
1188
1332
  ignoreDefaultRules: boolean;
1189
1333
  };
1334
+ callbacks: {
1335
+ externalValidation?: import("@@/Types/config").ExternalValidationHandler | undefined;
1336
+ };
1190
1337
  } | null;
1191
1338
  } & import("pinia").PiniaCustomStateProperties<ConfigStoreState>) => number;
1192
1339
  /**
@@ -1219,6 +1366,7 @@ export declare const useConfigStore: import("pinia").StoreDefinition<"guido-conf
1219
1366
  } | undefined;
1220
1367
  }[];
1221
1368
  selectedUnsubscribePages: number[];
1369
+ forceRecreate: boolean;
1222
1370
  };
1223
1371
  editor: {
1224
1372
  locale: string;
@@ -1278,6 +1426,9 @@ export declare const useConfigStore: import("pinia").StoreDefinition<"guido-conf
1278
1426
  })[];
1279
1427
  ignoreDefaultRules: boolean;
1280
1428
  };
1429
+ callbacks: {
1430
+ externalValidation?: import("@@/Types/config").ExternalValidationHandler | undefined;
1431
+ };
1281
1432
  } | null;
1282
1433
  } & import("pinia").PiniaCustomStateProperties<ConfigStoreState>) => number;
1283
1434
  /**
@@ -1310,6 +1461,7 @@ export declare const useConfigStore: import("pinia").StoreDefinition<"guido-conf
1310
1461
  } | undefined;
1311
1462
  }[];
1312
1463
  selectedUnsubscribePages: number[];
1464
+ forceRecreate: boolean;
1313
1465
  };
1314
1466
  editor: {
1315
1467
  locale: string;
@@ -1369,6 +1521,9 @@ export declare const useConfigStore: import("pinia").StoreDefinition<"guido-conf
1369
1521
  })[];
1370
1522
  ignoreDefaultRules: boolean;
1371
1523
  };
1524
+ callbacks: {
1525
+ externalValidation?: import("@@/Types/config").ExternalValidationHandler | undefined;
1526
+ };
1372
1527
  } | null;
1373
1528
  } & import("pinia").PiniaCustomStateProperties<ConfigStoreState>) => string;
1374
1529
  /**
@@ -1401,6 +1556,7 @@ export declare const useConfigStore: import("pinia").StoreDefinition<"guido-conf
1401
1556
  } | undefined;
1402
1557
  }[];
1403
1558
  selectedUnsubscribePages: number[];
1559
+ forceRecreate: boolean;
1404
1560
  };
1405
1561
  editor: {
1406
1562
  locale: string;
@@ -1460,6 +1616,9 @@ export declare const useConfigStore: import("pinia").StoreDefinition<"guido-conf
1460
1616
  })[];
1461
1617
  ignoreDefaultRules: boolean;
1462
1618
  };
1619
+ callbacks: {
1620
+ externalValidation?: import("@@/Types/config").ExternalValidationHandler | undefined;
1621
+ };
1463
1622
  } | null;
1464
1623
  } & import("pinia").PiniaCustomStateProperties<ConfigStoreState>) => boolean;
1465
1624
  /**
@@ -1492,6 +1651,7 @@ export declare const useConfigStore: import("pinia").StoreDefinition<"guido-conf
1492
1651
  } | undefined;
1493
1652
  }[];
1494
1653
  selectedUnsubscribePages: number[];
1654
+ forceRecreate: boolean;
1495
1655
  };
1496
1656
  editor: {
1497
1657
  locale: string;
@@ -1551,6 +1711,9 @@ export declare const useConfigStore: import("pinia").StoreDefinition<"guido-conf
1551
1711
  })[];
1552
1712
  ignoreDefaultRules: boolean;
1553
1713
  };
1714
+ callbacks: {
1715
+ externalValidation?: import("@@/Types/config").ExternalValidationHandler | undefined;
1716
+ };
1554
1717
  } | null;
1555
1718
  } & import("pinia").PiniaCustomStateProperties<ConfigStoreState>) => (feature: keyof FeaturesConfig) => boolean;
1556
1719
  }, {
@@ -9,6 +9,27 @@ export declare const useEditorStore: import("pinia").StoreDefinition<"guidoEdito
9
9
  isStripoInitialized: boolean;
10
10
  templateId: string;
11
11
  }, {
12
+ isEditorToolbarVisible: (state: {
13
+ loadingStatus: boolean;
14
+ isCodeEditorOpen: boolean;
15
+ isSaveAsTemplateDrawerOpen: boolean;
16
+ isVersionHistoryOpen: boolean;
17
+ isPreviewModeOpen: boolean;
18
+ editorVisualMode: string;
19
+ hasChanges: boolean;
20
+ isStripoInitialized: boolean;
21
+ templateId: string;
22
+ } & import("pinia").PiniaCustomStateProperties<{
23
+ loadingStatus: boolean;
24
+ isCodeEditorOpen: boolean;
25
+ isSaveAsTemplateDrawerOpen: boolean;
26
+ isVersionHistoryOpen: boolean;
27
+ isPreviewModeOpen: boolean;
28
+ editorVisualMode: string;
29
+ hasChanges: boolean;
30
+ isStripoInitialized: boolean;
31
+ templateId: string;
32
+ }>) => boolean;
12
33
  isUndoButtonDisabled: (state: {
13
34
  loadingStatus: boolean;
14
35
  isCodeEditorOpen: boolean;
@@ -0,0 +1,4 @@
1
+ const e = "data:image/svg+xml,%3csvg%20width='2'%20height='79'%20viewBox='0%200%202%2079'%20fill='none'%20xmlns='http://www.w3.org/2000/svg'%3e%3cg%20filter='url(%23filter0_d_14_463)'%3e%3crect%20y='42'%20width='2'%20height='36'%20fill='white'/%3e%3c/g%3e%3cg%20clip-path='url(%23clip0_14_463)'%3e%3crect%20y='46'%20width='2'%20height='28'%20fill='%23F0F3F4'/%3e%3c/g%3e%3cg%20clip-path='url(%23clip1_14_463)'%3e%3cpath%20d='M0%200H2V42H0V0Z'%20fill='%23DFE1E5'/%3e%3c/g%3e%3cdefs%3e%3cfilter%20id='filter0_d_14_463'%20x='0'%20y='42'%20width='2'%20height='37'%20filterUnits='userSpaceOnUse'%20color-interpolation-filters='sRGB'%3e%3cfeFlood%20flood-opacity='0'%20result='BackgroundImageFix'/%3e%3cfeColorMatrix%20in='SourceAlpha'%20type='matrix'%20values='0%200%200%200%200%200%200%200%200%200%200%200%200%200%200%200%200%200%20127%200'%20result='hardAlpha'/%3e%3cfeOffset%20dy='1'/%3e%3cfeColorMatrix%20type='matrix'%20values='0%200%200%200%200.858824%200%200%200%200%200.862745%200%200%200%200%200.866667%200%200%200%201%200'/%3e%3cfeBlend%20mode='normal'%20in2='BackgroundImageFix'%20result='effect1_dropShadow_14_463'/%3e%3cfeBlend%20mode='normal'%20in='SourceGraphic'%20in2='effect1_dropShadow_14_463'%20result='shape'/%3e%3c/filter%3e%3cclipPath%20id='clip0_14_463'%3e%3crect%20width='2'%20height='28'%20fill='white'%20transform='translate(0%2046)'/%3e%3c/clipPath%3e%3cclipPath%20id='clip1_14_463'%3e%3crect%20width='2'%20height='42'%20fill='white'/%3e%3c/clipPath%3e%3c/defs%3e%3c/svg%3e";
2
+ export {
3
+ e as default
4
+ };