@cravery/firebase 0.0.37 → 0.0.38
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/dist/converters/equipment/content.d.ts.map +1 -1
- package/dist/converters/equipment/content.js.map +1 -1
- package/dist/converters/equipment/meta.d.ts.map +1 -1
- package/dist/converters/equipment/meta.js.map +1 -1
- package/dist/converters/ingredients/content.d.ts.map +1 -1
- package/dist/converters/ingredients/content.js.map +1 -1
- package/dist/converters/ingredients/meta.d.ts.map +1 -1
- package/dist/converters/ingredients/meta.js.map +1 -1
- package/dist/converters/ingredients/user.d.ts.map +1 -1
- package/dist/converters/ingredients/user.js.map +1 -1
- package/package.json +33 -33
- package/src/converters/equipment/content.ts +18 -17
- package/src/converters/equipment/index.ts +3 -3
- package/src/converters/equipment/meta.ts +37 -36
- package/src/converters/equipment/user.ts +36 -36
- package/src/converters/ingredients/content.ts +18 -17
- package/src/converters/ingredients/index.ts +3 -3
- package/src/converters/ingredients/meta.ts +37 -36
- package/src/converters/ingredients/user.ts +40 -38
- package/src/converters/recipes/comment.ts +36 -36
- package/src/converters/recipes/content.ts +17 -17
- package/src/converters/recipes/index.ts +3 -3
- package/src/converters/recipes/meta.ts +36 -36
- package/src/converters/reports/index.ts +2 -2
- package/src/converters/reports/report.ts +36 -36
- package/src/converters/reports/update.ts +36 -36
- package/src/converters/settings/index.ts +1 -1
- package/src/converters/settings/settings.ts +36 -36
- package/src/converters/subscriptions/index.ts +1 -1
- package/src/converters/subscriptions/subscription.ts +85 -85
- package/src/converters/users/bookmark.ts +36 -36
- package/src/converters/users/index.ts +3 -3
- package/src/converters/users/profile.ts +36 -36
- package/src/converters/users/user.ts +36 -36
- package/src/lib/index.ts +2 -2
- package/src/lib/strip-undefined.ts +32 -32
- package/src/lib/timestamp.ts +44 -44
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"content.d.ts","sourceRoot":"","sources":["../../../src/converters/equipment/content.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,sBAAsB,EAGvB,MAAM,0BAA0B,CAAC;AAClC,OAAO,KAAK,EAAE,sBAAsB,EAAE,MAAM,eAAe,CAAC;AAG5D,eAAO,MAAM,yBAAyB,EAAE,sBAAsB,CAAC,sBAAsB,
|
|
1
|
+
{"version":3,"file":"content.d.ts","sourceRoot":"","sources":["../../../src/converters/equipment/content.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,sBAAsB,EAGvB,MAAM,0BAA0B,CAAC;AAClC,OAAO,KAAK,EAAE,sBAAsB,EAAE,MAAM,eAAe,CAAC;AAG5D,eAAO,MAAM,yBAAyB,EAAE,sBAAsB,CAAC,sBAAsB,CASlF,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"content.js","sourceRoot":"","sources":["../../../src/converters/equipment/content.ts"],"names":[],"mappings":";;;AAMA,mCAA2C;AAE9B,QAAA,yBAAyB,
|
|
1
|
+
{"version":3,"file":"content.js","sourceRoot":"","sources":["../../../src/converters/equipment/content.ts"],"names":[],"mappings":";;;AAMA,mCAA2C;AAE9B,QAAA,yBAAyB,GACpC;IACE,WAAW,CAAC,OAA+B;QACzC,OAAO,IAAA,oBAAc,oBAAM,OAAO,EAAG,CAAC;IACxC,CAAC;IAED,aAAa,CAAC,QAA+B;QAC3C,OAAO,QAAQ,CAAC,IAAI,EAA4B,CAAC;IACnD,CAAC;CACF,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"meta.d.ts","sourceRoot":"","sources":["../../../src/converters/equipment/meta.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,sBAAsB,EAGvB,MAAM,0BAA0B,CAAC;AAClC,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,eAAe,CAAC;AASzD,eAAO,MAAM,sBAAsB,EAAE,sBAAsB,CAAC,mBAAmB,
|
|
1
|
+
{"version":3,"file":"meta.d.ts","sourceRoot":"","sources":["../../../src/converters/equipment/meta.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,sBAAsB,EAGvB,MAAM,0BAA0B,CAAC;AAClC,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,eAAe,CAAC;AASzD,eAAO,MAAM,sBAAsB,EAAE,sBAAsB,CAAC,mBAAmB,CAsB5E,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"meta.js","sourceRoot":"","sources":["../../../src/converters/equipment/meta.ts"],"names":[],"mappings":";;;;;;;;;;;;;;AAMA,mCAMmB;AAEN,QAAA,sBAAsB,
|
|
1
|
+
{"version":3,"file":"meta.js","sourceRoot":"","sources":["../../../src/converters/equipment/meta.ts"],"names":[],"mappings":";;;;;;;;;;;;;;AAMA,mCAMmB;AAEN,QAAA,sBAAsB,GACjC;IACE,WAAW,CAAC,IAAyB;QACnC,MAAM,EAAE,EAAE,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,KAAc,IAAI,EAAb,IAAI,UAAK,IAAI,EAAvD,6CAAgD,CAAO,CAAC;QAC9D,OAAO,IAAA,oBAAc,kCAChB,IAAI,KACP,SAAS,EAAE,IAAA,0BAAoB,EAAC,SAAS,CAAC,EAC1C,SAAS,EAAE,IAAA,0BAAoB,EAAC,SAAS,CAAC,EAC1C,SAAS,EAAE,IAAA,kCAA4B,EAAC,SAAS,CAAC,IAClD,CAAC;IACL,CAAC;IAED,aAAa,CAAC,QAA+B;QAC3C,MAAM,KAA+C,QAAQ,CAAC,IAAI,EAAE,EAA9D,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,OAA6B,EAAxB,IAAI,cAA1C,uCAA4C,CAAkB,CAAC;QACrE,OAAO,gCACF,IAAI,KACP,EAAE,EAAE,QAAQ,CAAC,EAAE,EACf,SAAS,EAAE,IAAA,iBAAW,EAAC,SAAS,CAAC,EACjC,SAAS,EAAE,IAAA,iBAAW,EAAC,SAAS,CAAC,EACjC,SAAS,EAAE,IAAA,yBAAmB,EAAC,SAAS,CAAC,GACnB,CAAC;IAC3B,CAAC;CACF,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"content.d.ts","sourceRoot":"","sources":["../../../src/converters/ingredients/content.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,sBAAsB,EAGvB,MAAM,0BAA0B,CAAC;AAClC,OAAO,KAAK,EAAE,uBAAuB,EAAE,MAAM,eAAe,CAAC;AAG7D,eAAO,MAAM,0BAA0B,EAAE,sBAAsB,CAAC,uBAAuB,
|
|
1
|
+
{"version":3,"file":"content.d.ts","sourceRoot":"","sources":["../../../src/converters/ingredients/content.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,sBAAsB,EAGvB,MAAM,0BAA0B,CAAC;AAClC,OAAO,KAAK,EAAE,uBAAuB,EAAE,MAAM,eAAe,CAAC;AAG7D,eAAO,MAAM,0BAA0B,EAAE,sBAAsB,CAAC,uBAAuB,CASpF,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"content.js","sourceRoot":"","sources":["../../../src/converters/ingredients/content.ts"],"names":[],"mappings":";;;AAMA,mCAA2C;AAE9B,QAAA,0BAA0B,
|
|
1
|
+
{"version":3,"file":"content.js","sourceRoot":"","sources":["../../../src/converters/ingredients/content.ts"],"names":[],"mappings":";;;AAMA,mCAA2C;AAE9B,QAAA,0BAA0B,GACrC;IACE,WAAW,CAAC,OAAgC;QAC1C,OAAO,IAAA,oBAAc,oBAAM,OAAO,EAAG,CAAC;IACxC,CAAC;IAED,aAAa,CAAC,QAA+B;QAC3C,OAAO,QAAQ,CAAC,IAAI,EAA6B,CAAC;IACpD,CAAC;CACF,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"meta.d.ts","sourceRoot":"","sources":["../../../src/converters/ingredients/meta.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,sBAAsB,EAGvB,MAAM,0BAA0B,CAAC;AAClC,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,eAAe,CAAC;AAS1D,eAAO,MAAM,uBAAuB,EAAE,sBAAsB,CAAC,oBAAoB,
|
|
1
|
+
{"version":3,"file":"meta.d.ts","sourceRoot":"","sources":["../../../src/converters/ingredients/meta.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,sBAAsB,EAGvB,MAAM,0BAA0B,CAAC;AAClC,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,eAAe,CAAC;AAS1D,eAAO,MAAM,uBAAuB,EAAE,sBAAsB,CAAC,oBAAoB,CAsB9E,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"meta.js","sourceRoot":"","sources":["../../../src/converters/ingredients/meta.ts"],"names":[],"mappings":";;;;;;;;;;;;;;AAMA,mCAMmB;AAEN,QAAA,uBAAuB,
|
|
1
|
+
{"version":3,"file":"meta.js","sourceRoot":"","sources":["../../../src/converters/ingredients/meta.ts"],"names":[],"mappings":";;;;;;;;;;;;;;AAMA,mCAMmB;AAEN,QAAA,uBAAuB,GAClC;IACE,WAAW,CAAC,IAA0B;QACpC,MAAM,EAAE,EAAE,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,KAAc,IAAI,EAAb,IAAI,UAAK,IAAI,EAAvD,6CAAgD,CAAO,CAAC;QAC9D,OAAO,IAAA,oBAAc,kCAChB,IAAI,KACP,SAAS,EAAE,IAAA,0BAAoB,EAAC,SAAS,CAAC,EAC1C,SAAS,EAAE,IAAA,0BAAoB,EAAC,SAAS,CAAC,EAC1C,SAAS,EAAE,IAAA,kCAA4B,EAAC,SAAS,CAAC,IAClD,CAAC;IACL,CAAC;IAED,aAAa,CAAC,QAA+B;QAC3C,MAAM,KAA+C,QAAQ,CAAC,IAAI,EAAE,EAA9D,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,OAA6B,EAAxB,IAAI,cAA1C,uCAA4C,CAAkB,CAAC;QACrE,OAAO,gCACF,IAAI,KACP,EAAE,EAAE,QAAQ,CAAC,EAAE,EACf,SAAS,EAAE,IAAA,iBAAW,EAAC,SAAS,CAAC,EACjC,SAAS,EAAE,IAAA,iBAAW,EAAC,SAAS,CAAC,EACjC,SAAS,EAAE,IAAA,yBAAmB,EAAC,SAAS,CAAC,GAClB,CAAC;IAC5B,CAAC;CACF,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"user.d.ts","sourceRoot":"","sources":["../../../src/converters/ingredients/user.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,sBAAsB,EAGvB,MAAM,0BAA0B,CAAC;AAClC,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,eAAe,CAAC;AASpD,eAAO,MAAM,uBAAuB,EAAE,sBAAsB,CAAC,cAAc,
|
|
1
|
+
{"version":3,"file":"user.d.ts","sourceRoot":"","sources":["../../../src/converters/ingredients/user.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,sBAAsB,EAGvB,MAAM,0BAA0B,CAAC;AAClC,OAAO,KAAK,EAAE,cAAc,EAAE,MAAM,eAAe,CAAC;AASpD,eAAO,MAAM,uBAAuB,EAAE,sBAAsB,CAAC,cAAc,CAyB1E,CAAC"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"user.js","sourceRoot":"","sources":["../../../src/converters/ingredients/user.ts"],"names":[],"mappings":";;;;;;;;;;;;;;AAMA,mCAMmB;AAEN,QAAA,uBAAuB,GAA2C;IAC7E,WAAW,CAAC,UAA0B;QACpC,MAAM,EAAE,EAAE,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,
|
|
1
|
+
{"version":3,"file":"user.js","sourceRoot":"","sources":["../../../src/converters/ingredients/user.ts"],"names":[],"mappings":";;;;;;;;;;;;;;AAMA,mCAMmB;AAEN,QAAA,uBAAuB,GAA2C;IAC7E,WAAW,CAAC,UAA0B;QACpC,MAAM,EAAE,EAAE,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,KACpD,UAAU,EAD+C,IAAI,UAC7D,UAAU,EADN,0DAA2D,CACrD,CAAC;QACb,OAAO,IAAA,oBAAc,kCAChB,IAAI,KACP,SAAS,EAAE,IAAA,0BAAoB,EAAC,SAAS,CAAC,EAC1C,SAAS,EAAE,IAAA,0BAAoB,EAAC,SAAS,CAAC,EAC1C,SAAS,EAAE,IAAA,kCAA4B,EAAC,SAAS,CAAC,EAClD,SAAS,EAAE,IAAA,kCAA4B,EAAC,SAAS,CAAC,IAClD,CAAC;IACL,CAAC;IAED,aAAa,CAAC,QAA+B;QAC3C,MAAM,KACJ,QAAQ,CAAC,IAAI,EAAE,EADX,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,EAAE,SAAS,OACjC,EADsC,IAAI,cAArD,oDAAuD,CAC5C,CAAC;QAClB,OAAO,gCACF,IAAI,KACP,EAAE,EAAE,QAAQ,CAAC,EAAE,EACf,SAAS,EAAE,IAAA,iBAAW,EAAC,SAAS,CAAC,EACjC,SAAS,EAAE,IAAA,iBAAW,EAAC,SAAS,CAAC,EACjC,SAAS,EAAE,IAAA,yBAAmB,EAAC,SAAS,CAAC,EACzC,SAAS,EAAE,IAAA,yBAAmB,EAAC,SAAS,CAAC,GACxB,CAAC;IACtB,CAAC;CACF,CAAC"}
|
package/package.json
CHANGED
|
@@ -1,33 +1,33 @@
|
|
|
1
|
-
{
|
|
2
|
-
"name": "@cravery/firebase",
|
|
3
|
-
"version": "0.0.
|
|
4
|
-
"description": "Shared Firebase Admin SDK utilities for Cravery",
|
|
5
|
-
"main": "dist/index.js",
|
|
6
|
-
"types": "dist/index.d.ts",
|
|
7
|
-
"exports": {
|
|
8
|
-
".": {
|
|
9
|
-
"types": "./dist/index.d.ts",
|
|
10
|
-
"default": "./dist/index.js"
|
|
11
|
-
}
|
|
12
|
-
},
|
|
13
|
-
"scripts": {
|
|
14
|
-
"build": "tsc",
|
|
15
|
-
"build:watch": "tsc --watch",
|
|
16
|
-
"clean": "rimraf dist && npm run build"
|
|
17
|
-
},
|
|
18
|
-
"keywords": [],
|
|
19
|
-
"files": [
|
|
20
|
-
"dist/**/*",
|
|
21
|
-
"src/**/*"
|
|
22
|
-
],
|
|
23
|
-
"peerDependencies": {
|
|
24
|
-
"firebase-admin": "^13.6.0"
|
|
25
|
-
},
|
|
26
|
-
"devDependencies": {
|
|
27
|
-
"rimraf": "^6.1.2",
|
|
28
|
-
"typescript": "^5.9.3"
|
|
29
|
-
},
|
|
30
|
-
"dependencies": {
|
|
31
|
-
"@cravery/core": "^0.0.
|
|
32
|
-
}
|
|
33
|
-
}
|
|
1
|
+
{
|
|
2
|
+
"name": "@cravery/firebase",
|
|
3
|
+
"version": "0.0.38",
|
|
4
|
+
"description": "Shared Firebase Admin SDK utilities for Cravery",
|
|
5
|
+
"main": "dist/index.js",
|
|
6
|
+
"types": "dist/index.d.ts",
|
|
7
|
+
"exports": {
|
|
8
|
+
".": {
|
|
9
|
+
"types": "./dist/index.d.ts",
|
|
10
|
+
"default": "./dist/index.js"
|
|
11
|
+
}
|
|
12
|
+
},
|
|
13
|
+
"scripts": {
|
|
14
|
+
"build": "tsc",
|
|
15
|
+
"build:watch": "tsc --watch",
|
|
16
|
+
"clean": "rimraf dist && npm run build"
|
|
17
|
+
},
|
|
18
|
+
"keywords": [],
|
|
19
|
+
"files": [
|
|
20
|
+
"dist/**/*",
|
|
21
|
+
"src/**/*"
|
|
22
|
+
],
|
|
23
|
+
"peerDependencies": {
|
|
24
|
+
"firebase-admin": "^13.6.0"
|
|
25
|
+
},
|
|
26
|
+
"devDependencies": {
|
|
27
|
+
"rimraf": "^6.1.2",
|
|
28
|
+
"typescript": "^5.9.3"
|
|
29
|
+
},
|
|
30
|
+
"dependencies": {
|
|
31
|
+
"@cravery/core": "^0.0.61"
|
|
32
|
+
}
|
|
33
|
+
}
|
|
@@ -1,17 +1,18 @@
|
|
|
1
|
-
import {
|
|
2
|
-
FirestoreDataConverter,
|
|
3
|
-
QueryDocumentSnapshot,
|
|
4
|
-
DocumentData,
|
|
5
|
-
} from "firebase-admin/firestore";
|
|
6
|
-
import type { EquipmentEntityContent } from "@cravery/core";
|
|
7
|
-
import { stripUndefined } from "../../lib";
|
|
8
|
-
|
|
9
|
-
export const equipmentContentConverter: FirestoreDataConverter<EquipmentEntityContent> =
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
}
|
|
1
|
+
import {
|
|
2
|
+
FirestoreDataConverter,
|
|
3
|
+
QueryDocumentSnapshot,
|
|
4
|
+
DocumentData,
|
|
5
|
+
} from "firebase-admin/firestore";
|
|
6
|
+
import type { EquipmentEntityContent } from "@cravery/core";
|
|
7
|
+
import { stripUndefined } from "../../lib";
|
|
8
|
+
|
|
9
|
+
export const equipmentContentConverter: FirestoreDataConverter<EquipmentEntityContent> =
|
|
10
|
+
{
|
|
11
|
+
toFirestore(content: EquipmentEntityContent): DocumentData {
|
|
12
|
+
return stripUndefined({ ...content });
|
|
13
|
+
},
|
|
14
|
+
|
|
15
|
+
fromFirestore(snapshot: QueryDocumentSnapshot): EquipmentEntityContent {
|
|
16
|
+
return snapshot.data() as EquipmentEntityContent;
|
|
17
|
+
},
|
|
18
|
+
};
|
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
export * from "./content";
|
|
2
|
-
export * from "./meta";
|
|
3
|
-
export * from "./user";
|
|
1
|
+
export * from "./content";
|
|
2
|
+
export * from "./meta";
|
|
3
|
+
export * from "./user";
|
|
@@ -1,36 +1,37 @@
|
|
|
1
|
-
import {
|
|
2
|
-
FirestoreDataConverter,
|
|
3
|
-
QueryDocumentSnapshot,
|
|
4
|
-
DocumentData,
|
|
5
|
-
} from "firebase-admin/firestore";
|
|
6
|
-
import type { EquipmentEntityMeta } from "@cravery/core";
|
|
7
|
-
import {
|
|
8
|
-
toTimestamp,
|
|
9
|
-
toOptionalTimestamp,
|
|
10
|
-
toFirestoreTimestamp,
|
|
11
|
-
toOptionalFirestoreTimestamp,
|
|
12
|
-
stripUndefined,
|
|
13
|
-
} from "../../lib";
|
|
14
|
-
|
|
15
|
-
export const equipmentMetaConverter: FirestoreDataConverter<EquipmentEntityMeta> =
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
}
|
|
1
|
+
import {
|
|
2
|
+
FirestoreDataConverter,
|
|
3
|
+
QueryDocumentSnapshot,
|
|
4
|
+
DocumentData,
|
|
5
|
+
} from "firebase-admin/firestore";
|
|
6
|
+
import type { EquipmentEntityMeta } from "@cravery/core";
|
|
7
|
+
import {
|
|
8
|
+
toTimestamp,
|
|
9
|
+
toOptionalTimestamp,
|
|
10
|
+
toFirestoreTimestamp,
|
|
11
|
+
toOptionalFirestoreTimestamp,
|
|
12
|
+
stripUndefined,
|
|
13
|
+
} from "../../lib";
|
|
14
|
+
|
|
15
|
+
export const equipmentMetaConverter: FirestoreDataConverter<EquipmentEntityMeta> =
|
|
16
|
+
{
|
|
17
|
+
toFirestore(meta: EquipmentEntityMeta): DocumentData {
|
|
18
|
+
const { id, createdAt, updatedAt, deletedAt, ...rest } = meta;
|
|
19
|
+
return stripUndefined({
|
|
20
|
+
...rest,
|
|
21
|
+
createdAt: toFirestoreTimestamp(createdAt),
|
|
22
|
+
updatedAt: toFirestoreTimestamp(updatedAt),
|
|
23
|
+
deletedAt: toOptionalFirestoreTimestamp(deletedAt),
|
|
24
|
+
});
|
|
25
|
+
},
|
|
26
|
+
|
|
27
|
+
fromFirestore(snapshot: QueryDocumentSnapshot): EquipmentEntityMeta {
|
|
28
|
+
const { createdAt, updatedAt, deletedAt, ...rest } = snapshot.data();
|
|
29
|
+
return {
|
|
30
|
+
...rest,
|
|
31
|
+
id: snapshot.id,
|
|
32
|
+
createdAt: toTimestamp(createdAt),
|
|
33
|
+
updatedAt: toTimestamp(updatedAt),
|
|
34
|
+
deletedAt: toOptionalTimestamp(deletedAt),
|
|
35
|
+
} as EquipmentEntityMeta;
|
|
36
|
+
},
|
|
37
|
+
};
|
|
@@ -1,36 +1,36 @@
|
|
|
1
|
-
import {
|
|
2
|
-
FirestoreDataConverter,
|
|
3
|
-
QueryDocumentSnapshot,
|
|
4
|
-
DocumentData,
|
|
5
|
-
} from "firebase-admin/firestore";
|
|
6
|
-
import type { UserEquipment } from "@cravery/core";
|
|
7
|
-
import {
|
|
8
|
-
toTimestamp,
|
|
9
|
-
toOptionalTimestamp,
|
|
10
|
-
toFirestoreTimestamp,
|
|
11
|
-
toOptionalFirestoreTimestamp,
|
|
12
|
-
stripUndefined,
|
|
13
|
-
} from "../../lib";
|
|
14
|
-
|
|
15
|
-
export const userEquipmentConverter: FirestoreDataConverter<UserEquipment> = {
|
|
16
|
-
toFirestore(equipment: UserEquipment): DocumentData {
|
|
17
|
-
const { id, createdAt, updatedAt, deletedAt, ...rest } = equipment;
|
|
18
|
-
return stripUndefined({
|
|
19
|
-
...rest,
|
|
20
|
-
createdAt: toFirestoreTimestamp(createdAt),
|
|
21
|
-
updatedAt: toFirestoreTimestamp(updatedAt),
|
|
22
|
-
deletedAt: toOptionalFirestoreTimestamp(deletedAt),
|
|
23
|
-
});
|
|
24
|
-
},
|
|
25
|
-
|
|
26
|
-
fromFirestore(snapshot: QueryDocumentSnapshot): UserEquipment {
|
|
27
|
-
const { createdAt, updatedAt, deletedAt, ...rest } = snapshot.data();
|
|
28
|
-
return {
|
|
29
|
-
...rest,
|
|
30
|
-
id: snapshot.id,
|
|
31
|
-
createdAt: toTimestamp(createdAt),
|
|
32
|
-
updatedAt: toTimestamp(updatedAt),
|
|
33
|
-
deletedAt: toOptionalTimestamp(deletedAt),
|
|
34
|
-
} as UserEquipment;
|
|
35
|
-
},
|
|
36
|
-
};
|
|
1
|
+
import {
|
|
2
|
+
FirestoreDataConverter,
|
|
3
|
+
QueryDocumentSnapshot,
|
|
4
|
+
DocumentData,
|
|
5
|
+
} from "firebase-admin/firestore";
|
|
6
|
+
import type { UserEquipment } from "@cravery/core";
|
|
7
|
+
import {
|
|
8
|
+
toTimestamp,
|
|
9
|
+
toOptionalTimestamp,
|
|
10
|
+
toFirestoreTimestamp,
|
|
11
|
+
toOptionalFirestoreTimestamp,
|
|
12
|
+
stripUndefined,
|
|
13
|
+
} from "../../lib";
|
|
14
|
+
|
|
15
|
+
export const userEquipmentConverter: FirestoreDataConverter<UserEquipment> = {
|
|
16
|
+
toFirestore(equipment: UserEquipment): DocumentData {
|
|
17
|
+
const { id, createdAt, updatedAt, deletedAt, ...rest } = equipment;
|
|
18
|
+
return stripUndefined({
|
|
19
|
+
...rest,
|
|
20
|
+
createdAt: toFirestoreTimestamp(createdAt),
|
|
21
|
+
updatedAt: toFirestoreTimestamp(updatedAt),
|
|
22
|
+
deletedAt: toOptionalFirestoreTimestamp(deletedAt),
|
|
23
|
+
});
|
|
24
|
+
},
|
|
25
|
+
|
|
26
|
+
fromFirestore(snapshot: QueryDocumentSnapshot): UserEquipment {
|
|
27
|
+
const { createdAt, updatedAt, deletedAt, ...rest } = snapshot.data();
|
|
28
|
+
return {
|
|
29
|
+
...rest,
|
|
30
|
+
id: snapshot.id,
|
|
31
|
+
createdAt: toTimestamp(createdAt),
|
|
32
|
+
updatedAt: toTimestamp(updatedAt),
|
|
33
|
+
deletedAt: toOptionalTimestamp(deletedAt),
|
|
34
|
+
} as UserEquipment;
|
|
35
|
+
},
|
|
36
|
+
};
|
|
@@ -1,17 +1,18 @@
|
|
|
1
|
-
import {
|
|
2
|
-
FirestoreDataConverter,
|
|
3
|
-
QueryDocumentSnapshot,
|
|
4
|
-
DocumentData,
|
|
5
|
-
} from "firebase-admin/firestore";
|
|
6
|
-
import type { IngredientEntityContent } from "@cravery/core";
|
|
7
|
-
import { stripUndefined } from "../../lib";
|
|
8
|
-
|
|
9
|
-
export const ingredientContentConverter: FirestoreDataConverter<IngredientEntityContent> =
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
}
|
|
1
|
+
import {
|
|
2
|
+
FirestoreDataConverter,
|
|
3
|
+
QueryDocumentSnapshot,
|
|
4
|
+
DocumentData,
|
|
5
|
+
} from "firebase-admin/firestore";
|
|
6
|
+
import type { IngredientEntityContent } from "@cravery/core";
|
|
7
|
+
import { stripUndefined } from "../../lib";
|
|
8
|
+
|
|
9
|
+
export const ingredientContentConverter: FirestoreDataConverter<IngredientEntityContent> =
|
|
10
|
+
{
|
|
11
|
+
toFirestore(content: IngredientEntityContent): DocumentData {
|
|
12
|
+
return stripUndefined({ ...content });
|
|
13
|
+
},
|
|
14
|
+
|
|
15
|
+
fromFirestore(snapshot: QueryDocumentSnapshot): IngredientEntityContent {
|
|
16
|
+
return snapshot.data() as IngredientEntityContent;
|
|
17
|
+
},
|
|
18
|
+
};
|
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
export * from "./content";
|
|
2
|
-
export * from "./meta";
|
|
3
|
-
export * from "./user";
|
|
1
|
+
export * from "./content";
|
|
2
|
+
export * from "./meta";
|
|
3
|
+
export * from "./user";
|
|
@@ -1,36 +1,37 @@
|
|
|
1
|
-
import {
|
|
2
|
-
FirestoreDataConverter,
|
|
3
|
-
QueryDocumentSnapshot,
|
|
4
|
-
DocumentData,
|
|
5
|
-
} from "firebase-admin/firestore";
|
|
6
|
-
import type { IngredientEntityMeta } from "@cravery/core";
|
|
7
|
-
import {
|
|
8
|
-
toTimestamp,
|
|
9
|
-
toOptionalTimestamp,
|
|
10
|
-
toFirestoreTimestamp,
|
|
11
|
-
toOptionalFirestoreTimestamp,
|
|
12
|
-
stripUndefined,
|
|
13
|
-
} from "../../lib";
|
|
14
|
-
|
|
15
|
-
export const ingredientMetaConverter: FirestoreDataConverter<IngredientEntityMeta> =
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
}
|
|
1
|
+
import {
|
|
2
|
+
FirestoreDataConverter,
|
|
3
|
+
QueryDocumentSnapshot,
|
|
4
|
+
DocumentData,
|
|
5
|
+
} from "firebase-admin/firestore";
|
|
6
|
+
import type { IngredientEntityMeta } from "@cravery/core";
|
|
7
|
+
import {
|
|
8
|
+
toTimestamp,
|
|
9
|
+
toOptionalTimestamp,
|
|
10
|
+
toFirestoreTimestamp,
|
|
11
|
+
toOptionalFirestoreTimestamp,
|
|
12
|
+
stripUndefined,
|
|
13
|
+
} from "../../lib";
|
|
14
|
+
|
|
15
|
+
export const ingredientMetaConverter: FirestoreDataConverter<IngredientEntityMeta> =
|
|
16
|
+
{
|
|
17
|
+
toFirestore(meta: IngredientEntityMeta): DocumentData {
|
|
18
|
+
const { id, createdAt, updatedAt, deletedAt, ...rest } = meta;
|
|
19
|
+
return stripUndefined({
|
|
20
|
+
...rest,
|
|
21
|
+
createdAt: toFirestoreTimestamp(createdAt),
|
|
22
|
+
updatedAt: toFirestoreTimestamp(updatedAt),
|
|
23
|
+
deletedAt: toOptionalFirestoreTimestamp(deletedAt),
|
|
24
|
+
});
|
|
25
|
+
},
|
|
26
|
+
|
|
27
|
+
fromFirestore(snapshot: QueryDocumentSnapshot): IngredientEntityMeta {
|
|
28
|
+
const { createdAt, updatedAt, deletedAt, ...rest } = snapshot.data();
|
|
29
|
+
return {
|
|
30
|
+
...rest,
|
|
31
|
+
id: snapshot.id,
|
|
32
|
+
createdAt: toTimestamp(createdAt),
|
|
33
|
+
updatedAt: toTimestamp(updatedAt),
|
|
34
|
+
deletedAt: toOptionalTimestamp(deletedAt),
|
|
35
|
+
} as IngredientEntityMeta;
|
|
36
|
+
},
|
|
37
|
+
};
|
|
@@ -1,38 +1,40 @@
|
|
|
1
|
-
import {
|
|
2
|
-
FirestoreDataConverter,
|
|
3
|
-
QueryDocumentSnapshot,
|
|
4
|
-
DocumentData,
|
|
5
|
-
} from "firebase-admin/firestore";
|
|
6
|
-
import type { UserIngredient } from "@cravery/core";
|
|
7
|
-
import {
|
|
8
|
-
toTimestamp,
|
|
9
|
-
toOptionalTimestamp,
|
|
10
|
-
toFirestoreTimestamp,
|
|
11
|
-
toOptionalFirestoreTimestamp,
|
|
12
|
-
stripUndefined,
|
|
13
|
-
} from "../../lib";
|
|
14
|
-
|
|
15
|
-
export const userIngredientConverter: FirestoreDataConverter<UserIngredient> = {
|
|
16
|
-
toFirestore(ingredient: UserIngredient): DocumentData {
|
|
17
|
-
const { id, createdAt, updatedAt, deletedAt, expiresAt, ...rest } =
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
};
|
|
1
|
+
import {
|
|
2
|
+
FirestoreDataConverter,
|
|
3
|
+
QueryDocumentSnapshot,
|
|
4
|
+
DocumentData,
|
|
5
|
+
} from "firebase-admin/firestore";
|
|
6
|
+
import type { UserIngredient } from "@cravery/core";
|
|
7
|
+
import {
|
|
8
|
+
toTimestamp,
|
|
9
|
+
toOptionalTimestamp,
|
|
10
|
+
toFirestoreTimestamp,
|
|
11
|
+
toOptionalFirestoreTimestamp,
|
|
12
|
+
stripUndefined,
|
|
13
|
+
} from "../../lib";
|
|
14
|
+
|
|
15
|
+
export const userIngredientConverter: FirestoreDataConverter<UserIngredient> = {
|
|
16
|
+
toFirestore(ingredient: UserIngredient): DocumentData {
|
|
17
|
+
const { id, createdAt, updatedAt, deletedAt, expiresAt, ...rest } =
|
|
18
|
+
ingredient;
|
|
19
|
+
return stripUndefined({
|
|
20
|
+
...rest,
|
|
21
|
+
createdAt: toFirestoreTimestamp(createdAt),
|
|
22
|
+
updatedAt: toFirestoreTimestamp(updatedAt),
|
|
23
|
+
deletedAt: toOptionalFirestoreTimestamp(deletedAt),
|
|
24
|
+
expiresAt: toOptionalFirestoreTimestamp(expiresAt),
|
|
25
|
+
});
|
|
26
|
+
},
|
|
27
|
+
|
|
28
|
+
fromFirestore(snapshot: QueryDocumentSnapshot): UserIngredient {
|
|
29
|
+
const { createdAt, updatedAt, deletedAt, expiresAt, ...rest } =
|
|
30
|
+
snapshot.data();
|
|
31
|
+
return {
|
|
32
|
+
...rest,
|
|
33
|
+
id: snapshot.id,
|
|
34
|
+
createdAt: toTimestamp(createdAt),
|
|
35
|
+
updatedAt: toTimestamp(updatedAt),
|
|
36
|
+
deletedAt: toOptionalTimestamp(deletedAt),
|
|
37
|
+
expiresAt: toOptionalTimestamp(expiresAt),
|
|
38
|
+
} as UserIngredient;
|
|
39
|
+
},
|
|
40
|
+
};
|
|
@@ -1,36 +1,36 @@
|
|
|
1
|
-
import {
|
|
2
|
-
FirestoreDataConverter,
|
|
3
|
-
QueryDocumentSnapshot,
|
|
4
|
-
DocumentData,
|
|
5
|
-
} from "firebase-admin/firestore";
|
|
6
|
-
import type { RecipeComment } from "@cravery/core";
|
|
7
|
-
import {
|
|
8
|
-
toTimestamp,
|
|
9
|
-
toOptionalTimestamp,
|
|
10
|
-
toFirestoreTimestamp,
|
|
11
|
-
toOptionalFirestoreTimestamp,
|
|
12
|
-
stripUndefined,
|
|
13
|
-
} from "../../lib";
|
|
14
|
-
|
|
15
|
-
export const commentConverter: FirestoreDataConverter<RecipeComment> = {
|
|
16
|
-
toFirestore(comment: RecipeComment): DocumentData {
|
|
17
|
-
const { id, createdAt, updatedAt, deletedAt, ...rest } = comment;
|
|
18
|
-
return stripUndefined({
|
|
19
|
-
...rest,
|
|
20
|
-
createdAt: toFirestoreTimestamp(createdAt),
|
|
21
|
-
updatedAt: toFirestoreTimestamp(updatedAt),
|
|
22
|
-
deletedAt: toOptionalFirestoreTimestamp(deletedAt),
|
|
23
|
-
});
|
|
24
|
-
},
|
|
25
|
-
|
|
26
|
-
fromFirestore(snapshot: QueryDocumentSnapshot): RecipeComment {
|
|
27
|
-
const { createdAt, updatedAt, deletedAt, ...rest } = snapshot.data();
|
|
28
|
-
return {
|
|
29
|
-
...rest,
|
|
30
|
-
id: snapshot.id,
|
|
31
|
-
createdAt: toTimestamp(createdAt),
|
|
32
|
-
updatedAt: toTimestamp(updatedAt),
|
|
33
|
-
deletedAt: toOptionalTimestamp(deletedAt),
|
|
34
|
-
} as RecipeComment;
|
|
35
|
-
},
|
|
36
|
-
};
|
|
1
|
+
import {
|
|
2
|
+
FirestoreDataConverter,
|
|
3
|
+
QueryDocumentSnapshot,
|
|
4
|
+
DocumentData,
|
|
5
|
+
} from "firebase-admin/firestore";
|
|
6
|
+
import type { RecipeComment } from "@cravery/core";
|
|
7
|
+
import {
|
|
8
|
+
toTimestamp,
|
|
9
|
+
toOptionalTimestamp,
|
|
10
|
+
toFirestoreTimestamp,
|
|
11
|
+
toOptionalFirestoreTimestamp,
|
|
12
|
+
stripUndefined,
|
|
13
|
+
} from "../../lib";
|
|
14
|
+
|
|
15
|
+
export const commentConverter: FirestoreDataConverter<RecipeComment> = {
|
|
16
|
+
toFirestore(comment: RecipeComment): DocumentData {
|
|
17
|
+
const { id, createdAt, updatedAt, deletedAt, ...rest } = comment;
|
|
18
|
+
return stripUndefined({
|
|
19
|
+
...rest,
|
|
20
|
+
createdAt: toFirestoreTimestamp(createdAt),
|
|
21
|
+
updatedAt: toFirestoreTimestamp(updatedAt),
|
|
22
|
+
deletedAt: toOptionalFirestoreTimestamp(deletedAt),
|
|
23
|
+
});
|
|
24
|
+
},
|
|
25
|
+
|
|
26
|
+
fromFirestore(snapshot: QueryDocumentSnapshot): RecipeComment {
|
|
27
|
+
const { createdAt, updatedAt, deletedAt, ...rest } = snapshot.data();
|
|
28
|
+
return {
|
|
29
|
+
...rest,
|
|
30
|
+
id: snapshot.id,
|
|
31
|
+
createdAt: toTimestamp(createdAt),
|
|
32
|
+
updatedAt: toTimestamp(updatedAt),
|
|
33
|
+
deletedAt: toOptionalTimestamp(deletedAt),
|
|
34
|
+
} as RecipeComment;
|
|
35
|
+
},
|
|
36
|
+
};
|
|
@@ -1,17 +1,17 @@
|
|
|
1
|
-
import {
|
|
2
|
-
FirestoreDataConverter,
|
|
3
|
-
QueryDocumentSnapshot,
|
|
4
|
-
DocumentData,
|
|
5
|
-
} from "firebase-admin/firestore";
|
|
6
|
-
import type { RecipeContent } from "@cravery/core";
|
|
7
|
-
import { stripUndefined } from "../../lib";
|
|
8
|
-
|
|
9
|
-
export const recipeContentConverter: FirestoreDataConverter<RecipeContent> = {
|
|
10
|
-
toFirestore(content: RecipeContent): DocumentData {
|
|
11
|
-
return stripUndefined({ ...content });
|
|
12
|
-
},
|
|
13
|
-
|
|
14
|
-
fromFirestore(snapshot: QueryDocumentSnapshot): RecipeContent {
|
|
15
|
-
return snapshot.data() as RecipeContent;
|
|
16
|
-
},
|
|
17
|
-
};
|
|
1
|
+
import {
|
|
2
|
+
FirestoreDataConverter,
|
|
3
|
+
QueryDocumentSnapshot,
|
|
4
|
+
DocumentData,
|
|
5
|
+
} from "firebase-admin/firestore";
|
|
6
|
+
import type { RecipeContent } from "@cravery/core";
|
|
7
|
+
import { stripUndefined } from "../../lib";
|
|
8
|
+
|
|
9
|
+
export const recipeContentConverter: FirestoreDataConverter<RecipeContent> = {
|
|
10
|
+
toFirestore(content: RecipeContent): DocumentData {
|
|
11
|
+
return stripUndefined({ ...content });
|
|
12
|
+
},
|
|
13
|
+
|
|
14
|
+
fromFirestore(snapshot: QueryDocumentSnapshot): RecipeContent {
|
|
15
|
+
return snapshot.data() as RecipeContent;
|
|
16
|
+
},
|
|
17
|
+
};
|
|
@@ -1,3 +1,3 @@
|
|
|
1
|
-
export * from "./comment";
|
|
2
|
-
export * from "./content";
|
|
3
|
-
export * from "./meta";
|
|
1
|
+
export * from "./comment";
|
|
2
|
+
export * from "./content";
|
|
3
|
+
export * from "./meta";
|