tinybase 5.3.7 → 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 +1 -1
- 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 +2 -2
- 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
|
-
var t,a;t=this,a=function(t){"use strict";const a=t=>typeof t,e="tinybase",n="",s=",",i=a(n),o=Promise,r=clearInterval,c=t=>null==t,l=(t,a,e)=>c(t)?e?.():a(t),u=t=>a(t)==i,y=t=>Array.isArray(t),w=(t,a,e)=>t.slice(a,e),d=t=>t.length,p=async t=>o.all(t),v=t=>{throw Error(t)},f=(t,a)=>t.forEach(a),g=(t,a="")=>t.join(a),E=(t,a)=>t.map(a),h=t=>0==d(t),m=(t,a)=>t.filter(a),A=(t,...a)=>t.push(...a),N=t=>t.shift(),T="_",$="_id",b="SELECT",S="WHERE",C="TABLE",L="ALTER "+C,O="DELETE FROM",I=b+"*FROM",D="pragma_",R="data_version",M="schema_version",P="pragma_table_",_=t=>`"${t.replace(/"/g,'""')}"`,F=(t,a=[1])=>g(E(t,(()=>"$"+a[0]++)),s),x=(t,a)=>t?.has(a)??!1,j=t=>c(t)||0==(t=>t?.size??0)(t),B=t=>[...t?.values()??[]],U=(t,a)=>t?.forEach(a),q=(t,a)=>t?.delete(a),J=Object,Y=t=>J.getPrototypeOf(t),k=J.entries,z=J.keys,G=J.freeze,H=(t=[])=>J.fromEntries(t),K=(...t)=>J.assign({},...t),Q=(t,a)=>(delete t[a],t),V=(t,a)=>E(k(t),(([t,e])=>a(e,t))),W=t=>J.values(t),X=t=>d(z(t)),Z=t=>(t=>!c(t)&&l(Y(t),(t=>t==J.prototype||c(Y(t))),(()=>!0)))(t)&&0==X(t),tt=JSON.stringify,at=JSON.parse,et=t=>new Map(t),nt=(t,a)=>t?.get(a),st=(t,a)=>E([...t?.entries()??[]],(([t,e])=>a(e,t))),it=(t,a,e)=>c(e)?(q(t,a),t):t?.set(a,e),ot=(t,a,e,n)=>(x(t,a)?n?.(nt(t,a)):it(t,a,e()),nt(t,a)),rt=(t,a,e,n,s=0)=>l((e?ot:nt)(t,a[s],s>d(a)-2?e:et),(i=>{if(s>d(a)-2)return n?.(i)&&it(t,a[s]),i;const o=rt(i,a,e,n,s+1);return j(i)&&it(t,a[s]),o})),ct=t=>new Set(y(t)||c(t)?t:[t]),lt=(t,a)=>t?.add(a),ut=/^\d+$/,yt=et(),wt=et(),dt=(t,a,e,s,i,o,r,u={},w=[])=>{let p,g,E,h=0,m=0,T=0;ot(yt,w,(()=>0)),ot(wt,w,(()=>[]));const $=et(),[b,S,C,L,O]=((t=1,a)=>1!=t&&a.isMergeable()?[1,a.getMergeableContent,a.getTransactionMergeableChanges,([[t],[a]])=>!Z(t)||!Z(a),a.setDefaultContent]:2!=t?[0,a.getContent,a.getTransactionChanges,([t,a])=>!Z(t)||!Z(a),a.setContent]:v("Store type not supported by this Persister"))(r,t),[I,D,R]=(()=>{let t;const[a,e]=(()=>{const t=[];let a=0;return[e=>(e?N(t):null)??n+a++,a=>{ut.test(a)&&d(t)<1e3&&A(t,a)}]})(),s=et();return[(e,i,o,r=[],c=()=>[])=>{t??=Y;const l=a(1);return it(s,l,[e,i,o,r,c]),lt(rt(i,o??[n],ct),l),l},(a,e,...i)=>f(((t,a=[n])=>{const e=[],s=(t,n)=>n==d(a)?A(e,t):null===a[n]?U(t,(t=>s(t,n+1))):f([a[n],null],(a=>s(nt(t,a),n+1)));return s(t,0),e})(a,e),(a=>U(a,(a=>nt(s,a)[0](t,...e??[],...i))))),t=>l(nt(s,t),(([,a,i])=>(rt(a,i??[n],void 0,(a=>(q(a,t),j(a)?1:0))),it(s,t),e(t),i))),a=>l(nt(s,a),(([a,,e=[],n,s])=>{const i=(...o)=>{const r=d(o);r==d(e)?a(t,...o,...s(o)):c(e[r])?f(n[r]?.(...o)??[],(t=>i(...o,t))):i(...o,e[r])};i()}))]})(),M=t=>{t!=h&&(h=t,D($,void 0,h))},P=a=>{(b&&y(a?.[0])?1===a?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===a?.[2]?t.applyChanges:t.setContent)(a)},_=async t=>(2!=h&&(M(1),m++,await J((async()=>{try{const e=await a();y(e)?P(e):t?O(t):v("Content is not an array "+e)}catch(a){o?.(a),t&&O(t)}M(0)}))),Y),F=()=>(g&&(i(g),g=void 0),Y),x=async t=>(1!=h&&(M(2),T++,await J((async()=>{try{await e(S,t)}catch(t){o?.(t)}M(0)}))),Y),B=()=>(l(E,t.delListener),E=void 0,Y),J=async(...t)=>(A(nt(wt,w),...t),await(async()=>{if(!nt(yt,w)){for(it(yt,w,1);!c(p=N(nt(wt,w)));)try{await p()}catch(t){o?.(t)}it(yt,w,0)}})(),Y),Y={load:_,startAutoLoad:async t=>{await F().load(t);try{g=await s((async(t,a)=>{a||t?2!=h&&(M(1),m++,P(a??t),M(0)):await _()}))}catch(t){o?.(t)}return Y},stopAutoLoad:F,isAutoLoading:()=>!c(g),save:x,startAutoSave:async()=>(await B().save(),E=t.addDidFinishTransactionListener((()=>{const t=C();L(t)&&x(t)})),Y),stopAutoSave:B,isAutoSaving:()=>!c(E),getStatus:()=>h,addStatusListener:t=>I(t,$),delListener:a=>(R(a),t),schedule:J,getStore:()=>t,destroy:()=>(nt(wt,w).splice(0,void 0),F().stopAutoSave()),getStats:()=>({loads:m,saves:T}),...u};return G(Y)},pt=(t,a,e,n,i,o=vt,r,l)=>{const u=et();return[async()=>{u.clear(),E(await e(t,a),(({tn:t,cn:a})=>lt(ot(u,t,ct),a)))},async(a,e)=>((t,a)=>x(nt(u,t),a))(a,e)?H(m(E(await t(I+_(a)),(t=>{return[t[e],l?(a=Q(t,e),n=l,H(V(a,((t,a)=>[a,n(t,a)])))):Q(t,e)];var a,n})),(([t,a])=>!c(t)&&!Z(a)))):{},async(a,e,n,l,y,w=!1)=>{const d=ct();V(n??{},(t=>E(z(t??{}),(t=>lt(d,t)))));const v=B(d);if(!w&&y&&h(v)&&x(u,a))return await t("DROP "+C+_(a)),void it(u,a);const f=nt(u,a),N=ct(B(f));if(h(v)||(x(u,a)?await p(E([e,...v],(async(n,s)=>{q(N,n)||(await t(L+_(a)+"ADD"+_(n)+i),0==s&&await t("CREATE UNIQUE INDEX pk ON "+_(a)+`(${_(e)})`),lt(f,n))}))):(await t("CREATE "+C+_(a)+`(${_(e)}${i} PRIMARY KEY${g(E(v,(t=>s+_(t)+i)))});`),it(u,a,ct([e,...v])))),await p([...!w&&l?E(B(N),(async n=>{n!=e&&(await t(L+_(a)+"DROP"+_(n)),q(f,n))})):[]]),w)c(n)?await t(O+_(a)+S+" true"):await p(V(n,(async(n,s)=>{c(n)?await t(O+_(a)+S+_(e)+"=$1",[s]):h(v)||await o(t,a,e,z(n),{[s]:r?E(W(n),r):W(n)},f)})));else if(h(v))x(u,a)&&await t(O+_(a)+S+" true");else{const s=m(B(nt(u,a)),(t=>t!=e)),i={},c=[];V(n??{},((t,a)=>{i[a]=E(s,(a=>r?r(t?.[a]):t?.[a])),A(c,a)})),await o(t,a,e,s,i),await t(O+_(a)+S+_(e)+`NOT IN(${F(c)})`,c)}},async a=>{let e;await t("BEGIN");try{e=await a()}catch(t){n?.(t)}return await t("END"),e}]},vt=async(t,a,e,n,i)=>{const o=[1];await t("INSERT INTO"+_(a)+"("+((...t)=>g(E(t,_),s))(e,...n)+")VALUES"+g(V(i,(t=>"($"+o[0]+++","+F(t,o)+")")),s)+"ON CONFLICT("+_(e)+")DO UPDATE SET"+g(E(n,(t=>_(t)+"=excluded."+_(t))),s),V(i,((t,a)=>[a,...E(t,(t=>t??null))])).flat())},ft=(t,a,e,n,s,i,o,[r,c,l],u,y,w,d,p,v)=>{const[f,g,E,h]=pt(a,u,y,s,p,v),m=dt(t,(async()=>await h((async()=>{return await f(),t=(await g(r,c))[T]?.[l]??"null",at(t,((t,a)=>""===a?void 0:a));var t}))),(async t=>await h((async()=>{var a;await f(),await E(r,c,{[T]:{[l]:(a=t()??null,tt(a,((t,a)=>void 0===a?"":a)))}},!0,!0)}))),e,n,s,o,{[d]:()=>w,destroy:()=>(m.stopAutoLoad().stopAutoSave(),i(),m)},w);return m},gt=(t,a,e,n,s,i,o,[r,l,[u,y,w]],d,v,f,g,E,h,A,N)=>{const[b,S,C,L]=pt(a,d,v,s,E,h,A,N),O=async(t,a)=>await p(st(l,(async([e,n,s,i],o)=>{a&&!(o in t)||await C(e,n,t[o],s,i,a)}))),I=async(t,a)=>y?await C(w,$,{[T]:t},!0,!0,a):null,D=dt(t,(async()=>await L((async()=>{await b();const t=await(async()=>H(m(await p(st(r,(async([t,a],e)=>[t,await S(e,a)]))),(t=>!Z(t[1])))))(),a=await(async()=>u?(await S(w,$))[T]:{})();return Z(t)&&c(a)?void 0:[t,a]}))),(async(t,a)=>await L((async()=>{if(await b(),c(a)){const[a,e]=t();await O(a),await I(e)}else await O(a[0],!0),await I(a[1],!0)}))),e,n,s,o,{[g]:()=>f,destroy:()=>(D.stopAutoLoad().stopAutoSave(),i(),D)},f);return D},Et="ColumnName",ht="store",mt="json",At=ht+"TableName",Nt=ht+"Id"+Et,Tt=ht+Et,$t="autoLoadIntervalSeconds",bt="rowId"+Et,St="tableId",Ct="tableName",Lt="deleteEmptyColumns",Ot="deleteEmptyTable",It={mode:mt,[$t]:1},Dt={load:0,save:0,[Ct]:e+"_values"},Rt=(t,a,e,n,s)=>{const i=et();return V(t,((t,o)=>{const r=w(W(K(a,u(t)?{[e]:t}:t)),0,X(a));c(r[0])||n(o,r[0])||(s(o,r[0]),it(i,o,r))})),i},Mt=(t,a,s,i,o,c,l,y,d,p,v="getDb",f)=>{let g,E,h;const m=((t,a)=>a?async(e,n)=>(a(e,n),await t(e,n)):t)(s,c),[A,N,T,C]=(t=>{const a=(t=>K(It,u(t)?{[At]:t}:t??{}))(t),n=a[$t];if(a.mode==mt){const t=a[At]??e;return[1,n,[t,a[Nt]??$,a[Tt]??ht],ct(t)]}const{tables:{load:s={},save:i={}}={},values:o={}}=a,r=w(W(K(Dt,o)),0,X(Dt)),c=r[2],l=ct(c),y=ct(c);return[0,n,[Rt(s,{[St]:null,[bt]:$},St,(t=>x(y,t)),(t=>lt(l,t))),Rt(i,{[Ct]:null,[bt]:$,[Lt]:0,[Ot]:0},Ct,((t,a)=>x(y,a)),((t,a)=>lt(l,a))),r],l]})(a);return(A?ft:gt)(t,m,(t=>{let a;const e=()=>a=setInterval((async()=>{try{const[{d:a,s:e,c:n}]=await m(`${b} ${R} d,${M} s,TOTAL_CHANGES() c FROM ${D}${R} JOIN ${D}${M}`);a==g&&e==E&&n==h||(null!=g&&t(),g=a,E=e,h=n)}catch{}}),1e3*N),n=()=>{g=E=h=null,r(a)},s=i((a=>{C.has(a)&&(n(),t(),e())}));return e(),()=>{n(),o(s)}}),(t=>t()),l,y,d,T,B(C),(async(t,a)=>await t(`${b} t.name tn,c.name cn FROM ${P}list()t,${P}info(t.name)c ${S} t.schema='main'AND t.type IN('table','view')AND t.name IN(${F(a)})ORDER BY t.name,c.name`,a)),p,v,n,f,(t=>!0===t?1:!1===t?0:t),void 0)};t.createLibSqlPersister=(t,a,e,n,s)=>Mt(t,e,(async(t,e=[])=>(await a.execute({sql:t,args:e})).rows),(()=>()=>0),(t=>t()),n,s,(()=>0),1,a,"getClient")},"object"==typeof exports&&"undefined"!=typeof module?a(exports):"function"==typeof define&&define.amd?define(["exports"],a):a((t="undefined"!=typeof globalThis?globalThis:t||self).TinyBasePersisterLibsql={});
|
|
1
|
+
var t,a;t=this,a=function(t){"use strict";const a=t=>typeof t,e="tinybase",n="",s=",",i=a(n),o=Promise,r=clearInterval,c=t=>null==t,l=(t,a,e)=>c(t)?e?.():a(t),u=t=>a(t)==i,y=t=>Array.isArray(t),w=(t,a,e)=>t.slice(a,e),d=t=>t.length,p=async t=>o.all(t),v=t=>{throw Error(t)},f=(t,a)=>t.forEach(a),g=(t,a="")=>t.join(a),E=(t,a)=>t.map(a),h=t=>0==d(t),m=(t,a)=>t.filter(a),A=(t,...a)=>t.push(...a),N=t=>t.shift(),T="_",$="_id",b="SELECT",S="WHERE",C="TABLE",L="ALTER "+C,O="DELETE FROM",I=b+"*FROM",D="pragma_",R="data_version",M="schema_version",P="pragma_table_",_=t=>`"${t.replace(/"/g,'""')}"`,F=(t,a=[1])=>g(E(t,(()=>"$"+a[0]++)),s),x=(t,a)=>t?.has(a)??!1,j=t=>c(t)||0==(t=>t?.size??0)(t),B=t=>[...t?.values()??[]],U=(t,a)=>t?.forEach(a),q=(t,a)=>t?.delete(a),J=Object,Y=t=>J.getPrototypeOf(t),k=J.entries,z=J.keys,G=J.freeze,H=(t=[])=>J.fromEntries(t),K=(...t)=>J.assign({},...t),Q=(t,a)=>(delete t[a],t),V=(t,a)=>E(k(t),(([t,e])=>a(e,t))),W=t=>J.values(t),X=t=>d(z(t)),Z=t=>(t=>!c(t)&&l(Y(t),(t=>t==J.prototype||c(Y(t))),(()=>!0)))(t)&&0==X(t),tt=JSON.stringify,at=JSON.parse,et=t=>new Map(t),nt=(t,a)=>t?.get(a),st=(t,a)=>E([...t?.entries()??[]],(([t,e])=>a(e,t))),it=(t,a,e)=>c(e)?(q(t,a),t):t?.set(a,e),ot=(t,a,e,n)=>(x(t,a)?n?.(nt(t,a)):it(t,a,e()),nt(t,a)),rt=(t,a,e,n,s=0)=>l((e?ot:nt)(t,a[s],s>d(a)-2?e:et),(i=>{if(s>d(a)-2)return n?.(i)&&it(t,a[s]),i;const o=rt(i,a,e,n,s+1);return j(i)&&it(t,a[s]),o})),ct=t=>new Set(y(t)||c(t)?t:[t]),lt=(t,a)=>t?.add(a),ut=/^\d+$/,yt=et(),wt=et(),dt=(t,a,e,s,i,o,r,u={},w=[])=>{let p,g,E,h=0,m=0,T=0;ot(yt,w,(()=>0)),ot(wt,w,(()=>[]));const $=et(),[b,S,C,L,O]=((t=1,a)=>1!=t&&a.isMergeable()?[1,a.getMergeableContent,a.getTransactionMergeableChanges,([[t],[a]])=>!Z(t)||!Z(a),a.setDefaultContent]:2!=t?[0,a.getContent,a.getTransactionChanges,([t,a])=>!Z(t)||!Z(a),a.setContent]:v("Store type not supported by this Persister"))(r,t),[I,D,R]=(()=>{let t;const[a,e]=(()=>{const t=[];let a=0;return[e=>(e?N(t):null)??n+a++,a=>{ut.test(a)&&d(t)<1e3&&A(t,a)}]})(),s=et();return[(e,i,o,r=[],c=()=>[])=>{t??=Y;const l=a(1);return it(s,l,[e,i,o,r,c]),lt(rt(i,o??[n],ct),l),l},(a,e,...i)=>f(((t,a=[n])=>{const e=[],s=(t,n)=>n==d(a)?A(e,t):null===a[n]?U(t,(t=>s(t,n+1))):f([a[n],null],(a=>s(nt(t,a),n+1)));return s(t,0),e})(a,e),(a=>U(a,(a=>nt(s,a)[0](t,...e??[],...i))))),t=>l(nt(s,t),(([,a,i])=>(rt(a,i??[n],void 0,(a=>(q(a,t),j(a)?1:0))),it(s,t),e(t),i))),a=>l(nt(s,a),(([a,,e=[],n,s])=>{const i=(...o)=>{const r=d(o);r==d(e)?a(t,...o,...s(o)):c(e[r])?f(n[r]?.(...o)??[],(t=>i(...o,t))):i(...o,e[r])};i()}))]})(),M=t=>{t!=h&&(h=t,D($,void 0,h))},P=a=>{(b&&y(a?.[0])?1===a?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===a?.[2]?t.applyChanges:t.setContent)(a)},_=async t=>(2!=h&&(M(1),m++,await J((async()=>{try{const e=await a();y(e)?P(e):t?O(t):v("Content is not an array: "+e)}catch(a){o?.(a),t&&O(t)}M(0)}))),Y),F=()=>(g&&(i(g),g=void 0),Y),x=async t=>(1!=h&&(M(2),T++,await J((async()=>{try{await e(S,t)}catch(t){o?.(t)}M(0)}))),Y),B=()=>(l(E,t.delListener),E=void 0,Y),J=async(...t)=>(A(nt(wt,w),...t),await(async()=>{if(!nt(yt,w)){for(it(yt,w,1);!c(p=N(nt(wt,w)));)try{await p()}catch(t){o?.(t)}it(yt,w,0)}})(),Y),Y={load:_,startAutoLoad:async t=>{await F().load(t);try{g=await s((async(t,a)=>{a||t?2!=h&&(M(1),m++,P(a??t),M(0)):await _()}))}catch(t){o?.(t)}return Y},stopAutoLoad:F,isAutoLoading:()=>!c(g),save:x,startAutoSave:async()=>(await B().save(),E=t.addDidFinishTransactionListener((()=>{const t=C();L(t)&&x(t)})),Y),stopAutoSave:B,isAutoSaving:()=>!c(E),getStatus:()=>h,addStatusListener:t=>I(t,$),delListener:a=>(R(a),t),schedule:J,getStore:()=>t,destroy:()=>(nt(wt,w).splice(0,void 0),F().stopAutoSave()),getStats:()=>({loads:m,saves:T}),...u};return G(Y)},pt=(t,a,e,n,i,o=vt,r,l)=>{const u=et();return[async()=>{u.clear(),E(await e(t,a),(({tn:t,cn:a})=>lt(ot(u,t,ct),a)))},async(a,e)=>((t,a)=>x(nt(u,t),a))(a,e)?H(m(E(await t(I+_(a)),(t=>{return[t[e],l?(a=Q(t,e),n=l,H(V(a,((t,a)=>[a,n(t,a)])))):Q(t,e)];var a,n})),(([t,a])=>!c(t)&&!Z(a)))):{},async(a,e,n,l,y,w=!1)=>{const d=ct();V(n??{},(t=>E(z(t??{}),(t=>lt(d,t)))));const v=B(d);if(!w&&y&&h(v)&&x(u,a))return await t("DROP "+C+_(a)),void it(u,a);const f=nt(u,a),N=ct(B(f));if(h(v)||(x(u,a)?await p(E([e,...v],(async(n,s)=>{q(N,n)||(await t(L+_(a)+"ADD"+_(n)+i),0==s&&await t("CREATE UNIQUE INDEX pk ON "+_(a)+`(${_(e)})`),lt(f,n))}))):(await t("CREATE "+C+_(a)+`(${_(e)}${i} PRIMARY KEY${g(E(v,(t=>s+_(t)+i)))});`),it(u,a,ct([e,...v])))),await p([...!w&&l?E(B(N),(async n=>{n!=e&&(await t(L+_(a)+"DROP"+_(n)),q(f,n))})):[]]),w)c(n)?await t(O+_(a)+S+" true"):await p(V(n,(async(n,s)=>{c(n)?await t(O+_(a)+S+_(e)+"=$1",[s]):h(v)||await o(t,a,e,z(n),{[s]:r?E(W(n),r):W(n)},f)})));else if(h(v))x(u,a)&&await t(O+_(a)+S+" true");else{const s=m(B(nt(u,a)),(t=>t!=e)),i={},c=[];V(n??{},((t,a)=>{i[a]=E(s,(a=>r?r(t?.[a]):t?.[a])),A(c,a)})),await o(t,a,e,s,i),await t(O+_(a)+S+_(e)+`NOT IN(${F(c)})`,c)}},async a=>{let e;await t("BEGIN");try{e=await a()}catch(t){n?.(t)}return await t("END"),e}]},vt=async(t,a,e,n,i)=>{const o=[1];await t("INSERT INTO"+_(a)+"("+((...t)=>g(E(t,_),s))(e,...n)+")VALUES"+g(V(i,(t=>"($"+o[0]+++","+F(t,o)+")")),s)+"ON CONFLICT("+_(e)+")DO UPDATE SET"+g(E(n,(t=>_(t)+"=excluded."+_(t))),s),V(i,((t,a)=>[a,...E(t,(t=>t??null))])).flat())},ft=(t,a,e,n,s,i,o,[r,c,l],u,y,w,d,p,v)=>{const[f,g,E,h]=pt(a,u,y,s,p,v),m=dt(t,(async()=>await h((async()=>{return await f(),t=(await g(r,c))[T]?.[l]??"null",at(t,((t,a)=>""===a?void 0:a));var t}))),(async t=>await h((async()=>{var a;await f(),await E(r,c,{[T]:{[l]:(a=t()??null,tt(a,((t,a)=>void 0===a?"":a)))}},!0,!0)}))),e,n,s,o,{[d]:()=>w,destroy:()=>(m.stopAutoLoad().stopAutoSave(),i(),m)},w);return m},gt=(t,a,e,n,s,i,o,[r,l,[u,y,w]],d,v,f,g,E,h,A,N)=>{const[b,S,C,L]=pt(a,d,v,s,E,h,A,N),O=async(t,a)=>await p(st(l,(async([e,n,s,i],o)=>{a&&!(o in t)||await C(e,n,t[o],s,i,a)}))),I=async(t,a)=>y?await C(w,$,{[T]:t},!0,!0,a):null,D=dt(t,(async()=>await L((async()=>{await b();const t=await(async()=>H(m(await p(st(r,(async([t,a],e)=>[t,await S(e,a)]))),(t=>!Z(t[1])))))(),a=await(async()=>u?(await S(w,$))[T]:{})();return Z(t)&&c(a)?void 0:[t,a]}))),(async(t,a)=>await L((async()=>{if(await b(),c(a)){const[a,e]=t();await O(a),await I(e)}else await O(a[0],!0),await I(a[1],!0)}))),e,n,s,o,{[g]:()=>f,destroy:()=>(D.stopAutoLoad().stopAutoSave(),i(),D)},f);return D},Et="ColumnName",ht="store",mt="json",At=ht+"TableName",Nt=ht+"Id"+Et,Tt=ht+Et,$t="autoLoadIntervalSeconds",bt="rowId"+Et,St="tableId",Ct="tableName",Lt="deleteEmptyColumns",Ot="deleteEmptyTable",It={mode:mt,[$t]:1},Dt={load:0,save:0,[Ct]:e+"_values"},Rt=(t,a,e,n,s)=>{const i=et();return V(t,((t,o)=>{const r=w(W(K(a,u(t)?{[e]:t}:t)),0,X(a));c(r[0])||n(o,r[0])||(s(o,r[0]),it(i,o,r))})),i},Mt=(t,a,s,i,o,c,l,y,d,p,v="getDb",f)=>{let g,E,h;const m=((t,a)=>a?async(e,n)=>(a(e,n),await t(e,n)):t)(s,c),[A,N,T,C]=(t=>{const a=(t=>K(It,u(t)?{[At]:t}:t??{}))(t),n=a[$t];if(a.mode==mt){const t=a[At]??e;return[1,n,[t,a[Nt]??$,a[Tt]??ht],ct(t)]}const{tables:{load:s={},save:i={}}={},values:o={}}=a,r=w(W(K(Dt,o)),0,X(Dt)),c=r[2],l=ct(c),y=ct(c);return[0,n,[Rt(s,{[St]:null,[bt]:$},St,(t=>x(y,t)),(t=>lt(l,t))),Rt(i,{[Ct]:null,[bt]:$,[Lt]:0,[Ot]:0},Ct,((t,a)=>x(y,a)),((t,a)=>lt(l,a))),r],l]})(a);return(A?ft:gt)(t,m,(t=>{let a;const e=()=>a=setInterval((async()=>{try{const[{d:a,s:e,c:n}]=await m(`${b} ${R} d,${M} s,TOTAL_CHANGES() c FROM ${D}${R} JOIN ${D}${M}`);a==g&&e==E&&n==h||(null!=g&&t(),g=a,E=e,h=n)}catch{}}),1e3*N),n=()=>{g=E=h=null,r(a)},s=i((a=>{C.has(a)&&(n(),t(),e())}));return e(),()=>{n(),o(s)}}),(t=>t()),l,y,d,T,B(C),(async(t,a)=>await t(`${b} t.name tn,c.name cn FROM ${P}list()t,${P}info(t.name)c ${S} t.schema='main'AND t.type IN('table','view')AND t.name IN(${F(a)})ORDER BY t.name,c.name`,a)),p,v,n,f,(t=>!0===t?1:!1===t?0:t),void 0)};t.createLibSqlPersister=(t,a,e,n,s)=>Mt(t,e,(async(t,e=[])=>(await a.execute({sql:t,args:e})).rows),(()=>()=>0),(t=>t()),n,s,(()=>0),1,a,"getClient")},"object"==typeof exports&&"undefined"!=typeof module?a(exports):"function"==typeof define&&define.amd?define(["exports"],a):a((t="undefined"!=typeof globalThis?globalThis:t||self).TinyBasePersisterLibsql={});
|
|
Binary file
|
|
@@ -1 +1 @@
|
|
|
1
|
-
var t,e;t=this,e=function(t){"use strict";const e=t=>typeof t,a="",s=e(a),n=t=>null==t,o=(t,e,a)=>n(t)?a?.():e(t),r=t=>e(t)==s,i=t=>Array.isArray(t),c=t=>t.length,d=t=>{throw Error(t)},l=(t,e)=>t.forEach(e),y=(t,...e)=>t.push(...e),u=t=>t.shift(),p=Object,h=t=>p.getPrototypeOf(t),f=p.keys,g=p.freeze,v=t=>(t=>!n(t)&&o(h(t),(t=>t==p.prototype||n(h(t))),(()=>!0)))(t)&&0==(t=>c(f(t)))(t),w=JSON.stringify,C=JSON.parse,S=t=>w(t,((t,e)=>e instanceof Map?p.fromEntries([...e]):e)),b="/store",P=t=>n(t)||0==(t=>t?.size??0)(t),m=(t,e)=>t?.forEach(e),A=(t,e)=>t?.delete(e),L=t=>new Map(t),M=(t,e)=>t?.get(e),T=(t,e,a)=>n(a)?(A(t,e),t):t?.set(e,a),E=(t,e,a,s)=>{var n,o;return n=t,o=e,n?.has(o)?s?.(M(t,e)):T(t,e,a()),M(t,e)},O=(t,e,a,s,n=0)=>o((a?E:M)(t,e[n],n>c(e)-2?a:L),(o=>{if(n>c(e)-2)return s?.(o)&&T(t,e[n]),o;const r=O(o,e,a,s,n+1);return P(o)&&T(t,e[n]),r})),x=t=>new Set(i(t)||n(t)?t:[t]),j=/^\d+$/,k=L(),z=L(),D=(t,e,s,r,p,h,f,w={},C=[])=>{let S,b,D,J=0,K=0,N=0;E(k,C,(()=>0)),E(z,C,(()=>[]));const B=L(),[F,U,W,$,q]=((t=1,e)=>1!=t&&e.isMergeable()?[1,e.getMergeableContent,e.getTransactionMergeableChanges,([[t],[e]])=>!v(t)||!v(e),e.setDefaultContent]:2!=t?[0,e.getContent,e.getTransactionChanges,([t,e])=>!v(t)||!v(e),e.setContent]:d("Store type not supported by this Persister"))(f,t),[G,H,I]=(()=>{let t;const[e,s]=(()=>{const t=[];let e=0;return[s=>(s?u(t):null)??a+e++,e=>{j.test(e)&&c(t)<1e3&&y(t,e)}]})(),r=L();return[(s,n,o,i=[],c=()=>[])=>{t??=tt;const d=e(1);var l,y;return T(r,d,[s,n,o,i,c]),l=O(n,o??[a],x),y=d,l?.add(y),d},(e,s,...n)=>l(((t,e=[a])=>{const s=[],n=(t,a)=>a==c(e)?y(s,t):null===e[a]?m(t,(t=>n(t,a+1))):l([e[a],null],(e=>n(M(t,e),a+1)));return n(t,0),s})(e,s),(e=>m(e,(e=>M(r,e)[0](t,...s??[],...n))))),t=>o(M(r,t),(([,e,n])=>(O(e,n??[a],void 0,(e=>(A(e,t),P(e)?1:0))),T(r,t),s(t),n))),e=>o(M(r,e),(([e,,a=[],s,o])=>{const r=(...i)=>{const d=c(i);d==c(a)?e(t,...i,...o(i)):n(a[d])?l(s[d]?.(...i)??[],(t=>r(...i,t))):r(...i,a[d])};r()}))]})(),Q=t=>{t!=J&&(J=t,H(B,void 0,J))},R=e=>{(F&&i(e?.[0])?1===e?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===e?.[2]?t.applyChanges:t.setContent)(e)},V=async t=>(2!=J&&(Q(1),K++,await _((async()=>{try{const a=await e();i(a)?R(a):t?q(t):d("Content is not an array "+a)}catch(e){h?.(e),t&&q(t)}Q(0)}))),tt),X=()=>(b&&(p(b),b=void 0),tt),Y=async t=>(1!=J&&(Q(2),N++,await _((async()=>{try{await s(U,t)}catch(t){h?.(t)}Q(0)}))),tt),Z=()=>(o(D,t.delListener),D=void 0,tt),_=async(...t)=>(y(M(z,C),...t),await(async()=>{if(!M(k,C)){for(T(k,C,1);!n(S=u(M(z,C)));)try{await S()}catch(t){h?.(t)}T(k,C,0)}})(),tt),tt={load:V,startAutoLoad:async t=>{await X().load(t);try{b=await r((async(t,e)=>{e||t?2!=J&&(Q(1),K++,R(e??t),Q(0)):await V()}))}catch(t){h?.(t)}return tt},stopAutoLoad:X,isAutoLoading:()=>!n(b),save:Y,startAutoSave:async()=>(await Z().save(),D=t.addDidFinishTransactionListener((()=>{const t=W();$(t)&&Y(t)})),tt),stopAutoSave:Z,isAutoSaving:()=>!n(D),getStatus:()=>J,addStatusListener:t=>G(t,B),delListener:e=>(I(e),t),schedule:_,getStore:()=>t,destroy:()=>(M(z,C).splice(0,void 0),X().stopAutoSave()),getStats:()=>({loads:K,saves:N}),...w};return g(tt)},J="message";t.createPartyKitPersister=(t,e,s,n)=>{const{host:i,room:d}=e.partySocketOptions,{storeProtocol:l="https",storePath:y=b,messagePrefix:u=a}={...r(s)?{storeProtocol:s}:s},p=l+"://"+i+"/parties/"+e.name+"/"+d+y,h=async t=>await(await fetch(p,{...t?{method:"PUT",body:S(t)}:{},mode:"cors",cache:"no-store"})).json();return D(t,(async()=>await h()),(async(t,a)=>{var s;a?e.send(u+"s"+(r(s=a)?s:S(s))):await h(t())}),(t=>{const a=e=>o(((t,e)=>{const a=c(t);return((t,e)=>t.startsWith(e))(e,t)?[e[a],C((s=e,n=a+1,s.slice(n,void 0)))]:void 0;var s,n})(u,e.data),(([e,a])=>{"s"==e&&t(void 0,a)}));return e.addEventListener(J,a),a}),(t=>{e.removeEventListener(J,t)}),n,1,{getConnection:()=>e})}},"object"==typeof exports&&"undefined"!=typeof module?e(exports):"function"==typeof define&&define.amd?define(["exports"],e):e((t="undefined"!=typeof globalThis?globalThis:t||self).TinyBasePersisterPartyKitClient={});
|
|
1
|
+
var t,e;t=this,e=function(t){"use strict";const e=t=>typeof t,a="",s=e(a),n=t=>null==t,o=(t,e,a)=>n(t)?a?.():e(t),r=t=>e(t)==s,i=t=>Array.isArray(t),c=t=>t.length,d=t=>{throw Error(t)},l=(t,e)=>t.forEach(e),y=(t,...e)=>t.push(...e),u=t=>t.shift(),p=Object,h=t=>p.getPrototypeOf(t),f=p.keys,g=p.freeze,v=t=>(t=>!n(t)&&o(h(t),(t=>t==p.prototype||n(h(t))),(()=>!0)))(t)&&0==(t=>c(f(t)))(t),w=JSON.stringify,C=JSON.parse,S=t=>w(t,((t,e)=>e instanceof Map?p.fromEntries([...e]):e)),b="/store",P=t=>n(t)||0==(t=>t?.size??0)(t),m=(t,e)=>t?.forEach(e),A=(t,e)=>t?.delete(e),L=t=>new Map(t),M=(t,e)=>t?.get(e),T=(t,e,a)=>n(a)?(A(t,e),t):t?.set(e,a),E=(t,e,a,s)=>{var n,o;return n=t,o=e,n?.has(o)?s?.(M(t,e)):T(t,e,a()),M(t,e)},O=(t,e,a,s,n=0)=>o((a?E:M)(t,e[n],n>c(e)-2?a:L),(o=>{if(n>c(e)-2)return s?.(o)&&T(t,e[n]),o;const r=O(o,e,a,s,n+1);return P(o)&&T(t,e[n]),r})),x=t=>new Set(i(t)||n(t)?t:[t]),j=/^\d+$/,k=L(),z=L(),D=(t,e,s,r,p,h,f,w={},C=[])=>{let S,b,D,J=0,K=0,N=0;E(k,C,(()=>0)),E(z,C,(()=>[]));const B=L(),[F,U,W,$,q]=((t=1,e)=>1!=t&&e.isMergeable()?[1,e.getMergeableContent,e.getTransactionMergeableChanges,([[t],[e]])=>!v(t)||!v(e),e.setDefaultContent]:2!=t?[0,e.getContent,e.getTransactionChanges,([t,e])=>!v(t)||!v(e),e.setContent]:d("Store type not supported by this Persister"))(f,t),[G,H,I]=(()=>{let t;const[e,s]=(()=>{const t=[];let e=0;return[s=>(s?u(t):null)??a+e++,e=>{j.test(e)&&c(t)<1e3&&y(t,e)}]})(),r=L();return[(s,n,o,i=[],c=()=>[])=>{t??=tt;const d=e(1);var l,y;return T(r,d,[s,n,o,i,c]),l=O(n,o??[a],x),y=d,l?.add(y),d},(e,s,...n)=>l(((t,e=[a])=>{const s=[],n=(t,a)=>a==c(e)?y(s,t):null===e[a]?m(t,(t=>n(t,a+1))):l([e[a],null],(e=>n(M(t,e),a+1)));return n(t,0),s})(e,s),(e=>m(e,(e=>M(r,e)[0](t,...s??[],...n))))),t=>o(M(r,t),(([,e,n])=>(O(e,n??[a],void 0,(e=>(A(e,t),P(e)?1:0))),T(r,t),s(t),n))),e=>o(M(r,e),(([e,,a=[],s,o])=>{const r=(...i)=>{const d=c(i);d==c(a)?e(t,...i,...o(i)):n(a[d])?l(s[d]?.(...i)??[],(t=>r(...i,t))):r(...i,a[d])};r()}))]})(),Q=t=>{t!=J&&(J=t,H(B,void 0,J))},R=e=>{(F&&i(e?.[0])?1===e?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===e?.[2]?t.applyChanges:t.setContent)(e)},V=async t=>(2!=J&&(Q(1),K++,await _((async()=>{try{const a=await e();i(a)?R(a):t?q(t):d("Content is not an array: "+a)}catch(e){h?.(e),t&&q(t)}Q(0)}))),tt),X=()=>(b&&(p(b),b=void 0),tt),Y=async t=>(1!=J&&(Q(2),N++,await _((async()=>{try{await s(U,t)}catch(t){h?.(t)}Q(0)}))),tt),Z=()=>(o(D,t.delListener),D=void 0,tt),_=async(...t)=>(y(M(z,C),...t),await(async()=>{if(!M(k,C)){for(T(k,C,1);!n(S=u(M(z,C)));)try{await S()}catch(t){h?.(t)}T(k,C,0)}})(),tt),tt={load:V,startAutoLoad:async t=>{await X().load(t);try{b=await r((async(t,e)=>{e||t?2!=J&&(Q(1),K++,R(e??t),Q(0)):await V()}))}catch(t){h?.(t)}return tt},stopAutoLoad:X,isAutoLoading:()=>!n(b),save:Y,startAutoSave:async()=>(await Z().save(),D=t.addDidFinishTransactionListener((()=>{const t=W();$(t)&&Y(t)})),tt),stopAutoSave:Z,isAutoSaving:()=>!n(D),getStatus:()=>J,addStatusListener:t=>G(t,B),delListener:e=>(I(e),t),schedule:_,getStore:()=>t,destroy:()=>(M(z,C).splice(0,void 0),X().stopAutoSave()),getStats:()=>({loads:K,saves:N}),...w};return g(tt)},J="message";t.createPartyKitPersister=(t,e,s,n)=>{const{host:i,room:d}=e.partySocketOptions,{storeProtocol:l="https",storePath:y=b,messagePrefix:u=a}={...r(s)?{storeProtocol:s}:s},p=l+"://"+i+"/parties/"+e.name+"/"+d+y,h=async t=>await(await fetch(p,{...t?{method:"PUT",body:S(t)}:{},mode:"cors",cache:"no-store"})).json();return D(t,(async()=>await h()),(async(t,a)=>{var s;a?e.send(u+"s"+(r(s=a)?s:S(s))):await h(t())}),(t=>{const a=e=>o(((t,e)=>{const a=c(t);return((t,e)=>t.startsWith(e))(e,t)?[e[a],C((s=e,n=a+1,s.slice(n,void 0)))]:void 0;var s,n})(u,e.data),(([e,a])=>{"s"==e&&t(void 0,a)}));return e.addEventListener(J,a),a}),(t=>{e.removeEventListener(J,t)}),n,1,{getConnection:()=>e})}},"object"==typeof exports&&"undefined"!=typeof module?e(exports):"function"==typeof define&&define.amd?define(["exports"],e):e((t="undefined"!=typeof globalThis?globalThis:t||self).TinyBasePersisterPartyKitClient={});
|
|
Binary file
|
|
@@ -1 +1 @@
|
|
|
1
|
-
var t,e;t=this,e=function(t){"use strict";const e=t=>typeof t,a="",s=e(a),n=t=>null==t,o=(t,e,a)=>n(t)?a?.():e(t),r=t=>e(t)==s,i=t=>Array.isArray(t),c=t=>t.length,d=t=>{throw Error(t)},l=(t,e)=>t.forEach(e),y=(t,...e)=>t.push(...e),u=t=>t.shift(),p=Object,h=t=>p.getPrototypeOf(t),f=p.keys,g=p.freeze,v=t=>(t=>!n(t)&&o(h(t),(t=>t==p.prototype||n(h(t))),(()=>!0)))(t)&&0==(t=>c(f(t)))(t),w=JSON.stringify,C=JSON.parse,S=t=>w(t,((t,e)=>e instanceof Map?p.fromEntries([...e]):e)),b="/store",P=t=>n(t)||0==(t=>t?.size??0)(t),m=(t,e)=>t?.forEach(e),A=(t,e)=>t?.delete(e),L=t=>new Map(t),M=(t,e)=>t?.get(e),T=(t,e,a)=>n(a)?(A(t,e),t):t?.set(e,a),E=(t,e,a,s)=>{var n,o;return n=t,o=e,n?.has(o)?s?.(M(t,e)):T(t,e,a()),M(t,e)},O=(t,e,a,s,n=0)=>o((a?E:M)(t,e[n],n>c(e)-2?a:L),(o=>{if(n>c(e)-2)return s?.(o)&&T(t,e[n]),o;const r=O(o,e,a,s,n+1);return P(o)&&T(t,e[n]),r})),x=t=>new Set(i(t)||n(t)?t:[t]),j=/^\d+$/,k=L(),z=L(),D=(t,e,s,r,p,h,f,w={},C=[])=>{let S,b,D,J=0,K=0,N=0;E(k,C,(()=>0)),E(z,C,(()=>[]));const B=L(),[F,U,W,$,q]=((t=1,e)=>1!=t&&e.isMergeable()?[1,e.getMergeableContent,e.getTransactionMergeableChanges,([[t],[e]])=>!v(t)||!v(e),e.setDefaultContent]:2!=t?[0,e.getContent,e.getTransactionChanges,([t,e])=>!v(t)||!v(e),e.setContent]:d("Store type not supported by this Persister"))(f,t),[G,H,I]=(()=>{let t;const[e,s]=(()=>{const t=[];let e=0;return[s=>(s?u(t):null)??a+e++,e=>{j.test(e)&&c(t)<1e3&&y(t,e)}]})(),r=L();return[(s,n,o,i=[],c=()=>[])=>{t??=tt;const d=e(1);var l,y;return T(r,d,[s,n,o,i,c]),l=O(n,o??[a],x),y=d,l?.add(y),d},(e,s,...n)=>l(((t,e=[a])=>{const s=[],n=(t,a)=>a==c(e)?y(s,t):null===e[a]?m(t,(t=>n(t,a+1))):l([e[a],null],(e=>n(M(t,e),a+1)));return n(t,0),s})(e,s),(e=>m(e,(e=>M(r,e)[0](t,...s??[],...n))))),t=>o(M(r,t),(([,e,n])=>(O(e,n??[a],void 0,(e=>(A(e,t),P(e)?1:0))),T(r,t),s(t),n))),e=>o(M(r,e),(([e,,a=[],s,o])=>{const r=(...i)=>{const d=c(i);d==c(a)?e(t,...i,...o(i)):n(a[d])?l(s[d]?.(...i)??[],(t=>r(...i,t))):r(...i,a[d])};r()}))]})(),Q=t=>{t!=J&&(J=t,H(B,void 0,J))},R=e=>{(F&&i(e?.[0])?1===e?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===e?.[2]?t.applyChanges:t.setContent)(e)},V=async t=>(2!=J&&(Q(1),K++,await _((async()=>{try{const a=await e();i(a)?R(a):t?q(t):d("Content is not an array "+a)}catch(e){h?.(e),t&&q(t)}Q(0)}))),tt),X=()=>(b&&(p(b),b=void 0),tt),Y=async t=>(1!=J&&(Q(2),N++,await _((async()=>{try{await s(U,t)}catch(t){h?.(t)}Q(0)}))),tt),Z=()=>(o(D,t.delListener),D=void 0,tt),_=async(...t)=>(y(M(z,C),...t),await(async()=>{if(!M(k,C)){for(T(k,C,1);!n(S=u(M(z,C)));)try{await S()}catch(t){h?.(t)}T(k,C,0)}})(),tt),tt={load:V,startAutoLoad:async t=>{await X().load(t);try{b=await r((async(t,e)=>{e||t?2!=J&&(Q(1),K++,R(e??t),Q(0)):await V()}))}catch(t){h?.(t)}return tt},stopAutoLoad:X,isAutoLoading:()=>!n(b),save:Y,startAutoSave:async()=>(await Z().save(),D=t.addDidFinishTransactionListener((()=>{const t=W();$(t)&&Y(t)})),tt),stopAutoSave:Z,isAutoSaving:()=>!n(D),getStatus:()=>J,addStatusListener:t=>G(t,B),delListener:e=>(I(e),t),schedule:_,getStore:()=>t,destroy:()=>(M(z,C).splice(0,void 0),X().stopAutoSave()),getStats:()=>({loads:K,saves:N}),...w};return g(tt)},J="message";t.createPartyKitPersister=(t,e,s,n)=>{const{host:i,room:d}=e.partySocketOptions,{storeProtocol:l="https",storePath:y=b,messagePrefix:u=a}={...r(s)?{storeProtocol:s}:s},p=l+"://"+i+"/parties/"+e.name+"/"+d+y,h=async t=>await(await fetch(p,{...t?{method:"PUT",body:S(t)}:{},mode:"cors",cache:"no-store"})).json();return D(t,(async()=>await h()),(async(t,a)=>{var s;a?e.send(u+"s"+(r(s=a)?s:S(s))):await h(t())}),(t=>{const a=e=>o(((t,e)=>{const a=c(t);return((t,e)=>t.startsWith(e))(e,t)?[e[a],C((s=e,n=a+1,s.slice(n,void 0)))]:void 0;var s,n})(u,e.data),(([e,a])=>{"s"==e&&t(void 0,a)}));return e.addEventListener(J,a),a}),(t=>{e.removeEventListener(J,t)}),n,1,{getConnection:()=>e})}},"object"==typeof exports&&"undefined"!=typeof module?e(exports):"function"==typeof define&&define.amd?define(["exports"],e):e((t="undefined"!=typeof globalThis?globalThis:t||self).TinyBasePersisterPartyKitClient={});
|
|
1
|
+
var t,e;t=this,e=function(t){"use strict";const e=t=>typeof t,a="",s=e(a),n=t=>null==t,o=(t,e,a)=>n(t)?a?.():e(t),r=t=>e(t)==s,i=t=>Array.isArray(t),c=t=>t.length,d=t=>{throw Error(t)},l=(t,e)=>t.forEach(e),y=(t,...e)=>t.push(...e),u=t=>t.shift(),p=Object,h=t=>p.getPrototypeOf(t),f=p.keys,g=p.freeze,v=t=>(t=>!n(t)&&o(h(t),(t=>t==p.prototype||n(h(t))),(()=>!0)))(t)&&0==(t=>c(f(t)))(t),w=JSON.stringify,C=JSON.parse,S=t=>w(t,((t,e)=>e instanceof Map?p.fromEntries([...e]):e)),b="/store",P=t=>n(t)||0==(t=>t?.size??0)(t),m=(t,e)=>t?.forEach(e),A=(t,e)=>t?.delete(e),L=t=>new Map(t),M=(t,e)=>t?.get(e),T=(t,e,a)=>n(a)?(A(t,e),t):t?.set(e,a),E=(t,e,a,s)=>{var n,o;return n=t,o=e,n?.has(o)?s?.(M(t,e)):T(t,e,a()),M(t,e)},O=(t,e,a,s,n=0)=>o((a?E:M)(t,e[n],n>c(e)-2?a:L),(o=>{if(n>c(e)-2)return s?.(o)&&T(t,e[n]),o;const r=O(o,e,a,s,n+1);return P(o)&&T(t,e[n]),r})),x=t=>new Set(i(t)||n(t)?t:[t]),j=/^\d+$/,k=L(),z=L(),D=(t,e,s,r,p,h,f,w={},C=[])=>{let S,b,D,J=0,K=0,N=0;E(k,C,(()=>0)),E(z,C,(()=>[]));const B=L(),[F,U,W,$,q]=((t=1,e)=>1!=t&&e.isMergeable()?[1,e.getMergeableContent,e.getTransactionMergeableChanges,([[t],[e]])=>!v(t)||!v(e),e.setDefaultContent]:2!=t?[0,e.getContent,e.getTransactionChanges,([t,e])=>!v(t)||!v(e),e.setContent]:d("Store type not supported by this Persister"))(f,t),[G,H,I]=(()=>{let t;const[e,s]=(()=>{const t=[];let e=0;return[s=>(s?u(t):null)??a+e++,e=>{j.test(e)&&c(t)<1e3&&y(t,e)}]})(),r=L();return[(s,n,o,i=[],c=()=>[])=>{t??=tt;const d=e(1);var l,y;return T(r,d,[s,n,o,i,c]),l=O(n,o??[a],x),y=d,l?.add(y),d},(e,s,...n)=>l(((t,e=[a])=>{const s=[],n=(t,a)=>a==c(e)?y(s,t):null===e[a]?m(t,(t=>n(t,a+1))):l([e[a],null],(e=>n(M(t,e),a+1)));return n(t,0),s})(e,s),(e=>m(e,(e=>M(r,e)[0](t,...s??[],...n))))),t=>o(M(r,t),(([,e,n])=>(O(e,n??[a],void 0,(e=>(A(e,t),P(e)?1:0))),T(r,t),s(t),n))),e=>o(M(r,e),(([e,,a=[],s,o])=>{const r=(...i)=>{const d=c(i);d==c(a)?e(t,...i,...o(i)):n(a[d])?l(s[d]?.(...i)??[],(t=>r(...i,t))):r(...i,a[d])};r()}))]})(),Q=t=>{t!=J&&(J=t,H(B,void 0,J))},R=e=>{(F&&i(e?.[0])?1===e?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===e?.[2]?t.applyChanges:t.setContent)(e)},V=async t=>(2!=J&&(Q(1),K++,await _((async()=>{try{const a=await e();i(a)?R(a):t?q(t):d("Content is not an array: "+a)}catch(e){h?.(e),t&&q(t)}Q(0)}))),tt),X=()=>(b&&(p(b),b=void 0),tt),Y=async t=>(1!=J&&(Q(2),N++,await _((async()=>{try{await s(U,t)}catch(t){h?.(t)}Q(0)}))),tt),Z=()=>(o(D,t.delListener),D=void 0,tt),_=async(...t)=>(y(M(z,C),...t),await(async()=>{if(!M(k,C)){for(T(k,C,1);!n(S=u(M(z,C)));)try{await S()}catch(t){h?.(t)}T(k,C,0)}})(),tt),tt={load:V,startAutoLoad:async t=>{await X().load(t);try{b=await r((async(t,e)=>{e||t?2!=J&&(Q(1),K++,R(e??t),Q(0)):await V()}))}catch(t){h?.(t)}return tt},stopAutoLoad:X,isAutoLoading:()=>!n(b),save:Y,startAutoSave:async()=>(await Z().save(),D=t.addDidFinishTransactionListener((()=>{const t=W();$(t)&&Y(t)})),tt),stopAutoSave:Z,isAutoSaving:()=>!n(D),getStatus:()=>J,addStatusListener:t=>G(t,B),delListener:e=>(I(e),t),schedule:_,getStore:()=>t,destroy:()=>(M(z,C).splice(0,void 0),X().stopAutoSave()),getStats:()=>({loads:K,saves:N}),...w};return g(tt)},J="message";t.createPartyKitPersister=(t,e,s,n)=>{const{host:i,room:d}=e.partySocketOptions,{storeProtocol:l="https",storePath:y=b,messagePrefix:u=a}={...r(s)?{storeProtocol:s}:s},p=l+"://"+i+"/parties/"+e.name+"/"+d+y,h=async t=>await(await fetch(p,{...t?{method:"PUT",body:S(t)}:{},mode:"cors",cache:"no-store"})).json();return D(t,(async()=>await h()),(async(t,a)=>{var s;a?e.send(u+"s"+(r(s=a)?s:S(s))):await h(t())}),(t=>{const a=e=>o(((t,e)=>{const a=c(t);return((t,e)=>t.startsWith(e))(e,t)?[e[a],C((s=e,n=a+1,s.slice(n,void 0)))]:void 0;var s,n})(u,e.data),(([e,a])=>{"s"==e&&t(void 0,a)}));return e.addEventListener(J,a),a}),(t=>{e.removeEventListener(J,t)}),n,1,{getConnection:()=>e})}},"object"==typeof exports&&"undefined"!=typeof module?e(exports):"function"==typeof define&&define.amd?define(["exports"],e):e((t="undefined"!=typeof globalThis?globalThis:t||self).TinyBasePersisterPartyKitClient={});
|
|
Binary file
|
|
@@ -1 +1 @@
|
|
|
1
|
-
var t,a;t=this,a=function(t){"use strict";const a=t=>typeof t,e="tinybase",n=",",s=a(""),i=Promise,o=t=>null==t,r=(t,a,e)=>o(t)?e?.():a(t),c=t=>a(t)==s,l=t=>Array.isArray(t),E=(t,a,e)=>t.slice(a,e),y=t=>t.length,w=async t=>i.all(t),d=t=>{throw Error(t)},u=(t,a)=>t.forEach(a),T=(t,a="")=>t.join(a),R=(t,a)=>t.map(a),A=t=>0==y(t),N=(t,a)=>t.filter(a),g=(t,...a)=>t.push(...a),p=t=>t.shift(),C="_",O="_id",f="SELECT",v="WHERE",L="TABLE",$="ALTER "+L,m="DELETE FROM",I=f+"*FROM",S=t=>`"${t.replace(/"/g,'""')}"`,h=(t,a=[1])=>T(R(t,(()=>"$"+a[0]++)),n),_=(t,a)=>t?.has(a)??!1,b=t=>o(t)||0==(t=>t?.size??0)(t),P=t=>[...t?.values()??[]],D=(t,a)=>t?.forEach(a),U=(t,a)=>t?.delete(a),F=Object,M=t=>F.getPrototypeOf(t),G=F.entries,B=F.keys,j=F.freeze,x=(t=[])=>F.fromEntries(t),X=(...t)=>F.assign({},...t),Y=(t,a)=>(delete t[a],t),q=(t,a)=>R(G(t),(([t,e])=>a(e,t))),H=t=>F.values(t),W=t=>y(B(t)),k=t=>(t=>!o(t)&&r(M(t),(t=>t==F.prototype||o(M(t))),(()=>!0)))(t)&&0==W(t),z=JSON.stringify,J=JSON.parse,K=t=>new Map(t),V=(t,a)=>t?.get(a),Q=(t,a)=>R([...t?.entries()??[]],(([t,e])=>a(e,t))),Z=(t,a,e)=>o(e)?(U(t,a),t):t?.set(a,e),tt=(t,a,e,n)=>(_(t,a)?n?.(V(t,a)):Z(t,a,e()),V(t,a)),at=(t,a,e,n,s=0)=>r((e?tt:V)(t,a[s],s>y(a)-2?e:K),(i=>{if(s>y(a)-2)return n?.(i)&&Z(t,a[s]),i;const o=at(i,a,e,n,s+1);return b(i)&&Z(t,a[s]),o})),et=t=>new Set(l(t)||o(t)?t:[t]),nt=(t,a)=>t?.add(a),st=/^\d+$/,it=K(),ot=K(),rt=(t,a,e,n,s,i,c,E={},w=[])=>{let T,R,A,N=0,C=0,O=0;tt(it,w,(()=>0)),tt(ot,w,(()=>[]));const f=K(),[v,L,$,m,I]=((t=1,a)=>1!=t&&a.isMergeable()?[1,a.getMergeableContent,a.getTransactionMergeableChanges,([[t],[a]])=>!k(t)||!k(a),a.setDefaultContent]:2!=t?[0,a.getContent,a.getTransactionChanges,([t,a])=>!k(t)||!k(a),a.setContent]:d("Store type not supported by this Persister"))(c,t),[S,h,_]=(()=>{let t;const[a,e]=(()=>{const t=[];let a=0;return[e=>(e?p(t):null)??""+a++,a=>{st.test(a)&&y(t)<1e3&&g(t,a)}]})(),n=K();return[(e,s,i,o=[],r=()=>[])=>{t??=Y;const c=a(1);return Z(n,c,[e,s,i,o,r]),nt(at(s,i??[""],et),c),c},(a,e,...s)=>u(((t,a=[""])=>{const e=[],n=(t,s)=>s==y(a)?g(e,t):null===a[s]?D(t,(t=>n(t,s+1))):u([a[s],null],(a=>n(V(t,a),s+1)));return n(t,0),e})(a,e),(a=>D(a,(a=>V(n,a)[0](t,...e??[],...s))))),t=>r(V(n,t),(([,a,s])=>(at(a,s??[""],void 0,(a=>(U(a,t),b(a)?1:0))),Z(n,t),e(t),s))),a=>r(V(n,a),(([a,,e=[],n,s])=>{const i=(...r)=>{const c=y(r);c==y(e)?a(t,...r,...s(r)):o(e[c])?u(n[c]?.(...r)??[],(t=>i(...r,t))):i(...r,e[c])};i()}))]})(),P=t=>{t!=N&&(N=t,h(f,void 0,N))},F=a=>{(v&&l(a?.[0])?1===a?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===a?.[2]?t.applyChanges:t.setContent)(a)},M=async t=>(2!=N&&(P(1),C++,await X((async()=>{try{const e=await a();l(e)?F(e):t?I(t):d("Content is not an array "+e)}catch(a){i?.(a),t&&I(t)}P(0)}))),Y),G=()=>(R&&(s(R),R=void 0),Y),B=async t=>(1!=N&&(P(2),O++,await X((async()=>{try{await e(L,t)}catch(t){i?.(t)}P(0)}))),Y),x=()=>(r(A,t.delListener),A=void 0,Y),X=async(...t)=>(g(V(ot,w),...t),await(async()=>{if(!V(it,w)){for(Z(it,w,1);!o(T=p(V(ot,w)));)try{await T()}catch(t){i?.(t)}Z(it,w,0)}})(),Y),Y={load:M,startAutoLoad:async t=>{await G().load(t);try{R=await n((async(t,a)=>{a||t?2!=N&&(P(1),C++,F(a??t),P(0)):await M()}))}catch(t){i?.(t)}return Y},stopAutoLoad:G,isAutoLoading:()=>!o(R),save:B,startAutoSave:async()=>(await x().save(),A=t.addDidFinishTransactionListener((()=>{const t=$();m(t)&&B(t)})),Y),stopAutoSave:x,isAutoSaving:()=>!o(A),getStatus:()=>N,addStatusListener:t=>S(t,f),delListener:a=>(_(a),t),schedule:X,getStore:()=>t,destroy:()=>(V(ot,w).splice(0,void 0),G().stopAutoSave()),getStats:()=>({loads:C,saves:O}),...E};return j(Y)},ct=(t,a,e,s,i,r=lt,c,l)=>{const E=K();return[async()=>{E.clear(),R(await e(t,a),(({tn:t,cn:a})=>nt(tt(E,t,et),a)))},async(a,e)=>((t,a)=>_(V(E,t),a))(a,e)?x(N(R(await t(I+S(a)),(t=>{return[t[e],l?(a=Y(t,e),n=l,x(q(a,((t,a)=>[a,n(t,a)])))):Y(t,e)];var a,n})),(([t,a])=>!o(t)&&!k(a)))):{},async(a,e,s,l,y,d=!1)=>{const u=et();q(s??{},(t=>R(B(t??{}),(t=>nt(u,t)))));const p=P(u);if(!d&&y&&A(p)&&_(E,a))return await t("DROP "+L+S(a)),void Z(E,a);const C=V(E,a),O=et(P(C));if(A(p)||(_(E,a)?await w(R([e,...p],(async(n,s)=>{U(O,n)||(await t($+S(a)+"ADD"+S(n)+i),0==s&&await t("CREATE UNIQUE INDEX pk ON "+S(a)+`(${S(e)})`),nt(C,n))}))):(await t("CREATE "+L+S(a)+`(${S(e)}${i} PRIMARY KEY${T(R(p,(t=>n+S(t)+i)))});`),Z(E,a,et([e,...p])))),await w([...!d&&l?R(P(O),(async n=>{n!=e&&(await t($+S(a)+"DROP"+S(n)),U(C,n))})):[]]),d)o(s)?await t(m+S(a)+v+" true"):await w(q(s,(async(n,s)=>{o(n)?await t(m+S(a)+v+S(e)+"=$1",[s]):A(p)||await r(t,a,e,B(n),{[s]:c?R(H(n),c):H(n)},C)})));else if(A(p))_(E,a)&&await t(m+S(a)+v+" true");else{const n=N(P(V(E,a)),(t=>t!=e)),i={},o=[];q(s??{},((t,a)=>{i[a]=R(n,(a=>c?c(t?.[a]):t?.[a])),g(o,a)})),await r(t,a,e,n,i),await t(m+S(a)+v+S(e)+`NOT IN(${h(o)})`,o)}},async a=>{let e;await t("BEGIN");try{e=await a()}catch(t){s?.(t)}return await t("END"),e}]},lt=async(t,a,e,s,i)=>{const o=[1];await t("INSERT INTO"+S(a)+"("+((...t)=>T(R(t,S),n))(e,...s)+")VALUES"+T(q(i,(t=>"($"+o[0]+++","+h(t,o)+")")),n)+"ON CONFLICT("+S(e)+")DO UPDATE SET"+T(R(s,(t=>S(t)+"=excluded."+S(t))),n),q(i,((t,a)=>[a,...R(t,(t=>t??null))])).flat())},Et=(t,a,e,n,s,i,o,[r,c,l],E,y,w,d,u,T)=>{const[R,A,N,g]=ct(a,E,y,s,u,T),p=rt(t,(async()=>await g((async()=>{return await R(),t=(await A(r,c))[C]?.[l]??"null",J(t,((t,a)=>""===a?void 0:a));var t}))),(async t=>await g((async()=>{var a;await R(),await N(r,c,{[C]:{[l]:(a=t()??null,z(a,((t,a)=>void 0===a?"":a)))}},!0,!0)}))),e,n,s,o,{[d]:()=>w,destroy:()=>(p.stopAutoLoad().stopAutoSave(),i(),p)},w);return p},yt=(t,a,e,n,s,i,r,[c,l,[E,y,d]],u,T,R,A,g,p,f,v)=>{const[L,$,m,I]=ct(a,u,T,s,g,p,f,v),S=async(t,a)=>await w(Q(l,(async([e,n,s,i],o)=>{a&&!(o in t)||await m(e,n,t[o],s,i,a)}))),h=async(t,a)=>y?await m(d,O,{[C]:t},!0,!0,a):null,_=rt(t,(async()=>await I((async()=>{await L();const t=await(async()=>x(N(await w(Q(c,(async([t,a],e)=>[t,await $(e,a)]))),(t=>!k(t[1])))))(),a=await(async()=>E?(await $(d,O))[C]:{})();return k(t)&&o(a)?void 0:[t,a]}))),(async(t,a)=>await I((async()=>{if(await L(),o(a)){const[a,e]=t();await S(a),await h(e)}else await S(a[0],!0),await h(a[1],!0)}))),e,n,s,r,{[A]:()=>R,destroy:()=>(_.stopAutoLoad().stopAutoSave(),i(),_)},R);return _},wt="ColumnName",dt="store",ut="json",Tt=dt+"TableName",Rt=dt+"Id"+wt,At=dt+wt,Nt="autoLoadIntervalSeconds",gt="rowId"+wt,pt="tableId",Ct="tableName",Ot="deleteEmptyColumns",ft="deleteEmptyTable",vt={mode:ut,[Nt]:1},Lt={load:0,save:0,[Ct]:e+"_values"},$t=(t,a,e,n,s)=>{const i=K();return q(t,((t,r)=>{const l=E(H(X(a,c(t)?{[e]:t}:t)),0,W(a));o(l[0])||n(r,l[0])||(s(r,l[0]),Z(i,r,l))})),i},mt=e,It=/^([cd]:)(.+)/,St=e+"_data",ht=e+"_table";t.createPglitePersister=async(t,a,n,s,i)=>((t,a,n,s,i,o,l,y,d,u,T="getDb")=>{const A=((t,a)=>a?async(e,n)=>(a(e,n),await t(e,n)):t)(n,o),[N,,g,p]=(t=>{const a=(t=>X(vt,c(t)?{[Tt]:t}:t??{}))(t),n=a[Nt];if(a.mode==ut){const t=a[Tt]??e;return[1,n,[t,a[Rt]??O,a[At]??dt],et(t)]}const{tables:{load:s={},save:i={}}={},values:o={}}=a,r=E(H(X(Lt,o)),0,W(Lt)),l=r[2],y=et(l),w=et(l);return[0,n,[$t(s,{[pt]:null,[gt]:O},pt,(t=>_(w,t)),(t=>nt(y,t))),$t(i,{[Ct]:null,[gt]:O,[Ot]:0,[ft]:0},Ct,((t,a)=>_(w,a)),((t,a)=>nt(y,a))),r],y]})(a),C=async t=>{await A(`CREATE OR REPLACE TRIGGER ${S(St+"_"+t)} AFTER INSERT OR UPDATE OR DELETE ON ${S(t)} EXECUTE FUNCTION ${St}()`)};return(N?Et:yt)(t,A,(async t=>{await A(`CREATE OR REPLACE FUNCTION ${ht}()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('${mt}','c:'||SPLIT_PART(row.object_identity,'.',2));END LOOP;END;$t2$ LANGUAGE plpgsql;`);try{await A(`CREATE EVENT TRIGGER ${ht} ON ddl_command_end WHEN TAG IN('CREATE TABLE')EXECUTE FUNCTION ${ht}();`)}catch{}return await A(`CREATE OR REPLACE FUNCTION ${St}()RETURNS trigger AS $t1$ BEGIN PERFORM pg_notify('${mt}','d:'||TG_TABLE_NAME);RETURN NULL;END;$t1$ LANGUAGE plpgsql;`),await w(R(P(p),(async t=>{await A(`CREATE TABLE IF NOT EXISTS ${S(t)}("_id"text PRIMARY KEY)`),await C(t)}))),await s(mt,(async a=>{return await r((e=a,n=It,e?.match(n)),(async([,a,e])=>{_(p,e)&&("c:"==a&&await C(e),t())}));var e,n}))}),i,l,y,d,g,P(p),(async(t,a)=>await t(`${f} table_name tn,column_name cn FROM information_schema.columns ${v} table_schema='public'AND table_name IN(${h(a)})`,a)),u,T,"text",void 0,(t=>z(t)),(t=>J(t)))})(t,n,(async(t,e=[])=>(await a.query(t,e)).rows),(async(t,e)=>await a.listen(t,e)),(async t=>{try{await t()}catch(t){i?.(t)}}),s,i,(()=>0),3,a,"getPglite")},"object"==typeof exports&&"undefined"!=typeof module?a(exports):"function"==typeof define&&define.amd?define(["exports"],a):a((t="undefined"!=typeof globalThis?globalThis:t||self).TinyBasePersisterPglite={});
|
|
1
|
+
var t,a;t=this,a=function(t){"use strict";const a=t=>typeof t,e="tinybase",n=",",s=a(""),i=Promise,o=t=>null==t,r=(t,a,e)=>o(t)?e?.():a(t),c=t=>a(t)==s,l=t=>Array.isArray(t),E=(t,a,e)=>t.slice(a,e),y=t=>t.length,w=async t=>i.all(t),d=t=>{throw Error(t)},u=(t,a)=>t.forEach(a),T=(t,a="")=>t.join(a),R=(t,a)=>t.map(a),A=t=>0==y(t),N=(t,a)=>t.filter(a),g=(t,...a)=>t.push(...a),p=t=>t.shift(),C="_",O="_id",f="SELECT",v="WHERE",L="TABLE",$="ALTER "+L,m="DELETE FROM",I=f+"*FROM",S=t=>`"${t.replace(/"/g,'""')}"`,h=(t,a=[1])=>T(R(t,(()=>"$"+a[0]++)),n),_=(t,a)=>t?.has(a)??!1,b=t=>o(t)||0==(t=>t?.size??0)(t),P=t=>[...t?.values()??[]],D=(t,a)=>t?.forEach(a),U=(t,a)=>t?.delete(a),F=Object,M=t=>F.getPrototypeOf(t),G=F.entries,B=F.keys,j=F.freeze,x=(t=[])=>F.fromEntries(t),X=(...t)=>F.assign({},...t),Y=(t,a)=>(delete t[a],t),q=(t,a)=>R(G(t),(([t,e])=>a(e,t))),H=t=>F.values(t),W=t=>y(B(t)),k=t=>(t=>!o(t)&&r(M(t),(t=>t==F.prototype||o(M(t))),(()=>!0)))(t)&&0==W(t),z=JSON.stringify,J=JSON.parse,K=t=>new Map(t),V=(t,a)=>t?.get(a),Q=(t,a)=>R([...t?.entries()??[]],(([t,e])=>a(e,t))),Z=(t,a,e)=>o(e)?(U(t,a),t):t?.set(a,e),tt=(t,a,e,n)=>(_(t,a)?n?.(V(t,a)):Z(t,a,e()),V(t,a)),at=(t,a,e,n,s=0)=>r((e?tt:V)(t,a[s],s>y(a)-2?e:K),(i=>{if(s>y(a)-2)return n?.(i)&&Z(t,a[s]),i;const o=at(i,a,e,n,s+1);return b(i)&&Z(t,a[s]),o})),et=t=>new Set(l(t)||o(t)?t:[t]),nt=(t,a)=>t?.add(a),st=/^\d+$/,it=K(),ot=K(),rt=(t,a,e,n,s,i,c,E={},w=[])=>{let T,R,A,N=0,C=0,O=0;tt(it,w,(()=>0)),tt(ot,w,(()=>[]));const f=K(),[v,L,$,m,I]=((t=1,a)=>1!=t&&a.isMergeable()?[1,a.getMergeableContent,a.getTransactionMergeableChanges,([[t],[a]])=>!k(t)||!k(a),a.setDefaultContent]:2!=t?[0,a.getContent,a.getTransactionChanges,([t,a])=>!k(t)||!k(a),a.setContent]:d("Store type not supported by this Persister"))(c,t),[S,h,_]=(()=>{let t;const[a,e]=(()=>{const t=[];let a=0;return[e=>(e?p(t):null)??""+a++,a=>{st.test(a)&&y(t)<1e3&&g(t,a)}]})(),n=K();return[(e,s,i,o=[],r=()=>[])=>{t??=Y;const c=a(1);return Z(n,c,[e,s,i,o,r]),nt(at(s,i??[""],et),c),c},(a,e,...s)=>u(((t,a=[""])=>{const e=[],n=(t,s)=>s==y(a)?g(e,t):null===a[s]?D(t,(t=>n(t,s+1))):u([a[s],null],(a=>n(V(t,a),s+1)));return n(t,0),e})(a,e),(a=>D(a,(a=>V(n,a)[0](t,...e??[],...s))))),t=>r(V(n,t),(([,a,s])=>(at(a,s??[""],void 0,(a=>(U(a,t),b(a)?1:0))),Z(n,t),e(t),s))),a=>r(V(n,a),(([a,,e=[],n,s])=>{const i=(...r)=>{const c=y(r);c==y(e)?a(t,...r,...s(r)):o(e[c])?u(n[c]?.(...r)??[],(t=>i(...r,t))):i(...r,e[c])};i()}))]})(),P=t=>{t!=N&&(N=t,h(f,void 0,N))},F=a=>{(v&&l(a?.[0])?1===a?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===a?.[2]?t.applyChanges:t.setContent)(a)},M=async t=>(2!=N&&(P(1),C++,await X((async()=>{try{const e=await a();l(e)?F(e):t?I(t):d("Content is not an array: "+e)}catch(a){i?.(a),t&&I(t)}P(0)}))),Y),G=()=>(R&&(s(R),R=void 0),Y),B=async t=>(1!=N&&(P(2),O++,await X((async()=>{try{await e(L,t)}catch(t){i?.(t)}P(0)}))),Y),x=()=>(r(A,t.delListener),A=void 0,Y),X=async(...t)=>(g(V(ot,w),...t),await(async()=>{if(!V(it,w)){for(Z(it,w,1);!o(T=p(V(ot,w)));)try{await T()}catch(t){i?.(t)}Z(it,w,0)}})(),Y),Y={load:M,startAutoLoad:async t=>{await G().load(t);try{R=await n((async(t,a)=>{a||t?2!=N&&(P(1),C++,F(a??t),P(0)):await M()}))}catch(t){i?.(t)}return Y},stopAutoLoad:G,isAutoLoading:()=>!o(R),save:B,startAutoSave:async()=>(await x().save(),A=t.addDidFinishTransactionListener((()=>{const t=$();m(t)&&B(t)})),Y),stopAutoSave:x,isAutoSaving:()=>!o(A),getStatus:()=>N,addStatusListener:t=>S(t,f),delListener:a=>(_(a),t),schedule:X,getStore:()=>t,destroy:()=>(V(ot,w).splice(0,void 0),G().stopAutoSave()),getStats:()=>({loads:C,saves:O}),...E};return j(Y)},ct=(t,a,e,s,i,r=lt,c,l)=>{const E=K();return[async()=>{E.clear(),R(await e(t,a),(({tn:t,cn:a})=>nt(tt(E,t,et),a)))},async(a,e)=>((t,a)=>_(V(E,t),a))(a,e)?x(N(R(await t(I+S(a)),(t=>{return[t[e],l?(a=Y(t,e),n=l,x(q(a,((t,a)=>[a,n(t,a)])))):Y(t,e)];var a,n})),(([t,a])=>!o(t)&&!k(a)))):{},async(a,e,s,l,y,d=!1)=>{const u=et();q(s??{},(t=>R(B(t??{}),(t=>nt(u,t)))));const p=P(u);if(!d&&y&&A(p)&&_(E,a))return await t("DROP "+L+S(a)),void Z(E,a);const C=V(E,a),O=et(P(C));if(A(p)||(_(E,a)?await w(R([e,...p],(async(n,s)=>{U(O,n)||(await t($+S(a)+"ADD"+S(n)+i),0==s&&await t("CREATE UNIQUE INDEX pk ON "+S(a)+`(${S(e)})`),nt(C,n))}))):(await t("CREATE "+L+S(a)+`(${S(e)}${i} PRIMARY KEY${T(R(p,(t=>n+S(t)+i)))});`),Z(E,a,et([e,...p])))),await w([...!d&&l?R(P(O),(async n=>{n!=e&&(await t($+S(a)+"DROP"+S(n)),U(C,n))})):[]]),d)o(s)?await t(m+S(a)+v+" true"):await w(q(s,(async(n,s)=>{o(n)?await t(m+S(a)+v+S(e)+"=$1",[s]):A(p)||await r(t,a,e,B(n),{[s]:c?R(H(n),c):H(n)},C)})));else if(A(p))_(E,a)&&await t(m+S(a)+v+" true");else{const n=N(P(V(E,a)),(t=>t!=e)),i={},o=[];q(s??{},((t,a)=>{i[a]=R(n,(a=>c?c(t?.[a]):t?.[a])),g(o,a)})),await r(t,a,e,n,i),await t(m+S(a)+v+S(e)+`NOT IN(${h(o)})`,o)}},async a=>{let e;await t("BEGIN");try{e=await a()}catch(t){s?.(t)}return await t("END"),e}]},lt=async(t,a,e,s,i)=>{const o=[1];await t("INSERT INTO"+S(a)+"("+((...t)=>T(R(t,S),n))(e,...s)+")VALUES"+T(q(i,(t=>"($"+o[0]+++","+h(t,o)+")")),n)+"ON CONFLICT("+S(e)+")DO UPDATE SET"+T(R(s,(t=>S(t)+"=excluded."+S(t))),n),q(i,((t,a)=>[a,...R(t,(t=>t??null))])).flat())},Et=(t,a,e,n,s,i,o,[r,c,l],E,y,w,d,u,T)=>{const[R,A,N,g]=ct(a,E,y,s,u,T),p=rt(t,(async()=>await g((async()=>{return await R(),t=(await A(r,c))[C]?.[l]??"null",J(t,((t,a)=>""===a?void 0:a));var t}))),(async t=>await g((async()=>{var a;await R(),await N(r,c,{[C]:{[l]:(a=t()??null,z(a,((t,a)=>void 0===a?"":a)))}},!0,!0)}))),e,n,s,o,{[d]:()=>w,destroy:()=>(p.stopAutoLoad().stopAutoSave(),i(),p)},w);return p},yt=(t,a,e,n,s,i,r,[c,l,[E,y,d]],u,T,R,A,g,p,f,v)=>{const[L,$,m,I]=ct(a,u,T,s,g,p,f,v),S=async(t,a)=>await w(Q(l,(async([e,n,s,i],o)=>{a&&!(o in t)||await m(e,n,t[o],s,i,a)}))),h=async(t,a)=>y?await m(d,O,{[C]:t},!0,!0,a):null,_=rt(t,(async()=>await I((async()=>{await L();const t=await(async()=>x(N(await w(Q(c,(async([t,a],e)=>[t,await $(e,a)]))),(t=>!k(t[1])))))(),a=await(async()=>E?(await $(d,O))[C]:{})();return k(t)&&o(a)?void 0:[t,a]}))),(async(t,a)=>await I((async()=>{if(await L(),o(a)){const[a,e]=t();await S(a),await h(e)}else await S(a[0],!0),await h(a[1],!0)}))),e,n,s,r,{[A]:()=>R,destroy:()=>(_.stopAutoLoad().stopAutoSave(),i(),_)},R);return _},wt="ColumnName",dt="store",ut="json",Tt=dt+"TableName",Rt=dt+"Id"+wt,At=dt+wt,Nt="autoLoadIntervalSeconds",gt="rowId"+wt,pt="tableId",Ct="tableName",Ot="deleteEmptyColumns",ft="deleteEmptyTable",vt={mode:ut,[Nt]:1},Lt={load:0,save:0,[Ct]:e+"_values"},$t=(t,a,e,n,s)=>{const i=K();return q(t,((t,r)=>{const l=E(H(X(a,c(t)?{[e]:t}:t)),0,W(a));o(l[0])||n(r,l[0])||(s(r,l[0]),Z(i,r,l))})),i},mt=e,It=/^([cd]:)(.+)/,St=e+"_data",ht=e+"_table";t.createPglitePersister=async(t,a,n,s,i)=>((t,a,n,s,i,o,l,y,d,u,T="getDb")=>{const A=((t,a)=>a?async(e,n)=>(a(e,n),await t(e,n)):t)(n,o),[N,,g,p]=(t=>{const a=(t=>X(vt,c(t)?{[Tt]:t}:t??{}))(t),n=a[Nt];if(a.mode==ut){const t=a[Tt]??e;return[1,n,[t,a[Rt]??O,a[At]??dt],et(t)]}const{tables:{load:s={},save:i={}}={},values:o={}}=a,r=E(H(X(Lt,o)),0,W(Lt)),l=r[2],y=et(l),w=et(l);return[0,n,[$t(s,{[pt]:null,[gt]:O},pt,(t=>_(w,t)),(t=>nt(y,t))),$t(i,{[Ct]:null,[gt]:O,[Ot]:0,[ft]:0},Ct,((t,a)=>_(w,a)),((t,a)=>nt(y,a))),r],y]})(a),C=async t=>{await A(`CREATE OR REPLACE TRIGGER ${S(St+"_"+t)} AFTER INSERT OR UPDATE OR DELETE ON ${S(t)} EXECUTE FUNCTION ${St}()`)};return(N?Et:yt)(t,A,(async t=>{await A(`CREATE OR REPLACE FUNCTION ${ht}()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('${mt}','c:'||SPLIT_PART(row.object_identity,'.',2));END LOOP;END;$t2$ LANGUAGE plpgsql;`);try{await A(`CREATE EVENT TRIGGER ${ht} ON ddl_command_end WHEN TAG IN('CREATE TABLE')EXECUTE FUNCTION ${ht}();`)}catch{}return await A(`CREATE OR REPLACE FUNCTION ${St}()RETURNS trigger AS $t1$ BEGIN PERFORM pg_notify('${mt}','d:'||TG_TABLE_NAME);RETURN NULL;END;$t1$ LANGUAGE plpgsql;`),await w(R(P(p),(async t=>{await A(`CREATE TABLE IF NOT EXISTS ${S(t)}("_id"text PRIMARY KEY)`),await C(t)}))),await s(mt,(async a=>{return await r((e=a,n=It,e?.match(n)),(async([,a,e])=>{_(p,e)&&("c:"==a&&await C(e),t())}));var e,n}))}),i,l,y,d,g,P(p),(async(t,a)=>await t(`${f} table_name tn,column_name cn FROM information_schema.columns ${v} table_schema='public'AND table_name IN(${h(a)})`,a)),u,T,"text",void 0,(t=>z(t)),(t=>J(t)))})(t,n,(async(t,e=[])=>(await a.query(t,e)).rows),(async(t,e)=>await a.listen(t,e)),(async t=>{try{await t()}catch(t){i?.(t)}}),s,i,(()=>0),3,a,"getPglite")},"object"==typeof exports&&"undefined"!=typeof module?a(exports):"function"==typeof define&&define.amd?define(["exports"],a):a((t="undefined"!=typeof globalThis?globalThis:t||self).TinyBasePersisterPglite={});
|
|
Binary file
|
|
@@ -1 +1 @@
|
|
|
1
|
-
var t,a;t=this,a=function(t){"use strict";const a=t=>typeof t,e="tinybase",n=",",s=a(""),i=Promise,o=t=>null==t,r=(t,a,e)=>o(t)?e?.():a(t),c=t=>a(t)==s,l=t=>Array.isArray(t),E=(t,a,e)=>t.slice(a,e),y=t=>t.length,w=async t=>i.all(t),d=t=>{throw Error(t)},u=(t,a)=>t.forEach(a),T=(t,a="")=>t.join(a),R=(t,a)=>t.map(a),A=t=>0==y(t),N=(t,a)=>t.filter(a),g=(t,...a)=>t.push(...a),p=t=>t.shift(),C="_",O="_id",f="SELECT",v="WHERE",L="TABLE",$="ALTER "+L,m="DELETE FROM",I=f+"*FROM",S=t=>`"${t.replace(/"/g,'""')}"`,h=(t,a=[1])=>T(R(t,(()=>"$"+a[0]++)),n),_=(t,a)=>t?.has(a)??!1,b=t=>o(t)||0==(t=>t?.size??0)(t),P=t=>[...t?.values()??[]],D=(t,a)=>t?.forEach(a),U=(t,a)=>t?.delete(a),F=Object,M=t=>F.getPrototypeOf(t),G=F.entries,B=F.keys,j=F.freeze,x=(t=[])=>F.fromEntries(t),X=(...t)=>F.assign({},...t),Y=(t,a)=>(delete t[a],t),q=(t,a)=>R(G(t),(([t,e])=>a(e,t))),H=t=>F.values(t),W=t=>y(B(t)),k=t=>(t=>!o(t)&&r(M(t),(t=>t==F.prototype||o(M(t))),(()=>!0)))(t)&&0==W(t),z=JSON.stringify,J=JSON.parse,K=t=>new Map(t),V=(t,a)=>t?.get(a),Q=(t,a)=>R([...t?.entries()??[]],(([t,e])=>a(e,t))),Z=(t,a,e)=>o(e)?(U(t,a),t):t?.set(a,e),tt=(t,a,e,n)=>(_(t,a)?n?.(V(t,a)):Z(t,a,e()),V(t,a)),at=(t,a,e,n,s=0)=>r((e?tt:V)(t,a[s],s>y(a)-2?e:K),(i=>{if(s>y(a)-2)return n?.(i)&&Z(t,a[s]),i;const o=at(i,a,e,n,s+1);return b(i)&&Z(t,a[s]),o})),et=t=>new Set(l(t)||o(t)?t:[t]),nt=(t,a)=>t?.add(a),st=/^\d+$/,it=K(),ot=K(),rt=(t,a,e,n,s,i,c,E={},w=[])=>{let T,R,A,N=0,C=0,O=0;tt(it,w,(()=>0)),tt(ot,w,(()=>[]));const f=K(),[v,L,$,m,I]=((t=1,a)=>1!=t&&a.isMergeable()?[1,a.getMergeableContent,a.getTransactionMergeableChanges,([[t],[a]])=>!k(t)||!k(a),a.setDefaultContent]:2!=t?[0,a.getContent,a.getTransactionChanges,([t,a])=>!k(t)||!k(a),a.setContent]:d("Store type not supported by this Persister"))(c,t),[S,h,_]=(()=>{let t;const[a,e]=(()=>{const t=[];let a=0;return[e=>(e?p(t):null)??""+a++,a=>{st.test(a)&&y(t)<1e3&&g(t,a)}]})(),n=K();return[(e,s,i,o=[],r=()=>[])=>{t??=Y;const c=a(1);return Z(n,c,[e,s,i,o,r]),nt(at(s,i??[""],et),c),c},(a,e,...s)=>u(((t,a=[""])=>{const e=[],n=(t,s)=>s==y(a)?g(e,t):null===a[s]?D(t,(t=>n(t,s+1))):u([a[s],null],(a=>n(V(t,a),s+1)));return n(t,0),e})(a,e),(a=>D(a,(a=>V(n,a)[0](t,...e??[],...s))))),t=>r(V(n,t),(([,a,s])=>(at(a,s??[""],void 0,(a=>(U(a,t),b(a)?1:0))),Z(n,t),e(t),s))),a=>r(V(n,a),(([a,,e=[],n,s])=>{const i=(...r)=>{const c=y(r);c==y(e)?a(t,...r,...s(r)):o(e[c])?u(n[c]?.(...r)??[],(t=>i(...r,t))):i(...r,e[c])};i()}))]})(),P=t=>{t!=N&&(N=t,h(f,void 0,N))},F=a=>{(v&&l(a?.[0])?1===a?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===a?.[2]?t.applyChanges:t.setContent)(a)},M=async t=>(2!=N&&(P(1),C++,await X((async()=>{try{const e=await a();l(e)?F(e):t?I(t):d("Content is not an array "+e)}catch(a){i?.(a),t&&I(t)}P(0)}))),Y),G=()=>(R&&(s(R),R=void 0),Y),B=async t=>(1!=N&&(P(2),O++,await X((async()=>{try{await e(L,t)}catch(t){i?.(t)}P(0)}))),Y),x=()=>(r(A,t.delListener),A=void 0,Y),X=async(...t)=>(g(V(ot,w),...t),await(async()=>{if(!V(it,w)){for(Z(it,w,1);!o(T=p(V(ot,w)));)try{await T()}catch(t){i?.(t)}Z(it,w,0)}})(),Y),Y={load:M,startAutoLoad:async t=>{await G().load(t);try{R=await n((async(t,a)=>{a||t?2!=N&&(P(1),C++,F(a??t),P(0)):await M()}))}catch(t){i?.(t)}return Y},stopAutoLoad:G,isAutoLoading:()=>!o(R),save:B,startAutoSave:async()=>(await x().save(),A=t.addDidFinishTransactionListener((()=>{const t=$();m(t)&&B(t)})),Y),stopAutoSave:x,isAutoSaving:()=>!o(A),getStatus:()=>N,addStatusListener:t=>S(t,f),delListener:a=>(_(a),t),schedule:X,getStore:()=>t,destroy:()=>(V(ot,w).splice(0,void 0),G().stopAutoSave()),getStats:()=>({loads:C,saves:O}),...E};return j(Y)},ct=(t,a,e,s,i,r=lt,c,l)=>{const E=K();return[async()=>{E.clear(),R(await e(t,a),(({tn:t,cn:a})=>nt(tt(E,t,et),a)))},async(a,e)=>((t,a)=>_(V(E,t),a))(a,e)?x(N(R(await t(I+S(a)),(t=>{return[t[e],l?(a=Y(t,e),n=l,x(q(a,((t,a)=>[a,n(t,a)])))):Y(t,e)];var a,n})),(([t,a])=>!o(t)&&!k(a)))):{},async(a,e,s,l,y,d=!1)=>{const u=et();q(s??{},(t=>R(B(t??{}),(t=>nt(u,t)))));const p=P(u);if(!d&&y&&A(p)&&_(E,a))return await t("DROP "+L+S(a)),void Z(E,a);const C=V(E,a),O=et(P(C));if(A(p)||(_(E,a)?await w(R([e,...p],(async(n,s)=>{U(O,n)||(await t($+S(a)+"ADD"+S(n)+i),0==s&&await t("CREATE UNIQUE INDEX pk ON "+S(a)+`(${S(e)})`),nt(C,n))}))):(await t("CREATE "+L+S(a)+`(${S(e)}${i} PRIMARY KEY${T(R(p,(t=>n+S(t)+i)))});`),Z(E,a,et([e,...p])))),await w([...!d&&l?R(P(O),(async n=>{n!=e&&(await t($+S(a)+"DROP"+S(n)),U(C,n))})):[]]),d)o(s)?await t(m+S(a)+v+" true"):await w(q(s,(async(n,s)=>{o(n)?await t(m+S(a)+v+S(e)+"=$1",[s]):A(p)||await r(t,a,e,B(n),{[s]:c?R(H(n),c):H(n)},C)})));else if(A(p))_(E,a)&&await t(m+S(a)+v+" true");else{const n=N(P(V(E,a)),(t=>t!=e)),i={},o=[];q(s??{},((t,a)=>{i[a]=R(n,(a=>c?c(t?.[a]):t?.[a])),g(o,a)})),await r(t,a,e,n,i),await t(m+S(a)+v+S(e)+`NOT IN(${h(o)})`,o)}},async a=>{let e;await t("BEGIN");try{e=await a()}catch(t){s?.(t)}return await t("END"),e}]},lt=async(t,a,e,s,i)=>{const o=[1];await t("INSERT INTO"+S(a)+"("+((...t)=>T(R(t,S),n))(e,...s)+")VALUES"+T(q(i,(t=>"($"+o[0]+++","+h(t,o)+")")),n)+"ON CONFLICT("+S(e)+")DO UPDATE SET"+T(R(s,(t=>S(t)+"=excluded."+S(t))),n),q(i,((t,a)=>[a,...R(t,(t=>t??null))])).flat())},Et=(t,a,e,n,s,i,o,[r,c,l],E,y,w,d,u,T)=>{const[R,A,N,g]=ct(a,E,y,s,u,T),p=rt(t,(async()=>await g((async()=>{return await R(),t=(await A(r,c))[C]?.[l]??"null",J(t,((t,a)=>""===a?void 0:a));var t}))),(async t=>await g((async()=>{var a;await R(),await N(r,c,{[C]:{[l]:(a=t()??null,z(a,((t,a)=>void 0===a?"":a)))}},!0,!0)}))),e,n,s,o,{[d]:()=>w,destroy:()=>(p.stopAutoLoad().stopAutoSave(),i(),p)},w);return p},yt=(t,a,e,n,s,i,r,[c,l,[E,y,d]],u,T,R,A,g,p,f,v)=>{const[L,$,m,I]=ct(a,u,T,s,g,p,f,v),S=async(t,a)=>await w(Q(l,(async([e,n,s,i],o)=>{a&&!(o in t)||await m(e,n,t[o],s,i,a)}))),h=async(t,a)=>y?await m(d,O,{[C]:t},!0,!0,a):null,_=rt(t,(async()=>await I((async()=>{await L();const t=await(async()=>x(N(await w(Q(c,(async([t,a],e)=>[t,await $(e,a)]))),(t=>!k(t[1])))))(),a=await(async()=>E?(await $(d,O))[C]:{})();return k(t)&&o(a)?void 0:[t,a]}))),(async(t,a)=>await I((async()=>{if(await L(),o(a)){const[a,e]=t();await S(a),await h(e)}else await S(a[0],!0),await h(a[1],!0)}))),e,n,s,r,{[A]:()=>R,destroy:()=>(_.stopAutoLoad().stopAutoSave(),i(),_)},R);return _},wt="ColumnName",dt="store",ut="json",Tt=dt+"TableName",Rt=dt+"Id"+wt,At=dt+wt,Nt="autoLoadIntervalSeconds",gt="rowId"+wt,pt="tableId",Ct="tableName",Ot="deleteEmptyColumns",ft="deleteEmptyTable",vt={mode:ut,[Nt]:1},Lt={load:0,save:0,[Ct]:e+"_values"},$t=(t,a,e,n,s)=>{const i=K();return q(t,((t,r)=>{const l=E(H(X(a,c(t)?{[e]:t}:t)),0,W(a));o(l[0])||n(r,l[0])||(s(r,l[0]),Z(i,r,l))})),i},mt=e,It=/^([cd]:)(.+)/,St=e+"_data",ht=e+"_table";t.createPglitePersister=async(t,a,n,s,i)=>((t,a,n,s,i,o,l,y,d,u,T="getDb")=>{const A=((t,a)=>a?async(e,n)=>(a(e,n),await t(e,n)):t)(n,o),[N,,g,p]=(t=>{const a=(t=>X(vt,c(t)?{[Tt]:t}:t??{}))(t),n=a[Nt];if(a.mode==ut){const t=a[Tt]??e;return[1,n,[t,a[Rt]??O,a[At]??dt],et(t)]}const{tables:{load:s={},save:i={}}={},values:o={}}=a,r=E(H(X(Lt,o)),0,W(Lt)),l=r[2],y=et(l),w=et(l);return[0,n,[$t(s,{[pt]:null,[gt]:O},pt,(t=>_(w,t)),(t=>nt(y,t))),$t(i,{[Ct]:null,[gt]:O,[Ot]:0,[ft]:0},Ct,((t,a)=>_(w,a)),((t,a)=>nt(y,a))),r],y]})(a),C=async t=>{await A(`CREATE OR REPLACE TRIGGER ${S(St+"_"+t)} AFTER INSERT OR UPDATE OR DELETE ON ${S(t)} EXECUTE FUNCTION ${St}()`)};return(N?Et:yt)(t,A,(async t=>{await A(`CREATE OR REPLACE FUNCTION ${ht}()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('${mt}','c:'||SPLIT_PART(row.object_identity,'.',2));END LOOP;END;$t2$ LANGUAGE plpgsql;`);try{await A(`CREATE EVENT TRIGGER ${ht} ON ddl_command_end WHEN TAG IN('CREATE TABLE')EXECUTE FUNCTION ${ht}();`)}catch{}return await A(`CREATE OR REPLACE FUNCTION ${St}()RETURNS trigger AS $t1$ BEGIN PERFORM pg_notify('${mt}','d:'||TG_TABLE_NAME);RETURN NULL;END;$t1$ LANGUAGE plpgsql;`),await w(R(P(p),(async t=>{await A(`CREATE TABLE IF NOT EXISTS ${S(t)}("_id"text PRIMARY KEY)`),await C(t)}))),await s(mt,(async a=>{return await r((e=a,n=It,e?.match(n)),(async([,a,e])=>{_(p,e)&&("c:"==a&&await C(e),t())}));var e,n}))}),i,l,y,d,g,P(p),(async(t,a)=>await t(`${f} table_name tn,column_name cn FROM information_schema.columns ${v} table_schema='public'AND table_name IN(${h(a)})`,a)),u,T,"text",void 0,(t=>z(t)),(t=>J(t)))})(t,n,(async(t,e=[])=>(await a.query(t,e)).rows),(async(t,e)=>await a.listen(t,e)),(async t=>{try{await t()}catch(t){i?.(t)}}),s,i,(()=>0),3,a,"getPglite")},"object"==typeof exports&&"undefined"!=typeof module?a(exports):"function"==typeof define&&define.amd?define(["exports"],a):a((t="undefined"!=typeof globalThis?globalThis:t||self).TinyBasePersisterPglite={});
|
|
1
|
+
var t,a;t=this,a=function(t){"use strict";const a=t=>typeof t,e="tinybase",n=",",s=a(""),i=Promise,o=t=>null==t,r=(t,a,e)=>o(t)?e?.():a(t),c=t=>a(t)==s,l=t=>Array.isArray(t),E=(t,a,e)=>t.slice(a,e),y=t=>t.length,w=async t=>i.all(t),d=t=>{throw Error(t)},u=(t,a)=>t.forEach(a),T=(t,a="")=>t.join(a),R=(t,a)=>t.map(a),A=t=>0==y(t),N=(t,a)=>t.filter(a),g=(t,...a)=>t.push(...a),p=t=>t.shift(),C="_",O="_id",f="SELECT",v="WHERE",L="TABLE",$="ALTER "+L,m="DELETE FROM",I=f+"*FROM",S=t=>`"${t.replace(/"/g,'""')}"`,h=(t,a=[1])=>T(R(t,(()=>"$"+a[0]++)),n),_=(t,a)=>t?.has(a)??!1,b=t=>o(t)||0==(t=>t?.size??0)(t),P=t=>[...t?.values()??[]],D=(t,a)=>t?.forEach(a),U=(t,a)=>t?.delete(a),F=Object,M=t=>F.getPrototypeOf(t),G=F.entries,B=F.keys,j=F.freeze,x=(t=[])=>F.fromEntries(t),X=(...t)=>F.assign({},...t),Y=(t,a)=>(delete t[a],t),q=(t,a)=>R(G(t),(([t,e])=>a(e,t))),H=t=>F.values(t),W=t=>y(B(t)),k=t=>(t=>!o(t)&&r(M(t),(t=>t==F.prototype||o(M(t))),(()=>!0)))(t)&&0==W(t),z=JSON.stringify,J=JSON.parse,K=t=>new Map(t),V=(t,a)=>t?.get(a),Q=(t,a)=>R([...t?.entries()??[]],(([t,e])=>a(e,t))),Z=(t,a,e)=>o(e)?(U(t,a),t):t?.set(a,e),tt=(t,a,e,n)=>(_(t,a)?n?.(V(t,a)):Z(t,a,e()),V(t,a)),at=(t,a,e,n,s=0)=>r((e?tt:V)(t,a[s],s>y(a)-2?e:K),(i=>{if(s>y(a)-2)return n?.(i)&&Z(t,a[s]),i;const o=at(i,a,e,n,s+1);return b(i)&&Z(t,a[s]),o})),et=t=>new Set(l(t)||o(t)?t:[t]),nt=(t,a)=>t?.add(a),st=/^\d+$/,it=K(),ot=K(),rt=(t,a,e,n,s,i,c,E={},w=[])=>{let T,R,A,N=0,C=0,O=0;tt(it,w,(()=>0)),tt(ot,w,(()=>[]));const f=K(),[v,L,$,m,I]=((t=1,a)=>1!=t&&a.isMergeable()?[1,a.getMergeableContent,a.getTransactionMergeableChanges,([[t],[a]])=>!k(t)||!k(a),a.setDefaultContent]:2!=t?[0,a.getContent,a.getTransactionChanges,([t,a])=>!k(t)||!k(a),a.setContent]:d("Store type not supported by this Persister"))(c,t),[S,h,_]=(()=>{let t;const[a,e]=(()=>{const t=[];let a=0;return[e=>(e?p(t):null)??""+a++,a=>{st.test(a)&&y(t)<1e3&&g(t,a)}]})(),n=K();return[(e,s,i,o=[],r=()=>[])=>{t??=Y;const c=a(1);return Z(n,c,[e,s,i,o,r]),nt(at(s,i??[""],et),c),c},(a,e,...s)=>u(((t,a=[""])=>{const e=[],n=(t,s)=>s==y(a)?g(e,t):null===a[s]?D(t,(t=>n(t,s+1))):u([a[s],null],(a=>n(V(t,a),s+1)));return n(t,0),e})(a,e),(a=>D(a,(a=>V(n,a)[0](t,...e??[],...s))))),t=>r(V(n,t),(([,a,s])=>(at(a,s??[""],void 0,(a=>(U(a,t),b(a)?1:0))),Z(n,t),e(t),s))),a=>r(V(n,a),(([a,,e=[],n,s])=>{const i=(...r)=>{const c=y(r);c==y(e)?a(t,...r,...s(r)):o(e[c])?u(n[c]?.(...r)??[],(t=>i(...r,t))):i(...r,e[c])};i()}))]})(),P=t=>{t!=N&&(N=t,h(f,void 0,N))},F=a=>{(v&&l(a?.[0])?1===a?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===a?.[2]?t.applyChanges:t.setContent)(a)},M=async t=>(2!=N&&(P(1),C++,await X((async()=>{try{const e=await a();l(e)?F(e):t?I(t):d("Content is not an array: "+e)}catch(a){i?.(a),t&&I(t)}P(0)}))),Y),G=()=>(R&&(s(R),R=void 0),Y),B=async t=>(1!=N&&(P(2),O++,await X((async()=>{try{await e(L,t)}catch(t){i?.(t)}P(0)}))),Y),x=()=>(r(A,t.delListener),A=void 0,Y),X=async(...t)=>(g(V(ot,w),...t),await(async()=>{if(!V(it,w)){for(Z(it,w,1);!o(T=p(V(ot,w)));)try{await T()}catch(t){i?.(t)}Z(it,w,0)}})(),Y),Y={load:M,startAutoLoad:async t=>{await G().load(t);try{R=await n((async(t,a)=>{a||t?2!=N&&(P(1),C++,F(a??t),P(0)):await M()}))}catch(t){i?.(t)}return Y},stopAutoLoad:G,isAutoLoading:()=>!o(R),save:B,startAutoSave:async()=>(await x().save(),A=t.addDidFinishTransactionListener((()=>{const t=$();m(t)&&B(t)})),Y),stopAutoSave:x,isAutoSaving:()=>!o(A),getStatus:()=>N,addStatusListener:t=>S(t,f),delListener:a=>(_(a),t),schedule:X,getStore:()=>t,destroy:()=>(V(ot,w).splice(0,void 0),G().stopAutoSave()),getStats:()=>({loads:C,saves:O}),...E};return j(Y)},ct=(t,a,e,s,i,r=lt,c,l)=>{const E=K();return[async()=>{E.clear(),R(await e(t,a),(({tn:t,cn:a})=>nt(tt(E,t,et),a)))},async(a,e)=>((t,a)=>_(V(E,t),a))(a,e)?x(N(R(await t(I+S(a)),(t=>{return[t[e],l?(a=Y(t,e),n=l,x(q(a,((t,a)=>[a,n(t,a)])))):Y(t,e)];var a,n})),(([t,a])=>!o(t)&&!k(a)))):{},async(a,e,s,l,y,d=!1)=>{const u=et();q(s??{},(t=>R(B(t??{}),(t=>nt(u,t)))));const p=P(u);if(!d&&y&&A(p)&&_(E,a))return await t("DROP "+L+S(a)),void Z(E,a);const C=V(E,a),O=et(P(C));if(A(p)||(_(E,a)?await w(R([e,...p],(async(n,s)=>{U(O,n)||(await t($+S(a)+"ADD"+S(n)+i),0==s&&await t("CREATE UNIQUE INDEX pk ON "+S(a)+`(${S(e)})`),nt(C,n))}))):(await t("CREATE "+L+S(a)+`(${S(e)}${i} PRIMARY KEY${T(R(p,(t=>n+S(t)+i)))});`),Z(E,a,et([e,...p])))),await w([...!d&&l?R(P(O),(async n=>{n!=e&&(await t($+S(a)+"DROP"+S(n)),U(C,n))})):[]]),d)o(s)?await t(m+S(a)+v+" true"):await w(q(s,(async(n,s)=>{o(n)?await t(m+S(a)+v+S(e)+"=$1",[s]):A(p)||await r(t,a,e,B(n),{[s]:c?R(H(n),c):H(n)},C)})));else if(A(p))_(E,a)&&await t(m+S(a)+v+" true");else{const n=N(P(V(E,a)),(t=>t!=e)),i={},o=[];q(s??{},((t,a)=>{i[a]=R(n,(a=>c?c(t?.[a]):t?.[a])),g(o,a)})),await r(t,a,e,n,i),await t(m+S(a)+v+S(e)+`NOT IN(${h(o)})`,o)}},async a=>{let e;await t("BEGIN");try{e=await a()}catch(t){s?.(t)}return await t("END"),e}]},lt=async(t,a,e,s,i)=>{const o=[1];await t("INSERT INTO"+S(a)+"("+((...t)=>T(R(t,S),n))(e,...s)+")VALUES"+T(q(i,(t=>"($"+o[0]+++","+h(t,o)+")")),n)+"ON CONFLICT("+S(e)+")DO UPDATE SET"+T(R(s,(t=>S(t)+"=excluded."+S(t))),n),q(i,((t,a)=>[a,...R(t,(t=>t??null))])).flat())},Et=(t,a,e,n,s,i,o,[r,c,l],E,y,w,d,u,T)=>{const[R,A,N,g]=ct(a,E,y,s,u,T),p=rt(t,(async()=>await g((async()=>{return await R(),t=(await A(r,c))[C]?.[l]??"null",J(t,((t,a)=>""===a?void 0:a));var t}))),(async t=>await g((async()=>{var a;await R(),await N(r,c,{[C]:{[l]:(a=t()??null,z(a,((t,a)=>void 0===a?"":a)))}},!0,!0)}))),e,n,s,o,{[d]:()=>w,destroy:()=>(p.stopAutoLoad().stopAutoSave(),i(),p)},w);return p},yt=(t,a,e,n,s,i,r,[c,l,[E,y,d]],u,T,R,A,g,p,f,v)=>{const[L,$,m,I]=ct(a,u,T,s,g,p,f,v),S=async(t,a)=>await w(Q(l,(async([e,n,s,i],o)=>{a&&!(o in t)||await m(e,n,t[o],s,i,a)}))),h=async(t,a)=>y?await m(d,O,{[C]:t},!0,!0,a):null,_=rt(t,(async()=>await I((async()=>{await L();const t=await(async()=>x(N(await w(Q(c,(async([t,a],e)=>[t,await $(e,a)]))),(t=>!k(t[1])))))(),a=await(async()=>E?(await $(d,O))[C]:{})();return k(t)&&o(a)?void 0:[t,a]}))),(async(t,a)=>await I((async()=>{if(await L(),o(a)){const[a,e]=t();await S(a),await h(e)}else await S(a[0],!0),await h(a[1],!0)}))),e,n,s,r,{[A]:()=>R,destroy:()=>(_.stopAutoLoad().stopAutoSave(),i(),_)},R);return _},wt="ColumnName",dt="store",ut="json",Tt=dt+"TableName",Rt=dt+"Id"+wt,At=dt+wt,Nt="autoLoadIntervalSeconds",gt="rowId"+wt,pt="tableId",Ct="tableName",Ot="deleteEmptyColumns",ft="deleteEmptyTable",vt={mode:ut,[Nt]:1},Lt={load:0,save:0,[Ct]:e+"_values"},$t=(t,a,e,n,s)=>{const i=K();return q(t,((t,r)=>{const l=E(H(X(a,c(t)?{[e]:t}:t)),0,W(a));o(l[0])||n(r,l[0])||(s(r,l[0]),Z(i,r,l))})),i},mt=e,It=/^([cd]:)(.+)/,St=e+"_data",ht=e+"_table";t.createPglitePersister=async(t,a,n,s,i)=>((t,a,n,s,i,o,l,y,d,u,T="getDb")=>{const A=((t,a)=>a?async(e,n)=>(a(e,n),await t(e,n)):t)(n,o),[N,,g,p]=(t=>{const a=(t=>X(vt,c(t)?{[Tt]:t}:t??{}))(t),n=a[Nt];if(a.mode==ut){const t=a[Tt]??e;return[1,n,[t,a[Rt]??O,a[At]??dt],et(t)]}const{tables:{load:s={},save:i={}}={},values:o={}}=a,r=E(H(X(Lt,o)),0,W(Lt)),l=r[2],y=et(l),w=et(l);return[0,n,[$t(s,{[pt]:null,[gt]:O},pt,(t=>_(w,t)),(t=>nt(y,t))),$t(i,{[Ct]:null,[gt]:O,[Ot]:0,[ft]:0},Ct,((t,a)=>_(w,a)),((t,a)=>nt(y,a))),r],y]})(a),C=async t=>{await A(`CREATE OR REPLACE TRIGGER ${S(St+"_"+t)} AFTER INSERT OR UPDATE OR DELETE ON ${S(t)} EXECUTE FUNCTION ${St}()`)};return(N?Et:yt)(t,A,(async t=>{await A(`CREATE OR REPLACE FUNCTION ${ht}()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('${mt}','c:'||SPLIT_PART(row.object_identity,'.',2));END LOOP;END;$t2$ LANGUAGE plpgsql;`);try{await A(`CREATE EVENT TRIGGER ${ht} ON ddl_command_end WHEN TAG IN('CREATE TABLE')EXECUTE FUNCTION ${ht}();`)}catch{}return await A(`CREATE OR REPLACE FUNCTION ${St}()RETURNS trigger AS $t1$ BEGIN PERFORM pg_notify('${mt}','d:'||TG_TABLE_NAME);RETURN NULL;END;$t1$ LANGUAGE plpgsql;`),await w(R(P(p),(async t=>{await A(`CREATE TABLE IF NOT EXISTS ${S(t)}("_id"text PRIMARY KEY)`),await C(t)}))),await s(mt,(async a=>{return await r((e=a,n=It,e?.match(n)),(async([,a,e])=>{_(p,e)&&("c:"==a&&await C(e),t())}));var e,n}))}),i,l,y,d,g,P(p),(async(t,a)=>await t(`${f} table_name tn,column_name cn FROM information_schema.columns ${v} table_schema='public'AND table_name IN(${h(a)})`,a)),u,T,"text",void 0,(t=>z(t)),(t=>J(t)))})(t,n,(async(t,e=[])=>(await a.query(t,e)).rows),(async(t,e)=>await a.listen(t,e)),(async t=>{try{await t()}catch(t){i?.(t)}}),s,i,(()=>0),3,a,"getPglite")},"object"==typeof exports&&"undefined"!=typeof module?a(exports):"function"==typeof define&&define.amd?define(["exports"],a):a((t="undefined"!=typeof globalThis?globalThis:t||self).TinyBasePersisterPglite={});
|
|
Binary file
|
|
@@ -1 +1 @@
|
|
|
1
|
-
var t,a;t=this,a=function(t){"use strict";const a=t=>typeof t,e="tinybase",n=",",s=a(""),i=Promise,o=t=>null==t,r=(t,a,e)=>o(t)?e?.():a(t),c=t=>a(t)==s,l=t=>Array.isArray(t),E=(t,a,e)=>t.slice(a,e),y=t=>t.length,d=async t=>i.all(t),w=t=>{throw Error(t)},u=(t,a)=>t.forEach(a),T=(t,a="")=>t.join(a),R=(t,a)=>t.map(a),A=t=>0==y(t),N=(t,a)=>t.filter(a),g=(t,...a)=>t.push(...a),p=t=>t.shift(),C="_",f="_id",O="SELECT",v="WHERE",L="TABLE",$="ALTER "+L,m="DELETE FROM",S=O+"*FROM",I=t=>`"${t.replace(/"/g,'""')}"`,h=(t,a=[1])=>T(R(t,(()=>"$"+a[0]++)),n),_=(t,a)=>t?.has(a)??!1,b=t=>o(t)||0==(t=>t?.size??0)(t),P=t=>[...t?.values()??[]],D=(t,a)=>t?.forEach(a),U=(t,a)=>t?.delete(a),F=Object,M=t=>F.getPrototypeOf(t),G=F.entries,B=F.keys,j=F.freeze,x=(t=[])=>F.fromEntries(t),X=(...t)=>F.assign({},...t),Y=(t,a)=>(delete t[a],t),q=(t,a)=>R(G(t),(([t,e])=>a(e,t))),H=t=>F.values(t),W=t=>y(B(t)),k=t=>(t=>!o(t)&&r(M(t),(t=>t==F.prototype||o(M(t))),(()=>!0)))(t)&&0==W(t),z=JSON.stringify,J=JSON.parse,K=t=>new Map(t),V=(t,a)=>t?.get(a),Q=(t,a)=>R([...t?.entries()??[]],(([t,e])=>a(e,t))),Z=(t,a,e)=>o(e)?(U(t,a),t):t?.set(a,e),tt=(t,a,e,n)=>(_(t,a)?n?.(V(t,a)):Z(t,a,e()),V(t,a)),at=(t,a,e,n,s=0)=>r((e?tt:V)(t,a[s],s>y(a)-2?e:K),(i=>{if(s>y(a)-2)return n?.(i)&&Z(t,a[s]),i;const o=at(i,a,e,n,s+1);return b(i)&&Z(t,a[s]),o})),et=t=>new Set(l(t)||o(t)?t:[t]),nt=(t,a)=>t?.add(a),st=/^\d+$/,it=K(),ot=K(),rt=(t,a,e,n,s,i,c,E={},d=[])=>{let T,R,A,N=0,C=0,f=0;tt(it,d,(()=>0)),tt(ot,d,(()=>[]));const O=K(),[v,L,$,m,S]=((t=1,a)=>1!=t&&a.isMergeable()?[1,a.getMergeableContent,a.getTransactionMergeableChanges,([[t],[a]])=>!k(t)||!k(a),a.setDefaultContent]:2!=t?[0,a.getContent,a.getTransactionChanges,([t,a])=>!k(t)||!k(a),a.setContent]:w("Store type not supported by this Persister"))(c,t),[I,h,_]=(()=>{let t;const[a,e]=(()=>{const t=[];let a=0;return[e=>(e?p(t):null)??""+a++,a=>{st.test(a)&&y(t)<1e3&&g(t,a)}]})(),n=K();return[(e,s,i,o=[],r=()=>[])=>{t??=Y;const c=a(1);return Z(n,c,[e,s,i,o,r]),nt(at(s,i??[""],et),c),c},(a,e,...s)=>u(((t,a=[""])=>{const e=[],n=(t,s)=>s==y(a)?g(e,t):null===a[s]?D(t,(t=>n(t,s+1))):u([a[s],null],(a=>n(V(t,a),s+1)));return n(t,0),e})(a,e),(a=>D(a,(a=>V(n,a)[0](t,...e??[],...s))))),t=>r(V(n,t),(([,a,s])=>(at(a,s??[""],void 0,(a=>(U(a,t),b(a)?1:0))),Z(n,t),e(t),s))),a=>r(V(n,a),(([a,,e=[],n,s])=>{const i=(...r)=>{const c=y(r);c==y(e)?a(t,...r,...s(r)):o(e[c])?u(n[c]?.(...r)??[],(t=>i(...r,t))):i(...r,e[c])};i()}))]})(),P=t=>{t!=N&&(N=t,h(O,void 0,N))},F=a=>{(v&&l(a?.[0])?1===a?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===a?.[2]?t.applyChanges:t.setContent)(a)},M=async t=>(2!=N&&(P(1),C++,await X((async()=>{try{const e=await a();l(e)?F(e):t?S(t):w("Content is not an array "+e)}catch(a){i?.(a),t&&S(t)}P(0)}))),Y),G=()=>(R&&(s(R),R=void 0),Y),B=async t=>(1!=N&&(P(2),f++,await X((async()=>{try{await e(L,t)}catch(t){i?.(t)}P(0)}))),Y),x=()=>(r(A,t.delListener),A=void 0,Y),X=async(...t)=>(g(V(ot,d),...t),await(async()=>{if(!V(it,d)){for(Z(it,d,1);!o(T=p(V(ot,d)));)try{await T()}catch(t){i?.(t)}Z(it,d,0)}})(),Y),Y={load:M,startAutoLoad:async t=>{await G().load(t);try{R=await n((async(t,a)=>{a||t?2!=N&&(P(1),C++,F(a??t),P(0)):await M()}))}catch(t){i?.(t)}return Y},stopAutoLoad:G,isAutoLoading:()=>!o(R),save:B,startAutoSave:async()=>(await x().save(),A=t.addDidFinishTransactionListener((()=>{const t=$();m(t)&&B(t)})),Y),stopAutoSave:x,isAutoSaving:()=>!o(A),getStatus:()=>N,addStatusListener:t=>I(t,O),delListener:a=>(_(a),t),schedule:X,getStore:()=>t,destroy:()=>(V(ot,d).splice(0,void 0),G().stopAutoSave()),getStats:()=>({loads:C,saves:f}),...E};return j(Y)},ct=(t,a,e,s,i,r=lt,c,l)=>{const E=K();return[async()=>{E.clear(),R(await e(t,a),(({tn:t,cn:a})=>nt(tt(E,t,et),a)))},async(a,e)=>((t,a)=>_(V(E,t),a))(a,e)?x(N(R(await t(S+I(a)),(t=>{return[t[e],l?(a=Y(t,e),n=l,x(q(a,((t,a)=>[a,n(t,a)])))):Y(t,e)];var a,n})),(([t,a])=>!o(t)&&!k(a)))):{},async(a,e,s,l,y,w=!1)=>{const u=et();q(s??{},(t=>R(B(t??{}),(t=>nt(u,t)))));const p=P(u);if(!w&&y&&A(p)&&_(E,a))return await t("DROP "+L+I(a)),void Z(E,a);const C=V(E,a),f=et(P(C));if(A(p)||(_(E,a)?await d(R([e,...p],(async(n,s)=>{U(f,n)||(await t($+I(a)+"ADD"+I(n)+i),0==s&&await t("CREATE UNIQUE INDEX pk ON "+I(a)+`(${I(e)})`),nt(C,n))}))):(await t("CREATE "+L+I(a)+`(${I(e)}${i} PRIMARY KEY${T(R(p,(t=>n+I(t)+i)))});`),Z(E,a,et([e,...p])))),await d([...!w&&l?R(P(f),(async n=>{n!=e&&(await t($+I(a)+"DROP"+I(n)),U(C,n))})):[]]),w)o(s)?await t(m+I(a)+v+" true"):await d(q(s,(async(n,s)=>{o(n)?await t(m+I(a)+v+I(e)+"=$1",[s]):A(p)||await r(t,a,e,B(n),{[s]:c?R(H(n),c):H(n)},C)})));else if(A(p))_(E,a)&&await t(m+I(a)+v+" true");else{const n=N(P(V(E,a)),(t=>t!=e)),i={},o=[];q(s??{},((t,a)=>{i[a]=R(n,(a=>c?c(t?.[a]):t?.[a])),g(o,a)})),await r(t,a,e,n,i),await t(m+I(a)+v+I(e)+`NOT IN(${h(o)})`,o)}},async a=>{let e;await t("BEGIN");try{e=await a()}catch(t){s?.(t)}return await t("END"),e}]},lt=async(t,a,e,s,i)=>{const o=[1];await t("INSERT INTO"+I(a)+"("+((...t)=>T(R(t,I),n))(e,...s)+")VALUES"+T(q(i,(t=>"($"+o[0]+++","+h(t,o)+")")),n)+"ON CONFLICT("+I(e)+")DO UPDATE SET"+T(R(s,(t=>I(t)+"=excluded."+I(t))),n),q(i,((t,a)=>[a,...R(t,(t=>t??null))])).flat())},Et=(t,a,e,n,s,i,o,[r,c,l],E,y,d,w,u,T)=>{const[R,A,N,g]=ct(a,E,y,s,u,T),p=rt(t,(async()=>await g((async()=>{return await R(),t=(await A(r,c))[C]?.[l]??"null",J(t,((t,a)=>""===a?void 0:a));var t}))),(async t=>await g((async()=>{var a;await R(),await N(r,c,{[C]:{[l]:(a=t()??null,z(a,((t,a)=>void 0===a?"":a)))}},!0,!0)}))),e,n,s,o,{[w]:()=>d,destroy:()=>(p.stopAutoLoad().stopAutoSave(),i(),p)},d);return p},yt=(t,a,e,n,s,i,r,[c,l,[E,y,w]],u,T,R,A,g,p,O,v)=>{const[L,$,m,S]=ct(a,u,T,s,g,p,O,v),I=async(t,a)=>await d(Q(l,(async([e,n,s,i],o)=>{a&&!(o in t)||await m(e,n,t[o],s,i,a)}))),h=async(t,a)=>y?await m(w,f,{[C]:t},!0,!0,a):null,_=rt(t,(async()=>await S((async()=>{await L();const t=await(async()=>x(N(await d(Q(c,(async([t,a],e)=>[t,await $(e,a)]))),(t=>!k(t[1])))))(),a=await(async()=>E?(await $(w,f))[C]:{})();return k(t)&&o(a)?void 0:[t,a]}))),(async(t,a)=>await S((async()=>{if(await L(),o(a)){const[a,e]=t();await I(a),await h(e)}else await I(a[0],!0),await h(a[1],!0)}))),e,n,s,r,{[A]:()=>R,destroy:()=>(_.stopAutoLoad().stopAutoSave(),i(),_)},R);return _},dt="ColumnName",wt="store",ut="json",Tt=wt+"TableName",Rt=wt+"Id"+dt,At=wt+dt,Nt="autoLoadIntervalSeconds",gt="rowId"+dt,pt="tableId",Ct="tableName",ft="deleteEmptyColumns",Ot="deleteEmptyTable",vt={mode:ut,[Nt]:1},Lt={load:0,save:0,[Ct]:e+"_values"},$t=(t,a,e,n,s)=>{const i=K();return q(t,((t,r)=>{const l=E(H(X(a,c(t)?{[e]:t}:t)),0,W(a));o(l[0])||n(r,l[0])||(s(r,l[0]),Z(i,r,l))})),i},mt=e,St=/^([cd]:)(.+)/,It=e+"_data",ht=e+"_table";t.createPostgresPersister=async(t,a,n,s,i)=>{const o=await(a.reserve?.());return((t,a,n,s,i,o,l,y,w,u,T="getDb")=>{const A=((t,a)=>a?async(e,n)=>(a(e,n),await t(e,n)):t)(n,o),[N,,g,p]=(t=>{const a=(t=>X(vt,c(t)?{[Tt]:t}:t??{}))(t),n=a[Nt];if(a.mode==ut){const t=a[Tt]??e;return[1,n,[t,a[Rt]??f,a[At]??wt],et(t)]}const{tables:{load:s={},save:i={}}={},values:o={}}=a,r=E(H(X(Lt,o)),0,W(Lt)),l=r[2],y=et(l),d=et(l);return[0,n,[$t(s,{[pt]:null,[gt]:f},pt,(t=>_(d,t)),(t=>nt(y,t))),$t(i,{[Ct]:null,[gt]:f,[ft]:0,[Ot]:0},Ct,((t,a)=>_(d,a)),((t,a)=>nt(y,a))),r],y]})(a),C=async t=>{await A(`CREATE OR REPLACE TRIGGER ${I(It+"_"+t)} AFTER INSERT OR UPDATE OR DELETE ON ${I(t)} EXECUTE FUNCTION ${It}()`)};return(N?Et:yt)(t,A,(async t=>{await A(`CREATE OR REPLACE FUNCTION ${ht}()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('${mt}','c:'||SPLIT_PART(row.object_identity,'.',2));END LOOP;END;$t2$ LANGUAGE plpgsql;`);try{await A(`CREATE EVENT TRIGGER ${ht} ON ddl_command_end WHEN TAG IN('CREATE TABLE')EXECUTE FUNCTION ${ht}();`)}catch{}return await A(`CREATE OR REPLACE FUNCTION ${It}()RETURNS trigger AS $t1$ BEGIN PERFORM pg_notify('${mt}','d:'||TG_TABLE_NAME);RETURN NULL;END;$t1$ LANGUAGE plpgsql;`),await d(R(P(p),(async t=>{await A(`CREATE TABLE IF NOT EXISTS ${I(t)}("_id"text PRIMARY KEY)`),await C(t)}))),await s(mt,(async a=>{return await r((e=a,n=St,e?.match(n)),(async([,a,e])=>{_(p,e)&&("c:"==a&&await C(e),t())}));var e,n}))}),i,l,y,w,g,P(p),(async(t,a)=>await t(`${O} table_name tn,column_name cn FROM information_schema.columns ${v} table_schema='public'AND table_name IN(${h(a)})`,a)),u,T,"text",void 0,(t=>z(t)),(t=>J(t)))})(t,n,o?.unsafe,(async(t,e)=>a.listen(t,e)),(async t=>{try{await t.unlisten()}catch(t){i?.(t)}}),s,i,(()=>o?.release?.()),3,a,"getSql")}},"object"==typeof exports&&"undefined"!=typeof module?a(exports):"function"==typeof define&&define.amd?define(["exports"],a):a((t="undefined"!=typeof globalThis?globalThis:t||self).TinyBasePersisterPostgres={});
|
|
1
|
+
var t,a;t=this,a=function(t){"use strict";const a=t=>typeof t,e="tinybase",n=",",s=a(""),i=Promise,o=t=>null==t,r=(t,a,e)=>o(t)?e?.():a(t),c=t=>a(t)==s,l=t=>Array.isArray(t),E=(t,a,e)=>t.slice(a,e),y=t=>t.length,d=async t=>i.all(t),w=t=>{throw Error(t)},u=(t,a)=>t.forEach(a),T=(t,a="")=>t.join(a),R=(t,a)=>t.map(a),A=t=>0==y(t),N=(t,a)=>t.filter(a),g=(t,...a)=>t.push(...a),p=t=>t.shift(),C="_",f="_id",O="SELECT",v="WHERE",L="TABLE",$="ALTER "+L,m="DELETE FROM",S=O+"*FROM",I=t=>`"${t.replace(/"/g,'""')}"`,h=(t,a=[1])=>T(R(t,(()=>"$"+a[0]++)),n),_=(t,a)=>t?.has(a)??!1,b=t=>o(t)||0==(t=>t?.size??0)(t),P=t=>[...t?.values()??[]],D=(t,a)=>t?.forEach(a),U=(t,a)=>t?.delete(a),F=Object,M=t=>F.getPrototypeOf(t),G=F.entries,B=F.keys,j=F.freeze,x=(t=[])=>F.fromEntries(t),X=(...t)=>F.assign({},...t),Y=(t,a)=>(delete t[a],t),q=(t,a)=>R(G(t),(([t,e])=>a(e,t))),H=t=>F.values(t),W=t=>y(B(t)),k=t=>(t=>!o(t)&&r(M(t),(t=>t==F.prototype||o(M(t))),(()=>!0)))(t)&&0==W(t),z=JSON.stringify,J=JSON.parse,K=t=>new Map(t),V=(t,a)=>t?.get(a),Q=(t,a)=>R([...t?.entries()??[]],(([t,e])=>a(e,t))),Z=(t,a,e)=>o(e)?(U(t,a),t):t?.set(a,e),tt=(t,a,e,n)=>(_(t,a)?n?.(V(t,a)):Z(t,a,e()),V(t,a)),at=(t,a,e,n,s=0)=>r((e?tt:V)(t,a[s],s>y(a)-2?e:K),(i=>{if(s>y(a)-2)return n?.(i)&&Z(t,a[s]),i;const o=at(i,a,e,n,s+1);return b(i)&&Z(t,a[s]),o})),et=t=>new Set(l(t)||o(t)?t:[t]),nt=(t,a)=>t?.add(a),st=/^\d+$/,it=K(),ot=K(),rt=(t,a,e,n,s,i,c,E={},d=[])=>{let T,R,A,N=0,C=0,f=0;tt(it,d,(()=>0)),tt(ot,d,(()=>[]));const O=K(),[v,L,$,m,S]=((t=1,a)=>1!=t&&a.isMergeable()?[1,a.getMergeableContent,a.getTransactionMergeableChanges,([[t],[a]])=>!k(t)||!k(a),a.setDefaultContent]:2!=t?[0,a.getContent,a.getTransactionChanges,([t,a])=>!k(t)||!k(a),a.setContent]:w("Store type not supported by this Persister"))(c,t),[I,h,_]=(()=>{let t;const[a,e]=(()=>{const t=[];let a=0;return[e=>(e?p(t):null)??""+a++,a=>{st.test(a)&&y(t)<1e3&&g(t,a)}]})(),n=K();return[(e,s,i,o=[],r=()=>[])=>{t??=Y;const c=a(1);return Z(n,c,[e,s,i,o,r]),nt(at(s,i??[""],et),c),c},(a,e,...s)=>u(((t,a=[""])=>{const e=[],n=(t,s)=>s==y(a)?g(e,t):null===a[s]?D(t,(t=>n(t,s+1))):u([a[s],null],(a=>n(V(t,a),s+1)));return n(t,0),e})(a,e),(a=>D(a,(a=>V(n,a)[0](t,...e??[],...s))))),t=>r(V(n,t),(([,a,s])=>(at(a,s??[""],void 0,(a=>(U(a,t),b(a)?1:0))),Z(n,t),e(t),s))),a=>r(V(n,a),(([a,,e=[],n,s])=>{const i=(...r)=>{const c=y(r);c==y(e)?a(t,...r,...s(r)):o(e[c])?u(n[c]?.(...r)??[],(t=>i(...r,t))):i(...r,e[c])};i()}))]})(),P=t=>{t!=N&&(N=t,h(O,void 0,N))},F=a=>{(v&&l(a?.[0])?1===a?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===a?.[2]?t.applyChanges:t.setContent)(a)},M=async t=>(2!=N&&(P(1),C++,await X((async()=>{try{const e=await a();l(e)?F(e):t?S(t):w("Content is not an array: "+e)}catch(a){i?.(a),t&&S(t)}P(0)}))),Y),G=()=>(R&&(s(R),R=void 0),Y),B=async t=>(1!=N&&(P(2),f++,await X((async()=>{try{await e(L,t)}catch(t){i?.(t)}P(0)}))),Y),x=()=>(r(A,t.delListener),A=void 0,Y),X=async(...t)=>(g(V(ot,d),...t),await(async()=>{if(!V(it,d)){for(Z(it,d,1);!o(T=p(V(ot,d)));)try{await T()}catch(t){i?.(t)}Z(it,d,0)}})(),Y),Y={load:M,startAutoLoad:async t=>{await G().load(t);try{R=await n((async(t,a)=>{a||t?2!=N&&(P(1),C++,F(a??t),P(0)):await M()}))}catch(t){i?.(t)}return Y},stopAutoLoad:G,isAutoLoading:()=>!o(R),save:B,startAutoSave:async()=>(await x().save(),A=t.addDidFinishTransactionListener((()=>{const t=$();m(t)&&B(t)})),Y),stopAutoSave:x,isAutoSaving:()=>!o(A),getStatus:()=>N,addStatusListener:t=>I(t,O),delListener:a=>(_(a),t),schedule:X,getStore:()=>t,destroy:()=>(V(ot,d).splice(0,void 0),G().stopAutoSave()),getStats:()=>({loads:C,saves:f}),...E};return j(Y)},ct=(t,a,e,s,i,r=lt,c,l)=>{const E=K();return[async()=>{E.clear(),R(await e(t,a),(({tn:t,cn:a})=>nt(tt(E,t,et),a)))},async(a,e)=>((t,a)=>_(V(E,t),a))(a,e)?x(N(R(await t(S+I(a)),(t=>{return[t[e],l?(a=Y(t,e),n=l,x(q(a,((t,a)=>[a,n(t,a)])))):Y(t,e)];var a,n})),(([t,a])=>!o(t)&&!k(a)))):{},async(a,e,s,l,y,w=!1)=>{const u=et();q(s??{},(t=>R(B(t??{}),(t=>nt(u,t)))));const p=P(u);if(!w&&y&&A(p)&&_(E,a))return await t("DROP "+L+I(a)),void Z(E,a);const C=V(E,a),f=et(P(C));if(A(p)||(_(E,a)?await d(R([e,...p],(async(n,s)=>{U(f,n)||(await t($+I(a)+"ADD"+I(n)+i),0==s&&await t("CREATE UNIQUE INDEX pk ON "+I(a)+`(${I(e)})`),nt(C,n))}))):(await t("CREATE "+L+I(a)+`(${I(e)}${i} PRIMARY KEY${T(R(p,(t=>n+I(t)+i)))});`),Z(E,a,et([e,...p])))),await d([...!w&&l?R(P(f),(async n=>{n!=e&&(await t($+I(a)+"DROP"+I(n)),U(C,n))})):[]]),w)o(s)?await t(m+I(a)+v+" true"):await d(q(s,(async(n,s)=>{o(n)?await t(m+I(a)+v+I(e)+"=$1",[s]):A(p)||await r(t,a,e,B(n),{[s]:c?R(H(n),c):H(n)},C)})));else if(A(p))_(E,a)&&await t(m+I(a)+v+" true");else{const n=N(P(V(E,a)),(t=>t!=e)),i={},o=[];q(s??{},((t,a)=>{i[a]=R(n,(a=>c?c(t?.[a]):t?.[a])),g(o,a)})),await r(t,a,e,n,i),await t(m+I(a)+v+I(e)+`NOT IN(${h(o)})`,o)}},async a=>{let e;await t("BEGIN");try{e=await a()}catch(t){s?.(t)}return await t("END"),e}]},lt=async(t,a,e,s,i)=>{const o=[1];await t("INSERT INTO"+I(a)+"("+((...t)=>T(R(t,I),n))(e,...s)+")VALUES"+T(q(i,(t=>"($"+o[0]+++","+h(t,o)+")")),n)+"ON CONFLICT("+I(e)+")DO UPDATE SET"+T(R(s,(t=>I(t)+"=excluded."+I(t))),n),q(i,((t,a)=>[a,...R(t,(t=>t??null))])).flat())},Et=(t,a,e,n,s,i,o,[r,c,l],E,y,d,w,u,T)=>{const[R,A,N,g]=ct(a,E,y,s,u,T),p=rt(t,(async()=>await g((async()=>{return await R(),t=(await A(r,c))[C]?.[l]??"null",J(t,((t,a)=>""===a?void 0:a));var t}))),(async t=>await g((async()=>{var a;await R(),await N(r,c,{[C]:{[l]:(a=t()??null,z(a,((t,a)=>void 0===a?"":a)))}},!0,!0)}))),e,n,s,o,{[w]:()=>d,destroy:()=>(p.stopAutoLoad().stopAutoSave(),i(),p)},d);return p},yt=(t,a,e,n,s,i,r,[c,l,[E,y,w]],u,T,R,A,g,p,O,v)=>{const[L,$,m,S]=ct(a,u,T,s,g,p,O,v),I=async(t,a)=>await d(Q(l,(async([e,n,s,i],o)=>{a&&!(o in t)||await m(e,n,t[o],s,i,a)}))),h=async(t,a)=>y?await m(w,f,{[C]:t},!0,!0,a):null,_=rt(t,(async()=>await S((async()=>{await L();const t=await(async()=>x(N(await d(Q(c,(async([t,a],e)=>[t,await $(e,a)]))),(t=>!k(t[1])))))(),a=await(async()=>E?(await $(w,f))[C]:{})();return k(t)&&o(a)?void 0:[t,a]}))),(async(t,a)=>await S((async()=>{if(await L(),o(a)){const[a,e]=t();await I(a),await h(e)}else await I(a[0],!0),await h(a[1],!0)}))),e,n,s,r,{[A]:()=>R,destroy:()=>(_.stopAutoLoad().stopAutoSave(),i(),_)},R);return _},dt="ColumnName",wt="store",ut="json",Tt=wt+"TableName",Rt=wt+"Id"+dt,At=wt+dt,Nt="autoLoadIntervalSeconds",gt="rowId"+dt,pt="tableId",Ct="tableName",ft="deleteEmptyColumns",Ot="deleteEmptyTable",vt={mode:ut,[Nt]:1},Lt={load:0,save:0,[Ct]:e+"_values"},$t=(t,a,e,n,s)=>{const i=K();return q(t,((t,r)=>{const l=E(H(X(a,c(t)?{[e]:t}:t)),0,W(a));o(l[0])||n(r,l[0])||(s(r,l[0]),Z(i,r,l))})),i},mt=e,St=/^([cd]:)(.+)/,It=e+"_data",ht=e+"_table";t.createPostgresPersister=async(t,a,n,s,i)=>{const o=await(a.reserve?.());return((t,a,n,s,i,o,l,y,w,u,T="getDb")=>{const A=((t,a)=>a?async(e,n)=>(a(e,n),await t(e,n)):t)(n,o),[N,,g,p]=(t=>{const a=(t=>X(vt,c(t)?{[Tt]:t}:t??{}))(t),n=a[Nt];if(a.mode==ut){const t=a[Tt]??e;return[1,n,[t,a[Rt]??f,a[At]??wt],et(t)]}const{tables:{load:s={},save:i={}}={},values:o={}}=a,r=E(H(X(Lt,o)),0,W(Lt)),l=r[2],y=et(l),d=et(l);return[0,n,[$t(s,{[pt]:null,[gt]:f},pt,(t=>_(d,t)),(t=>nt(y,t))),$t(i,{[Ct]:null,[gt]:f,[ft]:0,[Ot]:0},Ct,((t,a)=>_(d,a)),((t,a)=>nt(y,a))),r],y]})(a),C=async t=>{await A(`CREATE OR REPLACE TRIGGER ${I(It+"_"+t)} AFTER INSERT OR UPDATE OR DELETE ON ${I(t)} EXECUTE FUNCTION ${It}()`)};return(N?Et:yt)(t,A,(async t=>{await A(`CREATE OR REPLACE FUNCTION ${ht}()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('${mt}','c:'||SPLIT_PART(row.object_identity,'.',2));END LOOP;END;$t2$ LANGUAGE plpgsql;`);try{await A(`CREATE EVENT TRIGGER ${ht} ON ddl_command_end WHEN TAG IN('CREATE TABLE')EXECUTE FUNCTION ${ht}();`)}catch{}return await A(`CREATE OR REPLACE FUNCTION ${It}()RETURNS trigger AS $t1$ BEGIN PERFORM pg_notify('${mt}','d:'||TG_TABLE_NAME);RETURN NULL;END;$t1$ LANGUAGE plpgsql;`),await d(R(P(p),(async t=>{await A(`CREATE TABLE IF NOT EXISTS ${I(t)}("_id"text PRIMARY KEY)`),await C(t)}))),await s(mt,(async a=>{return await r((e=a,n=St,e?.match(n)),(async([,a,e])=>{_(p,e)&&("c:"==a&&await C(e),t())}));var e,n}))}),i,l,y,w,g,P(p),(async(t,a)=>await t(`${O} table_name tn,column_name cn FROM information_schema.columns ${v} table_schema='public'AND table_name IN(${h(a)})`,a)),u,T,"text",void 0,(t=>z(t)),(t=>J(t)))})(t,n,o?.unsafe,(async(t,e)=>a.listen(t,e)),(async t=>{try{await t.unlisten()}catch(t){i?.(t)}}),s,i,(()=>o?.release?.()),3,a,"getSql")}},"object"==typeof exports&&"undefined"!=typeof module?a(exports):"function"==typeof define&&define.amd?define(["exports"],a):a((t="undefined"!=typeof globalThis?globalThis:t||self).TinyBasePersisterPostgres={});
|
|
Binary file
|
|
@@ -1 +1 @@
|
|
|
1
|
-
var t,a;t=this,a=function(t){"use strict";const a=t=>typeof t,e="tinybase",n=",",s=a(""),i=Promise,o=t=>null==t,r=(t,a,e)=>o(t)?e?.():a(t),c=t=>a(t)==s,l=t=>Array.isArray(t),E=(t,a,e)=>t.slice(a,e),y=t=>t.length,d=async t=>i.all(t),w=t=>{throw Error(t)},u=(t,a)=>t.forEach(a),T=(t,a="")=>t.join(a),R=(t,a)=>t.map(a),A=t=>0==y(t),N=(t,a)=>t.filter(a),g=(t,...a)=>t.push(...a),p=t=>t.shift(),C="_",f="_id",O="SELECT",v="WHERE",L="TABLE",$="ALTER "+L,m="DELETE FROM",S=O+"*FROM",I=t=>`"${t.replace(/"/g,'""')}"`,h=(t,a=[1])=>T(R(t,(()=>"$"+a[0]++)),n),_=(t,a)=>t?.has(a)??!1,b=t=>o(t)||0==(t=>t?.size??0)(t),P=t=>[...t?.values()??[]],D=(t,a)=>t?.forEach(a),U=(t,a)=>t?.delete(a),F=Object,M=t=>F.getPrototypeOf(t),G=F.entries,B=F.keys,j=F.freeze,x=(t=[])=>F.fromEntries(t),X=(...t)=>F.assign({},...t),Y=(t,a)=>(delete t[a],t),q=(t,a)=>R(G(t),(([t,e])=>a(e,t))),H=t=>F.values(t),W=t=>y(B(t)),k=t=>(t=>!o(t)&&r(M(t),(t=>t==F.prototype||o(M(t))),(()=>!0)))(t)&&0==W(t),z=JSON.stringify,J=JSON.parse,K=t=>new Map(t),V=(t,a)=>t?.get(a),Q=(t,a)=>R([...t?.entries()??[]],(([t,e])=>a(e,t))),Z=(t,a,e)=>o(e)?(U(t,a),t):t?.set(a,e),tt=(t,a,e,n)=>(_(t,a)?n?.(V(t,a)):Z(t,a,e()),V(t,a)),at=(t,a,e,n,s=0)=>r((e?tt:V)(t,a[s],s>y(a)-2?e:K),(i=>{if(s>y(a)-2)return n?.(i)&&Z(t,a[s]),i;const o=at(i,a,e,n,s+1);return b(i)&&Z(t,a[s]),o})),et=t=>new Set(l(t)||o(t)?t:[t]),nt=(t,a)=>t?.add(a),st=/^\d+$/,it=K(),ot=K(),rt=(t,a,e,n,s,i,c,E={},d=[])=>{let T,R,A,N=0,C=0,f=0;tt(it,d,(()=>0)),tt(ot,d,(()=>[]));const O=K(),[v,L,$,m,S]=((t=1,a)=>1!=t&&a.isMergeable()?[1,a.getMergeableContent,a.getTransactionMergeableChanges,([[t],[a]])=>!k(t)||!k(a),a.setDefaultContent]:2!=t?[0,a.getContent,a.getTransactionChanges,([t,a])=>!k(t)||!k(a),a.setContent]:w("Store type not supported by this Persister"))(c,t),[I,h,_]=(()=>{let t;const[a,e]=(()=>{const t=[];let a=0;return[e=>(e?p(t):null)??""+a++,a=>{st.test(a)&&y(t)<1e3&&g(t,a)}]})(),n=K();return[(e,s,i,o=[],r=()=>[])=>{t??=Y;const c=a(1);return Z(n,c,[e,s,i,o,r]),nt(at(s,i??[""],et),c),c},(a,e,...s)=>u(((t,a=[""])=>{const e=[],n=(t,s)=>s==y(a)?g(e,t):null===a[s]?D(t,(t=>n(t,s+1))):u([a[s],null],(a=>n(V(t,a),s+1)));return n(t,0),e})(a,e),(a=>D(a,(a=>V(n,a)[0](t,...e??[],...s))))),t=>r(V(n,t),(([,a,s])=>(at(a,s??[""],void 0,(a=>(U(a,t),b(a)?1:0))),Z(n,t),e(t),s))),a=>r(V(n,a),(([a,,e=[],n,s])=>{const i=(...r)=>{const c=y(r);c==y(e)?a(t,...r,...s(r)):o(e[c])?u(n[c]?.(...r)??[],(t=>i(...r,t))):i(...r,e[c])};i()}))]})(),P=t=>{t!=N&&(N=t,h(O,void 0,N))},F=a=>{(v&&l(a?.[0])?1===a?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===a?.[2]?t.applyChanges:t.setContent)(a)},M=async t=>(2!=N&&(P(1),C++,await X((async()=>{try{const e=await a();l(e)?F(e):t?S(t):w("Content is not an array "+e)}catch(a){i?.(a),t&&S(t)}P(0)}))),Y),G=()=>(R&&(s(R),R=void 0),Y),B=async t=>(1!=N&&(P(2),f++,await X((async()=>{try{await e(L,t)}catch(t){i?.(t)}P(0)}))),Y),x=()=>(r(A,t.delListener),A=void 0,Y),X=async(...t)=>(g(V(ot,d),...t),await(async()=>{if(!V(it,d)){for(Z(it,d,1);!o(T=p(V(ot,d)));)try{await T()}catch(t){i?.(t)}Z(it,d,0)}})(),Y),Y={load:M,startAutoLoad:async t=>{await G().load(t);try{R=await n((async(t,a)=>{a||t?2!=N&&(P(1),C++,F(a??t),P(0)):await M()}))}catch(t){i?.(t)}return Y},stopAutoLoad:G,isAutoLoading:()=>!o(R),save:B,startAutoSave:async()=>(await x().save(),A=t.addDidFinishTransactionListener((()=>{const t=$();m(t)&&B(t)})),Y),stopAutoSave:x,isAutoSaving:()=>!o(A),getStatus:()=>N,addStatusListener:t=>I(t,O),delListener:a=>(_(a),t),schedule:X,getStore:()=>t,destroy:()=>(V(ot,d).splice(0,void 0),G().stopAutoSave()),getStats:()=>({loads:C,saves:f}),...E};return j(Y)},ct=(t,a,e,s,i,r=lt,c,l)=>{const E=K();return[async()=>{E.clear(),R(await e(t,a),(({tn:t,cn:a})=>nt(tt(E,t,et),a)))},async(a,e)=>((t,a)=>_(V(E,t),a))(a,e)?x(N(R(await t(S+I(a)),(t=>{return[t[e],l?(a=Y(t,e),n=l,x(q(a,((t,a)=>[a,n(t,a)])))):Y(t,e)];var a,n})),(([t,a])=>!o(t)&&!k(a)))):{},async(a,e,s,l,y,w=!1)=>{const u=et();q(s??{},(t=>R(B(t??{}),(t=>nt(u,t)))));const p=P(u);if(!w&&y&&A(p)&&_(E,a))return await t("DROP "+L+I(a)),void Z(E,a);const C=V(E,a),f=et(P(C));if(A(p)||(_(E,a)?await d(R([e,...p],(async(n,s)=>{U(f,n)||(await t($+I(a)+"ADD"+I(n)+i),0==s&&await t("CREATE UNIQUE INDEX pk ON "+I(a)+`(${I(e)})`),nt(C,n))}))):(await t("CREATE "+L+I(a)+`(${I(e)}${i} PRIMARY KEY${T(R(p,(t=>n+I(t)+i)))});`),Z(E,a,et([e,...p])))),await d([...!w&&l?R(P(f),(async n=>{n!=e&&(await t($+I(a)+"DROP"+I(n)),U(C,n))})):[]]),w)o(s)?await t(m+I(a)+v+" true"):await d(q(s,(async(n,s)=>{o(n)?await t(m+I(a)+v+I(e)+"=$1",[s]):A(p)||await r(t,a,e,B(n),{[s]:c?R(H(n),c):H(n)},C)})));else if(A(p))_(E,a)&&await t(m+I(a)+v+" true");else{const n=N(P(V(E,a)),(t=>t!=e)),i={},o=[];q(s??{},((t,a)=>{i[a]=R(n,(a=>c?c(t?.[a]):t?.[a])),g(o,a)})),await r(t,a,e,n,i),await t(m+I(a)+v+I(e)+`NOT IN(${h(o)})`,o)}},async a=>{let e;await t("BEGIN");try{e=await a()}catch(t){s?.(t)}return await t("END"),e}]},lt=async(t,a,e,s,i)=>{const o=[1];await t("INSERT INTO"+I(a)+"("+((...t)=>T(R(t,I),n))(e,...s)+")VALUES"+T(q(i,(t=>"($"+o[0]+++","+h(t,o)+")")),n)+"ON CONFLICT("+I(e)+")DO UPDATE SET"+T(R(s,(t=>I(t)+"=excluded."+I(t))),n),q(i,((t,a)=>[a,...R(t,(t=>t??null))])).flat())},Et=(t,a,e,n,s,i,o,[r,c,l],E,y,d,w,u,T)=>{const[R,A,N,g]=ct(a,E,y,s,u,T),p=rt(t,(async()=>await g((async()=>{return await R(),t=(await A(r,c))[C]?.[l]??"null",J(t,((t,a)=>""===a?void 0:a));var t}))),(async t=>await g((async()=>{var a;await R(),await N(r,c,{[C]:{[l]:(a=t()??null,z(a,((t,a)=>void 0===a?"":a)))}},!0,!0)}))),e,n,s,o,{[w]:()=>d,destroy:()=>(p.stopAutoLoad().stopAutoSave(),i(),p)},d);return p},yt=(t,a,e,n,s,i,r,[c,l,[E,y,w]],u,T,R,A,g,p,O,v)=>{const[L,$,m,S]=ct(a,u,T,s,g,p,O,v),I=async(t,a)=>await d(Q(l,(async([e,n,s,i],o)=>{a&&!(o in t)||await m(e,n,t[o],s,i,a)}))),h=async(t,a)=>y?await m(w,f,{[C]:t},!0,!0,a):null,_=rt(t,(async()=>await S((async()=>{await L();const t=await(async()=>x(N(await d(Q(c,(async([t,a],e)=>[t,await $(e,a)]))),(t=>!k(t[1])))))(),a=await(async()=>E?(await $(w,f))[C]:{})();return k(t)&&o(a)?void 0:[t,a]}))),(async(t,a)=>await S((async()=>{if(await L(),o(a)){const[a,e]=t();await I(a),await h(e)}else await I(a[0],!0),await h(a[1],!0)}))),e,n,s,r,{[A]:()=>R,destroy:()=>(_.stopAutoLoad().stopAutoSave(),i(),_)},R);return _},dt="ColumnName",wt="store",ut="json",Tt=wt+"TableName",Rt=wt+"Id"+dt,At=wt+dt,Nt="autoLoadIntervalSeconds",gt="rowId"+dt,pt="tableId",Ct="tableName",ft="deleteEmptyColumns",Ot="deleteEmptyTable",vt={mode:ut,[Nt]:1},Lt={load:0,save:0,[Ct]:e+"_values"},$t=(t,a,e,n,s)=>{const i=K();return q(t,((t,r)=>{const l=E(H(X(a,c(t)?{[e]:t}:t)),0,W(a));o(l[0])||n(r,l[0])||(s(r,l[0]),Z(i,r,l))})),i},mt=e,St=/^([cd]:)(.+)/,It=e+"_data",ht=e+"_table";t.createPostgresPersister=async(t,a,n,s,i)=>{const o=await(a.reserve?.());return((t,a,n,s,i,o,l,y,w,u,T="getDb")=>{const A=((t,a)=>a?async(e,n)=>(a(e,n),await t(e,n)):t)(n,o),[N,,g,p]=(t=>{const a=(t=>X(vt,c(t)?{[Tt]:t}:t??{}))(t),n=a[Nt];if(a.mode==ut){const t=a[Tt]??e;return[1,n,[t,a[Rt]??f,a[At]??wt],et(t)]}const{tables:{load:s={},save:i={}}={},values:o={}}=a,r=E(H(X(Lt,o)),0,W(Lt)),l=r[2],y=et(l),d=et(l);return[0,n,[$t(s,{[pt]:null,[gt]:f},pt,(t=>_(d,t)),(t=>nt(y,t))),$t(i,{[Ct]:null,[gt]:f,[ft]:0,[Ot]:0},Ct,((t,a)=>_(d,a)),((t,a)=>nt(y,a))),r],y]})(a),C=async t=>{await A(`CREATE OR REPLACE TRIGGER ${I(It+"_"+t)} AFTER INSERT OR UPDATE OR DELETE ON ${I(t)} EXECUTE FUNCTION ${It}()`)};return(N?Et:yt)(t,A,(async t=>{await A(`CREATE OR REPLACE FUNCTION ${ht}()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('${mt}','c:'||SPLIT_PART(row.object_identity,'.',2));END LOOP;END;$t2$ LANGUAGE plpgsql;`);try{await A(`CREATE EVENT TRIGGER ${ht} ON ddl_command_end WHEN TAG IN('CREATE TABLE')EXECUTE FUNCTION ${ht}();`)}catch{}return await A(`CREATE OR REPLACE FUNCTION ${It}()RETURNS trigger AS $t1$ BEGIN PERFORM pg_notify('${mt}','d:'||TG_TABLE_NAME);RETURN NULL;END;$t1$ LANGUAGE plpgsql;`),await d(R(P(p),(async t=>{await A(`CREATE TABLE IF NOT EXISTS ${I(t)}("_id"text PRIMARY KEY)`),await C(t)}))),await s(mt,(async a=>{return await r((e=a,n=St,e?.match(n)),(async([,a,e])=>{_(p,e)&&("c:"==a&&await C(e),t())}));var e,n}))}),i,l,y,w,g,P(p),(async(t,a)=>await t(`${O} table_name tn,column_name cn FROM information_schema.columns ${v} table_schema='public'AND table_name IN(${h(a)})`,a)),u,T,"text",void 0,(t=>z(t)),(t=>J(t)))})(t,n,o?.unsafe,(async(t,e)=>a.listen(t,e)),(async t=>{try{await t.unlisten()}catch(t){i?.(t)}}),s,i,(()=>o?.release?.()),3,a,"getSql")}},"object"==typeof exports&&"undefined"!=typeof module?a(exports):"function"==typeof define&&define.amd?define(["exports"],a):a((t="undefined"!=typeof globalThis?globalThis:t||self).TinyBasePersisterPostgres={});
|
|
1
|
+
var t,a;t=this,a=function(t){"use strict";const a=t=>typeof t,e="tinybase",n=",",s=a(""),i=Promise,o=t=>null==t,r=(t,a,e)=>o(t)?e?.():a(t),c=t=>a(t)==s,l=t=>Array.isArray(t),E=(t,a,e)=>t.slice(a,e),y=t=>t.length,d=async t=>i.all(t),w=t=>{throw Error(t)},u=(t,a)=>t.forEach(a),T=(t,a="")=>t.join(a),R=(t,a)=>t.map(a),A=t=>0==y(t),N=(t,a)=>t.filter(a),g=(t,...a)=>t.push(...a),p=t=>t.shift(),C="_",f="_id",O="SELECT",v="WHERE",L="TABLE",$="ALTER "+L,m="DELETE FROM",S=O+"*FROM",I=t=>`"${t.replace(/"/g,'""')}"`,h=(t,a=[1])=>T(R(t,(()=>"$"+a[0]++)),n),_=(t,a)=>t?.has(a)??!1,b=t=>o(t)||0==(t=>t?.size??0)(t),P=t=>[...t?.values()??[]],D=(t,a)=>t?.forEach(a),U=(t,a)=>t?.delete(a),F=Object,M=t=>F.getPrototypeOf(t),G=F.entries,B=F.keys,j=F.freeze,x=(t=[])=>F.fromEntries(t),X=(...t)=>F.assign({},...t),Y=(t,a)=>(delete t[a],t),q=(t,a)=>R(G(t),(([t,e])=>a(e,t))),H=t=>F.values(t),W=t=>y(B(t)),k=t=>(t=>!o(t)&&r(M(t),(t=>t==F.prototype||o(M(t))),(()=>!0)))(t)&&0==W(t),z=JSON.stringify,J=JSON.parse,K=t=>new Map(t),V=(t,a)=>t?.get(a),Q=(t,a)=>R([...t?.entries()??[]],(([t,e])=>a(e,t))),Z=(t,a,e)=>o(e)?(U(t,a),t):t?.set(a,e),tt=(t,a,e,n)=>(_(t,a)?n?.(V(t,a)):Z(t,a,e()),V(t,a)),at=(t,a,e,n,s=0)=>r((e?tt:V)(t,a[s],s>y(a)-2?e:K),(i=>{if(s>y(a)-2)return n?.(i)&&Z(t,a[s]),i;const o=at(i,a,e,n,s+1);return b(i)&&Z(t,a[s]),o})),et=t=>new Set(l(t)||o(t)?t:[t]),nt=(t,a)=>t?.add(a),st=/^\d+$/,it=K(),ot=K(),rt=(t,a,e,n,s,i,c,E={},d=[])=>{let T,R,A,N=0,C=0,f=0;tt(it,d,(()=>0)),tt(ot,d,(()=>[]));const O=K(),[v,L,$,m,S]=((t=1,a)=>1!=t&&a.isMergeable()?[1,a.getMergeableContent,a.getTransactionMergeableChanges,([[t],[a]])=>!k(t)||!k(a),a.setDefaultContent]:2!=t?[0,a.getContent,a.getTransactionChanges,([t,a])=>!k(t)||!k(a),a.setContent]:w("Store type not supported by this Persister"))(c,t),[I,h,_]=(()=>{let t;const[a,e]=(()=>{const t=[];let a=0;return[e=>(e?p(t):null)??""+a++,a=>{st.test(a)&&y(t)<1e3&&g(t,a)}]})(),n=K();return[(e,s,i,o=[],r=()=>[])=>{t??=Y;const c=a(1);return Z(n,c,[e,s,i,o,r]),nt(at(s,i??[""],et),c),c},(a,e,...s)=>u(((t,a=[""])=>{const e=[],n=(t,s)=>s==y(a)?g(e,t):null===a[s]?D(t,(t=>n(t,s+1))):u([a[s],null],(a=>n(V(t,a),s+1)));return n(t,0),e})(a,e),(a=>D(a,(a=>V(n,a)[0](t,...e??[],...s))))),t=>r(V(n,t),(([,a,s])=>(at(a,s??[""],void 0,(a=>(U(a,t),b(a)?1:0))),Z(n,t),e(t),s))),a=>r(V(n,a),(([a,,e=[],n,s])=>{const i=(...r)=>{const c=y(r);c==y(e)?a(t,...r,...s(r)):o(e[c])?u(n[c]?.(...r)??[],(t=>i(...r,t))):i(...r,e[c])};i()}))]})(),P=t=>{t!=N&&(N=t,h(O,void 0,N))},F=a=>{(v&&l(a?.[0])?1===a?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===a?.[2]?t.applyChanges:t.setContent)(a)},M=async t=>(2!=N&&(P(1),C++,await X((async()=>{try{const e=await a();l(e)?F(e):t?S(t):w("Content is not an array: "+e)}catch(a){i?.(a),t&&S(t)}P(0)}))),Y),G=()=>(R&&(s(R),R=void 0),Y),B=async t=>(1!=N&&(P(2),f++,await X((async()=>{try{await e(L,t)}catch(t){i?.(t)}P(0)}))),Y),x=()=>(r(A,t.delListener),A=void 0,Y),X=async(...t)=>(g(V(ot,d),...t),await(async()=>{if(!V(it,d)){for(Z(it,d,1);!o(T=p(V(ot,d)));)try{await T()}catch(t){i?.(t)}Z(it,d,0)}})(),Y),Y={load:M,startAutoLoad:async t=>{await G().load(t);try{R=await n((async(t,a)=>{a||t?2!=N&&(P(1),C++,F(a??t),P(0)):await M()}))}catch(t){i?.(t)}return Y},stopAutoLoad:G,isAutoLoading:()=>!o(R),save:B,startAutoSave:async()=>(await x().save(),A=t.addDidFinishTransactionListener((()=>{const t=$();m(t)&&B(t)})),Y),stopAutoSave:x,isAutoSaving:()=>!o(A),getStatus:()=>N,addStatusListener:t=>I(t,O),delListener:a=>(_(a),t),schedule:X,getStore:()=>t,destroy:()=>(V(ot,d).splice(0,void 0),G().stopAutoSave()),getStats:()=>({loads:C,saves:f}),...E};return j(Y)},ct=(t,a,e,s,i,r=lt,c,l)=>{const E=K();return[async()=>{E.clear(),R(await e(t,a),(({tn:t,cn:a})=>nt(tt(E,t,et),a)))},async(a,e)=>((t,a)=>_(V(E,t),a))(a,e)?x(N(R(await t(S+I(a)),(t=>{return[t[e],l?(a=Y(t,e),n=l,x(q(a,((t,a)=>[a,n(t,a)])))):Y(t,e)];var a,n})),(([t,a])=>!o(t)&&!k(a)))):{},async(a,e,s,l,y,w=!1)=>{const u=et();q(s??{},(t=>R(B(t??{}),(t=>nt(u,t)))));const p=P(u);if(!w&&y&&A(p)&&_(E,a))return await t("DROP "+L+I(a)),void Z(E,a);const C=V(E,a),f=et(P(C));if(A(p)||(_(E,a)?await d(R([e,...p],(async(n,s)=>{U(f,n)||(await t($+I(a)+"ADD"+I(n)+i),0==s&&await t("CREATE UNIQUE INDEX pk ON "+I(a)+`(${I(e)})`),nt(C,n))}))):(await t("CREATE "+L+I(a)+`(${I(e)}${i} PRIMARY KEY${T(R(p,(t=>n+I(t)+i)))});`),Z(E,a,et([e,...p])))),await d([...!w&&l?R(P(f),(async n=>{n!=e&&(await t($+I(a)+"DROP"+I(n)),U(C,n))})):[]]),w)o(s)?await t(m+I(a)+v+" true"):await d(q(s,(async(n,s)=>{o(n)?await t(m+I(a)+v+I(e)+"=$1",[s]):A(p)||await r(t,a,e,B(n),{[s]:c?R(H(n),c):H(n)},C)})));else if(A(p))_(E,a)&&await t(m+I(a)+v+" true");else{const n=N(P(V(E,a)),(t=>t!=e)),i={},o=[];q(s??{},((t,a)=>{i[a]=R(n,(a=>c?c(t?.[a]):t?.[a])),g(o,a)})),await r(t,a,e,n,i),await t(m+I(a)+v+I(e)+`NOT IN(${h(o)})`,o)}},async a=>{let e;await t("BEGIN");try{e=await a()}catch(t){s?.(t)}return await t("END"),e}]},lt=async(t,a,e,s,i)=>{const o=[1];await t("INSERT INTO"+I(a)+"("+((...t)=>T(R(t,I),n))(e,...s)+")VALUES"+T(q(i,(t=>"($"+o[0]+++","+h(t,o)+")")),n)+"ON CONFLICT("+I(e)+")DO UPDATE SET"+T(R(s,(t=>I(t)+"=excluded."+I(t))),n),q(i,((t,a)=>[a,...R(t,(t=>t??null))])).flat())},Et=(t,a,e,n,s,i,o,[r,c,l],E,y,d,w,u,T)=>{const[R,A,N,g]=ct(a,E,y,s,u,T),p=rt(t,(async()=>await g((async()=>{return await R(),t=(await A(r,c))[C]?.[l]??"null",J(t,((t,a)=>""===a?void 0:a));var t}))),(async t=>await g((async()=>{var a;await R(),await N(r,c,{[C]:{[l]:(a=t()??null,z(a,((t,a)=>void 0===a?"":a)))}},!0,!0)}))),e,n,s,o,{[w]:()=>d,destroy:()=>(p.stopAutoLoad().stopAutoSave(),i(),p)},d);return p},yt=(t,a,e,n,s,i,r,[c,l,[E,y,w]],u,T,R,A,g,p,O,v)=>{const[L,$,m,S]=ct(a,u,T,s,g,p,O,v),I=async(t,a)=>await d(Q(l,(async([e,n,s,i],o)=>{a&&!(o in t)||await m(e,n,t[o],s,i,a)}))),h=async(t,a)=>y?await m(w,f,{[C]:t},!0,!0,a):null,_=rt(t,(async()=>await S((async()=>{await L();const t=await(async()=>x(N(await d(Q(c,(async([t,a],e)=>[t,await $(e,a)]))),(t=>!k(t[1])))))(),a=await(async()=>E?(await $(w,f))[C]:{})();return k(t)&&o(a)?void 0:[t,a]}))),(async(t,a)=>await S((async()=>{if(await L(),o(a)){const[a,e]=t();await I(a),await h(e)}else await I(a[0],!0),await h(a[1],!0)}))),e,n,s,r,{[A]:()=>R,destroy:()=>(_.stopAutoLoad().stopAutoSave(),i(),_)},R);return _},dt="ColumnName",wt="store",ut="json",Tt=wt+"TableName",Rt=wt+"Id"+dt,At=wt+dt,Nt="autoLoadIntervalSeconds",gt="rowId"+dt,pt="tableId",Ct="tableName",ft="deleteEmptyColumns",Ot="deleteEmptyTable",vt={mode:ut,[Nt]:1},Lt={load:0,save:0,[Ct]:e+"_values"},$t=(t,a,e,n,s)=>{const i=K();return q(t,((t,r)=>{const l=E(H(X(a,c(t)?{[e]:t}:t)),0,W(a));o(l[0])||n(r,l[0])||(s(r,l[0]),Z(i,r,l))})),i},mt=e,St=/^([cd]:)(.+)/,It=e+"_data",ht=e+"_table";t.createPostgresPersister=async(t,a,n,s,i)=>{const o=await(a.reserve?.());return((t,a,n,s,i,o,l,y,w,u,T="getDb")=>{const A=((t,a)=>a?async(e,n)=>(a(e,n),await t(e,n)):t)(n,o),[N,,g,p]=(t=>{const a=(t=>X(vt,c(t)?{[Tt]:t}:t??{}))(t),n=a[Nt];if(a.mode==ut){const t=a[Tt]??e;return[1,n,[t,a[Rt]??f,a[At]??wt],et(t)]}const{tables:{load:s={},save:i={}}={},values:o={}}=a,r=E(H(X(Lt,o)),0,W(Lt)),l=r[2],y=et(l),d=et(l);return[0,n,[$t(s,{[pt]:null,[gt]:f},pt,(t=>_(d,t)),(t=>nt(y,t))),$t(i,{[Ct]:null,[gt]:f,[ft]:0,[Ot]:0},Ct,((t,a)=>_(d,a)),((t,a)=>nt(y,a))),r],y]})(a),C=async t=>{await A(`CREATE OR REPLACE TRIGGER ${I(It+"_"+t)} AFTER INSERT OR UPDATE OR DELETE ON ${I(t)} EXECUTE FUNCTION ${It}()`)};return(N?Et:yt)(t,A,(async t=>{await A(`CREATE OR REPLACE FUNCTION ${ht}()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('${mt}','c:'||SPLIT_PART(row.object_identity,'.',2));END LOOP;END;$t2$ LANGUAGE plpgsql;`);try{await A(`CREATE EVENT TRIGGER ${ht} ON ddl_command_end WHEN TAG IN('CREATE TABLE')EXECUTE FUNCTION ${ht}();`)}catch{}return await A(`CREATE OR REPLACE FUNCTION ${It}()RETURNS trigger AS $t1$ BEGIN PERFORM pg_notify('${mt}','d:'||TG_TABLE_NAME);RETURN NULL;END;$t1$ LANGUAGE plpgsql;`),await d(R(P(p),(async t=>{await A(`CREATE TABLE IF NOT EXISTS ${I(t)}("_id"text PRIMARY KEY)`),await C(t)}))),await s(mt,(async a=>{return await r((e=a,n=St,e?.match(n)),(async([,a,e])=>{_(p,e)&&("c:"==a&&await C(e),t())}));var e,n}))}),i,l,y,w,g,P(p),(async(t,a)=>await t(`${O} table_name tn,column_name cn FROM information_schema.columns ${v} table_schema='public'AND table_name IN(${h(a)})`,a)),u,T,"text",void 0,(t=>z(t)),(t=>J(t)))})(t,n,o?.unsafe,(async(t,e)=>a.listen(t,e)),(async t=>{try{await t.unlisten()}catch(t){i?.(t)}}),s,i,(()=>o?.release?.()),3,a,"getSql")}},"object"==typeof exports&&"undefined"!=typeof module?a(exports):"function"==typeof define&&define.amd?define(["exports"],a):a((t="undefined"!=typeof globalThis?globalThis:t||self).TinyBasePersisterPostgres={});
|
|
Binary file
|
|
@@ -1 +1 @@
|
|
|
1
|
-
var t,a;t=this,a=function(t){"use strict";const a=t=>typeof t,e="tinybase",n="",s=",",o=a(n),r=Promise,i=clearInterval,c=t=>null==t,l=(t,a,e)=>c(t)?e?.():a(t),y=t=>a(t)==o,u=t=>Array.isArray(t),w=(t,a,e)=>t.slice(a,e),d=t=>t.length,E=async t=>r.all(t),p=t=>{throw Error(t)},f=(t,a)=>t.forEach(a),v=(t,a="")=>t.join(a),g=(t,a)=>t.map(a),h=t=>0==d(t),A=(t,a)=>t.filter(a),T=(t,...a)=>t.push(...a),m=t=>t.shift(),N=Object,S=t=>N.getPrototypeOf(t),b=N.entries,C=N.keys,$=N.freeze,O=(t=[])=>N.fromEntries(t),I=(...t)=>N.assign({},...t),L=(t,a)=>(delete t[a],t),R=(t,a)=>g(b(t),(([t,e])=>a(e,t))),D=t=>N.values(t),P=t=>d(C(t)),M=t=>(t=>!c(t)&&l(S(t),(t=>t==N.prototype||c(S(t))),(()=>!0)))(t)&&0==P(t),_=t=>new Set(u(t)||c(t)?t:[t]),F=(t,a)=>t?.add(a),x="_",U="_id",j="SELECT",B="WHERE",H="TABLE",J="ALTER "+H,Y="DELETE FROM",k=j+"*FROM",z="pragma_",G="data_version",V="schema_version",W="pragma_table_",K=t=>`"${t.replace(/"/g,'""')}"`,Q=(...t)=>v(g(t,K),s),X=(t,a=[1])=>v(g(t,(()=>"$"+a[0]++)),s),q=(t,a)=>t?.has(a)??!1,Z=t=>c(t)||0==(t=>t?.size??0)(t),tt=t=>[...t?.values()??[]],at=(t,a)=>t?.forEach(a),et=(t,a)=>t?.delete(a),nt=JSON.stringify,st=JSON.parse,ot=t=>new Map(t),rt=(t,a)=>t?.get(a),it=(t,a)=>g([...t?.entries()??[]],(([t,e])=>a(e,t))),ct=(t,a,e)=>c(e)?(et(t,a),t):t?.set(a,e),lt=(t,a,e,n)=>(q(t,a)?n?.(rt(t,a)):ct(t,a,e()),rt(t,a)),yt=(t,a,e,n,s=0)=>l((e?lt:rt)(t,a[s],s>d(a)-2?e:ot),(o=>{if(s>d(a)-2)return n?.(o)&&ct(t,a[s]),o;const r=yt(o,a,e,n,s+1);return Z(o)&&ct(t,a[s]),r})),ut=/^\d+$/,wt=ot(),dt=ot(),Et=(t,a,e,s,o,r,i,y={},w=[])=>{let E,v,g,h=0,A=0,N=0;lt(wt,w,(()=>0)),lt(dt,w,(()=>[]));const S=ot(),[b,C,O,I,L]=((t=1,a)=>1!=t&&a.isMergeable()?[1,a.getMergeableContent,a.getTransactionMergeableChanges,([[t],[a]])=>!M(t)||!M(a),a.setDefaultContent]:2!=t?[0,a.getContent,a.getTransactionChanges,([t,a])=>!M(t)||!M(a),a.setContent]:p("Store type not supported by this Persister"))(i,t),[R,D,P]=(()=>{let t;const[a,e]=(()=>{const t=[];let a=0;return[e=>(e?m(t):null)??n+a++,a=>{ut.test(a)&&d(t)<1e3&&T(t,a)}]})(),s=ot();return[(e,o,r,i=[],c=()=>[])=>{t??=k;const l=a(1);return ct(s,l,[e,o,r,i,c]),F(yt(o,r??[n],_),l),l},(a,e,...o)=>f(((t,a=[n])=>{const e=[],s=(t,n)=>n==d(a)?T(e,t):null===a[n]?at(t,(t=>s(t,n+1))):f([a[n],null],(a=>s(rt(t,a),n+1)));return s(t,0),e})(a,e),(a=>at(a,(a=>rt(s,a)[0](t,...e??[],...o))))),t=>l(rt(s,t),(([,a,o])=>(yt(a,o??[n],void 0,(a=>(et(a,t),Z(a)?1:0))),ct(s,t),e(t),o))),a=>l(rt(s,a),(([a,,e=[],n,s])=>{const o=(...r)=>{const i=d(r);i==d(e)?a(t,...r,...s(r)):c(e[i])?f(n[i]?.(...r)??[],(t=>o(...r,t))):o(...r,e[i])};o()}))]})(),x=t=>{t!=h&&(h=t,D(S,void 0,h))},U=a=>{(b&&u(a?.[0])?1===a?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===a?.[2]?t.applyChanges:t.setContent)(a)},j=async t=>(2!=h&&(x(1),A++,await Y((async()=>{try{const e=await a();u(e)?U(e):t?L(t):p("Content is not an array "+e)}catch(a){r?.(a),t&&L(t)}x(0)}))),k),B=()=>(v&&(o(v),v=void 0),k),H=async t=>(1!=h&&(x(2),N++,await Y((async()=>{try{await e(C,t)}catch(t){r?.(t)}x(0)}))),k),J=()=>(l(g,t.delListener),g=void 0,k),Y=async(...t)=>(T(rt(dt,w),...t),await(async()=>{if(!rt(wt,w)){for(ct(wt,w,1);!c(E=m(rt(dt,w)));)try{await E()}catch(t){r?.(t)}ct(wt,w,0)}})(),k),k={load:j,startAutoLoad:async t=>{await B().load(t);try{v=await s((async(t,a)=>{a||t?2!=h&&(x(1),A++,U(a??t),x(0)):await j()}))}catch(t){r?.(t)}return k},stopAutoLoad:B,isAutoLoading:()=>!c(v),save:H,startAutoSave:async()=>(await J().save(),g=t.addDidFinishTransactionListener((()=>{const t=O();I(t)&&H(t)})),k),stopAutoSave:J,isAutoSaving:()=>!c(g),getStatus:()=>h,addStatusListener:t=>R(t,S),delListener:a=>(P(a),t),schedule:Y,getStore:()=>t,destroy:()=>(rt(dt,w).splice(0,void 0),B().stopAutoSave()),getStats:()=>({loads:A,saves:N}),...y};return $(k)},pt=(t,a,e,n,o,r=ft,i,l)=>{const y=ot();return[async()=>{y.clear(),g(await e(t,a),(({tn:t,cn:a})=>F(lt(y,t,_),a)))},async(a,e)=>((t,a)=>q(rt(y,t),a))(a,e)?O(A(g(await t(k+K(a)),(t=>{return[t[e],l?(a=L(t,e),n=l,O(R(a,((t,a)=>[a,n(t,a)])))):L(t,e)];var a,n})),(([t,a])=>!c(t)&&!M(a)))):{},async(a,e,n,l,u,w=!1)=>{const d=_();R(n??{},(t=>g(C(t??{}),(t=>F(d,t)))));const p=tt(d);if(!w&&u&&h(p)&&q(y,a))return await t("DROP "+H+K(a)),void ct(y,a);const f=rt(y,a),m=_(tt(f));if(h(p)||(q(y,a)?await E(g([e,...p],(async(n,s)=>{et(m,n)||(await t(J+K(a)+"ADD"+K(n)+o),0==s&&await t("CREATE UNIQUE INDEX pk ON "+K(a)+`(${K(e)})`),F(f,n))}))):(await t("CREATE "+H+K(a)+`(${K(e)}${o} PRIMARY KEY${v(g(p,(t=>s+K(t)+o)))});`),ct(y,a,_([e,...p])))),await E([...!w&&l?g(tt(m),(async n=>{n!=e&&(await t(J+K(a)+"DROP"+K(n)),et(f,n))})):[]]),w)c(n)?await t(Y+K(a)+B+" true"):await E(R(n,(async(n,s)=>{c(n)?await t(Y+K(a)+B+K(e)+"=$1",[s]):h(p)||await r(t,a,e,C(n),{[s]:i?g(D(n),i):D(n)},f)})));else if(h(p))q(y,a)&&await t(Y+K(a)+B+" true");else{const s=A(tt(rt(y,a)),(t=>t!=e)),o={},c=[];R(n??{},((t,a)=>{o[a]=g(s,(a=>i?i(t?.[a]):t?.[a])),T(c,a)})),await r(t,a,e,s,o),await t(Y+K(a)+B+K(e)+`NOT IN(${X(c)})`,c)}},async a=>{let e;await t("BEGIN");try{e=await a()}catch(t){n?.(t)}return await t("END"),e}]},ft=async(t,a,e,n,o)=>{const r=[1];await t("INSERT INTO"+K(a)+"("+Q(e,...n)+")VALUES"+v(R(o,(t=>"($"+r[0]+++","+X(t,r)+")")),s)+"ON CONFLICT("+K(e)+")DO UPDATE SET"+v(g(n,(t=>K(t)+"=excluded."+K(t))),s),R(o,((t,a)=>[a,...g(t,(t=>t??null))])).flat())},vt=(t,a,e,n,s,o,r,[i,c,l],y,u,w,d,E,p)=>{const[f,v,g,h]=pt(a,y,u,s,E,p),A=Et(t,(async()=>await h((async()=>{return await f(),t=(await v(i,c))[x]?.[l]??"null",st(t,((t,a)=>""===a?void 0:a));var t}))),(async t=>await h((async()=>{var a;await f(),await g(i,c,{[x]:{[l]:(a=t()??null,nt(a,((t,a)=>void 0===a?"":a)))}},!0,!0)}))),e,n,s,r,{[d]:()=>w,destroy:()=>(A.stopAutoLoad().stopAutoSave(),o(),A)},w);return A},gt=(t,a,e,n,s,o,r,[i,l,[y,u,w]],d,p,f,v,g,h,T,m)=>{const[N,S,b,C]=pt(a,d,p,s,g,h,T,m),$=async(t,a)=>await E(it(l,(async([e,n,s,o],r)=>{a&&!(r in t)||await b(e,n,t[r],s,o,a)}))),I=async(t,a)=>u?await b(w,U,{[x]:t},!0,!0,a):null,L=Et(t,(async()=>await C((async()=>{await N();const t=await(async()=>O(A(await E(it(i,(async([t,a],e)=>[t,await S(e,a)]))),(t=>!M(t[1])))))(),a=await(async()=>y?(await S(w,U))[x]:{})();return M(t)&&c(a)?void 0:[t,a]}))),(async(t,a)=>await C((async()=>{if(await N(),c(a)){const[a,e]=t();await $(a),await I(e)}else await $(a[0],!0),await I(a[1],!0)}))),e,n,s,r,{[v]:()=>f,destroy:()=>(L.stopAutoLoad().stopAutoSave(),o(),L)},f);return L},ht="ColumnName",At="store",Tt="json",mt=At+"TableName",Nt=At+"Id"+ht,St=At+ht,bt="autoLoadIntervalSeconds",Ct="rowId"+ht,$t="tableId",Ot="tableName",It="deleteEmptyColumns",Lt="deleteEmptyTable",Rt={mode:Tt,[bt]:1},Dt={load:0,save:0,[Ot]:e+"_values"},Pt=(t,a,e,n,s)=>{const o=ot();return R(t,((t,r)=>{const i=w(D(I(a,y(t)?{[e]:t}:t)),0,P(a));c(i[0])||n(r,i[0])||(s(r,i[0]),ct(o,r,i))})),o},Mt=(t,a,s,o,r,c,l,u,d,E,p="getDb",f)=>{let v,g,h;const A=((t,a)=>a?async(e,n)=>(a(e,n),await t(e,n)):t)(s,c),[T,m,N,S]=(t=>{const a=(t=>I(Rt,y(t)?{[mt]:t}:t??{}))(t),n=a[bt];if(a.mode==Tt){const t=a[mt]??e;return[1,n,[t,a[Nt]??U,a[St]??At],_(t)]}const{tables:{load:s={},save:o={}}={},values:r={}}=a,i=w(D(I(Dt,r)),0,P(Dt)),c=i[2],l=_(c),u=_(c);return[0,n,[Pt(s,{[$t]:null,[Ct]:U},$t,(t=>q(u,t)),(t=>F(l,t))),Pt(o,{[Ot]:null,[Ct]:U,[It]:0,[Lt]:0},Ot,((t,a)=>q(u,a)),((t,a)=>F(l,a))),i],l]})(a);return(T?vt:gt)(t,A,(t=>{let a;const e=()=>a=setInterval((async()=>{try{const[{d:a,s:e,c:n}]=await A(`${j} ${G} d,${V} s,TOTAL_CHANGES() c FROM ${z}${G} JOIN ${z}${V}`);a==v&&e==g&&n==h||(null!=v&&t(),v=a,g=e,h=n)}catch{}}),1e3*m),n=()=>{v=g=h=null,i(a)},s=o((a=>{S.has(a)&&(n(),t(),e())}));return e(),()=>{n(),r(s)}}),(t=>t()),l,u,d,N,tt(S),(async(t,a)=>await t(`${j} t.name tn,c.name cn FROM ${W}list()t,${W}info(t.name)c ${B} t.schema='main'AND t.type IN('table','view')AND t.name IN(${X(a)})ORDER BY t.name,c.name`,a)),E,p,n,f,(t=>!0===t?1:!1===t?0:t),void 0)},_t=async(t,a,e,n,o,r)=>{const i=[1],c=_(n),l=r?A([...r],(t=>t!=e&&!q(c,t))):[];if(!h(l)){const n=C(o),s=O(g(await t("SELECT"+Q(e,...l)+"FROM"+K(a)+"WHERE"+K(e)+"IN("+X(n)+")",n),(t=>[t[e],t])));f(n,(t=>T(o[t],...g(l,(a=>s?.[t]?.[a]??null)))))}await t("INSERT OR REPLACE INTO"+K(a)+"("+Q(e,...n,...l)+")VALUES"+v(R(o,(t=>"($"+i[0]+++","+X(t,i)+")")),s),R(o,((t,a)=>[a,...g(t,(t=>t??null))])).flat())};t.createPowerSyncPersister=(t,a,e,n,s)=>{let o;return Mt(t,e,(async(t,e=[])=>a.execute(t,e).then((t=>t.rows?._array??[]))),(t=>{const e=new AbortController,n=a.onChange({rawTableNames:!0,signal:e.signal});return(async()=>{for await(const t of n)o&&g(t.changedTables,o)})(),o=t,e}),(t=>{o=void 0,t.abort()}),n,s,(()=>0),1,a,"getPowerSync",_t)}},"object"==typeof exports&&"undefined"!=typeof module?a(exports):"function"==typeof define&&define.amd?define(["exports"],a):a((t="undefined"!=typeof globalThis?globalThis:t||self).TinyBasePersisterPowersync={});
|
|
1
|
+
var t,a;t=this,a=function(t){"use strict";const a=t=>typeof t,e="tinybase",n="",s=",",o=a(n),r=Promise,i=clearInterval,c=t=>null==t,l=(t,a,e)=>c(t)?e?.():a(t),y=t=>a(t)==o,u=t=>Array.isArray(t),w=(t,a,e)=>t.slice(a,e),d=t=>t.length,E=async t=>r.all(t),p=t=>{throw Error(t)},f=(t,a)=>t.forEach(a),v=(t,a="")=>t.join(a),g=(t,a)=>t.map(a),h=t=>0==d(t),A=(t,a)=>t.filter(a),T=(t,...a)=>t.push(...a),m=t=>t.shift(),N=Object,S=t=>N.getPrototypeOf(t),b=N.entries,C=N.keys,$=N.freeze,O=(t=[])=>N.fromEntries(t),I=(...t)=>N.assign({},...t),L=(t,a)=>(delete t[a],t),R=(t,a)=>g(b(t),(([t,e])=>a(e,t))),D=t=>N.values(t),P=t=>d(C(t)),M=t=>(t=>!c(t)&&l(S(t),(t=>t==N.prototype||c(S(t))),(()=>!0)))(t)&&0==P(t),_=t=>new Set(u(t)||c(t)?t:[t]),F=(t,a)=>t?.add(a),x="_",U="_id",j="SELECT",B="WHERE",H="TABLE",J="ALTER "+H,Y="DELETE FROM",k=j+"*FROM",z="pragma_",G="data_version",V="schema_version",W="pragma_table_",K=t=>`"${t.replace(/"/g,'""')}"`,Q=(...t)=>v(g(t,K),s),X=(t,a=[1])=>v(g(t,(()=>"$"+a[0]++)),s),q=(t,a)=>t?.has(a)??!1,Z=t=>c(t)||0==(t=>t?.size??0)(t),tt=t=>[...t?.values()??[]],at=(t,a)=>t?.forEach(a),et=(t,a)=>t?.delete(a),nt=JSON.stringify,st=JSON.parse,ot=t=>new Map(t),rt=(t,a)=>t?.get(a),it=(t,a)=>g([...t?.entries()??[]],(([t,e])=>a(e,t))),ct=(t,a,e)=>c(e)?(et(t,a),t):t?.set(a,e),lt=(t,a,e,n)=>(q(t,a)?n?.(rt(t,a)):ct(t,a,e()),rt(t,a)),yt=(t,a,e,n,s=0)=>l((e?lt:rt)(t,a[s],s>d(a)-2?e:ot),(o=>{if(s>d(a)-2)return n?.(o)&&ct(t,a[s]),o;const r=yt(o,a,e,n,s+1);return Z(o)&&ct(t,a[s]),r})),ut=/^\d+$/,wt=ot(),dt=ot(),Et=(t,a,e,s,o,r,i,y={},w=[])=>{let E,v,g,h=0,A=0,N=0;lt(wt,w,(()=>0)),lt(dt,w,(()=>[]));const S=ot(),[b,C,O,I,L]=((t=1,a)=>1!=t&&a.isMergeable()?[1,a.getMergeableContent,a.getTransactionMergeableChanges,([[t],[a]])=>!M(t)||!M(a),a.setDefaultContent]:2!=t?[0,a.getContent,a.getTransactionChanges,([t,a])=>!M(t)||!M(a),a.setContent]:p("Store type not supported by this Persister"))(i,t),[R,D,P]=(()=>{let t;const[a,e]=(()=>{const t=[];let a=0;return[e=>(e?m(t):null)??n+a++,a=>{ut.test(a)&&d(t)<1e3&&T(t,a)}]})(),s=ot();return[(e,o,r,i=[],c=()=>[])=>{t??=k;const l=a(1);return ct(s,l,[e,o,r,i,c]),F(yt(o,r??[n],_),l),l},(a,e,...o)=>f(((t,a=[n])=>{const e=[],s=(t,n)=>n==d(a)?T(e,t):null===a[n]?at(t,(t=>s(t,n+1))):f([a[n],null],(a=>s(rt(t,a),n+1)));return s(t,0),e})(a,e),(a=>at(a,(a=>rt(s,a)[0](t,...e??[],...o))))),t=>l(rt(s,t),(([,a,o])=>(yt(a,o??[n],void 0,(a=>(et(a,t),Z(a)?1:0))),ct(s,t),e(t),o))),a=>l(rt(s,a),(([a,,e=[],n,s])=>{const o=(...r)=>{const i=d(r);i==d(e)?a(t,...r,...s(r)):c(e[i])?f(n[i]?.(...r)??[],(t=>o(...r,t))):o(...r,e[i])};o()}))]})(),x=t=>{t!=h&&(h=t,D(S,void 0,h))},U=a=>{(b&&u(a?.[0])?1===a?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===a?.[2]?t.applyChanges:t.setContent)(a)},j=async t=>(2!=h&&(x(1),A++,await Y((async()=>{try{const e=await a();u(e)?U(e):t?L(t):p("Content is not an array: "+e)}catch(a){r?.(a),t&&L(t)}x(0)}))),k),B=()=>(v&&(o(v),v=void 0),k),H=async t=>(1!=h&&(x(2),N++,await Y((async()=>{try{await e(C,t)}catch(t){r?.(t)}x(0)}))),k),J=()=>(l(g,t.delListener),g=void 0,k),Y=async(...t)=>(T(rt(dt,w),...t),await(async()=>{if(!rt(wt,w)){for(ct(wt,w,1);!c(E=m(rt(dt,w)));)try{await E()}catch(t){r?.(t)}ct(wt,w,0)}})(),k),k={load:j,startAutoLoad:async t=>{await B().load(t);try{v=await s((async(t,a)=>{a||t?2!=h&&(x(1),A++,U(a??t),x(0)):await j()}))}catch(t){r?.(t)}return k},stopAutoLoad:B,isAutoLoading:()=>!c(v),save:H,startAutoSave:async()=>(await J().save(),g=t.addDidFinishTransactionListener((()=>{const t=O();I(t)&&H(t)})),k),stopAutoSave:J,isAutoSaving:()=>!c(g),getStatus:()=>h,addStatusListener:t=>R(t,S),delListener:a=>(P(a),t),schedule:Y,getStore:()=>t,destroy:()=>(rt(dt,w).splice(0,void 0),B().stopAutoSave()),getStats:()=>({loads:A,saves:N}),...y};return $(k)},pt=(t,a,e,n,o,r=ft,i,l)=>{const y=ot();return[async()=>{y.clear(),g(await e(t,a),(({tn:t,cn:a})=>F(lt(y,t,_),a)))},async(a,e)=>((t,a)=>q(rt(y,t),a))(a,e)?O(A(g(await t(k+K(a)),(t=>{return[t[e],l?(a=L(t,e),n=l,O(R(a,((t,a)=>[a,n(t,a)])))):L(t,e)];var a,n})),(([t,a])=>!c(t)&&!M(a)))):{},async(a,e,n,l,u,w=!1)=>{const d=_();R(n??{},(t=>g(C(t??{}),(t=>F(d,t)))));const p=tt(d);if(!w&&u&&h(p)&&q(y,a))return await t("DROP "+H+K(a)),void ct(y,a);const f=rt(y,a),m=_(tt(f));if(h(p)||(q(y,a)?await E(g([e,...p],(async(n,s)=>{et(m,n)||(await t(J+K(a)+"ADD"+K(n)+o),0==s&&await t("CREATE UNIQUE INDEX pk ON "+K(a)+`(${K(e)})`),F(f,n))}))):(await t("CREATE "+H+K(a)+`(${K(e)}${o} PRIMARY KEY${v(g(p,(t=>s+K(t)+o)))});`),ct(y,a,_([e,...p])))),await E([...!w&&l?g(tt(m),(async n=>{n!=e&&(await t(J+K(a)+"DROP"+K(n)),et(f,n))})):[]]),w)c(n)?await t(Y+K(a)+B+" true"):await E(R(n,(async(n,s)=>{c(n)?await t(Y+K(a)+B+K(e)+"=$1",[s]):h(p)||await r(t,a,e,C(n),{[s]:i?g(D(n),i):D(n)},f)})));else if(h(p))q(y,a)&&await t(Y+K(a)+B+" true");else{const s=A(tt(rt(y,a)),(t=>t!=e)),o={},c=[];R(n??{},((t,a)=>{o[a]=g(s,(a=>i?i(t?.[a]):t?.[a])),T(c,a)})),await r(t,a,e,s,o),await t(Y+K(a)+B+K(e)+`NOT IN(${X(c)})`,c)}},async a=>{let e;await t("BEGIN");try{e=await a()}catch(t){n?.(t)}return await t("END"),e}]},ft=async(t,a,e,n,o)=>{const r=[1];await t("INSERT INTO"+K(a)+"("+Q(e,...n)+")VALUES"+v(R(o,(t=>"($"+r[0]+++","+X(t,r)+")")),s)+"ON CONFLICT("+K(e)+")DO UPDATE SET"+v(g(n,(t=>K(t)+"=excluded."+K(t))),s),R(o,((t,a)=>[a,...g(t,(t=>t??null))])).flat())},vt=(t,a,e,n,s,o,r,[i,c,l],y,u,w,d,E,p)=>{const[f,v,g,h]=pt(a,y,u,s,E,p),A=Et(t,(async()=>await h((async()=>{return await f(),t=(await v(i,c))[x]?.[l]??"null",st(t,((t,a)=>""===a?void 0:a));var t}))),(async t=>await h((async()=>{var a;await f(),await g(i,c,{[x]:{[l]:(a=t()??null,nt(a,((t,a)=>void 0===a?"":a)))}},!0,!0)}))),e,n,s,r,{[d]:()=>w,destroy:()=>(A.stopAutoLoad().stopAutoSave(),o(),A)},w);return A},gt=(t,a,e,n,s,o,r,[i,l,[y,u,w]],d,p,f,v,g,h,T,m)=>{const[N,S,b,C]=pt(a,d,p,s,g,h,T,m),$=async(t,a)=>await E(it(l,(async([e,n,s,o],r)=>{a&&!(r in t)||await b(e,n,t[r],s,o,a)}))),I=async(t,a)=>u?await b(w,U,{[x]:t},!0,!0,a):null,L=Et(t,(async()=>await C((async()=>{await N();const t=await(async()=>O(A(await E(it(i,(async([t,a],e)=>[t,await S(e,a)]))),(t=>!M(t[1])))))(),a=await(async()=>y?(await S(w,U))[x]:{})();return M(t)&&c(a)?void 0:[t,a]}))),(async(t,a)=>await C((async()=>{if(await N(),c(a)){const[a,e]=t();await $(a),await I(e)}else await $(a[0],!0),await I(a[1],!0)}))),e,n,s,r,{[v]:()=>f,destroy:()=>(L.stopAutoLoad().stopAutoSave(),o(),L)},f);return L},ht="ColumnName",At="store",Tt="json",mt=At+"TableName",Nt=At+"Id"+ht,St=At+ht,bt="autoLoadIntervalSeconds",Ct="rowId"+ht,$t="tableId",Ot="tableName",It="deleteEmptyColumns",Lt="deleteEmptyTable",Rt={mode:Tt,[bt]:1},Dt={load:0,save:0,[Ot]:e+"_values"},Pt=(t,a,e,n,s)=>{const o=ot();return R(t,((t,r)=>{const i=w(D(I(a,y(t)?{[e]:t}:t)),0,P(a));c(i[0])||n(r,i[0])||(s(r,i[0]),ct(o,r,i))})),o},Mt=(t,a,s,o,r,c,l,u,d,E,p="getDb",f)=>{let v,g,h;const A=((t,a)=>a?async(e,n)=>(a(e,n),await t(e,n)):t)(s,c),[T,m,N,S]=(t=>{const a=(t=>I(Rt,y(t)?{[mt]:t}:t??{}))(t),n=a[bt];if(a.mode==Tt){const t=a[mt]??e;return[1,n,[t,a[Nt]??U,a[St]??At],_(t)]}const{tables:{load:s={},save:o={}}={},values:r={}}=a,i=w(D(I(Dt,r)),0,P(Dt)),c=i[2],l=_(c),u=_(c);return[0,n,[Pt(s,{[$t]:null,[Ct]:U},$t,(t=>q(u,t)),(t=>F(l,t))),Pt(o,{[Ot]:null,[Ct]:U,[It]:0,[Lt]:0},Ot,((t,a)=>q(u,a)),((t,a)=>F(l,a))),i],l]})(a);return(T?vt:gt)(t,A,(t=>{let a;const e=()=>a=setInterval((async()=>{try{const[{d:a,s:e,c:n}]=await A(`${j} ${G} d,${V} s,TOTAL_CHANGES() c FROM ${z}${G} JOIN ${z}${V}`);a==v&&e==g&&n==h||(null!=v&&t(),v=a,g=e,h=n)}catch{}}),1e3*m),n=()=>{v=g=h=null,i(a)},s=o((a=>{S.has(a)&&(n(),t(),e())}));return e(),()=>{n(),r(s)}}),(t=>t()),l,u,d,N,tt(S),(async(t,a)=>await t(`${j} t.name tn,c.name cn FROM ${W}list()t,${W}info(t.name)c ${B} t.schema='main'AND t.type IN('table','view')AND t.name IN(${X(a)})ORDER BY t.name,c.name`,a)),E,p,n,f,(t=>!0===t?1:!1===t?0:t),void 0)},_t=async(t,a,e,n,o,r)=>{const i=[1],c=_(n),l=r?A([...r],(t=>t!=e&&!q(c,t))):[];if(!h(l)){const n=C(o),s=O(g(await t("SELECT"+Q(e,...l)+"FROM"+K(a)+"WHERE"+K(e)+"IN("+X(n)+")",n),(t=>[t[e],t])));f(n,(t=>T(o[t],...g(l,(a=>s?.[t]?.[a]??null)))))}await t("INSERT OR REPLACE INTO"+K(a)+"("+Q(e,...n,...l)+")VALUES"+v(R(o,(t=>"($"+i[0]+++","+X(t,i)+")")),s),R(o,((t,a)=>[a,...g(t,(t=>t??null))])).flat())};t.createPowerSyncPersister=(t,a,e,n,s)=>{let o;return Mt(t,e,(async(t,e=[])=>a.execute(t,e).then((t=>t.rows?._array??[]))),(t=>{const e=new AbortController,n=a.onChange({rawTableNames:!0,signal:e.signal});return(async()=>{for await(const t of n)o&&g(t.changedTables,o)})(),o=t,e}),(t=>{o=void 0,t.abort()}),n,s,(()=>0),1,a,"getPowerSync",_t)}},"object"==typeof exports&&"undefined"!=typeof module?a(exports):"function"==typeof define&&define.amd?define(["exports"],a):a((t="undefined"!=typeof globalThis?globalThis:t||self).TinyBasePersisterPowersync={});
|
|
Binary file
|
|
@@ -1 +1 @@
|
|
|
1
|
-
var t,a;t=this,a=function(t){"use strict";const a=t=>typeof t,e="tinybase",n="",s=",",o=a(n),r=Promise,i=clearInterval,c=t=>null==t,l=(t,a,e)=>c(t)?e?.():a(t),y=t=>a(t)==o,u=t=>Array.isArray(t),w=(t,a,e)=>t.slice(a,e),d=t=>t.length,E=async t=>r.all(t),p=t=>{throw Error(t)},f=(t,a)=>t.forEach(a),v=(t,a="")=>t.join(a),g=(t,a)=>t.map(a),h=t=>0==d(t),A=(t,a)=>t.filter(a),T=(t,...a)=>t.push(...a),m=t=>t.shift(),N=Object,S=t=>N.getPrototypeOf(t),b=N.entries,C=N.keys,$=N.freeze,O=(t=[])=>N.fromEntries(t),I=(...t)=>N.assign({},...t),L=(t,a)=>(delete t[a],t),R=(t,a)=>g(b(t),(([t,e])=>a(e,t))),D=t=>N.values(t),P=t=>d(C(t)),M=t=>(t=>!c(t)&&l(S(t),(t=>t==N.prototype||c(S(t))),(()=>!0)))(t)&&0==P(t),_=t=>new Set(u(t)||c(t)?t:[t]),F=(t,a)=>t?.add(a),x="_",U="_id",j="SELECT",B="WHERE",H="TABLE",J="ALTER "+H,Y="DELETE FROM",k=j+"*FROM",z="pragma_",G="data_version",V="schema_version",W="pragma_table_",K=t=>`"${t.replace(/"/g,'""')}"`,Q=(...t)=>v(g(t,K),s),X=(t,a=[1])=>v(g(t,(()=>"$"+a[0]++)),s),q=(t,a)=>t?.has(a)??!1,Z=t=>c(t)||0==(t=>t?.size??0)(t),tt=t=>[...t?.values()??[]],at=(t,a)=>t?.forEach(a),et=(t,a)=>t?.delete(a),nt=JSON.stringify,st=JSON.parse,ot=t=>new Map(t),rt=(t,a)=>t?.get(a),it=(t,a)=>g([...t?.entries()??[]],(([t,e])=>a(e,t))),ct=(t,a,e)=>c(e)?(et(t,a),t):t?.set(a,e),lt=(t,a,e,n)=>(q(t,a)?n?.(rt(t,a)):ct(t,a,e()),rt(t,a)),yt=(t,a,e,n,s=0)=>l((e?lt:rt)(t,a[s],s>d(a)-2?e:ot),(o=>{if(s>d(a)-2)return n?.(o)&&ct(t,a[s]),o;const r=yt(o,a,e,n,s+1);return Z(o)&&ct(t,a[s]),r})),ut=/^\d+$/,wt=ot(),dt=ot(),Et=(t,a,e,s,o,r,i,y={},w=[])=>{let E,v,g,h=0,A=0,N=0;lt(wt,w,(()=>0)),lt(dt,w,(()=>[]));const S=ot(),[b,C,O,I,L]=((t=1,a)=>1!=t&&a.isMergeable()?[1,a.getMergeableContent,a.getTransactionMergeableChanges,([[t],[a]])=>!M(t)||!M(a),a.setDefaultContent]:2!=t?[0,a.getContent,a.getTransactionChanges,([t,a])=>!M(t)||!M(a),a.setContent]:p("Store type not supported by this Persister"))(i,t),[R,D,P]=(()=>{let t;const[a,e]=(()=>{const t=[];let a=0;return[e=>(e?m(t):null)??n+a++,a=>{ut.test(a)&&d(t)<1e3&&T(t,a)}]})(),s=ot();return[(e,o,r,i=[],c=()=>[])=>{t??=k;const l=a(1);return ct(s,l,[e,o,r,i,c]),F(yt(o,r??[n],_),l),l},(a,e,...o)=>f(((t,a=[n])=>{const e=[],s=(t,n)=>n==d(a)?T(e,t):null===a[n]?at(t,(t=>s(t,n+1))):f([a[n],null],(a=>s(rt(t,a),n+1)));return s(t,0),e})(a,e),(a=>at(a,(a=>rt(s,a)[0](t,...e??[],...o))))),t=>l(rt(s,t),(([,a,o])=>(yt(a,o??[n],void 0,(a=>(et(a,t),Z(a)?1:0))),ct(s,t),e(t),o))),a=>l(rt(s,a),(([a,,e=[],n,s])=>{const o=(...r)=>{const i=d(r);i==d(e)?a(t,...r,...s(r)):c(e[i])?f(n[i]?.(...r)??[],(t=>o(...r,t))):o(...r,e[i])};o()}))]})(),x=t=>{t!=h&&(h=t,D(S,void 0,h))},U=a=>{(b&&u(a?.[0])?1===a?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===a?.[2]?t.applyChanges:t.setContent)(a)},j=async t=>(2!=h&&(x(1),A++,await Y((async()=>{try{const e=await a();u(e)?U(e):t?L(t):p("Content is not an array "+e)}catch(a){r?.(a),t&&L(t)}x(0)}))),k),B=()=>(v&&(o(v),v=void 0),k),H=async t=>(1!=h&&(x(2),N++,await Y((async()=>{try{await e(C,t)}catch(t){r?.(t)}x(0)}))),k),J=()=>(l(g,t.delListener),g=void 0,k),Y=async(...t)=>(T(rt(dt,w),...t),await(async()=>{if(!rt(wt,w)){for(ct(wt,w,1);!c(E=m(rt(dt,w)));)try{await E()}catch(t){r?.(t)}ct(wt,w,0)}})(),k),k={load:j,startAutoLoad:async t=>{await B().load(t);try{v=await s((async(t,a)=>{a||t?2!=h&&(x(1),A++,U(a??t),x(0)):await j()}))}catch(t){r?.(t)}return k},stopAutoLoad:B,isAutoLoading:()=>!c(v),save:H,startAutoSave:async()=>(await J().save(),g=t.addDidFinishTransactionListener((()=>{const t=O();I(t)&&H(t)})),k),stopAutoSave:J,isAutoSaving:()=>!c(g),getStatus:()=>h,addStatusListener:t=>R(t,S),delListener:a=>(P(a),t),schedule:Y,getStore:()=>t,destroy:()=>(rt(dt,w).splice(0,void 0),B().stopAutoSave()),getStats:()=>({loads:A,saves:N}),...y};return $(k)},pt=(t,a,e,n,o,r=ft,i,l)=>{const y=ot();return[async()=>{y.clear(),g(await e(t,a),(({tn:t,cn:a})=>F(lt(y,t,_),a)))},async(a,e)=>((t,a)=>q(rt(y,t),a))(a,e)?O(A(g(await t(k+K(a)),(t=>{return[t[e],l?(a=L(t,e),n=l,O(R(a,((t,a)=>[a,n(t,a)])))):L(t,e)];var a,n})),(([t,a])=>!c(t)&&!M(a)))):{},async(a,e,n,l,u,w=!1)=>{const d=_();R(n??{},(t=>g(C(t??{}),(t=>F(d,t)))));const p=tt(d);if(!w&&u&&h(p)&&q(y,a))return await t("DROP "+H+K(a)),void ct(y,a);const f=rt(y,a),m=_(tt(f));if(h(p)||(q(y,a)?await E(g([e,...p],(async(n,s)=>{et(m,n)||(await t(J+K(a)+"ADD"+K(n)+o),0==s&&await t("CREATE UNIQUE INDEX pk ON "+K(a)+`(${K(e)})`),F(f,n))}))):(await t("CREATE "+H+K(a)+`(${K(e)}${o} PRIMARY KEY${v(g(p,(t=>s+K(t)+o)))});`),ct(y,a,_([e,...p])))),await E([...!w&&l?g(tt(m),(async n=>{n!=e&&(await t(J+K(a)+"DROP"+K(n)),et(f,n))})):[]]),w)c(n)?await t(Y+K(a)+B+" true"):await E(R(n,(async(n,s)=>{c(n)?await t(Y+K(a)+B+K(e)+"=$1",[s]):h(p)||await r(t,a,e,C(n),{[s]:i?g(D(n),i):D(n)},f)})));else if(h(p))q(y,a)&&await t(Y+K(a)+B+" true");else{const s=A(tt(rt(y,a)),(t=>t!=e)),o={},c=[];R(n??{},((t,a)=>{o[a]=g(s,(a=>i?i(t?.[a]):t?.[a])),T(c,a)})),await r(t,a,e,s,o),await t(Y+K(a)+B+K(e)+`NOT IN(${X(c)})`,c)}},async a=>{let e;await t("BEGIN");try{e=await a()}catch(t){n?.(t)}return await t("END"),e}]},ft=async(t,a,e,n,o)=>{const r=[1];await t("INSERT INTO"+K(a)+"("+Q(e,...n)+")VALUES"+v(R(o,(t=>"($"+r[0]+++","+X(t,r)+")")),s)+"ON CONFLICT("+K(e)+")DO UPDATE SET"+v(g(n,(t=>K(t)+"=excluded."+K(t))),s),R(o,((t,a)=>[a,...g(t,(t=>t??null))])).flat())},vt=(t,a,e,n,s,o,r,[i,c,l],y,u,w,d,E,p)=>{const[f,v,g,h]=pt(a,y,u,s,E,p),A=Et(t,(async()=>await h((async()=>{return await f(),t=(await v(i,c))[x]?.[l]??"null",st(t,((t,a)=>""===a?void 0:a));var t}))),(async t=>await h((async()=>{var a;await f(),await g(i,c,{[x]:{[l]:(a=t()??null,nt(a,((t,a)=>void 0===a?"":a)))}},!0,!0)}))),e,n,s,r,{[d]:()=>w,destroy:()=>(A.stopAutoLoad().stopAutoSave(),o(),A)},w);return A},gt=(t,a,e,n,s,o,r,[i,l,[y,u,w]],d,p,f,v,g,h,T,m)=>{const[N,S,b,C]=pt(a,d,p,s,g,h,T,m),$=async(t,a)=>await E(it(l,(async([e,n,s,o],r)=>{a&&!(r in t)||await b(e,n,t[r],s,o,a)}))),I=async(t,a)=>u?await b(w,U,{[x]:t},!0,!0,a):null,L=Et(t,(async()=>await C((async()=>{await N();const t=await(async()=>O(A(await E(it(i,(async([t,a],e)=>[t,await S(e,a)]))),(t=>!M(t[1])))))(),a=await(async()=>y?(await S(w,U))[x]:{})();return M(t)&&c(a)?void 0:[t,a]}))),(async(t,a)=>await C((async()=>{if(await N(),c(a)){const[a,e]=t();await $(a),await I(e)}else await $(a[0],!0),await I(a[1],!0)}))),e,n,s,r,{[v]:()=>f,destroy:()=>(L.stopAutoLoad().stopAutoSave(),o(),L)},f);return L},ht="ColumnName",At="store",Tt="json",mt=At+"TableName",Nt=At+"Id"+ht,St=At+ht,bt="autoLoadIntervalSeconds",Ct="rowId"+ht,$t="tableId",Ot="tableName",It="deleteEmptyColumns",Lt="deleteEmptyTable",Rt={mode:Tt,[bt]:1},Dt={load:0,save:0,[Ot]:e+"_values"},Pt=(t,a,e,n,s)=>{const o=ot();return R(t,((t,r)=>{const i=w(D(I(a,y(t)?{[e]:t}:t)),0,P(a));c(i[0])||n(r,i[0])||(s(r,i[0]),ct(o,r,i))})),o},Mt=(t,a,s,o,r,c,l,u,d,E,p="getDb",f)=>{let v,g,h;const A=((t,a)=>a?async(e,n)=>(a(e,n),await t(e,n)):t)(s,c),[T,m,N,S]=(t=>{const a=(t=>I(Rt,y(t)?{[mt]:t}:t??{}))(t),n=a[bt];if(a.mode==Tt){const t=a[mt]??e;return[1,n,[t,a[Nt]??U,a[St]??At],_(t)]}const{tables:{load:s={},save:o={}}={},values:r={}}=a,i=w(D(I(Dt,r)),0,P(Dt)),c=i[2],l=_(c),u=_(c);return[0,n,[Pt(s,{[$t]:null,[Ct]:U},$t,(t=>q(u,t)),(t=>F(l,t))),Pt(o,{[Ot]:null,[Ct]:U,[It]:0,[Lt]:0},Ot,((t,a)=>q(u,a)),((t,a)=>F(l,a))),i],l]})(a);return(T?vt:gt)(t,A,(t=>{let a;const e=()=>a=setInterval((async()=>{try{const[{d:a,s:e,c:n}]=await A(`${j} ${G} d,${V} s,TOTAL_CHANGES() c FROM ${z}${G} JOIN ${z}${V}`);a==v&&e==g&&n==h||(null!=v&&t(),v=a,g=e,h=n)}catch{}}),1e3*m),n=()=>{v=g=h=null,i(a)},s=o((a=>{S.has(a)&&(n(),t(),e())}));return e(),()=>{n(),r(s)}}),(t=>t()),l,u,d,N,tt(S),(async(t,a)=>await t(`${j} t.name tn,c.name cn FROM ${W}list()t,${W}info(t.name)c ${B} t.schema='main'AND t.type IN('table','view')AND t.name IN(${X(a)})ORDER BY t.name,c.name`,a)),E,p,n,f,(t=>!0===t?1:!1===t?0:t),void 0)},_t=async(t,a,e,n,o,r)=>{const i=[1],c=_(n),l=r?A([...r],(t=>t!=e&&!q(c,t))):[];if(!h(l)){const n=C(o),s=O(g(await t("SELECT"+Q(e,...l)+"FROM"+K(a)+"WHERE"+K(e)+"IN("+X(n)+")",n),(t=>[t[e],t])));f(n,(t=>T(o[t],...g(l,(a=>s?.[t]?.[a]??null)))))}await t("INSERT OR REPLACE INTO"+K(a)+"("+Q(e,...n,...l)+")VALUES"+v(R(o,(t=>"($"+i[0]+++","+X(t,i)+")")),s),R(o,((t,a)=>[a,...g(t,(t=>t??null))])).flat())};t.createPowerSyncPersister=(t,a,e,n,s)=>{let o;return Mt(t,e,(async(t,e=[])=>a.execute(t,e).then((t=>t.rows?._array??[]))),(t=>{const e=new AbortController,n=a.onChange({rawTableNames:!0,signal:e.signal});return(async()=>{for await(const t of n)o&&g(t.changedTables,o)})(),o=t,e}),(t=>{o=void 0,t.abort()}),n,s,(()=>0),1,a,"getPowerSync",_t)}},"object"==typeof exports&&"undefined"!=typeof module?a(exports):"function"==typeof define&&define.amd?define(["exports"],a):a((t="undefined"!=typeof globalThis?globalThis:t||self).TinyBasePersisterPowersync={});
|
|
1
|
+
var t,a;t=this,a=function(t){"use strict";const a=t=>typeof t,e="tinybase",n="",s=",",o=a(n),r=Promise,i=clearInterval,c=t=>null==t,l=(t,a,e)=>c(t)?e?.():a(t),y=t=>a(t)==o,u=t=>Array.isArray(t),w=(t,a,e)=>t.slice(a,e),d=t=>t.length,E=async t=>r.all(t),p=t=>{throw Error(t)},f=(t,a)=>t.forEach(a),v=(t,a="")=>t.join(a),g=(t,a)=>t.map(a),h=t=>0==d(t),A=(t,a)=>t.filter(a),T=(t,...a)=>t.push(...a),m=t=>t.shift(),N=Object,S=t=>N.getPrototypeOf(t),b=N.entries,C=N.keys,$=N.freeze,O=(t=[])=>N.fromEntries(t),I=(...t)=>N.assign({},...t),L=(t,a)=>(delete t[a],t),R=(t,a)=>g(b(t),(([t,e])=>a(e,t))),D=t=>N.values(t),P=t=>d(C(t)),M=t=>(t=>!c(t)&&l(S(t),(t=>t==N.prototype||c(S(t))),(()=>!0)))(t)&&0==P(t),_=t=>new Set(u(t)||c(t)?t:[t]),F=(t,a)=>t?.add(a),x="_",U="_id",j="SELECT",B="WHERE",H="TABLE",J="ALTER "+H,Y="DELETE FROM",k=j+"*FROM",z="pragma_",G="data_version",V="schema_version",W="pragma_table_",K=t=>`"${t.replace(/"/g,'""')}"`,Q=(...t)=>v(g(t,K),s),X=(t,a=[1])=>v(g(t,(()=>"$"+a[0]++)),s),q=(t,a)=>t?.has(a)??!1,Z=t=>c(t)||0==(t=>t?.size??0)(t),tt=t=>[...t?.values()??[]],at=(t,a)=>t?.forEach(a),et=(t,a)=>t?.delete(a),nt=JSON.stringify,st=JSON.parse,ot=t=>new Map(t),rt=(t,a)=>t?.get(a),it=(t,a)=>g([...t?.entries()??[]],(([t,e])=>a(e,t))),ct=(t,a,e)=>c(e)?(et(t,a),t):t?.set(a,e),lt=(t,a,e,n)=>(q(t,a)?n?.(rt(t,a)):ct(t,a,e()),rt(t,a)),yt=(t,a,e,n,s=0)=>l((e?lt:rt)(t,a[s],s>d(a)-2?e:ot),(o=>{if(s>d(a)-2)return n?.(o)&&ct(t,a[s]),o;const r=yt(o,a,e,n,s+1);return Z(o)&&ct(t,a[s]),r})),ut=/^\d+$/,wt=ot(),dt=ot(),Et=(t,a,e,s,o,r,i,y={},w=[])=>{let E,v,g,h=0,A=0,N=0;lt(wt,w,(()=>0)),lt(dt,w,(()=>[]));const S=ot(),[b,C,O,I,L]=((t=1,a)=>1!=t&&a.isMergeable()?[1,a.getMergeableContent,a.getTransactionMergeableChanges,([[t],[a]])=>!M(t)||!M(a),a.setDefaultContent]:2!=t?[0,a.getContent,a.getTransactionChanges,([t,a])=>!M(t)||!M(a),a.setContent]:p("Store type not supported by this Persister"))(i,t),[R,D,P]=(()=>{let t;const[a,e]=(()=>{const t=[];let a=0;return[e=>(e?m(t):null)??n+a++,a=>{ut.test(a)&&d(t)<1e3&&T(t,a)}]})(),s=ot();return[(e,o,r,i=[],c=()=>[])=>{t??=k;const l=a(1);return ct(s,l,[e,o,r,i,c]),F(yt(o,r??[n],_),l),l},(a,e,...o)=>f(((t,a=[n])=>{const e=[],s=(t,n)=>n==d(a)?T(e,t):null===a[n]?at(t,(t=>s(t,n+1))):f([a[n],null],(a=>s(rt(t,a),n+1)));return s(t,0),e})(a,e),(a=>at(a,(a=>rt(s,a)[0](t,...e??[],...o))))),t=>l(rt(s,t),(([,a,o])=>(yt(a,o??[n],void 0,(a=>(et(a,t),Z(a)?1:0))),ct(s,t),e(t),o))),a=>l(rt(s,a),(([a,,e=[],n,s])=>{const o=(...r)=>{const i=d(r);i==d(e)?a(t,...r,...s(r)):c(e[i])?f(n[i]?.(...r)??[],(t=>o(...r,t))):o(...r,e[i])};o()}))]})(),x=t=>{t!=h&&(h=t,D(S,void 0,h))},U=a=>{(b&&u(a?.[0])?1===a?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===a?.[2]?t.applyChanges:t.setContent)(a)},j=async t=>(2!=h&&(x(1),A++,await Y((async()=>{try{const e=await a();u(e)?U(e):t?L(t):p("Content is not an array: "+e)}catch(a){r?.(a),t&&L(t)}x(0)}))),k),B=()=>(v&&(o(v),v=void 0),k),H=async t=>(1!=h&&(x(2),N++,await Y((async()=>{try{await e(C,t)}catch(t){r?.(t)}x(0)}))),k),J=()=>(l(g,t.delListener),g=void 0,k),Y=async(...t)=>(T(rt(dt,w),...t),await(async()=>{if(!rt(wt,w)){for(ct(wt,w,1);!c(E=m(rt(dt,w)));)try{await E()}catch(t){r?.(t)}ct(wt,w,0)}})(),k),k={load:j,startAutoLoad:async t=>{await B().load(t);try{v=await s((async(t,a)=>{a||t?2!=h&&(x(1),A++,U(a??t),x(0)):await j()}))}catch(t){r?.(t)}return k},stopAutoLoad:B,isAutoLoading:()=>!c(v),save:H,startAutoSave:async()=>(await J().save(),g=t.addDidFinishTransactionListener((()=>{const t=O();I(t)&&H(t)})),k),stopAutoSave:J,isAutoSaving:()=>!c(g),getStatus:()=>h,addStatusListener:t=>R(t,S),delListener:a=>(P(a),t),schedule:Y,getStore:()=>t,destroy:()=>(rt(dt,w).splice(0,void 0),B().stopAutoSave()),getStats:()=>({loads:A,saves:N}),...y};return $(k)},pt=(t,a,e,n,o,r=ft,i,l)=>{const y=ot();return[async()=>{y.clear(),g(await e(t,a),(({tn:t,cn:a})=>F(lt(y,t,_),a)))},async(a,e)=>((t,a)=>q(rt(y,t),a))(a,e)?O(A(g(await t(k+K(a)),(t=>{return[t[e],l?(a=L(t,e),n=l,O(R(a,((t,a)=>[a,n(t,a)])))):L(t,e)];var a,n})),(([t,a])=>!c(t)&&!M(a)))):{},async(a,e,n,l,u,w=!1)=>{const d=_();R(n??{},(t=>g(C(t??{}),(t=>F(d,t)))));const p=tt(d);if(!w&&u&&h(p)&&q(y,a))return await t("DROP "+H+K(a)),void ct(y,a);const f=rt(y,a),m=_(tt(f));if(h(p)||(q(y,a)?await E(g([e,...p],(async(n,s)=>{et(m,n)||(await t(J+K(a)+"ADD"+K(n)+o),0==s&&await t("CREATE UNIQUE INDEX pk ON "+K(a)+`(${K(e)})`),F(f,n))}))):(await t("CREATE "+H+K(a)+`(${K(e)}${o} PRIMARY KEY${v(g(p,(t=>s+K(t)+o)))});`),ct(y,a,_([e,...p])))),await E([...!w&&l?g(tt(m),(async n=>{n!=e&&(await t(J+K(a)+"DROP"+K(n)),et(f,n))})):[]]),w)c(n)?await t(Y+K(a)+B+" true"):await E(R(n,(async(n,s)=>{c(n)?await t(Y+K(a)+B+K(e)+"=$1",[s]):h(p)||await r(t,a,e,C(n),{[s]:i?g(D(n),i):D(n)},f)})));else if(h(p))q(y,a)&&await t(Y+K(a)+B+" true");else{const s=A(tt(rt(y,a)),(t=>t!=e)),o={},c=[];R(n??{},((t,a)=>{o[a]=g(s,(a=>i?i(t?.[a]):t?.[a])),T(c,a)})),await r(t,a,e,s,o),await t(Y+K(a)+B+K(e)+`NOT IN(${X(c)})`,c)}},async a=>{let e;await t("BEGIN");try{e=await a()}catch(t){n?.(t)}return await t("END"),e}]},ft=async(t,a,e,n,o)=>{const r=[1];await t("INSERT INTO"+K(a)+"("+Q(e,...n)+")VALUES"+v(R(o,(t=>"($"+r[0]+++","+X(t,r)+")")),s)+"ON CONFLICT("+K(e)+")DO UPDATE SET"+v(g(n,(t=>K(t)+"=excluded."+K(t))),s),R(o,((t,a)=>[a,...g(t,(t=>t??null))])).flat())},vt=(t,a,e,n,s,o,r,[i,c,l],y,u,w,d,E,p)=>{const[f,v,g,h]=pt(a,y,u,s,E,p),A=Et(t,(async()=>await h((async()=>{return await f(),t=(await v(i,c))[x]?.[l]??"null",st(t,((t,a)=>""===a?void 0:a));var t}))),(async t=>await h((async()=>{var a;await f(),await g(i,c,{[x]:{[l]:(a=t()??null,nt(a,((t,a)=>void 0===a?"":a)))}},!0,!0)}))),e,n,s,r,{[d]:()=>w,destroy:()=>(A.stopAutoLoad().stopAutoSave(),o(),A)},w);return A},gt=(t,a,e,n,s,o,r,[i,l,[y,u,w]],d,p,f,v,g,h,T,m)=>{const[N,S,b,C]=pt(a,d,p,s,g,h,T,m),$=async(t,a)=>await E(it(l,(async([e,n,s,o],r)=>{a&&!(r in t)||await b(e,n,t[r],s,o,a)}))),I=async(t,a)=>u?await b(w,U,{[x]:t},!0,!0,a):null,L=Et(t,(async()=>await C((async()=>{await N();const t=await(async()=>O(A(await E(it(i,(async([t,a],e)=>[t,await S(e,a)]))),(t=>!M(t[1])))))(),a=await(async()=>y?(await S(w,U))[x]:{})();return M(t)&&c(a)?void 0:[t,a]}))),(async(t,a)=>await C((async()=>{if(await N(),c(a)){const[a,e]=t();await $(a),await I(e)}else await $(a[0],!0),await I(a[1],!0)}))),e,n,s,r,{[v]:()=>f,destroy:()=>(L.stopAutoLoad().stopAutoSave(),o(),L)},f);return L},ht="ColumnName",At="store",Tt="json",mt=At+"TableName",Nt=At+"Id"+ht,St=At+ht,bt="autoLoadIntervalSeconds",Ct="rowId"+ht,$t="tableId",Ot="tableName",It="deleteEmptyColumns",Lt="deleteEmptyTable",Rt={mode:Tt,[bt]:1},Dt={load:0,save:0,[Ot]:e+"_values"},Pt=(t,a,e,n,s)=>{const o=ot();return R(t,((t,r)=>{const i=w(D(I(a,y(t)?{[e]:t}:t)),0,P(a));c(i[0])||n(r,i[0])||(s(r,i[0]),ct(o,r,i))})),o},Mt=(t,a,s,o,r,c,l,u,d,E,p="getDb",f)=>{let v,g,h;const A=((t,a)=>a?async(e,n)=>(a(e,n),await t(e,n)):t)(s,c),[T,m,N,S]=(t=>{const a=(t=>I(Rt,y(t)?{[mt]:t}:t??{}))(t),n=a[bt];if(a.mode==Tt){const t=a[mt]??e;return[1,n,[t,a[Nt]??U,a[St]??At],_(t)]}const{tables:{load:s={},save:o={}}={},values:r={}}=a,i=w(D(I(Dt,r)),0,P(Dt)),c=i[2],l=_(c),u=_(c);return[0,n,[Pt(s,{[$t]:null,[Ct]:U},$t,(t=>q(u,t)),(t=>F(l,t))),Pt(o,{[Ot]:null,[Ct]:U,[It]:0,[Lt]:0},Ot,((t,a)=>q(u,a)),((t,a)=>F(l,a))),i],l]})(a);return(T?vt:gt)(t,A,(t=>{let a;const e=()=>a=setInterval((async()=>{try{const[{d:a,s:e,c:n}]=await A(`${j} ${G} d,${V} s,TOTAL_CHANGES() c FROM ${z}${G} JOIN ${z}${V}`);a==v&&e==g&&n==h||(null!=v&&t(),v=a,g=e,h=n)}catch{}}),1e3*m),n=()=>{v=g=h=null,i(a)},s=o((a=>{S.has(a)&&(n(),t(),e())}));return e(),()=>{n(),r(s)}}),(t=>t()),l,u,d,N,tt(S),(async(t,a)=>await t(`${j} t.name tn,c.name cn FROM ${W}list()t,${W}info(t.name)c ${B} t.schema='main'AND t.type IN('table','view')AND t.name IN(${X(a)})ORDER BY t.name,c.name`,a)),E,p,n,f,(t=>!0===t?1:!1===t?0:t),void 0)},_t=async(t,a,e,n,o,r)=>{const i=[1],c=_(n),l=r?A([...r],(t=>t!=e&&!q(c,t))):[];if(!h(l)){const n=C(o),s=O(g(await t("SELECT"+Q(e,...l)+"FROM"+K(a)+"WHERE"+K(e)+"IN("+X(n)+")",n),(t=>[t[e],t])));f(n,(t=>T(o[t],...g(l,(a=>s?.[t]?.[a]??null)))))}await t("INSERT OR REPLACE INTO"+K(a)+"("+Q(e,...n,...l)+")VALUES"+v(R(o,(t=>"($"+i[0]+++","+X(t,i)+")")),s),R(o,((t,a)=>[a,...g(t,(t=>t??null))])).flat())};t.createPowerSyncPersister=(t,a,e,n,s)=>{let o;return Mt(t,e,(async(t,e=[])=>a.execute(t,e).then((t=>t.rows?._array??[]))),(t=>{const e=new AbortController,n=a.onChange({rawTableNames:!0,signal:e.signal});return(async()=>{for await(const t of n)o&&g(t.changedTables,o)})(),o=t,e}),(t=>{o=void 0,t.abort()}),n,s,(()=>0),1,a,"getPowerSync",_t)}},"object"==typeof exports&&"undefined"!=typeof module?a(exports):"function"==typeof define&&define.amd?define(["exports"],a):a((t="undefined"!=typeof globalThis?globalThis:t||self).TinyBasePersisterPowersync={});
|
|
Binary file
|
|
@@ -1 +1 @@
|
|
|
1
|
-
var t,e;t=this,e=function(t){"use strict";const e=clearInterval,a=t=>null==t,n=(t,e,n)=>a(t)?n?.():e(t),s=t=>Array.isArray(t),r=t=>t.length,o=t=>{throw Error(t)},i=(t,e)=>t.forEach(e),c=(t,...e)=>t.push(...e),l=t=>t.shift(),d=Object,u=t=>d.getPrototypeOf(t),y=d.keys,h=d.freeze,p=t=>(t=>!a(t)&&n(u(t),(t=>t==d.prototype||a(u(t))),(()=>!0)))(t)&&0==(t=>r(y(t)))(t),f=JSON.stringify,g=JSON.parse,v=t=>a(t)||0==(t=>t?.size??0)(t),w=(t,e)=>t?.forEach(e),S=(t,e)=>t?.delete(e),C=t=>new Map(t),b=(t,e)=>t?.get(e),A=(t,e,n)=>a(n)?(S(t,e),t):t?.set(e,n),T=(t,e,a,n)=>{var s,r;return s=t,r=e,s?.has(r)?n?.(b(t,e)):A(t,e,a()),b(t,e)},m=(t,e,a,s,o=0)=>n((a?T:b)(t,e[o],o>r(e)-2?a:C),(n=>{if(o>r(e)-2)return s?.(n)&&A(t,e[o]),n;const i=m(n,e,a,s,o+1);return v(n)&&A(t,e[o]),i})),L=t=>new Set(s(t)||a(t)?t:[t]),M=/^\d+$/,E=C(),O=C(),P=(t,e,d,u,y,f,g,P={},x=[])=>{let j,D,z,I=0,J=0,N=0;T(E,x,(()=>0)),T(O,x,(()=>[]));const R=C(),[k,B,F,H,U]=((t=1,e)=>1!=t&&e.isMergeable()?[1,e.getMergeableContent,e.getTransactionMergeableChanges,([[t],[e]])=>!p(t)||!p(e),e.setDefaultContent]:2!=t?[0,e.getContent,e.getTransactionChanges,([t,e])=>!p(t)||!p(e),e.setContent]:o("Store type not supported by this Persister"))(g,t),[$,q,G]=(()=>{let t;const[e,s]=(()=>{const t=[];let e=0;return[a=>(a?l(t):null)??""+e++,e=>{M.test(e)&&r(t)<1e3&&c(t,e)}]})(),o=C();return[(a,n,s,r=[],i=()=>[])=>{t??=_;const c=e(1);var l,d;return A(o,c,[a,n,s,r,i]),l=m(n,s??[""],L),d=c,l?.add(d),c},(e,a,...n)=>i(((t,e=[""])=>{const a=[],n=(t,s)=>s==r(e)?c(a,t):null===e[s]?w(t,(t=>n(t,s+1))):i([e[s],null],(e=>n(b(t,e),s+1)));return n(t,0),a})(e,a),(e=>w(e,(e=>b(o,e)[0](t,...a??[],...n))))),t=>n(b(o,t),(([,e,a])=>(m(e,a??[""],void 0,(e=>(S(e,t),v(e)?1:0))),A(o,t),s(t),a))),e=>n(b(o,e),(([e,,n=[],s,o])=>{const c=(...l)=>{const d=r(l);d==r(n)?e(t,...l,...o(l)):a(n[d])?i(s[d]?.(...l)??[],(t=>c(...l,t))):c(...l,n[d])};c()}))]})(),K=t=>{t!=I&&(I=t,q(R,void 0,I))},Q=e=>{(k&&s(e?.[0])?1===e?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===e?.[2]?t.applyChanges:t.setContent)(e)},V=async t=>(2!=I&&(K(1),J++,await Z((async()=>{try{const a=await e();s(a)?Q(a):t?U(t):o("Content is not an array "+a)}catch(e){f?.(e),t&&U(t)}K(0)}))),_),W=()=>(D&&(y(D),D=void 0),_),X=async t=>(1!=I&&(K(2),N++,await Z((async()=>{try{await d(B,t)}catch(t){f?.(t)}K(0)}))),_),Y=()=>(n(z,t.delListener),z=void 0,_),Z=async(...t)=>(c(b(O,x),...t),await(async()=>{if(!b(E,x)){for(A(E,x,1);!a(j=l(b(O,x)));)try{await j()}catch(t){f?.(t)}A(E,x,0)}})(),_),_={load:V,startAutoLoad:async t=>{await W().load(t);try{D=await u((async(t,e)=>{e||t?2!=I&&(K(1),J++,Q(e??t),K(0)):await V()}))}catch(t){f?.(t)}return _},stopAutoLoad:W,isAutoLoading:()=>!a(D),save:X,startAutoSave:async()=>(await Y().save(),z=t.addDidFinishTransactionListener((()=>{const t=F();H(t)&&X(t)})),_),stopAutoSave:Y,isAutoSaving:()=>!a(z),getStatus:()=>I,addStatusListener:t=>$(t,R),delListener:e=>(G(e),t),schedule:Z,getStore:()=>t,destroy:()=>(b(O,x).splice(0,void 0),W().stopAutoSave()),getStats:()=>({loads:J,saves:N}),...P};return h(_)},x=t=>t.headers.get("ETag");t.createRemotePersister=(t,n,s,r=5,o)=>{let i;return P(t,(async()=>{const t=await fetch(n);return i=x(t),g(await t.text())}),(async t=>{return await fetch(s,{method:"POST",headers:{"Content-Type":"application/json"},body:(e=t(),f(e,((t,e)=>e instanceof Map?d.fromEntries([...e]):e)))});var e}),(t=>setInterval((async()=>{const e=await fetch(n,{method:"HEAD"}),s=x(e);a(i)||a(s)||s==i||(i=s,t())}),1e3*r)),(t=>e(t)),o,1,{getUrls:()=>[n,s]})}},"object"==typeof exports&&"undefined"!=typeof module?e(exports):"function"==typeof define&&define.amd?define(["exports"],e):e((t="undefined"!=typeof globalThis?globalThis:t||self).TinyBasePersisterRemote={});
|
|
1
|
+
var t,e;t=this,e=function(t){"use strict";const e=clearInterval,a=t=>null==t,n=(t,e,n)=>a(t)?n?.():e(t),s=t=>Array.isArray(t),r=t=>t.length,o=t=>{throw Error(t)},i=(t,e)=>t.forEach(e),c=(t,...e)=>t.push(...e),l=t=>t.shift(),d=Object,u=t=>d.getPrototypeOf(t),y=d.keys,h=d.freeze,p=t=>(t=>!a(t)&&n(u(t),(t=>t==d.prototype||a(u(t))),(()=>!0)))(t)&&0==(t=>r(y(t)))(t),f=JSON.stringify,g=JSON.parse,v=t=>a(t)||0==(t=>t?.size??0)(t),w=(t,e)=>t?.forEach(e),S=(t,e)=>t?.delete(e),C=t=>new Map(t),b=(t,e)=>t?.get(e),A=(t,e,n)=>a(n)?(S(t,e),t):t?.set(e,n),T=(t,e,a,n)=>{var s,r;return s=t,r=e,s?.has(r)?n?.(b(t,e)):A(t,e,a()),b(t,e)},m=(t,e,a,s,o=0)=>n((a?T:b)(t,e[o],o>r(e)-2?a:C),(n=>{if(o>r(e)-2)return s?.(n)&&A(t,e[o]),n;const i=m(n,e,a,s,o+1);return v(n)&&A(t,e[o]),i})),L=t=>new Set(s(t)||a(t)?t:[t]),M=/^\d+$/,E=C(),O=C(),P=(t,e,d,u,y,f,g,P={},x=[])=>{let j,D,z,I=0,J=0,N=0;T(E,x,(()=>0)),T(O,x,(()=>[]));const R=C(),[k,B,F,H,U]=((t=1,e)=>1!=t&&e.isMergeable()?[1,e.getMergeableContent,e.getTransactionMergeableChanges,([[t],[e]])=>!p(t)||!p(e),e.setDefaultContent]:2!=t?[0,e.getContent,e.getTransactionChanges,([t,e])=>!p(t)||!p(e),e.setContent]:o("Store type not supported by this Persister"))(g,t),[$,q,G]=(()=>{let t;const[e,s]=(()=>{const t=[];let e=0;return[a=>(a?l(t):null)??""+e++,e=>{M.test(e)&&r(t)<1e3&&c(t,e)}]})(),o=C();return[(a,n,s,r=[],i=()=>[])=>{t??=_;const c=e(1);var l,d;return A(o,c,[a,n,s,r,i]),l=m(n,s??[""],L),d=c,l?.add(d),c},(e,a,...n)=>i(((t,e=[""])=>{const a=[],n=(t,s)=>s==r(e)?c(a,t):null===e[s]?w(t,(t=>n(t,s+1))):i([e[s],null],(e=>n(b(t,e),s+1)));return n(t,0),a})(e,a),(e=>w(e,(e=>b(o,e)[0](t,...a??[],...n))))),t=>n(b(o,t),(([,e,a])=>(m(e,a??[""],void 0,(e=>(S(e,t),v(e)?1:0))),A(o,t),s(t),a))),e=>n(b(o,e),(([e,,n=[],s,o])=>{const c=(...l)=>{const d=r(l);d==r(n)?e(t,...l,...o(l)):a(n[d])?i(s[d]?.(...l)??[],(t=>c(...l,t))):c(...l,n[d])};c()}))]})(),K=t=>{t!=I&&(I=t,q(R,void 0,I))},Q=e=>{(k&&s(e?.[0])?1===e?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===e?.[2]?t.applyChanges:t.setContent)(e)},V=async t=>(2!=I&&(K(1),J++,await Z((async()=>{try{const a=await e();s(a)?Q(a):t?U(t):o("Content is not an array: "+a)}catch(e){f?.(e),t&&U(t)}K(0)}))),_),W=()=>(D&&(y(D),D=void 0),_),X=async t=>(1!=I&&(K(2),N++,await Z((async()=>{try{await d(B,t)}catch(t){f?.(t)}K(0)}))),_),Y=()=>(n(z,t.delListener),z=void 0,_),Z=async(...t)=>(c(b(O,x),...t),await(async()=>{if(!b(E,x)){for(A(E,x,1);!a(j=l(b(O,x)));)try{await j()}catch(t){f?.(t)}A(E,x,0)}})(),_),_={load:V,startAutoLoad:async t=>{await W().load(t);try{D=await u((async(t,e)=>{e||t?2!=I&&(K(1),J++,Q(e??t),K(0)):await V()}))}catch(t){f?.(t)}return _},stopAutoLoad:W,isAutoLoading:()=>!a(D),save:X,startAutoSave:async()=>(await Y().save(),z=t.addDidFinishTransactionListener((()=>{const t=F();H(t)&&X(t)})),_),stopAutoSave:Y,isAutoSaving:()=>!a(z),getStatus:()=>I,addStatusListener:t=>$(t,R),delListener:e=>(G(e),t),schedule:Z,getStore:()=>t,destroy:()=>(b(O,x).splice(0,void 0),W().stopAutoSave()),getStats:()=>({loads:J,saves:N}),...P};return h(_)},x=t=>t.headers.get("ETag");t.createRemotePersister=(t,n,s,r=5,o)=>{let i;return P(t,(async()=>{const t=await fetch(n);return i=x(t),g(await t.text())}),(async t=>{return await fetch(s,{method:"POST",headers:{"Content-Type":"application/json"},body:(e=t(),f(e,((t,e)=>e instanceof Map?d.fromEntries([...e]):e)))});var e}),(t=>setInterval((async()=>{const e=await fetch(n,{method:"HEAD"}),s=x(e);a(i)||a(s)||s==i||(i=s,t())}),1e3*r)),(t=>e(t)),o,1,{getUrls:()=>[n,s]})}},"object"==typeof exports&&"undefined"!=typeof module?e(exports):"function"==typeof define&&define.amd?define(["exports"],e):e((t="undefined"!=typeof globalThis?globalThis:t||self).TinyBasePersisterRemote={});
|
|
Binary file
|
|
@@ -1 +1 @@
|
|
|
1
|
-
var t,e;t=this,e=function(t){"use strict";const e=clearInterval,a=t=>null==t,n=(t,e,n)=>a(t)?n?.():e(t),s=t=>Array.isArray(t),r=t=>t.length,o=t=>{throw Error(t)},i=(t,e)=>t.forEach(e),c=(t,...e)=>t.push(...e),l=t=>t.shift(),d=Object,u=t=>d.getPrototypeOf(t),y=d.keys,h=d.freeze,p=t=>(t=>!a(t)&&n(u(t),(t=>t==d.prototype||a(u(t))),(()=>!0)))(t)&&0==(t=>r(y(t)))(t),f=JSON.stringify,g=JSON.parse,v=t=>a(t)||0==(t=>t?.size??0)(t),w=(t,e)=>t?.forEach(e),S=(t,e)=>t?.delete(e),C=t=>new Map(t),b=(t,e)=>t?.get(e),A=(t,e,n)=>a(n)?(S(t,e),t):t?.set(e,n),T=(t,e,a,n)=>{var s,r;return s=t,r=e,s?.has(r)?n?.(b(t,e)):A(t,e,a()),b(t,e)},m=(t,e,a,s,o=0)=>n((a?T:b)(t,e[o],o>r(e)-2?a:C),(n=>{if(o>r(e)-2)return s?.(n)&&A(t,e[o]),n;const i=m(n,e,a,s,o+1);return v(n)&&A(t,e[o]),i})),L=t=>new Set(s(t)||a(t)?t:[t]),M=/^\d+$/,E=C(),O=C(),P=(t,e,d,u,y,f,g,P={},x=[])=>{let j,D,z,I=0,J=0,N=0;T(E,x,(()=>0)),T(O,x,(()=>[]));const R=C(),[k,B,F,H,U]=((t=1,e)=>1!=t&&e.isMergeable()?[1,e.getMergeableContent,e.getTransactionMergeableChanges,([[t],[e]])=>!p(t)||!p(e),e.setDefaultContent]:2!=t?[0,e.getContent,e.getTransactionChanges,([t,e])=>!p(t)||!p(e),e.setContent]:o("Store type not supported by this Persister"))(g,t),[$,q,G]=(()=>{let t;const[e,s]=(()=>{const t=[];let e=0;return[a=>(a?l(t):null)??""+e++,e=>{M.test(e)&&r(t)<1e3&&c(t,e)}]})(),o=C();return[(a,n,s,r=[],i=()=>[])=>{t??=_;const c=e(1);var l,d;return A(o,c,[a,n,s,r,i]),l=m(n,s??[""],L),d=c,l?.add(d),c},(e,a,...n)=>i(((t,e=[""])=>{const a=[],n=(t,s)=>s==r(e)?c(a,t):null===e[s]?w(t,(t=>n(t,s+1))):i([e[s],null],(e=>n(b(t,e),s+1)));return n(t,0),a})(e,a),(e=>w(e,(e=>b(o,e)[0](t,...a??[],...n))))),t=>n(b(o,t),(([,e,a])=>(m(e,a??[""],void 0,(e=>(S(e,t),v(e)?1:0))),A(o,t),s(t),a))),e=>n(b(o,e),(([e,,n=[],s,o])=>{const c=(...l)=>{const d=r(l);d==r(n)?e(t,...l,...o(l)):a(n[d])?i(s[d]?.(...l)??[],(t=>c(...l,t))):c(...l,n[d])};c()}))]})(),K=t=>{t!=I&&(I=t,q(R,void 0,I))},Q=e=>{(k&&s(e?.[0])?1===e?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===e?.[2]?t.applyChanges:t.setContent)(e)},V=async t=>(2!=I&&(K(1),J++,await Z((async()=>{try{const a=await e();s(a)?Q(a):t?U(t):o("Content is not an array "+a)}catch(e){f?.(e),t&&U(t)}K(0)}))),_),W=()=>(D&&(y(D),D=void 0),_),X=async t=>(1!=I&&(K(2),N++,await Z((async()=>{try{await d(B,t)}catch(t){f?.(t)}K(0)}))),_),Y=()=>(n(z,t.delListener),z=void 0,_),Z=async(...t)=>(c(b(O,x),...t),await(async()=>{if(!b(E,x)){for(A(E,x,1);!a(j=l(b(O,x)));)try{await j()}catch(t){f?.(t)}A(E,x,0)}})(),_),_={load:V,startAutoLoad:async t=>{await W().load(t);try{D=await u((async(t,e)=>{e||t?2!=I&&(K(1),J++,Q(e??t),K(0)):await V()}))}catch(t){f?.(t)}return _},stopAutoLoad:W,isAutoLoading:()=>!a(D),save:X,startAutoSave:async()=>(await Y().save(),z=t.addDidFinishTransactionListener((()=>{const t=F();H(t)&&X(t)})),_),stopAutoSave:Y,isAutoSaving:()=>!a(z),getStatus:()=>I,addStatusListener:t=>$(t,R),delListener:e=>(G(e),t),schedule:Z,getStore:()=>t,destroy:()=>(b(O,x).splice(0,void 0),W().stopAutoSave()),getStats:()=>({loads:J,saves:N}),...P};return h(_)},x=t=>t.headers.get("ETag");t.createRemotePersister=(t,n,s,r=5,o)=>{let i;return P(t,(async()=>{const t=await fetch(n);return i=x(t),g(await t.text())}),(async t=>{return await fetch(s,{method:"POST",headers:{"Content-Type":"application/json"},body:(e=t(),f(e,((t,e)=>e instanceof Map?d.fromEntries([...e]):e)))});var e}),(t=>setInterval((async()=>{const e=await fetch(n,{method:"HEAD"}),s=x(e);a(i)||a(s)||s==i||(i=s,t())}),1e3*r)),(t=>e(t)),o,1,{getUrls:()=>[n,s]})}},"object"==typeof exports&&"undefined"!=typeof module?e(exports):"function"==typeof define&&define.amd?define(["exports"],e):e((t="undefined"!=typeof globalThis?globalThis:t||self).TinyBasePersisterRemote={});
|
|
1
|
+
var t,e;t=this,e=function(t){"use strict";const e=clearInterval,a=t=>null==t,n=(t,e,n)=>a(t)?n?.():e(t),s=t=>Array.isArray(t),r=t=>t.length,o=t=>{throw Error(t)},i=(t,e)=>t.forEach(e),c=(t,...e)=>t.push(...e),l=t=>t.shift(),d=Object,u=t=>d.getPrototypeOf(t),y=d.keys,h=d.freeze,p=t=>(t=>!a(t)&&n(u(t),(t=>t==d.prototype||a(u(t))),(()=>!0)))(t)&&0==(t=>r(y(t)))(t),f=JSON.stringify,g=JSON.parse,v=t=>a(t)||0==(t=>t?.size??0)(t),w=(t,e)=>t?.forEach(e),S=(t,e)=>t?.delete(e),C=t=>new Map(t),b=(t,e)=>t?.get(e),A=(t,e,n)=>a(n)?(S(t,e),t):t?.set(e,n),T=(t,e,a,n)=>{var s,r;return s=t,r=e,s?.has(r)?n?.(b(t,e)):A(t,e,a()),b(t,e)},m=(t,e,a,s,o=0)=>n((a?T:b)(t,e[o],o>r(e)-2?a:C),(n=>{if(o>r(e)-2)return s?.(n)&&A(t,e[o]),n;const i=m(n,e,a,s,o+1);return v(n)&&A(t,e[o]),i})),L=t=>new Set(s(t)||a(t)?t:[t]),M=/^\d+$/,E=C(),O=C(),P=(t,e,d,u,y,f,g,P={},x=[])=>{let j,D,z,I=0,J=0,N=0;T(E,x,(()=>0)),T(O,x,(()=>[]));const R=C(),[k,B,F,H,U]=((t=1,e)=>1!=t&&e.isMergeable()?[1,e.getMergeableContent,e.getTransactionMergeableChanges,([[t],[e]])=>!p(t)||!p(e),e.setDefaultContent]:2!=t?[0,e.getContent,e.getTransactionChanges,([t,e])=>!p(t)||!p(e),e.setContent]:o("Store type not supported by this Persister"))(g,t),[$,q,G]=(()=>{let t;const[e,s]=(()=>{const t=[];let e=0;return[a=>(a?l(t):null)??""+e++,e=>{M.test(e)&&r(t)<1e3&&c(t,e)}]})(),o=C();return[(a,n,s,r=[],i=()=>[])=>{t??=_;const c=e(1);var l,d;return A(o,c,[a,n,s,r,i]),l=m(n,s??[""],L),d=c,l?.add(d),c},(e,a,...n)=>i(((t,e=[""])=>{const a=[],n=(t,s)=>s==r(e)?c(a,t):null===e[s]?w(t,(t=>n(t,s+1))):i([e[s],null],(e=>n(b(t,e),s+1)));return n(t,0),a})(e,a),(e=>w(e,(e=>b(o,e)[0](t,...a??[],...n))))),t=>n(b(o,t),(([,e,a])=>(m(e,a??[""],void 0,(e=>(S(e,t),v(e)?1:0))),A(o,t),s(t),a))),e=>n(b(o,e),(([e,,n=[],s,o])=>{const c=(...l)=>{const d=r(l);d==r(n)?e(t,...l,...o(l)):a(n[d])?i(s[d]?.(...l)??[],(t=>c(...l,t))):c(...l,n[d])};c()}))]})(),K=t=>{t!=I&&(I=t,q(R,void 0,I))},Q=e=>{(k&&s(e?.[0])?1===e?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===e?.[2]?t.applyChanges:t.setContent)(e)},V=async t=>(2!=I&&(K(1),J++,await Z((async()=>{try{const a=await e();s(a)?Q(a):t?U(t):o("Content is not an array: "+a)}catch(e){f?.(e),t&&U(t)}K(0)}))),_),W=()=>(D&&(y(D),D=void 0),_),X=async t=>(1!=I&&(K(2),N++,await Z((async()=>{try{await d(B,t)}catch(t){f?.(t)}K(0)}))),_),Y=()=>(n(z,t.delListener),z=void 0,_),Z=async(...t)=>(c(b(O,x),...t),await(async()=>{if(!b(E,x)){for(A(E,x,1);!a(j=l(b(O,x)));)try{await j()}catch(t){f?.(t)}A(E,x,0)}})(),_),_={load:V,startAutoLoad:async t=>{await W().load(t);try{D=await u((async(t,e)=>{e||t?2!=I&&(K(1),J++,Q(e??t),K(0)):await V()}))}catch(t){f?.(t)}return _},stopAutoLoad:W,isAutoLoading:()=>!a(D),save:X,startAutoSave:async()=>(await Y().save(),z=t.addDidFinishTransactionListener((()=>{const t=F();H(t)&&X(t)})),_),stopAutoSave:Y,isAutoSaving:()=>!a(z),getStatus:()=>I,addStatusListener:t=>$(t,R),delListener:e=>(G(e),t),schedule:Z,getStore:()=>t,destroy:()=>(b(O,x).splice(0,void 0),W().stopAutoSave()),getStats:()=>({loads:J,saves:N}),...P};return h(_)},x=t=>t.headers.get("ETag");t.createRemotePersister=(t,n,s,r=5,o)=>{let i;return P(t,(async()=>{const t=await fetch(n);return i=x(t),g(await t.text())}),(async t=>{return await fetch(s,{method:"POST",headers:{"Content-Type":"application/json"},body:(e=t(),f(e,((t,e)=>e instanceof Map?d.fromEntries([...e]):e)))});var e}),(t=>setInterval((async()=>{const e=await fetch(n,{method:"HEAD"}),s=x(e);a(i)||a(s)||s==i||(i=s,t())}),1e3*r)),(t=>e(t)),o,1,{getUrls:()=>[n,s]})}},"object"==typeof exports&&"undefined"!=typeof module?e(exports):"function"==typeof define&&define.amd?define(["exports"],e):e((t="undefined"!=typeof globalThis?globalThis:t||self).TinyBasePersisterRemote={});
|
|
Binary file
|
|
@@ -1 +1 @@
|
|
|
1
|
-
var t,a;t=this,a=function(t){"use strict";const a=t=>typeof t,e="tinybase",n="",s=",",i=a(n),o=Promise,r=clearInterval,c=t=>null==t,l=(t,a,e)=>c(t)?e?.():a(t),u=t=>a(t)==i,y=t=>Array.isArray(t),d=(t,a,e)=>t.slice(a,e),w=t=>t.length,p=async t=>o.all(t),v=t=>{throw Error(t)},f=(t,a)=>t.forEach(a),E=(t,a="")=>t.join(a),g=(t,a)=>t.map(a),h=t=>0==w(t),m=(t,a)=>t.filter(a),A=(t,...a)=>t.push(...a),N=t=>t.shift(),S="_",T="_id",$="SELECT",b="WHERE",C="TABLE",O="ALTER "+C,I="DELETE FROM",L=$+"*FROM",R="pragma_",D="data_version",_="schema_version",M="pragma_table_",P=t=>`"${t.replace(/"/g,'""')}"`,F=(t,a=[1])=>E(g(t,(()=>"$"+a[0]++)),s),j=(t,a)=>t?.has(a)??!1,x=t=>c(t)||0==(t=>t?.size??0)(t),k=t=>[...t?.values()??[]],q=(t,a)=>t?.forEach(a),B=(t,a)=>t?.delete(a),U=Object,J=t=>U.getPrototypeOf(t),W=U.entries,Y=U.keys,z=U.freeze,G=(t=[])=>U.fromEntries(t),H=(...t)=>U.assign({},...t),V=(t,a)=>(delete t[a],t),K=(t,a)=>g(W(t),(([t,e])=>a(e,t))),Q=t=>U.values(t),X=t=>w(Y(t)),Z=t=>(t=>!c(t)&&l(J(t),(t=>t==U.prototype||c(J(t))),(()=>!0)))(t)&&0==X(t),tt=JSON.stringify,at=JSON.parse,et=t=>new Map(t),nt=(t,a)=>t?.get(a),st=(t,a)=>g([...t?.entries()??[]],(([t,e])=>a(e,t))),it=(t,a,e)=>c(e)?(B(t,a),t):t?.set(a,e),ot=(t,a,e,n)=>(j(t,a)?n?.(nt(t,a)):it(t,a,e()),nt(t,a)),rt=(t,a,e,n,s=0)=>l((e?ot:nt)(t,a[s],s>w(a)-2?e:et),(i=>{if(s>w(a)-2)return n?.(i)&&it(t,a[s]),i;const o=rt(i,a,e,n,s+1);return x(i)&&it(t,a[s]),o})),ct=t=>new Set(y(t)||c(t)?t:[t]),lt=(t,a)=>t?.add(a),ut=/^\d+$/,yt=et(),dt=et(),wt=(t,a,e,s,i,o,r,u={},d=[])=>{let p,E,g,h=0,m=0,S=0;ot(yt,d,(()=>0)),ot(dt,d,(()=>[]));const T=et(),[$,b,C,O,I]=((t=1,a)=>1!=t&&a.isMergeable()?[1,a.getMergeableContent,a.getTransactionMergeableChanges,([[t],[a]])=>!Z(t)||!Z(a),a.setDefaultContent]:2!=t?[0,a.getContent,a.getTransactionChanges,([t,a])=>!Z(t)||!Z(a),a.setContent]:v("Store type not supported by this Persister"))(r,t),[L,R,D]=(()=>{let t;const[a,e]=(()=>{const t=[];let a=0;return[e=>(e?N(t):null)??n+a++,a=>{ut.test(a)&&w(t)<1e3&&A(t,a)}]})(),s=et();return[(e,i,o,r=[],c=()=>[])=>{t??=J;const l=a(1);return it(s,l,[e,i,o,r,c]),lt(rt(i,o??[n],ct),l),l},(a,e,...i)=>f(((t,a=[n])=>{const e=[],s=(t,n)=>n==w(a)?A(e,t):null===a[n]?q(t,(t=>s(t,n+1))):f([a[n],null],(a=>s(nt(t,a),n+1)));return s(t,0),e})(a,e),(a=>q(a,(a=>nt(s,a)[0](t,...e??[],...i))))),t=>l(nt(s,t),(([,a,i])=>(rt(a,i??[n],void 0,(a=>(B(a,t),x(a)?1:0))),it(s,t),e(t),i))),a=>l(nt(s,a),(([a,,e=[],n,s])=>{const i=(...o)=>{const r=w(o);r==w(e)?a(t,...o,...s(o)):c(e[r])?f(n[r]?.(...o)??[],(t=>i(...o,t))):i(...o,e[r])};i()}))]})(),_=t=>{t!=h&&(h=t,R(T,void 0,h))},M=a=>{($&&y(a?.[0])?1===a?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===a?.[2]?t.applyChanges:t.setContent)(a)},P=async t=>(2!=h&&(_(1),m++,await U((async()=>{try{const e=await a();y(e)?M(e):t?I(t):v("Content is not an array "+e)}catch(a){o?.(a),t&&I(t)}_(0)}))),J),F=()=>(E&&(i(E),E=void 0),J),j=async t=>(1!=h&&(_(2),S++,await U((async()=>{try{await e(b,t)}catch(t){o?.(t)}_(0)}))),J),k=()=>(l(g,t.delListener),g=void 0,J),U=async(...t)=>(A(nt(dt,d),...t),await(async()=>{if(!nt(yt,d)){for(it(yt,d,1);!c(p=N(nt(dt,d)));)try{await p()}catch(t){o?.(t)}it(yt,d,0)}})(),J),J={load:P,startAutoLoad:async t=>{await F().load(t);try{E=await s((async(t,a)=>{a||t?2!=h&&(_(1),m++,M(a??t),_(0)):await P()}))}catch(t){o?.(t)}return J},stopAutoLoad:F,isAutoLoading:()=>!c(E),save:j,startAutoSave:async()=>(await k().save(),g=t.addDidFinishTransactionListener((()=>{const t=C();O(t)&&j(t)})),J),stopAutoSave:k,isAutoSaving:()=>!c(g),getStatus:()=>h,addStatusListener:t=>L(t,T),delListener:a=>(D(a),t),schedule:U,getStore:()=>t,destroy:()=>(nt(dt,d).splice(0,void 0),F().stopAutoSave()),getStats:()=>({loads:m,saves:S}),...u};return z(J)},pt=(t,a,e,n,i,o=vt,r,l)=>{const u=et();return[async()=>{u.clear(),g(await e(t,a),(({tn:t,cn:a})=>lt(ot(u,t,ct),a)))},async(a,e)=>((t,a)=>j(nt(u,t),a))(a,e)?G(m(g(await t(L+P(a)),(t=>{return[t[e],l?(a=V(t,e),n=l,G(K(a,((t,a)=>[a,n(t,a)])))):V(t,e)];var a,n})),(([t,a])=>!c(t)&&!Z(a)))):{},async(a,e,n,l,y,d=!1)=>{const w=ct();K(n??{},(t=>g(Y(t??{}),(t=>lt(w,t)))));const v=k(w);if(!d&&y&&h(v)&&j(u,a))return await t("DROP "+C+P(a)),void it(u,a);const f=nt(u,a),N=ct(k(f));if(h(v)||(j(u,a)?await p(g([e,...v],(async(n,s)=>{B(N,n)||(await t(O+P(a)+"ADD"+P(n)+i),0==s&&await t("CREATE UNIQUE INDEX pk ON "+P(a)+`(${P(e)})`),lt(f,n))}))):(await t("CREATE "+C+P(a)+`(${P(e)}${i} PRIMARY KEY${E(g(v,(t=>s+P(t)+i)))});`),it(u,a,ct([e,...v])))),await p([...!d&&l?g(k(N),(async n=>{n!=e&&(await t(O+P(a)+"DROP"+P(n)),B(f,n))})):[]]),d)c(n)?await t(I+P(a)+b+" true"):await p(K(n,(async(n,s)=>{c(n)?await t(I+P(a)+b+P(e)+"=$1",[s]):h(v)||await o(t,a,e,Y(n),{[s]:r?g(Q(n),r):Q(n)},f)})));else if(h(v))j(u,a)&&await t(I+P(a)+b+" true");else{const s=m(k(nt(u,a)),(t=>t!=e)),i={},c=[];K(n??{},((t,a)=>{i[a]=g(s,(a=>r?r(t?.[a]):t?.[a])),A(c,a)})),await o(t,a,e,s,i),await t(I+P(a)+b+P(e)+`NOT IN(${F(c)})`,c)}},async a=>{let e;await t("BEGIN");try{e=await a()}catch(t){n?.(t)}return await t("END"),e}]},vt=async(t,a,e,n,i)=>{const o=[1];await t("INSERT INTO"+P(a)+"("+((...t)=>E(g(t,P),s))(e,...n)+")VALUES"+E(K(i,(t=>"($"+o[0]+++","+F(t,o)+")")),s)+"ON CONFLICT("+P(e)+")DO UPDATE SET"+E(g(n,(t=>P(t)+"=excluded."+P(t))),s),K(i,((t,a)=>[a,...g(t,(t=>t??null))])).flat())},ft=(t,a,e,n,s,i,o,[r,c,l],u,y,d,w,p,v)=>{const[f,E,g,h]=pt(a,u,y,s,p,v),m=wt(t,(async()=>await h((async()=>{return await f(),t=(await E(r,c))[S]?.[l]??"null",at(t,((t,a)=>""===a?void 0:a));var t}))),(async t=>await h((async()=>{var a;await f(),await g(r,c,{[S]:{[l]:(a=t()??null,tt(a,((t,a)=>void 0===a?"":a)))}},!0,!0)}))),e,n,s,o,{[w]:()=>d,destroy:()=>(m.stopAutoLoad().stopAutoSave(),i(),m)},d);return m},Et=(t,a,e,n,s,i,o,[r,l,[u,y,d]],w,v,f,E,g,h,A,N)=>{const[$,b,C,O]=pt(a,w,v,s,g,h,A,N),I=async(t,a)=>await p(st(l,(async([e,n,s,i],o)=>{a&&!(o in t)||await C(e,n,t[o],s,i,a)}))),L=async(t,a)=>y?await C(d,T,{[S]:t},!0,!0,a):null,R=wt(t,(async()=>await O((async()=>{await $();const t=await(async()=>G(m(await p(st(r,(async([t,a],e)=>[t,await b(e,a)]))),(t=>!Z(t[1])))))(),a=await(async()=>u?(await b(d,T))[S]:{})();return Z(t)&&c(a)?void 0:[t,a]}))),(async(t,a)=>await O((async()=>{if(await $(),c(a)){const[a,e]=t();await I(a),await L(e)}else await I(a[0],!0),await L(a[1],!0)}))),e,n,s,o,{[E]:()=>f,destroy:()=>(R.stopAutoLoad().stopAutoSave(),i(),R)},f);return R},gt="ColumnName",ht="store",mt="json",At=ht+"TableName",Nt=ht+"Id"+gt,St=ht+gt,Tt="autoLoadIntervalSeconds",$t="rowId"+gt,bt="tableId",Ct="tableName",Ot="deleteEmptyColumns",It="deleteEmptyTable",Lt={mode:mt,[Tt]:1},Rt={load:0,save:0,[Ct]:e+"_values"},Dt=(t,a,e,n,s)=>{const i=et();return K(t,((t,o)=>{const r=d(Q(H(a,u(t)?{[e]:t}:t)),0,X(a));c(r[0])||n(o,r[0])||(s(o,r[0]),it(i,o,r))})),i},_t=(t,a,s,i,o,c,l,y,w,p,v="getDb",f)=>{let E,g,h;const m=((t,a)=>a?async(e,n)=>(a(e,n),await t(e,n)):t)(s,c),[A,N,S,C]=(t=>{const a=(t=>H(Lt,u(t)?{[At]:t}:t??{}))(t),n=a[Tt];if(a.mode==mt){const t=a[At]??e;return[1,n,[t,a[Nt]??T,a[St]??ht],ct(t)]}const{tables:{load:s={},save:i={}}={},values:o={}}=a,r=d(Q(H(Rt,o)),0,X(Rt)),c=r[2],l=ct(c),y=ct(c);return[0,n,[Dt(s,{[bt]:null,[$t]:T},bt,(t=>j(y,t)),(t=>lt(l,t))),Dt(i,{[Ct]:null,[$t]:T,[Ot]:0,[It]:0},Ct,((t,a)=>j(y,a)),((t,a)=>lt(l,a))),r],l]})(a);return(A?ft:Et)(t,m,(t=>{let a;const e=()=>a=setInterval((async()=>{try{const[{d:a,s:e,c:n}]=await m(`${$} ${D} d,${_} s,TOTAL_CHANGES() c FROM ${R}${D} JOIN ${R}${_}`);a==E&&e==g&&n==h||(null!=E&&t(),E=a,g=e,h=n)}catch{}}),1e3*N),n=()=>{E=g=h=null,r(a)},s=i((a=>{C.has(a)&&(n(),t(),e())}));return e(),()=>{n(),o(s)}}),(t=>t()),l,y,w,S,k(C),(async(t,a)=>await t(`${$} t.name tn,c.name cn FROM ${M}list()t,${M}info(t.name)c ${b} t.schema='main'AND t.type IN('table','view')AND t.name IN(${F(a)})ORDER BY t.name,c.name`,a)),p,v,n,f,(t=>!0===t?1:!1===t?0:t),void 0)};t.createSqliteWasmPersister=(t,a,e,n,s,i)=>_t(t,n,(async(t,a=[])=>e.exec(t,{bind:a,rowMode:"object",returnValue:"resultRows"}).map((t=>({...t})))),(t=>a.capi.sqlite3_update_hook(e,((a,e,n,s)=>t(s)),0)),(()=>a.capi.sqlite3_update_hook(e,(()=>0),0)),s,i,(()=>0),3,e)},"object"==typeof exports&&"undefined"!=typeof module?a(exports):"function"==typeof define&&define.amd?define(["exports"],a):a((t="undefined"!=typeof globalThis?globalThis:t||self).TinyBasePersisterSqliteWasm={});
|
|
1
|
+
var t,a;t=this,a=function(t){"use strict";const a=t=>typeof t,e="tinybase",n="",s=",",i=a(n),o=Promise,r=clearInterval,c=t=>null==t,l=(t,a,e)=>c(t)?e?.():a(t),u=t=>a(t)==i,y=t=>Array.isArray(t),d=(t,a,e)=>t.slice(a,e),w=t=>t.length,p=async t=>o.all(t),v=t=>{throw Error(t)},f=(t,a)=>t.forEach(a),E=(t,a="")=>t.join(a),g=(t,a)=>t.map(a),h=t=>0==w(t),m=(t,a)=>t.filter(a),A=(t,...a)=>t.push(...a),N=t=>t.shift(),S="_",T="_id",$="SELECT",b="WHERE",C="TABLE",O="ALTER "+C,I="DELETE FROM",L=$+"*FROM",R="pragma_",D="data_version",_="schema_version",M="pragma_table_",P=t=>`"${t.replace(/"/g,'""')}"`,F=(t,a=[1])=>E(g(t,(()=>"$"+a[0]++)),s),j=(t,a)=>t?.has(a)??!1,x=t=>c(t)||0==(t=>t?.size??0)(t),k=t=>[...t?.values()??[]],q=(t,a)=>t?.forEach(a),B=(t,a)=>t?.delete(a),U=Object,J=t=>U.getPrototypeOf(t),W=U.entries,Y=U.keys,z=U.freeze,G=(t=[])=>U.fromEntries(t),H=(...t)=>U.assign({},...t),V=(t,a)=>(delete t[a],t),K=(t,a)=>g(W(t),(([t,e])=>a(e,t))),Q=t=>U.values(t),X=t=>w(Y(t)),Z=t=>(t=>!c(t)&&l(J(t),(t=>t==U.prototype||c(J(t))),(()=>!0)))(t)&&0==X(t),tt=JSON.stringify,at=JSON.parse,et=t=>new Map(t),nt=(t,a)=>t?.get(a),st=(t,a)=>g([...t?.entries()??[]],(([t,e])=>a(e,t))),it=(t,a,e)=>c(e)?(B(t,a),t):t?.set(a,e),ot=(t,a,e,n)=>(j(t,a)?n?.(nt(t,a)):it(t,a,e()),nt(t,a)),rt=(t,a,e,n,s=0)=>l((e?ot:nt)(t,a[s],s>w(a)-2?e:et),(i=>{if(s>w(a)-2)return n?.(i)&&it(t,a[s]),i;const o=rt(i,a,e,n,s+1);return x(i)&&it(t,a[s]),o})),ct=t=>new Set(y(t)||c(t)?t:[t]),lt=(t,a)=>t?.add(a),ut=/^\d+$/,yt=et(),dt=et(),wt=(t,a,e,s,i,o,r,u={},d=[])=>{let p,E,g,h=0,m=0,S=0;ot(yt,d,(()=>0)),ot(dt,d,(()=>[]));const T=et(),[$,b,C,O,I]=((t=1,a)=>1!=t&&a.isMergeable()?[1,a.getMergeableContent,a.getTransactionMergeableChanges,([[t],[a]])=>!Z(t)||!Z(a),a.setDefaultContent]:2!=t?[0,a.getContent,a.getTransactionChanges,([t,a])=>!Z(t)||!Z(a),a.setContent]:v("Store type not supported by this Persister"))(r,t),[L,R,D]=(()=>{let t;const[a,e]=(()=>{const t=[];let a=0;return[e=>(e?N(t):null)??n+a++,a=>{ut.test(a)&&w(t)<1e3&&A(t,a)}]})(),s=et();return[(e,i,o,r=[],c=()=>[])=>{t??=J;const l=a(1);return it(s,l,[e,i,o,r,c]),lt(rt(i,o??[n],ct),l),l},(a,e,...i)=>f(((t,a=[n])=>{const e=[],s=(t,n)=>n==w(a)?A(e,t):null===a[n]?q(t,(t=>s(t,n+1))):f([a[n],null],(a=>s(nt(t,a),n+1)));return s(t,0),e})(a,e),(a=>q(a,(a=>nt(s,a)[0](t,...e??[],...i))))),t=>l(nt(s,t),(([,a,i])=>(rt(a,i??[n],void 0,(a=>(B(a,t),x(a)?1:0))),it(s,t),e(t),i))),a=>l(nt(s,a),(([a,,e=[],n,s])=>{const i=(...o)=>{const r=w(o);r==w(e)?a(t,...o,...s(o)):c(e[r])?f(n[r]?.(...o)??[],(t=>i(...o,t))):i(...o,e[r])};i()}))]})(),_=t=>{t!=h&&(h=t,R(T,void 0,h))},M=a=>{($&&y(a?.[0])?1===a?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===a?.[2]?t.applyChanges:t.setContent)(a)},P=async t=>(2!=h&&(_(1),m++,await U((async()=>{try{const e=await a();y(e)?M(e):t?I(t):v("Content is not an array: "+e)}catch(a){o?.(a),t&&I(t)}_(0)}))),J),F=()=>(E&&(i(E),E=void 0),J),j=async t=>(1!=h&&(_(2),S++,await U((async()=>{try{await e(b,t)}catch(t){o?.(t)}_(0)}))),J),k=()=>(l(g,t.delListener),g=void 0,J),U=async(...t)=>(A(nt(dt,d),...t),await(async()=>{if(!nt(yt,d)){for(it(yt,d,1);!c(p=N(nt(dt,d)));)try{await p()}catch(t){o?.(t)}it(yt,d,0)}})(),J),J={load:P,startAutoLoad:async t=>{await F().load(t);try{E=await s((async(t,a)=>{a||t?2!=h&&(_(1),m++,M(a??t),_(0)):await P()}))}catch(t){o?.(t)}return J},stopAutoLoad:F,isAutoLoading:()=>!c(E),save:j,startAutoSave:async()=>(await k().save(),g=t.addDidFinishTransactionListener((()=>{const t=C();O(t)&&j(t)})),J),stopAutoSave:k,isAutoSaving:()=>!c(g),getStatus:()=>h,addStatusListener:t=>L(t,T),delListener:a=>(D(a),t),schedule:U,getStore:()=>t,destroy:()=>(nt(dt,d).splice(0,void 0),F().stopAutoSave()),getStats:()=>({loads:m,saves:S}),...u};return z(J)},pt=(t,a,e,n,i,o=vt,r,l)=>{const u=et();return[async()=>{u.clear(),g(await e(t,a),(({tn:t,cn:a})=>lt(ot(u,t,ct),a)))},async(a,e)=>((t,a)=>j(nt(u,t),a))(a,e)?G(m(g(await t(L+P(a)),(t=>{return[t[e],l?(a=V(t,e),n=l,G(K(a,((t,a)=>[a,n(t,a)])))):V(t,e)];var a,n})),(([t,a])=>!c(t)&&!Z(a)))):{},async(a,e,n,l,y,d=!1)=>{const w=ct();K(n??{},(t=>g(Y(t??{}),(t=>lt(w,t)))));const v=k(w);if(!d&&y&&h(v)&&j(u,a))return await t("DROP "+C+P(a)),void it(u,a);const f=nt(u,a),N=ct(k(f));if(h(v)||(j(u,a)?await p(g([e,...v],(async(n,s)=>{B(N,n)||(await t(O+P(a)+"ADD"+P(n)+i),0==s&&await t("CREATE UNIQUE INDEX pk ON "+P(a)+`(${P(e)})`),lt(f,n))}))):(await t("CREATE "+C+P(a)+`(${P(e)}${i} PRIMARY KEY${E(g(v,(t=>s+P(t)+i)))});`),it(u,a,ct([e,...v])))),await p([...!d&&l?g(k(N),(async n=>{n!=e&&(await t(O+P(a)+"DROP"+P(n)),B(f,n))})):[]]),d)c(n)?await t(I+P(a)+b+" true"):await p(K(n,(async(n,s)=>{c(n)?await t(I+P(a)+b+P(e)+"=$1",[s]):h(v)||await o(t,a,e,Y(n),{[s]:r?g(Q(n),r):Q(n)},f)})));else if(h(v))j(u,a)&&await t(I+P(a)+b+" true");else{const s=m(k(nt(u,a)),(t=>t!=e)),i={},c=[];K(n??{},((t,a)=>{i[a]=g(s,(a=>r?r(t?.[a]):t?.[a])),A(c,a)})),await o(t,a,e,s,i),await t(I+P(a)+b+P(e)+`NOT IN(${F(c)})`,c)}},async a=>{let e;await t("BEGIN");try{e=await a()}catch(t){n?.(t)}return await t("END"),e}]},vt=async(t,a,e,n,i)=>{const o=[1];await t("INSERT INTO"+P(a)+"("+((...t)=>E(g(t,P),s))(e,...n)+")VALUES"+E(K(i,(t=>"($"+o[0]+++","+F(t,o)+")")),s)+"ON CONFLICT("+P(e)+")DO UPDATE SET"+E(g(n,(t=>P(t)+"=excluded."+P(t))),s),K(i,((t,a)=>[a,...g(t,(t=>t??null))])).flat())},ft=(t,a,e,n,s,i,o,[r,c,l],u,y,d,w,p,v)=>{const[f,E,g,h]=pt(a,u,y,s,p,v),m=wt(t,(async()=>await h((async()=>{return await f(),t=(await E(r,c))[S]?.[l]??"null",at(t,((t,a)=>""===a?void 0:a));var t}))),(async t=>await h((async()=>{var a;await f(),await g(r,c,{[S]:{[l]:(a=t()??null,tt(a,((t,a)=>void 0===a?"":a)))}},!0,!0)}))),e,n,s,o,{[w]:()=>d,destroy:()=>(m.stopAutoLoad().stopAutoSave(),i(),m)},d);return m},Et=(t,a,e,n,s,i,o,[r,l,[u,y,d]],w,v,f,E,g,h,A,N)=>{const[$,b,C,O]=pt(a,w,v,s,g,h,A,N),I=async(t,a)=>await p(st(l,(async([e,n,s,i],o)=>{a&&!(o in t)||await C(e,n,t[o],s,i,a)}))),L=async(t,a)=>y?await C(d,T,{[S]:t},!0,!0,a):null,R=wt(t,(async()=>await O((async()=>{await $();const t=await(async()=>G(m(await p(st(r,(async([t,a],e)=>[t,await b(e,a)]))),(t=>!Z(t[1])))))(),a=await(async()=>u?(await b(d,T))[S]:{})();return Z(t)&&c(a)?void 0:[t,a]}))),(async(t,a)=>await O((async()=>{if(await $(),c(a)){const[a,e]=t();await I(a),await L(e)}else await I(a[0],!0),await L(a[1],!0)}))),e,n,s,o,{[E]:()=>f,destroy:()=>(R.stopAutoLoad().stopAutoSave(),i(),R)},f);return R},gt="ColumnName",ht="store",mt="json",At=ht+"TableName",Nt=ht+"Id"+gt,St=ht+gt,Tt="autoLoadIntervalSeconds",$t="rowId"+gt,bt="tableId",Ct="tableName",Ot="deleteEmptyColumns",It="deleteEmptyTable",Lt={mode:mt,[Tt]:1},Rt={load:0,save:0,[Ct]:e+"_values"},Dt=(t,a,e,n,s)=>{const i=et();return K(t,((t,o)=>{const r=d(Q(H(a,u(t)?{[e]:t}:t)),0,X(a));c(r[0])||n(o,r[0])||(s(o,r[0]),it(i,o,r))})),i},_t=(t,a,s,i,o,c,l,y,w,p,v="getDb",f)=>{let E,g,h;const m=((t,a)=>a?async(e,n)=>(a(e,n),await t(e,n)):t)(s,c),[A,N,S,C]=(t=>{const a=(t=>H(Lt,u(t)?{[At]:t}:t??{}))(t),n=a[Tt];if(a.mode==mt){const t=a[At]??e;return[1,n,[t,a[Nt]??T,a[St]??ht],ct(t)]}const{tables:{load:s={},save:i={}}={},values:o={}}=a,r=d(Q(H(Rt,o)),0,X(Rt)),c=r[2],l=ct(c),y=ct(c);return[0,n,[Dt(s,{[bt]:null,[$t]:T},bt,(t=>j(y,t)),(t=>lt(l,t))),Dt(i,{[Ct]:null,[$t]:T,[Ot]:0,[It]:0},Ct,((t,a)=>j(y,a)),((t,a)=>lt(l,a))),r],l]})(a);return(A?ft:Et)(t,m,(t=>{let a;const e=()=>a=setInterval((async()=>{try{const[{d:a,s:e,c:n}]=await m(`${$} ${D} d,${_} s,TOTAL_CHANGES() c FROM ${R}${D} JOIN ${R}${_}`);a==E&&e==g&&n==h||(null!=E&&t(),E=a,g=e,h=n)}catch{}}),1e3*N),n=()=>{E=g=h=null,r(a)},s=i((a=>{C.has(a)&&(n(),t(),e())}));return e(),()=>{n(),o(s)}}),(t=>t()),l,y,w,S,k(C),(async(t,a)=>await t(`${$} t.name tn,c.name cn FROM ${M}list()t,${M}info(t.name)c ${b} t.schema='main'AND t.type IN('table','view')AND t.name IN(${F(a)})ORDER BY t.name,c.name`,a)),p,v,n,f,(t=>!0===t?1:!1===t?0:t),void 0)};t.createSqliteWasmPersister=(t,a,e,n,s,i)=>_t(t,n,(async(t,a=[])=>e.exec(t,{bind:a,rowMode:"object",returnValue:"resultRows"}).map((t=>({...t})))),(t=>a.capi.sqlite3_update_hook(e,((a,e,n,s)=>t(s)),0)),(()=>a.capi.sqlite3_update_hook(e,(()=>0),0)),s,i,(()=>0),3,e)},"object"==typeof exports&&"undefined"!=typeof module?a(exports):"function"==typeof define&&define.amd?define(["exports"],a):a((t="undefined"!=typeof globalThis?globalThis:t||self).TinyBasePersisterSqliteWasm={});
|
|
Binary file
|
|
@@ -1 +1 @@
|
|
|
1
|
-
var t,a;t=this,a=function(t){"use strict";const a=t=>typeof t,e="tinybase",n="",s=",",i=a(n),o=Promise,r=clearInterval,c=t=>null==t,l=(t,a,e)=>c(t)?e?.():a(t),u=t=>a(t)==i,y=t=>Array.isArray(t),d=(t,a,e)=>t.slice(a,e),w=t=>t.length,p=async t=>o.all(t),v=t=>{throw Error(t)},f=(t,a)=>t.forEach(a),E=(t,a="")=>t.join(a),g=(t,a)=>t.map(a),h=t=>0==w(t),m=(t,a)=>t.filter(a),A=(t,...a)=>t.push(...a),N=t=>t.shift(),S="_",T="_id",$="SELECT",b="WHERE",C="TABLE",O="ALTER "+C,I="DELETE FROM",L=$+"*FROM",R="pragma_",D="data_version",_="schema_version",M="pragma_table_",P=t=>`"${t.replace(/"/g,'""')}"`,F=(t,a=[1])=>E(g(t,(()=>"$"+a[0]++)),s),j=(t,a)=>t?.has(a)??!1,x=t=>c(t)||0==(t=>t?.size??0)(t),k=t=>[...t?.values()??[]],q=(t,a)=>t?.forEach(a),B=(t,a)=>t?.delete(a),U=Object,J=t=>U.getPrototypeOf(t),W=U.entries,Y=U.keys,z=U.freeze,G=(t=[])=>U.fromEntries(t),H=(...t)=>U.assign({},...t),V=(t,a)=>(delete t[a],t),K=(t,a)=>g(W(t),(([t,e])=>a(e,t))),Q=t=>U.values(t),X=t=>w(Y(t)),Z=t=>(t=>!c(t)&&l(J(t),(t=>t==U.prototype||c(J(t))),(()=>!0)))(t)&&0==X(t),tt=JSON.stringify,at=JSON.parse,et=t=>new Map(t),nt=(t,a)=>t?.get(a),st=(t,a)=>g([...t?.entries()??[]],(([t,e])=>a(e,t))),it=(t,a,e)=>c(e)?(B(t,a),t):t?.set(a,e),ot=(t,a,e,n)=>(j(t,a)?n?.(nt(t,a)):it(t,a,e()),nt(t,a)),rt=(t,a,e,n,s=0)=>l((e?ot:nt)(t,a[s],s>w(a)-2?e:et),(i=>{if(s>w(a)-2)return n?.(i)&&it(t,a[s]),i;const o=rt(i,a,e,n,s+1);return x(i)&&it(t,a[s]),o})),ct=t=>new Set(y(t)||c(t)?t:[t]),lt=(t,a)=>t?.add(a),ut=/^\d+$/,yt=et(),dt=et(),wt=(t,a,e,s,i,o,r,u={},d=[])=>{let p,E,g,h=0,m=0,S=0;ot(yt,d,(()=>0)),ot(dt,d,(()=>[]));const T=et(),[$,b,C,O,I]=((t=1,a)=>1!=t&&a.isMergeable()?[1,a.getMergeableContent,a.getTransactionMergeableChanges,([[t],[a]])=>!Z(t)||!Z(a),a.setDefaultContent]:2!=t?[0,a.getContent,a.getTransactionChanges,([t,a])=>!Z(t)||!Z(a),a.setContent]:v("Store type not supported by this Persister"))(r,t),[L,R,D]=(()=>{let t;const[a,e]=(()=>{const t=[];let a=0;return[e=>(e?N(t):null)??n+a++,a=>{ut.test(a)&&w(t)<1e3&&A(t,a)}]})(),s=et();return[(e,i,o,r=[],c=()=>[])=>{t??=J;const l=a(1);return it(s,l,[e,i,o,r,c]),lt(rt(i,o??[n],ct),l),l},(a,e,...i)=>f(((t,a=[n])=>{const e=[],s=(t,n)=>n==w(a)?A(e,t):null===a[n]?q(t,(t=>s(t,n+1))):f([a[n],null],(a=>s(nt(t,a),n+1)));return s(t,0),e})(a,e),(a=>q(a,(a=>nt(s,a)[0](t,...e??[],...i))))),t=>l(nt(s,t),(([,a,i])=>(rt(a,i??[n],void 0,(a=>(B(a,t),x(a)?1:0))),it(s,t),e(t),i))),a=>l(nt(s,a),(([a,,e=[],n,s])=>{const i=(...o)=>{const r=w(o);r==w(e)?a(t,...o,...s(o)):c(e[r])?f(n[r]?.(...o)??[],(t=>i(...o,t))):i(...o,e[r])};i()}))]})(),_=t=>{t!=h&&(h=t,R(T,void 0,h))},M=a=>{($&&y(a?.[0])?1===a?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===a?.[2]?t.applyChanges:t.setContent)(a)},P=async t=>(2!=h&&(_(1),m++,await U((async()=>{try{const e=await a();y(e)?M(e):t?I(t):v("Content is not an array "+e)}catch(a){o?.(a),t&&I(t)}_(0)}))),J),F=()=>(E&&(i(E),E=void 0),J),j=async t=>(1!=h&&(_(2),S++,await U((async()=>{try{await e(b,t)}catch(t){o?.(t)}_(0)}))),J),k=()=>(l(g,t.delListener),g=void 0,J),U=async(...t)=>(A(nt(dt,d),...t),await(async()=>{if(!nt(yt,d)){for(it(yt,d,1);!c(p=N(nt(dt,d)));)try{await p()}catch(t){o?.(t)}it(yt,d,0)}})(),J),J={load:P,startAutoLoad:async t=>{await F().load(t);try{E=await s((async(t,a)=>{a||t?2!=h&&(_(1),m++,M(a??t),_(0)):await P()}))}catch(t){o?.(t)}return J},stopAutoLoad:F,isAutoLoading:()=>!c(E),save:j,startAutoSave:async()=>(await k().save(),g=t.addDidFinishTransactionListener((()=>{const t=C();O(t)&&j(t)})),J),stopAutoSave:k,isAutoSaving:()=>!c(g),getStatus:()=>h,addStatusListener:t=>L(t,T),delListener:a=>(D(a),t),schedule:U,getStore:()=>t,destroy:()=>(nt(dt,d).splice(0,void 0),F().stopAutoSave()),getStats:()=>({loads:m,saves:S}),...u};return z(J)},pt=(t,a,e,n,i,o=vt,r,l)=>{const u=et();return[async()=>{u.clear(),g(await e(t,a),(({tn:t,cn:a})=>lt(ot(u,t,ct),a)))},async(a,e)=>((t,a)=>j(nt(u,t),a))(a,e)?G(m(g(await t(L+P(a)),(t=>{return[t[e],l?(a=V(t,e),n=l,G(K(a,((t,a)=>[a,n(t,a)])))):V(t,e)];var a,n})),(([t,a])=>!c(t)&&!Z(a)))):{},async(a,e,n,l,y,d=!1)=>{const w=ct();K(n??{},(t=>g(Y(t??{}),(t=>lt(w,t)))));const v=k(w);if(!d&&y&&h(v)&&j(u,a))return await t("DROP "+C+P(a)),void it(u,a);const f=nt(u,a),N=ct(k(f));if(h(v)||(j(u,a)?await p(g([e,...v],(async(n,s)=>{B(N,n)||(await t(O+P(a)+"ADD"+P(n)+i),0==s&&await t("CREATE UNIQUE INDEX pk ON "+P(a)+`(${P(e)})`),lt(f,n))}))):(await t("CREATE "+C+P(a)+`(${P(e)}${i} PRIMARY KEY${E(g(v,(t=>s+P(t)+i)))});`),it(u,a,ct([e,...v])))),await p([...!d&&l?g(k(N),(async n=>{n!=e&&(await t(O+P(a)+"DROP"+P(n)),B(f,n))})):[]]),d)c(n)?await t(I+P(a)+b+" true"):await p(K(n,(async(n,s)=>{c(n)?await t(I+P(a)+b+P(e)+"=$1",[s]):h(v)||await o(t,a,e,Y(n),{[s]:r?g(Q(n),r):Q(n)},f)})));else if(h(v))j(u,a)&&await t(I+P(a)+b+" true");else{const s=m(k(nt(u,a)),(t=>t!=e)),i={},c=[];K(n??{},((t,a)=>{i[a]=g(s,(a=>r?r(t?.[a]):t?.[a])),A(c,a)})),await o(t,a,e,s,i),await t(I+P(a)+b+P(e)+`NOT IN(${F(c)})`,c)}},async a=>{let e;await t("BEGIN");try{e=await a()}catch(t){n?.(t)}return await t("END"),e}]},vt=async(t,a,e,n,i)=>{const o=[1];await t("INSERT INTO"+P(a)+"("+((...t)=>E(g(t,P),s))(e,...n)+")VALUES"+E(K(i,(t=>"($"+o[0]+++","+F(t,o)+")")),s)+"ON CONFLICT("+P(e)+")DO UPDATE SET"+E(g(n,(t=>P(t)+"=excluded."+P(t))),s),K(i,((t,a)=>[a,...g(t,(t=>t??null))])).flat())},ft=(t,a,e,n,s,i,o,[r,c,l],u,y,d,w,p,v)=>{const[f,E,g,h]=pt(a,u,y,s,p,v),m=wt(t,(async()=>await h((async()=>{return await f(),t=(await E(r,c))[S]?.[l]??"null",at(t,((t,a)=>""===a?void 0:a));var t}))),(async t=>await h((async()=>{var a;await f(),await g(r,c,{[S]:{[l]:(a=t()??null,tt(a,((t,a)=>void 0===a?"":a)))}},!0,!0)}))),e,n,s,o,{[w]:()=>d,destroy:()=>(m.stopAutoLoad().stopAutoSave(),i(),m)},d);return m},Et=(t,a,e,n,s,i,o,[r,l,[u,y,d]],w,v,f,E,g,h,A,N)=>{const[$,b,C,O]=pt(a,w,v,s,g,h,A,N),I=async(t,a)=>await p(st(l,(async([e,n,s,i],o)=>{a&&!(o in t)||await C(e,n,t[o],s,i,a)}))),L=async(t,a)=>y?await C(d,T,{[S]:t},!0,!0,a):null,R=wt(t,(async()=>await O((async()=>{await $();const t=await(async()=>G(m(await p(st(r,(async([t,a],e)=>[t,await b(e,a)]))),(t=>!Z(t[1])))))(),a=await(async()=>u?(await b(d,T))[S]:{})();return Z(t)&&c(a)?void 0:[t,a]}))),(async(t,a)=>await O((async()=>{if(await $(),c(a)){const[a,e]=t();await I(a),await L(e)}else await I(a[0],!0),await L(a[1],!0)}))),e,n,s,o,{[E]:()=>f,destroy:()=>(R.stopAutoLoad().stopAutoSave(),i(),R)},f);return R},gt="ColumnName",ht="store",mt="json",At=ht+"TableName",Nt=ht+"Id"+gt,St=ht+gt,Tt="autoLoadIntervalSeconds",$t="rowId"+gt,bt="tableId",Ct="tableName",Ot="deleteEmptyColumns",It="deleteEmptyTable",Lt={mode:mt,[Tt]:1},Rt={load:0,save:0,[Ct]:e+"_values"},Dt=(t,a,e,n,s)=>{const i=et();return K(t,((t,o)=>{const r=d(Q(H(a,u(t)?{[e]:t}:t)),0,X(a));c(r[0])||n(o,r[0])||(s(o,r[0]),it(i,o,r))})),i},_t=(t,a,s,i,o,c,l,y,w,p,v="getDb",f)=>{let E,g,h;const m=((t,a)=>a?async(e,n)=>(a(e,n),await t(e,n)):t)(s,c),[A,N,S,C]=(t=>{const a=(t=>H(Lt,u(t)?{[At]:t}:t??{}))(t),n=a[Tt];if(a.mode==mt){const t=a[At]??e;return[1,n,[t,a[Nt]??T,a[St]??ht],ct(t)]}const{tables:{load:s={},save:i={}}={},values:o={}}=a,r=d(Q(H(Rt,o)),0,X(Rt)),c=r[2],l=ct(c),y=ct(c);return[0,n,[Dt(s,{[bt]:null,[$t]:T},bt,(t=>j(y,t)),(t=>lt(l,t))),Dt(i,{[Ct]:null,[$t]:T,[Ot]:0,[It]:0},Ct,((t,a)=>j(y,a)),((t,a)=>lt(l,a))),r],l]})(a);return(A?ft:Et)(t,m,(t=>{let a;const e=()=>a=setInterval((async()=>{try{const[{d:a,s:e,c:n}]=await m(`${$} ${D} d,${_} s,TOTAL_CHANGES() c FROM ${R}${D} JOIN ${R}${_}`);a==E&&e==g&&n==h||(null!=E&&t(),E=a,g=e,h=n)}catch{}}),1e3*N),n=()=>{E=g=h=null,r(a)},s=i((a=>{C.has(a)&&(n(),t(),e())}));return e(),()=>{n(),o(s)}}),(t=>t()),l,y,w,S,k(C),(async(t,a)=>await t(`${$} t.name tn,c.name cn FROM ${M}list()t,${M}info(t.name)c ${b} t.schema='main'AND t.type IN('table','view')AND t.name IN(${F(a)})ORDER BY t.name,c.name`,a)),p,v,n,f,(t=>!0===t?1:!1===t?0:t),void 0)};t.createSqliteWasmPersister=(t,a,e,n,s,i)=>_t(t,n,(async(t,a=[])=>e.exec(t,{bind:a,rowMode:"object",returnValue:"resultRows"}).map((t=>({...t})))),(t=>a.capi.sqlite3_update_hook(e,((a,e,n,s)=>t(s)),0)),(()=>a.capi.sqlite3_update_hook(e,(()=>0),0)),s,i,(()=>0),3,e)},"object"==typeof exports&&"undefined"!=typeof module?a(exports):"function"==typeof define&&define.amd?define(["exports"],a):a((t="undefined"!=typeof globalThis?globalThis:t||self).TinyBasePersisterSqliteWasm={});
|
|
1
|
+
var t,a;t=this,a=function(t){"use strict";const a=t=>typeof t,e="tinybase",n="",s=",",i=a(n),o=Promise,r=clearInterval,c=t=>null==t,l=(t,a,e)=>c(t)?e?.():a(t),u=t=>a(t)==i,y=t=>Array.isArray(t),d=(t,a,e)=>t.slice(a,e),w=t=>t.length,p=async t=>o.all(t),v=t=>{throw Error(t)},f=(t,a)=>t.forEach(a),E=(t,a="")=>t.join(a),g=(t,a)=>t.map(a),h=t=>0==w(t),m=(t,a)=>t.filter(a),A=(t,...a)=>t.push(...a),N=t=>t.shift(),S="_",T="_id",$="SELECT",b="WHERE",C="TABLE",O="ALTER "+C,I="DELETE FROM",L=$+"*FROM",R="pragma_",D="data_version",_="schema_version",M="pragma_table_",P=t=>`"${t.replace(/"/g,'""')}"`,F=(t,a=[1])=>E(g(t,(()=>"$"+a[0]++)),s),j=(t,a)=>t?.has(a)??!1,x=t=>c(t)||0==(t=>t?.size??0)(t),k=t=>[...t?.values()??[]],q=(t,a)=>t?.forEach(a),B=(t,a)=>t?.delete(a),U=Object,J=t=>U.getPrototypeOf(t),W=U.entries,Y=U.keys,z=U.freeze,G=(t=[])=>U.fromEntries(t),H=(...t)=>U.assign({},...t),V=(t,a)=>(delete t[a],t),K=(t,a)=>g(W(t),(([t,e])=>a(e,t))),Q=t=>U.values(t),X=t=>w(Y(t)),Z=t=>(t=>!c(t)&&l(J(t),(t=>t==U.prototype||c(J(t))),(()=>!0)))(t)&&0==X(t),tt=JSON.stringify,at=JSON.parse,et=t=>new Map(t),nt=(t,a)=>t?.get(a),st=(t,a)=>g([...t?.entries()??[]],(([t,e])=>a(e,t))),it=(t,a,e)=>c(e)?(B(t,a),t):t?.set(a,e),ot=(t,a,e,n)=>(j(t,a)?n?.(nt(t,a)):it(t,a,e()),nt(t,a)),rt=(t,a,e,n,s=0)=>l((e?ot:nt)(t,a[s],s>w(a)-2?e:et),(i=>{if(s>w(a)-2)return n?.(i)&&it(t,a[s]),i;const o=rt(i,a,e,n,s+1);return x(i)&&it(t,a[s]),o})),ct=t=>new Set(y(t)||c(t)?t:[t]),lt=(t,a)=>t?.add(a),ut=/^\d+$/,yt=et(),dt=et(),wt=(t,a,e,s,i,o,r,u={},d=[])=>{let p,E,g,h=0,m=0,S=0;ot(yt,d,(()=>0)),ot(dt,d,(()=>[]));const T=et(),[$,b,C,O,I]=((t=1,a)=>1!=t&&a.isMergeable()?[1,a.getMergeableContent,a.getTransactionMergeableChanges,([[t],[a]])=>!Z(t)||!Z(a),a.setDefaultContent]:2!=t?[0,a.getContent,a.getTransactionChanges,([t,a])=>!Z(t)||!Z(a),a.setContent]:v("Store type not supported by this Persister"))(r,t),[L,R,D]=(()=>{let t;const[a,e]=(()=>{const t=[];let a=0;return[e=>(e?N(t):null)??n+a++,a=>{ut.test(a)&&w(t)<1e3&&A(t,a)}]})(),s=et();return[(e,i,o,r=[],c=()=>[])=>{t??=J;const l=a(1);return it(s,l,[e,i,o,r,c]),lt(rt(i,o??[n],ct),l),l},(a,e,...i)=>f(((t,a=[n])=>{const e=[],s=(t,n)=>n==w(a)?A(e,t):null===a[n]?q(t,(t=>s(t,n+1))):f([a[n],null],(a=>s(nt(t,a),n+1)));return s(t,0),e})(a,e),(a=>q(a,(a=>nt(s,a)[0](t,...e??[],...i))))),t=>l(nt(s,t),(([,a,i])=>(rt(a,i??[n],void 0,(a=>(B(a,t),x(a)?1:0))),it(s,t),e(t),i))),a=>l(nt(s,a),(([a,,e=[],n,s])=>{const i=(...o)=>{const r=w(o);r==w(e)?a(t,...o,...s(o)):c(e[r])?f(n[r]?.(...o)??[],(t=>i(...o,t))):i(...o,e[r])};i()}))]})(),_=t=>{t!=h&&(h=t,R(T,void 0,h))},M=a=>{($&&y(a?.[0])?1===a?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===a?.[2]?t.applyChanges:t.setContent)(a)},P=async t=>(2!=h&&(_(1),m++,await U((async()=>{try{const e=await a();y(e)?M(e):t?I(t):v("Content is not an array: "+e)}catch(a){o?.(a),t&&I(t)}_(0)}))),J),F=()=>(E&&(i(E),E=void 0),J),j=async t=>(1!=h&&(_(2),S++,await U((async()=>{try{await e(b,t)}catch(t){o?.(t)}_(0)}))),J),k=()=>(l(g,t.delListener),g=void 0,J),U=async(...t)=>(A(nt(dt,d),...t),await(async()=>{if(!nt(yt,d)){for(it(yt,d,1);!c(p=N(nt(dt,d)));)try{await p()}catch(t){o?.(t)}it(yt,d,0)}})(),J),J={load:P,startAutoLoad:async t=>{await F().load(t);try{E=await s((async(t,a)=>{a||t?2!=h&&(_(1),m++,M(a??t),_(0)):await P()}))}catch(t){o?.(t)}return J},stopAutoLoad:F,isAutoLoading:()=>!c(E),save:j,startAutoSave:async()=>(await k().save(),g=t.addDidFinishTransactionListener((()=>{const t=C();O(t)&&j(t)})),J),stopAutoSave:k,isAutoSaving:()=>!c(g),getStatus:()=>h,addStatusListener:t=>L(t,T),delListener:a=>(D(a),t),schedule:U,getStore:()=>t,destroy:()=>(nt(dt,d).splice(0,void 0),F().stopAutoSave()),getStats:()=>({loads:m,saves:S}),...u};return z(J)},pt=(t,a,e,n,i,o=vt,r,l)=>{const u=et();return[async()=>{u.clear(),g(await e(t,a),(({tn:t,cn:a})=>lt(ot(u,t,ct),a)))},async(a,e)=>((t,a)=>j(nt(u,t),a))(a,e)?G(m(g(await t(L+P(a)),(t=>{return[t[e],l?(a=V(t,e),n=l,G(K(a,((t,a)=>[a,n(t,a)])))):V(t,e)];var a,n})),(([t,a])=>!c(t)&&!Z(a)))):{},async(a,e,n,l,y,d=!1)=>{const w=ct();K(n??{},(t=>g(Y(t??{}),(t=>lt(w,t)))));const v=k(w);if(!d&&y&&h(v)&&j(u,a))return await t("DROP "+C+P(a)),void it(u,a);const f=nt(u,a),N=ct(k(f));if(h(v)||(j(u,a)?await p(g([e,...v],(async(n,s)=>{B(N,n)||(await t(O+P(a)+"ADD"+P(n)+i),0==s&&await t("CREATE UNIQUE INDEX pk ON "+P(a)+`(${P(e)})`),lt(f,n))}))):(await t("CREATE "+C+P(a)+`(${P(e)}${i} PRIMARY KEY${E(g(v,(t=>s+P(t)+i)))});`),it(u,a,ct([e,...v])))),await p([...!d&&l?g(k(N),(async n=>{n!=e&&(await t(O+P(a)+"DROP"+P(n)),B(f,n))})):[]]),d)c(n)?await t(I+P(a)+b+" true"):await p(K(n,(async(n,s)=>{c(n)?await t(I+P(a)+b+P(e)+"=$1",[s]):h(v)||await o(t,a,e,Y(n),{[s]:r?g(Q(n),r):Q(n)},f)})));else if(h(v))j(u,a)&&await t(I+P(a)+b+" true");else{const s=m(k(nt(u,a)),(t=>t!=e)),i={},c=[];K(n??{},((t,a)=>{i[a]=g(s,(a=>r?r(t?.[a]):t?.[a])),A(c,a)})),await o(t,a,e,s,i),await t(I+P(a)+b+P(e)+`NOT IN(${F(c)})`,c)}},async a=>{let e;await t("BEGIN");try{e=await a()}catch(t){n?.(t)}return await t("END"),e}]},vt=async(t,a,e,n,i)=>{const o=[1];await t("INSERT INTO"+P(a)+"("+((...t)=>E(g(t,P),s))(e,...n)+")VALUES"+E(K(i,(t=>"($"+o[0]+++","+F(t,o)+")")),s)+"ON CONFLICT("+P(e)+")DO UPDATE SET"+E(g(n,(t=>P(t)+"=excluded."+P(t))),s),K(i,((t,a)=>[a,...g(t,(t=>t??null))])).flat())},ft=(t,a,e,n,s,i,o,[r,c,l],u,y,d,w,p,v)=>{const[f,E,g,h]=pt(a,u,y,s,p,v),m=wt(t,(async()=>await h((async()=>{return await f(),t=(await E(r,c))[S]?.[l]??"null",at(t,((t,a)=>""===a?void 0:a));var t}))),(async t=>await h((async()=>{var a;await f(),await g(r,c,{[S]:{[l]:(a=t()??null,tt(a,((t,a)=>void 0===a?"":a)))}},!0,!0)}))),e,n,s,o,{[w]:()=>d,destroy:()=>(m.stopAutoLoad().stopAutoSave(),i(),m)},d);return m},Et=(t,a,e,n,s,i,o,[r,l,[u,y,d]],w,v,f,E,g,h,A,N)=>{const[$,b,C,O]=pt(a,w,v,s,g,h,A,N),I=async(t,a)=>await p(st(l,(async([e,n,s,i],o)=>{a&&!(o in t)||await C(e,n,t[o],s,i,a)}))),L=async(t,a)=>y?await C(d,T,{[S]:t},!0,!0,a):null,R=wt(t,(async()=>await O((async()=>{await $();const t=await(async()=>G(m(await p(st(r,(async([t,a],e)=>[t,await b(e,a)]))),(t=>!Z(t[1])))))(),a=await(async()=>u?(await b(d,T))[S]:{})();return Z(t)&&c(a)?void 0:[t,a]}))),(async(t,a)=>await O((async()=>{if(await $(),c(a)){const[a,e]=t();await I(a),await L(e)}else await I(a[0],!0),await L(a[1],!0)}))),e,n,s,o,{[E]:()=>f,destroy:()=>(R.stopAutoLoad().stopAutoSave(),i(),R)},f);return R},gt="ColumnName",ht="store",mt="json",At=ht+"TableName",Nt=ht+"Id"+gt,St=ht+gt,Tt="autoLoadIntervalSeconds",$t="rowId"+gt,bt="tableId",Ct="tableName",Ot="deleteEmptyColumns",It="deleteEmptyTable",Lt={mode:mt,[Tt]:1},Rt={load:0,save:0,[Ct]:e+"_values"},Dt=(t,a,e,n,s)=>{const i=et();return K(t,((t,o)=>{const r=d(Q(H(a,u(t)?{[e]:t}:t)),0,X(a));c(r[0])||n(o,r[0])||(s(o,r[0]),it(i,o,r))})),i},_t=(t,a,s,i,o,c,l,y,w,p,v="getDb",f)=>{let E,g,h;const m=((t,a)=>a?async(e,n)=>(a(e,n),await t(e,n)):t)(s,c),[A,N,S,C]=(t=>{const a=(t=>H(Lt,u(t)?{[At]:t}:t??{}))(t),n=a[Tt];if(a.mode==mt){const t=a[At]??e;return[1,n,[t,a[Nt]??T,a[St]??ht],ct(t)]}const{tables:{load:s={},save:i={}}={},values:o={}}=a,r=d(Q(H(Rt,o)),0,X(Rt)),c=r[2],l=ct(c),y=ct(c);return[0,n,[Dt(s,{[bt]:null,[$t]:T},bt,(t=>j(y,t)),(t=>lt(l,t))),Dt(i,{[Ct]:null,[$t]:T,[Ot]:0,[It]:0},Ct,((t,a)=>j(y,a)),((t,a)=>lt(l,a))),r],l]})(a);return(A?ft:Et)(t,m,(t=>{let a;const e=()=>a=setInterval((async()=>{try{const[{d:a,s:e,c:n}]=await m(`${$} ${D} d,${_} s,TOTAL_CHANGES() c FROM ${R}${D} JOIN ${R}${_}`);a==E&&e==g&&n==h||(null!=E&&t(),E=a,g=e,h=n)}catch{}}),1e3*N),n=()=>{E=g=h=null,r(a)},s=i((a=>{C.has(a)&&(n(),t(),e())}));return e(),()=>{n(),o(s)}}),(t=>t()),l,y,w,S,k(C),(async(t,a)=>await t(`${$} t.name tn,c.name cn FROM ${M}list()t,${M}info(t.name)c ${b} t.schema='main'AND t.type IN('table','view')AND t.name IN(${F(a)})ORDER BY t.name,c.name`,a)),p,v,n,f,(t=>!0===t?1:!1===t?0:t),void 0)};t.createSqliteWasmPersister=(t,a,e,n,s,i)=>_t(t,n,(async(t,a=[])=>e.exec(t,{bind:a,rowMode:"object",returnValue:"resultRows"}).map((t=>({...t})))),(t=>a.capi.sqlite3_update_hook(e,((a,e,n,s)=>t(s)),0)),(()=>a.capi.sqlite3_update_hook(e,(()=>0),0)),s,i,(()=>0),3,e)},"object"==typeof exports&&"undefined"!=typeof module?a(exports):"function"==typeof define&&define.amd?define(["exports"],a):a((t="undefined"!=typeof globalThis?globalThis:t||self).TinyBasePersisterSqliteWasm={});
|
|
Binary file
|