@infrab4a/connect-angular 4.3.7-beta.2 → 4.3.7-beta.5

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 (100) hide show
  1. package/angular-connect.module.d.ts +24 -24
  2. package/angular-elastic-search.module.d.ts +9 -9
  3. package/angular-firebase-auth.module.d.ts +11 -11
  4. package/angular-firestore.module.d.ts +18 -18
  5. package/angular-hasura-graphql.module.d.ts +16 -16
  6. package/consts/backend-url.const.d.ts +1 -1
  7. package/consts/category-structure.d.ts +1 -1
  8. package/consts/default-shop.const.d.ts +1 -1
  9. package/consts/es-config.const.d.ts +1 -1
  10. package/consts/firebase-const.d.ts +3 -3
  11. package/consts/hasura-options.const.d.ts +1 -1
  12. package/consts/index.d.ts +6 -6
  13. package/consts/storage-base-url.const.d.ts +1 -1
  14. package/esm2020/angular-connect.module.mjs +113 -113
  15. package/esm2020/angular-elastic-search.module.mjs +34 -34
  16. package/esm2020/angular-firebase-auth.module.mjs +115 -115
  17. package/esm2020/angular-firestore.module.mjs +502 -502
  18. package/esm2020/angular-hasura-graphql.module.mjs +265 -265
  19. package/esm2020/consts/backend-url.const.mjs +1 -1
  20. package/esm2020/consts/category-structure.mjs +2 -2
  21. package/esm2020/consts/default-shop.const.mjs +2 -2
  22. package/esm2020/consts/es-config.const.mjs +2 -2
  23. package/esm2020/consts/firebase-const.mjs +4 -4
  24. package/esm2020/consts/hasura-options.const.mjs +2 -2
  25. package/esm2020/consts/index.mjs +7 -7
  26. package/esm2020/consts/storage-base-url.const.mjs +2 -2
  27. package/esm2020/helpers/index.mjs +2 -2
  28. package/esm2020/helpers/mobile-operation-system-checker.helper.mjs +7 -7
  29. package/esm2020/index.mjs +6 -6
  30. package/esm2020/infrab4a-connect-angular.mjs +4 -4
  31. package/esm2020/services/auth.service.mjs +37 -40
  32. package/esm2020/services/cart.service.mjs +281 -281
  33. package/esm2020/services/catalog/adapters/category-structure.adapter.mjs +2 -2
  34. package/esm2020/services/catalog/adapters/index.mjs +4 -4
  35. package/esm2020/services/catalog/adapters/new-category-structure.adapter.mjs +41 -41
  36. package/esm2020/services/catalog/adapters/old-category-structure.adapter.mjs +23 -23
  37. package/esm2020/services/catalog/catalog.service.mjs +185 -185
  38. package/esm2020/services/catalog/category.service.mjs +51 -51
  39. package/esm2020/services/catalog/enums/index.mjs +2 -2
  40. package/esm2020/services/catalog/enums/product-sorts.enum.mjs +11 -11
  41. package/esm2020/services/catalog/index.mjs +8 -8
  42. package/esm2020/services/catalog/models/category-with-tree.model.mjs +10 -10
  43. package/esm2020/services/catalog/models/index.mjs +2 -2
  44. package/esm2020/services/catalog/types/index.mjs +2 -2
  45. package/esm2020/services/catalog/types/product-sort.type.mjs +2 -2
  46. package/esm2020/services/catalog/wishlist.service.mjs +115 -115
  47. package/esm2020/services/checkout-subscription.service.mjs +53 -53
  48. package/esm2020/services/checkout.service.mjs +71 -71
  49. package/esm2020/services/coupon.service.mjs +235 -235
  50. package/esm2020/services/helpers/index.mjs +2 -2
  51. package/esm2020/services/helpers/util.helper.mjs +18 -18
  52. package/esm2020/services/home-shop.service.mjs +125 -125
  53. package/esm2020/services/index.mjs +11 -11
  54. package/esm2020/services/order.service.mjs +30 -30
  55. package/esm2020/services/shipping.service.mjs +96 -96
  56. package/esm2020/services/types/index.mjs +3 -3
  57. package/esm2020/services/types/required-checkout-data.type.mjs +2 -2
  58. package/esm2020/services/types/required-checkout-subscription-data.type.mjs +2 -2
  59. package/esm2020/services/types/shipping-methods.type.mjs +2 -2
  60. package/esm2020/types/firebase-app-config.type.mjs +2 -2
  61. package/esm2020/types/index.mjs +2 -2
  62. package/fesm2015/infrab4a-connect-angular.mjs +2310 -2313
  63. package/fesm2015/infrab4a-connect-angular.mjs.map +1 -1
  64. package/fesm2020/infrab4a-connect-angular.mjs +2242 -2245
  65. package/fesm2020/infrab4a-connect-angular.mjs.map +1 -1
  66. package/helpers/index.d.ts +1 -1
  67. package/helpers/mobile-operation-system-checker.helper.d.ts +3 -3
  68. package/index.d.ts +5 -5
  69. package/package.json +2 -2
  70. package/services/auth.service.d.ts +18 -18
  71. package/services/cart.service.d.ts +42 -42
  72. package/services/catalog/adapters/category-structure.adapter.d.ts +4 -4
  73. package/services/catalog/adapters/index.d.ts +3 -3
  74. package/services/catalog/adapters/new-category-structure.adapter.d.ts +12 -12
  75. package/services/catalog/adapters/old-category-structure.adapter.d.ts +10 -10
  76. package/services/catalog/catalog.service.d.ts +86 -86
  77. package/services/catalog/category.service.d.ts +20 -20
  78. package/services/catalog/enums/index.d.ts +1 -1
  79. package/services/catalog/enums/product-sorts.enum.d.ts +9 -9
  80. package/services/catalog/index.d.ts +7 -7
  81. package/services/catalog/models/category-with-tree.model.d.ts +4 -4
  82. package/services/catalog/models/index.d.ts +1 -1
  83. package/services/catalog/types/index.d.ts +1 -1
  84. package/services/catalog/types/product-sort.type.d.ts +2 -2
  85. package/services/catalog/wishlist.service.d.ts +38 -38
  86. package/services/checkout-subscription.service.d.ts +18 -18
  87. package/services/checkout.service.d.ts +23 -23
  88. package/services/coupon.service.d.ts +29 -29
  89. package/services/helpers/index.d.ts +1 -1
  90. package/services/helpers/util.helper.d.ts +3 -3
  91. package/services/home-shop.service.d.ts +26 -26
  92. package/services/index.d.ts +10 -10
  93. package/services/order.service.d.ts +13 -13
  94. package/services/shipping.service.d.ts +19 -19
  95. package/services/types/index.d.ts +2 -2
  96. package/services/types/required-checkout-data.type.d.ts +2 -2
  97. package/services/types/required-checkout-subscription-data.type.d.ts +2 -2
  98. package/services/types/shipping-methods.type.d.ts +12 -12
  99. package/types/firebase-app-config.type.d.ts +1 -1
  100. package/types/index.d.ts +1 -1
@@ -12,7 +12,7 @@ import { Firestore, provideFirestore, getFirestore, initializeFirestore, memoryL
12
12
  import * as i2 from '@angular/fire/storage';
13
13
  import { Storage, provideStorage, getStorage } from '@angular/fire/storage';
14
14
  import { combineLatest, from, of, throwError, Subject, iif, forkJoin } from 'rxjs';
15
- import { map, tap, mergeMap, catchError, concatMap } from 'rxjs/operators';
15
+ import { map, mergeMap, catchError, concatMap, tap } from 'rxjs/operators';
16
16
  import cookie from 'js-cookie';
17
17
  import { __decorate, __metadata } from 'tslib';
18
18
  import { Type } from 'class-transformer';
@@ -20,34 +20,34 @@ import * as i1$3 from '@angular/common/http';
20
20
 
21
21
  const ES_CONFIG = 'ES_CONFIG';
22
22
 
23
- class AngularElasticSeachModule {
24
- static initializeApp(options) {
25
- return {
26
- ngModule: AngularElasticSeachModule,
27
- providers: [{ provide: ES_CONFIG, useValue: options }],
28
- };
29
- }
30
- }
31
- AngularElasticSeachModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: AngularElasticSeachModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
32
- AngularElasticSeachModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.1.0", ngImport: i0, type: AngularElasticSeachModule });
33
- AngularElasticSeachModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: AngularElasticSeachModule, providers: [
34
- {
35
- provide: ProductsIndex,
36
- useFactory: (configuration) => new ProductsIndex(new AxiosAdapter(configuration)),
37
- deps: [ES_CONFIG],
38
- },
39
- ] });
40
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: AngularElasticSeachModule, decorators: [{
41
- type: NgModule,
42
- args: [{
43
- providers: [
44
- {
45
- provide: ProductsIndex,
46
- useFactory: (configuration) => new ProductsIndex(new AxiosAdapter(configuration)),
47
- deps: [ES_CONFIG],
48
- },
49
- ],
50
- }]
23
+ class AngularElasticSeachModule {
24
+ static initializeApp(options) {
25
+ return {
26
+ ngModule: AngularElasticSeachModule,
27
+ providers: [{ provide: ES_CONFIG, useValue: options }],
28
+ };
29
+ }
30
+ }
31
+ AngularElasticSeachModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: AngularElasticSeachModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
32
+ AngularElasticSeachModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.1.0", ngImport: i0, type: AngularElasticSeachModule });
33
+ AngularElasticSeachModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: AngularElasticSeachModule, providers: [
34
+ {
35
+ provide: ProductsIndex,
36
+ useFactory: (configuration) => new ProductsIndex(new AxiosAdapter(configuration)),
37
+ deps: [ES_CONFIG],
38
+ },
39
+ ] });
40
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: AngularElasticSeachModule, decorators: [{
41
+ type: NgModule,
42
+ args: [{
43
+ providers: [
44
+ {
45
+ provide: ProductsIndex,
46
+ useFactory: (configuration) => new ProductsIndex(new AxiosAdapter(configuration)),
47
+ deps: [ES_CONFIG],
48
+ },
49
+ ],
50
+ }]
51
51
  }] });
52
52
 
53
53
  const BACKEND_URL = 'BACKEND_URL';
@@ -56,2270 +56,2267 @@ const CATEGORY_STRUCTURE = 'CATEGORY_STRUCTURE';
56
56
 
57
57
  const DEFAULT_SHOP = 'DEFAULT_SHOP';
58
58
 
59
- const FIREBASE_APP_NAME = new InjectionToken('firebaseAppName');
59
+ const FIREBASE_APP_NAME = new InjectionToken('firebaseAppName');
60
60
  const FIREBASE_OPTIONS = new InjectionToken('firebaseOptions');
61
61
 
62
62
  const HASURA_OPTIONS = 'HASURA_OPTIONS';
63
63
 
64
- class AngularFirebaseAuthModule {
65
- static initializeApp(options, nameOrConfig) {
66
- return {
67
- ngModule: AngularFirebaseAuthModule,
68
- providers: [
69
- { provide: FIREBASE_OPTIONS, useValue: options },
70
- { provide: FIREBASE_APP_NAME, useValue: nameOrConfig },
71
- ],
72
- };
73
- }
74
- }
75
- AngularFirebaseAuthModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: AngularFirebaseAuthModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
76
- AngularFirebaseAuthModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.1.0", ngImport: i0, type: AngularFirebaseAuthModule, imports: [i1.AuthModule] });
77
- AngularFirebaseAuthModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: AngularFirebaseAuthModule, providers: [
78
- {
79
- provide: 'Authentication',
80
- useFactory: (authenticationService, userRepository) => {
81
- return new Authentication(authenticationService, userRepository);
82
- },
83
- deps: ['AuthenticationService', 'UserRepository'],
84
- },
85
- {
86
- provide: 'AuthenticationService',
87
- useFactory: (angularFireAuth) => {
88
- return new AuthenticationFirebaseAuthService(angularFireAuth);
89
- },
90
- deps: [Auth],
91
- },
92
- {
93
- provide: 'Register',
94
- useFactory: (registerService, userRepository) => {
95
- return new Register(registerService, userRepository);
96
- },
97
- deps: ['RegisterService', 'UserRepository'],
98
- },
99
- {
100
- provide: 'RegisterService',
101
- useFactory: (angularFireAuth) => {
102
- return new RegisterFirebaseAuthService(angularFireAuth);
103
- },
104
- deps: [Auth],
105
- },
106
- {
107
- provide: 'SignOut',
108
- useFactory: (authenticationService) => {
109
- return new SignOut(authenticationService);
110
- },
111
- deps: ['AuthenticationService'],
112
- },
113
- {
114
- provide: 'RecoveryPassword',
115
- useFactory: (authenticationService) => {
116
- return new RecoveryPassword(authenticationService);
117
- },
118
- deps: ['AuthenticationService'],
119
- },
120
- ], imports: [provideAuth((injector) => getAuth(injector.get(FirebaseApp)))] });
121
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: AngularFirebaseAuthModule, decorators: [{
122
- type: NgModule,
123
- args: [{
124
- imports: [provideAuth((injector) => getAuth(injector.get(FirebaseApp)))],
125
- providers: [
126
- {
127
- provide: 'Authentication',
128
- useFactory: (authenticationService, userRepository) => {
129
- return new Authentication(authenticationService, userRepository);
130
- },
131
- deps: ['AuthenticationService', 'UserRepository'],
132
- },
133
- {
134
- provide: 'AuthenticationService',
135
- useFactory: (angularFireAuth) => {
136
- return new AuthenticationFirebaseAuthService(angularFireAuth);
137
- },
138
- deps: [Auth],
139
- },
140
- {
141
- provide: 'Register',
142
- useFactory: (registerService, userRepository) => {
143
- return new Register(registerService, userRepository);
144
- },
145
- deps: ['RegisterService', 'UserRepository'],
146
- },
147
- {
148
- provide: 'RegisterService',
149
- useFactory: (angularFireAuth) => {
150
- return new RegisterFirebaseAuthService(angularFireAuth);
151
- },
152
- deps: [Auth],
153
- },
154
- {
155
- provide: 'SignOut',
156
- useFactory: (authenticationService) => {
157
- return new SignOut(authenticationService);
158
- },
159
- deps: ['AuthenticationService'],
160
- },
161
- {
162
- provide: 'RecoveryPassword',
163
- useFactory: (authenticationService) => {
164
- return new RecoveryPassword(authenticationService);
165
- },
166
- deps: ['AuthenticationService'],
167
- },
168
- ],
169
- }]
64
+ class AngularFirebaseAuthModule {
65
+ static initializeApp(options, nameOrConfig) {
66
+ return {
67
+ ngModule: AngularFirebaseAuthModule,
68
+ providers: [
69
+ { provide: FIREBASE_OPTIONS, useValue: options },
70
+ { provide: FIREBASE_APP_NAME, useValue: nameOrConfig },
71
+ ],
72
+ };
73
+ }
74
+ }
75
+ AngularFirebaseAuthModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: AngularFirebaseAuthModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
76
+ AngularFirebaseAuthModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.1.0", ngImport: i0, type: AngularFirebaseAuthModule, imports: [i1.AuthModule] });
77
+ AngularFirebaseAuthModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: AngularFirebaseAuthModule, providers: [
78
+ {
79
+ provide: 'Authentication',
80
+ useFactory: (authenticationService, userRepository) => {
81
+ return new Authentication(authenticationService, userRepository);
82
+ },
83
+ deps: ['AuthenticationService', 'UserRepository'],
84
+ },
85
+ {
86
+ provide: 'AuthenticationService',
87
+ useFactory: (angularFireAuth) => {
88
+ return new AuthenticationFirebaseAuthService(angularFireAuth);
89
+ },
90
+ deps: [Auth],
91
+ },
92
+ {
93
+ provide: 'Register',
94
+ useFactory: (registerService, userRepository) => {
95
+ return new Register(registerService, userRepository);
96
+ },
97
+ deps: ['RegisterService', 'UserRepository'],
98
+ },
99
+ {
100
+ provide: 'RegisterService',
101
+ useFactory: (angularFireAuth) => {
102
+ return new RegisterFirebaseAuthService(angularFireAuth);
103
+ },
104
+ deps: [Auth],
105
+ },
106
+ {
107
+ provide: 'SignOut',
108
+ useFactory: (authenticationService) => {
109
+ return new SignOut(authenticationService);
110
+ },
111
+ deps: ['AuthenticationService'],
112
+ },
113
+ {
114
+ provide: 'RecoveryPassword',
115
+ useFactory: (authenticationService) => {
116
+ return new RecoveryPassword(authenticationService);
117
+ },
118
+ deps: ['AuthenticationService'],
119
+ },
120
+ ], imports: [provideAuth((injector) => getAuth(injector.get(FirebaseApp)))] });
121
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: AngularFirebaseAuthModule, decorators: [{
122
+ type: NgModule,
123
+ args: [{
124
+ imports: [provideAuth((injector) => getAuth(injector.get(FirebaseApp)))],
125
+ providers: [
126
+ {
127
+ provide: 'Authentication',
128
+ useFactory: (authenticationService, userRepository) => {
129
+ return new Authentication(authenticationService, userRepository);
130
+ },
131
+ deps: ['AuthenticationService', 'UserRepository'],
132
+ },
133
+ {
134
+ provide: 'AuthenticationService',
135
+ useFactory: (angularFireAuth) => {
136
+ return new AuthenticationFirebaseAuthService(angularFireAuth);
137
+ },
138
+ deps: [Auth],
139
+ },
140
+ {
141
+ provide: 'Register',
142
+ useFactory: (registerService, userRepository) => {
143
+ return new Register(registerService, userRepository);
144
+ },
145
+ deps: ['RegisterService', 'UserRepository'],
146
+ },
147
+ {
148
+ provide: 'RegisterService',
149
+ useFactory: (angularFireAuth) => {
150
+ return new RegisterFirebaseAuthService(angularFireAuth);
151
+ },
152
+ deps: [Auth],
153
+ },
154
+ {
155
+ provide: 'SignOut',
156
+ useFactory: (authenticationService) => {
157
+ return new SignOut(authenticationService);
158
+ },
159
+ deps: ['AuthenticationService'],
160
+ },
161
+ {
162
+ provide: 'RecoveryPassword',
163
+ useFactory: (authenticationService) => {
164
+ return new RecoveryPassword(authenticationService);
165
+ },
166
+ deps: ['AuthenticationService'],
167
+ },
168
+ ],
169
+ }]
170
170
  }] });
171
171
 
172
172
  const STORAGE_BASE_URL = 'STORAGE_BASE_URL';
173
173
 
