@infrab4a/connect 4.0.0-beta.27 → 4.0.0-beta.29

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.
@@ -8,7 +8,7 @@ export class User extends BaseModel {
8
8
  const instance = super.toInstance(data);
9
9
  if (!isNil(data.firstName))
10
10
  instance.displayName = `${data.firstName}${!isNil(data.lastName) ? ` ${data.lastName}` : ''}`;
11
- return;
11
+ return instance;
12
12
  }
13
13
  toPlain() {
14
14
  const plain = super.toPlain();
@@ -23,4 +23,4 @@ __decorate([
23
23
  Type(() => BeautyProfile),
24
24
  __metadata("design:type", BeautyProfile)
25
25
  ], User.prototype, "beautyProfile", void 0);
26
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXNlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2Nvbm5lY3Qvc3JjL2RvbWFpbi91c2Vycy9tb2RlbHMvdXNlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUEsT0FBTyxFQUFFLElBQUksRUFBRSxNQUFNLG1CQUFtQixDQUFBO0FBQ3hDLE9BQU8sRUFBRSxLQUFLLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQTtBQUN0QyxPQUFPLEVBQUUsU0FBUyxFQUF5RCxNQUFNLGVBQWUsQ0FBQTtBQUNoRyxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sa0JBQWtCLENBQUE7QUFHaEQsTUFBTSxPQUFPLElBQUssU0FBUSxTQUFlO0lBdUJ2QyxNQUFNLENBQVUsVUFBVSxDQUF1QixJQUF3RDtRQUN2RyxNQUFNLFFBQVEsR0FBRyxLQUFLLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBb0IsQ0FBQTtRQUUxRCxJQUFJLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUM7WUFDeEIsUUFBUSxDQUFDLFdBQVcsR0FBRyxHQUFHLElBQUksQ0FBQyxTQUFTLEdBQUcsQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxDQUFDLENBQUMsQ0FBQyxJQUFJLElBQUksQ0FBQyxRQUFRLEVBQUUsQ0FBQyxDQUFDLENBQUMsRUFBRSxFQUFFLENBQUE7UUFFL0YsT0FBTTtJQUNSLENBQUM7SUFFUSxPQUFPO1FBQ2QsTUFBTSxLQUFLLEdBQUcsS0FBSyxDQUFDLE9BQU8sRUFBRSxDQUFBO1FBRTdCLE9BQU8sS0FBSyxDQUFDLGFBQWEsQ0FBQTtRQUUxQixPQUFPLEtBQUssQ0FBQTtJQUNkLENBQUM7SUFFRCxNQUFNLEtBQUssaUJBQWlCO1FBQzFCLE9BQU8sQ0FBQyxJQUFJLENBQUMsQ0FBQTtJQUNmLENBQUM7Q0FDRjtBQXZCQztJQUFDLElBQUksQ0FBQyxHQUFHLEVBQUUsQ0FBQyxhQUFhLENBQUM7OEJBQ1YsYUFBYTsyQ0FBQSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFR5cGUgfSBmcm9tICdjbGFzcy10cmFuc2Zvcm1lcidcbmltcG9ydCB7IGlzTmlsIH0gZnJvbSAnLi4vLi4vLi4vdXRpbHMnXG5pbXBvcnQgeyBCYXNlTW9kZWwsIEdlbmVyaWNJZGVudGlmaWVyLCBOb25GdW5jdGlvbkFuZElkZW50aWZpZXJQcm9wZXJ0aWVzIH0gZnJvbSAnLi4vLi4vZ2VuZXJpYydcbmltcG9ydCB7IEJlYXV0eVByb2ZpbGUgfSBmcm9tICcuL2JlYXV0eS1wcm9maWxlJ1xuaW1wb3J0IHsgQXJlYSwgT2ZmaWNlUG9zaXRpb24sIFVzZXJUeXBlIH0gZnJvbSAnLi9lbnVtcydcblxuZXhwb3J0IGNsYXNzIFVzZXIgZXh0ZW5kcyBCYXNlTW9kZWw8VXNlcj4ge1xuICBpZDogc3RyaW5nXG4gIGNwZj86IHN0cmluZ1xuICBlbWFpbDogc3RyaW5nXG4gIGZpcnN0TmFtZT86IHN0cmluZ1xuICBsYXN0TmFtZT86IHN0cmluZ1xuICBkaXNwbGF5TmFtZT86IHN0cmluZ1xuICBwaG9uZT86IHN0cmluZ1xuICBiaXJ0aGRheT86IERhdGVcbiAgYWNjZXB0c05ld3NsZXR0ZXI/OiBib29sZWFuXG4gIHR5cGU/OiBVc2VyVHlwZVxuICBhcmVhPzogQXJlYVxuICBvZmZpY2VQb3NpdGlvbj86IE9mZmljZVBvc2l0aW9uXG4gIGlzU3Vic2NyaWJlcj86IGJvb2xlYW5cbiAgc3Vic2NyaXB0aW9uUGxhbj86IHN0cmluZ1xuICBiYWRnZUlkPzogbnVtYmVyXG4gIGJhZGdlTXVsdGlwbGllcj86IG51bWJlclxuICBkYXRlQ3JlYXRlZD86IERhdGVcbiAgZGF0ZU1vZGlmaWVkPzogRGF0ZVxuXG4gIEBUeXBlKCgpID0+IEJlYXV0eVByb2ZpbGUpXG4gIGJlYXV0eVByb2ZpbGU/OiBCZWF1dHlQcm9maWxlXG5cbiAgc3RhdGljIG92ZXJyaWRlIHRvSW5zdGFuY2U8VD4odGhpczogbmV3ICgpID0+IFQsIGRhdGE/OiBQYXJ0aWFsPE5vbkZ1bmN0aW9uQW5kSWRlbnRpZmllclByb3BlcnRpZXM8VXNlcj4+KTogVCB7XG4gICAgY29uc3QgaW5zdGFuY2UgPSBzdXBlci50b0luc3RhbmNlKGRhdGEpIGFzIHVua25vd24gYXMgVXNlclxuXG4gICAgaWYgKCFpc05pbChkYXRhLmZpcnN0TmFtZSkpXG4gICAgICBpbnN0YW5jZS5kaXNwbGF5TmFtZSA9IGAke2RhdGEuZmlyc3ROYW1lfSR7IWlzTmlsKGRhdGEubGFzdE5hbWUpID8gYCAke2RhdGEubGFzdE5hbWV9YCA6ICcnfWBcblxuICAgIHJldHVyblxuICB9XG5cbiAgb3ZlcnJpZGUgdG9QbGFpbigpOiBSZWNvcmQ8c3RyaW5nLCBhbnk+IHtcbiAgICBjb25zdCBwbGFpbiA9IHN1cGVyLnRvUGxhaW4oKVxuXG4gICAgZGVsZXRlIHBsYWluLmJlYXV0eVByb2ZpbGVcblxuICAgIHJldHVybiBwbGFpblxuICB9XG5cbiAgc3RhdGljIGdldCBpZGVudGlmaWVyc0ZpZWxkcygpOiBHZW5lcmljSWRlbnRpZmllcltdIHtcbiAgICByZXR1cm4gWydpZCddXG4gIH1cbn1cbiJdfQ==
26
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXNlci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL2Nvbm5lY3Qvc3JjL2RvbWFpbi91c2Vycy9tb2RlbHMvdXNlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUEsT0FBTyxFQUFFLElBQUksRUFBRSxNQUFNLG1CQUFtQixDQUFBO0FBQ3hDLE9BQU8sRUFBRSxLQUFLLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQTtBQUN0QyxPQUFPLEVBQUUsU0FBUyxFQUF5RCxNQUFNLGVBQWUsQ0FBQTtBQUNoRyxPQUFPLEVBQUUsYUFBYSxFQUFFLE1BQU0sa0JBQWtCLENBQUE7QUFHaEQsTUFBTSxPQUFPLElBQUssU0FBUSxTQUFlO0lBdUJ2QyxNQUFNLENBQVUsVUFBVSxDQUF1QixJQUF3RDtRQUN2RyxNQUFNLFFBQVEsR0FBRyxLQUFLLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBb0IsQ0FBQTtRQUUxRCxJQUFJLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUM7WUFDeEIsUUFBUSxDQUFDLFdBQVcsR0FBRyxHQUFHLElBQUksQ0FBQyxTQUFTLEdBQUcsQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxDQUFDLENBQUMsQ0FBQyxJQUFJLElBQUksQ0FBQyxRQUFRLEVBQUUsQ0FBQyxDQUFDLENBQUMsRUFBRSxFQUFFLENBQUE7UUFFL0YsT0FBTyxRQUFhLENBQUE7SUFDdEIsQ0FBQztJQUVRLE9BQU87UUFDZCxNQUFNLEtBQUssR0FBRyxLQUFLLENBQUMsT0FBTyxFQUFFLENBQUE7UUFFN0IsT0FBTyxLQUFLLENBQUMsYUFBYSxDQUFBO1FBRTFCLE9BQU8sS0FBSyxDQUFBO0lBQ2QsQ0FBQztJQUVELE1BQU0sS0FBSyxpQkFBaUI7UUFDMUIsT0FBTyxDQUFDLElBQUksQ0FBQyxDQUFBO0lBQ2YsQ0FBQztDQUNGO0FBdkJDO0lBQUMsSUFBSSxDQUFDLEdBQUcsRUFBRSxDQUFDLGFBQWEsQ0FBQzs4QkFDVixhQUFhOzJDQUFBIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgVHlwZSB9IGZyb20gJ2NsYXNzLXRyYW5zZm9ybWVyJ1xuaW1wb3J0IHsgaXNOaWwgfSBmcm9tICcuLi8uLi8uLi91dGlscydcbmltcG9ydCB7IEJhc2VNb2RlbCwgR2VuZXJpY0lkZW50aWZpZXIsIE5vbkZ1bmN0aW9uQW5kSWRlbnRpZmllclByb3BlcnRpZXMgfSBmcm9tICcuLi8uLi9nZW5lcmljJ1xuaW1wb3J0IHsgQmVhdXR5UHJvZmlsZSB9IGZyb20gJy4vYmVhdXR5LXByb2ZpbGUnXG5pbXBvcnQgeyBBcmVhLCBPZmZpY2VQb3NpdGlvbiwgVXNlclR5cGUgfSBmcm9tICcuL2VudW1zJ1xuXG5leHBvcnQgY2xhc3MgVXNlciBleHRlbmRzIEJhc2VNb2RlbDxVc2VyPiB7XG4gIGlkOiBzdHJpbmdcbiAgY3BmPzogc3RyaW5nXG4gIGVtYWlsOiBzdHJpbmdcbiAgZmlyc3ROYW1lPzogc3RyaW5nXG4gIGxhc3ROYW1lPzogc3RyaW5nXG4gIGRpc3BsYXlOYW1lPzogc3RyaW5nXG4gIHBob25lPzogc3RyaW5nXG4gIGJpcnRoZGF5PzogRGF0ZVxuICBhY2NlcHRzTmV3c2xldHRlcj86IGJvb2xlYW5cbiAgdHlwZT86IFVzZXJUeXBlXG4gIGFyZWE/OiBBcmVhXG4gIG9mZmljZVBvc2l0aW9uPzogT2ZmaWNlUG9zaXRpb25cbiAgaXNTdWJzY3JpYmVyPzogYm9vbGVhblxuICBzdWJzY3JpcHRpb25QbGFuPzogc3RyaW5nXG4gIGJhZGdlSWQ/OiBudW1iZXJcbiAgYmFkZ2VNdWx0aXBsaWVyPzogbnVtYmVyXG4gIGRhdGVDcmVhdGVkPzogRGF0ZVxuICBkYXRlTW9kaWZpZWQ/OiBEYXRlXG5cbiAgQFR5cGUoKCkgPT4gQmVhdXR5UHJvZmlsZSlcbiAgYmVhdXR5UHJvZmlsZT86IEJlYXV0eVByb2ZpbGVcblxuICBzdGF0aWMgb3ZlcnJpZGUgdG9JbnN0YW5jZTxUPih0aGlzOiBuZXcgKCkgPT4gVCwgZGF0YT86IFBhcnRpYWw8Tm9uRnVuY3Rpb25BbmRJZGVudGlmaWVyUHJvcGVydGllczxVc2VyPj4pOiBUIHtcbiAgICBjb25zdCBpbnN0YW5jZSA9IHN1cGVyLnRvSW5zdGFuY2UoZGF0YSkgYXMgdW5rbm93biBhcyBVc2VyXG5cbiAgICBpZiAoIWlzTmlsKGRhdGEuZmlyc3ROYW1lKSlcbiAgICAgIGluc3RhbmNlLmRpc3BsYXlOYW1lID0gYCR7ZGF0YS5maXJzdE5hbWV9JHshaXNOaWwoZGF0YS5sYXN0TmFtZSkgPyBgICR7ZGF0YS5sYXN0TmFtZX1gIDogJyd9YFxuXG4gICAgcmV0dXJuIGluc3RhbmNlIGFzIFRcbiAgfVxuXG4gIG92ZXJyaWRlIHRvUGxhaW4oKTogUmVjb3JkPHN0cmluZywgYW55PiB7XG4gICAgY29uc3QgcGxhaW4gPSBzdXBlci50b1BsYWluKClcblxuICAgIGRlbGV0ZSBwbGFpbi5iZWF1dHlQcm9maWxlXG5cbiAgICByZXR1cm4gcGxhaW5cbiAgfVxuXG4gIHN0YXRpYyBnZXQgaWRlbnRpZmllcnNGaWVsZHMoKTogR2VuZXJpY0lkZW50aWZpZXJbXSB7XG4gICAgcmV0dXJuIFsnaWQnXVxuICB9XG59XG4iXX0=
@@ -1,4 +1,5 @@
1
1
  import { collection } from 'firebase/firestore';
2
+ import { each, isObject, unset } from '../../../../utils';
2
3
  export const withFirestore = (MixinBase) => {
3
4
  const isObjectsAndNoDate = (data) => data &&
4
5
  !Array.isArray(data) &&
@@ -24,6 +25,17 @@ export const withFirestore = (MixinBase) => {
24
25
  : bindDate(data[key], key),
25
26
  }), {});
