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