174
- class MobileOperationSystemCheckerHelper {
175
- static isAppleDevice() {
176
- return (['iPad Simulator', 'iPhone Simulator', 'iPod Simulator', 'iPad', 'iPhone', 'iPod'].includes(navigator?.platform) ||
177
- (navigator?.userAgent?.includes?.('Mac') && 'ontouchend' in (document || {})));
178
- }
174
+ class MobileOperationSystemCheckerHelper {
175
+ static isAppleDevice() {
176
+ return (['iPad Simulator', 'iPhone Simulator', 'iPod Simulator', 'iPad', 'iPhone', 'iPod'].includes(navigator?.platform) ||
177
+ (navigator?.userAgent?.includes?.('Mac') && 'ontouchend' in (document || {})));
178
+ }
179
179
  }
180
180
 
181
- class AngularFirestoreModule {
182
- static initializeApp(options, nameOrConfig) {
183
- return {
184
- ngModule: AngularFirestoreModule,
185
- providers: [
186
- { provide: FIREBASE_OPTIONS, useValue: options.firebase },
187
- { provide: FIREBASE_APP_NAME, useValue: nameOrConfig },
188
- { provide: ES_CONFIG, useValue: options.elasticSearch },
189
- ],
190
- };
191
- }
192
- }
193
- AngularFirestoreModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: AngularFirestoreModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
194
- AngularFirestoreModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.1.0", ngImport: i0, type: AngularFirestoreModule, imports: [AngularElasticSeachModule, i1$1.FirestoreModule, i2.StorageModule] });
195
- AngularFirestoreModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: AngularFirestoreModule, providers: [
196
- {
197
- provide: 'FirestoreOptions',
198
- useFactory: (firestore, platformId) => ({
199
- firestore,
200
- interceptors: {
201
- request: (request) => {
202
- if (isPlatformBrowser(platformId))
203
- return request;
204
- const interval = setInterval(() => { }, 100);
205
- request.interval = interval;
206
- return request;
207
- },
208
- response: (response, request) => {
209
- if (isPlatformBrowser(platformId))
210
- return response;
211
- clearInterval(request.interval);
212
- return response;
213
- },
214
- },
215
- }),
216
- deps: [Firestore, PLATFORM_ID],
217
- },
218
- {
219
- provide: 'BeautyProfileRepository',
220
- useFactory: (config, userRepository) => {
221
- return new UserBeautyProfileFirestoreRepository(config, userRepository);
222
- },
223
- deps: ['FirestoreOptions', 'UserRepository'],
224
- },
225
- {
226
- provide: 'Buy2WinRepository',
227
- useFactory: (options) => {
228
- return new Buy2WinFirestoreRepository(options);
229
- },
230
- deps: ['FirestoreOptions'],
231
- },
232
- {
233
- provide: CategoryFirestoreRepository,
234
- useFactory: (options) => {
235
- return new CategoryFirestoreRepository(options);
236
- },
237
- deps: ['FirestoreOptions'],
238
- },
239
- {
240
- provide: 'CheckoutRepository',
241
- useFactory: (options) => {
242
- return new CheckoutFirestoreRepository(options);
243
- },
244
- deps: ['FirestoreOptions'],
245
- },
246
- {
247
- provide: 'CheckoutSubscriptionRepository',
248
- useFactory: (options) => {
249
- return new CheckoutSubscriptionFirestoreRepository(options);
250
- },
251
- deps: ['FirestoreOptions'],
252
- },
253
- {
254
- provide: 'CouponRepository',
255
- useFactory: (options) => {
256
- return new CouponFirestoreRepository(options);
257
- },
258
- deps: ['FirestoreOptions'],
259
- },
260
- {
261
- provide: 'CampaignHashtagRepository',
262
- useFactory: (options) => {
263
- return new CampaignHashtagFirestoreRepository(options);
264
- },
265
- deps: ['FirestoreOptions'],
266
- },
267
- {
268
- provide: 'CampaignDashboardRepository',
269
- useFactory: (options) => {
270
- return new CampaignDashboardFirestoreRepository(options);
271
- },
272
- deps: ['FirestoreOptions'],
273
- },
274
- {
275
- provide: 'EditionRepository',
276
- useFactory: (options, subscriptionRepository) => {
277
- return new SubscriptionEditionFirestoreRepository(options, subscriptionRepository);
278
- },
279
- deps: ['FirestoreOptions', 'SubscriptionRepository'],
280
- },
281
- {
282
- provide: 'HomeRepository',
283
- useFactory: (options) => {
284
- return new HomeFirestoreRepository(options);
285
- },
286
- deps: ['FirestoreOptions'],
287
- },
288
- {
289
- provide: 'LeadRepository',
290
- useFactory: (options) => {
291
- return new LeadFirestoreRepository(options);
292
- },
293
- deps: ['FirestoreOptions'],
294
- },
295
- {
296
- provide: 'LegacyOrderRepository',
297
- useFactory: (options) => {
298
- return new LegacyOrderFirestoreRepository(options);
299
- },
300
- deps: ['FirestoreOptions'],
301
- },
302
- {
303
- provide: 'ShopMenuRepository',
304
- useFactory: (options) => {
305
- return new ShopMenuFirestoreRepository(options);
306
- },
307
- deps: ['FirestoreOptions'],
308
- },
309
- {
310
- provide: 'OrderRepository',
311
- useFactory: (options) => {
312
- return new OrderFirestoreRepository(options);
313
- },
314
- deps: ['FirestoreOptions'],
315
- },
316
- {
317
- provide: 'PaymentRepository',
318
- useFactory: (options) => {
319
- return new PaymentFirestoreRepository(options);
320
- },
321
- deps: ['FirestoreOptions'],
322
- },
323
- {
324
- provide: ProductFirestoreRepository,
325
- useFactory: (options) => {
326
- return new ProductFirestoreRepository(options);
327
- },
328
- deps: ['FirestoreOptions'],
329
- },
330
- {
331
- provide: 'ShopSettingsRepository',
332
- useFactory: (options) => {
333
- return new ShopSettingsFirestoreRepository(options);
334
- },
335
- deps: ['FirestoreOptions'],
336
- },
337
- {
338
- provide: 'SubscriptionPaymentRepository',
339
- useFactory: (options, subscriptionRepository) => {
340
- return new SubscriptionPaymentFirestoreRepository(options, subscriptionRepository);
341
- },
342
- deps: ['FirestoreOptions', 'SubscriptionRepository'],
343
- },
344
- {
345
- provide: 'SubscriptionPlanRepository',
346
- useFactory: (options) => {
347
- return new SubscriptionPlanFirestoreRepository(options);
348
- },
349
- deps: ['FirestoreOptions'],
350
- },
351
- {
352
- provide: 'SubscriptionProductRepository',
353
- useFactory: (options) => {
354
- return new SubscriptionProductFirestoreRepository(options);
355
- },
356
- deps: ['FirestoreOptions'],
357
- },
358
- {
359
- provide: 'SubscriptionRepository',
360
- useFactory: (options) => {
361
- return new SubscriptionFirestoreRepository(options);
362
- },
363
- deps: ['FirestoreOptions'],
364
- },
365
- {
366
- provide: 'UserRepository',
367
- useFactory: (options) => {
368
- return new UserFirestoreRepository(options);
369
- },
370
- deps: ['FirestoreOptions'],
371
- },
372
- {
373
- provide: 'UserAddressRepository',
374
- useFactory: (options, userRepository) => {
375
- return new UserAddressFirestoreRepository(options, userRepository);
376
- },
377
- deps: ['FirestoreOptions', 'UserRepository'],
378
- },
379
- {
380
- provide: 'UserPaymentMethodRepository',
381
- useFactory: (options, userRepository) => {
382
- return new UserPaymentMethodFirestoreRepository(options, userRepository);
383
- },
384
- deps: ['FirestoreOptions', 'UserRepository'],
385
- },
386
- {
387
- provide: 'SubscriptionMaterializationRepository',
388
- useFactory: (options) => {
389
- return new SubscriptionMaterializationFirestoreRepository(options);
390
- },
391
- deps: ['FirestoreOptions'],
392
- },
393
- {
394
- provide: 'SubscriptionSummaryRepository',
395
- useFactory: (options) => {
396
- return new SubscriptionSummaryFirestoreRepository(options);
397
- },
398
- deps: ['FirestoreOptions'],
399
- },
400
- {
401
- provide: ProductVariantFirestoreRepository,
402
- useFactory: (options, productRepository) => {
403
- return new ProductVariantFirestoreRepository(options, productRepository);
404
- },
405
- deps: ['FirestoreOptions', ProductFirestoreRepository],
406
- },
407
- {
408
- provide: 'FileUploaderService',
409
- useFactory: (storage, baseUrl) => {
410
- return new FirebaseFileUploaderService(storage, baseUrl);
411
- },
412
- deps: [Storage, STORAGE_BASE_URL],
413
- },
414
- ], imports: [AngularElasticSeachModule,
415
- provideFirestore((injector) => {
416
- const platformId = injector.get(PLATFORM_ID);
417
- if (isPlatformServer(platformId))
418
- return getFirestore(injector.get(FirebaseApp));
419
- if (!MobileOperationSystemCheckerHelper.isAppleDevice())
420
- return getFirestore(injector.get(FirebaseApp));
421
- const firestore = initializeFirestore(injector.get(FirebaseApp), {
422
- experimentalForceLongPolling: true,
423
- localCache: memoryLocalCache(),
424
- });
425
- return firestore;
426
- }),
427
- provideStorage(() => getStorage())] });
428
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: AngularFirestoreModule, decorators: [{
429
- type: NgModule,
430
- args: [{
431
- imports: [
432
- AngularElasticSeachModule,
433
- provideFirestore((injector) => {
434
- const platformId = injector.get(PLATFORM_ID);
435
- if (isPlatformServer(platformId))
436
- return getFirestore(injector.get(FirebaseApp));
437
- if (!MobileOperationSystemCheckerHelper.isAppleDevice())
438
- return getFirestore(injector.get(FirebaseApp));
439
- const firestore = initializeFirestore(injector.get(FirebaseApp), {
440
- experimentalForceLongPolling: true,
441
- localCache: memoryLocalCache(),
442
- });
443
- return firestore;
444
- }),
445
- provideStorage(() => getStorage()),
446
- ],
447
- providers: [
448
- {
449
- provide: 'FirestoreOptions',
450
- useFactory: (firestore, platformId) => ({
451
- firestore,
452
- interceptors: {
453
- request: (request) => {
454
- if (isPlatformBrowser(platformId))
455
- return request;
456
- const interval = setInterval(() => { }, 100);
457
- request.interval = interval;
458
- return request;
459
- },
460
- response: (response, request) => {
461
- if (isPlatformBrowser(platformId))
462
- return response;
463
- clearInterval(request.interval);
464
- return response;
465
- },
466
- },
467
- }),
468
- deps: [Firestore, PLATFORM_ID],
469
- },
470
- {
471
- provide: 'BeautyProfileRepository',
472
- useFactory: (config, userRepository) => {
473
- return new UserBeautyProfileFirestoreRepository(config, userRepository);
474
- },
475
- deps: ['FirestoreOptions', 'UserRepository'],
476
- },
477
- {
478
- provide: 'Buy2WinRepository',
479
- useFactory: (options) => {
480
- return new Buy2WinFirestoreRepository(options);
481
- },
482
- deps: ['FirestoreOptions'],
483
- },
484
- {
485
- provide: CategoryFirestoreRepository,
486
- useFactory: (options) => {
487
- return new CategoryFirestoreRepository(options);
488
- },
489
- deps: ['FirestoreOptions'],
490
- },
491
- {
492
- provide: 'CheckoutRepository',
493
- useFactory: (options) => {
494
- return new CheckoutFirestoreRepository(options);
495
- },
496
- deps: ['FirestoreOptions'],
497
- },
498
- {
499
- provide: 'CheckoutSubscriptionRepository',
500
- useFactory: (options) => {
501
- return new CheckoutSubscriptionFirestoreRepository(options);
502
- },
503
- deps: ['FirestoreOptions'],
504
- },
505
- {
506
- provide: 'CouponRepository',
507
- useFactory: (options) => {
508
- return new CouponFirestoreRepository(options);
509
- },
510
- deps: ['FirestoreOptions'],
511
- },
512
- {
513
- provide: 'CampaignHashtagRepository',
514
- useFactory: (options) => {
515
- return new CampaignHashtagFirestoreRepository(options);
516
- },
517
- deps: ['FirestoreOptions'],
518
- },
519
- {
520
- provide: 'CampaignDashboardRepository',
521
- useFactory: (options) => {
522
- return new CampaignDashboardFirestoreRepository(options);
523
- },
524
- deps: ['FirestoreOptions'],
525
- },
526
- {
527
- provide: 'EditionRepository',
528
- useFactory: (options, subscriptionRepository) => {
529
- return new SubscriptionEditionFirestoreRepository(options, subscriptionRepository);
530
- },
531
- deps: ['FirestoreOptions', 'SubscriptionRepository'],
532
- },
533
- {
534
- provide: 'HomeRepository',
535
- useFactory: (options) => {
536
- return new HomeFirestoreRepository(options);
537
- },
538
- deps: ['FirestoreOptions'],
539
- },
540
- {
541
- provide: 'LeadRepository',
542
- useFactory: (options) => {
543
- return new LeadFirestoreRepository(options);
544
- },
545
- deps: ['FirestoreOptions'],
546
- },
547
- {
548
- provide: 'LegacyOrderRepository',
549
- useFactory: (options) => {
550
- return new LegacyOrderFirestoreRepository(options);
551
- },
552
- deps: ['FirestoreOptions'],
553
- },
554
- {
555
- provide: 'ShopMenuRepository',
556
- useFactory: (options) => {
557
- return new ShopMenuFirestoreRepository(options);
558
- },
559
- deps: ['FirestoreOptions'],
560
- },
561
- {
562
- provide: 'OrderRepository',
563
- useFactory: (options) => {
564
- return new OrderFirestoreRepository(options);
565
- },
566
- deps: ['FirestoreOptions'],
567
- },
568
- {
569
- provide: 'PaymentRepository',
570
- useFactory: (options) => {
571
- return new PaymentFirestoreRepository(options);
572
- },
573
- deps: ['FirestoreOptions'],
574
- },
575
- {
576
- provide: ProductFirestoreRepository,
577
- useFactory: (options) => {
578
- return new ProductFirestoreRepository(options);
579
- },
580
- deps: ['FirestoreOptions'],
581
- },
582
- {
583
- provide: 'ShopSettingsRepository',
584
- useFactory: (options) => {
585
- return new ShopSettingsFirestoreRepository(options);
586
- },
587
- deps: ['FirestoreOptions'],
588
- },
589
- {
590
- provide: 'SubscriptionPaymentRepository',
591
- useFactory: (options, subscriptionRepository) => {
592
- return new SubscriptionPaymentFirestoreRepository(options, subscriptionRepository);
593
- },
594
- deps: ['FirestoreOptions', 'SubscriptionRepository'],
595
- },
596
- {
597
- provide: 'SubscriptionPlanRepository',
598
- useFactory: (options) => {
599
- return new SubscriptionPlanFirestoreRepository(options);
600
- },
601
- deps: ['FirestoreOptions'],
602
- },
603
- {
604
- provide: 'SubscriptionProductRepository',
605
- useFactory: (options) => {
606
- return new SubscriptionProductFirestoreRepository(options);
607
- },
608
- deps: ['FirestoreOptions'],
609
- },
610
- {
611
- provide: 'SubscriptionRepository',
612
- useFactory: (options) => {
613
- return new SubscriptionFirestoreRepository(options);
614
- },
615
- deps: ['FirestoreOptions'],
616
- },
617
- {
618
- provide: 'UserRepository',
619
- useFactory: (options) => {
620
- return new UserFirestoreRepository(options);
621
- },
622
- deps: ['FirestoreOptions'],
623
- },
624
- {
625
- provide: 'UserAddressRepository',
626
- useFactory: (options, userRepository) => {
627
- return new UserAddressFirestoreRepository(options, userRepository);
628
- },
629
- deps: ['FirestoreOptions', 'UserRepository'],
630
- },
631
- {
632
- provide: 'UserPaymentMethodRepository',
633
- useFactory: (options, userRepository) => {
634
- return new UserPaymentMethodFirestoreRepository(options, userRepository);
635
- },
636
- deps: ['FirestoreOptions', 'UserRepository'],
637
- },
638
- {
639
- provide: 'SubscriptionMaterializationRepository',
640
- useFactory: (options) => {
641
- return new SubscriptionMaterializationFirestoreRepository(options);
642
- },
643
- deps: ['FirestoreOptions'],
644
- },
645
- {
646
- provide: 'SubscriptionSummaryRepository',
647
- useFactory: (options) => {
648
- return new SubscriptionSummaryFirestoreRepository(options);
649
- },
650
- deps: ['FirestoreOptions'],
651
- },
652
- {
653
- provide: ProductVariantFirestoreRepository,
654
- useFactory: (options, productRepository) => {
655
- return new ProductVariantFirestoreRepository(options, productRepository);
656
- },
657
- deps: ['FirestoreOptions', ProductFirestoreRepository],
658
- },
659
- {
660
- provide: 'FileUploaderService',
661
- useFactory: (storage, baseUrl) => {
662
- return new FirebaseFileUploaderService(storage, baseUrl);
663
- },
664
- deps: [Storage, STORAGE_BASE_URL],
665
- },
666
- ],
667
- }]
181
+ class AngularFirestoreModule {
182
+ static initializeApp(options, nameOrConfig) {
183
+ return {
184
+ ngModule: AngularFirestoreModule,
185
+ providers: [
186
+ { provide: FIREBASE_OPTIONS, useValue: options.firebase },
187
+ { provide: FIREBASE_APP_NAME, useValue: nameOrConfig },
188
+ { provide: ES_CONFIG, useValue: options.elasticSearch },
189
+ ],
190
+ };
191
+ }
192
+ }
193
+ AngularFirestoreModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: AngularFirestoreModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
194
+ AngularFirestoreModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.1.0", ngImport: i0, type: AngularFirestoreModule, imports: [AngularElasticSeachModule, i1$1.FirestoreModule, i2.StorageModule] });
195
+ AngularFirestoreModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: AngularFirestoreModule, providers: [
196
+ {
197
+ provide: 'FirestoreOptions',
198
+ useFactory: (firestore, platformId) => ({
199
+ firestore,
200
+ interceptors: {
201
+ request: (request) => {
202
+ if (isPlatformBrowser(platformId))
203
+ return request;
204
+ const interval = setInterval(() => { }, 100);
205
+ request.interval = interval;
206
+ return request;
207
+ },
208
+ response: (response, request) => {
209
+ if (isPlatformBrowser(platformId))
210
+ return response;
211
+ clearInterval(request.interval);
212
+ return response;
213
+ },
214
+ },
215
+ }),
216
+ deps: [Firestore, PLATFORM_ID],
217
+ },
218
+ {
219
+ provide: 'BeautyProfileRepository',
220
+ useFactory: (config, userRepository) => {
221
+ return new UserBeautyProfileFirestoreRepository(config, userRepository);
222
+ },
223
+ deps: ['FirestoreOptions', 'UserRepository'],
224
+ },
225
+ {
226
+ provide: 'Buy2WinRepository',
227
+ useFactory: (options) => {
228
+ return new Buy2WinFirestoreRepository(options);
229
+ },
230
+ deps: ['FirestoreOptions'],
231
+ },
232
+ {
233
+ provide: CategoryFirestoreRepository,
234
+ useFactory: (options) => {
235
+ return new CategoryFirestoreRepository(options);
236
+ },
237
+ deps: ['FirestoreOptions'],
238
+ },
239
+ {
240
+ provide: 'CheckoutRepository',
241
+ useFactory: (options) => {
242
+ return new CheckoutFirestoreRepository(options);
243
+ },
244
+ deps: ['FirestoreOptions'],
245
+ },
246
+ {
247
+ provide: 'CheckoutSubscriptionRepository',
248
+ useFactory: (options) => {
249
+ return new CheckoutSubscriptionFirestoreRepository(options);
250
+ },
251
+ deps: ['FirestoreOptions'],
252
+ },
253
+ {
254
+ provide: 'CouponRepository',
255
+ useFactory: (options) => {
256
+ return new CouponFirestoreRepository(options);
257
+ },
258
+ deps: ['FirestoreOptions'],
259
+ },
260
+ {
261
+ provide: 'CampaignHashtagRepository',
262
+ useFactory: (options) => {
263
+ return new CampaignHashtagFirestoreRepository(options);
264
+ },
265
+ deps: ['FirestoreOptions'],
266
+ },
267
+ {
268
+ provide: 'CampaignDashboardRepository',
269
+ useFactory: (options) => {
270
+ return new CampaignDashboardFirestoreRepository(options);
271
+ },
272
+ deps: ['FirestoreOptions'],
273
+ },
274
+ {
275
+ provide: 'EditionRepository',
276
+ useFactory: (options, subscriptionRepository) => {
277
+ return new SubscriptionEditionFirestoreRepository(options, subscriptionRepository);
278
+ },
279
+ deps: ['FirestoreOptions', 'SubscriptionRepository'],
280
+ },
281
+ {
282
+ provide: 'HomeRepository',
283
+ useFactory: (options) => {
284
+ return new HomeFirestoreRepository(options);
285
+ },
286
+ deps: ['FirestoreOptions'],
287
+ },
288
+ {
289
+ provide: 'LeadRepository',
290
+ useFactory: (options) => {
291
+ return new LeadFirestoreRepository(options);
292
+ },
293
+ deps: ['FirestoreOptions'],
294
+ },
295
+ {
296
+ provide: 'LegacyOrderRepository',
297
+ useFactory: (options) => {
298
+ return new LegacyOrderFirestoreRepository(options);
299
+ },
300
+ deps: ['FirestoreOptions'],
301
+ },
302
+ {
303
+ provide: 'ShopMenuRepository',
304
+ useFactory: (options) => {
305
+ return new ShopMenuFirestoreRepository(options);
306
+ },
307
+ deps: ['FirestoreOptions'],
308
+ },
309
+ {
310
+ provide: 'OrderRepository',
311
+ useFactory: (options) => {
312
+ return new OrderFirestoreRepository(options);
313
+ },
314
+ deps: ['FirestoreOptions'],
315
+ },
316
+ {
317
+ provide: 'PaymentRepository',
318
+ useFactory: (options) => {
319
+ return new PaymentFirestoreRepository(options);
320
+ },
321
+ deps: ['FirestoreOptions'],
322
+ },
323
+ {
324
+ provide: ProductFirestoreRepository,
325
+ useFactory: (options) => {
326
+ return new ProductFirestoreRepository(options);
327
+ },
328
+ deps: ['FirestoreOptions'],
329
+ },
330
+ {
331
+ provide: 'ShopSettingsRepository',
332
+ useFactory: (options) => {
333
+ return new ShopSettingsFirestoreRepository(options);
334
+ },
335
+ deps: ['FirestoreOptions'],
336
+ },
337
+ {
338
+ provide: 'SubscriptionPaymentRepository',
339
+ useFactory: (options, subscriptionRepository) => {
340
+ return new SubscriptionPaymentFirestoreRepository(options, subscriptionRepository);
341
+ },
342
+ deps: ['FirestoreOptions', 'SubscriptionRepository'],
343
+ },
344
+ {
345
+ provide: 'SubscriptionPlanRepository',
346
+ useFactory: (options) => {
347
+ return new SubscriptionPlanFirestoreRepository(options);
348
+ },
349
+ deps: ['FirestoreOptions'],
350
+ },
351
+ {
352
+ provide: 'SubscriptionProductRepository',
353
+ useFactory: (options) => {
354
+ return new SubscriptionProductFirestoreRepository(options);
355
+ },
356
+ deps: ['FirestoreOptions'],
357
+ },
358
+ {
359
+ provide: 'SubscriptionRepository',
360
+ useFactory: (options) => {
361
+ return new SubscriptionFirestoreRepository(options);
362
+ },
363
+ deps: ['FirestoreOptions'],
364
+ },
365
+ {
366
+ provide: 'UserRepository',
367
+ useFactory: (options) => {
368
+ return new UserFirestoreRepository(options);
369
+ },
370
+ deps: ['FirestoreOptions'],
371
+ },
372
+ {
373
+ provide: 'UserAddressRepository',
374
+ useFactory: (options, userRepository) => {
375
+ return new UserAddressFirestoreRepository(options, userRepository);
376
+ },
377
+ deps: ['FirestoreOptions', 'UserRepository'],
378
+ },
379
+ {
380
+ provide: 'UserPaymentMethodRepository',
381
+ useFactory: (options, userRepository) => {
382
+ return new UserPaymentMethodFirestoreRepository(options, userRepository);
383
+ },
384
+ deps: ['FirestoreOptions', 'UserRepository'],
385
+ },
386
+ {
387
+ provide: 'SubscriptionMaterializationRepository',
388
+ useFactory: (options) => {
389
+ return new SubscriptionMaterializationFirestoreRepository(options);
390
+ },
391
+ deps: ['FirestoreOptions'],
392
+ },
393
+ {
394
+ provide: 'SubscriptionSummaryRepository',
395
+ useFactory: (options) => {
396
+ return new SubscriptionSummaryFirestoreRepository(options);
397
+ },
398
+ deps: ['FirestoreOptions'],
399
+ },
400
+ {
401
+ provide: ProductVariantFirestoreRepository,
402
+ useFactory: (options, productRepository) => {
403
+ return new ProductVariantFirestoreRepository(options, productRepository);
404
+ },
405
+ deps: ['FirestoreOptions', ProductFirestoreRepository],
406
+ },
407
+ {
408
+ provide: 'FileUploaderService',
409
+ useFactory: (storage, baseUrl) => {
410
+ return new FirebaseFileUploaderService(storage, baseUrl);
411
+ },
412
+ deps: [Storage, STORAGE_BASE_URL],
413
+ },
414
+ ], imports: [AngularElasticSeachModule,
415
+ provideFirestore((injector) => {
416
+ const platformId = injector.get(PLATFORM_ID);
417
+ if (isPlatformServer(platformId))
418
+ return getFirestore(injector.get(FirebaseApp));
419
+ if (!MobileOperationSystemCheckerHelper.isAppleDevice())
420
+ return getFirestore(injector.get(FirebaseApp));
421
+ const firestore = initializeFirestore(injector.get(FirebaseApp), {
422
+ experimentalForceLongPolling: true,
423
+ localCache: memoryLocalCache(),
424
+ });
425
+ return firestore;
426
+ }),
427
+ provideStorage(() => getStorage())] });
428
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: AngularFirestoreModule, decorators: [{
429
+ type: NgModule,
430
+ args: [{
431
+ imports: [
432
+ AngularElasticSeachModule,
433
+ provideFirestore((injector) => {
434
+ const platformId = injector.get(PLATFORM_ID);
435
+ if (isPlatformServer(platformId))
436
+ return getFirestore(injector.get(FirebaseApp));
437
+ if (!MobileOperationSystemCheckerHelper.isAppleDevice())
438
+ return getFirestore(injector.get(FirebaseApp));
439
+ const firestore = initializeFirestore(injector.get(FirebaseApp), {
440
+ experimentalForceLongPolling: true,
441
+ localCache: memoryLocalCache(),
442
+ });
443
+ return firestore;
444
+ }),
445
+ provideStorage(() => getStorage()),
446
+ ],
447
+ providers: [
448
+ {
449
+ provide: 'FirestoreOptions',
450
+ useFactory: (firestore, platformId) => ({
451
+ firestore,
452
+ interceptors: {
453
+ request: (request) => {
454
+ if (isPlatformBrowser(platformId))
455
+ return request;
456
+ const interval = setInterval(() => { }, 100);
457
+ request.interval = interval;
458
+ return request;
459
+ },
460
+ response: (response, request) => {
461
+ if (isPlatformBrowser(platformId))
462
+ return response;
463
+ clearInterval(request.interval);
464
+ return response;
465
+ },
466
+ },
467
+ }),
468
+ deps: [Firestore, PLATFORM_ID],
469
+ },
470
+ {
471
+ provide: 'BeautyProfileRepository',
472
+ useFactory: (config, userRepository) => {
473
+ return new UserBeautyProfileFirestoreRepository(config, userRepository);
474
+ },
475
+ deps: ['FirestoreOptions', 'UserRepository'],
476
+ },
477
+ {
478
+ provide: 'Buy2WinRepository',
479
+ useFactory: (options) => {
480
+ return new Buy2WinFirestoreRepository(options);
481
+ },
482
+ deps: ['FirestoreOptions'],
483
+ },
484
+ {
485
+ provide: CategoryFirestoreRepository,
486
+ useFactory: (options) => {
487
+ return new CategoryFirestoreRepository(options);
488
+ },
489
+ deps: ['FirestoreOptions'],
490
+ },
491
+ {
492
+ provide: 'CheckoutRepository',
493
+ useFactory: (options) => {
494
+ return new CheckoutFirestoreRepository(options);
495
+ },
496
+ deps: ['FirestoreOptions'],
497
+ },
498
+ {
499
+ provide: 'CheckoutSubscriptionRepository',
500
+ useFactory: (options) => {
501
+ return new CheckoutSubscriptionFirestoreRepository(options);
502
+ },
503
+ deps: ['FirestoreOptions'],
504
+ },
505
+ {
506
+ provide: 'CouponRepository',
507
+ useFactory: (options) => {
508
+ return new CouponFirestoreRepository(options);
509
+ },
510
+ deps: ['FirestoreOptions'],
511
+ },
512
+ {
513
+ provide: 'CampaignHashtagRepository',
514
+ useFactory: (options) => {
515
+ return new CampaignHashtagFirestoreRepository(options);
516
+ },
517
+ deps: ['FirestoreOptions'],
518
+ },
519
+ {
520
+ provide: 'CampaignDashboardRepository',
521
+ useFactory: (options) => {
522
+ return new CampaignDashboardFirestoreRepository(options);
523
+ },
524
+ deps: ['FirestoreOptions'],
525
+ },
526
+ {
527
+ provide: 'EditionRepository',
528
+ useFactory: (options, subscriptionRepository) => {
529
+ return new SubscriptionEditionFirestoreRepository(options, subscriptionRepository);
530
+ },
531
+ deps: ['FirestoreOptions', 'SubscriptionRepository'],
532
+ },
533
+ {
534
+ provide: 'HomeRepository',
535
+ useFactory: (options) => {
536
+ return new HomeFirestoreRepository(options);
537
+ },
538
+ deps: ['FirestoreOptions'],
539
+ },
540
+ {
541
+ provide: 'LeadRepository',
542
+ useFactory: (options) => {
543
+ return new LeadFirestoreRepository(options);
544
+ },
545
+ deps: ['FirestoreOptions'],
546
+ },
547
+ {
548
+ provide: 'LegacyOrderRepository',
549
+ useFactory: (options) => {
550
+ return new LegacyOrderFirestoreRepository(options);
551
+ },
552
+ deps: ['FirestoreOptions'],
553
+ },
554
+ {
555
+ provide: 'ShopMenuRepository',
556
+ useFactory: (options) => {
557
+ return new ShopMenuFirestoreRepository(options);
558
+ },
559
+ deps: ['FirestoreOptions'],
560
+ },
561
+ {
562
+ provide: 'OrderRepository',
563
+ useFactory: (options) => {
564
+ return new OrderFirestoreRepository(options);
565
+ },
566
+ deps: ['FirestoreOptions'],
567
+ },
568
+ {
569
+ provide: 'PaymentRepository',
570
+ useFactory: (options) => {
571
+ return new PaymentFirestoreRepository(options);
572
+ },
573
+ deps: ['FirestoreOptions'],
574
+ },
575
+ {
576
+ provide: ProductFirestoreRepository,
577
+ useFactory: (options) => {
578
+ return new ProductFirestoreRepository(options);
579
+ },
580
+ deps: ['FirestoreOptions'],
581
+ },
582
+ {
583
+ provide: 'ShopSettingsRepository',
584
+ useFactory: (options) => {
585
+ return new ShopSettingsFirestoreRepository(options);
586
+ },
587
+ deps: ['FirestoreOptions'],
588
+ },
589
+ {
590
+ provide: 'SubscriptionPaymentRepository',
591
+ useFactory: (options, subscriptionRepository) => {
592
+ return new SubscriptionPaymentFirestoreRepository(options, subscriptionRepository);
593
+ },
594
+ deps: ['FirestoreOptions', 'SubscriptionRepository'],
595
+ },
596
+ {
597
+ provide: 'SubscriptionPlanRepository',
598
+ useFactory: (options) => {
599
+ return new SubscriptionPlanFirestoreRepository(options);
600
+ },
601
+ deps: ['FirestoreOptions'],
602
+ },
603
+ {
604
+ provide: 'SubscriptionProductRepository',
605
+ useFactory: (options) => {
606
+ return new SubscriptionProductFirestoreRepository(options);
607
+ },
608
+ deps: ['FirestoreOptions'],
609
+ },
610
+ {
611
+ provide: 'SubscriptionRepository',
612
+ useFactory: (options) => {
613
+ return new SubscriptionFirestoreRepository(options);
614
+ },
615
+ deps: ['FirestoreOptions'],
616
+ },
617
+ {
618
+ provide: 'UserRepository',
619
+ useFactory: (options) => {
620
+ return new UserFirestoreRepository(options);
621
+ },
622
+ deps: ['FirestoreOptions'],
623
+ },
624
+ {
625
+ provide: 'UserAddressRepository',
626
+ useFactory: (options, userRepository) => {
627
+ return new UserAddressFirestoreRepository(options, userRepository);
628
+ },
629
+ deps: ['FirestoreOptions', 'UserRepository'],
630
+ },
631
+ {
632
+ provide: 'UserPaymentMethodRepository',
633
+ useFactory: (options, userRepository) => {
634
+ return new UserPaymentMethodFirestoreRepository(options, userRepository);
635
+ },
636
+ deps: ['FirestoreOptions', 'UserRepository'],
637
+ },
638
+ {
639
+ provide: 'SubscriptionMaterializationRepository',
640
+ useFactory: (options) => {
641
+ return new SubscriptionMaterializationFirestoreRepository(options);
642
+ },
643
+ deps: ['FirestoreOptions'],
644
+ },
645
+ {
646
+ provide: 'SubscriptionSummaryRepository',
647
+ useFactory: (options) => {
648
+ return new SubscriptionSummaryFirestoreRepository(options);
649
+ },
650
+ deps: ['FirestoreOptions'],
651
+ },
652
+ {
653
+ provide: ProductVariantFirestoreRepository,
654
+ useFactory: (options, productRepository) => {
655
+ return new ProductVariantFirestoreRepository(options, productRepository);
656
+ },
657
+ deps: ['FirestoreOptions', ProductFirestoreRepository],
658
+ },
659
+ {
660
+ provide: 'FileUploaderService',
661
+ useFactory: (storage, baseUrl) => {
662
+ return new FirebaseFileUploaderService(storage, baseUrl);
663
+ },
664
+ deps: [Storage, STORAGE_BASE_URL],
665
+ },
666
+ ],
667
+ }]
668
668
  }] });
669
669
 
