tinybase 7.3.1 → 7.3.3

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.
Files changed (142) hide show
  1. package/@types/mergeable-store/with-schemas/index.d.ts +1 -1
  2. package/min/omni/index.js +1 -1
  3. package/min/omni/index.js.gz +0 -0
  4. package/min/omni/with-schemas/index.js +1 -1
  5. package/min/omni/with-schemas/index.js.gz +0 -0
  6. package/min/persisters/index.js +1 -1
  7. package/min/persisters/index.js.gz +0 -0
  8. package/min/persisters/persister-browser/index.js +1 -1
  9. package/min/persisters/persister-browser/index.js.gz +0 -0
  10. package/min/persisters/persister-browser/with-schemas/index.js +1 -1
  11. package/min/persisters/persister-browser/with-schemas/index.js.gz +0 -0
  12. package/min/persisters/persister-cr-sqlite-wasm/index.js +1 -1
  13. package/min/persisters/persister-cr-sqlite-wasm/index.js.gz +0 -0
  14. package/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.js +1 -1
  15. package/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.js.gz +0 -0
  16. package/min/persisters/persister-durable-object-sql-storage/index.js +1 -1
  17. package/min/persisters/persister-durable-object-sql-storage/index.js.gz +0 -0
  18. package/min/persisters/persister-durable-object-sql-storage/with-schemas/index.js +1 -1
  19. package/min/persisters/persister-durable-object-sql-storage/with-schemas/index.js.gz +0 -0
  20. package/min/persisters/persister-durable-object-storage/index.js +1 -1
  21. package/min/persisters/persister-durable-object-storage/index.js.gz +0 -0
  22. package/min/persisters/persister-durable-object-storage/with-schemas/index.js +1 -1
  23. package/min/persisters/persister-durable-object-storage/with-schemas/index.js.gz +0 -0
  24. package/min/persisters/persister-electric-sql/index.js +1 -1
  25. package/min/persisters/persister-electric-sql/index.js.gz +0 -0
  26. package/min/persisters/persister-electric-sql/with-schemas/index.js +1 -1
  27. package/min/persisters/persister-electric-sql/with-schemas/index.js.gz +0 -0
  28. package/min/persisters/persister-expo-sqlite/index.js +1 -1
  29. package/min/persisters/persister-expo-sqlite/index.js.gz +0 -0
  30. package/min/persisters/persister-expo-sqlite/with-schemas/index.js +1 -1
  31. package/min/persisters/persister-expo-sqlite/with-schemas/index.js.gz +0 -0
  32. package/min/persisters/persister-file/index.js +1 -1
  33. package/min/persisters/persister-file/index.js.gz +0 -0
  34. package/min/persisters/persister-file/with-schemas/index.js +1 -1
  35. package/min/persisters/persister-file/with-schemas/index.js.gz +0 -0
  36. package/min/persisters/persister-libsql/index.js +1 -1
  37. package/min/persisters/persister-libsql/index.js.gz +0 -0
  38. package/min/persisters/persister-libsql/with-schemas/index.js +1 -1
  39. package/min/persisters/persister-libsql/with-schemas/index.js.gz +0 -0
  40. package/min/persisters/persister-partykit-client/index.js +1 -1
  41. package/min/persisters/persister-partykit-client/index.js.gz +0 -0
  42. package/min/persisters/persister-partykit-client/with-schemas/index.js +1 -1
  43. package/min/persisters/persister-partykit-client/with-schemas/index.js.gz +0 -0
  44. package/min/persisters/persister-partykit-server/index.js +1 -1
  45. package/min/persisters/persister-partykit-server/index.js.gz +0 -0
  46. package/min/persisters/persister-partykit-server/with-schemas/index.js +1 -1
  47. package/min/persisters/persister-partykit-server/with-schemas/index.js.gz +0 -0
  48. package/min/persisters/persister-pglite/index.js +1 -1
  49. package/min/persisters/persister-pglite/index.js.gz +0 -0
  50. package/min/persisters/persister-pglite/with-schemas/index.js +1 -1
  51. package/min/persisters/persister-pglite/with-schemas/index.js.gz +0 -0
  52. package/min/persisters/persister-postgres/index.js +1 -1
  53. package/min/persisters/persister-postgres/index.js.gz +0 -0
  54. package/min/persisters/persister-postgres/with-schemas/index.js +1 -1
  55. package/min/persisters/persister-postgres/with-schemas/index.js.gz +0 -0
  56. package/min/persisters/persister-powersync/index.js +1 -1
  57. package/min/persisters/persister-powersync/index.js.gz +0 -0
  58. package/min/persisters/persister-powersync/with-schemas/index.js +1 -1
  59. package/min/persisters/persister-powersync/with-schemas/index.js.gz +0 -0
  60. package/min/persisters/persister-react-native-sqlite/index.js +1 -1
  61. package/min/persisters/persister-react-native-sqlite/index.js.gz +0 -0
  62. package/min/persisters/persister-react-native-sqlite/with-schemas/index.js +1 -1
  63. package/min/persisters/persister-react-native-sqlite/with-schemas/index.js.gz +0 -0
  64. package/min/persisters/persister-sqlite-bun/index.js +1 -1
  65. package/min/persisters/persister-sqlite-bun/index.js.gz +0 -0
  66. package/min/persisters/persister-sqlite-bun/with-schemas/index.js +1 -1
  67. package/min/persisters/persister-sqlite-bun/with-schemas/index.js.gz +0 -0
  68. package/min/persisters/persister-sqlite-wasm/index.js +1 -1
  69. package/min/persisters/persister-sqlite-wasm/index.js.gz +0 -0
  70. package/min/persisters/persister-sqlite-wasm/with-schemas/index.js +1 -1
  71. package/min/persisters/persister-sqlite-wasm/with-schemas/index.js.gz +0 -0
  72. package/min/persisters/persister-sqlite3/index.js +1 -1
  73. package/min/persisters/persister-sqlite3/index.js.gz +0 -0
  74. package/min/persisters/persister-sqlite3/with-schemas/index.js +1 -1
  75. package/min/persisters/persister-sqlite3/with-schemas/index.js.gz +0 -0
  76. package/min/persisters/with-schemas/index.js +1 -1
  77. package/min/persisters/with-schemas/index.js.gz +0 -0
  78. package/min/synchronizers/synchronizer-ws-client/index.js +1 -1
  79. package/min/synchronizers/synchronizer-ws-client/index.js.gz +0 -0
  80. package/min/synchronizers/synchronizer-ws-client/with-schemas/index.js +1 -1
  81. package/min/synchronizers/synchronizer-ws-client/with-schemas/index.js.gz +0 -0
  82. package/min/synchronizers/synchronizer-ws-server/index.js +1 -1
  83. package/min/synchronizers/synchronizer-ws-server/index.js.gz +0 -0
  84. package/min/synchronizers/synchronizer-ws-server/with-schemas/index.js +1 -1
  85. package/min/synchronizers/synchronizer-ws-server/with-schemas/index.js.gz +0 -0
  86. package/min/synchronizers/synchronizer-ws-server-durable-object/index.js +1 -1
  87. package/min/synchronizers/synchronizer-ws-server-durable-object/index.js.gz +0 -0
  88. package/min/synchronizers/synchronizer-ws-server-durable-object/with-schemas/index.js +1 -1
  89. package/min/synchronizers/synchronizer-ws-server-durable-object/with-schemas/index.js.gz +0 -0
  90. package/min/ui-react-inspector/index.js +1 -1
  91. package/min/ui-react-inspector/index.js.gz +0 -0
  92. package/min/ui-react-inspector/with-schemas/index.js +1 -1
  93. package/min/ui-react-inspector/with-schemas/index.js.gz +0 -0
  94. package/omni/index.js +21 -9
  95. package/omni/with-schemas/index.js +21 -9
  96. package/package.json +18 -18
  97. package/persisters/index.js +10 -1
  98. package/persisters/persister-browser/index.js +17 -1
  99. package/persisters/persister-browser/with-schemas/index.js +17 -1
  100. package/persisters/persister-cr-sqlite-wasm/index.js +10 -1
  101. package/persisters/persister-cr-sqlite-wasm/with-schemas/index.js +10 -1
  102. package/persisters/persister-durable-object-sql-storage/index.js +10 -1
  103. package/persisters/persister-durable-object-sql-storage/with-schemas/index.js +10 -1
  104. package/persisters/persister-durable-object-storage/index.js +5 -6
  105. package/persisters/persister-durable-object-storage/with-schemas/index.js +5 -6
  106. package/persisters/persister-electric-sql/index.js +10 -1
  107. package/persisters/persister-electric-sql/with-schemas/index.js +10 -1
  108. package/persisters/persister-expo-sqlite/index.js +10 -1
  109. package/persisters/persister-expo-sqlite/with-schemas/index.js +10 -1
  110. package/persisters/persister-file/index.js +17 -1
  111. package/persisters/persister-file/with-schemas/index.js +17 -1
  112. package/persisters/persister-libsql/index.js +10 -1
  113. package/persisters/persister-libsql/with-schemas/index.js +10 -1
  114. package/persisters/persister-partykit-client/index.js +27 -2
  115. package/persisters/persister-partykit-client/with-schemas/index.js +27 -2
  116. package/persisters/persister-partykit-server/index.js +37 -2
  117. package/persisters/persister-partykit-server/with-schemas/index.js +37 -2
  118. package/persisters/persister-pglite/index.js +10 -1
  119. package/persisters/persister-pglite/with-schemas/index.js +10 -1
  120. package/persisters/persister-postgres/index.js +10 -1
  121. package/persisters/persister-postgres/with-schemas/index.js +10 -1
  122. package/persisters/persister-powersync/index.js +10 -1
  123. package/persisters/persister-powersync/with-schemas/index.js +10 -1
  124. package/persisters/persister-react-native-sqlite/index.js +10 -1
  125. package/persisters/persister-react-native-sqlite/with-schemas/index.js +10 -1
  126. package/persisters/persister-sqlite-bun/index.js +10 -1
  127. package/persisters/persister-sqlite-bun/with-schemas/index.js +10 -1
  128. package/persisters/persister-sqlite-wasm/index.js +10 -1
  129. package/persisters/persister-sqlite-wasm/with-schemas/index.js +10 -1
  130. package/persisters/persister-sqlite3/index.js +10 -1
  131. package/persisters/persister-sqlite3/with-schemas/index.js +10 -1
  132. package/persisters/with-schemas/index.js +10 -1
  133. package/readme.md +10 -2
  134. package/releases.md +1 -1
  135. package/synchronizers/synchronizer-ws-client/index.js +14 -1
  136. package/synchronizers/synchronizer-ws-client/with-schemas/index.js +14 -1
  137. package/synchronizers/synchronizer-ws-server/index.js +14 -1
  138. package/synchronizers/synchronizer-ws-server/with-schemas/index.js +14 -1
  139. package/synchronizers/synchronizer-ws-server-durable-object/index.js +14 -1
  140. package/synchronizers/synchronizer-ws-server-durable-object/with-schemas/index.js +14 -1
  141. package/ui-react-inspector/index.js +10 -1
  142. package/ui-react-inspector/with-schemas/index.js +10 -1
