@infrab4a/connect-angular 4.0.0-beta.26 → 4.0.0-beta.28

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