tinybase 5.4.6 → 5.4.7
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/cjs/es6/index.cjs +13 -11
- package/cjs/es6/mergeable-store/index.cjs +12 -10
- package/cjs/es6/mergeable-store/with-schemas/index.cjs +12 -10
- package/cjs/es6/min/index.cjs +1 -1
- package/cjs/es6/min/index.cjs.gz +0 -0
- package/cjs/es6/min/mergeable-store/index.cjs +1 -1
- package/cjs/es6/min/mergeable-store/index.cjs.gz +0 -0
- package/cjs/es6/min/mergeable-store/with-schemas/index.cjs +1 -1
- package/cjs/es6/min/mergeable-store/with-schemas/index.cjs.gz +0 -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-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-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-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-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/queries/index.cjs +1 -1
- package/cjs/es6/min/queries/index.cjs.gz +0 -0
- package/cjs/es6/min/queries/with-schemas/index.cjs +1 -1
- package/cjs/es6/min/queries/with-schemas/index.cjs.gz +0 -0
- package/cjs/es6/min/store/index.cjs +1 -1
- package/cjs/es6/min/store/index.cjs.gz +0 -0
- package/cjs/es6/min/store/with-schemas/index.cjs +1 -1
- package/cjs/es6/min/store/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/min/with-schemas/index.cjs +1 -1
- package/cjs/es6/min/with-schemas/index.cjs.gz +0 -0
- package/cjs/es6/persisters/index.cjs +3 -3
- package/cjs/es6/persisters/persister-automerge/index.cjs +8 -6
- package/cjs/es6/persisters/persister-automerge/with-schemas/index.cjs +8 -6
- package/cjs/es6/persisters/persister-cr-sqlite-wasm/index.cjs +3 -3
- package/cjs/es6/persisters/persister-cr-sqlite-wasm/with-schemas/index.cjs +3 -3
- package/cjs/es6/persisters/persister-electric-sql/index.cjs +3 -3
- package/cjs/es6/persisters/persister-electric-sql/with-schemas/index.cjs +3 -3
- package/cjs/es6/persisters/persister-expo-sqlite/index.cjs +3 -3
- package/cjs/es6/persisters/persister-expo-sqlite/with-schemas/index.cjs +3 -3
- package/cjs/es6/persisters/persister-libsql/index.cjs +3 -3
- package/cjs/es6/persisters/persister-libsql/with-schemas/index.cjs +3 -3
- package/cjs/es6/persisters/persister-pglite/index.cjs +3 -3
- package/cjs/es6/persisters/persister-pglite/with-schemas/index.cjs +3 -3
- package/cjs/es6/persisters/persister-postgres/index.cjs +3 -3
- package/cjs/es6/persisters/persister-postgres/with-schemas/index.cjs +3 -3
- package/cjs/es6/persisters/persister-powersync/index.cjs +3 -3
- package/cjs/es6/persisters/persister-powersync/with-schemas/index.cjs +3 -3
- package/cjs/es6/persisters/persister-sqlite-wasm/index.cjs +3 -3
- package/cjs/es6/persisters/persister-sqlite-wasm/with-schemas/index.cjs +3 -3
- package/cjs/es6/persisters/persister-sqlite3/index.cjs +3 -3
- package/cjs/es6/persisters/persister-sqlite3/with-schemas/index.cjs +3 -3
- package/cjs/es6/persisters/persister-yjs/index.cjs +7 -5
- package/cjs/es6/persisters/persister-yjs/with-schemas/index.cjs +7 -5
- package/cjs/es6/persisters/with-schemas/index.cjs +3 -3
- package/cjs/es6/queries/index.cjs +4 -1
- package/cjs/es6/queries/with-schemas/index.cjs +4 -1
- package/cjs/es6/store/index.cjs +14 -9
- package/cjs/es6/store/with-schemas/index.cjs +14 -9
- package/cjs/es6/tools/index.cjs +4 -4
- package/cjs/es6/tools/with-schemas/index.cjs +4 -4
- package/cjs/es6/ui-react-inspector/index.cjs +11 -9
- package/cjs/es6/ui-react-inspector/with-schemas/index.cjs +11 -9
- package/cjs/es6/with-schemas/index.cjs +13 -11
- package/cjs/index.cjs +13 -11
- package/cjs/mergeable-store/index.cjs +12 -10
- package/cjs/mergeable-store/with-schemas/index.cjs +12 -10
- package/cjs/min/index.cjs +1 -1
- package/cjs/min/index.cjs.gz +0 -0
- package/cjs/min/mergeable-store/index.cjs +1 -1
- package/cjs/min/mergeable-store/index.cjs.gz +0 -0
- package/cjs/min/mergeable-store/with-schemas/index.cjs +1 -1
- package/cjs/min/mergeable-store/with-schemas/index.cjs.gz +0 -0
- 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-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-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-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-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/queries/index.cjs +1 -1
- package/cjs/min/queries/index.cjs.gz +0 -0
- package/cjs/min/queries/with-schemas/index.cjs +1 -1
- package/cjs/min/queries/with-schemas/index.cjs.gz +0 -0
- package/cjs/min/store/index.cjs +1 -1
- package/cjs/min/store/index.cjs.gz +0 -0
- package/cjs/min/store/with-schemas/index.cjs +1 -1
- package/cjs/min/store/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/min/with-schemas/index.cjs +1 -1
- package/cjs/min/with-schemas/index.cjs.gz +0 -0
- package/cjs/persisters/index.cjs +3 -3
- package/cjs/persisters/persister-automerge/index.cjs +8 -6
- package/cjs/persisters/persister-automerge/with-schemas/index.cjs +8 -6
- package/cjs/persisters/persister-cr-sqlite-wasm/index.cjs +3 -3
- package/cjs/persisters/persister-cr-sqlite-wasm/with-schemas/index.cjs +3 -3
- package/cjs/persisters/persister-electric-sql/index.cjs +3 -3
- package/cjs/persisters/persister-electric-sql/with-schemas/index.cjs +3 -3
- package/cjs/persisters/persister-expo-sqlite/index.cjs +3 -3
- package/cjs/persisters/persister-expo-sqlite/with-schemas/index.cjs +3 -3
- package/cjs/persisters/persister-libsql/index.cjs +3 -3
- package/cjs/persisters/persister-libsql/with-schemas/index.cjs +3 -3
- package/cjs/persisters/persister-pglite/index.cjs +3 -3
- package/cjs/persisters/persister-pglite/with-schemas/index.cjs +3 -3
- package/cjs/persisters/persister-postgres/index.cjs +3 -3
- package/cjs/persisters/persister-postgres/with-schemas/index.cjs +3 -3
- package/cjs/persisters/persister-powersync/index.cjs +3 -3
- package/cjs/persisters/persister-powersync/with-schemas/index.cjs +3 -3
- package/cjs/persisters/persister-sqlite-wasm/index.cjs +3 -3
- package/cjs/persisters/persister-sqlite-wasm/with-schemas/index.cjs +3 -3
- package/cjs/persisters/persister-sqlite3/index.cjs +3 -3
- package/cjs/persisters/persister-sqlite3/with-schemas/index.cjs +3 -3
- package/cjs/persisters/persister-yjs/index.cjs +7 -5
- package/cjs/persisters/persister-yjs/with-schemas/index.cjs +7 -5
- package/cjs/persisters/with-schemas/index.cjs +3 -3
- package/cjs/queries/index.cjs +4 -1
- package/cjs/queries/with-schemas/index.cjs +4 -1
- package/cjs/store/index.cjs +14 -9
- package/cjs/store/with-schemas/index.cjs +14 -9
- package/cjs/tools/index.cjs +4 -4
- package/cjs/tools/with-schemas/index.cjs +4 -4
- package/cjs/ui-react-inspector/index.cjs +11 -9
- package/cjs/ui-react-inspector/with-schemas/index.cjs +11 -9
- package/cjs/with-schemas/index.cjs +13 -11
- package/cli/index.js +4 -1
- package/es6/index.js +13 -11
- package/es6/mergeable-store/index.js +12 -10
- package/es6/mergeable-store/with-schemas/index.js +12 -10
- package/es6/min/index.js +1 -1
- package/es6/min/index.js.gz +0 -0
- package/es6/min/mergeable-store/index.js +1 -1
- package/es6/min/mergeable-store/index.js.gz +0 -0
- package/es6/min/mergeable-store/with-schemas/index.js +1 -1
- package/es6/min/mergeable-store/with-schemas/index.js.gz +0 -0
- 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-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-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-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-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/queries/index.js +1 -1
- package/es6/min/queries/index.js.gz +0 -0
- package/es6/min/queries/with-schemas/index.js +1 -1
- package/es6/min/queries/with-schemas/index.js.gz +0 -0
- package/es6/min/store/index.js +1 -1
- package/es6/min/store/index.js.gz +0 -0
- package/es6/min/store/with-schemas/index.js +1 -1
- package/es6/min/store/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/min/with-schemas/index.js +1 -1
- package/es6/min/with-schemas/index.js.gz +0 -0
- package/es6/persisters/index.js +3 -3
- package/es6/persisters/persister-automerge/index.js +8 -6
- package/es6/persisters/persister-automerge/with-schemas/index.js +8 -6
- package/es6/persisters/persister-cr-sqlite-wasm/index.js +3 -3
- package/es6/persisters/persister-cr-sqlite-wasm/with-schemas/index.js +3 -3
- package/es6/persisters/persister-electric-sql/index.js +3 -3
- package/es6/persisters/persister-electric-sql/with-schemas/index.js +3 -3
- package/es6/persisters/persister-expo-sqlite/index.js +3 -3
- package/es6/persisters/persister-expo-sqlite/with-schemas/index.js +3 -3
- package/es6/persisters/persister-libsql/index.js +3 -3
- package/es6/persisters/persister-libsql/with-schemas/index.js +3 -3
- package/es6/persisters/persister-pglite/index.js +3 -3
- package/es6/persisters/persister-pglite/with-schemas/index.js +3 -3
- package/es6/persisters/persister-postgres/index.js +3 -3
- package/es6/persisters/persister-postgres/with-schemas/index.js +3 -3
- package/es6/persisters/persister-powersync/index.js +3 -3
- package/es6/persisters/persister-powersync/with-schemas/index.js +3 -3
- package/es6/persisters/persister-sqlite-wasm/index.js +3 -3
- package/es6/persisters/persister-sqlite-wasm/with-schemas/index.js +3 -3
- package/es6/persisters/persister-sqlite3/index.js +3 -3
- package/es6/persisters/persister-sqlite3/with-schemas/index.js +3 -3
- package/es6/persisters/persister-yjs/index.js +7 -5
- package/es6/persisters/persister-yjs/with-schemas/index.js +7 -5
- package/es6/persisters/with-schemas/index.js +3 -3
- package/es6/queries/index.js +4 -1
- package/es6/queries/with-schemas/index.js +4 -1
- package/es6/store/index.js +14 -9
- package/es6/store/with-schemas/index.js +14 -9
- package/es6/tools/index.js +4 -4
- package/es6/tools/with-schemas/index.js +4 -4
- package/es6/ui-react-inspector/index.js +11 -9
- package/es6/ui-react-inspector/with-schemas/index.js +11 -9
- package/es6/with-schemas/index.js +13 -11
- package/index.js +13 -11
- package/mergeable-store/index.js +12 -10
- package/mergeable-store/with-schemas/index.js +12 -10
- package/min/index.js +1 -1
- package/min/index.js.gz +0 -0
- package/min/mergeable-store/index.js +1 -1
- package/min/mergeable-store/index.js.gz +0 -0
- package/min/mergeable-store/with-schemas/index.js +1 -1
- package/min/mergeable-store/with-schemas/index.js.gz +0 -0
- 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-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-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-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-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/queries/index.js +1 -1
- package/min/queries/index.js.gz +0 -0
- package/min/queries/with-schemas/index.js +1 -1
- package/min/queries/with-schemas/index.js.gz +0 -0
- package/min/store/index.js +1 -1
- package/min/store/index.js.gz +0 -0
- package/min/store/with-schemas/index.js +1 -1
- package/min/store/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/min/with-schemas/index.js +1 -1
- package/min/with-schemas/index.js.gz +0 -0
- package/package.json +7 -7
- package/persisters/index.js +3 -3
- package/persisters/persister-automerge/index.js +8 -6
- package/persisters/persister-automerge/with-schemas/index.js +8 -6
- package/persisters/persister-cr-sqlite-wasm/index.js +3 -3
- package/persisters/persister-cr-sqlite-wasm/with-schemas/index.js +3 -3
- package/persisters/persister-electric-sql/index.js +3 -3
- package/persisters/persister-electric-sql/with-schemas/index.js +3 -3
- package/persisters/persister-expo-sqlite/index.js +3 -3
- package/persisters/persister-expo-sqlite/with-schemas/index.js +3 -3
- package/persisters/persister-libsql/index.js +3 -3
- package/persisters/persister-libsql/with-schemas/index.js +3 -3
- package/persisters/persister-pglite/index.js +3 -3
- package/persisters/persister-pglite/with-schemas/index.js +3 -3
- package/persisters/persister-postgres/index.js +3 -3
- package/persisters/persister-postgres/with-schemas/index.js +3 -3
- package/persisters/persister-powersync/index.js +3 -3
- package/persisters/persister-powersync/with-schemas/index.js +3 -3
- package/persisters/persister-sqlite-wasm/index.js +3 -3
- package/persisters/persister-sqlite-wasm/with-schemas/index.js +3 -3
- package/persisters/persister-sqlite3/index.js +3 -3
- package/persisters/persister-sqlite3/with-schemas/index.js +3 -3
- package/persisters/persister-yjs/index.js +7 -5
- package/persisters/persister-yjs/with-schemas/index.js +7 -5
- package/persisters/with-schemas/index.js +3 -3
- package/queries/index.js +4 -1
- package/queries/with-schemas/index.js +4 -1
- package/readme.md +2 -2
- package/store/index.js +14 -9
- package/store/with-schemas/index.js +14 -9
- package/tools/index.js +4 -4
- package/tools/with-schemas/index.js +4 -4
- package/ui-react-inspector/index.js +11 -9
- package/ui-react-inspector/with-schemas/index.js +11 -9
- package/umd/es6/index.js +13 -11
- package/umd/es6/mergeable-store/index.js +12 -10
- package/umd/es6/mergeable-store/with-schemas/index.js +12 -10
- package/umd/es6/min/index.js +1 -1
- package/umd/es6/min/index.js.gz +0 -0
- package/umd/es6/min/mergeable-store/index.js +1 -1
- package/umd/es6/min/mergeable-store/index.js.gz +0 -0
- package/umd/es6/min/mergeable-store/with-schemas/index.js +1 -1
- package/umd/es6/min/mergeable-store/with-schemas/index.js.gz +0 -0
- 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-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-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-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-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/queries/index.js +1 -1
- package/umd/es6/min/queries/index.js.gz +0 -0
- package/umd/es6/min/queries/with-schemas/index.js +1 -1
- package/umd/es6/min/queries/with-schemas/index.js.gz +0 -0
- package/umd/es6/min/store/index.js +1 -1
- package/umd/es6/min/store/index.js.gz +0 -0
- package/umd/es6/min/store/with-schemas/index.js +1 -1
- package/umd/es6/min/store/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/min/with-schemas/index.js +1 -1
- package/umd/es6/min/with-schemas/index.js.gz +0 -0
- package/umd/es6/persisters/index.js +3 -3
- package/umd/es6/persisters/persister-automerge/index.js +8 -6
- package/umd/es6/persisters/persister-automerge/with-schemas/index.js +8 -6
- package/umd/es6/persisters/persister-cr-sqlite-wasm/index.js +3 -3
- package/umd/es6/persisters/persister-cr-sqlite-wasm/with-schemas/index.js +3 -3
- package/umd/es6/persisters/persister-electric-sql/index.js +3 -3
- package/umd/es6/persisters/persister-electric-sql/with-schemas/index.js +3 -3
- package/umd/es6/persisters/persister-expo-sqlite/index.js +3 -3
- package/umd/es6/persisters/persister-expo-sqlite/with-schemas/index.js +3 -3
- package/umd/es6/persisters/persister-libsql/index.js +3 -3
- package/umd/es6/persisters/persister-libsql/with-schemas/index.js +3 -3
- package/umd/es6/persisters/persister-pglite/index.js +3 -3
- package/umd/es6/persisters/persister-pglite/with-schemas/index.js +3 -3
- package/umd/es6/persisters/persister-postgres/index.js +3 -3
- package/umd/es6/persisters/persister-postgres/with-schemas/index.js +3 -3
- package/umd/es6/persisters/persister-powersync/index.js +3 -3
- package/umd/es6/persisters/persister-powersync/with-schemas/index.js +3 -3
- package/umd/es6/persisters/persister-sqlite-wasm/index.js +3 -3
- package/umd/es6/persisters/persister-sqlite-wasm/with-schemas/index.js +3 -3
- package/umd/es6/persisters/persister-sqlite3/index.js +3 -3
- package/umd/es6/persisters/persister-sqlite3/with-schemas/index.js +3 -3
- package/umd/es6/persisters/persister-yjs/index.js +7 -5
- package/umd/es6/persisters/persister-yjs/with-schemas/index.js +7 -5
- package/umd/es6/persisters/with-schemas/index.js +3 -3
- package/umd/es6/queries/index.js +4 -1
- package/umd/es6/queries/with-schemas/index.js +4 -1
- package/umd/es6/store/index.js +14 -9
- package/umd/es6/store/with-schemas/index.js +14 -9
- package/umd/es6/tools/index.js +4 -4
- package/umd/es6/tools/with-schemas/index.js +4 -4
- package/umd/es6/ui-react-inspector/index.js +11 -9
- package/umd/es6/ui-react-inspector/with-schemas/index.js +11 -9
- package/umd/es6/with-schemas/index.js +13 -11
- package/umd/index.js +13 -11
- package/umd/mergeable-store/index.js +12 -10
- package/umd/mergeable-store/with-schemas/index.js +12 -10
- package/umd/min/index.js +1 -1
- package/umd/min/index.js.gz +0 -0
- package/umd/min/mergeable-store/index.js +1 -1
- package/umd/min/mergeable-store/index.js.gz +0 -0
- package/umd/min/mergeable-store/with-schemas/index.js +1 -1
- package/umd/min/mergeable-store/with-schemas/index.js.gz +0 -0
- 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-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-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-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-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/queries/index.js +1 -1
- package/umd/min/queries/index.js.gz +0 -0
- package/umd/min/queries/with-schemas/index.js +1 -1
- package/umd/min/queries/with-schemas/index.js.gz +0 -0
- package/umd/min/store/index.js +1 -1
- package/umd/min/store/index.js.gz +0 -0
- package/umd/min/store/with-schemas/index.js +1 -1
- package/umd/min/store/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/min/with-schemas/index.js +1 -1
- package/umd/min/with-schemas/index.js.gz +0 -0
- package/umd/persisters/index.js +3 -3
- package/umd/persisters/persister-automerge/index.js +8 -6
- package/umd/persisters/persister-automerge/with-schemas/index.js +8 -6
- package/umd/persisters/persister-cr-sqlite-wasm/index.js +3 -3
- package/umd/persisters/persister-cr-sqlite-wasm/with-schemas/index.js +3 -3
- package/umd/persisters/persister-electric-sql/index.js +3 -3
- package/umd/persisters/persister-electric-sql/with-schemas/index.js +3 -3
- package/umd/persisters/persister-expo-sqlite/index.js +3 -3
- package/umd/persisters/persister-expo-sqlite/with-schemas/index.js +3 -3
- package/umd/persisters/persister-libsql/index.js +3 -3
- package/umd/persisters/persister-libsql/with-schemas/index.js +3 -3
- package/umd/persisters/persister-pglite/index.js +3 -3
- package/umd/persisters/persister-pglite/with-schemas/index.js +3 -3
- package/umd/persisters/persister-postgres/index.js +3 -3
- package/umd/persisters/persister-postgres/with-schemas/index.js +3 -3
- package/umd/persisters/persister-powersync/index.js +3 -3
- package/umd/persisters/persister-powersync/with-schemas/index.js +3 -3
- package/umd/persisters/persister-sqlite-wasm/index.js +3 -3
- package/umd/persisters/persister-sqlite-wasm/with-schemas/index.js +3 -3
- package/umd/persisters/persister-sqlite3/index.js +3 -3
- package/umd/persisters/persister-sqlite3/with-schemas/index.js +3 -3
- package/umd/persisters/persister-yjs/index.js +7 -5
- package/umd/persisters/persister-yjs/with-schemas/index.js +7 -5
- package/umd/persisters/with-schemas/index.js +3 -3
- package/umd/queries/index.js +4 -1
- package/umd/queries/with-schemas/index.js +4 -1
- package/umd/store/index.js +14 -9
- package/umd/store/with-schemas/index.js +14 -9
- package/umd/tools/index.js +4 -4
- package/umd/tools/with-schemas/index.js +4 -4
- package/umd/ui-react-inspector/index.js +11 -9
- package/umd/ui-react-inspector/with-schemas/index.js +11 -9
- package/umd/with-schemas/index.js +13 -11
- package/with-schemas/index.js +13 -11
|
@@ -1 +1 @@
|
|
|
1
|
-
import{addDatabaseChangeListener as a}from"expo-sqlite";const t=a=>typeof a,e="tinybase",n="",s=",",i=t(n),o=Promise,r=clearInterval,c=a=>null==a,l=(a,t,e)=>c(a)?e?.():t(a),y=a=>t(a)==i,w=a=>Array.isArray(a),u=(a,t,e)=>a.slice(t,e),d=a=>a.length,
|
|
1
|
+
import{addDatabaseChangeListener as a}from"expo-sqlite";const t=a=>typeof a,e="tinybase",n="",s=",",i=t(n),o=Promise,r=clearInterval,c=a=>null==a,l=(a,t,e)=>c(a)?e?.():t(a),y=a=>t(a)==i,w=a=>Array.isArray(a),u=(a,t,e)=>a.slice(t,e),d=a=>a.length,p=async a=>o.all(a),v=a=>{throw Error(a)},E=(a,t)=>a.forEach(t),g=(a,t="")=>a.join(t),m=(a,t)=>a.map(t),A=a=>0==d(a),h=(a,t)=>a.filter(t),N=(a,...t)=>a.push(...t),$=a=>a.shift(),f="_",S="_id",C="SELECT",O="WHERE",T="TABLE",b="ALTER "+T,I="DELETE FROM",L=C+"*FROM",D="pragma_",R="data_version",M="schema_version",_="pragma_table_",P=a=>`"${a.replace(/"/g,'""')}"`,F=(a,t=[1])=>g(m(a,(()=>"$"+t[0]++)),s),U=(a,t)=>a?.has(t)??!1,j=a=>c(a)||0==(a=>a?.size??0)(a),x=a=>[...a?.values()??[]],B=(a,t)=>a?.forEach(t),J=(a,t)=>a?.delete(t),Y=Object,k=a=>Y.getPrototypeOf(a),z=Y.entries,G=Y.keys,H=Y.freeze,q=(a=[])=>Y.fromEntries(a),K=(...a)=>Y.assign({},...a),Q=(a,t)=>(delete a[t],a),V=(a,t)=>m(z(a),(([a,e])=>t(e,a))),W=(a,t)=>q(V(a,((a,e)=>[e,t(a,e)]))),X=a=>Y.values(a),Z=a=>d(G(a)),aa=a=>(a=>!c(a)&&l(k(a),(a=>a==Y.prototype||c(k(a))),(()=>!0)))(a)&&0==Z(a),ta=JSON.stringify,ea=JSON.parse,na=a=>new Map(a),sa=(a,t)=>a?.get(t),ia=(a,t)=>m([...a?.entries()??[]],(([a,e])=>t(e,a))),oa=(a,t,e)=>c(e)?(J(a,t),a):a?.set(t,e),ra=(a,t,e,n)=>(U(a,t)?n?.(sa(a,t)):oa(a,t,e()),sa(a,t)),ca=(a,t,e,n,s=0)=>l((e?ra:sa)(a,t[s],s>d(t)-2?e:na),(i=>{if(s>d(t)-2)return n?.(i)&&oa(a,t[s]),i;const o=ca(i,t,e,n,s+1);return j(i)&&oa(a,t[s]),o})),la=a=>new Set(w(a)||c(a)?a:[a]),ya=(a,t)=>a?.add(t),wa=/^\d+$/,ua=na(),da=na(),pa=(a,t,e,s,i,o,r,y={},u=0,p=[])=>{let g,m,A,h=0,f=0,S=0;ra(ua,p,(()=>0)),ra(da,p,(()=>[]));const C=na(),[O,T,b,I,L]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!aa(a)||!aa(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!aa(a)||!aa(t),t.setContent]:v("Store type not supported by this Persister"))(r,a,u),[D,R,M]=(()=>{let a;const[t,e]=(()=>{const a=[];let t=0;return[e=>(e?$(a):null)??n+t++,t=>{wa.test(t)&&d(a)<1e3&&N(a,t)}]})(),s=na();return[(e,i,o,r=[],c=()=>[])=>{a??=z;const l=t(1);return oa(s,l,[e,i,o,r,c]),ya(ca(i,o??[n],la),l),l},(t,e,...i)=>E(((a,t=[n])=>{const e=[],s=(a,n)=>n==d(t)?N(e,a):null===t[n]?B(a,(a=>s(a,n+1))):E([t[n],null],(t=>s(sa(a,t),n+1)));return s(a,0),e})(t,e),(t=>B(t,(t=>sa(s,t)[0](a,...e??[],...i))))),a=>l(sa(s,a),(([,t,i])=>(ca(t,i??[n],void 0,(t=>(J(t,a),j(t)?1:0))),oa(s,a),e(a),i))),t=>l(sa(s,t),(([t,,e=[],n,s])=>{const i=(...o)=>{const r=d(o);r==d(e)?t(a,...o,...s(o)):c(e[r])?E(n[r]?.(...o)??[],(a=>i(...o,a))):i(...o,e[r])};i()}))]})(),_=a=>{a!=h&&(h=a,R(C,void 0,h))},P=t=>{(O&&w(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},F=async a=>(2!=h&&(_(1),f++,await k((async()=>{try{const e=await t();w(e)?P(e):a?L(a):v("Content is not an array: "+e)}catch(t){o?.(t),a&&L(a)}_(0)}))),z),U=()=>(m&&(i(m),m=void 0),z),x=async a=>(1!=h&&(_(2),S++,await k((async()=>{try{await e(T,a)}catch(a){o?.(a)}_(0)}))),z),Y=()=>(A&&(a.delListener(A),A=void 0),z),k=async(...a)=>(N(sa(da,p),...a),await(async()=>{if(!sa(ua,p)){for(oa(ua,p,1);!c(g=$(sa(da,p)));)try{await g()}catch(a){o?.(a)}oa(ua,p,0)}})(),z),z={load:F,startAutoLoad:async a=>{U(),await F(a);try{m=await s((async(a,t)=>{t||a?2!=h&&(_(1),f++,P(t??a),_(0)):await F()}))}catch(a){o?.(a)}return z},stopAutoLoad:U,isAutoLoading:()=>!c(m),save:x,startAutoSave:async()=>(Y(),await x(),A=a.addDidFinishTransactionListener((()=>{const a=b();I(a)&&x(a)})),z),stopAutoSave:Y,isAutoSaving:()=>!c(A),getStatus:()=>h,addStatusListener:a=>D(a,C),delListener:t=>(M(t),a),schedule:k,getStore:()=>a,destroy:()=>(sa(da,p).splice(0,void 0),U().stopAutoSave()),getStats:()=>({loads:f,saves:S}),...y};return H(z)},va=(a,t,e,n,i,o=Ea,r,l)=>{const y=na();return[async()=>{y.clear(),m(await e(a,t),(({tn:a,cn:t})=>ya(ra(y,a,la),t)))},async(t,e)=>((a,t)=>U(sa(y,a),t))(t,e)?q(h(m(await a(L+P(t)),(a=>[a[e],l?W(Q(a,e),l):Q(a,e)])),(([a,t])=>!c(a)&&!aa(t)))):{},async(t,e,n,l,w,u=!1)=>{const d=la();W(n??{},(a=>m(G(a??{}),(a=>ya(d,a)))));const v=x(d);if(!u&&w&&A(v)&&U(y,t))return await a("DROP "+T+P(t)),void oa(y,t);const E=sa(y,t),$=la(x(E));if(A(v)||(U(y,t)?await p(m([e,...v],(async(n,s)=>{J($,n)||(await a(b+P(t)+"ADD"+P(n)+i),0==s&&await a("CREATE UNIQUE INDEX pk ON "+P(t)+`(${P(e)})`),ya(E,n))}))):(await a("CREATE "+T+P(t)+`(${P(e)}${i} PRIMARY KEY${g(m(v,(a=>s+P(a)+i)))});`),oa(y,t,la([e,...v])))),await p([...!u&&l?m(x($),(async n=>{n!=e&&(await a(b+P(t)+"DROP"+P(n)),J(E,n))})):[]]),u)c(n)?await a(I+P(t)+O+" true"):await p(V(n,(async(n,s)=>{c(n)?await a(I+P(t)+O+P(e)+"=$1",[s]):A(v)||await o(a,t,e,G(n),{[s]:r?m(X(n),r):X(n)},E)})));else if(A(v))U(y,t)&&await a(I+P(t)+O+" true");else{const s=h(x(sa(y,t)),(a=>a!=e)),i={},c=[];W(n??{},((a,t)=>{i[t]=m(s,(t=>r?r(a?.[t]):a?.[t])),N(c,t)})),await o(a,t,e,s,i),await a(I+P(t)+O+P(e)+`NOT IN(${F(c)})`,c)}},async t=>{let e;await a("BEGIN");try{e=await t()}catch(a){n?.(a)}return await a("END"),e}]},Ea=async(a,t,e,n,i)=>{const o=[1];await a("INSERT INTO"+P(t)+"("+((...a)=>g(m(a,P),s))(e,...n)+")VALUES"+g(V(i,(a=>"($"+o[0]+++","+F(a,o)+")")),s)+"ON CONFLICT("+P(e)+")DO UPDATE SET"+g(m(n,(a=>P(a)+"=excluded."+P(a))),s),V(i,((a,t)=>[t,...m(a,(a=>a??null))])).flat())},ga=(a,t,e,n,s,i,o,[r,c,l],y,w,u,d,p,v)=>{const[E,g,m,A]=va(t,y,w,s,p,v),h=pa(a,(async()=>await A((async()=>{return await E(),a=(await g(r,c))[f]?.[l]??"null",ea(a,((a,t)=>""===t?void 0:t));var a}))),(async a=>await A((async()=>{var t;await E(),await m(r,c,{[f]:{[l]:(t=a()??null,ta(t,((a,t)=>void 0===t?"":t)))}},!0,!0)}))),e,n,s,o,{[d]:()=>u,destroy:()=>(h.stopAutoLoad().stopAutoSave(),i(),h)},0,u);return h},ma=(a,t,e,n,s,i,o,[r,l,[y,w,u]],d,v,E,g,m,A,N,$)=>{const[C,O,T,b]=va(t,d,v,s,m,A,N,$),I=async(a,t)=>await p(ia(l,(async([e,n,s,i],o)=>{t&&!(o in a)||await T(e,n,a[o],s,i,t)}))),L=async(a,t)=>w?await T(u,S,{[f]:a},!0,!0,t):null,D=pa(a,(async()=>await b((async()=>{await C();const a=await(async()=>q(h(await p(ia(r,(async([a,t],e)=>[a,await O(e,t)]))),(a=>!aa(a[1])))))(),t=await(async()=>y?(await O(u,S))[f]:{})();return aa(a)&&c(t)?void 0:[a,t]}))),(async(a,t)=>await b((async()=>{if(await C(),c(t)){const[t,e]=a();await I(t),await L(e)}else await I(t[0],!0),await L(t[1],!0)}))),e,n,s,o,{[g]:()=>E,destroy:()=>(D.stopAutoLoad().stopAutoSave(),i(),D)},0,E);return D},Aa="ColumnName",ha="store",Na="json",$a=ha+"TableName",fa=ha+"Id"+Aa,Sa=ha+Aa,Ca="autoLoadIntervalSeconds",Oa="rowId"+Aa,Ta="tableId",ba="tableName",Ia="deleteEmptyColumns",La="deleteEmptyTable",Da={mode:Na,[Ca]:1},Ra={load:0,save:0,[ba]:e+"_values"},Ma=(a,t,e,n,s)=>{const i=na();return W(a,((a,o)=>{const r=u(X(K(t,y(a)?{[e]:a}:a)),0,Z(t));c(r[0])||n(o,r[0])||(s(o,r[0]),oa(i,o,r))})),i},_a=(a,t,s,i,o,c,l,w,d,p,v="getDb",E)=>{let g,m,A;const h=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,c),[N,$,f,T]=(a=>{const t=(a=>K(Da,y(a)?{[$a]:a}:a??{}))(a),n=t[Ca];if(t.mode==Na){const a=t[$a]??e;return[1,n,[a,t[fa]??S,t[Sa]??ha],la(a)]}const{tables:{load:s={},save:i={}}={},values:o={}}=t,r=u(X(K(Ra,o)),0,Z(Ra)),c=r[2],l=la(c),w=la(c);return[0,n,[Ma(s,{[Ta]:null,[Oa]:S},Ta,(a=>U(w,a)),(a=>ya(l,a))),Ma(i,{[ba]:null,[Oa]:S,[Ia]:0,[La]:0},ba,((a,t)=>U(w,t)),((a,t)=>ya(l,t))),r],l]})(t);return(N?ga:ma)(a,h,(a=>{let t;const e=()=>t=setInterval((async()=>{try{const[{d:t,s:e,c:n}]=await h(`${C} ${R} d,${M} s,TOTAL_CHANGES() c FROM ${D}${R} JOIN ${D}${M}`);t==g&&e==m&&n==A||(null!=g&&a(),g=t,m=e,A=n)}catch{}}),1e3*$),n=()=>{g=m=A=null,r(t)},s=i((t=>{T.has(t)&&(n(),a(),e())}));return e(),()=>{n(),o(s)}}),(a=>a()),l,w,d,f,x(T),(async(a,t)=>await a(`${C} t.name tn,c.name cn FROM ${_}list()t,${_}info(t.name)c ${O} t.schema='main'AND t.type IN('table','view')AND t.name IN(${F(t)})ORDER BY t.name,c.name`,t)),p,v,n,E,(a=>!0===a?1:!1===a?0:a),void 0)},Pa=(t,e,n,s,i)=>_a(t,n,(async(a,t=[])=>await e.getAllAsync(a,t)),(t=>a((({tableName:a})=>t(a)))),(a=>a.remove()),s,i,(()=>0),3,e);export{Pa as createExpoSqlitePersister};
|
|
Binary file
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{addDatabaseChangeListener as a}from"expo-sqlite";const t=a=>typeof a,e="tinybase",n="",s=",",i=t(n),o=Promise,r=clearInterval,c=a=>null==a,l=(a,t,e)=>c(a)?e?.():t(a),y=a=>t(a)==i,w=a=>Array.isArray(a),u=(a,t,e)=>a.slice(t,e),d=a=>a.length,
|
|
1
|
+
import{addDatabaseChangeListener as a}from"expo-sqlite";const t=a=>typeof a,e="tinybase",n="",s=",",i=t(n),o=Promise,r=clearInterval,c=a=>null==a,l=(a,t,e)=>c(a)?e?.():t(a),y=a=>t(a)==i,w=a=>Array.isArray(a),u=(a,t,e)=>a.slice(t,e),d=a=>a.length,p=async a=>o.all(a),v=a=>{throw Error(a)},E=(a,t)=>a.forEach(t),g=(a,t="")=>a.join(t),m=(a,t)=>a.map(t),A=a=>0==d(a),h=(a,t)=>a.filter(t),N=(a,...t)=>a.push(...t),$=a=>a.shift(),f="_",S="_id",C="SELECT",O="WHERE",T="TABLE",b="ALTER "+T,I="DELETE FROM",L=C+"*FROM",D="pragma_",R="data_version",M="schema_version",_="pragma_table_",P=a=>`"${a.replace(/"/g,'""')}"`,F=(a,t=[1])=>g(m(a,(()=>"$"+t[0]++)),s),U=(a,t)=>a?.has(t)??!1,j=a=>c(a)||0==(a=>a?.size??0)(a),x=a=>[...a?.values()??[]],B=(a,t)=>a?.forEach(t),J=(a,t)=>a?.delete(t),Y=Object,k=a=>Y.getPrototypeOf(a),z=Y.entries,G=Y.keys,H=Y.freeze,q=(a=[])=>Y.fromEntries(a),K=(...a)=>Y.assign({},...a),Q=(a,t)=>(delete a[t],a),V=(a,t)=>m(z(a),(([a,e])=>t(e,a))),W=(a,t)=>q(V(a,((a,e)=>[e,t(a,e)]))),X=a=>Y.values(a),Z=a=>d(G(a)),aa=a=>(a=>!c(a)&&l(k(a),(a=>a==Y.prototype||c(k(a))),(()=>!0)))(a)&&0==Z(a),ta=JSON.stringify,ea=JSON.parse,na=a=>new Map(a),sa=(a,t)=>a?.get(t),ia=(a,t)=>m([...a?.entries()??[]],(([a,e])=>t(e,a))),oa=(a,t,e)=>c(e)?(J(a,t),a):a?.set(t,e),ra=(a,t,e,n)=>(U(a,t)?n?.(sa(a,t)):oa(a,t,e()),sa(a,t)),ca=(a,t,e,n,s=0)=>l((e?ra:sa)(a,t[s],s>d(t)-2?e:na),(i=>{if(s>d(t)-2)return n?.(i)&&oa(a,t[s]),i;const o=ca(i,t,e,n,s+1);return j(i)&&oa(a,t[s]),o})),la=a=>new Set(w(a)||c(a)?a:[a]),ya=(a,t)=>a?.add(t),wa=/^\d+$/,ua=na(),da=na(),pa=(a,t,e,s,i,o,r,y={},u=0,p=[])=>{let g,m,A,h=0,f=0,S=0;ra(ua,p,(()=>0)),ra(da,p,(()=>[]));const C=na(),[O,T,b,I,L]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!aa(a)||!aa(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!aa(a)||!aa(t),t.setContent]:v("Store type not supported by this Persister"))(r,a,u),[D,R,M]=(()=>{let a;const[t,e]=(()=>{const a=[];let t=0;return[e=>(e?$(a):null)??n+t++,t=>{wa.test(t)&&d(a)<1e3&&N(a,t)}]})(),s=na();return[(e,i,o,r=[],c=()=>[])=>{a??=z;const l=t(1);return oa(s,l,[e,i,o,r,c]),ya(ca(i,o??[n],la),l),l},(t,e,...i)=>E(((a,t=[n])=>{const e=[],s=(a,n)=>n==d(t)?N(e,a):null===t[n]?B(a,(a=>s(a,n+1))):E([t[n],null],(t=>s(sa(a,t),n+1)));return s(a,0),e})(t,e),(t=>B(t,(t=>sa(s,t)[0](a,...e??[],...i))))),a=>l(sa(s,a),(([,t,i])=>(ca(t,i??[n],void 0,(t=>(J(t,a),j(t)?1:0))),oa(s,a),e(a),i))),t=>l(sa(s,t),(([t,,e=[],n,s])=>{const i=(...o)=>{const r=d(o);r==d(e)?t(a,...o,...s(o)):c(e[r])?E(n[r]?.(...o)??[],(a=>i(...o,a))):i(...o,e[r])};i()}))]})(),_=a=>{a!=h&&(h=a,R(C,void 0,h))},P=t=>{(O&&w(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},F=async a=>(2!=h&&(_(1),f++,await k((async()=>{try{const e=await t();w(e)?P(e):a?L(a):v("Content is not an array: "+e)}catch(t){o?.(t),a&&L(a)}_(0)}))),z),U=()=>(m&&(i(m),m=void 0),z),x=async a=>(1!=h&&(_(2),S++,await k((async()=>{try{await e(T,a)}catch(a){o?.(a)}_(0)}))),z),Y=()=>(A&&(a.delListener(A),A=void 0),z),k=async(...a)=>(N(sa(da,p),...a),await(async()=>{if(!sa(ua,p)){for(oa(ua,p,1);!c(g=$(sa(da,p)));)try{await g()}catch(a){o?.(a)}oa(ua,p,0)}})(),z),z={load:F,startAutoLoad:async a=>{U(),await F(a);try{m=await s((async(a,t)=>{t||a?2!=h&&(_(1),f++,P(t??a),_(0)):await F()}))}catch(a){o?.(a)}return z},stopAutoLoad:U,isAutoLoading:()=>!c(m),save:x,startAutoSave:async()=>(Y(),await x(),A=a.addDidFinishTransactionListener((()=>{const a=b();I(a)&&x(a)})),z),stopAutoSave:Y,isAutoSaving:()=>!c(A),getStatus:()=>h,addStatusListener:a=>D(a,C),delListener:t=>(M(t),a),schedule:k,getStore:()=>a,destroy:()=>(sa(da,p).splice(0,void 0),U().stopAutoSave()),getStats:()=>({loads:f,saves:S}),...y};return H(z)},va=(a,t,e,n,i,o=Ea,r,l)=>{const y=na();return[async()=>{y.clear(),m(await e(a,t),(({tn:a,cn:t})=>ya(ra(y,a,la),t)))},async(t,e)=>((a,t)=>U(sa(y,a),t))(t,e)?q(h(m(await a(L+P(t)),(a=>[a[e],l?W(Q(a,e),l):Q(a,e)])),(([a,t])=>!c(a)&&!aa(t)))):{},async(t,e,n,l,w,u=!1)=>{const d=la();W(n??{},(a=>m(G(a??{}),(a=>ya(d,a)))));const v=x(d);if(!u&&w&&A(v)&&U(y,t))return await a("DROP "+T+P(t)),void oa(y,t);const E=sa(y,t),$=la(x(E));if(A(v)||(U(y,t)?await p(m([e,...v],(async(n,s)=>{J($,n)||(await a(b+P(t)+"ADD"+P(n)+i),0==s&&await a("CREATE UNIQUE INDEX pk ON "+P(t)+`(${P(e)})`),ya(E,n))}))):(await a("CREATE "+T+P(t)+`(${P(e)}${i} PRIMARY KEY${g(m(v,(a=>s+P(a)+i)))});`),oa(y,t,la([e,...v])))),await p([...!u&&l?m(x($),(async n=>{n!=e&&(await a(b+P(t)+"DROP"+P(n)),J(E,n))})):[]]),u)c(n)?await a(I+P(t)+O+" true"):await p(V(n,(async(n,s)=>{c(n)?await a(I+P(t)+O+P(e)+"=$1",[s]):A(v)||await o(a,t,e,G(n),{[s]:r?m(X(n),r):X(n)},E)})));else if(A(v))U(y,t)&&await a(I+P(t)+O+" true");else{const s=h(x(sa(y,t)),(a=>a!=e)),i={},c=[];W(n??{},((a,t)=>{i[t]=m(s,(t=>r?r(a?.[t]):a?.[t])),N(c,t)})),await o(a,t,e,s,i),await a(I+P(t)+O+P(e)+`NOT IN(${F(c)})`,c)}},async t=>{let e;await a("BEGIN");try{e=await t()}catch(a){n?.(a)}return await a("END"),e}]},Ea=async(a,t,e,n,i)=>{const o=[1];await a("INSERT INTO"+P(t)+"("+((...a)=>g(m(a,P),s))(e,...n)+")VALUES"+g(V(i,(a=>"($"+o[0]+++","+F(a,o)+")")),s)+"ON CONFLICT("+P(e)+")DO UPDATE SET"+g(m(n,(a=>P(a)+"=excluded."+P(a))),s),V(i,((a,t)=>[t,...m(a,(a=>a??null))])).flat())},ga=(a,t,e,n,s,i,o,[r,c,l],y,w,u,d,p,v)=>{const[E,g,m,A]=va(t,y,w,s,p,v),h=pa(a,(async()=>await A((async()=>{return await E(),a=(await g(r,c))[f]?.[l]??"null",ea(a,((a,t)=>""===t?void 0:t));var a}))),(async a=>await A((async()=>{var t;await E(),await m(r,c,{[f]:{[l]:(t=a()??null,ta(t,((a,t)=>void 0===t?"":t)))}},!0,!0)}))),e,n,s,o,{[d]:()=>u,destroy:()=>(h.stopAutoLoad().stopAutoSave(),i(),h)},0,u);return h},ma=(a,t,e,n,s,i,o,[r,l,[y,w,u]],d,v,E,g,m,A,N,$)=>{const[C,O,T,b]=va(t,d,v,s,m,A,N,$),I=async(a,t)=>await p(ia(l,(async([e,n,s,i],o)=>{t&&!(o in a)||await T(e,n,a[o],s,i,t)}))),L=async(a,t)=>w?await T(u,S,{[f]:a},!0,!0,t):null,D=pa(a,(async()=>await b((async()=>{await C();const a=await(async()=>q(h(await p(ia(r,(async([a,t],e)=>[a,await O(e,t)]))),(a=>!aa(a[1])))))(),t=await(async()=>y?(await O(u,S))[f]:{})();return aa(a)&&c(t)?void 0:[a,t]}))),(async(a,t)=>await b((async()=>{if(await C(),c(t)){const[t,e]=a();await I(t),await L(e)}else await I(t[0],!0),await L(t[1],!0)}))),e,n,s,o,{[g]:()=>E,destroy:()=>(D.stopAutoLoad().stopAutoSave(),i(),D)},0,E);return D},Aa="ColumnName",ha="store",Na="json",$a=ha+"TableName",fa=ha+"Id"+Aa,Sa=ha+Aa,Ca="autoLoadIntervalSeconds",Oa="rowId"+Aa,Ta="tableId",ba="tableName",Ia="deleteEmptyColumns",La="deleteEmptyTable",Da={mode:Na,[Ca]:1},Ra={load:0,save:0,[ba]:e+"_values"},Ma=(a,t,e,n,s)=>{const i=na();return W(a,((a,o)=>{const r=u(X(K(t,y(a)?{[e]:a}:a)),0,Z(t));c(r[0])||n(o,r[0])||(s(o,r[0]),oa(i,o,r))})),i},_a=(a,t,s,i,o,c,l,w,d,p,v="getDb",E)=>{let g,m,A;const h=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,c),[N,$,f,T]=(a=>{const t=(a=>K(Da,y(a)?{[$a]:a}:a??{}))(a),n=t[Ca];if(t.mode==Na){const a=t[$a]??e;return[1,n,[a,t[fa]??S,t[Sa]??ha],la(a)]}const{tables:{load:s={},save:i={}}={},values:o={}}=t,r=u(X(K(Ra,o)),0,Z(Ra)),c=r[2],l=la(c),w=la(c);return[0,n,[Ma(s,{[Ta]:null,[Oa]:S},Ta,(a=>U(w,a)),(a=>ya(l,a))),Ma(i,{[ba]:null,[Oa]:S,[Ia]:0,[La]:0},ba,((a,t)=>U(w,t)),((a,t)=>ya(l,t))),r],l]})(t);return(N?ga:ma)(a,h,(a=>{let t;const e=()=>t=setInterval((async()=>{try{const[{d:t,s:e,c:n}]=await h(`${C} ${R} d,${M} s,TOTAL_CHANGES() c FROM ${D}${R} JOIN ${D}${M}`);t==g&&e==m&&n==A||(null!=g&&a(),g=t,m=e,A=n)}catch{}}),1e3*$),n=()=>{g=m=A=null,r(t)},s=i((t=>{T.has(t)&&(n(),a(),e())}));return e(),()=>{n(),o(s)}}),(a=>a()),l,w,d,f,x(T),(async(a,t)=>await a(`${C} t.name tn,c.name cn FROM ${_}list()t,${_}info(t.name)c ${O} t.schema='main'AND t.type IN('table','view')AND t.name IN(${F(t)})ORDER BY t.name,c.name`,t)),p,v,n,E,(a=>!0===a?1:!1===a?0:a),void 0)},Pa=(t,e,n,s,i)=>_a(t,n,(async(a,t=[])=>await e.getAllAsync(a,t)),(t=>a((({tableName:a})=>t(a)))),(a=>a.remove()),s,i,(()=>0),3,e);export{Pa as createExpoSqlitePersister};
|
|
Binary file
|
|
@@ -1 +1 @@
|
|
|
1
|
-
const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),i=Promise,
|
|
1
|
+
const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),i=Promise,o=clearInterval,r=a=>null==a,c=(a,t,e)=>r(a)?e?.():t(a),l=t=>a(t)==s,w=a=>Array.isArray(a),y=(a,t,e)=>a.slice(t,e),u=a=>a.length,d=async a=>i.all(a),v=a=>{throw Error(a)},p=(a,t)=>a.forEach(t),E=(a,t="")=>a.join(t),g=(a,t)=>a.map(t),A=a=>0==u(a),h=(a,t)=>a.filter(t),m=(a,...t)=>a.push(...t),N=a=>a.shift(),$="_",f="_id",C="SELECT",S="WHERE",O="TABLE",T="ALTER "+O,I="DELETE FROM",L=C+"*FROM",b="pragma_",D="data_version",R="schema_version",M="pragma_table_",_=a=>`"${a.replace(/"/g,'""')}"`,P=(a,t=[1])=>E(g(a,(()=>"$"+t[0]++)),n),F=(a,t)=>a?.has(t)??!1,U=a=>r(a)||0==(a=>a?.size??0)(a),j=a=>[...a?.values()??[]],x=(a,t)=>a?.forEach(t),B=(a,t)=>a?.delete(t),J=Object,Y=a=>J.getPrototypeOf(a),k=J.entries,z=J.keys,G=J.freeze,H=(a=[])=>J.fromEntries(a),q=(...a)=>J.assign({},...a),K=(a,t)=>(delete a[t],a),Q=(a,t)=>g(k(a),(([a,e])=>t(e,a))),V=(a,t)=>H(Q(a,((a,e)=>[e,t(a,e)]))),W=a=>J.values(a),X=a=>u(z(a)),Z=a=>(a=>!r(a)&&c(Y(a),(a=>a==J.prototype||r(Y(a))),(()=>!0)))(a)&&0==X(a),aa=JSON.stringify,ta=JSON.parse,ea=a=>new Map(a),na=(a,t)=>a?.get(t),sa=(a,t)=>g([...a?.entries()??[]],(([a,e])=>t(e,a))),ia=(a,t,e)=>r(e)?(B(a,t),a):a?.set(t,e),oa=(a,t,e,n)=>(F(a,t)?n?.(na(a,t)):ia(a,t,e()),na(a,t)),ra=(a,t,e,n,s=0)=>c((e?oa:na)(a,t[s],s>u(t)-2?e:ea),(i=>{if(s>u(t)-2)return n?.(i)&&ia(a,t[s]),i;const o=ra(i,t,e,n,s+1);return U(i)&&ia(a,t[s]),o})),ca=a=>new Set(w(a)||r(a)?a:[a]),la=(a,t)=>a?.add(t),wa=/^\d+$/,ya=ea(),ua=ea(),da=(a,t,n,s,i,o,l,y={},d=0,E=[])=>{let g,A,h,$=0,f=0,C=0;oa(ya,E,(()=>0)),oa(ua,E,(()=>[]));const S=ea(),[O,T,I,L,b]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!Z(a)||!Z(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!Z(a)||!Z(t),t.setContent]:v("Store type not supported by this Persister"))(l,a,d),[D,R,M]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?N(a):null)??e+t++,t=>{wa.test(t)&&u(a)<1e3&&m(a,t)}]})(),s=ea();return[(n,i,o,r=[],c=()=>[])=>{a??=z;const l=t(1);return ia(s,l,[n,i,o,r,c]),la(ra(i,o??[e],ca),l),l},(t,n,...i)=>p(((a,t=[e])=>{const n=[],s=(a,e)=>e==u(t)?m(n,a):null===t[e]?x(a,(a=>s(a,e+1))):p([t[e],null],(t=>s(na(a,t),e+1)));return s(a,0),n})(t,n),(t=>x(t,(t=>na(s,t)[0](a,...n??[],...i))))),a=>c(na(s,a),(([,t,i])=>(ra(t,i??[e],void 0,(t=>(B(t,a),U(t)?1:0))),ia(s,a),n(a),i))),t=>c(na(s,t),(([t,,e=[],n,s])=>{const i=(...o)=>{const c=u(o);c==u(e)?t(a,...o,...s(o)):r(e[c])?p(n[c]?.(...o)??[],(a=>i(...o,a))):i(...o,e[c])};i()}))]})(),_=a=>{a!=$&&($=a,R(S,void 0,$))},P=t=>{(O&&w(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},F=async a=>(2!=$&&(_(1),f++,await k((async()=>{try{const e=await t();w(e)?P(e):a?b(a):v("Content is not an array: "+e)}catch(t){o?.(t),a&&b(a)}_(0)}))),z),j=()=>(A&&(i(A),A=void 0),z),J=async a=>(1!=$&&(_(2),C++,await k((async()=>{try{await n(T,a)}catch(a){o?.(a)}_(0)}))),z),Y=()=>(h&&(a.delListener(h),h=void 0),z),k=async(...a)=>(m(na(ua,E),...a),await(async()=>{if(!na(ya,E)){for(ia(ya,E,1);!r(g=N(na(ua,E)));)try{await g()}catch(a){o?.(a)}ia(ya,E,0)}})(),z),z={load:F,startAutoLoad:async a=>{j(),await F(a);try{A=await s((async(a,t)=>{t||a?2!=$&&(_(1),f++,P(t??a),_(0)):await F()}))}catch(a){o?.(a)}return z},stopAutoLoad:j,isAutoLoading:()=>!r(A),save:J,startAutoSave:async()=>(Y(),await J(),h=a.addDidFinishTransactionListener((()=>{const a=I();L(a)&&J(a)})),z),stopAutoSave:Y,isAutoSaving:()=>!r(h),getStatus:()=>$,addStatusListener:a=>D(a,S),delListener:t=>(M(t),a),schedule:k,getStore:()=>a,destroy:()=>(na(ua,E).splice(0,void 0),j().stopAutoSave()),getStats:()=>({loads:f,saves:C}),...y};return G(z)},va=(a,t,e,s,i,o=pa,c,l)=>{const w=ea();return[async()=>{w.clear(),g(await e(a,t),(({tn:a,cn:t})=>la(oa(w,a,ca),t)))},async(t,e)=>((a,t)=>F(na(w,a),t))(t,e)?H(h(g(await a(L+_(t)),(a=>[a[e],l?V(K(a,e),l):K(a,e)])),(([a,t])=>!r(a)&&!Z(t)))):{},async(t,e,s,l,y,u=!1)=>{const v=ca();V(s??{},(a=>g(z(a??{}),(a=>la(v,a)))));const p=j(v);if(!u&&y&&A(p)&&F(w,t))return await a("DROP "+O+_(t)),void ia(w,t);const N=na(w,t),$=ca(j(N));if(A(p)||(F(w,t)?await d(g([e,...p],(async(n,s)=>{B($,n)||(await a(T+_(t)+"ADD"+_(n)+i),0==s&&await a("CREATE UNIQUE INDEX pk ON "+_(t)+`(${_(e)})`),la(N,n))}))):(await a("CREATE "+O+_(t)+`(${_(e)}${i} PRIMARY KEY${E(g(p,(a=>n+_(a)+i)))});`),ia(w,t,ca([e,...p])))),await d([...!u&&l?g(j($),(async n=>{n!=e&&(await a(T+_(t)+"DROP"+_(n)),B(N,n))})):[]]),u)r(s)?await a(I+_(t)+S+" true"):await d(Q(s,(async(n,s)=>{r(n)?await a(I+_(t)+S+_(e)+"=$1",[s]):A(p)||await o(a,t,e,z(n),{[s]:c?g(W(n),c):W(n)},N)})));else if(A(p))F(w,t)&&await a(I+_(t)+S+" true");else{const n=h(j(na(w,t)),(a=>a!=e)),i={},r=[];V(s??{},((a,t)=>{i[t]=g(n,(t=>c?c(a?.[t]):a?.[t])),m(r,t)})),await o(a,t,e,n,i),await a(I+_(t)+S+_(e)+`NOT IN(${P(r)})`,r)}},async t=>{let e;await a("BEGIN");try{e=await t()}catch(a){s?.(a)}return await a("END"),e}]},pa=async(a,t,e,s,i)=>{const o=[1];await a("INSERT INTO"+_(t)+"("+((...a)=>E(g(a,_),n))(e,...s)+")VALUES"+E(Q(i,(a=>"($"+o[0]+++","+P(a,o)+")")),n)+"ON CONFLICT("+_(e)+")DO UPDATE SET"+E(g(s,(a=>_(a)+"=excluded."+_(a))),n),Q(i,((a,t)=>[t,...g(a,(a=>a??null))])).flat())},Ea=(a,t,e,n,s,i,o,[r,c,l],w,y,u,d,v,p)=>{const[E,g,A,h]=va(t,w,y,s,v,p),m=da(a,(async()=>await h((async()=>{return await E(),a=(await g(r,c))[$]?.[l]??"null",ta(a,((a,t)=>""===t?void 0:t));var a}))),(async a=>await h((async()=>{var t;await E(),await A(r,c,{[$]:{[l]:(t=a()??null,aa(t,((a,t)=>void 0===t?"":t)))}},!0,!0)}))),e,n,s,o,{[d]:()=>u,destroy:()=>(m.stopAutoLoad().stopAutoSave(),i(),m)},0,u);return m},ga=(a,t,e,n,s,i,o,[c,l,[w,y,u]],v,p,E,g,A,m,N,C)=>{const[S,O,T,I]=va(t,v,p,s,A,m,N,C),L=async(a,t)=>await d(sa(l,(async([e,n,s,i],o)=>{t&&!(o in a)||await T(e,n,a[o],s,i,t)}))),b=async(a,t)=>y?await T(u,f,{[$]:a},!0,!0,t):null,D=da(a,(async()=>await I((async()=>{await S();const a=await(async()=>H(h(await d(sa(c,(async([a,t],e)=>[a,await O(e,t)]))),(a=>!Z(a[1])))))(),t=await(async()=>w?(await O(u,f))[$]:{})();return Z(a)&&r(t)?void 0:[a,t]}))),(async(a,t)=>await I((async()=>{if(await S(),r(t)){const[t,e]=a();await L(t),await b(e)}else await L(t[0],!0),await b(t[1],!0)}))),e,n,s,o,{[g]:()=>E,destroy:()=>(D.stopAutoLoad().stopAutoSave(),i(),D)},0,E);return D},Aa="ColumnName",ha="store",ma="json",Na=ha+"TableName",$a=ha+"Id"+Aa,fa=ha+Aa,Ca="autoLoadIntervalSeconds",Sa="rowId"+Aa,Oa="tableId",Ta="tableName",Ia="deleteEmptyColumns",La="deleteEmptyTable",ba={mode:ma,[Ca]:1},Da={load:0,save:0,[Ta]:t+"_values"},Ra=(a,t,e,n,s)=>{const i=ea();return V(a,((a,o)=>{const c=y(W(q(t,l(a)?{[e]:a}:a)),0,X(t));r(c[0])||n(o,c[0])||(s(o,c[0]),ia(i,o,c))})),i},Ma=(a,n,s,i,r,c,w,u,d,v,p="getDb",E)=>{let g,A,h;const m=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,c),[N,$,O,T]=(a=>{const e=(a=>q(ba,l(a)?{[Na]:a}:a??{}))(a),n=e[Ca];if(e.mode==ma){const a=e[Na]??t;return[1,n,[a,e[$a]??f,e[fa]??ha],ca(a)]}const{tables:{load:s={},save:i={}}={},values:o={}}=e,r=y(W(q(Da,o)),0,X(Da)),c=r[2],w=ca(c),u=ca(c);return[0,n,[Ra(s,{[Oa]:null,[Sa]:f},Oa,(a=>F(u,a)),(a=>la(w,a))),Ra(i,{[Ta]:null,[Sa]:f,[Ia]:0,[La]:0},Ta,((a,t)=>F(u,t)),((a,t)=>la(w,t))),r],w]})(n);return(N?Ea:ga)(a,m,(a=>{let t;const e=()=>t=setInterval((async()=>{try{const[{d:t,s:e,c:n}]=await m(`${C} ${D} d,${R} s,TOTAL_CHANGES() c FROM ${b}${D} JOIN ${b}${R}`);t==g&&e==A&&n==h||(null!=g&&a(),g=t,A=e,h=n)}catch{}}),1e3*$),n=()=>{g=A=h=null,o(t)},s=i((t=>{T.has(t)&&(n(),a(),e())}));return e(),()=>{n(),r(s)}}),(a=>a()),w,u,d,O,j(T),(async(a,t)=>await a(`${C} t.name tn,c.name cn FROM ${M}list()t,${M}info(t.name)c ${S} t.schema='main'AND t.type IN('table','view')AND t.name IN(${P(t)})ORDER BY t.name,c.name`,t)),v,p,e,E,(a=>!0===a?1:!1===a?0:a),void 0)},_a=(a,t,e,n,s)=>Ma(a,e,(async(a,e=[])=>(await t.execute({sql:a,args:e})).rows),(()=>()=>0),(a=>a()),n,s,(()=>0),1,t,"getClient");export{_a as createLibSqlPersister};
|
|
Binary file
|
|
@@ -1 +1 @@
|
|
|
1
|
-
const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),i=Promise,
|
|
1
|
+
const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),i=Promise,o=clearInterval,r=a=>null==a,c=(a,t,e)=>r(a)?e?.():t(a),l=t=>a(t)==s,w=a=>Array.isArray(a),y=(a,t,e)=>a.slice(t,e),u=a=>a.length,d=async a=>i.all(a),v=a=>{throw Error(a)},p=(a,t)=>a.forEach(t),E=(a,t="")=>a.join(t),g=(a,t)=>a.map(t),A=a=>0==u(a),h=(a,t)=>a.filter(t),m=(a,...t)=>a.push(...t),N=a=>a.shift(),$="_",f="_id",C="SELECT",S="WHERE",O="TABLE",T="ALTER "+O,I="DELETE FROM",L=C+"*FROM",b="pragma_",D="data_version",R="schema_version",M="pragma_table_",_=a=>`"${a.replace(/"/g,'""')}"`,P=(a,t=[1])=>E(g(a,(()=>"$"+t[0]++)),n),F=(a,t)=>a?.has(t)??!1,U=a=>r(a)||0==(a=>a?.size??0)(a),j=a=>[...a?.values()??[]],x=(a,t)=>a?.forEach(t),B=(a,t)=>a?.delete(t),J=Object,Y=a=>J.getPrototypeOf(a),k=J.entries,z=J.keys,G=J.freeze,H=(a=[])=>J.fromEntries(a),q=(...a)=>J.assign({},...a),K=(a,t)=>(delete a[t],a),Q=(a,t)=>g(k(a),(([a,e])=>t(e,a))),V=(a,t)=>H(Q(a,((a,e)=>[e,t(a,e)]))),W=a=>J.values(a),X=a=>u(z(a)),Z=a=>(a=>!r(a)&&c(Y(a),(a=>a==J.prototype||r(Y(a))),(()=>!0)))(a)&&0==X(a),aa=JSON.stringify,ta=JSON.parse,ea=a=>new Map(a),na=(a,t)=>a?.get(t),sa=(a,t)=>g([...a?.entries()??[]],(([a,e])=>t(e,a))),ia=(a,t,e)=>r(e)?(B(a,t),a):a?.set(t,e),oa=(a,t,e,n)=>(F(a,t)?n?.(na(a,t)):ia(a,t,e()),na(a,t)),ra=(a,t,e,n,s=0)=>c((e?oa:na)(a,t[s],s>u(t)-2?e:ea),(i=>{if(s>u(t)-2)return n?.(i)&&ia(a,t[s]),i;const o=ra(i,t,e,n,s+1);return U(i)&&ia(a,t[s]),o})),ca=a=>new Set(w(a)||r(a)?a:[a]),la=(a,t)=>a?.add(t),wa=/^\d+$/,ya=ea(),ua=ea(),da=(a,t,n,s,i,o,l,y={},d=0,E=[])=>{let g,A,h,$=0,f=0,C=0;oa(ya,E,(()=>0)),oa(ua,E,(()=>[]));const S=ea(),[O,T,I,L,b]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!Z(a)||!Z(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!Z(a)||!Z(t),t.setContent]:v("Store type not supported by this Persister"))(l,a,d),[D,R,M]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?N(a):null)??e+t++,t=>{wa.test(t)&&u(a)<1e3&&m(a,t)}]})(),s=ea();return[(n,i,o,r=[],c=()=>[])=>{a??=z;const l=t(1);return ia(s,l,[n,i,o,r,c]),la(ra(i,o??[e],ca),l),l},(t,n,...i)=>p(((a,t=[e])=>{const n=[],s=(a,e)=>e==u(t)?m(n,a):null===t[e]?x(a,(a=>s(a,e+1))):p([t[e],null],(t=>s(na(a,t),e+1)));return s(a,0),n})(t,n),(t=>x(t,(t=>na(s,t)[0](a,...n??[],...i))))),a=>c(na(s,a),(([,t,i])=>(ra(t,i??[e],void 0,(t=>(B(t,a),U(t)?1:0))),ia(s,a),n(a),i))),t=>c(na(s,t),(([t,,e=[],n,s])=>{const i=(...o)=>{const c=u(o);c==u(e)?t(a,...o,...s(o)):r(e[c])?p(n[c]?.(...o)??[],(a=>i(...o,a))):i(...o,e[c])};i()}))]})(),_=a=>{a!=$&&($=a,R(S,void 0,$))},P=t=>{(O&&w(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},F=async a=>(2!=$&&(_(1),f++,await k((async()=>{try{const e=await t();w(e)?P(e):a?b(a):v("Content is not an array: "+e)}catch(t){o?.(t),a&&b(a)}_(0)}))),z),j=()=>(A&&(i(A),A=void 0),z),J=async a=>(1!=$&&(_(2),C++,await k((async()=>{try{await n(T,a)}catch(a){o?.(a)}_(0)}))),z),Y=()=>(h&&(a.delListener(h),h=void 0),z),k=async(...a)=>(m(na(ua,E),...a),await(async()=>{if(!na(ya,E)){for(ia(ya,E,1);!r(g=N(na(ua,E)));)try{await g()}catch(a){o?.(a)}ia(ya,E,0)}})(),z),z={load:F,startAutoLoad:async a=>{j(),await F(a);try{A=await s((async(a,t)=>{t||a?2!=$&&(_(1),f++,P(t??a),_(0)):await F()}))}catch(a){o?.(a)}return z},stopAutoLoad:j,isAutoLoading:()=>!r(A),save:J,startAutoSave:async()=>(Y(),await J(),h=a.addDidFinishTransactionListener((()=>{const a=I();L(a)&&J(a)})),z),stopAutoSave:Y,isAutoSaving:()=>!r(h),getStatus:()=>$,addStatusListener:a=>D(a,S),delListener:t=>(M(t),a),schedule:k,getStore:()=>a,destroy:()=>(na(ua,E).splice(0,void 0),j().stopAutoSave()),getStats:()=>({loads:f,saves:C}),...y};return G(z)},va=(a,t,e,s,i,o=pa,c,l)=>{const w=ea();return[async()=>{w.clear(),g(await e(a,t),(({tn:a,cn:t})=>la(oa(w,a,ca),t)))},async(t,e)=>((a,t)=>F(na(w,a),t))(t,e)?H(h(g(await a(L+_(t)),(a=>[a[e],l?V(K(a,e),l):K(a,e)])),(([a,t])=>!r(a)&&!Z(t)))):{},async(t,e,s,l,y,u=!1)=>{const v=ca();V(s??{},(a=>g(z(a??{}),(a=>la(v,a)))));const p=j(v);if(!u&&y&&A(p)&&F(w,t))return await a("DROP "+O+_(t)),void ia(w,t);const N=na(w,t),$=ca(j(N));if(A(p)||(F(w,t)?await d(g([e,...p],(async(n,s)=>{B($,n)||(await a(T+_(t)+"ADD"+_(n)+i),0==s&&await a("CREATE UNIQUE INDEX pk ON "+_(t)+`(${_(e)})`),la(N,n))}))):(await a("CREATE "+O+_(t)+`(${_(e)}${i} PRIMARY KEY${E(g(p,(a=>n+_(a)+i)))});`),ia(w,t,ca([e,...p])))),await d([...!u&&l?g(j($),(async n=>{n!=e&&(await a(T+_(t)+"DROP"+_(n)),B(N,n))})):[]]),u)r(s)?await a(I+_(t)+S+" true"):await d(Q(s,(async(n,s)=>{r(n)?await a(I+_(t)+S+_(e)+"=$1",[s]):A(p)||await o(a,t,e,z(n),{[s]:c?g(W(n),c):W(n)},N)})));else if(A(p))F(w,t)&&await a(I+_(t)+S+" true");else{const n=h(j(na(w,t)),(a=>a!=e)),i={},r=[];V(s??{},((a,t)=>{i[t]=g(n,(t=>c?c(a?.[t]):a?.[t])),m(r,t)})),await o(a,t,e,n,i),await a(I+_(t)+S+_(e)+`NOT IN(${P(r)})`,r)}},async t=>{let e;await a("BEGIN");try{e=await t()}catch(a){s?.(a)}return await a("END"),e}]},pa=async(a,t,e,s,i)=>{const o=[1];await a("INSERT INTO"+_(t)+"("+((...a)=>E(g(a,_),n))(e,...s)+")VALUES"+E(Q(i,(a=>"($"+o[0]+++","+P(a,o)+")")),n)+"ON CONFLICT("+_(e)+")DO UPDATE SET"+E(g(s,(a=>_(a)+"=excluded."+_(a))),n),Q(i,((a,t)=>[t,...g(a,(a=>a??null))])).flat())},Ea=(a,t,e,n,s,i,o,[r,c,l],w,y,u,d,v,p)=>{const[E,g,A,h]=va(t,w,y,s,v,p),m=da(a,(async()=>await h((async()=>{return await E(),a=(await g(r,c))[$]?.[l]??"null",ta(a,((a,t)=>""===t?void 0:t));var a}))),(async a=>await h((async()=>{var t;await E(),await A(r,c,{[$]:{[l]:(t=a()??null,aa(t,((a,t)=>void 0===t?"":t)))}},!0,!0)}))),e,n,s,o,{[d]:()=>u,destroy:()=>(m.stopAutoLoad().stopAutoSave(),i(),m)},0,u);return m},ga=(a,t,e,n,s,i,o,[c,l,[w,y,u]],v,p,E,g,A,m,N,C)=>{const[S,O,T,I]=va(t,v,p,s,A,m,N,C),L=async(a,t)=>await d(sa(l,(async([e,n,s,i],o)=>{t&&!(o in a)||await T(e,n,a[o],s,i,t)}))),b=async(a,t)=>y?await T(u,f,{[$]:a},!0,!0,t):null,D=da(a,(async()=>await I((async()=>{await S();const a=await(async()=>H(h(await d(sa(c,(async([a,t],e)=>[a,await O(e,t)]))),(a=>!Z(a[1])))))(),t=await(async()=>w?(await O(u,f))[$]:{})();return Z(a)&&r(t)?void 0:[a,t]}))),(async(a,t)=>await I((async()=>{if(await S(),r(t)){const[t,e]=a();await L(t),await b(e)}else await L(t[0],!0),await b(t[1],!0)}))),e,n,s,o,{[g]:()=>E,destroy:()=>(D.stopAutoLoad().stopAutoSave(),i(),D)},0,E);return D},Aa="ColumnName",ha="store",ma="json",Na=ha+"TableName",$a=ha+"Id"+Aa,fa=ha+Aa,Ca="autoLoadIntervalSeconds",Sa="rowId"+Aa,Oa="tableId",Ta="tableName",Ia="deleteEmptyColumns",La="deleteEmptyTable",ba={mode:ma,[Ca]:1},Da={load:0,save:0,[Ta]:t+"_values"},Ra=(a,t,e,n,s)=>{const i=ea();return V(a,((a,o)=>{const c=y(W(q(t,l(a)?{[e]:a}:a)),0,X(t));r(c[0])||n(o,c[0])||(s(o,c[0]),ia(i,o,c))})),i},Ma=(a,n,s,i,r,c,w,u,d,v,p="getDb",E)=>{let g,A,h;const m=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,c),[N,$,O,T]=(a=>{const e=(a=>q(ba,l(a)?{[Na]:a}:a??{}))(a),n=e[Ca];if(e.mode==ma){const a=e[Na]??t;return[1,n,[a,e[$a]??f,e[fa]??ha],ca(a)]}const{tables:{load:s={},save:i={}}={},values:o={}}=e,r=y(W(q(Da,o)),0,X(Da)),c=r[2],w=ca(c),u=ca(c);return[0,n,[Ra(s,{[Oa]:null,[Sa]:f},Oa,(a=>F(u,a)),(a=>la(w,a))),Ra(i,{[Ta]:null,[Sa]:f,[Ia]:0,[La]:0},Ta,((a,t)=>F(u,t)),((a,t)=>la(w,t))),r],w]})(n);return(N?Ea:ga)(a,m,(a=>{let t;const e=()=>t=setInterval((async()=>{try{const[{d:t,s:e,c:n}]=await m(`${C} ${D} d,${R} s,TOTAL_CHANGES() c FROM ${b}${D} JOIN ${b}${R}`);t==g&&e==A&&n==h||(null!=g&&a(),g=t,A=e,h=n)}catch{}}),1e3*$),n=()=>{g=A=h=null,o(t)},s=i((t=>{T.has(t)&&(n(),a(),e())}));return e(),()=>{n(),r(s)}}),(a=>a()),w,u,d,O,j(T),(async(a,t)=>await a(`${C} t.name tn,c.name cn FROM ${M}list()t,${M}info(t.name)c ${S} t.schema='main'AND t.type IN('table','view')AND t.name IN(${P(t)})ORDER BY t.name,c.name`,t)),v,p,e,E,(a=>!0===a?1:!1===a?0:a),void 0)},_a=(a,t,e,n,s)=>Ma(a,e,(async(a,e=[])=>(await t.execute({sql:a,args:e})).rows),(()=>()=>0),(a=>a()),n,s,(()=>0),1,t,"getClient");export{_a as createLibSqlPersister};
|
|
Binary file
|
|
@@ -1 +1 @@
|
|
|
1
|
-
const a=a=>typeof a,t="tinybase",e=",",n=a(""),s=Promise,i=a=>null==a,
|
|
1
|
+
const a=a=>typeof a,t="tinybase",e=",",n=a(""),s=Promise,i=a=>null==a,o=(a,t,e)=>i(a)?e?.():t(a),r=t=>a(t)==n,c=a=>Array.isArray(a),E=(a,t,e)=>a.slice(t,e),l=a=>a.length,w=async a=>s.all(a),y=a=>{throw Error(a)},d=(a,t)=>a.forEach(t),u=(a,t="")=>a.join(t),T=(a,t)=>a.map(t),R=a=>0==l(a),A=(a,t)=>a.filter(t),N=(a,...t)=>a.push(...t),g=a=>a.shift(),p="_",C="_id",O="SELECT",L="WHERE",$="TABLE",v="ALTER "+$,I="DELETE FROM",S=O+"*FROM",m=a=>`"${a.replace(/"/g,'""')}"`,_=(a,t=[1])=>u(T(a,(()=>"$"+t[0]++)),e),h=(a,t)=>a?.has(t)??!1,f=a=>i(a)||0==(a=>a?.size??0)(a),b=a=>[...a?.values()??[]],D=(a,t)=>a?.forEach(t),P=(a,t)=>a?.delete(t),U=Object,F=a=>U.getPrototypeOf(a),M=U.entries,G=U.keys,B=U.freeze,j=(a=[])=>U.fromEntries(a),x=(...a)=>U.assign({},...a),X=(a,t)=>(delete a[t],a),Y=(a,t)=>T(M(a),(([a,e])=>t(e,a))),q=(a,t)=>j(Y(a,((a,e)=>[e,t(a,e)]))),H=a=>U.values(a),W=a=>l(G(a)),k=a=>(a=>!i(a)&&o(F(a),(a=>a==U.prototype||i(F(a))),(()=>!0)))(a)&&0==W(a),z=JSON.stringify,J=JSON.parse,K=a=>new Map(a),V=(a,t)=>a?.get(t),Q=(a,t)=>T([...a?.entries()??[]],(([a,e])=>t(e,a))),Z=(a,t,e)=>i(e)?(P(a,t),a):a?.set(t,e),aa=(a,t,e,n)=>(h(a,t)?n?.(V(a,t)):Z(a,t,e()),V(a,t)),ta=(a,t,e,n,s=0)=>o((e?aa:V)(a,t[s],s>l(t)-2?e:K),(i=>{if(s>l(t)-2)return n?.(i)&&Z(a,t[s]),i;const o=ta(i,t,e,n,s+1);return f(i)&&Z(a,t[s]),o})),ea=a=>new Set(c(a)||i(a)?a:[a]),na=(a,t)=>a?.add(t),sa=/^\d+$/,ia=K(),oa=K(),ra=(a,t,e,n,s,r,E,w={},u=0,T=[])=>{let R,A,p,C=0,O=0,L=0;aa(ia,T,(()=>0)),aa(oa,T,(()=>[]));const $=K(),[v,I,S,m,_]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!k(a)||!k(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!k(a)||!k(t),t.setContent]:y("Store type not supported by this Persister"))(E,a,u),[h,b,U]=(()=>{let a;const[t,e]=(()=>{const a=[];let t=0;return[e=>(e?g(a):null)??""+t++,t=>{sa.test(t)&&l(a)<1e3&&N(a,t)}]})(),n=K();return[(e,s,i,o=[],r=()=>[])=>{a??=q;const c=t(1);return Z(n,c,[e,s,i,o,r]),na(ta(s,i??[""],ea),c),c},(t,e,...s)=>d(((a,t=[""])=>{const e=[],n=(a,s)=>s==l(t)?N(e,a):null===t[s]?D(a,(a=>n(a,s+1))):d([t[s],null],(t=>n(V(a,t),s+1)));return n(a,0),e})(t,e),(t=>D(t,(t=>V(n,t)[0](a,...e??[],...s))))),a=>o(V(n,a),(([,t,s])=>(ta(t,s??[""],void 0,(t=>(P(t,a),f(t)?1:0))),Z(n,a),e(a),s))),t=>o(V(n,t),(([t,,e=[],n,s])=>{const o=(...r)=>{const c=l(r);c==l(e)?t(a,...r,...s(r)):i(e[c])?d(n[c]?.(...r)??[],(a=>o(...r,a))):o(...r,e[c])};o()}))]})(),F=a=>{a!=C&&(C=a,b($,void 0,C))},M=t=>{(v&&c(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},G=async a=>(2!=C&&(F(1),O++,await Y((async()=>{try{const e=await t();c(e)?M(e):a?_(a):y("Content is not an array: "+e)}catch(t){r?.(t),a&&_(a)}F(0)}))),q),j=()=>(A&&(s(A),A=void 0),q),x=async a=>(1!=C&&(F(2),L++,await Y((async()=>{try{await e(I,a)}catch(a){r?.(a)}F(0)}))),q),X=()=>(p&&(a.delListener(p),p=void 0),q),Y=async(...a)=>(N(V(oa,T),...a),await(async()=>{if(!V(ia,T)){for(Z(ia,T,1);!i(R=g(V(oa,T)));)try{await R()}catch(a){r?.(a)}Z(ia,T,0)}})(),q),q={load:G,startAutoLoad:async a=>{j(),await G(a);try{A=await n((async(a,t)=>{t||a?2!=C&&(F(1),O++,M(t??a),F(0)):await G()}))}catch(a){r?.(a)}return q},stopAutoLoad:j,isAutoLoading:()=>!i(A),save:x,startAutoSave:async()=>(X(),await x(),p=a.addDidFinishTransactionListener((()=>{const a=S();m(a)&&x(a)})),q),stopAutoSave:X,isAutoSaving:()=>!i(p),getStatus:()=>C,addStatusListener:a=>h(a,$),delListener:t=>(U(t),a),schedule:Y,getStore:()=>a,destroy:()=>(V(oa,T).splice(0,void 0),j().stopAutoSave()),getStats:()=>({loads:O,saves:L}),...w};return B(q)},ca=(a,t,n,s,o,r=Ea,c,E)=>{const l=K();return[async()=>{l.clear(),T(await n(a,t),(({tn:a,cn:t})=>na(aa(l,a,ea),t)))},async(t,e)=>((a,t)=>h(V(l,a),t))(t,e)?j(A(T(await a(S+m(t)),(a=>[a[e],E?q(X(a,e),E):X(a,e)])),(([a,t])=>!i(a)&&!k(t)))):{},async(t,n,s,E,y,d=!1)=>{const g=ea();q(s??{},(a=>T(G(a??{}),(a=>na(g,a)))));const p=b(g);if(!d&&y&&R(p)&&h(l,t))return await a("DROP "+$+m(t)),void Z(l,t);const C=V(l,t),O=ea(b(C));if(R(p)||(h(l,t)?await w(T([n,...p],(async(e,s)=>{P(O,e)||(await a(v+m(t)+"ADD"+m(e)+o),0==s&&await a("CREATE UNIQUE INDEX pk ON "+m(t)+`(${m(n)})`),na(C,e))}))):(await a("CREATE "+$+m(t)+`(${m(n)}${o} PRIMARY KEY${u(T(p,(a=>e+m(a)+o)))});`),Z(l,t,ea([n,...p])))),await w([...!d&&E?T(b(O),(async e=>{e!=n&&(await a(v+m(t)+"DROP"+m(e)),P(C,e))})):[]]),d)i(s)?await a(I+m(t)+L+" true"):await w(Y(s,(async(e,s)=>{i(e)?await a(I+m(t)+L+m(n)+"=$1",[s]):R(p)||await r(a,t,n,G(e),{[s]:c?T(H(e),c):H(e)},C)})));else if(R(p))h(l,t)&&await a(I+m(t)+L+" true");else{const e=A(b(V(l,t)),(a=>a!=n)),i={},o=[];q(s??{},((a,t)=>{i[t]=T(e,(t=>c?c(a?.[t]):a?.[t])),N(o,t)})),await r(a,t,n,e,i),await a(I+m(t)+L+m(n)+`NOT IN(${_(o)})`,o)}},async t=>{let e;await a("BEGIN");try{e=await t()}catch(a){s?.(a)}return await a("END"),e}]},Ea=async(a,t,n,s,i)=>{const o=[1];await a("INSERT INTO"+m(t)+"("+((...a)=>u(T(a,m),e))(n,...s)+")VALUES"+u(Y(i,(a=>"($"+o[0]+++","+_(a,o)+")")),e)+"ON CONFLICT("+m(n)+")DO UPDATE SET"+u(T(s,(a=>m(a)+"=excluded."+m(a))),e),Y(i,((a,t)=>[t,...T(a,(a=>a??null))])).flat())},la=(a,t,e,n,s,i,o,[r,c,E],l,w,y,d,u,T)=>{const[R,A,N,g]=ca(t,l,w,s,u,T),C=ra(a,(async()=>await g((async()=>{return await R(),a=(await A(r,c))[p]?.[E]??"null",J(a,((a,t)=>""===t?void 0:t));var a}))),(async a=>await g((async()=>{var t;await R(),await N(r,c,{[p]:{[E]:(t=a()??null,z(t,((a,t)=>void 0===t?"":t)))}},!0,!0)}))),e,n,s,o,{[d]:()=>y,destroy:()=>(C.stopAutoLoad().stopAutoSave(),i(),C)},0,y);return C},wa=(a,t,e,n,s,o,r,[c,E,[l,y,d]],u,T,R,N,g,O,L,$)=>{const[v,I,S,m]=ca(t,u,T,s,g,O,L,$),_=async(a,t)=>await w(Q(E,(async([e,n,s,i],o)=>{t&&!(o in a)||await S(e,n,a[o],s,i,t)}))),h=async(a,t)=>y?await S(d,C,{[p]:a},!0,!0,t):null,f=ra(a,(async()=>await m((async()=>{await v();const a=await(async()=>j(A(await w(Q(c,(async([a,t],e)=>[a,await I(e,t)]))),(a=>!k(a[1])))))(),t=await(async()=>l?(await I(d,C))[p]:{})();return k(a)&&i(t)?void 0:[a,t]}))),(async(a,t)=>await m((async()=>{if(await v(),i(t)){const[t,e]=a();await _(t),await h(e)}else await _(t[0],!0),await h(t[1],!0)}))),e,n,s,r,{[N]:()=>R,destroy:()=>(f.stopAutoLoad().stopAutoSave(),o(),f)},0,R);return f},ya="ColumnName",da="store",ua="json",Ta=da+"TableName",Ra=da+"Id"+ya,Aa=da+ya,Na="autoLoadIntervalSeconds",ga="rowId"+ya,pa="tableId",Ca="tableName",Oa="deleteEmptyColumns",La="deleteEmptyTable",$a={mode:ua,[Na]:1},va={load:0,save:0,[Ca]:t+"_values"},Ia=(a,t,e,n,s)=>{const o=K();return q(a,((a,c)=>{const l=E(H(x(t,r(a)?{[e]:a}:a)),0,W(t));i(l[0])||n(c,l[0])||(s(c,l[0]),Z(o,c,l))})),o},Sa=t,ma=/^([cd]:)(.+)/,_a=t+"_data",ha=t+"_table",fa=async(a,e,n,s,i)=>((a,e,n,s,i,c,l,y,d,u,R="getDb")=>{const A=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(n,c),[N,,g,p]=(a=>{const e=(a=>x($a,r(a)?{[Ta]:a}:a??{}))(a),n=e[Na];if(e.mode==ua){const a=e[Ta]??t;return[1,n,[a,e[Ra]??C,e[Aa]??da],ea(a)]}const{tables:{load:s={},save:i={}}={},values:o={}}=e,c=E(H(x(va,o)),0,W(va)),l=c[2],w=ea(l),y=ea(l);return[0,n,[Ia(s,{[pa]:null,[ga]:C},pa,(a=>h(y,a)),(a=>na(w,a))),Ia(i,{[Ca]:null,[ga]:C,[Oa]:0,[La]:0},Ca,((a,t)=>h(y,t)),((a,t)=>na(w,t))),c],w]})(e),$=async a=>{await A(`CREATE OR REPLACE TRIGGER ${m(_a+"_"+a)} AFTER INSERT OR UPDATE OR DELETE ON ${m(a)} EXECUTE FUNCTION ${_a}()`)};return(N?la:wa)(a,A,(async a=>{await A(`CREATE OR REPLACE FUNCTION ${ha}()RETURNS event_trigger AS $t2$ DECLARE row record; BEGIN FOR row IN SELECT object_identity FROM pg_event_trigger_ddl_commands()WHERE command_tag='CREATE TABLE' LOOP PERFORM pg_notify('${Sa}','c:'||SPLIT_PART(row.object_identity,'.',2));END LOOP;END;$t2$ LANGUAGE plpgsql;`);try{await A(`CREATE EVENT TRIGGER ${ha} ON ddl_command_end WHEN TAG IN('CREATE TABLE')EXECUTE FUNCTION ${ha}();`)}catch{}return await A(`CREATE OR REPLACE FUNCTION ${_a}()RETURNS trigger AS $t1$ BEGIN PERFORM pg_notify('${Sa}','d:'||TG_TABLE_NAME);RETURN NULL;END;$t1$ LANGUAGE plpgsql;`),await w(T(b(p),(async a=>{await A(`CREATE TABLE IF NOT EXISTS ${m(a)}("_id"text PRIMARY KEY)`),await $(a)}))),await s(Sa,(async t=>{return await o((e=t,n=ma,e?.match(n)),(async([,t,e])=>{h(p,e)&&("c:"==t&&await $(e),a())}));var e,n}))}),i,l,y,d,g,b(p),(async(a,t)=>await a(`${O} table_name tn,column_name cn FROM information_schema.columns ${L} table_schema='public'AND table_name IN(${_(t)})`,t)),u,R,"text",void 0,(a=>z(a)),(a=>J(a)))})(a,n,(async(a,t=[])=>(await e.query(a,t)).rows),(async(a,t)=>await e.listen(a,t)),(async a=>{try{await a()}catch(a){i?.(a)}}),s,i,(()=>0),3,e,"getPglite");export{fa as createPglitePersister};
|
|
Binary file
|
|
@@ -1 +1 @@
|
|
|
1
|
-
const a=a=>typeof a,t="tinybase",e=",",n=a(""),s=Promise,i=a=>null==a,
|
|
1
|
+
const a=a=>typeof a,t="tinybase",e=",",n=a(""),s=Promise,i=a=>null==a,o=(a,t,e)=>i(a)?e?.():t(a),r=t=>a(t)==n,c=a=>Array.isArray(a),E=(a,t,e)=>a.slice(t,e),l=a=>a.length,w=async a=>s.all(a),y=a=>{throw Error(a)},d=(a,t)=>a.forEach(t),u=(a,t="")=>a.join(t),T=(a,t)=>a.map(t),R=a=>0==l(a),A=(a,t)=>a.filter(t),N=(a,...t)=>a.push(...t),g=a=>a.shift(),p="_",C="_id",O="SELECT",L="WHERE",$="TABLE",v="ALTER "+$,I="DELETE FROM",S=O+"*FROM",m=a=>`"${a.replace(/"/g,'""')}"`,_=(a,t=[1])=>u(T(a,(()=>"$"+t[0]++)),e),h=(a,t)=>a?.has(t)??!1,f=a=>i(a)||0==(a=>a?.size??0)(a),b=a=>[...a?.values()??[]],D=(a,t)=>a?.forEach(t),P=(a,t)=>a?.delete(t),U=Object,F=a=>U.getPrototypeOf(a),M=U.entries,G=U.keys,B=U.freeze,j=(a=[])=>U.fromEntries(a),x=(...a)=>U.assign({},...a),X=(a,t)=>(delete a[t],a),Y=(a,t)=>T(M(a),(([a,e])=>t(e,a))),q=(a,t)=>j(Y(a,((a,e)=>[e,t(a,e)]))),H=a=>U.values(a),W=a=>l(G(a)),k=a=>(a=>!i(a)&&o(F(a),(a=>a==U.prototype||i(F(a))),(()=>!0)))(a)&&0==W(a),z=JSON.stringify,J=JSON.parse,K=a=>new Map(a),V=(a,t)=>a?.get(t),Q=(a,t)=>T([...a?.entries()??[]],(([a,e])=>t(e,a))),Z=(a,t,e)=>i(e)?(P(a,t),a):a?.set(t,e),aa=(a,t,e,n)=>(h(a,t)?n?.(V(a,t)):Z(a,t,e()),V(a,t)),ta=(a,t,e,n,s=0)=>o((e?aa:V)(a,t[s],s>l(t)-2?e:K),(i=>{if(s>l(t)-2)return n?.(i)&&Z(a,t[s]),i;const o=ta(i,t,e,n,s+1);return f(i)&&Z(a,t[s]),o})),ea=a=>new Set(c(a)||i(a)?a:[a]),na=(a,t)=>a?.add(t),sa=/^\d+$/,ia=K(),oa=K(),ra=(a,t,e,n,s,r,E,w={},u=0,T=[])=>{let R,A,p,C=0,O=0,L=0;aa(ia,T,(()=>0)),aa(oa,T,(()=>[]));const $=K(),[v,I,S,m,_]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!k(a)||!k(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!k(a)||!k(t),t.setContent]:y("Store type not supported by this Persister"))(E,a,u),[h,b,U]=(()=>{let a;const[t,e]=(()=>{const a=[];let t=0;return[e=>(e?g(a):null)??""+t++,t=>{sa.test(t)&&l(a)<1e3&&N(a,t)}]})(),n=K();return[(e,s,i,o=[],r=()=>[])=>{a??=q;const c=t(1);return Z(n,c,[e,s,i,o,r]),na(ta(s,i??[""],ea),c),c},(t,e,...s)=>d(((a,t=[""])=>{const e=[],n=(a,s)=>s==l(t)?N(e,a):null===t[s]?D(a,(a=>n(a,s+1))):d([t[s],null],(t=>n(V(a,t),s+1)));return n(a,0),e})(t,e),(t=>D(t,(t=>V(n,t)[0](a,...e??[],...s))))),a=>o(V(n,a),(([,t,s])=>(ta(t,s??[""],void 0,(t=>(P(t,a),f(t)?1:0))),Z(n,a),e(a),s))),t=>o(V(n,t),(([t,,e=[],n,s])=>{const o=(...r)=>{const c=l(r);c==l(e)?t(a,...r,...s(r)):i(e[c])?d(n[c]?.(...r)??[],(a=>o(...r,a))):o(...r,e[c])};o()}))]})(),F=a=>{a!=C&&(C=a,b($,void 0,C))},M=t=>{(v&&c(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},G=async a=>(2!=C&&(F(1),O++,await Y((async()=>{try{const e=await t();c(e)?M(e):a?_(a):y("Content is not an array: "+e)}catch(t){r?.(t),a&&_(a)}F(0)}))),q),j=()=>(A&&(s(A),A=void 0),q),x=async a=>(1!=C&&(F(2),L++,await Y((async()=>{try{await e(I,a)}catch(a){r?.(a)}F(0)}))),q),X=()=>(p&&(a.delListener(p),p=void 0),q),Y=async(...a)=>(N(V(oa,T),...a),await(async()=>{if(!V(ia,T)){for(Z(ia,T,1);!i(R=g(V(oa,T)));)try{await R()}catch(a){r?.(a)}Z(ia,T,0)}})(),q),q={load:G,startAutoLoad:async a=>{j(),await G(a);try{A=await n((async(a,t)=>{t||a?2!=C&&(F(1),O++,M(t??a),F(0)):await G()}))}catch(a){r?.(a)}return q},stopAutoLoad:j,isAutoLoading:()=>!i(A),save:x,startAutoSave:async()=>(X(),await x(),p=a.addDidFinishTransactionListener((()=>{const a=S();m(a)&&x(a)})),q),stopAutoSave:X,isAutoSaving:()=>!i(p),getStatus:()=>C,addStatusListener:a=>h(a,$),delListener:t=>(U(t),a),schedule:Y,getStore:()=>a,destroy:()=>(V(oa,T).splice(0,void 0),j().stopAutoSave()),getStats:()=>({loads:O,saves:L}),...w};return B(q)},ca=(a,t,n,s,o,r=Ea,c,E)=>{const l=K();return[async()=>{l.clear(),T(await n(a,t),(({tn:a,cn:t})=>na(aa(l,a,ea),t)))},async(t,e)=>((a,t)=>h(V(l,a),t))(t,e)?j(A(T(await a(S+m(t)),(a=>[a[e],E?q(X(a,e),E):X(a,e)])),(([a,t])=>!i(a)&&!k(t)))):{},async(t,n,s,E,y,d=!1)=>{const g=ea();q(s??{},(a=>T(G(a??{}),(a=>na(g,a)))));const p=b(g);if(!d&&y&&R(p)&&h(l,t))return await a("DROP "+$+m(t)),void Z(l,t);const C=V(l,t),O=ea(b(C));if(R(p)||(h(l,t)?await w(T([n,...p],(async(e,s)=>{P(O,e)||(await a(v+m(t)+"ADD"+m(e)+o),0==s&&await a("CREATE UNIQUE INDEX pk ON "+m(t)+`(${m(n)})`),na(C,e))}))):(await a("CREATE "+$+m(t)+`(${m(n)}${o} PRIMARY KEY${u(T(p,(a=>e+m(a)+o)))});`),Z(l,t,ea([n,...p])))),await w([...!d&&E?T(b(O),(async e=>{e!=n&&(await a(v+m(t)+"DROP"+m(e)),P(C,e))})):[]]),d)i(s)?await a(I+m(t)+L+" true"):await w(Y(s,(async(e,s)=>{i(e)?await a(I+m(t)+L+m(n)+"=$1",[s]):R(p)||await r(a,t,n,G(e),{[s]:c?T(H(e),c):H(e)},C)})));else if(R(p))h(l,t)&&await a(I+m(t)+L+" true");else{const e=A(b(V(l,t)),(a=>a!=n)),i={},o=[];q(s??{},((a,t)=>{i[t]=T(e,(t=>c?c(a?.[t]):a?.[t])),N(o,t)})),await r(a,t,n,e,i),await a(I+m(t)+L+m(n)+`NOT IN(${_(o)})`,o)}},async t=>{let e;await a("BEGIN");try{e=await t()}catch(a){s?.(a)}return await a("END"),e}]},Ea=async(a,t,n,s,i)=>{const o=[1];await a("INSERT INTO"+m(t)+"("+((...a)=>u(T(a,m),e))(n,...s)+")VALUES"+u(Y(i,(a=>"($"+o[0]+++","+_(a,o)+")")),e)+"ON CONFLICT("+m(n)+")DO UPDATE SET"+u(T(s,(a=>m(a)+"=excluded."+m(a))),e),Y(i,((a,t)=>[t,...T(a,(a=>a??null))])).flat())},la=(a,t,e,n,s,i,o,[r,c,E],l,w,y,d,u,T)=>{const[R,A,N,g]=ca(t,l,w,s,u,T),C=ra(a,(async()=>await g((async()=>{return await R(),a=(await A(r,c))[p]?.[E]??"null",J(a,((a,t)=>""===t?void 0:t));var a}))),(async a=>await g((async()=>{var t;await R(),await N(r,c,{[p]:{[E]:(t=a()??null,z(t,((a,t)=>void 0===t?"":t)))}},!0,!0)}))),e,n,s,o,{[d]:()=>y,destroy:()=>(C.stopAutoLoad().stopAutoSave(),i(),C)},0,y);return C},wa=(a,t,e,n,s,o,r,[c,E,[l,y,d]],u,T,R,N,g,O,L,$)=>{const[v,I,S,m]=ca(t,u,T,s,g,O,L,$),_=async(a,t)=>await w(Q(E,(async([e,n,s,i],o)=>{t&&!(o in a)||await S(e,n,a[o],s,i,t)}))),h=async(a,t)=>y?await S(d,C,{[p]:a},!0,!0,t):null,f=ra(a,(async()=>await m((async()=>{await v();const a=await(async()=>j(A(await w(Q(c,(async([a,t],e)=>[a,await I(e,t)]))),(a=>!k(a[1])))))(),t=await(async()=>l?(await I(d,C))[p]:{})();return k(a)&&i(t)?void 0:[a,t]}))),(async(a,t)=>await m((async()=>{if(await v(),i(t)){const[t,e]=a();await _(t),await h(e)}else await _(t[0],!0),await h(t[1],!0)}))),e,n,s,r,{[N]:()=>R,destroy:()=>(f.stopAutoLoad().stopAutoSave(),o(),f)},0,R);return f},ya="ColumnName",da="store",ua="json",Ta=da+"TableName",Ra=da+"Id"+ya,Aa=da+ya,Na="autoLoadIntervalSeconds",ga="rowId"+ya,pa="tableId",Ca="tableName",Oa="deleteEmptyColumns",La="deleteEmptyTable",$a={mode:ua,[Na]:1},va={load:0,save:0,[Ca]:t+"_values"},Ia=(a,t,e,n,s)=>{const o=K();return q(a,((a,c)=>{const l=E(H(x(t,r(a)?{[e]:a}:a)),0,W(t));i(l[0])||n(c,l[0])||(s(c,l[0]),Z(o,c,l))})),o},Sa=t,ma=/^([cd]:)(.+)/,_a=t+"_data",ha=t+"_table",fa=async(a,e,n,s,i)=>((a,e,n,s,i,c,l,y,d,u,R="getDb")=>{const A=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(n,c),[N,,g,p]=(a=>{const e=(a=>x($a,r(a)?{[Ta]:a}:a??{}))(a),n=e[Na];if(e.mode==ua){const a=e[Ta]??t;return[1,n,[a,e[Ra]??C,e[Aa]??da],ea(a)]}const{tables:{load:s={},save:i={}}={},values:o={}}=e,c=E(H(x(va,o)),0,W(va)),l=c[2],w=ea(l),y=ea(l);return[0,n,[Ia(s,{[pa]:null,[ga]:C},pa,(a=>h(y,a)),(a=>na(w,a))),Ia(i,{[Ca]:null,[ga]:C,[Oa]:0,[La]:0},Ca,((a,t)=>h(y,t)),((a,t)=>na(w,t))),c],w]})(e),$=async a=>{await A(`CREATE OR REPLACE TRIGGER ${m(_a+"_"+a)} AFTER INSERT OR UPDATE OR DELETE ON ${m(a)} EXECUTE FUNCTION ${_a}()`)};return(N?la:wa)(a,A,(async a=>{await A(`CREATE OR REPLACE FUNCTION ${ha}()RETURNS event_trigger AS $t2$ DECLARE row record; BEGIN FOR row IN SELECT object_identity FROM pg_event_trigger_ddl_commands()WHERE command_tag='CREATE TABLE' LOOP PERFORM pg_notify('${Sa}','c:'||SPLIT_PART(row.object_identity,'.',2));END LOOP;END;$t2$ LANGUAGE plpgsql;`);try{await A(`CREATE EVENT TRIGGER ${ha} ON ddl_command_end WHEN TAG IN('CREATE TABLE')EXECUTE FUNCTION ${ha}();`)}catch{}return await A(`CREATE OR REPLACE FUNCTION ${_a}()RETURNS trigger AS $t1$ BEGIN PERFORM pg_notify('${Sa}','d:'||TG_TABLE_NAME);RETURN NULL;END;$t1$ LANGUAGE plpgsql;`),await w(T(b(p),(async a=>{await A(`CREATE TABLE IF NOT EXISTS ${m(a)}("_id"text PRIMARY KEY)`),await $(a)}))),await s(Sa,(async t=>{return await o((e=t,n=ma,e?.match(n)),(async([,t,e])=>{h(p,e)&&("c:"==t&&await $(e),a())}));var e,n}))}),i,l,y,d,g,b(p),(async(a,t)=>await a(`${O} table_name tn,column_name cn FROM information_schema.columns ${L} table_schema='public'AND table_name IN(${_(t)})`,t)),u,R,"text",void 0,(a=>z(a)),(a=>J(a)))})(a,n,(async(a,t=[])=>(await e.query(a,t)).rows),(async(a,t)=>await e.listen(a,t)),(async a=>{try{await a()}catch(a){i?.(a)}}),s,i,(()=>0),3,e,"getPglite");export{fa as createPglitePersister};
|
|
Binary file
|
|
@@ -1 +1 @@
|
|
|
1
|
-
const a=a=>typeof a,t="tinybase",e=",",n=a(""),s=Promise,i=a=>null==a,r=(a,t,e)=>i(a)?e?.():t(a),o=t=>a(t)==n,c=a=>Array.isArray(a),E=(a,t,e)=>a.slice(t,e),l=a=>a.length,w=async a=>s.all(a),y=a=>{throw Error(a)},u=(a,t)=>a.forEach(t),d=(a,t="")=>a.join(t),T=(a,t)=>a.map(t),R=a=>0==l(a),A=(a,t)=>a.filter(t),N=(a,...t)=>a.push(...t),g=a=>a.shift(),p="_",C="_id",O="SELECT",L="WHERE",v="TABLE",$="ALTER "+v,S="DELETE FROM",I=O+"*FROM",m=a=>`"${a.replace(/"/g,'""')}"`,_=(a,t=[1])=>d(T(a,(()=>"$"+t[0]++)),e),h=(a,t)=>a?.has(t)??!1,f=a=>i(a)||0==(a=>a?.size??0)(a),b=a=>[...a?.values()??[]],D=(a,t)=>a?.forEach(t),P=(a,t)=>a?.delete(t),U=Object,F=a=>U.getPrototypeOf(a),M=U.entries,G=U.keys,B=U.freeze,j=(a=[])=>U.fromEntries(a),x=(...a)=>U.assign({},...a),X=(a,t)=>(delete a[t],a),Y=(a,t)=>T(M(a),(([a,e])=>t(e,a))),q=a=>U.values(a),
|
|
1
|
+
const a=a=>typeof a,t="tinybase",e=",",n=a(""),s=Promise,i=a=>null==a,r=(a,t,e)=>i(a)?e?.():t(a),o=t=>a(t)==n,c=a=>Array.isArray(a),E=(a,t,e)=>a.slice(t,e),l=a=>a.length,w=async a=>s.all(a),y=a=>{throw Error(a)},u=(a,t)=>a.forEach(t),d=(a,t="")=>a.join(t),T=(a,t)=>a.map(t),R=a=>0==l(a),A=(a,t)=>a.filter(t),N=(a,...t)=>a.push(...t),g=a=>a.shift(),p="_",C="_id",O="SELECT",L="WHERE",v="TABLE",$="ALTER "+v,S="DELETE FROM",I=O+"*FROM",m=a=>`"${a.replace(/"/g,'""')}"`,_=(a,t=[1])=>d(T(a,(()=>"$"+t[0]++)),e),h=(a,t)=>a?.has(t)??!1,f=a=>i(a)||0==(a=>a?.size??0)(a),b=a=>[...a?.values()??[]],D=(a,t)=>a?.forEach(t),P=(a,t)=>a?.delete(t),U=Object,F=a=>U.getPrototypeOf(a),M=U.entries,G=U.keys,B=U.freeze,j=(a=[])=>U.fromEntries(a),x=(...a)=>U.assign({},...a),X=(a,t)=>(delete a[t],a),Y=(a,t)=>T(M(a),(([a,e])=>t(e,a))),q=(a,t)=>j(Y(a,((a,e)=>[e,t(a,e)]))),H=a=>U.values(a),W=a=>l(G(a)),k=a=>(a=>!i(a)&&r(F(a),(a=>a==U.prototype||i(F(a))),(()=>!0)))(a)&&0==W(a),z=JSON.stringify,J=JSON.parse,K=a=>new Map(a),V=(a,t)=>a?.get(t),Q=(a,t)=>T([...a?.entries()??[]],(([a,e])=>t(e,a))),Z=(a,t,e)=>i(e)?(P(a,t),a):a?.set(t,e),aa=(a,t,e,n)=>(h(a,t)?n?.(V(a,t)):Z(a,t,e()),V(a,t)),ta=(a,t,e,n,s=0)=>r((e?aa:V)(a,t[s],s>l(t)-2?e:K),(i=>{if(s>l(t)-2)return n?.(i)&&Z(a,t[s]),i;const r=ta(i,t,e,n,s+1);return f(i)&&Z(a,t[s]),r})),ea=a=>new Set(c(a)||i(a)?a:[a]),na=(a,t)=>a?.add(t),sa=/^\d+$/,ia=K(),ra=K(),oa=(a,t,e,n,s,o,E,w={},d=0,T=[])=>{let R,A,p,C=0,O=0,L=0;aa(ia,T,(()=>0)),aa(ra,T,(()=>[]));const v=K(),[$,S,I,m,_]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!k(a)||!k(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!k(a)||!k(t),t.setContent]:y("Store type not supported by this Persister"))(E,a,d),[h,b,U]=(()=>{let a;const[t,e]=(()=>{const a=[];let t=0;return[e=>(e?g(a):null)??""+t++,t=>{sa.test(t)&&l(a)<1e3&&N(a,t)}]})(),n=K();return[(e,s,i,r=[],o=()=>[])=>{a??=q;const c=t(1);return Z(n,c,[e,s,i,r,o]),na(ta(s,i??[""],ea),c),c},(t,e,...s)=>u(((a,t=[""])=>{const e=[],n=(a,s)=>s==l(t)?N(e,a):null===t[s]?D(a,(a=>n(a,s+1))):u([t[s],null],(t=>n(V(a,t),s+1)));return n(a,0),e})(t,e),(t=>D(t,(t=>V(n,t)[0](a,...e??[],...s))))),a=>r(V(n,a),(([,t,s])=>(ta(t,s??[""],void 0,(t=>(P(t,a),f(t)?1:0))),Z(n,a),e(a),s))),t=>r(V(n,t),(([t,,e=[],n,s])=>{const r=(...o)=>{const c=l(o);c==l(e)?t(a,...o,...s(o)):i(e[c])?u(n[c]?.(...o)??[],(a=>r(...o,a))):r(...o,e[c])};r()}))]})(),F=a=>{a!=C&&(C=a,b(v,void 0,C))},M=t=>{($&&c(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},G=async a=>(2!=C&&(F(1),O++,await Y((async()=>{try{const e=await t();c(e)?M(e):a?_(a):y("Content is not an array: "+e)}catch(t){o?.(t),a&&_(a)}F(0)}))),q),j=()=>(A&&(s(A),A=void 0),q),x=async a=>(1!=C&&(F(2),L++,await Y((async()=>{try{await e(S,a)}catch(a){o?.(a)}F(0)}))),q),X=()=>(p&&(a.delListener(p),p=void 0),q),Y=async(...a)=>(N(V(ra,T),...a),await(async()=>{if(!V(ia,T)){for(Z(ia,T,1);!i(R=g(V(ra,T)));)try{await R()}catch(a){o?.(a)}Z(ia,T,0)}})(),q),q={load:G,startAutoLoad:async a=>{j(),await G(a);try{A=await n((async(a,t)=>{t||a?2!=C&&(F(1),O++,M(t??a),F(0)):await G()}))}catch(a){o?.(a)}return q},stopAutoLoad:j,isAutoLoading:()=>!i(A),save:x,startAutoSave:async()=>(X(),await x(),p=a.addDidFinishTransactionListener((()=>{const a=I();m(a)&&x(a)})),q),stopAutoSave:X,isAutoSaving:()=>!i(p),getStatus:()=>C,addStatusListener:a=>h(a,v),delListener:t=>(U(t),a),schedule:Y,getStore:()=>a,destroy:()=>(V(ra,T).splice(0,void 0),j().stopAutoSave()),getStats:()=>({loads:O,saves:L}),...w};return B(q)},ca=(a,t,n,s,r,o=Ea,c,E)=>{const l=K();return[async()=>{l.clear(),T(await n(a,t),(({tn:a,cn:t})=>na(aa(l,a,ea),t)))},async(t,e)=>((a,t)=>h(V(l,a),t))(t,e)?j(A(T(await a(I+m(t)),(a=>[a[e],E?q(X(a,e),E):X(a,e)])),(([a,t])=>!i(a)&&!k(t)))):{},async(t,n,s,E,y,u=!1)=>{const g=ea();q(s??{},(a=>T(G(a??{}),(a=>na(g,a)))));const p=b(g);if(!u&&y&&R(p)&&h(l,t))return await a("DROP "+v+m(t)),void Z(l,t);const C=V(l,t),O=ea(b(C));if(R(p)||(h(l,t)?await w(T([n,...p],(async(e,s)=>{P(O,e)||(await a($+m(t)+"ADD"+m(e)+r),0==s&&await a("CREATE UNIQUE INDEX pk ON "+m(t)+`(${m(n)})`),na(C,e))}))):(await a("CREATE "+v+m(t)+`(${m(n)}${r} PRIMARY KEY${d(T(p,(a=>e+m(a)+r)))});`),Z(l,t,ea([n,...p])))),await w([...!u&&E?T(b(O),(async e=>{e!=n&&(await a($+m(t)+"DROP"+m(e)),P(C,e))})):[]]),u)i(s)?await a(S+m(t)+L+" true"):await w(Y(s,(async(e,s)=>{i(e)?await a(S+m(t)+L+m(n)+"=$1",[s]):R(p)||await o(a,t,n,G(e),{[s]:c?T(H(e),c):H(e)},C)})));else if(R(p))h(l,t)&&await a(S+m(t)+L+" true");else{const e=A(b(V(l,t)),(a=>a!=n)),i={},r=[];q(s??{},((a,t)=>{i[t]=T(e,(t=>c?c(a?.[t]):a?.[t])),N(r,t)})),await o(a,t,n,e,i),await a(S+m(t)+L+m(n)+`NOT IN(${_(r)})`,r)}},async t=>{let e;await a("BEGIN");try{e=await t()}catch(a){s?.(a)}return await a("END"),e}]},Ea=async(a,t,n,s,i)=>{const r=[1];await a("INSERT INTO"+m(t)+"("+((...a)=>d(T(a,m),e))(n,...s)+")VALUES"+d(Y(i,(a=>"($"+r[0]+++","+_(a,r)+")")),e)+"ON CONFLICT("+m(n)+")DO UPDATE SET"+d(T(s,(a=>m(a)+"=excluded."+m(a))),e),Y(i,((a,t)=>[t,...T(a,(a=>a??null))])).flat())},la=(a,t,e,n,s,i,r,[o,c,E],l,w,y,u,d,T)=>{const[R,A,N,g]=ca(t,l,w,s,d,T),C=oa(a,(async()=>await g((async()=>{return await R(),a=(await A(o,c))[p]?.[E]??"null",J(a,((a,t)=>""===t?void 0:t));var a}))),(async a=>await g((async()=>{var t;await R(),await N(o,c,{[p]:{[E]:(t=a()??null,z(t,((a,t)=>void 0===t?"":t)))}},!0,!0)}))),e,n,s,r,{[u]:()=>y,destroy:()=>(C.stopAutoLoad().stopAutoSave(),i(),C)},0,y);return C},wa=(a,t,e,n,s,r,o,[c,E,[l,y,u]],d,T,R,N,g,O,L,v)=>{const[$,S,I,m]=ca(t,d,T,s,g,O,L,v),_=async(a,t)=>await w(Q(E,(async([e,n,s,i],r)=>{t&&!(r in a)||await I(e,n,a[r],s,i,t)}))),h=async(a,t)=>y?await I(u,C,{[p]:a},!0,!0,t):null,f=oa(a,(async()=>await m((async()=>{await $();const a=await(async()=>j(A(await w(Q(c,(async([a,t],e)=>[a,await S(e,t)]))),(a=>!k(a[1])))))(),t=await(async()=>l?(await S(u,C))[p]:{})();return k(a)&&i(t)?void 0:[a,t]}))),(async(a,t)=>await m((async()=>{if(await $(),i(t)){const[t,e]=a();await _(t),await h(e)}else await _(t[0],!0),await h(t[1],!0)}))),e,n,s,o,{[N]:()=>R,destroy:()=>(f.stopAutoLoad().stopAutoSave(),r(),f)},0,R);return f},ya="ColumnName",ua="store",da="json",Ta=ua+"TableName",Ra=ua+"Id"+ya,Aa=ua+ya,Na="autoLoadIntervalSeconds",ga="rowId"+ya,pa="tableId",Ca="tableName",Oa="deleteEmptyColumns",La="deleteEmptyTable",va={mode:da,[Na]:1},$a={load:0,save:0,[Ca]:t+"_values"},Sa=(a,t,e,n,s)=>{const r=K();return q(a,((a,c)=>{const l=E(H(x(t,o(a)?{[e]:a}:a)),0,W(t));i(l[0])||n(c,l[0])||(s(c,l[0]),Z(r,c,l))})),r},Ia=t,ma=/^([cd]:)(.+)/,_a=t+"_data",ha=t+"_table",fa=async(a,e,n,s,i)=>{const c=await(e.reserve?.());return((a,e,n,s,i,c,l,y,u,d,R="getDb")=>{const A=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(n,c),[N,,g,p]=(a=>{const e=(a=>x(va,o(a)?{[Ta]:a}:a??{}))(a),n=e[Na];if(e.mode==da){const a=e[Ta]??t;return[1,n,[a,e[Ra]??C,e[Aa]??ua],ea(a)]}const{tables:{load:s={},save:i={}}={},values:r={}}=e,c=E(H(x($a,r)),0,W($a)),l=c[2],w=ea(l),y=ea(l);return[0,n,[Sa(s,{[pa]:null,[ga]:C},pa,(a=>h(y,a)),(a=>na(w,a))),Sa(i,{[Ca]:null,[ga]:C,[Oa]:0,[La]:0},Ca,((a,t)=>h(y,t)),((a,t)=>na(w,t))),c],w]})(e),v=async a=>{await A(`CREATE OR REPLACE TRIGGER ${m(_a+"_"+a)} AFTER INSERT OR UPDATE OR DELETE ON ${m(a)} EXECUTE FUNCTION ${_a}()`)};return(N?la:wa)(a,A,(async a=>{await A(`CREATE OR REPLACE FUNCTION ${ha}()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('${Ia}','c:'||SPLIT_PART(row.object_identity,'.',2));END LOOP;END;$t2$ LANGUAGE plpgsql;`);try{await A(`CREATE EVENT TRIGGER ${ha} ON ddl_command_end WHEN TAG IN('CREATE TABLE')EXECUTE FUNCTION ${ha}();`)}catch{}return await A(`CREATE OR REPLACE FUNCTION ${_a}()RETURNS trigger AS $t1$ BEGIN PERFORM pg_notify('${Ia}','d:'||TG_TABLE_NAME);RETURN NULL;END;$t1$ LANGUAGE plpgsql;`),await w(T(b(p),(async a=>{await A(`CREATE TABLE IF NOT EXISTS ${m(a)}("_id"text PRIMARY KEY)`),await v(a)}))),await s(Ia,(async t=>{return await r((e=t,n=ma,e?.match(n)),(async([,t,e])=>{h(p,e)&&("c:"==t&&await v(e),a())}));var e,n}))}),i,l,y,u,g,b(p),(async(a,t)=>await a(`${O} table_name tn,column_name cn FROM information_schema.columns ${L} table_schema='public'AND table_name IN(${_(t)})`,t)),d,R,"text",void 0,(a=>z(a)),(a=>J(a)))})(a,n,c?.unsafe,(async(a,t)=>e.listen(a,t)),(async a=>{try{await a.unlisten()}catch(a){i?.(a)}}),s,i,(()=>c?.release?.()),3,e,"getSql")};export{fa as createPostgresPersister};
|
|
Binary file
|
|
@@ -1 +1 @@
|
|
|
1
|
-
const a=a=>typeof a,t="tinybase",e=",",n=a(""),s=Promise,i=a=>null==a,r=(a,t,e)=>i(a)?e?.():t(a),o=t=>a(t)==n,c=a=>Array.isArray(a),E=(a,t,e)=>a.slice(t,e),l=a=>a.length,w=async a=>s.all(a),y=a=>{throw Error(a)},u=(a,t)=>a.forEach(t),d=(a,t="")=>a.join(t),T=(a,t)=>a.map(t),R=a=>0==l(a),A=(a,t)=>a.filter(t),N=(a,...t)=>a.push(...t),g=a=>a.shift(),p="_",C="_id",O="SELECT",L="WHERE",v="TABLE",$="ALTER "+v,S="DELETE FROM",I=O+"*FROM",m=a=>`"${a.replace(/"/g,'""')}"`,_=(a,t=[1])=>d(T(a,(()=>"$"+t[0]++)),e),h=(a,t)=>a?.has(t)??!1,f=a=>i(a)||0==(a=>a?.size??0)(a),b=a=>[...a?.values()??[]],D=(a,t)=>a?.forEach(t),P=(a,t)=>a?.delete(t),U=Object,F=a=>U.getPrototypeOf(a),M=U.entries,G=U.keys,B=U.freeze,j=(a=[])=>U.fromEntries(a),x=(...a)=>U.assign({},...a),X=(a,t)=>(delete a[t],a),Y=(a,t)=>T(M(a),(([a,e])=>t(e,a))),q=a=>U.values(a),
|
|
1
|
+
const a=a=>typeof a,t="tinybase",e=",",n=a(""),s=Promise,i=a=>null==a,r=(a,t,e)=>i(a)?e?.():t(a),o=t=>a(t)==n,c=a=>Array.isArray(a),E=(a,t,e)=>a.slice(t,e),l=a=>a.length,w=async a=>s.all(a),y=a=>{throw Error(a)},u=(a,t)=>a.forEach(t),d=(a,t="")=>a.join(t),T=(a,t)=>a.map(t),R=a=>0==l(a),A=(a,t)=>a.filter(t),N=(a,...t)=>a.push(...t),g=a=>a.shift(),p="_",C="_id",O="SELECT",L="WHERE",v="TABLE",$="ALTER "+v,S="DELETE FROM",I=O+"*FROM",m=a=>`"${a.replace(/"/g,'""')}"`,_=(a,t=[1])=>d(T(a,(()=>"$"+t[0]++)),e),h=(a,t)=>a?.has(t)??!1,f=a=>i(a)||0==(a=>a?.size??0)(a),b=a=>[...a?.values()??[]],D=(a,t)=>a?.forEach(t),P=(a,t)=>a?.delete(t),U=Object,F=a=>U.getPrototypeOf(a),M=U.entries,G=U.keys,B=U.freeze,j=(a=[])=>U.fromEntries(a),x=(...a)=>U.assign({},...a),X=(a,t)=>(delete a[t],a),Y=(a,t)=>T(M(a),(([a,e])=>t(e,a))),q=(a,t)=>j(Y(a,((a,e)=>[e,t(a,e)]))),H=a=>U.values(a),W=a=>l(G(a)),k=a=>(a=>!i(a)&&r(F(a),(a=>a==U.prototype||i(F(a))),(()=>!0)))(a)&&0==W(a),z=JSON.stringify,J=JSON.parse,K=a=>new Map(a),V=(a,t)=>a?.get(t),Q=(a,t)=>T([...a?.entries()??[]],(([a,e])=>t(e,a))),Z=(a,t,e)=>i(e)?(P(a,t),a):a?.set(t,e),aa=(a,t,e,n)=>(h(a,t)?n?.(V(a,t)):Z(a,t,e()),V(a,t)),ta=(a,t,e,n,s=0)=>r((e?aa:V)(a,t[s],s>l(t)-2?e:K),(i=>{if(s>l(t)-2)return n?.(i)&&Z(a,t[s]),i;const r=ta(i,t,e,n,s+1);return f(i)&&Z(a,t[s]),r})),ea=a=>new Set(c(a)||i(a)?a:[a]),na=(a,t)=>a?.add(t),sa=/^\d+$/,ia=K(),ra=K(),oa=(a,t,e,n,s,o,E,w={},d=0,T=[])=>{let R,A,p,C=0,O=0,L=0;aa(ia,T,(()=>0)),aa(ra,T,(()=>[]));const v=K(),[$,S,I,m,_]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!k(a)||!k(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!k(a)||!k(t),t.setContent]:y("Store type not supported by this Persister"))(E,a,d),[h,b,U]=(()=>{let a;const[t,e]=(()=>{const a=[];let t=0;return[e=>(e?g(a):null)??""+t++,t=>{sa.test(t)&&l(a)<1e3&&N(a,t)}]})(),n=K();return[(e,s,i,r=[],o=()=>[])=>{a??=q;const c=t(1);return Z(n,c,[e,s,i,r,o]),na(ta(s,i??[""],ea),c),c},(t,e,...s)=>u(((a,t=[""])=>{const e=[],n=(a,s)=>s==l(t)?N(e,a):null===t[s]?D(a,(a=>n(a,s+1))):u([t[s],null],(t=>n(V(a,t),s+1)));return n(a,0),e})(t,e),(t=>D(t,(t=>V(n,t)[0](a,...e??[],...s))))),a=>r(V(n,a),(([,t,s])=>(ta(t,s??[""],void 0,(t=>(P(t,a),f(t)?1:0))),Z(n,a),e(a),s))),t=>r(V(n,t),(([t,,e=[],n,s])=>{const r=(...o)=>{const c=l(o);c==l(e)?t(a,...o,...s(o)):i(e[c])?u(n[c]?.(...o)??[],(a=>r(...o,a))):r(...o,e[c])};r()}))]})(),F=a=>{a!=C&&(C=a,b(v,void 0,C))},M=t=>{($&&c(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},G=async a=>(2!=C&&(F(1),O++,await Y((async()=>{try{const e=await t();c(e)?M(e):a?_(a):y("Content is not an array: "+e)}catch(t){o?.(t),a&&_(a)}F(0)}))),q),j=()=>(A&&(s(A),A=void 0),q),x=async a=>(1!=C&&(F(2),L++,await Y((async()=>{try{await e(S,a)}catch(a){o?.(a)}F(0)}))),q),X=()=>(p&&(a.delListener(p),p=void 0),q),Y=async(...a)=>(N(V(ra,T),...a),await(async()=>{if(!V(ia,T)){for(Z(ia,T,1);!i(R=g(V(ra,T)));)try{await R()}catch(a){o?.(a)}Z(ia,T,0)}})(),q),q={load:G,startAutoLoad:async a=>{j(),await G(a);try{A=await n((async(a,t)=>{t||a?2!=C&&(F(1),O++,M(t??a),F(0)):await G()}))}catch(a){o?.(a)}return q},stopAutoLoad:j,isAutoLoading:()=>!i(A),save:x,startAutoSave:async()=>(X(),await x(),p=a.addDidFinishTransactionListener((()=>{const a=I();m(a)&&x(a)})),q),stopAutoSave:X,isAutoSaving:()=>!i(p),getStatus:()=>C,addStatusListener:a=>h(a,v),delListener:t=>(U(t),a),schedule:Y,getStore:()=>a,destroy:()=>(V(ra,T).splice(0,void 0),j().stopAutoSave()),getStats:()=>({loads:O,saves:L}),...w};return B(q)},ca=(a,t,n,s,r,o=Ea,c,E)=>{const l=K();return[async()=>{l.clear(),T(await n(a,t),(({tn:a,cn:t})=>na(aa(l,a,ea),t)))},async(t,e)=>((a,t)=>h(V(l,a),t))(t,e)?j(A(T(await a(I+m(t)),(a=>[a[e],E?q(X(a,e),E):X(a,e)])),(([a,t])=>!i(a)&&!k(t)))):{},async(t,n,s,E,y,u=!1)=>{const g=ea();q(s??{},(a=>T(G(a??{}),(a=>na(g,a)))));const p=b(g);if(!u&&y&&R(p)&&h(l,t))return await a("DROP "+v+m(t)),void Z(l,t);const C=V(l,t),O=ea(b(C));if(R(p)||(h(l,t)?await w(T([n,...p],(async(e,s)=>{P(O,e)||(await a($+m(t)+"ADD"+m(e)+r),0==s&&await a("CREATE UNIQUE INDEX pk ON "+m(t)+`(${m(n)})`),na(C,e))}))):(await a("CREATE "+v+m(t)+`(${m(n)}${r} PRIMARY KEY${d(T(p,(a=>e+m(a)+r)))});`),Z(l,t,ea([n,...p])))),await w([...!u&&E?T(b(O),(async e=>{e!=n&&(await a($+m(t)+"DROP"+m(e)),P(C,e))})):[]]),u)i(s)?await a(S+m(t)+L+" true"):await w(Y(s,(async(e,s)=>{i(e)?await a(S+m(t)+L+m(n)+"=$1",[s]):R(p)||await o(a,t,n,G(e),{[s]:c?T(H(e),c):H(e)},C)})));else if(R(p))h(l,t)&&await a(S+m(t)+L+" true");else{const e=A(b(V(l,t)),(a=>a!=n)),i={},r=[];q(s??{},((a,t)=>{i[t]=T(e,(t=>c?c(a?.[t]):a?.[t])),N(r,t)})),await o(a,t,n,e,i),await a(S+m(t)+L+m(n)+`NOT IN(${_(r)})`,r)}},async t=>{let e;await a("BEGIN");try{e=await t()}catch(a){s?.(a)}return await a("END"),e}]},Ea=async(a,t,n,s,i)=>{const r=[1];await a("INSERT INTO"+m(t)+"("+((...a)=>d(T(a,m),e))(n,...s)+")VALUES"+d(Y(i,(a=>"($"+r[0]+++","+_(a,r)+")")),e)+"ON CONFLICT("+m(n)+")DO UPDATE SET"+d(T(s,(a=>m(a)+"=excluded."+m(a))),e),Y(i,((a,t)=>[t,...T(a,(a=>a??null))])).flat())},la=(a,t,e,n,s,i,r,[o,c,E],l,w,y,u,d,T)=>{const[R,A,N,g]=ca(t,l,w,s,d,T),C=oa(a,(async()=>await g((async()=>{return await R(),a=(await A(o,c))[p]?.[E]??"null",J(a,((a,t)=>""===t?void 0:t));var a}))),(async a=>await g((async()=>{var t;await R(),await N(o,c,{[p]:{[E]:(t=a()??null,z(t,((a,t)=>void 0===t?"":t)))}},!0,!0)}))),e,n,s,r,{[u]:()=>y,destroy:()=>(C.stopAutoLoad().stopAutoSave(),i(),C)},0,y);return C},wa=(a,t,e,n,s,r,o,[c,E,[l,y,u]],d,T,R,N,g,O,L,v)=>{const[$,S,I,m]=ca(t,d,T,s,g,O,L,v),_=async(a,t)=>await w(Q(E,(async([e,n,s,i],r)=>{t&&!(r in a)||await I(e,n,a[r],s,i,t)}))),h=async(a,t)=>y?await I(u,C,{[p]:a},!0,!0,t):null,f=oa(a,(async()=>await m((async()=>{await $();const a=await(async()=>j(A(await w(Q(c,(async([a,t],e)=>[a,await S(e,t)]))),(a=>!k(a[1])))))(),t=await(async()=>l?(await S(u,C))[p]:{})();return k(a)&&i(t)?void 0:[a,t]}))),(async(a,t)=>await m((async()=>{if(await $(),i(t)){const[t,e]=a();await _(t),await h(e)}else await _(t[0],!0),await h(t[1],!0)}))),e,n,s,o,{[N]:()=>R,destroy:()=>(f.stopAutoLoad().stopAutoSave(),r(),f)},0,R);return f},ya="ColumnName",ua="store",da="json",Ta=ua+"TableName",Ra=ua+"Id"+ya,Aa=ua+ya,Na="autoLoadIntervalSeconds",ga="rowId"+ya,pa="tableId",Ca="tableName",Oa="deleteEmptyColumns",La="deleteEmptyTable",va={mode:da,[Na]:1},$a={load:0,save:0,[Ca]:t+"_values"},Sa=(a,t,e,n,s)=>{const r=K();return q(a,((a,c)=>{const l=E(H(x(t,o(a)?{[e]:a}:a)),0,W(t));i(l[0])||n(c,l[0])||(s(c,l[0]),Z(r,c,l))})),r},Ia=t,ma=/^([cd]:)(.+)/,_a=t+"_data",ha=t+"_table",fa=async(a,e,n,s,i)=>{const c=await(e.reserve?.());return((a,e,n,s,i,c,l,y,u,d,R="getDb")=>{const A=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(n,c),[N,,g,p]=(a=>{const e=(a=>x(va,o(a)?{[Ta]:a}:a??{}))(a),n=e[Na];if(e.mode==da){const a=e[Ta]??t;return[1,n,[a,e[Ra]??C,e[Aa]??ua],ea(a)]}const{tables:{load:s={},save:i={}}={},values:r={}}=e,c=E(H(x($a,r)),0,W($a)),l=c[2],w=ea(l),y=ea(l);return[0,n,[Sa(s,{[pa]:null,[ga]:C},pa,(a=>h(y,a)),(a=>na(w,a))),Sa(i,{[Ca]:null,[ga]:C,[Oa]:0,[La]:0},Ca,((a,t)=>h(y,t)),((a,t)=>na(w,t))),c],w]})(e),v=async a=>{await A(`CREATE OR REPLACE TRIGGER ${m(_a+"_"+a)} AFTER INSERT OR UPDATE OR DELETE ON ${m(a)} EXECUTE FUNCTION ${_a}()`)};return(N?la:wa)(a,A,(async a=>{await A(`CREATE OR REPLACE FUNCTION ${ha}()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('${Ia}','c:'||SPLIT_PART(row.object_identity,'.',2));END LOOP;END;$t2$ LANGUAGE plpgsql;`);try{await A(`CREATE EVENT TRIGGER ${ha} ON ddl_command_end WHEN TAG IN('CREATE TABLE')EXECUTE FUNCTION ${ha}();`)}catch{}return await A(`CREATE OR REPLACE FUNCTION ${_a}()RETURNS trigger AS $t1$ BEGIN PERFORM pg_notify('${Ia}','d:'||TG_TABLE_NAME);RETURN NULL;END;$t1$ LANGUAGE plpgsql;`),await w(T(b(p),(async a=>{await A(`CREATE TABLE IF NOT EXISTS ${m(a)}("_id"text PRIMARY KEY)`),await v(a)}))),await s(Ia,(async t=>{return await r((e=t,n=ma,e?.match(n)),(async([,t,e])=>{h(p,e)&&("c:"==t&&await v(e),a())}));var e,n}))}),i,l,y,u,g,b(p),(async(a,t)=>await a(`${O} table_name tn,column_name cn FROM information_schema.columns ${L} table_schema='public'AND table_name IN(${_(t)})`,t)),d,R,"text",void 0,(a=>z(a)),(a=>J(a)))})(a,n,c?.unsafe,(async(a,t)=>e.listen(a,t)),(async a=>{try{await a.unlisten()}catch(a){i?.(a)}}),s,i,(()=>c?.release?.()),3,e,"getSql")};export{fa as createPostgresPersister};
|
|
Binary file
|
|
@@ -1 +1 @@
|
|
|
1
|
-
const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),
|
|
1
|
+
const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),o=Promise,r=clearInterval,i=a=>null==a,c=(a,t,e)=>i(a)?e?.():t(a),l=t=>a(t)==s,w=a=>Array.isArray(a),y=(a,t,e)=>a.slice(t,e),u=a=>a.length,d=async a=>o.all(a),E=a=>{throw Error(a)},v=(a,t)=>a.forEach(t),g=(a,t="")=>a.join(t),p=(a,t)=>a.map(t),A=a=>0==u(a),h=(a,t)=>a.filter(t),N=(a,...t)=>a.push(...t),f=a=>a.shift(),m=Object,S=a=>m.getPrototypeOf(a),T=m.entries,C=m.keys,$=m.freeze,O=(a=[])=>m.fromEntries(a),b=(...a)=>m.assign({},...a),I=(a,t)=>(delete a[t],a),L=(a,t)=>p(T(a),(([a,e])=>t(e,a))),R=(a,t)=>O(L(a,((a,e)=>[e,t(a,e)]))),D=a=>m.values(a),M=a=>u(C(a)),_=a=>(a=>!i(a)&&c(S(a),(a=>a==m.prototype||i(S(a))),(()=>!0)))(a)&&0==M(a),P=a=>new Set(w(a)||i(a)?a:[a]),F=(a,t)=>a?.add(t),U="_",j="_id",x="SELECT",B="WHERE",H="TABLE",J="ALTER "+H,Y="DELETE FROM",k=x+"*FROM",z="pragma_",G="data_version",V="schema_version",W="pragma_table_",K=a=>`"${a.replace(/"/g,'""')}"`,Q=(...a)=>g(p(a,K),n),X=(a,t=[1])=>g(p(a,(()=>"$"+t[0]++)),n),q=(a,t)=>a?.has(t)??!1,Z=a=>i(a)||0==(a=>a?.size??0)(a),aa=a=>[...a?.values()??[]],ta=(a,t)=>a?.forEach(t),ea=(a,t)=>a?.delete(t),na=JSON.stringify,sa=JSON.parse,oa=a=>new Map(a),ra=(a,t)=>a?.get(t),ia=(a,t)=>p([...a?.entries()??[]],(([a,e])=>t(e,a))),ca=(a,t,e)=>i(e)?(ea(a,t),a):a?.set(t,e),la=(a,t,e,n)=>(q(a,t)?n?.(ra(a,t)):ca(a,t,e()),ra(a,t)),wa=(a,t,e,n,s=0)=>c((e?la:ra)(a,t[s],s>u(t)-2?e:oa),(o=>{if(s>u(t)-2)return n?.(o)&&ca(a,t[s]),o;const r=wa(o,t,e,n,s+1);return Z(o)&&ca(a,t[s]),r})),ya=/^\d+$/,ua=oa(),da=oa(),Ea=(a,t,n,s,o,r,l,y={},d=0,g=[])=>{let p,A,h,m=0,S=0,T=0;la(ua,g,(()=>0)),la(da,g,(()=>[]));const C=oa(),[O,b,I,L,R]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!_(a)||!_(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!_(a)||!_(t),t.setContent]:E("Store type not supported by this Persister"))(l,a,d),[D,M,U]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?f(a):null)??e+t++,t=>{ya.test(t)&&u(a)<1e3&&N(a,t)}]})(),s=oa();return[(n,o,r,i=[],c=()=>[])=>{a??=z;const l=t(1);return ca(s,l,[n,o,r,i,c]),F(wa(o,r??[e],P),l),l},(t,n,...o)=>v(((a,t=[e])=>{const n=[],s=(a,e)=>e==u(t)?N(n,a):null===t[e]?ta(a,(a=>s(a,e+1))):v([t[e],null],(t=>s(ra(a,t),e+1)));return s(a,0),n})(t,n),(t=>ta(t,(t=>ra(s,t)[0](a,...n??[],...o))))),a=>c(ra(s,a),(([,t,o])=>(wa(t,o??[e],void 0,(t=>(ea(t,a),Z(t)?1:0))),ca(s,a),n(a),o))),t=>c(ra(s,t),(([t,,e=[],n,s])=>{const o=(...r)=>{const c=u(r);c==u(e)?t(a,...r,...s(r)):i(e[c])?v(n[c]?.(...r)??[],(a=>o(...r,a))):o(...r,e[c])};o()}))]})(),j=a=>{a!=m&&(m=a,M(C,void 0,m))},x=t=>{(O&&w(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},B=async a=>(2!=m&&(j(1),S++,await k((async()=>{try{const e=await t();w(e)?x(e):a?R(a):E("Content is not an array: "+e)}catch(t){r?.(t),a&&R(a)}j(0)}))),z),H=()=>(A&&(o(A),A=void 0),z),J=async a=>(1!=m&&(j(2),T++,await k((async()=>{try{await n(b,a)}catch(a){r?.(a)}j(0)}))),z),Y=()=>(h&&(a.delListener(h),h=void 0),z),k=async(...a)=>(N(ra(da,g),...a),await(async()=>{if(!ra(ua,g)){for(ca(ua,g,1);!i(p=f(ra(da,g)));)try{await p()}catch(a){r?.(a)}ca(ua,g,0)}})(),z),z={load:B,startAutoLoad:async a=>{H(),await B(a);try{A=await s((async(a,t)=>{t||a?2!=m&&(j(1),S++,x(t??a),j(0)):await B()}))}catch(a){r?.(a)}return z},stopAutoLoad:H,isAutoLoading:()=>!i(A),save:J,startAutoSave:async()=>(Y(),await J(),h=a.addDidFinishTransactionListener((()=>{const a=I();L(a)&&J(a)})),z),stopAutoSave:Y,isAutoSaving:()=>!i(h),getStatus:()=>m,addStatusListener:a=>D(a,C),delListener:t=>(U(t),a),schedule:k,getStore:()=>a,destroy:()=>(ra(da,g).splice(0,void 0),H().stopAutoSave()),getStats:()=>({loads:S,saves:T}),...y};return $(z)},va=(a,t,e,s,o,r=ga,c,l)=>{const w=oa();return[async()=>{w.clear(),p(await e(a,t),(({tn:a,cn:t})=>F(la(w,a,P),t)))},async(t,e)=>((a,t)=>q(ra(w,a),t))(t,e)?O(h(p(await a(k+K(t)),(a=>[a[e],l?R(I(a,e),l):I(a,e)])),(([a,t])=>!i(a)&&!_(t)))):{},async(t,e,s,l,y,u=!1)=>{const E=P();R(s??{},(a=>p(C(a??{}),(a=>F(E,a)))));const v=aa(E);if(!u&&y&&A(v)&&q(w,t))return await a("DROP "+H+K(t)),void ca(w,t);const f=ra(w,t),m=P(aa(f));if(A(v)||(q(w,t)?await d(p([e,...v],(async(n,s)=>{ea(m,n)||(await a(J+K(t)+"ADD"+K(n)+o),0==s&&await a("CREATE UNIQUE INDEX pk ON "+K(t)+`(${K(e)})`),F(f,n))}))):(await a("CREATE "+H+K(t)+`(${K(e)}${o} PRIMARY KEY${g(p(v,(a=>n+K(a)+o)))});`),ca(w,t,P([e,...v])))),await d([...!u&&l?p(aa(m),(async n=>{n!=e&&(await a(J+K(t)+"DROP"+K(n)),ea(f,n))})):[]]),u)i(s)?await a(Y+K(t)+B+" true"):await d(L(s,(async(n,s)=>{i(n)?await a(Y+K(t)+B+K(e)+"=$1",[s]):A(v)||await r(a,t,e,C(n),{[s]:c?p(D(n),c):D(n)},f)})));else if(A(v))q(w,t)&&await a(Y+K(t)+B+" true");else{const n=h(aa(ra(w,t)),(a=>a!=e)),o={},i=[];R(s??{},((a,t)=>{o[t]=p(n,(t=>c?c(a?.[t]):a?.[t])),N(i,t)})),await r(a,t,e,n,o),await a(Y+K(t)+B+K(e)+`NOT IN(${X(i)})`,i)}},async t=>{let e;await a("BEGIN");try{e=await t()}catch(a){s?.(a)}return await a("END"),e}]},ga=async(a,t,e,s,o)=>{const r=[1];await a("INSERT INTO"+K(t)+"("+Q(e,...s)+")VALUES"+g(L(o,(a=>"($"+r[0]+++","+X(a,r)+")")),n)+"ON CONFLICT("+K(e)+")DO UPDATE SET"+g(p(s,(a=>K(a)+"=excluded."+K(a))),n),L(o,((a,t)=>[t,...p(a,(a=>a??null))])).flat())},pa=(a,t,e,n,s,o,r,[i,c,l],w,y,u,d,E,v)=>{const[g,p,A,h]=va(t,w,y,s,E,v),N=Ea(a,(async()=>await h((async()=>{return await g(),a=(await p(i,c))[U]?.[l]??"null",sa(a,((a,t)=>""===t?void 0:t));var a}))),(async a=>await h((async()=>{var t;await g(),await A(i,c,{[U]:{[l]:(t=a()??null,na(t,((a,t)=>void 0===t?"":t)))}},!0,!0)}))),e,n,s,r,{[d]:()=>u,destroy:()=>(N.stopAutoLoad().stopAutoSave(),o(),N)},0,u);return N},Aa=(a,t,e,n,s,o,r,[c,l,[w,y,u]],E,v,g,p,A,N,f,m)=>{const[S,T,C,$]=va(t,E,v,s,A,N,f,m),b=async(a,t)=>await d(ia(l,(async([e,n,s,o],r)=>{t&&!(r in a)||await C(e,n,a[r],s,o,t)}))),I=async(a,t)=>y?await C(u,j,{[U]:a},!0,!0,t):null,L=Ea(a,(async()=>await $((async()=>{await S();const a=await(async()=>O(h(await d(ia(c,(async([a,t],e)=>[a,await T(e,t)]))),(a=>!_(a[1])))))(),t=await(async()=>w?(await T(u,j))[U]:{})();return _(a)&&i(t)?void 0:[a,t]}))),(async(a,t)=>await $((async()=>{if(await S(),i(t)){const[t,e]=a();await b(t),await I(e)}else await b(t[0],!0),await I(t[1],!0)}))),e,n,s,r,{[p]:()=>g,destroy:()=>(L.stopAutoLoad().stopAutoSave(),o(),L)},0,g);return L},ha="ColumnName",Na="store",fa="json",ma=Na+"TableName",Sa=Na+"Id"+ha,Ta=Na+ha,Ca="autoLoadIntervalSeconds",$a="rowId"+ha,Oa="tableId",ba="tableName",Ia="deleteEmptyColumns",La="deleteEmptyTable",Ra={mode:fa,[Ca]:1},Da={load:0,save:0,[ba]:t+"_values"},Ma=(a,t,e,n,s)=>{const o=oa();return R(a,((a,r)=>{const c=y(D(b(t,l(a)?{[e]:a}:a)),0,M(t));i(c[0])||n(r,c[0])||(s(r,c[0]),ca(o,r,c))})),o},_a=(a,n,s,o,i,c,w,u,d,E,v="getDb",g)=>{let p,A,h;const N=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,c),[f,m,S,T]=(a=>{const e=(a=>b(Ra,l(a)?{[ma]:a}:a??{}))(a),n=e[Ca];if(e.mode==fa){const a=e[ma]??t;return[1,n,[a,e[Sa]??j,e[Ta]??Na],P(a)]}const{tables:{load:s={},save:o={}}={},values:r={}}=e,i=y(D(b(Da,r)),0,M(Da)),c=i[2],w=P(c),u=P(c);return[0,n,[Ma(s,{[Oa]:null,[$a]:j},Oa,(a=>q(u,a)),(a=>F(w,a))),Ma(o,{[ba]:null,[$a]:j,[Ia]:0,[La]:0},ba,((a,t)=>q(u,t)),((a,t)=>F(w,t))),i],w]})(n);return(f?pa:Aa)(a,N,(a=>{let t;const e=()=>t=setInterval((async()=>{try{const[{d:t,s:e,c:n}]=await N(`${x} ${G} d,${V} s,TOTAL_CHANGES() c FROM ${z}${G} JOIN ${z}${V}`);t==p&&e==A&&n==h||(null!=p&&a(),p=t,A=e,h=n)}catch{}}),1e3*m),n=()=>{p=A=h=null,r(t)},s=o((t=>{T.has(t)&&(n(),a(),e())}));return e(),()=>{n(),i(s)}}),(a=>a()),w,u,d,S,aa(T),(async(a,t)=>await a(`${x} 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(t)})ORDER BY t.name,c.name`,t)),E,v,e,g,(a=>!0===a?1:!1===a?0:a),void 0)},Pa=(a,t,e,n,s)=>{let o;return _a(a,e,(async(a,e=[])=>t.execute(a,e).then((a=>a.rows?._array??[]))),(a=>{const e=new AbortController,n=t.onChange({rawTableNames:!0,signal:e.signal});return(async()=>{for await(const a of n)o&&p(a.changedTables,o)})(),o=a,e}),(a=>{o=void 0,a.abort()}),n,s,(()=>0),1,t,"getPowerSync",Fa)},Fa=async(a,t,e,s,o,r)=>{const i=[1],c=P(s),l=r?h([...r],(a=>a!=e&&!q(c,a))):[];if(!A(l)){const n=C(o),s=O(p(await a("SELECT"+Q(e,...l)+"FROM"+K(t)+"WHERE"+K(e)+"IN("+X(n)+")",n),(a=>[a[e],a])));v(n,(a=>N(o[a],...p(l,(t=>s?.[a]?.[t]??null)))))}await a("INSERT OR REPLACE INTO"+K(t)+"("+Q(e,...s,...l)+")VALUES"+g(L(o,(a=>"($"+i[0]+++","+X(a,i)+")")),n),L(o,((a,t)=>[t,...p(a,(a=>a??null))])).flat())};export{Pa as createPowerSyncPersister};
|
|
Binary file
|