@infrab4a/connect 4.0.0-beta.40 → 4.0.0-beta.42

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,4 +1,5 @@
1
1
  import { BaseModel } from '../../generic/model';
2
+ import { Category } from './category';
2
3
  import { Filter } from './filter';
3
4
  declare type CategoryFilterIdentifiers = 'id' | 'filterId' | 'categoryId';
4
5
  export declare class CategoryFilter extends BaseModel<CategoryFilter, CategoryFilterIdentifiers> {
@@ -6,6 +7,7 @@ export declare class CategoryFilter extends BaseModel<CategoryFilter, CategoryFi
6
7
  filterId: number;
7
8
  categoryId: number;
8
9
  filter?: Filter;
10
+ category?: Category;
9
11
  static get identifiersFields(): CategoryFilterIdentifiers[];
10
12
  }
11
13
  export {};
@@ -1,6 +1,7 @@
1
1
  import { BaseModel, GenericIdentifier } from '../../generic/model';
2
2
  import { Shops } from './enums';
3
3
  import { Filter } from './filter';
4
+ import { Product } from './product';
4
5
  import { CategoryCondition, CategoryMetadata } from './types';
5
6
  export declare class Category extends BaseModel<Category> {
6
7
  id: string;
@@ -25,5 +26,6 @@ export declare class Category extends BaseModel<Category> {
25
26
  parentId?: number;
26
27
  parent?: Category;
27
28
  filters?: Filter[];
29
+ childrenProducts?: Product[];
28
30
  static get identifiersFields(): GenericIdentifier[];
29
31
  }
@@ -1,6 +1,7 @@
1
1
  import { __decorate, __metadata } from "tslib";
2
2
  import { Type } from 'class-transformer';
3
3
  import { BaseModel } from '../../generic/model';
4
+ import { Category } from './category';
4
5
  import { Filter } from './filter';
5
6
  export class CategoryFilter extends BaseModel {
6
7
  static get identifiersFields() {
@@ -11,4 +12,8 @@ __decorate([
11
12
  Type(() => Filter),
12
13
  __metadata("design:type", Filter)
13
14
  ], CategoryFilter.prototype, "filter", void 0);
14
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2F0ZWdvcnktZmlsdGVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29ubmVjdC9zcmMvZG9tYWluL2NhdGFsb2cvbW9kZWxzL2NhdGVnb3J5LWZpbHRlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUEsT0FBTyxFQUFFLElBQUksRUFBRSxNQUFNLG1CQUFtQixDQUFBO0FBQ3hDLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQTtBQUMvQyxPQUFPLEVBQUUsTUFBTSxFQUFFLE1BQU0sVUFBVSxDQUFBO0FBSWpDLE1BQU0sT0FBTyxjQUFlLFNBQVEsU0FBb0Q7SUFRdEYsTUFBTSxLQUFLLGlCQUFpQjtRQUMxQixPQUFPLENBQUMsSUFBSSxDQUFDLENBQUE7SUFDZixDQUFDO0NBQ0Y7QUFOQztJQUFDLElBQUksQ0FBQyxHQUFHLEVBQUUsQ0FBQyxNQUFNLENBQUM7OEJBQ1YsTUFBTTs4Q0FBQSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFR5cGUgfSBmcm9tICdjbGFzcy10cmFuc2Zvcm1lcidcbmltcG9ydCB7IEJhc2VNb2RlbCB9IGZyb20gJy4uLy4uL2dlbmVyaWMvbW9kZWwnXG5pbXBvcnQgeyBGaWx0ZXIgfSBmcm9tICcuL2ZpbHRlcidcblxudHlwZSBDYXRlZ29yeUZpbHRlcklkZW50aWZpZXJzID0gJ2lkJyB8ICdmaWx0ZXJJZCcgfCAnY2F0ZWdvcnlJZCdcblxuZXhwb3J0IGNsYXNzIENhdGVnb3J5RmlsdGVyIGV4dGVuZHMgQmFzZU1vZGVsPENhdGVnb3J5RmlsdGVyLCBDYXRlZ29yeUZpbHRlcklkZW50aWZpZXJzPiB7XG4gIGlkOiBudW1iZXJcbiAgZmlsdGVySWQ6IG51bWJlclxuICBjYXRlZ29yeUlkOiBudW1iZXJcblxuICBAVHlwZSgoKSA9PiBGaWx0ZXIpXG4gIGZpbHRlcj86IEZpbHRlclxuXG4gIHN0YXRpYyBnZXQgaWRlbnRpZmllcnNGaWVsZHMoKTogQ2F0ZWdvcnlGaWx0ZXJJZGVudGlmaWVyc1tdIHtcbiAgICByZXR1cm4gWydpZCddXG4gIH1cbn1cbiJdfQ==
15
+ __decorate([
16
+ Type(() => Category),
17
+ __metadata("design:type", Category)
18
+ ], CategoryFilter.prototype, "category", void 0);
19
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2F0ZWdvcnktZmlsdGVyLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvY29ubmVjdC9zcmMvZG9tYWluL2NhdGFsb2cvbW9kZWxzL2NhdGVnb3J5LWZpbHRlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUEsT0FBTyxFQUFFLElBQUksRUFBRSxNQUFNLG1CQUFtQixDQUFBO0FBQ3hDLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQTtBQUMvQyxPQUFPLEVBQUUsUUFBUSxFQUFFLE1BQU0sWUFBWSxDQUFBO0FBQ3JDLE9BQU8sRUFBRSxNQUFNLEVBQUUsTUFBTSxVQUFVLENBQUE7QUFJakMsTUFBTSxPQUFPLGNBQWUsU0FBUSxTQUFvRDtJQVd0RixNQUFNLEtBQUssaUJBQWlCO1FBQzFCLE9BQU8sQ0FBQyxJQUFJLENBQUMsQ0FBQTtJQUNmLENBQUM7Q0FDRjtBQVRDO0lBQUMsSUFBSSxDQUFDLEdBQUcsRUFBRSxDQUFDLE1BQU0sQ0FBQzs4QkFDVixNQUFNOzhDQUFBO0FBRWY7SUFBQyxJQUFJLENBQUMsR0FBRyxFQUFFLENBQUMsUUFBUSxDQUFDOzhCQUNWLFFBQVE7Z0RBQUEiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBUeXBlIH0gZnJvbSAnY2xhc3MtdHJhbnNmb3JtZXInXG5pbXBvcnQgeyBCYXNlTW9kZWwgfSBmcm9tICcuLi8uLi9nZW5lcmljL21vZGVsJ1xuaW1wb3J0IHsgQ2F0ZWdvcnkgfSBmcm9tICcuL2NhdGVnb3J5J1xuaW1wb3J0IHsgRmlsdGVyIH0gZnJvbSAnLi9maWx0ZXInXG5cbnR5cGUgQ2F0ZWdvcnlGaWx0ZXJJZGVudGlmaWVycyA9ICdpZCcgfCAnZmlsdGVySWQnIHwgJ2NhdGVnb3J5SWQnXG5cbmV4cG9ydCBjbGFzcyBDYXRlZ29yeUZpbHRlciBleHRlbmRzIEJhc2VNb2RlbDxDYXRlZ29yeUZpbHRlciwgQ2F0ZWdvcnlGaWx0ZXJJZGVudGlmaWVycz4ge1xuICBpZDogbnVtYmVyXG4gIGZpbHRlcklkOiBudW1iZXJcbiAgY2F0ZWdvcnlJZDogbnVtYmVyXG5cbiAgQFR5cGUoKCkgPT4gRmlsdGVyKVxuICBmaWx0ZXI/OiBGaWx0ZXJcblxuICBAVHlwZSgoKSA9PiBDYXRlZ29yeSlcbiAgY2F0ZWdvcnk/OiBDYXRlZ29yeVxuXG4gIHN0YXRpYyBnZXQgaWRlbnRpZmllcnNGaWVsZHMoKTogQ2F0ZWdvcnlGaWx0ZXJJZGVudGlmaWVyc1tdIHtcbiAgICByZXR1cm4gWydpZCddXG4gIH1cbn1cbiJdfQ==
@@ -2,6 +2,7 @@ import { __decorate, __metadata } from "tslib";
2
2
  import { Type } from 'class-transformer';
3
3
  import { BaseModel } from '../../generic/model';
4
4
  import { Filter } from './filter';
5
+ import { Product } from './product';
5
6
  export class Category extends BaseModel {
6
7
  static get identifiersFields() {
7
8
  return ['id'];
@@ -15,4 +16,8 @@ __decorate([
15
16
  Type(() => Filter),
16
17
  __metadata("design:type", Array)
17
18
  ], Category.prototype, "filters", void 0);
18
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2F0ZWdvcnkuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb25uZWN0L3NyYy9kb21haW4vY2F0YWxvZy9tb2RlbHMvY2F0ZWdvcnkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLE9BQU8sRUFBRSxJQUFJLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQTtBQUN4QyxPQUFPLEVBQUUsU0FBUyxFQUFxQixNQUFNLHFCQUFxQixDQUFBO0FBRWxFLE9BQU8sRUFBRSxNQUFNLEVBQUUsTUFBTSxVQUFVLENBQUE7QUFHakMsTUFBTSxPQUFPLFFBQVMsU0FBUSxTQUFtQjtJQTRCL0MsTUFBTSxLQUFLLGlCQUFpQjtRQUMxQixPQUFPLENBQUMsSUFBSSxDQUFDLENBQUE7SUFDZixDQUFDO0NBQ0Y7QUFUQztJQUFDLElBQUksQ0FBQyxHQUFHLEVBQUUsQ0FBQyxRQUFRLENBQUM7OEJBQ1osUUFBUTt3Q0FBQTtBQUVqQjtJQUFDLElBQUksQ0FBQyxHQUFHLEVBQUUsQ0FBQyxNQUFNLENBQUM7O3lDQUNEIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgVHlwZSB9IGZyb20gJ2NsYXNzLXRyYW5zZm9ybWVyJ1xuaW1wb3J0IHsgQmFzZU1vZGVsLCBHZW5lcmljSWRlbnRpZmllciB9IGZyb20gJy4uLy4uL2dlbmVyaWMvbW9kZWwnXG5pbXBvcnQgeyBTaG9wcyB9IGZyb20gJy4vZW51bXMnXG5pbXBvcnQgeyBGaWx0ZXIgfSBmcm9tICcuL2ZpbHRlcidcbmltcG9ydCB7IENhdGVnb3J5Q29uZGl0aW9uLCBDYXRlZ29yeU1ldGFkYXRhIH0gZnJvbSAnLi90eXBlcydcblxuZXhwb3J0IGNsYXNzIENhdGVnb3J5IGV4dGVuZHMgQmFzZU1vZGVsPENhdGVnb3J5PiB7XG4gIGlkOiBzdHJpbmdcbiAgYnJhbmRDYXRlZ29yeTogYm9vbGVhblxuICBicmFuZExvZ28/OiBzdHJpbmdcbiAgbmFtZTogc3RyaW5nXG4gIHNsdWc6IHN0cmluZ1xuICBpbWFnZT86IHN0cmluZ1xuICBicmFuZENhdGVnb3J5QmFubmVyPzogc3RyaW5nXG4gIGJyYW5kQ2F0ZWdvcnlCYW5uZXJNb2JpbGU/OiBzdHJpbmdcbiAgZGVzY3JpcHRpb246IHN0cmluZ1xuICBjb25kaXRpb25zPzogQ2F0ZWdvcnlDb25kaXRpb25cbiAgcHJvZHVjdHM/OiBzdHJpbmdbXVxuICBjcmVhdGVkQXQ/OiBEYXRlXG4gIHVwZGF0ZWRBdD86IERhdGVcbiAgc2hvcD86IFNob3BzXG4gIHNob3BzPzogc3RyaW5nW11cbiAgcHVibGlzaGVkOiBib29sZWFuXG4gIG1ldGFkYXRhOiBDYXRlZ29yeU1ldGFkYXRhXG4gIGlzQ29sbGVjdGlvbj86IGJvb2xlYW5cbiAgcmVmZXJlbmNlPzogc3RyaW5nXG4gIHBhcmVudElkPzogbnVtYmVyXG5cbiAgQFR5cGUoKCkgPT4gQ2F0ZWdvcnkpXG4gIHBhcmVudD86IENhdGVnb3J5XG5cbiAgQFR5cGUoKCkgPT4gRmlsdGVyKVxuICBmaWx0ZXJzPzogRmlsdGVyW11cblxuICBzdGF0aWMgZ2V0IGlkZW50aWZpZXJzRmllbGRzKCk6IEdlbmVyaWNJZGVudGlmaWVyW10ge1xuICAgIHJldHVybiBbJ2lkJ11cbiAgfVxufVxuIl19
19
+ __decorate([
20
+ Type(() => Product),
21
+ __metadata("design:type", Array)
22
+ ], Category.prototype, "childrenProducts", void 0);
23
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2F0ZWdvcnkuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb25uZWN0L3NyYy9kb21haW4vY2F0YWxvZy9tb2RlbHMvY2F0ZWdvcnkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IjtBQUFBLE9BQU8sRUFBRSxJQUFJLEVBQUUsTUFBTSxtQkFBbUIsQ0FBQTtBQUN4QyxPQUFPLEVBQUUsU0FBUyxFQUFxQixNQUFNLHFCQUFxQixDQUFBO0FBRWxFLE9BQU8sRUFBRSxNQUFNLEVBQUUsTUFBTSxVQUFVLENBQUE7QUFDakMsT0FBTyxFQUFFLE9BQU8sRUFBRSxNQUFNLFdBQVcsQ0FBQTtBQUduQyxNQUFNLE9BQU8sUUFBUyxTQUFRLFNBQW1CO0lBK0IvQyxNQUFNLEtBQUssaUJBQWlCO1FBQzFCLE9BQU8sQ0FBQyxJQUFJLENBQUMsQ0FBQTtJQUNmLENBQUM7Q0FDRjtBQVpDO0lBQUMsSUFBSSxDQUFDLEdBQUcsRUFBRSxDQUFDLFFBQVEsQ0FBQzs4QkFDWixRQUFRO3dDQUFBO0FBRWpCO0lBQUMsSUFBSSxDQUFDLEdBQUcsRUFBRSxDQUFDLE1BQU0sQ0FBQzs7eUNBQ0Q7QUFFbEI7SUFBQyxJQUFJLENBQUMsR0FBRyxFQUFFLENBQUMsT0FBTyxDQUFDOztrREFDUSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFR5cGUgfSBmcm9tICdjbGFzcy10cmFuc2Zvcm1lcidcbmltcG9ydCB7IEJhc2VNb2RlbCwgR2VuZXJpY0lkZW50aWZpZXIgfSBmcm9tICcuLi8uLi9nZW5lcmljL21vZGVsJ1xuaW1wb3J0IHsgU2hvcHMgfSBmcm9tICcuL2VudW1zJ1xuaW1wb3J0IHsgRmlsdGVyIH0gZnJvbSAnLi9maWx0ZXInXG5pbXBvcnQgeyBQcm9kdWN0IH0gZnJvbSAnLi9wcm9kdWN0J1xuaW1wb3J0IHsgQ2F0ZWdvcnlDb25kaXRpb24sIENhdGVnb3J5TWV0YWRhdGEgfSBmcm9tICcuL3R5cGVzJ1xuXG5leHBvcnQgY2xhc3MgQ2F0ZWdvcnkgZXh0ZW5kcyBCYXNlTW9kZWw8Q2F0ZWdvcnk+IHtcbiAgaWQ6IHN0cmluZ1xuICBicmFuZENhdGVnb3J5OiBib29sZWFuXG4gIGJyYW5kTG9nbz86IHN0cmluZ1xuICBuYW1lOiBzdHJpbmdcbiAgc2x1Zzogc3RyaW5nXG4gIGltYWdlPzogc3RyaW5nXG4gIGJyYW5kQ2F0ZWdvcnlCYW5uZXI/OiBzdHJpbmdcbiAgYnJhbmRDYXRlZ29yeUJhbm5lck1vYmlsZT86IHN0cmluZ1xuICBkZXNjcmlwdGlvbjogc3RyaW5nXG4gIGNvbmRpdGlvbnM/OiBDYXRlZ29yeUNvbmRpdGlvblxuICBwcm9kdWN0cz86IHN0cmluZ1tdXG4gIGNyZWF0ZWRBdD86IERhdGVcbiAgdXBkYXRlZEF0PzogRGF0ZVxuICBzaG9wPzogU2hvcHNcbiAgc2hvcHM/OiBzdHJpbmdbXVxuICBwdWJsaXNoZWQ6IGJvb2xlYW5cbiAgbWV0YWRhdGE6IENhdGVnb3J5TWV0YWRhdGFcbiAgaXNDb2xsZWN0aW9uPzogYm9vbGVhblxuICByZWZlcmVuY2U/OiBzdHJpbmdcbiAgcGFyZW50SWQ/OiBudW1iZXJcblxuICBAVHlwZSgoKSA9PiBDYXRlZ29yeSlcbiAgcGFyZW50PzogQ2F0ZWdvcnlcblxuICBAVHlwZSgoKSA9PiBGaWx0ZXIpXG4gIGZpbHRlcnM/OiBGaWx0ZXJbXVxuXG4gIEBUeXBlKCgpID0+IFByb2R1Y3QpXG4gIGNoaWxkcmVuUHJvZHVjdHM/OiBQcm9kdWN0W11cblxuICBzdGF0aWMgZ2V0IGlkZW50aWZpZXJzRmllbGRzKCk6IEdlbmVyaWNJZGVudGlmaWVyW10ge1xuICAgIHJldHVybiBbJ2lkJ11cbiAgfVxufVxuIl19
@@ -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"]}
@@ -37,7 +37,7 @@ BindFilterQueryHelper.BuildWhereSentence = (field, options, fields) => {
37
37
  const columnFields = fieldOptions.fields;
38
38
  return {
39
39
  ...variables,
40
- [columnName]: BindFilterQueryHelper.BuildWhereSentence(key, is(is(options)[key]), columnFields || []),
40
+ [columnName]: BindFilterQueryHelper.BuildWhereSentence(key, is(is(options)[key]), fieldSentenceOptions?.fields || columnFields || fields),
41
41
  };
42
42
  }, {});
43
43
  if (!Array.isArray(options) && !isNil(fieldSentenceOptions.fields))
@@ -68,4 +68,4 @@ BindFilterQueryHelper.GetHasuraJsonbOperator = (options) => options.operator ===
68
68
  ? HasuraGraphQLWhere.JSON_HAS_KEYS_ANY
69
69
  : HasuraGraphQLWhere[Object.keys(HasuraGraphQLWhere).find((graphQLOperator) => graphQLOperator ===
70
70
  Object.keys(Where).find((operator) => Where[operator] === options?.operator))];
71
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bind-filter-query.helper.js","sourceRoot":"","sources":["../../../../../../../projects/connect/src/infra/hasura-graphql/mixins/helpers/bind-filter-query.helper.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ModelBaseStructure,\n  NonFunctionAndIdentifierPropertyNames,\n  NonFunctionPropertyNames,\n  RepositoryFindFielters,\n  RepositoryFindFieltersOptions,\n  Where,\n} from '../../../../domain'\nimport { is, isNil, isObject } from '../../../../utils'\nimport { HasuraGraphQLColumnType, HasuraGraphQLWhere } from '../../enums'\nimport { ColumnOptions, HasuraGraphQLFields, VariableOptions } from '../../types'\n\nimport { AttributeOptionHelper } from './attribute-option.helper'\nimport { FilterOptionHelper } from './filter-option.helper'\n\nexport class BindFilterQueryHelper {\n  static MakeGraphQLWhere = <MBase extends ModelBaseStructure<MBase>>(\n    filter: RepositoryFindFielters<MBase>,\n    fields: HasuraGraphQLFields<MBase>,\n  ): VariableOptions =>\n    Object.keys(filter).reduce((variables: VariableOptions, fieldName: string) => {\n      const columnOption = AttributeOptionHelper.FindByAttribute(\n        fieldName as NonFunctionAndIdentifierPropertyNames<MBase>,\n        fields,\n      )\n\n      if (!columnOption.bindFindFilter)\n        return {\n          ...variables,\n          ...{\n            [columnOption.columnName]: BindFilterQueryHelper.BuildWhereSentence(\n              fieldName as NonFunctionAndIdentifierPropertyNames<MBase>,\n              filter[fieldName as NonFunctionAndIdentifierPropertyNames<MBase>] as RepositoryFindFieltersOptions<\n                MBase,\n                NonFunctionAndIdentifierPropertyNames<MBase>\n              >,\n              fields,\n            ),\n          },\n        }\n\n      const builtFilter: RepositoryFindFielters<MBase> = columnOption.bindFindFilter(\n        filter[fieldName as NonFunctionPropertyNames<MBase>] as RepositoryFindFieltersOptions<\n          MBase,\n          NonFunctionPropertyNames<MBase>\n        >,\n      )\n\n      return {\n        ...variables,\n        ...Object.keys(builtFilter).reduce(\n          (variablesList: VariableOptions, columnName: string) => ({\n            ...variablesList,\n            [columnName]: BindFilterQueryHelper.BuildWhereSentence(\n              fieldName as NonFunctionAndIdentifierPropertyNames<MBase>,\n              builtFilter[columnName as NonFunctionAndIdentifierPropertyNames<MBase>] as RepositoryFindFieltersOptions<\n                MBase,\n                NonFunctionAndIdentifierPropertyNames<MBase>\n              >,\n              fields,\n            ),\n          }),\n          {},\n        ),\n      }\n    }, {})\n\n  static BuildWhereSentence = <MBase extends ModelBaseStructure<MBase>>(\n    field: NonFunctionAndIdentifierPropertyNames<MBase>,\n    options: RepositoryFindFieltersOptions<MBase, NonFunctionAndIdentifierPropertyNames<MBase>>,\n    fields: HasuraGraphQLFields<MBase>,\n  ): VariableOptions => {\n    const fieldSentenceOptions = AttributeOptionHelper.FindByAttribute<MBase>(field, fields)\n    const isNestedField =\n      !Array.isArray(options) &&\n      isObject(options) &&\n      isNil(options?.operator) &&\n      isNil(options?.value) &&\n      isNil(fieldSentenceOptions?.to)\n\n    if (isNestedField)\n      return Object.keys(options).reduce((variables, key) => {\n        const fieldOptions = AttributeOptionHelper.FindByAttribute<MBase>(\n          key as NonFunctionAndIdentifierPropertyNames<MBase>,\n          fieldSentenceOptions?.fields || (fields as any),\n        )\n        const columnName = fieldOptions.columnName\n        const columnFields = fieldOptions.fields\n\n        return {\n          ...variables,\n          [columnName]: BindFilterQueryHelper.BuildWhereSentence<MBase>(\n            key as NonFunctionAndIdentifierPropertyNames<MBase>,\n            is<RepositoryFindFieltersOptions<MBase, NonFunctionAndIdentifierPropertyNames<MBase>>>(\n              is<RepositoryFindFielters<MBase>>(options)[key as NonFunctionAndIdentifierPropertyNames<MBase>],\n            ),\n            columnFields || ([] as any),\n          ),\n        }\n      }, {})\n\n    if (!Array.isArray(options) && !isNil(fieldSentenceOptions.fields))\n      return {\n        [fieldSentenceOptions.fields[0] as NonFunctionAndIdentifierPropertyNames<MBase>]:\n          BindFilterQueryHelper.BuildOperatorSentence(\n            options,\n            fieldSentenceOptions as ColumnOptions<MBase[NonFunctionAndIdentifierPropertyNames<MBase>], MBase>,\n          ),\n      }\n\n    if (!Array.isArray(options) && isObject(options) && !FilterOptionHelper.CheckIfIsFilterOption(options))\n      options = Object.values(options)[0] as RepositoryFindFieltersOptions<MBase, any>\n\n    return Array.isArray(options)\n      ? options.reduce(\n          (whereSentence, option) => ({\n            ...whereSentence,\n            ...BindFilterQueryHelper.BuildOperatorSentence(\n              option,\n              fieldSentenceOptions as ColumnOptions<MBase[NonFunctionAndIdentifierPropertyNames<MBase>], MBase>,\n            ),\n          }),\n          {},\n        )\n      : BindFilterQueryHelper.BuildOperatorSentence(\n          options,\n          fieldSentenceOptions as ColumnOptions<MBase[NonFunctionAndIdentifierPropertyNames<MBase>], MBase>,\n        )\n  }\n\n  static BuildOperatorSentence = <MBase extends ModelBaseStructure<MBase>>(\n    options: RepositoryFindFieltersOptions<MBase, any>,\n    fieldOption: ColumnOptions<any, any>,\n  ): VariableOptions => ({\n    [BindFilterQueryHelper.GetHasuraOperator(options, fieldOption)]: FilterOptionHelper.GetValueFromFilter(\n      options,\n      fieldOption,\n    ),\n  })\n\n  static GetHasuraOperator = <MBase extends ModelBaseStructure<MBase>>(\n    options: RepositoryFindFieltersOptions<MBase, NonFunctionPropertyNames<MBase>>,\n    fieldOption: ColumnOptions<any, any>,\n  ): HasuraGraphQLWhere =>\n    FilterOptionHelper.CheckIfIsFilterOption(options)\n      ? fieldOption.type === HasuraGraphQLColumnType.Jsonb\n        ? BindFilterQueryHelper.GetHasuraJsonbOperator(options)\n        : HasuraGraphQLWhere[\n            Object.keys(HasuraGraphQLWhere).find(\n              (graphQLOperator) =>\n                graphQLOperator ===\n                Object.keys(Where).find((operator) => Where[operator as keyof typeof Where] === options?.operator),\n            ) as keyof typeof HasuraGraphQLWhere\n          ]\n      : HasuraGraphQLWhere.EQUALS\n\n  static GetHasuraJsonbOperator = <MBase extends ModelBaseStructure<MBase>>(\n    options: RepositoryFindFieltersOptions<MBase, NonFunctionPropertyNames<MBase>>,\n  ): HasuraGraphQLWhere =>\n    options.operator === Where.IN\n      ? HasuraGraphQLWhere.JSON_CONTAINS\n      : options.operator === Where.LIKE\n      ? HasuraGraphQLWhere.JSON_HAS_KEYS_ANY\n      : HasuraGraphQLWhere[\n          Object.keys(HasuraGraphQLWhere).find(\n            (graphQLOperator) =>\n              graphQLOperator ===\n              Object.keys(Where).find((operator) => Where[operator as keyof typeof Where] === options?.operator),\n          ) as keyof typeof HasuraGraphQLWhere\n        ]\n}\n"]}
71
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bind-filter-query.helper.js","sourceRoot":"","sources":["../../../../../../../projects/connect/src/infra/hasura-graphql/mixins/helpers/bind-filter-query.helper.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ModelBaseStructure,\n  NonFunctionAndIdentifierPropertyNames,\n  NonFunctionPropertyNames,\n  RepositoryFindFielters,\n  RepositoryFindFieltersOptions,\n  Where,\n} from '../../../../domain'\nimport { is, isNil, isObject } from '../../../../utils'\nimport { HasuraGraphQLColumnType, HasuraGraphQLWhere } from '../../enums'\nimport { ColumnOptions, HasuraGraphQLFields, VariableOptions } from '../../types'\nimport { AttributeOptionHelper } from './attribute-option.helper'\nimport { FilterOptionHelper } from './filter-option.helper'\n\nexport class BindFilterQueryHelper {\n  static MakeGraphQLWhere = <MBase extends ModelBaseStructure<MBase>>(\n    filter: RepositoryFindFielters<MBase>,\n    fields: HasuraGraphQLFields<MBase>,\n  ): VariableOptions =>\n    Object.keys(filter).reduce((variables: VariableOptions, fieldName: string) => {\n      const columnOption = AttributeOptionHelper.FindByAttribute(\n        fieldName as NonFunctionAndIdentifierPropertyNames<MBase>,\n        fields,\n      )\n\n      if (!columnOption.bindFindFilter)\n        return {\n          ...variables,\n          ...{\n            [columnOption.columnName]: BindFilterQueryHelper.BuildWhereSentence(\n              fieldName as NonFunctionAndIdentifierPropertyNames<MBase>,\n              filter[fieldName as NonFunctionAndIdentifierPropertyNames<MBase>] as RepositoryFindFieltersOptions<\n                MBase,\n                NonFunctionAndIdentifierPropertyNames<MBase>\n              >,\n              fields,\n            ),\n          },\n        }\n\n      const builtFilter: RepositoryFindFielters<MBase> = columnOption.bindFindFilter(\n        filter[fieldName as NonFunctionPropertyNames<MBase>] as RepositoryFindFieltersOptions<\n          MBase,\n          NonFunctionPropertyNames<MBase>\n        >,\n      )\n\n      return {\n        ...variables,\n        ...Object.keys(builtFilter).reduce(\n          (variablesList: VariableOptions, columnName: string) => ({\n            ...variablesList,\n            [columnName]: BindFilterQueryHelper.BuildWhereSentence(\n              fieldName as NonFunctionAndIdentifierPropertyNames<MBase>,\n              builtFilter[columnName as NonFunctionAndIdentifierPropertyNames<MBase>] as RepositoryFindFieltersOptions<\n                MBase,\n                NonFunctionAndIdentifierPropertyNames<MBase>\n              >,\n              fields,\n            ),\n          }),\n          {},\n        ),\n      }\n    }, {})\n\n  static BuildWhereSentence = <MBase extends ModelBaseStructure<MBase>>(\n    field: NonFunctionAndIdentifierPropertyNames<MBase>,\n    options: RepositoryFindFieltersOptions<MBase, NonFunctionAndIdentifierPropertyNames<MBase>>,\n    fields: HasuraGraphQLFields<MBase>,\n  ): VariableOptions => {\n    const fieldSentenceOptions = AttributeOptionHelper.FindByAttribute<MBase>(field, fields)\n    const isNestedField =\n      !Array.isArray(options) &&\n      isObject(options) &&\n      isNil(options?.operator) &&\n      isNil(options?.value) &&\n      isNil(fieldSentenceOptions?.to)\n\n    if (isNestedField)\n      return Object.keys(options).reduce((variables, key) => {\n        const fieldOptions = AttributeOptionHelper.FindByAttribute<MBase>(\n          key as NonFunctionAndIdentifierPropertyNames<MBase>,\n          fieldSentenceOptions?.fields || (fields as any),\n        )\n        const columnName = fieldOptions.columnName\n        const columnFields = fieldOptions.fields\n\n        return {\n          ...variables,\n          [columnName]: BindFilterQueryHelper.BuildWhereSentence<MBase>(\n            key as NonFunctionAndIdentifierPropertyNames<MBase>,\n            is<RepositoryFindFieltersOptions<MBase, NonFunctionAndIdentifierPropertyNames<MBase>>>(\n              is<RepositoryFindFielters<MBase>>(options)[key as NonFunctionAndIdentifierPropertyNames<MBase>],\n            ),\n            fieldSentenceOptions?.fields || columnFields || (fields as any),\n          ),\n        }\n      }, {})\n\n    if (!Array.isArray(options) && !isNil(fieldSentenceOptions.fields))\n      return {\n        [fieldSentenceOptions.fields[0] as NonFunctionAndIdentifierPropertyNames<MBase>]:\n          BindFilterQueryHelper.BuildOperatorSentence(\n            options,\n            fieldSentenceOptions as ColumnOptions<MBase[NonFunctionAndIdentifierPropertyNames<MBase>], MBase>,\n          ),\n      }\n\n    if (!Array.isArray(options) && isObject(options) && !FilterOptionHelper.CheckIfIsFilterOption(options))\n      options = Object.values(options)[0] as RepositoryFindFieltersOptions<MBase, any>\n\n    return Array.isArray(options)\n      ? options.reduce(\n          (whereSentence, option) => ({\n            ...whereSentence,\n            ...BindFilterQueryHelper.BuildOperatorSentence(\n              option,\n              fieldSentenceOptions as ColumnOptions<MBase[NonFunctionAndIdentifierPropertyNames<MBase>], MBase>,\n            ),\n          }),\n          {},\n        )\n      : BindFilterQueryHelper.BuildOperatorSentence(\n          options,\n          fieldSentenceOptions as ColumnOptions<MBase[NonFunctionAndIdentifierPropertyNames<MBase>], MBase>,\n        )\n  }\n\n  static BuildOperatorSentence = <MBase extends ModelBaseStructure<MBase>>(\n    options: RepositoryFindFieltersOptions<MBase, any>,\n    fieldOption: ColumnOptions<any, any>,\n  ): VariableOptions => ({\n    [BindFilterQueryHelper.GetHasuraOperator(options, fieldOption)]: FilterOptionHelper.GetValueFromFilter(\n      options,\n      fieldOption,\n    ),\n  })\n\n  static GetHasuraOperator = <MBase extends ModelBaseStructure<MBase>>(\n    options: RepositoryFindFieltersOptions<MBase, NonFunctionPropertyNames<MBase>>,\n    fieldOption: ColumnOptions<any, any>,\n  ): HasuraGraphQLWhere =>\n    FilterOptionHelper.CheckIfIsFilterOption(options)\n      ? fieldOption.type === HasuraGraphQLColumnType.Jsonb\n        ? BindFilterQueryHelper.GetHasuraJsonbOperator(options)\n        : HasuraGraphQLWhere[\n            Object.keys(HasuraGraphQLWhere).find(\n              (graphQLOperator) =>\n                graphQLOperator ===\n                Object.keys(Where).find((operator) => Where[operator as keyof typeof Where] === options?.operator),\n            ) as keyof typeof HasuraGraphQLWhere\n          ]\n      : HasuraGraphQLWhere.EQUALS\n\n  static GetHasuraJsonbOperator = <MBase extends ModelBaseStructure<MBase>>(\n    options: RepositoryFindFieltersOptions<MBase, NonFunctionPropertyNames<MBase>>,\n  ): HasuraGraphQLWhere =>\n    options.operator === Where.IN\n      ? HasuraGraphQLWhere.JSON_CONTAINS\n      : options.operator === Where.LIKE\n      ? HasuraGraphQLWhere.JSON_HAS_KEYS_ANY\n      : HasuraGraphQLWhere[\n          Object.keys(HasuraGraphQLWhere).find(\n            (graphQLOperator) =>\n              graphQLOperator ===\n              Object.keys(Where).find((operator) => Where[operator as keyof typeof Where] === options?.operator),\n          ) as keyof typeof HasuraGraphQLWhere\n        ]\n}\n"]}
@@ -40,6 +40,48 @@ export class CategoryFilterHasuraGraphQLRepository extends withCrudHasuraGraphQL
40
40
  ],
41
41
  },
