@useinsider/guido 2.0.0-beta.c9db5fd → 2.0.0-beta.d0056c9

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 (196) hide show
  1. package/dist/components/organisms/email-preview/PreviewContainer.vue.js +3 -3
  2. package/dist/components/organisms/email-preview/amp/AmpErrorModal.vue.js +6 -6
  3. package/dist/components/organisms/email-preview/amp/AmpErrorModal.vue2.js +17 -13
  4. package/dist/components/organisms/email-preview/amp/AmpToggle.vue.js +6 -6
  5. package/dist/components/organisms/email-preview/amp/AmpToggle.vue2.js +14 -12
  6. package/dist/components/organisms/email-preview/desktop-preview/DesktopBrowserHeader.vue.js +18 -0
  7. package/dist/components/organisms/email-preview/desktop-preview/DesktopBrowserHeader.vue2.js +15 -0
  8. package/dist/components/organisms/email-preview/desktop-preview/DesktopPreview.vue.js +10 -14
  9. package/dist/components/organisms/email-preview/desktop-preview/DesktopPreview.vue2.js +14 -22
  10. package/dist/components/organisms/email-preview/desktop-preview/EmailSizeIndicator.vue.js +3 -3
  11. package/dist/components/organisms/email-preview/mobile-preview/ContentView.vue.js +11 -10
  12. package/dist/components/organisms/email-preview/mobile-preview/InboxView.vue.js +12 -10
  13. package/dist/components/organisms/email-preview/mobile-preview/MobilePreview.vue.js +11 -10
  14. package/dist/components/organisms/email-preview/mobile-preview/MobilePreview.vue2.js +15 -14
  15. package/dist/components/organisms/header/EditorActions.vue.js +21 -0
  16. package/dist/components/organisms/header/EditorActions.vue2.js +41 -0
  17. package/dist/components/organisms/header/EditorToolbar.vue.js +18 -0
  18. package/dist/components/organisms/header/EditorToolbar.vue2.js +17 -0
  19. package/dist/components/organisms/header/HeaderWrapper.vue.js +6 -5
  20. package/dist/components/organisms/header/LeftSlot.vue.js +11 -11
  21. package/dist/components/organisms/header/LeftSlot.vue2.js +11 -12
  22. package/dist/components/organisms/header/MiddleSlot.vue.js +7 -7
  23. package/dist/components/organisms/header/MiddleSlot.vue2.js +11 -15
  24. package/dist/components/organisms/header/RightSlot.vue.js +11 -14
  25. package/dist/components/organisms/header/RightSlot.vue2.js +13 -30
  26. package/dist/components/organisms/header/version-history/VersionHistory.vue.js +5 -5
  27. package/dist/components/organisms/onboarding/NewVersionPopup.vue2.js +15 -15
  28. package/dist/components/organisms/unsubscribe/UnsubscribeTypeSelection.vue.js +1 -1
  29. package/dist/components/organisms/unsubscribe/UnsubscribeTypeSelection.vue2.js +20 -19
  30. package/dist/config/migrator/recommendationMigrator.js +1 -1
  31. package/dist/enums/academy.js +8 -0
  32. package/dist/enums/onboarding.js +1 -2
  33. package/dist/enums/unsubscribe.js +20 -21
  34. package/dist/extensions/Blocks/Items/controls/cardComposition.js +4 -13
  35. package/dist/extensions/Blocks/Recommendation/block.js +1 -1
  36. package/dist/extensions/Blocks/Recommendation/cardCompositionControl.js +103 -0
  37. package/dist/extensions/Blocks/Recommendation/constants.js +5 -0
  38. package/dist/extensions/Blocks/Recommendation/control.js +306 -0
  39. package/dist/extensions/Blocks/Recommendation/controls/button/align.js +13 -0
  40. package/dist/extensions/Blocks/Recommendation/controls/button/border.js +13 -0
  41. package/dist/extensions/Blocks/Recommendation/controls/button/borderRadius.js +13 -0
  42. package/dist/extensions/Blocks/Recommendation/controls/button/color.js +13 -0
  43. package/dist/extensions/Blocks/Recommendation/controls/button/fitToContent.js +13 -0
  44. package/dist/extensions/Blocks/Recommendation/controls/button/fontFamily.js +13 -0
  45. package/dist/extensions/Blocks/Recommendation/controls/button/margins.js +13 -0
  46. package/dist/extensions/Blocks/Recommendation/controls/button/paddings.js +13 -0
  47. package/dist/extensions/Blocks/Recommendation/controls/button/text.js +13 -0
  48. package/dist/extensions/Blocks/Recommendation/controls/button/textSize.js +13 -0
  49. package/dist/extensions/Blocks/Recommendation/controls/button/textStyleAndFontColor.js +13 -0
  50. package/dist/extensions/Blocks/Recommendation/controls/image/margins.js +13 -0
  51. package/dist/extensions/Blocks/Recommendation/controls/image/size.js +13 -0
  52. package/dist/extensions/Blocks/Recommendation/controls/name/align.js +13 -0
  53. package/dist/extensions/Blocks/Recommendation/controls/name/background.js +13 -0
  54. package/dist/extensions/Blocks/Recommendation/controls/name/color.js +13 -0
  55. package/dist/extensions/Blocks/Recommendation/controls/name/fontFamily.js +13 -0
  56. package/dist/extensions/Blocks/Recommendation/controls/name/paddings.js +13 -0
  57. package/dist/extensions/Blocks/Recommendation/controls/name/size.js +13 -0
  58. package/dist/extensions/Blocks/Recommendation/controls/name/style.js +13 -0
  59. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/align.js +13 -0
  60. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/background.js +13 -0
  61. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/color.js +13 -0
  62. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/fontFamily.js +13 -0
  63. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/paddings.js +13 -0
  64. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/size.js +13 -0
  65. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/style.js +13 -0
  66. package/dist/extensions/Blocks/Recommendation/controls/price/align.js +13 -0
  67. package/dist/extensions/Blocks/Recommendation/controls/price/background.js +13 -0
  68. package/dist/extensions/Blocks/Recommendation/controls/price/color.js +13 -0
  69. package/dist/extensions/Blocks/Recommendation/controls/price/fontFamily.js +13 -0
  70. package/dist/extensions/Blocks/Recommendation/controls/price/paddings.js +13 -0
  71. package/dist/extensions/Blocks/Recommendation/controls/price/size.js +13 -0
  72. package/dist/extensions/Blocks/Recommendation/controls/price/style.js +13 -0
  73. package/dist/extensions/Blocks/Recommendation/extension.js +43 -39
  74. package/dist/extensions/Blocks/Recommendation/recommendation.css.js +0 -5
  75. package/dist/extensions/Blocks/Recommendation/settingsPanel.js +72 -127
  76. package/dist/extensions/Blocks/Recommendation/store/recommendation.js +20 -20
  77. package/dist/extensions/Blocks/Recommendation/templates/blockTemplate.js +160 -0
  78. package/dist/extensions/Blocks/Recommendation/templates/migrationTemplate.js +152 -0
  79. package/dist/extensions/Blocks/Recommendation/templates/templateUtils.js +88 -67
  80. package/dist/extensions/Blocks/controlFactories.js +121 -155
  81. package/dist/guido.css +1 -1
  82. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/esm/index.js +291 -361
  83. package/dist/package.json.js +1 -1
  84. package/dist/src/components/organisms/email-preview/desktop-preview/DesktopBrowserHeader.vue.d.ts +2 -0
  85. package/dist/src/components/organisms/header/EditorActions.vue.d.ts +4 -0
  86. package/dist/src/components/organisms/header/EditorToolbar.vue.d.ts +2 -0
  87. package/dist/src/components/organisms/header/RightSlot.vue.d.ts +1 -1
  88. package/dist/src/enums/academy.d.ts +12 -0
  89. package/dist/src/enums/onboarding.d.ts +0 -1
  90. package/dist/src/enums/unsubscribe.d.ts +0 -1
  91. package/dist/src/extensions/Blocks/Recommendation/cardCompositionControl.d.ts +28 -0
  92. package/dist/src/extensions/Blocks/Recommendation/{constants/controlIds.d.ts → constants.d.ts} +11 -19
  93. package/dist/src/extensions/Blocks/Recommendation/{controls/main/index.d.ts → control.d.ts} +3 -19
  94. package/dist/src/extensions/Blocks/Recommendation/controls/button/align.d.ts +5 -0
  95. package/dist/src/extensions/Blocks/Recommendation/controls/button/border.d.ts +5 -0
  96. package/dist/src/extensions/Blocks/Recommendation/controls/button/borderRadius.d.ts +5 -0
  97. package/dist/src/extensions/Blocks/Recommendation/controls/button/color.d.ts +5 -0
  98. package/dist/src/extensions/Blocks/Recommendation/controls/button/fitToContent.d.ts +5 -0
  99. package/dist/src/extensions/Blocks/Recommendation/controls/button/fontFamily.d.ts +5 -0
  100. package/dist/src/extensions/Blocks/Recommendation/controls/button/margins.d.ts +5 -0
  101. package/dist/src/extensions/Blocks/Recommendation/controls/button/paddings.d.ts +5 -0
  102. package/dist/src/extensions/Blocks/Recommendation/controls/button/text.d.ts +5 -0
  103. package/dist/src/extensions/Blocks/Recommendation/controls/button/textSize.d.ts +5 -0
  104. package/dist/src/extensions/Blocks/Recommendation/controls/button/textStyleAndFontColor.d.ts +5 -0
  105. package/dist/src/extensions/Blocks/Recommendation/controls/image/margins.d.ts +5 -0
  106. package/dist/src/extensions/Blocks/Recommendation/controls/image/size.d.ts +5 -0
  107. package/dist/src/extensions/Blocks/Recommendation/controls/name/align.d.ts +5 -0
  108. package/dist/src/extensions/Blocks/Recommendation/controls/name/background.d.ts +5 -0
  109. package/dist/src/extensions/Blocks/Recommendation/controls/name/color.d.ts +5 -0
  110. package/dist/src/extensions/Blocks/Recommendation/controls/name/fontFamily.d.ts +5 -0
  111. package/dist/src/extensions/Blocks/Recommendation/controls/name/paddings.d.ts +5 -0
  112. package/dist/src/extensions/Blocks/Recommendation/controls/name/size.d.ts +5 -0
  113. package/dist/src/extensions/Blocks/Recommendation/controls/name/style.d.ts +5 -0
  114. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/align.d.ts +5 -0
  115. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/background.d.ts +5 -0
  116. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/color.d.ts +5 -0
  117. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/fontFamily.d.ts +5 -0
  118. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/paddings.d.ts +5 -0
  119. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/size.d.ts +5 -0
  120. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/style.d.ts +5 -0
  121. package/dist/src/extensions/Blocks/Recommendation/controls/price/align.d.ts +5 -0
  122. package/dist/src/extensions/Blocks/Recommendation/controls/price/background.d.ts +5 -0
  123. package/dist/src/extensions/Blocks/Recommendation/controls/price/color.d.ts +5 -0
  124. package/dist/src/extensions/Blocks/Recommendation/controls/price/fontFamily.d.ts +5 -0
  125. package/dist/src/extensions/Blocks/Recommendation/controls/price/paddings.d.ts +5 -0
  126. package/dist/src/extensions/Blocks/Recommendation/controls/price/size.d.ts +5 -0
  127. package/dist/src/extensions/Blocks/Recommendation/controls/price/style.d.ts +5 -0
  128. package/dist/src/extensions/Blocks/Recommendation/extension.d.ts +0 -9
  129. package/dist/src/extensions/Blocks/Recommendation/templates/{verticalTemplate.d.ts → blockTemplate.d.ts} +9 -13
  130. package/dist/src/extensions/Blocks/Recommendation/templates/{verticalMigrationTemplate.d.ts → migrationTemplate.d.ts} +4 -11
  131. package/dist/src/extensions/Blocks/Recommendation/templates/templateUtils.d.ts +21 -59
  132. package/dist/src/stores/editor.d.ts +21 -0
  133. package/dist/static/assets/desktop/desktop-mockup-center.svg.js +4 -0
  134. package/dist/static/assets/desktop/desktop-mockup-left.svg.js +4 -0
  135. package/dist/static/assets/desktop/desktop-mockup-right.svg.js +4 -0
  136. package/dist/static/assets/mobile/email-mockup.svg.js +4 -0
  137. package/dist/static/assets/mobile/inbox-mockup.svg.js +4 -0
  138. package/dist/static/styles/components/wide-panel.css.js +5 -1
  139. package/dist/static/styles/customEditorStyle.css.js +2 -38
  140. package/dist/stores/editor.js +1 -0
  141. package/package.json +3 -3
  142. package/dist/components/organisms/email-preview/desktop-preview/EmailHeaderInfo.vue.js +0 -17
  143. package/dist/components/organisms/email-preview/desktop-preview/EmailHeaderInfo.vue2.js +0 -20
  144. package/dist/extensions/Blocks/Recommendation/constants/blockIds.js +0 -4
  145. package/dist/extensions/Blocks/Recommendation/constants/controlIds.js +0 -4
  146. package/dist/extensions/Blocks/Recommendation/constants/selectors.js +0 -11
  147. package/dist/extensions/Blocks/Recommendation/controls/button/index.js +0 -64
  148. package/dist/extensions/Blocks/Recommendation/controls/cardBackground/index.js +0 -100
  149. package/dist/extensions/Blocks/Recommendation/controls/cardComposition/index.js +0 -243
  150. package/dist/extensions/Blocks/Recommendation/controls/image/index.js +0 -19
  151. package/dist/extensions/Blocks/Recommendation/controls/layout/index.js +0 -152
  152. package/dist/extensions/Blocks/Recommendation/controls/main/index.js +0 -370
  153. package/dist/extensions/Blocks/Recommendation/controls/name/index.js +0 -46
  154. package/dist/extensions/Blocks/Recommendation/controls/name/textTrim.js +0 -76
  155. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/index.js +0 -44
  156. package/dist/extensions/Blocks/Recommendation/controls/omnibusDiscount/index.js +0 -48
  157. package/dist/extensions/Blocks/Recommendation/controls/omnibusDiscount/textAfter.js +0 -73
  158. package/dist/extensions/Blocks/Recommendation/controls/omnibusDiscount/textBefore.js +0 -73
  159. package/dist/extensions/Blocks/Recommendation/controls/omnibusPrice/index.js +0 -48
  160. package/dist/extensions/Blocks/Recommendation/controls/omnibusPrice/textAfter.js +0 -73
  161. package/dist/extensions/Blocks/Recommendation/controls/omnibusPrice/textBefore.js +0 -73
  162. package/dist/extensions/Blocks/Recommendation/controls/price/index.js +0 -44
  163. package/dist/extensions/Blocks/Recommendation/controls/spacing/index.js +0 -224
  164. package/dist/extensions/Blocks/Recommendation/templates/horizontalElementRenderer.js +0 -157
  165. package/dist/extensions/Blocks/Recommendation/templates/horizontalTemplate.js +0 -78
  166. package/dist/extensions/Blocks/Recommendation/templates/verticalElementRenderer.js +0 -186
  167. package/dist/extensions/Blocks/Recommendation/templates/verticalMigrationTemplate.js +0 -256
  168. package/dist/extensions/Blocks/Recommendation/templates/verticalTemplate.js +0 -81
  169. package/dist/extensions/Blocks/Recommendation/utils/preserveTextStyles.js +0 -25
  170. package/dist/src/extensions/Blocks/Recommendation/constants/blockIds.d.ts +0 -13
  171. package/dist/src/extensions/Blocks/Recommendation/constants/index.d.ts +0 -11
  172. package/dist/src/extensions/Blocks/Recommendation/constants/selectors.d.ts +0 -19
  173. package/dist/src/extensions/Blocks/Recommendation/controls/button/index.d.ts +0 -143
  174. package/dist/src/extensions/Blocks/Recommendation/controls/cardBackground/index.d.ts +0 -41
  175. package/dist/src/extensions/Blocks/Recommendation/controls/cardComposition/index.d.ts +0 -95
  176. package/dist/src/extensions/Blocks/Recommendation/controls/image/index.d.ts +0 -35
  177. package/dist/src/extensions/Blocks/Recommendation/controls/index.d.ts +0 -23
  178. package/dist/src/extensions/Blocks/Recommendation/controls/layout/index.d.ts +0 -50
  179. package/dist/src/extensions/Blocks/Recommendation/controls/name/index.d.ts +0 -97
  180. package/dist/src/extensions/Blocks/Recommendation/controls/name/textTrim.d.ts +0 -16
  181. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/index.d.ts +0 -95
  182. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusDiscount/index.d.ts +0 -100
  183. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusDiscount/textAfter.d.ts +0 -15
  184. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusDiscount/textBefore.d.ts +0 -15
  185. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusPrice/index.d.ts +0 -100
  186. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusPrice/textAfter.d.ts +0 -15
  187. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusPrice/textBefore.d.ts +0 -15
  188. package/dist/src/extensions/Blocks/Recommendation/controls/price/index.d.ts +0 -95
  189. package/dist/src/extensions/Blocks/Recommendation/controls/spacing/index.d.ts +0 -77
  190. package/dist/src/extensions/Blocks/Recommendation/templates/horizontalElementRenderer.d.ts +0 -8
  191. package/dist/src/extensions/Blocks/Recommendation/templates/horizontalMigrationTemplate.d.ts +0 -25
  192. package/dist/src/extensions/Blocks/Recommendation/templates/horizontalTemplate.d.ts +0 -28
  193. package/dist/src/extensions/Blocks/Recommendation/templates/verticalElementRenderer.d.ts +0 -7
  194. package/dist/src/extensions/Blocks/Recommendation/utils/preserveTextStyles.d.ts +0 -19
  195. package/dist/static/assets/inbox-mockup.svg.js +0 -4
  196. package/dist/static/assets/phone-mockup.svg.js +0 -4