670
- class AngularHasuraGraphQLModule {
671
- static initializeApp(options) {
672
- return {
673
- ngModule: AngularHasuraGraphQLModule,
674
- providers: [{ provide: HASURA_OPTIONS, useValue: options }],
675
- };
676
- }
677
- }
678
- AngularHasuraGraphQLModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: AngularHasuraGraphQLModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
679
- AngularHasuraGraphQLModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.1.0", ngImport: i0, type: AngularHasuraGraphQLModule });
680
- AngularHasuraGraphQLModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: AngularHasuraGraphQLModule, providers: [
681
- {
682
- provide: 'HasuraConfig',
683
- useFactory: (options, platformId) => ({
684
- endpoint: options.endpoint,
685
- authOptions: options.credentials,
686
- interceptors: {
687
- request: (request) => {
688
- if (isPlatformBrowser(platformId))
689
- return request;
690
- const interval = setInterval(() => { }, 100);
691
- request.interval = interval;
692
- return request;
693
- },
694
- response: (response, request) => {
695
- if (isPlatformBrowser(platformId))
696
- return response;
697
- clearInterval(request.interval);
698
- return response;
699
- },
700
- },
701
- }),
702
- deps: [HASURA_OPTIONS, PLATFORM_ID],
703
- },
704
- {
705
- provide: 'CategoryRepository',
706
- useExisting: CategoryHasuraGraphQLRepository,
707
- },
708
- {
709
- provide: CategoryHasuraGraphQLRepository,
710
- useFactory: (options, productRepository, categoryFilterRepository) => {
711
- return new CategoryHasuraGraphQLRepository(options, productRepository, categoryFilterRepository);
712
- },
713
- deps: ['HasuraConfig', ProductHasuraGraphQLRepository, CategoryFilterHasuraGraphQLRepository],
714
- },
715
- {
716
- provide: 'ProductRepository',
717
- useExisting: ProductHasuraGraphQLRepository,
718
- },
719
- {
720
- provide: ProductHasuraGraphQLRepository,
721
- useFactory: (hasuraConfig) => {
722
- return new ProductHasuraGraphQLRepository(hasuraConfig);
723
- },
724
- deps: ['HasuraConfig'],
725
- },
726
- {
727
- provide: 'ProductReviewsRepository',
728
- useExisting: ProductReviewsHasuraGraphQLRepository,
729
- },
730
- {
731
- provide: ProductReviewsHasuraGraphQLRepository,
732
- useFactory: (hasuraConfig) => {
733
- return new ProductReviewsHasuraGraphQLRepository(hasuraConfig);
734
- },
735
- deps: ['HasuraConfig'],
736
- },
737
- {
738
- provide: 'VariantRepository',
739
- useExisting: VariantHasuraGraphQLRepository,
740
- },
741
- {
742
- provide: VariantHasuraGraphQLRepository,
743
- useFactory: (hasuraConfig) => {
744
- return new VariantHasuraGraphQLRepository(hasuraConfig);
745
- },
746
- deps: ['HasuraConfig'],
747
- },
748
- {
749
- provide: 'CategoryFilterRepository',
750
- useExisting: CategoryFilterHasuraGraphQLRepository,
751
- },
752
- {
753
- provide: CategoryFilterHasuraGraphQLRepository,
754
- useFactory: (options) => {
755
- return new CategoryFilterHasuraGraphQLRepository(options);
756
- },
757
- deps: ['HasuraConfig'],
758
- },
759
- {
760
- provide: 'FilterOptionRepository',
761
- useExisting: FilterOptionHasuraGraphQLRepository,
762
- },
763
- {
764
- provide: FilterOptionHasuraGraphQLRepository,
765
- useFactory: (options) => {
766
- return new FilterOptionHasuraGraphQLRepository(options);
767
- },
768
- deps: ['HasuraConfig'],
769
- },
770
- {
771
- provide: 'FilterRepository',
772
- useExisting: FilterHasuraGraphQLRepository,
773
- },
774
- {
775
- provide: FilterHasuraGraphQLRepository,
776
- useFactory: (options, filterOptionRepository, categoryFilterRepository) => {
777
- return new FilterHasuraGraphQLRepository(options, filterOptionRepository, categoryFilterRepository);
778
- },
779
- deps: ['HasuraConfig', FilterOptionHasuraGraphQLRepository, CategoryFilterHasuraGraphQLRepository],
780
- },
781
- {
782
- provide: CategoryCollectionChildrenHasuraGraphQLRepository,
783
- useFactory: (options) => new CategoryCollectionChildrenHasuraGraphQLRepository(options),
784
- deps: ['HasuraConfig'],
785
- },
786
- {
787
- provide: 'CategoryCollectionChildrenRepository',
788
- useExisting: CategoryCollectionChildrenHasuraGraphQLRepository,
789
- },
790
- {
791
- provide: WishlistHasuraGraphQLRepository,
792
- useFactory: (options, categoryFilterRepository) => {
793
- return new WishlistHasuraGraphQLRepository(options, categoryFilterRepository);
794
- },
795
- deps: ['HasuraConfig', CategoryFilterHasuraGraphQLRepository],
796
- },
797
- {
798
- provide: 'WishlistRepository',
799
- useExisting: WishlistHasuraGraphQLRepository,
800
- },
801
- ] });
802
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: AngularHasuraGraphQLModule, decorators: [{
803
- type: NgModule,
804
- args: [{
805
- providers: [
806
- {
807
- provide: 'HasuraConfig',
808
- useFactory: (options, platformId) => ({
809
- endpoint: options.endpoint,
810
- authOptions: options.credentials,
811
- interceptors: {
812
- request: (request) => {
813
- if (isPlatformBrowser(platformId))
814
- return request;
815
- const interval = setInterval(() => { }, 100);
816
- request.interval = interval;
817
- return request;
818
- },
819
- response: (response, request) => {
820
- if (isPlatformBrowser(platformId))
821
- return response;
822
- clearInterval(request.interval);
823
- return response;
824
- },
825
- },
826
- }),
827
- deps: [HASURA_OPTIONS, PLATFORM_ID],
828
- },
829
- {
830
- provide: 'CategoryRepository',
831
- useExisting: CategoryHasuraGraphQLRepository,
832
- },
833
- {
834
- provide: CategoryHasuraGraphQLRepository,
835
- useFactory: (options, productRepository, categoryFilterRepository) => {
836
- return new CategoryHasuraGraphQLRepository(options, productRepository, categoryFilterRepository);
837
- },
838
- deps: ['HasuraConfig', ProductHasuraGraphQLRepository, CategoryFilterHasuraGraphQLRepository],
839
- },
840
- {
841
- provide: 'ProductRepository',
842
- useExisting: ProductHasuraGraphQLRepository,
843
- },
844
- {
845
- provide: ProductHasuraGraphQLRepository,
846
- useFactory: (hasuraConfig) => {
847
- return new ProductHasuraGraphQLRepository(hasuraConfig);
848
- },
849
- deps: ['HasuraConfig'],
850
- },
851
- {
852
- provide: 'ProductReviewsRepository',
853
- useExisting: ProductReviewsHasuraGraphQLRepository,
854
- },
855
- {
856
- provide: ProductReviewsHasuraGraphQLRepository,
857
- useFactory: (hasuraConfig) => {
858
- return new ProductReviewsHasuraGraphQLRepository(hasuraConfig);
859
- },
860
- deps: ['HasuraConfig'],
861
- },
862
- {
863
- provide: 'VariantRepository',
864
- useExisting: VariantHasuraGraphQLRepository,
865
- },
866
- {
867
- provide: VariantHasuraGraphQLRepository,
868
- useFactory: (hasuraConfig) => {
869
- return new VariantHasuraGraphQLRepository(hasuraConfig);
870
- },
871
- deps: ['HasuraConfig'],
872
- },
873
- {
874
- provide: 'CategoryFilterRepository',
875
- useExisting: CategoryFilterHasuraGraphQLRepository,
876
- },
877
- {
878
- provide: CategoryFilterHasuraGraphQLRepository,
879
- useFactory: (options) => {
880
- return new CategoryFilterHasuraGraphQLRepository(options);
881
- },
882
- deps: ['HasuraConfig'],
883
- },
884
- {
885
- provide: 'FilterOptionRepository',
886
- useExisting: FilterOptionHasuraGraphQLRepository,
887
- },
888
- {
889
- provide: FilterOptionHasuraGraphQLRepository,
890
- useFactory: (options) => {
891
- return new FilterOptionHasuraGraphQLRepository(options);
892
- },
893
- deps: ['HasuraConfig'],
894
- },
895
- {
896
- provide: 'FilterRepository',
897
- useExisting: FilterHasuraGraphQLRepository,
898
- },
899
- {
900
- provide: FilterHasuraGraphQLRepository,
901
- useFactory: (options, filterOptionRepository, categoryFilterRepository) => {
902
- return new FilterHasuraGraphQLRepository(options, filterOptionRepository, categoryFilterRepository);
903
- },
904
- deps: ['HasuraConfig', FilterOptionHasuraGraphQLRepository, CategoryFilterHasuraGraphQLRepository],
905
- },
906
- {
907
- provide: CategoryCollectionChildrenHasuraGraphQLRepository,
908
- useFactory: (options) => new CategoryCollectionChildrenHasuraGraphQLRepository(options),
909
- deps: ['HasuraConfig'],
910
- },
911
- {
912
- provide: 'CategoryCollectionChildrenRepository',
913
- useExisting: CategoryCollectionChildrenHasuraGraphQLRepository,
914
- },
915
- {
916
- provide: WishlistHasuraGraphQLRepository,
917
- useFactory: (options, categoryFilterRepository) => {
918
- return new WishlistHasuraGraphQLRepository(options, categoryFilterRepository);
919
- },
920
- deps: ['HasuraConfig', CategoryFilterHasuraGraphQLRepository],
921
- },
922
- {
923
- provide: 'WishlistRepository',
924
- useExisting: WishlistHasuraGraphQLRepository,
925
- },
926
- ],
927
- }]
670
+ class AngularHasuraGraphQLModule {
671
+ static initializeApp(options) {
672
+ return {
673
+ ngModule: AngularHasuraGraphQLModule,
674
+ providers: [{ provide: HASURA_OPTIONS, useValue: options }],
675
+ };
676
+ }
677
+ }
678
+ AngularHasuraGraphQLModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: AngularHasuraGraphQLModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
679
+ AngularHasuraGraphQLModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.1.0", ngImport: i0, type: AngularHasuraGraphQLModule });
680
+ AngularHasuraGraphQLModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: AngularHasuraGraphQLModule, providers: [
681
+ {
682
+ provide: 'HasuraConfig',
683
+ useFactory: (options, platformId) => ({
684
+ endpoint: options.endpoint,
685
+ authOptions: options.credentials,
686
+ interceptors: {
687
+ request: (request) => {
688
+ if (isPlatformBrowser(platformId))
689
+ return request;
690
+ const interval = setInterval(() => { }, 100);
691
+ request.interval = interval;
692
+ return request;
693
+ },
694
+ response: (response, request) => {
695
+ if (isPlatformBrowser(platformId))
696
+ return response;
697
+ clearInterval(request.interval);
698
+ return response;
699
+ },
700
+ },
701
+ }),
702
+ deps: [HASURA_OPTIONS, PLATFORM_ID],
703
+ },
704
+ {
705
+ provide: 'CategoryRepository',
706
+ useExisting: CategoryHasuraGraphQLRepository,
707
+ },
708
+ {
709
+ provide: CategoryHasuraGraphQLRepository,
710
+ useFactory: (options, productRepository, categoryFilterRepository) => {
711
+ return new CategoryHasuraGraphQLRepository(options, productRepository, categoryFilterRepository);
712
+ },
713
+ deps: ['HasuraConfig', ProductHasuraGraphQLRepository, CategoryFilterHasuraGraphQLRepository],
714
+ },
715
+ {
716
+ provide: 'ProductRepository',
717
+ useExisting: ProductHasuraGraphQLRepository,
718
+ },
719
+ {
720
+ provide: ProductHasuraGraphQLRepository,
721
+ useFactory: (hasuraConfig) => {
722
+ return new ProductHasuraGraphQLRepository(hasuraConfig);
723
+ },
724
+ deps: ['HasuraConfig'],
725
+ },
726
+ {
727
+ provide: 'ProductReviewsRepository',
728
+ useExisting: ProductReviewsHasuraGraphQLRepository,
729
+ },
730
+ {
731
+ provide: ProductReviewsHasuraGraphQLRepository,
732
+ useFactory: (hasuraConfig) => {
733
+ return new ProductReviewsHasuraGraphQLRepository(hasuraConfig);
734
+ },
735
+ deps: ['HasuraConfig'],
736
+ },
737
+ {
738
+ provide: 'VariantRepository',
739
+ useExisting: VariantHasuraGraphQLRepository,
740
+ },
741
+ {
742
+ provide: VariantHasuraGraphQLRepository,
743
+ useFactory: (hasuraConfig) => {
744
+ return new VariantHasuraGraphQLRepository(hasuraConfig);
745
+ },
746
+ deps: ['HasuraConfig'],
747
+ },
748
+ {
749
+ provide: 'CategoryFilterRepository',
750
+ useExisting: CategoryFilterHasuraGraphQLRepository,
751
+ },
752
+ {
753
+ provide: CategoryFilterHasuraGraphQLRepository,
754
+ useFactory: (options) => {
755
+ return new CategoryFilterHasuraGraphQLRepository(options);
756
+ },
757
+ deps: ['HasuraConfig'],
758
+ },
759
+ {
760
+ provide: 'FilterOptionRepository',
761
+ useExisting: FilterOptionHasuraGraphQLRepository,
762
+ },
763
+ {
764
+ provide: FilterOptionHasuraGraphQLRepository,
765
+ useFactory: (options) => {
766
+ return new FilterOptionHasuraGraphQLRepository(options);
767
+ },
768
+ deps: ['HasuraConfig'],
769
+ },
770
+ {
771
+ provide: 'FilterRepository',
772
+ useExisting: FilterHasuraGraphQLRepository,
773
+ },
774
+ {
775
+ provide: FilterHasuraGraphQLRepository,
776
+ useFactory: (options, filterOptionRepository, categoryFilterRepository) => {
777
+ return new FilterHasuraGraphQLRepository(options, filterOptionRepository, categoryFilterRepository);
778
+ },
779
+ deps: ['HasuraConfig', FilterOptionHasuraGraphQLRepository, CategoryFilterHasuraGraphQLRepository],
780
+ },
781
+ {
782
+ provide: CategoryCollectionChildrenHasuraGraphQLRepository,
783
+ useFactory: (options) => new CategoryCollectionChildrenHasuraGraphQLRepository(options),
784
+ deps: ['HasuraConfig'],
785
+ },
786
+ {
787
+ provide: 'CategoryCollectionChildrenRepository',
788
+ useExisting: CategoryCollectionChildrenHasuraGraphQLRepository,
789
+ },
790
+ {
791
+ provide: WishlistHasuraGraphQLRepository,
792
+ useFactory: (options, categoryFilterRepository) => {
793
+ return new WishlistHasuraGraphQLRepository(options, categoryFilterRepository);
794
+ },
795
+ deps: ['HasuraConfig', CategoryFilterHasuraGraphQLRepository],
796
+ },
797
+ {
798
+ provide: 'WishlistRepository',
799
+ useExisting: WishlistHasuraGraphQLRepository,
800
+ },
801
+ ] });
802
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: AngularHasuraGraphQLModule, decorators: [{
803
+ type: NgModule,
804
+ args: [{
805
+ providers: [
806
+ {
807
+ provide: 'HasuraConfig',
808
+ useFactory: (options, platformId) => ({
809
+ endpoint: options.endpoint,
810
+ authOptions: options.credentials,
811
+ interceptors: {
812
+ request: (request) => {
813
+ if (isPlatformBrowser(platformId))
814
+ return request;
815
+ const interval = setInterval(() => { }, 100);
816
+ request.interval = interval;
817
+ return request;
818
+ },
819
+ response: (response, request) => {
820
+ if (isPlatformBrowser(platformId))
821
+ return response;
822
+ clearInterval(request.interval);
823
+ return response;
824
+ },
825
+ },
826
+ }),
827
+ deps: [HASURA_OPTIONS, PLATFORM_ID],
828
+ },
829
+ {
830
+ provide: 'CategoryRepository',
831
+ useExisting: CategoryHasuraGraphQLRepository,
832
+ },
833
+ {
834
+ provide: CategoryHasuraGraphQLRepository,
835
+ useFactory: (options, productRepository, categoryFilterRepository) => {
836
+ return new CategoryHasuraGraphQLRepository(options, productRepository, categoryFilterRepository);
837
+ },
838
+ deps: ['HasuraConfig', ProductHasuraGraphQLRepository, CategoryFilterHasuraGraphQLRepository],
839
+ },
840
+ {
841
+ provide: 'ProductRepository',
842
+ useExisting: ProductHasuraGraphQLRepository,
843
+ },
844
+ {
845
+ provide: ProductHasuraGraphQLRepository,
846
+ useFactory: (hasuraConfig) => {
847
+ return new ProductHasuraGraphQLRepository(hasuraConfig);
848
+ },
849
+ deps: ['HasuraConfig'],
850
+ },
851
+ {
852
+ provide: 'ProductReviewsRepository',
853
+ useExisting: ProductReviewsHasuraGraphQLRepository,
854
+ },
855
+ {
856
+ provide: ProductReviewsHasuraGraphQLRepository,
857
+ useFactory: (hasuraConfig) => {
858
+ return new ProductReviewsHasuraGraphQLRepository(hasuraConfig);
859
+ },
860
+ deps: ['HasuraConfig'],
861
+ },
862
+ {
863
+ provide: 'VariantRepository',
864
+ useExisting: VariantHasuraGraphQLRepository,
865
+ },
866
+ {
867
+ provide: VariantHasuraGraphQLRepository,
868
+ useFactory: (hasuraConfig) => {
869
+ return new VariantHasuraGraphQLRepository(hasuraConfig);
870
+ },
871
+ deps: ['HasuraConfig'],
872
+ },
873
+ {
874
+ provide: 'CategoryFilterRepository',
875
+ useExisting: CategoryFilterHasuraGraphQLRepository,
876
+ },
877
+ {
878
+ provide: CategoryFilterHasuraGraphQLRepository,
879
+ useFactory: (options) => {
880
+ return new CategoryFilterHasuraGraphQLRepository(options);
881
+ },
882
+ deps: ['HasuraConfig'],
883
+ },
884
+ {
885
+ provide: 'FilterOptionRepository',
886
+ useExisting: FilterOptionHasuraGraphQLRepository,
887
+ },
888
+ {
889
+ provide: FilterOptionHasuraGraphQLRepository,
890
+ useFactory: (options) => {
891
+ return new FilterOptionHasuraGraphQLRepository(options);
892
+ },
893
+ deps: ['HasuraConfig'],
894
+ },
895
+ {
896
+ provide: 'FilterRepository',
897
+ useExisting: FilterHasuraGraphQLRepository,
898
+ },
899
+ {
900
+ provide: FilterHasuraGraphQLRepository,
901
+ useFactory: (options, filterOptionRepository, categoryFilterRepository) => {
902
+ return new FilterHasuraGraphQLRepository(options, filterOptionRepository, categoryFilterRepository);
903
+ },
904
+ deps: ['HasuraConfig', FilterOptionHasuraGraphQLRepository, CategoryFilterHasuraGraphQLRepository],
905
+ },
906
+ {
907
+ provide: CategoryCollectionChildrenHasuraGraphQLRepository,
908
+ useFactory: (options) => new CategoryCollectionChildrenHasuraGraphQLRepository(options),
909
+ deps: ['HasuraConfig'],
910
+ },
911
+ {
912
+ provide: 'CategoryCollectionChildrenRepository',
913
+ useExisting: CategoryCollectionChildrenHasuraGraphQLRepository,
914
+ },
915
+ {
916
+ provide: WishlistHasuraGraphQLRepository,
917
+ useFactory: (options, categoryFilterRepository) => {
918
+ return new WishlistHasuraGraphQLRepository(options, categoryFilterRepository);
919
+ },
920
+ deps: ['HasuraConfig', CategoryFilterHasuraGraphQLRepository],
921
+ },
922
+ {
923
+ provide: 'WishlistRepository',
924
+ useExisting: WishlistHasuraGraphQLRepository,
925
+ },
926
+ ],
927
+ }]
928
928
  }] });
929
929
 
930
- class AuthService {
931
- constructor(angularFireAuth, userRepository) {
932
- this.angularFireAuth = angularFireAuth;
933
- this.userRepository = userRepository;
934
- }
935
- getAuthstate() {
936
- const observables = [this.getFireUser(), this.getUser()];
937
- return combineLatest(observables).pipe(map(([fireUser, user]) => ({
938
- user,
939
- isAnonymous: fireUser?.isAnonymous,
940
- })));
941
- }
942
- getUser() {
943
- return this.getFireUser().pipe(tap((user) => console.log('connect - getUser', user?.uid)), map((user) => user?.uid), mergeMap((id) => (id ? from(this.userRepository.get({ id })).pipe(catchError(() => of(null))) : of(null))), tap((user) => console.log('connect - getUser after', user)));
944
- }
945
- getTokenId() {
946
- return from(getIdToken(this.angularFireAuth.currentUser));
947
- }
948
- getFireUser() {
949
- return authState(this.angularFireAuth).pipe(tap((user) => console.log('connect - getFireUser', user?.uid)), catchError((error) => {
950
- console.log(error);
951
- return of(null);
952
- }));
953
- }
954
- }
955
- AuthService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: AuthService, deps: [{ token: i1.Auth }, { token: 'UserRepository' }], target: i0.ɵɵFactoryTarget.Injectable });
956
- AuthService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: AuthService });
957
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: AuthService, decorators: [{
958
- type: Injectable
959
- }], ctorParameters: function () { return [{ type: i1.Auth }, { type: undefined, decorators: [{
960
- type: Inject,
961
- args: ['UserRepository']
930
+ class AuthService {
931
+ constructor(angularFireAuth, userRepository) {
932
+ this.angularFireAuth = angularFireAuth;
933
+ this.userRepository = userRepository;
934
+ }
935
+ getAuthstate() {
936
+ const observables = [this.getFireUser(), this.getUser()];
937
+ return combineLatest(observables).pipe(map(([fireUser, user]) => ({
938
+ user,
939
+ isAnonymous: fireUser?.isAnonymous,
940
+ })));
941
+ }
942
+ getUser() {
943
+ return this.getFireUser().pipe(map((user) => user?.uid), mergeMap((id) => (id ? from(this.userRepository.get({ id })).pipe(catchError(() => of(null))) : of(null))));
944
+ }
945
+ getTokenId() {
946
+ return from(getIdToken(this.angularFireAuth.currentUser));
947
+ }
948
+ getFireUser() {
949
+ return authState(this.angularFireAuth).pipe(catchError(() => of(null)));
950
+ }
951
+ }
952
+ AuthService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: AuthService, deps: [{ token: i1.Auth }, { token: 'UserRepository' }], target: i0.ɵɵFactoryTarget.Injectable });
953
+ AuthService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: AuthService });
954
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: AuthService, decorators: [{
955
+ type: Injectable
956
+ }], ctorParameters: function () { return [{ type: i1.Auth }, { type: undefined, decorators: [{
957
+ type: Inject,
958
+ args: ['UserRepository']
962
959
  }] }]; } });
963
960
 
