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