@@ -0,0 +1,160 @@
1
+ import { BlockType as t, BlockAttr as n } from "../../../../node_modules/@stripoinc/ui-editor-extensions/dist/esm/index.js";
2
+ import { RecommendationBlockId as o } from "../constants.js";
3
+ import { generateTemplate as l, prepareProductRows as s, spacer as d, DEFAULTS as p, getDefaultProducts as i } from "./templateUtils.js";
4
+ import { DEFAULT_CARD_COMPOSITION as $ } from "./templateUtils.js";
5
+ const g = `
6
+ <td align="left" class="ins-recommendation-v3-block-v2 esd-block-recommendation-v3-block es-p20">
7
+ <table width="100%" cellpadding="0" cellspacing="0" border="0">
8
+ <tr>
9
+ <td align="center">
10
+ <table
11
+ class="container"
12
+ width="100%"
13
+ cellpadding="0"
14
+ cellspacing="0"
15
+ border="0">
16
+ <tbody>
17
+ <tr>
18
+ <td>
19
+ <table
20
+ width="100%"
21
+ cellpadding="0"
22
+ cellspacing="0"
23
+ border="0">
24
+ <tbody>
25
+ <${t.BLOCK_TEXT}
26
+ class="es-p10t es-p10b es-p20l es-p20r"
27
+ align="center">
28
+ <p path="1" style="font-size: 28px; color: #333333;">
29
+ <strong path="1,0">{-{-TITLE-}-}</strong>
30
+ </p>
31
+ </${t.BLOCK_TEXT}>
32
+ </tbody>
33
+ </table>
34
+ </td>
35
+ </tr>
36
+ ${d}
37
+ <tr>
38
+ <td>
39
+ <table
40
+ class="ins-recommendation-product-container"
41
+ width="100%"
42
+ cellpadding="0"
43
+ cellspacing="0"
44
+ border="0"
45
+ >
46
+ {-{-PRODUCT_ROWS-}-}
47
+ </table>
48
+ </td>
49
+ </tr>
50
+ </tbody>
51
+ </table>
52
+ </td>
53
+ </tr>
54
+ </table>
55
+ </td>
56
+ `, a = {
57
+ productImage: (e) => `
58
+ <${t.BLOCK_IMAGE}
59
+ ${n.BLOCK_IMAGE.src}="${e.image_url}"
60
+ ${n.BLOCK_IMAGE.alt}="${e.name}"
61
+ ${n.BLOCK_IMAGE.href}="#"
62
+ class="product-image"
63
+ align="center"
64
+ style="max-width: 100%; height: auto; margin: 0 auto;"
65
+ esd-extension-block-id="${o.IMAGE}">
66
+ </${t.BLOCK_IMAGE}>
67
+ `,
68
+ productName: (e) => `
69
+ <${t.BLOCK_TEXT}
70
+ class="product-name"
71
+ align="center"
72
+ style="font-size: 16px; color: #333333; font-weight: 600; padding: 15px 10px; text-align: center;"
73
+ esd-extension-block-id="${o.NAME}">
74
+ <p path="1" contenteditable="false">
75
+ <strong path="1,0">${e.name}</strong>
76
+ </p>
77
+ </${t.BLOCK_TEXT}>
78
+ `,
79
+ productPrice: () => `
80
+ <${t.BLOCK_TEXT}
81
+ class="product-price"
82
+ align="center"
83
+ style="padding: 10px; text-align: center;"
84
+ esd-extension-block-id="${o.PRICE}">
85
+ <p path="1" contenteditable="false">
86
+ <span class="current-price" style="font-size: 16px; color: #333333; font-weight: bold;">
87
+ <strong path="1,0">18,00 TRY</strong>
88
+ </span>
89
+ </p>
90
+ </${t.BLOCK_TEXT}>
91
+ `,
92
+ productOldPrice: () => `
93
+ <${t.BLOCK_TEXT}
94
+ class="product-old-price"
95
+ align="center"
96
+ style="padding: 10px; text-align: center;"
97
+ esd-extension-block-id="${o.OLD_PRICE}">
98
+ <p path="1" contenteditable="false">
99
+ <span class="old-price" style="font-size: 14px; color: #999999; text-decoration: line-through;">
100
+ <s path="1,0">20,00 TRY</s>
101
+ </span>
102
+ </p>
103
+ </${t.BLOCK_TEXT}>
104
+ `,
105
+ productButton: () => `
106
+ <${t.BLOCK_BUTTON}
107
+ ${n.BLOCK_BUTTON.href}="#"
108
+ class="product-button"
109
+ align="center"
110
+ style="padding: 15px 10px 20px 10px; text-align: center;"
111
+ esd-extension-block-id="${o.BUTTON}">
112
+ <span class="es-button-border">
113
+ <a
114
+ href="#"
115
+ class="es-button buy-button"
116
+ target="_blank"
117
+ style="
118
+ display: inline-block;
119
+ width: 90%;
120
+ max-width: 150px;
121
+ padding: 12px 20px;
122
+ background-color: #ffffff;
123
+ color: #333333;
124
+ text-decoration: none;
125
+ border: 2px solid #cccccc;
126
+ font-size: 16px;
127
+ box-sizing: border-box;
128
+ ">
129
+ Buy
130
+ </a>
131
+ </span>
132
+ </${t.BLOCK_BUTTON}>
133
+ `
134
+ };
135
+ function x() {
136
+ const e = i();
137
+ return l(
138
+ g,
139
+ e,
140
+ 3,
141
+ a,
142
+ p.TITLE
143
+ );
144
+ }
145
+ function f(e, r, c) {
146
+ return s(
147
+ e,
148
+ r,
149
+ a,
150
+ c
151
+ );
152
+ }
153
+ export {
154
+ p as DEFAULTS,
155
+ $ as DEFAULT_CARD_COMPOSITION,
156
+ g as default,
157
+ i as getDefaultProducts,
158
+ x as getDefaultTemplate,
159
+ f as prepareProductRows
160
+ };
@@ -0,0 +1,152 @@
1
+ import { prepareProductRows as n } from "./templateUtils.js";
2
+ import { DEFAULTS as i, getDefaultProducts as p } from "./templateUtils.js";
3
+ const a = `
4
+ <td
5
+ align="left"
6
+ esd-extension-block-id="recommendation-block"
7
+ esd-handler-name="esd-extension-RecommendationBlock"
8
+ class="ins-recommendation-v3-block-v2 esd-block-recommendation-v3-block esd-extension-block es-p20"
9
+ >
10
+ <table width="100%" cellpadding="0" cellspacing="0" border="0">
11
+ <tr>
12
+ <td align="center">
13
+ <table
14
+ class="container"
15
+ width="100%"
16
+ cellpadding="0"
17
+ cellspacing="0"
18
+ border="0">
19
+ <tbody>
20
+ <tr>
21
+ <td>
22
+ <table
23
+ width="100%"
24
+ cellpadding="0"
25
+ cellspacing="0"
26
+ border="0">
27
+ <tbody>
28
+ <tr>
29
+ {-{-TITLE-}-}
30
+ </tr>
31
+ </tbody>
32
+ </table>
33
+ </td>
34
+ </tr>
35
+ <tr>
36
+ <td class="spacer" style="height: 20px;"></td>
37
+ </tr>
38
+ <tr>
39
+ <td>
40
+ <table
41
+ class="ins-recommendation-product-container"
42
+ width="100%"
43
+ cellpadding="0"
44
+ cellspacing="0"
45
+ border="0"
46
+ >
47
+ {-{-PRODUCT_ROWS-}-}
48
+ </table>
49
+ </td>
50
+ </tr>
51
+ </tbody>
52
+ </table>
53
+ </td>
54
+ </tr>
55
+ </table>
56
+ </td>
57
+ `, l = {
58
+ productImage: (t) => `
59
+ <tr>
60
+ <td
61
+ class="esd-block-image product-image"
62
+ esd-extension-block-id="recommendation-block-image"
63
+ align="center"
64
+ style="font-size: 0px;">
65
+ <a target="_blank" href="${t.url}">
66
+ <img
67
+ src="${t.image_url}"
68
+ alt="${t.name}"
69
+ width="120"
70
+ style="display: block; max-width: 100%; height: auto;"
71
+ class="adapt-img">
72
+ </a>
73
+ </td>
74
+ </tr>
75
+ `,
76
+ productName: (t) => `
77
+ <tr>
78
+ <td
79
+ class="esd-block-text product-name"
80
+ esd-extension-block-id="recommendation-block-name"
81
+ align="center">
82
+ <p
83
+ path="1"
84
+ contenteditable="false"
85
+ style="font-size: 16px; color: #333333; font-weight: 600; text-align: center;">
86
+ <strong path="1,0">${t.name}</strong>
87
+ </p>
88
+ </td>
89
+ </tr>
90
+ `,
91
+ productPrice: () => `
92
+ <tr>
93
+ <td
94
+ class="esd-block-text product-price"
95
+ esd-extension-block-id="recommendation-block-price"
96
+ align="center">
97
+ <p
98
+ path="1"
99
+ contenteditable="false"
100
+ style="font-size: 16px; color: #333333; font-weight: bold; text-align: center;">
101
+ <strong path="1,0">18,00 TRY</strong>
102
+ </p>
103
+ </td>
104
+ </tr>
105
+ `,
106
+ productOldPrice: () => `
107
+ <tr>
108
+ <td
109
+ class="esd-block-text product-old-price"
110
+ esd-extension-block-id="recommendation-block-old-price"
111
+ align="center">
112
+ <p
113
+ path="1"
114
+ contenteditable="false"
115
+ style="font-size: 14px; color: #999999; text-decoration: line-through; text-align: center;">
116
+ <s path="1,0">20,00 TRY</s>
117
+ </p>
118
+ </td>
119
+ </tr>
120
+ `,
121
+ productButton: (t) => `
122
+ <tr>
123
+ <td
124
+ class="esd-block-button product-button"
125
+ esd-extension-block-id="recommendation-block-button"
126
+ align="center">
127
+ <span class="es-button-border" style="display: block;">
128
+ <a
129
+ href="${t.url}"
130
+ target="_blank"
131
+ class="es-button">
132
+ {-{-PRODUCT_BUTTON_TEXT-}-}
133
+ </a>
134
+ </span>
135
+ </td>
136
+ </tr>
137
+ `
138
+ };
139
+ function d(t, e, o) {
140
+ return n(
141
+ t,
142
+ e,
143
+ l,
144
+ o
145
+ );
146
+ }
147
+ export {
148
+ i as DEFAULTS,
149
+ a as default,
150
+ p as getDefaultProducts,
151
+ d as prepareProductRows
152
+ };
@@ -1,46 +1,47 @@
1
- import { ATTR_PRODUCT_IMAGE as s, ATTR_PRODUCT_NAME as n, ATTR_PRODUCT_OLD_PRICE as u, ATTR_PRODUCT_PRICE as m, ATTR_PRODUCT_OMNIBUS_PRICE as d, ATTR_PRODUCT_OMNIBUS_DISCOUNT as T, ATTR_PRODUCT_BUTTON as _ } from "../constants/selectors.js";
2
- const E = {
1
+ const R = {
3
2
  TITLE: "You May Also Like!"
4
- }, I = [
5
- s,
6
- n,
7
- u,
8
- m,
9
- d,
10
- T,
11
- _
12
- ], Y = {
13
- [s]: !0,
14
- [n]: !0,
15
- [m]: !0,
16
- [u]: !0,
17
- [d]: !1,
18
- [T]: !1,
19
- [_]: !0
20
- }, b = `
3
+ }, O = `
21
4
  <tr>
22
- <td class="spacer" style="height: 10px;"></td>
5
+ <td class="spacer" style="height: 20px;"></td>
23
6
  </tr>
24
- `, A = `
25
- <tr class="recommendation-product-row">
7
+ `, w = `
8
+ <tr>
26
9
  <td>
27
- <table width="100%" height="100%" cellpadding="0" cellspacing="0" border="0" class="product-card-wrapper">
28
- <tbody>
29
- {-{-ATTRIBUTE_ROWS-}-}
30
- </tbody>
10
+ <table width="100%" height="100%" cellpadding="0" cellspacing="0" border="0">
11
+ {-{-PRODUCTS-}-}
31
12
  </table>
32
13
  </td>
33
14
  </tr>
34
- `, w = `
35
- <tr
36
- class="recommendation-attribute-row"
37
- data-attribute-type="{-{-ATTR_TYPE-}-}"
38
- data-visibility="{-{-VISIBILITY-}-}"
39
- {-{-DISPLAY_STYLE-}-}>
40
- {-{-CELLS-}-}
41
- </tr>
42
- `;
43
- function L() {
15
+ `, i = `
16
+ <td width="{-{-COLUMN_WIDTH-}-}" style="padding: 0 5px;" valign="top" height="100%">
17
+ <table
18
+ width="100%"
19
+ height="100%"
20
+ cellpadding="0"
21
+ cellspacing="0"
22
+ border="0"
23
+ class="product-card-wrapper">
24
+ <tr>
25
+ <td
26
+ class="product-attribute-cell"
27
+ valign="top">
28
+ <table cellpadding="0" cellspacing="0" role="presentation" width="100%">
29
+ <tbody>
30
+ {-{-PRODUCT_CONTENT-}-}
31
+ </tbody>
32
+ </table>
33
+ </td>
34
+ </tr>
35
+ </table>
36
+ </td>
37
+ `, b = [
38
+ "productImage",
39
+ "productName",
40
+ "productOldPrice",
41
+ "productPrice",
42
+ "productButton"
43
+ ];
44
+ function C() {
44
45
  return [
45
46
  {
46
47
  name: "Product Name",
@@ -122,38 +123,58 @@ function L() {
122
123
  }
123
124
  ];
124
125
  }
125
- function S(r, e, o, l = I) {
126
- const i = (100 / e).toFixed(2);
127
- return l.filter((t) => o[t]).map((t) => {
128
- const c = Y[t] ?? !0, p = c ? "" : 'style="display: none;"', a = r.map((g) => {
129
- const h = o[t];
130
- return h(g).replace("<td", `<td width="${i}%"`);
131
- }).join("");
132
- return w.replace("{-{-ATTR_TYPE-}-}", t).replace("{-{-VISIBILITY-}-}", c ? "1" : "0").replace("{-{-DISPLAY_STYLE-}-}", p).replace("{-{-CELLS-}-}", a);
133
- }).join("");
126
+ function N(p, r, e, l = b) {
127
+ const n = (100 / r).toFixed(2), a = [];
128
+ for (let o = 0; o < p.length; o += r)
129
+ a.push(p.slice(o, o + r));
130
+ let c = "";
131
+ return a.forEach((o, _) => {
132
+ _ > 0 && (c += O);
133
+ let s = "", u = "", d = "", m = "", g = "";
134
+ o.forEach((t) => {
135
+ s += i.replace(
136
+ "{-{-PRODUCT_CONTENT-}-}",
137
+ e.productImage(t)
138
+ ), u += i.replace(
139
+ "{-{-PRODUCT_CONTENT-}-}",
140
+ e.productName(t)
141
+ ), d += i.replace(
142
+ "{-{-PRODUCT_CONTENT-}-}",
143
+ e.productPrice(t)
144
+ ), m += i.replace(
145
+ "{-{-PRODUCT_CONTENT-}-}",
146
+ e.productOldPrice(t)
147
+ ), g += i.replace(
148
+ "{-{-PRODUCT_CONTENT-}-}",
149
+ e.productButton(t)
150
+ );
151
+ });
152
+ const T = {
153
+ productImage: s,
154
+ productName: u,
155
+ productPrice: d,
156
+ productOldPrice: m,
157
+ productButton: g
158
+ }, h = l.filter((t) => !!T[t]).map((t) => `<tr>${T[t]}</tr>`).join("");
159
+ c += w.replace("{-{-PRODUCTS-}-}", h);
160
+ }), c.replaceAll("{-{-COLUMN_WIDTH-}-}", `${n}%`);
134
161
  }
135
- function O(r, e, o, l) {
136
- const i = [];
137
- for (let t = 0; t < r.length; t += e)
138
- i.push(r.slice(t, t + e));
139
- return i.map((t, c) => {
140
- const p = S(
141
- t,
142
- e,
143
- o,
144
- l
145
- ), a = A.replace("{-{-ATTRIBUTE_ROWS-}-}", p);
146
- return c > 0 ? b + a : a;
147
- }).join("");
162
+ function P(p, r, e, l, n = R.TITLE, a) {
163
+ const c = N(
164
+ r,
165
+ e,
166
+ l,
167
+ a
168
+ );
169
+ return p.replace("{-{-TITLE-}-}", n).replace("{-{-PRODUCT_ROWS-}-}", c);
148
170
  }
149
171
  export {
150
- E as DEFAULTS,
151
- I as DEFAULT_CARD_COMPOSITION,
152
- Y as DEFAULT_CARD_VISIBILITY,
153
- w as attributeRowTemplate,
154
- L as getDefaultProducts,
155
- S as prepareVerticalAttributeRows,
156
- O as prepareVerticalProductRows,
157
- b as spacer,
158
- A as verticalProductRowWrapper
172
+ R as DEFAULTS,
173
+ b as DEFAULT_CARD_COMPOSITION,
174
+ P as generateTemplate,
175
+ C as getDefaultProducts,
176
+ N as prepareProductRows,
177
+ i as productCardWrapper,
178
+ w as productRow,
179
+ O as spacer
159
180
  };