tinybase 5.0.0-beta.1 → 5.0.0-beta.3
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/lib/cjs/mergeable-store.cjs +1 -0
- package/lib/cjs/mergeable-store.cjs.gz +0 -0
- package/lib/cjs/persisters/persister-automerge.cjs +1 -1
- package/lib/cjs/persisters/persister-automerge.cjs.gz +0 -0
- package/lib/cjs/persisters/persister-browser.cjs +1 -1
- package/lib/cjs/persisters/persister-browser.cjs.gz +0 -0
- package/lib/cjs/persisters/persister-cr-sqlite-wasm.cjs +1 -1
- package/lib/cjs/persisters/persister-cr-sqlite-wasm.cjs.gz +0 -0
- package/lib/cjs/persisters/persister-electric-sql.cjs +1 -1
- package/lib/cjs/persisters/persister-electric-sql.cjs.gz +0 -0
- package/lib/cjs/persisters/persister-expo-sqlite-next.cjs +1 -1
- package/lib/cjs/persisters/persister-expo-sqlite-next.cjs.gz +0 -0
- package/lib/cjs/persisters/persister-expo-sqlite.cjs +1 -1
- package/lib/cjs/persisters/persister-expo-sqlite.cjs.gz +0 -0
- package/lib/cjs/persisters/persister-file.cjs +1 -1
- package/lib/cjs/persisters/persister-file.cjs.gz +0 -0
- package/lib/cjs/persisters/persister-indexed-db.cjs +1 -1
- package/lib/cjs/persisters/persister-indexed-db.cjs.gz +0 -0
- package/lib/cjs/persisters/persister-partykit-client.cjs +1 -1
- package/lib/cjs/persisters/persister-partykit-client.cjs.gz +0 -0
- package/lib/cjs/persisters/persister-partykit-server.cjs +1 -1
- package/lib/cjs/persisters/persister-partykit-server.cjs.gz +0 -0
- package/lib/cjs/persisters/persister-remote.cjs +1 -1
- package/lib/cjs/persisters/persister-remote.cjs.gz +0 -0
- package/lib/cjs/persisters/persister-sqlite-wasm.cjs +1 -1
- package/lib/cjs/persisters/persister-sqlite-wasm.cjs.gz +0 -0
- package/lib/cjs/persisters/persister-sqlite3.cjs +1 -1
- package/lib/cjs/persisters/persister-sqlite3.cjs.gz +0 -0
- package/lib/cjs/persisters/persister-yjs.cjs +1 -1
- package/lib/cjs/persisters/persister-yjs.cjs.gz +0 -0
- package/lib/cjs/persisters.cjs +1 -1
- package/lib/cjs/persisters.cjs.gz +0 -0
- package/lib/cjs/store.cjs +1 -1
- package/lib/cjs/store.cjs.gz +0 -0
- package/lib/cjs/tinybase.cjs +1 -1
- package/lib/cjs/tinybase.cjs.gz +0 -0
- package/lib/cjs/tools.cjs +1 -1
- package/lib/cjs/tools.cjs.gz +0 -0
- package/lib/cjs/ui-react-dom-debug.cjs +1 -1
- package/lib/cjs/ui-react-dom-debug.cjs.gz +0 -0
- package/lib/cjs/ui-react-dom.cjs +1 -1
- package/lib/cjs/ui-react-dom.cjs.gz +0 -0
- package/lib/cjs-es6/mergeable-store.cjs +1 -0
- package/lib/cjs-es6/mergeable-store.cjs.gz +0 -0
- package/lib/cjs-es6/persisters/persister-automerge.cjs +1 -1
- package/lib/cjs-es6/persisters/persister-automerge.cjs.gz +0 -0
- package/lib/cjs-es6/persisters/persister-browser.cjs +1 -1
- package/lib/cjs-es6/persisters/persister-browser.cjs.gz +0 -0
- package/lib/cjs-es6/persisters/persister-cr-sqlite-wasm.cjs +1 -1
- package/lib/cjs-es6/persisters/persister-cr-sqlite-wasm.cjs.gz +0 -0
- package/lib/cjs-es6/persisters/persister-electric-sql.cjs +1 -1
- package/lib/cjs-es6/persisters/persister-electric-sql.cjs.gz +0 -0
- package/lib/cjs-es6/persisters/persister-expo-sqlite-next.cjs +1 -1
- package/lib/cjs-es6/persisters/persister-expo-sqlite-next.cjs.gz +0 -0
- package/lib/cjs-es6/persisters/persister-expo-sqlite.cjs +1 -1
- package/lib/cjs-es6/persisters/persister-expo-sqlite.cjs.gz +0 -0
- package/lib/cjs-es6/persisters/persister-file.cjs +1 -1
- package/lib/cjs-es6/persisters/persister-file.cjs.gz +0 -0
- package/lib/cjs-es6/persisters/persister-indexed-db.cjs +1 -1
- package/lib/cjs-es6/persisters/persister-indexed-db.cjs.gz +0 -0
- package/lib/cjs-es6/persisters/persister-partykit-client.cjs +1 -1
- package/lib/cjs-es6/persisters/persister-partykit-client.cjs.gz +0 -0
- package/lib/cjs-es6/persisters/persister-partykit-server.cjs +1 -1
- package/lib/cjs-es6/persisters/persister-partykit-server.cjs.gz +0 -0
- package/lib/cjs-es6/persisters/persister-remote.cjs +1 -1
- package/lib/cjs-es6/persisters/persister-remote.cjs.gz +0 -0
- package/lib/cjs-es6/persisters/persister-sqlite-wasm.cjs +1 -1
- package/lib/cjs-es6/persisters/persister-sqlite-wasm.cjs.gz +0 -0
- package/lib/cjs-es6/persisters/persister-sqlite3.cjs +1 -1
- package/lib/cjs-es6/persisters/persister-sqlite3.cjs.gz +0 -0
- package/lib/cjs-es6/persisters/persister-yjs.cjs +1 -1
- package/lib/cjs-es6/persisters/persister-yjs.cjs.gz +0 -0
- package/lib/cjs-es6/persisters.cjs +1 -1
- package/lib/cjs-es6/persisters.cjs.gz +0 -0
- package/lib/cjs-es6/store.cjs +1 -1
- package/lib/cjs-es6/store.cjs.gz +0 -0
- package/lib/cjs-es6/tinybase.cjs +1 -1
- package/lib/cjs-es6/tinybase.cjs.gz +0 -0
- package/lib/cjs-es6/tools.cjs +1 -1
- package/lib/cjs-es6/tools.cjs.gz +0 -0
- package/lib/cjs-es6/ui-react-dom-debug.cjs +1 -1
- package/lib/cjs-es6/ui-react-dom-debug.cjs.gz +0 -0
- package/lib/cjs-es6/ui-react-dom.cjs +1 -1
- package/lib/cjs-es6/ui-react-dom.cjs.gz +0 -0
- package/lib/debug/mergeable-store.js +1863 -0
- package/lib/debug/persisters/persister-automerge.js +54 -53
- package/lib/debug/persisters/persister-browser.js +28 -18
- package/lib/debug/persisters/persister-cr-sqlite-wasm.js +80 -57
- package/lib/debug/persisters/persister-electric-sql.js +80 -57
- package/lib/debug/persisters/persister-expo-sqlite-next.js +80 -57
- package/lib/debug/persisters/persister-expo-sqlite.js +80 -57
- package/lib/debug/persisters/persister-file.js +27 -18
- package/lib/debug/persisters/persister-indexed-db.js +34 -23
- package/lib/debug/persisters/persister-partykit-client.js +26 -23
- package/lib/debug/persisters/persister-partykit-server.js +11 -21
- package/lib/debug/persisters/persister-remote.js +28 -18
- package/lib/debug/persisters/persister-sqlite-wasm.js +80 -57
- package/lib/debug/persisters/persister-sqlite3.js +80 -57
- package/lib/debug/persisters/persister-yjs.js +50 -48
- package/lib/debug/persisters.js +27 -18
- package/lib/debug/queries.js +2 -2
- package/lib/debug/store.js +63 -71
- package/lib/debug/tinybase.js +354 -90
- package/lib/debug/tools.js +13 -15
- package/lib/debug/ui-react-dom.js +115 -119
- package/lib/es6/mergeable-store.js +1 -0
- package/lib/es6/mergeable-store.js.gz +0 -0
- package/lib/es6/persisters/persister-automerge.js +1 -1
- package/lib/es6/persisters/persister-automerge.js.gz +0 -0
- package/lib/es6/persisters/persister-browser.js +1 -1
- package/lib/es6/persisters/persister-browser.js.gz +0 -0
- package/lib/es6/persisters/persister-cr-sqlite-wasm.js +1 -1
- package/lib/es6/persisters/persister-cr-sqlite-wasm.js.gz +0 -0
- package/lib/es6/persisters/persister-electric-sql.js +1 -1
- package/lib/es6/persisters/persister-electric-sql.js.gz +0 -0
- package/lib/es6/persisters/persister-expo-sqlite-next.js +1 -1
- package/lib/es6/persisters/persister-expo-sqlite-next.js.gz +0 -0
- package/lib/es6/persisters/persister-expo-sqlite.js +1 -1
- package/lib/es6/persisters/persister-expo-sqlite.js.gz +0 -0
- package/lib/es6/persisters/persister-file.js +1 -1
- package/lib/es6/persisters/persister-file.js.gz +0 -0
- package/lib/es6/persisters/persister-indexed-db.js +1 -1
- package/lib/es6/persisters/persister-indexed-db.js.gz +0 -0
- package/lib/es6/persisters/persister-partykit-client.js +1 -1
- package/lib/es6/persisters/persister-partykit-client.js.gz +0 -0
- package/lib/es6/persisters/persister-partykit-server.js +1 -1
- package/lib/es6/persisters/persister-partykit-server.js.gz +0 -0
- package/lib/es6/persisters/persister-remote.js +1 -1
- package/lib/es6/persisters/persister-remote.js.gz +0 -0
- package/lib/es6/persisters/persister-sqlite-wasm.js +1 -1
- package/lib/es6/persisters/persister-sqlite-wasm.js.gz +0 -0
- package/lib/es6/persisters/persister-sqlite3.js +1 -1
- package/lib/es6/persisters/persister-sqlite3.js.gz +0 -0
- package/lib/es6/persisters/persister-yjs.js +1 -1
- package/lib/es6/persisters/persister-yjs.js.gz +0 -0
- package/lib/es6/persisters.js +1 -1
- package/lib/es6/persisters.js.gz +0 -0
- package/lib/es6/store.js +1 -1
- package/lib/es6/store.js.gz +0 -0
- package/lib/es6/tinybase.js +1 -1
- package/lib/es6/tinybase.js.gz +0 -0
- package/lib/es6/tools.js +1 -1
- package/lib/es6/tools.js.gz +0 -0
- package/lib/es6/ui-react-dom-debug.js +1 -1
- package/lib/es6/ui-react-dom-debug.js.gz +0 -0
- package/lib/es6/ui-react-dom.js +1 -1
- package/lib/es6/ui-react-dom.js.gz +0 -0
- package/lib/mergeable-store.js +1 -0
- package/lib/mergeable-store.js.gz +0 -0
- package/lib/persisters/persister-automerge.js +1 -1
- package/lib/persisters/persister-automerge.js.gz +0 -0
- package/lib/persisters/persister-browser.js +1 -1
- package/lib/persisters/persister-browser.js.gz +0 -0
- package/lib/persisters/persister-cr-sqlite-wasm.js +1 -1
- package/lib/persisters/persister-cr-sqlite-wasm.js.gz +0 -0
- package/lib/persisters/persister-electric-sql.js +1 -1
- package/lib/persisters/persister-electric-sql.js.gz +0 -0
- package/lib/persisters/persister-expo-sqlite-next.js +1 -1
- package/lib/persisters/persister-expo-sqlite-next.js.gz +0 -0
- package/lib/persisters/persister-expo-sqlite.js +1 -1
- package/lib/persisters/persister-expo-sqlite.js.gz +0 -0
- package/lib/persisters/persister-file.js +1 -1
- package/lib/persisters/persister-file.js.gz +0 -0
- package/lib/persisters/persister-indexed-db.js +1 -1
- package/lib/persisters/persister-indexed-db.js.gz +0 -0
- package/lib/persisters/persister-partykit-client.js +1 -1
- package/lib/persisters/persister-partykit-client.js.gz +0 -0
- package/lib/persisters/persister-partykit-server.js +1 -1
- package/lib/persisters/persister-partykit-server.js.gz +0 -0
- package/lib/persisters/persister-remote.js +1 -1
- package/lib/persisters/persister-remote.js.gz +0 -0
- package/lib/persisters/persister-sqlite-wasm.js +1 -1
- package/lib/persisters/persister-sqlite-wasm.js.gz +0 -0
- package/lib/persisters/persister-sqlite3.js +1 -1
- package/lib/persisters/persister-sqlite3.js.gz +0 -0
- package/lib/persisters/persister-yjs.js +1 -1
- package/lib/persisters/persister-yjs.js.gz +0 -0
- package/lib/persisters.js +1 -1
- package/lib/persisters.js.gz +0 -0
- package/lib/store.js +1 -1
- package/lib/store.js.gz +0 -0
- package/lib/tinybase.js +1 -1
- package/lib/tinybase.js.gz +0 -0
- package/lib/tools.js +1 -1
- package/lib/tools.js.gz +0 -0
- package/lib/types/mergeable-store.d.ts +79 -0
- package/lib/types/persisters/persister-automerge.d.ts +8 -7
- package/lib/types/persisters/persister-browser.d.ts +2 -0
- package/lib/types/persisters/persister-cr-sqlite-wasm.d.ts +1 -0
- package/lib/types/persisters/persister-electric-sql.d.ts +1 -0
- package/lib/types/persisters/persister-expo-sqlite-next.d.ts +1 -0
- package/lib/types/persisters/persister-expo-sqlite.d.ts +1 -0
- package/lib/types/persisters/persister-file.d.ts +1 -0
- package/lib/types/persisters/persister-indexed-db.d.ts +1 -0
- package/lib/types/persisters/persister-partykit-client.d.ts +1 -0
- package/lib/types/persisters/persister-partykit-server.d.ts +12 -8
- package/lib/types/persisters/persister-remote.d.ts +1 -0
- package/lib/types/persisters/persister-sqlite-wasm.d.ts +1 -0
- package/lib/types/persisters/persister-sqlite3.d.ts +1 -0
- package/lib/types/persisters/persister-yjs.d.ts +1 -0
- package/lib/types/persisters.d.ts +50 -30
- package/lib/types/store.d.ts +241 -186
- package/lib/types/tinybase.d.ts +1 -0
- package/lib/types/tools.d.ts +2 -2
- package/lib/types/ui-react.d.ts +1 -0
- package/lib/types/with-schemas/internal/store.d.ts +4 -0
- package/lib/types/with-schemas/mergeable-store.d.ts +112 -0
- package/lib/types/with-schemas/persisters/persister-automerge.d.ts +8 -7
- package/lib/types/with-schemas/persisters/persister-browser.d.ts +2 -0
- package/lib/types/with-schemas/persisters/persister-cr-sqlite-wasm.d.ts +1 -0
- package/lib/types/with-schemas/persisters/persister-electric-sql.d.ts +1 -0
- package/lib/types/with-schemas/persisters/persister-expo-sqlite-next.d.ts +1 -0
- package/lib/types/with-schemas/persisters/persister-expo-sqlite.d.ts +1 -0
- package/lib/types/with-schemas/persisters/persister-file.d.ts +1 -0
- package/lib/types/with-schemas/persisters/persister-indexed-db.d.ts +1 -0
- package/lib/types/with-schemas/persisters/persister-partykit-client.d.ts +1 -0
- package/lib/types/with-schemas/persisters/persister-partykit-server.d.ts +15 -11
- package/lib/types/with-schemas/persisters/persister-remote.d.ts +1 -0
- package/lib/types/with-schemas/persisters/persister-sqlite-wasm.d.ts +1 -0
- package/lib/types/with-schemas/persisters/persister-sqlite3.d.ts +1 -0
- package/lib/types/with-schemas/persisters/persister-yjs.d.ts +1 -0
- package/lib/types/with-schemas/persisters.d.ts +81 -45
- package/lib/types/with-schemas/store.d.ts +364 -273
- package/lib/types/with-schemas/tinybase.d.ts +1 -0
- package/lib/types/with-schemas/tools.d.ts +2 -2
- package/lib/ui-react-dom.js +1 -1
- package/lib/ui-react-dom.js.gz +0 -0
- package/lib/umd/mergeable-store.js +1 -0
- package/lib/umd/mergeable-store.js.gz +0 -0
- package/lib/umd/persisters/persister-automerge.js +1 -1
- package/lib/umd/persisters/persister-automerge.js.gz +0 -0
- package/lib/umd/persisters/persister-browser.js +1 -1
- package/lib/umd/persisters/persister-browser.js.gz +0 -0
- package/lib/umd/persisters/persister-cr-sqlite-wasm.js +1 -1
- package/lib/umd/persisters/persister-cr-sqlite-wasm.js.gz +0 -0
- package/lib/umd/persisters/persister-electric-sql.js +1 -1
- package/lib/umd/persisters/persister-electric-sql.js.gz +0 -0
- package/lib/umd/persisters/persister-expo-sqlite-next.js +1 -1
- package/lib/umd/persisters/persister-expo-sqlite-next.js.gz +0 -0
- package/lib/umd/persisters/persister-expo-sqlite.js +1 -1
- package/lib/umd/persisters/persister-expo-sqlite.js.gz +0 -0
- package/lib/umd/persisters/persister-file.js +1 -1
- package/lib/umd/persisters/persister-file.js.gz +0 -0
- package/lib/umd/persisters/persister-indexed-db.js +1 -1
- package/lib/umd/persisters/persister-indexed-db.js.gz +0 -0
- package/lib/umd/persisters/persister-partykit-client.js +1 -1
- package/lib/umd/persisters/persister-partykit-client.js.gz +0 -0
- package/lib/umd/persisters/persister-partykit-server.js +1 -1
- package/lib/umd/persisters/persister-partykit-server.js.gz +0 -0
- package/lib/umd/persisters/persister-remote.js +1 -1
- package/lib/umd/persisters/persister-remote.js.gz +0 -0
- package/lib/umd/persisters/persister-sqlite-wasm.js +1 -1
- package/lib/umd/persisters/persister-sqlite-wasm.js.gz +0 -0
- package/lib/umd/persisters/persister-sqlite3.js +1 -1
- package/lib/umd/persisters/persister-sqlite3.js.gz +0 -0
- package/lib/umd/persisters/persister-yjs.js +1 -1
- package/lib/umd/persisters/persister-yjs.js.gz +0 -0
- package/lib/umd/persisters.js +1 -1
- package/lib/umd/persisters.js.gz +0 -0
- package/lib/umd/store.js +1 -1
- package/lib/umd/store.js.gz +0 -0
- package/lib/umd/tinybase.js +1 -1
- package/lib/umd/tinybase.js.gz +0 -0
- package/lib/umd/tools.js +1 -1
- package/lib/umd/tools.js.gz +0 -0
- package/lib/umd/ui-react-dom-debug.js +1 -1
- package/lib/umd/ui-react-dom-debug.js.gz +0 -0
- package/lib/umd/ui-react-dom.js +1 -1
- package/lib/umd/ui-react-dom.js.gz +0 -0
- package/lib/umd-es6/mergeable-store.js +1 -0
- package/lib/umd-es6/mergeable-store.js.gz +0 -0
- package/lib/umd-es6/persisters/persister-automerge.js +1 -1
- package/lib/umd-es6/persisters/persister-automerge.js.gz +0 -0
- package/lib/umd-es6/persisters/persister-browser.js +1 -1
- package/lib/umd-es6/persisters/persister-browser.js.gz +0 -0
- package/lib/umd-es6/persisters/persister-cr-sqlite-wasm.js +1 -1
- package/lib/umd-es6/persisters/persister-cr-sqlite-wasm.js.gz +0 -0
- package/lib/umd-es6/persisters/persister-electric-sql.js +1 -1
- package/lib/umd-es6/persisters/persister-electric-sql.js.gz +0 -0
- package/lib/umd-es6/persisters/persister-expo-sqlite-next.js +1 -1
- package/lib/umd-es6/persisters/persister-expo-sqlite-next.js.gz +0 -0
- package/lib/umd-es6/persisters/persister-expo-sqlite.js +1 -1
- package/lib/umd-es6/persisters/persister-expo-sqlite.js.gz +0 -0
- package/lib/umd-es6/persisters/persister-file.js +1 -1
- package/lib/umd-es6/persisters/persister-file.js.gz +0 -0
- package/lib/umd-es6/persisters/persister-indexed-db.js +1 -1
- package/lib/umd-es6/persisters/persister-indexed-db.js.gz +0 -0
- package/lib/umd-es6/persisters/persister-partykit-client.js +1 -1
- package/lib/umd-es6/persisters/persister-partykit-client.js.gz +0 -0
- package/lib/umd-es6/persisters/persister-partykit-server.js +1 -1
- package/lib/umd-es6/persisters/persister-partykit-server.js.gz +0 -0
- package/lib/umd-es6/persisters/persister-remote.js +1 -1
- package/lib/umd-es6/persisters/persister-remote.js.gz +0 -0
- package/lib/umd-es6/persisters/persister-sqlite-wasm.js +1 -1
- package/lib/umd-es6/persisters/persister-sqlite-wasm.js.gz +0 -0
- package/lib/umd-es6/persisters/persister-sqlite3.js +1 -1
- package/lib/umd-es6/persisters/persister-sqlite3.js.gz +0 -0
- package/lib/umd-es6/persisters/persister-yjs.js +1 -1
- package/lib/umd-es6/persisters/persister-yjs.js.gz +0 -0
- package/lib/umd-es6/persisters.js +1 -1
- package/lib/umd-es6/persisters.js.gz +0 -0
- package/lib/umd-es6/store.js +1 -1
- package/lib/umd-es6/store.js.gz +0 -0
- package/lib/umd-es6/tinybase.js +1 -1
- package/lib/umd-es6/tinybase.js.gz +0 -0
- package/lib/umd-es6/tools.js +1 -1
- package/lib/umd-es6/tools.js.gz +0 -0
- package/lib/umd-es6/ui-react-dom-debug.js +1 -1
- package/lib/umd-es6/ui-react-dom-debug.js.gz +0 -0
- package/lib/umd-es6/ui-react-dom.js +1 -1
- package/lib/umd-es6/ui-react-dom.js.gz +0 -0
- package/package.json +39 -35
- package/readme.md +2 -2
|
@@ -75,6 +75,7 @@ const createCustomPersister = (
|
|
|
75
75
|
addPersisterListener,
|
|
76
76
|
delPersisterListener,
|
|
77
77
|
onIgnoredError,
|
|
78
|
+
supportsMergeableStore,
|
|
78
79
|
[getThing, thing] = [],
|
|
79
80
|
scheduleId = [],
|
|
80
81
|
) => {
|
|
@@ -87,6 +88,10 @@ const createCustomPersister = (
|
|
|
87
88
|
let listeningHandle;
|
|
88
89
|
mapEnsure(scheduleRunning, scheduleId, () => 0);
|
|
89
90
|
mapEnsure(scheduleActions, scheduleId, () => []);
|
|
91
|
+
const getContent =
|
|
92
|
+
(supportsMergeableStore ? store.getMergeableContent : null) ??
|
|
93
|
+
store.getContent;
|
|
94
|
+
const getChanges = store.getTransactionChanges;
|
|
90
95
|
const run = async () => {
|
|
91
96
|
/* istanbul ignore else */
|
|
92
97
|
if (!mapGet(scheduleRunning, scheduleId)) {
|
|
@@ -122,7 +127,10 @@ const createCustomPersister = (
|
|
|
122
127
|
load: async (initialTables, initialValues) =>
|
|
123
128
|
await loadLock(async () => {
|
|
124
129
|
try {
|
|
125
|
-
|
|
130
|
+
const content = await getPersisted();
|
|
131
|
+
(supportsMergeableStore && isString(content[0])
|
|
132
|
+
? store.applyMergeableChanges
|
|
133
|
+
: store.setContent)(content);
|
|
126
134
|
} catch {
|
|
127
135
|
store.setContent([initialTables, initialValues]);
|
|
128
136
|
}
|
|
@@ -132,16 +140,14 @@ const createCustomPersister = (
|
|
|
132
140
|
await persister.load(initialTables, initialValues);
|
|
133
141
|
listening = 1;
|
|
134
142
|
listeningHandle = addPersisterListener(
|
|
135
|
-
async (
|
|
136
|
-
if (
|
|
137
|
-
const
|
|
138
|
-
await loadLock(async () =>
|
|
139
|
-
store.setTransactionChanges(transactionChanges),
|
|
140
|
-
);
|
|
143
|
+
async (getContent2, getChanges2) => {
|
|
144
|
+
if (getChanges2) {
|
|
145
|
+
const changes = getChanges2();
|
|
146
|
+
await loadLock(async () => store.applyChanges(changes));
|
|
141
147
|
} else {
|
|
142
148
|
await loadLock(async () => {
|
|
143
149
|
try {
|
|
144
|
-
store.setContent(
|
|
150
|
+
store.setContent(getContent2?.() ?? (await getPersisted()));
|
|
145
151
|
} catch (error) {
|
|
146
152
|
onIgnoredError?.(error);
|
|
147
153
|
}
|
|
@@ -159,7 +165,7 @@ const createCustomPersister = (
|
|
|
159
165
|
}
|
|
160
166
|
return persister;
|
|
161
167
|
},
|
|
162
|
-
save: async (
|
|
168
|
+
save: async (getChanges2) => {
|
|
163
169
|
/* istanbul ignore else */
|
|
164
170
|
if (loadSave != 1) {
|
|
165
171
|
loadSave = 2;
|
|
@@ -168,7 +174,7 @@ const createCustomPersister = (
|
|
|
168
174
|
}
|
|
169
175
|
await persister.schedule(async () => {
|
|
170
176
|
try {
|
|
171
|
-
await setPersisted(
|
|
177
|
+
await setPersisted(getContent, getChanges2);
|
|
172
178
|
} catch (error) {
|
|
173
179
|
/* istanbul ignore next */
|
|
174
180
|
onIgnoredError?.(error);
|
|
@@ -180,14 +186,12 @@ const createCustomPersister = (
|
|
|
180
186
|
},
|
|
181
187
|
startAutoSave: async () => {
|
|
182
188
|
await persister.stopAutoSave().save();
|
|
183
|
-
listenerId = store.addDidFinishTransactionListener(
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
},
|
|
190
|
-
);
|
|
189
|
+
listenerId = store.addDidFinishTransactionListener(() => {
|
|
190
|
+
const [tableChanges, valueChanges] = getChanges();
|
|
191
|
+
if (!objIsEmpty(tableChanges) || !objIsEmpty(valueChanges)) {
|
|
192
|
+
persister.save(() => [tableChanges, valueChanges]);
|
|
193
|
+
}
|
|
194
|
+
});
|
|
191
195
|
return persister;
|
|
192
196
|
},
|
|
193
197
|
stopAutoSave: () => {
|
|
@@ -245,11 +249,9 @@ const createPartyKitPersister = (
|
|
|
245
249
|
})
|
|
246
250
|
).json();
|
|
247
251
|
const getPersisted = async () => await getOrSetStore();
|
|
248
|
-
const setPersisted = async (getContent,
|
|
249
|
-
if (
|
|
250
|
-
connection.send(
|
|
251
|
-
construct(messagePrefix, SET_CHANGES, getTransactionChanges()),
|
|
252
|
-
);
|
|
252
|
+
const setPersisted = async (getContent, getChanges) => {
|
|
253
|
+
if (getChanges) {
|
|
254
|
+
connection.send(construct(messagePrefix, SET_CHANGES, getChanges()));
|
|
253
255
|
} else {
|
|
254
256
|
await getOrSetStore(getContent());
|
|
255
257
|
}
|
|
@@ -277,6 +279,7 @@ const createPartyKitPersister = (
|
|
|
277
279
|
addPersisterListener,
|
|
278
280
|
delPersisterListener,
|
|
279
281
|
onIgnoredError,
|
|
282
|
+
false,
|
|
280
283
|
['getConnection', connection],
|
|
281
284
|
);
|
|
282
285
|
};
|
|
@@ -24,9 +24,8 @@ const arrayUnshift = (array, ...values) => array.unshift(...values);
|
|
|
24
24
|
const object = Object;
|
|
25
25
|
const objEntries = object.entries;
|
|
26
26
|
const objNew = (entries = []) => object.fromEntries(entries);
|
|
27
|
-
const
|
|
28
|
-
const
|
|
29
|
-
const objMap = (obj, cb) =>
|
|
27
|
+
const objHas = (obj, id) => id in obj;
|
|
28
|
+
const objToArray = (obj, cb) =>
|
|
30
29
|
arrayMap(objEntries(obj), ([id, value]) => cb(value, id));
|
|
31
30
|
const objEnsure = (obj, id, getDefaultValue) => {
|
|
32
31
|
if (!objHas(obj, id)) {
|
|
@@ -86,21 +85,12 @@ const loadStoreFromStorage = async (storage, storagePrefix = EMPTY_STRING) => {
|
|
|
86
85
|
);
|
|
87
86
|
return [tables, values];
|
|
88
87
|
};
|
|
89
|
-
const
|
|
90
|
-
server,
|
|
91
|
-
transactionChanges,
|
|
92
|
-
without,
|
|
93
|
-
) =>
|
|
88
|
+
const broadcastChanges = async (server, changes, without) =>
|
|
94
89
|
server.party.broadcast(
|
|
95
|
-
construct(server.config.messagePrefix, SET_CHANGES,
|
|
90
|
+
construct(server.config.messagePrefix, SET_CHANGES, changes),
|
|
96
91
|
without,
|
|
97
92
|
);
|
|
98
|
-
const saveStore = async (
|
|
99
|
-
that,
|
|
100
|
-
transactionChanges,
|
|
101
|
-
initialSave,
|
|
102
|
-
requestOrConnection,
|
|
103
|
-
) => {
|
|
93
|
+
const saveStore = async (that, changes, initialSave, requestOrConnection) => {
|
|
104
94
|
const storage = that.party.storage;
|
|
105
95
|
const storagePrefix = that.config.storagePrefix;
|
|
106
96
|
const keysToSet = {
|
|
@@ -109,7 +99,7 @@ const saveStore = async (
|
|
|
109
99
|
const keysToDel = [];
|
|
110
100
|
const keyPrefixesToDel = [];
|
|
111
101
|
await promiseAll(
|
|
112
|
-
|
|
102
|
+
objToArray(changes[0], async (table, tableId) =>
|
|
113
103
|
isUndefined(table)
|
|
114
104
|
? !initialSave &&
|
|
115
105
|
(await that.canDelTable(tableId, requestOrConnection)) &&
|
|
@@ -119,7 +109,7 @@ const saveStore = async (
|
|
|
119
109
|
)
|
|
120
110
|
: (await that.canSetTable(tableId, initialSave, requestOrConnection)) &&
|
|
121
111
|
(await promiseAll(
|
|
122
|
-
|
|
112
|
+
objToArray(table, async (row, rowId) =>
|
|
123
113
|
isUndefined(row)
|
|
124
114
|
? !initialSave &&
|
|
125
115
|
(await that.canDelRow(tableId, rowId, requestOrConnection)) &&
|
|
@@ -134,7 +124,7 @@ const saveStore = async (
|
|
|
134
124
|
requestOrConnection,
|
|
135
125
|
)) &&
|
|
136
126
|
(await promiseAll(
|
|
137
|
-
|
|
127
|
+
objToArray(row, async (cell, cellId) => {
|
|
138
128
|
const ids = [tableId, rowId, cellId];
|
|
139
129
|
const key = constructStorageKey(storagePrefix, T, ...ids);
|
|
140
130
|
isUndefined(cell)
|
|
@@ -158,7 +148,7 @@ const saveStore = async (
|
|
|
158
148
|
),
|
|
159
149
|
);
|
|
160
150
|
await promiseAll(
|
|
161
|
-
|
|
151
|
+
objToArray(changes[1], async (value, valueId) => {
|
|
162
152
|
const key = storagePrefix + V + valueId;
|
|
163
153
|
isUndefined(value)
|
|
164
154
|
? !initialSave &&
|
|
@@ -239,7 +229,7 @@ class TinyBasePartyKitServer {
|
|
|
239
229
|
(await hasStoreInStorage(this.party.storage, storagePrefix))
|
|
240
230
|
) {
|
|
241
231
|
await saveStore(this, payload, false, connection);
|
|
242
|
-
|
|
232
|
+
broadcastChanges(this, payload, [connection.id]);
|
|
243
233
|
}
|
|
244
234
|
},
|
|
245
235
|
);
|
|
@@ -286,7 +276,7 @@ class TinyBasePartyKitServer {
|
|
|
286
276
|
|
|
287
277
|
export {
|
|
288
278
|
TinyBasePartyKitServer,
|
|
289
|
-
|
|
279
|
+
broadcastChanges,
|
|
290
280
|
hasStoreInStorage,
|
|
291
281
|
loadStoreFromStorage,
|
|
292
282
|
};
|
|
@@ -1,3 +1,7 @@
|
|
|
1
|
+
const getTypeOf = (thing) => typeof thing;
|
|
2
|
+
const EMPTY_STRING = '';
|
|
3
|
+
const STRING = getTypeOf(EMPTY_STRING);
|
|
4
|
+
|
|
1
5
|
const startInterval = (callback, sec, immediate) => {
|
|
2
6
|
immediate && callback();
|
|
3
7
|
return setInterval(callback, sec * 1e3);
|
|
@@ -7,6 +11,7 @@ const isInstanceOf = (thing, cls) => thing instanceof cls;
|
|
|
7
11
|
const isUndefined = (thing) => thing == void 0;
|
|
8
12
|
const ifNotUndefined = (value, then, otherwise) =>
|
|
9
13
|
isUndefined(value) ? otherwise?.() : then(value);
|
|
14
|
+
const isString = (thing) => getTypeOf(thing) == STRING;
|
|
10
15
|
const size = (arrayOrString) => arrayOrString.length;
|
|
11
16
|
|
|
12
17
|
const arrayPush = (array, ...values) => array.push(...values);
|
|
@@ -58,6 +63,7 @@ const createCustomPersister = (
|
|
|
58
63
|
addPersisterListener,
|
|
59
64
|
delPersisterListener,
|
|
60
65
|
onIgnoredError,
|
|
66
|
+
supportsMergeableStore,
|
|
61
67
|
[getThing, thing] = [],
|
|
62
68
|
scheduleId = [],
|
|
63
69
|
) => {
|
|
@@ -70,6 +76,10 @@ const createCustomPersister = (
|
|
|
70
76
|
let listeningHandle;
|
|
71
77
|
mapEnsure(scheduleRunning, scheduleId, () => 0);
|
|
72
78
|
mapEnsure(scheduleActions, scheduleId, () => []);
|
|
79
|
+
const getContent =
|
|
80
|
+
(supportsMergeableStore ? store.getMergeableContent : null) ??
|
|
81
|
+
store.getContent;
|
|
82
|
+
const getChanges = store.getTransactionChanges;
|
|
73
83
|
const run = async () => {
|
|
74
84
|
/* istanbul ignore else */
|
|
75
85
|
if (!mapGet(scheduleRunning, scheduleId)) {
|
|
@@ -105,7 +115,10 @@ const createCustomPersister = (
|
|
|
105
115
|
load: async (initialTables, initialValues) =>
|
|
106
116
|
await loadLock(async () => {
|
|
107
117
|
try {
|
|
108
|
-
|
|
118
|
+
const content = await getPersisted();
|
|
119
|
+
(supportsMergeableStore && isString(content[0])
|
|
120
|
+
? store.applyMergeableChanges
|
|
121
|
+
: store.setContent)(content);
|
|
109
122
|
} catch {
|
|
110
123
|
store.setContent([initialTables, initialValues]);
|
|
111
124
|
}
|
|
@@ -115,16 +128,14 @@ const createCustomPersister = (
|
|
|
115
128
|
await persister.load(initialTables, initialValues);
|
|
116
129
|
listening = 1;
|
|
117
130
|
listeningHandle = addPersisterListener(
|
|
118
|
-
async (
|
|
119
|
-
if (
|
|
120
|
-
const
|
|
121
|
-
await loadLock(async () =>
|
|
122
|
-
store.setTransactionChanges(transactionChanges),
|
|
123
|
-
);
|
|
131
|
+
async (getContent2, getChanges2) => {
|
|
132
|
+
if (getChanges2) {
|
|
133
|
+
const changes = getChanges2();
|
|
134
|
+
await loadLock(async () => store.applyChanges(changes));
|
|
124
135
|
} else {
|
|
125
136
|
await loadLock(async () => {
|
|
126
137
|
try {
|
|
127
|
-
store.setContent(
|
|
138
|
+
store.setContent(getContent2?.() ?? (await getPersisted()));
|
|
128
139
|
} catch (error) {
|
|
129
140
|
onIgnoredError?.(error);
|
|
130
141
|
}
|
|
@@ -142,7 +153,7 @@ const createCustomPersister = (
|
|
|
142
153
|
}
|
|
143
154
|
return persister;
|
|
144
155
|
},
|
|
145
|
-
save: async (
|
|
156
|
+
save: async (getChanges2) => {
|
|
146
157
|
/* istanbul ignore else */
|
|
147
158
|
if (loadSave != 1) {
|
|
148
159
|
loadSave = 2;
|
|
@@ -151,7 +162,7 @@ const createCustomPersister = (
|
|
|
151
162
|
}
|
|
152
163
|
await persister.schedule(async () => {
|
|
153
164
|
try {
|
|
154
|
-
await setPersisted(
|
|
165
|
+
await setPersisted(getContent, getChanges2);
|
|
155
166
|
} catch (error) {
|
|
156
167
|
/* istanbul ignore next */
|
|
157
168
|
onIgnoredError?.(error);
|
|
@@ -163,14 +174,12 @@ const createCustomPersister = (
|
|
|
163
174
|
},
|
|
164
175
|
startAutoSave: async () => {
|
|
165
176
|
await persister.stopAutoSave().save();
|
|
166
|
-
listenerId = store.addDidFinishTransactionListener(
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
},
|
|
173
|
-
);
|
|
177
|
+
listenerId = store.addDidFinishTransactionListener(() => {
|
|
178
|
+
const [tableChanges, valueChanges] = getChanges();
|
|
179
|
+
if (!objIsEmpty(tableChanges) || !objIsEmpty(valueChanges)) {
|
|
180
|
+
persister.save(() => [tableChanges, valueChanges]);
|
|
181
|
+
}
|
|
182
|
+
});
|
|
174
183
|
return persister;
|
|
175
184
|
},
|
|
176
185
|
stopAutoSave: () => {
|
|
@@ -234,6 +243,7 @@ const createRemotePersister = (
|
|
|
234
243
|
addPersisterListener,
|
|
235
244
|
delPersisterListener,
|
|
236
245
|
onIgnoredError,
|
|
246
|
+
false,
|
|
237
247
|
['getUrls', [loadUrl, saveUrl]],
|
|
238
248
|
);
|
|
239
249
|
};
|
|
@@ -55,13 +55,12 @@ const isObject = (obj) =>
|
|
|
55
55
|
);
|
|
56
56
|
const objNew = (entries = []) => object.fromEntries(entries);
|
|
57
57
|
const objMerge = (...objs) => object.assign({}, ...objs);
|
|
58
|
-
const
|
|
59
|
-
const objHas = (obj, id) => !isUndefined(objGet(obj, id));
|
|
58
|
+
const objHas = (obj, id) => id in obj;
|
|
60
59
|
const objDel = (obj, id) => {
|
|
61
60
|
delete obj[id];
|
|
62
61
|
return obj;
|
|
63
62
|
};
|
|
64
|
-
const
|
|
63
|
+
const objToArray = (obj, cb) =>
|
|
65
64
|
arrayMap(objEntries(obj), ([id, value]) => cb(value, id));
|
|
66
65
|
const objValues = (obj) => object.values(obj);
|
|
67
66
|
const objSize = (obj) => size(objIds(obj));
|
|
@@ -83,7 +82,7 @@ const mapEnsure = (map, key, getDefaultValue) => {
|
|
|
83
82
|
return mapGet(map, key);
|
|
84
83
|
};
|
|
85
84
|
const mapMatch = (map, obj, set, del = mapSet) => {
|
|
86
|
-
|
|
85
|
+
objToArray(obj, (value, id) => set(map, id, value));
|
|
87
86
|
mapForEach(map, (id) => (objHas(obj, id) ? 0 : del(map, id)));
|
|
88
87
|
return map;
|
|
89
88
|
};
|
|
@@ -99,7 +98,12 @@ const setAdd = (set, value) => set?.add(value);
|
|
|
99
98
|
const SELECT_STAR_FROM = SELECT + '*FROM';
|
|
100
99
|
const FROM_PRAGMA_TABLE = 'FROM pragma_table_';
|
|
101
100
|
const WHERE = 'WHERE';
|
|
102
|
-
const getCommandFunctions = (
|
|
101
|
+
const getCommandFunctions = (
|
|
102
|
+
cmd,
|
|
103
|
+
managedTableNames,
|
|
104
|
+
onIgnoredError,
|
|
105
|
+
useOnConflict,
|
|
106
|
+
) => {
|
|
103
107
|
const schemaMap = mapNew();
|
|
104
108
|
const canSelect = (tableName, rowIdColumnName) =>
|
|
105
109
|
!isUndefined(mapGet(mapGet(schemaMap, tableName), rowIdColumnName));
|
|
@@ -112,7 +116,7 @@ const getCommandFunctions = (cmd, managedTableNames, onIgnoredError) => {
|
|
|
112
116
|
await cmd(
|
|
113
117
|
'SELECT name ' +
|
|
114
118
|
FROM_PRAGMA_TABLE +
|
|
115
|
-
`list WHERE schema='main'AND
|
|
119
|
+
`list WHERE schema='main'AND(type='table'OR type='view')AND name IN(` +
|
|
116
120
|
getPlaceholders(managedTableNames) +
|
|
117
121
|
`)ORDER BY name`,
|
|
118
122
|
managedTableNames,
|
|
@@ -167,16 +171,18 @@ const getCommandFunctions = (cmd, managedTableNames, onIgnoredError) => {
|
|
|
167
171
|
const saveTable = async (
|
|
168
172
|
tableName,
|
|
169
173
|
rowIdColumnName,
|
|
170
|
-
|
|
174
|
+
content,
|
|
171
175
|
deleteEmptyColumns,
|
|
172
176
|
deleteEmptyTable,
|
|
173
177
|
partial = false,
|
|
174
178
|
) => {
|
|
175
|
-
const
|
|
176
|
-
|
|
177
|
-
arrayMap(objIds(
|
|
179
|
+
const tableCellOrValueIds = setNew();
|
|
180
|
+
objToArray(content ?? {}, (contentRow) =>
|
|
181
|
+
arrayMap(objIds(contentRow ?? {}), (cellOrValueId) =>
|
|
182
|
+
setAdd(tableCellOrValueIds, cellOrValueId),
|
|
183
|
+
),
|
|
178
184
|
);
|
|
179
|
-
const tableColumnNames = collValues(
|
|
185
|
+
const tableColumnNames = collValues(tableCellOrValueIds);
|
|
180
186
|
if (
|
|
181
187
|
!partial &&
|
|
182
188
|
deleteEmptyTable &&
|
|
@@ -234,11 +240,11 @@ const getCommandFunctions = (cmd, managedTableNames, onIgnoredError) => {
|
|
|
234
240
|
]);
|
|
235
241
|
}
|
|
236
242
|
if (partial) {
|
|
237
|
-
if (isUndefined(
|
|
243
|
+
if (isUndefined(content)) {
|
|
238
244
|
await cmd('DELETE FROM' + escapeId(tableName) + 'WHERE 1');
|
|
239
245
|
} else {
|
|
240
246
|
await promiseAll(
|
|
241
|
-
|
|
247
|
+
objToArray(content, async (row, rowId) => {
|
|
242
248
|
if (isUndefined(row)) {
|
|
243
249
|
await cmd(
|
|
244
250
|
'DELETE FROM' +
|
|
@@ -249,10 +255,14 @@ const getCommandFunctions = (cmd, managedTableNames, onIgnoredError) => {
|
|
|
249
255
|
[rowId],
|
|
250
256
|
);
|
|
251
257
|
} else if (!arrayIsEmpty(tableColumnNames)) {
|
|
252
|
-
await upsert(
|
|
253
|
-
|
|
254
|
-
|
|
255
|
-
|
|
258
|
+
await upsert(
|
|
259
|
+
cmd,
|
|
260
|
+
tableName,
|
|
261
|
+
rowIdColumnName,
|
|
262
|
+
objIds(row),
|
|
263
|
+
[rowId, ...objValues(row)],
|
|
264
|
+
useOnConflict,
|
|
265
|
+
);
|
|
256
266
|
}
|
|
257
267
|
}),
|
|
258
268
|
);
|
|
@@ -265,7 +275,7 @@ const getCommandFunctions = (cmd, managedTableNames, onIgnoredError) => {
|
|
|
265
275
|
);
|
|
266
276
|
const args = [];
|
|
267
277
|
const deleteRowIds = [];
|
|
268
|
-
|
|
278
|
+
objToArray(content ?? {}, (row, rowId) => {
|
|
269
279
|
arrayPush(
|
|
270
280
|
args,
|
|
271
281
|
rowId,
|
|
@@ -314,9 +324,12 @@ const upsert = async (
|
|
|
314
324
|
rowIdColumnName,
|
|
315
325
|
changingColumnNames,
|
|
316
326
|
args,
|
|
327
|
+
useOnConflict = true,
|
|
317
328
|
) =>
|
|
318
329
|
await cmd(
|
|
319
|
-
'INSERT
|
|
330
|
+
'INSERT ' +
|
|
331
|
+
(useOnConflict ? EMPTY_STRING : 'OR REPLACE ') +
|
|
332
|
+
'INTO' +
|
|
320
333
|
escapeId(tableName) +
|
|
321
334
|
'(' +
|
|
322
335
|
escapeId(rowIdColumnName) +
|
|
@@ -334,18 +347,20 @@ const upsert = async (
|
|
|
334
347
|
),
|
|
335
348
|
1,
|
|
336
349
|
) +
|
|
337
|
-
|
|
338
|
-
|
|
339
|
-
|
|
340
|
-
|
|
341
|
-
|
|
342
|
-
|
|
343
|
-
|
|
344
|
-
|
|
345
|
-
|
|
346
|
-
|
|
347
|
-
|
|
348
|
-
|
|
350
|
+
(useOnConflict
|
|
351
|
+
? 'ON CONFLICT(' +
|
|
352
|
+
escapeId(rowIdColumnName) +
|
|
353
|
+
')DO UPDATE SET' +
|
|
354
|
+
arrayJoin(
|
|
355
|
+
arrayMap(
|
|
356
|
+
changingColumnNames,
|
|
357
|
+
(columnName) =>
|
|
358
|
+
escapeId(columnName) + '=excluded.' + escapeId(columnName),
|
|
359
|
+
),
|
|
360
|
+
COMMA,
|
|
361
|
+
)
|
|
362
|
+
: EMPTY_STRING),
|
|
363
|
+
arrayMap(args, (arg) => arg ?? null),
|
|
349
364
|
);
|
|
350
365
|
const getPlaceholders = (array) =>
|
|
351
366
|
arrayJoin(
|
|
@@ -368,6 +383,7 @@ const createCustomPersister = (
|
|
|
368
383
|
addPersisterListener,
|
|
369
384
|
delPersisterListener,
|
|
370
385
|
onIgnoredError,
|
|
386
|
+
supportsMergeableStore,
|
|
371
387
|
[getThing, thing] = [],
|
|
372
388
|
scheduleId = [],
|
|
373
389
|
) => {
|
|
@@ -380,6 +396,10 @@ const createCustomPersister = (
|
|
|
380
396
|
let listeningHandle;
|
|
381
397
|
mapEnsure(scheduleRunning, scheduleId, () => 0);
|
|
382
398
|
mapEnsure(scheduleActions, scheduleId, () => []);
|
|
399
|
+
const getContent =
|
|
400
|
+
(supportsMergeableStore ? store.getMergeableContent : null) ??
|
|
401
|
+
store.getContent;
|
|
402
|
+
const getChanges = store.getTransactionChanges;
|
|
383
403
|
const run = async () => {
|
|
384
404
|
/* istanbul ignore else */
|
|
385
405
|
if (!mapGet(scheduleRunning, scheduleId)) {
|
|
@@ -415,7 +435,10 @@ const createCustomPersister = (
|
|
|
415
435
|
load: async (initialTables, initialValues) =>
|
|
416
436
|
await loadLock(async () => {
|
|
417
437
|
try {
|
|
418
|
-
|
|
438
|
+
const content = await getPersisted();
|
|
439
|
+
(supportsMergeableStore && isString(content[0])
|
|
440
|
+
? store.applyMergeableChanges
|
|
441
|
+
: store.setContent)(content);
|
|
419
442
|
} catch {
|
|
420
443
|
store.setContent([initialTables, initialValues]);
|
|
421
444
|
}
|
|
@@ -425,16 +448,14 @@ const createCustomPersister = (
|
|
|
425
448
|
await persister.load(initialTables, initialValues);
|
|
426
449
|
listening = 1;
|
|
427
450
|
listeningHandle = addPersisterListener(
|
|
428
|
-
async (
|
|
429
|
-
if (
|
|
430
|
-
const
|
|
431
|
-
await loadLock(async () =>
|
|
432
|
-
store.setTransactionChanges(transactionChanges),
|
|
433
|
-
);
|
|
451
|
+
async (getContent2, getChanges2) => {
|
|
452
|
+
if (getChanges2) {
|
|
453
|
+
const changes = getChanges2();
|
|
454
|
+
await loadLock(async () => store.applyChanges(changes));
|
|
434
455
|
} else {
|
|
435
456
|
await loadLock(async () => {
|
|
436
457
|
try {
|
|
437
|
-
store.setContent(
|
|
458
|
+
store.setContent(getContent2?.() ?? (await getPersisted()));
|
|
438
459
|
} catch (error) {
|
|
439
460
|
onIgnoredError?.(error);
|
|
440
461
|
}
|
|
@@ -452,7 +473,7 @@ const createCustomPersister = (
|
|
|
452
473
|
}
|
|
453
474
|
return persister;
|
|
454
475
|
},
|
|
455
|
-
save: async (
|
|
476
|
+
save: async (getChanges2) => {
|
|
456
477
|
/* istanbul ignore else */
|
|
457
478
|
if (loadSave != 1) {
|
|
458
479
|
loadSave = 2;
|
|
@@ -461,7 +482,7 @@ const createCustomPersister = (
|
|
|
461
482
|
}
|
|
462
483
|
await persister.schedule(async () => {
|
|
463
484
|
try {
|
|
464
|
-
await setPersisted(
|
|
485
|
+
await setPersisted(getContent, getChanges2);
|
|
465
486
|
} catch (error) {
|
|
466
487
|
/* istanbul ignore next */
|
|
467
488
|
onIgnoredError?.(error);
|
|
@@ -473,14 +494,12 @@ const createCustomPersister = (
|
|
|
473
494
|
},
|
|
474
495
|
startAutoSave: async () => {
|
|
475
496
|
await persister.stopAutoSave().save();
|
|
476
|
-
listenerId = store.addDidFinishTransactionListener(
|
|
477
|
-
|
|
478
|
-
|
|
479
|
-
|
|
480
|
-
|
|
481
|
-
|
|
482
|
-
},
|
|
483
|
-
);
|
|
497
|
+
listenerId = store.addDidFinishTransactionListener(() => {
|
|
498
|
+
const [tableChanges, valueChanges] = getChanges();
|
|
499
|
+
if (!objIsEmpty(tableChanges) || !objIsEmpty(valueChanges)) {
|
|
500
|
+
persister.save(() => [tableChanges, valueChanges]);
|
|
501
|
+
}
|
|
502
|
+
});
|
|
484
503
|
return persister;
|
|
485
504
|
},
|
|
486
505
|
stopAutoSave: () => {
|
|
@@ -546,6 +565,7 @@ const createJsonSqlitePersister = (
|
|
|
546
565
|
addPersisterListener,
|
|
547
566
|
delPersisterListener,
|
|
548
567
|
onIgnoredError,
|
|
568
|
+
false,
|
|
549
569
|
[getThing, db],
|
|
550
570
|
db,
|
|
551
571
|
);
|
|
@@ -566,9 +586,10 @@ const createTabularSqlitePersister = (
|
|
|
566
586
|
managedTableNames,
|
|
567
587
|
db,
|
|
568
588
|
getThing,
|
|
589
|
+
useOnConflict,
|
|
569
590
|
) => {
|
|
570
591
|
const [refreshSchema, loadTable, saveTable, transaction] =
|
|
571
|
-
getCommandFunctions(cmd, managedTableNames, onIgnoredError);
|
|
592
|
+
getCommandFunctions(cmd, managedTableNames, onIgnoredError, useOnConflict);
|
|
572
593
|
const saveTables = async (tables, partial) =>
|
|
573
594
|
await promiseAll(
|
|
574
595
|
mapMap(
|
|
@@ -577,12 +598,11 @@ const createTabularSqlitePersister = (
|
|
|
577
598
|
[tableName, rowIdColumnName, deleteEmptyColumns, deleteEmptyTable],
|
|
578
599
|
tableId,
|
|
579
600
|
) => {
|
|
580
|
-
|
|
581
|
-
if (!partial || table !== void 0) {
|
|
601
|
+
if (!partial || objHas(tables, tableId)) {
|
|
582
602
|
await saveTable(
|
|
583
603
|
tableName,
|
|
584
604
|
rowIdColumnName,
|
|
585
|
-
|
|
605
|
+
tables[tableId],
|
|
586
606
|
deleteEmptyColumns,
|
|
587
607
|
deleteEmptyTable,
|
|
588
608
|
partial,
|
|
@@ -632,11 +652,11 @@ const createTabularSqlitePersister = (
|
|
|
632
652
|
? [tables, values]
|
|
633
653
|
: void 0;
|
|
634
654
|
});
|
|
635
|
-
const setPersisted = async (getContent,
|
|
655
|
+
const setPersisted = async (getContent, getChanges) =>
|
|
636
656
|
await transaction(async () => {
|
|
637
657
|
await refreshSchema();
|
|
638
|
-
if (!isUndefined(
|
|
639
|
-
const [tableChanges, valueChanges] =
|
|
658
|
+
if (!isUndefined(getChanges)) {
|
|
659
|
+
const [tableChanges, valueChanges] = getChanges();
|
|
640
660
|
await saveTables(tableChanges, true);
|
|
641
661
|
await saveValues(valueChanges, true);
|
|
642
662
|
} else {
|
|
@@ -652,6 +672,7 @@ const createTabularSqlitePersister = (
|
|
|
652
672
|
addPersisterListener,
|
|
653
673
|
delPersisterListener,
|
|
654
674
|
onIgnoredError,
|
|
675
|
+
false,
|
|
655
676
|
[getThing, db],
|
|
656
677
|
db,
|
|
657
678
|
);
|
|
@@ -689,7 +710,7 @@ const getDefaultedTabularConfigMap = (
|
|
|
689
710
|
filter,
|
|
690
711
|
) => {
|
|
691
712
|
const configMap = mapNew();
|
|
692
|
-
|
|
713
|
+
objToArray(configsObj, (configObj, id) => {
|
|
693
714
|
const defaultedConfig = slice(
|
|
694
715
|
objValues(
|
|
695
716
|
objMerge(
|
|
@@ -764,6 +785,7 @@ const createSqlitePersister = (
|
|
|
764
785
|
onIgnoredError,
|
|
765
786
|
db,
|
|
766
787
|
getThing = 'getDb',
|
|
788
|
+
useOnConflict,
|
|
767
789
|
) => {
|
|
768
790
|
let dataVersion;
|
|
769
791
|
let schemaVersion;
|
|
@@ -826,6 +848,7 @@ const createSqlitePersister = (
|
|
|
826
848
|
collValues(managedTableNamesSet),
|
|
827
849
|
db,
|
|
828
850
|
getThing,
|
|
851
|
+
useOnConflict,
|
|
829
852
|
);
|
|
830
853
|
};
|
|
831
854
|
|