tinybase 6.2.0 → 6.3.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (184) hide show
  1. package/@types/omni/index.d.ts +1 -0
  2. package/@types/omni/with-schemas/index.d.ts +1 -0
  3. package/@types/persisters/index.d.ts +4 -2
  4. package/@types/persisters/persister-durable-object-sql-storage/index.d.ts +348 -0
  5. package/@types/persisters/persister-durable-object-sql-storage/with-schemas/index.d.ts +381 -0
  6. package/@types/persisters/with-schemas/index.d.ts +4 -2
  7. package/@types/queries/index.d.ts +1 -1
  8. package/@types/queries/with-schemas/index.d.ts +1 -1
  9. package/LICENSE +1 -1
  10. package/min/checkpoints/index.js +1 -1
  11. package/min/checkpoints/index.js.gz +0 -0
  12. package/min/checkpoints/with-schemas/index.js +1 -1
  13. package/min/checkpoints/with-schemas/index.js.gz +0 -0
  14. package/min/common/index.js +1 -1
  15. package/min/common/index.js.gz +0 -0
  16. package/min/common/with-schemas/index.js +1 -1
  17. package/min/common/with-schemas/index.js.gz +0 -0
  18. package/min/index.js +1 -1
  19. package/min/index.js.gz +0 -0
  20. package/min/indexes/index.js +1 -1
  21. package/min/indexes/index.js.gz +0 -0
  22. package/min/indexes/with-schemas/index.js +1 -1
  23. package/min/indexes/with-schemas/index.js.gz +0 -0
  24. package/min/mergeable-store/index.js +1 -1
  25. package/min/mergeable-store/index.js.gz +0 -0
  26. package/min/mergeable-store/with-schemas/index.js +1 -1
  27. package/min/mergeable-store/with-schemas/index.js.gz +0 -0
  28. package/min/metrics/index.js +1 -1
  29. package/min/metrics/index.js.gz +0 -0
  30. package/min/metrics/with-schemas/index.js +1 -1
  31. package/min/metrics/with-schemas/index.js.gz +0 -0
  32. package/min/omni/index.js +1 -1
  33. package/min/omni/index.js.gz +0 -0
  34. package/min/omni/with-schemas/index.js +1 -1
  35. package/min/omni/with-schemas/index.js.gz +0 -0
  36. package/min/persisters/index.js +1 -1
  37. package/min/persisters/index.js.gz +0 -0
  38. package/min/persisters/persister-automerge/index.js +1 -1
  39. package/min/persisters/persister-automerge/index.js.gz +0 -0
  40. package/min/persisters/persister-automerge/with-schemas/index.js +1 -1
  41. package/min/persisters/persister-automerge/with-schemas/index.js.gz +0 -0
  42. package/min/persisters/persister-browser/index.js +1 -1
  43. package/min/persisters/persister-browser/index.js.gz +0 -0
  44. package/min/persisters/persister-browser/with-schemas/index.js +1 -1
  45. package/min/persisters/persister-browser/with-schemas/index.js.gz +0 -0
  46. package/min/persisters/persister-cr-sqlite-wasm/index.js +1 -1
  47. package/min/persisters/persister-cr-sqlite-wasm/index.js.gz +0 -0
  48. package/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.js +1 -1
  49. package/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.js.gz +0 -0
  50. package/min/persisters/persister-durable-object-sql-storage/index.js +1 -0
  51. package/min/persisters/persister-durable-object-sql-storage/index.js.gz +0 -0
  52. package/min/persisters/persister-durable-object-sql-storage/with-schemas/index.js +1 -0
  53. package/min/persisters/persister-durable-object-sql-storage/with-schemas/index.js.gz +0 -0
  54. package/min/persisters/persister-durable-object-storage/index.js +1 -1
  55. package/min/persisters/persister-durable-object-storage/index.js.gz +0 -0
  56. package/min/persisters/persister-durable-object-storage/with-schemas/index.js +1 -1
  57. package/min/persisters/persister-durable-object-storage/with-schemas/index.js.gz +0 -0
  58. package/min/persisters/persister-electric-sql/index.js +1 -1
  59. package/min/persisters/persister-electric-sql/index.js.gz +0 -0
  60. package/min/persisters/persister-electric-sql/with-schemas/index.js +1 -1
  61. package/min/persisters/persister-electric-sql/with-schemas/index.js.gz +0 -0
  62. package/min/persisters/persister-expo-sqlite/index.js +1 -1
  63. package/min/persisters/persister-expo-sqlite/index.js.gz +0 -0
  64. package/min/persisters/persister-expo-sqlite/with-schemas/index.js +1 -1
  65. package/min/persisters/persister-expo-sqlite/with-schemas/index.js.gz +0 -0
  66. package/min/persisters/persister-file/index.js +1 -1
  67. package/min/persisters/persister-file/index.js.gz +0 -0
  68. package/min/persisters/persister-file/with-schemas/index.js +1 -1
  69. package/min/persisters/persister-file/with-schemas/index.js.gz +0 -0
  70. package/min/persisters/persister-indexed-db/index.js +1 -1
  71. package/min/persisters/persister-indexed-db/index.js.gz +0 -0
  72. package/min/persisters/persister-indexed-db/with-schemas/index.js +1 -1
  73. package/min/persisters/persister-indexed-db/with-schemas/index.js.gz +0 -0
  74. package/min/persisters/persister-libsql/index.js +1 -1
  75. package/min/persisters/persister-libsql/index.js.gz +0 -0
  76. package/min/persisters/persister-libsql/with-schemas/index.js +1 -1
  77. package/min/persisters/persister-libsql/with-schemas/index.js.gz +0 -0
  78. package/min/persisters/persister-partykit-client/index.js +1 -1
  79. package/min/persisters/persister-partykit-client/index.js.gz +0 -0
  80. package/min/persisters/persister-partykit-client/with-schemas/index.js +1 -1
  81. package/min/persisters/persister-partykit-client/with-schemas/index.js.gz +0 -0
  82. package/min/persisters/persister-partykit-server/index.js +1 -1
  83. package/min/persisters/persister-partykit-server/index.js.gz +0 -0
  84. package/min/persisters/persister-partykit-server/with-schemas/index.js +1 -1
  85. package/min/persisters/persister-partykit-server/with-schemas/index.js.gz +0 -0
  86. package/min/persisters/persister-pglite/index.js +1 -1
  87. package/min/persisters/persister-pglite/index.js.gz +0 -0
  88. package/min/persisters/persister-pglite/with-schemas/index.js +1 -1
  89. package/min/persisters/persister-pglite/with-schemas/index.js.gz +0 -0
  90. package/min/persisters/persister-postgres/index.js +1 -1
  91. package/min/persisters/persister-postgres/index.js.gz +0 -0
  92. package/min/persisters/persister-postgres/with-schemas/index.js +1 -1
  93. package/min/persisters/persister-postgres/with-schemas/index.js.gz +0 -0
  94. package/min/persisters/persister-powersync/index.js +1 -1
  95. package/min/persisters/persister-powersync/index.js.gz +0 -0
  96. package/min/persisters/persister-powersync/with-schemas/index.js +1 -1
  97. package/min/persisters/persister-powersync/with-schemas/index.js.gz +0 -0
  98. package/min/persisters/persister-remote/index.js +1 -1
  99. package/min/persisters/persister-remote/index.js.gz +0 -0
  100. package/min/persisters/persister-remote/with-schemas/index.js +1 -1
  101. package/min/persisters/persister-remote/with-schemas/index.js.gz +0 -0
  102. package/min/persisters/persister-sqlite-bun/index.js +1 -1
  103. package/min/persisters/persister-sqlite-bun/index.js.gz +0 -0
  104. package/min/persisters/persister-sqlite-bun/with-schemas/index.js +1 -1
  105. package/min/persisters/persister-sqlite-bun/with-schemas/index.js.gz +0 -0
  106. package/min/persisters/persister-sqlite-wasm/index.js +1 -1
  107. package/min/persisters/persister-sqlite-wasm/index.js.gz +0 -0
  108. package/min/persisters/persister-sqlite-wasm/with-schemas/index.js +1 -1
  109. package/min/persisters/persister-sqlite-wasm/with-schemas/index.js.gz +0 -0
  110. package/min/persisters/persister-sqlite3/index.js +1 -1
  111. package/min/persisters/persister-sqlite3/index.js.gz +0 -0
  112. package/min/persisters/persister-sqlite3/with-schemas/index.js +1 -1
  113. package/min/persisters/persister-sqlite3/with-schemas/index.js.gz +0 -0
  114. package/min/persisters/persister-yjs/index.js +1 -1
  115. package/min/persisters/persister-yjs/index.js.gz +0 -0
  116. package/min/persisters/persister-yjs/with-schemas/index.js +1 -1
  117. package/min/persisters/persister-yjs/with-schemas/index.js.gz +0 -0
  118. package/min/persisters/with-schemas/index.js +1 -1
  119. package/min/persisters/with-schemas/index.js.gz +0 -0
  120. package/min/queries/index.js +1 -1
  121. package/min/queries/index.js.gz +0 -0
  122. package/min/queries/with-schemas/index.js +1 -1
  123. package/min/queries/with-schemas/index.js.gz +0 -0
  124. package/min/relationships/index.js +1 -1
  125. package/min/relationships/index.js.gz +0 -0
  126. package/min/relationships/with-schemas/index.js +1 -1
  127. package/min/relationships/with-schemas/index.js.gz +0 -0
  128. package/min/store/index.js +1 -1
  129. package/min/store/index.js.gz +0 -0
  130. package/min/store/with-schemas/index.js +1 -1
  131. package/min/store/with-schemas/index.js.gz +0 -0
  132. package/min/synchronizers/index.js +1 -1
  133. package/min/synchronizers/index.js.gz +0 -0
  134. package/min/synchronizers/synchronizer-broadcast-channel/index.js +1 -1
  135. package/min/synchronizers/synchronizer-broadcast-channel/index.js.gz +0 -0
  136. package/min/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js +1 -1
  137. package/min/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js.gz +0 -0
  138. package/min/synchronizers/synchronizer-local/index.js +1 -1
  139. package/min/synchronizers/synchronizer-local/index.js.gz +0 -0
  140. package/min/synchronizers/synchronizer-local/with-schemas/index.js +1 -1
  141. package/min/synchronizers/synchronizer-local/with-schemas/index.js.gz +0 -0
  142. package/min/synchronizers/synchronizer-ws-client/index.js +1 -1
  143. package/min/synchronizers/synchronizer-ws-client/index.js.gz +0 -0
  144. package/min/synchronizers/synchronizer-ws-client/with-schemas/index.js +1 -1
  145. package/min/synchronizers/synchronizer-ws-client/with-schemas/index.js.gz +0 -0
  146. package/min/synchronizers/synchronizer-ws-server/index.js +1 -1
  147. package/min/synchronizers/synchronizer-ws-server/index.js.gz +0 -0
  148. package/min/synchronizers/synchronizer-ws-server/with-schemas/index.js +1 -1
  149. package/min/synchronizers/synchronizer-ws-server/with-schemas/index.js.gz +0 -0
  150. package/min/synchronizers/synchronizer-ws-server-durable-object/index.js +1 -1
  151. package/min/synchronizers/synchronizer-ws-server-durable-object/index.js.gz +0 -0
  152. package/min/synchronizers/synchronizer-ws-server-durable-object/with-schemas/index.js +1 -1
  153. package/min/synchronizers/synchronizer-ws-server-durable-object/with-schemas/index.js.gz +0 -0
  154. package/min/synchronizers/synchronizer-ws-server-simple/index.js +1 -1
  155. package/min/synchronizers/synchronizer-ws-server-simple/index.js.gz +0 -0
  156. package/min/synchronizers/synchronizer-ws-server-simple/with-schemas/index.js +1 -1
  157. package/min/synchronizers/synchronizer-ws-server-simple/with-schemas/index.js.gz +0 -0
  158. package/min/synchronizers/with-schemas/index.js +1 -1
  159. package/min/synchronizers/with-schemas/index.js.gz +0 -0
  160. package/min/ui-react/index.js +1 -1
  161. package/min/ui-react/index.js.gz +0 -0
  162. package/min/ui-react/with-schemas/index.js +1 -1
  163. package/min/ui-react/with-schemas/index.js.gz +0 -0
  164. package/min/ui-react-dom/index.js +1 -1
  165. package/min/ui-react-dom/index.js.gz +0 -0
  166. package/min/ui-react-dom/with-schemas/index.js +1 -1
  167. package/min/ui-react-dom/with-schemas/index.js.gz +0 -0
  168. package/min/ui-react-inspector/index.js +1 -1
  169. package/min/ui-react-inspector/index.js.gz +0 -0
  170. package/min/ui-react-inspector/with-schemas/index.js +1 -1
  171. package/min/ui-react-inspector/with-schemas/index.js.gz +0 -0
  172. package/min/with-schemas/index.js +1 -1
  173. package/min/with-schemas/index.js.gz +0 -0
  174. package/omni/index.js +4 -1
  175. package/omni/with-schemas/index.js +4 -1
  176. package/package.json +43 -7
  177. package/persisters/persister-browser/index.js +4 -1
  178. package/persisters/persister-browser/with-schemas/index.js +4 -1
  179. package/persisters/persister-durable-object-sql-storage/index.js +1391 -0
  180. package/persisters/persister-durable-object-sql-storage/with-schemas/index.js +1391 -0
  181. package/readme.md +13 -13
  182. package/releases.md +30 -30
  183. package/ui-react-inspector/index.js +4 -1
  184. package/ui-react-inspector/with-schemas/index.js +4 -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=clearInterval,l=a=>null==a,w=(a,t,e)=>l(a)?e?.():t(a),u=t=>a(t)==s,y=a=>Array.isArray(a),d=(a,t,e)=>a.slice(t,e),g=a=>a.length,E=()=>{},v=async a=>o.all(a),p=a=>{throw Error(a)},A=async(a,t,e)=>{try{return await a()}catch(a){t?.(a)}},N=(a,t)=>a.forEach(t),m=(a,t="")=>a.join(t),$=(a,t)=>a.map(t),f=a=>0==g(a),C=(a,t)=>a.filter(t),T=(a,...t)=>a.push(...t),b=a=>a.shift(),h=(a,t)=>a?.has(t)??!1,O=a=>l(a)||0==(a=>a?.size??0)(a),I=a=>[...a?.values()??[]],S=(a,t)=>a?.forEach(t),D=(a,t)=>a?.delete(t),L=Object,R=a=>L.getPrototypeOf(a),P=L.entries,M=L.keys,_=L.freeze,F=(a=[])=>L.fromEntries(a),U=(...a)=>L.assign({},...a),j=(a,t)=>(delete a[t],a),x=(a,t)=>$(P(a),(([a,e])=>t(e,a))),B=(a,t)=>F(x(a,((a,e)=>[e,t(a,e)]))),J=a=>L.values(a),Y=a=>g(M(a)),k=a=>(a=>!l(a)&&w(R(a),(a=>a==L.prototype||l(R(a))),(()=>!0)))(a)&&0==Y(a),z=a=>new Set(y(a)||l(a)?a:[a]),G=(a,t)=>a?.add(t),H="_",V="_id",K="SELECT",Q="WHERE",W="TABLE",X="INSERT",q="ALTER "+W,Z="FROM",aa="DELETE "+Z,ta=K+"*"+Z,ea="pragma_",na="data_version",sa="schema_version",ia="pragma_table_",ra="CREATE "+W,oa=a=>m($(((a,t="",e)=>a.split(t,e))(a,"."),(a=>`"${r(a,/"/g,'""')}"`)),"."),ca=(...a)=>m($(a,oa),n),la=(a,t=[1])=>m($(a,(()=>"$"+t[0]++)),n),wa=(a,t=i)=>Q+`(${r(t,"$tableName",oa(a))})`,ua=a=>new Map(a),ya=(a,t)=>a?.get(t),da=(a,t)=>$([...a?.entries()??[]],(([a,e])=>t(e,a))),ga=(a,t,e)=>l(e)?(D(a,t),a):a?.set(t,e),Ea=(a,t,e,n)=>(h(a,t)?n?.(ya(a,t)):ga(a,t,e()),ya(a,t)),va=(a,t,e,n,s=0)=>w((e?Ea:ya)(a,t[s],s>g(t)-2?e:ua),(i=>{if(s>g(t)-2)return n?.(i)&&ga(a,t[s]),i;const r=va(i,t,e,n,s+1);return O(i)&&ga(a,t[s]),r})),pa="ColumnName",Aa="store",Na="json",ma=Aa+"TableName",$a=Aa+"Id"+pa,fa=Aa+pa,Ca="autoLoadIntervalSeconds",Ta="rowId"+pa,ba="tableId",ha="tableName",Oa="deleteEmptyColumns",Ia="deleteEmptyTable",Sa="condition",Da={mode:Na,[Ca]:1},La={load:0,save:0,[ha]:t+"_values"},Ra=(a,t,e,n,s)=>{const i=ua();return B(a,((a,r)=>{const o=d(J(U(t,u(a)?{[e]:a}:a)),0,Y(t));l(o[0])||n(r,o[0])||(s(r,o[0]),ga(i,r,o))})),i},Pa=JSON.stringify,Ma=JSON.parse,_a=/^\d+$/,Fa=ua(),Ua=ua(),ja=(a,t,n,s,i,r,o,c={},u=0,d=[])=>{let E,v,m,$=0,f=0,C=0;Ea(Fa,d,(()=>0)),Ea(Ua,d,(()=>[]));const h=ua(),[I,L,R,P,M]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!k(a)||!k(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!k(a)||!k(t),t.setContent]:p("Store type not supported by this Persister"))(o,a,u),[F,U,j]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?b(a):null)??e+t++,t=>{_a.test(t)&&g(a)<1e3&&T(a,t)}]})(),s=ua();return[(n,i,r,o=[],c=()=>[])=>{a??=q;const l=t(1);return ga(s,l,[n,i,r,o,c]),G(va(i,r??[e],z),l),l},(t,n,...i)=>N(((a,t=[e])=>{const n=[],s=(a,e)=>e==g(t)?T(n,a):null===t[e]?S(a,(a=>s(a,e+1))):N([t[e],null],(t=>s(ya(a,t),e+1)));return s(a,0),n})(t,n),(t=>S(t,(t=>ya(s,t)[0](a,...n??[],...i))))),a=>w(ya(s,a),(([,t,i])=>(va(t,i??[e],void 0,(t=>(D(t,a),O(t)?1:0))),ga(s,a),n(a),i))),t=>w(ya(s,t),(([t,,e=[],n,s])=>{const i=(...r)=>{const o=g(r);o==g(e)?t(a,...r,...s(r)):l(e[o])?N(n[o]?.(...r)??[],(a=>i(...r,a))):i(...r,e[o])};i()}))]})(),x=a=>{a!=$&&($=a,U(h,void 0,$))},B=t=>{(I&&y(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},J=async a=>(2!=$&&(x(1),f++,await X((async()=>{await A((async()=>{const e=await t();y(e)?B(e):a?M(a):p("Content is not an array: "+e)}),(()=>{a&&M(a)})),x(0)}))),q),Y=async a=>(H(),await J(a),await A((async()=>v=await s((async(a,t)=>{t||a?2!=$&&(x(1),f++,B(t??a),x(0)):await J()}))),r),q),H=async()=>(v&&(await A((()=>i(v)),r),v=void 0),q),V=async a=>(1!=$&&(x(2),C++,await X((async()=>{await A((()=>n(L,a)),r),x(0)}))),q),K=async()=>(Q(),await V(),m=a.addDidFinishTransactionListener((()=>{const a=R();P(a)&&V(a)})),q),Q=async()=>(m&&(a.delListener(m),m=void 0),q),W=async(a=!1)=>{const[t,e]=a?[Q,H]:[H,Q];return await t(),await e(),q},X=async(...a)=>(T(ya(Ua,d),...a),await(async()=>{if(!ya(Fa,d)){for(ga(Fa,d,1);!l(E=b(ya(Ua,d)));)await A(E,r);ga(Fa,d,0)}})(),q),q={load:J,startAutoLoad:Y,stopAutoLoad:H,isAutoLoading:()=>!l(v),save:V,startAutoSave:K,stopAutoSave:Q,isAutoSaving:()=>!l(m),startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[K,Y]:[Y,K];return await e(a),await n(a),q},stopAutoPersisting:W,getStatus:()=>$,addStatusListener:a=>F(a,h),delListener:t=>(j(t),a),schedule:X,getStore:()=>a,destroy:()=>(ya(Ua,d).splice(0,void 0),W()),getStats:()=>({loads:f,saves:C}),...c};return _(q)},xa=(a,t,e,s,r,o=Ba,c,w)=>{const u=ua();return[async()=>{u.clear(),$(await e(a,t),(({tn:a,cn:t})=>G(Ea(u,a,z),t)))},async(t,e,n)=>((a,t)=>h(ya(u,a),t))(t,e)?F(C($(await a(ta+oa(t)+wa(t,n)),(a=>[a[e],w?B(j(a,e),w):j(a,e)])),(([a,t])=>!l(a)&&!k(t)))):{},async(t,e,s,w,y,d=!1,g=i)=>{const E=z();B(s??{},(a=>$(M(a??{}),(a=>G(E,a)))));const p=I(E);if(!d&&y&&g==i&&f(p)&&h(u,t))return await a("DROP "+W+oa(t)),void ga(u,t);const A=ya(u,t),N=z(I(A));if(f(p)||(h(u,t)?await v($([e,...p],(async(n,s)=>{D(N,n)||(await a(q+oa(t)+"ADD"+oa(n)+r),0==s&&await a("CREATE UNIQUE INDEX pk ON "+oa(t)+`(${oa(e)})`),G(A,n))}))):(await a(ra+oa(t)+`(${oa(e)}${r} PRIMARY KEY${m($(p,(a=>n+oa(a)+r)))});`),ga(u,t,z([e,...p])))),await v([...!d&&w?$(I(N),(async n=>{n!=e&&(await a(q+oa(t)+"DROP"+oa(n)),D(A,n))})):[]]),d)l(s)?await a(aa+oa(t)+wa(t,g)):await v(x(s,(async(n,s)=>{l(n)?await a(aa+oa(t)+wa(t,g)+`AND(${oa(e)}=$1)`,[s]):f(p)||await o(a,t,e,M(n),{[s]:c?$(J(n),c):J(n)},A)})));else if(f(p))h(u,t)&&await a(aa+oa(t)+wa(t,g));else{const n=C(I(ya(u,t)),(a=>a!=e)),i={},r=[];B(s??{},((a,t)=>{i[t]=$(n,(t=>c?c(a?.[t]):a?.[t])),T(r,t)})),await o(a,t,e,n,i),await a(aa+oa(t)+wa(t,g)+`AND${oa(e)}NOT IN(${la(r)})`,r)}},async t=>{let e;return await a("BEGIN"),await A((async()=>e=await t()),s),await a("END"),e}]},Ba=async(a,t,e,s,i)=>{const r=[1];await a(X+" INTO"+oa(t)+"("+ca(e,...s)+")VALUES"+m(x(i,(a=>"($"+r[0]+++","+la(a,r)+")")),n)+"ON CONFLICT("+oa(e)+")DO UPDATE SET"+m($(s,(a=>oa(a)+"=excluded."+oa(a))),n),x(i,((a,t)=>[t,...$(a,(a=>a??null))])).flat())},Ja=(a,t,e,n,s,i,r,[o,c,l],w,u,y,d,g,E)=>{const[v,p,A,N]=xa(t,w,u,s,g,E),m=ja(a,(()=>N((async()=>{return await v(),a=(await p(o,c))[H]?.[l]??"null",Ma(a,((a,t)=>""===t?void 0:t));var a}))),(a=>N((async()=>{var t;await v(),await A(o,c,{[H]:{[l]:(t=a()??null,Pa(t,((a,t)=>void 0===t?"":t)))}},!0,!0)}))),e,n,s,r,{[d]:()=>y,destroy:async()=>(await m.stopAutoPersisting(),i(),m)},0,y);return m},Ya=(a,t,e,n,s,i,r,[o,c,[w,u,y]],d,g,E,p,A,N,m,$)=>{const[f,T,b,h]=xa(t,d,g,s,A,N,m,$),O=(a,t)=>v(da(c,(async([e,n,s,i,r],o)=>{t&&!(o in a)||await b(e,n,a[o],s,i,t,r)}))),I=async(a,t)=>u?await b(y,V,{[H]:a},!0,!0,t):null,S=ja(a,(()=>h((async()=>{await f();const a=await(async()=>F(C(await v(da(o,(async([a,t,e],n)=>[a,await T(n,t,e)]))),(a=>!k(a[1])))))(),t=await(async()=>w?(await T(y,V))[H]:{})();return k(a)&&l(t)?void 0:[a,t]}))),((a,t)=>h((async()=>{if(await f(),l(t)){const[t,e]=a();await O(t),await I(e)}else await O(t[0],!0),await I(t[1],!0)}))),e,n,s,r,{[p]:()=>E,destroy:async()=>(await S.stopAutoPersisting(),i(),S)},0,E);return S},ka=(a,n,s,r,o,l,w,y,g,E,v="getDb",p)=>{let N,m,$;const f=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,l),[C,T,b,O]=(a=>{const e=(a=>U(Da,u(a)?{[ma]:a}:a??{}))(a),n=e[Ca];if(e.mode==Na){const a=e[ma]??t;return[1,n,[a,e[$a]??V,e[fa]??Aa],z(a)]}const{tables:{load:s={},save:r={}}={},values:o={}}=e,c=d(J(U(La,o)),0,Y(La)),l=c[2],w=z(l),y=z(l),g=Ra(s,{[ba]:null,[Ta]:V,[Sa]:i},ba,(a=>h(y,a)),(a=>G(w,a))),E=Ra(r,{[ha]:null,[Ta]:V,[Oa]:0,[Ia]:0,[Sa]:null},ha,((a,t)=>h(y,t)),((a,t)=>G(w,t)));var v;return v=(a,t)=>t[4]??=ya(g,t[0])?.[2]??i,S(E,((a,t)=>v(0,a))),[0,n,[g,E,c],w]})(n);return(C?Ja:Ya)(a,f,(a=>{let t;const e=()=>t=setInterval((()=>A((async()=>{const[{d:t,s:e,c:n}]=await f(K+` ${na} d,${sa} s,TOTAL_CHANGES() c FROM ${ea}${na} JOIN ${ea}${sa}`);t==N&&e==m&&n==$||(null!=N&&a(),N=t,m=e,$=n)}))),1e3*T),n=()=>{N=m=$=null,c(t)},s=r((t=>{O.has(t)&&(n(),a(),e())}));return e(),()=>{n(),o(s)}}),(a=>a()),w,y,g,b,I(O),(async(a,t)=>await a(K+` t.name tn,c.name cn FROM ${ia}list()t,${ia}info(t.name)c ${Q} t.schema='main'AND t.type IN('table','view')AND t.name IN(${la(t)})ORDER BY t.name,c.name`,t)),E,v,e,p,(a=>!0===a?1:!1===a?0:a),void 0)},za=(a,t,e,n,s)=>{let i;return ka(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&&$(a.changedTables,i)})(),i=a,e}),(a=>{i=void 0,a.abort()}),n,s,E,1,t,"getPowerSync",Ga)},Ga=async(a,t,e,s,i,r)=>{const o=[1],c=z(s),l=r?C([...r],(a=>a!=e&&!h(c,a))):[];if(!f(l)){const n=M(i),s=F($(await a(K+ca(e,...l)+Z+oa(t)+Q+oa(e)+"IN("+la(n)+")",n),(a=>[a[e],a])));N(n,(a=>T(i[a],...$(l,(t=>s?.[a]?.[t]??null)))))}await a(X+" OR REPLACE INTO"+oa(t)+"("+ca(e,...s,...l)+")VALUES"+m(x(i,(a=>"($"+o[0]+++","+la(a,o)+")")),n),x(i,((a,t)=>[t,...$(a,(a=>a??null))])).flat())};export{za 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=clearInterval,l=a=>null==a,w=(a,t,e)=>l(a)?e?.():t(a),u=t=>a(t)==s,y=a=>Array.isArray(a),d=(a,t,e)=>a.slice(t,e),g=a=>a.length,E=()=>{},v=async a=>o.all(a),p=a=>{throw Error(a)},A=async(a,t,e)=>{try{return await a()}catch(a){t?.(a)}},N=(a,t)=>a.forEach(t),m=(a,t="")=>a.join(t),$=(a,t)=>a.map(t),f=a=>0==g(a),C=(a,t)=>a.filter(t),T=(a,...t)=>a.push(...t),b=a=>a.shift(),h=(a,t)=>a?.has(t)??!1,O=a=>l(a)||0==(a=>a?.size??0)(a),I=a=>[...a?.values()??[]],S=(a,t)=>a?.forEach(t),D=(a,t)=>a?.delete(t),L=Object,R=a=>L.getPrototypeOf(a),P=L.entries,M=L.keys,_=L.freeze,F=(a=[])=>L.fromEntries(a),U=(...a)=>L.assign({},...a),j=(a,t)=>(delete a[t],a),x=(a,t)=>$(P(a),([a,e])=>t(e,a)),B=(a,t)=>F(x(a,(a,e)=>[e,t(a,e)])),J=a=>L.values(a),Y=a=>g(M(a)),k=a=>(a=>!l(a)&&w(R(a),a=>a==L.prototype||l(R(a)),()=>!0))(a)&&0==Y(a),z=a=>new Set(y(a)||l(a)?a:[a]),G=(a,t)=>a?.add(t),H="_",V="_id",K="SELECT",Q="WHERE",W="TABLE",X="INSERT",q="ALTER "+W,Z="FROM",aa="DELETE "+Z,ta=K+"*"+Z,ea="pragma_",na="data_version",sa="schema_version",ia="pragma_table_",ra="CREATE "+W,oa=a=>m($(((a,t="",e)=>a.split(t,e))(a,"."),a=>`"${r(a,/"/g,'""')}"`),"."),ca=(...a)=>m($(a,oa),n),la=(a,t=[1])=>m($(a,()=>"$"+t[0]++),n),wa=(a,t=i)=>Q+`(${r(t,"$tableName",oa(a))})`,ua=a=>new Map(a),ya=(a,t)=>a?.get(t),da=(a,t)=>$([...a?.entries()??[]],([a,e])=>t(e,a)),ga=(a,t,e)=>l(e)?(D(a,t),a):a?.set(t,e),Ea=(a,t,e,n)=>(h(a,t)?n?.(ya(a,t)):ga(a,t,e()),ya(a,t)),va=(a,t,e,n,s=0)=>w((e?Ea:ya)(a,t[s],s>g(t)-2?e:ua),i=>{if(s>g(t)-2)return n?.(i)&&ga(a,t[s]),i;const r=va(i,t,e,n,s+1);return O(i)&&ga(a,t[s]),r}),pa="ColumnName",Aa="store",Na="json",ma=Aa+"TableName",$a=Aa+"Id"+pa,fa=Aa+pa,Ca="autoLoadIntervalSeconds",Ta="rowId"+pa,ba="tableId",ha="tableName",Oa="deleteEmptyColumns",Ia="deleteEmptyTable",Sa="condition",Da={mode:Na,[Ca]:1},La={load:0,save:0,[ha]:t+"_values"},Ra=(a,t,e,n,s)=>{const i=ua();return B(a,(a,r)=>{const o=d(J(U(t,u(a)?{[e]:a}:a)),0,Y(t));l(o[0])||n(r,o[0])||(s(r,o[0]),ga(i,r,o))}),i},Pa=JSON.stringify,Ma=JSON.parse,_a=/^\d+$/,Fa=ua(),Ua=ua(),ja=(a,t,n,s,i,r,o,c={},u=0,d=[])=>{let E,v,m,$=0,f=0,C=0;Ea(Fa,d,()=>0),Ea(Ua,d,()=>[]);const h=ua(),[I,L,R,P,M]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!k(a)||!k(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!k(a)||!k(t),t.setContent]:p("Store type not supported by this Persister"))(o,a,u),[F,U,j]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?b(a):null)??e+t++,t=>{_a.test(t)&&g(a)<1e3&&T(a,t)}]})(),s=ua();return[(n,i,r,o=[],c=()=>[])=>{a??=q;const l=t(1);return ga(s,l,[n,i,r,o,c]),G(va(i,r??[e],z),l),l},(t,n,...i)=>N(((a,t=[e])=>{const n=[],s=(a,e)=>e==g(t)?T(n,a):null===t[e]?S(a,a=>s(a,e+1)):N([t[e],null],t=>s(ya(a,t),e+1));return s(a,0),n})(t,n),t=>S(t,t=>ya(s,t)[0](a,...n??[],...i))),a=>w(ya(s,a),([,t,i])=>(va(t,i??[e],void 0,t=>(D(t,a),O(t)?1:0)),ga(s,a),n(a),i)),t=>w(ya(s,t),([t,,e=[],n,s])=>{const i=(...r)=>{const o=g(r);o==g(e)?t(a,...r,...s(r)):l(e[o])?N(n[o]?.(...r)??[],a=>i(...r,a)):i(...r,e[o])};i()})]})(),x=a=>{a!=$&&($=a,U(h,void 0,$))},B=t=>{(I&&y(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},J=async a=>(2!=$&&(x(1),f++,await X(async()=>{await A(async()=>{const e=await t();y(e)?B(e):a?M(a):p("Content is not an array: "+e)},()=>{a&&M(a)}),x(0)})),q),Y=async a=>(H(),await J(a),await A(async()=>v=await s(async(a,t)=>{t||a?2!=$&&(x(1),f++,B(t??a),x(0)):await J()}),r),q),H=async()=>(v&&(await A(()=>i(v),r),v=void 0),q),V=async a=>(1!=$&&(x(2),C++,await X(async()=>{await A(()=>n(L,a),r),x(0)})),q),K=async()=>(Q(),await V(),m=a.addDidFinishTransactionListener(()=>{const a=R();P(a)&&V(a)}),q),Q=async()=>(m&&(a.delListener(m),m=void 0),q),W=async(a=!1)=>{const[t,e]=a?[Q,H]:[H,Q];return await t(),await e(),q},X=async(...a)=>(T(ya(Ua,d),...a),await(async()=>{if(!ya(Fa,d)){for(ga(Fa,d,1);!l(E=b(ya(Ua,d)));)await A(E,r);ga(Fa,d,0)}})(),q),q={load:J,startAutoLoad:Y,stopAutoLoad:H,isAutoLoading:()=>!l(v),save:V,startAutoSave:K,stopAutoSave:Q,isAutoSaving:()=>!l(m),startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[K,Y]:[Y,K];return await e(a),await n(a),q},stopAutoPersisting:W,getStatus:()=>$,addStatusListener:a=>F(a,h),delListener:t=>(j(t),a),schedule:X,getStore:()=>a,destroy:()=>(ya(Ua,d).splice(0,void 0),W()),getStats:()=>({loads:f,saves:C}),...c};return _(q)},xa=(a,t,e,s,r,o=Ba,c,w)=>{const u=ua();return[async()=>{u.clear(),$(await e(a,t),({tn:a,cn:t})=>G(Ea(u,a,z),t))},async(t,e,n)=>((a,t)=>h(ya(u,a),t))(t,e)?F(C($(await a(ta+oa(t)+wa(t,n)),a=>[a[e],w?B(j(a,e),w):j(a,e)]),([a,t])=>!l(a)&&!k(t))):{},async(t,e,s,w,y,d=!1,g=i)=>{const E=z();B(s??{},a=>$(M(a??{}),a=>G(E,a)));const p=I(E);if(!d&&y&&g==i&&f(p)&&h(u,t))return await a("DROP "+W+oa(t)),void ga(u,t);const A=ya(u,t),N=z(I(A));if(f(p)||(h(u,t)?await v($([e,...p],async(n,s)=>{D(N,n)||(await a(q+oa(t)+"ADD"+oa(n)+r),0==s&&await a("CREATE UNIQUE INDEX pk ON "+oa(t)+`(${oa(e)})`),G(A,n))})):(await a(ra+oa(t)+`(${oa(e)}${r} PRIMARY KEY${m($(p,a=>n+oa(a)+r))});`),ga(u,t,z([e,...p])))),await v([...!d&&w?$(I(N),async n=>{n!=e&&(await a(q+oa(t)+"DROP"+oa(n)),D(A,n))}):[]]),d)l(s)?await a(aa+oa(t)+wa(t,g)):await v(x(s,async(n,s)=>{l(n)?await a(aa+oa(t)+wa(t,g)+`AND(${oa(e)}=$1)`,[s]):f(p)||await o(a,t,e,M(n),{[s]:c?$(J(n),c):J(n)},A)}));else if(f(p))h(u,t)&&await a(aa+oa(t)+wa(t,g));else{const n=C(I(ya(u,t)),a=>a!=e),i={},r=[];B(s??{},(a,t)=>{i[t]=$(n,t=>c?c(a?.[t]):a?.[t]),T(r,t)}),await o(a,t,e,n,i),await a(aa+oa(t)+wa(t,g)+`AND${oa(e)}NOT IN(${la(r)})`,r)}},async t=>{let e;return await a("BEGIN"),await A(async()=>e=await t(),s),await a("END"),e}]},Ba=async(a,t,e,s,i)=>{const r=[1];await a(X+" INTO"+oa(t)+"("+ca(e,...s)+")VALUES"+m(x(i,a=>"($"+r[0]+++","+la(a,r)+")"),n)+"ON CONFLICT("+oa(e)+")DO UPDATE SET"+m($(s,a=>oa(a)+"=excluded."+oa(a)),n),x(i,(a,t)=>[t,...$(a,a=>a??null)]).flat())},Ja=(a,t,e,n,s,i,r,[o,c,l],w,u,y,d,g,E)=>{const[v,p,A,N]=xa(t,w,u,s,g,E),m=ja(a,()=>N(async()=>{return await v(),a=(await p(o,c))[H]?.[l]??"null",Ma(a,(a,t)=>""===t?void 0:t);var a}),a=>N(async()=>{var t;await v(),await A(o,c,{[H]:{[l]:(t=a()??null,Pa(t,(a,t)=>void 0===t?"":t))}},!0,!0)}),e,n,s,r,{[d]:()=>y,destroy:async()=>(await m.stopAutoPersisting(),i(),m)},0,y);return m},Ya=(a,t,e,n,s,i,r,[o,c,[w,u,y]],d,g,E,p,A,N,m,$)=>{const[f,T,b,h]=xa(t,d,g,s,A,N,m,$),O=(a,t)=>v(da(c,async([e,n,s,i,r],o)=>{t&&!(o in a)||await b(e,n,a[o],s,i,t,r)})),I=async(a,t)=>u?await b(y,V,{[H]:a},!0,!0,t):null,S=ja(a,()=>h(async()=>{await f();const a=await(async()=>F(C(await v(da(o,async([a,t,e],n)=>[a,await T(n,t,e)])),a=>!k(a[1]))))(),t=await(async()=>w?(await T(y,V))[H]:{})();return k(a)&&l(t)?void 0:[a,t]}),(a,t)=>h(async()=>{if(await f(),l(t)){const[t,e]=a();await O(t),await I(e)}else await O(t[0],!0),await I(t[1],!0)}),e,n,s,r,{[p]:()=>E,destroy:async()=>(await S.stopAutoPersisting(),i(),S)},0,E);return S},ka=(a,n,s,r,o,l,w,y,g,E,v="getDb",p)=>{let N,m,$;const f=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,l),[C,T,b,O]=(a=>{const e=(a=>U(Da,u(a)?{[ma]:a}:a??{}))(a),n=e[Ca];if(e.mode==Na){const a=e[ma]??t;return[1,n,[a,e[$a]??V,e[fa]??Aa],z(a)]}const{tables:{load:s={},save:r={}}={},values:o={}}=e,c=d(J(U(La,o)),0,Y(La)),l=c[2],w=z(l),y=z(l),g=Ra(s,{[ba]:null,[Ta]:V,[Sa]:i},ba,a=>h(y,a),a=>G(w,a)),E=Ra(r,{[ha]:null,[Ta]:V,[Oa]:0,[Ia]:0,[Sa]:null},ha,(a,t)=>h(y,t),(a,t)=>G(w,t));var v;return v=(a,t)=>t[4]??=ya(g,t[0])?.[2]??i,S(E,(a,t)=>v(0,a)),[0,n,[g,E,c],w]})(n);return(C?Ja:Ya)(a,f,a=>{let t;const e=()=>t=setInterval(()=>A(async()=>{const[{d:t,s:e,c:n}]=await f(K+` ${na} d,${sa} s,TOTAL_CHANGES() c FROM ${ea}${na} JOIN ${ea}${sa}`);t==N&&e==m&&n==$||(null!=N&&a(),N=t,m=e,$=n)}),1e3*T),n=()=>{N=m=$=null,c(t)},s=r(t=>{O.has(t)&&(n(),a(),e())});return e(),()=>{n(),o(s)}},a=>a(),w,y,g,b,I(O),async(a,t)=>await a(K+` t.name tn,c.name cn FROM ${ia}list()t,${ia}info(t.name)c ${Q} t.schema='main'AND t.type IN('table','view')AND t.name IN(${la(t)})ORDER BY t.name,c.name`,t),E,v,e,p,a=>!0===a?1:!1===a?0:a,void 0)},za=(a,t,e,n,s)=>{let i;return ka(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&&$(a.changedTables,i)})(),i=a,e},a=>{i=void 0,a.abort()},n,s,E,1,t,"getPowerSync",Ga)},Ga=async(a,t,e,s,i,r)=>{const o=[1],c=z(s),l=r?C([...r],a=>a!=e&&!h(c,a)):[];if(!f(l)){const n=M(i),s=F($(await a(K+ca(e,...l)+Z+oa(t)+Q+oa(e)+"IN("+la(n)+")",n),a=>[a[e],a]));N(n,a=>T(i[a],...$(l,t=>s?.[a]?.[t]??null)))}await a(X+" OR REPLACE INTO"+oa(t)+"("+ca(e,...s,...l)+")VALUES"+m(x(i,a=>"($"+o[0]+++","+la(a,o)+")"),n),x(i,(a,t)=>[t,...$(a,a=>a??null)]).flat())};export{za as createPowerSyncPersister};
