tinybase 4.8.7 → 4.8.8

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 (108) hide show
  1. package/lib/cjs/persisters/persister-cr-sqlite-wasm.cjs +1 -1
  2. package/lib/cjs/persisters/persister-cr-sqlite-wasm.cjs.gz +0 -0
  3. package/lib/cjs/persisters/persister-electric-sql.cjs +1 -1
  4. package/lib/cjs/persisters/persister-electric-sql.cjs.gz +0 -0
  5. package/lib/cjs/persisters/persister-expo-sqlite-next.cjs +1 -1
  6. package/lib/cjs/persisters/persister-expo-sqlite-next.cjs.gz +0 -0
  7. package/lib/cjs/persisters/persister-expo-sqlite.cjs +1 -1
  8. package/lib/cjs/persisters/persister-expo-sqlite.cjs.gz +0 -0
  9. package/lib/cjs/persisters/persister-libsql.cjs +1 -1
  10. package/lib/cjs/persisters/persister-libsql.cjs.gz +0 -0
  11. package/lib/cjs/persisters/persister-powersync.cjs +1 -1
  12. package/lib/cjs/persisters/persister-powersync.cjs.gz +0 -0
  13. package/lib/cjs/persisters/persister-sqlite-wasm.cjs +1 -1
  14. package/lib/cjs/persisters/persister-sqlite-wasm.cjs.gz +0 -0
  15. package/lib/cjs/persisters/persister-sqlite3.cjs +1 -1
  16. package/lib/cjs/persisters/persister-sqlite3.cjs.gz +0 -0
  17. package/lib/cjs-es6/persisters/persister-cr-sqlite-wasm.cjs +1 -1
  18. package/lib/cjs-es6/persisters/persister-cr-sqlite-wasm.cjs.gz +0 -0
  19. package/lib/cjs-es6/persisters/persister-electric-sql.cjs +1 -1
  20. package/lib/cjs-es6/persisters/persister-electric-sql.cjs.gz +0 -0
  21. package/lib/cjs-es6/persisters/persister-expo-sqlite-next.cjs +1 -1
  22. package/lib/cjs-es6/persisters/persister-expo-sqlite-next.cjs.gz +0 -0
  23. package/lib/cjs-es6/persisters/persister-expo-sqlite.cjs +1 -1
  24. package/lib/cjs-es6/persisters/persister-expo-sqlite.cjs.gz +0 -0
  25. package/lib/cjs-es6/persisters/persister-libsql.cjs +1 -1
  26. package/lib/cjs-es6/persisters/persister-libsql.cjs.gz +0 -0
  27. package/lib/cjs-es6/persisters/persister-powersync.cjs +1 -1
  28. package/lib/cjs-es6/persisters/persister-powersync.cjs.gz +0 -0
  29. package/lib/cjs-es6/persisters/persister-sqlite-wasm.cjs +1 -1
  30. package/lib/cjs-es6/persisters/persister-sqlite-wasm.cjs.gz +0 -0
  31. package/lib/cjs-es6/persisters/persister-sqlite3.cjs +1 -1
  32. package/lib/cjs-es6/persisters/persister-sqlite3.cjs.gz +0 -0
  33. package/lib/debug/persisters/persister-cr-sqlite-wasm.js +15 -22
  34. package/lib/debug/persisters/persister-electric-sql.js +15 -22
  35. package/lib/debug/persisters/persister-expo-sqlite-next.js +15 -22
  36. package/lib/debug/persisters/persister-expo-sqlite.js +15 -22
  37. package/lib/debug/persisters/persister-libsql.js +15 -22
  38. package/lib/debug/persisters/persister-powersync.js +15 -22
  39. package/lib/debug/persisters/persister-sqlite-wasm.js +15 -22
  40. package/lib/debug/persisters/persister-sqlite3.js +15 -22
  41. package/lib/es6/persisters/persister-cr-sqlite-wasm.js +1 -1
  42. package/lib/es6/persisters/persister-cr-sqlite-wasm.js.gz +0 -0
  43. package/lib/es6/persisters/persister-electric-sql.js +1 -1
  44. package/lib/es6/persisters/persister-electric-sql.js.gz +0 -0
  45. package/lib/es6/persisters/persister-expo-sqlite-next.js +1 -1
  46. package/lib/es6/persisters/persister-expo-sqlite-next.js.gz +0 -0
  47. package/lib/es6/persisters/persister-expo-sqlite.js +1 -1
  48. package/lib/es6/persisters/persister-expo-sqlite.js.gz +0 -0
  49. package/lib/es6/persisters/persister-libsql.js +1 -1
  50. package/lib/es6/persisters/persister-libsql.js.gz +0 -0
  51. package/lib/es6/persisters/persister-powersync.js +1 -1
  52. package/lib/es6/persisters/persister-powersync.js.gz +0 -0
  53. package/lib/es6/persisters/persister-sqlite-wasm.js +1 -1
  54. package/lib/es6/persisters/persister-sqlite-wasm.js.gz +0 -0
  55. package/lib/es6/persisters/persister-sqlite3.js +1 -1
  56. package/lib/es6/persisters/persister-sqlite3.js.gz +0 -0
  57. package/lib/persisters/persister-cr-sqlite-wasm.js +1 -1
  58. package/lib/persisters/persister-cr-sqlite-wasm.js.gz +0 -0
  59. package/lib/persisters/persister-electric-sql.js +1 -1
  60. package/lib/persisters/persister-electric-sql.js.gz +0 -0
  61. package/lib/persisters/persister-expo-sqlite-next.js +1 -1
  62. package/lib/persisters/persister-expo-sqlite-next.js.gz +0 -0
  63. package/lib/persisters/persister-expo-sqlite.js +1 -1
  64. package/lib/persisters/persister-expo-sqlite.js.gz +0 -0
  65. package/lib/persisters/persister-libsql.js +1 -1
  66. package/lib/persisters/persister-libsql.js.gz +0 -0
  67. package/lib/persisters/persister-powersync.js +1 -1
  68. package/lib/persisters/persister-powersync.js.gz +0 -0
  69. package/lib/persisters/persister-sqlite-wasm.js +1 -1
  70. package/lib/persisters/persister-sqlite-wasm.js.gz +0 -0
  71. package/lib/persisters/persister-sqlite3.js +1 -1
  72. package/lib/persisters/persister-sqlite3.js.gz +0 -0
  73. package/lib/types/ui-react.d.ts +1 -1
  74. package/lib/types/with-schemas/ui-react.d.ts +1 -1
  75. package/lib/umd/persisters/persister-cr-sqlite-wasm.js +1 -1
  76. package/lib/umd/persisters/persister-cr-sqlite-wasm.js.gz +0 -0
  77. package/lib/umd/persisters/persister-electric-sql.js +1 -1
  78. package/lib/umd/persisters/persister-electric-sql.js.gz +0 -0
  79. package/lib/umd/persisters/persister-expo-sqlite-next.js +1 -1
  80. package/lib/umd/persisters/persister-expo-sqlite-next.js.gz +0 -0
  81. package/lib/umd/persisters/persister-expo-sqlite.js +1 -1
  82. package/lib/umd/persisters/persister-expo-sqlite.js.gz +0 -0
  83. package/lib/umd/persisters/persister-libsql.js +1 -1
  84. package/lib/umd/persisters/persister-libsql.js.gz +0 -0
  85. package/lib/umd/persisters/persister-powersync.js +1 -1
  86. package/lib/umd/persisters/persister-powersync.js.gz +0 -0
  87. package/lib/umd/persisters/persister-sqlite-wasm.js +1 -1
  88. package/lib/umd/persisters/persister-sqlite-wasm.js.gz +0 -0
  89. package/lib/umd/persisters/persister-sqlite3.js +1 -1
  90. package/lib/umd/persisters/persister-sqlite3.js.gz +0 -0
  91. package/lib/umd-es6/persisters/persister-cr-sqlite-wasm.js +1 -1
  92. package/lib/umd-es6/persisters/persister-cr-sqlite-wasm.js.gz +0 -0
  93. package/lib/umd-es6/persisters/persister-electric-sql.js +1 -1
  94. package/lib/umd-es6/persisters/persister-electric-sql.js.gz +0 -0
  95. package/lib/umd-es6/persisters/persister-expo-sqlite-next.js +1 -1
  96. package/lib/umd-es6/persisters/persister-expo-sqlite-next.js.gz +0 -0
  97. package/lib/umd-es6/persisters/persister-expo-sqlite.js +1 -1
  98. package/lib/umd-es6/persisters/persister-expo-sqlite.js.gz +0 -0
  99. package/lib/umd-es6/persisters/persister-libsql.js +1 -1
  100. package/lib/umd-es6/persisters/persister-libsql.js.gz +0 -0
  101. package/lib/umd-es6/persisters/persister-powersync.js +1 -1
  102. package/lib/umd-es6/persisters/persister-powersync.js.gz +0 -0
  103. package/lib/umd-es6/persisters/persister-sqlite-wasm.js +1 -1
  104. package/lib/umd-es6/persisters/persister-sqlite-wasm.js.gz +0 -0
  105. package/lib/umd-es6/persisters/persister-sqlite3.js +1 -1
  106. package/lib/umd-es6/persisters/persister-sqlite3.js.gz +0 -0
  107. package/package.json +18 -18
  108. package/readme.md +1 -1
