@useinsider/guido 2.0.0-beta.faa7c5d → 2.0.0-beta.fb0f99d

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 (223) hide show
  1. package/dist/components/organisms/email-preview/amp/AmpToggle.vue.js +2 -2
  2. package/dist/components/organisms/email-preview/desktop-preview/DesktopPreview.vue.js +2 -2
  3. package/dist/components/organisms/email-preview/mobile-preview/ContentView.vue.js +5 -5
  4. package/dist/components/organisms/header/LeftSlot.vue.js +12 -12
  5. package/dist/components/organisms/header/LeftSlot.vue2.js +6 -6
  6. package/dist/config/migrator/index.js +8 -9
  7. package/dist/config/migrator/recommendationMigrator.js +2 -2
  8. package/dist/extensions/Blocks/Items/block.js +40 -39
  9. package/dist/extensions/Blocks/Items/controls/button/link.js +29 -22
  10. package/dist/extensions/Blocks/Items/controls/cardComposition.js +59 -70
  11. package/dist/extensions/Blocks/Items/controls/image/link.js +30 -23
  12. package/dist/extensions/Blocks/Items/controls/name/trimming.js +25 -25
  13. package/dist/extensions/Blocks/Items/controls/price/currencyLocation.js +17 -19
  14. package/dist/extensions/Blocks/Items/controls/price/currencySymbol.js +29 -31
  15. package/dist/extensions/Blocks/Items/controls/price/formattedPrice.js +36 -36
  16. package/dist/extensions/Blocks/Items/controls/price/hideDiscount.js +19 -21
  17. package/dist/extensions/Blocks/Items/controls/price/priceOrientation.js +27 -29
  18. package/dist/extensions/Blocks/Items/controls/settingsControl.js +143 -152
  19. package/dist/extensions/Blocks/Items/enums/controlEnums.js +2 -2
  20. package/dist/extensions/Blocks/Items/enums/productEnums.js +45 -43
  21. package/dist/extensions/Blocks/Items/enums/settingsEnums.js +3 -4
  22. package/dist/extensions/Blocks/Items/extension.js +6 -7
  23. package/dist/extensions/Blocks/Items/layouts/horizontal.html.js +49 -58
  24. package/dist/extensions/Blocks/Items/layouts/vertical.html.js +59 -48
  25. package/dist/extensions/Blocks/Items/settingsPanel.js +26 -27
  26. package/dist/extensions/Blocks/Items/store/items-block.js +7 -11
  27. package/dist/extensions/Blocks/Items/template.js +129 -366
  28. package/dist/extensions/Blocks/Items/utils/configBlockUtils.js +17 -0
  29. package/dist/extensions/Blocks/Items/utils/syncAttributeFromConfigBlock.js +28 -0
  30. package/dist/extensions/Blocks/Items/utils/syncAttributesFromConfigBlock.js +76 -0
  31. package/dist/extensions/Blocks/Items/utils/updateAttributes.js +46 -0
  32. package/dist/extensions/Blocks/Recommendation/block.js +1 -1
  33. package/dist/extensions/Blocks/Recommendation/constants/blockIds.js +4 -0
  34. package/dist/extensions/Blocks/Recommendation/constants/controlIds.js +4 -0
  35. package/dist/extensions/Blocks/Recommendation/constants/layout.js +12 -0
  36. package/dist/extensions/Blocks/Recommendation/constants/selectors.js +11 -0
  37. package/dist/extensions/Blocks/Recommendation/controls/button/index.js +64 -0
  38. package/dist/extensions/Blocks/Recommendation/controls/cardBackground/index.js +80 -0
  39. package/dist/extensions/Blocks/Recommendation/controls/cardComposition/index.js +232 -0
  40. package/dist/extensions/Blocks/Recommendation/controls/image/index.js +19 -0
  41. package/dist/extensions/Blocks/Recommendation/controls/layout/index.js +104 -0
  42. package/dist/extensions/Blocks/Recommendation/controls/main/algorithm.js +86 -0
  43. package/dist/extensions/Blocks/Recommendation/controls/main/currency.js +134 -0
  44. package/dist/extensions/Blocks/Recommendation/controls/main/filters.js +54 -0
  45. package/dist/extensions/Blocks/Recommendation/controls/main/index.js +134 -0
  46. package/dist/extensions/Blocks/Recommendation/controls/main/locale.js +64 -0
  47. package/dist/extensions/Blocks/Recommendation/controls/main/productLayout.js +124 -0
  48. package/dist/extensions/Blocks/Recommendation/controls/main/shuffle.js +60 -0
  49. package/dist/extensions/Blocks/Recommendation/controls/main/utils.js +114 -0
  50. package/dist/extensions/Blocks/Recommendation/controls/name/index.js +46 -0
  51. package/dist/extensions/Blocks/Recommendation/controls/name/textTrim.js +76 -0
  52. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/index.js +44 -0
  53. package/dist/extensions/Blocks/Recommendation/controls/omnibusDiscount/index.js +48 -0
  54. package/dist/extensions/Blocks/Recommendation/controls/omnibusDiscount/textAfter.js +73 -0
  55. package/dist/extensions/Blocks/Recommendation/controls/omnibusDiscount/textBefore.js +73 -0
  56. package/dist/extensions/Blocks/Recommendation/controls/omnibusPrice/index.js +48 -0
  57. package/dist/extensions/Blocks/Recommendation/controls/omnibusPrice/textAfter.js +73 -0
  58. package/dist/extensions/Blocks/Recommendation/controls/omnibusPrice/textBefore.js +73 -0
  59. package/dist/extensions/Blocks/Recommendation/controls/price/index.js +44 -0
  60. package/dist/extensions/Blocks/Recommendation/controls/spacing/index.js +204 -0
  61. package/dist/extensions/Blocks/Recommendation/extension.js +40 -43
  62. package/dist/extensions/Blocks/Recommendation/recommendation.css.js +5 -0
  63. package/dist/extensions/Blocks/Recommendation/settingsPanel.js +128 -72
  64. package/dist/extensions/Blocks/Recommendation/store/recommendation.js +29 -26
  65. package/dist/extensions/Blocks/Recommendation/templates/horizontal/elementRenderer.js +157 -0
  66. package/dist/extensions/Blocks/Recommendation/templates/horizontal/template.js +72 -0
  67. package/dist/extensions/Blocks/Recommendation/templates/index.js +12 -0
  68. package/dist/extensions/Blocks/Recommendation/templates/utils.js +173 -0
  69. package/dist/extensions/Blocks/Recommendation/templates/vertical/elementRenderer.js +186 -0
  70. package/dist/extensions/Blocks/Recommendation/templates/vertical/migration.js +251 -0
  71. package/dist/extensions/Blocks/Recommendation/templates/vertical/template.js +62 -0
  72. package/dist/extensions/Blocks/Recommendation/utils/filterUtil.js +9 -9
  73. package/dist/extensions/Blocks/Recommendation/utils/preserveTextStyles.js +36 -0
  74. package/dist/extensions/Blocks/Recommendation/utils/tagName.js +46 -0
  75. package/dist/extensions/Blocks/common-control.js +28 -28
  76. package/dist/extensions/Blocks/controlFactories.js +130 -106
  77. package/dist/guido.css +1 -1
  78. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/esm/index.js +116 -125
  79. package/dist/src/extensions/Blocks/Items/controls/button/link.d.ts +2 -0
  80. package/dist/src/extensions/Blocks/Items/controls/cardComposition.d.ts +0 -9
  81. package/dist/src/extensions/Blocks/Items/controls/image/link.d.ts +2 -0
  82. package/dist/src/extensions/Blocks/Items/controls/price/priceOrientation.d.ts +1 -1
  83. package/dist/src/extensions/Blocks/Items/controls/settingsControl.d.ts +4 -0
  84. package/dist/src/extensions/Blocks/Items/enums/controlEnums.d.ts +0 -1
  85. package/dist/src/extensions/Blocks/Items/enums/productEnums.d.ts +26 -24
  86. package/dist/src/extensions/Blocks/Items/enums/settingsEnums.d.ts +0 -1
  87. package/dist/src/extensions/Blocks/Items/store/items-block.d.ts +0 -2
  88. package/dist/src/extensions/Blocks/Items/template.d.ts +1 -22
  89. package/dist/src/extensions/Blocks/Items/utils/configBlockUtils.d.ts +23 -0
  90. package/dist/src/extensions/Blocks/Items/utils/syncAttributeFromConfigBlock.d.ts +32 -0
  91. package/dist/src/extensions/Blocks/Items/utils/syncAttributesFromConfigBlock.d.ts +50 -0
  92. package/dist/src/extensions/Blocks/Items/utils/updateAttributes.d.ts +8 -0
  93. package/dist/src/extensions/Blocks/Recommendation/constants/blockIds.d.ts +13 -0
  94. package/dist/src/extensions/Blocks/Recommendation/{constants.d.ts → constants/controlIds.d.ts} +19 -11
  95. package/dist/src/extensions/Blocks/Recommendation/constants/index.d.ts +12 -0
  96. package/dist/src/extensions/Blocks/Recommendation/constants/layout.d.ts +27 -0
  97. package/dist/src/extensions/Blocks/Recommendation/constants/selectors.d.ts +19 -0
  98. package/dist/src/extensions/Blocks/Recommendation/controls/button/index.d.ts +143 -0
  99. package/dist/src/extensions/Blocks/Recommendation/controls/cardBackground/index.d.ts +31 -0
  100. package/dist/src/extensions/Blocks/Recommendation/controls/cardComposition/index.d.ts +95 -0
  101. package/dist/src/extensions/Blocks/Recommendation/controls/image/index.d.ts +35 -0
  102. package/dist/src/extensions/Blocks/Recommendation/controls/index.d.ts +24 -0
  103. package/dist/src/extensions/Blocks/Recommendation/controls/layout/index.d.ts +34 -0
  104. package/dist/src/extensions/Blocks/Recommendation/controls/main/algorithm.d.ts +17 -0
  105. package/dist/src/extensions/Blocks/Recommendation/controls/main/currency.d.ts +16 -0
  106. package/dist/src/extensions/Blocks/Recommendation/controls/main/filters.d.ts +22 -0
  107. package/dist/src/extensions/Blocks/Recommendation/controls/main/index.d.ts +43 -0
  108. package/dist/src/extensions/Blocks/Recommendation/controls/main/locale.d.ts +15 -0
  109. package/dist/src/extensions/Blocks/Recommendation/controls/main/productLayout.d.ts +40 -0
  110. package/dist/src/extensions/Blocks/Recommendation/controls/main/shuffle.d.ts +15 -0
  111. package/dist/src/extensions/Blocks/Recommendation/controls/main/utils.d.ts +81 -0
  112. package/dist/src/extensions/Blocks/Recommendation/controls/name/index.d.ts +97 -0
  113. package/dist/src/extensions/Blocks/Recommendation/controls/name/textTrim.d.ts +16 -0
  114. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/index.d.ts +95 -0
  115. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusDiscount/index.d.ts +100 -0
  116. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusDiscount/textAfter.d.ts +15 -0
  117. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusDiscount/textBefore.d.ts +15 -0
  118. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusPrice/index.d.ts +100 -0
  119. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusPrice/textAfter.d.ts +15 -0
  120. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusPrice/textBefore.d.ts +15 -0
  121. package/dist/src/extensions/Blocks/Recommendation/controls/price/index.d.ts +95 -0
  122. package/dist/src/extensions/Blocks/Recommendation/controls/spacing/index.d.ts +72 -0
  123. package/dist/src/extensions/Blocks/Recommendation/extension.d.ts +9 -0
  124. package/dist/src/extensions/Blocks/Recommendation/store/recommendation.d.ts +17 -16
  125. package/dist/src/extensions/Blocks/Recommendation/templates/horizontal/elementRenderer.d.ts +8 -0
  126. package/dist/src/extensions/Blocks/Recommendation/templates/horizontal/migration.d.ts +25 -0
  127. package/dist/src/extensions/Blocks/Recommendation/templates/horizontal/template.d.ts +18 -0
  128. package/dist/src/extensions/Blocks/Recommendation/templates/index.d.ts +39 -0
  129. package/dist/src/extensions/Blocks/Recommendation/templates/utils.d.ts +45 -0
  130. package/dist/src/extensions/Blocks/Recommendation/templates/vertical/elementRenderer.d.ts +7 -0
  131. package/dist/src/extensions/Blocks/Recommendation/templates/{migrationTemplate.d.ts → vertical/migration.d.ts} +11 -4
  132. package/dist/src/extensions/Blocks/Recommendation/templates/vertical/template.d.ts +33 -0
  133. package/dist/src/extensions/Blocks/Recommendation/utils/preserveTextStyles.d.ts +19 -0
  134. package/dist/src/extensions/Blocks/Recommendation/utils/tagName.d.ts +77 -0
  135. package/dist/src/extensions/Blocks/common-control.d.ts +11 -10
  136. package/dist/static/styles/components/wide-panel.css.js +0 -4
  137. package/dist/static/styles/customEditorStyle.css.js +38 -2
  138. package/dist/utils/pairProductVariables.js +58 -61
  139. package/package.json +1 -1
  140. package/dist/config/migrator/itemsBlockMigrator.js +0 -342
  141. package/dist/extensions/Blocks/Items/controls/price/singlePrice.js +0 -93
  142. package/dist/extensions/Blocks/Items/utils/nodeConfigUtils.js +0 -184
  143. package/dist/extensions/Blocks/Recommendation/cardCompositionControl.js +0 -103
  144. package/dist/extensions/Blocks/Recommendation/constants.js +0 -5
  145. package/dist/extensions/Blocks/Recommendation/control.js +0 -306
  146. package/dist/extensions/Blocks/Recommendation/controls/button/align.js +0 -13
  147. package/dist/extensions/Blocks/Recommendation/controls/button/border.js +0 -13
  148. package/dist/extensions/Blocks/Recommendation/controls/button/borderRadius.js +0 -13
  149. package/dist/extensions/Blocks/Recommendation/controls/button/color.js +0 -13
  150. package/dist/extensions/Blocks/Recommendation/controls/button/fitToContent.js +0 -13
  151. package/dist/extensions/Blocks/Recommendation/controls/button/fontFamily.js +0 -13
  152. package/dist/extensions/Blocks/Recommendation/controls/button/margins.js +0 -13
  153. package/dist/extensions/Blocks/Recommendation/controls/button/paddings.js +0 -13
  154. package/dist/extensions/Blocks/Recommendation/controls/button/text.js +0 -13
  155. package/dist/extensions/Blocks/Recommendation/controls/button/textSize.js +0 -13
  156. package/dist/extensions/Blocks/Recommendation/controls/button/textStyleAndFontColor.js +0 -13
  157. package/dist/extensions/Blocks/Recommendation/controls/image/margins.js +0 -13
  158. package/dist/extensions/Blocks/Recommendation/controls/image/size.js +0 -13
  159. package/dist/extensions/Blocks/Recommendation/controls/name/align.js +0 -13
  160. package/dist/extensions/Blocks/Recommendation/controls/name/background.js +0 -13
  161. package/dist/extensions/Blocks/Recommendation/controls/name/color.js +0 -13
  162. package/dist/extensions/Blocks/Recommendation/controls/name/fontFamily.js +0 -13
  163. package/dist/extensions/Blocks/Recommendation/controls/name/paddings.js +0 -13
  164. package/dist/extensions/Blocks/Recommendation/controls/name/size.js +0 -13
  165. package/dist/extensions/Blocks/Recommendation/controls/name/style.js +0 -13
  166. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/align.js +0 -13
  167. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/background.js +0 -13
  168. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/color.js +0 -13
  169. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/fontFamily.js +0 -13
  170. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/paddings.js +0 -13
  171. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/size.js +0 -13
  172. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/style.js +0 -13
  173. package/dist/extensions/Blocks/Recommendation/controls/price/align.js +0 -13
  174. package/dist/extensions/Blocks/Recommendation/controls/price/background.js +0 -13
  175. package/dist/extensions/Blocks/Recommendation/controls/price/color.js +0 -13
  176. package/dist/extensions/Blocks/Recommendation/controls/price/fontFamily.js +0 -13
  177. package/dist/extensions/Blocks/Recommendation/controls/price/paddings.js +0 -13
  178. package/dist/extensions/Blocks/Recommendation/controls/price/size.js +0 -13
  179. package/dist/extensions/Blocks/Recommendation/controls/price/style.js +0 -13
  180. package/dist/extensions/Blocks/Recommendation/templates/blockTemplate.js +0 -160
  181. package/dist/extensions/Blocks/Recommendation/templates/migrationTemplate.js +0 -152
  182. package/dist/extensions/Blocks/Recommendation/templates/templateUtils.js +0 -180
  183. package/dist/src/config/migrator/itemsBlockMigrator.d.ts +0 -6
  184. package/dist/src/extensions/Blocks/Items/controls/price/singlePrice.d.ts +0 -18
  185. package/dist/src/extensions/Blocks/Items/utils/nodeConfigUtils.d.ts +0 -73
  186. package/dist/src/extensions/Blocks/Recommendation/cardCompositionControl.d.ts +0 -28
  187. package/dist/src/extensions/Blocks/Recommendation/control.d.ts +0 -35
  188. package/dist/src/extensions/Blocks/Recommendation/controls/button/align.d.ts +0 -5
  189. package/dist/src/extensions/Blocks/Recommendation/controls/button/border.d.ts +0 -5
  190. package/dist/src/extensions/Blocks/Recommendation/controls/button/borderRadius.d.ts +0 -5
  191. package/dist/src/extensions/Blocks/Recommendation/controls/button/color.d.ts +0 -5
  192. package/dist/src/extensions/Blocks/Recommendation/controls/button/fitToContent.d.ts +0 -5
  193. package/dist/src/extensions/Blocks/Recommendation/controls/button/fontFamily.d.ts +0 -5
  194. package/dist/src/extensions/Blocks/Recommendation/controls/button/margins.d.ts +0 -5
  195. package/dist/src/extensions/Blocks/Recommendation/controls/button/paddings.d.ts +0 -5
  196. package/dist/src/extensions/Blocks/Recommendation/controls/button/text.d.ts +0 -5
  197. package/dist/src/extensions/Blocks/Recommendation/controls/button/textSize.d.ts +0 -5
  198. package/dist/src/extensions/Blocks/Recommendation/controls/button/textStyleAndFontColor.d.ts +0 -5
  199. package/dist/src/extensions/Blocks/Recommendation/controls/image/margins.d.ts +0 -5
  200. package/dist/src/extensions/Blocks/Recommendation/controls/image/size.d.ts +0 -5
  201. package/dist/src/extensions/Blocks/Recommendation/controls/name/align.d.ts +0 -5
  202. package/dist/src/extensions/Blocks/Recommendation/controls/name/background.d.ts +0 -5
  203. package/dist/src/extensions/Blocks/Recommendation/controls/name/color.d.ts +0 -5
  204. package/dist/src/extensions/Blocks/Recommendation/controls/name/fontFamily.d.ts +0 -5
  205. package/dist/src/extensions/Blocks/Recommendation/controls/name/paddings.d.ts +0 -5
  206. package/dist/src/extensions/Blocks/Recommendation/controls/name/size.d.ts +0 -5
  207. package/dist/src/extensions/Blocks/Recommendation/controls/name/style.d.ts +0 -5
  208. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/align.d.ts +0 -5
  209. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/background.d.ts +0 -5
  210. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/color.d.ts +0 -5
  211. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/fontFamily.d.ts +0 -5
  212. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/paddings.d.ts +0 -5
  213. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/size.d.ts +0 -5
  214. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/style.d.ts +0 -5
  215. package/dist/src/extensions/Blocks/Recommendation/controls/price/align.d.ts +0 -5
  216. package/dist/src/extensions/Blocks/Recommendation/controls/price/background.d.ts +0 -5
  217. package/dist/src/extensions/Blocks/Recommendation/controls/price/color.d.ts +0 -5
  218. package/dist/src/extensions/Blocks/Recommendation/controls/price/fontFamily.d.ts +0 -5
  219. package/dist/src/extensions/Blocks/Recommendation/controls/price/paddings.d.ts +0 -5
  220. package/dist/src/extensions/Blocks/Recommendation/controls/price/size.d.ts +0 -5
  221. package/dist/src/extensions/Blocks/Recommendation/controls/price/style.d.ts +0 -5
  222. package/dist/src/extensions/Blocks/Recommendation/templates/blockTemplate.d.ts +0 -16
  223. package/dist/src/extensions/Blocks/Recommendation/templates/templateUtils.d.ts +0 -44
