@infrab4a/connect 4.0.0-beta.41 → 4.0.0-beta.43

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.
@@ -0,0 +1,29 @@
1
+ import { BaseModel, GenericIdentifier, ModelBaseStructure } from '../../generic/model';
2
+ import { Shops } from './enums';
3
+ import { Filter } from './filter';
4
+ import { CategoryCondition, CategoryMetadata } from './types';
5
+ export declare class CategoryBase<ChildCategory extends ModelBaseStructure<ChildCategory, Identifiers> = ModelBaseStructure<any, any>, Identifiers = ChildCategory['identifiersFields']> extends BaseModel<ChildCategory, Identifiers> {
6
+ id: string;
7
+ brandCategory: boolean;
8
+ brandLogo?: string;
9
+ name: string;
10
+ slug: string;
11
+ image?: string;
12
+ brandCategoryBanner?: string;
13
+ brandCategoryBannerMobile?: string;
14
+ description: string;
15
+ conditions?: CategoryCondition;
16
+ products?: string[];
17
+ createdAt?: Date;
18
+ updatedAt?: Date;
19
+ shop?: Shops;
20
+ shops?: string[];
21
+ published: boolean;
22
+ metadata: CategoryMetadata;
23
+ isCollection?: boolean;
24
+ reference?: string;
25
+ parentId?: number;
26
+ parent?: CategoryBase;
27
+ filters?: Filter[];
28
+ static get identifiersFields(): GenericIdentifier[];
29
+ }
@@ -0,0 +1,5 @@
1
+ import { GenericIdentifier } from '../../generic/model';
2
+ import { CategoryBase } from './category-base';
3
+ export declare class CategoryForProduct extends CategoryBase<CategoryForProduct, GenericIdentifier> {
4
+ static get identifiersFields(): GenericIdentifier[];
5
+ }
@@ -1,31 +1,7 @@
1
- import { BaseModel, GenericIdentifier } from '../../generic/model';
2
- import { Shops } from './enums';
3
- import { Filter } from './filter';
4
- import { Product } from './product';
5
- import { CategoryCondition, CategoryMetadata } from './types';
6
- export declare class Category extends BaseModel<Category> {
7
- id: string;
8
- brandCategory: boolean;
9
- brandLogo?: string;
10
- name: string;
11
- slug: string;
12
- image?: string;
13
- brandCategoryBanner?: string;
14
- brandCategoryBannerMobile?: string;
15
- description: string;
16
- conditions?: CategoryCondition;
17
- products?: string[];
18
- createdAt?: Date;
19
- updatedAt?: Date;
20
- shop?: Shops;
21
- shops?: string[];
22
- published: boolean;
23
- metadata: CategoryMetadata;
24
- isCollection?: boolean;
25
- reference?: string;
26
- parentId?: number;
27
- parent?: Category;
28
- filters?: Filter[];
29
- childrenProducts?: Product[];
1
+ import { GenericIdentifier } from '../../generic/model';
2
+ import { CategoryBase } from './category-base';
3
+ import { ProductForCategory } from './product-for-category';
4
+ export declare class Category extends CategoryBase<Category, GenericIdentifier> {
5
+ childrenProducts?: ProductForCategory[];
30
6
  static get identifiersFields(): GenericIdentifier[];
31
7
  }
@@ -1,12 +1,12 @@
1
1
  import { BaseModel } from '../../generic/model';
2
- import { Product } from './product';
2
+ import { ProductForKit } from './product-for-kit';
3
3
  declare type KitProductIdentifiers = 'productId' | 'kitProductId';
4
4
  export declare class KitProduct extends BaseModel<KitProduct, KitProductIdentifiers> {
5
5
  productId: string;
6
6
  kitProductId: string;
7
7
  quantity: number;
8
- kit: Product;
9
- product: Product;
8
+ kit: ProductForKit;
9
+ product: ProductForKit;
10
10
  static get identifiersFields(): KitProductIdentifiers[];
11
11
  }
12
12
  export {};
@@ -0,0 +1,40 @@
1
+ import { BaseModel, GenericIdentifier, ModelBaseStructure } from '../../generic/model';
2
+ import { ProductEvaluation, ProductGender, ProductMetadata, ProductReview, ShopDescription, ShopPrice, Stock } from './types';
3
+ import { Variant } from './variant';
4
+ export declare class ProductBase<ChildProduct extends ModelBaseStructure<ChildProduct, Identifiers>, Identifiers = ChildProduct['identifiersFields']> extends BaseModel<ChildProduct, Identifiers> {
5
+ id: string;
6
+ name: string;
7
+ slug: string;
8
+ description: ShopDescription;
9
+ sku: string;
10
+ price: ShopPrice;
11
+ hasVariants: boolean;
12
+ NCM: string;
13
+ EAN: string;
14
+ CEST: string;
15
+ weight: number;
16
+ stock: Stock;
17
+ costPrice: number;
18
+ images?: string[];
19
+ miniatures?: string[];
20
+ published: boolean;
21
+ createdAt?: Date;
22
+ updatedAt?: Date;
23
+ brand: string;
24
+ tags?: string[];
25
+ filters?: string[];
26
+ type?: string;
27
+ categories?: string[];
28
+ reviews?: ProductReview[];
29
+ variant?: Variant;
30
+ video?: string;
31
+ isKit?: boolean;
32
+ rate?: number;
33
+ gender?: ProductGender;
34
+ shoppingCount?: number;
35
+ metadata: ProductMetadata;
36
+ private reviewsTotal?;
37
+ get evaluation(): ProductEvaluation;
38
+ set evaluation(evaluation: ProductEvaluation);
39
+ static get identifiersFields(): GenericIdentifier[];
40
+ }
@@ -0,0 +1,7 @@
1
+ import { GenericIdentifier } from '../../generic/model';
2
+ import { KitProduct } from './kit-product';
3
+ import { ProductBase } from './product-base';
4
+ export declare class ProductForCategory extends ProductBase<ProductForCategory, GenericIdentifier> {
5
+ kitProducts?: KitProduct[];
6
+ static get identifiersFields(): GenericIdentifier[];
7
+ }
@@ -0,0 +1,7 @@
1
+ import { GenericIdentifier } from '../../generic/model';
2
+ import { CategoryForProduct } from './category-for-product';
3
+ import { ProductBase } from './product-base';
4
+ export declare class ProductForKit extends ProductBase<ProductForKit, GenericIdentifier> {
5
+ category: CategoryForProduct;
6
+ static get identifiersFields(): GenericIdentifier[];
7
+ }
@@ -1,44 +1,9 @@
1
- import { BaseModel, GenericIdentifier } from '../../generic/model';
2
- import { Category } from './category';
1
+ import { GenericIdentifier } from '../../generic/model';
2
+ import { CategoryForProduct } from './category-for-product';
3
3
  import { KitProduct } from './kit-product';
4
- import { ProductEvaluation, ProductGender, ProductMetadata, ProductReview, ShopDescription, ShopPrice, Stock } from './types';
5
- import { Variant } from './variant';
6
- export declare class Product extends BaseModel<Product> {
7
- id: string;
8
- name: string;
9
- slug: string;
10
- description: ShopDescription;
11
- sku: string;
12
- price: ShopPrice;
13
- hasVariants: boolean;
14
- NCM: string;
15
- EAN: string;
16
- CEST: string;
17
- weight: number;
18
- stock: Stock;
19
- costPrice: number;
20
- images?: string[];
21
- miniatures?: string[];
22
- published: boolean;
23
- createdAt?: Date;
24
- updatedAt?: Date;
25
- brand: string;
26
- tags?: string[];
27
- filters?: string[];
28
- type?: string;
29
- categories?: string[];
30
- reviews?: ProductReview[];
31
- variant?: Variant;
32
- video?: string;
33
- isKit?: boolean;
34
- rate?: number;
35
- gender?: ProductGender;
36
- shoppingCount?: number;
37
- metadata: ProductMetadata;
38
- category: Category;
4
+ import { ProductBase } from './product-base';
5
+ export declare class Product extends ProductBase<Product, GenericIdentifier> {
6
+ category: CategoryForProduct;
39
7
  kitProducts?: KitProduct[];
40
- private reviewsTotal?;
41
- get evaluation(): ProductEvaluation;
42
- set evaluation(evaluation: ProductEvaluation);
43
8
  static get identifiersFields(): GenericIdentifier[];
44
9
  }
@@ -0,0 +1,18 @@
1
+ import { __decorate, __metadata } from "tslib";
2
+ import { Type } from 'class-transformer';
3
+ import { BaseModel } from '../../generic/model';
4
+ import { Filter } from './filter';
5
+ export class CategoryBase extends BaseModel {
6
+ static get identifiersFields() {
7
+ return ['id'];
8
+ }
9
+ }
10
+ __decorate([
11
+ Type(() => CategoryBase),
12
+ __metadata("design:type", CategoryBase)
13
+ ], CategoryBase.prototype, "parent", void 0);
14
+ __decorate([
15
+ Type(() => Filter),
16
+ __metadata("design:type", Array)
17
+ ], CategoryBase.prototype, "filters", void 0);
18
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2F0ZWdvcnktYmFzZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2Nvbm5lY3Qvc3JjL2RvbWFpbi9jYXRhbG9nL21vZGVscy9jYXRlZ29yeS1iYXNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSxPQUFPLEVBQUUsSUFBSSxFQUFFLE1BQU0sbUJBQW1CLENBQUE7QUFDeEMsT0FBTyxFQUFFLFNBQVMsRUFBeUMsTUFBTSxxQkFBcUIsQ0FBQTtBQUV0RixPQUFPLEVBQUUsTUFBTSxFQUFFLE1BQU0sVUFBVSxDQUFBO0FBR2pDLE1BQU0sT0FBTyxZQUdYLFNBQVEsU0FBcUM7SUE0QjdDLE1BQU0sS0FBSyxpQkFBaUI7UUFDMUIsT0FBTyxDQUFDLElBQUksQ0FBQyxDQUFBO0lBQ2YsQ0FBQztDQUNGO0FBVEM7SUFBQyxJQUFJLENBQUMsR0FBRyxFQUFFLENBQUMsWUFBWSxDQUFDOzhCQUNoQixZQUFZOzRDQUFBO0FBRXJCO0lBQUMsSUFBSSxDQUFDLEdBQUcsRUFBRSxDQUFDLE1BQU0sQ0FBQzs7NkNBQ0QiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBUeXBlIH0gZnJvbSAnY2xhc3MtdHJhbnNmb3JtZXInXG5pbXBvcnQgeyBCYXNlTW9kZWwsIEdlbmVyaWNJZGVudGlmaWVyLCBNb2RlbEJhc2VTdHJ1Y3R1cmUgfSBmcm9tICcuLi8uLi9nZW5lcmljL21vZGVsJ1xuaW1wb3J0IHsgU2hvcHMgfSBmcm9tICcuL2VudW1zJ1xuaW1wb3J0IHsgRmlsdGVyIH0gZnJvbSAnLi9maWx0ZXInXG5pbXBvcnQgeyBDYXRlZ29yeUNvbmRpdGlvbiwgQ2F0ZWdvcnlNZXRhZGF0YSB9IGZyb20gJy4vdHlwZXMnXG5cbmV4cG9ydCBjbGFzcyBDYXRlZ29yeUJhc2U8XG4gIENoaWxkQ2F0ZWdvcnkgZXh0ZW5kcyBNb2RlbEJhc2VTdHJ1Y3R1cmU8Q2hpbGRDYXRlZ29yeSwgSWRlbnRpZmllcnM+ID0gTW9kZWxCYXNlU3RydWN0dXJlPGFueSwgYW55PixcbiAgSWRlbnRpZmllcnMgPSBDaGlsZENhdGVnb3J5WydpZGVudGlmaWVyc0ZpZWxkcyddLFxuPiBleHRlbmRzIEJhc2VNb2RlbDxDaGlsZENhdGVnb3J5LCBJZGVudGlmaWVycz4ge1xuICBpZDogc3RyaW5nXG4gIGJyYW5kQ2F0ZWdvcnk6IGJvb2xlYW5cbiAgYnJhbmRMb2dvPzogc3RyaW5nXG4gIG5hbWU6IHN0cmluZ1xuICBzbHVnOiBzdHJpbmdcbiAgaW1hZ2U/OiBzdHJpbmdcbiAgYnJhbmRDYXRlZ29yeUJhbm5lcj86IHN0cmluZ1xuICBicmFuZENhdGVnb3J5QmFubmVyTW9iaWxlPzogc3RyaW5nXG4gIGRlc2NyaXB0aW9uOiBzdHJpbmdcbiAgY29uZGl0aW9ucz86IENhdGVnb3J5Q29uZGl0aW9uXG4gIHByb2R1Y3RzPzogc3RyaW5nW11cbiAgY3JlYXRlZEF0PzogRGF0ZVxuICB1cGRhdGVkQXQ/OiBEYXRlXG4gIHNob3A/OiBTaG9wc1xuICBzaG9wcz86IHN0cmluZ1tdXG4gIHB1Ymxpc2hlZDogYm9vbGVhblxuICBtZXRhZGF0YTogQ2F0ZWdvcnlNZXRhZGF0YVxuICBpc0NvbGxlY3Rpb24/OiBib29sZWFuXG4gIHJlZmVyZW5jZT86IHN0cmluZ1xuICBwYXJlbnRJZD86IG51bWJlclxuXG4gIEBUeXBlKCgpID0+IENhdGVnb3J5QmFzZSlcbiAgcGFyZW50PzogQ2F0ZWdvcnlCYXNlXG5cbiAgQFR5cGUoKCkgPT4gRmlsdGVyKVxuICBmaWx0ZXJzPzogRmlsdGVyW11cblxuICBzdGF0aWMgZ2V0IGlkZW50aWZpZXJzRmllbGRzKCk6IEdlbmVyaWNJZGVudGlmaWVyW10ge1xuICAgIHJldHVybiBbJ2lkJ11cbiAgfVxufVxuIl19
@@ -0,0 +1,7 @@
1
+ import { CategoryBase } from './category-base';
2
+ export class CategoryForProduct extends CategoryBase {
3
+ static get identifiersFields() {
4
+ return ['id'];
5
+ }
6
+ }
7
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2F0ZWdvcnktZm9yLXByb2R1Y3QuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb25uZWN0L3NyYy9kb21haW4vY2F0YWxvZy9tb2RlbHMvY2F0ZWdvcnktZm9yLXByb2R1Y3QudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFBO0FBRTlDLE1BQU0sT0FBTyxrQkFBbUIsU0FBUSxZQUFtRDtJQUN6RixNQUFNLEtBQWMsaUJBQWlCO1FBQ25DLE9BQU8sQ0FBQyxJQUFJLENBQUMsQ0FBQTtJQUNmLENBQUM7Q0FDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEdlbmVyaWNJZGVudGlmaWVyIH0gZnJvbSAnLi4vLi4vZ2VuZXJpYy9tb2RlbCdcbmltcG9ydCB7IENhdGVnb3J5QmFzZSB9IGZyb20gJy4vY2F0ZWdvcnktYmFzZSdcblxuZXhwb3J0IGNsYXNzIENhdGVnb3J5Rm9yUHJvZHVjdCBleHRlbmRzIENhdGVnb3J5QmFzZTxDYXRlZ29yeUZvclByb2R1Y3QsIEdlbmVyaWNJZGVudGlmaWVyPiB7XG4gIHN0YXRpYyBvdmVycmlkZSBnZXQgaWRlbnRpZmllcnNGaWVsZHMoKTogR2VuZXJpY0lkZW50aWZpZXJbXSB7XG4gICAgcmV0dXJuIFsnaWQnXVxuICB9XG59XG4iXX0=
@@ -1,23 +1,14 @@
1
1
  import { __decorate, __metadata } from "tslib";
2
2
  import { Type } from 'class-transformer';
3
- import { BaseModel } from '../../generic/model';
4
- import { Filter } from './filter';
5
- import { Product } from './product';
6
- export class Category extends BaseModel {
3
+ import { CategoryBase } from './category-base';
4
+ import { ProductForCategory } from './product-for-category';
5
+ export class Category extends CategoryBase {
7
6
  static get identifiersFields() {
8
7
  return ['id'];
9
8
  }
10
9
  }
11
10
  __decorate([
12
- Type(() => Category),
13
- __metadata("design:type", Category)
14
- ], Category.prototype, "parent", void 0);
15
- __decorate([
16
- Type(() => Filter),
17
- __metadata("design:type", Array)
18
- ], Category.prototype, "filters", void 0);
19
- __decorate([
20
- Type(() => Product),
11
+ Type(() => ProductForCategory),
21
12
  __metadata("design:type", Array)
22
13
  ], Category.prototype, "childrenProducts", void 0);
23
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2F0ZWdvcnkuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb25uZWN0L3NyYy9kb21haW4vY2F0YWxvZy9tb2RlbHMvY2F0ZWdvcnkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLE9BQU8sRUFBRSxJQUFJLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQTtBQUN4QyxPQUFPLEVBQUUsU0FBUyxFQUFxQixNQUFNLHFCQUFxQixDQUFBO0FBRWxFLE9BQU8sRUFBRSxNQUFNLEVBQUUsTUFBTSxVQUFVLENBQUE7QUFDakMsT0FBTyxFQUFFLE9BQU8sRUFBRSxNQUFNLFdBQVcsQ0FBQTtBQUduQyxNQUFNLE9BQU8sUUFBUyxTQUFRLFNBQW1CO0lBK0IvQyxNQUFNLEtBQUssaUJBQWlCO1FBQzFCLE9BQU8sQ0FBQyxJQUFJLENBQUMsQ0FBQTtJQUNmLENBQUM7Q0FDRjtBQVpDO0lBQUMsSUFBSSxDQUFDLEdBQUcsRUFBRSxDQUFDLFFBQVEsQ0FBQzs4QkFDWixRQUFRO3dDQUFBO0FBRWpCO0lBQUMsSUFBSSxDQUFDLEdBQUcsRUFBRSxDQUFDLE1BQU0sQ0FBQzs7eUNBQ0Q7QUFFbEI7SUFBQyxJQUFJLENBQUMsR0FBRyxFQUFFLENBQUMsT0FBTyxDQUFDOztrREFDUSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFR5cGUgfSBmcm9tICdjbGFzcy10cmFuc2Zvcm1lcidcbmltcG9ydCB7IEJhc2VNb2RlbCwgR2VuZXJpY0lkZW50aWZpZXIgfSBmcm9tICcuLi8uLi9nZW5lcmljL21vZGVsJ1xuaW1wb3J0IHsgU2hvcHMgfSBmcm9tICcuL2VudW1zJ1xuaW1wb3J0IHsgRmlsdGVyIH0gZnJvbSAnLi9maWx0ZXInXG5pbXBvcnQgeyBQcm9kdWN0IH0gZnJvbSAnLi9wcm9kdWN0J1xuaW1wb3J0IHsgQ2F0ZWdvcnlDb25kaXRpb24sIENhdGVnb3J5TWV0YWRhdGEgfSBmcm9tICcuL3R5cGVzJ1xuXG5leHBvcnQgY2xhc3MgQ2F0ZWdvcnkgZXh0ZW5kcyBCYXNlTW9kZWw8Q2F0ZWdvcnk+IHtcbiAgaWQ6IHN0cmluZ1xuICBicmFuZENhdGVnb3J5OiBib29sZWFuXG4gIGJyYW5kTG9nbz86IHN0cmluZ1xuICBuYW1lOiBzdHJpbmdcbiAgc2x1Zzogc3RyaW5nXG4gIGltYWdlPzogc3RyaW5nXG4gIGJyYW5kQ2F0ZWdvcnlCYW5uZXI/OiBzdHJpbmdcbiAgYnJhbmRDYXRlZ29yeUJhbm5lck1vYmlsZT86IHN0cmluZ1xuICBkZXNjcmlwdGlvbjogc3RyaW5nXG4gIGNvbmRpdGlvbnM/OiBDYXRlZ29yeUNvbmRpdGlvblxuICBwcm9kdWN0cz86IHN0cmluZ1tdXG4gIGNyZWF0ZWRBdD86IERhdGVcbiAgdXBkYXRlZEF0PzogRGF0ZVxuICBzaG9wPzogU2hvcHNcbiAgc2hvcHM/OiBzdHJpbmdbXVxuICBwdWJsaXNoZWQ6IGJvb2xlYW5cbiAgbWV0YWRhdGE6IENhdGVnb3J5TWV0YWRhdGFcbiAgaXNDb2xsZWN0aW9uPzogYm9vbGVhblxuICByZWZlcmVuY2U/OiBzdHJpbmdcbiAgcGFyZW50SWQ/OiBudW1iZXJcblxuICBAVHlwZSgoKSA9PiBDYXRlZ29yeSlcbiAgcGFyZW50PzogQ2F0ZWdvcnlcblxuICBAVHlwZSgoKSA9PiBGaWx0ZXIpXG4gIGZpbHRlcnM/OiBGaWx0ZXJbXVxuXG4gIEBUeXBlKCgpID0+IFByb2R1Y3QpXG4gIGNoaWxkcmVuUHJvZHVjdHM/OiBQcm9kdWN0W11cblxuICBzdGF0aWMgZ2V0IGlkZW50aWZpZXJzRmllbGRzKCk6IEdlbmVyaWNJZGVudGlmaWVyW10ge1xuICAgIHJldHVybiBbJ2lkJ11cbiAgfVxufVxuIl19
14
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2F0ZWdvcnkuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb25uZWN0L3NyYy9kb21haW4vY2F0YWxvZy9tb2RlbHMvY2F0ZWdvcnkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLE9BQU8sRUFBRSxJQUFJLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQTtBQUV4QyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUE7QUFDOUMsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sd0JBQXdCLENBQUE7QUFFM0QsTUFBTSxPQUFPLFFBQVMsU0FBUSxZQUF5QztJQUlyRSxNQUFNLEtBQWMsaUJBQWlCO1FBQ25DLE9BQU8sQ0FBQyxJQUFJLENBQUMsQ0FBQTtJQUNmLENBQUM7Q0FDRjtBQU5DO0lBQUMsSUFBSSxDQUFDLEdBQUcsRUFBRSxDQUFDLGtCQUFrQixDQUFDOztrREFDUSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFR5cGUgfSBmcm9tICdjbGFzcy10cmFuc2Zvcm1lcidcbmltcG9ydCB7IEdlbmVyaWNJZGVudGlmaWVyIH0gZnJvbSAnLi4vLi4vZ2VuZXJpYy9tb2RlbCdcbmltcG9ydCB7IENhdGVnb3J5QmFzZSB9IGZyb20gJy4vY2F0ZWdvcnktYmFzZSdcbmltcG9ydCB7IFByb2R1Y3RGb3JDYXRlZ29yeSB9IGZyb20gJy4vcHJvZHVjdC1mb3ItY2F0ZWdvcnknXG5cbmV4cG9ydCBjbGFzcyBDYXRlZ29yeSBleHRlbmRzIENhdGVnb3J5QmFzZTxDYXRlZ29yeSwgR2VuZXJpY0lkZW50aWZpZXI+IHtcbiAgQFR5cGUoKCkgPT4gUHJvZHVjdEZvckNhdGVnb3J5KVxuICBjaGlsZHJlblByb2R1Y3RzPzogUHJvZHVjdEZvckNhdGVnb3J5W11cblxuICBzdGF0aWMgb3ZlcnJpZGUgZ2V0IGlkZW50aWZpZXJzRmllbGRzKCk6IEdlbmVyaWNJZGVudGlmaWVyW10ge1xuICAgIHJldHVybiBbJ2lkJ11cbiAgfVxufVxuIl19
@@ -1,18 +1,18 @@
1
1
  import { __decorate, __metadata } from "tslib";
2
2
  import { Type } from 'class-transformer';
3
3
  import { BaseModel } from '../../generic/model';
4
- import { Product } from './product';
4
+ import { ProductForKit } from './product-for-kit';
5
5
  export class KitProduct extends BaseModel {
6
6
  static get identifiersFields() {
7
7
  return ['productId', 'kitProductId'];
8
8
  }
9
9
  }
10
10
  __decorate([
11
- Type(() => Product),
12
- __metadata("design:type", Product)
11
+ Type(() => ProductForKit),
12
+ __metadata("design:type", ProductForKit)
13
13
  ], KitProduct.prototype, "kit", void 0);
14
14
  __decorate([
15
- Type(() => Product),
16
- __metadata("design:type", Product)
15
+ Type(() => ProductForKit),
16
+ __metadata("design:type", ProductForKit)
17
17
  ], KitProduct.prototype, "product", void 0);
18
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoia2l0LXByb2R1Y3QuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb25uZWN0L3NyYy9kb21haW4vY2F0YWxvZy9tb2RlbHMva2l0LXByb2R1Y3QudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLE9BQU8sRUFBRSxJQUFJLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQTtBQUN4QyxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0scUJBQXFCLENBQUE7QUFDL0MsT0FBTyxFQUFFLE9BQU8sRUFBRSxNQUFNLFdBQVcsQ0FBQTtBQUluQyxNQUFNLE9BQU8sVUFBVyxTQUFRLFNBQTRDO0lBVzFFLE1BQU0sS0FBSyxpQkFBaUI7UUFDMUIsT0FBTyxDQUFDLFdBQVcsRUFBRSxjQUFjLENBQUMsQ0FBQTtJQUN0QyxDQUFDO0NBQ0Y7QUFUQztJQUFDLElBQUksQ0FBQyxHQUFHLEVBQUUsQ0FBQyxPQUFPLENBQUM7OEJBQ2YsT0FBTzt1Q0FBQTtBQUVaO0lBQUMsSUFBSSxDQUFDLEdBQUcsRUFBRSxDQUFDLE9BQU8sQ0FBQzs4QkFDWCxPQUFPOzJDQUFBIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgVHlwZSB9IGZyb20gJ2NsYXNzLXRyYW5zZm9ybWVyJ1xuaW1wb3J0IHsgQmFzZU1vZGVsIH0gZnJvbSAnLi4vLi4vZ2VuZXJpYy9tb2RlbCdcbmltcG9ydCB7IFByb2R1Y3QgfSBmcm9tICcuL3Byb2R1Y3QnXG5cbnR5cGUgS2l0UHJvZHVjdElkZW50aWZpZXJzID0gJ3Byb2R1Y3RJZCcgfCAna2l0UHJvZHVjdElkJ1xuXG5leHBvcnQgY2xhc3MgS2l0UHJvZHVjdCBleHRlbmRzIEJhc2VNb2RlbDxLaXRQcm9kdWN0LCBLaXRQcm9kdWN0SWRlbnRpZmllcnM+IHtcbiAgcHJvZHVjdElkOiBzdHJpbmdcbiAga2l0UHJvZHVjdElkOiBzdHJpbmdcbiAgcXVhbnRpdHk6IG51bWJlclxuXG4gIEBUeXBlKCgpID0+IFByb2R1Y3QpXG4gIGtpdDogUHJvZHVjdFxuXG4gIEBUeXBlKCgpID0+IFByb2R1Y3QpXG4gIHByb2R1Y3Q6IFByb2R1Y3RcblxuICBzdGF0aWMgZ2V0IGlkZW50aWZpZXJzRmllbGRzKCk6IEtpdFByb2R1Y3RJZGVudGlmaWVyc1tdIHtcbiAgICByZXR1cm4gWydwcm9kdWN0SWQnLCAna2l0UHJvZHVjdElkJ11cbiAgfVxufVxuIl19
18
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoia2l0LXByb2R1Y3QuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb25uZWN0L3NyYy9kb21haW4vY2F0YWxvZy9tb2RlbHMva2l0LXByb2R1Y3QudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLE9BQU8sRUFBRSxJQUFJLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQTtBQUN4QyxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0scUJBQXFCLENBQUE7QUFDL0MsT0FBTyxFQUFFLGFBQWEsRUFBRSxNQUFNLG1CQUFtQixDQUFBO0FBSWpELE1BQU0sT0FBTyxVQUFXLFNBQVEsU0FBNEM7SUFXMUUsTUFBTSxLQUFLLGlCQUFpQjtRQUMxQixPQUFPLENBQUMsV0FBVyxFQUFFLGNBQWMsQ0FBQyxDQUFBO0lBQ3RDLENBQUM7Q0FDRjtBQVRDO0lBQUMsSUFBSSxDQUFDLEdBQUcsRUFBRSxDQUFDLGFBQWEsQ0FBQzs4QkFDckIsYUFBYTt1Q0FBQTtBQUVsQjtJQUFDLElBQUksQ0FBQyxHQUFHLEVBQUUsQ0FBQyxhQUFhLENBQUM7OEJBQ2pCLGFBQWE7MkNBQUEiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBUeXBlIH0gZnJvbSAnY2xhc3MtdHJhbnNmb3JtZXInXG5pbXBvcnQgeyBCYXNlTW9kZWwgfSBmcm9tICcuLi8uLi9nZW5lcmljL21vZGVsJ1xuaW1wb3J0IHsgUHJvZHVjdEZvcktpdCB9IGZyb20gJy4vcHJvZHVjdC1mb3Ita2l0J1xuXG50eXBlIEtpdFByb2R1Y3RJZGVudGlmaWVycyA9ICdwcm9kdWN0SWQnIHwgJ2tpdFByb2R1Y3RJZCdcblxuZXhwb3J0IGNsYXNzIEtpdFByb2R1Y3QgZXh0ZW5kcyBCYXNlTW9kZWw8S2l0UHJvZHVjdCwgS2l0UHJvZHVjdElkZW50aWZpZXJzPiB7XG4gIHByb2R1Y3RJZDogc3RyaW5nXG4gIGtpdFByb2R1Y3RJZDogc3RyaW5nXG4gIHF1YW50aXR5OiBudW1iZXJcblxuICBAVHlwZSgoKSA9PiBQcm9kdWN0Rm9yS2l0KVxuICBraXQ6IFByb2R1Y3RGb3JLaXRcblxuICBAVHlwZSgoKSA9PiBQcm9kdWN0Rm9yS2l0KVxuICBwcm9kdWN0OiBQcm9kdWN0Rm9yS2l0XG5cbiAgc3RhdGljIGdldCBpZGVudGlmaWVyc0ZpZWxkcygpOiBLaXRQcm9kdWN0SWRlbnRpZmllcnNbXSB7XG4gICAgcmV0dXJuIFsncHJvZHVjdElkJywgJ2tpdFByb2R1Y3RJZCddXG4gIH1cbn1cbiJdfQ==
@@ -0,0 +1,25 @@
1
+ import { BaseModel } from '../../generic/model';
2
+ export class ProductBase extends BaseModel {
3
+ get evaluation() {
4
+ return {
5
+ reviews: this.reviews,
6
+ count: this.reviewsTotal,
7
+ rating: this.rate,
8
+ };
9
+ }
10
+ set evaluation(evaluation) {
11
+ if (!evaluation) {
12
+ this.reviews = null;
13
+ this.reviewsTotal = null;
14
+ this.rate = null;
15
+ return;
16
+ }
17
+ this.reviews = evaluation.reviews || this.reviews;
18
+ this.reviewsTotal = evaluation.count || this.reviewsTotal;
19
+ this.rate = evaluation.rating || this.rate;
20
+ }
21
+ static get identifiersFields() {
22
+ return ['id'];
23
+ }
24
+ }
25
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvZHVjdC1iYXNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29ubmVjdC9zcmMvZG9tYWluL2NhdGFsb2cvbW9kZWxzL3Byb2R1Y3QtYmFzZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUF5QyxNQUFNLHFCQUFxQixDQUFBO0FBWXRGLE1BQU0sT0FBTyxXQUdYLFNBQVEsU0FBb0M7SUFtQzVDLElBQUksVUFBVTtRQUNaLE9BQU87WUFDTCxPQUFPLEVBQUUsSUFBSSxDQUFDLE9BQU87WUFDckIsS0FBSyxFQUFFLElBQUksQ0FBQyxZQUFZO1lBQ3hCLE1BQU0sRUFBRSxJQUFJLENBQUMsSUFBSTtTQUNsQixDQUFBO0lBQ0gsQ0FBQztJQUVELElBQUksVUFBVSxDQUFDLFVBQTZCO1FBQzFDLElBQUksQ0FBQyxVQUFVLEVBQUU7WUFDZixJQUFJLENBQUMsT0FBTyxHQUFHLElBQUksQ0FBQTtZQUNuQixJQUFJLENBQUMsWUFBWSxHQUFHLElBQUksQ0FBQTtZQUN4QixJQUFJLENBQUMsSUFBSSxHQUFHLElBQUksQ0FBQTtZQUVoQixPQUFNO1NBQ1A7UUFFRCxJQUFJLENBQUMsT0FBTyxHQUFHLFVBQVUsQ0FBQyxPQUFPLElBQUksSUFBSSxDQUFDLE9BQU8sQ0FBQTtRQUNqRCxJQUFJLENBQUMsWUFBWSxHQUFHLFVBQVUsQ0FBQyxLQUFLLElBQUksSUFBSSxDQUFDLFlBQVksQ0FBQTtRQUN6RCxJQUFJLENBQUMsSUFBSSxHQUFHLFVBQVUsQ0FBQyxNQUFNLElBQUksSUFBSSxDQUFDLElBQUksQ0FBQTtJQUM1QyxDQUFDO0lBRUQsTUFBTSxLQUFLLGlCQUFpQjtRQUMxQixPQUFPLENBQUMsSUFBSSxDQUFDLENBQUE7SUFDZixDQUFDO0NBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBCYXNlTW9kZWwsIEdlbmVyaWNJZGVudGlmaWVyLCBNb2RlbEJhc2VTdHJ1Y3R1cmUgfSBmcm9tICcuLi8uLi9nZW5lcmljL21vZGVsJ1xuaW1wb3J0IHtcbiAgUHJvZHVjdEV2YWx1YXRpb24sXG4gIFByb2R1Y3RHZW5kZXIsXG4gIFByb2R1Y3RNZXRhZGF0YSxcbiAgUHJvZHVjdFJldmlldyxcbiAgU2hvcERlc2NyaXB0aW9uLFxuICBTaG9wUHJpY2UsXG4gIFN0b2NrLFxufSBmcm9tICcuL3R5cGVzJ1xuaW1wb3J0IHsgVmFyaWFudCB9IGZyb20gJy4vdmFyaWFudCdcblxuZXhwb3J0IGNsYXNzIFByb2R1Y3RCYXNlPFxuICBDaGlsZFByb2R1Y3QgZXh0ZW5kcyBNb2RlbEJhc2VTdHJ1Y3R1cmU8Q2hpbGRQcm9kdWN0LCBJZGVudGlmaWVycz4sXG4gIElkZW50aWZpZXJzID0gQ2hpbGRQcm9kdWN0WydpZGVudGlmaWVyc0ZpZWxkcyddLFxuPiBleHRlbmRzIEJhc2VNb2RlbDxDaGlsZFByb2R1Y3QsIElkZW50aWZpZXJzPiB7XG4gIGlkOiBzdHJpbmdcbiAgbmFtZTogc3RyaW5nXG4gIHNsdWc6IHN0cmluZ1xuICBkZXNjcmlwdGlvbjogU2hvcERlc2NyaXB0aW9uXG4gIHNrdTogc3RyaW5nXG4gIHByaWNlOiBTaG9wUHJpY2VcbiAgaGFzVmFyaWFudHM6IGJvb2xlYW5cbiAgTkNNOiBzdHJpbmdcbiAgRUFOOiBzdHJpbmdcbiAgQ0VTVDogc3RyaW5nXG4gIHdlaWdodDogbnVtYmVyXG4gIHN0b2NrOiBTdG9ja1xuICBjb3N0UHJpY2U6IG51bWJlclxuICBpbWFnZXM/OiBzdHJpbmdbXVxuICBtaW5pYXR1cmVzPzogc3RyaW5nW11cbiAgcHVibGlzaGVkOiBib29sZWFuXG4gIGNyZWF0ZWRBdD86IERhdGVcbiAgdXBkYXRlZEF0PzogRGF0ZVxuICBicmFuZDogc3RyaW5nXG4gIHRhZ3M/OiBzdHJpbmdbXVxuICBmaWx0ZXJzPzogc3RyaW5nW11cbiAgdHlwZT86IHN0cmluZ1xuICBjYXRlZ29yaWVzPzogc3RyaW5nW11cbiAgcmV2aWV3cz86IFByb2R1Y3RSZXZpZXdbXVxuICB2YXJpYW50PzogVmFyaWFudFxuICB2aWRlbz86IHN0cmluZ1xuICBpc0tpdD86IGJvb2xlYW5cbiAgcmF0ZT86IG51bWJlclxuICBnZW5kZXI/OiBQcm9kdWN0R2VuZGVyXG4gIHNob3BwaW5nQ291bnQ/OiBudW1iZXJcbiAgbWV0YWRhdGE6IFByb2R1Y3RNZXRhZGF0YVxuXG4gIHByaXZhdGUgcmV2aWV3c1RvdGFsPzogbnVtYmVyXG5cbiAgZ2V0IGV2YWx1YXRpb24oKTogUHJvZHVjdEV2YWx1YXRpb24ge1xuICAgIHJldHVybiB7XG4gICAgICByZXZpZXdzOiB0aGlzLnJldmlld3MsXG4gICAgICBjb3VudDogdGhpcy5yZXZpZXdzVG90YWwsXG4gICAgICByYXRpbmc6IHRoaXMucmF0ZSxcbiAgICB9XG4gIH1cblxuICBzZXQgZXZhbHVhdGlvbihldmFsdWF0aW9uOiBQcm9kdWN0RXZhbHVhdGlvbikge1xuICAgIGlmICghZXZhbHVhdGlvbikge1xuICAgICAgdGhpcy5yZXZpZXdzID0gbnVsbFxuICAgICAgdGhpcy5yZXZpZXdzVG90YWwgPSBudWxsXG4gICAgICB0aGlzLnJhdGUgPSBudWxsXG5cbiAgICAgIHJldHVyblxuICAgIH1cblxuICAgIHRoaXMucmV2aWV3cyA9IGV2YWx1YXRpb24ucmV2aWV3cyB8fCB0aGlzLnJldmlld3NcbiAgICB0aGlzLnJldmlld3NUb3RhbCA9IGV2YWx1YXRpb24uY291bnQgfHwgdGhpcy5yZXZpZXdzVG90YWxcbiAgICB0aGlzLnJhdGUgPSBldmFsdWF0aW9uLnJhdGluZyB8fCB0aGlzLnJhdGVcbiAgfVxuXG4gIHN0YXRpYyBnZXQgaWRlbnRpZmllcnNGaWVsZHMoKTogR2VuZXJpY0lkZW50aWZpZXJbXSB7XG4gICAgcmV0dXJuIFsnaWQnXVxuICB9XG59XG4iXX0=
@@ -0,0 +1,14 @@
1
+ import { __decorate, __metadata } from "tslib";
2
+ import { Type } from 'class-transformer';
3
+ import { KitProduct } from './kit-product';
4
+ import { ProductBase } from './product-base';
5
+ export class ProductForCategory extends ProductBase {
6
+ static get identifiersFields() {
7
+ return ['id'];
8
+ }
9
+ }
10
+ __decorate([
11
+ Type(() => KitProduct),
12
+ __metadata("design:type", Array)
13
+ ], ProductForCategory.prototype, "kitProducts", void 0);
14
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvZHVjdC1mb3ItY2F0ZWdvcnkuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb25uZWN0L3NyYy9kb21haW4vY2F0YWxvZy9tb2RlbHMvcHJvZHVjdC1mb3ItY2F0ZWdvcnkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLE9BQU8sRUFBRSxJQUFJLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQTtBQUV4QyxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sZUFBZSxDQUFBO0FBQzFDLE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQTtBQUU1QyxNQUFNLE9BQU8sa0JBQW1CLFNBQVEsV0FBa0Q7SUFJeEYsTUFBTSxLQUFjLGlCQUFpQjtRQUNuQyxPQUFPLENBQUMsSUFBSSxDQUFDLENBQUE7SUFDZixDQUFDO0NBQ0Y7QUFOQztJQUFDLElBQUksQ0FBQyxHQUFHLEVBQUUsQ0FBQyxVQUFVLENBQUM7O3VEQUNHIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgVHlwZSB9IGZyb20gJ2NsYXNzLXRyYW5zZm9ybWVyJ1xuaW1wb3J0IHsgR2VuZXJpY0lkZW50aWZpZXIgfSBmcm9tICcuLi8uLi9nZW5lcmljL21vZGVsJ1xuaW1wb3J0IHsgS2l0UHJvZHVjdCB9IGZyb20gJy4va2l0LXByb2R1Y3QnXG5pbXBvcnQgeyBQcm9kdWN0QmFzZSB9IGZyb20gJy4vcHJvZHVjdC1iYXNlJ1xuXG5leHBvcnQgY2xhc3MgUHJvZHVjdEZvckNhdGVnb3J5IGV4dGVuZHMgUHJvZHVjdEJhc2U8UHJvZHVjdEZvckNhdGVnb3J5LCBHZW5lcmljSWRlbnRpZmllcj4ge1xuICBAVHlwZSgoKSA9PiBLaXRQcm9kdWN0KVxuICBraXRQcm9kdWN0cz86IEtpdFByb2R1Y3RbXVxuXG4gIHN0YXRpYyBvdmVycmlkZSBnZXQgaWRlbnRpZmllcnNGaWVsZHMoKTogR2VuZXJpY0lkZW50aWZpZXJbXSB7XG4gICAgcmV0dXJuIFsnaWQnXVxuICB9XG59XG4iXX0=
@@ -0,0 +1,14 @@
1
+ import { __decorate, __metadata } from "tslib";
2
+ import { Type } from 'class-transformer';
3
+ import { CategoryForProduct } from './category-for-product';
4
+ import { ProductBase } from './product-base';
5
+ export class ProductForKit extends ProductBase {
6
+ static get identifiersFields() {
7
+ return ['id'];
8
+ }
9
+ }
10
+ __decorate([
11
+ Type(() => CategoryForProduct),
12
+ __metadata("design:type", CategoryForProduct)
13
+ ], ProductForKit.prototype, "category", void 0);
14
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvZHVjdC1mb3Ita2l0LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29ubmVjdC9zcmMvZG9tYWluL2NhdGFsb2cvbW9kZWxzL3Byb2R1Y3QtZm9yLWtpdC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUEsT0FBTyxFQUFFLElBQUksRUFBRSxNQUFNLG1CQUFtQixDQUFBO0FBRXhDLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLHdCQUF3QixDQUFBO0FBQzNELE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQTtBQUU1QyxNQUFNLE9BQU8sYUFBYyxTQUFRLFdBQTZDO0lBSTlFLE1BQU0sS0FBYyxpQkFBaUI7UUFDbkMsT0FBTyxDQUFDLElBQUksQ0FBQyxDQUFBO0lBQ2YsQ0FBQztDQUNGO0FBTkM7SUFBQyxJQUFJLENBQUMsR0FBRyxFQUFFLENBQUMsa0JBQWtCLENBQUM7OEJBQ3JCLGtCQUFrQjsrQ0FBQSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFR5cGUgfSBmcm9tICdjbGFzcy10cmFuc2Zvcm1lcidcbmltcG9ydCB7IEdlbmVyaWNJZGVudGlmaWVyIH0gZnJvbSAnLi4vLi4vZ2VuZXJpYy9tb2RlbCdcbmltcG9ydCB7IENhdGVnb3J5Rm9yUHJvZHVjdCB9IGZyb20gJy4vY2F0ZWdvcnktZm9yLXByb2R1Y3QnXG5pbXBvcnQgeyBQcm9kdWN0QmFzZSB9IGZyb20gJy4vcHJvZHVjdC1iYXNlJ1xuXG5leHBvcnQgY2xhc3MgUHJvZHVjdEZvcktpdCBleHRlbmRzIFByb2R1Y3RCYXNlPFByb2R1Y3RGb3JLaXQsIEdlbmVyaWNJZGVudGlmaWVyPiB7XG4gIEBUeXBlKCgpID0+IENhdGVnb3J5Rm9yUHJvZHVjdClcbiAgY2F0ZWdvcnk6IENhdGVnb3J5Rm9yUHJvZHVjdFxuXG4gIHN0YXRpYyBvdmVycmlkZSBnZXQgaWRlbnRpZmllcnNGaWVsZHMoKTogR2VuZXJpY0lkZW50aWZpZXJbXSB7XG4gICAgcmV0dXJuIFsnaWQnXVxuICB9XG59XG4iXX0=
@@ -1,37 +1,19 @@
1
1
  import { __decorate, __metadata } from "tslib";
2
2
  import { Type } from 'class-transformer';
3
- import { BaseModel } from '../../generic/model';
4
- import { Category } from './category';
3
+ import { CategoryForProduct } from './category-for-product';
5
4
  import { KitProduct } from './kit-product';
6
- export class Product extends BaseModel {
7
- get evaluation() {
8
- return {
9
- reviews: this.reviews,
10
- count: this.reviewsTotal,
11
- rating: this.rate,
12
- };
13
- }
14
- set evaluation(evaluation) {
15
- if (!evaluation) {
16
- this.reviews = null;
17
- this.reviewsTotal = null;
18
- this.rate = null;
19
- return;
20
- }
21
- this.reviews = evaluation.reviews || this.reviews;
22
- this.reviewsTotal = evaluation.count || this.reviewsTotal;
23
- this.rate = evaluation.rating || this.rate;
24
- }
5
+ import { ProductBase } from './product-base';
6
+ export class Product extends ProductBase {
25
7
  static get identifiersFields() {
26
8
  return ['id'];
27
9
  }
28
10
  }
29
11
  __decorate([
30
- Type(() => Category),
31
- __metadata("design:type", Category)
12
+ Type(() => CategoryForProduct),
13
+ __metadata("design:type", CategoryForProduct)
32
14
  ], Product.prototype, "category", void 0);
33
15
  __decorate([
34
16
  Type(() => KitProduct),
35
17
  __metadata("design:type", Array)
36
18
  ], Product.prototype, "kitProducts", void 0);
37
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvZHVjdC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2Nvbm5lY3Qvc3JjL2RvbWFpbi9jYXRhbG9nL21vZGVscy9wcm9kdWN0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSxPQUFPLEVBQUUsSUFBSSxFQUFFLE1BQU0sbUJBQW1CLENBQUE7QUFDeEMsT0FBTyxFQUFFLFNBQVMsRUFBcUIsTUFBTSxxQkFBcUIsQ0FBQTtBQUVsRSxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sWUFBWSxDQUFBO0FBQ3JDLE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUE7QUFZMUMsTUFBTSxPQUFPLE9BQVEsU0FBUSxTQUFrQjtJQXlDN0MsSUFBSSxVQUFVO1FBQ1osT0FBTztZQUNMLE9BQU8sRUFBRSxJQUFJLENBQUMsT0FBTztZQUNyQixLQUFLLEVBQUUsSUFBSSxDQUFDLFlBQVk7WUFDeEIsTUFBTSxFQUFFLElBQUksQ0FBQyxJQUFJO1NBQ2xCLENBQUE7SUFDSCxDQUFDO0lBRUQsSUFBSSxVQUFVLENBQUMsVUFBNkI7UUFDMUMsSUFBSSxDQUFDLFVBQVUsRUFBRTtZQUNmLElBQUksQ0FBQyxPQUFPLEdBQUcsSUFBSSxDQUFBO1lBQ25CLElBQUksQ0FBQyxZQUFZLEdBQUcsSUFBSSxDQUFBO1lBQ3hCLElBQUksQ0FBQyxJQUFJLEdBQUcsSUFBSSxDQUFBO1lBRWhCLE9BQU07U0FDUDtRQUVELElBQUksQ0FBQyxPQUFPLEdBQUcsVUFBVSxDQUFDLE9BQU8sSUFBSSxJQUFJLENBQUMsT0FBTyxDQUFBO1FBQ2pELElBQUksQ0FBQyxZQUFZLEdBQUcsVUFBVSxDQUFDLEtBQUssSUFBSSxJQUFJLENBQUMsWUFBWSxDQUFBO1FBQ3pELElBQUksQ0FBQyxJQUFJLEdBQUcsVUFBVSxDQUFDLE1BQU0sSUFBSSxJQUFJLENBQUMsSUFBSSxDQUFBO0lBQzVDLENBQUM7SUFFRCxNQUFNLEtBQUssaUJBQWlCO1FBQzFCLE9BQU8sQ0FBQyxJQUFJLENBQUMsQ0FBQTtJQUNmLENBQUM7Q0FDRjtBQWpDQztJQUFDLElBQUksQ0FBQyxHQUFHLEVBQUUsQ0FBQyxRQUFRLENBQUM7OEJBQ1gsUUFBUTt5Q0FBQTtBQUVsQjtJQUFDLElBQUksQ0FBQyxHQUFHLEVBQUUsQ0FBQyxVQUFVLENBQUM7OzRDQUNHIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgVHlwZSB9IGZyb20gJ2NsYXNzLXRyYW5zZm9ybWVyJ1xuaW1wb3J0IHsgQmFzZU1vZGVsLCBHZW5lcmljSWRlbnRpZmllciB9IGZyb20gJy4uLy4uL2dlbmVyaWMvbW9kZWwnXG5cbmltcG9ydCB7IENhdGVnb3J5IH0gZnJvbSAnLi9jYXRlZ29yeSdcbmltcG9ydCB7IEtpdFByb2R1Y3QgfSBmcm9tICcuL2tpdC1wcm9kdWN0J1xuaW1wb3J0IHtcbiAgUHJvZHVjdEV2YWx1YXRpb24sXG4gIFByb2R1Y3RHZW5kZXIsXG4gIFByb2R1Y3RNZXRhZGF0YSxcbiAgUHJvZHVjdFJldmlldyxcbiAgU2hvcERlc2NyaXB0aW9uLFxuICBTaG9wUHJpY2UsXG4gIFN0b2NrLFxufSBmcm9tICcuL3R5cGVzJ1xuaW1wb3J0IHsgVmFyaWFudCB9IGZyb20gJy4vdmFyaWFudCdcblxuZXhwb3J0IGNsYXNzIFByb2R1Y3QgZXh0ZW5kcyBCYXNlTW9kZWw8UHJvZHVjdD4ge1xuICBpZDogc3RyaW5nXG4gIG5hbWU6IHN0cmluZ1xuICBzbHVnOiBzdHJpbmdcbiAgZGVzY3JpcHRpb246IFNob3BEZXNjcmlwdGlvblxuICBza3U6IHN0cmluZ1xuICBwcmljZTogU2hvcFByaWNlXG4gIGhhc1ZhcmlhbnRzOiBib29sZWFuXG4gIE5DTTogc3RyaW5nXG4gIEVBTjogc3RyaW5nXG4gIENFU1Q6IHN0cmluZ1xuICB3ZWlnaHQ6IG51bWJlclxuICBzdG9jazogU3RvY2tcbiAgY29zdFByaWNlOiBudW1iZXJcbiAgaW1hZ2VzPzogc3RyaW5nW11cbiAgbWluaWF0dXJlcz86IHN0cmluZ1tdXG4gIHB1Ymxpc2hlZDogYm9vbGVhblxuICBjcmVhdGVkQXQ/OiBEYXRlXG4gIHVwZGF0ZWRBdD86IERhdGVcbiAgYnJhbmQ6IHN0cmluZ1xuICB0YWdzPzogc3RyaW5nW11cbiAgZmlsdGVycz86IHN0cmluZ1tdXG4gIHR5cGU/OiBzdHJpbmdcbiAgY2F0ZWdvcmllcz86IHN0cmluZ1tdXG4gIHJldmlld3M/OiBQcm9kdWN0UmV2aWV3W11cbiAgdmFyaWFudD86IFZhcmlhbnRcbiAgdmlkZW8/OiBzdHJpbmdcbiAgaXNLaXQ/OiBib29sZWFuXG4gIHJhdGU/OiBudW1iZXJcbiAgZ2VuZGVyPzogUHJvZHVjdEdlbmRlclxuICBzaG9wcGluZ0NvdW50PzogbnVtYmVyXG4gIG1ldGFkYXRhOiBQcm9kdWN0TWV0YWRhdGFcblxuICBAVHlwZSgoKSA9PiBDYXRlZ29yeSlcbiAgY2F0ZWdvcnk6IENhdGVnb3J5XG5cbiAgQFR5cGUoKCkgPT4gS2l0UHJvZHVjdClcbiAga2l0UHJvZHVjdHM/OiBLaXRQcm9kdWN0W11cblxuICBwcml2YXRlIHJldmlld3NUb3RhbD86IG51bWJlclxuXG4gIGdldCBldmFsdWF0aW9uKCk6IFByb2R1Y3RFdmFsdWF0aW9uIHtcbiAgICByZXR1cm4ge1xuICAgICAgcmV2aWV3czogdGhpcy5yZXZpZXdzLFxuICAgICAgY291bnQ6IHRoaXMucmV2aWV3c1RvdGFsLFxuICAgICAgcmF0aW5nOiB0aGlzLnJhdGUsXG4gICAgfVxuICB9XG5cbiAgc2V0IGV2YWx1YXRpb24oZXZhbHVhdGlvbjogUHJvZHVjdEV2YWx1YXRpb24pIHtcbiAgICBpZiAoIWV2YWx1YXRpb24pIHtcbiAgICAgIHRoaXMucmV2aWV3cyA9IG51bGxcbiAgICAgIHRoaXMucmV2aWV3c1RvdGFsID0gbnVsbFxuICAgICAgdGhpcy5yYXRlID0gbnVsbFxuXG4gICAgICByZXR1cm5cbiAgICB9XG5cbiAgICB0aGlzLnJldmlld3MgPSBldmFsdWF0aW9uLnJldmlld3MgfHwgdGhpcy5yZXZpZXdzXG4gICAgdGhpcy5yZXZpZXdzVG90YWwgPSBldmFsdWF0aW9uLmNvdW50IHx8IHRoaXMucmV2aWV3c1RvdGFsXG4gICAgdGhpcy5yYXRlID0gZXZhbHVhdGlvbi5yYXRpbmcgfHwgdGhpcy5yYXRlXG4gIH1cblxuICBzdGF0aWMgZ2V0IGlkZW50aWZpZXJzRmllbGRzKCk6IEdlbmVyaWNJZGVudGlmaWVyW10ge1xuICAgIHJldHVybiBbJ2lkJ11cbiAgfVxufVxuIl19
19
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvZHVjdC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2Nvbm5lY3Qvc3JjL2RvbWFpbi9jYXRhbG9nL21vZGVscy9wcm9kdWN0LnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7QUFBQSxPQUFPLEVBQUUsSUFBSSxFQUFFLE1BQU0sbUJBQW1CLENBQUE7QUFFeEMsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sd0JBQXdCLENBQUE7QUFDM0QsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLGVBQWUsQ0FBQTtBQUMxQyxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sZ0JBQWdCLENBQUE7QUFFNUMsTUFBTSxPQUFPLE9BQVEsU0FBUSxXQUF1QztJQU9sRSxNQUFNLEtBQWMsaUJBQWlCO1FBQ25DLE9BQU8sQ0FBQyxJQUFJLENBQUMsQ0FBQTtJQUNmLENBQUM7Q0FDRjtBQVRDO0lBQUMsSUFBSSxDQUFDLEdBQUcsRUFBRSxDQUFDLGtCQUFrQixDQUFDOzhCQUNyQixrQkFBa0I7eUNBQUE7QUFFNUI7SUFBQyxJQUFJLENBQUMsR0FBRyxFQUFFLENBQUMsVUFBVSxDQUFDOzs0Q0FDRyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFR5cGUgfSBmcm9tICdjbGFzcy10cmFuc2Zvcm1lcidcbmltcG9ydCB7IEdlbmVyaWNJZGVudGlmaWVyIH0gZnJvbSAnLi4vLi4vZ2VuZXJpYy9tb2RlbCdcbmltcG9ydCB7IENhdGVnb3J5Rm9yUHJvZHVjdCB9IGZyb20gJy4vY2F0ZWdvcnktZm9yLXByb2R1Y3QnXG5pbXBvcnQgeyBLaXRQcm9kdWN0IH0gZnJvbSAnLi9raXQtcHJvZHVjdCdcbmltcG9ydCB7IFByb2R1Y3RCYXNlIH0gZnJvbSAnLi9wcm9kdWN0LWJhc2UnXG5cbmV4cG9ydCBjbGFzcyBQcm9kdWN0IGV4dGVuZHMgUHJvZHVjdEJhc2U8UHJvZHVjdCwgR2VuZXJpY0lkZW50aWZpZXI+IHtcbiAgQFR5cGUoKCkgPT4gQ2F0ZWdvcnlGb3JQcm9kdWN0KVxuICBjYXRlZ29yeTogQ2F0ZWdvcnlGb3JQcm9kdWN0XG5cbiAgQFR5cGUoKCkgPT4gS2l0UHJvZHVjdClcbiAga2l0UHJvZHVjdHM/OiBLaXRQcm9kdWN0W11cblxuICBzdGF0aWMgb3ZlcnJpZGUgZ2V0IGlkZW50aWZpZXJzRmllbGRzKCk6IEdlbmVyaWNJZGVudGlmaWVyW10ge1xuICAgIHJldHVybiBbJ2lkJ11cbiAgfVxufVxuIl19
@@ -19,7 +19,7 @@ export const withFindFirestore = (MixinBase) => {
19
19
  ], []);
20
20
  this.buildWhereSentence = (fieldName, options) => {
21
21
  if (this.isSubCollection(this) && fieldName === this.parentIdField)
22
- [];
22
+ return [];
23
23
  const value = options?.value || options;
24
24
  const object = {};
25
25
  set(object, fieldName, value);
@@ -107,4 +107,4 @@ export const withFindFirestore = (MixinBase) => {
107
107
  }
108
108
  };
109
109
  };
110
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"with-find-firestore.mixin.js","sourceRoot":"","sources":["../../../../../../../projects/connect/src/infra/firebase/firestore/mixins/with-find-firestore.mixin.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  CollectionReference,\n  doc,\n  getDoc,\n  getDocs,\n  limit,\n  orderBy,\n  query,\n  QueryConstraint,\n  startAfter,\n  startAt,\n  where,\n  WhereFilterOp,\n} from 'firebase/firestore'\n\nimport {\n  FindRepository,\n  ModelBaseStructure,\n  NonFunctionAndIdentifierPropertyNames,\n  NonFunctionPropertyNames,\n  RepositoryFindField,\n  RepositoryFindFielters,\n  RepositoryFindFieltersOptions,\n  RepositoryFindResult,\n  RepositoryLimitOptions,\n  RepositoryOrderBy,\n  Where,\n} from '../../../../domain'\nimport { is, isDate, isNil, isNumber, isObject, isString, MixinCtor, set } from '../../../../utils'\nimport { FirestoreFieldType } from '../enums'\nimport { FirestoreHelpers, FirestoreRepository } from '../types'\n\nexport const withFindFirestore = <\n  TBase extends ModelBaseStructure<TBase>,\n  TMixinBase extends MixinCtor<FirestoreRepository<TBase>>,\n>(\n  MixinBase: MixinCtor<FirestoreRepository<TBase> & FirestoreHelpers> & TMixinBase,\n): MixinCtor<FirestoreRepository<TBase> & InstanceType<TMixinBase> & FindRepository<TBase> & FirestoreHelpers, []> => {\n  const checkIfIsFilterOption = (filter: any): filter is RepositoryFindFieltersOptions<TBase, any> =>\n    !isNil(filter?.operator)\n  const getValueFromFilter = (filter: RepositoryFindField<TBase, any>): any => {\n    return checkIfIsFilterOption(filter) ? filter.value : filter\n  }\n  const getFinalValueFrom = (value: any) =>\n    isNumber(value) || isString(value) || isDate(value) || Array.isArray(value)\n      ? value\n      : Object.values(getFinalValueFrom)\n\n  return class FindFirestore extends MixinBase implements FindRepository<TBase> {\n    async find(\n      find: {\n        filters?: RepositoryFindFielters<TBase>\n        limits?: RepositoryLimitOptions<TBase>\n        orderBy?: RepositoryOrderBy<TBase>\n        options?: { enableCount?: boolean }\n      } = {},\n    ): Promise<RepositoryFindResult<TBase>> {\n      const collection: CollectionReference<TBase> = this.collection(this.buildCollectionPathForFind(find.filters))\n      const enableCount = find?.options?.enableCount ?? true\n      const intercepted = await this.interceptors?.request?.({ find })\n      const { filters, limits, orderBy } = intercepted.find || find\n      const queries = this.makeFirestoreWhere(filters || {})\n      const ordination = this.makeFirestoreOrderBy(filters, orderBy)\n      const offsets = await this.defineLimits(filters, limits)\n      const queryArgumments: QueryConstraint[] = [...queries, ...ordination, ...offsets]\n      const docs = await getDocs(query(collection, ...queryArgumments))\n      const data = docs.docs.map((doc) => doc.data())\n\n      return {\n        data: (await this.interceptors?.response?.(data, intercepted)) || data,\n        count: enableCount ? this.calculateCount(data, limits) : Infinity,\n      }\n    }\n\n    buildCollectionPathForFind(filters: RepositoryFindFielters<TBase>): string {\n      if (!this.isSubCollection(this)) return this.collectionName\n\n      const parentIdField = this.parentIdField as NonFunctionAndIdentifierPropertyNames<TBase>\n      const parentId = getValueFromFilter(filters?.[parentIdField])\n\n      return `${this.parentRepository.collectionName}/${parentId}/${this.collectionName}`\n    }\n\n    makeFirestoreWhere = (filter: RepositoryFindFielters<TBase>): QueryConstraint[] =>\n      Object.keys(filter).reduce(\n        (queries: QueryConstraint[], fieldName: string) => [\n          ...queries,\n          ...this.buildWhereSentence(fieldName, is(filter[fieldName as NonFunctionPropertyNames<TBase>])),\n        ],\n        [],\n      )\n\n    buildWhereSentence = (\n      fieldName: NonFunctionPropertyNames<TBase> | string,\n      options: RepositoryFindFieltersOptions<TBase, NonFunctionPropertyNames<TBase>>,\n    ): QueryConstraint[] => {\n      if (this.isSubCollection(this) && fieldName === this.parentIdField) []\n\n      const value = options?.value || options\n      const object = {}\n\n      set(object, fieldName, value)\n\n      const plainInstance = new this.model(object).toPlain()\n      const firestoreFieldName =\n        fieldName.toString().indexOf('.') > -1\n          ? fieldName.toString()\n          : Object.keys(plainInstance).find((key) => plainInstance[key])\n\n      if (options?.operator === Where.LIKE) {\n        if (\n          Array.isArray(options?.value) &&\n          (this.fields[firestoreFieldName as NonFunctionAndIdentifierPropertyNames<TBase>] ===\n            FirestoreFieldType.Array ||\n            !this.fields[firestoreFieldName as NonFunctionAndIdentifierPropertyNames<TBase>])\n        )\n          return [where(firestoreFieldName, 'array-contains-any', options.value)]\n\n        return [where(firestoreFieldName, '>=', options.value), where(firestoreFieldName, '<=', `${options.value}~`)]\n      }\n      if (\n        options?.operator === Where.IN &&\n        Array.isArray(options?.value) &&\n        (this.fields[firestoreFieldName as NonFunctionAndIdentifierPropertyNames<TBase>] === FirestoreFieldType.Array ||\n          !this.fields[firestoreFieldName as NonFunctionAndIdentifierPropertyNames<TBase>])\n      )\n        return [where(firestoreFieldName, 'array-contains', options.value)]\n      if (isObject(options) && isNil(options?.operator) && isNil(options?.value)) {\n        return Object.keys(options).reduce(\n          (queries, key) => [\n            ...queries,\n            ...this.buildWhereSentence(`${fieldName.toString()}.${key}`, is<Record<string, any>>(options)[key]),\n          ],\n          [],\n        )\n      }\n\n      return [where(firestoreFieldName, (options?.operator as WhereFilterOp) || '==', options?.value || options)]\n    }\n\n    makeFirestoreOrderBy = (\n      filters: RepositoryFindFielters<TBase>,\n      fieldsToOrderBy?: RepositoryOrderBy<TBase>,\n    ): QueryConstraint[] => {\n      const orderByKeys = Object.keys(fieldsToOrderBy || {})\n\n      if (!orderByKeys.length) return []\n\n      const filtersKeysWithUnordered = Object.keys(filters || {}).filter(\n        (filterKey) => !orderByKeys.includes(filterKey),\n      )\n\n      if (filtersKeysWithUnordered.length)\n        filtersKeysWithUnordered.forEach(\n          (filterKey) =>\n            (fieldsToOrderBy = {\n              ...(![Where.EQUALS].includes(\n                is<RepositoryFindFieltersOptions<TBase, NonFunctionPropertyNames<TBase>>>(\n                  filters[filterKey as NonFunctionPropertyNames<TBase>],\n                ).operator,\n              )\n                ? { [filterKey]: 'asc' }\n                : {}),\n              ...fieldsToOrderBy,\n            }),\n        )\n\n      return Object.keys(fieldsToOrderBy).map((fieldName) =>\n        orderBy(fieldName, fieldsToOrderBy[fieldName as NonFunctionPropertyNames<TBase>]),\n      )\n    }\n\n    async defineLimits(\n      filters: RepositoryFindFielters<TBase>,\n      limits: RepositoryLimitOptions<TBase>,\n    ): Promise<QueryConstraint[]> {\n      const queries = []\n\n      if (limits?.offset) {\n        if (this.model.isModel(limits.offset))\n          queries.push(\n            startAfter(\n              await getDoc(\n                doc(\n                  this.collection(this.buildCollectionPathForFind(filters)),\n                  Object.values(limits.offset.identifier).shift()?.toString(),\n                ),\n              ),\n            ),\n          )\n        else if (isNumber(limits.offset) || isString(limits.offset)) queries.push(startAt(limits.offset))\n      }\n      if (limits?.limit) queries.push(limit(limits.limit))\n\n      return queries\n    }\n\n    calculateCount(data: TBase[], limits: RepositoryLimitOptions<TBase>): number {\n      if (data.length <= 0) return 0\n      if (data.length < limits?.limit) return data.length\n\n      return Infinity\n    }\n  } as any\n}\n"]}
110
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"with-find-firestore.mixin.js","sourceRoot":"","sources":["../../../../../../../projects/connect/src/infra/firebase/firestore/mixins/with-find-firestore.mixin.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  CollectionReference,\n  doc,\n  getDoc,\n  getDocs,\n  limit,\n  orderBy,\n  query,\n  QueryConstraint,\n  startAfter,\n  startAt,\n  where,\n  WhereFilterOp,\n} from 'firebase/firestore'\n\nimport {\n  FindRepository,\n  ModelBaseStructure,\n  NonFunctionAndIdentifierPropertyNames,\n  NonFunctionPropertyNames,\n  RepositoryFindField,\n  RepositoryFindFielters,\n  RepositoryFindFieltersOptions,\n  RepositoryFindResult,\n  RepositoryLimitOptions,\n  RepositoryOrderBy,\n  Where,\n} from '../../../../domain'\nimport { is, isDate, isNil, isNumber, isObject, isString, MixinCtor, set } from '../../../../utils'\nimport { FirestoreFieldType } from '../enums'\nimport { FirestoreHelpers, FirestoreRepository } from '../types'\n\nexport const withFindFirestore = <\n  TBase extends ModelBaseStructure<TBase>,\n  TMixinBase extends MixinCtor<FirestoreRepository<TBase>>,\n>(\n  MixinBase: MixinCtor<FirestoreRepository<TBase> & FirestoreHelpers> & TMixinBase,\n): MixinCtor<FirestoreRepository<TBase> & InstanceType<TMixinBase> & FindRepository<TBase> & FirestoreHelpers, []> => {\n  const checkIfIsFilterOption = (filter: any): filter is RepositoryFindFieltersOptions<TBase, any> =>\n    !isNil(filter?.operator)\n  const getValueFromFilter = (filter: RepositoryFindField<TBase, any>): any => {\n    return checkIfIsFilterOption(filter) ? filter.value : filter\n  }\n  const getFinalValueFrom = (value: any) =>\n    isNumber(value) || isString(value) || isDate(value) || Array.isArray(value)\n      ? value\n      : Object.values(getFinalValueFrom)\n\n  return class FindFirestore extends MixinBase implements FindRepository<TBase> {\n    async find(\n      find: {\n        filters?: RepositoryFindFielters<TBase>\n        limits?: RepositoryLimitOptions<TBase>\n        orderBy?: RepositoryOrderBy<TBase>\n        options?: { enableCount?: boolean }\n      } = {},\n    ): Promise<RepositoryFindResult<TBase>> {\n      const collection: CollectionReference<TBase> = this.collection(this.buildCollectionPathForFind(find.filters))\n      const enableCount = find?.options?.enableCount ?? true\n      const intercepted = await this.interceptors?.request?.({ find })\n      const { filters, limits, orderBy } = intercepted.find || find\n      const queries = this.makeFirestoreWhere(filters || {})\n      const ordination = this.makeFirestoreOrderBy(filters, orderBy)\n      const offsets = await this.defineLimits(filters, limits)\n      const queryArgumments: QueryConstraint[] = [...queries, ...ordination, ...offsets]\n      const docs = await getDocs(query(collection, ...queryArgumments))\n      const data = docs.docs.map((doc) => doc.data())\n\n      return {\n        data: (await this.interceptors?.response?.(data, intercepted)) || data,\n        count: enableCount ? this.calculateCount(data, limits) : Infinity,\n      }\n    }\n\n    buildCollectionPathForFind(filters: RepositoryFindFielters<TBase>): string {\n      if (!this.isSubCollection(this)) return this.collectionName\n\n      const parentIdField = this.parentIdField as NonFunctionAndIdentifierPropertyNames<TBase>\n      const parentId = getValueFromFilter(filters?.[parentIdField])\n\n      return `${this.parentRepository.collectionName}/${parentId}/${this.collectionName}`\n    }\n\n    makeFirestoreWhere = (filter: RepositoryFindFielters<TBase>): QueryConstraint[] =>\n      Object.keys(filter).reduce(\n        (queries: QueryConstraint[], fieldName: string) => [\n          ...queries,\n          ...this.buildWhereSentence(fieldName, is(filter[fieldName as NonFunctionPropertyNames<TBase>])),\n        ],\n        [],\n      )\n\n    buildWhereSentence = (\n      fieldName: NonFunctionPropertyNames<TBase> | string,\n      options: RepositoryFindFieltersOptions<TBase, NonFunctionPropertyNames<TBase>>,\n    ): QueryConstraint[] => {\n      if (this.isSubCollection(this) && fieldName === this.parentIdField) return []\n\n      const value = options?.value || options\n      const object = {}\n\n      set(object, fieldName, value)\n\n      const plainInstance = new this.model(object).toPlain()\n      const firestoreFieldName =\n        fieldName.toString().indexOf('.') > -1\n          ? fieldName.toString()\n          : Object.keys(plainInstance).find((key) => plainInstance[key])\n\n      if (options?.operator === Where.LIKE) {\n        if (\n          Array.isArray(options?.value) &&\n          (this.fields[firestoreFieldName as NonFunctionAndIdentifierPropertyNames<TBase>] ===\n            FirestoreFieldType.Array ||\n            !this.fields[firestoreFieldName as NonFunctionAndIdentifierPropertyNames<TBase>])\n        )\n          return [where(firestoreFieldName, 'array-contains-any', options.value)]\n\n        return [where(firestoreFieldName, '>=', options.value), where(firestoreFieldName, '<=', `${options.value}~`)]\n      }\n      if (\n        options?.operator === Where.IN &&\n        Array.isArray(options?.value) &&\n        (this.fields[firestoreFieldName as NonFunctionAndIdentifierPropertyNames<TBase>] === FirestoreFieldType.Array ||\n          !this.fields[firestoreFieldName as NonFunctionAndIdentifierPropertyNames<TBase>])\n      )\n        return [where(firestoreFieldName, 'array-contains', options.value)]\n      if (isObject(options) && isNil(options?.operator) && isNil(options?.value)) {\n        return Object.keys(options).reduce(\n          (queries, key) => [\n            ...queries,\n            ...this.buildWhereSentence(`${fieldName.toString()}.${key}`, is<Record<string, any>>(options)[key]),\n          ],\n          [],\n        )\n      }\n\n      return [where(firestoreFieldName, (options?.operator as WhereFilterOp) || '==', options?.value || options)]\n    }\n\n    makeFirestoreOrderBy = (\n      filters: RepositoryFindFielters<TBase>,\n      fieldsToOrderBy?: RepositoryOrderBy<TBase>,\n    ): QueryConstraint[] => {\n      const orderByKeys = Object.keys(fieldsToOrderBy || {})\n\n      if (!orderByKeys.length) return []\n\n      const filtersKeysWithUnordered = Object.keys(filters || {}).filter(\n        (filterKey) => !orderByKeys.includes(filterKey),\n      )\n\n      if (filtersKeysWithUnordered.length)\n        filtersKeysWithUnordered.forEach(\n          (filterKey) =>\n            (fieldsToOrderBy = {\n              ...(![Where.EQUALS].includes(\n                is<RepositoryFindFieltersOptions<TBase, NonFunctionPropertyNames<TBase>>>(\n                  filters[filterKey as NonFunctionPropertyNames<TBase>],\n                ).operator,\n              )\n                ? { [filterKey]: 'asc' }\n                : {}),\n              ...fieldsToOrderBy,\n            }),\n        )\n\n      return Object.keys(fieldsToOrderBy).map((fieldName) =>\n        orderBy(fieldName, fieldsToOrderBy[fieldName as NonFunctionPropertyNames<TBase>]),\n      )\n    }\n\n    async defineLimits(\n      filters: RepositoryFindFielters<TBase>,\n      limits: RepositoryLimitOptions<TBase>,\n    ): Promise<QueryConstraint[]> {\n      const queries = []\n\n      if (limits?.offset) {\n        if (this.model.isModel(limits.offset))\n          queries.push(\n            startAfter(\n              await getDoc(\n                doc(\n                  this.collection(this.buildCollectionPathForFind(filters)),\n                  Object.values(limits.offset.identifier).shift()?.toString(),\n                ),\n              ),\n            ),\n          )\n        else if (isNumber(limits.offset) || isString(limits.offset)) queries.push(startAt(limits.offset))\n      }\n      if (limits?.limit) queries.push(limit(limits.limit))\n\n      return queries\n    }\n\n    calculateCount(data: TBase[], limits: RepositoryLimitOptions<TBase>): number {\n      if (data.length <= 0) return 0\n      if (data.length < limits?.limit) return data.length\n\n      return Infinity\n    }\n  } as any\n}\n"]}