@infrab4a/connect 4.0.0-beta.27 → 4.0.0-beta.28
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2020/infra/firebase/firestore/mixins/with-firestore.mixin.mjs +17 -2
- package/esm2020/utils/index.mjs +3 -3
- package/fesm2015/infrab4a-connect.mjs +17 -3
- package/fesm2015/infrab4a-connect.mjs.map +1 -1
- package/fesm2020/infrab4a-connect.mjs +17 -3
- package/fesm2020/infrab4a-connect.mjs.map +1 -1
- package/package.json +1 -1
- package/utils/index.d.ts +2 -2
|
@@ -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) =>
|
|
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":"AAAA,OAAO,EAAE,UAAU,EAAuE,MAAM,oBAAoB,CAAA;AAQpH,OAAO,EAAE,IAAI,EAAE,QAAQ,EAAqC,KAAK,EAAE,MAAM,mBAAmB,CAAA;AAY5F,MAAM,CAAC,MAAM,aAAa,GAAG,CAC3B,SAAY,EAC+F,EAAE;IAC7G,MAAM,kBAAkB,GAAG,CAAC,IAAS,EAAW,EAAE,CAChD,IAAI;QACJ,CAAC,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC;QACpB,OAAO,IAAI,KAAK,QAAQ;QACxB,IAAI,EAAE,WAAW,CAAC,IAAI,KAAK,WAAW;QACtC,CAAC,CAAC,SAAS,IAAI,IAAI,CAAC,CAAA;IACtB,MAAM,QAAQ,GAAG,CAAC,IAAS,EAAE,OAAe,EAAuB,EAAE;QACnE,IAAI,IAAI,EAAE,WAAW,CAAC,IAAI,KAAK,WAAW;YAAE,OAAO,IAAI,CAAC,MAAM,EAAE,CAAA;QAChE,IAAI,IAAI,IAAI,OAAO,IAAI,KAAK,QAAQ,IAAI,SAAS,IAAI,IAAI;YAAE,OAAO,IAAI,IAAI,CAAC,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,CAAA;QAC/F,IAAI,OAAO,IAAI,KAAK,QAAQ,IAAI,CAAC,WAAW,EAAE,WAAW,CAAC,CAAC,QAAQ,CAAC,OAAO,CAAC;YAAE,OAAO,IAAI,IAAI,CAAC,IAAI,CAAC,CAAA;QAEnG,OAAO,IAAI,CAAA;IACb,CAAC,CAAA;IACD,MAAM,qBAAqB,GAAG,CAAC,IAAyB,EAA0D,EAAE;QAClH,OAAO,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,MAAM,CAC7B,CAAC,MAAM,EAAE,GAAG,EAAE,EAAE,CAAC,CAAC;YAChB,GAAG,MAAM;YACT,CAAC,GAAG,CAAC,EAAE,kBAAkB,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;gBAClC,CAAC,CAAC,qBAAqB,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;gBAClC,CAAC,CAAC,KAAK,CAAC,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;oBAC1B,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,OAAY,EAAE,EAAE,CAAC,CAAC,kBAAkB,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,qBAAqB,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC;oBAC3G,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,GAAG,CAAC;SAC7B,CAAC,EACF,EAA4D,CAC7D,CAAA;IACH,CAAC,CAAA;IACD,MAAM,wBAAwB,GAAG,CAAC,KAAU,EAAE,QAA8C,EAAO,EAAE;QACnG,IAAI,CAAC,KAAK,EAAE,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE;YACnB,IAAI,QAAQ,CAAC,CAAC,EAAE,CAAC,CAAC,EAAE;gBAClB,KAAK,CAAC,KAAK,EAAE,CAAC,CAAC,CAAA;aAChB;iBAAM,IAAI,QAAQ,CAAC,CAAC,CAAC,EAAE;gBACtB,wBAAwB,CAAC,CAAC,EAAE,QAAQ,CAAC,CAAA;aACtC;QACH,CAAC,CAAC,CAAA;QAEF,OAAO,KAAK,CAAA;IACd,CAAC,CAAA;IAED,OAAO,KAAM,SAAQ,SAAS;QAO5B,YAAY,GAAG,MAAa;YAC1B,MAAM,OAAO,GAAsC,MAAM,CAAC,CAAC,CAAC,CAAA;YAE5D,KAAK,CAAC,GAAG,MAAM,CAAC,CAAA;YARlB,WAAM,GAAsF,EAAE,CAAA;YAC9F,iBAAY,GAAiC,EAAE,CAAA;YAC/C,mBAAc,GAAW,EAAE,CAAA;YAQzB,IAAI,CAAC,SAAS,GAAG,OAAO,CAAC,SAAS,CAAA;YAClC,IAAI,CAAC,cAAc,GAAG,OAAO,CAAC,cAAc,CAAA;YAC5C,IAAI,CAAC,KAAK,GAAG,OAAO,CAAC,KAAK,CAAA;YAC1B,IAAI,CAAC,MAAM,GAAG,OAAO,CAAC,MAAM,CAAA;YAC5B,IAAI,CAAC,YAAY,GAAG,OAAO,CAAC,YAAY,CAAA;QAC1C,CAAC;QAED,UAAU,CAAC,IAAa;YACtB,OAAO,UAAU,CAAC,IAAI,CAAC,SAAS,EAAE,IAAI,IAAI,IAAI,CAAC,cAAc,CAAC,CAAC,aAAa,CAAC,IAAI,CAAC,kBAAkB,EAAE,CAAC,CAAA;QACzG,CAAC;QAED,kBAAkB;YAIhB,OAAO;gBACL,WAAW,EAAE,CAAC,IAAW,EAAgB,EAAE;oBACzC,MAAM,KAAK,GAAG,IAAI,EAAE,OAAO,CAAC,CAAC,CAAC,IAAI,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC,IAAI,CAAA;oBAEnD,OAAO,wBAAwB,CAAC,KAAK,EAAE,CAAC,KAAK,EAAE,EAAE,CAAC,KAAK,KAAK,SAAS,CAAC,CAAA;gBACxE,CAAC;gBACD,aAAa,EAAE,CAAC,IAAkC,EAAS,EAAE;oBAC3D,MAAM,IAAI,GAAG,IAAI,CAAC,IAAI,EAAE,CAAA;oBACxB,IAAI,UAAU,GAA2D,IAAI,CAAA;oBAE7E,IAAI;wBACF,MAAM,GAAG,GAAG,EAAE,EAAE,EAAE,IAAI,CAAC,EAAE,EAAE,CAAA;wBAE3B,UAAU,GAAG,qBAAqB,CAAC,IAAI,CAAC,CAAA;wBAExC,OAAO,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,EAAE,GAAG,UAAU,EAAE,GAAG,GAAG,EAAE,CAAC,CAAA;qBACxD;oBAAC,OAAO,KAAK,EAAE;wBACd,OAAO,CAAC,IAAI,CAAC,IAAI,EAAE,IAAI,CAAC,EAAE,CAAC,CAAA;wBAC3B,OAAO,CAAC,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,CAAC,CAAA;wBAChD,OAAO,CAAC,KAAK,CAAC,KAAK,CAAC,CAAA;wBAEpB,MAAM,KAAK,CAAA;qBACZ;gBACH,CAAC;aACF,CAAA;QACH,CAAC;KACF,CAAA;AACH,CAAC,CAAA","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"]}
|
package/esm2020/utils/index.mjs
CHANGED
|
@@ -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,
|
|
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,
|
|
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';
|
|
@@ -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) =>
|
|
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;
|