@@ -0,0 +1,8 @@
1
+ import type { ElementRenderer } from '../utils';
2
+ /**
3
+ * Horizontal element renderer
4
+ * - Image and Button return `<td>` cells for the 3-column layout
5
+ * - Name and Prices return `<tr><td>` rows for the info cell table
6
+ * All elements have esd-block-* classes for Stripo selection
7
+ */
8
+ export declare const horizontalElementRenderer: ElementRenderer;
@@ -0,0 +1,25 @@
1
+ import type { RecommendationProduct } from '@@/Types/recommendation';
2
+ import { DEFAULTS, getDefaultProducts } from '../utils';
3
+ /**
4
+ * Migration template for horizontal layout
5
+ * Used when migrating old recommendation blocks to horizontal format
6
+ */
7
+ declare const migrationTemplate = "\n <td\n align=\"left\"\n esd-extension-block-id=\"recommendation-block\"\n esd-handler-name=\"esd-extension-RecommendationBlock\"\n class=\"ins-recommendation-v3-block-v2 esd-block-recommendation-v3-block esd-extension-block es-p20\"\n data-layout=\"horizontal\"\n >\n <table width=\"100%\" cellpadding=\"0\" cellspacing=\"0\" border=\"0\">\n <tr>\n <td align=\"center\">\n <table\n class=\"container\"\n width=\"100%\"\n cellpadding=\"0\"\n cellspacing=\"0\"\n border=\"0\">\n <tbody>\n <tr>\n <td>\n <table\n width=\"100%\"\n cellpadding=\"0\"\n cellspacing=\"0\"\n border=\"0\">\n <tbody>\n <tr>\n {-{-TITLE-}-}\n </tr>\n </tbody>\n </table>\n </td>\n </tr>\n <tr>\n <td class=\"spacer\" style=\"height: 20px;\"></td>\n </tr>\n <tr>\n <td>\n <table\n class=\"ins-recommendation-product-container\"\n width=\"100%\"\n cellpadding=\"0\"\n cellspacing=\"0\"\n border=\"0\"\n >\n {-{-PRODUCT_ROWS-}-}\n </table>\n </td>\n </tr>\n </tbody>\n </table>\n </td>\n </tr>\n </table>\n </td>\n";
8
+ export declare function getMigrationTemplate(): string;
9
+ /**
10
+ * Generates a custom horizontal migration template with specified products
11
+ * @param products - Array of products to display
12
+ * @param title - Optional title for the block
13
+ * @param composition - Optional array defining order of card elements
14
+ * @returns Complete HTML template
15
+ */
16
+ export declare function generateMigrationTemplate(products: RecommendationProduct[], title?: string, composition?: string[]): string;
17
+ /**
18
+ * Prepares horizontal product rows for migration
19
+ * @param products - Array of products to display
20
+ * @param composition - Optional array defining order of card elements
21
+ * @returns HTML string for product rows
22
+ */
23
+ export declare function prepareProductRows(products: RecommendationProduct[], composition?: string[]): string;
24
+ export { DEFAULTS, getDefaultProducts };
25
+ export default migrationTemplate;
@@ -0,0 +1,18 @@
1
+ import type { RecommendationProduct } from '@@/Types/recommendation';
2
+ /**
3
+ * Generates a horizontal product card with 3-column layout
4
+ * Uses horizontalElementRenderer to render Image, Info content, and Button
5
+ * Layout: [Image (120px)] [Info table (flexible)] [Button (100px)]
6
+ * @param product - The product data
7
+ * @returns HTML string for a single product card row
8
+ */
9
+ export declare function getHorizontalProductCard(product: RecommendationProduct): string;
10
+ /**
11
+ * Prepares horizontal product rows
12
+ * Each product is a full-width row with 3-column layout
13
+ * @param products - Array of products to display
14
+ * @returns HTML string for product rows
15
+ */
16
+ export declare function prepareProductRows(products: RecommendationProduct[]): string;
17
+ export declare function getDefaultTemplate(): string;
18
+ export declare function generateBlockTemplate(products: RecommendationProduct[], title?: string): string;
@@ -0,0 +1,39 @@
1
+ /**
2
+ * Unified Template API for Recommendation Block
3
+ *
4
+ * This module provides a single entry point for working with recommendation
5
+ * block templates, abstracting away the layout-specific implementations.
6
+ */
7
+ import type { RecommendationProduct } from '@@/Types/recommendation';
8
+ import { type Orientation, type PrepareProductRowsOptions } from './utils';
9
+ export { DEFAULTS, DEFAULT_CARD_COMPOSITION, DEFAULT_CARD_VISIBILITY, getDefaultProducts, spacer, createBlockTemplate, type Orientation, type PrepareProductRowsOptions, type ElementRenderer, type ProductCardGetter, } from './utils';
10
+ /**
11
+ * Unified function to prepare product rows for any layout.
12
+ * Delegates to the appropriate layout-specific implementation.
13
+ * @example
14
+ * // Horizontal layout (full-width rows)
15
+ * prepareProductRows(products, 'horizontal');
16
+ * @example
17
+ * // Vertical layout (grid)
18
+ * prepareProductRows(products, 'vertical', { productsPerRow: 3 });
19
+ * @param products - Array of products to display
20
+ * @param layout - The layout orientation ('horizontal' or 'vertical')
21
+ * @param options - Layout-specific options
22
+ * @returns HTML string for product rows
23
+ */
24
+ export declare function prepareProductRows(products: RecommendationProduct[], layout: Orientation, options?: PrepareProductRowsOptions): string;
25
+ /**
26
+ * Generates the default template for a given layout.
27
+ * @param layout - The layout orientation ('horizontal' or 'vertical')
28
+ * @returns Complete HTML template with default products
29
+ */
30
+ export declare function getDefaultTemplate(layout?: Orientation): string;
31
+ /**
32
+ * Generates a complete block template with custom products.
33
+ * @param products - Array of products to display
34
+ * @param layout - The layout orientation ('horizontal' or 'vertical')
35
+ * @param title - Title for the block
36
+ * @param options - Layout-specific options
37
+ * @returns Complete HTML template
38
+ */
39
+ export declare function generateBlockTemplate(products: RecommendationProduct[], layout: Orientation, title?: string, options?: PrepareProductRowsOptions): string;
@@ -0,0 +1,45 @@
1
+ import type { RecommendationProduct } from '@@/Types/recommendation';
2
+ import { ATTR_PRODUCT_IMAGE, ATTR_PRODUCT_NAME, ATTR_PRODUCT_PRICE, ATTR_PRODUCT_OLD_PRICE, ATTR_PRODUCT_OMNIBUS_PRICE, ATTR_PRODUCT_OMNIBUS_DISCOUNT, ATTR_PRODUCT_BUTTON } from '../constants';
3
+ export type Orientation = 'horizontal' | 'vertical';
4
+ /**
5
+ * Options for prepareProductRows unified function
6
+ */
7
+ export interface PrepareProductRowsOptions {
8
+ /** Number of products per row (only for vertical layout, defaults to 3) */
9
+ productsPerRow?: number;
10
+ /** Array defining order of card elements */
11
+ composition?: string[];
12
+ }
13
+ /**
14
+ * Element renderer interface for product card elements
15
+ * Keys are ATTR_PRODUCT_* constants for consistent naming
16
+ */
17
+ export interface ElementRenderer {
18
+ [ATTR_PRODUCT_IMAGE]: (product: RecommendationProduct) => string;
19
+ [ATTR_PRODUCT_NAME]: (product: RecommendationProduct) => string;
20
+ [ATTR_PRODUCT_PRICE]: (product: RecommendationProduct) => string;
21
+ [ATTR_PRODUCT_OLD_PRICE]: (product: RecommendationProduct) => string;
22
+ [ATTR_PRODUCT_OMNIBUS_PRICE]: (product: RecommendationProduct) => string;
23
+ [ATTR_PRODUCT_OMNIBUS_DISCOUNT]: (product: RecommendationProduct) => string;
24
+ [ATTR_PRODUCT_BUTTON]: (product: RecommendationProduct) => string;
25
+ }
26
+ /**
27
+ * Product card getter function type
28
+ * Used by prepareProductRows to generate individual product cards
29
+ */
30
+ export type ProductCardGetter = (product: RecommendationProduct, composition?: string[]) => string;
31
+ export declare const DEFAULTS: {
32
+ TITLE: string;
33
+ DESCRIPTION: string;
34
+ };
35
+ export declare const DEFAULT_CARD_COMPOSITION: string[];
36
+ export declare const DEFAULT_CARD_VISIBILITY: Record<string, boolean>;
37
+ export declare const spacer = "\n <tr>\n <td class=\"spacer\" style=\"height: 10px;\"></td>\n </tr>\n";
38
+ export declare function getDefaultProducts(): RecommendationProduct[];
39
+ /**
40
+ * Creates the block template wrapper HTML for recommendation blocks.
41
+ * The template includes title placeholder and product container.
42
+ * @param layout - The layout orientation ('horizontal' or 'vertical')
43
+ * @returns HTML template string with {-{-TITLE-}-} and {-{-PRODUCT_ROWS-}-} placeholders
44
+ */
45
+ export declare function createBlockTemplate(layout?: Orientation): string;
@@ -0,0 +1,7 @@
1
+ import type { ElementRenderer } from '../utils';
2
+ /**
3
+ * Class name for outer cells in attribute rows
4
+ * Used by controls to reliably select direct children for spacing adjustments
5
+ */
6
+ export declare const ATTRIBUTE_CELL_CLASS = "attribute-cell";
7
+ export declare const verticalElementRenderer: ElementRenderer;
@@ -1,9 +1,17 @@
1
1
  import type { RecommendationProduct } from '@@/Types/recommendation';