@@ -1 +1 @@
1
- var e,n;e=this,n=function(e){"use strict";const n=e=>typeof e,t="tinybase",l="",o=",",r=n(l),i=(e,n)=>e.repeat(n),u=Promise,a=clearInterval,d=e=>null==e,c=(e,n,t)=>d(e)?null==t?void 0:t():n(e),s=e=>n(e)==r,v=(e,n,t)=>e.slice(n,t),y=e=>e.length,f=e=>{return n=function*(){return u.all(e)},new Promise(((e,t)=>{var l=e=>{try{r(n.next(e))}catch(e){t(e)}},o=e=>{try{r(n.throw(e))}catch(e){t(e)}},r=n=>n.done?e(n.value):Promise.resolve(n.value).then(l,o);r((n=n.apply(void 0,null)).next())}));var n},p="_",h="_id",m=e=>`"${e.replace(/"/g,'""')}"`,E="SELECT",b=(e,n="")=>e.join(n),O=(e,n)=>e.map(n),P=e=>0==y(e),w=(e,n)=>e.filter(n),A=(e,...n)=>e.push(...n),T=(e,n)=>{var t;return null!=(t=null==e?void 0:e.has(n))&&t},N=e=>{var n;return[...null!=(n=null==e?void 0:e.values())?n:[]]},S=(e,n)=>null==e?void 0:e.delete(n),g=Object,x=e=>g.getPrototypeOf(e),R=g.keys,L=g.freeze,C=(e=[])=>g.fromEntries(e),I=(...e)=>g.assign({},...e),j=(e,n)=>O(g.entries(e),(([e,t])=>n(t,e))),D=e=>g.values(e),_=e=>y(R(e)),M=e=>(e=>!d(e)&&c(x(e),(e=>e==g.prototype||d(x(e))),(()=>!0)))(e)&&0==_(e),F=e=>new Map(e),k=e=>{var n;return[...null!=(n=null==e?void 0:e.keys())?n:[]]},q=(e,n)=>null==e?void 0:e.get(n),B=(e,n)=>{var t;return O([...null!=(t=null==e?void 0:e.entries())?t:[]],(([e,t])=>n(t,e)))},W=(e,n,t)=>d(t)?(S(e,n),e):null==e?void 0:e.set(n,t),H=(e,n,t)=>(T(e,n)||W(e,n,t()),q(e,n)),Y=(e,n,t,l=W)=>(j(n,((n,l)=>t(e,l,n))),((e,n)=>{((e,n)=>{null==e||e.forEach(n)})(e,((e,t)=>n(t)))})(e,(t=>((e,n)=>!d(((e,n)=>c(e,(e=>e[n])))(e,n)))(n,t)?0:l(e,t))),e),$=e=>new Set(Array.isArray(e)||d(e)?e:[e]),G=(e,n)=>null==e?void 0:e.add(n);var J=Object.defineProperty,U=Object.getOwnPropertySymbols,V=Object.prototype.hasOwnProperty,z=Object.prototype.propertyIsEnumerable,K=(e,n,t)=>n in e?J(e,n,{enumerable:!0,configurable:!0,writable:!0,value:t}):e[n]=t,Q=(e,n)=>{for(var t in n||(n={}))V.call(n,t)&&K(e,t,n[t]);if(U)for(var t of U(n))z.call(n,t)&&K(e,t,n[t]);return e},X=(e,n,t)=>new Promise(((l,o)=>{var r=e=>{try{u(t.next(e))}catch(e){o(e)}},i=e=>{try{u(t.throw(e))}catch(e){o(e)}},u=e=>e.done?l(e.value):Promise.resolve(e.value).then(r,i);u((t=t.apply(e,n)).next())}));const Z="TABLE",ee="ALTER "+Z,ne="DELETE FROM",te=E+"*FROM",le="FROM pragma_table_",oe="WHERE",re=(e,n,t,r)=>{const i=F();return[()=>X(void 0,null,(function*(){return Y(i,C(yield f(O(yield e("SELECT name "+le+"list WHERE schema='main'AND(type='table'OR type='view')AND name IN("+ue(n)+")ORDER BY name",n),(n=>X(void 0,[n],(function*({name:n}){return[n,C(O(yield e(E+" name,type "+le+"info(?)",[n]),(({name:e,type:n})=>[e,n])))]})))))),((e,n,t)=>W(i,n,Y(H(i,n,F),t,((e,n,t)=>{t!=q(e,n)&&W(e,n,t)}),((e,n)=>W(e,n))))),((e,n)=>W(i,n)))})),(n,t)=>X(void 0,null,(function*(){return((e,n)=>!d(q(q(i,e),n)))(n,t)?C(w(O(yield e(te+m(n)),(e=>{return[e[t],(n=Q({},e),l=t,delete n[l],n)];var n,l})),(([e,n])=>!d(e)&&!M(n)))):{}})),(n,t,u,a,c,s=!1)=>X(void 0,null,(function*(){const v=$();j(null!=u?u:{},(e=>O(R(null!=e?e:{}),(e=>G(v,e)))));const y=N(v);if(!s&&c&&P(y)&&T(i,n))return yield e("DROP "+Z+m(n)),void W(i,n);if(P(y)||T(i,n)){const o=q(i,n),r=$(k(o));yield f([...O(y,(t=>X(void 0,null,(function*(){S(r,t)||(yield e(ee+m(n)+"ADD"+m(t)),W(o,t,l))})))),...!s&&a?O(N(r),(l=>X(void 0,null,(function*(){l!=t&&(yield e(ee+m(n)+"DROP"+m(l)),W(o,l))})))):[]])}else yield e("CREATE "+Z+m(n)+"("+m(t)+` PRIMARY KEY ON CONFLICT REPLACE${b(O(y,(e=>o+m(e))))});`),W(i,n,F([[t,l],...O(y,(e=>[e,l]))]));if(s)d(u)?yield e(ne+m(n)+oe+" 1"):yield f(j(u,((l,o)=>X(void 0,null,(function*(){d(l)?yield e(ne+m(n)+oe+m(t)+"=?",[o]):P(y)||(yield ie(e,n,t,R(l),[o,...D(l)],r))})))));else if(P(y))T(i,n)&&(yield e(ne+m(n)+oe+" 1"));else{const l=w(k(q(i,n)),(e=>e!=t)),o=[],a=[];j(null!=u?u:{},((e,n)=>{A(o,n,...O(l,(n=>null==e?void 0:e[n]))),A(a,n)})),yield ie(e,n,t,l,o,r),yield e(ne+m(n)+oe+m(t)+"NOT IN("+ue(a)+")",a)}})),n=>X(void 0,null,(function*(){let l;yield e("BEGIN");try{l=yield n()}catch(e){null==t||t(e)}return yield e("END"),l}))]},ie=(e,n,t,r,u,a=!0)=>X(void 0,null,(function*(){return yield e("INSERT "+(a?l:"OR REPLACE ")+"INTO"+m(n)+"("+m(t)+b(O(r,(e=>o+m(e))))+")VALUES"+v(i(`,(?${i(",?",y(r))})`,y(u)/(y(r)+1)),1)+(a?"ON CONFLICT("+m(t)+")DO UPDATE SET"+b(O(r,(e=>m(e)+"=excluded."+m(e))),o):l),O(u,(e=>null!=e?e:null)))})),ue=e=>b(O(e,(()=>"?")),o),ae=JSON.parse;var de=(e,n,t)=>new Promise(((l,o)=>{var r=e=>{try{u(t.next(e))}catch(e){o(e)}},i=e=>{try{u(t.throw(e))}catch(e){o(e)}},u=e=>e.done?l(e.value):Promise.resolve(e.value).then(r,i);u((t=t.apply(e,n)).next())}));const ce=F(),se=F(),ve=(e,n,t,l,o,r,[i,u]=[],a=[])=>{let s,v,y,f=0,p=0;H(ce,a,(()=>0)),H(se,a,(()=>[]));const h=e=>de(void 0,null,(function*(){return 2!=f&&(f=1,yield m.schedule((()=>de(void 0,null,(function*(){yield e(),f=0}))))),m})),m={load:(t,l)=>de(void 0,null,(function*(){return yield h((()=>de(void 0,null,(function*(){try{e.setContent(yield n())}catch(n){e.setContent([t,l])}}))))})),startAutoLoad:(...t)=>de(void 0,[...t],(function*(t={},o={}){return m.stopAutoLoad(),yield m.load(t,o),p=1,y=l(((t,l)=>de(void 0,null,(function*(){if(l){const n=l();yield h((()=>de(void 0,null,(function*(){return e.setTransactionChanges(n)}))))}else yield h((()=>de(void 0,null,(function*(){var l;try{e.setContent(null!=(l=null==t?void 0:t())?l:yield n())}catch(e){null==r||r(e)}}))))})))),m})),stopAutoLoad:()=>(p&&(o(y),y=void 0,p=0),m),save:n=>de(void 0,null,(function*(){return 1!=f&&(f=2,yield m.schedule((()=>de(void 0,null,(function*(){try{yield t(e.getContent,n)}catch(e){null==r||r(e)}f=0}))))),m})),startAutoSave:()=>de(void 0,null,(function*(){return yield m.stopAutoSave().save(),s=e.addDidFinishTransactionListener(((e,n)=>{const[t,l]=n();M(t)&&M(l)||m.save((()=>[t,l]))})),m})),stopAutoSave:()=>(c(s,e.delListener),s=void 0,m),schedule:(...e)=>de(void 0,null,(function*(){return A(q(se,a),...e),yield de(void 0,null,(function*(){if(!q(ce,a)){for(W(ce,a,1);!d((e=q(se,a),v=e.shift()));)try{yield v()}catch(e){null==r||r(e)}W(ce,a,0)}var e})),m})),getStore:()=>e,destroy:()=>m.stopAutoLoad().stopAutoSave(),getStats:()=>({})};return i&&(m[i]=()=>u),L(m)};var ye=(e,n,t)=>new Promise(((l,o)=>{var r=e=>{try{u(t.next(e))}catch(e){o(e)}},i=e=>{try{u(t.throw(e))}catch(e){o(e)}},u=e=>e.done?l(e.value):Promise.resolve(e.value).then(r,i);u((t=t.apply(e,n)).next())}));const fe="store",pe=(e,n,t,l,o,[r],i,u,a,d)=>{const[c,s,v,y]=re(n,i,o,d);return ve(e,(()=>ye(void 0,null,(function*(){return yield y((()=>ye(void 0,null,(function*(){var e,n;return yield c(),ae(null!=(n=null==(e=(yield s(r,h))[p])?void 0:e[fe])?n:"null")}))))}))),(e=>ye(void 0,null,(function*(){return yield y((()=>ye(void 0,null,(function*(){var n,t;yield c(),yield v(r,h,{[p]:{[fe]:(t=null!=(n=e())?n:null,JSON.stringify(t,((e,n)=>n instanceof Map?g.fromEntries([...n]):n)))}},!0,!0)}))))}))),t,l,o,[a,u],u)};var he=(e,n,t)=>new Promise(((l,o)=>{var r=e=>{try{u(t.next(e))}catch(e){o(e)}},i=e=>{try{u(t.throw(e))}catch(e){o(e)}},u=e=>e.done?l(e.value):Promise.resolve(e.value).then(r,i);u((t=t.apply(e,n)).next())}));const me=(e,n,t,l,o,[r,i,[u,a,c]],s,v,y,m)=>{const[E,b,O,P]=re(n,s,o,m),A=(e,n)=>he(void 0,null,(function*(){return yield f(B(i,((t,l)=>he(void 0,[t,l],(function*([t,l,o,r],i){const u=e[i];n&&void 0===u||(yield O(t,l,u,o,r,n))})))))})),T=(e,n)=>he(void 0,null,(function*(){return a?yield O(c,h,{[p]:e},!0,!0,n):null}));return ve(e,(()=>he(void 0,null,(function*(){return yield P((()=>he(void 0,null,(function*(){yield E();const e=yield he(void 0,null,(function*(){return C(w(yield f(B(r,((e,n)=>he(void 0,[e,n],(function*([e,n],t){return[e,yield b(t,n)]}))))),(e=>!M(e[1]))))})),n=yield he(void 0,null,(function*(){return u?(yield b(c,h))[p]:{}}));return M(e)&&d(n)?void 0:[e,n]}))))}))),((e,n)=>he(void 0,null,(function*(){return yield P((()=>he(void 0,null,(function*(){if(yield E(),d(n)){const[n,t]=e();yield A(n),yield T(t)}else{const[e,t]=n();yield A(e,!0),yield T(t,!0)}}))))}))),t,l,o,[y,v],v)},Ee="json",be="autoLoadIntervalSeconds",Oe="rowIdColumnName",Pe="tableId",we="tableName",Ae={mode:Ee,[be]:1},Te={load:0,save:0,[we]:t+"_values"},Ne=(e,n,t,l)=>{const o=F();return j(e,((e,r)=>{const i=v(D(I(n,s(e)?{[t]:e}:e)),0,_(n));d(i[0])||l(r,i[0])||W(o,r,i)})),o};var Se=(e,n,t)=>new Promise(((l,o)=>{var r=e=>{try{u(t.next(e))}catch(e){o(e)}},i=e=>{try{u(t.throw(e))}catch(e){o(e)}},u=e=>e.done?l(e.value):Promise.resolve(e.value).then(r,i);u((t=t.apply(e,n)).next())}));const ge="pragma ",xe="data_version",Re="schema_version",Le=(e,n,l,o,r,i,u,d,c="getDb",y)=>{let f,p,m;const[b,O,P,w]=(e=>{const n=(e=>I(Ae,s(e)?{storeTableName:e}:null!=e?e:{}))(e),l=n[be];if(n.mode==Ee){const{storeTableName:e=t}=n;return[1,l,[e],$(e)]}const{tables:{load:o={},save:r={}}={},values:i={}}=n,u=v(D(I(Te,i)),0,_(Te)),a=u[2],d=$(a);return[0,l,[Ne(o,{[Pe]:null,[Oe]:h},Pe,(e=>G(d,e)&&e==a)),Ne(r,{[we]:null,[Oe]:h,deleteEmptyColumns:0,deleteEmptyTable:0},we,((e,n)=>G(d,n)&&n==a)),u],d]})(n);return(b?pe:me)(e,i?(e,n)=>Se(void 0,null,(function*(){return i(e,n),yield l(e,n)})):l,(e=>{return[(n=()=>Se(void 0,null,(function*(){try{const n=(yield l(ge+xe))[0][xe],t=(yield l(ge+Re))[0][Re],o=(yield l(E+" TOTAL_CHANGES() c"))[0].c;n==(null!=f?f:f=n)&&t==(null!=p?p:p=t)&&o==(null!=m?m:m=o)||(e(),f=n,p=t)}catch(e){}})),t=O,n(),setInterval(n,1e3*t)),o((n=>w.has(n)?e():0))];var n,t}),(([e,n])=>{a(e),f=p=null,r(n)}),u,P,N(w),d,c,y)};var Ce=Object.defineProperty,Ie=Object.getOwnPropertySymbols,je=Object.prototype.hasOwnProperty,De=Object.prototype.propertyIsEnumerable,_e=(e,n,t)=>n in e?Ce(e,n,{enumerable:!0,configurable:!0,writable:!0,value:t}):e[n]=t;e.createSqliteWasmPersister=(e,n,t,l,o,r)=>Le(e,l,((e,...n)=>{return l=[e,...n],o=function*(e,n=[]){return t.exec(e,{bind:n,rowMode:"object",returnValue:"resultRows"}).map((e=>((e,n)=>{for(var t in n||(n={}))je.call(n,t)&&_e(e,t,n[t]);if(Ie)for(var t of Ie(n))De.call(n,t)&&_e(e,t,n[t]);return e})({},e)))},new Promise(((e,n)=>{var t=e=>{try{i(o.next(e))}catch(e){n(e)}},r=e=>{try{i(o.throw(e))}catch(e){n(e)}},i=n=>n.done?e(n.value):Promise.resolve(n.value).then(t,r);i((o=o.apply(void 0,l)).next())}));var l,o}),(e=>n.capi.sqlite3_update_hook(t,((n,t,l,o)=>e(o)),0)),(()=>n.capi.sqlite3_update_hook(t,(()=>0),0)),o,r,t)},"object"==typeof exports&&"undefined"!=typeof module?n(exports):"function"==typeof define&&define.amd?define(["exports"],n):n((e="undefined"!=typeof globalThis?globalThis:e||self).TinyBasePersisterSqliteWasm={});
1
+ var e,n;e=this,n=function(e){"use strict";const n=e=>typeof e,t="tinybase",l="",o=",",r=n(l),i=(e,n)=>e.repeat(n),u=Promise,a=clearInterval,d=e=>null==e,c=(e,n,t)=>d(e)?null==t?void 0:t():n(e),s=e=>n(e)==r,v=(e,n,t)=>e.slice(n,t),y=e=>e.length,f=e=>{return n=function*(){return u.all(e)},new Promise(((e,t)=>{var l=e=>{try{r(n.next(e))}catch(e){t(e)}},o=e=>{try{r(n.throw(e))}catch(e){t(e)}},r=n=>n.done?e(n.value):Promise.resolve(n.value).then(l,o);r((n=n.apply(void 0,null)).next())}));var n},p=(e,n="")=>e.join(n),h=(e,n)=>e.map(n),m=e=>0==y(e),E=(e,n)=>e.filter(n),b=(e,...n)=>e.push(...n),O=(e,n)=>{var t;return null!=(t=null==e?void 0:e.has(n))&&t},P=e=>{var n;return[...null!=(n=null==e?void 0:e.values())?n:[]]},w=(e,n)=>null==e?void 0:e.delete(n),T=Object,A=e=>T.getPrototypeOf(e),N=T.keys,S=T.freeze,R=(e=[])=>T.fromEntries(e),g=(...e)=>T.assign({},...e),x=(e,n)=>h(T.entries(e),(([e,t])=>n(t,e))),L=e=>T.values(e),C=e=>y(N(e)),I=e=>(e=>!d(e)&&c(A(e),(e=>e==T.prototype||d(A(e))),(()=>!0)))(e)&&0==C(e),j=e=>new Map(e),D=e=>{var n;return[...null!=(n=null==e?void 0:e.keys())?n:[]]},_=(e,n)=>null==e?void 0:e.get(n),$=(e,n)=>{var t;return h([...null!=(t=null==e?void 0:e.entries())?t:[]],(([e,t])=>n(t,e)))},M=(e,n,t)=>d(t)?(w(e,n),e):null==e?void 0:e.set(n,t),F=(e,n,t)=>(O(e,n)||M(e,n,t()),_(e,n)),k=(e,n,t,l=M)=>(x(n,((n,l)=>t(e,l,n))),((e,n)=>{((e,n)=>{null==e||e.forEach(n)})(e,((e,t)=>n(t)))})(e,(t=>((e,n)=>!d(((e,n)=>c(e,(e=>e[n])))(e,n)))(n,t)?0:l(e,t))),e),q="_",B="_id",W=e=>`"${e.replace(/"/g,'""')}"`,H="SELECT",J=e=>new Set(Array.isArray(e)||d(e)?e:[e]),Y=(e,n)=>null==e?void 0:e.add(n);var G=Object.defineProperty,U=Object.getOwnPropertySymbols,V=Object.prototype.hasOwnProperty,z=Object.prototype.propertyIsEnumerable,K=(e,n,t)=>n in e?G(e,n,{enumerable:!0,configurable:!0,writable:!0,value:t}):e[n]=t,Q=(e,n)=>{for(var t in n||(n={}))V.call(n,t)&&K(e,t,n[t]);if(U)for(var t of U(n))z.call(n,t)&&K(e,t,n[t]);return e},X=(e,n,t)=>new Promise(((l,o)=>{var r=e=>{try{u(t.next(e))}catch(e){o(e)}},i=e=>{try{u(t.throw(e))}catch(e){o(e)}},u=e=>e.done?l(e.value):Promise.resolve(e.value).then(r,i);u((t=t.apply(e,n)).next())}));const Z="TABLE",ee="ALTER "+Z,ne="DELETE FROM",te=H+"*FROM",le="FROM pragma_table_",oe="WHERE",re=(e,n,t,r)=>{const i=j();return[()=>X(void 0,null,(function*(){return k(i,R(yield f(h(yield e("SELECT name "+le+"list WHERE schema='main'AND(type='table'OR type='view')AND name IN("+ue(n)+")ORDER BY name",n),(n=>X(void 0,[n],(function*({name:n}){return[n,R(h(yield e(H+" name,type "+le+"info(?)",[n]),(({name:e,type:n})=>[e,n])))]})))))),((e,n,t)=>M(i,n,k(F(i,n,j),t,((e,n,t)=>{t!=_(e,n)&&M(e,n,t)}),((e,n)=>M(e,n))))),((e,n)=>M(i,n)))})),(n,t)=>X(void 0,null,(function*(){return((e,n)=>!d(_(_(i,e),n)))(n,t)?R(E(h(yield e(te+W(n)),(e=>{return[e[t],(n=Q({},e),l=t,delete n[l],n)];var n,l})),(([e,n])=>!d(e)&&!I(n)))):{}})),(n,t,u,a,c,s=!1)=>X(void 0,null,(function*(){const v=J();x(null!=u?u:{},(e=>h(N(null!=e?e:{}),(e=>Y(v,e)))));const y=P(v);if(!s&&c&&m(y)&&O(i,n))return yield e("DROP "+Z+W(n)),void M(i,n);if(m(y)||O(i,n)){const o=_(i,n),r=J(D(o));yield f([...h(y,(t=>X(void 0,null,(function*(){w(r,t)||(yield e(ee+W(n)+"ADD"+W(t)),M(o,t,l))})))),...!s&&a?h(P(r),(l=>X(void 0,null,(function*(){l!=t&&(yield e(ee+W(n)+"DROP"+W(l)),M(o,l))})))):[]])}else yield e("CREATE "+Z+W(n)+"("+W(t)+` PRIMARY KEY ON CONFLICT REPLACE${p(h(y,(e=>o+W(e))))});`),M(i,n,j([[t,l],...h(y,(e=>[e,l]))]));if(s)d(u)?yield e(ne+W(n)+oe+" 1"):yield f(x(u,((l,o)=>X(void 0,null,(function*(){d(l)?yield e(ne+W(n)+oe+W(t)+"=?",[o]):m(y)||(yield ie(e,n,t,N(l),[o,...L(l)],r))})))));else if(m(y))O(i,n)&&(yield e(ne+W(n)+oe+" 1"));else{const l=E(D(_(i,n)),(e=>e!=t)),o=[],a=[];x(null!=u?u:{},((e,n)=>{b(o,n,...h(l,(n=>null==e?void 0:e[n]))),b(a,n)})),yield ie(e,n,t,l,o,r),yield e(ne+W(n)+oe+W(t)+"NOT IN("+ue(a)+")",a)}})),n=>X(void 0,null,(function*(){let l;yield e("BEGIN");try{l=yield n()}catch(e){null==t||t(e)}return yield e("END"),l}))]},ie=(e,n,t,r,u,a=!0)=>X(void 0,null,(function*(){return yield e("INSERT "+(a?l:"OR REPLACE ")+"INTO"+W(n)+"("+W(t)+p(h(r,(e=>o+W(e))))+")VALUES"+v(i(`,(?${i(",?",y(r))})`,y(u)/(y(r)+1)),1)+(a?"ON CONFLICT("+W(t)+")DO UPDATE SET"+p(h(r,(e=>W(e)+"=excluded."+W(e))),o):l),h(u,(e=>null!=e?e:null)))})),ue=e=>p(h(e,(()=>"?")),o),ae=JSON.parse;var de=(e,n,t)=>new Promise(((l,o)=>{var r=e=>{try{u(t.next(e))}catch(e){o(e)}},i=e=>{try{u(t.throw(e))}catch(e){o(e)}},u=e=>e.done?l(e.value):Promise.resolve(e.value).then(r,i);u((t=t.apply(e,n)).next())}));const ce=j(),se=j(),ve=(e,n,t,l,o,r,[i,u]=[],a=[])=>{let s,v,y,f=0,p=0;F(ce,a,(()=>0)),F(se,a,(()=>[]));const h=e=>de(void 0,null,(function*(){return 2!=f&&(f=1,yield m.schedule((()=>de(void 0,null,(function*(){yield e(),f=0}))))),m})),m={load:(t,l)=>de(void 0,null,(function*(){return yield h((()=>de(void 0,null,(function*(){try{e.setContent(yield n())}catch(n){e.setContent([t,l])}}))))})),startAutoLoad:(...t)=>de(void 0,[...t],(function*(t={},o={}){return m.stopAutoLoad(),yield m.load(t,o),p=1,y=l(((t,l)=>de(void 0,null,(function*(){if(l){const n=l();yield h((()=>de(void 0,null,(function*(){return e.setTransactionChanges(n)}))))}else yield h((()=>de(void 0,null,(function*(){var l;try{e.setContent(null!=(l=null==t?void 0:t())?l:yield n())}catch(e){null==r||r(e)}}))))})))),m})),stopAutoLoad:()=>(p&&(o(y),y=void 0,p=0),m),save:n=>de(void 0,null,(function*(){return 1!=f&&(f=2,yield m.schedule((()=>de(void 0,null,(function*(){try{yield t(e.getContent,n)}catch(e){null==r||r(e)}f=0}))))),m})),startAutoSave:()=>de(void 0,null,(function*(){return yield m.stopAutoSave().save(),s=e.addDidFinishTransactionListener(((e,n)=>{const[t,l]=n();I(t)&&I(l)||m.save((()=>[t,l]))})),m})),stopAutoSave:()=>(c(s,e.delListener),s=void 0,m),schedule:(...e)=>de(void 0,null,(function*(){return b(_(se,a),...e),yield de(void 0,null,(function*(){if(!_(ce,a)){for(M(ce,a,1);!d((e=_(se,a),v=e.shift()));)try{yield v()}catch(e){null==r||r(e)}M(ce,a,0)}var e})),m})),getStore:()=>e,destroy:()=>m.stopAutoLoad().stopAutoSave(),getStats:()=>({})};return i&&(m[i]=()=>u),S(m)};var ye=(e,n,t)=>new Promise(((l,o)=>{var r=e=>{try{u(t.next(e))}catch(e){o(e)}},i=e=>{try{u(t.throw(e))}catch(e){o(e)}},u=e=>e.done?l(e.value):Promise.resolve(e.value).then(r,i);u((t=t.apply(e,n)).next())}));const fe="store",pe=(e,n,t,l,o,[r],i,u,a,d)=>{const[c,s,v,y]=re(n,i,o,d);return ve(e,(()=>ye(void 0,null,(function*(){return yield y((()=>ye(void 0,null,(function*(){var e,n;return yield c(),ae(null!=(n=null==(e=(yield s(r,B))[q])?void 0:e[fe])?n:"null")}))))}))),(e=>ye(void 0,null,(function*(){return yield y((()=>ye(void 0,null,(function*(){var n,t;yield c(),yield v(r,B,{[q]:{[fe]:(t=null!=(n=e())?n:null,JSON.stringify(t,((e,n)=>n instanceof Map?T.fromEntries([...n]):n)))}},!0,!0)}))))}))),t,l,o,[a,u],u)};var he=(e,n,t)=>new Promise(((l,o)=>{var r=e=>{try{u(t.next(e))}catch(e){o(e)}},i=e=>{try{u(t.throw(e))}catch(e){o(e)}},u=e=>e.done?l(e.value):Promise.resolve(e.value).then(r,i);u((t=t.apply(e,n)).next())}));const me=(e,n,t,l,o,[r,i,[u,a,c]],s,v,y,p)=>{const[h,m,b,O]=re(n,s,o,p),P=(e,n)=>he(void 0,null,(function*(){return yield f($(i,((t,l)=>he(void 0,[t,l],(function*([t,l,o,r],i){const u=e[i];n&&void 0===u||(yield b(t,l,u,o,r,n))})))))})),w=(e,n)=>he(void 0,null,(function*(){return a?yield b(c,B,{[q]:e},!0,!0,n):null}));return ve(e,(()=>he(void 0,null,(function*(){return yield O((()=>he(void 0,null,(function*(){yield h();const e=yield he(void 0,null,(function*(){return R(E(yield f($(r,((e,n)=>he(void 0,[e,n],(function*([e,n],t){return[e,yield m(t,n)]}))))),(e=>!I(e[1]))))})),n=yield he(void 0,null,(function*(){return u?(yield m(c,B))[q]:{}}));return I(e)&&d(n)?void 0:[e,n]}))))}))),((e,n)=>he(void 0,null,(function*(){return yield O((()=>he(void 0,null,(function*(){if(yield h(),d(n)){const[n,t]=e();yield P(n),yield w(t)}else{const[e,t]=n();yield P(e,!0),yield w(t,!0)}}))))}))),t,l,o,[y,v],v)},Ee="json",be="autoLoadIntervalSeconds",Oe="rowIdColumnName",Pe="tableId",we="tableName",Te={mode:Ee,[be]:1},Ae={load:0,save:0,[we]:t+"_values"},Ne=(e,n,t,l)=>{const o=j();return x(e,((e,r)=>{const i=v(L(g(n,s(e)?{[t]:e}:e)),0,C(n));d(i[0])||l(r,i[0])||M(o,r,i)})),o};var Se=(e,n,t)=>new Promise(((l,o)=>{var r=e=>{try{u(t.next(e))}catch(e){o(e)}},i=e=>{try{u(t.throw(e))}catch(e){o(e)}},u=e=>e.done?l(e.value):Promise.resolve(e.value).then(r,i);u((t=t.apply(e,n)).next())}));const Re="pragma_",ge="data_version",xe="schema_version",Le=(e,n,l,o,r,i,u,d,c="getDb",y)=>{let f,p,h;const[m,E,b,O]=(e=>{const n=(e=>g(Te,s(e)?{storeTableName:e}:null!=e?e:{}))(e),l=n[be];if(n.mode==Ee){const{storeTableName:e=t}=n;return[1,l,[e],J(e)]}const{tables:{load:o={},save:r={}}={},values:i={}}=n,u=v(L(g(Ae,i)),0,C(Ae)),a=u[2],d=J(a);return[0,l,[Ne(o,{[Pe]:null,[Oe]:B},Pe,(e=>Y(d,e)&&e==a)),Ne(r,{[we]:null,[Oe]:B,deleteEmptyColumns:0,deleteEmptyTable:0},we,((e,n)=>Y(d,n)&&n==a)),u],d]})(n);return(m?pe:me)(e,i?(e,n)=>Se(void 0,null,(function*(){return i(e,n),yield l(e,n)})):l,(e=>{return[(n=()=>Se(void 0,null,(function*(){try{const[{d:n,s:t,c:o}]=yield l(`SELECT ${ge} d,${xe} s,TOTAL_CHANGES() c FROM ${Re}${ge} JOIN ${Re}${xe}`);n==(null!=f?f:f=n)&&t==(null!=p?p:p=t)&&o==(null!=h?h:h=o)||(e(),f=n,p=t)}catch(e){}})),t=E,n(),setInterval(n,1e3*t)),o((n=>O.has(n)?e():0))];var n,t}),(([e,n])=>{a(e),f=p=h=null,r(n)}),u,b,P(O),d,c,y)};var Ce=Object.defineProperty,Ie=Object.getOwnPropertySymbols,je=Object.prototype.hasOwnProperty,De=Object.prototype.propertyIsEnumerable,_e=(e,n,t)=>n in e?Ce(e,n,{enumerable:!0,configurable:!0,writable:!0,value:t}):e[n]=t;e.createSqliteWasmPersister=(e,n,t,l,o,r)=>Le(e,l,((e,...n)=>{return l=[e,...n],o=function*(e,n=[]){return t.exec(e,{bind:n,rowMode:"object",returnValue:"resultRows"}).map((e=>((e,n)=>{for(var t in n||(n={}))je.call(n,t)&&_e(e,t,n[t]);if(Ie)for(var t of Ie(n))De.call(n,t)&&_e(e,t,n[t]);return e})({},e)))},new Promise(((e,n)=>{var t=e=>{try{i(o.next(e))}catch(e){n(e)}},r=e=>{try{i(o.throw(e))}catch(e){n(e)}},i=n=>n.done?e(n.value):Promise.resolve(n.value).then(t,r);i((o=o.apply(void 0,l)).next())}));var l,o}),(e=>n.capi.sqlite3_update_hook(t,((n,t,l,o)=>e(o)),0)),(()=>n.capi.sqlite3_update_hook(t,(()=>0),0)),o,r,t)},"object"==typeof exports&&"undefined"!=typeof module?n(exports):"function"==typeof define&&define.amd?define(["exports"],n):n((e="undefined"!=typeof globalThis?globalThis:e||self).TinyBasePersisterSqliteWasm={});
@@ -1 +1 @@
1
- var e,n;e=this,n=function(e){"use strict";const n=e=>typeof e,l="tinybase",t="",o=",",r=n(t),i=(e,n)=>e.repeat(n),u=Promise,d=clearInterval,a=e=>null==e,c=(e,n,l)=>a(e)?null==l?void 0:l():n(e),s=e=>n(e)==r,v=(e,n,l)=>e.slice(n,l),y=e=>e.length,f=e=>{return n=function*(){return u.all(e)},new Promise(((e,l)=>{var t=e=>{try{r(n.next(e))}catch(e){l(e)}},o=e=>{try{r(n.throw(e))}catch(e){l(e)}},r=n=>n.done?e(n.value):Promise.resolve(n.value).then(t,o);r((n=n.apply(void 0,null)).next())}));var n},p="_",h="_id",m=e=>`"${e.replace(/"/g,'""')}"`,E="SELECT",P=(e,n="")=>e.join(n),O=(e,n)=>e.map(n),b=e=>0==y(e),A=(e,n)=>e.filter(n),T=(e,...n)=>e.push(...n),w=(e,n)=>{var l;return null!=(l=null==e?void 0:e.has(n))&&l},N=e=>{var n;return[...null!=(n=null==e?void 0:e.values())?n:[]]},S=(e,n)=>null==e?void 0:e.delete(n),g=Object,x=e=>g.getPrototypeOf(e),L=g.keys,R=g.freeze,C=(e=[])=>g.fromEntries(e),I=(...e)=>g.assign({},...e),D=(e,n)=>O(g.entries(e),(([e,l])=>n(l,e))),j=e=>g.values(e),_=e=>y(L(e)),F=e=>(e=>!a(e)&&c(x(e),(e=>e==g.prototype||a(x(e))),(()=>!0)))(e)&&0==_(e),M=e=>new Map(e),B=e=>{var n;return[...null!=(n=null==e?void 0:e.keys())?n:[]]},H=(e,n)=>null==e?void 0:e.get(n),Y=(e,n)=>{var l;return O([...null!=(l=null==e?void 0:e.entries())?l:[]],(([e,l])=>n(l,e)))},$=(e,n,l)=>a(l)?(S(e,n),e):null==e?void 0:e.set(n,l),k=(e,n,l)=>(w(e,n)||$(e,n,l()),H(e,n)),q=(e,n,l,t=$)=>(D(n,((n,t)=>l(e,t,n))),((e,n)=>{((e,n)=>{null==e||e.forEach(n)})(e,((e,l)=>n(l)))})(e,(l=>((e,n)=>!a(((e,n)=>c(e,(e=>e[n])))(e,n)))(n,l)?0:t(e,l))),e),G=e=>new Set(Array.isArray(e)||a(e)?e:[e]),J=(e,n)=>null==e?void 0:e.add(n);var U=Object.defineProperty,W=Object.getOwnPropertySymbols,z=Object.prototype.hasOwnProperty,K=Object.prototype.propertyIsEnumerable,V=(e,n,l)=>n in e?U(e,n,{enumerable:!0,configurable:!0,writable:!0,value:l}):e[n]=l,Q=(e,n)=>{for(var l in n||(n={}))z.call(n,l)&&V(e,l,n[l]);if(W)for(var l of W(n))K.call(n,l)&&V(e,l,n[l]);return e},X=(e,n,l)=>new Promise(((t,o)=>{var r=e=>{try{u(l.next(e))}catch(e){o(e)}},i=e=>{try{u(l.throw(e))}catch(e){o(e)}},u=e=>e.done?t(e.value):Promise.resolve(e.value).then(r,i);u((l=l.apply(e,n)).next())}));const Z="TABLE",ee="ALTER "+Z,ne="DELETE FROM",le=E+"*FROM",te="FROM pragma_table_",oe="WHERE",re=(e,n,l,r)=>{const i=M();return[()=>X(void 0,null,(function*(){return q(i,C(yield f(O(yield e("SELECT name "+te+"list WHERE schema='main'AND(type='table'OR type='view')AND name IN("+ue(n)+")ORDER BY name",n),(n=>X(void 0,[n],(function*({name:n}){return[n,C(O(yield e(E+" name,type "+te+"info(?)",[n]),(({name:e,type:n})=>[e,n])))]})))))),((e,n,l)=>$(i,n,q(k(i,n,M),l,((e,n,l)=>{l!=H(e,n)&&$(e,n,l)}),((e,n)=>$(e,n))))),((e,n)=>$(i,n)))})),(n,l)=>X(void 0,null,(function*(){return((e,n)=>!a(H(H(i,e),n)))(n,l)?C(A(O(yield e(le+m(n)),(e=>{return[e[l],(n=Q({},e),t=l,delete n[t],n)];var n,t})),(([e,n])=>!a(e)&&!F(n)))):{}})),(n,l,u,d,c,s=!1)=>X(void 0,null,(function*(){const v=G();D(null!=u?u:{},(e=>O(L(null!=e?e:{}),(e=>J(v,e)))));const y=N(v);if(!s&&c&&b(y)&&w(i,n))return yield e("DROP "+Z+m(n)),void $(i,n);if(b(y)||w(i,n)){const o=H(i,n),r=G(B(o));yield f([...O(y,(l=>X(void 0,null,(function*(){S(r,l)||(yield e(ee+m(n)+"ADD"+m(l)),$(o,l,t))})))),...!s&&d?O(N(r),(t=>X(void 0,null,(function*(){t!=l&&(yield e(ee+m(n)+"DROP"+m(t)),$(o,t))})))):[]])}else yield e("CREATE "+Z+m(n)+"("+m(l)+` PRIMARY KEY ON CONFLICT REPLACE${P(O(y,(e=>o+m(e))))});`),$(i,n,M([[l,t],...O(y,(e=>[e,t]))]));if(s)a(u)?yield e(ne+m(n)+oe+" 1"):yield f(D(u,((t,o)=>X(void 0,null,(function*(){a(t)?yield e(ne+m(n)+oe+m(l)+"=?",[o]):b(y)||(yield ie(e,n,l,L(t),[o,...j(t)],r))})))));else if(b(y))w(i,n)&&(yield e(ne+m(n)+oe+" 1"));else{const t=A(B(H(i,n)),(e=>e!=l)),o=[],d=[];D(null!=u?u:{},((e,n)=>{T(o,n,...O(t,(n=>null==e?void 0:e[n]))),T(d,n)})),yield ie(e,n,l,t,o,r),yield e(ne+m(n)+oe+m(l)+"NOT IN("+ue(d)+")",d)}})),n=>X(void 0,null,(function*(){let t;yield e("BEGIN");try{t=yield n()}catch(e){null==l||l(e)}return yield e("END"),t}))]},ie=(e,n,l,r,u,d=!0)=>X(void 0,null,(function*(){return yield e("INSERT "+(d?t:"OR REPLACE ")+"INTO"+m(n)+"("+m(l)+P(O(r,(e=>o+m(e))))+")VALUES"+v(i(`,(?${i(",?",y(r))})`,y(u)/(y(r)+1)),1)+(d?"ON CONFLICT("+m(l)+")DO UPDATE SET"+P(O(r,(e=>m(e)+"=excluded."+m(e))),o):t),O(u,(e=>null!=e?e:null)))})),ue=e=>P(O(e,(()=>"?")),o),de=JSON.parse;var ae=(e,n,l)=>new Promise(((t,o)=>{var r=e=>{try{u(l.next(e))}catch(e){o(e)}},i=e=>{try{u(l.throw(e))}catch(e){o(e)}},u=e=>e.done?t(e.value):Promise.resolve(e.value).then(r,i);u((l=l.apply(e,n)).next())}));const ce=M(),se=M(),ve=(e,n,l,t,o,r,[i,u]=[],d=[])=>{let s,v,y,f=0,p=0;k(ce,d,(()=>0)),k(se,d,(()=>[]));const h=e=>ae(void 0,null,(function*(){return 2!=f&&(f=1,yield m.schedule((()=>ae(void 0,null,(function*(){yield e(),f=0}))))),m})),m={load:(l,t)=>ae(void 0,null,(function*(){return yield h((()=>ae(void 0,null,(function*(){try{e.setContent(yield n())}catch(n){e.setContent([l,t])}}))))})),startAutoLoad:(...l)=>ae(void 0,[...l],(function*(l={},o={}){return m.stopAutoLoad(),yield m.load(l,o),p=1,y=t(((l,t)=>ae(void 0,null,(function*(){if(t){const n=t();yield h((()=>ae(void 0,null,(function*(){return e.setTransactionChanges(n)}))))}else yield h((()=>ae(void 0,null,(function*(){var t;try{e.setContent(null!=(t=null==l?void 0:l())?t:yield n())}catch(e){null==r||r(e)}}))))})))),m})),stopAutoLoad:()=>(p&&(o(y),y=void 0,p=0),m),save:n=>ae(void 0,null,(function*(){return 1!=f&&(f=2,yield m.schedule((()=>ae(void 0,null,(function*(){try{yield l(e.getContent,n)}catch(e){null==r||r(e)}f=0}))))),m})),startAutoSave:()=>ae(void 0,null,(function*(){return yield m.stopAutoSave().save(),s=e.addDidFinishTransactionListener(((e,n)=>{const[l,t]=n();F(l)&&F(t)||m.save((()=>[l,t]))})),m})),stopAutoSave:()=>(c(s,e.delListener),s=void 0,m),schedule:(...e)=>ae(void 0,null,(function*(){return T(H(se,d),...e),yield ae(void 0,null,(function*(){if(!H(ce,d)){for($(ce,d,1);!a((e=H(se,d),v=e.shift()));)try{yield v()}catch(e){null==r||r(e)}$(ce,d,0)}var e})),m})),getStore:()=>e,destroy:()=>m.stopAutoLoad().stopAutoSave(),getStats:()=>({})};return i&&(m[i]=()=>u),R(m)};var ye=(e,n,l)=>new Promise(((t,o)=>{var r=e=>{try{u(l.next(e))}catch(e){o(e)}},i=e=>{try{u(l.throw(e))}catch(e){o(e)}},u=e=>e.done?t(e.value):Promise.resolve(e.value).then(r,i);u((l=l.apply(e,n)).next())}));const fe="store",pe=(e,n,l,t,o,[r],i,u,d,a)=>{const[c,s,v,y]=re(n,i,o,a);return ve(e,(()=>ye(void 0,null,(function*(){return yield y((()=>ye(void 0,null,(function*(){var e,n;return yield c(),de(null!=(n=null==(e=(yield s(r,h))[p])?void 0:e[fe])?n:"null")}))))}))),(e=>ye(void 0,null,(function*(){return yield y((()=>ye(void 0,null,(function*(){var n,l;yield c(),yield v(r,h,{[p]:{[fe]:(l=null!=(n=e())?n:null,JSON.stringify(l,((e,n)=>n instanceof Map?g.fromEntries([...n]):n)))}},!0,!0)}))))}))),l,t,o,[d,u],u)};var he=(e,n,l)=>new Promise(((t,o)=>{var r=e=>{try{u(l.next(e))}catch(e){o(e)}},i=e=>{try{u(l.throw(e))}catch(e){o(e)}},u=e=>e.done?t(e.value):Promise.resolve(e.value).then(r,i);u((l=l.apply(e,n)).next())}));const me=(e,n,l,t,o,[r,i,[u,d,c]],s,v,y,m)=>{const[E,P,O,b]=re(n,s,o,m),T=(e,n)=>he(void 0,null,(function*(){return yield f(Y(i,((l,t)=>he(void 0,[l,t],(function*([l,t,o,r],i){const u=e[i];n&&void 0===u||(yield O(l,t,u,o,r,n))})))))})),w=(e,n)=>he(void 0,null,(function*(){return d?yield O(c,h,{[p]:e},!0,!0,n):null}));return ve(e,(()=>he(void 0,null,(function*(){return yield b((()=>he(void 0,null,(function*(){yield E();const e=yield he(void 0,null,(function*(){return C(A(yield f(Y(r,((e,n)=>he(void 0,[e,n],(function*([e,n],l){return[e,yield P(l,n)]}))))),(e=>!F(e[1]))))})),n=yield he(void 0,null,(function*(){return u?(yield P(c,h))[p]:{}}));return F(e)&&a(n)?void 0:[e,n]}))))}))),((e,n)=>he(void 0,null,(function*(){return yield b((()=>he(void 0,null,(function*(){if(yield E(),a(n)){const[n,l]=e();yield T(n),yield w(l)}else{const[e,l]=n();yield T(e,!0),yield w(l,!0)}}))))}))),l,t,o,[y,v],v)},Ee="json",Pe="autoLoadIntervalSeconds",Oe="rowIdColumnName",be="tableId",Ae="tableName",Te={mode:Ee,[Pe]:1},we={load:0,save:0,[Ae]:l+"_values"},Ne=(e,n,l,t)=>{const o=M();return D(e,((e,r)=>{const i=v(j(I(n,s(e)?{[l]:e}:e)),0,_(n));a(i[0])||t(r,i[0])||$(o,r,i)})),o};var Se=(e,n,l)=>new Promise(((t,o)=>{var r=e=>{try{u(l.next(e))}catch(e){o(e)}},i=e=>{try{u(l.throw(e))}catch(e){o(e)}},u=e=>e.done?t(e.value):Promise.resolve(e.value).then(r,i);u((l=l.apply(e,n)).next())}));const ge="pragma ",xe="data_version",Le="schema_version",Re=(e,n,t,o,r,i,u,a,c="getDb",y)=>{let f,p,m;const[P,O,b,A]=(e=>{const n=(e=>I(Te,s(e)?{storeTableName:e}:null!=e?e:{}))(e),t=n[Pe];if(n.mode==Ee){const{storeTableName:e=l}=n;return[1,t,[e],G(e)]}const{tables:{load:o={},save:r={}}={},values:i={}}=n,u=v(j(I(we,i)),0,_(we)),d=u[2],a=G(d);return[0,t,[Ne(o,{[be]:null,[Oe]:h},be,(e=>J(a,e)&&e==d)),Ne(r,{[Ae]:null,[Oe]:h,deleteEmptyColumns:0,deleteEmptyTable:0},Ae,((e,n)=>J(a,n)&&n==d)),u],a]})(n);return(P?pe:me)(e,i?(e,n)=>Se(void 0,null,(function*(){return i(e,n),yield t(e,n)})):t,(e=>{return[(n=()=>Se(void 0,null,(function*(){try{const n=(yield t(ge+xe))[0][xe],l=(yield t(ge+Le))[0][Le],o=(yield t(E+" TOTAL_CHANGES() c"))[0].c;n==(null!=f?f:f=n)&&l==(null!=p?p:p=l)&&o==(null!=m?m:m=o)||(e(),f=n,p=l)}catch(e){}})),l=O,n(),setInterval(n,1e3*l)),o((n=>A.has(n)?e():0))];var n,l}),(([e,n])=>{d(e),f=p=null,r(n)}),u,b,N(A),a,c,y)},Ce="change";e.createSqlite3Persister=(e,n,l,t,o)=>Re(e,l,((e,...l)=>{return t=[e,...l],o=function*(e,l=[]){return yield(t=(t,o)=>n.all(e,l,((e,n)=>e?o(e):t(n))),new u(t));var t},new Promise(((e,n)=>{var l=e=>{try{i(o.next(e))}catch(e){n(e)}},r=e=>{try{i(o.throw(e))}catch(e){n(e)}},i=n=>n.done?e(n.value):Promise.resolve(n.value).then(l,r);i((o=o.apply(void 0,t)).next())}));var t,o}),(e=>{const l=(n,l,t)=>e(t);return n.on(Ce,l),l}),(e=>n.off(Ce,e)),t,o,n)},"object"==typeof exports&&"undefined"!=typeof module?n(exports):"function"==typeof define&&define.amd?define(["exports"],n):n((e="undefined"!=typeof globalThis?globalThis:e||self).TinyBasePersisterSqlite3={});
1
+ var e,n;e=this,n=function(e){"use strict";const n=e=>typeof e,t="tinybase",l="",o=",",r=n(l),i=(e,n)=>e.repeat(n),u=Promise,d=clearInterval,a=e=>null==e,c=(e,n,t)=>a(e)?null==t?void 0:t():n(e),s=e=>n(e)==r,v=(e,n,t)=>e.slice(n,t),y=e=>e.length,f=e=>{return n=function*(){return u.all(e)},new Promise(((e,t)=>{var l=e=>{try{r(n.next(e))}catch(e){t(e)}},o=e=>{try{r(n.throw(e))}catch(e){t(e)}},r=n=>n.done?e(n.value):Promise.resolve(n.value).then(l,o);r((n=n.apply(void 0,null)).next())}));var n},p=(e,n="")=>e.join(n),h=(e,n)=>e.map(n),m=e=>0==y(e),E=(e,n)=>e.filter(n),O=(e,...n)=>e.push(...n),P=(e,n)=>{var t;return null!=(t=null==e?void 0:e.has(n))&&t},T=e=>{var n;return[...null!=(n=null==e?void 0:e.values())?n:[]]},b=(e,n)=>null==e?void 0:e.delete(n),A=Object,w=e=>A.getPrototypeOf(e),N=A.keys,S=A.freeze,L=(e=[])=>A.fromEntries(e),R=(...e)=>A.assign({},...e),g=(e,n)=>h(A.entries(e),(([e,t])=>n(t,e))),x=e=>A.values(e),C=e=>y(N(e)),I=e=>(e=>!a(e)&&c(w(e),(e=>e==A.prototype||a(w(e))),(()=>!0)))(e)&&0==C(e),D=e=>new Map(e),$=e=>{var n;return[...null!=(n=null==e?void 0:e.keys())?n:[]]},_=(e,n)=>null==e?void 0:e.get(n),j=(e,n)=>{var t;return h([...null!=(t=null==e?void 0:e.entries())?t:[]],(([e,t])=>n(t,e)))},F=(e,n,t)=>a(t)?(b(e,n),e):null==e?void 0:e.set(n,t),M=(e,n,t)=>(P(e,n)||F(e,n,t()),_(e,n)),B=(e,n,t,l=F)=>(g(n,((n,l)=>t(e,l,n))),((e,n)=>{((e,n)=>{null==e||e.forEach(n)})(e,((e,t)=>n(t)))})(e,(t=>((e,n)=>!a(((e,n)=>c(e,(e=>e[n])))(e,n)))(n,t)?0:l(e,t))),e),H="_",J="_id",Y=e=>`"${e.replace(/"/g,'""')}"`,k="SELECT",q=e=>new Set(Array.isArray(e)||a(e)?e:[e]),G=(e,n)=>null==e?void 0:e.add(n);var U=Object.defineProperty,W=Object.getOwnPropertySymbols,z=Object.prototype.hasOwnProperty,K=Object.prototype.propertyIsEnumerable,V=(e,n,t)=>n in e?U(e,n,{enumerable:!0,configurable:!0,writable:!0,value:t}):e[n]=t,Q=(e,n)=>{for(var t in n||(n={}))z.call(n,t)&&V(e,t,n[t]);if(W)for(var t of W(n))K.call(n,t)&&V(e,t,n[t]);return e},X=(e,n,t)=>new Promise(((l,o)=>{var r=e=>{try{u(t.next(e))}catch(e){o(e)}},i=e=>{try{u(t.throw(e))}catch(e){o(e)}},u=e=>e.done?l(e.value):Promise.resolve(e.value).then(r,i);u((t=t.apply(e,n)).next())}));const Z="TABLE",ee="ALTER "+Z,ne="DELETE FROM",te=k+"*FROM",le="FROM pragma_table_",oe="WHERE",re=(e,n,t,r)=>{const i=D();return[()=>X(void 0,null,(function*(){return B(i,L(yield f(h(yield e("SELECT name "+le+"list WHERE schema='main'AND(type='table'OR type='view')AND name IN("+ue(n)+")ORDER BY name",n),(n=>X(void 0,[n],(function*({name:n}){return[n,L(h(yield e(k+" name,type "+le+"info(?)",[n]),(({name:e,type:n})=>[e,n])))]})))))),((e,n,t)=>F(i,n,B(M(i,n,D),t,((e,n,t)=>{t!=_(e,n)&&F(e,n,t)}),((e,n)=>F(e,n))))),((e,n)=>F(i,n)))})),(n,t)=>X(void 0,null,(function*(){return((e,n)=>!a(_(_(i,e),n)))(n,t)?L(E(h(yield e(te+Y(n)),(e=>{return[e[t],(n=Q({},e),l=t,delete n[l],n)];var n,l})),(([e,n])=>!a(e)&&!I(n)))):{}})),(n,t,u,d,c,s=!1)=>X(void 0,null,(function*(){const v=q();g(null!=u?u:{},(e=>h(N(null!=e?e:{}),(e=>G(v,e)))));const y=T(v);if(!s&&c&&m(y)&&P(i,n))return yield e("DROP "+Z+Y(n)),void F(i,n);if(m(y)||P(i,n)){const o=_(i,n),r=q($(o));yield f([...h(y,(t=>X(void 0,null,(function*(){b(r,t)||(yield e(ee+Y(n)+"ADD"+Y(t)),F(o,t,l))})))),...!s&&d?h(T(r),(l=>X(void 0,null,(function*(){l!=t&&(yield e(ee+Y(n)+"DROP"+Y(l)),F(o,l))})))):[]])}else yield e("CREATE "+Z+Y(n)+"("+Y(t)+` PRIMARY KEY ON CONFLICT REPLACE${p(h(y,(e=>o+Y(e))))});`),F(i,n,D([[t,l],...h(y,(e=>[e,l]))]));if(s)a(u)?yield e(ne+Y(n)+oe+" 1"):yield f(g(u,((l,o)=>X(void 0,null,(function*(){a(l)?yield e(ne+Y(n)+oe+Y(t)+"=?",[o]):m(y)||(yield ie(e,n,t,N(l),[o,...x(l)],r))})))));else if(m(y))P(i,n)&&(yield e(ne+Y(n)+oe+" 1"));else{const l=E($(_(i,n)),(e=>e!=t)),o=[],d=[];g(null!=u?u:{},((e,n)=>{O(o,n,...h(l,(n=>null==e?void 0:e[n]))),O(d,n)})),yield ie(e,n,t,l,o,r),yield e(ne+Y(n)+oe+Y(t)+"NOT IN("+ue(d)+")",d)}})),n=>X(void 0,null,(function*(){let l;yield e("BEGIN");try{l=yield n()}catch(e){null==t||t(e)}return yield e("END"),l}))]},ie=(e,n,t,r,u,d=!0)=>X(void 0,null,(function*(){return yield e("INSERT "+(d?l:"OR REPLACE ")+"INTO"+Y(n)+"("+Y(t)+p(h(r,(e=>o+Y(e))))+")VALUES"+v(i(`,(?${i(",?",y(r))})`,y(u)/(y(r)+1)),1)+(d?"ON CONFLICT("+Y(t)+")DO UPDATE SET"+p(h(r,(e=>Y(e)+"=excluded."+Y(e))),o):l),h(u,(e=>null!=e?e:null)))})),ue=e=>p(h(e,(()=>"?")),o),de=JSON.parse;var ae=(e,n,t)=>new Promise(((l,o)=>{var r=e=>{try{u(t.next(e))}catch(e){o(e)}},i=e=>{try{u(t.throw(e))}catch(e){o(e)}},u=e=>e.done?l(e.value):Promise.resolve(e.value).then(r,i);u((t=t.apply(e,n)).next())}));const ce=D(),se=D(),ve=(e,n,t,l,o,r,[i,u]=[],d=[])=>{let s,v,y,f=0,p=0;M(ce,d,(()=>0)),M(se,d,(()=>[]));const h=e=>ae(void 0,null,(function*(){return 2!=f&&(f=1,yield m.schedule((()=>ae(void 0,null,(function*(){yield e(),f=0}))))),m})),m={load:(t,l)=>ae(void 0,null,(function*(){return yield h((()=>ae(void 0,null,(function*(){try{e.setContent(yield n())}catch(n){e.setContent([t,l])}}))))})),startAutoLoad:(...t)=>ae(void 0,[...t],(function*(t={},o={}){return m.stopAutoLoad(),yield m.load(t,o),p=1,y=l(((t,l)=>ae(void 0,null,(function*(){if(l){const n=l();yield h((()=>ae(void 0,null,(function*(){return e.setTransactionChanges(n)}))))}else yield h((()=>ae(void 0,null,(function*(){var l;try{e.setContent(null!=(l=null==t?void 0:t())?l:yield n())}catch(e){null==r||r(e)}}))))})))),m})),stopAutoLoad:()=>(p&&(o(y),y=void 0,p=0),m),save:n=>ae(void 0,null,(function*(){return 1!=f&&(f=2,yield m.schedule((()=>ae(void 0,null,(function*(){try{yield t(e.getContent,n)}catch(e){null==r||r(e)}f=0}))))),m})),startAutoSave:()=>ae(void 0,null,(function*(){return yield m.stopAutoSave().save(),s=e.addDidFinishTransactionListener(((e,n)=>{const[t,l]=n();I(t)&&I(l)||m.save((()=>[t,l]))})),m})),stopAutoSave:()=>(c(s,e.delListener),s=void 0,m),schedule:(...e)=>ae(void 0,null,(function*(){return O(_(se,d),...e),yield ae(void 0,null,(function*(){if(!_(ce,d)){for(F(ce,d,1);!a((e=_(se,d),v=e.shift()));)try{yield v()}catch(e){null==r||r(e)}F(ce,d,0)}var e})),m})),getStore:()=>e,destroy:()=>m.stopAutoLoad().stopAutoSave(),getStats:()=>({})};return i&&(m[i]=()=>u),S(m)};var ye=(e,n,t)=>new Promise(((l,o)=>{var r=e=>{try{u(t.next(e))}catch(e){o(e)}},i=e=>{try{u(t.throw(e))}catch(e){o(e)}},u=e=>e.done?l(e.value):Promise.resolve(e.value).then(r,i);u((t=t.apply(e,n)).next())}));const fe="store",pe=(e,n,t,l,o,[r],i,u,d,a)=>{const[c,s,v,y]=re(n,i,o,a);return ve(e,(()=>ye(void 0,null,(function*(){return yield y((()=>ye(void 0,null,(function*(){var e,n;return yield c(),de(null!=(n=null==(e=(yield s(r,J))[H])?void 0:e[fe])?n:"null")}))))}))),(e=>ye(void 0,null,(function*(){return yield y((()=>ye(void 0,null,(function*(){var n,t;yield c(),yield v(r,J,{[H]:{[fe]:(t=null!=(n=e())?n:null,JSON.stringify(t,((e,n)=>n instanceof Map?A.fromEntries([...n]):n)))}},!0,!0)}))))}))),t,l,o,[d,u],u)};var he=(e,n,t)=>new Promise(((l,o)=>{var r=e=>{try{u(t.next(e))}catch(e){o(e)}},i=e=>{try{u(t.throw(e))}catch(e){o(e)}},u=e=>e.done?l(e.value):Promise.resolve(e.value).then(r,i);u((t=t.apply(e,n)).next())}));const me=(e,n,t,l,o,[r,i,[u,d,c]],s,v,y,p)=>{const[h,m,O,P]=re(n,s,o,p),T=(e,n)=>he(void 0,null,(function*(){return yield f(j(i,((t,l)=>he(void 0,[t,l],(function*([t,l,o,r],i){const u=e[i];n&&void 0===u||(yield O(t,l,u,o,r,n))})))))})),b=(e,n)=>he(void 0,null,(function*(){return d?yield O(c,J,{[H]:e},!0,!0,n):null}));return ve(e,(()=>he(void 0,null,(function*(){return yield P((()=>he(void 0,null,(function*(){yield h();const e=yield he(void 0,null,(function*(){return L(E(yield f(j(r,((e,n)=>he(void 0,[e,n],(function*([e,n],t){return[e,yield m(t,n)]}))))),(e=>!I(e[1]))))})),n=yield he(void 0,null,(function*(){return u?(yield m(c,J))[H]:{}}));return I(e)&&a(n)?void 0:[e,n]}))))}))),((e,n)=>he(void 0,null,(function*(){return yield P((()=>he(void 0,null,(function*(){if(yield h(),a(n)){const[n,t]=e();yield T(n),yield b(t)}else{const[e,t]=n();yield T(e,!0),yield b(t,!0)}}))))}))),t,l,o,[y,v],v)},Ee="json",Oe="autoLoadIntervalSeconds",Pe="rowIdColumnName",Te="tableId",be="tableName",Ae={mode:Ee,[Oe]:1},we={load:0,save:0,[be]:t+"_values"},Ne=(e,n,t,l)=>{const o=D();return g(e,((e,r)=>{const i=v(x(R(n,s(e)?{[t]:e}:e)),0,C(n));a(i[0])||l(r,i[0])||F(o,r,i)})),o};var Se=(e,n,t)=>new Promise(((l,o)=>{var r=e=>{try{u(t.next(e))}catch(e){o(e)}},i=e=>{try{u(t.throw(e))}catch(e){o(e)}},u=e=>e.done?l(e.value):Promise.resolve(e.value).then(r,i);u((t=t.apply(e,n)).next())}));const Le="pragma_",Re="data_version",ge="schema_version",xe=(e,n,l,o,r,i,u,a,c="getDb",y)=>{let f,p,h;const[m,E,O,P]=(e=>{const n=(e=>R(Ae,s(e)?{storeTableName:e}:null!=e?e:{}))(e),l=n[Oe];if(n.mode==Ee){const{storeTableName:e=t}=n;return[1,l,[e],q(e)]}const{tables:{load:o={},save:r={}}={},values:i={}}=n,u=v(x(R(we,i)),0,C(we)),d=u[2],a=q(d);return[0,l,[Ne(o,{[Te]:null,[Pe]:J},Te,(e=>G(a,e)&&e==d)),Ne(r,{[be]:null,[Pe]:J,deleteEmptyColumns:0,deleteEmptyTable:0},be,((e,n)=>G(a,n)&&n==d)),u],a]})(n);return(m?pe:me)(e,i?(e,n)=>Se(void 0,null,(function*(){return i(e,n),yield l(e,n)})):l,(e=>{return[(n=()=>Se(void 0,null,(function*(){try{const[{d:n,s:t,c:o}]=yield l(`SELECT ${Re} d,${ge} s,TOTAL_CHANGES() c FROM ${Le}${Re} JOIN ${Le}${ge}`);n==(null!=f?f:f=n)&&t==(null!=p?p:p=t)&&o==(null!=h?h:h=o)||(e(),f=n,p=t)}catch(e){}})),t=E,n(),setInterval(n,1e3*t)),o((n=>P.has(n)?e():0))];var n,t}),(([e,n])=>{d(e),f=p=h=null,r(n)}),u,O,T(P),a,c,y)},Ce="change";e.createSqlite3Persister=(e,n,t,l,o)=>xe(e,t,((e,...t)=>{return l=[e,...t],o=function*(e,t=[]){return yield(l=(l,o)=>n.all(e,t,((e,n)=>e?o(e):l(n))),new u(l));var l},new Promise(((e,n)=>{var t=e=>{try{i(o.next(e))}catch(e){n(e)}},r=e=>{try{i(o.throw(e))}catch(e){n(e)}},i=n=>n.done?e(n.value):Promise.resolve(n.value).then(t,r);i((o=o.apply(void 0,l)).next())}));var l,o}),(e=>{const t=(n,t,l)=>e(l);return n.on(Ce,t),t}),(e=>n.off(Ce,e)),l,o,n)},"object"==typeof exports&&"undefined"!=typeof module?n(exports):"function"==typeof define&&define.amd?define(["exports"],n):n((e="undefined"!=typeof globalThis?globalThis:e||self).TinyBasePersisterSqlite3={});
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "tinybase",
3
- "version": "4.8.7",
3
+ "version": "4.8.8",
4
4
  "author": "jamesgpearce",
