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