tinybase 4.6.8 → 4.6.10
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/lib/cjs/persisters/persister-cr-sqlite-wasm.cjs +1 -1
- package/lib/cjs/persisters/persister-cr-sqlite-wasm.cjs.gz +0 -0
- package/lib/cjs/persisters/persister-electric-sql.cjs +1 -1
- package/lib/cjs/persisters/persister-electric-sql.cjs.gz +0 -0
- package/lib/cjs/persisters/persister-expo-sqlite-next.cjs +1 -1
- package/lib/cjs/persisters/persister-expo-sqlite-next.cjs.gz +0 -0
- package/lib/cjs/persisters/persister-expo-sqlite.cjs +1 -1
- package/lib/cjs/persisters/persister-expo-sqlite.cjs.gz +0 -0
- package/lib/cjs/persisters/persister-sqlite-wasm.cjs +1 -1
- package/lib/cjs/persisters/persister-sqlite-wasm.cjs.gz +0 -0
- package/lib/cjs/persisters/persister-sqlite3.cjs +1 -1
- package/lib/cjs/persisters/persister-sqlite3.cjs.gz +0 -0
- package/lib/cjs-es6/persisters/persister-cr-sqlite-wasm.cjs +1 -1
- package/lib/cjs-es6/persisters/persister-cr-sqlite-wasm.cjs.gz +0 -0
- package/lib/cjs-es6/persisters/persister-electric-sql.cjs +1 -1
- package/lib/cjs-es6/persisters/persister-electric-sql.cjs.gz +0 -0
- package/lib/cjs-es6/persisters/persister-expo-sqlite-next.cjs +1 -1
- package/lib/cjs-es6/persisters/persister-expo-sqlite-next.cjs.gz +0 -0
- package/lib/cjs-es6/persisters/persister-expo-sqlite.cjs +1 -1
- package/lib/cjs-es6/persisters/persister-expo-sqlite.cjs.gz +0 -0
- package/lib/cjs-es6/persisters/persister-sqlite-wasm.cjs +1 -1
- package/lib/cjs-es6/persisters/persister-sqlite-wasm.cjs.gz +0 -0
- package/lib/cjs-es6/persisters/persister-sqlite3.cjs +1 -1
- package/lib/cjs-es6/persisters/persister-sqlite3.cjs.gz +0 -0
- package/lib/debug/persisters/persister-cr-sqlite-wasm.js +36 -19
- package/lib/debug/persisters/persister-electric-sql.js +36 -19
- package/lib/debug/persisters/persister-expo-sqlite-next.js +36 -19
- package/lib/debug/persisters/persister-expo-sqlite.js +36 -19
- package/lib/debug/persisters/persister-sqlite-wasm.js +36 -19
- package/lib/debug/persisters/persister-sqlite3.js +36 -19
- package/lib/es6/persisters/persister-cr-sqlite-wasm.js +1 -1
- package/lib/es6/persisters/persister-cr-sqlite-wasm.js.gz +0 -0
- package/lib/es6/persisters/persister-electric-sql.js +1 -1
- package/lib/es6/persisters/persister-electric-sql.js.gz +0 -0
- package/lib/es6/persisters/persister-expo-sqlite-next.js +1 -1
- package/lib/es6/persisters/persister-expo-sqlite-next.js.gz +0 -0
- package/lib/es6/persisters/persister-expo-sqlite.js +1 -1
- package/lib/es6/persisters/persister-expo-sqlite.js.gz +0 -0
- package/lib/es6/persisters/persister-sqlite-wasm.js +1 -1
- package/lib/es6/persisters/persister-sqlite-wasm.js.gz +0 -0
- package/lib/es6/persisters/persister-sqlite3.js +1 -1
- package/lib/es6/persisters/persister-sqlite3.js.gz +0 -0
- package/lib/persisters/persister-cr-sqlite-wasm.js +1 -1
- package/lib/persisters/persister-cr-sqlite-wasm.js.gz +0 -0
- package/lib/persisters/persister-electric-sql.js +1 -1
- package/lib/persisters/persister-electric-sql.js.gz +0 -0
- package/lib/persisters/persister-expo-sqlite-next.js +1 -1
- package/lib/persisters/persister-expo-sqlite-next.js.gz +0 -0
- package/lib/persisters/persister-expo-sqlite.js +1 -1
- package/lib/persisters/persister-expo-sqlite.js.gz +0 -0
- package/lib/persisters/persister-sqlite-wasm.js +1 -1
- package/lib/persisters/persister-sqlite-wasm.js.gz +0 -0
- package/lib/persisters/persister-sqlite3.js +1 -1
- package/lib/persisters/persister-sqlite3.js.gz +0 -0
- package/lib/umd/persisters/persister-cr-sqlite-wasm.js +1 -1
- package/lib/umd/persisters/persister-cr-sqlite-wasm.js.gz +0 -0
- package/lib/umd/persisters/persister-electric-sql.js +1 -1
- package/lib/umd/persisters/persister-electric-sql.js.gz +0 -0
- package/lib/umd/persisters/persister-expo-sqlite-next.js +1 -1
- package/lib/umd/persisters/persister-expo-sqlite-next.js.gz +0 -0
- package/lib/umd/persisters/persister-expo-sqlite.js +1 -1
- package/lib/umd/persisters/persister-expo-sqlite.js.gz +0 -0
- package/lib/umd/persisters/persister-sqlite-wasm.js +1 -1
- package/lib/umd/persisters/persister-sqlite-wasm.js.gz +0 -0
- package/lib/umd/persisters/persister-sqlite3.js +1 -1
- package/lib/umd/persisters/persister-sqlite3.js.gz +0 -0
- package/lib/umd-es6/persisters/persister-cr-sqlite-wasm.js +1 -1
- package/lib/umd-es6/persisters/persister-cr-sqlite-wasm.js.gz +0 -0
- package/lib/umd-es6/persisters/persister-electric-sql.js +1 -1
- package/lib/umd-es6/persisters/persister-electric-sql.js.gz +0 -0
- package/lib/umd-es6/persisters/persister-expo-sqlite-next.js +1 -1
- package/lib/umd-es6/persisters/persister-expo-sqlite-next.js.gz +0 -0
- package/lib/umd-es6/persisters/persister-expo-sqlite.js +1 -1
- package/lib/umd-es6/persisters/persister-expo-sqlite.js.gz +0 -0
- package/lib/umd-es6/persisters/persister-sqlite-wasm.js +1 -1
- package/lib/umd-es6/persisters/persister-sqlite-wasm.js.gz +0 -0
- package/lib/umd-es6/persisters/persister-sqlite3.js +1 -1
- package/lib/umd-es6/persisters/persister-sqlite3.js.gz +0 -0
- package/package.json +14 -14
- 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="
|
|
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,s=(e,n,t)=>d(e)?null==t?void 0:t():n(e),c=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="_id",h=e=>`"${e.replace(/"/g,'""')}"`,m="SELECT",T=(e,n="")=>e.join(n),O=(e,n)=>e.map(n),A=e=>0==y(e),P=(e,n)=>e.filter(n),b=(e,...n)=>e.push(...n),L=(e,n)=>{var t;return null!=(t=null==e?void 0:e.has(n))&&t},R=e=>{var n;return[...null!=(n=null==e?void 0:e.values())?n:[]]},w=(e,n)=>null==e?void 0:e.delete(n),x=Object,N=e=>x.getPrototypeOf(e),g=x.keys,S=x.freeze,C=(e=[])=>x.fromEntries(e),D=(...e)=>x.assign({},...e),I=(e,n)=>O(x.entries(e),(([e,t])=>n(t,e))),F=e=>x.values(e),M=e=>y(g(e)),$=e=>(e=>!d(e)&&s(N(e),(e=>e==x.prototype||d(N(e))),(()=>!0)))(e)&&0==M(e),j=e=>new Map(e),_=e=>{var n;return[...null!=(n=null==e?void 0:e.keys())?n:[]]},B=(e,n)=>null==e?void 0:e.get(n),H=(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)?(w(e,n),e):null==e?void 0:e.set(n,t),q=(e,n,t)=>(L(e,n)||W(e,n,t()),B(e,n)),Y=(e,n,t,l=W)=>(I(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)=>s(e,(e=>e[n])))(e,n)))(n,t)?0:l(e,t))),e),k=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,z=Object.prototype.hasOwnProperty,K=Object.prototype.propertyIsEnumerable,V=(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={}))z.call(n,t)&&V(e,t,n[t]);if(U)for(var t of U(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=m+"*FROM",ee="FROM pragma_table_",ne="WHERE",te=(e,n,t,r)=>{const i=j();return[()=>X(void 0,null,(function*(){return Y(i,C(yield f(O(yield e("SELECT name "+ee+"list WHERE schema='main'AND(type='table'OR type='view')AND name IN("+oe(n)+")ORDER BY name",n),(n=>X(void 0,[n],(function*({name:n}){return[n,C(O(yield e(m+" name,type "+ee+"info(?)",[n]),(({name:e,type:n})=>[e,n])))]})))))),((e,n,t)=>W(i,n,Y(q(i,n,j),t,((e,n,t)=>{t!=B(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(B(B(i,e),n)))(n,t)?C(P(O(yield e(Z+h(n)),(e=>{return[e[t],(n=Q({},e),l=t,delete n[l],n)];var n,l})),(([e,n])=>!d(e)&&!$(n)))):{}})),(n,t,u,a,s,c=!1)=>X(void 0,null,(function*(){const v=k();I(null!=u?u:{},(e=>O(g(null!=e?e:{}),(e=>G(v,e)))));const y=R(v);if(!c&&s&&A(y)&&L(i,n))return yield e("DROP TABLE"+h(n)),void W(i,n);if(A(y)||L(i,n)){const o=B(i,n),r=k(_(o));yield f([...O(y,(t=>X(void 0,null,(function*(){w(r,t)||(yield e(`ALTER TABLE${h(n)}ADD${h(t)}`),W(o,t,l))})))),...!c&&a?O(R(r),(l=>X(void 0,null,(function*(){l!=t&&(yield e(`ALTER TABLE${h(n)}DROP${h(l)}`),W(o,l))})))):[]])}else yield e(`CREATE TABLE${h(n)}(${h(t)} PRIMARY KEY ON CONFLICT REPLACE${T(O(y,(e=>o+h(e))))});`),W(i,n,j([[t,l],...O(y,(e=>[e,l]))]));if(c)d(u)?yield e("DELETE FROM"+h(n)+"WHERE 1"):yield f(I(u,((l,o)=>X(void 0,null,(function*(){d(l)?yield e("DELETE FROM"+h(n)+ne+h(t)+"=?",[o]):A(y)||(yield le(e,n,t,g(l),[o,...F(l)],r))})))));else if(A(y))L(i,n)&&(yield e("DELETE FROM"+h(n)+"WHERE 1"));else{const l=P(_(B(i,n)),(e=>e!=t)),o=[],r=[];I(null!=u?u:{},((e,n)=>{b(o,n,...O(l,(n=>null==e?void 0:e[n]))),b(r,n)})),yield le(e,n,t,l,o),yield e("DELETE FROM"+h(n)+ne+h(t)+"NOT IN("+oe(r)+")",r)}})),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}))]},le=(e,n,t,r,u,a=!0)=>X(void 0,null,(function*(){return yield e("INSERT "+(a?l:"OR REPLACE ")+"INTO"+h(n)+"("+h(t)+T(O(r,(e=>o+h(e))))+")VALUES"+v(i(`,(?${i(",?",y(r))})`,y(u)/(y(r)+1)),1)+(a?"ON CONFLICT("+h(t)+")DO UPDATE SET"+T(O(r,(e=>h(e)+"=excluded."+h(e))),o):l),u)})),oe=e=>T(O(e,(()=>"?")),o),re=JSON.parse;var ie=(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 ue=j(),ae=j(),de=(e,n,t,l,o,r,[i,u]=[],a=[])=>{let c,v,y,f=0,p=0;q(ue,a,(()=>0)),q(ae,a,(()=>[]));const E=e=>ie(void 0,null,(function*(){return 2!=f&&(f=1,yield h.schedule((()=>ie(void 0,null,(function*(){yield e(),f=0}))))),h})),h={load:(t,l)=>ie(void 0,null,(function*(){return yield E((()=>ie(void 0,null,(function*(){try{e.setContent(yield n())}catch(n){e.setContent([t,l])}}))))})),startAutoLoad:(...t)=>ie(void 0,[...t],(function*(t={},o={}){return h.stopAutoLoad(),yield h.load(t,o),p=1,y=l(((t,l)=>ie(void 0,null,(function*(){if(l){const n=l();yield E((()=>ie(void 0,null,(function*(){return e.setTransactionChanges(n)}))))}else yield E((()=>ie(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)}}))))})))),h})),stopAutoLoad:()=>(p&&(o(y),y=void 0,p=0),h),save:n=>ie(void 0,null,(function*(){return 1!=f&&(f=2,yield h.schedule((()=>ie(void 0,null,(function*(){try{yield t(e.getContent,n)}catch(e){null==r||r(e)}f=0}))))),h})),startAutoSave:()=>ie(void 0,null,(function*(){return yield h.stopAutoSave().save(),c=e.addDidFinishTransactionListener(((e,n)=>{const[t,l]=n();$(t)&&$(l)||h.save((()=>[t,l]))})),h})),stopAutoSave:()=>(s(c,e.delListener),c=void 0,h),schedule:(...e)=>ie(void 0,null,(function*(){return b(B(ae,a),...e),yield ie(void 0,null,(function*(){if(!B(ue,a)){for(W(ue,a,1);!d((e=B(ae,a),v=e.shift()));)try{yield v()}catch(e){null==r||r(e)}W(ue,a,0)}var e})),h})),getStore:()=>e,destroy:()=>h.stopAutoLoad().stopAutoSave(),getStats:()=>({})};return i&&(h[i]=()=>u),S(h)};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 ce="store",ve=(e,n,t,l,o,[r],i,u,a)=>{const[d,s,c,v]=te(n,i,o);return de(e,(()=>se(void 0,null,(function*(){return yield v((()=>se(void 0,null,(function*(){var e,n;return yield d(),re(null!=(n=null==(e=(yield s(r,E))[p])?void 0:e[ce])?n:"null")}))))}))),(e=>se(void 0,null,(function*(){return yield v((()=>se(void 0,null,(function*(){var n,t;yield d(),yield c(r,E,{[p]:{[ce]:(t=null!=(n=e())?n:null,JSON.stringify(t,((e,n)=>n instanceof Map?x.fromEntries([...n]):n)))}},!0,!0)}))))}))),t,l,o,[a,u],u)};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=(e,n,t,l,o,[r,i,[u,a,s]],c,v,y,h)=>{const[m,T,O,A]=te(n,c,o,h),b=(e,n)=>ye(void 0,null,(function*(){return yield f(H(i,((t,l)=>ye(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))})))))})),L=(e,n)=>ye(void 0,null,(function*(){return a?yield O(s,E,{[p]:e},!0,!0,n):null}));return de(e,(()=>ye(void 0,null,(function*(){return yield A((()=>ye(void 0,null,(function*(){yield m();const e=yield ye(void 0,null,(function*(){return C(P(yield f(H(r,((e,n)=>ye(void 0,[e,n],(function*([e,n],t){return[e,yield T(t,n)]}))))),(e=>!$(e[1]))))})),n=yield ye(void 0,null,(function*(){return u?(yield T(s,E))[p]:{}}));return $(e)&&d(n)?void 0:[e,n]}))))}))),((e,n)=>ye(void 0,null,(function*(){return yield A((()=>ye(void 0,null,(function*(){if(yield m(),d(n)){const[n,t]=e();yield b(n),yield L(t)}else{const[e,t]=n();yield b(e,!0),yield L(t,!0)}}))))}))),t,l,o,[y,v],v)},pe="json",Ee="autoLoadIntervalSeconds",he="rowIdColumnName",me="tableId",Te="tableName",Oe={mode:pe,[Ee]:1},Ae={load:0,save:0,[Te]:t+"_values"},Pe=(e,n,t,l)=>{const o=j();return I(e,((e,r)=>{const i=v(F(D(n,c(e)?{[t]:e}:e)),0,M(n));d(i[0])||l(r,i[0])||W(o,r,i)})),o};var be=(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",we="schema_version",xe=(e,n,l,o,r,i,u,d,s="getDb",y)=>{let f,p,h;const[T,O,A,P]=(e=>{const n=(e=>D(Oe,c(e)?{storeTableName:e}:null!=e?e:{}))(e),l=n[Ee];if(n.mode==pe){const{storeTableName:e=t}=n;return[1,l,[e],k(e)]}const{tables:{load:o={},save:r={}}={},values:i={}}=n,u=v(F(D(Ae,i)),0,M(Ae)),a=u[2],d=k(a);return[0,l,[Pe(o,{[me]:null,[he]:E},me,(e=>G(d,e)&&e==a)),Pe(r,{[Te]:null,[he]:E,deleteEmptyColumns:0,deleteEmptyTable:0},Te,((e,n)=>G(d,n)&&n==a)),u],d]})(n);return(T?ve:fe)(e,i?(e,n)=>be(void 0,null,(function*(){return i(e,n),yield l(e,n)})):l,(e=>{return[(n=()=>be(void 0,null,(function*(){try{const n=(yield l(Le+Re))[0][Re],t=(yield l(Le+we))[0][we],o=(yield l(m+" TOTAL_CHANGES() c"))[0].c;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=O,n(),setInterval(n,1e3*t)),o((n=>P.has(n)?e():0))];var n,t}),(([e,n])=>{a(e),f=p=null,r(n)}),u,A,R(P),d,s,y)};e.createExpoSqlitePersister=(e,n,t,l,o)=>xe(e,t,((e,...t)=>{return l=[e,...t],o=function*(e,t=[]){return(yield n.execAsync([{sql:e,args:t}],!1))[0].rows},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.onDatabaseChange((({tableName:n})=>e(n)))),(e=>e.remove()),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).TinyBasePersisterExpoSqlite={});
|
|
Binary file
|
|
@@ -1 +1 @@
|
|
|
1
|
-
var e,n;e=this,n=function(e){"use strict";const n=e=>typeof e,t="tinybase",l=",",o=n(""),r=(e,n)=>e.repeat(n),i=Promise,u=clearInterval,a=e=>null==e,d=(e,n,t)=>a(e)?null==t?void 0:t():n(e),c=e=>n(e)==o,s=(e,n,t)=>e.slice(n,t),v=e=>e.length,y=e=>{return n=function*(){return i.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},f="_",p="_id",h=e=>`"${e.replace(/"/g,'""')}"`,m="SELECT",E=(e,n="")=>e.join(n),b=(e,n)=>e.map(n),O=e=>0==v(e),T=(e,n)=>e.filter(n),P=(e,...n)=>e.push(...n),A=(e,n)=>{var t;return null!=(t=null==e?void 0:e.has(n))&&t},w=e=>{var n;return[...null!=(n=null==e?void 0:e.values())?n:[]]},L=(e,n)=>null==e?void 0:e.delete(n),R=Object,N=e=>R.getPrototypeOf(e),S=R.keys,g=R.freeze,x=(e=[])=>R.fromEntries(e),C=(...e)=>R.assign({},...e),D=(e,n)=>b(R.entries(e),(([e,t])=>n(t,e))),I=e=>R.values(e),j=e=>v(S(e)),_=e=>(e=>!a(e)&&d(N(e),(e=>e==R.prototype||a(N(e))),(()=>!0)))(e)&&0==j(e),M=e=>new Map(e),F=e=>{var n;return[...null!=(n=null==e?void 0:e.keys())?n:[]]},$=(e,n)=>null==e?void 0:e.get(n),B=(e,n)=>{var t;return b([...null!=(t=null==e?void 0:e.entries())?t:[]],(([e,t])=>n(t,e)))},W=(e,n,t)=>a(t)?(L(e,n),e):null==e?void 0:e.set(n,t),H=(e,n,t)=>(A(e,n)||W(e,n,t()),$(e,n)),k=(e,n,t,l=W)=>(D(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)=>d(e,(e=>e[n])))(e,n)))(n,t)?0:l(e,t))),e),q=e=>new Set(Array.isArray(e)||a(e)?e:[e]),Y=(e,n)=>null==e?void 0:e.add(n);var G=Object.defineProperty,J=Object.getOwnPropertySymbols,U=Object.prototype.hasOwnProperty,V=Object.prototype.propertyIsEnumerable,z=(e,n,t)=>n in e?G(e,n,{enumerable:!0,configurable:!0,writable:!0,value:t}):e[n]=t,K=(e,n)=>{for(var t in n||(n={}))U.call(n,t)&&z(e,t,n[t]);if(J)for(var t of J(n))V.call(n,t)&&z(e,t,n[t]);return e},Q=(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 X=m+"*FROM",Z="FROM pragma_table_",ee="WHERE",ne=(e,n,t)=>{const o=M();return[()=>Q(void 0,null,(function*(){return k(o,x(yield y(b(yield e("SELECT name "+Z+"list WHERE schema='main'AND type='table'AND name IN("+le(n)+")ORDER BY name",n),(n=>Q(void 0,[n],(function*({name:n}){return[n,x(b(yield e(m+" name,type "+Z+"info(?)",[n]),(({name:e,type:n})=>[e,n])))]})))))),((e,n,t)=>W(o,n,k(H(o,n,M),t,((e,n,t)=>{t!=$(e,n)&&W(e,n,t)}),((e,n)=>W(e,n))))),((e,n)=>W(o,n)))})),(n,t)=>Q(void 0,null,(function*(){return((e,n)=>!a($($(o,e),n)))(n,t)?x(T(b(yield e(X+h(n)),(e=>{return[e[t],(n=K({},e),l=t,delete n[l],n)];var n,l})),(([e,n])=>!a(e)&&!_(n)))):{}})),(n,t,r,i,u,d=!1)=>Q(void 0,null,(function*(){const c=q();D(null!=r?r:{},(e=>b(S(null!=e?e:{}),(e=>Y(c,e)))));const s=w(c);if(!d&&u&&O(s)&&A(o,n))return yield e("DROP TABLE"+h(n)),void W(o,n);if(O(s)||A(o,n)){const l=$(o,n),r=q(F(l));yield y([...b(s,(t=>Q(void 0,null,(function*(){L(r,t)||(yield e(`ALTER TABLE${h(n)}ADD${h(t)}`),W(l,t,""))})))),...!d&&i?b(w(r),(o=>Q(void 0,null,(function*(){o!=t&&(yield e(`ALTER TABLE${h(n)}DROP${h(o)}`),W(l,o))})))):[]])}else yield e(`CREATE TABLE${h(n)}(${h(t)} PRIMARY KEY ON CONFLICT REPLACE${E(b(s,(e=>l+h(e))))});`),W(o,n,M([[t,""],...b(s,(e=>[e,""]))]));if(d)a(r)?yield e("DELETE FROM"+h(n)+"WHERE 1"):yield y(D(r,((l,o)=>Q(void 0,null,(function*(){a(l)?yield e("DELETE FROM"+h(n)+ee+h(t)+"=?",[o]):O(s)||(yield te(e,n,t,S(l),[o,...I(l)]))})))));else if(O(s))A(o,n)&&(yield e("DELETE FROM"+h(n)+"WHERE 1"));else{const l=T(F($(o,n)),(e=>e!=t)),i=[],u=[];D(null!=r?r:{},((e,n)=>{P(i,n,...b(l,(n=>null==e?void 0:e[n]))),P(u,n)})),yield te(e,n,t,l,i),yield e("DELETE FROM"+h(n)+ee+h(t)+"NOT IN("+le(u)+")",u)}})),n=>Q(void 0,null,(function*(){let l;yield e("BEGIN");try{l=yield n()}catch(e){null==t||t(e)}return yield e("END"),l}))]},te=(e,n,t,o,i)=>Q(void 0,null,(function*(){return yield e("INSERT INTO"+h(n)+"("+h(t)+E(b(o,(e=>l+h(e))))+")VALUES"+s(r(`,(?${r(",?",v(o))})`,v(i)/(v(o)+1)),1)+"ON CONFLICT("+h(t)+")DO UPDATE SET"+E(b(o,(e=>h(e)+"=excluded."+h(e))),l),i)})),le=e=>E(b(e,(()=>"?")),l),oe=JSON.parse;var re=(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 ie=M(),ue=M(),ae=(e,n,t,l,o,r,[i,u]=[],c=[])=>{let s,v,y,f=0,p=0;H(ie,c,(()=>0)),H(ue,c,(()=>[]));const h=e=>re(void 0,null,(function*(){return 2!=f&&(f=1,yield m.schedule((()=>re(void 0,null,(function*(){yield e(),f=0}))))),m})),m={load:(t,l)=>re(void 0,null,(function*(){return yield h((()=>re(void 0,null,(function*(){try{e.setContent(yield n())}catch(n){e.setContent([t,l])}}))))})),startAutoLoad:(...t)=>re(void 0,[...t],(function*(t={},o={}){return m.stopAutoLoad(),yield m.load(t,o),p=1,y=l(((t,l)=>re(void 0,null,(function*(){if(l){const n=l();yield h((()=>re(void 0,null,(function*(){return e.setTransactionChanges(n)}))))}else yield h((()=>re(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=>re(void 0,null,(function*(){return 1!=f&&(f=2,yield m.schedule((()=>re(void 0,null,(function*(){try{yield t(e.getContent,n)}catch(e){null==r||r(e)}f=0}))))),m})),startAutoSave:()=>re(void 0,null,(function*(){return yield m.stopAutoSave().save(),s=e.addDidFinishTransactionListener(((e,n)=>{const[t,l]=n();_(t)&&_(l)||m.save((()=>[t,l]))})),m})),stopAutoSave:()=>(d(s,e.delListener),s=void 0,m),schedule:(...e)=>re(void 0,null,(function*(){return P($(ue,c),...e),yield re(void 0,null,(function*(){if(!$(ie,c)){for(W(ie,c,1);!a((e=$(ue,c),v=e.shift()));)try{yield v()}catch(e){null==r||r(e)}W(ie,c,0)}var e})),m})),getStore:()=>e,destroy:()=>m.stopAutoLoad().stopAutoSave(),getStats:()=>({})};return i&&(m[i]=()=>u),g(m)};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="store",se=(e,n,t,l,o,[r],i,u,a)=>{const[d,c,s,v]=ne(n,i,o);return ae(e,(()=>de(void 0,null,(function*(){return yield v((()=>de(void 0,null,(function*(){var e,n;return yield d(),oe(null!=(n=null==(e=(yield c(r,p))[f])?void 0:e[ce])?n:"null")}))))}))),(e=>de(void 0,null,(function*(){return yield v((()=>de(void 0,null,(function*(){var n,t;yield d(),yield s(r,p,{[f]:{[ce]:(t=null!=(n=e())?n:null,JSON.stringify(t,((e,n)=>n instanceof Map?R.fromEntries([...n]):n)))}},!0,!0)}))))}))),t,l,o,[a,u],u)};var ve=(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 ye=(e,n,t,l,o,[r,i,[u,d,c]],s,v,h)=>{const[m,E,b,O]=ne(n,s,o),P=(e,n)=>ve(void 0,null,(function*(){return yield y(B(i,((t,l)=>ve(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))})))))})),A=(e,n)=>ve(void 0,null,(function*(){return d?yield b(c,p,{[f]:e},!0,!0,n):null}));return ae(e,(()=>ve(void 0,null,(function*(){return yield O((()=>ve(void 0,null,(function*(){yield m();const e=yield ve(void 0,null,(function*(){return x(T(yield y(B(r,((e,n)=>ve(void 0,[e,n],(function*([e,n],t){return[e,yield E(t,n)]}))))),(e=>!_(e[1]))))})),n=yield ve(void 0,null,(function*(){return u?(yield E(c,p))[f]:{}}));return _(e)&&a(n)?void 0:[e,n]}))))}))),((e,n)=>ve(void 0,null,(function*(){return yield O((()=>ve(void 0,null,(function*(){if(yield m(),a(n)){const[n,t]=e();yield P(n),yield A(t)}else{const[e,t]=n();yield P(e,!0),yield A(t,!0)}}))))}))),t,l,o,[h,v],v)},fe="json",pe="autoLoadIntervalSeconds",he="rowIdColumnName",me="tableId",Ee="tableName",be={mode:fe,[pe]:1},Oe={load:0,save:0,[Ee]:t+"_values"},Te=(e,n,t,l)=>{const o=M();return D(e,((e,r)=>{const i=s(I(C(n,c(e)?{[t]:e}:e)),0,j(n));a(i[0])||l(r,i[0])||W(o,r,i)})),o};var Pe=(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 Ae="pragma ",we="data_version",Le="schema_version",Re=(e,n,l,o,r,i,a,d,v="getDb")=>{let y,f,h;const[E,b,O,T]=(e=>{const n=(e=>C(be,c(e)?{storeTableName:e}:null!=e?e:{}))(e),l=n[pe];if(n.mode==fe){const{storeTableName:e=t}=n;return[1,l,[e],q(e)]}const{tables:{load:o={},save:r={}}={},values:i={}}=n,u=s(I(C(Oe,i)),0,j(Oe)),a=u[2],d=q(a);return[0,l,[Te(o,{[me]:null,[he]:p},me,(e=>Y(d,e)&&e==a)),Te(r,{[Ee]:null,[he]:p,deleteEmptyColumns:0,deleteEmptyTable:0},Ee,((e,n)=>Y(d,n)&&n==a)),u],d]})(n);return(E?se:ye)(e,i?(e,n)=>Pe(void 0,null,(function*(){return i(e,n),yield l(e,n)})):l,(e=>{return[(n=()=>Pe(void 0,null,(function*(){try{const n=(yield l(Ae+we))[0][we],t=(yield l(Ae+Le))[0][Le],o=(yield l(m+" TOTAL_CHANGES() c"))[0].c;n==(null!=y?y:y=n)&&t==(null!=f?f:f=t)&&o==(null!=h?h:h=o)||(e(),y=n,f=t)}catch(e){}})),t=b,n(),setInterval(n,1e3*t)),o((n=>T.has(n)?e():0))];var n,t}),(([e,n])=>{u(e),y=f=null,r(n)}),a,O,w(T),d,v)};var Ne=Object.defineProperty,Se=Object.getOwnPropertySymbols,ge=Object.prototype.hasOwnProperty,xe=Object.prototype.propertyIsEnumerable,Ce=(e,n,t)=>n in e?Ne(e,n,{enumerable:!0,configurable:!0,writable:!0,value:t}):e[n]=t;e.createSqliteWasmPersister=(e,n,t,l,o,r)=>Re(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={}))ge.call(n,t)&&Ce(e,t,n[t]);if(Se)for(var t of Se(n))xe.call(n,t)&&Ce(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="_",h="_id",E=e=>`"${e.replace(/"/g,'""')}"`,m="SELECT",O=(e,n="")=>e.join(n),b=(e,n)=>e.map(n),P=e=>0==y(e),T=(e,n)=>e.filter(n),A=(e,...n)=>e.push(...n),w=(e,n)=>{var t;return null!=(t=null==e?void 0:e.has(n))&&t},L=e=>{var n;return[...null!=(n=null==e?void 0:e.values())?n:[]]},R=(e,n)=>null==e?void 0:e.delete(n),N=Object,S=e=>N.getPrototypeOf(e),g=N.keys,x=N.freeze,C=(e=[])=>N.fromEntries(e),D=(...e)=>N.assign({},...e),I=(e,n)=>b(N.entries(e),(([e,t])=>n(t,e))),j=e=>N.values(e),_=e=>y(g(e)),M=e=>(e=>!d(e)&&c(S(e),(e=>e==N.prototype||d(S(e))),(()=>!0)))(e)&&0==_(e),F=e=>new Map(e),$=e=>{var n;return[...null!=(n=null==e?void 0:e.keys())?n:[]]},B=(e,n)=>null==e?void 0:e.get(n),W=(e,n)=>{var t;return b([...null!=(t=null==e?void 0:e.entries())?t:[]],(([e,t])=>n(t,e)))},H=(e,n,t)=>d(t)?(R(e,n),e):null==e?void 0:e.set(n,t),k=(e,n,t)=>(w(e,n)||H(e,n,t()),B(e,n)),q=(e,n,t,l=H)=>(I(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),Y=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=m+"*FROM",ee="FROM pragma_table_",ne="WHERE",te=(e,n,t,r)=>{const i=F();return[()=>X(void 0,null,(function*(){return q(i,C(yield f(b(yield e("SELECT name "+ee+"list WHERE schema='main'AND(type='table'OR type='view')AND name IN("+oe(n)+")ORDER BY name",n),(n=>X(void 0,[n],(function*({name:n}){return[n,C(b(yield e(m+" name,type "+ee+"info(?)",[n]),(({name:e,type:n})=>[e,n])))]})))))),((e,n,t)=>H(i,n,q(k(i,n,F),t,((e,n,t)=>{t!=B(e,n)&&H(e,n,t)}),((e,n)=>H(e,n))))),((e,n)=>H(i,n)))})),(n,t)=>X(void 0,null,(function*(){return((e,n)=>!d(B(B(i,e),n)))(n,t)?C(T(b(yield e(Z+E(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=Y();I(null!=u?u:{},(e=>b(g(null!=e?e:{}),(e=>G(v,e)))));const y=L(v);if(!s&&c&&P(y)&&w(i,n))return yield e("DROP TABLE"+E(n)),void H(i,n);if(P(y)||w(i,n)){const o=B(i,n),r=Y($(o));yield f([...b(y,(t=>X(void 0,null,(function*(){R(r,t)||(yield e(`ALTER TABLE${E(n)}ADD${E(t)}`),H(o,t,l))})))),...!s&&a?b(L(r),(l=>X(void 0,null,(function*(){l!=t&&(yield e(`ALTER TABLE${E(n)}DROP${E(l)}`),H(o,l))})))):[]])}else yield e(`CREATE TABLE${E(n)}(${E(t)} PRIMARY KEY ON CONFLICT REPLACE${O(b(y,(e=>o+E(e))))});`),H(i,n,F([[t,l],...b(y,(e=>[e,l]))]));if(s)d(u)?yield e("DELETE FROM"+E(n)+"WHERE 1"):yield f(I(u,((l,o)=>X(void 0,null,(function*(){d(l)?yield e("DELETE FROM"+E(n)+ne+E(t)+"=?",[o]):P(y)||(yield le(e,n,t,g(l),[o,...j(l)],r))})))));else if(P(y))w(i,n)&&(yield e("DELETE FROM"+E(n)+"WHERE 1"));else{const l=T($(B(i,n)),(e=>e!=t)),o=[],r=[];I(null!=u?u:{},((e,n)=>{A(o,n,...b(l,(n=>null==e?void 0:e[n]))),A(r,n)})),yield le(e,n,t,l,o),yield e("DELETE FROM"+E(n)+ne+E(t)+"NOT IN("+oe(r)+")",r)}})),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}))]},le=(e,n,t,r,u,a=!0)=>X(void 0,null,(function*(){return yield e("INSERT "+(a?l:"OR REPLACE ")+"INTO"+E(n)+"("+E(t)+O(b(r,(e=>o+E(e))))+")VALUES"+v(i(`,(?${i(",?",y(r))})`,y(u)/(y(r)+1)),1)+(a?"ON CONFLICT("+E(t)+")DO UPDATE SET"+O(b(r,(e=>E(e)+"=excluded."+E(e))),o):l),u)})),oe=e=>O(b(e,(()=>"?")),o),re=JSON.parse;var ie=(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 ue=F(),ae=F(),de=(e,n,t,l,o,r,[i,u]=[],a=[])=>{let s,v,y,f=0,p=0;k(ue,a,(()=>0)),k(ae,a,(()=>[]));const h=e=>ie(void 0,null,(function*(){return 2!=f&&(f=1,yield E.schedule((()=>ie(void 0,null,(function*(){yield e(),f=0}))))),E})),E={load:(t,l)=>ie(void 0,null,(function*(){return yield h((()=>ie(void 0,null,(function*(){try{e.setContent(yield n())}catch(n){e.setContent([t,l])}}))))})),startAutoLoad:(...t)=>ie(void 0,[...t],(function*(t={},o={}){return E.stopAutoLoad(),yield E.load(t,o),p=1,y=l(((t,l)=>ie(void 0,null,(function*(){if(l){const n=l();yield h((()=>ie(void 0,null,(function*(){return e.setTransactionChanges(n)}))))}else yield h((()=>ie(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)}}))))})))),E})),stopAutoLoad:()=>(p&&(o(y),y=void 0,p=0),E),save:n=>ie(void 0,null,(function*(){return 1!=f&&(f=2,yield E.schedule((()=>ie(void 0,null,(function*(){try{yield t(e.getContent,n)}catch(e){null==r||r(e)}f=0}))))),E})),startAutoSave:()=>ie(void 0,null,(function*(){return yield E.stopAutoSave().save(),s=e.addDidFinishTransactionListener(((e,n)=>{const[t,l]=n();M(t)&&M(l)||E.save((()=>[t,l]))})),E})),stopAutoSave:()=>(c(s,e.delListener),s=void 0,E),schedule:(...e)=>ie(void 0,null,(function*(){return A(B(ae,a),...e),yield ie(void 0,null,(function*(){if(!B(ue,a)){for(H(ue,a,1);!d((e=B(ae,a),v=e.shift()));)try{yield v()}catch(e){null==r||r(e)}H(ue,a,0)}var e})),E})),getStore:()=>e,destroy:()=>E.stopAutoLoad().stopAutoSave(),getStats:()=>({})};return i&&(E[i]=()=>u),x(E)};var ce=(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 se="store",ve=(e,n,t,l,o,[r],i,u,a)=>{const[d,c,s,v]=te(n,i,o);return de(e,(()=>ce(void 0,null,(function*(){return yield v((()=>ce(void 0,null,(function*(){var e,n;return yield d(),re(null!=(n=null==(e=(yield c(r,h))[p])?void 0:e[se])?n:"null")}))))}))),(e=>ce(void 0,null,(function*(){return yield v((()=>ce(void 0,null,(function*(){var n,t;yield d(),yield s(r,h,{[p]:{[se]:(t=null!=(n=e())?n:null,JSON.stringify(t,((e,n)=>n instanceof Map?N.fromEntries([...n]):n)))}},!0,!0)}))))}))),t,l,o,[a,u],u)};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=(e,n,t,l,o,[r,i,[u,a,c]],s,v,y,E)=>{const[m,O,b,P]=te(n,s,o,E),A=(e,n)=>ye(void 0,null,(function*(){return yield f(W(i,((t,l)=>ye(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)=>ye(void 0,null,(function*(){return a?yield b(c,h,{[p]:e},!0,!0,n):null}));return de(e,(()=>ye(void 0,null,(function*(){return yield P((()=>ye(void 0,null,(function*(){yield m();const e=yield ye(void 0,null,(function*(){return C(T(yield f(W(r,((e,n)=>ye(void 0,[e,n],(function*([e,n],t){return[e,yield O(t,n)]}))))),(e=>!M(e[1]))))})),n=yield ye(void 0,null,(function*(){return u?(yield O(c,h))[p]:{}}));return M(e)&&d(n)?void 0:[e,n]}))))}))),((e,n)=>ye(void 0,null,(function*(){return yield P((()=>ye(void 0,null,(function*(){if(yield m(),d(n)){const[n,t]=e();yield A(n),yield w(t)}else{const[e,t]=n();yield A(e,!0),yield w(t,!0)}}))))}))),t,l,o,[y,v],v)},pe="json",he="autoLoadIntervalSeconds",Ee="rowIdColumnName",me="tableId",Oe="tableName",be={mode:pe,[he]:1},Pe={load:0,save:0,[Oe]:t+"_values"},Te=(e,n,t,l)=>{const o=F();return I(e,((e,r)=>{const i=v(j(D(n,s(e)?{[t]:e}:e)),0,_(n));d(i[0])||l(r,i[0])||H(o,r,i)})),o};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 we="pragma ",Le="data_version",Re="schema_version",Ne=(e,n,l,o,r,i,u,d,c="getDb",y)=>{let f,p,E;const[O,b,P,T]=(e=>{const n=(e=>D(be,s(e)?{storeTableName:e}:null!=e?e:{}))(e),l=n[he];if(n.mode==pe){const{storeTableName:e=t}=n;return[1,l,[e],Y(e)]}const{tables:{load:o={},save:r={}}={},values:i={}}=n,u=v(j(D(Pe,i)),0,_(Pe)),a=u[2],d=Y(a);return[0,l,[Te(o,{[me]:null,[Ee]:h},me,(e=>G(d,e)&&e==a)),Te(r,{[Oe]:null,[Ee]:h,deleteEmptyColumns:0,deleteEmptyTable:0},Oe,((e,n)=>G(d,n)&&n==a)),u],d]})(n);return(O?ve:fe)(e,i?(e,n)=>Ae(void 0,null,(function*(){return i(e,n),yield l(e,n)})):l,(e=>{return[(n=()=>Ae(void 0,null,(function*(){try{const n=(yield l(we+Le))[0][Le],t=(yield l(we+Re))[0][Re],o=(yield l(m+" TOTAL_CHANGES() c"))[0].c;n==(null!=f?f:f=n)&&t==(null!=p?p:p=t)&&o==(null!=E?E:E=o)||(e(),f=n,p=t)}catch(e){}})),t=b,n(),setInterval(n,1e3*t)),o((n=>T.has(n)?e():0))];var n,t}),(([e,n])=>{a(e),f=p=null,r(n)}),u,P,L(T),d,c,y)};var Se=Object.defineProperty,ge=Object.getOwnPropertySymbols,xe=Object.prototype.hasOwnProperty,Ce=Object.prototype.propertyIsEnumerable,De=(e,n,t)=>n in e?Se(e,n,{enumerable:!0,configurable:!0,writable:!0,value:t}):e[n]=t;e.createSqliteWasmPersister=(e,n,t,l,o,r)=>Ne(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={}))xe.call(n,t)&&De(e,t,n[t]);if(ge)for(var t of ge(n))Ce.call(n,t)&&De(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={});
|
|
Binary file
|
|
@@ -1 +1 @@
|
|
|
1
|
-
var e,n;e=this,n=function(e){"use strict";const n=e=>typeof e,t="tinybase",l="
|
|
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="_",h="_id",E=e=>`"${e.replace(/"/g,'""')}"`,m="SELECT",T=(e,n="")=>e.join(n),O=(e,n)=>e.map(n),A=e=>0==y(e),P=(e,n)=>e.filter(n),L=(e,...n)=>e.push(...n),R=(e,n)=>{var t;return null!=(t=null==e?void 0:e.has(n))&&t},b=e=>{var n;return[...null!=(n=null==e?void 0:e.values())?n:[]]},w=(e,n)=>null==e?void 0:e.delete(n),N=Object,S=e=>N.getPrototypeOf(e),g=N.keys,x=N.freeze,C=(e=[])=>N.fromEntries(e),D=(...e)=>N.assign({},...e),I=(e,n)=>O(N.entries(e),(([e,t])=>n(t,e))),F=e=>N.values(e),M=e=>y(g(e)),$=e=>(e=>!a(e)&&c(S(e),(e=>e==N.prototype||a(S(e))),(()=>!0)))(e)&&0==M(e),j=e=>new Map(e),_=e=>{var n;return[...null!=(n=null==e?void 0:e.keys())?n:[]]},B=(e,n)=>null==e?void 0:e.get(n),H=(e,n)=>{var t;return O([...null!=(t=null==e?void 0:e.entries())?t:[]],(([e,t])=>n(t,e)))},W=(e,n,t)=>a(t)?(w(e,n),e):null==e?void 0:e.set(n,t),Y=(e,n,t)=>(R(e,n)||W(e,n,t()),B(e,n)),k=(e,n,t,l=W)=>(I(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),q=e=>new Set(Array.isArray(e)||a(e)?e:[e]),G=(e,n)=>null==e?void 0:e.add(n);var J=Object.defineProperty,U=Object.getOwnPropertySymbols,z=Object.prototype.hasOwnProperty,K=Object.prototype.propertyIsEnumerable,V=(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={}))z.call(n,t)&&V(e,t,n[t]);if(U)for(var t of U(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=m+"*FROM",ee="FROM pragma_table_",ne="WHERE",te=(e,n,t,r)=>{const i=j();return[()=>X(void 0,null,(function*(){return k(i,C(yield f(O(yield e("SELECT name "+ee+"list WHERE schema='main'AND(type='table'OR type='view')AND name IN("+oe(n)+")ORDER BY name",n),(n=>X(void 0,[n],(function*({name:n}){return[n,C(O(yield e(m+" name,type "+ee+"info(?)",[n]),(({name:e,type:n})=>[e,n])))]})))))),((e,n,t)=>W(i,n,k(Y(i,n,j),t,((e,n,t)=>{t!=B(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)=>!a(B(B(i,e),n)))(n,t)?C(P(O(yield e(Z+E(n)),(e=>{return[e[t],(n=Q({},e),l=t,delete n[l],n)];var n,l})),(([e,n])=>!a(e)&&!$(n)))):{}})),(n,t,u,d,c,s=!1)=>X(void 0,null,(function*(){const v=q();I(null!=u?u:{},(e=>O(g(null!=e?e:{}),(e=>G(v,e)))));const y=b(v);if(!s&&c&&A(y)&&R(i,n))return yield e("DROP TABLE"+E(n)),void W(i,n);if(A(y)||R(i,n)){const o=B(i,n),r=q(_(o));yield f([...O(y,(t=>X(void 0,null,(function*(){w(r,t)||(yield e(`ALTER TABLE${E(n)}ADD${E(t)}`),W(o,t,l))})))),...!s&&d?O(b(r),(l=>X(void 0,null,(function*(){l!=t&&(yield e(`ALTER TABLE${E(n)}DROP${E(l)}`),W(o,l))})))):[]])}else yield e(`CREATE TABLE${E(n)}(${E(t)} PRIMARY KEY ON CONFLICT REPLACE${T(O(y,(e=>o+E(e))))});`),W(i,n,j([[t,l],...O(y,(e=>[e,l]))]));if(s)a(u)?yield e("DELETE FROM"+E(n)+"WHERE 1"):yield f(I(u,((l,o)=>X(void 0,null,(function*(){a(l)?yield e("DELETE FROM"+E(n)+ne+E(t)+"=?",[o]):A(y)||(yield le(e,n,t,g(l),[o,...F(l)],r))})))));else if(A(y))R(i,n)&&(yield e("DELETE FROM"+E(n)+"WHERE 1"));else{const l=P(_(B(i,n)),(e=>e!=t)),o=[],r=[];I(null!=u?u:{},((e,n)=>{L(o,n,...O(l,(n=>null==e?void 0:e[n]))),L(r,n)})),yield le(e,n,t,l,o),yield e("DELETE FROM"+E(n)+ne+E(t)+"NOT IN("+oe(r)+")",r)}})),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}))]},le=(e,n,t,r,u,d=!0)=>X(void 0,null,(function*(){return yield e("INSERT "+(d?l:"OR REPLACE ")+"INTO"+E(n)+"("+E(t)+T(O(r,(e=>o+E(e))))+")VALUES"+v(i(`,(?${i(",?",y(r))})`,y(u)/(y(r)+1)),1)+(d?"ON CONFLICT("+E(t)+")DO UPDATE SET"+T(O(r,(e=>E(e)+"=excluded."+E(e))),o):l),u)})),oe=e=>T(O(e,(()=>"?")),o),re=JSON.parse;var ie=(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 ue=j(),de=j(),ae=(e,n,t,l,o,r,[i,u]=[],d=[])=>{let s,v,y,f=0,p=0;Y(ue,d,(()=>0)),Y(de,d,(()=>[]));const h=e=>ie(void 0,null,(function*(){return 2!=f&&(f=1,yield E.schedule((()=>ie(void 0,null,(function*(){yield e(),f=0}))))),E})),E={load:(t,l)=>ie(void 0,null,(function*(){return yield h((()=>ie(void 0,null,(function*(){try{e.setContent(yield n())}catch(n){e.setContent([t,l])}}))))})),startAutoLoad:(...t)=>ie(void 0,[...t],(function*(t={},o={}){return E.stopAutoLoad(),yield E.load(t,o),p=1,y=l(((t,l)=>ie(void 0,null,(function*(){if(l){const n=l();yield h((()=>ie(void 0,null,(function*(){return e.setTransactionChanges(n)}))))}else yield h((()=>ie(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)}}))))})))),E})),stopAutoLoad:()=>(p&&(o(y),y=void 0,p=0),E),save:n=>ie(void 0,null,(function*(){return 1!=f&&(f=2,yield E.schedule((()=>ie(void 0,null,(function*(){try{yield t(e.getContent,n)}catch(e){null==r||r(e)}f=0}))))),E})),startAutoSave:()=>ie(void 0,null,(function*(){return yield E.stopAutoSave().save(),s=e.addDidFinishTransactionListener(((e,n)=>{const[t,l]=n();$(t)&&$(l)||E.save((()=>[t,l]))})),E})),stopAutoSave:()=>(c(s,e.delListener),s=void 0,E),schedule:(...e)=>ie(void 0,null,(function*(){return L(B(de,d),...e),yield ie(void 0,null,(function*(){if(!B(ue,d)){for(W(ue,d,1);!a((e=B(de,d),v=e.shift()));)try{yield v()}catch(e){null==r||r(e)}W(ue,d,0)}var e})),E})),getStore:()=>e,destroy:()=>E.stopAutoLoad().stopAutoSave(),getStats:()=>({})};return i&&(E[i]=()=>u),x(E)};var ce=(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 se="store",ve=(e,n,t,l,o,[r],i,u,d)=>{const[a,c,s,v]=te(n,i,o);return ae(e,(()=>ce(void 0,null,(function*(){return yield v((()=>ce(void 0,null,(function*(){var e,n;return yield a(),re(null!=(n=null==(e=(yield c(r,h))[p])?void 0:e[se])?n:"null")}))))}))),(e=>ce(void 0,null,(function*(){return yield v((()=>ce(void 0,null,(function*(){var n,t;yield a(),yield s(r,h,{[p]:{[se]:(t=null!=(n=e())?n:null,JSON.stringify(t,((e,n)=>n instanceof Map?N.fromEntries([...n]):n)))}},!0,!0)}))))}))),t,l,o,[d,u],u)};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=(e,n,t,l,o,[r,i,[u,d,c]],s,v,y,E)=>{const[m,T,O,A]=te(n,s,o,E),L=(e,n)=>ye(void 0,null,(function*(){return yield f(H(i,((t,l)=>ye(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))})))))})),R=(e,n)=>ye(void 0,null,(function*(){return d?yield O(c,h,{[p]:e},!0,!0,n):null}));return ae(e,(()=>ye(void 0,null,(function*(){return yield A((()=>ye(void 0,null,(function*(){yield m();const e=yield ye(void 0,null,(function*(){return C(P(yield f(H(r,((e,n)=>ye(void 0,[e,n],(function*([e,n],t){return[e,yield T(t,n)]}))))),(e=>!$(e[1]))))})),n=yield ye(void 0,null,(function*(){return u?(yield T(c,h))[p]:{}}));return $(e)&&a(n)?void 0:[e,n]}))))}))),((e,n)=>ye(void 0,null,(function*(){return yield A((()=>ye(void 0,null,(function*(){if(yield m(),a(n)){const[n,t]=e();yield L(n),yield R(t)}else{const[e,t]=n();yield L(e,!0),yield R(t,!0)}}))))}))),t,l,o,[y,v],v)},pe="json",he="autoLoadIntervalSeconds",Ee="rowIdColumnName",me="tableId",Te="tableName",Oe={mode:pe,[he]:1},Ae={load:0,save:0,[Te]:t+"_values"},Pe=(e,n,t,l)=>{const o=j();return I(e,((e,r)=>{const i=v(F(D(n,s(e)?{[t]:e}:e)),0,M(n));a(i[0])||l(r,i[0])||W(o,r,i)})),o};var Le=(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 ",be="data_version",we="schema_version",Ne=(e,n,l,o,r,i,u,a,c="getDb",y)=>{let f,p,E;const[T,O,A,P]=(e=>{const n=(e=>D(Oe,s(e)?{storeTableName:e}:null!=e?e:{}))(e),l=n[he];if(n.mode==pe){const{storeTableName:e=t}=n;return[1,l,[e],q(e)]}const{tables:{load:o={},save:r={}}={},values:i={}}=n,u=v(F(D(Ae,i)),0,M(Ae)),d=u[2],a=q(d);return[0,l,[Pe(o,{[me]:null,[Ee]:h},me,(e=>G(a,e)&&e==d)),Pe(r,{[Te]:null,[Ee]:h,deleteEmptyColumns:0,deleteEmptyTable:0},Te,((e,n)=>G(a,n)&&n==d)),u],a]})(n);return(T?ve:fe)(e,i?(e,n)=>Le(void 0,null,(function*(){return i(e,n),yield l(e,n)})):l,(e=>{return[(n=()=>Le(void 0,null,(function*(){try{const n=(yield l(Re+be))[0][be],t=(yield l(Re+we))[0][we],o=(yield l(m+" TOTAL_CHANGES() c"))[0].c;n==(null!=f?f:f=n)&&t==(null!=p?p:p=t)&&o==(null!=E?E:E=o)||(e(),f=n,p=t)}catch(e){}})),t=O,n(),setInterval(n,1e3*t)),o((n=>P.has(n)?e():0))];var n,t}),(([e,n])=>{d(e),f=p=null,r(n)}),u,A,b(P),a,c,y)},Se="change";e.createSqlite3Persister=(e,n,t,l,o)=>Ne(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(Se,t),t}),(e=>n.off(Se,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={});
|
|
Binary file
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "tinybase",
|
|
3
|
-
"version": "4.6.
|
|
3
|
+
"version": "4.6.10",
|
|
4
4
|
"author": "jamesgpearce",
|
|
5
5
|
"repository": "github:tinyplex/tinybase",
|
|
6
6
|
"license": "MIT",
|
|
@@ -232,14 +232,14 @@
|
|
|
232
232
|
"@types/jest": "^29.5.12",
|
|
233
233
|
"@types/jest-environment-puppeteer": "^5.0.6",
|
|
234
234
|
"@types/less": "^3.0.6",
|
|
235
|
-
"@types/node": "^20.11.
|
|
235
|
+
"@types/node": "^20.11.19",
|
|
236
236
|
"@types/puppeteer": "^5.4.7",
|
|
237
|
-
"@types/react": "^18.2.
|
|
237
|
+
"@types/react": "^18.2.56",
|
|
238
238
|
"@types/react-dom": "^18.2.19",
|
|
239
239
|
"@types/react-test-renderer": "^18.0.7",
|
|
240
240
|
"@types/tmp": "^0.2.6",
|
|
241
|
-
"@typescript-eslint/eslint-plugin": "^
|
|
242
|
-
"@typescript-eslint/parser": "^
|
|
241
|
+
"@typescript-eslint/eslint-plugin": "^7.0.1",
|
|
242
|
+
"@typescript-eslint/parser": "^7.0.1",
|
|
243
243
|
"@vlcn.io/crsqlite-wasm": "^0.16.0",
|
|
244
244
|
"asciichart": "^1.5.25",
|
|
245
245
|
"babel-eslint": "^10.1.0",
|
|
@@ -254,8 +254,8 @@
|
|
|
254
254
|
"esbuild": "^0.20.0",
|
|
255
255
|
"eslint": "^8.56.0",
|
|
256
256
|
"eslint-config-prettier": "^9.1.0",
|
|
257
|
-
"eslint-plugin-jest": "^27.
|
|
258
|
-
"eslint-plugin-jsdoc": "^48.0
|
|
257
|
+
"eslint-plugin-jest": "^27.9.0",
|
|
258
|
+
"eslint-plugin-jsdoc": "^48.1.0",
|
|
259
259
|
"eslint-plugin-react": "7.33.2",
|
|
260
260
|
"eslint-plugin-react-hooks": "^4.6.0",
|
|
261
261
|
"expo-sqlite": "^13.2.1",
|
|
@@ -267,16 +267,16 @@
|
|
|
267
267
|
"jest": "^29.7.0",
|
|
268
268
|
"jest-environment-jsdom": "^29.7.0",
|
|
269
269
|
"jest-fetch-mock": "^3.0.3",
|
|
270
|
-
"jest-puppeteer": "^
|
|
270
|
+
"jest-puppeteer": "^10.0.1",
|
|
271
271
|
"less": "^4.2.0",
|
|
272
|
-
"partykit": "^0.0.
|
|
272
|
+
"partykit": "^0.0.91",
|
|
273
273
|
"partysocket": "^0.0.25",
|
|
274
274
|
"prettier": "^3.2.5",
|
|
275
|
-
"puppeteer": "22.
|
|
275
|
+
"puppeteer": "22.1.0",
|
|
276
276
|
"react": "^18.2.0",
|
|
277
277
|
"react-dom": "^18.2.0",
|
|
278
278
|
"react-test-renderer": "^18.2.0",
|
|
279
|
-
"rollup": "^4.
|
|
279
|
+
"rollup": "^4.12.0",
|
|
280
280
|
"rollup-plugin-esbuild": "^6.1.1",
|
|
281
281
|
"rollup-plugin-gzip": "^3.1.1",
|
|
282
282
|
"rollup-plugin-preserve-shebang": "^1.0.1",
|
|
@@ -288,7 +288,7 @@
|
|
|
288
288
|
"ts-unused-exports": "^10.0.1",
|
|
289
289
|
"typescript": "5.3.3",
|
|
290
290
|
"wa-sqlite": "github:rhashimoto/wa-sqlite",
|
|
291
|
-
"yjs": "^13.6.
|
|
291
|
+
"yjs": "^13.6.12"
|
|
292
292
|
},
|
|
293
293
|
"peerDependencies": {
|
|
294
294
|
"@automerge/automerge-repo": "^1.1.1",
|
|
@@ -296,13 +296,13 @@
|
|
|
296
296
|
"@vlcn.io/crsqlite-wasm": "^0.16.0",
|
|
297
297
|
"electric-sql": "^0.9.2",
|
|
298
298
|
"expo-sqlite": "^13.2.1",
|
|
299
|
-
"partykit": "^0.0.
|
|
299
|
+
"partykit": "^0.0.91",
|
|
300
300
|
"partysocket": "^0.0.25",
|
|
301
301
|
"prettier": "^3.2.5",
|
|
302
302
|
"react": "^18.2.0",
|
|
303
303
|
"react-dom": "^18.2.0",
|
|
304
304
|
"sqlite3": "^5.1.7",
|
|
305
|
-
"yjs": "^13.6.
|
|
305
|
+
"yjs": "^13.6.12"
|
|
306
306
|
},
|
|
307
307
|
"peerDependenciesMeta": {
|
|
308
308
|
"@automerge/automerge-repo": {
|
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-6"><em>NEW!</em> v4.6 release</a> <span id="one-with">"The One With ElectricSQL"</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'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 & 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/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&logo=GitHub&logoColor=%23fff&label=GitHub&labelColor=%23d81b60&color=%23333"> </a><a href="https://discord.com/invite/mGz3mevwP8" target="_blank"><img src="https://img.shields.io/discord/1027918215323590676?style=for-the-badge&logo=discord&logoColor=%23fff&label=Discord&labelColor=%233131e8&color=%23333"> </a><a href="https://twitter.com/tinybasejs" target="_blank"><img src="https://img.shields.io/twitter/follow/tinybasejs?style=for-the-badge&logo=x&logoColor=%23fff&label=Twitter&labelColor=%23333&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&logo=GitHub&logoColor=%23fff&label=Ideas&labelColor=%23d81b60&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&logo=GitHub&logoColor=%23fff&label=Issues&labelColor=%23d81b60&color=%23333"> </a><a href="#well-tested-and-documented"><img src="https://img.shields.io/badge/Tests-100%25-green?style=for-the-badge&logo=jest&logoColor=%23fff&color=%23333&labelColor=%2387c305"> </a><a href="https://www.npmjs.com/package/tinybase/v/4.6.
|
|
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-6"><em>NEW!</em> v4.6 release</a> <span id="one-with">"The One With ElectricSQL"</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'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 & 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/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&logo=GitHub&logoColor=%23fff&label=GitHub&labelColor=%23d81b60&color=%23333"> </a><a href="https://discord.com/invite/mGz3mevwP8" target="_blank"><img src="https://img.shields.io/discord/1027918215323590676?style=for-the-badge&logo=discord&logoColor=%23fff&label=Discord&labelColor=%233131e8&color=%23333"> </a><a href="https://twitter.com/tinybasejs" target="_blank"><img src="https://img.shields.io/twitter/follow/tinybasejs?style=for-the-badge&logo=x&logoColor=%23fff&label=Twitter&labelColor=%23333&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&logo=GitHub&logoColor=%23fff&label=Ideas&labelColor=%23d81b60&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&logo=GitHub&logoColor=%23fff&label=Issues&labelColor=%23d81b60&color=%23333"> </a><a href="#well-tested-and-documented"><img src="https://img.shields.io/badge/Tests-100%25-green?style=for-the-badge&logo=jest&logoColor=%23fff&color=%23333&labelColor=%2387c305"> </a><a href="https://www.npmjs.com/package/tinybase/v/4.6.10" target="_blank"><img src="https://img.shields.io/npm/v/tinybase?style=for-the-badge&logo=npm&logoColor=%23fff&labelColor=%23bd0005&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()
|