2
- import { DEFAULTS, getDefaultProducts } from './templateUtils';
2
+ import { DEFAULTS, getDefaultProducts, DEFAULT_CARD_COMPOSITION, DEFAULT_CARD_VISIBILITY } from '../utils';
3
3
  declare const migrationTemplate = "\n <td\n align=\"left\"\n esd-extension-block-id=\"recommendation-block\"\n esd-handler-name=\"esd-extension-RecommendationBlock\"\n class=\"ins-recommendation-v3-block-v2 esd-block-recommendation-v3-block esd-extension-block es-p20\"\n >\n <table width=\"100%\" cellpadding=\"0\" cellspacing=\"0\" border=\"0\">\n <tr>\n <td align=\"center\">\n <table\n class=\"container\"\n width=\"100%\"\n cellpadding=\"0\"\n cellspacing=\"0\"\n border=\"0\">\n <tbody>\n <tr>\n <td>\n <table\n width=\"100%\"\n cellpadding=\"0\"\n cellspacing=\"0\"\n border=\"0\">\n <tbody>\n <tr>\n {-{-TITLE-}-}\n </tr>\n </tbody>\n </table>\n </td>\n </tr>\n <tr>\n <td class=\"spacer\" style=\"height: 20px;\"></td>\n </tr>\n <tr>\n <td>\n <table\n class=\"ins-recommendation-product-container\"\n width=\"100%\"\n cellpadding=\"0\"\n cellspacing=\"0\"\n border=\"0\"\n >\n {-{-PRODUCT_ROWS-}-}\n </table>\n </td>\n </tr>\n </tbody>\n </table>\n </td>\n </tr>\n </table>\n </td>\n";
