tinybase 7.0.0-beta.2 → 7.0.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/@types/common/index.d.ts +1 -1
- package/@types/mergeable-store/index.d.ts +1 -1
- package/@types/mergeable-store/with-schemas/index.d.ts +1 -1
- package/@types/persisters/persister-cr-sqlite-wasm/index.d.ts +4 -0
- package/@types/persisters/persister-cr-sqlite-wasm/with-schemas/index.d.ts +4 -0
- package/@types/persisters/persister-durable-object-sql-storage/index.d.ts +4 -0
- package/@types/persisters/persister-durable-object-sql-storage/with-schemas/index.d.ts +4 -0
- package/@types/persisters/persister-electric-sql/index.d.ts +4 -0
- package/@types/persisters/persister-electric-sql/with-schemas/index.d.ts +4 -0
- package/@types/persisters/persister-expo-sqlite/index.d.ts +4 -0
- package/@types/persisters/persister-expo-sqlite/with-schemas/index.d.ts +4 -0
- package/@types/persisters/persister-libsql/index.d.ts +4 -0
- package/@types/persisters/persister-libsql/with-schemas/index.d.ts +4 -0
- package/@types/persisters/persister-pglite/index.d.ts +5 -1
- package/@types/persisters/persister-pglite/with-schemas/index.d.ts +5 -1
- package/@types/persisters/persister-postgres/index.d.ts +4 -0
- package/@types/persisters/persister-postgres/with-schemas/index.d.ts +4 -0
- package/@types/persisters/persister-powersync/index.d.ts +4 -0
- package/@types/persisters/persister-powersync/with-schemas/index.d.ts +4 -0
- package/@types/persisters/persister-react-native-sqlite/index.d.ts +4 -0
- package/@types/persisters/persister-react-native-sqlite/with-schemas/index.d.ts +4 -0
- package/@types/persisters/persister-sqlite-bun/index.d.ts +4 -0
- package/@types/persisters/persister-sqlite-bun/with-schemas/index.d.ts +4 -0
- package/@types/persisters/persister-sqlite-wasm/index.d.ts +4 -0
- package/@types/persisters/persister-sqlite-wasm/with-schemas/index.d.ts +4 -0
- package/@types/persisters/persister-sqlite3/index.d.ts +4 -0
- package/@types/persisters/persister-sqlite3/with-schemas/index.d.ts +4 -0
- package/@types/queries/index.d.ts +1 -1
- package/@types/store/index.d.ts +21 -19
- package/@types/store/with-schemas/index.d.ts +15 -13
- package/agents.md +62 -0
- package/checkpoints/index.js +8 -6
- package/checkpoints/with-schemas/index.js +8 -6
- package/common/index.js +4 -3
- package/common/with-schemas/index.js +4 -3
- package/index.js +60 -30
- package/indexes/index.js +7 -5
- package/indexes/with-schemas/index.js +7 -5
- package/mergeable-store/index.js +51 -21
- package/mergeable-store/with-schemas/index.js +51 -21
- package/metrics/index.js +7 -5
- package/metrics/with-schemas/index.js +7 -5
- package/min/checkpoints/index.js +1 -1
- package/min/checkpoints/index.js.gz +0 -0
- package/min/checkpoints/with-schemas/index.js +1 -1
- package/min/checkpoints/with-schemas/index.js.gz +0 -0
- package/min/common/index.js +1 -1
- package/min/common/index.js.gz +0 -0
- package/min/common/with-schemas/index.js +1 -1
- package/min/common/with-schemas/index.js.gz +0 -0
- package/min/index.js +1 -1
- package/min/index.js.gz +0 -0
- package/min/indexes/index.js +1 -1
- package/min/indexes/index.js.gz +0 -0
- package/min/indexes/with-schemas/index.js +1 -1
- package/min/indexes/with-schemas/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/metrics/index.js +1 -1
- package/min/metrics/index.js.gz +0 -0
- package/min/metrics/with-schemas/index.js +1 -1
- package/min/metrics/with-schemas/index.js.gz +0 -0
- package/min/omni/index.js +1 -1
- package/min/omni/index.js.gz +0 -0
- package/min/omni/with-schemas/index.js +1 -1
- package/min/omni/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-browser/index.js +1 -1
- package/min/persisters/persister-browser/index.js.gz +0 -0
- package/min/persisters/persister-browser/with-schemas/index.js +1 -1
- package/min/persisters/persister-browser/with-schemas/index.js.gz +0 -0
- package/min/persisters/persister-cr-sqlite-wasm/index.js +1 -1
- package/min/persisters/persister-cr-sqlite-wasm/index.js.gz +0 -0
- package/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.js +1 -1
- package/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.js.gz +0 -0
- package/min/persisters/persister-durable-object-sql-storage/index.js +1 -1
- package/min/persisters/persister-durable-object-sql-storage/index.js.gz +0 -0
- package/min/persisters/persister-durable-object-sql-storage/with-schemas/index.js +1 -1
- package/min/persisters/persister-durable-object-sql-storage/with-schemas/index.js.gz +0 -0
- package/min/persisters/persister-durable-object-storage/index.js +1 -1
- package/min/persisters/persister-durable-object-storage/index.js.gz +0 -0
- package/min/persisters/persister-durable-object-storage/with-schemas/index.js +1 -1
- package/min/persisters/persister-durable-object-storage/with-schemas/index.js.gz +0 -0
- package/min/persisters/persister-electric-sql/index.js +1 -1
- package/min/persisters/persister-electric-sql/index.js.gz +0 -0
- package/min/persisters/persister-electric-sql/with-schemas/index.js +1 -1
- package/min/persisters/persister-electric-sql/with-schemas/index.js.gz +0 -0
- package/min/persisters/persister-expo-sqlite/index.js +1 -1
- package/min/persisters/persister-expo-sqlite/index.js.gz +0 -0
- package/min/persisters/persister-expo-sqlite/with-schemas/index.js +1 -1
- package/min/persisters/persister-expo-sqlite/with-schemas/index.js.gz +0 -0
- package/min/persisters/persister-file/index.js +1 -1
- package/min/persisters/persister-file/index.js.gz +0 -0
- package/min/persisters/persister-file/with-schemas/index.js +1 -1
- package/min/persisters/persister-file/with-schemas/index.js.gz +0 -0
- package/min/persisters/persister-indexed-db/index.js +1 -1
- package/min/persisters/persister-indexed-db/index.js.gz +0 -0
- package/min/persisters/persister-indexed-db/with-schemas/index.js +1 -1
- package/min/persisters/persister-indexed-db/with-schemas/index.js.gz +0 -0
- package/min/persisters/persister-libsql/index.js +1 -1
- package/min/persisters/persister-libsql/index.js.gz +0 -0
- package/min/persisters/persister-libsql/with-schemas/index.js +1 -1
- package/min/persisters/persister-libsql/with-schemas/index.js.gz +0 -0
- package/min/persisters/persister-partykit-client/index.js +1 -1
- package/min/persisters/persister-partykit-client/index.js.gz +0 -0
- package/min/persisters/persister-partykit-client/with-schemas/index.js +1 -1
- package/min/persisters/persister-partykit-client/with-schemas/index.js.gz +0 -0
- package/min/persisters/persister-partykit-server/index.js +1 -1
- package/min/persisters/persister-partykit-server/index.js.gz +0 -0
- package/min/persisters/persister-partykit-server/with-schemas/index.js +1 -1
- package/min/persisters/persister-partykit-server/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-react-native-mmkv/index.js +1 -1
- package/min/persisters/persister-react-native-mmkv/index.js.gz +0 -0
- package/min/persisters/persister-react-native-mmkv/with-schemas/index.js +1 -1
- package/min/persisters/persister-react-native-mmkv/with-schemas/index.js.gz +0 -0
- package/min/persisters/persister-react-native-sqlite/index.js +1 -1
- package/min/persisters/persister-react-native-sqlite/index.js.gz +0 -0
- package/min/persisters/persister-react-native-sqlite/with-schemas/index.js +1 -1
- package/min/persisters/persister-react-native-sqlite/with-schemas/index.js.gz +0 -0
- package/min/persisters/persister-remote/index.js +1 -1
- package/min/persisters/persister-remote/index.js.gz +0 -0
- package/min/persisters/persister-remote/with-schemas/index.js +1 -1
- package/min/persisters/persister-remote/with-schemas/index.js.gz +0 -0
- package/min/persisters/persister-sqlite-bun/index.js +1 -1
- package/min/persisters/persister-sqlite-bun/index.js.gz +0 -0
- package/min/persisters/persister-sqlite-bun/with-schemas/index.js +1 -1
- package/min/persisters/persister-sqlite-bun/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/relationships/index.js +1 -1
- package/min/relationships/index.js.gz +0 -0
- package/min/relationships/with-schemas/index.js +1 -1
- package/min/relationships/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/synchronizers/index.js +1 -1
- package/min/synchronizers/index.js.gz +0 -0
- package/min/synchronizers/synchronizer-broadcast-channel/index.js +1 -1
- package/min/synchronizers/synchronizer-broadcast-channel/index.js.gz +0 -0
- package/min/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js +1 -1
- package/min/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js.gz +0 -0
- package/min/synchronizers/synchronizer-local/index.js +1 -1
- package/min/synchronizers/synchronizer-local/index.js.gz +0 -0
- package/min/synchronizers/synchronizer-local/with-schemas/index.js +1 -1
- package/min/synchronizers/synchronizer-local/with-schemas/index.js.gz +0 -0
- package/min/synchronizers/synchronizer-ws-client/index.js +1 -1
- package/min/synchronizers/synchronizer-ws-client/index.js.gz +0 -0
- package/min/synchronizers/synchronizer-ws-client/with-schemas/index.js +1 -1
- package/min/synchronizers/synchronizer-ws-client/with-schemas/index.js.gz +0 -0
- package/min/synchronizers/synchronizer-ws-server/index.js +1 -1
- package/min/synchronizers/synchronizer-ws-server/index.js.gz +0 -0
- package/min/synchronizers/synchronizer-ws-server/with-schemas/index.js +1 -1
- package/min/synchronizers/synchronizer-ws-server/with-schemas/index.js.gz +0 -0
- package/min/synchronizers/synchronizer-ws-server-durable-object/index.js +1 -1
- package/min/synchronizers/synchronizer-ws-server-durable-object/index.js.gz +0 -0
- package/min/synchronizers/synchronizer-ws-server-durable-object/with-schemas/index.js +1 -1
- package/min/synchronizers/synchronizer-ws-server-durable-object/with-schemas/index.js.gz +0 -0
- package/min/synchronizers/synchronizer-ws-server-simple/index.js +1 -1
- package/min/synchronizers/synchronizer-ws-server-simple/index.js.gz +0 -0
- package/min/synchronizers/synchronizer-ws-server-simple/with-schemas/index.js +1 -1
- package/min/synchronizers/synchronizer-ws-server-simple/with-schemas/index.js.gz +0 -0
- package/min/synchronizers/with-schemas/index.js +1 -1
- package/min/synchronizers/with-schemas/index.js.gz +0 -0
- package/min/ui-react/index.js +1 -1
- package/min/ui-react/index.js.gz +0 -0
- package/min/ui-react/with-schemas/index.js +1 -1
- package/min/ui-react/with-schemas/index.js.gz +0 -0
- package/min/ui-react-dom/index.js +1 -1
- package/min/ui-react-dom/index.js.gz +0 -0
- package/min/ui-react-dom/with-schemas/index.js +1 -1
- package/min/ui-react-dom/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/omni/index.js +78 -46
- package/omni/with-schemas/index.js +78 -46
- package/package.json +3 -3
- package/persisters/index.js +14 -10
- package/persisters/persister-automerge/index.js +12 -8
- package/persisters/persister-automerge/with-schemas/index.js +12 -8
- package/persisters/persister-browser/index.js +12 -8
- package/persisters/persister-browser/with-schemas/index.js +12 -8
- package/persisters/persister-cr-sqlite-wasm/index.js +14 -10
- package/persisters/persister-cr-sqlite-wasm/with-schemas/index.js +14 -10
- package/persisters/persister-durable-object-sql-storage/index.js +14 -10
- package/persisters/persister-durable-object-sql-storage/with-schemas/index.js +14 -10
- package/persisters/persister-durable-object-storage/index.js +12 -8
- package/persisters/persister-durable-object-storage/with-schemas/index.js +12 -8
- package/persisters/persister-electric-sql/index.js +14 -10
- package/persisters/persister-electric-sql/with-schemas/index.js +14 -10
- package/persisters/persister-expo-sqlite/index.js +14 -10
- package/persisters/persister-expo-sqlite/with-schemas/index.js +14 -10
- package/persisters/persister-file/index.js +12 -8
- package/persisters/persister-file/with-schemas/index.js +12 -8
- package/persisters/persister-indexed-db/index.js +12 -8
- package/persisters/persister-indexed-db/with-schemas/index.js +12 -8
- package/persisters/persister-libsql/index.js +14 -10
- package/persisters/persister-libsql/with-schemas/index.js +14 -10
- package/persisters/persister-partykit-client/index.js +12 -8
- package/persisters/persister-partykit-client/with-schemas/index.js +12 -8
- package/persisters/persister-partykit-server/index.js +4 -3
- package/persisters/persister-partykit-server/with-schemas/index.js +4 -3
- package/persisters/persister-pglite/index.js +13 -9
- package/persisters/persister-pglite/with-schemas/index.js +13 -9
- package/persisters/persister-postgres/index.js +13 -9
- package/persisters/persister-postgres/with-schemas/index.js +13 -9
- package/persisters/persister-powersync/index.js +14 -10
- package/persisters/persister-powersync/with-schemas/index.js +14 -10
- package/persisters/persister-react-native-mmkv/index.js +12 -8
- package/persisters/persister-react-native-mmkv/with-schemas/index.js +12 -8
- package/persisters/persister-react-native-sqlite/index.js +14 -10
- package/persisters/persister-react-native-sqlite/with-schemas/index.js +14 -10
- package/persisters/persister-remote/index.js +14 -10
- package/persisters/persister-remote/with-schemas/index.js +14 -10
- package/persisters/persister-sqlite-bun/index.js +14 -10
- package/persisters/persister-sqlite-bun/with-schemas/index.js +14 -10
- package/persisters/persister-sqlite-wasm/index.js +14 -10
- package/persisters/persister-sqlite-wasm/with-schemas/index.js +14 -10
- package/persisters/persister-sqlite3/index.js +14 -10
- package/persisters/persister-sqlite3/with-schemas/index.js +14 -10
- package/persisters/persister-yjs/index.js +18 -12
- package/persisters/persister-yjs/with-schemas/index.js +18 -12
- package/persisters/with-schemas/index.js +14 -10
- package/queries/index.js +17 -12
- package/queries/with-schemas/index.js +17 -12
- package/readme.md +2 -2
- package/relationships/index.js +7 -5
- package/relationships/with-schemas/index.js +7 -5
- package/releases.md +100 -12
- package/store/index.js +48 -18
- package/store/with-schemas/index.js +48 -18
- package/synchronizers/index.js +13 -9
- package/synchronizers/synchronizer-broadcast-channel/index.js +14 -10
- package/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js +14 -10
- package/synchronizers/synchronizer-local/index.js +14 -10
- package/synchronizers/synchronizer-local/with-schemas/index.js +14 -10
- package/synchronizers/synchronizer-ws-client/index.js +13 -9
- package/synchronizers/synchronizer-ws-client/with-schemas/index.js +13 -9
- package/synchronizers/synchronizer-ws-server/index.js +13 -9
- package/synchronizers/synchronizer-ws-server/with-schemas/index.js +13 -9
- package/synchronizers/synchronizer-ws-server-durable-object/index.js +13 -9
- package/synchronizers/synchronizer-ws-server-durable-object/with-schemas/index.js +13 -9
- package/synchronizers/synchronizer-ws-server-simple/index.js +5 -4
- package/synchronizers/synchronizer-ws-server-simple/with-schemas/index.js +5 -4
- package/synchronizers/with-schemas/index.js +13 -9
- package/ui-react/index.js +9 -6
- package/ui-react/with-schemas/index.js +9 -6
- package/ui-react-dom/index.js +14 -7
- package/ui-react-dom/with-schemas/index.js +14 -7
- package/ui-react-inspector/index.js +53 -23
- package/ui-react-inspector/with-schemas/index.js +53 -23
- package/with-schemas/index.js +60 -30
|
@@ -1 +1 @@
|
|
|
1
|
-
const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),i="true",r=(a,t,e)=>a.replace(t,e),o=Promise,c=
|
|
1
|
+
const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),i="true",r=(a,t,e)=>a.replace(t,e),o=Promise,c=a=>(t,e,n)=>a(t)?n?.():e(t),l=clearInterval,w=a=>null==a,y=a=>void 0===a,u=a=>null===a,d=c(w),v=c(y),g=t=>a(t)==s,p=a=>Array.isArray(a),E=(a,t,e)=>a.slice(t,e),A=a=>a.length,N=()=>{},m=async a=>o.all(a),$=a=>{throw Error(a)},f=async(a,t,e)=>{try{return await a()}catch(a){t?.(a)}},C=(a,t)=>a.forEach(t),T=(a,t="")=>a.join(t),h=(a,t)=>a.map(t),O=a=>0==A(a),b=(a,t)=>a.filter(t),D=(a,...t)=>a.push(...t),I=a=>a.shift(),S=(a,t)=>a?.has(t)??!1,L=a=>y(a)||0==(a=>a?.size??0)(a),R=a=>[...a?.values()??[]],P=(a,t)=>a?.forEach(t),M=(a,t)=>a?.delete(t),_="_",F="_id",U="SELECT",j="WHERE",B="TABLE",J="ALTER "+B,Y="FROM",k="DELETE "+Y,x=U+"*"+Y,z="pragma_",G="data_version",H="schema_version",q="pragma_table_",K="CREATE "+B,Q=a=>T(h(((a,t="",e)=>a.split(t,e))(a,"."),a=>`"${r(a,/"/g,'""')}"`),"."),V=(a,t=[1])=>T(h(a,()=>"$"+t[0]++),n),W=(a,t=i)=>j+`(${r(t,"$tableName",Q(a))})`,X=Object,Z=a=>X.getPrototypeOf(a),aa=X.entries,ta=X.keys,ea=X.freeze,na=(a=[])=>X.fromEntries(a),sa=(...a)=>X.assign({},...a),ia=(a,t)=>(delete a[t],a),ra=(a,t)=>h(aa(a),([a,e])=>t(e,a)),oa=(a,t)=>na(ra(a,(a,e)=>[e,t(a,e)])),ca=a=>X.values(a),la=a=>A(ta(a)),wa=a=>(a=>!w(a)&&d(Z(a),a=>a==X.prototype||w(Z(a)),()=>!0))(a)&&0==la(a),ya=a=>new Map(a),ua=(a,t)=>a?.get(t),da=(a,t)=>h([...a?.entries()??[]],([a,e])=>t(e,a)),va=(a,t,e)=>void 0===e?(M(a,t),a):a?.set(t,e),ga=(a,t,e,n)=>(S(a,t)?n?.(ua(a,t)):va(a,t,e()),ua(a,t)),pa=(a,t,e,n,s=0)=>v((e?ga:ua)(a,t[s],s>A(t)-2?e:ya),i=>{if(s>A(t)-2)return n?.(i)&&va(a,t[s]),i;const r=pa(i,t,e,n,s+1);return L(i)&&va(a,t[s]),r}),Ea=a=>new Set(p(a)||y(a)?a:[a]),Aa=(a,t)=>a?.add(t),Na="ColumnName",ma="store",$a="json",fa=ma+"TableName",Ca=ma+"Id"+Na,Ta=ma+Na,ha="autoLoadIntervalSeconds",Oa="rowId"+Na,ba="tableId",Da="tableName",Ia="deleteEmptyColumns",Sa="deleteEmptyTable",La="condition",Ra={mode:$a,[ha]:1},Pa={load:0,save:0,[Da]:t+"_values"},Ma=(a,t,e,n,s)=>{const i=ya();return oa(a,(a,r)=>{const o=E(ca(sa(t,g(a)?{[e]:a}:a)),0,la(t));u(o[0])||n(r,o[0])||(s(r,o[0]),va(i,r,o))}),i},_a=JSON.stringify,Fa=JSON.parse,Ua=/^\d+$/,ja=ya(),Ba=ya(),Ja=(a,t,n,s,i,r,o,c={},l=0,w=[])=>{let d,g,E,N=0,m=0,T=0;ga(ja,w,()=>0),ga(Ba,w,()=>[]);const h=ya(),[O,b,S,R,_]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!wa(a)||!wa(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!wa(a)||!wa(t),t.setContent]:$("Store type not supported by this Persister"))(o,a,l),[F,U,j]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?I(a):null)??e+t++,t=>{Ua.test(t)&&A(a)<1e3&&D(a,t)}]})(),s=ya();return[(n,i,r,o=[],c=()=>[])=>{a??=Q;const l=t(1);return va(s,l,[n,i,r,o,c]),Aa(pa(i,r??[e],Ea),l),l},(t,n,...i)=>C(((a,t=[e])=>{const n=[],s=(a,e)=>e==A(t)?D(n,a):null===t[e]?P(a,a=>s(a,e+1)):C([t[e],null],t=>s(ua(a,t),e+1));return s(a,0),n})(t,n),t=>P(t,t=>ua(s,t)[0](a,...n??[],...i))),a=>v(ua(s,a),([,t,i])=>(pa(t,i??[e],void 0,t=>(M(t,a),L(t)?1:0)),va(s,a),n(a),i)),t=>v(ua(s,t),([t,,e=[],n,s])=>{const i=(...r)=>{const o=A(r);o==A(e)?t(a,...r,...s(r)):u(e[o])?C(n[o]?.(...r)??[],a=>i(...r,a)):i(...r,e[o])};i()})]})(),B=a=>{a!=N&&(N=a,U(h,void 0,N))},J=t=>{(O&&p(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},Y=async a=>(2!=N&&(B(1),m++,await K(async()=>{await f(async()=>{const e=await t();p(e)?J(e):a?_(a):$("Content is not an array: "+e)},()=>{a&&_(a)}),B(0)})),Q),k=async a=>(x(),await Y(a),await f(async()=>g=await s(async(a,t)=>{t||a?2!=N&&(B(1),m++,J(t??a),B(0)):await Y()}),r),Q),x=async()=>(g&&(await f(()=>i(g),r),g=void 0),Q),z=async a=>(1!=N&&(B(2),T++,await K(async()=>{await f(()=>n(b,a),r),B(0)})),Q),G=async()=>(H(),await z(),E=a.addDidFinishTransactionListener(()=>{const a=S();R(a)&&z(a)}),Q),H=async()=>(E&&(a.delListener(E),E=void 0),Q),q=async(a=!1)=>{const[t,e]=a?[H,x]:[x,H];return await t(),await e(),Q},K=async(...a)=>(D(ua(Ba,w),...a),await(async()=>{if(!ua(ja,w)){for(va(ja,w,1);!y(d=I(ua(Ba,w)));)await f(d,r);va(ja,w,0)}})(),Q),Q={load:Y,startAutoLoad:k,stopAutoLoad:x,isAutoLoading:()=>!y(g),save:z,startAutoSave:G,stopAutoSave:H,isAutoSaving:()=>!y(E),startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[G,k]:[k,G];return await e(a),await n(a),Q},stopAutoPersisting:q,getStatus:()=>N,addStatusListener:a=>F(a,h),delListener:t=>(j(t),a),schedule:K,getStore:()=>a,destroy:()=>(ua(Ba,w).splice(0,void 0),q()),getStats:()=>({loads:m,saves:T}),...c};return ea(Q)},Ya=(a,t,e,s,r,o=ka,c,l)=>{const w=ya();return[async()=>{w.clear(),h(await e(a,t),({tn:a,cn:t})=>Aa(ga(w,a,Ea),t))},async(t,e,n)=>((a,t)=>S(ua(w,a),t))(t,e)?na(b(h(await a(x+Q(t)+W(t,n)),a=>[a[e],l?oa(ia(a,e),l):ia(a,e)]),([a,t])=>!y(a)&&!wa(t))):{},async(t,e,s,l,u,d=!1,v=i)=>{const g=Ea();oa(s??{},a=>h(ta(a??{}),a=>Aa(g,a)));const p=R(g);if(!d&&u&&v==i&&O(p)&&S(w,t))return await a("DROP "+B+Q(t)),void va(w,t);const E=ua(w,t),A=Ea(R(E));if(O(p)||(S(w,t)?await m(h([e,...p],async(n,s)=>{M(A,n)||(await a(J+Q(t)+"ADD"+Q(n)+r),0==s&&await a("CREATE UNIQUE INDEX pk ON "+Q(t)+`(${Q(e)})`),Aa(E,n))})):(await a(K+Q(t)+`(${Q(e)}${r} PRIMARY KEY${T(h(p,a=>n+Q(a)+r))});`),va(w,t,Ea([e,...p])))),await m([...!d&&l?h(R(A),async n=>{n!=e&&(await a(J+Q(t)+"DROP"+Q(n)),M(E,n))}):[]]),d)y(s)?await a(k+Q(t)+W(t,v)):await m(ra(s,async(n,s)=>{y(n)?await a(k+Q(t)+W(t,v)+`AND(${Q(e)}=$1)`,[s]):O(p)||await o(a,t,e,ta(n),{[s]:c?h(ca(n),c):ca(n)},E)}));else if(O(p))S(w,t)&&await a(k+Q(t)+W(t,v));else{const n=b(R(ua(w,t)),a=>a!=e),i={},r=[];oa(s??{},(a,t)=>{i[t]=h(n,t=>c?c(a?.[t]):a?.[t]),D(r,t)}),await o(a,t,e,n,i),await a(k+Q(t)+W(t,v)+`AND${Q(e)}NOT IN(${V(r)})`,r)}},async t=>{let e;return await a("BEGIN"),await f(async()=>e=await t(),s),await a("END"),e}]},ka=async(a,t,e,s,i)=>{const r=[1];await a("INSERT INTO"+Q(t)+"("+((...a)=>T(h(a,Q),n))(e,...s)+")VALUES"+T(ra(i,a=>"($"+r[0]+++","+V(a,r)+")"),n)+"ON CONFLICT("+Q(e)+")DO UPDATE SET"+T(h(s,a=>Q(a)+"=excluded."+Q(a)),n),ra(i,(a,t)=>[t,...h(a,a=>a??null)]).flat())},xa=(a,t,e,n,s,i,r,[o,c,l],w,y,u,d,v,g)=>{const[p,E,A,N]=Ya(t,w,y,s,v,g),m=Ja(a,()=>N(async()=>{return await p(),a=(await E(o,c))[_]?.[l]??"null",Fa(a,(a,t)=>""===t?void 0:t);var a}),a=>N(async()=>{var t;await p(),await A(o,c,{[_]:{[l]:(t=a()??null,_a(t,(a,t)=>void 0===t?"":t))}},!0,!0)}),e,n,s,r,{[d]:()=>u,destroy:async()=>(await m.stopAutoPersisting(),i(),m)},0,u);return m},za=(a,t,e,n,s,i,r,[o,c,[l,w,u]],d,v,g,p,E,A,N,$)=>{const[f,C,T,h]=Ya(t,d,v,s,E,A,N,$),O=(a,t)=>m(da(c,async([e,n,s,i,r],o)=>{t&&!(o in a)||await T(e,n,a[o],s,i,t,r)})),D=async(a,t)=>w?await T(u,F,{[_]:a},!0,!0,t):null,I=Ja(a,()=>h(async()=>{await f();const a=await(async()=>na(b(await m(da(o,async([a,t,e],n)=>[a,await C(n,t,e)])),a=>!wa(a[1]))))(),t=await(async()=>l?(await C(u,F))[_]:{})();return wa(a)&&y(t)?void 0:[a,t]}),(a,t)=>h(async()=>{if(await f(),y(t)){const[t,e]=a();await O(t),await D(e)}else await O(t[0],!0),await D(t[1],!0)}),e,n,s,r,{[p]:()=>g,destroy:async()=>(await I.stopAutoPersisting(),i(),I)},0,g);return I},Ga=(a,n,s,r,o,c,y,u,d,v,p="getDb",A)=>{let N,m,$;const C=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,c),[T,h,O,b]=(a=>{const e=(a=>sa(Ra,g(a)?{[fa]:a}:a??{}))(a),n=e[ha];if(e.mode==$a){const a=e[fa]??t;return[1,n,[a,e[Ca]??F,e[Ta]??ma],Ea(a)]}const{tables:{load:s={},save:r={}}={},values:o={}}=e,c=E(ca(sa(Pa,o)),0,la(Pa)),l=c[2],w=Ea(l),y=Ea(l),u=Ma(s,{[ba]:null,[Oa]:F,[La]:i},ba,a=>S(y,a),a=>Aa(w,a)),d=Ma(r,{[Da]:null,[Oa]:F,[Ia]:0,[Sa]:0,[La]:null},Da,(a,t)=>S(y,t),(a,t)=>Aa(w,t));var v;return v=(a,t)=>t[4]??=ua(u,t[0])?.[2]??i,P(d,(a,t)=>v(0,a)),[0,n,[u,d,c],w]})(n);return(T?xa:za)(a,C,a=>{let t;const e=()=>t=setInterval(()=>f(async()=>{const[{d:t,s:e,c:n}]=await C(U+` ${G} d,${H} s,TOTAL_CHANGES() c FROM ${z}${G} JOIN ${z}${H}`);t==N&&e==m&&n==$||(w(N)||a(),N=t,m=e,$=n)}),1e3*h),n=()=>{N=m=$=null,l(t)},s=r(t=>{b.has(t)&&(n(),a(),e())});return e(),()=>{n(),o(s)}},a=>a(),y,u,d,O,R(b),async(a,t)=>await a(U+` t.name tn,c.name cn FROM ${q}list()t,${q}info(t.name)c ${j} t.schema='main'AND t.type IN('table','view')AND t.name IN(${V(t)})ORDER BY t.name,c.name`,t),v,p,e,A,a=>!0===a?1:!1===a?0:a,void 0)},Ha=(a,t,e,n,s)=>Ga(a,e,async(a,e=[])=>t.query(a).all(...e),()=>N,a=>a(),n,s,N,3,t);export{Ha as createSqliteBunPersister};
|
|
Binary file
|
|
@@ -1 +1 @@
|
|
|
1
|
-
const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),i="true",o=(a,t,e)=>a.replace(t,e),r=Promise,c=
|
|
1
|
+
const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),i="true",o=(a,t,e)=>a.replace(t,e),r=Promise,c=a=>(t,e,n)=>a(t)?n?.():e(t),l=clearInterval,w=a=>null==a,u=a=>void 0===a,y=a=>null===a,d=c(w),p=c(u),v=t=>a(t)==s,g=a=>Array.isArray(a),E=(a,t,e)=>a.slice(t,e),A=a=>a.length,m=()=>{},N=async a=>r.all(a),$=a=>{throw Error(a)},f=async(a,t,e)=>{try{return await a()}catch(a){t?.(a)}},h=(a,t)=>a.forEach(t),b=(a,t="")=>a.join(t),C=(a,t)=>a.map(t),T=a=>0==A(a),O=(a,t)=>a.filter(t),D=(a,...t)=>a.push(...t),I=a=>a.shift(),S=(a,t)=>a?.has(t)??!1,L=a=>u(a)||0==(a=>a?.size??0)(a),R=a=>[...a?.values()??[]],_=(a,t)=>a?.forEach(t),M=(a,t)=>a?.delete(t),P="_",F="_id",j="SELECT",k="WHERE",U="TABLE",x="ALTER "+U,B="FROM",J="DELETE "+B,Y=j+"*"+B,q="pragma_",z="data_version",G="schema_version",H="pragma_table_",V="CREATE "+U,K=a=>b(C(((a,t="",e)=>a.split(t,e))(a,"."),a=>`"${o(a,/"/g,'""')}"`),"."),Q=(a,t=[1])=>b(C(a,()=>"$"+t[0]++),n),W=(a,t=i)=>k+`(${o(t,"$tableName",K(a))})`,X=Object,Z=a=>X.getPrototypeOf(a),aa=X.entries,ta=X.keys,ea=X.freeze,na=(a=[])=>X.fromEntries(a),sa=(...a)=>X.assign({},...a),ia=(a,t)=>(delete a[t],a),oa=(a,t)=>C(aa(a),([a,e])=>t(e,a)),ra=(a,t)=>na(oa(a,(a,e)=>[e,t(a,e)])),ca=a=>X.values(a),la=a=>A(ta(a)),wa=a=>(a=>!w(a)&&d(Z(a),a=>a==X.prototype||w(Z(a)),()=>!0))(a)&&0==la(a),ua=a=>new Map(a),ya=(a,t)=>a?.get(t),da=(a,t)=>C([...a?.entries()??[]],([a,e])=>t(e,a)),pa=(a,t,e)=>void 0===e?(M(a,t),a):a?.set(t,e),va=(a,t,e,n)=>(S(a,t)?n?.(ya(a,t)):pa(a,t,e()),ya(a,t)),ga=(a,t,e,n,s=0)=>p((e?va:ya)(a,t[s],s>A(t)-2?e:ua),i=>{if(s>A(t)-2)return n?.(i)&&pa(a,t[s]),i;const o=ga(i,t,e,n,s+1);return L(i)&&pa(a,t[s]),o}),Ea=a=>new Set(g(a)||u(a)?a:[a]),Aa=(a,t)=>a?.add(t),ma="ColumnName",Na="store",$a="json",fa=Na+"TableName",ha=Na+"Id"+ma,ba=Na+ma,Ca="autoLoadIntervalSeconds",Ta="rowId"+ma,Oa="tableId",Da="tableName",Ia="deleteEmptyColumns",Sa="deleteEmptyTable",La="condition",Ra={mode:$a,[Ca]:1},_a={load:0,save:0,[Da]:t+"_values"},Ma=(a,t,e,n,s)=>{const i=ua();return ra(a,(a,o)=>{const r=E(ca(sa(t,v(a)?{[e]:a}:a)),0,la(t));y(r[0])||n(o,r[0])||(s(o,r[0]),pa(i,o,r))}),i},Pa=JSON.stringify,Fa=JSON.parse,ja=/^\d+$/,ka=ua(),Ua=ua(),xa=(a,t,n,s,i,o,r,c={},l=0,w=[])=>{let d,v,E,m=0,N=0,b=0;va(ka,w,()=>0),va(Ua,w,()=>[]);const C=ua(),[T,O,S,R,P]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!wa(a)||!wa(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!wa(a)||!wa(t),t.setContent]:$("Store type not supported by this Persister"))(r,a,l),[F,j,k]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?I(a):null)??e+t++,t=>{ja.test(t)&&A(a)<1e3&&D(a,t)}]})(),s=ua();return[(n,i,o,r=[],c=()=>[])=>{a??=K;const l=t(1);return pa(s,l,[n,i,o,r,c]),Aa(ga(i,o??[e],Ea),l),l},(t,n,...i)=>h(((a,t=[e])=>{const n=[],s=(a,e)=>e==A(t)?D(n,a):null===t[e]?_(a,a=>s(a,e+1)):h([t[e],null],t=>s(ya(a,t),e+1));return s(a,0),n})(t,n),t=>_(t,t=>ya(s,t)[0](a,...n??[],...i))),a=>p(ya(s,a),([,t,i])=>(ga(t,i??[e],void 0,t=>(M(t,a),L(t)?1:0)),pa(s,a),n(a),i)),t=>p(ya(s,t),([t,,e=[],n,s])=>{const i=(...o)=>{const r=A(o);r==A(e)?t(a,...o,...s(o)):y(e[r])?h(n[r]?.(...o)??[],a=>i(...o,a)):i(...o,e[r])};i()})]})(),U=a=>{a!=m&&(m=a,j(C,void 0,m))},x=t=>{(T&&g(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},B=async a=>(2!=m&&(U(1),N++,await V(async()=>{await f(async()=>{const e=await t();g(e)?x(e):a?P(a):$("Content is not an array: "+e)},()=>{a&&P(a)}),U(0)})),K),J=async a=>(Y(),await B(a),await f(async()=>v=await s(async(a,t)=>{t||a?2!=m&&(U(1),N++,x(t??a),U(0)):await B()}),o),K),Y=async()=>(v&&(await f(()=>i(v),o),v=void 0),K),q=async a=>(1!=m&&(U(2),b++,await V(async()=>{await f(()=>n(O,a),o),U(0)})),K),z=async()=>(G(),await q(),E=a.addDidFinishTransactionListener(()=>{const a=S();R(a)&&q(a)}),K),G=async()=>(E&&(a.delListener(E),E=void 0),K),H=async(a=!1)=>{const[t,e]=a?[G,Y]:[Y,G];return await t(),await e(),K},V=async(...a)=>(D(ya(Ua,w),...a),await(async()=>{if(!ya(ka,w)){for(pa(ka,w,1);!u(d=I(ya(Ua,w)));)await f(d,o);pa(ka,w,0)}})(),K),K={load:B,startAutoLoad:J,stopAutoLoad:Y,isAutoLoading:()=>!u(v),save:q,startAutoSave:z,stopAutoSave:G,isAutoSaving:()=>!u(E),startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[z,J]:[J,z];return await e(a),await n(a),K},stopAutoPersisting:H,getStatus:()=>m,addStatusListener:a=>F(a,C),delListener:t=>(k(t),a),schedule:V,getStore:()=>a,destroy:()=>(ya(Ua,w).splice(0,void 0),H()),getStats:()=>({loads:N,saves:b}),...c};return ea(K)},Ba=(a,t,e,s,o,r=Ja,c,l)=>{const w=ua();return[async()=>{w.clear(),C(await e(a,t),({tn:a,cn:t})=>Aa(va(w,a,Ea),t))},async(t,e,n)=>((a,t)=>S(ya(w,a),t))(t,e)?na(O(C(await a(Y+K(t)+W(t,n)),a=>[a[e],l?ra(ia(a,e),l):ia(a,e)]),([a,t])=>!u(a)&&!wa(t))):{},async(t,e,s,l,y,d=!1,p=i)=>{const v=Ea();ra(s??{},a=>C(ta(a??{}),a=>Aa(v,a)));const g=R(v);if(!d&&y&&p==i&&T(g)&&S(w,t))return await a("DROP "+U+K(t)),void pa(w,t);const E=ya(w,t),A=Ea(R(E));if(T(g)||(S(w,t)?await N(C([e,...g],async(n,s)=>{M(A,n)||(await a(x+K(t)+"ADD"+K(n)+o),0==s&&await a("CREATE UNIQUE INDEX pk ON "+K(t)+`(${K(e)})`),Aa(E,n))})):(await a(V+K(t)+`(${K(e)}${o} PRIMARY KEY${b(C(g,a=>n+K(a)+o))});`),pa(w,t,Ea([e,...g])))),await N([...!d&&l?C(R(A),async n=>{n!=e&&(await a(x+K(t)+"DROP"+K(n)),M(E,n))}):[]]),d)u(s)?await a(J+K(t)+W(t,p)):await N(oa(s,async(n,s)=>{u(n)?await a(J+K(t)+W(t,p)+`AND(${K(e)}=$1)`,[s]):T(g)||await r(a,t,e,ta(n),{[s]:c?C(ca(n),c):ca(n)},E)}));else if(T(g))S(w,t)&&await a(J+K(t)+W(t,p));else{const n=O(R(ya(w,t)),a=>a!=e),i={},o=[];ra(s??{},(a,t)=>{i[t]=C(n,t=>c?c(a?.[t]):a?.[t]),D(o,t)}),await r(a,t,e,n,i),await a(J+K(t)+W(t,p)+`AND${K(e)}NOT IN(${Q(o)})`,o)}},async t=>{let e;return await a("BEGIN"),await f(async()=>e=await t(),s),await a("END"),e}]},Ja=async(a,t,e,s,i)=>{const o=[1];await a("INSERT INTO"+K(t)+"("+((...a)=>b(C(a,K),n))(e,...s)+")VALUES"+b(oa(i,a=>"($"+o[0]+++","+Q(a,o)+")"),n)+"ON CONFLICT("+K(e)+")DO UPDATE SET"+b(C(s,a=>K(a)+"=excluded."+K(a)),n),oa(i,(a,t)=>[t,...C(a,a=>a??null)]).flat())},Ya=(a,t,e,n,s,i,o,[r,c,l],w,u,y,d,p,v)=>{const[g,E,A,m]=Ba(t,w,u,s,p,v),N=xa(a,()=>m(async()=>{return await g(),a=(await E(r,c))[P]?.[l]??"null",Fa(a,(a,t)=>""===t?void 0:t);var a}),a=>m(async()=>{var t;await g(),await A(r,c,{[P]:{[l]:(t=a()??null,Pa(t,(a,t)=>void 0===t?"":t))}},!0,!0)}),e,n,s,o,{[d]:()=>y,destroy:async()=>(await N.stopAutoPersisting(),i(),N)},0,y);return N},qa=(a,t,e,n,s,i,o,[r,c,[l,w,y]],d,p,v,g,E,A,m,$)=>{const[f,h,b,C]=Ba(t,d,p,s,E,A,m,$),T=(a,t)=>N(da(c,async([e,n,s,i,o],r)=>{t&&!(r in a)||await b(e,n,a[r],s,i,t,o)})),D=async(a,t)=>w?await b(y,F,{[P]:a},!0,!0,t):null,I=xa(a,()=>C(async()=>{await f();const a=await(async()=>na(O(await N(da(r,async([a,t,e],n)=>[a,await h(n,t,e)])),a=>!wa(a[1]))))(),t=await(async()=>l?(await h(y,F))[P]:{})();return wa(a)&&u(t)?void 0:[a,t]}),(a,t)=>C(async()=>{if(await f(),u(t)){const[t,e]=a();await T(t),await D(e)}else await T(t[0],!0),await D(t[1],!0)}),e,n,s,o,{[g]:()=>v,destroy:async()=>(await I.stopAutoPersisting(),i(),I)},0,v);return I},za=(a,n,s,o,r,c,u,y,d,p,g="getDb",A)=>{let m,N,$;const h=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,c),[b,C,T,O]=(a=>{const e=(a=>sa(Ra,v(a)?{[fa]:a}:a??{}))(a),n=e[Ca];if(e.mode==$a){const a=e[fa]??t;return[1,n,[a,e[ha]??F,e[ba]??Na],Ea(a)]}const{tables:{load:s={},save:o={}}={},values:r={}}=e,c=E(ca(sa(_a,r)),0,la(_a)),l=c[2],w=Ea(l),u=Ea(l),y=Ma(s,{[Oa]:null,[Ta]:F,[La]:i},Oa,a=>S(u,a),a=>Aa(w,a)),d=Ma(o,{[Da]:null,[Ta]:F,[Ia]:0,[Sa]:0,[La]:null},Da,(a,t)=>S(u,t),(a,t)=>Aa(w,t));var p;return p=(a,t)=>t[4]??=ya(y,t[0])?.[2]??i,_(d,(a,t)=>p(0,a)),[0,n,[y,d,c],w]})(n);return(b?Ya:qa)(a,h,a=>{let t;const e=()=>t=setInterval(()=>f(async()=>{const[{d:t,s:e,c:n}]=await h(j+` ${z} d,${G} s,TOTAL_CHANGES() c FROM ${q}${z} JOIN ${q}${G}`);t==m&&e==N&&n==$||(w(m)||a(),m=t,N=e,$=n)}),1e3*C),n=()=>{m=N=$=null,l(t)},s=o(t=>{O.has(t)&&(n(),a(),e())});return e(),()=>{n(),r(s)}},a=>a(),u,y,d,T,R(O),async(a,t)=>await a(j+` t.name tn,c.name cn FROM ${H}list()t,${H}info(t.name)c ${k} t.schema='main'AND t.type IN('table','view')AND t.name IN(${Q(t)})ORDER BY t.name,c.name`,t),p,g,e,A,a=>!0===a?1:!1===a?0:a,void 0)},Ga=(a,t,e,n,s,i)=>za(a,n,async(a,t=[])=>e.exec(a,{bind:t,rowMode:"object",returnValue:"resultRows"}).map(a=>({...a})),a=>t.capi.sqlite3_update_hook(e,(t,e,n,s)=>a(s),0),()=>t.capi.sqlite3_update_hook(e,m,0),s,i,m,3,e);export{Ga as createSqliteWasmPersister};
|
|
Binary file
|
|
@@ -1 +1 @@
|
|
|
1
|
-
const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),i="true",o=(a,t,e)=>a.replace(t,e),r=Promise,c=
|
|
1
|
+
const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),i="true",o=(a,t,e)=>a.replace(t,e),r=Promise,c=a=>(t,e,n)=>a(t)?n?.():e(t),l=clearInterval,w=a=>null==a,u=a=>void 0===a,y=a=>null===a,d=c(w),p=c(u),v=t=>a(t)==s,g=a=>Array.isArray(a),E=(a,t,e)=>a.slice(t,e),A=a=>a.length,m=()=>{},N=async a=>r.all(a),$=a=>{throw Error(a)},f=async(a,t,e)=>{try{return await a()}catch(a){t?.(a)}},h=(a,t)=>a.forEach(t),b=(a,t="")=>a.join(t),C=(a,t)=>a.map(t),T=a=>0==A(a),O=(a,t)=>a.filter(t),D=(a,...t)=>a.push(...t),I=a=>a.shift(),S=(a,t)=>a?.has(t)??!1,L=a=>u(a)||0==(a=>a?.size??0)(a),R=a=>[...a?.values()??[]],_=(a,t)=>a?.forEach(t),M=(a,t)=>a?.delete(t),P="_",F="_id",j="SELECT",k="WHERE",U="TABLE",x="ALTER "+U,B="FROM",J="DELETE "+B,Y=j+"*"+B,q="pragma_",z="data_version",G="schema_version",H="pragma_table_",V="CREATE "+U,K=a=>b(C(((a,t="",e)=>a.split(t,e))(a,"."),a=>`"${o(a,/"/g,'""')}"`),"."),Q=(a,t=[1])=>b(C(a,()=>"$"+t[0]++),n),W=(a,t=i)=>k+`(${o(t,"$tableName",K(a))})`,X=Object,Z=a=>X.getPrototypeOf(a),aa=X.entries,ta=X.keys,ea=X.freeze,na=(a=[])=>X.fromEntries(a),sa=(...a)=>X.assign({},...a),ia=(a,t)=>(delete a[t],a),oa=(a,t)=>C(aa(a),([a,e])=>t(e,a)),ra=(a,t)=>na(oa(a,(a,e)=>[e,t(a,e)])),ca=a=>X.values(a),la=a=>A(ta(a)),wa=a=>(a=>!w(a)&&d(Z(a),a=>a==X.prototype||w(Z(a)),()=>!0))(a)&&0==la(a),ua=a=>new Map(a),ya=(a,t)=>a?.get(t),da=(a,t)=>C([...a?.entries()??[]],([a,e])=>t(e,a)),pa=(a,t,e)=>void 0===e?(M(a,t),a):a?.set(t,e),va=(a,t,e,n)=>(S(a,t)?n?.(ya(a,t)):pa(a,t,e()),ya(a,t)),ga=(a,t,e,n,s=0)=>p((e?va:ya)(a,t[s],s>A(t)-2?e:ua),i=>{if(s>A(t)-2)return n?.(i)&&pa(a,t[s]),i;const o=ga(i,t,e,n,s+1);return L(i)&&pa(a,t[s]),o}),Ea=a=>new Set(g(a)||u(a)?a:[a]),Aa=(a,t)=>a?.add(t),ma="ColumnName",Na="store",$a="json",fa=Na+"TableName",ha=Na+"Id"+ma,ba=Na+ma,Ca="autoLoadIntervalSeconds",Ta="rowId"+ma,Oa="tableId",Da="tableName",Ia="deleteEmptyColumns",Sa="deleteEmptyTable",La="condition",Ra={mode:$a,[Ca]:1},_a={load:0,save:0,[Da]:t+"_values"},Ma=(a,t,e,n,s)=>{const i=ua();return ra(a,(a,o)=>{const r=E(ca(sa(t,v(a)?{[e]:a}:a)),0,la(t));y(r[0])||n(o,r[0])||(s(o,r[0]),pa(i,o,r))}),i},Pa=JSON.stringify,Fa=JSON.parse,ja=/^\d+$/,ka=ua(),Ua=ua(),xa=(a,t,n,s,i,o,r,c={},l=0,w=[])=>{let d,v,E,m=0,N=0,b=0;va(ka,w,()=>0),va(Ua,w,()=>[]);const C=ua(),[T,O,S,R,P]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!wa(a)||!wa(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!wa(a)||!wa(t),t.setContent]:$("Store type not supported by this Persister"))(r,a,l),[F,j,k]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?I(a):null)??e+t++,t=>{ja.test(t)&&A(a)<1e3&&D(a,t)}]})(),s=ua();return[(n,i,o,r=[],c=()=>[])=>{a??=K;const l=t(1);return pa(s,l,[n,i,o,r,c]),Aa(ga(i,o??[e],Ea),l),l},(t,n,...i)=>h(((a,t=[e])=>{const n=[],s=(a,e)=>e==A(t)?D(n,a):null===t[e]?_(a,a=>s(a,e+1)):h([t[e],null],t=>s(ya(a,t),e+1));return s(a,0),n})(t,n),t=>_(t,t=>ya(s,t)[0](a,...n??[],...i))),a=>p(ya(s,a),([,t,i])=>(ga(t,i??[e],void 0,t=>(M(t,a),L(t)?1:0)),pa(s,a),n(a),i)),t=>p(ya(s,t),([t,,e=[],n,s])=>{const i=(...o)=>{const r=A(o);r==A(e)?t(a,...o,...s(o)):y(e[r])?h(n[r]?.(...o)??[],a=>i(...o,a)):i(...o,e[r])};i()})]})(),U=a=>{a!=m&&(m=a,j(C,void 0,m))},x=t=>{(T&&g(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},B=async a=>(2!=m&&(U(1),N++,await V(async()=>{await f(async()=>{const e=await t();g(e)?x(e):a?P(a):$("Content is not an array: "+e)},()=>{a&&P(a)}),U(0)})),K),J=async a=>(Y(),await B(a),await f(async()=>v=await s(async(a,t)=>{t||a?2!=m&&(U(1),N++,x(t??a),U(0)):await B()}),o),K),Y=async()=>(v&&(await f(()=>i(v),o),v=void 0),K),q=async a=>(1!=m&&(U(2),b++,await V(async()=>{await f(()=>n(O,a),o),U(0)})),K),z=async()=>(G(),await q(),E=a.addDidFinishTransactionListener(()=>{const a=S();R(a)&&q(a)}),K),G=async()=>(E&&(a.delListener(E),E=void 0),K),H=async(a=!1)=>{const[t,e]=a?[G,Y]:[Y,G];return await t(),await e(),K},V=async(...a)=>(D(ya(Ua,w),...a),await(async()=>{if(!ya(ka,w)){for(pa(ka,w,1);!u(d=I(ya(Ua,w)));)await f(d,o);pa(ka,w,0)}})(),K),K={load:B,startAutoLoad:J,stopAutoLoad:Y,isAutoLoading:()=>!u(v),save:q,startAutoSave:z,stopAutoSave:G,isAutoSaving:()=>!u(E),startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[z,J]:[J,z];return await e(a),await n(a),K},stopAutoPersisting:H,getStatus:()=>m,addStatusListener:a=>F(a,C),delListener:t=>(k(t),a),schedule:V,getStore:()=>a,destroy:()=>(ya(Ua,w).splice(0,void 0),H()),getStats:()=>({loads:N,saves:b}),...c};return ea(K)},Ba=(a,t,e,s,o,r=Ja,c,l)=>{const w=ua();return[async()=>{w.clear(),C(await e(a,t),({tn:a,cn:t})=>Aa(va(w,a,Ea),t))},async(t,e,n)=>((a,t)=>S(ya(w,a),t))(t,e)?na(O(C(await a(Y+K(t)+W(t,n)),a=>[a[e],l?ra(ia(a,e),l):ia(a,e)]),([a,t])=>!u(a)&&!wa(t))):{},async(t,e,s,l,y,d=!1,p=i)=>{const v=Ea();ra(s??{},a=>C(ta(a??{}),a=>Aa(v,a)));const g=R(v);if(!d&&y&&p==i&&T(g)&&S(w,t))return await a("DROP "+U+K(t)),void pa(w,t);const E=ya(w,t),A=Ea(R(E));if(T(g)||(S(w,t)?await N(C([e,...g],async(n,s)=>{M(A,n)||(await a(x+K(t)+"ADD"+K(n)+o),0==s&&await a("CREATE UNIQUE INDEX pk ON "+K(t)+`(${K(e)})`),Aa(E,n))})):(await a(V+K(t)+`(${K(e)}${o} PRIMARY KEY${b(C(g,a=>n+K(a)+o))});`),pa(w,t,Ea([e,...g])))),await N([...!d&&l?C(R(A),async n=>{n!=e&&(await a(x+K(t)+"DROP"+K(n)),M(E,n))}):[]]),d)u(s)?await a(J+K(t)+W(t,p)):await N(oa(s,async(n,s)=>{u(n)?await a(J+K(t)+W(t,p)+`AND(${K(e)}=$1)`,[s]):T(g)||await r(a,t,e,ta(n),{[s]:c?C(ca(n),c):ca(n)},E)}));else if(T(g))S(w,t)&&await a(J+K(t)+W(t,p));else{const n=O(R(ya(w,t)),a=>a!=e),i={},o=[];ra(s??{},(a,t)=>{i[t]=C(n,t=>c?c(a?.[t]):a?.[t]),D(o,t)}),await r(a,t,e,n,i),await a(J+K(t)+W(t,p)+`AND${K(e)}NOT IN(${Q(o)})`,o)}},async t=>{let e;return await a("BEGIN"),await f(async()=>e=await t(),s),await a("END"),e}]},Ja=async(a,t,e,s,i)=>{const o=[1];await a("INSERT INTO"+K(t)+"("+((...a)=>b(C(a,K),n))(e,...s)+")VALUES"+b(oa(i,a=>"($"+o[0]+++","+Q(a,o)+")"),n)+"ON CONFLICT("+K(e)+")DO UPDATE SET"+b(C(s,a=>K(a)+"=excluded."+K(a)),n),oa(i,(a,t)=>[t,...C(a,a=>a??null)]).flat())},Ya=(a,t,e,n,s,i,o,[r,c,l],w,u,y,d,p,v)=>{const[g,E,A,m]=Ba(t,w,u,s,p,v),N=xa(a,()=>m(async()=>{return await g(),a=(await E(r,c))[P]?.[l]??"null",Fa(a,(a,t)=>""===t?void 0:t);var a}),a=>m(async()=>{var t;await g(),await A(r,c,{[P]:{[l]:(t=a()??null,Pa(t,(a,t)=>void 0===t?"":t))}},!0,!0)}),e,n,s,o,{[d]:()=>y,destroy:async()=>(await N.stopAutoPersisting(),i(),N)},0,y);return N},qa=(a,t,e,n,s,i,o,[r,c,[l,w,y]],d,p,v,g,E,A,m,$)=>{const[f,h,b,C]=Ba(t,d,p,s,E,A,m,$),T=(a,t)=>N(da(c,async([e,n,s,i,o],r)=>{t&&!(r in a)||await b(e,n,a[r],s,i,t,o)})),D=async(a,t)=>w?await b(y,F,{[P]:a},!0,!0,t):null,I=xa(a,()=>C(async()=>{await f();const a=await(async()=>na(O(await N(da(r,async([a,t,e],n)=>[a,await h(n,t,e)])),a=>!wa(a[1]))))(),t=await(async()=>l?(await h(y,F))[P]:{})();return wa(a)&&u(t)?void 0:[a,t]}),(a,t)=>C(async()=>{if(await f(),u(t)){const[t,e]=a();await T(t),await D(e)}else await T(t[0],!0),await D(t[1],!0)}),e,n,s,o,{[g]:()=>v,destroy:async()=>(await I.stopAutoPersisting(),i(),I)},0,v);return I},za=(a,n,s,o,r,c,u,y,d,p,g="getDb",A)=>{let m,N,$;const h=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,c),[b,C,T,O]=(a=>{const e=(a=>sa(Ra,v(a)?{[fa]:a}:a??{}))(a),n=e[Ca];if(e.mode==$a){const a=e[fa]??t;return[1,n,[a,e[ha]??F,e[ba]??Na],Ea(a)]}const{tables:{load:s={},save:o={}}={},values:r={}}=e,c=E(ca(sa(_a,r)),0,la(_a)),l=c[2],w=Ea(l),u=Ea(l),y=Ma(s,{[Oa]:null,[Ta]:F,[La]:i},Oa,a=>S(u,a),a=>Aa(w,a)),d=Ma(o,{[Da]:null,[Ta]:F,[Ia]:0,[Sa]:0,[La]:null},Da,(a,t)=>S(u,t),(a,t)=>Aa(w,t));var p;return p=(a,t)=>t[4]??=ya(y,t[0])?.[2]??i,_(d,(a,t)=>p(0,a)),[0,n,[y,d,c],w]})(n);return(b?Ya:qa)(a,h,a=>{let t;const e=()=>t=setInterval(()=>f(async()=>{const[{d:t,s:e,c:n}]=await h(j+` ${z} d,${G} s,TOTAL_CHANGES() c FROM ${q}${z} JOIN ${q}${G}`);t==m&&e==N&&n==$||(w(m)||a(),m=t,N=e,$=n)}),1e3*C),n=()=>{m=N=$=null,l(t)},s=o(t=>{O.has(t)&&(n(),a(),e())});return e(),()=>{n(),r(s)}},a=>a(),u,y,d,T,R(O),async(a,t)=>await a(j+` t.name tn,c.name cn FROM ${H}list()t,${H}info(t.name)c ${k} t.schema='main'AND t.type IN('table','view')AND t.name IN(${Q(t)})ORDER BY t.name,c.name`,t),p,g,e,A,a=>!0===a?1:!1===a?0:a,void 0)},Ga=(a,t,e,n,s,i)=>za(a,n,async(a,t=[])=>e.exec(a,{bind:t,rowMode:"object",returnValue:"resultRows"}).map(a=>({...a})),a=>t.capi.sqlite3_update_hook(e,(t,e,n,s)=>a(s),0),()=>t.capi.sqlite3_update_hook(e,m,0),s,i,m,3,e);export{Ga as createSqliteWasmPersister};
|
|
Binary file
|
|
@@ -1 +1 @@
|
|
|
1
|
-
const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),i="true",r=(a,t,e)=>a.replace(t,e),o=Promise,c=
|
|
1
|
+
const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),i="true",r=(a,t,e)=>a.replace(t,e),o=Promise,c=a=>(t,e,n)=>a(t)?n?.():e(t),l=clearInterval,w=a=>null==a,u=a=>void 0===a,y=a=>null===a,d=c(w),v=c(u),g=t=>a(t)==s,p=a=>Array.isArray(a),E=(a,t,e)=>a.slice(t,e),A=a=>a.length,N=()=>{},m=async a=>o.all(a),$=a=>{throw Error(a)},f=async(a,t,e)=>{try{return await a()}catch(a){t?.(a)}},h=(a,t)=>a.forEach(t),C=(a,t="")=>a.join(t),T=(a,t)=>a.map(t),O=a=>0==A(a),b=(a,t)=>a.filter(t),D=(a,...t)=>a.push(...t),I=a=>a.shift(),S=(a,t)=>a?.has(t)??!1,L=a=>u(a)||0==(a=>a?.size??0)(a),R=a=>[...a?.values()??[]],P=(a,t)=>a?.forEach(t),M=(a,t)=>a?.delete(t),_="_",F="_id",U="SELECT",j="WHERE",B="TABLE",J="ALTER "+B,Y="FROM",k="DELETE "+Y,x=U+"*"+Y,z="pragma_",G="data_version",H="schema_version",K="pragma_table_",Q="CREATE "+B,V=a=>C(T(((a,t="",e)=>a.split(t,e))(a,"."),a=>`"${r(a,/"/g,'""')}"`),"."),W=(a,t=[1])=>C(T(a,()=>"$"+t[0]++),n),X=(a,t=i)=>j+`(${r(t,"$tableName",V(a))})`,q=Object,Z=a=>q.getPrototypeOf(a),aa=q.entries,ta=q.keys,ea=q.freeze,na=(a=[])=>q.fromEntries(a),sa=(...a)=>q.assign({},...a),ia=(a,t)=>(delete a[t],a),ra=(a,t)=>T(aa(a),([a,e])=>t(e,a)),oa=(a,t)=>na(ra(a,(a,e)=>[e,t(a,e)])),ca=a=>q.values(a),la=a=>A(ta(a)),wa=a=>(a=>!w(a)&&d(Z(a),a=>a==q.prototype||w(Z(a)),()=>!0))(a)&&0==la(a),ua=a=>new Map(a),ya=(a,t)=>a?.get(t),da=(a,t)=>T([...a?.entries()??[]],([a,e])=>t(e,a)),va=(a,t,e)=>void 0===e?(M(a,t),a):a?.set(t,e),ga=(a,t,e,n)=>(S(a,t)?n?.(ya(a,t)):va(a,t,e()),ya(a,t)),pa=(a,t,e,n,s=0)=>v((e?ga:ya)(a,t[s],s>A(t)-2?e:ua),i=>{if(s>A(t)-2)return n?.(i)&&va(a,t[s]),i;const r=pa(i,t,e,n,s+1);return L(i)&&va(a,t[s]),r}),Ea=a=>new Set(p(a)||u(a)?a:[a]),Aa=(a,t)=>a?.add(t),Na="ColumnName",ma="store",$a="json",fa=ma+"TableName",ha=ma+"Id"+Na,Ca=ma+Na,Ta="autoLoadIntervalSeconds",Oa="rowId"+Na,ba="tableId",Da="tableName",Ia="deleteEmptyColumns",Sa="deleteEmptyTable",La="condition",Ra={mode:$a,[Ta]:1},Pa={load:0,save:0,[Da]:t+"_values"},Ma=(a,t,e,n,s)=>{const i=ua();return oa(a,(a,r)=>{const o=E(ca(sa(t,g(a)?{[e]:a}:a)),0,la(t));y(o[0])||n(r,o[0])||(s(r,o[0]),va(i,r,o))}),i},_a=JSON.stringify,Fa=JSON.parse,Ua=/^\d+$/,ja=ua(),Ba=ua(),Ja=(a,t,n,s,i,r,o,c={},l=0,w=[])=>{let d,g,E,N=0,m=0,C=0;ga(ja,w,()=>0),ga(Ba,w,()=>[]);const T=ua(),[O,b,S,R,_]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!wa(a)||!wa(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!wa(a)||!wa(t),t.setContent]:$("Store type not supported by this Persister"))(o,a,l),[F,U,j]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?I(a):null)??e+t++,t=>{Ua.test(t)&&A(a)<1e3&&D(a,t)}]})(),s=ua();return[(n,i,r,o=[],c=()=>[])=>{a??=V;const l=t(1);return va(s,l,[n,i,r,o,c]),Aa(pa(i,r??[e],Ea),l),l},(t,n,...i)=>h(((a,t=[e])=>{const n=[],s=(a,e)=>e==A(t)?D(n,a):null===t[e]?P(a,a=>s(a,e+1)):h([t[e],null],t=>s(ya(a,t),e+1));return s(a,0),n})(t,n),t=>P(t,t=>ya(s,t)[0](a,...n??[],...i))),a=>v(ya(s,a),([,t,i])=>(pa(t,i??[e],void 0,t=>(M(t,a),L(t)?1:0)),va(s,a),n(a),i)),t=>v(ya(s,t),([t,,e=[],n,s])=>{const i=(...r)=>{const o=A(r);o==A(e)?t(a,...r,...s(r)):y(e[o])?h(n[o]?.(...r)??[],a=>i(...r,a)):i(...r,e[o])};i()})]})(),B=a=>{a!=N&&(N=a,U(T,void 0,N))},J=t=>{(O&&p(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},Y=async a=>(2!=N&&(B(1),m++,await Q(async()=>{await f(async()=>{const e=await t();p(e)?J(e):a?_(a):$("Content is not an array: "+e)},()=>{a&&_(a)}),B(0)})),V),k=async a=>(x(),await Y(a),await f(async()=>g=await s(async(a,t)=>{t||a?2!=N&&(B(1),m++,J(t??a),B(0)):await Y()}),r),V),x=async()=>(g&&(await f(()=>i(g),r),g=void 0),V),z=async a=>(1!=N&&(B(2),C++,await Q(async()=>{await f(()=>n(b,a),r),B(0)})),V),G=async()=>(H(),await z(),E=a.addDidFinishTransactionListener(()=>{const a=S();R(a)&&z(a)}),V),H=async()=>(E&&(a.delListener(E),E=void 0),V),K=async(a=!1)=>{const[t,e]=a?[H,x]:[x,H];return await t(),await e(),V},Q=async(...a)=>(D(ya(Ba,w),...a),await(async()=>{if(!ya(ja,w)){for(va(ja,w,1);!u(d=I(ya(Ba,w)));)await f(d,r);va(ja,w,0)}})(),V),V={load:Y,startAutoLoad:k,stopAutoLoad:x,isAutoLoading:()=>!u(g),save:z,startAutoSave:G,stopAutoSave:H,isAutoSaving:()=>!u(E),startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[G,k]:[k,G];return await e(a),await n(a),V},stopAutoPersisting:K,getStatus:()=>N,addStatusListener:a=>F(a,T),delListener:t=>(j(t),a),schedule:Q,getStore:()=>a,destroy:()=>(ya(Ba,w).splice(0,void 0),K()),getStats:()=>({loads:m,saves:C}),...c};return ea(V)},Ya=(a,t,e,s,r,o=ka,c,l)=>{const w=ua();return[async()=>{w.clear(),T(await e(a,t),({tn:a,cn:t})=>Aa(ga(w,a,Ea),t))},async(t,e,n)=>((a,t)=>S(ya(w,a),t))(t,e)?na(b(T(await a(x+V(t)+X(t,n)),a=>[a[e],l?oa(ia(a,e),l):ia(a,e)]),([a,t])=>!u(a)&&!wa(t))):{},async(t,e,s,l,y,d=!1,v=i)=>{const g=Ea();oa(s??{},a=>T(ta(a??{}),a=>Aa(g,a)));const p=R(g);if(!d&&y&&v==i&&O(p)&&S(w,t))return await a("DROP "+B+V(t)),void va(w,t);const E=ya(w,t),A=Ea(R(E));if(O(p)||(S(w,t)?await m(T([e,...p],async(n,s)=>{M(A,n)||(await a(J+V(t)+"ADD"+V(n)+r),0==s&&await a("CREATE UNIQUE INDEX pk ON "+V(t)+`(${V(e)})`),Aa(E,n))})):(await a(Q+V(t)+`(${V(e)}${r} PRIMARY KEY${C(T(p,a=>n+V(a)+r))});`),va(w,t,Ea([e,...p])))),await m([...!d&&l?T(R(A),async n=>{n!=e&&(await a(J+V(t)+"DROP"+V(n)),M(E,n))}):[]]),d)u(s)?await a(k+V(t)+X(t,v)):await m(ra(s,async(n,s)=>{u(n)?await a(k+V(t)+X(t,v)+`AND(${V(e)}=$1)`,[s]):O(p)||await o(a,t,e,ta(n),{[s]:c?T(ca(n),c):ca(n)},E)}));else if(O(p))S(w,t)&&await a(k+V(t)+X(t,v));else{const n=b(R(ya(w,t)),a=>a!=e),i={},r=[];oa(s??{},(a,t)=>{i[t]=T(n,t=>c?c(a?.[t]):a?.[t]),D(r,t)}),await o(a,t,e,n,i),await a(k+V(t)+X(t,v)+`AND${V(e)}NOT IN(${W(r)})`,r)}},async t=>{let e;return await a("BEGIN"),await f(async()=>e=await t(),s),await a("END"),e}]},ka=async(a,t,e,s,i)=>{const r=[1];await a("INSERT INTO"+V(t)+"("+((...a)=>C(T(a,V),n))(e,...s)+")VALUES"+C(ra(i,a=>"($"+r[0]+++","+W(a,r)+")"),n)+"ON CONFLICT("+V(e)+")DO UPDATE SET"+C(T(s,a=>V(a)+"=excluded."+V(a)),n),ra(i,(a,t)=>[t,...T(a,a=>a??null)]).flat())},xa=(a,t,e,n,s,i,r,[o,c,l],w,u,y,d,v,g)=>{const[p,E,A,N]=Ya(t,w,u,s,v,g),m=Ja(a,()=>N(async()=>{return await p(),a=(await E(o,c))[_]?.[l]??"null",Fa(a,(a,t)=>""===t?void 0:t);var a}),a=>N(async()=>{var t;await p(),await A(o,c,{[_]:{[l]:(t=a()??null,_a(t,(a,t)=>void 0===t?"":t))}},!0,!0)}),e,n,s,r,{[d]:()=>y,destroy:async()=>(await m.stopAutoPersisting(),i(),m)},0,y);return m},za=(a,t,e,n,s,i,r,[o,c,[l,w,y]],d,v,g,p,E,A,N,$)=>{const[f,h,C,T]=Ya(t,d,v,s,E,A,N,$),O=(a,t)=>m(da(c,async([e,n,s,i,r],o)=>{t&&!(o in a)||await C(e,n,a[o],s,i,t,r)})),D=async(a,t)=>w?await C(y,F,{[_]:a},!0,!0,t):null,I=Ja(a,()=>T(async()=>{await f();const a=await(async()=>na(b(await m(da(o,async([a,t,e],n)=>[a,await h(n,t,e)])),a=>!wa(a[1]))))(),t=await(async()=>l?(await h(y,F))[_]:{})();return wa(a)&&u(t)?void 0:[a,t]}),(a,t)=>T(async()=>{if(await f(),u(t)){const[t,e]=a();await O(t),await D(e)}else await O(t[0],!0),await D(t[1],!0)}),e,n,s,r,{[p]:()=>g,destroy:async()=>(await I.stopAutoPersisting(),i(),I)},0,g);return I},Ga=(a,n,s,r,o,c,u,y,d,v,p="getDb",A)=>{let N,m,$;const h=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,c),[C,T,O,b]=(a=>{const e=(a=>sa(Ra,g(a)?{[fa]:a}:a??{}))(a),n=e[Ta];if(e.mode==$a){const a=e[fa]??t;return[1,n,[a,e[ha]??F,e[Ca]??ma],Ea(a)]}const{tables:{load:s={},save:r={}}={},values:o={}}=e,c=E(ca(sa(Pa,o)),0,la(Pa)),l=c[2],w=Ea(l),u=Ea(l),y=Ma(s,{[ba]:null,[Oa]:F,[La]:i},ba,a=>S(u,a),a=>Aa(w,a)),d=Ma(r,{[Da]:null,[Oa]:F,[Ia]:0,[Sa]:0,[La]:null},Da,(a,t)=>S(u,t),(a,t)=>Aa(w,t));var v;return v=(a,t)=>t[4]??=ya(y,t[0])?.[2]??i,P(d,(a,t)=>v(0,a)),[0,n,[y,d,c],w]})(n);return(C?xa:za)(a,h,a=>{let t;const e=()=>t=setInterval(()=>f(async()=>{const[{d:t,s:e,c:n}]=await h(U+` ${G} d,${H} s,TOTAL_CHANGES() c FROM ${z}${G} JOIN ${z}${H}`);t==N&&e==m&&n==$||(w(N)||a(),N=t,m=e,$=n)}),1e3*T),n=()=>{N=m=$=null,l(t)},s=r(t=>{b.has(t)&&(n(),a(),e())});return e(),()=>{n(),o(s)}},a=>a(),u,y,d,O,R(b),async(a,t)=>await a(U+` t.name tn,c.name cn FROM ${K}list()t,${K}info(t.name)c ${j} t.schema='main'AND t.type IN('table','view')AND t.name IN(${W(t)})ORDER BY t.name,c.name`,t),v,p,e,A,a=>!0===a?1:!1===a?0:a,void 0)},Ha="change",Ka=(a,t,e,n,s)=>Ga(a,e,async(a,e=[])=>{return await(n=(n,s)=>t.all(a,e,(a,t)=>a?s(a):n(t)),new o(n));var n},a=>{const e=(t,e,n)=>a(n);return t.on(Ha,e),e},a=>t.off(Ha,a),n,s,N,3,t);export{Ka as createSqlite3Persister};
|
|
Binary file
|
|
@@ -1 +1 @@
|
|
|
1
|
-
const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),i="true",r=(a,t,e)=>a.replace(t,e),o=Promise,c=
|
|
1
|
+
const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),i="true",r=(a,t,e)=>a.replace(t,e),o=Promise,c=a=>(t,e,n)=>a(t)?n?.():e(t),l=clearInterval,w=a=>null==a,u=a=>void 0===a,y=a=>null===a,d=c(w),v=c(u),g=t=>a(t)==s,p=a=>Array.isArray(a),E=(a,t,e)=>a.slice(t,e),A=a=>a.length,N=()=>{},m=async a=>o.all(a),$=a=>{throw Error(a)},f=async(a,t,e)=>{try{return await a()}catch(a){t?.(a)}},h=(a,t)=>a.forEach(t),C=(a,t="")=>a.join(t),T=(a,t)=>a.map(t),O=a=>0==A(a),b=(a,t)=>a.filter(t),D=(a,...t)=>a.push(...t),I=a=>a.shift(),S=(a,t)=>a?.has(t)??!1,L=a=>u(a)||0==(a=>a?.size??0)(a),R=a=>[...a?.values()??[]],P=(a,t)=>a?.forEach(t),M=(a,t)=>a?.delete(t),_="_",F="_id",U="SELECT",j="WHERE",B="TABLE",J="ALTER "+B,Y="FROM",k="DELETE "+Y,x=U+"*"+Y,z="pragma_",G="data_version",H="schema_version",K="pragma_table_",Q="CREATE "+B,V=a=>C(T(((a,t="",e)=>a.split(t,e))(a,"."),a=>`"${r(a,/"/g,'""')}"`),"."),W=(a,t=[1])=>C(T(a,()=>"$"+t[0]++),n),X=(a,t=i)=>j+`(${r(t,"$tableName",V(a))})`,q=Object,Z=a=>q.getPrototypeOf(a),aa=q.entries,ta=q.keys,ea=q.freeze,na=(a=[])=>q.fromEntries(a),sa=(...a)=>q.assign({},...a),ia=(a,t)=>(delete a[t],a),ra=(a,t)=>T(aa(a),([a,e])=>t(e,a)),oa=(a,t)=>na(ra(a,(a,e)=>[e,t(a,e)])),ca=a=>q.values(a),la=a=>A(ta(a)),wa=a=>(a=>!w(a)&&d(Z(a),a=>a==q.prototype||w(Z(a)),()=>!0))(a)&&0==la(a),ua=a=>new Map(a),ya=(a,t)=>a?.get(t),da=(a,t)=>T([...a?.entries()??[]],([a,e])=>t(e,a)),va=(a,t,e)=>void 0===e?(M(a,t),a):a?.set(t,e),ga=(a,t,e,n)=>(S(a,t)?n?.(ya(a,t)):va(a,t,e()),ya(a,t)),pa=(a,t,e,n,s=0)=>v((e?ga:ya)(a,t[s],s>A(t)-2?e:ua),i=>{if(s>A(t)-2)return n?.(i)&&va(a,t[s]),i;const r=pa(i,t,e,n,s+1);return L(i)&&va(a,t[s]),r}),Ea=a=>new Set(p(a)||u(a)?a:[a]),Aa=(a,t)=>a?.add(t),Na="ColumnName",ma="store",$a="json",fa=ma+"TableName",ha=ma+"Id"+Na,Ca=ma+Na,Ta="autoLoadIntervalSeconds",Oa="rowId"+Na,ba="tableId",Da="tableName",Ia="deleteEmptyColumns",Sa="deleteEmptyTable",La="condition",Ra={mode:$a,[Ta]:1},Pa={load:0,save:0,[Da]:t+"_values"},Ma=(a,t,e,n,s)=>{const i=ua();return oa(a,(a,r)=>{const o=E(ca(sa(t,g(a)?{[e]:a}:a)),0,la(t));y(o[0])||n(r,o[0])||(s(r,o[0]),va(i,r,o))}),i},_a=JSON.stringify,Fa=JSON.parse,Ua=/^\d+$/,ja=ua(),Ba=ua(),Ja=(a,t,n,s,i,r,o,c={},l=0,w=[])=>{let d,g,E,N=0,m=0,C=0;ga(ja,w,()=>0),ga(Ba,w,()=>[]);const T=ua(),[O,b,S,R,_]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!wa(a)||!wa(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!wa(a)||!wa(t),t.setContent]:$("Store type not supported by this Persister"))(o,a,l),[F,U,j]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?I(a):null)??e+t++,t=>{Ua.test(t)&&A(a)<1e3&&D(a,t)}]})(),s=ua();return[(n,i,r,o=[],c=()=>[])=>{a??=V;const l=t(1);return va(s,l,[n,i,r,o,c]),Aa(pa(i,r??[e],Ea),l),l},(t,n,...i)=>h(((a,t=[e])=>{const n=[],s=(a,e)=>e==A(t)?D(n,a):null===t[e]?P(a,a=>s(a,e+1)):h([t[e],null],t=>s(ya(a,t),e+1));return s(a,0),n})(t,n),t=>P(t,t=>ya(s,t)[0](a,...n??[],...i))),a=>v(ya(s,a),([,t,i])=>(pa(t,i??[e],void 0,t=>(M(t,a),L(t)?1:0)),va(s,a),n(a),i)),t=>v(ya(s,t),([t,,e=[],n,s])=>{const i=(...r)=>{const o=A(r);o==A(e)?t(a,...r,...s(r)):y(e[o])?h(n[o]?.(...r)??[],a=>i(...r,a)):i(...r,e[o])};i()})]})(),B=a=>{a!=N&&(N=a,U(T,void 0,N))},J=t=>{(O&&p(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},Y=async a=>(2!=N&&(B(1),m++,await Q(async()=>{await f(async()=>{const e=await t();p(e)?J(e):a?_(a):$("Content is not an array: "+e)},()=>{a&&_(a)}),B(0)})),V),k=async a=>(x(),await Y(a),await f(async()=>g=await s(async(a,t)=>{t||a?2!=N&&(B(1),m++,J(t??a),B(0)):await Y()}),r),V),x=async()=>(g&&(await f(()=>i(g),r),g=void 0),V),z=async a=>(1!=N&&(B(2),C++,await Q(async()=>{await f(()=>n(b,a),r),B(0)})),V),G=async()=>(H(),await z(),E=a.addDidFinishTransactionListener(()=>{const a=S();R(a)&&z(a)}),V),H=async()=>(E&&(a.delListener(E),E=void 0),V),K=async(a=!1)=>{const[t,e]=a?[H,x]:[x,H];return await t(),await e(),V},Q=async(...a)=>(D(ya(Ba,w),...a),await(async()=>{if(!ya(ja,w)){for(va(ja,w,1);!u(d=I(ya(Ba,w)));)await f(d,r);va(ja,w,0)}})(),V),V={load:Y,startAutoLoad:k,stopAutoLoad:x,isAutoLoading:()=>!u(g),save:z,startAutoSave:G,stopAutoSave:H,isAutoSaving:()=>!u(E),startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[G,k]:[k,G];return await e(a),await n(a),V},stopAutoPersisting:K,getStatus:()=>N,addStatusListener:a=>F(a,T),delListener:t=>(j(t),a),schedule:Q,getStore:()=>a,destroy:()=>(ya(Ba,w).splice(0,void 0),K()),getStats:()=>({loads:m,saves:C}),...c};return ea(V)},Ya=(a,t,e,s,r,o=ka,c,l)=>{const w=ua();return[async()=>{w.clear(),T(await e(a,t),({tn:a,cn:t})=>Aa(ga(w,a,Ea),t))},async(t,e,n)=>((a,t)=>S(ya(w,a),t))(t,e)?na(b(T(await a(x+V(t)+X(t,n)),a=>[a[e],l?oa(ia(a,e),l):ia(a,e)]),([a,t])=>!u(a)&&!wa(t))):{},async(t,e,s,l,y,d=!1,v=i)=>{const g=Ea();oa(s??{},a=>T(ta(a??{}),a=>Aa(g,a)));const p=R(g);if(!d&&y&&v==i&&O(p)&&S(w,t))return await a("DROP "+B+V(t)),void va(w,t);const E=ya(w,t),A=Ea(R(E));if(O(p)||(S(w,t)?await m(T([e,...p],async(n,s)=>{M(A,n)||(await a(J+V(t)+"ADD"+V(n)+r),0==s&&await a("CREATE UNIQUE INDEX pk ON "+V(t)+`(${V(e)})`),Aa(E,n))})):(await a(Q+V(t)+`(${V(e)}${r} PRIMARY KEY${C(T(p,a=>n+V(a)+r))});`),va(w,t,Ea([e,...p])))),await m([...!d&&l?T(R(A),async n=>{n!=e&&(await a(J+V(t)+"DROP"+V(n)),M(E,n))}):[]]),d)u(s)?await a(k+V(t)+X(t,v)):await m(ra(s,async(n,s)=>{u(n)?await a(k+V(t)+X(t,v)+`AND(${V(e)}=$1)`,[s]):O(p)||await o(a,t,e,ta(n),{[s]:c?T(ca(n),c):ca(n)},E)}));else if(O(p))S(w,t)&&await a(k+V(t)+X(t,v));else{const n=b(R(ya(w,t)),a=>a!=e),i={},r=[];oa(s??{},(a,t)=>{i[t]=T(n,t=>c?c(a?.[t]):a?.[t]),D(r,t)}),await o(a,t,e,n,i),await a(k+V(t)+X(t,v)+`AND${V(e)}NOT IN(${W(r)})`,r)}},async t=>{let e;return await a("BEGIN"),await f(async()=>e=await t(),s),await a("END"),e}]},ka=async(a,t,e,s,i)=>{const r=[1];await a("INSERT INTO"+V(t)+"("+((...a)=>C(T(a,V),n))(e,...s)+")VALUES"+C(ra(i,a=>"($"+r[0]+++","+W(a,r)+")"),n)+"ON CONFLICT("+V(e)+")DO UPDATE SET"+C(T(s,a=>V(a)+"=excluded."+V(a)),n),ra(i,(a,t)=>[t,...T(a,a=>a??null)]).flat())},xa=(a,t,e,n,s,i,r,[o,c,l],w,u,y,d,v,g)=>{const[p,E,A,N]=Ya(t,w,u,s,v,g),m=Ja(a,()=>N(async()=>{return await p(),a=(await E(o,c))[_]?.[l]??"null",Fa(a,(a,t)=>""===t?void 0:t);var a}),a=>N(async()=>{var t;await p(),await A(o,c,{[_]:{[l]:(t=a()??null,_a(t,(a,t)=>void 0===t?"":t))}},!0,!0)}),e,n,s,r,{[d]:()=>y,destroy:async()=>(await m.stopAutoPersisting(),i(),m)},0,y);return m},za=(a,t,e,n,s,i,r,[o,c,[l,w,y]],d,v,g,p,E,A,N,$)=>{const[f,h,C,T]=Ya(t,d,v,s,E,A,N,$),O=(a,t)=>m(da(c,async([e,n,s,i,r],o)=>{t&&!(o in a)||await C(e,n,a[o],s,i,t,r)})),D=async(a,t)=>w?await C(y,F,{[_]:a},!0,!0,t):null,I=Ja(a,()=>T(async()=>{await f();const a=await(async()=>na(b(await m(da(o,async([a,t,e],n)=>[a,await h(n,t,e)])),a=>!wa(a[1]))))(),t=await(async()=>l?(await h(y,F))[_]:{})();return wa(a)&&u(t)?void 0:[a,t]}),(a,t)=>T(async()=>{if(await f(),u(t)){const[t,e]=a();await O(t),await D(e)}else await O(t[0],!0),await D(t[1],!0)}),e,n,s,r,{[p]:()=>g,destroy:async()=>(await I.stopAutoPersisting(),i(),I)},0,g);return I},Ga=(a,n,s,r,o,c,u,y,d,v,p="getDb",A)=>{let N,m,$;const h=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,c),[C,T,O,b]=(a=>{const e=(a=>sa(Ra,g(a)?{[fa]:a}:a??{}))(a),n=e[Ta];if(e.mode==$a){const a=e[fa]??t;return[1,n,[a,e[ha]??F,e[Ca]??ma],Ea(a)]}const{tables:{load:s={},save:r={}}={},values:o={}}=e,c=E(ca(sa(Pa,o)),0,la(Pa)),l=c[2],w=Ea(l),u=Ea(l),y=Ma(s,{[ba]:null,[Oa]:F,[La]:i},ba,a=>S(u,a),a=>Aa(w,a)),d=Ma(r,{[Da]:null,[Oa]:F,[Ia]:0,[Sa]:0,[La]:null},Da,(a,t)=>S(u,t),(a,t)=>Aa(w,t));var v;return v=(a,t)=>t[4]??=ya(y,t[0])?.[2]??i,P(d,(a,t)=>v(0,a)),[0,n,[y,d,c],w]})(n);return(C?xa:za)(a,h,a=>{let t;const e=()=>t=setInterval(()=>f(async()=>{const[{d:t,s:e,c:n}]=await h(U+` ${G} d,${H} s,TOTAL_CHANGES() c FROM ${z}${G} JOIN ${z}${H}`);t==N&&e==m&&n==$||(w(N)||a(),N=t,m=e,$=n)}),1e3*T),n=()=>{N=m=$=null,l(t)},s=r(t=>{b.has(t)&&(n(),a(),e())});return e(),()=>{n(),o(s)}},a=>a(),u,y,d,O,R(b),async(a,t)=>await a(U+` t.name tn,c.name cn FROM ${K}list()t,${K}info(t.name)c ${j} t.schema='main'AND t.type IN('table','view')AND t.name IN(${W(t)})ORDER BY t.name,c.name`,t),v,p,e,A,a=>!0===a?1:!1===a?0:a,void 0)},Ha="change",Ka=(a,t,e,n,s)=>Ga(a,e,async(a,e=[])=>{return await(n=(n,s)=>t.all(a,e,(a,t)=>a?s(a):n(t)),new o(n));var n},a=>{const e=(t,e,n)=>a(n);return t.on(Ha,e),e},a=>t.off(Ha,a),n,s,N,3,t);export{Ka as createSqlite3Persister};
|
|
Binary file
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{Map as t}from"yjs";const e="t",a="v",n=t=>
|
|
1
|
+
import{Map as t}from"yjs";const e="t",a="v",n=t=>(e,a,n)=>t(e)?n?.():a(e),s=t=>null==t,o=t=>void 0===t,r=n(s),i=n(o),c=t=>Array.isArray(t),g=t=>t.length,d=t=>{throw Error(t)},l=async(t,e,a)=>{try{return await t()}catch(t){e?.(t)}},u=(t,e)=>t.forEach(e),y=(t,...e)=>t.push(...e),v=t=>t.shift(),p=t=>o(t)||0==(t=>t?.size??0)(t),w=(t,e)=>t?.forEach(e),h=(t,e)=>t?.delete(e),f=Object,S=t=>f.getPrototypeOf(t),C=f.entries,b=f.keys,A=f.freeze,M=(t=[])=>f.fromEntries(t),O=(t,e)=>e in t,L=(t,e)=>M(((t,e)=>((t,e)=>t.map(e))(C(t),([t,a])=>e(a,t)))(t,(t,a)=>[a,e(t,a)])),J=t=>(t=>!s(t)&&r(S(t),t=>t==f.prototype||s(S(t)),()=>!0))(t)&&0==(t=>g(b(t)))(t),N=(t,e,a)=>(O(t,e)||(t[e]=a()),t[e]),z=t=>new Map(t),D=(t,e)=>t?.get(e),E=(t,e)=>w(t,(t,a)=>e(a,t)),m=(t,e,a)=>void 0===a?(h(t,e),t):t?.set(e,a),P=(t,e,a,n)=>{var s,o;return s=t,o=e,s?.has(o)?n?.(D(t,e)):m(t,e,a()),D(t,e)},T=(t,e,a,n,s=0)=>i((a?P:D)(t,e[s],s>g(e)-2?a:z),o=>{if(s>g(e)-2)return n?.(o)&&m(t,e[s]),o;const r=T(o,e,a,n,s+1);return p(o)&&m(t,e[s]),r}),j=/^\d+$/,k=t=>new Set(c(t)||o(t)?t:[t]),x=z(),F=z(),Y=(t,e,a,n,s,r,f,S={},C=0,b=[])=>{let M,O,L,N=0,E=0,Y=0;P(x,b,()=>0),P(F,b,()=>[]);const $=z(),[q,B,G,H,I]=((t=1,e,a)=>1!=t&&e.isMergeable()?[1,e.getMergeableContent,()=>e.getTransactionMergeableChanges(!a),([[t],[e]])=>!J(t)||!J(e),e.setDefaultContent]:2!=t?[0,e.getContent,e.getTransactionChanges,([t,e])=>!J(t)||!J(e),e.setContent]:d("Store type not supported by this Persister"))(f,t,C),[K,Q,R]=(()=>{let t;const[e,a]=(()=>{const t=[];let e=0;return[a=>(a?v(t):null)??""+e++,e=>{j.test(e)&&g(t)<1e3&&y(t,e)}]})(),n=z();return[(a,s,o,r=[],i=()=>[])=>{t??=st;const c=e(1);var g,d;return m(n,c,[a,s,o,r,i]),g=T(s,o??[""],k),d=c,g?.add(d),c},(e,a,...s)=>u(((t,e=[""])=>{const a=[],n=(t,s)=>s==g(e)?y(a,t):null===e[s]?w(t,t=>n(t,s+1)):u([e[s],null],e=>n(D(t,e),s+1));return n(t,0),a})(e,a),e=>w(e,e=>D(n,e)[0](t,...a??[],...s))),t=>i(D(n,t),([,e,s])=>(T(e,s??[""],void 0,e=>(h(e,t),p(e)?1:0)),m(n,t),a(t),s)),e=>i(D(n,e),([e,,a=[],n,s])=>{const o=(...r)=>{const i=g(r);i==g(a)?e(t,...r,...s(r)):(t=>null===t)(a[i])?u(n[i]?.(...r)??[],t=>o(...r,t)):o(...r,a[i])};o()})]})(),U=t=>{t!=N&&(N=t,Q($,void 0,N))},V=e=>{(q&&c(e?.[0])?1===e?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===e?.[2]?t.applyChanges:t.setContent)(e)},W=async t=>(2!=N&&(U(1),E++,await nt(async()=>{await l(async()=>{const a=await e();c(a)?V(a):t?I(t):d("Content is not an array: "+a)},()=>{t&&I(t)}),U(0)})),st),X=async t=>(Z(),await W(t),await l(async()=>O=await n(async(t,e)=>{e||t?2!=N&&(U(1),E++,V(e??t),U(0)):await W()}),r),st),Z=async()=>(O&&(await l(()=>s(O),r),O=void 0),st),_=async t=>(1!=N&&(U(2),Y++,await nt(async()=>{await l(()=>a(B,t),r),U(0)})),st),tt=async()=>(et(),await _(),L=t.addDidFinishTransactionListener(()=>{const t=G();H(t)&&_(t)}),st),et=async()=>(L&&(t.delListener(L),L=void 0),st),at=async(t=!1)=>{const[e,a]=t?[et,Z]:[Z,et];return await e(),await a(),st},nt=async(...t)=>(y(D(F,b),...t),await(async()=>{if(!D(x,b)){for(m(x,b,1);!o(M=v(D(F,b)));)await l(M,r);m(x,b,0)}})(),st),st={load:W,startAutoLoad:X,stopAutoLoad:Z,isAutoLoading:()=>!o(O),save:_,startAutoSave:tt,stopAutoSave:et,isAutoSaving:()=>!o(L),startAutoPersisting:async(t,e=!1)=>{const[a,n]=e?[tt,X]:[X,tt];return await a(t),await n(t),st},stopAutoPersisting:at,getStatus:()=>N,addStatusListener:t=>K(t,$),delListener:e=>(R(e),t),schedule:nt,getStore:()=>t,destroy:()=>(D(F,b).splice(0,void 0),at()),getStats:()=>({loads:E,saves:Y}),...S};return A(st)},$="delete",q=t=>[t.get(e),t.get(a)],B=(e,a,n,s)=>{const r=o(a)?e:e.get(a)??e.set(a,new t);let i;return L(n,(t,e)=>{s(r,e,t)&&(i=1)}),r.forEach((t,e)=>{O(n,e)||(r.delete(e),i=1)}),o(a)||r.size||e.delete(a),i},G=(n,s,r="tinybase",c)=>{const d=s.getMap(r);return Y(n,async()=>d.size?[d.get(e).toJSON(),d.get(a).toJSON()]:void 0,async(n,r)=>s.transact(()=>((n,s,r)=>{n.size||(n.set(e,new t),n.set(a,new t));const[c,g]=q(n),d=()=>{l=1};let l=1;if(i(r,([t,e])=>{l=0,L(t,(t,e)=>l?0:o(t)?c.delete(e):i(c.get(e),e=>L(t,(t,a)=>l?0:o(t)?e.delete(a):i(e.get(a),e=>L(t,(t,a)=>o(t)?e.delete(a):e.set(a,t)),d)),d)),L(e,(t,e)=>l?0:o(t)?g.delete(e):g.set(e,t))}),l){const[t,e]=s();B(c,void 0,t,(t,e,a)=>B(c,e,a,(t,e,a)=>B(t,e,a,(t,e,a)=>{if(t.get(e)!==a)return t.set(e,a),1}))),B(g,void 0,e,(t,e,a)=>{g.get(e)!==a&&g.set(e,a)})}})(d,n,r)),t=>{const n=n=>t(void 0,((t,n)=>{if(1==g(n)&&(s=n[0].path,0==g(s)))return[t.get(e).toJSON(),t.get(a).toJSON(),1];var s;const[o,r]=q(t),c={},d={};return u(n,({path:t,changes:{keys:a}})=>v(t)==e?i(v(t),e=>{const n=N(c,e,M),s=o.get(e);i(v(t),t=>{const e=N(n,t,M),o=s.get(t);E(a,(t,{action:a})=>e[t]=a==$?void 0:o.get(t))},()=>E(a,(t,{action:e})=>n[t]=e==$?void 0:s.get(t)?.toJSON()))},()=>E(a,(t,{action:e})=>c[t]=e==$?void 0:o.get(t)?.toJSON())):E(a,(t,{action:e})=>d[t]=e==$?void 0:r.get(t))),[c,d,1]})(d,n));return d.observeDeep(n),n},t=>{d.unobserveDeep(t)},c,1,{getYDoc:()=>s})};export{G as createYjsPersister};
|
|
Binary file
|
|
@@ -1 +1 @@
|
|
|
1
|
-
import{Map as t}from"yjs";const e="t",a="v",n=t=>
|
|
1
|
+
import{Map as t}from"yjs";const e="t",a="v",n=t=>(e,a,n)=>t(e)?n?.():a(e),s=t=>null==t,o=t=>void 0===t,r=n(s),i=n(o),c=t=>Array.isArray(t),g=t=>t.length,d=t=>{throw Error(t)},l=async(t,e,a)=>{try{return await t()}catch(t){e?.(t)}},u=(t,e)=>t.forEach(e),y=(t,...e)=>t.push(...e),v=t=>t.shift(),p=t=>o(t)||0==(t=>t?.size??0)(t),w=(t,e)=>t?.forEach(e),h=(t,e)=>t?.delete(e),f=Object,S=t=>f.getPrototypeOf(t),C=f.entries,b=f.keys,A=f.freeze,M=(t=[])=>f.fromEntries(t),O=(t,e)=>e in t,L=(t,e)=>M(((t,e)=>((t,e)=>t.map(e))(C(t),([t,a])=>e(a,t)))(t,(t,a)=>[a,e(t,a)])),J=t=>(t=>!s(t)&&r(S(t),t=>t==f.prototype||s(S(t)),()=>!0))(t)&&0==(t=>g(b(t)))(t),N=(t,e,a)=>(O(t,e)||(t[e]=a()),t[e]),z=t=>new Map(t),D=(t,e)=>t?.get(e),E=(t,e)=>w(t,(t,a)=>e(a,t)),m=(t,e,a)=>void 0===a?(h(t,e),t):t?.set(e,a),P=(t,e,a,n)=>{var s,o;return s=t,o=e,s?.has(o)?n?.(D(t,e)):m(t,e,a()),D(t,e)},T=(t,e,a,n,s=0)=>i((a?P:D)(t,e[s],s>g(e)-2?a:z),o=>{if(s>g(e)-2)return n?.(o)&&m(t,e[s]),o;const r=T(o,e,a,n,s+1);return p(o)&&m(t,e[s]),r}),j=/^\d+$/,k=t=>new Set(c(t)||o(t)?t:[t]),x=z(),F=z(),Y=(t,e,a,n,s,r,f,S={},C=0,b=[])=>{let M,O,L,N=0,E=0,Y=0;P(x,b,()=>0),P(F,b,()=>[]);const $=z(),[q,B,G,H,I]=((t=1,e,a)=>1!=t&&e.isMergeable()?[1,e.getMergeableContent,()=>e.getTransactionMergeableChanges(!a),([[t],[e]])=>!J(t)||!J(e),e.setDefaultContent]:2!=t?[0,e.getContent,e.getTransactionChanges,([t,e])=>!J(t)||!J(e),e.setContent]:d("Store type not supported by this Persister"))(f,t,C),[K,Q,R]=(()=>{let t;const[e,a]=(()=>{const t=[];let e=0;return[a=>(a?v(t):null)??""+e++,e=>{j.test(e)&&g(t)<1e3&&y(t,e)}]})(),n=z();return[(a,s,o,r=[],i=()=>[])=>{t??=st;const c=e(1);var g,d;return m(n,c,[a,s,o,r,i]),g=T(s,o??[""],k),d=c,g?.add(d),c},(e,a,...s)=>u(((t,e=[""])=>{const a=[],n=(t,s)=>s==g(e)?y(a,t):null===e[s]?w(t,t=>n(t,s+1)):u([e[s],null],e=>n(D(t,e),s+1));return n(t,0),a})(e,a),e=>w(e,e=>D(n,e)[0](t,...a??[],...s))),t=>i(D(n,t),([,e,s])=>(T(e,s??[""],void 0,e=>(h(e,t),p(e)?1:0)),m(n,t),a(t),s)),e=>i(D(n,e),([e,,a=[],n,s])=>{const o=(...r)=>{const i=g(r);i==g(a)?e(t,...r,...s(r)):(t=>null===t)(a[i])?u(n[i]?.(...r)??[],t=>o(...r,t)):o(...r,a[i])};o()})]})(),U=t=>{t!=N&&(N=t,Q($,void 0,N))},V=e=>{(q&&c(e?.[0])?1===e?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===e?.[2]?t.applyChanges:t.setContent)(e)},W=async t=>(2!=N&&(U(1),E++,await nt(async()=>{await l(async()=>{const a=await e();c(a)?V(a):t?I(t):d("Content is not an array: "+a)},()=>{t&&I(t)}),U(0)})),st),X=async t=>(Z(),await W(t),await l(async()=>O=await n(async(t,e)=>{e||t?2!=N&&(U(1),E++,V(e??t),U(0)):await W()}),r),st),Z=async()=>(O&&(await l(()=>s(O),r),O=void 0),st),_=async t=>(1!=N&&(U(2),Y++,await nt(async()=>{await l(()=>a(B,t),r),U(0)})),st),tt=async()=>(et(),await _(),L=t.addDidFinishTransactionListener(()=>{const t=G();H(t)&&_(t)}),st),et=async()=>(L&&(t.delListener(L),L=void 0),st),at=async(t=!1)=>{const[e,a]=t?[et,Z]:[Z,et];return await e(),await a(),st},nt=async(...t)=>(y(D(F,b),...t),await(async()=>{if(!D(x,b)){for(m(x,b,1);!o(M=v(D(F,b)));)await l(M,r);m(x,b,0)}})(),st),st={load:W,startAutoLoad:X,stopAutoLoad:Z,isAutoLoading:()=>!o(O),save:_,startAutoSave:tt,stopAutoSave:et,isAutoSaving:()=>!o(L),startAutoPersisting:async(t,e=!1)=>{const[a,n]=e?[tt,X]:[X,tt];return await a(t),await n(t),st},stopAutoPersisting:at,getStatus:()=>N,addStatusListener:t=>K(t,$),delListener:e=>(R(e),t),schedule:nt,getStore:()=>t,destroy:()=>(D(F,b).splice(0,void 0),at()),getStats:()=>({loads:E,saves:Y}),...S};return A(st)},$="delete",q=t=>[t.get(e),t.get(a)],B=(e,a,n,s)=>{const r=o(a)?e:e.get(a)??e.set(a,new t);let i;return L(n,(t,e)=>{s(r,e,t)&&(i=1)}),r.forEach((t,e)=>{O(n,e)||(r.delete(e),i=1)}),o(a)||r.size||e.delete(a),i},G=(n,s,r="tinybase",c)=>{const d=s.getMap(r);return Y(n,async()=>d.size?[d.get(e).toJSON(),d.get(a).toJSON()]:void 0,async(n,r)=>s.transact(()=>((n,s,r)=>{n.size||(n.set(e,new t),n.set(a,new t));const[c,g]=q(n),d=()=>{l=1};let l=1;if(i(r,([t,e])=>{l=0,L(t,(t,e)=>l?0:o(t)?c.delete(e):i(c.get(e),e=>L(t,(t,a)=>l?0:o(t)?e.delete(a):i(e.get(a),e=>L(t,(t,a)=>o(t)?e.delete(a):e.set(a,t)),d)),d)),L(e,(t,e)=>l?0:o(t)?g.delete(e):g.set(e,t))}),l){const[t,e]=s();B(c,void 0,t,(t,e,a)=>B(c,e,a,(t,e,a)=>B(t,e,a,(t,e,a)=>{if(t.get(e)!==a)return t.set(e,a),1}))),B(g,void 0,e,(t,e,a)=>{g.get(e)!==a&&g.set(e,a)})}})(d,n,r)),t=>{const n=n=>t(void 0,((t,n)=>{if(1==g(n)&&(s=n[0].path,0==g(s)))return[t.get(e).toJSON(),t.get(a).toJSON(),1];var s;const[o,r]=q(t),c={},d={};return u(n,({path:t,changes:{keys:a}})=>v(t)==e?i(v(t),e=>{const n=N(c,e,M),s=o.get(e);i(v(t),t=>{const e=N(n,t,M),o=s.get(t);E(a,(t,{action:a})=>e[t]=a==$?void 0:o.get(t))},()=>E(a,(t,{action:e})=>n[t]=e==$?void 0:s.get(t)?.toJSON()))},()=>E(a,(t,{action:e})=>c[t]=e==$?void 0:o.get(t)?.toJSON())):E(a,(t,{action:e})=>d[t]=e==$?void 0:r.get(t))),[c,d,1]})(d,n));return d.observeDeep(n),n},t=>{d.unobserveDeep(t)},c,1,{getYDoc:()=>s})};export{G as createYjsPersister};
|
|
Binary file
|
|
@@ -1 +1 @@
|
|
|
1
|
-
const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),i="true",r=(a,t,e)=>a.replace(t,e),o=Promise,c=globalThis,l=clearInterval,w=a=>null==a,y=(a,t,e)=>w(a)?e?.():t(a),d=t=>a(t)==s,u=a=>Array.isArray(a),E=(a,t,e)=>a.slice(t,e),N=a=>a.length,g=async a=>o.all(a),$=a=>{throw Error(a)},A=async(a,t,e)=>{try{return await a()}catch(a){t?.(a)}},O=(a,t)=>a.forEach(t),m=(a,t="")=>a.join(t),T=(a,t)=>a.map(t),R=a=>0==N(a),p=(a,t)=>a.filter(t),v=(a,...t)=>a.push(...t),I=a=>a.shift(),S=(a,t)=>a?.has(t)??!1,_=a=>w(a)||0==(a=>a?.size??0)(a),C=a=>[...a?.values()??[]],b=(a,t)=>a?.forEach(t),L=(a,t)=>a?.delete(t),D=Object,f=a=>D.getPrototypeOf(a),h=D.entries,P=D.keys,M=D.freeze,F=(a=[])=>D.fromEntries(a),U=(...a)=>D.assign({},...a),G=(a,t)=>(delete a[t],a),j=(a,t)=>T(h(a),([a,e])=>t(e,a)),x=(a,t)=>F(j(a,(a,e)=>[e,t(a,e)])),B=a=>D.values(a),H=a=>N(P(a)),W=a=>(a=>!w(a)&&y(f(a),a=>a==D.prototype||w(f(a)),()=>!0))(a)&&0==H(a),Y=a=>new Map(a),X=(a,t)=>a?.get(t),J=(a,t)=>T([...a?.entries()??[]],([a,e])=>t(e,a)),k=(a,t,e)=>w(e)?(L(a,t),a):a?.set(t,e),z=(a,t,e,n)=>(S(a,t)?n?.(X(a,t)):k(a,t,e()),X(a,t)),K=(a,t,e,n,s=0)=>y((e?z:X)(a,t[s],s>N(t)-2?e:Y),i=>{if(s>N(t)-2)return n?.(i)&&k(a,t[s]),i;const r=K(i,t,e,n,s+1);return _(i)&&k(a,t[s]),r}),V=/^\d+$/,q=a=>new Set(u(a)||w(a)?a:[a]),Q=(a,t)=>a?.add(t),Z={Idle:0,Loading:1,Saving:2},aa={StoreOnly:1,MergeableStoreOnly:2,StoreOrMergeableStore:3},ta=Y(),ea=Y(),na=(a,t,n,s,i,r,o,c={},l=0,d=[])=>{let E,g,m,T=0,R=0,p=0;z(ta,d,()=>0),z(ea,d,()=>[]);const S=Y(),[C,D,f,h,P]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!W(a)||!W(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!W(a)||!W(t),t.setContent]:$("Store type not supported by this Persister"))(o,a,l),[F,U,G]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?I(a):null)??e+t++,t=>{V.test(t)&&N(a)<1e3&&v(a,t)}]})(),s=Y();return[(n,i,r,o=[],c=()=>[])=>{a??=ra;const l=t(1);return k(s,l,[n,i,r,o,c]),Q(K(i,r??[e],q),l),l},(t,n,...i)=>O(((a,t=[e])=>{const n=[],s=(a,e)=>e==N(t)?v(n,a):null===t[e]?b(a,a=>s(a,e+1)):O([t[e],null],t=>s(X(a,t),e+1));return s(a,0),n})(t,n),t=>b(t,t=>X(s,t)[0](a,...n??[],...i))),a=>y(X(s,a),([,t,i])=>(K(t,i??[e],void 0,t=>(L(t,a),_(t)?1:0)),k(s,a),n(a),i)),t=>y(X(s,t),([t,,e=[],n,s])=>{const i=(...r)=>{const o=N(r);o==N(e)?t(a,...r,...s(r)):w(e[o])?O(n[o]?.(...r)??[],a=>i(...r,a)):i(...r,e[o])};i()})]})(),j=a=>{a!=T&&(T=a,U(S,void 0,T))},x=t=>{(C&&u(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},B=async a=>(2!=T&&(j(1),R++,await ia(async()=>{await A(async()=>{const e=await t();u(e)?x(e):a?P(a):$("Content is not an array: "+e)},()=>{a&&P(a)}),j(0)})),ra),H=async a=>(J(),await B(a),await A(async()=>g=await s(async(a,t)=>{t||a?2!=T&&(j(1),R++,x(t??a),j(0)):await B()}),r),ra),J=async()=>(g&&(await A(()=>i(g),r),g=void 0),ra),Z=async a=>(1!=T&&(j(2),p++,await ia(async()=>{await A(()=>n(D,a),r),j(0)})),ra),aa=async()=>(na(),await Z(),m=a.addDidFinishTransactionListener(()=>{const a=f();h(a)&&Z(a)}),ra),na=async()=>(m&&(a.delListener(m),m=void 0),ra),sa=async(a=!1)=>{const[t,e]=a?[na,J]:[J,na];return await t(),await e(),ra},ia=async(...a)=>(v(X(ea,d),...a),await(async()=>{if(!X(ta,d)){for(k(ta,d,1);!w(E=I(X(ea,d)));)await A(E,r);k(ta,d,0)}})(),ra),ra={load:B,startAutoLoad:H,stopAutoLoad:J,isAutoLoading:()=>!w(g),save:Z,startAutoSave:aa,stopAutoSave:na,isAutoSaving:()=>!w(m),startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[aa,H]:[H,aa];return await e(a),await n(a),ra},stopAutoPersisting:sa,getStatus:()=>T,addStatusListener:a=>F(a,S),delListener:t=>(G(t),a),schedule:ia,getStore:()=>a,destroy:()=>(X(ea,d).splice(0,void 0),sa()),getStats:()=>({loads:R,saves:p}),...c};return M(ra)},sa=JSON.stringify,ia=JSON.parse,ra=a=>sa(a,(a,t)=>void 0===t?"":t),oa=new c.TextEncoder,ca="_",la="_id",wa="SELECT",ya="WHERE",da="TABLE",ua="INSERT",Ea="DELETE",Na="UPDATE",ga="ALTER "+da,$a="FROM",Aa=Ea+" "+$a,Oa=wa+"*"+$a,ma="pragma_",Ta="data_version",Ra="schema_version",pa="pragma_table_",va="CREATE ",Ia=va+da,Sa="OR REPLACE ",_a="FUNCTION",Ca="$tableName",ba=(a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a,La=a=>m(T(((a,t="",e)=>a.split(t,e))(a,"."),a=>`"${r(a,/"/g,'""')}"`),"."),Da=(...a)=>La(m(a,"_")),fa=(a,t=[1])=>m(T(a,()=>"$"+t[0]++),n),ha=(a,t=i)=>ya+`(${r(t,Ca,La(a))})`,Pa="ColumnName",Ma="store",Fa="json",Ua=Ma+"TableName",Ga=Ma+"Id"+Pa,ja=Ma+Pa,xa="autoLoadIntervalSeconds",Ba="rowId"+Pa,Ha="tableId",Wa="tableName",Ya="deleteEmptyColumns",Xa="deleteEmptyTable",Ja="condition",ka={mode:Fa,[xa]:1},za={load:0,save:0,[Wa]:t+"_values"},Ka=(a,t,e,n,s)=>{const i=Y();return x(a,(a,r)=>{const o=E(B(U(t,d(a)?{[e]:a}:a)),0,H(t));w(o[0])||n(r,o[0])||(s(r,o[0]),k(i,r,o))}),i},Va=a=>{const e=(a=>U(ka,d(a)?{[Ua]:a}:a??{}))(a),n=e[xa];if(e.mode==Fa){const a=e[Ua]??t;return[1,n,[a,e[Ga]??la,e[ja]??Ma],q(a)]}const{tables:{load:s={},save:r={}}={},values:o={}}=e,c=E(B(U(za,o)),0,H(za)),l=c[2],w=q(l),y=q(l),u=Ka(s,{[Ha]:null,[Ba]:la,[Ja]:i},Ha,a=>S(y,a),a=>Q(w,a)),N=Ka(r,{[Wa]:null,[Ba]:la,[Ya]:0,[Xa]:0,[Ja]:null},Wa,(a,t)=>S(y,t),(a,t)=>Q(w,t));var g;return g=(a,t)=>t[4]??=X(u,t[0])?.[2]??i,b(N,(a,t)=>g(0,a)),[0,n,[u,N,c],w]},qa=(a,t,e,s,r,o=Qa,c,l)=>{const y=Y();return[async()=>{y.clear(),T(await e(a,t),({tn:a,cn:t})=>Q(z(y,a,q),t))},async(t,e,n)=>((a,t)=>S(X(y,a),t))(t,e)?F(p(T(await a(Oa+La(t)+ha(t,n)),a=>[a[e],l?x(G(a,e),l):G(a,e)]),([a,t])=>!w(a)&&!W(t))):{},async(t,e,s,l,d,u=!1,E=i)=>{const N=q();x(s??{},a=>T(P(a??{}),a=>Q(N,a)));const $=C(N);if(!u&&d&&E==i&&R($)&&S(y,t))return await a("DROP "+da+La(t)),void k(y,t);const A=X(y,t),O=q(C(A));if(R($)||(S(y,t)?await g(T([e,...$],async(n,s)=>{L(O,n)||(await a(ga+La(t)+"ADD"+La(n)+r),0==s&&await a("CREATE UNIQUE INDEX pk ON "+La(t)+`(${La(e)})`),Q(A,n))})):(await a(Ia+La(t)+`(${La(e)}${r} PRIMARY KEY${m(T($,a=>n+La(a)+r))});`),k(y,t,q([e,...$])))),await g([...!u&&l?T(C(O),async n=>{n!=e&&(await a(ga+La(t)+"DROP"+La(n)),L(A,n))}):[]]),u)w(s)?await a(Aa+La(t)+ha(t,E)):await g(j(s,async(n,s)=>{w(n)?await a(Aa+La(t)+ha(t,E)+`AND(${La(e)}=$1)`,[s]):R($)||await o(a,t,e,P(n),{[s]:c?T(B(n),c):B(n)},A)}));else if(R($))S(y,t)&&await a(Aa+La(t)+ha(t,E));else{const n=p(C(X(y,t)),a=>a!=e),i={},r=[];x(s??{},(a,t)=>{i[t]=T(n,t=>c?c(a?.[t]):a?.[t]),v(r,t)}),await o(a,t,e,n,i),await a(Aa+La(t)+ha(t,E)+`AND${La(e)}NOT IN(${fa(r)})`,r)}},async t=>{let e;return await a("BEGIN"),await A(async()=>e=await t(),s),await a("END"),e}]},Qa=async(a,t,e,s,i)=>{const r=[1];await a(ua+" INTO"+La(t)+"("+((...a)=>m(T(a,La),n))(e,...s)+")VALUES"+m(j(i,a=>"($"+r[0]+++","+fa(a,r)+")"),n)+"ON CONFLICT("+La(e)+`)DO ${Na} SET`+m(T(s,a=>La(a)+"=excluded."+La(a)),n),j(i,(a,t)=>[t,...T(a,a=>a??null)]).flat())},Za=(a,t,e,n,s,i,r,[o,c,l],w,y,d,u,E,N)=>{const[g,$,A,O]=qa(t,w,y,s,E,N),m=na(a,()=>O(async()=>{return await g(),a=(await $(o,c))[ca]?.[l]??"null",ia(a,(a,t)=>""===t?void 0:t);var a}),a=>O(async()=>{await g(),await A(o,c,{[ca]:{[l]:ra(a()??null)}},!0,!0)}),e,n,s,r,{[u]:()=>d,destroy:async()=>(await m.stopAutoPersisting(),i(),m)},0,d);return m},at=(a,t,e,n,s,i,r,[o,c,[l,y,d]],u,E,N,$,A,O,m,T)=>{const[R,v,I,S]=qa(t,u,E,s,A,O,m,T),_=(a,t)=>g(J(c,async([e,n,s,i,r],o)=>{t&&!(o in a)||await I(e,n,a[o],s,i,t,r)})),C=async(a,t)=>y?await I(d,la,{[ca]:a},!0,!0,t):null,b=na(a,()=>S(async()=>{await R();const a=await(async()=>F(p(await g(J(o,async([a,t,e],n)=>[a,await v(n,t,e)])),a=>!W(a[1]))))(),t=await(async()=>l?(await v(d,la))[ca]:{})();return W(a)&&w(t)?void 0:[a,t]}),(a,t)=>S(async()=>{if(await R(),w(t)){const[t,e]=a();await _(t),await C(e)}else await _(t[0],!0),await C(t[1],!0)}),e,n,s,r,{[$]:()=>N,destroy:async()=>(await b.stopAutoPersisting(),i(),b)},0,N);return b},tt=/^([cd]:)(.+)/,et=(a,n,s,o,c,l,w,d,u,E,N="getDb")=>{const $=ba(s,l),[A,,R,p]=Va(n),v=e+(a=>{let t=2166136261;return O(oa.encode(a),a=>{t^=a,t+=(t<<1)+(t<<4)+(t<<7)+(t<<8)+(t<<24)}),t>>>0})(ra(R)),I=t+"_"+v,_=async(a,e,n="",s="")=>{const i=Da(t,a,v);return await $(va+Sa+_a+i+`()RETURNS ${n}trigger AS $$ ${s}BEGIN ${e}END;$$ LANGUAGE plpgsql;`),i},b=async(a,t,e,n)=>(await $(va+a+"TRIGGER"+t+e+"EXECUTE "+_a+n+"()"),t),L=a=>`PERFORM pg_notify('${I}',${a});`,D=(a,t)=>A?i:2===t?D(a,0)+" OR "+D(a,1):r(X(R[0],a)?.[2]??i,Ca,0==t?"NEW":"OLD"),f=(a,e)=>g(T([ua,Ea,Na],(n,s)=>b(Sa,Da(t,"d",v,a,n),`AFTER ${n} ON${La(a)}FOR EACH ROW WHEN(${D(a,s)})`,e)));return(A?Za:at)(a,$,async a=>{const e=await _("c",`FOR row IN SELECT object_identity FROM pg_event_trigger_ddl_commands()${ya} command_tag='${Ia}' LOOP ${L("'c:'||SPLIT_PART(row.object_identity,'.',2)")}END LOOP;`,"event_","DECLARE row record;");await b("EVENT ",Da(t,"c",v),`ON ddl_command_end WHEN TAG IN('${Ia}')`,e);const n=await _("d",L("'d:'||TG_TABLE_NAME")+"RETURN NULL;");return await g(T(C(p),async a=>(await $(Ia+` IF NOT EXISTS${La(a)}("_id"text PRIMARY KEY)`),await f(a,n)))),[await o(I,t=>{return y((e=t,s=tt,e?.match(s)),async([,t,e])=>{S(p,e)&&("c:"==t&&await f(e,n),a())});var e,s}),[e,n]]},async([a,t])=>{c(a),await $(`DROP FUNCTION IF EXISTS${m(t,",")}CASCADE`)},w,d,u,R,C(p),async(a,t)=>await a(wa+` table_name tn,column_name cn FROM information_schema.columns ${ya} table_schema='public'AND table_name IN(${fa(t)})`,t),E,N,"text",void 0,a=>sa(a),a=>ia(a))},nt=(a,t,n,s,i,r,o,c,w,y,d="getDb",u)=>{let E,N,g;const $=ba(n,r),[O,m,T,R]=Va(t);return(O?Za:at)(a,$,a=>{let t;const e=()=>t=setInterval(()=>A(async()=>{const[{d:t,s:e,c:n}]=await $(wa+` ${Ta} d,${Ra} s,TOTAL_CHANGES() c FROM ${ma}${Ta} JOIN ${ma}${Ra}`);t==E&&e==N&&n==g||(null!=E&&a(),E=t,N=e,g=n)}),1e3*m),n=()=>{E=N=g=null,l(t)},r=s(t=>{R.has(t)&&(n(),a(),e())});return e(),()=>{n(),i(r)}},a=>a(),o,c,w,T,C(R),async(a,t)=>await a(wa+` t.name tn,c.name cn FROM ${pa}list()t,${pa}info(t.name)c ${ya} t.schema='main'AND t.type IN('table','view')AND t.name IN(${fa(t)})ORDER BY t.name,c.name`,t),y,d,e,u,a=>!0===a?1:!1===a?0:a,void 0)};export{aa as Persists,Z as Status,na as createCustomPersister,et as createCustomPostgreSqlPersister,nt as createCustomSqlitePersister};
|
|
1
|
+
const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),i="true",r=(a,t,e)=>a.replace(t,e),o=Promise,c=a=>(t,e,n)=>a(t)?n?.():e(t),l=globalThis,w=clearInterval,d=a=>null==a,y=a=>void 0===a,u=a=>null===a,E=c(d),N=c(y),g=t=>a(t)==s,$=a=>Array.isArray(a),A=(a,t,e)=>a.slice(t,e),O=a=>a.length,m=async a=>o.all(a),T=a=>{throw Error(a)},v=async(a,t,e)=>{try{return await a()}catch(a){t?.(a)}},R=(a,t)=>a.forEach(t),p=(a,t="")=>a.join(t),I=(a,t)=>a.map(t),S=a=>0==O(a),_=(a,t)=>a.filter(t),C=(a,...t)=>a.push(...t),b=a=>a.shift(),L=(a,t)=>a?.has(t)??!1,D=a=>y(a)||0==(a=>a?.size??0)(a),f=a=>[...a?.values()??[]],h=(a,t)=>a?.forEach(t),P=(a,t)=>a?.delete(t),M=Object,F=a=>M.getPrototypeOf(a),U=M.entries,G=M.keys,j=M.freeze,x=(a=[])=>M.fromEntries(a),B=(...a)=>M.assign({},...a),H=(a,t)=>(delete a[t],a),W=(a,t)=>I(U(a),([a,e])=>t(e,a)),Y=(a,t)=>x(W(a,(a,e)=>[e,t(a,e)])),X=a=>M.values(a),J=a=>O(G(a)),k=a=>(a=>!d(a)&&E(F(a),a=>a==M.prototype||d(F(a)),()=>!0))(a)&&0==J(a),z=a=>new Map(a),K=(a,t)=>a?.get(t),V=(a,t)=>I([...a?.entries()??[]],([a,e])=>t(e,a)),q=(a,t,e)=>void 0===e?(P(a,t),a):a?.set(t,e),Q=(a,t,e,n)=>(L(a,t)?n?.(K(a,t)):q(a,t,e()),K(a,t)),Z=(a,t,e,n,s=0)=>N((e?Q:K)(a,t[s],s>O(t)-2?e:z),i=>{if(s>O(t)-2)return n?.(i)&&q(a,t[s]),i;const r=Z(i,t,e,n,s+1);return D(i)&&q(a,t[s]),r}),aa=/^\d+$/,ta=a=>new Set($(a)||y(a)?a:[a]),ea=(a,t)=>a?.add(t),na={Idle:0,Loading:1,Saving:2},sa={StoreOnly:1,MergeableStoreOnly:2,StoreOrMergeableStore:3},ia=z(),ra=z(),oa=(a,t,n,s,i,r,o,c={},l=0,w=[])=>{let d,E,g,A=0,m=0,p=0;Q(ia,w,()=>0),Q(ra,w,()=>[]);const I=z(),[S,_,L,f,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]:T("Store type not supported by this Persister"))(o,a,l),[F,U,G]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?b(a):null)??e+t++,t=>{aa.test(t)&&O(a)<1e3&&C(a,t)}]})(),s=z();return[(n,i,r,o=[],c=()=>[])=>{a??=oa;const l=t(1);return q(s,l,[n,i,r,o,c]),ea(Z(i,r??[e],ta),l),l},(t,n,...i)=>R(((a,t=[e])=>{const n=[],s=(a,e)=>e==O(t)?C(n,a):null===t[e]?h(a,a=>s(a,e+1)):R([t[e],null],t=>s(K(a,t),e+1));return s(a,0),n})(t,n),t=>h(t,t=>K(s,t)[0](a,...n??[],...i))),a=>N(K(s,a),([,t,i])=>(Z(t,i??[e],void 0,t=>(P(t,a),D(t)?1:0)),q(s,a),n(a),i)),t=>N(K(s,t),([t,,e=[],n,s])=>{const i=(...r)=>{const o=O(r);o==O(e)?t(a,...r,...s(r)):u(e[o])?R(n[o]?.(...r)??[],a=>i(...r,a)):i(...r,e[o])};i()})]})(),x=a=>{a!=A&&(A=a,U(I,void 0,A))},B=t=>{(S&&$(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},H=async a=>(2!=A&&(x(1),m++,await sa(async()=>{await v(async()=>{const e=await t();$(e)?B(e):a?M(a):T("Content is not an array: "+e)},()=>{a&&M(a)}),x(0)})),oa),W=async a=>(Y(),await H(a),await v(async()=>E=await s(async(a,t)=>{t||a?2!=A&&(x(1),m++,B(t??a),x(0)):await H()}),r),oa),Y=async()=>(E&&(await v(()=>i(E),r),E=void 0),oa),X=async a=>(1!=A&&(x(2),p++,await sa(async()=>{await v(()=>n(_,a),r),x(0)})),oa),J=async()=>(V(),await X(),g=a.addDidFinishTransactionListener(()=>{const a=L();f(a)&&X(a)}),oa),V=async()=>(g&&(a.delListener(g),g=void 0),oa),na=async(a=!1)=>{const[t,e]=a?[V,Y]:[Y,V];return await t(),await e(),oa},sa=async(...a)=>(C(K(ra,w),...a),await(async()=>{if(!K(ia,w)){for(q(ia,w,1);!y(d=b(K(ra,w)));)await v(d,r);q(ia,w,0)}})(),oa),oa={load:H,startAutoLoad:W,stopAutoLoad:Y,isAutoLoading:()=>!y(E),save:X,startAutoSave:J,stopAutoSave:V,isAutoSaving:()=>!y(g),startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[J,W]:[W,J];return await e(a),await n(a),oa},stopAutoPersisting:na,getStatus:()=>A,addStatusListener:a=>F(a,I),delListener:t=>(G(t),a),schedule:sa,getStore:()=>a,destroy:()=>(K(ra,w).splice(0,void 0),na()),getStats:()=>({loads:m,saves:p}),...c};return j(oa)},ca=JSON.stringify,la=JSON.parse,wa=a=>ca(a,(a,t)=>void 0===t?"":t),da=new l.TextEncoder,ya="_",ua="_id",Ea="SELECT",Na="WHERE",ga="TABLE",$a="INSERT",Aa="DELETE",Oa="UPDATE",ma="ALTER "+ga,Ta="FROM",va=Aa+" "+Ta,Ra=Ea+"*"+Ta,pa="pragma_",Ia="data_version",Sa="schema_version",_a="pragma_table_",Ca="CREATE ",ba=Ca+ga,La="OR REPLACE ",Da="FUNCTION",fa="$tableName",ha=(a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a,Pa=a=>p(I(((a,t="",e)=>a.split(t,e))(a,"."),a=>`"${r(a,/"/g,'""')}"`),"."),Ma=(...a)=>Pa(p(a,"_")),Fa=(a,t=[1])=>p(I(a,()=>"$"+t[0]++),n),Ua=(a,t=i)=>Na+`(${r(t,fa,Pa(a))})`,Ga="ColumnName",ja="store",xa="json",Ba=ja+"TableName",Ha=ja+"Id"+Ga,Wa=ja+Ga,Ya="autoLoadIntervalSeconds",Xa="rowId"+Ga,Ja="tableId",ka="tableName",za="deleteEmptyColumns",Ka="deleteEmptyTable",Va="condition",qa={mode:xa,[Ya]:1},Qa={load:0,save:0,[ka]:t+"_values"},Za=(a,t,e,n,s)=>{const i=z();return Y(a,(a,r)=>{const o=A(X(B(t,g(a)?{[e]:a}:a)),0,J(t));u(o[0])||n(r,o[0])||(s(r,o[0]),q(i,r,o))}),i},at=a=>{const e=(a=>B(qa,g(a)?{[Ba]:a}:a??{}))(a),n=e[Ya];if(e.mode==xa){const a=e[Ba]??t;return[1,n,[a,e[Ha]??ua,e[Wa]??ja],ta(a)]}const{tables:{load:s={},save:r={}}={},values:o={}}=e,c=A(X(B(Qa,o)),0,J(Qa)),l=c[2],w=ta(l),d=ta(l),y=Za(s,{[Ja]:null,[Xa]:ua,[Va]:i},Ja,a=>L(d,a),a=>ea(w,a)),u=Za(r,{[ka]:null,[Xa]:ua,[za]:0,[Ka]:0,[Va]:null},ka,(a,t)=>L(d,t),(a,t)=>ea(w,t));var E;return E=(a,t)=>t[4]??=K(y,t[0])?.[2]??i,h(u,(a,t)=>E(0,a)),[0,n,[y,u,c],w]},tt=(a,t,e,s,r,o=et,c,l)=>{const w=z();return[async()=>{w.clear(),I(await e(a,t),({tn:a,cn:t})=>ea(Q(w,a,ta),t))},async(t,e,n)=>((a,t)=>L(K(w,a),t))(t,e)?x(_(I(await a(Ra+Pa(t)+Ua(t,n)),a=>[a[e],l?Y(H(a,e),l):H(a,e)]),([a,t])=>!y(a)&&!k(t))):{},async(t,e,s,l,d,u=!1,E=i)=>{const N=ta();Y(s??{},a=>I(G(a??{}),a=>ea(N,a)));const g=f(N);if(!u&&d&&E==i&&S(g)&&L(w,t))return await a("DROP "+ga+Pa(t)),void q(w,t);const $=K(w,t),A=ta(f($));if(S(g)||(L(w,t)?await m(I([e,...g],async(n,s)=>{P(A,n)||(await a(ma+Pa(t)+"ADD"+Pa(n)+r),0==s&&await a("CREATE UNIQUE INDEX pk ON "+Pa(t)+`(${Pa(e)})`),ea($,n))})):(await a(ba+Pa(t)+`(${Pa(e)}${r} PRIMARY KEY${p(I(g,a=>n+Pa(a)+r))});`),q(w,t,ta([e,...g])))),await m([...!u&&l?I(f(A),async n=>{n!=e&&(await a(ma+Pa(t)+"DROP"+Pa(n)),P($,n))}):[]]),u)y(s)?await a(va+Pa(t)+Ua(t,E)):await m(W(s,async(n,s)=>{y(n)?await a(va+Pa(t)+Ua(t,E)+`AND(${Pa(e)}=$1)`,[s]):S(g)||await o(a,t,e,G(n),{[s]:c?I(X(n),c):X(n)},$)}));else if(S(g))L(w,t)&&await a(va+Pa(t)+Ua(t,E));else{const n=_(f(K(w,t)),a=>a!=e),i={},r=[];Y(s??{},(a,t)=>{i[t]=I(n,t=>c?c(a?.[t]):a?.[t]),C(r,t)}),await o(a,t,e,n,i),await a(va+Pa(t)+Ua(t,E)+`AND${Pa(e)}NOT IN(${Fa(r)})`,r)}},async t=>{let e;return await a("BEGIN"),await v(async()=>e=await t(),s),await a("END"),e}]},et=async(a,t,e,s,i)=>{const r=[1];await a($a+" INTO"+Pa(t)+"("+((...a)=>p(I(a,Pa),n))(e,...s)+")VALUES"+p(W(i,a=>"($"+r[0]+++","+Fa(a,r)+")"),n)+"ON CONFLICT("+Pa(e)+`)DO ${Oa} SET`+p(I(s,a=>Pa(a)+"=excluded."+Pa(a)),n),W(i,(a,t)=>[t,...I(a,a=>a??null)]).flat())},nt=(a,t,e,n,s,i,r,[o,c,l],w,d,y,u,E,N)=>{const[g,$,A,O]=tt(t,w,d,s,E,N),m=oa(a,()=>O(async()=>{return await g(),a=(await $(o,c))[ya]?.[l]??"null",la(a,(a,t)=>""===t?void 0:t);var a}),a=>O(async()=>{await g(),await A(o,c,{[ya]:{[l]:wa(a()??null)}},!0,!0)}),e,n,s,r,{[u]:()=>y,destroy:async()=>(await m.stopAutoPersisting(),i(),m)},0,y);return m},st=(a,t,e,n,s,i,r,[o,c,[l,w,d]],u,E,N,g,$,A,O,T)=>{const[v,R,p,I]=tt(t,u,E,s,$,A,O,T),S=(a,t)=>m(V(c,async([e,n,s,i,r],o)=>{t&&!(o in a)||await p(e,n,a[o],s,i,t,r)})),C=async(a,t)=>w?await p(d,ua,{[ya]:a},!0,!0,t):null,b=oa(a,()=>I(async()=>{await v();const a=await(async()=>x(_(await m(V(o,async([a,t,e],n)=>[a,await R(n,t,e)])),a=>!k(a[1]))))(),t=await(async()=>l?(await R(d,ua))[ya]:{})();return k(a)&&y(t)?void 0:[a,t]}),(a,t)=>I(async()=>{if(await v(),y(t)){const[t,e]=a();await S(t),await C(e)}else await S(t[0],!0),await C(t[1],!0)}),e,n,s,r,{[g]:()=>N,destroy:async()=>(await b.stopAutoPersisting(),i(),b)},0,N);return b},it=/^([cd]:)(.+)/,rt=(a,n,s,o,c,l,w,d,y,u,E="getDb")=>{const g=ha(s,l),[$,,A,O]=at(n),T=e+(a=>{let t=2166136261;return R(da.encode(a),a=>{t^=a,t+=(t<<1)+(t<<4)+(t<<7)+(t<<8)+(t<<24)}),t>>>0})(wa(A)),v=t+"_"+T,S=async(a,e,n="",s="")=>{const i=Ma(t,a,T);return await g(Ca+La+Da+i+`()RETURNS ${n}trigger AS $$ ${s}BEGIN ${e}END;$$ LANGUAGE plpgsql;`),i},_=async(a,t,e,n)=>(await g(Ca+a+"TRIGGER"+t+e+"EXECUTE "+Da+n+"()"),t),C=a=>`PERFORM pg_notify('${v}',${a});`,b=(a,t)=>$?i:2===t?b(a,0)+" OR "+b(a,1):r(K(A[0],a)?.[2]??i,fa,0==t?"NEW":"OLD"),D=(a,e)=>m(I([$a,Aa,Oa],(n,s)=>_(La,Ma(t,"d",T,a,n),`AFTER ${n} ON${Pa(a)}FOR EACH ROW WHEN(${b(a,s)})`,e)));return($?nt:st)(a,g,async a=>{const e=await S("c",`FOR row IN SELECT object_identity FROM pg_event_trigger_ddl_commands()${Na} command_tag='${ba}' LOOP ${C("'c:'||SPLIT_PART(row.object_identity,'.',2)")}END LOOP;`,"event_","DECLARE row record;");await _("EVENT ",Ma(t,"c",T),`ON ddl_command_end WHEN TAG IN('${ba}')`,e);const n=await S("d",C("'d:'||TG_TABLE_NAME")+"RETURN NULL;");return await m(I(f(O),async a=>(await g(ba+` IF NOT EXISTS${Pa(a)}("_id"text PRIMARY KEY)`),await D(a,n)))),[await o(v,t=>{return N((e=t,s=it,e?.match(s)),async([,t,e])=>{L(O,e)&&("c:"==t&&await D(e,n),a())});var e,s}),[e,n]]},async([a,t])=>{c(a),await g(`DROP FUNCTION IF EXISTS${p(t,",")}CASCADE`)},w,d,y,A,f(O),async(a,t)=>await a(Ea+` table_name tn,column_name cn FROM information_schema.columns ${Na} table_schema='public'AND table_name IN(${Fa(t)})`,t),u,E,"text",void 0,a=>ca(a),a=>la(a))},ot=(a,t,n,s,i,r,o,c,l,y,u="getDb",E)=>{let N,g,$;const A=ha(n,r),[O,m,T,R]=at(t);return(O?nt:st)(a,A,a=>{let t;const e=()=>t=setInterval(()=>v(async()=>{const[{d:t,s:e,c:n}]=await A(Ea+` ${Ia} d,${Sa} s,TOTAL_CHANGES() c FROM ${pa}${Ia} JOIN ${pa}${Sa}`);t==N&&e==g&&n==$||(d(N)||a(),N=t,g=e,$=n)}),1e3*m),n=()=>{N=g=$=null,w(t)},r=s(t=>{R.has(t)&&(n(),a(),e())});return e(),()=>{n(),i(r)}},a=>a(),o,c,l,T,f(R),async(a,t)=>await a(Ea+` t.name tn,c.name cn FROM ${_a}list()t,${_a}info(t.name)c ${Na} t.schema='main'AND t.type IN('table','view')AND t.name IN(${Fa(t)})ORDER BY t.name,c.name`,t),y,u,e,E,a=>!0===a?1:!1===a?0:a,void 0)};export{sa as Persists,na as Status,oa as createCustomPersister,rt as createCustomPostgreSqlPersister,ot as createCustomSqlitePersister};
|
|
Binary file
|