5
5
  "repository": "github:tinyplex/tinybase",
6
6
  "license": "MIT",
@@ -214,8 +214,8 @@
214
214
  "publishPackage": "gulp publishPackage"
215
215
  },
216
216
  "devDependencies": {
217
- "@automerge/automerge": "^2.2.1",
218
- "@automerge/automerge-repo": "^1.1.9",
217
+ "@automerge/automerge": "^2.2.2",
218
+ "@automerge/automerge-repo": "^1.1.12",
219
219
  "@babel/cli": "^7.24.5",
220
220
  "@babel/core": "^7.24.5",
221
221
  "@babel/preset-env": "^7.24.5",
@@ -227,21 +227,21 @@
227
227
  "@rollup/plugin-image": "^3.0.3",
228
228
  "@rollup/plugin-replace": "^5.0.5",
229
229
  "@rollup/plugin-terser": "^0.4.4",
230
- "@sqlite.org/sqlite-wasm": "^3.45.3-build1",
230
+ "@sqlite.org/sqlite-wasm": "^3.45.3-build2",
231
231
  "@types/asciichart": "^1.5.8",
232
232
  "@types/expect-puppeteer": "^5.0.6",
233
233
  "@types/http-server": "^0.12.4",
234
234
  "@types/jest": "^29.5.12",
235
235
  "@types/jest-environment-puppeteer": "^5.0.6",
236
236
  "@types/less": "^3.0.6",
237
- "@types/node": "^20.12.7",
237
+ "@types/node": "^20.12.12",
238
238
  "@types/puppeteer": "^5.4.7",
239
- "@types/react": "^18.3.1",
239
+ "@types/react": "^18.3.2",
240
240
  "@types/react-dom": "^18.3.0",
241
241
  "@types/react-test-renderer": "^18.3.0",
242
242
  "@types/tmp": "^0.2.6",
243
- "@typescript-eslint/eslint-plugin": "^7.8.0",
244
- "@typescript-eslint/parser": "^7.8.0",
243
+ "@typescript-eslint/eslint-plugin": "^7.9.0",
244
+ "@typescript-eslint/parser": "^7.9.0",
245
245
  "@vlcn.io/crsqlite-wasm": "^0.16.0",
246
246
  "asciichart": "^1.5.25",
247
247
  "babel-eslint": "^10.1.0",
@@ -251,13 +251,13 @@
251
251
  "babel-preset-minify": "^0.5.2",
252
252
  "buffer-replace": "^1.0.0",
253
253
  "country-flag-emoji-json": "^2.0.0",
254
- "cspell": "^8.7.0",
255
- "electric-sql": "^0.10.1",
256
- "esbuild": "^0.20.2",
254
+ "cspell": "^8.8.1",
255
+ "electric-sql": "^0.11.3",
256
+ "esbuild": "^0.21.2",
257
257
  "eslint": "^8.57.0",
258
258
  "eslint-config-prettier": "^9.1.0",
259
- "eslint-plugin-jest": "^28.3.0",
260
- "eslint-plugin-jsdoc": "^48.2.3",
259
+ "eslint-plugin-jest": "^28.5.0",
260
+ "eslint-plugin-jsdoc": "^48.2.4",
261
261
  "eslint-plugin-react": "7.34.1",
262
262
  "eslint-plugin-react-hooks": "^4.6.2",
263
263
  "expo-sqlite": "^13.2.1",
@@ -274,11 +274,11 @@
274
274
  "partykit": "^0.0.104",
275
275
  "partysocket": "^1.0.1",
276
276
  "prettier": "^3.2.5",
277
- "puppeteer": "22.7.1",
277
+ "puppeteer": "22.8.1",
278
278
  "react": "^18.3.1",
279
279
  "react-dom": "^18.3.1",
280
280
  "react-test-renderer": "^18.3.1",
281
- "rollup": "^4.17.1",
281
+ "rollup": "^4.17.2",
282
282
  "rollup-plugin-esbuild": "^6.1.1",
283
283
  "rollup-plugin-gzip": "^3.1.2",
284
284
  "rollup-plugin-preserve-shebang": "^1.0.1",
@@ -293,12 +293,12 @@
293
293
  "yjs": "^13.6.15"
294
294
  },