964
- class CouponService {
965
- constructor(couponRepository, defaultShop, orderRepository, categoryRepository) {
966
- this.couponRepository = couponRepository;
967
- this.defaultShop = defaultShop;
968
- this.orderRepository = orderRepository;
969
- this.categoryRepository = categoryRepository;
970
- this.emailIsFromCollaborator = (userEmail) => !!userEmail?.match(/@b4a.com.br/g);
971
- }
972
- checkCoupon(nickname, checkoutType, checkout, plan) {
973
- return from(this.couponRepository
974
- .find({
975
- filters: {
976
- nickname: { operator: Where.EQUALS, value: nickname },
977
- active: { operator: Where.EQUALS, value: true },
978
- },
979
- })
980
- .then((result) => result.data[0])).pipe(concatMap((coupon) => this.couponValidation(coupon, checkoutType)), concatMap((couponValid) => this.couponRulesValidation(couponValid, checkoutType, checkout, plan)), map((couponValidated) => couponValidated));
981
- }
982
- async couponValidation(coupon, checkoutType) {
983
- if (!coupon)
984
- throw 'Cupom inválido.';
985
- if (coupon?.beginAt && coupon?.beginAt.getTime() > new Date().getTime())
986
- throw 'Cupom inválido.';
987
- if (coupon?.expiresIn && coupon?.expiresIn.getTime() < new Date().getTime())
988
- throw 'Cupom expirado.';
989
- const isInShop = coupon.shopAvailability === Shops.ALL || coupon.shopAvailability === this.defaultShop;
990
- if (!isInShop)
991
- throw 'Cupom inválido para loja.';
992
- const isCheckoutType = coupon.checkoutType === CheckoutTypes.ALL || coupon.checkoutType === checkoutType;
993
- if (!isCheckoutType)
994
- throw 'Cupom inválido. Erro de checkout.';
995
- return coupon;
996
- }
997
- async couponRulesValidation(coupon, checkoutType, checkout, plan) {
998
- if (checkoutType == CheckoutTypes.SUBSCRIPTION) {
999
- if (coupon.plan && coupon.plan.toUpperCase() !== plan.toUpperCase())
1000
- throw 'Cupom inválido para sua assinatura.';
1001
- return coupon;
1002
- }
1003
- const validUser = this.coupomUserValidation(coupon, checkout?.user);
1004
- if (!validUser)
1005
- throw 'Usuário não elegível.';
1006
- const couponUseLimits = this.getCouponUseLimits(coupon, checkoutType, checkout.user);
1007
- if (couponUseLimits.firstOrder) {
1008
- const ordersUser = await this.getOrdersFromUser(checkout.user.email.toLocaleLowerCase());
1009
- if (couponUseLimits.firstOrder && ordersUser.length >= 1)
1010
- throw 'Limite de uso atingido';
1011
- }
1012
- if (!couponUseLimits.unlimited || couponUseLimits.limitedPerUser) {
1013
- const orders = await this.getOrdersWithCoupon(coupon);
1014
- if (!couponUseLimits.unlimited && couponUseLimits.total && orders.length >= couponUseLimits.total)
1015
- throw 'Limite de uso atingido.';
1016
- if (couponUseLimits.limitedPerUser) {
1017
- const ordersWithUser = this.countOrdersWithUser(orders, checkout.user.email);
1018
- if (ordersWithUser > 0)
1019
- throw 'Limite de uso por usuário atingido.';
1020
- }
1021
- }
1022
- const hasProductCategories = await this.hasProductCategories(coupon, checkout);
1023
- if (!hasProductCategories)
1024
- throw 'Seu carrinho não possui produtos elegíveis para desconto.';
1025
- const hasMinSubTotal = await this.hasMinSubTotal(coupon, checkout);
1026
- if (!hasMinSubTotal)
1027
- throw `Valor mínimo de ${Intl.NumberFormat('pt-BR', { style: 'currency', currency: 'BRL' }).format(coupon.minSubTotalValue)} não atingido`;
1028
- return coupon;
1029
- }
1030
- calcDiscountSubscription(coupon, checkout) {
1031
- let discount = 0;
1032
- if (coupon.discount.subscription.type == CouponTypes.ABSOLUTE)
1033
- discount = coupon.discount.subscription.value;
1034
- else
1035
- discount = checkout.subscriptionPlan.recurrencePrice * (coupon.discount.subscription.value / 100);
1036
- return of(discount);
1037
- }
1038
- async calcDiscountShopping(coupon, checkout) {
1039
- let discount = 0;
1040
- if (checkout.user.isSubscriber && coupon.discount.subscriber.value) {
1041
- discount = await this.calcDiscountByType(coupon.discount.subscriber.type, coupon.discount.subscriber.value, coupon.productsCategories, checkout);
1042
- }
1043
- else {
1044
- discount = await this.calcDiscountByType(coupon.discount.non_subscriber.type, coupon.discount.non_subscriber.value, coupon.productsCategories, checkout);
1045
- }
1046
- return discount;
1047
- }
1048
- async calcDiscountByType(type, value, categories, checkout) {
1049
- let discount = 0;
1050
- let lineItensDiscount = await this.getLineItensEligebleForDiscount(categories, checkout);
1051
- const subTotal = this.calcCheckoutSubtotal(lineItensDiscount, checkout.user, checkout.shop);
1052
- if (type == CouponTypes.ABSOLUTE) {
1053
- discount = value > subTotal ? subTotal : value;
1054
- }
1055
- else {
1056
- discount = subTotal * (value / 100);
1057
- }
1058
- return discount;
1059
- }
1060
- async hasMinSubTotal(coupon, checkout) {
1061
- if (!coupon.minSubTotalValue)
1062
- return true;
1063
- let lineItensDiscount = await this.getLineItensEligebleForDiscount(coupon.productsCategories, checkout);
1064
- const subTotal = this.calcCheckoutSubtotal(lineItensDiscount, checkout.user, checkout.shop);
1065
- if (coupon.minSubTotalValue <= subTotal)
1066
- return true;
1067
- return false;
1068
- }
1069
- async hasProductCategories(coupon, checkout) {
1070
- if (!coupon.productsCategories || !coupon.productsCategories.length) {
1071
- return true;
1072
- }
1073
- const couponCategories = await this.getCouponCategoriesId(coupon.productsCategories);
1074
- const hasCategories = checkout.lineItems?.filter((i) => {
1075
- if (!i.categories || !i.categories?.length)
1076
- return true;
1077
- return i.categories.some((c) => couponCategories.some((cat) => cat == c));
1078
- });
1079
- return hasCategories.length ? true : false;
1080
- }
1081
- coupomUserValidation(coupon, user) {
1082
- if (!user || coupon.exclusivityType.includes(Exclusivities.ALL_USERS))
1083
- return true;
1084
- let userTypes = [];
1085
- if (coupon.exclusivityType.includes(Exclusivities.COLLABORATORS) &&
1086
- this.emailIsFromCollaborator(user.email.toLocaleLowerCase()))
1087
- userTypes.push(Exclusivities.COLLABORATORS);
1088
- if (coupon.exclusivityType.includes(Exclusivities.SPECIFIC_USER) &&
1089
- coupon.userExclusiveEmail.includes(user.email.toLocaleLowerCase()))
1090
- userTypes.push(Exclusivities.SPECIFIC_USER);
1091
- if (coupon.exclusivityType.includes(Exclusivities.ACTIVE_SUBSCRIBER) &&
1092
- user.isSubscriber &&
1093
- user.subscriptionPlan != '')
1094
- userTypes.push(Exclusivities.ACTIVE_SUBSCRIBER);
1095
- if (user.isSubscriber &&
1096
- user.subscriptionPlan == '' &&
1097
- coupon.exclusivityType.includes(Exclusivities.INACTIVE_SUBSCRIBER))
1098
- userTypes.push(Exclusivities.INACTIVE_SUBSCRIBER);
1099
- if (coupon.exclusivityType.includes(Exclusivities.NON_SUBSCRIBER) && !user.isSubscriber)
1100
- userTypes.push(Exclusivities.NON_SUBSCRIBER);
1101
- return coupon.exclusivityType.some((r) => userTypes.includes(r));
1102
- }
1103
- async getCouponCategoriesId(productsCategories) {
1104
- const couponCategories = [];
1105
- for (let index = 0; index < productsCategories.length; index++) {
1106
- const category = await this.categoryRepository.get({
1107
- id: productsCategories[index],
1108
- });
1109
- if (category) {
1110
- const children = await this.categoryRepository.getChildren(parseInt(productsCategories[index]));
1111
- couponCategories.push(category.id, ...children.map((c) => c.id.toString()));
1112
- }
1113
- }
1114
- return [...new Set(couponCategories)];
1115
- }
1116
- async getLineItensEligebleForDiscount(productsCategories, checkout) {
1117
- let lineItensDiscount = [];
1118
- const couponCategories = await this.getCouponCategoriesId(productsCategories);
1119
- if (productsCategories && productsCategories.length) {
1120
- lineItensDiscount = checkout.lineItems?.filter((i) => {
1121
- if (i.categories?.length) {
1122
- return i.categories.some((c) => couponCategories.some((cat) => cat == c));
1123
- }
1124
- return true;
1125
- });
1126
- }
1127
- else {
1128
- lineItensDiscount = checkout.lineItems;
1129
- }
1130
- return lineItensDiscount;
1131
- }
1132
- calcCheckoutSubtotal(lineItens, user, shop) {
1133
- return (lineItens?.reduce((acc, curr) => user?.isSubscriber && curr.price.subscriberPrice
1134
- ? acc + curr.price?.subscriberPrice * curr.quantity
1135
- : acc + curr.pricePaid * curr.quantity, 0) || 0);
1136
- }
1137
- async getOrdersWithCoupon(coupon) {
1138
- return await this.orderRepository
1139
- .find({
1140
- filters: {
1141
- coupon: { id: coupon.id },
1142
- payment: { status: 'paid' },
1143
- },
1144
- })
1145
- .then((result) => result.data);
1146
- }
1147
- async getOrdersFromUser(email) {
1148
- return await this.orderRepository
1149
- .find({
1150
- filters: {
1151
- user: { email: { operator: Where.EQUALS, value: email } },
1152
- payment: { status: 'paid' },
1153
- },
1154
- })
1155
- .then((result) => result.data);
1156
- }
1157
- countOrdersWithUser(orders, email) {
1158
- return orders.filter((o) => o.user.email == email).length;
1159
- }
1160
- getCouponUseLimits(coupon, checkoutType, user) {
1161
- let couponUseLimits;
1162
- if (checkoutType == CheckoutTypes.ECOMMERCE || checkoutType == CheckoutTypes.ALL) {
1163
- couponUseLimits = user && user.isSubscriber ? coupon.useLimits.subscriber : coupon.useLimits.non_subscriber;
1164
- }
1165
- else {
1166
- couponUseLimits = coupon.useLimits.subscription;
1167
- }
1168
- return couponUseLimits;
1169
- }
1170
- }
1171
- CouponService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: CouponService, deps: [{ token: 'CouponRepository' }, { token: DEFAULT_SHOP }, { token: 'OrderRepository' }, { token: 'CategoryRepository' }], target: i0.ɵɵFactoryTarget.Injectable });
1172
- CouponService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: CouponService, providedIn: 'root' });
1173
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: CouponService, decorators: [{
1174
- type: Injectable,
1175
- args: [{
1176
- providedIn: 'root',
1177
- }]
1178
- }], ctorParameters: function () { return [{ type: undefined, decorators: [{
1179
- type: Inject,
1180
- args: ['CouponRepository']
1181
- }] }, { type: i1$2.Shops, decorators: [{
1182
- type: Inject,
1183
- args: [DEFAULT_SHOP]
1184
- }] }, { type: undefined, decorators: [{
1185
- type: Inject,
1186
- args: ['OrderRepository']
1187
- }] }, { type: undefined, decorators: [{
1188
- type: Inject,
1189
- args: ['CategoryRepository']
961
+ class CouponService {
962
+ constructor(couponRepository, defaultShop, orderRepository, categoryRepository) {
963
+ this.couponRepository = couponRepository;
964
+ this.defaultShop = defaultShop;
965
+ this.orderRepository = orderRepository;
966
+ this.categoryRepository = categoryRepository;
967
+ this.emailIsFromCollaborator = (userEmail) => !!userEmail?.match(/@b4a.com.br/g);
968
+ }
969
+ checkCoupon(nickname, checkoutType, checkout, plan) {
970
+ return from(this.couponRepository
971
+ .find({
972
+ filters: {
973
+ nickname: { operator: Where.EQUALS, value: nickname },
974
+ active: { operator: Where.EQUALS, value: true },
975
+ },
976
+ })
977
+ .then((result) => result.data[0])).pipe(concatMap((coupon) => this.couponValidation(coupon, checkoutType)), concatMap((couponValid) => this.couponRulesValidation(couponValid, checkoutType, checkout, plan)), map((couponValidated) => couponValidated));
978
+ }
979
+ async couponValidation(coupon, checkoutType) {
980
+ if (!coupon)
981
+ throw 'Cupom inválido.';
982
+ if (coupon?.beginAt && coupon?.beginAt.getTime() > new Date().getTime())
983
+ throw 'Cupom inválido.';
984
+ if (coupon?.expiresIn && coupon?.expiresIn.getTime() < new Date().getTime())
985
+ throw 'Cupom expirado.';
986
+ const isInShop = coupon.shopAvailability === Shops.ALL || coupon.shopAvailability === this.defaultShop;
987
+ if (!isInShop)
988
+ throw 'Cupom inválido para loja.';
989
+ const isCheckoutType = coupon.checkoutType === CheckoutTypes.ALL || coupon.checkoutType === checkoutType;
990
+ if (!isCheckoutType)
991
+ throw 'Cupom inválido. Erro de checkout.';
992
+ return coupon;
993
+ }
994
+ async couponRulesValidation(coupon, checkoutType, checkout, plan) {
995
+ if (checkoutType == CheckoutTypes.SUBSCRIPTION) {
996
+ if (coupon.plan && coupon.plan.toUpperCase() !== plan.toUpperCase())
997
+ throw 'Cupom inválido para sua assinatura.';
998
+ return coupon;
999
+ }
1000
+ const validUser = this.coupomUserValidation(coupon, checkout?.user);
1001
+ if (!validUser)
1002
+ throw 'Usuário não elegível.';
1003
+ const couponUseLimits = this.getCouponUseLimits(coupon, checkoutType, checkout.user);
1004
+ if (couponUseLimits.firstOrder) {
1005
+ const ordersUser = await this.getOrdersFromUser(checkout.user.email.toLocaleLowerCase());
1006
+ if (couponUseLimits.firstOrder && ordersUser.length >= 1)
1007
+ throw 'Limite de uso atingido';
1008
+ }
1009
+ if (!couponUseLimits.unlimited || couponUseLimits.limitedPerUser) {
1010
+ const orders = await this.getOrdersWithCoupon(coupon);
1011
+ if (!couponUseLimits.unlimited && couponUseLimits.total && orders.length >= couponUseLimits.total)
1012
+ throw 'Limite de uso atingido.';
1013
+ if (couponUseLimits.limitedPerUser) {
1014
+ const ordersWithUser = this.countOrdersWithUser(orders, checkout.user.email);
1015
+ if (ordersWithUser > 0)
1016
+ throw 'Limite de uso por usuário atingido.';
1017
+ }
1018
+ }
1019
+ const hasProductCategories = await this.hasProductCategories(coupon, checkout);
1020
+ if (!hasProductCategories)
1021
+ throw 'Seu carrinho não possui produtos elegíveis para desconto.';
1022
+ const hasMinSubTotal = await this.hasMinSubTotal(coupon, checkout);
1023
+ if (!hasMinSubTotal)
1024
+ throw `Valor mínimo de ${Intl.NumberFormat('pt-BR', { style: 'currency', currency: 'BRL' }).format(coupon.minSubTotalValue)} não atingido`;
1025
+ return coupon;
1026
+ }
1027
+ calcDiscountSubscription(coupon, checkout) {
1028
+ let discount = 0;
1029
+ if (coupon.discount.subscription.type == CouponTypes.ABSOLUTE)
1030
+ discount = coupon.discount.subscription.value;
1031
+ else
1032
+ discount = checkout.subscriptionPlan.recurrencePrice * (coupon.discount.subscription.value / 100);
1033
+ return of(discount);
1034
+ }
1035
+ async calcDiscountShopping(coupon, checkout) {
1036
+ let discount = 0;
1037
+ if (checkout.user.isSubscriber && coupon.discount.subscriber.value) {
1038
+ discount = await this.calcDiscountByType(coupon.discount.subscriber.type, coupon.discount.subscriber.value, coupon.productsCategories, checkout);
1039
+ }
1040
+ else {
1041
+ discount = await this.calcDiscountByType(coupon.discount.non_subscriber.type, coupon.discount.non_subscriber.value, coupon.productsCategories, checkout);
1042
+ }
1043
+ return discount;
1044
+ }
1045
+ async calcDiscountByType(type, value, categories, checkout) {
1046
+ let discount = 0;
1047
+ let lineItensDiscount = await this.getLineItensEligebleForDiscount(categories, checkout);
1048
+ const subTotal = this.calcCheckoutSubtotal(lineItensDiscount, checkout.user, checkout.shop);
1049
+ if (type == CouponTypes.ABSOLUTE) {
1050
+ discount = value > subTotal ? subTotal : value;
1051
+ }
1052
+ else {
1053
+ discount = subTotal * (value / 100);
1054
+ }
1055
+ return discount;
1056
+ }
1057
+ async hasMinSubTotal(coupon, checkout) {
1058
+ if (!coupon.minSubTotalValue)
1059
+ return true;
1060
+ let lineItensDiscount = await this.getLineItensEligebleForDiscount(coupon.productsCategories, checkout);
1061
+ const subTotal = this.calcCheckoutSubtotal(lineItensDiscount, checkout.user, checkout.shop);
1062
+ if (coupon.minSubTotalValue <= subTotal)
1063
+ return true;
1064
+ return false;
1065
+ }
1066
+ async hasProductCategories(coupon, checkout) {
1067
+ if (!coupon.productsCategories || !coupon.productsCategories.length) {
1068
+ return true;
1069
+ }
1070
+ const couponCategories = await this.getCouponCategoriesId(coupon.productsCategories);
1071
+ const hasCategories = checkout.lineItems?.filter((i) => {
1072
+ if (!i.categories || !i.categories?.length)
1073
+ return true;
1074
+ return i.categories.some((c) => couponCategories.some((cat) => cat == c));
1075
+ });
1076
+ return hasCategories.length ? true : false;
1077
+ }
1078
+ coupomUserValidation(coupon, user) {
1079
+ if (!user || coupon.exclusivityType.includes(Exclusivities.ALL_USERS))
1080
+ return true;
1081
+ let userTypes = [];
1082
+ if (coupon.exclusivityType.includes(Exclusivities.COLLABORATORS) &&
1083
+ this.emailIsFromCollaborator(user.email.toLocaleLowerCase()))
1084
+ userTypes.push(Exclusivities.COLLABORATORS);
1085
+ if (coupon.exclusivityType.includes(Exclusivities.SPECIFIC_USER) &&
1086
+ coupon.userExclusiveEmail.includes(user.email.toLocaleLowerCase()))
1087
+ userTypes.push(Exclusivities.SPECIFIC_USER);
1088
+ if (coupon.exclusivityType.includes(Exclusivities.ACTIVE_SUBSCRIBER) &&
1089
+ user.isSubscriber &&
1090
+ user.subscriptionPlan != '')
1091
+ userTypes.push(Exclusivities.ACTIVE_SUBSCRIBER);
1092
+ if (user.isSubscriber &&
1093
+ user.subscriptionPlan == '' &&
1094
+ coupon.exclusivityType.includes(Exclusivities.INACTIVE_SUBSCRIBER))
1095
+ userTypes.push(Exclusivities.INACTIVE_SUBSCRIBER);
1096
+ if (coupon.exclusivityType.includes(Exclusivities.NON_SUBSCRIBER) && !user.isSubscriber)
1097
+ userTypes.push(Exclusivities.NON_SUBSCRIBER);
1098
+ return coupon.exclusivityType.some((r) => userTypes.includes(r));
1099
+ }
1100
+ async getCouponCategoriesId(productsCategories) {
1101
+ const couponCategories = [];
1102
+ for (let index = 0; index < productsCategories.length; index++) {
1103
+ const category = await this.categoryRepository.get({
1104
+ id: productsCategories[index],
1105
+ });
1106
+ if (category) {
1107
+ const children = await this.categoryRepository.getChildren(parseInt(productsCategories[index]));
1108
+ couponCategories.push(category.id, ...children.map((c) => c.id.toString()));
1109
+ }
1110
+ }
1111
+ return [...new Set(couponCategories)];
1112
+ }
1113
+ async getLineItensEligebleForDiscount(productsCategories, checkout) {
1114
+ let lineItensDiscount = [];
1115
+ const couponCategories = await this.getCouponCategoriesId(productsCategories);
1116
+ if (productsCategories && productsCategories.length) {
1117
+ lineItensDiscount = checkout.lineItems?.filter((i) => {
1118
+ if (i.categories?.length) {
1119
+ return i.categories.some((c) => couponCategories.some((cat) => cat == c));
1120
+ }
1121
+ return true;
1122
+ });
1123
+ }
1124
+ else {
1125
+ lineItensDiscount = checkout.lineItems;
1126
+ }
1127
+ return lineItensDiscount;
1128
+ }
1129
+ calcCheckoutSubtotal(lineItens, user, shop) {
1130
+ return (lineItens?.reduce((acc, curr) => user?.isSubscriber && curr.price.subscriberPrice
1131
+ ? acc + curr.price?.subscriberPrice * curr.quantity
1132
+ : acc + curr.pricePaid * curr.quantity, 0) || 0);
1133
+ }
1134
+ async getOrdersWithCoupon(coupon) {
1135
+ return await this.orderRepository
1136
+ .find({
1137
+ filters: {
1138
+ coupon: { id: coupon.id },
1139
+ payment: { status: 'paid' },
1140
+ },
1141
+ })
1142
+ .then((result) => result.data);
1143
+ }
1144
+ async getOrdersFromUser(email) {
1145
+ return await this.orderRepository
1146
+ .find({
1147
+ filters: {
1148
+ user: { email: { operator: Where.EQUALS, value: email } },
1149
+ payment: { status: 'paid' },
1150
+ },
1151
+ })
1152
+ .then((result) => result.data);
1153
+ }
1154
+ countOrdersWithUser(orders, email) {
1155
+ return orders.filter((o) => o.user.email == email).length;
1156
+ }
1157
+ getCouponUseLimits(coupon, checkoutType, user) {
1158
+ let couponUseLimits;
1159
+ if (checkoutType == CheckoutTypes.ECOMMERCE || checkoutType == CheckoutTypes.ALL) {
1160
+ couponUseLimits = user && user.isSubscriber ? coupon.useLimits.subscriber : coupon.useLimits.non_subscriber;
1161
+ }
1162
+ else {
1163
+ couponUseLimits = coupon.useLimits.subscription;
1164
+ }
1165
+ return couponUseLimits;
1166
+ }
1167
+ }
1168
+ CouponService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: CouponService, deps: [{ token: 'CouponRepository' }, { token: DEFAULT_SHOP }, { token: 'OrderRepository' }, { token: 'CategoryRepository' }], target: i0.ɵɵFactoryTarget.Injectable });
1169
+ CouponService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: CouponService, providedIn: 'root' });
1170
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: CouponService, decorators: [{
1171
+ type: Injectable,
1172
+ args: [{
1173
+ providedIn: 'root',
1174
+ }]
1175
+ }], ctorParameters: function () { return [{ type: undefined, decorators: [{
1176
+ type: Inject,
1177
+ args: ['CouponRepository']
1178
+ }] }, { type: i1$2.Shops, decorators: [{
1179
+ type: Inject,
1180
+ args: [DEFAULT_SHOP]
1181
+ }] }, { type: undefined, decorators: [{
1182
+ type: Inject,
1183
+ args: ['OrderRepository']
1184
+ }] }, { type: undefined, decorators: [{
1185
+ type: Inject,
1186
+ args: ['CategoryRepository']
1190
1187
  }] }]; } });
1191
1188
 
1192
- class CheckoutService {
1193
- constructor(couponService, checkoutRepository, orderRepository, userRepository, defaultShop) {
1194
- this.couponService = couponService;
1195
- this.checkoutRepository = checkoutRepository;
1196
- this.orderRepository = orderRepository;
1197
- this.userRepository = userRepository;
1198
- this.defaultShop = defaultShop;
1199
- }
1200
- getCheckout(checkoutData) {
1201
- const checkoutId = cookie.get('checkoutId');
1202
- if (!isNil(checkoutId))
1203
- return from(this.checkoutRepository.get({ id: checkoutId }));
1204
- return from(this.createCheckout(checkoutData));
1205
- }
1206
- getUserByCheckout(checkoutId) {
1207
- return from(this.checkoutRepository.get({ id: checkoutId })).pipe(concatMap((checkout) => checkout?.user?.id ? of(checkout.user) : from(this.userRepository.get({ id: checkout.user.id }))), concatMap((user) => of(user) || throwError(() => new NotFoundError('User is not found'))));
1208
- }
1209
- updateCheckoutLineItems(checkout) {
1210
- return from(this.checkoutRepository.update(Checkout.toInstance({ id: checkout.id, lineItems: checkout.lineItems })));
1211
- }
1212
- updateCheckoutUser(checkout) {
1213
- return from(this.checkoutRepository.update(Checkout.toInstance({ id: checkout.id, user: checkout.user })));
1214
- }
1215
- clearCheckoutFromSession() {
1216
- cookie.remove('checkoutId');
1217
- return of();
1218
- }
1219
- calcDiscount(coupon) {
1220
- return this.getCheckout().pipe(concatMap(async (checkout) => await this.couponService.calcDiscountShopping(coupon, checkout)));
1221
- }
1222
- checkCoupon(nickname, checkoutType) {
1223
- return this.getCheckout().pipe(concatMap((checkout) => this.couponService.checkCoupon(nickname, CheckoutTypes.ECOMMERCE, checkout, null).pipe()));
1224
- }
1225
- async createCheckout(checkoutData) {
1226
- const checkout = await this.checkoutRepository.create({
1227
- createdAt: new Date(),
1228
- ...Checkout.toInstance(pick(checkoutData, ['user', 'shop'])).toPlain(),
1229
- shop: checkoutData?.shop || this.defaultShop,
1230
- });
1231
- cookie.set('checkoutId', checkout.id);
1232
- return checkout;
1233
- }
1234
- }
1235
- CheckoutService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: CheckoutService, deps: [{ token: CouponService }, { token: 'CheckoutRepository' }, { token: 'OrderRepository' }, { token: 'UserRepository' }, { token: DEFAULT_SHOP }], target: i0.ɵɵFactoryTarget.Injectable });
1236
- CheckoutService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: CheckoutService });
1237
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: CheckoutService, decorators: [{
1238
- type: Injectable
1239
- }], ctorParameters: function () { return [{ type: CouponService }, { type: undefined, decorators: [{
1240
- type: Inject,
1241
- args: ['CheckoutRepository']
1242
- }] }, { type: undefined, decorators: [{
1243
- type: Inject,
1244
- args: ['OrderRepository']
1245
- }] }, { type: undefined, decorators: [{
1246
- type: Inject,
1247
- args: ['UserRepository']
1248
- }] }, { type: i1$2.Shops, decorators: [{
1249
- type: Inject,
1250
- args: [DEFAULT_SHOP]
1189
+ class CheckoutService {
1190
+ constructor(couponService, checkoutRepository, orderRepository, userRepository, defaultShop) {
1191
+ this.couponService = couponService;
1192
+ this.checkoutRepository = checkoutRepository;
1193
+ this.orderRepository = orderRepository;
1194
+ this.userRepository = userRepository;
1195
+ this.defaultShop = defaultShop;
1196
+ }
1197
+ getCheckout(checkoutData) {
1198
+ const checkoutId = cookie.get('checkoutId');
1199
+ if (!isNil(checkoutId))
1200
+ return from(this.checkoutRepository.get({ id: checkoutId }));
1201
+ return from(this.createCheckout(checkoutData));
1202
+ }
1203
+ getUserByCheckout(checkoutId) {
1204
+ return from(this.checkoutRepository.get({ id: checkoutId })).pipe(concatMap((checkout) => checkout?.user?.id ? of(checkout.user) : from(this.userRepository.get({ id: checkout.user.id }))), concatMap((user) => of(user) || throwError(() => new NotFoundError('User is not found'))));
1205
+ }
1206
+ updateCheckoutLineItems(checkout) {
1207
+ return from(this.checkoutRepository.update(Checkout.toInstance({ id: checkout.id, lineItems: checkout.lineItems })));
1208
+ }
1209
+ updateCheckoutUser(checkout) {
1210
+ return from(this.checkoutRepository.update(Checkout.toInstance({ id: checkout.id, user: checkout.user })));
1211
+ }
1212
+ clearCheckoutFromSession() {
1213
+ cookie.remove('checkoutId');
1214
+ return of();
1215
+ }
1216
+ calcDiscount(coupon) {
1217
+ return this.getCheckout().pipe(concatMap(async (checkout) => await this.couponService.calcDiscountShopping(coupon, checkout)));
1218
+ }
1219
+ checkCoupon(nickname, checkoutType) {
1220
+ return this.getCheckout().pipe(concatMap((checkout) => this.couponService.checkCoupon(nickname, CheckoutTypes.ECOMMERCE, checkout, null).pipe()));
1221
+ }
1222
+ async createCheckout(checkoutData) {
1223
+ const checkout = await this.checkoutRepository.create({
1224
+ createdAt: new Date(),
1225
+ ...Checkout.toInstance(pick(checkoutData, ['user', 'shop'])).toPlain(),
1226
+ shop: checkoutData?.shop || this.defaultShop,
1227
+ });
1228
+ cookie.set('checkoutId', checkout.id);
1229
+ return checkout;
1230
+ }
1231
+ }
1232
+ CheckoutService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: CheckoutService, deps: [{ token: CouponService }, { token: 'CheckoutRepository' }, { token: 'OrderRepository' }, { token: 'UserRepository' }, { token: DEFAULT_SHOP }], target: i0.ɵɵFactoryTarget.Injectable });
1233
+ CheckoutService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: CheckoutService });
1234
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: CheckoutService, decorators: [{
1235
+ type: Injectable
1236
+ }], ctorParameters: function () { return [{ type: CouponService }, { type: undefined, decorators: [{
1237
+ type: Inject,
1238
+ args: ['CheckoutRepository']
1239
+ }] }, { type: undefined, decorators: [{
1240
+ type: Inject,
1241
+ args: ['OrderRepository']
1242
+ }] }, { type: undefined, decorators: [{
1243
+ type: Inject,
1244
+ args: ['UserRepository']
1245
+ }] }, { type: i1$2.Shops, decorators: [{
1246
+ type: Inject,
1247
+ args: [DEFAULT_SHOP]
1251
1248
  }] }]; } });
1252
1249
 