@@ -1 +1 @@
1
- const t=clearInterval,e=t=>null==t,a=(t,a,n)=>e(t)?n?.():a(t),n=t=>Array.isArray(t),s=t=>t.length,r=t=>{throw Error(t)},o=async(t,e,a)=>{try{return await t()}catch(t){e?.(t)}},i=(t,e)=>t.forEach(e),c=(t,...e)=>t.push(...e),y=t=>t.shift(),l=Object,u=t=>l.getPrototypeOf(t),d=l.keys,g=l.freeze,w=t=>(t=>!e(t)&&a(u(t),(t=>t==l.prototype||e(u(t))),(()=>!0)))(t)&&0==(t=>s(d(t)))(t),h=JSON.stringify,p=JSON.parse,f=t=>e(t)||0==(t=>t?.size??0)(t),v=(t,e)=>t?.forEach(e),C=(t,e)=>t?.delete(e),S=t=>new Map(t),A=(t,e)=>t?.get(e),b=(t,a,n)=>e(n)?(C(t,a),t):t?.set(a,n),L=(t,e,a,n)=>{var s,r;return s=t,r=e,s?.has(r)?n?.(A(t,e)):b(t,e,a()),A(t,e)},M=(t,e,n,r,o=0)=>a((n?L:A)(t,e[o],o>s(e)-2?n:S),(a=>{if(o>s(e)-2)return r?.(a)&&b(t,e[o]),a;const i=M(a,e,n,r,o+1);return f(a)&&b(t,e[o]),i})),E=/^\d+$/,T=t=>new Set(n(t)||e(t)?t:[t]),O=S(),P=S(),m=(t,l,u,d,h,p,m,D={},j=0,x=[])=>{let z,I,J,N=0,k=0,F=0;L(O,x,(()=>0)),L(P,x,(()=>[]));const H=S(),[U,$,q,B,G]=((t=1,e,a)=>1!=t&&e.isMergeable()?[1,e.getMergeableContent,()=>e.getTransactionMergeableChanges(!a),([[t],[e]])=>!w(t)||!w(e),e.setDefaultContent]:2!=t?[0,e.getContent,e.getTransactionChanges,([t,e])=>!w(t)||!w(e),e.setContent]:r("Store type not supported by this Persister"))(m,t,j),[K,Q,R]=(()=>{let t;const[n,r]=(()=>{const t=[];let e=0;return[a=>(a?y(t):null)??""+e++,e=>{E.test(e)&&s(t)<1e3&&c(t,e)}]})(),o=S();return[(e,a,s,r=[],i=()=>[])=>{t??=st;const c=n(1);var y,l;return b(o,c,[e,a,s,r,i]),y=M(a,s??[""],T),l=c,y?.add(l),c},(e,a,...n)=>i(((t,e=[""])=>{const a=[],n=(t,r)=>r==s(e)?c(a,t):null===e[r]?v(t,(t=>n(t,r+1))):i([e[r],null],(e=>n(A(t,e),r+1)));return n(t,0),a})(e,a),(e=>v(e,(e=>A(o,e)[0](t,...a??[],...n))))),t=>a(A(o,t),(([,e,a])=>(M(e,a??[""],void 0,(e=>(C(e,t),f(e)?1:0))),b(o,t),r(t),a))),n=>a(A(o,n),(([a,,n=[],r,o])=>{const c=(...y)=>{const l=s(y);l==s(n)?a(t,...y,...o(y)):e(n[l])?i(r[l]?.(...y)??[],(t=>c(...y,t))):c(...y,n[l])};c()}))]})(),V=t=>{t!=N&&(N=t,Q(H,void 0,N))},W=e=>{(U&&n(e?.[0])?1===e?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===e?.[2]?t.applyChanges:t.setContent)(e)},X=async t=>(2!=N&&(V(1),k++,await nt((async()=>{await o((async()=>{const e=await l();n(e)?W(e):t?G(t):r("Content is not an array: "+e)}),(()=>{t&&G(t)})),V(0)}))),st),Y=async t=>(Z(),await X(t),await o((async()=>I=await d((async(t,e)=>{e||t?2!=N&&(V(1),k++,W(e??t),V(0)):await X()}))),p),st),Z=async()=>(I&&(await o((()=>h(I)),p),I=void 0),st),_=async t=>(1!=N&&(V(2),F++,await nt((async()=>{await o((()=>u($,t)),p),V(0)}))),st),tt=async()=>(et(),await _(),J=t.addDidFinishTransactionListener((()=>{const t=q();B(t)&&_(t)})),st),et=async()=>(J&&(t.delListener(J),J=void 0),st),at=async(t=!1)=>{const[e,a]=t?[et,Z]:[Z,et];return await e(),await a(),st},nt=async(...t)=>(c(A(P,x),...t),await(async()=>{if(!A(O,x)){for(b(O,x,1);!e(z=y(A(P,x)));)await o(z,p);b(O,x,0)}})(),st),st={load:X,startAutoLoad:Y,stopAutoLoad:Z,isAutoLoading:()=>!e(I),save:_,startAutoSave:tt,stopAutoSave:et,isAutoSaving:()=>!e(J),startAutoPersisting:async(t,e=!1)=>{const[a,n]=e?[tt,Y]:[Y,tt];return await a(t),await n(t),st},stopAutoPersisting:at,getStatus:()=>N,addStatusListener:t=>K(t,H),delListener:e=>(R(e),t),schedule:nt,getStore:()=>t,destroy:()=>(A(P,x).splice(0,void 0),at()),getStats:()=>({loads:k,saves:F}),...D};return g(st)},D=t=>t.headers.get("ETag"),j=(a,n,s,r=5,o)=>{let i;return m(a,(async()=>{const t=await fetch(n);return i=D(t),p(await t.text())}),(async t=>{return await fetch(s,{method:"POST",headers:{"Content-Type":"application/json"},body:(e=t(),h(e,((t,e)=>e instanceof Map?l.fromEntries([...e]):e)))});var e}),(t=>setInterval((async()=>{const a=await fetch(n,{method:"HEAD"}),s=D(a);e(i)||e(s)||s==i||(i=s,t())}),1e3*r)),(e=>t(e)),o,1,{getUrls:()=>[n,s]})};export{j as createRemotePersister};
1
+ const t=clearInterval,e=t=>null==t,a=(t,a,n)=>e(t)?n?.():a(t),n=t=>Array.isArray(t),s=t=>t.length,r=t=>{throw Error(t)},o=async(t,e,a)=>{try{return await t()}catch(t){e?.(t)}},i=(t,e)=>t.forEach(e),c=(t,...e)=>t.push(...e),y=t=>t.shift(),l=Object,u=t=>l.getPrototypeOf(t),d=l.keys,g=l.freeze,w=t=>(t=>!e(t)&&a(u(t),t=>t==l.prototype||e(u(t)),()=>!0))(t)&&0==(t=>s(d(t)))(t),h=JSON.stringify,p=JSON.parse,f=t=>e(t)||0==(t=>t?.size??0)(t),v=(t,e)=>t?.forEach(e),C=(t,e)=>t?.delete(e),S=t=>new Map(t),A=(t,e)=>t?.get(e),b=(t,a,n)=>e(n)?(C(t,a),t):t?.set(a,n),L=(t,e,a,n)=>{var s,r;return s=t,r=e,s?.has(r)?n?.(A(t,e)):b(t,e,a()),A(t,e)},M=(t,e,n,r,o=0)=>a((n?L:A)(t,e[o],o>s(e)-2?n:S),a=>{if(o>s(e)-2)return r?.(a)&&b(t,e[o]),a;const i=M(a,e,n,r,o+1);return f(a)&&b(t,e[o]),i}),E=/^\d+$/,T=t=>new Set(n(t)||e(t)?t:[t]),O=S(),P=S(),m=(t,l,u,d,h,p,m,D={},j=0,x=[])=>{let z,I,J,N=0,k=0,F=0;L(O,x,()=>0),L(P,x,()=>[]);const H=S(),[U,$,q,B,G]=((t=1,e,a)=>1!=t&&e.isMergeable()?[1,e.getMergeableContent,()=>e.getTransactionMergeableChanges(!a),([[t],[e]])=>!w(t)||!w(e),e.setDefaultContent]:2!=t?[0,e.getContent,e.getTransactionChanges,([t,e])=>!w(t)||!w(e),e.setContent]:r("Store type not supported by this Persister"))(m,t,j),[K,Q,R]=(()=>{let t;const[n,r]=(()=>{const t=[];let e=0;return[a=>(a?y(t):null)??""+e++,e=>{E.test(e)&&s(t)<1e3&&c(t,e)}]})(),o=S();return[(e,a,s,r=[],i=()=>[])=>{t??=st;const c=n(1);var y,l;return b(o,c,[e,a,s,r,i]),y=M(a,s??[""],T),l=c,y?.add(l),c},(e,a,...n)=>i(((t,e=[""])=>{const a=[],n=(t,r)=>r==s(e)?c(a,t):null===e[r]?v(t,t=>n(t,r+1)):i([e[r],null],e=>n(A(t,e),r+1));return n(t,0),a})(e,a),e=>v(e,e=>A(o,e)[0](t,...a??[],...n))),t=>a(A(o,t),([,e,a])=>(M(e,a??[""],void 0,e=>(C(e,t),f(e)?1:0)),b(o,t),r(t),a)),n=>a(A(o,n),([a,,n=[],r,o])=>{const c=(...y)=>{const l=s(y);l==s(n)?a(t,...y,...o(y)):e(n[l])?i(r[l]?.(...y)??[],t=>c(...y,t)):c(...y,n[l])};c()})]})(),V=t=>{t!=N&&(N=t,Q(H,void 0,N))},W=e=>{(U&&n(e?.[0])?1===e?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===e?.[2]?t.applyChanges:t.setContent)(e)},X=async t=>(2!=N&&(V(1),k++,await nt(async()=>{await o(async()=>{const e=await l();n(e)?W(e):t?G(t):r("Content is not an array: "+e)},()=>{t&&G(t)}),V(0)})),st),Y=async t=>(Z(),await X(t),await o(async()=>I=await d(async(t,e)=>{e||t?2!=N&&(V(1),k++,W(e??t),V(0)):await X()}),p),st),Z=async()=>(I&&(await o(()=>h(I),p),I=void 0),st),_=async t=>(1!=N&&(V(2),F++,await nt(async()=>{await o(()=>u($,t),p),V(0)})),st),tt=async()=>(et(),await _(),J=t.addDidFinishTransactionListener(()=>{const t=q();B(t)&&_(t)}),st),et=async()=>(J&&(t.delListener(J),J=void 0),st),at=async(t=!1)=>{const[e,a]=t?[et,Z]:[Z,et];return await e(),await a(),st},nt=async(...t)=>(c(A(P,x),...t),await(async()=>{if(!A(O,x)){for(b(O,x,1);!e(z=y(A(P,x)));)await o(z,p);b(O,x,0)}})(),st),st={load:X,startAutoLoad:Y,stopAutoLoad:Z,isAutoLoading:()=>!e(I),save:_,startAutoSave:tt,stopAutoSave:et,isAutoSaving:()=>!e(J),startAutoPersisting:async(t,e=!1)=>{const[a,n]=e?[tt,Y]:[Y,tt];return await a(t),await n(t),st},stopAutoPersisting:at,getStatus:()=>N,addStatusListener:t=>K(t,H),delListener:e=>(R(e),t),schedule:nt,getStore:()=>t,destroy:()=>(A(P,x).splice(0,void 0),at()),getStats:()=>({loads:k,saves:F}),...D};return g(st)},D=t=>t.headers.get("ETag"),j=(a,n,s,r=5,o)=>{let i;return m(a,async()=>{const t=await fetch(n);return i=D(t),p(await t.text())},async t=>{return await fetch(s,{method:"POST",headers:{"Content-Type":"application/json"},body:(e=t(),h(e,(t,e)=>e instanceof Map?l.fromEntries([...e]):e))});var e},t=>setInterval(async()=>{const a=await fetch(n,{method:"HEAD"}),s=D(a);e(i)||e(s)||s==i||(i=s,t())},1e3*r),e=>t(e),o,1,{getUrls:()=>[n,s]})};export{j as createRemotePersister};
@@ -1 +1 @@
1
- const t=clearInterval,e=t=>null==t,a=(t,a,n)=>e(t)?n?.():a(t),n=t=>Array.isArray(t),s=t=>t.length,r=t=>{throw Error(t)},o=async(t,e,a)=>{try{return await t()}catch(t){e?.(t)}},i=(t,e)=>t.forEach(e),c=(t,...e)=>t.push(...e),y=t=>t.shift(),l=Object,u=t=>l.getPrototypeOf(t),d=l.keys,g=l.freeze,w=t=>(t=>!e(t)&&a(u(t),(t=>t==l.prototype||e(u(t))),(()=>!0)))(t)&&0==(t=>s(d(t)))(t),h=JSON.stringify,p=JSON.parse,f=t=>e(t)||0==(t=>t?.size??0)(t),v=(t,e)=>t?.forEach(e),C=(t,e)=>t?.delete(e),S=t=>new Map(t),A=(t,e)=>t?.get(e),b=(t,a,n)=>e(n)?(C(t,a),t):t?.set(a,n),L=(t,e,a,n)=>{var s,r;return s=t,r=e,s?.has(r)?n?.(A(t,e)):b(t,e,a()),A(t,e)},M=(t,e,n,r,o=0)=>a((n?L:A)(t,e[o],o>s(e)-2?n:S),(a=>{if(o>s(e)-2)return r?.(a)&&b(t,e[o]),a;const i=M(a,e,n,r,o+1);return f(a)&&b(t,e[o]),i})),E=/^\d+$/,T=t=>new Set(n(t)||e(t)?t:[t]),O=S(),P=S(),m=(t,l,u,d,h,p,m,D={},j=0,x=[])=>{let z,I,J,N=0,k=0,F=0;L(O,x,(()=>0)),L(P,x,(()=>[]));const H=S(),[U,$,q,B,G]=((t=1,e,a)=>1!=t&&e.isMergeable()?[1,e.getMergeableContent,()=>e.getTransactionMergeableChanges(!a),([[t],[e]])=>!w(t)||!w(e),e.setDefaultContent]:2!=t?[0,e.getContent,e.getTransactionChanges,([t,e])=>!w(t)||!w(e),e.setContent]:r("Store type not supported by this Persister"))(m,t,j),[K,Q,R]=(()=>{let t;const[n,r]=(()=>{const t=[];let e=0;return[a=>(a?y(t):null)??""+e++,e=>{E.test(e)&&s(t)<1e3&&c(t,e)}]})(),o=S();return[(e,a,s,r=[],i=()=>[])=>{t??=st;const c=n(1);var y,l;return b(o,c,[e,a,s,r,i]),y=M(a,s??[""],T),l=c,y?.add(l),c},(e,a,...n)=>i(((t,e=[""])=>{const a=[],n=(t,r)=>r==s(e)?c(a,t):null===e[r]?v(t,(t=>n(t,r+1))):i([e[r],null],(e=>n(A(t,e),r+1)));return n(t,0),a})(e,a),(e=>v(e,(e=>A(o,e)[0](t,...a??[],...n))))),t=>a(A(o,t),(([,e,a])=>(M(e,a??[""],void 0,(e=>(C(e,t),f(e)?1:0))),b(o,t),r(t),a))),n=>a(A(o,n),(([a,,n=[],r,o])=>{const c=(...y)=>{const l=s(y);l==s(n)?a(t,...y,...o(y)):e(n[l])?i(r[l]?.(...y)??[],(t=>c(...y,t))):c(...y,n[l])};c()}))]})(),V=t=>{t!=N&&(N=t,Q(H,void 0,N))},W=e=>{(U&&n(e?.[0])?1===e?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===e?.[2]?t.applyChanges:t.setContent)(e)},X=async t=>(2!=N&&(V(1),k++,await nt((async()=>{await o((async()=>{const e=await l();n(e)?W(e):t?G(t):r("Content is not an array: "+e)}),(()=>{t&&G(t)})),V(0)}))),st),Y=async t=>(Z(),await X(t),await o((async()=>I=await d((async(t,e)=>{e||t?2!=N&&(V(1),k++,W(e??t),V(0)):await X()}))),p),st),Z=async()=>(I&&(await o((()=>h(I)),p),I=void 0),st),_=async t=>(1!=N&&(V(2),F++,await nt((async()=>{await o((()=>u($,t)),p),V(0)}))),st),tt=async()=>(et(),await _(),J=t.addDidFinishTransactionListener((()=>{const t=q();B(t)&&_(t)})),st),et=async()=>(J&&(t.delListener(J),J=void 0),st),at=async(t=!1)=>{const[e,a]=t?[et,Z]:[Z,et];return await e(),await a(),st},nt=async(...t)=>(c(A(P,x),...t),await(async()=>{if(!A(O,x)){for(b(O,x,1);!e(z=y(A(P,x)));)await o(z,p);b(O,x,0)}})(),st),st={load:X,startAutoLoad:Y,stopAutoLoad:Z,isAutoLoading:()=>!e(I),save:_,startAutoSave:tt,stopAutoSave:et,isAutoSaving:()=>!e(J),startAutoPersisting:async(t,e=!1)=>{const[a,n]=e?[tt,Y]:[Y,tt];return await a(t),await n(t),st},stopAutoPersisting:at,getStatus:()=>N,addStatusListener:t=>K(t,H),delListener:e=>(R(e),t),schedule:nt,getStore:()=>t,destroy:()=>(A(P,x).splice(0,void 0),at()),getStats:()=>({loads:k,saves:F}),...D};return g(st)},D=t=>t.headers.get("ETag"),j=(a,n,s,r=5,o)=>{let i;return m(a,(async()=>{const t=await fetch(n);return i=D(t),p(await t.text())}),(async t=>{return await fetch(s,{method:"POST",headers:{"Content-Type":"application/json"},body:(e=t(),h(e,((t,e)=>e instanceof Map?l.fromEntries([...e]):e)))});var e}),(t=>setInterval((async()=>{const a=await fetch(n,{method:"HEAD"}),s=D(a);e(i)||e(s)||s==i||(i=s,t())}),1e3*r)),(e=>t(e)),o,1,{getUrls:()=>[n,s]})};export{j as createRemotePersister};
1
+ const t=clearInterval,e=t=>null==t,a=(t,a,n)=>e(t)?n?.():a(t),n=t=>Array.isArray(t),s=t=>t.length,r=t=>{throw Error(t)},o=async(t,e,a)=>{try{return await t()}catch(t){e?.(t)}},i=(t,e)=>t.forEach(e),c=(t,...e)=>t.push(...e),y=t=>t.shift(),l=Object,u=t=>l.getPrototypeOf(t),d=l.keys,g=l.freeze,w=t=>(t=>!e(t)&&a(u(t),t=>t==l.prototype||e(u(t)),()=>!0))(t)&&0==(t=>s(d(t)))(t),h=JSON.stringify,p=JSON.parse,f=t=>e(t)||0==(t=>t?.size??0)(t),v=(t,e)=>t?.forEach(e),C=(t,e)=>t?.delete(e),S=t=>new Map(t),A=(t,e)=>t?.get(e),b=(t,a,n)=>e(n)?(C(t,a),t):t?.set(a,n),L=(t,e,a,n)=>{var s,r;return s=t,r=e,s?.has(r)?n?.(A(t,e)):b(t,e,a()),A(t,e)},M=(t,e,n,r,o=0)=>a((n?L:A)(t,e[o],o>s(e)-2?n:S),a=>{if(o>s(e)-2)return r?.(a)&&b(t,e[o]),a;const i=M(a,e,n,r,o+1);return f(a)&&b(t,e[o]),i}),E=/^\d+$/,T=t=>new Set(n(t)||e(t)?t:[t]),O=S(),P=S(),m=(t,l,u,d,h,p,m,D={},j=0,x=[])=>{let z,I,J,N=0,k=0,F=0;L(O,x,()=>0),L(P,x,()=>[]);const H=S(),[U,$,q,B,G]=((t=1,e,a)=>1!=t&&e.isMergeable()?[1,e.getMergeableContent,()=>e.getTransactionMergeableChanges(!a),([[t],[e]])=>!w(t)||!w(e),e.setDefaultContent]:2!=t?[0,e.getContent,e.getTransactionChanges,([t,e])=>!w(t)||!w(e),e.setContent]:r("Store type not supported by this Persister"))(m,t,j),[K,Q,R]=(()=>{let t;const[n,r]=(()=>{const t=[];let e=0;return[a=>(a?y(t):null)??""+e++,e=>{E.test(e)&&s(t)<1e3&&c(t,e)}]})(),o=S();return[(e,a,s,r=[],i=()=>[])=>{t??=st;const c=n(1);var y,l;return b(o,c,[e,a,s,r,i]),y=M(a,s??[""],T),l=c,y?.add(l),c},(e,a,...n)=>i(((t,e=[""])=>{const a=[],n=(t,r)=>r==s(e)?c(a,t):null===e[r]?v(t,t=>n(t,r+1)):i([e[r],null],e=>n(A(t,e),r+1));return n(t,0),a})(e,a),e=>v(e,e=>A(o,e)[0](t,...a??[],...n))),t=>a(A(o,t),([,e,a])=>(M(e,a??[""],void 0,e=>(C(e,t),f(e)?1:0)),b(o,t),r(t),a)),n=>a(A(o,n),([a,,n=[],r,o])=>{const c=(...y)=>{const l=s(y);l==s(n)?a(t,...y,...o(y)):e(n[l])?i(r[l]?.(...y)??[],t=>c(...y,t)):c(...y,n[l])};c()})]})(),V=t=>{t!=N&&(N=t,Q(H,void 0,N))},W=e=>{(U&&n(e?.[0])?1===e?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===e?.[2]?t.applyChanges:t.setContent)(e)},X=async t=>(2!=N&&(V(1),k++,await nt(async()=>{await o(async()=>{const e=await l();n(e)?W(e):t?G(t):r("Content is not an array: "+e)},()=>{t&&G(t)}),V(0)})),st),Y=async t=>(Z(),await X(t),await o(async()=>I=await d(async(t,e)=>{e||t?2!=N&&(V(1),k++,W(e??t),V(0)):await X()}),p),st),Z=async()=>(I&&(await o(()=>h(I),p),I=void 0),st),_=async t=>(1!=N&&(V(2),F++,await nt(async()=>{await o(()=>u($,t),p),V(0)})),st),tt=async()=>(et(),await _(),J=t.addDidFinishTransactionListener(()=>{const t=q();B(t)&&_(t)}),st),et=async()=>(J&&(t.delListener(J),J=void 0),st),at=async(t=!1)=>{const[e,a]=t?[et,Z]:[Z,et];return await e(),await a(),st},nt=async(...t)=>(c(A(P,x),...t),await(async()=>{if(!A(O,x)){for(b(O,x,1);!e(z=y(A(P,x)));)await o(z,p);b(O,x,0)}})(),st),st={load:X,startAutoLoad:Y,stopAutoLoad:Z,isAutoLoading:()=>!e(I),save:_,startAutoSave:tt,stopAutoSave:et,isAutoSaving:()=>!e(J),startAutoPersisting:async(t,e=!1)=>{const[a,n]=e?[tt,Y]:[Y,tt];return await a(t),await n(t),st},stopAutoPersisting:at,getStatus:()=>N,addStatusListener:t=>K(t,H),delListener:e=>(R(e),t),schedule:nt,getStore:()=>t,destroy:()=>(A(P,x).splice(0,void 0),at()),getStats:()=>({loads:k,saves:F}),...D};return g(st)},D=t=>t.headers.get("ETag"),j=(a,n,s,r=5,o)=>{let i;return m(a,async()=>{const t=await fetch(n);return i=D(t),p(await t.text())},async t=>{return await fetch(s,{method:"POST",headers:{"Content-Type":"application/json"},body:(e=t(),h(e,(t,e)=>e instanceof Map?l.fromEntries([...e]):e))});var e},t=>setInterval(async()=>{const a=await fetch(n,{method:"HEAD"}),s=D(a);e(i)||e(s)||s==i||(i=s,t())},1e3*r),e=>t(e),o,1,{getUrls:()=>[n,s]})};export{j as createRemotePersister};
@@ -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=clearInterval,l=a=>null==a,w=(a,t,e)=>l(a)?e?.():t(a),y=t=>a(t)==s,u=a=>Array.isArray(a),d=(a,t,e)=>a.slice(t,e),g=a=>a.length,p=()=>{},v=async a=>o.all(a),E=a=>{throw Error(a)},A=async(a,t,e)=>{try{return await a()}catch(a){t?.(a)}},N=(a,t)=>a.forEach(t),m=(a,t="")=>a.join(t),$=(a,t)=>a.map(t),f=a=>0==g(a),C=(a,t)=>a.filter(t),T=(a,...t)=>a.push(...t),h=a=>a.shift(),O=(a,t)=>a?.has(t)??!1,b=a=>l(a)||0==(a=>a?.size??0)(a),D=a=>[...a?.values()??[]],I=(a,t)=>a?.forEach(t),S=(a,t)=>a?.delete(t),L="_",R="_id",P="SELECT",M="WHERE",_="TABLE",F="ALTER "+_,U="FROM",j="DELETE "+U,B=P+"*"+U,J="pragma_",Y="data_version",k="schema_version",x="pragma_table_",z="CREATE "+_,G=a=>m($(((a,t="",e)=>a.split(t,e))(a,"."),(a=>`"${r(a,/"/g,'""')}"`)),"."),H=(a,t=[1])=>m($(a,(()=>"$"+t[0]++)),n),q=(a,t=i)=>M+`(${r(t,"$tableName",G(a))})`,K=Object,Q=a=>K.getPrototypeOf(a),V=K.entries,W=K.keys,X=K.freeze,Z=(a=[])=>K.fromEntries(a),aa=(...a)=>K.assign({},...a),ta=(a,t)=>(delete a[t],a),ea=(a,t)=>$(V(a),(([a,e])=>t(e,a))),na=(a,t)=>Z(ea(a,((a,e)=>[e,t(a,e)]))),sa=a=>K.values(a),ia=a=>g(W(a)),ra=a=>(a=>!l(a)&&w(Q(a),(a=>a==K.prototype||l(Q(a))),(()=>!0)))(a)&&0==ia(a),oa=a=>new Map(a),ca=(a,t)=>a?.get(t),la=(a,t)=>$([...a?.entries()??[]],(([a,e])=>t(e,a))),wa=(a,t,e)=>l(e)?(S(a,t),a):a?.set(t,e),ya=(a,t,e,n)=>(O(a,t)?n?.(ca(a,t)):wa(a,t,e()),ca(a,t)),ua=(a,t,e,n,s=0)=>w((e?ya:ca)(a,t[s],s>g(t)-2?e:oa),(i=>{if(s>g(t)-2)return n?.(i)&&wa(a,t[s]),i;const r=ua(i,t,e,n,s+1);return b(i)&&wa(a,t[s]),r})),da=a=>new Set(u(a)||l(a)?a:[a]),ga=(a,t)=>a?.add(t),pa="ColumnName",va="store",Ea="json",Aa=va+"TableName",Na=va+"Id"+pa,ma=va+pa,$a="autoLoadIntervalSeconds",fa="rowId"+pa,Ca="tableId",Ta="tableName",ha="deleteEmptyColumns",Oa="deleteEmptyTable",ba="condition",Da={mode:Ea,[$a]:1},Ia={load:0,save:0,[Ta]:t+"_values"},Sa=(a,t,e,n,s)=>{const i=oa();return na(a,((a,r)=>{const o=d(sa(aa(t,y(a)?{[e]:a}:a)),0,ia(t));l(o[0])||n(r,o[0])||(s(r,o[0]),wa(i,r,o))})),i},La=JSON.stringify,Ra=JSON.parse,Pa=/^\d+$/,Ma=oa(),_a=oa(),Fa=(a,t,n,s,i,r,o,c={},y=0,d=[])=>{let p,v,m,$=0,f=0,C=0;ya(Ma,d,(()=>0)),ya(_a,d,(()=>[]));const O=oa(),[D,L,R,P,M]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!ra(a)||!ra(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!ra(a)||!ra(t),t.setContent]:E("Store type not supported by this Persister"))(o,a,y),[_,F,U]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?h(a):null)??e+t++,t=>{Pa.test(t)&&g(a)<1e3&&T(a,t)}]})(),s=oa();return[(n,i,r,o=[],c=()=>[])=>{a??=K;const l=t(1);return wa(s,l,[n,i,r,o,c]),ga(ua(i,r??[e],da),l),l},(t,n,...i)=>N(((a,t=[e])=>{const n=[],s=(a,e)=>e==g(t)?T(n,a):null===t[e]?I(a,(a=>s(a,e+1))):N([t[e],null],(t=>s(ca(a,t),e+1)));return s(a,0),n})(t,n),(t=>I(t,(t=>ca(s,t)[0](a,...n??[],...i))))),a=>w(ca(s,a),(([,t,i])=>(ua(t,i??[e],void 0,(t=>(S(t,a),b(t)?1:0))),wa(s,a),n(a),i))),t=>w(ca(s,t),(([t,,e=[],n,s])=>{const i=(...r)=>{const o=g(r);o==g(e)?t(a,...r,...s(r)):l(e[o])?N(n[o]?.(...r)??[],(a=>i(...r,a))):i(...r,e[o])};i()}))]})(),j=a=>{a!=$&&($=a,F(O,void 0,$))},B=t=>{(D&&u(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},J=async a=>(2!=$&&(j(1),f++,await q((async()=>{await A((async()=>{const e=await t();u(e)?B(e):a?M(a):E("Content is not an array: "+e)}),(()=>{a&&M(a)})),j(0)}))),K),Y=async a=>(k(),await J(a),await A((async()=>v=await s((async(a,t)=>{t||a?2!=$&&(j(1),f++,B(t??a),j(0)):await J()}))),r),K),k=async()=>(v&&(await A((()=>i(v)),r),v=void 0),K),x=async a=>(1!=$&&(j(2),C++,await q((async()=>{await A((()=>n(L,a)),r),j(0)}))),K),z=async()=>(G(),await x(),m=a.addDidFinishTransactionListener((()=>{const a=R();P(a)&&x(a)})),K),G=async()=>(m&&(a.delListener(m),m=void 0),K),H=async(a=!1)=>{const[t,e]=a?[G,k]:[k,G];return await t(),await e(),K},q=async(...a)=>(T(ca(_a,d),...a),await(async()=>{if(!ca(Ma,d)){for(wa(Ma,d,1);!l(p=h(ca(_a,d)));)await A(p,r);wa(Ma,d,0)}})(),K),K={load:J,startAutoLoad:Y,stopAutoLoad:k,isAutoLoading:()=>!l(v),save:x,startAutoSave:z,stopAutoSave:G,isAutoSaving:()=>!l(m),startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[z,Y]:[Y,z];return await e(a),await n(a),K},stopAutoPersisting:H,getStatus:()=>$,addStatusListener:a=>_(a,O),delListener:t=>(U(t),a),schedule:q,getStore:()=>a,destroy:()=>(ca(_a,d).splice(0,void 0),H()),getStats:()=>({loads:f,saves:C}),...c};return X(K)},Ua=(a,t,e,s,r,o=ja,c,w)=>{const y=oa();return[async()=>{y.clear(),$(await e(a,t),(({tn:a,cn:t})=>ga(ya(y,a,da),t)))},async(t,e,n)=>((a,t)=>O(ca(y,a),t))(t,e)?Z(C($(await a(B+G(t)+q(t,n)),(a=>[a[e],w?na(ta(a,e),w):ta(a,e)])),(([a,t])=>!l(a)&&!ra(t)))):{},async(t,e,s,w,u,d=!1,g=i)=>{const p=da();na(s??{},(a=>$(W(a??{}),(a=>ga(p,a)))));const E=D(p);if(!d&&u&&g==i&&f(E)&&O(y,t))return await a("DROP "+_+G(t)),void wa(y,t);const A=ca(y,t),N=da(D(A));if(f(E)||(O(y,t)?await v($([e,...E],(async(n,s)=>{S(N,n)||(await a(F+G(t)+"ADD"+G(n)+r),0==s&&await a("CREATE UNIQUE INDEX pk ON "+G(t)+`(${G(e)})`),ga(A,n))}))):(await a(z+G(t)+`(${G(e)}${r} PRIMARY KEY${m($(E,(a=>n+G(a)+r)))});`),wa(y,t,da([e,...E])))),await v([...!d&&w?$(D(N),(async n=>{n!=e&&(await a(F+G(t)+"DROP"+G(n)),S(A,n))})):[]]),d)l(s)?await a(j+G(t)+q(t,g)):await v(ea(s,(async(n,s)=>{l(n)?await a(j+G(t)+q(t,g)+`AND(${G(e)}=$1)`,[s]):f(E)||await o(a,t,e,W(n),{[s]:c?$(sa(n),c):sa(n)},A)})));else if(f(E))O(y,t)&&await a(j+G(t)+q(t,g));else{const n=C(D(ca(y,t)),(a=>a!=e)),i={},r=[];na(s??{},((a,t)=>{i[t]=$(n,(t=>c?c(a?.[t]):a?.[t])),T(r,t)})),await o(a,t,e,n,i),await a(j+G(t)+q(t,g)+`AND${G(e)}NOT IN(${H(r)})`,r)}},async t=>{let e;return await a("BEGIN"),await A((async()=>e=await t()),s),await a("END"),e}]},ja=async(a,t,e,s,i)=>{const r=[1];await a("INSERT INTO"+G(t)+"("+((...a)=>m($(a,G),n))(e,...s)+")VALUES"+m(ea(i,(a=>"($"+r[0]+++","+H(a,r)+")")),n)+"ON CONFLICT("+G(e)+")DO UPDATE SET"+m($(s,(a=>G(a)+"=excluded."+G(a))),n),ea(i,((a,t)=>[t,...$(a,(a=>a??null))])).flat())},Ba=(a,t,e,n,s,i,r,[o,c,l],w,y,u,d,g,p)=>{const[v,E,A,N]=Ua(t,w,y,s,g,p),m=Fa(a,(()=>N((async()=>{return await v(),a=(await E(o,c))[L]?.[l]??"null",Ra(a,((a,t)=>""===t?void 0:t));var a}))),(a=>N((async()=>{var t;await v(),await A(o,c,{[L]:{[l]:(t=a()??null,La(t,((a,t)=>void 0===t?"":t)))}},!0,!0)}))),e,n,s,r,{[d]:()=>u,destroy:async()=>(await m.stopAutoPersisting(),i(),m)},0,u);return m},Ja=(a,t,e,n,s,i,r,[o,c,[w,y,u]],d,g,p,E,A,N,m,$)=>{const[f,T,h,O]=Ua(t,d,g,s,A,N,m,$),b=(a,t)=>v(la(c,(async([e,n,s,i,r],o)=>{t&&!(o in a)||await h(e,n,a[o],s,i,t,r)}))),D=async(a,t)=>y?await h(u,R,{[L]:a},!0,!0,t):null,I=Fa(a,(()=>O((async()=>{await f();const a=await(async()=>Z(C(await v(la(o,(async([a,t,e],n)=>[a,await T(n,t,e)]))),(a=>!ra(a[1])))))(),t=await(async()=>w?(await T(u,R))[L]:{})();return ra(a)&&l(t)?void 0:[a,t]}))),((a,t)=>O((async()=>{if(await f(),l(t)){const[t,e]=a();await b(t),await D(e)}else await b(t[0],!0),await D(t[1],!0)}))),e,n,s,r,{[E]:()=>p,destroy:async()=>(await I.stopAutoPersisting(),i(),I)},0,p);return I},Ya=(a,n,s,r,o,l,w,u,g,p,v="getDb",E)=>{let N,m,$;const f=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,l),[C,T,h,b]=(a=>{const e=(a=>aa(Da,y(a)?{[Aa]:a}:a??{}))(a),n=e[$a];if(e.mode==Ea){const a=e[Aa]??t;return[1,n,[a,e[Na]??R,e[ma]??va],da(a)]}const{tables:{load:s={},save:r={}}={},values:o={}}=e,c=d(sa(aa(Ia,o)),0,ia(Ia)),l=c[2],w=da(l),u=da(l),g=Sa(s,{[Ca]:null,[fa]:R,[ba]:i},Ca,(a=>O(u,a)),(a=>ga(w,a))),p=Sa(r,{[Ta]:null,[fa]:R,[ha]:0,[Oa]:0,[ba]:null},Ta,((a,t)=>O(u,t)),((a,t)=>ga(w,t)));var v;return v=(a,t)=>t[4]??=ca(g,t[0])?.[2]??i,I(p,((a,t)=>v(0,a))),[0,n,[g,p,c],w]})(n);return(C?Ba:Ja)(a,f,(a=>{let t;const e=()=>t=setInterval((()=>A((async()=>{const[{d:t,s:e,c:n}]=await f(P+` ${Y} d,${k} s,TOTAL_CHANGES() c FROM ${J}${Y} JOIN ${J}${k}`);t==N&&e==m&&n==$||(null!=N&&a(),N=t,m=e,$=n)}))),1e3*T),n=()=>{N=m=$=null,c(t)},s=r((t=>{b.has(t)&&(n(),a(),e())}));return e(),()=>{n(),o(s)}}),(a=>a()),w,u,g,h,D(b),(async(a,t)=>await a(P+` t.name tn,c.name cn FROM ${x}list()t,${x}info(t.name)c ${M} t.schema='main'AND t.type IN('table','view')AND t.name IN(${H(t)})ORDER BY t.name,c.name`,t)),p,v,e,E,(a=>!0===a?1:!1===a?0:a),void 0)},ka=(a,t,e,n,s)=>Ya(a,e,(async(a,e=[])=>t.query(a).all(...e)),(()=>p),(a=>a()),n,s,p,3,t);export{ka 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=clearInterval,l=a=>null==a,w=(a,t,e)=>l(a)?e?.():t(a),y=t=>a(t)==s,u=a=>Array.isArray(a),d=(a,t,e)=>a.slice(t,e),g=a=>a.length,p=()=>{},v=async a=>o.all(a),E=a=>{throw Error(a)},A=async(a,t,e)=>{try{return await a()}catch(a){t?.(a)}},N=(a,t)=>a.forEach(t),m=(a,t="")=>a.join(t),$=(a,t)=>a.map(t),f=a=>0==g(a),C=(a,t)=>a.filter(t),T=(a,...t)=>a.push(...t),h=a=>a.shift(),O=(a,t)=>a?.has(t)??!1,b=a=>l(a)||0==(a=>a?.size??0)(a),D=a=>[...a?.values()??[]],I=(a,t)=>a?.forEach(t),S=(a,t)=>a?.delete(t),L="_",R="_id",P="SELECT",M="WHERE",_="TABLE",F="ALTER "+_,U="FROM",j="DELETE "+U,B=P+"*"+U,J="pragma_",Y="data_version",k="schema_version",x="pragma_table_",z="CREATE "+_,G=a=>m($(((a,t="",e)=>a.split(t,e))(a,"."),a=>`"${r(a,/"/g,'""')}"`),"."),H=(a,t=[1])=>m($(a,()=>"$"+t[0]++),n),q=(a,t=i)=>M+`(${r(t,"$tableName",G(a))})`,K=Object,Q=a=>K.getPrototypeOf(a),V=K.entries,W=K.keys,X=K.freeze,Z=(a=[])=>K.fromEntries(a),aa=(...a)=>K.assign({},...a),ta=(a,t)=>(delete a[t],a),ea=(a,t)=>$(V(a),([a,e])=>t(e,a)),na=(a,t)=>Z(ea(a,(a,e)=>[e,t(a,e)])),sa=a=>K.values(a),ia=a=>g(W(a)),ra=a=>(a=>!l(a)&&w(Q(a),a=>a==K.prototype||l(Q(a)),()=>!0))(a)&&0==ia(a),oa=a=>new Map(a),ca=(a,t)=>a?.get(t),la=(a,t)=>$([...a?.entries()??[]],([a,e])=>t(e,a)),wa=(a,t,e)=>l(e)?(S(a,t),a):a?.set(t,e),ya=(a,t,e,n)=>(O(a,t)?n?.(ca(a,t)):wa(a,t,e()),ca(a,t)),ua=(a,t,e,n,s=0)=>w((e?ya:ca)(a,t[s],s>g(t)-2?e:oa),i=>{if(s>g(t)-2)return n?.(i)&&wa(a,t[s]),i;const r=ua(i,t,e,n,s+1);return b(i)&&wa(a,t[s]),r}),da=a=>new Set(u(a)||l(a)?a:[a]),ga=(a,t)=>a?.add(t),pa="ColumnName",va="store",Ea="json",Aa=va+"TableName",Na=va+"Id"+pa,ma=va+pa,$a="autoLoadIntervalSeconds",fa="rowId"+pa,Ca="tableId",Ta="tableName",ha="deleteEmptyColumns",Oa="deleteEmptyTable",ba="condition",Da={mode:Ea,[$a]:1},Ia={load:0,save:0,[Ta]:t+"_values"},Sa=(a,t,e,n,s)=>{const i=oa();return na(a,(a,r)=>{const o=d(sa(aa(t,y(a)?{[e]:a}:a)),0,ia(t));l(o[0])||n(r,o[0])||(s(r,o[0]),wa(i,r,o))}),i},La=JSON.stringify,Ra=JSON.parse,Pa=/^\d+$/,Ma=oa(),_a=oa(),Fa=(a,t,n,s,i,r,o,c={},y=0,d=[])=>{let p,v,m,$=0,f=0,C=0;ya(Ma,d,()=>0),ya(_a,d,()=>[]);const O=oa(),[D,L,R,P,M]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!ra(a)||!ra(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!ra(a)||!ra(t),t.setContent]:E("Store type not supported by this Persister"))(o,a,y),[_,F,U]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?h(a):null)??e+t++,t=>{Pa.test(t)&&g(a)<1e3&&T(a,t)}]})(),s=oa();return[(n,i,r,o=[],c=()=>[])=>{a??=K;const l=t(1);return wa(s,l,[n,i,r,o,c]),ga(ua(i,r??[e],da),l),l},(t,n,...i)=>N(((a,t=[e])=>{const n=[],s=(a,e)=>e==g(t)?T(n,a):null===t[e]?I(a,a=>s(a,e+1)):N([t[e],null],t=>s(ca(a,t),e+1));return s(a,0),n})(t,n),t=>I(t,t=>ca(s,t)[0](a,...n??[],...i))),a=>w(ca(s,a),([,t,i])=>(ua(t,i??[e],void 0,t=>(S(t,a),b(t)?1:0)),wa(s,a),n(a),i)),t=>w(ca(s,t),([t,,e=[],n,s])=>{const i=(...r)=>{const o=g(r);o==g(e)?t(a,...r,...s(r)):l(e[o])?N(n[o]?.(...r)??[],a=>i(...r,a)):i(...r,e[o])};i()})]})(),j=a=>{a!=$&&($=a,F(O,void 0,$))},B=t=>{(D&&u(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},J=async a=>(2!=$&&(j(1),f++,await q(async()=>{await A(async()=>{const e=await t();u(e)?B(e):a?M(a):E("Content is not an array: "+e)},()=>{a&&M(a)}),j(0)})),K),Y=async a=>(k(),await J(a),await A(async()=>v=await s(async(a,t)=>{t||a?2!=$&&(j(1),f++,B(t??a),j(0)):await J()}),r),K),k=async()=>(v&&(await A(()=>i(v),r),v=void 0),K),x=async a=>(1!=$&&(j(2),C++,await q(async()=>{await A(()=>n(L,a),r),j(0)})),K),z=async()=>(G(),await x(),m=a.addDidFinishTransactionListener(()=>{const a=R();P(a)&&x(a)}),K),G=async()=>(m&&(a.delListener(m),m=void 0),K),H=async(a=!1)=>{const[t,e]=a?[G,k]:[k,G];return await t(),await e(),K},q=async(...a)=>(T(ca(_a,d),...a),await(async()=>{if(!ca(Ma,d)){for(wa(Ma,d,1);!l(p=h(ca(_a,d)));)await A(p,r);wa(Ma,d,0)}})(),K),K={load:J,startAutoLoad:Y,stopAutoLoad:k,isAutoLoading:()=>!l(v),save:x,startAutoSave:z,stopAutoSave:G,isAutoSaving:()=>!l(m),startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[z,Y]:[Y,z];return await e(a),await n(a),K},stopAutoPersisting:H,getStatus:()=>$,addStatusListener:a=>_(a,O),delListener:t=>(U(t),a),schedule:q,getStore:()=>a,destroy:()=>(ca(_a,d).splice(0,void 0),H()),getStats:()=>({loads:f,saves:C}),...c};return X(K)},Ua=(a,t,e,s,r,o=ja,c,w)=>{const y=oa();return[async()=>{y.clear(),$(await e(a,t),({tn:a,cn:t})=>ga(ya(y,a,da),t))},async(t,e,n)=>((a,t)=>O(ca(y,a),t))(t,e)?Z(C($(await a(B+G(t)+q(t,n)),a=>[a[e],w?na(ta(a,e),w):ta(a,e)]),([a,t])=>!l(a)&&!ra(t))):{},async(t,e,s,w,u,d=!1,g=i)=>{const p=da();na(s??{},a=>$(W(a??{}),a=>ga(p,a)));const E=D(p);if(!d&&u&&g==i&&f(E)&&O(y,t))return await a("DROP "+_+G(t)),void wa(y,t);const A=ca(y,t),N=da(D(A));if(f(E)||(O(y,t)?await v($([e,...E],async(n,s)=>{S(N,n)||(await a(F+G(t)+"ADD"+G(n)+r),0==s&&await a("CREATE UNIQUE INDEX pk ON "+G(t)+`(${G(e)})`),ga(A,n))})):(await a(z+G(t)+`(${G(e)}${r} PRIMARY KEY${m($(E,a=>n+G(a)+r))});`),wa(y,t,da([e,...E])))),await v([...!d&&w?$(D(N),async n=>{n!=e&&(await a(F+G(t)+"DROP"+G(n)),S(A,n))}):[]]),d)l(s)?await a(j+G(t)+q(t,g)):await v(ea(s,async(n,s)=>{l(n)?await a(j+G(t)+q(t,g)+`AND(${G(e)}=$1)`,[s]):f(E)||await o(a,t,e,W(n),{[s]:c?$(sa(n),c):sa(n)},A)}));else if(f(E))O(y,t)&&await a(j+G(t)+q(t,g));else{const n=C(D(ca(y,t)),a=>a!=e),i={},r=[];na(s??{},(a,t)=>{i[t]=$(n,t=>c?c(a?.[t]):a?.[t]),T(r,t)}),await o(a,t,e,n,i),await a(j+G(t)+q(t,g)+`AND${G(e)}NOT IN(${H(r)})`,r)}},async t=>{let e;return await a("BEGIN"),await A(async()=>e=await t(),s),await a("END"),e}]},ja=async(a,t,e,s,i)=>{const r=[1];await a("INSERT INTO"+G(t)+"("+((...a)=>m($(a,G),n))(e,...s)+")VALUES"+m(ea(i,a=>"($"+r[0]+++","+H(a,r)+")"),n)+"ON CONFLICT("+G(e)+")DO UPDATE SET"+m($(s,a=>G(a)+"=excluded."+G(a)),n),ea(i,(a,t)=>[t,...$(a,a=>a??null)]).flat())},Ba=(a,t,e,n,s,i,r,[o,c,l],w,y,u,d,g,p)=>{const[v,E,A,N]=Ua(t,w,y,s,g,p),m=Fa(a,()=>N(async()=>{return await v(),a=(await E(o,c))[L]?.[l]??"null",Ra(a,(a,t)=>""===t?void 0:t);var a}),a=>N(async()=>{var t;await v(),await A(o,c,{[L]:{[l]:(t=a()??null,La(t,(a,t)=>void 0===t?"":t))}},!0,!0)}),e,n,s,r,{[d]:()=>u,destroy:async()=>(await m.stopAutoPersisting(),i(),m)},0,u);return m},Ja=(a,t,e,n,s,i,r,[o,c,[w,y,u]],d,g,p,E,A,N,m,$)=>{const[f,T,h,O]=Ua(t,d,g,s,A,N,m,$),b=(a,t)=>v(la(c,async([e,n,s,i,r],o)=>{t&&!(o in a)||await h(e,n,a[o],s,i,t,r)})),D=async(a,t)=>y?await h(u,R,{[L]:a},!0,!0,t):null,I=Fa(a,()=>O(async()=>{await f();const a=await(async()=>Z(C(await v(la(o,async([a,t,e],n)=>[a,await T(n,t,e)])),a=>!ra(a[1]))))(),t=await(async()=>w?(await T(u,R))[L]:{})();return ra(a)&&l(t)?void 0:[a,t]}),(a,t)=>O(async()=>{if(await f(),l(t)){const[t,e]=a();await b(t),await D(e)}else await b(t[0],!0),await D(t[1],!0)}),e,n,s,r,{[E]:()=>p,destroy:async()=>(await I.stopAutoPersisting(),i(),I)},0,p);return I},Ya=(a,n,s,r,o,l,w,u,g,p,v="getDb",E)=>{let N,m,$;const f=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,l),[C,T,h,b]=(a=>{const e=(a=>aa(Da,y(a)?{[Aa]:a}:a??{}))(a),n=e[$a];if(e.mode==Ea){const a=e[Aa]??t;return[1,n,[a,e[Na]??R,e[ma]??va],da(a)]}const{tables:{load:s={},save:r={}}={},values:o={}}=e,c=d(sa(aa(Ia,o)),0,ia(Ia)),l=c[2],w=da(l),u=da(l),g=Sa(s,{[Ca]:null,[fa]:R,[ba]:i},Ca,a=>O(u,a),a=>ga(w,a)),p=Sa(r,{[Ta]:null,[fa]:R,[ha]:0,[Oa]:0,[ba]:null},Ta,(a,t)=>O(u,t),(a,t)=>ga(w,t));var v;return v=(a,t)=>t[4]??=ca(g,t[0])?.[2]??i,I(p,(a,t)=>v(0,a)),[0,n,[g,p,c],w]})(n);return(C?Ba:Ja)(a,f,a=>{let t;const e=()=>t=setInterval(()=>A(async()=>{const[{d:t,s:e,c:n}]=await f(P+` ${Y} d,${k} s,TOTAL_CHANGES() c FROM ${J}${Y} JOIN ${J}${k}`);t==N&&e==m&&n==$||(null!=N&&a(),N=t,m=e,$=n)}),1e3*T),n=()=>{N=m=$=null,c(t)},s=r(t=>{b.has(t)&&(n(),a(),e())});return e(),()=>{n(),o(s)}},a=>a(),w,u,g,h,D(b),async(a,t)=>await a(P+` t.name tn,c.name cn FROM ${x}list()t,${x}info(t.name)c ${M} t.schema='main'AND t.type IN('table','view')AND t.name IN(${H(t)})ORDER BY t.name,c.name`,t),p,v,e,E,a=>!0===a?1:!1===a?0:a,void 0)},ka=(a,t,e,n,s)=>Ya(a,e,async(a,e=[])=>t.query(a).all(...e),()=>p,a=>a(),n,s,p,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=clearInterval,l=a=>null==a,w=(a,t,e)=>l(a)?e?.():t(a),y=t=>a(t)==s,u=a=>Array.isArray(a),d=(a,t,e)=>a.slice(t,e),g=a=>a.length,p=()=>{},v=async a=>o.all(a),E=a=>{throw Error(a)},A=async(a,t,e)=>{try{return await a()}catch(a){t?.(a)}},N=(a,t)=>a.forEach(t),m=(a,t="")=>a.join(t),$=(a,t)=>a.map(t),f=a=>0==g(a),C=(a,t)=>a.filter(t),T=(a,...t)=>a.push(...t),h=a=>a.shift(),O=(a,t)=>a?.has(t)??!1,b=a=>l(a)||0==(a=>a?.size??0)(a),D=a=>[...a?.values()??[]],I=(a,t)=>a?.forEach(t),S=(a,t)=>a?.delete(t),L="_",R="_id",P="SELECT",M="WHERE",_="TABLE",F="ALTER "+_,U="FROM",j="DELETE "+U,B=P+"*"+U,J="pragma_",Y="data_version",k="schema_version",x="pragma_table_",z="CREATE "+_,G=a=>m($(((a,t="",e)=>a.split(t,e))(a,"."),(a=>`"${r(a,/"/g,'""')}"`)),"."),H=(a,t=[1])=>m($(a,(()=>"$"+t[0]++)),n),q=(a,t=i)=>M+`(${r(t,"$tableName",G(a))})`,K=Object,Q=a=>K.getPrototypeOf(a),V=K.entries,W=K.keys,X=K.freeze,Z=(a=[])=>K.fromEntries(a),aa=(...a)=>K.assign({},...a),ta=(a,t)=>(delete a[t],a),ea=(a,t)=>$(V(a),(([a,e])=>t(e,a))),na=(a,t)=>Z(ea(a,((a,e)=>[e,t(a,e)]))),sa=a=>K.values(a),ia=a=>g(W(a)),ra=a=>(a=>!l(a)&&w(Q(a),(a=>a==K.prototype||l(Q(a))),(()=>!0)))(a)&&0==ia(a),oa=a=>new Map(a),ca=(a,t)=>a?.get(t),la=(a,t)=>$([...a?.entries()??[]],(([a,e])=>t(e,a))),wa=(a,t,e)=>l(e)?(S(a,t),a):a?.set(t,e),ya=(a,t,e,n)=>(O(a,t)?n?.(ca(a,t)):wa(a,t,e()),ca(a,t)),ua=(a,t,e,n,s=0)=>w((e?ya:ca)(a,t[s],s>g(t)-2?e:oa),(i=>{if(s>g(t)-2)return n?.(i)&&wa(a,t[s]),i;const r=ua(i,t,e,n,s+1);return b(i)&&wa(a,t[s]),r})),da=a=>new Set(u(a)||l(a)?a:[a]),ga=(a,t)=>a?.add(t),pa="ColumnName",va="store",Ea="json",Aa=va+"TableName",Na=va+"Id"+pa,ma=va+pa,$a="autoLoadIntervalSeconds",fa="rowId"+pa,Ca="tableId",Ta="tableName",ha="deleteEmptyColumns",Oa="deleteEmptyTable",ba="condition",Da={mode:Ea,[$a]:1},Ia={load:0,save:0,[Ta]:t+"_values"},Sa=(a,t,e,n,s)=>{const i=oa();return na(a,((a,r)=>{const o=d(sa(aa(t,y(a)?{[e]:a}:a)),0,ia(t));l(o[0])||n(r,o[0])||(s(r,o[0]),wa(i,r,o))})),i},La=JSON.stringify,Ra=JSON.parse,Pa=/^\d+$/,Ma=oa(),_a=oa(),Fa=(a,t,n,s,i,r,o,c={},y=0,d=[])=>{let p,v,m,$=0,f=0,C=0;ya(Ma,d,(()=>0)),ya(_a,d,(()=>[]));const O=oa(),[D,L,R,P,M]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!ra(a)||!ra(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!ra(a)||!ra(t),t.setContent]:E("Store type not supported by this Persister"))(o,a,y),[_,F,U]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?h(a):null)??e+t++,t=>{Pa.test(t)&&g(a)<1e3&&T(a,t)}]})(),s=oa();return[(n,i,r,o=[],c=()=>[])=>{a??=K;const l=t(1);return wa(s,l,[n,i,r,o,c]),ga(ua(i,r??[e],da),l),l},(t,n,...i)=>N(((a,t=[e])=>{const n=[],s=(a,e)=>e==g(t)?T(n,a):null===t[e]?I(a,(a=>s(a,e+1))):N([t[e],null],(t=>s(ca(a,t),e+1)));return s(a,0),n})(t,n),(t=>I(t,(t=>ca(s,t)[0](a,...n??[],...i))))),a=>w(ca(s,a),(([,t,i])=>(ua(t,i??[e],void 0,(t=>(S(t,a),b(t)?1:0))),wa(s,a),n(a),i))),t=>w(ca(s,t),(([t,,e=[],n,s])=>{const i=(...r)=>{const o=g(r);o==g(e)?t(a,...r,...s(r)):l(e[o])?N(n[o]?.(...r)??[],(a=>i(...r,a))):i(...r,e[o])};i()}))]})(),j=a=>{a!=$&&($=a,F(O,void 0,$))},B=t=>{(D&&u(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},J=async a=>(2!=$&&(j(1),f++,await q((async()=>{await A((async()=>{const e=await t();u(e)?B(e):a?M(a):E("Content is not an array: "+e)}),(()=>{a&&M(a)})),j(0)}))),K),Y=async a=>(k(),await J(a),await A((async()=>v=await s((async(a,t)=>{t||a?2!=$&&(j(1),f++,B(t??a),j(0)):await J()}))),r),K),k=async()=>(v&&(await A((()=>i(v)),r),v=void 0),K),x=async a=>(1!=$&&(j(2),C++,await q((async()=>{await A((()=>n(L,a)),r),j(0)}))),K),z=async()=>(G(),await x(),m=a.addDidFinishTransactionListener((()=>{const a=R();P(a)&&x(a)})),K),G=async()=>(m&&(a.delListener(m),m=void 0),K),H=async(a=!1)=>{const[t,e]=a?[G,k]:[k,G];return await t(),await e(),K},q=async(...a)=>(T(ca(_a,d),...a),await(async()=>{if(!ca(Ma,d)){for(wa(Ma,d,1);!l(p=h(ca(_a,d)));)await A(p,r);wa(Ma,d,0)}})(),K),K={load:J,startAutoLoad:Y,stopAutoLoad:k,isAutoLoading:()=>!l(v),save:x,startAutoSave:z,stopAutoSave:G,isAutoSaving:()=>!l(m),startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[z,Y]:[Y,z];return await e(a),await n(a),K},stopAutoPersisting:H,getStatus:()=>$,addStatusListener:a=>_(a,O),delListener:t=>(U(t),a),schedule:q,getStore:()=>a,destroy:()=>(ca(_a,d).splice(0,void 0),H()),getStats:()=>({loads:f,saves:C}),...c};return X(K)},Ua=(a,t,e,s,r,o=ja,c,w)=>{const y=oa();return[async()=>{y.clear(),$(await e(a,t),(({tn:a,cn:t})=>ga(ya(y,a,da),t)))},async(t,e,n)=>((a,t)=>O(ca(y,a),t))(t,e)?Z(C($(await a(B+G(t)+q(t,n)),(a=>[a[e],w?na(ta(a,e),w):ta(a,e)])),(([a,t])=>!l(a)&&!ra(t)))):{},async(t,e,s,w,u,d=!1,g=i)=>{const p=da();na(s??{},(a=>$(W(a??{}),(a=>ga(p,a)))));const E=D(p);if(!d&&u&&g==i&&f(E)&&O(y,t))return await a("DROP "+_+G(t)),void wa(y,t);const A=ca(y,t),N=da(D(A));if(f(E)||(O(y,t)?await v($([e,...E],(async(n,s)=>{S(N,n)||(await a(F+G(t)+"ADD"+G(n)+r),0==s&&await a("CREATE UNIQUE INDEX pk ON "+G(t)+`(${G(e)})`),ga(A,n))}))):(await a(z+G(t)+`(${G(e)}${r} PRIMARY KEY${m($(E,(a=>n+G(a)+r)))});`),wa(y,t,da([e,...E])))),await v([...!d&&w?$(D(N),(async n=>{n!=e&&(await a(F+G(t)+"DROP"+G(n)),S(A,n))})):[]]),d)l(s)?await a(j+G(t)+q(t,g)):await v(ea(s,(async(n,s)=>{l(n)?await a(j+G(t)+q(t,g)+`AND(${G(e)}=$1)`,[s]):f(E)||await o(a,t,e,W(n),{[s]:c?$(sa(n),c):sa(n)},A)})));else if(f(E))O(y,t)&&await a(j+G(t)+q(t,g));else{const n=C(D(ca(y,t)),(a=>a!=e)),i={},r=[];na(s??{},((a,t)=>{i[t]=$(n,(t=>c?c(a?.[t]):a?.[t])),T(r,t)})),await o(a,t,e,n,i),await a(j+G(t)+q(t,g)+`AND${G(e)}NOT IN(${H(r)})`,r)}},async t=>{let e;return await a("BEGIN"),await A((async()=>e=await t()),s),await a("END"),e}]},ja=async(a,t,e,s,i)=>{const r=[1];await a("INSERT INTO"+G(t)+"("+((...a)=>m($(a,G),n))(e,...s)+")VALUES"+m(ea(i,(a=>"($"+r[0]+++","+H(a,r)+")")),n)+"ON CONFLICT("+G(e)+")DO UPDATE SET"+m($(s,(a=>G(a)+"=excluded."+G(a))),n),ea(i,((a,t)=>[t,...$(a,(a=>a??null))])).flat())},Ba=(a,t,e,n,s,i,r,[o,c,l],w,y,u,d,g,p)=>{const[v,E,A,N]=Ua(t,w,y,s,g,p),m=Fa(a,(()=>N((async()=>{return await v(),a=(await E(o,c))[L]?.[l]??"null",Ra(a,((a,t)=>""===t?void 0:t));var a}))),(a=>N((async()=>{var t;await v(),await A(o,c,{[L]:{[l]:(t=a()??null,La(t,((a,t)=>void 0===t?"":t)))}},!0,!0)}))),e,n,s,r,{[d]:()=>u,destroy:async()=>(await m.stopAutoPersisting(),i(),m)},0,u);return m},Ja=(a,t,e,n,s,i,r,[o,c,[w,y,u]],d,g,p,E,A,N,m,$)=>{const[f,T,h,O]=Ua(t,d,g,s,A,N,m,$),b=(a,t)=>v(la(c,(async([e,n,s,i,r],o)=>{t&&!(o in a)||await h(e,n,a[o],s,i,t,r)}))),D=async(a,t)=>y?await h(u,R,{[L]:a},!0,!0,t):null,I=Fa(a,(()=>O((async()=>{await f();const a=await(async()=>Z(C(await v(la(o,(async([a,t,e],n)=>[a,await T(n,t,e)]))),(a=>!ra(a[1])))))(),t=await(async()=>w?(await T(u,R))[L]:{})();return ra(a)&&l(t)?void 0:[a,t]}))),((a,t)=>O((async()=>{if(await f(),l(t)){const[t,e]=a();await b(t),await D(e)}else await b(t[0],!0),await D(t[1],!0)}))),e,n,s,r,{[E]:()=>p,destroy:async()=>(await I.stopAutoPersisting(),i(),I)},0,p);return I},Ya=(a,n,s,r,o,l,w,u,g,p,v="getDb",E)=>{let N,m,$;const f=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,l),[C,T,h,b]=(a=>{const e=(a=>aa(Da,y(a)?{[Aa]:a}:a??{}))(a),n=e[$a];if(e.mode==Ea){const a=e[Aa]??t;return[1,n,[a,e[Na]??R,e[ma]??va],da(a)]}const{tables:{load:s={},save:r={}}={},values:o={}}=e,c=d(sa(aa(Ia,o)),0,ia(Ia)),l=c[2],w=da(l),u=da(l),g=Sa(s,{[Ca]:null,[fa]:R,[ba]:i},Ca,(a=>O(u,a)),(a=>ga(w,a))),p=Sa(r,{[Ta]:null,[fa]:R,[ha]:0,[Oa]:0,[ba]:null},Ta,((a,t)=>O(u,t)),((a,t)=>ga(w,t)));var v;return v=(a,t)=>t[4]??=ca(g,t[0])?.[2]??i,I(p,((a,t)=>v(0,a))),[0,n,[g,p,c],w]})(n);return(C?Ba:Ja)(a,f,(a=>{let t;const e=()=>t=setInterval((()=>A((async()=>{const[{d:t,s:e,c:n}]=await f(P+` ${Y} d,${k} s,TOTAL_CHANGES() c FROM ${J}${Y} JOIN ${J}${k}`);t==N&&e==m&&n==$||(null!=N&&a(),N=t,m=e,$=n)}))),1e3*T),n=()=>{N=m=$=null,c(t)},s=r((t=>{b.has(t)&&(n(),a(),e())}));return e(),()=>{n(),o(s)}}),(a=>a()),w,u,g,h,D(b),(async(a,t)=>await a(P+` t.name tn,c.name cn FROM ${x}list()t,${x}info(t.name)c ${M} t.schema='main'AND t.type IN('table','view')AND t.name IN(${H(t)})ORDER BY t.name,c.name`,t)),p,v,e,E,(a=>!0===a?1:!1===a?0:a),void 0)},ka=(a,t,e,n,s)=>Ya(a,e,(async(a,e=[])=>t.query(a).all(...e)),(()=>p),(a=>a()),n,s,p,3,t);export{ka 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=clearInterval,l=a=>null==a,w=(a,t,e)=>l(a)?e?.():t(a),y=t=>a(t)==s,u=a=>Array.isArray(a),d=(a,t,e)=>a.slice(t,e),g=a=>a.length,p=()=>{},v=async a=>o.all(a),E=a=>{throw Error(a)},A=async(a,t,e)=>{try{return await a()}catch(a){t?.(a)}},N=(a,t)=>a.forEach(t),m=(a,t="")=>a.join(t),$=(a,t)=>a.map(t),f=a=>0==g(a),C=(a,t)=>a.filter(t),T=(a,...t)=>a.push(...t),h=a=>a.shift(),O=(a,t)=>a?.has(t)??!1,b=a=>l(a)||0==(a=>a?.size??0)(a),D=a=>[...a?.values()??[]],I=(a,t)=>a?.forEach(t),S=(a,t)=>a?.delete(t),L="_",R="_id",P="SELECT",M="WHERE",_="TABLE",F="ALTER "+_,U="FROM",j="DELETE "+U,B=P+"*"+U,J="pragma_",Y="data_version",k="schema_version",x="pragma_table_",z="CREATE "+_,G=a=>m($(((a,t="",e)=>a.split(t,e))(a,"."),a=>`"${r(a,/"/g,'""')}"`),"."),H=(a,t=[1])=>m($(a,()=>"$"+t[0]++),n),q=(a,t=i)=>M+`(${r(t,"$tableName",G(a))})`,K=Object,Q=a=>K.getPrototypeOf(a),V=K.entries,W=K.keys,X=K.freeze,Z=(a=[])=>K.fromEntries(a),aa=(...a)=>K.assign({},...a),ta=(a,t)=>(delete a[t],a),ea=(a,t)=>$(V(a),([a,e])=>t(e,a)),na=(a,t)=>Z(ea(a,(a,e)=>[e,t(a,e)])),sa=a=>K.values(a),ia=a=>g(W(a)),ra=a=>(a=>!l(a)&&w(Q(a),a=>a==K.prototype||l(Q(a)),()=>!0))(a)&&0==ia(a),oa=a=>new Map(a),ca=(a,t)=>a?.get(t),la=(a,t)=>$([...a?.entries()??[]],([a,e])=>t(e,a)),wa=(a,t,e)=>l(e)?(S(a,t),a):a?.set(t,e),ya=(a,t,e,n)=>(O(a,t)?n?.(ca(a,t)):wa(a,t,e()),ca(a,t)),ua=(a,t,e,n,s=0)=>w((e?ya:ca)(a,t[s],s>g(t)-2?e:oa),i=>{if(s>g(t)-2)return n?.(i)&&wa(a,t[s]),i;const r=ua(i,t,e,n,s+1);return b(i)&&wa(a,t[s]),r}),da=a=>new Set(u(a)||l(a)?a:[a]),ga=(a,t)=>a?.add(t),pa="ColumnName",va="store",Ea="json",Aa=va+"TableName",Na=va+"Id"+pa,ma=va+pa,$a="autoLoadIntervalSeconds",fa="rowId"+pa,Ca="tableId",Ta="tableName",ha="deleteEmptyColumns",Oa="deleteEmptyTable",ba="condition",Da={mode:Ea,[$a]:1},Ia={load:0,save:0,[Ta]:t+"_values"},Sa=(a,t,e,n,s)=>{const i=oa();return na(a,(a,r)=>{const o=d(sa(aa(t,y(a)?{[e]:a}:a)),0,ia(t));l(o[0])||n(r,o[0])||(s(r,o[0]),wa(i,r,o))}),i},La=JSON.stringify,Ra=JSON.parse,Pa=/^\d+$/,Ma=oa(),_a=oa(),Fa=(a,t,n,s,i,r,o,c={},y=0,d=[])=>{let p,v,m,$=0,f=0,C=0;ya(Ma,d,()=>0),ya(_a,d,()=>[]);const O=oa(),[D,L,R,P,M]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!ra(a)||!ra(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!ra(a)||!ra(t),t.setContent]:E("Store type not supported by this Persister"))(o,a,y),[_,F,U]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?h(a):null)??e+t++,t=>{Pa.test(t)&&g(a)<1e3&&T(a,t)}]})(),s=oa();return[(n,i,r,o=[],c=()=>[])=>{a??=K;const l=t(1);return wa(s,l,[n,i,r,o,c]),ga(ua(i,r??[e],da),l),l},(t,n,...i)=>N(((a,t=[e])=>{const n=[],s=(a,e)=>e==g(t)?T(n,a):null===t[e]?I(a,a=>s(a,e+1)):N([t[e],null],t=>s(ca(a,t),e+1));return s(a,0),n})(t,n),t=>I(t,t=>ca(s,t)[0](a,...n??[],...i))),a=>w(ca(s,a),([,t,i])=>(ua(t,i??[e],void 0,t=>(S(t,a),b(t)?1:0)),wa(s,a),n(a),i)),t=>w(ca(s,t),([t,,e=[],n,s])=>{const i=(...r)=>{const o=g(r);o==g(e)?t(a,...r,...s(r)):l(e[o])?N(n[o]?.(...r)??[],a=>i(...r,a)):i(...r,e[o])};i()})]})(),j=a=>{a!=$&&($=a,F(O,void 0,$))},B=t=>{(D&&u(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},J=async a=>(2!=$&&(j(1),f++,await q(async()=>{await A(async()=>{const e=await t();u(e)?B(e):a?M(a):E("Content is not an array: "+e)},()=>{a&&M(a)}),j(0)})),K),Y=async a=>(k(),await J(a),await A(async()=>v=await s(async(a,t)=>{t||a?2!=$&&(j(1),f++,B(t??a),j(0)):await J()}),r),K),k=async()=>(v&&(await A(()=>i(v),r),v=void 0),K),x=async a=>(1!=$&&(j(2),C++,await q(async()=>{await A(()=>n(L,a),r),j(0)})),K),z=async()=>(G(),await x(),m=a.addDidFinishTransactionListener(()=>{const a=R();P(a)&&x(a)}),K),G=async()=>(m&&(a.delListener(m),m=void 0),K),H=async(a=!1)=>{const[t,e]=a?[G,k]:[k,G];return await t(),await e(),K},q=async(...a)=>(T(ca(_a,d),...a),await(async()=>{if(!ca(Ma,d)){for(wa(Ma,d,1);!l(p=h(ca(_a,d)));)await A(p,r);wa(Ma,d,0)}})(),K),K={load:J,startAutoLoad:Y,stopAutoLoad:k,isAutoLoading:()=>!l(v),save:x,startAutoSave:z,stopAutoSave:G,isAutoSaving:()=>!l(m),startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[z,Y]:[Y,z];return await e(a),await n(a),K},stopAutoPersisting:H,getStatus:()=>$,addStatusListener:a=>_(a,O),delListener:t=>(U(t),a),schedule:q,getStore:()=>a,destroy:()=>(ca(_a,d).splice(0,void 0),H()),getStats:()=>({loads:f,saves:C}),...c};return X(K)},Ua=(a,t,e,s,r,o=ja,c,w)=>{const y=oa();return[async()=>{y.clear(),$(await e(a,t),({tn:a,cn:t})=>ga(ya(y,a,da),t))},async(t,e,n)=>((a,t)=>O(ca(y,a),t))(t,e)?Z(C($(await a(B+G(t)+q(t,n)),a=>[a[e],w?na(ta(a,e),w):ta(a,e)]),([a,t])=>!l(a)&&!ra(t))):{},async(t,e,s,w,u,d=!1,g=i)=>{const p=da();na(s??{},a=>$(W(a??{}),a=>ga(p,a)));const E=D(p);if(!d&&u&&g==i&&f(E)&&O(y,t))return await a("DROP "+_+G(t)),void wa(y,t);const A=ca(y,t),N=da(D(A));if(f(E)||(O(y,t)?await v($([e,...E],async(n,s)=>{S(N,n)||(await a(F+G(t)+"ADD"+G(n)+r),0==s&&await a("CREATE UNIQUE INDEX pk ON "+G(t)+`(${G(e)})`),ga(A,n))})):(await a(z+G(t)+`(${G(e)}${r} PRIMARY KEY${m($(E,a=>n+G(a)+r))});`),wa(y,t,da([e,...E])))),await v([...!d&&w?$(D(N),async n=>{n!=e&&(await a(F+G(t)+"DROP"+G(n)),S(A,n))}):[]]),d)l(s)?await a(j+G(t)+q(t,g)):await v(ea(s,async(n,s)=>{l(n)?await a(j+G(t)+q(t,g)+`AND(${G(e)}=$1)`,[s]):f(E)||await o(a,t,e,W(n),{[s]:c?$(sa(n),c):sa(n)},A)}));else if(f(E))O(y,t)&&await a(j+G(t)+q(t,g));else{const n=C(D(ca(y,t)),a=>a!=e),i={},r=[];na(s??{},(a,t)=>{i[t]=$(n,t=>c?c(a?.[t]):a?.[t]),T(r,t)}),await o(a,t,e,n,i),await a(j+G(t)+q(t,g)+`AND${G(e)}NOT IN(${H(r)})`,r)}},async t=>{let e;return await a("BEGIN"),await A(async()=>e=await t(),s),await a("END"),e}]},ja=async(a,t,e,s,i)=>{const r=[1];await a("INSERT INTO"+G(t)+"("+((...a)=>m($(a,G),n))(e,...s)+")VALUES"+m(ea(i,a=>"($"+r[0]+++","+H(a,r)+")"),n)+"ON CONFLICT("+G(e)+")DO UPDATE SET"+m($(s,a=>G(a)+"=excluded."+G(a)),n),ea(i,(a,t)=>[t,...$(a,a=>a??null)]).flat())},Ba=(a,t,e,n,s,i,r,[o,c,l],w,y,u,d,g,p)=>{const[v,E,A,N]=Ua(t,w,y,s,g,p),m=Fa(a,()=>N(async()=>{return await v(),a=(await E(o,c))[L]?.[l]??"null",Ra(a,(a,t)=>""===t?void 0:t);var a}),a=>N(async()=>{var t;await v(),await A(o,c,{[L]:{[l]:(t=a()??null,La(t,(a,t)=>void 0===t?"":t))}},!0,!0)}),e,n,s,r,{[d]:()=>u,destroy:async()=>(await m.stopAutoPersisting(),i(),m)},0,u);return m},Ja=(a,t,e,n,s,i,r,[o,c,[w,y,u]],d,g,p,E,A,N,m,$)=>{const[f,T,h,O]=Ua(t,d,g,s,A,N,m,$),b=(a,t)=>v(la(c,async([e,n,s,i,r],o)=>{t&&!(o in a)||await h(e,n,a[o],s,i,t,r)})),D=async(a,t)=>y?await h(u,R,{[L]:a},!0,!0,t):null,I=Fa(a,()=>O(async()=>{await f();const a=await(async()=>Z(C(await v(la(o,async([a,t,e],n)=>[a,await T(n,t,e)])),a=>!ra(a[1]))))(),t=await(async()=>w?(await T(u,R))[L]:{})();return ra(a)&&l(t)?void 0:[a,t]}),(a,t)=>O(async()=>{if(await f(),l(t)){const[t,e]=a();await b(t),await D(e)}else await b(t[0],!0),await D(t[1],!0)}),e,n,s,r,{[E]:()=>p,destroy:async()=>(await I.stopAutoPersisting(),i(),I)},0,p);return I},Ya=(a,n,s,r,o,l,w,u,g,p,v="getDb",E)=>{let N,m,$;const f=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,l),[C,T,h,b]=(a=>{const e=(a=>aa(Da,y(a)?{[Aa]:a}:a??{}))(a),n=e[$a];if(e.mode==Ea){const a=e[Aa]??t;return[1,n,[a,e[Na]??R,e[ma]??va],da(a)]}const{tables:{load:s={},save:r={}}={},values:o={}}=e,c=d(sa(aa(Ia,o)),0,ia(Ia)),l=c[2],w=da(l),u=da(l),g=Sa(s,{[Ca]:null,[fa]:R,[ba]:i},Ca,a=>O(u,a),a=>ga(w,a)),p=Sa(r,{[Ta]:null,[fa]:R,[ha]:0,[Oa]:0,[ba]:null},Ta,(a,t)=>O(u,t),(a,t)=>ga(w,t));var v;return v=(a,t)=>t[4]??=ca(g,t[0])?.[2]??i,I(p,(a,t)=>v(0,a)),[0,n,[g,p,c],w]})(n);return(C?Ba:Ja)(a,f,a=>{let t;const e=()=>t=setInterval(()=>A(async()=>{const[{d:t,s:e,c:n}]=await f(P+` ${Y} d,${k} s,TOTAL_CHANGES() c FROM ${J}${Y} JOIN ${J}${k}`);t==N&&e==m&&n==$||(null!=N&&a(),N=t,m=e,$=n)}),1e3*T),n=()=>{N=m=$=null,c(t)},s=r(t=>{b.has(t)&&(n(),a(),e())});return e(),()=>{n(),o(s)}},a=>a(),w,u,g,h,D(b),async(a,t)=>await a(P+` t.name tn,c.name cn FROM ${x}list()t,${x}info(t.name)c ${M} t.schema='main'AND t.type IN('table','view')AND t.name IN(${H(t)})ORDER BY t.name,c.name`,t),p,v,e,E,a=>!0===a?1:!1===a?0:a,void 0)},ka=(a,t,e,n,s)=>Ya(a,e,async(a,e=[])=>t.query(a).all(...e),()=>p,a=>a(),n,s,p,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=clearInterval,l=a=>null==a,w=(a,t,e)=>l(a)?e?.():t(a),u=t=>a(t)==s,y=a=>Array.isArray(a),d=(a,t,e)=>a.slice(t,e),p=a=>a.length,g=()=>{},v=async a=>r.all(a),E=a=>{throw Error(a)},A=async(a,t,e)=>{try{return await a()}catch(a){t?.(a)}},m=(a,t)=>a.forEach(t),N=(a,t="")=>a.join(t),$=(a,t)=>a.map(t),f=a=>0==p(a),h=(a,t)=>a.filter(t),b=(a,...t)=>a.push(...t),C=a=>a.shift(),T=(a,t)=>a?.has(t)??!1,O=a=>l(a)||0==(a=>a?.size??0)(a),D=a=>[...a?.values()??[]],I=(a,t)=>a?.forEach(t),S=(a,t)=>a?.delete(t),L="_",R="_id",_="SELECT",M="WHERE",P="TABLE",F="ALTER "+P,j="FROM",k="DELETE "+j,U=_+"*"+j,x="pragma_",B="data_version",J="schema_version",Y="pragma_table_",q="CREATE "+P,z=a=>N($(((a,t="",e)=>a.split(t,e))(a,"."),(a=>`"${o(a,/"/g,'""')}"`)),"."),G=(a,t=[1])=>N($(a,(()=>"$"+t[0]++)),n),H=(a,t=i)=>M+`(${o(t,"$tableName",z(a))})`,V=Object,K=a=>V.getPrototypeOf(a),Q=V.entries,W=V.keys,X=V.freeze,Z=(a=[])=>V.fromEntries(a),aa=(...a)=>V.assign({},...a),ta=(a,t)=>(delete a[t],a),ea=(a,t)=>$(Q(a),(([a,e])=>t(e,a))),na=(a,t)=>Z(ea(a,((a,e)=>[e,t(a,e)]))),sa=a=>V.values(a),ia=a=>p(W(a)),oa=a=>(a=>!l(a)&&w(K(a),(a=>a==V.prototype||l(K(a))),(()=>!0)))(a)&&0==ia(a),ra=a=>new Map(a),ca=(a,t)=>a?.get(t),la=(a,t)=>$([...a?.entries()??[]],(([a,e])=>t(e,a))),wa=(a,t,e)=>l(e)?(S(a,t),a):a?.set(t,e),ua=(a,t,e,n)=>(T(a,t)?n?.(ca(a,t)):wa(a,t,e()),ca(a,t)),ya=(a,t,e,n,s=0)=>w((e?ua:ca)(a,t[s],s>p(t)-2?e:ra),(i=>{if(s>p(t)-2)return n?.(i)&&wa(a,t[s]),i;const o=ya(i,t,e,n,s+1);return O(i)&&wa(a,t[s]),o})),da=a=>new Set(y(a)||l(a)?a:[a]),pa=(a,t)=>a?.add(t),ga="ColumnName",va="store",Ea="json",Aa=va+"TableName",ma=va+"Id"+ga,Na=va+ga,$a="autoLoadIntervalSeconds",fa="rowId"+ga,ha="tableId",ba="tableName",Ca="deleteEmptyColumns",Ta="deleteEmptyTable",Oa="condition",Da={mode:Ea,[$a]:1},Ia={load:0,save:0,[ba]:t+"_values"},Sa=(a,t,e,n,s)=>{const i=ra();return na(a,((a,o)=>{const r=d(sa(aa(t,u(a)?{[e]:a}:a)),0,ia(t));l(r[0])||n(o,r[0])||(s(o,r[0]),wa(i,o,r))})),i},La=JSON.stringify,Ra=JSON.parse,_a=/^\d+$/,Ma=ra(),Pa=ra(),Fa=(a,t,n,s,i,o,r,c={},u=0,d=[])=>{let g,v,N,$=0,f=0,h=0;ua(Ma,d,(()=>0)),ua(Pa,d,(()=>[]));const T=ra(),[D,L,R,_,M]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!oa(a)||!oa(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!oa(a)||!oa(t),t.setContent]:E("Store type not supported by this Persister"))(r,a,u),[P,F,j]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?C(a):null)??e+t++,t=>{_a.test(t)&&p(a)<1e3&&b(a,t)}]})(),s=ra();return[(n,i,o,r=[],c=()=>[])=>{a??=V;const l=t(1);return wa(s,l,[n,i,o,r,c]),pa(ya(i,o??[e],da),l),l},(t,n,...i)=>m(((a,t=[e])=>{const n=[],s=(a,e)=>e==p(t)?b(n,a):null===t[e]?I(a,(a=>s(a,e+1))):m([t[e],null],(t=>s(ca(a,t),e+1)));return s(a,0),n})(t,n),(t=>I(t,(t=>ca(s,t)[0](a,...n??[],...i))))),a=>w(ca(s,a),(([,t,i])=>(ya(t,i??[e],void 0,(t=>(S(t,a),O(t)?1:0))),wa(s,a),n(a),i))),t=>w(ca(s,t),(([t,,e=[],n,s])=>{const i=(...o)=>{const r=p(o);r==p(e)?t(a,...o,...s(o)):l(e[r])?m(n[r]?.(...o)??[],(a=>i(...o,a))):i(...o,e[r])};i()}))]})(),k=a=>{a!=$&&($=a,F(T,void 0,$))},U=t=>{(D&&y(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},x=async a=>(2!=$&&(k(1),f++,await H((async()=>{await A((async()=>{const e=await t();y(e)?U(e):a?M(a):E("Content is not an array: "+e)}),(()=>{a&&M(a)})),k(0)}))),V),B=async a=>(J(),await x(a),await A((async()=>v=await s((async(a,t)=>{t||a?2!=$&&(k(1),f++,U(t??a),k(0)):await x()}))),o),V),J=async()=>(v&&(await A((()=>i(v)),o),v=void 0),V),Y=async a=>(1!=$&&(k(2),h++,await H((async()=>{await A((()=>n(L,a)),o),k(0)}))),V),q=async()=>(z(),await Y(),N=a.addDidFinishTransactionListener((()=>{const a=R();_(a)&&Y(a)})),V),z=async()=>(N&&(a.delListener(N),N=void 0),V),G=async(a=!1)=>{const[t,e]=a?[z,J]:[J,z];return await t(),await e(),V},H=async(...a)=>(b(ca(Pa,d),...a),await(async()=>{if(!ca(Ma,d)){for(wa(Ma,d,1);!l(g=C(ca(Pa,d)));)await A(g,o);wa(Ma,d,0)}})(),V),V={load:x,startAutoLoad:B,stopAutoLoad:J,isAutoLoading:()=>!l(v),save:Y,startAutoSave:q,stopAutoSave:z,isAutoSaving:()=>!l(N),startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[q,B]:[B,q];return await e(a),await n(a),V},stopAutoPersisting:G,getStatus:()=>$,addStatusListener:a=>P(a,T),delListener:t=>(j(t),a),schedule:H,getStore:()=>a,destroy:()=>(ca(Pa,d).splice(0,void 0),G()),getStats:()=>({loads:f,saves:h}),...c};return X(V)},ja=(a,t,e,s,o,r=ka,c,w)=>{const u=ra();return[async()=>{u.clear(),$(await e(a,t),(({tn:a,cn:t})=>pa(ua(u,a,da),t)))},async(t,e,n)=>((a,t)=>T(ca(u,a),t))(t,e)?Z(h($(await a(U+z(t)+H(t,n)),(a=>[a[e],w?na(ta(a,e),w):ta(a,e)])),(([a,t])=>!l(a)&&!oa(t)))):{},async(t,e,s,w,y,d=!1,p=i)=>{const g=da();na(s??{},(a=>$(W(a??{}),(a=>pa(g,a)))));const E=D(g);if(!d&&y&&p==i&&f(E)&&T(u,t))return await a("DROP "+P+z(t)),void wa(u,t);const A=ca(u,t),m=da(D(A));if(f(E)||(T(u,t)?await v($([e,...E],(async(n,s)=>{S(m,n)||(await a(F+z(t)+"ADD"+z(n)+o),0==s&&await a("CREATE UNIQUE INDEX pk ON "+z(t)+`(${z(e)})`),pa(A,n))}))):(await a(q+z(t)+`(${z(e)}${o} PRIMARY KEY${N($(E,(a=>n+z(a)+o)))});`),wa(u,t,da([e,...E])))),await v([...!d&&w?$(D(m),(async n=>{n!=e&&(await a(F+z(t)+"DROP"+z(n)),S(A,n))})):[]]),d)l(s)?await a(k+z(t)+H(t,p)):await v(ea(s,(async(n,s)=>{l(n)?await a(k+z(t)+H(t,p)+`AND(${z(e)}=$1)`,[s]):f(E)||await r(a,t,e,W(n),{[s]:c?$(sa(n),c):sa(n)},A)})));else if(f(E))T(u,t)&&await a(k+z(t)+H(t,p));else{const n=h(D(ca(u,t)),(a=>a!=e)),i={},o=[];na(s??{},((a,t)=>{i[t]=$(n,(t=>c?c(a?.[t]):a?.[t])),b(o,t)})),await r(a,t,e,n,i),await a(k+z(t)+H(t,p)+`AND${z(e)}NOT IN(${G(o)})`,o)}},async t=>{let e;return await a("BEGIN"),await A((async()=>e=await t()),s),await a("END"),e}]},ka=async(a,t,e,s,i)=>{const o=[1];await a("INSERT INTO"+z(t)+"("+((...a)=>N($(a,z),n))(e,...s)+")VALUES"+N(ea(i,(a=>"($"+o[0]+++","+G(a,o)+")")),n)+"ON CONFLICT("+z(e)+")DO UPDATE SET"+N($(s,(a=>z(a)+"=excluded."+z(a))),n),ea(i,((a,t)=>[t,...$(a,(a=>a??null))])).flat())},Ua=(a,t,e,n,s,i,o,[r,c,l],w,u,y,d,p,g)=>{const[v,E,A,m]=ja(t,w,u,s,p,g),N=Fa(a,(()=>m((async()=>{return await v(),a=(await E(r,c))[L]?.[l]??"null",Ra(a,((a,t)=>""===t?void 0:t));var a}))),(a=>m((async()=>{var t;await v(),await A(r,c,{[L]:{[l]:(t=a()??null,La(t,((a,t)=>void 0===t?"":t)))}},!0,!0)}))),e,n,s,o,{[d]:()=>y,destroy:async()=>(await N.stopAutoPersisting(),i(),N)},0,y);return N},xa=(a,t,e,n,s,i,o,[r,c,[w,u,y]],d,p,g,E,A,m,N,$)=>{const[f,b,C,T]=ja(t,d,p,s,A,m,N,$),O=(a,t)=>v(la(c,(async([e,n,s,i,o],r)=>{t&&!(r in a)||await C(e,n,a[r],s,i,t,o)}))),D=async(a,t)=>u?await C(y,R,{[L]:a},!0,!0,t):null,I=Fa(a,(()=>T((async()=>{await f();const a=await(async()=>Z(h(await v(la(r,(async([a,t,e],n)=>[a,await b(n,t,e)]))),(a=>!oa(a[1])))))(),t=await(async()=>w?(await b(y,R))[L]:{})();return oa(a)&&l(t)?void 0:[a,t]}))),((a,t)=>T((async()=>{if(await f(),l(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,o,{[E]:()=>g,destroy:async()=>(await I.stopAutoPersisting(),i(),I)},0,g);return I},Ba=(a,n,s,o,r,l,w,y,p,g,v="getDb",E)=>{let m,N,$;const f=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,l),[h,b,C,O]=(a=>{const e=(a=>aa(Da,u(a)?{[Aa]:a}:a??{}))(a),n=e[$a];if(e.mode==Ea){const a=e[Aa]??t;return[1,n,[a,e[ma]??R,e[Na]??va],da(a)]}const{tables:{load:s={},save:o={}}={},values:r={}}=e,c=d(sa(aa(Ia,r)),0,ia(Ia)),l=c[2],w=da(l),y=da(l),p=Sa(s,{[ha]:null,[fa]:R,[Oa]:i},ha,(a=>T(y,a)),(a=>pa(w,a))),g=Sa(o,{[ba]:null,[fa]:R,[Ca]:0,[Ta]:0,[Oa]:null},ba,((a,t)=>T(y,t)),((a,t)=>pa(w,t)));var v;return v=(a,t)=>t[4]??=ca(p,t[0])?.[2]??i,I(g,((a,t)=>v(0,a))),[0,n,[p,g,c],w]})(n);return(h?Ua:xa)(a,f,(a=>{let t;const e=()=>t=setInterval((()=>A((async()=>{const[{d:t,s:e,c:n}]=await f(_+` ${B} d,${J} s,TOTAL_CHANGES() c FROM ${x}${B} JOIN ${x}${J}`);t==m&&e==N&&n==$||(null!=m&&a(),m=t,N=e,$=n)}))),1e3*b),n=()=>{m=N=$=null,c(t)},s=o((t=>{O.has(t)&&(n(),a(),e())}));return e(),()=>{n(),r(s)}}),(a=>a()),w,y,p,C,D(O),(async(a,t)=>await a(_+` t.name tn,c.name cn FROM ${Y}list()t,${Y}info(t.name)c ${M} t.schema='main'AND t.type IN('table','view')AND t.name IN(${G(t)})ORDER BY t.name,c.name`,t)),g,v,e,E,(a=>!0===a?1:!1===a?0:a),void 0)},Ja=(a,t,e,n,s,i)=>Ba(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,g,0)),s,i,g,3,e);export{Ja 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=clearInterval,l=a=>null==a,w=(a,t,e)=>l(a)?e?.():t(a),u=t=>a(t)==s,y=a=>Array.isArray(a),d=(a,t,e)=>a.slice(t,e),p=a=>a.length,g=()=>{},v=async a=>r.all(a),E=a=>{throw Error(a)},A=async(a,t,e)=>{try{return await a()}catch(a){t?.(a)}},m=(a,t)=>a.forEach(t),N=(a,t="")=>a.join(t),$=(a,t)=>a.map(t),f=a=>0==p(a),h=(a,t)=>a.filter(t),b=(a,...t)=>a.push(...t),C=a=>a.shift(),T=(a,t)=>a?.has(t)??!1,O=a=>l(a)||0==(a=>a?.size??0)(a),D=a=>[...a?.values()??[]],I=(a,t)=>a?.forEach(t),S=(a,t)=>a?.delete(t),L="_",R="_id",_="SELECT",M="WHERE",P="TABLE",F="ALTER "+P,j="FROM",k="DELETE "+j,U=_+"*"+j,x="pragma_",B="data_version",J="schema_version",Y="pragma_table_",q="CREATE "+P,z=a=>N($(((a,t="",e)=>a.split(t,e))(a,"."),a=>`"${o(a,/"/g,'""')}"`),"."),G=(a,t=[1])=>N($(a,()=>"$"+t[0]++),n),H=(a,t=i)=>M+`(${o(t,"$tableName",z(a))})`,V=Object,K=a=>V.getPrototypeOf(a),Q=V.entries,W=V.keys,X=V.freeze,Z=(a=[])=>V.fromEntries(a),aa=(...a)=>V.assign({},...a),ta=(a,t)=>(delete a[t],a),ea=(a,t)=>$(Q(a),([a,e])=>t(e,a)),na=(a,t)=>Z(ea(a,(a,e)=>[e,t(a,e)])),sa=a=>V.values(a),ia=a=>p(W(a)),oa=a=>(a=>!l(a)&&w(K(a),a=>a==V.prototype||l(K(a)),()=>!0))(a)&&0==ia(a),ra=a=>new Map(a),ca=(a,t)=>a?.get(t),la=(a,t)=>$([...a?.entries()??[]],([a,e])=>t(e,a)),wa=(a,t,e)=>l(e)?(S(a,t),a):a?.set(t,e),ua=(a,t,e,n)=>(T(a,t)?n?.(ca(a,t)):wa(a,t,e()),ca(a,t)),ya=(a,t,e,n,s=0)=>w((e?ua:ca)(a,t[s],s>p(t)-2?e:ra),i=>{if(s>p(t)-2)return n?.(i)&&wa(a,t[s]),i;const o=ya(i,t,e,n,s+1);return O(i)&&wa(a,t[s]),o}),da=a=>new Set(y(a)||l(a)?a:[a]),pa=(a,t)=>a?.add(t),ga="ColumnName",va="store",Ea="json",Aa=va+"TableName",ma=va+"Id"+ga,Na=va+ga,$a="autoLoadIntervalSeconds",fa="rowId"+ga,ha="tableId",ba="tableName",Ca="deleteEmptyColumns",Ta="deleteEmptyTable",Oa="condition",Da={mode:Ea,[$a]:1},Ia={load:0,save:0,[ba]:t+"_values"},Sa=(a,t,e,n,s)=>{const i=ra();return na(a,(a,o)=>{const r=d(sa(aa(t,u(a)?{[e]:a}:a)),0,ia(t));l(r[0])||n(o,r[0])||(s(o,r[0]),wa(i,o,r))}),i},La=JSON.stringify,Ra=JSON.parse,_a=/^\d+$/,Ma=ra(),Pa=ra(),Fa=(a,t,n,s,i,o,r,c={},u=0,d=[])=>{let g,v,N,$=0,f=0,h=0;ua(Ma,d,()=>0),ua(Pa,d,()=>[]);const T=ra(),[D,L,R,_,M]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!oa(a)||!oa(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!oa(a)||!oa(t),t.setContent]:E("Store type not supported by this Persister"))(r,a,u),[P,F,j]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?C(a):null)??e+t++,t=>{_a.test(t)&&p(a)<1e3&&b(a,t)}]})(),s=ra();return[(n,i,o,r=[],c=()=>[])=>{a??=V;const l=t(1);return wa(s,l,[n,i,o,r,c]),pa(ya(i,o??[e],da),l),l},(t,n,...i)=>m(((a,t=[e])=>{const n=[],s=(a,e)=>e==p(t)?b(n,a):null===t[e]?I(a,a=>s(a,e+1)):m([t[e],null],t=>s(ca(a,t),e+1));return s(a,0),n})(t,n),t=>I(t,t=>ca(s,t)[0](a,...n??[],...i))),a=>w(ca(s,a),([,t,i])=>(ya(t,i??[e],void 0,t=>(S(t,a),O(t)?1:0)),wa(s,a),n(a),i)),t=>w(ca(s,t),([t,,e=[],n,s])=>{const i=(...o)=>{const r=p(o);r==p(e)?t(a,...o,...s(o)):l(e[r])?m(n[r]?.(...o)??[],a=>i(...o,a)):i(...o,e[r])};i()})]})(),k=a=>{a!=$&&($=a,F(T,void 0,$))},U=t=>{(D&&y(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},x=async a=>(2!=$&&(k(1),f++,await H(async()=>{await A(async()=>{const e=await t();y(e)?U(e):a?M(a):E("Content is not an array: "+e)},()=>{a&&M(a)}),k(0)})),V),B=async a=>(J(),await x(a),await A(async()=>v=await s(async(a,t)=>{t||a?2!=$&&(k(1),f++,U(t??a),k(0)):await x()}),o),V),J=async()=>(v&&(await A(()=>i(v),o),v=void 0),V),Y=async a=>(1!=$&&(k(2),h++,await H(async()=>{await A(()=>n(L,a),o),k(0)})),V),q=async()=>(z(),await Y(),N=a.addDidFinishTransactionListener(()=>{const a=R();_(a)&&Y(a)}),V),z=async()=>(N&&(a.delListener(N),N=void 0),V),G=async(a=!1)=>{const[t,e]=a?[z,J]:[J,z];return await t(),await e(),V},H=async(...a)=>(b(ca(Pa,d),...a),await(async()=>{if(!ca(Ma,d)){for(wa(Ma,d,1);!l(g=C(ca(Pa,d)));)await A(g,o);wa(Ma,d,0)}})(),V),V={load:x,startAutoLoad:B,stopAutoLoad:J,isAutoLoading:()=>!l(v),save:Y,startAutoSave:q,stopAutoSave:z,isAutoSaving:()=>!l(N),startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[q,B]:[B,q];return await e(a),await n(a),V},stopAutoPersisting:G,getStatus:()=>$,addStatusListener:a=>P(a,T),delListener:t=>(j(t),a),schedule:H,getStore:()=>a,destroy:()=>(ca(Pa,d).splice(0,void 0),G()),getStats:()=>({loads:f,saves:h}),...c};return X(V)},ja=(a,t,e,s,o,r=ka,c,w)=>{const u=ra();return[async()=>{u.clear(),$(await e(a,t),({tn:a,cn:t})=>pa(ua(u,a,da),t))},async(t,e,n)=>((a,t)=>T(ca(u,a),t))(t,e)?Z(h($(await a(U+z(t)+H(t,n)),a=>[a[e],w?na(ta(a,e),w):ta(a,e)]),([a,t])=>!l(a)&&!oa(t))):{},async(t,e,s,w,y,d=!1,p=i)=>{const g=da();na(s??{},a=>$(W(a??{}),a=>pa(g,a)));const E=D(g);if(!d&&y&&p==i&&f(E)&&T(u,t))return await a("DROP "+P+z(t)),void wa(u,t);const A=ca(u,t),m=da(D(A));if(f(E)||(T(u,t)?await v($([e,...E],async(n,s)=>{S(m,n)||(await a(F+z(t)+"ADD"+z(n)+o),0==s&&await a("CREATE UNIQUE INDEX pk ON "+z(t)+`(${z(e)})`),pa(A,n))})):(await a(q+z(t)+`(${z(e)}${o} PRIMARY KEY${N($(E,a=>n+z(a)+o))});`),wa(u,t,da([e,...E])))),await v([...!d&&w?$(D(m),async n=>{n!=e&&(await a(F+z(t)+"DROP"+z(n)),S(A,n))}):[]]),d)l(s)?await a(k+z(t)+H(t,p)):await v(ea(s,async(n,s)=>{l(n)?await a(k+z(t)+H(t,p)+`AND(${z(e)}=$1)`,[s]):f(E)||await r(a,t,e,W(n),{[s]:c?$(sa(n),c):sa(n)},A)}));else if(f(E))T(u,t)&&await a(k+z(t)+H(t,p));else{const n=h(D(ca(u,t)),a=>a!=e),i={},o=[];na(s??{},(a,t)=>{i[t]=$(n,t=>c?c(a?.[t]):a?.[t]),b(o,t)}),await r(a,t,e,n,i),await a(k+z(t)+H(t,p)+`AND${z(e)}NOT IN(${G(o)})`,o)}},async t=>{let e;return await a("BEGIN"),await A(async()=>e=await t(),s),await a("END"),e}]},ka=async(a,t,e,s,i)=>{const o=[1];await a("INSERT INTO"+z(t)+"("+((...a)=>N($(a,z),n))(e,...s)+")VALUES"+N(ea(i,a=>"($"+o[0]+++","+G(a,o)+")"),n)+"ON CONFLICT("+z(e)+")DO UPDATE SET"+N($(s,a=>z(a)+"=excluded."+z(a)),n),ea(i,(a,t)=>[t,...$(a,a=>a??null)]).flat())},Ua=(a,t,e,n,s,i,o,[r,c,l],w,u,y,d,p,g)=>{const[v,E,A,m]=ja(t,w,u,s,p,g),N=Fa(a,()=>m(async()=>{return await v(),a=(await E(r,c))[L]?.[l]??"null",Ra(a,(a,t)=>""===t?void 0:t);var a}),a=>m(async()=>{var t;await v(),await A(r,c,{[L]:{[l]:(t=a()??null,La(t,(a,t)=>void 0===t?"":t))}},!0,!0)}),e,n,s,o,{[d]:()=>y,destroy:async()=>(await N.stopAutoPersisting(),i(),N)},0,y);return N},xa=(a,t,e,n,s,i,o,[r,c,[w,u,y]],d,p,g,E,A,m,N,$)=>{const[f,b,C,T]=ja(t,d,p,s,A,m,N,$),O=(a,t)=>v(la(c,async([e,n,s,i,o],r)=>{t&&!(r in a)||await C(e,n,a[r],s,i,t,o)})),D=async(a,t)=>u?await C(y,R,{[L]:a},!0,!0,t):null,I=Fa(a,()=>T(async()=>{await f();const a=await(async()=>Z(h(await v(la(r,async([a,t,e],n)=>[a,await b(n,t,e)])),a=>!oa(a[1]))))(),t=await(async()=>w?(await b(y,R))[L]:{})();return oa(a)&&l(t)?void 0:[a,t]}),(a,t)=>T(async()=>{if(await f(),l(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,o,{[E]:()=>g,destroy:async()=>(await I.stopAutoPersisting(),i(),I)},0,g);return I},Ba=(a,n,s,o,r,l,w,y,p,g,v="getDb",E)=>{let m,N,$;const f=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,l),[h,b,C,O]=(a=>{const e=(a=>aa(Da,u(a)?{[Aa]:a}:a??{}))(a),n=e[$a];if(e.mode==Ea){const a=e[Aa]??t;return[1,n,[a,e[ma]??R,e[Na]??va],da(a)]}const{tables:{load:s={},save:o={}}={},values:r={}}=e,c=d(sa(aa(Ia,r)),0,ia(Ia)),l=c[2],w=da(l),y=da(l),p=Sa(s,{[ha]:null,[fa]:R,[Oa]:i},ha,a=>T(y,a),a=>pa(w,a)),g=Sa(o,{[ba]:null,[fa]:R,[Ca]:0,[Ta]:0,[Oa]:null},ba,(a,t)=>T(y,t),(a,t)=>pa(w,t));var v;return v=(a,t)=>t[4]??=ca(p,t[0])?.[2]??i,I(g,(a,t)=>v(0,a)),[0,n,[p,g,c],w]})(n);return(h?Ua:xa)(a,f,a=>{let t;const e=()=>t=setInterval(()=>A(async()=>{const[{d:t,s:e,c:n}]=await f(_+` ${B} d,${J} s,TOTAL_CHANGES() c FROM ${x}${B} JOIN ${x}${J}`);t==m&&e==N&&n==$||(null!=m&&a(),m=t,N=e,$=n)}),1e3*b),n=()=>{m=N=$=null,c(t)},s=o(t=>{O.has(t)&&(n(),a(),e())});return e(),()=>{n(),r(s)}},a=>a(),w,y,p,C,D(O),async(a,t)=>await a(_+` t.name tn,c.name cn FROM ${Y}list()t,${Y}info(t.name)c ${M} t.schema='main'AND t.type IN('table','view')AND t.name IN(${G(t)})ORDER BY t.name,c.name`,t),g,v,e,E,a=>!0===a?1:!1===a?0:a,void 0)},Ja=(a,t,e,n,s,i)=>Ba(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,g,0),s,i,g,3,e);export{Ja as createSqliteWasmPersister};
@@ -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=clearInterval,l=a=>null==a,w=(a,t,e)=>l(a)?e?.():t(a),u=t=>a(t)==s,y=a=>Array.isArray(a),d=(a,t,e)=>a.slice(t,e),p=a=>a.length,g=()=>{},v=async a=>r.all(a),E=a=>{throw Error(a)},A=async(a,t,e)=>{try{return await a()}catch(a){t?.(a)}},m=(a,t)=>a.forEach(t),N=(a,t="")=>a.join(t),$=(a,t)=>a.map(t),f=a=>0==p(a),h=(a,t)=>a.filter(t),b=(a,...t)=>a.push(...t),C=a=>a.shift(),T=(a,t)=>a?.has(t)??!1,O=a=>l(a)||0==(a=>a?.size??0)(a),D=a=>[...a?.values()??[]],I=(a,t)=>a?.forEach(t),S=(a,t)=>a?.delete(t),L="_",R="_id",_="SELECT",M="WHERE",P="TABLE",F="ALTER "+P,j="FROM",k="DELETE "+j,U=_+"*"+j,x="pragma_",B="data_version",J="schema_version",Y="pragma_table_",q="CREATE "+P,z=a=>N($(((a,t="",e)=>a.split(t,e))(a,"."),(a=>`"${o(a,/"/g,'""')}"`)),"."),G=(a,t=[1])=>N($(a,(()=>"$"+t[0]++)),n),H=(a,t=i)=>M+`(${o(t,"$tableName",z(a))})`,V=Object,K=a=>V.getPrototypeOf(a),Q=V.entries,W=V.keys,X=V.freeze,Z=(a=[])=>V.fromEntries(a),aa=(...a)=>V.assign({},...a),ta=(a,t)=>(delete a[t],a),ea=(a,t)=>$(Q(a),(([a,e])=>t(e,a))),na=(a,t)=>Z(ea(a,((a,e)=>[e,t(a,e)]))),sa=a=>V.values(a),ia=a=>p(W(a)),oa=a=>(a=>!l(a)&&w(K(a),(a=>a==V.prototype||l(K(a))),(()=>!0)))(a)&&0==ia(a),ra=a=>new Map(a),ca=(a,t)=>a?.get(t),la=(a,t)=>$([...a?.entries()??[]],(([a,e])=>t(e,a))),wa=(a,t,e)=>l(e)?(S(a,t),a):a?.set(t,e),ua=(a,t,e,n)=>(T(a,t)?n?.(ca(a,t)):wa(a,t,e()),ca(a,t)),ya=(a,t,e,n,s=0)=>w((e?ua:ca)(a,t[s],s>p(t)-2?e:ra),(i=>{if(s>p(t)-2)return n?.(i)&&wa(a,t[s]),i;const o=ya(i,t,e,n,s+1);return O(i)&&wa(a,t[s]),o})),da=a=>new Set(y(a)||l(a)?a:[a]),pa=(a,t)=>a?.add(t),ga="ColumnName",va="store",Ea="json",Aa=va+"TableName",ma=va+"Id"+ga,Na=va+ga,$a="autoLoadIntervalSeconds",fa="rowId"+ga,ha="tableId",ba="tableName",Ca="deleteEmptyColumns",Ta="deleteEmptyTable",Oa="condition",Da={mode:Ea,[$a]:1},Ia={load:0,save:0,[ba]:t+"_values"},Sa=(a,t,e,n,s)=>{const i=ra();return na(a,((a,o)=>{const r=d(sa(aa(t,u(a)?{[e]:a}:a)),0,ia(t));l(r[0])||n(o,r[0])||(s(o,r[0]),wa(i,o,r))})),i},La=JSON.stringify,Ra=JSON.parse,_a=/^\d+$/,Ma=ra(),Pa=ra(),Fa=(a,t,n,s,i,o,r,c={},u=0,d=[])=>{let g,v,N,$=0,f=0,h=0;ua(Ma,d,(()=>0)),ua(Pa,d,(()=>[]));const T=ra(),[D,L,R,_,M]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!oa(a)||!oa(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!oa(a)||!oa(t),t.setContent]:E("Store type not supported by this Persister"))(r,a,u),[P,F,j]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?C(a):null)??e+t++,t=>{_a.test(t)&&p(a)<1e3&&b(a,t)}]})(),s=ra();return[(n,i,o,r=[],c=()=>[])=>{a??=V;const l=t(1);return wa(s,l,[n,i,o,r,c]),pa(ya(i,o??[e],da),l),l},(t,n,...i)=>m(((a,t=[e])=>{const n=[],s=(a,e)=>e==p(t)?b(n,a):null===t[e]?I(a,(a=>s(a,e+1))):m([t[e],null],(t=>s(ca(a,t),e+1)));return s(a,0),n})(t,n),(t=>I(t,(t=>ca(s,t)[0](a,...n??[],...i))))),a=>w(ca(s,a),(([,t,i])=>(ya(t,i??[e],void 0,(t=>(S(t,a),O(t)?1:0))),wa(s,a),n(a),i))),t=>w(ca(s,t),(([t,,e=[],n,s])=>{const i=(...o)=>{const r=p(o);r==p(e)?t(a,...o,...s(o)):l(e[r])?m(n[r]?.(...o)??[],(a=>i(...o,a))):i(...o,e[r])};i()}))]})(),k=a=>{a!=$&&($=a,F(T,void 0,$))},U=t=>{(D&&y(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},x=async a=>(2!=$&&(k(1),f++,await H((async()=>{await A((async()=>{const e=await t();y(e)?U(e):a?M(a):E("Content is not an array: "+e)}),(()=>{a&&M(a)})),k(0)}))),V),B=async a=>(J(),await x(a),await A((async()=>v=await s((async(a,t)=>{t||a?2!=$&&(k(1),f++,U(t??a),k(0)):await x()}))),o),V),J=async()=>(v&&(await A((()=>i(v)),o),v=void 0),V),Y=async a=>(1!=$&&(k(2),h++,await H((async()=>{await A((()=>n(L,a)),o),k(0)}))),V),q=async()=>(z(),await Y(),N=a.addDidFinishTransactionListener((()=>{const a=R();_(a)&&Y(a)})),V),z=async()=>(N&&(a.delListener(N),N=void 0),V),G=async(a=!1)=>{const[t,e]=a?[z,J]:[J,z];return await t(),await e(),V},H=async(...a)=>(b(ca(Pa,d),...a),await(async()=>{if(!ca(Ma,d)){for(wa(Ma,d,1);!l(g=C(ca(Pa,d)));)await A(g,o);wa(Ma,d,0)}})(),V),V={load:x,startAutoLoad:B,stopAutoLoad:J,isAutoLoading:()=>!l(v),save:Y,startAutoSave:q,stopAutoSave:z,isAutoSaving:()=>!l(N),startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[q,B]:[B,q];return await e(a),await n(a),V},stopAutoPersisting:G,getStatus:()=>$,addStatusListener:a=>P(a,T),delListener:t=>(j(t),a),schedule:H,getStore:()=>a,destroy:()=>(ca(Pa,d).splice(0,void 0),G()),getStats:()=>({loads:f,saves:h}),...c};return X(V)},ja=(a,t,e,s,o,r=ka,c,w)=>{const u=ra();return[async()=>{u.clear(),$(await e(a,t),(({tn:a,cn:t})=>pa(ua(u,a,da),t)))},async(t,e,n)=>((a,t)=>T(ca(u,a),t))(t,e)?Z(h($(await a(U+z(t)+H(t,n)),(a=>[a[e],w?na(ta(a,e),w):ta(a,e)])),(([a,t])=>!l(a)&&!oa(t)))):{},async(t,e,s,w,y,d=!1,p=i)=>{const g=da();na(s??{},(a=>$(W(a??{}),(a=>pa(g,a)))));const E=D(g);if(!d&&y&&p==i&&f(E)&&T(u,t))return await a("DROP "+P+z(t)),void wa(u,t);const A=ca(u,t),m=da(D(A));if(f(E)||(T(u,t)?await v($([e,...E],(async(n,s)=>{S(m,n)||(await a(F+z(t)+"ADD"+z(n)+o),0==s&&await a("CREATE UNIQUE INDEX pk ON "+z(t)+`(${z(e)})`),pa(A,n))}))):(await a(q+z(t)+`(${z(e)}${o} PRIMARY KEY${N($(E,(a=>n+z(a)+o)))});`),wa(u,t,da([e,...E])))),await v([...!d&&w?$(D(m),(async n=>{n!=e&&(await a(F+z(t)+"DROP"+z(n)),S(A,n))})):[]]),d)l(s)?await a(k+z(t)+H(t,p)):await v(ea(s,(async(n,s)=>{l(n)?await a(k+z(t)+H(t,p)+`AND(${z(e)}=$1)`,[s]):f(E)||await r(a,t,e,W(n),{[s]:c?$(sa(n),c):sa(n)},A)})));else if(f(E))T(u,t)&&await a(k+z(t)+H(t,p));else{const n=h(D(ca(u,t)),(a=>a!=e)),i={},o=[];na(s??{},((a,t)=>{i[t]=$(n,(t=>c?c(a?.[t]):a?.[t])),b(o,t)})),await r(a,t,e,n,i),await a(k+z(t)+H(t,p)+`AND${z(e)}NOT IN(${G(o)})`,o)}},async t=>{let e;return await a("BEGIN"),await A((async()=>e=await t()),s),await a("END"),e}]},ka=async(a,t,e,s,i)=>{const o=[1];await a("INSERT INTO"+z(t)+"("+((...a)=>N($(a,z),n))(e,...s)+")VALUES"+N(ea(i,(a=>"($"+o[0]+++","+G(a,o)+")")),n)+"ON CONFLICT("+z(e)+")DO UPDATE SET"+N($(s,(a=>z(a)+"=excluded."+z(a))),n),ea(i,((a,t)=>[t,...$(a,(a=>a??null))])).flat())},Ua=(a,t,e,n,s,i,o,[r,c,l],w,u,y,d,p,g)=>{const[v,E,A,m]=ja(t,w,u,s,p,g),N=Fa(a,(()=>m((async()=>{return await v(),a=(await E(r,c))[L]?.[l]??"null",Ra(a,((a,t)=>""===t?void 0:t));var a}))),(a=>m((async()=>{var t;await v(),await A(r,c,{[L]:{[l]:(t=a()??null,La(t,((a,t)=>void 0===t?"":t)))}},!0,!0)}))),e,n,s,o,{[d]:()=>y,destroy:async()=>(await N.stopAutoPersisting(),i(),N)},0,y);return N},xa=(a,t,e,n,s,i,o,[r,c,[w,u,y]],d,p,g,E,A,m,N,$)=>{const[f,b,C,T]=ja(t,d,p,s,A,m,N,$),O=(a,t)=>v(la(c,(async([e,n,s,i,o],r)=>{t&&!(r in a)||await C(e,n,a[r],s,i,t,o)}))),D=async(a,t)=>u?await C(y,R,{[L]:a},!0,!0,t):null,I=Fa(a,(()=>T((async()=>{await f();const a=await(async()=>Z(h(await v(la(r,(async([a,t,e],n)=>[a,await b(n,t,e)]))),(a=>!oa(a[1])))))(),t=await(async()=>w?(await b(y,R))[L]:{})();return oa(a)&&l(t)?void 0:[a,t]}))),((a,t)=>T((async()=>{if(await f(),l(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,o,{[E]:()=>g,destroy:async()=>(await I.stopAutoPersisting(),i(),I)},0,g);return I},Ba=(a,n,s,o,r,l,w,y,p,g,v="getDb",E)=>{let m,N,$;const f=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,l),[h,b,C,O]=(a=>{const e=(a=>aa(Da,u(a)?{[Aa]:a}:a??{}))(a),n=e[$a];if(e.mode==Ea){const a=e[Aa]??t;return[1,n,[a,e[ma]??R,e[Na]??va],da(a)]}const{tables:{load:s={},save:o={}}={},values:r={}}=e,c=d(sa(aa(Ia,r)),0,ia(Ia)),l=c[2],w=da(l),y=da(l),p=Sa(s,{[ha]:null,[fa]:R,[Oa]:i},ha,(a=>T(y,a)),(a=>pa(w,a))),g=Sa(o,{[ba]:null,[fa]:R,[Ca]:0,[Ta]:0,[Oa]:null},ba,((a,t)=>T(y,t)),((a,t)=>pa(w,t)));var v;return v=(a,t)=>t[4]??=ca(p,t[0])?.[2]??i,I(g,((a,t)=>v(0,a))),[0,n,[p,g,c],w]})(n);return(h?Ua:xa)(a,f,(a=>{let t;const e=()=>t=setInterval((()=>A((async()=>{const[{d:t,s:e,c:n}]=await f(_+` ${B} d,${J} s,TOTAL_CHANGES() c FROM ${x}${B} JOIN ${x}${J}`);t==m&&e==N&&n==$||(null!=m&&a(),m=t,N=e,$=n)}))),1e3*b),n=()=>{m=N=$=null,c(t)},s=o((t=>{O.has(t)&&(n(),a(),e())}));return e(),()=>{n(),r(s)}}),(a=>a()),w,y,p,C,D(O),(async(a,t)=>await a(_+` t.name tn,c.name cn FROM ${Y}list()t,${Y}info(t.name)c ${M} t.schema='main'AND t.type IN('table','view')AND t.name IN(${G(t)})ORDER BY t.name,c.name`,t)),g,v,e,E,(a=>!0===a?1:!1===a?0:a),void 0)},Ja=(a,t,e,n,s,i)=>Ba(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,g,0)),s,i,g,3,e);export{Ja 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=clearInterval,l=a=>null==a,w=(a,t,e)=>l(a)?e?.():t(a),u=t=>a(t)==s,y=a=>Array.isArray(a),d=(a,t,e)=>a.slice(t,e),p=a=>a.length,g=()=>{},v=async a=>r.all(a),E=a=>{throw Error(a)},A=async(a,t,e)=>{try{return await a()}catch(a){t?.(a)}},m=(a,t)=>a.forEach(t),N=(a,t="")=>a.join(t),$=(a,t)=>a.map(t),f=a=>0==p(a),h=(a,t)=>a.filter(t),b=(a,...t)=>a.push(...t),C=a=>a.shift(),T=(a,t)=>a?.has(t)??!1,O=a=>l(a)||0==(a=>a?.size??0)(a),D=a=>[...a?.values()??[]],I=(a,t)=>a?.forEach(t),S=(a,t)=>a?.delete(t),L="_",R="_id",_="SELECT",M="WHERE",P="TABLE",F="ALTER "+P,j="FROM",k="DELETE "+j,U=_+"*"+j,x="pragma_",B="data_version",J="schema_version",Y="pragma_table_",q="CREATE "+P,z=a=>N($(((a,t="",e)=>a.split(t,e))(a,"."),a=>`"${o(a,/"/g,'""')}"`),"."),G=(a,t=[1])=>N($(a,()=>"$"+t[0]++),n),H=(a,t=i)=>M+`(${o(t,"$tableName",z(a))})`,V=Object,K=a=>V.getPrototypeOf(a),Q=V.entries,W=V.keys,X=V.freeze,Z=(a=[])=>V.fromEntries(a),aa=(...a)=>V.assign({},...a),ta=(a,t)=>(delete a[t],a),ea=(a,t)=>$(Q(a),([a,e])=>t(e,a)),na=(a,t)=>Z(ea(a,(a,e)=>[e,t(a,e)])),sa=a=>V.values(a),ia=a=>p(W(a)),oa=a=>(a=>!l(a)&&w(K(a),a=>a==V.prototype||l(K(a)),()=>!0))(a)&&0==ia(a),ra=a=>new Map(a),ca=(a,t)=>a?.get(t),la=(a,t)=>$([...a?.entries()??[]],([a,e])=>t(e,a)),wa=(a,t,e)=>l(e)?(S(a,t),a):a?.set(t,e),ua=(a,t,e,n)=>(T(a,t)?n?.(ca(a,t)):wa(a,t,e()),ca(a,t)),ya=(a,t,e,n,s=0)=>w((e?ua:ca)(a,t[s],s>p(t)-2?e:ra),i=>{if(s>p(t)-2)return n?.(i)&&wa(a,t[s]),i;const o=ya(i,t,e,n,s+1);return O(i)&&wa(a,t[s]),o}),da=a=>new Set(y(a)||l(a)?a:[a]),pa=(a,t)=>a?.add(t),ga="ColumnName",va="store",Ea="json",Aa=va+"TableName",ma=va+"Id"+ga,Na=va+ga,$a="autoLoadIntervalSeconds",fa="rowId"+ga,ha="tableId",ba="tableName",Ca="deleteEmptyColumns",Ta="deleteEmptyTable",Oa="condition",Da={mode:Ea,[$a]:1},Ia={load:0,save:0,[ba]:t+"_values"},Sa=(a,t,e,n,s)=>{const i=ra();return na(a,(a,o)=>{const r=d(sa(aa(t,u(a)?{[e]:a}:a)),0,ia(t));l(r[0])||n(o,r[0])||(s(o,r[0]),wa(i,o,r))}),i},La=JSON.stringify,Ra=JSON.parse,_a=/^\d+$/,Ma=ra(),Pa=ra(),Fa=(a,t,n,s,i,o,r,c={},u=0,d=[])=>{let g,v,N,$=0,f=0,h=0;ua(Ma,d,()=>0),ua(Pa,d,()=>[]);const T=ra(),[D,L,R,_,M]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!oa(a)||!oa(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!oa(a)||!oa(t),t.setContent]:E("Store type not supported by this Persister"))(r,a,u),[P,F,j]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?C(a):null)??e+t++,t=>{_a.test(t)&&p(a)<1e3&&b(a,t)}]})(),s=ra();return[(n,i,o,r=[],c=()=>[])=>{a??=V;const l=t(1);return wa(s,l,[n,i,o,r,c]),pa(ya(i,o??[e],da),l),l},(t,n,...i)=>m(((a,t=[e])=>{const n=[],s=(a,e)=>e==p(t)?b(n,a):null===t[e]?I(a,a=>s(a,e+1)):m([t[e],null],t=>s(ca(a,t),e+1));return s(a,0),n})(t,n),t=>I(t,t=>ca(s,t)[0](a,...n??[],...i))),a=>w(ca(s,a),([,t,i])=>(ya(t,i??[e],void 0,t=>(S(t,a),O(t)?1:0)),wa(s,a),n(a),i)),t=>w(ca(s,t),([t,,e=[],n,s])=>{const i=(...o)=>{const r=p(o);r==p(e)?t(a,...o,...s(o)):l(e[r])?m(n[r]?.(...o)??[],a=>i(...o,a)):i(...o,e[r])};i()})]})(),k=a=>{a!=$&&($=a,F(T,void 0,$))},U=t=>{(D&&y(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},x=async a=>(2!=$&&(k(1),f++,await H(async()=>{await A(async()=>{const e=await t();y(e)?U(e):a?M(a):E("Content is not an array: "+e)},()=>{a&&M(a)}),k(0)})),V),B=async a=>(J(),await x(a),await A(async()=>v=await s(async(a,t)=>{t||a?2!=$&&(k(1),f++,U(t??a),k(0)):await x()}),o),V),J=async()=>(v&&(await A(()=>i(v),o),v=void 0),V),Y=async a=>(1!=$&&(k(2),h++,await H(async()=>{await A(()=>n(L,a),o),k(0)})),V),q=async()=>(z(),await Y(),N=a.addDidFinishTransactionListener(()=>{const a=R();_(a)&&Y(a)}),V),z=async()=>(N&&(a.delListener(N),N=void 0),V),G=async(a=!1)=>{const[t,e]=a?[z,J]:[J,z];return await t(),await e(),V},H=async(...a)=>(b(ca(Pa,d),...a),await(async()=>{if(!ca(Ma,d)){for(wa(Ma,d,1);!l(g=C(ca(Pa,d)));)await A(g,o);wa(Ma,d,0)}})(),V),V={load:x,startAutoLoad:B,stopAutoLoad:J,isAutoLoading:()=>!l(v),save:Y,startAutoSave:q,stopAutoSave:z,isAutoSaving:()=>!l(N),startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[q,B]:[B,q];return await e(a),await n(a),V},stopAutoPersisting:G,getStatus:()=>$,addStatusListener:a=>P(a,T),delListener:t=>(j(t),a),schedule:H,getStore:()=>a,destroy:()=>(ca(Pa,d).splice(0,void 0),G()),getStats:()=>({loads:f,saves:h}),...c};return X(V)},ja=(a,t,e,s,o,r=ka,c,w)=>{const u=ra();return[async()=>{u.clear(),$(await e(a,t),({tn:a,cn:t})=>pa(ua(u,a,da),t))},async(t,e,n)=>((a,t)=>T(ca(u,a),t))(t,e)?Z(h($(await a(U+z(t)+H(t,n)),a=>[a[e],w?na(ta(a,e),w):ta(a,e)]),([a,t])=>!l(a)&&!oa(t))):{},async(t,e,s,w,y,d=!1,p=i)=>{const g=da();na(s??{},a=>$(W(a??{}),a=>pa(g,a)));const E=D(g);if(!d&&y&&p==i&&f(E)&&T(u,t))return await a("DROP "+P+z(t)),void wa(u,t);const A=ca(u,t),m=da(D(A));if(f(E)||(T(u,t)?await v($([e,...E],async(n,s)=>{S(m,n)||(await a(F+z(t)+"ADD"+z(n)+o),0==s&&await a("CREATE UNIQUE INDEX pk ON "+z(t)+`(${z(e)})`),pa(A,n))})):(await a(q+z(t)+`(${z(e)}${o} PRIMARY KEY${N($(E,a=>n+z(a)+o))});`),wa(u,t,da([e,...E])))),await v([...!d&&w?$(D(m),async n=>{n!=e&&(await a(F+z(t)+"DROP"+z(n)),S(A,n))}):[]]),d)l(s)?await a(k+z(t)+H(t,p)):await v(ea(s,async(n,s)=>{l(n)?await a(k+z(t)+H(t,p)+`AND(${z(e)}=$1)`,[s]):f(E)||await r(a,t,e,W(n),{[s]:c?$(sa(n),c):sa(n)},A)}));else if(f(E))T(u,t)&&await a(k+z(t)+H(t,p));else{const n=h(D(ca(u,t)),a=>a!=e),i={},o=[];na(s??{},(a,t)=>{i[t]=$(n,t=>c?c(a?.[t]):a?.[t]),b(o,t)}),await r(a,t,e,n,i),await a(k+z(t)+H(t,p)+`AND${z(e)}NOT IN(${G(o)})`,o)}},async t=>{let e;return await a("BEGIN"),await A(async()=>e=await t(),s),await a("END"),e}]},ka=async(a,t,e,s,i)=>{const o=[1];await a("INSERT INTO"+z(t)+"("+((...a)=>N($(a,z),n))(e,...s)+")VALUES"+N(ea(i,a=>"($"+o[0]+++","+G(a,o)+")"),n)+"ON CONFLICT("+z(e)+")DO UPDATE SET"+N($(s,a=>z(a)+"=excluded."+z(a)),n),ea(i,(a,t)=>[t,...$(a,a=>a??null)]).flat())},Ua=(a,t,e,n,s,i,o,[r,c,l],w,u,y,d,p,g)=>{const[v,E,A,m]=ja(t,w,u,s,p,g),N=Fa(a,()=>m(async()=>{return await v(),a=(await E(r,c))[L]?.[l]??"null",Ra(a,(a,t)=>""===t?void 0:t);var a}),a=>m(async()=>{var t;await v(),await A(r,c,{[L]:{[l]:(t=a()??null,La(t,(a,t)=>void 0===t?"":t))}},!0,!0)}),e,n,s,o,{[d]:()=>y,destroy:async()=>(await N.stopAutoPersisting(),i(),N)},0,y);return N},xa=(a,t,e,n,s,i,o,[r,c,[w,u,y]],d,p,g,E,A,m,N,$)=>{const[f,b,C,T]=ja(t,d,p,s,A,m,N,$),O=(a,t)=>v(la(c,async([e,n,s,i,o],r)=>{t&&!(r in a)||await C(e,n,a[r],s,i,t,o)})),D=async(a,t)=>u?await C(y,R,{[L]:a},!0,!0,t):null,I=Fa(a,()=>T(async()=>{await f();const a=await(async()=>Z(h(await v(la(r,async([a,t,e],n)=>[a,await b(n,t,e)])),a=>!oa(a[1]))))(),t=await(async()=>w?(await b(y,R))[L]:{})();return oa(a)&&l(t)?void 0:[a,t]}),(a,t)=>T(async()=>{if(await f(),l(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,o,{[E]:()=>g,destroy:async()=>(await I.stopAutoPersisting(),i(),I)},0,g);return I},Ba=(a,n,s,o,r,l,w,y,p,g,v="getDb",E)=>{let m,N,$;const f=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,l),[h,b,C,O]=(a=>{const e=(a=>aa(Da,u(a)?{[Aa]:a}:a??{}))(a),n=e[$a];if(e.mode==Ea){const a=e[Aa]??t;return[1,n,[a,e[ma]??R,e[Na]??va],da(a)]}const{tables:{load:s={},save:o={}}={},values:r={}}=e,c=d(sa(aa(Ia,r)),0,ia(Ia)),l=c[2],w=da(l),y=da(l),p=Sa(s,{[ha]:null,[fa]:R,[Oa]:i},ha,a=>T(y,a),a=>pa(w,a)),g=Sa(o,{[ba]:null,[fa]:R,[Ca]:0,[Ta]:0,[Oa]:null},ba,(a,t)=>T(y,t),(a,t)=>pa(w,t));var v;return v=(a,t)=>t[4]??=ca(p,t[0])?.[2]??i,I(g,(a,t)=>v(0,a)),[0,n,[p,g,c],w]})(n);return(h?Ua:xa)(a,f,a=>{let t;const e=()=>t=setInterval(()=>A(async()=>{const[{d:t,s:e,c:n}]=await f(_+` ${B} d,${J} s,TOTAL_CHANGES() c FROM ${x}${B} JOIN ${x}${J}`);t==m&&e==N&&n==$||(null!=m&&a(),m=t,N=e,$=n)}),1e3*b),n=()=>{m=N=$=null,c(t)},s=o(t=>{O.has(t)&&(n(),a(),e())});return e(),()=>{n(),r(s)}},a=>a(),w,y,p,C,D(O),async(a,t)=>await a(_+` t.name tn,c.name cn FROM ${Y}list()t,${Y}info(t.name)c ${M} t.schema='main'AND t.type IN('table','view')AND t.name IN(${G(t)})ORDER BY t.name,c.name`,t),g,v,e,E,a=>!0===a?1:!1===a?0:a,void 0)},Ja=(a,t,e,n,s,i)=>Ba(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,g,0),s,i,g,3,e);export{Ja as createSqliteWasmPersister};
@@ -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=clearInterval,l=a=>null==a,w=(a,t,e)=>l(a)?e?.():t(a),u=t=>a(t)==s,y=a=>Array.isArray(a),d=(a,t,e)=>a.slice(t,e),g=a=>a.length,v=()=>{},p=async a=>o.all(a),E=a=>{throw Error(a)},A=async(a,t,e)=>{try{return await a()}catch(a){t?.(a)}},N=(a,t)=>a.forEach(t),m=(a,t="")=>a.join(t),$=(a,t)=>a.map(t),f=a=>0==g(a),h=(a,t)=>a.filter(t),C=(a,...t)=>a.push(...t),T=a=>a.shift(),O=(a,t)=>a?.has(t)??!1,b=a=>l(a)||0==(a=>a?.size??0)(a),D=a=>[...a?.values()??[]],I=(a,t)=>a?.forEach(t),S=(a,t)=>a?.delete(t),L="_",R="_id",P="SELECT",M="WHERE",_="TABLE",F="ALTER "+_,U="FROM",j="DELETE "+U,B=P+"*"+U,J="pragma_",Y="data_version",k="schema_version",x="pragma_table_",z="CREATE "+_,G=a=>m($(((a,t="",e)=>a.split(t,e))(a,"."),(a=>`"${r(a,/"/g,'""')}"`)),"."),H=(a,t=[1])=>m($(a,(()=>"$"+t[0]++)),n),K=(a,t=i)=>M+`(${r(t,"$tableName",G(a))})`,Q=Object,V=a=>Q.getPrototypeOf(a),W=Q.entries,X=Q.keys,q=Q.freeze,Z=(a=[])=>Q.fromEntries(a),aa=(...a)=>Q.assign({},...a),ta=(a,t)=>(delete a[t],a),ea=(a,t)=>$(W(a),(([a,e])=>t(e,a))),na=(a,t)=>Z(ea(a,((a,e)=>[e,t(a,e)]))),sa=a=>Q.values(a),ia=a=>g(X(a)),ra=a=>(a=>!l(a)&&w(V(a),(a=>a==Q.prototype||l(V(a))),(()=>!0)))(a)&&0==ia(a),oa=a=>new Map(a),ca=(a,t)=>a?.get(t),la=(a,t)=>$([...a?.entries()??[]],(([a,e])=>t(e,a))),wa=(a,t,e)=>l(e)?(S(a,t),a):a?.set(t,e),ua=(a,t,e,n)=>(O(a,t)?n?.(ca(a,t)):wa(a,t,e()),ca(a,t)),ya=(a,t,e,n,s=0)=>w((e?ua:ca)(a,t[s],s>g(t)-2?e:oa),(i=>{if(s>g(t)-2)return n?.(i)&&wa(a,t[s]),i;const r=ya(i,t,e,n,s+1);return b(i)&&wa(a,t[s]),r})),da=a=>new Set(y(a)||l(a)?a:[a]),ga=(a,t)=>a?.add(t),va="ColumnName",pa="store",Ea="json",Aa=pa+"TableName",Na=pa+"Id"+va,ma=pa+va,$a="autoLoadIntervalSeconds",fa="rowId"+va,ha="tableId",Ca="tableName",Ta="deleteEmptyColumns",Oa="deleteEmptyTable",ba="condition",Da={mode:Ea,[$a]:1},Ia={load:0,save:0,[Ca]:t+"_values"},Sa=(a,t,e,n,s)=>{const i=oa();return na(a,((a,r)=>{const o=d(sa(aa(t,u(a)?{[e]:a}:a)),0,ia(t));l(o[0])||n(r,o[0])||(s(r,o[0]),wa(i,r,o))})),i},La=JSON.stringify,Ra=JSON.parse,Pa=/^\d+$/,Ma=oa(),_a=oa(),Fa=(a,t,n,s,i,r,o,c={},u=0,d=[])=>{let v,p,m,$=0,f=0,h=0;ua(Ma,d,(()=>0)),ua(_a,d,(()=>[]));const O=oa(),[D,L,R,P,M]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!ra(a)||!ra(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!ra(a)||!ra(t),t.setContent]:E("Store type not supported by this Persister"))(o,a,u),[_,F,U]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?T(a):null)??e+t++,t=>{Pa.test(t)&&g(a)<1e3&&C(a,t)}]})(),s=oa();return[(n,i,r,o=[],c=()=>[])=>{a??=Q;const l=t(1);return wa(s,l,[n,i,r,o,c]),ga(ya(i,r??[e],da),l),l},(t,n,...i)=>N(((a,t=[e])=>{const n=[],s=(a,e)=>e==g(t)?C(n,a):null===t[e]?I(a,(a=>s(a,e+1))):N([t[e],null],(t=>s(ca(a,t),e+1)));return s(a,0),n})(t,n),(t=>I(t,(t=>ca(s,t)[0](a,...n??[],...i))))),a=>w(ca(s,a),(([,t,i])=>(ya(t,i??[e],void 0,(t=>(S(t,a),b(t)?1:0))),wa(s,a),n(a),i))),t=>w(ca(s,t),(([t,,e=[],n,s])=>{const i=(...r)=>{const o=g(r);o==g(e)?t(a,...r,...s(r)):l(e[o])?N(n[o]?.(...r)??[],(a=>i(...r,a))):i(...r,e[o])};i()}))]})(),j=a=>{a!=$&&($=a,F(O,void 0,$))},B=t=>{(D&&y(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},J=async a=>(2!=$&&(j(1),f++,await K((async()=>{await A((async()=>{const e=await t();y(e)?B(e):a?M(a):E("Content is not an array: "+e)}),(()=>{a&&M(a)})),j(0)}))),Q),Y=async a=>(k(),await J(a),await A((async()=>p=await s((async(a,t)=>{t||a?2!=$&&(j(1),f++,B(t??a),j(0)):await J()}))),r),Q),k=async()=>(p&&(await A((()=>i(p)),r),p=void 0),Q),x=async a=>(1!=$&&(j(2),h++,await K((async()=>{await A((()=>n(L,a)),r),j(0)}))),Q),z=async()=>(G(),await x(),m=a.addDidFinishTransactionListener((()=>{const a=R();P(a)&&x(a)})),Q),G=async()=>(m&&(a.delListener(m),m=void 0),Q),H=async(a=!1)=>{const[t,e]=a?[G,k]:[k,G];return await t(),await e(),Q},K=async(...a)=>(C(ca(_a,d),...a),await(async()=>{if(!ca(Ma,d)){for(wa(Ma,d,1);!l(v=T(ca(_a,d)));)await A(v,r);wa(Ma,d,0)}})(),Q),Q={load:J,startAutoLoad:Y,stopAutoLoad:k,isAutoLoading:()=>!l(p),save:x,startAutoSave:z,stopAutoSave:G,isAutoSaving:()=>!l(m),startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[z,Y]:[Y,z];return await e(a),await n(a),Q},stopAutoPersisting:H,getStatus:()=>$,addStatusListener:a=>_(a,O),delListener:t=>(U(t),a),schedule:K,getStore:()=>a,destroy:()=>(ca(_a,d).splice(0,void 0),H()),getStats:()=>({loads:f,saves:h}),...c};return q(Q)},Ua=(a,t,e,s,r,o=ja,c,w)=>{const u=oa();return[async()=>{u.clear(),$(await e(a,t),(({tn:a,cn:t})=>ga(ua(u,a,da),t)))},async(t,e,n)=>((a,t)=>O(ca(u,a),t))(t,e)?Z(h($(await a(B+G(t)+K(t,n)),(a=>[a[e],w?na(ta(a,e),w):ta(a,e)])),(([a,t])=>!l(a)&&!ra(t)))):{},async(t,e,s,w,y,d=!1,g=i)=>{const v=da();na(s??{},(a=>$(X(a??{}),(a=>ga(v,a)))));const E=D(v);if(!d&&y&&g==i&&f(E)&&O(u,t))return await a("DROP "+_+G(t)),void wa(u,t);const A=ca(u,t),N=da(D(A));if(f(E)||(O(u,t)?await p($([e,...E],(async(n,s)=>{S(N,n)||(await a(F+G(t)+"ADD"+G(n)+r),0==s&&await a("CREATE UNIQUE INDEX pk ON "+G(t)+`(${G(e)})`),ga(A,n))}))):(await a(z+G(t)+`(${G(e)}${r} PRIMARY KEY${m($(E,(a=>n+G(a)+r)))});`),wa(u,t,da([e,...E])))),await p([...!d&&w?$(D(N),(async n=>{n!=e&&(await a(F+G(t)+"DROP"+G(n)),S(A,n))})):[]]),d)l(s)?await a(j+G(t)+K(t,g)):await p(ea(s,(async(n,s)=>{l(n)?await a(j+G(t)+K(t,g)+`AND(${G(e)}=$1)`,[s]):f(E)||await o(a,t,e,X(n),{[s]:c?$(sa(n),c):sa(n)},A)})));else if(f(E))O(u,t)&&await a(j+G(t)+K(t,g));else{const n=h(D(ca(u,t)),(a=>a!=e)),i={},r=[];na(s??{},((a,t)=>{i[t]=$(n,(t=>c?c(a?.[t]):a?.[t])),C(r,t)})),await o(a,t,e,n,i),await a(j+G(t)+K(t,g)+`AND${G(e)}NOT IN(${H(r)})`,r)}},async t=>{let e;return await a("BEGIN"),await A((async()=>e=await t()),s),await a("END"),e}]},ja=async(a,t,e,s,i)=>{const r=[1];await a("INSERT INTO"+G(t)+"("+((...a)=>m($(a,G),n))(e,...s)+")VALUES"+m(ea(i,(a=>"($"+r[0]+++","+H(a,r)+")")),n)+"ON CONFLICT("+G(e)+")DO UPDATE SET"+m($(s,(a=>G(a)+"=excluded."+G(a))),n),ea(i,((a,t)=>[t,...$(a,(a=>a??null))])).flat())},Ba=(a,t,e,n,s,i,r,[o,c,l],w,u,y,d,g,v)=>{const[p,E,A,N]=Ua(t,w,u,s,g,v),m=Fa(a,(()=>N((async()=>{return await p(),a=(await E(o,c))[L]?.[l]??"null",Ra(a,((a,t)=>""===t?void 0:t));var a}))),(a=>N((async()=>{var t;await p(),await A(o,c,{[L]:{[l]:(t=a()??null,La(t,((a,t)=>void 0===t?"":t)))}},!0,!0)}))),e,n,s,r,{[d]:()=>y,destroy:async()=>(await m.stopAutoPersisting(),i(),m)},0,y);return m},Ja=(a,t,e,n,s,i,r,[o,c,[w,u,y]],d,g,v,E,A,N,m,$)=>{const[f,C,T,O]=Ua(t,d,g,s,A,N,m,$),b=(a,t)=>p(la(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)=>u?await T(y,R,{[L]:a},!0,!0,t):null,I=Fa(a,(()=>O((async()=>{await f();const a=await(async()=>Z(h(await p(la(o,(async([a,t,e],n)=>[a,await C(n,t,e)]))),(a=>!ra(a[1])))))(),t=await(async()=>w?(await C(y,R))[L]:{})();return ra(a)&&l(t)?void 0:[a,t]}))),((a,t)=>O((async()=>{if(await f(),l(t)){const[t,e]=a();await b(t),await D(e)}else await b(t[0],!0),await D(t[1],!0)}))),e,n,s,r,{[E]:()=>v,destroy:async()=>(await I.stopAutoPersisting(),i(),I)},0,v);return I},Ya=(a,n,s,r,o,l,w,y,g,v,p="getDb",E)=>{let N,m,$;const f=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,l),[h,C,T,b]=(a=>{const e=(a=>aa(Da,u(a)?{[Aa]:a}:a??{}))(a),n=e[$a];if(e.mode==Ea){const a=e[Aa]??t;return[1,n,[a,e[Na]??R,e[ma]??pa],da(a)]}const{tables:{load:s={},save:r={}}={},values:o={}}=e,c=d(sa(aa(Ia,o)),0,ia(Ia)),l=c[2],w=da(l),y=da(l),g=Sa(s,{[ha]:null,[fa]:R,[ba]:i},ha,(a=>O(y,a)),(a=>ga(w,a))),v=Sa(r,{[Ca]:null,[fa]:R,[Ta]:0,[Oa]:0,[ba]:null},Ca,((a,t)=>O(y,t)),((a,t)=>ga(w,t)));var p;return p=(a,t)=>t[4]??=ca(g,t[0])?.[2]??i,I(v,((a,t)=>p(0,a))),[0,n,[g,v,c],w]})(n);return(h?Ba:Ja)(a,f,(a=>{let t;const e=()=>t=setInterval((()=>A((async()=>{const[{d:t,s:e,c:n}]=await f(P+` ${Y} d,${k} s,TOTAL_CHANGES() c FROM ${J}${Y} JOIN ${J}${k}`);t==N&&e==m&&n==$||(null!=N&&a(),N=t,m=e,$=n)}))),1e3*C),n=()=>{N=m=$=null,c(t)},s=r((t=>{b.has(t)&&(n(),a(),e())}));return e(),()=>{n(),o(s)}}),(a=>a()),w,y,g,T,D(b),(async(a,t)=>await a(P+` t.name tn,c.name cn FROM ${x}list()t,${x}info(t.name)c ${M} t.schema='main'AND t.type IN('table','view')AND t.name IN(${H(t)})ORDER BY t.name,c.name`,t)),v,p,e,E,(a=>!0===a?1:!1===a?0:a),void 0)},ka="change",xa=(a,t,e,n,s)=>Ya(a,e,(async(a,e=[])=>{return await(n=(n,s)=>t.all(a,e,((a,t)=>a?s(a):n(t))),new o(n));var n}),(a=>{const e=(t,e,n)=>a(n);return t.on(ka,e),e}),(a=>t.off(ka,a)),n,s,v,3,t);export{xa as createSqlite3Persister};
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=clearInterval,l=a=>null==a,w=(a,t,e)=>l(a)?e?.():t(a),u=t=>a(t)==s,y=a=>Array.isArray(a),d=(a,t,e)=>a.slice(t,e),g=a=>a.length,v=()=>{},p=async a=>o.all(a),E=a=>{throw Error(a)},A=async(a,t,e)=>{try{return await a()}catch(a){t?.(a)}},N=(a,t)=>a.forEach(t),m=(a,t="")=>a.join(t),$=(a,t)=>a.map(t),f=a=>0==g(a),h=(a,t)=>a.filter(t),C=(a,...t)=>a.push(...t),T=a=>a.shift(),O=(a,t)=>a?.has(t)??!1,b=a=>l(a)||0==(a=>a?.size??0)(a),D=a=>[...a?.values()??[]],I=(a,t)=>a?.forEach(t),S=(a,t)=>a?.delete(t),L="_",R="_id",P="SELECT",M="WHERE",_="TABLE",F="ALTER "+_,U="FROM",j="DELETE "+U,B=P+"*"+U,J="pragma_",Y="data_version",k="schema_version",x="pragma_table_",z="CREATE "+_,G=a=>m($(((a,t="",e)=>a.split(t,e))(a,"."),a=>`"${r(a,/"/g,'""')}"`),"."),H=(a,t=[1])=>m($(a,()=>"$"+t[0]++),n),K=(a,t=i)=>M+`(${r(t,"$tableName",G(a))})`,Q=Object,V=a=>Q.getPrototypeOf(a),W=Q.entries,X=Q.keys,q=Q.freeze,Z=(a=[])=>Q.fromEntries(a),aa=(...a)=>Q.assign({},...a),ta=(a,t)=>(delete a[t],a),ea=(a,t)=>$(W(a),([a,e])=>t(e,a)),na=(a,t)=>Z(ea(a,(a,e)=>[e,t(a,e)])),sa=a=>Q.values(a),ia=a=>g(X(a)),ra=a=>(a=>!l(a)&&w(V(a),a=>a==Q.prototype||l(V(a)),()=>!0))(a)&&0==ia(a),oa=a=>new Map(a),ca=(a,t)=>a?.get(t),la=(a,t)=>$([...a?.entries()??[]],([a,e])=>t(e,a)),wa=(a,t,e)=>l(e)?(S(a,t),a):a?.set(t,e),ua=(a,t,e,n)=>(O(a,t)?n?.(ca(a,t)):wa(a,t,e()),ca(a,t)),ya=(a,t,e,n,s=0)=>w((e?ua:ca)(a,t[s],s>g(t)-2?e:oa),i=>{if(s>g(t)-2)return n?.(i)&&wa(a,t[s]),i;const r=ya(i,t,e,n,s+1);return b(i)&&wa(a,t[s]),r}),da=a=>new Set(y(a)||l(a)?a:[a]),ga=(a,t)=>a?.add(t),va="ColumnName",pa="store",Ea="json",Aa=pa+"TableName",Na=pa+"Id"+va,ma=pa+va,$a="autoLoadIntervalSeconds",fa="rowId"+va,ha="tableId",Ca="tableName",Ta="deleteEmptyColumns",Oa="deleteEmptyTable",ba="condition",Da={mode:Ea,[$a]:1},Ia={load:0,save:0,[Ca]:t+"_values"},Sa=(a,t,e,n,s)=>{const i=oa();return na(a,(a,r)=>{const o=d(sa(aa(t,u(a)?{[e]:a}:a)),0,ia(t));l(o[0])||n(r,o[0])||(s(r,o[0]),wa(i,r,o))}),i},La=JSON.stringify,Ra=JSON.parse,Pa=/^\d+$/,Ma=oa(),_a=oa(),Fa=(a,t,n,s,i,r,o,c={},u=0,d=[])=>{let v,p,m,$=0,f=0,h=0;ua(Ma,d,()=>0),ua(_a,d,()=>[]);const O=oa(),[D,L,R,P,M]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!ra(a)||!ra(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!ra(a)||!ra(t),t.setContent]:E("Store type not supported by this Persister"))(o,a,u),[_,F,U]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?T(a):null)??e+t++,t=>{Pa.test(t)&&g(a)<1e3&&C(a,t)}]})(),s=oa();return[(n,i,r,o=[],c=()=>[])=>{a??=Q;const l=t(1);return wa(s,l,[n,i,r,o,c]),ga(ya(i,r??[e],da),l),l},(t,n,...i)=>N(((a,t=[e])=>{const n=[],s=(a,e)=>e==g(t)?C(n,a):null===t[e]?I(a,a=>s(a,e+1)):N([t[e],null],t=>s(ca(a,t),e+1));return s(a,0),n})(t,n),t=>I(t,t=>ca(s,t)[0](a,...n??[],...i))),a=>w(ca(s,a),([,t,i])=>(ya(t,i??[e],void 0,t=>(S(t,a),b(t)?1:0)),wa(s,a),n(a),i)),t=>w(ca(s,t),([t,,e=[],n,s])=>{const i=(...r)=>{const o=g(r);o==g(e)?t(a,...r,...s(r)):l(e[o])?N(n[o]?.(...r)??[],a=>i(...r,a)):i(...r,e[o])};i()})]})(),j=a=>{a!=$&&($=a,F(O,void 0,$))},B=t=>{(D&&y(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},J=async a=>(2!=$&&(j(1),f++,await K(async()=>{await A(async()=>{const e=await t();y(e)?B(e):a?M(a):E("Content is not an array: "+e)},()=>{a&&M(a)}),j(0)})),Q),Y=async a=>(k(),await J(a),await A(async()=>p=await s(async(a,t)=>{t||a?2!=$&&(j(1),f++,B(t??a),j(0)):await J()}),r),Q),k=async()=>(p&&(await A(()=>i(p),r),p=void 0),Q),x=async a=>(1!=$&&(j(2),h++,await K(async()=>{await A(()=>n(L,a),r),j(0)})),Q),z=async()=>(G(),await x(),m=a.addDidFinishTransactionListener(()=>{const a=R();P(a)&&x(a)}),Q),G=async()=>(m&&(a.delListener(m),m=void 0),Q),H=async(a=!1)=>{const[t,e]=a?[G,k]:[k,G];return await t(),await e(),Q},K=async(...a)=>(C(ca(_a,d),...a),await(async()=>{if(!ca(Ma,d)){for(wa(Ma,d,1);!l(v=T(ca(_a,d)));)await A(v,r);wa(Ma,d,0)}})(),Q),Q={load:J,startAutoLoad:Y,stopAutoLoad:k,isAutoLoading:()=>!l(p),save:x,startAutoSave:z,stopAutoSave:G,isAutoSaving:()=>!l(m),startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[z,Y]:[Y,z];return await e(a),await n(a),Q},stopAutoPersisting:H,getStatus:()=>$,addStatusListener:a=>_(a,O),delListener:t=>(U(t),a),schedule:K,getStore:()=>a,destroy:()=>(ca(_a,d).splice(0,void 0),H()),getStats:()=>({loads:f,saves:h}),...c};return q(Q)},Ua=(a,t,e,s,r,o=ja,c,w)=>{const u=oa();return[async()=>{u.clear(),$(await e(a,t),({tn:a,cn:t})=>ga(ua(u,a,da),t))},async(t,e,n)=>((a,t)=>O(ca(u,a),t))(t,e)?Z(h($(await a(B+G(t)+K(t,n)),a=>[a[e],w?na(ta(a,e),w):ta(a,e)]),([a,t])=>!l(a)&&!ra(t))):{},async(t,e,s,w,y,d=!1,g=i)=>{const v=da();na(s??{},a=>$(X(a??{}),a=>ga(v,a)));const E=D(v);if(!d&&y&&g==i&&f(E)&&O(u,t))return await a("DROP "+_+G(t)),void wa(u,t);const A=ca(u,t),N=da(D(A));if(f(E)||(O(u,t)?await p($([e,...E],async(n,s)=>{S(N,n)||(await a(F+G(t)+"ADD"+G(n)+r),0==s&&await a("CREATE UNIQUE INDEX pk ON "+G(t)+`(${G(e)})`),ga(A,n))})):(await a(z+G(t)+`(${G(e)}${r} PRIMARY KEY${m($(E,a=>n+G(a)+r))});`),wa(u,t,da([e,...E])))),await p([...!d&&w?$(D(N),async n=>{n!=e&&(await a(F+G(t)+"DROP"+G(n)),S(A,n))}):[]]),d)l(s)?await a(j+G(t)+K(t,g)):await p(ea(s,async(n,s)=>{l(n)?await a(j+G(t)+K(t,g)+`AND(${G(e)}=$1)`,[s]):f(E)||await o(a,t,e,X(n),{[s]:c?$(sa(n),c):sa(n)},A)}));else if(f(E))O(u,t)&&await a(j+G(t)+K(t,g));else{const n=h(D(ca(u,t)),a=>a!=e),i={},r=[];na(s??{},(a,t)=>{i[t]=$(n,t=>c?c(a?.[t]):a?.[t]),C(r,t)}),await o(a,t,e,n,i),await a(j+G(t)+K(t,g)+`AND${G(e)}NOT IN(${H(r)})`,r)}},async t=>{let e;return await a("BEGIN"),await A(async()=>e=await t(),s),await a("END"),e}]},ja=async(a,t,e,s,i)=>{const r=[1];await a("INSERT INTO"+G(t)+"("+((...a)=>m($(a,G),n))(e,...s)+")VALUES"+m(ea(i,a=>"($"+r[0]+++","+H(a,r)+")"),n)+"ON CONFLICT("+G(e)+")DO UPDATE SET"+m($(s,a=>G(a)+"=excluded."+G(a)),n),ea(i,(a,t)=>[t,...$(a,a=>a??null)]).flat())},Ba=(a,t,e,n,s,i,r,[o,c,l],w,u,y,d,g,v)=>{const[p,E,A,N]=Ua(t,w,u,s,g,v),m=Fa(a,()=>N(async()=>{return await p(),a=(await E(o,c))[L]?.[l]??"null",Ra(a,(a,t)=>""===t?void 0:t);var a}),a=>N(async()=>{var t;await p(),await A(o,c,{[L]:{[l]:(t=a()??null,La(t,(a,t)=>void 0===t?"":t))}},!0,!0)}),e,n,s,r,{[d]:()=>y,destroy:async()=>(await m.stopAutoPersisting(),i(),m)},0,y);return m},Ja=(a,t,e,n,s,i,r,[o,c,[w,u,y]],d,g,v,E,A,N,m,$)=>{const[f,C,T,O]=Ua(t,d,g,s,A,N,m,$),b=(a,t)=>p(la(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)=>u?await T(y,R,{[L]:a},!0,!0,t):null,I=Fa(a,()=>O(async()=>{await f();const a=await(async()=>Z(h(await p(la(o,async([a,t,e],n)=>[a,await C(n,t,e)])),a=>!ra(a[1]))))(),t=await(async()=>w?(await C(y,R))[L]:{})();return ra(a)&&l(t)?void 0:[a,t]}),(a,t)=>O(async()=>{if(await f(),l(t)){const[t,e]=a();await b(t),await D(e)}else await b(t[0],!0),await D(t[1],!0)}),e,n,s,r,{[E]:()=>v,destroy:async()=>(await I.stopAutoPersisting(),i(),I)},0,v);return I},Ya=(a,n,s,r,o,l,w,y,g,v,p="getDb",E)=>{let N,m,$;const f=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,l),[h,C,T,b]=(a=>{const e=(a=>aa(Da,u(a)?{[Aa]:a}:a??{}))(a),n=e[$a];if(e.mode==Ea){const a=e[Aa]??t;return[1,n,[a,e[Na]??R,e[ma]??pa],da(a)]}const{tables:{load:s={},save:r={}}={},values:o={}}=e,c=d(sa(aa(Ia,o)),0,ia(Ia)),l=c[2],w=da(l),y=da(l),g=Sa(s,{[ha]:null,[fa]:R,[ba]:i},ha,a=>O(y,a),a=>ga(w,a)),v=Sa(r,{[Ca]:null,[fa]:R,[Ta]:0,[Oa]:0,[ba]:null},Ca,(a,t)=>O(y,t),(a,t)=>ga(w,t));var p;return p=(a,t)=>t[4]??=ca(g,t[0])?.[2]??i,I(v,(a,t)=>p(0,a)),[0,n,[g,v,c],w]})(n);return(h?Ba:Ja)(a,f,a=>{let t;const e=()=>t=setInterval(()=>A(async()=>{const[{d:t,s:e,c:n}]=await f(P+` ${Y} d,${k} s,TOTAL_CHANGES() c FROM ${J}${Y} JOIN ${J}${k}`);t==N&&e==m&&n==$||(null!=N&&a(),N=t,m=e,$=n)}),1e3*C),n=()=>{N=m=$=null,c(t)},s=r(t=>{b.has(t)&&(n(),a(),e())});return e(),()=>{n(),o(s)}},a=>a(),w,y,g,T,D(b),async(a,t)=>await a(P+` t.name tn,c.name cn FROM ${x}list()t,${x}info(t.name)c ${M} t.schema='main'AND t.type IN('table','view')AND t.name IN(${H(t)})ORDER BY t.name,c.name`,t),v,p,e,E,a=>!0===a?1:!1===a?0:a,void 0)},ka="change",xa=(a,t,e,n,s)=>Ya(a,e,async(a,e=[])=>{return await(n=(n,s)=>t.all(a,e,(a,t)=>a?s(a):n(t)),new o(n));var n},a=>{const e=(t,e,n)=>a(n);return t.on(ka,e),e},a=>t.off(ka,a),n,s,v,3,t);export{xa as createSqlite3Persister};
@@ -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=clearInterval,l=a=>null==a,w=(a,t,e)=>l(a)?e?.():t(a),u=t=>a(t)==s,y=a=>Array.isArray(a),d=(a,t,e)=>a.slice(t,e),g=a=>a.length,v=()=>{},p=async a=>o.all(a),E=a=>{throw Error(a)},A=async(a,t,e)=>{try{return await a()}catch(a){t?.(a)}},N=(a,t)=>a.forEach(t),m=(a,t="")=>a.join(t),$=(a,t)=>a.map(t),f=a=>0==g(a),h=(a,t)=>a.filter(t),C=(a,...t)=>a.push(...t),T=a=>a.shift(),O=(a,t)=>a?.has(t)??!1,b=a=>l(a)||0==(a=>a?.size??0)(a),D=a=>[...a?.values()??[]],I=(a,t)=>a?.forEach(t),S=(a,t)=>a?.delete(t),L="_",R="_id",P="SELECT",M="WHERE",_="TABLE",F="ALTER "+_,U="FROM",j="DELETE "+U,B=P+"*"+U,J="pragma_",Y="data_version",k="schema_version",x="pragma_table_",z="CREATE "+_,G=a=>m($(((a,t="",e)=>a.split(t,e))(a,"."),(a=>`"${r(a,/"/g,'""')}"`)),"."),H=(a,t=[1])=>m($(a,(()=>"$"+t[0]++)),n),K=(a,t=i)=>M+`(${r(t,"$tableName",G(a))})`,Q=Object,V=a=>Q.getPrototypeOf(a),W=Q.entries,X=Q.keys,q=Q.freeze,Z=(a=[])=>Q.fromEntries(a),aa=(...a)=>Q.assign({},...a),ta=(a,t)=>(delete a[t],a),ea=(a,t)=>$(W(a),(([a,e])=>t(e,a))),na=(a,t)=>Z(ea(a,((a,e)=>[e,t(a,e)]))),sa=a=>Q.values(a),ia=a=>g(X(a)),ra=a=>(a=>!l(a)&&w(V(a),(a=>a==Q.prototype||l(V(a))),(()=>!0)))(a)&&0==ia(a),oa=a=>new Map(a),ca=(a,t)=>a?.get(t),la=(a,t)=>$([...a?.entries()??[]],(([a,e])=>t(e,a))),wa=(a,t,e)=>l(e)?(S(a,t),a):a?.set(t,e),ua=(a,t,e,n)=>(O(a,t)?n?.(ca(a,t)):wa(a,t,e()),ca(a,t)),ya=(a,t,e,n,s=0)=>w((e?ua:ca)(a,t[s],s>g(t)-2?e:oa),(i=>{if(s>g(t)-2)return n?.(i)&&wa(a,t[s]),i;const r=ya(i,t,e,n,s+1);return b(i)&&wa(a,t[s]),r})),da=a=>new Set(y(a)||l(a)?a:[a]),ga=(a,t)=>a?.add(t),va="ColumnName",pa="store",Ea="json",Aa=pa+"TableName",Na=pa+"Id"+va,ma=pa+va,$a="autoLoadIntervalSeconds",fa="rowId"+va,ha="tableId",Ca="tableName",Ta="deleteEmptyColumns",Oa="deleteEmptyTable",ba="condition",Da={mode:Ea,[$a]:1},Ia={load:0,save:0,[Ca]:t+"_values"},Sa=(a,t,e,n,s)=>{const i=oa();return na(a,((a,r)=>{const o=d(sa(aa(t,u(a)?{[e]:a}:a)),0,ia(t));l(o[0])||n(r,o[0])||(s(r,o[0]),wa(i,r,o))})),i},La=JSON.stringify,Ra=JSON.parse,Pa=/^\d+$/,Ma=oa(),_a=oa(),Fa=(a,t,n,s,i,r,o,c={},u=0,d=[])=>{let v,p,m,$=0,f=0,h=0;ua(Ma,d,(()=>0)),ua(_a,d,(()=>[]));const O=oa(),[D,L,R,P,M]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!ra(a)||!ra(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!ra(a)||!ra(t),t.setContent]:E("Store type not supported by this Persister"))(o,a,u),[_,F,U]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?T(a):null)??e+t++,t=>{Pa.test(t)&&g(a)<1e3&&C(a,t)}]})(),s=oa();return[(n,i,r,o=[],c=()=>[])=>{a??=Q;const l=t(1);return wa(s,l,[n,i,r,o,c]),ga(ya(i,r??[e],da),l),l},(t,n,...i)=>N(((a,t=[e])=>{const n=[],s=(a,e)=>e==g(t)?C(n,a):null===t[e]?I(a,(a=>s(a,e+1))):N([t[e],null],(t=>s(ca(a,t),e+1)));return s(a,0),n})(t,n),(t=>I(t,(t=>ca(s,t)[0](a,...n??[],...i))))),a=>w(ca(s,a),(([,t,i])=>(ya(t,i??[e],void 0,(t=>(S(t,a),b(t)?1:0))),wa(s,a),n(a),i))),t=>w(ca(s,t),(([t,,e=[],n,s])=>{const i=(...r)=>{const o=g(r);o==g(e)?t(a,...r,...s(r)):l(e[o])?N(n[o]?.(...r)??[],(a=>i(...r,a))):i(...r,e[o])};i()}))]})(),j=a=>{a!=$&&($=a,F(O,void 0,$))},B=t=>{(D&&y(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},J=async a=>(2!=$&&(j(1),f++,await K((async()=>{await A((async()=>{const e=await t();y(e)?B(e):a?M(a):E("Content is not an array: "+e)}),(()=>{a&&M(a)})),j(0)}))),Q),Y=async a=>(k(),await J(a),await A((async()=>p=await s((async(a,t)=>{t||a?2!=$&&(j(1),f++,B(t??a),j(0)):await J()}))),r),Q),k=async()=>(p&&(await A((()=>i(p)),r),p=void 0),Q),x=async a=>(1!=$&&(j(2),h++,await K((async()=>{await A((()=>n(L,a)),r),j(0)}))),Q),z=async()=>(G(),await x(),m=a.addDidFinishTransactionListener((()=>{const a=R();P(a)&&x(a)})),Q),G=async()=>(m&&(a.delListener(m),m=void 0),Q),H=async(a=!1)=>{const[t,e]=a?[G,k]:[k,G];return await t(),await e(),Q},K=async(...a)=>(C(ca(_a,d),...a),await(async()=>{if(!ca(Ma,d)){for(wa(Ma,d,1);!l(v=T(ca(_a,d)));)await A(v,r);wa(Ma,d,0)}})(),Q),Q={load:J,startAutoLoad:Y,stopAutoLoad:k,isAutoLoading:()=>!l(p),save:x,startAutoSave:z,stopAutoSave:G,isAutoSaving:()=>!l(m),startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[z,Y]:[Y,z];return await e(a),await n(a),Q},stopAutoPersisting:H,getStatus:()=>$,addStatusListener:a=>_(a,O),delListener:t=>(U(t),a),schedule:K,getStore:()=>a,destroy:()=>(ca(_a,d).splice(0,void 0),H()),getStats:()=>({loads:f,saves:h}),...c};return q(Q)},Ua=(a,t,e,s,r,o=ja,c,w)=>{const u=oa();return[async()=>{u.clear(),$(await e(a,t),(({tn:a,cn:t})=>ga(ua(u,a,da),t)))},async(t,e,n)=>((a,t)=>O(ca(u,a),t))(t,e)?Z(h($(await a(B+G(t)+K(t,n)),(a=>[a[e],w?na(ta(a,e),w):ta(a,e)])),(([a,t])=>!l(a)&&!ra(t)))):{},async(t,e,s,w,y,d=!1,g=i)=>{const v=da();na(s??{},(a=>$(X(a??{}),(a=>ga(v,a)))));const E=D(v);if(!d&&y&&g==i&&f(E)&&O(u,t))return await a("DROP "+_+G(t)),void wa(u,t);const A=ca(u,t),N=da(D(A));if(f(E)||(O(u,t)?await p($([e,...E],(async(n,s)=>{S(N,n)||(await a(F+G(t)+"ADD"+G(n)+r),0==s&&await a("CREATE UNIQUE INDEX pk ON "+G(t)+`(${G(e)})`),ga(A,n))}))):(await a(z+G(t)+`(${G(e)}${r} PRIMARY KEY${m($(E,(a=>n+G(a)+r)))});`),wa(u,t,da([e,...E])))),await p([...!d&&w?$(D(N),(async n=>{n!=e&&(await a(F+G(t)+"DROP"+G(n)),S(A,n))})):[]]),d)l(s)?await a(j+G(t)+K(t,g)):await p(ea(s,(async(n,s)=>{l(n)?await a(j+G(t)+K(t,g)+`AND(${G(e)}=$1)`,[s]):f(E)||await o(a,t,e,X(n),{[s]:c?$(sa(n),c):sa(n)},A)})));else if(f(E))O(u,t)&&await a(j+G(t)+K(t,g));else{const n=h(D(ca(u,t)),(a=>a!=e)),i={},r=[];na(s??{},((a,t)=>{i[t]=$(n,(t=>c?c(a?.[t]):a?.[t])),C(r,t)})),await o(a,t,e,n,i),await a(j+G(t)+K(t,g)+`AND${G(e)}NOT IN(${H(r)})`,r)}},async t=>{let e;return await a("BEGIN"),await A((async()=>e=await t()),s),await a("END"),e}]},ja=async(a,t,e,s,i)=>{const r=[1];await a("INSERT INTO"+G(t)+"("+((...a)=>m($(a,G),n))(e,...s)+")VALUES"+m(ea(i,(a=>"($"+r[0]+++","+H(a,r)+")")),n)+"ON CONFLICT("+G(e)+")DO UPDATE SET"+m($(s,(a=>G(a)+"=excluded."+G(a))),n),ea(i,((a,t)=>[t,...$(a,(a=>a??null))])).flat())},Ba=(a,t,e,n,s,i,r,[o,c,l],w,u,y,d,g,v)=>{const[p,E,A,N]=Ua(t,w,u,s,g,v),m=Fa(a,(()=>N((async()=>{return await p(),a=(await E(o,c))[L]?.[l]??"null",Ra(a,((a,t)=>""===t?void 0:t));var a}))),(a=>N((async()=>{var t;await p(),await A(o,c,{[L]:{[l]:(t=a()??null,La(t,((a,t)=>void 0===t?"":t)))}},!0,!0)}))),e,n,s,r,{[d]:()=>y,destroy:async()=>(await m.stopAutoPersisting(),i(),m)},0,y);return m},Ja=(a,t,e,n,s,i,r,[o,c,[w,u,y]],d,g,v,E,A,N,m,$)=>{const[f,C,T,O]=Ua(t,d,g,s,A,N,m,$),b=(a,t)=>p(la(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)=>u?await T(y,R,{[L]:a},!0,!0,t):null,I=Fa(a,(()=>O((async()=>{await f();const a=await(async()=>Z(h(await p(la(o,(async([a,t,e],n)=>[a,await C(n,t,e)]))),(a=>!ra(a[1])))))(),t=await(async()=>w?(await C(y,R))[L]:{})();return ra(a)&&l(t)?void 0:[a,t]}))),((a,t)=>O((async()=>{if(await f(),l(t)){const[t,e]=a();await b(t),await D(e)}else await b(t[0],!0),await D(t[1],!0)}))),e,n,s,r,{[E]:()=>v,destroy:async()=>(await I.stopAutoPersisting(),i(),I)},0,v);return I},Ya=(a,n,s,r,o,l,w,y,g,v,p="getDb",E)=>{let N,m,$;const f=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,l),[h,C,T,b]=(a=>{const e=(a=>aa(Da,u(a)?{[Aa]:a}:a??{}))(a),n=e[$a];if(e.mode==Ea){const a=e[Aa]??t;return[1,n,[a,e[Na]??R,e[ma]??pa],da(a)]}const{tables:{load:s={},save:r={}}={},values:o={}}=e,c=d(sa(aa(Ia,o)),0,ia(Ia)),l=c[2],w=da(l),y=da(l),g=Sa(s,{[ha]:null,[fa]:R,[ba]:i},ha,(a=>O(y,a)),(a=>ga(w,a))),v=Sa(r,{[Ca]:null,[fa]:R,[Ta]:0,[Oa]:0,[ba]:null},Ca,((a,t)=>O(y,t)),((a,t)=>ga(w,t)));var p;return p=(a,t)=>t[4]??=ca(g,t[0])?.[2]??i,I(v,((a,t)=>p(0,a))),[0,n,[g,v,c],w]})(n);return(h?Ba:Ja)(a,f,(a=>{let t;const e=()=>t=setInterval((()=>A((async()=>{const[{d:t,s:e,c:n}]=await f(P+` ${Y} d,${k} s,TOTAL_CHANGES() c FROM ${J}${Y} JOIN ${J}${k}`);t==N&&e==m&&n==$||(null!=N&&a(),N=t,m=e,$=n)}))),1e3*C),n=()=>{N=m=$=null,c(t)},s=r((t=>{b.has(t)&&(n(),a(),e())}));return e(),()=>{n(),o(s)}}),(a=>a()),w,y,g,T,D(b),(async(a,t)=>await a(P+` t.name tn,c.name cn FROM ${x}list()t,${x}info(t.name)c ${M} t.schema='main'AND t.type IN('table','view')AND t.name IN(${H(t)})ORDER BY t.name,c.name`,t)),v,p,e,E,(a=>!0===a?1:!1===a?0:a),void 0)},ka="change",xa=(a,t,e,n,s)=>Ya(a,e,(async(a,e=[])=>{return await(n=(n,s)=>t.all(a,e,((a,t)=>a?s(a):n(t))),new o(n));var n}),(a=>{const e=(t,e,n)=>a(n);return t.on(ka,e),e}),(a=>t.off(ka,a)),n,s,v,3,t);export{xa as createSqlite3Persister};
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=clearInterval,l=a=>null==a,w=(a,t,e)=>l(a)?e?.():t(a),u=t=>a(t)==s,y=a=>Array.isArray(a),d=(a,t,e)=>a.slice(t,e),g=a=>a.length,v=()=>{},p=async a=>o.all(a),E=a=>{throw Error(a)},A=async(a,t,e)=>{try{return await a()}catch(a){t?.(a)}},N=(a,t)=>a.forEach(t),m=(a,t="")=>a.join(t),$=(a,t)=>a.map(t),f=a=>0==g(a),h=(a,t)=>a.filter(t),C=(a,...t)=>a.push(...t),T=a=>a.shift(),O=(a,t)=>a?.has(t)??!1,b=a=>l(a)||0==(a=>a?.size??0)(a),D=a=>[...a?.values()??[]],I=(a,t)=>a?.forEach(t),S=(a,t)=>a?.delete(t),L="_",R="_id",P="SELECT",M="WHERE",_="TABLE",F="ALTER "+_,U="FROM",j="DELETE "+U,B=P+"*"+U,J="pragma_",Y="data_version",k="schema_version",x="pragma_table_",z="CREATE "+_,G=a=>m($(((a,t="",e)=>a.split(t,e))(a,"."),a=>`"${r(a,/"/g,'""')}"`),"."),H=(a,t=[1])=>m($(a,()=>"$"+t[0]++),n),K=(a,t=i)=>M+`(${r(t,"$tableName",G(a))})`,Q=Object,V=a=>Q.getPrototypeOf(a),W=Q.entries,X=Q.keys,q=Q.freeze,Z=(a=[])=>Q.fromEntries(a),aa=(...a)=>Q.assign({},...a),ta=(a,t)=>(delete a[t],a),ea=(a,t)=>$(W(a),([a,e])=>t(e,a)),na=(a,t)=>Z(ea(a,(a,e)=>[e,t(a,e)])),sa=a=>Q.values(a),ia=a=>g(X(a)),ra=a=>(a=>!l(a)&&w(V(a),a=>a==Q.prototype||l(V(a)),()=>!0))(a)&&0==ia(a),oa=a=>new Map(a),ca=(a,t)=>a?.get(t),la=(a,t)=>$([...a?.entries()??[]],([a,e])=>t(e,a)),wa=(a,t,e)=>l(e)?(S(a,t),a):a?.set(t,e),ua=(a,t,e,n)=>(O(a,t)?n?.(ca(a,t)):wa(a,t,e()),ca(a,t)),ya=(a,t,e,n,s=0)=>w((e?ua:ca)(a,t[s],s>g(t)-2?e:oa),i=>{if(s>g(t)-2)return n?.(i)&&wa(a,t[s]),i;const r=ya(i,t,e,n,s+1);return b(i)&&wa(a,t[s]),r}),da=a=>new Set(y(a)||l(a)?a:[a]),ga=(a,t)=>a?.add(t),va="ColumnName",pa="store",Ea="json",Aa=pa+"TableName",Na=pa+"Id"+va,ma=pa+va,$a="autoLoadIntervalSeconds",fa="rowId"+va,ha="tableId",Ca="tableName",Ta="deleteEmptyColumns",Oa="deleteEmptyTable",ba="condition",Da={mode:Ea,[$a]:1},Ia={load:0,save:0,[Ca]:t+"_values"},Sa=(a,t,e,n,s)=>{const i=oa();return na(a,(a,r)=>{const o=d(sa(aa(t,u(a)?{[e]:a}:a)),0,ia(t));l(o[0])||n(r,o[0])||(s(r,o[0]),wa(i,r,o))}),i},La=JSON.stringify,Ra=JSON.parse,Pa=/^\d+$/,Ma=oa(),_a=oa(),Fa=(a,t,n,s,i,r,o,c={},u=0,d=[])=>{let v,p,m,$=0,f=0,h=0;ua(Ma,d,()=>0),ua(_a,d,()=>[]);const O=oa(),[D,L,R,P,M]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!ra(a)||!ra(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!ra(a)||!ra(t),t.setContent]:E("Store type not supported by this Persister"))(o,a,u),[_,F,U]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?T(a):null)??e+t++,t=>{Pa.test(t)&&g(a)<1e3&&C(a,t)}]})(),s=oa();return[(n,i,r,o=[],c=()=>[])=>{a??=Q;const l=t(1);return wa(s,l,[n,i,r,o,c]),ga(ya(i,r??[e],da),l),l},(t,n,...i)=>N(((a,t=[e])=>{const n=[],s=(a,e)=>e==g(t)?C(n,a):null===t[e]?I(a,a=>s(a,e+1)):N([t[e],null],t=>s(ca(a,t),e+1));return s(a,0),n})(t,n),t=>I(t,t=>ca(s,t)[0](a,...n??[],...i))),a=>w(ca(s,a),([,t,i])=>(ya(t,i??[e],void 0,t=>(S(t,a),b(t)?1:0)),wa(s,a),n(a),i)),t=>w(ca(s,t),([t,,e=[],n,s])=>{const i=(...r)=>{const o=g(r);o==g(e)?t(a,...r,...s(r)):l(e[o])?N(n[o]?.(...r)??[],a=>i(...r,a)):i(...r,e[o])};i()})]})(),j=a=>{a!=$&&($=a,F(O,void 0,$))},B=t=>{(D&&y(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},J=async a=>(2!=$&&(j(1),f++,await K(async()=>{await A(async()=>{const e=await t();y(e)?B(e):a?M(a):E("Content is not an array: "+e)},()=>{a&&M(a)}),j(0)})),Q),Y=async a=>(k(),await J(a),await A(async()=>p=await s(async(a,t)=>{t||a?2!=$&&(j(1),f++,B(t??a),j(0)):await J()}),r),Q),k=async()=>(p&&(await A(()=>i(p),r),p=void 0),Q),x=async a=>(1!=$&&(j(2),h++,await K(async()=>{await A(()=>n(L,a),r),j(0)})),Q),z=async()=>(G(),await x(),m=a.addDidFinishTransactionListener(()=>{const a=R();P(a)&&x(a)}),Q),G=async()=>(m&&(a.delListener(m),m=void 0),Q),H=async(a=!1)=>{const[t,e]=a?[G,k]:[k,G];return await t(),await e(),Q},K=async(...a)=>(C(ca(_a,d),...a),await(async()=>{if(!ca(Ma,d)){for(wa(Ma,d,1);!l(v=T(ca(_a,d)));)await A(v,r);wa(Ma,d,0)}})(),Q),Q={load:J,startAutoLoad:Y,stopAutoLoad:k,isAutoLoading:()=>!l(p),save:x,startAutoSave:z,stopAutoSave:G,isAutoSaving:()=>!l(m),startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[z,Y]:[Y,z];return await e(a),await n(a),Q},stopAutoPersisting:H,getStatus:()=>$,addStatusListener:a=>_(a,O),delListener:t=>(U(t),a),schedule:K,getStore:()=>a,destroy:()=>(ca(_a,d).splice(0,void 0),H()),getStats:()=>({loads:f,saves:h}),...c};return q(Q)},Ua=(a,t,e,s,r,o=ja,c,w)=>{const u=oa();return[async()=>{u.clear(),$(await e(a,t),({tn:a,cn:t})=>ga(ua(u,a,da),t))},async(t,e,n)=>((a,t)=>O(ca(u,a),t))(t,e)?Z(h($(await a(B+G(t)+K(t,n)),a=>[a[e],w?na(ta(a,e),w):ta(a,e)]),([a,t])=>!l(a)&&!ra(t))):{},async(t,e,s,w,y,d=!1,g=i)=>{const v=da();na(s??{},a=>$(X(a??{}),a=>ga(v,a)));const E=D(v);if(!d&&y&&g==i&&f(E)&&O(u,t))return await a("DROP "+_+G(t)),void wa(u,t);const A=ca(u,t),N=da(D(A));if(f(E)||(O(u,t)?await p($([e,...E],async(n,s)=>{S(N,n)||(await a(F+G(t)+"ADD"+G(n)+r),0==s&&await a("CREATE UNIQUE INDEX pk ON "+G(t)+`(${G(e)})`),ga(A,n))})):(await a(z+G(t)+`(${G(e)}${r} PRIMARY KEY${m($(E,a=>n+G(a)+r))});`),wa(u,t,da([e,...E])))),await p([...!d&&w?$(D(N),async n=>{n!=e&&(await a(F+G(t)+"DROP"+G(n)),S(A,n))}):[]]),d)l(s)?await a(j+G(t)+K(t,g)):await p(ea(s,async(n,s)=>{l(n)?await a(j+G(t)+K(t,g)+`AND(${G(e)}=$1)`,[s]):f(E)||await o(a,t,e,X(n),{[s]:c?$(sa(n),c):sa(n)},A)}));else if(f(E))O(u,t)&&await a(j+G(t)+K(t,g));else{const n=h(D(ca(u,t)),a=>a!=e),i={},r=[];na(s??{},(a,t)=>{i[t]=$(n,t=>c?c(a?.[t]):a?.[t]),C(r,t)}),await o(a,t,e,n,i),await a(j+G(t)+K(t,g)+`AND${G(e)}NOT IN(${H(r)})`,r)}},async t=>{let e;return await a("BEGIN"),await A(async()=>e=await t(),s),await a("END"),e}]},ja=async(a,t,e,s,i)=>{const r=[1];await a("INSERT INTO"+G(t)+"("+((...a)=>m($(a,G),n))(e,...s)+")VALUES"+m(ea(i,a=>"($"+r[0]+++","+H(a,r)+")"),n)+"ON CONFLICT("+G(e)+")DO UPDATE SET"+m($(s,a=>G(a)+"=excluded."+G(a)),n),ea(i,(a,t)=>[t,...$(a,a=>a??null)]).flat())},Ba=(a,t,e,n,s,i,r,[o,c,l],w,u,y,d,g,v)=>{const[p,E,A,N]=Ua(t,w,u,s,g,v),m=Fa(a,()=>N(async()=>{return await p(),a=(await E(o,c))[L]?.[l]??"null",Ra(a,(a,t)=>""===t?void 0:t);var a}),a=>N(async()=>{var t;await p(),await A(o,c,{[L]:{[l]:(t=a()??null,La(t,(a,t)=>void 0===t?"":t))}},!0,!0)}),e,n,s,r,{[d]:()=>y,destroy:async()=>(await m.stopAutoPersisting(),i(),m)},0,y);return m},Ja=(a,t,e,n,s,i,r,[o,c,[w,u,y]],d,g,v,E,A,N,m,$)=>{const[f,C,T,O]=Ua(t,d,g,s,A,N,m,$),b=(a,t)=>p(la(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)=>u?await T(y,R,{[L]:a},!0,!0,t):null,I=Fa(a,()=>O(async()=>{await f();const a=await(async()=>Z(h(await p(la(o,async([a,t,e],n)=>[a,await C(n,t,e)])),a=>!ra(a[1]))))(),t=await(async()=>w?(await C(y,R))[L]:{})();return ra(a)&&l(t)?void 0:[a,t]}),(a,t)=>O(async()=>{if(await f(),l(t)){const[t,e]=a();await b(t),await D(e)}else await b(t[0],!0),await D(t[1],!0)}),e,n,s,r,{[E]:()=>v,destroy:async()=>(await I.stopAutoPersisting(),i(),I)},0,v);return I},Ya=(a,n,s,r,o,l,w,y,g,v,p="getDb",E)=>{let N,m,$;const f=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,l),[h,C,T,b]=(a=>{const e=(a=>aa(Da,u(a)?{[Aa]:a}:a??{}))(a),n=e[$a];if(e.mode==Ea){const a=e[Aa]??t;return[1,n,[a,e[Na]??R,e[ma]??pa],da(a)]}const{tables:{load:s={},save:r={}}={},values:o={}}=e,c=d(sa(aa(Ia,o)),0,ia(Ia)),l=c[2],w=da(l),y=da(l),g=Sa(s,{[ha]:null,[fa]:R,[ba]:i},ha,a=>O(y,a),a=>ga(w,a)),v=Sa(r,{[Ca]:null,[fa]:R,[Ta]:0,[Oa]:0,[ba]:null},Ca,(a,t)=>O(y,t),(a,t)=>ga(w,t));var p;return p=(a,t)=>t[4]??=ca(g,t[0])?.[2]??i,I(v,(a,t)=>p(0,a)),[0,n,[g,v,c],w]})(n);return(h?Ba:Ja)(a,f,a=>{let t;const e=()=>t=setInterval(()=>A(async()=>{const[{d:t,s:e,c:n}]=await f(P+` ${Y} d,${k} s,TOTAL_CHANGES() c FROM ${J}${Y} JOIN ${J}${k}`);t==N&&e==m&&n==$||(null!=N&&a(),N=t,m=e,$=n)}),1e3*C),n=()=>{N=m=$=null,c(t)},s=r(t=>{b.has(t)&&(n(),a(),e())});return e(),()=>{n(),o(s)}},a=>a(),w,y,g,T,D(b),async(a,t)=>await a(P+` t.name tn,c.name cn FROM ${x}list()t,${x}info(t.name)c ${M} t.schema='main'AND t.type IN('table','view')AND t.name IN(${H(t)})ORDER BY t.name,c.name`,t),v,p,e,E,a=>!0===a?1:!1===a?0:a,void 0)},ka="change",xa=(a,t,e,n,s)=>Ya(a,e,async(a,e=[])=>{return await(n=(n,s)=>t.all(a,e,(a,t)=>a?s(a):n(t)),new o(n));var n},a=>{const e=(t,e,n)=>a(n);return t.on(ka,e),e},a=>t.off(ka,a),n,s,v,3,t);export{xa as createSqlite3Persister};
@@ -1 +1 @@
1
- import{Map as t}from"yjs";const e="t",a="v",n=t=>null==t,s=(t,e,a)=>n(t)?a?.():e(t),o=t=>Array.isArray(t),r=t=>t.length,i=t=>{throw Error(t)},c=async(t,e,a)=>{try{return await t()}catch(t){e?.(t)}},l=(t,e)=>t.forEach(e),g=(t,...e)=>t.push(...e),u=t=>t.shift(),d=t=>n(t)||0==(t=>t?.size??0)(t),y=(t,e)=>t?.forEach(e),p=(t,e)=>t?.delete(e),w=Object,v=t=>w.getPrototypeOf(t),h=w.entries,f=w.keys,S=w.freeze,C=(t=[])=>w.fromEntries(t),b=(t,e)=>e in t,A=(t,e)=>C(((t,e)=>((t,e)=>t.map(e))(h(t),(([t,a])=>e(a,t))))(t,((t,a)=>[a,e(t,a)]))),M=t=>(t=>!n(t)&&s(v(t),(t=>t==w.prototype||n(v(t))),(()=>!0)))(t)&&0==(t=>r(f(t)))(t),O=(t,e,a)=>(b(t,e)||(t[e]=a()),t[e]),L=t=>new Map(t),J=(t,e)=>t?.get(e),N=(t,e)=>y(t,((t,a)=>e(a,t))),z=(t,e,a)=>n(a)?(p(t,e),t):t?.set(e,a),D=(t,e,a,n)=>{var s,o;return s=t,o=e,s?.has(o)?n?.(J(t,e)):z(t,e,a()),J(t,e)},E=(t,e,a,n,o=0)=>s((a?D:J)(t,e[o],o>r(e)-2?a:L),(s=>{if(o>r(e)-2)return n?.(s)&&z(t,e[o]),s;const i=E(s,e,a,n,o+1);return d(s)&&z(t,e[o]),i})),m=/^\d+$/,P=t=>new Set(o(t)||n(t)?t:[t]),T=L(),j=L(),k=(t,e,a,w,v,h,f,C={},b=0,A=[])=>{let O,N,k,x=0,F=0,Y=0;D(T,A,(()=>0)),D(j,A,(()=>[]));const $=L(),[q,B,G,H,I]=((t=1,e,a)=>1!=t&&e.isMergeable()?[1,e.getMergeableContent,()=>e.getTransactionMergeableChanges(!a),([[t],[e]])=>!M(t)||!M(e),e.setDefaultContent]:2!=t?[0,e.getContent,e.getTransactionChanges,([t,e])=>!M(t)||!M(e),e.setContent]:i("Store type not supported by this Persister"))(f,t,b),[K,Q,R]=(()=>{let t;const[e,a]=(()=>{const t=[];let e=0;return[a=>(a?u(t):null)??""+e++,e=>{m.test(e)&&r(t)<1e3&&g(t,e)}]})(),o=L();return[(a,n,s,r=[],i=()=>[])=>{t??=st;const c=e(1);var l,g;return z(o,c,[a,n,s,r,i]),l=E(n,s??[""],P),g=c,l?.add(g),c},(e,a,...n)=>l(((t,e=[""])=>{const a=[],n=(t,s)=>s==r(e)?g(a,t):null===e[s]?y(t,(t=>n(t,s+1))):l([e[s],null],(e=>n(J(t,e),s+1)));return n(t,0),a})(e,a),(e=>y(e,(e=>J(o,e)[0](t,...a??[],...n))))),t=>s(J(o,t),(([,e,n])=>(E(e,n??[""],void 0,(e=>(p(e,t),d(e)?1:0))),z(o,t),a(t),n))),e=>s(J(o,e),(([e,,a=[],s,o])=>{const i=(...c)=>{const g=r(c);g==r(a)?e(t,...c,...o(c)):n(a[g])?l(s[g]?.(...c)??[],(t=>i(...c,t))):i(...c,a[g])};i()}))]})(),U=t=>{t!=x&&(x=t,Q($,void 0,x))},V=e=>{(q&&o(e?.[0])?1===e?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===e?.[2]?t.applyChanges:t.setContent)(e)},W=async t=>(2!=x&&(U(1),F++,await nt((async()=>{await c((async()=>{const a=await e();o(a)?V(a):t?I(t):i("Content is not an array: "+a)}),(()=>{t&&I(t)})),U(0)}))),st),X=async t=>(Z(),await W(t),await c((async()=>N=await w((async(t,e)=>{e||t?2!=x&&(U(1),F++,V(e??t),U(0)):await W()}))),h),st),Z=async()=>(N&&(await c((()=>v(N)),h),N=void 0),st),_=async t=>(1!=x&&(U(2),Y++,await nt((async()=>{await c((()=>a(B,t)),h),U(0)}))),st),tt=async()=>(et(),await _(),k=t.addDidFinishTransactionListener((()=>{const t=G();H(t)&&_(t)})),st),et=async()=>(k&&(t.delListener(k),k=void 0),st),at=async(t=!1)=>{const[e,a]=t?[et,Z]:[Z,et];return await e(),await a(),st},nt=async(...t)=>(g(J(j,A),...t),await(async()=>{if(!J(T,A)){for(z(T,A,1);!n(O=u(J(j,A)));)await c(O,h);z(T,A,0)}})(),st),st={load:W,startAutoLoad:X,stopAutoLoad:Z,isAutoLoading:()=>!n(N),save:_,startAutoSave:tt,stopAutoSave:et,isAutoSaving:()=>!n(k),startAutoPersisting:async(t,e=!1)=>{const[a,n]=e?[tt,X]:[X,tt];return await a(t),await n(t),st},stopAutoPersisting:at,getStatus:()=>x,addStatusListener:t=>K(t,$),delListener:e=>(R(e),t),schedule:nt,getStore:()=>t,destroy:()=>(J(j,A).splice(0,void 0),at()),getStats:()=>({loads:F,saves:Y}),...C};return S(st)},x="delete",F=t=>[t.get(e),t.get(a)],Y=(e,a,s,o)=>{const r=n(a)?e:e.get(a)??e.set(a,new t);let i;return A(s,((t,e)=>{o(r,e,t)&&(i=1)})),r.forEach(((t,e)=>{b(s,e)||(r.delete(e),i=1)})),n(a)||r.size||e.delete(a),i},$=(o,i,c="tinybase",g)=>{const d=i.getMap(c);return k(o,(async()=>d.size?[d.get(e).toJSON(),d.get(a).toJSON()]:void 0),(async(o,r)=>i.transact((()=>((o,r,i)=>{o.size||(o.set(e,new t),o.set(a,new t));const[c,l]=F(o),g=()=>{u=1};let u=1;if(s(i,(([t,e])=>{u=0,A(t,((t,e)=>u?0:n(t)?c.delete(e):s(c.get(e),(e=>A(t,((t,a)=>u?0:n(t)?e.delete(a):s(e.get(a),(e=>A(t,((t,a)=>n(t)?e.delete(a):e.set(a,t)))),g)))),g))),A(e,((t,e)=>u?0:n(t)?l.delete(e):l.set(e,t)))})),u){const[t,e]=r();Y(c,void 0,t,((t,e,a)=>Y(c,e,a,((t,e,a)=>Y(t,e,a,((t,e,a)=>{if(t.get(e)!==a)return t.set(e,a),1})))))),Y(l,void 0,e,((t,e,a)=>{l.get(e)!==a&&l.set(e,a)}))}})(d,o,r)))),(t=>{const n=n=>t(void 0,((t,n)=>{if(1==r(n)&&(o=n[0].path,0==r(o)))return[t.get(e).toJSON(),t.get(a).toJSON(),1];var o;const[i,c]=F(t),g={},d={};return l(n,(({path:t,changes:{keys:a}})=>u(t)==e?s(u(t),(e=>{const n=O(g,e,C),o=i.get(e);s(u(t),(t=>{const e=O(n,t,C),s=o.get(t);N(a,((t,{action:a})=>e[t]=a==x?null:s.get(t)))}),(()=>N(a,((t,{action:e})=>n[t]=e==x?null:o.get(t)?.toJSON()))))}),(()=>N(a,((t,{action:e})=>g[t]=e==x?null:i.get(t)?.toJSON())))):N(a,((t,{action:e})=>d[t]=e==x?null:c.get(t))))),[g,d,1]})(d,n));return d.observeDeep(n),n}),(t=>{d.unobserveDeep(t)}),g,1,{getYDoc:()=>i})};export{$ as createYjsPersister};
1
+ import{Map as t}from"yjs";const e="t",a="v",n=t=>null==t,s=(t,e,a)=>n(t)?a?.():e(t),o=t=>Array.isArray(t),r=t=>t.length,i=t=>{throw Error(t)},c=async(t,e,a)=>{try{return await t()}catch(t){e?.(t)}},l=(t,e)=>t.forEach(e),g=(t,...e)=>t.push(...e),u=t=>t.shift(),d=t=>n(t)||0==(t=>t?.size??0)(t),y=(t,e)=>t?.forEach(e),p=(t,e)=>t?.delete(e),w=Object,v=t=>w.getPrototypeOf(t),h=w.entries,f=w.keys,S=w.freeze,C=(t=[])=>w.fromEntries(t),b=(t,e)=>e in t,A=(t,e)=>C(((t,e)=>((t,e)=>t.map(e))(h(t),([t,a])=>e(a,t)))(t,(t,a)=>[a,e(t,a)])),M=t=>(t=>!n(t)&&s(v(t),t=>t==w.prototype||n(v(t)),()=>!0))(t)&&0==(t=>r(f(t)))(t),O=(t,e,a)=>(b(t,e)||(t[e]=a()),t[e]),L=t=>new Map(t),J=(t,e)=>t?.get(e),N=(t,e)=>y(t,(t,a)=>e(a,t)),z=(t,e,a)=>n(a)?(p(t,e),t):t?.set(e,a),D=(t,e,a,n)=>{var s,o;return s=t,o=e,s?.has(o)?n?.(J(t,e)):z(t,e,a()),J(t,e)},E=(t,e,a,n,o=0)=>s((a?D:J)(t,e[o],o>r(e)-2?a:L),s=>{if(o>r(e)-2)return n?.(s)&&z(t,e[o]),s;const i=E(s,e,a,n,o+1);return d(s)&&z(t,e[o]),i}),m=/^\d+$/,P=t=>new Set(o(t)||n(t)?t:[t]),T=L(),j=L(),k=(t,e,a,w,v,h,f,C={},b=0,A=[])=>{let O,N,k,x=0,F=0,Y=0;D(T,A,()=>0),D(j,A,()=>[]);const $=L(),[q,B,G,H,I]=((t=1,e,a)=>1!=t&&e.isMergeable()?[1,e.getMergeableContent,()=>e.getTransactionMergeableChanges(!a),([[t],[e]])=>!M(t)||!M(e),e.setDefaultContent]:2!=t?[0,e.getContent,e.getTransactionChanges,([t,e])=>!M(t)||!M(e),e.setContent]:i("Store type not supported by this Persister"))(f,t,b),[K,Q,R]=(()=>{let t;const[e,a]=(()=>{const t=[];let e=0;return[a=>(a?u(t):null)??""+e++,e=>{m.test(e)&&r(t)<1e3&&g(t,e)}]})(),o=L();return[(a,n,s,r=[],i=()=>[])=>{t??=st;const c=e(1);var l,g;return z(o,c,[a,n,s,r,i]),l=E(n,s??[""],P),g=c,l?.add(g),c},(e,a,...n)=>l(((t,e=[""])=>{const a=[],n=(t,s)=>s==r(e)?g(a,t):null===e[s]?y(t,t=>n(t,s+1)):l([e[s],null],e=>n(J(t,e),s+1));return n(t,0),a})(e,a),e=>y(e,e=>J(o,e)[0](t,...a??[],...n))),t=>s(J(o,t),([,e,n])=>(E(e,n??[""],void 0,e=>(p(e,t),d(e)?1:0)),z(o,t),a(t),n)),e=>s(J(o,e),([e,,a=[],s,o])=>{const i=(...c)=>{const g=r(c);g==r(a)?e(t,...c,...o(c)):n(a[g])?l(s[g]?.(...c)??[],t=>i(...c,t)):i(...c,a[g])};i()})]})(),U=t=>{t!=x&&(x=t,Q($,void 0,x))},V=e=>{(q&&o(e?.[0])?1===e?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===e?.[2]?t.applyChanges:t.setContent)(e)},W=async t=>(2!=x&&(U(1),F++,await nt(async()=>{await c(async()=>{const a=await e();o(a)?V(a):t?I(t):i("Content is not an array: "+a)},()=>{t&&I(t)}),U(0)})),st),X=async t=>(Z(),await W(t),await c(async()=>N=await w(async(t,e)=>{e||t?2!=x&&(U(1),F++,V(e??t),U(0)):await W()}),h),st),Z=async()=>(N&&(await c(()=>v(N),h),N=void 0),st),_=async t=>(1!=x&&(U(2),Y++,await nt(async()=>{await c(()=>a(B,t),h),U(0)})),st),tt=async()=>(et(),await _(),k=t.addDidFinishTransactionListener(()=>{const t=G();H(t)&&_(t)}),st),et=async()=>(k&&(t.delListener(k),k=void 0),st),at=async(t=!1)=>{const[e,a]=t?[et,Z]:[Z,et];return await e(),await a(),st},nt=async(...t)=>(g(J(j,A),...t),await(async()=>{if(!J(T,A)){for(z(T,A,1);!n(O=u(J(j,A)));)await c(O,h);z(T,A,0)}})(),st),st={load:W,startAutoLoad:X,stopAutoLoad:Z,isAutoLoading:()=>!n(N),save:_,startAutoSave:tt,stopAutoSave:et,isAutoSaving:()=>!n(k),startAutoPersisting:async(t,e=!1)=>{const[a,n]=e?[tt,X]:[X,tt];return await a(t),await n(t),st},stopAutoPersisting:at,getStatus:()=>x,addStatusListener:t=>K(t,$),delListener:e=>(R(e),t),schedule:nt,getStore:()=>t,destroy:()=>(J(j,A).splice(0,void 0),at()),getStats:()=>({loads:F,saves:Y}),...C};return S(st)},x="delete",F=t=>[t.get(e),t.get(a)],Y=(e,a,s,o)=>{const r=n(a)?e:e.get(a)??e.set(a,new t);let i;return A(s,(t,e)=>{o(r,e,t)&&(i=1)}),r.forEach((t,e)=>{b(s,e)||(r.delete(e),i=1)}),n(a)||r.size||e.delete(a),i},$=(o,i,c="tinybase",g)=>{const d=i.getMap(c);return k(o,async()=>d.size?[d.get(e).toJSON(),d.get(a).toJSON()]:void 0,async(o,r)=>i.transact(()=>((o,r,i)=>{o.size||(o.set(e,new t),o.set(a,new t));const[c,l]=F(o),g=()=>{u=1};let u=1;if(s(i,([t,e])=>{u=0,A(t,(t,e)=>u?0:n(t)?c.delete(e):s(c.get(e),e=>A(t,(t,a)=>u?0:n(t)?e.delete(a):s(e.get(a),e=>A(t,(t,a)=>n(t)?e.delete(a):e.set(a,t)),g)),g)),A(e,(t,e)=>u?0:n(t)?l.delete(e):l.set(e,t))}),u){const[t,e]=r();Y(c,void 0,t,(t,e,a)=>Y(c,e,a,(t,e,a)=>Y(t,e,a,(t,e,a)=>{if(t.get(e)!==a)return t.set(e,a),1}))),Y(l,void 0,e,(t,e,a)=>{l.get(e)!==a&&l.set(e,a)})}})(d,o,r)),t=>{const n=n=>t(void 0,((t,n)=>{if(1==r(n)&&(o=n[0].path,0==r(o)))return[t.get(e).toJSON(),t.get(a).toJSON(),1];var o;const[i,c]=F(t),g={},d={};return l(n,({path:t,changes:{keys:a}})=>u(t)==e?s(u(t),e=>{const n=O(g,e,C),o=i.get(e);s(u(t),t=>{const e=O(n,t,C),s=o.get(t);N(a,(t,{action:a})=>e[t]=a==x?null:s.get(t))},()=>N(a,(t,{action:e})=>n[t]=e==x?null:o.get(t)?.toJSON()))},()=>N(a,(t,{action:e})=>g[t]=e==x?null:i.get(t)?.toJSON())):N(a,(t,{action:e})=>d[t]=e==x?null:c.get(t))),[g,d,1]})(d,n));return d.observeDeep(n),n},t=>{d.unobserveDeep(t)},g,1,{getYDoc:()=>i})};export{$ as createYjsPersister};
@@ -1 +1 @@
1
- import{Map as t}from"yjs";const e="t",a="v",n=t=>null==t,s=(t,e,a)=>n(t)?a?.():e(t),o=t=>Array.isArray(t),r=t=>t.length,i=t=>{throw Error(t)},c=async(t,e,a)=>{try{return await t()}catch(t){e?.(t)}},l=(t,e)=>t.forEach(e),g=(t,...e)=>t.push(...e),u=t=>t.shift(),d=t=>n(t)||0==(t=>t?.size??0)(t),y=(t,e)=>t?.forEach(e),p=(t,e)=>t?.delete(e),w=Object,v=t=>w.getPrototypeOf(t),h=w.entries,f=w.keys,S=w.freeze,C=(t=[])=>w.fromEntries(t),b=(t,e)=>e in t,A=(t,e)=>C(((t,e)=>((t,e)=>t.map(e))(h(t),(([t,a])=>e(a,t))))(t,((t,a)=>[a,e(t,a)]))),M=t=>(t=>!n(t)&&s(v(t),(t=>t==w.prototype||n(v(t))),(()=>!0)))(t)&&0==(t=>r(f(t)))(t),O=(t,e,a)=>(b(t,e)||(t[e]=a()),t[e]),L=t=>new Map(t),J=(t,e)=>t?.get(e),N=(t,e)=>y(t,((t,a)=>e(a,t))),z=(t,e,a)=>n(a)?(p(t,e),t):t?.set(e,a),D=(t,e,a,n)=>{var s,o;return s=t,o=e,s?.has(o)?n?.(J(t,e)):z(t,e,a()),J(t,e)},E=(t,e,a,n,o=0)=>s((a?D:J)(t,e[o],o>r(e)-2?a:L),(s=>{if(o>r(e)-2)return n?.(s)&&z(t,e[o]),s;const i=E(s,e,a,n,o+1);return d(s)&&z(t,e[o]),i})),m=/^\d+$/,P=t=>new Set(o(t)||n(t)?t:[t]),T=L(),j=L(),k=(t,e,a,w,v,h,f,C={},b=0,A=[])=>{let O,N,k,x=0,F=0,Y=0;D(T,A,(()=>0)),D(j,A,(()=>[]));const $=L(),[q,B,G,H,I]=((t=1,e,a)=>1!=t&&e.isMergeable()?[1,e.getMergeableContent,()=>e.getTransactionMergeableChanges(!a),([[t],[e]])=>!M(t)||!M(e),e.setDefaultContent]:2!=t?[0,e.getContent,e.getTransactionChanges,([t,e])=>!M(t)||!M(e),e.setContent]:i("Store type not supported by this Persister"))(f,t,b),[K,Q,R]=(()=>{let t;const[e,a]=(()=>{const t=[];let e=0;return[a=>(a?u(t):null)??""+e++,e=>{m.test(e)&&r(t)<1e3&&g(t,e)}]})(),o=L();return[(a,n,s,r=[],i=()=>[])=>{t??=st;const c=e(1);var l,g;return z(o,c,[a,n,s,r,i]),l=E(n,s??[""],P),g=c,l?.add(g),c},(e,a,...n)=>l(((t,e=[""])=>{const a=[],n=(t,s)=>s==r(e)?g(a,t):null===e[s]?y(t,(t=>n(t,s+1))):l([e[s],null],(e=>n(J(t,e),s+1)));return n(t,0),a})(e,a),(e=>y(e,(e=>J(o,e)[0](t,...a??[],...n))))),t=>s(J(o,t),(([,e,n])=>(E(e,n??[""],void 0,(e=>(p(e,t),d(e)?1:0))),z(o,t),a(t),n))),e=>s(J(o,e),(([e,,a=[],s,o])=>{const i=(...c)=>{const g=r(c);g==r(a)?e(t,...c,...o(c)):n(a[g])?l(s[g]?.(...c)??[],(t=>i(...c,t))):i(...c,a[g])};i()}))]})(),U=t=>{t!=x&&(x=t,Q($,void 0,x))},V=e=>{(q&&o(e?.[0])?1===e?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===e?.[2]?t.applyChanges:t.setContent)(e)},W=async t=>(2!=x&&(U(1),F++,await nt((async()=>{await c((async()=>{const a=await e();o(a)?V(a):t?I(t):i("Content is not an array: "+a)}),(()=>{t&&I(t)})),U(0)}))),st),X=async t=>(Z(),await W(t),await c((async()=>N=await w((async(t,e)=>{e||t?2!=x&&(U(1),F++,V(e??t),U(0)):await W()}))),h),st),Z=async()=>(N&&(await c((()=>v(N)),h),N=void 0),st),_=async t=>(1!=x&&(U(2),Y++,await nt((async()=>{await c((()=>a(B,t)),h),U(0)}))),st),tt=async()=>(et(),await _(),k=t.addDidFinishTransactionListener((()=>{const t=G();H(t)&&_(t)})),st),et=async()=>(k&&(t.delListener(k),k=void 0),st),at=async(t=!1)=>{const[e,a]=t?[et,Z]:[Z,et];return await e(),await a(),st},nt=async(...t)=>(g(J(j,A),...t),await(async()=>{if(!J(T,A)){for(z(T,A,1);!n(O=u(J(j,A)));)await c(O,h);z(T,A,0)}})(),st),st={load:W,startAutoLoad:X,stopAutoLoad:Z,isAutoLoading:()=>!n(N),save:_,startAutoSave:tt,stopAutoSave:et,isAutoSaving:()=>!n(k),startAutoPersisting:async(t,e=!1)=>{const[a,n]=e?[tt,X]:[X,tt];return await a(t),await n(t),st},stopAutoPersisting:at,getStatus:()=>x,addStatusListener:t=>K(t,$),delListener:e=>(R(e),t),schedule:nt,getStore:()=>t,destroy:()=>(J(j,A).splice(0,void 0),at()),getStats:()=>({loads:F,saves:Y}),...C};return S(st)},x="delete",F=t=>[t.get(e),t.get(a)],Y=(e,a,s,o)=>{const r=n(a)?e:e.get(a)??e.set(a,new t);let i;return A(s,((t,e)=>{o(r,e,t)&&(i=1)})),r.forEach(((t,e)=>{b(s,e)||(r.delete(e),i=1)})),n(a)||r.size||e.delete(a),i},$=(o,i,c="tinybase",g)=>{const d=i.getMap(c);return k(o,(async()=>d.size?[d.get(e).toJSON(),d.get(a).toJSON()]:void 0),(async(o,r)=>i.transact((()=>((o,r,i)=>{o.size||(o.set(e,new t),o.set(a,new t));const[c,l]=F(o),g=()=>{u=1};let u=1;if(s(i,(([t,e])=>{u=0,A(t,((t,e)=>u?0:n(t)?c.delete(e):s(c.get(e),(e=>A(t,((t,a)=>u?0:n(t)?e.delete(a):s(e.get(a),(e=>A(t,((t,a)=>n(t)?e.delete(a):e.set(a,t)))),g)))),g))),A(e,((t,e)=>u?0:n(t)?l.delete(e):l.set(e,t)))})),u){const[t,e]=r();Y(c,void 0,t,((t,e,a)=>Y(c,e,a,((t,e,a)=>Y(t,e,a,((t,e,a)=>{if(t.get(e)!==a)return t.set(e,a),1})))))),Y(l,void 0,e,((t,e,a)=>{l.get(e)!==a&&l.set(e,a)}))}})(d,o,r)))),(t=>{const n=n=>t(void 0,((t,n)=>{if(1==r(n)&&(o=n[0].path,0==r(o)))return[t.get(e).toJSON(),t.get(a).toJSON(),1];var o;const[i,c]=F(t),g={},d={};return l(n,(({path:t,changes:{keys:a}})=>u(t)==e?s(u(t),(e=>{const n=O(g,e,C),o=i.get(e);s(u(t),(t=>{const e=O(n,t,C),s=o.get(t);N(a,((t,{action:a})=>e[t]=a==x?null:s.get(t)))}),(()=>N(a,((t,{action:e})=>n[t]=e==x?null:o.get(t)?.toJSON()))))}),(()=>N(a,((t,{action:e})=>g[t]=e==x?null:i.get(t)?.toJSON())))):N(a,((t,{action:e})=>d[t]=e==x?null:c.get(t))))),[g,d,1]})(d,n));return d.observeDeep(n),n}),(t=>{d.unobserveDeep(t)}),g,1,{getYDoc:()=>i})};export{$ as createYjsPersister};
1
+ import{Map as t}from"yjs";const e="t",a="v",n=t=>null==t,s=(t,e,a)=>n(t)?a?.():e(t),o=t=>Array.isArray(t),r=t=>t.length,i=t=>{throw Error(t)},c=async(t,e,a)=>{try{return await t()}catch(t){e?.(t)}},l=(t,e)=>t.forEach(e),g=(t,...e)=>t.push(...e),u=t=>t.shift(),d=t=>n(t)||0==(t=>t?.size??0)(t),y=(t,e)=>t?.forEach(e),p=(t,e)=>t?.delete(e),w=Object,v=t=>w.getPrototypeOf(t),h=w.entries,f=w.keys,S=w.freeze,C=(t=[])=>w.fromEntries(t),b=(t,e)=>e in t,A=(t,e)=>C(((t,e)=>((t,e)=>t.map(e))(h(t),([t,a])=>e(a,t)))(t,(t,a)=>[a,e(t,a)])),M=t=>(t=>!n(t)&&s(v(t),t=>t==w.prototype||n(v(t)),()=>!0))(t)&&0==(t=>r(f(t)))(t),O=(t,e,a)=>(b(t,e)||(t[e]=a()),t[e]),L=t=>new Map(t),J=(t,e)=>t?.get(e),N=(t,e)=>y(t,(t,a)=>e(a,t)),z=(t,e,a)=>n(a)?(p(t,e),t):t?.set(e,a),D=(t,e,a,n)=>{var s,o;return s=t,o=e,s?.has(o)?n?.(J(t,e)):z(t,e,a()),J(t,e)},E=(t,e,a,n,o=0)=>s((a?D:J)(t,e[o],o>r(e)-2?a:L),s=>{if(o>r(e)-2)return n?.(s)&&z(t,e[o]),s;const i=E(s,e,a,n,o+1);return d(s)&&z(t,e[o]),i}),m=/^\d+$/,P=t=>new Set(o(t)||n(t)?t:[t]),T=L(),j=L(),k=(t,e,a,w,v,h,f,C={},b=0,A=[])=>{let O,N,k,x=0,F=0,Y=0;D(T,A,()=>0),D(j,A,()=>[]);const $=L(),[q,B,G,H,I]=((t=1,e,a)=>1!=t&&e.isMergeable()?[1,e.getMergeableContent,()=>e.getTransactionMergeableChanges(!a),([[t],[e]])=>!M(t)||!M(e),e.setDefaultContent]:2!=t?[0,e.getContent,e.getTransactionChanges,([t,e])=>!M(t)||!M(e),e.setContent]:i("Store type not supported by this Persister"))(f,t,b),[K,Q,R]=(()=>{let t;const[e,a]=(()=>{const t=[];let e=0;return[a=>(a?u(t):null)??""+e++,e=>{m.test(e)&&r(t)<1e3&&g(t,e)}]})(),o=L();return[(a,n,s,r=[],i=()=>[])=>{t??=st;const c=e(1);var l,g;return z(o,c,[a,n,s,r,i]),l=E(n,s??[""],P),g=c,l?.add(g),c},(e,a,...n)=>l(((t,e=[""])=>{const a=[],n=(t,s)=>s==r(e)?g(a,t):null===e[s]?y(t,t=>n(t,s+1)):l([e[s],null],e=>n(J(t,e),s+1));return n(t,0),a})(e,a),e=>y(e,e=>J(o,e)[0](t,...a??[],...n))),t=>s(J(o,t),([,e,n])=>(E(e,n??[""],void 0,e=>(p(e,t),d(e)?1:0)),z(o,t),a(t),n)),e=>s(J(o,e),([e,,a=[],s,o])=>{const i=(...c)=>{const g=r(c);g==r(a)?e(t,...c,...o(c)):n(a[g])?l(s[g]?.(...c)??[],t=>i(...c,t)):i(...c,a[g])};i()})]})(),U=t=>{t!=x&&(x=t,Q($,void 0,x))},V=e=>{(q&&o(e?.[0])?1===e?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===e?.[2]?t.applyChanges:t.setContent)(e)},W=async t=>(2!=x&&(U(1),F++,await nt(async()=>{await c(async()=>{const a=await e();o(a)?V(a):t?I(t):i("Content is not an array: "+a)},()=>{t&&I(t)}),U(0)})),st),X=async t=>(Z(),await W(t),await c(async()=>N=await w(async(t,e)=>{e||t?2!=x&&(U(1),F++,V(e??t),U(0)):await W()}),h),st),Z=async()=>(N&&(await c(()=>v(N),h),N=void 0),st),_=async t=>(1!=x&&(U(2),Y++,await nt(async()=>{await c(()=>a(B,t),h),U(0)})),st),tt=async()=>(et(),await _(),k=t.addDidFinishTransactionListener(()=>{const t=G();H(t)&&_(t)}),st),et=async()=>(k&&(t.delListener(k),k=void 0),st),at=async(t=!1)=>{const[e,a]=t?[et,Z]:[Z,et];return await e(),await a(),st},nt=async(...t)=>(g(J(j,A),...t),await(async()=>{if(!J(T,A)){for(z(T,A,1);!n(O=u(J(j,A)));)await c(O,h);z(T,A,0)}})(),st),st={load:W,startAutoLoad:X,stopAutoLoad:Z,isAutoLoading:()=>!n(N),save:_,startAutoSave:tt,stopAutoSave:et,isAutoSaving:()=>!n(k),startAutoPersisting:async(t,e=!1)=>{const[a,n]=e?[tt,X]:[X,tt];return await a(t),await n(t),st},stopAutoPersisting:at,getStatus:()=>x,addStatusListener:t=>K(t,$),delListener:e=>(R(e),t),schedule:nt,getStore:()=>t,destroy:()=>(J(j,A).splice(0,void 0),at()),getStats:()=>({loads:F,saves:Y}),...C};return S(st)},x="delete",F=t=>[t.get(e),t.get(a)],Y=(e,a,s,o)=>{const r=n(a)?e:e.get(a)??e.set(a,new t);let i;return A(s,(t,e)=>{o(r,e,t)&&(i=1)}),r.forEach((t,e)=>{b(s,e)||(r.delete(e),i=1)}),n(a)||r.size||e.delete(a),i},$=(o,i,c="tinybase",g)=>{const d=i.getMap(c);return k(o,async()=>d.size?[d.get(e).toJSON(),d.get(a).toJSON()]:void 0,async(o,r)=>i.transact(()=>((o,r,i)=>{o.size||(o.set(e,new t),o.set(a,new t));const[c,l]=F(o),g=()=>{u=1};let u=1;if(s(i,([t,e])=>{u=0,A(t,(t,e)=>u?0:n(t)?c.delete(e):s(c.get(e),e=>A(t,(t,a)=>u?0:n(t)?e.delete(a):s(e.get(a),e=>A(t,(t,a)=>n(t)?e.delete(a):e.set(a,t)),g)),g)),A(e,(t,e)=>u?0:n(t)?l.delete(e):l.set(e,t))}),u){const[t,e]=r();Y(c,void 0,t,(t,e,a)=>Y(c,e,a,(t,e,a)=>Y(t,e,a,(t,e,a)=>{if(t.get(e)!==a)return t.set(e,a),1}))),Y(l,void 0,e,(t,e,a)=>{l.get(e)!==a&&l.set(e,a)})}})(d,o,r)),t=>{const n=n=>t(void 0,((t,n)=>{if(1==r(n)&&(o=n[0].path,0==r(o)))return[t.get(e).toJSON(),t.get(a).toJSON(),1];var o;const[i,c]=F(t),g={},d={};return l(n,({path:t,changes:{keys:a}})=>u(t)==e?s(u(t),e=>{const n=O(g,e,C),o=i.get(e);s(u(t),t=>{const e=O(n,t,C),s=o.get(t);N(a,(t,{action:a})=>e[t]=a==x?null:s.get(t))},()=>N(a,(t,{action:e})=>n[t]=e==x?null:o.get(t)?.toJSON()))},()=>N(a,(t,{action:e})=>g[t]=e==x?null:i.get(t)?.toJSON())):N(a,(t,{action:e})=>d[t]=e==x?null:c.get(t))),[g,d,1]})(d,n));return d.observeDeep(n),n},t=>{d.unobserveDeep(t)},g,1,{getYDoc:()=>i})};export{$ as createYjsPersister};
@@ -1 +1 @@
1
- const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),i="true",r=(a,t,e)=>a.replace(t,e),o=Promise,c=globalThis,l=clearInterval,w=a=>null==a,y=(a,t,e)=>w(a)?e?.():t(a),d=t=>a(t)==s,u=a=>Array.isArray(a),E=(a,t,e)=>a.slice(t,e),N=a=>a.length,g=async a=>o.all(a),$=a=>{throw Error(a)},A=async(a,t,e)=>{try{return await a()}catch(a){t?.(a)}},O=(a,t)=>a.forEach(t),m=(a,t="")=>a.join(t),T=(a,t)=>a.map(t),R=a=>0==N(a),p=(a,t)=>a.filter(t),v=(a,...t)=>a.push(...t),I=a=>a.shift(),S=(a,t)=>a?.has(t)??!1,_=a=>w(a)||0==(a=>a?.size??0)(a),C=a=>[...a?.values()??[]],b=(a,t)=>a?.forEach(t),L=(a,t)=>a?.delete(t),D=Object,f=a=>D.getPrototypeOf(a),h=D.entries,P=D.keys,M=D.freeze,F=(a=[])=>D.fromEntries(a),U=(...a)=>D.assign({},...a),G=(a,t)=>(delete a[t],a),j=(a,t)=>T(h(a),(([a,e])=>t(e,a))),x=(a,t)=>F(j(a,((a,e)=>[e,t(a,e)]))),B=a=>D.values(a),H=a=>N(P(a)),W=a=>(a=>!w(a)&&y(f(a),(a=>a==D.prototype||w(f(a))),(()=>!0)))(a)&&0==H(a),Y=a=>new Map(a),X=(a,t)=>a?.get(t),J=(a,t)=>T([...a?.entries()??[]],(([a,e])=>t(e,a))),k=(a,t,e)=>w(e)?(L(a,t),a):a?.set(t,e),z=(a,t,e,n)=>(S(a,t)?n?.(X(a,t)):k(a,t,e()),X(a,t)),K=(a,t,e,n,s=0)=>y((e?z:X)(a,t[s],s>N(t)-2?e:Y),(i=>{if(s>N(t)-2)return n?.(i)&&k(a,t[s]),i;const r=K(i,t,e,n,s+1);return _(i)&&k(a,t[s]),r})),V=/^\d+$/,q=a=>new Set(u(a)||w(a)?a:[a]),Q=(a,t)=>a?.add(t),Z={Idle:0,Loading:1,Saving:2},aa={StoreOnly:1,MergeableStoreOnly:2,StoreOrMergeableStore:3},ta=Y(),ea=Y(),na=(a,t,n,s,i,r,o,c={},l=0,d=[])=>{let E,g,m,T=0,R=0,p=0;z(ta,d,(()=>0)),z(ea,d,(()=>[]));const S=Y(),[C,D,f,h,P]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!W(a)||!W(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!W(a)||!W(t),t.setContent]:$("Store type not supported by this Persister"))(o,a,l),[F,U,G]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?I(a):null)??e+t++,t=>{V.test(t)&&N(a)<1e3&&v(a,t)}]})(),s=Y();return[(n,i,r,o=[],c=()=>[])=>{a??=ra;const l=t(1);return k(s,l,[n,i,r,o,c]),Q(K(i,r??[e],q),l),l},(t,n,...i)=>O(((a,t=[e])=>{const n=[],s=(a,e)=>e==N(t)?v(n,a):null===t[e]?b(a,(a=>s(a,e+1))):O([t[e],null],(t=>s(X(a,t),e+1)));return s(a,0),n})(t,n),(t=>b(t,(t=>X(s,t)[0](a,...n??[],...i))))),a=>y(X(s,a),(([,t,i])=>(K(t,i??[e],void 0,(t=>(L(t,a),_(t)?1:0))),k(s,a),n(a),i))),t=>y(X(s,t),(([t,,e=[],n,s])=>{const i=(...r)=>{const o=N(r);o==N(e)?t(a,...r,...s(r)):w(e[o])?O(n[o]?.(...r)??[],(a=>i(...r,a))):i(...r,e[o])};i()}))]})(),j=a=>{a!=T&&(T=a,U(S,void 0,T))},x=t=>{(C&&u(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},B=async a=>(2!=T&&(j(1),R++,await ia((async()=>{await A((async()=>{const e=await t();u(e)?x(e):a?P(a):$("Content is not an array: "+e)}),(()=>{a&&P(a)})),j(0)}))),ra),H=async a=>(J(),await B(a),await A((async()=>g=await s((async(a,t)=>{t||a?2!=T&&(j(1),R++,x(t??a),j(0)):await B()}))),r),ra),J=async()=>(g&&(await A((()=>i(g)),r),g=void 0),ra),Z=async a=>(1!=T&&(j(2),p++,await ia((async()=>{await A((()=>n(D,a)),r),j(0)}))),ra),aa=async()=>(na(),await Z(),m=a.addDidFinishTransactionListener((()=>{const a=f();h(a)&&Z(a)})),ra),na=async()=>(m&&(a.delListener(m),m=void 0),ra),sa=async(a=!1)=>{const[t,e]=a?[na,J]:[J,na];return await t(),await e(),ra},ia=async(...a)=>(v(X(ea,d),...a),await(async()=>{if(!X(ta,d)){for(k(ta,d,1);!w(E=I(X(ea,d)));)await A(E,r);k(ta,d,0)}})(),ra),ra={load:B,startAutoLoad:H,stopAutoLoad:J,isAutoLoading:()=>!w(g),save:Z,startAutoSave:aa,stopAutoSave:na,isAutoSaving:()=>!w(m),startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[aa,H]:[H,aa];return await e(a),await n(a),ra},stopAutoPersisting:sa,getStatus:()=>T,addStatusListener:a=>F(a,S),delListener:t=>(G(t),a),schedule:ia,getStore:()=>a,destroy:()=>(X(ea,d).splice(0,void 0),sa()),getStats:()=>({loads:R,saves:p}),...c};return M(ra)},sa=JSON.stringify,ia=JSON.parse,ra=a=>sa(a,((a,t)=>void 0===t?"":t)),oa=new c.TextEncoder,ca="_",la="_id",wa="SELECT",ya="WHERE",da="TABLE",ua="INSERT",Ea="DELETE",Na="UPDATE",ga="ALTER "+da,$a="FROM",Aa=Ea+" "+$a,Oa=wa+"*"+$a,ma="pragma_",Ta="data_version",Ra="schema_version",pa="pragma_table_",va="CREATE ",Ia=va+da,Sa="OR REPLACE ",_a="FUNCTION",Ca="$tableName",ba=(a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a,La=a=>m(T(((a,t="",e)=>a.split(t,e))(a,"."),(a=>`"${r(a,/"/g,'""')}"`)),"."),Da=(...a)=>La(m(a,"_")),fa=(a,t=[1])=>m(T(a,(()=>"$"+t[0]++)),n),ha=(a,t=i)=>ya+`(${r(t,Ca,La(a))})`,Pa="ColumnName",Ma="store",Fa="json",Ua=Ma+"TableName",Ga=Ma+"Id"+Pa,ja=Ma+Pa,xa="autoLoadIntervalSeconds",Ba="rowId"+Pa,Ha="tableId",Wa="tableName",Ya="deleteEmptyColumns",Xa="deleteEmptyTable",Ja="condition",ka={mode:Fa,[xa]:1},za={load:0,save:0,[Wa]:t+"_values"},Ka=(a,t,e,n,s)=>{const i=Y();return x(a,((a,r)=>{const o=E(B(U(t,d(a)?{[e]:a}:a)),0,H(t));w(o[0])||n(r,o[0])||(s(r,o[0]),k(i,r,o))})),i},Va=a=>{const e=(a=>U(ka,d(a)?{[Ua]:a}:a??{}))(a),n=e[xa];if(e.mode==Fa){const a=e[Ua]??t;return[1,n,[a,e[Ga]??la,e[ja]??Ma],q(a)]}const{tables:{load:s={},save:r={}}={},values:o={}}=e,c=E(B(U(za,o)),0,H(za)),l=c[2],w=q(l),y=q(l),u=Ka(s,{[Ha]:null,[Ba]:la,[Ja]:i},Ha,(a=>S(y,a)),(a=>Q(w,a))),N=Ka(r,{[Wa]:null,[Ba]:la,[Ya]:0,[Xa]:0,[Ja]:null},Wa,((a,t)=>S(y,t)),((a,t)=>Q(w,t)));var g;return g=(a,t)=>t[4]??=X(u,t[0])?.[2]??i,b(N,((a,t)=>g(0,a))),[0,n,[u,N,c],w]},qa=(a,t,e,s,r,o=Qa,c,l)=>{const y=Y();return[async()=>{y.clear(),T(await e(a,t),(({tn:a,cn:t})=>Q(z(y,a,q),t)))},async(t,e,n)=>((a,t)=>S(X(y,a),t))(t,e)?F(p(T(await a(Oa+La(t)+ha(t,n)),(a=>[a[e],l?x(G(a,e),l):G(a,e)])),(([a,t])=>!w(a)&&!W(t)))):{},async(t,e,s,l,d,u=!1,E=i)=>{const N=q();x(s??{},(a=>T(P(a??{}),(a=>Q(N,a)))));const $=C(N);if(!u&&d&&E==i&&R($)&&S(y,t))return await a("DROP "+da+La(t)),void k(y,t);const A=X(y,t),O=q(C(A));if(R($)||(S(y,t)?await g(T([e,...$],(async(n,s)=>{L(O,n)||(await a(ga+La(t)+"ADD"+La(n)+r),0==s&&await a("CREATE UNIQUE INDEX pk ON "+La(t)+`(${La(e)})`),Q(A,n))}))):(await a(Ia+La(t)+`(${La(e)}${r} PRIMARY KEY${m(T($,(a=>n+La(a)+r)))});`),k(y,t,q([e,...$])))),await g([...!u&&l?T(C(O),(async n=>{n!=e&&(await a(ga+La(t)+"DROP"+La(n)),L(A,n))})):[]]),u)w(s)?await a(Aa+La(t)+ha(t,E)):await g(j(s,(async(n,s)=>{w(n)?await a(Aa+La(t)+ha(t,E)+`AND(${La(e)}=$1)`,[s]):R($)||await o(a,t,e,P(n),{[s]:c?T(B(n),c):B(n)},A)})));else if(R($))S(y,t)&&await a(Aa+La(t)+ha(t,E));else{const n=p(C(X(y,t)),(a=>a!=e)),i={},r=[];x(s??{},((a,t)=>{i[t]=T(n,(t=>c?c(a?.[t]):a?.[t])),v(r,t)})),await o(a,t,e,n,i),await a(Aa+La(t)+ha(t,E)+`AND${La(e)}NOT IN(${fa(r)})`,r)}},async t=>{let e;return await a("BEGIN"),await A((async()=>e=await t()),s),await a("END"),e}]},Qa=async(a,t,e,s,i)=>{const r=[1];await a(ua+" INTO"+La(t)+"("+((...a)=>m(T(a,La),n))(e,...s)+")VALUES"+m(j(i,(a=>"($"+r[0]+++","+fa(a,r)+")")),n)+"ON CONFLICT("+La(e)+`)DO ${Na} SET`+m(T(s,(a=>La(a)+"=excluded."+La(a))),n),j(i,((a,t)=>[t,...T(a,(a=>a??null))])).flat())},Za=(a,t,e,n,s,i,r,[o,c,l],w,y,d,u,E,N)=>{const[g,$,A,O]=qa(t,w,y,s,E,N),m=na(a,(()=>O((async()=>{return await g(),a=(await $(o,c))[ca]?.[l]??"null",ia(a,((a,t)=>""===t?void 0:t));var a}))),(a=>O((async()=>{await g(),await A(o,c,{[ca]:{[l]:ra(a()??null)}},!0,!0)}))),e,n,s,r,{[u]:()=>d,destroy:async()=>(await m.stopAutoPersisting(),i(),m)},0,d);return m},at=(a,t,e,n,s,i,r,[o,c,[l,y,d]],u,E,N,$,A,O,m,T)=>{const[R,v,I,S]=qa(t,u,E,s,A,O,m,T),_=(a,t)=>g(J(c,(async([e,n,s,i,r],o)=>{t&&!(o in a)||await I(e,n,a[o],s,i,t,r)}))),C=async(a,t)=>y?await I(d,la,{[ca]:a},!0,!0,t):null,b=na(a,(()=>S((async()=>{await R();const a=await(async()=>F(p(await g(J(o,(async([a,t,e],n)=>[a,await v(n,t,e)]))),(a=>!W(a[1])))))(),t=await(async()=>l?(await v(d,la))[ca]:{})();return W(a)&&w(t)?void 0:[a,t]}))),((a,t)=>S((async()=>{if(await R(),w(t)){const[t,e]=a();await _(t),await C(e)}else await _(t[0],!0),await C(t[1],!0)}))),e,n,s,r,{[$]:()=>N,destroy:async()=>(await b.stopAutoPersisting(),i(),b)},0,N);return b},tt=/^([cd]:)(.+)/,et=(a,n,s,o,c,l,w,d,u,E,N="getDb")=>{const $=ba(s,l),[A,,R,p]=Va(n),v=e+(a=>{let t=2166136261;return O(oa.encode(a),(a=>{t^=a,t+=(t<<1)+(t<<4)+(t<<7)+(t<<8)+(t<<24)})),t>>>0})(ra(R)),I=t+"_"+v,_=async(a,e,n="",s="")=>{const i=Da(t,a,v);return await $(va+Sa+_a+i+`()RETURNS ${n}trigger AS $$ ${s}BEGIN ${e}END;$$ LANGUAGE plpgsql;`),i},b=async(a,t,e,n)=>(await $(va+a+"TRIGGER"+t+e+"EXECUTE "+_a+n+"()"),t),L=a=>`PERFORM pg_notify('${I}',${a});`,D=(a,t)=>A?i:2===t?D(a,0)+" OR "+D(a,1):r(X(R[0],a)?.[2]??i,Ca,0==t?"NEW":"OLD"),f=(a,e)=>g(T([ua,Ea,Na],((n,s)=>b(Sa,Da(t,"d",v,a,n),`AFTER ${n} ON${La(a)}FOR EACH ROW WHEN(${D(a,s)})`,e))));return(A?Za:at)(a,$,(async a=>{const e=await _("c",`FOR row IN SELECT object_identity FROM pg_event_trigger_ddl_commands()${ya} command_tag='${Ia}' LOOP ${L("'c:'||SPLIT_PART(row.object_identity,'.',2)")}END LOOP;`,"event_","DECLARE row record;");await b("EVENT ",Da(t,"c",v),`ON ddl_command_end WHEN TAG IN('${Ia}')`,e);const n=await _("d",L("'d:'||TG_TABLE_NAME")+"RETURN NULL;");return await g(T(C(p),(async a=>(await $(Ia+` IF NOT EXISTS${La(a)}("_id"text PRIMARY KEY)`),await f(a,n))))),[await o(I,(t=>{return y((e=t,s=tt,e?.match(s)),(async([,t,e])=>{S(p,e)&&("c:"==t&&await f(e,n),a())}));var e,s})),[e,n]]}),(async([a,t])=>{c(a),await $(`DROP FUNCTION IF EXISTS${m(t,",")}CASCADE`)}),w,d,u,R,C(p),(async(a,t)=>await a(wa+` table_name tn,column_name cn FROM information_schema.columns ${ya} table_schema='public'AND table_name IN(${fa(t)})`,t)),E,N,"text",void 0,(a=>sa(a)),(a=>ia(a)))},nt=(a,t,n,s,i,r,o,c,w,y,d="getDb",u)=>{let E,N,g;const $=ba(n,r),[O,m,T,R]=Va(t);return(O?Za:at)(a,$,(a=>{let t;const e=()=>t=setInterval((()=>A((async()=>{const[{d:t,s:e,c:n}]=await $(wa+` ${Ta} d,${Ra} s,TOTAL_CHANGES() c FROM ${ma}${Ta} JOIN ${ma}${Ra}`);t==E&&e==N&&n==g||(null!=E&&a(),E=t,N=e,g=n)}))),1e3*m),n=()=>{E=N=g=null,l(t)},r=s((t=>{R.has(t)&&(n(),a(),e())}));return e(),()=>{n(),i(r)}}),(a=>a()),o,c,w,T,C(R),(async(a,t)=>await a(wa+` t.name tn,c.name cn FROM ${pa}list()t,${pa}info(t.name)c ${ya} t.schema='main'AND t.type IN('table','view')AND t.name IN(${fa(t)})ORDER BY t.name,c.name`,t)),y,d,e,u,(a=>!0===a?1:!1===a?0:a),void 0)};export{aa as Persists,Z as Status,na as createCustomPersister,et as createCustomPostgreSqlPersister,nt as createCustomSqlitePersister};
1
+ const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),i="true",r=(a,t,e)=>a.replace(t,e),o=Promise,c=globalThis,l=clearInterval,w=a=>null==a,y=(a,t,e)=>w(a)?e?.():t(a),d=t=>a(t)==s,u=a=>Array.isArray(a),E=(a,t,e)=>a.slice(t,e),N=a=>a.length,g=async a=>o.all(a),$=a=>{throw Error(a)},A=async(a,t,e)=>{try{return await a()}catch(a){t?.(a)}},O=(a,t)=>a.forEach(t),m=(a,t="")=>a.join(t),T=(a,t)=>a.map(t),R=a=>0==N(a),p=(a,t)=>a.filter(t),v=(a,...t)=>a.push(...t),I=a=>a.shift(),S=(a,t)=>a?.has(t)??!1,_=a=>w(a)||0==(a=>a?.size??0)(a),C=a=>[...a?.values()??[]],b=(a,t)=>a?.forEach(t),L=(a,t)=>a?.delete(t),D=Object,f=a=>D.getPrototypeOf(a),h=D.entries,P=D.keys,M=D.freeze,F=(a=[])=>D.fromEntries(a),U=(...a)=>D.assign({},...a),G=(a,t)=>(delete a[t],a),j=(a,t)=>T(h(a),([a,e])=>t(e,a)),x=(a,t)=>F(j(a,(a,e)=>[e,t(a,e)])),B=a=>D.values(a),H=a=>N(P(a)),W=a=>(a=>!w(a)&&y(f(a),a=>a==D.prototype||w(f(a)),()=>!0))(a)&&0==H(a),Y=a=>new Map(a),X=(a,t)=>a?.get(t),J=(a,t)=>T([...a?.entries()??[]],([a,e])=>t(e,a)),k=(a,t,e)=>w(e)?(L(a,t),a):a?.set(t,e),z=(a,t,e,n)=>(S(a,t)?n?.(X(a,t)):k(a,t,e()),X(a,t)),K=(a,t,e,n,s=0)=>y((e?z:X)(a,t[s],s>N(t)-2?e:Y),i=>{if(s>N(t)-2)return n?.(i)&&k(a,t[s]),i;const r=K(i,t,e,n,s+1);return _(i)&&k(a,t[s]),r}),V=/^\d+$/,q=a=>new Set(u(a)||w(a)?a:[a]),Q=(a,t)=>a?.add(t),Z={Idle:0,Loading:1,Saving:2},aa={StoreOnly:1,MergeableStoreOnly:2,StoreOrMergeableStore:3},ta=Y(),ea=Y(),na=(a,t,n,s,i,r,o,c={},l=0,d=[])=>{let E,g,m,T=0,R=0,p=0;z(ta,d,()=>0),z(ea,d,()=>[]);const S=Y(),[C,D,f,h,P]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!W(a)||!W(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!W(a)||!W(t),t.setContent]:$("Store type not supported by this Persister"))(o,a,l),[F,U,G]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?I(a):null)??e+t++,t=>{V.test(t)&&N(a)<1e3&&v(a,t)}]})(),s=Y();return[(n,i,r,o=[],c=()=>[])=>{a??=ra;const l=t(1);return k(s,l,[n,i,r,o,c]),Q(K(i,r??[e],q),l),l},(t,n,...i)=>O(((a,t=[e])=>{const n=[],s=(a,e)=>e==N(t)?v(n,a):null===t[e]?b(a,a=>s(a,e+1)):O([t[e],null],t=>s(X(a,t),e+1));return s(a,0),n})(t,n),t=>b(t,t=>X(s,t)[0](a,...n??[],...i))),a=>y(X(s,a),([,t,i])=>(K(t,i??[e],void 0,t=>(L(t,a),_(t)?1:0)),k(s,a),n(a),i)),t=>y(X(s,t),([t,,e=[],n,s])=>{const i=(...r)=>{const o=N(r);o==N(e)?t(a,...r,...s(r)):w(e[o])?O(n[o]?.(...r)??[],a=>i(...r,a)):i(...r,e[o])};i()})]})(),j=a=>{a!=T&&(T=a,U(S,void 0,T))},x=t=>{(C&&u(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},B=async a=>(2!=T&&(j(1),R++,await ia(async()=>{await A(async()=>{const e=await t();u(e)?x(e):a?P(a):$("Content is not an array: "+e)},()=>{a&&P(a)}),j(0)})),ra),H=async a=>(J(),await B(a),await A(async()=>g=await s(async(a,t)=>{t||a?2!=T&&(j(1),R++,x(t??a),j(0)):await B()}),r),ra),J=async()=>(g&&(await A(()=>i(g),r),g=void 0),ra),Z=async a=>(1!=T&&(j(2),p++,await ia(async()=>{await A(()=>n(D,a),r),j(0)})),ra),aa=async()=>(na(),await Z(),m=a.addDidFinishTransactionListener(()=>{const a=f();h(a)&&Z(a)}),ra),na=async()=>(m&&(a.delListener(m),m=void 0),ra),sa=async(a=!1)=>{const[t,e]=a?[na,J]:[J,na];return await t(),await e(),ra},ia=async(...a)=>(v(X(ea,d),...a),await(async()=>{if(!X(ta,d)){for(k(ta,d,1);!w(E=I(X(ea,d)));)await A(E,r);k(ta,d,0)}})(),ra),ra={load:B,startAutoLoad:H,stopAutoLoad:J,isAutoLoading:()=>!w(g),save:Z,startAutoSave:aa,stopAutoSave:na,isAutoSaving:()=>!w(m),startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[aa,H]:[H,aa];return await e(a),await n(a),ra},stopAutoPersisting:sa,getStatus:()=>T,addStatusListener:a=>F(a,S),delListener:t=>(G(t),a),schedule:ia,getStore:()=>a,destroy:()=>(X(ea,d).splice(0,void 0),sa()),getStats:()=>({loads:R,saves:p}),...c};return M(ra)},sa=JSON.stringify,ia=JSON.parse,ra=a=>sa(a,(a,t)=>void 0===t?"":t),oa=new c.TextEncoder,ca="_",la="_id",wa="SELECT",ya="WHERE",da="TABLE",ua="INSERT",Ea="DELETE",Na="UPDATE",ga="ALTER "+da,$a="FROM",Aa=Ea+" "+$a,Oa=wa+"*"+$a,ma="pragma_",Ta="data_version",Ra="schema_version",pa="pragma_table_",va="CREATE ",Ia=va+da,Sa="OR REPLACE ",_a="FUNCTION",Ca="$tableName",ba=(a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a,La=a=>m(T(((a,t="",e)=>a.split(t,e))(a,"."),a=>`"${r(a,/"/g,'""')}"`),"."),Da=(...a)=>La(m(a,"_")),fa=(a,t=[1])=>m(T(a,()=>"$"+t[0]++),n),ha=(a,t=i)=>ya+`(${r(t,Ca,La(a))})`,Pa="ColumnName",Ma="store",Fa="json",Ua=Ma+"TableName",Ga=Ma+"Id"+Pa,ja=Ma+Pa,xa="autoLoadIntervalSeconds",Ba="rowId"+Pa,Ha="tableId",Wa="tableName",Ya="deleteEmptyColumns",Xa="deleteEmptyTable",Ja="condition",ka={mode:Fa,[xa]:1},za={load:0,save:0,[Wa]:t+"_values"},Ka=(a,t,e,n,s)=>{const i=Y();return x(a,(a,r)=>{const o=E(B(U(t,d(a)?{[e]:a}:a)),0,H(t));w(o[0])||n(r,o[0])||(s(r,o[0]),k(i,r,o))}),i},Va=a=>{const e=(a=>U(ka,d(a)?{[Ua]:a}:a??{}))(a),n=e[xa];if(e.mode==Fa){const a=e[Ua]??t;return[1,n,[a,e[Ga]??la,e[ja]??Ma],q(a)]}const{tables:{load:s={},save:r={}}={},values:o={}}=e,c=E(B(U(za,o)),0,H(za)),l=c[2],w=q(l),y=q(l),u=Ka(s,{[Ha]:null,[Ba]:la,[Ja]:i},Ha,a=>S(y,a),a=>Q(w,a)),N=Ka(r,{[Wa]:null,[Ba]:la,[Ya]:0,[Xa]:0,[Ja]:null},Wa,(a,t)=>S(y,t),(a,t)=>Q(w,t));var g;return g=(a,t)=>t[4]??=X(u,t[0])?.[2]??i,b(N,(a,t)=>g(0,a)),[0,n,[u,N,c],w]},qa=(a,t,e,s,r,o=Qa,c,l)=>{const y=Y();return[async()=>{y.clear(),T(await e(a,t),({tn:a,cn:t})=>Q(z(y,a,q),t))},async(t,e,n)=>((a,t)=>S(X(y,a),t))(t,e)?F(p(T(await a(Oa+La(t)+ha(t,n)),a=>[a[e],l?x(G(a,e),l):G(a,e)]),([a,t])=>!w(a)&&!W(t))):{},async(t,e,s,l,d,u=!1,E=i)=>{const N=q();x(s??{},a=>T(P(a??{}),a=>Q(N,a)));const $=C(N);if(!u&&d&&E==i&&R($)&&S(y,t))return await a("DROP "+da+La(t)),void k(y,t);const A=X(y,t),O=q(C(A));if(R($)||(S(y,t)?await g(T([e,...$],async(n,s)=>{L(O,n)||(await a(ga+La(t)+"ADD"+La(n)+r),0==s&&await a("CREATE UNIQUE INDEX pk ON "+La(t)+`(${La(e)})`),Q(A,n))})):(await a(Ia+La(t)+`(${La(e)}${r} PRIMARY KEY${m(T($,a=>n+La(a)+r))});`),k(y,t,q([e,...$])))),await g([...!u&&l?T(C(O),async n=>{n!=e&&(await a(ga+La(t)+"DROP"+La(n)),L(A,n))}):[]]),u)w(s)?await a(Aa+La(t)+ha(t,E)):await g(j(s,async(n,s)=>{w(n)?await a(Aa+La(t)+ha(t,E)+`AND(${La(e)}=$1)`,[s]):R($)||await o(a,t,e,P(n),{[s]:c?T(B(n),c):B(n)},A)}));else if(R($))S(y,t)&&await a(Aa+La(t)+ha(t,E));else{const n=p(C(X(y,t)),a=>a!=e),i={},r=[];x(s??{},(a,t)=>{i[t]=T(n,t=>c?c(a?.[t]):a?.[t]),v(r,t)}),await o(a,t,e,n,i),await a(Aa+La(t)+ha(t,E)+`AND${La(e)}NOT IN(${fa(r)})`,r)}},async t=>{let e;return await a("BEGIN"),await A(async()=>e=await t(),s),await a("END"),e}]},Qa=async(a,t,e,s,i)=>{const r=[1];await a(ua+" INTO"+La(t)+"("+((...a)=>m(T(a,La),n))(e,...s)+")VALUES"+m(j(i,a=>"($"+r[0]+++","+fa(a,r)+")"),n)+"ON CONFLICT("+La(e)+`)DO ${Na} SET`+m(T(s,a=>La(a)+"=excluded."+La(a)),n),j(i,(a,t)=>[t,...T(a,a=>a??null)]).flat())},Za=(a,t,e,n,s,i,r,[o,c,l],w,y,d,u,E,N)=>{const[g,$,A,O]=qa(t,w,y,s,E,N),m=na(a,()=>O(async()=>{return await g(),a=(await $(o,c))[ca]?.[l]??"null",ia(a,(a,t)=>""===t?void 0:t);var a}),a=>O(async()=>{await g(),await A(o,c,{[ca]:{[l]:ra(a()??null)}},!0,!0)}),e,n,s,r,{[u]:()=>d,destroy:async()=>(await m.stopAutoPersisting(),i(),m)},0,d);return m},at=(a,t,e,n,s,i,r,[o,c,[l,y,d]],u,E,N,$,A,O,m,T)=>{const[R,v,I,S]=qa(t,u,E,s,A,O,m,T),_=(a,t)=>g(J(c,async([e,n,s,i,r],o)=>{t&&!(o in a)||await I(e,n,a[o],s,i,t,r)})),C=async(a,t)=>y?await I(d,la,{[ca]:a},!0,!0,t):null,b=na(a,()=>S(async()=>{await R();const a=await(async()=>F(p(await g(J(o,async([a,t,e],n)=>[a,await v(n,t,e)])),a=>!W(a[1]))))(),t=await(async()=>l?(await v(d,la))[ca]:{})();return W(a)&&w(t)?void 0:[a,t]}),(a,t)=>S(async()=>{if(await R(),w(t)){const[t,e]=a();await _(t),await C(e)}else await _(t[0],!0),await C(t[1],!0)}),e,n,s,r,{[$]:()=>N,destroy:async()=>(await b.stopAutoPersisting(),i(),b)},0,N);return b},tt=/^([cd]:)(.+)/,et=(a,n,s,o,c,l,w,d,u,E,N="getDb")=>{const $=ba(s,l),[A,,R,p]=Va(n),v=e+(a=>{let t=2166136261;return O(oa.encode(a),a=>{t^=a,t+=(t<<1)+(t<<4)+(t<<7)+(t<<8)+(t<<24)}),t>>>0})(ra(R)),I=t+"_"+v,_=async(a,e,n="",s="")=>{const i=Da(t,a,v);return await $(va+Sa+_a+i+`()RETURNS ${n}trigger AS $$ ${s}BEGIN ${e}END;$$ LANGUAGE plpgsql;`),i},b=async(a,t,e,n)=>(await $(va+a+"TRIGGER"+t+e+"EXECUTE "+_a+n+"()"),t),L=a=>`PERFORM pg_notify('${I}',${a});`,D=(a,t)=>A?i:2===t?D(a,0)+" OR "+D(a,1):r(X(R[0],a)?.[2]??i,Ca,0==t?"NEW":"OLD"),f=(a,e)=>g(T([ua,Ea,Na],(n,s)=>b(Sa,Da(t,"d",v,a,n),`AFTER ${n} ON${La(a)}FOR EACH ROW WHEN(${D(a,s)})`,e)));return(A?Za:at)(a,$,async a=>{const e=await _("c",`FOR row IN SELECT object_identity FROM pg_event_trigger_ddl_commands()${ya} command_tag='${Ia}' LOOP ${L("'c:'||SPLIT_PART(row.object_identity,'.',2)")}END LOOP;`,"event_","DECLARE row record;");await b("EVENT ",Da(t,"c",v),`ON ddl_command_end WHEN TAG IN('${Ia}')`,e);const n=await _("d",L("'d:'||TG_TABLE_NAME")+"RETURN NULL;");return await g(T(C(p),async a=>(await $(Ia+` IF NOT EXISTS${La(a)}("_id"text PRIMARY KEY)`),await f(a,n)))),[await o(I,t=>{return y((e=t,s=tt,e?.match(s)),async([,t,e])=>{S(p,e)&&("c:"==t&&await f(e,n),a())});var e,s}),[e,n]]},async([a,t])=>{c(a),await $(`DROP FUNCTION IF EXISTS${m(t,",")}CASCADE`)},w,d,u,R,C(p),async(a,t)=>await a(wa+` table_name tn,column_name cn FROM information_schema.columns ${ya} table_schema='public'AND table_name IN(${fa(t)})`,t),E,N,"text",void 0,a=>sa(a),a=>ia(a))},nt=(a,t,n,s,i,r,o,c,w,y,d="getDb",u)=>{let E,N,g;const $=ba(n,r),[O,m,T,R]=Va(t);return(O?Za:at)(a,$,a=>{let t;const e=()=>t=setInterval(()=>A(async()=>{const[{d:t,s:e,c:n}]=await $(wa+` ${Ta} d,${Ra} s,TOTAL_CHANGES() c FROM ${ma}${Ta} JOIN ${ma}${Ra}`);t==E&&e==N&&n==g||(null!=E&&a(),E=t,N=e,g=n)}),1e3*m),n=()=>{E=N=g=null,l(t)},r=s(t=>{R.has(t)&&(n(),a(),e())});return e(),()=>{n(),i(r)}},a=>a(),o,c,w,T,C(R),async(a,t)=>await a(wa+` t.name tn,c.name cn FROM ${pa}list()t,${pa}info(t.name)c ${ya} t.schema='main'AND t.type IN('table','view')AND t.name IN(${fa(t)})ORDER BY t.name,c.name`,t),y,d,e,u,a=>!0===a?1:!1===a?0:a,void 0)};export{aa as Persists,Z as Status,na as createCustomPersister,et as createCustomPostgreSqlPersister,nt as createCustomSqlitePersister};