tinybase 5.3.6 → 5.3.8
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/@types/persisters/index.d.cts +6 -4
- package/@types/persisters/index.d.ts +6 -4
- package/@types/persisters/with-schemas/index.d.cts +6 -4
- package/@types/persisters/with-schemas/index.d.ts +6 -4
- package/@types/synchronizers/synchronizer-ws-server/index.d.cts +4 -0
- package/@types/synchronizers/synchronizer-ws-server/index.d.ts +4 -0
- package/@types/synchronizers/synchronizer-ws-server/with-schemas/index.d.cts +5 -0
- package/@types/synchronizers/synchronizer-ws-server/with-schemas/index.d.ts +5 -0
- package/cjs/es6/min/persisters/index.cjs +1 -1
- package/cjs/es6/min/persisters/index.cjs.gz +0 -0
- package/cjs/es6/min/persisters/persister-automerge/index.cjs +1 -1
- package/cjs/es6/min/persisters/persister-automerge/index.cjs.gz +0 -0
- package/cjs/es6/min/persisters/persister-automerge/with-schemas/index.cjs +1 -1
- package/cjs/es6/min/persisters/persister-automerge/with-schemas/index.cjs.gz +0 -0
- package/cjs/es6/min/persisters/persister-browser/index.cjs +1 -1
- package/cjs/es6/min/persisters/persister-browser/index.cjs.gz +0 -0
- package/cjs/es6/min/persisters/persister-browser/with-schemas/index.cjs +1 -1
- package/cjs/es6/min/persisters/persister-browser/with-schemas/index.cjs.gz +0 -0
- package/cjs/es6/min/persisters/persister-cr-sqlite-wasm/index.cjs +1 -1
- package/cjs/es6/min/persisters/persister-cr-sqlite-wasm/index.cjs.gz +0 -0
- package/cjs/es6/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.cjs +1 -1
- package/cjs/es6/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.cjs.gz +0 -0
- package/cjs/es6/min/persisters/persister-electric-sql/index.cjs +1 -1
- package/cjs/es6/min/persisters/persister-electric-sql/index.cjs.gz +0 -0
- package/cjs/es6/min/persisters/persister-electric-sql/with-schemas/index.cjs +1 -1
- package/cjs/es6/min/persisters/persister-electric-sql/with-schemas/index.cjs.gz +0 -0
- package/cjs/es6/min/persisters/persister-expo-sqlite/index.cjs +1 -1
- package/cjs/es6/min/persisters/persister-expo-sqlite/index.cjs.gz +0 -0
- package/cjs/es6/min/persisters/persister-expo-sqlite/with-schemas/index.cjs +1 -1
- package/cjs/es6/min/persisters/persister-expo-sqlite/with-schemas/index.cjs.gz +0 -0
- package/cjs/es6/min/persisters/persister-file/index.cjs +1 -1
- package/cjs/es6/min/persisters/persister-file/index.cjs.gz +0 -0
- package/cjs/es6/min/persisters/persister-file/with-schemas/index.cjs +1 -1
- package/cjs/es6/min/persisters/persister-file/with-schemas/index.cjs.gz +0 -0
- package/cjs/es6/min/persisters/persister-indexed-db/index.cjs +1 -1
- package/cjs/es6/min/persisters/persister-indexed-db/index.cjs.gz +0 -0
- package/cjs/es6/min/persisters/persister-indexed-db/with-schemas/index.cjs +1 -1
- package/cjs/es6/min/persisters/persister-indexed-db/with-schemas/index.cjs.gz +0 -0
- package/cjs/es6/min/persisters/persister-libsql/index.cjs +1 -1
- package/cjs/es6/min/persisters/persister-libsql/index.cjs.gz +0 -0
- package/cjs/es6/min/persisters/persister-libsql/with-schemas/index.cjs +1 -1
- package/cjs/es6/min/persisters/persister-libsql/with-schemas/index.cjs.gz +0 -0
- package/cjs/es6/min/persisters/persister-partykit-client/index.cjs +1 -1
- package/cjs/es6/min/persisters/persister-partykit-client/index.cjs.gz +0 -0
- package/cjs/es6/min/persisters/persister-partykit-client/with-schemas/index.cjs +1 -1
- package/cjs/es6/min/persisters/persister-partykit-client/with-schemas/index.cjs.gz +0 -0
- package/cjs/es6/min/persisters/persister-pglite/index.cjs +1 -1
- package/cjs/es6/min/persisters/persister-pglite/index.cjs.gz +0 -0
- package/cjs/es6/min/persisters/persister-pglite/with-schemas/index.cjs +1 -1
- package/cjs/es6/min/persisters/persister-pglite/with-schemas/index.cjs.gz +0 -0
- package/cjs/es6/min/persisters/persister-postgres/index.cjs +1 -1
- package/cjs/es6/min/persisters/persister-postgres/index.cjs.gz +0 -0
- package/cjs/es6/min/persisters/persister-postgres/with-schemas/index.cjs +1 -1
- package/cjs/es6/min/persisters/persister-postgres/with-schemas/index.cjs.gz +0 -0
- package/cjs/es6/min/persisters/persister-powersync/index.cjs +1 -1
- package/cjs/es6/min/persisters/persister-powersync/index.cjs.gz +0 -0
- package/cjs/es6/min/persisters/persister-powersync/with-schemas/index.cjs +1 -1
- package/cjs/es6/min/persisters/persister-powersync/with-schemas/index.cjs.gz +0 -0
- package/cjs/es6/min/persisters/persister-remote/index.cjs +1 -1
- package/cjs/es6/min/persisters/persister-remote/index.cjs.gz +0 -0
- package/cjs/es6/min/persisters/persister-remote/with-schemas/index.cjs +1 -1
- package/cjs/es6/min/persisters/persister-remote/with-schemas/index.cjs.gz +0 -0
- package/cjs/es6/min/persisters/persister-sqlite-wasm/index.cjs +1 -1
- package/cjs/es6/min/persisters/persister-sqlite-wasm/index.cjs.gz +0 -0
- package/cjs/es6/min/persisters/persister-sqlite-wasm/with-schemas/index.cjs +1 -1
- package/cjs/es6/min/persisters/persister-sqlite-wasm/with-schemas/index.cjs.gz +0 -0
- package/cjs/es6/min/persisters/persister-sqlite3/index.cjs +1 -1
- package/cjs/es6/min/persisters/persister-sqlite3/index.cjs.gz +0 -0
- package/cjs/es6/min/persisters/persister-sqlite3/with-schemas/index.cjs +1 -1
- package/cjs/es6/min/persisters/persister-sqlite3/with-schemas/index.cjs.gz +0 -0
- package/cjs/es6/min/persisters/persister-yjs/index.cjs +1 -1
- package/cjs/es6/min/persisters/persister-yjs/index.cjs.gz +0 -0
- package/cjs/es6/min/persisters/persister-yjs/with-schemas/index.cjs +1 -1
- package/cjs/es6/min/persisters/persister-yjs/with-schemas/index.cjs.gz +0 -0
- package/cjs/es6/min/persisters/with-schemas/index.cjs +1 -1
- package/cjs/es6/min/persisters/with-schemas/index.cjs.gz +0 -0
- package/cjs/es6/min/synchronizers/index.cjs +1 -1
- package/cjs/es6/min/synchronizers/index.cjs.gz +0 -0
- package/cjs/es6/min/synchronizers/synchronizer-broadcast-channel/index.cjs +1 -1
- package/cjs/es6/min/synchronizers/synchronizer-broadcast-channel/index.cjs.gz +0 -0
- package/cjs/es6/min/synchronizers/synchronizer-broadcast-channel/with-schemas/index.cjs +1 -1
- package/cjs/es6/min/synchronizers/synchronizer-broadcast-channel/with-schemas/index.cjs.gz +0 -0
- package/cjs/es6/min/synchronizers/synchronizer-local/index.cjs +1 -1
- package/cjs/es6/min/synchronizers/synchronizer-local/index.cjs.gz +0 -0
- package/cjs/es6/min/synchronizers/synchronizer-local/with-schemas/index.cjs +1 -1
- package/cjs/es6/min/synchronizers/synchronizer-local/with-schemas/index.cjs.gz +0 -0
- package/cjs/es6/min/synchronizers/synchronizer-ws-client/index.cjs +1 -1
- package/cjs/es6/min/synchronizers/synchronizer-ws-client/index.cjs.gz +0 -0
- package/cjs/es6/min/synchronizers/synchronizer-ws-client/with-schemas/index.cjs +1 -1
- package/cjs/es6/min/synchronizers/synchronizer-ws-client/with-schemas/index.cjs.gz +0 -0
- package/cjs/es6/min/synchronizers/synchronizer-ws-server/index.cjs +1 -1
- package/cjs/es6/min/synchronizers/synchronizer-ws-server/index.cjs.gz +0 -0
- package/cjs/es6/min/synchronizers/synchronizer-ws-server/with-schemas/index.cjs +1 -1
- package/cjs/es6/min/synchronizers/synchronizer-ws-server/with-schemas/index.cjs.gz +0 -0
- package/cjs/es6/min/synchronizers/with-schemas/index.cjs +1 -1
- package/cjs/es6/min/synchronizers/with-schemas/index.cjs.gz +0 -0
- package/cjs/es6/min/ui-react-inspector/index.cjs +1 -1
- package/cjs/es6/min/ui-react-inspector/index.cjs.gz +0 -0
- package/cjs/es6/min/ui-react-inspector/with-schemas/index.cjs +1 -1
- package/cjs/es6/min/ui-react-inspector/with-schemas/index.cjs.gz +0 -0
- package/cjs/es6/persisters/index.cjs +1 -1
- package/cjs/es6/persisters/persister-automerge/index.cjs +1 -1
- package/cjs/es6/persisters/persister-automerge/with-schemas/index.cjs +1 -1
- package/cjs/es6/persisters/persister-browser/index.cjs +1 -1
- package/cjs/es6/persisters/persister-browser/with-schemas/index.cjs +1 -1
- package/cjs/es6/persisters/persister-cr-sqlite-wasm/index.cjs +1 -1
- package/cjs/es6/persisters/persister-cr-sqlite-wasm/with-schemas/index.cjs +1 -1
- package/cjs/es6/persisters/persister-electric-sql/index.cjs +1 -1
- package/cjs/es6/persisters/persister-electric-sql/with-schemas/index.cjs +1 -1
- package/cjs/es6/persisters/persister-expo-sqlite/index.cjs +1 -1
- package/cjs/es6/persisters/persister-expo-sqlite/with-schemas/index.cjs +1 -1
- package/cjs/es6/persisters/persister-file/index.cjs +1 -1
- package/cjs/es6/persisters/persister-file/with-schemas/index.cjs +1 -1
- package/cjs/es6/persisters/persister-indexed-db/index.cjs +1 -1
- package/cjs/es6/persisters/persister-indexed-db/with-schemas/index.cjs +1 -1
- package/cjs/es6/persisters/persister-libsql/index.cjs +1 -1
- package/cjs/es6/persisters/persister-libsql/with-schemas/index.cjs +1 -1
- package/cjs/es6/persisters/persister-partykit-client/index.cjs +1 -1
- package/cjs/es6/persisters/persister-partykit-client/with-schemas/index.cjs +1 -1
- package/cjs/es6/persisters/persister-pglite/index.cjs +1 -1
- package/cjs/es6/persisters/persister-pglite/with-schemas/index.cjs +1 -1
- package/cjs/es6/persisters/persister-postgres/index.cjs +1 -1
- package/cjs/es6/persisters/persister-postgres/with-schemas/index.cjs +1 -1
- package/cjs/es6/persisters/persister-powersync/index.cjs +1 -1
- package/cjs/es6/persisters/persister-powersync/with-schemas/index.cjs +1 -1
- package/cjs/es6/persisters/persister-remote/index.cjs +1 -1
- package/cjs/es6/persisters/persister-remote/with-schemas/index.cjs +1 -1
- package/cjs/es6/persisters/persister-sqlite-wasm/index.cjs +1 -1
- package/cjs/es6/persisters/persister-sqlite-wasm/with-schemas/index.cjs +1 -1
- package/cjs/es6/persisters/persister-sqlite3/index.cjs +1 -1
- package/cjs/es6/persisters/persister-sqlite3/with-schemas/index.cjs +1 -1
- package/cjs/es6/persisters/persister-yjs/index.cjs +1 -1
- package/cjs/es6/persisters/persister-yjs/with-schemas/index.cjs +1 -1
- package/cjs/es6/persisters/with-schemas/index.cjs +1 -1
- package/cjs/es6/synchronizers/index.cjs +51 -42
- package/cjs/es6/synchronizers/synchronizer-broadcast-channel/index.cjs +51 -42
- package/cjs/es6/synchronizers/synchronizer-broadcast-channel/with-schemas/index.cjs +51 -42
- package/cjs/es6/synchronizers/synchronizer-local/index.cjs +51 -42
- package/cjs/es6/synchronizers/synchronizer-local/with-schemas/index.cjs +51 -42
- package/cjs/es6/synchronizers/synchronizer-ws-client/index.cjs +51 -42
- package/cjs/es6/synchronizers/synchronizer-ws-client/with-schemas/index.cjs +51 -42
- package/cjs/es6/synchronizers/synchronizer-ws-server/index.cjs +78 -46
- package/cjs/es6/synchronizers/synchronizer-ws-server/with-schemas/index.cjs +78 -46
- package/cjs/es6/synchronizers/with-schemas/index.cjs +51 -42
- package/cjs/es6/ui-react-inspector/index.cjs +1 -1
- package/cjs/es6/ui-react-inspector/with-schemas/index.cjs +1 -1
- package/cjs/min/persisters/index.cjs +1 -1
- package/cjs/min/persisters/index.cjs.gz +0 -0
- package/cjs/min/persisters/persister-automerge/index.cjs +1 -1
- package/cjs/min/persisters/persister-automerge/index.cjs.gz +0 -0
- package/cjs/min/persisters/persister-automerge/with-schemas/index.cjs +1 -1
- package/cjs/min/persisters/persister-automerge/with-schemas/index.cjs.gz +0 -0
- package/cjs/min/persisters/persister-browser/index.cjs +1 -1
- package/cjs/min/persisters/persister-browser/index.cjs.gz +0 -0
- package/cjs/min/persisters/persister-browser/with-schemas/index.cjs +1 -1
- package/cjs/min/persisters/persister-browser/with-schemas/index.cjs.gz +0 -0
- package/cjs/min/persisters/persister-cr-sqlite-wasm/index.cjs +1 -1
- package/cjs/min/persisters/persister-cr-sqlite-wasm/index.cjs.gz +0 -0
- package/cjs/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.cjs +1 -1
- package/cjs/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.cjs.gz +0 -0
- package/cjs/min/persisters/persister-electric-sql/index.cjs +1 -1
- package/cjs/min/persisters/persister-electric-sql/index.cjs.gz +0 -0
- package/cjs/min/persisters/persister-electric-sql/with-schemas/index.cjs +1 -1
- package/cjs/min/persisters/persister-electric-sql/with-schemas/index.cjs.gz +0 -0
- package/cjs/min/persisters/persister-expo-sqlite/index.cjs +1 -1
- package/cjs/min/persisters/persister-expo-sqlite/index.cjs.gz +0 -0
- package/cjs/min/persisters/persister-expo-sqlite/with-schemas/index.cjs +1 -1
- package/cjs/min/persisters/persister-expo-sqlite/with-schemas/index.cjs.gz +0 -0
- package/cjs/min/persisters/persister-file/index.cjs +1 -1
- package/cjs/min/persisters/persister-file/index.cjs.gz +0 -0
- package/cjs/min/persisters/persister-file/with-schemas/index.cjs +1 -1
- package/cjs/min/persisters/persister-file/with-schemas/index.cjs.gz +0 -0
- package/cjs/min/persisters/persister-indexed-db/index.cjs +1 -1
- package/cjs/min/persisters/persister-indexed-db/index.cjs.gz +0 -0
- package/cjs/min/persisters/persister-indexed-db/with-schemas/index.cjs +1 -1
- package/cjs/min/persisters/persister-indexed-db/with-schemas/index.cjs.gz +0 -0
- package/cjs/min/persisters/persister-libsql/index.cjs +1 -1
- package/cjs/min/persisters/persister-libsql/index.cjs.gz +0 -0
- package/cjs/min/persisters/persister-libsql/with-schemas/index.cjs +1 -1
- package/cjs/min/persisters/persister-libsql/with-schemas/index.cjs.gz +0 -0
- package/cjs/min/persisters/persister-partykit-client/index.cjs +1 -1
- package/cjs/min/persisters/persister-partykit-client/index.cjs.gz +0 -0
- package/cjs/min/persisters/persister-partykit-client/with-schemas/index.cjs +1 -1
- package/cjs/min/persisters/persister-partykit-client/with-schemas/index.cjs.gz +0 -0
- package/cjs/min/persisters/persister-pglite/index.cjs +1 -1
- package/cjs/min/persisters/persister-pglite/index.cjs.gz +0 -0
- package/cjs/min/persisters/persister-pglite/with-schemas/index.cjs +1 -1
- package/cjs/min/persisters/persister-pglite/with-schemas/index.cjs.gz +0 -0
- package/cjs/min/persisters/persister-postgres/index.cjs +1 -1
- package/cjs/min/persisters/persister-postgres/index.cjs.gz +0 -0
- package/cjs/min/persisters/persister-postgres/with-schemas/index.cjs +1 -1
- package/cjs/min/persisters/persister-postgres/with-schemas/index.cjs.gz +0 -0
- package/cjs/min/persisters/persister-powersync/index.cjs +1 -1
- package/cjs/min/persisters/persister-powersync/index.cjs.gz +0 -0
- package/cjs/min/persisters/persister-powersync/with-schemas/index.cjs +1 -1
- package/cjs/min/persisters/persister-powersync/with-schemas/index.cjs.gz +0 -0
- package/cjs/min/persisters/persister-remote/index.cjs +1 -1
- package/cjs/min/persisters/persister-remote/index.cjs.gz +0 -0
- package/cjs/min/persisters/persister-remote/with-schemas/index.cjs +1 -1
- package/cjs/min/persisters/persister-remote/with-schemas/index.cjs.gz +0 -0
- package/cjs/min/persisters/persister-sqlite-wasm/index.cjs +1 -1
- package/cjs/min/persisters/persister-sqlite-wasm/index.cjs.gz +0 -0
- package/cjs/min/persisters/persister-sqlite-wasm/with-schemas/index.cjs +1 -1
- package/cjs/min/persisters/persister-sqlite-wasm/with-schemas/index.cjs.gz +0 -0
- package/cjs/min/persisters/persister-sqlite3/index.cjs +1 -1
- package/cjs/min/persisters/persister-sqlite3/index.cjs.gz +0 -0
- package/cjs/min/persisters/persister-sqlite3/with-schemas/index.cjs +1 -1
- package/cjs/min/persisters/persister-sqlite3/with-schemas/index.cjs.gz +0 -0
- package/cjs/min/persisters/persister-yjs/index.cjs +1 -1
- package/cjs/min/persisters/persister-yjs/index.cjs.gz +0 -0
- package/cjs/min/persisters/persister-yjs/with-schemas/index.cjs +1 -1
- package/cjs/min/persisters/persister-yjs/with-schemas/index.cjs.gz +0 -0
- package/cjs/min/persisters/with-schemas/index.cjs +1 -1
- package/cjs/min/persisters/with-schemas/index.cjs.gz +0 -0
- package/cjs/min/synchronizers/index.cjs +1 -1
- package/cjs/min/synchronizers/index.cjs.gz +0 -0
- package/cjs/min/synchronizers/synchronizer-broadcast-channel/index.cjs +1 -1
- package/cjs/min/synchronizers/synchronizer-broadcast-channel/index.cjs.gz +0 -0
- package/cjs/min/synchronizers/synchronizer-broadcast-channel/with-schemas/index.cjs +1 -1
- package/cjs/min/synchronizers/synchronizer-broadcast-channel/with-schemas/index.cjs.gz +0 -0
- package/cjs/min/synchronizers/synchronizer-local/index.cjs +1 -1
- package/cjs/min/synchronizers/synchronizer-local/index.cjs.gz +0 -0
- package/cjs/min/synchronizers/synchronizer-local/with-schemas/index.cjs +1 -1
- package/cjs/min/synchronizers/synchronizer-local/with-schemas/index.cjs.gz +0 -0
- package/cjs/min/synchronizers/synchronizer-ws-client/index.cjs +1 -1
- package/cjs/min/synchronizers/synchronizer-ws-client/index.cjs.gz +0 -0
- package/cjs/min/synchronizers/synchronizer-ws-client/with-schemas/index.cjs +1 -1
- package/cjs/min/synchronizers/synchronizer-ws-client/with-schemas/index.cjs.gz +0 -0
- package/cjs/min/synchronizers/synchronizer-ws-server/index.cjs +1 -1
- package/cjs/min/synchronizers/synchronizer-ws-server/index.cjs.gz +0 -0
- package/cjs/min/synchronizers/synchronizer-ws-server/with-schemas/index.cjs +1 -1
- package/cjs/min/synchronizers/synchronizer-ws-server/with-schemas/index.cjs.gz +0 -0
- package/cjs/min/synchronizers/with-schemas/index.cjs +1 -1
- package/cjs/min/synchronizers/with-schemas/index.cjs.gz +0 -0
- package/cjs/min/ui-react-inspector/index.cjs +1 -1
- package/cjs/min/ui-react-inspector/index.cjs.gz +0 -0
- package/cjs/min/ui-react-inspector/with-schemas/index.cjs +1 -1
- package/cjs/min/ui-react-inspector/with-schemas/index.cjs.gz +0 -0
- package/cjs/persisters/index.cjs +1 -1
- package/cjs/persisters/persister-automerge/index.cjs +1 -1
- package/cjs/persisters/persister-automerge/with-schemas/index.cjs +1 -1
- package/cjs/persisters/persister-browser/index.cjs +1 -1
- package/cjs/persisters/persister-browser/with-schemas/index.cjs +1 -1
- package/cjs/persisters/persister-cr-sqlite-wasm/index.cjs +1 -1
- package/cjs/persisters/persister-cr-sqlite-wasm/with-schemas/index.cjs +1 -1
- package/cjs/persisters/persister-electric-sql/index.cjs +1 -1
- package/cjs/persisters/persister-electric-sql/with-schemas/index.cjs +1 -1
- package/cjs/persisters/persister-expo-sqlite/index.cjs +1 -1
- package/cjs/persisters/persister-expo-sqlite/with-schemas/index.cjs +1 -1
- package/cjs/persisters/persister-file/index.cjs +1 -1
- package/cjs/persisters/persister-file/with-schemas/index.cjs +1 -1
- package/cjs/persisters/persister-indexed-db/index.cjs +1 -1
- package/cjs/persisters/persister-indexed-db/with-schemas/index.cjs +1 -1
- package/cjs/persisters/persister-libsql/index.cjs +1 -1
- package/cjs/persisters/persister-libsql/with-schemas/index.cjs +1 -1
- package/cjs/persisters/persister-partykit-client/index.cjs +1 -1
- package/cjs/persisters/persister-partykit-client/with-schemas/index.cjs +1 -1
- package/cjs/persisters/persister-pglite/index.cjs +1 -1
- package/cjs/persisters/persister-pglite/with-schemas/index.cjs +1 -1
- package/cjs/persisters/persister-postgres/index.cjs +1 -1
- package/cjs/persisters/persister-postgres/with-schemas/index.cjs +1 -1
- package/cjs/persisters/persister-powersync/index.cjs +1 -1
- package/cjs/persisters/persister-powersync/with-schemas/index.cjs +1 -1
- package/cjs/persisters/persister-remote/index.cjs +1 -1
- package/cjs/persisters/persister-remote/with-schemas/index.cjs +1 -1
- package/cjs/persisters/persister-sqlite-wasm/index.cjs +1 -1
- package/cjs/persisters/persister-sqlite-wasm/with-schemas/index.cjs +1 -1
- package/cjs/persisters/persister-sqlite3/index.cjs +1 -1
- package/cjs/persisters/persister-sqlite3/with-schemas/index.cjs +1 -1
- package/cjs/persisters/persister-yjs/index.cjs +1 -1
- package/cjs/persisters/persister-yjs/with-schemas/index.cjs +1 -1
- package/cjs/persisters/with-schemas/index.cjs +1 -1
- package/cjs/synchronizers/index.cjs +51 -45
- package/cjs/synchronizers/synchronizer-broadcast-channel/index.cjs +51 -45
- package/cjs/synchronizers/synchronizer-broadcast-channel/with-schemas/index.cjs +51 -45
- package/cjs/synchronizers/synchronizer-local/index.cjs +51 -45
- package/cjs/synchronizers/synchronizer-local/with-schemas/index.cjs +51 -45
- package/cjs/synchronizers/synchronizer-ws-client/index.cjs +51 -45
- package/cjs/synchronizers/synchronizer-ws-client/with-schemas/index.cjs +51 -45
- package/cjs/synchronizers/synchronizer-ws-server/index.cjs +78 -49
- package/cjs/synchronizers/synchronizer-ws-server/with-schemas/index.cjs +78 -49
- package/cjs/synchronizers/with-schemas/index.cjs +51 -45
- package/cjs/ui-react-inspector/index.cjs +1 -1
- package/cjs/ui-react-inspector/with-schemas/index.cjs +1 -1
- package/es6/min/persisters/index.js +1 -1
- package/es6/min/persisters/index.js.gz +0 -0
- package/es6/min/persisters/persister-automerge/index.js +1 -1
- package/es6/min/persisters/persister-automerge/index.js.gz +0 -0
- package/es6/min/persisters/persister-automerge/with-schemas/index.js +1 -1
- package/es6/min/persisters/persister-automerge/with-schemas/index.js.gz +0 -0
- package/es6/min/persisters/persister-browser/index.js +1 -1
- package/es6/min/persisters/persister-browser/index.js.gz +0 -0
- package/es6/min/persisters/persister-browser/with-schemas/index.js +1 -1
- package/es6/min/persisters/persister-browser/with-schemas/index.js.gz +0 -0
- package/es6/min/persisters/persister-cr-sqlite-wasm/index.js +1 -1
- package/es6/min/persisters/persister-cr-sqlite-wasm/index.js.gz +0 -0
- package/es6/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.js +1 -1
- package/es6/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.js.gz +0 -0
- package/es6/min/persisters/persister-electric-sql/index.js +1 -1
- package/es6/min/persisters/persister-electric-sql/index.js.gz +0 -0
- package/es6/min/persisters/persister-electric-sql/with-schemas/index.js +1 -1
- package/es6/min/persisters/persister-electric-sql/with-schemas/index.js.gz +0 -0
- package/es6/min/persisters/persister-expo-sqlite/index.js +1 -1
- package/es6/min/persisters/persister-expo-sqlite/index.js.gz +0 -0
- package/es6/min/persisters/persister-expo-sqlite/with-schemas/index.js +1 -1
- package/es6/min/persisters/persister-expo-sqlite/with-schemas/index.js.gz +0 -0
- package/es6/min/persisters/persister-file/index.js +1 -1
- package/es6/min/persisters/persister-file/index.js.gz +0 -0
- package/es6/min/persisters/persister-file/with-schemas/index.js +1 -1
- package/es6/min/persisters/persister-file/with-schemas/index.js.gz +0 -0
- package/es6/min/persisters/persister-indexed-db/index.js +1 -1
- package/es6/min/persisters/persister-indexed-db/index.js.gz +0 -0
- package/es6/min/persisters/persister-indexed-db/with-schemas/index.js +1 -1
- package/es6/min/persisters/persister-indexed-db/with-schemas/index.js.gz +0 -0
- package/es6/min/persisters/persister-libsql/index.js +1 -1
- package/es6/min/persisters/persister-libsql/index.js.gz +0 -0
- package/es6/min/persisters/persister-libsql/with-schemas/index.js +1 -1
- package/es6/min/persisters/persister-libsql/with-schemas/index.js.gz +0 -0
- package/es6/min/persisters/persister-partykit-client/index.js +1 -1
- package/es6/min/persisters/persister-partykit-client/index.js.gz +0 -0
- package/es6/min/persisters/persister-partykit-client/with-schemas/index.js +1 -1
- package/es6/min/persisters/persister-partykit-client/with-schemas/index.js.gz +0 -0
- package/es6/min/persisters/persister-pglite/index.js +1 -1
- package/es6/min/persisters/persister-pglite/index.js.gz +0 -0
- package/es6/min/persisters/persister-pglite/with-schemas/index.js +1 -1
- package/es6/min/persisters/persister-pglite/with-schemas/index.js.gz +0 -0
- package/es6/min/persisters/persister-postgres/index.js +1 -1
- package/es6/min/persisters/persister-postgres/index.js.gz +0 -0
- package/es6/min/persisters/persister-postgres/with-schemas/index.js +1 -1
- package/es6/min/persisters/persister-postgres/with-schemas/index.js.gz +0 -0
- package/es6/min/persisters/persister-powersync/index.js +1 -1
- package/es6/min/persisters/persister-powersync/index.js.gz +0 -0
- package/es6/min/persisters/persister-powersync/with-schemas/index.js +1 -1
- package/es6/min/persisters/persister-powersync/with-schemas/index.js.gz +0 -0
- package/es6/min/persisters/persister-remote/index.js +1 -1
- package/es6/min/persisters/persister-remote/index.js.gz +0 -0
- package/es6/min/persisters/persister-remote/with-schemas/index.js +1 -1
- package/es6/min/persisters/persister-remote/with-schemas/index.js.gz +0 -0
- package/es6/min/persisters/persister-sqlite-wasm/index.js +1 -1
- package/es6/min/persisters/persister-sqlite-wasm/index.js.gz +0 -0
- package/es6/min/persisters/persister-sqlite-wasm/with-schemas/index.js +1 -1
- package/es6/min/persisters/persister-sqlite-wasm/with-schemas/index.js.gz +0 -0
- package/es6/min/persisters/persister-sqlite3/index.js +1 -1
- package/es6/min/persisters/persister-sqlite3/index.js.gz +0 -0
- package/es6/min/persisters/persister-sqlite3/with-schemas/index.js +1 -1
- package/es6/min/persisters/persister-sqlite3/with-schemas/index.js.gz +0 -0
- package/es6/min/persisters/persister-yjs/index.js +1 -1
- package/es6/min/persisters/persister-yjs/index.js.gz +0 -0
- package/es6/min/persisters/persister-yjs/with-schemas/index.js +1 -1
- package/es6/min/persisters/persister-yjs/with-schemas/index.js.gz +0 -0
- package/es6/min/persisters/with-schemas/index.js +1 -1
- package/es6/min/persisters/with-schemas/index.js.gz +0 -0
- package/es6/min/synchronizers/index.js +1 -1
- package/es6/min/synchronizers/index.js.gz +0 -0
- package/es6/min/synchronizers/synchronizer-broadcast-channel/index.js +1 -1
- package/es6/min/synchronizers/synchronizer-broadcast-channel/index.js.gz +0 -0
- package/es6/min/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js +1 -1
- package/es6/min/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js.gz +0 -0
- package/es6/min/synchronizers/synchronizer-local/index.js +1 -1
- package/es6/min/synchronizers/synchronizer-local/index.js.gz +0 -0
- package/es6/min/synchronizers/synchronizer-local/with-schemas/index.js +1 -1
- package/es6/min/synchronizers/synchronizer-local/with-schemas/index.js.gz +0 -0
- package/es6/min/synchronizers/synchronizer-ws-client/index.js +1 -1
- package/es6/min/synchronizers/synchronizer-ws-client/index.js.gz +0 -0
- package/es6/min/synchronizers/synchronizer-ws-client/with-schemas/index.js +1 -1
- package/es6/min/synchronizers/synchronizer-ws-client/with-schemas/index.js.gz +0 -0
- package/es6/min/synchronizers/synchronizer-ws-server/index.js +1 -1
- package/es6/min/synchronizers/synchronizer-ws-server/index.js.gz +0 -0
- package/es6/min/synchronizers/synchronizer-ws-server/with-schemas/index.js +1 -1
- package/es6/min/synchronizers/synchronizer-ws-server/with-schemas/index.js.gz +0 -0
- package/es6/min/synchronizers/with-schemas/index.js +1 -1
- package/es6/min/synchronizers/with-schemas/index.js.gz +0 -0
- package/es6/min/ui-react-inspector/index.js +1 -1
- package/es6/min/ui-react-inspector/index.js.gz +0 -0
- package/es6/min/ui-react-inspector/with-schemas/index.js +1 -1
- package/es6/min/ui-react-inspector/with-schemas/index.js.gz +0 -0
- package/es6/persisters/index.js +1 -1
- package/es6/persisters/persister-automerge/index.js +1 -1
- package/es6/persisters/persister-automerge/with-schemas/index.js +1 -1
- package/es6/persisters/persister-browser/index.js +1 -1
- package/es6/persisters/persister-browser/with-schemas/index.js +1 -1
- package/es6/persisters/persister-cr-sqlite-wasm/index.js +1 -1
- package/es6/persisters/persister-cr-sqlite-wasm/with-schemas/index.js +1 -1
- package/es6/persisters/persister-electric-sql/index.js +1 -1
- package/es6/persisters/persister-electric-sql/with-schemas/index.js +1 -1
- package/es6/persisters/persister-expo-sqlite/index.js +1 -1
- package/es6/persisters/persister-expo-sqlite/with-schemas/index.js +1 -1
- package/es6/persisters/persister-file/index.js +1 -1
- package/es6/persisters/persister-file/with-schemas/index.js +1 -1
- package/es6/persisters/persister-indexed-db/index.js +1 -1
- package/es6/persisters/persister-indexed-db/with-schemas/index.js +1 -1
- package/es6/persisters/persister-libsql/index.js +1 -1
- package/es6/persisters/persister-libsql/with-schemas/index.js +1 -1
- package/es6/persisters/persister-partykit-client/index.js +1 -1
- package/es6/persisters/persister-partykit-client/with-schemas/index.js +1 -1
- package/es6/persisters/persister-pglite/index.js +1 -1
- package/es6/persisters/persister-pglite/with-schemas/index.js +1 -1
- package/es6/persisters/persister-postgres/index.js +1 -1
- package/es6/persisters/persister-postgres/with-schemas/index.js +1 -1
- package/es6/persisters/persister-powersync/index.js +1 -1
- package/es6/persisters/persister-powersync/with-schemas/index.js +1 -1
- package/es6/persisters/persister-remote/index.js +1 -1
- package/es6/persisters/persister-remote/with-schemas/index.js +1 -1
- package/es6/persisters/persister-sqlite-wasm/index.js +1 -1
- package/es6/persisters/persister-sqlite-wasm/with-schemas/index.js +1 -1
- package/es6/persisters/persister-sqlite3/index.js +1 -1
- package/es6/persisters/persister-sqlite3/with-schemas/index.js +1 -1
- package/es6/persisters/persister-yjs/index.js +1 -1
- package/es6/persisters/persister-yjs/with-schemas/index.js +1 -1
- package/es6/persisters/with-schemas/index.js +1 -1
- package/es6/synchronizers/index.js +51 -42
- package/es6/synchronizers/synchronizer-broadcast-channel/index.js +51 -42
- package/es6/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js +51 -42
- package/es6/synchronizers/synchronizer-local/index.js +51 -42
- package/es6/synchronizers/synchronizer-local/with-schemas/index.js +51 -42
- package/es6/synchronizers/synchronizer-ws-client/index.js +51 -42
- package/es6/synchronizers/synchronizer-ws-client/with-schemas/index.js +51 -42
- package/es6/synchronizers/synchronizer-ws-server/index.js +78 -46
- package/es6/synchronizers/synchronizer-ws-server/with-schemas/index.js +78 -46
- package/es6/synchronizers/with-schemas/index.js +51 -42
- package/es6/ui-react-inspector/index.js +1 -1
- package/es6/ui-react-inspector/with-schemas/index.js +1 -1
- package/min/persisters/index.js +1 -1
- package/min/persisters/index.js.gz +0 -0
- package/min/persisters/persister-automerge/index.js +1 -1
- package/min/persisters/persister-automerge/index.js.gz +0 -0
- package/min/persisters/persister-automerge/with-schemas/index.js +1 -1
- package/min/persisters/persister-automerge/with-schemas/index.js.gz +0 -0
- package/min/persisters/persister-browser/index.js +1 -1
- package/min/persisters/persister-browser/index.js.gz +0 -0
- package/min/persisters/persister-browser/with-schemas/index.js +1 -1
- package/min/persisters/persister-browser/with-schemas/index.js.gz +0 -0
- package/min/persisters/persister-cr-sqlite-wasm/index.js +1 -1
- package/min/persisters/persister-cr-sqlite-wasm/index.js.gz +0 -0
- package/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.js +1 -1
- package/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.js.gz +0 -0
- package/min/persisters/persister-electric-sql/index.js +1 -1
- package/min/persisters/persister-electric-sql/index.js.gz +0 -0
- package/min/persisters/persister-electric-sql/with-schemas/index.js +1 -1
- package/min/persisters/persister-electric-sql/with-schemas/index.js.gz +0 -0
- package/min/persisters/persister-expo-sqlite/index.js +1 -1
- package/min/persisters/persister-expo-sqlite/index.js.gz +0 -0
- package/min/persisters/persister-expo-sqlite/with-schemas/index.js +1 -1
- package/min/persisters/persister-expo-sqlite/with-schemas/index.js.gz +0 -0
- package/min/persisters/persister-file/index.js +1 -1
- package/min/persisters/persister-file/index.js.gz +0 -0
- package/min/persisters/persister-file/with-schemas/index.js +1 -1
- package/min/persisters/persister-file/with-schemas/index.js.gz +0 -0
- package/min/persisters/persister-indexed-db/index.js +1 -1
- package/min/persisters/persister-indexed-db/index.js.gz +0 -0
- package/min/persisters/persister-indexed-db/with-schemas/index.js +1 -1
- package/min/persisters/persister-indexed-db/with-schemas/index.js.gz +0 -0
- package/min/persisters/persister-libsql/index.js +1 -1
- package/min/persisters/persister-libsql/index.js.gz +0 -0
- package/min/persisters/persister-libsql/with-schemas/index.js +1 -1
- package/min/persisters/persister-libsql/with-schemas/index.js.gz +0 -0
- package/min/persisters/persister-partykit-client/index.js +1 -1
- package/min/persisters/persister-partykit-client/index.js.gz +0 -0
- package/min/persisters/persister-partykit-client/with-schemas/index.js +1 -1
- package/min/persisters/persister-partykit-client/with-schemas/index.js.gz +0 -0
- package/min/persisters/persister-pglite/index.js +1 -1
- package/min/persisters/persister-pglite/index.js.gz +0 -0
- package/min/persisters/persister-pglite/with-schemas/index.js +1 -1
- package/min/persisters/persister-pglite/with-schemas/index.js.gz +0 -0
- package/min/persisters/persister-postgres/index.js +1 -1
- package/min/persisters/persister-postgres/index.js.gz +0 -0
- package/min/persisters/persister-postgres/with-schemas/index.js +1 -1
- package/min/persisters/persister-postgres/with-schemas/index.js.gz +0 -0
- package/min/persisters/persister-powersync/index.js +1 -1
- package/min/persisters/persister-powersync/index.js.gz +0 -0
- package/min/persisters/persister-powersync/with-schemas/index.js +1 -1
- package/min/persisters/persister-powersync/with-schemas/index.js.gz +0 -0
- package/min/persisters/persister-remote/index.js +1 -1
- package/min/persisters/persister-remote/index.js.gz +0 -0
- package/min/persisters/persister-remote/with-schemas/index.js +1 -1
- package/min/persisters/persister-remote/with-schemas/index.js.gz +0 -0
- package/min/persisters/persister-sqlite-wasm/index.js +1 -1
- package/min/persisters/persister-sqlite-wasm/index.js.gz +0 -0
- package/min/persisters/persister-sqlite-wasm/with-schemas/index.js +1 -1
- package/min/persisters/persister-sqlite-wasm/with-schemas/index.js.gz +0 -0
- package/min/persisters/persister-sqlite3/index.js +1 -1
- package/min/persisters/persister-sqlite3/index.js.gz +0 -0
- package/min/persisters/persister-sqlite3/with-schemas/index.js +1 -1
- package/min/persisters/persister-sqlite3/with-schemas/index.js.gz +0 -0
- package/min/persisters/persister-yjs/index.js +1 -1
- package/min/persisters/persister-yjs/index.js.gz +0 -0
- package/min/persisters/persister-yjs/with-schemas/index.js +1 -1
- package/min/persisters/persister-yjs/with-schemas/index.js.gz +0 -0
- package/min/persisters/with-schemas/index.js +1 -1
- package/min/persisters/with-schemas/index.js.gz +0 -0
- package/min/synchronizers/index.js +1 -1
- package/min/synchronizers/index.js.gz +0 -0
- package/min/synchronizers/synchronizer-broadcast-channel/index.js +1 -1
- package/min/synchronizers/synchronizer-broadcast-channel/index.js.gz +0 -0
- package/min/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js +1 -1
- package/min/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js.gz +0 -0
- package/min/synchronizers/synchronizer-local/index.js +1 -1
- package/min/synchronizers/synchronizer-local/index.js.gz +0 -0
- package/min/synchronizers/synchronizer-local/with-schemas/index.js +1 -1
- package/min/synchronizers/synchronizer-local/with-schemas/index.js.gz +0 -0
- package/min/synchronizers/synchronizer-ws-client/index.js +1 -1
- package/min/synchronizers/synchronizer-ws-client/index.js.gz +0 -0
- package/min/synchronizers/synchronizer-ws-client/with-schemas/index.js +1 -1
- package/min/synchronizers/synchronizer-ws-client/with-schemas/index.js.gz +0 -0
- package/min/synchronizers/synchronizer-ws-server/index.js +1 -1
- package/min/synchronizers/synchronizer-ws-server/index.js.gz +0 -0
- package/min/synchronizers/synchronizer-ws-server/with-schemas/index.js +1 -1
- package/min/synchronizers/synchronizer-ws-server/with-schemas/index.js.gz +0 -0
- package/min/synchronizers/with-schemas/index.js +1 -1
- package/min/synchronizers/with-schemas/index.js.gz +0 -0
- package/min/ui-react-inspector/index.js +1 -1
- package/min/ui-react-inspector/index.js.gz +0 -0
- package/min/ui-react-inspector/with-schemas/index.js +1 -1
- package/min/ui-react-inspector/with-schemas/index.js.gz +0 -0
- package/package.json +2 -2
- package/persisters/index.js +1 -1
- package/persisters/persister-automerge/index.js +1 -1
- package/persisters/persister-automerge/with-schemas/index.js +1 -1
- package/persisters/persister-browser/index.js +1 -1
- package/persisters/persister-browser/with-schemas/index.js +1 -1
- package/persisters/persister-cr-sqlite-wasm/index.js +1 -1
- package/persisters/persister-cr-sqlite-wasm/with-schemas/index.js +1 -1
- package/persisters/persister-electric-sql/index.js +1 -1
- package/persisters/persister-electric-sql/with-schemas/index.js +1 -1
- package/persisters/persister-expo-sqlite/index.js +1 -1
- package/persisters/persister-expo-sqlite/with-schemas/index.js +1 -1
- package/persisters/persister-file/index.js +1 -1
- package/persisters/persister-file/with-schemas/index.js +1 -1
- package/persisters/persister-indexed-db/index.js +1 -1
- package/persisters/persister-indexed-db/with-schemas/index.js +1 -1
- package/persisters/persister-libsql/index.js +1 -1
- package/persisters/persister-libsql/with-schemas/index.js +1 -1
- package/persisters/persister-partykit-client/index.js +1 -1
- package/persisters/persister-partykit-client/with-schemas/index.js +1 -1
- package/persisters/persister-pglite/index.js +1 -1
- package/persisters/persister-pglite/with-schemas/index.js +1 -1
- package/persisters/persister-postgres/index.js +1 -1
- package/persisters/persister-postgres/with-schemas/index.js +1 -1
- package/persisters/persister-powersync/index.js +1 -1
- package/persisters/persister-powersync/with-schemas/index.js +1 -1
- package/persisters/persister-remote/index.js +1 -1
- package/persisters/persister-remote/with-schemas/index.js +1 -1
- package/persisters/persister-sqlite-wasm/index.js +1 -1
- package/persisters/persister-sqlite-wasm/with-schemas/index.js +1 -1
- package/persisters/persister-sqlite3/index.js +1 -1
- package/persisters/persister-sqlite3/with-schemas/index.js +1 -1
- package/persisters/persister-yjs/index.js +1 -1
- package/persisters/persister-yjs/with-schemas/index.js +1 -1
- package/persisters/with-schemas/index.js +1 -1
- package/readme.md +13 -13
- package/releases.md +23 -23
- package/synchronizers/index.js +51 -45
- package/synchronizers/synchronizer-broadcast-channel/index.js +51 -45
- package/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js +51 -45
- package/synchronizers/synchronizer-local/index.js +51 -45
- package/synchronizers/synchronizer-local/with-schemas/index.js +51 -45
- package/synchronizers/synchronizer-ws-client/index.js +51 -45
- package/synchronizers/synchronizer-ws-client/with-schemas/index.js +51 -45
- package/synchronizers/synchronizer-ws-server/index.js +78 -49
- package/synchronizers/synchronizer-ws-server/with-schemas/index.js +78 -49
- package/synchronizers/with-schemas/index.js +51 -45
- package/ui-react-inspector/index.js +1 -1
- package/ui-react-inspector/with-schemas/index.js +1 -1
- package/umd/es6/min/persisters/index.js +1 -1
- package/umd/es6/min/persisters/index.js.gz +0 -0
- package/umd/es6/min/persisters/persister-automerge/index.js +1 -1
- package/umd/es6/min/persisters/persister-automerge/index.js.gz +0 -0
- package/umd/es6/min/persisters/persister-automerge/with-schemas/index.js +1 -1
- package/umd/es6/min/persisters/persister-automerge/with-schemas/index.js.gz +0 -0
- package/umd/es6/min/persisters/persister-browser/index.js +1 -1
- package/umd/es6/min/persisters/persister-browser/index.js.gz +0 -0
- package/umd/es6/min/persisters/persister-browser/with-schemas/index.js +1 -1
- package/umd/es6/min/persisters/persister-browser/with-schemas/index.js.gz +0 -0
- package/umd/es6/min/persisters/persister-cr-sqlite-wasm/index.js +1 -1
- package/umd/es6/min/persisters/persister-cr-sqlite-wasm/index.js.gz +0 -0
- package/umd/es6/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.js +1 -1
- package/umd/es6/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.js.gz +0 -0
- package/umd/es6/min/persisters/persister-electric-sql/index.js +1 -1
- package/umd/es6/min/persisters/persister-electric-sql/index.js.gz +0 -0
- package/umd/es6/min/persisters/persister-electric-sql/with-schemas/index.js +1 -1
- package/umd/es6/min/persisters/persister-electric-sql/with-schemas/index.js.gz +0 -0
- package/umd/es6/min/persisters/persister-expo-sqlite/index.js +1 -1
- package/umd/es6/min/persisters/persister-expo-sqlite/index.js.gz +0 -0
- package/umd/es6/min/persisters/persister-expo-sqlite/with-schemas/index.js +1 -1
- package/umd/es6/min/persisters/persister-expo-sqlite/with-schemas/index.js.gz +0 -0
- package/umd/es6/min/persisters/persister-file/index.js +1 -1
- package/umd/es6/min/persisters/persister-file/index.js.gz +0 -0
- package/umd/es6/min/persisters/persister-file/with-schemas/index.js +1 -1
- package/umd/es6/min/persisters/persister-file/with-schemas/index.js.gz +0 -0
- package/umd/es6/min/persisters/persister-indexed-db/index.js +1 -1
- package/umd/es6/min/persisters/persister-indexed-db/index.js.gz +0 -0
- package/umd/es6/min/persisters/persister-indexed-db/with-schemas/index.js +1 -1
- package/umd/es6/min/persisters/persister-indexed-db/with-schemas/index.js.gz +0 -0
- package/umd/es6/min/persisters/persister-libsql/index.js +1 -1
- package/umd/es6/min/persisters/persister-libsql/index.js.gz +0 -0
- package/umd/es6/min/persisters/persister-libsql/with-schemas/index.js +1 -1
- package/umd/es6/min/persisters/persister-libsql/with-schemas/index.js.gz +0 -0
- package/umd/es6/min/persisters/persister-partykit-client/index.js +1 -1
- package/umd/es6/min/persisters/persister-partykit-client/index.js.gz +0 -0
- package/umd/es6/min/persisters/persister-partykit-client/with-schemas/index.js +1 -1
- package/umd/es6/min/persisters/persister-partykit-client/with-schemas/index.js.gz +0 -0
- package/umd/es6/min/persisters/persister-pglite/index.js +1 -1
- package/umd/es6/min/persisters/persister-pglite/index.js.gz +0 -0
- package/umd/es6/min/persisters/persister-pglite/with-schemas/index.js +1 -1
- package/umd/es6/min/persisters/persister-pglite/with-schemas/index.js.gz +0 -0
- package/umd/es6/min/persisters/persister-postgres/index.js +1 -1
- package/umd/es6/min/persisters/persister-postgres/index.js.gz +0 -0
- package/umd/es6/min/persisters/persister-postgres/with-schemas/index.js +1 -1
- package/umd/es6/min/persisters/persister-postgres/with-schemas/index.js.gz +0 -0
- package/umd/es6/min/persisters/persister-powersync/index.js +1 -1
- package/umd/es6/min/persisters/persister-powersync/index.js.gz +0 -0
- package/umd/es6/min/persisters/persister-powersync/with-schemas/index.js +1 -1
- package/umd/es6/min/persisters/persister-powersync/with-schemas/index.js.gz +0 -0
- package/umd/es6/min/persisters/persister-remote/index.js +1 -1
- package/umd/es6/min/persisters/persister-remote/index.js.gz +0 -0
- package/umd/es6/min/persisters/persister-remote/with-schemas/index.js +1 -1
- package/umd/es6/min/persisters/persister-remote/with-schemas/index.js.gz +0 -0
- package/umd/es6/min/persisters/persister-sqlite-wasm/index.js +1 -1
- package/umd/es6/min/persisters/persister-sqlite-wasm/index.js.gz +0 -0
- package/umd/es6/min/persisters/persister-sqlite-wasm/with-schemas/index.js +1 -1
- package/umd/es6/min/persisters/persister-sqlite-wasm/with-schemas/index.js.gz +0 -0
- package/umd/es6/min/persisters/persister-sqlite3/index.js +1 -1
- package/umd/es6/min/persisters/persister-sqlite3/index.js.gz +0 -0
- package/umd/es6/min/persisters/persister-sqlite3/with-schemas/index.js +1 -1
- package/umd/es6/min/persisters/persister-sqlite3/with-schemas/index.js.gz +0 -0
- package/umd/es6/min/persisters/persister-yjs/index.js +1 -1
- package/umd/es6/min/persisters/persister-yjs/index.js.gz +0 -0
- package/umd/es6/min/persisters/persister-yjs/with-schemas/index.js +1 -1
- package/umd/es6/min/persisters/persister-yjs/with-schemas/index.js.gz +0 -0
- package/umd/es6/min/persisters/with-schemas/index.js +1 -1
- package/umd/es6/min/persisters/with-schemas/index.js.gz +0 -0
- package/umd/es6/min/synchronizers/index.js +1 -1
- package/umd/es6/min/synchronizers/index.js.gz +0 -0
- package/umd/es6/min/synchronizers/synchronizer-broadcast-channel/index.js +1 -1
- package/umd/es6/min/synchronizers/synchronizer-broadcast-channel/index.js.gz +0 -0
- package/umd/es6/min/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js +1 -1
- package/umd/es6/min/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js.gz +0 -0
- package/umd/es6/min/synchronizers/synchronizer-local/index.js +1 -1
- package/umd/es6/min/synchronizers/synchronizer-local/index.js.gz +0 -0
- package/umd/es6/min/synchronizers/synchronizer-local/with-schemas/index.js +1 -1
- package/umd/es6/min/synchronizers/synchronizer-local/with-schemas/index.js.gz +0 -0
- package/umd/es6/min/synchronizers/synchronizer-ws-client/index.js +1 -1
- package/umd/es6/min/synchronizers/synchronizer-ws-client/index.js.gz +0 -0
- package/umd/es6/min/synchronizers/synchronizer-ws-client/with-schemas/index.js +1 -1
- package/umd/es6/min/synchronizers/synchronizer-ws-client/with-schemas/index.js.gz +0 -0
- package/umd/es6/min/synchronizers/synchronizer-ws-server/index.js +1 -1
- package/umd/es6/min/synchronizers/synchronizer-ws-server/index.js.gz +0 -0
- package/umd/es6/min/synchronizers/synchronizer-ws-server/with-schemas/index.js +1 -1
- package/umd/es6/min/synchronizers/synchronizer-ws-server/with-schemas/index.js.gz +0 -0
- package/umd/es6/min/synchronizers/with-schemas/index.js +1 -1
- package/umd/es6/min/synchronizers/with-schemas/index.js.gz +0 -0
- package/umd/es6/min/ui-react-inspector/index.js +1 -1
- package/umd/es6/min/ui-react-inspector/index.js.gz +0 -0
- package/umd/es6/min/ui-react-inspector/with-schemas/index.js +1 -1
- package/umd/es6/min/ui-react-inspector/with-schemas/index.js.gz +0 -0
- package/umd/es6/persisters/index.js +1 -1
- package/umd/es6/persisters/persister-automerge/index.js +1 -1
- package/umd/es6/persisters/persister-automerge/with-schemas/index.js +1 -1
- package/umd/es6/persisters/persister-browser/index.js +1 -1
- package/umd/es6/persisters/persister-browser/with-schemas/index.js +1 -1
- package/umd/es6/persisters/persister-cr-sqlite-wasm/index.js +1 -1
- package/umd/es6/persisters/persister-cr-sqlite-wasm/with-schemas/index.js +1 -1
- package/umd/es6/persisters/persister-electric-sql/index.js +1 -1
- package/umd/es6/persisters/persister-electric-sql/with-schemas/index.js +1 -1
- package/umd/es6/persisters/persister-expo-sqlite/index.js +1 -1
- package/umd/es6/persisters/persister-expo-sqlite/with-schemas/index.js +1 -1
- package/umd/es6/persisters/persister-file/index.js +1 -1
- package/umd/es6/persisters/persister-file/with-schemas/index.js +1 -1
- package/umd/es6/persisters/persister-indexed-db/index.js +1 -1
- package/umd/es6/persisters/persister-indexed-db/with-schemas/index.js +1 -1
- package/umd/es6/persisters/persister-libsql/index.js +1 -1
- package/umd/es6/persisters/persister-libsql/with-schemas/index.js +1 -1
- package/umd/es6/persisters/persister-partykit-client/index.js +1 -1
- package/umd/es6/persisters/persister-partykit-client/with-schemas/index.js +1 -1
- package/umd/es6/persisters/persister-pglite/index.js +1 -1
- package/umd/es6/persisters/persister-pglite/with-schemas/index.js +1 -1
- package/umd/es6/persisters/persister-postgres/index.js +1 -1
- package/umd/es6/persisters/persister-postgres/with-schemas/index.js +1 -1
- package/umd/es6/persisters/persister-powersync/index.js +1 -1
- package/umd/es6/persisters/persister-powersync/with-schemas/index.js +1 -1
- package/umd/es6/persisters/persister-remote/index.js +1 -1
- package/umd/es6/persisters/persister-remote/with-schemas/index.js +1 -1
- package/umd/es6/persisters/persister-sqlite-wasm/index.js +1 -1
- package/umd/es6/persisters/persister-sqlite-wasm/with-schemas/index.js +1 -1
- package/umd/es6/persisters/persister-sqlite3/index.js +1 -1
- package/umd/es6/persisters/persister-sqlite3/with-schemas/index.js +1 -1
- package/umd/es6/persisters/persister-yjs/index.js +1 -1
- package/umd/es6/persisters/persister-yjs/with-schemas/index.js +1 -1
- package/umd/es6/persisters/with-schemas/index.js +1 -1
- package/umd/es6/synchronizers/index.js +51 -44
- package/umd/es6/synchronizers/synchronizer-broadcast-channel/index.js +51 -44
- package/umd/es6/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js +51 -44
- package/umd/es6/synchronizers/synchronizer-local/index.js +51 -44
- package/umd/es6/synchronizers/synchronizer-local/with-schemas/index.js +51 -44
- package/umd/es6/synchronizers/synchronizer-ws-client/index.js +51 -44
- package/umd/es6/synchronizers/synchronizer-ws-client/with-schemas/index.js +51 -44
- package/umd/es6/synchronizers/synchronizer-ws-server/index.js +78 -48
- package/umd/es6/synchronizers/synchronizer-ws-server/with-schemas/index.js +78 -48
- package/umd/es6/synchronizers/with-schemas/index.js +51 -44
- package/umd/es6/ui-react-inspector/index.js +1 -1
- package/umd/es6/ui-react-inspector/with-schemas/index.js +1 -1
- package/umd/min/persisters/index.js +1 -1
- package/umd/min/persisters/index.js.gz +0 -0
- package/umd/min/persisters/persister-automerge/index.js +1 -1
- package/umd/min/persisters/persister-automerge/index.js.gz +0 -0
- package/umd/min/persisters/persister-automerge/with-schemas/index.js +1 -1
- package/umd/min/persisters/persister-automerge/with-schemas/index.js.gz +0 -0
- package/umd/min/persisters/persister-browser/index.js +1 -1
- package/umd/min/persisters/persister-browser/index.js.gz +0 -0
- package/umd/min/persisters/persister-browser/with-schemas/index.js +1 -1
- package/umd/min/persisters/persister-browser/with-schemas/index.js.gz +0 -0
- package/umd/min/persisters/persister-cr-sqlite-wasm/index.js +1 -1
- package/umd/min/persisters/persister-cr-sqlite-wasm/index.js.gz +0 -0
- package/umd/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.js +1 -1
- package/umd/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.js.gz +0 -0
- package/umd/min/persisters/persister-electric-sql/index.js +1 -1
- package/umd/min/persisters/persister-electric-sql/index.js.gz +0 -0
- package/umd/min/persisters/persister-electric-sql/with-schemas/index.js +1 -1
- package/umd/min/persisters/persister-electric-sql/with-schemas/index.js.gz +0 -0
- package/umd/min/persisters/persister-expo-sqlite/index.js +1 -1
- package/umd/min/persisters/persister-expo-sqlite/index.js.gz +0 -0
- package/umd/min/persisters/persister-expo-sqlite/with-schemas/index.js +1 -1
- package/umd/min/persisters/persister-expo-sqlite/with-schemas/index.js.gz +0 -0
- package/umd/min/persisters/persister-file/index.js +1 -1
- package/umd/min/persisters/persister-file/index.js.gz +0 -0
- package/umd/min/persisters/persister-file/with-schemas/index.js +1 -1
- package/umd/min/persisters/persister-file/with-schemas/index.js.gz +0 -0
- package/umd/min/persisters/persister-indexed-db/index.js +1 -1
- package/umd/min/persisters/persister-indexed-db/index.js.gz +0 -0
- package/umd/min/persisters/persister-indexed-db/with-schemas/index.js +1 -1
- package/umd/min/persisters/persister-indexed-db/with-schemas/index.js.gz +0 -0
- package/umd/min/persisters/persister-libsql/index.js +1 -1
- package/umd/min/persisters/persister-libsql/index.js.gz +0 -0
- package/umd/min/persisters/persister-libsql/with-schemas/index.js +1 -1
- package/umd/min/persisters/persister-libsql/with-schemas/index.js.gz +0 -0
- package/umd/min/persisters/persister-partykit-client/index.js +1 -1
- package/umd/min/persisters/persister-partykit-client/index.js.gz +0 -0
- package/umd/min/persisters/persister-partykit-client/with-schemas/index.js +1 -1
- package/umd/min/persisters/persister-partykit-client/with-schemas/index.js.gz +0 -0
- package/umd/min/persisters/persister-pglite/index.js +1 -1
- package/umd/min/persisters/persister-pglite/index.js.gz +0 -0
- package/umd/min/persisters/persister-pglite/with-schemas/index.js +1 -1
- package/umd/min/persisters/persister-pglite/with-schemas/index.js.gz +0 -0
- package/umd/min/persisters/persister-postgres/index.js +1 -1
- package/umd/min/persisters/persister-postgres/index.js.gz +0 -0
- package/umd/min/persisters/persister-postgres/with-schemas/index.js +1 -1
- package/umd/min/persisters/persister-postgres/with-schemas/index.js.gz +0 -0
- package/umd/min/persisters/persister-powersync/index.js +1 -1
- package/umd/min/persisters/persister-powersync/index.js.gz +0 -0
- package/umd/min/persisters/persister-powersync/with-schemas/index.js +1 -1
- package/umd/min/persisters/persister-powersync/with-schemas/index.js.gz +0 -0
- package/umd/min/persisters/persister-remote/index.js +1 -1
- package/umd/min/persisters/persister-remote/index.js.gz +0 -0
- package/umd/min/persisters/persister-remote/with-schemas/index.js +1 -1
- package/umd/min/persisters/persister-remote/with-schemas/index.js.gz +0 -0
- package/umd/min/persisters/persister-sqlite-wasm/index.js +1 -1
- package/umd/min/persisters/persister-sqlite-wasm/index.js.gz +0 -0
- package/umd/min/persisters/persister-sqlite-wasm/with-schemas/index.js +1 -1
- package/umd/min/persisters/persister-sqlite-wasm/with-schemas/index.js.gz +0 -0
- package/umd/min/persisters/persister-sqlite3/index.js +1 -1
- package/umd/min/persisters/persister-sqlite3/index.js.gz +0 -0
- package/umd/min/persisters/persister-sqlite3/with-schemas/index.js +1 -1
- package/umd/min/persisters/persister-sqlite3/with-schemas/index.js.gz +0 -0
- package/umd/min/persisters/persister-yjs/index.js +1 -1
- package/umd/min/persisters/persister-yjs/index.js.gz +0 -0
- package/umd/min/persisters/persister-yjs/with-schemas/index.js +1 -1
- package/umd/min/persisters/persister-yjs/with-schemas/index.js.gz +0 -0
- package/umd/min/persisters/with-schemas/index.js +1 -1
- package/umd/min/persisters/with-schemas/index.js.gz +0 -0
- package/umd/min/synchronizers/index.js +1 -1
- package/umd/min/synchronizers/index.js.gz +0 -0
- package/umd/min/synchronizers/synchronizer-broadcast-channel/index.js +1 -1
- package/umd/min/synchronizers/synchronizer-broadcast-channel/index.js.gz +0 -0
- package/umd/min/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js +1 -1
- package/umd/min/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js.gz +0 -0
- package/umd/min/synchronizers/synchronizer-local/index.js +1 -1
- package/umd/min/synchronizers/synchronizer-local/index.js.gz +0 -0
- package/umd/min/synchronizers/synchronizer-local/with-schemas/index.js +1 -1
- package/umd/min/synchronizers/synchronizer-local/with-schemas/index.js.gz +0 -0
- package/umd/min/synchronizers/synchronizer-ws-client/index.js +1 -1
- package/umd/min/synchronizers/synchronizer-ws-client/index.js.gz +0 -0
- package/umd/min/synchronizers/synchronizer-ws-client/with-schemas/index.js +1 -1
- package/umd/min/synchronizers/synchronizer-ws-client/with-schemas/index.js.gz +0 -0
- package/umd/min/synchronizers/synchronizer-ws-server/index.js +1 -1
- package/umd/min/synchronizers/synchronizer-ws-server/index.js.gz +0 -0
- package/umd/min/synchronizers/synchronizer-ws-server/with-schemas/index.js +1 -1
- package/umd/min/synchronizers/synchronizer-ws-server/with-schemas/index.js.gz +0 -0
- package/umd/min/synchronizers/with-schemas/index.js +1 -1
- package/umd/min/synchronizers/with-schemas/index.js.gz +0 -0
- package/umd/min/ui-react-inspector/index.js +1 -1
- package/umd/min/ui-react-inspector/index.js.gz +0 -0
- package/umd/min/ui-react-inspector/with-schemas/index.js +1 -1
- package/umd/min/ui-react-inspector/with-schemas/index.js.gz +0 -0
- package/umd/persisters/index.js +1 -1
- package/umd/persisters/persister-automerge/index.js +1 -1
- package/umd/persisters/persister-automerge/with-schemas/index.js +1 -1
- package/umd/persisters/persister-browser/index.js +1 -1
- package/umd/persisters/persister-browser/with-schemas/index.js +1 -1
- package/umd/persisters/persister-cr-sqlite-wasm/index.js +1 -1
- package/umd/persisters/persister-cr-sqlite-wasm/with-schemas/index.js +1 -1
- package/umd/persisters/persister-electric-sql/index.js +1 -1
- package/umd/persisters/persister-electric-sql/with-schemas/index.js +1 -1
- package/umd/persisters/persister-expo-sqlite/index.js +1 -1
- package/umd/persisters/persister-expo-sqlite/with-schemas/index.js +1 -1
- package/umd/persisters/persister-file/index.js +1 -1
- package/umd/persisters/persister-file/with-schemas/index.js +1 -1
- package/umd/persisters/persister-indexed-db/index.js +1 -1
- package/umd/persisters/persister-indexed-db/with-schemas/index.js +1 -1
- package/umd/persisters/persister-libsql/index.js +1 -1
- package/umd/persisters/persister-libsql/with-schemas/index.js +1 -1
- package/umd/persisters/persister-partykit-client/index.js +1 -1
- package/umd/persisters/persister-partykit-client/with-schemas/index.js +1 -1
- package/umd/persisters/persister-pglite/index.js +1 -1
- package/umd/persisters/persister-pglite/with-schemas/index.js +1 -1
- package/umd/persisters/persister-postgres/index.js +1 -1
- package/umd/persisters/persister-postgres/with-schemas/index.js +1 -1
- package/umd/persisters/persister-powersync/index.js +1 -1
- package/umd/persisters/persister-powersync/with-schemas/index.js +1 -1
- package/umd/persisters/persister-remote/index.js +1 -1
- package/umd/persisters/persister-remote/with-schemas/index.js +1 -1
- package/umd/persisters/persister-sqlite-wasm/index.js +1 -1
- package/umd/persisters/persister-sqlite-wasm/with-schemas/index.js +1 -1
- package/umd/persisters/persister-sqlite3/index.js +1 -1
- package/umd/persisters/persister-sqlite3/with-schemas/index.js +1 -1
- package/umd/persisters/persister-yjs/index.js +1 -1
- package/umd/persisters/persister-yjs/with-schemas/index.js +1 -1
- package/umd/persisters/with-schemas/index.js +1 -1
- package/umd/synchronizers/index.js +52 -45
- package/umd/synchronizers/synchronizer-broadcast-channel/index.js +52 -45
- package/umd/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js +52 -45
- package/umd/synchronizers/synchronizer-local/index.js +52 -45
- package/umd/synchronizers/synchronizer-local/with-schemas/index.js +52 -45
- package/umd/synchronizers/synchronizer-ws-client/index.js +52 -45
- package/umd/synchronizers/synchronizer-ws-client/with-schemas/index.js +52 -45
- package/umd/synchronizers/synchronizer-ws-server/index.js +79 -49
- package/umd/synchronizers/synchronizer-ws-server/with-schemas/index.js +79 -49
- package/umd/synchronizers/with-schemas/index.js +52 -45
- package/umd/ui-react-inspector/index.js +1 -1
- package/umd/ui-react-inspector/with-schemas/index.js +1 -1
|
@@ -1 +1 @@
|
|
|
1
|
-
const a=a=>typeof a,t="tinybase",e=",",n=a(""),s=Promise,i=a=>null==a,r=(a,t,e)=>i(a)?e?.():t(a),o=t=>a(t)==n,c=a=>Array.isArray(a),E=(a,t,e)=>a.slice(t,e),l=a=>a.length,w=async a=>s.all(a),y=a=>{throw Error(a)},u=(a,t)=>a.forEach(t),d=(a,t="")=>a.join(t),T=(a,t)=>a.map(t),R=a=>0==l(a),A=(a,t)=>a.filter(t),N=(a,...t)=>a.push(...t),g=a=>a.shift(),p="_",C="_id",O="SELECT",v="WHERE",L="TABLE",$="ALTER "+L,S="DELETE FROM",I=O+"*FROM",m=a=>`"${a.replace(/"/g,'""')}"`,_=(a,t=[1])=>d(T(a,(()=>"$"+t[0]++)),e),h=(a,t)=>a?.has(t)??!1,f=a=>i(a)||0==(a=>a?.size??0)(a),b=a=>[...a?.values()??[]],D=(a,t)=>a?.forEach(t),P=(a,t)=>a?.delete(t),U=Object,F=a=>U.getPrototypeOf(a),M=U.entries,G=U.keys,B=U.freeze,j=(a=[])=>U.fromEntries(a),x=(...a)=>U.assign({},...a),X=(a,t)=>(delete a[t],a),Y=(a,t)=>T(M(a),(([a,e])=>t(e,a))),q=a=>U.values(a),H=a=>l(G(a)),W=a=>(a=>!i(a)&&r(F(a),(a=>a==U.prototype||i(F(a))),(()=>!0)))(a)&&0==H(a),k=JSON.stringify,z=JSON.parse,J=a=>new Map(a),K=(a,t)=>a?.get(t),V=(a,t)=>T([...a?.entries()??[]],(([a,e])=>t(e,a))),Q=(a,t,e)=>i(e)?(P(a,t),a):a?.set(t,e),Z=(a,t,e,n)=>(h(a,t)?n?.(K(a,t)):Q(a,t,e()),K(a,t)),aa=(a,t,e,n,s=0)=>r((e?Z:K)(a,t[s],s>l(t)-2?e:J),(i=>{if(s>l(t)-2)return n?.(i)&&Q(a,t[s]),i;const r=aa(i,t,e,n,s+1);return f(i)&&Q(a,t[s]),r})),ta=a=>new Set(c(a)||i(a)?a:[a]),ea=(a,t)=>a?.add(t),na=/^\d+$/,sa=J(),ia=J(),ra=(a,t,e,n,s,o,E,w={},d=[])=>{let T,R,A,p=0,C=0,O=0;Z(sa,d,(()=>0)),Z(ia,d,(()=>[]));const v=J(),[L,$,S,I,m]=((a=1,t)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,t.getTransactionMergeableChanges,([[a],[t]])=>!W(a)||!W(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!W(a)||!W(t),t.setContent]:y("Store type not supported by this Persister"))(E,a),[_,h,b]=(()=>{let a;const[t,e]=(()=>{const a=[];let t=0;return[e=>(e?g(a):null)??""+t++,t=>{na.test(t)&&l(a)<1e3&&N(a,t)}]})(),n=J();return[(e,s,i,r=[],o=()=>[])=>{a??=Y;const c=t(1);return Q(n,c,[e,s,i,r,o]),ea(aa(s,i??[""],ta),c),c},(t,e,...s)=>u(((a,t=[""])=>{const e=[],n=(a,s)=>s==l(t)?N(e,a):null===t[s]?D(a,(a=>n(a,s+1))):u([t[s],null],(t=>n(K(a,t),s+1)));return n(a,0),e})(t,e),(t=>D(t,(t=>K(n,t)[0](a,...e??[],...s))))),a=>r(K(n,a),(([,t,s])=>(aa(t,s??[""],void 0,(t=>(P(t,a),f(t)?1:0))),Q(n,a),e(a),s))),t=>r(K(n,t),(([t,,e=[],n,s])=>{const r=(...o)=>{const c=l(o);c==l(e)?t(a,...o,...s(o)):i(e[c])?u(n[c]?.(...o)??[],(a=>r(...o,a))):r(...o,e[c])};r()}))]})(),U=a=>{a!=p&&(p=a,h(v,void 0,p))},F=t=>{(L&&c(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},M=async a=>(2!=p&&(U(1),C++,await X((async()=>{try{const e=await t();c(e)?F(e):a?m(a):y("Content is not an array "+e)}catch(t){o?.(t),a&&m(a)}U(0)}))),Y),G=()=>(R&&(s(R),R=void 0),Y),j=async a=>(1!=p&&(U(2),O++,await X((async()=>{try{await e($,a)}catch(a){o?.(a)}U(0)}))),Y),x=()=>(r(A,a.delListener),A=void 0,Y),X=async(...a)=>(N(K(ia,d),...a),await(async()=>{if(!K(sa,d)){for(Q(sa,d,1);!i(T=g(K(ia,d)));)try{await T()}catch(a){o?.(a)}Q(sa,d,0)}})(),Y),Y={load:M,startAutoLoad:async a=>{await G().load(a);try{R=await n((async(a,t)=>{t||a?2!=p&&(U(1),C++,F(t??a),U(0)):await M()}))}catch(a){o?.(a)}return Y},stopAutoLoad:G,isAutoLoading:()=>!i(R),save:j,startAutoSave:async()=>(await x().save(),A=a.addDidFinishTransactionListener((()=>{const a=S();I(a)&&j(a)})),Y),stopAutoSave:x,isAutoSaving:()=>!i(A),getStatus:()=>p,addStatusListener:a=>_(a,v),delListener:t=>(b(t),a),schedule:X,getStore:()=>a,destroy:()=>(K(ia,d).splice(0,void 0),G().stopAutoSave()),getStats:()=>({loads:C,saves:O}),...w};return B(Y)},oa=(a,t,n,s,r,o=ca,c,E)=>{const l=J();return[async()=>{l.clear(),T(await n(a,t),(({tn:a,cn:t})=>ea(Z(l,a,ta),t)))},async(t,e)=>((a,t)=>h(K(l,a),t))(t,e)?j(A(T(await a(I+m(t)),(a=>{return[a[e],E?(t=X(a,e),n=E,j(Y(t,((a,t)=>[t,n(a,t)])))):X(a,e)];var t,n})),(([a,t])=>!i(a)&&!W(t)))):{},async(t,n,s,E,y,u=!1)=>{const g=ta();Y(s??{},(a=>T(G(a??{}),(a=>ea(g,a)))));const p=b(g);if(!u&&y&&R(p)&&h(l,t))return await a("DROP "+L+m(t)),void Q(l,t);const C=K(l,t),O=ta(b(C));if(R(p)||(h(l,t)?await w(T([n,...p],(async(e,s)=>{P(O,e)||(await a($+m(t)+"ADD"+m(e)+r),0==s&&await a("CREATE UNIQUE INDEX pk ON "+m(t)+`(${m(n)})`),ea(C,e))}))):(await a("CREATE "+L+m(t)+`(${m(n)}${r} PRIMARY KEY${d(T(p,(a=>e+m(a)+r)))});`),Q(l,t,ta([n,...p])))),await w([...!u&&E?T(b(O),(async e=>{e!=n&&(await a($+m(t)+"DROP"+m(e)),P(C,e))})):[]]),u)i(s)?await a(S+m(t)+v+" true"):await w(Y(s,(async(e,s)=>{i(e)?await a(S+m(t)+v+m(n)+"=$1",[s]):R(p)||await o(a,t,n,G(e),{[s]:c?T(q(e),c):q(e)},C)})));else if(R(p))h(l,t)&&await a(S+m(t)+v+" true");else{const e=A(b(K(l,t)),(a=>a!=n)),i={},r=[];Y(s??{},((a,t)=>{i[t]=T(e,(t=>c?c(a?.[t]):a?.[t])),N(r,t)})),await o(a,t,n,e,i),await a(S+m(t)+v+m(n)+`NOT IN(${_(r)})`,r)}},async t=>{let e;await a("BEGIN");try{e=await t()}catch(a){s?.(a)}return await a("END"),e}]},ca=async(a,t,n,s,i)=>{const r=[1];await a("INSERT INTO"+m(t)+"("+((...a)=>d(T(a,m),e))(n,...s)+")VALUES"+d(Y(i,(a=>"($"+r[0]+++","+_(a,r)+")")),e)+"ON CONFLICT("+m(n)+")DO UPDATE SET"+d(T(s,(a=>m(a)+"=excluded."+m(a))),e),Y(i,((a,t)=>[t,...T(a,(a=>a??null))])).flat())},Ea=(a,t,e,n,s,i,r,[o,c,E],l,w,y,u,d,T)=>{const[R,A,N,g]=oa(t,l,w,s,d,T),C=ra(a,(async()=>await g((async()=>{return await R(),a=(await A(o,c))[p]?.[E]??"null",z(a,((a,t)=>""===t?void 0:t));var a}))),(async a=>await g((async()=>{var t;await R(),await N(o,c,{[p]:{[E]:(t=a()??null,k(t,((a,t)=>void 0===t?"":t)))}},!0,!0)}))),e,n,s,r,{[u]:()=>y,destroy:()=>(C.stopAutoLoad().stopAutoSave(),i(),C)},y);return C},la=(a,t,e,n,s,r,o,[c,E,[l,y,u]],d,T,R,N,g,O,v,L)=>{const[$,S,I,m]=oa(t,d,T,s,g,O,v,L),_=async(a,t)=>await w(V(E,(async([e,n,s,i],r)=>{t&&!(r in a)||await I(e,n,a[r],s,i,t)}))),h=async(a,t)=>y?await I(u,C,{[p]:a},!0,!0,t):null,f=ra(a,(async()=>await m((async()=>{await $();const a=await(async()=>j(A(await w(V(c,(async([a,t],e)=>[a,await S(e,t)]))),(a=>!W(a[1])))))(),t=await(async()=>l?(await S(u,C))[p]:{})();return W(a)&&i(t)?void 0:[a,t]}))),(async(a,t)=>await m((async()=>{if(await $(),i(t)){const[t,e]=a();await _(t),await h(e)}else await _(t[0],!0),await h(t[1],!0)}))),e,n,s,o,{[N]:()=>R,destroy:()=>(f.stopAutoLoad().stopAutoSave(),r(),f)},R);return f},wa="ColumnName",ya="store",ua="json",da=ya+"TableName",Ta=ya+"Id"+wa,Ra=ya+wa,Aa="autoLoadIntervalSeconds",Na="rowId"+wa,ga="tableId",pa="tableName",Ca="deleteEmptyColumns",Oa="deleteEmptyTable",va={mode:ua,[Aa]:1},La={load:0,save:0,[pa]:t+"_values"},$a=(a,t,e,n,s)=>{const r=J();return Y(a,((a,c)=>{const l=E(q(x(t,o(a)?{[e]:a}:a)),0,H(t));i(l[0])||n(c,l[0])||(s(c,l[0]),Q(r,c,l))})),r},Sa=t,Ia=/^([cd]:)(.+)/,ma=t+"_data",_a=t+"_table",ha=async(a,e,n,s,i)=>{const c=await(e.reserve?.());return((a,e,n,s,i,c,l,y,u,d,R="getDb")=>{const A=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(n,c),[N,,g,p]=(a=>{const e=(a=>x(va,o(a)?{[da]:a}:a??{}))(a),n=e[Aa];if(e.mode==ua){const a=e[da]??t;return[1,n,[a,e[Ta]??C,e[Ra]??ya],ta(a)]}const{tables:{load:s={},save:i={}}={},values:r={}}=e,c=E(q(x(La,r)),0,H(La)),l=c[2],w=ta(l),y=ta(l);return[0,n,[$a(s,{[ga]:null,[Na]:C},ga,(a=>h(y,a)),(a=>ea(w,a))),$a(i,{[pa]:null,[Na]:C,[Ca]:0,[Oa]:0},pa,((a,t)=>h(y,t)),((a,t)=>ea(w,t))),c],w]})(e),L=async a=>{await A(`CREATE OR REPLACE TRIGGER ${m(ma+"_"+a)} AFTER INSERT OR UPDATE OR DELETE ON ${m(a)} EXECUTE FUNCTION ${ma}()`)};return(N?Ea:la)(a,A,(async a=>{await A(`CREATE OR REPLACE FUNCTION ${_a}()RETURNS event_trigger AS $t2$ DECLARE row record; BEGIN FOR row IN SELECT object_identity FROM pg_event_trigger_ddl_commands()WHERE command_tag='CREATE TABLE' LOOP PERFORM pg_notify('${Sa}','c:'||SPLIT_PART(row.object_identity,'.',2));END LOOP;END;$t2$ LANGUAGE plpgsql;`);try{await A(`CREATE EVENT TRIGGER ${_a} ON ddl_command_end WHEN TAG IN('CREATE TABLE')EXECUTE FUNCTION ${_a}();`)}catch{}return await A(`CREATE OR REPLACE FUNCTION ${ma}()RETURNS trigger AS $t1$ BEGIN PERFORM pg_notify('${Sa}','d:'||TG_TABLE_NAME);RETURN NULL;END;$t1$ LANGUAGE plpgsql;`),await w(T(b(p),(async a=>{await A(`CREATE TABLE IF NOT EXISTS ${m(a)}("_id"text PRIMARY KEY)`),await L(a)}))),await s(Sa,(async t=>{return await r((e=t,n=Ia,e?.match(n)),(async([,t,e])=>{h(p,e)&&("c:"==t&&await L(e),a())}));var e,n}))}),i,l,y,u,g,b(p),(async(a,t)=>await a(`${O} table_name tn,column_name cn FROM information_schema.columns ${v} table_schema='public'AND table_name IN(${_(t)})`,t)),d,R,"text",void 0,(a=>k(a)),(a=>z(a)))})(a,n,c?.unsafe,(async(a,t)=>e.listen(a,t)),(async a=>{try{await a.unlisten()}catch(a){i?.(a)}}),s,i,(()=>c?.release?.()),3,e,"getSql")};export{ha as createPostgresPersister};
|
|
1
|
+
const a=a=>typeof a,t="tinybase",e=",",n=a(""),s=Promise,i=a=>null==a,r=(a,t,e)=>i(a)?e?.():t(a),o=t=>a(t)==n,c=a=>Array.isArray(a),E=(a,t,e)=>a.slice(t,e),l=a=>a.length,w=async a=>s.all(a),y=a=>{throw Error(a)},u=(a,t)=>a.forEach(t),d=(a,t="")=>a.join(t),T=(a,t)=>a.map(t),R=a=>0==l(a),A=(a,t)=>a.filter(t),N=(a,...t)=>a.push(...t),g=a=>a.shift(),p="_",C="_id",O="SELECT",v="WHERE",L="TABLE",$="ALTER "+L,S="DELETE FROM",I=O+"*FROM",m=a=>`"${a.replace(/"/g,'""')}"`,_=(a,t=[1])=>d(T(a,(()=>"$"+t[0]++)),e),h=(a,t)=>a?.has(t)??!1,f=a=>i(a)||0==(a=>a?.size??0)(a),b=a=>[...a?.values()??[]],D=(a,t)=>a?.forEach(t),P=(a,t)=>a?.delete(t),U=Object,F=a=>U.getPrototypeOf(a),M=U.entries,G=U.keys,B=U.freeze,j=(a=[])=>U.fromEntries(a),x=(...a)=>U.assign({},...a),X=(a,t)=>(delete a[t],a),Y=(a,t)=>T(M(a),(([a,e])=>t(e,a))),q=a=>U.values(a),H=a=>l(G(a)),W=a=>(a=>!i(a)&&r(F(a),(a=>a==U.prototype||i(F(a))),(()=>!0)))(a)&&0==H(a),k=JSON.stringify,z=JSON.parse,J=a=>new Map(a),K=(a,t)=>a?.get(t),V=(a,t)=>T([...a?.entries()??[]],(([a,e])=>t(e,a))),Q=(a,t,e)=>i(e)?(P(a,t),a):a?.set(t,e),Z=(a,t,e,n)=>(h(a,t)?n?.(K(a,t)):Q(a,t,e()),K(a,t)),aa=(a,t,e,n,s=0)=>r((e?Z:K)(a,t[s],s>l(t)-2?e:J),(i=>{if(s>l(t)-2)return n?.(i)&&Q(a,t[s]),i;const r=aa(i,t,e,n,s+1);return f(i)&&Q(a,t[s]),r})),ta=a=>new Set(c(a)||i(a)?a:[a]),ea=(a,t)=>a?.add(t),na=/^\d+$/,sa=J(),ia=J(),ra=(a,t,e,n,s,o,E,w={},d=[])=>{let T,R,A,p=0,C=0,O=0;Z(sa,d,(()=>0)),Z(ia,d,(()=>[]));const v=J(),[L,$,S,I,m]=((a=1,t)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,t.getTransactionMergeableChanges,([[a],[t]])=>!W(a)||!W(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!W(a)||!W(t),t.setContent]:y("Store type not supported by this Persister"))(E,a),[_,h,b]=(()=>{let a;const[t,e]=(()=>{const a=[];let t=0;return[e=>(e?g(a):null)??""+t++,t=>{na.test(t)&&l(a)<1e3&&N(a,t)}]})(),n=J();return[(e,s,i,r=[],o=()=>[])=>{a??=Y;const c=t(1);return Q(n,c,[e,s,i,r,o]),ea(aa(s,i??[""],ta),c),c},(t,e,...s)=>u(((a,t=[""])=>{const e=[],n=(a,s)=>s==l(t)?N(e,a):null===t[s]?D(a,(a=>n(a,s+1))):u([t[s],null],(t=>n(K(a,t),s+1)));return n(a,0),e})(t,e),(t=>D(t,(t=>K(n,t)[0](a,...e??[],...s))))),a=>r(K(n,a),(([,t,s])=>(aa(t,s??[""],void 0,(t=>(P(t,a),f(t)?1:0))),Q(n,a),e(a),s))),t=>r(K(n,t),(([t,,e=[],n,s])=>{const r=(...o)=>{const c=l(o);c==l(e)?t(a,...o,...s(o)):i(e[c])?u(n[c]?.(...o)??[],(a=>r(...o,a))):r(...o,e[c])};r()}))]})(),U=a=>{a!=p&&(p=a,h(v,void 0,p))},F=t=>{(L&&c(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},M=async a=>(2!=p&&(U(1),C++,await X((async()=>{try{const e=await t();c(e)?F(e):a?m(a):y("Content is not an array: "+e)}catch(t){o?.(t),a&&m(a)}U(0)}))),Y),G=()=>(R&&(s(R),R=void 0),Y),j=async a=>(1!=p&&(U(2),O++,await X((async()=>{try{await e($,a)}catch(a){o?.(a)}U(0)}))),Y),x=()=>(r(A,a.delListener),A=void 0,Y),X=async(...a)=>(N(K(ia,d),...a),await(async()=>{if(!K(sa,d)){for(Q(sa,d,1);!i(T=g(K(ia,d)));)try{await T()}catch(a){o?.(a)}Q(sa,d,0)}})(),Y),Y={load:M,startAutoLoad:async a=>{await G().load(a);try{R=await n((async(a,t)=>{t||a?2!=p&&(U(1),C++,F(t??a),U(0)):await M()}))}catch(a){o?.(a)}return Y},stopAutoLoad:G,isAutoLoading:()=>!i(R),save:j,startAutoSave:async()=>(await x().save(),A=a.addDidFinishTransactionListener((()=>{const a=S();I(a)&&j(a)})),Y),stopAutoSave:x,isAutoSaving:()=>!i(A),getStatus:()=>p,addStatusListener:a=>_(a,v),delListener:t=>(b(t),a),schedule:X,getStore:()=>a,destroy:()=>(K(ia,d).splice(0,void 0),G().stopAutoSave()),getStats:()=>({loads:C,saves:O}),...w};return B(Y)},oa=(a,t,n,s,r,o=ca,c,E)=>{const l=J();return[async()=>{l.clear(),T(await n(a,t),(({tn:a,cn:t})=>ea(Z(l,a,ta),t)))},async(t,e)=>((a,t)=>h(K(l,a),t))(t,e)?j(A(T(await a(I+m(t)),(a=>{return[a[e],E?(t=X(a,e),n=E,j(Y(t,((a,t)=>[t,n(a,t)])))):X(a,e)];var t,n})),(([a,t])=>!i(a)&&!W(t)))):{},async(t,n,s,E,y,u=!1)=>{const g=ta();Y(s??{},(a=>T(G(a??{}),(a=>ea(g,a)))));const p=b(g);if(!u&&y&&R(p)&&h(l,t))return await a("DROP "+L+m(t)),void Q(l,t);const C=K(l,t),O=ta(b(C));if(R(p)||(h(l,t)?await w(T([n,...p],(async(e,s)=>{P(O,e)||(await a($+m(t)+"ADD"+m(e)+r),0==s&&await a("CREATE UNIQUE INDEX pk ON "+m(t)+`(${m(n)})`),ea(C,e))}))):(await a("CREATE "+L+m(t)+`(${m(n)}${r} PRIMARY KEY${d(T(p,(a=>e+m(a)+r)))});`),Q(l,t,ta([n,...p])))),await w([...!u&&E?T(b(O),(async e=>{e!=n&&(await a($+m(t)+"DROP"+m(e)),P(C,e))})):[]]),u)i(s)?await a(S+m(t)+v+" true"):await w(Y(s,(async(e,s)=>{i(e)?await a(S+m(t)+v+m(n)+"=$1",[s]):R(p)||await o(a,t,n,G(e),{[s]:c?T(q(e),c):q(e)},C)})));else if(R(p))h(l,t)&&await a(S+m(t)+v+" true");else{const e=A(b(K(l,t)),(a=>a!=n)),i={},r=[];Y(s??{},((a,t)=>{i[t]=T(e,(t=>c?c(a?.[t]):a?.[t])),N(r,t)})),await o(a,t,n,e,i),await a(S+m(t)+v+m(n)+`NOT IN(${_(r)})`,r)}},async t=>{let e;await a("BEGIN");try{e=await t()}catch(a){s?.(a)}return await a("END"),e}]},ca=async(a,t,n,s,i)=>{const r=[1];await a("INSERT INTO"+m(t)+"("+((...a)=>d(T(a,m),e))(n,...s)+")VALUES"+d(Y(i,(a=>"($"+r[0]+++","+_(a,r)+")")),e)+"ON CONFLICT("+m(n)+")DO UPDATE SET"+d(T(s,(a=>m(a)+"=excluded."+m(a))),e),Y(i,((a,t)=>[t,...T(a,(a=>a??null))])).flat())},Ea=(a,t,e,n,s,i,r,[o,c,E],l,w,y,u,d,T)=>{const[R,A,N,g]=oa(t,l,w,s,d,T),C=ra(a,(async()=>await g((async()=>{return await R(),a=(await A(o,c))[p]?.[E]??"null",z(a,((a,t)=>""===t?void 0:t));var a}))),(async a=>await g((async()=>{var t;await R(),await N(o,c,{[p]:{[E]:(t=a()??null,k(t,((a,t)=>void 0===t?"":t)))}},!0,!0)}))),e,n,s,r,{[u]:()=>y,destroy:()=>(C.stopAutoLoad().stopAutoSave(),i(),C)},y);return C},la=(a,t,e,n,s,r,o,[c,E,[l,y,u]],d,T,R,N,g,O,v,L)=>{const[$,S,I,m]=oa(t,d,T,s,g,O,v,L),_=async(a,t)=>await w(V(E,(async([e,n,s,i],r)=>{t&&!(r in a)||await I(e,n,a[r],s,i,t)}))),h=async(a,t)=>y?await I(u,C,{[p]:a},!0,!0,t):null,f=ra(a,(async()=>await m((async()=>{await $();const a=await(async()=>j(A(await w(V(c,(async([a,t],e)=>[a,await S(e,t)]))),(a=>!W(a[1])))))(),t=await(async()=>l?(await S(u,C))[p]:{})();return W(a)&&i(t)?void 0:[a,t]}))),(async(a,t)=>await m((async()=>{if(await $(),i(t)){const[t,e]=a();await _(t),await h(e)}else await _(t[0],!0),await h(t[1],!0)}))),e,n,s,o,{[N]:()=>R,destroy:()=>(f.stopAutoLoad().stopAutoSave(),r(),f)},R);return f},wa="ColumnName",ya="store",ua="json",da=ya+"TableName",Ta=ya+"Id"+wa,Ra=ya+wa,Aa="autoLoadIntervalSeconds",Na="rowId"+wa,ga="tableId",pa="tableName",Ca="deleteEmptyColumns",Oa="deleteEmptyTable",va={mode:ua,[Aa]:1},La={load:0,save:0,[pa]:t+"_values"},$a=(a,t,e,n,s)=>{const r=J();return Y(a,((a,c)=>{const l=E(q(x(t,o(a)?{[e]:a}:a)),0,H(t));i(l[0])||n(c,l[0])||(s(c,l[0]),Q(r,c,l))})),r},Sa=t,Ia=/^([cd]:)(.+)/,ma=t+"_data",_a=t+"_table",ha=async(a,e,n,s,i)=>{const c=await(e.reserve?.());return((a,e,n,s,i,c,l,y,u,d,R="getDb")=>{const A=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(n,c),[N,,g,p]=(a=>{const e=(a=>x(va,o(a)?{[da]:a}:a??{}))(a),n=e[Aa];if(e.mode==ua){const a=e[da]??t;return[1,n,[a,e[Ta]??C,e[Ra]??ya],ta(a)]}const{tables:{load:s={},save:i={}}={},values:r={}}=e,c=E(q(x(La,r)),0,H(La)),l=c[2],w=ta(l),y=ta(l);return[0,n,[$a(s,{[ga]:null,[Na]:C},ga,(a=>h(y,a)),(a=>ea(w,a))),$a(i,{[pa]:null,[Na]:C,[Ca]:0,[Oa]:0},pa,((a,t)=>h(y,t)),((a,t)=>ea(w,t))),c],w]})(e),L=async a=>{await A(`CREATE OR REPLACE TRIGGER ${m(ma+"_"+a)} AFTER INSERT OR UPDATE OR DELETE ON ${m(a)} EXECUTE FUNCTION ${ma}()`)};return(N?Ea:la)(a,A,(async a=>{await A(`CREATE OR REPLACE FUNCTION ${_a}()RETURNS event_trigger AS $t2$ DECLARE row record; BEGIN FOR row IN SELECT object_identity FROM pg_event_trigger_ddl_commands()WHERE command_tag='CREATE TABLE' LOOP PERFORM pg_notify('${Sa}','c:'||SPLIT_PART(row.object_identity,'.',2));END LOOP;END;$t2$ LANGUAGE plpgsql;`);try{await A(`CREATE EVENT TRIGGER ${_a} ON ddl_command_end WHEN TAG IN('CREATE TABLE')EXECUTE FUNCTION ${_a}();`)}catch{}return await A(`CREATE OR REPLACE FUNCTION ${ma}()RETURNS trigger AS $t1$ BEGIN PERFORM pg_notify('${Sa}','d:'||TG_TABLE_NAME);RETURN NULL;END;$t1$ LANGUAGE plpgsql;`),await w(T(b(p),(async a=>{await A(`CREATE TABLE IF NOT EXISTS ${m(a)}("_id"text PRIMARY KEY)`),await L(a)}))),await s(Sa,(async t=>{return await r((e=t,n=Ia,e?.match(n)),(async([,t,e])=>{h(p,e)&&("c:"==t&&await L(e),a())}));var e,n}))}),i,l,y,u,g,b(p),(async(a,t)=>await a(`${O} table_name tn,column_name cn FROM information_schema.columns ${v} table_schema='public'AND table_name IN(${_(t)})`,t)),d,R,"text",void 0,(a=>k(a)),(a=>z(a)))})(a,n,c?.unsafe,(async(a,t)=>e.listen(a,t)),(async a=>{try{await a.unlisten()}catch(a){i?.(a)}}),s,i,(()=>c?.release?.()),3,e,"getSql")};export{ha as createPostgresPersister};
|
|
Binary file
|
|
@@ -1 +1 @@
|
|
|
1
|
-
const a=a=>typeof a,t="tinybase",e=",",n=a(""),s=Promise,i=a=>null==a,r=(a,t,e)=>i(a)?e?.():t(a),o=t=>a(t)==n,c=a=>Array.isArray(a),E=(a,t,e)=>a.slice(t,e),l=a=>a.length,w=async a=>s.all(a),y=a=>{throw Error(a)},u=(a,t)=>a.forEach(t),d=(a,t="")=>a.join(t),T=(a,t)=>a.map(t),R=a=>0==l(a),A=(a,t)=>a.filter(t),N=(a,...t)=>a.push(...t),g=a=>a.shift(),p="_",C="_id",O="SELECT",v="WHERE",L="TABLE",$="ALTER "+L,S="DELETE FROM",I=O+"*FROM",m=a=>`"${a.replace(/"/g,'""')}"`,_=(a,t=[1])=>d(T(a,(()=>"$"+t[0]++)),e),h=(a,t)=>a?.has(t)??!1,f=a=>i(a)||0==(a=>a?.size??0)(a),b=a=>[...a?.values()??[]],D=(a,t)=>a?.forEach(t),P=(a,t)=>a?.delete(t),U=Object,F=a=>U.getPrototypeOf(a),M=U.entries,G=U.keys,B=U.freeze,j=(a=[])=>U.fromEntries(a),x=(...a)=>U.assign({},...a),X=(a,t)=>(delete a[t],a),Y=(a,t)=>T(M(a),(([a,e])=>t(e,a))),q=a=>U.values(a),H=a=>l(G(a)),W=a=>(a=>!i(a)&&r(F(a),(a=>a==U.prototype||i(F(a))),(()=>!0)))(a)&&0==H(a),k=JSON.stringify,z=JSON.parse,J=a=>new Map(a),K=(a,t)=>a?.get(t),V=(a,t)=>T([...a?.entries()??[]],(([a,e])=>t(e,a))),Q=(a,t,e)=>i(e)?(P(a,t),a):a?.set(t,e),Z=(a,t,e,n)=>(h(a,t)?n?.(K(a,t)):Q(a,t,e()),K(a,t)),aa=(a,t,e,n,s=0)=>r((e?Z:K)(a,t[s],s>l(t)-2?e:J),(i=>{if(s>l(t)-2)return n?.(i)&&Q(a,t[s]),i;const r=aa(i,t,e,n,s+1);return f(i)&&Q(a,t[s]),r})),ta=a=>new Set(c(a)||i(a)?a:[a]),ea=(a,t)=>a?.add(t),na=/^\d+$/,sa=J(),ia=J(),ra=(a,t,e,n,s,o,E,w={},d=[])=>{let T,R,A,p=0,C=0,O=0;Z(sa,d,(()=>0)),Z(ia,d,(()=>[]));const v=J(),[L,$,S,I,m]=((a=1,t)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,t.getTransactionMergeableChanges,([[a],[t]])=>!W(a)||!W(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!W(a)||!W(t),t.setContent]:y("Store type not supported by this Persister"))(E,a),[_,h,b]=(()=>{let a;const[t,e]=(()=>{const a=[];let t=0;return[e=>(e?g(a):null)??""+t++,t=>{na.test(t)&&l(a)<1e3&&N(a,t)}]})(),n=J();return[(e,s,i,r=[],o=()=>[])=>{a??=Y;const c=t(1);return Q(n,c,[e,s,i,r,o]),ea(aa(s,i??[""],ta),c),c},(t,e,...s)=>u(((a,t=[""])=>{const e=[],n=(a,s)=>s==l(t)?N(e,a):null===t[s]?D(a,(a=>n(a,s+1))):u([t[s],null],(t=>n(K(a,t),s+1)));return n(a,0),e})(t,e),(t=>D(t,(t=>K(n,t)[0](a,...e??[],...s))))),a=>r(K(n,a),(([,t,s])=>(aa(t,s??[""],void 0,(t=>(P(t,a),f(t)?1:0))),Q(n,a),e(a),s))),t=>r(K(n,t),(([t,,e=[],n,s])=>{const r=(...o)=>{const c=l(o);c==l(e)?t(a,...o,...s(o)):i(e[c])?u(n[c]?.(...o)??[],(a=>r(...o,a))):r(...o,e[c])};r()}))]})(),U=a=>{a!=p&&(p=a,h(v,void 0,p))},F=t=>{(L&&c(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},M=async a=>(2!=p&&(U(1),C++,await X((async()=>{try{const e=await t();c(e)?F(e):a?m(a):y("Content is not an array "+e)}catch(t){o?.(t),a&&m(a)}U(0)}))),Y),G=()=>(R&&(s(R),R=void 0),Y),j=async a=>(1!=p&&(U(2),O++,await X((async()=>{try{await e($,a)}catch(a){o?.(a)}U(0)}))),Y),x=()=>(r(A,a.delListener),A=void 0,Y),X=async(...a)=>(N(K(ia,d),...a),await(async()=>{if(!K(sa,d)){for(Q(sa,d,1);!i(T=g(K(ia,d)));)try{await T()}catch(a){o?.(a)}Q(sa,d,0)}})(),Y),Y={load:M,startAutoLoad:async a=>{await G().load(a);try{R=await n((async(a,t)=>{t||a?2!=p&&(U(1),C++,F(t??a),U(0)):await M()}))}catch(a){o?.(a)}return Y},stopAutoLoad:G,isAutoLoading:()=>!i(R),save:j,startAutoSave:async()=>(await x().save(),A=a.addDidFinishTransactionListener((()=>{const a=S();I(a)&&j(a)})),Y),stopAutoSave:x,isAutoSaving:()=>!i(A),getStatus:()=>p,addStatusListener:a=>_(a,v),delListener:t=>(b(t),a),schedule:X,getStore:()=>a,destroy:()=>(K(ia,d).splice(0,void 0),G().stopAutoSave()),getStats:()=>({loads:C,saves:O}),...w};return B(Y)},oa=(a,t,n,s,r,o=ca,c,E)=>{const l=J();return[async()=>{l.clear(),T(await n(a,t),(({tn:a,cn:t})=>ea(Z(l,a,ta),t)))},async(t,e)=>((a,t)=>h(K(l,a),t))(t,e)?j(A(T(await a(I+m(t)),(a=>{return[a[e],E?(t=X(a,e),n=E,j(Y(t,((a,t)=>[t,n(a,t)])))):X(a,e)];var t,n})),(([a,t])=>!i(a)&&!W(t)))):{},async(t,n,s,E,y,u=!1)=>{const g=ta();Y(s??{},(a=>T(G(a??{}),(a=>ea(g,a)))));const p=b(g);if(!u&&y&&R(p)&&h(l,t))return await a("DROP "+L+m(t)),void Q(l,t);const C=K(l,t),O=ta(b(C));if(R(p)||(h(l,t)?await w(T([n,...p],(async(e,s)=>{P(O,e)||(await a($+m(t)+"ADD"+m(e)+r),0==s&&await a("CREATE UNIQUE INDEX pk ON "+m(t)+`(${m(n)})`),ea(C,e))}))):(await a("CREATE "+L+m(t)+`(${m(n)}${r} PRIMARY KEY${d(T(p,(a=>e+m(a)+r)))});`),Q(l,t,ta([n,...p])))),await w([...!u&&E?T(b(O),(async e=>{e!=n&&(await a($+m(t)+"DROP"+m(e)),P(C,e))})):[]]),u)i(s)?await a(S+m(t)+v+" true"):await w(Y(s,(async(e,s)=>{i(e)?await a(S+m(t)+v+m(n)+"=$1",[s]):R(p)||await o(a,t,n,G(e),{[s]:c?T(q(e),c):q(e)},C)})));else if(R(p))h(l,t)&&await a(S+m(t)+v+" true");else{const e=A(b(K(l,t)),(a=>a!=n)),i={},r=[];Y(s??{},((a,t)=>{i[t]=T(e,(t=>c?c(a?.[t]):a?.[t])),N(r,t)})),await o(a,t,n,e,i),await a(S+m(t)+v+m(n)+`NOT IN(${_(r)})`,r)}},async t=>{let e;await a("BEGIN");try{e=await t()}catch(a){s?.(a)}return await a("END"),e}]},ca=async(a,t,n,s,i)=>{const r=[1];await a("INSERT INTO"+m(t)+"("+((...a)=>d(T(a,m),e))(n,...s)+")VALUES"+d(Y(i,(a=>"($"+r[0]+++","+_(a,r)+")")),e)+"ON CONFLICT("+m(n)+")DO UPDATE SET"+d(T(s,(a=>m(a)+"=excluded."+m(a))),e),Y(i,((a,t)=>[t,...T(a,(a=>a??null))])).flat())},Ea=(a,t,e,n,s,i,r,[o,c,E],l,w,y,u,d,T)=>{const[R,A,N,g]=oa(t,l,w,s,d,T),C=ra(a,(async()=>await g((async()=>{return await R(),a=(await A(o,c))[p]?.[E]??"null",z(a,((a,t)=>""===t?void 0:t));var a}))),(async a=>await g((async()=>{var t;await R(),await N(o,c,{[p]:{[E]:(t=a()??null,k(t,((a,t)=>void 0===t?"":t)))}},!0,!0)}))),e,n,s,r,{[u]:()=>y,destroy:()=>(C.stopAutoLoad().stopAutoSave(),i(),C)},y);return C},la=(a,t,e,n,s,r,o,[c,E,[l,y,u]],d,T,R,N,g,O,v,L)=>{const[$,S,I,m]=oa(t,d,T,s,g,O,v,L),_=async(a,t)=>await w(V(E,(async([e,n,s,i],r)=>{t&&!(r in a)||await I(e,n,a[r],s,i,t)}))),h=async(a,t)=>y?await I(u,C,{[p]:a},!0,!0,t):null,f=ra(a,(async()=>await m((async()=>{await $();const a=await(async()=>j(A(await w(V(c,(async([a,t],e)=>[a,await S(e,t)]))),(a=>!W(a[1])))))(),t=await(async()=>l?(await S(u,C))[p]:{})();return W(a)&&i(t)?void 0:[a,t]}))),(async(a,t)=>await m((async()=>{if(await $(),i(t)){const[t,e]=a();await _(t),await h(e)}else await _(t[0],!0),await h(t[1],!0)}))),e,n,s,o,{[N]:()=>R,destroy:()=>(f.stopAutoLoad().stopAutoSave(),r(),f)},R);return f},wa="ColumnName",ya="store",ua="json",da=ya+"TableName",Ta=ya+"Id"+wa,Ra=ya+wa,Aa="autoLoadIntervalSeconds",Na="rowId"+wa,ga="tableId",pa="tableName",Ca="deleteEmptyColumns",Oa="deleteEmptyTable",va={mode:ua,[Aa]:1},La={load:0,save:0,[pa]:t+"_values"},$a=(a,t,e,n,s)=>{const r=J();return Y(a,((a,c)=>{const l=E(q(x(t,o(a)?{[e]:a}:a)),0,H(t));i(l[0])||n(c,l[0])||(s(c,l[0]),Q(r,c,l))})),r},Sa=t,Ia=/^([cd]:)(.+)/,ma=t+"_data",_a=t+"_table",ha=async(a,e,n,s,i)=>{const c=await(e.reserve?.());return((a,e,n,s,i,c,l,y,u,d,R="getDb")=>{const A=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(n,c),[N,,g,p]=(a=>{const e=(a=>x(va,o(a)?{[da]:a}:a??{}))(a),n=e[Aa];if(e.mode==ua){const a=e[da]??t;return[1,n,[a,e[Ta]??C,e[Ra]??ya],ta(a)]}const{tables:{load:s={},save:i={}}={},values:r={}}=e,c=E(q(x(La,r)),0,H(La)),l=c[2],w=ta(l),y=ta(l);return[0,n,[$a(s,{[ga]:null,[Na]:C},ga,(a=>h(y,a)),(a=>ea(w,a))),$a(i,{[pa]:null,[Na]:C,[Ca]:0,[Oa]:0},pa,((a,t)=>h(y,t)),((a,t)=>ea(w,t))),c],w]})(e),L=async a=>{await A(`CREATE OR REPLACE TRIGGER ${m(ma+"_"+a)} AFTER INSERT OR UPDATE OR DELETE ON ${m(a)} EXECUTE FUNCTION ${ma}()`)};return(N?Ea:la)(a,A,(async a=>{await A(`CREATE OR REPLACE FUNCTION ${_a}()RETURNS event_trigger AS $t2$ DECLARE row record; BEGIN FOR row IN SELECT object_identity FROM pg_event_trigger_ddl_commands()WHERE command_tag='CREATE TABLE' LOOP PERFORM pg_notify('${Sa}','c:'||SPLIT_PART(row.object_identity,'.',2));END LOOP;END;$t2$ LANGUAGE plpgsql;`);try{await A(`CREATE EVENT TRIGGER ${_a} ON ddl_command_end WHEN TAG IN('CREATE TABLE')EXECUTE FUNCTION ${_a}();`)}catch{}return await A(`CREATE OR REPLACE FUNCTION ${ma}()RETURNS trigger AS $t1$ BEGIN PERFORM pg_notify('${Sa}','d:'||TG_TABLE_NAME);RETURN NULL;END;$t1$ LANGUAGE plpgsql;`),await w(T(b(p),(async a=>{await A(`CREATE TABLE IF NOT EXISTS ${m(a)}("_id"text PRIMARY KEY)`),await L(a)}))),await s(Sa,(async t=>{return await r((e=t,n=Ia,e?.match(n)),(async([,t,e])=>{h(p,e)&&("c:"==t&&await L(e),a())}));var e,n}))}),i,l,y,u,g,b(p),(async(a,t)=>await a(`${O} table_name tn,column_name cn FROM information_schema.columns ${v} table_schema='public'AND table_name IN(${_(t)})`,t)),d,R,"text",void 0,(a=>k(a)),(a=>z(a)))})(a,n,c?.unsafe,(async(a,t)=>e.listen(a,t)),(async a=>{try{await a.unlisten()}catch(a){i?.(a)}}),s,i,(()=>c?.release?.()),3,e,"getSql")};export{ha as createPostgresPersister};
|
|
1
|
+
const a=a=>typeof a,t="tinybase",e=",",n=a(""),s=Promise,i=a=>null==a,r=(a,t,e)=>i(a)?e?.():t(a),o=t=>a(t)==n,c=a=>Array.isArray(a),E=(a,t,e)=>a.slice(t,e),l=a=>a.length,w=async a=>s.all(a),y=a=>{throw Error(a)},u=(a,t)=>a.forEach(t),d=(a,t="")=>a.join(t),T=(a,t)=>a.map(t),R=a=>0==l(a),A=(a,t)=>a.filter(t),N=(a,...t)=>a.push(...t),g=a=>a.shift(),p="_",C="_id",O="SELECT",v="WHERE",L="TABLE",$="ALTER "+L,S="DELETE FROM",I=O+"*FROM",m=a=>`"${a.replace(/"/g,'""')}"`,_=(a,t=[1])=>d(T(a,(()=>"$"+t[0]++)),e),h=(a,t)=>a?.has(t)??!1,f=a=>i(a)||0==(a=>a?.size??0)(a),b=a=>[...a?.values()??[]],D=(a,t)=>a?.forEach(t),P=(a,t)=>a?.delete(t),U=Object,F=a=>U.getPrototypeOf(a),M=U.entries,G=U.keys,B=U.freeze,j=(a=[])=>U.fromEntries(a),x=(...a)=>U.assign({},...a),X=(a,t)=>(delete a[t],a),Y=(a,t)=>T(M(a),(([a,e])=>t(e,a))),q=a=>U.values(a),H=a=>l(G(a)),W=a=>(a=>!i(a)&&r(F(a),(a=>a==U.prototype||i(F(a))),(()=>!0)))(a)&&0==H(a),k=JSON.stringify,z=JSON.parse,J=a=>new Map(a),K=(a,t)=>a?.get(t),V=(a,t)=>T([...a?.entries()??[]],(([a,e])=>t(e,a))),Q=(a,t,e)=>i(e)?(P(a,t),a):a?.set(t,e),Z=(a,t,e,n)=>(h(a,t)?n?.(K(a,t)):Q(a,t,e()),K(a,t)),aa=(a,t,e,n,s=0)=>r((e?Z:K)(a,t[s],s>l(t)-2?e:J),(i=>{if(s>l(t)-2)return n?.(i)&&Q(a,t[s]),i;const r=aa(i,t,e,n,s+1);return f(i)&&Q(a,t[s]),r})),ta=a=>new Set(c(a)||i(a)?a:[a]),ea=(a,t)=>a?.add(t),na=/^\d+$/,sa=J(),ia=J(),ra=(a,t,e,n,s,o,E,w={},d=[])=>{let T,R,A,p=0,C=0,O=0;Z(sa,d,(()=>0)),Z(ia,d,(()=>[]));const v=J(),[L,$,S,I,m]=((a=1,t)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,t.getTransactionMergeableChanges,([[a],[t]])=>!W(a)||!W(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!W(a)||!W(t),t.setContent]:y("Store type not supported by this Persister"))(E,a),[_,h,b]=(()=>{let a;const[t,e]=(()=>{const a=[];let t=0;return[e=>(e?g(a):null)??""+t++,t=>{na.test(t)&&l(a)<1e3&&N(a,t)}]})(),n=J();return[(e,s,i,r=[],o=()=>[])=>{a??=Y;const c=t(1);return Q(n,c,[e,s,i,r,o]),ea(aa(s,i??[""],ta),c),c},(t,e,...s)=>u(((a,t=[""])=>{const e=[],n=(a,s)=>s==l(t)?N(e,a):null===t[s]?D(a,(a=>n(a,s+1))):u([t[s],null],(t=>n(K(a,t),s+1)));return n(a,0),e})(t,e),(t=>D(t,(t=>K(n,t)[0](a,...e??[],...s))))),a=>r(K(n,a),(([,t,s])=>(aa(t,s??[""],void 0,(t=>(P(t,a),f(t)?1:0))),Q(n,a),e(a),s))),t=>r(K(n,t),(([t,,e=[],n,s])=>{const r=(...o)=>{const c=l(o);c==l(e)?t(a,...o,...s(o)):i(e[c])?u(n[c]?.(...o)??[],(a=>r(...o,a))):r(...o,e[c])};r()}))]})(),U=a=>{a!=p&&(p=a,h(v,void 0,p))},F=t=>{(L&&c(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},M=async a=>(2!=p&&(U(1),C++,await X((async()=>{try{const e=await t();c(e)?F(e):a?m(a):y("Content is not an array: "+e)}catch(t){o?.(t),a&&m(a)}U(0)}))),Y),G=()=>(R&&(s(R),R=void 0),Y),j=async a=>(1!=p&&(U(2),O++,await X((async()=>{try{await e($,a)}catch(a){o?.(a)}U(0)}))),Y),x=()=>(r(A,a.delListener),A=void 0,Y),X=async(...a)=>(N(K(ia,d),...a),await(async()=>{if(!K(sa,d)){for(Q(sa,d,1);!i(T=g(K(ia,d)));)try{await T()}catch(a){o?.(a)}Q(sa,d,0)}})(),Y),Y={load:M,startAutoLoad:async a=>{await G().load(a);try{R=await n((async(a,t)=>{t||a?2!=p&&(U(1),C++,F(t??a),U(0)):await M()}))}catch(a){o?.(a)}return Y},stopAutoLoad:G,isAutoLoading:()=>!i(R),save:j,startAutoSave:async()=>(await x().save(),A=a.addDidFinishTransactionListener((()=>{const a=S();I(a)&&j(a)})),Y),stopAutoSave:x,isAutoSaving:()=>!i(A),getStatus:()=>p,addStatusListener:a=>_(a,v),delListener:t=>(b(t),a),schedule:X,getStore:()=>a,destroy:()=>(K(ia,d).splice(0,void 0),G().stopAutoSave()),getStats:()=>({loads:C,saves:O}),...w};return B(Y)},oa=(a,t,n,s,r,o=ca,c,E)=>{const l=J();return[async()=>{l.clear(),T(await n(a,t),(({tn:a,cn:t})=>ea(Z(l,a,ta),t)))},async(t,e)=>((a,t)=>h(K(l,a),t))(t,e)?j(A(T(await a(I+m(t)),(a=>{return[a[e],E?(t=X(a,e),n=E,j(Y(t,((a,t)=>[t,n(a,t)])))):X(a,e)];var t,n})),(([a,t])=>!i(a)&&!W(t)))):{},async(t,n,s,E,y,u=!1)=>{const g=ta();Y(s??{},(a=>T(G(a??{}),(a=>ea(g,a)))));const p=b(g);if(!u&&y&&R(p)&&h(l,t))return await a("DROP "+L+m(t)),void Q(l,t);const C=K(l,t),O=ta(b(C));if(R(p)||(h(l,t)?await w(T([n,...p],(async(e,s)=>{P(O,e)||(await a($+m(t)+"ADD"+m(e)+r),0==s&&await a("CREATE UNIQUE INDEX pk ON "+m(t)+`(${m(n)})`),ea(C,e))}))):(await a("CREATE "+L+m(t)+`(${m(n)}${r} PRIMARY KEY${d(T(p,(a=>e+m(a)+r)))});`),Q(l,t,ta([n,...p])))),await w([...!u&&E?T(b(O),(async e=>{e!=n&&(await a($+m(t)+"DROP"+m(e)),P(C,e))})):[]]),u)i(s)?await a(S+m(t)+v+" true"):await w(Y(s,(async(e,s)=>{i(e)?await a(S+m(t)+v+m(n)+"=$1",[s]):R(p)||await o(a,t,n,G(e),{[s]:c?T(q(e),c):q(e)},C)})));else if(R(p))h(l,t)&&await a(S+m(t)+v+" true");else{const e=A(b(K(l,t)),(a=>a!=n)),i={},r=[];Y(s??{},((a,t)=>{i[t]=T(e,(t=>c?c(a?.[t]):a?.[t])),N(r,t)})),await o(a,t,n,e,i),await a(S+m(t)+v+m(n)+`NOT IN(${_(r)})`,r)}},async t=>{let e;await a("BEGIN");try{e=await t()}catch(a){s?.(a)}return await a("END"),e}]},ca=async(a,t,n,s,i)=>{const r=[1];await a("INSERT INTO"+m(t)+"("+((...a)=>d(T(a,m),e))(n,...s)+")VALUES"+d(Y(i,(a=>"($"+r[0]+++","+_(a,r)+")")),e)+"ON CONFLICT("+m(n)+")DO UPDATE SET"+d(T(s,(a=>m(a)+"=excluded."+m(a))),e),Y(i,((a,t)=>[t,...T(a,(a=>a??null))])).flat())},Ea=(a,t,e,n,s,i,r,[o,c,E],l,w,y,u,d,T)=>{const[R,A,N,g]=oa(t,l,w,s,d,T),C=ra(a,(async()=>await g((async()=>{return await R(),a=(await A(o,c))[p]?.[E]??"null",z(a,((a,t)=>""===t?void 0:t));var a}))),(async a=>await g((async()=>{var t;await R(),await N(o,c,{[p]:{[E]:(t=a()??null,k(t,((a,t)=>void 0===t?"":t)))}},!0,!0)}))),e,n,s,r,{[u]:()=>y,destroy:()=>(C.stopAutoLoad().stopAutoSave(),i(),C)},y);return C},la=(a,t,e,n,s,r,o,[c,E,[l,y,u]],d,T,R,N,g,O,v,L)=>{const[$,S,I,m]=oa(t,d,T,s,g,O,v,L),_=async(a,t)=>await w(V(E,(async([e,n,s,i],r)=>{t&&!(r in a)||await I(e,n,a[r],s,i,t)}))),h=async(a,t)=>y?await I(u,C,{[p]:a},!0,!0,t):null,f=ra(a,(async()=>await m((async()=>{await $();const a=await(async()=>j(A(await w(V(c,(async([a,t],e)=>[a,await S(e,t)]))),(a=>!W(a[1])))))(),t=await(async()=>l?(await S(u,C))[p]:{})();return W(a)&&i(t)?void 0:[a,t]}))),(async(a,t)=>await m((async()=>{if(await $(),i(t)){const[t,e]=a();await _(t),await h(e)}else await _(t[0],!0),await h(t[1],!0)}))),e,n,s,o,{[N]:()=>R,destroy:()=>(f.stopAutoLoad().stopAutoSave(),r(),f)},R);return f},wa="ColumnName",ya="store",ua="json",da=ya+"TableName",Ta=ya+"Id"+wa,Ra=ya+wa,Aa="autoLoadIntervalSeconds",Na="rowId"+wa,ga="tableId",pa="tableName",Ca="deleteEmptyColumns",Oa="deleteEmptyTable",va={mode:ua,[Aa]:1},La={load:0,save:0,[pa]:t+"_values"},$a=(a,t,e,n,s)=>{const r=J();return Y(a,((a,c)=>{const l=E(q(x(t,o(a)?{[e]:a}:a)),0,H(t));i(l[0])||n(c,l[0])||(s(c,l[0]),Q(r,c,l))})),r},Sa=t,Ia=/^([cd]:)(.+)/,ma=t+"_data",_a=t+"_table",ha=async(a,e,n,s,i)=>{const c=await(e.reserve?.());return((a,e,n,s,i,c,l,y,u,d,R="getDb")=>{const A=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(n,c),[N,,g,p]=(a=>{const e=(a=>x(va,o(a)?{[da]:a}:a??{}))(a),n=e[Aa];if(e.mode==ua){const a=e[da]??t;return[1,n,[a,e[Ta]??C,e[Ra]??ya],ta(a)]}const{tables:{load:s={},save:i={}}={},values:r={}}=e,c=E(q(x(La,r)),0,H(La)),l=c[2],w=ta(l),y=ta(l);return[0,n,[$a(s,{[ga]:null,[Na]:C},ga,(a=>h(y,a)),(a=>ea(w,a))),$a(i,{[pa]:null,[Na]:C,[Ca]:0,[Oa]:0},pa,((a,t)=>h(y,t)),((a,t)=>ea(w,t))),c],w]})(e),L=async a=>{await A(`CREATE OR REPLACE TRIGGER ${m(ma+"_"+a)} AFTER INSERT OR UPDATE OR DELETE ON ${m(a)} EXECUTE FUNCTION ${ma}()`)};return(N?Ea:la)(a,A,(async a=>{await A(`CREATE OR REPLACE FUNCTION ${_a}()RETURNS event_trigger AS $t2$ DECLARE row record; BEGIN FOR row IN SELECT object_identity FROM pg_event_trigger_ddl_commands()WHERE command_tag='CREATE TABLE' LOOP PERFORM pg_notify('${Sa}','c:'||SPLIT_PART(row.object_identity,'.',2));END LOOP;END;$t2$ LANGUAGE plpgsql;`);try{await A(`CREATE EVENT TRIGGER ${_a} ON ddl_command_end WHEN TAG IN('CREATE TABLE')EXECUTE FUNCTION ${_a}();`)}catch{}return await A(`CREATE OR REPLACE FUNCTION ${ma}()RETURNS trigger AS $t1$ BEGIN PERFORM pg_notify('${Sa}','d:'||TG_TABLE_NAME);RETURN NULL;END;$t1$ LANGUAGE plpgsql;`),await w(T(b(p),(async a=>{await A(`CREATE TABLE IF NOT EXISTS ${m(a)}("_id"text PRIMARY KEY)`),await L(a)}))),await s(Sa,(async t=>{return await r((e=t,n=Ia,e?.match(n)),(async([,t,e])=>{h(p,e)&&("c:"==t&&await L(e),a())}));var e,n}))}),i,l,y,u,g,b(p),(async(a,t)=>await a(`${O} table_name tn,column_name cn FROM information_schema.columns ${v} table_schema='public'AND table_name IN(${_(t)})`,t)),d,R,"text",void 0,(a=>k(a)),(a=>z(a)))})(a,n,c?.unsafe,(async(a,t)=>e.listen(a,t)),(async a=>{try{await a.unlisten()}catch(a){i?.(a)}}),s,i,(()=>c?.release?.()),3,e,"getSql")};export{ha as createPostgresPersister};
|
|
Binary file
|
|
@@ -1 +1 @@
|
|
|
1
|
-
const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),o=Promise,r=clearInterval,i=a=>null==a,c=(a,t,e)=>i(a)?e?.():t(a),l=t=>a(t)==s,w=a=>Array.isArray(a),u=(a,t,e)=>a.slice(t,e),y=a=>a.length,d=async a=>o.all(a),E=a=>{throw Error(a)},v=(a,t)=>a.forEach(t),g=(a,t="")=>a.join(t),p=(a,t)=>a.map(t),A=a=>0==y(a),h=(a,t)=>a.filter(t),N=(a,...t)=>a.push(...t),f=a=>a.shift(),m=Object,S=a=>m.getPrototypeOf(a),T=m.entries,C=m.keys,$=m.freeze,O=(a=[])=>m.fromEntries(a),b=(...a)=>m.assign({},...a),I=(a,t)=>(delete a[t],a),L=(a,t)=>p(T(a),(([a,e])=>t(e,a))),R=a=>m.values(a),D=a=>y(C(a)),M=a=>(a=>!i(a)&&c(S(a),(a=>a==m.prototype||i(S(a))),(()=>!0)))(a)&&0==D(a),_=a=>new Set(w(a)||i(a)?a:[a]),P=(a,t)=>a?.add(t),F="_",U="_id",j="SELECT",x="WHERE",B="TABLE",H="ALTER "+B,J="DELETE FROM",Y=j+"*FROM",k="pragma_",z="data_version",G="schema_version",V="pragma_table_",W=a=>`"${a.replace(/"/g,'""')}"`,K=(...a)=>g(p(a,W),n),Q=(a,t=[1])=>g(p(a,(()=>"$"+t[0]++)),n),X=(a,t)=>a?.has(t)??!1,q=a=>i(a)||0==(a=>a?.size??0)(a),Z=a=>[...a?.values()??[]],aa=(a,t)=>a?.forEach(t),ta=(a,t)=>a?.delete(t),ea=JSON.stringify,na=JSON.parse,sa=a=>new Map(a),oa=(a,t)=>a?.get(t),ra=(a,t)=>p([...a?.entries()??[]],(([a,e])=>t(e,a))),ia=(a,t,e)=>i(e)?(ta(a,t),a):a?.set(t,e),ca=(a,t,e,n)=>(X(a,t)?n?.(oa(a,t)):ia(a,t,e()),oa(a,t)),la=(a,t,e,n,s=0)=>c((e?ca:oa)(a,t[s],s>y(t)-2?e:sa),(o=>{if(s>y(t)-2)return n?.(o)&&ia(a,t[s]),o;const r=la(o,t,e,n,s+1);return q(o)&&ia(a,t[s]),r})),wa=/^\d+$/,ua=sa(),ya=sa(),da=(a,t,n,s,o,r,l,u={},d=[])=>{let g,p,A,h=0,m=0,S=0;ca(ua,d,(()=>0)),ca(ya,d,(()=>[]));const T=sa(),[C,O,b,I,L]=((a=1,t)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,t.getTransactionMergeableChanges,([[a],[t]])=>!M(a)||!M(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!M(a)||!M(t),t.setContent]:E("Store type not supported by this Persister"))(l,a),[R,D,F]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?f(a):null)??e+t++,t=>{wa.test(t)&&y(a)<1e3&&N(a,t)}]})(),s=sa();return[(n,o,r,i=[],c=()=>[])=>{a??=k;const l=t(1);return ia(s,l,[n,o,r,i,c]),P(la(o,r??[e],_),l),l},(t,n,...o)=>v(((a,t=[e])=>{const n=[],s=(a,e)=>e==y(t)?N(n,a):null===t[e]?aa(a,(a=>s(a,e+1))):v([t[e],null],(t=>s(oa(a,t),e+1)));return s(a,0),n})(t,n),(t=>aa(t,(t=>oa(s,t)[0](a,...n??[],...o))))),a=>c(oa(s,a),(([,t,o])=>(la(t,o??[e],void 0,(t=>(ta(t,a),q(t)?1:0))),ia(s,a),n(a),o))),t=>c(oa(s,t),(([t,,e=[],n,s])=>{const o=(...r)=>{const c=y(r);c==y(e)?t(a,...r,...s(r)):i(e[c])?v(n[c]?.(...r)??[],(a=>o(...r,a))):o(...r,e[c])};o()}))]})(),U=a=>{a!=h&&(h=a,D(T,void 0,h))},j=t=>{(C&&w(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},x=async a=>(2!=h&&(U(1),m++,await Y((async()=>{try{const e=await t();w(e)?j(e):a?L(a):E("Content is not an array "+e)}catch(t){r?.(t),a&&L(a)}U(0)}))),k),B=()=>(p&&(o(p),p=void 0),k),H=async a=>(1!=h&&(U(2),S++,await Y((async()=>{try{await n(O,a)}catch(a){r?.(a)}U(0)}))),k),J=()=>(c(A,a.delListener),A=void 0,k),Y=async(...a)=>(N(oa(ya,d),...a),await(async()=>{if(!oa(ua,d)){for(ia(ua,d,1);!i(g=f(oa(ya,d)));)try{await g()}catch(a){r?.(a)}ia(ua,d,0)}})(),k),k={load:x,startAutoLoad:async a=>{await B().load(a);try{p=await s((async(a,t)=>{t||a?2!=h&&(U(1),m++,j(t??a),U(0)):await x()}))}catch(a){r?.(a)}return k},stopAutoLoad:B,isAutoLoading:()=>!i(p),save:H,startAutoSave:async()=>(await J().save(),A=a.addDidFinishTransactionListener((()=>{const a=b();I(a)&&H(a)})),k),stopAutoSave:J,isAutoSaving:()=>!i(A),getStatus:()=>h,addStatusListener:a=>R(a,T),delListener:t=>(F(t),a),schedule:Y,getStore:()=>a,destroy:()=>(oa(ya,d).splice(0,void 0),B().stopAutoSave()),getStats:()=>({loads:m,saves:S}),...u};return $(k)},Ea=(a,t,e,s,o,r=va,c,l)=>{const w=sa();return[async()=>{w.clear(),p(await e(a,t),(({tn:a,cn:t})=>P(ca(w,a,_),t)))},async(t,e)=>((a,t)=>X(oa(w,a),t))(t,e)?O(h(p(await a(Y+W(t)),(a=>{return[a[e],l?(t=I(a,e),n=l,O(L(t,((a,t)=>[t,n(a,t)])))):I(a,e)];var t,n})),(([a,t])=>!i(a)&&!M(t)))):{},async(t,e,s,l,u,y=!1)=>{const E=_();L(s??{},(a=>p(C(a??{}),(a=>P(E,a)))));const v=Z(E);if(!y&&u&&A(v)&&X(w,t))return await a("DROP "+B+W(t)),void ia(w,t);const f=oa(w,t),m=_(Z(f));if(A(v)||(X(w,t)?await d(p([e,...v],(async(n,s)=>{ta(m,n)||(await a(H+W(t)+"ADD"+W(n)+o),0==s&&await a("CREATE UNIQUE INDEX pk ON "+W(t)+`(${W(e)})`),P(f,n))}))):(await a("CREATE "+B+W(t)+`(${W(e)}${o} PRIMARY KEY${g(p(v,(a=>n+W(a)+o)))});`),ia(w,t,_([e,...v])))),await d([...!y&&l?p(Z(m),(async n=>{n!=e&&(await a(H+W(t)+"DROP"+W(n)),ta(f,n))})):[]]),y)i(s)?await a(J+W(t)+x+" true"):await d(L(s,(async(n,s)=>{i(n)?await a(J+W(t)+x+W(e)+"=$1",[s]):A(v)||await r(a,t,e,C(n),{[s]:c?p(R(n),c):R(n)},f)})));else if(A(v))X(w,t)&&await a(J+W(t)+x+" true");else{const n=h(Z(oa(w,t)),(a=>a!=e)),o={},i=[];L(s??{},((a,t)=>{o[t]=p(n,(t=>c?c(a?.[t]):a?.[t])),N(i,t)})),await r(a,t,e,n,o),await a(J+W(t)+x+W(e)+`NOT IN(${Q(i)})`,i)}},async t=>{let e;await a("BEGIN");try{e=await t()}catch(a){s?.(a)}return await a("END"),e}]},va=async(a,t,e,s,o)=>{const r=[1];await a("INSERT INTO"+W(t)+"("+K(e,...s)+")VALUES"+g(L(o,(a=>"($"+r[0]+++","+Q(a,r)+")")),n)+"ON CONFLICT("+W(e)+")DO UPDATE SET"+g(p(s,(a=>W(a)+"=excluded."+W(a))),n),L(o,((a,t)=>[t,...p(a,(a=>a??null))])).flat())},ga=(a,t,e,n,s,o,r,[i,c,l],w,u,y,d,E,v)=>{const[g,p,A,h]=Ea(t,w,u,s,E,v),N=da(a,(async()=>await h((async()=>{return await g(),a=(await p(i,c))[F]?.[l]??"null",na(a,((a,t)=>""===t?void 0:t));var a}))),(async a=>await h((async()=>{var t;await g(),await A(i,c,{[F]:{[l]:(t=a()??null,ea(t,((a,t)=>void 0===t?"":t)))}},!0,!0)}))),e,n,s,r,{[d]:()=>y,destroy:()=>(N.stopAutoLoad().stopAutoSave(),o(),N)},y);return N},pa=(a,t,e,n,s,o,r,[c,l,[w,u,y]],E,v,g,p,A,N,f,m)=>{const[S,T,C,$]=Ea(t,E,v,s,A,N,f,m),b=async(a,t)=>await d(ra(l,(async([e,n,s,o],r)=>{t&&!(r in a)||await C(e,n,a[r],s,o,t)}))),I=async(a,t)=>u?await C(y,U,{[F]:a},!0,!0,t):null,L=da(a,(async()=>await $((async()=>{await S();const a=await(async()=>O(h(await d(ra(c,(async([a,t],e)=>[a,await T(e,t)]))),(a=>!M(a[1])))))(),t=await(async()=>w?(await T(y,U))[F]:{})();return M(a)&&i(t)?void 0:[a,t]}))),(async(a,t)=>await $((async()=>{if(await S(),i(t)){const[t,e]=a();await b(t),await I(e)}else await b(t[0],!0),await I(t[1],!0)}))),e,n,s,r,{[p]:()=>g,destroy:()=>(L.stopAutoLoad().stopAutoSave(),o(),L)},g);return L},Aa="ColumnName",ha="store",Na="json",fa=ha+"TableName",ma=ha+"Id"+Aa,Sa=ha+Aa,Ta="autoLoadIntervalSeconds",Ca="rowId"+Aa,$a="tableId",Oa="tableName",ba="deleteEmptyColumns",Ia="deleteEmptyTable",La={mode:Na,[Ta]:1},Ra={load:0,save:0,[Oa]:t+"_values"},Da=(a,t,e,n,s)=>{const o=sa();return L(a,((a,r)=>{const c=u(R(b(t,l(a)?{[e]:a}:a)),0,D(t));i(c[0])||n(r,c[0])||(s(r,c[0]),ia(o,r,c))})),o},Ma=(a,n,s,o,i,c,w,y,d,E,v="getDb",g)=>{let p,A,h;const N=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,c),[f,m,S,T]=(a=>{const e=(a=>b(La,l(a)?{[fa]:a}:a??{}))(a),n=e[Ta];if(e.mode==Na){const a=e[fa]??t;return[1,n,[a,e[ma]??U,e[Sa]??ha],_(a)]}const{tables:{load:s={},save:o={}}={},values:r={}}=e,i=u(R(b(Ra,r)),0,D(Ra)),c=i[2],w=_(c),y=_(c);return[0,n,[Da(s,{[$a]:null,[Ca]:U},$a,(a=>X(y,a)),(a=>P(w,a))),Da(o,{[Oa]:null,[Ca]:U,[ba]:0,[Ia]:0},Oa,((a,t)=>X(y,t)),((a,t)=>P(w,t))),i],w]})(n);return(f?ga:pa)(a,N,(a=>{let t;const e=()=>t=setInterval((async()=>{try{const[{d:t,s:e,c:n}]=await N(`${j} ${z} d,${G} s,TOTAL_CHANGES() c FROM ${k}${z} JOIN ${k}${G}`);t==p&&e==A&&n==h||(null!=p&&a(),p=t,A=e,h=n)}catch{}}),1e3*m),n=()=>{p=A=h=null,r(t)},s=o((t=>{T.has(t)&&(n(),a(),e())}));return e(),()=>{n(),i(s)}}),(a=>a()),w,y,d,S,Z(T),(async(a,t)=>await a(`${j} t.name tn,c.name cn FROM ${V}list()t,${V}info(t.name)c ${x} t.schema='main'AND t.type IN('table','view')AND t.name IN(${Q(t)})ORDER BY t.name,c.name`,t)),E,v,e,g,(a=>!0===a?1:!1===a?0:a),void 0)},_a=(a,t,e,n,s)=>{let o;return Ma(a,e,(async(a,e=[])=>t.execute(a,e).then((a=>a.rows?._array??[]))),(a=>{const e=new AbortController,n=t.onChange({rawTableNames:!0,signal:e.signal});return(async()=>{for await(const a of n)o&&p(a.changedTables,o)})(),o=a,e}),(a=>{o=void 0,a.abort()}),n,s,(()=>0),1,t,"getPowerSync",Pa)},Pa=async(a,t,e,s,o,r)=>{const i=[1],c=_(s),l=r?h([...r],(a=>a!=e&&!X(c,a))):[];if(!A(l)){const n=C(o),s=O(p(await a("SELECT"+K(e,...l)+"FROM"+W(t)+"WHERE"+W(e)+"IN("+Q(n)+")",n),(a=>[a[e],a])));v(n,(a=>N(o[a],...p(l,(t=>s?.[a]?.[t]??null)))))}await a("INSERT OR REPLACE INTO"+W(t)+"("+K(e,...s,...l)+")VALUES"+g(L(o,(a=>"($"+i[0]+++","+Q(a,i)+")")),n),L(o,((a,t)=>[t,...p(a,(a=>a??null))])).flat())};export{_a as createPowerSyncPersister};
|
|
1
|
+
const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),o=Promise,r=clearInterval,i=a=>null==a,c=(a,t,e)=>i(a)?e?.():t(a),l=t=>a(t)==s,w=a=>Array.isArray(a),u=(a,t,e)=>a.slice(t,e),y=a=>a.length,d=async a=>o.all(a),E=a=>{throw Error(a)},v=(a,t)=>a.forEach(t),g=(a,t="")=>a.join(t),p=(a,t)=>a.map(t),A=a=>0==y(a),h=(a,t)=>a.filter(t),N=(a,...t)=>a.push(...t),f=a=>a.shift(),m=Object,S=a=>m.getPrototypeOf(a),T=m.entries,C=m.keys,$=m.freeze,O=(a=[])=>m.fromEntries(a),b=(...a)=>m.assign({},...a),I=(a,t)=>(delete a[t],a),L=(a,t)=>p(T(a),(([a,e])=>t(e,a))),R=a=>m.values(a),D=a=>y(C(a)),M=a=>(a=>!i(a)&&c(S(a),(a=>a==m.prototype||i(S(a))),(()=>!0)))(a)&&0==D(a),_=a=>new Set(w(a)||i(a)?a:[a]),P=(a,t)=>a?.add(t),F="_",U="_id",j="SELECT",x="WHERE",B="TABLE",H="ALTER "+B,J="DELETE FROM",Y=j+"*FROM",k="pragma_",z="data_version",G="schema_version",V="pragma_table_",W=a=>`"${a.replace(/"/g,'""')}"`,K=(...a)=>g(p(a,W),n),Q=(a,t=[1])=>g(p(a,(()=>"$"+t[0]++)),n),X=(a,t)=>a?.has(t)??!1,q=a=>i(a)||0==(a=>a?.size??0)(a),Z=a=>[...a?.values()??[]],aa=(a,t)=>a?.forEach(t),ta=(a,t)=>a?.delete(t),ea=JSON.stringify,na=JSON.parse,sa=a=>new Map(a),oa=(a,t)=>a?.get(t),ra=(a,t)=>p([...a?.entries()??[]],(([a,e])=>t(e,a))),ia=(a,t,e)=>i(e)?(ta(a,t),a):a?.set(t,e),ca=(a,t,e,n)=>(X(a,t)?n?.(oa(a,t)):ia(a,t,e()),oa(a,t)),la=(a,t,e,n,s=0)=>c((e?ca:oa)(a,t[s],s>y(t)-2?e:sa),(o=>{if(s>y(t)-2)return n?.(o)&&ia(a,t[s]),o;const r=la(o,t,e,n,s+1);return q(o)&&ia(a,t[s]),r})),wa=/^\d+$/,ua=sa(),ya=sa(),da=(a,t,n,s,o,r,l,u={},d=[])=>{let g,p,A,h=0,m=0,S=0;ca(ua,d,(()=>0)),ca(ya,d,(()=>[]));const T=sa(),[C,O,b,I,L]=((a=1,t)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,t.getTransactionMergeableChanges,([[a],[t]])=>!M(a)||!M(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!M(a)||!M(t),t.setContent]:E("Store type not supported by this Persister"))(l,a),[R,D,F]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?f(a):null)??e+t++,t=>{wa.test(t)&&y(a)<1e3&&N(a,t)}]})(),s=sa();return[(n,o,r,i=[],c=()=>[])=>{a??=k;const l=t(1);return ia(s,l,[n,o,r,i,c]),P(la(o,r??[e],_),l),l},(t,n,...o)=>v(((a,t=[e])=>{const n=[],s=(a,e)=>e==y(t)?N(n,a):null===t[e]?aa(a,(a=>s(a,e+1))):v([t[e],null],(t=>s(oa(a,t),e+1)));return s(a,0),n})(t,n),(t=>aa(t,(t=>oa(s,t)[0](a,...n??[],...o))))),a=>c(oa(s,a),(([,t,o])=>(la(t,o??[e],void 0,(t=>(ta(t,a),q(t)?1:0))),ia(s,a),n(a),o))),t=>c(oa(s,t),(([t,,e=[],n,s])=>{const o=(...r)=>{const c=y(r);c==y(e)?t(a,...r,...s(r)):i(e[c])?v(n[c]?.(...r)??[],(a=>o(...r,a))):o(...r,e[c])};o()}))]})(),U=a=>{a!=h&&(h=a,D(T,void 0,h))},j=t=>{(C&&w(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},x=async a=>(2!=h&&(U(1),m++,await Y((async()=>{try{const e=await t();w(e)?j(e):a?L(a):E("Content is not an array: "+e)}catch(t){r?.(t),a&&L(a)}U(0)}))),k),B=()=>(p&&(o(p),p=void 0),k),H=async a=>(1!=h&&(U(2),S++,await Y((async()=>{try{await n(O,a)}catch(a){r?.(a)}U(0)}))),k),J=()=>(c(A,a.delListener),A=void 0,k),Y=async(...a)=>(N(oa(ya,d),...a),await(async()=>{if(!oa(ua,d)){for(ia(ua,d,1);!i(g=f(oa(ya,d)));)try{await g()}catch(a){r?.(a)}ia(ua,d,0)}})(),k),k={load:x,startAutoLoad:async a=>{await B().load(a);try{p=await s((async(a,t)=>{t||a?2!=h&&(U(1),m++,j(t??a),U(0)):await x()}))}catch(a){r?.(a)}return k},stopAutoLoad:B,isAutoLoading:()=>!i(p),save:H,startAutoSave:async()=>(await J().save(),A=a.addDidFinishTransactionListener((()=>{const a=b();I(a)&&H(a)})),k),stopAutoSave:J,isAutoSaving:()=>!i(A),getStatus:()=>h,addStatusListener:a=>R(a,T),delListener:t=>(F(t),a),schedule:Y,getStore:()=>a,destroy:()=>(oa(ya,d).splice(0,void 0),B().stopAutoSave()),getStats:()=>({loads:m,saves:S}),...u};return $(k)},Ea=(a,t,e,s,o,r=va,c,l)=>{const w=sa();return[async()=>{w.clear(),p(await e(a,t),(({tn:a,cn:t})=>P(ca(w,a,_),t)))},async(t,e)=>((a,t)=>X(oa(w,a),t))(t,e)?O(h(p(await a(Y+W(t)),(a=>{return[a[e],l?(t=I(a,e),n=l,O(L(t,((a,t)=>[t,n(a,t)])))):I(a,e)];var t,n})),(([a,t])=>!i(a)&&!M(t)))):{},async(t,e,s,l,u,y=!1)=>{const E=_();L(s??{},(a=>p(C(a??{}),(a=>P(E,a)))));const v=Z(E);if(!y&&u&&A(v)&&X(w,t))return await a("DROP "+B+W(t)),void ia(w,t);const f=oa(w,t),m=_(Z(f));if(A(v)||(X(w,t)?await d(p([e,...v],(async(n,s)=>{ta(m,n)||(await a(H+W(t)+"ADD"+W(n)+o),0==s&&await a("CREATE UNIQUE INDEX pk ON "+W(t)+`(${W(e)})`),P(f,n))}))):(await a("CREATE "+B+W(t)+`(${W(e)}${o} PRIMARY KEY${g(p(v,(a=>n+W(a)+o)))});`),ia(w,t,_([e,...v])))),await d([...!y&&l?p(Z(m),(async n=>{n!=e&&(await a(H+W(t)+"DROP"+W(n)),ta(f,n))})):[]]),y)i(s)?await a(J+W(t)+x+" true"):await d(L(s,(async(n,s)=>{i(n)?await a(J+W(t)+x+W(e)+"=$1",[s]):A(v)||await r(a,t,e,C(n),{[s]:c?p(R(n),c):R(n)},f)})));else if(A(v))X(w,t)&&await a(J+W(t)+x+" true");else{const n=h(Z(oa(w,t)),(a=>a!=e)),o={},i=[];L(s??{},((a,t)=>{o[t]=p(n,(t=>c?c(a?.[t]):a?.[t])),N(i,t)})),await r(a,t,e,n,o),await a(J+W(t)+x+W(e)+`NOT IN(${Q(i)})`,i)}},async t=>{let e;await a("BEGIN");try{e=await t()}catch(a){s?.(a)}return await a("END"),e}]},va=async(a,t,e,s,o)=>{const r=[1];await a("INSERT INTO"+W(t)+"("+K(e,...s)+")VALUES"+g(L(o,(a=>"($"+r[0]+++","+Q(a,r)+")")),n)+"ON CONFLICT("+W(e)+")DO UPDATE SET"+g(p(s,(a=>W(a)+"=excluded."+W(a))),n),L(o,((a,t)=>[t,...p(a,(a=>a??null))])).flat())},ga=(a,t,e,n,s,o,r,[i,c,l],w,u,y,d,E,v)=>{const[g,p,A,h]=Ea(t,w,u,s,E,v),N=da(a,(async()=>await h((async()=>{return await g(),a=(await p(i,c))[F]?.[l]??"null",na(a,((a,t)=>""===t?void 0:t));var a}))),(async a=>await h((async()=>{var t;await g(),await A(i,c,{[F]:{[l]:(t=a()??null,ea(t,((a,t)=>void 0===t?"":t)))}},!0,!0)}))),e,n,s,r,{[d]:()=>y,destroy:()=>(N.stopAutoLoad().stopAutoSave(),o(),N)},y);return N},pa=(a,t,e,n,s,o,r,[c,l,[w,u,y]],E,v,g,p,A,N,f,m)=>{const[S,T,C,$]=Ea(t,E,v,s,A,N,f,m),b=async(a,t)=>await d(ra(l,(async([e,n,s,o],r)=>{t&&!(r in a)||await C(e,n,a[r],s,o,t)}))),I=async(a,t)=>u?await C(y,U,{[F]:a},!0,!0,t):null,L=da(a,(async()=>await $((async()=>{await S();const a=await(async()=>O(h(await d(ra(c,(async([a,t],e)=>[a,await T(e,t)]))),(a=>!M(a[1])))))(),t=await(async()=>w?(await T(y,U))[F]:{})();return M(a)&&i(t)?void 0:[a,t]}))),(async(a,t)=>await $((async()=>{if(await S(),i(t)){const[t,e]=a();await b(t),await I(e)}else await b(t[0],!0),await I(t[1],!0)}))),e,n,s,r,{[p]:()=>g,destroy:()=>(L.stopAutoLoad().stopAutoSave(),o(),L)},g);return L},Aa="ColumnName",ha="store",Na="json",fa=ha+"TableName",ma=ha+"Id"+Aa,Sa=ha+Aa,Ta="autoLoadIntervalSeconds",Ca="rowId"+Aa,$a="tableId",Oa="tableName",ba="deleteEmptyColumns",Ia="deleteEmptyTable",La={mode:Na,[Ta]:1},Ra={load:0,save:0,[Oa]:t+"_values"},Da=(a,t,e,n,s)=>{const o=sa();return L(a,((a,r)=>{const c=u(R(b(t,l(a)?{[e]:a}:a)),0,D(t));i(c[0])||n(r,c[0])||(s(r,c[0]),ia(o,r,c))})),o},Ma=(a,n,s,o,i,c,w,y,d,E,v="getDb",g)=>{let p,A,h;const N=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,c),[f,m,S,T]=(a=>{const e=(a=>b(La,l(a)?{[fa]:a}:a??{}))(a),n=e[Ta];if(e.mode==Na){const a=e[fa]??t;return[1,n,[a,e[ma]??U,e[Sa]??ha],_(a)]}const{tables:{load:s={},save:o={}}={},values:r={}}=e,i=u(R(b(Ra,r)),0,D(Ra)),c=i[2],w=_(c),y=_(c);return[0,n,[Da(s,{[$a]:null,[Ca]:U},$a,(a=>X(y,a)),(a=>P(w,a))),Da(o,{[Oa]:null,[Ca]:U,[ba]:0,[Ia]:0},Oa,((a,t)=>X(y,t)),((a,t)=>P(w,t))),i],w]})(n);return(f?ga:pa)(a,N,(a=>{let t;const e=()=>t=setInterval((async()=>{try{const[{d:t,s:e,c:n}]=await N(`${j} ${z} d,${G} s,TOTAL_CHANGES() c FROM ${k}${z} JOIN ${k}${G}`);t==p&&e==A&&n==h||(null!=p&&a(),p=t,A=e,h=n)}catch{}}),1e3*m),n=()=>{p=A=h=null,r(t)},s=o((t=>{T.has(t)&&(n(),a(),e())}));return e(),()=>{n(),i(s)}}),(a=>a()),w,y,d,S,Z(T),(async(a,t)=>await a(`${j} t.name tn,c.name cn FROM ${V}list()t,${V}info(t.name)c ${x} t.schema='main'AND t.type IN('table','view')AND t.name IN(${Q(t)})ORDER BY t.name,c.name`,t)),E,v,e,g,(a=>!0===a?1:!1===a?0:a),void 0)},_a=(a,t,e,n,s)=>{let o;return Ma(a,e,(async(a,e=[])=>t.execute(a,e).then((a=>a.rows?._array??[]))),(a=>{const e=new AbortController,n=t.onChange({rawTableNames:!0,signal:e.signal});return(async()=>{for await(const a of n)o&&p(a.changedTables,o)})(),o=a,e}),(a=>{o=void 0,a.abort()}),n,s,(()=>0),1,t,"getPowerSync",Pa)},Pa=async(a,t,e,s,o,r)=>{const i=[1],c=_(s),l=r?h([...r],(a=>a!=e&&!X(c,a))):[];if(!A(l)){const n=C(o),s=O(p(await a("SELECT"+K(e,...l)+"FROM"+W(t)+"WHERE"+W(e)+"IN("+Q(n)+")",n),(a=>[a[e],a])));v(n,(a=>N(o[a],...p(l,(t=>s?.[a]?.[t]??null)))))}await a("INSERT OR REPLACE INTO"+W(t)+"("+K(e,...s,...l)+")VALUES"+g(L(o,(a=>"($"+i[0]+++","+Q(a,i)+")")),n),L(o,((a,t)=>[t,...p(a,(a=>a??null))])).flat())};export{_a as createPowerSyncPersister};
|
|
Binary file
|
|
@@ -1 +1 @@
|
|
|
1
|
-
const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),o=Promise,r=clearInterval,i=a=>null==a,c=(a,t,e)=>i(a)?e?.():t(a),l=t=>a(t)==s,w=a=>Array.isArray(a),u=(a,t,e)=>a.slice(t,e),y=a=>a.length,d=async a=>o.all(a),E=a=>{throw Error(a)},v=(a,t)=>a.forEach(t),g=(a,t="")=>a.join(t),p=(a,t)=>a.map(t),A=a=>0==y(a),h=(a,t)=>a.filter(t),N=(a,...t)=>a.push(...t),f=a=>a.shift(),m=Object,S=a=>m.getPrototypeOf(a),T=m.entries,C=m.keys,$=m.freeze,O=(a=[])=>m.fromEntries(a),b=(...a)=>m.assign({},...a),I=(a,t)=>(delete a[t],a),L=(a,t)=>p(T(a),(([a,e])=>t(e,a))),R=a=>m.values(a),D=a=>y(C(a)),M=a=>(a=>!i(a)&&c(S(a),(a=>a==m.prototype||i(S(a))),(()=>!0)))(a)&&0==D(a),_=a=>new Set(w(a)||i(a)?a:[a]),P=(a,t)=>a?.add(t),F="_",U="_id",j="SELECT",x="WHERE",B="TABLE",H="ALTER "+B,J="DELETE FROM",Y=j+"*FROM",k="pragma_",z="data_version",G="schema_version",V="pragma_table_",W=a=>`"${a.replace(/"/g,'""')}"`,K=(...a)=>g(p(a,W),n),Q=(a,t=[1])=>g(p(a,(()=>"$"+t[0]++)),n),X=(a,t)=>a?.has(t)??!1,q=a=>i(a)||0==(a=>a?.size??0)(a),Z=a=>[...a?.values()??[]],aa=(a,t)=>a?.forEach(t),ta=(a,t)=>a?.delete(t),ea=JSON.stringify,na=JSON.parse,sa=a=>new Map(a),oa=(a,t)=>a?.get(t),ra=(a,t)=>p([...a?.entries()??[]],(([a,e])=>t(e,a))),ia=(a,t,e)=>i(e)?(ta(a,t),a):a?.set(t,e),ca=(a,t,e,n)=>(X(a,t)?n?.(oa(a,t)):ia(a,t,e()),oa(a,t)),la=(a,t,e,n,s=0)=>c((e?ca:oa)(a,t[s],s>y(t)-2?e:sa),(o=>{if(s>y(t)-2)return n?.(o)&&ia(a,t[s]),o;const r=la(o,t,e,n,s+1);return q(o)&&ia(a,t[s]),r})),wa=/^\d+$/,ua=sa(),ya=sa(),da=(a,t,n,s,o,r,l,u={},d=[])=>{let g,p,A,h=0,m=0,S=0;ca(ua,d,(()=>0)),ca(ya,d,(()=>[]));const T=sa(),[C,O,b,I,L]=((a=1,t)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,t.getTransactionMergeableChanges,([[a],[t]])=>!M(a)||!M(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!M(a)||!M(t),t.setContent]:E("Store type not supported by this Persister"))(l,a),[R,D,F]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?f(a):null)??e+t++,t=>{wa.test(t)&&y(a)<1e3&&N(a,t)}]})(),s=sa();return[(n,o,r,i=[],c=()=>[])=>{a??=k;const l=t(1);return ia(s,l,[n,o,r,i,c]),P(la(o,r??[e],_),l),l},(t,n,...o)=>v(((a,t=[e])=>{const n=[],s=(a,e)=>e==y(t)?N(n,a):null===t[e]?aa(a,(a=>s(a,e+1))):v([t[e],null],(t=>s(oa(a,t),e+1)));return s(a,0),n})(t,n),(t=>aa(t,(t=>oa(s,t)[0](a,...n??[],...o))))),a=>c(oa(s,a),(([,t,o])=>(la(t,o??[e],void 0,(t=>(ta(t,a),q(t)?1:0))),ia(s,a),n(a),o))),t=>c(oa(s,t),(([t,,e=[],n,s])=>{const o=(...r)=>{const c=y(r);c==y(e)?t(a,...r,...s(r)):i(e[c])?v(n[c]?.(...r)??[],(a=>o(...r,a))):o(...r,e[c])};o()}))]})(),U=a=>{a!=h&&(h=a,D(T,void 0,h))},j=t=>{(C&&w(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},x=async a=>(2!=h&&(U(1),m++,await Y((async()=>{try{const e=await t();w(e)?j(e):a?L(a):E("Content is not an array "+e)}catch(t){r?.(t),a&&L(a)}U(0)}))),k),B=()=>(p&&(o(p),p=void 0),k),H=async a=>(1!=h&&(U(2),S++,await Y((async()=>{try{await n(O,a)}catch(a){r?.(a)}U(0)}))),k),J=()=>(c(A,a.delListener),A=void 0,k),Y=async(...a)=>(N(oa(ya,d),...a),await(async()=>{if(!oa(ua,d)){for(ia(ua,d,1);!i(g=f(oa(ya,d)));)try{await g()}catch(a){r?.(a)}ia(ua,d,0)}})(),k),k={load:x,startAutoLoad:async a=>{await B().load(a);try{p=await s((async(a,t)=>{t||a?2!=h&&(U(1),m++,j(t??a),U(0)):await x()}))}catch(a){r?.(a)}return k},stopAutoLoad:B,isAutoLoading:()=>!i(p),save:H,startAutoSave:async()=>(await J().save(),A=a.addDidFinishTransactionListener((()=>{const a=b();I(a)&&H(a)})),k),stopAutoSave:J,isAutoSaving:()=>!i(A),getStatus:()=>h,addStatusListener:a=>R(a,T),delListener:t=>(F(t),a),schedule:Y,getStore:()=>a,destroy:()=>(oa(ya,d).splice(0,void 0),B().stopAutoSave()),getStats:()=>({loads:m,saves:S}),...u};return $(k)},Ea=(a,t,e,s,o,r=va,c,l)=>{const w=sa();return[async()=>{w.clear(),p(await e(a,t),(({tn:a,cn:t})=>P(ca(w,a,_),t)))},async(t,e)=>((a,t)=>X(oa(w,a),t))(t,e)?O(h(p(await a(Y+W(t)),(a=>{return[a[e],l?(t=I(a,e),n=l,O(L(t,((a,t)=>[t,n(a,t)])))):I(a,e)];var t,n})),(([a,t])=>!i(a)&&!M(t)))):{},async(t,e,s,l,u,y=!1)=>{const E=_();L(s??{},(a=>p(C(a??{}),(a=>P(E,a)))));const v=Z(E);if(!y&&u&&A(v)&&X(w,t))return await a("DROP "+B+W(t)),void ia(w,t);const f=oa(w,t),m=_(Z(f));if(A(v)||(X(w,t)?await d(p([e,...v],(async(n,s)=>{ta(m,n)||(await a(H+W(t)+"ADD"+W(n)+o),0==s&&await a("CREATE UNIQUE INDEX pk ON "+W(t)+`(${W(e)})`),P(f,n))}))):(await a("CREATE "+B+W(t)+`(${W(e)}${o} PRIMARY KEY${g(p(v,(a=>n+W(a)+o)))});`),ia(w,t,_([e,...v])))),await d([...!y&&l?p(Z(m),(async n=>{n!=e&&(await a(H+W(t)+"DROP"+W(n)),ta(f,n))})):[]]),y)i(s)?await a(J+W(t)+x+" true"):await d(L(s,(async(n,s)=>{i(n)?await a(J+W(t)+x+W(e)+"=$1",[s]):A(v)||await r(a,t,e,C(n),{[s]:c?p(R(n),c):R(n)},f)})));else if(A(v))X(w,t)&&await a(J+W(t)+x+" true");else{const n=h(Z(oa(w,t)),(a=>a!=e)),o={},i=[];L(s??{},((a,t)=>{o[t]=p(n,(t=>c?c(a?.[t]):a?.[t])),N(i,t)})),await r(a,t,e,n,o),await a(J+W(t)+x+W(e)+`NOT IN(${Q(i)})`,i)}},async t=>{let e;await a("BEGIN");try{e=await t()}catch(a){s?.(a)}return await a("END"),e}]},va=async(a,t,e,s,o)=>{const r=[1];await a("INSERT INTO"+W(t)+"("+K(e,...s)+")VALUES"+g(L(o,(a=>"($"+r[0]+++","+Q(a,r)+")")),n)+"ON CONFLICT("+W(e)+")DO UPDATE SET"+g(p(s,(a=>W(a)+"=excluded."+W(a))),n),L(o,((a,t)=>[t,...p(a,(a=>a??null))])).flat())},ga=(a,t,e,n,s,o,r,[i,c,l],w,u,y,d,E,v)=>{const[g,p,A,h]=Ea(t,w,u,s,E,v),N=da(a,(async()=>await h((async()=>{return await g(),a=(await p(i,c))[F]?.[l]??"null",na(a,((a,t)=>""===t?void 0:t));var a}))),(async a=>await h((async()=>{var t;await g(),await A(i,c,{[F]:{[l]:(t=a()??null,ea(t,((a,t)=>void 0===t?"":t)))}},!0,!0)}))),e,n,s,r,{[d]:()=>y,destroy:()=>(N.stopAutoLoad().stopAutoSave(),o(),N)},y);return N},pa=(a,t,e,n,s,o,r,[c,l,[w,u,y]],E,v,g,p,A,N,f,m)=>{const[S,T,C,$]=Ea(t,E,v,s,A,N,f,m),b=async(a,t)=>await d(ra(l,(async([e,n,s,o],r)=>{t&&!(r in a)||await C(e,n,a[r],s,o,t)}))),I=async(a,t)=>u?await C(y,U,{[F]:a},!0,!0,t):null,L=da(a,(async()=>await $((async()=>{await S();const a=await(async()=>O(h(await d(ra(c,(async([a,t],e)=>[a,await T(e,t)]))),(a=>!M(a[1])))))(),t=await(async()=>w?(await T(y,U))[F]:{})();return M(a)&&i(t)?void 0:[a,t]}))),(async(a,t)=>await $((async()=>{if(await S(),i(t)){const[t,e]=a();await b(t),await I(e)}else await b(t[0],!0),await I(t[1],!0)}))),e,n,s,r,{[p]:()=>g,destroy:()=>(L.stopAutoLoad().stopAutoSave(),o(),L)},g);return L},Aa="ColumnName",ha="store",Na="json",fa=ha+"TableName",ma=ha+"Id"+Aa,Sa=ha+Aa,Ta="autoLoadIntervalSeconds",Ca="rowId"+Aa,$a="tableId",Oa="tableName",ba="deleteEmptyColumns",Ia="deleteEmptyTable",La={mode:Na,[Ta]:1},Ra={load:0,save:0,[Oa]:t+"_values"},Da=(a,t,e,n,s)=>{const o=sa();return L(a,((a,r)=>{const c=u(R(b(t,l(a)?{[e]:a}:a)),0,D(t));i(c[0])||n(r,c[0])||(s(r,c[0]),ia(o,r,c))})),o},Ma=(a,n,s,o,i,c,w,y,d,E,v="getDb",g)=>{let p,A,h;const N=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,c),[f,m,S,T]=(a=>{const e=(a=>b(La,l(a)?{[fa]:a}:a??{}))(a),n=e[Ta];if(e.mode==Na){const a=e[fa]??t;return[1,n,[a,e[ma]??U,e[Sa]??ha],_(a)]}const{tables:{load:s={},save:o={}}={},values:r={}}=e,i=u(R(b(Ra,r)),0,D(Ra)),c=i[2],w=_(c),y=_(c);return[0,n,[Da(s,{[$a]:null,[Ca]:U},$a,(a=>X(y,a)),(a=>P(w,a))),Da(o,{[Oa]:null,[Ca]:U,[ba]:0,[Ia]:0},Oa,((a,t)=>X(y,t)),((a,t)=>P(w,t))),i],w]})(n);return(f?ga:pa)(a,N,(a=>{let t;const e=()=>t=setInterval((async()=>{try{const[{d:t,s:e,c:n}]=await N(`${j} ${z} d,${G} s,TOTAL_CHANGES() c FROM ${k}${z} JOIN ${k}${G}`);t==p&&e==A&&n==h||(null!=p&&a(),p=t,A=e,h=n)}catch{}}),1e3*m),n=()=>{p=A=h=null,r(t)},s=o((t=>{T.has(t)&&(n(),a(),e())}));return e(),()=>{n(),i(s)}}),(a=>a()),w,y,d,S,Z(T),(async(a,t)=>await a(`${j} t.name tn,c.name cn FROM ${V}list()t,${V}info(t.name)c ${x} t.schema='main'AND t.type IN('table','view')AND t.name IN(${Q(t)})ORDER BY t.name,c.name`,t)),E,v,e,g,(a=>!0===a?1:!1===a?0:a),void 0)},_a=(a,t,e,n,s)=>{let o;return Ma(a,e,(async(a,e=[])=>t.execute(a,e).then((a=>a.rows?._array??[]))),(a=>{const e=new AbortController,n=t.onChange({rawTableNames:!0,signal:e.signal});return(async()=>{for await(const a of n)o&&p(a.changedTables,o)})(),o=a,e}),(a=>{o=void 0,a.abort()}),n,s,(()=>0),1,t,"getPowerSync",Pa)},Pa=async(a,t,e,s,o,r)=>{const i=[1],c=_(s),l=r?h([...r],(a=>a!=e&&!X(c,a))):[];if(!A(l)){const n=C(o),s=O(p(await a("SELECT"+K(e,...l)+"FROM"+W(t)+"WHERE"+W(e)+"IN("+Q(n)+")",n),(a=>[a[e],a])));v(n,(a=>N(o[a],...p(l,(t=>s?.[a]?.[t]??null)))))}await a("INSERT OR REPLACE INTO"+W(t)+"("+K(e,...s,...l)+")VALUES"+g(L(o,(a=>"($"+i[0]+++","+Q(a,i)+")")),n),L(o,((a,t)=>[t,...p(a,(a=>a??null))])).flat())};export{_a as createPowerSyncPersister};
|
|
1
|
+
const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),o=Promise,r=clearInterval,i=a=>null==a,c=(a,t,e)=>i(a)?e?.():t(a),l=t=>a(t)==s,w=a=>Array.isArray(a),u=(a,t,e)=>a.slice(t,e),y=a=>a.length,d=async a=>o.all(a),E=a=>{throw Error(a)},v=(a,t)=>a.forEach(t),g=(a,t="")=>a.join(t),p=(a,t)=>a.map(t),A=a=>0==y(a),h=(a,t)=>a.filter(t),N=(a,...t)=>a.push(...t),f=a=>a.shift(),m=Object,S=a=>m.getPrototypeOf(a),T=m.entries,C=m.keys,$=m.freeze,O=(a=[])=>m.fromEntries(a),b=(...a)=>m.assign({},...a),I=(a,t)=>(delete a[t],a),L=(a,t)=>p(T(a),(([a,e])=>t(e,a))),R=a=>m.values(a),D=a=>y(C(a)),M=a=>(a=>!i(a)&&c(S(a),(a=>a==m.prototype||i(S(a))),(()=>!0)))(a)&&0==D(a),_=a=>new Set(w(a)||i(a)?a:[a]),P=(a,t)=>a?.add(t),F="_",U="_id",j="SELECT",x="WHERE",B="TABLE",H="ALTER "+B,J="DELETE FROM",Y=j+"*FROM",k="pragma_",z="data_version",G="schema_version",V="pragma_table_",W=a=>`"${a.replace(/"/g,'""')}"`,K=(...a)=>g(p(a,W),n),Q=(a,t=[1])=>g(p(a,(()=>"$"+t[0]++)),n),X=(a,t)=>a?.has(t)??!1,q=a=>i(a)||0==(a=>a?.size??0)(a),Z=a=>[...a?.values()??[]],aa=(a,t)=>a?.forEach(t),ta=(a,t)=>a?.delete(t),ea=JSON.stringify,na=JSON.parse,sa=a=>new Map(a),oa=(a,t)=>a?.get(t),ra=(a,t)=>p([...a?.entries()??[]],(([a,e])=>t(e,a))),ia=(a,t,e)=>i(e)?(ta(a,t),a):a?.set(t,e),ca=(a,t,e,n)=>(X(a,t)?n?.(oa(a,t)):ia(a,t,e()),oa(a,t)),la=(a,t,e,n,s=0)=>c((e?ca:oa)(a,t[s],s>y(t)-2?e:sa),(o=>{if(s>y(t)-2)return n?.(o)&&ia(a,t[s]),o;const r=la(o,t,e,n,s+1);return q(o)&&ia(a,t[s]),r})),wa=/^\d+$/,ua=sa(),ya=sa(),da=(a,t,n,s,o,r,l,u={},d=[])=>{let g,p,A,h=0,m=0,S=0;ca(ua,d,(()=>0)),ca(ya,d,(()=>[]));const T=sa(),[C,O,b,I,L]=((a=1,t)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,t.getTransactionMergeableChanges,([[a],[t]])=>!M(a)||!M(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!M(a)||!M(t),t.setContent]:E("Store type not supported by this Persister"))(l,a),[R,D,F]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?f(a):null)??e+t++,t=>{wa.test(t)&&y(a)<1e3&&N(a,t)}]})(),s=sa();return[(n,o,r,i=[],c=()=>[])=>{a??=k;const l=t(1);return ia(s,l,[n,o,r,i,c]),P(la(o,r??[e],_),l),l},(t,n,...o)=>v(((a,t=[e])=>{const n=[],s=(a,e)=>e==y(t)?N(n,a):null===t[e]?aa(a,(a=>s(a,e+1))):v([t[e],null],(t=>s(oa(a,t),e+1)));return s(a,0),n})(t,n),(t=>aa(t,(t=>oa(s,t)[0](a,...n??[],...o))))),a=>c(oa(s,a),(([,t,o])=>(la(t,o??[e],void 0,(t=>(ta(t,a),q(t)?1:0))),ia(s,a),n(a),o))),t=>c(oa(s,t),(([t,,e=[],n,s])=>{const o=(...r)=>{const c=y(r);c==y(e)?t(a,...r,...s(r)):i(e[c])?v(n[c]?.(...r)??[],(a=>o(...r,a))):o(...r,e[c])};o()}))]})(),U=a=>{a!=h&&(h=a,D(T,void 0,h))},j=t=>{(C&&w(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},x=async a=>(2!=h&&(U(1),m++,await Y((async()=>{try{const e=await t();w(e)?j(e):a?L(a):E("Content is not an array: "+e)}catch(t){r?.(t),a&&L(a)}U(0)}))),k),B=()=>(p&&(o(p),p=void 0),k),H=async a=>(1!=h&&(U(2),S++,await Y((async()=>{try{await n(O,a)}catch(a){r?.(a)}U(0)}))),k),J=()=>(c(A,a.delListener),A=void 0,k),Y=async(...a)=>(N(oa(ya,d),...a),await(async()=>{if(!oa(ua,d)){for(ia(ua,d,1);!i(g=f(oa(ya,d)));)try{await g()}catch(a){r?.(a)}ia(ua,d,0)}})(),k),k={load:x,startAutoLoad:async a=>{await B().load(a);try{p=await s((async(a,t)=>{t||a?2!=h&&(U(1),m++,j(t??a),U(0)):await x()}))}catch(a){r?.(a)}return k},stopAutoLoad:B,isAutoLoading:()=>!i(p),save:H,startAutoSave:async()=>(await J().save(),A=a.addDidFinishTransactionListener((()=>{const a=b();I(a)&&H(a)})),k),stopAutoSave:J,isAutoSaving:()=>!i(A),getStatus:()=>h,addStatusListener:a=>R(a,T),delListener:t=>(F(t),a),schedule:Y,getStore:()=>a,destroy:()=>(oa(ya,d).splice(0,void 0),B().stopAutoSave()),getStats:()=>({loads:m,saves:S}),...u};return $(k)},Ea=(a,t,e,s,o,r=va,c,l)=>{const w=sa();return[async()=>{w.clear(),p(await e(a,t),(({tn:a,cn:t})=>P(ca(w,a,_),t)))},async(t,e)=>((a,t)=>X(oa(w,a),t))(t,e)?O(h(p(await a(Y+W(t)),(a=>{return[a[e],l?(t=I(a,e),n=l,O(L(t,((a,t)=>[t,n(a,t)])))):I(a,e)];var t,n})),(([a,t])=>!i(a)&&!M(t)))):{},async(t,e,s,l,u,y=!1)=>{const E=_();L(s??{},(a=>p(C(a??{}),(a=>P(E,a)))));const v=Z(E);if(!y&&u&&A(v)&&X(w,t))return await a("DROP "+B+W(t)),void ia(w,t);const f=oa(w,t),m=_(Z(f));if(A(v)||(X(w,t)?await d(p([e,...v],(async(n,s)=>{ta(m,n)||(await a(H+W(t)+"ADD"+W(n)+o),0==s&&await a("CREATE UNIQUE INDEX pk ON "+W(t)+`(${W(e)})`),P(f,n))}))):(await a("CREATE "+B+W(t)+`(${W(e)}${o} PRIMARY KEY${g(p(v,(a=>n+W(a)+o)))});`),ia(w,t,_([e,...v])))),await d([...!y&&l?p(Z(m),(async n=>{n!=e&&(await a(H+W(t)+"DROP"+W(n)),ta(f,n))})):[]]),y)i(s)?await a(J+W(t)+x+" true"):await d(L(s,(async(n,s)=>{i(n)?await a(J+W(t)+x+W(e)+"=$1",[s]):A(v)||await r(a,t,e,C(n),{[s]:c?p(R(n),c):R(n)},f)})));else if(A(v))X(w,t)&&await a(J+W(t)+x+" true");else{const n=h(Z(oa(w,t)),(a=>a!=e)),o={},i=[];L(s??{},((a,t)=>{o[t]=p(n,(t=>c?c(a?.[t]):a?.[t])),N(i,t)})),await r(a,t,e,n,o),await a(J+W(t)+x+W(e)+`NOT IN(${Q(i)})`,i)}},async t=>{let e;await a("BEGIN");try{e=await t()}catch(a){s?.(a)}return await a("END"),e}]},va=async(a,t,e,s,o)=>{const r=[1];await a("INSERT INTO"+W(t)+"("+K(e,...s)+")VALUES"+g(L(o,(a=>"($"+r[0]+++","+Q(a,r)+")")),n)+"ON CONFLICT("+W(e)+")DO UPDATE SET"+g(p(s,(a=>W(a)+"=excluded."+W(a))),n),L(o,((a,t)=>[t,...p(a,(a=>a??null))])).flat())},ga=(a,t,e,n,s,o,r,[i,c,l],w,u,y,d,E,v)=>{const[g,p,A,h]=Ea(t,w,u,s,E,v),N=da(a,(async()=>await h((async()=>{return await g(),a=(await p(i,c))[F]?.[l]??"null",na(a,((a,t)=>""===t?void 0:t));var a}))),(async a=>await h((async()=>{var t;await g(),await A(i,c,{[F]:{[l]:(t=a()??null,ea(t,((a,t)=>void 0===t?"":t)))}},!0,!0)}))),e,n,s,r,{[d]:()=>y,destroy:()=>(N.stopAutoLoad().stopAutoSave(),o(),N)},y);return N},pa=(a,t,e,n,s,o,r,[c,l,[w,u,y]],E,v,g,p,A,N,f,m)=>{const[S,T,C,$]=Ea(t,E,v,s,A,N,f,m),b=async(a,t)=>await d(ra(l,(async([e,n,s,o],r)=>{t&&!(r in a)||await C(e,n,a[r],s,o,t)}))),I=async(a,t)=>u?await C(y,U,{[F]:a},!0,!0,t):null,L=da(a,(async()=>await $((async()=>{await S();const a=await(async()=>O(h(await d(ra(c,(async([a,t],e)=>[a,await T(e,t)]))),(a=>!M(a[1])))))(),t=await(async()=>w?(await T(y,U))[F]:{})();return M(a)&&i(t)?void 0:[a,t]}))),(async(a,t)=>await $((async()=>{if(await S(),i(t)){const[t,e]=a();await b(t),await I(e)}else await b(t[0],!0),await I(t[1],!0)}))),e,n,s,r,{[p]:()=>g,destroy:()=>(L.stopAutoLoad().stopAutoSave(),o(),L)},g);return L},Aa="ColumnName",ha="store",Na="json",fa=ha+"TableName",ma=ha+"Id"+Aa,Sa=ha+Aa,Ta="autoLoadIntervalSeconds",Ca="rowId"+Aa,$a="tableId",Oa="tableName",ba="deleteEmptyColumns",Ia="deleteEmptyTable",La={mode:Na,[Ta]:1},Ra={load:0,save:0,[Oa]:t+"_values"},Da=(a,t,e,n,s)=>{const o=sa();return L(a,((a,r)=>{const c=u(R(b(t,l(a)?{[e]:a}:a)),0,D(t));i(c[0])||n(r,c[0])||(s(r,c[0]),ia(o,r,c))})),o},Ma=(a,n,s,o,i,c,w,y,d,E,v="getDb",g)=>{let p,A,h;const N=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,c),[f,m,S,T]=(a=>{const e=(a=>b(La,l(a)?{[fa]:a}:a??{}))(a),n=e[Ta];if(e.mode==Na){const a=e[fa]??t;return[1,n,[a,e[ma]??U,e[Sa]??ha],_(a)]}const{tables:{load:s={},save:o={}}={},values:r={}}=e,i=u(R(b(Ra,r)),0,D(Ra)),c=i[2],w=_(c),y=_(c);return[0,n,[Da(s,{[$a]:null,[Ca]:U},$a,(a=>X(y,a)),(a=>P(w,a))),Da(o,{[Oa]:null,[Ca]:U,[ba]:0,[Ia]:0},Oa,((a,t)=>X(y,t)),((a,t)=>P(w,t))),i],w]})(n);return(f?ga:pa)(a,N,(a=>{let t;const e=()=>t=setInterval((async()=>{try{const[{d:t,s:e,c:n}]=await N(`${j} ${z} d,${G} s,TOTAL_CHANGES() c FROM ${k}${z} JOIN ${k}${G}`);t==p&&e==A&&n==h||(null!=p&&a(),p=t,A=e,h=n)}catch{}}),1e3*m),n=()=>{p=A=h=null,r(t)},s=o((t=>{T.has(t)&&(n(),a(),e())}));return e(),()=>{n(),i(s)}}),(a=>a()),w,y,d,S,Z(T),(async(a,t)=>await a(`${j} t.name tn,c.name cn FROM ${V}list()t,${V}info(t.name)c ${x} t.schema='main'AND t.type IN('table','view')AND t.name IN(${Q(t)})ORDER BY t.name,c.name`,t)),E,v,e,g,(a=>!0===a?1:!1===a?0:a),void 0)},_a=(a,t,e,n,s)=>{let o;return Ma(a,e,(async(a,e=[])=>t.execute(a,e).then((a=>a.rows?._array??[]))),(a=>{const e=new AbortController,n=t.onChange({rawTableNames:!0,signal:e.signal});return(async()=>{for await(const a of n)o&&p(a.changedTables,o)})(),o=a,e}),(a=>{o=void 0,a.abort()}),n,s,(()=>0),1,t,"getPowerSync",Pa)},Pa=async(a,t,e,s,o,r)=>{const i=[1],c=_(s),l=r?h([...r],(a=>a!=e&&!X(c,a))):[];if(!A(l)){const n=C(o),s=O(p(await a("SELECT"+K(e,...l)+"FROM"+W(t)+"WHERE"+W(e)+"IN("+Q(n)+")",n),(a=>[a[e],a])));v(n,(a=>N(o[a],...p(l,(t=>s?.[a]?.[t]??null)))))}await a("INSERT OR REPLACE INTO"+W(t)+"("+K(e,...s,...l)+")VALUES"+g(L(o,(a=>"($"+i[0]+++","+Q(a,i)+")")),n),L(o,((a,t)=>[t,...p(a,(a=>a??null))])).flat())};export{_a as createPowerSyncPersister};
|
|
Binary file
|
|
@@ -1 +1 @@
|
|
|
1
|
-
const t=clearInterval,e=t=>null==t,a=(t,a,n)=>e(t)?n?.():a(t),n=t=>Array.isArray(t),s=t=>t.length,r=t=>{throw Error(t)},o=(t,e)=>t.forEach(e),i=(t,...e)=>t.push(...e),c=t=>t.shift(),l=Object,d=t=>l.getPrototypeOf(t),y=l.keys,u=l.freeze,g=t=>(t=>!e(t)&&a(d(t),(t=>t==l.prototype||e(d(t))),(()=>!0)))(t)&&0==(t=>s(y(t)))(t),h=JSON.stringify,p=JSON.parse,v=t=>e(t)||0==(t=>t?.size??0)(t),w=(t,e)=>t?.forEach(e),f=(t,e)=>t?.delete(e),S=t=>new Map(t),C=(t,e)=>t?.get(e),A=(t,a,n)=>e(n)?(f(t,a),t):t?.set(a,n),b=(t,e,a,n)=>{var s,r;return s=t,r=e,s?.has(r)?n?.(C(t,e)):A(t,e,a()),C(t,e)},L=(t,e,n,r,o=0)=>a((n?b:C)(t,e[o],o>s(e)-2?n:S),(a=>{if(o>s(e)-2)return r?.(a)&&A(t,e[o]),a;const i=L(a,e,n,r,o+1);return v(a)&&A(t,e[o]),i})),M=t=>new Set(n(t)||e(t)?t:[t]),E=/^\d+$/,T=S(),O=S(),m=(t,l,d,y,h,p,m,D={},P=[])=>{let j,x,z,I=0,J=0,N=0;b(T,P,(()=>0)),b(O,P,(()=>[]));const k=S(),[F,H,U,$,q]=((t=1,e)=>1!=t&&e.isMergeable()?[1,e.getMergeableContent,e.getTransactionMergeableChanges,([[t],[e]])=>!g(t)||!g(e),e.setDefaultContent]:2!=t?[0,e.getContent,e.getTransactionChanges,([t,e])=>!g(t)||!g(e),e.setContent]:r("Store type not supported by this Persister"))(m,t),[B,G,K]=(()=>{let t;const[n,r]=(()=>{const t=[];let e=0;return[a=>(a?c(t):null)??""+e++,e=>{E.test(e)&&s(t)<1e3&&i(t,e)}]})(),l=S();return[(e,a,s,r=[],o=()=>[])=>{t??=_;const i=n(1);var c,d;return A(l,i,[e,a,s,r,o]),c=L(a,s??[""],M),d=i,c?.add(d),i},(e,a,...n)=>o(((t,e=[""])=>{const a=[],n=(t,r)=>r==s(e)?i(a,t):null===e[r]?w(t,(t=>n(t,r+1))):o([e[r],null],(e=>n(C(t,e),r+1)));return n(t,0),a})(e,a),(e=>w(e,(e=>C(l,e)[0](t,...a??[],...n))))),t=>a(C(l,t),(([,e,a])=>(L(e,a??[""],void 0,(e=>(f(e,t),v(e)?1:0))),A(l,t),r(t),a))),n=>a(C(l,n),(([a,,n=[],r,i])=>{const c=(...l)=>{const d=s(l);d==s(n)?a(t,...l,...i(l)):e(n[d])?o(r[d]?.(...l)??[],(t=>c(...l,t))):c(...l,n[d])};c()}))]})(),Q=t=>{t!=I&&(I=t,G(k,void 0,I))},R=e=>{(F&&n(e?.[0])?1===e?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===e?.[2]?t.applyChanges:t.setContent)(e)},V=async t=>(2!=I&&(Q(1),J++,await Z((async()=>{try{const e=await l();n(e)?R(e):t?q(t):r("Content is not an array "+e)}catch(e){p?.(e),t&&q(t)}Q(0)}))),_),W=()=>(x&&(h(x),x=void 0),_),X=async t=>(1!=I&&(Q(2),N++,await Z((async()=>{try{await d(H,t)}catch(t){p?.(t)}Q(0)}))),_),Y=()=>(a(z,t.delListener),z=void 0,_),Z=async(...t)=>(i(C(O,P),...t),await(async()=>{if(!C(T,P)){for(A(T,P,1);!e(j=c(C(O,P)));)try{await j()}catch(t){p?.(t)}A(T,P,0)}})(),_),_={load:V,startAutoLoad:async t=>{await W().load(t);try{x=await y((async(t,e)=>{e||t?2!=I&&(Q(1),J++,R(e??t),Q(0)):await V()}))}catch(t){p?.(t)}return _},stopAutoLoad:W,isAutoLoading:()=>!e(x),save:X,startAutoSave:async()=>(await Y().save(),z=t.addDidFinishTransactionListener((()=>{const t=U();$(t)&&X(t)})),_),stopAutoSave:Y,isAutoSaving:()=>!e(z),getStatus:()=>I,addStatusListener:t=>B(t,k),delListener:e=>(K(e),t),schedule:Z,getStore:()=>t,destroy:()=>(C(O,P).splice(0,void 0),W().stopAutoSave()),getStats:()=>({loads:J,saves:N}),...D};return u(_)},D=t=>t.headers.get("ETag"),P=(a,n,s,r=5,o)=>{let i;return m(a,(async()=>{const t=await fetch(n);return i=D(t),p(await t.text())}),(async t=>{return await fetch(s,{method:"POST",headers:{"Content-Type":"application/json"},body:(e=t(),h(e,((t,e)=>e instanceof Map?l.fromEntries([...e]):e)))});var e}),(t=>setInterval((async()=>{const a=await fetch(n,{method:"HEAD"}),s=D(a);e(i)||e(s)||s==i||(i=s,t())}),1e3*r)),(e=>t(e)),o,1,{getUrls:()=>[n,s]})};export{P as createRemotePersister};
|
|
1
|
+
const t=clearInterval,e=t=>null==t,a=(t,a,n)=>e(t)?n?.():a(t),n=t=>Array.isArray(t),s=t=>t.length,r=t=>{throw Error(t)},o=(t,e)=>t.forEach(e),i=(t,...e)=>t.push(...e),c=t=>t.shift(),l=Object,d=t=>l.getPrototypeOf(t),y=l.keys,u=l.freeze,g=t=>(t=>!e(t)&&a(d(t),(t=>t==l.prototype||e(d(t))),(()=>!0)))(t)&&0==(t=>s(y(t)))(t),h=JSON.stringify,p=JSON.parse,v=t=>e(t)||0==(t=>t?.size??0)(t),w=(t,e)=>t?.forEach(e),f=(t,e)=>t?.delete(e),S=t=>new Map(t),C=(t,e)=>t?.get(e),A=(t,a,n)=>e(n)?(f(t,a),t):t?.set(a,n),b=(t,e,a,n)=>{var s,r;return s=t,r=e,s?.has(r)?n?.(C(t,e)):A(t,e,a()),C(t,e)},L=(t,e,n,r,o=0)=>a((n?b:C)(t,e[o],o>s(e)-2?n:S),(a=>{if(o>s(e)-2)return r?.(a)&&A(t,e[o]),a;const i=L(a,e,n,r,o+1);return v(a)&&A(t,e[o]),i})),M=t=>new Set(n(t)||e(t)?t:[t]),E=/^\d+$/,T=S(),O=S(),m=(t,l,d,y,h,p,m,D={},P=[])=>{let j,x,z,I=0,J=0,N=0;b(T,P,(()=>0)),b(O,P,(()=>[]));const k=S(),[F,H,U,$,q]=((t=1,e)=>1!=t&&e.isMergeable()?[1,e.getMergeableContent,e.getTransactionMergeableChanges,([[t],[e]])=>!g(t)||!g(e),e.setDefaultContent]:2!=t?[0,e.getContent,e.getTransactionChanges,([t,e])=>!g(t)||!g(e),e.setContent]:r("Store type not supported by this Persister"))(m,t),[B,G,K]=(()=>{let t;const[n,r]=(()=>{const t=[];let e=0;return[a=>(a?c(t):null)??""+e++,e=>{E.test(e)&&s(t)<1e3&&i(t,e)}]})(),l=S();return[(e,a,s,r=[],o=()=>[])=>{t??=_;const i=n(1);var c,d;return A(l,i,[e,a,s,r,o]),c=L(a,s??[""],M),d=i,c?.add(d),i},(e,a,...n)=>o(((t,e=[""])=>{const a=[],n=(t,r)=>r==s(e)?i(a,t):null===e[r]?w(t,(t=>n(t,r+1))):o([e[r],null],(e=>n(C(t,e),r+1)));return n(t,0),a})(e,a),(e=>w(e,(e=>C(l,e)[0](t,...a??[],...n))))),t=>a(C(l,t),(([,e,a])=>(L(e,a??[""],void 0,(e=>(f(e,t),v(e)?1:0))),A(l,t),r(t),a))),n=>a(C(l,n),(([a,,n=[],r,i])=>{const c=(...l)=>{const d=s(l);d==s(n)?a(t,...l,...i(l)):e(n[d])?o(r[d]?.(...l)??[],(t=>c(...l,t))):c(...l,n[d])};c()}))]})(),Q=t=>{t!=I&&(I=t,G(k,void 0,I))},R=e=>{(F&&n(e?.[0])?1===e?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===e?.[2]?t.applyChanges:t.setContent)(e)},V=async t=>(2!=I&&(Q(1),J++,await Z((async()=>{try{const e=await l();n(e)?R(e):t?q(t):r("Content is not an array: "+e)}catch(e){p?.(e),t&&q(t)}Q(0)}))),_),W=()=>(x&&(h(x),x=void 0),_),X=async t=>(1!=I&&(Q(2),N++,await Z((async()=>{try{await d(H,t)}catch(t){p?.(t)}Q(0)}))),_),Y=()=>(a(z,t.delListener),z=void 0,_),Z=async(...t)=>(i(C(O,P),...t),await(async()=>{if(!C(T,P)){for(A(T,P,1);!e(j=c(C(O,P)));)try{await j()}catch(t){p?.(t)}A(T,P,0)}})(),_),_={load:V,startAutoLoad:async t=>{await W().load(t);try{x=await y((async(t,e)=>{e||t?2!=I&&(Q(1),J++,R(e??t),Q(0)):await V()}))}catch(t){p?.(t)}return _},stopAutoLoad:W,isAutoLoading:()=>!e(x),save:X,startAutoSave:async()=>(await Y().save(),z=t.addDidFinishTransactionListener((()=>{const t=U();$(t)&&X(t)})),_),stopAutoSave:Y,isAutoSaving:()=>!e(z),getStatus:()=>I,addStatusListener:t=>B(t,k),delListener:e=>(K(e),t),schedule:Z,getStore:()=>t,destroy:()=>(C(O,P).splice(0,void 0),W().stopAutoSave()),getStats:()=>({loads:J,saves:N}),...D};return u(_)},D=t=>t.headers.get("ETag"),P=(a,n,s,r=5,o)=>{let i;return m(a,(async()=>{const t=await fetch(n);return i=D(t),p(await t.text())}),(async t=>{return await fetch(s,{method:"POST",headers:{"Content-Type":"application/json"},body:(e=t(),h(e,((t,e)=>e instanceof Map?l.fromEntries([...e]):e)))});var e}),(t=>setInterval((async()=>{const a=await fetch(n,{method:"HEAD"}),s=D(a);e(i)||e(s)||s==i||(i=s,t())}),1e3*r)),(e=>t(e)),o,1,{getUrls:()=>[n,s]})};export{P as createRemotePersister};
|
|
Binary file
|
|
@@ -1 +1 @@
|
|
|
1
|
-
const t=clearInterval,e=t=>null==t,a=(t,a,n)=>e(t)?n?.():a(t),n=t=>Array.isArray(t),s=t=>t.length,r=t=>{throw Error(t)},o=(t,e)=>t.forEach(e),i=(t,...e)=>t.push(...e),c=t=>t.shift(),l=Object,d=t=>l.getPrototypeOf(t),y=l.keys,u=l.freeze,g=t=>(t=>!e(t)&&a(d(t),(t=>t==l.prototype||e(d(t))),(()=>!0)))(t)&&0==(t=>s(y(t)))(t),h=JSON.stringify,p=JSON.parse,v=t=>e(t)||0==(t=>t?.size??0)(t),w=(t,e)=>t?.forEach(e),f=(t,e)=>t?.delete(e),S=t=>new Map(t),C=(t,e)=>t?.get(e),A=(t,a,n)=>e(n)?(f(t,a),t):t?.set(a,n),b=(t,e,a,n)=>{var s,r;return s=t,r=e,s?.has(r)?n?.(C(t,e)):A(t,e,a()),C(t,e)},L=(t,e,n,r,o=0)=>a((n?b:C)(t,e[o],o>s(e)-2?n:S),(a=>{if(o>s(e)-2)return r?.(a)&&A(t,e[o]),a;const i=L(a,e,n,r,o+1);return v(a)&&A(t,e[o]),i})),M=t=>new Set(n(t)||e(t)?t:[t]),E=/^\d+$/,T=S(),O=S(),m=(t,l,d,y,h,p,m,D={},P=[])=>{let j,x,z,I=0,J=0,N=0;b(T,P,(()=>0)),b(O,P,(()=>[]));const k=S(),[F,H,U,$,q]=((t=1,e)=>1!=t&&e.isMergeable()?[1,e.getMergeableContent,e.getTransactionMergeableChanges,([[t],[e]])=>!g(t)||!g(e),e.setDefaultContent]:2!=t?[0,e.getContent,e.getTransactionChanges,([t,e])=>!g(t)||!g(e),e.setContent]:r("Store type not supported by this Persister"))(m,t),[B,G,K]=(()=>{let t;const[n,r]=(()=>{const t=[];let e=0;return[a=>(a?c(t):null)??""+e++,e=>{E.test(e)&&s(t)<1e3&&i(t,e)}]})(),l=S();return[(e,a,s,r=[],o=()=>[])=>{t??=_;const i=n(1);var c,d;return A(l,i,[e,a,s,r,o]),c=L(a,s??[""],M),d=i,c?.add(d),i},(e,a,...n)=>o(((t,e=[""])=>{const a=[],n=(t,r)=>r==s(e)?i(a,t):null===e[r]?w(t,(t=>n(t,r+1))):o([e[r],null],(e=>n(C(t,e),r+1)));return n(t,0),a})(e,a),(e=>w(e,(e=>C(l,e)[0](t,...a??[],...n))))),t=>a(C(l,t),(([,e,a])=>(L(e,a??[""],void 0,(e=>(f(e,t),v(e)?1:0))),A(l,t),r(t),a))),n=>a(C(l,n),(([a,,n=[],r,i])=>{const c=(...l)=>{const d=s(l);d==s(n)?a(t,...l,...i(l)):e(n[d])?o(r[d]?.(...l)??[],(t=>c(...l,t))):c(...l,n[d])};c()}))]})(),Q=t=>{t!=I&&(I=t,G(k,void 0,I))},R=e=>{(F&&n(e?.[0])?1===e?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===e?.[2]?t.applyChanges:t.setContent)(e)},V=async t=>(2!=I&&(Q(1),J++,await Z((async()=>{try{const e=await l();n(e)?R(e):t?q(t):r("Content is not an array "+e)}catch(e){p?.(e),t&&q(t)}Q(0)}))),_),W=()=>(x&&(h(x),x=void 0),_),X=async t=>(1!=I&&(Q(2),N++,await Z((async()=>{try{await d(H,t)}catch(t){p?.(t)}Q(0)}))),_),Y=()=>(a(z,t.delListener),z=void 0,_),Z=async(...t)=>(i(C(O,P),...t),await(async()=>{if(!C(T,P)){for(A(T,P,1);!e(j=c(C(O,P)));)try{await j()}catch(t){p?.(t)}A(T,P,0)}})(),_),_={load:V,startAutoLoad:async t=>{await W().load(t);try{x=await y((async(t,e)=>{e||t?2!=I&&(Q(1),J++,R(e??t),Q(0)):await V()}))}catch(t){p?.(t)}return _},stopAutoLoad:W,isAutoLoading:()=>!e(x),save:X,startAutoSave:async()=>(await Y().save(),z=t.addDidFinishTransactionListener((()=>{const t=U();$(t)&&X(t)})),_),stopAutoSave:Y,isAutoSaving:()=>!e(z),getStatus:()=>I,addStatusListener:t=>B(t,k),delListener:e=>(K(e),t),schedule:Z,getStore:()=>t,destroy:()=>(C(O,P).splice(0,void 0),W().stopAutoSave()),getStats:()=>({loads:J,saves:N}),...D};return u(_)},D=t=>t.headers.get("ETag"),P=(a,n,s,r=5,o)=>{let i;return m(a,(async()=>{const t=await fetch(n);return i=D(t),p(await t.text())}),(async t=>{return await fetch(s,{method:"POST",headers:{"Content-Type":"application/json"},body:(e=t(),h(e,((t,e)=>e instanceof Map?l.fromEntries([...e]):e)))});var e}),(t=>setInterval((async()=>{const a=await fetch(n,{method:"HEAD"}),s=D(a);e(i)||e(s)||s==i||(i=s,t())}),1e3*r)),(e=>t(e)),o,1,{getUrls:()=>[n,s]})};export{P as createRemotePersister};
|
|
1
|
+
const t=clearInterval,e=t=>null==t,a=(t,a,n)=>e(t)?n?.():a(t),n=t=>Array.isArray(t),s=t=>t.length,r=t=>{throw Error(t)},o=(t,e)=>t.forEach(e),i=(t,...e)=>t.push(...e),c=t=>t.shift(),l=Object,d=t=>l.getPrototypeOf(t),y=l.keys,u=l.freeze,g=t=>(t=>!e(t)&&a(d(t),(t=>t==l.prototype||e(d(t))),(()=>!0)))(t)&&0==(t=>s(y(t)))(t),h=JSON.stringify,p=JSON.parse,v=t=>e(t)||0==(t=>t?.size??0)(t),w=(t,e)=>t?.forEach(e),f=(t,e)=>t?.delete(e),S=t=>new Map(t),C=(t,e)=>t?.get(e),A=(t,a,n)=>e(n)?(f(t,a),t):t?.set(a,n),b=(t,e,a,n)=>{var s,r;return s=t,r=e,s?.has(r)?n?.(C(t,e)):A(t,e,a()),C(t,e)},L=(t,e,n,r,o=0)=>a((n?b:C)(t,e[o],o>s(e)-2?n:S),(a=>{if(o>s(e)-2)return r?.(a)&&A(t,e[o]),a;const i=L(a,e,n,r,o+1);return v(a)&&A(t,e[o]),i})),M=t=>new Set(n(t)||e(t)?t:[t]),E=/^\d+$/,T=S(),O=S(),m=(t,l,d,y,h,p,m,D={},P=[])=>{let j,x,z,I=0,J=0,N=0;b(T,P,(()=>0)),b(O,P,(()=>[]));const k=S(),[F,H,U,$,q]=((t=1,e)=>1!=t&&e.isMergeable()?[1,e.getMergeableContent,e.getTransactionMergeableChanges,([[t],[e]])=>!g(t)||!g(e),e.setDefaultContent]:2!=t?[0,e.getContent,e.getTransactionChanges,([t,e])=>!g(t)||!g(e),e.setContent]:r("Store type not supported by this Persister"))(m,t),[B,G,K]=(()=>{let t;const[n,r]=(()=>{const t=[];let e=0;return[a=>(a?c(t):null)??""+e++,e=>{E.test(e)&&s(t)<1e3&&i(t,e)}]})(),l=S();return[(e,a,s,r=[],o=()=>[])=>{t??=_;const i=n(1);var c,d;return A(l,i,[e,a,s,r,o]),c=L(a,s??[""],M),d=i,c?.add(d),i},(e,a,...n)=>o(((t,e=[""])=>{const a=[],n=(t,r)=>r==s(e)?i(a,t):null===e[r]?w(t,(t=>n(t,r+1))):o([e[r],null],(e=>n(C(t,e),r+1)));return n(t,0),a})(e,a),(e=>w(e,(e=>C(l,e)[0](t,...a??[],...n))))),t=>a(C(l,t),(([,e,a])=>(L(e,a??[""],void 0,(e=>(f(e,t),v(e)?1:0))),A(l,t),r(t),a))),n=>a(C(l,n),(([a,,n=[],r,i])=>{const c=(...l)=>{const d=s(l);d==s(n)?a(t,...l,...i(l)):e(n[d])?o(r[d]?.(...l)??[],(t=>c(...l,t))):c(...l,n[d])};c()}))]})(),Q=t=>{t!=I&&(I=t,G(k,void 0,I))},R=e=>{(F&&n(e?.[0])?1===e?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===e?.[2]?t.applyChanges:t.setContent)(e)},V=async t=>(2!=I&&(Q(1),J++,await Z((async()=>{try{const e=await l();n(e)?R(e):t?q(t):r("Content is not an array: "+e)}catch(e){p?.(e),t&&q(t)}Q(0)}))),_),W=()=>(x&&(h(x),x=void 0),_),X=async t=>(1!=I&&(Q(2),N++,await Z((async()=>{try{await d(H,t)}catch(t){p?.(t)}Q(0)}))),_),Y=()=>(a(z,t.delListener),z=void 0,_),Z=async(...t)=>(i(C(O,P),...t),await(async()=>{if(!C(T,P)){for(A(T,P,1);!e(j=c(C(O,P)));)try{await j()}catch(t){p?.(t)}A(T,P,0)}})(),_),_={load:V,startAutoLoad:async t=>{await W().load(t);try{x=await y((async(t,e)=>{e||t?2!=I&&(Q(1),J++,R(e??t),Q(0)):await V()}))}catch(t){p?.(t)}return _},stopAutoLoad:W,isAutoLoading:()=>!e(x),save:X,startAutoSave:async()=>(await Y().save(),z=t.addDidFinishTransactionListener((()=>{const t=U();$(t)&&X(t)})),_),stopAutoSave:Y,isAutoSaving:()=>!e(z),getStatus:()=>I,addStatusListener:t=>B(t,k),delListener:e=>(K(e),t),schedule:Z,getStore:()=>t,destroy:()=>(C(O,P).splice(0,void 0),W().stopAutoSave()),getStats:()=>({loads:J,saves:N}),...D};return u(_)},D=t=>t.headers.get("ETag"),P=(a,n,s,r=5,o)=>{let i;return m(a,(async()=>{const t=await fetch(n);return i=D(t),p(await t.text())}),(async t=>{return await fetch(s,{method:"POST",headers:{"Content-Type":"application/json"},body:(e=t(),h(e,((t,e)=>e instanceof Map?l.fromEntries([...e]):e)))});var e}),(t=>setInterval((async()=>{const a=await fetch(n,{method:"HEAD"}),s=D(a);e(i)||e(s)||s==i||(i=s,t())}),1e3*r)),(e=>t(e)),o,1,{getUrls:()=>[n,s]})};export{P as createRemotePersister};
|
|
Binary file
|
|
@@ -1 +1 @@
|
|
|
1
|
-
const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),o=Promise,i=clearInterval,r=a=>null==a,c=(a,t,e)=>r(a)?e?.():t(a),l=t=>a(t)==s,u=a=>Array.isArray(a),w=(a,t,e)=>a.slice(t,e),y=a=>a.length,d=async a=>o.all(a),p=a=>{throw Error(a)},v=(a,t)=>a.forEach(t),E=(a,t="")=>a.join(t),g=(a,t)=>a.map(t),h=a=>0==y(a),A=(a,t)=>a.filter(t),m=(a,...t)=>a.push(...t),N=a=>a.shift(),$="_",f="_id",S="SELECT",C="WHERE",O="TABLE",T="ALTER "+O,b="DELETE FROM",I=S+"*FROM",L="pragma_",R="data_version",D="schema_version",_="pragma_table_",M=a=>`"${a.replace(/"/g,'""')}"`,P=(a,t=[1])=>E(g(a,(()=>"$"+t[0]++)),n),F=(a,t)=>a?.has(t)??!1,j=a=>r(a)||0==(a=>a?.size??0)(a),k=a=>[...a?.values()??[]],U=(a,t)=>a?.forEach(t),x=(a,t)=>a?.delete(t),B=Object,J=a=>B.getPrototypeOf(a),Y=B.entries,q=B.keys,z=B.freeze,G=(a=[])=>B.fromEntries(a),H=(...a)=>B.assign({},...a),V=(a,t)=>(delete a[t],a),K=(a,t)=>g(Y(a),(([a,e])=>t(e,a))),Q=a=>B.values(a),W=a=>y(q(a)),X=a=>(a=>!r(a)&&c(J(a),(a=>a==B.prototype||r(J(a))),(()=>!0)))(a)&&0==W(a),Z=JSON.stringify,aa=JSON.parse,ta=a=>new Map(a),ea=(a,t)=>a?.get(t),na=(a,t)=>g([...a?.entries()??[]],(([a,e])=>t(e,a))),sa=(a,t,e)=>r(e)?(x(a,t),a):a?.set(t,e),oa=(a,t,e,n)=>(F(a,t)?n?.(ea(a,t)):sa(a,t,e()),ea(a,t)),ia=(a,t,e,n,s=0)=>c((e?oa:ea)(a,t[s],s>y(t)-2?e:ta),(o=>{if(s>y(t)-2)return n?.(o)&&sa(a,t[s]),o;const i=ia(o,t,e,n,s+1);return j(o)&&sa(a,t[s]),i})),ra=a=>new Set(u(a)||r(a)?a:[a]),ca=(a,t)=>a?.add(t),la=/^\d+$/,ua=ta(),wa=ta(),ya=(a,t,n,s,o,i,l,w={},d=[])=>{let E,g,h,A=0,$=0,f=0;oa(ua,d,(()=>0)),oa(wa,d,(()=>[]));const S=ta(),[C,O,T,b,I]=((a=1,t)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,t.getTransactionMergeableChanges,([[a],[t]])=>!X(a)||!X(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!X(a)||!X(t),t.setContent]:p("Store type not supported by this Persister"))(l,a),[L,R,D]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?N(a):null)??e+t++,t=>{la.test(t)&&y(a)<1e3&&m(a,t)}]})(),s=ta();return[(n,o,i,r=[],c=()=>[])=>{a??=Y;const l=t(1);return sa(s,l,[n,o,i,r,c]),ca(ia(o,i??[e],ra),l),l},(t,n,...o)=>v(((a,t=[e])=>{const n=[],s=(a,e)=>e==y(t)?m(n,a):null===t[e]?U(a,(a=>s(a,e+1))):v([t[e],null],(t=>s(ea(a,t),e+1)));return s(a,0),n})(t,n),(t=>U(t,(t=>ea(s,t)[0](a,...n??[],...o))))),a=>c(ea(s,a),(([,t,o])=>(ia(t,o??[e],void 0,(t=>(x(t,a),j(t)?1:0))),sa(s,a),n(a),o))),t=>c(ea(s,t),(([t,,e=[],n,s])=>{const o=(...i)=>{const c=y(i);c==y(e)?t(a,...i,...s(i)):r(e[c])?v(n[c]?.(...i)??[],(a=>o(...i,a))):o(...i,e[c])};o()}))]})(),_=a=>{a!=A&&(A=a,R(S,void 0,A))},M=t=>{(C&&u(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},P=async a=>(2!=A&&(_(1),$++,await J((async()=>{try{const e=await t();u(e)?M(e):a?I(a):p("Content is not an array "+e)}catch(t){i?.(t),a&&I(a)}_(0)}))),Y),F=()=>(g&&(o(g),g=void 0),Y),k=async a=>(1!=A&&(_(2),f++,await J((async()=>{try{await n(O,a)}catch(a){i?.(a)}_(0)}))),Y),B=()=>(c(h,a.delListener),h=void 0,Y),J=async(...a)=>(m(ea(wa,d),...a),await(async()=>{if(!ea(ua,d)){for(sa(ua,d,1);!r(E=N(ea(wa,d)));)try{await E()}catch(a){i?.(a)}sa(ua,d,0)}})(),Y),Y={load:P,startAutoLoad:async a=>{await F().load(a);try{g=await s((async(a,t)=>{t||a?2!=A&&(_(1),$++,M(t??a),_(0)):await P()}))}catch(a){i?.(a)}return Y},stopAutoLoad:F,isAutoLoading:()=>!r(g),save:k,startAutoSave:async()=>(await B().save(),h=a.addDidFinishTransactionListener((()=>{const a=T();b(a)&&k(a)})),Y),stopAutoSave:B,isAutoSaving:()=>!r(h),getStatus:()=>A,addStatusListener:a=>L(a,S),delListener:t=>(D(t),a),schedule:J,getStore:()=>a,destroy:()=>(ea(wa,d).splice(0,void 0),F().stopAutoSave()),getStats:()=>({loads:$,saves:f}),...w};return z(Y)},da=(a,t,e,s,o,i=pa,c,l)=>{const u=ta();return[async()=>{u.clear(),g(await e(a,t),(({tn:a,cn:t})=>ca(oa(u,a,ra),t)))},async(t,e)=>((a,t)=>F(ea(u,a),t))(t,e)?G(A(g(await a(I+M(t)),(a=>{return[a[e],l?(t=V(a,e),n=l,G(K(t,((a,t)=>[t,n(a,t)])))):V(a,e)];var t,n})),(([a,t])=>!r(a)&&!X(t)))):{},async(t,e,s,l,w,y=!1)=>{const p=ra();K(s??{},(a=>g(q(a??{}),(a=>ca(p,a)))));const v=k(p);if(!y&&w&&h(v)&&F(u,t))return await a("DROP "+O+M(t)),void sa(u,t);const N=ea(u,t),$=ra(k(N));if(h(v)||(F(u,t)?await d(g([e,...v],(async(n,s)=>{x($,n)||(await a(T+M(t)+"ADD"+M(n)+o),0==s&&await a("CREATE UNIQUE INDEX pk ON "+M(t)+`(${M(e)})`),ca(N,n))}))):(await a("CREATE "+O+M(t)+`(${M(e)}${o} PRIMARY KEY${E(g(v,(a=>n+M(a)+o)))});`),sa(u,t,ra([e,...v])))),await d([...!y&&l?g(k($),(async n=>{n!=e&&(await a(T+M(t)+"DROP"+M(n)),x(N,n))})):[]]),y)r(s)?await a(b+M(t)+C+" true"):await d(K(s,(async(n,s)=>{r(n)?await a(b+M(t)+C+M(e)+"=$1",[s]):h(v)||await i(a,t,e,q(n),{[s]:c?g(Q(n),c):Q(n)},N)})));else if(h(v))F(u,t)&&await a(b+M(t)+C+" true");else{const n=A(k(ea(u,t)),(a=>a!=e)),o={},r=[];K(s??{},((a,t)=>{o[t]=g(n,(t=>c?c(a?.[t]):a?.[t])),m(r,t)})),await i(a,t,e,n,o),await a(b+M(t)+C+M(e)+`NOT IN(${P(r)})`,r)}},async t=>{let e;await a("BEGIN");try{e=await t()}catch(a){s?.(a)}return await a("END"),e}]},pa=async(a,t,e,s,o)=>{const i=[1];await a("INSERT INTO"+M(t)+"("+((...a)=>E(g(a,M),n))(e,...s)+")VALUES"+E(K(o,(a=>"($"+i[0]+++","+P(a,i)+")")),n)+"ON CONFLICT("+M(e)+")DO UPDATE SET"+E(g(s,(a=>M(a)+"=excluded."+M(a))),n),K(o,((a,t)=>[t,...g(a,(a=>a??null))])).flat())},va=(a,t,e,n,s,o,i,[r,c,l],u,w,y,d,p,v)=>{const[E,g,h,A]=da(t,u,w,s,p,v),m=ya(a,(async()=>await A((async()=>{return await E(),a=(await g(r,c))[$]?.[l]??"null",aa(a,((a,t)=>""===t?void 0:t));var a}))),(async a=>await A((async()=>{var t;await E(),await h(r,c,{[$]:{[l]:(t=a()??null,Z(t,((a,t)=>void 0===t?"":t)))}},!0,!0)}))),e,n,s,i,{[d]:()=>y,destroy:()=>(m.stopAutoLoad().stopAutoSave(),o(),m)},y);return m},Ea=(a,t,e,n,s,o,i,[c,l,[u,w,y]],p,v,E,g,h,m,N,S)=>{const[C,O,T,b]=da(t,p,v,s,h,m,N,S),I=async(a,t)=>await d(na(l,(async([e,n,s,o],i)=>{t&&!(i in a)||await T(e,n,a[i],s,o,t)}))),L=async(a,t)=>w?await T(y,f,{[$]:a},!0,!0,t):null,R=ya(a,(async()=>await b((async()=>{await C();const a=await(async()=>G(A(await d(na(c,(async([a,t],e)=>[a,await O(e,t)]))),(a=>!X(a[1])))))(),t=await(async()=>u?(await O(y,f))[$]:{})();return X(a)&&r(t)?void 0:[a,t]}))),(async(a,t)=>await b((async()=>{if(await C(),r(t)){const[t,e]=a();await I(t),await L(e)}else await I(t[0],!0),await L(t[1],!0)}))),e,n,s,i,{[g]:()=>E,destroy:()=>(R.stopAutoLoad().stopAutoSave(),o(),R)},E);return R},ga="ColumnName",ha="store",Aa="json",ma=ha+"TableName",Na=ha+"Id"+ga,$a=ha+ga,fa="autoLoadIntervalSeconds",Sa="rowId"+ga,Ca="tableId",Oa="tableName",Ta="deleteEmptyColumns",ba="deleteEmptyTable",Ia={mode:Aa,[fa]:1},La={load:0,save:0,[Oa]:t+"_values"},Ra=(a,t,e,n,s)=>{const o=ta();return K(a,((a,i)=>{const c=w(Q(H(t,l(a)?{[e]:a}:a)),0,W(t));r(c[0])||n(i,c[0])||(s(i,c[0]),sa(o,i,c))})),o},Da=(a,n,s,o,r,c,u,y,d,p,v="getDb",E)=>{let g,h,A;const m=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,c),[N,$,O,T]=(a=>{const e=(a=>H(Ia,l(a)?{[ma]:a}:a??{}))(a),n=e[fa];if(e.mode==Aa){const a=e[ma]??t;return[1,n,[a,e[Na]??f,e[$a]??ha],ra(a)]}const{tables:{load:s={},save:o={}}={},values:i={}}=e,r=w(Q(H(La,i)),0,W(La)),c=r[2],u=ra(c),y=ra(c);return[0,n,[Ra(s,{[Ca]:null,[Sa]:f},Ca,(a=>F(y,a)),(a=>ca(u,a))),Ra(o,{[Oa]:null,[Sa]:f,[Ta]:0,[ba]:0},Oa,((a,t)=>F(y,t)),((a,t)=>ca(u,t))),r],u]})(n);return(N?va:Ea)(a,m,(a=>{let t;const e=()=>t=setInterval((async()=>{try{const[{d:t,s:e,c:n}]=await m(`${S} ${R} d,${D} s,TOTAL_CHANGES() c FROM ${L}${R} JOIN ${L}${D}`);t==g&&e==h&&n==A||(null!=g&&a(),g=t,h=e,A=n)}catch{}}),1e3*$),n=()=>{g=h=A=null,i(t)},s=o((t=>{T.has(t)&&(n(),a(),e())}));return e(),()=>{n(),r(s)}}),(a=>a()),u,y,d,O,k(T),(async(a,t)=>await a(`${S} t.name tn,c.name cn FROM ${_}list()t,${_}info(t.name)c ${C} t.schema='main'AND t.type IN('table','view')AND t.name IN(${P(t)})ORDER BY t.name,c.name`,t)),p,v,e,E,(a=>!0===a?1:!1===a?0:a),void 0)},_a=(a,t,e,n,s,o)=>Da(a,n,(async(a,t=[])=>e.exec(a,{bind:t,rowMode:"object",returnValue:"resultRows"}).map((a=>({...a})))),(a=>t.capi.sqlite3_update_hook(e,((t,e,n,s)=>a(s)),0)),(()=>t.capi.sqlite3_update_hook(e,(()=>0),0)),s,o,(()=>0),3,e);export{_a as createSqliteWasmPersister};
|
|
1
|
+
const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),o=Promise,i=clearInterval,r=a=>null==a,c=(a,t,e)=>r(a)?e?.():t(a),l=t=>a(t)==s,u=a=>Array.isArray(a),w=(a,t,e)=>a.slice(t,e),y=a=>a.length,d=async a=>o.all(a),p=a=>{throw Error(a)},v=(a,t)=>a.forEach(t),E=(a,t="")=>a.join(t),g=(a,t)=>a.map(t),h=a=>0==y(a),A=(a,t)=>a.filter(t),m=(a,...t)=>a.push(...t),N=a=>a.shift(),$="_",f="_id",S="SELECT",C="WHERE",O="TABLE",T="ALTER "+O,b="DELETE FROM",I=S+"*FROM",L="pragma_",R="data_version",D="schema_version",_="pragma_table_",M=a=>`"${a.replace(/"/g,'""')}"`,P=(a,t=[1])=>E(g(a,(()=>"$"+t[0]++)),n),F=(a,t)=>a?.has(t)??!1,j=a=>r(a)||0==(a=>a?.size??0)(a),k=a=>[...a?.values()??[]],U=(a,t)=>a?.forEach(t),x=(a,t)=>a?.delete(t),B=Object,J=a=>B.getPrototypeOf(a),Y=B.entries,q=B.keys,z=B.freeze,G=(a=[])=>B.fromEntries(a),H=(...a)=>B.assign({},...a),V=(a,t)=>(delete a[t],a),K=(a,t)=>g(Y(a),(([a,e])=>t(e,a))),Q=a=>B.values(a),W=a=>y(q(a)),X=a=>(a=>!r(a)&&c(J(a),(a=>a==B.prototype||r(J(a))),(()=>!0)))(a)&&0==W(a),Z=JSON.stringify,aa=JSON.parse,ta=a=>new Map(a),ea=(a,t)=>a?.get(t),na=(a,t)=>g([...a?.entries()??[]],(([a,e])=>t(e,a))),sa=(a,t,e)=>r(e)?(x(a,t),a):a?.set(t,e),oa=(a,t,e,n)=>(F(a,t)?n?.(ea(a,t)):sa(a,t,e()),ea(a,t)),ia=(a,t,e,n,s=0)=>c((e?oa:ea)(a,t[s],s>y(t)-2?e:ta),(o=>{if(s>y(t)-2)return n?.(o)&&sa(a,t[s]),o;const i=ia(o,t,e,n,s+1);return j(o)&&sa(a,t[s]),i})),ra=a=>new Set(u(a)||r(a)?a:[a]),ca=(a,t)=>a?.add(t),la=/^\d+$/,ua=ta(),wa=ta(),ya=(a,t,n,s,o,i,l,w={},d=[])=>{let E,g,h,A=0,$=0,f=0;oa(ua,d,(()=>0)),oa(wa,d,(()=>[]));const S=ta(),[C,O,T,b,I]=((a=1,t)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,t.getTransactionMergeableChanges,([[a],[t]])=>!X(a)||!X(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!X(a)||!X(t),t.setContent]:p("Store type not supported by this Persister"))(l,a),[L,R,D]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?N(a):null)??e+t++,t=>{la.test(t)&&y(a)<1e3&&m(a,t)}]})(),s=ta();return[(n,o,i,r=[],c=()=>[])=>{a??=Y;const l=t(1);return sa(s,l,[n,o,i,r,c]),ca(ia(o,i??[e],ra),l),l},(t,n,...o)=>v(((a,t=[e])=>{const n=[],s=(a,e)=>e==y(t)?m(n,a):null===t[e]?U(a,(a=>s(a,e+1))):v([t[e],null],(t=>s(ea(a,t),e+1)));return s(a,0),n})(t,n),(t=>U(t,(t=>ea(s,t)[0](a,...n??[],...o))))),a=>c(ea(s,a),(([,t,o])=>(ia(t,o??[e],void 0,(t=>(x(t,a),j(t)?1:0))),sa(s,a),n(a),o))),t=>c(ea(s,t),(([t,,e=[],n,s])=>{const o=(...i)=>{const c=y(i);c==y(e)?t(a,...i,...s(i)):r(e[c])?v(n[c]?.(...i)??[],(a=>o(...i,a))):o(...i,e[c])};o()}))]})(),_=a=>{a!=A&&(A=a,R(S,void 0,A))},M=t=>{(C&&u(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},P=async a=>(2!=A&&(_(1),$++,await J((async()=>{try{const e=await t();u(e)?M(e):a?I(a):p("Content is not an array: "+e)}catch(t){i?.(t),a&&I(a)}_(0)}))),Y),F=()=>(g&&(o(g),g=void 0),Y),k=async a=>(1!=A&&(_(2),f++,await J((async()=>{try{await n(O,a)}catch(a){i?.(a)}_(0)}))),Y),B=()=>(c(h,a.delListener),h=void 0,Y),J=async(...a)=>(m(ea(wa,d),...a),await(async()=>{if(!ea(ua,d)){for(sa(ua,d,1);!r(E=N(ea(wa,d)));)try{await E()}catch(a){i?.(a)}sa(ua,d,0)}})(),Y),Y={load:P,startAutoLoad:async a=>{await F().load(a);try{g=await s((async(a,t)=>{t||a?2!=A&&(_(1),$++,M(t??a),_(0)):await P()}))}catch(a){i?.(a)}return Y},stopAutoLoad:F,isAutoLoading:()=>!r(g),save:k,startAutoSave:async()=>(await B().save(),h=a.addDidFinishTransactionListener((()=>{const a=T();b(a)&&k(a)})),Y),stopAutoSave:B,isAutoSaving:()=>!r(h),getStatus:()=>A,addStatusListener:a=>L(a,S),delListener:t=>(D(t),a),schedule:J,getStore:()=>a,destroy:()=>(ea(wa,d).splice(0,void 0),F().stopAutoSave()),getStats:()=>({loads:$,saves:f}),...w};return z(Y)},da=(a,t,e,s,o,i=pa,c,l)=>{const u=ta();return[async()=>{u.clear(),g(await e(a,t),(({tn:a,cn:t})=>ca(oa(u,a,ra),t)))},async(t,e)=>((a,t)=>F(ea(u,a),t))(t,e)?G(A(g(await a(I+M(t)),(a=>{return[a[e],l?(t=V(a,e),n=l,G(K(t,((a,t)=>[t,n(a,t)])))):V(a,e)];var t,n})),(([a,t])=>!r(a)&&!X(t)))):{},async(t,e,s,l,w,y=!1)=>{const p=ra();K(s??{},(a=>g(q(a??{}),(a=>ca(p,a)))));const v=k(p);if(!y&&w&&h(v)&&F(u,t))return await a("DROP "+O+M(t)),void sa(u,t);const N=ea(u,t),$=ra(k(N));if(h(v)||(F(u,t)?await d(g([e,...v],(async(n,s)=>{x($,n)||(await a(T+M(t)+"ADD"+M(n)+o),0==s&&await a("CREATE UNIQUE INDEX pk ON "+M(t)+`(${M(e)})`),ca(N,n))}))):(await a("CREATE "+O+M(t)+`(${M(e)}${o} PRIMARY KEY${E(g(v,(a=>n+M(a)+o)))});`),sa(u,t,ra([e,...v])))),await d([...!y&&l?g(k($),(async n=>{n!=e&&(await a(T+M(t)+"DROP"+M(n)),x(N,n))})):[]]),y)r(s)?await a(b+M(t)+C+" true"):await d(K(s,(async(n,s)=>{r(n)?await a(b+M(t)+C+M(e)+"=$1",[s]):h(v)||await i(a,t,e,q(n),{[s]:c?g(Q(n),c):Q(n)},N)})));else if(h(v))F(u,t)&&await a(b+M(t)+C+" true");else{const n=A(k(ea(u,t)),(a=>a!=e)),o={},r=[];K(s??{},((a,t)=>{o[t]=g(n,(t=>c?c(a?.[t]):a?.[t])),m(r,t)})),await i(a,t,e,n,o),await a(b+M(t)+C+M(e)+`NOT IN(${P(r)})`,r)}},async t=>{let e;await a("BEGIN");try{e=await t()}catch(a){s?.(a)}return await a("END"),e}]},pa=async(a,t,e,s,o)=>{const i=[1];await a("INSERT INTO"+M(t)+"("+((...a)=>E(g(a,M),n))(e,...s)+")VALUES"+E(K(o,(a=>"($"+i[0]+++","+P(a,i)+")")),n)+"ON CONFLICT("+M(e)+")DO UPDATE SET"+E(g(s,(a=>M(a)+"=excluded."+M(a))),n),K(o,((a,t)=>[t,...g(a,(a=>a??null))])).flat())},va=(a,t,e,n,s,o,i,[r,c,l],u,w,y,d,p,v)=>{const[E,g,h,A]=da(t,u,w,s,p,v),m=ya(a,(async()=>await A((async()=>{return await E(),a=(await g(r,c))[$]?.[l]??"null",aa(a,((a,t)=>""===t?void 0:t));var a}))),(async a=>await A((async()=>{var t;await E(),await h(r,c,{[$]:{[l]:(t=a()??null,Z(t,((a,t)=>void 0===t?"":t)))}},!0,!0)}))),e,n,s,i,{[d]:()=>y,destroy:()=>(m.stopAutoLoad().stopAutoSave(),o(),m)},y);return m},Ea=(a,t,e,n,s,o,i,[c,l,[u,w,y]],p,v,E,g,h,m,N,S)=>{const[C,O,T,b]=da(t,p,v,s,h,m,N,S),I=async(a,t)=>await d(na(l,(async([e,n,s,o],i)=>{t&&!(i in a)||await T(e,n,a[i],s,o,t)}))),L=async(a,t)=>w?await T(y,f,{[$]:a},!0,!0,t):null,R=ya(a,(async()=>await b((async()=>{await C();const a=await(async()=>G(A(await d(na(c,(async([a,t],e)=>[a,await O(e,t)]))),(a=>!X(a[1])))))(),t=await(async()=>u?(await O(y,f))[$]:{})();return X(a)&&r(t)?void 0:[a,t]}))),(async(a,t)=>await b((async()=>{if(await C(),r(t)){const[t,e]=a();await I(t),await L(e)}else await I(t[0],!0),await L(t[1],!0)}))),e,n,s,i,{[g]:()=>E,destroy:()=>(R.stopAutoLoad().stopAutoSave(),o(),R)},E);return R},ga="ColumnName",ha="store",Aa="json",ma=ha+"TableName",Na=ha+"Id"+ga,$a=ha+ga,fa="autoLoadIntervalSeconds",Sa="rowId"+ga,Ca="tableId",Oa="tableName",Ta="deleteEmptyColumns",ba="deleteEmptyTable",Ia={mode:Aa,[fa]:1},La={load:0,save:0,[Oa]:t+"_values"},Ra=(a,t,e,n,s)=>{const o=ta();return K(a,((a,i)=>{const c=w(Q(H(t,l(a)?{[e]:a}:a)),0,W(t));r(c[0])||n(i,c[0])||(s(i,c[0]),sa(o,i,c))})),o},Da=(a,n,s,o,r,c,u,y,d,p,v="getDb",E)=>{let g,h,A;const m=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,c),[N,$,O,T]=(a=>{const e=(a=>H(Ia,l(a)?{[ma]:a}:a??{}))(a),n=e[fa];if(e.mode==Aa){const a=e[ma]??t;return[1,n,[a,e[Na]??f,e[$a]??ha],ra(a)]}const{tables:{load:s={},save:o={}}={},values:i={}}=e,r=w(Q(H(La,i)),0,W(La)),c=r[2],u=ra(c),y=ra(c);return[0,n,[Ra(s,{[Ca]:null,[Sa]:f},Ca,(a=>F(y,a)),(a=>ca(u,a))),Ra(o,{[Oa]:null,[Sa]:f,[Ta]:0,[ba]:0},Oa,((a,t)=>F(y,t)),((a,t)=>ca(u,t))),r],u]})(n);return(N?va:Ea)(a,m,(a=>{let t;const e=()=>t=setInterval((async()=>{try{const[{d:t,s:e,c:n}]=await m(`${S} ${R} d,${D} s,TOTAL_CHANGES() c FROM ${L}${R} JOIN ${L}${D}`);t==g&&e==h&&n==A||(null!=g&&a(),g=t,h=e,A=n)}catch{}}),1e3*$),n=()=>{g=h=A=null,i(t)},s=o((t=>{T.has(t)&&(n(),a(),e())}));return e(),()=>{n(),r(s)}}),(a=>a()),u,y,d,O,k(T),(async(a,t)=>await a(`${S} t.name tn,c.name cn FROM ${_}list()t,${_}info(t.name)c ${C} t.schema='main'AND t.type IN('table','view')AND t.name IN(${P(t)})ORDER BY t.name,c.name`,t)),p,v,e,E,(a=>!0===a?1:!1===a?0:a),void 0)},_a=(a,t,e,n,s,o)=>Da(a,n,(async(a,t=[])=>e.exec(a,{bind:t,rowMode:"object",returnValue:"resultRows"}).map((a=>({...a})))),(a=>t.capi.sqlite3_update_hook(e,((t,e,n,s)=>a(s)),0)),(()=>t.capi.sqlite3_update_hook(e,(()=>0),0)),s,o,(()=>0),3,e);export{_a as createSqliteWasmPersister};
|
|
Binary file
|
|
@@ -1 +1 @@
|
|
|
1
|
-
const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),o=Promise,i=clearInterval,r=a=>null==a,c=(a,t,e)=>r(a)?e?.():t(a),l=t=>a(t)==s,u=a=>Array.isArray(a),w=(a,t,e)=>a.slice(t,e),y=a=>a.length,d=async a=>o.all(a),p=a=>{throw Error(a)},v=(a,t)=>a.forEach(t),E=(a,t="")=>a.join(t),g=(a,t)=>a.map(t),h=a=>0==y(a),A=(a,t)=>a.filter(t),m=(a,...t)=>a.push(...t),N=a=>a.shift(),$="_",f="_id",S="SELECT",C="WHERE",O="TABLE",T="ALTER "+O,b="DELETE FROM",I=S+"*FROM",L="pragma_",R="data_version",D="schema_version",_="pragma_table_",M=a=>`"${a.replace(/"/g,'""')}"`,P=(a,t=[1])=>E(g(a,(()=>"$"+t[0]++)),n),F=(a,t)=>a?.has(t)??!1,j=a=>r(a)||0==(a=>a?.size??0)(a),k=a=>[...a?.values()??[]],U=(a,t)=>a?.forEach(t),x=(a,t)=>a?.delete(t),B=Object,J=a=>B.getPrototypeOf(a),Y=B.entries,q=B.keys,z=B.freeze,G=(a=[])=>B.fromEntries(a),H=(...a)=>B.assign({},...a),V=(a,t)=>(delete a[t],a),K=(a,t)=>g(Y(a),(([a,e])=>t(e,a))),Q=a=>B.values(a),W=a=>y(q(a)),X=a=>(a=>!r(a)&&c(J(a),(a=>a==B.prototype||r(J(a))),(()=>!0)))(a)&&0==W(a),Z=JSON.stringify,aa=JSON.parse,ta=a=>new Map(a),ea=(a,t)=>a?.get(t),na=(a,t)=>g([...a?.entries()??[]],(([a,e])=>t(e,a))),sa=(a,t,e)=>r(e)?(x(a,t),a):a?.set(t,e),oa=(a,t,e,n)=>(F(a,t)?n?.(ea(a,t)):sa(a,t,e()),ea(a,t)),ia=(a,t,e,n,s=0)=>c((e?oa:ea)(a,t[s],s>y(t)-2?e:ta),(o=>{if(s>y(t)-2)return n?.(o)&&sa(a,t[s]),o;const i=ia(o,t,e,n,s+1);return j(o)&&sa(a,t[s]),i})),ra=a=>new Set(u(a)||r(a)?a:[a]),ca=(a,t)=>a?.add(t),la=/^\d+$/,ua=ta(),wa=ta(),ya=(a,t,n,s,o,i,l,w={},d=[])=>{let E,g,h,A=0,$=0,f=0;oa(ua,d,(()=>0)),oa(wa,d,(()=>[]));const S=ta(),[C,O,T,b,I]=((a=1,t)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,t.getTransactionMergeableChanges,([[a],[t]])=>!X(a)||!X(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!X(a)||!X(t),t.setContent]:p("Store type not supported by this Persister"))(l,a),[L,R,D]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?N(a):null)??e+t++,t=>{la.test(t)&&y(a)<1e3&&m(a,t)}]})(),s=ta();return[(n,o,i,r=[],c=()=>[])=>{a??=Y;const l=t(1);return sa(s,l,[n,o,i,r,c]),ca(ia(o,i??[e],ra),l),l},(t,n,...o)=>v(((a,t=[e])=>{const n=[],s=(a,e)=>e==y(t)?m(n,a):null===t[e]?U(a,(a=>s(a,e+1))):v([t[e],null],(t=>s(ea(a,t),e+1)));return s(a,0),n})(t,n),(t=>U(t,(t=>ea(s,t)[0](a,...n??[],...o))))),a=>c(ea(s,a),(([,t,o])=>(ia(t,o??[e],void 0,(t=>(x(t,a),j(t)?1:0))),sa(s,a),n(a),o))),t=>c(ea(s,t),(([t,,e=[],n,s])=>{const o=(...i)=>{const c=y(i);c==y(e)?t(a,...i,...s(i)):r(e[c])?v(n[c]?.(...i)??[],(a=>o(...i,a))):o(...i,e[c])};o()}))]})(),_=a=>{a!=A&&(A=a,R(S,void 0,A))},M=t=>{(C&&u(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},P=async a=>(2!=A&&(_(1),$++,await J((async()=>{try{const e=await t();u(e)?M(e):a?I(a):p("Content is not an array "+e)}catch(t){i?.(t),a&&I(a)}_(0)}))),Y),F=()=>(g&&(o(g),g=void 0),Y),k=async a=>(1!=A&&(_(2),f++,await J((async()=>{try{await n(O,a)}catch(a){i?.(a)}_(0)}))),Y),B=()=>(c(h,a.delListener),h=void 0,Y),J=async(...a)=>(m(ea(wa,d),...a),await(async()=>{if(!ea(ua,d)){for(sa(ua,d,1);!r(E=N(ea(wa,d)));)try{await E()}catch(a){i?.(a)}sa(ua,d,0)}})(),Y),Y={load:P,startAutoLoad:async a=>{await F().load(a);try{g=await s((async(a,t)=>{t||a?2!=A&&(_(1),$++,M(t??a),_(0)):await P()}))}catch(a){i?.(a)}return Y},stopAutoLoad:F,isAutoLoading:()=>!r(g),save:k,startAutoSave:async()=>(await B().save(),h=a.addDidFinishTransactionListener((()=>{const a=T();b(a)&&k(a)})),Y),stopAutoSave:B,isAutoSaving:()=>!r(h),getStatus:()=>A,addStatusListener:a=>L(a,S),delListener:t=>(D(t),a),schedule:J,getStore:()=>a,destroy:()=>(ea(wa,d).splice(0,void 0),F().stopAutoSave()),getStats:()=>({loads:$,saves:f}),...w};return z(Y)},da=(a,t,e,s,o,i=pa,c,l)=>{const u=ta();return[async()=>{u.clear(),g(await e(a,t),(({tn:a,cn:t})=>ca(oa(u,a,ra),t)))},async(t,e)=>((a,t)=>F(ea(u,a),t))(t,e)?G(A(g(await a(I+M(t)),(a=>{return[a[e],l?(t=V(a,e),n=l,G(K(t,((a,t)=>[t,n(a,t)])))):V(a,e)];var t,n})),(([a,t])=>!r(a)&&!X(t)))):{},async(t,e,s,l,w,y=!1)=>{const p=ra();K(s??{},(a=>g(q(a??{}),(a=>ca(p,a)))));const v=k(p);if(!y&&w&&h(v)&&F(u,t))return await a("DROP "+O+M(t)),void sa(u,t);const N=ea(u,t),$=ra(k(N));if(h(v)||(F(u,t)?await d(g([e,...v],(async(n,s)=>{x($,n)||(await a(T+M(t)+"ADD"+M(n)+o),0==s&&await a("CREATE UNIQUE INDEX pk ON "+M(t)+`(${M(e)})`),ca(N,n))}))):(await a("CREATE "+O+M(t)+`(${M(e)}${o} PRIMARY KEY${E(g(v,(a=>n+M(a)+o)))});`),sa(u,t,ra([e,...v])))),await d([...!y&&l?g(k($),(async n=>{n!=e&&(await a(T+M(t)+"DROP"+M(n)),x(N,n))})):[]]),y)r(s)?await a(b+M(t)+C+" true"):await d(K(s,(async(n,s)=>{r(n)?await a(b+M(t)+C+M(e)+"=$1",[s]):h(v)||await i(a,t,e,q(n),{[s]:c?g(Q(n),c):Q(n)},N)})));else if(h(v))F(u,t)&&await a(b+M(t)+C+" true");else{const n=A(k(ea(u,t)),(a=>a!=e)),o={},r=[];K(s??{},((a,t)=>{o[t]=g(n,(t=>c?c(a?.[t]):a?.[t])),m(r,t)})),await i(a,t,e,n,o),await a(b+M(t)+C+M(e)+`NOT IN(${P(r)})`,r)}},async t=>{let e;await a("BEGIN");try{e=await t()}catch(a){s?.(a)}return await a("END"),e}]},pa=async(a,t,e,s,o)=>{const i=[1];await a("INSERT INTO"+M(t)+"("+((...a)=>E(g(a,M),n))(e,...s)+")VALUES"+E(K(o,(a=>"($"+i[0]+++","+P(a,i)+")")),n)+"ON CONFLICT("+M(e)+")DO UPDATE SET"+E(g(s,(a=>M(a)+"=excluded."+M(a))),n),K(o,((a,t)=>[t,...g(a,(a=>a??null))])).flat())},va=(a,t,e,n,s,o,i,[r,c,l],u,w,y,d,p,v)=>{const[E,g,h,A]=da(t,u,w,s,p,v),m=ya(a,(async()=>await A((async()=>{return await E(),a=(await g(r,c))[$]?.[l]??"null",aa(a,((a,t)=>""===t?void 0:t));var a}))),(async a=>await A((async()=>{var t;await E(),await h(r,c,{[$]:{[l]:(t=a()??null,Z(t,((a,t)=>void 0===t?"":t)))}},!0,!0)}))),e,n,s,i,{[d]:()=>y,destroy:()=>(m.stopAutoLoad().stopAutoSave(),o(),m)},y);return m},Ea=(a,t,e,n,s,o,i,[c,l,[u,w,y]],p,v,E,g,h,m,N,S)=>{const[C,O,T,b]=da(t,p,v,s,h,m,N,S),I=async(a,t)=>await d(na(l,(async([e,n,s,o],i)=>{t&&!(i in a)||await T(e,n,a[i],s,o,t)}))),L=async(a,t)=>w?await T(y,f,{[$]:a},!0,!0,t):null,R=ya(a,(async()=>await b((async()=>{await C();const a=await(async()=>G(A(await d(na(c,(async([a,t],e)=>[a,await O(e,t)]))),(a=>!X(a[1])))))(),t=await(async()=>u?(await O(y,f))[$]:{})();return X(a)&&r(t)?void 0:[a,t]}))),(async(a,t)=>await b((async()=>{if(await C(),r(t)){const[t,e]=a();await I(t),await L(e)}else await I(t[0],!0),await L(t[1],!0)}))),e,n,s,i,{[g]:()=>E,destroy:()=>(R.stopAutoLoad().stopAutoSave(),o(),R)},E);return R},ga="ColumnName",ha="store",Aa="json",ma=ha+"TableName",Na=ha+"Id"+ga,$a=ha+ga,fa="autoLoadIntervalSeconds",Sa="rowId"+ga,Ca="tableId",Oa="tableName",Ta="deleteEmptyColumns",ba="deleteEmptyTable",Ia={mode:Aa,[fa]:1},La={load:0,save:0,[Oa]:t+"_values"},Ra=(a,t,e,n,s)=>{const o=ta();return K(a,((a,i)=>{const c=w(Q(H(t,l(a)?{[e]:a}:a)),0,W(t));r(c[0])||n(i,c[0])||(s(i,c[0]),sa(o,i,c))})),o},Da=(a,n,s,o,r,c,u,y,d,p,v="getDb",E)=>{let g,h,A;const m=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,c),[N,$,O,T]=(a=>{const e=(a=>H(Ia,l(a)?{[ma]:a}:a??{}))(a),n=e[fa];if(e.mode==Aa){const a=e[ma]??t;return[1,n,[a,e[Na]??f,e[$a]??ha],ra(a)]}const{tables:{load:s={},save:o={}}={},values:i={}}=e,r=w(Q(H(La,i)),0,W(La)),c=r[2],u=ra(c),y=ra(c);return[0,n,[Ra(s,{[Ca]:null,[Sa]:f},Ca,(a=>F(y,a)),(a=>ca(u,a))),Ra(o,{[Oa]:null,[Sa]:f,[Ta]:0,[ba]:0},Oa,((a,t)=>F(y,t)),((a,t)=>ca(u,t))),r],u]})(n);return(N?va:Ea)(a,m,(a=>{let t;const e=()=>t=setInterval((async()=>{try{const[{d:t,s:e,c:n}]=await m(`${S} ${R} d,${D} s,TOTAL_CHANGES() c FROM ${L}${R} JOIN ${L}${D}`);t==g&&e==h&&n==A||(null!=g&&a(),g=t,h=e,A=n)}catch{}}),1e3*$),n=()=>{g=h=A=null,i(t)},s=o((t=>{T.has(t)&&(n(),a(),e())}));return e(),()=>{n(),r(s)}}),(a=>a()),u,y,d,O,k(T),(async(a,t)=>await a(`${S} t.name tn,c.name cn FROM ${_}list()t,${_}info(t.name)c ${C} t.schema='main'AND t.type IN('table','view')AND t.name IN(${P(t)})ORDER BY t.name,c.name`,t)),p,v,e,E,(a=>!0===a?1:!1===a?0:a),void 0)},_a=(a,t,e,n,s,o)=>Da(a,n,(async(a,t=[])=>e.exec(a,{bind:t,rowMode:"object",returnValue:"resultRows"}).map((a=>({...a})))),(a=>t.capi.sqlite3_update_hook(e,((t,e,n,s)=>a(s)),0)),(()=>t.capi.sqlite3_update_hook(e,(()=>0),0)),s,o,(()=>0),3,e);export{_a as createSqliteWasmPersister};
|
|
1
|
+
const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),o=Promise,i=clearInterval,r=a=>null==a,c=(a,t,e)=>r(a)?e?.():t(a),l=t=>a(t)==s,u=a=>Array.isArray(a),w=(a,t,e)=>a.slice(t,e),y=a=>a.length,d=async a=>o.all(a),p=a=>{throw Error(a)},v=(a,t)=>a.forEach(t),E=(a,t="")=>a.join(t),g=(a,t)=>a.map(t),h=a=>0==y(a),A=(a,t)=>a.filter(t),m=(a,...t)=>a.push(...t),N=a=>a.shift(),$="_",f="_id",S="SELECT",C="WHERE",O="TABLE",T="ALTER "+O,b="DELETE FROM",I=S+"*FROM",L="pragma_",R="data_version",D="schema_version",_="pragma_table_",M=a=>`"${a.replace(/"/g,'""')}"`,P=(a,t=[1])=>E(g(a,(()=>"$"+t[0]++)),n),F=(a,t)=>a?.has(t)??!1,j=a=>r(a)||0==(a=>a?.size??0)(a),k=a=>[...a?.values()??[]],U=(a,t)=>a?.forEach(t),x=(a,t)=>a?.delete(t),B=Object,J=a=>B.getPrototypeOf(a),Y=B.entries,q=B.keys,z=B.freeze,G=(a=[])=>B.fromEntries(a),H=(...a)=>B.assign({},...a),V=(a,t)=>(delete a[t],a),K=(a,t)=>g(Y(a),(([a,e])=>t(e,a))),Q=a=>B.values(a),W=a=>y(q(a)),X=a=>(a=>!r(a)&&c(J(a),(a=>a==B.prototype||r(J(a))),(()=>!0)))(a)&&0==W(a),Z=JSON.stringify,aa=JSON.parse,ta=a=>new Map(a),ea=(a,t)=>a?.get(t),na=(a,t)=>g([...a?.entries()??[]],(([a,e])=>t(e,a))),sa=(a,t,e)=>r(e)?(x(a,t),a):a?.set(t,e),oa=(a,t,e,n)=>(F(a,t)?n?.(ea(a,t)):sa(a,t,e()),ea(a,t)),ia=(a,t,e,n,s=0)=>c((e?oa:ea)(a,t[s],s>y(t)-2?e:ta),(o=>{if(s>y(t)-2)return n?.(o)&&sa(a,t[s]),o;const i=ia(o,t,e,n,s+1);return j(o)&&sa(a,t[s]),i})),ra=a=>new Set(u(a)||r(a)?a:[a]),ca=(a,t)=>a?.add(t),la=/^\d+$/,ua=ta(),wa=ta(),ya=(a,t,n,s,o,i,l,w={},d=[])=>{let E,g,h,A=0,$=0,f=0;oa(ua,d,(()=>0)),oa(wa,d,(()=>[]));const S=ta(),[C,O,T,b,I]=((a=1,t)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,t.getTransactionMergeableChanges,([[a],[t]])=>!X(a)||!X(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!X(a)||!X(t),t.setContent]:p("Store type not supported by this Persister"))(l,a),[L,R,D]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?N(a):null)??e+t++,t=>{la.test(t)&&y(a)<1e3&&m(a,t)}]})(),s=ta();return[(n,o,i,r=[],c=()=>[])=>{a??=Y;const l=t(1);return sa(s,l,[n,o,i,r,c]),ca(ia(o,i??[e],ra),l),l},(t,n,...o)=>v(((a,t=[e])=>{const n=[],s=(a,e)=>e==y(t)?m(n,a):null===t[e]?U(a,(a=>s(a,e+1))):v([t[e],null],(t=>s(ea(a,t),e+1)));return s(a,0),n})(t,n),(t=>U(t,(t=>ea(s,t)[0](a,...n??[],...o))))),a=>c(ea(s,a),(([,t,o])=>(ia(t,o??[e],void 0,(t=>(x(t,a),j(t)?1:0))),sa(s,a),n(a),o))),t=>c(ea(s,t),(([t,,e=[],n,s])=>{const o=(...i)=>{const c=y(i);c==y(e)?t(a,...i,...s(i)):r(e[c])?v(n[c]?.(...i)??[],(a=>o(...i,a))):o(...i,e[c])};o()}))]})(),_=a=>{a!=A&&(A=a,R(S,void 0,A))},M=t=>{(C&&u(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},P=async a=>(2!=A&&(_(1),$++,await J((async()=>{try{const e=await t();u(e)?M(e):a?I(a):p("Content is not an array: "+e)}catch(t){i?.(t),a&&I(a)}_(0)}))),Y),F=()=>(g&&(o(g),g=void 0),Y),k=async a=>(1!=A&&(_(2),f++,await J((async()=>{try{await n(O,a)}catch(a){i?.(a)}_(0)}))),Y),B=()=>(c(h,a.delListener),h=void 0,Y),J=async(...a)=>(m(ea(wa,d),...a),await(async()=>{if(!ea(ua,d)){for(sa(ua,d,1);!r(E=N(ea(wa,d)));)try{await E()}catch(a){i?.(a)}sa(ua,d,0)}})(),Y),Y={load:P,startAutoLoad:async a=>{await F().load(a);try{g=await s((async(a,t)=>{t||a?2!=A&&(_(1),$++,M(t??a),_(0)):await P()}))}catch(a){i?.(a)}return Y},stopAutoLoad:F,isAutoLoading:()=>!r(g),save:k,startAutoSave:async()=>(await B().save(),h=a.addDidFinishTransactionListener((()=>{const a=T();b(a)&&k(a)})),Y),stopAutoSave:B,isAutoSaving:()=>!r(h),getStatus:()=>A,addStatusListener:a=>L(a,S),delListener:t=>(D(t),a),schedule:J,getStore:()=>a,destroy:()=>(ea(wa,d).splice(0,void 0),F().stopAutoSave()),getStats:()=>({loads:$,saves:f}),...w};return z(Y)},da=(a,t,e,s,o,i=pa,c,l)=>{const u=ta();return[async()=>{u.clear(),g(await e(a,t),(({tn:a,cn:t})=>ca(oa(u,a,ra),t)))},async(t,e)=>((a,t)=>F(ea(u,a),t))(t,e)?G(A(g(await a(I+M(t)),(a=>{return[a[e],l?(t=V(a,e),n=l,G(K(t,((a,t)=>[t,n(a,t)])))):V(a,e)];var t,n})),(([a,t])=>!r(a)&&!X(t)))):{},async(t,e,s,l,w,y=!1)=>{const p=ra();K(s??{},(a=>g(q(a??{}),(a=>ca(p,a)))));const v=k(p);if(!y&&w&&h(v)&&F(u,t))return await a("DROP "+O+M(t)),void sa(u,t);const N=ea(u,t),$=ra(k(N));if(h(v)||(F(u,t)?await d(g([e,...v],(async(n,s)=>{x($,n)||(await a(T+M(t)+"ADD"+M(n)+o),0==s&&await a("CREATE UNIQUE INDEX pk ON "+M(t)+`(${M(e)})`),ca(N,n))}))):(await a("CREATE "+O+M(t)+`(${M(e)}${o} PRIMARY KEY${E(g(v,(a=>n+M(a)+o)))});`),sa(u,t,ra([e,...v])))),await d([...!y&&l?g(k($),(async n=>{n!=e&&(await a(T+M(t)+"DROP"+M(n)),x(N,n))})):[]]),y)r(s)?await a(b+M(t)+C+" true"):await d(K(s,(async(n,s)=>{r(n)?await a(b+M(t)+C+M(e)+"=$1",[s]):h(v)||await i(a,t,e,q(n),{[s]:c?g(Q(n),c):Q(n)},N)})));else if(h(v))F(u,t)&&await a(b+M(t)+C+" true");else{const n=A(k(ea(u,t)),(a=>a!=e)),o={},r=[];K(s??{},((a,t)=>{o[t]=g(n,(t=>c?c(a?.[t]):a?.[t])),m(r,t)})),await i(a,t,e,n,o),await a(b+M(t)+C+M(e)+`NOT IN(${P(r)})`,r)}},async t=>{let e;await a("BEGIN");try{e=await t()}catch(a){s?.(a)}return await a("END"),e}]},pa=async(a,t,e,s,o)=>{const i=[1];await a("INSERT INTO"+M(t)+"("+((...a)=>E(g(a,M),n))(e,...s)+")VALUES"+E(K(o,(a=>"($"+i[0]+++","+P(a,i)+")")),n)+"ON CONFLICT("+M(e)+")DO UPDATE SET"+E(g(s,(a=>M(a)+"=excluded."+M(a))),n),K(o,((a,t)=>[t,...g(a,(a=>a??null))])).flat())},va=(a,t,e,n,s,o,i,[r,c,l],u,w,y,d,p,v)=>{const[E,g,h,A]=da(t,u,w,s,p,v),m=ya(a,(async()=>await A((async()=>{return await E(),a=(await g(r,c))[$]?.[l]??"null",aa(a,((a,t)=>""===t?void 0:t));var a}))),(async a=>await A((async()=>{var t;await E(),await h(r,c,{[$]:{[l]:(t=a()??null,Z(t,((a,t)=>void 0===t?"":t)))}},!0,!0)}))),e,n,s,i,{[d]:()=>y,destroy:()=>(m.stopAutoLoad().stopAutoSave(),o(),m)},y);return m},Ea=(a,t,e,n,s,o,i,[c,l,[u,w,y]],p,v,E,g,h,m,N,S)=>{const[C,O,T,b]=da(t,p,v,s,h,m,N,S),I=async(a,t)=>await d(na(l,(async([e,n,s,o],i)=>{t&&!(i in a)||await T(e,n,a[i],s,o,t)}))),L=async(a,t)=>w?await T(y,f,{[$]:a},!0,!0,t):null,R=ya(a,(async()=>await b((async()=>{await C();const a=await(async()=>G(A(await d(na(c,(async([a,t],e)=>[a,await O(e,t)]))),(a=>!X(a[1])))))(),t=await(async()=>u?(await O(y,f))[$]:{})();return X(a)&&r(t)?void 0:[a,t]}))),(async(a,t)=>await b((async()=>{if(await C(),r(t)){const[t,e]=a();await I(t),await L(e)}else await I(t[0],!0),await L(t[1],!0)}))),e,n,s,i,{[g]:()=>E,destroy:()=>(R.stopAutoLoad().stopAutoSave(),o(),R)},E);return R},ga="ColumnName",ha="store",Aa="json",ma=ha+"TableName",Na=ha+"Id"+ga,$a=ha+ga,fa="autoLoadIntervalSeconds",Sa="rowId"+ga,Ca="tableId",Oa="tableName",Ta="deleteEmptyColumns",ba="deleteEmptyTable",Ia={mode:Aa,[fa]:1},La={load:0,save:0,[Oa]:t+"_values"},Ra=(a,t,e,n,s)=>{const o=ta();return K(a,((a,i)=>{const c=w(Q(H(t,l(a)?{[e]:a}:a)),0,W(t));r(c[0])||n(i,c[0])||(s(i,c[0]),sa(o,i,c))})),o},Da=(a,n,s,o,r,c,u,y,d,p,v="getDb",E)=>{let g,h,A;const m=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,c),[N,$,O,T]=(a=>{const e=(a=>H(Ia,l(a)?{[ma]:a}:a??{}))(a),n=e[fa];if(e.mode==Aa){const a=e[ma]??t;return[1,n,[a,e[Na]??f,e[$a]??ha],ra(a)]}const{tables:{load:s={},save:o={}}={},values:i={}}=e,r=w(Q(H(La,i)),0,W(La)),c=r[2],u=ra(c),y=ra(c);return[0,n,[Ra(s,{[Ca]:null,[Sa]:f},Ca,(a=>F(y,a)),(a=>ca(u,a))),Ra(o,{[Oa]:null,[Sa]:f,[Ta]:0,[ba]:0},Oa,((a,t)=>F(y,t)),((a,t)=>ca(u,t))),r],u]})(n);return(N?va:Ea)(a,m,(a=>{let t;const e=()=>t=setInterval((async()=>{try{const[{d:t,s:e,c:n}]=await m(`${S} ${R} d,${D} s,TOTAL_CHANGES() c FROM ${L}${R} JOIN ${L}${D}`);t==g&&e==h&&n==A||(null!=g&&a(),g=t,h=e,A=n)}catch{}}),1e3*$),n=()=>{g=h=A=null,i(t)},s=o((t=>{T.has(t)&&(n(),a(),e())}));return e(),()=>{n(),r(s)}}),(a=>a()),u,y,d,O,k(T),(async(a,t)=>await a(`${S} t.name tn,c.name cn FROM ${_}list()t,${_}info(t.name)c ${C} t.schema='main'AND t.type IN('table','view')AND t.name IN(${P(t)})ORDER BY t.name,c.name`,t)),p,v,e,E,(a=>!0===a?1:!1===a?0:a),void 0)},_a=(a,t,e,n,s,o)=>Da(a,n,(async(a,t=[])=>e.exec(a,{bind:t,rowMode:"object",returnValue:"resultRows"}).map((a=>({...a})))),(a=>t.capi.sqlite3_update_hook(e,((t,e,n,s)=>a(s)),0)),(()=>t.capi.sqlite3_update_hook(e,(()=>0),0)),s,o,(()=>0),3,e);export{_a as createSqliteWasmPersister};
|
|
Binary file
|
|
@@ -1 +1 @@
|
|
|
1
|
-
const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),r=Promise,o=clearInterval,i=a=>null==a,c=(a,t,e)=>i(a)?e?.():t(a),l=t=>a(t)==s,u=a=>Array.isArray(a),w=(a,t,e)=>a.slice(t,e),y=a=>a.length,d=async a=>r.all(a),v=a=>{throw Error(a)},p=(a,t)=>a.forEach(t),E=(a,t="")=>a.join(t),g=(a,t)=>a.map(t),A=a=>0==y(a),h=(a,t)=>a.filter(t),m=(a,...t)=>a.push(...t),f=a=>a.shift(),N="_",$="_id",S="SELECT",C="WHERE",O="TABLE",T="ALTER "+O,I="DELETE FROM",L=S+"*FROM",b="pragma_",D="data_version",R="schema_version",M="pragma_table_",_=a=>`"${a.replace(/"/g,'""')}"`,P=(a,t=[1])=>E(g(a,(()=>"$"+t[0]++)),n),F=(a,t)=>a?.has(t)??!1,U=a=>i(a)||0==(a=>a?.size??0)(a),j=a=>[...a?.values()??[]],B=(a,t)=>a?.forEach(t),J=(a,t)=>a?.delete(t),Y=Object,k=a=>Y.getPrototypeOf(a),x=Y.entries,z=Y.keys,G=Y.freeze,H=(a=[])=>Y.fromEntries(a),K=(...a)=>Y.assign({},...a),Q=(a,t)=>(delete a[t],a),V=(a,t)=>g(x(a),(([a,e])=>t(e,a))),W=a=>Y.values(a),X=a=>y(z(a)),q=a=>(a=>!i(a)&&c(k(a),(a=>a==Y.prototype||i(k(a))),(()=>!0)))(a)&&0==X(a),Z=JSON.stringify,aa=JSON.parse,ta=a=>new Map(a),ea=(a,t)=>a?.get(t),na=(a,t)=>g([...a?.entries()??[]],(([a,e])=>t(e,a))),sa=(a,t,e)=>i(e)?(J(a,t),a):a?.set(t,e),ra=(a,t,e,n)=>(F(a,t)?n?.(ea(a,t)):sa(a,t,e()),ea(a,t)),oa=(a,t,e,n,s=0)=>c((e?ra:ea)(a,t[s],s>y(t)-2?e:ta),(r=>{if(s>y(t)-2)return n?.(r)&&sa(a,t[s]),r;const o=oa(r,t,e,n,s+1);return U(r)&&sa(a,t[s]),o})),ia=a=>new Set(u(a)||i(a)?a:[a]),ca=(a,t)=>a?.add(t),la=/^\d+$/,ua=ta(),wa=ta(),ya=(a,t,n,s,r,o,l,w={},d=[])=>{let E,g,A,h=0,N=0,$=0;ra(ua,d,(()=>0)),ra(wa,d,(()=>[]));const S=ta(),[C,O,T,I,L]=((a=1,t)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,t.getTransactionMergeableChanges,([[a],[t]])=>!q(a)||!q(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!q(a)||!q(t),t.setContent]:v("Store type not supported by this Persister"))(l,a),[b,D,R]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?f(a):null)??e+t++,t=>{la.test(t)&&y(a)<1e3&&m(a,t)}]})(),s=ta();return[(n,r,o,i=[],c=()=>[])=>{a??=x;const l=t(1);return sa(s,l,[n,r,o,i,c]),ca(oa(r,o??[e],ia),l),l},(t,n,...r)=>p(((a,t=[e])=>{const n=[],s=(a,e)=>e==y(t)?m(n,a):null===t[e]?B(a,(a=>s(a,e+1))):p([t[e],null],(t=>s(ea(a,t),e+1)));return s(a,0),n})(t,n),(t=>B(t,(t=>ea(s,t)[0](a,...n??[],...r))))),a=>c(ea(s,a),(([,t,r])=>(oa(t,r??[e],void 0,(t=>(J(t,a),U(t)?1:0))),sa(s,a),n(a),r))),t=>c(ea(s,t),(([t,,e=[],n,s])=>{const r=(...o)=>{const c=y(o);c==y(e)?t(a,...o,...s(o)):i(e[c])?p(n[c]?.(...o)??[],(a=>r(...o,a))):r(...o,e[c])};r()}))]})(),M=a=>{a!=h&&(h=a,D(S,void 0,h))},_=t=>{(C&&u(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},P=async a=>(2!=h&&(M(1),N++,await k((async()=>{try{const e=await t();u(e)?_(e):a?L(a):v("Content is not an array "+e)}catch(t){o?.(t),a&&L(a)}M(0)}))),x),F=()=>(g&&(r(g),g=void 0),x),j=async a=>(1!=h&&(M(2),$++,await k((async()=>{try{await n(O,a)}catch(a){o?.(a)}M(0)}))),x),Y=()=>(c(A,a.delListener),A=void 0,x),k=async(...a)=>(m(ea(wa,d),...a),await(async()=>{if(!ea(ua,d)){for(sa(ua,d,1);!i(E=f(ea(wa,d)));)try{await E()}catch(a){o?.(a)}sa(ua,d,0)}})(),x),x={load:P,startAutoLoad:async a=>{await F().load(a);try{g=await s((async(a,t)=>{t||a?2!=h&&(M(1),N++,_(t??a),M(0)):await P()}))}catch(a){o?.(a)}return x},stopAutoLoad:F,isAutoLoading:()=>!i(g),save:j,startAutoSave:async()=>(await Y().save(),A=a.addDidFinishTransactionListener((()=>{const a=T();I(a)&&j(a)})),x),stopAutoSave:Y,isAutoSaving:()=>!i(A),getStatus:()=>h,addStatusListener:a=>b(a,S),delListener:t=>(R(t),a),schedule:k,getStore:()=>a,destroy:()=>(ea(wa,d).splice(0,void 0),F().stopAutoSave()),getStats:()=>({loads:N,saves:$}),...w};return G(x)},da=(a,t,e,s,r,o=va,c,l)=>{const u=ta();return[async()=>{u.clear(),g(await e(a,t),(({tn:a,cn:t})=>ca(ra(u,a,ia),t)))},async(t,e)=>((a,t)=>F(ea(u,a),t))(t,e)?H(h(g(await a(L+_(t)),(a=>{return[a[e],l?(t=Q(a,e),n=l,H(V(t,((a,t)=>[t,n(a,t)])))):Q(a,e)];var t,n})),(([a,t])=>!i(a)&&!q(t)))):{},async(t,e,s,l,w,y=!1)=>{const v=ia();V(s??{},(a=>g(z(a??{}),(a=>ca(v,a)))));const p=j(v);if(!y&&w&&A(p)&&F(u,t))return await a("DROP "+O+_(t)),void sa(u,t);const f=ea(u,t),N=ia(j(f));if(A(p)||(F(u,t)?await d(g([e,...p],(async(n,s)=>{J(N,n)||(await a(T+_(t)+"ADD"+_(n)+r),0==s&&await a("CREATE UNIQUE INDEX pk ON "+_(t)+`(${_(e)})`),ca(f,n))}))):(await a("CREATE "+O+_(t)+`(${_(e)}${r} PRIMARY KEY${E(g(p,(a=>n+_(a)+r)))});`),sa(u,t,ia([e,...p])))),await d([...!y&&l?g(j(N),(async n=>{n!=e&&(await a(T+_(t)+"DROP"+_(n)),J(f,n))})):[]]),y)i(s)?await a(I+_(t)+C+" true"):await d(V(s,(async(n,s)=>{i(n)?await a(I+_(t)+C+_(e)+"=$1",[s]):A(p)||await o(a,t,e,z(n),{[s]:c?g(W(n),c):W(n)},f)})));else if(A(p))F(u,t)&&await a(I+_(t)+C+" true");else{const n=h(j(ea(u,t)),(a=>a!=e)),r={},i=[];V(s??{},((a,t)=>{r[t]=g(n,(t=>c?c(a?.[t]):a?.[t])),m(i,t)})),await o(a,t,e,n,r),await a(I+_(t)+C+_(e)+`NOT IN(${P(i)})`,i)}},async t=>{let e;await a("BEGIN");try{e=await t()}catch(a){s?.(a)}return await a("END"),e}]},va=async(a,t,e,s,r)=>{const o=[1];await a("INSERT INTO"+_(t)+"("+((...a)=>E(g(a,_),n))(e,...s)+")VALUES"+E(V(r,(a=>"($"+o[0]+++","+P(a,o)+")")),n)+"ON CONFLICT("+_(e)+")DO UPDATE SET"+E(g(s,(a=>_(a)+"=excluded."+_(a))),n),V(r,((a,t)=>[t,...g(a,(a=>a??null))])).flat())},pa=(a,t,e,n,s,r,o,[i,c,l],u,w,y,d,v,p)=>{const[E,g,A,h]=da(t,u,w,s,v,p),m=ya(a,(async()=>await h((async()=>{return await E(),a=(await g(i,c))[N]?.[l]??"null",aa(a,((a,t)=>""===t?void 0:t));var a}))),(async a=>await h((async()=>{var t;await E(),await A(i,c,{[N]:{[l]:(t=a()??null,Z(t,((a,t)=>void 0===t?"":t)))}},!0,!0)}))),e,n,s,o,{[d]:()=>y,destroy:()=>(m.stopAutoLoad().stopAutoSave(),r(),m)},y);return m},Ea=(a,t,e,n,s,r,o,[c,l,[u,w,y]],v,p,E,g,A,m,f,S)=>{const[C,O,T,I]=da(t,v,p,s,A,m,f,S),L=async(a,t)=>await d(na(l,(async([e,n,s,r],o)=>{t&&!(o in a)||await T(e,n,a[o],s,r,t)}))),b=async(a,t)=>w?await T(y,$,{[N]:a},!0,!0,t):null,D=ya(a,(async()=>await I((async()=>{await C();const a=await(async()=>H(h(await d(na(c,(async([a,t],e)=>[a,await O(e,t)]))),(a=>!q(a[1])))))(),t=await(async()=>u?(await O(y,$))[N]:{})();return q(a)&&i(t)?void 0:[a,t]}))),(async(a,t)=>await I((async()=>{if(await C(),i(t)){const[t,e]=a();await L(t),await b(e)}else await L(t[0],!0),await b(t[1],!0)}))),e,n,s,o,{[g]:()=>E,destroy:()=>(D.stopAutoLoad().stopAutoSave(),r(),D)},E);return D},ga="ColumnName",Aa="store",ha="json",ma=Aa+"TableName",fa=Aa+"Id"+ga,Na=Aa+ga,$a="autoLoadIntervalSeconds",Sa="rowId"+ga,Ca="tableId",Oa="tableName",Ta="deleteEmptyColumns",Ia="deleteEmptyTable",La={mode:ha,[$a]:1},ba={load:0,save:0,[Oa]:t+"_values"},Da=(a,t,e,n,s)=>{const r=ta();return V(a,((a,o)=>{const c=w(W(K(t,l(a)?{[e]:a}:a)),0,X(t));i(c[0])||n(o,c[0])||(s(o,c[0]),sa(r,o,c))})),r},Ra=(a,n,s,r,i,c,u,y,d,v,p="getDb",E)=>{let g,A,h;const m=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,c),[f,N,O,T]=(a=>{const e=(a=>K(La,l(a)?{[ma]:a}:a??{}))(a),n=e[$a];if(e.mode==ha){const a=e[ma]??t;return[1,n,[a,e[fa]??$,e[Na]??Aa],ia(a)]}const{tables:{load:s={},save:r={}}={},values:o={}}=e,i=w(W(K(ba,o)),0,X(ba)),c=i[2],u=ia(c),y=ia(c);return[0,n,[Da(s,{[Ca]:null,[Sa]:$},Ca,(a=>F(y,a)),(a=>ca(u,a))),Da(r,{[Oa]:null,[Sa]:$,[Ta]:0,[Ia]:0},Oa,((a,t)=>F(y,t)),((a,t)=>ca(u,t))),i],u]})(n);return(f?pa:Ea)(a,m,(a=>{let t;const e=()=>t=setInterval((async()=>{try{const[{d:t,s:e,c:n}]=await m(`${S} ${D} d,${R} s,TOTAL_CHANGES() c FROM ${b}${D} JOIN ${b}${R}`);t==g&&e==A&&n==h||(null!=g&&a(),g=t,A=e,h=n)}catch{}}),1e3*N),n=()=>{g=A=h=null,o(t)},s=r((t=>{T.has(t)&&(n(),a(),e())}));return e(),()=>{n(),i(s)}}),(a=>a()),u,y,d,O,j(T),(async(a,t)=>await a(`${S} t.name tn,c.name cn FROM ${M}list()t,${M}info(t.name)c ${C} t.schema='main'AND t.type IN('table','view')AND t.name IN(${P(t)})ORDER BY t.name,c.name`,t)),v,p,e,E,(a=>!0===a?1:!1===a?0:a),void 0)},Ma="change",_a=(a,t,e,n,s)=>Ra(a,e,(async(a,e=[])=>{return await(n=(n,s)=>t.all(a,e,((a,t)=>a?s(a):n(t))),new r(n));var n}),(a=>{const e=(t,e,n)=>a(n);return t.on(Ma,e),e}),(a=>t.off(Ma,a)),n,s,(()=>0),3,t);export{_a as createSqlite3Persister};
|
|
1
|
+
const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),r=Promise,o=clearInterval,i=a=>null==a,c=(a,t,e)=>i(a)?e?.():t(a),l=t=>a(t)==s,u=a=>Array.isArray(a),w=(a,t,e)=>a.slice(t,e),y=a=>a.length,d=async a=>r.all(a),v=a=>{throw Error(a)},p=(a,t)=>a.forEach(t),E=(a,t="")=>a.join(t),g=(a,t)=>a.map(t),A=a=>0==y(a),h=(a,t)=>a.filter(t),m=(a,...t)=>a.push(...t),f=a=>a.shift(),N="_",$="_id",S="SELECT",C="WHERE",O="TABLE",T="ALTER "+O,I="DELETE FROM",L=S+"*FROM",b="pragma_",D="data_version",R="schema_version",M="pragma_table_",_=a=>`"${a.replace(/"/g,'""')}"`,P=(a,t=[1])=>E(g(a,(()=>"$"+t[0]++)),n),F=(a,t)=>a?.has(t)??!1,U=a=>i(a)||0==(a=>a?.size??0)(a),j=a=>[...a?.values()??[]],B=(a,t)=>a?.forEach(t),J=(a,t)=>a?.delete(t),Y=Object,k=a=>Y.getPrototypeOf(a),x=Y.entries,z=Y.keys,G=Y.freeze,H=(a=[])=>Y.fromEntries(a),K=(...a)=>Y.assign({},...a),Q=(a,t)=>(delete a[t],a),V=(a,t)=>g(x(a),(([a,e])=>t(e,a))),W=a=>Y.values(a),X=a=>y(z(a)),q=a=>(a=>!i(a)&&c(k(a),(a=>a==Y.prototype||i(k(a))),(()=>!0)))(a)&&0==X(a),Z=JSON.stringify,aa=JSON.parse,ta=a=>new Map(a),ea=(a,t)=>a?.get(t),na=(a,t)=>g([...a?.entries()??[]],(([a,e])=>t(e,a))),sa=(a,t,e)=>i(e)?(J(a,t),a):a?.set(t,e),ra=(a,t,e,n)=>(F(a,t)?n?.(ea(a,t)):sa(a,t,e()),ea(a,t)),oa=(a,t,e,n,s=0)=>c((e?ra:ea)(a,t[s],s>y(t)-2?e:ta),(r=>{if(s>y(t)-2)return n?.(r)&&sa(a,t[s]),r;const o=oa(r,t,e,n,s+1);return U(r)&&sa(a,t[s]),o})),ia=a=>new Set(u(a)||i(a)?a:[a]),ca=(a,t)=>a?.add(t),la=/^\d+$/,ua=ta(),wa=ta(),ya=(a,t,n,s,r,o,l,w={},d=[])=>{let E,g,A,h=0,N=0,$=0;ra(ua,d,(()=>0)),ra(wa,d,(()=>[]));const S=ta(),[C,O,T,I,L]=((a=1,t)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,t.getTransactionMergeableChanges,([[a],[t]])=>!q(a)||!q(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!q(a)||!q(t),t.setContent]:v("Store type not supported by this Persister"))(l,a),[b,D,R]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?f(a):null)??e+t++,t=>{la.test(t)&&y(a)<1e3&&m(a,t)}]})(),s=ta();return[(n,r,o,i=[],c=()=>[])=>{a??=x;const l=t(1);return sa(s,l,[n,r,o,i,c]),ca(oa(r,o??[e],ia),l),l},(t,n,...r)=>p(((a,t=[e])=>{const n=[],s=(a,e)=>e==y(t)?m(n,a):null===t[e]?B(a,(a=>s(a,e+1))):p([t[e],null],(t=>s(ea(a,t),e+1)));return s(a,0),n})(t,n),(t=>B(t,(t=>ea(s,t)[0](a,...n??[],...r))))),a=>c(ea(s,a),(([,t,r])=>(oa(t,r??[e],void 0,(t=>(J(t,a),U(t)?1:0))),sa(s,a),n(a),r))),t=>c(ea(s,t),(([t,,e=[],n,s])=>{const r=(...o)=>{const c=y(o);c==y(e)?t(a,...o,...s(o)):i(e[c])?p(n[c]?.(...o)??[],(a=>r(...o,a))):r(...o,e[c])};r()}))]})(),M=a=>{a!=h&&(h=a,D(S,void 0,h))},_=t=>{(C&&u(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},P=async a=>(2!=h&&(M(1),N++,await k((async()=>{try{const e=await t();u(e)?_(e):a?L(a):v("Content is not an array: "+e)}catch(t){o?.(t),a&&L(a)}M(0)}))),x),F=()=>(g&&(r(g),g=void 0),x),j=async a=>(1!=h&&(M(2),$++,await k((async()=>{try{await n(O,a)}catch(a){o?.(a)}M(0)}))),x),Y=()=>(c(A,a.delListener),A=void 0,x),k=async(...a)=>(m(ea(wa,d),...a),await(async()=>{if(!ea(ua,d)){for(sa(ua,d,1);!i(E=f(ea(wa,d)));)try{await E()}catch(a){o?.(a)}sa(ua,d,0)}})(),x),x={load:P,startAutoLoad:async a=>{await F().load(a);try{g=await s((async(a,t)=>{t||a?2!=h&&(M(1),N++,_(t??a),M(0)):await P()}))}catch(a){o?.(a)}return x},stopAutoLoad:F,isAutoLoading:()=>!i(g),save:j,startAutoSave:async()=>(await Y().save(),A=a.addDidFinishTransactionListener((()=>{const a=T();I(a)&&j(a)})),x),stopAutoSave:Y,isAutoSaving:()=>!i(A),getStatus:()=>h,addStatusListener:a=>b(a,S),delListener:t=>(R(t),a),schedule:k,getStore:()=>a,destroy:()=>(ea(wa,d).splice(0,void 0),F().stopAutoSave()),getStats:()=>({loads:N,saves:$}),...w};return G(x)},da=(a,t,e,s,r,o=va,c,l)=>{const u=ta();return[async()=>{u.clear(),g(await e(a,t),(({tn:a,cn:t})=>ca(ra(u,a,ia),t)))},async(t,e)=>((a,t)=>F(ea(u,a),t))(t,e)?H(h(g(await a(L+_(t)),(a=>{return[a[e],l?(t=Q(a,e),n=l,H(V(t,((a,t)=>[t,n(a,t)])))):Q(a,e)];var t,n})),(([a,t])=>!i(a)&&!q(t)))):{},async(t,e,s,l,w,y=!1)=>{const v=ia();V(s??{},(a=>g(z(a??{}),(a=>ca(v,a)))));const p=j(v);if(!y&&w&&A(p)&&F(u,t))return await a("DROP "+O+_(t)),void sa(u,t);const f=ea(u,t),N=ia(j(f));if(A(p)||(F(u,t)?await d(g([e,...p],(async(n,s)=>{J(N,n)||(await a(T+_(t)+"ADD"+_(n)+r),0==s&&await a("CREATE UNIQUE INDEX pk ON "+_(t)+`(${_(e)})`),ca(f,n))}))):(await a("CREATE "+O+_(t)+`(${_(e)}${r} PRIMARY KEY${E(g(p,(a=>n+_(a)+r)))});`),sa(u,t,ia([e,...p])))),await d([...!y&&l?g(j(N),(async n=>{n!=e&&(await a(T+_(t)+"DROP"+_(n)),J(f,n))})):[]]),y)i(s)?await a(I+_(t)+C+" true"):await d(V(s,(async(n,s)=>{i(n)?await a(I+_(t)+C+_(e)+"=$1",[s]):A(p)||await o(a,t,e,z(n),{[s]:c?g(W(n),c):W(n)},f)})));else if(A(p))F(u,t)&&await a(I+_(t)+C+" true");else{const n=h(j(ea(u,t)),(a=>a!=e)),r={},i=[];V(s??{},((a,t)=>{r[t]=g(n,(t=>c?c(a?.[t]):a?.[t])),m(i,t)})),await o(a,t,e,n,r),await a(I+_(t)+C+_(e)+`NOT IN(${P(i)})`,i)}},async t=>{let e;await a("BEGIN");try{e=await t()}catch(a){s?.(a)}return await a("END"),e}]},va=async(a,t,e,s,r)=>{const o=[1];await a("INSERT INTO"+_(t)+"("+((...a)=>E(g(a,_),n))(e,...s)+")VALUES"+E(V(r,(a=>"($"+o[0]+++","+P(a,o)+")")),n)+"ON CONFLICT("+_(e)+")DO UPDATE SET"+E(g(s,(a=>_(a)+"=excluded."+_(a))),n),V(r,((a,t)=>[t,...g(a,(a=>a??null))])).flat())},pa=(a,t,e,n,s,r,o,[i,c,l],u,w,y,d,v,p)=>{const[E,g,A,h]=da(t,u,w,s,v,p),m=ya(a,(async()=>await h((async()=>{return await E(),a=(await g(i,c))[N]?.[l]??"null",aa(a,((a,t)=>""===t?void 0:t));var a}))),(async a=>await h((async()=>{var t;await E(),await A(i,c,{[N]:{[l]:(t=a()??null,Z(t,((a,t)=>void 0===t?"":t)))}},!0,!0)}))),e,n,s,o,{[d]:()=>y,destroy:()=>(m.stopAutoLoad().stopAutoSave(),r(),m)},y);return m},Ea=(a,t,e,n,s,r,o,[c,l,[u,w,y]],v,p,E,g,A,m,f,S)=>{const[C,O,T,I]=da(t,v,p,s,A,m,f,S),L=async(a,t)=>await d(na(l,(async([e,n,s,r],o)=>{t&&!(o in a)||await T(e,n,a[o],s,r,t)}))),b=async(a,t)=>w?await T(y,$,{[N]:a},!0,!0,t):null,D=ya(a,(async()=>await I((async()=>{await C();const a=await(async()=>H(h(await d(na(c,(async([a,t],e)=>[a,await O(e,t)]))),(a=>!q(a[1])))))(),t=await(async()=>u?(await O(y,$))[N]:{})();return q(a)&&i(t)?void 0:[a,t]}))),(async(a,t)=>await I((async()=>{if(await C(),i(t)){const[t,e]=a();await L(t),await b(e)}else await L(t[0],!0),await b(t[1],!0)}))),e,n,s,o,{[g]:()=>E,destroy:()=>(D.stopAutoLoad().stopAutoSave(),r(),D)},E);return D},ga="ColumnName",Aa="store",ha="json",ma=Aa+"TableName",fa=Aa+"Id"+ga,Na=Aa+ga,$a="autoLoadIntervalSeconds",Sa="rowId"+ga,Ca="tableId",Oa="tableName",Ta="deleteEmptyColumns",Ia="deleteEmptyTable",La={mode:ha,[$a]:1},ba={load:0,save:0,[Oa]:t+"_values"},Da=(a,t,e,n,s)=>{const r=ta();return V(a,((a,o)=>{const c=w(W(K(t,l(a)?{[e]:a}:a)),0,X(t));i(c[0])||n(o,c[0])||(s(o,c[0]),sa(r,o,c))})),r},Ra=(a,n,s,r,i,c,u,y,d,v,p="getDb",E)=>{let g,A,h;const m=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,c),[f,N,O,T]=(a=>{const e=(a=>K(La,l(a)?{[ma]:a}:a??{}))(a),n=e[$a];if(e.mode==ha){const a=e[ma]??t;return[1,n,[a,e[fa]??$,e[Na]??Aa],ia(a)]}const{tables:{load:s={},save:r={}}={},values:o={}}=e,i=w(W(K(ba,o)),0,X(ba)),c=i[2],u=ia(c),y=ia(c);return[0,n,[Da(s,{[Ca]:null,[Sa]:$},Ca,(a=>F(y,a)),(a=>ca(u,a))),Da(r,{[Oa]:null,[Sa]:$,[Ta]:0,[Ia]:0},Oa,((a,t)=>F(y,t)),((a,t)=>ca(u,t))),i],u]})(n);return(f?pa:Ea)(a,m,(a=>{let t;const e=()=>t=setInterval((async()=>{try{const[{d:t,s:e,c:n}]=await m(`${S} ${D} d,${R} s,TOTAL_CHANGES() c FROM ${b}${D} JOIN ${b}${R}`);t==g&&e==A&&n==h||(null!=g&&a(),g=t,A=e,h=n)}catch{}}),1e3*N),n=()=>{g=A=h=null,o(t)},s=r((t=>{T.has(t)&&(n(),a(),e())}));return e(),()=>{n(),i(s)}}),(a=>a()),u,y,d,O,j(T),(async(a,t)=>await a(`${S} t.name tn,c.name cn FROM ${M}list()t,${M}info(t.name)c ${C} t.schema='main'AND t.type IN('table','view')AND t.name IN(${P(t)})ORDER BY t.name,c.name`,t)),v,p,e,E,(a=>!0===a?1:!1===a?0:a),void 0)},Ma="change",_a=(a,t,e,n,s)=>Ra(a,e,(async(a,e=[])=>{return await(n=(n,s)=>t.all(a,e,((a,t)=>a?s(a):n(t))),new r(n));var n}),(a=>{const e=(t,e,n)=>a(n);return t.on(Ma,e),e}),(a=>t.off(Ma,a)),n,s,(()=>0),3,t);export{_a as createSqlite3Persister};
|
|
Binary file
|
|
@@ -1 +1 @@
|
|
|
1
|
-
const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),r=Promise,o=clearInterval,i=a=>null==a,c=(a,t,e)=>i(a)?e?.():t(a),l=t=>a(t)==s,u=a=>Array.isArray(a),w=(a,t,e)=>a.slice(t,e),y=a=>a.length,d=async a=>r.all(a),v=a=>{throw Error(a)},p=(a,t)=>a.forEach(t),E=(a,t="")=>a.join(t),g=(a,t)=>a.map(t),A=a=>0==y(a),h=(a,t)=>a.filter(t),m=(a,...t)=>a.push(...t),f=a=>a.shift(),N="_",$="_id",S="SELECT",C="WHERE",O="TABLE",T="ALTER "+O,I="DELETE FROM",L=S+"*FROM",b="pragma_",D="data_version",R="schema_version",M="pragma_table_",_=a=>`"${a.replace(/"/g,'""')}"`,P=(a,t=[1])=>E(g(a,(()=>"$"+t[0]++)),n),F=(a,t)=>a?.has(t)??!1,U=a=>i(a)||0==(a=>a?.size??0)(a),j=a=>[...a?.values()??[]],B=(a,t)=>a?.forEach(t),J=(a,t)=>a?.delete(t),Y=Object,k=a=>Y.getPrototypeOf(a),x=Y.entries,z=Y.keys,G=Y.freeze,H=(a=[])=>Y.fromEntries(a),K=(...a)=>Y.assign({},...a),Q=(a,t)=>(delete a[t],a),V=(a,t)=>g(x(a),(([a,e])=>t(e,a))),W=a=>Y.values(a),X=a=>y(z(a)),q=a=>(a=>!i(a)&&c(k(a),(a=>a==Y.prototype||i(k(a))),(()=>!0)))(a)&&0==X(a),Z=JSON.stringify,aa=JSON.parse,ta=a=>new Map(a),ea=(a,t)=>a?.get(t),na=(a,t)=>g([...a?.entries()??[]],(([a,e])=>t(e,a))),sa=(a,t,e)=>i(e)?(J(a,t),a):a?.set(t,e),ra=(a,t,e,n)=>(F(a,t)?n?.(ea(a,t)):sa(a,t,e()),ea(a,t)),oa=(a,t,e,n,s=0)=>c((e?ra:ea)(a,t[s],s>y(t)-2?e:ta),(r=>{if(s>y(t)-2)return n?.(r)&&sa(a,t[s]),r;const o=oa(r,t,e,n,s+1);return U(r)&&sa(a,t[s]),o})),ia=a=>new Set(u(a)||i(a)?a:[a]),ca=(a,t)=>a?.add(t),la=/^\d+$/,ua=ta(),wa=ta(),ya=(a,t,n,s,r,o,l,w={},d=[])=>{let E,g,A,h=0,N=0,$=0;ra(ua,d,(()=>0)),ra(wa,d,(()=>[]));const S=ta(),[C,O,T,I,L]=((a=1,t)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,t.getTransactionMergeableChanges,([[a],[t]])=>!q(a)||!q(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!q(a)||!q(t),t.setContent]:v("Store type not supported by this Persister"))(l,a),[b,D,R]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?f(a):null)??e+t++,t=>{la.test(t)&&y(a)<1e3&&m(a,t)}]})(),s=ta();return[(n,r,o,i=[],c=()=>[])=>{a??=x;const l=t(1);return sa(s,l,[n,r,o,i,c]),ca(oa(r,o??[e],ia),l),l},(t,n,...r)=>p(((a,t=[e])=>{const n=[],s=(a,e)=>e==y(t)?m(n,a):null===t[e]?B(a,(a=>s(a,e+1))):p([t[e],null],(t=>s(ea(a,t),e+1)));return s(a,0),n})(t,n),(t=>B(t,(t=>ea(s,t)[0](a,...n??[],...r))))),a=>c(ea(s,a),(([,t,r])=>(oa(t,r??[e],void 0,(t=>(J(t,a),U(t)?1:0))),sa(s,a),n(a),r))),t=>c(ea(s,t),(([t,,e=[],n,s])=>{const r=(...o)=>{const c=y(o);c==y(e)?t(a,...o,...s(o)):i(e[c])?p(n[c]?.(...o)??[],(a=>r(...o,a))):r(...o,e[c])};r()}))]})(),M=a=>{a!=h&&(h=a,D(S,void 0,h))},_=t=>{(C&&u(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},P=async a=>(2!=h&&(M(1),N++,await k((async()=>{try{const e=await t();u(e)?_(e):a?L(a):v("Content is not an array "+e)}catch(t){o?.(t),a&&L(a)}M(0)}))),x),F=()=>(g&&(r(g),g=void 0),x),j=async a=>(1!=h&&(M(2),$++,await k((async()=>{try{await n(O,a)}catch(a){o?.(a)}M(0)}))),x),Y=()=>(c(A,a.delListener),A=void 0,x),k=async(...a)=>(m(ea(wa,d),...a),await(async()=>{if(!ea(ua,d)){for(sa(ua,d,1);!i(E=f(ea(wa,d)));)try{await E()}catch(a){o?.(a)}sa(ua,d,0)}})(),x),x={load:P,startAutoLoad:async a=>{await F().load(a);try{g=await s((async(a,t)=>{t||a?2!=h&&(M(1),N++,_(t??a),M(0)):await P()}))}catch(a){o?.(a)}return x},stopAutoLoad:F,isAutoLoading:()=>!i(g),save:j,startAutoSave:async()=>(await Y().save(),A=a.addDidFinishTransactionListener((()=>{const a=T();I(a)&&j(a)})),x),stopAutoSave:Y,isAutoSaving:()=>!i(A),getStatus:()=>h,addStatusListener:a=>b(a,S),delListener:t=>(R(t),a),schedule:k,getStore:()=>a,destroy:()=>(ea(wa,d).splice(0,void 0),F().stopAutoSave()),getStats:()=>({loads:N,saves:$}),...w};return G(x)},da=(a,t,e,s,r,o=va,c,l)=>{const u=ta();return[async()=>{u.clear(),g(await e(a,t),(({tn:a,cn:t})=>ca(ra(u,a,ia),t)))},async(t,e)=>((a,t)=>F(ea(u,a),t))(t,e)?H(h(g(await a(L+_(t)),(a=>{return[a[e],l?(t=Q(a,e),n=l,H(V(t,((a,t)=>[t,n(a,t)])))):Q(a,e)];var t,n})),(([a,t])=>!i(a)&&!q(t)))):{},async(t,e,s,l,w,y=!1)=>{const v=ia();V(s??{},(a=>g(z(a??{}),(a=>ca(v,a)))));const p=j(v);if(!y&&w&&A(p)&&F(u,t))return await a("DROP "+O+_(t)),void sa(u,t);const f=ea(u,t),N=ia(j(f));if(A(p)||(F(u,t)?await d(g([e,...p],(async(n,s)=>{J(N,n)||(await a(T+_(t)+"ADD"+_(n)+r),0==s&&await a("CREATE UNIQUE INDEX pk ON "+_(t)+`(${_(e)})`),ca(f,n))}))):(await a("CREATE "+O+_(t)+`(${_(e)}${r} PRIMARY KEY${E(g(p,(a=>n+_(a)+r)))});`),sa(u,t,ia([e,...p])))),await d([...!y&&l?g(j(N),(async n=>{n!=e&&(await a(T+_(t)+"DROP"+_(n)),J(f,n))})):[]]),y)i(s)?await a(I+_(t)+C+" true"):await d(V(s,(async(n,s)=>{i(n)?await a(I+_(t)+C+_(e)+"=$1",[s]):A(p)||await o(a,t,e,z(n),{[s]:c?g(W(n),c):W(n)},f)})));else if(A(p))F(u,t)&&await a(I+_(t)+C+" true");else{const n=h(j(ea(u,t)),(a=>a!=e)),r={},i=[];V(s??{},((a,t)=>{r[t]=g(n,(t=>c?c(a?.[t]):a?.[t])),m(i,t)})),await o(a,t,e,n,r),await a(I+_(t)+C+_(e)+`NOT IN(${P(i)})`,i)}},async t=>{let e;await a("BEGIN");try{e=await t()}catch(a){s?.(a)}return await a("END"),e}]},va=async(a,t,e,s,r)=>{const o=[1];await a("INSERT INTO"+_(t)+"("+((...a)=>E(g(a,_),n))(e,...s)+")VALUES"+E(V(r,(a=>"($"+o[0]+++","+P(a,o)+")")),n)+"ON CONFLICT("+_(e)+")DO UPDATE SET"+E(g(s,(a=>_(a)+"=excluded."+_(a))),n),V(r,((a,t)=>[t,...g(a,(a=>a??null))])).flat())},pa=(a,t,e,n,s,r,o,[i,c,l],u,w,y,d,v,p)=>{const[E,g,A,h]=da(t,u,w,s,v,p),m=ya(a,(async()=>await h((async()=>{return await E(),a=(await g(i,c))[N]?.[l]??"null",aa(a,((a,t)=>""===t?void 0:t));var a}))),(async a=>await h((async()=>{var t;await E(),await A(i,c,{[N]:{[l]:(t=a()??null,Z(t,((a,t)=>void 0===t?"":t)))}},!0,!0)}))),e,n,s,o,{[d]:()=>y,destroy:()=>(m.stopAutoLoad().stopAutoSave(),r(),m)},y);return m},Ea=(a,t,e,n,s,r,o,[c,l,[u,w,y]],v,p,E,g,A,m,f,S)=>{const[C,O,T,I]=da(t,v,p,s,A,m,f,S),L=async(a,t)=>await d(na(l,(async([e,n,s,r],o)=>{t&&!(o in a)||await T(e,n,a[o],s,r,t)}))),b=async(a,t)=>w?await T(y,$,{[N]:a},!0,!0,t):null,D=ya(a,(async()=>await I((async()=>{await C();const a=await(async()=>H(h(await d(na(c,(async([a,t],e)=>[a,await O(e,t)]))),(a=>!q(a[1])))))(),t=await(async()=>u?(await O(y,$))[N]:{})();return q(a)&&i(t)?void 0:[a,t]}))),(async(a,t)=>await I((async()=>{if(await C(),i(t)){const[t,e]=a();await L(t),await b(e)}else await L(t[0],!0),await b(t[1],!0)}))),e,n,s,o,{[g]:()=>E,destroy:()=>(D.stopAutoLoad().stopAutoSave(),r(),D)},E);return D},ga="ColumnName",Aa="store",ha="json",ma=Aa+"TableName",fa=Aa+"Id"+ga,Na=Aa+ga,$a="autoLoadIntervalSeconds",Sa="rowId"+ga,Ca="tableId",Oa="tableName",Ta="deleteEmptyColumns",Ia="deleteEmptyTable",La={mode:ha,[$a]:1},ba={load:0,save:0,[Oa]:t+"_values"},Da=(a,t,e,n,s)=>{const r=ta();return V(a,((a,o)=>{const c=w(W(K(t,l(a)?{[e]:a}:a)),0,X(t));i(c[0])||n(o,c[0])||(s(o,c[0]),sa(r,o,c))})),r},Ra=(a,n,s,r,i,c,u,y,d,v,p="getDb",E)=>{let g,A,h;const m=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,c),[f,N,O,T]=(a=>{const e=(a=>K(La,l(a)?{[ma]:a}:a??{}))(a),n=e[$a];if(e.mode==ha){const a=e[ma]??t;return[1,n,[a,e[fa]??$,e[Na]??Aa],ia(a)]}const{tables:{load:s={},save:r={}}={},values:o={}}=e,i=w(W(K(ba,o)),0,X(ba)),c=i[2],u=ia(c),y=ia(c);return[0,n,[Da(s,{[Ca]:null,[Sa]:$},Ca,(a=>F(y,a)),(a=>ca(u,a))),Da(r,{[Oa]:null,[Sa]:$,[Ta]:0,[Ia]:0},Oa,((a,t)=>F(y,t)),((a,t)=>ca(u,t))),i],u]})(n);return(f?pa:Ea)(a,m,(a=>{let t;const e=()=>t=setInterval((async()=>{try{const[{d:t,s:e,c:n}]=await m(`${S} ${D} d,${R} s,TOTAL_CHANGES() c FROM ${b}${D} JOIN ${b}${R}`);t==g&&e==A&&n==h||(null!=g&&a(),g=t,A=e,h=n)}catch{}}),1e3*N),n=()=>{g=A=h=null,o(t)},s=r((t=>{T.has(t)&&(n(),a(),e())}));return e(),()=>{n(),i(s)}}),(a=>a()),u,y,d,O,j(T),(async(a,t)=>await a(`${S} t.name tn,c.name cn FROM ${M}list()t,${M}info(t.name)c ${C} t.schema='main'AND t.type IN('table','view')AND t.name IN(${P(t)})ORDER BY t.name,c.name`,t)),v,p,e,E,(a=>!0===a?1:!1===a?0:a),void 0)},Ma="change",_a=(a,t,e,n,s)=>Ra(a,e,(async(a,e=[])=>{return await(n=(n,s)=>t.all(a,e,((a,t)=>a?s(a):n(t))),new r(n));var n}),(a=>{const e=(t,e,n)=>a(n);return t.on(Ma,e),e}),(a=>t.off(Ma,a)),n,s,(()=>0),3,t);export{_a as createSqlite3Persister};
|
|
1
|
+
const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),r=Promise,o=clearInterval,i=a=>null==a,c=(a,t,e)=>i(a)?e?.():t(a),l=t=>a(t)==s,u=a=>Array.isArray(a),w=(a,t,e)=>a.slice(t,e),y=a=>a.length,d=async a=>r.all(a),v=a=>{throw Error(a)},p=(a,t)=>a.forEach(t),E=(a,t="")=>a.join(t),g=(a,t)=>a.map(t),A=a=>0==y(a),h=(a,t)=>a.filter(t),m=(a,...t)=>a.push(...t),f=a=>a.shift(),N="_",$="_id",S="SELECT",C="WHERE",O="TABLE",T="ALTER "+O,I="DELETE FROM",L=S+"*FROM",b="pragma_",D="data_version",R="schema_version",M="pragma_table_",_=a=>`"${a.replace(/"/g,'""')}"`,P=(a,t=[1])=>E(g(a,(()=>"$"+t[0]++)),n),F=(a,t)=>a?.has(t)??!1,U=a=>i(a)||0==(a=>a?.size??0)(a),j=a=>[...a?.values()??[]],B=(a,t)=>a?.forEach(t),J=(a,t)=>a?.delete(t),Y=Object,k=a=>Y.getPrototypeOf(a),x=Y.entries,z=Y.keys,G=Y.freeze,H=(a=[])=>Y.fromEntries(a),K=(...a)=>Y.assign({},...a),Q=(a,t)=>(delete a[t],a),V=(a,t)=>g(x(a),(([a,e])=>t(e,a))),W=a=>Y.values(a),X=a=>y(z(a)),q=a=>(a=>!i(a)&&c(k(a),(a=>a==Y.prototype||i(k(a))),(()=>!0)))(a)&&0==X(a),Z=JSON.stringify,aa=JSON.parse,ta=a=>new Map(a),ea=(a,t)=>a?.get(t),na=(a,t)=>g([...a?.entries()??[]],(([a,e])=>t(e,a))),sa=(a,t,e)=>i(e)?(J(a,t),a):a?.set(t,e),ra=(a,t,e,n)=>(F(a,t)?n?.(ea(a,t)):sa(a,t,e()),ea(a,t)),oa=(a,t,e,n,s=0)=>c((e?ra:ea)(a,t[s],s>y(t)-2?e:ta),(r=>{if(s>y(t)-2)return n?.(r)&&sa(a,t[s]),r;const o=oa(r,t,e,n,s+1);return U(r)&&sa(a,t[s]),o})),ia=a=>new Set(u(a)||i(a)?a:[a]),ca=(a,t)=>a?.add(t),la=/^\d+$/,ua=ta(),wa=ta(),ya=(a,t,n,s,r,o,l,w={},d=[])=>{let E,g,A,h=0,N=0,$=0;ra(ua,d,(()=>0)),ra(wa,d,(()=>[]));const S=ta(),[C,O,T,I,L]=((a=1,t)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,t.getTransactionMergeableChanges,([[a],[t]])=>!q(a)||!q(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!q(a)||!q(t),t.setContent]:v("Store type not supported by this Persister"))(l,a),[b,D,R]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?f(a):null)??e+t++,t=>{la.test(t)&&y(a)<1e3&&m(a,t)}]})(),s=ta();return[(n,r,o,i=[],c=()=>[])=>{a??=x;const l=t(1);return sa(s,l,[n,r,o,i,c]),ca(oa(r,o??[e],ia),l),l},(t,n,...r)=>p(((a,t=[e])=>{const n=[],s=(a,e)=>e==y(t)?m(n,a):null===t[e]?B(a,(a=>s(a,e+1))):p([t[e],null],(t=>s(ea(a,t),e+1)));return s(a,0),n})(t,n),(t=>B(t,(t=>ea(s,t)[0](a,...n??[],...r))))),a=>c(ea(s,a),(([,t,r])=>(oa(t,r??[e],void 0,(t=>(J(t,a),U(t)?1:0))),sa(s,a),n(a),r))),t=>c(ea(s,t),(([t,,e=[],n,s])=>{const r=(...o)=>{const c=y(o);c==y(e)?t(a,...o,...s(o)):i(e[c])?p(n[c]?.(...o)??[],(a=>r(...o,a))):r(...o,e[c])};r()}))]})(),M=a=>{a!=h&&(h=a,D(S,void 0,h))},_=t=>{(C&&u(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},P=async a=>(2!=h&&(M(1),N++,await k((async()=>{try{const e=await t();u(e)?_(e):a?L(a):v("Content is not an array: "+e)}catch(t){o?.(t),a&&L(a)}M(0)}))),x),F=()=>(g&&(r(g),g=void 0),x),j=async a=>(1!=h&&(M(2),$++,await k((async()=>{try{await n(O,a)}catch(a){o?.(a)}M(0)}))),x),Y=()=>(c(A,a.delListener),A=void 0,x),k=async(...a)=>(m(ea(wa,d),...a),await(async()=>{if(!ea(ua,d)){for(sa(ua,d,1);!i(E=f(ea(wa,d)));)try{await E()}catch(a){o?.(a)}sa(ua,d,0)}})(),x),x={load:P,startAutoLoad:async a=>{await F().load(a);try{g=await s((async(a,t)=>{t||a?2!=h&&(M(1),N++,_(t??a),M(0)):await P()}))}catch(a){o?.(a)}return x},stopAutoLoad:F,isAutoLoading:()=>!i(g),save:j,startAutoSave:async()=>(await Y().save(),A=a.addDidFinishTransactionListener((()=>{const a=T();I(a)&&j(a)})),x),stopAutoSave:Y,isAutoSaving:()=>!i(A),getStatus:()=>h,addStatusListener:a=>b(a,S),delListener:t=>(R(t),a),schedule:k,getStore:()=>a,destroy:()=>(ea(wa,d).splice(0,void 0),F().stopAutoSave()),getStats:()=>({loads:N,saves:$}),...w};return G(x)},da=(a,t,e,s,r,o=va,c,l)=>{const u=ta();return[async()=>{u.clear(),g(await e(a,t),(({tn:a,cn:t})=>ca(ra(u,a,ia),t)))},async(t,e)=>((a,t)=>F(ea(u,a),t))(t,e)?H(h(g(await a(L+_(t)),(a=>{return[a[e],l?(t=Q(a,e),n=l,H(V(t,((a,t)=>[t,n(a,t)])))):Q(a,e)];var t,n})),(([a,t])=>!i(a)&&!q(t)))):{},async(t,e,s,l,w,y=!1)=>{const v=ia();V(s??{},(a=>g(z(a??{}),(a=>ca(v,a)))));const p=j(v);if(!y&&w&&A(p)&&F(u,t))return await a("DROP "+O+_(t)),void sa(u,t);const f=ea(u,t),N=ia(j(f));if(A(p)||(F(u,t)?await d(g([e,...p],(async(n,s)=>{J(N,n)||(await a(T+_(t)+"ADD"+_(n)+r),0==s&&await a("CREATE UNIQUE INDEX pk ON "+_(t)+`(${_(e)})`),ca(f,n))}))):(await a("CREATE "+O+_(t)+`(${_(e)}${r} PRIMARY KEY${E(g(p,(a=>n+_(a)+r)))});`),sa(u,t,ia([e,...p])))),await d([...!y&&l?g(j(N),(async n=>{n!=e&&(await a(T+_(t)+"DROP"+_(n)),J(f,n))})):[]]),y)i(s)?await a(I+_(t)+C+" true"):await d(V(s,(async(n,s)=>{i(n)?await a(I+_(t)+C+_(e)+"=$1",[s]):A(p)||await o(a,t,e,z(n),{[s]:c?g(W(n),c):W(n)},f)})));else if(A(p))F(u,t)&&await a(I+_(t)+C+" true");else{const n=h(j(ea(u,t)),(a=>a!=e)),r={},i=[];V(s??{},((a,t)=>{r[t]=g(n,(t=>c?c(a?.[t]):a?.[t])),m(i,t)})),await o(a,t,e,n,r),await a(I+_(t)+C+_(e)+`NOT IN(${P(i)})`,i)}},async t=>{let e;await a("BEGIN");try{e=await t()}catch(a){s?.(a)}return await a("END"),e}]},va=async(a,t,e,s,r)=>{const o=[1];await a("INSERT INTO"+_(t)+"("+((...a)=>E(g(a,_),n))(e,...s)+")VALUES"+E(V(r,(a=>"($"+o[0]+++","+P(a,o)+")")),n)+"ON CONFLICT("+_(e)+")DO UPDATE SET"+E(g(s,(a=>_(a)+"=excluded."+_(a))),n),V(r,((a,t)=>[t,...g(a,(a=>a??null))])).flat())},pa=(a,t,e,n,s,r,o,[i,c,l],u,w,y,d,v,p)=>{const[E,g,A,h]=da(t,u,w,s,v,p),m=ya(a,(async()=>await h((async()=>{return await E(),a=(await g(i,c))[N]?.[l]??"null",aa(a,((a,t)=>""===t?void 0:t));var a}))),(async a=>await h((async()=>{var t;await E(),await A(i,c,{[N]:{[l]:(t=a()??null,Z(t,((a,t)=>void 0===t?"":t)))}},!0,!0)}))),e,n,s,o,{[d]:()=>y,destroy:()=>(m.stopAutoLoad().stopAutoSave(),r(),m)},y);return m},Ea=(a,t,e,n,s,r,o,[c,l,[u,w,y]],v,p,E,g,A,m,f,S)=>{const[C,O,T,I]=da(t,v,p,s,A,m,f,S),L=async(a,t)=>await d(na(l,(async([e,n,s,r],o)=>{t&&!(o in a)||await T(e,n,a[o],s,r,t)}))),b=async(a,t)=>w?await T(y,$,{[N]:a},!0,!0,t):null,D=ya(a,(async()=>await I((async()=>{await C();const a=await(async()=>H(h(await d(na(c,(async([a,t],e)=>[a,await O(e,t)]))),(a=>!q(a[1])))))(),t=await(async()=>u?(await O(y,$))[N]:{})();return q(a)&&i(t)?void 0:[a,t]}))),(async(a,t)=>await I((async()=>{if(await C(),i(t)){const[t,e]=a();await L(t),await b(e)}else await L(t[0],!0),await b(t[1],!0)}))),e,n,s,o,{[g]:()=>E,destroy:()=>(D.stopAutoLoad().stopAutoSave(),r(),D)},E);return D},ga="ColumnName",Aa="store",ha="json",ma=Aa+"TableName",fa=Aa+"Id"+ga,Na=Aa+ga,$a="autoLoadIntervalSeconds",Sa="rowId"+ga,Ca="tableId",Oa="tableName",Ta="deleteEmptyColumns",Ia="deleteEmptyTable",La={mode:ha,[$a]:1},ba={load:0,save:0,[Oa]:t+"_values"},Da=(a,t,e,n,s)=>{const r=ta();return V(a,((a,o)=>{const c=w(W(K(t,l(a)?{[e]:a}:a)),0,X(t));i(c[0])||n(o,c[0])||(s(o,c[0]),sa(r,o,c))})),r},Ra=(a,n,s,r,i,c,u,y,d,v,p="getDb",E)=>{let g,A,h;const m=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,c),[f,N,O,T]=(a=>{const e=(a=>K(La,l(a)?{[ma]:a}:a??{}))(a),n=e[$a];if(e.mode==ha){const a=e[ma]??t;return[1,n,[a,e[fa]??$,e[Na]??Aa],ia(a)]}const{tables:{load:s={},save:r={}}={},values:o={}}=e,i=w(W(K(ba,o)),0,X(ba)),c=i[2],u=ia(c),y=ia(c);return[0,n,[Da(s,{[Ca]:null,[Sa]:$},Ca,(a=>F(y,a)),(a=>ca(u,a))),Da(r,{[Oa]:null,[Sa]:$,[Ta]:0,[Ia]:0},Oa,((a,t)=>F(y,t)),((a,t)=>ca(u,t))),i],u]})(n);return(f?pa:Ea)(a,m,(a=>{let t;const e=()=>t=setInterval((async()=>{try{const[{d:t,s:e,c:n}]=await m(`${S} ${D} d,${R} s,TOTAL_CHANGES() c FROM ${b}${D} JOIN ${b}${R}`);t==g&&e==A&&n==h||(null!=g&&a(),g=t,A=e,h=n)}catch{}}),1e3*N),n=()=>{g=A=h=null,o(t)},s=r((t=>{T.has(t)&&(n(),a(),e())}));return e(),()=>{n(),i(s)}}),(a=>a()),u,y,d,O,j(T),(async(a,t)=>await a(`${S} t.name tn,c.name cn FROM ${M}list()t,${M}info(t.name)c ${C} t.schema='main'AND t.type IN('table','view')AND t.name IN(${P(t)})ORDER BY t.name,c.name`,t)),v,p,e,E,(a=>!0===a?1:!1===a?0:a),void 0)},Ma="change",_a=(a,t,e,n,s)=>Ra(a,e,(async(a,e=[])=>{return await(n=(n,s)=>t.all(a,e,((a,t)=>a?s(a):n(t))),new r(n));var n}),(a=>{const e=(t,e,n)=>a(n);return t.on(Ma,e),e}),(a=>t.off(Ma,a)),n,s,(()=>0),3,t);export{_a as createSqlite3Persister};
|
|
Binary file
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{Map as t}from"yjs";const e="t",n="v",a=t=>null==t,s=(t,e,n)=>a(t)?n?.():e(t),o=t=>Array.isArray(t),r=t=>t.length,i=t=>{throw Error(t)},c=(t,e)=>t.forEach(e),l=(t,...e)=>t.push(...e),g=t=>t.shift(),u=Object,d=t=>u.getPrototypeOf(t),y=u.entries,p=u.keys,h=u.freeze,v=(t=[])=>u.fromEntries(t),w=(t,e)=>e in t,S=(t,e)=>((t,e)=>t.map(e))(y(t),(([t,n])=>e(n,t))),f=t=>(t=>!a(t)&&s(d(t),(t=>t==u.prototype||a(d(t))),(()=>!0)))(t)&&0==(t=>r(p(t)))(t),C=(t,e,n)=>(w(t,e)||(t[e]=n()),t[e]),b=t=>a(t)||0==(t=>t?.size??0)(t),A=(t,e)=>t?.forEach(e),M=(t,e)=>t?.delete(e),O=t=>new Map(t),L=(t,e)=>t?.get(e),J=(t,e)=>A(t,((t,n)=>e(n,t))),N=(t,e,n)=>a(n)?(M(t,e),t):t?.set(e,n),z=(t,e,n,a)=>{var s,o;return s=t,o=e,s?.has(o)?a?.(L(t,e)):N(t,e,n()),L(t,e)},D=(t,e,n,a,o=0)=>s((n?z:L)(t,e[o],o>r(e)-2?n:O),(s=>{if(o>r(e)-2)return a?.(s)&&N(t,e[o]),s;const i=D(s,e,n,a,o+1);return b(s)&&N(t,e[o]),i})),E=t=>new Set(o(t)||a(t)?t:[t]),m=/^\d+$/,T=O(),j=O(),k=(t,e,n,u,d,y,p,v={},w=[])=>{let S,C,J,k=0,P=0,x=0;z(T,w,(()=>0)),z(j,w,(()=>[]));const F=O(),[Y,$,q,B,G]=((t=1,e)=>1!=t&&e.isMergeable()?[1,e.getMergeableContent,e.getTransactionMergeableChanges,([[t],[e]])=>!f(t)||!f(e),e.setDefaultContent]:2!=t?[0,e.getContent,e.getTransactionChanges,([t,e])=>!f(t)||!f(e),e.setContent]:i("Store type not supported by this Persister"))(p,t),[H,I,K]=(()=>{let t;const[e,n]=(()=>{const t=[];let e=0;return[n=>(n?g(t):null)??""+e++,e=>{m.test(e)&&r(t)<1e3&&l(t,e)}]})(),o=O();return[(n,a,s,r=[],i=()=>[])=>{t??=_;const c=e(1);var l,g;return N(o,c,[n,a,s,r,i]),l=D(a,s??[""],E),g=c,l?.add(g),c},(e,n,...a)=>c(((t,e=[""])=>{const n=[],a=(t,s)=>s==r(e)?l(n,t):null===e[s]?A(t,(t=>a(t,s+1))):c([e[s],null],(e=>a(L(t,e),s+1)));return a(t,0),n})(e,n),(e=>A(e,(e=>L(o,e)[0](t,...n??[],...a))))),t=>s(L(o,t),(([,e,a])=>(D(e,a??[""],void 0,(e=>(M(e,t),b(e)?1:0))),N(o,t),n(t),a))),e=>s(L(o,e),(([e,,n=[],s,o])=>{const i=(...l)=>{const g=r(l);g==r(n)?e(t,...l,...o(l)):a(n[g])?c(s[g]?.(...l)??[],(t=>i(...l,t))):i(...l,n[g])};i()}))]})(),Q=t=>{t!=k&&(k=t,I(F,void 0,k))},R=e=>{(Y&&o(e?.[0])?1===e?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===e?.[2]?t.applyChanges:t.setContent)(e)},U=async t=>(2!=k&&(Q(1),P++,await Z((async()=>{try{const n=await e();o(n)?R(n):t?G(t):i("Content is not an array "+n)}catch(e){y?.(e),t&&G(t)}Q(0)}))),_),V=()=>(C&&(d(C),C=void 0),_),W=async t=>(1!=k&&(Q(2),x++,await Z((async()=>{try{await n($,t)}catch(t){y?.(t)}Q(0)}))),_),X=()=>(s(J,t.delListener),J=void 0,_),Z=async(...t)=>(l(L(j,w),...t),await(async()=>{if(!L(T,w)){for(N(T,w,1);!a(S=g(L(j,w)));)try{await S()}catch(t){y?.(t)}N(T,w,0)}})(),_),_={load:U,startAutoLoad:async t=>{await V().load(t);try{C=await u((async(t,e)=>{e||t?2!=k&&(Q(1),P++,R(e??t),Q(0)):await U()}))}catch(t){y?.(t)}return _},stopAutoLoad:V,isAutoLoading:()=>!a(C),save:W,startAutoSave:async()=>(await X().save(),J=t.addDidFinishTransactionListener((()=>{const t=q();B(t)&&W(t)})),_),stopAutoSave:X,isAutoSaving:()=>!a(J),getStatus:()=>k,addStatusListener:t=>H(t,F),delListener:e=>(K(e),t),schedule:Z,getStore:()=>t,destroy:()=>(L(j,w).splice(0,void 0),V().stopAutoSave()),getStats:()=>({loads:P,saves:x}),...v};return h(_)},P="delete",x=t=>[t.get(e),t.get(n)],F=(e,n,s,o)=>{const r=a(n)?e:e.get(n)??e.set(n,new t);let i;return S(s,((t,e)=>{o(r,e,t)&&(i=1)})),r.forEach(((t,e)=>{w(s,e)||(r.delete(e),i=1)})),a(n)||r.size||e.delete(n),i},Y=(o,i,l="tinybase",u)=>{const d=i.getMap(l);return k(o,(async()=>d.size?[d.get(e).toJSON(),d.get(n).toJSON()]:void 0),(async(o,r)=>i.transact((()=>((o,r,i)=>{o.size||(o.set(e,new t),o.set(n,new t));const[c,l]=x(o),g=()=>{u=1};let u=1;if(s(i,(([t,e])=>{u=0,S(t,((t,e)=>u?0:a(t)?c.delete(e):s(c.get(e),(e=>S(t,((t,n)=>u?0:a(t)?e.delete(n):s(e.get(n),(e=>S(t,((t,n)=>a(t)?e.delete(n):e.set(n,t)))),g)))),g))),S(e,((t,e)=>u?0:a(t)?l.delete(e):l.set(e,t)))})),u){const[t,e]=r();F(c,void 0,t,((t,e,n)=>F(c,e,n,((t,e,n)=>F(t,e,n,((t,e,n)=>{if(t.get(e)!==n)return t.set(e,n),1})))))),F(l,void 0,e,((t,e,n)=>{l.get(e)!==n&&l.set(e,n)}))}})(d,o,r)))),(t=>{const a=a=>t(void 0,((t,a)=>{if(1==r(a)&&(o=a[0].path,0==r(o)))return[t.get(e).toJSON(),t.get(n).toJSON(),1];var o;const[i,l]=x(t),u={},d={};return c(a,(({path:t,changes:{keys:n}})=>g(t)==e?s(g(t),(e=>{const a=C(u,e,v),o=i.get(e);s(g(t),(t=>{const e=C(a,t,v),s=o.get(t);J(n,((t,{action:n})=>e[t]=n==P?null:s.get(t)))}),(()=>J(n,((t,{action:e})=>a[t]=e==P?null:o.get(t)?.toJSON()))))}),(()=>J(n,((t,{action:e})=>u[t]=e==P?null:i.get(t)?.toJSON())))):J(n,((t,{action:e})=>d[t]=e==P?null:l.get(t))))),[u,d,1]})(d,a));return d.observeDeep(a),a}),(t=>{d.unobserveDeep(t)}),u,1,{getYDoc:()=>i})};export{Y as createYjsPersister};
|
|
1
|
+
import{Map as t}from"yjs";const e="t",n="v",a=t=>null==t,s=(t,e,n)=>a(t)?n?.():e(t),o=t=>Array.isArray(t),r=t=>t.length,i=t=>{throw Error(t)},c=(t,e)=>t.forEach(e),l=(t,...e)=>t.push(...e),g=t=>t.shift(),u=Object,d=t=>u.getPrototypeOf(t),y=u.entries,p=u.keys,h=u.freeze,v=(t=[])=>u.fromEntries(t),w=(t,e)=>e in t,S=(t,e)=>((t,e)=>t.map(e))(y(t),(([t,n])=>e(n,t))),f=t=>(t=>!a(t)&&s(d(t),(t=>t==u.prototype||a(d(t))),(()=>!0)))(t)&&0==(t=>r(p(t)))(t),C=(t,e,n)=>(w(t,e)||(t[e]=n()),t[e]),b=t=>a(t)||0==(t=>t?.size??0)(t),A=(t,e)=>t?.forEach(e),M=(t,e)=>t?.delete(e),O=t=>new Map(t),L=(t,e)=>t?.get(e),J=(t,e)=>A(t,((t,n)=>e(n,t))),N=(t,e,n)=>a(n)?(M(t,e),t):t?.set(e,n),z=(t,e,n,a)=>{var s,o;return s=t,o=e,s?.has(o)?a?.(L(t,e)):N(t,e,n()),L(t,e)},D=(t,e,n,a,o=0)=>s((n?z:L)(t,e[o],o>r(e)-2?n:O),(s=>{if(o>r(e)-2)return a?.(s)&&N(t,e[o]),s;const i=D(s,e,n,a,o+1);return b(s)&&N(t,e[o]),i})),E=t=>new Set(o(t)||a(t)?t:[t]),m=/^\d+$/,T=O(),j=O(),k=(t,e,n,u,d,y,p,v={},w=[])=>{let S,C,J,k=0,P=0,x=0;z(T,w,(()=>0)),z(j,w,(()=>[]));const F=O(),[Y,$,q,B,G]=((t=1,e)=>1!=t&&e.isMergeable()?[1,e.getMergeableContent,e.getTransactionMergeableChanges,([[t],[e]])=>!f(t)||!f(e),e.setDefaultContent]:2!=t?[0,e.getContent,e.getTransactionChanges,([t,e])=>!f(t)||!f(e),e.setContent]:i("Store type not supported by this Persister"))(p,t),[H,I,K]=(()=>{let t;const[e,n]=(()=>{const t=[];let e=0;return[n=>(n?g(t):null)??""+e++,e=>{m.test(e)&&r(t)<1e3&&l(t,e)}]})(),o=O();return[(n,a,s,r=[],i=()=>[])=>{t??=_;const c=e(1);var l,g;return N(o,c,[n,a,s,r,i]),l=D(a,s??[""],E),g=c,l?.add(g),c},(e,n,...a)=>c(((t,e=[""])=>{const n=[],a=(t,s)=>s==r(e)?l(n,t):null===e[s]?A(t,(t=>a(t,s+1))):c([e[s],null],(e=>a(L(t,e),s+1)));return a(t,0),n})(e,n),(e=>A(e,(e=>L(o,e)[0](t,...n??[],...a))))),t=>s(L(o,t),(([,e,a])=>(D(e,a??[""],void 0,(e=>(M(e,t),b(e)?1:0))),N(o,t),n(t),a))),e=>s(L(o,e),(([e,,n=[],s,o])=>{const i=(...l)=>{const g=r(l);g==r(n)?e(t,...l,...o(l)):a(n[g])?c(s[g]?.(...l)??[],(t=>i(...l,t))):i(...l,n[g])};i()}))]})(),Q=t=>{t!=k&&(k=t,I(F,void 0,k))},R=e=>{(Y&&o(e?.[0])?1===e?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===e?.[2]?t.applyChanges:t.setContent)(e)},U=async t=>(2!=k&&(Q(1),P++,await Z((async()=>{try{const n=await e();o(n)?R(n):t?G(t):i("Content is not an array: "+n)}catch(e){y?.(e),t&&G(t)}Q(0)}))),_),V=()=>(C&&(d(C),C=void 0),_),W=async t=>(1!=k&&(Q(2),x++,await Z((async()=>{try{await n($,t)}catch(t){y?.(t)}Q(0)}))),_),X=()=>(s(J,t.delListener),J=void 0,_),Z=async(...t)=>(l(L(j,w),...t),await(async()=>{if(!L(T,w)){for(N(T,w,1);!a(S=g(L(j,w)));)try{await S()}catch(t){y?.(t)}N(T,w,0)}})(),_),_={load:U,startAutoLoad:async t=>{await V().load(t);try{C=await u((async(t,e)=>{e||t?2!=k&&(Q(1),P++,R(e??t),Q(0)):await U()}))}catch(t){y?.(t)}return _},stopAutoLoad:V,isAutoLoading:()=>!a(C),save:W,startAutoSave:async()=>(await X().save(),J=t.addDidFinishTransactionListener((()=>{const t=q();B(t)&&W(t)})),_),stopAutoSave:X,isAutoSaving:()=>!a(J),getStatus:()=>k,addStatusListener:t=>H(t,F),delListener:e=>(K(e),t),schedule:Z,getStore:()=>t,destroy:()=>(L(j,w).splice(0,void 0),V().stopAutoSave()),getStats:()=>({loads:P,saves:x}),...v};return h(_)},P="delete",x=t=>[t.get(e),t.get(n)],F=(e,n,s,o)=>{const r=a(n)?e:e.get(n)??e.set(n,new t);let i;return S(s,((t,e)=>{o(r,e,t)&&(i=1)})),r.forEach(((t,e)=>{w(s,e)||(r.delete(e),i=1)})),a(n)||r.size||e.delete(n),i},Y=(o,i,l="tinybase",u)=>{const d=i.getMap(l);return k(o,(async()=>d.size?[d.get(e).toJSON(),d.get(n).toJSON()]:void 0),(async(o,r)=>i.transact((()=>((o,r,i)=>{o.size||(o.set(e,new t),o.set(n,new t));const[c,l]=x(o),g=()=>{u=1};let u=1;if(s(i,(([t,e])=>{u=0,S(t,((t,e)=>u?0:a(t)?c.delete(e):s(c.get(e),(e=>S(t,((t,n)=>u?0:a(t)?e.delete(n):s(e.get(n),(e=>S(t,((t,n)=>a(t)?e.delete(n):e.set(n,t)))),g)))),g))),S(e,((t,e)=>u?0:a(t)?l.delete(e):l.set(e,t)))})),u){const[t,e]=r();F(c,void 0,t,((t,e,n)=>F(c,e,n,((t,e,n)=>F(t,e,n,((t,e,n)=>{if(t.get(e)!==n)return t.set(e,n),1})))))),F(l,void 0,e,((t,e,n)=>{l.get(e)!==n&&l.set(e,n)}))}})(d,o,r)))),(t=>{const a=a=>t(void 0,((t,a)=>{if(1==r(a)&&(o=a[0].path,0==r(o)))return[t.get(e).toJSON(),t.get(n).toJSON(),1];var o;const[i,l]=x(t),u={},d={};return c(a,(({path:t,changes:{keys:n}})=>g(t)==e?s(g(t),(e=>{const a=C(u,e,v),o=i.get(e);s(g(t),(t=>{const e=C(a,t,v),s=o.get(t);J(n,((t,{action:n})=>e[t]=n==P?null:s.get(t)))}),(()=>J(n,((t,{action:e})=>a[t]=e==P?null:o.get(t)?.toJSON()))))}),(()=>J(n,((t,{action:e})=>u[t]=e==P?null:i.get(t)?.toJSON())))):J(n,((t,{action:e})=>d[t]=e==P?null:l.get(t))))),[u,d,1]})(d,a));return d.observeDeep(a),a}),(t=>{d.unobserveDeep(t)}),u,1,{getYDoc:()=>i})};export{Y as createYjsPersister};
|
|
Binary file
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{Map as t}from"yjs";const e="t",n="v",a=t=>null==t,s=(t,e,n)=>a(t)?n?.():e(t),o=t=>Array.isArray(t),r=t=>t.length,i=t=>{throw Error(t)},c=(t,e)=>t.forEach(e),l=(t,...e)=>t.push(...e),g=t=>t.shift(),u=Object,d=t=>u.getPrototypeOf(t),y=u.entries,p=u.keys,h=u.freeze,v=(t=[])=>u.fromEntries(t),w=(t,e)=>e in t,S=(t,e)=>((t,e)=>t.map(e))(y(t),(([t,n])=>e(n,t))),f=t=>(t=>!a(t)&&s(d(t),(t=>t==u.prototype||a(d(t))),(()=>!0)))(t)&&0==(t=>r(p(t)))(t),C=(t,e,n)=>(w(t,e)||(t[e]=n()),t[e]),b=t=>a(t)||0==(t=>t?.size??0)(t),A=(t,e)=>t?.forEach(e),M=(t,e)=>t?.delete(e),O=t=>new Map(t),L=(t,e)=>t?.get(e),J=(t,e)=>A(t,((t,n)=>e(n,t))),N=(t,e,n)=>a(n)?(M(t,e),t):t?.set(e,n),z=(t,e,n,a)=>{var s,o;return s=t,o=e,s?.has(o)?a?.(L(t,e)):N(t,e,n()),L(t,e)},D=(t,e,n,a,o=0)=>s((n?z:L)(t,e[o],o>r(e)-2?n:O),(s=>{if(o>r(e)-2)return a?.(s)&&N(t,e[o]),s;const i=D(s,e,n,a,o+1);return b(s)&&N(t,e[o]),i})),E=t=>new Set(o(t)||a(t)?t:[t]),m=/^\d+$/,T=O(),j=O(),k=(t,e,n,u,d,y,p,v={},w=[])=>{let S,C,J,k=0,P=0,x=0;z(T,w,(()=>0)),z(j,w,(()=>[]));const F=O(),[Y,$,q,B,G]=((t=1,e)=>1!=t&&e.isMergeable()?[1,e.getMergeableContent,e.getTransactionMergeableChanges,([[t],[e]])=>!f(t)||!f(e),e.setDefaultContent]:2!=t?[0,e.getContent,e.getTransactionChanges,([t,e])=>!f(t)||!f(e),e.setContent]:i("Store type not supported by this Persister"))(p,t),[H,I,K]=(()=>{let t;const[e,n]=(()=>{const t=[];let e=0;return[n=>(n?g(t):null)??""+e++,e=>{m.test(e)&&r(t)<1e3&&l(t,e)}]})(),o=O();return[(n,a,s,r=[],i=()=>[])=>{t??=_;const c=e(1);var l,g;return N(o,c,[n,a,s,r,i]),l=D(a,s??[""],E),g=c,l?.add(g),c},(e,n,...a)=>c(((t,e=[""])=>{const n=[],a=(t,s)=>s==r(e)?l(n,t):null===e[s]?A(t,(t=>a(t,s+1))):c([e[s],null],(e=>a(L(t,e),s+1)));return a(t,0),n})(e,n),(e=>A(e,(e=>L(o,e)[0](t,...n??[],...a))))),t=>s(L(o,t),(([,e,a])=>(D(e,a??[""],void 0,(e=>(M(e,t),b(e)?1:0))),N(o,t),n(t),a))),e=>s(L(o,e),(([e,,n=[],s,o])=>{const i=(...l)=>{const g=r(l);g==r(n)?e(t,...l,...o(l)):a(n[g])?c(s[g]?.(...l)??[],(t=>i(...l,t))):i(...l,n[g])};i()}))]})(),Q=t=>{t!=k&&(k=t,I(F,void 0,k))},R=e=>{(Y&&o(e?.[0])?1===e?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===e?.[2]?t.applyChanges:t.setContent)(e)},U=async t=>(2!=k&&(Q(1),P++,await Z((async()=>{try{const n=await e();o(n)?R(n):t?G(t):i("Content is not an array "+n)}catch(e){y?.(e),t&&G(t)}Q(0)}))),_),V=()=>(C&&(d(C),C=void 0),_),W=async t=>(1!=k&&(Q(2),x++,await Z((async()=>{try{await n($,t)}catch(t){y?.(t)}Q(0)}))),_),X=()=>(s(J,t.delListener),J=void 0,_),Z=async(...t)=>(l(L(j,w),...t),await(async()=>{if(!L(T,w)){for(N(T,w,1);!a(S=g(L(j,w)));)try{await S()}catch(t){y?.(t)}N(T,w,0)}})(),_),_={load:U,startAutoLoad:async t=>{await V().load(t);try{C=await u((async(t,e)=>{e||t?2!=k&&(Q(1),P++,R(e??t),Q(0)):await U()}))}catch(t){y?.(t)}return _},stopAutoLoad:V,isAutoLoading:()=>!a(C),save:W,startAutoSave:async()=>(await X().save(),J=t.addDidFinishTransactionListener((()=>{const t=q();B(t)&&W(t)})),_),stopAutoSave:X,isAutoSaving:()=>!a(J),getStatus:()=>k,addStatusListener:t=>H(t,F),delListener:e=>(K(e),t),schedule:Z,getStore:()=>t,destroy:()=>(L(j,w).splice(0,void 0),V().stopAutoSave()),getStats:()=>({loads:P,saves:x}),...v};return h(_)},P="delete",x=t=>[t.get(e),t.get(n)],F=(e,n,s,o)=>{const r=a(n)?e:e.get(n)??e.set(n,new t);let i;return S(s,((t,e)=>{o(r,e,t)&&(i=1)})),r.forEach(((t,e)=>{w(s,e)||(r.delete(e),i=1)})),a(n)||r.size||e.delete(n),i},Y=(o,i,l="tinybase",u)=>{const d=i.getMap(l);return k(o,(async()=>d.size?[d.get(e).toJSON(),d.get(n).toJSON()]:void 0),(async(o,r)=>i.transact((()=>((o,r,i)=>{o.size||(o.set(e,new t),o.set(n,new t));const[c,l]=x(o),g=()=>{u=1};let u=1;if(s(i,(([t,e])=>{u=0,S(t,((t,e)=>u?0:a(t)?c.delete(e):s(c.get(e),(e=>S(t,((t,n)=>u?0:a(t)?e.delete(n):s(e.get(n),(e=>S(t,((t,n)=>a(t)?e.delete(n):e.set(n,t)))),g)))),g))),S(e,((t,e)=>u?0:a(t)?l.delete(e):l.set(e,t)))})),u){const[t,e]=r();F(c,void 0,t,((t,e,n)=>F(c,e,n,((t,e,n)=>F(t,e,n,((t,e,n)=>{if(t.get(e)!==n)return t.set(e,n),1})))))),F(l,void 0,e,((t,e,n)=>{l.get(e)!==n&&l.set(e,n)}))}})(d,o,r)))),(t=>{const a=a=>t(void 0,((t,a)=>{if(1==r(a)&&(o=a[0].path,0==r(o)))return[t.get(e).toJSON(),t.get(n).toJSON(),1];var o;const[i,l]=x(t),u={},d={};return c(a,(({path:t,changes:{keys:n}})=>g(t)==e?s(g(t),(e=>{const a=C(u,e,v),o=i.get(e);s(g(t),(t=>{const e=C(a,t,v),s=o.get(t);J(n,((t,{action:n})=>e[t]=n==P?null:s.get(t)))}),(()=>J(n,((t,{action:e})=>a[t]=e==P?null:o.get(t)?.toJSON()))))}),(()=>J(n,((t,{action:e})=>u[t]=e==P?null:i.get(t)?.toJSON())))):J(n,((t,{action:e})=>d[t]=e==P?null:l.get(t))))),[u,d,1]})(d,a));return d.observeDeep(a),a}),(t=>{d.unobserveDeep(t)}),u,1,{getYDoc:()=>i})};export{Y as createYjsPersister};
|
|
1
|
+
import{Map as t}from"yjs";const e="t",n="v",a=t=>null==t,s=(t,e,n)=>a(t)?n?.():e(t),o=t=>Array.isArray(t),r=t=>t.length,i=t=>{throw Error(t)},c=(t,e)=>t.forEach(e),l=(t,...e)=>t.push(...e),g=t=>t.shift(),u=Object,d=t=>u.getPrototypeOf(t),y=u.entries,p=u.keys,h=u.freeze,v=(t=[])=>u.fromEntries(t),w=(t,e)=>e in t,S=(t,e)=>((t,e)=>t.map(e))(y(t),(([t,n])=>e(n,t))),f=t=>(t=>!a(t)&&s(d(t),(t=>t==u.prototype||a(d(t))),(()=>!0)))(t)&&0==(t=>r(p(t)))(t),C=(t,e,n)=>(w(t,e)||(t[e]=n()),t[e]),b=t=>a(t)||0==(t=>t?.size??0)(t),A=(t,e)=>t?.forEach(e),M=(t,e)=>t?.delete(e),O=t=>new Map(t),L=(t,e)=>t?.get(e),J=(t,e)=>A(t,((t,n)=>e(n,t))),N=(t,e,n)=>a(n)?(M(t,e),t):t?.set(e,n),z=(t,e,n,a)=>{var s,o;return s=t,o=e,s?.has(o)?a?.(L(t,e)):N(t,e,n()),L(t,e)},D=(t,e,n,a,o=0)=>s((n?z:L)(t,e[o],o>r(e)-2?n:O),(s=>{if(o>r(e)-2)return a?.(s)&&N(t,e[o]),s;const i=D(s,e,n,a,o+1);return b(s)&&N(t,e[o]),i})),E=t=>new Set(o(t)||a(t)?t:[t]),m=/^\d+$/,T=O(),j=O(),k=(t,e,n,u,d,y,p,v={},w=[])=>{let S,C,J,k=0,P=0,x=0;z(T,w,(()=>0)),z(j,w,(()=>[]));const F=O(),[Y,$,q,B,G]=((t=1,e)=>1!=t&&e.isMergeable()?[1,e.getMergeableContent,e.getTransactionMergeableChanges,([[t],[e]])=>!f(t)||!f(e),e.setDefaultContent]:2!=t?[0,e.getContent,e.getTransactionChanges,([t,e])=>!f(t)||!f(e),e.setContent]:i("Store type not supported by this Persister"))(p,t),[H,I,K]=(()=>{let t;const[e,n]=(()=>{const t=[];let e=0;return[n=>(n?g(t):null)??""+e++,e=>{m.test(e)&&r(t)<1e3&&l(t,e)}]})(),o=O();return[(n,a,s,r=[],i=()=>[])=>{t??=_;const c=e(1);var l,g;return N(o,c,[n,a,s,r,i]),l=D(a,s??[""],E),g=c,l?.add(g),c},(e,n,...a)=>c(((t,e=[""])=>{const n=[],a=(t,s)=>s==r(e)?l(n,t):null===e[s]?A(t,(t=>a(t,s+1))):c([e[s],null],(e=>a(L(t,e),s+1)));return a(t,0),n})(e,n),(e=>A(e,(e=>L(o,e)[0](t,...n??[],...a))))),t=>s(L(o,t),(([,e,a])=>(D(e,a??[""],void 0,(e=>(M(e,t),b(e)?1:0))),N(o,t),n(t),a))),e=>s(L(o,e),(([e,,n=[],s,o])=>{const i=(...l)=>{const g=r(l);g==r(n)?e(t,...l,...o(l)):a(n[g])?c(s[g]?.(...l)??[],(t=>i(...l,t))):i(...l,n[g])};i()}))]})(),Q=t=>{t!=k&&(k=t,I(F,void 0,k))},R=e=>{(Y&&o(e?.[0])?1===e?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===e?.[2]?t.applyChanges:t.setContent)(e)},U=async t=>(2!=k&&(Q(1),P++,await Z((async()=>{try{const n=await e();o(n)?R(n):t?G(t):i("Content is not an array: "+n)}catch(e){y?.(e),t&&G(t)}Q(0)}))),_),V=()=>(C&&(d(C),C=void 0),_),W=async t=>(1!=k&&(Q(2),x++,await Z((async()=>{try{await n($,t)}catch(t){y?.(t)}Q(0)}))),_),X=()=>(s(J,t.delListener),J=void 0,_),Z=async(...t)=>(l(L(j,w),...t),await(async()=>{if(!L(T,w)){for(N(T,w,1);!a(S=g(L(j,w)));)try{await S()}catch(t){y?.(t)}N(T,w,0)}})(),_),_={load:U,startAutoLoad:async t=>{await V().load(t);try{C=await u((async(t,e)=>{e||t?2!=k&&(Q(1),P++,R(e??t),Q(0)):await U()}))}catch(t){y?.(t)}return _},stopAutoLoad:V,isAutoLoading:()=>!a(C),save:W,startAutoSave:async()=>(await X().save(),J=t.addDidFinishTransactionListener((()=>{const t=q();B(t)&&W(t)})),_),stopAutoSave:X,isAutoSaving:()=>!a(J),getStatus:()=>k,addStatusListener:t=>H(t,F),delListener:e=>(K(e),t),schedule:Z,getStore:()=>t,destroy:()=>(L(j,w).splice(0,void 0),V().stopAutoSave()),getStats:()=>({loads:P,saves:x}),...v};return h(_)},P="delete",x=t=>[t.get(e),t.get(n)],F=(e,n,s,o)=>{const r=a(n)?e:e.get(n)??e.set(n,new t);let i;return S(s,((t,e)=>{o(r,e,t)&&(i=1)})),r.forEach(((t,e)=>{w(s,e)||(r.delete(e),i=1)})),a(n)||r.size||e.delete(n),i},Y=(o,i,l="tinybase",u)=>{const d=i.getMap(l);return k(o,(async()=>d.size?[d.get(e).toJSON(),d.get(n).toJSON()]:void 0),(async(o,r)=>i.transact((()=>((o,r,i)=>{o.size||(o.set(e,new t),o.set(n,new t));const[c,l]=x(o),g=()=>{u=1};let u=1;if(s(i,(([t,e])=>{u=0,S(t,((t,e)=>u?0:a(t)?c.delete(e):s(c.get(e),(e=>S(t,((t,n)=>u?0:a(t)?e.delete(n):s(e.get(n),(e=>S(t,((t,n)=>a(t)?e.delete(n):e.set(n,t)))),g)))),g))),S(e,((t,e)=>u?0:a(t)?l.delete(e):l.set(e,t)))})),u){const[t,e]=r();F(c,void 0,t,((t,e,n)=>F(c,e,n,((t,e,n)=>F(t,e,n,((t,e,n)=>{if(t.get(e)!==n)return t.set(e,n),1})))))),F(l,void 0,e,((t,e,n)=>{l.get(e)!==n&&l.set(e,n)}))}})(d,o,r)))),(t=>{const a=a=>t(void 0,((t,a)=>{if(1==r(a)&&(o=a[0].path,0==r(o)))return[t.get(e).toJSON(),t.get(n).toJSON(),1];var o;const[i,l]=x(t),u={},d={};return c(a,(({path:t,changes:{keys:n}})=>g(t)==e?s(g(t),(e=>{const a=C(u,e,v),o=i.get(e);s(g(t),(t=>{const e=C(a,t,v),s=o.get(t);J(n,((t,{action:n})=>e[t]=n==P?null:s.get(t)))}),(()=>J(n,((t,{action:e})=>a[t]=e==P?null:o.get(t)?.toJSON()))))}),(()=>J(n,((t,{action:e})=>u[t]=e==P?null:i.get(t)?.toJSON())))):J(n,((t,{action:e})=>d[t]=e==P?null:l.get(t))))),[u,d,1]})(d,a));return d.observeDeep(a),a}),(t=>{d.unobserveDeep(t)}),u,1,{getYDoc:()=>i})};export{Y as createYjsPersister};
|
|
Binary file
|
|
@@ -1 +1 @@
|
|
|
1
|
-
const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),i=Promise,r=clearInterval,o=a=>null==a,c=(a,t,e)=>o(a)?e?.():t(a),l=t=>a(t)==s,E=a=>Array.isArray(a),w=(a,t,e)=>a.slice(t,e),y=a=>a.length,d=async a=>i.all(a),u=a=>{throw Error(a)},R=(a,t)=>a.forEach(t),A=(a,t="")=>a.join(t),T=(a,t)=>a.map(t),N=a=>0==y(a),g=(a,t)=>a.filter(t),O=(a,...t)=>a.push(...t),$=a=>a.shift(),p=Object,v=a=>p.getPrototypeOf(a),m=p.entries,C=p.keys,L=p.freeze,I=(a=[])=>p.fromEntries(a),S=(...a)=>p.assign({},...a),_=(a,t)=>(delete a[t],a),h=(a,t)=>T(m(a),(([a,e])=>t(e,a))),b=a=>p.values(a),f=a=>y(C(a)),D=a=>(a=>!o(a)&&c(v(a),(a=>a==p.prototype||o(v(a))),(()=>!0)))(a)&&0==f(a),M=(a,t)=>a?.has(t)??!1,P=a=>o(a)||0==(a=>a?.size??0)(a),F=a=>[...a?.values()??[]],U=(a,t)=>a?.forEach(t),G=(a,t)=>a?.delete(t),B=a=>new Map(a),j=(a,t)=>a?.get(t),Y=(a,t)=>T([...a?.entries()??[]],(([a,e])=>t(e,a))),x=(a,t,e)=>o(e)?(G(a,t),a):a?.set(t,e),H=(a,t,e,n)=>(M(a,t)?n?.(j(a,t)):x(a,t,e()),j(a,t)),X=(a,t,e,n,s=0)=>c((e?H:j)(a,t[s],s>y(t)-2?e:B),(i=>{if(s>y(t)-2)return n?.(i)&&x(a,t[s]),i;const r=X(i,t,e,n,s+1);return P(i)&&x(a,t[s]),r})),J=a=>new Set(E(a)||o(a)?a:[a]),W=(a,t)=>a?.add(t),k=/^\d+$/,q={Idle:0,Loading:1,Saving:2},z={StoreOnly:1,MergeableStoreOnly:2,StoreOrMergeableStore:3},K=B(),V=B(),Q=(a,t,n,s,i,r,l,w={},d=[])=>{let A,T,N,g=0,p=0,v=0;H(K,d,(()=>0)),H(V,d,(()=>[]));const m=B(),[C,I,S,_,h]=((a=1,t)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,t.getTransactionMergeableChanges,([[a],[t]])=>!D(a)||!D(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!D(a)||!D(t),t.setContent]:u("Store type not supported by this Persister"))(l,a),[b,f,M]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?$(a):null)??e+t++,t=>{k.test(t)&&y(a)<1e3&&O(a,t)}]})(),s=B();return[(n,i,r,o=[],c=()=>[])=>{a??=ta;const l=t(1);return x(s,l,[n,i,r,o,c]),W(X(i,r??[e],J),l),l},(t,n,...i)=>R(((a,t=[e])=>{const n=[],s=(a,e)=>e==y(t)?O(n,a):null===t[e]?U(a,(a=>s(a,e+1))):R([t[e],null],(t=>s(j(a,t),e+1)));return s(a,0),n})(t,n),(t=>U(t,(t=>j(s,t)[0](a,...n??[],...i))))),a=>c(j(s,a),(([,t,i])=>(X(t,i??[e],void 0,(t=>(G(t,a),P(t)?1:0))),x(s,a),n(a),i))),t=>c(j(s,t),(([t,,e=[],n,s])=>{const i=(...r)=>{const c=y(r);c==y(e)?t(a,...r,...s(r)):o(e[c])?R(n[c]?.(...r)??[],(a=>i(...r,a))):i(...r,e[c])};i()}))]})(),F=a=>{a!=g&&(g=a,f(m,void 0,g))},Y=t=>{(C&&E(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},q=async a=>(2!=g&&(F(1),p++,await aa((async()=>{try{const e=await t();E(e)?Y(e):a?h(a):u("Content is not an array "+e)}catch(t){r?.(t),a&&h(a)}F(0)}))),ta),z=()=>(T&&(i(T),T=void 0),ta),Q=async a=>(1!=g&&(F(2),v++,await aa((async()=>{try{await n(I,a)}catch(a){r?.(a)}F(0)}))),ta),Z=()=>(c(N,a.delListener),N=void 0,ta),aa=async(...a)=>(O(j(V,d),...a),await(async()=>{if(!j(K,d)){for(x(K,d,1);!o(A=$(j(V,d)));)try{await A()}catch(a){r?.(a)}x(K,d,0)}})(),ta),ta={load:q,startAutoLoad:async a=>{await z().load(a);try{T=await s((async(a,t)=>{t||a?2!=g&&(F(1),p++,Y(t??a),F(0)):await q()}))}catch(a){r?.(a)}return ta},stopAutoLoad:z,isAutoLoading:()=>!o(T),save:Q,startAutoSave:async()=>(await Z().save(),N=a.addDidFinishTransactionListener((()=>{const a=S();_(a)&&Q(a)})),ta),stopAutoSave:Z,isAutoSaving:()=>!o(N),getStatus:()=>g,addStatusListener:a=>b(a,m),delListener:t=>(M(t),a),schedule:aa,getStore:()=>a,destroy:()=>(j(V,d).splice(0,void 0),z().stopAutoSave()),getStats:()=>({loads:p,saves:v}),...w};return L(ta)},Z="_",aa="_id",ta="SELECT",ea="WHERE",na="TABLE",sa="ALTER "+na,ia="DELETE FROM",ra=ta+"*FROM",oa="pragma_",ca="data_version",la="schema_version",Ea="pragma_table_",wa=(a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a,ya=a=>`"${a.replace(/"/g,'""')}"`,da=(a,t=[1])=>A(T(a,(()=>"$"+t[0]++)),n),ua=JSON.stringify,Ra=JSON.parse,Aa=(a,t,e,s,i,r=Ta,c,l)=>{const E=B();return[async()=>{E.clear(),T(await e(a,t),(({tn:a,cn:t})=>W(H(E,a,J),t)))},async(t,e)=>((a,t)=>M(j(E,a),t))(t,e)?I(g(T(await a(ra+ya(t)),(a=>{return[a[e],l?(t=_(a,e),n=l,I(h(t,((a,t)=>[t,n(a,t)])))):_(a,e)];var t,n})),(([a,t])=>!o(a)&&!D(t)))):{},async(t,e,s,l,w,y=!1)=>{const u=J();h(s??{},(a=>T(C(a??{}),(a=>W(u,a)))));const R=F(u);if(!y&&w&&N(R)&&M(E,t))return await a("DROP "+na+ya(t)),void x(E,t);const $=j(E,t),p=J(F($));if(N(R)||(M(E,t)?await d(T([e,...R],(async(n,s)=>{G(p,n)||(await a(sa+ya(t)+"ADD"+ya(n)+i),0==s&&await a("CREATE UNIQUE INDEX pk ON "+ya(t)+`(${ya(e)})`),W($,n))}))):(await a("CREATE "+na+ya(t)+`(${ya(e)}${i} PRIMARY KEY${A(T(R,(a=>n+ya(a)+i)))});`),x(E,t,J([e,...R])))),await d([...!y&&l?T(F(p),(async n=>{n!=e&&(await a(sa+ya(t)+"DROP"+ya(n)),G($,n))})):[]]),y)o(s)?await a(ia+ya(t)+ea+" true"):await d(h(s,(async(n,s)=>{o(n)?await a(ia+ya(t)+ea+ya(e)+"=$1",[s]):N(R)||await r(a,t,e,C(n),{[s]:c?T(b(n),c):b(n)},$)})));else if(N(R))M(E,t)&&await a(ia+ya(t)+ea+" true");else{const n=g(F(j(E,t)),(a=>a!=e)),i={},o=[];h(s??{},((a,t)=>{i[t]=T(n,(t=>c?c(a?.[t]):a?.[t])),O(o,t)})),await r(a,t,e,n,i),await a(ia+ya(t)+ea+ya(e)+`NOT IN(${da(o)})`,o)}},async t=>{let e;await a("BEGIN");try{e=await t()}catch(a){s?.(a)}return await a("END"),e}]},Ta=async(a,t,e,s,i)=>{const r=[1];await a("INSERT INTO"+ya(t)+"("+((...a)=>A(T(a,ya),n))(e,...s)+")VALUES"+A(h(i,(a=>"($"+r[0]+++","+da(a,r)+")")),n)+"ON CONFLICT("+ya(e)+")DO UPDATE SET"+A(T(s,(a=>ya(a)+"=excluded."+ya(a))),n),h(i,((a,t)=>[t,...T(a,(a=>a??null))])).flat())},Na=(a,t,e,n,s,i,r,[o,c,l],E,w,y,d,u,R)=>{const[A,T,N,g]=Aa(t,E,w,s,u,R),O=Q(a,(async()=>await g((async()=>{return await A(),a=(await T(o,c))[Z]?.[l]??"null",Ra(a,((a,t)=>""===t?void 0:t));var a}))),(async a=>await g((async()=>{var t;await A(),await N(o,c,{[Z]:{[l]:(t=a()??null,ua(t,((a,t)=>void 0===t?"":t)))}},!0,!0)}))),e,n,s,r,{[d]:()=>y,destroy:()=>(O.stopAutoLoad().stopAutoSave(),i(),O)},y);return O},ga=(a,t,e,n,s,i,r,[c,l,[E,w,y]],u,R,A,T,N,O,$,p)=>{const[v,m,C,L]=Aa(t,u,R,s,N,O,$,p),S=async(a,t)=>await d(Y(l,(async([e,n,s,i],r)=>{t&&!(r in a)||await C(e,n,a[r],s,i,t)}))),_=async(a,t)=>w?await C(y,aa,{[Z]:a},!0,!0,t):null,h=Q(a,(async()=>await L((async()=>{await v();const a=await(async()=>I(g(await d(Y(c,(async([a,t],e)=>[a,await m(e,t)]))),(a=>!D(a[1])))))(),t=await(async()=>E?(await m(y,aa))[Z]:{})();return D(a)&&o(t)?void 0:[a,t]}))),(async(a,t)=>await L((async()=>{if(await v(),o(t)){const[t,e]=a();await S(t),await _(e)}else await S(t[0],!0),await _(t[1],!0)}))),e,n,s,r,{[T]:()=>A,destroy:()=>(h.stopAutoLoad().stopAutoSave(),i(),h)},A);return h},Oa="ColumnName",$a="store",pa="json",va=$a+"TableName",ma=$a+"Id"+Oa,Ca=$a+Oa,La="autoLoadIntervalSeconds",Ia="rowId"+Oa,Sa="tableId",_a="tableName",ha="deleteEmptyColumns",ba="deleteEmptyTable",fa={mode:pa,[La]:1},Da={load:0,save:0,[_a]:t+"_values"},Ma=(a,t,e,n,s)=>{const i=B();return h(a,((a,r)=>{const c=w(b(S(t,l(a)?{[e]:a}:a)),0,f(t));o(c[0])||n(r,c[0])||(s(r,c[0]),x(i,r,c))})),i},Pa=a=>{const e=(a=>S(fa,l(a)?{[va]:a}:a??{}))(a),n=e[La];if(e.mode==pa){const a=e[va]??t;return[1,n,[a,e[ma]??aa,e[Ca]??$a],J(a)]}const{tables:{load:s={},save:i={}}={},values:r={}}=e,o=w(b(S(Da,r)),0,f(Da)),c=o[2],E=J(c),y=J(c);return[0,n,[Ma(s,{[Sa]:null,[Ia]:aa},Sa,(a=>M(y,a)),(a=>W(E,a))),Ma(i,{[_a]:null,[Ia]:aa,[ha]:0,[ba]:0},_a,((a,t)=>M(y,t)),((a,t)=>W(E,t))),o],E]},Fa=(a,t,n,s,i,o,c,l,E,w,y="getDb",d)=>{let u,R,A;const T=wa(n,o),[N,g,O,$]=Pa(t);return(N?Na:ga)(a,T,(a=>{let t;const e=()=>t=setInterval((async()=>{try{const[{d:t,s:e,c:n}]=await T(`${ta} ${ca} d,${la} s,TOTAL_CHANGES() c FROM ${oa}${ca} JOIN ${oa}${la}`);t==u&&e==R&&n==A||(null!=u&&a(),u=t,R=e,A=n)}catch{}}),1e3*g),n=()=>{u=R=A=null,r(t)},o=s((t=>{$.has(t)&&(n(),a(),e())}));return e(),()=>{n(),i(o)}}),(a=>a()),c,l,E,O,F($),(async(a,t)=>await a(`${ta} t.name tn,c.name cn FROM ${Ea}list()t,${Ea}info(t.name)c ${ea} t.schema='main'AND t.type IN('table','view')AND t.name IN(${da(t)})ORDER BY t.name,c.name`,t)),w,y,e,d,(a=>!0===a?1:!1===a?0:a),void 0)},Ua=t,Ga=/^([cd]:)(.+)/,Ba=t+"_data",ja=t+"_table",Ya=(a,t,e,n,s,i,r,o,l,E,w="getDb")=>{const y=wa(e,i),[u,,R,A]=Pa(t),N=async a=>{await y(`CREATE OR REPLACE TRIGGER ${ya(Ba+"_"+a)} AFTER INSERT OR UPDATE OR DELETE ON ${ya(a)} EXECUTE FUNCTION ${Ba}()`)};return(u?Na:ga)(a,y,(async a=>{await y(`CREATE OR REPLACE FUNCTION ${ja}()RETURNS event_trigger AS $t2$ DECLARE row record; BEGIN FOR row IN SELECT object_identity FROM pg_event_trigger_ddl_commands()WHERE command_tag='CREATE TABLE' LOOP PERFORM pg_notify('${Ua}','c:'||SPLIT_PART(row.object_identity,'.',2));END LOOP;END;$t2$ LANGUAGE plpgsql;`);try{await y(`CREATE EVENT TRIGGER ${ja} ON ddl_command_end WHEN TAG IN('CREATE TABLE')EXECUTE FUNCTION ${ja}();`)}catch{}return await y(`CREATE OR REPLACE FUNCTION ${Ba}()RETURNS trigger AS $t1$ BEGIN PERFORM pg_notify('${Ua}','d:'||TG_TABLE_NAME);RETURN NULL;END;$t1$ LANGUAGE plpgsql;`),await d(T(F(A),(async a=>{await y(`CREATE TABLE IF NOT EXISTS ${ya(a)}("_id"text PRIMARY KEY)`),await N(a)}))),await n(Ua,(async t=>{return await c((e=t,n=Ga,e?.match(n)),(async([,t,e])=>{M(A,e)&&("c:"==t&&await N(e),a())}));var e,n}))}),s,r,o,l,R,F(A),(async(a,t)=>await a(`${ta} table_name tn,column_name cn FROM information_schema.columns ${ea} table_schema='public'AND table_name IN(${da(t)})`,t)),E,w,"text",void 0,(a=>ua(a)),(a=>Ra(a)))};export{z as Persists,q as Status,Q as createCustomPersister,Ya as createCustomPostgreSqlPersister,Fa as createCustomSqlitePersister};
|
|
1
|
+
const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),i=Promise,r=clearInterval,o=a=>null==a,c=(a,t,e)=>o(a)?e?.():t(a),l=t=>a(t)==s,E=a=>Array.isArray(a),w=(a,t,e)=>a.slice(t,e),y=a=>a.length,d=async a=>i.all(a),u=a=>{throw Error(a)},R=(a,t)=>a.forEach(t),A=(a,t="")=>a.join(t),T=(a,t)=>a.map(t),N=a=>0==y(a),g=(a,t)=>a.filter(t),O=(a,...t)=>a.push(...t),$=a=>a.shift(),p=Object,v=a=>p.getPrototypeOf(a),m=p.entries,C=p.keys,L=p.freeze,I=(a=[])=>p.fromEntries(a),S=(...a)=>p.assign({},...a),_=(a,t)=>(delete a[t],a),h=(a,t)=>T(m(a),(([a,e])=>t(e,a))),b=a=>p.values(a),f=a=>y(C(a)),D=a=>(a=>!o(a)&&c(v(a),(a=>a==p.prototype||o(v(a))),(()=>!0)))(a)&&0==f(a),M=(a,t)=>a?.has(t)??!1,P=a=>o(a)||0==(a=>a?.size??0)(a),F=a=>[...a?.values()??[]],U=(a,t)=>a?.forEach(t),G=(a,t)=>a?.delete(t),B=a=>new Map(a),j=(a,t)=>a?.get(t),Y=(a,t)=>T([...a?.entries()??[]],(([a,e])=>t(e,a))),x=(a,t,e)=>o(e)?(G(a,t),a):a?.set(t,e),H=(a,t,e,n)=>(M(a,t)?n?.(j(a,t)):x(a,t,e()),j(a,t)),X=(a,t,e,n,s=0)=>c((e?H:j)(a,t[s],s>y(t)-2?e:B),(i=>{if(s>y(t)-2)return n?.(i)&&x(a,t[s]),i;const r=X(i,t,e,n,s+1);return P(i)&&x(a,t[s]),r})),J=a=>new Set(E(a)||o(a)?a:[a]),W=(a,t)=>a?.add(t),k=/^\d+$/,q={Idle:0,Loading:1,Saving:2},z={StoreOnly:1,MergeableStoreOnly:2,StoreOrMergeableStore:3},K=B(),V=B(),Q=(a,t,n,s,i,r,l,w={},d=[])=>{let A,T,N,g=0,p=0,v=0;H(K,d,(()=>0)),H(V,d,(()=>[]));const m=B(),[C,I,S,_,h]=((a=1,t)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,t.getTransactionMergeableChanges,([[a],[t]])=>!D(a)||!D(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!D(a)||!D(t),t.setContent]:u("Store type not supported by this Persister"))(l,a),[b,f,M]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?$(a):null)??e+t++,t=>{k.test(t)&&y(a)<1e3&&O(a,t)}]})(),s=B();return[(n,i,r,o=[],c=()=>[])=>{a??=ta;const l=t(1);return x(s,l,[n,i,r,o,c]),W(X(i,r??[e],J),l),l},(t,n,...i)=>R(((a,t=[e])=>{const n=[],s=(a,e)=>e==y(t)?O(n,a):null===t[e]?U(a,(a=>s(a,e+1))):R([t[e],null],(t=>s(j(a,t),e+1)));return s(a,0),n})(t,n),(t=>U(t,(t=>j(s,t)[0](a,...n??[],...i))))),a=>c(j(s,a),(([,t,i])=>(X(t,i??[e],void 0,(t=>(G(t,a),P(t)?1:0))),x(s,a),n(a),i))),t=>c(j(s,t),(([t,,e=[],n,s])=>{const i=(...r)=>{const c=y(r);c==y(e)?t(a,...r,...s(r)):o(e[c])?R(n[c]?.(...r)??[],(a=>i(...r,a))):i(...r,e[c])};i()}))]})(),F=a=>{a!=g&&(g=a,f(m,void 0,g))},Y=t=>{(C&&E(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},q=async a=>(2!=g&&(F(1),p++,await aa((async()=>{try{const e=await t();E(e)?Y(e):a?h(a):u("Content is not an array: "+e)}catch(t){r?.(t),a&&h(a)}F(0)}))),ta),z=()=>(T&&(i(T),T=void 0),ta),Q=async a=>(1!=g&&(F(2),v++,await aa((async()=>{try{await n(I,a)}catch(a){r?.(a)}F(0)}))),ta),Z=()=>(c(N,a.delListener),N=void 0,ta),aa=async(...a)=>(O(j(V,d),...a),await(async()=>{if(!j(K,d)){for(x(K,d,1);!o(A=$(j(V,d)));)try{await A()}catch(a){r?.(a)}x(K,d,0)}})(),ta),ta={load:q,startAutoLoad:async a=>{await z().load(a);try{T=await s((async(a,t)=>{t||a?2!=g&&(F(1),p++,Y(t??a),F(0)):await q()}))}catch(a){r?.(a)}return ta},stopAutoLoad:z,isAutoLoading:()=>!o(T),save:Q,startAutoSave:async()=>(await Z().save(),N=a.addDidFinishTransactionListener((()=>{const a=S();_(a)&&Q(a)})),ta),stopAutoSave:Z,isAutoSaving:()=>!o(N),getStatus:()=>g,addStatusListener:a=>b(a,m),delListener:t=>(M(t),a),schedule:aa,getStore:()=>a,destroy:()=>(j(V,d).splice(0,void 0),z().stopAutoSave()),getStats:()=>({loads:p,saves:v}),...w};return L(ta)},Z="_",aa="_id",ta="SELECT",ea="WHERE",na="TABLE",sa="ALTER "+na,ia="DELETE FROM",ra=ta+"*FROM",oa="pragma_",ca="data_version",la="schema_version",Ea="pragma_table_",wa=(a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a,ya=a=>`"${a.replace(/"/g,'""')}"`,da=(a,t=[1])=>A(T(a,(()=>"$"+t[0]++)),n),ua=JSON.stringify,Ra=JSON.parse,Aa=(a,t,e,s,i,r=Ta,c,l)=>{const E=B();return[async()=>{E.clear(),T(await e(a,t),(({tn:a,cn:t})=>W(H(E,a,J),t)))},async(t,e)=>((a,t)=>M(j(E,a),t))(t,e)?I(g(T(await a(ra+ya(t)),(a=>{return[a[e],l?(t=_(a,e),n=l,I(h(t,((a,t)=>[t,n(a,t)])))):_(a,e)];var t,n})),(([a,t])=>!o(a)&&!D(t)))):{},async(t,e,s,l,w,y=!1)=>{const u=J();h(s??{},(a=>T(C(a??{}),(a=>W(u,a)))));const R=F(u);if(!y&&w&&N(R)&&M(E,t))return await a("DROP "+na+ya(t)),void x(E,t);const $=j(E,t),p=J(F($));if(N(R)||(M(E,t)?await d(T([e,...R],(async(n,s)=>{G(p,n)||(await a(sa+ya(t)+"ADD"+ya(n)+i),0==s&&await a("CREATE UNIQUE INDEX pk ON "+ya(t)+`(${ya(e)})`),W($,n))}))):(await a("CREATE "+na+ya(t)+`(${ya(e)}${i} PRIMARY KEY${A(T(R,(a=>n+ya(a)+i)))});`),x(E,t,J([e,...R])))),await d([...!y&&l?T(F(p),(async n=>{n!=e&&(await a(sa+ya(t)+"DROP"+ya(n)),G($,n))})):[]]),y)o(s)?await a(ia+ya(t)+ea+" true"):await d(h(s,(async(n,s)=>{o(n)?await a(ia+ya(t)+ea+ya(e)+"=$1",[s]):N(R)||await r(a,t,e,C(n),{[s]:c?T(b(n),c):b(n)},$)})));else if(N(R))M(E,t)&&await a(ia+ya(t)+ea+" true");else{const n=g(F(j(E,t)),(a=>a!=e)),i={},o=[];h(s??{},((a,t)=>{i[t]=T(n,(t=>c?c(a?.[t]):a?.[t])),O(o,t)})),await r(a,t,e,n,i),await a(ia+ya(t)+ea+ya(e)+`NOT IN(${da(o)})`,o)}},async t=>{let e;await a("BEGIN");try{e=await t()}catch(a){s?.(a)}return await a("END"),e}]},Ta=async(a,t,e,s,i)=>{const r=[1];await a("INSERT INTO"+ya(t)+"("+((...a)=>A(T(a,ya),n))(e,...s)+")VALUES"+A(h(i,(a=>"($"+r[0]+++","+da(a,r)+")")),n)+"ON CONFLICT("+ya(e)+")DO UPDATE SET"+A(T(s,(a=>ya(a)+"=excluded."+ya(a))),n),h(i,((a,t)=>[t,...T(a,(a=>a??null))])).flat())},Na=(a,t,e,n,s,i,r,[o,c,l],E,w,y,d,u,R)=>{const[A,T,N,g]=Aa(t,E,w,s,u,R),O=Q(a,(async()=>await g((async()=>{return await A(),a=(await T(o,c))[Z]?.[l]??"null",Ra(a,((a,t)=>""===t?void 0:t));var a}))),(async a=>await g((async()=>{var t;await A(),await N(o,c,{[Z]:{[l]:(t=a()??null,ua(t,((a,t)=>void 0===t?"":t)))}},!0,!0)}))),e,n,s,r,{[d]:()=>y,destroy:()=>(O.stopAutoLoad().stopAutoSave(),i(),O)},y);return O},ga=(a,t,e,n,s,i,r,[c,l,[E,w,y]],u,R,A,T,N,O,$,p)=>{const[v,m,C,L]=Aa(t,u,R,s,N,O,$,p),S=async(a,t)=>await d(Y(l,(async([e,n,s,i],r)=>{t&&!(r in a)||await C(e,n,a[r],s,i,t)}))),_=async(a,t)=>w?await C(y,aa,{[Z]:a},!0,!0,t):null,h=Q(a,(async()=>await L((async()=>{await v();const a=await(async()=>I(g(await d(Y(c,(async([a,t],e)=>[a,await m(e,t)]))),(a=>!D(a[1])))))(),t=await(async()=>E?(await m(y,aa))[Z]:{})();return D(a)&&o(t)?void 0:[a,t]}))),(async(a,t)=>await L((async()=>{if(await v(),o(t)){const[t,e]=a();await S(t),await _(e)}else await S(t[0],!0),await _(t[1],!0)}))),e,n,s,r,{[T]:()=>A,destroy:()=>(h.stopAutoLoad().stopAutoSave(),i(),h)},A);return h},Oa="ColumnName",$a="store",pa="json",va=$a+"TableName",ma=$a+"Id"+Oa,Ca=$a+Oa,La="autoLoadIntervalSeconds",Ia="rowId"+Oa,Sa="tableId",_a="tableName",ha="deleteEmptyColumns",ba="deleteEmptyTable",fa={mode:pa,[La]:1},Da={load:0,save:0,[_a]:t+"_values"},Ma=(a,t,e,n,s)=>{const i=B();return h(a,((a,r)=>{const c=w(b(S(t,l(a)?{[e]:a}:a)),0,f(t));o(c[0])||n(r,c[0])||(s(r,c[0]),x(i,r,c))})),i},Pa=a=>{const e=(a=>S(fa,l(a)?{[va]:a}:a??{}))(a),n=e[La];if(e.mode==pa){const a=e[va]??t;return[1,n,[a,e[ma]??aa,e[Ca]??$a],J(a)]}const{tables:{load:s={},save:i={}}={},values:r={}}=e,o=w(b(S(Da,r)),0,f(Da)),c=o[2],E=J(c),y=J(c);return[0,n,[Ma(s,{[Sa]:null,[Ia]:aa},Sa,(a=>M(y,a)),(a=>W(E,a))),Ma(i,{[_a]:null,[Ia]:aa,[ha]:0,[ba]:0},_a,((a,t)=>M(y,t)),((a,t)=>W(E,t))),o],E]},Fa=(a,t,n,s,i,o,c,l,E,w,y="getDb",d)=>{let u,R,A;const T=wa(n,o),[N,g,O,$]=Pa(t);return(N?Na:ga)(a,T,(a=>{let t;const e=()=>t=setInterval((async()=>{try{const[{d:t,s:e,c:n}]=await T(`${ta} ${ca} d,${la} s,TOTAL_CHANGES() c FROM ${oa}${ca} JOIN ${oa}${la}`);t==u&&e==R&&n==A||(null!=u&&a(),u=t,R=e,A=n)}catch{}}),1e3*g),n=()=>{u=R=A=null,r(t)},o=s((t=>{$.has(t)&&(n(),a(),e())}));return e(),()=>{n(),i(o)}}),(a=>a()),c,l,E,O,F($),(async(a,t)=>await a(`${ta} t.name tn,c.name cn FROM ${Ea}list()t,${Ea}info(t.name)c ${ea} t.schema='main'AND t.type IN('table','view')AND t.name IN(${da(t)})ORDER BY t.name,c.name`,t)),w,y,e,d,(a=>!0===a?1:!1===a?0:a),void 0)},Ua=t,Ga=/^([cd]:)(.+)/,Ba=t+"_data",ja=t+"_table",Ya=(a,t,e,n,s,i,r,o,l,E,w="getDb")=>{const y=wa(e,i),[u,,R,A]=Pa(t),N=async a=>{await y(`CREATE OR REPLACE TRIGGER ${ya(Ba+"_"+a)} AFTER INSERT OR UPDATE OR DELETE ON ${ya(a)} EXECUTE FUNCTION ${Ba}()`)};return(u?Na:ga)(a,y,(async a=>{await y(`CREATE OR REPLACE FUNCTION ${ja}()RETURNS event_trigger AS $t2$ DECLARE row record; BEGIN FOR row IN SELECT object_identity FROM pg_event_trigger_ddl_commands()WHERE command_tag='CREATE TABLE' LOOP PERFORM pg_notify('${Ua}','c:'||SPLIT_PART(row.object_identity,'.',2));END LOOP;END;$t2$ LANGUAGE plpgsql;`);try{await y(`CREATE EVENT TRIGGER ${ja} ON ddl_command_end WHEN TAG IN('CREATE TABLE')EXECUTE FUNCTION ${ja}();`)}catch{}return await y(`CREATE OR REPLACE FUNCTION ${Ba}()RETURNS trigger AS $t1$ BEGIN PERFORM pg_notify('${Ua}','d:'||TG_TABLE_NAME);RETURN NULL;END;$t1$ LANGUAGE plpgsql;`),await d(T(F(A),(async a=>{await y(`CREATE TABLE IF NOT EXISTS ${ya(a)}("_id"text PRIMARY KEY)`),await N(a)}))),await n(Ua,(async t=>{return await c((e=t,n=Ga,e?.match(n)),(async([,t,e])=>{M(A,e)&&("c:"==t&&await N(e),a())}));var e,n}))}),s,r,o,l,R,F(A),(async(a,t)=>await a(`${ta} table_name tn,column_name cn FROM information_schema.columns ${ea} table_schema='public'AND table_name IN(${da(t)})`,t)),E,w,"text",void 0,(a=>ua(a)),(a=>Ra(a)))};export{z as Persists,q as Status,Q as createCustomPersister,Ya as createCustomPostgreSqlPersister,Fa as createCustomSqlitePersister};
|
|
Binary file
|