4
+ /**
5
+ * Prepares migration product rows with attribute-aligned structure.
6
+ * @param products - Array of products to display
7
+ * @param productsPerRow - Number of products per row
8
+ * @param composition - Array defining element order
9
+ * @returns HTML string for product rows
10
+ */
11
+ export declare function prepareProductRows(products: RecommendationProduct[], productsPerRow: number, composition?: string[]): string;
4
12
  export declare function getMigrationTemplate(): string;
5
13
  /**
6
- * Generates a custom migration template with specified products and layout
14
+ * Generates a custom migration template with specified products and layout.
7
15
  * @param products - Array of products to display
8
16
  * @param productsPerRow - Number of products per row
9
17
  * @param title - Optional title for the block
@@ -11,6 +19,5 @@ export declare function getMigrationTemplate(): string;
11
19
  * @returns Complete HTML template
12
20
  */
13
21
  export declare function generateMigrationTemplate(products: RecommendationProduct[], productsPerRow: number, title?: string, composition?: string[]): string;
14
- export declare function prepareProductRows(products: RecommendationProduct[], productsPerRow: number, composition?: string[]): string;
15
- export { DEFAULTS, getDefaultProducts };
22
+ export { DEFAULTS, DEFAULT_CARD_COMPOSITION, DEFAULT_CARD_VISIBILITY, getDefaultProducts, };
16
23
  export default migrationTemplate;
