@useinsider/guido 2.1.0-beta.6df87d7 → 2.1.0-beta.76217f3

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 (145) hide show
  1. package/README.md +36 -0
  2. package/dist/@types/config/schemas.js +70 -65
  3. package/dist/components/Guido.vue.js +1 -1
  4. package/dist/components/Guido.vue2.js +69 -58
  5. package/dist/components/organisms/extensions/recommendation/FilterSelectionDrawer.vue2.js +14 -15
  6. package/dist/composables/useBlocksConfig.js +26 -16
  7. package/dist/composables/useHtmlValidator.js +84 -106
  8. package/dist/composables/useRecommendation.js +21 -54
  9. package/dist/config/compiler/recommendationCompilerRules.js +39 -45
  10. package/dist/config/migrator/recommendationMigrator.js +2 -2
  11. package/dist/enums/defaults.js +8 -4
  12. package/dist/enums/extensions/recommendationBlock.js +1 -1
  13. package/dist/enums/recommendation.js +15 -16
  14. package/dist/extensions/Blocks/Recommendation/block.js +9 -133
  15. package/dist/extensions/Blocks/Recommendation/cardCompositionControl.js +187 -0
  16. package/dist/extensions/Blocks/Recommendation/constants.js +13 -0
  17. package/dist/extensions/Blocks/Recommendation/control.js +336 -0
  18. package/dist/extensions/Blocks/Recommendation/controls/cardBackgroundColorControl.js +68 -0
  19. package/dist/extensions/Blocks/Recommendation/controls/index.js +245 -0
  20. package/dist/extensions/Blocks/Recommendation/controls/nameTextTrimControl.js +74 -0
  21. package/dist/extensions/Blocks/Recommendation/controls/{omnibusDiscount/textAfter.js → omnibusDiscountTextAfterControl.js} +14 -16
  22. package/dist/extensions/Blocks/Recommendation/controls/{omnibusDiscount/textBefore.js → omnibusDiscountTextBeforeControl.js} +14 -16
  23. package/dist/extensions/Blocks/Recommendation/controls/{omnibusPrice/textAfter.js → omnibusPriceTextAfterControl.js} +14 -16
  24. package/dist/extensions/Blocks/Recommendation/controls/{omnibusPrice/textBefore.js → omnibusPriceTextBeforeControl.js} +12 -14
  25. package/dist/extensions/Blocks/Recommendation/controls/spacingControl.js +188 -0
  26. package/dist/extensions/Blocks/Recommendation/extension.js +17 -40
  27. package/dist/extensions/Blocks/Recommendation/iconsRegistry.js +3 -19
  28. package/dist/extensions/Blocks/Recommendation/recommendation.css.js +4 -13
  29. package/dist/extensions/Blocks/Recommendation/settingsPanel.js +10 -21
  30. package/dist/extensions/Blocks/Recommendation/store/recommendation.js +207 -256
  31. package/dist/extensions/Blocks/Recommendation/templates/blockTemplate.js +181 -0
  32. package/dist/extensions/Blocks/Recommendation/templates/migrationTemplate.js +189 -0
  33. package/dist/extensions/Blocks/Recommendation/templates/templateUtils.js +209 -0
  34. package/dist/extensions/Blocks/Recommendation/utils/filterUtil.js +9 -9
  35. package/dist/extensions/Blocks/Recommendation/utils/preserveTextStyles.js +15 -26
  36. package/dist/extensions/Blocks/controlFactories.js +93 -125
  37. package/dist/extensions/ModulesTabIcons/extension.js +17 -0
  38. package/dist/guido.css +1 -1
  39. package/dist/node_modules/@stripoinc/ui-editor-extensions/dist/esm/index.js +237 -225
  40. package/dist/services/recommendationApi.js +8 -11
  41. package/dist/services/templateLibraryApi.js +13 -16
  42. package/dist/src/@types/config/schemas.d.ts +8 -0
  43. package/dist/src/components/wrappers/WpDrawer.vue.d.ts +1 -1
  44. package/dist/src/composables/useConfig.d.ts +4 -0
  45. package/dist/src/composables/useRecommendation.d.ts +0 -1
  46. package/dist/src/enums/defaults.d.ts +4 -0
  47. package/dist/src/extensions/Blocks/Recommendation/block.d.ts +0 -67
  48. package/dist/src/extensions/Blocks/Recommendation/{controls/cardComposition/index.d.ts → cardCompositionControl.d.ts} +3 -23
  49. package/dist/src/extensions/Blocks/Recommendation/{constants/controlIds.d.ts → constants.d.ts} +24 -0
  50. package/dist/src/extensions/Blocks/Recommendation/control.d.ts +38 -0
  51. package/dist/src/extensions/Blocks/Recommendation/controls/index.d.ts +589 -21
  52. package/dist/src/extensions/Blocks/Recommendation/controls/nameTextTrimControl.d.ts +16 -0
  53. package/dist/src/extensions/Blocks/Recommendation/extension.d.ts +0 -9
  54. package/dist/src/extensions/Blocks/Recommendation/store/recommendation.d.ts +468 -138
  55. package/dist/src/extensions/Blocks/Recommendation/templates/blockTemplate.d.ts +16 -0
  56. package/dist/src/extensions/Blocks/Recommendation/templates/{grid/migration.d.ts → migrationTemplate.d.ts} +4 -11
  57. package/dist/src/extensions/Blocks/Recommendation/templates/templateUtils.d.ts +52 -0
  58. package/dist/src/extensions/ModulesTabIcons/extension.d.ts +2 -0
  59. package/dist/src/stores/config.d.ts +36 -0
  60. package/dist/static/styles/customEditorStyle.css.js +11 -35
  61. package/dist/utils/pairProductVariables.js +56 -57
  62. package/dist/utils/templatePreparation.js +14 -15
  63. package/package.json +1 -1
  64. package/dist/config/compiler/utils/recommendationCompilerUtils.js +0 -116
  65. package/dist/extensions/Blocks/Recommendation/constants/blockIds.js +0 -4
  66. package/dist/extensions/Blocks/Recommendation/constants/controlIds.js +0 -4
  67. package/dist/extensions/Blocks/Recommendation/constants/defaultConfig.js +0 -66
  68. package/dist/extensions/Blocks/Recommendation/constants/layout.js +0 -22
  69. package/dist/extensions/Blocks/Recommendation/constants/selectors.js +0 -21
  70. package/dist/extensions/Blocks/Recommendation/controls/button/index.js +0 -64
  71. package/dist/extensions/Blocks/Recommendation/controls/cardBackground/index.js +0 -80
  72. package/dist/extensions/Blocks/Recommendation/controls/cardComposition/index.js +0 -232
  73. package/dist/extensions/Blocks/Recommendation/controls/image/index.js +0 -19
  74. package/dist/extensions/Blocks/Recommendation/controls/layout/index.js +0 -92
  75. package/dist/extensions/Blocks/Recommendation/controls/main/algorithm.js +0 -102
  76. package/dist/extensions/Blocks/Recommendation/controls/main/currency.js +0 -209
  77. package/dist/extensions/Blocks/Recommendation/controls/main/filters.js +0 -52
  78. package/dist/extensions/Blocks/Recommendation/controls/main/index.js +0 -218
  79. package/dist/extensions/Blocks/Recommendation/controls/main/locale.js +0 -70
  80. package/dist/extensions/Blocks/Recommendation/controls/main/productLayout.js +0 -160
  81. package/dist/extensions/Blocks/Recommendation/controls/main/shuffle.js +0 -67
  82. package/dist/extensions/Blocks/Recommendation/controls/main/utils.js +0 -307
  83. package/dist/extensions/Blocks/Recommendation/controls/mobileLayout/cssRules.js +0 -21
  84. package/dist/extensions/Blocks/Recommendation/controls/name/index.js +0 -46
  85. package/dist/extensions/Blocks/Recommendation/controls/name/textTrim.js +0 -108
  86. package/dist/extensions/Blocks/Recommendation/controls/oldPrice/index.js +0 -44
  87. package/dist/extensions/Blocks/Recommendation/controls/omnibusDiscount/index.js +0 -48
  88. package/dist/extensions/Blocks/Recommendation/controls/omnibusPrice/index.js +0 -48
  89. package/dist/extensions/Blocks/Recommendation/controls/price/index.js +0 -44
  90. package/dist/extensions/Blocks/Recommendation/controls/spacing/index.js +0 -222
  91. package/dist/extensions/Blocks/Recommendation/services/configService.js +0 -240
  92. package/dist/extensions/Blocks/Recommendation/templates/grid/elementRenderer.js +0 -233
  93. package/dist/extensions/Blocks/Recommendation/templates/grid/migration.js +0 -251
  94. package/dist/extensions/Blocks/Recommendation/templates/grid/template.js +0 -66
  95. package/dist/extensions/Blocks/Recommendation/templates/index.js +0 -12
  96. package/dist/extensions/Blocks/Recommendation/templates/list/elementRenderer.js +0 -174
  97. package/dist/extensions/Blocks/Recommendation/templates/list/template.js +0 -73
  98. package/dist/extensions/Blocks/Recommendation/templates/utils.js +0 -134
  99. package/dist/extensions/Blocks/Recommendation/types/nodeConfig.js +0 -6
  100. package/dist/extensions/Blocks/Recommendation/utils/priceFormatter.js +0 -29
  101. package/dist/extensions/Blocks/Recommendation/utils/tagName.js +0 -46
  102. package/dist/src/config/compiler/utils/recommendationCompilerUtils.d.ts +0 -17
  103. package/dist/src/extensions/Blocks/Recommendation/constants/blockIds.d.ts +0 -13
  104. package/dist/src/extensions/Blocks/Recommendation/constants/defaultConfig.d.ts +0 -49
  105. package/dist/src/extensions/Blocks/Recommendation/constants/index.d.ts +0 -13
  106. package/dist/src/extensions/Blocks/Recommendation/constants/layout.d.ts +0 -41
  107. package/dist/src/extensions/Blocks/Recommendation/constants/selectors.d.ts +0 -35
  108. package/dist/src/extensions/Blocks/Recommendation/controls/button/index.d.ts +0 -143
  109. package/dist/src/extensions/Blocks/Recommendation/controls/cardBackground/index.d.ts +0 -31
  110. package/dist/src/extensions/Blocks/Recommendation/controls/image/index.d.ts +0 -35
  111. package/dist/src/extensions/Blocks/Recommendation/controls/layout/index.d.ts +0 -37
  112. package/dist/src/extensions/Blocks/Recommendation/controls/main/algorithm.d.ts +0 -29
  113. package/dist/src/extensions/Blocks/Recommendation/controls/main/currency.d.ts +0 -52
  114. package/dist/src/extensions/Blocks/Recommendation/controls/main/filters.d.ts +0 -22
  115. package/dist/src/extensions/Blocks/Recommendation/controls/main/index.d.ts +0 -67
  116. package/dist/src/extensions/Blocks/Recommendation/controls/main/locale.d.ts +0 -24
  117. package/dist/src/extensions/Blocks/Recommendation/controls/main/productLayout.d.ts +0 -60
  118. package/dist/src/extensions/Blocks/Recommendation/controls/main/shuffle.d.ts +0 -23
  119. package/dist/src/extensions/Blocks/Recommendation/controls/main/utils.d.ts +0 -221
  120. package/dist/src/extensions/Blocks/Recommendation/controls/mobileLayout/cssRules.d.ts +0 -29
  121. package/dist/src/extensions/Blocks/Recommendation/controls/name/index.d.ts +0 -97
  122. package/dist/src/extensions/Blocks/Recommendation/controls/name/textTrim.d.ts +0 -34
  123. package/dist/src/extensions/Blocks/Recommendation/controls/oldPrice/index.d.ts +0 -95
  124. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusDiscount/index.d.ts +0 -100
  125. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusDiscount/textAfter.d.ts +0 -15
  126. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusDiscount/textBefore.d.ts +0 -15
  127. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusPrice/index.d.ts +0 -100
  128. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusPrice/textAfter.d.ts +0 -15
  129. package/dist/src/extensions/Blocks/Recommendation/controls/omnibusPrice/textBefore.d.ts +0 -15
  130. package/dist/src/extensions/Blocks/Recommendation/controls/price/index.d.ts +0 -95
  131. package/dist/src/extensions/Blocks/Recommendation/controls/spacing/index.d.ts +0 -83
  132. package/dist/src/extensions/Blocks/Recommendation/services/configService.d.ts +0 -151
  133. package/dist/src/extensions/Blocks/Recommendation/services/index.d.ts +0 -6
  134. package/dist/src/extensions/Blocks/Recommendation/templates/grid/elementRenderer.d.ts +0 -20
  135. package/dist/src/extensions/Blocks/Recommendation/templates/grid/template.d.ts +0 -33
  136. package/dist/src/extensions/Blocks/Recommendation/templates/index.d.ts +0 -41
  137. package/dist/src/extensions/Blocks/Recommendation/templates/list/elementRenderer.d.ts +0 -8
  138. package/dist/src/extensions/Blocks/Recommendation/templates/list/migration.d.ts +0 -25
  139. package/dist/src/extensions/Blocks/Recommendation/templates/list/template.d.ts +0 -18
  140. package/dist/src/extensions/Blocks/Recommendation/templates/utils.d.ts +0 -66
  141. package/dist/src/extensions/Blocks/Recommendation/types/index.d.ts +0 -7
  142. package/dist/src/extensions/Blocks/Recommendation/types/nodeConfig.d.ts +0 -166
  143. package/dist/src/extensions/Blocks/Recommendation/utils/priceFormatter.d.ts +0 -33
  144. package/dist/src/extensions/Blocks/Recommendation/utils/stylePreserver.d.ts +0 -113
  145. package/dist/src/extensions/Blocks/Recommendation/utils/tagName.d.ts +0 -77