1253
- class CartService {
1254
- constructor(authService, checkoutService, defaultShop, productRepository, categoryRepository, variantRepository, buy2WinRepository) {
1255
- this.authService = authService;
1256
- this.checkoutService = checkoutService;
1257
- this.defaultShop = defaultShop;
1258
- this.productRepository = productRepository;
1259
- this.categoryRepository = categoryRepository;
1260
- this.variantRepository = variantRepository;
1261
- this.buy2WinRepository = buy2WinRepository;
1262
- this.cartSubject = new Subject();
1263
- this.updateLineItemInCart = (lineItem, quantity, checkout) => (isNil(checkout) ? this.checkoutService.getCheckout() : of(checkout)).pipe(concatMap((checkoutLoaded) => {
1264
- const items = [];
1265
- const index = checkoutLoaded.lineItems?.map((checkoutItem) => checkoutItem.id).indexOf(lineItem.id);
1266
- if (index > -1) {
1267
- checkoutLoaded.lineItems[index].quantity += quantity;
1268
- checkoutLoaded.lineItems[index].pricePaid = lineItem.pricePaid;
1269
- }
1270
- else
1271
- checkoutLoaded.lineItems = items.concat(checkoutLoaded.lineItems ? checkoutLoaded.lineItems.concat([lineItem]) : [lineItem]);
1272
- return this.checkoutService
1273
- .updateCheckoutLineItems(checkoutLoaded)
1274
- .pipe(map((updatedCheckout) => this.generateCartObject(updatedCheckout.lineItems)));
1275
- }));
1276
- this.generateCartObject = (items) => items?.reduce((cart, item) => ({
1277
- ...cart,
1278
- [item.id]: LineItem.toInstance({
1279
- ...(cart[item.id] || item),
1280
- quantity: (cart[item.id]?.quantity || 0) + (item.quantity ? item.quantity : 1),
1281
- }),
1282
- }), {}) || {};
1283
- this.buildLineItem = async ({ checkout, item, quantity, }) => {
1284
- const product = await this.getProductData(item.id);
1285
- item.quantity = item?.quantity || checkout?.lineItems?.find((lineItem) => lineItem.id === item.id)?.quantity || 0;
1286
- if (this.checkMaxStock(item, quantity || 0))
1287
- throw new Error('Desculpe! Temos apenas ' + item.stock?.quantity + ' em estoque.');
1288
- const image = item.image || item.images?.shift();
1289
- const { id, name, EAN, slug, stock, price, weight, sku, type } = item;
1290
- const isGift = item.isGift || null;
1291
- const pricePaid = this.getProductPrice({
1292
- product: item,
1293
- shop: checkout.shop || this.defaultShop,
1294
- isSubscriber: checkout.user?.isSubscriber,
1295
- });
1296
- RoundProductPricesHelper.roundProductPrices(item);
1297
- return {
1298
- checkout,
1299
- lineItem: LineItem.toInstance({
1300
- id,
1301
- name: name ?? product.name,
1302
- EAN: EAN ?? product.EAN,
1303
- brand: product.brand,
1304
- slug: slug ?? product.slug,
1305
- sku: sku ?? product.sku,
1306
- stock,
1307
- price: this.roundPrice(price),
1308
- image,
1309
- weight: weight ?? product.weight,
1310
- quantity: (item.quantity || 0) + (quantity || 0),
1311
- pricePaid,
1312
- categories: product.categories ?? [],
1313
- isGift: isGift ?? null,
1314
- costPrice: product.costPrice ?? 0,
1315
- type,
1316
- }),
1317
- };
1318
- };
1319
- this.getProductPrice = ({ product, isSubscriber, }) => {
1320
- const info = product.price;
1321
- if (product.isGift)
1322
- return 0;
1323
- return isSubscriber && info.subscriberPrice > 0
1324
- ? Number(info.subscriberPrice.toFixed(2))
1325
- : Number(info.price.toFixed(2));
1326
- };
1327
- this.checkMaxStock = (item, quantity) => {
1328
- const maxStock = item.stock?.quantity || 0;
1329
- const currentItemAmount = item.quantity || 0;
1330
- return currentItemAmount + quantity > maxStock;
1331
- };
1332
- }
1333
- addItem(item, quantity = 1) {
1334
- return from(this.checkoutService.getCheckout()).pipe(concatMap(async (checkout) => await this.buildLineItem({ checkout, item, quantity: quantity || 1 })), mergeMap(({ checkout, lineItem }) => this.updateLineItemInCart(lineItem, quantity || 1, checkout)), tap((cart) => this.cartSubject.next(cart)));
1335
- }
1336
- decreaseItem(item) {
1337
- return this.checkoutService.getCheckout().pipe(map((checkout) => {
1338
- const checkoutItem = checkout.lineItems?.find((lineItem) => lineItem.id === item.id);
1339
- if (!isNil(checkoutItem))
1340
- checkoutItem.quantity -= checkoutItem.quantity > 1 ? 1 : 0;
1341
- return checkout;
1342
- }), concatMap((checkout) => this.checkoutService.updateCheckoutLineItems(checkout)), map((checkout) => this.generateCartObject(checkout.lineItems)), tap((cart) => this.cartSubject.next(cart)));
1343
- }
1344
- getCart(checkout) {
1345
- this.buildCartFromCheckout(checkout).subscribe((cart) => this.cartSubject.next(cart));
1346
- return this.cartSubject;
1347
- }
1348
- /**
1349
- * @deprecated The method should not be used
1350
- */
1351
- getVariantPriceDiscount(item) {
1352
- return this.authService.getUser().pipe(concatMap((user) => iif(() => user.isSubscriber && !!item.price.subscriberPrice, of(item.price.subscriberPrice), of(item.price.price))), catchError(() => of(item.price.price)));
1353
- }
1354
- removeItem(item) {
1355
- return this.checkoutService.getCheckout().pipe(map((checkout) => {
1356
- const index = checkout.lineItems.findIndex((lineItem) => lineItem.id === item.id);
1357
- if (index >= 0)
1358
- checkout.lineItems.splice(index, 1);
1359
- return checkout;
1360
- }), concatMap((checkout) => this.checkoutService.updateCheckoutLineItems(checkout)), map((checkout) => this.generateCartObject(checkout.lineItems)), tap((cart) => this.cartSubject.next(cart)));
1361
- }
1362
- updateUserCart(user) {
1363
- return this.checkoutService.getCheckout().pipe(concatMap((checkout) => this.checkoutService.updateCheckoutUser(Checkout.toInstance({ ...checkout.toPlain(), user }))), concatMap(async (checkout) => await this.checkoutService
1364
- .updateCheckoutLineItems(Checkout.toInstance({
1365
- ...checkout.toPlain(),
1366
- lineItems: checkout.lineItems?.length
1367
- ? await Promise.all(checkout.lineItems?.map(async (item) => (await this.buildLineItem({ checkout, item })).lineItem))
1368
- : [],
1369
- }))
1370
- .toPromise()), map((checkout) => this.generateCartObject(checkout.lineItems)), tap((cart) => this.cartSubject.next(cart)));
1371
- }
1372
- clearCart() {
1373
- return this.checkoutService.getCheckout().pipe(map((checkout) => {
1374
- this.checkoutService.clearCheckoutFromSession();
1375
- return checkout;
1376
- }), concatMap((oldCheckout) => this.buildCartFromCheckout(oldCheckout)), tap((cart) => this.cartSubject.next(cart)));
1377
- }
1378
- buildCartFromCheckout(checkoutData) {
1379
- return this.checkoutService.getCheckout(checkoutData).pipe(map((checkout) => checkout.lineItems), concatMap((lineItems) => of(this.generateCartObject(lineItems))));
1380
- }
1381
- roundPrice(productPrice) {
1382
- const { price, fullPrice, subscriberPrice } = productPrice;
1383
- return {
1384
- ...productPrice,
1385
- price: Number(price.toFixed(2)),
1386
- fullPrice: Number(fullPrice.toFixed(2)),
1387
- ...(subscriberPrice && { subscriberPrice: Number(subscriberPrice.toFixed(2)) }),
1388
- };
1389
- }
1390
- async getProductData(productId) {
1391
- let product;
1392
- let variant;
1393
- try {
1394
- product = await this.productRepository.get({ id: productId });
1395
- }
1396
- catch (error) {
1397
- if (!(error instanceof NotFoundError))
1398
- throw error;
1399
- const { data: variants } = await this.variantRepository.find({ filters: { id: productId } });
1400
- variant = variants.shift();
1401
- if (!variant)
1402
- throw error;
1403
- product = await this.productRepository.get({ id: variant.productId });
1404
- }
1405
- return {
1406
- ...product.toPlain(),
1407
- ...(variant && { ...variant.toPlain() }),
1408
- };
1409
- }
1410
- getGifts() {
1411
- return this.checkoutService.getCheckout().pipe(mergeMap(async (checkout) => {
1412
- const notGiftItems = checkout.lineItems ? checkout.lineItems.filter((item) => !item.isGift) : [];
1413
- if (!notGiftItems.length)
1414
- return { ...checkout, lineItems: [] };
1415
- const cartTotal = notGiftItems.reduce((a, b) => a + b.pricePaid * b.quantity, 0);
1416
- const campaigns = await this.buy2WinRepository
1417
- .find({
1418
- filters: {
1419
- active: { operator: Where.EQUALS, value: true },
1420
- shop: { operator: Where.EQUALS, value: this.defaultShop },
1421
- },
1422
- })
1423
- .then((data) => data.data);
1424
- if (!campaigns.length)
1425
- return { ...checkout, lineItems: notGiftItems };
1426
- const elegibleCampaigns = [];
1427
- for (const campaign of campaigns) {
1428
- const today = new Date().getTime();
1429
- if (!(campaign.startDate.getTime() <= today) && !(campaign.endDate.getTime() >= today))
1430
- continue;
1431
- if (campaign.activeCategory) {
1432
- const categoriesCampaing = campaign.categories.map((c) => c.id.toString());
1433
- const categoriesCampaingFullTree = [];
1434
- for (const id of categoriesCampaing) {
1435
- const children = await this.categoryRepository.getChildren(parseInt(id));
1436
- categoriesCampaingFullTree.push(id, ...children.map((c) => c.id.toString()));
1437
- }
1438
- const categoriesCampaingTree = [...new Set(categoriesCampaingFullTree)];
1439
- const filterProductsCategories = checkout.lineItems.filter((l) => {
1440
- if (!l.categories || !l.categories?.length)
1441
- return true;
1442
- return l.categories.some((c) => categoriesCampaingTree.some((cat) => cat == c));
1443
- });
1444
- if (filterProductsCategories.length) {
1445
- const cartTotalCategories = filterProductsCategories.reduce((a, b) => a + b.pricePaid * b.quantity, 0);
1446
- if (cartTotalCategories >= campaign.cartValueMin)
1447
- elegibleCampaigns.push(campaign);
1448
- }
1449
- }
1450
- else {
1451
- if (campaign.cartValue && campaign.cartValue > 0) {
1452
- if (campaign.cartValue <= cartTotal)
1453
- elegibleCampaigns.push(campaign);
1454
- }
1455
- }
1456
- }
1457
- if (!elegibleCampaigns.length)
1458
- return { ...checkout, lineItems: notGiftItems };
1459
- const campaingnProducts = [];
1460
- for (const campaign of elegibleCampaigns) {
1461
- let elegibleProducts = [];
1462
- for (const product of campaign.products) {
1463
- const { data: productData } = await this.productRepository.find({ filters: { sku: product } });
1464
- if (!productData.length)
1465
- continue;
1466
- const gift = productData.shift();
1467
- if (gift.stock.quantity < 1)
1468
- continue;
1469
- elegibleProducts.push(gift);
1470
- }
1471
- campaingnProducts.push(elegibleProducts);
1472
- }
1473
- if (!campaingnProducts.length)
1474
- return { ...checkout, lineItems: notGiftItems };
1475
- const gifts = this.giftToLineItems([].concat(...campaingnProducts));
1476
- return { ...checkout, lineItems: notGiftItems.concat(gifts) };
1477
- }), concatMap((checkout) => this.checkoutService.updateCheckoutLineItems(checkout)), map((checkout) => this.generateCartObject(checkout.lineItems)), tap((cart) => this.cartSubject.next(cart)));
1478
- }
1479
- giftToLineItems(items) {
1480
- return items.map((item) => {
1481
- const { brand, categories, id, name, price, sku, slug, stock, weight, EAN } = item;
1482
- const image = item?.miniatures?.length ? item.miniatures[0] : item.images[0];
1483
- return LineItem.toInstance({
1484
- brand,
1485
- categories,
1486
- id: id.toString(),
1487
- name,
1488
- price,
1489
- sku,
1490
- slug,
1491
- stock,
1492
- weight,
1493
- EAN,
1494
- image,
1495
- pricePaid: 0,
1496
- quantity: 1,
1497
- isGift: true,
1498
- });
1499
- });
1500
- }
1501
- }
1502
- CartService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: CartService, deps: [{ token: AuthService }, { token: CheckoutService }, { token: DEFAULT_SHOP }, { token: 'ProductRepository' }, { token: 'CategoryRepository' }, { token: 'VariantRepository' }, { token: 'Buy2WinRepository' }], target: i0.ɵɵFactoryTarget.Injectable });
1503
- CartService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: CartService });
1504
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: CartService, decorators: [{
1505
- type: Injectable
1506
- }], ctorParameters: function () { return [{ type: AuthService }, { type: CheckoutService }, { type: i1$2.Shops, decorators: [{
1507
- type: Inject,
1508
- args: [DEFAULT_SHOP]
1509
- }] }, { type: undefined, decorators: [{
1510
- type: Inject,
1511
- args: ['ProductRepository']
1512
- }] }, { type: undefined, decorators: [{
1513
- type: Inject,
1514
- args: ['CategoryRepository']
1515
- }] }, { type: undefined, decorators: [{
1516
- type: Inject,
1517
- args: ['VariantRepository']
1518
- }] }, { type: i1$2.Buy2WinFirestoreRepository, decorators: [{
1519
- type: Inject,
1520
- args: ['Buy2WinRepository']
1250
+ class CartService {
1251
+ constructor(authService, checkoutService, defaultShop, productRepository, categoryRepository, variantRepository, buy2WinRepository) {
1252
+ this.authService = authService;
1253
+ this.checkoutService = checkoutService;
1254
+ this.defaultShop = defaultShop;
1255
+ this.productRepository = productRepository;
1256
+ this.categoryRepository = categoryRepository;
1257
+ this.variantRepository = variantRepository;
1258
+ this.buy2WinRepository = buy2WinRepository;
1259
+ this.cartSubject = new Subject();
1260
+ this.updateLineItemInCart = (lineItem, quantity, checkout) => (isNil(checkout) ? this.checkoutService.getCheckout() : of(checkout)).pipe(concatMap((checkoutLoaded) => {
1261
+ const items = [];
1262
+ const index = checkoutLoaded.lineItems?.map((checkoutItem) => checkoutItem.id).indexOf(lineItem.id);
1263
+ if (index > -1) {
1264
+ checkoutLoaded.lineItems[index].quantity += quantity;
1265
+ checkoutLoaded.lineItems[index].pricePaid = lineItem.pricePaid;
1266
+ }
1267
+ else
1268
+ checkoutLoaded.lineItems = items.concat(checkoutLoaded.lineItems ? checkoutLoaded.lineItems.concat([lineItem]) : [lineItem]);
1269
+ return this.checkoutService
1270
+ .updateCheckoutLineItems(checkoutLoaded)
1271
+ .pipe(map((updatedCheckout) => this.generateCartObject(updatedCheckout.lineItems)));
1272
+ }));
1273
+ this.generateCartObject = (items) => items?.reduce((cart, item) => ({
1274
+ ...cart,
1275
+ [item.id]: LineItem.toInstance({
1276
+ ...(cart[item.id] || item),
1277
+ quantity: (cart[item.id]?.quantity || 0) + (item.quantity ? item.quantity : 1),
1278
+ }),
1279
+ }), {}) || {};
1280
+ this.buildLineItem = async ({ checkout, item, quantity, }) => {
1281
+ const product = await this.getProductData(item.id);
1282
+ item.quantity = item?.quantity || checkout?.lineItems?.find((lineItem) => lineItem.id === item.id)?.quantity || 0;
1283
+ if (this.checkMaxStock(item, quantity || 0))
1284
+ throw new Error('Desculpe! Temos apenas ' + item.stock?.quantity + ' em estoque.');
1285
+ const image = item.image || item.images?.shift();
1286
+ const { id, name, EAN, slug, stock, price, weight, sku, type } = item;
1287
+ const isGift = item.isGift || null;
1288
+ const pricePaid = this.getProductPrice({
1289
+ product: item,
1290
+ shop: checkout.shop || this.defaultShop,
1291
+ isSubscriber: checkout.user?.isSubscriber,
1292
+ });
1293
+ RoundProductPricesHelper.roundProductPrices(item);
1294
+ return {
1295
+ checkout,
1296
+ lineItem: LineItem.toInstance({
1297
+ id,
1298
+ name: name ?? product.name,
1299
+ EAN: EAN ?? product.EAN,
1300
+ brand: product.brand,
1301
+ slug: slug ?? product.slug,
1302
+ sku: sku ?? product.sku,
1303
+ stock,
1304
+ price: this.roundPrice(price),
1305
+ image,
1306
+ weight: weight ?? product.weight,
1307
+ quantity: (item.quantity || 0) + (quantity || 0),
1308
+ pricePaid,
1309
+ categories: product.categories ?? [],
1310
+ isGift: isGift ?? null,
1311
+ costPrice: product.costPrice ?? 0,
1312
+ type,
1313
+ }),
1314
+ };
1315
+ };
1316
+ this.getProductPrice = ({ product, isSubscriber, }) => {
1317
+ const info = product.price;
1318
+ if (product.isGift)
1319
+ return 0;
1320
+ return isSubscriber && info.subscriberPrice > 0
1321
+ ? Number(info.subscriberPrice.toFixed(2))
1322
+ : Number(info.price.toFixed(2));
1323
+ };
1324
+ this.checkMaxStock = (item, quantity) => {
1325
+ const maxStock = item.stock?.quantity || 0;
1326
+ const currentItemAmount = item.quantity || 0;
1327
+ return currentItemAmount + quantity > maxStock;
1328
+ };
1329
+ }
1330
+ addItem(item, quantity = 1) {
1331
+ return from(this.checkoutService.getCheckout()).pipe(concatMap(async (checkout) => await this.buildLineItem({ checkout, item, quantity: quantity || 1 })), mergeMap(({ checkout, lineItem }) => this.updateLineItemInCart(lineItem, quantity || 1, checkout)), tap((cart) => this.cartSubject.next(cart)));
1332
+ }
1333
+ decreaseItem(item) {
1334
+ return this.checkoutService.getCheckout().pipe(map((checkout) => {
1335
+ const checkoutItem = checkout.lineItems?.find((lineItem) => lineItem.id === item.id);
1336
+ if (!isNil(checkoutItem))
1337
+ checkoutItem.quantity -= checkoutItem.quantity > 1 ? 1 : 0;
1338
+ return checkout;
1339
+ }), concatMap((checkout) => this.checkoutService.updateCheckoutLineItems(checkout)), map((checkout) => this.generateCartObject(checkout.lineItems)), tap((cart) => this.cartSubject.next(cart)));
1340
+ }
1341
+ getCart(checkout) {
1342
+ this.buildCartFromCheckout(checkout).subscribe((cart) => this.cartSubject.next(cart));
1343
+ return this.cartSubject;
1344
+ }
1345
+ /**
1346
+ * @deprecated The method should not be used
1347
+ */
1348
+ getVariantPriceDiscount(item) {
1349
+ return this.authService.getUser().pipe(concatMap((user) => iif(() => user.isSubscriber && !!item.price.subscriberPrice, of(item.price.subscriberPrice), of(item.price.price))), catchError(() => of(item.price.price)));
1350
+ }
1351
+ removeItem(item) {
1352
+ return this.checkoutService.getCheckout().pipe(map((checkout) => {
1353
+ const index = checkout.lineItems.findIndex((lineItem) => lineItem.id === item.id);
1354
+ if (index >= 0)
1355
+ checkout.lineItems.splice(index, 1);
1356
+ return checkout;
1357
+ }), concatMap((checkout) => this.checkoutService.updateCheckoutLineItems(checkout)), map((checkout) => this.generateCartObject(checkout.lineItems)), tap((cart) => this.cartSubject.next(cart)));
1358
+ }
1359
+ updateUserCart(user) {
1360
+ return this.checkoutService.getCheckout().pipe(concatMap((checkout) => this.checkoutService.updateCheckoutUser(Checkout.toInstance({ ...checkout.toPlain(), user }))), concatMap(async (checkout) => await this.checkoutService
1361
+ .updateCheckoutLineItems(Checkout.toInstance({
1362
+ ...checkout.toPlain(),
1363
+ lineItems: checkout.lineItems?.length
1364
+ ? await Promise.all(checkout.lineItems?.map(async (item) => (await this.buildLineItem({ checkout, item })).lineItem))
1365
+ : [],
1366
+ }))
1367
+ .toPromise()), map((checkout) => this.generateCartObject(checkout.lineItems)), tap((cart) => this.cartSubject.next(cart)));
1368
+ }
1369
+ clearCart() {
1370
+ return this.checkoutService.getCheckout().pipe(map((checkout) => {
1371
+ this.checkoutService.clearCheckoutFromSession();
1372
+ return checkout;
1373
+ }), concatMap((oldCheckout) => this.buildCartFromCheckout(oldCheckout)), tap((cart) => this.cartSubject.next(cart)));
1374
+ }
1375
+ buildCartFromCheckout(checkoutData) {
1376
+ return this.checkoutService.getCheckout(checkoutData).pipe(map((checkout) => checkout.lineItems), concatMap((lineItems) => of(this.generateCartObject(lineItems))));
1377
+ }
1378
+ roundPrice(productPrice) {
1379
+ const { price, fullPrice, subscriberPrice } = productPrice;
1380
+ return {
1381
+ ...productPrice,
1382
+ price: Number(price.toFixed(2)),
1383
+ fullPrice: Number(fullPrice.toFixed(2)),
1384
+ ...(subscriberPrice && { subscriberPrice: Number(subscriberPrice.toFixed(2)) }),
1385
+ };
1386
+ }
1387
+ async getProductData(productId) {
1388
+ let product;
1389
+ let variant;
1390
+ try {
1391
+ product = await this.productRepository.get({ id: productId });
1392
+ }
1393
+ catch (error) {
1394
+ if (!(error instanceof NotFoundError))
1395
+ throw error;
1396
+ const { data: variants } = await this.variantRepository.find({ filters: { id: productId } });
1397
+ variant = variants.shift();
1398
+ if (!variant)
1399
+ throw error;
1400
+ product = await this.productRepository.get({ id: variant.productId });
1401
+ }
1402
+ return {
1403
+ ...product.toPlain(),
1404
+ ...(variant && { ...variant.toPlain() }),
1405
+ };
1406
+ }
1407
+ getGifts() {
1408
+ return this.checkoutService.getCheckout().pipe(mergeMap(async (checkout) => {
1409
+ const notGiftItems = checkout.lineItems ? checkout.lineItems.filter((item) => !item.isGift) : [];
1410
+ if (!notGiftItems.length)
1411
+ return { ...checkout, lineItems: [] };
1412
+ const cartTotal = notGiftItems.reduce((a, b) => a + b.pricePaid * b.quantity, 0);
1413
+ const campaigns = await this.buy2WinRepository
1414
+ .find({
1415
+ filters: {
1416
+ active: { operator: Where.EQUALS, value: true },
1417
+ shop: { operator: Where.EQUALS, value: this.defaultShop },
1418
+ },
1419
+ })
1420
+ .then((data) => data.data);
1421
+ if (!campaigns.length)
1422
+ return { ...checkout, lineItems: notGiftItems };
1423
+ const elegibleCampaigns = [];
1424
+ for (const campaign of campaigns) {
1425
+ const today = new Date().getTime();
1426
+ if (!(campaign.startDate.getTime() <= today) && !(campaign.endDate.getTime() >= today))
1427
+ continue;
1428
+ if (campaign.activeCategory) {
1429
+ const categoriesCampaing = campaign.categories.map((c) => c.id.toString());
1430
+ const categoriesCampaingFullTree = [];
1431
+ for (const id of categoriesCampaing) {
1432
+ const children = await this.categoryRepository.getChildren(parseInt(id));
1433
+ categoriesCampaingFullTree.push(id, ...children.map((c) => c.id.toString()));
1434
+ }
1435
+ const categoriesCampaingTree = [...new Set(categoriesCampaingFullTree)];
1436
+ const filterProductsCategories = checkout.lineItems.filter((l) => {
1437
+ if (!l.categories || !l.categories?.length)
1438
+ return true;
1439
+ return l.categories.some((c) => categoriesCampaingTree.some((cat) => cat == c));
1440
+ });
1441
+ if (filterProductsCategories.length) {
1442
+ const cartTotalCategories = filterProductsCategories.reduce((a, b) => a + b.pricePaid * b.quantity, 0);
1443
+ if (cartTotalCategories >= campaign.cartValueMin)
1444
+ elegibleCampaigns.push(campaign);
1445
+ }
1446
+ }
1447
+ else {
1448
+ if (campaign.cartValue && campaign.cartValue > 0) {
1449
+ if (campaign.cartValue <= cartTotal)
1450
+ elegibleCampaigns.push(campaign);
1451
+ }
1452
+ }
1453
+ }
1454
+ if (!elegibleCampaigns.length)
1455
+ return { ...checkout, lineItems: notGiftItems };
1456
+ const campaingnProducts = [];
1457
+ for (const campaign of elegibleCampaigns) {
1458
+ let elegibleProducts = [];
1459
+ for (const product of campaign.products) {
1460
+ const { data: productData } = await this.productRepository.find({ filters: { sku: product } });
1461
+ if (!productData.length)
1462
+ continue;
1463
+ const gift = productData.shift();
1464
+ if (gift.stock.quantity < 1)
1465
+ continue;
1466
+ elegibleProducts.push(gift);
1467
+ }
1468
+ campaingnProducts.push(elegibleProducts);
1469
+ }
1470
+ if (!campaingnProducts.length)
1471
+ return { ...checkout, lineItems: notGiftItems };
1472
+ const gifts = this.giftToLineItems([].concat(...campaingnProducts));
1473
+ return { ...checkout, lineItems: notGiftItems.concat(gifts) };
1474
+ }), concatMap((checkout) => this.checkoutService.updateCheckoutLineItems(checkout)), map((checkout) => this.generateCartObject(checkout.lineItems)), tap((cart) => this.cartSubject.next(cart)));
1475
+ }
1476
+ giftToLineItems(items) {
1477
+ return items.map((item) => {
1478
+ const { brand, categories, id, name, price, sku, slug, stock, weight, EAN } = item;
1479
+ const image = item?.miniatures?.length ? item.miniatures[0] : item.images[0];
1480
+ return LineItem.toInstance({
1481
+ brand,
1482
+ categories,
1483
+ id: id.toString(),
1484
+ name,
1485
+ price,
1486
+ sku,
1487
+ slug,
1488
+ stock,
1489
+ weight,
1490
+ EAN,
1491
+ image,
1492
+ pricePaid: 0,
1493
+ quantity: 1,
1494
+ isGift: true,
1495
+ });
1496
+ });
1497
+ }
1498
+ }
1499
+ CartService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: CartService, deps: [{ token: AuthService }, { token: CheckoutService }, { token: DEFAULT_SHOP }, { token: 'ProductRepository' }, { token: 'CategoryRepository' }, { token: 'VariantRepository' }, { token: 'Buy2WinRepository' }], target: i0.ɵɵFactoryTarget.Injectable });
1500
+ CartService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: CartService });
1501
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: CartService, decorators: [{
1502
+ type: Injectable
1503
+ }], ctorParameters: function () { return [{ type: AuthService }, { type: CheckoutService }, { type: i1$2.Shops, decorators: [{
1504
+ type: Inject,
1505
+ args: [DEFAULT_SHOP]
1506
+ }] }, { type: undefined, decorators: [{
1507
+ type: Inject,
1508
+ args: ['ProductRepository']
1509
+ }] }, { type: undefined, decorators: [{
1510
+ type: Inject,
1511
+ args: ['CategoryRepository']
1512
+ }] }, { type: undefined, decorators: [{
1513
+ type: Inject,
1514
+ args: ['VariantRepository']
1515
+ }] }, { type: i1$2.Buy2WinFirestoreRepository, decorators: [{
1516
+ type: Inject,
1517
+ args: ['Buy2WinRepository']
1521
1518
  }] }]; } });