@@ -0,0 +1,33 @@
1
+ import type { RecommendationProduct } from '@@/Types/recommendation';
2
+ import { type ElementRenderer } from '../utils';
3
+ /**
4
+ * Generates attribute-aligned product rows for vertical layout.
5
+ * Creates rows where each row contains one attribute type from all products.
6
+ * @param products - Array of products in this row group
7
+ * @param productsPerRow - Number of products per row (for column width calculation)
8
+ * @param elementRenderer - Object mapping attribute types to render functions
9
+ * @param composition - Array defining order of card elements
10
+ * @returns HTML string for attribute-aligned rows
11
+ */
12
+ export declare function prepareVerticalAttributeRows(products: RecommendationProduct[], productsPerRow: number, elementRenderer: ElementRenderer, composition?: string[]): string;
13
+ /**
14
+ * Prepares vertical product rows with attribute-aligned structure
15
+ * Groups products into rows, then generates attribute-aligned HTML for each group
16
+ * @param products - Array of products to display
17
+ * @param productsPerRow - Number of products per row
18
+ * @param elementRenderer - Object mapping attribute types to render functions
19
+ * @param composition - Array defining order of card elements
20
+ * @returns HTML string for all product rows
21
+ */
22
+ export declare function prepareVerticalProductRows(products: RecommendationProduct[], productsPerRow: number, elementRenderer: ElementRenderer, composition?: string[]): string;
23
+ /**
24
+ * Prepares vertical product rows with attribute-aligned structure.
25
+ * Uses row-based rendering where each attribute type forms a single row across all products.
26
+ * @param products - Array of products to display
27
+ * @param productsPerRow - Number of products per row
28
+ * @param composition - Array defining element order
29
+ * @returns HTML string for product rows
30
+ */
31
+ export declare function prepareProductRows(products: RecommendationProduct[], productsPerRow: number, composition?: string[]): string;
32
+ export declare function getDefaultTemplate(): string;
33
+ export declare function generateBlockTemplate(products: RecommendationProduct[], productsPerRow: number, title?: string, composition?: string[]): string;
@@ -0,0 +1,19 @@
1
+ /**
2
+ * Utility for preserving text styling when updating innerHTML
3
+ */
4
+ import type { ImmutableHtmlNode } from '@stripoinc/ui-editor-extensions';
5
+ /**
6
+ * Preserves existing style tags when updating text content
7
+ *
8
+ * When users apply text styles (bold, italic, etc.) in Stripo, the editor wraps
9
+ * content in tags like <strong>, <em>, <u>, <s>. This function extracts those
10
+ * style tags from the original HTML and re-applies them to the new text content.
11
+ * @example
12
+ * // Original: <span class="omnibus-text-before"><strong>Lowest price: </strong></span>
13
+ * // After calling preserveTextStyles(element, 'Best price: ')
14
+ * // Result: <strong>Best price: </strong>
15
+ * @param element - The DOM element or ImmutableHtmlNode containing the styled text
16
+ * @param newText - The new text content to insert
17
+ * @returns The new text wrapped in the original style tags
18
+ */
19
+ export declare function preserveTextStyles(element: ImmutableHtmlNode | Element, newText: string): string;
@@ -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 {};
@@ -56,25 +56,26 @@ export declare abstract class CommonControl extends Control {
56
56
  onTemplateNodeUpdated(node: ImmutableHtmlNode): void;
57
57
  onDestroy(): void;
58
58
  /**
59
- * Gets the Items block container element from the current node.
60
- * @returns The container element or null if not found
59
+ * Gets the config block element from the current node.
60
+ * @returns The config block element or null if not found
61
61
  */
62
- protected getItemsBlockContainer(): ImmutableHtmlElementNode | null;
62
+ protected getConfigBlock(): ImmutableHtmlElementNode | null;
63
63
  /**
64
- * Gets the current block instance ID from the node config (Stripo V2).
64
+ * Gets the current block instance ID from the config block.
65
+ * @param blockInstanceIdAttribute - The attribute name for block instance ID (default: 'data-block-instance-id')
65
66
  * @returns The block instance ID or null if not found
66
67
  */
67
- protected getBlockInstanceId(): string | null;
68
+ protected getBlockInstanceId(blockInstanceIdAttribute?: string): string | null;
68
69
  /**
69
70
  * Handles block instance change detection and syncing.
70
- * This is a helper method for controls that need to sync config when switching between block instances.
71
- * Uses Stripo V2 nodeConfig API for block instance tracking.
72
- * @param syncFunction - Function to call when block instance changes (to sync from node config)
71
+ * This is a helper method for controls that need to sync attributes when switching between block instances.
72
+ * @param syncFunction - Function to call when block instance changes (to sync from attributes)
73
73
  * @param updateUI - Function to call to update the UI (called both on change and when same block)
74
+ * @param blockInstanceIdAttribute - The attribute name for block instance ID (default: 'data-block-instance-id')
74
75
  * @returns true if block instance changed, false otherwise
75
76
  */
76
- protected handleBlockInstanceChange(syncFunction: (node: ImmutableHtmlNode) => void, updateUI: () => void): boolean;
77
- _GuLabel({ text, name, position }: LabelProps): string;
77
+ protected handleBlockInstanceChange(syncFunction: (node: ImmutableHtmlNode) => void, updateUI: () => void, blockInstanceIdAttribute?: string): boolean;
78
+ _GuLabel({ text, name }: LabelProps): string;
78
79
  _GuToggle(name: string): string;
79
80
  _GuSelectItem({ text, value }: {
80
81
  text: string;
@@ -6,10 +6,6 @@ ue-main-editor-container[panel-position=SETTINGS_BLOCKS] ue-wide-panel {
6
6
  right: calc(100% - calc(var(--ue-spacing-step, 5px) * 3) - 425px);
7
7
  }
8
8
 
9
- ue-main-tabs-panel-component .fixed-panel-header {
10
- display: none;
11
- }
12
-
13
9
  /* Remove with this writing task DT-28355 */
14
10
  ue-description a {
15
11
  display: none;
@@ -19,10 +19,46 @@ const n = `.esd-x,
19
19
  box-shadow: none;
20
20
  }
21
21
  .ins-product-cart ue-node-actions,
22
- .ins-recommendation-v3-block-v2 .product-attribute-cell ue-node-actions,
23
- .ins-recommendation-v3-block-v2 .product-attribute-cell ue-node-panel {
22
+ /* Horizontal layout - hide for info, image, and button cells */
23
+ .ins-recommendation-v3-block-v2 .product-info-cell ue-node-actions,
24
+ .ins-recommendation-v3-block-v2 .product-info-cell ue-node-panel,
25
+ .ins-recommendation-v3-block-v2 .product-image-cell ue-node-actions,
26
+ .ins-recommendation-v3-block-v2 .product-image-cell ue-node-panel,
27
+ .ins-recommendation-v3-block-v2 .button-cell ue-node-actions,
28
+ .ins-recommendation-v3-block-v2 .button-cell ue-node-panel,
29
+ /* Vertical layout - hide for product-card-segment inner cells */
30
+ .ins-recommendation-v3-block-v2 .product-card-segment ue-node-actions,
31
+ .ins-recommendation-v3-block-v2 .product-card-segment ue-node-panel,
32
+ /* Hide for specific product attribute cells in both layouts */
33
+ .ins-recommendation-v3-block-v2 .product-image ue-node-actions,
34
+ .ins-recommendation-v3-block-v2 .product-image ue-node-panel,
35
+ .ins-recommendation-v3-block-v2 .product-name ue-node-actions,
36
+ .ins-recommendation-v3-block-v2 .product-name ue-node-panel,
37
+ .ins-recommendation-v3-block-v2 .product-price ue-node-actions,
38
+ .ins-recommendation-v3-block-v2 .product-price ue-node-panel,
39
+ .ins-recommendation-v3-block-v2 .product-old-price ue-node-actions,
40
+ .ins-recommendation-v3-block-v2 .product-old-price ue-node-panel,
41
+ .ins-recommendation-v3-block-v2 .product-omnibus-price ue-node-actions,
42
+ .ins-recommendation-v3-block-v2 .product-omnibus-price ue-node-panel,
43
+ .ins-recommendation-v3-block-v2 .product-omnibus-discount ue-node-actions,
44
+ .ins-recommendation-v3-block-v2 .product-omnibus-discount ue-node-panel,
45
+ .ins-recommendation-v3-block-v2 .product-button ue-node-actions,
46
+ .ins-recommendation-v3-block-v2 .product-button ue-node-panel {
24
47
  display: none !important;
25
48
  }
49
+
50
+ /* Apply to the table cell (td) with text-trim-enabled class */
51
+ .text-trim-enabled {
52
+ max-width: 0 !important;
53
+ }
54
+
55
+ .text-trim-enabled p {
56
+ overflow: hidden !important;
57
+ text-overflow: ellipsis !important;
58
+ white-space: nowrap !important;
59
+ margin: 0 !important;
60
+ display: block !important;
61
+ }
26
62
  `;
27
63
  export {
28
64
  n as default
@@ -1,77 +1,74 @@
1
1
  import { productPairs as w } from "../extensions/Blocks/Items/enums/productEnums.js";
2
- function P(k) {
3
- const m = k.replaceAll("{%", "<!--{%").replaceAll("%}", "%}-->"), $ = new DOMParser().parseFromString(m, "text/html"), R = w.PAIRS_FOR_EXTENSION;
4
- Object.entries(R).forEach(([n, l]) => {
2
+ function M(H) {
3
+ const m = H.replaceAll("{%", "<!--{%").replaceAll("%}", "%}-->"), $ = new DOMParser().parseFromString(m, "text/html"), C = w.PAIRS_FOR_EXTENSION;
4
+ Object.entries(C).forEach(([n, d]) => {
5
5
  $.querySelectorAll(".ins-product-td").forEach((o) => {
6
- const E = o.getAttribute("data-number") || "1", b = o.getAttribute("data-type") || "CART_ITEMS";
6
+ const h = o.getAttribute("data-number") || "1", _ = o.getAttribute("data-type") || "CART_ITEMS";
7
7
  o.querySelectorAll(`[product-attr="${n}"]`).forEach((e) => {
8
8
  var y;
9
- const T = e.getAttribute("data-type") || b, u = e.getAttribute("data-number") || E, p = l[T];
9
+ const b = e.getAttribute("data-type") || _, u = e.getAttribute("data-number") || h, p = d[b];
10
10
  if (p)
11
11
  switch (n) {
12
12
  case "imageSrc": {
13
- let t = null, c = null;
14
- if (e.tagName === "IMG" ? (t = e, c = t.closest("a")) : (t = e.querySelector("img"), c = e.querySelector("a") || e.closest("a")), !t)
13
+ let t = null, i = null;
14
+ if (e.tagName === "IMG" ? (t = e, i = t.closest("a")) : (t = e.querySelector("img"), i = e.querySelector("a") || e.closest("a")), !t)
15
15
  break;
16
- const i = p.DEFAULT, a = p.ATTR;
17
- if (i && t.src) {
16
+ const c = p.DEFAULT, a = p.ATTR;
17
+ if (c && t.src) {
18
18
  const r = t.src;
19
- i.some((d) => {
20
- const s = d.split("/").pop() || "", _ = r.split("/").pop() || "";
21
- return r.includes(d) || r.includes(s) || _ === s;
19
+ c.some((l) => {
20
+ const s = l.split("/").pop() || "", F = r.split("/").pop() || "";
21
+ return r.includes(l) || r.includes(s) || F === s;
22
22
  }) && (t.src = `{{${a}_${u}}}`);
23
23
  }
24
- if (c) {
25
- const r = (y = R.itemLink) == null ? void 0 : y[T];
24
+ if (i) {
25
+ const r = (y = C.itemLink) == null ? void 0 : y[b];
26
26
  if (r) {
27
- const f = r.HREF, d = r.DEFAULT_HREF || "#!", s = c.href;
28
- (s === "#" || s === "" || s.endsWith("#!") || s.endsWith(d) || s === `${window.location.href}${d}` || !s || s === window.location.href) && (c.href = `{{${f}_${u}}}`);
27
+ const f = r.HREF, l = r.DEFAULT_HREF || "#!", s = i.href;
28
+ (s === "#" || s === "" || s.endsWith("#!") || s.endsWith(l) || s === `${window.location.href}${l}` || !s || s === window.location.href) && (i.href = `{{${f}_${u}}}`);
29
29
  }
30
30
  }
31
31
  break;
32
32
  }
33
33
  case "name": {
34
- const t = p, c = t.ATTR, i = t.DEFAULT_HREF || "#!", a = t.HREF;
35
- e.textContent && (e.textContent = `{{${c}_${u}}}`);
34
+ const t = p, i = t.ATTR, c = t.DEFAULT_HREF || "#!", a = t.HREF;
35
+ e.textContent && (e.textContent = `{{${i}_${u}}}`);
36
36
  const r = e.closest("a") || (e.tagName === "A" ? e : null);
37
37
  if (r && a) {
38
- const f = r.href, d = `${window.location.href}${i}`;
39
- (f === d || f.endsWith(i)) && (r.href = `{{${a}_${u}}}`);
38
+ const f = r.href, l = `${window.location.href}${c}`;
39
+ (f === l || f.endsWith(c)) && (r.href = `{{${a}_${u}}}`);
40
40
  }
41
41
  break;
42
42
  }
43
43
  case "price":
44
44
  case "originalPrice": {
45
- const t = p, c = e.getAttribute("data-formated"), i = e.getAttribute("data-single_price"), a = c === "true", r = i === "true", f = e.getAttribute("data-curency") || "before";
46
- let d;
47
- r ? d = a ? t.SINGLE_PRICE_FORMATTED : t.SINGLE_PRICE : d = a ? t.PRICE_FORMATTED : t.PRICE;
48
- const s = t.CURRENCY;
49
- let _ = `{{${d}_${u}}}`;
50
- if (s) {
51
- const H = `{{${s}_${u}}}`;
52
- _ = f === "after" ? `${_} ${H}` : `${H} ${_}`;
45
+ const t = p, c = e.getAttribute("data-formated") === "true", a = e.getAttribute("data-curency") || "before", r = c ? t.PRICE_FORMATTED : t.PRICE, f = t.CURRENCY;
46
+ let l = `{{${r}_${u}}}`;
47
+ if (f) {
48
+ const s = `{{${f}_${u}}}`;
49
+ l = a === "after" ? `${l} ${s}` : `${s} ${l}`;
53
50
  }
54
- e.textContent = _;
51
+ e.textContent = l;
55
52
  break;
56
53
  }
57
54
  case "quantity": {
58
- const t = p, c = t.ATTR, i = t.DEFAULT;
59
- e.textContent && e.textContent.trim() === i && (e.textContent = `{{${c}_${u}}}`);
55
+ const t = p, i = t.ATTR, c = t.DEFAULT;
56
+ e.textContent && e.textContent.trim() === c && (e.textContent = `{{${i}_${u}}}`);
60
57
  break;
61
58
  }
62
59
  case "button": {
63
- const t = p, c = t.HREF, i = t.DEFAULT_HREF || "#!", a = e.tagName === "A" ? e : e.querySelector("a");
60
+ const t = p, i = t.HREF, c = t.DEFAULT_HREF || "#!", a = e.tagName === "A" ? e : e.querySelector("a");
64
61
  if (a) {
65
- const r = a.href || "", f = `${window.location.href}${i}`;
66
- (r === "" || r === "#" || r === f || r.endsWith(i) || r.endsWith("#!") || r === window.location.href) && (a.href = `{{${c}_${u}}}`);
62
+ const r = a.href || "", f = `${window.location.href}${c}`;
63
+ (r === "" || r === "#" || r === f || r.endsWith(c) || r.endsWith("#!") || r === window.location.href) && (a.href = `{{${i}_${u}}}`);
67
64
  }
68
65
  break;
69
66
  }
70
67
  case "itemLink": {
71
- const t = p, c = t.HREF, i = t.DEFAULT_HREF || "#!", a = e;
68
+ const t = p, i = t.HREF, c = t.DEFAULT_HREF || "#!", a = e;
72
69
  if (a.href) {
73
- const r = a.href, f = `${window.location.href}${i}`;
74
- (r === f || r.endsWith(i)) && (a.href = `{{${c}_${u}}}`);
70
+ const r = a.href, f = `${window.location.href}${c}`;
71
+ (r === f || r.endsWith(c)) && (a.href = `{{${i}_${u}}}`);
75
72
  }
76
73
  break;
77
74
  }
@@ -86,21 +83,21 @@ function P(k) {
86
83
  });
87
84
  });
88
85
  });
89
- const F = $.querySelectorAll(".ins-product-td"), S = [];
90
- F.forEach((n) => {
91
- const l = n.getAttribute("data-type") || "CART_ITEMS", A = n.getAttribute("data-number") || "1", o = n.getAttribute("data-nodup"), E = n.outerHTML;
92
- S.push({
86
+ const S = $.querySelectorAll(".ins-product-td"), R = [];
87
+ S.forEach((n) => {
88
+ const d = n.getAttribute("data-type") || "CART_ITEMS", A = n.getAttribute("data-number") || "1", o = n.getAttribute("data-nodup"), h = n.outerHTML;
89
+ R.push({
93
90
  element: n,
94
- outerHtml: E,
95
- type: l,
91
+ outerHtml: h,
92
+ type: d,
96
93
  number: A,
97
94
  nodup: o || void 0
98
95
  });
99
96
  });
100
- let h = $.body.innerHTML;
101
- S.reverse().forEach(({ outerHtml: n, type: l, number: A }) => {
97
+ let E = $.body.innerHTML;
98
+ R.reverse().forEach(({ outerHtml: n, type: d, number: A }) => {
102
99
  let o = "";
103
- switch (l) {
100
+ switch (d) {
104
101
  case "CART_ITEMS":
105
102
  o = "ins_apr_total_product_kind";
106
103
  break;
@@ -112,28 +109,28 @@ function P(k) {
112
109
  break;
113
110
  }
114
111
  if (o) {
115
- const b = parseInt(A) - 1, T = `${`{% if ${o} > ${b} %}`}${n}{% endif %}`;
116
- h = h.replace(n, T);
112
+ const _ = parseInt(A) - 1, b = `${`{% if ${o} > ${_} %}`}${n}{% endif %}`;
113
+ E = E.replace(n, b);
117
114
  }
118
115
  });
119
- const I = $.querySelectorAll('[product-attr="originalPrice"][data-type="CART_ITEMS"]'), g = [];
120
- return I.forEach((n) => {
121
- const l = n.getAttribute("data-number"), A = n.getAttribute("data-type");
122
- if (!l || A !== "CART_ITEMS")
116
+ const k = $.querySelectorAll('[product-attr="originalPrice"][data-type="CART_ITEMS"]'), T = [];
117
+ return k.forEach((n) => {
118
+ const d = n.getAttribute("data-number"), A = n.getAttribute("data-type");
119
+ if (!d || A !== "CART_ITEMS")
123
120
  return;
124
121
  const o = n.closest(".product-original-price-class");
125
122
  if (o) {
126
- const E = o.outerHTML;
127
- g.some((C) => C.tdOuterHtml === E) || g.push({ tdOuterHtml: E, number: l });
123
+ const h = o.outerHTML;
124
+ T.some((g) => g.tdOuterHtml === h) || T.push({ tdOuterHtml: h, number: d });
128
125
  }
129
- }), g.reverse().forEach(({ tdOuterHtml: n, number: l }) => {
130
- const A = `{% if ins_apr_price_${l} != ins_apr_originalprice_${l} %}`;
131
- if (!h.includes(A) && !n.includes("{% if")) {
132
- const E = `${A}${n}{% endif %}`;
133
- h = h.replace(n, E);
126
+ }), T.reverse().forEach(({ tdOuterHtml: n, number: d }) => {
127
+ const A = `{% if ins_apr_price_${d} != ins_apr_originalprice_${d} %}`;
128
+ if (!E.includes(A) && !n.includes("{% if")) {
129
+ const h = `${A}${n}{% endif %}`;
130
+ E = E.replace(n, h);
134
131
  }
135
- }), h.replaceAll("<!--{%", "{%").replaceAll("%}-->", "%}").replaceAll("&lt;!--{%", "{%").replaceAll("%}--&gt;", "%}");
132
+ }), E.replaceAll("<!--{%", "{%").replaceAll("%}-->", "%}").replaceAll("&lt;!--{%", "{%").replaceAll("%}--&gt;", "%}");
136
133
  }
137
134
  export {
138
- P as pairProductVariables
135
+ M as pairProductVariables
139
136
  };
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@useinsider/guido",
3
- "version": "2.0.0-beta.faa7c5d",
3
+ "version": "2.0.0-beta.fb0f99d",
4
4
  "description": "Guido is a Vue + TypeScript wrapper for Email Plugin. Easily embed the email editor in your Vue applications.",
5
5
  "main": "./dist/guido.umd.cjs",
6
6
  "module": "./dist/library.js",