295
295
  "peerDependencies": {
296
- "@automerge/automerge-repo": "^1.1.9",
296
+ "@automerge/automerge-repo": "^1.1.12",
297
297
  "@journeyapps/powersync-sdk-common": "^1.6.0",
298
298
  "@libsql/client": "^0.5.6",
299
- "@sqlite.org/sqlite-wasm": "^3.45.3-build1",
299
+ "@sqlite.org/sqlite-wasm": "^3.45.3-build2",
300
300
  "@vlcn.io/crsqlite-wasm": "^0.16.0",
301
- "electric-sql": "^0.10.1",
301
+ "electric-sql": "^0.11.3",
302
302
  "expo-sqlite": "^13.2.1",
303
303
  "partykit": "^0.0.104",
304
304
  "partysocket": "^1.0.1",
package/readme.md CHANGED
@@ -1,4 +1,4 @@
1
- <section id="hero"><h2 id="the-reactive-data-store-for-local-first-apps">The <em>reactive</em> data store for <span>local-first apps</span>.</h2><p id="copy">Build blisteringly fast web apps that work both online and offline. Manage your state locally, synchronize it to the cloud when you need to, or even make it collaborative. But, most importantly... have fun building stuff again!</p></section><p><a href="https://tinybase.org/guides/releases/#v4-8"><em>NEW!</em> v4.8 release</a> <span id="one-with">&quot;The One With PowerSync&quot;</span></p><p><a class="start" href="https://tinybase.org/guides/the-basics/getting-started/">Get started</a></p><p><a href="https://tinybase.org/demos/">Try the demos</a></p><p><a href="https://tinybase.org/api/store/interfaces/store/store/">Read the docs</a></p><hr><ul><li>Manage <a href="#start-with-a-simple-key-value-store">key-value data</a>, <a href="#level-up-to-use-tabular-data">tabular data</a> - or both - with optional <a href="#apply-schemas-to-tables-values">schematization</a> to model your app&#x27;s data structures.</li><li><a href="#register-granular-listeners">Flexibly reactive</a> to reconciled updates, so you only spend rendering cycles on things that change.</li><li><a href="#build-complex-queries-with-tinyql">Powerful query engine</a> to select, join, filter, group, sort and paginate data - reactively - and without SQL.</li><li>Built-in <a href="#create-indexes-for-fast-lookups">indexing</a>, <a href="#define-metrics-and-aggregations">metric aggregation</a>, <a href="#model-table-relationships">tabular relationships</a> - and even an <a href="#set-checkpoints-for-an-undo-stack">undo stack</a> for your app state.</li><li>Create <a href="#type-definitions-orm-like-apis">type definitions &amp; ORM-like APIs</a>, from schema or inference. <a href="#an-inspector-for-your-data">Inspect your data</a> (<em>new!</em>) directly in the browser.</li><li>Easily <a href="#persist-to-storage-sqlite-crdts">sync your data</a> to browser <a href="https://tinybase.org/api/persister-browser">storage</a>, <a href="https://tinybase.org/api/persister-indexed-db/">IndexedDB</a>, <a href="https://tinybase.org/guides/schemas-and-persistence/database-persistence/">SQLite</a>, <a href="https://tinybase.org/guides/schemas-and-persistence/synchronizing-data/">CRDTs</a>; and (<em>new!</em>) <a href="https://tinybase.org/api/persister-partykit-client/">PartyKit</a> and <a href="https://electric-sql.com/">ElectricSQL</a>.</li><li>Optional <a href="#call-hooks-to-bind-to-data">bindings to React</a> and (<em>new!</em>) <a href="#pre-built-reactive-components">pre-built components</a> that let you easily build fully reactive user interfaces.</li><li>Tiny by name, tiny by nature: <a href="#did-we-say-tiny">5.0kB - 9.4kB</a>, no dependencies. <a href="#well-tested-and-documented">100% tested</a>, <a href="https://tinybase.org/guides/the-basics/getting-started/">fully documented</a>, and of course, <a href="https://github.com/tinyplex/tinybase">open source</a>!</li></ul><hr><section id="friends"><h2 id="tinybase-works-great-on-its-own-but-also-plays-well-with-friends">TinyBase works great on its own, but also plays well with friends!</h2><div><a href="https://tinybase.org/guides/building-uis/getting-started-with-ui-react"><img width="48" src="https://tinybase.org/react.svg"> React</a></div><div><a href="https://tinybase.org/api/persister-partykit-client"><img width="48" src="https://tinybase.org/partykit.svg"> PartyKit</a></div><div><a href="https://tinybase.org/guides/schemas-and-persistence/database-persistence"><img width="48" src="https://tinybase.org/expo.svg">Expo SQLite</a></div><div><a href="https://tinybase.org/guides/schemas-and-persistence/database-persistence"><img width="48" src="https://tinybase.org/electric.svg">ElectricSQL</a></div><div><a href="https://tinybase.org/guides/schemas-and-persistence/database-persistence"><img width="48" src="https://tinybase.org/sqlite.svg"> SQLite</a></div><div><a href="https://tinybase.org/guides/schemas-and-persistence/database-persistence"><img width="48" src="https://tinybase.org/turso.svg">Turso</a></div><div><a href="https://tinybase.org/guides/schemas-and-persistence/database-persistence"><img width="48" src="https://tinybase.org/powersync.svg">PowerSync</a></div><div><a href="https://tinybase.org/api/persister-indexed-db/functions/creation/createindexeddbpersister"><img width="48" src="https://tinybase.org/indexeddb.svg"> IndexedDB</a></div><div><a href="https://tinybase.org/api/persister-yjs/functions/creation/createyjspersister"><img width="48" src="https://tinybase.org/yjs.svg"> YJS</a></div><div><a href="https://tinybase.org/api/persister-cr-sqlite-wasm"><img width="48" src="https://tinybase.org/crsqlite.png"> CR-SQLite</a></div><div><a href="https://tinybase.org/api/persister-automerge"><img width="48" src="https://tinybase.org/automerge.svg"> Automerge</a></div></section><hr><section id="follow"><a href="https://github.com/tinyplex/tinybase" target="_blank"><img src="https://img.shields.io/github/stars/tinyplex/tinybase?style=for-the-badge&amp;logo=GitHub&amp;logoColor=%23fff&amp;label=GitHub&amp;labelColor=%23d81b60&amp;color=%23333"> </a><a href="https://discord.com/invite/mGz3mevwP8" target="_blank"><img src="https://img.shields.io/discord/1027918215323590676?style=for-the-badge&amp;logo=discord&amp;logoColor=%23fff&amp;label=Discord&amp;labelColor=%233131e8&amp;color=%23333"> </a><a href="https://twitter.com/tinybasejs" target="_blank"><img src="https://img.shields.io/twitter/follow/tinybasejs?style=for-the-badge&amp;logo=x&amp;logoColor=%23fff&amp;label=Twitter&amp;labelColor=%23333&amp;color=%23333"></a><br><a href="https://github.com/tinyplex/tinybase/discussions" target="_blank"><img src="https://img.shields.io/github/discussions/tinyplex/tinybase?style=for-the-badge&amp;logo=GitHub&amp;logoColor=%23fff&amp;label=Ideas&amp;labelColor=%23d81b60&amp;color=%23333"> </a><a href="https://github.com/tinyplex/tinybase/issues" target="_blank"><img src="https://img.shields.io/github/issues/tinyplex/tinybase?style=for-the-badge&amp;logo=GitHub&amp;logoColor=%23fff&amp;label=Issues&amp;labelColor=%23d81b60&amp;color=%23333"> </a><a href="#well-tested-and-documented"><img src="https://img.shields.io/badge/Tests-100%25-green?style=for-the-badge&amp;logo=jest&amp;logoColor=%23fff&amp;color=%23333&amp;labelColor=%2387c305"> </a><a href="https://www.npmjs.com/package/tinybase/v/4.8.7" target="_blank"><img src="https://img.shields.io/npm/v/tinybase?style=for-the-badge&amp;logo=npm&amp;logoColor=%23fff&amp;labelColor=%23bd0005&amp;color=%23333"></a></section><hr><section><h2 id="start-with-a-simple-key-value-store">Start with a simple key-value store.</h2><p>Creating a <a href="https://tinybase.org/api/store/interfaces/store/store/"><code>Store</code></a> requires just a simple call to the <a href="https://tinybase.org/api/store/functions/creation/createstore/"><code>createStore</code></a> function. Once you have one, you can easily set <a href="https://tinybase.org/api/store/type-aliases/store/values/"><code>Values</code></a> in it by unique <a href="https://tinybase.org/api/common/type-aliases/identity/id/"><code>Id</code></a>. And of course you can easily get them back out again.</p><p>Read more about using keyed value data in <a href="https://tinybase.org/guides/the-basics/">The Basics</a> guide.</p></section>
1
+ <section id="hero"><h2 id="the-reactive-data-store-for-local-first-apps">The <em>reactive</em> data store for <span>local-first apps</span>.</h2><p id="copy">Build blisteringly fast web apps that work both online and offline. Manage your state locally, synchronize it to the cloud when you need to, or even make it collaborative. But, most importantly... have fun building stuff again!</p></section><p><a href="https://tinybase.org/guides/releases/#v4-8"><em>NEW!</em> v4.8 release</a> <span id="one-with">&quot;The One With PowerSync&quot;</span></p><p><a class="start" href="https://tinybase.org/guides/the-basics/getting-started/">Get started</a></p><p><a href="https://tinybase.org/demos/">Try the demos</a></p><p><a href="https://tinybase.org/api/store/interfaces/store/store/">Read the docs</a></p><hr><ul><li>Manage <a href="#start-with-a-simple-key-value-store">key-value data</a>, <a href="#level-up-to-use-tabular-data">tabular data</a> - or both - with optional <a href="#apply-schemas-to-tables-values">schematization</a> to model your app&#x27;s data structures.</li><li><a href="#register-granular-listeners">Flexibly reactive</a> to reconciled updates, so you only spend rendering cycles on things that change.</li><li><a href="#build-complex-queries-with-tinyql">Powerful query engine</a> to select, join, filter, group, sort and paginate data - reactively - and without SQL.</li><li>Built-in <a href="#create-indexes-for-fast-lookups">indexing</a>, <a href="#define-metrics-and-aggregations">metric aggregation</a>, <a href="#model-table-relationships">tabular relationships</a> - and even an <a href="#set-checkpoints-for-an-undo-stack">undo stack</a> for your app state.</li><li>Create <a href="#type-definitions-orm-like-apis">type definitions &amp; ORM-like APIs</a>, from schema or inference. <a href="#an-inspector-for-your-data">Inspect your data</a> (<em>new!</em>) directly in the browser.</li><li>Easily <a href="#persist-to-storage-sqlite-crdts">sync your data</a> to browser <a href="https://tinybase.org/api/persister-browser">storage</a>, <a href="https://tinybase.org/api/persister-indexed-db/">IndexedDB</a>, <a href="https://tinybase.org/guides/schemas-and-persistence/database-persistence/">SQLite</a>, <a href="https://tinybase.org/guides/schemas-and-persistence/synchronizing-data/">CRDTs</a>; and (<em>new!</em>) <a href="https://tinybase.org/api/persister-partykit-client/">PartyKit</a> and <a href="https://electric-sql.com/">ElectricSQL</a>.</li><li>Optional <a href="#call-hooks-to-bind-to-data">bindings to React</a> and (<em>new!</em>) <a href="#pre-built-reactive-components">pre-built components</a> that let you easily build fully reactive user interfaces.</li><li>Tiny by name, tiny by nature: <a href="#did-we-say-tiny">5.0kB - 9.4kB</a>, no dependencies. <a href="#well-tested-and-documented">100% tested</a>, <a href="https://tinybase.org/guides/the-basics/getting-started/">fully documented</a>, and of course, <a href="https://github.com/tinyplex/tinybase">open source</a>!</li></ul><hr><section id="friends"><h2 id="tinybase-works-great-on-its-own-but-also-plays-well-with-friends">TinyBase works great on its own, but also plays well with friends!</h2><div><a href="https://tinybase.org/guides/building-uis/getting-started-with-ui-react"><img width="48" src="https://tinybase.org/react.svg"> React</a></div><div><a href="https://tinybase.org/api/persister-partykit-client"><img width="48" src="https://tinybase.org/partykit.svg"> PartyKit</a></div><div><a href="https://tinybase.org/guides/schemas-and-persistence/database-persistence"><img width="48" src="https://tinybase.org/expo.svg">Expo SQLite</a></div><div><a href="https://tinybase.org/guides/schemas-and-persistence/database-persistence"><img width="48" src="https://tinybase.org/electric.svg">ElectricSQL</a></div><div><a href="https://tinybase.org/guides/schemas-and-persistence/database-persistence"><img width="48" src="https://tinybase.org/sqlite.svg"> SQLite</a></div><div><a href="https://tinybase.org/guides/schemas-and-persistence/database-persistence"><img width="48" src="https://tinybase.org/turso.svg">Turso</a></div><div><a href="https://tinybase.org/guides/schemas-and-persistence/database-persistence"><img width="48" src="https://tinybase.org/powersync.svg">PowerSync</a></div><div><a href="https://tinybase.org/api/persister-indexed-db/functions/creation/createindexeddbpersister"><img width="48" src="https://tinybase.org/indexeddb.svg"> IndexedDB</a></div><div><a href="https://tinybase.org/api/persister-yjs/functions/creation/createyjspersister"><img width="48" src="https://tinybase.org/yjs.svg"> YJS</a></div><div><a href="https://tinybase.org/api/persister-cr-sqlite-wasm"><img width="48" src="https://tinybase.org/crsqlite.png"> CR-SQLite</a></div><div><a href="https://tinybase.org/api/persister-automerge"><img width="48" src="https://tinybase.org/automerge.svg"> Automerge</a></div></section><hr><section id="follow"><a href="https://github.com/tinyplex/tinybase" target="_blank"><img src="https://img.shields.io/github/stars/tinyplex/tinybase?style=for-the-badge&amp;logo=GitHub&amp;logoColor=%23fff&amp;label=GitHub&amp;labelColor=%23d81b60&amp;color=%23333"> </a><a href="https://discord.com/invite/mGz3mevwP8" target="_blank"><img src="https://img.shields.io/discord/1027918215323590676?style=for-the-badge&amp;logo=discord&amp;logoColor=%23fff&amp;label=Discord&amp;labelColor=%233131e8&amp;color=%23333"> </a><a href="https://twitter.com/tinybasejs" target="_blank"><img src="https://img.shields.io/twitter/follow/tinybasejs?style=for-the-badge&amp;logo=x&amp;logoColor=%23fff&amp;label=Twitter&amp;labelColor=%23333&amp;color=%23333"></a><br><a href="https://github.com/tinyplex/tinybase/discussions" target="_blank"><img src="https://img.shields.io/github/discussions/tinyplex/tinybase?style=for-the-badge&amp;logo=GitHub&amp;logoColor=%23fff&amp;label=Ideas&amp;labelColor=%23d81b60&amp;color=%23333"> </a><a href="https://github.com/tinyplex/tinybase/issues" target="_blank"><img src="https://img.shields.io/github/issues/tinyplex/tinybase?style=for-the-badge&amp;logo=GitHub&amp;logoColor=%23fff&amp;label=Issues&amp;labelColor=%23d81b60&amp;color=%23333"> </a><a href="#well-tested-and-documented"><img src="https://img.shields.io/badge/Tests-100%25-green?style=for-the-badge&amp;logo=jest&amp;logoColor=%23fff&amp;color=%23333&amp;labelColor=%2387c305"> </a><a href="https://www.npmjs.com/package/tinybase/v/4.8.8" target="_blank"><img src="https://img.shields.io/npm/v/tinybase?style=for-the-badge&amp;logo=npm&amp;logoColor=%23fff&amp;labelColor=%23bd0005&amp;color=%23333"></a></section><hr><section><h2 id="start-with-a-simple-key-value-store">Start with a simple key-value store.</h2><p>Creating a <a href="https://tinybase.org/api/store/interfaces/store/store/"><code>Store</code></a> requires just a simple call to the <a href="https://tinybase.org/api/store/functions/creation/createstore/"><code>createStore</code></a> function. Once you have one, you can easily set <a href="https://tinybase.org/api/store/type-aliases/store/values/"><code>Values</code></a> in it by unique <a href="https://tinybase.org/api/common/type-aliases/identity/id/"><code>Id</code></a>. And of course you can easily get them back out again.</p><p>Read more about using keyed value data in <a href="https://tinybase.org/guides/the-basics/">The Basics</a> guide.</p></section>
2
2
 
3
3
  ```js
4
4
  const store = createStore()