@infrab4a/connect 4.0.0-beta.41 → 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.
@@ -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"]}
@@ -1888,7 +1888,7 @@ const withFindFirestore = (MixinBase) => {
1888
1888
  ], []);
1889
1889
  this.buildWhereSentence = (fieldName, options) => {
1890
1890
  if (this.isSubCollection(this) && fieldName === this.parentIdField)
1891
- [];
1891
+ return [];
1892
1892
  const value = (options === null || options === void 0 ? void 0 : options.value) || options;
1893
1893
  const object = {};
1894
1894
  set(object, fieldName, value);