@@ -1,27 +1,17 @@
1
1
  import { SettingsPanelRegistry as S, SettingsPanelTab as I, SettingsTab as T, ContainerControls as E, TextControls as C } from "../../../node_modules/@stripoinc/ui-editor-extensions/dist/esm/index.js";
2
2
  import { BLOCK_ID as R } from "./block.js";
3
- import { RecommendationBlockId as N } from "./constants/blockIds.js";
4
- import { RecommendationControlId as _ } from "./constants/controlIds.js";
5
- import { CONTROL_BLOCK_ID as L } from "./controls/main/index.js";
6
- import "./store/recommendation.js";
7
- import "./controls/name/index.js";
8
- import "./controls/price/index.js";
9
- import "./controls/oldPrice/index.js";
10
- import "./controls/omnibusPrice/index.js";
11
- import "./controls/omnibusDiscount/index.js";
12
- import "./controls/button/index.js";
13
- import "./controls/image/index.js";
14
- import { SPACING_CONTROL_ID as U } from "./controls/spacing/index.js";
15
- import { CARD_BACKGROUND_COLOR_CONTROL_ID as B } from "./controls/cardBackground/index.js";
16
- import { LAYOUT_CONTROL_ID as D } from "./controls/layout/index.js";
17
- import { COMPOSITION_CONTROL_BLOCK_ID as A } from "./controls/cardComposition/index.js";
18
- class s extends S {
3
+ import { COMPOSITION_CONTROL_BLOCK_ID as L } from "./cardCompositionControl.js";
4
+ import { RecommendationBlockId as N, RecommendationControlId as _ } from "./constants.js";
5
+ import { CONTROL_BLOCK_ID as U } from "./control.js";
6
+ import { CARD_BACKGROUND_COLOR_CONTROL_ID as B } from "./controls/cardBackgroundColorControl.js";
7
+ import { SPACING_CONTROL_ID as D } from "./controls/spacingControl.js";
8
+ class m extends S {
19
9
  registerBlockControls(O) {
20
10
  O[R] = [
21
11
  new I(
22
12
  T.SETTINGS,
23
13
  [
24
- L,
14
+ U,
25
15
  E.EXTERNAL_INDENTS
26
16
  ]
27
17
  ),
@@ -30,14 +20,13 @@ class s extends S {
30
20
  [
31
21
  C.TEXT_BLOCK_BACKGROUND_COLOR,
32
22
  B,
33
- D,
34
- U
23
+ D
35
24
  ]
36
25
  ),
37
26
  new I(
38
27
  "Card Composition",
39
28
  [
40
- A
29
+ L
41
30
  ]
42
31
  ).withLabel("Card Composition")
43
32
  ], O[N.NAME] = [
@@ -169,5 +158,5 @@ class s extends S {
169
158
  }
170
159
  }
171
160
  export {
172
- s as SettingsPanel
161
+ m as SettingsPanel
173
162
  };
@@ -1,14 +1,13 @@
1
- import { RecommendationFeedSourceMaps as d, PriceAttributes as S } from "../../../../enums/extensions/recommendationBlock.js";
2
- import { useRecommendationApi as p } from "../../../../services/recommendationApi.js";
3
- import { useConfigStore as b } from "../../../../stores/config.js";
4
- import { defineStore as I } from "pinia";
5
- import { DEFAULT_CARDS_IN_ROW as R } from "../constants/layout.js";
6
- import { getDefaultProducts as k } from "../templates/utils.js";
7
- import { generateCompleteFilterQuery as f } from "../utils/filterUtil.js";
8
- const m = p();
9
- function h() {
10
- return {
11
- cardsInRow: R,
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 = () => ({
7
+ recommendationCampaignUrls: {},
8
+ recommendationProducts: [],
9
+ recommendationConfigs: {
10
+ cardsInRow: 3,
12
11
  currencySettings: {
13
12
  name: "USD",
14
13
  value: "USD",
@@ -18,225 +17,178 @@ function h() {
18
17
  decimalSeparator: ",",
19
18
  thousandSeparator: "."
20
19
  },
21
- filters: [],
22
- productIds: [],
20
+ filters: [
21
+ {
22
+ type: "standardFilter",
23
+ attribute: "product_attributes.rating_star",
24
+ operatorReplace: "=",
25
+ operator: "=",
26
+ innerGroupOperator: "*",
27
+ outerGroupOperator: "*",
28
+ value: "5",
29
+ filterGroup: 1,
30
+ filterNumber: 1,
31
+ isValid: !0
32
+ },
33
+ {
34
+ type: "standardFilter",
35
+ attribute: "gender",
36
+ operatorReplace: "=",
37
+ operator: "=",
38
+ innerGroupOperator: "|",
39
+ outerGroupOperator: "*",
40
+ value: "male",
41
+ filterGroup: 1,
42
+ filterNumber: 2,
43
+ isValid: !0
44
+ },
45
+ {
46
+ type: "standardFilter",
47
+ attribute: "size",
48
+ operatorReplace: "=",
49
+ operator: "=",
50
+ innerGroupOperator: "*",
51
+ outerGroupOperator: "*",
52
+ value: "L",
53
+ filterGroup: 1,
54
+ filterNumber: 3,
55
+ isValid: !0
56
+ },
57
+ {
58
+ type: "standardFilter",
59
+ attribute: "price.USD",
60
+ operatorReplace: ">",
61
+ operator: ">",
62
+ innerGroupOperator: "*",
63
+ outerGroupOperator: "*",
64
+ value: "20",
65
+ filterGroup: 2,
66
+ filterNumber: 1,
67
+ isValid: !0
68
+ },
69
+ {
70
+ type: "standardFilter",
71
+ attribute: "url",
72
+ operatorReplace: "~",
73
+ operator: "~",
74
+ innerGroupOperator: "|",
75
+ outerGroupOperator: "*",
76
+ value: "user",
77
+ filterGroup: 2,
78
+ filterNumber: 2,
79
+ isValid: !0
80
+ },
81
+ {
82
+ type: "standardFilter",
83
+ attribute: "category",
84
+ operatorReplace: "!~",
85
+ operator: "!~",
86
+ innerGroupOperator: "*",
87
+ outerGroupOperator: "|",
88
+ value: "t-shirt",
89
+ filterGroup: 3,
90
+ filterNumber: 1,
91
+ isValid: !0
92
+ },
93
+ {
94
+ type: "standardFilter",
95
+ attribute: "omnibus_price.USD",
96
+ operatorReplace: ">",
97
+ operator: ">",
98
+ innerGroupOperator: "*",
99
+ outerGroupOperator: "|",
100
+ value: "31",
101
+ filterGroup: 3,
102
+ filterNumber: 2,
103
+ isValid: !0
104
+ },
105
+ {
106
+ type: "standardFilter",
107
+ attribute: "omnibus_discount.USD",
108
+ operatorReplace: "<",
109
+ operator: "%3C",
110
+ innerGroupOperator: "|",
111
+ outerGroupOperator: "|",
112
+ value: "20",
113
+ filterGroup: 3,
114
+ filterNumber: 3,
115
+ isValid: !0
116
+ }
117
+ ],
118
+ productIds: ["22", "12"],
23
119
  id: 1,
24
- language: "en_US",
25
- orientation: "grid",
120
+ language: "tr_TR",
121
+ orientation: "vertical",
26
122
  recommendedProducts: [],
27
123
  sendProductRequestFlag: !1,
28
124
  shuffleProducts: !1,
29
125
  strategy: "mostPopular",
30
126
  textTrimming: !0,
31
127
  unresponsive: !1,
32
- size: "6"
33
- };
34
- }
35
- function C() {
36
- return {
37
- recommendationConfigs: h(),
38
- recommendationProducts: [],
39
- filterStatus: !1,
40
- filterSelectionDrawerStatus: !1,
41
- filterGroup: 1,
42
- isInitialized: !1
43
- };
44
- }
45
- const y = () => ({
46
- recommendationCampaignUrls: {},
128
+ size: "9"
129
+ },
47
130
  activePredictiveAlgorithms: [],
48
131
  languages: {},
49
132
  currencyList: [],
133
+ filterStatus: !1,
134
+ filterSelectionDrawerStatus: !1,
50
135
  filterList: {},
51
- blockStates: {},
52
- currentRecommendationId: null,
53
- configVersion: 0
54
- }), A = I("guidoRecommendationExtension", {
55
- state: () => y(),
136
+ filterGroup: 1
137
+ }), y = p("guidoRecommendationExtension", {
138
+ state: () => d(),
56
139
  getters: {
57
- // ====================================================================
58
- // Proxy Getters — Backward Compatible Access to Current Block State
59
- // ====================================================================
60
- /**
61
- * Proxy getter: delegates to blockStates[currentRecommendationId].recommendationConfigs
62
- * This allows all existing code that reads `store.recommendationConfigs` to work unchanged.
63
- */
64
- recommendationConfigs(t) {
65
- return t.currentRecommendationId !== null && t.blockStates[t.currentRecommendationId] ? t.blockStates[t.currentRecommendationId].recommendationConfigs : h();
66
- },
67
- /**
68
- * Proxy getter: delegates to blockStates[currentRecommendationId].recommendationProducts
69
- */
70
- recommendationProducts(t) {
71
- return t.currentRecommendationId !== null && t.blockStates[t.currentRecommendationId] ? t.blockStates[t.currentRecommendationId].recommendationProducts : [];
72
- },
73
- /**
74
- * Proxy getter: delegates to blockStates[currentRecommendationId].filterSelectionDrawerStatus
75
- */
76
- filterSelectionDrawerStatus(t) {
77
- return t.currentRecommendationId !== null && t.blockStates[t.currentRecommendationId] ? t.blockStates[t.currentRecommendationId].filterSelectionDrawerStatus : !1;
78
- },
79
- /**
80
- * Proxy getter: delegates to blockStates[currentRecommendationId].filterStatus
81
- */
82
- filterStatus(t) {
83
- return t.currentRecommendationId !== null && t.blockStates[t.currentRecommendationId] ? t.blockStates[t.currentRecommendationId].filterStatus : !1;
84
- },
85
- /**
86
- * Proxy getter: delegates to blockStates[currentRecommendationId].filterGroup
87
- */
88
- filterGroup(t) {
89
- return t.currentRecommendationId !== null && t.blockStates[t.currentRecommendationId] ? t.blockStates[t.currentRecommendationId].filterGroup : 1;
90
- },
91
- // ====================================================================
92
- // Existing Getters (now reading through proxy)
93
- // ====================================================================
94
- hasFilters() {
95
- return !!this.recommendationConfigs.filters.length;
96
- },
97
- getFilterGroupCount() {
98
- const { filters: t } = this.recommendationConfigs;
140
+ hasFilters: (e) => !!e.recommendationConfigs.filters.length,
141
+ getFilterGroupCount: (e) => {
142
+ const { filters: t } = e.recommendationConfigs;
99
143
  return t.length && t[t.length - 1].filterGroup || 0;
100
144
  },
101
- getActivePredictiveAlgorithms: (t) => {
102
- const r = [];
103
- return t.activePredictiveAlgorithms.forEach((e) => {
104
- r.push(...d.filter((n) => n.id === e));
105
- }), r.map((e) => ({
106
- text: e.name,
107
- value: e.key
145
+ getActivePredictiveAlgorithms: (e) => {
146
+ const t = [];
147
+ return e.activePredictiveAlgorithms.forEach((r) => {
148
+ t.push(...n.filter((i) => i.id === r));
149
+ }), t.map((r) => ({
150
+ text: r.name,
151
+ value: r.key
108
152
  }));
109
153
  },
110
- getLanguages: (t) => Object.entries(t.languages).map(([r, e]) => ({
111
- text: e,
112
- value: r
154
+ getLanguages: (e) => Object.entries(e.languages).map(([t, r]) => ({
155
+ text: r,
156
+ value: t
113
157
  })),
114
- getCurrencySymbolList: (t) => t.currencyList.map((r) => ({
115
- text: r.text,
116
- value: r.text
158
+ getCurrencySymbolList: (e) => e.currencyList.map((t) => ({
159
+ text: t.text,
160
+ value: t.text
117
161
  })),
118
- getFilterList() {
119
- return Object.values(this.filterList).map((t) => {
120
- const r = t.type === "defaultAttribute", e = S.includes(t.attributeName);
121
- let n = r ? t.attributeName : `product_attributes.${t.attributeName}`;
122
- return n = e ? `${n}.${this.recommendationConfigs.currencySettings.value}` : n, {
123
- text: t.displayName,
124
- value: n,
125
- type: t.attributeType
126
- };
127
- });
128
- },
129
- getSelectedFilterGroup() {
130
- return (t) => [...this.recommendationConfigs.filters].filter((r) => r.filterGroup === t);
131
- }
162
+ getFilterList: (e) => Object.values(e.filterList).map((t) => {
163
+ const r = t.type === "defaultAttribute", i = u.includes(t.attributeName);
164
+ let o = r ? t.attributeName : `product_attributes.${t.attributeName}`;
165
+ return o = i ? `${o}.${e.recommendationConfigs.currencySettings.value}` : o, {
166
+ text: t.displayName,
167
+ value: o,
168
+ type: t.attributeType
169
+ };
170
+ }),
171
+ getSelectedFilterGroup: (e) => (t) => [...e.recommendationConfigs.filters].filter((r) => r.filterGroup === t)
132
172
  },
133
173
  actions: {
134
- // ====================================================================
135
- // Block Lifecycle Actions
136
- // ====================================================================
137
- /**
138
- * Sets the currently active block ID.
139
- * Creates a new entry in blockStates if one doesn't exist.
140
- */
141
- setCurrentBlock(t) {
142
- this.blockStates[t] || (this.blockStates = {
143
- ...this.blockStates,
144
- [t]: C()
145
- }), this.currentRecommendationId = t;
146
- },
147
- /**
148
- * Removes a block's state from the store.
149
- * Resets currentRecommendationId if it was the deleted block.
150
- */
151
- removeBlockState(t) {
152
- const r = { ...this.blockStates };
153
- if (delete r[t], this.blockStates = r, this.currentRecommendationId === t) {
154
- const e = Object.keys(this.blockStates).map(Number);
155
- this.currentRecommendationId = e.length > 0 ? e[0] : null;
156
- }
157
- },
158
- /**
159
- * Marks a block as initialized (initial API data has been fetched).
160
- * Automatically cleaned up when removeBlockState deletes the block entry.
161
- */
162
- markBlockInitialized(t) {
163
- this.blockStates[t] && (this.blockStates[t].isInitialized = !0);
164
- },
165
- /**
166
- * Patches the current block's recommendationConfigs.
167
- * Replaces `store.$patch({ recommendationConfigs: { ... } })` pattern.
168
- */
169
- patchCurrentBlockConfig(t, r = {}) {
170
- if (this.currentRecommendationId === null || !this.blockStates[this.currentRecommendationId])
171
- return;
172
- const e = this.blockStates[this.currentRecommendationId];
173
- e.recommendationConfigs = {
174
- ...e.recommendationConfigs,
175
- ...t,
176
- currencySettings: {
177
- ...e.recommendationConfigs.currencySettings,
178
- ...t.currencySettings || {}
179
- }
180
- };
181
- const { triggerRefetch: n = !0 } = r;
182
- n && this.configVersion++;
183
- },
184
- /**
185
- * Opens the filter selection drawer for the current block.
186
- * If no filters exist, initializes with a default empty filter
187
- * so the user has a starting point for input.
188
- */
189
- openFilterDrawer() {
190
- if (this.currentRecommendationId === null || !this.blockStates[this.currentRecommendationId])
191
- return;
192
- const t = this.blockStates[this.currentRecommendationId];
193
- t.recommendationConfigs.filters.length || (t.recommendationConfigs.filters = [{
194
- type: "standardFilter",
195
- attribute: "",
196
- operatorReplace: "",
197
- operator: "",
198
- innerGroupOperator: "*",
199
- outerGroupOperator: "*",
200
- filterNumber: 1,
201
- filterGroup: 1,
202
- isValid: !1,
203
- value: ""
204
- }]), t.filterSelectionDrawerStatus = !0;
205
- },
206
- /**
207
- * Closes the filter selection drawer for the current block
208
- */
209
- closeFilterDrawer() {
210
- this.currentRecommendationId === null || !this.blockStates[this.currentRecommendationId] || (this.blockStates[this.currentRecommendationId].filterSelectionDrawerStatus = !1);
211
- },
212
- // ====================================================================
213
- // Shared Data Fetching (fetched once, used by all blocks)
214
- // ====================================================================
215
174
  async fetchRecommendationCreateData() {
216
175
  if (this.activePredictiveAlgorithms.length)
217
176
  return;
218
177
  const {
219
- activePredictiveAlgorithms: t,
220
- languages: r,
221
- currencies: e
222
- } = await m.fetchRecommendationCreateData();
223
- this.activePredictiveAlgorithms = t, this.languages = r;
224
- const [n] = e, o = n.value.includes(".") ? n.value.split(".")[1] : n.value;
225
- if (this.currentRecommendationId !== null && this.blockStates[this.currentRecommendationId]) {
226
- const i = this.blockStates[this.currentRecommendationId];
227
- i.recommendationConfigs.currencySettings.name = n.text, i.recommendationConfigs.currencySettings.value = o, i.filterStatus = !!i.recommendationConfigs.filters.length;
228
- }
229
- this.currencyList = e;
178
+ activePredictiveAlgorithms: e,
179
+ languages: t,
180
+ currencies: r
181
+ } = await a.fetchRecommendationCreateData();
182
+ this.activePredictiveAlgorithms = e, this.languages = t;
183
+ const [i] = r;
184
+ this.recommendationConfigs.currencySettings.name = i.text, this.recommendationConfigs.currencySettings.value = i.value, this.currencyList = r, this.filterStatus = !!this.recommendationConfigs.filters.length;
230
185
  },
231
186
  async fetchRecommendationFilters() {
232
- const t = await m.fetchRecommendationFilters();
233
- this.filterList = t;
187
+ const e = await a.fetchRecommendationFilters();
188
+ this.filterList = e;
234
189
  },
235
- // ====================================================================
236
- // Per-Block Filter Actions
237
- // ====================================================================
238
- addFilterGroup(t) {
239
- this.currentRecommendationId === null || !this.blockStates[this.currentRecommendationId] || this.blockStates[this.currentRecommendationId].recommendationConfigs.filters.push({
190
+ addFilterGroup(e) {
191
+ this.recommendationConfigs.filters.push({
240
192
  type: "standardFilter",
241
193
  attribute: "",
242
194
  operatorReplace: "",
@@ -246,71 +198,70 @@ const y = () => ({
246
198
  value: "",
247
199
  filterNumber: 1,
248
200
  isValid: !0,
249
- filterGroup: t
201
+ filterGroup: e
250
202
  });
251
203
  },
252
- updateFilter(t) {
253
- if (this.currentRecommendationId === null || !this.blockStates[this.currentRecommendationId])
254
- return;
255
- const r = this.blockStates[this.currentRecommendationId], e = r.recommendationConfigs.filters.findIndex((n) => n.filterNumber === t.filterNumber && n.filterGroup === t.filterGroup);
256
- if (e !== -1) {
257
- const n = [...r.recommendationConfigs.filters];
258
- n[e] = t, t.value.length && t.operator && t.attribute && t.innerGroupOperator && t.outerGroupOperator ? n[e].isValid = !0 : n[e].isValid = !1, r.recommendationConfigs.filters = n;
204
+ updateFilter(e) {
205
+ const t = this.recommendationConfigs.filters.findIndex((r) => r.filterNumber === e.filterNumber && r.filterGroup === e.filterGroup);
206
+ if (t !== -1) {
207
+ const r = [...this.recommendationConfigs.filters];
208
+ r[t] = e, e.value.length && e.operator && e.attribute && e.innerGroupOperator && e.outerGroupOperator ? r[t].isValid = !0 : r[t].isValid = !1, this.$patch({
209
+ recommendationConfigs: {
210
+ filters: r
211
+ }
212
+ });
259
213
  }
260
214
  },
261
- deleteFilter(t) {
262
- if (this.currentRecommendationId === null || !this.blockStates[this.currentRecommendationId])
263
- return;
264
- const r = this.blockStates[this.currentRecommendationId], e = [...r.recommendationConfigs.filters].findIndex((n) => n.filterNumber === t.filterNumber && n.filterGroup === t.filterGroup);
265
- if (e !== -1) {
266
- const n = [...r.recommendationConfigs.filters];
267
- n.splice(e, 1), r.recommendationConfigs.filters = n;
215
+ deleteFilter(e) {
216
+ const t = [...this.recommendationConfigs.filters].findIndex((r) => r.filterNumber === e.filterNumber && r.filterGroup === e.filterGroup);
217
+ if (t !== -1) {
218
+ const r = [...this.recommendationConfigs.filters];
219
+ r.splice(t, 1), this.$patch({
220
+ recommendationConfigs: {
221
+ filters: r
222
+ }
223
+ });
268
224
  }
269
225
  },
270
- addFilter(t) {
271
- if (this.currentRecommendationId === null || !this.blockStates[this.currentRecommendationId])
272
- return;
273
- const r = this.blockStates[this.currentRecommendationId], e = [...r.recommendationConfigs.filters], o = e.filter(
274
- (c) => c.filterGroup === t.filterGroup
275
- ).length + 1, i = e.findLastIndex((c) => c.filterGroup === t.filterGroup);
276
- i !== -1 ? e.splice(i + 1, 0, {
277
- ...t,
278
- filterNumber: o
279
- }) : e.push({
280
- ...t,
281
- filterNumber: o
282
- }), r.recommendationConfigs.filters = e;
226
+ addFilter(e) {
227
+ const t = [...this.recommendationConfigs.filters], r = t.findLastIndex((i) => i.filterGroup === e.filterGroup);
228
+ r !== -1 ? t.splice(r + 1, 0, {
229
+ ...e,
230
+ filterNumber: r + 2
231
+ }) : t.push({
232
+ ...e,
233
+ filterNumber: 1
234
+ }), this.$patch({
235
+ recommendationConfigs: {
236
+ filters: t
237
+ }
238
+ });
283
239
  },
284
240
  generateFilterQuery() {
285
- return f(this.recommendationConfigs.filters);
241
+ return m(this.recommendationConfigs.filters);
286
242
  },
287
- // ====================================================================
288
- // Per-Block Product Fetching
289
- // ====================================================================
290
243
  async fetchRecommendationProducts() {
291
- var u;
292
- if (this.currentRecommendationId === null || !this.blockStates[this.currentRecommendationId])
293
- return;
294
- const t = this.currentRecommendationId, r = this.blockStates[t], { recommendationConfigs: e } = r, n = e.filters.filter((l) => l.isValid), o = f(n), i = ((u = d.find((l) => l.key === e.strategy)) == null ? void 0 : u.path) || "", c = b(), s = {
295
- locale: e.language,
296
- currency: e.currencySettings.value,
297
- partnerName: c.partnerName,
298
- size: e.size,
299
- details: !0,
300
- campaignId: c.variationId
301
- };
302
- e.strategy === "manualMerchandising" ? s.productId = e.productIds.join(",") : e.strategy === "similarViewed" && (s.productId = "{itemId}"), o && (s.filter = o), e.shuffleProducts && (s.shuffle = !0);
303
- const g = parseInt(e.size) || 6;
304
- let a;
305
- try {
306
- a = await m.fetchRecommendationProducts(i, s);
307
- } catch {
308
- a = [];
309
- }
310
- this.blockStates[t] && (this.blockStates[t].recommendationProducts = a.length > 0 ? a : k(g));
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
+ {
248
+ // TODO: Here will be optimized and filled carefully
249
+ locale: this.recommendationConfigs.language,
250
+ currency: this.recommendationConfigs.currencySettings.value,
251
+ partnerName: r.partnerName,
252
+ productId: this.recommendationConfigs.strategy === "manualMerchandising" ? this.recommendationConfigs.productIds.join(",") : "{itemId}",
253
+ size: this.recommendationConfigs.size,
254
+ details: !0,
255
+ campaignId: "{campaignId}",
256
+ filter: e
257
+ }
258
+ );
259
+ this.$patch({
260
+ recommendationProducts: i
261
+ });
311
262
  }
312
263
  }
313
264
  });
314
265
  export {
315
- A as useRecommendationExtensionStore
266
+ y as useRecommendationExtensionStore
316
267
  };