1522
1519
 
1523
- class NewCategoryStructureAdapter {
1524
- constructor(categoryRepository) {
1525
- this.categoryRepository = categoryRepository;
1526
- }
1527
- async buildProductFilterByCategory(category) {
1528
- const loadedCategory = await this.getCategory(category);
1529
- if (loadedCategory.isCollection)
1530
- return { id: { operator: Where.IN, value: loadedCategory.products } };
1531
- const categoryIds = [...(await this.getAllCategoriesIdFromCategory(category)), category.id.toString()];
1532
- return {
1533
- category: {
1534
- id: {
1535
- operator: Where.IN,
1536
- value: categoryIds,
1537
- },
1538
- },
1539
- };
1540
- }
1541
- async getAllCategoriesIdFromCategory(category) {
1542
- return this.categoryRepository
1543
- .getChildren(+category.id)
1544
- .then((categories) => categories.map((category) => category.id.toString()));
1545
- }
1546
- async getCategory(category) {
1547
- return isNil(category.isCollection) || (category.isCollection && !category.products?.length)
1548
- ? this.categoryRepository.get({ id: category.id })
1549
- : category;
1550
- }
1551
- }
1552
- NewCategoryStructureAdapter.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: NewCategoryStructureAdapter, deps: [{ token: 'CategoryRepository' }], target: i0.ɵɵFactoryTarget.Injectable });
1553
- NewCategoryStructureAdapter.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: NewCategoryStructureAdapter });
1554
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: NewCategoryStructureAdapter, decorators: [{
1555
- type: Injectable
1556
- }], ctorParameters: function () { return [{ type: undefined, decorators: [{
1557
- type: Inject,
1558
- args: ['CategoryRepository']
1520
+ class NewCategoryStructureAdapter {
1521
+ constructor(categoryRepository) {
1522
+ this.categoryRepository = categoryRepository;
1523
+ }
1524
+ async buildProductFilterByCategory(category) {
1525
+ const loadedCategory = await this.getCategory(category);
1526
+ if (loadedCategory.isCollection)
1527
+ return { id: { operator: Where.IN, value: loadedCategory.products } };
1528
+ const categoryIds = [...(await this.getAllCategoriesIdFromCategory(category)), category.id.toString()];
1529
+ return {
1530
+ category: {
1531
+ id: {
1532
+ operator: Where.IN,
1533
+ value: categoryIds,
1534
+ },
1535
+ },
1536
+ };
1537
+ }
1538
+ async getAllCategoriesIdFromCategory(category) {
1539
+ return this.categoryRepository
1540
+ .getChildren(+category.id)
1541
+ .then((categories) => categories.map((category) => category.id.toString()));
1542
+ }
1543
+ async getCategory(category) {
1544
+ return isNil(category.isCollection) || (category.isCollection && !category.products?.length)
1545
+ ? this.categoryRepository.get({ id: category.id })
1546
+ : category;
1547
+ }
1548
+ }
1549
+ NewCategoryStructureAdapter.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: NewCategoryStructureAdapter, deps: [{ token: 'CategoryRepository' }], target: i0.ɵɵFactoryTarget.Injectable });
1550
+ NewCategoryStructureAdapter.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: NewCategoryStructureAdapter });
1551
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: NewCategoryStructureAdapter, decorators: [{
1552
+ type: Injectable
1553
+ }], ctorParameters: function () { return [{ type: undefined, decorators: [{
1554
+ type: Inject,
1555
+ args: ['CategoryRepository']
1559
1556
  }] }]; } });
1560
1557
 
1561
- class OldCategoryStructureAdapter {
1562
- constructor(categoryRepository) {
1563
- this.categoryRepository = categoryRepository;
1564
- }
1565
- async buildProductFilterByCategory(category) {
1566
- const productsIds = category.products?.length
1567
- ? category.products
1568
- : await this.categoryRepository.get({ id: category.id }).then((categoryFound) => categoryFound.products);
1569
- return { id: { operator: Where.IN, value: productsIds } };
1570
- }
1571
- }
1572
- OldCategoryStructureAdapter.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: OldCategoryStructureAdapter, deps: [{ token: 'CategoryRepository' }], target: i0.ɵɵFactoryTarget.Injectable });
1573
- OldCategoryStructureAdapter.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: OldCategoryStructureAdapter });
1574
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: OldCategoryStructureAdapter, decorators: [{
1575
- type: Injectable
1576
- }], ctorParameters: function () { return [{ type: undefined, decorators: [{
1577
- type: Inject,
1578
- args: ['CategoryRepository']
1558
+ class OldCategoryStructureAdapter {
1559
+ constructor(categoryRepository) {
1560
+ this.categoryRepository = categoryRepository;
1561
+ }
1562
+ async buildProductFilterByCategory(category) {
1563
+ const productsIds = category.products?.length
1564
+ ? category.products
1565
+ : await this.categoryRepository.get({ id: category.id }).then((categoryFound) => categoryFound.products);
1566
+ return { id: { operator: Where.IN, value: productsIds } };
1567
+ }
1568
+ }
1569
+ OldCategoryStructureAdapter.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: OldCategoryStructureAdapter, deps: [{ token: 'CategoryRepository' }], target: i0.ɵɵFactoryTarget.Injectable });
1570
+ OldCategoryStructureAdapter.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: OldCategoryStructureAdapter });
1571
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: OldCategoryStructureAdapter, decorators: [{
1572
+ type: Injectable
1573
+ }], ctorParameters: function () { return [{ type: undefined, decorators: [{
1574
+ type: Inject,
1575
+ args: ['CategoryRepository']
1579
1576
  }] }]; } });
1580
1577
 
1581
- class CatalogService {
1582
- constructor(productRepository, categoryRepository, categoryStructureAdapter, shop, productIndex) {
1583
- this.productRepository = productRepository;
1584
- this.categoryRepository = categoryRepository;
1585
- this.categoryStructureAdapter = categoryStructureAdapter;
1586
- this.shop = shop;
1587
- this.productIndex = productIndex;
1588
- this.productsByTerm = {};
1589
- this.buildFilterQuery = ({ clubDiscount, brands, prices, gender, tags, rate, customOptions, }) => {
1590
- const filters = {};
1591
- if (clubDiscount?.length)
1592
- set(filters, 'price.subscriberDiscountPercentage', { operator: Where.IN, value: clubDiscount });
1593
- if (brands?.length)
1594
- filters.brand = { operator: Where.IN, value: brands };
1595
- if (gender?.length)
1596
- filters.gender = { operator: Where.IN, value: gender };
1597
- if (prices?.min || prices?.max)
1598
- set(filters, prices.subscriberPrice ? 'price.subscriberPrice' : 'price.price', [
1599
- ...(prices.min ? [{ operator: Where.GTE, value: Math.round(prices.min) }] : []),
1600
- ...(prices.max ? [{ operator: Where.LTE, value: Math.ceil(prices.max) }] : []),
1601
- ]);
1602
- if (rate)
1603
- filters.rate = { operator: Where.GTE, value: rate };
1604
- if (tags?.length)
1605
- filters.tags = { operator: Where.LIKE, value: tags };
1606
- if (customOptions?.length)
1607
- filters.filters = { operator: Where.LIKE, value: customOptions };
1608
- return filters;
1609
- };
1610
- this.buildSortQuery = (sort) => {
1611
- if (!sort || sort === 'most-relevant')
1612
- return {};
1613
- if (sort === 'best-sellers')
1614
- return { shoppingCount: 'desc' };
1615
- if (sort === 'biggest-price')
1616
- return { subscriberPrice: 'desc' };
1617
- if (sort === 'lowest-price')
1618
- return { subscriberPrice: 'asc' };
1619
- if (sort === 'best-rating')
1620
- return { rate: 'desc' };
1621
- if (sort === 'news')
1622
- return { createdAt: 'desc' };
1623
- if (sort === 'biggest-discount')
1624
- return { subscriberDiscountPercentage: 'desc' };
1625
- };
1626
- this.buildLimitQuery = (options) => {
1627
- const limit = options?.perPage || 20;
1628
- return {
1629
- limit,
1630
- offset: ((options?.page || 1) - 1) * limit,
1631
- };
1632
- };
1633
- this.hasProfile = (options) => 'profile' in options;
1634
- this.hasTerm = (options) => 'term' in options;
1635
- this.hasCategory = (options) => 'category' in options;
1636
- }
1637
- async fetchProducts(options) {
1638
- const limits = this.buildLimitQuery(options);
1639
- if (this.hasProfile(options) && options.filters?.customOptions)
1640
- throw new InvalidArgumentError(`It couldn't filled customOptions when profile is given`);
1641
- if (this.hasProfile(options) && options.filters?.tags)
1642
- throw new InvalidArgumentError(`It couldn't filled tags when profile is given`);
1643
- if (this.hasTerm(options) && options.filters?.customOptions)
1644
- throw new InvalidArgumentError(`It couldn't filled customOptions when term is given`);
1645
- return await this.findCatalog(options, limits).then(({ data, count: total, maximum, minimal, distinct }) => ({
1646
- products: { data: data.map((product) => RoundProductPricesHelper.roundProductPrices(product)), total },
1647
- pages: Math.ceil(total / limits.limit),
1648
- prices: {
1649
- price: { min: +minimal?.price?.price?.toFixed(2), max: +maximum?.price?.price?.toFixed(2) },
1650
- subscriberPrice: {
1651
- min: +minimal?.price?.subscriberPrice?.toFixed(2),
1652
- max: +maximum?.price?.subscriberPrice?.toFixed(2),
1653
- },
1654
- },
1655
- brands: distinct?.brand,
1656
- }));
1657
- }
1658
- async findCatalog(options, limits) {
1659
- if (this.hasTerm(options) && options.sort === 'most-relevant') {
1660
- const productsIds = await this.findCatalogIdsByElasticSearch(options.term);
1661
- return this.findCatalogAndSortByMostRevelant(productsIds, options, limits);
1662
- }
1663
- if (this.hasCategory(options) && options.sort === 'most-relevant') {
1664
- const productsIds = options.category.products?.length
1665
- ? options.category.products
1666
- : await this.categoryRepository.get({ id: options.category.id }).then((categoryFound) => categoryFound.products);
1667
- return this.findCatalogAndSortByMostRevelant(productsIds, options, limits);
1668
- }
1669
- const repoParams = {
1670
- filters: {
1671
- ...(await this.buildMainFilter(options)),
1672
- ...this.buildFilterQuery(options?.filters || {}),
1673
- },
1674
- ...(options?.sort ? { orderBy: this.buildSortQuery(options?.sort) } : {}),
1675
- limits,
1676
- options: {
1677
- minimal: ['price'],
1678
- maximum: ['price'],
1679
- ...(!this.hasCategory(options) ? { distinct: ['brand'] } : {}),
1680
- },
1681
- };
1682
- if (['biggest-price', 'lowest-price', 'biggest-discount', 'best-rating'].includes(options.sort))
1683
- return this.productRepository.findCatalog(repoParams);
1684
- return this.productRepository.findCatalog(repoParams, options?.mainGender || this.shop === Shops.MENSMARKET ? 'male' : 'female');
1685
- }
1686
- async buildMainFilter({ category, profile, term, }) {
1687
- if (category)
1688
- return this.categoryStructureAdapter.buildProductFilterByCategory(category);
1689
- if (profile)
1690
- return { tags: { operator: Where.LIKE, value: profile } };
1691
- if (term)
1692
- return this.productIndex
1693
- .search(term, 999, this.shop)
1694
- .then((data) => ({ id: { operator: Where.IN, value: data.hits.map(({ _source }) => _source.id) } }));
1695
- }
1696
- async findCatalogAndSortByMostRevelant(productIds, options, limits) {
1697
- const totalResult = await this.productRepository.findCatalog({
1698
- fields: ['id', 'stock'],
1699
- filters: {
1700
- id: { operator: Where.IN, value: productIds },
1701
- ...this.buildFilterQuery(options?.filters || {}),
1702
- },
1703
- options: {
1704
- minimal: ['price'],
1705
- maximum: ['price'],
1706
- distinct: ['brand'],
1707
- },
1708
- }, options?.mainGender || this.shop === Shops.MENSMARKET ? 'male' : 'female');
1709
- const stockData = totalResult.data.filter((product) => product.stock.quantity > 0);
1710
- const stockOut = totalResult.data.filter((product) => product.stock.quantity <= 0);
1711
- const productIdsStock = productIds.filter((product) => stockData.some((result) => result.id == product));
1712
- const productIdsStockOut = productIds.filter((product) => stockOut.some((result) => result.id == product));
1713
- const limitedProductId = productIdsStock
1714
- .concat(productIdsStockOut)
1715
- .slice(limits.offset, limits.offset + limits.limit);
1716
- const orderedId = productIds.filter((product) => limitedProductId.includes(product));
1717
- const productResult = await this.productRepository.findCatalog({
1718
- filters: {
1719
- id: { operator: Where.IN, value: orderedId },
1720
- },
1721
- });
1722
- return {
1723
- data: limitedProductId.map((id) => productResult.data.find((product) => product.id === id)).filter(Boolean),
1724
- count: totalResult.count,
1725
- maximum: totalResult.maximum,
1726
- minimal: totalResult.minimal,
1727
- distinct: totalResult.distinct,
1728
- };
1729
- }
1730
- async findCatalogIdsByElasticSearch(term) {
1731
- if (this.productsByTerm[term])
1732
- return this.productsByTerm[term];
1733
- return (this.productsByTerm[term] = await this.productIndex
1734
- .search(term, 999, this.shop)
1735
- .then(({ hits: products }) => {
1736
- const withStock = products.filter(({ _source }) => _source.stock.quantity > 0);
1737
- const withOutStock = products.filter(({ _source }) => _source.stock.quantity <= 0);
1738
- const sorted = [...withStock, ...withOutStock];
1739
- return [...new Set(sorted.map(({ _source }) => _source.id))];
1740
- }));
1741
- }
1742
- }
1743
- CatalogService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: CatalogService, deps: [{ token: 'ProductRepository' }, { token: 'CategoryRepository' }, { token: CATEGORY_STRUCTURE }, { token: DEFAULT_SHOP }, { token: i1$2.ProductsIndex }], target: i0.ɵɵFactoryTarget.Injectable });
1744
- CatalogService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: CatalogService });
1745
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: CatalogService, decorators: [{
1746
- type: Injectable
1747
- }], ctorParameters: function () { return [{ type: undefined, decorators: [{
1748
- type: Inject,
1749
- args: ['ProductRepository']
1750
- }] }, { type: undefined, decorators: [{
1751
- type: Inject,
1752
- args: ['CategoryRepository']
1753
- }] }, { type: undefined, decorators: [{
1754
- type: Inject,
1755
- args: [CATEGORY_STRUCTURE]
1756
- }] }, { type: i1$2.Shops, decorators: [{
1757
- type: Inject,
1758
- args: [DEFAULT_SHOP]
1578
+ class CatalogService {
1579
+ constructor(productRepository, categoryRepository, categoryStructureAdapter, shop, productIndex) {
1580
+ this.productRepository = productRepository;
1581
+ this.categoryRepository = categoryRepository;
1582
+ this.categoryStructureAdapter = categoryStructureAdapter;
1583
+ this.shop = shop;
1584
+ this.productIndex = productIndex;
1585
+ this.productsByTerm = {};
1586
+ this.buildFilterQuery = ({ clubDiscount, brands, prices, gender, tags, rate, customOptions, }) => {
1587
+ const filters = {};
1588
+ if (clubDiscount?.length)
1589
+ set(filters, 'price.subscriberDiscountPercentage', { operator: Where.IN, value: clubDiscount });
1590
+ if (brands?.length)
1591
+ filters.brand = { operator: Where.IN, value: brands };
1592
+ if (gender?.length)
1593
+ filters.gender = { operator: Where.IN, value: gender };
1594
+ if (prices?.min || prices?.max)
1595
+ set(filters, prices.subscriberPrice ? 'price.subscriberPrice' : 'price.price', [
1596
+ ...(prices.min ? [{ operator: Where.GTE, value: Math.round(prices.min) }] : []),
1597
+ ...(prices.max ? [{ operator: Where.LTE, value: Math.ceil(prices.max) }] : []),
1598
+ ]);
1599
+ if (rate)
1600
+ filters.rate = { operator: Where.GTE, value: rate };
1601
+ if (tags?.length)
1602
+ filters.tags = { operator: Where.LIKE, value: tags };
1603
+ if (customOptions?.length)
1604
+ filters.filters = { operator: Where.LIKE, value: customOptions };
1605
+ return filters;
1606
+ };
1607
+ this.buildSortQuery = (sort) => {
1608
+ if (!sort || sort === 'most-relevant')
1609
+ return {};
1610
+ if (sort === 'best-sellers')
1611
+ return { shoppingCount: 'desc' };
1612
+ if (sort === 'biggest-price')
1613
+ return { subscriberPrice: 'desc' };
1614
+ if (sort === 'lowest-price')
1615
+ return { subscriberPrice: 'asc' };
1616
+ if (sort === 'best-rating')
1617
+ return { rate: 'desc' };
1618
+ if (sort === 'news')
1619
+ return { createdAt: 'desc' };
1620
+ if (sort === 'biggest-discount')
1621
+ return { subscriberDiscountPercentage: 'desc' };
1622
+ };
1623
+ this.buildLimitQuery = (options) => {
1624
+ const limit = options?.perPage || 20;
1625
+ return {
1626
+ limit,
1627
+ offset: ((options?.page || 1) - 1) * limit,
1628
+ };
1629
+ };
1630
+ this.hasProfile = (options) => 'profile' in options;
1631
+ this.hasTerm = (options) => 'term' in options;
1632
+ this.hasCategory = (options) => 'category' in options;
1633
+ }
1634
+ async fetchProducts(options) {
1635
+ const limits = this.buildLimitQuery(options);
1636
+ if (this.hasProfile(options) && options.filters?.customOptions)
1637
+ throw new InvalidArgumentError(`It couldn't filled customOptions when profile is given`);
1638
+ if (this.hasProfile(options) && options.filters?.tags)
1639
+ throw new InvalidArgumentError(`It couldn't filled tags when profile is given`);
1640
+ if (this.hasTerm(options) && options.filters?.customOptions)
1641
+ throw new InvalidArgumentError(`It couldn't filled customOptions when term is given`);
1642
+ return await this.findCatalog(options, limits).then(({ data, count: total, maximum, minimal, distinct }) => ({
1643
+ products: { data: data.map((product) => RoundProductPricesHelper.roundProductPrices(product)), total },
1644
+ pages: Math.ceil(total / limits.limit),
1645
+ prices: {
1646
+ price: { min: +minimal?.price?.price?.toFixed(2), max: +maximum?.price?.price?.toFixed(2) },
1647
+ subscriberPrice: {
1648
+ min: +minimal?.price?.subscriberPrice?.toFixed(2),
1649
+ max: +maximum?.price?.subscriberPrice?.toFixed(2),
1650
+ },
1651
+ },
1652
+ brands: distinct?.brand,
1653
+ }));
1654
+ }
1655
+ async findCatalog(options, limits) {
1656
+ if (this.hasTerm(options) && options.sort === 'most-relevant') {
1657
+ const productsIds = await this.findCatalogIdsByElasticSearch(options.term);
1658
+ return this.findCatalogAndSortByMostRevelant(productsIds, options, limits);
1659
+ }
1660
+ if (this.hasCategory(options) && options.sort === 'most-relevant') {
1661
+ const productsIds = options.category.products?.length
1662
+ ? options.category.products
1663
+ : await this.categoryRepository.get({ id: options.category.id }).then((categoryFound) => categoryFound.products);
1664
+ return this.findCatalogAndSortByMostRevelant(productsIds, options, limits);
1665
+ }
1666
+ const repoParams = {
1667
+ filters: {
1668
+ ...(await this.buildMainFilter(options)),
1669
+ ...this.buildFilterQuery(options?.filters || {}),
1670
+ },
1671
+ ...(options?.sort ? { orderBy: this.buildSortQuery(options?.sort) } : {}),
1672
+ limits,
1673
+ options: {
1674
+ minimal: ['price'],
1675
+ maximum: ['price'],
1676
+ ...(!this.hasCategory(options) ? { distinct: ['brand'] } : {}),
1677
+ },
1678
+ };
1679
+ if (['biggest-price', 'lowest-price', 'biggest-discount', 'best-rating'].includes(options.sort))
1680
+ return this.productRepository.findCatalog(repoParams);
1681
+ return this.productRepository.findCatalog(repoParams, options?.mainGender || this.shop === Shops.MENSMARKET ? 'male' : 'female');
1682
+ }
1683
+ async buildMainFilter({ category, profile, term, }) {
1684
+ if (category)
1685
+ return this.categoryStructureAdapter.buildProductFilterByCategory(category);
1686
+ if (profile)
1687
+ return { tags: { operator: Where.LIKE, value: profile } };
1688
+ if (term)
1689
+ return this.productIndex
1690
+ .search(term, 999, this.shop)
1691
+ .then((data) => ({ id: { operator: Where.IN, value: data.hits.map(({ _source }) => _source.id) } }));
1692
+ }
1693
+ async findCatalogAndSortByMostRevelant(productIds, options, limits) {
1694
+ const totalResult = await this.productRepository.findCatalog({
1695
+ fields: ['id', 'stock'],
1696
+ filters: {
1697
+ id: { operator: Where.IN, value: productIds },
1698
+ ...this.buildFilterQuery(options?.filters || {}),
1699
+ },
1700
+ options: {
1701
+ minimal: ['price'],
1702
+ maximum: ['price'],
1703
+ distinct: ['brand'],
1704
+ },
1705
+ }, options?.mainGender || this.shop === Shops.MENSMARKET ? 'male' : 'female');
1706
+ const stockData = totalResult.data.filter((product) => product.stock.quantity > 0);
1707
+ const stockOut = totalResult.data.filter((product) => product.stock.quantity <= 0);
1708
+ const productIdsStock = productIds.filter((product) => stockData.some((result) => result.id == product));
1709
+ const productIdsStockOut = productIds.filter((product) => stockOut.some((result) => result.id == product));
1710
+ const limitedProductId = productIdsStock
1711
+ .concat(productIdsStockOut)
1712
+ .slice(limits.offset, limits.offset + limits.limit);
1713
+ const orderedId = productIds.filter((product) => limitedProductId.includes(product));
1714
+ const productResult = await this.productRepository.findCatalog({
1715
+ filters: {
1716
+ id: { operator: Where.IN, value: orderedId },
1717
+ },
1718
+ });
1719
+ return {
1720
+ data: limitedProductId.map((id) => productResult.data.find((product) => product.id === id)).filter(Boolean),
1721
+ count: totalResult.count,
1722
+ maximum: totalResult.maximum,
1723
+ minimal: totalResult.minimal,
1724
+ distinct: totalResult.distinct,
1725
+ };
1726
+ }
1727
+ async findCatalogIdsByElasticSearch(term) {
1728
+ if (this.productsByTerm[term])
1729
+ return this.productsByTerm[term];
1730
+ return (this.productsByTerm[term] = await this.productIndex
1731
+ .search(term, 999, this.shop)
1732
+ .then(({ hits: products }) => {
1733
+ const withStock = products.filter(({ _source }) => _source.stock.quantity > 0);
1734
+ const withOutStock = products.filter(({ _source }) => _source.stock.quantity <= 0);
1735
+ const sorted = [...withStock, ...withOutStock];
1736
+ return [...new Set(sorted.map(({ _source }) => _source.id))];
1737
+ }));
1738
+ }
1739
+ }
1740
+ CatalogService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: CatalogService, deps: [{ token: 'ProductRepository' }, { token: 'CategoryRepository' }, { token: CATEGORY_STRUCTURE }, { token: DEFAULT_SHOP }, { token: i1$2.ProductsIndex }], target: i0.ɵɵFactoryTarget.Injectable });
1741
+ CatalogService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: CatalogService });
1742
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: CatalogService, decorators: [{
1743
+ type: Injectable
1744
+ }], ctorParameters: function () { return [{ type: undefined, decorators: [{
1745
+ type: Inject,
1746
+ args: ['ProductRepository']
1747
+ }] }, { type: undefined, decorators: [{
1748
+ type: Inject,
1749
+ args: ['CategoryRepository']
1750
+ }] }, { type: undefined, decorators: [{
1751
+ type: Inject,
1752
+ args: [CATEGORY_STRUCTURE]
1753
+ }] }, { type: i1$2.Shops, decorators: [{
1754
+ type: Inject,
1755
+ args: [DEFAULT_SHOP]
1759
1756
  }] }, { type: i1$2.ProductsIndex }]; } });
1760
1757
 
