tinybase
Version:
A reactive data store and sync engine.
2 lines (1 loc) • 8.54 kB
JavaScript
const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),i="true",o=(a,t,e)=>a.replace(t,e),r=Promise,c=clearInterval,l=a=>null==a,w=(a,t,e)=>l(a)?e?.():t(a),u=t=>a(t)==s,y=a=>Array.isArray(a),d=(a,t,e)=>a.slice(t,e),p=a=>a.length,g=()=>{},v=async a=>r.all(a),E=a=>{throw Error(a)},A=async(a,t,e)=>{try{return await a()}catch(a){t?.(a)}},m=(a,t)=>a.forEach(t),N=(a,t="")=>a.join(t),$=(a,t)=>a.map(t),f=a=>0==p(a),h=(a,t)=>a.filter(t),b=(a,...t)=>a.push(...t),C=a=>a.shift(),T=(a,t)=>a?.has(t)??!1,O=a=>l(a)||0==(a=>a?.size??0)(a),D=a=>[...a?.values()??[]],I=(a,t)=>a?.forEach(t),S=(a,t)=>a?.delete(t),L="_",R="_id",_="SELECT",M="WHERE",P="TABLE",F="ALTER "+P,j="FROM",k="DELETE "+j,U=_+"*"+j,x="pragma_",B="data_version",J="schema_version",Y="pragma_table_",q="CREATE "+P,z=a=>N($(((a,t="",e)=>a.split(t,e))(a,"."),(a=>`"${o(a,/"/g,'""')}"`)),"."),G=(a,t=[1])=>N($(a,(()=>"$"+t[0]++)),n),H=(a,t=i)=>M+`(${o(t,"$tableName",z(a))})`,V=Object,K=a=>V.getPrototypeOf(a),Q=V.entries,W=V.keys,X=V.freeze,Z=(a=[])=>V.fromEntries(a),aa=(...a)=>V.assign({},...a),ta=(a,t)=>(delete a[t],a),ea=(a,t)=>$(Q(a),(([a,e])=>t(e,a))),na=(a,t)=>Z(ea(a,((a,e)=>[e,t(a,e)]))),sa=a=>V.values(a),ia=a=>p(W(a)),oa=a=>(a=>!l(a)&&w(K(a),(a=>a==V.prototype||l(K(a))),(()=>!0)))(a)&&0==ia(a),ra=a=>new Map(a),ca=(a,t)=>a?.get(t),la=(a,t)=>$([...a?.entries()??[]],(([a,e])=>t(e,a))),wa=(a,t,e)=>l(e)?(S(a,t),a):a?.set(t,e),ua=(a,t,e,n)=>(T(a,t)?n?.(ca(a,t)):wa(a,t,e()),ca(a,t)),ya=(a,t,e,n,s=0)=>w((e?ua:ca)(a,t[s],s>p(t)-2?e:ra),(i=>{if(s>p(t)-2)return n?.(i)&&wa(a,t[s]),i;const o=ya(i,t,e,n,s+1);return O(i)&&wa(a,t[s]),o})),da=a=>new Set(y(a)||l(a)?a:[a]),pa=(a,t)=>a?.add(t),ga="ColumnName",va="store",Ea="json",Aa=va+"TableName",ma=va+"Id"+ga,Na=va+ga,$a="autoLoadIntervalSeconds",fa="rowId"+ga,ha="tableId",ba="tableName",Ca="deleteEmptyColumns",Ta="deleteEmptyTable",Oa="condition",Da={mode:Ea,[$a]:1},Ia={load:0,save:0,[ba]:t+"_values"},Sa=(a,t,e,n,s)=>{const i=ra();return na(a,((a,o)=>{const r=d(sa(aa(t,u(a)?{[e]:a}:a)),0,ia(t));l(r[0])||n(o,r[0])||(s(o,r[0]),wa(i,o,r))})),i},La=JSON.stringify,Ra=JSON.parse,_a=/^\d+$/,Ma=ra(),Pa=ra(),Fa=(a,t,n,s,i,o,r,c={},u=0,d=[])=>{let g,v,N,$=0,f=0,h=0;ua(Ma,d,(()=>0)),ua(Pa,d,(()=>[]));const T=ra(),[D,L,R,_,M]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!oa(a)||!oa(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!oa(a)||!oa(t),t.setContent]:E("Store type not supported by this Persister"))(r,a,u),[P,F,j]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?C(a):null)??e+t++,t=>{_a.test(t)&&p(a)<1e3&&b(a,t)}]})(),s=ra();return[(n,i,o,r=[],c=()=>[])=>{a??=V;const l=t(1);return wa(s,l,[n,i,o,r,c]),pa(ya(i,o??[e],da),l),l},(t,n,...i)=>m(((a,t=[e])=>{const n=[],s=(a,e)=>e==p(t)?b(n,a):null===t[e]?I(a,(a=>s(a,e+1))):m([t[e],null],(t=>s(ca(a,t),e+1)));return s(a,0),n})(t,n),(t=>I(t,(t=>ca(s,t)[0](a,...n??[],...i))))),a=>w(ca(s,a),(([,t,i])=>(ya(t,i??[e],void 0,(t=>(S(t,a),O(t)?1:0))),wa(s,a),n(a),i))),t=>w(ca(s,t),(([t,,e=[],n,s])=>{const i=(...o)=>{const r=p(o);r==p(e)?t(a,...o,...s(o)):l(e[r])?m(n[r]?.(...o)??[],(a=>i(...o,a))):i(...o,e[r])};i()}))]})(),k=a=>{a!=$&&($=a,F(T,void 0,$))},U=t=>{(D&&y(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},x=async a=>(2!=$&&(k(1),f++,await H((async()=>{await A((async()=>{const e=await t();y(e)?U(e):a?M(a):E("Content is not an array: "+e)}),(()=>{a&&M(a)})),k(0)}))),V),B=async a=>(J(),await x(a),await A((async()=>v=await s((async(a,t)=>{t||a?2!=$&&(k(1),f++,U(t??a),k(0)):await x()}))),o),V),J=async()=>(v&&(await A((()=>i(v)),o),v=void 0),V),Y=async a=>(1!=$&&(k(2),h++,await H((async()=>{await A((()=>n(L,a)),o),k(0)}))),V),q=async()=>(z(),await Y(),N=a.addDidFinishTransactionListener((()=>{const a=R();_(a)&&Y(a)})),V),z=async()=>(N&&(a.delListener(N),N=void 0),V),G=async(a=!1)=>{const[t,e]=a?[z,J]:[J,z];return await t(),await e(),V},H=async(...a)=>(b(ca(Pa,d),...a),await(async()=>{if(!ca(Ma,d)){for(wa(Ma,d,1);!l(g=C(ca(Pa,d)));)await A(g,o);wa(Ma,d,0)}})(),V),V={load:x,startAutoLoad:B,stopAutoLoad:J,isAutoLoading:()=>!l(v),save:Y,startAutoSave:q,stopAutoSave:z,isAutoSaving:()=>!l(N),startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[q,B]:[B,q];return await e(a),await n(a),V},stopAutoPersisting:G,getStatus:()=>$,addStatusListener:a=>P(a,T),delListener:t=>(j(t),a),schedule:H,getStore:()=>a,destroy:()=>(ca(Pa,d).splice(0,void 0),G()),getStats:()=>({loads:f,saves:h}),...c};return X(V)},ja=(a,t,e,s,o,r=ka,c,w)=>{const u=ra();return[async()=>{u.clear(),$(await e(a,t),(({tn:a,cn:t})=>pa(ua(u,a,da),t)))},async(t,e,n)=>((a,t)=>T(ca(u,a),t))(t,e)?Z(h($(await a(U+z(t)+H(t,n)),(a=>[a[e],w?na(ta(a,e),w):ta(a,e)])),(([a,t])=>!l(a)&&!oa(t)))):{},async(t,e,s,w,y,d=!1,p=i)=>{const g=da();na(s??{},(a=>$(W(a??{}),(a=>pa(g,a)))));const E=D(g);if(!d&&y&&p==i&&f(E)&&T(u,t))return await a("DROP "+P+z(t)),void wa(u,t);const A=ca(u,t),m=da(D(A));if(f(E)||(T(u,t)?await v($([e,...E],(async(n,s)=>{S(m,n)||(await a(F+z(t)+"ADD"+z(n)+o),0==s&&await a("CREATE UNIQUE INDEX pk ON "+z(t)+`(${z(e)})`),pa(A,n))}))):(await a(q+z(t)+`(${z(e)}${o} PRIMARY KEY${N($(E,(a=>n+z(a)+o)))});`),wa(u,t,da([e,...E])))),await v([...!d&&w?$(D(m),(async n=>{n!=e&&(await a(F+z(t)+"DROP"+z(n)),S(A,n))})):[]]),d)l(s)?await a(k+z(t)+H(t,p)):await v(ea(s,(async(n,s)=>{l(n)?await a(k+z(t)+H(t,p)+`AND(${z(e)}=$1)`,[s]):f(E)||await r(a,t,e,W(n),{[s]:c?$(sa(n),c):sa(n)},A)})));else if(f(E))T(u,t)&&await a(k+z(t)+H(t,p));else{const n=h(D(ca(u,t)),(a=>a!=e)),i={},o=[];na(s??{},((a,t)=>{i[t]=$(n,(t=>c?c(a?.[t]):a?.[t])),b(o,t)})),await r(a,t,e,n,i),await a(k+z(t)+H(t,p)+`AND${z(e)}NOT IN(${G(o)})`,o)}},async t=>{let e;return await a("BEGIN"),await A((async()=>e=await t()),s),await a("END"),e}]},ka=async(a,t,e,s,i)=>{const o=[1];await a("INSERT INTO"+z(t)+"("+((...a)=>N($(a,z),n))(e,...s)+")VALUES"+N(ea(i,(a=>"($"+o[0]+++","+G(a,o)+")")),n)+"ON CONFLICT("+z(e)+")DO UPDATE SET"+N($(s,(a=>z(a)+"=excluded."+z(a))),n),ea(i,((a,t)=>[t,...$(a,(a=>a??null))])).flat())},Ua=(a,t,e,n,s,i,o,[r,c,l],w,u,y,d,p,g)=>{const[v,E,A,m]=ja(t,w,u,s,p,g),N=Fa(a,(()=>m((async()=>{return await v(),a=(await E(r,c))[L]?.[l]??"null",Ra(a,((a,t)=>""===t?void 0:t));var a}))),(a=>m((async()=>{var t;await v(),await A(r,c,{[L]:{[l]:(t=a()??null,La(t,((a,t)=>void 0===t?"":t)))}},!0,!0)}))),e,n,s,o,{[d]:()=>y,destroy:async()=>(await N.stopAutoPersisting(),i(),N)},0,y);return N},xa=(a,t,e,n,s,i,o,[r,c,[w,u,y]],d,p,g,E,A,m,N,$)=>{const[f,b,C,T]=ja(t,d,p,s,A,m,N,$),O=(a,t)=>v(la(c,(async([e,n,s,i,o],r)=>{t&&!(r in a)||await C(e,n,a[r],s,i,t,o)}))),D=async(a,t)=>u?await C(y,R,{[L]:a},!0,!0,t):null,I=Fa(a,(()=>T((async()=>{await f();const a=await(async()=>Z(h(await v(la(r,(async([a,t,e],n)=>[a,await b(n,t,e)]))),(a=>!oa(a[1])))))(),t=await(async()=>w?(await b(y,R))[L]:{})();return oa(a)&&l(t)?void 0:[a,t]}))),((a,t)=>T((async()=>{if(await f(),l(t)){const[t,e]=a();await O(t),await D(e)}else await O(t[0],!0),await D(t[1],!0)}))),e,n,s,o,{[E]:()=>g,destroy:async()=>(await I.stopAutoPersisting(),i(),I)},0,g);return I},Ba=(a,n,s,o,r,l,w,y,p,g,v="getDb",E)=>{let m,N,$;const f=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,l),[h,b,C,O]=(a=>{const e=(a=>aa(Da,u(a)?{[Aa]:a}:a??{}))(a),n=e[$a];if(e.mode==Ea){const a=e[Aa]??t;return[1,n,[a,e[ma]??R,e[Na]??va],da(a)]}const{tables:{load:s={},save:o={}}={},values:r={}}=e,c=d(sa(aa(Ia,r)),0,ia(Ia)),l=c[2],w=da(l),y=da(l),p=Sa(s,{[ha]:null,[fa]:R,[Oa]:i},ha,(a=>T(y,a)),(a=>pa(w,a))),g=Sa(o,{[ba]:null,[fa]:R,[Ca]:0,[Ta]:0,[Oa]:null},ba,((a,t)=>T(y,t)),((a,t)=>pa(w,t)));var v;return v=(a,t)=>t[4]??=ca(p,t[0])?.[2]??i,I(g,((a,t)=>v(0,a))),[0,n,[p,g,c],w]})(n);return(h?Ua:xa)(a,f,(a=>{let t;const e=()=>t=setInterval((()=>A((async()=>{const[{d:t,s:e,c:n}]=await f(_+` ${B} d,${J} s,TOTAL_CHANGES() c FROM ${x}${B} JOIN ${x}${J}`);t==m&&e==N&&n==$||(null!=m&&a(),m=t,N=e,$=n)}))),1e3*b),n=()=>{m=N=$=null,c(t)},s=o((t=>{O.has(t)&&(n(),a(),e())}));return e(),()=>{n(),r(s)}}),(a=>a()),w,y,p,C,D(O),(async(a,t)=>await a(_+` t.name tn,c.name cn FROM ${Y}list()t,${Y}info(t.name)c ${M} t.schema='main'AND t.type IN('table','view')AND t.name IN(${G(t)})ORDER BY t.name,c.name`,t)),g,v,e,E,(a=>!0===a?1:!1===a?0:a),void 0)},Ja=(a,t,e,n,s,i)=>Ba(a,n,(async(a,t=[])=>e.exec(a,{bind:t,rowMode:"object",returnValue:"resultRows"}).map((a=>({...a})))),(a=>t.capi.sqlite3_update_hook(e,((t,e,n,s)=>a(s)),0)),(()=>t.capi.sqlite3_update_hook(e,g,0)),s,i,g,3,e);export{Ja as createSqliteWasmPersister};