42
42
  },
43
+ {
44
+ category: {
45
+ columnName: 'category',
46
+ foreignKeyColumn: { id: 'categoryId' },
47
+ fields: [
48
+ 'id',
49
+ 'description',
50
+ {
51
+ products: {
52
+ columnName: 'products',
53
+ fields: ['product_id'],
54
+ from: (value) => value.map((product) => product.product_id.toString()),
55
+ to: (productIds) => productIds.map((productId) => ({
56
+ product_id: +productId,
57
+ })),
58
+ },
59
+ },
60
+ {
61
+ childrenProducts: {
62
+ columnName: 'children_products',
63
+ foreignKeyColumn: { category_id: 'id' },
64
+ fields: [
65
+ 'id',
66
+ 'name',
67
+ 'slug',
68
+ {
69
+ categories: {
70
+ columnName: 'categories',
71
+ fields: ['category_id'],
72
+ bindPersistData: (value) => ({
73
+ categories: { data: value.map((category) => ({ category_id: +category })) },
74
+ }),
75
+ to: (categories) => categories.map((categoryId) => +categoryId),
76
+ from: (categories) => categories?.map((category) => category?.category_id?.toString()) || [],
77
+ },
78
+ },
79
+ ],
80
+ },
81
+ },
82
+ ],
83
+ },
84
+ },
43
85
  ],