1761
- class CategoryService {
1762
- constructor(productRepository, categoryRepository, categoryFilterRepository, categoryStructureAdapter, shop) {
1763
- this.productRepository = productRepository;
1764
- this.categoryRepository = categoryRepository;
1765
- this.categoryFilterRepository = categoryFilterRepository;
1766
- this.categoryStructureAdapter = categoryStructureAdapter;
1767
- this.shop = shop;
1768
- }
1769
- async fetchBrands(category, options) {
1770
- const brands = await this.productRepository
1771
- .findCatalog({
1772
- filters: await this.categoryStructureAdapter.buildProductFilterByCategory(category),
1773
- fields: ['brand'],
1774
- }, options?.mainGender ? options?.mainGender : this.shop === Shops.MENSMARKET ? 'male' : 'female')
1775
- .then(({ data }) => Object.keys(data.map((product) => product.brand).reduce((brands, brand) => ({ ...brands, [brand]: true }), {})));
1776
- return this.categoryRepository
1777
- .find({ filters: { brandCategory: true, shop: options?.shop || this.shop }, orderBy: { name: 'asc' } })
1778
- .then(({ data }) => data.filter((category) => brands.includes(category.conditions.brand)));
1779
- }
1780
- async fetchFilterOptions(category) {
1781
- return await this.categoryFilterRepository
1782
- .find({ filters: { categoryId: +category.id } })
1783
- .then(({ data }) => data.map((categoryFilter) => categoryFilter.filter));
1784
- }
1785
- }
1786
- CategoryService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: CategoryService, deps: [{ token: 'ProductRepository' }, { token: 'CategoryRepository' }, { token: 'CategoryFilterRepository' }, { token: CATEGORY_STRUCTURE }, { token: DEFAULT_SHOP }], target: i0.ɵɵFactoryTarget.Injectable });
1787
- CategoryService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: CategoryService });
1788
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: CategoryService, decorators: [{
1789
- type: Injectable
1790
- }], ctorParameters: function () { return [{ type: undefined, decorators: [{
1791
- type: Inject,
1792
- args: ['ProductRepository']
1793
- }] }, { type: undefined, decorators: [{
1794
- type: Inject,
1795
- args: ['CategoryRepository']
1796
- }] }, { type: undefined, decorators: [{
1797
- type: Inject,
1798
- args: ['CategoryFilterRepository']
1799
- }] }, { type: undefined, decorators: [{
1800
- type: Inject,
1801
- args: [CATEGORY_STRUCTURE]
1802
- }] }, { type: i1$2.Shops, decorators: [{
1803
- type: Inject,
1804
- args: [DEFAULT_SHOP]
1758
+ class CategoryService {
1759
+ constructor(productRepository, categoryRepository, categoryFilterRepository, categoryStructureAdapter, shop) {
1760
+ this.productRepository = productRepository;
1761
+ this.categoryRepository = categoryRepository;
1762
+ this.categoryFilterRepository = categoryFilterRepository;
1763
+ this.categoryStructureAdapter = categoryStructureAdapter;
1764
+ this.shop = shop;
1765
+ }
1766
+ async fetchBrands(category, options) {
1767
+ const brands = await this.productRepository
1768
+ .findCatalog({
1769
+ filters: await this.categoryStructureAdapter.buildProductFilterByCategory(category),
1770
+ fields: ['brand'],
1771
+ }, options?.mainGender ? options?.mainGender : this.shop === Shops.MENSMARKET ? 'male' : 'female')
1772
+ .then(({ data }) => Object.keys(data.map((product) => product.brand).reduce((brands, brand) => ({ ...brands, [brand]: true }), {})));
1773
+ return this.categoryRepository
1774
+ .find({ filters: { brandCategory: true, shop: options?.shop || this.shop }, orderBy: { name: 'asc' } })
1775
+ .then(({ data }) => data.filter((category) => brands.includes(category.conditions.brand)));
1776
+ }
1777
+ async fetchFilterOptions(category) {
1778
+ return await this.categoryFilterRepository
1779
+ .find({ filters: { categoryId: +category.id } })
1780
+ .then(({ data }) => data.map((categoryFilter) => categoryFilter.filter));
1781
+ }
1782
+ }
1783
+ CategoryService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: CategoryService, deps: [{ token: 'ProductRepository' }, { token: 'CategoryRepository' }, { token: 'CategoryFilterRepository' }, { token: CATEGORY_STRUCTURE }, { token: DEFAULT_SHOP }], target: i0.ɵɵFactoryTarget.Injectable });
1784
+ CategoryService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: CategoryService });
1785
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: CategoryService, decorators: [{
1786
+ type: Injectable
1787
+ }], ctorParameters: function () { return [{ type: undefined, decorators: [{
1788
+ type: Inject,
1789
+ args: ['ProductRepository']
1790
+ }] }, { type: undefined, decorators: [{
1791
+ type: Inject,
1792
+ args: ['CategoryRepository']
1793
+ }] }, { type: undefined, decorators: [{
1794
+ type: Inject,
1795
+ args: ['CategoryFilterRepository']
1796
+ }] }, { type: undefined, decorators: [{
1797
+ type: Inject,
1798
+ args: [CATEGORY_STRUCTURE]
1799
+ }] }, { type: i1$2.Shops, decorators: [{
1800
+ type: Inject,
1801
+ args: [DEFAULT_SHOP]
1805
1802
  }] }]; } });
1806
1803
 
1807
- var ProductSorts;
1808
- (function (ProductSorts) {
1809
- ProductSorts["MOST_RELEVANT"] = "most-relevant";
1810
- ProductSorts["BEST_SELLER"] = "best-sellers";
1811
- ProductSorts["BIGGEST_PRICE"] = "biggest-price";
1812
- ProductSorts["LOWEST_PRICE"] = "lowest-price";
1813
- ProductSorts["BIGGEST_DISCOUNT"] = "biggest-discount";
1814
- ProductSorts["BEST_RATING"] = "best-rating";
1815
- ProductSorts["NEWS"] = "news";
1804
+ var ProductSorts;
1805
+ (function (ProductSorts) {
1806
+ ProductSorts["MOST_RELEVANT"] = "most-relevant";
1807
+ ProductSorts["BEST_SELLER"] = "best-sellers";
1808
+ ProductSorts["BIGGEST_PRICE"] = "biggest-price";
1809
+ ProductSorts["LOWEST_PRICE"] = "lowest-price";
1810
+ ProductSorts["BIGGEST_DISCOUNT"] = "biggest-discount";
1811
+ ProductSorts["BEST_RATING"] = "best-rating";
1812
+ ProductSorts["NEWS"] = "news";
1816
1813
  })(ProductSorts || (ProductSorts = {}));
1817
1814
 
1818
- class CategoryWithTree extends Category {
1819
- }
1820
- __decorate([
1821
- Type(() => CategoryWithTree),
1822
- __metadata("design:type", Array)
1815
+ class CategoryWithTree extends Category {
1816
+ }
1817
+ __decorate([
1818
+ Type(() => CategoryWithTree),
1819
+ __metadata("design:type", Array)
1823
1820
  ], CategoryWithTree.prototype, "children", void 0);
1824
1821
 
1825
- class WishlistService {
1826
- constructor(wishlistRepository, shop, productRepository, categoryFilterRepository, categoryRepository, productIndex) {
1827
- this.wishlistRepository = wishlistRepository;
1828
- this.shop = shop;
1829
- const categoryStructureAdapter = new NewCategoryStructureAdapter(wishlistRepository);
1830
- this.catalogService = new CatalogService(productRepository, categoryRepository, categoryStructureAdapter, shop, productIndex);
1831
- this.categoryService = new CategoryService(productRepository, categoryRepository, categoryFilterRepository, categoryStructureAdapter, shop);
1832
- }
1833
- getCatalogService() {
1834
- return this.catalogService;
1835
- }
1836
- getCategoryService() {
1837
- return this.categoryService;
1838
- }
1839
- async create({ personId, title, description, userFullName, userPhoto, theme, bannerUrl, }) {
1840
- const data = {
1841
- slug: '',
1842
- name: title,
1843
- description,
1844
- metadata: {
1845
- title: `${userFullName} - ${title}`,
1846
- description: `${userFullName} - ${description}`,
1847
- },
1848
- shop: this.shop,
1849
- shops: [this.shop],
1850
- personId,
1851
- personName: userFullName,
1852
- personPhoto: userPhoto,
1853
- brandCategory: false,
1854
- published: true,
1855
- theme,
1856
- bannerUrl,
1857
- };
1858
- const newWishlist = await this.wishlistRepository.create(data);
1859
- await this.wishlistRepository.update({ id: newWishlist.id, slug: newWishlist.id });
1860
- return Wishlist.toInstance({ ...newWishlist.toPlain(), slug: newWishlist.id });
1861
- }
1862
- update({ id, title, description, userFullName, userPhoto, theme, bannerUrl, }) {
1863
- const data = {
1864
- id,
1865
- name: title,
1866
- description,
1867
- metadata: {
1868
- title: `${userFullName} - ${title}`,
1869
- description: `${userFullName} - ${description}`,
1870
- },
1871
- personName: userFullName,
1872
- personPhoto: userPhoto,
1873
- theme,
1874
- bannerUrl,
1875
- };
1876
- return this.wishlistRepository.update(data);
1877
- }
1878
- delete(wishlistId) {
1879
- return this.wishlistRepository.delete({ id: wishlistId });
1880
- }
1881
- getWishlistBySlug(slug) {
1882
- const [id] = slug.split('-');
1883
- if (+id)
1884
- return this.wishlistRepository.get({ id });
1885
- return this.wishlistRepository.getWishlistBySlug(slug);
1886
- }
1887
- getWishlistsByPerson(personId) {
1888
- return this.wishlistRepository.getWishlistByPerson(personId);
1889
- }
1890
- async addProduct(wishlistId, productId) {
1891
- const wishlist = await this.wishlistRepository.get({ id: wishlistId });
1892
- const hasProduct = wishlist.products.some((p) => p == productId);
1893
- if (!hasProduct) {
1894
- wishlist.products = [...wishlist.products, productId];
1895
- return this.wishlistRepository.update({ id: wishlistId, products: wishlist.products });
1896
- }
1897
- return wishlist;
1898
- }
1899
- async removeProduct(wishlistId, productId) {
1900
- const wishlist = await this.wishlistRepository.get({ id: wishlistId });
1901
- const productIndex = wishlist.products.findIndex((p) => p == productId);
1902
- if (productIndex != -1) {
1903
- wishlist.products.splice(productIndex, 1);
1904
- if (!wishlist.products.length)
1905
- return this.wishlistRepository.update({ id: wishlistId, products: { action: 'remove' } });
1906
- return this.wishlistRepository.update({ id: wishlistId, products: wishlist.products });
1907
- }
1908
- return wishlist;
1909
- }
1910
- }
1911
- WishlistService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: WishlistService, deps: [{ token: 'WishlistRepository' }, { token: DEFAULT_SHOP }, { token: 'ProductRepository' }, { token: 'CategoryFilterRepository' }, { token: 'CategoryRepository' }, { token: i1$2.ProductsIndex }], target: i0.ɵɵFactoryTarget.Injectable });
1912
- WishlistService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: WishlistService });
1913
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: WishlistService, decorators: [{
1914
- type: Injectable
1915
- }], ctorParameters: function () { return [{ type: undefined, decorators: [{
1916
- type: Inject,
1917
- args: ['WishlistRepository']
1918
- }] }, { type: i1$2.Shops, decorators: [{
1919
- type: Inject,
1920
- args: [DEFAULT_SHOP]
1921
- }] }, { type: undefined, decorators: [{
1922
- type: Inject,
1923
- args: ['ProductRepository']
1924
- }] }, { type: undefined, decorators: [{
1925
- type: Inject,
1926
- args: ['CategoryFilterRepository']
1927
- }] }, { type: undefined, decorators: [{
1928
- type: Inject,
1929
- args: ['CategoryRepository']
1822
+ class WishlistService {
1823
+ constructor(wishlistRepository, shop, productRepository, categoryFilterRepository, categoryRepository, productIndex) {
1824
+ this.wishlistRepository = wishlistRepository;
1825
+ this.shop = shop;
1826
+ const categoryStructureAdapter = new NewCategoryStructureAdapter(wishlistRepository);
1827
+ this.catalogService = new CatalogService(productRepository, categoryRepository, categoryStructureAdapter, shop, productIndex);
1828
+ this.categoryService = new CategoryService(productRepository, categoryRepository, categoryFilterRepository, categoryStructureAdapter, shop);
1829
+ }
1830
+ getCatalogService() {
1831
+ return this.catalogService;
1832
+ }
1833
+ getCategoryService() {
1834
+ return this.categoryService;
1835
+ }
1836
+ async create({ personId, title, description, userFullName, userPhoto, theme, bannerUrl, }) {
1837
+ const data = {
1838
+ slug: '',
1839
+ name: title,
1840
+ description,
1841
+ metadata: {
1842
+ title: `${userFullName} - ${title}`,
1843
+ description: `${userFullName} - ${description}`,
1844
+ },
1845
+ shop: this.shop,
1846
+ shops: [this.shop],
1847
+ personId,
1848
+ personName: userFullName,
1849
+ personPhoto: userPhoto,
1850
+ brandCategory: false,
1851
+ published: true,
1852
+ theme,
1853
+ bannerUrl,
1854
+ };
1855
+ const newWishlist = await this.wishlistRepository.create(data);
1856
+ await this.wishlistRepository.update({ id: newWishlist.id, slug: newWishlist.id });
1857
+ return Wishlist.toInstance({ ...newWishlist.toPlain(), slug: newWishlist.id });
1858
+ }
1859
+ update({ id, title, description, userFullName, userPhoto, theme, bannerUrl, }) {
1860
+ const data = {
1861
+ id,
1862
+ name: title,
1863
+ description,
1864
+ metadata: {
1865
+ title: `${userFullName} - ${title}`,
1866
+ description: `${userFullName} - ${description}`,
1867
+ },
1868
+ personName: userFullName,
1869
+ personPhoto: userPhoto,
1870
+ theme,
1871
+ bannerUrl,
1872
+ };
1873
+ return this.wishlistRepository.update(data);
1874
+ }
1875
+ delete(wishlistId) {
1876
+ return this.wishlistRepository.delete({ id: wishlistId });
1877
+ }
1878
+ getWishlistBySlug(slug) {
1879
+ const [id] = slug.split('-');
1880
+ if (+id)
1881
+ return this.wishlistRepository.get({ id });
1882
+ return this.wishlistRepository.getWishlistBySlug(slug);
1883
+ }
1884
+ getWishlistsByPerson(personId) {
1885
+ return this.wishlistRepository.getWishlistByPerson(personId);
1886
+ }
1887
+ async addProduct(wishlistId, productId) {
1888
+ const wishlist = await this.wishlistRepository.get({ id: wishlistId });
1889
+ const hasProduct = wishlist.products.some((p) => p == productId);
1890
+ if (!hasProduct) {
1891
+ wishlist.products = [...wishlist.products, productId];
1892
+ return this.wishlistRepository.update({ id: wishlistId, products: wishlist.products });
1893
+ }
1894
+ return wishlist;
1895
+ }
1896
+ async removeProduct(wishlistId, productId) {
1897
+ const wishlist = await this.wishlistRepository.get({ id: wishlistId });
1898
+ const productIndex = wishlist.products.findIndex((p) => p == productId);
1899
+ if (productIndex != -1) {
1900
+ wishlist.products.splice(productIndex, 1);
1901
+ if (!wishlist.products.length)
1902
+ return this.wishlistRepository.update({ id: wishlistId, products: { action: 'remove' } });
1903
+ return this.wishlistRepository.update({ id: wishlistId, products: wishlist.products });
1904
+ }
1905
+ return wishlist;
1906
+ }
1907
+ }
1908
+ WishlistService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: WishlistService, deps: [{ token: 'WishlistRepository' }, { token: DEFAULT_SHOP }, { token: 'ProductRepository' }, { token: 'CategoryFilterRepository' }, { token: 'CategoryRepository' }, { token: i1$2.ProductsIndex }], target: i0.ɵɵFactoryTarget.Injectable });
1909
+ WishlistService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: WishlistService });
1910
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: WishlistService, decorators: [{
1911
+ type: Injectable
1912
+ }], ctorParameters: function () { return [{ type: undefined, decorators: [{
1913
+ type: Inject,
1914
+ args: ['WishlistRepository']
1915
+ }] }, { type: i1$2.Shops, decorators: [{
1916
+ type: Inject,
1917
+ args: [DEFAULT_SHOP]
1918
+ }] }, { type: undefined, decorators: [{
1919
+ type: Inject,
1920
+ args: ['ProductRepository']
1921
+ }] }, { type: undefined, decorators: [{
1922
+ type: Inject,
1923
+ args: ['CategoryFilterRepository']
1924
+ }] }, { type: undefined, decorators: [{
1925
+ type: Inject,
1926
+ args: ['CategoryRepository']
1930
1927
  }] }, { type: i1$2.ProductsIndex }]; } });
1931
1928
 
1932
- class CheckoutSubscriptionService {
1933
- constructor(checkoutSubscriptionRepository, subscriptionRepository, couponService) {
1934
- this.checkoutSubscriptionRepository = checkoutSubscriptionRepository;
1935
- this.subscriptionRepository = subscriptionRepository;
1936
- this.couponService = couponService;
1937
- }
1938
- getCheckoutSubscription(checkoutData) {
1939
- const checkoutId = cookie.get('checkoutSubscriptionId');
1940
- if (!isNil(checkoutId))
1941
- return from(this.checkoutSubscriptionRepository.get({ id: checkoutId }));
1942
- return from(this.createCheckoutSubscription(checkoutData));
1943
- }
1944
- async createCheckoutSubscription(checkoutData) {
1945
- const checkout = await this.checkoutSubscriptionRepository.create({
1946
- createdAt: new Date(),
1947
- ...CheckoutSubscription.toInstance(pick(checkoutData, ['user', 'shop'])).toPlain(),
1948
- });
1949
- cookie.set('checkoutSubscriptionId', checkout.id);
1950
- return checkout;
1951
- }
1952
- clearCheckoutSubscriptionFromSession() {
1953
- cookie.remove('checkoutSubscriptionId');
1954
- return of();
1955
- }
1956
- checkCoupon(nickname, userEmail) {
1957
- return this.getCheckoutSubscription().pipe(concatMap((checkout) => this.couponService
1958
- .checkCoupon(nickname, CheckoutTypes.SUBSCRIPTION, checkout, checkout.subscriptionPlan.name)
1959
- .pipe()));
1960
- }
1961
- calcDiscountSubscription(coupon) {
1962
- return this.getCheckoutSubscription().pipe(concatMap((checkout) => this.couponService.calcDiscountSubscription(coupon, checkout).pipe()));
1963
- }
1964
- }
1965
- CheckoutSubscriptionService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: CheckoutSubscriptionService, deps: [{ token: 'CheckoutSubscriptionRepository' }, { token: 'SubscriptionRepository' }, { token: CouponService }], target: i0.ɵɵFactoryTarget.Injectable });
1966
- CheckoutSubscriptionService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: CheckoutSubscriptionService });
1967
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: CheckoutSubscriptionService, decorators: [{
1968
- type: Injectable
1969
- }], ctorParameters: function () { return [{ type: undefined, decorators: [{
1970
- type: Inject,
1971
- args: ['CheckoutSubscriptionRepository']
1972
- }] }, { type: undefined, decorators: [{
1973
- type: Inject,
1974
- args: ['SubscriptionRepository']
1929
+ class CheckoutSubscriptionService {
1930
+ constructor(checkoutSubscriptionRepository, subscriptionRepository, couponService) {
1931
+ this.checkoutSubscriptionRepository = checkoutSubscriptionRepository;
1932
+ this.subscriptionRepository = subscriptionRepository;
1933
+ this.couponService = couponService;
1934
+ }
1935
+ getCheckoutSubscription(checkoutData) {
1936
+ const checkoutId = cookie.get('checkoutSubscriptionId');
1937
+ if (!isNil(checkoutId))
1938
+ return from(this.checkoutSubscriptionRepository.get({ id: checkoutId }));
1939
+ return from(this.createCheckoutSubscription(checkoutData));
1940
+ }
1941
+ async createCheckoutSubscription(checkoutData) {
1942
+ const checkout = await this.checkoutSubscriptionRepository.create({
1943
+ createdAt: new Date(),
1944
+ ...CheckoutSubscription.toInstance(pick(checkoutData, ['user', 'shop'])).toPlain(),
1945
+ });
1946
+ cookie.set('checkoutSubscriptionId', checkout.id);
1947
+ return checkout;
1948
+ }
1949
+ clearCheckoutSubscriptionFromSession() {
1950
+ cookie.remove('checkoutSubscriptionId');
1951
+ return of();
1952
+ }
1953
+ checkCoupon(nickname, userEmail) {
1954
+ return this.getCheckoutSubscription().pipe(concatMap((checkout) => this.couponService
1955
+ .checkCoupon(nickname, CheckoutTypes.SUBSCRIPTION, checkout, checkout.subscriptionPlan.name)
1956
+ .pipe()));
1957
+ }
1958
+ calcDiscountSubscription(coupon) {
1959
+ return this.getCheckoutSubscription().pipe(concatMap((checkout) => this.couponService.calcDiscountSubscription(coupon, checkout).pipe()));
1960
+ }
1961
+ }
1962
+ CheckoutSubscriptionService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: CheckoutSubscriptionService, deps: [{ token: 'CheckoutSubscriptionRepository' }, { token: 'SubscriptionRepository' }, { token: CouponService }], target: i0.ɵɵFactoryTarget.Injectable });
1963
+ CheckoutSubscriptionService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: CheckoutSubscriptionService });
1964
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: CheckoutSubscriptionService, decorators: [{
1965
+ type: Injectable
1966
+ }], ctorParameters: function () { return [{ type: undefined, decorators: [{
1967
+ type: Inject,
1968
+ args: ['CheckoutSubscriptionRepository']
1969
+ }] }, { type: undefined, decorators: [{
1970
+ type: Inject,
1971
+ args: ['SubscriptionRepository']
1975
1972
  }] }, { type: CouponService }]; } });
1976
1973
 
