tinybase 7.3.3 → 7.3.4
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/checkpoints/index.js +12 -11
- package/checkpoints/with-schemas/index.js +12 -11
- package/common/index.js +3 -2
- package/common/with-schemas/index.js +3 -2
- package/index.js +92 -64
- package/indexes/index.js +13 -12
- package/indexes/with-schemas/index.js +13 -12
- package/mergeable-store/index.js +92 -64
- package/mergeable-store/with-schemas/index.js +92 -64
- package/metrics/index.js +13 -12
- package/metrics/with-schemas/index.js +13 -12
- 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-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-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 +99 -64
- package/omni/with-schemas/index.js +99 -64
- package/package.json +3 -3
- package/persisters/index.js +19 -11
- package/persisters/persister-automerge/index.js +17 -9
- package/persisters/persister-automerge/with-schemas/index.js +17 -9
- package/persisters/persister-browser/index.js +17 -9
- package/persisters/persister-browser/with-schemas/index.js +17 -9
- package/persisters/persister-cr-sqlite-wasm/index.js +19 -11
- package/persisters/persister-cr-sqlite-wasm/with-schemas/index.js +19 -11
- package/persisters/persister-durable-object-sql-storage/index.js +19 -11
- package/persisters/persister-durable-object-sql-storage/with-schemas/index.js +19 -11
- package/persisters/persister-durable-object-storage/index.js +19 -11
- package/persisters/persister-durable-object-storage/with-schemas/index.js +19 -11
- package/persisters/persister-electric-sql/index.js +19 -11
- package/persisters/persister-electric-sql/with-schemas/index.js +19 -11
- package/persisters/persister-expo-sqlite/index.js +19 -11
- package/persisters/persister-expo-sqlite/with-schemas/index.js +19 -11
- package/persisters/persister-file/index.js +17 -9
- package/persisters/persister-file/with-schemas/index.js +17 -9
- package/persisters/persister-indexed-db/index.js +17 -9
- package/persisters/persister-indexed-db/with-schemas/index.js +17 -9
- package/persisters/persister-libsql/index.js +19 -11
- package/persisters/persister-libsql/with-schemas/index.js +19 -11
- package/persisters/persister-partykit-client/index.js +17 -9
- package/persisters/persister-partykit-client/with-schemas/index.js +17 -9
- package/persisters/persister-partykit-server/index.js +2 -2
- package/persisters/persister-partykit-server/with-schemas/index.js +2 -2
- package/persisters/persister-pglite/index.js +19 -11
- package/persisters/persister-pglite/with-schemas/index.js +19 -11
- package/persisters/persister-postgres/index.js +19 -11
- package/persisters/persister-postgres/with-schemas/index.js +19 -11
- package/persisters/persister-powersync/index.js +19 -11
- package/persisters/persister-powersync/with-schemas/index.js +19 -11
- package/persisters/persister-react-native-mmkv/index.js +17 -9
- package/persisters/persister-react-native-mmkv/with-schemas/index.js +17 -9
- package/persisters/persister-react-native-sqlite/index.js +19 -11
- package/persisters/persister-react-native-sqlite/with-schemas/index.js +19 -11
- package/persisters/persister-remote/index.js +17 -9
- package/persisters/persister-remote/with-schemas/index.js +17 -9
- package/persisters/persister-sqlite-bun/index.js +19 -11
- package/persisters/persister-sqlite-bun/with-schemas/index.js +19 -11
- package/persisters/persister-sqlite-wasm/index.js +19 -11
- package/persisters/persister-sqlite-wasm/with-schemas/index.js +19 -11
- package/persisters/persister-sqlite3/index.js +19 -11
- package/persisters/persister-sqlite3/with-schemas/index.js +19 -11
- package/persisters/persister-yjs/index.js +19 -11
- package/persisters/persister-yjs/with-schemas/index.js +19 -11
- package/persisters/with-schemas/index.js +19 -11
- package/queries/index.js +15 -14
- package/queries/with-schemas/index.js +15 -14
- package/readme.md +2 -2
- package/relationships/index.js +13 -12
- package/relationships/with-schemas/index.js +13 -12
- package/store/index.js +74 -60
- package/store/with-schemas/index.js +74 -60
- package/synchronizers/index.js +17 -9
- package/synchronizers/synchronizer-broadcast-channel/index.js +17 -9
- package/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js +17 -9
- package/synchronizers/synchronizer-local/index.js +19 -11
- package/synchronizers/synchronizer-local/with-schemas/index.js +19 -11
- package/synchronizers/synchronizer-ws-client/index.js +17 -9
- package/synchronizers/synchronizer-ws-client/with-schemas/index.js +17 -9
- package/synchronizers/synchronizer-ws-server/index.js +20 -12
- package/synchronizers/synchronizer-ws-server/with-schemas/index.js +20 -12
- package/synchronizers/synchronizer-ws-server-durable-object/index.js +17 -9
- package/synchronizers/synchronizer-ws-server-durable-object/with-schemas/index.js +17 -9
- package/synchronizers/synchronizer-ws-server-simple/index.js +11 -10
- package/synchronizers/synchronizer-ws-server-simple/with-schemas/index.js +11 -10
- package/synchronizers/with-schemas/index.js +17 -9
- package/ui-react-inspector/index.js +81 -60
- package/ui-react-inspector/with-schemas/index.js +81 -60
- package/with-schemas/index.js +92 -64
|
@@ -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=a=>(t,e,n)=>a(t)?n?.():e(t),l=globalThis,w=a=>null==a,y=a=>void 0===a,d=a=>null===a,u=c(w),E=c(y),N=t=>a(t)==s,g=a=>Array.isArray(a),A=(a,t,e)=>a.slice(t,e),T=a=>a.length,$=()=>{},p=async a=>r.all(a),O=a=>{throw Error(a)},R=async(a,t,e)=>{try{return await a()}catch(a){t?.(a)}},m=(a,t)=>a.forEach(t),v=(a,t="")=>a.join(t),C=(a,t)=>a.map(t),I=a=>0==T(a),L=(a,t)=>a.filter(t),S=(a,...t)=>a.push(...t),_=a=>a.shift(),b=(a,t)=>a?.has(t)??!1,f=a=>y(a)||0==(a=>a?.size??0)(a),D=a=>[...a?.values()??[]],
|
|
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=globalThis,w=a=>null==a,y=a=>void 0===a,d=a=>null===a,u=c(w),E=c(y),N=t=>a(t)==s,g=a=>Array.isArray(a),A=(a,t,e)=>a.slice(t,e),T=a=>a.length,$=()=>{},p=async a=>r.all(a),O=a=>{throw Error(a)},R=async(a,t,e)=>{try{return await a()}catch(a){t?.(a)}},m=(a,t)=>a.forEach(t),v=(a,t="")=>a.join(t),C=(a,t)=>a.map(t),I=a=>0==T(a),L=(a,t)=>a.filter(t),S=(a,...t)=>a.push(...t),_=a=>a.shift(),b=(a,t)=>a?.has(t)??!1,f=a=>y(a)||0==(a=>a?.size??0)(a),D=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=a=>!w(a)&&u(F(a),a=>a==M.prototype||w(F(a)),()=>!0),j=M.keys,x=M.freeze,W=(a=[])=>M.fromEntries(a),B=(...a)=>M.assign({},...a),H=(a,t)=>(delete a[t],a),X=(a,t)=>C(U(a),([a,e])=>t(e,a)),Y=(a,t)=>W(X(a,(a,e)=>[e,t(a,e)])),k=a=>M.values(a),q=a=>T(j(a)),z=a=>G(a)&&0==q(a),J=JSON.stringify,K=JSON.parse,V=a=>J(a,(a,t)=>y(t)?"":t),Q=a=>""===a?void 0:g(a)?C(a,Q):G(a)?Y(a,Q):a,Z=new l.TextEncoder,aa=Map,ta=a=>new aa(a),ea=(a,t)=>a?.get(t),na=(a,t)=>C([...a?.entries()??[]],([a,e])=>t(e,a)),sa=(a,t,e)=>y(e)?(P(a,t),a):a?.set(t,e),ia=(a,t,e,n)=>(b(a,t)?n?.(ea(a,t)):sa(a,t,e()),ea(a,t)),oa=(a,t,e,n,s=0)=>E((e?ia:ea)(a,t[s],s>T(t)-2?e:ta),i=>{if(s>T(t)-2)return n?.(i)&&sa(a,t[s]),i;const o=oa(i,t,e,n,s+1);return f(i)&&sa(a,t[s]),o}),ra="_",ca="_id",la="SELECT",wa="WHERE",ya="TABLE",da="INSERT",ua="DELETE",Ea="UPDATE",Na="ALTER "+ya,ga="FROM",Aa=ua+" "+ga,Ta=la+"*"+ga,$a="CREATE ",pa=$a+ya,Oa="OR REPLACE ",Ra="FUNCTION",ma="$tableName",va=a=>v(C(((a,t="",e)=>a.split(t,e))(a,"."),a=>`"${o(a,/"/g,'""')}"`),"."),Ca=(...a)=>va(v(a,"_")),Ia=(a,t=[1])=>v(C(a,()=>"$"+t[0]++),n),La=(a,t=i)=>wa+`(${o(t,ma,va(a))})`,Sa=a=>new Set(g(a)||y(a)?a:[a]),_a=(a,t)=>a?.add(t),ba="ColumnName",fa="store",Da="json",ha=fa+"TableName",Pa=fa+"Id"+ba,Ma=fa+ba,Fa="autoLoadIntervalSeconds",Ua="rowId"+ba,Ga="tableId",ja="tableName",xa="deleteEmptyColumns",Wa="deleteEmptyTable",Ba="condition",Ha={mode:Da,[Fa]:1},Xa={load:0,save:0,[ja]:t+"_values"},Ya=(a,t,e,n,s)=>{const i=ta();return Y(a,(a,o)=>{const r=A(k(B(t,N(a)?{[e]:a}:a)),0,q(t));d(r[0])||n(o,r[0])||(s(o,r[0]),sa(i,o,r))}),i},ka=/^\d+$/,qa=ta(),za=ta(),Ja=(a,t,n,s,i,o,r,c={},l=0,w=[])=>{let u,N,A,$=0,p=0,v=0;ia(qa,w,()=>0),ia(za,w,()=>[]);const C=ta(),[I,L,b,D,M]=((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]:O("Store type not supported by this Persister"))(r,a,l),[F,U,G]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?_(a):null)??e+t++,t=>{ka.test(t)&&T(a)<1e3&&S(a,t)}]})(),s=ta();return[(n,i,o,r=[],c=()=>[])=>{a??=Z;const l=t(1);return sa(s,l,[n,i,o,r,c]),_a(oa(i,o??[e],Sa),l),l},(t,n,...i)=>m(((a,t=[e])=>{const n=[],s=(a,e)=>e==T(t)?S(n,a):d(t[e])?h(a,a=>s(a,e+1)):m([t[e],null],t=>s(ea(a,t),e+1));return s(a,0),n})(t,n),t=>h(t,t=>ea(s,t)[0](a,...n??[],...i))),a=>E(ea(s,a),([,t,i])=>(oa(t,i??[e],void 0,t=>(P(t,a),f(t)?1:0)),sa(s,a),n(a),i)),t=>E(ea(s,t),([t,,e=[],n,s])=>{const i=(...o)=>{const r=T(o);r==T(e)?t(a,...o,...s(o)):d(e[r])?m(n[r]?.(...o)??[],a=>i(...o,a)):i(...o,e[r])};i()})]})(),j=a=>{a!=$&&($=a,U(C,void 0,$))},W=t=>{(I&&g(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},B=async()=>{K()&&a.hadMutated?.()&&await k()},H=async a=>(2!=$&&(j(1),p++,await Q(async()=>{await R(async()=>{const e=await t();g(e)?W(e):a?M(a):O("Content is not an array: "+e)},()=>{a&&M(a)}),j(0),await B()})),Z),X=async a=>(Y(),await H(a),await R(async()=>N=await s(async(a,t)=>{t||a?2!=$&&(j(1),p++,W(t??a),j(0),await B()):await H()}),o),Z),Y=async()=>(N&&(await R(()=>i(N),o),N=void 0),Z),k=async a=>(1!=$&&(j(2),v++,await Q(async()=>{await R(()=>n(L,a),o),j(0)})),Z),q=async()=>(J(),await k(),A=a.addDidFinishTransactionListener(()=>{const a=b();D(a)&&k(a)}),Z),J=async()=>(A&&(a.delListener(A),A=void 0),Z),K=()=>!y(A),V=async(a=!1)=>{const[t,e]=a?[J,Y]:[Y,J];return await t(),await e(),Z},Q=async(...a)=>(S(ea(za,w),...a),await(async()=>{if(!ea(qa,w)){for(sa(qa,w,1);!y(u=_(ea(za,w)));)await R(u,o);sa(qa,w,0)}})(),Z),Z={load:H,startAutoLoad:X,stopAutoLoad:Y,isAutoLoading:()=>!y(N),save:k,startAutoSave:q,stopAutoSave:J,isAutoSaving:K,startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[q,X]:[X,q];return await e(a),await n(a),Z},stopAutoPersisting:V,getStatus:()=>$,addStatusListener:a=>F(a,C),delListener:t=>(G(t),a),schedule:Q,getStore:()=>a,destroy:()=>(ea(za,w).splice(0,void 0),V()),getStats:()=>({loads:p,saves:v}),...c};return x(Z)},Ka=(a,t,e,s,o,r=Va,c,l)=>{const w=ta();return[async()=>{w.clear(),C(await e(a,t),({tn:a,cn:t})=>_a(ia(w,a,Sa),t))},async(t,e,n)=>((a,t)=>b(ea(w,a),t))(t,e)?W(L(C(await a(Ta+va(t)+La(t,n)),a=>[a[e],l?Y(H(a,e),l):H(a,e)]),([a,t])=>!y(a)&&!z(t))):{},async(t,e,s,l,d,u=!1,E=i)=>{const N=Sa();Y(s??{},a=>C(j(a??{}),a=>_a(N,a)));const g=D(N);if(!u&&d&&E==i&&I(g)&&b(w,t))return await a("DROP "+ya+va(t)),void sa(w,t);const A=ea(w,t),T=Sa(D(A));if(I(g)||(b(w,t)?await p(C([e,...g],async(n,s)=>{P(T,n)||(await a(Na+va(t)+"ADD"+va(n)+o),0==s&&await a("CREATE UNIQUE INDEX pk ON "+va(t)+`(${va(e)})`),_a(A,n))})):(await a(pa+va(t)+`(${va(e)}${o} PRIMARY KEY${v(C(g,a=>n+va(a)+o))});`),sa(w,t,Sa([e,...g])))),await p([...!u&&l?C(D(T),async n=>{n!=e&&(await a(Na+va(t)+"DROP"+va(n)),P(A,n))}):[]]),u)y(s)?await a(Aa+va(t)+La(t,E)):await p(X(s,async(n,s)=>{y(n)?await a(Aa+va(t)+La(t,E)+`AND(${va(e)}=$1)`,[s]):I(g)||await r(a,t,e,j(n),{[s]:c?C(k(n),c):k(n)},A)}));else if(I(g))b(w,t)&&await a(Aa+va(t)+La(t,E));else{const n=L(D(ea(w,t)),a=>a!=e),i={},o=[];Y(s??{},(a,t)=>{i[t]=C(n,t=>c?c(a?.[t]):a?.[t]),S(o,t)}),await r(a,t,e,n,i),await a(Aa+va(t)+La(t,E)+`AND${va(e)}NOT IN(${Ia(o)})`,o)}},async t=>{let e;return await a("BEGIN"),await R(async()=>e=await t(),s),await a("END"),e}]},Va=async(a,t,e,s,i)=>{const o=[1];await a(da+" INTO"+va(t)+"("+((...a)=>v(C(a,va),n))(e,...s)+")VALUES"+v(X(i,a=>"($"+o[0]+++","+Ia(a,o)+")"),n)+"ON CONFLICT("+va(e)+`)DO ${Ea} SET`+v(C(s,a=>va(a)+"=excluded."+va(a)),n),X(i,(a,t)=>[t,...C(a,a=>a??null)]).flat())},Qa=(a,t,e,n,s,i,o,[r,c,l],w,y,d,u,E,N)=>{const[g,A,T,$]=Ka(t,w,y,s,E,N),p=Ja(a,()=>$(async()=>{return await g(),a=(await A(r,c))[ra]?.[l]??"null",Q(K(a));var a}),a=>$(async()=>{await g(),await T(r,c,{[ra]:{[l]:V(a()??null)}},!0,!0)}),e,n,s,o,{[u]:()=>d,destroy:async()=>(await p.stopAutoPersisting(),i(),p)},0,d);return p},Za=(a,t,e,n,s,i,o,[r,c,[l,w,d]],u,E,N,g,A,T,$,O)=>{const[R,m,v,C]=Ka(t,u,E,s,A,T,$,O),I=(a,t)=>p(na(c,async([e,n,s,i,o],r)=>{t&&!(r in a)||await v(e,n,a[r],s,i,t,o)})),S=async(a,t)=>w?await v(d,ca,{[ra]:a},!0,!0,t):null,_=Ja(a,()=>C(async()=>{await R();const a=await(async()=>W(L(await p(na(r,async([a,t,e],n)=>[a,await m(n,t,e)])),a=>!z(a[1]))))(),t=await(async()=>l?(await m(d,ca))[ra]:{})();return z(a)&&y(t)?void 0:[a,t]}),(a,t)=>C(async()=>{if(await R(),y(t)){const[t,e]=a();await I(t),await S(e)}else await I(t[0],!0),await S(t[1],!0)}),e,n,s,o,{[g]:()=>N,destroy:async()=>(await _.stopAutoPersisting(),i(),_)},0,N);return _},at=/^([cd]:)(.+)/,tt=(a,n,s,r,c,l,w,y,d,u,g="getDb")=>{const T=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,l),[$,,O,R]=(a=>{const e=(a=>B(Ha,N(a)?{[ha]:a}:a??{}))(a),n=e[Fa];if(e.mode==Da){const a=e[ha]??t;return[1,n,[a,e[Pa]??ca,e[Ma]??fa],Sa(a)]}const{tables:{load:s={},save:o={}}={},values:r={}}=e,c=A(k(B(Xa,r)),0,q(Xa)),l=c[2],w=Sa(l),y=Sa(l),d=Ya(s,{[Ga]:null,[Ua]:ca,[Ba]:i},Ga,a=>b(y,a),a=>_a(w,a)),u=Ya(o,{[ja]:null,[Ua]:ca,[xa]:0,[Wa]:0,[Ba]:null},ja,(a,t)=>b(y,t),(a,t)=>_a(w,t));var E;return E=(a,t)=>t[4]??=ea(d,t[0])?.[2]??i,h(u,(a,t)=>E(0,a)),[0,n,[d,u,c],w]})(n),I=e+(a=>{let t=2166136261;return m(Z.encode(a),a=>{t^=a,t+=(t<<1)+(t<<4)+(t<<7)+(t<<8)+(t<<24)}),t>>>0})(V(O)),L=t+"_"+I,S=async(a,e,n="",s="")=>{const i=Ca(t,a,I);return await T($a+Oa+Ra+i+`()RETURNS ${n}trigger AS $$ ${s}BEGIN ${e}END;$$ LANGUAGE plpgsql;`),i},_=async(a,t,e,n)=>(await T($a+a+"TRIGGER"+t+e+"EXECUTE "+Ra+n+"()"),t),f=a=>`PERFORM pg_notify('${L}',${a});`,P=(a,t)=>$?i:2===t?P(a,0)+" OR "+P(a,1):o(ea(O[0],a)?.[2]??i,ma,0==t?"NEW":"OLD"),M=(a,e)=>p(C([da,ua,Ea],(n,s)=>_(Oa,Ca(t,"d",I,a,n),`AFTER ${n} ON${va(a)}FOR EACH ROW WHEN(${P(a,s)})`,e)));return($?Qa:Za)(a,T,async a=>{const e=await S("c",`FOR row IN SELECT object_identity FROM pg_event_trigger_ddl_commands()${wa} command_tag='${pa}' LOOP ${f("'c:'||SPLIT_PART(row.object_identity,'.',2)")}END LOOP;`,"event_","DECLARE row record;");await _("EVENT ",Ca(t,"c",I),`ON ddl_command_end WHEN TAG IN('${pa}')`,e);const n=await S("d",f("'d:'||TG_TABLE_NAME")+"RETURN NULL;");return await p(C(D(R),async a=>(await T(pa+` IF NOT EXISTS${va(a)}("_id"text PRIMARY KEY)`),await M(a,n)))),[await r(L,t=>{return E((e=t,s=at,e?.match(s)),async([,t,e])=>{b(R,e)&&("c:"==t&&await M(e,n),a())});var e,s}),[e,n]]},async([a,t])=>{c(a),await T(`DROP FUNCTION IF EXISTS${v(t,",")}CASCADE`)},w,y,d,O,D(R),async(a,t)=>await a(la+` table_name tn,column_name cn FROM information_schema.columns ${wa} table_schema='public'AND table_name IN(${Ia(t)})`,t),u,g,"text",void 0,a=>J(a),a=>K(a))},et=async(a,t,e,n,s)=>tt(a,e,async(a,e=[])=>(await t.query(a,e)).rows,(a,e)=>t.listen(a,e),a=>R(a,s),n,s,$,3,t,"getPglite");export{et as createPglitePersister};
|
|
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=a=>(t,e,n)=>a(t)?n?.():e(t),l=globalThis,w=a=>null==a,y=a=>void 0===a,d=a=>null===a,u=c(w),E=c(y),N=t=>a(t)==s,g=a=>Array.isArray(a),A=(a,t,e)=>a.slice(t,e),T=a=>a.length,$=()=>{},p=async a=>r.all(a),O=a=>{throw Error(a)},R=async(a,t,e)=>{try{return await a()}catch(a){t?.(a)}},m=(a,t)=>a.forEach(t),v=(a,t="")=>a.join(t),C=(a,t)=>a.map(t),I=a=>0==T(a),L=(a,t)=>a.filter(t),S=(a,...t)=>a.push(...t),_=a=>a.shift(),b=(a,t)=>a?.has(t)??!1,f=a=>y(a)||0==(a=>a?.size??0)(a),D=a=>[...a?.values()??[]],
|
|
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=globalThis,w=a=>null==a,y=a=>void 0===a,d=a=>null===a,u=c(w),E=c(y),N=t=>a(t)==s,g=a=>Array.isArray(a),A=(a,t,e)=>a.slice(t,e),T=a=>a.length,$=()=>{},p=async a=>r.all(a),O=a=>{throw Error(a)},R=async(a,t,e)=>{try{return await a()}catch(a){t?.(a)}},m=(a,t)=>a.forEach(t),v=(a,t="")=>a.join(t),C=(a,t)=>a.map(t),I=a=>0==T(a),L=(a,t)=>a.filter(t),S=(a,...t)=>a.push(...t),_=a=>a.shift(),b=(a,t)=>a?.has(t)??!1,f=a=>y(a)||0==(a=>a?.size??0)(a),D=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=a=>!w(a)&&u(F(a),a=>a==M.prototype||w(F(a)),()=>!0),j=M.keys,x=M.freeze,W=(a=[])=>M.fromEntries(a),B=(...a)=>M.assign({},...a),H=(a,t)=>(delete a[t],a),X=(a,t)=>C(U(a),([a,e])=>t(e,a)),Y=(a,t)=>W(X(a,(a,e)=>[e,t(a,e)])),k=a=>M.values(a),q=a=>T(j(a)),z=a=>G(a)&&0==q(a),J=JSON.stringify,K=JSON.parse,V=a=>J(a,(a,t)=>y(t)?"":t),Q=a=>""===a?void 0:g(a)?C(a,Q):G(a)?Y(a,Q):a,Z=new l.TextEncoder,aa=Map,ta=a=>new aa(a),ea=(a,t)=>a?.get(t),na=(a,t)=>C([...a?.entries()??[]],([a,e])=>t(e,a)),sa=(a,t,e)=>y(e)?(P(a,t),a):a?.set(t,e),ia=(a,t,e,n)=>(b(a,t)?n?.(ea(a,t)):sa(a,t,e()),ea(a,t)),oa=(a,t,e,n,s=0)=>E((e?ia:ea)(a,t[s],s>T(t)-2?e:ta),i=>{if(s>T(t)-2)return n?.(i)&&sa(a,t[s]),i;const o=oa(i,t,e,n,s+1);return f(i)&&sa(a,t[s]),o}),ra="_",ca="_id",la="SELECT",wa="WHERE",ya="TABLE",da="INSERT",ua="DELETE",Ea="UPDATE",Na="ALTER "+ya,ga="FROM",Aa=ua+" "+ga,Ta=la+"*"+ga,$a="CREATE ",pa=$a+ya,Oa="OR REPLACE ",Ra="FUNCTION",ma="$tableName",va=a=>v(C(((a,t="",e)=>a.split(t,e))(a,"."),a=>`"${o(a,/"/g,'""')}"`),"."),Ca=(...a)=>va(v(a,"_")),Ia=(a,t=[1])=>v(C(a,()=>"$"+t[0]++),n),La=(a,t=i)=>wa+`(${o(t,ma,va(a))})`,Sa=a=>new Set(g(a)||y(a)?a:[a]),_a=(a,t)=>a?.add(t),ba="ColumnName",fa="store",Da="json",ha=fa+"TableName",Pa=fa+"Id"+ba,Ma=fa+ba,Fa="autoLoadIntervalSeconds",Ua="rowId"+ba,Ga="tableId",ja="tableName",xa="deleteEmptyColumns",Wa="deleteEmptyTable",Ba="condition",Ha={mode:Da,[Fa]:1},Xa={load:0,save:0,[ja]:t+"_values"},Ya=(a,t,e,n,s)=>{const i=ta();return Y(a,(a,o)=>{const r=A(k(B(t,N(a)?{[e]:a}:a)),0,q(t));d(r[0])||n(o,r[0])||(s(o,r[0]),sa(i,o,r))}),i},ka=/^\d+$/,qa=ta(),za=ta(),Ja=(a,t,n,s,i,o,r,c={},l=0,w=[])=>{let u,N,A,$=0,p=0,v=0;ia(qa,w,()=>0),ia(za,w,()=>[]);const C=ta(),[I,L,b,D,M]=((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]:O("Store type not supported by this Persister"))(r,a,l),[F,U,G]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?_(a):null)??e+t++,t=>{ka.test(t)&&T(a)<1e3&&S(a,t)}]})(),s=ta();return[(n,i,o,r=[],c=()=>[])=>{a??=Z;const l=t(1);return sa(s,l,[n,i,o,r,c]),_a(oa(i,o??[e],Sa),l),l},(t,n,...i)=>m(((a,t=[e])=>{const n=[],s=(a,e)=>e==T(t)?S(n,a):d(t[e])?h(a,a=>s(a,e+1)):m([t[e],null],t=>s(ea(a,t),e+1));return s(a,0),n})(t,n),t=>h(t,t=>ea(s,t)[0](a,...n??[],...i))),a=>E(ea(s,a),([,t,i])=>(oa(t,i??[e],void 0,t=>(P(t,a),f(t)?1:0)),sa(s,a),n(a),i)),t=>E(ea(s,t),([t,,e=[],n,s])=>{const i=(...o)=>{const r=T(o);r==T(e)?t(a,...o,...s(o)):d(e[r])?m(n[r]?.(...o)??[],a=>i(...o,a)):i(...o,e[r])};i()})]})(),j=a=>{a!=$&&($=a,U(C,void 0,$))},W=t=>{(I&&g(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},B=async()=>{K()&&a.hadMutated?.()&&await k()},H=async a=>(2!=$&&(j(1),p++,await Q(async()=>{await R(async()=>{const e=await t();g(e)?W(e):a?M(a):O("Content is not an array: "+e)},()=>{a&&M(a)}),j(0),await B()})),Z),X=async a=>(Y(),await H(a),await R(async()=>N=await s(async(a,t)=>{t||a?2!=$&&(j(1),p++,W(t??a),j(0),await B()):await H()}),o),Z),Y=async()=>(N&&(await R(()=>i(N),o),N=void 0),Z),k=async a=>(1!=$&&(j(2),v++,await Q(async()=>{await R(()=>n(L,a),o),j(0)})),Z),q=async()=>(J(),await k(),A=a.addDidFinishTransactionListener(()=>{const a=b();D(a)&&k(a)}),Z),J=async()=>(A&&(a.delListener(A),A=void 0),Z),K=()=>!y(A),V=async(a=!1)=>{const[t,e]=a?[J,Y]:[Y,J];return await t(),await e(),Z},Q=async(...a)=>(S(ea(za,w),...a),await(async()=>{if(!ea(qa,w)){for(sa(qa,w,1);!y(u=_(ea(za,w)));)await R(u,o);sa(qa,w,0)}})(),Z),Z={load:H,startAutoLoad:X,stopAutoLoad:Y,isAutoLoading:()=>!y(N),save:k,startAutoSave:q,stopAutoSave:J,isAutoSaving:K,startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[q,X]:[X,q];return await e(a),await n(a),Z},stopAutoPersisting:V,getStatus:()=>$,addStatusListener:a=>F(a,C),delListener:t=>(G(t),a),schedule:Q,getStore:()=>a,destroy:()=>(ea(za,w).splice(0,void 0),V()),getStats:()=>({loads:p,saves:v}),...c};return x(Z)},Ka=(a,t,e,s,o,r=Va,c,l)=>{const w=ta();return[async()=>{w.clear(),C(await e(a,t),({tn:a,cn:t})=>_a(ia(w,a,Sa),t))},async(t,e,n)=>((a,t)=>b(ea(w,a),t))(t,e)?W(L(C(await a(Ta+va(t)+La(t,n)),a=>[a[e],l?Y(H(a,e),l):H(a,e)]),([a,t])=>!y(a)&&!z(t))):{},async(t,e,s,l,d,u=!1,E=i)=>{const N=Sa();Y(s??{},a=>C(j(a??{}),a=>_a(N,a)));const g=D(N);if(!u&&d&&E==i&&I(g)&&b(w,t))return await a("DROP "+ya+va(t)),void sa(w,t);const A=ea(w,t),T=Sa(D(A));if(I(g)||(b(w,t)?await p(C([e,...g],async(n,s)=>{P(T,n)||(await a(Na+va(t)+"ADD"+va(n)+o),0==s&&await a("CREATE UNIQUE INDEX pk ON "+va(t)+`(${va(e)})`),_a(A,n))})):(await a(pa+va(t)+`(${va(e)}${o} PRIMARY KEY${v(C(g,a=>n+va(a)+o))});`),sa(w,t,Sa([e,...g])))),await p([...!u&&l?C(D(T),async n=>{n!=e&&(await a(Na+va(t)+"DROP"+va(n)),P(A,n))}):[]]),u)y(s)?await a(Aa+va(t)+La(t,E)):await p(X(s,async(n,s)=>{y(n)?await a(Aa+va(t)+La(t,E)+`AND(${va(e)}=$1)`,[s]):I(g)||await r(a,t,e,j(n),{[s]:c?C(k(n),c):k(n)},A)}));else if(I(g))b(w,t)&&await a(Aa+va(t)+La(t,E));else{const n=L(D(ea(w,t)),a=>a!=e),i={},o=[];Y(s??{},(a,t)=>{i[t]=C(n,t=>c?c(a?.[t]):a?.[t]),S(o,t)}),await r(a,t,e,n,i),await a(Aa+va(t)+La(t,E)+`AND${va(e)}NOT IN(${Ia(o)})`,o)}},async t=>{let e;return await a("BEGIN"),await R(async()=>e=await t(),s),await a("END"),e}]},Va=async(a,t,e,s,i)=>{const o=[1];await a(da+" INTO"+va(t)+"("+((...a)=>v(C(a,va),n))(e,...s)+")VALUES"+v(X(i,a=>"($"+o[0]+++","+Ia(a,o)+")"),n)+"ON CONFLICT("+va(e)+`)DO ${Ea} SET`+v(C(s,a=>va(a)+"=excluded."+va(a)),n),X(i,(a,t)=>[t,...C(a,a=>a??null)]).flat())},Qa=(a,t,e,n,s,i,o,[r,c,l],w,y,d,u,E,N)=>{const[g,A,T,$]=Ka(t,w,y,s,E,N),p=Ja(a,()=>$(async()=>{return await g(),a=(await A(r,c))[ra]?.[l]??"null",Q(K(a));var a}),a=>$(async()=>{await g(),await T(r,c,{[ra]:{[l]:V(a()??null)}},!0,!0)}),e,n,s,o,{[u]:()=>d,destroy:async()=>(await p.stopAutoPersisting(),i(),p)},0,d);return p},Za=(a,t,e,n,s,i,o,[r,c,[l,w,d]],u,E,N,g,A,T,$,O)=>{const[R,m,v,C]=Ka(t,u,E,s,A,T,$,O),I=(a,t)=>p(na(c,async([e,n,s,i,o],r)=>{t&&!(r in a)||await v(e,n,a[r],s,i,t,o)})),S=async(a,t)=>w?await v(d,ca,{[ra]:a},!0,!0,t):null,_=Ja(a,()=>C(async()=>{await R();const a=await(async()=>W(L(await p(na(r,async([a,t,e],n)=>[a,await m(n,t,e)])),a=>!z(a[1]))))(),t=await(async()=>l?(await m(d,ca))[ra]:{})();return z(a)&&y(t)?void 0:[a,t]}),(a,t)=>C(async()=>{if(await R(),y(t)){const[t,e]=a();await I(t),await S(e)}else await I(t[0],!0),await S(t[1],!0)}),e,n,s,o,{[g]:()=>N,destroy:async()=>(await _.stopAutoPersisting(),i(),_)},0,N);return _},at=/^([cd]:)(.+)/,tt=(a,n,s,r,c,l,w,y,d,u,g="getDb")=>{const T=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,l),[$,,O,R]=(a=>{const e=(a=>B(Ha,N(a)?{[ha]:a}:a??{}))(a),n=e[Fa];if(e.mode==Da){const a=e[ha]??t;return[1,n,[a,e[Pa]??ca,e[Ma]??fa],Sa(a)]}const{tables:{load:s={},save:o={}}={},values:r={}}=e,c=A(k(B(Xa,r)),0,q(Xa)),l=c[2],w=Sa(l),y=Sa(l),d=Ya(s,{[Ga]:null,[Ua]:ca,[Ba]:i},Ga,a=>b(y,a),a=>_a(w,a)),u=Ya(o,{[ja]:null,[Ua]:ca,[xa]:0,[Wa]:0,[Ba]:null},ja,(a,t)=>b(y,t),(a,t)=>_a(w,t));var E;return E=(a,t)=>t[4]??=ea(d,t[0])?.[2]??i,h(u,(a,t)=>E(0,a)),[0,n,[d,u,c],w]})(n),I=e+(a=>{let t=2166136261;return m(Z.encode(a),a=>{t^=a,t+=(t<<1)+(t<<4)+(t<<7)+(t<<8)+(t<<24)}),t>>>0})(V(O)),L=t+"_"+I,S=async(a,e,n="",s="")=>{const i=Ca(t,a,I);return await T($a+Oa+Ra+i+`()RETURNS ${n}trigger AS $$ ${s}BEGIN ${e}END;$$ LANGUAGE plpgsql;`),i},_=async(a,t,e,n)=>(await T($a+a+"TRIGGER"+t+e+"EXECUTE "+Ra+n+"()"),t),f=a=>`PERFORM pg_notify('${L}',${a});`,P=(a,t)=>$?i:2===t?P(a,0)+" OR "+P(a,1):o(ea(O[0],a)?.[2]??i,ma,0==t?"NEW":"OLD"),M=(a,e)=>p(C([da,ua,Ea],(n,s)=>_(Oa,Ca(t,"d",I,a,n),`AFTER ${n} ON${va(a)}FOR EACH ROW WHEN(${P(a,s)})`,e)));return($?Qa:Za)(a,T,async a=>{const e=await S("c",`FOR row IN SELECT object_identity FROM pg_event_trigger_ddl_commands()${wa} command_tag='${pa}' LOOP ${f("'c:'||SPLIT_PART(row.object_identity,'.',2)")}END LOOP;`,"event_","DECLARE row record;");await _("EVENT ",Ca(t,"c",I),`ON ddl_command_end WHEN TAG IN('${pa}')`,e);const n=await S("d",f("'d:'||TG_TABLE_NAME")+"RETURN NULL;");return await p(C(D(R),async a=>(await T(pa+` IF NOT EXISTS${va(a)}("_id"text PRIMARY KEY)`),await M(a,n)))),[await r(L,t=>{return E((e=t,s=at,e?.match(s)),async([,t,e])=>{b(R,e)&&("c:"==t&&await M(e,n),a())});var e,s}),[e,n]]},async([a,t])=>{c(a),await T(`DROP FUNCTION IF EXISTS${v(t,",")}CASCADE`)},w,y,d,O,D(R),async(a,t)=>await a(la+` table_name tn,column_name cn FROM information_schema.columns ${wa} table_schema='public'AND table_name IN(${Ia(t)})`,t),u,g,"text",void 0,a=>J(a),a=>K(a))},et=async(a,t,e,n,s)=>tt(a,e,async(a,e=[])=>(await t.query(a,e)).rows,(a,e)=>t.listen(a,e),a=>R(a,s),n,s,$,3,t,"getPglite");export{et as createPglitePersister};
|
|
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=a=>(t,e,n)=>a(t)?n?.():e(t),l=globalThis,w=a=>null==a,y=a=>void 0===a,u=a=>null===a,d=c(w),E=c(y),N=t=>a(t)==s,g=a=>Array.isArray(a),A=(a,t,e)=>a.slice(t,e),T=a=>a.length,$=async a=>o.all(a),p=a=>{throw Error(a)},O=async(a,t,e)=>{try{return await a()}catch(a){t?.(a)}},R=(a,t)=>a.forEach(t),m=(a,t="")=>a.join(t),v=(a,t)=>a.map(t),C=a=>0==T(a),S=(a,t)=>a.filter(t),I=(a,...t)=>a.push(...t),L=a=>a.shift(),_=(a,t)=>a?.has(t)??!1,b=a=>y(a)||0==(a=>a?.size??0)(a),f=a=>[...a?.values()??[]],D=(a,t)=>a?.forEach(t),h=(a,t)=>a?.delete(t),P=Object,
|
|
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=a=>null==a,y=a=>void 0===a,u=a=>null===a,d=c(w),E=c(y),N=t=>a(t)==s,g=a=>Array.isArray(a),A=(a,t,e)=>a.slice(t,e),T=a=>a.length,$=async a=>o.all(a),p=a=>{throw Error(a)},O=async(a,t,e)=>{try{return await a()}catch(a){t?.(a)}},R=(a,t)=>a.forEach(t),m=(a,t="")=>a.join(t),v=(a,t)=>a.map(t),C=a=>0==T(a),S=(a,t)=>a.filter(t),I=(a,...t)=>a.push(...t),L=a=>a.shift(),_=(a,t)=>a?.has(t)??!1,b=a=>y(a)||0==(a=>a?.size??0)(a),f=a=>[...a?.values()??[]],D=(a,t)=>a?.forEach(t),h=(a,t)=>a?.delete(t),P=Object,M=a=>P.getPrototypeOf(a),F=P.entries,U=a=>!w(a)&&d(M(a),a=>a==P.prototype||w(M(a)),()=>!0),G=P.keys,j=P.freeze,x=(a=[])=>P.fromEntries(a),W=(...a)=>P.assign({},...a),B=(a,t)=>(delete a[t],a),H=(a,t)=>v(F(a),([a,e])=>t(e,a)),X=(a,t)=>x(H(a,(a,e)=>[e,t(a,e)])),Y=a=>P.values(a),k=a=>T(G(a)),q=a=>U(a)&&0==k(a),z=JSON.stringify,J=JSON.parse,K=a=>z(a,(a,t)=>y(t)?"":t),V=a=>""===a?void 0:g(a)?v(a,V):U(a)?X(a,V):a,Q=new l.TextEncoder,Z=Map,aa=a=>new Z(a),ta=(a,t)=>a?.get(t),ea=(a,t)=>v([...a?.entries()??[]],([a,e])=>t(e,a)),na=(a,t,e)=>y(e)?(h(a,t),a):a?.set(t,e),sa=(a,t,e,n)=>(_(a,t)?n?.(ta(a,t)):na(a,t,e()),ta(a,t)),ia=(a,t,e,n,s=0)=>E((e?sa:ta)(a,t[s],s>T(t)-2?e:aa),i=>{if(s>T(t)-2)return n?.(i)&&na(a,t[s]),i;const r=ia(i,t,e,n,s+1);return b(i)&&na(a,t[s]),r}),ra="_",oa="_id",ca="SELECT",la="WHERE",wa="TABLE",ya="INSERT",ua="DELETE",da="UPDATE",Ea="ALTER "+wa,Na="FROM",ga=ua+" "+Na,Aa=ca+"*"+Na,Ta="CREATE ",$a=Ta+wa,pa="OR REPLACE ",Oa="FUNCTION",Ra="$tableName",ma=a=>m(v(((a,t="",e)=>a.split(t,e))(a,"."),a=>`"${r(a,/"/g,'""')}"`),"."),va=(...a)=>ma(m(a,"_")),Ca=(a,t=[1])=>m(v(a,()=>"$"+t[0]++),n),Sa=(a,t=i)=>la+`(${r(t,Ra,ma(a))})`,Ia=a=>new Set(g(a)||y(a)?a:[a]),La=(a,t)=>a?.add(t),_a="ColumnName",ba="store",fa="json",Da=ba+"TableName",ha=ba+"Id"+_a,Pa=ba+_a,Ma="autoLoadIntervalSeconds",Fa="rowId"+_a,Ua="tableId",Ga="tableName",ja="deleteEmptyColumns",xa="deleteEmptyTable",Wa="condition",Ba={mode:fa,[Ma]:1},Ha={load:0,save:0,[Ga]:t+"_values"},Xa=(a,t,e,n,s)=>{const i=aa();return X(a,(a,r)=>{const o=A(Y(W(t,N(a)?{[e]:a}:a)),0,k(t));u(o[0])||n(r,o[0])||(s(r,o[0]),na(i,r,o))}),i},Ya=/^\d+$/,ka=aa(),qa=aa(),za=(a,t,n,s,i,r,o,c={},l=0,w=[])=>{let d,N,A,$=0,m=0,v=0;sa(ka,w,()=>0),sa(qa,w,()=>[]);const C=aa(),[S,_,f,P,M]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!q(a)||!q(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!q(a)||!q(t),t.setContent]:p("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?L(a):null)??e+t++,t=>{Ya.test(t)&&T(a)<1e3&&I(a,t)}]})(),s=aa();return[(n,i,r,o=[],c=()=>[])=>{a??=Z;const l=t(1);return na(s,l,[n,i,r,o,c]),La(ia(i,r??[e],Ia),l),l},(t,n,...i)=>R(((a,t=[e])=>{const n=[],s=(a,e)=>e==T(t)?I(n,a):u(t[e])?D(a,a=>s(a,e+1)):R([t[e],null],t=>s(ta(a,t),e+1));return s(a,0),n})(t,n),t=>D(t,t=>ta(s,t)[0](a,...n??[],...i))),a=>E(ta(s,a),([,t,i])=>(ia(t,i??[e],void 0,t=>(h(t,a),b(t)?1:0)),na(s,a),n(a),i)),t=>E(ta(s,t),([t,,e=[],n,s])=>{const i=(...r)=>{const o=T(r);o==T(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,U(C,void 0,$))},W=t=>{(S&&g(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},B=async()=>{K()&&a.hadMutated?.()&&await k()},H=async a=>(2!=$&&(x(1),m++,await Q(async()=>{await O(async()=>{const e=await t();g(e)?W(e):a?M(a):p("Content is not an array: "+e)},()=>{a&&M(a)}),x(0),await B()})),Z),X=async a=>(Y(),await H(a),await O(async()=>N=await s(async(a,t)=>{t||a?2!=$&&(x(1),m++,W(t??a),x(0),await B()):await H()}),r),Z),Y=async()=>(N&&(await O(()=>i(N),r),N=void 0),Z),k=async a=>(1!=$&&(x(2),v++,await Q(async()=>{await O(()=>n(_,a),r),x(0)})),Z),z=async()=>(J(),await k(),A=a.addDidFinishTransactionListener(()=>{const a=f();P(a)&&k(a)}),Z),J=async()=>(A&&(a.delListener(A),A=void 0),Z),K=()=>!y(A),V=async(a=!1)=>{const[t,e]=a?[J,Y]:[Y,J];return await t(),await e(),Z},Q=async(...a)=>(I(ta(qa,w),...a),await(async()=>{if(!ta(ka,w)){for(na(ka,w,1);!y(d=L(ta(qa,w)));)await O(d,r);na(ka,w,0)}})(),Z),Z={load:H,startAutoLoad:X,stopAutoLoad:Y,isAutoLoading:()=>!y(N),save:k,startAutoSave:z,stopAutoSave:J,isAutoSaving:K,startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[z,X]:[X,z];return await e(a),await n(a),Z},stopAutoPersisting:V,getStatus:()=>$,addStatusListener:a=>F(a,C),delListener:t=>(G(t),a),schedule:Q,getStore:()=>a,destroy:()=>(ta(qa,w).splice(0,void 0),V()),getStats:()=>({loads:m,saves:v}),...c};return j(Z)},Ja=(a,t,e,s,r,o=Ka,c,l)=>{const w=aa();return[async()=>{w.clear(),v(await e(a,t),({tn:a,cn:t})=>La(sa(w,a,Ia),t))},async(t,e,n)=>((a,t)=>_(ta(w,a),t))(t,e)?x(S(v(await a(Aa+ma(t)+Sa(t,n)),a=>[a[e],l?X(B(a,e),l):B(a,e)]),([a,t])=>!y(a)&&!q(t))):{},async(t,e,s,l,u,d=!1,E=i)=>{const N=Ia();X(s??{},a=>v(G(a??{}),a=>La(N,a)));const g=f(N);if(!d&&u&&E==i&&C(g)&&_(w,t))return await a("DROP "+wa+ma(t)),void na(w,t);const A=ta(w,t),T=Ia(f(A));if(C(g)||(_(w,t)?await $(v([e,...g],async(n,s)=>{h(T,n)||(await a(Ea+ma(t)+"ADD"+ma(n)+r),0==s&&await a("CREATE UNIQUE INDEX pk ON "+ma(t)+`(${ma(e)})`),La(A,n))})):(await a($a+ma(t)+`(${ma(e)}${r} PRIMARY KEY${m(v(g,a=>n+ma(a)+r))});`),na(w,t,Ia([e,...g])))),await $([...!d&&l?v(f(T),async n=>{n!=e&&(await a(Ea+ma(t)+"DROP"+ma(n)),h(A,n))}):[]]),d)y(s)?await a(ga+ma(t)+Sa(t,E)):await $(H(s,async(n,s)=>{y(n)?await a(ga+ma(t)+Sa(t,E)+`AND(${ma(e)}=$1)`,[s]):C(g)||await o(a,t,e,G(n),{[s]:c?v(Y(n),c):Y(n)},A)}));else if(C(g))_(w,t)&&await a(ga+ma(t)+Sa(t,E));else{const n=S(f(ta(w,t)),a=>a!=e),i={},r=[];X(s??{},(a,t)=>{i[t]=v(n,t=>c?c(a?.[t]):a?.[t]),I(r,t)}),await o(a,t,e,n,i),await a(ga+ma(t)+Sa(t,E)+`AND${ma(e)}NOT IN(${Ca(r)})`,r)}},async t=>{let e;return await a("BEGIN"),await O(async()=>e=await t(),s),await a("END"),e}]},Ka=async(a,t,e,s,i)=>{const r=[1];await a(ya+" INTO"+ma(t)+"("+((...a)=>m(v(a,ma),n))(e,...s)+")VALUES"+m(H(i,a=>"($"+r[0]+++","+Ca(a,r)+")"),n)+"ON CONFLICT("+ma(e)+`)DO ${da} SET`+m(v(s,a=>ma(a)+"=excluded."+ma(a)),n),H(i,(a,t)=>[t,...v(a,a=>a??null)]).flat())},Va=(a,t,e,n,s,i,r,[o,c,l],w,y,u,d,E,N)=>{const[g,A,T,$]=Ja(t,w,y,s,E,N),p=za(a,()=>$(async()=>{return await g(),a=(await A(o,c))[ra]?.[l]??"null",V(J(a));var a}),a=>$(async()=>{await g(),await T(o,c,{[ra]:{[l]:K(a()??null)}},!0,!0)}),e,n,s,r,{[d]:()=>u,destroy:async()=>(await p.stopAutoPersisting(),i(),p)},0,u);return p},Qa=(a,t,e,n,s,i,r,[o,c,[l,w,u]],d,E,N,g,A,T,p,O)=>{const[R,m,v,C]=Ja(t,d,E,s,A,T,p,O),I=(a,t)=>$(ea(c,async([e,n,s,i,r],o)=>{t&&!(o in a)||await v(e,n,a[o],s,i,t,r)})),L=async(a,t)=>w?await v(u,oa,{[ra]:a},!0,!0,t):null,_=za(a,()=>C(async()=>{await R();const a=await(async()=>x(S(await $(ea(o,async([a,t,e],n)=>[a,await m(n,t,e)])),a=>!q(a[1]))))(),t=await(async()=>l?(await m(u,oa))[ra]:{})();return q(a)&&y(t)?void 0:[a,t]}),(a,t)=>C(async()=>{if(await R(),y(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,r,{[g]:()=>N,destroy:async()=>(await _.stopAutoPersisting(),i(),_)},0,N);return _},Za=/^([cd]:)(.+)/,at=(a,n,s,o,c,l,w,y,u,d,g="getDb")=>{const T=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,l),[p,,O,C]=(a=>{const e=(a=>W(Ba,N(a)?{[Da]:a}:a??{}))(a),n=e[Ma];if(e.mode==fa){const a=e[Da]??t;return[1,n,[a,e[ha]??oa,e[Pa]??ba],Ia(a)]}const{tables:{load:s={},save:r={}}={},values:o={}}=e,c=A(Y(W(Ha,o)),0,k(Ha)),l=c[2],w=Ia(l),y=Ia(l),u=Xa(s,{[Ua]:null,[Fa]:oa,[Wa]:i},Ua,a=>_(y,a),a=>La(w,a)),d=Xa(r,{[Ga]:null,[Fa]:oa,[ja]:0,[xa]:0,[Wa]:null},Ga,(a,t)=>_(y,t),(a,t)=>La(w,t));var E;return E=(a,t)=>t[4]??=ta(u,t[0])?.[2]??i,D(d,(a,t)=>E(0,a)),[0,n,[u,d,c],w]})(n),S=e+(a=>{let t=2166136261;return R(Q.encode(a),a=>{t^=a,t+=(t<<1)+(t<<4)+(t<<7)+(t<<8)+(t<<24)}),t>>>0})(K(O)),I=t+"_"+S,L=async(a,e,n="",s="")=>{const i=va(t,a,S);return await T(Ta+pa+Oa+i+`()RETURNS ${n}trigger AS $$ ${s}BEGIN ${e}END;$$ LANGUAGE plpgsql;`),i},b=async(a,t,e,n)=>(await T(Ta+a+"TRIGGER"+t+e+"EXECUTE "+Oa+n+"()"),t),h=a=>`PERFORM pg_notify('${I}',${a});`,P=(a,t)=>p?i:2===t?P(a,0)+" OR "+P(a,1):r(ta(O[0],a)?.[2]??i,Ra,0==t?"NEW":"OLD"),M=(a,e)=>$(v([ya,ua,da],(n,s)=>b(pa,va(t,"d",S,a,n),`AFTER ${n} ON${ma(a)}FOR EACH ROW WHEN(${P(a,s)})`,e)));return(p?Va:Qa)(a,T,async a=>{const e=await L("c",`FOR row IN SELECT object_identity FROM pg_event_trigger_ddl_commands()${la} command_tag='${$a}' LOOP ${h("'c:'||SPLIT_PART(row.object_identity,'.',2)")}END LOOP;`,"event_","DECLARE row record;");await b("EVENT ",va(t,"c",S),`ON ddl_command_end WHEN TAG IN('${$a}')`,e);const n=await L("d",h("'d:'||TG_TABLE_NAME")+"RETURN NULL;");return await $(v(f(C),async a=>(await T($a+` IF NOT EXISTS${ma(a)}("_id"text PRIMARY KEY)`),await M(a,n)))),[await o(I,t=>{return E((e=t,s=Za,e?.match(s)),async([,t,e])=>{_(C,e)&&("c:"==t&&await M(e,n),a())});var e,s}),[e,n]]},async([a,t])=>{c(a),await T(`DROP FUNCTION IF EXISTS${m(t,",")}CASCADE`)},w,y,u,O,f(C),async(a,t)=>await a(ca+` table_name tn,column_name cn FROM information_schema.columns ${la} table_schema='public'AND table_name IN(${Ca(t)})`,t),d,g,"text",void 0,a=>z(a),a=>J(a))},tt=async(a,t,e,n,s)=>{const i=await(t.reserve?.());return at(a,e,i?.unsafe,async(a,e)=>t.listen(a,e),a=>O(a.unlisten,s),n,s,()=>i?.release?.(),3,t,"getSql")};export{tt as createPostgresPersister};
|
|
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=a=>(t,e,n)=>a(t)?n?.():e(t),l=globalThis,w=a=>null==a,y=a=>void 0===a,u=a=>null===a,d=c(w),E=c(y),N=t=>a(t)==s,g=a=>Array.isArray(a),A=(a,t,e)=>a.slice(t,e),T=a=>a.length,$=async a=>o.all(a),p=a=>{throw Error(a)},O=async(a,t,e)=>{try{return await a()}catch(a){t?.(a)}},R=(a,t)=>a.forEach(t),m=(a,t="")=>a.join(t),v=(a,t)=>a.map(t),C=a=>0==T(a),S=(a,t)=>a.filter(t),I=(a,...t)=>a.push(...t),L=a=>a.shift(),_=(a,t)=>a?.has(t)??!1,b=a=>y(a)||0==(a=>a?.size??0)(a),f=a=>[...a?.values()??[]],D=(a,t)=>a?.forEach(t),h=(a,t)=>a?.delete(t),P=Object,
|
|
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=a=>null==a,y=a=>void 0===a,u=a=>null===a,d=c(w),E=c(y),N=t=>a(t)==s,g=a=>Array.isArray(a),A=(a,t,e)=>a.slice(t,e),T=a=>a.length,$=async a=>o.all(a),p=a=>{throw Error(a)},O=async(a,t,e)=>{try{return await a()}catch(a){t?.(a)}},R=(a,t)=>a.forEach(t),m=(a,t="")=>a.join(t),v=(a,t)=>a.map(t),C=a=>0==T(a),S=(a,t)=>a.filter(t),I=(a,...t)=>a.push(...t),L=a=>a.shift(),_=(a,t)=>a?.has(t)??!1,b=a=>y(a)||0==(a=>a?.size??0)(a),f=a=>[...a?.values()??[]],D=(a,t)=>a?.forEach(t),h=(a,t)=>a?.delete(t),P=Object,M=a=>P.getPrototypeOf(a),F=P.entries,U=a=>!w(a)&&d(M(a),a=>a==P.prototype||w(M(a)),()=>!0),G=P.keys,j=P.freeze,x=(a=[])=>P.fromEntries(a),W=(...a)=>P.assign({},...a),B=(a,t)=>(delete a[t],a),H=(a,t)=>v(F(a),([a,e])=>t(e,a)),X=(a,t)=>x(H(a,(a,e)=>[e,t(a,e)])),Y=a=>P.values(a),k=a=>T(G(a)),q=a=>U(a)&&0==k(a),z=JSON.stringify,J=JSON.parse,K=a=>z(a,(a,t)=>y(t)?"":t),V=a=>""===a?void 0:g(a)?v(a,V):U(a)?X(a,V):a,Q=new l.TextEncoder,Z=Map,aa=a=>new Z(a),ta=(a,t)=>a?.get(t),ea=(a,t)=>v([...a?.entries()??[]],([a,e])=>t(e,a)),na=(a,t,e)=>y(e)?(h(a,t),a):a?.set(t,e),sa=(a,t,e,n)=>(_(a,t)?n?.(ta(a,t)):na(a,t,e()),ta(a,t)),ia=(a,t,e,n,s=0)=>E((e?sa:ta)(a,t[s],s>T(t)-2?e:aa),i=>{if(s>T(t)-2)return n?.(i)&&na(a,t[s]),i;const r=ia(i,t,e,n,s+1);return b(i)&&na(a,t[s]),r}),ra="_",oa="_id",ca="SELECT",la="WHERE",wa="TABLE",ya="INSERT",ua="DELETE",da="UPDATE",Ea="ALTER "+wa,Na="FROM",ga=ua+" "+Na,Aa=ca+"*"+Na,Ta="CREATE ",$a=Ta+wa,pa="OR REPLACE ",Oa="FUNCTION",Ra="$tableName",ma=a=>m(v(((a,t="",e)=>a.split(t,e))(a,"."),a=>`"${r(a,/"/g,'""')}"`),"."),va=(...a)=>ma(m(a,"_")),Ca=(a,t=[1])=>m(v(a,()=>"$"+t[0]++),n),Sa=(a,t=i)=>la+`(${r(t,Ra,ma(a))})`,Ia=a=>new Set(g(a)||y(a)?a:[a]),La=(a,t)=>a?.add(t),_a="ColumnName",ba="store",fa="json",Da=ba+"TableName",ha=ba+"Id"+_a,Pa=ba+_a,Ma="autoLoadIntervalSeconds",Fa="rowId"+_a,Ua="tableId",Ga="tableName",ja="deleteEmptyColumns",xa="deleteEmptyTable",Wa="condition",Ba={mode:fa,[Ma]:1},Ha={load:0,save:0,[Ga]:t+"_values"},Xa=(a,t,e,n,s)=>{const i=aa();return X(a,(a,r)=>{const o=A(Y(W(t,N(a)?{[e]:a}:a)),0,k(t));u(o[0])||n(r,o[0])||(s(r,o[0]),na(i,r,o))}),i},Ya=/^\d+$/,ka=aa(),qa=aa(),za=(a,t,n,s,i,r,o,c={},l=0,w=[])=>{let d,N,A,$=0,m=0,v=0;sa(ka,w,()=>0),sa(qa,w,()=>[]);const C=aa(),[S,_,f,P,M]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!q(a)||!q(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!q(a)||!q(t),t.setContent]:p("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?L(a):null)??e+t++,t=>{Ya.test(t)&&T(a)<1e3&&I(a,t)}]})(),s=aa();return[(n,i,r,o=[],c=()=>[])=>{a??=Z;const l=t(1);return na(s,l,[n,i,r,o,c]),La(ia(i,r??[e],Ia),l),l},(t,n,...i)=>R(((a,t=[e])=>{const n=[],s=(a,e)=>e==T(t)?I(n,a):u(t[e])?D(a,a=>s(a,e+1)):R([t[e],null],t=>s(ta(a,t),e+1));return s(a,0),n})(t,n),t=>D(t,t=>ta(s,t)[0](a,...n??[],...i))),a=>E(ta(s,a),([,t,i])=>(ia(t,i??[e],void 0,t=>(h(t,a),b(t)?1:0)),na(s,a),n(a),i)),t=>E(ta(s,t),([t,,e=[],n,s])=>{const i=(...r)=>{const o=T(r);o==T(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,U(C,void 0,$))},W=t=>{(S&&g(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},B=async()=>{K()&&a.hadMutated?.()&&await k()},H=async a=>(2!=$&&(x(1),m++,await Q(async()=>{await O(async()=>{const e=await t();g(e)?W(e):a?M(a):p("Content is not an array: "+e)},()=>{a&&M(a)}),x(0),await B()})),Z),X=async a=>(Y(),await H(a),await O(async()=>N=await s(async(a,t)=>{t||a?2!=$&&(x(1),m++,W(t??a),x(0),await B()):await H()}),r),Z),Y=async()=>(N&&(await O(()=>i(N),r),N=void 0),Z),k=async a=>(1!=$&&(x(2),v++,await Q(async()=>{await O(()=>n(_,a),r),x(0)})),Z),z=async()=>(J(),await k(),A=a.addDidFinishTransactionListener(()=>{const a=f();P(a)&&k(a)}),Z),J=async()=>(A&&(a.delListener(A),A=void 0),Z),K=()=>!y(A),V=async(a=!1)=>{const[t,e]=a?[J,Y]:[Y,J];return await t(),await e(),Z},Q=async(...a)=>(I(ta(qa,w),...a),await(async()=>{if(!ta(ka,w)){for(na(ka,w,1);!y(d=L(ta(qa,w)));)await O(d,r);na(ka,w,0)}})(),Z),Z={load:H,startAutoLoad:X,stopAutoLoad:Y,isAutoLoading:()=>!y(N),save:k,startAutoSave:z,stopAutoSave:J,isAutoSaving:K,startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[z,X]:[X,z];return await e(a),await n(a),Z},stopAutoPersisting:V,getStatus:()=>$,addStatusListener:a=>F(a,C),delListener:t=>(G(t),a),schedule:Q,getStore:()=>a,destroy:()=>(ta(qa,w).splice(0,void 0),V()),getStats:()=>({loads:m,saves:v}),...c};return j(Z)},Ja=(a,t,e,s,r,o=Ka,c,l)=>{const w=aa();return[async()=>{w.clear(),v(await e(a,t),({tn:a,cn:t})=>La(sa(w,a,Ia),t))},async(t,e,n)=>((a,t)=>_(ta(w,a),t))(t,e)?x(S(v(await a(Aa+ma(t)+Sa(t,n)),a=>[a[e],l?X(B(a,e),l):B(a,e)]),([a,t])=>!y(a)&&!q(t))):{},async(t,e,s,l,u,d=!1,E=i)=>{const N=Ia();X(s??{},a=>v(G(a??{}),a=>La(N,a)));const g=f(N);if(!d&&u&&E==i&&C(g)&&_(w,t))return await a("DROP "+wa+ma(t)),void na(w,t);const A=ta(w,t),T=Ia(f(A));if(C(g)||(_(w,t)?await $(v([e,...g],async(n,s)=>{h(T,n)||(await a(Ea+ma(t)+"ADD"+ma(n)+r),0==s&&await a("CREATE UNIQUE INDEX pk ON "+ma(t)+`(${ma(e)})`),La(A,n))})):(await a($a+ma(t)+`(${ma(e)}${r} PRIMARY KEY${m(v(g,a=>n+ma(a)+r))});`),na(w,t,Ia([e,...g])))),await $([...!d&&l?v(f(T),async n=>{n!=e&&(await a(Ea+ma(t)+"DROP"+ma(n)),h(A,n))}):[]]),d)y(s)?await a(ga+ma(t)+Sa(t,E)):await $(H(s,async(n,s)=>{y(n)?await a(ga+ma(t)+Sa(t,E)+`AND(${ma(e)}=$1)`,[s]):C(g)||await o(a,t,e,G(n),{[s]:c?v(Y(n),c):Y(n)},A)}));else if(C(g))_(w,t)&&await a(ga+ma(t)+Sa(t,E));else{const n=S(f(ta(w,t)),a=>a!=e),i={},r=[];X(s??{},(a,t)=>{i[t]=v(n,t=>c?c(a?.[t]):a?.[t]),I(r,t)}),await o(a,t,e,n,i),await a(ga+ma(t)+Sa(t,E)+`AND${ma(e)}NOT IN(${Ca(r)})`,r)}},async t=>{let e;return await a("BEGIN"),await O(async()=>e=await t(),s),await a("END"),e}]},Ka=async(a,t,e,s,i)=>{const r=[1];await a(ya+" INTO"+ma(t)+"("+((...a)=>m(v(a,ma),n))(e,...s)+")VALUES"+m(H(i,a=>"($"+r[0]+++","+Ca(a,r)+")"),n)+"ON CONFLICT("+ma(e)+`)DO ${da} SET`+m(v(s,a=>ma(a)+"=excluded."+ma(a)),n),H(i,(a,t)=>[t,...v(a,a=>a??null)]).flat())},Va=(a,t,e,n,s,i,r,[o,c,l],w,y,u,d,E,N)=>{const[g,A,T,$]=Ja(t,w,y,s,E,N),p=za(a,()=>$(async()=>{return await g(),a=(await A(o,c))[ra]?.[l]??"null",V(J(a));var a}),a=>$(async()=>{await g(),await T(o,c,{[ra]:{[l]:K(a()??null)}},!0,!0)}),e,n,s,r,{[d]:()=>u,destroy:async()=>(await p.stopAutoPersisting(),i(),p)},0,u);return p},Qa=(a,t,e,n,s,i,r,[o,c,[l,w,u]],d,E,N,g,A,T,p,O)=>{const[R,m,v,C]=Ja(t,d,E,s,A,T,p,O),I=(a,t)=>$(ea(c,async([e,n,s,i,r],o)=>{t&&!(o in a)||await v(e,n,a[o],s,i,t,r)})),L=async(a,t)=>w?await v(u,oa,{[ra]:a},!0,!0,t):null,_=za(a,()=>C(async()=>{await R();const a=await(async()=>x(S(await $(ea(o,async([a,t,e],n)=>[a,await m(n,t,e)])),a=>!q(a[1]))))(),t=await(async()=>l?(await m(u,oa))[ra]:{})();return q(a)&&y(t)?void 0:[a,t]}),(a,t)=>C(async()=>{if(await R(),y(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,r,{[g]:()=>N,destroy:async()=>(await _.stopAutoPersisting(),i(),_)},0,N);return _},Za=/^([cd]:)(.+)/,at=(a,n,s,o,c,l,w,y,u,d,g="getDb")=>{const T=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,l),[p,,O,C]=(a=>{const e=(a=>W(Ba,N(a)?{[Da]:a}:a??{}))(a),n=e[Ma];if(e.mode==fa){const a=e[Da]??t;return[1,n,[a,e[ha]??oa,e[Pa]??ba],Ia(a)]}const{tables:{load:s={},save:r={}}={},values:o={}}=e,c=A(Y(W(Ha,o)),0,k(Ha)),l=c[2],w=Ia(l),y=Ia(l),u=Xa(s,{[Ua]:null,[Fa]:oa,[Wa]:i},Ua,a=>_(y,a),a=>La(w,a)),d=Xa(r,{[Ga]:null,[Fa]:oa,[ja]:0,[xa]:0,[Wa]:null},Ga,(a,t)=>_(y,t),(a,t)=>La(w,t));var E;return E=(a,t)=>t[4]??=ta(u,t[0])?.[2]??i,D(d,(a,t)=>E(0,a)),[0,n,[u,d,c],w]})(n),S=e+(a=>{let t=2166136261;return R(Q.encode(a),a=>{t^=a,t+=(t<<1)+(t<<4)+(t<<7)+(t<<8)+(t<<24)}),t>>>0})(K(O)),I=t+"_"+S,L=async(a,e,n="",s="")=>{const i=va(t,a,S);return await T(Ta+pa+Oa+i+`()RETURNS ${n}trigger AS $$ ${s}BEGIN ${e}END;$$ LANGUAGE plpgsql;`),i},b=async(a,t,e,n)=>(await T(Ta+a+"TRIGGER"+t+e+"EXECUTE "+Oa+n+"()"),t),h=a=>`PERFORM pg_notify('${I}',${a});`,P=(a,t)=>p?i:2===t?P(a,0)+" OR "+P(a,1):r(ta(O[0],a)?.[2]??i,Ra,0==t?"NEW":"OLD"),M=(a,e)=>$(v([ya,ua,da],(n,s)=>b(pa,va(t,"d",S,a,n),`AFTER ${n} ON${ma(a)}FOR EACH ROW WHEN(${P(a,s)})`,e)));return(p?Va:Qa)(a,T,async a=>{const e=await L("c",`FOR row IN SELECT object_identity FROM pg_event_trigger_ddl_commands()${la} command_tag='${$a}' LOOP ${h("'c:'||SPLIT_PART(row.object_identity,'.',2)")}END LOOP;`,"event_","DECLARE row record;");await b("EVENT ",va(t,"c",S),`ON ddl_command_end WHEN TAG IN('${$a}')`,e);const n=await L("d",h("'d:'||TG_TABLE_NAME")+"RETURN NULL;");return await $(v(f(C),async a=>(await T($a+` IF NOT EXISTS${ma(a)}("_id"text PRIMARY KEY)`),await M(a,n)))),[await o(I,t=>{return E((e=t,s=Za,e?.match(s)),async([,t,e])=>{_(C,e)&&("c:"==t&&await M(e,n),a())});var e,s}),[e,n]]},async([a,t])=>{c(a),await T(`DROP FUNCTION IF EXISTS${m(t,",")}CASCADE`)},w,y,u,O,f(C),async(a,t)=>await a(ca+` table_name tn,column_name cn FROM information_schema.columns ${la} table_schema='public'AND table_name IN(${Ca(t)})`,t),d,g,"text",void 0,a=>z(a),a=>J(a))},tt=async(a,t,e,n,s)=>{const i=await(t.reserve?.());return at(a,e,i?.unsafe,async(a,e)=>t.listen(a,e),a=>O(a.unlisten,s),n,s,()=>i?.release?.(),3,t,"getSql")};export{tt as createPostgresPersister};
|
|
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=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),g=c(y),E=t=>a(t)==s,v=a=>Array.isArray(a),p=(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)}},
|
|
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),g=c(y),E=t=>a(t)==s,v=a=>Array.isArray(a),p=(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),b=a=>0==A(a),O=(a,t)=>a.filter(t),I=(a,...t)=>a.push(...t),S=a=>a.shift(),D=(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),_=Object,F=a=>_.getPrototypeOf(a),U=_.entries,j=a=>!w(a)&&d(F(a),a=>a==_.prototype||w(F(a)),()=>!0),x=_.keys,B=_.freeze,J=(a=[])=>_.fromEntries(a),Y=(...a)=>_.assign({},...a),k=(a,t)=>(delete a[t],a),z=(a,t)=>T(U(a),([a,e])=>t(e,a)),G=(a,t)=>J(z(a,(a,e)=>[e,t(a,e)])),H=a=>_.values(a),V=a=>A(x(a)),K=a=>j(a)&&0==V(a),Q=a=>new Set(v(a)||y(a)?a:[a]),W=(a,t)=>a?.add(t),X="_",q="_id",Z="SELECT",aa="WHERE",ta="TABLE",ea="INSERT",na="ALTER "+ta,sa="FROM",ia="DELETE "+sa,ra=Z+"*"+sa,oa="pragma_",ca="data_version",la="schema_version",wa="pragma_table_",ya="CREATE "+ta,ua=a=>C(T(((a,t="",e)=>a.split(t,e))(a,"."),a=>`"${r(a,/"/g,'""')}"`),"."),da=(...a)=>C(T(a,ua),n),ga=(a,t=[1])=>C(T(a,()=>"$"+t[0]++),n),Ea=(a,t=i)=>aa+`(${r(t,"$tableName",ua(a))})`,va=Map,pa=a=>new va(a),Aa=(a,t)=>a?.get(t),Na=(a,t)=>T([...a?.entries()??[]],([a,e])=>t(e,a)),ma=(a,t,e)=>y(e)?(M(a,t),a):a?.set(t,e),$a=(a,t,e,n)=>(D(a,t)?n?.(Aa(a,t)):ma(a,t,e()),Aa(a,t)),fa=(a,t,e,n,s=0)=>g((e?$a:Aa)(a,t[s],s>A(t)-2?e:pa),i=>{if(s>A(t)-2)return n?.(i)&&ma(a,t[s]),i;const r=fa(i,t,e,n,s+1);return L(i)&&ma(a,t[s]),r}),ha="ColumnName",Ca="store",Ta="json",ba=Ca+"TableName",Oa=Ca+"Id"+ha,Ia=Ca+ha,Sa="autoLoadIntervalSeconds",Da="rowId"+ha,La="tableId",Ra="tableName",Pa="deleteEmptyColumns",Ma="deleteEmptyTable",_a="condition",Fa={mode:Ta,[Sa]:1},Ua={load:0,save:0,[Ra]:t+"_values"},ja=(a,t,e,n,s)=>{const i=pa();return G(a,(a,r)=>{const o=p(H(Y(t,E(a)?{[e]:a}:a)),0,V(t));u(o[0])||n(r,o[0])||(s(r,o[0]),ma(i,r,o))}),i},xa=JSON.stringify,Ba=JSON.parse,Ja=a=>""===a?void 0:v(a)?T(a,Ja):j(a)?G(a,Ja):a,Ya=/^\d+$/,ka=pa(),za=pa(),Ga=(a,t,n,s,i,r,o,c={},l=0,w=[])=>{let d,E,p,N=0,m=0,C=0;$a(ka,w,()=>0),$a(za,w,()=>[]);const T=pa(),[b,O,D,R,_]=((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]:$("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?S(a):null)??e+t++,t=>{Ya.test(t)&&A(a)<1e3&&I(a,t)}]})(),s=pa();return[(n,i,r,o=[],c=()=>[])=>{a??=ta;const l=t(1);return ma(s,l,[n,i,r,o,c]),W(fa(i,r??[e],Q),l),l},(t,n,...i)=>h(((a,t=[e])=>{const n=[],s=(a,e)=>e==A(t)?I(n,a):u(t[e])?P(a,a=>s(a,e+1)):h([t[e],null],t=>s(Aa(a,t),e+1));return s(a,0),n})(t,n),t=>P(t,t=>Aa(s,t)[0](a,...n??[],...i))),a=>g(Aa(s,a),([,t,i])=>(fa(t,i??[e],void 0,t=>(M(t,a),L(t)?1:0)),ma(s,a),n(a),i)),t=>g(Aa(s,t),([t,,e=[],n,s])=>{const i=(...r)=>{const o=A(r);o==A(e)?t(a,...r,...s(r)):u(e[o])?h(n[o]?.(...r)??[],a=>i(...r,a)):i(...r,e[o])};i()})]})(),x=a=>{a!=N&&(N=a,U(T,void 0,N))},J=t=>{(b&&v(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},Y=async()=>{q()&&a.hadMutated?.()&&await H()},k=async a=>(2!=N&&(x(1),m++,await aa(async()=>{await f(async()=>{const e=await t();v(e)?J(e):a?_(a):$("Content is not an array: "+e)},()=>{a&&_(a)}),x(0),await Y()})),ta),z=async a=>(G(),await k(a),await f(async()=>E=await s(async(a,t)=>{t||a?2!=N&&(x(1),m++,J(t??a),x(0),await Y()):await k()}),r),ta),G=async()=>(E&&(await f(()=>i(E),r),E=void 0),ta),H=async a=>(1!=N&&(x(2),C++,await aa(async()=>{await f(()=>n(O,a),r),x(0)})),ta),V=async()=>(X(),await H(),p=a.addDidFinishTransactionListener(()=>{const a=D();R(a)&&H(a)}),ta),X=async()=>(p&&(a.delListener(p),p=void 0),ta),q=()=>!y(p),Z=async(a=!1)=>{const[t,e]=a?[X,G]:[G,X];return await t(),await e(),ta},aa=async(...a)=>(I(Aa(za,w),...a),await(async()=>{if(!Aa(ka,w)){for(ma(ka,w,1);!y(d=S(Aa(za,w)));)await f(d,r);ma(ka,w,0)}})(),ta),ta={load:k,startAutoLoad:z,stopAutoLoad:G,isAutoLoading:()=>!y(E),save:H,startAutoSave:V,stopAutoSave:X,isAutoSaving:q,startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[V,z]:[z,V];return await e(a),await n(a),ta},stopAutoPersisting:Z,getStatus:()=>N,addStatusListener:a=>F(a,T),delListener:t=>(j(t),a),schedule:aa,getStore:()=>a,destroy:()=>(Aa(za,w).splice(0,void 0),Z()),getStats:()=>({loads:m,saves:C}),...c};return B(ta)},Ha=(a,t,e,s,r,o=Va,c,l)=>{const w=pa();return[async()=>{w.clear(),T(await e(a,t),({tn:a,cn:t})=>W($a(w,a,Q),t))},async(t,e,n)=>((a,t)=>D(Aa(w,a),t))(t,e)?J(O(T(await a(ra+ua(t)+Ea(t,n)),a=>[a[e],l?G(k(a,e),l):k(a,e)]),([a,t])=>!y(a)&&!K(t))):{},async(t,e,s,l,u,d=!1,g=i)=>{const E=Q();G(s??{},a=>T(x(a??{}),a=>W(E,a)));const v=R(E);if(!d&&u&&g==i&&b(v)&&D(w,t))return await a("DROP "+ta+ua(t)),void ma(w,t);const p=Aa(w,t),A=Q(R(p));if(b(v)||(D(w,t)?await m(T([e,...v],async(n,s)=>{M(A,n)||(await a(na+ua(t)+"ADD"+ua(n)+r),0==s&&await a("CREATE UNIQUE INDEX pk ON "+ua(t)+`(${ua(e)})`),W(p,n))})):(await a(ya+ua(t)+`(${ua(e)}${r} PRIMARY KEY${C(T(v,a=>n+ua(a)+r))});`),ma(w,t,Q([e,...v])))),await m([...!d&&l?T(R(A),async n=>{n!=e&&(await a(na+ua(t)+"DROP"+ua(n)),M(p,n))}):[]]),d)y(s)?await a(ia+ua(t)+Ea(t,g)):await m(z(s,async(n,s)=>{y(n)?await a(ia+ua(t)+Ea(t,g)+`AND(${ua(e)}=$1)`,[s]):b(v)||await o(a,t,e,x(n),{[s]:c?T(H(n),c):H(n)},p)}));else if(b(v))D(w,t)&&await a(ia+ua(t)+Ea(t,g));else{const n=O(R(Aa(w,t)),a=>a!=e),i={},r=[];G(s??{},(a,t)=>{i[t]=T(n,t=>c?c(a?.[t]):a?.[t]),I(r,t)}),await o(a,t,e,n,i),await a(ia+ua(t)+Ea(t,g)+`AND${ua(e)}NOT IN(${ga(r)})`,r)}},async t=>{let e;return await a("BEGIN"),await f(async()=>e=await t(),s),await a("END"),e}]},Va=async(a,t,e,s,i)=>{const r=[1];await a(ea+" INTO"+ua(t)+"("+da(e,...s)+")VALUES"+C(z(i,a=>"($"+r[0]+++","+ga(a,r)+")"),n)+"ON CONFLICT("+ua(e)+")DO UPDATE SET"+C(T(s,a=>ua(a)+"=excluded."+ua(a)),n),z(i,(a,t)=>[t,...T(a,a=>a??null)]).flat())},Ka=(a,t,e,n,s,i,r,[o,c,l],w,u,d,g,E,v)=>{const[p,A,N,m]=Ha(t,w,u,s,E,v),$=Ga(a,()=>m(async()=>{return await p(),a=(await A(o,c))[X]?.[l]??"null",Ja(Ba(a));var a}),a=>m(async()=>{var t;await p(),await N(o,c,{[X]:{[l]:(t=a()??null,xa(t,(a,t)=>y(t)?"":t))}},!0,!0)}),e,n,s,r,{[g]:()=>d,destroy:async()=>(await $.stopAutoPersisting(),i(),$)},0,d);return $},Qa=(a,t,e,n,s,i,r,[o,c,[l,w,u]],d,g,E,v,p,A,N,$)=>{const[f,h,C,T]=Ha(t,d,g,s,p,A,N,$),b=(a,t)=>m(Na(c,async([e,n,s,i,r],o)=>{t&&!(o in a)||await C(e,n,a[o],s,i,t,r)})),I=async(a,t)=>w?await C(u,q,{[X]:a},!0,!0,t):null,S=Ga(a,()=>T(async()=>{await f();const a=await(async()=>J(O(await m(Na(o,async([a,t,e],n)=>[a,await h(n,t,e)])),a=>!K(a[1]))))(),t=await(async()=>l?(await h(u,q))[X]:{})();return K(a)&&y(t)?void 0:[a,t]}),(a,t)=>T(async()=>{if(await f(),y(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,{[v]:()=>E,destroy:async()=>(await S.stopAutoPersisting(),i(),S)},0,E);return S},Wa=(a,n,s,r,o,c,y,u,d,g,v="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,b,O]=(a=>{const e=(a=>Y(Fa,E(a)?{[ba]:a}:a??{}))(a),n=e[Sa];if(e.mode==Ta){const a=e[ba]??t;return[1,n,[a,e[Oa]??q,e[Ia]??Ca],Q(a)]}const{tables:{load:s={},save:r={}}={},values:o={}}=e,c=p(H(Y(Ua,o)),0,V(Ua)),l=c[2],w=Q(l),y=Q(l),u=ja(s,{[La]:null,[Da]:q,[_a]:i},La,a=>D(y,a),a=>W(w,a)),d=ja(r,{[Ra]:null,[Da]:q,[Pa]:0,[Ma]:0,[_a]:null},Ra,(a,t)=>D(y,t),(a,t)=>W(w,t));var g;return g=(a,t)=>t[4]??=Aa(u,t[0])?.[2]??i,P(d,(a,t)=>g(0,a)),[0,n,[u,d,c],w]})(n);return(C?Ka:Qa)(a,h,a=>{let t;const e=()=>t=setInterval(()=>f(async()=>{const[{d:t,s:e,c:n}]=await h(Z+` ${ca} d,${la} s,TOTAL_CHANGES() c FROM ${oa}${ca} JOIN ${oa}${la}`);t==N&&e==m&&n==$||(w(N)||a(),N=t,m=e,$=n)}),1e3*T),n=()=>{N=m=$=null,l(t)},s=r(t=>{O.has(t)&&(n(),a(),e())});return e(),()=>{n(),o(s)}},a=>a(),y,u,d,b,R(O),async(a,t)=>await a(Z+` t.name tn,c.name cn FROM ${wa}list()t,${wa}info(t.name)c ${aa} t.schema='main'AND t.type IN('table','view')AND t.name IN(${ga(t)})ORDER BY t.name,c.name`,t),g,v,e,A,a=>(a=>!0===a)(a)?1:(a=>!1===a)(a)?0:a,void 0)},Xa=(a,t,e,n,s)=>{let i;return Wa(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)i&&T(a.changedTables,i)})(),i=a,e},a=>{i=void 0,a.abort()},n,s,N,1,t,"getPowerSync",qa)},qa=async(a,t,e,s,i,r)=>{const o=[1],c=Q(s),l=r?O([...r],a=>a!=e&&!D(c,a)):[];if(!b(l)){const n=x(i),s=J(T(await a(Z+da(e,...l)+sa+ua(t)+aa+ua(e)+"IN("+ga(n)+")",n),a=>[a[e],a]));h(n,a=>I(i[a],...T(l,t=>s?.[a]?.[t]??null)))}await a(ea+" OR REPLACE INTO"+ua(t)+"("+da(e,...s,...l)+")VALUES"+C(z(i,a=>"($"+o[0]+++","+ga(a,o)+")"),n),z(i,(a,t)=>[t,...T(a,a=>a??null)]).flat())};export{Xa as createPowerSyncPersister};
|
|
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=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),g=c(y),E=t=>a(t)==s,v=a=>Array.isArray(a),p=(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)}},
|
|
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),g=c(y),E=t=>a(t)==s,v=a=>Array.isArray(a),p=(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),b=a=>0==A(a),O=(a,t)=>a.filter(t),I=(a,...t)=>a.push(...t),S=a=>a.shift(),D=(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),_=Object,F=a=>_.getPrototypeOf(a),U=_.entries,j=a=>!w(a)&&d(F(a),a=>a==_.prototype||w(F(a)),()=>!0),x=_.keys,B=_.freeze,J=(a=[])=>_.fromEntries(a),Y=(...a)=>_.assign({},...a),k=(a,t)=>(delete a[t],a),z=(a,t)=>T(U(a),([a,e])=>t(e,a)),G=(a,t)=>J(z(a,(a,e)=>[e,t(a,e)])),H=a=>_.values(a),V=a=>A(x(a)),K=a=>j(a)&&0==V(a),Q=a=>new Set(v(a)||y(a)?a:[a]),W=(a,t)=>a?.add(t),X="_",q="_id",Z="SELECT",aa="WHERE",ta="TABLE",ea="INSERT",na="ALTER "+ta,sa="FROM",ia="DELETE "+sa,ra=Z+"*"+sa,oa="pragma_",ca="data_version",la="schema_version",wa="pragma_table_",ya="CREATE "+ta,ua=a=>C(T(((a,t="",e)=>a.split(t,e))(a,"."),a=>`"${r(a,/"/g,'""')}"`),"."),da=(...a)=>C(T(a,ua),n),ga=(a,t=[1])=>C(T(a,()=>"$"+t[0]++),n),Ea=(a,t=i)=>aa+`(${r(t,"$tableName",ua(a))})`,va=Map,pa=a=>new va(a),Aa=(a,t)=>a?.get(t),Na=(a,t)=>T([...a?.entries()??[]],([a,e])=>t(e,a)),ma=(a,t,e)=>y(e)?(M(a,t),a):a?.set(t,e),$a=(a,t,e,n)=>(D(a,t)?n?.(Aa(a,t)):ma(a,t,e()),Aa(a,t)),fa=(a,t,e,n,s=0)=>g((e?$a:Aa)(a,t[s],s>A(t)-2?e:pa),i=>{if(s>A(t)-2)return n?.(i)&&ma(a,t[s]),i;const r=fa(i,t,e,n,s+1);return L(i)&&ma(a,t[s]),r}),ha="ColumnName",Ca="store",Ta="json",ba=Ca+"TableName",Oa=Ca+"Id"+ha,Ia=Ca+ha,Sa="autoLoadIntervalSeconds",Da="rowId"+ha,La="tableId",Ra="tableName",Pa="deleteEmptyColumns",Ma="deleteEmptyTable",_a="condition",Fa={mode:Ta,[Sa]:1},Ua={load:0,save:0,[Ra]:t+"_values"},ja=(a,t,e,n,s)=>{const i=pa();return G(a,(a,r)=>{const o=p(H(Y(t,E(a)?{[e]:a}:a)),0,V(t));u(o[0])||n(r,o[0])||(s(r,o[0]),ma(i,r,o))}),i},xa=JSON.stringify,Ba=JSON.parse,Ja=a=>""===a?void 0:v(a)?T(a,Ja):j(a)?G(a,Ja):a,Ya=/^\d+$/,ka=pa(),za=pa(),Ga=(a,t,n,s,i,r,o,c={},l=0,w=[])=>{let d,E,p,N=0,m=0,C=0;$a(ka,w,()=>0),$a(za,w,()=>[]);const T=pa(),[b,O,D,R,_]=((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]:$("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?S(a):null)??e+t++,t=>{Ya.test(t)&&A(a)<1e3&&I(a,t)}]})(),s=pa();return[(n,i,r,o=[],c=()=>[])=>{a??=ta;const l=t(1);return ma(s,l,[n,i,r,o,c]),W(fa(i,r??[e],Q),l),l},(t,n,...i)=>h(((a,t=[e])=>{const n=[],s=(a,e)=>e==A(t)?I(n,a):u(t[e])?P(a,a=>s(a,e+1)):h([t[e],null],t=>s(Aa(a,t),e+1));return s(a,0),n})(t,n),t=>P(t,t=>Aa(s,t)[0](a,...n??[],...i))),a=>g(Aa(s,a),([,t,i])=>(fa(t,i??[e],void 0,t=>(M(t,a),L(t)?1:0)),ma(s,a),n(a),i)),t=>g(Aa(s,t),([t,,e=[],n,s])=>{const i=(...r)=>{const o=A(r);o==A(e)?t(a,...r,...s(r)):u(e[o])?h(n[o]?.(...r)??[],a=>i(...r,a)):i(...r,e[o])};i()})]})(),x=a=>{a!=N&&(N=a,U(T,void 0,N))},J=t=>{(b&&v(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},Y=async()=>{q()&&a.hadMutated?.()&&await H()},k=async a=>(2!=N&&(x(1),m++,await aa(async()=>{await f(async()=>{const e=await t();v(e)?J(e):a?_(a):$("Content is not an array: "+e)},()=>{a&&_(a)}),x(0),await Y()})),ta),z=async a=>(G(),await k(a),await f(async()=>E=await s(async(a,t)=>{t||a?2!=N&&(x(1),m++,J(t??a),x(0),await Y()):await k()}),r),ta),G=async()=>(E&&(await f(()=>i(E),r),E=void 0),ta),H=async a=>(1!=N&&(x(2),C++,await aa(async()=>{await f(()=>n(O,a),r),x(0)})),ta),V=async()=>(X(),await H(),p=a.addDidFinishTransactionListener(()=>{const a=D();R(a)&&H(a)}),ta),X=async()=>(p&&(a.delListener(p),p=void 0),ta),q=()=>!y(p),Z=async(a=!1)=>{const[t,e]=a?[X,G]:[G,X];return await t(),await e(),ta},aa=async(...a)=>(I(Aa(za,w),...a),await(async()=>{if(!Aa(ka,w)){for(ma(ka,w,1);!y(d=S(Aa(za,w)));)await f(d,r);ma(ka,w,0)}})(),ta),ta={load:k,startAutoLoad:z,stopAutoLoad:G,isAutoLoading:()=>!y(E),save:H,startAutoSave:V,stopAutoSave:X,isAutoSaving:q,startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[V,z]:[z,V];return await e(a),await n(a),ta},stopAutoPersisting:Z,getStatus:()=>N,addStatusListener:a=>F(a,T),delListener:t=>(j(t),a),schedule:aa,getStore:()=>a,destroy:()=>(Aa(za,w).splice(0,void 0),Z()),getStats:()=>({loads:m,saves:C}),...c};return B(ta)},Ha=(a,t,e,s,r,o=Va,c,l)=>{const w=pa();return[async()=>{w.clear(),T(await e(a,t),({tn:a,cn:t})=>W($a(w,a,Q),t))},async(t,e,n)=>((a,t)=>D(Aa(w,a),t))(t,e)?J(O(T(await a(ra+ua(t)+Ea(t,n)),a=>[a[e],l?G(k(a,e),l):k(a,e)]),([a,t])=>!y(a)&&!K(t))):{},async(t,e,s,l,u,d=!1,g=i)=>{const E=Q();G(s??{},a=>T(x(a??{}),a=>W(E,a)));const v=R(E);if(!d&&u&&g==i&&b(v)&&D(w,t))return await a("DROP "+ta+ua(t)),void ma(w,t);const p=Aa(w,t),A=Q(R(p));if(b(v)||(D(w,t)?await m(T([e,...v],async(n,s)=>{M(A,n)||(await a(na+ua(t)+"ADD"+ua(n)+r),0==s&&await a("CREATE UNIQUE INDEX pk ON "+ua(t)+`(${ua(e)})`),W(p,n))})):(await a(ya+ua(t)+`(${ua(e)}${r} PRIMARY KEY${C(T(v,a=>n+ua(a)+r))});`),ma(w,t,Q([e,...v])))),await m([...!d&&l?T(R(A),async n=>{n!=e&&(await a(na+ua(t)+"DROP"+ua(n)),M(p,n))}):[]]),d)y(s)?await a(ia+ua(t)+Ea(t,g)):await m(z(s,async(n,s)=>{y(n)?await a(ia+ua(t)+Ea(t,g)+`AND(${ua(e)}=$1)`,[s]):b(v)||await o(a,t,e,x(n),{[s]:c?T(H(n),c):H(n)},p)}));else if(b(v))D(w,t)&&await a(ia+ua(t)+Ea(t,g));else{const n=O(R(Aa(w,t)),a=>a!=e),i={},r=[];G(s??{},(a,t)=>{i[t]=T(n,t=>c?c(a?.[t]):a?.[t]),I(r,t)}),await o(a,t,e,n,i),await a(ia+ua(t)+Ea(t,g)+`AND${ua(e)}NOT IN(${ga(r)})`,r)}},async t=>{let e;return await a("BEGIN"),await f(async()=>e=await t(),s),await a("END"),e}]},Va=async(a,t,e,s,i)=>{const r=[1];await a(ea+" INTO"+ua(t)+"("+da(e,...s)+")VALUES"+C(z(i,a=>"($"+r[0]+++","+ga(a,r)+")"),n)+"ON CONFLICT("+ua(e)+")DO UPDATE SET"+C(T(s,a=>ua(a)+"=excluded."+ua(a)),n),z(i,(a,t)=>[t,...T(a,a=>a??null)]).flat())},Ka=(a,t,e,n,s,i,r,[o,c,l],w,u,d,g,E,v)=>{const[p,A,N,m]=Ha(t,w,u,s,E,v),$=Ga(a,()=>m(async()=>{return await p(),a=(await A(o,c))[X]?.[l]??"null",Ja(Ba(a));var a}),a=>m(async()=>{var t;await p(),await N(o,c,{[X]:{[l]:(t=a()??null,xa(t,(a,t)=>y(t)?"":t))}},!0,!0)}),e,n,s,r,{[g]:()=>d,destroy:async()=>(await $.stopAutoPersisting(),i(),$)},0,d);return $},Qa=(a,t,e,n,s,i,r,[o,c,[l,w,u]],d,g,E,v,p,A,N,$)=>{const[f,h,C,T]=Ha(t,d,g,s,p,A,N,$),b=(a,t)=>m(Na(c,async([e,n,s,i,r],o)=>{t&&!(o in a)||await C(e,n,a[o],s,i,t,r)})),I=async(a,t)=>w?await C(u,q,{[X]:a},!0,!0,t):null,S=Ga(a,()=>T(async()=>{await f();const a=await(async()=>J(O(await m(Na(o,async([a,t,e],n)=>[a,await h(n,t,e)])),a=>!K(a[1]))))(),t=await(async()=>l?(await h(u,q))[X]:{})();return K(a)&&y(t)?void 0:[a,t]}),(a,t)=>T(async()=>{if(await f(),y(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,{[v]:()=>E,destroy:async()=>(await S.stopAutoPersisting(),i(),S)},0,E);return S},Wa=(a,n,s,r,o,c,y,u,d,g,v="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,b,O]=(a=>{const e=(a=>Y(Fa,E(a)?{[ba]:a}:a??{}))(a),n=e[Sa];if(e.mode==Ta){const a=e[ba]??t;return[1,n,[a,e[Oa]??q,e[Ia]??Ca],Q(a)]}const{tables:{load:s={},save:r={}}={},values:o={}}=e,c=p(H(Y(Ua,o)),0,V(Ua)),l=c[2],w=Q(l),y=Q(l),u=ja(s,{[La]:null,[Da]:q,[_a]:i},La,a=>D(y,a),a=>W(w,a)),d=ja(r,{[Ra]:null,[Da]:q,[Pa]:0,[Ma]:0,[_a]:null},Ra,(a,t)=>D(y,t),(a,t)=>W(w,t));var g;return g=(a,t)=>t[4]??=Aa(u,t[0])?.[2]??i,P(d,(a,t)=>g(0,a)),[0,n,[u,d,c],w]})(n);return(C?Ka:Qa)(a,h,a=>{let t;const e=()=>t=setInterval(()=>f(async()=>{const[{d:t,s:e,c:n}]=await h(Z+` ${ca} d,${la} s,TOTAL_CHANGES() c FROM ${oa}${ca} JOIN ${oa}${la}`);t==N&&e==m&&n==$||(w(N)||a(),N=t,m=e,$=n)}),1e3*T),n=()=>{N=m=$=null,l(t)},s=r(t=>{O.has(t)&&(n(),a(),e())});return e(),()=>{n(),o(s)}},a=>a(),y,u,d,b,R(O),async(a,t)=>await a(Z+` t.name tn,c.name cn FROM ${wa}list()t,${wa}info(t.name)c ${aa} t.schema='main'AND t.type IN('table','view')AND t.name IN(${ga(t)})ORDER BY t.name,c.name`,t),g,v,e,A,a=>(a=>!0===a)(a)?1:(a=>!1===a)(a)?0:a,void 0)},Xa=(a,t,e,n,s)=>{let i;return Wa(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)i&&T(a.changedTables,i)})(),i=a,e},a=>{i=void 0,a.abort()},n,s,N,1,t,"getPowerSync",qa)},qa=async(a,t,e,s,i,r)=>{const o=[1],c=Q(s),l=r?O([...r],a=>a!=e&&!D(c,a)):[];if(!b(l)){const n=x(i),s=J(T(await a(Z+da(e,...l)+sa+ua(t)+aa+ua(e)+"IN("+ga(n)+")",n),a=>[a[e],a]));h(n,a=>I(i[a],...T(l,t=>s?.[a]?.[t]??null)))}await a(ea+" OR REPLACE INTO"+ua(t)+"("+da(e,...s,...l)+")VALUES"+C(z(i,a=>"($"+o[0]+++","+ga(a,o)+")"),n),z(i,(a,t)=>[t,...T(a,a=>a??null)]).flat())};export{Xa as createPowerSyncPersister};
|
|
Binary file
|
|
@@ -1 +1 @@
|
|
|
1
|
-
const t=t=>(e,
|
|
1
|
+
const t=t=>(a,e,n)=>t(a)?n?.():e(a),a=t=>null==t,e=t=>void 0===t,n=t=>null===t,s=t(a),r=t(e),o=t=>Array.isArray(t),i=t=>t.length,c=t=>{throw Error(t)},g=async(t,a,e)=>{try{return await t()}catch(t){a?.(t)}},u=(t,a)=>t.forEach(a),y=(t,...a)=>t.push(...a),d=t=>t.shift(),l=t=>e(t)||0==(t=>t?.size??0)(t),w=(t,a)=>t?.forEach(a),p=(t,a)=>t?.delete(a),h=Object,v=t=>h.getPrototypeOf(t),S=h.keys,C=h.freeze,f=t=>(t=>!a(t)&&s(v(t),t=>t==h.prototype||a(v(t)),()=>!0))(t)&&0==(t=>i(S(t)))(t),A=Map,L=t=>new A(t),b=(t,a)=>t?.get(a),M=(t,a,n)=>e(n)?(p(t,a),t):t?.set(a,n),O=(t,a,e,n)=>{var s,r;return s=t,r=a,s?.has(r)?n?.(b(t,a)):M(t,a,e()),b(t,a)},P=(t,a,e,n,s=0)=>r((e?O:b)(t,a[s],s>i(a)-2?e:L),r=>{if(s>i(a)-2)return n?.(r)&&M(t,a[s]),r;const o=P(r,a,e,n,s+1);return l(r)&&M(t,a[s]),o}),N=/^\d+$/,m=t=>new Set(o(t)||e(t)?t:[t]),E=L(),J=L(),T=(t,a,s,h,v,S,A,T={},z=0,D=[])=>{let j,k,x,F=0,V=0,$=0;O(E,D,()=>0),O(J,D,()=>[]);const q=L(),[B,G,H,I,K]=((t=1,a,e)=>1!=t&&a.isMergeable()?[1,a.getMergeableContent,()=>a.getTransactionMergeableChanges(!e),([[t],[a]])=>!f(t)||!f(a),a.setDefaultContent]:2!=t?[0,a.getContent,a.getTransactionChanges,([t,a])=>!f(t)||!f(a),a.setContent]:c("Store type not supported by this Persister"))(A,t,z),[Q,R,U]=(()=>{let t;const[a,e]=(()=>{const t=[];let a=0;return[e=>(e?d(t):null)??""+a++,a=>{N.test(a)&&i(t)<1e3&&y(t,a)}]})(),s=L();return[(e,n,r,o=[],i=()=>[])=>{t??=it;const c=a(1);var g,u;return M(s,c,[e,n,r,o,i]),g=P(n,r??[""],m),u=c,g?.add(u),c},(a,e,...r)=>u(((t,a=[""])=>{const e=[],s=(t,r)=>r==i(a)?y(e,t):n(a[r])?w(t,t=>s(t,r+1)):u([a[r],null],a=>s(b(t,a),r+1));return s(t,0),e})(a,e),a=>w(a,a=>b(s,a)[0](t,...e??[],...r))),t=>r(b(s,t),([,a,n])=>(P(a,n??[""],void 0,a=>(p(a,t),l(a)?1:0)),M(s,t),e(t),n)),a=>r(b(s,a),([a,,e=[],s,r])=>{const o=(...c)=>{const g=i(c);g==i(e)?a(t,...c,...r(c)):n(e[g])?u(s[g]?.(...c)??[],t=>o(...c,t)):o(...c,e[g])};o()})]})(),W=t=>{t!=F&&(F=t,R(q,void 0,F))},X=a=>{(B&&o(a?.[0])?1===a?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===a?.[2]?t.applyChanges:t.setContent)(a)},Y=async()=>{st()&&t.hadMutated?.()&&await at()},Z=async t=>(2!=F&&(W(1),V++,await ot(async()=>{await g(async()=>{const e=await a();o(e)?X(e):t?K(t):c("Content is not an array: "+e)},()=>{t&&K(t)}),W(0),await Y()})),it),_=async t=>(tt(),await Z(t),await g(async()=>k=await h(async(t,a)=>{a||t?2!=F&&(W(1),V++,X(a??t),W(0),await Y()):await Z()}),S),it),tt=async()=>(k&&(await g(()=>v(k),S),k=void 0),it),at=async t=>(1!=F&&(W(2),$++,await ot(async()=>{await g(()=>s(G,t),S),W(0)})),it),et=async()=>(nt(),await at(),x=t.addDidFinishTransactionListener(()=>{const t=H();I(t)&&at(t)}),it),nt=async()=>(x&&(t.delListener(x),x=void 0),it),st=()=>!e(x),rt=async(t=!1)=>{const[a,e]=t?[nt,tt]:[tt,nt];return await a(),await e(),it},ot=async(...t)=>(y(b(J,D),...t),await(async()=>{if(!b(E,D)){for(M(E,D,1);!e(j=d(b(J,D)));)await g(j,S);M(E,D,0)}})(),it),it={load:Z,startAutoLoad:_,stopAutoLoad:tt,isAutoLoading:()=>!e(k),save:at,startAutoSave:et,stopAutoSave:nt,isAutoSaving:st,startAutoPersisting:async(t,a=!1)=>{const[e,n]=a?[et,_]:[_,et];return await e(t),await n(t),it},stopAutoPersisting:rt,getStatus:()=>F,addStatusListener:t=>Q(t,q),delListener:a=>(U(a),t),schedule:ot,getStore:()=>t,destroy:()=>(b(J,D).splice(0,void 0),rt()),getStats:()=>({loads:V,saves:$}),...T};return C(it)},z=(t,a,n="storage",s)=>T(t,async()=>{const t=a.getString(n),s=e(t)?void 0:JSON.parse(t);return Promise.resolve(s)},async t=>{const s=t();e(s)||a.set(n,JSON.stringify(s))},t=>a.addOnValueChangedListener(e=>{if(e===n){const e=a.getString(n);e&&t(JSON.parse(e))}}),t=>{t.remove()},s,3,{getStorageName:()=>n});export{z as createReactNativeMmkvPersister};
|
|
Binary file
|
|
@@ -1 +1 @@
|
|
|
1
|
-
const t=t=>(e,
|
|
1
|
+
const t=t=>(a,e,n)=>t(a)?n?.():e(a),a=t=>null==t,e=t=>void 0===t,n=t=>null===t,s=t(a),r=t(e),o=t=>Array.isArray(t),i=t=>t.length,c=t=>{throw Error(t)},g=async(t,a,e)=>{try{return await t()}catch(t){a?.(t)}},u=(t,a)=>t.forEach(a),y=(t,...a)=>t.push(...a),d=t=>t.shift(),l=t=>e(t)||0==(t=>t?.size??0)(t),w=(t,a)=>t?.forEach(a),p=(t,a)=>t?.delete(a),h=Object,v=t=>h.getPrototypeOf(t),S=h.keys,C=h.freeze,f=t=>(t=>!a(t)&&s(v(t),t=>t==h.prototype||a(v(t)),()=>!0))(t)&&0==(t=>i(S(t)))(t),A=Map,L=t=>new A(t),b=(t,a)=>t?.get(a),M=(t,a,n)=>e(n)?(p(t,a),t):t?.set(a,n),O=(t,a,e,n)=>{var s,r;return s=t,r=a,s?.has(r)?n?.(b(t,a)):M(t,a,e()),b(t,a)},P=(t,a,e,n,s=0)=>r((e?O:b)(t,a[s],s>i(a)-2?e:L),r=>{if(s>i(a)-2)return n?.(r)&&M(t,a[s]),r;const o=P(r,a,e,n,s+1);return l(r)&&M(t,a[s]),o}),N=/^\d+$/,m=t=>new Set(o(t)||e(t)?t:[t]),E=L(),J=L(),T=(t,a,s,h,v,S,A,T={},z=0,D=[])=>{let j,k,x,F=0,V=0,$=0;O(E,D,()=>0),O(J,D,()=>[]);const q=L(),[B,G,H,I,K]=((t=1,a,e)=>1!=t&&a.isMergeable()?[1,a.getMergeableContent,()=>a.getTransactionMergeableChanges(!e),([[t],[a]])=>!f(t)||!f(a),a.setDefaultContent]:2!=t?[0,a.getContent,a.getTransactionChanges,([t,a])=>!f(t)||!f(a),a.setContent]:c("Store type not supported by this Persister"))(A,t,z),[Q,R,U]=(()=>{let t;const[a,e]=(()=>{const t=[];let a=0;return[e=>(e?d(t):null)??""+a++,a=>{N.test(a)&&i(t)<1e3&&y(t,a)}]})(),s=L();return[(e,n,r,o=[],i=()=>[])=>{t??=it;const c=a(1);var g,u;return M(s,c,[e,n,r,o,i]),g=P(n,r??[""],m),u=c,g?.add(u),c},(a,e,...r)=>u(((t,a=[""])=>{const e=[],s=(t,r)=>r==i(a)?y(e,t):n(a[r])?w(t,t=>s(t,r+1)):u([a[r],null],a=>s(b(t,a),r+1));return s(t,0),e})(a,e),a=>w(a,a=>b(s,a)[0](t,...e??[],...r))),t=>r(b(s,t),([,a,n])=>(P(a,n??[""],void 0,a=>(p(a,t),l(a)?1:0)),M(s,t),e(t),n)),a=>r(b(s,a),([a,,e=[],s,r])=>{const o=(...c)=>{const g=i(c);g==i(e)?a(t,...c,...r(c)):n(e[g])?u(s[g]?.(...c)??[],t=>o(...c,t)):o(...c,e[g])};o()})]})(),W=t=>{t!=F&&(F=t,R(q,void 0,F))},X=a=>{(B&&o(a?.[0])?1===a?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===a?.[2]?t.applyChanges:t.setContent)(a)},Y=async()=>{st()&&t.hadMutated?.()&&await at()},Z=async t=>(2!=F&&(W(1),V++,await ot(async()=>{await g(async()=>{const e=await a();o(e)?X(e):t?K(t):c("Content is not an array: "+e)},()=>{t&&K(t)}),W(0),await Y()})),it),_=async t=>(tt(),await Z(t),await g(async()=>k=await h(async(t,a)=>{a||t?2!=F&&(W(1),V++,X(a??t),W(0),await Y()):await Z()}),S),it),tt=async()=>(k&&(await g(()=>v(k),S),k=void 0),it),at=async t=>(1!=F&&(W(2),$++,await ot(async()=>{await g(()=>s(G,t),S),W(0)})),it),et=async()=>(nt(),await at(),x=t.addDidFinishTransactionListener(()=>{const t=H();I(t)&&at(t)}),it),nt=async()=>(x&&(t.delListener(x),x=void 0),it),st=()=>!e(x),rt=async(t=!1)=>{const[a,e]=t?[nt,tt]:[tt,nt];return await a(),await e(),it},ot=async(...t)=>(y(b(J,D),...t),await(async()=>{if(!b(E,D)){for(M(E,D,1);!e(j=d(b(J,D)));)await g(j,S);M(E,D,0)}})(),it),it={load:Z,startAutoLoad:_,stopAutoLoad:tt,isAutoLoading:()=>!e(k),save:at,startAutoSave:et,stopAutoSave:nt,isAutoSaving:st,startAutoPersisting:async(t,a=!1)=>{const[e,n]=a?[et,_]:[_,et];return await e(t),await n(t),it},stopAutoPersisting:rt,getStatus:()=>F,addStatusListener:t=>Q(t,q),delListener:a=>(U(a),t),schedule:ot,getStore:()=>t,destroy:()=>(b(J,D).splice(0,void 0),rt()),getStats:()=>({loads:V,saves:$}),...T};return C(it)},z=(t,a,n="storage",s)=>T(t,async()=>{const t=a.getString(n),s=e(t)?void 0:JSON.parse(t);return Promise.resolve(s)},async t=>{const s=t();e(s)||a.set(n,JSON.stringify(s))},t=>a.addOnValueChangedListener(e=>{if(e===n){const e=a.getString(n);e&&t(JSON.parse(e))}}),t=>{t.remove()},s,3,{getStorageName:()=>n});export{z as createReactNativeMmkvPersister};
|
|
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=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),g=c(y),p=t=>a(t)==s,v=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),
|
|
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),g=c(y),p=t=>a(t)==s,v=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),S=(a,t)=>a.filter(t),b=(a,...t)=>a.push(...t),D=a=>a.shift(),I=(a,t)=>a?.has(t)??!1,L=a=>y(a)||0==(a=>a?.size??0)(a),R=a=>[...a?.values()??[]],M=(a,t)=>a?.forEach(t),P=(a,t)=>a?.delete(t),_="_",F="_id",U="SELECT",j="WHERE",x="TABLE",B="ALTER "+x,J="FROM",Y="DELETE "+J,k=U+"*"+J,z="pragma_",G="data_version",H="schema_version",q="pragma_table_",K="CREATE "+x,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=a=>!w(a)&&d(Z(a),a=>a==X.prototype||w(Z(a)),()=>!0),ea=X.keys,na=X.freeze,sa=(a=[])=>X.fromEntries(a),ia=(...a)=>X.assign({},...a),ra=(a,t)=>(delete a[t],a),oa=(a,t)=>h(aa(a),([a,e])=>t(e,a)),ca=(a,t)=>sa(oa(a,(a,e)=>[e,t(a,e)])),la=a=>X.values(a),wa=a=>A(ea(a)),ya=a=>ta(a)&&0==wa(a),ua=Map,da=a=>new ua(a),ga=(a,t)=>a?.get(t),pa=(a,t)=>h([...a?.entries()??[]],([a,e])=>t(e,a)),va=(a,t,e)=>y(e)?(P(a,t),a):a?.set(t,e),Ea=(a,t,e,n)=>(I(a,t)?n?.(ga(a,t)):va(a,t,e()),ga(a,t)),Aa=(a,t,e,n,s=0)=>g((e?Ea:ga)(a,t[s],s>A(t)-2?e:da),i=>{if(s>A(t)-2)return n?.(i)&&va(a,t[s]),i;const r=Aa(i,t,e,n,s+1);return L(i)&&va(a,t[s]),r}),Na=a=>new Set(v(a)||y(a)?a:[a]),ma=(a,t)=>a?.add(t),$a="ColumnName",fa="store",Ca="json",Ta=fa+"TableName",ha=fa+"Id"+$a,Oa=fa+$a,Sa="autoLoadIntervalSeconds",ba="rowId"+$a,Da="tableId",Ia="tableName",La="deleteEmptyColumns",Ra="deleteEmptyTable",Ma="condition",Pa={mode:Ca,[Sa]:1},_a={load:0,save:0,[Ia]:t+"_values"},Fa=(a,t,e,n,s)=>{const i=da();return ca(a,(a,r)=>{const o=E(la(ia(t,p(a)?{[e]:a}:a)),0,wa(t));u(o[0])||n(r,o[0])||(s(r,o[0]),va(i,r,o))}),i},Ua=JSON.stringify,ja=JSON.parse,xa=a=>""===a?void 0:v(a)?h(a,xa):ta(a)?ca(a,xa):a,Ba=/^\d+$/,Ja=da(),Ya=da(),ka=(a,t,n,s,i,r,o,c={},l=0,w=[])=>{let d,p,E,N=0,m=0,T=0;Ea(Ja,w,()=>0),Ea(Ya,w,()=>[]);const h=da(),[O,S,I,R,_]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!ya(a)||!ya(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!ya(a)||!ya(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?D(a):null)??e+t++,t=>{Ba.test(t)&&A(a)<1e3&&b(a,t)}]})(),s=da();return[(n,i,r,o=[],c=()=>[])=>{a??=W;const l=t(1);return va(s,l,[n,i,r,o,c]),ma(Aa(i,r??[e],Na),l),l},(t,n,...i)=>C(((a,t=[e])=>{const n=[],s=(a,e)=>e==A(t)?b(n,a):u(t[e])?M(a,a=>s(a,e+1)):C([t[e],null],t=>s(ga(a,t),e+1));return s(a,0),n})(t,n),t=>M(t,t=>ga(s,t)[0](a,...n??[],...i))),a=>g(ga(s,a),([,t,i])=>(Aa(t,i??[e],void 0,t=>(P(t,a),L(t)?1:0)),va(s,a),n(a),i)),t=>g(ga(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()})]})(),x=a=>{a!=N&&(N=a,U(h,void 0,N))},B=t=>{(O&&v(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},J=async()=>{K()&&a.hadMutated?.()&&await G()},Y=async a=>(2!=N&&(x(1),m++,await V(async()=>{await f(async()=>{const e=await t();v(e)?B(e):a?_(a):$("Content is not an array: "+e)},()=>{a&&_(a)}),x(0),await J()})),W),k=async a=>(z(),await Y(a),await f(async()=>p=await s(async(a,t)=>{t||a?2!=N&&(x(1),m++,B(t??a),x(0),await J()):await Y()}),r),W),z=async()=>(p&&(await f(()=>i(p),r),p=void 0),W),G=async a=>(1!=N&&(x(2),T++,await V(async()=>{await f(()=>n(S,a),r),x(0)})),W),H=async()=>(q(),await G(),E=a.addDidFinishTransactionListener(()=>{const a=I();R(a)&&G(a)}),W),q=async()=>(E&&(a.delListener(E),E=void 0),W),K=()=>!y(E),Q=async(a=!1)=>{const[t,e]=a?[q,z]:[z,q];return await t(),await e(),W},V=async(...a)=>(b(ga(Ya,w),...a),await(async()=>{if(!ga(Ja,w)){for(va(Ja,w,1);!y(d=D(ga(Ya,w)));)await f(d,r);va(Ja,w,0)}})(),W),W={load:Y,startAutoLoad:k,stopAutoLoad:z,isAutoLoading:()=>!y(p),save:G,startAutoSave:H,stopAutoSave:q,isAutoSaving:K,startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[H,k]:[k,H];return await e(a),await n(a),W},stopAutoPersisting:Q,getStatus:()=>N,addStatusListener:a=>F(a,h),delListener:t=>(j(t),a),schedule:V,getStore:()=>a,destroy:()=>(ga(Ya,w).splice(0,void 0),Q()),getStats:()=>({loads:m,saves:T}),...c};return na(W)},za=(a,t,e,s,r,o=Ga,c,l)=>{const w=da();return[async()=>{w.clear(),h(await e(a,t),({tn:a,cn:t})=>ma(Ea(w,a,Na),t))},async(t,e,n)=>((a,t)=>I(ga(w,a),t))(t,e)?sa(S(h(await a(k+Q(t)+W(t,n)),a=>[a[e],l?ca(ra(a,e),l):ra(a,e)]),([a,t])=>!y(a)&&!ya(t))):{},async(t,e,s,l,u,d=!1,g=i)=>{const p=Na();ca(s??{},a=>h(ea(a??{}),a=>ma(p,a)));const v=R(p);if(!d&&u&&g==i&&O(v)&&I(w,t))return await a("DROP "+x+Q(t)),void va(w,t);const E=ga(w,t),A=Na(R(E));if(O(v)||(I(w,t)?await m(h([e,...v],async(n,s)=>{P(A,n)||(await a(B+Q(t)+"ADD"+Q(n)+r),0==s&&await a("CREATE UNIQUE INDEX pk ON "+Q(t)+`(${Q(e)})`),ma(E,n))})):(await a(K+Q(t)+`(${Q(e)}${r} PRIMARY KEY${T(h(v,a=>n+Q(a)+r))});`),va(w,t,Na([e,...v])))),await m([...!d&&l?h(R(A),async n=>{n!=e&&(await a(B+Q(t)+"DROP"+Q(n)),P(E,n))}):[]]),d)y(s)?await a(Y+Q(t)+W(t,g)):await m(oa(s,async(n,s)=>{y(n)?await a(Y+Q(t)+W(t,g)+`AND(${Q(e)}=$1)`,[s]):O(v)||await o(a,t,e,ea(n),{[s]:c?h(la(n),c):la(n)},E)}));else if(O(v))I(w,t)&&await a(Y+Q(t)+W(t,g));else{const n=S(R(ga(w,t)),a=>a!=e),i={},r=[];ca(s??{},(a,t)=>{i[t]=h(n,t=>c?c(a?.[t]):a?.[t]),b(r,t)}),await o(a,t,e,n,i),await a(Y+Q(t)+W(t,g)+`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}]},Ga=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(oa(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),oa(i,(a,t)=>[t,...h(a,a=>a??null)]).flat())},Ha=(a,t,e,n,s,i,r,[o,c,l],w,u,d,g,p,v)=>{const[E,A,N,m]=za(t,w,u,s,p,v),$=ka(a,()=>m(async()=>{return await E(),a=(await A(o,c))[_]?.[l]??"null",xa(ja(a));var a}),a=>m(async()=>{var t;await E(),await N(o,c,{[_]:{[l]:(t=a()??null,Ua(t,(a,t)=>y(t)?"":t))}},!0,!0)}),e,n,s,r,{[g]:()=>d,destroy:async()=>(await $.stopAutoPersisting(),i(),$)},0,d);return $},qa=(a,t,e,n,s,i,r,[o,c,[l,w,u]],d,g,p,v,E,A,N,$)=>{const[f,C,T,h]=za(t,d,g,s,E,A,N,$),O=(a,t)=>m(pa(c,async([e,n,s,i,r],o)=>{t&&!(o in a)||await T(e,n,a[o],s,i,t,r)})),b=async(a,t)=>w?await T(u,F,{[_]:a},!0,!0,t):null,D=ka(a,()=>h(async()=>{await f();const a=await(async()=>sa(S(await m(pa(o,async([a,t,e],n)=>[a,await C(n,t,e)])),a=>!ya(a[1]))))(),t=await(async()=>l?(await C(u,F))[_]:{})();return ya(a)&&y(t)?void 0:[a,t]}),(a,t)=>h(async()=>{if(await f(),y(t)){const[t,e]=a();await O(t),await b(e)}else await O(t[0],!0),await b(t[1],!0)}),e,n,s,r,{[v]:()=>p,destroy:async()=>(await D.stopAutoPersisting(),i(),D)},0,p);return D},Ka=(a,n,s,r,o,c,y,u,d,g,v="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,S]=(a=>{const e=(a=>ia(Pa,p(a)?{[Ta]:a}:a??{}))(a),n=e[Sa];if(e.mode==Ca){const a=e[Ta]??t;return[1,n,[a,e[ha]??F,e[Oa]??fa],Na(a)]}const{tables:{load:s={},save:r={}}={},values:o={}}=e,c=E(la(ia(_a,o)),0,wa(_a)),l=c[2],w=Na(l),y=Na(l),u=Fa(s,{[Da]:null,[ba]:F,[Ma]:i},Da,a=>I(y,a),a=>ma(w,a)),d=Fa(r,{[Ia]:null,[ba]:F,[La]:0,[Ra]:0,[Ma]:null},Ia,(a,t)=>I(y,t),(a,t)=>ma(w,t));var g;return g=(a,t)=>t[4]??=ga(u,t[0])?.[2]??i,M(d,(a,t)=>g(0,a)),[0,n,[u,d,c],w]})(n);return(T?Ha:qa)(a,C,a=>{let t;return 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=m=$=null,l(t)}},a=>a(),y,u,d,O,R(S),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),g,v,e,A,a=>(a=>!0===a)(a)?1:(a=>!1===a)(a)?0:a,void 0)},Qa=(a,t,e,n,s)=>Ka(a,e,async(a,e=[])=>(await t.executeSql(a,e))[0].rows.raw(),0,0,n,s,N,3,t);export{Qa as createReactNativeSqlitePersister};
|
|
Binary file
|