44
86
  });
45
87
  }
@@ -53,4 +95,4 @@ export class CategoryFilterHasuraGraphQLRepository extends withCrudHasuraGraphQL
53
95
  });
54
96
  }
55
97
  }
56
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2F0ZWdvcnktZmlsdGVyLWhhc3VyYS1ncmFwaHFsLnJlcG9zaXRvcnkuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9jb25uZWN0L3NyYy9pbmZyYS9oYXN1cmEtZ3JhcGhxbC9yZXBvc2l0b3JpZXMvY2F0YWxvZy9jYXRlZ29yeS1maWx0ZXItaGFzdXJhLWdyYXBocWwucmVwb3NpdG9yeS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sb0JBQW9CLENBQUE7QUFFbkQsT0FBTyxFQUFFLElBQUksRUFBRSxNQUFNLG1CQUFtQixDQUFBO0FBQ3hDLE9BQU8sRUFBMkIscUJBQXFCLEVBQUUsaUJBQWlCLEVBQUUsTUFBTSxjQUFjLENBQUE7QUFFaEcsTUFBTSxPQUFPLHFDQUNYLFNBQVEscUJBQXFCLENBQUMsaUJBQWlCLENBQWlCLElBQUksQ0FBQyxDQUFDO0lBR3RFLFlBQVksRUFDVixRQUFRLEVBQ1IsV0FBVyxFQUNYLFlBQVksR0FDK0U7UUFDM0YsS0FBSyxDQUFDO1lBQ0osU0FBUyxFQUFFLGlCQUFpQjtZQUM1QixLQUFLLEVBQUUsY0FBYztZQUNyQixRQUFRO1lBQ1IsV0FBVztZQUNYLFlBQVk7WUFDWixNQUFNLEVBQUU7Z0JBQ04sSUFBSTtnQkFDSixFQUFFLFFBQVEsRUFBRSxFQUFFLFVBQVUsRUFBRSxXQUFXLEVBQUUsRUFBRTtnQkFDekMsRUFBRSxVQUFVLEVBQUUsRUFBRSxVQUFVLEVBQUUsYUFBYSxFQUFFLEVBQUU7Z0JBQzdDO29CQUNFLE1BQU0sRUFBRTt3QkFDTixVQUFVLEVBQUUsUUFBUTt3QkFDcEIsZ0JBQWdCLEVBQUUsRUFBRSxFQUFFLEVBQUUsVUFBVSxFQUFFO3dCQUNwQyxNQUFNLEVBQUU7NEJBQ04sSUFBSTs0QkFDSixhQUFhOzRCQUNiLE1BQU07NEJBQ04sU0FBUzs0QkFDVCxFQUFFLFNBQVMsRUFBRSxFQUFFLFVBQVUsRUFBRSxZQUFZLEVBQUUsRUFBRTs0QkFDM0MsRUFBRSxTQUFTLEVBQUUsRUFBRSxVQUFVLEVBQUUsWUFBWSxFQUFFLEVBQUU7NEJBQzNDO2dDQUNFLE9BQU8sRUFBRTtvQ0FDUCxVQUFVLEVBQUUsU0FBUztvQ0FDckIsZ0JBQWdCLEVBQUUsRUFBRSxRQUFRLEVBQUUsSUFBSSxFQUFFO29DQUNwQyxNQUFNLEVBQUU7d0NBQ04sSUFBSTt3Q0FDSixFQUFFLFFBQVEsRUFBRSxFQUFFLFVBQVUsRUFBRSxXQUFXLEVBQUUsRUFBRTt3Q0FDekMsYUFBYTt3Q0FDYixFQUFFLFNBQVMsRUFBRSxFQUFFLFVBQVUsRUFBRSxZQUFZLEVBQUUsRUFBRTt3Q0FDM0MsRUFBRSxTQUFTLEVBQUUsRUFBRSxVQUFVLEVBQUUsWUFBWSxFQUFFLEVBQUU7cUNBQzVDO2lDQUNGOzZCQUNGO3lCQUNGO3FCQUNGO2lCQUNGO2FBQ0Y7U0FDRixDQUFDLENBQUE7SUFDSixDQUFDO0lBRUQseUJBQXlCLENBQUMsVUFBa0IsRUFBRSxRQUFnQjtRQUM1RCxPQUFPLElBQUksQ0FBQyxRQUFRLENBQUMsd0JBQXdCLEVBQUUsQ0FBQyxlQUFlLENBQUMsRUFBRTtZQUNoRSxLQUFLLEVBQUU7Z0JBQ0wsSUFBSSxFQUFFLDBCQUEwQjtnQkFDaEMsUUFBUSxFQUFFLElBQUk7Z0JBQ2QsS0FBSyxFQUFFLEVBQUUsV0FBVyxFQUFFLEVBQUUsR0FBRyxFQUFFLFVBQVUsRUFBRSxFQUFFLFNBQVMsRUFBRSxFQUFFLEdBQUcsRUFBRSxRQUFRLEVBQUUsRUFBRTthQUMxRTtTQUNGLENBQUMsQ0FBQTtJQUNKLENBQUM7Q0FDRiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENhdGVnb3J5RmlsdGVyIH0gZnJvbSAnLi4vLi4vLi4vLi4vZG9tYWluJ1xuaW1wb3J0IHsgQ2F0ZWdvcnlGaWx0ZXJSZXBvc2l0b3J5IH0gZnJvbSAnLi4vLi4vLi4vLi4vZG9tYWluL2NhdGFsb2cvcmVwb3NpdG9yaWVzJ1xuaW1wb3J0IHsgQmFzZSB9IGZyb20gJy4uLy4uLy4uLy4uL3V0aWxzJ1xuaW1wb3J0IHsgSGFzdXJhQ29uc3RydWN0b3JQYXJhbXMsIHdpdGhDcnVkSGFzdXJhR3JhcGhRTCwgd2l0aEhhc3VyYUdyYXBoUUwgfSBmcm9tICcuLi8uLi9taXhpbnMnXG5cbmV4cG9ydCBjbGFzcyBDYXRlZ29yeUZpbHRlckhhc3VyYUdyYXBoUUxSZXBvc2l0b3J5XG4gIGV4dGVuZHMgd2l0aENydWRIYXN1cmFHcmFwaFFMKHdpdGhIYXN1cmFHcmFwaFFMPENhdGVnb3J5RmlsdGVyPihCYXNlKSlcbiAgaW1wbGVtZW50cyBDYXRlZ29yeUZpbHRlclJlcG9zaXRvcnlcbntcbiAgY29uc3RydWN0b3Ioe1xuICAgIGVuZHBvaW50LFxuICAgIGF1dGhPcHRpb25zLFxuICAgIGludGVyY2VwdG9ycyxcbiAgfTogUGljazxIYXN1cmFDb25zdHJ1Y3RvclBhcmFtczxDYXRlZ29yeUZpbHRlcj4sICdlbmRwb2ludCcgfCAnYXV0aE9wdGlvbnMnIHwgJ2ludGVyY2VwdG9ycyc+KSB7XG4gICAgc3VwZXIoe1xuICAgICAgdGFibGVOYW1lOiAnY2F0ZWdvcnlfZmlsdGVyJyxcbiAgICAgIG1vZGVsOiBDYXRlZ29yeUZpbHRlcixcbiAgICAgIGVuZHBvaW50LFxuICAgICAgYXV0aE9wdGlvbnMsXG4gICAgICBpbnRlcmNlcHRvcnMsXG4gICAgICBmaWVsZHM6IFtcbiAgICAgICAgJ2lkJyxcbiAgICAgICAgeyBmaWx0ZXJJZDogeyBjb2x1bW5OYW1lOiAnZmlsdGVyX2lkJyB9IH0sXG4gICAgICAgIHsgY2F0ZWdvcnlJZDogeyBjb2x1bW5OYW1lOiAnY2F0ZWdvcnlfaWQnIH0gfSxcbiAgICAgICAge1xuICAgICAgICAgIGZpbHRlcjoge1xuICAgICAgICAgICAgY29sdW1uTmFtZTogJ2ZpbHRlcicsXG4gICAgICAgICAgICBmb3JlaWduS2V5Q29sdW1uOiB7IGlkOiAnZmlsdGVySWQnIH0sXG4gICAgICAgICAgICBmaWVsZHM6IFtcbiAgICAgICAgICAgICAgJ2lkJyxcbiAgICAgICAgICAgICAgJ2Rlc2NyaXB0aW9uJyxcbiAgICAgICAgICAgICAgJ3NsdWcnLFxuICAgICAgICAgICAgICAnZW5hYmxlZCcsXG4gICAgICAgICAgICAgIHsgY3JlYXRlZEF0OiB7IGNvbHVtbk5hbWU6ICdjcmVhdGVkX2F0JyB9IH0sXG4gICAgICAgICAgICAgIHsgdXBkYXRlZEF0OiB7IGNvbHVtbk5hbWU6ICd1cGRhdGVkX2F0JyB9IH0sXG4gICAgICAgICAgICAgIHtcbiAgICAgICAgICAgICAgICBvcHRpb25zOiB7XG4gICAgICAgICAgICAgICAgICBjb2x1bW5OYW1lOiAnb3B0aW9ucycsXG4gICAgICAgICAgICAgICAgICBmb3JlaWduS2V5Q29sdW1uOiB7IGZpbHRlcklkOiAnaWQnIH0sXG4gICAgICAgICAgICAgICAgICBmaWVsZHM6IFtcbiAgICAgICAgICAgICAgICAgICAgJ2lkJyxcbiAgICAgICAgICAgICAgICAgICAgeyBmaWx0ZXJJZDogeyBjb2x1bW5OYW1lOiAnZmlsdGVyX2lkJyB9IH0sXG4gICAgICAgICAgICAgICAgICAgICdkZXNjcmlwdGlvbicsXG4gICAgICAgICAgICAgICAgICAgIHsgY3JlYXRlZEF0OiB7IGNvbHVtbk5hbWU6ICdjcmVhdGVkX2F0JyB9IH0sXG4gICAgICAgICAgICAgICAgICAgIHsgdXBkYXRlZEF0OiB7IGNvbHVtbk5hbWU6ICd1cGRhdGVkX2F0JyB9IH0sXG4gICAgICAgICAgICAgICAgICBdLFxuICAgICAgICAgICAgICAgIH0sXG4gICAgICAgICAgICAgIH0sXG4gICAgICAgICAgICBdLFxuICAgICAgICAgIH0sXG4gICAgICAgIH0sXG4gICAgICBdLFxuICAgIH0pXG4gIH1cblxuICBkZWxldGVCeUNhdGVnb3J5QW5kRmlsdGVyKGNhdGVnb3J5SWQ6IG51bWJlciwgZmlsdGVySWQ6IG51bWJlcik6IFByb21pc2U8YW55PiB7XG4gICAgcmV0dXJuIHRoaXMubXV0YXRpb24oJ2RlbGV0ZV9jYXRlZ29yeV9maWx0ZXInLCBbJ2FmZmVjdGVkX3Jvd3MnXSwge1xuICAgICAgd2hlcmU6IHtcbiAgICAgICAgdHlwZTogJ2NhdGVnb3J5X2ZpbHRlcl9ib29sX2V4cCcsXG4gICAgICAgIHJlcXVpcmVkOiB0cnVlLFxuICAgICAgICB2YWx1ZTogeyBjYXRlZ29yeV9pZDogeyBfZXE6IGNhdGVnb3J5SWQgfSwgZmlsdGVyX2lkOiB7IF9lcTogZmlsdGVySWQgfSB9LFxuICAgICAgfSxcbiAgICB9KVxuICB9XG59XG4iXX0=
98
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"category-filter-hasura-graphql.repository.js","sourceRoot":"","sources":["../../../../../../../projects/connect/src/infra/hasura-graphql/repositories/catalog/category-filter-hasura-graphql.repository.ts"],"names":[],"mappings":"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","sourcesContent":["import { CategoryFilter } from '../../../../domain'\nimport { CategoryFilterRepository } from '../../../../domain/catalog/repositories'\nimport { Base } from '../../../../utils'\nimport { HasuraConstructorParams, withCrudHasuraGraphQL, withHasuraGraphQL } from '../../mixins'\n\nexport class CategoryFilterHasuraGraphQLRepository\n  extends withCrudHasuraGraphQL(withHasuraGraphQL<CategoryFilter>(Base))\n  implements CategoryFilterRepository\n{\n  constructor({\n    endpoint,\n    authOptions,\n    interceptors,\n  }: Pick<HasuraConstructorParams<CategoryFilter>, 'endpoint' | 'authOptions' | 'interceptors'>) {\n    super({\n      tableName: 'category_filter',\n      model: CategoryFilter,\n      endpoint,\n      authOptions,\n      interceptors,\n      fields: [\n        'id',\n        { filterId: { columnName: 'filter_id' } },\n        { categoryId: { columnName: 'category_id' } },\n        {\n          filter: {\n            columnName: 'filter',\n            foreignKeyColumn: { id: 'filterId' },\n            fields: [\n              'id',\n              'description',\n              'slug',\n              'enabled',\n              { createdAt: { columnName: 'created_at' } },\n              { updatedAt: { columnName: 'updated_at' } },\n              {\n                options: {\n                  columnName: 'options',\n                  foreignKeyColumn: { filterId: 'id' },\n                  fields: [\n                    'id',\n                    { filterId: { columnName: 'filter_id' } },\n                    'description',\n                    { createdAt: { columnName: 'created_at' } },\n                    { updatedAt: { columnName: 'updated_at' } },\n                  ],\n                },\n              },\n            ],\n          },\n        },\n        {\n          category: {\n            columnName: 'category',\n            foreignKeyColumn: { id: 'categoryId' },\n            fields: [\n              'id',\n              'description',\n              {\n                products: {\n                  columnName: 'products',\n                  fields: ['product_id'],\n                  from: (value: { product_id: number }[]) => value.map((product) => product.product_id.toString()),\n                  to: (productIds: string[]) =>\n                    productIds.map((productId) => ({\n                      product_id: +productId,\n                    })),\n                },\n              },\n              {\n                childrenProducts: {\n                  columnName: 'children_products',\n                  foreignKeyColumn: { category_id: 'id' },\n                  fields: [\n                    'id',\n                    'name',\n                    'slug',\n                    {\n                      categories: {\n                        columnName: 'categories',\n                        fields: ['category_id'],\n                        bindPersistData: (value) => ({\n                          categories: { data: value.map((category: string) => ({ category_id: +category })) },\n                        }),\n                        to: (categories: string[]) => categories.map((categoryId) => +categoryId),\n                        from: (categories: { category_id: number }[]) =>\n                          categories?.map((category) => category?.category_id?.toString()) || [],\n                      },\n                    },\n                  ],\n                },\n              },\n            ],\n          },\n        },\n      ],\n    })\n  }\n\n  deleteByCategoryAndFilter(categoryId: number, filterId: number): Promise<any> {\n    return this.mutation('delete_category_filter', ['affected_rows'], {\n      where: {\n        type: 'category_filter_bool_exp',\n        required: true,\n        value: { category_id: { _eq: categoryId }, filter_id: { _eq: filterId } },\n      },\n    })\n  }\n}\n"]}
@@ -1197,6 +1197,52 @@ class Filter extends BaseModel {
1197
1197
  }