1977
- class UtilHelper {
1978
- static createSlug(name) {
1979
- return name
1980
- .toLowerCase()
1981
- .replace(/\s+/g, '-') // Replace spaces with -
1982
- .replace(/[ãàáäâ]/g, 'a') // Replace spaces with -
1983
- .replace(/[ẽèéëê]/g, 'e') // Replace spaces with -
1984
- .replace(/[ìíïî]/g, 'i') // Replace spaces with -
1985
- .replace(/[õòóöô]/g, 'o') // Replace spaces with -
1986
- .replace(/[ùúüû]/g, 'u') // Replace spaces with -
1987
- .replace(/[ñ]/g, 'n') // Replace spaces with -
1988
- .replace(/[ç]/g, 'c') // Replace spaces with -
1989
- .replace(/[&]/g, 'and') // Replace spaces with -
1990
- .replace(/[^\w\-]+/g, '') // Remove all non-word chars
1991
- .replace(/\-\-+/g, '-'); // Replace multiple - with single -
1992
- }
1974
+ class UtilHelper {
1975
+ static createSlug(name) {
1976
+ return name
1977
+ .toLowerCase()
1978
+ .replace(/\s+/g, '-') // Replace spaces with -
1979
+ .replace(/[ãàáäâ]/g, 'a') // Replace spaces with -
1980
+ .replace(/[ẽèéëê]/g, 'e') // Replace spaces with -
1981
+ .replace(/[ìíïî]/g, 'i') // Replace spaces with -
1982
+ .replace(/[õòóöô]/g, 'o') // Replace spaces with -
1983
+ .replace(/[ùúüû]/g, 'u') // Replace spaces with -
1984
+ .replace(/[ñ]/g, 'n') // Replace spaces with -
1985
+ .replace(/[ç]/g, 'c') // Replace spaces with -
1986
+ .replace(/[&]/g, 'and') // Replace spaces with -
1987
+ .replace(/[^\w\-]+/g, '') // Remove all non-word chars
1988
+ .replace(/\-\-+/g, '-'); // Replace multiple - with single -
1989
+ }
1993
1990
  }
1994
1991
 
1995
- class HomeShopService {
1996
- get homeId() {
1997
- if (this.defaultShop === Shops.GLAMSHOP)
1998
- return 'glamshop';
1999
- if (this.defaultShop === Shops.MENSMARKET)
2000
- return 'mens_market';
2001
- return null;
2002
- }
2003
- constructor(categoryRepository, homeRepository, productRepository, defaultShop) {
2004
- this.categoryRepository = categoryRepository;
2005
- this.homeRepository = homeRepository;
2006
- this.productRepository = productRepository;
2007
- this.defaultShop = defaultShop;
2008
- this.buildCategoryGroupWithRequiredData = (group) => ({
2009
- category: Category.toInstance(pick(group?.category?.toPlain() || {}, ['id', 'name', 'slug', 'conditions'])),
2010
- products: group?.products?.map((product) => Product.toInstance(pick(product?.toPlain() || {}, [
2011
- 'id',
2012
- 'price',
2013
- 'reviews',
2014
- 'hasVariants',
2015
- 'slug',
2016
- 'sku',
2017
- 'stock',
2018
- 'costPrice',
2019
- 'images',
2020
- 'miniatures',
2021
- 'name',
2022
- 'weight',
2023
- 'rate',
2024
- 'type',
2025
- 'brand',
2026
- ]))) || [],
2027
- });
2028
- }
2029
- getHomeData() {
2030
- return this.getHomeConfiguration().pipe(map((home) => (home?.data?.expiresAt > new Date() ? home : null)), concatMap((home) => home
2031
- ? of(home)
2032
- : forkJoin([
2033
- this.getDiscoverProducts(this.gender),
2034
- this.getFeaturedProducts(this.gender),
2035
- this.getVerticalProducts(this.gender),
2036
- ]).pipe(map(([discoverProducts, featuredProducts, verticalProducts]) => ({
2037
- discoverProducts,
2038
- featuredProducts,
2039
- verticalProducts,
2040
- })), concatMap((data) => this.saveHomeData(data)))));
2041
- }
2042
- getBanners(type) {
2043
- return this.getHomeConfiguration().pipe(map((home) => {
2044
- if (type === 'brand')
2045
- return home.brandsCarousel;
2046
- if (type === 'buyToWin')
2047
- return [home.buyToWinBanner];
2048
- if (type === 'block')
2049
- return home.blockBanners;
2050
- if (type === 'blog')
2051
- return [home.blogBanner];
2052
- return [];
2053
- }));
2054
- }
2055
- getMinValueForFreeShipping() {
2056
- return this.getHomeConfiguration().pipe(map((home) => home.minValueForFreeShipping));
2057
- }
2058
- getDiscoverProducts(gender) {
2059
- return this.getHomeConfiguration().pipe(concatMap((home) => from(this.categoryRepository.getCategoriesForHome(home.discoverCategories, undefined, gender)).pipe(map((groups) => groups.map(this.buildCategoryGroupWithRequiredData)))));
2060
- }
2061
- getFeaturedProducts(gender) {
2062
- return this.getHomeConfiguration().pipe(concatMap((home) => from(this.categoryRepository.getCategoriesForHome(home.featuredCategories, undefined, gender)).pipe(map((groups) => groups.map(this.buildCategoryGroupWithRequiredData)))));
2063
- }
2064
- getVerticalProducts(gender) {
2065
- return this.getHomeConfiguration().pipe(concatMap((home) => forkJoin(home.verticalCarousels.filter(Boolean).map((id) => from(this.categoryRepository.get({ id })).pipe(concatMap((category) => from(this.productRepository.find({
2066
- filters: {
2067
- categories: { operator: Where.IN, value: [category.id] },
2068
- ...(gender ? { tags: { operator: Where.IN, value: [gender] } } : {}),
2069
- },
2070
- limits: { limit: 12 },
2071
- })).pipe(map((products) => ({ category, products })))), map(({ category, products }) => ({ category, products: products.data })), map(this.buildCategoryGroupWithRequiredData))))));
2072
- }
2073
- getHomeConfiguration() {
2074
- return of(this.homeConfiguration).pipe(concatMap((home) => home
2075
- ? of(home)
2076
- : !this.homeId
2077
- ? throwError(new RequiredArgumentError(['homeId']))
2078
- : from(this.homeRepository.get({ id: this.homeId })).pipe(tap((homeLoaded) => (this.homeConfiguration = homeLoaded)))));
2079
- }
2080
- saveHomeData(homeData) {
2081
- const data = {
2082
- createdAt: new Date(),
2083
- expiresAt: add(new Date(), { hours: 1 }),
2084
- data: homeData,
2085
- };
2086
- return from(this.homeRepository.update({
2087
- id: this.homeId,
2088
- data,
2089
- })).pipe(tap(() => (this.homeConfiguration.data = data)), map(() => this.homeConfiguration));
2090
- }
2091
- get gender() {
2092
- return this.homeId === 'mens_market' ? 'masculino' : undefined;
2093
- }
2094
- }
2095
- HomeShopService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: HomeShopService, deps: [{ token: 'CategoryRepository' }, { token: 'HomeRepository' }, { token: 'ProductRepository' }, { token: DEFAULT_SHOP }], target: i0.ɵɵFactoryTarget.Injectable });
2096
- HomeShopService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: HomeShopService });
2097
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: HomeShopService, decorators: [{
2098
- type: Injectable
2099
- }], ctorParameters: function () { return [{ type: undefined, decorators: [{
2100
- type: Inject,
2101
- args: ['CategoryRepository']
2102
- }] }, { type: undefined, decorators: [{
2103
- type: Inject,
2104
- args: ['HomeRepository']
2105
- }] }, { type: undefined, decorators: [{
2106
- type: Inject,
2107
- args: ['ProductRepository']
2108
- }] }, { type: i1$2.Shops, decorators: [{
2109
- type: Inject,
2110
- args: [DEFAULT_SHOP]
1992
+ class HomeShopService {
1993
+ get homeId() {
1994
+ if (this.defaultShop === Shops.GLAMSHOP)
1995
+ return 'glamshop';
1996
+ if (this.defaultShop === Shops.MENSMARKET)
1997
+ return 'mens_market';
1998
+ return null;
1999
+ }
2000
+ constructor(categoryRepository, homeRepository, productRepository, defaultShop) {
2001
+ this.categoryRepository = categoryRepository;
2002
+ this.homeRepository = homeRepository;
2003
+ this.productRepository = productRepository;
2004
+ this.defaultShop = defaultShop;
2005
+ this.buildCategoryGroupWithRequiredData = (group) => ({
2006
+ category: Category.toInstance(pick(group?.category?.toPlain() || {}, ['id', 'name', 'slug', 'conditions'])),
2007
+ products: group?.products?.map((product) => Product.toInstance(pick(product?.toPlain() || {}, [
2008
+ 'id',
2009
+ 'price',
2010
+ 'reviews',
2011
+ 'hasVariants',
2012
+ 'slug',
2013
+ 'sku',
2014
+ 'stock',
2015
+ 'costPrice',
2016
+ 'images',
2017
+ 'miniatures',
2018
+ 'name',
2019
+ 'weight',
2020
+ 'rate',
2021
+ 'type',
2022
+ 'brand',
2023
+ ]))) || [],
2024
+ });
2025
+ }
2026
+ getHomeData() {
2027
+ return this.getHomeConfiguration().pipe(map((home) => (home?.data?.expiresAt > new Date() ? home : null)), concatMap((home) => home
2028
+ ? of(home)
2029
+ : forkJoin([
2030
+ this.getDiscoverProducts(this.gender),
2031
+ this.getFeaturedProducts(this.gender),
2032
+ this.getVerticalProducts(this.gender),
2033
+ ]).pipe(map(([discoverProducts, featuredProducts, verticalProducts]) => ({
2034
+ discoverProducts,
2035
+ featuredProducts,
2036
+ verticalProducts,
2037
+ })), concatMap((data) => this.saveHomeData(data)))));
2038
+ }
2039
+ getBanners(type) {
2040
+ return this.getHomeConfiguration().pipe(map((home) => {
2041
+ if (type === 'brand')
2042
+ return home.brandsCarousel;
2043
+ if (type === 'buyToWin')
2044
+ return [home.buyToWinBanner];
2045
+ if (type === 'block')
2046
+ return home.blockBanners;
2047
+ if (type === 'blog')
2048
+ return [home.blogBanner];
2049
+ return [];
2050
+ }));
2051
+ }
2052
+ getMinValueForFreeShipping() {
2053
+ return this.getHomeConfiguration().pipe(map((home) => home.minValueForFreeShipping));
2054
+ }
2055
+ getDiscoverProducts(gender) {
2056
+ return this.getHomeConfiguration().pipe(concatMap((home) => from(this.categoryRepository.getCategoriesForHome(home.discoverCategories, undefined, gender)).pipe(map((groups) => groups.map(this.buildCategoryGroupWithRequiredData)))));
2057
+ }
2058
+ getFeaturedProducts(gender) {
2059
+ return this.getHomeConfiguration().pipe(concatMap((home) => from(this.categoryRepository.getCategoriesForHome(home.featuredCategories, undefined, gender)).pipe(map((groups) => groups.map(this.buildCategoryGroupWithRequiredData)))));
2060
+ }
2061
+ getVerticalProducts(gender) {
2062
+ return this.getHomeConfiguration().pipe(concatMap((home) => forkJoin(home.verticalCarousels.filter(Boolean).map((id) => from(this.categoryRepository.get({ id })).pipe(concatMap((category) => from(this.productRepository.find({
2063
+ filters: {
2064
+ categories: { operator: Where.IN, value: [category.id] },
2065
+ ...(gender ? { tags: { operator: Where.IN, value: [gender] } } : {}),
2066
+ },
2067
+ limits: { limit: 12 },
2068
+ })).pipe(map((products) => ({ category, products })))), map(({ category, products }) => ({ category, products: products.data })), map(this.buildCategoryGroupWithRequiredData))))));
2069
+ }
2070
+ getHomeConfiguration() {
2071
+ return of(this.homeConfiguration).pipe(concatMap((home) => home
2072
+ ? of(home)
2073
+ : !this.homeId
2074
+ ? throwError(new RequiredArgumentError(['homeId']))
2075
+ : from(this.homeRepository.get({ id: this.homeId })).pipe(tap((homeLoaded) => (this.homeConfiguration = homeLoaded)))));
2076
+ }
2077
+ saveHomeData(homeData) {
2078
+ const data = {
2079
+ createdAt: new Date(),
2080
+ expiresAt: add(new Date(), { hours: 1 }),
2081
+ data: homeData,
2082
+ };
2083
+ return from(this.homeRepository.update({
2084
+ id: this.homeId,
2085
+ data,
2086
+ })).pipe(tap(() => (this.homeConfiguration.data = data)), map(() => this.homeConfiguration));
2087
+ }
2088
+ get gender() {
2089
+ return this.homeId === 'mens_market' ? 'masculino' : undefined;
2090
+ }
2091
+ }
2092
+ HomeShopService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: HomeShopService, deps: [{ token: 'CategoryRepository' }, { token: 'HomeRepository' }, { token: 'ProductRepository' }, { token: DEFAULT_SHOP }], target: i0.ɵɵFactoryTarget.Injectable });
2093
+ HomeShopService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: HomeShopService });
2094
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: HomeShopService, decorators: [{
2095
+ type: Injectable
2096
+ }], ctorParameters: function () { return [{ type: undefined, decorators: [{
2097
+ type: Inject,
2098
+ args: ['CategoryRepository']
2099
+ }] }, { type: undefined, decorators: [{
2100
+ type: Inject,
2101
+ args: ['HomeRepository']
2102
+ }] }, { type: undefined, decorators: [{
2103
+ type: Inject,
2104
+ args: ['ProductRepository']
2105
+ }] }, { type: i1$2.Shops, decorators: [{
2106
+ type: Inject,
2107
+ args: [DEFAULT_SHOP]
2111
2108
  }] }]; } });
2112
2109
 
2113
- class OrderService {
2114
- constructor(angularFirestore, orderRepository) {
2115
- this.angularFirestore = angularFirestore;
2116
- this.orderRepository = orderRepository;
2117
- this.orderSubject = new Subject();
2118
- }
2119
- getOrder(id) {
2120
- docSnapshots(doc(this.angularFirestore, `${this.orderRepository.collectionName}/${id}`))
2121
- .pipe(map((doc) => Order.toInstance(doc.data())))
2122
- .subscribe((doc) => this.orderSubject.next(doc));
2123
- return this.orderSubject;
2124
- }
2125
- }
2126
- OrderService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: OrderService, deps: [{ token: i1$1.Firestore }, { token: 'OrderRepository' }], target: i0.ɵɵFactoryTarget.Injectable });
2127
- OrderService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: OrderService });
2128
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: OrderService, decorators: [{
2129
- type: Injectable
2130
- }], ctorParameters: function () { return [{ type: i1$1.Firestore }, { type: i1$2.OrderFirestoreRepository, decorators: [{
2131
- type: Inject,
2132
- args: ['OrderRepository']
2110
+ class OrderService {
2111
+ constructor(angularFirestore, orderRepository) {
2112
+ this.angularFirestore = angularFirestore;
2113
+ this.orderRepository = orderRepository;
2114
+ this.orderSubject = new Subject();
2115
+ }
2116
+ getOrder(id) {
2117
+ docSnapshots(doc(this.angularFirestore, `${this.orderRepository.collectionName}/${id}`))
2118
+ .pipe(map((doc) => Order.toInstance(doc.data())))
2119
+ .subscribe((doc) => this.orderSubject.next(doc));
2120
+ return this.orderSubject;
2121
+ }
2122
+ }
2123
+ OrderService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: OrderService, deps: [{ token: i1$1.Firestore }, { token: 'OrderRepository' }], target: i0.ɵɵFactoryTarget.Injectable });
2124
+ OrderService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: OrderService });
2125
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: OrderService, decorators: [{
2126
+ type: Injectable
2127
+ }], ctorParameters: function () { return [{ type: i1$1.Firestore }, { type: i1$2.OrderFirestoreRepository, decorators: [{
2128
+ type: Inject,
2129
+ args: ['OrderRepository']
2133
2130
  }] }]; } });
2134
2131
 
2135
- class ShippingService {
2136
- constructor(http, apiUrl, homeService) {
2137
- this.http = http;
2138
- this.apiUrl = apiUrl;
2139
- this.homeService = homeService;
2140
- }
2141
- getShippingMethods(shop, zip, weightGrams, totalPrice, personId, subscriptionPlan) {
2142
- return combineLatest([
2143
- this.homeService.getHomeData(),
2144
- this.http.get(`${this.apiUrl}open/checkshippingcompany?personId=${personId}&postalCode=${zip}&weightGrams=${weightGrams}`),
2145
- ]).pipe(map(([datas, shippingMethodsResponse]) => {
2146
- let shippingMethods = shippingMethodsResponse.result;
2147
- if (!shippingMethods.length)
2148
- return [];
2149
- shippingMethods = shippingMethods.map((shippingMethod) => {
2150
- if (shippingMethod.ShippingCompanyName == 'Same Day EG')
2151
- shippingMethod.ShippingCompanyName = 'Same Day';
2152
- return shippingMethod;
2153
- });
2154
- const datasSameDayNotAvaliable = datas.sameDayNotAvaliable;
2155
- if (this.isHolidays(datasSameDayNotAvaliable)) {
2156
- shippingMethods = shippingMethods.filter((method) => method.serviceName !== 'Same Day');
2157
- }
2158
- if (totalPrice >= 200) {
2159
- shippingMethods = shippingMethods.map((s) => {
2160
- if (s.serviceName !== 'Same Day')
2161
- return { ...s, totalPrice: 0 };
2162
- else
2163
- return s;
2164
- });
2165
- }
2166
- if (shop == Shops.GLAMSHOP)
2167
- return shippingMethods;
2168
- if (this.isFreeShippingBySubscription(shop, subscriptionPlan)) {
2169
- shippingMethods = shippingMethods.map((s) => {
2170
- if (s.serviceName == 'Same Day')
2171
- return { ...s, totalPrice: s.totalPrice / 2 };
2172
- else
2173
- return { ...s, totalPrice: 0 };
2174
- });
2175
- }
2176
- if (this.isHalfShippingBySubscription(shop, subscriptionPlan)) {
2177
- shippingMethods = shippingMethods.map((s) => {
2178
- return { ...s, totalPrice: s.totalPrice / 2 };
2179
- });
2180
- }
2181
- return shippingMethods;
2182
- }));
2183
- }
2184
- isFreeShippingBySubscription(shop, subscriptionPlan) {
2185
- if (!subscriptionPlan)
2186
- return false;
2187
- if (shop == Shops.MENSMARKET && subscriptionPlan == 'SELECT')
2188
- return true;
2189
- return false;
2190
- }
2191
- isHalfShippingBySubscription(shop, subscriptionPlan) {
2192
- if (!subscriptionPlan)
2193
- return false;
2194
- if (shop == Shops.MENSMARKET && subscriptionPlan == 'PRIME') {
2195
- return true;
2196
- }
2197
- return false;
2198
- }
2199
- isHolidays(datas) {
2200
- const today = new Date();
2201
- for (const key in datas) {
2202
- let start = new Date(`${today.getFullYear()}-${datas[key].beginDate}`);
2203
- let end = new Date(`${today.getFullYear()}-${datas[key].endDate}`);
2204
- if (start > end)
2205
- end = new Date(`${today.getFullYear() + 1}-${datas[key].endDate}`);
2206
- if (today >= start && today <= end)
2207
- return true;
2208
- }
2209
- return false;
2210
- }
2211
- }
2212
- ShippingService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: ShippingService, deps: [{ token: i1$3.HttpClient }, { token: BACKEND_URL }, { token: HomeShopService }], target: i0.ɵɵFactoryTarget.Injectable });
2213
- ShippingService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: ShippingService });
2214
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: ShippingService, decorators: [{
2215
- type: Injectable
2216
- }], ctorParameters: function () { return [{ type: i1$3.HttpClient }, { type: undefined, decorators: [{
2217
- type: Inject,
2218
- args: [BACKEND_URL]
2132
+ class ShippingService {
2133
+ constructor(http, apiUrl, homeService) {
2134
+ this.http = http;
2135
+ this.apiUrl = apiUrl;
2136
+ this.homeService = homeService;
2137
+ }
2138
+ getShippingMethods(shop, zip, weightGrams, totalPrice, personId, subscriptionPlan) {
2139
+ return combineLatest([
2140
+ this.homeService.getHomeData(),
2141
+ this.http.get(`${this.apiUrl}open/checkshippingcompany?personId=${personId}&postalCode=${zip}&weightGrams=${weightGrams}`),
2142
+ ]).pipe(map(([datas, shippingMethodsResponse]) => {
2143
+ let shippingMethods = shippingMethodsResponse.result;
2144
+ if (!shippingMethods.length)
2145
+ return [];
2146
+ shippingMethods = shippingMethods.map((shippingMethod) => {
2147
+ if (shippingMethod.ShippingCompanyName == 'Same Day EG')
2148
+ shippingMethod.ShippingCompanyName = 'Same Day';
2149
+ return shippingMethod;
2150
+ });
2151
+ const datasSameDayNotAvaliable = datas.sameDayNotAvaliable;
2152
+ if (this.isHolidays(datasSameDayNotAvaliable)) {
2153
+ shippingMethods = shippingMethods.filter((method) => method.serviceName !== 'Same Day');
2154
+ }
2155
+ if (totalPrice >= 200) {
2156
+ shippingMethods = shippingMethods.map((s) => {
2157
+ if (s.serviceName !== 'Same Day')
2158
+ return { ...s, totalPrice: 0 };
2159
+ else
2160
+ return s;
2161
+ });
2162
+ }
2163
+ if (shop == Shops.GLAMSHOP)
2164
+ return shippingMethods;
2165
+ if (this.isFreeShippingBySubscription(shop, subscriptionPlan)) {
2166
+ shippingMethods = shippingMethods.map((s) => {
2167
+ if (s.serviceName == 'Same Day')
2168
+ return { ...s, totalPrice: s.totalPrice / 2 };
2169
+ else
2170
+ return { ...s, totalPrice: 0 };
2171
+ });
2172
+ }
2173
+ if (this.isHalfShippingBySubscription(shop, subscriptionPlan)) {
2174
+ shippingMethods = shippingMethods.map((s) => {
2175
+ return { ...s, totalPrice: s.totalPrice / 2 };
2176
+ });
2177
+ }
2178
+ return shippingMethods;
2179
+ }));
2180
+ }
2181
+ isFreeShippingBySubscription(shop, subscriptionPlan) {
2182
+ if (!subscriptionPlan)
2183
+ return false;
2184
+ if (shop == Shops.MENSMARKET && subscriptionPlan == 'SELECT')
2185
+ return true;
2186
+ return false;
2187
+ }
2188
+ isHalfShippingBySubscription(shop, subscriptionPlan) {
2189
+ if (!subscriptionPlan)
2190
+ return false;
2191
+ if (shop == Shops.MENSMARKET && subscriptionPlan == 'PRIME') {
2192
+ return true;
2193
+ }
2194
+ return false;
2195
+ }
2196
+ isHolidays(datas) {
2197
+ const today = new Date();
2198
+ for (const key in datas) {
2199
+ let start = new Date(`${today.getFullYear()}-${datas[key].beginDate}`);
2200
+ let end = new Date(`${today.getFullYear()}-${datas[key].endDate}`);
2201
+ if (start > end)
2202
+ end = new Date(`${today.getFullYear() + 1}-${datas[key].endDate}`);
2203
+ if (today >= start && today <= end)
2204
+ return true;
2205
+ }
2206
+ return false;
2207
+ }
2208
+ }
2209
+ ShippingService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: ShippingService, deps: [{ token: i1$3.HttpClient }, { token: BACKEND_URL }, { token: HomeShopService }], target: i0.ɵɵFactoryTarget.Injectable });
2210
+ ShippingService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: ShippingService });
2211
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: ShippingService, decorators: [{
2212
+ type: Injectable
2213
+ }], ctorParameters: function () { return [{ type: i1$3.HttpClient }, { type: undefined, decorators: [{
2214
+ type: Inject,
2215
+ args: [BACKEND_URL]
2219
2216
  }] }, { type: HomeShopService }]; } });
2220
2217
 
2221
- class AngularConnectModule {
2222
- static initializeApp(defaultShop, options, nameOrConfig) {
2223
- return {
2224
- ngModule: AngularConnectModule,
2225
- providers: [
2226
- {
2227
- provide: CATEGORY_STRUCTURE,
2228
- useClass: isNil(options?.oldCategoryStructure) || options?.oldCategoryStructure
2229
- ? OldCategoryStructureAdapter
2230
- : NewCategoryStructureAdapter,
2231
- },
2232
- ...(isNil(defaultShop) ? [] : [{ provide: DEFAULT_SHOP, useValue: defaultShop }]),
2233
- ...(isNil(options?.firebase) ? [] : [{ provide: FIREBASE_OPTIONS, useValue: options?.firebase }]),
2234
- ...(isNil(options?.firebase) ? [] : [{ provide: FIREBASE_APP_NAME, useValue: nameOrConfig }]),
2235
- ...(isNil(options?.elasticSearch) ? [] : [{ provide: ES_CONFIG, useValue: options.elasticSearch }]),
2236
- ...(isNil(options?.hasura) ? [] : [{ provide: HASURA_OPTIONS, useValue: options.hasura }]),
2237
- ...(isNil(options?.backendUrl) ? [] : [{ provide: BACKEND_URL, useValue: options.backendUrl }]),
2238
- ...(isNil(options?.storageBaseUrl) ? [] : [{ provide: STORAGE_BASE_URL, useValue: options.storageBaseUrl }]),
2239
- ],
2240
- };
2241
- }
2242
- }
2243
- AngularConnectModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: AngularConnectModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
2244
- AngularConnectModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.1.0", ngImport: i0, type: AngularConnectModule, imports: [i1$4.FirebaseAppModule, AngularElasticSeachModule,
2245
- AngularFirebaseAuthModule,
2246
- AngularFirestoreModule,
2247
- AngularHasuraGraphQLModule] });
2248
- AngularConnectModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: AngularConnectModule, providers: [
2249
- AuthService,
2250
- CartService,
2251
- CatalogService,
2252
- CategoryService,
2253
- CheckoutService,
2254
- CheckoutSubscriptionService,
2255
- CouponService,
2256
- HomeShopService,
2257
- OrderService,
2258
- ShippingService,
2259
- WishlistService,
2260
- {
2261
- provide: UpdateUserImage,
2262
- useFactory: (userRepository, fileUploader) => {
2263
- return new UpdateUserImage(userRepository, fileUploader);
2264
- },
2265
- deps: ['UserRepository', 'FileUploaderService'],
2266
- },
2267
- ], imports: [provideFirebaseApp((injector) => {
2268
- const appName = injector.get(FIREBASE_APP_NAME) || '[DEFAULT]';
2269
- try {
2270
- return getApp(appName);
2271
- }
2272
- catch (error) {
2273
- return initializeApp(injector.get(FIREBASE_OPTIONS), appName);
2274
- }
2275
- }),
2276
- AngularElasticSeachModule,
2277
- AngularFirebaseAuthModule,
2278
- AngularFirestoreModule,
2279
- AngularHasuraGraphQLModule] });
2280
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: AngularConnectModule, decorators: [{
2281
- type: NgModule,
2282
- args: [{
2283
- imports: [
2284
- provideFirebaseApp((injector) => {
2285
- const appName = injector.get(FIREBASE_APP_NAME) || '[DEFAULT]';
2286
- try {
2287
- return getApp(appName);
2288
- }
2289
- catch (error) {
2290
- return initializeApp(injector.get(FIREBASE_OPTIONS), appName);
2291
- }
2292
- }),
2293
- AngularElasticSeachModule,
2294
- AngularFirebaseAuthModule,
2295
- AngularFirestoreModule,
2296
- AngularHasuraGraphQLModule,
2297
- ],
2298
- providers: [
2299
- AuthService,
2300
- CartService,
2301
- CatalogService,
2302
- CategoryService,
2303
- CheckoutService,
2304
- CheckoutSubscriptionService,
2305
- CouponService,
2306
- HomeShopService,
2307
- OrderService,
2308
- ShippingService,
2309
- WishlistService,
2310
- {
2311
- provide: UpdateUserImage,
2312
- useFactory: (userRepository, fileUploader) => {
2313
- return new UpdateUserImage(userRepository, fileUploader);
2314
- },
2315
- deps: ['UserRepository', 'FileUploaderService'],
2316
- },
2317
- ],
2318
- }]
2218
+ class AngularConnectModule {
2219
+ static initializeApp(defaultShop, options, nameOrConfig) {
2220
+ return {
2221
+ ngModule: AngularConnectModule,
2222
+ providers: [
2223
+ {
2224
+ provide: CATEGORY_STRUCTURE,
2225
+ useClass: isNil(options?.oldCategoryStructure) || options?.oldCategoryStructure
2226
+ ? OldCategoryStructureAdapter
2227
+ : NewCategoryStructureAdapter,
2228
+ },
2229
+ ...(isNil(defaultShop) ? [] : [{ provide: DEFAULT_SHOP, useValue: defaultShop }]),
2230
+ ...(isNil(options?.firebase) ? [] : [{ provide: FIREBASE_OPTIONS, useValue: options?.firebase }]),
2231
+ ...(isNil(options?.firebase) ? [] : [{ provide: FIREBASE_APP_NAME, useValue: nameOrConfig }]),
2232
+ ...(isNil(options?.elasticSearch) ? [] : [{ provide: ES_CONFIG, useValue: options.elasticSearch }]),
2233
+ ...(isNil(options?.hasura) ? [] : [{ provide: HASURA_OPTIONS, useValue: options.hasura }]),
2234
+ ...(isNil(options?.backendUrl) ? [] : [{ provide: BACKEND_URL, useValue: options.backendUrl }]),
2235
+ ...(isNil(options?.storageBaseUrl) ? [] : [{ provide: STORAGE_BASE_URL, useValue: options.storageBaseUrl }]),
2236
+ ],
2237
+ };
2238
+ }
2239
+ }
2240
+ AngularConnectModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: AngularConnectModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
2241
+ AngularConnectModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.1.0", ngImport: i0, type: AngularConnectModule, imports: [i1$4.FirebaseAppModule, AngularElasticSeachModule,
2242
+ AngularFirebaseAuthModule,
2243
+ AngularFirestoreModule,
2244
+ AngularHasuraGraphQLModule] });
2245
+ AngularConnectModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: AngularConnectModule, providers: [
2246
+ AuthService,
2247
+ CartService,
2248
+ CatalogService,
2249
+ CategoryService,
2250
+ CheckoutService,
2251
+ CheckoutSubscriptionService,
2252
+ CouponService,
2253
+ HomeShopService,
2254
+ OrderService,
2255
+ ShippingService,
2256
+ WishlistService,
2257
+ {
2258
+ provide: UpdateUserImage,
2259
+ useFactory: (userRepository, fileUploader) => {
2260
+ return new UpdateUserImage(userRepository, fileUploader);
2261
+ },
2262
+ deps: ['UserRepository', 'FileUploaderService'],
2263
+ },
2264
+ ], imports: [provideFirebaseApp((injector) => {
2265
+ const appName = injector.get(FIREBASE_APP_NAME) || '[DEFAULT]';
2266
+ try {
2267
+ return getApp(appName);
2268
+ }
2269
+ catch (error) {
2270
+ return initializeApp(injector.get(FIREBASE_OPTIONS), appName);
2271
+ }
2272
+ }),
2273
+ AngularElasticSeachModule,
2274
+ AngularFirebaseAuthModule,
2275
+ AngularFirestoreModule,
2276
+ AngularHasuraGraphQLModule] });
2277
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: AngularConnectModule, decorators: [{
2278
+ type: NgModule,
2279
+ args: [{
2280
+ imports: [
2281
+ provideFirebaseApp((injector) => {
2282
+ const appName = injector.get(FIREBASE_APP_NAME) || '[DEFAULT]';
2283
+ try {
2284
+ return getApp(appName);
2285
+ }
2286
+ catch (error) {
2287
+ return initializeApp(injector.get(FIREBASE_OPTIONS), appName);
2288
+ }
2289
+ }),
2290
+ AngularElasticSeachModule,
2291
+ AngularFirebaseAuthModule,
2292
+ AngularFirestoreModule,
2293
+ AngularHasuraGraphQLModule,
2294
+ ],
2295
+ providers: [
2296
+ AuthService,
2297
+ CartService,
2298
+ CatalogService,
2299
+ CategoryService,
2300
+ CheckoutService,
2301
+ CheckoutSubscriptionService,
2302
+ CouponService,
2303
+ HomeShopService,
2304
+ OrderService,
2305
+ ShippingService,
2306
+ WishlistService,
2307
+ {
2308
+ provide: UpdateUserImage,
2309
+ useFactory: (userRepository, fileUploader) => {
2310
+ return new UpdateUserImage(userRepository, fileUploader);
2311
+ },
2312
+ deps: ['UserRepository', 'FileUploaderService'],
2313
+ },
2314
+ ],
2315
+ }]
2319
2316
  }] });
2320
2317
 
2321
- /**
2322
- * Generated bundle index. Do not edit.
2318
+ /**
2319
+ * Generated bundle index. Do not edit.
2323
2320
  */
2324
2321
 
2325
2322
  export { AngularConnectModule, AngularFirebaseAuthModule, AngularFirestoreModule, AngularHasuraGraphQLModule, AuthService, CartService, CatalogService, CategoryService, CategoryWithTree, CheckoutService, CheckoutSubscriptionService, CouponService, HomeShopService, NewCategoryStructureAdapter, OldCategoryStructureAdapter, OrderService, ProductSorts, ShippingService, UtilHelper, WishlistService };