@@ -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,F=a=>P.getPrototypeOf(a),M=P.entries,U=P.keys,G=P.freeze,j=(a=[])=>P.fromEntries(a),x=(...a)=>P.assign({},...a),W=(a,t)=>(delete a[t],a),B=(a,t)=>v(M(a),([a,e])=>t(e,a)),H=(a,t)=>j(B(a,(a,e)=>[e,t(a,e)])),X=a=>P.values(a),Y=a=>T(U(a)),k=a=>(a=>!w(a)&&d(F(a),a=>a==P.prototype||w(F(a)),()=>!0))(a)&&0==Y(a),q=JSON.stringify,z=JSON.parse,J=a=>q(a,(a,t)=>y(t)?"":t),K=new l.TextEncoder,V=a=>new Map(a),Q=(a,t)=>a?.get(t),Z=(a,t)=>v([...a?.entries()??[]],([a,e])=>t(e,a)),aa=(a,t,e)=>y(e)?(h(a,t),a):a?.set(t,e),ta=(a,t,e,n)=>(_(a,t)?n?.(Q(a,t)):aa(a,t,e()),Q(a,t)),ea=(a,t,e,n,s=0)=>E((e?ta:Q)(a,t[s],s>T(t)-2?e:V),i=>{if(s>T(t)-2)return n?.(i)&&aa(a,t[s]),i;const r=ea(i,t,e,n,s+1);return b(i)&&aa(a,t[s]),r}),na="_",sa="_id",ia="SELECT",ra="WHERE",oa="TABLE",ca="INSERT",la="DELETE",wa="UPDATE",ya="ALTER "+oa,ua="FROM",da=la+" "+ua,Ea=ia+"*"+ua,Na="CREATE ",ga=Na+oa,Aa="OR REPLACE ",Ta="FUNCTION",$a="$tableName",pa=a=>m(v(((a,t="",e)=>a.split(t,e))(a,"."),a=>`"${r(a,/"/g,'""')}"`),"."),Oa=(...a)=>pa(m(a,"_")),Ra=(a,t=[1])=>m(v(a,()=>"$"+t[0]++),n),ma=(a,t=i)=>ra+`(${r(t,$a,pa(a))})`,va=a=>new Set(g(a)||y(a)?a:[a]),Ca=(a,t)=>a?.add(t),Sa="ColumnName",Ia="store",La="json",_a=Ia+"TableName",ba=Ia+"Id"+Sa,fa=Ia+Sa,Da="autoLoadIntervalSeconds",ha="rowId"+Sa,Pa="tableId",Fa="tableName",Ma="deleteEmptyColumns",Ua="deleteEmptyTable",Ga="condition",ja={mode:La,[Da]:1},xa={load:0,save:0,[Fa]:t+"_values"},Wa=(a,t,e,n,s)=>{const i=V();return H(a,(a,r)=>{const o=A(X(x(t,N(a)?{[e]:a}:a)),0,Y(t));u(o[0])||n(r,o[0])||(s(r,o[0]),aa(i,r,o))}),i},Ba=/^\d+$/,Ha=V(),Xa=V(),Ya=(a,t,n,s,i,r,o,c={},l=0,w=[])=>{let d,N,A,$=0,m=0,v=0;ta(Ha,w,()=>0),ta(Xa,w,()=>[]);const C=V(),[S,_,f,P,F]=((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]:p("Store type not supported by this Persister"))(o,a,l),[M,U,j]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?L(a):null)??e+t++,t=>{Ba.test(t)&&T(a)<1e3&&I(a,t)}]})(),s=V();return[(n,i,r,o=[],c=()=>[])=>{a??=Z;const l=t(1);return aa(s,l,[n,i,r,o,c]),Ca(ea(i,r??[e],va),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(Q(a,t),e+1));return s(a,0),n})(t,n),t=>D(t,t=>Q(s,t)[0](a,...n??[],...i))),a=>E(Q(s,a),([,t,i])=>(ea(t,i??[e],void 0,t=>(h(t,a),b(t)?1:0)),aa(s,a),n(a),i)),t=>E(Q(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 a=>(2!=$&&(x(1),m++,await K(async()=>{await O(async()=>{const e=await t();g(e)?W(e):a?F(a):p("Content is not an array: "+e)},()=>{a&&F(a)}),x(0)})),Z),H=async a=>(X(),await B(a),await O(async()=>N=await s(async(a,t)=>{t||a?2!=$&&(x(1),m++,W(t??a),x(0)):await B()}),r),Z),X=async()=>(N&&(await O(()=>i(N),r),N=void 0),Z),Y=async a=>(1!=$&&(x(2),v++,await K(async()=>{await O(()=>n(_,a),r),x(0)})),Z),q=async()=>(z(),await Y(),A=a.addDidFinishTransactionListener(()=>{const a=f();P(a)&&Y(a)}),Z),z=async()=>(A&&(a.delListener(A),A=void 0),Z),J=async(a=!1)=>{const[t,e]=a?[z,X]:[X,z];return await t(),await e(),Z},K=async(...a)=>(I(Q(Xa,w),...a),await(async()=>{if(!Q(Ha,w)){for(aa(Ha,w,1);!y(d=L(Q(Xa,w)));)await O(d,r);aa(Ha,w,0)}})(),Z),Z={load:B,startAutoLoad:H,stopAutoLoad:X,isAutoLoading:()=>!y(N),save:Y,startAutoSave:q,stopAutoSave:z,isAutoSaving:()=>!y(A),startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[q,H]:[H,q];return await e(a),await n(a),Z},stopAutoPersisting:J,getStatus:()=>$,addStatusListener:a=>M(a,C),delListener:t=>(j(t),a),schedule:K,getStore:()=>a,destroy:()=>(Q(Xa,w).splice(0,void 0),J()),getStats:()=>({loads:m,saves:v}),...c};return G(Z)},ka=(a,t,e,s,r,o=qa,c,l)=>{const w=V();return[async()=>{w.clear(),v(await e(a,t),({tn:a,cn:t})=>Ca(ta(w,a,va),t))},async(t,e,n)=>((a,t)=>_(Q(w,a),t))(t,e)?j(S(v(await a(Ea+pa(t)+ma(t,n)),a=>[a[e],l?H(W(a,e),l):W(a,e)]),([a,t])=>!y(a)&&!k(t))):{},async(t,e,s,l,u,d=!1,E=i)=>{const N=va();H(s??{},a=>v(U(a??{}),a=>Ca(N,a)));const g=f(N);if(!d&&u&&E==i&&C(g)&&_(w,t))return await a("DROP "+oa+pa(t)),void aa(w,t);const A=Q(w,t),T=va(f(A));if(C(g)||(_(w,t)?await $(v([e,...g],async(n,s)=>{h(T,n)||(await a(ya+pa(t)+"ADD"+pa(n)+r),0==s&&await a("CREATE UNIQUE INDEX pk ON "+pa(t)+`(${pa(e)})`),Ca(A,n))})):(await a(ga+pa(t)+`(${pa(e)}${r} PRIMARY KEY${m(v(g,a=>n+pa(a)+r))});`),aa(w,t,va([e,...g])))),await $([...!d&&l?v(f(T),async n=>{n!=e&&(await a(ya+pa(t)+"DROP"+pa(n)),h(A,n))}):[]]),d)y(s)?await a(da+pa(t)+ma(t,E)):await $(B(s,async(n,s)=>{y(n)?await a(da+pa(t)+ma(t,E)+`AND(${pa(e)}=$1)`,[s]):C(g)||await o(a,t,e,U(n),{[s]:c?v(X(n),c):X(n)},A)}));else if(C(g))_(w,t)&&await a(da+pa(t)+ma(t,E));else{const n=S(f(Q(w,t)),a=>a!=e),i={},r=[];H(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(da+pa(t)+ma(t,E)+`AND${pa(e)}NOT IN(${Ra(r)})`,r)}},async t=>{let e;return await a("BEGIN"),await O(async()=>e=await t(),s),await a("END"),e}]},qa=async(a,t,e,s,i)=>{const r=[1];await a(ca+" INTO"+pa(t)+"("+((...a)=>m(v(a,pa),n))(e,...s)+")VALUES"+m(B(i,a=>"($"+r[0]+++","+Ra(a,r)+")"),n)+"ON CONFLICT("+pa(e)+`)DO ${wa} SET`+m(v(s,a=>pa(a)+"=excluded."+pa(a)),n),B(i,(a,t)=>[t,...v(a,a=>a??null)]).flat())},za=(a,t,e,n,s,i,r,[o,c,l],w,y,u,d,E,N)=>{const[g,A,T,$]=ka(t,w,y,s,E,N),p=Ya(a,()=>$(async()=>{return await g(),a=(await A(o,c))[na]?.[l]??"null",z(a,(a,t)=>""===t?void 0:t);var a}),a=>$(async()=>{await g(),await T(o,c,{[na]:{[l]:J(a()??null)}},!0,!0)}),e,n,s,r,{[d]:()=>u,destroy:async()=>(await p.stopAutoPersisting(),i(),p)},0,u);return p},Ja=(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]=ka(t,d,E,s,A,T,p,O),I=(a,t)=>$(Z(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,sa,{[na]:a},!0,!0,t):null,_=Ya(a,()=>C(async()=>{await R();const a=await(async()=>j(S(await $(Z(o,async([a,t,e],n)=>[a,await m(n,t,e)])),a=>!k(a[1]))))(),t=await(async()=>l?(await m(u,sa))[na]:{})();return k(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 _},Ka=/^([cd]:)(.+)/,Va=(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=>x(ja,N(a)?{[_a]:a}:a??{}))(a),n=e[Da];if(e.mode==La){const a=e[_a]??t;return[1,n,[a,e[ba]??sa,e[fa]??Ia],va(a)]}const{tables:{load:s={},save:r={}}={},values:o={}}=e,c=A(X(x(xa,o)),0,Y(xa)),l=c[2],w=va(l),y=va(l),u=Wa(s,{[Pa]:null,[ha]:sa,[Ga]:i},Pa,a=>_(y,a),a=>Ca(w,a)),d=Wa(r,{[Fa]:null,[ha]:sa,[Ma]:0,[Ua]:0,[Ga]:null},Fa,(a,t)=>_(y,t),(a,t)=>Ca(w,t));var E;return E=(a,t)=>t[4]??=Q(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(K.encode(a),a=>{t^=a,t+=(t<<1)+(t<<4)+(t<<7)+(t<<8)+(t<<24)}),t>>>0})(J(O)),I=t+"_"+S,L=async(a,e,n="",s="")=>{const i=Oa(t,a,S);return await T(Na+Aa+Ta+i+`()RETURNS ${n}trigger AS $$ ${s}BEGIN ${e}END;$$ LANGUAGE plpgsql;`),i},b=async(a,t,e,n)=>(await T(Na+a+"TRIGGER"+t+e+"EXECUTE "+Ta+n+"()"),t),h=a=>`PERFORM pg_notify('${I}',${a});`,P=(a,t)=>p?i:2===t?P(a,0)+" OR "+P(a,1):r(Q(O[0],a)?.[2]??i,$a,0==t?"NEW":"OLD"),F=(a,e)=>$(v([ca,la,wa],(n,s)=>b(Aa,Oa(t,"d",S,a,n),`AFTER ${n} ON${pa(a)}FOR EACH ROW WHEN(${P(a,s)})`,e)));return(p?za:Ja)(a,T,async a=>{const e=await L("c",`FOR row IN SELECT object_identity FROM pg_event_trigger_ddl_commands()${ra} command_tag='${ga}' LOOP ${h("'c:'||SPLIT_PART(row.object_identity,'.',2)")}END LOOP;`,"event_","DECLARE row record;");await b("EVENT ",Oa(t,"c",S),`ON ddl_command_end WHEN TAG IN('${ga}')`,e);const n=await L("d",h("'d:'||TG_TABLE_NAME")+"RETURN NULL;");return await $(v(f(C),async a=>(await T(ga+` IF NOT EXISTS${pa(a)}("_id"text PRIMARY KEY)`),await F(a,n)))),[await o(I,t=>{return E((e=t,s=Ka,e?.match(s)),async([,t,e])=>{_(C,e)&&("c:"==t&&await F(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(ia+` table_name tn,column_name cn FROM information_schema.columns ${ra} table_schema='public'AND table_name IN(${Ra(t)})`,t),d,g,"text",void 0,a=>q(a),a=>z(a))},Qa=async(a,t,e,n,s)=>{const i=await(t.reserve?.());return Va(a,e,i?.unsafe,async(a,e)=>t.listen(a,e),a=>O(a.unlisten,s),n,s,()=>i?.release?.(),3,t,"getSql")};export{Qa as createPostgresPersister};
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,F=a=>P.getPrototypeOf(a),M=P.entries,U=a=>!w(a)&&d(F(a),a=>a==P.prototype||w(F(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(M(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=a=>new Map(a),aa=(a,t)=>a?.get(t),ta=(a,t)=>v([...a?.entries()??[]],([a,e])=>t(e,a)),ea=(a,t,e)=>y(e)?(h(a,t),a):a?.set(t,e),na=(a,t,e,n)=>(_(a,t)?n?.(aa(a,t)):ea(a,t,e()),aa(a,t)),sa=(a,t,e,n,s=0)=>E((e?na:aa)(a,t[s],s>T(t)-2?e:Z),i=>{if(s>T(t)-2)return n?.(i)&&ea(a,t[s]),i;const r=sa(i,t,e,n,s+1);return b(i)&&ea(a,t[s]),r}),ia="_",ra="_id",oa="SELECT",ca="WHERE",la="TABLE",wa="INSERT",ya="DELETE",ua="UPDATE",da="ALTER "+la,Ea="FROM",Na=ya+" "+Ea,ga=oa+"*"+Ea,Aa="CREATE ",Ta=Aa+la,$a="OR REPLACE ",pa="FUNCTION",Oa="$tableName",Ra=a=>m(v(((a,t="",e)=>a.split(t,e))(a,"."),a=>`"${r(a,/"/g,'""')}"`),"."),ma=(...a)=>Ra(m(a,"_")),va=(a,t=[1])=>m(v(a,()=>"$"+t[0]++),n),Ca=(a,t=i)=>ca+`(${r(t,Oa,Ra(a))})`,Sa=a=>new Set(g(a)||y(a)?a:[a]),Ia=(a,t)=>a?.add(t),La="ColumnName",_a="store",ba="json",fa=_a+"TableName",Da=_a+"Id"+La,ha=_a+La,Pa="autoLoadIntervalSeconds",Fa="rowId"+La,Ma="tableId",Ua="tableName",Ga="deleteEmptyColumns",ja="deleteEmptyTable",xa="condition",Wa={mode:ba,[Pa]:1},Ba={load:0,save:0,[Ua]:t+"_values"},Ha=(a,t,e,n,s)=>{const i=Z();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]),ea(i,r,o))}),i},Xa=/^\d+$/,Ya=Z(),ka=Z(),qa=(a,t,n,s,i,r,o,c={},l=0,w=[])=>{let d,N,A,$=0,m=0,v=0;na(Ya,w,()=>0),na(ka,w,()=>[]);const C=Z(),[S,_,f,P,F]=((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),[M,U,G]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?L(a):null)??e+t++,t=>{Xa.test(t)&&T(a)<1e3&&I(a,t)}]})(),s=Z();return[(n,i,r,o=[],c=()=>[])=>{a??=V;const l=t(1);return ea(s,l,[n,i,r,o,c]),Ia(sa(i,r??[e],Sa),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(aa(a,t),e+1));return s(a,0),n})(t,n),t=>D(t,t=>aa(s,t)[0](a,...n??[],...i))),a=>E(aa(s,a),([,t,i])=>(sa(t,i??[e],void 0,t=>(h(t,a),b(t)?1:0)),ea(s,a),n(a),i)),t=>E(aa(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 a=>(2!=$&&(x(1),m++,await K(async()=>{await O(async()=>{const e=await t();g(e)?W(e):a?F(a):p("Content is not an array: "+e)},()=>{a&&F(a)}),x(0)})),V),H=async a=>(X(),await B(a),await O(async()=>N=await s(async(a,t)=>{t||a?2!=$&&(x(1),m++,W(t??a),x(0)):await B()}),r),V),X=async()=>(N&&(await O(()=>i(N),r),N=void 0),V),Y=async a=>(1!=$&&(x(2),v++,await K(async()=>{await O(()=>n(_,a),r),x(0)})),V),k=async()=>(z(),await Y(),A=a.addDidFinishTransactionListener(()=>{const a=f();P(a)&&Y(a)}),V),z=async()=>(A&&(a.delListener(A),A=void 0),V),J=async(a=!1)=>{const[t,e]=a?[z,X]:[X,z];return await t(),await e(),V},K=async(...a)=>(I(aa(ka,w),...a),await(async()=>{if(!aa(Ya,w)){for(ea(Ya,w,1);!y(d=L(aa(ka,w)));)await O(d,r);ea(Ya,w,0)}})(),V),V={load:B,startAutoLoad:H,stopAutoLoad:X,isAutoLoading:()=>!y(N),save:Y,startAutoSave:k,stopAutoSave:z,isAutoSaving:()=>!y(A),startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[k,H]:[H,k];return await e(a),await n(a),V},stopAutoPersisting:J,getStatus:()=>$,addStatusListener:a=>M(a,C),delListener:t=>(G(t),a),schedule:K,getStore:()=>a,destroy:()=>(aa(ka,w).splice(0,void 0),J()),getStats:()=>({loads:m,saves:v}),...c};return j(V)},za=(a,t,e,s,r,o=Ja,c,l)=>{const w=Z();return[async()=>{w.clear(),v(await e(a,t),({tn:a,cn:t})=>Ia(na(w,a,Sa),t))},async(t,e,n)=>((a,t)=>_(aa(w,a),t))(t,e)?x(S(v(await a(ga+Ra(t)+Ca(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=Sa();X(s??{},a=>v(G(a??{}),a=>Ia(N,a)));const g=f(N);if(!d&&u&&E==i&&C(g)&&_(w,t))return await a("DROP "+la+Ra(t)),void ea(w,t);const A=aa(w,t),T=Sa(f(A));if(C(g)||(_(w,t)?await $(v([e,...g],async(n,s)=>{h(T,n)||(await a(da+Ra(t)+"ADD"+Ra(n)+r),0==s&&await a("CREATE UNIQUE INDEX pk ON "+Ra(t)+`(${Ra(e)})`),Ia(A,n))})):(await a(Ta+Ra(t)+`(${Ra(e)}${r} PRIMARY KEY${m(v(g,a=>n+Ra(a)+r))});`),ea(w,t,Sa([e,...g])))),await $([...!d&&l?v(f(T),async n=>{n!=e&&(await a(da+Ra(t)+"DROP"+Ra(n)),h(A,n))}):[]]),d)y(s)?await a(Na+Ra(t)+Ca(t,E)):await $(H(s,async(n,s)=>{y(n)?await a(Na+Ra(t)+Ca(t,E)+`AND(${Ra(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(Na+Ra(t)+Ca(t,E));else{const n=S(f(aa(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(Na+Ra(t)+Ca(t,E)+`AND${Ra(e)}NOT IN(${va(r)})`,r)}},async t=>{let e;return await a("BEGIN"),await O(async()=>e=await t(),s),await a("END"),e}]},Ja=async(a,t,e,s,i)=>{const r=[1];await a(wa+" INTO"+Ra(t)+"("+((...a)=>m(v(a,Ra),n))(e,...s)+")VALUES"+m(H(i,a=>"($"+r[0]+++","+va(a,r)+")"),n)+"ON CONFLICT("+Ra(e)+`)DO ${ua} SET`+m(v(s,a=>Ra(a)+"=excluded."+Ra(a)),n),H(i,(a,t)=>[t,...v(a,a=>a??null)]).flat())},Ka=(a,t,e,n,s,i,r,[o,c,l],w,y,u,d,E,N)=>{const[g,A,T,$]=za(t,w,y,s,E,N),p=qa(a,()=>$(async()=>{return await g(),a=(await A(o,c))[ia]?.[l]??"null",V(J(a));var a}),a=>$(async()=>{await g(),await T(o,c,{[ia]:{[l]:K(a()??null)}},!0,!0)}),e,n,s,r,{[d]:()=>u,destroy:async()=>(await p.stopAutoPersisting(),i(),p)},0,u);return p},Va=(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]=za(t,d,E,s,A,T,p,O),I=(a,t)=>$(ta(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,ra,{[ia]:a},!0,!0,t):null,_=qa(a,()=>C(async()=>{await R();const a=await(async()=>x(S(await $(ta(o,async([a,t,e],n)=>[a,await m(n,t,e)])),a=>!q(a[1]))))(),t=await(async()=>l?(await m(u,ra))[ia]:{})();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 _},Qa=/^([cd]:)(.+)/,Za=(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(Wa,N(a)?{[fa]:a}:a??{}))(a),n=e[Pa];if(e.mode==ba){const a=e[fa]??t;return[1,n,[a,e[Da]??ra,e[ha]??_a],Sa(a)]}const{tables:{load:s={},save:r={}}={},values:o={}}=e,c=A(Y(W(Ba,o)),0,k(Ba)),l=c[2],w=Sa(l),y=Sa(l),u=Ha(s,{[Ma]:null,[Fa]:ra,[xa]:i},Ma,a=>_(y,a),a=>Ia(w,a)),d=Ha(r,{[Ua]:null,[Fa]:ra,[Ga]:0,[ja]:0,[xa]:null},Ua,(a,t)=>_(y,t),(a,t)=>Ia(w,t));var E;return E=(a,t)=>t[4]??=aa(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=ma(t,a,S);return await T(Aa+$a+pa+i+`()RETURNS ${n}trigger AS $$ ${s}BEGIN ${e}END;$$ LANGUAGE plpgsql;`),i},b=async(a,t,e,n)=>(await T(Aa+a+"TRIGGER"+t+e+"EXECUTE "+pa+n+"()"),t),h=a=>`PERFORM pg_notify('${I}',${a});`,P=(a,t)=>p?i:2===t?P(a,0)+" OR "+P(a,1):r(aa(O[0],a)?.[2]??i,Oa,0==t?"NEW":"OLD"),F=(a,e)=>$(v([wa,ya,ua],(n,s)=>b($a,ma(t,"d",S,a,n),`AFTER ${n} ON${Ra(a)}FOR EACH ROW WHEN(${P(a,s)})`,e)));return(p?Ka:Va)(a,T,async a=>{const e=await L("c",`FOR row IN SELECT object_identity FROM pg_event_trigger_ddl_commands()${ca} command_tag='${Ta}' LOOP ${h("'c:'||SPLIT_PART(row.object_identity,'.',2)")}END LOOP;`,"event_","DECLARE row record;");await b("EVENT ",ma(t,"c",S),`ON ddl_command_end WHEN TAG IN('${Ta}')`,e);const n=await L("d",h("'d:'||TG_TABLE_NAME")+"RETURN NULL;");return await $(v(f(C),async a=>(await T(Ta+` IF NOT EXISTS${Ra(a)}("_id"text PRIMARY KEY)`),await F(a,n)))),[await o(I,t=>{return E((e=t,s=Qa,e?.match(s)),async([,t,e])=>{_(C,e)&&("c:"==t&&await F(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(oa+` table_name tn,column_name cn FROM information_schema.columns ${ca} table_schema='public'AND table_name IN(${va(t)})`,t),d,g,"text",void 0,a=>z(a),a=>J(a))},at=async(a,t,e,n,s)=>{const i=await(t.reserve?.());return Za(a,e,i?.unsafe,async(a,e)=>t.listen(a,e),a=>O(a.unlisten,s),n,s,()=>i?.release?.(),3,t,"getSql")};export{at as createPostgresPersister};
@@ -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,F=a=>P.getPrototypeOf(a),M=P.entries,U=P.keys,G=P.freeze,j=(a=[])=>P.fromEntries(a),x=(...a)=>P.assign({},...a),W=(a,t)=>(delete a[t],a),B=(a,t)=>v(M(a),([a,e])=>t(e,a)),H=(a,t)=>j(B(a,(a,e)=>[e,t(a,e)])),X=a=>P.values(a),Y=a=>T(U(a)),k=a=>(a=>!w(a)&&d(F(a),a=>a==P.prototype||w(F(a)),()=>!0))(a)&&0==Y(a),q=JSON.stringify,z=JSON.parse,J=a=>q(a,(a,t)=>y(t)?"":t),K=new l.TextEncoder,V=a=>new Map(a),Q=(a,t)=>a?.get(t),Z=(a,t)=>v([...a?.entries()??[]],([a,e])=>t(e,a)),aa=(a,t,e)=>y(e)?(h(a,t),a):a?.set(t,e),ta=(a,t,e,n)=>(_(a,t)?n?.(Q(a,t)):aa(a,t,e()),Q(a,t)),ea=(a,t,e,n,s=0)=>E((e?ta:Q)(a,t[s],s>T(t)-2?e:V),i=>{if(s>T(t)-2)return n?.(i)&&aa(a,t[s]),i;const r=ea(i,t,e,n,s+1);return b(i)&&aa(a,t[s]),r}),na="_",sa="_id",ia="SELECT",ra="WHERE",oa="TABLE",ca="INSERT",la="DELETE",wa="UPDATE",ya="ALTER "+oa,ua="FROM",da=la+" "+ua,Ea=ia+"*"+ua,Na="CREATE ",ga=Na+oa,Aa="OR REPLACE ",Ta="FUNCTION",$a="$tableName",pa=a=>m(v(((a,t="",e)=>a.split(t,e))(a,"."),a=>`"${r(a,/"/g,'""')}"`),"."),Oa=(...a)=>pa(m(a,"_")),Ra=(a,t=[1])=>m(v(a,()=>"$"+t[0]++),n),ma=(a,t=i)=>ra+`(${r(t,$a,pa(a))})`,va=a=>new Set(g(a)||y(a)?a:[a]),Ca=(a,t)=>a?.add(t),Sa="ColumnName",Ia="store",La="json",_a=Ia+"TableName",ba=Ia+"Id"+Sa,fa=Ia+Sa,Da="autoLoadIntervalSeconds",ha="rowId"+Sa,Pa="tableId",Fa="tableName",Ma="deleteEmptyColumns",Ua="deleteEmptyTable",Ga="condition",ja={mode:La,[Da]:1},xa={load:0,save:0,[Fa]:t+"_values"},Wa=(a,t,e,n,s)=>{const i=V();return H(a,(a,r)=>{const o=A(X(x(t,N(a)?{[e]:a}:a)),0,Y(t));u(o[0])||n(r,o[0])||(s(r,o[0]),aa(i,r,o))}),i},Ba=/^\d+$/,Ha=V(),Xa=V(),Ya=(a,t,n,s,i,r,o,c={},l=0,w=[])=>{let d,N,A,$=0,m=0,v=0;ta(Ha,w,()=>0),ta(Xa,w,()=>[]);const C=V(),[S,_,f,P,F]=((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]:p("Store type not supported by this Persister"))(o,a,l),[M,U,j]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?L(a):null)??e+t++,t=>{Ba.test(t)&&T(a)<1e3&&I(a,t)}]})(),s=V();return[(n,i,r,o=[],c=()=>[])=>{a??=Z;const l=t(1);return aa(s,l,[n,i,r,o,c]),Ca(ea(i,r??[e],va),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(Q(a,t),e+1));return s(a,0),n})(t,n),t=>D(t,t=>Q(s,t)[0](a,...n??[],...i))),a=>E(Q(s,a),([,t,i])=>(ea(t,i??[e],void 0,t=>(h(t,a),b(t)?1:0)),aa(s,a),n(a),i)),t=>E(Q(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 a=>(2!=$&&(x(1),m++,await K(async()=>{await O(async()=>{const e=await t();g(e)?W(e):a?F(a):p("Content is not an array: "+e)},()=>{a&&F(a)}),x(0)})),Z),H=async a=>(X(),await B(a),await O(async()=>N=await s(async(a,t)=>{t||a?2!=$&&(x(1),m++,W(t??a),x(0)):await B()}),r),Z),X=async()=>(N&&(await O(()=>i(N),r),N=void 0),Z),Y=async a=>(1!=$&&(x(2),v++,await K(async()=>{await O(()=>n(_,a),r),x(0)})),Z),q=async()=>(z(),await Y(),A=a.addDidFinishTransactionListener(()=>{const a=f();P(a)&&Y(a)}),Z),z=async()=>(A&&(a.delListener(A),A=void 0),Z),J=async(a=!1)=>{const[t,e]=a?[z,X]:[X,z];return await t(),await e(),Z},K=async(...a)=>(I(Q(Xa,w),...a),await(async()=>{if(!Q(Ha,w)){for(aa(Ha,w,1);!y(d=L(Q(Xa,w)));)await O(d,r);aa(Ha,w,0)}})(),Z),Z={load:B,startAutoLoad:H,stopAutoLoad:X,isAutoLoading:()=>!y(N),save:Y,startAutoSave:q,stopAutoSave:z,isAutoSaving:()=>!y(A),startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[q,H]:[H,q];return await e(a),await n(a),Z},stopAutoPersisting:J,getStatus:()=>$,addStatusListener:a=>M(a,C),delListener:t=>(j(t),a),schedule:K,getStore:()=>a,destroy:()=>(Q(Xa,w).splice(0,void 0),J()),getStats:()=>({loads:m,saves:v}),...c};return G(Z)},ka=(a,t,e,s,r,o=qa,c,l)=>{const w=V();return[async()=>{w.clear(),v(await e(a,t),({tn:a,cn:t})=>Ca(ta(w,a,va),t))},async(t,e,n)=>((a,t)=>_(Q(w,a),t))(t,e)?j(S(v(await a(Ea+pa(t)+ma(t,n)),a=>[a[e],l?H(W(a,e),l):W(a,e)]),([a,t])=>!y(a)&&!k(t))):{},async(t,e,s,l,u,d=!1,E=i)=>{const N=va();H(s??{},a=>v(U(a??{}),a=>Ca(N,a)));const g=f(N);if(!d&&u&&E==i&&C(g)&&_(w,t))return await a("DROP "+oa+pa(t)),void aa(w,t);const A=Q(w,t),T=va(f(A));if(C(g)||(_(w,t)?await $(v([e,...g],async(n,s)=>{h(T,n)||(await a(ya+pa(t)+"ADD"+pa(n)+r),0==s&&await a("CREATE UNIQUE INDEX pk ON "+pa(t)+`(${pa(e)})`),Ca(A,n))})):(await a(ga+pa(t)+`(${pa(e)}${r} PRIMARY KEY${m(v(g,a=>n+pa(a)+r))});`),aa(w,t,va([e,...g])))),await $([...!d&&l?v(f(T),async n=>{n!=e&&(await a(ya+pa(t)+"DROP"+pa(n)),h(A,n))}):[]]),d)y(s)?await a(da+pa(t)+ma(t,E)):await $(B(s,async(n,s)=>{y(n)?await a(da+pa(t)+ma(t,E)+`AND(${pa(e)}=$1)`,[s]):C(g)||await o(a,t,e,U(n),{[s]:c?v(X(n),c):X(n)},A)}));else if(C(g))_(w,t)&&await a(da+pa(t)+ma(t,E));else{const n=S(f(Q(w,t)),a=>a!=e),i={},r=[];H(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(da+pa(t)+ma(t,E)+`AND${pa(e)}NOT IN(${Ra(r)})`,r)}},async t=>{let e;return await a("BEGIN"),await O(async()=>e=await t(),s),await a("END"),e}]},qa=async(a,t,e,s,i)=>{const r=[1];await a(ca+" INTO"+pa(t)+"("+((...a)=>m(v(a,pa),n))(e,...s)+")VALUES"+m(B(i,a=>"($"+r[0]+++","+Ra(a,r)+")"),n)+"ON CONFLICT("+pa(e)+`)DO ${wa} SET`+m(v(s,a=>pa(a)+"=excluded."+pa(a)),n),B(i,(a,t)=>[t,...v(a,a=>a??null)]).flat())},za=(a,t,e,n,s,i,r,[o,c,l],w,y,u,d,E,N)=>{const[g,A,T,$]=ka(t,w,y,s,E,N),p=Ya(a,()=>$(async()=>{return await g(),a=(await A(o,c))[na]?.[l]??"null",z(a,(a,t)=>""===t?void 0:t);var a}),a=>$(async()=>{await g(),await T(o,c,{[na]:{[l]:J(a()??null)}},!0,!0)}),e,n,s,r,{[d]:()=>u,destroy:async()=>(await p.stopAutoPersisting(),i(),p)},0,u);return p},Ja=(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]=ka(t,d,E,s,A,T,p,O),I=(a,t)=>$(Z(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,sa,{[na]:a},!0,!0,t):null,_=Ya(a,()=>C(async()=>{await R();const a=await(async()=>j(S(await $(Z(o,async([a,t,e],n)=>[a,await m(n,t,e)])),a=>!k(a[1]))))(),t=await(async()=>l?(await m(u,sa))[na]:{})();return k(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 _},Ka=/^([cd]:)(.+)/,Va=(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=>x(ja,N(a)?{[_a]:a}:a??{}))(a),n=e[Da];if(e.mode==La){const a=e[_a]??t;return[1,n,[a,e[ba]??sa,e[fa]??Ia],va(a)]}const{tables:{load:s={},save:r={}}={},values:o={}}=e,c=A(X(x(xa,o)),0,Y(xa)),l=c[2],w=va(l),y=va(l),u=Wa(s,{[Pa]:null,[ha]:sa,[Ga]:i},Pa,a=>_(y,a),a=>Ca(w,a)),d=Wa(r,{[Fa]:null,[ha]:sa,[Ma]:0,[Ua]:0,[Ga]:null},Fa,(a,t)=>_(y,t),(a,t)=>Ca(w,t));var E;return E=(a,t)=>t[4]??=Q(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(K.encode(a),a=>{t^=a,t+=(t<<1)+(t<<4)+(t<<7)+(t<<8)+(t<<24)}),t>>>0})(J(O)),I=t+"_"+S,L=async(a,e,n="",s="")=>{const i=Oa(t,a,S);return await T(Na+Aa+Ta+i+`()RETURNS ${n}trigger AS $$ ${s}BEGIN ${e}END;$$ LANGUAGE plpgsql;`),i},b=async(a,t,e,n)=>(await T(Na+a+"TRIGGER"+t+e+"EXECUTE "+Ta+n+"()"),t),h=a=>`PERFORM pg_notify('${I}',${a});`,P=(a,t)=>p?i:2===t?P(a,0)+" OR "+P(a,1):r(Q(O[0],a)?.[2]??i,$a,0==t?"NEW":"OLD"),F=(a,e)=>$(v([ca,la,wa],(n,s)=>b(Aa,Oa(t,"d",S,a,n),`AFTER ${n} ON${pa(a)}FOR EACH ROW WHEN(${P(a,s)})`,e)));return(p?za:Ja)(a,T,async a=>{const e=await L("c",`FOR row IN SELECT object_identity FROM pg_event_trigger_ddl_commands()${ra} command_tag='${ga}' LOOP ${h("'c:'||SPLIT_PART(row.object_identity,'.',2)")}END LOOP;`,"event_","DECLARE row record;");await b("EVENT ",Oa(t,"c",S),`ON ddl_command_end WHEN TAG IN('${ga}')`,e);const n=await L("d",h("'d:'||TG_TABLE_NAME")+"RETURN NULL;");return await $(v(f(C),async a=>(await T(ga+` IF NOT EXISTS${pa(a)}("_id"text PRIMARY KEY)`),await F(a,n)))),[await o(I,t=>{return E((e=t,s=Ka,e?.match(s)),async([,t,e])=>{_(C,e)&&("c:"==t&&await F(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(ia+` table_name tn,column_name cn FROM information_schema.columns ${ra} table_schema='public'AND table_name IN(${Ra(t)})`,t),d,g,"text",void 0,a=>q(a),a=>z(a))},Qa=async(a,t,e,n,s)=>{const i=await(t.reserve?.());return Va(a,e,i?.unsafe,async(a,e)=>t.listen(a,e),a=>O(a.unlisten,s),n,s,()=>i?.release?.(),3,t,"getSql")};export{Qa as createPostgresPersister};
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,F=a=>P.getPrototypeOf(a),M=P.entries,U=a=>!w(a)&&d(F(a),a=>a==P.prototype||w(F(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(M(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=a=>new Map(a),aa=(a,t)=>a?.get(t),ta=(a,t)=>v([...a?.entries()??[]],([a,e])=>t(e,a)),ea=(a,t,e)=>y(e)?(h(a,t),a):a?.set(t,e),na=(a,t,e,n)=>(_(a,t)?n?.(aa(a,t)):ea(a,t,e()),aa(a,t)),sa=(a,t,e,n,s=0)=>E((e?na:aa)(a,t[s],s>T(t)-2?e:Z),i=>{if(s>T(t)-2)return n?.(i)&&ea(a,t[s]),i;const r=sa(i,t,e,n,s+1);return b(i)&&ea(a,t[s]),r}),ia="_",ra="_id",oa="SELECT",ca="WHERE",la="TABLE",wa="INSERT",ya="DELETE",ua="UPDATE",da="ALTER "+la,Ea="FROM",Na=ya+" "+Ea,ga=oa+"*"+Ea,Aa="CREATE ",Ta=Aa+la,$a="OR REPLACE ",pa="FUNCTION",Oa="$tableName",Ra=a=>m(v(((a,t="",e)=>a.split(t,e))(a,"."),a=>`"${r(a,/"/g,'""')}"`),"."),ma=(...a)=>Ra(m(a,"_")),va=(a,t=[1])=>m(v(a,()=>"$"+t[0]++),n),Ca=(a,t=i)=>ca+`(${r(t,Oa,Ra(a))})`,Sa=a=>new Set(g(a)||y(a)?a:[a]),Ia=(a,t)=>a?.add(t),La="ColumnName",_a="store",ba="json",fa=_a+"TableName",Da=_a+"Id"+La,ha=_a+La,Pa="autoLoadIntervalSeconds",Fa="rowId"+La,Ma="tableId",Ua="tableName",Ga="deleteEmptyColumns",ja="deleteEmptyTable",xa="condition",Wa={mode:ba,[Pa]:1},Ba={load:0,save:0,[Ua]:t+"_values"},Ha=(a,t,e,n,s)=>{const i=Z();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]),ea(i,r,o))}),i},Xa=/^\d+$/,Ya=Z(),ka=Z(),qa=(a,t,n,s,i,r,o,c={},l=0,w=[])=>{let d,N,A,$=0,m=0,v=0;na(Ya,w,()=>0),na(ka,w,()=>[]);const C=Z(),[S,_,f,P,F]=((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),[M,U,G]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?L(a):null)??e+t++,t=>{Xa.test(t)&&T(a)<1e3&&I(a,t)}]})(),s=Z();return[(n,i,r,o=[],c=()=>[])=>{a??=V;const l=t(1);return ea(s,l,[n,i,r,o,c]),Ia(sa(i,r??[e],Sa),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(aa(a,t),e+1));return s(a,0),n})(t,n),t=>D(t,t=>aa(s,t)[0](a,...n??[],...i))),a=>E(aa(s,a),([,t,i])=>(sa(t,i??[e],void 0,t=>(h(t,a),b(t)?1:0)),ea(s,a),n(a),i)),t=>E(aa(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 a=>(2!=$&&(x(1),m++,await K(async()=>{await O(async()=>{const e=await t();g(e)?W(e):a?F(a):p("Content is not an array: "+e)},()=>{a&&F(a)}),x(0)})),V),H=async a=>(X(),await B(a),await O(async()=>N=await s(async(a,t)=>{t||a?2!=$&&(x(1),m++,W(t??a),x(0)):await B()}),r),V),X=async()=>(N&&(await O(()=>i(N),r),N=void 0),V),Y=async a=>(1!=$&&(x(2),v++,await K(async()=>{await O(()=>n(_,a),r),x(0)})),V),k=async()=>(z(),await Y(),A=a.addDidFinishTransactionListener(()=>{const a=f();P(a)&&Y(a)}),V),z=async()=>(A&&(a.delListener(A),A=void 0),V),J=async(a=!1)=>{const[t,e]=a?[z,X]:[X,z];return await t(),await e(),V},K=async(...a)=>(I(aa(ka,w),...a),await(async()=>{if(!aa(Ya,w)){for(ea(Ya,w,1);!y(d=L(aa(ka,w)));)await O(d,r);ea(Ya,w,0)}})(),V),V={load:B,startAutoLoad:H,stopAutoLoad:X,isAutoLoading:()=>!y(N),save:Y,startAutoSave:k,stopAutoSave:z,isAutoSaving:()=>!y(A),startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[k,H]:[H,k];return await e(a),await n(a),V},stopAutoPersisting:J,getStatus:()=>$,addStatusListener:a=>M(a,C),delListener:t=>(G(t),a),schedule:K,getStore:()=>a,destroy:()=>(aa(ka,w).splice(0,void 0),J()),getStats:()=>({loads:m,saves:v}),...c};return j(V)},za=(a,t,e,s,r,o=Ja,c,l)=>{const w=Z();return[async()=>{w.clear(),v(await e(a,t),({tn:a,cn:t})=>Ia(na(w,a,Sa),t))},async(t,e,n)=>((a,t)=>_(aa(w,a),t))(t,e)?x(S(v(await a(ga+Ra(t)+Ca(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=Sa();X(s??{},a=>v(G(a??{}),a=>Ia(N,a)));const g=f(N);if(!d&&u&&E==i&&C(g)&&_(w,t))return await a("DROP "+la+Ra(t)),void ea(w,t);const A=aa(w,t),T=Sa(f(A));if(C(g)||(_(w,t)?await $(v([e,...g],async(n,s)=>{h(T,n)||(await a(da+Ra(t)+"ADD"+Ra(n)+r),0==s&&await a("CREATE UNIQUE INDEX pk ON "+Ra(t)+`(${Ra(e)})`),Ia(A,n))})):(await a(Ta+Ra(t)+`(${Ra(e)}${r} PRIMARY KEY${m(v(g,a=>n+Ra(a)+r))});`),ea(w,t,Sa([e,...g])))),await $([...!d&&l?v(f(T),async n=>{n!=e&&(await a(da+Ra(t)+"DROP"+Ra(n)),h(A,n))}):[]]),d)y(s)?await a(Na+Ra(t)+Ca(t,E)):await $(H(s,async(n,s)=>{y(n)?await a(Na+Ra(t)+Ca(t,E)+`AND(${Ra(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(Na+Ra(t)+Ca(t,E));else{const n=S(f(aa(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(Na+Ra(t)+Ca(t,E)+`AND${Ra(e)}NOT IN(${va(r)})`,r)}},async t=>{let e;return await a("BEGIN"),await O(async()=>e=await t(),s),await a("END"),e}]},Ja=async(a,t,e,s,i)=>{const r=[1];await a(wa+" INTO"+Ra(t)+"("+((...a)=>m(v(a,Ra),n))(e,...s)+")VALUES"+m(H(i,a=>"($"+r[0]+++","+va(a,r)+")"),n)+"ON CONFLICT("+Ra(e)+`)DO ${ua} SET`+m(v(s,a=>Ra(a)+"=excluded."+Ra(a)),n),H(i,(a,t)=>[t,...v(a,a=>a??null)]).flat())},Ka=(a,t,e,n,s,i,r,[o,c,l],w,y,u,d,E,N)=>{const[g,A,T,$]=za(t,w,y,s,E,N),p=qa(a,()=>$(async()=>{return await g(),a=(await A(o,c))[ia]?.[l]??"null",V(J(a));var a}),a=>$(async()=>{await g(),await T(o,c,{[ia]:{[l]:K(a()??null)}},!0,!0)}),e,n,s,r,{[d]:()=>u,destroy:async()=>(await p.stopAutoPersisting(),i(),p)},0,u);return p},Va=(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]=za(t,d,E,s,A,T,p,O),I=(a,t)=>$(ta(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,ra,{[ia]:a},!0,!0,t):null,_=qa(a,()=>C(async()=>{await R();const a=await(async()=>x(S(await $(ta(o,async([a,t,e],n)=>[a,await m(n,t,e)])),a=>!q(a[1]))))(),t=await(async()=>l?(await m(u,ra))[ia]:{})();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 _},Qa=/^([cd]:)(.+)/,Za=(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(Wa,N(a)?{[fa]:a}:a??{}))(a),n=e[Pa];if(e.mode==ba){const a=e[fa]??t;return[1,n,[a,e[Da]??ra,e[ha]??_a],Sa(a)]}const{tables:{load:s={},save:r={}}={},values:o={}}=e,c=A(Y(W(Ba,o)),0,k(Ba)),l=c[2],w=Sa(l),y=Sa(l),u=Ha(s,{[Ma]:null,[Fa]:ra,[xa]:i},Ma,a=>_(y,a),a=>Ia(w,a)),d=Ha(r,{[Ua]:null,[Fa]:ra,[Ga]:0,[ja]:0,[xa]:null},Ua,(a,t)=>_(y,t),(a,t)=>Ia(w,t));var E;return E=(a,t)=>t[4]??=aa(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=ma(t,a,S);return await T(Aa+$a+pa+i+`()RETURNS ${n}trigger AS $$ ${s}BEGIN ${e}END;$$ LANGUAGE plpgsql;`),i},b=async(a,t,e,n)=>(await T(Aa+a+"TRIGGER"+t+e+"EXECUTE "+pa+n+"()"),t),h=a=>`PERFORM pg_notify('${I}',${a});`,P=(a,t)=>p?i:2===t?P(a,0)+" OR "+P(a,1):r(aa(O[0],a)?.[2]??i,Oa,0==t?"NEW":"OLD"),F=(a,e)=>$(v([wa,ya,ua],(n,s)=>b($a,ma(t,"d",S,a,n),`AFTER ${n} ON${Ra(a)}FOR EACH ROW WHEN(${P(a,s)})`,e)));return(p?Ka:Va)(a,T,async a=>{const e=await L("c",`FOR row IN SELECT object_identity FROM pg_event_trigger_ddl_commands()${ca} command_tag='${Ta}' LOOP ${h("'c:'||SPLIT_PART(row.object_identity,'.',2)")}END LOOP;`,"event_","DECLARE row record;");await b("EVENT ",ma(t,"c",S),`ON ddl_command_end WHEN TAG IN('${Ta}')`,e);const n=await L("d",h("'d:'||TG_TABLE_NAME")+"RETURN NULL;");return await $(v(f(C),async a=>(await T(Ta+` IF NOT EXISTS${Ra(a)}("_id"text PRIMARY KEY)`),await F(a,n)))),[await o(I,t=>{return E((e=t,s=Qa,e?.match(s)),async([,t,e])=>{_(C,e)&&("c:"==t&&await F(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(oa+` table_name tn,column_name cn FROM information_schema.columns ${ca} table_schema='public'AND table_name IN(${va(t)})`,t),d,g,"text",void 0,a=>z(a),a=>J(a))},at=async(a,t,e,n,s)=>{const i=await(t.reserve?.());return Za(a,e,i?.unsafe,async(a,e)=>t.listen(a,e),a=>O(a.unlisten,s),n,s,()=>i?.release?.(),3,t,"getSql")};export{at as createPostgresPersister};
@@ -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)}},C=(a,t)=>a.forEach(t),T=(a,t="")=>a.join(t),b=(a,t)=>a.map(t),h=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=_.keys,x=_.freeze,B=(a=[])=>_.fromEntries(a),J=(...a)=>_.assign({},...a),Y=(a,t)=>(delete a[t],a),k=(a,t)=>b(U(a),([a,e])=>t(e,a)),z=(a,t)=>B(k(a,(a,e)=>[e,t(a,e)])),G=a=>_.values(a),H=a=>A(j(a)),V=a=>(a=>!w(a)&&d(F(a),a=>a==_.prototype||w(F(a)),()=>!0))(a)&&0==H(a),K=a=>new Set(v(a)||y(a)?a:[a]),Q=(a,t)=>a?.add(t),W="_",X="_id",q="SELECT",Z="WHERE",aa="TABLE",ta="INSERT",ea="ALTER "+aa,na="FROM",sa="DELETE "+na,ia=q+"*"+na,ra="pragma_",oa="data_version",ca="schema_version",la="pragma_table_",wa="CREATE "+aa,ya=a=>T(b(((a,t="",e)=>a.split(t,e))(a,"."),a=>`"${r(a,/"/g,'""')}"`),"."),ua=(...a)=>T(b(a,ya),n),da=(a,t=[1])=>T(b(a,()=>"$"+t[0]++),n),ga=(a,t=i)=>Z+`(${r(t,"$tableName",ya(a))})`,Ea=a=>new Map(a),va=(a,t)=>a?.get(t),pa=(a,t)=>b([...a?.entries()??[]],([a,e])=>t(e,a)),Aa=(a,t,e)=>y(e)?(M(a,t),a):a?.set(t,e),Na=(a,t,e,n)=>(D(a,t)?n?.(va(a,t)):Aa(a,t,e()),va(a,t)),ma=(a,t,e,n,s=0)=>g((e?Na:va)(a,t[s],s>A(t)-2?e:Ea),i=>{if(s>A(t)-2)return n?.(i)&&Aa(a,t[s]),i;const r=ma(i,t,e,n,s+1);return L(i)&&Aa(a,t[s]),r}),$a="ColumnName",fa="store",Ca="json",Ta=fa+"TableName",ba=fa+"Id"+$a,ha=fa+$a,Oa="autoLoadIntervalSeconds",Ia="rowId"+$a,Sa="tableId",Da="tableName",La="deleteEmptyColumns",Ra="deleteEmptyTable",Pa="condition",Ma={mode:Ca,[Oa]:1},_a={load:0,save:0,[Da]:t+"_values"},Fa=(a,t,e,n,s)=>{const i=Ea();return z(a,(a,r)=>{const o=p(G(J(t,E(a)?{[e]:a}:a)),0,H(t));u(o[0])||n(r,o[0])||(s(r,o[0]),Aa(i,r,o))}),i},Ua=JSON.stringify,ja=JSON.parse,xa=/^\d+$/,Ba=Ea(),Ja=Ea(),Ya=(a,t,n,s,i,r,o,c={},l=0,w=[])=>{let d,E,p,N=0,m=0,T=0;Na(Ba,w,()=>0),Na(Ja,w,()=>[]);const b=Ea(),[h,O,D,R,_]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!V(a)||!V(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!V(a)||!V(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=>{xa.test(t)&&A(a)<1e3&&I(a,t)}]})(),s=Ea();return[(n,i,r,o=[],c=()=>[])=>{a??=Z;const l=t(1);return Aa(s,l,[n,i,r,o,c]),Q(ma(i,r??[e],K),l),l},(t,n,...i)=>C(((a,t=[e])=>{const n=[],s=(a,e)=>e==A(t)?I(n,a):u(t[e])?P(a,a=>s(a,e+1)):C([t[e],null],t=>s(va(a,t),e+1));return s(a,0),n})(t,n),t=>P(t,t=>va(s,t)[0](a,...n??[],...i))),a=>g(va(s,a),([,t,i])=>(ma(t,i??[e],void 0,t=>(M(t,a),L(t)?1:0)),Aa(s,a),n(a),i)),t=>g(va(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(b,void 0,N))},J=t=>{(h&&v(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();v(e)?J(e):a?_(a):$("Content is not an array: "+e)},()=>{a&&_(a)}),B(0)})),Z),k=async a=>(z(),await Y(a),await f(async()=>E=await s(async(a,t)=>{t||a?2!=N&&(B(1),m++,J(t??a),B(0)):await Y()}),r),Z),z=async()=>(E&&(await f(()=>i(E),r),E=void 0),Z),G=async a=>(1!=N&&(B(2),T++,await q(async()=>{await f(()=>n(O,a),r),B(0)})),Z),H=async()=>(W(),await G(),p=a.addDidFinishTransactionListener(()=>{const a=D();R(a)&&G(a)}),Z),W=async()=>(p&&(a.delListener(p),p=void 0),Z),X=async(a=!1)=>{const[t,e]=a?[W,z]:[z,W];return await t(),await e(),Z},q=async(...a)=>(I(va(Ja,w),...a),await(async()=>{if(!va(Ba,w)){for(Aa(Ba,w,1);!y(d=S(va(Ja,w)));)await f(d,r);Aa(Ba,w,0)}})(),Z),Z={load:Y,startAutoLoad:k,stopAutoLoad:z,isAutoLoading:()=>!y(E),save:G,startAutoSave:H,stopAutoSave:W,isAutoSaving:()=>!y(p),startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[H,k]:[k,H];return await e(a),await n(a),Z},stopAutoPersisting:X,getStatus:()=>N,addStatusListener:a=>F(a,b),delListener:t=>(j(t),a),schedule:q,getStore:()=>a,destroy:()=>(va(Ja,w).splice(0,void 0),X()),getStats:()=>({loads:m,saves:T}),...c};return x(Z)},ka=(a,t,e,s,r,o=za,c,l)=>{const w=Ea();return[async()=>{w.clear(),b(await e(a,t),({tn:a,cn:t})=>Q(Na(w,a,K),t))},async(t,e,n)=>((a,t)=>D(va(w,a),t))(t,e)?B(O(b(await a(ia+ya(t)+ga(t,n)),a=>[a[e],l?z(Y(a,e),l):Y(a,e)]),([a,t])=>!y(a)&&!V(t))):{},async(t,e,s,l,u,d=!1,g=i)=>{const E=K();z(s??{},a=>b(j(a??{}),a=>Q(E,a)));const v=R(E);if(!d&&u&&g==i&&h(v)&&D(w,t))return await a("DROP "+aa+ya(t)),void Aa(w,t);const p=va(w,t),A=K(R(p));if(h(v)||(D(w,t)?await m(b([e,...v],async(n,s)=>{M(A,n)||(await a(ea+ya(t)+"ADD"+ya(n)+r),0==s&&await a("CREATE UNIQUE INDEX pk ON "+ya(t)+`(${ya(e)})`),Q(p,n))})):(await a(wa+ya(t)+`(${ya(e)}${r} PRIMARY KEY${T(b(v,a=>n+ya(a)+r))});`),Aa(w,t,K([e,...v])))),await m([...!d&&l?b(R(A),async n=>{n!=e&&(await a(ea+ya(t)+"DROP"+ya(n)),M(p,n))}):[]]),d)y(s)?await a(sa+ya(t)+ga(t,g)):await m(k(s,async(n,s)=>{y(n)?await a(sa+ya(t)+ga(t,g)+`AND(${ya(e)}=$1)`,[s]):h(v)||await o(a,t,e,j(n),{[s]:c?b(G(n),c):G(n)},p)}));else if(h(v))D(w,t)&&await a(sa+ya(t)+ga(t,g));else{const n=O(R(va(w,t)),a=>a!=e),i={},r=[];z(s??{},(a,t)=>{i[t]=b(n,t=>c?c(a?.[t]):a?.[t]),I(r,t)}),await o(a,t,e,n,i),await a(sa+ya(t)+ga(t,g)+`AND${ya(e)}NOT IN(${da(r)})`,r)}},async t=>{let e;return await a("BEGIN"),await f(async()=>e=await t(),s),await a("END"),e}]},za=async(a,t,e,s,i)=>{const r=[1];await a(ta+" INTO"+ya(t)+"("+ua(e,...s)+")VALUES"+T(k(i,a=>"($"+r[0]+++","+da(a,r)+")"),n)+"ON CONFLICT("+ya(e)+")DO UPDATE SET"+T(b(s,a=>ya(a)+"=excluded."+ya(a)),n),k(i,(a,t)=>[t,...b(a,a=>a??null)]).flat())},Ga=(a,t,e,n,s,i,r,[o,c,l],w,u,d,g,E,v)=>{const[p,A,N,m]=ka(t,w,u,s,E,v),$=Ya(a,()=>m(async()=>{return await p(),a=(await A(o,c))[W]?.[l]??"null",ja(a,(a,t)=>""===t?void 0:t);var a}),a=>m(async()=>{var t;await p(),await N(o,c,{[W]:{[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 $},Ha=(a,t,e,n,s,i,r,[o,c,[l,w,u]],d,g,E,v,p,A,N,$)=>{const[f,C,T,b]=ka(t,d,g,s,p,A,N,$),h=(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)})),I=async(a,t)=>w?await T(u,X,{[W]:a},!0,!0,t):null,S=Ya(a,()=>b(async()=>{await f();const a=await(async()=>B(O(await m(pa(o,async([a,t,e],n)=>[a,await C(n,t,e)])),a=>!V(a[1]))))(),t=await(async()=>l?(await C(u,X))[W]:{})();return V(a)&&y(t)?void 0:[a,t]}),(a,t)=>b(async()=>{if(await f(),y(t)){const[t,e]=a();await h(t),await I(e)}else await h(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},Va=(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,b,h,O]=(a=>{const e=(a=>J(Ma,E(a)?{[Ta]:a}:a??{}))(a),n=e[Oa];if(e.mode==Ca){const a=e[Ta]??t;return[1,n,[a,e[ba]??X,e[ha]??fa],K(a)]}const{tables:{load:s={},save:r={}}={},values:o={}}=e,c=p(G(J(_a,o)),0,H(_a)),l=c[2],w=K(l),y=K(l),u=Fa(s,{[Sa]:null,[Ia]:X,[Pa]:i},Sa,a=>D(y,a),a=>Q(w,a)),d=Fa(r,{[Da]:null,[Ia]:X,[La]:0,[Ra]:0,[Pa]:null},Da,(a,t)=>D(y,t),(a,t)=>Q(w,t));var g;return g=(a,t)=>t[4]??=va(u,t[0])?.[2]??i,P(d,(a,t)=>g(0,a)),[0,n,[u,d,c],w]})(n);return(T?Ga:Ha)(a,C,a=>{let t;const e=()=>t=setInterval(()=>f(async()=>{const[{d:t,s:e,c:n}]=await C(q+` ${oa} d,${ca} s,TOTAL_CHANGES() c FROM ${ra}${oa} JOIN ${ra}${ca}`);t==N&&e==m&&n==$||(w(N)||a(),N=t,m=e,$=n)}),1e3*b),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,h,R(O),async(a,t)=>await a(q+` t.name tn,c.name cn FROM ${la}list()t,${la}info(t.name)c ${Z} t.schema='main'AND t.type IN('table','view')AND t.name IN(${da(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)},Ka=(a,t,e,n,s)=>{let i;return Va(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&&b(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=K(s),l=r?O([...r],a=>a!=e&&!D(c,a)):[];if(!h(l)){const n=j(i),s=B(b(await a(q+ua(e,...l)+na+ya(t)+Z+ya(e)+"IN("+da(n)+")",n),a=>[a[e],a]));C(n,a=>I(i[a],...b(l,t=>s?.[a]?.[t]??null)))}await a(ta+" OR REPLACE INTO"+ya(t)+"("+ua(e,...s,...l)+")VALUES"+T(k(i,a=>"($"+o[0]+++","+da(a,o)+")"),n),k(i,(a,t)=>[t,...b(a,a=>a??null)]).flat())};export{Ka as createPowerSyncPersister};
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)}},C=(a,t)=>a.forEach(t),T=(a,t="")=>a.join(t),b=(a,t)=>a.map(t),h=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)=>b(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=>T(b(((a,t="",e)=>a.split(t,e))(a,"."),a=>`"${r(a,/"/g,'""')}"`),"."),da=(...a)=>T(b(a,ua),n),ga=(a,t=[1])=>T(b(a,()=>"$"+t[0]++),n),Ea=(a,t=i)=>aa+`(${r(t,"$tableName",ua(a))})`,va=a=>new Map(a),pa=(a,t)=>a?.get(t),Aa=(a,t)=>b([...a?.entries()??[]],([a,e])=>t(e,a)),Na=(a,t,e)=>y(e)?(M(a,t),a):a?.set(t,e),ma=(a,t,e,n)=>(D(a,t)?n?.(pa(a,t)):Na(a,t,e()),pa(a,t)),$a=(a,t,e,n,s=0)=>g((e?ma:pa)(a,t[s],s>A(t)-2?e:va),i=>{if(s>A(t)-2)return n?.(i)&&Na(a,t[s]),i;const r=$a(i,t,e,n,s+1);return L(i)&&Na(a,t[s]),r}),fa="ColumnName",Ca="store",Ta="json",ba=Ca+"TableName",ha=Ca+"Id"+fa,Oa=Ca+fa,Ia="autoLoadIntervalSeconds",Sa="rowId"+fa,Da="tableId",La="tableName",Ra="deleteEmptyColumns",Pa="deleteEmptyTable",Ma="condition",_a={mode:Ta,[Ia]:1},Fa={load:0,save:0,[La]:t+"_values"},Ua=(a,t,e,n,s)=>{const i=va();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]),Na(i,r,o))}),i},ja=JSON.stringify,xa=JSON.parse,Ba=a=>""===a?void 0:v(a)?b(a,Ba):j(a)?G(a,Ba):a,Ja=/^\d+$/,Ya=va(),ka=va(),za=(a,t,n,s,i,r,o,c={},l=0,w=[])=>{let d,E,p,N=0,m=0,T=0;ma(Ya,w,()=>0),ma(ka,w,()=>[]);const b=va(),[h,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=>{Ja.test(t)&&A(a)<1e3&&I(a,t)}]})(),s=va();return[(n,i,r,o=[],c=()=>[])=>{a??=Z;const l=t(1);return Na(s,l,[n,i,r,o,c]),W($a(i,r??[e],Q),l),l},(t,n,...i)=>C(((a,t=[e])=>{const n=[],s=(a,e)=>e==A(t)?I(n,a):u(t[e])?P(a,a=>s(a,e+1)):C([t[e],null],t=>s(pa(a,t),e+1));return s(a,0),n})(t,n),t=>P(t,t=>pa(s,t)[0](a,...n??[],...i))),a=>g(pa(s,a),([,t,i])=>($a(t,i??[e],void 0,t=>(M(t,a),L(t)?1:0)),Na(s,a),n(a),i)),t=>g(pa(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(b,void 0,N))},J=t=>{(h&&v(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},Y=async a=>(2!=N&&(x(1),m++,await q(async()=>{await f(async()=>{const e=await t();v(e)?J(e):a?_(a):$("Content is not an array: "+e)},()=>{a&&_(a)}),x(0)})),Z),k=async a=>(z(),await Y(a),await f(async()=>E=await s(async(a,t)=>{t||a?2!=N&&(x(1),m++,J(t??a),x(0)):await Y()}),r),Z),z=async()=>(E&&(await f(()=>i(E),r),E=void 0),Z),G=async a=>(1!=N&&(x(2),T++,await q(async()=>{await f(()=>n(O,a),r),x(0)})),Z),H=async()=>(V(),await G(),p=a.addDidFinishTransactionListener(()=>{const a=D();R(a)&&G(a)}),Z),V=async()=>(p&&(a.delListener(p),p=void 0),Z),X=async(a=!1)=>{const[t,e]=a?[V,z]:[z,V];return await t(),await e(),Z},q=async(...a)=>(I(pa(ka,w),...a),await(async()=>{if(!pa(Ya,w)){for(Na(Ya,w,1);!y(d=S(pa(ka,w)));)await f(d,r);Na(Ya,w,0)}})(),Z),Z={load:Y,startAutoLoad:k,stopAutoLoad:z,isAutoLoading:()=>!y(E),save:G,startAutoSave:H,stopAutoSave:V,isAutoSaving:()=>!y(p),startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[H,k]:[k,H];return await e(a),await n(a),Z},stopAutoPersisting:X,getStatus:()=>N,addStatusListener:a=>F(a,b),delListener:t=>(j(t),a),schedule:q,getStore:()=>a,destroy:()=>(pa(ka,w).splice(0,void 0),X()),getStats:()=>({loads:m,saves:T}),...c};return B(Z)},Ga=(a,t,e,s,r,o=Ha,c,l)=>{const w=va();return[async()=>{w.clear(),b(await e(a,t),({tn:a,cn:t})=>W(ma(w,a,Q),t))},async(t,e,n)=>((a,t)=>D(pa(w,a),t))(t,e)?J(O(b(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=>b(x(a??{}),a=>W(E,a)));const v=R(E);if(!d&&u&&g==i&&h(v)&&D(w,t))return await a("DROP "+ta+ua(t)),void Na(w,t);const p=pa(w,t),A=Q(R(p));if(h(v)||(D(w,t)?await m(b([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${T(b(v,a=>n+ua(a)+r))});`),Na(w,t,Q([e,...v])))),await m([...!d&&l?b(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]):h(v)||await o(a,t,e,x(n),{[s]:c?b(H(n),c):H(n)},p)}));else if(h(v))D(w,t)&&await a(ia+ua(t)+Ea(t,g));else{const n=O(R(pa(w,t)),a=>a!=e),i={},r=[];G(s??{},(a,t)=>{i[t]=b(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}]},Ha=async(a,t,e,s,i)=>{const r=[1];await a(ea+" INTO"+ua(t)+"("+da(e,...s)+")VALUES"+T(z(i,a=>"($"+r[0]+++","+ga(a,r)+")"),n)+"ON CONFLICT("+ua(e)+")DO UPDATE SET"+T(b(s,a=>ua(a)+"=excluded."+ua(a)),n),z(i,(a,t)=>[t,...b(a,a=>a??null)]).flat())},Va=(a,t,e,n,s,i,r,[o,c,l],w,u,d,g,E,v)=>{const[p,A,N,m]=Ga(t,w,u,s,E,v),$=za(a,()=>m(async()=>{return await p(),a=(await A(o,c))[X]?.[l]??"null",Ba(xa(a));var a}),a=>m(async()=>{var t;await p(),await N(o,c,{[X]:{[l]:(t=a()??null,ja(t,(a,t)=>y(t)?"":t))}},!0,!0)}),e,n,s,r,{[g]:()=>d,destroy:async()=>(await $.stopAutoPersisting(),i(),$)},0,d);return $},Ka=(a,t,e,n,s,i,r,[o,c,[l,w,u]],d,g,E,v,p,A,N,$)=>{const[f,C,T,b]=Ga(t,d,g,s,p,A,N,$),h=(a,t)=>m(Aa(c,async([e,n,s,i,r],o)=>{t&&!(o in a)||await T(e,n,a[o],s,i,t,r)})),I=async(a,t)=>w?await T(u,q,{[X]:a},!0,!0,t):null,S=za(a,()=>b(async()=>{await f();const a=await(async()=>J(O(await m(Aa(o,async([a,t,e],n)=>[a,await C(n,t,e)])),a=>!K(a[1]))))(),t=await(async()=>l?(await C(u,q))[X]:{})();return K(a)&&y(t)?void 0:[a,t]}),(a,t)=>b(async()=>{if(await f(),y(t)){const[t,e]=a();await h(t),await I(e)}else await h(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},Qa=(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,b,h,O]=(a=>{const e=(a=>Y(_a,E(a)?{[ba]:a}:a??{}))(a),n=e[Ia];if(e.mode==Ta){const a=e[ba]??t;return[1,n,[a,e[ha]??q,e[Oa]??Ca],Q(a)]}const{tables:{load:s={},save:r={}}={},values:o={}}=e,c=p(H(Y(Fa,o)),0,V(Fa)),l=c[2],w=Q(l),y=Q(l),u=Ua(s,{[Da]:null,[Sa]:q,[Ma]:i},Da,a=>D(y,a),a=>W(w,a)),d=Ua(r,{[La]:null,[Sa]:q,[Ra]:0,[Pa]:0,[Ma]:null},La,(a,t)=>D(y,t),(a,t)=>W(w,t));var g;return g=(a,t)=>t[4]??=pa(u,t[0])?.[2]??i,P(d,(a,t)=>g(0,a)),[0,n,[u,d,c],w]})(n);return(T?Va:Ka)(a,C,a=>{let t;const e=()=>t=setInterval(()=>f(async()=>{const[{d:t,s:e,c:n}]=await C(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*b),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,h,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)},Wa=(a,t,e,n,s)=>{let i;return Qa(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&&b(a.changedTables,i)})(),i=a,e},a=>{i=void 0,a.abort()},n,s,N,1,t,"getPowerSync",Xa)},Xa=async(a,t,e,s,i,r)=>{const o=[1],c=Q(s),l=r?O([...r],a=>a!=e&&!D(c,a)):[];if(!h(l)){const n=x(i),s=J(b(await a(Z+da(e,...l)+sa+ua(t)+aa+ua(e)+"IN("+ga(n)+")",n),a=>[a[e],a]));C(n,a=>I(i[a],...b(l,t=>s?.[a]?.[t]??null)))}await a(ea+" OR REPLACE INTO"+ua(t)+"("+da(e,...s,...l)+")VALUES"+T(z(i,a=>"($"+o[0]+++","+ga(a,o)+")"),n),z(i,(a,t)=>[t,...b(a,a=>a??null)]).flat())};export{Wa as createPowerSyncPersister};
@@ -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)}},C=(a,t)=>a.forEach(t),T=(a,t="")=>a.join(t),b=(a,t)=>a.map(t),h=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=_.keys,x=_.freeze,B=(a=[])=>_.fromEntries(a),J=(...a)=>_.assign({},...a),Y=(a,t)=>(delete a[t],a),k=(a,t)=>b(U(a),([a,e])=>t(e,a)),z=(a,t)=>B(k(a,(a,e)=>[e,t(a,e)])),G=a=>_.values(a),H=a=>A(j(a)),V=a=>(a=>!w(a)&&d(F(a),a=>a==_.prototype||w(F(a)),()=>!0))(a)&&0==H(a),K=a=>new Set(v(a)||y(a)?a:[a]),Q=(a,t)=>a?.add(t),W="_",X="_id",q="SELECT",Z="WHERE",aa="TABLE",ta="INSERT",ea="ALTER "+aa,na="FROM",sa="DELETE "+na,ia=q+"*"+na,ra="pragma_",oa="data_version",ca="schema_version",la="pragma_table_",wa="CREATE "+aa,ya=a=>T(b(((a,t="",e)=>a.split(t,e))(a,"."),a=>`"${r(a,/"/g,'""')}"`),"."),ua=(...a)=>T(b(a,ya),n),da=(a,t=[1])=>T(b(a,()=>"$"+t[0]++),n),ga=(a,t=i)=>Z+`(${r(t,"$tableName",ya(a))})`,Ea=a=>new Map(a),va=(a,t)=>a?.get(t),pa=(a,t)=>b([...a?.entries()??[]],([a,e])=>t(e,a)),Aa=(a,t,e)=>y(e)?(M(a,t),a):a?.set(t,e),Na=(a,t,e,n)=>(D(a,t)?n?.(va(a,t)):Aa(a,t,e()),va(a,t)),ma=(a,t,e,n,s=0)=>g((e?Na:va)(a,t[s],s>A(t)-2?e:Ea),i=>{if(s>A(t)-2)return n?.(i)&&Aa(a,t[s]),i;const r=ma(i,t,e,n,s+1);return L(i)&&Aa(a,t[s]),r}),$a="ColumnName",fa="store",Ca="json",Ta=fa+"TableName",ba=fa+"Id"+$a,ha=fa+$a,Oa="autoLoadIntervalSeconds",Ia="rowId"+$a,Sa="tableId",Da="tableName",La="deleteEmptyColumns",Ra="deleteEmptyTable",Pa="condition",Ma={mode:Ca,[Oa]:1},_a={load:0,save:0,[Da]:t+"_values"},Fa=(a,t,e,n,s)=>{const i=Ea();return z(a,(a,r)=>{const o=p(G(J(t,E(a)?{[e]:a}:a)),0,H(t));u(o[0])||n(r,o[0])||(s(r,o[0]),Aa(i,r,o))}),i},Ua=JSON.stringify,ja=JSON.parse,xa=/^\d+$/,Ba=Ea(),Ja=Ea(),Ya=(a,t,n,s,i,r,o,c={},l=0,w=[])=>{let d,E,p,N=0,m=0,T=0;Na(Ba,w,()=>0),Na(Ja,w,()=>[]);const b=Ea(),[h,O,D,R,_]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!V(a)||!V(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!V(a)||!V(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=>{xa.test(t)&&A(a)<1e3&&I(a,t)}]})(),s=Ea();return[(n,i,r,o=[],c=()=>[])=>{a??=Z;const l=t(1);return Aa(s,l,[n,i,r,o,c]),Q(ma(i,r??[e],K),l),l},(t,n,...i)=>C(((a,t=[e])=>{const n=[],s=(a,e)=>e==A(t)?I(n,a):u(t[e])?P(a,a=>s(a,e+1)):C([t[e],null],t=>s(va(a,t),e+1));return s(a,0),n})(t,n),t=>P(t,t=>va(s,t)[0](a,...n??[],...i))),a=>g(va(s,a),([,t,i])=>(ma(t,i??[e],void 0,t=>(M(t,a),L(t)?1:0)),Aa(s,a),n(a),i)),t=>g(va(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(b,void 0,N))},J=t=>{(h&&v(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();v(e)?J(e):a?_(a):$("Content is not an array: "+e)},()=>{a&&_(a)}),B(0)})),Z),k=async a=>(z(),await Y(a),await f(async()=>E=await s(async(a,t)=>{t||a?2!=N&&(B(1),m++,J(t??a),B(0)):await Y()}),r),Z),z=async()=>(E&&(await f(()=>i(E),r),E=void 0),Z),G=async a=>(1!=N&&(B(2),T++,await q(async()=>{await f(()=>n(O,a),r),B(0)})),Z),H=async()=>(W(),await G(),p=a.addDidFinishTransactionListener(()=>{const a=D();R(a)&&G(a)}),Z),W=async()=>(p&&(a.delListener(p),p=void 0),Z),X=async(a=!1)=>{const[t,e]=a?[W,z]:[z,W];return await t(),await e(),Z},q=async(...a)=>(I(va(Ja,w),...a),await(async()=>{if(!va(Ba,w)){for(Aa(Ba,w,1);!y(d=S(va(Ja,w)));)await f(d,r);Aa(Ba,w,0)}})(),Z),Z={load:Y,startAutoLoad:k,stopAutoLoad:z,isAutoLoading:()=>!y(E),save:G,startAutoSave:H,stopAutoSave:W,isAutoSaving:()=>!y(p),startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[H,k]:[k,H];return await e(a),await n(a),Z},stopAutoPersisting:X,getStatus:()=>N,addStatusListener:a=>F(a,b),delListener:t=>(j(t),a),schedule:q,getStore:()=>a,destroy:()=>(va(Ja,w).splice(0,void 0),X()),getStats:()=>({loads:m,saves:T}),...c};return x(Z)},ka=(a,t,e,s,r,o=za,c,l)=>{const w=Ea();return[async()=>{w.clear(),b(await e(a,t),({tn:a,cn:t})=>Q(Na(w,a,K),t))},async(t,e,n)=>((a,t)=>D(va(w,a),t))(t,e)?B(O(b(await a(ia+ya(t)+ga(t,n)),a=>[a[e],l?z(Y(a,e),l):Y(a,e)]),([a,t])=>!y(a)&&!V(t))):{},async(t,e,s,l,u,d=!1,g=i)=>{const E=K();z(s??{},a=>b(j(a??{}),a=>Q(E,a)));const v=R(E);if(!d&&u&&g==i&&h(v)&&D(w,t))return await a("DROP "+aa+ya(t)),void Aa(w,t);const p=va(w,t),A=K(R(p));if(h(v)||(D(w,t)?await m(b([e,...v],async(n,s)=>{M(A,n)||(await a(ea+ya(t)+"ADD"+ya(n)+r),0==s&&await a("CREATE UNIQUE INDEX pk ON "+ya(t)+`(${ya(e)})`),Q(p,n))})):(await a(wa+ya(t)+`(${ya(e)}${r} PRIMARY KEY${T(b(v,a=>n+ya(a)+r))});`),Aa(w,t,K([e,...v])))),await m([...!d&&l?b(R(A),async n=>{n!=e&&(await a(ea+ya(t)+"DROP"+ya(n)),M(p,n))}):[]]),d)y(s)?await a(sa+ya(t)+ga(t,g)):await m(k(s,async(n,s)=>{y(n)?await a(sa+ya(t)+ga(t,g)+`AND(${ya(e)}=$1)`,[s]):h(v)||await o(a,t,e,j(n),{[s]:c?b(G(n),c):G(n)},p)}));else if(h(v))D(w,t)&&await a(sa+ya(t)+ga(t,g));else{const n=O(R(va(w,t)),a=>a!=e),i={},r=[];z(s??{},(a,t)=>{i[t]=b(n,t=>c?c(a?.[t]):a?.[t]),I(r,t)}),await o(a,t,e,n,i),await a(sa+ya(t)+ga(t,g)+`AND${ya(e)}NOT IN(${da(r)})`,r)}},async t=>{let e;return await a("BEGIN"),await f(async()=>e=await t(),s),await a("END"),e}]},za=async(a,t,e,s,i)=>{const r=[1];await a(ta+" INTO"+ya(t)+"("+ua(e,...s)+")VALUES"+T(k(i,a=>"($"+r[0]+++","+da(a,r)+")"),n)+"ON CONFLICT("+ya(e)+")DO UPDATE SET"+T(b(s,a=>ya(a)+"=excluded."+ya(a)),n),k(i,(a,t)=>[t,...b(a,a=>a??null)]).flat())},Ga=(a,t,e,n,s,i,r,[o,c,l],w,u,d,g,E,v)=>{const[p,A,N,m]=ka(t,w,u,s,E,v),$=Ya(a,()=>m(async()=>{return await p(),a=(await A(o,c))[W]?.[l]??"null",ja(a,(a,t)=>""===t?void 0:t);var a}),a=>m(async()=>{var t;await p(),await N(o,c,{[W]:{[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 $},Ha=(a,t,e,n,s,i,r,[o,c,[l,w,u]],d,g,E,v,p,A,N,$)=>{const[f,C,T,b]=ka(t,d,g,s,p,A,N,$),h=(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)})),I=async(a,t)=>w?await T(u,X,{[W]:a},!0,!0,t):null,S=Ya(a,()=>b(async()=>{await f();const a=await(async()=>B(O(await m(pa(o,async([a,t,e],n)=>[a,await C(n,t,e)])),a=>!V(a[1]))))(),t=await(async()=>l?(await C(u,X))[W]:{})();return V(a)&&y(t)?void 0:[a,t]}),(a,t)=>b(async()=>{if(await f(),y(t)){const[t,e]=a();await h(t),await I(e)}else await h(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},Va=(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,b,h,O]=(a=>{const e=(a=>J(Ma,E(a)?{[Ta]:a}:a??{}))(a),n=e[Oa];if(e.mode==Ca){const a=e[Ta]??t;return[1,n,[a,e[ba]??X,e[ha]??fa],K(a)]}const{tables:{load:s={},save:r={}}={},values:o={}}=e,c=p(G(J(_a,o)),0,H(_a)),l=c[2],w=K(l),y=K(l),u=Fa(s,{[Sa]:null,[Ia]:X,[Pa]:i},Sa,a=>D(y,a),a=>Q(w,a)),d=Fa(r,{[Da]:null,[Ia]:X,[La]:0,[Ra]:0,[Pa]:null},Da,(a,t)=>D(y,t),(a,t)=>Q(w,t));var g;return g=(a,t)=>t[4]??=va(u,t[0])?.[2]??i,P(d,(a,t)=>g(0,a)),[0,n,[u,d,c],w]})(n);return(T?Ga:Ha)(a,C,a=>{let t;const e=()=>t=setInterval(()=>f(async()=>{const[{d:t,s:e,c:n}]=await C(q+` ${oa} d,${ca} s,TOTAL_CHANGES() c FROM ${ra}${oa} JOIN ${ra}${ca}`);t==N&&e==m&&n==$||(w(N)||a(),N=t,m=e,$=n)}),1e3*b),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,h,R(O),async(a,t)=>await a(q+` t.name tn,c.name cn FROM ${la}list()t,${la}info(t.name)c ${Z} t.schema='main'AND t.type IN('table','view')AND t.name IN(${da(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)},Ka=(a,t,e,n,s)=>{let i;return Va(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&&b(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=K(s),l=r?O([...r],a=>a!=e&&!D(c,a)):[];if(!h(l)){const n=j(i),s=B(b(await a(q+ua(e,...l)+na+ya(t)+Z+ya(e)+"IN("+da(n)+")",n),a=>[a[e],a]));C(n,a=>I(i[a],...b(l,t=>s?.[a]?.[t]??null)))}await a(ta+" OR REPLACE INTO"+ya(t)+"("+ua(e,...s,...l)+")VALUES"+T(k(i,a=>"($"+o[0]+++","+da(a,o)+")"),n),k(i,(a,t)=>[t,...b(a,a=>a??null)]).flat())};export{Ka as createPowerSyncPersister};
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)}},C=(a,t)=>a.forEach(t),T=(a,t="")=>a.join(t),b=(a,t)=>a.map(t),h=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)=>b(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=>T(b(((a,t="",e)=>a.split(t,e))(a,"."),a=>`"${r(a,/"/g,'""')}"`),"."),da=(...a)=>T(b(a,ua),n),ga=(a,t=[1])=>T(b(a,()=>"$"+t[0]++),n),Ea=(a,t=i)=>aa+`(${r(t,"$tableName",ua(a))})`,va=a=>new Map(a),pa=(a,t)=>a?.get(t),Aa=(a,t)=>b([...a?.entries()??[]],([a,e])=>t(e,a)),Na=(a,t,e)=>y(e)?(M(a,t),a):a?.set(t,e),ma=(a,t,e,n)=>(D(a,t)?n?.(pa(a,t)):Na(a,t,e()),pa(a,t)),$a=(a,t,e,n,s=0)=>g((e?ma:pa)(a,t[s],s>A(t)-2?e:va),i=>{if(s>A(t)-2)return n?.(i)&&Na(a,t[s]),i;const r=$a(i,t,e,n,s+1);return L(i)&&Na(a,t[s]),r}),fa="ColumnName",Ca="store",Ta="json",ba=Ca+"TableName",ha=Ca+"Id"+fa,Oa=Ca+fa,Ia="autoLoadIntervalSeconds",Sa="rowId"+fa,Da="tableId",La="tableName",Ra="deleteEmptyColumns",Pa="deleteEmptyTable",Ma="condition",_a={mode:Ta,[Ia]:1},Fa={load:0,save:0,[La]:t+"_values"},Ua=(a,t,e,n,s)=>{const i=va();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]),Na(i,r,o))}),i},ja=JSON.stringify,xa=JSON.parse,Ba=a=>""===a?void 0:v(a)?b(a,Ba):j(a)?G(a,Ba):a,Ja=/^\d+$/,Ya=va(),ka=va(),za=(a,t,n,s,i,r,o,c={},l=0,w=[])=>{let d,E,p,N=0,m=0,T=0;ma(Ya,w,()=>0),ma(ka,w,()=>[]);const b=va(),[h,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=>{Ja.test(t)&&A(a)<1e3&&I(a,t)}]})(),s=va();return[(n,i,r,o=[],c=()=>[])=>{a??=Z;const l=t(1);return Na(s,l,[n,i,r,o,c]),W($a(i,r??[e],Q),l),l},(t,n,...i)=>C(((a,t=[e])=>{const n=[],s=(a,e)=>e==A(t)?I(n,a):u(t[e])?P(a,a=>s(a,e+1)):C([t[e],null],t=>s(pa(a,t),e+1));return s(a,0),n})(t,n),t=>P(t,t=>pa(s,t)[0](a,...n??[],...i))),a=>g(pa(s,a),([,t,i])=>($a(t,i??[e],void 0,t=>(M(t,a),L(t)?1:0)),Na(s,a),n(a),i)),t=>g(pa(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(b,void 0,N))},J=t=>{(h&&v(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},Y=async a=>(2!=N&&(x(1),m++,await q(async()=>{await f(async()=>{const e=await t();v(e)?J(e):a?_(a):$("Content is not an array: "+e)},()=>{a&&_(a)}),x(0)})),Z),k=async a=>(z(),await Y(a),await f(async()=>E=await s(async(a,t)=>{t||a?2!=N&&(x(1),m++,J(t??a),x(0)):await Y()}),r),Z),z=async()=>(E&&(await f(()=>i(E),r),E=void 0),Z),G=async a=>(1!=N&&(x(2),T++,await q(async()=>{await f(()=>n(O,a),r),x(0)})),Z),H=async()=>(V(),await G(),p=a.addDidFinishTransactionListener(()=>{const a=D();R(a)&&G(a)}),Z),V=async()=>(p&&(a.delListener(p),p=void 0),Z),X=async(a=!1)=>{const[t,e]=a?[V,z]:[z,V];return await t(),await e(),Z},q=async(...a)=>(I(pa(ka,w),...a),await(async()=>{if(!pa(Ya,w)){for(Na(Ya,w,1);!y(d=S(pa(ka,w)));)await f(d,r);Na(Ya,w,0)}})(),Z),Z={load:Y,startAutoLoad:k,stopAutoLoad:z,isAutoLoading:()=>!y(E),save:G,startAutoSave:H,stopAutoSave:V,isAutoSaving:()=>!y(p),startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[H,k]:[k,H];return await e(a),await n(a),Z},stopAutoPersisting:X,getStatus:()=>N,addStatusListener:a=>F(a,b),delListener:t=>(j(t),a),schedule:q,getStore:()=>a,destroy:()=>(pa(ka,w).splice(0,void 0),X()),getStats:()=>({loads:m,saves:T}),...c};return B(Z)},Ga=(a,t,e,s,r,o=Ha,c,l)=>{const w=va();return[async()=>{w.clear(),b(await e(a,t),({tn:a,cn:t})=>W(ma(w,a,Q),t))},async(t,e,n)=>((a,t)=>D(pa(w,a),t))(t,e)?J(O(b(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=>b(x(a??{}),a=>W(E,a)));const v=R(E);if(!d&&u&&g==i&&h(v)&&D(w,t))return await a("DROP "+ta+ua(t)),void Na(w,t);const p=pa(w,t),A=Q(R(p));if(h(v)||(D(w,t)?await m(b([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${T(b(v,a=>n+ua(a)+r))});`),Na(w,t,Q([e,...v])))),await m([...!d&&l?b(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]):h(v)||await o(a,t,e,x(n),{[s]:c?b(H(n),c):H(n)},p)}));else if(h(v))D(w,t)&&await a(ia+ua(t)+Ea(t,g));else{const n=O(R(pa(w,t)),a=>a!=e),i={},r=[];G(s??{},(a,t)=>{i[t]=b(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}]},Ha=async(a,t,e,s,i)=>{const r=[1];await a(ea+" INTO"+ua(t)+"("+da(e,...s)+")VALUES"+T(z(i,a=>"($"+r[0]+++","+ga(a,r)+")"),n)+"ON CONFLICT("+ua(e)+")DO UPDATE SET"+T(b(s,a=>ua(a)+"=excluded."+ua(a)),n),z(i,(a,t)=>[t,...b(a,a=>a??null)]).flat())},Va=(a,t,e,n,s,i,r,[o,c,l],w,u,d,g,E,v)=>{const[p,A,N,m]=Ga(t,w,u,s,E,v),$=za(a,()=>m(async()=>{return await p(),a=(await A(o,c))[X]?.[l]??"null",Ba(xa(a));var a}),a=>m(async()=>{var t;await p(),await N(o,c,{[X]:{[l]:(t=a()??null,ja(t,(a,t)=>y(t)?"":t))}},!0,!0)}),e,n,s,r,{[g]:()=>d,destroy:async()=>(await $.stopAutoPersisting(),i(),$)},0,d);return $},Ka=(a,t,e,n,s,i,r,[o,c,[l,w,u]],d,g,E,v,p,A,N,$)=>{const[f,C,T,b]=Ga(t,d,g,s,p,A,N,$),h=(a,t)=>m(Aa(c,async([e,n,s,i,r],o)=>{t&&!(o in a)||await T(e,n,a[o],s,i,t,r)})),I=async(a,t)=>w?await T(u,q,{[X]:a},!0,!0,t):null,S=za(a,()=>b(async()=>{await f();const a=await(async()=>J(O(await m(Aa(o,async([a,t,e],n)=>[a,await C(n,t,e)])),a=>!K(a[1]))))(),t=await(async()=>l?(await C(u,q))[X]:{})();return K(a)&&y(t)?void 0:[a,t]}),(a,t)=>b(async()=>{if(await f(),y(t)){const[t,e]=a();await h(t),await I(e)}else await h(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},Qa=(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,b,h,O]=(a=>{const e=(a=>Y(_a,E(a)?{[ba]:a}:a??{}))(a),n=e[Ia];if(e.mode==Ta){const a=e[ba]??t;return[1,n,[a,e[ha]??q,e[Oa]??Ca],Q(a)]}const{tables:{load:s={},save:r={}}={},values:o={}}=e,c=p(H(Y(Fa,o)),0,V(Fa)),l=c[2],w=Q(l),y=Q(l),u=Ua(s,{[Da]:null,[Sa]:q,[Ma]:i},Da,a=>D(y,a),a=>W(w,a)),d=Ua(r,{[La]:null,[Sa]:q,[Ra]:0,[Pa]:0,[Ma]:null},La,(a,t)=>D(y,t),(a,t)=>W(w,t));var g;return g=(a,t)=>t[4]??=pa(u,t[0])?.[2]??i,P(d,(a,t)=>g(0,a)),[0,n,[u,d,c],w]})(n);return(T?Va:Ka)(a,C,a=>{let t;const e=()=>t=setInterval(()=>f(async()=>{const[{d:t,s:e,c:n}]=await C(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*b),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,h,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)},Wa=(a,t,e,n,s)=>{let i;return Qa(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&&b(a.changedTables,i)})(),i=a,e},a=>{i=void 0,a.abort()},n,s,N,1,t,"getPowerSync",Xa)},Xa=async(a,t,e,s,i,r)=>{const o=[1],c=Q(s),l=r?O([...r],a=>a!=e&&!D(c,a)):[];if(!h(l)){const n=x(i),s=J(b(await a(Z+da(e,...l)+sa+ua(t)+aa+ua(e)+"IN("+ga(n)+")",n),a=>[a[e],a]));C(n,a=>I(i[a],...b(l,t=>s?.[a]?.[t]??null)))}await a(ea+" OR REPLACE INTO"+ua(t)+"("+da(e,...s,...l)+")VALUES"+T(z(i,a=>"($"+o[0]+++","+ga(a,o)+")"),n),z(i,(a,t)=>[t,...b(a,a=>a??null)]).flat())};export{Wa as createPowerSyncPersister};
@@ -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),O=(a,t)=>a.map(t),S=a=>0==A(a),b=(a,t)=>a.filter(t),h=(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()??[]],P=(a,t)=>a?.forEach(t),M=(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(O(((a,t="",e)=>a.split(t,e))(a,"."),a=>`"${r(a,/"/g,'""')}"`),"."),V=(a,t=[1])=>T(O(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)=>O(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)=>O([...a?.entries()??[]],([a,e])=>t(e,a)),ga=(a,t,e)=>y(e)?(M(a,t),a):a?.set(t,e),pa=(a,t,e,n)=>(I(a,t)?n?.(ua(a,t)):ga(a,t,e()),ua(a,t)),va=(a,t,e,n,s=0)=>g((e?pa:ua)(a,t[s],s>A(t)-2?e:ya),i=>{if(s>A(t)-2)return n?.(i)&&ga(a,t[s]),i;const r=va(i,t,e,n,s+1);return L(i)&&ga(a,t[s]),r}),Ea=a=>new Set(v(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,Oa="autoLoadIntervalSeconds",Sa="rowId"+Na,ba="tableId",ha="tableName",Da="deleteEmptyColumns",Ia="deleteEmptyTable",La="condition",Ra={mode:$a,[Oa]:1},Pa={load:0,save:0,[ha]:t+"_values"},Ma=(a,t,e,n,s)=>{const i=ya();return oa(a,(a,r)=>{const o=E(ca(sa(t,p(a)?{[e]:a}:a)),0,la(t));u(o[0])||n(r,o[0])||(s(r,o[0]),ga(i,r,o))}),i},_a=JSON.stringify,Fa=JSON.parse,Ua=/^\d+$/,ja=ya(),xa=ya(),Ba=(a,t,n,s,i,r,o,c={},l=0,w=[])=>{let d,p,E,N=0,m=0,T=0;pa(ja,w,()=>0),pa(xa,w,()=>[]);const O=ya(),[S,b,I,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?D(a):null)??e+t++,t=>{Ua.test(t)&&A(a)<1e3&&h(a,t)}]})(),s=ya();return[(n,i,r,o=[],c=()=>[])=>{a??=Q;const l=t(1);return ga(s,l,[n,i,r,o,c]),Aa(va(i,r??[e],Ea),l),l},(t,n,...i)=>C(((a,t=[e])=>{const n=[],s=(a,e)=>e==A(t)?h(n,a):u(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=>g(ua(s,a),([,t,i])=>(va(t,i??[e],void 0,t=>(M(t,a),L(t)?1:0)),ga(s,a),n(a),i)),t=>g(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()})]})(),x=a=>{a!=N&&(N=a,U(O,void 0,N))},B=t=>{(S&&v(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},J=async a=>(2!=N&&(x(1),m++,await K(async()=>{await f(async()=>{const e=await t();v(e)?B(e):a?_(a):$("Content is not an array: "+e)},()=>{a&&_(a)}),x(0)})),Q),Y=async a=>(k(),await J(a),await f(async()=>p=await s(async(a,t)=>{t||a?2!=N&&(x(1),m++,B(t??a),x(0)):await J()}),r),Q),k=async()=>(p&&(await f(()=>i(p),r),p=void 0),Q),z=async a=>(1!=N&&(x(2),T++,await K(async()=>{await f(()=>n(b,a),r),x(0)})),Q),G=async()=>(H(),await z(),E=a.addDidFinishTransactionListener(()=>{const a=I();R(a)&&z(a)}),Q),H=async()=>(E&&(a.delListener(E),E=void 0),Q),q=async(a=!1)=>{const[t,e]=a?[H,k]:[k,H];return await t(),await e(),Q},K=async(...a)=>(h(ua(xa,w),...a),await(async()=>{if(!ua(ja,w)){for(ga(ja,w,1);!y(d=D(ua(xa,w)));)await f(d,r);ga(ja,w,0)}})(),Q),Q={load:J,startAutoLoad:Y,stopAutoLoad:k,isAutoLoading:()=>!y(p),save:z,startAutoSave:G,stopAutoSave:H,isAutoSaving:()=>!y(E),startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[G,Y]:[Y,G];return await e(a),await n(a),Q},stopAutoPersisting:q,getStatus:()=>N,addStatusListener:a=>F(a,O),delListener:t=>(j(t),a),schedule:K,getStore:()=>a,destroy:()=>(ua(xa,w).splice(0,void 0),q()),getStats:()=>({loads:m,saves:T}),...c};return ea(Q)},Ja=(a,t,e,s,r,o=Ya,c,l)=>{const w=ya();return[async()=>{w.clear(),O(await e(a,t),({tn:a,cn:t})=>Aa(pa(w,a,Ea),t))},async(t,e,n)=>((a,t)=>I(ua(w,a),t))(t,e)?na(b(O(await a(k+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,g=i)=>{const p=Ea();oa(s??{},a=>O(ta(a??{}),a=>Aa(p,a)));const v=R(p);if(!d&&u&&g==i&&S(v)&&I(w,t))return await a("DROP "+x+Q(t)),void ga(w,t);const E=ua(w,t),A=Ea(R(E));if(S(v)||(I(w,t)?await m(O([e,...v],async(n,s)=>{M(A,n)||(await a(B+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(O(v,a=>n+Q(a)+r))});`),ga(w,t,Ea([e,...v])))),await m([...!d&&l?O(R(A),async n=>{n!=e&&(await a(B+Q(t)+"DROP"+Q(n)),M(E,n))}):[]]),d)y(s)?await a(Y+Q(t)+W(t,g)):await m(ra(s,async(n,s)=>{y(n)?await a(Y+Q(t)+W(t,g)+`AND(${Q(e)}=$1)`,[s]):S(v)||await o(a,t,e,ta(n),{[s]:c?O(ca(n),c):ca(n)},E)}));else if(S(v))I(w,t)&&await a(Y+Q(t)+W(t,g));else{const n=b(R(ua(w,t)),a=>a!=e),i={},r=[];oa(s??{},(a,t)=>{i[t]=O(n,t=>c?c(a?.[t]):a?.[t]),h(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}]},Ya=async(a,t,e,s,i)=>{const r=[1];await a("INSERT INTO"+Q(t)+"("+((...a)=>T(O(a,Q),n))(e,...s)+")VALUES"+T(ra(i,a=>"($"+r[0]+++","+V(a,r)+")"),n)+"ON CONFLICT("+Q(e)+")DO UPDATE SET"+T(O(s,a=>Q(a)+"=excluded."+Q(a)),n),ra(i,(a,t)=>[t,...O(a,a=>a??null)]).flat())},ka=(a,t,e,n,s,i,r,[o,c,l],w,u,d,g,p,v)=>{const[E,A,N,m]=Ja(t,w,u,s,p,v),$=Ba(a,()=>m(async()=>{return await E(),a=(await A(o,c))[_]?.[l]??"null",Fa(a,(a,t)=>""===t?void 0:t);var a}),a=>m(async()=>{var t;await E(),await N(o,c,{[_]:{[l]:(t=a()??null,_a(t,(a,t)=>y(t)?"":t))}},!0,!0)}),e,n,s,r,{[g]:()=>d,destroy:async()=>(await $.stopAutoPersisting(),i(),$)},0,d);return $},za=(a,t,e,n,s,i,r,[o,c,[l,w,u]],d,g,p,v,E,A,N,$)=>{const[f,C,T,O]=Ja(t,d,g,s,E,A,N,$),S=(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)})),h=async(a,t)=>w?await T(u,F,{[_]:a},!0,!0,t):null,D=Ba(a,()=>O(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)=>O(async()=>{if(await f(),y(t)){const[t,e]=a();await S(t),await h(e)}else await S(t[0],!0),await h(t[1],!0)}),e,n,s,r,{[v]:()=>p,destroy:async()=>(await D.stopAutoPersisting(),i(),D)},0,p);return D},Ga=(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,O,S,b]=(a=>{const e=(a=>sa(Ra,p(a)?{[fa]:a}:a??{}))(a),n=e[Oa];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,[Sa]:F,[La]:i},ba,a=>I(y,a),a=>Aa(w,a)),d=Ma(r,{[ha]:null,[Sa]:F,[Da]:0,[Ia]:0,[La]:null},ha,(a,t)=>I(y,t),(a,t)=>Aa(w,t));var g;return g=(a,t)=>t[4]??=ua(u,t[0])?.[2]??i,P(d,(a,t)=>g(0,a)),[0,n,[u,d,c],w]})(n);return(T?ka:za)(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*O),()=>{N=m=$=null,l(t)}},a=>a(),y,u,d,S,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),g,v,e,A,a=>(a=>!0===a)(a)?1:(a=>!1===a)(a)?0:a,void 0)},Ha=(a,t,e,n,s)=>Ga(a,e,async(a,e=[])=>(await t.executeSql(a,e))[0].rows.raw(),0,0,n,s,N,3,t);export{Ha as createReactNativeSqlitePersister};
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),O=(a,t)=>a.map(t),S=a=>0==A(a),b=(a,t)=>a.filter(t),h=(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()??[]],P=(a,t)=>a?.forEach(t),M=(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(O(((a,t="",e)=>a.split(t,e))(a,"."),a=>`"${r(a,/"/g,'""')}"`),"."),V=(a,t=[1])=>T(O(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)=>O(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=a=>new Map(a),da=(a,t)=>a?.get(t),ga=(a,t)=>O([...a?.entries()??[]],([a,e])=>t(e,a)),pa=(a,t,e)=>y(e)?(M(a,t),a):a?.set(t,e),va=(a,t,e,n)=>(I(a,t)?n?.(da(a,t)):pa(a,t,e()),da(a,t)),Ea=(a,t,e,n,s=0)=>g((e?va:da)(a,t[s],s>A(t)-2?e:ua),i=>{if(s>A(t)-2)return n?.(i)&&pa(a,t[s]),i;const r=Ea(i,t,e,n,s+1);return L(i)&&pa(a,t[s]),r}),Aa=a=>new Set(v(a)||y(a)?a:[a]),Na=(a,t)=>a?.add(t),ma="ColumnName",$a="store",fa="json",Ca=$a+"TableName",Ta=$a+"Id"+ma,Oa=$a+ma,Sa="autoLoadIntervalSeconds",ba="rowId"+ma,ha="tableId",Da="tableName",Ia="deleteEmptyColumns",La="deleteEmptyTable",Ra="condition",Pa={mode:fa,[Sa]:1},Ma={load:0,save:0,[Da]:t+"_values"},_a=(a,t,e,n,s)=>{const i=ua();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]),pa(i,r,o))}),i},Fa=JSON.stringify,Ua=JSON.parse,ja=a=>""===a?void 0:v(a)?O(a,ja):ta(a)?ca(a,ja):a,xa=/^\d+$/,Ba=ua(),Ja=ua(),Ya=(a,t,n,s,i,r,o,c={},l=0,w=[])=>{let d,p,E,N=0,m=0,T=0;va(Ba,w,()=>0),va(Ja,w,()=>[]);const O=ua(),[S,b,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=>{xa.test(t)&&A(a)<1e3&&h(a,t)}]})(),s=ua();return[(n,i,r,o=[],c=()=>[])=>{a??=Q;const l=t(1);return pa(s,l,[n,i,r,o,c]),Na(Ea(i,r??[e],Aa),l),l},(t,n,...i)=>C(((a,t=[e])=>{const n=[],s=(a,e)=>e==A(t)?h(n,a):u(t[e])?P(a,a=>s(a,e+1)):C([t[e],null],t=>s(da(a,t),e+1));return s(a,0),n})(t,n),t=>P(t,t=>da(s,t)[0](a,...n??[],...i))),a=>g(da(s,a),([,t,i])=>(Ea(t,i??[e],void 0,t=>(M(t,a),L(t)?1:0)),pa(s,a),n(a),i)),t=>g(da(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(O,void 0,N))},B=t=>{(S&&v(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},J=async a=>(2!=N&&(x(1),m++,await K(async()=>{await f(async()=>{const e=await t();v(e)?B(e):a?_(a):$("Content is not an array: "+e)},()=>{a&&_(a)}),x(0)})),Q),Y=async a=>(k(),await J(a),await f(async()=>p=await s(async(a,t)=>{t||a?2!=N&&(x(1),m++,B(t??a),x(0)):await J()}),r),Q),k=async()=>(p&&(await f(()=>i(p),r),p=void 0),Q),z=async a=>(1!=N&&(x(2),T++,await K(async()=>{await f(()=>n(b,a),r),x(0)})),Q),G=async()=>(H(),await z(),E=a.addDidFinishTransactionListener(()=>{const a=I();R(a)&&z(a)}),Q),H=async()=>(E&&(a.delListener(E),E=void 0),Q),q=async(a=!1)=>{const[t,e]=a?[H,k]:[k,H];return await t(),await e(),Q},K=async(...a)=>(h(da(Ja,w),...a),await(async()=>{if(!da(Ba,w)){for(pa(Ba,w,1);!y(d=D(da(Ja,w)));)await f(d,r);pa(Ba,w,0)}})(),Q),Q={load:J,startAutoLoad:Y,stopAutoLoad:k,isAutoLoading:()=>!y(p),save:z,startAutoSave:G,stopAutoSave:H,isAutoSaving:()=>!y(E),startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[G,Y]:[Y,G];return await e(a),await n(a),Q},stopAutoPersisting:q,getStatus:()=>N,addStatusListener:a=>F(a,O),delListener:t=>(j(t),a),schedule:K,getStore:()=>a,destroy:()=>(da(Ja,w).splice(0,void 0),q()),getStats:()=>({loads:m,saves:T}),...c};return na(Q)},ka=(a,t,e,s,r,o=za,c,l)=>{const w=ua();return[async()=>{w.clear(),O(await e(a,t),({tn:a,cn:t})=>Na(va(w,a,Aa),t))},async(t,e,n)=>((a,t)=>I(da(w,a),t))(t,e)?sa(b(O(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=Aa();ca(s??{},a=>O(ea(a??{}),a=>Na(p,a)));const v=R(p);if(!d&&u&&g==i&&S(v)&&I(w,t))return await a("DROP "+x+Q(t)),void pa(w,t);const E=da(w,t),A=Aa(R(E));if(S(v)||(I(w,t)?await m(O([e,...v],async(n,s)=>{M(A,n)||(await a(B+Q(t)+"ADD"+Q(n)+r),0==s&&await a("CREATE UNIQUE INDEX pk ON "+Q(t)+`(${Q(e)})`),Na(E,n))})):(await a(K+Q(t)+`(${Q(e)}${r} PRIMARY KEY${T(O(v,a=>n+Q(a)+r))});`),pa(w,t,Aa([e,...v])))),await m([...!d&&l?O(R(A),async n=>{n!=e&&(await a(B+Q(t)+"DROP"+Q(n)),M(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]):S(v)||await o(a,t,e,ea(n),{[s]:c?O(la(n),c):la(n)},E)}));else if(S(v))I(w,t)&&await a(Y+Q(t)+W(t,g));else{const n=b(R(da(w,t)),a=>a!=e),i={},r=[];ca(s??{},(a,t)=>{i[t]=O(n,t=>c?c(a?.[t]):a?.[t]),h(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}]},za=async(a,t,e,s,i)=>{const r=[1];await a("INSERT INTO"+Q(t)+"("+((...a)=>T(O(a,Q),n))(e,...s)+")VALUES"+T(oa(i,a=>"($"+r[0]+++","+V(a,r)+")"),n)+"ON CONFLICT("+Q(e)+")DO UPDATE SET"+T(O(s,a=>Q(a)+"=excluded."+Q(a)),n),oa(i,(a,t)=>[t,...O(a,a=>a??null)]).flat())},Ga=(a,t,e,n,s,i,r,[o,c,l],w,u,d,g,p,v)=>{const[E,A,N,m]=ka(t,w,u,s,p,v),$=Ya(a,()=>m(async()=>{return await E(),a=(await A(o,c))[_]?.[l]??"null",ja(Ua(a));var a}),a=>m(async()=>{var t;await E(),await N(o,c,{[_]:{[l]:(t=a()??null,Fa(t,(a,t)=>y(t)?"":t))}},!0,!0)}),e,n,s,r,{[g]:()=>d,destroy:async()=>(await $.stopAutoPersisting(),i(),$)},0,d);return $},Ha=(a,t,e,n,s,i,r,[o,c,[l,w,u]],d,g,p,v,E,A,N,$)=>{const[f,C,T,O]=ka(t,d,g,s,E,A,N,$),S=(a,t)=>m(ga(c,async([e,n,s,i,r],o)=>{t&&!(o in a)||await T(e,n,a[o],s,i,t,r)})),h=async(a,t)=>w?await T(u,F,{[_]:a},!0,!0,t):null,D=Ya(a,()=>O(async()=>{await f();const a=await(async()=>sa(b(await m(ga(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)=>O(async()=>{if(await f(),y(t)){const[t,e]=a();await S(t),await h(e)}else await S(t[0],!0),await h(t[1],!0)}),e,n,s,r,{[v]:()=>p,destroy:async()=>(await D.stopAutoPersisting(),i(),D)},0,p);return D},qa=(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,O,S,b]=(a=>{const e=(a=>ia(Pa,p(a)?{[Ca]:a}:a??{}))(a),n=e[Sa];if(e.mode==fa){const a=e[Ca]??t;return[1,n,[a,e[Ta]??F,e[Oa]??$a],Aa(a)]}const{tables:{load:s={},save:r={}}={},values:o={}}=e,c=E(la(ia(Ma,o)),0,wa(Ma)),l=c[2],w=Aa(l),y=Aa(l),u=_a(s,{[ha]:null,[ba]:F,[Ra]:i},ha,a=>I(y,a),a=>Na(w,a)),d=_a(r,{[Da]:null,[ba]:F,[Ia]:0,[La]:0,[Ra]:null},Da,(a,t)=>I(y,t),(a,t)=>Na(w,t));var g;return g=(a,t)=>t[4]??=da(u,t[0])?.[2]??i,P(d,(a,t)=>g(0,a)),[0,n,[u,d,c],w]})(n);return(T?Ga:Ha)(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*O),()=>{N=m=$=null,l(t)}},a=>a(),y,u,d,S,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),g,v,e,A,a=>(a=>!0===a)(a)?1:(a=>!1===a)(a)?0:a,void 0)},Ka=(a,t,e,n,s)=>qa(a,e,async(a,e=[])=>(await t.executeSql(a,e))[0].rows.raw(),0,0,n,s,N,3,t);export{Ka as createReactNativeSqlitePersister};
@@ -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),O=(a,t)=>a.map(t),S=a=>0==A(a),b=(a,t)=>a.filter(t),h=(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()??[]],P=(a,t)=>a?.forEach(t),M=(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(O(((a,t="",e)=>a.split(t,e))(a,"."),a=>`"${r(a,/"/g,'""')}"`),"."),V=(a,t=[1])=>T(O(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)=>O(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)=>O([...a?.entries()??[]],([a,e])=>t(e,a)),ga=(a,t,e)=>y(e)?(M(a,t),a):a?.set(t,e),pa=(a,t,e,n)=>(I(a,t)?n?.(ua(a,t)):ga(a,t,e()),ua(a,t)),va=(a,t,e,n,s=0)=>g((e?pa:ua)(a,t[s],s>A(t)-2?e:ya),i=>{if(s>A(t)-2)return n?.(i)&&ga(a,t[s]),i;const r=va(i,t,e,n,s+1);return L(i)&&ga(a,t[s]),r}),Ea=a=>new Set(v(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,Oa="autoLoadIntervalSeconds",Sa="rowId"+Na,ba="tableId",ha="tableName",Da="deleteEmptyColumns",Ia="deleteEmptyTable",La="condition",Ra={mode:$a,[Oa]:1},Pa={load:0,save:0,[ha]:t+"_values"},Ma=(a,t,e,n,s)=>{const i=ya();return oa(a,(a,r)=>{const o=E(ca(sa(t,p(a)?{[e]:a}:a)),0,la(t));u(o[0])||n(r,o[0])||(s(r,o[0]),ga(i,r,o))}),i},_a=JSON.stringify,Fa=JSON.parse,Ua=/^\d+$/,ja=ya(),xa=ya(),Ba=(a,t,n,s,i,r,o,c={},l=0,w=[])=>{let d,p,E,N=0,m=0,T=0;pa(ja,w,()=>0),pa(xa,w,()=>[]);const O=ya(),[S,b,I,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?D(a):null)??e+t++,t=>{Ua.test(t)&&A(a)<1e3&&h(a,t)}]})(),s=ya();return[(n,i,r,o=[],c=()=>[])=>{a??=Q;const l=t(1);return ga(s,l,[n,i,r,o,c]),Aa(va(i,r??[e],Ea),l),l},(t,n,...i)=>C(((a,t=[e])=>{const n=[],s=(a,e)=>e==A(t)?h(n,a):u(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=>g(ua(s,a),([,t,i])=>(va(t,i??[e],void 0,t=>(M(t,a),L(t)?1:0)),ga(s,a),n(a),i)),t=>g(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()})]})(),x=a=>{a!=N&&(N=a,U(O,void 0,N))},B=t=>{(S&&v(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},J=async a=>(2!=N&&(x(1),m++,await K(async()=>{await f(async()=>{const e=await t();v(e)?B(e):a?_(a):$("Content is not an array: "+e)},()=>{a&&_(a)}),x(0)})),Q),Y=async a=>(k(),await J(a),await f(async()=>p=await s(async(a,t)=>{t||a?2!=N&&(x(1),m++,B(t??a),x(0)):await J()}),r),Q),k=async()=>(p&&(await f(()=>i(p),r),p=void 0),Q),z=async a=>(1!=N&&(x(2),T++,await K(async()=>{await f(()=>n(b,a),r),x(0)})),Q),G=async()=>(H(),await z(),E=a.addDidFinishTransactionListener(()=>{const a=I();R(a)&&z(a)}),Q),H=async()=>(E&&(a.delListener(E),E=void 0),Q),q=async(a=!1)=>{const[t,e]=a?[H,k]:[k,H];return await t(),await e(),Q},K=async(...a)=>(h(ua(xa,w),...a),await(async()=>{if(!ua(ja,w)){for(ga(ja,w,1);!y(d=D(ua(xa,w)));)await f(d,r);ga(ja,w,0)}})(),Q),Q={load:J,startAutoLoad:Y,stopAutoLoad:k,isAutoLoading:()=>!y(p),save:z,startAutoSave:G,stopAutoSave:H,isAutoSaving:()=>!y(E),startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[G,Y]:[Y,G];return await e(a),await n(a),Q},stopAutoPersisting:q,getStatus:()=>N,addStatusListener:a=>F(a,O),delListener:t=>(j(t),a),schedule:K,getStore:()=>a,destroy:()=>(ua(xa,w).splice(0,void 0),q()),getStats:()=>({loads:m,saves:T}),...c};return ea(Q)},Ja=(a,t,e,s,r,o=Ya,c,l)=>{const w=ya();return[async()=>{w.clear(),O(await e(a,t),({tn:a,cn:t})=>Aa(pa(w,a,Ea),t))},async(t,e,n)=>((a,t)=>I(ua(w,a),t))(t,e)?na(b(O(await a(k+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,g=i)=>{const p=Ea();oa(s??{},a=>O(ta(a??{}),a=>Aa(p,a)));const v=R(p);if(!d&&u&&g==i&&S(v)&&I(w,t))return await a("DROP "+x+Q(t)),void ga(w,t);const E=ua(w,t),A=Ea(R(E));if(S(v)||(I(w,t)?await m(O([e,...v],async(n,s)=>{M(A,n)||(await a(B+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(O(v,a=>n+Q(a)+r))});`),ga(w,t,Ea([e,...v])))),await m([...!d&&l?O(R(A),async n=>{n!=e&&(await a(B+Q(t)+"DROP"+Q(n)),M(E,n))}):[]]),d)y(s)?await a(Y+Q(t)+W(t,g)):await m(ra(s,async(n,s)=>{y(n)?await a(Y+Q(t)+W(t,g)+`AND(${Q(e)}=$1)`,[s]):S(v)||await o(a,t,e,ta(n),{[s]:c?O(ca(n),c):ca(n)},E)}));else if(S(v))I(w,t)&&await a(Y+Q(t)+W(t,g));else{const n=b(R(ua(w,t)),a=>a!=e),i={},r=[];oa(s??{},(a,t)=>{i[t]=O(n,t=>c?c(a?.[t]):a?.[t]),h(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}]},Ya=async(a,t,e,s,i)=>{const r=[1];await a("INSERT INTO"+Q(t)+"("+((...a)=>T(O(a,Q),n))(e,...s)+")VALUES"+T(ra(i,a=>"($"+r[0]+++","+V(a,r)+")"),n)+"ON CONFLICT("+Q(e)+")DO UPDATE SET"+T(O(s,a=>Q(a)+"=excluded."+Q(a)),n),ra(i,(a,t)=>[t,...O(a,a=>a??null)]).flat())},ka=(a,t,e,n,s,i,r,[o,c,l],w,u,d,g,p,v)=>{const[E,A,N,m]=Ja(t,w,u,s,p,v),$=Ba(a,()=>m(async()=>{return await E(),a=(await A(o,c))[_]?.[l]??"null",Fa(a,(a,t)=>""===t?void 0:t);var a}),a=>m(async()=>{var t;await E(),await N(o,c,{[_]:{[l]:(t=a()??null,_a(t,(a,t)=>y(t)?"":t))}},!0,!0)}),e,n,s,r,{[g]:()=>d,destroy:async()=>(await $.stopAutoPersisting(),i(),$)},0,d);return $},za=(a,t,e,n,s,i,r,[o,c,[l,w,u]],d,g,p,v,E,A,N,$)=>{const[f,C,T,O]=Ja(t,d,g,s,E,A,N,$),S=(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)})),h=async(a,t)=>w?await T(u,F,{[_]:a},!0,!0,t):null,D=Ba(a,()=>O(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)=>O(async()=>{if(await f(),y(t)){const[t,e]=a();await S(t),await h(e)}else await S(t[0],!0),await h(t[1],!0)}),e,n,s,r,{[v]:()=>p,destroy:async()=>(await D.stopAutoPersisting(),i(),D)},0,p);return D},Ga=(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,O,S,b]=(a=>{const e=(a=>sa(Ra,p(a)?{[fa]:a}:a??{}))(a),n=e[Oa];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,[Sa]:F,[La]:i},ba,a=>I(y,a),a=>Aa(w,a)),d=Ma(r,{[ha]:null,[Sa]:F,[Da]:0,[Ia]:0,[La]:null},ha,(a,t)=>I(y,t),(a,t)=>Aa(w,t));var g;return g=(a,t)=>t[4]??=ua(u,t[0])?.[2]??i,P(d,(a,t)=>g(0,a)),[0,n,[u,d,c],w]})(n);return(T?ka:za)(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*O),()=>{N=m=$=null,l(t)}},a=>a(),y,u,d,S,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),g,v,e,A,a=>(a=>!0===a)(a)?1:(a=>!1===a)(a)?0:a,void 0)},Ha=(a,t,e,n,s)=>Ga(a,e,async(a,e=[])=>(await t.executeSql(a,e))[0].rows.raw(),0,0,n,s,N,3,t);export{Ha as createReactNativeSqlitePersister};
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),O=(a,t)=>a.map(t),S=a=>0==A(a),b=(a,t)=>a.filter(t),h=(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()??[]],P=(a,t)=>a?.forEach(t),M=(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(O(((a,t="",e)=>a.split(t,e))(a,"."),a=>`"${r(a,/"/g,'""')}"`),"."),V=(a,t=[1])=>T(O(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)=>O(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=a=>new Map(a),da=(a,t)=>a?.get(t),ga=(a,t)=>O([...a?.entries()??[]],([a,e])=>t(e,a)),pa=(a,t,e)=>y(e)?(M(a,t),a):a?.set(t,e),va=(a,t,e,n)=>(I(a,t)?n?.(da(a,t)):pa(a,t,e()),da(a,t)),Ea=(a,t,e,n,s=0)=>g((e?va:da)(a,t[s],s>A(t)-2?e:ua),i=>{if(s>A(t)-2)return n?.(i)&&pa(a,t[s]),i;const r=Ea(i,t,e,n,s+1);return L(i)&&pa(a,t[s]),r}),Aa=a=>new Set(v(a)||y(a)?a:[a]),Na=(a,t)=>a?.add(t),ma="ColumnName",$a="store",fa="json",Ca=$a+"TableName",Ta=$a+"Id"+ma,Oa=$a+ma,Sa="autoLoadIntervalSeconds",ba="rowId"+ma,ha="tableId",Da="tableName",Ia="deleteEmptyColumns",La="deleteEmptyTable",Ra="condition",Pa={mode:fa,[Sa]:1},Ma={load:0,save:0,[Da]:t+"_values"},_a=(a,t,e,n,s)=>{const i=ua();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]),pa(i,r,o))}),i},Fa=JSON.stringify,Ua=JSON.parse,ja=a=>""===a?void 0:v(a)?O(a,ja):ta(a)?ca(a,ja):a,xa=/^\d+$/,Ba=ua(),Ja=ua(),Ya=(a,t,n,s,i,r,o,c={},l=0,w=[])=>{let d,p,E,N=0,m=0,T=0;va(Ba,w,()=>0),va(Ja,w,()=>[]);const O=ua(),[S,b,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=>{xa.test(t)&&A(a)<1e3&&h(a,t)}]})(),s=ua();return[(n,i,r,o=[],c=()=>[])=>{a??=Q;const l=t(1);return pa(s,l,[n,i,r,o,c]),Na(Ea(i,r??[e],Aa),l),l},(t,n,...i)=>C(((a,t=[e])=>{const n=[],s=(a,e)=>e==A(t)?h(n,a):u(t[e])?P(a,a=>s(a,e+1)):C([t[e],null],t=>s(da(a,t),e+1));return s(a,0),n})(t,n),t=>P(t,t=>da(s,t)[0](a,...n??[],...i))),a=>g(da(s,a),([,t,i])=>(Ea(t,i??[e],void 0,t=>(M(t,a),L(t)?1:0)),pa(s,a),n(a),i)),t=>g(da(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(O,void 0,N))},B=t=>{(S&&v(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},J=async a=>(2!=N&&(x(1),m++,await K(async()=>{await f(async()=>{const e=await t();v(e)?B(e):a?_(a):$("Content is not an array: "+e)},()=>{a&&_(a)}),x(0)})),Q),Y=async a=>(k(),await J(a),await f(async()=>p=await s(async(a,t)=>{t||a?2!=N&&(x(1),m++,B(t??a),x(0)):await J()}),r),Q),k=async()=>(p&&(await f(()=>i(p),r),p=void 0),Q),z=async a=>(1!=N&&(x(2),T++,await K(async()=>{await f(()=>n(b,a),r),x(0)})),Q),G=async()=>(H(),await z(),E=a.addDidFinishTransactionListener(()=>{const a=I();R(a)&&z(a)}),Q),H=async()=>(E&&(a.delListener(E),E=void 0),Q),q=async(a=!1)=>{const[t,e]=a?[H,k]:[k,H];return await t(),await e(),Q},K=async(...a)=>(h(da(Ja,w),...a),await(async()=>{if(!da(Ba,w)){for(pa(Ba,w,1);!y(d=D(da(Ja,w)));)await f(d,r);pa(Ba,w,0)}})(),Q),Q={load:J,startAutoLoad:Y,stopAutoLoad:k,isAutoLoading:()=>!y(p),save:z,startAutoSave:G,stopAutoSave:H,isAutoSaving:()=>!y(E),startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[G,Y]:[Y,G];return await e(a),await n(a),Q},stopAutoPersisting:q,getStatus:()=>N,addStatusListener:a=>F(a,O),delListener:t=>(j(t),a),schedule:K,getStore:()=>a,destroy:()=>(da(Ja,w).splice(0,void 0),q()),getStats:()=>({loads:m,saves:T}),...c};return na(Q)},ka=(a,t,e,s,r,o=za,c,l)=>{const w=ua();return[async()=>{w.clear(),O(await e(a,t),({tn:a,cn:t})=>Na(va(w,a,Aa),t))},async(t,e,n)=>((a,t)=>I(da(w,a),t))(t,e)?sa(b(O(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=Aa();ca(s??{},a=>O(ea(a??{}),a=>Na(p,a)));const v=R(p);if(!d&&u&&g==i&&S(v)&&I(w,t))return await a("DROP "+x+Q(t)),void pa(w,t);const E=da(w,t),A=Aa(R(E));if(S(v)||(I(w,t)?await m(O([e,...v],async(n,s)=>{M(A,n)||(await a(B+Q(t)+"ADD"+Q(n)+r),0==s&&await a("CREATE UNIQUE INDEX pk ON "+Q(t)+`(${Q(e)})`),Na(E,n))})):(await a(K+Q(t)+`(${Q(e)}${r} PRIMARY KEY${T(O(v,a=>n+Q(a)+r))});`),pa(w,t,Aa([e,...v])))),await m([...!d&&l?O(R(A),async n=>{n!=e&&(await a(B+Q(t)+"DROP"+Q(n)),M(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]):S(v)||await o(a,t,e,ea(n),{[s]:c?O(la(n),c):la(n)},E)}));else if(S(v))I(w,t)&&await a(Y+Q(t)+W(t,g));else{const n=b(R(da(w,t)),a=>a!=e),i={},r=[];ca(s??{},(a,t)=>{i[t]=O(n,t=>c?c(a?.[t]):a?.[t]),h(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}]},za=async(a,t,e,s,i)=>{const r=[1];await a("INSERT INTO"+Q(t)+"("+((...a)=>T(O(a,Q),n))(e,...s)+")VALUES"+T(oa(i,a=>"($"+r[0]+++","+V(a,r)+")"),n)+"ON CONFLICT("+Q(e)+")DO UPDATE SET"+T(O(s,a=>Q(a)+"=excluded."+Q(a)),n),oa(i,(a,t)=>[t,...O(a,a=>a??null)]).flat())},Ga=(a,t,e,n,s,i,r,[o,c,l],w,u,d,g,p,v)=>{const[E,A,N,m]=ka(t,w,u,s,p,v),$=Ya(a,()=>m(async()=>{return await E(),a=(await A(o,c))[_]?.[l]??"null",ja(Ua(a));var a}),a=>m(async()=>{var t;await E(),await N(o,c,{[_]:{[l]:(t=a()??null,Fa(t,(a,t)=>y(t)?"":t))}},!0,!0)}),e,n,s,r,{[g]:()=>d,destroy:async()=>(await $.stopAutoPersisting(),i(),$)},0,d);return $},Ha=(a,t,e,n,s,i,r,[o,c,[l,w,u]],d,g,p,v,E,A,N,$)=>{const[f,C,T,O]=ka(t,d,g,s,E,A,N,$),S=(a,t)=>m(ga(c,async([e,n,s,i,r],o)=>{t&&!(o in a)||await T(e,n,a[o],s,i,t,r)})),h=async(a,t)=>w?await T(u,F,{[_]:a},!0,!0,t):null,D=Ya(a,()=>O(async()=>{await f();const a=await(async()=>sa(b(await m(ga(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)=>O(async()=>{if(await f(),y(t)){const[t,e]=a();await S(t),await h(e)}else await S(t[0],!0),await h(t[1],!0)}),e,n,s,r,{[v]:()=>p,destroy:async()=>(await D.stopAutoPersisting(),i(),D)},0,p);return D},qa=(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,O,S,b]=(a=>{const e=(a=>ia(Pa,p(a)?{[Ca]:a}:a??{}))(a),n=e[Sa];if(e.mode==fa){const a=e[Ca]??t;return[1,n,[a,e[Ta]??F,e[Oa]??$a],Aa(a)]}const{tables:{load:s={},save:r={}}={},values:o={}}=e,c=E(la(ia(Ma,o)),0,wa(Ma)),l=c[2],w=Aa(l),y=Aa(l),u=_a(s,{[ha]:null,[ba]:F,[Ra]:i},ha,a=>I(y,a),a=>Na(w,a)),d=_a(r,{[Da]:null,[ba]:F,[Ia]:0,[La]:0,[Ra]:null},Da,(a,t)=>I(y,t),(a,t)=>Na(w,t));var g;return g=(a,t)=>t[4]??=da(u,t[0])?.[2]??i,P(d,(a,t)=>g(0,a)),[0,n,[u,d,c],w]})(n);return(T?Ga:Ha)(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*O),()=>{N=m=$=null,l(t)}},a=>a(),y,u,d,S,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),g,v,e,A,a=>(a=>!0===a)(a)?1:(a=>!1===a)(a)?0:a,void 0)},Ka=(a,t,e,n,s)=>qa(a,e,async(a,e=[])=>(await t.executeSql(a,e))[0].rows.raw(),0,0,n,s,N,3,t);export{Ka as createReactNativeSqlitePersister};
@@ -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),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)),ga=(a,t,e)=>y(e)?(M(a,t),a):a?.set(t,e),pa=(a,t,e,n)=>(S(a,t)?n?.(ua(a,t)):ga(a,t,e()),ua(a,t)),va=(a,t,e,n,s=0)=>g((e?pa:ua)(a,t[s],s>A(t)-2?e:ya),i=>{if(s>A(t)-2)return n?.(i)&&ga(a,t[s]),i;const r=va(i,t,e,n,s+1);return L(i)&&ga(a,t[s]),r}),Ea=a=>new Set(v(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,p(a)?{[e]:a}:a)),0,la(t));u(o[0])||n(r,o[0])||(s(r,o[0]),ga(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,p,E,N=0,m=0,T=0;pa(ja,w,()=>0),pa(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 ga(s,l,[n,i,r,o,c]),Aa(va(i,r??[e],Ea),l),l},(t,n,...i)=>C(((a,t=[e])=>{const n=[],s=(a,e)=>e==A(t)?D(n,a):u(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=>g(ua(s,a),([,t,i])=>(va(t,i??[e],void 0,t=>(M(t,a),L(t)?1:0)),ga(s,a),n(a),i)),t=>g(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&&v(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();v(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()=>p=await s(async(a,t)=>{t||a?2!=N&&(B(1),m++,J(t??a),B(0)):await Y()}),r),Q),x=async()=>(p&&(await f(()=>i(p),r),p=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(ga(ja,w,1);!y(d=I(ua(Ba,w)));)await f(d,r);ga(ja,w,0)}})(),Q),Q={load:Y,startAutoLoad:k,stopAutoLoad:x,isAutoLoading:()=>!y(p),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(pa(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,g=i)=>{const p=Ea();oa(s??{},a=>h(ta(a??{}),a=>Aa(p,a)));const v=R(p);if(!d&&u&&g==i&&O(v)&&S(w,t))return await a("DROP "+B+Q(t)),void ga(w,t);const E=ua(w,t),A=Ea(R(E));if(O(v)||(S(w,t)?await m(h([e,...v],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(v,a=>n+Q(a)+r))});`),ga(w,t,Ea([e,...v])))),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,g)):await m(ra(s,async(n,s)=>{y(n)?await a(k+Q(t)+W(t,g)+`AND(${Q(e)}=$1)`,[s]):O(v)||await o(a,t,e,ta(n),{[s]:c?h(ca(n),c):ca(n)},E)}));else if(O(v))S(w,t)&&await a(k+Q(t)+W(t,g));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,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}]},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,u,d,g,p,v)=>{const[E,A,N,m]=Ya(t,w,u,s,p,v),$=Ja(a,()=>m(async()=>{return await E(),a=(await A(o,c))[_]?.[l]??"null",Fa(a,(a,t)=>""===t?void 0:t);var a}),a=>m(async()=>{var t;await E(),await N(o,c,{[_]:{[l]:(t=a()??null,_a(t,(a,t)=>y(t)?"":t))}},!0,!0)}),e,n,s,r,{[g]:()=>d,destroy:async()=>(await $.stopAutoPersisting(),i(),$)},0,d);return $},za=(a,t,e,n,s,i,r,[o,c,[l,w,u]],d,g,p,v,E,A,N,$)=>{const[f,C,T,h]=Ya(t,d,g,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,{[v]:()=>p,destroy:async()=>(await I.stopAutoPersisting(),i(),I)},0,p);return I},Ga=(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,b]=(a=>{const e=(a=>sa(Ra,p(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 g;return g=(a,t)=>t[4]??=ua(u,t[0])?.[2]??i,P(d,(a,t)=>g(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),g,v,e,A,a=>(a=>!0===a)(a)?1:(a=>!1===a)(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};
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),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=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=a=>new Map(a),da=(a,t)=>a?.get(t),ga=(a,t)=>h([...a?.entries()??[]],([a,e])=>t(e,a)),pa=(a,t,e)=>y(e)?(M(a,t),a):a?.set(t,e),va=(a,t,e,n)=>(S(a,t)?n?.(da(a,t)):pa(a,t,e()),da(a,t)),Ea=(a,t,e,n,s=0)=>g((e?va:da)(a,t[s],s>A(t)-2?e:ua),i=>{if(s>A(t)-2)return n?.(i)&&pa(a,t[s]),i;const r=Ea(i,t,e,n,s+1);return L(i)&&pa(a,t[s]),r}),Aa=a=>new Set(v(a)||y(a)?a:[a]),Na=(a,t)=>a?.add(t),ma="ColumnName",$a="store",fa="json",Ca=$a+"TableName",Ta=$a+"Id"+ma,ha=$a+ma,Oa="autoLoadIntervalSeconds",ba="rowId"+ma,Da="tableId",Ia="tableName",Sa="deleteEmptyColumns",La="deleteEmptyTable",Ra="condition",Pa={mode:fa,[Oa]:1},Ma={load:0,save:0,[Ia]:t+"_values"},_a=(a,t,e,n,s)=>{const i=ua();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]),pa(i,r,o))}),i},Fa=JSON.stringify,Ua=JSON.parse,ja=a=>""===a?void 0:v(a)?h(a,ja):ta(a)?ca(a,ja):a,Ba=/^\d+$/,Ja=ua(),Ya=ua(),ka=(a,t,n,s,i,r,o,c={},l=0,w=[])=>{let d,p,E,N=0,m=0,T=0;va(Ja,w,()=>0),va(Ya,w,()=>[]);const h=ua(),[O,b,S,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?I(a):null)??e+t++,t=>{Ba.test(t)&&A(a)<1e3&&D(a,t)}]})(),s=ua();return[(n,i,r,o=[],c=()=>[])=>{a??=Q;const l=t(1);return pa(s,l,[n,i,r,o,c]),Na(Ea(i,r??[e],Aa),l),l},(t,n,...i)=>C(((a,t=[e])=>{const n=[],s=(a,e)=>e==A(t)?D(n,a):u(t[e])?P(a,a=>s(a,e+1)):C([t[e],null],t=>s(da(a,t),e+1));return s(a,0),n})(t,n),t=>P(t,t=>da(s,t)[0](a,...n??[],...i))),a=>g(da(s,a),([,t,i])=>(Ea(t,i??[e],void 0,t=>(M(t,a),L(t)?1:0)),pa(s,a),n(a),i)),t=>g(da(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&&v(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();v(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()=>p=await s(async(a,t)=>{t||a?2!=N&&(B(1),m++,J(t??a),B(0)):await Y()}),r),Q),x=async()=>(p&&(await f(()=>i(p),r),p=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(da(Ya,w),...a),await(async()=>{if(!da(Ja,w)){for(pa(Ja,w,1);!y(d=I(da(Ya,w)));)await f(d,r);pa(Ja,w,0)}})(),Q),Q={load:Y,startAutoLoad:k,stopAutoLoad:x,isAutoLoading:()=>!y(p),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:()=>(da(Ya,w).splice(0,void 0),q()),getStats:()=>({loads:m,saves:T}),...c};return na(Q)},xa=(a,t,e,s,r,o=za,c,l)=>{const w=ua();return[async()=>{w.clear(),h(await e(a,t),({tn:a,cn:t})=>Na(va(w,a,Aa),t))},async(t,e,n)=>((a,t)=>S(da(w,a),t))(t,e)?sa(b(h(await a(x+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=Aa();ca(s??{},a=>h(ea(a??{}),a=>Na(p,a)));const v=R(p);if(!d&&u&&g==i&&O(v)&&S(w,t))return await a("DROP "+B+Q(t)),void pa(w,t);const E=da(w,t),A=Aa(R(E));if(O(v)||(S(w,t)?await m(h([e,...v],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)})`),Na(E,n))})):(await a(K+Q(t)+`(${Q(e)}${r} PRIMARY KEY${T(h(v,a=>n+Q(a)+r))});`),pa(w,t,Aa([e,...v])))),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,g)):await m(oa(s,async(n,s)=>{y(n)?await a(k+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))S(w,t)&&await a(k+Q(t)+W(t,g));else{const n=b(R(da(w,t)),a=>a!=e),i={},r=[];ca(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,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}]},za=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())},Ga=(a,t,e,n,s,i,r,[o,c,l],w,u,d,g,p,v)=>{const[E,A,N,m]=xa(t,w,u,s,p,v),$=ka(a,()=>m(async()=>{return await E(),a=(await A(o,c))[_]?.[l]??"null",ja(Ua(a));var a}),a=>m(async()=>{var t;await E(),await N(o,c,{[_]:{[l]:(t=a()??null,Fa(t,(a,t)=>y(t)?"":t))}},!0,!0)}),e,n,s,r,{[g]:()=>d,destroy:async()=>(await $.stopAutoPersisting(),i(),$)},0,d);return $},Ha=(a,t,e,n,s,i,r,[o,c,[l,w,u]],d,g,p,v,E,A,N,$)=>{const[f,C,T,h]=xa(t,d,g,s,E,A,N,$),O=(a,t)=>m(ga(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=ka(a,()=>h(async()=>{await f();const a=await(async()=>sa(b(await m(ga(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 D(e)}else await O(t[0],!0),await D(t[1],!0)}),e,n,s,r,{[v]:()=>p,destroy:async()=>(await I.stopAutoPersisting(),i(),I)},0,p);return I},qa=(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,b]=(a=>{const e=(a=>ia(Pa,p(a)?{[Ca]:a}:a??{}))(a),n=e[Oa];if(e.mode==fa){const a=e[Ca]??t;return[1,n,[a,e[Ta]??F,e[ha]??$a],Aa(a)]}const{tables:{load:s={},save:r={}}={},values:o={}}=e,c=E(la(ia(Ma,o)),0,wa(Ma)),l=c[2],w=Aa(l),y=Aa(l),u=_a(s,{[Da]:null,[ba]:F,[Ra]:i},Da,a=>S(y,a),a=>Na(w,a)),d=_a(r,{[Ia]:null,[ba]:F,[Sa]:0,[La]:0,[Ra]:null},Ia,(a,t)=>S(y,t),(a,t)=>Na(w,t));var g;return g=(a,t)=>t[4]??=da(u,t[0])?.[2]??i,P(d,(a,t)=>g(0,a)),[0,n,[u,d,c],w]})(n);return(T?Ga:Ha)(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),g,v,e,A,a=>(a=>!0===a)(a)?1:(a=>!1===a)(a)?0:a,void 0)},Ka=(a,t,e,n,s)=>qa(a,e,async(a,e=[])=>t.query(a).all(...e),()=>N,a=>a(),n,s,N,3,t);export{Ka as createSqliteBunPersister};
@@ -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),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)),ga=(a,t,e)=>y(e)?(M(a,t),a):a?.set(t,e),pa=(a,t,e,n)=>(S(a,t)?n?.(ua(a,t)):ga(a,t,e()),ua(a,t)),va=(a,t,e,n,s=0)=>g((e?pa:ua)(a,t[s],s>A(t)-2?e:ya),i=>{if(s>A(t)-2)return n?.(i)&&ga(a,t[s]),i;const r=va(i,t,e,n,s+1);return L(i)&&ga(a,t[s]),r}),Ea=a=>new Set(v(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,p(a)?{[e]:a}:a)),0,la(t));u(o[0])||n(r,o[0])||(s(r,o[0]),ga(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,p,E,N=0,m=0,T=0;pa(ja,w,()=>0),pa(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 ga(s,l,[n,i,r,o,c]),Aa(va(i,r??[e],Ea),l),l},(t,n,...i)=>C(((a,t=[e])=>{const n=[],s=(a,e)=>e==A(t)?D(n,a):u(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=>g(ua(s,a),([,t,i])=>(va(t,i??[e],void 0,t=>(M(t,a),L(t)?1:0)),ga(s,a),n(a),i)),t=>g(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&&v(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();v(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()=>p=await s(async(a,t)=>{t||a?2!=N&&(B(1),m++,J(t??a),B(0)):await Y()}),r),Q),x=async()=>(p&&(await f(()=>i(p),r),p=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(ga(ja,w,1);!y(d=I(ua(Ba,w)));)await f(d,r);ga(ja,w,0)}})(),Q),Q={load:Y,startAutoLoad:k,stopAutoLoad:x,isAutoLoading:()=>!y(p),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(pa(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,g=i)=>{const p=Ea();oa(s??{},a=>h(ta(a??{}),a=>Aa(p,a)));const v=R(p);if(!d&&u&&g==i&&O(v)&&S(w,t))return await a("DROP "+B+Q(t)),void ga(w,t);const E=ua(w,t),A=Ea(R(E));if(O(v)||(S(w,t)?await m(h([e,...v],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(v,a=>n+Q(a)+r))});`),ga(w,t,Ea([e,...v])))),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,g)):await m(ra(s,async(n,s)=>{y(n)?await a(k+Q(t)+W(t,g)+`AND(${Q(e)}=$1)`,[s]):O(v)||await o(a,t,e,ta(n),{[s]:c?h(ca(n),c):ca(n)},E)}));else if(O(v))S(w,t)&&await a(k+Q(t)+W(t,g));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,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}]},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,u,d,g,p,v)=>{const[E,A,N,m]=Ya(t,w,u,s,p,v),$=Ja(a,()=>m(async()=>{return await E(),a=(await A(o,c))[_]?.[l]??"null",Fa(a,(a,t)=>""===t?void 0:t);var a}),a=>m(async()=>{var t;await E(),await N(o,c,{[_]:{[l]:(t=a()??null,_a(t,(a,t)=>y(t)?"":t))}},!0,!0)}),e,n,s,r,{[g]:()=>d,destroy:async()=>(await $.stopAutoPersisting(),i(),$)},0,d);return $},za=(a,t,e,n,s,i,r,[o,c,[l,w,u]],d,g,p,v,E,A,N,$)=>{const[f,C,T,h]=Ya(t,d,g,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,{[v]:()=>p,destroy:async()=>(await I.stopAutoPersisting(),i(),I)},0,p);return I},Ga=(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,b]=(a=>{const e=(a=>sa(Ra,p(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 g;return g=(a,t)=>t[4]??=ua(u,t[0])?.[2]??i,P(d,(a,t)=>g(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),g,v,e,A,a=>(a=>!0===a)(a)?1:(a=>!1===a)(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};
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),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=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=a=>new Map(a),da=(a,t)=>a?.get(t),ga=(a,t)=>h([...a?.entries()??[]],([a,e])=>t(e,a)),pa=(a,t,e)=>y(e)?(M(a,t),a):a?.set(t,e),va=(a,t,e,n)=>(S(a,t)?n?.(da(a,t)):pa(a,t,e()),da(a,t)),Ea=(a,t,e,n,s=0)=>g((e?va:da)(a,t[s],s>A(t)-2?e:ua),i=>{if(s>A(t)-2)return n?.(i)&&pa(a,t[s]),i;const r=Ea(i,t,e,n,s+1);return L(i)&&pa(a,t[s]),r}),Aa=a=>new Set(v(a)||y(a)?a:[a]),Na=(a,t)=>a?.add(t),ma="ColumnName",$a="store",fa="json",Ca=$a+"TableName",Ta=$a+"Id"+ma,ha=$a+ma,Oa="autoLoadIntervalSeconds",ba="rowId"+ma,Da="tableId",Ia="tableName",Sa="deleteEmptyColumns",La="deleteEmptyTable",Ra="condition",Pa={mode:fa,[Oa]:1},Ma={load:0,save:0,[Ia]:t+"_values"},_a=(a,t,e,n,s)=>{const i=ua();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]),pa(i,r,o))}),i},Fa=JSON.stringify,Ua=JSON.parse,ja=a=>""===a?void 0:v(a)?h(a,ja):ta(a)?ca(a,ja):a,Ba=/^\d+$/,Ja=ua(),Ya=ua(),ka=(a,t,n,s,i,r,o,c={},l=0,w=[])=>{let d,p,E,N=0,m=0,T=0;va(Ja,w,()=>0),va(Ya,w,()=>[]);const h=ua(),[O,b,S,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?I(a):null)??e+t++,t=>{Ba.test(t)&&A(a)<1e3&&D(a,t)}]})(),s=ua();return[(n,i,r,o=[],c=()=>[])=>{a??=Q;const l=t(1);return pa(s,l,[n,i,r,o,c]),Na(Ea(i,r??[e],Aa),l),l},(t,n,...i)=>C(((a,t=[e])=>{const n=[],s=(a,e)=>e==A(t)?D(n,a):u(t[e])?P(a,a=>s(a,e+1)):C([t[e],null],t=>s(da(a,t),e+1));return s(a,0),n})(t,n),t=>P(t,t=>da(s,t)[0](a,...n??[],...i))),a=>g(da(s,a),([,t,i])=>(Ea(t,i??[e],void 0,t=>(M(t,a),L(t)?1:0)),pa(s,a),n(a),i)),t=>g(da(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&&v(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();v(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()=>p=await s(async(a,t)=>{t||a?2!=N&&(B(1),m++,J(t??a),B(0)):await Y()}),r),Q),x=async()=>(p&&(await f(()=>i(p),r),p=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(da(Ya,w),...a),await(async()=>{if(!da(Ja,w)){for(pa(Ja,w,1);!y(d=I(da(Ya,w)));)await f(d,r);pa(Ja,w,0)}})(),Q),Q={load:Y,startAutoLoad:k,stopAutoLoad:x,isAutoLoading:()=>!y(p),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:()=>(da(Ya,w).splice(0,void 0),q()),getStats:()=>({loads:m,saves:T}),...c};return na(Q)},xa=(a,t,e,s,r,o=za,c,l)=>{const w=ua();return[async()=>{w.clear(),h(await e(a,t),({tn:a,cn:t})=>Na(va(w,a,Aa),t))},async(t,e,n)=>((a,t)=>S(da(w,a),t))(t,e)?sa(b(h(await a(x+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=Aa();ca(s??{},a=>h(ea(a??{}),a=>Na(p,a)));const v=R(p);if(!d&&u&&g==i&&O(v)&&S(w,t))return await a("DROP "+B+Q(t)),void pa(w,t);const E=da(w,t),A=Aa(R(E));if(O(v)||(S(w,t)?await m(h([e,...v],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)})`),Na(E,n))})):(await a(K+Q(t)+`(${Q(e)}${r} PRIMARY KEY${T(h(v,a=>n+Q(a)+r))});`),pa(w,t,Aa([e,...v])))),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,g)):await m(oa(s,async(n,s)=>{y(n)?await a(k+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))S(w,t)&&await a(k+Q(t)+W(t,g));else{const n=b(R(da(w,t)),a=>a!=e),i={},r=[];ca(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,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}]},za=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())},Ga=(a,t,e,n,s,i,r,[o,c,l],w,u,d,g,p,v)=>{const[E,A,N,m]=xa(t,w,u,s,p,v),$=ka(a,()=>m(async()=>{return await E(),a=(await A(o,c))[_]?.[l]??"null",ja(Ua(a));var a}),a=>m(async()=>{var t;await E(),await N(o,c,{[_]:{[l]:(t=a()??null,Fa(t,(a,t)=>y(t)?"":t))}},!0,!0)}),e,n,s,r,{[g]:()=>d,destroy:async()=>(await $.stopAutoPersisting(),i(),$)},0,d);return $},Ha=(a,t,e,n,s,i,r,[o,c,[l,w,u]],d,g,p,v,E,A,N,$)=>{const[f,C,T,h]=xa(t,d,g,s,E,A,N,$),O=(a,t)=>m(ga(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=ka(a,()=>h(async()=>{await f();const a=await(async()=>sa(b(await m(ga(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 D(e)}else await O(t[0],!0),await D(t[1],!0)}),e,n,s,r,{[v]:()=>p,destroy:async()=>(await I.stopAutoPersisting(),i(),I)},0,p);return I},qa=(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,b]=(a=>{const e=(a=>ia(Pa,p(a)?{[Ca]:a}:a??{}))(a),n=e[Oa];if(e.mode==fa){const a=e[Ca]??t;return[1,n,[a,e[Ta]??F,e[ha]??$a],Aa(a)]}const{tables:{load:s={},save:r={}}={},values:o={}}=e,c=E(la(ia(Ma,o)),0,wa(Ma)),l=c[2],w=Aa(l),y=Aa(l),u=_a(s,{[Da]:null,[ba]:F,[Ra]:i},Da,a=>S(y,a),a=>Na(w,a)),d=_a(r,{[Ia]:null,[ba]:F,[Sa]:0,[La]:0,[Ra]:null},Ia,(a,t)=>S(y,t),(a,t)=>Na(w,t));var g;return g=(a,t)=>t[4]??=da(u,t[0])?.[2]??i,P(d,(a,t)=>g(0,a)),[0,n,[u,d,c],w]})(n);return(T?Ga:Ha)(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),g,v,e,A,a=>(a=>!0===a)(a)?1:(a=>!1===a)(a)?0:a,void 0)},Ka=(a,t,e,n,s)=>qa(a,e,async(a,e=[])=>t.query(a).all(...e),()=>N,a=>a(),n,s,N,3,t);export{Ka as createSqliteBunPersister};
@@ -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=clearInterval,w=a=>null==a,u=a=>void 0===a,y=a=>null===a,d=c(w),p=c(u),g=t=>a(t)==s,v=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)=>u(e)?(M(a,t),a):a?.set(t,e),ga=(a,t,e,n)=>(S(a,t)?n?.(ya(a,t)):pa(a,t,e()),ya(a,t)),va=(a,t,e,n,s=0)=>p((e?ga: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=va(i,t,e,n,s+1);return L(i)&&pa(a,t[s]),o}),Ea=a=>new Set(v(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,g(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,g,E,m=0,N=0,b=0;ga(ka,w,()=>0),ga(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(va(i,o??[e],Ea),l),l},(t,n,...i)=>h(((a,t=[e])=>{const n=[],s=(a,e)=>e==A(t)?D(n,a):y(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])=>(va(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&&v(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();v(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()=>g=await s(async(a,t)=>{t||a?2!=m&&(U(1),N++,x(t??a),U(0)):await B()}),o),K),Y=async()=>(g&&(await f(()=>i(g),o),g=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(g),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(ga(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 g=Ea();ra(s??{},a=>C(ta(a??{}),a=>Aa(g,a)));const v=R(g);if(!d&&y&&p==i&&T(v)&&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(v)||(S(w,t)?await N(C([e,...v],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(v,a=>n+K(a)+o))});`),pa(w,t,Ea([e,...v])))),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(v)||await r(a,t,e,ta(n),{[s]:c?C(ca(n),c):ca(n)},E)}));else if(T(v))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,y,d,p,g,v)=>{const[E,A,m,N]=Ba(t,w,y,s,g,v),$=xa(a,()=>N(async()=>{return await E(),a=(await A(r,c))[P]?.[l]??"null",Fa(a,(a,t)=>""===t?void 0:t);var a}),a=>N(async()=>{var t;await E(),await m(r,c,{[P]:{[l]:(t=a()??null,Pa(t,(a,t)=>u(t)?"":t))}},!0,!0)}),e,n,s,o,{[p]:()=>d,destroy:async()=>(await $.stopAutoPersisting(),i(),$)},0,d);return $},qa=(a,t,e,n,s,i,o,[r,c,[l,w,y]],d,p,g,v,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,{[v]:()=>g,destroy:async()=>(await I.stopAutoPersisting(),i(),I)},0,g);return I},za=(a,n,s,o,r,c,u,y,d,p,v="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,g(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,v,e,A,a=>(a=>!0===a)(a)?1:(a=>!1===a)(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};
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),g=t=>a(t)==s,v=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=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),oa=(a,t)=>(delete a[t],a),ra=(a,t)=>C(aa(a),([a,e])=>t(e,a)),ca=(a,t)=>sa(ra(a,(a,e)=>[e,t(a,e)])),la=a=>X.values(a),wa=a=>A(ea(a)),ua=a=>ta(a)&&0==wa(a),ya=a=>new Map(a),da=(a,t)=>a?.get(t),pa=(a,t)=>C([...a?.entries()??[]],([a,e])=>t(e,a)),ga=(a,t,e)=>u(e)?(M(a,t),a):a?.set(t,e),va=(a,t,e,n)=>(S(a,t)?n?.(da(a,t)):ga(a,t,e()),da(a,t)),Ea=(a,t,e,n,s=0)=>p((e?va:da)(a,t[s],s>A(t)-2?e:ya),i=>{if(s>A(t)-2)return n?.(i)&&ga(a,t[s]),i;const o=Ea(i,t,e,n,s+1);return L(i)&&ga(a,t[s]),o}),Aa=a=>new Set(v(a)||u(a)?a:[a]),ma=(a,t)=>a?.add(t),Na="ColumnName",$a="store",fa="json",ha=$a+"TableName",ba=$a+"Id"+Na,Ca=$a+Na,Ta="autoLoadIntervalSeconds",Oa="rowId"+Na,Da="tableId",Ia="tableName",Sa="deleteEmptyColumns",La="deleteEmptyTable",Ra="condition",_a={mode:fa,[Ta]:1},Ma={load:0,save:0,[Ia]:t+"_values"},Pa=(a,t,e,n,s)=>{const i=ya();return ca(a,(a,o)=>{const r=E(la(ia(t,g(a)?{[e]:a}:a)),0,wa(t));y(r[0])||n(o,r[0])||(s(o,r[0]),ga(i,o,r))}),i},Fa=JSON.stringify,ja=JSON.parse,ka=a=>""===a?void 0:v(a)?C(a,ka):ta(a)?ca(a,ka):a,Ua=/^\d+$/,xa=ya(),Ba=ya(),Ja=(a,t,n,s,i,o,r,c={},l=0,w=[])=>{let d,g,E,m=0,N=0,b=0;va(xa,w,()=>0),va(Ba,w,()=>[]);const C=ya(),[T,O,S,R,P]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!ua(a)||!ua(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!ua(a)||!ua(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=>{Ua.test(t)&&A(a)<1e3&&D(a,t)}]})(),s=ya();return[(n,i,o,r=[],c=()=>[])=>{a??=K;const l=t(1);return ga(s,l,[n,i,o,r,c]),ma(Ea(i,o??[e],Aa),l),l},(t,n,...i)=>h(((a,t=[e])=>{const n=[],s=(a,e)=>e==A(t)?D(n,a):y(t[e])?_(a,a=>s(a,e+1)):h([t[e],null],t=>s(da(a,t),e+1));return s(a,0),n})(t,n),t=>_(t,t=>da(s,t)[0](a,...n??[],...i))),a=>p(da(s,a),([,t,i])=>(Ea(t,i??[e],void 0,t=>(M(t,a),L(t)?1:0)),ga(s,a),n(a),i)),t=>p(da(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&&v(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();v(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()=>g=await s(async(a,t)=>{t||a?2!=m&&(U(1),N++,x(t??a),U(0)):await B()}),o),K),Y=async()=>(g&&(await f(()=>i(g),o),g=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(da(Ba,w),...a),await(async()=>{if(!da(xa,w)){for(ga(xa,w,1);!u(d=I(da(Ba,w)));)await f(d,o);ga(xa,w,0)}})(),K),K={load:B,startAutoLoad:J,stopAutoLoad:Y,isAutoLoading:()=>!u(g),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:()=>(da(Ba,w).splice(0,void 0),H()),getStats:()=>({loads:N,saves:b}),...c};return na(K)},Ya=(a,t,e,s,o,r=qa,c,l)=>{const w=ya();return[async()=>{w.clear(),C(await e(a,t),({tn:a,cn:t})=>ma(va(w,a,Aa),t))},async(t,e,n)=>((a,t)=>S(da(w,a),t))(t,e)?sa(O(C(await a(Y+K(t)+W(t,n)),a=>[a[e],l?ca(oa(a,e),l):oa(a,e)]),([a,t])=>!u(a)&&!ua(t))):{},async(t,e,s,l,y,d=!1,p=i)=>{const g=Aa();ca(s??{},a=>C(ea(a??{}),a=>ma(g,a)));const v=R(g);if(!d&&y&&p==i&&T(v)&&S(w,t))return await a("DROP "+U+K(t)),void ga(w,t);const E=da(w,t),A=Aa(R(E));if(T(v)||(S(w,t)?await N(C([e,...v],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)})`),ma(E,n))})):(await a(V+K(t)+`(${K(e)}${o} PRIMARY KEY${b(C(v,a=>n+K(a)+o))});`),ga(w,t,Aa([e,...v])))),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(ra(s,async(n,s)=>{u(n)?await a(J+K(t)+W(t,p)+`AND(${K(e)}=$1)`,[s]):T(v)||await r(a,t,e,ea(n),{[s]:c?C(la(n),c):la(n)},E)}));else if(T(v))S(w,t)&&await a(J+K(t)+W(t,p));else{const n=O(R(da(w,t)),a=>a!=e),i={},o=[];ca(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}]},qa=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(ra(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),ra(i,(a,t)=>[t,...C(a,a=>a??null)]).flat())},za=(a,t,e,n,s,i,o,[r,c,l],w,y,d,p,g,v)=>{const[E,A,m,N]=Ya(t,w,y,s,g,v),$=Ja(a,()=>N(async()=>{return await E(),a=(await A(r,c))[P]?.[l]??"null",ka(ja(a));var a}),a=>N(async()=>{var t;await E(),await m(r,c,{[P]:{[l]:(t=a()??null,Fa(t,(a,t)=>u(t)?"":t))}},!0,!0)}),e,n,s,o,{[p]:()=>d,destroy:async()=>(await $.stopAutoPersisting(),i(),$)},0,d);return $},Ga=(a,t,e,n,s,i,o,[r,c,[l,w,y]],d,p,g,v,E,A,m,$)=>{const[f,h,b,C]=Ya(t,d,p,s,E,A,m,$),T=(a,t)=>N(pa(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=Ja(a,()=>C(async()=>{await f();const a=await(async()=>sa(O(await N(pa(r,async([a,t,e],n)=>[a,await h(n,t,e)])),a=>!ua(a[1]))))(),t=await(async()=>l?(await h(y,F))[P]:{})();return ua(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,{[v]:()=>g,destroy:async()=>(await I.stopAutoPersisting(),i(),I)},0,g);return I},Ha=(a,n,s,o,r,c,u,y,d,p,v="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=>ia(_a,g(a)?{[ha]:a}:a??{}))(a),n=e[Ta];if(e.mode==fa){const a=e[ha]??t;return[1,n,[a,e[ba]??F,e[Ca]??$a],Aa(a)]}const{tables:{load:s={},save:o={}}={},values:r={}}=e,c=E(la(ia(Ma,r)),0,wa(Ma)),l=c[2],w=Aa(l),u=Aa(l),y=Pa(s,{[Da]:null,[Oa]:F,[Ra]:i},Da,a=>S(u,a),a=>ma(w,a)),d=Pa(o,{[Ia]:null,[Oa]:F,[Sa]:0,[La]:0,[Ra]:null},Ia,(a,t)=>S(u,t),(a,t)=>ma(w,t));var p;return p=(a,t)=>t[4]??=da(y,t[0])?.[2]??i,_(d,(a,t)=>p(0,a)),[0,n,[y,d,c],w]})(n);return(b?za:Ga)(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,v,e,A,a=>(a=>!0===a)(a)?1:(a=>!1===a)(a)?0:a,void 0)},Va=(a,t,e,n,s,i)=>Ha(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{Va as createSqliteWasmPersister};