@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
@@ -1,13 +1,14 @@
1
- import { RecommendationFeedSourceMaps as n, PriceAttributes as u } from "../../../../enums/extensions/recommendationBlock.js";
2
- import { useRecommendationApi as l } from "../../../../services/recommendationApi.js";
3
- import { useConfigStore as c } from "../../../../stores/config.js";
4
- import { defineStore as p } from "pinia";
5
- import { generateCompleteFilterQuery as m } from "../utils/filterUtil.js";
6
- const a = l(), d = () => ({
1
+ import { RecommendationFeedSourceMaps as u, PriceAttributes as c } from "../../../../enums/extensions/recommendationBlock.js";
2
+ import { useRecommendationApi as p } from "../../../../services/recommendationApi.js";
3
+ import { useConfigStore as m } from "../../../../stores/config.js";
4
+ import { defineStore as f } from "pinia";
5
+ import { DEFAULT_CARDS_IN_ROW as d } from "../constants/layout.js";
6
+ import { generateCompleteFilterQuery as l } from "../utils/filterUtil.js";
7
+ const s = p(), g = () => ({
7
8
  recommendationCampaignUrls: {},
8
9
  recommendationProducts: [],
9
10
  recommendationConfigs: {
10
- cardsInRow: 3,
11
+ cardsInRow: d,
11
12
  currencySettings: {
12
13
  name: "USD",
13
14
  value: "USD",
@@ -134,8 +135,8 @@ const a = l(), d = () => ({
134
135
  filterSelectionDrawerStatus: !1,
135
136
  filterList: {},
136
137
  filterGroup: 1
137
- }), y = p("guidoRecommendationExtension", {
138
- state: () => d(),
138
+ }), S = f("guidoRecommendationExtension", {
139
+ state: () => g(),
139
140
  getters: {
140
141
  hasFilters: (e) => !!e.recommendationConfigs.filters.length,
141
142
  getFilterGroupCount: (e) => {
@@ -145,7 +146,7 @@ const a = l(), d = () => ({
145
146
  getActivePredictiveAlgorithms: (e) => {
146
147
  const t = [];
147
148
  return e.activePredictiveAlgorithms.forEach((r) => {
148
- t.push(...n.filter((i) => i.id === r));
149
+ t.push(...u.filter((i) => i.id === r));
149
150
  }), t.map((r) => ({
150
151
  text: r.name,
151
152
  value: r.key
@@ -160,7 +161,7 @@ const a = l(), d = () => ({
160
161
  value: t.text
161
162
  })),
162
163
  getFilterList: (e) => Object.values(e.filterList).map((t) => {
163
- const r = t.type === "defaultAttribute", i = u.includes(t.attributeName);
164
+ const r = t.type === "defaultAttribute", i = c.includes(t.attributeName);
164
165
  let o = r ? t.attributeName : `product_attributes.${t.attributeName}`;
165
166
  return o = i ? `${o}.${e.recommendationConfigs.currencySettings.value}` : o, {
166
167
  text: t.displayName,
@@ -178,13 +179,13 @@ const a = l(), d = () => ({
178
179
  activePredictiveAlgorithms: e,
179
180
  languages: t,
180
181
  currencies: r
181
- } = await a.fetchRecommendationCreateData();
182
+ } = await s.fetchRecommendationCreateData();
182
183
  this.activePredictiveAlgorithms = e, this.languages = t;
183
184
  const [i] = r;
184
185
  this.recommendationConfigs.currencySettings.name = i.text, this.recommendationConfigs.currencySettings.value = i.value, this.currencyList = r, this.filterStatus = !!this.recommendationConfigs.filters.length;
185
186
  },
186
187
  async fetchRecommendationFilters() {
187
- const e = await a.fetchRecommendationFilters();
188
+ const e = await s.fetchRecommendationFilters();
188
189
  this.filterList = e;
189
190
  },
190
191
  addFilterGroup(e) {
@@ -224,13 +225,15 @@ const a = l(), d = () => ({
224
225
  }
225
226
  },
226
227
  addFilter(e) {
227
- const t = [...this.recommendationConfigs.filters], r = t.findLastIndex((i) => i.filterGroup === e.filterGroup);
228
- r !== -1 ? t.splice(r + 1, 0, {
228
+ const t = [...this.recommendationConfigs.filters], i = t.filter(
229
+ (a) => a.filterGroup === e.filterGroup
230
+ ).length + 1, o = t.findLastIndex((a) => a.filterGroup === e.filterGroup);
231
+ o !== -1 ? t.splice(o + 1, 0, {
229
232
  ...e,
230
- filterNumber: r + 2
233
+ filterNumber: i
231
234
  }) : t.push({
232
235
  ...e,
233
- filterNumber: 1
236
+ filterNumber: i
234
237
  }), this.$patch({
235
238
  recommendationConfigs: {
236
239
  filters: t
@@ -238,30 +241,30 @@ const a = l(), d = () => ({
238
241
  });
239
242
  },
240
243
  generateFilterQuery() {
241
- return m(this.recommendationConfigs.filters);
244
+ return l(this.recommendationConfigs.filters);
242
245
  },
243
246
  async fetchRecommendationProducts() {
244
- var o;
245
- const e = this.generateFilterQuery(), t = ((o = n.find((s) => s.key === this.recommendationConfigs.strategy)) == null ? void 0 : o.path) || "", r = c(), i = await a.fetchRecommendationProducts(
246
- t,
247
+ var a;
248
+ const e = this.recommendationConfigs.filters.filter((n) => n.isValid), t = l(e), r = ((a = u.find((n) => n.key === this.recommendationConfigs.strategy)) == null ? void 0 : a.path) || "", i = m(), o = await s.fetchRecommendationProducts(
249
+ r,
247
250
  {
248
- // TODO: Here will be optimized and filled carefully
251
+ // Note: {itemId} and {campaignId} are template placeholders replaced at runtime
249
252
  locale: this.recommendationConfigs.language,
250
253
  currency: this.recommendationConfigs.currencySettings.value,
251
- partnerName: r.partnerName,
254
+ partnerName: i.partnerName,
252
255
  productId: this.recommendationConfigs.strategy === "manualMerchandising" ? this.recommendationConfigs.productIds.join(",") : "{itemId}",
253
256
  size: this.recommendationConfigs.size,
254
257
  details: !0,
255
258
  campaignId: "{campaignId}",
256
- filter: e
259
+ filter: t
257
260
  }
258
261
  );
259
262
  this.$patch({
260
- recommendationProducts: i
263
+ recommendationProducts: o
261
264
  });
262
265
  }
263
266
  }
264
267
  });
265
268
  export {
266
- y as useRecommendationExtensionStore
269
+ S as useRecommendationExtensionStore
267
270
  };
@@ -0,0 +1,157 @@
1
+ import { RecommendationBlockId as e } from "../../constants/blockIds.js";
2
+ import { ATTR_PRODUCT_BUTTON as a, ATTR_PRODUCT_IMAGE as s, ATTR_PRODUCT_OMNIBUS_DISCOUNT as o, ATTR_PRODUCT_OMNIBUS_PRICE as n, ATTR_PRODUCT_OLD_PRICE as l, ATTR_PRODUCT_PRICE as i, ATTR_PRODUCT_NAME as r } from "../../constants/selectors.js";
3
+ const p = {
4
+ /**
5
+ * Image cell - left column (120px fixed width)
6
+ * Has recommendation-attribute-row class and data attributes for Card Composition control
7
+ */
8
+ [s]: (t) => `
9
+ <td
10
+ width="120"
11
+ class="esd-block-image product-image-cell recommendation-attribute-row es-p5"
12
+ esd-extension-block-id="${e.IMAGE}"
13
+ data-attribute-type="${s}"
14
+ data-visibility="1"
15
+ align=center
16
+ valign="middle">
17
+ <a target="_blank" href="${t.url}">
18
+ <img
19
+ src="${t.image_url}"
20
+ alt="${t.name}"
21
+ style="display: block; max-width: 100%;"
22
+ class="adapt-img product-image">
23
+ </a>
24
+ </td>
25
+ `,
26
+ /**
27
+ * Name element - row for info cell table
28
+ */
29
+ [r]: (t) => `
30
+ <tr>
31
+ <td
32
+ class="esd-block-text product-name"
33
+ esd-extension-block-id="${e.NAME}"
34
+ align="left">
35
+ <p
36
+ path="1"
37
+ contenteditable="false"
38
+ style="font-size: 16px; color: #333333; font-weight: 600; margin: 0;">
39
+ <strong path="1,0">${t.name}</strong>
40
+ </p>
41
+ </td>
42
+ </tr>
43
+ `,
44
+ /**
45
+ * Price element - row for info cell table
46
+ */
47
+ [i]: () => `
48
+ <tr>
49
+ <td
50
+ class="esd-block-text product-price"
51
+ esd-extension-block-id="${e.PRICE}"
52
+ align="left">
53
+ <p
54
+ path="1"
55
+ contenteditable="false"
56
+ style="font-size: 16px; color: #333333; font-weight: bold; margin: 0;">
57
+ <strong path="1,0">18,00 TRY</strong>
58
+ </p>
59
+ </td>
60
+ </tr>
61
+ `,
62
+ /**
63
+ * Old price element - row for info cell table
64
+ */
65
+ [l]: () => `
66
+ <tr>
67
+ <td
68
+ class="esd-block-text product-old-price"
69
+ esd-extension-block-id="${e.OLD_PRICE}"
70
+ align="left">
71
+ <p
72
+ path="1"
73
+ contenteditable="false"
74
+ style="font-size: 14px; color: #999999; text-decoration: line-through; margin: 0;">
75
+ <s path="1,0">20,00 TRY</s>
76
+ </p>
77
+ </td>
78
+ </tr>
79
+ `,
80
+ /**
81
+ * Omnibus price element - row for info cell table
82
+ */
83
+ [n]: () => `
84
+ <tr>
85
+ <td
86
+ class="esd-block-text product-omnibus-price"
87
+ data-text-before="Lowest 30-day price: "
88
+ data-text-after=""
89
+ esd-extension-block-id="${e.OMNIBUS_PRICE}"
90
+ align="left">
91
+ <p
92
+ path="1"
93
+ contenteditable="false"
94
+ style="font-size: 12px; color: #666666; margin: 0;">
95
+ <span class="omnibus-text-before">Lowest 30-day price: </span>
96
+ <span class="omnibus-price-value">17,00 TRY</span>
97
+ <span class="omnibus-text-after"></span>
98
+ </p>
99
+ </td>
100
+ </tr>
101
+ `,
102
+ /**
103
+ * Omnibus discount element - row for info cell table
104
+ */
105
+ [o]: () => `
106
+ <tr>
107
+ <td
108
+ class="esd-block-text product-omnibus-discount"
109
+ data-text-before=""
110
+ data-text-after=""
111
+ esd-extension-block-id="${e.OMNIBUS_DISCOUNT}"
112
+ align="left">
113
+ <p
114
+ path="1"
115
+ contenteditable="false"
116
+ style="font-size: 12px; color: #666666; margin: 0;">
117
+ <span class="omnibus-text-before"></span>
118
+ <span class="omnibus-discount-value">-6%</span>
119
+ <span class="omnibus-text-after"></span>
120
+ </p>
121
+ </td>
122
+ </tr>
123
+ `,
124
+ /**
125
+ * Button cell - right column (100px fixed width)
126
+ * Has recommendation-attribute-row class and data attributes for Card Composition control
127
+ */
128
+ [a]: (t) => `
129
+ <td
130
+ width="100"
131
+ class="esd-block-button button-cell recommendation-attribute-row product-button es-p5l es-p5r"
132
+ esd-extension-block-id="${e.BUTTON}"
133
+ data-attribute-type="${a}"
134
+ data-visibility="1"
135
+ align="center"
136
+ valign="middle">
137
+ <span
138
+ class="es-button-border"
139
+ style="
140
+ border-width: 1px;
141
+ background: rgb(217, 234, 211);
142
+ border-color: rgb(106, 168, 79);
143
+ ">
144
+ <a
145
+ href="${t.url}"
146
+ target="_blank"
147
+ class="es-button buy-button"
148
+ style="color: rgb(56, 118, 29); background: rgb(217, 234, 211); padding: 5px 30px;">
149
+ Buy
150
+ </a>
151
+ </span>
152
+ </td>
153
+ `
154
+ };
155
+ export {
156
+ p as horizontalElementRenderer
157
+ };
@@ -0,0 +1,72 @@
1
+ import { ATTR_PRODUCT_IMAGE as g, ATTR_PRODUCT_NAME as s, ATTR_PRODUCT_OLD_PRICE as c, ATTR_PRODUCT_PRICE as a, ATTR_PRODUCT_OMNIBUS_PRICE as d, ATTR_PRODUCT_OMNIBUS_DISCOUNT as T, ATTR_PRODUCT_BUTTON as E } from "../../constants/selectors.js";
2
+ import { spacer as N, DEFAULT_CARD_VISIBILITY as n } from "../utils.js";
3
+ import { horizontalElementRenderer as o } from "./elementRenderer.js";
4
+ const $ = `
5
+ <tr class="recommendation-product-row">
6
+ <td style="padding: 0 5px;">
7
+ <table
8
+ width="100%"
9
+ cellpadding="0"
10
+ cellspacing="0"
11
+ border="0"
12
+ class="product-card-wrapper"
13
+ style="background-color: #f8f8f8;">
14
+ <tr>
15
+ {-{-PRODUCT_CONTENT-}-}
16
+ </tr>
17
+ </table>
18
+ </td>
19
+ </tr>
20
+ `;
21
+ function V(t) {
22
+ const i = o[g](t), l = n[s], r = n[c], R = n[a], C = n[d], b = n[T], e = (y, A, p) => {
23
+ const I = p ? "" : ' style="display: none;"', f = y.replace(/<tr>/, "").replace(/<\/tr>/, "");
24
+ return `<tr
25
+ class="recommendation-attribute-row"
26
+ data-attribute-type="${A}"
27
+ data-visibility="${p ? "1" : "0"}"${I}>${f}</tr>`;
28
+ }, m = e(
29
+ o[s](t),
30
+ s,
31
+ l
32
+ ), _ = e(
33
+ o[c](t),
34
+ c,
35
+ r
36
+ ), u = e(
37
+ o[a](t),
38
+ a,
39
+ R
40
+ ), O = e(
41
+ o[d](t),
42
+ d,
43
+ C
44
+ ), P = e(
45
+ o[T](t),
46
+ T,
47
+ b
48
+ ), D = `
49
+ <td class="product-info-cell" valign="middle" style="padding: 15px;">
50
+ <table cellpadding="0" cellspacing="0" role="presentation" width="100%">
51
+ <tbody>
52
+ ${m}
53
+ ${_}
54
+ ${u}
55
+ ${O}
56
+ ${P}
57
+ </tbody>
58
+ </table>
59
+ </td>
60
+ `, U = o[E](t), w = i + D + U;
61
+ return $.replace("{-{-PRODUCT_CONTENT-}-}", w);
62
+ }
63
+ function M(t) {
64
+ return t.map((i, l) => {
65
+ const r = V(i);
66
+ return l > 0 ? N + r : r;
67
+ }).join("");
68
+ }
69
+ export {
70
+ V as getHorizontalProductCard,
71
+ M as prepareProductRows
72
+ };
@@ -0,0 +1,12 @@
1
+ import { DEFAULT_PRODUCTS_PER_ROW as s } from "../constants/layout.js";
2
+ import { prepareProductRows as R } from "./horizontal/template.js";
3
+ import { prepareProductRows as a } from "./vertical/template.js";
4
+ function P(r, o, p = {}) {
5
+ if (o === "horizontal")
6
+ return R(r);
7
+ const { productsPerRow: t = s, composition: e } = p;
8
+ return a(r, t, e);
9
+ }
10
+ export {
11
+ P as prepareProductRows
12
+ };
@@ -0,0 +1,173 @@
1
+ import { ATTR_PRODUCT_IMAGE as t, ATTR_PRODUCT_NAME as e, ATTR_PRODUCT_OLD_PRICE as o, ATTR_PRODUCT_PRICE as r, ATTR_PRODUCT_OMNIBUS_PRICE as i, ATTR_PRODUCT_OMNIBUS_DISCOUNT as c, ATTR_PRODUCT_BUTTON as a } from "../constants/selectors.js";
2
+ const d = {
3
+ TITLE: "You May Also Like!"
4
+ }, u = [
5
+ t,
6
+ e,
7
+ o,
8
+ r,
9
+ i,
10
+ c,
11
+ a
12
+ ], m = {
13
+ [t]: !0,
14
+ [e]: !0,
15
+ [r]: !0,
16
+ [o]: !0,
17
+ [i]: !1,
18
+ [c]: !1,
19
+ [a]: !0
20
+ }, n = `
21
+ <tr>
22
+ <td class="spacer" style="height: 10px;"></td>
23
+ </tr>
24
+ `;
25
+ function _() {
26
+ return [
27
+ {
28
+ name: "Product Name",
29
+ image_url: "https://email-static.useinsider.com/stripo/modules/email-recommendation-v3/assets/images/image-placeholder.png",
30
+ price: { USD: 18 },
31
+ original_price: { USD: 20 },
32
+ discount: { USD: 2 },
33
+ url: "https://example.com/product/1",
34
+ item_id: "1",
35
+ in_stock: 1,
36
+ locale: "en",
37
+ product_attributes: {},
38
+ category: []
39
+ },
40
+ {
41
+ name: "Belt",
42
+ image_url: "https://inshoppingcart.com/ins-html/wp-content/uploads/2018/09/belt-2.jpg",
43
+ price: { TRY: 55 },
44
+ original_price: { TRY: 65 },
45
+ discount: { TRY: 10 },
46
+ url: "https://example.com/product/2",
47
+ item_id: "2",
48
+ in_stock: 1,
49
+ locale: "tr",
50
+ product_attributes: {},
51
+ category: []
52
+ },
53
+ {
54
+ name: "Beanie",
55
+ image_url: "https://inshoppingcart.com/ins-html/wp-content/uploads/2018/08/beanie-with-logo-1.jpg",
56
+ price: { TRY: 18 },
57
+ original_price: { TRY: 20 },
58
+ discount: { TRY: 2 },
59
+ url: "https://example.com/product/3",
60
+ item_id: "3",
61
+ in_stock: 1,
62
+ locale: "tr",
63
+ product_attributes: {},
64
+ category: []
65
+ },
66
+ {
67
+ name: "Album",
68
+ image_url: "https://inshoppingcart.com/ins-html/wp-content/uploads/2018/12/poster_2_up.jpg",
69
+ price: { TRY: 15 },
70
+ original_price: { TRY: 15 },
71
+ discount: { TRY: 0 },
72
+ url: "https://example.com/product/4",
73
+ item_id: "4",
74
+ in_stock: 1,
75
+ locale: "tr",
76
+ product_attributes: {},
77
+ category: []
78
+ },
79
+ {
80
+ name: "Flying Ninja with a very long product name",
81
+ image_url: "https://inshoppingcart.com/ins-html/wp-content/uploads/2018/09/belt-2.jpg",
82
+ price: { TRY: 12 },
83
+ original_price: { TRY: 15 },
84
+ discount: { TRY: 3 },
85
+ url: "https://example.com/product/5",
86
+ item_id: "5",
87
+ in_stock: 1,
88
+ locale: "tr",
89
+ product_attributes: {},
90
+ category: []
91
+ },
92
+ {
93
+ name: "Single",
94
+ image_url: "https://inshoppingcart.com/ins-html/wp-content/uploads/2018/12/poster_2_up.jpg",
95
+ price: { TRY: 22555 },
96
+ original_price: { TRY: 33989 },
97
+ discount: { TRY: 11434 },
98
+ url: "https://example.com/product/6",
99
+ item_id: "6",
100
+ in_stock: 1,
101
+ locale: "tr",
102
+ product_attributes: {},
103
+ category: []
104
+ }
105
+ ];
106
+ }
107
+ function g(l = "vertical") {
108
+ return `
109
+ <td
110
+ align="left"
111
+ class="ins-recommendation-v3-block-v2 esd-block-recommendation-v3-block es-p20"${l === "horizontal" ? `
112
+ data-layout="horizontal"` : ""}>
113
+ <table width="100%" cellpadding="0" cellspacing="0" border="0">
114
+ <tr>
115
+ <td align="center">
116
+ <table
117
+ class="container"
118
+ width="100%"
119
+ cellpadding="0"
120
+ cellspacing="0"
121
+ border="0">
122
+ <tbody>
123
+ <tr>
124
+ <td>
125
+ <table
126
+ width="100%"
127
+ cellpadding="0"
128
+ cellspacing="0"
129
+ border="0">
130
+ <tbody>
131
+ <tr>
132
+ <td
133
+ class="esd-block-text es-p10t es-p10b es-p20l es-p20r"
134
+ align="center">
135
+ <p path="1" style="font-size: 28px; color: #333333;">
136
+ <strong path="1,0">{-{-TITLE-}-}</strong>
137
+ </p>
138
+ </td>
139
+ </tr>
140
+ </tbody>
141
+ </table>
142
+ </td>
143
+ </tr>
144
+ ${n}
145
+ <tr>
146
+ <td>
147
+ <table
148
+ class="ins-recommendation-product-container"
149
+ width="100%"
150
+ cellpadding="0"
151
+ cellspacing="0"
152
+ border="0"
153
+ >
154
+ {-{-PRODUCT_ROWS-}-}
155
+ </table>
156
+ </td>
157
+ </tr>
158
+ </tbody>
159
+ </table>
160
+ </td>
161
+ </tr>
162
+ </table>
163
+ </td>
164
+ `;
165
+ }
166
+ export {
167
+ d as DEFAULTS,
168
+ u as DEFAULT_CARD_COMPOSITION,
169
+ m as DEFAULT_CARD_VISIBILITY,
170
+ g as createBlockTemplate,
171
+ _ as getDefaultProducts,
172
+ n as spacer
173
+ };