26
27
  };
28
+ const omitByRecursivelyInPlace = (value, iteratee) => {
29
+ each(value, (v, k) => {
30
+ if (iteratee(v, k)) {
31
+ unset(value, k);
32
+ }
33
+ else if (isObject(v)) {
34
+ omitByRecursivelyInPlace(v, iteratee);
35
+ }
36
+ });
37
+ return value;
38
+ };
27
39
  return class extends MixinBase {
28
40
  constructor(...params) {
29
41
  const options = params[0];
@@ -42,7 +54,10 @@ export const withFirestore = (MixinBase) => {
42
54
  }
43
55
  buildModelInstance() {
44
56
  return {
45
- toFirestore: (data) => (data?.toPlain ? data.toPlain() : data),
57
+ toFirestore: (data) => {
58
+ const plain = data?.toPlain ? data.toPlain() : data;
59
+ return omitByRecursivelyInPlace(plain, (value) => value === undefined);
60
+ },
46
61
  fromFirestore: (snap) => {
47
62
  const data = snap.data();
48
63
  let bindedData = null;
@@ -62,4 +77,4 @@ export const withFirestore = (MixinBase) => {
62
77
  }
63
78
  };
64
79
  };
65
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"with-firestore.mixin.js","sourceRoot":"","sources":["../../../../../../../projects/connect/src/infra/firebase/firestore/mixins/with-firestore.mixin.ts"],"names":[],"mappings":"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","sourcesContent":["import { collection, CollectionReference, DocumentData, Firestore, QueryDocumentSnapshot } from 'firebase/firestore'\n\nimport {\n  BaseModelBuilder,\n  ModelBaseStructure,\n  NonFunctionAndIdentifierPropertiesWithNoPartial,\n  NonFunctionAndIdentifierPropertyNames,\n} from '../../../../domain'\nimport { MergeConstructorParams, MixinCtor } from '../../../../utils'\nimport { FirestoreFieldType } from '../enums'\nimport { FirestoreInterceptors, FirestoreRepository } from '../types'\n\nexport type FirestoreConstructorParams<Model extends ModelBaseStructure<Model>> = {\n  firestore: Firestore\n  collectionName: string\n  model: BaseModelBuilder<Model>\n  fields?: Partial<Record<NonFunctionAndIdentifierPropertyNames<Model>, FirestoreFieldType>>\n  interceptors?: FirestoreInterceptors<Model>\n}\n\nexport const withFirestore = <TBase extends ModelBaseStructure<TBase>, T extends MixinCtor = MixinCtor>(\n  MixinBase: T,\n): MixinCtor<FirestoreRepository<TBase>, MergeConstructorParams<any[], FirestoreConstructorParams<TBase>[]>> => {\n  const isObjectsAndNoDate = (data: any): boolean =>\n    data &&\n    !Array.isArray(data) &&\n    typeof data === 'object' &&\n    data?.constructor.name !== 'Timestamp' &&\n    !('seconds' in data)\n  const bindDate = (data: any, keyName: string): Record<string, any> => {\n    if (data?.constructor.name === 'Timestamp') return data.toDate()\n    if (data && typeof data === 'object' && 'seconds' in data) return new Date(data.seconds * 1000)\n    if (typeof data === 'number' && ['createdAt', 'updatedAt'].includes(keyName)) return new Date(data)\n\n    return data\n  }\n  const bindAllDateFromObject = (data: Record<string, any>): NonFunctionAndIdentifierPropertiesWithNoPartial<TBase> => {\n    return Object.keys(data).reduce(\n      (object, key) => ({\n        ...object,\n        [key]: isObjectsAndNoDate(data[key])\n          ? bindAllDateFromObject(data[key])\n          : Array.isArray(data[key])\n          ? data[key].map((element: any) => (isObjectsAndNoDate(element) ? bindAllDateFromObject(element) : element))\n          : bindDate(data[key], key),\n      }),\n      {} as NonFunctionAndIdentifierPropertiesWithNoPartial<TBase>,\n    )\n  }\n\n  return class extends MixinBase implements FirestoreRepository<TBase> {\n    firestore: Firestore\n    fields: Partial<Record<NonFunctionAndIdentifierPropertyNames<TBase>, FirestoreFieldType>> = {}\n    interceptors: FirestoreInterceptors<TBase> = {}\n    collectionName: string = ''\n    model: BaseModelBuilder<TBase>\n\n    constructor(...params: any[]) {\n      const options: FirestoreConstructorParams<TBase> = params[0]\n\n      super(...params)\n\n      this.firestore = options.firestore\n      this.collectionName = options.collectionName\n      this.model = options.model\n      this.fields = options.fields\n      this.interceptors = options.interceptors\n    }\n\n    collection(path?: string): CollectionReference<TBase> {\n      return collection(this.firestore, path || this.collectionName).withConverter(this.buildModelInstance())\n    }\n\n    buildModelInstance(): {\n      toFirestore: (data: TBase) => DocumentData\n      fromFirestore: (snap: QueryDocumentSnapshot<TBase>) => TBase\n    } {\n      return {\n        toFirestore: (data: TBase): DocumentData => (data?.toPlain ? data.toPlain() : data),\n        fromFirestore: (snap: QueryDocumentSnapshot<TBase>): TBase => {\n          const data = snap.data()\n          let bindedData: NonFunctionAndIdentifierPropertiesWithNoPartial<TBase> = null\n\n          try {\n            const ids = { id: snap.id }\n\n            bindedData = bindAllDateFromObject(data)\n\n            return this.model.toInstance({ ...bindedData, ...ids })\n          } catch (error) {\n            console.info('id', snap.id)\n            console.info('data', JSON.stringify(bindedData))\n            console.error(error)\n\n            throw error\n          }\n        },\n      }\n    }\n  }\n}\n"]}
80
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"with-firestore.mixin.js","sourceRoot":"","sources":["../../../../../../../projects/connect/src/infra/firebase/firestore/mixins/with-firestore.mixin.ts"],"names":[],"mappings":"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","sourcesContent":["import { collection, CollectionReference, DocumentData, Firestore, QueryDocumentSnapshot } from 'firebase/firestore'\n\nimport {\n  BaseModelBuilder,\n  ModelBaseStructure,\n  NonFunctionAndIdentifierPropertiesWithNoPartial,\n  NonFunctionAndIdentifierPropertyNames,\n} from '../../../../domain'\nimport { each, isObject, MergeConstructorParams, MixinCtor, unset } from '../../../../utils'\nimport { FirestoreFieldType } from '../enums'\nimport { FirestoreInterceptors, FirestoreRepository } from '../types'\n\nexport type FirestoreConstructorParams<Model extends ModelBaseStructure<Model>> = {\n  firestore: Firestore\n  collectionName: string\n  model: BaseModelBuilder<Model>\n  fields?: Partial<Record<NonFunctionAndIdentifierPropertyNames<Model>, FirestoreFieldType>>\n  interceptors?: FirestoreInterceptors<Model>\n}\n\nexport const withFirestore = <TBase extends ModelBaseStructure<TBase>, T extends MixinCtor = MixinCtor>(\n  MixinBase: T,\n): MixinCtor<FirestoreRepository<TBase>, MergeConstructorParams<any[], FirestoreConstructorParams<TBase>[]>> => {\n  const isObjectsAndNoDate = (data: any): boolean =>\n    data &&\n    !Array.isArray(data) &&\n    typeof data === 'object' &&\n    data?.constructor.name !== 'Timestamp' &&\n    !('seconds' in data)\n  const bindDate = (data: any, keyName: string): Record<string, any> => {\n    if (data?.constructor.name === 'Timestamp') return data.toDate()\n    if (data && typeof data === 'object' && 'seconds' in data) return new Date(data.seconds * 1000)\n    if (typeof data === 'number' && ['createdAt', 'updatedAt'].includes(keyName)) return new Date(data)\n\n    return data\n  }\n  const bindAllDateFromObject = (data: Record<string, any>): NonFunctionAndIdentifierPropertiesWithNoPartial<TBase> => {\n    return Object.keys(data).reduce(\n      (object, key) => ({\n        ...object,\n        [key]: isObjectsAndNoDate(data[key])\n          ? bindAllDateFromObject(data[key])\n          : Array.isArray(data[key])\n          ? data[key].map((element: any) => (isObjectsAndNoDate(element) ? bindAllDateFromObject(element) : element))\n          : bindDate(data[key], key),\n      }),\n      {} as NonFunctionAndIdentifierPropertiesWithNoPartial<TBase>,\n    )\n  }\n  const omitByRecursivelyInPlace = (value: any, iteratee: (value: any, key: string) => boolean): any => {\n    each(value, (v, k) => {\n      if (iteratee(v, k)) {\n        unset(value, k)\n      } else if (isObject(v)) {\n        omitByRecursivelyInPlace(v, iteratee)\n      }\n    })\n\n    return value\n  }\n\n  return class extends MixinBase implements FirestoreRepository<TBase> {\n    firestore: Firestore\n    fields: Partial<Record<NonFunctionAndIdentifierPropertyNames<TBase>, FirestoreFieldType>> = {}\n    interceptors: FirestoreInterceptors<TBase> = {}\n    collectionName: string = ''\n    model: BaseModelBuilder<TBase>\n\n    constructor(...params: any[]) {\n      const options: FirestoreConstructorParams<TBase> = params[0]\n\n      super(...params)\n\n      this.firestore = options.firestore\n      this.collectionName = options.collectionName\n      this.model = options.model\n      this.fields = options.fields\n      this.interceptors = options.interceptors\n    }\n\n    collection(path?: string): CollectionReference<TBase> {\n      return collection(this.firestore, path || this.collectionName).withConverter(this.buildModelInstance())\n    }\n\n    buildModelInstance(): {\n      toFirestore: (data: TBase) => DocumentData\n      fromFirestore: (snap: QueryDocumentSnapshot<TBase>) => TBase\n    } {\n      return {\n        toFirestore: (data: TBase): DocumentData => {\n          const plain = data?.toPlain ? data.toPlain() : data\n\n          return omitByRecursivelyInPlace(plain, (value) => value === undefined)\n        },\n        fromFirestore: (snap: QueryDocumentSnapshot<TBase>): TBase => {\n          const data = snap.data()\n          let bindedData: NonFunctionAndIdentifierPropertiesWithNoPartial<TBase> = null\n\n          try {\n            const ids = { id: snap.id }\n\n            bindedData = bindAllDateFromObject(data)\n\n            return this.model.toInstance({ ...bindedData, ...ids })\n          } catch (error) {\n            console.info('id', snap.id)\n            console.info('data', JSON.stringify(bindedData))\n            console.error(error)\n\n            throw error\n          }\n        },\n      }\n    }\n  }\n}\n"]}
@@ -1,5 +1,5 @@
1
1
  import { add, addBusinessDays, addDays, addMonths, addYears, endOfDay, format, formatISO9075, parseISO, startOfDay, sub, } from 'date-fns';
2
- import { chunk, isBoolean, isDate, isEmpty, isInteger, isNaN, isNil, isNumber, isObject, isString, now, omit, pick, set, } from 'lodash';
2
+ import { chunk, each, isBoolean, isDate, isEmpty, isInteger, isNaN, isNil, isNumber, isObject, isString, now, omit, pick, set, unset, } from 'lodash';
3
3
  export * from './decorators';
4
4
  export * from './get';
5
5
  export * from './helpers';
@@ -9,5 +9,5 @@ export * from './log.utils';
9
9
  export * from './mixins';
10
10
  export * from './parse-datetime';
11
11
  export * from './types';
12
- export { add, addDays, addBusinessDays, addMonths, addYears, chunk, endOfDay, format, formatISO9075, isBoolean, isDate, isEmpty, isInteger, isNil, isNaN, isNumber, isObject, isString, parseISO, now, omit, pick, set, startOfDay, sub, };
13
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy9jb25uZWN0L3NyYy91dGlscy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQ0wsR0FBRyxFQUNILGVBQWUsRUFDZixPQUFPLEVBQ1AsU0FBUyxFQUNULFFBQVEsRUFFUixRQUFRLEVBQ1IsTUFBTSxFQUNOLGFBQWEsRUFDYixRQUFRLEVBQ1IsVUFBVSxFQUNWLEdBQUcsR0FDSixNQUFNLFVBQVUsQ0FBQTtBQUNqQixPQUFPLEVBQ0wsS0FBSyxFQUNMLFNBQVMsRUFDVCxNQUFNLEVBQ04sT0FBTyxFQUNQLFNBQVMsRUFDVCxLQUFLLEVBQ0wsS0FBSyxFQUNMLFFBQVEsRUFDUixRQUFRLEVBQ1IsUUFBUSxFQUNSLEdBQUcsRUFDSCxJQUFJLEVBQ0osSUFBSSxFQUNKLEdBQUcsR0FDSixNQUFNLFFBQVEsQ0FBQTtBQUlmLGNBQWMsY0FBYyxDQUFBO0FBQzVCLGNBQWMsT0FBTyxDQUFBO0FBQ3JCLGNBQWMsV0FBVyxDQUFBO0FBQ3pCLGNBQWMsTUFBTSxDQUFBO0FBQ3BCLGNBQWMsV0FBVyxDQUFBO0FBQ3pCLGNBQWMsYUFBYSxDQUFBO0FBQzNCLGNBQWMsVUFBVSxDQUFBO0FBQ3hCLGNBQWMsa0JBQWtCLENBQUE7QUFDaEMsY0FBYyxTQUFTLENBQUE7QUFDdkIsT0FBTyxFQUNMLEdBQUcsRUFDSCxPQUFPLEVBQ1AsZUFBZSxFQUNmLFNBQVMsRUFDVCxRQUFRLEVBQ1IsS0FBSyxFQUNMLFFBQVEsRUFDUixNQUFNLEVBQ04sYUFBYSxFQUNiLFNBQVMsRUFDVCxNQUFNLEVBQ04sT0FBTyxFQUNQLFNBQVMsRUFDVCxLQUFLLEVBQ0wsS0FBSyxFQUNMLFFBQVEsRUFDUixRQUFRLEVBQ1IsUUFBUSxFQUNSLFFBQVEsRUFDUixHQUFHLEVBQ0gsSUFBSSxFQUNKLElBQUksRUFDSixHQUFHLEVBQ0gsVUFBVSxFQUNWLEdBQUcsR0FDSixDQUFBIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcbiAgYWRkLFxuICBhZGRCdXNpbmVzc0RheXMsXG4gIGFkZERheXMsXG4gIGFkZE1vbnRocyxcbiAgYWRkWWVhcnMsXG4gIER1cmF0aW9uLFxuICBlbmRPZkRheSxcbiAgZm9ybWF0LFxuICBmb3JtYXRJU085MDc1LFxuICBwYXJzZUlTTyxcbiAgc3RhcnRPZkRheSxcbiAgc3ViLFxufSBmcm9tICdkYXRlLWZucydcbmltcG9ydCB7XG4gIGNodW5rLFxuICBpc0Jvb2xlYW4sXG4gIGlzRGF0ZSxcbiAgaXNFbXB0eSxcbiAgaXNJbnRlZ2VyLFxuICBpc05hTixcbiAgaXNOaWwsXG4gIGlzTnVtYmVyLFxuICBpc09iamVjdCxcbiAgaXNTdHJpbmcsXG4gIG5vdyxcbiAgb21pdCxcbiAgcGljayxcbiAgc2V0LFxufSBmcm9tICdsb2Rhc2gnXG5cbmV4cG9ydCB0eXBlIERhdGVEdXJhdGlvbiA9IER1cmF0aW9uXG5cbmV4cG9ydCAqIGZyb20gJy4vZGVjb3JhdG9ycydcbmV4cG9ydCAqIGZyb20gJy4vZ2V0J1xuZXhwb3J0ICogZnJvbSAnLi9oZWxwZXJzJ1xuZXhwb3J0ICogZnJvbSAnLi9pcydcbmV4cG9ydCAqIGZyb20gJy4vaXMtdXVpZCdcbmV4cG9ydCAqIGZyb20gJy4vbG9nLnV0aWxzJ1xuZXhwb3J0ICogZnJvbSAnLi9taXhpbnMnXG5leHBvcnQgKiBmcm9tICcuL3BhcnNlLWRhdGV0aW1lJ1xuZXhwb3J0ICogZnJvbSAnLi90eXBlcydcbmV4cG9ydCB7XG4gIGFkZCxcbiAgYWRkRGF5cyxcbiAgYWRkQnVzaW5lc3NEYXlzLFxuICBhZGRNb250aHMsXG4gIGFkZFllYXJzLFxuICBjaHVuayxcbiAgZW5kT2ZEYXksXG4gIGZvcm1hdCxcbiAgZm9ybWF0SVNPOTA3NSxcbiAgaXNCb29sZWFuLFxuICBpc0RhdGUsXG4gIGlzRW1wdHksXG4gIGlzSW50ZWdlcixcbiAgaXNOaWwsXG4gIGlzTmFOLFxuICBpc051bWJlcixcbiAgaXNPYmplY3QsXG4gIGlzU3RyaW5nLFxuICBwYXJzZUlTTyxcbiAgbm93LFxuICBvbWl0LFxuICBwaWNrLFxuICBzZXQsXG4gIHN0YXJ0T2ZEYXksXG4gIHN1Yixcbn1cbiJdfQ==
12
+ export { add, addDays, addBusinessDays, addMonths, addYears, chunk, each, endOfDay, format, formatISO9075, isBoolean, isDate, isEmpty, isInteger, isNil, isNaN, isNumber, isObject, isString, parseISO, now, omit, pick, set, startOfDay, sub, unset, };
13
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9wcm9qZWN0cy9jb25uZWN0L3NyYy91dGlscy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQ0wsR0FBRyxFQUNILGVBQWUsRUFDZixPQUFPLEVBQ1AsU0FBUyxFQUNULFFBQVEsRUFFUixRQUFRLEVBQ1IsTUFBTSxFQUNOLGFBQWEsRUFDYixRQUFRLEVBQ1IsVUFBVSxFQUNWLEdBQUcsR0FDSixNQUFNLFVBQVUsQ0FBQTtBQUNqQixPQUFPLEVBQ0wsS0FBSyxFQUNMLElBQUksRUFDSixTQUFTLEVBQ1QsTUFBTSxFQUNOLE9BQU8sRUFDUCxTQUFTLEVBQ1QsS0FBSyxFQUNMLEtBQUssRUFDTCxRQUFRLEVBQ1IsUUFBUSxFQUNSLFFBQVEsRUFDUixHQUFHLEVBQ0gsSUFBSSxFQUNKLElBQUksRUFDSixHQUFHLEVBQ0gsS0FBSyxHQUNOLE1BQU0sUUFBUSxDQUFBO0FBSWYsY0FBYyxjQUFjLENBQUE7QUFDNUIsY0FBYyxPQUFPLENBQUE7QUFDckIsY0FBYyxXQUFXLENBQUE7QUFDekIsY0FBYyxNQUFNLENBQUE7QUFDcEIsY0FBYyxXQUFXLENBQUE7QUFDekIsY0FBYyxhQUFhLENBQUE7QUFDM0IsY0FBYyxVQUFVLENBQUE7QUFDeEIsY0FBYyxrQkFBa0IsQ0FBQTtBQUNoQyxjQUFjLFNBQVMsQ0FBQTtBQUN2QixPQUFPLEVBQ0wsR0FBRyxFQUNILE9BQU8sRUFDUCxlQUFlLEVBQ2YsU0FBUyxFQUNULFFBQVEsRUFDUixLQUFLLEVBQ0wsSUFBSSxFQUNKLFFBQVEsRUFDUixNQUFNLEVBQ04sYUFBYSxFQUNiLFNBQVMsRUFDVCxNQUFNLEVBQ04sT0FBTyxFQUNQLFNBQVMsRUFDVCxLQUFLLEVBQ0wsS0FBSyxFQUNMLFFBQVEsRUFDUixRQUFRLEVBQ1IsUUFBUSxFQUNSLFFBQVEsRUFDUixHQUFHLEVBQ0gsSUFBSSxFQUNKLElBQUksRUFDSixHQUFHLEVBQ0gsVUFBVSxFQUNWLEdBQUcsRUFDSCxLQUFLLEdBQ04sQ0FBQSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7XG4gIGFkZCxcbiAgYWRkQnVzaW5lc3NEYXlzLFxuICBhZGREYXlzLFxuICBhZGRNb250aHMsXG4gIGFkZFllYXJzLFxuICBEdXJhdGlvbixcbiAgZW5kT2ZEYXksXG4gIGZvcm1hdCxcbiAgZm9ybWF0SVNPOTA3NSxcbiAgcGFyc2VJU08sXG4gIHN0YXJ0T2ZEYXksXG4gIHN1Yixcbn0gZnJvbSAnZGF0ZS1mbnMnXG5pbXBvcnQge1xuICBjaHVuayxcbiAgZWFjaCxcbiAgaXNCb29sZWFuLFxuICBpc0RhdGUsXG4gIGlzRW1wdHksXG4gIGlzSW50ZWdlcixcbiAgaXNOYU4sXG4gIGlzTmlsLFxuICBpc051bWJlcixcbiAgaXNPYmplY3QsXG4gIGlzU3RyaW5nLFxuICBub3csXG4gIG9taXQsXG4gIHBpY2ssXG4gIHNldCxcbiAgdW5zZXQsXG59IGZyb20gJ2xvZGFzaCdcblxuZXhwb3J0IHR5cGUgRGF0ZUR1cmF0aW9uID0gRHVyYXRpb25cblxuZXhwb3J0ICogZnJvbSAnLi9kZWNvcmF0b3JzJ1xuZXhwb3J0ICogZnJvbSAnLi9nZXQnXG5leHBvcnQgKiBmcm9tICcuL2hlbHBlcnMnXG5leHBvcnQgKiBmcm9tICcuL2lzJ1xuZXhwb3J0ICogZnJvbSAnLi9pcy11dWlkJ1xuZXhwb3J0ICogZnJvbSAnLi9sb2cudXRpbHMnXG5leHBvcnQgKiBmcm9tICcuL21peGlucydcbmV4cG9ydCAqIGZyb20gJy4vcGFyc2UtZGF0ZXRpbWUnXG5leHBvcnQgKiBmcm9tICcuL3R5cGVzJ1xuZXhwb3J0IHtcbiAgYWRkLFxuICBhZGREYXlzLFxuICBhZGRCdXNpbmVzc0RheXMsXG4gIGFkZE1vbnRocyxcbiAgYWRkWWVhcnMsXG4gIGNodW5rLFxuICBlYWNoLFxuICBlbmRPZkRheSxcbiAgZm9ybWF0LFxuICBmb3JtYXRJU085MDc1LFxuICBpc0Jvb2xlYW4sXG4gIGlzRGF0ZSxcbiAgaXNFbXB0eSxcbiAgaXNJbnRlZ2VyLFxuICBpc05pbCxcbiAgaXNOYU4sXG4gIGlzTnVtYmVyLFxuICBpc09iamVjdCxcbiAgaXNTdHJpbmcsXG4gIHBhcnNlSVNPLFxuICBub3csXG4gIG9taXQsXG4gIHBpY2ssXG4gIHNldCxcbiAgc3RhcnRPZkRheSxcbiAgc3ViLFxuICB1bnNldCxcbn1cbiJdfQ==
@@ -3,8 +3,8 @@ import { plainToInstance, instanceToPlain, Expose, Type } from 'class-transforme
3
3
  import { __decorate, __metadata, __awaiter, __rest } from 'tslib';
4
4
  import { parseISO } from 'date-fns';
5
5
  export { add, addBusinessDays, addDays, addMonths, addYears, endOfDay, format, formatISO9075, parseISO, startOfDay, sub } from 'date-fns';
6
- import { isNil, isArray, first, last, flatten, compact, get as get$1, isString, isNumber, isDate, set, isObject, isEmpty, chunk, isBoolean, isInteger, isNaN as isNaN$1, omit } from 'lodash';
7
- export { chunk, isBoolean, isDate, isEmpty, isInteger, isNaN, isNil, isNumber, isObject, isString, now, omit, pick, set } from 'lodash';
6
+ import { isNil, isArray, first, last, flatten, compact, get as get$1, isString, each, unset, isObject, isNumber, isDate, set, isEmpty, chunk, isBoolean, isInteger, isNaN as isNaN$1, omit } from 'lodash';
7
+ export { chunk, each, isBoolean, isDate, isEmpty, isInteger, isNaN, isNil, isNumber, isObject, isString, now, omit, pick, set, unset } from 'lodash';
8
8
  import { Subject } from 'rxjs';
9
9
  import { debug } from 'debug';
10
10
  import { CustomError } from 'ts-custom-error';
@@ -1008,7 +1008,7 @@ class User extends BaseModel {
1008
1008
  const instance = super.toInstance(data);
1009
1009
  if (!isNil(data.firstName))
1010
1010
  instance.displayName = `${data.firstName}${!isNil(data.lastName) ? ` ${data.lastName}` : ''}`;
1011
- return;
1011
+ return instance;
1012
1012
  }
1013
1013
  toPlain() {
1014
1014
  const plain = super.toPlain();
@@ -1754,6 +1754,17 @@ const withFirestore = (MixinBase) => {
1754
1754
  ? data[key].map((element) => (isObjectsAndNoDate(element) ? bindAllDateFromObject(element) : element))
1755
1755
  : bindDate(data[key], key) })), {});
1756
1756
  };
1757
+ const omitByRecursivelyInPlace = (value, iteratee) => {
1758
+ each(value, (v, k) => {
1759
+ if (iteratee(v, k)) {
1760
+ unset(value, k);
1761
+ }
1762
+ else if (isObject(v)) {
1763
+ omitByRecursivelyInPlace(v, iteratee);
1764
+ }
1765
+ });
1766
+ return value;
1767
+ };
1757
1768
  return class extends MixinBase {
1758
1769
  constructor(...params) {
1759
1770
  const options = params[0];
@@ -1772,7 +1783,10 @@ const withFirestore = (MixinBase) => {
1772
1783
  }
1773
1784
  buildModelInstance() {
1774
1785
  return {
1775
- toFirestore: (data) => ((data === null || data === void 0 ? void 0 : data.toPlain) ? data.toPlain() : data),
1786
+ toFirestore: (data) => {
1787
+ const plain = (data === null || data === void 0 ? void 0 : data.toPlain) ? data.toPlain() : data;
1788
+ return omitByRecursivelyInPlace(plain, (value) => value === undefined);
1789
+ },
1776
1790
  fromFirestore: (snap) => {
1777
1791
  const data = snap.data();
1778
1792
  let bindedData = null;