@infrab4a/connect-angular 4.0.0-beta.30 → 4.0.0-beta.31
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2020/angular-connect.module.mjs +1 -1
- package/esm2020/services/catalog/catalog.service.mjs +44 -10
- package/esm2020/services/catalog/category.service.mjs +29 -3
- package/fesm2015/infrab4a-connect-angular.mjs +71 -17
- package/fesm2015/infrab4a-connect-angular.mjs.map +1 -1
- package/fesm2020/infrab4a-connect-angular.mjs +70 -11
- package/fesm2020/infrab4a-connect-angular.mjs.map +1 -1
- package/package.json +2 -2
- package/services/catalog/catalog.service.d.ts +37 -11
- package/services/catalog/category.service.d.ts +5 -2
|
@@ -53,4 +53,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.0", ngImpor
|
|
|
53
53
|
],
|
|
54
54
|
}]
|
|
55
55
|
}] });
|
|
56
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
56
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYW5ndWxhci1jb25uZWN0Lm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3Byb2plY3RzL2Nvbm5lY3QtYW5ndWxhci9zcmMvYW5ndWxhci1jb25uZWN0Lm1vZHVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQXVCLFFBQVEsRUFBRSxNQUFNLGVBQWUsQ0FBQTtBQUU3RCxPQUFPLEVBQW1DLEtBQUssRUFBRSxNQUFNLG1CQUFtQixDQUFBO0FBRTFFLE9BQU8sRUFBRSx5QkFBeUIsRUFBRSxNQUFNLGdDQUFnQyxDQUFBO0FBQzFFLE9BQU8sRUFBRSxzQkFBc0IsRUFBRSxNQUFNLDRCQUE0QixDQUFBO0FBQ25FLE9BQU8sRUFBRSwwQkFBMEIsRUFBd0IsTUFBTSxpQ0FBaUMsQ0FBQTtBQUNsRyxPQUFPLEVBQUUsV0FBVyxFQUFFLFlBQVksRUFBRSxTQUFTLEVBQUUsaUJBQWlCLEVBQUUsZ0JBQWdCLEVBQUUsY0FBYyxFQUFFLE1BQU0sVUFBVSxDQUFBO0FBQ3BILE9BQU8sRUFDTCxXQUFXLEVBQ1gsV0FBVyxFQUNYLGNBQWMsRUFDZCxlQUFlLEVBQ2YsZUFBZSxFQUNmLDJCQUEyQixFQUMzQixhQUFhLEVBQ2IsZUFBZSxFQUNmLFlBQVksRUFDWixlQUFlLEdBQ2hCLE1BQU0sWUFBWSxDQUFBOztBQWtCbkIsTUFBTSxPQUFPLG9CQUFvQjtJQUMvQixNQUFNLENBQUMsYUFBYSxDQUNsQixXQUFrQixFQUNsQixPQUtDLEVBQ0QsWUFBeUM7UUFFekMsT0FBTztZQUNMLFFBQVEsRUFBRSxvQkFBb0I7WUFDOUIsU0FBUyxFQUFFO2dCQUNULEdBQUcsQ0FBQyxLQUFLLENBQUMsV0FBVyxDQUFDLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUMsQ0FBQyxFQUFFLE9BQU8sRUFBRSxZQUFZLEVBQUUsUUFBUSxFQUFFLFdBQVcsRUFBRSxDQUFDLENBQUM7Z0JBQ2pGLEdBQUcsQ0FBQyxLQUFLLENBQUMsT0FBTyxFQUFFLFFBQVEsQ0FBQyxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLENBQUMsRUFBRSxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsUUFBUSxFQUFFLE9BQU8sRUFBRSxRQUFRLEVBQUUsQ0FBQyxDQUFDO2dCQUNqRyxHQUFHLENBQUMsS0FBSyxDQUFDLE9BQU8sRUFBRSxRQUFRLENBQUMsQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQyxDQUFDLEVBQUUsT0FBTyxFQUFFLGlCQUFpQixFQUFFLFFBQVEsRUFBRSxZQUFZLEVBQUUsQ0FBQyxDQUFDO2dCQUM3RixHQUFHLENBQUMsS0FBSyxDQUFDLE9BQU8sRUFBRSxhQUFhLENBQUMsQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FBQyxDQUFDLEVBQUUsT0FBTyxFQUFFLFNBQVMsRUFBRSxRQUFRLEVBQUUsT0FBTyxDQUFDLGFBQWEsRUFBRSxDQUFDLENBQUM7Z0JBQ25HLEdBQUcsQ0FBQyxLQUFLLENBQUMsT0FBTyxFQUFFLE1BQU0sQ0FBQyxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFDLENBQUMsRUFBRSxPQUFPLEVBQUUsY0FBYyxFQUFFLFFBQVEsRUFBRSxPQUFPLENBQUMsTUFBTSxFQUFFLENBQUMsQ0FBQztnQkFDMUYsR0FBRyxDQUFDLEtBQUssQ0FBQyxPQUFPLEVBQUUsVUFBVSxDQUFDLENBQUMsQ0FBQyxDQUFDLEVBQUUsQ0FBQyxDQUFDLENBQUMsQ0FBQyxFQUFFLE9BQU8sRUFBRSxXQUFXLEVBQUUsUUFBUSxFQUFFLE9BQU8sQ0FBQyxVQUFVLEVBQUUsQ0FBQyxDQUFDO2FBQ2hHO1NBQ0YsQ0FBQTtJQUNILENBQUM7O2lIQXRCVSxvQkFBb0I7a0hBQXBCLG9CQUFvQixZQWRyQix5QkFBeUIsRUFBRSxzQkFBc0IsRUFBRSwwQkFBMEI7a0hBYzVFLG9CQUFvQixhQWJwQjtRQUNULFdBQVc7UUFDWCxXQUFXO1FBQ1gsY0FBYztRQUNkLGVBQWU7UUFDZixlQUFlO1FBQ2YsMkJBQTJCO1FBQzNCLGFBQWE7UUFDYixlQUFlO1FBQ2YsWUFBWTtRQUNaLGVBQWU7S0FDaEIsWUFaUyx5QkFBeUIsRUFBRSxzQkFBc0IsRUFBRSwwQkFBMEI7MkZBYzVFLG9CQUFvQjtrQkFmaEMsUUFBUTttQkFBQztvQkFDUixPQUFPLEVBQUUsQ0FBQyx5QkFBeUIsRUFBRSxzQkFBc0IsRUFBRSwwQkFBMEIsQ0FBQztvQkFDeEYsU0FBUyxFQUFFO3dCQUNULFdBQVc7d0JBQ1gsV0FBVzt3QkFDWCxjQUFjO3dCQUNkLGVBQWU7d0JBQ2YsZUFBZTt3QkFDZiwyQkFBMkI7d0JBQzNCLGFBQWE7d0JBQ2IsZUFBZTt3QkFDZixZQUFZO3dCQUNaLGVBQWU7cUJBQ2hCO2lCQUNGIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTW9kdWxlV2l0aFByb3ZpZGVycywgTmdNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJ1xuaW1wb3J0IHsgRmlyZWJhc2VPcHRpb25zIH0gZnJvbSAnQGFuZ3VsYXIvZmlyZS9hcHAnXG5pbXBvcnQgeyBBeGlvc0VsYXN0aWNTZWFyY2hDb25maWcsIFNob3BzLCBpc05pbCB9IGZyb20gJ0BpbmZyYWI0YS9jb25uZWN0J1xuXG5pbXBvcnQgeyBBbmd1bGFyRmlyZWJhc2VBdXRoTW9kdWxlIH0gZnJvbSAnLi9hbmd1bGFyLWZpcmViYXNlLWF1dGgubW9kdWxlJ1xuaW1wb3J0IHsgQW5ndWxhckZpcmVzdG9yZU1vZHVsZSB9IGZyb20gJy4vYW5ndWxhci1maXJlc3RvcmUubW9kdWxlJ1xuaW1wb3J0IHsgQW5ndWxhckhhc3VyYUdyYXBoUUxNb2R1bGUsIEhhc3VyYUdyYXBoUUxPcHRpb25zIH0gZnJvbSAnLi9hbmd1bGFyLWhhc3VyYS1ncmFwaHFsLm1vZHVsZSdcbmltcG9ydCB7IEJBQ0tFTkRfVVJMLCBERUZBVUxUX1NIT1AsIEVTX0NPTkZJRywgRklSRUJBU0VfQVBQX05BTUUsIEZJUkVCQVNFX09QVElPTlMsIEhBU1VSQV9PUFRJT05TIH0gZnJvbSAnLi9jb25zdHMnXG5pbXBvcnQge1xuICBBdXRoU2VydmljZSxcbiAgQ2FydFNlcnZpY2UsXG4gIENhdGFsb2dTZXJ2aWNlLFxuICBDYXRlZ29yeVNlcnZpY2UsXG4gIENoZWNrb3V0U2VydmljZSxcbiAgQ2hlY2tvdXRTdWJzY3JpcHRpb25TZXJ2aWNlLFxuICBDb3Vwb25TZXJ2aWNlLFxuICBIb21lU2hvcFNlcnZpY2UsXG4gIE9yZGVyU2VydmljZSxcbiAgU2hpcHBpbmdTZXJ2aWNlLFxufSBmcm9tICcuL3NlcnZpY2VzJ1xuaW1wb3J0IHsgRmlyZWJhc2VBcHBDb25maWcgfSBmcm9tICcuL3R5cGVzJ1xuXG5ATmdNb2R1bGUoe1xuICBpbXBvcnRzOiBbQW5ndWxhckZpcmViYXNlQXV0aE1vZHVsZSwgQW5ndWxhckZpcmVzdG9yZU1vZHVsZSwgQW5ndWxhckhhc3VyYUdyYXBoUUxNb2R1bGVdLFxuICBwcm92aWRlcnM6IFtcbiAgICBBdXRoU2VydmljZSxcbiAgICBDYXJ0U2VydmljZSxcbiAgICBDYXRhbG9nU2VydmljZSxcbiAgICBDYXRlZ29yeVNlcnZpY2UsXG4gICAgQ2hlY2tvdXRTZXJ2aWNlLFxuICAgIENoZWNrb3V0U3Vic2NyaXB0aW9uU2VydmljZSxcbiAgICBDb3Vwb25TZXJ2aWNlLFxuICAgIEhvbWVTaG9wU2VydmljZSxcbiAgICBPcmRlclNlcnZpY2UsXG4gICAgU2hpcHBpbmdTZXJ2aWNlLFxuICBdLFxufSlcbmV4cG9ydCBjbGFzcyBBbmd1bGFyQ29ubmVjdE1vZHVsZSB7XG4gIHN0YXRpYyBpbml0aWFsaXplQXBwKFxuICAgIGRlZmF1bHRTaG9wOiBTaG9wcyxcbiAgICBvcHRpb25zOiB7XG4gICAgICBmaXJlYmFzZTogRmlyZWJhc2VPcHRpb25zXG4gICAgICBlbGFzdGljU2VhcmNoOiBBeGlvc0VsYXN0aWNTZWFyY2hDb25maWdcbiAgICAgIGhhc3VyYTogSGFzdXJhR3JhcGhRTE9wdGlvbnNcbiAgICAgIGJhY2tlbmRVcmw6IHN0cmluZ1xuICAgIH0sXG4gICAgbmFtZU9yQ29uZmlnPzogc3RyaW5nIHwgRmlyZWJhc2VBcHBDb25maWcsXG4gICk6IE1vZHVsZVdpdGhQcm92aWRlcnM8QW5ndWxhckNvbm5lY3RNb2R1bGU+IHtcbiAgICByZXR1cm4ge1xuICAgICAgbmdNb2R1bGU6IEFuZ3VsYXJDb25uZWN0TW9kdWxlLFxuICAgICAgcHJvdmlkZXJzOiBbXG4gICAgICAgIC4uLihpc05pbChkZWZhdWx0U2hvcCkgPyBbXSA6IFt7IHByb3ZpZGU6IERFRkFVTFRfU0hPUCwgdXNlVmFsdWU6IGRlZmF1bHRTaG9wIH1dKSxcbiAgICAgICAgLi4uKGlzTmlsKG9wdGlvbnM/LmZpcmViYXNlKSA/IFtdIDogW3sgcHJvdmlkZTogRklSRUJBU0VfT1BUSU9OUywgdXNlVmFsdWU6IG9wdGlvbnM/LmZpcmViYXNlIH1dKSxcbiAgICAgICAgLi4uKGlzTmlsKG9wdGlvbnM/LmZpcmViYXNlKSA/IFtdIDogW3sgcHJvdmlkZTogRklSRUJBU0VfQVBQX05BTUUsIHVzZVZhbHVlOiBuYW1lT3JDb25maWcgfV0pLFxuICAgICAgICAuLi4oaXNOaWwob3B0aW9ucz8uZWxhc3RpY1NlYXJjaCkgPyBbXSA6IFt7IHByb3ZpZGU6IEVTX0NPTkZJRywgdXNlVmFsdWU6IG9wdGlvbnMuZWxhc3RpY1NlYXJjaCB9XSksXG4gICAgICAgIC4uLihpc05pbChvcHRpb25zPy5oYXN1cmEpID8gW10gOiBbeyBwcm92aWRlOiBIQVNVUkFfT1BUSU9OUywgdXNlVmFsdWU6IG9wdGlvbnMuaGFzdXJhIH1dKSxcbiAgICAgICAgLi4uKGlzTmlsKG9wdGlvbnM/LmJhY2tlbmRVcmwpID8gW10gOiBbeyBwcm92aWRlOiBCQUNLRU5EX1VSTCwgdXNlVmFsdWU6IG9wdGlvbnMuYmFja2VuZFVybCB9XSksXG4gICAgICBdLFxuICAgIH1cbiAgfVxufVxuIl19
|
|
@@ -1,17 +1,41 @@
|
|
|
1
1
|
import { Inject, Injectable } from '@angular/core';
|
|
2
|
-
import { Where } from '@infrab4a/connect';
|
|
2
|
+
import { set, Where, } from '@infrab4a/connect';
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
4
|
export class CatalogService {
|
|
5
5
|
constructor(productRepository, categoryRepository) {
|
|
6
6
|
this.productRepository = productRepository;
|
|
7
7
|
this.categoryRepository = categoryRepository;
|
|
8
|
-
this.buildFilterQuery = (
|
|
8
|
+
this.buildFilterQuery = ({ clubDiscount, brands, prices, gender, }) => {
|
|
9
|
+
const filters = {};
|
|
10
|
+
if (clubDiscount?.length)
|
|
11
|
+
set(filters, 'price.subscriberDiscountPercentage', { operator: Where.IN, value: clubDiscount });
|
|
12
|
+
if (brands?.length)
|
|
13
|
+
filters.brand = { operator: Where.IN, value: brands };
|
|
14
|
+
if (gender?.length)
|
|
15
|
+
filters.tags = {
|
|
16
|
+
operator: Where.IN,
|
|
17
|
+
value: gender
|
|
18
|
+
.map((genderOptions) => genderOptions === 'female' ? 'feminino' : genderOptions === 'male' ? 'masculino' : null)
|
|
19
|
+
.filter(Boolean),
|
|
20
|
+
};
|
|
21
|
+
if (prices?.min || prices?.max)
|
|
22
|
+
set(filters, prices.subscriberPrice ? 'price.subscriberPrice' : 'price.price', [
|
|
23
|
+
...(prices.min ? [{ operator: Where.GTE, value: prices.min }] : []),
|
|
24
|
+
...(prices.max ? [{ operator: Where.LTE, value: prices.max }] : []),
|
|
25
|
+
]);
|
|
26
|
+
return filters;
|
|
27
|
+
};
|
|
9
28
|
this.buildSortQuery = (sort) => {
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
29
|
+
if (!sort || sort === 'most-relevant')
|
|
30
|
+
return {};
|
|
31
|
+
if (sort === 'best-sellers')
|
|
32
|
+
return { shoppingCount: 'desc' };
|
|
33
|
+
if (sort === 'biggest-price')
|
|
34
|
+
return { price: 'desc' };
|
|
35
|
+
if (sort === 'lowest-price')
|
|
36
|
+
return { price: 'asc' };
|
|
37
|
+
if (sort === 'best-rating')
|
|
38
|
+
return { rate: 'desc' };
|
|
15
39
|
};
|
|
16
40
|
this.buildLimitQuery = (options) => {
|
|
17
41
|
const limit = options?.perPage || 20;
|
|
@@ -22,7 +46,7 @@ export class CatalogService {
|
|
|
22
46
|
};
|
|
23
47
|
}
|
|
24
48
|
async fetchProducts(category, options) {
|
|
25
|
-
const productsIds = category.products
|
|
49
|
+
const productsIds = category.products?.length
|
|
26
50
|
? category.products
|
|
27
51
|
: await this.categoryRepository.get({ id: category.id }).then((categoryFound) => categoryFound.products);
|
|
28
52
|
const limits = this.buildLimitQuery(options);
|
|
@@ -31,10 +55,20 @@ export class CatalogService {
|
|
|
31
55
|
filters: {
|
|
32
56
|
id: { operator: Where.IN, value: productsIds },
|
|
33
57
|
published: true,
|
|
58
|
+
...this.buildFilterQuery(options?.filters || {}),
|
|
34
59
|
},
|
|
60
|
+
...(options?.sort ? { orderBy: this.buildSortQuery(options?.sort) } : {}),
|
|
35
61
|
limits,
|
|
62
|
+
options: { minimal: ['price'], maximum: ['price'] },
|
|
36
63
|
})
|
|
37
|
-
.then(({ data, count: total }) => ({
|
|
64
|
+
.then(({ data, count: total, maximum, minimal }) => ({
|
|
65
|
+
products: { data, total },
|
|
66
|
+
pages: Math.ceil(total / limits.limit),
|
|
67
|
+
prices: {
|
|
68
|
+
price: { min: minimal.price.price, max: maximum.price.price },
|
|
69
|
+
subscriberPrice: { min: minimal.price.subscriberPrice, max: maximum.price.subscriberPrice },
|
|
70
|
+
},
|
|
71
|
+
}));
|
|
38
72
|
}
|
|
39
73
|
}
|
|
40
74
|
CatalogService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: CatalogService, deps: [{ token: 'ProductRepository' }, { token: 'CategoryRepository' }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
@@ -48,4 +82,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.0", ngImpor
|
|
|
48
82
|
type: Inject,
|
|
49
83
|
args: ['CategoryRepository']
|
|
50
84
|
}] }]; } });
|
|
51
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
85
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"catalog.service.js","sourceRoot":"","sources":["../../../../../projects/connect-angular/src/services/catalog/catalog.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Inject, Injectable } from '@angular/core'\nimport {\n  Category,\n  CategoryRepository,\n  Product,\n  ProductGender,\n  ProductRepository,\n  RepositoryFindFielters,\n  RepositoryOrderBy,\n  set,\n  Where,\n} from '@infrab4a/connect'\nimport { ProductSort } from './types/product-sort.type'\n\ntype FetchProductsFilters = {\n  clubDiscount?: number[]\n  brands?: string[]\n  prices?: { min?: number; max?: number; subscriberPrice?: boolean }\n  gender?: ProductGender[]\n  customOptions?: string[]\n}\n\ntype FetchProductsOptions = { page?: number; perPage?: number; filters?: FetchProductsFilters; sort?: ProductSort }\n\ntype FetchProductsResponse = {\n  products: { data: Product[]; total: number }\n  pages: number\n  prices: {\n    price: { min: number; max: number }\n    subscriberPrice: { min: number; max: number }\n  }\n}\n\n@Injectable()\nexport class CatalogService {\n  constructor(\n    @Inject('ProductRepository') private readonly productRepository: ProductRepository,\n    @Inject('CategoryRepository') private readonly categoryRepository: CategoryRepository,\n  ) {}\n\n  async fetchProducts(category: Category, options?: FetchProductsOptions): Promise<FetchProductsResponse> {\n    const productsIds = category.products?.length\n      ? category.products\n      : await this.categoryRepository.get({ id: category.id }).then((categoryFound) => categoryFound.products)\n    const limits = this.buildLimitQuery(options)\n\n    return await this.productRepository\n      .find({\n        filters: {\n          id: { operator: Where.IN, value: productsIds },\n          published: true,\n          ...this.buildFilterQuery(options?.filters || {}),\n        },\n        ...(options?.sort ? { orderBy: this.buildSortQuery(options?.sort) } : {}),\n        limits,\n        options: { minimal: ['price'], maximum: ['price'] },\n      })\n      .then(({ data, count: total, maximum, minimal }) => ({\n        products: { data, total },\n        pages: Math.ceil(total / limits.limit),\n        prices: {\n          price: { min: minimal.price.price, max: maximum.price.price },\n          subscriberPrice: { min: minimal.price.subscriberPrice, max: maximum.price.subscriberPrice },\n        },\n      }))\n  }\n\n  private buildFilterQuery = ({\n    clubDiscount,\n    brands,\n    prices,\n    gender,\n  }: FetchProductsFilters): RepositoryFindFielters<Product> => {\n    const filters = {} as RepositoryFindFielters<Product>\n\n    if (clubDiscount?.length)\n      set(filters, 'price.subscriberDiscountPercentage', { operator: Where.IN, value: clubDiscount })\n    if (brands?.length) filters.brand = { operator: Where.IN, value: brands }\n    if (gender?.length)\n      filters.tags = {\n        operator: Where.IN,\n        value: gender\n          .map((genderOptions) =>\n            genderOptions === 'female' ? 'feminino' : genderOptions === 'male' ? 'masculino' : null,\n          )\n          .filter(Boolean),\n      }\n    if (prices?.min || prices?.max)\n      set(filters, prices.subscriberPrice ? 'price.subscriberPrice' : 'price.price', [\n        ...(prices.min ? [{ operator: Where.GTE, value: prices.min }] : []),\n        ...(prices.max ? [{ operator: Where.LTE, value: prices.max }] : []),\n      ])\n\n    return filters\n  }\n\n  private buildSortQuery = (sort: ProductSort): RepositoryOrderBy<Product> => {\n    if (!sort || sort === 'most-relevant') return {}\n\n    if (sort === 'best-sellers') return { shoppingCount: 'desc' }\n    if (sort === 'biggest-price') return { price: 'desc' }\n    if (sort === 'lowest-price') return { price: 'asc' }\n    if (sort === 'best-rating') return { rate: 'desc' }\n  }\n\n  private buildLimitQuery = (options: { page?: number; perPage?: number }): { limit?: number; offset?: number } => {\n    const limit = options?.perPage || 20\n\n    return {\n      limit,\n      offset: ((options?.page || 1) - 1) * limit,\n    }\n  }\n}\n"]}
|
|
@@ -1,9 +1,29 @@
|
|
|
1
1
|
import { Inject, Injectable } from '@angular/core';
|
|
2
|
+
import { Where, } from '@infrab4a/connect';
|
|
2
3
|
import * as i0 from "@angular/core";
|
|
3
4
|
export class CategoryService {
|
|
4
|
-
constructor(categoryFilterRepository) {
|
|
5
|
+
constructor(productRepository, categoryRepository, categoryFilterRepository) {
|
|
6
|
+
this.productRepository = productRepository;
|
|
7
|
+
this.categoryRepository = categoryRepository;
|
|
5
8
|
this.categoryFilterRepository = categoryFilterRepository;
|
|
6
9
|
}
|
|
10
|
+
async fetchBrands(category) {
|
|
11
|
+
const productsIds = category.products?.length
|
|
12
|
+
? category.products
|
|
13
|
+
: await this.categoryRepository.get({ id: category.id }).then((categoryFound) => categoryFound.products);
|
|
14
|
+
const brands = await this.productRepository
|
|
15
|
+
.find({
|
|
16
|
+
filters: {
|
|
17
|
+
id: { operator: Where.IN, value: productsIds },
|
|
18
|
+
published: true,
|
|
19
|
+
},
|
|
20
|
+
fields: ['brand'],
|
|
21
|
+
})
|
|
22
|
+
.then(({ data }) => Object.keys(data.map((product) => product.brand).reduce((brands, brand) => ({ ...brands, [brand]: true }), {})));
|
|
23
|
+
return this.categoryRepository
|
|
24
|
+
.find({ filters: { brandCategory: true }, orderBy: { name: 'asc' } })
|
|
25
|
+
.then(({ data }) => data.filter((category) => brands.includes(category.conditions.brand)));
|
|
26
|
+
}
|
|
7
27
|
async fetchSubCategories(category) {
|
|
8
28
|
return [];
|
|
9
29
|
}
|
|
@@ -18,12 +38,18 @@ export class CategoryService {
|
|
|
18
38
|
: categoryFilters;
|
|
19
39
|
}
|
|
20
40
|
}
|
|
21
|
-
CategoryService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: CategoryService, deps: [{ token: 'CategoryFilterRepository' }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
41
|
+
CategoryService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: CategoryService, deps: [{ token: 'ProductRepository' }, { token: 'CategoryRepository' }, { token: 'CategoryFilterRepository' }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
22
42
|
CategoryService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: CategoryService });
|
|
23
43
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: CategoryService, decorators: [{
|
|
24
44
|
type: Injectable
|
|
25
45
|
}], ctorParameters: function () { return [{ type: undefined, decorators: [{
|
|
46
|
+
type: Inject,
|
|
47
|
+
args: ['ProductRepository']
|
|
48
|
+
}] }, { type: undefined, decorators: [{
|
|
49
|
+
type: Inject,
|
|
50
|
+
args: ['CategoryRepository']
|
|
51
|
+
}] }, { type: undefined, decorators: [{
|
|
26
52
|
type: Inject,
|
|
27
53
|
args: ['CategoryFilterRepository']
|
|
28
54
|
}] }]; } });
|
|
29
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
55
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2F0ZWdvcnkuc2VydmljZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2Nvbm5lY3QtYW5ndWxhci9zcmMvc2VydmljZXMvY2F0YWxvZy9jYXRlZ29yeS5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxNQUFNLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFBO0FBQ2xELE9BQU8sRUFNTCxLQUFLLEdBQ04sTUFBTSxtQkFBbUIsQ0FBQTs7QUFJMUIsTUFBTSxPQUFPLGVBQWU7SUFDMUIsWUFDZ0QsaUJBQW9DLEVBQ25DLGtCQUFzQyxFQUNoQyx3QkFBa0Q7UUFGekQsc0JBQWlCLEdBQWpCLGlCQUFpQixDQUFtQjtRQUNuQyx1QkFBa0IsR0FBbEIsa0JBQWtCLENBQW9CO1FBQ2hDLDZCQUF3QixHQUF4Qix3QkFBd0IsQ0FBMEI7SUFDdEcsQ0FBQztJQUVKLEtBQUssQ0FBQyxXQUFXLENBQUMsUUFBa0I7UUFDbEMsTUFBTSxXQUFXLEdBQUcsUUFBUSxDQUFDLFFBQVEsRUFBRSxNQUFNO1lBQzNDLENBQUMsQ0FBQyxRQUFRLENBQUMsUUFBUTtZQUNuQixDQUFDLENBQUMsTUFBTSxJQUFJLENBQUMsa0JBQWtCLENBQUMsR0FBRyxDQUFDLEVBQUUsRUFBRSxFQUFFLFFBQVEsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDLElBQUksQ0FBQyxDQUFDLGFBQWEsRUFBRSxFQUFFLENBQUMsYUFBYSxDQUFDLFFBQVEsQ0FBQyxDQUFBO1FBQzFHLE1BQU0sTUFBTSxHQUFHLE1BQU0sSUFBSSxDQUFDLGlCQUFpQjthQUN4QyxJQUFJLENBQUM7WUFDSixPQUFPLEVBQUU7Z0JBQ1AsRUFBRSxFQUFFLEVBQUUsUUFBUSxFQUFFLEtBQUssQ0FBQyxFQUFFLEVBQUUsS0FBSyxFQUFFLFdBQVcsRUFBRTtnQkFDOUMsU0FBUyxFQUFFLElBQUk7YUFDaEI7WUFDRCxNQUFNLEVBQUUsQ0FBQyxPQUFPLENBQUM7U0FDbEIsQ0FBQzthQUNELElBQUksQ0FBQyxDQUFDLEVBQUUsSUFBSSxFQUFFLEVBQUUsRUFBRSxDQUNqQixNQUFNLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxHQUFHLENBQUMsQ0FBQyxPQUFPLEVBQUUsRUFBRSxDQUFDLE9BQU8sQ0FBQyxLQUFLLENBQUMsQ0FBQyxNQUFNLENBQUMsQ0FBQyxNQUFNLEVBQUUsS0FBSyxFQUFFLEVBQUUsQ0FBQyxDQUFDLEVBQUUsR0FBRyxNQUFNLEVBQUUsQ0FBQyxLQUFLLENBQUMsRUFBRSxJQUFJLEVBQUUsQ0FBQyxFQUFFLEVBQUUsQ0FBQyxDQUFDLENBQ2hILENBQUE7UUFFSCxPQUFPLElBQUksQ0FBQyxrQkFBa0I7YUFDM0IsSUFBSSxDQUFDLEVBQUUsT0FBTyxFQUFFLEVBQUUsYUFBYSxFQUFFLElBQUksRUFBRSxFQUFFLE9BQU8sRUFBRSxFQUFFLElBQUksRUFBRSxLQUFLLEVBQUUsRUFBRSxDQUFDO2FBQ3BFLElBQUksQ0FBQyxDQUFDLEVBQUUsSUFBSSxFQUFFLEVBQUUsRUFBRSxDQUFDLElBQUksQ0FBQyxNQUFNLENBQUMsQ0FBQyxRQUFRLEVBQUUsRUFBRSxDQUFDLE1BQU0sQ0FBQyxRQUFRLENBQUMsUUFBUSxDQUFDLFVBQVUsQ0FBQyxLQUFLLENBQUMsQ0FBQyxDQUFDLENBQUE7SUFDOUYsQ0FBQztJQUVELEtBQUssQ0FBQyxrQkFBa0IsQ0FBQyxRQUFrQjtRQUN6QyxPQUFPLEVBQUUsQ0FBQTtJQUNYLENBQUM7SUFFRCxLQUFLLENBQUMsa0JBQWtCLENBQUMsUUFBa0IsRUFBRSxPQUFrQjtRQUM3RCxNQUFNLGVBQWUsR0FDbkIsUUFBUSxDQUFDLE9BQU8sSUFBSSxRQUFRLENBQUMsT0FBTyxDQUFDLE1BQU07WUFDekMsQ0FBQyxDQUFDLFFBQVEsQ0FBQyxPQUFPO1lBQ2xCLENBQUMsQ0FBQyxNQUFNLElBQUksQ0FBQyx3QkFBd0I7aUJBQ2hDLElBQUksQ0FBQyxFQUFFLE9BQU8sRUFBRSxFQUFFLFVBQVUsRUFBRSxDQUFDLFFBQVEsQ0FBQyxFQUFFLEVBQUUsRUFBRSxDQUFDO2lCQUMvQyxJQUFJLENBQUMsQ0FBQyxFQUFFLElBQUksRUFBRSxFQUFFLEVBQUUsQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUMsY0FBYyxFQUFFLEVBQUUsQ0FBQyxjQUFjLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQTtRQUVoRixPQUFPLE9BQU8sRUFBRSxNQUFNO1lBQ3BCLENBQUMsQ0FBQyxlQUFlLENBQUMsTUFBTSxDQUNwQixDQUFDLGNBQWMsRUFBRSxFQUFFLENBQ2pCLENBQUMsT0FBTyxJQUFJLENBQUMsT0FBTyxDQUFDLE1BQU0sSUFBSSxjQUFjLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxDQUFDLE1BQU0sRUFBRSxFQUFFLENBQUMsT0FBTyxDQUFDLFFBQVEsQ0FBQyxNQUFNLENBQUMsRUFBRSxDQUFDLENBQUMsQ0FDdEc7WUFDSCxDQUFDLENBQUMsZUFBZSxDQUFBO0lBQ3JCLENBQUM7OzRHQTlDVSxlQUFlLGtCQUVoQixtQkFBbUIsYUFDbkIsb0JBQW9CLGFBQ3BCLDBCQUEwQjtnSEFKekIsZUFBZTsyRkFBZixlQUFlO2tCQUQzQixVQUFVOzswQkFHTixNQUFNOzJCQUFDLG1CQUFtQjs7MEJBQzFCLE1BQU07MkJBQUMsb0JBQW9COzswQkFDM0IsTUFBTTsyQkFBQywwQkFBMEIiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBJbmplY3QsIEluamVjdGFibGUgfSBmcm9tICdAYW5ndWxhci9jb3JlJ1xuaW1wb3J0IHtcbiAgQ2F0ZWdvcnksXG4gIENhdGVnb3J5RmlsdGVyUmVwb3NpdG9yeSxcbiAgQ2F0ZWdvcnlSZXBvc2l0b3J5LFxuICBGaWx0ZXIsXG4gIFByb2R1Y3RSZXBvc2l0b3J5LFxuICBXaGVyZSxcbn0gZnJvbSAnQGluZnJhYjRhL2Nvbm5lY3QnXG5pbXBvcnQgeyBDYXRlZ29yeVdpdGhUcmVlIH0gZnJvbSAnLi9tb2RlbHMnXG5cbkBJbmplY3RhYmxlKClcbmV4cG9ydCBjbGFzcyBDYXRlZ29yeVNlcnZpY2Uge1xuICBjb25zdHJ1Y3RvcihcbiAgICBASW5qZWN0KCdQcm9kdWN0UmVwb3NpdG9yeScpIHByaXZhdGUgcmVhZG9ubHkgcHJvZHVjdFJlcG9zaXRvcnk6IFByb2R1Y3RSZXBvc2l0b3J5LFxuICAgIEBJbmplY3QoJ0NhdGVnb3J5UmVwb3NpdG9yeScpIHByaXZhdGUgcmVhZG9ubHkgY2F0ZWdvcnlSZXBvc2l0b3J5OiBDYXRlZ29yeVJlcG9zaXRvcnksXG4gICAgQEluamVjdCgnQ2F0ZWdvcnlGaWx0ZXJSZXBvc2l0b3J5JykgcHJpdmF0ZSByZWFkb25seSBjYXRlZ29yeUZpbHRlclJlcG9zaXRvcnk6IENhdGVnb3J5RmlsdGVyUmVwb3NpdG9yeSxcbiAgKSB7fVxuXG4gIGFzeW5jIGZldGNoQnJhbmRzKGNhdGVnb3J5OiBDYXRlZ29yeSk6IFByb21pc2U8Q2F0ZWdvcnlbXT4ge1xuICAgIGNvbnN0IHByb2R1Y3RzSWRzID0gY2F0ZWdvcnkucHJvZHVjdHM/Lmxlbmd0aFxuICAgICAgPyBjYXRlZ29yeS5wcm9kdWN0c1xuICAgICAgOiBhd2FpdCB0aGlzLmNhdGVnb3J5UmVwb3NpdG9yeS5nZXQoeyBpZDogY2F0ZWdvcnkuaWQgfSkudGhlbigoY2F0ZWdvcnlGb3VuZCkgPT4gY2F0ZWdvcnlGb3VuZC5wcm9kdWN0cylcbiAgICBjb25zdCBicmFuZHMgPSBhd2FpdCB0aGlzLnByb2R1Y3RSZXBvc2l0b3J5XG4gICAgICAuZmluZCh7XG4gICAgICAgIGZpbHRlcnM6IHtcbiAgICAgICAgICBpZDogeyBvcGVyYXRvcjogV2hlcmUuSU4sIHZhbHVlOiBwcm9kdWN0c0lkcyB9LFxuICAgICAgICAgIHB1Ymxpc2hlZDogdHJ1ZSxcbiAgICAgICAgfSxcbiAgICAgICAgZmllbGRzOiBbJ2JyYW5kJ10sXG4gICAgICB9KVxuICAgICAgLnRoZW4oKHsgZGF0YSB9KSA9PlxuICAgICAgICBPYmplY3Qua2V5cyhkYXRhLm1hcCgocHJvZHVjdCkgPT4gcHJvZHVjdC5icmFuZCkucmVkdWNlKChicmFuZHMsIGJyYW5kKSA9PiAoeyAuLi5icmFuZHMsIFticmFuZF06IHRydWUgfSksIHt9KSksXG4gICAgICApXG5cbiAgICByZXR1cm4gdGhpcy5jYXRlZ29yeVJlcG9zaXRvcnlcbiAgICAgIC5maW5kKHsgZmlsdGVyczogeyBicmFuZENhdGVnb3J5OiB0cnVlIH0sIG9yZGVyQnk6IHsgbmFtZTogJ2FzYycgfSB9KVxuICAgICAgLnRoZW4oKHsgZGF0YSB9KSA9PiBkYXRhLmZpbHRlcigoY2F0ZWdvcnkpID0+IGJyYW5kcy5pbmNsdWRlcyhjYXRlZ29yeS5jb25kaXRpb25zLmJyYW5kKSkpXG4gIH1cblxuICBhc3luYyBmZXRjaFN1YkNhdGVnb3JpZXMoY2F0ZWdvcnk6IENhdGVnb3J5KTogUHJvbWlzZTxDYXRlZ29yeVdpdGhUcmVlW10+IHtcbiAgICByZXR1cm4gW11cbiAgfVxuXG4gIGFzeW5jIGZldGNoRmlsdGVyT3B0aW9ucyhjYXRlZ29yeTogQ2F0ZWdvcnksIGZpbHRlcnM/OiBzdHJpbmdbXSk6IFByb21pc2U8RmlsdGVyW10+IHtcbiAgICBjb25zdCBjYXRlZ29yeUZpbHRlcnMgPVxuICAgICAgY2F0ZWdvcnkuZmlsdGVycyAmJiBjYXRlZ29yeS5maWx0ZXJzLmxlbmd0aFxuICAgICAgICA/IGNhdGVnb3J5LmZpbHRlcnNcbiAgICAgICAgOiBhd2FpdCB0aGlzLmNhdGVnb3J5RmlsdGVyUmVwb3NpdG9yeVxuICAgICAgICAgICAgLmZpbmQoeyBmaWx0ZXJzOiB7IGNhdGVnb3J5SWQ6ICtjYXRlZ29yeS5pZCB9IH0pXG4gICAgICAgICAgICAudGhlbigoeyBkYXRhIH0pID0+IGRhdGEubWFwKChjYXRlZ29yeUZpbHRlcikgPT4gY2F0ZWdvcnlGaWx0ZXIuZmlsdGVyKSlcblxuICAgIHJldHVybiBmaWx0ZXJzPy5sZW5ndGhcbiAgICAgID8gY2F0ZWdvcnlGaWx0ZXJzLmZpbHRlcihcbiAgICAgICAgICAoY2F0ZWdvcnlGaWx0ZXIpID0+XG4gICAgICAgICAgICAhZmlsdGVycyB8fCAhZmlsdGVycy5sZW5ndGggfHwgY2F0ZWdvcnlGaWx0ZXIub3B0aW9ucy5zb21lKChvcHRpb24pID0+IGZpbHRlcnMuaW5jbHVkZXMob3B0aW9uLmlkKSksXG4gICAgICAgIClcbiAgICAgIDogY2F0ZWdvcnlGaWx0ZXJzXG4gIH1cbn1cbiJdfQ==
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import * as i0 from '@angular/core';
|
|
2
2
|
import { InjectionToken, NgModule, PLATFORM_ID, Injectable, Inject } from '@angular/core';
|
|
3
3
|
import * as i3 from '@infrab4a/connect';
|
|
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, Category, CheckoutSubscription, Product, RequiredArgumentError, add, Order } from '@infrab4a/connect';
|
|
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, set, Category, CheckoutSubscription, Product, RequiredArgumentError, add, Order } from '@infrab4a/connect';
|
|
5
5
|
import * as i1 from '@angular/fire/app';
|
|
6
6
|
import { provideFirebaseApp, initializeApp } from '@angular/fire/app';
|
|
7
7
|
import * as i1$1 from '@angular/fire/auth';
|
|
@@ -1421,13 +1421,37 @@ class CatalogService {
|
|
|
1421
1421
|
constructor(productRepository, categoryRepository) {
|
|
1422
1422
|
this.productRepository = productRepository;
|
|
1423
1423
|
this.categoryRepository = categoryRepository;
|
|
1424
|
-
this.buildFilterQuery = (
|
|
1424
|
+
this.buildFilterQuery = ({ clubDiscount, brands, prices, gender, }) => {
|
|
1425
|
+
const filters = {};
|
|
1426
|
+
if (clubDiscount === null || clubDiscount === void 0 ? void 0 : clubDiscount.length)
|
|
1427
|
+
set(filters, 'price.subscriberDiscountPercentage', { operator: Where.IN, value: clubDiscount });
|
|
1428
|
+
if (brands === null || brands === void 0 ? void 0 : brands.length)
|
|
1429
|
+
filters.brand = { operator: Where.IN, value: brands };
|
|
1430
|
+
if (gender === null || gender === void 0 ? void 0 : gender.length)
|
|
1431
|
+
filters.tags = {
|
|
1432
|
+
operator: Where.IN,
|
|
1433
|
+
value: gender
|
|
1434
|
+
.map((genderOptions) => genderOptions === 'female' ? 'feminino' : genderOptions === 'male' ? 'masculino' : null)
|
|
1435
|
+
.filter(Boolean),
|
|
1436
|
+
};
|
|
1437
|
+
if ((prices === null || prices === void 0 ? void 0 : prices.min) || (prices === null || prices === void 0 ? void 0 : prices.max))
|
|
1438
|
+
set(filters, prices.subscriberPrice ? 'price.subscriberPrice' : 'price.price', [
|
|
1439
|
+
...(prices.min ? [{ operator: Where.GTE, value: prices.min }] : []),
|
|
1440
|
+
...(prices.max ? [{ operator: Where.LTE, value: prices.max }] : []),
|
|
1441
|
+
]);
|
|
1442
|
+
return filters;
|
|
1443
|
+
};
|
|
1425
1444
|
this.buildSortQuery = (sort) => {
|
|
1426
|
-
|
|
1427
|
-
|
|
1428
|
-
|
|
1429
|
-
|
|
1430
|
-
|
|
1445
|
+
if (!sort || sort === 'most-relevant')
|
|
1446
|
+
return {};
|
|
1447
|
+
if (sort === 'best-sellers')
|
|
1448
|
+
return { shoppingCount: 'desc' };
|
|
1449
|
+
if (sort === 'biggest-price')
|
|
1450
|
+
return { price: 'desc' };
|
|
1451
|
+
if (sort === 'lowest-price')
|
|
1452
|
+
return { price: 'asc' };
|
|
1453
|
+
if (sort === 'best-rating')
|
|
1454
|
+
return { rate: 'desc' };
|
|
1431
1455
|
};
|
|
1432
1456
|
this.buildLimitQuery = (options) => {
|
|
1433
1457
|
const limit = (options === null || options === void 0 ? void 0 : options.perPage) || 20;
|
|
@@ -1438,20 +1462,22 @@ class CatalogService {
|
|
|
1438
1462
|
};
|
|
1439
1463
|
}
|
|
1440
1464
|
fetchProducts(category, options) {
|
|
1465
|
+
var _a;
|
|
1441
1466
|
return __awaiter(this, void 0, void 0, function* () {
|
|
1442
|
-
const productsIds = category.products.length
|
|
1467
|
+
const productsIds = ((_a = category.products) === null || _a === void 0 ? void 0 : _a.length)
|
|
1443
1468
|
? category.products
|
|
1444
1469
|
: yield this.categoryRepository.get({ id: category.id }).then((categoryFound) => categoryFound.products);
|
|
1445
1470
|
const limits = this.buildLimitQuery(options);
|
|
1446
1471
|
return yield this.productRepository
|
|
1447
|
-
.find({
|
|
1448
|
-
|
|
1449
|
-
|
|
1450
|
-
|
|
1472
|
+
.find(Object.assign(Object.assign({ filters: Object.assign({ id: { operator: Where.IN, value: productsIds }, published: true }, this.buildFilterQuery((options === null || options === void 0 ? void 0 : options.filters) || {})) }, ((options === null || options === void 0 ? void 0 : options.sort) ? { orderBy: this.buildSortQuery(options === null || options === void 0 ? void 0 : options.sort) } : {})), { limits, options: { minimal: ['price'], maximum: ['price'] } }))
|
|
1473
|
+
.then(({ data, count: total, maximum, minimal }) => ({
|
|
1474
|
+
products: { data, total },
|
|
1475
|
+
pages: Math.ceil(total / limits.limit),
|
|
1476
|
+
prices: {
|
|
1477
|
+
price: { min: minimal.price.price, max: maximum.price.price },
|
|
1478
|
+
subscriberPrice: { min: minimal.price.subscriberPrice, max: maximum.price.subscriberPrice },
|
|
1451
1479
|
},
|
|
1452
|
-
|
|
1453
|
-
})
|
|
1454
|
-
.then(({ data, count: total }) => ({ products: data, pages: Math.ceil(total / limits.limit), total }));
|
|
1480
|
+
}));
|
|
1455
1481
|
});
|
|
1456
1482
|
}
|
|
1457
1483
|
}
|
|
@@ -1470,9 +1496,31 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.0", ngImpor
|
|
|
1470
1496
|
} });
|
|
1471
1497
|
|
|
1472
1498
|
class CategoryService {
|
|
1473
|
-
constructor(categoryFilterRepository) {
|
|
1499
|
+
constructor(productRepository, categoryRepository, categoryFilterRepository) {
|
|
1500
|
+
this.productRepository = productRepository;
|
|
1501
|
+
this.categoryRepository = categoryRepository;
|
|
1474
1502
|
this.categoryFilterRepository = categoryFilterRepository;
|
|
1475
1503
|
}
|
|
1504
|
+
fetchBrands(category) {
|
|
1505
|
+
var _a;
|
|
1506
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
1507
|
+
const productsIds = ((_a = category.products) === null || _a === void 0 ? void 0 : _a.length)
|
|
1508
|
+
? category.products
|
|
1509
|
+
: yield this.categoryRepository.get({ id: category.id }).then((categoryFound) => categoryFound.products);
|
|
1510
|
+
const brands = yield this.productRepository
|
|
1511
|
+
.find({
|
|
1512
|
+
filters: {
|
|
1513
|
+
id: { operator: Where.IN, value: productsIds },
|
|
1514
|
+
published: true,
|
|
1515
|
+
},
|
|
1516
|
+
fields: ['brand'],
|
|
1517
|
+
})
|
|
1518
|
+
.then(({ data }) => Object.keys(data.map((product) => product.brand).reduce((brands, brand) => (Object.assign(Object.assign({}, brands), { [brand]: true })), {})));
|
|
1519
|
+
return this.categoryRepository
|
|
1520
|
+
.find({ filters: { brandCategory: true }, orderBy: { name: 'asc' } })
|
|
1521
|
+
.then(({ data }) => data.filter((category) => brands.includes(category.conditions.brand)));
|
|
1522
|
+
});
|
|
1523
|
+
}
|
|
1476
1524
|
fetchSubCategories(category) {
|
|
1477
1525
|
return __awaiter(this, void 0, void 0, function* () {
|
|
1478
1526
|
return [];
|
|
@@ -1491,12 +1539,18 @@ class CategoryService {
|
|
|
1491
1539
|
});
|
|
1492
1540
|
}
|
|
1493
1541
|
}
|
|
1494
|
-
CategoryService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: CategoryService, deps: [{ token: 'CategoryFilterRepository' }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
1542
|
+
CategoryService.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: CategoryService, deps: [{ token: 'ProductRepository' }, { token: 'CategoryRepository' }, { token: 'CategoryFilterRepository' }], target: i0.ɵɵFactoryTarget.Injectable });
|
|
1495
1543
|
CategoryService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: CategoryService });
|
|
1496
1544
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.1.0", ngImport: i0, type: CategoryService, decorators: [{
|
|
1497
1545
|
type: Injectable
|
|
1498
1546
|
}], ctorParameters: function () {
|
|
1499
1547
|
return [{ type: undefined, decorators: [{
|
|
1548
|
+
type: Inject,
|
|
1549
|
+
args: ['ProductRepository']
|
|
1550
|
+
}] }, { type: undefined, decorators: [{
|
|
1551
|
+
type: Inject,
|
|
1552
|
+
args: ['CategoryRepository']
|
|
1553
|
+
}] }, { type: undefined, decorators: [{
|
|
1500
1554
|
type: Inject,
|
|
1501
1555
|
args: ['CategoryFilterRepository']
|
|
1502
1556
|
}] }];
|