@infrab4a/connect-angular 4.0.0-beta.28 → 4.0.0-beta.3
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.
- package/angular-connect.module.d.ts +0 -1
- package/angular-firestore.module.d.ts +1 -2
- package/consts/index.d.ts +0 -1
- package/esm2020/angular-connect.module.mjs +3 -6
- package/esm2020/angular-elastic-search.module.mjs +7 -3
- package/esm2020/angular-firestore.module.mjs +137 -226
- package/esm2020/angular-hasura-graphql.module.mjs +24 -105
- package/esm2020/consts/index.mjs +1 -2
- package/esm2020/index.mjs +3 -4
- package/esm2020/services/auth.service.mjs +3 -3
- package/esm2020/services/cart.service.mjs +23 -161
- package/esm2020/services/checkout-subscription.service.mjs +3 -5
- package/esm2020/services/checkout.service.mjs +2 -2
- package/esm2020/services/coupon.service.mjs +37 -21
- package/esm2020/services/index.mjs +3 -4
- package/fesm2015/infrab4a-connect-angular.mjs +884 -1307
- package/fesm2015/infrab4a-connect-angular.mjs.map +1 -1
- package/fesm2020/infrab4a-connect-angular.mjs +880 -1315
- package/fesm2020/infrab4a-connect-angular.mjs.map +1 -1
- package/index.d.ts +2 -3
- package/package.json +3 -2
- package/services/cart.service.d.ts +2 -9
- package/services/coupon.service.d.ts +3 -2
- package/services/index.d.ts +2 -3
- package/catalog/catalog.service.d.ts +0 -16
- package/catalog/category.service.d.ts +0 -6
- package/catalog/enums/index.d.ts +0 -1
- package/catalog/enums/product-sorts.enum.d.ts +0 -8
- package/catalog/index.d.ts +0 -5
- package/catalog/models/category-with-tree.model.d.ts +0 -4
- package/catalog/models/index.d.ts +0 -1
- package/catalog/types/index.d.ts +0 -1
- package/catalog/types/product-sort.type.d.ts +0 -2
- package/consts/backend-url.const.d.ts +0 -1
- package/esm2020/catalog/catalog.service.mjs +0 -26
- package/esm2020/catalog/category.service.mjs +0 -9
- package/esm2020/catalog/enums/index.mjs +0 -2
- package/esm2020/catalog/enums/product-sorts.enum.mjs +0 -10
- package/esm2020/catalog/index.mjs +0 -6
- package/esm2020/catalog/models/category-with-tree.model.mjs +0 -10
- package/esm2020/catalog/models/index.mjs +0 -2
- package/esm2020/catalog/types/index.mjs +0 -2
- package/esm2020/catalog/types/product-sort.type.mjs +0 -2
- package/esm2020/consts/backend-url.const.mjs +0 -2
- package/esm2020/services/shipping.service.mjs +0 -96
- package/esm2020/services/types/shipping-methods.type.mjs +0 -2
- package/services/shipping.service.d.ts +0 -19
- package/services/types/shipping-methods.type.d.ts +0 -12
|
@@ -1,25 +1,48 @@
|
|
|
1
1
|
import * as i0 from '@angular/core';
|
|
2
|
-
import {
|
|
3
|
-
import * as
|
|
4
|
-
import {
|
|
5
|
-
import
|
|
6
|
-
import { provideFirebaseApp, initializeApp } from '@angular/fire/app';
|
|
7
|
-
import * as i1$1 from '@angular/fire/auth';
|
|
8
|
-
import { Auth, provideAuth, getAuth, getIdToken, authState } from '@angular/fire/auth';
|
|
9
|
-
import { isPlatformBrowser } from '@angular/common';
|
|
10
|
-
import * as i1$2 from '@angular/fire/firestore';
|
|
11
|
-
import { Firestore, provideFirestore, docSnapshots, doc } from '@angular/fire/firestore';
|
|
12
|
-
import { initializeApp as initializeApp$1 } from 'firebase/app';
|
|
13
|
-
import { getFirestore } from 'firebase/firestore';
|
|
14
|
-
import { combineLatest, from, of, throwError, Subject, iif, forkJoin } from 'rxjs';
|
|
2
|
+
import { Injectable, Inject, InjectionToken, NgModule, PLATFORM_ID } from '@angular/core';
|
|
3
|
+
import * as i1 from '@angular/fire/auth';
|
|
4
|
+
import { getIdToken, authState, Auth, provideAuth, getAuth } from '@angular/fire/auth';
|
|
5
|
+
import { combineLatest, of, from, throwError, Subject, iif, forkJoin } from 'rxjs';
|
|
15
6
|
import { map, mergeMap, catchError, concatMap, tap } from 'rxjs/operators';
|
|
7
|
+
import * as i2 from '@infrab4a/connect';
|
|
8
|
+
import { Where, Shops, CheckoutTypes, CouponTypes, Exclusivities, Status, isNil, NotFoundError, Checkout, pick, LineItem, CheckoutSubscription, Order, Category, Product, RequiredArgumentError, add, Authentication, AuthenticationFirebaseAuthService, Register, RegisterFirebaseAuthService, SignOut, RecoveryPassword, ProductsIndex, AxiosAdapter, UserBeautyProfileFirestoreRepository, Buy2WinFirestoreRepository, CategoryFirestoreRepository, CheckoutFirestoreRepository, CheckoutSubscriptionFirestoreRepository, CouponFirestoreRepository, SubscriptionEditionFirestoreRepository, HomeFirestoreRepository, LeadFirestoreRepository, LegacyOrderFirestoreRepository, ShopMenuFirestoreRepository, OrderFirestoreRepository, PaymentFirestoreRepository, ProductFirestoreRepository, SubscriptionPaymentFirestoreRepository, SubscriptionPlanFirestoreRepository, SubscriptionProductFirestoreRepository, SubscriptionFirestoreRepository, UserFirestoreRepository, UserAddressFirestoreRepository, UserPaymentMethodFirestoreRepository, ProductVariantFirestoreRepository, CategoryHasuraGraphQLRepository, ProductHasuraGraphQLRepository, VariantHasuraGraphQLRepository } from '@infrab4a/connect';
|
|
16
9
|
import cookie from 'js-cookie';
|
|
17
10
|
import { CustomError } from 'ts-custom-error';
|
|
18
|
-
import * as i1$
|
|
19
|
-
import {
|
|
20
|
-
import
|
|
11
|
+
import * as i1$1 from '@angular/fire/firestore';
|
|
12
|
+
import { docSnapshots, doc, Firestore, provideFirestore, getFirestore } from '@angular/fire/firestore';
|
|
13
|
+
import * as i1$2 from '@angular/fire/app';
|
|
14
|
+
import { provideFirebaseApp, initializeApp } from '@angular/fire/app';
|
|
21
15
|
|
|
22
|
-
|
|
16
|
+
class AuthService {
|
|
17
|
+
constructor(angularFireAuth, userRepository) {
|
|
18
|
+
this.angularFireAuth = angularFireAuth;
|
|
19
|
+
this.userRepository = userRepository;
|
|
20
|
+
}
|
|
21
|
+
getAuthstate() {
|
|
22
|
+
const observables = [this.getFireUser(), this.getUser()];
|
|
23
|
+
return combineLatest(observables).pipe(map(([fireUser, user]) => ({
|
|
24
|
+
user,
|
|
25
|
+
isAnonymous: fireUser?.isAnonymous,
|
|
26
|
+
})));
|
|
27
|
+
}
|
|
28
|
+
getUser() {
|
|
29
|
+
return this.getFireUser().pipe(map((user) => user?.uid), mergeMap((id) => (id ? this.userRepository.get({ id }) : of(null))), catchError(() => of(null)));
|
|
30
|
+
}
|
|
31
|
+
getTokenId() {
|
|
32
|
+
return from(getIdToken(this.angularFireAuth.currentUser));
|
|
33
|
+
}
|
|
34
|
+
getFireUser() {
|
|
35
|
+
return authState(this.angularFireAuth).pipe(catchError(() => of(null)));
|
|
36
|
+
}
|
|
37
|
+
}
|
|
38
|
+
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 });
|
|
39
|
+
AuthService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: AuthService });
|
|
40
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: AuthService, decorators: [{
|
|
41
|
+
type: Injectable
|
|
42
|
+
}], ctorParameters: function () { return [{ type: i1.Auth }, { type: undefined, decorators: [{
|
|
43
|
+
type: Inject,
|
|
44
|
+
args: ['UserRepository']
|
|
45
|
+
}] }]; } });
|
|
23
46
|
|
|
24
47
|
const DEFAULT_SHOP = 'DEFAULT_SHOP';
|
|
25
48
|
|
|
@@ -30,848 +53,33 @@ const FIREBASE_OPTIONS = new InjectionToken('firebaseOptions');
|
|
|
30
53
|
|
|
31
54
|
const HASURA_OPTIONS = 'HASURA_OPTIONS';
|
|
32
55
|
|
|
33
|
-
class
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
ngModule: AngularFirebaseAuthModule,
|
|
37
|
-
providers: [
|
|
38
|
-
{ provide: FIREBASE_OPTIONS, useValue: options },
|
|
39
|
-
{ provide: FIREBASE_APP_NAME, useValue: nameOrConfig },
|
|
40
|
-
],
|
|
41
|
-
};
|
|
56
|
+
class InvalidCouponError extends CustomError {
|
|
57
|
+
constructor(message) {
|
|
58
|
+
super(message);
|
|
42
59
|
}
|
|
43
60
|
}
|
|
44
|
-
AngularFirebaseAuthModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: AngularFirebaseAuthModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
45
|
-
AngularFirebaseAuthModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.1.0", ngImport: i0, type: AngularFirebaseAuthModule, imports: [i1.FirebaseAppModule, i1$1.AuthModule] });
|
|
46
|
-
AngularFirebaseAuthModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: AngularFirebaseAuthModule, providers: [
|
|
47
|
-
{
|
|
48
|
-
provide: 'Authentication',
|
|
49
|
-
useFactory: (authenticationService, userRepository) => {
|
|
50
|
-
return new Authentication(authenticationService, userRepository);
|
|
51
|
-
},
|
|
52
|
-
deps: ['AuthenticationService', 'UserRepository'],
|
|
53
|
-
},
|
|
54
|
-
{
|
|
55
|
-
provide: 'AuthenticationService',
|
|
56
|
-
useFactory: (angularFireAuth) => {
|
|
57
|
-
return new AuthenticationFirebaseAuthService(angularFireAuth);
|
|
58
|
-
},
|
|
59
|
-
deps: [Auth],
|
|
60
|
-
},
|
|
61
|
-
{
|
|
62
|
-
provide: 'Register',
|
|
63
|
-
useFactory: (registerService, userRepository) => {
|
|
64
|
-
return new Register(registerService, userRepository);
|
|
65
|
-
},
|
|
66
|
-
deps: ['RegisterService', 'UserRepository'],
|
|
67
|
-
},
|
|
68
|
-
{
|
|
69
|
-
provide: 'RegisterService',
|
|
70
|
-
useFactory: (angularFireAuth) => {
|
|
71
|
-
return new RegisterFirebaseAuthService(angularFireAuth);
|
|
72
|
-
},
|
|
73
|
-
deps: [Auth],
|
|
74
|
-
},
|
|
75
|
-
{
|
|
76
|
-
provide: 'SignOut',
|
|
77
|
-
useFactory: (authenticationService) => {
|
|
78
|
-
return new SignOut(authenticationService);
|
|
79
|
-
},
|
|
80
|
-
deps: ['AuthenticationService'],
|
|
81
|
-
},
|
|
82
|
-
{
|
|
83
|
-
provide: 'RecoveryPassword',
|
|
84
|
-
useFactory: (authenticationService) => {
|
|
85
|
-
return new RecoveryPassword(authenticationService);
|
|
86
|
-
},
|
|
87
|
-
deps: ['AuthenticationService'],
|
|
88
|
-
},
|
|
89
|
-
], imports: [provideFirebaseApp((injector) => {
|
|
90
|
-
const appName = injector.get(FIREBASE_APP_NAME);
|
|
91
|
-
return appName
|
|
92
|
-
? initializeApp(injector.get(FIREBASE_OPTIONS), appName)
|
|
93
|
-
: initializeApp(injector.get(FIREBASE_OPTIONS));
|
|
94
|
-
}),
|
|
95
|
-
provideAuth(() => getAuth())] });
|
|
96
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: AngularFirebaseAuthModule, decorators: [{
|
|
97
|
-
type: NgModule,
|
|
98
|
-
args: [{
|
|
99
|
-
imports: [
|
|
100
|
-
provideFirebaseApp((injector) => {
|
|
101
|
-
const appName = injector.get(FIREBASE_APP_NAME);
|
|
102
|
-
return appName
|
|
103
|
-
? initializeApp(injector.get(FIREBASE_OPTIONS), appName)
|
|
104
|
-
: initializeApp(injector.get(FIREBASE_OPTIONS));
|
|
105
|
-
}),
|
|
106
|
-
provideAuth(() => getAuth()),
|
|
107
|
-
],
|
|
108
|
-
providers: [
|
|
109
|
-
{
|
|
110
|
-
provide: 'Authentication',
|
|
111
|
-
useFactory: (authenticationService, userRepository) => {
|
|
112
|
-
return new Authentication(authenticationService, userRepository);
|
|
113
|
-
},
|
|
114
|
-
deps: ['AuthenticationService', 'UserRepository'],
|
|
115
|
-
},
|
|
116
|
-
{
|
|
117
|
-
provide: 'AuthenticationService',
|
|
118
|
-
useFactory: (angularFireAuth) => {
|
|
119
|
-
return new AuthenticationFirebaseAuthService(angularFireAuth);
|
|
120
|
-
},
|
|
121
|
-
deps: [Auth],
|
|
122
|
-
},
|
|
123
|
-
{
|
|
124
|
-
provide: 'Register',
|
|
125
|
-
useFactory: (registerService, userRepository) => {
|
|
126
|
-
return new Register(registerService, userRepository);
|
|
127
|
-
},
|
|
128
|
-
deps: ['RegisterService', 'UserRepository'],
|
|
129
|
-
},
|
|
130
|
-
{
|
|
131
|
-
provide: 'RegisterService',
|
|
132
|
-
useFactory: (angularFireAuth) => {
|
|
133
|
-
return new RegisterFirebaseAuthService(angularFireAuth);
|
|
134
|
-
},
|
|
135
|
-
deps: [Auth],
|
|
136
|
-
},
|
|
137
|
-
{
|
|
138
|
-
provide: 'SignOut',
|
|
139
|
-
useFactory: (authenticationService) => {
|
|
140
|
-
return new SignOut(authenticationService);
|
|
141
|
-
},
|
|
142
|
-
deps: ['AuthenticationService'],
|
|
143
|
-
},
|
|
144
|
-
{
|
|
145
|
-
provide: 'RecoveryPassword',
|
|
146
|
-
useFactory: (authenticationService) => {
|
|
147
|
-
return new RecoveryPassword(authenticationService);
|
|
148
|
-
},
|
|
149
|
-
deps: ['AuthenticationService'],
|
|
150
|
-
},
|
|
151
|
-
],
|
|
152
|
-
}]
|
|
153
|
-
}] });
|
|
154
61
|
|
|
155
|
-
class
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
providers: [{ provide: ES_CONFIG, useValue: options }],
|
|
160
|
-
};
|
|
62
|
+
class GroupInvalidCouponError extends CustomError {
|
|
63
|
+
constructor(errors) {
|
|
64
|
+
super('Many coupon errors throw');
|
|
65
|
+
this.errors = errors;
|
|
161
66
|
}
|
|
162
67
|
}
|
|
163
|
-
AngularElasticSeachModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: AngularElasticSeachModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
164
|
-
AngularElasticSeachModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.1.0", ngImport: i0, type: AngularElasticSeachModule });
|
|
165
|
-
AngularElasticSeachModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: AngularElasticSeachModule, providers: [
|
|
166
|
-
{
|
|
167
|
-
provide: ProductsIndex,
|
|
168
|
-
useFactory: (configuration) => new ProductsIndex(new AxiosAdapter(configuration)),
|
|
169
|
-
deps: [ES_CONFIG],
|
|
170
|
-
},
|
|
171
|
-
] });
|
|
172
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: AngularElasticSeachModule, decorators: [{
|
|
173
|
-
type: NgModule,
|
|
174
|
-
args: [{
|
|
175
|
-
providers: [
|
|
176
|
-
{
|
|
177
|
-
provide: ProductsIndex,
|
|
178
|
-
useFactory: (configuration) => new ProductsIndex(new AxiosAdapter(configuration)),
|
|
179
|
-
deps: [ES_CONFIG],
|
|
180
|
-
},
|
|
181
|
-
],
|
|
182
|
-
}]
|
|
183
|
-
}] });
|
|
184
68
|
|
|
185
|
-
class
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
|
|
190
|
-
|
|
191
|
-
|
|
192
|
-
|
|
193
|
-
],
|
|
194
|
-
};
|
|
69
|
+
class CouponService {
|
|
70
|
+
constructor(couponRepository, defaultShop, orderRepository, subscriptionRepository, categoryRepository) {
|
|
71
|
+
this.couponRepository = couponRepository;
|
|
72
|
+
this.defaultShop = defaultShop;
|
|
73
|
+
this.orderRepository = orderRepository;
|
|
74
|
+
this.subscriptionRepository = subscriptionRepository;
|
|
75
|
+
this.categoryRepository = categoryRepository;
|
|
76
|
+
this.emailIsFromCollaborator = (userEmail) => !!userEmail?.match(/@b4a.com.br/g);
|
|
195
77
|
}
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
provide: 'FirestoreOptions',
|
|
202
|
-
useFactory: (firestore, platformId) => ({
|
|
203
|
-
firestore,
|
|
204
|
-
interceptors: {
|
|
205
|
-
request: (request) => {
|
|
206
|
-
if (isPlatformBrowser(platformId))
|
|
207
|
-
return request;
|
|
208
|
-
const interval = setInterval(() => { }, 100);
|
|
209
|
-
request.interval = interval;
|
|
210
|
-
return request;
|
|
211
|
-
},
|
|
212
|
-
response: (response, request) => {
|
|
213
|
-
if (isPlatformBrowser(platformId))
|
|
214
|
-
return response;
|
|
215
|
-
clearInterval(request.interval);
|
|
216
|
-
return response;
|
|
217
|
-
},
|
|
218
|
-
},
|
|
219
|
-
}),
|
|
220
|
-
deps: [Firestore, PLATFORM_ID],
|
|
221
|
-
},
|
|
222
|
-
{
|
|
223
|
-
provide: 'BeautyProfileRepository',
|
|
224
|
-
useFactory: (config, userRepository) => {
|
|
225
|
-
return new UserBeautyProfileFirestoreRepository(config, userRepository);
|
|
226
|
-
},
|
|
227
|
-
deps: ['FirestoreOptions', 'UserRepository'],
|
|
228
|
-
},
|
|
229
|
-
{
|
|
230
|
-
provide: 'Buy2WinRepository',
|
|
231
|
-
useFactory: (options) => {
|
|
232
|
-
return new Buy2WinFirestoreRepository(options);
|
|
233
|
-
},
|
|
234
|
-
deps: ['FirestoreOptions'],
|
|
235
|
-
},
|
|
236
|
-
{
|
|
237
|
-
provide: CategoryFirestoreRepository,
|
|
238
|
-
useFactory: (options) => {
|
|
239
|
-
return new CategoryFirestoreRepository(options);
|
|
240
|
-
},
|
|
241
|
-
deps: ['FirestoreOptions'],
|
|
242
|
-
},
|
|
243
|
-
{
|
|
244
|
-
provide: 'CheckoutRepository',
|
|
245
|
-
useFactory: (options) => {
|
|
246
|
-
return new CheckoutFirestoreRepository(options);
|
|
247
|
-
},
|
|
248
|
-
deps: ['FirestoreOptions'],
|
|
249
|
-
},
|
|
250
|
-
{
|
|
251
|
-
provide: 'CheckoutSubscriptionRepository',
|
|
252
|
-
useFactory: (options) => {
|
|
253
|
-
return new CheckoutSubscriptionFirestoreRepository(options);
|
|
254
|
-
},
|
|
255
|
-
deps: ['FirestoreOptions'],
|
|
256
|
-
},
|
|
257
|
-
{
|
|
258
|
-
provide: 'CouponRepository',
|
|
259
|
-
useFactory: (options) => {
|
|
260
|
-
return new CouponFirestoreRepository(options);
|
|
261
|
-
},
|
|
262
|
-
deps: ['FirestoreOptions'],
|
|
263
|
-
},
|
|
264
|
-
{
|
|
265
|
-
provide: 'CampaignHashtagRepository',
|
|
266
|
-
useFactory: (options) => {
|
|
267
|
-
return new CampaignHashtagFirestoreRepository(options);
|
|
268
|
-
},
|
|
269
|
-
deps: ['FirestoreOptions'],
|
|
270
|
-
},
|
|
271
|
-
{
|
|
272
|
-
provide: 'CampaignDashboardRepository',
|
|
273
|
-
useFactory: (options) => {
|
|
274
|
-
return new CampaignDashboardFirestoreRepository(options);
|
|
275
|
-
},
|
|
276
|
-
deps: ['FirestoreOptions'],
|
|
277
|
-
},
|
|
278
|
-
{
|
|
279
|
-
provide: 'EditionRepository',
|
|
280
|
-
useFactory: (options, subscriptionRepository) => {
|
|
281
|
-
return new SubscriptionEditionFirestoreRepository(options, subscriptionRepository);
|
|
282
|
-
},
|
|
283
|
-
deps: ['FirestoreOptions', 'SubscriptionRepository'],
|
|
284
|
-
},
|
|
285
|
-
{
|
|
286
|
-
provide: 'HomeRepository',
|
|
287
|
-
useFactory: (options) => {
|
|
288
|
-
return new HomeFirestoreRepository(options);
|
|
289
|
-
},
|
|
290
|
-
deps: ['FirestoreOptions'],
|
|
291
|
-
},
|
|
292
|
-
{
|
|
293
|
-
provide: 'LeadRepository',
|
|
294
|
-
useFactory: (options) => {
|
|
295
|
-
return new LeadFirestoreRepository(options);
|
|
296
|
-
},
|
|
297
|
-
deps: ['FirestoreOptions'],
|
|
298
|
-
},
|
|
299
|
-
{
|
|
300
|
-
provide: 'LegacyOrderRepository',
|
|
301
|
-
useFactory: (options) => {
|
|
302
|
-
return new LegacyOrderFirestoreRepository(options);
|
|
303
|
-
},
|
|
304
|
-
deps: ['FirestoreOptions'],
|
|
305
|
-
},
|
|
306
|
-
{
|
|
307
|
-
provide: 'ShopMenuRepository',
|
|
308
|
-
useFactory: (options) => {
|
|
309
|
-
return new ShopMenuFirestoreRepository(options);
|
|
310
|
-
},
|
|
311
|
-
deps: ['FirestoreOptions'],
|
|
312
|
-
},
|
|
313
|
-
{
|
|
314
|
-
provide: 'OrderRepository',
|
|
315
|
-
useFactory: (options) => {
|
|
316
|
-
return new OrderFirestoreRepository(options);
|
|
317
|
-
},
|
|
318
|
-
deps: ['FirestoreOptions'],
|
|
319
|
-
},
|
|
320
|
-
{
|
|
321
|
-
provide: 'PaymentRepository',
|
|
322
|
-
useFactory: (options) => {
|
|
323
|
-
return new PaymentFirestoreRepository(options);
|
|
324
|
-
},
|
|
325
|
-
deps: ['FirestoreOptions'],
|
|
326
|
-
},
|
|
327
|
-
{
|
|
328
|
-
provide: ProductFirestoreRepository,
|
|
329
|
-
useFactory: (options) => {
|
|
330
|
-
return new ProductFirestoreRepository(options);
|
|
331
|
-
},
|
|
332
|
-
deps: ['FirestoreOptions'],
|
|
333
|
-
},
|
|
334
|
-
{
|
|
335
|
-
provide: 'ShopSettingsRepository',
|
|
336
|
-
useFactory: (options) => {
|
|
337
|
-
return new ShopSettingsFirestoreRepository(options);
|
|
338
|
-
},
|
|
339
|
-
deps: ['FirestoreOptions'],
|
|
340
|
-
},
|
|
341
|
-
{
|
|
342
|
-
provide: 'SubscriptionPaymentRepository',
|
|
343
|
-
useFactory: (options, subscriptionRepository) => {
|
|
344
|
-
return new SubscriptionPaymentFirestoreRepository(options, subscriptionRepository);
|
|
345
|
-
},
|
|
346
|
-
deps: ['FirestoreOptions', 'SubscriptionRepository'],
|
|
347
|
-
},
|
|
348
|
-
{
|
|
349
|
-
provide: 'SubscriptionPlanRepository',
|
|
350
|
-
useFactory: (options) => {
|
|
351
|
-
return new SubscriptionPlanFirestoreRepository(options);
|
|
352
|
-
},
|
|
353
|
-
deps: ['FirestoreOptions'],
|
|
354
|
-
},
|
|
355
|
-
{
|
|
356
|
-
provide: 'SubscriptionProductRepository',
|
|
357
|
-
useFactory: (options) => {
|
|
358
|
-
return new SubscriptionProductFirestoreRepository(options);
|
|
359
|
-
},
|
|
360
|
-
deps: ['FirestoreOptions'],
|
|
361
|
-
},
|
|
362
|
-
{
|
|
363
|
-
provide: 'SubscriptionRepository',
|
|
364
|
-
useFactory: (options) => {
|
|
365
|
-
return new SubscriptionFirestoreRepository(options);
|
|
366
|
-
},
|
|
367
|
-
deps: ['FirestoreOptions'],
|
|
368
|
-
},
|
|
369
|
-
{
|
|
370
|
-
provide: 'UserRepository',
|
|
371
|
-
useFactory: (options) => {
|
|
372
|
-
return new UserFirestoreRepository(options);
|
|
373
|
-
},
|
|
374
|
-
deps: ['FirestoreOptions'],
|
|
375
|
-
},
|
|
376
|
-
{
|
|
377
|
-
provide: 'UserAddressRepository',
|
|
378
|
-
useFactory: (options, userRepository) => {
|
|
379
|
-
return new UserAddressFirestoreRepository(options, userRepository);
|
|
380
|
-
},
|
|
381
|
-
deps: ['FirestoreOptions', 'UserRepository'],
|
|
382
|
-
},
|
|
383
|
-
{
|
|
384
|
-
provide: 'UserPaymentMethodRepository',
|
|
385
|
-
useFactory: (options, userRepository) => {
|
|
386
|
-
return new UserPaymentMethodFirestoreRepository(options, userRepository);
|
|
387
|
-
},
|
|
388
|
-
deps: ['FirestoreOptions', 'UserRepository'],
|
|
389
|
-
},
|
|
390
|
-
{
|
|
391
|
-
provide: ProductVariantFirestoreRepository,
|
|
392
|
-
useFactory: (options, productRepository) => {
|
|
393
|
-
return new ProductVariantFirestoreRepository(options, productRepository);
|
|
394
|
-
},
|
|
395
|
-
deps: ['FirestoreOptions', ProductFirestoreRepository],
|
|
396
|
-
},
|
|
397
|
-
], imports: [AngularElasticSeachModule,
|
|
398
|
-
provideFirebaseApp((injector) => {
|
|
399
|
-
const appName = injector.get(FIREBASE_APP_NAME);
|
|
400
|
-
return appName
|
|
401
|
-
? initializeApp$1(injector.get(FIREBASE_OPTIONS), appName)
|
|
402
|
-
: initializeApp$1(injector.get(FIREBASE_OPTIONS));
|
|
403
|
-
}),
|
|
404
|
-
provideFirestore(() => getFirestore())] });
|
|
405
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: AngularFirestoreModule, decorators: [{
|
|
406
|
-
type: NgModule,
|
|
407
|
-
args: [{
|
|
408
|
-
imports: [
|
|
409
|
-
AngularElasticSeachModule,
|
|
410
|
-
provideFirebaseApp((injector) => {
|
|
411
|
-
const appName = injector.get(FIREBASE_APP_NAME);
|
|
412
|
-
return appName
|
|
413
|
-
? initializeApp$1(injector.get(FIREBASE_OPTIONS), appName)
|
|
414
|
-
: initializeApp$1(injector.get(FIREBASE_OPTIONS));
|
|
415
|
-
}),
|
|
416
|
-
provideFirestore(() => getFirestore()),
|
|
417
|
-
],
|
|
418
|
-
providers: [
|
|
419
|
-
{
|
|
420
|
-
provide: 'FirestoreOptions',
|
|
421
|
-
useFactory: (firestore, platformId) => ({
|
|
422
|
-
firestore,
|
|
423
|
-
interceptors: {
|
|
424
|
-
request: (request) => {
|
|
425
|
-
if (isPlatformBrowser(platformId))
|
|
426
|
-
return request;
|
|
427
|
-
const interval = setInterval(() => { }, 100);
|
|
428
|
-
request.interval = interval;
|
|
429
|
-
return request;
|
|
430
|
-
},
|
|
431
|
-
response: (response, request) => {
|
|
432
|
-
if (isPlatformBrowser(platformId))
|
|
433
|
-
return response;
|
|
434
|
-
clearInterval(request.interval);
|
|
435
|
-
return response;
|
|
436
|
-
},
|
|
437
|
-
},
|
|
438
|
-
}),
|
|
439
|
-
deps: [Firestore, PLATFORM_ID],
|
|
440
|
-
},
|
|
441
|
-
{
|
|
442
|
-
provide: 'BeautyProfileRepository',
|
|
443
|
-
useFactory: (config, userRepository) => {
|
|
444
|
-
return new UserBeautyProfileFirestoreRepository(config, userRepository);
|
|
445
|
-
},
|
|
446
|
-
deps: ['FirestoreOptions', 'UserRepository'],
|
|
447
|
-
},
|
|
448
|
-
{
|
|
449
|
-
provide: 'Buy2WinRepository',
|
|
450
|
-
useFactory: (options) => {
|
|
451
|
-
return new Buy2WinFirestoreRepository(options);
|
|
452
|
-
},
|
|
453
|
-
deps: ['FirestoreOptions'],
|
|
454
|
-
},
|
|
455
|
-
{
|
|
456
|
-
provide: CategoryFirestoreRepository,
|
|
457
|
-
useFactory: (options) => {
|
|
458
|
-
return new CategoryFirestoreRepository(options);
|
|
459
|
-
},
|
|
460
|
-
deps: ['FirestoreOptions'],
|
|
461
|
-
},
|
|
462
|
-
{
|
|
463
|
-
provide: 'CheckoutRepository',
|
|
464
|
-
useFactory: (options) => {
|
|
465
|
-
return new CheckoutFirestoreRepository(options);
|
|
466
|
-
},
|
|
467
|
-
deps: ['FirestoreOptions'],
|
|
468
|
-
},
|
|
469
|
-
{
|
|
470
|
-
provide: 'CheckoutSubscriptionRepository',
|
|
471
|
-
useFactory: (options) => {
|
|
472
|
-
return new CheckoutSubscriptionFirestoreRepository(options);
|
|
473
|
-
},
|
|
474
|
-
deps: ['FirestoreOptions'],
|
|
475
|
-
},
|
|
476
|
-
{
|
|
477
|
-
provide: 'CouponRepository',
|
|
478
|
-
useFactory: (options) => {
|
|
479
|
-
return new CouponFirestoreRepository(options);
|
|
480
|
-
},
|
|
481
|
-
deps: ['FirestoreOptions'],
|
|
482
|
-
},
|
|
483
|
-
{
|
|
484
|
-
provide: 'CampaignHashtagRepository',
|
|
485
|
-
useFactory: (options) => {
|
|
486
|
-
return new CampaignHashtagFirestoreRepository(options);
|
|
487
|
-
},
|
|
488
|
-
deps: ['FirestoreOptions'],
|
|
489
|
-
},
|
|
490
|
-
{
|
|
491
|
-
provide: 'CampaignDashboardRepository',
|
|
492
|
-
useFactory: (options) => {
|
|
493
|
-
return new CampaignDashboardFirestoreRepository(options);
|
|
494
|
-
},
|
|
495
|
-
deps: ['FirestoreOptions'],
|
|
496
|
-
},
|
|
497
|
-
{
|
|
498
|
-
provide: 'EditionRepository',
|
|
499
|
-
useFactory: (options, subscriptionRepository) => {
|
|
500
|
-
return new SubscriptionEditionFirestoreRepository(options, subscriptionRepository);
|
|
501
|
-
},
|
|
502
|
-
deps: ['FirestoreOptions', 'SubscriptionRepository'],
|
|
503
|
-
},
|
|
504
|
-
{
|
|
505
|
-
provide: 'HomeRepository',
|
|
506
|
-
useFactory: (options) => {
|
|
507
|
-
return new HomeFirestoreRepository(options);
|
|
508
|
-
},
|
|
509
|
-
deps: ['FirestoreOptions'],
|
|
510
|
-
},
|
|
511
|
-
{
|
|
512
|
-
provide: 'LeadRepository',
|
|
513
|
-
useFactory: (options) => {
|
|
514
|
-
return new LeadFirestoreRepository(options);
|
|
515
|
-
},
|
|
516
|
-
deps: ['FirestoreOptions'],
|
|
517
|
-
},
|
|
518
|
-
{
|
|
519
|
-
provide: 'LegacyOrderRepository',
|
|
520
|
-
useFactory: (options) => {
|
|
521
|
-
return new LegacyOrderFirestoreRepository(options);
|
|
522
|
-
},
|
|
523
|
-
deps: ['FirestoreOptions'],
|
|
524
|
-
},
|
|
525
|
-
{
|
|
526
|
-
provide: 'ShopMenuRepository',
|
|
527
|
-
useFactory: (options) => {
|
|
528
|
-
return new ShopMenuFirestoreRepository(options);
|
|
529
|
-
},
|
|
530
|
-
deps: ['FirestoreOptions'],
|
|
531
|
-
},
|
|
532
|
-
{
|
|
533
|
-
provide: 'OrderRepository',
|
|
534
|
-
useFactory: (options) => {
|
|
535
|
-
return new OrderFirestoreRepository(options);
|
|
536
|
-
},
|
|
537
|
-
deps: ['FirestoreOptions'],
|
|
538
|
-
},
|
|
539
|
-
{
|
|
540
|
-
provide: 'PaymentRepository',
|
|
541
|
-
useFactory: (options) => {
|
|
542
|
-
return new PaymentFirestoreRepository(options);
|
|
543
|
-
},
|
|
544
|
-
deps: ['FirestoreOptions'],
|
|
545
|
-
},
|
|
546
|
-
{
|
|
547
|
-
provide: ProductFirestoreRepository,
|
|
548
|
-
useFactory: (options) => {
|
|
549
|
-
return new ProductFirestoreRepository(options);
|
|
550
|
-
},
|
|
551
|
-
deps: ['FirestoreOptions'],
|
|
552
|
-
},
|
|
553
|
-
{
|
|
554
|
-
provide: 'ShopSettingsRepository',
|
|
555
|
-
useFactory: (options) => {
|
|
556
|
-
return new ShopSettingsFirestoreRepository(options);
|
|
557
|
-
},
|
|
558
|
-
deps: ['FirestoreOptions'],
|
|
559
|
-
},
|
|
560
|
-
{
|
|
561
|
-
provide: 'SubscriptionPaymentRepository',
|
|
562
|
-
useFactory: (options, subscriptionRepository) => {
|
|
563
|
-
return new SubscriptionPaymentFirestoreRepository(options, subscriptionRepository);
|
|
564
|
-
},
|
|
565
|
-
deps: ['FirestoreOptions', 'SubscriptionRepository'],
|
|
566
|
-
},
|
|
567
|
-
{
|
|
568
|
-
provide: 'SubscriptionPlanRepository',
|
|
569
|
-
useFactory: (options) => {
|
|
570
|
-
return new SubscriptionPlanFirestoreRepository(options);
|
|
571
|
-
},
|
|
572
|
-
deps: ['FirestoreOptions'],
|
|
573
|
-
},
|
|
574
|
-
{
|
|
575
|
-
provide: 'SubscriptionProductRepository',
|
|
576
|
-
useFactory: (options) => {
|
|
577
|
-
return new SubscriptionProductFirestoreRepository(options);
|
|
578
|
-
},
|
|
579
|
-
deps: ['FirestoreOptions'],
|
|
580
|
-
},
|
|
581
|
-
{
|
|
582
|
-
provide: 'SubscriptionRepository',
|
|
583
|
-
useFactory: (options) => {
|
|
584
|
-
return new SubscriptionFirestoreRepository(options);
|
|
585
|
-
},
|
|
586
|
-
deps: ['FirestoreOptions'],
|
|
587
|
-
},
|
|
588
|
-
{
|
|
589
|
-
provide: 'UserRepository',
|
|
590
|
-
useFactory: (options) => {
|
|
591
|
-
return new UserFirestoreRepository(options);
|
|
592
|
-
},
|
|
593
|
-
deps: ['FirestoreOptions'],
|
|
594
|
-
},
|
|
595
|
-
{
|
|
596
|
-
provide: 'UserAddressRepository',
|
|
597
|
-
useFactory: (options, userRepository) => {
|
|
598
|
-
return new UserAddressFirestoreRepository(options, userRepository);
|
|
599
|
-
},
|
|
600
|
-
deps: ['FirestoreOptions', 'UserRepository'],
|
|
601
|
-
},
|
|
602
|
-
{
|
|
603
|
-
provide: 'UserPaymentMethodRepository',
|
|
604
|
-
useFactory: (options, userRepository) => {
|
|
605
|
-
return new UserPaymentMethodFirestoreRepository(options, userRepository);
|
|
606
|
-
},
|
|
607
|
-
deps: ['FirestoreOptions', 'UserRepository'],
|
|
608
|
-
},
|
|
609
|
-
{
|
|
610
|
-
provide: ProductVariantFirestoreRepository,
|
|
611
|
-
useFactory: (options, productRepository) => {
|
|
612
|
-
return new ProductVariantFirestoreRepository(options, productRepository);
|
|
613
|
-
},
|
|
614
|
-
deps: ['FirestoreOptions', ProductFirestoreRepository],
|
|
615
|
-
},
|
|
616
|
-
],
|
|
617
|
-
}]
|
|
618
|
-
}] });
|
|
619
|
-
|
|
620
|
-
class AngularHasuraGraphQLModule {
|
|
621
|
-
static initializeApp(options) {
|
|
622
|
-
return {
|
|
623
|
-
ngModule: AngularHasuraGraphQLModule,
|
|
624
|
-
providers: [{ provide: HASURA_OPTIONS, useValue: options }],
|
|
625
|
-
};
|
|
626
|
-
}
|
|
627
|
-
}
|
|
628
|
-
AngularHasuraGraphQLModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: AngularHasuraGraphQLModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
629
|
-
AngularHasuraGraphQLModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.1.0", ngImport: i0, type: AngularHasuraGraphQLModule });
|
|
630
|
-
AngularHasuraGraphQLModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: AngularHasuraGraphQLModule, providers: [
|
|
631
|
-
{
|
|
632
|
-
provide: 'HasuraConfig',
|
|
633
|
-
useFactory: (options, platformId) => ({
|
|
634
|
-
endpoint: options.endpoint,
|
|
635
|
-
authOptions: options.credentials,
|
|
636
|
-
interceptors: {
|
|
637
|
-
request: (request) => {
|
|
638
|
-
if (isPlatformBrowser(platformId))
|
|
639
|
-
return request;
|
|
640
|
-
const interval = setInterval(() => { }, 100);
|
|
641
|
-
request.interval = interval;
|
|
642
|
-
return request;
|
|
643
|
-
},
|
|
644
|
-
response: (response, request) => {
|
|
645
|
-
if (isPlatformBrowser(platformId))
|
|
646
|
-
return response;
|
|
647
|
-
clearInterval(request.interval);
|
|
648
|
-
return response;
|
|
649
|
-
},
|
|
650
|
-
},
|
|
651
|
-
}),
|
|
652
|
-
deps: [HASURA_OPTIONS, PLATFORM_ID],
|
|
653
|
-
},
|
|
654
|
-
{
|
|
655
|
-
provide: 'CategoryRepository',
|
|
656
|
-
useExisting: CategoryHasuraGraphQLRepository,
|
|
657
|
-
},
|
|
658
|
-
{
|
|
659
|
-
provide: CategoryHasuraGraphQLRepository,
|
|
660
|
-
useFactory: (options, productRepository, categoryFilterRepository) => {
|
|
661
|
-
return new CategoryHasuraGraphQLRepository(options, productRepository, categoryFilterRepository);
|
|
662
|
-
},
|
|
663
|
-
deps: ['HasuraConfig', ProductHasuraGraphQLRepository, CategoryFilterHasuraGraphQLRepository],
|
|
664
|
-
},
|
|
665
|
-
{
|
|
666
|
-
provide: 'ProductRepository',
|
|
667
|
-
useExisting: ProductHasuraGraphQLRepository,
|
|
668
|
-
},
|
|
669
|
-
{
|
|
670
|
-
provide: ProductHasuraGraphQLRepository,
|
|
671
|
-
useFactory: (hasuraConfig) => {
|
|
672
|
-
return new ProductHasuraGraphQLRepository(hasuraConfig);
|
|
673
|
-
},
|
|
674
|
-
deps: ['HasuraConfig'],
|
|
675
|
-
},
|
|
676
|
-
{
|
|
677
|
-
provide: 'VariantRepository',
|
|
678
|
-
useExisting: VariantHasuraGraphQLRepository,
|
|
679
|
-
},
|
|
680
|
-
{
|
|
681
|
-
provide: VariantHasuraGraphQLRepository,
|
|
682
|
-
useFactory: (hasuraConfig) => {
|
|
683
|
-
return new VariantHasuraGraphQLRepository(hasuraConfig);
|
|
684
|
-
},
|
|
685
|
-
deps: ['HasuraConfig'],
|
|
686
|
-
},
|
|
687
|
-
{
|
|
688
|
-
provide: 'CategoryFilterRepository',
|
|
689
|
-
useExisting: CategoryFilterHasuraGraphQLRepository,
|
|
690
|
-
},
|
|
691
|
-
{
|
|
692
|
-
provide: CategoryFilterHasuraGraphQLRepository,
|
|
693
|
-
useFactory: (options) => {
|
|
694
|
-
return new CategoryFilterHasuraGraphQLRepository(options);
|
|
695
|
-
},
|
|
696
|
-
deps: ['HasuraConfig'],
|
|
697
|
-
},
|
|
698
|
-
{
|
|
699
|
-
provide: 'FilterOptionRepository',
|
|
700
|
-
useExisting: FilterOptionHasuraGraphQLRepository,
|
|
701
|
-
},
|
|
702
|
-
{
|
|
703
|
-
provide: FilterOptionHasuraGraphQLRepository,
|
|
704
|
-
useFactory: (options) => {
|
|
705
|
-
return new FilterOptionHasuraGraphQLRepository(options);
|
|
706
|
-
},
|
|
707
|
-
deps: ['HasuraConfig'],
|
|
708
|
-
},
|
|
709
|
-
{
|
|
710
|
-
provide: 'FilterRepository',
|
|
711
|
-
useExisting: FilterHasuraGraphQLRepository,
|
|
712
|
-
},
|
|
713
|
-
{
|
|
714
|
-
provide: FilterHasuraGraphQLRepository,
|
|
715
|
-
useFactory: (options, filterOptionRepository, categoryFilterRepository) => {
|
|
716
|
-
return new FilterHasuraGraphQLRepository(options, filterOptionRepository, categoryFilterRepository);
|
|
717
|
-
},
|
|
718
|
-
deps: ['HasuraConfig', FilterOptionHasuraGraphQLRepository, CategoryFilterHasuraGraphQLRepository],
|
|
719
|
-
},
|
|
720
|
-
] });
|
|
721
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: AngularHasuraGraphQLModule, decorators: [{
|
|
722
|
-
type: NgModule,
|
|
723
|
-
args: [{
|
|
724
|
-
providers: [
|
|
725
|
-
{
|
|
726
|
-
provide: 'HasuraConfig',
|
|
727
|
-
useFactory: (options, platformId) => ({
|
|
728
|
-
endpoint: options.endpoint,
|
|
729
|
-
authOptions: options.credentials,
|
|
730
|
-
interceptors: {
|
|
731
|
-
request: (request) => {
|
|
732
|
-
if (isPlatformBrowser(platformId))
|
|
733
|
-
return request;
|
|
734
|
-
const interval = setInterval(() => { }, 100);
|
|
735
|
-
request.interval = interval;
|
|
736
|
-
return request;
|
|
737
|
-
},
|
|
738
|
-
response: (response, request) => {
|
|
739
|
-
if (isPlatformBrowser(platformId))
|
|
740
|
-
return response;
|
|
741
|
-
clearInterval(request.interval);
|
|
742
|
-
return response;
|
|
743
|
-
},
|
|
744
|
-
},
|
|
745
|
-
}),
|
|
746
|
-
deps: [HASURA_OPTIONS, PLATFORM_ID],
|
|
747
|
-
},
|
|
748
|
-
{
|
|
749
|
-
provide: 'CategoryRepository',
|
|
750
|
-
useExisting: CategoryHasuraGraphQLRepository,
|
|
751
|
-
},
|
|
752
|
-
{
|
|
753
|
-
provide: CategoryHasuraGraphQLRepository,
|
|
754
|
-
useFactory: (options, productRepository, categoryFilterRepository) => {
|
|
755
|
-
return new CategoryHasuraGraphQLRepository(options, productRepository, categoryFilterRepository);
|
|
756
|
-
},
|
|
757
|
-
deps: ['HasuraConfig', ProductHasuraGraphQLRepository, CategoryFilterHasuraGraphQLRepository],
|
|
758
|
-
},
|
|
759
|
-
{
|
|
760
|
-
provide: 'ProductRepository',
|
|
761
|
-
useExisting: ProductHasuraGraphQLRepository,
|
|
762
|
-
},
|
|
763
|
-
{
|
|
764
|
-
provide: ProductHasuraGraphQLRepository,
|
|
765
|
-
useFactory: (hasuraConfig) => {
|
|
766
|
-
return new ProductHasuraGraphQLRepository(hasuraConfig);
|
|
767
|
-
},
|
|
768
|
-
deps: ['HasuraConfig'],
|
|
769
|
-
},
|
|
770
|
-
{
|
|
771
|
-
provide: 'VariantRepository',
|
|
772
|
-
useExisting: VariantHasuraGraphQLRepository,
|
|
773
|
-
},
|
|
774
|
-
{
|
|
775
|
-
provide: VariantHasuraGraphQLRepository,
|
|
776
|
-
useFactory: (hasuraConfig) => {
|
|
777
|
-
return new VariantHasuraGraphQLRepository(hasuraConfig);
|
|
778
|
-
},
|
|
779
|
-
deps: ['HasuraConfig'],
|
|
780
|
-
},
|
|
781
|
-
{
|
|
782
|
-
provide: 'CategoryFilterRepository',
|
|
783
|
-
useExisting: CategoryFilterHasuraGraphQLRepository,
|
|
784
|
-
},
|
|
785
|
-
{
|
|
786
|
-
provide: CategoryFilterHasuraGraphQLRepository,
|
|
787
|
-
useFactory: (options) => {
|
|
788
|
-
return new CategoryFilterHasuraGraphQLRepository(options);
|
|
789
|
-
},
|
|
790
|
-
deps: ['HasuraConfig'],
|
|
791
|
-
},
|
|
792
|
-
{
|
|
793
|
-
provide: 'FilterOptionRepository',
|
|
794
|
-
useExisting: FilterOptionHasuraGraphQLRepository,
|
|
795
|
-
},
|
|
796
|
-
{
|
|
797
|
-
provide: FilterOptionHasuraGraphQLRepository,
|
|
798
|
-
useFactory: (options) => {
|
|
799
|
-
return new FilterOptionHasuraGraphQLRepository(options);
|
|
800
|
-
},
|
|
801
|
-
deps: ['HasuraConfig'],
|
|
802
|
-
},
|
|
803
|
-
{
|
|
804
|
-
provide: 'FilterRepository',
|
|
805
|
-
useExisting: FilterHasuraGraphQLRepository,
|
|
806
|
-
},
|
|
807
|
-
{
|
|
808
|
-
provide: FilterHasuraGraphQLRepository,
|
|
809
|
-
useFactory: (options, filterOptionRepository, categoryFilterRepository) => {
|
|
810
|
-
return new FilterHasuraGraphQLRepository(options, filterOptionRepository, categoryFilterRepository);
|
|
811
|
-
},
|
|
812
|
-
deps: ['HasuraConfig', FilterOptionHasuraGraphQLRepository, CategoryFilterHasuraGraphQLRepository],
|
|
813
|
-
},
|
|
814
|
-
],
|
|
815
|
-
}]
|
|
816
|
-
}] });
|
|
817
|
-
|
|
818
|
-
class AuthService {
|
|
819
|
-
constructor(angularFireAuth, userRepository) {
|
|
820
|
-
this.angularFireAuth = angularFireAuth;
|
|
821
|
-
this.userRepository = userRepository;
|
|
822
|
-
}
|
|
823
|
-
getAuthstate() {
|
|
824
|
-
const observables = [this.getFireUser(), this.getUser()];
|
|
825
|
-
return combineLatest(observables).pipe(map(([fireUser, user]) => ({
|
|
826
|
-
user,
|
|
827
|
-
isAnonymous: fireUser?.isAnonymous,
|
|
828
|
-
})));
|
|
829
|
-
}
|
|
830
|
-
getUser() {
|
|
831
|
-
return this.getFireUser().pipe(map((user) => user?.uid), mergeMap((id) => (id ? from(this.userRepository.get({ id })).pipe(catchError(() => of(null))) : of(null))));
|
|
832
|
-
}
|
|
833
|
-
getTokenId() {
|
|
834
|
-
return from(getIdToken(this.angularFireAuth.currentUser));
|
|
835
|
-
}
|
|
836
|
-
getFireUser() {
|
|
837
|
-
return authState(this.angularFireAuth).pipe(catchError(() => of(null)));
|
|
838
|
-
}
|
|
839
|
-
}
|
|
840
|
-
AuthService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: AuthService, deps: [{ token: i1$1.Auth }, { token: 'UserRepository' }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
841
|
-
AuthService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: AuthService });
|
|
842
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: AuthService, decorators: [{
|
|
843
|
-
type: Injectable
|
|
844
|
-
}], ctorParameters: function () { return [{ type: i1$1.Auth }, { type: undefined, decorators: [{
|
|
845
|
-
type: Inject,
|
|
846
|
-
args: ['UserRepository']
|
|
847
|
-
}] }]; } });
|
|
848
|
-
|
|
849
|
-
class InvalidCouponError extends CustomError {
|
|
850
|
-
constructor(message) {
|
|
851
|
-
super(message);
|
|
852
|
-
}
|
|
853
|
-
}
|
|
854
|
-
|
|
855
|
-
class GroupInvalidCouponError extends CustomError {
|
|
856
|
-
constructor(errors) {
|
|
857
|
-
super('Many coupon errors throw');
|
|
858
|
-
this.errors = errors;
|
|
859
|
-
}
|
|
860
|
-
}
|
|
861
|
-
|
|
862
|
-
class CouponService {
|
|
863
|
-
constructor(couponRepository, defaultShop, orderRepository, categoryRepository) {
|
|
864
|
-
this.couponRepository = couponRepository;
|
|
865
|
-
this.defaultShop = defaultShop;
|
|
866
|
-
this.orderRepository = orderRepository;
|
|
867
|
-
this.categoryRepository = categoryRepository;
|
|
868
|
-
this.emailIsFromCollaborator = (userEmail) => !!userEmail?.match(/@b4a.com.br/g);
|
|
869
|
-
}
|
|
870
|
-
checkCoupon(nickname, userEmail, checkoutType, plan, checkout, isSubscription) {
|
|
871
|
-
return from(this.couponRepository.find({
|
|
872
|
-
filters: {
|
|
873
|
-
nickname: { operator: Where.EQUALS, value: nickname },
|
|
874
|
-
active: { operator: Where.EQUALS, value: true },
|
|
78
|
+
checkCoupon(nickname, userEmail, checkoutType, plan, checkout, isSubscription) {
|
|
79
|
+
return from(this.couponRepository.find({
|
|
80
|
+
filters: {
|
|
81
|
+
nickname: { operator: Where.EQUALS, value: nickname },
|
|
82
|
+
active: { operator: Where.EQUALS, value: true },
|
|
875
83
|
},
|
|
876
84
|
})).pipe(concatMap((coupons) => this.checkCouponRules(coupons, checkoutType, plan, checkout, isSubscription)), concatMap((coupon) => this.checkCouponUseAndLimit(coupon, userEmail, checkout)), map((coupon) => this.isValidCoupon(coupon, userEmail)), map((coupon) => coupon));
|
|
877
85
|
}
|
|
@@ -904,7 +112,7 @@ class CouponService {
|
|
|
904
112
|
const hasMinSubTotal = this.hasMinSubTotal(coupon, checkout);
|
|
905
113
|
// Se não tem valor mínimo atingido, retorna erro
|
|
906
114
|
if (!hasMinSubTotal)
|
|
907
|
-
return throwError(
|
|
115
|
+
return throwError('Valor mínimo não atingido');
|
|
908
116
|
return of(coupon);
|
|
909
117
|
}
|
|
910
118
|
isValidCoupon(coupon, userEmail) {
|
|
@@ -921,7 +129,6 @@ class CouponService {
|
|
|
921
129
|
filters: {
|
|
922
130
|
coupon: { id: coupon.id },
|
|
923
131
|
payment: { status: 'paid' },
|
|
924
|
-
...(coupon.influencerEmail ? { user: { email: userEmail } } : {}),
|
|
925
132
|
},
|
|
926
133
|
});
|
|
927
134
|
// orders que usuario ja fez com o cupom
|
|
@@ -932,7 +139,7 @@ class CouponService {
|
|
|
932
139
|
// Verifica o limite de uso geral por usuario
|
|
933
140
|
if (coupon.useLimit && orders.data.length >= coupon.useLimit)
|
|
934
141
|
throw new InvalidCouponError('Limite de uso atingido.');
|
|
935
|
-
const validUser = this.userValidationAndSubscriptionStatus(coupon,
|
|
142
|
+
const validUser = await this.userValidationAndSubscriptionStatus(coupon, userEmail);
|
|
936
143
|
if (!validUser)
|
|
937
144
|
throw new InvalidCouponError('Usuário não elegível.');
|
|
938
145
|
const hasProductCategories = await this.hasProductCategories(coupon, checkout);
|
|
@@ -1008,24 +215,37 @@ class CouponService {
|
|
|
1008
215
|
});
|
|
1009
216
|
return hasCategories.length ? true : false;
|
|
1010
217
|
}
|
|
1011
|
-
userValidationAndSubscriptionStatus(coupon,
|
|
1012
|
-
if (coupon.exclusivityType === Exclusivities.ALL_USERS)
|
|
1013
|
-
return true;
|
|
1014
|
-
if (!user)
|
|
1015
|
-
return true;
|
|
218
|
+
async userValidationAndSubscriptionStatus(coupon, userEmail) {
|
|
1016
219
|
// Verifica se o email do usuário é coorporativo
|
|
1017
|
-
if (!this.emailIsFromCollaborator(
|
|
220
|
+
if (!this.emailIsFromCollaborator(userEmail) && coupon.exclusivityType === Exclusivities.COLLABORATORS)
|
|
1018
221
|
throw new InvalidCouponError('Você não é colaborador.');
|
|
1019
222
|
// Verifica se o email do usuário é associado ao cupom de uso por usuario
|
|
1020
|
-
if (coupon.exclusivityType === Exclusivities.SPECIFIC_USER && coupon.userExclusiveEmail !==
|
|
223
|
+
if (coupon.exclusivityType === Exclusivities.SPECIFIC_USER && coupon.userExclusiveEmail !== userEmail)
|
|
1021
224
|
throw new InvalidCouponError('Cupom não é válido para este usuário.');
|
|
1022
|
-
|
|
1023
|
-
|
|
1024
|
-
|
|
1025
|
-
|
|
1026
|
-
|
|
1027
|
-
|
|
1028
|
-
|
|
225
|
+
const couponRuleSubscription = coupon.exclusivityType === Exclusivities.ACTIVE_SUBSCRIBER ||
|
|
226
|
+
coupon.exclusivityType === Exclusivities.INACTIVE_SUBSCRIBER ||
|
|
227
|
+
coupon.exclusivityType === Exclusivities.NON_SUBSCRIBER;
|
|
228
|
+
if (couponRuleSubscription && userEmail) {
|
|
229
|
+
const sub = await this.subscriptionRepository
|
|
230
|
+
.find({
|
|
231
|
+
filters: {
|
|
232
|
+
user: {
|
|
233
|
+
email: { operator: Where.EQUALS, value: userEmail },
|
|
234
|
+
},
|
|
235
|
+
},
|
|
236
|
+
})
|
|
237
|
+
.then((sub) => sub.data);
|
|
238
|
+
const activeSubs = sub?.filter((s) => s.status === Status.ACTIVE);
|
|
239
|
+
switch (coupon.exclusivityType) {
|
|
240
|
+
case Exclusivities.ACTIVE_SUBSCRIBER:
|
|
241
|
+
return activeSubs.length > 0;
|
|
242
|
+
case Exclusivities.INACTIVE_SUBSCRIBER:
|
|
243
|
+
return activeSubs.length === 0;
|
|
244
|
+
case Exclusivities.NON_SUBSCRIBER:
|
|
245
|
+
return sub.length === 0;
|
|
246
|
+
default:
|
|
247
|
+
return false;
|
|
248
|
+
}
|
|
1029
249
|
}
|
|
1030
250
|
return true;
|
|
1031
251
|
}
|
|
@@ -1040,7 +260,7 @@ class CouponService {
|
|
|
1040
260
|
return couponCategories;
|
|
1041
261
|
}
|
|
1042
262
|
}
|
|
1043
|
-
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 });
|
|
263
|
+
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: 'SubscriptionRepository' }, { token: 'CategoryRepository' }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
1044
264
|
CouponService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: CouponService, providedIn: 'root' });
|
|
1045
265
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: CouponService, decorators: [{
|
|
1046
266
|
type: Injectable,
|
|
@@ -1050,12 +270,15 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.0", ngImpor
|
|
|
1050
270
|
}], ctorParameters: function () { return [{ type: undefined, decorators: [{
|
|
1051
271
|
type: Inject,
|
|
1052
272
|
args: ['CouponRepository']
|
|
1053
|
-
}] }, { type:
|
|
273
|
+
}] }, { type: i2.Shops, decorators: [{
|
|
1054
274
|
type: Inject,
|
|
1055
275
|
args: [DEFAULT_SHOP]
|
|
1056
276
|
}] }, { type: undefined, decorators: [{
|
|
1057
277
|
type: Inject,
|
|
1058
278
|
args: ['OrderRepository']
|
|
279
|
+
}] }, { type: undefined, decorators: [{
|
|
280
|
+
type: Inject,
|
|
281
|
+
args: ['SubscriptionRepository']
|
|
1059
282
|
}] }, { type: undefined, decorators: [{
|
|
1060
283
|
type: Inject,
|
|
1061
284
|
args: ['CategoryRepository']
|
|
@@ -1119,24 +342,21 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.0", ngImpor
|
|
|
1119
342
|
}] }, { type: undefined, decorators: [{
|
|
1120
343
|
type: Inject,
|
|
1121
344
|
args: ['UserRepository']
|
|
1122
|
-
}] }, { type:
|
|
345
|
+
}] }, { type: i2.Shops, decorators: [{
|
|
1123
346
|
type: Inject,
|
|
1124
347
|
args: [DEFAULT_SHOP]
|
|
1125
348
|
}] }]; } });
|
|
1126
349
|
|
|
1127
350
|
class CartService {
|
|
1128
|
-
constructor(authService, checkoutService, defaultShop, productRepository
|
|
351
|
+
constructor(authService, checkoutService, defaultShop, productRepository) {
|
|
1129
352
|
this.authService = authService;
|
|
1130
353
|
this.checkoutService = checkoutService;
|
|
1131
354
|
this.defaultShop = defaultShop;
|
|
1132
355
|
this.productRepository = productRepository;
|
|
1133
|
-
this.categoryRepository = categoryRepository;
|
|
1134
|
-
this.variantRepository = variantRepository;
|
|
1135
|
-
this.buy2WinRepository = buy2WinRepository;
|
|
1136
356
|
this.cartSubject = new Subject();
|
|
1137
357
|
this.updateLineItemInCart = (lineItem, quantity, checkout) => (isNil(checkout) ? this.checkoutService.getCheckout() : of(checkout)).pipe(concatMap((checkoutLoaded) => {
|
|
1138
358
|
const items = [];
|
|
1139
|
-
const index = checkoutLoaded.lineItems?.map((checkoutItem) => checkoutItem.
|
|
359
|
+
const index = checkoutLoaded.lineItems?.map((checkoutItem) => checkoutItem.sku).indexOf(lineItem.sku);
|
|
1140
360
|
if (index > -1) {
|
|
1141
361
|
checkoutLoaded.lineItems[index].quantity += quantity;
|
|
1142
362
|
checkoutLoaded.lineItems[index].pricePaid = lineItem.pricePaid;
|
|
@@ -1147,27 +367,27 @@ class CartService {
|
|
|
1147
367
|
.updateCheckoutLineItems(checkoutLoaded)
|
|
1148
368
|
.pipe(map((updatedCheckout) => this.generateCartObject(updatedCheckout.lineItems)));
|
|
1149
369
|
}));
|
|
1150
|
-
this.generateCartObject = (items) =>
|
|
1151
|
-
|
|
1152
|
-
[item.
|
|
1153
|
-
...(cart[item.
|
|
1154
|
-
quantity: (cart[item.
|
|
1155
|
-
})
|
|
1156
|
-
|
|
370
|
+
this.generateCartObject = (items) => {
|
|
371
|
+
const cart = {};
|
|
372
|
+
items?.forEach((item) => (cart[item.sku] = LineItem.toInstance({
|
|
373
|
+
...(cart[item.sku] || item),
|
|
374
|
+
quantity: (cart[item.sku]?.quantity || 0) + (item.quantity ? item.quantity : 1),
|
|
375
|
+
})));
|
|
376
|
+
return cart;
|
|
377
|
+
};
|
|
1157
378
|
this.buildLineItem = async ({ checkout, item, quantity, }) => {
|
|
1158
|
-
const product = await this.
|
|
1159
|
-
item.quantity = item?.quantity || checkout?.lineItems?.find((lineItem) => lineItem.
|
|
379
|
+
const product = await this.productRepository.get({ id: item.id });
|
|
380
|
+
item.quantity = item?.quantity || checkout?.lineItems?.find((lineItem) => lineItem.sku === item.sku)?.quantity || 0;
|
|
1160
381
|
if (this.checkMaxStock(item, quantity || 0))
|
|
1161
382
|
throw new Error('Desculpe! Temos apenas ' + item.stock?.quantity + ' em estoque.');
|
|
1162
383
|
const image = item.image || item.images?.shift();
|
|
1163
|
-
const { id, name, EAN, slug, stock, price, weight, sku, type } = item;
|
|
384
|
+
const { id, name, EAN, brand, slug, stock, price, weight, categories, sku, type } = item;
|
|
1164
385
|
const isGift = item.isGift || null;
|
|
1165
386
|
const pricePaid = this.getProductPrice({
|
|
1166
387
|
product: item,
|
|
1167
388
|
shop: checkout.shop || this.defaultShop,
|
|
1168
389
|
isSubscriber: checkout.user?.isSubscriber,
|
|
1169
390
|
});
|
|
1170
|
-
RoundProductPricesHelper.roundProductPrices(item);
|
|
1171
391
|
return {
|
|
1172
392
|
checkout,
|
|
1173
393
|
lineItem: LineItem.toInstance({
|
|
@@ -1178,7 +398,7 @@ class CartService {
|
|
|
1178
398
|
slug: slug ?? product.slug,
|
|
1179
399
|
sku: sku ?? product.sku,
|
|
1180
400
|
stock,
|
|
1181
|
-
price
|
|
401
|
+
price,
|
|
1182
402
|
image,
|
|
1183
403
|
weight: weight ?? product.weight,
|
|
1184
404
|
quantity: (item.quantity || 0) + (quantity || 0),
|
|
@@ -1194,9 +414,7 @@ class CartService {
|
|
|
1194
414
|
const info = product.price;
|
|
1195
415
|
if (product.isGift)
|
|
1196
416
|
return 0;
|
|
1197
|
-
return isSubscriber && info.subscriberPrice > 0
|
|
1198
|
-
? Number(info.subscriberPrice.toFixed(2))
|
|
1199
|
-
: Number(info.price.toFixed(2));
|
|
417
|
+
return isSubscriber && info.subscriberPrice > 0 ? info.subscriberPrice : info.price;
|
|
1200
418
|
};
|
|
1201
419
|
this.checkMaxStock = (item, quantity) => {
|
|
1202
420
|
const maxStock = item.stock?.quantity || 0;
|
|
@@ -1209,7 +427,7 @@ class CartService {
|
|
|
1209
427
|
}
|
|
1210
428
|
decreaseItem(item) {
|
|
1211
429
|
return this.checkoutService.getCheckout().pipe(map((checkout) => {
|
|
1212
|
-
const checkoutItem = checkout.lineItems?.find((lineItem) => lineItem.
|
|
430
|
+
const checkoutItem = checkout.lineItems?.find((lineItem) => lineItem.sku === item.sku);
|
|
1213
431
|
if (!isNil(checkoutItem))
|
|
1214
432
|
checkoutItem.quantity -= checkoutItem.quantity > 1 ? 1 : 0;
|
|
1215
433
|
return checkout;
|
|
@@ -1222,176 +440,43 @@ class CartService {
|
|
|
1222
440
|
/**
|
|
1223
441
|
* @deprecated The method should not be used
|
|
1224
442
|
*/
|
|
1225
|
-
getVariantPriceDiscount(item) {
|
|
1226
|
-
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)));
|
|
1227
|
-
}
|
|
1228
|
-
removeItem(item) {
|
|
1229
|
-
return this.checkoutService.getCheckout().pipe(map((checkout) => {
|
|
1230
|
-
const index = checkout.lineItems.findIndex((lineItem) => lineItem.
|
|
1231
|
-
if (index >= 0)
|
|
1232
|
-
checkout.lineItems.splice(index, 1);
|
|
1233
|
-
return checkout;
|
|
1234
|
-
}), concatMap((checkout) => this.checkoutService.updateCheckoutLineItems(checkout)), map((checkout) => this.generateCartObject(checkout.lineItems)), tap((cart) => this.cartSubject.next(cart)));
|
|
1235
|
-
}
|
|
1236
|
-
updateUserCart(user) {
|
|
1237
|
-
return this.checkoutService.getCheckout().pipe(concatMap((checkout) => this.checkoutService.updateCheckoutUser(Checkout.toInstance({ ...checkout.toPlain(), user }))), concatMap(async (checkout) => this.checkoutService
|
|
1238
|
-
.updateCheckoutLineItems(Checkout.toInstance({
|
|
1239
|
-
...checkout.toPlain(),
|
|
1240
|
-
lineItems: checkout.lineItems?.length
|
|
1241
|
-
? await Promise.all(checkout.lineItems?.map(async (item) => (await this.buildLineItem({ checkout, item })).lineItem))
|
|
1242
|
-
: [],
|
|
1243
|
-
}))
|
|
1244
|
-
.toPromise()), map((checkout) => this.generateCartObject(checkout.lineItems)), tap((cart) => this.cartSubject.next(cart)));
|
|
1245
|
-
}
|
|
1246
|
-
clearCart() {
|
|
1247
|
-
return this.checkoutService.getCheckout().pipe(map((checkout) => {
|
|
1248
|
-
this.checkoutService.clearCheckoutFromSession();
|
|
1249
|
-
return checkout;
|
|
1250
|
-
}), concatMap((oldCheckout) => this.buildCartFromCheckout(oldCheckout)), tap((cart) => this.cartSubject.next(cart)));
|
|
1251
|
-
}
|
|
1252
|
-
buildCartFromCheckout(checkoutData) {
|
|
1253
|
-
return this.checkoutService.getCheckout(checkoutData).pipe(map((checkout) => checkout.lineItems), concatMap((lineItems) => of(this.generateCartObject(lineItems))));
|
|
1254
|
-
}
|
|
1255
|
-
roundPrice(productPrice) {
|
|
1256
|
-
const { price, fullPrice, subscriberPrice } = productPrice;
|
|
1257
|
-
return {
|
|
1258
|
-
...productPrice,
|
|
1259
|
-
price: Number(price.toFixed(2)),
|
|
1260
|
-
fullPrice: Number(fullPrice.toFixed(2)),
|
|
1261
|
-
...(subscriberPrice && { subscriberPrice: Number(subscriberPrice.toFixed(2)) }),
|
|
1262
|
-
};
|
|
1263
|
-
}
|
|
1264
|
-
async getProductData(productId) {
|
|
1265
|
-
let product;
|
|
1266
|
-
let variant;
|
|
1267
|
-
try {
|
|
1268
|
-
product = await this.productRepository.get({ id: productId });
|
|
1269
|
-
}
|
|
1270
|
-
catch (error) {
|
|
1271
|
-
if (!(error instanceof NotFoundError))
|
|
1272
|
-
throw error;
|
|
1273
|
-
const { data: variants } = await this.variantRepository.find({ filters: { id: productId } });
|
|
1274
|
-
variant = variants.shift();
|
|
1275
|
-
if (!variant)
|
|
1276
|
-
throw error;
|
|
1277
|
-
product = await this.productRepository.get({ id: variant.productId });
|
|
1278
|
-
}
|
|
1279
|
-
return {
|
|
1280
|
-
...product.toPlain(),
|
|
1281
|
-
...(variant && { ...variant.toPlain() }),
|
|
1282
|
-
};
|
|
1283
|
-
}
|
|
1284
|
-
getGifts() {
|
|
1285
|
-
return this.checkoutService.getCheckout().pipe(mergeMap(async (checkout) => {
|
|
1286
|
-
const notGiftItems = checkout.lineItems ? checkout.lineItems.filter((item) => !item.isGift) : [];
|
|
1287
|
-
if (!notGiftItems.length)
|
|
1288
|
-
return { ...checkout, lineItems: [] };
|
|
1289
|
-
const cartTotal = notGiftItems.reduce((a, b) => a + b.pricePaid * b.quantity, 0);
|
|
1290
|
-
const campaigns = await this.buy2WinRepository
|
|
1291
|
-
.find({
|
|
1292
|
-
filters: {
|
|
1293
|
-
active: { operator: Where.EQUALS, value: true },
|
|
1294
|
-
shop: { operator: Where.EQUALS, value: this.defaultShop },
|
|
1295
|
-
},
|
|
1296
|
-
})
|
|
1297
|
-
.then((data) => data.data);
|
|
1298
|
-
if (!campaigns.length)
|
|
1299
|
-
return { ...checkout, lineItems: notGiftItems };
|
|
1300
|
-
const elegibleCampaigns = [];
|
|
1301
|
-
for (const campaign of campaigns) {
|
|
1302
|
-
const today = new Date();
|
|
1303
|
-
if (!(campaign.startDate <= today) && !(campaign.endDate >= today))
|
|
1304
|
-
continue;
|
|
1305
|
-
if (campaign.activeCategory) {
|
|
1306
|
-
const categoriesCampaing = campaign.categories.map((c) => c.id.toString());
|
|
1307
|
-
const categoriesCampaingFullTree = [];
|
|
1308
|
-
for (const id of categoriesCampaing) {
|
|
1309
|
-
const children = await this.categoryRepository.getChildren(parseInt(id));
|
|
1310
|
-
categoriesCampaingFullTree.push(id, ...children.map((c) => c.id.toString()));
|
|
1311
|
-
}
|
|
1312
|
-
const categoriesCampaingTree = [...new Set(categoriesCampaingFullTree)];
|
|
1313
|
-
const filterProductsCategories = checkout.lineItems.filter((l) => {
|
|
1314
|
-
if (!l.categories || !l.categories?.length)
|
|
1315
|
-
return true;
|
|
1316
|
-
return l.categories.some((c) => categoriesCampaingTree.some((cat) => cat == c));
|
|
1317
|
-
});
|
|
1318
|
-
if (filterProductsCategories.length) {
|
|
1319
|
-
const cartTotalCategories = filterProductsCategories.reduce((a, b) => a + b.pricePaid * b.quantity, 0);
|
|
1320
|
-
if (cartTotalCategories >= campaign.cartValueMin)
|
|
1321
|
-
elegibleCampaigns.push(campaign);
|
|
1322
|
-
}
|
|
1323
|
-
}
|
|
1324
|
-
else {
|
|
1325
|
-
if (campaign.cartValue && campaign.cartValue > 0) {
|
|
1326
|
-
if (campaign.cartValue <= cartTotal)
|
|
1327
|
-
elegibleCampaigns.push(campaign);
|
|
1328
|
-
}
|
|
1329
|
-
}
|
|
1330
|
-
}
|
|
1331
|
-
if (!elegibleCampaigns.length)
|
|
1332
|
-
return { ...checkout, lineItems: notGiftItems };
|
|
1333
|
-
const campaingnProducts = [];
|
|
1334
|
-
for (const campaign of elegibleCampaigns) {
|
|
1335
|
-
let elegibleProducts = [];
|
|
1336
|
-
for (const product of campaign.products) {
|
|
1337
|
-
const { data: productData } = await this.productRepository.find({ filters: { sku: product } });
|
|
1338
|
-
if (!productData.length)
|
|
1339
|
-
continue;
|
|
1340
|
-
const gift = productData.shift();
|
|
1341
|
-
if (gift.stock.quantity < 1)
|
|
1342
|
-
continue;
|
|
1343
|
-
elegibleProducts.push(gift);
|
|
1344
|
-
}
|
|
1345
|
-
campaingnProducts.push(elegibleProducts);
|
|
1346
|
-
}
|
|
1347
|
-
if (!campaingnProducts.length)
|
|
1348
|
-
return { ...checkout, lineItems: notGiftItems };
|
|
1349
|
-
const gifts = this.giftToLineItems([].concat(...campaingnProducts));
|
|
1350
|
-
return { ...checkout, lineItems: notGiftItems.concat(gifts) };
|
|
443
|
+
getVariantPriceDiscount(item) {
|
|
444
|
+
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)));
|
|
445
|
+
}
|
|
446
|
+
removeItem(item) {
|
|
447
|
+
return this.checkoutService.getCheckout().pipe(map((checkout) => {
|
|
448
|
+
const index = checkout.lineItems.findIndex((lineItem) => lineItem.sku === item.sku);
|
|
449
|
+
if (index >= 0)
|
|
450
|
+
checkout.lineItems.splice(index, 1);
|
|
451
|
+
return checkout;
|
|
1351
452
|
}), concatMap((checkout) => this.checkoutService.updateCheckoutLineItems(checkout)), map((checkout) => this.generateCartObject(checkout.lineItems)), tap((cart) => this.cartSubject.next(cart)));
|
|
1352
453
|
}
|
|
1353
|
-
|
|
1354
|
-
return
|
|
1355
|
-
|
|
1356
|
-
|
|
1357
|
-
|
|
1358
|
-
|
|
1359
|
-
|
|
1360
|
-
|
|
1361
|
-
|
|
1362
|
-
|
|
1363
|
-
|
|
1364
|
-
|
|
1365
|
-
|
|
1366
|
-
|
|
1367
|
-
EAN,
|
|
1368
|
-
image,
|
|
1369
|
-
pricePaid: 0,
|
|
1370
|
-
quantity: 1,
|
|
1371
|
-
isGift: true,
|
|
1372
|
-
});
|
|
1373
|
-
});
|
|
454
|
+
updateUserCart(user) {
|
|
455
|
+
return this.checkoutService.getCheckout().pipe(concatMap((checkout) => this.checkoutService.updateCheckoutUser(Checkout.toInstance({ ...checkout.toPlain(), user }))), concatMap(async (checkout) => this.checkoutService.updateCheckoutLineItems(Checkout.toInstance({
|
|
456
|
+
...checkout.toPlain(),
|
|
457
|
+
lineItems: checkout.lineItems?.length ? await Promise.all(checkout.lineItems?.map(async (item) => (await this.buildLineItem({ checkout, item })).lineItem)) : [],
|
|
458
|
+
})).toPromise()), map(checkout => this.generateCartObject(checkout.lineItems)), tap((cart) => this.cartSubject.next(cart)));
|
|
459
|
+
}
|
|
460
|
+
clearCart() {
|
|
461
|
+
return this.checkoutService.getCheckout().pipe(map((checkout) => {
|
|
462
|
+
this.checkoutService.clearCheckoutFromSession();
|
|
463
|
+
return checkout;
|
|
464
|
+
}), concatMap((oldCheckout) => this.buildCartFromCheckout(oldCheckout)), tap((cart) => this.cartSubject.next(cart)));
|
|
465
|
+
}
|
|
466
|
+
buildCartFromCheckout(checkoutData) {
|
|
467
|
+
return this.checkoutService.getCheckout(checkoutData).pipe(map((checkout) => checkout.lineItems), concatMap((lineItems) => of(this.generateCartObject(lineItems))));
|
|
1374
468
|
}
|
|
1375
469
|
}
|
|
1376
|
-
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' }
|
|
470
|
+
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' }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
1377
471
|
CartService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: CartService });
|
|
1378
472
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: CartService, decorators: [{
|
|
1379
473
|
type: Injectable
|
|
1380
|
-
}], ctorParameters: function () { return [{ type: AuthService }, { type: CheckoutService }, { type:
|
|
474
|
+
}], ctorParameters: function () { return [{ type: AuthService }, { type: CheckoutService }, { type: i2.Shops, decorators: [{
|
|
1381
475
|
type: Inject,
|
|
1382
476
|
args: [DEFAULT_SHOP]
|
|
1383
477
|
}] }, { type: undefined, decorators: [{
|
|
1384
478
|
type: Inject,
|
|
1385
479
|
args: ['ProductRepository']
|
|
1386
|
-
}] }, { type: undefined, decorators: [{
|
|
1387
|
-
type: Inject,
|
|
1388
|
-
args: ['CategoryRepository']
|
|
1389
|
-
}] }, { type: undefined, decorators: [{
|
|
1390
|
-
type: Inject,
|
|
1391
|
-
args: ['VariantRepository']
|
|
1392
|
-
}] }, { type: i3.Buy2WinFirestoreRepository, decorators: [{
|
|
1393
|
-
type: Inject,
|
|
1394
|
-
args: ['Buy2WinRepository']
|
|
1395
480
|
}] }]; } });
|
|
1396
481
|
|
|
1397
482
|
class CheckoutSubscriptionService {
|
|
@@ -1419,9 +504,7 @@ class CheckoutSubscriptionService {
|
|
|
1419
504
|
return of();
|
|
1420
505
|
}
|
|
1421
506
|
checkCoupon(nickname, userEmail) {
|
|
1422
|
-
return this.getCheckoutSubscription().pipe(concatMap((checkout) => this.couponService
|
|
1423
|
-
.checkCoupon(nickname, userEmail, CheckoutTypes.SUBSCRIPTION, checkout.subscriptionPlan.name, checkout, true)
|
|
1424
|
-
.pipe()));
|
|
507
|
+
return this.getCheckoutSubscription().pipe(concatMap((checkout) => this.couponService.checkCoupon(nickname, userEmail, CheckoutTypes.SUBSCRIPTION, checkout.subscriptionPlan.name, null, true).pipe()));
|
|
1425
508
|
}
|
|
1426
509
|
calcDiscountSubscription(coupon) {
|
|
1427
510
|
return this.getCheckoutSubscription().pipe(concatMap((checkout) => this.couponService.calcDiscountSubscription(coupon, checkout).pipe()));
|
|
@@ -1439,220 +522,757 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.0", ngImpor
|
|
|
1439
522
|
args: ['SubscriptionRepository']
|
|
1440
523
|
}] }, { type: CouponService }]; } });
|
|
1441
524
|
|
|
1442
|
-
class
|
|
1443
|
-
constructor(
|
|
1444
|
-
this.
|
|
1445
|
-
this.
|
|
1446
|
-
this.
|
|
1447
|
-
|
|
1448
|
-
|
|
1449
|
-
|
|
1450
|
-
|
|
1451
|
-
|
|
1452
|
-
|
|
1453
|
-
|
|
1454
|
-
|
|
1455
|
-
|
|
1456
|
-
|
|
1457
|
-
|
|
1458
|
-
|
|
1459
|
-
|
|
1460
|
-
|
|
1461
|
-
|
|
1462
|
-
|
|
1463
|
-
|
|
1464
|
-
|
|
1465
|
-
|
|
1466
|
-
|
|
1467
|
-
|
|
1468
|
-
|
|
1469
|
-
|
|
1470
|
-
|
|
1471
|
-
|
|
1472
|
-
|
|
1473
|
-
|
|
1474
|
-
|
|
1475
|
-
|
|
1476
|
-
|
|
1477
|
-
|
|
1478
|
-
|
|
1479
|
-
|
|
1480
|
-
|
|
1481
|
-
|
|
1482
|
-
|
|
1483
|
-
|
|
1484
|
-
|
|
1485
|
-
|
|
1486
|
-
|
|
1487
|
-
|
|
1488
|
-
|
|
1489
|
-
|
|
1490
|
-
|
|
1491
|
-
|
|
1492
|
-
|
|
1493
|
-
|
|
1494
|
-
return
|
|
1495
|
-
|
|
1496
|
-
}
|
|
1497
|
-
|
|
1498
|
-
return this.getHomeConfiguration().pipe(map((home) => home
|
|
1499
|
-
|
|
1500
|
-
|
|
1501
|
-
|
|
1502
|
-
|
|
1503
|
-
|
|
1504
|
-
|
|
1505
|
-
}
|
|
1506
|
-
|
|
1507
|
-
return this.getHomeConfiguration().pipe(
|
|
1508
|
-
|
|
1509
|
-
|
|
1510
|
-
|
|
1511
|
-
|
|
1512
|
-
|
|
1513
|
-
|
|
1514
|
-
|
|
1515
|
-
|
|
1516
|
-
|
|
1517
|
-
|
|
1518
|
-
}
|
|
1519
|
-
|
|
1520
|
-
|
|
1521
|
-
|
|
1522
|
-
|
|
1523
|
-
|
|
525
|
+
class OrderService {
|
|
526
|
+
constructor(angularFirestore, orderRepository) {
|
|
527
|
+
this.angularFirestore = angularFirestore;
|
|
528
|
+
this.orderRepository = orderRepository;
|
|
529
|
+
this.orderSubject = new Subject();
|
|
530
|
+
}
|
|
531
|
+
getOrder(id) {
|
|
532
|
+
docSnapshots(doc(this.angularFirestore, `${this.orderRepository.collectionName}/${id}`))
|
|
533
|
+
.pipe(map((doc) => Order.toInstance(doc.data())))
|
|
534
|
+
.subscribe((doc) => this.orderSubject.next(doc));
|
|
535
|
+
return this.orderSubject;
|
|
536
|
+
}
|
|
537
|
+
}
|
|
538
|
+
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 });
|
|
539
|
+
OrderService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: OrderService });
|
|
540
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: OrderService, decorators: [{
|
|
541
|
+
type: Injectable
|
|
542
|
+
}], ctorParameters: function () { return [{ type: i1$1.Firestore }, { type: i2.OrderFirestoreRepository, decorators: [{
|
|
543
|
+
type: Inject,
|
|
544
|
+
args: ['OrderRepository']
|
|
545
|
+
}] }]; } });
|
|
546
|
+
|
|
547
|
+
class HomeShopService {
|
|
548
|
+
constructor(categoryRepository, homeRepository, productRepository, defaultShop) {
|
|
549
|
+
this.categoryRepository = categoryRepository;
|
|
550
|
+
this.homeRepository = homeRepository;
|
|
551
|
+
this.productRepository = productRepository;
|
|
552
|
+
this.defaultShop = defaultShop;
|
|
553
|
+
this.buildCategoryGroupWithRequiredData = (group) => ({
|
|
554
|
+
category: Category.toInstance(pick(group?.category?.toPlain() || {}, ['id', 'name', 'slug', 'conditions'])),
|
|
555
|
+
products: group?.products?.map((product) => Product.toInstance(pick(product?.toPlain() || {}, [
|
|
556
|
+
'id',
|
|
557
|
+
'price',
|
|
558
|
+
'reviews',
|
|
559
|
+
'hasVariants',
|
|
560
|
+
'slug',
|
|
561
|
+
'sku',
|
|
562
|
+
'stock',
|
|
563
|
+
'costPrice',
|
|
564
|
+
'images',
|
|
565
|
+
'miniatures',
|
|
566
|
+
'name',
|
|
567
|
+
'weight',
|
|
568
|
+
'rate',
|
|
569
|
+
'type',
|
|
570
|
+
]))) || [],
|
|
571
|
+
});
|
|
572
|
+
}
|
|
573
|
+
get homeId() {
|
|
574
|
+
if (this.defaultShop === Shops.GLAMSHOP)
|
|
575
|
+
return 'glamshop';
|
|
576
|
+
if (this.defaultShop === Shops.MENSMARKET)
|
|
577
|
+
return 'mens_market';
|
|
578
|
+
return null;
|
|
579
|
+
}
|
|
580
|
+
getHomeData() {
|
|
581
|
+
return this.getHomeConfiguration().pipe(map((home) => (home?.data?.expiresAt > new Date() ? home : null)), concatMap((home) => home
|
|
582
|
+
? of(home)
|
|
583
|
+
: forkJoin([this.getDiscoverProducts(), this.getFeaturedProducts(), this.getVerticalProducts()]).pipe(map(([discoverProducts, featuredProducts, verticalProducts]) => ({
|
|
584
|
+
discoverProducts,
|
|
585
|
+
featuredProducts,
|
|
586
|
+
verticalProducts,
|
|
587
|
+
})), concatMap((data) => this.saveHomeData(data)))));
|
|
588
|
+
}
|
|
589
|
+
getBanners(type) {
|
|
590
|
+
return this.getHomeConfiguration().pipe(map((home) => {
|
|
591
|
+
if (type === 'brand')
|
|
592
|
+
return home.brandsCarousel;
|
|
593
|
+
if (type === 'buyToWin')
|
|
594
|
+
return [home.buyToWinBanner];
|
|
595
|
+
if (type === 'block')
|
|
596
|
+
return home.blockBanners;
|
|
597
|
+
if (type === 'blog')
|
|
598
|
+
return [home.blogBanner];
|
|
599
|
+
return [];
|
|
600
|
+
}));
|
|
601
|
+
}
|
|
602
|
+
getMinValueForFreeShipping() {
|
|
603
|
+
return this.getHomeConfiguration().pipe(map((home) => home.minValueForFreeShipping));
|
|
604
|
+
}
|
|
605
|
+
getDiscoverProducts() {
|
|
606
|
+
return this.getHomeConfiguration().pipe(concatMap((home) => from(this.categoryRepository.getCategoriesForHome(home.discoverCategories)).pipe(map((groups) => groups.map(this.buildCategoryGroupWithRequiredData)))));
|
|
607
|
+
}
|
|
608
|
+
getFeaturedProducts() {
|
|
609
|
+
return this.getHomeConfiguration().pipe(concatMap((home) => from(this.categoryRepository.getCategoriesForHome(home.featuredCategories)).pipe(map((groups) => groups.map(this.buildCategoryGroupWithRequiredData)))));
|
|
610
|
+
}
|
|
611
|
+
getVerticalProducts() {
|
|
612
|
+
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({
|
|
613
|
+
filters: { categories: { operator: Where.IN, value: [category.id] } },
|
|
614
|
+
limits: { limit: 12 },
|
|
615
|
+
})).pipe(map((products) => ({ category, products })))), map(({ category, products }) => ({ category, products: products.data })), map(this.buildCategoryGroupWithRequiredData))))));
|
|
616
|
+
}
|
|
617
|
+
getHomeConfiguration() {
|
|
618
|
+
return of(this.homeConfiguration).pipe(concatMap((home) => home
|
|
619
|
+
? of(home)
|
|
620
|
+
: !this.homeId
|
|
621
|
+
? throwError(new RequiredArgumentError(['homeId']))
|
|
622
|
+
: from(this.homeRepository.get({ id: this.homeId })).pipe(tap((homeLoaded) => (this.homeConfiguration = homeLoaded)))));
|
|
623
|
+
}
|
|
624
|
+
saveHomeData(homeData) {
|
|
625
|
+
const data = {
|
|
626
|
+
createdAt: new Date(),
|
|
627
|
+
expiresAt: add(new Date(), { hours: 1 }),
|
|
628
|
+
data: homeData,
|
|
629
|
+
};
|
|
630
|
+
return from(this.homeRepository.update({
|
|
631
|
+
id: this.homeId,
|
|
632
|
+
data,
|
|
633
|
+
})).pipe(tap(() => (this.homeConfiguration.data = data)), map(() => this.homeConfiguration));
|
|
634
|
+
}
|
|
635
|
+
}
|
|
636
|
+
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 });
|
|
637
|
+
HomeShopService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: HomeShopService });
|
|
638
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: HomeShopService, decorators: [{
|
|
639
|
+
type: Injectable
|
|
640
|
+
}], ctorParameters: function () { return [{ type: undefined, decorators: [{
|
|
641
|
+
type: Inject,
|
|
642
|
+
args: ['CategoryRepository']
|
|
643
|
+
}] }, { type: undefined, decorators: [{
|
|
644
|
+
type: Inject,
|
|
645
|
+
args: ['HomeRepository']
|
|
646
|
+
}] }, { type: undefined, decorators: [{
|
|
647
|
+
type: Inject,
|
|
648
|
+
args: ['ProductRepository']
|
|
649
|
+
}] }, { type: i2.Shops, decorators: [{
|
|
650
|
+
type: Inject,
|
|
651
|
+
args: [DEFAULT_SHOP]
|
|
652
|
+
}] }]; } });
|
|
653
|
+
|
|
654
|
+
class AngularFirebaseAuthModule {
|
|
655
|
+
static initializeApp(options, nameOrConfig) {
|
|
656
|
+
return {
|
|
657
|
+
ngModule: AngularFirebaseAuthModule,
|
|
658
|
+
providers: [
|
|
659
|
+
{ provide: FIREBASE_OPTIONS, useValue: options },
|
|
660
|
+
{ provide: FIREBASE_APP_NAME, useValue: nameOrConfig },
|
|
661
|
+
],
|
|
662
|
+
};
|
|
663
|
+
}
|
|
664
|
+
}
|
|
665
|
+
AngularFirebaseAuthModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: AngularFirebaseAuthModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
666
|
+
AngularFirebaseAuthModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.1.0", ngImport: i0, type: AngularFirebaseAuthModule, imports: [i1$2.FirebaseAppModule, i1.AuthModule] });
|
|
667
|
+
AngularFirebaseAuthModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: AngularFirebaseAuthModule, providers: [
|
|
668
|
+
{
|
|
669
|
+
provide: 'Authentication',
|
|
670
|
+
useFactory: (authenticationService, userRepository) => {
|
|
671
|
+
return new Authentication(authenticationService, userRepository);
|
|
672
|
+
},
|
|
673
|
+
deps: ['AuthenticationService', 'UserRepository'],
|
|
674
|
+
},
|
|
675
|
+
{
|
|
676
|
+
provide: 'AuthenticationService',
|
|
677
|
+
useFactory: (angularFireAuth) => {
|
|
678
|
+
return new AuthenticationFirebaseAuthService(angularFireAuth);
|
|
679
|
+
},
|
|
680
|
+
deps: [Auth],
|
|
681
|
+
},
|
|
682
|
+
{
|
|
683
|
+
provide: 'Register',
|
|
684
|
+
useFactory: (registerService, userRepository) => {
|
|
685
|
+
return new Register(registerService, userRepository);
|
|
686
|
+
},
|
|
687
|
+
deps: ['RegisterService', 'UserRepository'],
|
|
688
|
+
},
|
|
689
|
+
{
|
|
690
|
+
provide: 'RegisterService',
|
|
691
|
+
useFactory: (angularFireAuth) => {
|
|
692
|
+
return new RegisterFirebaseAuthService(angularFireAuth);
|
|
693
|
+
},
|
|
694
|
+
deps: [Auth],
|
|
695
|
+
},
|
|
696
|
+
{
|
|
697
|
+
provide: 'SignOut',
|
|
698
|
+
useFactory: (authenticationService) => {
|
|
699
|
+
return new SignOut(authenticationService);
|
|
700
|
+
},
|
|
701
|
+
deps: ['AuthenticationService'],
|
|
702
|
+
},
|
|
703
|
+
{
|
|
704
|
+
provide: 'RecoveryPassword',
|
|
705
|
+
useFactory: (authenticationService) => {
|
|
706
|
+
return new RecoveryPassword(authenticationService);
|
|
707
|
+
},
|
|
708
|
+
deps: ['AuthenticationService'],
|
|
709
|
+
},
|
|
710
|
+
], imports: [provideFirebaseApp((injector) => {
|
|
711
|
+
const appName = injector.get(FIREBASE_APP_NAME);
|
|
712
|
+
return appName
|
|
713
|
+
? initializeApp(injector.get(FIREBASE_OPTIONS), appName)
|
|
714
|
+
: initializeApp(injector.get(FIREBASE_OPTIONS));
|
|
715
|
+
}),
|
|
716
|
+
provideAuth(() => getAuth())] });
|
|
717
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: AngularFirebaseAuthModule, decorators: [{
|
|
718
|
+
type: NgModule,
|
|
719
|
+
args: [{
|
|
720
|
+
imports: [
|
|
721
|
+
provideFirebaseApp((injector) => {
|
|
722
|
+
const appName = injector.get(FIREBASE_APP_NAME);
|
|
723
|
+
return appName
|
|
724
|
+
? initializeApp(injector.get(FIREBASE_OPTIONS), appName)
|
|
725
|
+
: initializeApp(injector.get(FIREBASE_OPTIONS));
|
|
726
|
+
}),
|
|
727
|
+
provideAuth(() => getAuth()),
|
|
728
|
+
],
|
|
729
|
+
providers: [
|
|
730
|
+
{
|
|
731
|
+
provide: 'Authentication',
|
|
732
|
+
useFactory: (authenticationService, userRepository) => {
|
|
733
|
+
return new Authentication(authenticationService, userRepository);
|
|
734
|
+
},
|
|
735
|
+
deps: ['AuthenticationService', 'UserRepository'],
|
|
736
|
+
},
|
|
737
|
+
{
|
|
738
|
+
provide: 'AuthenticationService',
|
|
739
|
+
useFactory: (angularFireAuth) => {
|
|
740
|
+
return new AuthenticationFirebaseAuthService(angularFireAuth);
|
|
741
|
+
},
|
|
742
|
+
deps: [Auth],
|
|
743
|
+
},
|
|
744
|
+
{
|
|
745
|
+
provide: 'Register',
|
|
746
|
+
useFactory: (registerService, userRepository) => {
|
|
747
|
+
return new Register(registerService, userRepository);
|
|
748
|
+
},
|
|
749
|
+
deps: ['RegisterService', 'UserRepository'],
|
|
750
|
+
},
|
|
751
|
+
{
|
|
752
|
+
provide: 'RegisterService',
|
|
753
|
+
useFactory: (angularFireAuth) => {
|
|
754
|
+
return new RegisterFirebaseAuthService(angularFireAuth);
|
|
755
|
+
},
|
|
756
|
+
deps: [Auth],
|
|
757
|
+
},
|
|
758
|
+
{
|
|
759
|
+
provide: 'SignOut',
|
|
760
|
+
useFactory: (authenticationService) => {
|
|
761
|
+
return new SignOut(authenticationService);
|
|
762
|
+
},
|
|
763
|
+
deps: ['AuthenticationService'],
|
|
764
|
+
},
|
|
765
|
+
{
|
|
766
|
+
provide: 'RecoveryPassword',
|
|
767
|
+
useFactory: (authenticationService) => {
|
|
768
|
+
return new RecoveryPassword(authenticationService);
|
|
769
|
+
},
|
|
770
|
+
deps: ['AuthenticationService'],
|
|
771
|
+
},
|
|
772
|
+
],
|
|
773
|
+
}]
|
|
774
|
+
}] });
|
|
775
|
+
|
|
776
|
+
class AngularElasticSeachModule {
|
|
777
|
+
static initializeApp(options) {
|
|
778
|
+
return {
|
|
779
|
+
ngModule: AngularElasticSeachModule,
|
|
780
|
+
providers: [{ provide: ES_CONFIG, useValue: options }],
|
|
1524
781
|
};
|
|
1525
|
-
return from(this.homeRepository.update({
|
|
1526
|
-
id: this.homeId,
|
|
1527
|
-
data,
|
|
1528
|
-
})).pipe(tap(() => (this.homeConfiguration.data = data)), map(() => this.homeConfiguration));
|
|
1529
782
|
}
|
|
1530
783
|
}
|
|
1531
|
-
|
|
1532
|
-
|
|
1533
|
-
i0.ɵɵ
|
|
1534
|
-
|
|
1535
|
-
|
|
1536
|
-
|
|
1537
|
-
|
|
1538
|
-
|
|
1539
|
-
|
|
1540
|
-
|
|
1541
|
-
|
|
1542
|
-
|
|
1543
|
-
|
|
1544
|
-
|
|
1545
|
-
|
|
1546
|
-
|
|
1547
|
-
|
|
784
|
+
AngularElasticSeachModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: AngularElasticSeachModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
785
|
+
AngularElasticSeachModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.1.0", ngImport: i0, type: AngularElasticSeachModule });
|
|
786
|
+
AngularElasticSeachModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: AngularElasticSeachModule, providers: [
|
|
787
|
+
{
|
|
788
|
+
provide: ProductsIndex,
|
|
789
|
+
useFactory: (configuration) => {
|
|
790
|
+
return new ProductsIndex(new AxiosAdapter(configuration));
|
|
791
|
+
},
|
|
792
|
+
deps: [ES_CONFIG],
|
|
793
|
+
},
|
|
794
|
+
] });
|
|
795
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: AngularElasticSeachModule, decorators: [{
|
|
796
|
+
type: NgModule,
|
|
797
|
+
args: [{
|
|
798
|
+
providers: [
|
|
799
|
+
{
|
|
800
|
+
provide: ProductsIndex,
|
|
801
|
+
useFactory: (configuration) => {
|
|
802
|
+
return new ProductsIndex(new AxiosAdapter(configuration));
|
|
803
|
+
},
|
|
804
|
+
deps: [ES_CONFIG],
|
|
805
|
+
},
|
|
806
|
+
],
|
|
807
|
+
}]
|
|
808
|
+
}] });
|
|
1548
809
|
|
|
1549
|
-
class
|
|
1550
|
-
|
|
1551
|
-
|
|
1552
|
-
|
|
1553
|
-
|
|
1554
|
-
|
|
1555
|
-
|
|
1556
|
-
|
|
1557
|
-
|
|
1558
|
-
|
|
1559
|
-
return this.orderSubject;
|
|
810
|
+
class AngularFirestoreModule {
|
|
811
|
+
static initializeApp(options, nameOrConfig) {
|
|
812
|
+
return {
|
|
813
|
+
ngModule: AngularFirestoreModule,
|
|
814
|
+
providers: [
|
|
815
|
+
{ provide: FIREBASE_OPTIONS, useValue: options.firebase },
|
|
816
|
+
{ provide: FIREBASE_APP_NAME, useValue: nameOrConfig },
|
|
817
|
+
{ provide: ES_CONFIG, useValue: options.elasticSearch },
|
|
818
|
+
],
|
|
819
|
+
};
|
|
1560
820
|
}
|
|
1561
821
|
}
|
|
1562
|
-
|
|
1563
|
-
|
|
1564
|
-
i0.ɵɵ
|
|
1565
|
-
|
|
1566
|
-
|
|
1567
|
-
|
|
1568
|
-
|
|
1569
|
-
|
|
822
|
+
AngularFirestoreModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: AngularFirestoreModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
823
|
+
AngularFirestoreModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.1.0", ngImport: i0, type: AngularFirestoreModule, imports: [AngularElasticSeachModule, i1$2.FirebaseAppModule, i1$1.FirestoreModule] });
|
|
824
|
+
AngularFirestoreModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: AngularFirestoreModule, providers: [
|
|
825
|
+
{
|
|
826
|
+
provide: 'BeautyProfileRepository',
|
|
827
|
+
useFactory: (firestore, userRepository) => {
|
|
828
|
+
return new UserBeautyProfileFirestoreRepository(firestore, userRepository);
|
|
829
|
+
},
|
|
830
|
+
deps: [Firestore, 'UserRepository'],
|
|
831
|
+
},
|
|
832
|
+
{
|
|
833
|
+
provide: 'Buy2WinRepository',
|
|
834
|
+
useFactory: (firestore) => {
|
|
835
|
+
return new Buy2WinFirestoreRepository(firestore);
|
|
836
|
+
},
|
|
837
|
+
deps: [Firestore],
|
|
838
|
+
},
|
|
839
|
+
{
|
|
840
|
+
provide: CategoryFirestoreRepository,
|
|
841
|
+
useFactory: (firestore) => {
|
|
842
|
+
return new CategoryFirestoreRepository(firestore);
|
|
843
|
+
},
|
|
844
|
+
deps: [Firestore],
|
|
845
|
+
},
|
|
846
|
+
{
|
|
847
|
+
provide: 'CheckoutRepository',
|
|
848
|
+
useFactory: (firestore) => {
|
|
849
|
+
return new CheckoutFirestoreRepository(firestore);
|
|
850
|
+
},
|
|
851
|
+
deps: [Firestore],
|
|
852
|
+
},
|
|
853
|
+
{
|
|
854
|
+
provide: 'CheckoutSubscriptionRepository',
|
|
855
|
+
useFactory: (firestore) => {
|
|
856
|
+
return new CheckoutSubscriptionFirestoreRepository(firestore);
|
|
857
|
+
},
|
|
858
|
+
deps: [Firestore],
|
|
859
|
+
},
|
|
860
|
+
{
|
|
861
|
+
provide: 'CouponRepository',
|
|
862
|
+
useFactory: (firestore) => {
|
|
863
|
+
return new CouponFirestoreRepository(firestore);
|
|
864
|
+
},
|
|
865
|
+
deps: [Firestore],
|
|
866
|
+
},
|
|
867
|
+
{
|
|
868
|
+
provide: 'EditionRepository',
|
|
869
|
+
useFactory: (firestore, subscriptionRepository) => {
|
|
870
|
+
return new SubscriptionEditionFirestoreRepository(firestore, subscriptionRepository);
|
|
871
|
+
},
|
|
872
|
+
deps: [Firestore, 'SubscriptionRepository'],
|
|
873
|
+
},
|
|
874
|
+
{
|
|
875
|
+
provide: 'HomeRepository',
|
|
876
|
+
useFactory: (firestore) => {
|
|
877
|
+
return new HomeFirestoreRepository(firestore);
|
|
878
|
+
},
|
|
879
|
+
deps: [Firestore],
|
|
880
|
+
},
|
|
881
|
+
{
|
|
882
|
+
provide: 'LeadRepository',
|
|
883
|
+
useFactory: (firestore) => {
|
|
884
|
+
return new LeadFirestoreRepository(firestore);
|
|
885
|
+
},
|
|
886
|
+
deps: [Firestore],
|
|
887
|
+
},
|
|
888
|
+
{
|
|
889
|
+
provide: 'LegacyOrderRepository',
|
|
890
|
+
useFactory: (firestore) => {
|
|
891
|
+
return new LegacyOrderFirestoreRepository(firestore);
|
|
892
|
+
},
|
|
893
|
+
deps: [Firestore],
|
|
894
|
+
},
|
|
895
|
+
{
|
|
896
|
+
provide: 'ShopMenuRepository',
|
|
897
|
+
useFactory: (firestore) => {
|
|
898
|
+
return new ShopMenuFirestoreRepository(firestore);
|
|
899
|
+
},
|
|
900
|
+
deps: [Firestore],
|
|
901
|
+
},
|
|
902
|
+
{
|
|
903
|
+
provide: 'OrderRepository',
|
|
904
|
+
useFactory: (firestore) => {
|
|
905
|
+
return new OrderFirestoreRepository(firestore);
|
|
906
|
+
},
|
|
907
|
+
deps: [Firestore],
|
|
908
|
+
},
|
|
909
|
+
{
|
|
910
|
+
provide: 'PaymentRepository',
|
|
911
|
+
useFactory: (firestore) => {
|
|
912
|
+
return new PaymentFirestoreRepository(firestore);
|
|
913
|
+
},
|
|
914
|
+
deps: [Firestore],
|
|
915
|
+
},
|
|
916
|
+
{
|
|
917
|
+
provide: ProductFirestoreRepository,
|
|
918
|
+
useFactory: (firestore) => {
|
|
919
|
+
return new ProductFirestoreRepository(firestore);
|
|
920
|
+
},
|
|
921
|
+
deps: [Firestore],
|
|
922
|
+
},
|
|
923
|
+
{
|
|
924
|
+
provide: 'SubscriptionPaymentRepository',
|
|
925
|
+
useFactory: (firestore, subscriptionRepository) => {
|
|
926
|
+
return new SubscriptionPaymentFirestoreRepository(firestore, subscriptionRepository);
|
|
927
|
+
},
|
|
928
|
+
deps: [Firestore, 'SubscriptionRepository'],
|
|
929
|
+
},
|
|
930
|
+
{
|
|
931
|
+
provide: 'SubscriptionPlanRepository',
|
|
932
|
+
useFactory: (firestore) => {
|
|
933
|
+
return new SubscriptionPlanFirestoreRepository(firestore);
|
|
934
|
+
},
|
|
935
|
+
deps: [Firestore],
|
|
936
|
+
},
|
|
937
|
+
{
|
|
938
|
+
provide: 'SubscriptionProductRepository',
|
|
939
|
+
useFactory: (firestore) => {
|
|
940
|
+
return new SubscriptionProductFirestoreRepository(firestore);
|
|
941
|
+
},
|
|
942
|
+
deps: [Firestore],
|
|
943
|
+
},
|
|
944
|
+
{
|
|
945
|
+
provide: 'SubscriptionRepository',
|
|
946
|
+
useFactory: (firestore) => {
|
|
947
|
+
return new SubscriptionFirestoreRepository(firestore);
|
|
948
|
+
},
|
|
949
|
+
deps: [Firestore],
|
|
950
|
+
},
|
|
951
|
+
{
|
|
952
|
+
provide: 'UserRepository',
|
|
953
|
+
useFactory: (firestore) => {
|
|
954
|
+
return new UserFirestoreRepository(firestore);
|
|
955
|
+
},
|
|
956
|
+
deps: [Firestore],
|
|
957
|
+
},
|
|
958
|
+
{
|
|
959
|
+
provide: 'UserAddressRepository',
|
|
960
|
+
useFactory: (firestore, userRepository) => {
|
|
961
|
+
return new UserAddressFirestoreRepository(firestore, userRepository);
|
|
962
|
+
},
|
|
963
|
+
deps: [Firestore, 'UserRepository'],
|
|
964
|
+
},
|
|
965
|
+
{
|
|
966
|
+
provide: 'UserPaymentMethodRepository',
|
|
967
|
+
useFactory: (firestore, userRepository) => {
|
|
968
|
+
return new UserPaymentMethodFirestoreRepository(firestore, userRepository);
|
|
969
|
+
},
|
|
970
|
+
deps: [Firestore, 'UserRepository'],
|
|
971
|
+
},
|
|
972
|
+
{
|
|
973
|
+
provide: ProductVariantFirestoreRepository,
|
|
974
|
+
useFactory: (firestore, productRepository) => {
|
|
975
|
+
return new ProductVariantFirestoreRepository(firestore, productRepository);
|
|
976
|
+
},
|
|
977
|
+
deps: [Firestore, ProductFirestoreRepository],
|
|
978
|
+
},
|
|
979
|
+
], imports: [AngularElasticSeachModule,
|
|
980
|
+
provideFirebaseApp((injector) => {
|
|
981
|
+
const appName = injector.get(FIREBASE_APP_NAME);
|
|
982
|
+
return appName
|
|
983
|
+
? initializeApp(injector.get(FIREBASE_OPTIONS), appName)
|
|
984
|
+
: initializeApp(injector.get(FIREBASE_OPTIONS));
|
|
985
|
+
}),
|
|
986
|
+
provideFirestore(() => getFirestore())] });
|
|
987
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: AngularFirestoreModule, decorators: [{
|
|
988
|
+
type: NgModule,
|
|
989
|
+
args: [{
|
|
990
|
+
imports: [
|
|
991
|
+
AngularElasticSeachModule,
|
|
992
|
+
provideFirebaseApp((injector) => {
|
|
993
|
+
const appName = injector.get(FIREBASE_APP_NAME);
|
|
994
|
+
return appName
|
|
995
|
+
? initializeApp(injector.get(FIREBASE_OPTIONS), appName)
|
|
996
|
+
: initializeApp(injector.get(FIREBASE_OPTIONS));
|
|
997
|
+
}),
|
|
998
|
+
provideFirestore(() => getFirestore()),
|
|
999
|
+
],
|
|
1000
|
+
providers: [
|
|
1001
|
+
{
|
|
1002
|
+
provide: 'BeautyProfileRepository',
|
|
1003
|
+
useFactory: (firestore, userRepository) => {
|
|
1004
|
+
return new UserBeautyProfileFirestoreRepository(firestore, userRepository);
|
|
1005
|
+
},
|
|
1006
|
+
deps: [Firestore, 'UserRepository'],
|
|
1007
|
+
},
|
|
1008
|
+
{
|
|
1009
|
+
provide: 'Buy2WinRepository',
|
|
1010
|
+
useFactory: (firestore) => {
|
|
1011
|
+
return new Buy2WinFirestoreRepository(firestore);
|
|
1012
|
+
},
|
|
1013
|
+
deps: [Firestore],
|
|
1014
|
+
},
|
|
1015
|
+
{
|
|
1016
|
+
provide: CategoryFirestoreRepository,
|
|
1017
|
+
useFactory: (firestore) => {
|
|
1018
|
+
return new CategoryFirestoreRepository(firestore);
|
|
1019
|
+
},
|
|
1020
|
+
deps: [Firestore],
|
|
1021
|
+
},
|
|
1022
|
+
{
|
|
1023
|
+
provide: 'CheckoutRepository',
|
|
1024
|
+
useFactory: (firestore) => {
|
|
1025
|
+
return new CheckoutFirestoreRepository(firestore);
|
|
1026
|
+
},
|
|
1027
|
+
deps: [Firestore],
|
|
1028
|
+
},
|
|
1029
|
+
{
|
|
1030
|
+
provide: 'CheckoutSubscriptionRepository',
|
|
1031
|
+
useFactory: (firestore) => {
|
|
1032
|
+
return new CheckoutSubscriptionFirestoreRepository(firestore);
|
|
1033
|
+
},
|
|
1034
|
+
deps: [Firestore],
|
|
1035
|
+
},
|
|
1036
|
+
{
|
|
1037
|
+
provide: 'CouponRepository',
|
|
1038
|
+
useFactory: (firestore) => {
|
|
1039
|
+
return new CouponFirestoreRepository(firestore);
|
|
1040
|
+
},
|
|
1041
|
+
deps: [Firestore],
|
|
1042
|
+
},
|
|
1043
|
+
{
|
|
1044
|
+
provide: 'EditionRepository',
|
|
1045
|
+
useFactory: (firestore, subscriptionRepository) => {
|
|
1046
|
+
return new SubscriptionEditionFirestoreRepository(firestore, subscriptionRepository);
|
|
1047
|
+
},
|
|
1048
|
+
deps: [Firestore, 'SubscriptionRepository'],
|
|
1049
|
+
},
|
|
1050
|
+
{
|
|
1051
|
+
provide: 'HomeRepository',
|
|
1052
|
+
useFactory: (firestore) => {
|
|
1053
|
+
return new HomeFirestoreRepository(firestore);
|
|
1054
|
+
},
|
|
1055
|
+
deps: [Firestore],
|
|
1056
|
+
},
|
|
1057
|
+
{
|
|
1058
|
+
provide: 'LeadRepository',
|
|
1059
|
+
useFactory: (firestore) => {
|
|
1060
|
+
return new LeadFirestoreRepository(firestore);
|
|
1061
|
+
},
|
|
1062
|
+
deps: [Firestore],
|
|
1063
|
+
},
|
|
1064
|
+
{
|
|
1065
|
+
provide: 'LegacyOrderRepository',
|
|
1066
|
+
useFactory: (firestore) => {
|
|
1067
|
+
return new LegacyOrderFirestoreRepository(firestore);
|
|
1068
|
+
},
|
|
1069
|
+
deps: [Firestore],
|
|
1070
|
+
},
|
|
1071
|
+
{
|
|
1072
|
+
provide: 'ShopMenuRepository',
|
|
1073
|
+
useFactory: (firestore) => {
|
|
1074
|
+
return new ShopMenuFirestoreRepository(firestore);
|
|
1075
|
+
},
|
|
1076
|
+
deps: [Firestore],
|
|
1077
|
+
},
|
|
1078
|
+
{
|
|
1079
|
+
provide: 'OrderRepository',
|
|
1080
|
+
useFactory: (firestore) => {
|
|
1081
|
+
return new OrderFirestoreRepository(firestore);
|
|
1082
|
+
},
|
|
1083
|
+
deps: [Firestore],
|
|
1084
|
+
},
|
|
1085
|
+
{
|
|
1086
|
+
provide: 'PaymentRepository',
|
|
1087
|
+
useFactory: (firestore) => {
|
|
1088
|
+
return new PaymentFirestoreRepository(firestore);
|
|
1089
|
+
},
|
|
1090
|
+
deps: [Firestore],
|
|
1091
|
+
},
|
|
1092
|
+
{
|
|
1093
|
+
provide: ProductFirestoreRepository,
|
|
1094
|
+
useFactory: (firestore) => {
|
|
1095
|
+
return new ProductFirestoreRepository(firestore);
|
|
1096
|
+
},
|
|
1097
|
+
deps: [Firestore],
|
|
1098
|
+
},
|
|
1099
|
+
{
|
|
1100
|
+
provide: 'SubscriptionPaymentRepository',
|
|
1101
|
+
useFactory: (firestore, subscriptionRepository) => {
|
|
1102
|
+
return new SubscriptionPaymentFirestoreRepository(firestore, subscriptionRepository);
|
|
1103
|
+
},
|
|
1104
|
+
deps: [Firestore, 'SubscriptionRepository'],
|
|
1105
|
+
},
|
|
1106
|
+
{
|
|
1107
|
+
provide: 'SubscriptionPlanRepository',
|
|
1108
|
+
useFactory: (firestore) => {
|
|
1109
|
+
return new SubscriptionPlanFirestoreRepository(firestore);
|
|
1110
|
+
},
|
|
1111
|
+
deps: [Firestore],
|
|
1112
|
+
},
|
|
1113
|
+
{
|
|
1114
|
+
provide: 'SubscriptionProductRepository',
|
|
1115
|
+
useFactory: (firestore) => {
|
|
1116
|
+
return new SubscriptionProductFirestoreRepository(firestore);
|
|
1117
|
+
},
|
|
1118
|
+
deps: [Firestore],
|
|
1119
|
+
},
|
|
1120
|
+
{
|
|
1121
|
+
provide: 'SubscriptionRepository',
|
|
1122
|
+
useFactory: (firestore) => {
|
|
1123
|
+
return new SubscriptionFirestoreRepository(firestore);
|
|
1124
|
+
},
|
|
1125
|
+
deps: [Firestore],
|
|
1126
|
+
},
|
|
1127
|
+
{
|
|
1128
|
+
provide: 'UserRepository',
|
|
1129
|
+
useFactory: (firestore) => {
|
|
1130
|
+
return new UserFirestoreRepository(firestore);
|
|
1131
|
+
},
|
|
1132
|
+
deps: [Firestore],
|
|
1133
|
+
},
|
|
1134
|
+
{
|
|
1135
|
+
provide: 'UserAddressRepository',
|
|
1136
|
+
useFactory: (firestore, userRepository) => {
|
|
1137
|
+
return new UserAddressFirestoreRepository(firestore, userRepository);
|
|
1138
|
+
},
|
|
1139
|
+
deps: [Firestore, 'UserRepository'],
|
|
1140
|
+
},
|
|
1141
|
+
{
|
|
1142
|
+
provide: 'UserPaymentMethodRepository',
|
|
1143
|
+
useFactory: (firestore, userRepository) => {
|
|
1144
|
+
return new UserPaymentMethodFirestoreRepository(firestore, userRepository);
|
|
1145
|
+
},
|
|
1146
|
+
deps: [Firestore, 'UserRepository'],
|
|
1147
|
+
},
|
|
1148
|
+
{
|
|
1149
|
+
provide: ProductVariantFirestoreRepository,
|
|
1150
|
+
useFactory: (firestore, productRepository) => {
|
|
1151
|
+
return new ProductVariantFirestoreRepository(firestore, productRepository);
|
|
1152
|
+
},
|
|
1153
|
+
deps: [Firestore, ProductFirestoreRepository],
|
|
1154
|
+
},
|
|
1155
|
+
],
|
|
1156
|
+
}]
|
|
1157
|
+
}] });
|
|
1570
1158
|
|
|
1571
|
-
class
|
|
1572
|
-
|
|
1573
|
-
|
|
1574
|
-
|
|
1575
|
-
|
|
1576
|
-
|
|
1577
|
-
getShippingMethods(shop, zip, weightGrams, totalPrice, personId, subscriptionPlan) {
|
|
1578
|
-
return combineLatest([
|
|
1579
|
-
this.homeService.getHomeData(),
|
|
1580
|
-
this.http.get(`${this.apiUrl}open/checkshippingcompany?personId=${personId}&postalCode=${zip}&weightGrams=${weightGrams}`),
|
|
1581
|
-
]).pipe(map(([datas, shippingMethodsResponse]) => {
|
|
1582
|
-
let shippingMethods = shippingMethodsResponse.result;
|
|
1583
|
-
if (!shippingMethods.length)
|
|
1584
|
-
return [];
|
|
1585
|
-
shippingMethods = shippingMethods.map((shippingMethod) => {
|
|
1586
|
-
if (shippingMethod.ShippingCompanyName == 'Same Day EG')
|
|
1587
|
-
shippingMethod.ShippingCompanyName = 'Same Day';
|
|
1588
|
-
return shippingMethod;
|
|
1589
|
-
});
|
|
1590
|
-
const datasSameDayNotAvaliable = datas.sameDayNotAvaliable;
|
|
1591
|
-
if (this.isHolidays(datasSameDayNotAvaliable)) {
|
|
1592
|
-
shippingMethods = shippingMethods.filter((method) => method.serviceName !== 'Same Day');
|
|
1593
|
-
}
|
|
1594
|
-
if (totalPrice >= 200) {
|
|
1595
|
-
shippingMethods = shippingMethods.map((s) => {
|
|
1596
|
-
if (s.serviceName !== 'Same Day')
|
|
1597
|
-
return { ...s, totalPrice: 0 };
|
|
1598
|
-
else
|
|
1599
|
-
return s;
|
|
1600
|
-
});
|
|
1601
|
-
}
|
|
1602
|
-
if (shop == Shops.GLAMSHOP)
|
|
1603
|
-
return shippingMethods;
|
|
1604
|
-
if (this.isFreeShippingBySubscription(shop, subscriptionPlan)) {
|
|
1605
|
-
shippingMethods = shippingMethods.map((s) => {
|
|
1606
|
-
if (s.serviceName == 'Same Day')
|
|
1607
|
-
return { ...s, totalPrice: s.totalPrice / 2 };
|
|
1608
|
-
else
|
|
1609
|
-
return { ...s, totalPrice: 0 };
|
|
1610
|
-
});
|
|
1611
|
-
}
|
|
1612
|
-
if (this.isHalfShippingBySubscription(shop, subscriptionPlan)) {
|
|
1613
|
-
shippingMethods = shippingMethods.map((s) => {
|
|
1614
|
-
return { ...s, totalPrice: s.totalPrice / 2 };
|
|
1615
|
-
});
|
|
1616
|
-
}
|
|
1617
|
-
return shippingMethods;
|
|
1618
|
-
}));
|
|
1619
|
-
}
|
|
1620
|
-
isFreeShippingBySubscription(shop, subscriptionPlan) {
|
|
1621
|
-
if (!subscriptionPlan)
|
|
1622
|
-
return false;
|
|
1623
|
-
if (shop == Shops.MENSMARKET && subscriptionPlan == 'SELECT')
|
|
1624
|
-
return true;
|
|
1625
|
-
return false;
|
|
1626
|
-
}
|
|
1627
|
-
isHalfShippingBySubscription(shop, subscriptionPlan) {
|
|
1628
|
-
if (!subscriptionPlan)
|
|
1629
|
-
return false;
|
|
1630
|
-
if (shop == Shops.MENSMARKET && subscriptionPlan == 'PRIME') {
|
|
1631
|
-
return true;
|
|
1632
|
-
}
|
|
1633
|
-
return false;
|
|
1634
|
-
}
|
|
1635
|
-
isHolidays(datas) {
|
|
1636
|
-
const today = new Date();
|
|
1637
|
-
for (const key in datas) {
|
|
1638
|
-
let start = new Date(`${today.getFullYear()}-${datas[key].beginDate}`);
|
|
1639
|
-
let end = new Date(`${today.getFullYear()}-${datas[key].endDate}`);
|
|
1640
|
-
if (start > end)
|
|
1641
|
-
end = new Date(`${today.getFullYear() + 1}-${datas[key].endDate}`);
|
|
1642
|
-
if (today >= start && today <= end)
|
|
1643
|
-
return true;
|
|
1644
|
-
}
|
|
1645
|
-
return false;
|
|
1159
|
+
class AngularHasuraGraphQLModule {
|
|
1160
|
+
static initializeApp(options) {
|
|
1161
|
+
return {
|
|
1162
|
+
ngModule: AngularHasuraGraphQLModule,
|
|
1163
|
+
providers: [{ provide: HASURA_OPTIONS, useValue: options }],
|
|
1164
|
+
};
|
|
1646
1165
|
}
|
|
1647
1166
|
}
|
|
1648
|
-
|
|
1649
|
-
|
|
1650
|
-
i0.ɵɵ
|
|
1651
|
-
|
|
1652
|
-
|
|
1653
|
-
|
|
1654
|
-
|
|
1655
|
-
|
|
1167
|
+
AngularHasuraGraphQLModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: AngularHasuraGraphQLModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
1168
|
+
AngularHasuraGraphQLModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "15.1.0", ngImport: i0, type: AngularHasuraGraphQLModule });
|
|
1169
|
+
AngularHasuraGraphQLModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: AngularHasuraGraphQLModule, providers: [
|
|
1170
|
+
{
|
|
1171
|
+
provide: 'HasuraConfig',
|
|
1172
|
+
useFactory: (options, platformId) => ({
|
|
1173
|
+
endpoint: options.endpoint,
|
|
1174
|
+
authOptions: options.credentials,
|
|
1175
|
+
interceptors: {
|
|
1176
|
+
request: (request) => {
|
|
1177
|
+
console.log('request', request);
|
|
1178
|
+
},
|
|
1179
|
+
response: (response) => {
|
|
1180
|
+
console.log('response', response);
|
|
1181
|
+
},
|
|
1182
|
+
},
|
|
1183
|
+
}),
|
|
1184
|
+
deps: [HASURA_OPTIONS, PLATFORM_ID],
|
|
1185
|
+
},
|
|
1186
|
+
{
|
|
1187
|
+
provide: 'CategoryRepository',
|
|
1188
|
+
useExisting: CategoryHasuraGraphQLRepository,
|
|
1189
|
+
},
|
|
1190
|
+
{
|
|
1191
|
+
provide: CategoryHasuraGraphQLRepository,
|
|
1192
|
+
useFactory: (options, productRepository) => {
|
|
1193
|
+
return new CategoryHasuraGraphQLRepository({ endpoint: options.endpoint, authOptions: options.credentials }, productRepository);
|
|
1194
|
+
},
|
|
1195
|
+
deps: [HASURA_OPTIONS, ProductHasuraGraphQLRepository],
|
|
1196
|
+
},
|
|
1197
|
+
{
|
|
1198
|
+
provide: 'ProductRepository',
|
|
1199
|
+
useExisting: ProductHasuraGraphQLRepository,
|
|
1200
|
+
},
|
|
1201
|
+
{
|
|
1202
|
+
provide: ProductHasuraGraphQLRepository,
|
|
1203
|
+
useFactory: (options) => {
|
|
1204
|
+
return new ProductHasuraGraphQLRepository({ endpoint: options.endpoint, authOptions: options.credentials });
|
|
1205
|
+
},
|
|
1206
|
+
deps: [HASURA_OPTIONS],
|
|
1207
|
+
},
|
|
1208
|
+
{
|
|
1209
|
+
provide: 'VariantRepository',
|
|
1210
|
+
useExisting: VariantHasuraGraphQLRepository,
|
|
1211
|
+
},
|
|
1212
|
+
{
|
|
1213
|
+
provide: VariantHasuraGraphQLRepository,
|
|
1214
|
+
useFactory: (options) => {
|
|
1215
|
+
return new VariantHasuraGraphQLRepository({ endpoint: options.endpoint, authOptions: options.credentials });
|
|
1216
|
+
},
|
|
1217
|
+
deps: [HASURA_OPTIONS],
|
|
1218
|
+
},
|
|
1219
|
+
] });
|
|
1220
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: AngularHasuraGraphQLModule, decorators: [{
|
|
1221
|
+
type: NgModule,
|
|
1222
|
+
args: [{
|
|
1223
|
+
providers: [
|
|
1224
|
+
{
|
|
1225
|
+
provide: 'HasuraConfig',
|
|
1226
|
+
useFactory: (options, platformId) => ({
|
|
1227
|
+
endpoint: options.endpoint,
|
|
1228
|
+
authOptions: options.credentials,
|
|
1229
|
+
interceptors: {
|
|
1230
|
+
request: (request) => {
|
|
1231
|
+
console.log('request', request);
|
|
1232
|
+
},
|
|
1233
|
+
response: (response) => {
|
|
1234
|
+
console.log('response', response);
|
|
1235
|
+
},
|
|
1236
|
+
},
|
|
1237
|
+
}),
|
|
1238
|
+
deps: [HASURA_OPTIONS, PLATFORM_ID],
|
|
1239
|
+
},
|
|
1240
|
+
{
|
|
1241
|
+
provide: 'CategoryRepository',
|
|
1242
|
+
useExisting: CategoryHasuraGraphQLRepository,
|
|
1243
|
+
},
|
|
1244
|
+
{
|
|
1245
|
+
provide: CategoryHasuraGraphQLRepository,
|
|
1246
|
+
useFactory: (options, productRepository) => {
|
|
1247
|
+
return new CategoryHasuraGraphQLRepository({ endpoint: options.endpoint, authOptions: options.credentials }, productRepository);
|
|
1248
|
+
},
|
|
1249
|
+
deps: [HASURA_OPTIONS, ProductHasuraGraphQLRepository],
|
|
1250
|
+
},
|
|
1251
|
+
{
|
|
1252
|
+
provide: 'ProductRepository',
|
|
1253
|
+
useExisting: ProductHasuraGraphQLRepository,
|
|
1254
|
+
},
|
|
1255
|
+
{
|
|
1256
|
+
provide: ProductHasuraGraphQLRepository,
|
|
1257
|
+
useFactory: (options) => {
|
|
1258
|
+
return new ProductHasuraGraphQLRepository({ endpoint: options.endpoint, authOptions: options.credentials });
|
|
1259
|
+
},
|
|
1260
|
+
deps: [HASURA_OPTIONS],
|
|
1261
|
+
},
|
|
1262
|
+
{
|
|
1263
|
+
provide: 'VariantRepository',
|
|
1264
|
+
useExisting: VariantHasuraGraphQLRepository,
|
|
1265
|
+
},
|
|
1266
|
+
{
|
|
1267
|
+
provide: VariantHasuraGraphQLRepository,
|
|
1268
|
+
useFactory: (options) => {
|
|
1269
|
+
return new VariantHasuraGraphQLRepository({ endpoint: options.endpoint, authOptions: options.credentials });
|
|
1270
|
+
},
|
|
1271
|
+
deps: [HASURA_OPTIONS],
|
|
1272
|
+
},
|
|
1273
|
+
],
|
|
1274
|
+
}]
|
|
1275
|
+
}] });
|
|
1656
1276
|
|
|
1657
1277
|
class AngularConnectModule {
|
|
1658
1278
|
static initializeApp(defaultShop, options, nameOrConfig) {
|
|
@@ -1664,7 +1284,6 @@ class AngularConnectModule {
|
|
|
1664
1284
|
...(isNil(options?.firebase) ? [] : [{ provide: FIREBASE_APP_NAME, useValue: nameOrConfig }]),
|
|
1665
1285
|
...(isNil(options?.elasticSearch) ? [] : [{ provide: ES_CONFIG, useValue: options.elasticSearch }]),
|
|
1666
1286
|
...(isNil(options?.hasura) ? [] : [{ provide: HASURA_OPTIONS, useValue: options.hasura }]),
|
|
1667
|
-
...(isNil(options?.backendUrl) ? [] : [{ provide: BACKEND_URL, useValue: options.backendUrl }]),
|
|
1668
1287
|
],
|
|
1669
1288
|
};
|
|
1670
1289
|
}
|
|
@@ -1679,7 +1298,6 @@ AngularConnectModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", ve
|
|
|
1679
1298
|
CouponService,
|
|
1680
1299
|
HomeShopService,
|
|
1681
1300
|
OrderService,
|
|
1682
|
-
ShippingService,
|
|
1683
1301
|
], imports: [AngularFirebaseAuthModule, AngularFirestoreModule, AngularHasuraGraphQLModule] });
|
|
1684
1302
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: AngularConnectModule, decorators: [{
|
|
1685
1303
|
type: NgModule,
|
|
@@ -1693,66 +1311,13 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.0", ngImpor
|
|
|
1693
1311
|
CouponService,
|
|
1694
1312
|
HomeShopService,
|
|
1695
1313
|
OrderService,
|
|
1696
|
-
ShippingService,
|
|
1697
1314
|
],
|
|
1698
1315
|
}]
|
|
1699
1316
|
}] });
|
|
1700
1317
|
|
|
1701
|
-
class CatalogService {
|
|
1702
|
-
constructor() {
|
|
1703
|
-
this.buildFilterQuery = (category, filters) => { };
|
|
1704
|
-
this.buildSortQuery = (sort) => {
|
|
1705
|
-
const query = {
|
|
1706
|
-
stock: 'desc',
|
|
1707
|
-
gender: 'asc',
|
|
1708
|
-
};
|
|
1709
|
-
return query;
|
|
1710
|
-
};
|
|
1711
|
-
this.buildLimitQuery = (options) => {
|
|
1712
|
-
const limit = options?.perPage || 20;
|
|
1713
|
-
return {
|
|
1714
|
-
limit,
|
|
1715
|
-
offset: ((options?.page || 1) - 1) * limit,
|
|
1716
|
-
};
|
|
1717
|
-
};
|
|
1718
|
-
}
|
|
1719
|
-
fetchProducts(category, options) {
|
|
1720
|
-
return {
|
|
1721
|
-
products: [],
|
|
1722
|
-
pages: 1,
|
|
1723
|
-
};
|
|
1724
|
-
}
|
|
1725
|
-
}
|
|
1726
|
-
|
|
1727
|
-
class CategoryService {
|
|
1728
|
-
fetchSubCategories(category) {
|
|
1729
|
-
return [];
|
|
1730
|
-
}
|
|
1731
|
-
fetchFilterOptions(category, filters) {
|
|
1732
|
-
return [];
|
|
1733
|
-
}
|
|
1734
|
-
}
|
|
1735
|
-
|
|
1736
|
-
var ProductSorts;
|
|
1737
|
-
(function (ProductSorts) {
|
|
1738
|
-
ProductSorts["MOST_RELEVANT"] = "most-relevant";
|
|
1739
|
-
ProductSorts["BEST_SELLER"] = "best-sellers";
|
|
1740
|
-
ProductSorts["BIGGEST_PRICE"] = "biggest-price";
|
|
1741
|
-
ProductSorts["LOWEST_PRICE"] = "lowest-price";
|
|
1742
|
-
ProductSorts["BIGGEST_DISCOUNT"] = "biggest-discount";
|
|
1743
|
-
ProductSorts["BEST_RATING"] = "best-rating";
|
|
1744
|
-
})(ProductSorts || (ProductSorts = {}));
|
|
1745
|
-
|
|
1746
|
-
class CategoryWithTree extends Category {
|
|
1747
|
-
}
|
|
1748
|
-
__decorate([
|
|
1749
|
-
Type(() => CategoryWithTree),
|
|
1750
|
-
__metadata("design:type", Array)
|
|
1751
|
-
], CategoryWithTree.prototype, "children", void 0);
|
|
1752
|
-
|
|
1753
1318
|
/**
|
|
1754
1319
|
* Generated bundle index. Do not edit.
|
|
1755
1320
|
*/
|
|
1756
1321
|
|
|
1757
|
-
export { AngularConnectModule, AngularFirebaseAuthModule, AngularFirestoreModule, AngularHasuraGraphQLModule, AuthService, CartService,
|
|
1322
|
+
export { AngularConnectModule, AngularFirebaseAuthModule, AngularFirestoreModule, AngularHasuraGraphQLModule, AuthService, CartService, CheckoutService, CheckoutSubscriptionService, CouponService, HomeShopService, OrderService };
|
|
1758
1323
|
//# sourceMappingURL=infrab4a-connect-angular.mjs.map
|