1198
1198
  }
1199
1199
 
1200
+ class KitProduct extends BaseModel {
1201
+ static get identifiersFields() {
1202
+ return ['productId', 'kitProductId'];
1203
+ }
1204
+ }
1205
+ __decorate([
1206
+ Type(() => Product),
1207
+ __metadata("design:type", Product)
1208
+ ], KitProduct.prototype, "kit", void 0);
1209
+ __decorate([
1210
+ Type(() => Product),
1211
+ __metadata("design:type", Product)
1212
+ ], KitProduct.prototype, "product", void 0);
1213
+
1214
+ class Product extends BaseModel {
1215
+ get evaluation() {
1216
+ return {
1217
+ reviews: this.reviews,
1218
+ count: this.reviewsTotal,
1219
+ rating: this.rate,
1220
+ };
1221
+ }
1222
+ set evaluation(evaluation) {
1223
+ if (!evaluation) {
1224
+ this.reviews = null;
1225
+ this.reviewsTotal = null;
1226
+ this.rate = null;
1227
+ return;
1228
+ }
1229
+ this.reviews = evaluation.reviews || this.reviews;
1230
+ this.reviewsTotal = evaluation.count || this.reviewsTotal;
1231
+ this.rate = evaluation.rating || this.rate;
1232
+ }
1233
+ static get identifiersFields() {
1234
+ return ['id'];
1235
+ }
1236
+ }
1237
+ __decorate([
1238
+ Type(() => Category),
1239
+ __metadata("design:type", Category)
1240
+ ], Product.prototype, "category", void 0);
1241
+ __decorate([
1242
+ Type(() => KitProduct),
1243
+ __metadata("design:type", Array)
1244
+ ], Product.prototype, "kitProducts", void 0);
1245
+
1200
1246
  class Category extends BaseModel {
1201
1247
  static get identifiersFields() {
1202
1248
  return ['id'];
@@ -1210,6 +1256,10 @@ __decorate([
1210
1256
  Type(() => Filter),
1211
1257
  __metadata("design:type", Array)
1212
1258
  ], Category.prototype, "filters", void 0);
1259
+ __decorate([
1260
+ Type(() => Product),
1261
+ __metadata("design:type", Array)
1262
+ ], Category.prototype, "childrenProducts", void 0);
1213
1263
 
1214
1264
  class CategoryCollectionChildren extends BaseModel {
1215
1265
  static get identifiersFields() {
@@ -1230,6 +1280,10 @@ __decorate([
1230
1280
  Type(() => Filter),
1231
1281
  __metadata("design:type", Filter)
1232
1282
  ], CategoryFilter.prototype, "filter", void 0);
1283
+ __decorate([
1284
+ Type(() => Category),
1285
+ __metadata("design:type", Category)
1286
+ ], CategoryFilter.prototype, "category", void 0);
1233
1287
 
1234
1288
  var GenderDestination;
1235
1289
  (function (GenderDestination) {
@@ -1252,52 +1306,6 @@ class FilterOption extends BaseModel {
1252
1306
  }
1253
1307
  }
1254
1308
 
1255
- class Product extends BaseModel {
1256
- get evaluation() {
1257
- return {
1258
- reviews: this.reviews,
1259
- count: this.reviewsTotal,
1260
- rating: this.rate,
1261
- };
1262
- }
1263
- set evaluation(evaluation) {
1264
- if (!evaluation) {
1265
- this.reviews = null;
1266
- this.reviewsTotal = null;
1267
- this.rate = null;
1268
- return;
1269
- }
1270
- this.reviews = evaluation.reviews || this.reviews;
1271
- this.reviewsTotal = evaluation.count || this.reviewsTotal;
1272
- this.rate = evaluation.rating || this.rate;
1273
- }
1274
- static get identifiersFields() {
1275
- return ['id'];
1276
- }
1277
- }
1278
- __decorate([
1279
- Type(() => Category),
1280
- __metadata("design:type", Category)
1281
- ], Product.prototype, "category", void 0);
1282
- __decorate([
1283
- Type(() => KitProduct),
1284
- __metadata("design:type", Array)
1285
- ], Product.prototype, "kitProducts", void 0);
1286
-
1287
- class KitProduct extends BaseModel {
1288
- static get identifiersFields() {
1289
- return ['productId', 'kitProductId'];
1290
- }
1291
- }
1292
- __decorate([
1293
- Type(() => Product),
1294
- __metadata("design:type", Product)
1295
- ], KitProduct.prototype, "kit", void 0);
1296
- __decorate([
1297
- Type(() => Product),
1298
- __metadata("design:type", Product)
1299
- ], KitProduct.prototype, "product", void 0);
1300
-
1301
1309
  class Variant extends BaseModel {
1302
1310
  static get identifiersFields() {
1303
1311
  return ['id', 'productId'];
@@ -1880,7 +1888,7 @@ const withFindFirestore = (MixinBase) => {
1880
1888
  ], []);
1881
1889
  this.buildWhereSentence = (fieldName, options) => {
1882
1890
  if (this.isSubCollection(this) && fieldName === this.parentIdField)
1883
- [];
1891
+ return [];
1884
1892
  const value = (options === null || options === void 0 ? void 0 : options.value) || options;
1885
1893
  const object = {};
1886
1894
  set(object, fieldName, value);
@@ -2812,7 +2820,7 @@ BindFilterQueryHelper.BuildWhereSentence = (field, options, fields) => {
2812
2820
  const fieldOptions = AttributeOptionHelper.FindByAttribute(key, (fieldSentenceOptions === null || fieldSentenceOptions === void 0 ? void 0 : fieldSentenceOptions.fields) || fields);
2813
2821
  const columnName = fieldOptions.columnName;
2814
2822
  const columnFields = fieldOptions.fields;
2815
- return Object.assign(Object.assign({}, variables), { [columnName]: BindFilterQueryHelper.BuildWhereSentence(key, is(is(options)[key]), columnFields || []) });
2823
+ return Object.assign(Object.assign({}, variables), { [columnName]: BindFilterQueryHelper.BuildWhereSentence(key, is(is(options)[key]), (fieldSentenceOptions === null || fieldSentenceOptions === void 0 ? void 0 : fieldSentenceOptions.fields) || columnFields || fields) });
2816
2824
  }, {});
2817
2825
  if (!Array.isArray(options) && !isNil(fieldSentenceOptions.fields))
2818
2826
  return {
@@ -3426,6 +3434,48 @@ class CategoryFilterHasuraGraphQLRepository extends withCrudHasuraGraphQL(withHa
3426
3434
  ],
3427
3435
  },
3428
3436
  },
3437
+ {
3438
+ category: {
3439
+ columnName: 'category',
3440
+ foreignKeyColumn: { id: 'categoryId' },
3441
+ fields: [
3442
+ 'id',
3443
+ 'description',
3444
+ {
3445
+ products: {
3446
+ columnName: 'products',
3447
+ fields: ['product_id'],
3448
+ from: (value) => value.map((product) => product.product_id.toString()),
3449
+ to: (productIds) => productIds.map((productId) => ({
3450
+ product_id: +productId,
3451
+ })),
3452
+ },
3453
+ },
3454
+ {
3455
+ childrenProducts: {
3456
+ columnName: 'children_products',
3457
+ foreignKeyColumn: { category_id: 'id' },
3458
+ fields: [
3459
+ 'id',
3460
+ 'name',
3461
+ 'slug',
3462
+ {
3463
+ categories: {
3464
+ columnName: 'categories',
3465
+ fields: ['category_id'],
3466
+ bindPersistData: (value) => ({
3467
+ categories: { data: value.map((category) => ({ category_id: +category })) },
3468
+ }),
3469
+ to: (categories) => categories.map((categoryId) => +categoryId),
3470
+ from: (categories) => (categories === null || categories === void 0 ? void 0 : categories.map((category) => { var _a; return (_a = category === null || category === void 0 ? void 0 : category.category_id) === null || _a === void 0 ? void 0 : _a.toString(); })) || [],
3471
+ },
3472
+ },
3473
+ ],
3474
+ },
3475
+ },
3476
+ ],
3477
+ },
3478
+ },
3429
3479
  ],
3430
3480
  });
3431
3481
  }