tinybase 4.8.7 → 4.8.9
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-libsql.cjs +1 -1
- package/lib/cjs/persisters/persister-libsql.cjs.gz +0 -0
- package/lib/cjs/persisters/persister-powersync.cjs +1 -1
- package/lib/cjs/persisters/persister-powersync.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-libsql.cjs +1 -1
- package/lib/cjs-es6/persisters/persister-libsql.cjs.gz +0 -0
- package/lib/cjs-es6/persisters/persister-powersync.cjs +1 -1
- package/lib/cjs-es6/persisters/persister-powersync.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 +15 -22
- package/lib/debug/persisters/persister-electric-sql.js +15 -22
- package/lib/debug/persisters/persister-expo-sqlite-next.js +15 -22
- package/lib/debug/persisters/persister-expo-sqlite.js +15 -22
- package/lib/debug/persisters/persister-libsql.js +15 -22
- package/lib/debug/persisters/persister-powersync.js +15 -22
- package/lib/debug/persisters/persister-sqlite-wasm.js +15 -22
- package/lib/debug/persisters/persister-sqlite3.js +15 -22
- 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-libsql.js +1 -1
- package/lib/es6/persisters/persister-libsql.js.gz +0 -0
- package/lib/es6/persisters/persister-powersync.js +1 -1
- package/lib/es6/persisters/persister-powersync.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-libsql.js +1 -1
- package/lib/persisters/persister-libsql.js.gz +0 -0
- package/lib/persisters/persister-powersync.js +1 -1
- package/lib/persisters/persister-powersync.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/types/ui-react.d.ts +1 -1
- package/lib/types/with-schemas/ui-react.d.ts +1 -1
- 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-libsql.js +1 -1
- package/lib/umd/persisters/persister-libsql.js.gz +0 -0
- package/lib/umd/persisters/persister-powersync.js +1 -1
- package/lib/umd/persisters/persister-powersync.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-libsql.js +1 -1
- package/lib/umd-es6/persisters/persister-libsql.js.gz +0 -0
- package/lib/umd-es6/persisters/persister-powersync.js +1 -1
- package/lib/umd-es6/persisters/persister-powersync.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 +21 -21
- 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={});
|
|
Binary file
|
|
@@ -1 +1 @@
|
|
|
1
|
-
var e,n;e=this,n=function(e){"use strict";const n=e=>typeof e,
|
|
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={});
|
|
Binary file
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "tinybase",
|
|
3
|
-
"version": "4.8.
|
|
3
|
+
"version": "4.8.9",
|
|
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.
|
|
218
|
-
"@automerge/automerge-repo": "^1.1.
|
|
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-
|
|
230
|
+
"@sqlite.org/sqlite-wasm": "^3.45.3-build3",
|
|
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.
|
|
237
|
+
"@types/node": "^20.12.12",
|
|
238
238
|
"@types/puppeteer": "^5.4.7",
|
|
239
|
-
"@types/react": "^18.3.
|
|
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.
|
|
244
|
-
"@typescript-eslint/parser": "^7.
|
|
243
|
+
"@typescript-eslint/eslint-plugin": "^7.10.0",
|
|
244
|
+
"@typescript-eslint/parser": "^7.10.0",
|
|
245
245
|
"@vlcn.io/crsqlite-wasm": "^0.16.0",
|
|
246
246
|
"asciichart": "^1.5.25",
|
|
247
247
|
"babel-eslint": "^10.1.0",
|
|
@@ -251,17 +251,17 @@
|
|
|
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.
|
|
255
|
-
"electric-sql": "^0.
|
|
256
|
-
"esbuild": "^0.
|
|
254
|
+
"cspell": "^8.8.1",
|
|
255
|
+
"electric-sql": "^0.11.3",
|
|
256
|
+
"esbuild": "^0.21.3",
|
|
257
257
|
"eslint": "^8.57.0",
|
|
258
258
|
"eslint-config-prettier": "^9.1.0",
|
|
259
|
-
"eslint-plugin-jest": "^28.
|
|
260
|
-
"eslint-plugin-jsdoc": "^48.2.
|
|
259
|
+
"eslint-plugin-jest": "^28.5.0",
|
|
260
|
+
"eslint-plugin-jsdoc": "^48.2.5",
|
|
261
261
|
"eslint-plugin-react": "7.34.1",
|
|
262
262
|
"eslint-plugin-react-hooks": "^4.6.2",
|
|
263
263
|
"expo-sqlite": "^13.2.1",
|
|
264
|
-
"fake-indexeddb": "^
|
|
264
|
+
"fake-indexeddb": "^6.0.0",
|
|
265
265
|
"gulp": "^5.0.0",
|
|
266
266
|
"gulp-gzip": "^1.4.2",
|
|
267
267
|
"http-server": "^14.1.1",
|
|
@@ -271,14 +271,14 @@
|
|
|
271
271
|
"jest-fetch-mock": "^3.0.3",
|
|
272
272
|
"jest-puppeteer": "^10.0.1",
|
|
273
273
|
"less": "^4.2.0",
|
|
274
|
-
"partykit": "^0.0.
|
|
274
|
+
"partykit": "^0.0.105",
|
|
275
275
|
"partysocket": "^1.0.1",
|
|
276
276
|
"prettier": "^3.2.5",
|
|
277
|
-
"puppeteer": "22.
|
|
277
|
+
"puppeteer": "22.9.0",
|
|
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.
|
|
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,14 +293,14 @@
|
|
|
293
293
|
"yjs": "^13.6.15"
|
|
294
294
|
},
|
|
295
295
|
"peerDependencies": {
|
|
296
|
-
"@automerge/automerge-repo": "^1.1.
|
|
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-
|
|
299
|
+
"@sqlite.org/sqlite-wasm": "^3.45.3-build3",
|
|
300
300
|
"@vlcn.io/crsqlite-wasm": "^0.16.0",
|
|
301
|
-
"electric-sql": "^0.
|
|
301
|
+
"electric-sql": "^0.11.3",
|
|
302
302
|
"expo-sqlite": "^13.2.1",
|
|
303
|
-
"partykit": "^0.0.
|
|
303
|
+
"partykit": "^0.0.105",
|
|
304
304
|
"partysocket": "^1.0.1",
|
|
305
305
|
"prettier": "^3.2.5",
|
|
306
306
|
"react": "^18.3.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">"The One With PowerSync"</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/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&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.8.
|
|
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">"The One With PowerSync"</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/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&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.8.9" 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()
|