tinybase 7.3.2 → 7.3.3

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.
Files changed (135) hide show
  1. package/min/omni/index.js +1 -1
  2. package/min/omni/index.js.gz +0 -0
  3. package/min/omni/with-schemas/index.js +1 -1
  4. package/min/omni/with-schemas/index.js.gz +0 -0
  5. package/min/persisters/index.js +1 -1
  6. package/min/persisters/index.js.gz +0 -0
  7. package/min/persisters/persister-browser/index.js +1 -1
  8. package/min/persisters/persister-browser/index.js.gz +0 -0
  9. package/min/persisters/persister-browser/with-schemas/index.js +1 -1
  10. package/min/persisters/persister-browser/with-schemas/index.js.gz +0 -0
  11. package/min/persisters/persister-cr-sqlite-wasm/index.js +1 -1
  12. package/min/persisters/persister-cr-sqlite-wasm/index.js.gz +0 -0
  13. package/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.js +1 -1
  14. package/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.js.gz +0 -0
  15. package/min/persisters/persister-durable-object-sql-storage/index.js +1 -1
  16. package/min/persisters/persister-durable-object-sql-storage/index.js.gz +0 -0
  17. package/min/persisters/persister-durable-object-sql-storage/with-schemas/index.js +1 -1
  18. package/min/persisters/persister-durable-object-sql-storage/with-schemas/index.js.gz +0 -0
  19. package/min/persisters/persister-electric-sql/index.js +1 -1
  20. package/min/persisters/persister-electric-sql/index.js.gz +0 -0
  21. package/min/persisters/persister-electric-sql/with-schemas/index.js +1 -1
  22. package/min/persisters/persister-electric-sql/with-schemas/index.js.gz +0 -0
  23. package/min/persisters/persister-expo-sqlite/index.js +1 -1
  24. package/min/persisters/persister-expo-sqlite/index.js.gz +0 -0
  25. package/min/persisters/persister-expo-sqlite/with-schemas/index.js +1 -1
  26. package/min/persisters/persister-expo-sqlite/with-schemas/index.js.gz +0 -0
  27. package/min/persisters/persister-file/index.js +1 -1
  28. package/min/persisters/persister-file/index.js.gz +0 -0
  29. package/min/persisters/persister-file/with-schemas/index.js +1 -1
  30. package/min/persisters/persister-file/with-schemas/index.js.gz +0 -0
  31. package/min/persisters/persister-libsql/index.js +1 -1
  32. package/min/persisters/persister-libsql/index.js.gz +0 -0
  33. package/min/persisters/persister-libsql/with-schemas/index.js +1 -1
  34. package/min/persisters/persister-libsql/with-schemas/index.js.gz +0 -0
  35. package/min/persisters/persister-partykit-client/index.js +1 -1
  36. package/min/persisters/persister-partykit-client/index.js.gz +0 -0
  37. package/min/persisters/persister-partykit-client/with-schemas/index.js +1 -1
  38. package/min/persisters/persister-partykit-client/with-schemas/index.js.gz +0 -0
  39. package/min/persisters/persister-partykit-server/index.js +1 -1
  40. package/min/persisters/persister-partykit-server/index.js.gz +0 -0
  41. package/min/persisters/persister-partykit-server/with-schemas/index.js +1 -1
  42. package/min/persisters/persister-partykit-server/with-schemas/index.js.gz +0 -0
  43. package/min/persisters/persister-pglite/index.js +1 -1
  44. package/min/persisters/persister-pglite/index.js.gz +0 -0
  45. package/min/persisters/persister-pglite/with-schemas/index.js +1 -1
  46. package/min/persisters/persister-pglite/with-schemas/index.js.gz +0 -0
  47. package/min/persisters/persister-postgres/index.js +1 -1
  48. package/min/persisters/persister-postgres/index.js.gz +0 -0
  49. package/min/persisters/persister-postgres/with-schemas/index.js +1 -1
  50. package/min/persisters/persister-postgres/with-schemas/index.js.gz +0 -0
  51. package/min/persisters/persister-powersync/index.js +1 -1
  52. package/min/persisters/persister-powersync/index.js.gz +0 -0
  53. package/min/persisters/persister-powersync/with-schemas/index.js +1 -1
  54. package/min/persisters/persister-powersync/with-schemas/index.js.gz +0 -0
  55. package/min/persisters/persister-react-native-sqlite/index.js +1 -1
  56. package/min/persisters/persister-react-native-sqlite/index.js.gz +0 -0
  57. package/min/persisters/persister-react-native-sqlite/with-schemas/index.js +1 -1
  58. package/min/persisters/persister-react-native-sqlite/with-schemas/index.js.gz +0 -0
  59. package/min/persisters/persister-sqlite-bun/index.js +1 -1
  60. package/min/persisters/persister-sqlite-bun/index.js.gz +0 -0
  61. package/min/persisters/persister-sqlite-bun/with-schemas/index.js +1 -1
  62. package/min/persisters/persister-sqlite-bun/with-schemas/index.js.gz +0 -0
  63. package/min/persisters/persister-sqlite-wasm/index.js +1 -1
  64. package/min/persisters/persister-sqlite-wasm/index.js.gz +0 -0
  65. package/min/persisters/persister-sqlite-wasm/with-schemas/index.js +1 -1
  66. package/min/persisters/persister-sqlite-wasm/with-schemas/index.js.gz +0 -0
  67. package/min/persisters/persister-sqlite3/index.js +1 -1
  68. package/min/persisters/persister-sqlite3/index.js.gz +0 -0
  69. package/min/persisters/persister-sqlite3/with-schemas/index.js +1 -1
  70. package/min/persisters/persister-sqlite3/with-schemas/index.js.gz +0 -0
  71. package/min/persisters/with-schemas/index.js +1 -1
  72. package/min/persisters/with-schemas/index.js.gz +0 -0
  73. package/min/synchronizers/synchronizer-ws-client/index.js +1 -1
  74. package/min/synchronizers/synchronizer-ws-client/index.js.gz +0 -0
  75. package/min/synchronizers/synchronizer-ws-client/with-schemas/index.js +1 -1
  76. package/min/synchronizers/synchronizer-ws-client/with-schemas/index.js.gz +0 -0
  77. package/min/synchronizers/synchronizer-ws-server/index.js +1 -1
  78. package/min/synchronizers/synchronizer-ws-server/index.js.gz +0 -0
  79. package/min/synchronizers/synchronizer-ws-server/with-schemas/index.js +1 -1
  80. package/min/synchronizers/synchronizer-ws-server/with-schemas/index.js.gz +0 -0
  81. package/min/synchronizers/synchronizer-ws-server-durable-object/index.js +1 -1
  82. package/min/synchronizers/synchronizer-ws-server-durable-object/index.js.gz +0 -0
  83. package/min/synchronizers/synchronizer-ws-server-durable-object/with-schemas/index.js +1 -1
  84. package/min/synchronizers/synchronizer-ws-server-durable-object/with-schemas/index.js.gz +0 -0
  85. package/min/ui-react-inspector/index.js +1 -1
  86. package/min/ui-react-inspector/index.js.gz +0 -0
  87. package/min/ui-react-inspector/with-schemas/index.js +1 -1
  88. package/min/ui-react-inspector/with-schemas/index.js.gz +0 -0
  89. package/omni/index.js +16 -3
  90. package/omni/with-schemas/index.js +16 -3
  91. package/package.json +13 -13
  92. package/persisters/index.js +10 -1
  93. package/persisters/persister-browser/index.js +17 -1
  94. package/persisters/persister-browser/with-schemas/index.js +17 -1
  95. package/persisters/persister-cr-sqlite-wasm/index.js +10 -1
  96. package/persisters/persister-cr-sqlite-wasm/with-schemas/index.js +10 -1
  97. package/persisters/persister-durable-object-sql-storage/index.js +10 -1
  98. package/persisters/persister-durable-object-sql-storage/with-schemas/index.js +10 -1
  99. package/persisters/persister-electric-sql/index.js +10 -1
  100. package/persisters/persister-electric-sql/with-schemas/index.js +10 -1
  101. package/persisters/persister-expo-sqlite/index.js +10 -1
  102. package/persisters/persister-expo-sqlite/with-schemas/index.js +10 -1
  103. package/persisters/persister-file/index.js +17 -1
  104. package/persisters/persister-file/with-schemas/index.js +17 -1
  105. package/persisters/persister-libsql/index.js +10 -1
  106. package/persisters/persister-libsql/with-schemas/index.js +10 -1
  107. package/persisters/persister-partykit-client/index.js +27 -2
  108. package/persisters/persister-partykit-client/with-schemas/index.js +27 -2
  109. package/persisters/persister-partykit-server/index.js +37 -2
  110. package/persisters/persister-partykit-server/with-schemas/index.js +37 -2
  111. package/persisters/persister-pglite/index.js +10 -1
  112. package/persisters/persister-pglite/with-schemas/index.js +10 -1
  113. package/persisters/persister-postgres/index.js +10 -1
  114. package/persisters/persister-postgres/with-schemas/index.js +10 -1
  115. package/persisters/persister-powersync/index.js +10 -1
  116. package/persisters/persister-powersync/with-schemas/index.js +10 -1
  117. package/persisters/persister-react-native-sqlite/index.js +10 -1
  118. package/persisters/persister-react-native-sqlite/with-schemas/index.js +10 -1
  119. package/persisters/persister-sqlite-bun/index.js +10 -1
  120. package/persisters/persister-sqlite-bun/with-schemas/index.js +10 -1
  121. package/persisters/persister-sqlite-wasm/index.js +10 -1
  122. package/persisters/persister-sqlite-wasm/with-schemas/index.js +10 -1
  123. package/persisters/persister-sqlite3/index.js +10 -1
  124. package/persisters/persister-sqlite3/with-schemas/index.js +10 -1
  125. package/persisters/with-schemas/index.js +10 -1
  126. package/readme.md +9 -1
  127. package/releases.md +1 -1
  128. package/synchronizers/synchronizer-ws-client/index.js +14 -1
  129. package/synchronizers/synchronizer-ws-client/with-schemas/index.js +14 -1
  130. package/synchronizers/synchronizer-ws-server/index.js +14 -1
  131. package/synchronizers/synchronizer-ws-server/with-schemas/index.js +14 -1
  132. package/synchronizers/synchronizer-ws-server-durable-object/index.js +14 -1
  133. package/synchronizers/synchronizer-ws-server-durable-object/with-schemas/index.js +14 -1
  134. package/ui-react-inspector/index.js +10 -1
  135. package/ui-react-inspector/with-schemas/index.js +10 -1
@@ -1 +1 @@
1
- import{existsSync as t,writeFileSync as a,watch as e}from"fs";import{writeFile as s,readFile as n}from"fs/promises";const r="utf8",o=t=>(a,e,s)=>t(a)?s?.():e(a),i=t=>null==t,c=t=>void 0===t,u=t=>null===t,y=o(i),l=o(c),d=t=>Array.isArray(t),g=t=>t.length,w=t=>{throw Error(t)},p=async(t,a,e)=>{try{return await t()}catch(t){a?.(t)}},h=(t,a)=>t.forEach(a),v=(t,...a)=>t.push(...a),f=t=>t.shift(),C=Object,S=t=>C.getPrototypeOf(t),A=C.keys,b=C.freeze,L=t=>(t=>!i(t)&&y(S(t),t=>t==C.prototype||i(S(t)),()=>!0))(t)&&0==(t=>g(A(t)))(t),M=JSON.stringify,m=JSON.parse,P=t=>c(t)||0==(t=>t?.size??0)(t),O=(t,a)=>t?.forEach(a),E=(t,a)=>t?.delete(a),T=t=>new Map(t),z=(t,a)=>t?.get(a),D=(t,a,e)=>c(e)?(E(t,a),t):t?.set(a,e),F=(t,a,e,s)=>{var n,r;return n=t,r=a,n?.has(r)?s?.(z(t,a)):D(t,a,e()),z(t,a)},J=(t,a,e,s,n=0)=>l((e?F:z)(t,a[n],n>g(a)-2?e:T),r=>{if(n>g(a)-2)return s?.(r)&&D(t,a[n]),r;const o=J(r,a,e,s,n+1);return P(r)&&D(t,a[n]),o}),N=/^\d+$/,j=t=>new Set(d(t)||c(t)?t:[t]),k=T(),x=T(),$=(t,a,e,s,n,r,o,i={},y=0,C=[])=>{let S,A,M,m=0,$=0,q=0;F(k,C,()=>0),F(x,C,()=>[]);const B=T(),[G,H,I,K,Q]=((t=1,a,e)=>1!=t&&a.isMergeable()?[1,a.getMergeableContent,()=>a.getTransactionMergeableChanges(!e),([[t],[a]])=>!L(t)||!L(a),a.setDefaultContent]:2!=t?[0,a.getContent,a.getTransactionChanges,([t,a])=>!L(t)||!L(a),a.setContent]:w("Store type not supported by this Persister"))(o,t,y),[R,U,V]=(()=>{let t;const[a,e]=(()=>{const t=[];let a=0;return[e=>(e?f(t):null)??""+a++,a=>{N.test(a)&&g(t)<1e3&&v(t,a)}]})(),s=T();return[(e,n,r,o=[],i=()=>[])=>{t??=rt;const c=a(1);var u,y;return D(s,c,[e,n,r,o,i]),u=J(n,r??[""],j),y=c,u?.add(y),c},(a,e,...n)=>h(((t,a=[""])=>{const e=[],s=(t,n)=>n==g(a)?v(e,t):u(a[n])?O(t,t=>s(t,n+1)):h([a[n],null],a=>s(z(t,a),n+1));return s(t,0),e})(a,e),a=>O(a,a=>z(s,a)[0](t,...e??[],...n))),t=>l(z(s,t),([,a,n])=>(J(a,n??[""],void 0,a=>(E(a,t),P(a)?1:0)),D(s,t),e(t),n)),a=>l(z(s,a),([a,,e=[],s,n])=>{const r=(...o)=>{const i=g(o);i==g(e)?a(t,...o,...n(o)):u(e[i])?h(s[i]?.(...o)??[],t=>r(...o,t)):r(...o,e[i])};r()})]})(),W=t=>{t!=m&&(m=t,U(B,void 0,m))},X=a=>{(G&&d(a?.[0])?1===a?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===a?.[2]?t.applyChanges:t.setContent)(a)},Y=async t=>(2!=m&&(W(1),$++,await nt(async()=>{await p(async()=>{const e=await a();d(e)?X(e):t?Q(t):w("Content is not an array: "+e)},()=>{t&&Q(t)}),W(0)})),rt),Z=async t=>(_(),await Y(t),await p(async()=>A=await s(async(t,a)=>{a||t?2!=m&&(W(1),$++,X(a??t),W(0)):await Y()}),r),rt),_=async()=>(A&&(await p(()=>n(A),r),A=void 0),rt),tt=async t=>(1!=m&&(W(2),q++,await nt(async()=>{await p(()=>e(H,t),r),W(0)})),rt),at=async()=>(et(),await tt(),M=t.addDidFinishTransactionListener(()=>{const t=I();K(t)&&tt(t)}),rt),et=async()=>(M&&(t.delListener(M),M=void 0),rt),st=async(t=!1)=>{const[a,e]=t?[et,_]:[_,et];return await a(),await e(),rt},nt=async(...t)=>(v(z(x,C),...t),await(async()=>{if(!z(k,C)){for(D(k,C,1);!c(S=f(z(x,C)));)await p(S,r);D(k,C,0)}})(),rt),rt={load:Y,startAutoLoad:Z,stopAutoLoad:_,isAutoLoading:()=>!c(A),save:tt,startAutoSave:at,stopAutoSave:et,isAutoSaving:()=>!c(M),startAutoPersisting:async(t,a=!1)=>{const[e,s]=a?[at,Z]:[Z,at];return await e(t),await s(t),rt},stopAutoPersisting:st,getStatus:()=>m,addStatusListener:t=>R(t,B),delListener:a=>(V(a),t),schedule:nt,getStore:()=>t,destroy:()=>(z(x,C).splice(0,void 0),st()),getStats:()=>({loads:$,saves:q}),...i};return b(rt)},q=(o,i,u)=>$(o,async()=>{return t=await n(i,r),m(t,(t,a)=>""===a?void 0:a);var t},async t=>{return await s(i,(a=t(),M(a,(t,a)=>c(a)?"":a)),r);var a},s=>(t(i)||a(i,"",r),e(i,()=>s())),t=>t?.close(),u,3,{getFilePath:()=>i});export{q as createFilePersister};
1
+ import{existsSync as t,writeFileSync as a,watch as e}from"fs";import{writeFile as s,readFile as n}from"fs/promises";const r="utf8",o=t=>(a,e,s)=>t(a)?s?.():e(a),i=t=>null==t,c=t=>void 0===t,u=t=>null===t,y=o(i),l=o(c),d=t=>Array.isArray(t),g=t=>t.length,w=t=>{throw Error(t)},p=async(t,a,e)=>{try{return await t()}catch(t){a?.(t)}},f=(t,a)=>t.forEach(a),h=(t,a)=>t.map(a),v=(t,...a)=>t.push(...a),C=t=>t.shift(),S=Object,A=t=>S.getPrototypeOf(t),b=S.entries,m=t=>!i(t)&&y(A(t),t=>t==S.prototype||i(A(t)),()=>!0),L=S.keys,M=S.freeze,P=t=>m(t)&&0==(t=>g(L(t)))(t),E=JSON.stringify,O=JSON.parse,T=t=>""===t?void 0:d(t)?h(t,T):m(t)?((t,a)=>((t=[])=>S.fromEntries(t))(((t,a)=>h(b(t),([t,e])=>a(e,t)))(t,(t,e)=>[e,a(t,e)])))(t,T):t,z=t=>c(t)||0==(t=>t?.size??0)(t),D=(t,a)=>t?.forEach(a),F=(t,a)=>t?.delete(a),J=t=>new Map(t),N=(t,a)=>t?.get(a),j=(t,a,e)=>c(e)?(F(t,a),t):t?.set(a,e),k=(t,a,e,s)=>{var n,r;return n=t,r=a,n?.has(r)?s?.(N(t,a)):j(t,a,e()),N(t,a)},x=(t,a,e,s,n=0)=>l((e?k:N)(t,a[n],n>g(a)-2?e:J),r=>{if(n>g(a)-2)return s?.(r)&&j(t,a[n]),r;const o=x(r,a,e,s,n+1);return z(r)&&j(t,a[n]),o}),$=/^\d+$/,q=t=>new Set(d(t)||c(t)?t:[t]),B=J(),G=J(),H=(t,a,e,s,n,r,o,i={},y=0,h=[])=>{let S,A,b,m=0,L=0,E=0;k(B,h,()=>0),k(G,h,()=>[]);const O=J(),[T,H,I,K,Q]=((t=1,a,e)=>1!=t&&a.isMergeable()?[1,a.getMergeableContent,()=>a.getTransactionMergeableChanges(!e),([[t],[a]])=>!P(t)||!P(a),a.setDefaultContent]:2!=t?[0,a.getContent,a.getTransactionChanges,([t,a])=>!P(t)||!P(a),a.setContent]:w("Store type not supported by this Persister"))(o,t,y),[R,U,V]=(()=>{let t;const[a,e]=(()=>{const t=[];let a=0;return[e=>(e?C(t):null)??""+a++,a=>{$.test(a)&&g(t)<1e3&&v(t,a)}]})(),s=J();return[(e,n,r,o=[],i=()=>[])=>{t??=rt;const c=a(1);var u,y;return j(s,c,[e,n,r,o,i]),u=x(n,r??[""],q),y=c,u?.add(y),c},(a,e,...n)=>f(((t,a=[""])=>{const e=[],s=(t,n)=>n==g(a)?v(e,t):u(a[n])?D(t,t=>s(t,n+1)):f([a[n],null],a=>s(N(t,a),n+1));return s(t,0),e})(a,e),a=>D(a,a=>N(s,a)[0](t,...e??[],...n))),t=>l(N(s,t),([,a,n])=>(x(a,n??[""],void 0,a=>(F(a,t),z(a)?1:0)),j(s,t),e(t),n)),a=>l(N(s,a),([a,,e=[],s,n])=>{const r=(...o)=>{const i=g(o);i==g(e)?a(t,...o,...n(o)):u(e[i])?f(s[i]?.(...o)??[],t=>r(...o,t)):r(...o,e[i])};r()})]})(),W=t=>{t!=m&&(m=t,U(O,void 0,m))},X=a=>{(T&&d(a?.[0])?1===a?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===a?.[2]?t.applyChanges:t.setContent)(a)},Y=async t=>(2!=m&&(W(1),L++,await nt(async()=>{await p(async()=>{const e=await a();d(e)?X(e):t?Q(t):w("Content is not an array: "+e)},()=>{t&&Q(t)}),W(0)})),rt),Z=async t=>(_(),await Y(t),await p(async()=>A=await s(async(t,a)=>{a||t?2!=m&&(W(1),L++,X(a??t),W(0)):await Y()}),r),rt),_=async()=>(A&&(await p(()=>n(A),r),A=void 0),rt),tt=async t=>(1!=m&&(W(2),E++,await nt(async()=>{await p(()=>e(H,t),r),W(0)})),rt),at=async()=>(et(),await tt(),b=t.addDidFinishTransactionListener(()=>{const t=I();K(t)&&tt(t)}),rt),et=async()=>(b&&(t.delListener(b),b=void 0),rt),st=async(t=!1)=>{const[a,e]=t?[et,_]:[_,et];return await a(),await e(),rt},nt=async(...t)=>(v(N(G,h),...t),await(async()=>{if(!N(B,h)){for(j(B,h,1);!c(S=C(N(G,h)));)await p(S,r);j(B,h,0)}})(),rt),rt={load:Y,startAutoLoad:Z,stopAutoLoad:_,isAutoLoading:()=>!c(A),save:tt,startAutoSave:at,stopAutoSave:et,isAutoSaving:()=>!c(b),startAutoPersisting:async(t,a=!1)=>{const[e,s]=a?[at,Z]:[Z,at];return await e(t),await s(t),rt},stopAutoPersisting:st,getStatus:()=>m,addStatusListener:t=>R(t,O),delListener:a=>(V(a),t),schedule:nt,getStore:()=>t,destroy:()=>(N(G,h).splice(0,void 0),st()),getStats:()=>({loads:L,saves:E}),...i};return M(rt)},I=(o,i,u)=>H(o,async()=>{return t=await n(i,r),T(O(t));var t},async t=>{return await s(i,(a=t(),E(a,(t,a)=>c(a)?"":a)),r);var a},s=>(t(i)||a(i,"",r),e(i,()=>s())),t=>t?.close(),u,3,{getFilePath:()=>i});export{I as createFilePersister};
@@ -1 +1 @@
1
- import{existsSync as t,writeFileSync as a,watch as e}from"fs";import{writeFile as s,readFile as n}from"fs/promises";const r="utf8",o=t=>(a,e,s)=>t(a)?s?.():e(a),i=t=>null==t,c=t=>void 0===t,u=t=>null===t,y=o(i),l=o(c),d=t=>Array.isArray(t),g=t=>t.length,w=t=>{throw Error(t)},p=async(t,a,e)=>{try{return await t()}catch(t){a?.(t)}},h=(t,a)=>t.forEach(a),v=(t,...a)=>t.push(...a),f=t=>t.shift(),C=Object,S=t=>C.getPrototypeOf(t),A=C.keys,b=C.freeze,L=t=>(t=>!i(t)&&y(S(t),t=>t==C.prototype||i(S(t)),()=>!0))(t)&&0==(t=>g(A(t)))(t),M=JSON.stringify,m=JSON.parse,P=t=>c(t)||0==(t=>t?.size??0)(t),O=(t,a)=>t?.forEach(a),E=(t,a)=>t?.delete(a),T=t=>new Map(t),z=(t,a)=>t?.get(a),D=(t,a,e)=>c(e)?(E(t,a),t):t?.set(a,e),F=(t,a,e,s)=>{var n,r;return n=t,r=a,n?.has(r)?s?.(z(t,a)):D(t,a,e()),z(t,a)},J=(t,a,e,s,n=0)=>l((e?F:z)(t,a[n],n>g(a)-2?e:T),r=>{if(n>g(a)-2)return s?.(r)&&D(t,a[n]),r;const o=J(r,a,e,s,n+1);return P(r)&&D(t,a[n]),o}),N=/^\d+$/,j=t=>new Set(d(t)||c(t)?t:[t]),k=T(),x=T(),$=(t,a,e,s,n,r,o,i={},y=0,C=[])=>{let S,A,M,m=0,$=0,q=0;F(k,C,()=>0),F(x,C,()=>[]);const B=T(),[G,H,I,K,Q]=((t=1,a,e)=>1!=t&&a.isMergeable()?[1,a.getMergeableContent,()=>a.getTransactionMergeableChanges(!e),([[t],[a]])=>!L(t)||!L(a),a.setDefaultContent]:2!=t?[0,a.getContent,a.getTransactionChanges,([t,a])=>!L(t)||!L(a),a.setContent]:w("Store type not supported by this Persister"))(o,t,y),[R,U,V]=(()=>{let t;const[a,e]=(()=>{const t=[];let a=0;return[e=>(e?f(t):null)??""+a++,a=>{N.test(a)&&g(t)<1e3&&v(t,a)}]})(),s=T();return[(e,n,r,o=[],i=()=>[])=>{t??=rt;const c=a(1);var u,y;return D(s,c,[e,n,r,o,i]),u=J(n,r??[""],j),y=c,u?.add(y),c},(a,e,...n)=>h(((t,a=[""])=>{const e=[],s=(t,n)=>n==g(a)?v(e,t):u(a[n])?O(t,t=>s(t,n+1)):h([a[n],null],a=>s(z(t,a),n+1));return s(t,0),e})(a,e),a=>O(a,a=>z(s,a)[0](t,...e??[],...n))),t=>l(z(s,t),([,a,n])=>(J(a,n??[""],void 0,a=>(E(a,t),P(a)?1:0)),D(s,t),e(t),n)),a=>l(z(s,a),([a,,e=[],s,n])=>{const r=(...o)=>{const i=g(o);i==g(e)?a(t,...o,...n(o)):u(e[i])?h(s[i]?.(...o)??[],t=>r(...o,t)):r(...o,e[i])};r()})]})(),W=t=>{t!=m&&(m=t,U(B,void 0,m))},X=a=>{(G&&d(a?.[0])?1===a?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===a?.[2]?t.applyChanges:t.setContent)(a)},Y=async t=>(2!=m&&(W(1),$++,await nt(async()=>{await p(async()=>{const e=await a();d(e)?X(e):t?Q(t):w("Content is not an array: "+e)},()=>{t&&Q(t)}),W(0)})),rt),Z=async t=>(_(),await Y(t),await p(async()=>A=await s(async(t,a)=>{a||t?2!=m&&(W(1),$++,X(a??t),W(0)):await Y()}),r),rt),_=async()=>(A&&(await p(()=>n(A),r),A=void 0),rt),tt=async t=>(1!=m&&(W(2),q++,await nt(async()=>{await p(()=>e(H,t),r),W(0)})),rt),at=async()=>(et(),await tt(),M=t.addDidFinishTransactionListener(()=>{const t=I();K(t)&&tt(t)}),rt),et=async()=>(M&&(t.delListener(M),M=void 0),rt),st=async(t=!1)=>{const[a,e]=t?[et,_]:[_,et];return await a(),await e(),rt},nt=async(...t)=>(v(z(x,C),...t),await(async()=>{if(!z(k,C)){for(D(k,C,1);!c(S=f(z(x,C)));)await p(S,r);D(k,C,0)}})(),rt),rt={load:Y,startAutoLoad:Z,stopAutoLoad:_,isAutoLoading:()=>!c(A),save:tt,startAutoSave:at,stopAutoSave:et,isAutoSaving:()=>!c(M),startAutoPersisting:async(t,a=!1)=>{const[e,s]=a?[at,Z]:[Z,at];return await e(t),await s(t),rt},stopAutoPersisting:st,getStatus:()=>m,addStatusListener:t=>R(t,B),delListener:a=>(V(a),t),schedule:nt,getStore:()=>t,destroy:()=>(z(x,C).splice(0,void 0),st()),getStats:()=>({loads:$,saves:q}),...i};return b(rt)},q=(o,i,u)=>$(o,async()=>{return t=await n(i,r),m(t,(t,a)=>""===a?void 0:a);var t},async t=>{return await s(i,(a=t(),M(a,(t,a)=>c(a)?"":a)),r);var a},s=>(t(i)||a(i,"",r),e(i,()=>s())),t=>t?.close(),u,3,{getFilePath:()=>i});export{q as createFilePersister};
1
+ import{existsSync as t,writeFileSync as a,watch as e}from"fs";import{writeFile as s,readFile as n}from"fs/promises";const r="utf8",o=t=>(a,e,s)=>t(a)?s?.():e(a),i=t=>null==t,c=t=>void 0===t,u=t=>null===t,y=o(i),l=o(c),d=t=>Array.isArray(t),g=t=>t.length,w=t=>{throw Error(t)},p=async(t,a,e)=>{try{return await t()}catch(t){a?.(t)}},f=(t,a)=>t.forEach(a),h=(t,a)=>t.map(a),v=(t,...a)=>t.push(...a),C=t=>t.shift(),S=Object,A=t=>S.getPrototypeOf(t),b=S.entries,m=t=>!i(t)&&y(A(t),t=>t==S.prototype||i(A(t)),()=>!0),L=S.keys,M=S.freeze,P=t=>m(t)&&0==(t=>g(L(t)))(t),E=JSON.stringify,O=JSON.parse,T=t=>""===t?void 0:d(t)?h(t,T):m(t)?((t,a)=>((t=[])=>S.fromEntries(t))(((t,a)=>h(b(t),([t,e])=>a(e,t)))(t,(t,e)=>[e,a(t,e)])))(t,T):t,z=t=>c(t)||0==(t=>t?.size??0)(t),D=(t,a)=>t?.forEach(a),F=(t,a)=>t?.delete(a),J=t=>new Map(t),N=(t,a)=>t?.get(a),j=(t,a,e)=>c(e)?(F(t,a),t):t?.set(a,e),k=(t,a,e,s)=>{var n,r;return n=t,r=a,n?.has(r)?s?.(N(t,a)):j(t,a,e()),N(t,a)},x=(t,a,e,s,n=0)=>l((e?k:N)(t,a[n],n>g(a)-2?e:J),r=>{if(n>g(a)-2)return s?.(r)&&j(t,a[n]),r;const o=x(r,a,e,s,n+1);return z(r)&&j(t,a[n]),o}),$=/^\d+$/,q=t=>new Set(d(t)||c(t)?t:[t]),B=J(),G=J(),H=(t,a,e,s,n,r,o,i={},y=0,h=[])=>{let S,A,b,m=0,L=0,E=0;k(B,h,()=>0),k(G,h,()=>[]);const O=J(),[T,H,I,K,Q]=((t=1,a,e)=>1!=t&&a.isMergeable()?[1,a.getMergeableContent,()=>a.getTransactionMergeableChanges(!e),([[t],[a]])=>!P(t)||!P(a),a.setDefaultContent]:2!=t?[0,a.getContent,a.getTransactionChanges,([t,a])=>!P(t)||!P(a),a.setContent]:w("Store type not supported by this Persister"))(o,t,y),[R,U,V]=(()=>{let t;const[a,e]=(()=>{const t=[];let a=0;return[e=>(e?C(t):null)??""+a++,a=>{$.test(a)&&g(t)<1e3&&v(t,a)}]})(),s=J();return[(e,n,r,o=[],i=()=>[])=>{t??=rt;const c=a(1);var u,y;return j(s,c,[e,n,r,o,i]),u=x(n,r??[""],q),y=c,u?.add(y),c},(a,e,...n)=>f(((t,a=[""])=>{const e=[],s=(t,n)=>n==g(a)?v(e,t):u(a[n])?D(t,t=>s(t,n+1)):f([a[n],null],a=>s(N(t,a),n+1));return s(t,0),e})(a,e),a=>D(a,a=>N(s,a)[0](t,...e??[],...n))),t=>l(N(s,t),([,a,n])=>(x(a,n??[""],void 0,a=>(F(a,t),z(a)?1:0)),j(s,t),e(t),n)),a=>l(N(s,a),([a,,e=[],s,n])=>{const r=(...o)=>{const i=g(o);i==g(e)?a(t,...o,...n(o)):u(e[i])?f(s[i]?.(...o)??[],t=>r(...o,t)):r(...o,e[i])};r()})]})(),W=t=>{t!=m&&(m=t,U(O,void 0,m))},X=a=>{(T&&d(a?.[0])?1===a?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===a?.[2]?t.applyChanges:t.setContent)(a)},Y=async t=>(2!=m&&(W(1),L++,await nt(async()=>{await p(async()=>{const e=await a();d(e)?X(e):t?Q(t):w("Content is not an array: "+e)},()=>{t&&Q(t)}),W(0)})),rt),Z=async t=>(_(),await Y(t),await p(async()=>A=await s(async(t,a)=>{a||t?2!=m&&(W(1),L++,X(a??t),W(0)):await Y()}),r),rt),_=async()=>(A&&(await p(()=>n(A),r),A=void 0),rt),tt=async t=>(1!=m&&(W(2),E++,await nt(async()=>{await p(()=>e(H,t),r),W(0)})),rt),at=async()=>(et(),await tt(),b=t.addDidFinishTransactionListener(()=>{const t=I();K(t)&&tt(t)}),rt),et=async()=>(b&&(t.delListener(b),b=void 0),rt),st=async(t=!1)=>{const[a,e]=t?[et,_]:[_,et];return await a(),await e(),rt},nt=async(...t)=>(v(N(G,h),...t),await(async()=>{if(!N(B,h)){for(j(B,h,1);!c(S=C(N(G,h)));)await p(S,r);j(B,h,0)}})(),rt),rt={load:Y,startAutoLoad:Z,stopAutoLoad:_,isAutoLoading:()=>!c(A),save:tt,startAutoSave:at,stopAutoSave:et,isAutoSaving:()=>!c(b),startAutoPersisting:async(t,a=!1)=>{const[e,s]=a?[at,Z]:[Z,at];return await e(t),await s(t),rt},stopAutoPersisting:st,getStatus:()=>m,addStatusListener:t=>R(t,O),delListener:a=>(V(a),t),schedule:nt,getStore:()=>t,destroy:()=>(N(G,h).splice(0,void 0),st()),getStats:()=>({loads:L,saves:E}),...i};return M(rt)},I=(o,i,u)=>H(o,async()=>{return t=await n(i,r),T(O(t));var t},async t=>{return await s(i,(a=t(),E(a,(t,a)=>c(a)?"":a)),r);var a},s=>(t(i)||a(i,"",r),e(i,()=>s())),t=>t?.close(),u,3,{getFilePath:()=>i});export{I as createFilePersister};
@@ -1 +1 @@
1
- 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),b=(a,t)=>a.filter(t),D=(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",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=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)=>h(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)=>h([...a?.entries()??[]],([a,e])=>t(e,a)),ga=(a,t,e)=>y(e)?(M(a,t),a):a?.set(t,e),pa=(a,t,e,n)=>(S(a,t)?n?.(ua(a,t)):ga(a,t,e()),ua(a,t)),va=(a,t,e,n,s=0)=>g((e?pa: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=va(i,t,e,n,s+1);return L(i)&&ga(a,t[s]),r}),Ea=a=>new Set(v(a)||y(a)?a:[a]),Aa=(a,t)=>a?.add(t),Na="ColumnName",ma="store",$a="json",fa=ma+"TableName",Ca=ma+"Id"+Na,Ta=ma+Na,ha="autoLoadIntervalSeconds",Oa="rowId"+Na,ba="tableId",Da="tableName",Ia="deleteEmptyColumns",Sa="deleteEmptyTable",La="condition",Ra={mode:$a,[ha]:1},Pa={load:0,save:0,[Da]:t+"_values"},Ma=(a,t,e,n,s)=>{const i=ya();return oa(a,(a,r)=>{const o=E(ca(sa(t,p(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(),xa=ya(),Ba=(a,t,n,s,i,r,o,c={},l=0,w=[])=>{let d,p,E,N=0,m=0,T=0;pa(ja,w,()=>0),pa(xa,w,()=>[]);const h=ya(),[O,b,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&&D(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(va(i,r??[e],Ea),l),l},(t,n,...i)=>C(((a,t=[e])=>{const n=[],s=(a,e)=>e==A(t)?D(n,a):u(t[e])?P(a,a=>s(a,e+1)):C([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])=>(va(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])?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 a=>(2!=N&&(x(1),m++,await K(async()=>{await f(async()=>{const e=await t();v(e)?B(e):a?_(a):$("Content is not an array: "+e)},()=>{a&&_(a)}),x(0)})),Q),Y=async a=>(k(),await J(a),await f(async()=>p=await s(async(a,t)=>{t||a?2!=N&&(x(1),m++,B(t??a),x(0)):await J()}),r),Q),k=async()=>(p&&(await f(()=>i(p),r),p=void 0),Q),z=async a=>(1!=N&&(x(2),T++,await K(async()=>{await f(()=>n(b,a),r),x(0)})),Q),G=async()=>(H(),await z(),E=a.addDidFinishTransactionListener(()=>{const a=S();R(a)&&z(a)}),Q),H=async()=>(E&&(a.delListener(E),E=void 0),Q),q=async(a=!1)=>{const[t,e]=a?[H,k]:[k,H];return await t(),await e(),Q},K=async(...a)=>(D(ua(xa,w),...a),await(async()=>{if(!ua(ja,w)){for(ga(ja,w,1);!y(d=I(ua(xa,w)));)await f(d,r);ga(ja,w,0)}})(),Q),Q={load:J,startAutoLoad:Y,stopAutoLoad:k,isAutoLoading:()=>!y(p),save:z,startAutoSave:G,stopAutoSave:H,isAutoSaving:()=>!y(E),startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[G,Y]:[Y,G];return await e(a),await n(a),Q},stopAutoPersisting:q,getStatus:()=>N,addStatusListener:a=>F(a,h),delListener:t=>(j(t),a),schedule:K,getStore:()=>a,destroy:()=>(ua(xa,w).splice(0,void 0),q()),getStats:()=>({loads:m,saves:T}),...c};return ea(Q)},Ja=(a,t,e,s,r,o=Ya,c,l)=>{const w=ya();return[async()=>{w.clear(),h(await e(a,t),({tn:a,cn:t})=>Aa(pa(w,a,Ea),t))},async(t,e,n)=>((a,t)=>S(ua(w,a),t))(t,e)?na(b(h(await a(k+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 p=Ea();oa(s??{},a=>h(ta(a??{}),a=>Aa(p,a)));const v=R(p);if(!d&&u&&g==i&&O(v)&&S(w,t))return await a("DROP "+x+Q(t)),void ga(w,t);const E=ua(w,t),A=Ea(R(E));if(O(v)||(S(w,t)?await m(h([e,...v],async(n,s)=>{M(A,n)||(await a(B+Q(t)+"ADD"+Q(n)+r),0==s&&await a("CREATE UNIQUE INDEX pk ON "+Q(t)+`(${Q(e)})`),Aa(E,n))})):(await a(K+Q(t)+`(${Q(e)}${r} PRIMARY KEY${T(h(v,a=>n+Q(a)+r))});`),ga(w,t,Ea([e,...v])))),await m([...!d&&l?h(R(A),async n=>{n!=e&&(await a(B+Q(t)+"DROP"+Q(n)),M(E,n))}):[]]),d)y(s)?await a(Y+Q(t)+W(t,g)):await m(ra(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,ta(n),{[s]:c?h(ca(n),c):ca(n)},E)}));else if(O(v))S(w,t)&&await a(Y+Q(t)+W(t,g));else{const n=b(R(ua(w,t)),a=>a!=e),i={},r=[];oa(s??{},(a,t)=>{i[t]=h(n,t=>c?c(a?.[t]):a?.[t]),D(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}]},Ya=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(ra(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),ra(i,(a,t)=>[t,...h(a,a=>a??null)]).flat())},ka=(a,t,e,n,s,i,r,[o,c,l],w,u,d,g,p,v)=>{const[E,A,N,m]=Ja(t,w,u,s,p,v),$=Ba(a,()=>m(async()=>{return await E(),a=(await A(o,c))[_]?.[l]??"null",Fa(a,(a,t)=>""===t?void 0:t);var a}),a=>m(async()=>{var t;await E(),await N(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,p,v,E,A,N,$)=>{const[f,C,T,h]=Ja(t,d,g,s,E,A,N,$),O=(a,t)=>m(da(c,async([e,n,s,i,r],o)=>{t&&!(o in a)||await T(e,n,a[o],s,i,t,r)})),D=async(a,t)=>w?await T(u,F,{[_]:a},!0,!0,t):null,I=Ba(a,()=>h(async()=>{await f();const a=await(async()=>na(b(await m(da(o,async([a,t,e],n)=>[a,await C(n,t,e)])),a=>!wa(a[1]))))(),t=await(async()=>l?(await C(u,F))[_]:{})();return wa(a)&&y(t)?void 0:[a,t]}),(a,t)=>h(async()=>{if(await f(),y(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,r,{[v]:()=>p,destroy:async()=>(await I.stopAutoPersisting(),i(),I)},0,p);return I},Ga=(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,b]=(a=>{const e=(a=>sa(Ra,p(a)?{[fa]:a}:a??{}))(a),n=e[ha];if(e.mode==$a){const a=e[fa]??t;return[1,n,[a,e[Ca]??F,e[Ta]??ma],Ea(a)]}const{tables:{load:s={},save:r={}}={},values:o={}}=e,c=E(ca(sa(Pa,o)),0,la(Pa)),l=c[2],w=Ea(l),y=Ea(l),u=Ma(s,{[ba]:null,[Oa]:F,[La]:i},ba,a=>S(y,a),a=>Aa(w,a)),d=Ma(r,{[Da]:null,[Oa]:F,[Ia]:0,[Sa]:0,[La]:null},Da,(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(T?ka:za)(a,C,a=>{let t;const e=()=>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=()=>{N=m=$=null,l(t)},s=r(t=>{b.has(t)&&(n(),a(),e())});return e(),()=>{n(),o(s)}},a=>a(),y,u,d,O,R(b),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)},Ha=(a,t,e,n,s)=>Ga(a,e,async(a,e=[])=>(await t.execute({sql:a,args:e})).rows,()=>N,a=>a(),n,s,N,1,t,"getClient");export{Ha as createLibSqlPersister};
1
+ 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),b=(a,t)=>a.filter(t),D=(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",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=a=>new Map(a),da=(a,t)=>a?.get(t),ga=(a,t)=>h([...a?.entries()??[]],([a,e])=>t(e,a)),pa=(a,t,e)=>y(e)?(M(a,t),a):a?.set(t,e),va=(a,t,e,n)=>(S(a,t)?n?.(da(a,t)):pa(a,t,e()),da(a,t)),Ea=(a,t,e,n,s=0)=>g((e?va:da)(a,t[s],s>A(t)-2?e:ua),i=>{if(s>A(t)-2)return n?.(i)&&pa(a,t[s]),i;const r=Ea(i,t,e,n,s+1);return L(i)&&pa(a,t[s]),r}),Aa=a=>new Set(v(a)||y(a)?a:[a]),Na=(a,t)=>a?.add(t),ma="ColumnName",$a="store",fa="json",Ca=$a+"TableName",Ta=$a+"Id"+ma,ha=$a+ma,Oa="autoLoadIntervalSeconds",ba="rowId"+ma,Da="tableId",Ia="tableName",Sa="deleteEmptyColumns",La="deleteEmptyTable",Ra="condition",Pa={mode:fa,[Oa]:1},Ma={load:0,save:0,[Ia]:t+"_values"},_a=(a,t,e,n,s)=>{const i=ua();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]),pa(i,r,o))}),i},Fa=JSON.stringify,Ua=JSON.parse,ja=a=>""===a?void 0:v(a)?h(a,ja):ta(a)?ca(a,ja):a,xa=/^\d+$/,Ba=ua(),Ja=ua(),Ya=(a,t,n,s,i,r,o,c={},l=0,w=[])=>{let d,p,E,N=0,m=0,T=0;va(Ba,w,()=>0),va(Ja,w,()=>[]);const h=ua(),[O,b,S,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?I(a):null)??e+t++,t=>{xa.test(t)&&A(a)<1e3&&D(a,t)}]})(),s=ua();return[(n,i,r,o=[],c=()=>[])=>{a??=Q;const l=t(1);return pa(s,l,[n,i,r,o,c]),Na(Ea(i,r??[e],Aa),l),l},(t,n,...i)=>C(((a,t=[e])=>{const n=[],s=(a,e)=>e==A(t)?D(n,a):u(t[e])?P(a,a=>s(a,e+1)):C([t[e],null],t=>s(da(a,t),e+1));return s(a,0),n})(t,n),t=>P(t,t=>da(s,t)[0](a,...n??[],...i))),a=>g(da(s,a),([,t,i])=>(Ea(t,i??[e],void 0,t=>(M(t,a),L(t)?1:0)),pa(s,a),n(a),i)),t=>g(da(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 a=>(2!=N&&(x(1),m++,await K(async()=>{await f(async()=>{const e=await t();v(e)?B(e):a?_(a):$("Content is not an array: "+e)},()=>{a&&_(a)}),x(0)})),Q),Y=async a=>(k(),await J(a),await f(async()=>p=await s(async(a,t)=>{t||a?2!=N&&(x(1),m++,B(t??a),x(0)):await J()}),r),Q),k=async()=>(p&&(await f(()=>i(p),r),p=void 0),Q),z=async a=>(1!=N&&(x(2),T++,await K(async()=>{await f(()=>n(b,a),r),x(0)})),Q),G=async()=>(H(),await z(),E=a.addDidFinishTransactionListener(()=>{const a=S();R(a)&&z(a)}),Q),H=async()=>(E&&(a.delListener(E),E=void 0),Q),q=async(a=!1)=>{const[t,e]=a?[H,k]:[k,H];return await t(),await e(),Q},K=async(...a)=>(D(da(Ja,w),...a),await(async()=>{if(!da(Ba,w)){for(pa(Ba,w,1);!y(d=I(da(Ja,w)));)await f(d,r);pa(Ba,w,0)}})(),Q),Q={load:J,startAutoLoad:Y,stopAutoLoad:k,isAutoLoading:()=>!y(p),save:z,startAutoSave:G,stopAutoSave:H,isAutoSaving:()=>!y(E),startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[G,Y]:[Y,G];return await e(a),await n(a),Q},stopAutoPersisting:q,getStatus:()=>N,addStatusListener:a=>F(a,h),delListener:t=>(j(t),a),schedule:K,getStore:()=>a,destroy:()=>(da(Ja,w).splice(0,void 0),q()),getStats:()=>({loads:m,saves:T}),...c};return na(Q)},ka=(a,t,e,s,r,o=za,c,l)=>{const w=ua();return[async()=>{w.clear(),h(await e(a,t),({tn:a,cn:t})=>Na(va(w,a,Aa),t))},async(t,e,n)=>((a,t)=>S(da(w,a),t))(t,e)?sa(b(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=Aa();ca(s??{},a=>h(ea(a??{}),a=>Na(p,a)));const v=R(p);if(!d&&u&&g==i&&O(v)&&S(w,t))return await a("DROP "+x+Q(t)),void pa(w,t);const E=da(w,t),A=Aa(R(E));if(O(v)||(S(w,t)?await m(h([e,...v],async(n,s)=>{M(A,n)||(await a(B+Q(t)+"ADD"+Q(n)+r),0==s&&await a("CREATE UNIQUE INDEX pk ON "+Q(t)+`(${Q(e)})`),Na(E,n))})):(await a(K+Q(t)+`(${Q(e)}${r} PRIMARY KEY${T(h(v,a=>n+Q(a)+r))});`),pa(w,t,Aa([e,...v])))),await m([...!d&&l?h(R(A),async n=>{n!=e&&(await a(B+Q(t)+"DROP"+Q(n)),M(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))S(w,t)&&await a(Y+Q(t)+W(t,g));else{const n=b(R(da(w,t)),a=>a!=e),i={},r=[];ca(s??{},(a,t)=>{i[t]=h(n,t=>c?c(a?.[t]):a?.[t]),D(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}]},za=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())},Ga=(a,t,e,n,s,i,r,[o,c,l],w,u,d,g,p,v)=>{const[E,A,N,m]=ka(t,w,u,s,p,v),$=Ya(a,()=>m(async()=>{return await E(),a=(await A(o,c))[_]?.[l]??"null",ja(Ua(a));var a}),a=>m(async()=>{var t;await E(),await N(o,c,{[_]:{[l]:(t=a()??null,Fa(t,(a,t)=>y(t)?"":t))}},!0,!0)}),e,n,s,r,{[g]:()=>d,destroy:async()=>(await $.stopAutoPersisting(),i(),$)},0,d);return $},Ha=(a,t,e,n,s,i,r,[o,c,[l,w,u]],d,g,p,v,E,A,N,$)=>{const[f,C,T,h]=ka(t,d,g,s,E,A,N,$),O=(a,t)=>m(ga(c,async([e,n,s,i,r],o)=>{t&&!(o in a)||await T(e,n,a[o],s,i,t,r)})),D=async(a,t)=>w?await T(u,F,{[_]:a},!0,!0,t):null,I=Ya(a,()=>h(async()=>{await f();const a=await(async()=>sa(b(await m(ga(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 D(e)}else await O(t[0],!0),await D(t[1],!0)}),e,n,s,r,{[v]:()=>p,destroy:async()=>(await I.stopAutoPersisting(),i(),I)},0,p);return I},qa=(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,b]=(a=>{const e=(a=>ia(Pa,p(a)?{[Ca]:a}:a??{}))(a),n=e[Oa];if(e.mode==fa){const a=e[Ca]??t;return[1,n,[a,e[Ta]??F,e[ha]??$a],Aa(a)]}const{tables:{load:s={},save:r={}}={},values:o={}}=e,c=E(la(ia(Ma,o)),0,wa(Ma)),l=c[2],w=Aa(l),y=Aa(l),u=_a(s,{[Da]:null,[ba]:F,[Ra]:i},Da,a=>S(y,a),a=>Na(w,a)),d=_a(r,{[Ia]:null,[ba]:F,[Sa]:0,[La]:0,[Ra]:null},Ia,(a,t)=>S(y,t),(a,t)=>Na(w,t));var g;return g=(a,t)=>t[4]??=da(u,t[0])?.[2]??i,P(d,(a,t)=>g(0,a)),[0,n,[u,d,c],w]})(n);return(T?Ga:Ha)(a,C,a=>{let t;const e=()=>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=()=>{N=m=$=null,l(t)},s=r(t=>{b.has(t)&&(n(),a(),e())});return e(),()=>{n(),o(s)}},a=>a(),y,u,d,O,R(b),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)},Ka=(a,t,e,n,s)=>qa(a,e,async(a,e=[])=>(await t.execute({sql:a,args:e})).rows,()=>N,a=>a(),n,s,N,1,t,"getClient");export{Ka as createLibSqlPersister};
@@ -1 +1 @@
1
- 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),b=(a,t)=>a.filter(t),D=(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",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=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)=>h(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)=>h([...a?.entries()??[]],([a,e])=>t(e,a)),ga=(a,t,e)=>y(e)?(M(a,t),a):a?.set(t,e),pa=(a,t,e,n)=>(S(a,t)?n?.(ua(a,t)):ga(a,t,e()),ua(a,t)),va=(a,t,e,n,s=0)=>g((e?pa: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=va(i,t,e,n,s+1);return L(i)&&ga(a,t[s]),r}),Ea=a=>new Set(v(a)||y(a)?a:[a]),Aa=(a,t)=>a?.add(t),Na="ColumnName",ma="store",$a="json",fa=ma+"TableName",Ca=ma+"Id"+Na,Ta=ma+Na,ha="autoLoadIntervalSeconds",Oa="rowId"+Na,ba="tableId",Da="tableName",Ia="deleteEmptyColumns",Sa="deleteEmptyTable",La="condition",Ra={mode:$a,[ha]:1},Pa={load:0,save:0,[Da]:t+"_values"},Ma=(a,t,e,n,s)=>{const i=ya();return oa(a,(a,r)=>{const o=E(ca(sa(t,p(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(),xa=ya(),Ba=(a,t,n,s,i,r,o,c={},l=0,w=[])=>{let d,p,E,N=0,m=0,T=0;pa(ja,w,()=>0),pa(xa,w,()=>[]);const h=ya(),[O,b,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&&D(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(va(i,r??[e],Ea),l),l},(t,n,...i)=>C(((a,t=[e])=>{const n=[],s=(a,e)=>e==A(t)?D(n,a):u(t[e])?P(a,a=>s(a,e+1)):C([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])=>(va(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])?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 a=>(2!=N&&(x(1),m++,await K(async()=>{await f(async()=>{const e=await t();v(e)?B(e):a?_(a):$("Content is not an array: "+e)},()=>{a&&_(a)}),x(0)})),Q),Y=async a=>(k(),await J(a),await f(async()=>p=await s(async(a,t)=>{t||a?2!=N&&(x(1),m++,B(t??a),x(0)):await J()}),r),Q),k=async()=>(p&&(await f(()=>i(p),r),p=void 0),Q),z=async a=>(1!=N&&(x(2),T++,await K(async()=>{await f(()=>n(b,a),r),x(0)})),Q),G=async()=>(H(),await z(),E=a.addDidFinishTransactionListener(()=>{const a=S();R(a)&&z(a)}),Q),H=async()=>(E&&(a.delListener(E),E=void 0),Q),q=async(a=!1)=>{const[t,e]=a?[H,k]:[k,H];return await t(),await e(),Q},K=async(...a)=>(D(ua(xa,w),...a),await(async()=>{if(!ua(ja,w)){for(ga(ja,w,1);!y(d=I(ua(xa,w)));)await f(d,r);ga(ja,w,0)}})(),Q),Q={load:J,startAutoLoad:Y,stopAutoLoad:k,isAutoLoading:()=>!y(p),save:z,startAutoSave:G,stopAutoSave:H,isAutoSaving:()=>!y(E),startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[G,Y]:[Y,G];return await e(a),await n(a),Q},stopAutoPersisting:q,getStatus:()=>N,addStatusListener:a=>F(a,h),delListener:t=>(j(t),a),schedule:K,getStore:()=>a,destroy:()=>(ua(xa,w).splice(0,void 0),q()),getStats:()=>({loads:m,saves:T}),...c};return ea(Q)},Ja=(a,t,e,s,r,o=Ya,c,l)=>{const w=ya();return[async()=>{w.clear(),h(await e(a,t),({tn:a,cn:t})=>Aa(pa(w,a,Ea),t))},async(t,e,n)=>((a,t)=>S(ua(w,a),t))(t,e)?na(b(h(await a(k+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 p=Ea();oa(s??{},a=>h(ta(a??{}),a=>Aa(p,a)));const v=R(p);if(!d&&u&&g==i&&O(v)&&S(w,t))return await a("DROP "+x+Q(t)),void ga(w,t);const E=ua(w,t),A=Ea(R(E));if(O(v)||(S(w,t)?await m(h([e,...v],async(n,s)=>{M(A,n)||(await a(B+Q(t)+"ADD"+Q(n)+r),0==s&&await a("CREATE UNIQUE INDEX pk ON "+Q(t)+`(${Q(e)})`),Aa(E,n))})):(await a(K+Q(t)+`(${Q(e)}${r} PRIMARY KEY${T(h(v,a=>n+Q(a)+r))});`),ga(w,t,Ea([e,...v])))),await m([...!d&&l?h(R(A),async n=>{n!=e&&(await a(B+Q(t)+"DROP"+Q(n)),M(E,n))}):[]]),d)y(s)?await a(Y+Q(t)+W(t,g)):await m(ra(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,ta(n),{[s]:c?h(ca(n),c):ca(n)},E)}));else if(O(v))S(w,t)&&await a(Y+Q(t)+W(t,g));else{const n=b(R(ua(w,t)),a=>a!=e),i={},r=[];oa(s??{},(a,t)=>{i[t]=h(n,t=>c?c(a?.[t]):a?.[t]),D(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}]},Ya=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(ra(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),ra(i,(a,t)=>[t,...h(a,a=>a??null)]).flat())},ka=(a,t,e,n,s,i,r,[o,c,l],w,u,d,g,p,v)=>{const[E,A,N,m]=Ja(t,w,u,s,p,v),$=Ba(a,()=>m(async()=>{return await E(),a=(await A(o,c))[_]?.[l]??"null",Fa(a,(a,t)=>""===t?void 0:t);var a}),a=>m(async()=>{var t;await E(),await N(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,p,v,E,A,N,$)=>{const[f,C,T,h]=Ja(t,d,g,s,E,A,N,$),O=(a,t)=>m(da(c,async([e,n,s,i,r],o)=>{t&&!(o in a)||await T(e,n,a[o],s,i,t,r)})),D=async(a,t)=>w?await T(u,F,{[_]:a},!0,!0,t):null,I=Ba(a,()=>h(async()=>{await f();const a=await(async()=>na(b(await m(da(o,async([a,t,e],n)=>[a,await C(n,t,e)])),a=>!wa(a[1]))))(),t=await(async()=>l?(await C(u,F))[_]:{})();return wa(a)&&y(t)?void 0:[a,t]}),(a,t)=>h(async()=>{if(await f(),y(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,r,{[v]:()=>p,destroy:async()=>(await I.stopAutoPersisting(),i(),I)},0,p);return I},Ga=(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,b]=(a=>{const e=(a=>sa(Ra,p(a)?{[fa]:a}:a??{}))(a),n=e[ha];if(e.mode==$a){const a=e[fa]??t;return[1,n,[a,e[Ca]??F,e[Ta]??ma],Ea(a)]}const{tables:{load:s={},save:r={}}={},values:o={}}=e,c=E(ca(sa(Pa,o)),0,la(Pa)),l=c[2],w=Ea(l),y=Ea(l),u=Ma(s,{[ba]:null,[Oa]:F,[La]:i},ba,a=>S(y,a),a=>Aa(w,a)),d=Ma(r,{[Da]:null,[Oa]:F,[Ia]:0,[Sa]:0,[La]:null},Da,(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(T?ka:za)(a,C,a=>{let t;const e=()=>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=()=>{N=m=$=null,l(t)},s=r(t=>{b.has(t)&&(n(),a(),e())});return e(),()=>{n(),o(s)}},a=>a(),y,u,d,O,R(b),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)},Ha=(a,t,e,n,s)=>Ga(a,e,async(a,e=[])=>(await t.execute({sql:a,args:e})).rows,()=>N,a=>a(),n,s,N,1,t,"getClient");export{Ha as createLibSqlPersister};
1
+ 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),b=(a,t)=>a.filter(t),D=(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",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=a=>new Map(a),da=(a,t)=>a?.get(t),ga=(a,t)=>h([...a?.entries()??[]],([a,e])=>t(e,a)),pa=(a,t,e)=>y(e)?(M(a,t),a):a?.set(t,e),va=(a,t,e,n)=>(S(a,t)?n?.(da(a,t)):pa(a,t,e()),da(a,t)),Ea=(a,t,e,n,s=0)=>g((e?va:da)(a,t[s],s>A(t)-2?e:ua),i=>{if(s>A(t)-2)return n?.(i)&&pa(a,t[s]),i;const r=Ea(i,t,e,n,s+1);return L(i)&&pa(a,t[s]),r}),Aa=a=>new Set(v(a)||y(a)?a:[a]),Na=(a,t)=>a?.add(t),ma="ColumnName",$a="store",fa="json",Ca=$a+"TableName",Ta=$a+"Id"+ma,ha=$a+ma,Oa="autoLoadIntervalSeconds",ba="rowId"+ma,Da="tableId",Ia="tableName",Sa="deleteEmptyColumns",La="deleteEmptyTable",Ra="condition",Pa={mode:fa,[Oa]:1},Ma={load:0,save:0,[Ia]:t+"_values"},_a=(a,t,e,n,s)=>{const i=ua();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]),pa(i,r,o))}),i},Fa=JSON.stringify,Ua=JSON.parse,ja=a=>""===a?void 0:v(a)?h(a,ja):ta(a)?ca(a,ja):a,xa=/^\d+$/,Ba=ua(),Ja=ua(),Ya=(a,t,n,s,i,r,o,c={},l=0,w=[])=>{let d,p,E,N=0,m=0,T=0;va(Ba,w,()=>0),va(Ja,w,()=>[]);const h=ua(),[O,b,S,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?I(a):null)??e+t++,t=>{xa.test(t)&&A(a)<1e3&&D(a,t)}]})(),s=ua();return[(n,i,r,o=[],c=()=>[])=>{a??=Q;const l=t(1);return pa(s,l,[n,i,r,o,c]),Na(Ea(i,r??[e],Aa),l),l},(t,n,...i)=>C(((a,t=[e])=>{const n=[],s=(a,e)=>e==A(t)?D(n,a):u(t[e])?P(a,a=>s(a,e+1)):C([t[e],null],t=>s(da(a,t),e+1));return s(a,0),n})(t,n),t=>P(t,t=>da(s,t)[0](a,...n??[],...i))),a=>g(da(s,a),([,t,i])=>(Ea(t,i??[e],void 0,t=>(M(t,a),L(t)?1:0)),pa(s,a),n(a),i)),t=>g(da(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 a=>(2!=N&&(x(1),m++,await K(async()=>{await f(async()=>{const e=await t();v(e)?B(e):a?_(a):$("Content is not an array: "+e)},()=>{a&&_(a)}),x(0)})),Q),Y=async a=>(k(),await J(a),await f(async()=>p=await s(async(a,t)=>{t||a?2!=N&&(x(1),m++,B(t??a),x(0)):await J()}),r),Q),k=async()=>(p&&(await f(()=>i(p),r),p=void 0),Q),z=async a=>(1!=N&&(x(2),T++,await K(async()=>{await f(()=>n(b,a),r),x(0)})),Q),G=async()=>(H(),await z(),E=a.addDidFinishTransactionListener(()=>{const a=S();R(a)&&z(a)}),Q),H=async()=>(E&&(a.delListener(E),E=void 0),Q),q=async(a=!1)=>{const[t,e]=a?[H,k]:[k,H];return await t(),await e(),Q},K=async(...a)=>(D(da(Ja,w),...a),await(async()=>{if(!da(Ba,w)){for(pa(Ba,w,1);!y(d=I(da(Ja,w)));)await f(d,r);pa(Ba,w,0)}})(),Q),Q={load:J,startAutoLoad:Y,stopAutoLoad:k,isAutoLoading:()=>!y(p),save:z,startAutoSave:G,stopAutoSave:H,isAutoSaving:()=>!y(E),startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[G,Y]:[Y,G];return await e(a),await n(a),Q},stopAutoPersisting:q,getStatus:()=>N,addStatusListener:a=>F(a,h),delListener:t=>(j(t),a),schedule:K,getStore:()=>a,destroy:()=>(da(Ja,w).splice(0,void 0),q()),getStats:()=>({loads:m,saves:T}),...c};return na(Q)},ka=(a,t,e,s,r,o=za,c,l)=>{const w=ua();return[async()=>{w.clear(),h(await e(a,t),({tn:a,cn:t})=>Na(va(w,a,Aa),t))},async(t,e,n)=>((a,t)=>S(da(w,a),t))(t,e)?sa(b(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=Aa();ca(s??{},a=>h(ea(a??{}),a=>Na(p,a)));const v=R(p);if(!d&&u&&g==i&&O(v)&&S(w,t))return await a("DROP "+x+Q(t)),void pa(w,t);const E=da(w,t),A=Aa(R(E));if(O(v)||(S(w,t)?await m(h([e,...v],async(n,s)=>{M(A,n)||(await a(B+Q(t)+"ADD"+Q(n)+r),0==s&&await a("CREATE UNIQUE INDEX pk ON "+Q(t)+`(${Q(e)})`),Na(E,n))})):(await a(K+Q(t)+`(${Q(e)}${r} PRIMARY KEY${T(h(v,a=>n+Q(a)+r))});`),pa(w,t,Aa([e,...v])))),await m([...!d&&l?h(R(A),async n=>{n!=e&&(await a(B+Q(t)+"DROP"+Q(n)),M(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))S(w,t)&&await a(Y+Q(t)+W(t,g));else{const n=b(R(da(w,t)),a=>a!=e),i={},r=[];ca(s??{},(a,t)=>{i[t]=h(n,t=>c?c(a?.[t]):a?.[t]),D(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}]},za=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())},Ga=(a,t,e,n,s,i,r,[o,c,l],w,u,d,g,p,v)=>{const[E,A,N,m]=ka(t,w,u,s,p,v),$=Ya(a,()=>m(async()=>{return await E(),a=(await A(o,c))[_]?.[l]??"null",ja(Ua(a));var a}),a=>m(async()=>{var t;await E(),await N(o,c,{[_]:{[l]:(t=a()??null,Fa(t,(a,t)=>y(t)?"":t))}},!0,!0)}),e,n,s,r,{[g]:()=>d,destroy:async()=>(await $.stopAutoPersisting(),i(),$)},0,d);return $},Ha=(a,t,e,n,s,i,r,[o,c,[l,w,u]],d,g,p,v,E,A,N,$)=>{const[f,C,T,h]=ka(t,d,g,s,E,A,N,$),O=(a,t)=>m(ga(c,async([e,n,s,i,r],o)=>{t&&!(o in a)||await T(e,n,a[o],s,i,t,r)})),D=async(a,t)=>w?await T(u,F,{[_]:a},!0,!0,t):null,I=Ya(a,()=>h(async()=>{await f();const a=await(async()=>sa(b(await m(ga(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 D(e)}else await O(t[0],!0),await D(t[1],!0)}),e,n,s,r,{[v]:()=>p,destroy:async()=>(await I.stopAutoPersisting(),i(),I)},0,p);return I},qa=(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,b]=(a=>{const e=(a=>ia(Pa,p(a)?{[Ca]:a}:a??{}))(a),n=e[Oa];if(e.mode==fa){const a=e[Ca]??t;return[1,n,[a,e[Ta]??F,e[ha]??$a],Aa(a)]}const{tables:{load:s={},save:r={}}={},values:o={}}=e,c=E(la(ia(Ma,o)),0,wa(Ma)),l=c[2],w=Aa(l),y=Aa(l),u=_a(s,{[Da]:null,[ba]:F,[Ra]:i},Da,a=>S(y,a),a=>Na(w,a)),d=_a(r,{[Ia]:null,[ba]:F,[Sa]:0,[La]:0,[Ra]:null},Ia,(a,t)=>S(y,t),(a,t)=>Na(w,t));var g;return g=(a,t)=>t[4]??=da(u,t[0])?.[2]??i,P(d,(a,t)=>g(0,a)),[0,n,[u,d,c],w]})(n);return(T?Ga:Ha)(a,C,a=>{let t;const e=()=>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=()=>{N=m=$=null,l(t)},s=r(t=>{b.has(t)&&(n(),a(),e())});return e(),()=>{n(),o(s)}},a=>a(),y,u,d,O,R(b),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)},Ka=(a,t,e,n,s)=>qa(a,e,async(a,e=[])=>(await t.execute({sql:a,args:e})).rows,()=>N,a=>a(),n,s,N,1,t,"getClient");export{Ka as createLibSqlPersister};
@@ -1 +1 @@
1
- const t=t=>typeof t,e="",a=t(e),s="message",n=t=>(e,a,s)=>t(e)?s?.():a(e),o=t=>null==t,r=t=>void 0===t,i=t=>null===t,c=n(o),d=n(r),y=e=>t(e)==a,u=t=>Array.isArray(t),l=t=>t.length,g=t=>{throw Error(t)},p=async(t,e,a)=>{try{return await t()}catch(t){e?.(t)}},w=(t,e)=>t.forEach(e),h=(t,...e)=>t.push(...e),v=t=>t.shift(),f=Object,C=t=>f.getPrototypeOf(t),S=f.keys,A=f.freeze,L=t=>(t=>!o(t)&&c(C(t),t=>t==f.prototype||o(C(t)),()=>!0))(t)&&0==(t=>l(S(t)))(t),P=JSON.stringify,b=JSON.parse,m=t=>P(t,(t,e)=>e instanceof Map?f.fromEntries([...e]):e),M=t=>r(t)||0==(t=>t?.size??0)(t),E=(t,e)=>t?.forEach(e),O=(t,e)=>t?.delete(e),T=t=>new Map(t),j=(t,e)=>t?.get(e),k=(t,e,a)=>r(a)?(O(t,e),t):t?.set(e,a),x=(t,e,a,s)=>{var n,o;return n=t,o=e,n?.has(o)?s?.(j(t,e)):k(t,e,a()),j(t,e)},z=(t,e,a,s,n=0)=>d((a?x:j)(t,e[n],n>l(e)-2?a:T),o=>{if(n>l(e)-2)return s?.(o)&&k(t,e[n]),o;const r=z(o,e,a,s,n+1);return M(o)&&k(t,e[n]),r}),D=/^\d+$/,J=t=>new Set(u(t)||r(t)?t:[t]),N=T(),F=T(),U=(t,a,s,n,o,c,y,f={},C=0,S=[])=>{let P,b,m,U=0,W=0,$=0;x(N,S,()=>0),x(F,S,()=>[]);const q=T(),[B,G,H,I,K]=((t=1,e,a)=>1!=t&&e.isMergeable()?[1,e.getMergeableContent,()=>e.getTransactionMergeableChanges(!a),([[t],[e]])=>!L(t)||!L(e),e.setDefaultContent]:2!=t?[0,e.getContent,e.getTransactionChanges,([t,e])=>!L(t)||!L(e),e.setContent]:g("Store type not supported by this Persister"))(y,t,C),[Q,R,V]=(()=>{let t;const[a,s]=(()=>{const t=[];let a=0;return[s=>(s?v(t):null)??e+a++,e=>{D.test(e)&&l(t)<1e3&&h(t,e)}]})(),n=T();return[(s,o,r,i=[],c=()=>[])=>{t??=rt;const d=a(1);var y,u;return k(n,d,[s,o,r,i,c]),y=z(o,r??[e],J),u=d,y?.add(u),d},(a,s,...o)=>w(((t,a=[e])=>{const s=[],n=(t,e)=>e==l(a)?h(s,t):i(a[e])?E(t,t=>n(t,e+1)):w([a[e],null],a=>n(j(t,a),e+1));return n(t,0),s})(a,s),e=>E(e,e=>j(n,e)[0](t,...s??[],...o))),t=>d(j(n,t),([,a,o])=>(z(a,o??[e],void 0,e=>(O(e,t),M(e)?1:0)),k(n,t),s(t),o)),e=>d(j(n,e),([e,,a=[],s,n])=>{const o=(...r)=>{const c=l(r);c==l(a)?e(t,...r,...n(r)):i(a[c])?w(s[c]?.(...r)??[],t=>o(...r,t)):o(...r,a[c])};o()})]})(),X=t=>{t!=U&&(U=t,R(q,void 0,U))},Y=e=>{(B&&u(e?.[0])?1===e?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===e?.[2]?t.applyChanges:t.setContent)(e)},Z=async t=>(2!=U&&(X(1),W++,await ot(async()=>{await p(async()=>{const e=await a();u(e)?Y(e):t?K(t):g("Content is not an array: "+e)},()=>{t&&K(t)}),X(0)})),rt),_=async t=>(tt(),await Z(t),await p(async()=>b=await n(async(t,e)=>{e||t?2!=U&&(X(1),W++,Y(e??t),X(0)):await Z()}),c),rt),tt=async()=>(b&&(await p(()=>o(b),c),b=void 0),rt),et=async t=>(1!=U&&(X(2),$++,await ot(async()=>{await p(()=>s(G,t),c),X(0)})),rt),at=async()=>(st(),await et(),m=t.addDidFinishTransactionListener(()=>{const t=H();I(t)&&et(t)}),rt),st=async()=>(m&&(t.delListener(m),m=void 0),rt),nt=async(t=!1)=>{const[e,a]=t?[st,tt]:[tt,st];return await e(),await a(),rt},ot=async(...t)=>(h(j(F,S),...t),await(async()=>{if(!j(N,S)){for(k(N,S,1);!r(P=v(j(F,S)));)await p(P,c);k(N,S,0)}})(),rt),rt={load:Z,startAutoLoad:_,stopAutoLoad:tt,isAutoLoading:()=>!r(b),save:et,startAutoSave:at,stopAutoSave:st,isAutoSaving:()=>!r(m),startAutoPersisting:async(t,e=!1)=>{const[a,s]=e?[at,_]:[_,at];return await a(t),await s(t),rt},stopAutoPersisting:nt,getStatus:()=>U,addStatusListener:t=>Q(t,q),delListener:e=>(V(e),t),schedule:ot,getStore:()=>t,destroy:()=>(j(F,S).splice(0,void 0),nt()),getStats:()=>({loads:W,saves:$}),...f};return A(rt)},W="/store",$=(t,a,n,o)=>{const{host:r,room:i}=a.partySocketOptions,{storeProtocol:c="https",storePath:u=W,messagePrefix:g=e}={...y(n)?{storeProtocol:n}:n},p=c+"://"+r+"/parties/"+a.name+"/"+i+u,w=async t=>await(await fetch(p,{...t?{method:"PUT",body:m(t)}:{},mode:"cors",cache:"no-store"})).json();return U(t,w,async(t,e)=>{var s;e?a.send(g+"s"+(y(s=e)?s:m(s))):await w(t())},t=>{const e=e=>d(((t,e)=>{const a=l(t);return((t,e)=>t.startsWith(e))(e,t)?[e[a],b((s=e,n=a+1,s.slice(n,void 0)))]:void 0;var s,n})(g,e.data),([e,a])=>{"s"==e&&t(void 0,a)});return a.addEventListener(s,e),e},t=>{a.removeEventListener(s,t)},o,1,{getConnection:()=>a})};export{$ as createPartyKitPersister};
1
+ const t=t=>typeof t,e="",a=t(e),s="message",n=t=>(e,a,s)=>t(e)?s?.():a(e),r=t=>null==t,o=t=>void 0===t,i=t=>null===t,c=n(r),d=n(o),y=e=>t(e)==a,u=t=>Array.isArray(t),l=t=>t.length,g=t=>{throw Error(t)},p=async(t,e,a)=>{try{return await t()}catch(t){e?.(t)}},w=(t,e)=>t.forEach(e),v=(t,e)=>t.map(e),h=(t,...e)=>t.push(...e),f=t=>t.shift(),C=Object,S=t=>C.getPrototypeOf(t),m=C.entries,A=t=>!r(t)&&c(S(t),t=>t==C.prototype||r(S(t)),()=>!0),L=C.keys,P=C.freeze,b=t=>A(t)&&0==(t=>l(L(t)))(t),E=JSON.stringify,M=JSON.parse,O=t=>""===t?void 0:u(t)?v(t,O):A(t)?((t,e)=>((t=[])=>C.fromEntries(t))(((t,e)=>v(m(t),([t,a])=>e(a,t)))(t,(t,a)=>[a,e(t,a)])))(t,O):t,T=t=>o(t)||0==(t=>t?.size??0)(t),j=(t,e)=>t?.forEach(e),k=(t,e)=>t?.delete(e),x=t=>new Map(t),z=(t,e)=>t?.get(e),D=(t,e,a)=>o(a)?(k(t,e),t):t?.set(e,a),J=(t,e,a,s)=>{var n,r;return n=t,r=e,n?.has(r)?s?.(z(t,e)):D(t,e,a()),z(t,e)},N=(t,e,a,s,n=0)=>d((a?J:z)(t,e[n],n>l(e)-2?a:x),r=>{if(n>l(e)-2)return s?.(r)&&D(t,e[n]),r;const o=N(r,e,a,s,n+1);return T(r)&&D(t,e[n]),o}),F=/^\d+$/,U=t=>new Set(u(t)||o(t)?t:[t]),W=x(),$=x(),q=(t,a,s,n,r,c,y,v={},C=0,S=[])=>{let m,A,L,E=0,M=0,O=0;J(W,S,()=>0),J($,S,()=>[]);const q=x(),[B,G,H,I,K]=((t=1,e,a)=>1!=t&&e.isMergeable()?[1,e.getMergeableContent,()=>e.getTransactionMergeableChanges(!a),([[t],[e]])=>!b(t)||!b(e),e.setDefaultContent]:2!=t?[0,e.getContent,e.getTransactionChanges,([t,e])=>!b(t)||!b(e),e.setContent]:g("Store type not supported by this Persister"))(y,t,C),[Q,R,V]=(()=>{let t;const[a,s]=(()=>{const t=[];let a=0;return[s=>(s?f(t):null)??e+a++,e=>{F.test(e)&&l(t)<1e3&&h(t,e)}]})(),n=x();return[(s,r,o,i=[],c=()=>[])=>{t??=ot;const d=a(1);var y,u;return D(n,d,[s,r,o,i,c]),y=N(r,o??[e],U),u=d,y?.add(u),d},(a,s,...r)=>w(((t,a=[e])=>{const s=[],n=(t,e)=>e==l(a)?h(s,t):i(a[e])?j(t,t=>n(t,e+1)):w([a[e],null],a=>n(z(t,a),e+1));return n(t,0),s})(a,s),e=>j(e,e=>z(n,e)[0](t,...s??[],...r))),t=>d(z(n,t),([,a,r])=>(N(a,r??[e],void 0,e=>(k(e,t),T(e)?1:0)),D(n,t),s(t),r)),e=>d(z(n,e),([e,,a=[],s,n])=>{const r=(...o)=>{const c=l(o);c==l(a)?e(t,...o,...n(o)):i(a[c])?w(s[c]?.(...o)??[],t=>r(...o,t)):r(...o,a[c])};r()})]})(),X=t=>{t!=E&&(E=t,R(q,void 0,E))},Y=e=>{(B&&u(e?.[0])?1===e?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===e?.[2]?t.applyChanges:t.setContent)(e)},Z=async t=>(2!=E&&(X(1),M++,await rt(async()=>{await p(async()=>{const e=await a();u(e)?Y(e):t?K(t):g("Content is not an array: "+e)},()=>{t&&K(t)}),X(0)})),ot),_=async t=>(tt(),await Z(t),await p(async()=>A=await n(async(t,e)=>{e||t?2!=E&&(X(1),M++,Y(e??t),X(0)):await Z()}),c),ot),tt=async()=>(A&&(await p(()=>r(A),c),A=void 0),ot),et=async t=>(1!=E&&(X(2),O++,await rt(async()=>{await p(()=>s(G,t),c),X(0)})),ot),at=async()=>(st(),await et(),L=t.addDidFinishTransactionListener(()=>{const t=H();I(t)&&et(t)}),ot),st=async()=>(L&&(t.delListener(L),L=void 0),ot),nt=async(t=!1)=>{const[e,a]=t?[st,tt]:[tt,st];return await e(),await a(),ot},rt=async(...t)=>(h(z($,S),...t),await(async()=>{if(!z(W,S)){for(D(W,S,1);!o(m=f(z($,S)));)await p(m,c);D(W,S,0)}})(),ot),ot={load:Z,startAutoLoad:_,stopAutoLoad:tt,isAutoLoading:()=>!o(A),save:et,startAutoSave:at,stopAutoSave:st,isAutoSaving:()=>!o(L),startAutoPersisting:async(t,e=!1)=>{const[a,s]=e?[at,_]:[_,at];return await a(t),await s(t),ot},stopAutoPersisting:nt,getStatus:()=>E,addStatusListener:t=>Q(t,q),delListener:e=>(V(e),t),schedule:rt,getStore:()=>t,destroy:()=>(z($,S).splice(0,void 0),nt()),getStats:()=>({loads:M,saves:O}),...v};return P(ot)},B="/store",G=(t,a,n,r)=>{const{host:i,room:c}=a.partySocketOptions,{storeProtocol:u="https",storePath:g=B,messagePrefix:p=e}={...y(n)?{storeProtocol:n}:n},w=u+"://"+i+"/parties/"+a.name+"/"+c+g,v=async t=>{return await(await fetch(w,{...t?{method:"PUT",body:(e=t,E(e,(t,e)=>e instanceof Map?C.fromEntries([...e]):e))}:{},mode:"cors",cache:"no-store"})).json();var e};return q(t,v,async(t,e)=>{var s;e?a.send(p+"s"+(y(s=e)?s:E(s,(t,e)=>o(e)?"":e))):await v(t())},t=>{const e=e=>d(((t,e)=>{const a=l(t);return((t,e)=>t.startsWith(e))(e,t)?[e[a],(n=e,r=a+1,s=n.slice(r,void 0),O(M(s)))]:void 0;var s,n,r})(p,e.data),([e,a])=>{"s"==e&&t(void 0,a)});return a.addEventListener(s,e),e},t=>{a.removeEventListener(s,t)},r,1,{getConnection:()=>a})};export{G as createPartyKitPersister};
@@ -1 +1 @@
1
- const t=t=>typeof t,e="",a=t(e),s="message",n=t=>(e,a,s)=>t(e)?s?.():a(e),o=t=>null==t,r=t=>void 0===t,i=t=>null===t,c=n(o),d=n(r),y=e=>t(e)==a,u=t=>Array.isArray(t),l=t=>t.length,g=t=>{throw Error(t)},p=async(t,e,a)=>{try{return await t()}catch(t){e?.(t)}},w=(t,e)=>t.forEach(e),h=(t,...e)=>t.push(...e),v=t=>t.shift(),f=Object,C=t=>f.getPrototypeOf(t),S=f.keys,A=f.freeze,L=t=>(t=>!o(t)&&c(C(t),t=>t==f.prototype||o(C(t)),()=>!0))(t)&&0==(t=>l(S(t)))(t),P=JSON.stringify,b=JSON.parse,m=t=>P(t,(t,e)=>e instanceof Map?f.fromEntries([...e]):e),M=t=>r(t)||0==(t=>t?.size??0)(t),E=(t,e)=>t?.forEach(e),O=(t,e)=>t?.delete(e),T=t=>new Map(t),j=(t,e)=>t?.get(e),k=(t,e,a)=>r(a)?(O(t,e),t):t?.set(e,a),x=(t,e,a,s)=>{var n,o;return n=t,o=e,n?.has(o)?s?.(j(t,e)):k(t,e,a()),j(t,e)},z=(t,e,a,s,n=0)=>d((a?x:j)(t,e[n],n>l(e)-2?a:T),o=>{if(n>l(e)-2)return s?.(o)&&k(t,e[n]),o;const r=z(o,e,a,s,n+1);return M(o)&&k(t,e[n]),r}),D=/^\d+$/,J=t=>new Set(u(t)||r(t)?t:[t]),N=T(),F=T(),U=(t,a,s,n,o,c,y,f={},C=0,S=[])=>{let P,b,m,U=0,W=0,$=0;x(N,S,()=>0),x(F,S,()=>[]);const q=T(),[B,G,H,I,K]=((t=1,e,a)=>1!=t&&e.isMergeable()?[1,e.getMergeableContent,()=>e.getTransactionMergeableChanges(!a),([[t],[e]])=>!L(t)||!L(e),e.setDefaultContent]:2!=t?[0,e.getContent,e.getTransactionChanges,([t,e])=>!L(t)||!L(e),e.setContent]:g("Store type not supported by this Persister"))(y,t,C),[Q,R,V]=(()=>{let t;const[a,s]=(()=>{const t=[];let a=0;return[s=>(s?v(t):null)??e+a++,e=>{D.test(e)&&l(t)<1e3&&h(t,e)}]})(),n=T();return[(s,o,r,i=[],c=()=>[])=>{t??=rt;const d=a(1);var y,u;return k(n,d,[s,o,r,i,c]),y=z(o,r??[e],J),u=d,y?.add(u),d},(a,s,...o)=>w(((t,a=[e])=>{const s=[],n=(t,e)=>e==l(a)?h(s,t):i(a[e])?E(t,t=>n(t,e+1)):w([a[e],null],a=>n(j(t,a),e+1));return n(t,0),s})(a,s),e=>E(e,e=>j(n,e)[0](t,...s??[],...o))),t=>d(j(n,t),([,a,o])=>(z(a,o??[e],void 0,e=>(O(e,t),M(e)?1:0)),k(n,t),s(t),o)),e=>d(j(n,e),([e,,a=[],s,n])=>{const o=(...r)=>{const c=l(r);c==l(a)?e(t,...r,...n(r)):i(a[c])?w(s[c]?.(...r)??[],t=>o(...r,t)):o(...r,a[c])};o()})]})(),X=t=>{t!=U&&(U=t,R(q,void 0,U))},Y=e=>{(B&&u(e?.[0])?1===e?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===e?.[2]?t.applyChanges:t.setContent)(e)},Z=async t=>(2!=U&&(X(1),W++,await ot(async()=>{await p(async()=>{const e=await a();u(e)?Y(e):t?K(t):g("Content is not an array: "+e)},()=>{t&&K(t)}),X(0)})),rt),_=async t=>(tt(),await Z(t),await p(async()=>b=await n(async(t,e)=>{e||t?2!=U&&(X(1),W++,Y(e??t),X(0)):await Z()}),c),rt),tt=async()=>(b&&(await p(()=>o(b),c),b=void 0),rt),et=async t=>(1!=U&&(X(2),$++,await ot(async()=>{await p(()=>s(G,t),c),X(0)})),rt),at=async()=>(st(),await et(),m=t.addDidFinishTransactionListener(()=>{const t=H();I(t)&&et(t)}),rt),st=async()=>(m&&(t.delListener(m),m=void 0),rt),nt=async(t=!1)=>{const[e,a]=t?[st,tt]:[tt,st];return await e(),await a(),rt},ot=async(...t)=>(h(j(F,S),...t),await(async()=>{if(!j(N,S)){for(k(N,S,1);!r(P=v(j(F,S)));)await p(P,c);k(N,S,0)}})(),rt),rt={load:Z,startAutoLoad:_,stopAutoLoad:tt,isAutoLoading:()=>!r(b),save:et,startAutoSave:at,stopAutoSave:st,isAutoSaving:()=>!r(m),startAutoPersisting:async(t,e=!1)=>{const[a,s]=e?[at,_]:[_,at];return await a(t),await s(t),rt},stopAutoPersisting:nt,getStatus:()=>U,addStatusListener:t=>Q(t,q),delListener:e=>(V(e),t),schedule:ot,getStore:()=>t,destroy:()=>(j(F,S).splice(0,void 0),nt()),getStats:()=>({loads:W,saves:$}),...f};return A(rt)},W="/store",$=(t,a,n,o)=>{const{host:r,room:i}=a.partySocketOptions,{storeProtocol:c="https",storePath:u=W,messagePrefix:g=e}={...y(n)?{storeProtocol:n}:n},p=c+"://"+r+"/parties/"+a.name+"/"+i+u,w=async t=>await(await fetch(p,{...t?{method:"PUT",body:m(t)}:{},mode:"cors",cache:"no-store"})).json();return U(t,w,async(t,e)=>{var s;e?a.send(g+"s"+(y(s=e)?s:m(s))):await w(t())},t=>{const e=e=>d(((t,e)=>{const a=l(t);return((t,e)=>t.startsWith(e))(e,t)?[e[a],b((s=e,n=a+1,s.slice(n,void 0)))]:void 0;var s,n})(g,e.data),([e,a])=>{"s"==e&&t(void 0,a)});return a.addEventListener(s,e),e},t=>{a.removeEventListener(s,t)},o,1,{getConnection:()=>a})};export{$ as createPartyKitPersister};
1
+ const t=t=>typeof t,e="",a=t(e),s="message",n=t=>(e,a,s)=>t(e)?s?.():a(e),r=t=>null==t,o=t=>void 0===t,i=t=>null===t,c=n(r),d=n(o),y=e=>t(e)==a,u=t=>Array.isArray(t),l=t=>t.length,g=t=>{throw Error(t)},p=async(t,e,a)=>{try{return await t()}catch(t){e?.(t)}},w=(t,e)=>t.forEach(e),v=(t,e)=>t.map(e),h=(t,...e)=>t.push(...e),f=t=>t.shift(),C=Object,S=t=>C.getPrototypeOf(t),m=C.entries,A=t=>!r(t)&&c(S(t),t=>t==C.prototype||r(S(t)),()=>!0),L=C.keys,P=C.freeze,b=t=>A(t)&&0==(t=>l(L(t)))(t),E=JSON.stringify,M=JSON.parse,O=t=>""===t?void 0:u(t)?v(t,O):A(t)?((t,e)=>((t=[])=>C.fromEntries(t))(((t,e)=>v(m(t),([t,a])=>e(a,t)))(t,(t,a)=>[a,e(t,a)])))(t,O):t,T=t=>o(t)||0==(t=>t?.size??0)(t),j=(t,e)=>t?.forEach(e),k=(t,e)=>t?.delete(e),x=t=>new Map(t),z=(t,e)=>t?.get(e),D=(t,e,a)=>o(a)?(k(t,e),t):t?.set(e,a),J=(t,e,a,s)=>{var n,r;return n=t,r=e,n?.has(r)?s?.(z(t,e)):D(t,e,a()),z(t,e)},N=(t,e,a,s,n=0)=>d((a?J:z)(t,e[n],n>l(e)-2?a:x),r=>{if(n>l(e)-2)return s?.(r)&&D(t,e[n]),r;const o=N(r,e,a,s,n+1);return T(r)&&D(t,e[n]),o}),F=/^\d+$/,U=t=>new Set(u(t)||o(t)?t:[t]),W=x(),$=x(),q=(t,a,s,n,r,c,y,v={},C=0,S=[])=>{let m,A,L,E=0,M=0,O=0;J(W,S,()=>0),J($,S,()=>[]);const q=x(),[B,G,H,I,K]=((t=1,e,a)=>1!=t&&e.isMergeable()?[1,e.getMergeableContent,()=>e.getTransactionMergeableChanges(!a),([[t],[e]])=>!b(t)||!b(e),e.setDefaultContent]:2!=t?[0,e.getContent,e.getTransactionChanges,([t,e])=>!b(t)||!b(e),e.setContent]:g("Store type not supported by this Persister"))(y,t,C),[Q,R,V]=(()=>{let t;const[a,s]=(()=>{const t=[];let a=0;return[s=>(s?f(t):null)??e+a++,e=>{F.test(e)&&l(t)<1e3&&h(t,e)}]})(),n=x();return[(s,r,o,i=[],c=()=>[])=>{t??=ot;const d=a(1);var y,u;return D(n,d,[s,r,o,i,c]),y=N(r,o??[e],U),u=d,y?.add(u),d},(a,s,...r)=>w(((t,a=[e])=>{const s=[],n=(t,e)=>e==l(a)?h(s,t):i(a[e])?j(t,t=>n(t,e+1)):w([a[e],null],a=>n(z(t,a),e+1));return n(t,0),s})(a,s),e=>j(e,e=>z(n,e)[0](t,...s??[],...r))),t=>d(z(n,t),([,a,r])=>(N(a,r??[e],void 0,e=>(k(e,t),T(e)?1:0)),D(n,t),s(t),r)),e=>d(z(n,e),([e,,a=[],s,n])=>{const r=(...o)=>{const c=l(o);c==l(a)?e(t,...o,...n(o)):i(a[c])?w(s[c]?.(...o)??[],t=>r(...o,t)):r(...o,a[c])};r()})]})(),X=t=>{t!=E&&(E=t,R(q,void 0,E))},Y=e=>{(B&&u(e?.[0])?1===e?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===e?.[2]?t.applyChanges:t.setContent)(e)},Z=async t=>(2!=E&&(X(1),M++,await rt(async()=>{await p(async()=>{const e=await a();u(e)?Y(e):t?K(t):g("Content is not an array: "+e)},()=>{t&&K(t)}),X(0)})),ot),_=async t=>(tt(),await Z(t),await p(async()=>A=await n(async(t,e)=>{e||t?2!=E&&(X(1),M++,Y(e??t),X(0)):await Z()}),c),ot),tt=async()=>(A&&(await p(()=>r(A),c),A=void 0),ot),et=async t=>(1!=E&&(X(2),O++,await rt(async()=>{await p(()=>s(G,t),c),X(0)})),ot),at=async()=>(st(),await et(),L=t.addDidFinishTransactionListener(()=>{const t=H();I(t)&&et(t)}),ot),st=async()=>(L&&(t.delListener(L),L=void 0),ot),nt=async(t=!1)=>{const[e,a]=t?[st,tt]:[tt,st];return await e(),await a(),ot},rt=async(...t)=>(h(z($,S),...t),await(async()=>{if(!z(W,S)){for(D(W,S,1);!o(m=f(z($,S)));)await p(m,c);D(W,S,0)}})(),ot),ot={load:Z,startAutoLoad:_,stopAutoLoad:tt,isAutoLoading:()=>!o(A),save:et,startAutoSave:at,stopAutoSave:st,isAutoSaving:()=>!o(L),startAutoPersisting:async(t,e=!1)=>{const[a,s]=e?[at,_]:[_,at];return await a(t),await s(t),ot},stopAutoPersisting:nt,getStatus:()=>E,addStatusListener:t=>Q(t,q),delListener:e=>(V(e),t),schedule:rt,getStore:()=>t,destroy:()=>(z($,S).splice(0,void 0),nt()),getStats:()=>({loads:M,saves:O}),...v};return P(ot)},B="/store",G=(t,a,n,r)=>{const{host:i,room:c}=a.partySocketOptions,{storeProtocol:u="https",storePath:g=B,messagePrefix:p=e}={...y(n)?{storeProtocol:n}:n},w=u+"://"+i+"/parties/"+a.name+"/"+c+g,v=async t=>{return await(await fetch(w,{...t?{method:"PUT",body:(e=t,E(e,(t,e)=>e instanceof Map?C.fromEntries([...e]):e))}:{},mode:"cors",cache:"no-store"})).json();var e};return q(t,v,async(t,e)=>{var s;e?a.send(p+"s"+(y(s=e)?s:E(s,(t,e)=>o(e)?"":e))):await v(t())},t=>{const e=e=>d(((t,e)=>{const a=l(t);return((t,e)=>t.startsWith(e))(e,t)?[e[a],(n=e,r=a+1,s=n.slice(r,void 0),O(M(s)))]:void 0;var s,n,r})(p,e.data),([e,a])=>{"s"==e&&t(void 0,a)});return a.addEventListener(s,e),e},t=>{a.removeEventListener(s,t)},r,1,{getConnection:()=>a})};export{G as createPartyKitPersister};
@@ -1 +1 @@
1
- const a=a=>typeof a,t="",e=a(t),s="t",n=(a,t)=>a.startsWith(t),i=Promise,r=a=>void 0===a,c=(o=r,(a,t,e)=>o(a)?e?.():t(a));var o;const l=(a,t,e)=>a.slice(t,e),w=a=>a.length,y=async a=>i.all(a),g=(a,t)=>a.map(t),h=(a,...t)=>a.push(...t),f=Object,u=f.entries,p=(a=[])=>f.fromEntries(a),d=(a,t)=>g(u(a),([a,e])=>t(e,a)),S=(a,t,e)=>(((a,t)=>t in a)(a,t)||(a[t]=e()),a[t]),P=JSON.stringify,m=JSON.parse,x=a=>P(a,(a,t)=>t instanceof Map?f.fromEntries([...t]):t),D=(a,t)=>((a,t)=>a?.forEach(t))(a,(a,e)=>t(e,a)),R="/store",b=(t,s,n)=>t+s+(a(n)==e?n:x(n)),v=(a,t,e)=>{const s=w(a);return n(t,a)?[t[s],(e?m:String)(l(t,s+1))]:void 0},C="hasStore",T=p(g(["Origin","Methods","Headers"],a=>["Access-Control-Allow-"+a,"*"])),O=async(a,e=t)=>!!await a.get(e+C),V=async(a,e=t)=>{const n={},i={};return D(await a.list(),(a,t)=>c(v(e,a),([a,e])=>{if(a==s){const[a,s,i]=m("["+e+"]");S(S(n,a,p),s,p)[i]=t}else"v"==a&&(i[e]=t)})),[n,i]},E=async(a,e,s)=>a.party.broadcast(b(a.config.messagePrefix??t,"s",e),s),H=async(a,e,i,c)=>{const o=a.party.storage,l=a.config.storagePrefix??t,g={[l+C]:1},f=[],u=[];await y(d(e[0],async(t,e)=>r(t)?!i&&await a.canDelTable(e,c)&&((a,...t)=>a.unshift(...t))(u,M(l,s,e)):await a.canSetTable(e,i,c)&&await y(d(t,async(t,n)=>r(t)?!i&&await a.canDelRow(e,n,c)&&h(u,M(l,s,e,n)):await a.canSetRow(e,n,i,c)&&await y(d(t,async(t,w)=>{const y=[e,n,w],u=M(l,s,...y);r(t)?!i&&await a.canDelCell(...y,c)&&h(f,u):await a.canSetCell(...y,t,i,c,await o.get(u))&&(g[u]=t)})))))),await y(d(e[1],async(t,e)=>{const s=l+"v"+e;r(t)?!i&&await a.canDelValue(e,c)&&h(f,s):await a.canSetValue(e,t,i,c,await o.get(s))&&(g[s]=t)})),0!=w(u)&&D(await o.list(),a=>u.every(t=>!n(a,t)||h(f,a)&&0)),await o.delete(f),await o.put(g)},M=(a,t,...e)=>b(a,t,l(x(e),1,-1)),A=async(a,t,e=null)=>new Response(e,{status:t,headers:a.config.responseHeaders});class J{constructor(a){this.party=a,this.config.storePath??=R,this.config.messagePrefix??=t,this.config.storagePrefix??=t,this.config.responseHeaders??=T}config={};async onRequest(a){const{party:{storage:e},config:{storePath:s=R,storagePrefix:n}}=this;if(new URL(a.url).pathname.endsWith(s)){const s=await O(e,n),i=await a.text();return"PUT"==a.method?s?A(this,205):(await H(this,m(i),!0,a),A(this,201)):A(this,200,s?x(await V(e,n)):t)}return A(this,404)}async onMessage(a,e){const{config:{messagePrefix:s=t,storagePrefix:n}}=this;await c(v(s,a,1),async([a,t])=>{"s"==a&&await O(this.party.storage,n)&&(await H(this,t,!1,e),E(this,t,[e.id]))})}async canSetTable(a,t,e){return!0}async canDelTable(a,t){return!0}async canSetRow(a,t,e,s){return!0}async canDelRow(a,t,e){return!0}async canSetCell(a,t,e,s,n,i,r){return!0}async canDelCell(a,t,e,s){return!0}async canSetValue(a,t,e,s,n){return!0}async canDelValue(a,t){return!0}}export{J as TinyBasePartyKitServer,E as broadcastChanges,O as hasStoreInStorage,V as loadStoreFromStorage};
1
+ const a=a=>typeof a,t="",e=a(t),s="t",n=(a,t)=>a.startsWith(t),i=Promise,r=a=>(t,e,s)=>a(t)?s?.():e(t),c=a=>null==a,o=a=>void 0===a,l=r(c),w=r(o),y=(a,t,e)=>a.slice(t,e),g=a=>a.length,h=async a=>i.all(a),f=(a,t)=>a.map(t),u=(a,...t)=>a.push(...t),p=Object,d=a=>p.getPrototypeOf(a),P=p.entries,S=(a=[])=>p.fromEntries(a),m=(a,t)=>f(P(a),([a,e])=>t(e,a)),x=(a,t,e)=>(((a,t)=>t in a)(a,t)||(a[t]=e()),a[t]),D=JSON.stringify,R=JSON.parse,b=a=>D(a,(a,t)=>t instanceof Map?p.fromEntries([...t]):t),v=a=>C(R(a)),C=a=>""===a?void 0:Array.isArray(a)?f(a,C):(a=>!c(a)&&l(d(a),a=>a==p.prototype||c(d(a)),()=>!0))(a)?((a,t)=>S(m(a,(a,e)=>[e,t(a,e)])))(a,C):a,O=(a,t)=>((a,t)=>a?.forEach(t))(a,(a,e)=>t(e,a)),T="/store",A=(t,s,n)=>t+s+(a(n)==e?n:D(n,(a,t)=>o(t)?"":t)),V=(a,t,e)=>{const s=g(a);return n(t,a)?[t[s],(e?v:String)(y(t,s+1))]:void 0},E="hasStore",H=S(f(["Origin","Methods","Headers"],a=>["Access-Control-Allow-"+a,"*"])),M=async(a,e=t)=>!!await a.get(e+E),J=async(a,e=t)=>{const n={},i={};return O(await a.list(),(a,t)=>w(V(e,a),([a,e])=>{if(a==s){const[a,s,i]=R("["+e+"]");x(x(n,a,S),s,S)[i]=t}else"v"==a&&(i[e]=t)})),[n,i]},N=async(a,e,s)=>a.party.broadcast(A(a.config.messagePrefix??t,"s",e),s),U=async(a,e,i,r)=>{const c=a.party.storage,l=a.config.storagePrefix??t,w={[l+E]:1},y=[],f=[];await h(m(e[0],async(t,e)=>o(t)?!i&&await a.canDelTable(e,r)&&((a,...t)=>a.unshift(...t))(f,W(l,s,e)):await a.canSetTable(e,i,r)&&await h(m(t,async(t,n)=>o(t)?!i&&await a.canDelRow(e,n,r)&&u(f,W(l,s,e,n)):await a.canSetRow(e,n,i,r)&&await h(m(t,async(t,g)=>{const h=[e,n,g],f=W(l,s,...h);o(t)?!i&&await a.canDelCell(...h,r)&&u(y,f):await a.canSetCell(...h,t,i,r,await c.get(f))&&(w[f]=t)})))))),await h(m(e[1],async(t,e)=>{const s=l+"v"+e;o(t)?!i&&await a.canDelValue(e,r)&&u(y,s):await a.canSetValue(e,t,i,r,await c.get(s))&&(w[s]=t)})),0!=g(f)&&O(await c.list(),a=>f.every(t=>!n(a,t)||u(y,a)&&0)),await c.delete(y),await c.put(w)},W=(a,t,...e)=>A(a,t,y(b(e),1,-1)),j=async(a,t,e=null)=>new Response(e,{status:t,headers:a.config.responseHeaders});class q{constructor(a){this.party=a,this.config.storePath??=T,this.config.messagePrefix??=t,this.config.storagePrefix??=t,this.config.responseHeaders??=H}config={};async onRequest(a){const{party:{storage:e},config:{storePath:s=T,storagePrefix:n}}=this;if(new URL(a.url).pathname.endsWith(s)){const s=await M(e,n),i=await a.text();return"PUT"==a.method?s?j(this,205):(await U(this,R(i),!0,a),j(this,201)):j(this,200,s?b(await J(e,n)):t)}return j(this,404)}async onMessage(a,e){const{config:{messagePrefix:s=t,storagePrefix:n}}=this;await w(V(s,a,1),async([a,t])=>{"s"==a&&await M(this.party.storage,n)&&(await U(this,t,!1,e),N(this,t,[e.id]))})}async canSetTable(a,t,e){return!0}async canDelTable(a,t){return!0}async canSetRow(a,t,e,s){return!0}async canDelRow(a,t,e){return!0}async canSetCell(a,t,e,s,n,i,r){return!0}async canDelCell(a,t,e,s){return!0}async canSetValue(a,t,e,s,n){return!0}async canDelValue(a,t){return!0}}export{q as TinyBasePartyKitServer,N as broadcastChanges,M as hasStoreInStorage,J as loadStoreFromStorage};
@@ -1 +1 @@
1
- const a=a=>typeof a,t="",e=a(t),s="t",n=(a,t)=>a.startsWith(t),i=Promise,r=a=>void 0===a,c=(o=r,(a,t,e)=>o(a)?e?.():t(a));var o;const l=(a,t,e)=>a.slice(t,e),w=a=>a.length,y=async a=>i.all(a),g=(a,t)=>a.map(t),h=(a,...t)=>a.push(...t),f=Object,u=f.entries,p=(a=[])=>f.fromEntries(a),d=(a,t)=>g(u(a),([a,e])=>t(e,a)),S=(a,t,e)=>(((a,t)=>t in a)(a,t)||(a[t]=e()),a[t]),P=JSON.stringify,m=JSON.parse,x=a=>P(a,(a,t)=>t instanceof Map?f.fromEntries([...t]):t),D=(a,t)=>((a,t)=>a?.forEach(t))(a,(a,e)=>t(e,a)),R="/store",b=(t,s,n)=>t+s+(a(n)==e?n:x(n)),v=(a,t,e)=>{const s=w(a);return n(t,a)?[t[s],(e?m:String)(l(t,s+1))]:void 0},C="hasStore",T=p(g(["Origin","Methods","Headers"],a=>["Access-Control-Allow-"+a,"*"])),O=async(a,e=t)=>!!await a.get(e+C),V=async(a,e=t)=>{const n={},i={};return D(await a.list(),(a,t)=>c(v(e,a),([a,e])=>{if(a==s){const[a,s,i]=m("["+e+"]");S(S(n,a,p),s,p)[i]=t}else"v"==a&&(i[e]=t)})),[n,i]},E=async(a,e,s)=>a.party.broadcast(b(a.config.messagePrefix??t,"s",e),s),H=async(a,e,i,c)=>{const o=a.party.storage,l=a.config.storagePrefix??t,g={[l+C]:1},f=[],u=[];await y(d(e[0],async(t,e)=>r(t)?!i&&await a.canDelTable(e,c)&&((a,...t)=>a.unshift(...t))(u,M(l,s,e)):await a.canSetTable(e,i,c)&&await y(d(t,async(t,n)=>r(t)?!i&&await a.canDelRow(e,n,c)&&h(u,M(l,s,e,n)):await a.canSetRow(e,n,i,c)&&await y(d(t,async(t,w)=>{const y=[e,n,w],u=M(l,s,...y);r(t)?!i&&await a.canDelCell(...y,c)&&h(f,u):await a.canSetCell(...y,t,i,c,await o.get(u))&&(g[u]=t)})))))),await y(d(e[1],async(t,e)=>{const s=l+"v"+e;r(t)?!i&&await a.canDelValue(e,c)&&h(f,s):await a.canSetValue(e,t,i,c,await o.get(s))&&(g[s]=t)})),0!=w(u)&&D(await o.list(),a=>u.every(t=>!n(a,t)||h(f,a)&&0)),await o.delete(f),await o.put(g)},M=(a,t,...e)=>b(a,t,l(x(e),1,-1)),A=async(a,t,e=null)=>new Response(e,{status:t,headers:a.config.responseHeaders});class J{constructor(a){this.party=a,this.config.storePath??=R,this.config.messagePrefix??=t,this.config.storagePrefix??=t,this.config.responseHeaders??=T}config={};async onRequest(a){const{party:{storage:e},config:{storePath:s=R,storagePrefix:n}}=this;if(new URL(a.url).pathname.endsWith(s)){const s=await O(e,n),i=await a.text();return"PUT"==a.method?s?A(this,205):(await H(this,m(i),!0,a),A(this,201)):A(this,200,s?x(await V(e,n)):t)}return A(this,404)}async onMessage(a,e){const{config:{messagePrefix:s=t,storagePrefix:n}}=this;await c(v(s,a,1),async([a,t])=>{"s"==a&&await O(this.party.storage,n)&&(await H(this,t,!1,e),E(this,t,[e.id]))})}async canSetTable(a,t,e){return!0}async canDelTable(a,t){return!0}async canSetRow(a,t,e,s){return!0}async canDelRow(a,t,e){return!0}async canSetCell(a,t,e,s,n,i,r){return!0}async canDelCell(a,t,e,s){return!0}async canSetValue(a,t,e,s,n){return!0}async canDelValue(a,t){return!0}}export{J as TinyBasePartyKitServer,E as broadcastChanges,O as hasStoreInStorage,V as loadStoreFromStorage};
1
+ const a=a=>typeof a,t="",e=a(t),s="t",n=(a,t)=>a.startsWith(t),i=Promise,r=a=>(t,e,s)=>a(t)?s?.():e(t),c=a=>null==a,o=a=>void 0===a,l=r(c),w=r(o),y=(a,t,e)=>a.slice(t,e),g=a=>a.length,h=async a=>i.all(a),f=(a,t)=>a.map(t),u=(a,...t)=>a.push(...t),p=Object,d=a=>p.getPrototypeOf(a),P=p.entries,S=(a=[])=>p.fromEntries(a),m=(a,t)=>f(P(a),([a,e])=>t(e,a)),x=(a,t,e)=>(((a,t)=>t in a)(a,t)||(a[t]=e()),a[t]),D=JSON.stringify,R=JSON.parse,b=a=>D(a,(a,t)=>t instanceof Map?p.fromEntries([...t]):t),v=a=>C(R(a)),C=a=>""===a?void 0:Array.isArray(a)?f(a,C):(a=>!c(a)&&l(d(a),a=>a==p.prototype||c(d(a)),()=>!0))(a)?((a,t)=>S(m(a,(a,e)=>[e,t(a,e)])))(a,C):a,O=(a,t)=>((a,t)=>a?.forEach(t))(a,(a,e)=>t(e,a)),T="/store",A=(t,s,n)=>t+s+(a(n)==e?n:D(n,(a,t)=>o(t)?"":t)),V=(a,t,e)=>{const s=g(a);return n(t,a)?[t[s],(e?v:String)(y(t,s+1))]:void 0},E="hasStore",H=S(f(["Origin","Methods","Headers"],a=>["Access-Control-Allow-"+a,"*"])),M=async(a,e=t)=>!!await a.get(e+E),J=async(a,e=t)=>{const n={},i={};return O(await a.list(),(a,t)=>w(V(e,a),([a,e])=>{if(a==s){const[a,s,i]=R("["+e+"]");x(x(n,a,S),s,S)[i]=t}else"v"==a&&(i[e]=t)})),[n,i]},N=async(a,e,s)=>a.party.broadcast(A(a.config.messagePrefix??t,"s",e),s),U=async(a,e,i,r)=>{const c=a.party.storage,l=a.config.storagePrefix??t,w={[l+E]:1},y=[],f=[];await h(m(e[0],async(t,e)=>o(t)?!i&&await a.canDelTable(e,r)&&((a,...t)=>a.unshift(...t))(f,W(l,s,e)):await a.canSetTable(e,i,r)&&await h(m(t,async(t,n)=>o(t)?!i&&await a.canDelRow(e,n,r)&&u(f,W(l,s,e,n)):await a.canSetRow(e,n,i,r)&&await h(m(t,async(t,g)=>{const h=[e,n,g],f=W(l,s,...h);o(t)?!i&&await a.canDelCell(...h,r)&&u(y,f):await a.canSetCell(...h,t,i,r,await c.get(f))&&(w[f]=t)})))))),await h(m(e[1],async(t,e)=>{const s=l+"v"+e;o(t)?!i&&await a.canDelValue(e,r)&&u(y,s):await a.canSetValue(e,t,i,r,await c.get(s))&&(w[s]=t)})),0!=g(f)&&O(await c.list(),a=>f.every(t=>!n(a,t)||u(y,a)&&0)),await c.delete(y),await c.put(w)},W=(a,t,...e)=>A(a,t,y(b(e),1,-1)),j=async(a,t,e=null)=>new Response(e,{status:t,headers:a.config.responseHeaders});class q{constructor(a){this.party=a,this.config.storePath??=T,this.config.messagePrefix??=t,this.config.storagePrefix??=t,this.config.responseHeaders??=H}config={};async onRequest(a){const{party:{storage:e},config:{storePath:s=T,storagePrefix:n}}=this;if(new URL(a.url).pathname.endsWith(s)){const s=await M(e,n),i=await a.text();return"PUT"==a.method?s?j(this,205):(await U(this,R(i),!0,a),j(this,201)):j(this,200,s?b(await J(e,n)):t)}return j(this,404)}async onMessage(a,e){const{config:{messagePrefix:s=t,storagePrefix:n}}=this;await w(V(s,a,1),async([a,t])=>{"s"==a&&await M(this.party.storage,n)&&(await U(this,t,!1,e),N(this,t,[e.id]))})}async canSetTable(a,t,e){return!0}async canDelTable(a,t){return!0}async canSetRow(a,t,e,s){return!0}async canDelRow(a,t,e){return!0}async canSetCell(a,t,e,s,n,i,r){return!0}async canDelCell(a,t,e,s){return!0}async canSetValue(a,t,e,s,n){return!0}async canDelValue(a,t){return!0}}export{q as TinyBasePartyKitServer,N as broadcastChanges,M as hasStoreInStorage,J as loadStoreFromStorage};
@@ -1 +1 @@
1
- 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=a=>(t,e,n)=>a(t)?n?.():e(t),l=globalThis,w=a=>null==a,y=a=>void 0===a,d=a=>null===a,u=c(w),E=c(y),N=t=>a(t)==s,g=a=>Array.isArray(a),A=(a,t,e)=>a.slice(t,e),T=a=>a.length,$=()=>{},p=async a=>r.all(a),O=a=>{throw Error(a)},R=async(a,t,e)=>{try{return await a()}catch(a){t?.(a)}},m=(a,t)=>a.forEach(t),v=(a,t="")=>a.join(t),C=(a,t)=>a.map(t),I=a=>0==T(a),L=(a,t)=>a.filter(t),S=(a,...t)=>a.push(...t),_=a=>a.shift(),b=(a,t)=>a?.has(t)??!1,f=a=>y(a)||0==(a=>a?.size??0)(a),D=a=>[...a?.values()??[]],P=(a,t)=>a?.forEach(t),h=(a,t)=>a?.delete(t),F=Object,M=a=>F.getPrototypeOf(a),U=F.entries,G=F.keys,j=F.freeze,x=(a=[])=>F.fromEntries(a),W=(...a)=>F.assign({},...a),B=(a,t)=>(delete a[t],a),H=(a,t)=>C(U(a),([a,e])=>t(e,a)),X=(a,t)=>x(H(a,(a,e)=>[e,t(a,e)])),Y=a=>F.values(a),k=a=>T(G(a)),q=a=>(a=>!w(a)&&u(M(a),a=>a==F.prototype||w(M(a)),()=>!0))(a)&&0==k(a),z=JSON.stringify,J=JSON.parse,K=a=>z(a,(a,t)=>y(t)?"":t),V=new l.TextEncoder,Q=a=>new Map(a),Z=(a,t)=>a?.get(t),aa=(a,t)=>C([...a?.entries()??[]],([a,e])=>t(e,a)),ta=(a,t,e)=>y(e)?(h(a,t),a):a?.set(t,e),ea=(a,t,e,n)=>(b(a,t)?n?.(Z(a,t)):ta(a,t,e()),Z(a,t)),na=(a,t,e,n,s=0)=>E((e?ea:Z)(a,t[s],s>T(t)-2?e:Q),i=>{if(s>T(t)-2)return n?.(i)&&ta(a,t[s]),i;const o=na(i,t,e,n,s+1);return f(i)&&ta(a,t[s]),o}),sa="_",ia="_id",oa="SELECT",ra="WHERE",ca="TABLE",la="INSERT",wa="DELETE",ya="UPDATE",da="ALTER "+ca,ua="FROM",Ea=wa+" "+ua,Na=oa+"*"+ua,ga="CREATE ",Aa=ga+ca,Ta="OR REPLACE ",$a="FUNCTION",pa="$tableName",Oa=a=>v(C(((a,t="",e)=>a.split(t,e))(a,"."),a=>`"${o(a,/"/g,'""')}"`),"."),Ra=(...a)=>Oa(v(a,"_")),ma=(a,t=[1])=>v(C(a,()=>"$"+t[0]++),n),va=(a,t=i)=>ra+`(${o(t,pa,Oa(a))})`,Ca=a=>new Set(g(a)||y(a)?a:[a]),Ia=(a,t)=>a?.add(t),La="ColumnName",Sa="store",_a="json",ba=Sa+"TableName",fa=Sa+"Id"+La,Da=Sa+La,Pa="autoLoadIntervalSeconds",ha="rowId"+La,Fa="tableId",Ma="tableName",Ua="deleteEmptyColumns",Ga="deleteEmptyTable",ja="condition",xa={mode:_a,[Pa]:1},Wa={load:0,save:0,[Ma]:t+"_values"},Ba=(a,t,e,n,s)=>{const i=Q();return X(a,(a,o)=>{const r=A(Y(W(t,N(a)?{[e]:a}:a)),0,k(t));d(r[0])||n(o,r[0])||(s(o,r[0]),ta(i,o,r))}),i},Ha=/^\d+$/,Xa=Q(),Ya=Q(),ka=(a,t,n,s,i,o,r,c={},l=0,w=[])=>{let u,N,A,$=0,p=0,v=0;ea(Xa,w,()=>0),ea(Ya,w,()=>[]);const C=Q(),[I,L,b,D,F]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!q(a)||!q(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!q(a)||!q(t),t.setContent]:O("Store type not supported by this Persister"))(r,a,l),[M,U,G]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?_(a):null)??e+t++,t=>{Ha.test(t)&&T(a)<1e3&&S(a,t)}]})(),s=Q();return[(n,i,o,r=[],c=()=>[])=>{a??=V;const l=t(1);return ta(s,l,[n,i,o,r,c]),Ia(na(i,o??[e],Ca),l),l},(t,n,...i)=>m(((a,t=[e])=>{const n=[],s=(a,e)=>e==T(t)?S(n,a):d(t[e])?P(a,a=>s(a,e+1)):m([t[e],null],t=>s(Z(a,t),e+1));return s(a,0),n})(t,n),t=>P(t,t=>Z(s,t)[0](a,...n??[],...i))),a=>E(Z(s,a),([,t,i])=>(na(t,i??[e],void 0,t=>(h(t,a),f(t)?1:0)),ta(s,a),n(a),i)),t=>E(Z(s,t),([t,,e=[],n,s])=>{const i=(...o)=>{const r=T(o);r==T(e)?t(a,...o,...s(o)):d(e[r])?m(n[r]?.(...o)??[],a=>i(...o,a)):i(...o,e[r])};i()})]})(),x=a=>{a!=$&&($=a,U(C,void 0,$))},W=t=>{(I&&g(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},B=async a=>(2!=$&&(x(1),p++,await K(async()=>{await R(async()=>{const e=await t();g(e)?W(e):a?F(a):O("Content is not an array: "+e)},()=>{a&&F(a)}),x(0)})),V),H=async a=>(X(),await B(a),await R(async()=>N=await s(async(a,t)=>{t||a?2!=$&&(x(1),p++,W(t??a),x(0)):await B()}),o),V),X=async()=>(N&&(await R(()=>i(N),o),N=void 0),V),Y=async a=>(1!=$&&(x(2),v++,await K(async()=>{await R(()=>n(L,a),o),x(0)})),V),k=async()=>(z(),await Y(),A=a.addDidFinishTransactionListener(()=>{const a=b();D(a)&&Y(a)}),V),z=async()=>(A&&(a.delListener(A),A=void 0),V),J=async(a=!1)=>{const[t,e]=a?[z,X]:[X,z];return await t(),await e(),V},K=async(...a)=>(S(Z(Ya,w),...a),await(async()=>{if(!Z(Xa,w)){for(ta(Xa,w,1);!y(u=_(Z(Ya,w)));)await R(u,o);ta(Xa,w,0)}})(),V),V={load:B,startAutoLoad:H,stopAutoLoad:X,isAutoLoading:()=>!y(N),save:Y,startAutoSave:k,stopAutoSave:z,isAutoSaving:()=>!y(A),startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[k,H]:[H,k];return await e(a),await n(a),V},stopAutoPersisting:J,getStatus:()=>$,addStatusListener:a=>M(a,C),delListener:t=>(G(t),a),schedule:K,getStore:()=>a,destroy:()=>(Z(Ya,w).splice(0,void 0),J()),getStats:()=>({loads:p,saves:v}),...c};return j(V)},qa=(a,t,e,s,o,r=za,c,l)=>{const w=Q();return[async()=>{w.clear(),C(await e(a,t),({tn:a,cn:t})=>Ia(ea(w,a,Ca),t))},async(t,e,n)=>((a,t)=>b(Z(w,a),t))(t,e)?x(L(C(await a(Na+Oa(t)+va(t,n)),a=>[a[e],l?X(B(a,e),l):B(a,e)]),([a,t])=>!y(a)&&!q(t))):{},async(t,e,s,l,d,u=!1,E=i)=>{const N=Ca();X(s??{},a=>C(G(a??{}),a=>Ia(N,a)));const g=D(N);if(!u&&d&&E==i&&I(g)&&b(w,t))return await a("DROP "+ca+Oa(t)),void ta(w,t);const A=Z(w,t),T=Ca(D(A));if(I(g)||(b(w,t)?await p(C([e,...g],async(n,s)=>{h(T,n)||(await a(da+Oa(t)+"ADD"+Oa(n)+o),0==s&&await a("CREATE UNIQUE INDEX pk ON "+Oa(t)+`(${Oa(e)})`),Ia(A,n))})):(await a(Aa+Oa(t)+`(${Oa(e)}${o} PRIMARY KEY${v(C(g,a=>n+Oa(a)+o))});`),ta(w,t,Ca([e,...g])))),await p([...!u&&l?C(D(T),async n=>{n!=e&&(await a(da+Oa(t)+"DROP"+Oa(n)),h(A,n))}):[]]),u)y(s)?await a(Ea+Oa(t)+va(t,E)):await p(H(s,async(n,s)=>{y(n)?await a(Ea+Oa(t)+va(t,E)+`AND(${Oa(e)}=$1)`,[s]):I(g)||await r(a,t,e,G(n),{[s]:c?C(Y(n),c):Y(n)},A)}));else if(I(g))b(w,t)&&await a(Ea+Oa(t)+va(t,E));else{const n=L(D(Z(w,t)),a=>a!=e),i={},o=[];X(s??{},(a,t)=>{i[t]=C(n,t=>c?c(a?.[t]):a?.[t]),S(o,t)}),await r(a,t,e,n,i),await a(Ea+Oa(t)+va(t,E)+`AND${Oa(e)}NOT IN(${ma(o)})`,o)}},async t=>{let e;return await a("BEGIN"),await R(async()=>e=await t(),s),await a("END"),e}]},za=async(a,t,e,s,i)=>{const o=[1];await a(la+" INTO"+Oa(t)+"("+((...a)=>v(C(a,Oa),n))(e,...s)+")VALUES"+v(H(i,a=>"($"+o[0]+++","+ma(a,o)+")"),n)+"ON CONFLICT("+Oa(e)+`)DO ${ya} SET`+v(C(s,a=>Oa(a)+"=excluded."+Oa(a)),n),H(i,(a,t)=>[t,...C(a,a=>a??null)]).flat())},Ja=(a,t,e,n,s,i,o,[r,c,l],w,y,d,u,E,N)=>{const[g,A,T,$]=qa(t,w,y,s,E,N),p=ka(a,()=>$(async()=>{return await g(),a=(await A(r,c))[sa]?.[l]??"null",J(a,(a,t)=>""===t?void 0:t);var a}),a=>$(async()=>{await g(),await T(r,c,{[sa]:{[l]:K(a()??null)}},!0,!0)}),e,n,s,o,{[u]:()=>d,destroy:async()=>(await p.stopAutoPersisting(),i(),p)},0,d);return p},Ka=(a,t,e,n,s,i,o,[r,c,[l,w,d]],u,E,N,g,A,T,$,O)=>{const[R,m,v,C]=qa(t,u,E,s,A,T,$,O),I=(a,t)=>p(aa(c,async([e,n,s,i,o],r)=>{t&&!(r in a)||await v(e,n,a[r],s,i,t,o)})),S=async(a,t)=>w?await v(d,ia,{[sa]:a},!0,!0,t):null,_=ka(a,()=>C(async()=>{await R();const a=await(async()=>x(L(await p(aa(r,async([a,t,e],n)=>[a,await m(n,t,e)])),a=>!q(a[1]))))(),t=await(async()=>l?(await m(d,ia))[sa]:{})();return q(a)&&y(t)?void 0:[a,t]}),(a,t)=>C(async()=>{if(await R(),y(t)){const[t,e]=a();await I(t),await S(e)}else await I(t[0],!0),await S(t[1],!0)}),e,n,s,o,{[g]:()=>N,destroy:async()=>(await _.stopAutoPersisting(),i(),_)},0,N);return _},Va=/^([cd]:)(.+)/,Qa=(a,n,s,r,c,l,w,y,d,u,g="getDb")=>{const T=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,l),[$,,O,R]=(a=>{const e=(a=>W(xa,N(a)?{[ba]:a}:a??{}))(a),n=e[Pa];if(e.mode==_a){const a=e[ba]??t;return[1,n,[a,e[fa]??ia,e[Da]??Sa],Ca(a)]}const{tables:{load:s={},save:o={}}={},values:r={}}=e,c=A(Y(W(Wa,r)),0,k(Wa)),l=c[2],w=Ca(l),y=Ca(l),d=Ba(s,{[Fa]:null,[ha]:ia,[ja]:i},Fa,a=>b(y,a),a=>Ia(w,a)),u=Ba(o,{[Ma]:null,[ha]:ia,[Ua]:0,[Ga]:0,[ja]:null},Ma,(a,t)=>b(y,t),(a,t)=>Ia(w,t));var E;return E=(a,t)=>t[4]??=Z(d,t[0])?.[2]??i,P(u,(a,t)=>E(0,a)),[0,n,[d,u,c],w]})(n),I=e+(a=>{let t=2166136261;return m(V.encode(a),a=>{t^=a,t+=(t<<1)+(t<<4)+(t<<7)+(t<<8)+(t<<24)}),t>>>0})(K(O)),L=t+"_"+I,S=async(a,e,n="",s="")=>{const i=Ra(t,a,I);return await T(ga+Ta+$a+i+`()RETURNS ${n}trigger AS $$ ${s}BEGIN ${e}END;$$ LANGUAGE plpgsql;`),i},_=async(a,t,e,n)=>(await T(ga+a+"TRIGGER"+t+e+"EXECUTE "+$a+n+"()"),t),f=a=>`PERFORM pg_notify('${L}',${a});`,h=(a,t)=>$?i:2===t?h(a,0)+" OR "+h(a,1):o(Z(O[0],a)?.[2]??i,pa,0==t?"NEW":"OLD"),F=(a,e)=>p(C([la,wa,ya],(n,s)=>_(Ta,Ra(t,"d",I,a,n),`AFTER ${n} ON${Oa(a)}FOR EACH ROW WHEN(${h(a,s)})`,e)));return($?Ja:Ka)(a,T,async a=>{const e=await S("c",`FOR row IN SELECT object_identity FROM pg_event_trigger_ddl_commands()${ra} command_tag='${Aa}' LOOP ${f("'c:'||SPLIT_PART(row.object_identity,'.',2)")}END LOOP;`,"event_","DECLARE row record;");await _("EVENT ",Ra(t,"c",I),`ON ddl_command_end WHEN TAG IN('${Aa}')`,e);const n=await S("d",f("'d:'||TG_TABLE_NAME")+"RETURN NULL;");return await p(C(D(R),async a=>(await T(Aa+` IF NOT EXISTS${Oa(a)}("_id"text PRIMARY KEY)`),await F(a,n)))),[await r(L,t=>{return E((e=t,s=Va,e?.match(s)),async([,t,e])=>{b(R,e)&&("c:"==t&&await F(e,n),a())});var e,s}),[e,n]]},async([a,t])=>{c(a),await T(`DROP FUNCTION IF EXISTS${v(t,",")}CASCADE`)},w,y,d,O,D(R),async(a,t)=>await a(oa+` table_name tn,column_name cn FROM information_schema.columns ${ra} table_schema='public'AND table_name IN(${ma(t)})`,t),u,g,"text",void 0,a=>z(a),a=>J(a))},Za=async(a,t,e,n,s)=>Qa(a,e,async(a,e=[])=>(await t.query(a,e)).rows,(a,e)=>t.listen(a,e),a=>R(a,s),n,s,$,3,t,"getPglite");export{Za as createPglitePersister};
1
+ 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=a=>(t,e,n)=>a(t)?n?.():e(t),l=globalThis,w=a=>null==a,y=a=>void 0===a,d=a=>null===a,u=c(w),E=c(y),N=t=>a(t)==s,g=a=>Array.isArray(a),A=(a,t,e)=>a.slice(t,e),T=a=>a.length,$=()=>{},p=async a=>r.all(a),O=a=>{throw Error(a)},R=async(a,t,e)=>{try{return await a()}catch(a){t?.(a)}},m=(a,t)=>a.forEach(t),v=(a,t="")=>a.join(t),C=(a,t)=>a.map(t),I=a=>0==T(a),L=(a,t)=>a.filter(t),S=(a,...t)=>a.push(...t),_=a=>a.shift(),b=(a,t)=>a?.has(t)??!1,f=a=>y(a)||0==(a=>a?.size??0)(a),D=a=>[...a?.values()??[]],P=(a,t)=>a?.forEach(t),h=(a,t)=>a?.delete(t),F=Object,M=a=>F.getPrototypeOf(a),U=F.entries,G=a=>!w(a)&&u(M(a),a=>a==F.prototype||w(M(a)),()=>!0),j=F.keys,x=F.freeze,W=(a=[])=>F.fromEntries(a),B=(...a)=>F.assign({},...a),H=(a,t)=>(delete a[t],a),X=(a,t)=>C(U(a),([a,e])=>t(e,a)),Y=(a,t)=>W(X(a,(a,e)=>[e,t(a,e)])),k=a=>F.values(a),q=a=>T(j(a)),z=a=>G(a)&&0==q(a),J=JSON.stringify,K=JSON.parse,V=a=>J(a,(a,t)=>y(t)?"":t),Q=a=>""===a?void 0:g(a)?C(a,Q):G(a)?Y(a,Q):a,Z=new l.TextEncoder,aa=a=>new Map(a),ta=(a,t)=>a?.get(t),ea=(a,t)=>C([...a?.entries()??[]],([a,e])=>t(e,a)),na=(a,t,e)=>y(e)?(h(a,t),a):a?.set(t,e),sa=(a,t,e,n)=>(b(a,t)?n?.(ta(a,t)):na(a,t,e()),ta(a,t)),ia=(a,t,e,n,s=0)=>E((e?sa:ta)(a,t[s],s>T(t)-2?e:aa),i=>{if(s>T(t)-2)return n?.(i)&&na(a,t[s]),i;const o=ia(i,t,e,n,s+1);return f(i)&&na(a,t[s]),o}),oa="_",ra="_id",ca="SELECT",la="WHERE",wa="TABLE",ya="INSERT",da="DELETE",ua="UPDATE",Ea="ALTER "+wa,Na="FROM",ga=da+" "+Na,Aa=ca+"*"+Na,Ta="CREATE ",$a=Ta+wa,pa="OR REPLACE ",Oa="FUNCTION",Ra="$tableName",ma=a=>v(C(((a,t="",e)=>a.split(t,e))(a,"."),a=>`"${o(a,/"/g,'""')}"`),"."),va=(...a)=>ma(v(a,"_")),Ca=(a,t=[1])=>v(C(a,()=>"$"+t[0]++),n),Ia=(a,t=i)=>la+`(${o(t,Ra,ma(a))})`,La=a=>new Set(g(a)||y(a)?a:[a]),Sa=(a,t)=>a?.add(t),_a="ColumnName",ba="store",fa="json",Da=ba+"TableName",Pa=ba+"Id"+_a,ha=ba+_a,Fa="autoLoadIntervalSeconds",Ma="rowId"+_a,Ua="tableId",Ga="tableName",ja="deleteEmptyColumns",xa="deleteEmptyTable",Wa="condition",Ba={mode:fa,[Fa]:1},Ha={load:0,save:0,[Ga]:t+"_values"},Xa=(a,t,e,n,s)=>{const i=aa();return Y(a,(a,o)=>{const r=A(k(B(t,N(a)?{[e]:a}:a)),0,q(t));d(r[0])||n(o,r[0])||(s(o,r[0]),na(i,o,r))}),i},Ya=/^\d+$/,ka=aa(),qa=aa(),za=(a,t,n,s,i,o,r,c={},l=0,w=[])=>{let u,N,A,$=0,p=0,v=0;sa(ka,w,()=>0),sa(qa,w,()=>[]);const C=aa(),[I,L,b,D,F]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!z(a)||!z(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!z(a)||!z(t),t.setContent]:O("Store type not supported by this Persister"))(r,a,l),[M,U,G]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?_(a):null)??e+t++,t=>{Ya.test(t)&&T(a)<1e3&&S(a,t)}]})(),s=aa();return[(n,i,o,r=[],c=()=>[])=>{a??=V;const l=t(1);return na(s,l,[n,i,o,r,c]),Sa(ia(i,o??[e],La),l),l},(t,n,...i)=>m(((a,t=[e])=>{const n=[],s=(a,e)=>e==T(t)?S(n,a):d(t[e])?P(a,a=>s(a,e+1)):m([t[e],null],t=>s(ta(a,t),e+1));return s(a,0),n})(t,n),t=>P(t,t=>ta(s,t)[0](a,...n??[],...i))),a=>E(ta(s,a),([,t,i])=>(ia(t,i??[e],void 0,t=>(h(t,a),f(t)?1:0)),na(s,a),n(a),i)),t=>E(ta(s,t),([t,,e=[],n,s])=>{const i=(...o)=>{const r=T(o);r==T(e)?t(a,...o,...s(o)):d(e[r])?m(n[r]?.(...o)??[],a=>i(...o,a)):i(...o,e[r])};i()})]})(),j=a=>{a!=$&&($=a,U(C,void 0,$))},W=t=>{(I&&g(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},B=async a=>(2!=$&&(j(1),p++,await K(async()=>{await R(async()=>{const e=await t();g(e)?W(e):a?F(a):O("Content is not an array: "+e)},()=>{a&&F(a)}),j(0)})),V),H=async a=>(X(),await B(a),await R(async()=>N=await s(async(a,t)=>{t||a?2!=$&&(j(1),p++,W(t??a),j(0)):await B()}),o),V),X=async()=>(N&&(await R(()=>i(N),o),N=void 0),V),Y=async a=>(1!=$&&(j(2),v++,await K(async()=>{await R(()=>n(L,a),o),j(0)})),V),k=async()=>(q(),await Y(),A=a.addDidFinishTransactionListener(()=>{const a=b();D(a)&&Y(a)}),V),q=async()=>(A&&(a.delListener(A),A=void 0),V),J=async(a=!1)=>{const[t,e]=a?[q,X]:[X,q];return await t(),await e(),V},K=async(...a)=>(S(ta(qa,w),...a),await(async()=>{if(!ta(ka,w)){for(na(ka,w,1);!y(u=_(ta(qa,w)));)await R(u,o);na(ka,w,0)}})(),V),V={load:B,startAutoLoad:H,stopAutoLoad:X,isAutoLoading:()=>!y(N),save:Y,startAutoSave:k,stopAutoSave:q,isAutoSaving:()=>!y(A),startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[k,H]:[H,k];return await e(a),await n(a),V},stopAutoPersisting:J,getStatus:()=>$,addStatusListener:a=>M(a,C),delListener:t=>(G(t),a),schedule:K,getStore:()=>a,destroy:()=>(ta(qa,w).splice(0,void 0),J()),getStats:()=>({loads:p,saves:v}),...c};return x(V)},Ja=(a,t,e,s,o,r=Ka,c,l)=>{const w=aa();return[async()=>{w.clear(),C(await e(a,t),({tn:a,cn:t})=>Sa(sa(w,a,La),t))},async(t,e,n)=>((a,t)=>b(ta(w,a),t))(t,e)?W(L(C(await a(Aa+ma(t)+Ia(t,n)),a=>[a[e],l?Y(H(a,e),l):H(a,e)]),([a,t])=>!y(a)&&!z(t))):{},async(t,e,s,l,d,u=!1,E=i)=>{const N=La();Y(s??{},a=>C(j(a??{}),a=>Sa(N,a)));const g=D(N);if(!u&&d&&E==i&&I(g)&&b(w,t))return await a("DROP "+wa+ma(t)),void na(w,t);const A=ta(w,t),T=La(D(A));if(I(g)||(b(w,t)?await p(C([e,...g],async(n,s)=>{h(T,n)||(await a(Ea+ma(t)+"ADD"+ma(n)+o),0==s&&await a("CREATE UNIQUE INDEX pk ON "+ma(t)+`(${ma(e)})`),Sa(A,n))})):(await a($a+ma(t)+`(${ma(e)}${o} PRIMARY KEY${v(C(g,a=>n+ma(a)+o))});`),na(w,t,La([e,...g])))),await p([...!u&&l?C(D(T),async n=>{n!=e&&(await a(Ea+ma(t)+"DROP"+ma(n)),h(A,n))}):[]]),u)y(s)?await a(ga+ma(t)+Ia(t,E)):await p(X(s,async(n,s)=>{y(n)?await a(ga+ma(t)+Ia(t,E)+`AND(${ma(e)}=$1)`,[s]):I(g)||await r(a,t,e,j(n),{[s]:c?C(k(n),c):k(n)},A)}));else if(I(g))b(w,t)&&await a(ga+ma(t)+Ia(t,E));else{const n=L(D(ta(w,t)),a=>a!=e),i={},o=[];Y(s??{},(a,t)=>{i[t]=C(n,t=>c?c(a?.[t]):a?.[t]),S(o,t)}),await r(a,t,e,n,i),await a(ga+ma(t)+Ia(t,E)+`AND${ma(e)}NOT IN(${Ca(o)})`,o)}},async t=>{let e;return await a("BEGIN"),await R(async()=>e=await t(),s),await a("END"),e}]},Ka=async(a,t,e,s,i)=>{const o=[1];await a(ya+" INTO"+ma(t)+"("+((...a)=>v(C(a,ma),n))(e,...s)+")VALUES"+v(X(i,a=>"($"+o[0]+++","+Ca(a,o)+")"),n)+"ON CONFLICT("+ma(e)+`)DO ${ua} SET`+v(C(s,a=>ma(a)+"=excluded."+ma(a)),n),X(i,(a,t)=>[t,...C(a,a=>a??null)]).flat())},Va=(a,t,e,n,s,i,o,[r,c,l],w,y,d,u,E,N)=>{const[g,A,T,$]=Ja(t,w,y,s,E,N),p=za(a,()=>$(async()=>{return await g(),a=(await A(r,c))[oa]?.[l]??"null",Q(K(a));var a}),a=>$(async()=>{await g(),await T(r,c,{[oa]:{[l]:V(a()??null)}},!0,!0)}),e,n,s,o,{[u]:()=>d,destroy:async()=>(await p.stopAutoPersisting(),i(),p)},0,d);return p},Qa=(a,t,e,n,s,i,o,[r,c,[l,w,d]],u,E,N,g,A,T,$,O)=>{const[R,m,v,C]=Ja(t,u,E,s,A,T,$,O),I=(a,t)=>p(ea(c,async([e,n,s,i,o],r)=>{t&&!(r in a)||await v(e,n,a[r],s,i,t,o)})),S=async(a,t)=>w?await v(d,ra,{[oa]:a},!0,!0,t):null,_=za(a,()=>C(async()=>{await R();const a=await(async()=>W(L(await p(ea(r,async([a,t,e],n)=>[a,await m(n,t,e)])),a=>!z(a[1]))))(),t=await(async()=>l?(await m(d,ra))[oa]:{})();return z(a)&&y(t)?void 0:[a,t]}),(a,t)=>C(async()=>{if(await R(),y(t)){const[t,e]=a();await I(t),await S(e)}else await I(t[0],!0),await S(t[1],!0)}),e,n,s,o,{[g]:()=>N,destroy:async()=>(await _.stopAutoPersisting(),i(),_)},0,N);return _},Za=/^([cd]:)(.+)/,at=(a,n,s,r,c,l,w,y,d,u,g="getDb")=>{const T=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,l),[$,,O,R]=(a=>{const e=(a=>B(Ba,N(a)?{[Da]:a}:a??{}))(a),n=e[Fa];if(e.mode==fa){const a=e[Da]??t;return[1,n,[a,e[Pa]??ra,e[ha]??ba],La(a)]}const{tables:{load:s={},save:o={}}={},values:r={}}=e,c=A(k(B(Ha,r)),0,q(Ha)),l=c[2],w=La(l),y=La(l),d=Xa(s,{[Ua]:null,[Ma]:ra,[Wa]:i},Ua,a=>b(y,a),a=>Sa(w,a)),u=Xa(o,{[Ga]:null,[Ma]:ra,[ja]:0,[xa]:0,[Wa]:null},Ga,(a,t)=>b(y,t),(a,t)=>Sa(w,t));var E;return E=(a,t)=>t[4]??=ta(d,t[0])?.[2]??i,P(u,(a,t)=>E(0,a)),[0,n,[d,u,c],w]})(n),I=e+(a=>{let t=2166136261;return m(Z.encode(a),a=>{t^=a,t+=(t<<1)+(t<<4)+(t<<7)+(t<<8)+(t<<24)}),t>>>0})(V(O)),L=t+"_"+I,S=async(a,e,n="",s="")=>{const i=va(t,a,I);return await T(Ta+pa+Oa+i+`()RETURNS ${n}trigger AS $$ ${s}BEGIN ${e}END;$$ LANGUAGE plpgsql;`),i},_=async(a,t,e,n)=>(await T(Ta+a+"TRIGGER"+t+e+"EXECUTE "+Oa+n+"()"),t),f=a=>`PERFORM pg_notify('${L}',${a});`,h=(a,t)=>$?i:2===t?h(a,0)+" OR "+h(a,1):o(ta(O[0],a)?.[2]??i,Ra,0==t?"NEW":"OLD"),F=(a,e)=>p(C([ya,da,ua],(n,s)=>_(pa,va(t,"d",I,a,n),`AFTER ${n} ON${ma(a)}FOR EACH ROW WHEN(${h(a,s)})`,e)));return($?Va:Qa)(a,T,async a=>{const e=await S("c",`FOR row IN SELECT object_identity FROM pg_event_trigger_ddl_commands()${la} command_tag='${$a}' LOOP ${f("'c:'||SPLIT_PART(row.object_identity,'.',2)")}END LOOP;`,"event_","DECLARE row record;");await _("EVENT ",va(t,"c",I),`ON ddl_command_end WHEN TAG IN('${$a}')`,e);const n=await S("d",f("'d:'||TG_TABLE_NAME")+"RETURN NULL;");return await p(C(D(R),async a=>(await T($a+` IF NOT EXISTS${ma(a)}("_id"text PRIMARY KEY)`),await F(a,n)))),[await r(L,t=>{return E((e=t,s=Za,e?.match(s)),async([,t,e])=>{b(R,e)&&("c:"==t&&await F(e,n),a())});var e,s}),[e,n]]},async([a,t])=>{c(a),await T(`DROP FUNCTION IF EXISTS${v(t,",")}CASCADE`)},w,y,d,O,D(R),async(a,t)=>await a(ca+` table_name tn,column_name cn FROM information_schema.columns ${la} table_schema='public'AND table_name IN(${Ca(t)})`,t),u,g,"text",void 0,a=>J(a),a=>K(a))},tt=async(a,t,e,n,s)=>at(a,e,async(a,e=[])=>(await t.query(a,e)).rows,(a,e)=>t.listen(a,e),a=>R(a,s),n,s,$,3,t,"getPglite");export{tt as createPglitePersister};
@@ -1 +1 @@
1
- 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=a=>(t,e,n)=>a(t)?n?.():e(t),l=globalThis,w=a=>null==a,y=a=>void 0===a,d=a=>null===a,u=c(w),E=c(y),N=t=>a(t)==s,g=a=>Array.isArray(a),A=(a,t,e)=>a.slice(t,e),T=a=>a.length,$=()=>{},p=async a=>r.all(a),O=a=>{throw Error(a)},R=async(a,t,e)=>{try{return await a()}catch(a){t?.(a)}},m=(a,t)=>a.forEach(t),v=(a,t="")=>a.join(t),C=(a,t)=>a.map(t),I=a=>0==T(a),L=(a,t)=>a.filter(t),S=(a,...t)=>a.push(...t),_=a=>a.shift(),b=(a,t)=>a?.has(t)??!1,f=a=>y(a)||0==(a=>a?.size??0)(a),D=a=>[...a?.values()??[]],P=(a,t)=>a?.forEach(t),h=(a,t)=>a?.delete(t),F=Object,M=a=>F.getPrototypeOf(a),U=F.entries,G=F.keys,j=F.freeze,x=(a=[])=>F.fromEntries(a),W=(...a)=>F.assign({},...a),B=(a,t)=>(delete a[t],a),H=(a,t)=>C(U(a),([a,e])=>t(e,a)),X=(a,t)=>x(H(a,(a,e)=>[e,t(a,e)])),Y=a=>F.values(a),k=a=>T(G(a)),q=a=>(a=>!w(a)&&u(M(a),a=>a==F.prototype||w(M(a)),()=>!0))(a)&&0==k(a),z=JSON.stringify,J=JSON.parse,K=a=>z(a,(a,t)=>y(t)?"":t),V=new l.TextEncoder,Q=a=>new Map(a),Z=(a,t)=>a?.get(t),aa=(a,t)=>C([...a?.entries()??[]],([a,e])=>t(e,a)),ta=(a,t,e)=>y(e)?(h(a,t),a):a?.set(t,e),ea=(a,t,e,n)=>(b(a,t)?n?.(Z(a,t)):ta(a,t,e()),Z(a,t)),na=(a,t,e,n,s=0)=>E((e?ea:Z)(a,t[s],s>T(t)-2?e:Q),i=>{if(s>T(t)-2)return n?.(i)&&ta(a,t[s]),i;const o=na(i,t,e,n,s+1);return f(i)&&ta(a,t[s]),o}),sa="_",ia="_id",oa="SELECT",ra="WHERE",ca="TABLE",la="INSERT",wa="DELETE",ya="UPDATE",da="ALTER "+ca,ua="FROM",Ea=wa+" "+ua,Na=oa+"*"+ua,ga="CREATE ",Aa=ga+ca,Ta="OR REPLACE ",$a="FUNCTION",pa="$tableName",Oa=a=>v(C(((a,t="",e)=>a.split(t,e))(a,"."),a=>`"${o(a,/"/g,'""')}"`),"."),Ra=(...a)=>Oa(v(a,"_")),ma=(a,t=[1])=>v(C(a,()=>"$"+t[0]++),n),va=(a,t=i)=>ra+`(${o(t,pa,Oa(a))})`,Ca=a=>new Set(g(a)||y(a)?a:[a]),Ia=(a,t)=>a?.add(t),La="ColumnName",Sa="store",_a="json",ba=Sa+"TableName",fa=Sa+"Id"+La,Da=Sa+La,Pa="autoLoadIntervalSeconds",ha="rowId"+La,Fa="tableId",Ma="tableName",Ua="deleteEmptyColumns",Ga="deleteEmptyTable",ja="condition",xa={mode:_a,[Pa]:1},Wa={load:0,save:0,[Ma]:t+"_values"},Ba=(a,t,e,n,s)=>{const i=Q();return X(a,(a,o)=>{const r=A(Y(W(t,N(a)?{[e]:a}:a)),0,k(t));d(r[0])||n(o,r[0])||(s(o,r[0]),ta(i,o,r))}),i},Ha=/^\d+$/,Xa=Q(),Ya=Q(),ka=(a,t,n,s,i,o,r,c={},l=0,w=[])=>{let u,N,A,$=0,p=0,v=0;ea(Xa,w,()=>0),ea(Ya,w,()=>[]);const C=Q(),[I,L,b,D,F]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!q(a)||!q(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!q(a)||!q(t),t.setContent]:O("Store type not supported by this Persister"))(r,a,l),[M,U,G]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?_(a):null)??e+t++,t=>{Ha.test(t)&&T(a)<1e3&&S(a,t)}]})(),s=Q();return[(n,i,o,r=[],c=()=>[])=>{a??=V;const l=t(1);return ta(s,l,[n,i,o,r,c]),Ia(na(i,o??[e],Ca),l),l},(t,n,...i)=>m(((a,t=[e])=>{const n=[],s=(a,e)=>e==T(t)?S(n,a):d(t[e])?P(a,a=>s(a,e+1)):m([t[e],null],t=>s(Z(a,t),e+1));return s(a,0),n})(t,n),t=>P(t,t=>Z(s,t)[0](a,...n??[],...i))),a=>E(Z(s,a),([,t,i])=>(na(t,i??[e],void 0,t=>(h(t,a),f(t)?1:0)),ta(s,a),n(a),i)),t=>E(Z(s,t),([t,,e=[],n,s])=>{const i=(...o)=>{const r=T(o);r==T(e)?t(a,...o,...s(o)):d(e[r])?m(n[r]?.(...o)??[],a=>i(...o,a)):i(...o,e[r])};i()})]})(),x=a=>{a!=$&&($=a,U(C,void 0,$))},W=t=>{(I&&g(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},B=async a=>(2!=$&&(x(1),p++,await K(async()=>{await R(async()=>{const e=await t();g(e)?W(e):a?F(a):O("Content is not an array: "+e)},()=>{a&&F(a)}),x(0)})),V),H=async a=>(X(),await B(a),await R(async()=>N=await s(async(a,t)=>{t||a?2!=$&&(x(1),p++,W(t??a),x(0)):await B()}),o),V),X=async()=>(N&&(await R(()=>i(N),o),N=void 0),V),Y=async a=>(1!=$&&(x(2),v++,await K(async()=>{await R(()=>n(L,a),o),x(0)})),V),k=async()=>(z(),await Y(),A=a.addDidFinishTransactionListener(()=>{const a=b();D(a)&&Y(a)}),V),z=async()=>(A&&(a.delListener(A),A=void 0),V),J=async(a=!1)=>{const[t,e]=a?[z,X]:[X,z];return await t(),await e(),V},K=async(...a)=>(S(Z(Ya,w),...a),await(async()=>{if(!Z(Xa,w)){for(ta(Xa,w,1);!y(u=_(Z(Ya,w)));)await R(u,o);ta(Xa,w,0)}})(),V),V={load:B,startAutoLoad:H,stopAutoLoad:X,isAutoLoading:()=>!y(N),save:Y,startAutoSave:k,stopAutoSave:z,isAutoSaving:()=>!y(A),startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[k,H]:[H,k];return await e(a),await n(a),V},stopAutoPersisting:J,getStatus:()=>$,addStatusListener:a=>M(a,C),delListener:t=>(G(t),a),schedule:K,getStore:()=>a,destroy:()=>(Z(Ya,w).splice(0,void 0),J()),getStats:()=>({loads:p,saves:v}),...c};return j(V)},qa=(a,t,e,s,o,r=za,c,l)=>{const w=Q();return[async()=>{w.clear(),C(await e(a,t),({tn:a,cn:t})=>Ia(ea(w,a,Ca),t))},async(t,e,n)=>((a,t)=>b(Z(w,a),t))(t,e)?x(L(C(await a(Na+Oa(t)+va(t,n)),a=>[a[e],l?X(B(a,e),l):B(a,e)]),([a,t])=>!y(a)&&!q(t))):{},async(t,e,s,l,d,u=!1,E=i)=>{const N=Ca();X(s??{},a=>C(G(a??{}),a=>Ia(N,a)));const g=D(N);if(!u&&d&&E==i&&I(g)&&b(w,t))return await a("DROP "+ca+Oa(t)),void ta(w,t);const A=Z(w,t),T=Ca(D(A));if(I(g)||(b(w,t)?await p(C([e,...g],async(n,s)=>{h(T,n)||(await a(da+Oa(t)+"ADD"+Oa(n)+o),0==s&&await a("CREATE UNIQUE INDEX pk ON "+Oa(t)+`(${Oa(e)})`),Ia(A,n))})):(await a(Aa+Oa(t)+`(${Oa(e)}${o} PRIMARY KEY${v(C(g,a=>n+Oa(a)+o))});`),ta(w,t,Ca([e,...g])))),await p([...!u&&l?C(D(T),async n=>{n!=e&&(await a(da+Oa(t)+"DROP"+Oa(n)),h(A,n))}):[]]),u)y(s)?await a(Ea+Oa(t)+va(t,E)):await p(H(s,async(n,s)=>{y(n)?await a(Ea+Oa(t)+va(t,E)+`AND(${Oa(e)}=$1)`,[s]):I(g)||await r(a,t,e,G(n),{[s]:c?C(Y(n),c):Y(n)},A)}));else if(I(g))b(w,t)&&await a(Ea+Oa(t)+va(t,E));else{const n=L(D(Z(w,t)),a=>a!=e),i={},o=[];X(s??{},(a,t)=>{i[t]=C(n,t=>c?c(a?.[t]):a?.[t]),S(o,t)}),await r(a,t,e,n,i),await a(Ea+Oa(t)+va(t,E)+`AND${Oa(e)}NOT IN(${ma(o)})`,o)}},async t=>{let e;return await a("BEGIN"),await R(async()=>e=await t(),s),await a("END"),e}]},za=async(a,t,e,s,i)=>{const o=[1];await a(la+" INTO"+Oa(t)+"("+((...a)=>v(C(a,Oa),n))(e,...s)+")VALUES"+v(H(i,a=>"($"+o[0]+++","+ma(a,o)+")"),n)+"ON CONFLICT("+Oa(e)+`)DO ${ya} SET`+v(C(s,a=>Oa(a)+"=excluded."+Oa(a)),n),H(i,(a,t)=>[t,...C(a,a=>a??null)]).flat())},Ja=(a,t,e,n,s,i,o,[r,c,l],w,y,d,u,E,N)=>{const[g,A,T,$]=qa(t,w,y,s,E,N),p=ka(a,()=>$(async()=>{return await g(),a=(await A(r,c))[sa]?.[l]??"null",J(a,(a,t)=>""===t?void 0:t);var a}),a=>$(async()=>{await g(),await T(r,c,{[sa]:{[l]:K(a()??null)}},!0,!0)}),e,n,s,o,{[u]:()=>d,destroy:async()=>(await p.stopAutoPersisting(),i(),p)},0,d);return p},Ka=(a,t,e,n,s,i,o,[r,c,[l,w,d]],u,E,N,g,A,T,$,O)=>{const[R,m,v,C]=qa(t,u,E,s,A,T,$,O),I=(a,t)=>p(aa(c,async([e,n,s,i,o],r)=>{t&&!(r in a)||await v(e,n,a[r],s,i,t,o)})),S=async(a,t)=>w?await v(d,ia,{[sa]:a},!0,!0,t):null,_=ka(a,()=>C(async()=>{await R();const a=await(async()=>x(L(await p(aa(r,async([a,t,e],n)=>[a,await m(n,t,e)])),a=>!q(a[1]))))(),t=await(async()=>l?(await m(d,ia))[sa]:{})();return q(a)&&y(t)?void 0:[a,t]}),(a,t)=>C(async()=>{if(await R(),y(t)){const[t,e]=a();await I(t),await S(e)}else await I(t[0],!0),await S(t[1],!0)}),e,n,s,o,{[g]:()=>N,destroy:async()=>(await _.stopAutoPersisting(),i(),_)},0,N);return _},Va=/^([cd]:)(.+)/,Qa=(a,n,s,r,c,l,w,y,d,u,g="getDb")=>{const T=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,l),[$,,O,R]=(a=>{const e=(a=>W(xa,N(a)?{[ba]:a}:a??{}))(a),n=e[Pa];if(e.mode==_a){const a=e[ba]??t;return[1,n,[a,e[fa]??ia,e[Da]??Sa],Ca(a)]}const{tables:{load:s={},save:o={}}={},values:r={}}=e,c=A(Y(W(Wa,r)),0,k(Wa)),l=c[2],w=Ca(l),y=Ca(l),d=Ba(s,{[Fa]:null,[ha]:ia,[ja]:i},Fa,a=>b(y,a),a=>Ia(w,a)),u=Ba(o,{[Ma]:null,[ha]:ia,[Ua]:0,[Ga]:0,[ja]:null},Ma,(a,t)=>b(y,t),(a,t)=>Ia(w,t));var E;return E=(a,t)=>t[4]??=Z(d,t[0])?.[2]??i,P(u,(a,t)=>E(0,a)),[0,n,[d,u,c],w]})(n),I=e+(a=>{let t=2166136261;return m(V.encode(a),a=>{t^=a,t+=(t<<1)+(t<<4)+(t<<7)+(t<<8)+(t<<24)}),t>>>0})(K(O)),L=t+"_"+I,S=async(a,e,n="",s="")=>{const i=Ra(t,a,I);return await T(ga+Ta+$a+i+`()RETURNS ${n}trigger AS $$ ${s}BEGIN ${e}END;$$ LANGUAGE plpgsql;`),i},_=async(a,t,e,n)=>(await T(ga+a+"TRIGGER"+t+e+"EXECUTE "+$a+n+"()"),t),f=a=>`PERFORM pg_notify('${L}',${a});`,h=(a,t)=>$?i:2===t?h(a,0)+" OR "+h(a,1):o(Z(O[0],a)?.[2]??i,pa,0==t?"NEW":"OLD"),F=(a,e)=>p(C([la,wa,ya],(n,s)=>_(Ta,Ra(t,"d",I,a,n),`AFTER ${n} ON${Oa(a)}FOR EACH ROW WHEN(${h(a,s)})`,e)));return($?Ja:Ka)(a,T,async a=>{const e=await S("c",`FOR row IN SELECT object_identity FROM pg_event_trigger_ddl_commands()${ra} command_tag='${Aa}' LOOP ${f("'c:'||SPLIT_PART(row.object_identity,'.',2)")}END LOOP;`,"event_","DECLARE row record;");await _("EVENT ",Ra(t,"c",I),`ON ddl_command_end WHEN TAG IN('${Aa}')`,e);const n=await S("d",f("'d:'||TG_TABLE_NAME")+"RETURN NULL;");return await p(C(D(R),async a=>(await T(Aa+` IF NOT EXISTS${Oa(a)}("_id"text PRIMARY KEY)`),await F(a,n)))),[await r(L,t=>{return E((e=t,s=Va,e?.match(s)),async([,t,e])=>{b(R,e)&&("c:"==t&&await F(e,n),a())});var e,s}),[e,n]]},async([a,t])=>{c(a),await T(`DROP FUNCTION IF EXISTS${v(t,",")}CASCADE`)},w,y,d,O,D(R),async(a,t)=>await a(oa+` table_name tn,column_name cn FROM information_schema.columns ${ra} table_schema='public'AND table_name IN(${ma(t)})`,t),u,g,"text",void 0,a=>z(a),a=>J(a))},Za=async(a,t,e,n,s)=>Qa(a,e,async(a,e=[])=>(await t.query(a,e)).rows,(a,e)=>t.listen(a,e),a=>R(a,s),n,s,$,3,t,"getPglite");export{Za as createPglitePersister};
1
+ 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=a=>(t,e,n)=>a(t)?n?.():e(t),l=globalThis,w=a=>null==a,y=a=>void 0===a,d=a=>null===a,u=c(w),E=c(y),N=t=>a(t)==s,g=a=>Array.isArray(a),A=(a,t,e)=>a.slice(t,e),T=a=>a.length,$=()=>{},p=async a=>r.all(a),O=a=>{throw Error(a)},R=async(a,t,e)=>{try{return await a()}catch(a){t?.(a)}},m=(a,t)=>a.forEach(t),v=(a,t="")=>a.join(t),C=(a,t)=>a.map(t),I=a=>0==T(a),L=(a,t)=>a.filter(t),S=(a,...t)=>a.push(...t),_=a=>a.shift(),b=(a,t)=>a?.has(t)??!1,f=a=>y(a)||0==(a=>a?.size??0)(a),D=a=>[...a?.values()??[]],P=(a,t)=>a?.forEach(t),h=(a,t)=>a?.delete(t),F=Object,M=a=>F.getPrototypeOf(a),U=F.entries,G=a=>!w(a)&&u(M(a),a=>a==F.prototype||w(M(a)),()=>!0),j=F.keys,x=F.freeze,W=(a=[])=>F.fromEntries(a),B=(...a)=>F.assign({},...a),H=(a,t)=>(delete a[t],a),X=(a,t)=>C(U(a),([a,e])=>t(e,a)),Y=(a,t)=>W(X(a,(a,e)=>[e,t(a,e)])),k=a=>F.values(a),q=a=>T(j(a)),z=a=>G(a)&&0==q(a),J=JSON.stringify,K=JSON.parse,V=a=>J(a,(a,t)=>y(t)?"":t),Q=a=>""===a?void 0:g(a)?C(a,Q):G(a)?Y(a,Q):a,Z=new l.TextEncoder,aa=a=>new Map(a),ta=(a,t)=>a?.get(t),ea=(a,t)=>C([...a?.entries()??[]],([a,e])=>t(e,a)),na=(a,t,e)=>y(e)?(h(a,t),a):a?.set(t,e),sa=(a,t,e,n)=>(b(a,t)?n?.(ta(a,t)):na(a,t,e()),ta(a,t)),ia=(a,t,e,n,s=0)=>E((e?sa:ta)(a,t[s],s>T(t)-2?e:aa),i=>{if(s>T(t)-2)return n?.(i)&&na(a,t[s]),i;const o=ia(i,t,e,n,s+1);return f(i)&&na(a,t[s]),o}),oa="_",ra="_id",ca="SELECT",la="WHERE",wa="TABLE",ya="INSERT",da="DELETE",ua="UPDATE",Ea="ALTER "+wa,Na="FROM",ga=da+" "+Na,Aa=ca+"*"+Na,Ta="CREATE ",$a=Ta+wa,pa="OR REPLACE ",Oa="FUNCTION",Ra="$tableName",ma=a=>v(C(((a,t="",e)=>a.split(t,e))(a,"."),a=>`"${o(a,/"/g,'""')}"`),"."),va=(...a)=>ma(v(a,"_")),Ca=(a,t=[1])=>v(C(a,()=>"$"+t[0]++),n),Ia=(a,t=i)=>la+`(${o(t,Ra,ma(a))})`,La=a=>new Set(g(a)||y(a)?a:[a]),Sa=(a,t)=>a?.add(t),_a="ColumnName",ba="store",fa="json",Da=ba+"TableName",Pa=ba+"Id"+_a,ha=ba+_a,Fa="autoLoadIntervalSeconds",Ma="rowId"+_a,Ua="tableId",Ga="tableName",ja="deleteEmptyColumns",xa="deleteEmptyTable",Wa="condition",Ba={mode:fa,[Fa]:1},Ha={load:0,save:0,[Ga]:t+"_values"},Xa=(a,t,e,n,s)=>{const i=aa();return Y(a,(a,o)=>{const r=A(k(B(t,N(a)?{[e]:a}:a)),0,q(t));d(r[0])||n(o,r[0])||(s(o,r[0]),na(i,o,r))}),i},Ya=/^\d+$/,ka=aa(),qa=aa(),za=(a,t,n,s,i,o,r,c={},l=0,w=[])=>{let u,N,A,$=0,p=0,v=0;sa(ka,w,()=>0),sa(qa,w,()=>[]);const C=aa(),[I,L,b,D,F]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!z(a)||!z(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!z(a)||!z(t),t.setContent]:O("Store type not supported by this Persister"))(r,a,l),[M,U,G]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?_(a):null)??e+t++,t=>{Ya.test(t)&&T(a)<1e3&&S(a,t)}]})(),s=aa();return[(n,i,o,r=[],c=()=>[])=>{a??=V;const l=t(1);return na(s,l,[n,i,o,r,c]),Sa(ia(i,o??[e],La),l),l},(t,n,...i)=>m(((a,t=[e])=>{const n=[],s=(a,e)=>e==T(t)?S(n,a):d(t[e])?P(a,a=>s(a,e+1)):m([t[e],null],t=>s(ta(a,t),e+1));return s(a,0),n})(t,n),t=>P(t,t=>ta(s,t)[0](a,...n??[],...i))),a=>E(ta(s,a),([,t,i])=>(ia(t,i??[e],void 0,t=>(h(t,a),f(t)?1:0)),na(s,a),n(a),i)),t=>E(ta(s,t),([t,,e=[],n,s])=>{const i=(...o)=>{const r=T(o);r==T(e)?t(a,...o,...s(o)):d(e[r])?m(n[r]?.(...o)??[],a=>i(...o,a)):i(...o,e[r])};i()})]})(),j=a=>{a!=$&&($=a,U(C,void 0,$))},W=t=>{(I&&g(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},B=async a=>(2!=$&&(j(1),p++,await K(async()=>{await R(async()=>{const e=await t();g(e)?W(e):a?F(a):O("Content is not an array: "+e)},()=>{a&&F(a)}),j(0)})),V),H=async a=>(X(),await B(a),await R(async()=>N=await s(async(a,t)=>{t||a?2!=$&&(j(1),p++,W(t??a),j(0)):await B()}),o),V),X=async()=>(N&&(await R(()=>i(N),o),N=void 0),V),Y=async a=>(1!=$&&(j(2),v++,await K(async()=>{await R(()=>n(L,a),o),j(0)})),V),k=async()=>(q(),await Y(),A=a.addDidFinishTransactionListener(()=>{const a=b();D(a)&&Y(a)}),V),q=async()=>(A&&(a.delListener(A),A=void 0),V),J=async(a=!1)=>{const[t,e]=a?[q,X]:[X,q];return await t(),await e(),V},K=async(...a)=>(S(ta(qa,w),...a),await(async()=>{if(!ta(ka,w)){for(na(ka,w,1);!y(u=_(ta(qa,w)));)await R(u,o);na(ka,w,0)}})(),V),V={load:B,startAutoLoad:H,stopAutoLoad:X,isAutoLoading:()=>!y(N),save:Y,startAutoSave:k,stopAutoSave:q,isAutoSaving:()=>!y(A),startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[k,H]:[H,k];return await e(a),await n(a),V},stopAutoPersisting:J,getStatus:()=>$,addStatusListener:a=>M(a,C),delListener:t=>(G(t),a),schedule:K,getStore:()=>a,destroy:()=>(ta(qa,w).splice(0,void 0),J()),getStats:()=>({loads:p,saves:v}),...c};return x(V)},Ja=(a,t,e,s,o,r=Ka,c,l)=>{const w=aa();return[async()=>{w.clear(),C(await e(a,t),({tn:a,cn:t})=>Sa(sa(w,a,La),t))},async(t,e,n)=>((a,t)=>b(ta(w,a),t))(t,e)?W(L(C(await a(Aa+ma(t)+Ia(t,n)),a=>[a[e],l?Y(H(a,e),l):H(a,e)]),([a,t])=>!y(a)&&!z(t))):{},async(t,e,s,l,d,u=!1,E=i)=>{const N=La();Y(s??{},a=>C(j(a??{}),a=>Sa(N,a)));const g=D(N);if(!u&&d&&E==i&&I(g)&&b(w,t))return await a("DROP "+wa+ma(t)),void na(w,t);const A=ta(w,t),T=La(D(A));if(I(g)||(b(w,t)?await p(C([e,...g],async(n,s)=>{h(T,n)||(await a(Ea+ma(t)+"ADD"+ma(n)+o),0==s&&await a("CREATE UNIQUE INDEX pk ON "+ma(t)+`(${ma(e)})`),Sa(A,n))})):(await a($a+ma(t)+`(${ma(e)}${o} PRIMARY KEY${v(C(g,a=>n+ma(a)+o))});`),na(w,t,La([e,...g])))),await p([...!u&&l?C(D(T),async n=>{n!=e&&(await a(Ea+ma(t)+"DROP"+ma(n)),h(A,n))}):[]]),u)y(s)?await a(ga+ma(t)+Ia(t,E)):await p(X(s,async(n,s)=>{y(n)?await a(ga+ma(t)+Ia(t,E)+`AND(${ma(e)}=$1)`,[s]):I(g)||await r(a,t,e,j(n),{[s]:c?C(k(n),c):k(n)},A)}));else if(I(g))b(w,t)&&await a(ga+ma(t)+Ia(t,E));else{const n=L(D(ta(w,t)),a=>a!=e),i={},o=[];Y(s??{},(a,t)=>{i[t]=C(n,t=>c?c(a?.[t]):a?.[t]),S(o,t)}),await r(a,t,e,n,i),await a(ga+ma(t)+Ia(t,E)+`AND${ma(e)}NOT IN(${Ca(o)})`,o)}},async t=>{let e;return await a("BEGIN"),await R(async()=>e=await t(),s),await a("END"),e}]},Ka=async(a,t,e,s,i)=>{const o=[1];await a(ya+" INTO"+ma(t)+"("+((...a)=>v(C(a,ma),n))(e,...s)+")VALUES"+v(X(i,a=>"($"+o[0]+++","+Ca(a,o)+")"),n)+"ON CONFLICT("+ma(e)+`)DO ${ua} SET`+v(C(s,a=>ma(a)+"=excluded."+ma(a)),n),X(i,(a,t)=>[t,...C(a,a=>a??null)]).flat())},Va=(a,t,e,n,s,i,o,[r,c,l],w,y,d,u,E,N)=>{const[g,A,T,$]=Ja(t,w,y,s,E,N),p=za(a,()=>$(async()=>{return await g(),a=(await A(r,c))[oa]?.[l]??"null",Q(K(a));var a}),a=>$(async()=>{await g(),await T(r,c,{[oa]:{[l]:V(a()??null)}},!0,!0)}),e,n,s,o,{[u]:()=>d,destroy:async()=>(await p.stopAutoPersisting(),i(),p)},0,d);return p},Qa=(a,t,e,n,s,i,o,[r,c,[l,w,d]],u,E,N,g,A,T,$,O)=>{const[R,m,v,C]=Ja(t,u,E,s,A,T,$,O),I=(a,t)=>p(ea(c,async([e,n,s,i,o],r)=>{t&&!(r in a)||await v(e,n,a[r],s,i,t,o)})),S=async(a,t)=>w?await v(d,ra,{[oa]:a},!0,!0,t):null,_=za(a,()=>C(async()=>{await R();const a=await(async()=>W(L(await p(ea(r,async([a,t,e],n)=>[a,await m(n,t,e)])),a=>!z(a[1]))))(),t=await(async()=>l?(await m(d,ra))[oa]:{})();return z(a)&&y(t)?void 0:[a,t]}),(a,t)=>C(async()=>{if(await R(),y(t)){const[t,e]=a();await I(t),await S(e)}else await I(t[0],!0),await S(t[1],!0)}),e,n,s,o,{[g]:()=>N,destroy:async()=>(await _.stopAutoPersisting(),i(),_)},0,N);return _},Za=/^([cd]:)(.+)/,at=(a,n,s,r,c,l,w,y,d,u,g="getDb")=>{const T=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,l),[$,,O,R]=(a=>{const e=(a=>B(Ba,N(a)?{[Da]:a}:a??{}))(a),n=e[Fa];if(e.mode==fa){const a=e[Da]??t;return[1,n,[a,e[Pa]??ra,e[ha]??ba],La(a)]}const{tables:{load:s={},save:o={}}={},values:r={}}=e,c=A(k(B(Ha,r)),0,q(Ha)),l=c[2],w=La(l),y=La(l),d=Xa(s,{[Ua]:null,[Ma]:ra,[Wa]:i},Ua,a=>b(y,a),a=>Sa(w,a)),u=Xa(o,{[Ga]:null,[Ma]:ra,[ja]:0,[xa]:0,[Wa]:null},Ga,(a,t)=>b(y,t),(a,t)=>Sa(w,t));var E;return E=(a,t)=>t[4]??=ta(d,t[0])?.[2]??i,P(u,(a,t)=>E(0,a)),[0,n,[d,u,c],w]})(n),I=e+(a=>{let t=2166136261;return m(Z.encode(a),a=>{t^=a,t+=(t<<1)+(t<<4)+(t<<7)+(t<<8)+(t<<24)}),t>>>0})(V(O)),L=t+"_"+I,S=async(a,e,n="",s="")=>{const i=va(t,a,I);return await T(Ta+pa+Oa+i+`()RETURNS ${n}trigger AS $$ ${s}BEGIN ${e}END;$$ LANGUAGE plpgsql;`),i},_=async(a,t,e,n)=>(await T(Ta+a+"TRIGGER"+t+e+"EXECUTE "+Oa+n+"()"),t),f=a=>`PERFORM pg_notify('${L}',${a});`,h=(a,t)=>$?i:2===t?h(a,0)+" OR "+h(a,1):o(ta(O[0],a)?.[2]??i,Ra,0==t?"NEW":"OLD"),F=(a,e)=>p(C([ya,da,ua],(n,s)=>_(pa,va(t,"d",I,a,n),`AFTER ${n} ON${ma(a)}FOR EACH ROW WHEN(${h(a,s)})`,e)));return($?Va:Qa)(a,T,async a=>{const e=await S("c",`FOR row IN SELECT object_identity FROM pg_event_trigger_ddl_commands()${la} command_tag='${$a}' LOOP ${f("'c:'||SPLIT_PART(row.object_identity,'.',2)")}END LOOP;`,"event_","DECLARE row record;");await _("EVENT ",va(t,"c",I),`ON ddl_command_end WHEN TAG IN('${$a}')`,e);const n=await S("d",f("'d:'||TG_TABLE_NAME")+"RETURN NULL;");return await p(C(D(R),async a=>(await T($a+` IF NOT EXISTS${ma(a)}("_id"text PRIMARY KEY)`),await F(a,n)))),[await r(L,t=>{return E((e=t,s=Za,e?.match(s)),async([,t,e])=>{b(R,e)&&("c:"==t&&await F(e,n),a())});var e,s}),[e,n]]},async([a,t])=>{c(a),await T(`DROP FUNCTION IF EXISTS${v(t,",")}CASCADE`)},w,y,d,O,D(R),async(a,t)=>await a(ca+` table_name tn,column_name cn FROM information_schema.columns ${la} table_schema='public'AND table_name IN(${Ca(t)})`,t),u,g,"text",void 0,a=>J(a),a=>K(a))},tt=async(a,t,e,n,s)=>at(a,e,async(a,e=[])=>(await t.query(a,e)).rows,(a,e)=>t.listen(a,e),a=>R(a,s),n,s,$,3,t,"getPglite");export{tt as createPglitePersister};
@@ -1 +1 @@
1
- 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=globalThis,w=a=>null==a,y=a=>void 0===a,u=a=>null===a,d=c(w),E=c(y),N=t=>a(t)==s,g=a=>Array.isArray(a),A=(a,t,e)=>a.slice(t,e),T=a=>a.length,$=async a=>o.all(a),p=a=>{throw Error(a)},O=async(a,t,e)=>{try{return await a()}catch(a){t?.(a)}},R=(a,t)=>a.forEach(t),m=(a,t="")=>a.join(t),v=(a,t)=>a.map(t),C=a=>0==T(a),S=(a,t)=>a.filter(t),I=(a,...t)=>a.push(...t),L=a=>a.shift(),_=(a,t)=>a?.has(t)??!1,b=a=>y(a)||0==(a=>a?.size??0)(a),f=a=>[...a?.values()??[]],D=(a,t)=>a?.forEach(t),h=(a,t)=>a?.delete(t),P=Object,F=a=>P.getPrototypeOf(a),M=P.entries,U=P.keys,G=P.freeze,j=(a=[])=>P.fromEntries(a),x=(...a)=>P.assign({},...a),W=(a,t)=>(delete a[t],a),B=(a,t)=>v(M(a),([a,e])=>t(e,a)),H=(a,t)=>j(B(a,(a,e)=>[e,t(a,e)])),X=a=>P.values(a),Y=a=>T(U(a)),k=a=>(a=>!w(a)&&d(F(a),a=>a==P.prototype||w(F(a)),()=>!0))(a)&&0==Y(a),q=JSON.stringify,z=JSON.parse,J=a=>q(a,(a,t)=>y(t)?"":t),K=new l.TextEncoder,V=a=>new Map(a),Q=(a,t)=>a?.get(t),Z=(a,t)=>v([...a?.entries()??[]],([a,e])=>t(e,a)),aa=(a,t,e)=>y(e)?(h(a,t),a):a?.set(t,e),ta=(a,t,e,n)=>(_(a,t)?n?.(Q(a,t)):aa(a,t,e()),Q(a,t)),ea=(a,t,e,n,s=0)=>E((e?ta:Q)(a,t[s],s>T(t)-2?e:V),i=>{if(s>T(t)-2)return n?.(i)&&aa(a,t[s]),i;const r=ea(i,t,e,n,s+1);return b(i)&&aa(a,t[s]),r}),na="_",sa="_id",ia="SELECT",ra="WHERE",oa="TABLE",ca="INSERT",la="DELETE",wa="UPDATE",ya="ALTER "+oa,ua="FROM",da=la+" "+ua,Ea=ia+"*"+ua,Na="CREATE ",ga=Na+oa,Aa="OR REPLACE ",Ta="FUNCTION",$a="$tableName",pa=a=>m(v(((a,t="",e)=>a.split(t,e))(a,"."),a=>`"${r(a,/"/g,'""')}"`),"."),Oa=(...a)=>pa(m(a,"_")),Ra=(a,t=[1])=>m(v(a,()=>"$"+t[0]++),n),ma=(a,t=i)=>ra+`(${r(t,$a,pa(a))})`,va=a=>new Set(g(a)||y(a)?a:[a]),Ca=(a,t)=>a?.add(t),Sa="ColumnName",Ia="store",La="json",_a=Ia+"TableName",ba=Ia+"Id"+Sa,fa=Ia+Sa,Da="autoLoadIntervalSeconds",ha="rowId"+Sa,Pa="tableId",Fa="tableName",Ma="deleteEmptyColumns",Ua="deleteEmptyTable",Ga="condition",ja={mode:La,[Da]:1},xa={load:0,save:0,[Fa]:t+"_values"},Wa=(a,t,e,n,s)=>{const i=V();return H(a,(a,r)=>{const o=A(X(x(t,N(a)?{[e]:a}:a)),0,Y(t));u(o[0])||n(r,o[0])||(s(r,o[0]),aa(i,r,o))}),i},Ba=/^\d+$/,Ha=V(),Xa=V(),Ya=(a,t,n,s,i,r,o,c={},l=0,w=[])=>{let d,N,A,$=0,m=0,v=0;ta(Ha,w,()=>0),ta(Xa,w,()=>[]);const C=V(),[S,_,f,P,F]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!k(a)||!k(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!k(a)||!k(t),t.setContent]:p("Store type not supported by this Persister"))(o,a,l),[M,U,j]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?L(a):null)??e+t++,t=>{Ba.test(t)&&T(a)<1e3&&I(a,t)}]})(),s=V();return[(n,i,r,o=[],c=()=>[])=>{a??=Z;const l=t(1);return aa(s,l,[n,i,r,o,c]),Ca(ea(i,r??[e],va),l),l},(t,n,...i)=>R(((a,t=[e])=>{const n=[],s=(a,e)=>e==T(t)?I(n,a):u(t[e])?D(a,a=>s(a,e+1)):R([t[e],null],t=>s(Q(a,t),e+1));return s(a,0),n})(t,n),t=>D(t,t=>Q(s,t)[0](a,...n??[],...i))),a=>E(Q(s,a),([,t,i])=>(ea(t,i??[e],void 0,t=>(h(t,a),b(t)?1:0)),aa(s,a),n(a),i)),t=>E(Q(s,t),([t,,e=[],n,s])=>{const i=(...r)=>{const o=T(r);o==T(e)?t(a,...r,...s(r)):u(e[o])?R(n[o]?.(...r)??[],a=>i(...r,a)):i(...r,e[o])};i()})]})(),x=a=>{a!=$&&($=a,U(C,void 0,$))},W=t=>{(S&&g(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},B=async a=>(2!=$&&(x(1),m++,await K(async()=>{await O(async()=>{const e=await t();g(e)?W(e):a?F(a):p("Content is not an array: "+e)},()=>{a&&F(a)}),x(0)})),Z),H=async a=>(X(),await B(a),await O(async()=>N=await s(async(a,t)=>{t||a?2!=$&&(x(1),m++,W(t??a),x(0)):await B()}),r),Z),X=async()=>(N&&(await O(()=>i(N),r),N=void 0),Z),Y=async a=>(1!=$&&(x(2),v++,await K(async()=>{await O(()=>n(_,a),r),x(0)})),Z),q=async()=>(z(),await Y(),A=a.addDidFinishTransactionListener(()=>{const a=f();P(a)&&Y(a)}),Z),z=async()=>(A&&(a.delListener(A),A=void 0),Z),J=async(a=!1)=>{const[t,e]=a?[z,X]:[X,z];return await t(),await e(),Z},K=async(...a)=>(I(Q(Xa,w),...a),await(async()=>{if(!Q(Ha,w)){for(aa(Ha,w,1);!y(d=L(Q(Xa,w)));)await O(d,r);aa(Ha,w,0)}})(),Z),Z={load:B,startAutoLoad:H,stopAutoLoad:X,isAutoLoading:()=>!y(N),save:Y,startAutoSave:q,stopAutoSave:z,isAutoSaving:()=>!y(A),startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[q,H]:[H,q];return await e(a),await n(a),Z},stopAutoPersisting:J,getStatus:()=>$,addStatusListener:a=>M(a,C),delListener:t=>(j(t),a),schedule:K,getStore:()=>a,destroy:()=>(Q(Xa,w).splice(0,void 0),J()),getStats:()=>({loads:m,saves:v}),...c};return G(Z)},ka=(a,t,e,s,r,o=qa,c,l)=>{const w=V();return[async()=>{w.clear(),v(await e(a,t),({tn:a,cn:t})=>Ca(ta(w,a,va),t))},async(t,e,n)=>((a,t)=>_(Q(w,a),t))(t,e)?j(S(v(await a(Ea+pa(t)+ma(t,n)),a=>[a[e],l?H(W(a,e),l):W(a,e)]),([a,t])=>!y(a)&&!k(t))):{},async(t,e,s,l,u,d=!1,E=i)=>{const N=va();H(s??{},a=>v(U(a??{}),a=>Ca(N,a)));const g=f(N);if(!d&&u&&E==i&&C(g)&&_(w,t))return await a("DROP "+oa+pa(t)),void aa(w,t);const A=Q(w,t),T=va(f(A));if(C(g)||(_(w,t)?await $(v([e,...g],async(n,s)=>{h(T,n)||(await a(ya+pa(t)+"ADD"+pa(n)+r),0==s&&await a("CREATE UNIQUE INDEX pk ON "+pa(t)+`(${pa(e)})`),Ca(A,n))})):(await a(ga+pa(t)+`(${pa(e)}${r} PRIMARY KEY${m(v(g,a=>n+pa(a)+r))});`),aa(w,t,va([e,...g])))),await $([...!d&&l?v(f(T),async n=>{n!=e&&(await a(ya+pa(t)+"DROP"+pa(n)),h(A,n))}):[]]),d)y(s)?await a(da+pa(t)+ma(t,E)):await $(B(s,async(n,s)=>{y(n)?await a(da+pa(t)+ma(t,E)+`AND(${pa(e)}=$1)`,[s]):C(g)||await o(a,t,e,U(n),{[s]:c?v(X(n),c):X(n)},A)}));else if(C(g))_(w,t)&&await a(da+pa(t)+ma(t,E));else{const n=S(f(Q(w,t)),a=>a!=e),i={},r=[];H(s??{},(a,t)=>{i[t]=v(n,t=>c?c(a?.[t]):a?.[t]),I(r,t)}),await o(a,t,e,n,i),await a(da+pa(t)+ma(t,E)+`AND${pa(e)}NOT IN(${Ra(r)})`,r)}},async t=>{let e;return await a("BEGIN"),await O(async()=>e=await t(),s),await a("END"),e}]},qa=async(a,t,e,s,i)=>{const r=[1];await a(ca+" INTO"+pa(t)+"("+((...a)=>m(v(a,pa),n))(e,...s)+")VALUES"+m(B(i,a=>"($"+r[0]+++","+Ra(a,r)+")"),n)+"ON CONFLICT("+pa(e)+`)DO ${wa} SET`+m(v(s,a=>pa(a)+"=excluded."+pa(a)),n),B(i,(a,t)=>[t,...v(a,a=>a??null)]).flat())},za=(a,t,e,n,s,i,r,[o,c,l],w,y,u,d,E,N)=>{const[g,A,T,$]=ka(t,w,y,s,E,N),p=Ya(a,()=>$(async()=>{return await g(),a=(await A(o,c))[na]?.[l]??"null",z(a,(a,t)=>""===t?void 0:t);var a}),a=>$(async()=>{await g(),await T(o,c,{[na]:{[l]:J(a()??null)}},!0,!0)}),e,n,s,r,{[d]:()=>u,destroy:async()=>(await p.stopAutoPersisting(),i(),p)},0,u);return p},Ja=(a,t,e,n,s,i,r,[o,c,[l,w,u]],d,E,N,g,A,T,p,O)=>{const[R,m,v,C]=ka(t,d,E,s,A,T,p,O),I=(a,t)=>$(Z(c,async([e,n,s,i,r],o)=>{t&&!(o in a)||await v(e,n,a[o],s,i,t,r)})),L=async(a,t)=>w?await v(u,sa,{[na]:a},!0,!0,t):null,_=Ya(a,()=>C(async()=>{await R();const a=await(async()=>j(S(await $(Z(o,async([a,t,e],n)=>[a,await m(n,t,e)])),a=>!k(a[1]))))(),t=await(async()=>l?(await m(u,sa))[na]:{})();return k(a)&&y(t)?void 0:[a,t]}),(a,t)=>C(async()=>{if(await R(),y(t)){const[t,e]=a();await I(t),await L(e)}else await I(t[0],!0),await L(t[1],!0)}),e,n,s,r,{[g]:()=>N,destroy:async()=>(await _.stopAutoPersisting(),i(),_)},0,N);return _},Ka=/^([cd]:)(.+)/,Va=(a,n,s,o,c,l,w,y,u,d,g="getDb")=>{const T=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,l),[p,,O,C]=(a=>{const e=(a=>x(ja,N(a)?{[_a]:a}:a??{}))(a),n=e[Da];if(e.mode==La){const a=e[_a]??t;return[1,n,[a,e[ba]??sa,e[fa]??Ia],va(a)]}const{tables:{load:s={},save:r={}}={},values:o={}}=e,c=A(X(x(xa,o)),0,Y(xa)),l=c[2],w=va(l),y=va(l),u=Wa(s,{[Pa]:null,[ha]:sa,[Ga]:i},Pa,a=>_(y,a),a=>Ca(w,a)),d=Wa(r,{[Fa]:null,[ha]:sa,[Ma]:0,[Ua]:0,[Ga]:null},Fa,(a,t)=>_(y,t),(a,t)=>Ca(w,t));var E;return E=(a,t)=>t[4]??=Q(u,t[0])?.[2]??i,D(d,(a,t)=>E(0,a)),[0,n,[u,d,c],w]})(n),S=e+(a=>{let t=2166136261;return R(K.encode(a),a=>{t^=a,t+=(t<<1)+(t<<4)+(t<<7)+(t<<8)+(t<<24)}),t>>>0})(J(O)),I=t+"_"+S,L=async(a,e,n="",s="")=>{const i=Oa(t,a,S);return await T(Na+Aa+Ta+i+`()RETURNS ${n}trigger AS $$ ${s}BEGIN ${e}END;$$ LANGUAGE plpgsql;`),i},b=async(a,t,e,n)=>(await T(Na+a+"TRIGGER"+t+e+"EXECUTE "+Ta+n+"()"),t),h=a=>`PERFORM pg_notify('${I}',${a});`,P=(a,t)=>p?i:2===t?P(a,0)+" OR "+P(a,1):r(Q(O[0],a)?.[2]??i,$a,0==t?"NEW":"OLD"),F=(a,e)=>$(v([ca,la,wa],(n,s)=>b(Aa,Oa(t,"d",S,a,n),`AFTER ${n} ON${pa(a)}FOR EACH ROW WHEN(${P(a,s)})`,e)));return(p?za:Ja)(a,T,async a=>{const e=await L("c",`FOR row IN SELECT object_identity FROM pg_event_trigger_ddl_commands()${ra} command_tag='${ga}' LOOP ${h("'c:'||SPLIT_PART(row.object_identity,'.',2)")}END LOOP;`,"event_","DECLARE row record;");await b("EVENT ",Oa(t,"c",S),`ON ddl_command_end WHEN TAG IN('${ga}')`,e);const n=await L("d",h("'d:'||TG_TABLE_NAME")+"RETURN NULL;");return await $(v(f(C),async a=>(await T(ga+` IF NOT EXISTS${pa(a)}("_id"text PRIMARY KEY)`),await F(a,n)))),[await o(I,t=>{return E((e=t,s=Ka,e?.match(s)),async([,t,e])=>{_(C,e)&&("c:"==t&&await F(e,n),a())});var e,s}),[e,n]]},async([a,t])=>{c(a),await T(`DROP FUNCTION IF EXISTS${m(t,",")}CASCADE`)},w,y,u,O,f(C),async(a,t)=>await a(ia+` table_name tn,column_name cn FROM information_schema.columns ${ra} table_schema='public'AND table_name IN(${Ra(t)})`,t),d,g,"text",void 0,a=>q(a),a=>z(a))},Qa=async(a,t,e,n,s)=>{const i=await(t.reserve?.());return Va(a,e,i?.unsafe,async(a,e)=>t.listen(a,e),a=>O(a.unlisten,s),n,s,()=>i?.release?.(),3,t,"getSql")};export{Qa as createPostgresPersister};
1
+ 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=globalThis,w=a=>null==a,y=a=>void 0===a,u=a=>null===a,d=c(w),E=c(y),N=t=>a(t)==s,g=a=>Array.isArray(a),A=(a,t,e)=>a.slice(t,e),T=a=>a.length,$=async a=>o.all(a),p=a=>{throw Error(a)},O=async(a,t,e)=>{try{return await a()}catch(a){t?.(a)}},R=(a,t)=>a.forEach(t),m=(a,t="")=>a.join(t),v=(a,t)=>a.map(t),C=a=>0==T(a),S=(a,t)=>a.filter(t),I=(a,...t)=>a.push(...t),L=a=>a.shift(),_=(a,t)=>a?.has(t)??!1,b=a=>y(a)||0==(a=>a?.size??0)(a),f=a=>[...a?.values()??[]],D=(a,t)=>a?.forEach(t),h=(a,t)=>a?.delete(t),P=Object,F=a=>P.getPrototypeOf(a),M=P.entries,U=a=>!w(a)&&d(F(a),a=>a==P.prototype||w(F(a)),()=>!0),G=P.keys,j=P.freeze,x=(a=[])=>P.fromEntries(a),W=(...a)=>P.assign({},...a),B=(a,t)=>(delete a[t],a),H=(a,t)=>v(M(a),([a,e])=>t(e,a)),X=(a,t)=>x(H(a,(a,e)=>[e,t(a,e)])),Y=a=>P.values(a),k=a=>T(G(a)),q=a=>U(a)&&0==k(a),z=JSON.stringify,J=JSON.parse,K=a=>z(a,(a,t)=>y(t)?"":t),V=a=>""===a?void 0:g(a)?v(a,V):U(a)?X(a,V):a,Q=new l.TextEncoder,Z=a=>new Map(a),aa=(a,t)=>a?.get(t),ta=(a,t)=>v([...a?.entries()??[]],([a,e])=>t(e,a)),ea=(a,t,e)=>y(e)?(h(a,t),a):a?.set(t,e),na=(a,t,e,n)=>(_(a,t)?n?.(aa(a,t)):ea(a,t,e()),aa(a,t)),sa=(a,t,e,n,s=0)=>E((e?na:aa)(a,t[s],s>T(t)-2?e:Z),i=>{if(s>T(t)-2)return n?.(i)&&ea(a,t[s]),i;const r=sa(i,t,e,n,s+1);return b(i)&&ea(a,t[s]),r}),ia="_",ra="_id",oa="SELECT",ca="WHERE",la="TABLE",wa="INSERT",ya="DELETE",ua="UPDATE",da="ALTER "+la,Ea="FROM",Na=ya+" "+Ea,ga=oa+"*"+Ea,Aa="CREATE ",Ta=Aa+la,$a="OR REPLACE ",pa="FUNCTION",Oa="$tableName",Ra=a=>m(v(((a,t="",e)=>a.split(t,e))(a,"."),a=>`"${r(a,/"/g,'""')}"`),"."),ma=(...a)=>Ra(m(a,"_")),va=(a,t=[1])=>m(v(a,()=>"$"+t[0]++),n),Ca=(a,t=i)=>ca+`(${r(t,Oa,Ra(a))})`,Sa=a=>new Set(g(a)||y(a)?a:[a]),Ia=(a,t)=>a?.add(t),La="ColumnName",_a="store",ba="json",fa=_a+"TableName",Da=_a+"Id"+La,ha=_a+La,Pa="autoLoadIntervalSeconds",Fa="rowId"+La,Ma="tableId",Ua="tableName",Ga="deleteEmptyColumns",ja="deleteEmptyTable",xa="condition",Wa={mode:ba,[Pa]:1},Ba={load:0,save:0,[Ua]:t+"_values"},Ha=(a,t,e,n,s)=>{const i=Z();return X(a,(a,r)=>{const o=A(Y(W(t,N(a)?{[e]:a}:a)),0,k(t));u(o[0])||n(r,o[0])||(s(r,o[0]),ea(i,r,o))}),i},Xa=/^\d+$/,Ya=Z(),ka=Z(),qa=(a,t,n,s,i,r,o,c={},l=0,w=[])=>{let d,N,A,$=0,m=0,v=0;na(Ya,w,()=>0),na(ka,w,()=>[]);const C=Z(),[S,_,f,P,F]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!q(a)||!q(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!q(a)||!q(t),t.setContent]:p("Store type not supported by this Persister"))(o,a,l),[M,U,G]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?L(a):null)??e+t++,t=>{Xa.test(t)&&T(a)<1e3&&I(a,t)}]})(),s=Z();return[(n,i,r,o=[],c=()=>[])=>{a??=V;const l=t(1);return ea(s,l,[n,i,r,o,c]),Ia(sa(i,r??[e],Sa),l),l},(t,n,...i)=>R(((a,t=[e])=>{const n=[],s=(a,e)=>e==T(t)?I(n,a):u(t[e])?D(a,a=>s(a,e+1)):R([t[e],null],t=>s(aa(a,t),e+1));return s(a,0),n})(t,n),t=>D(t,t=>aa(s,t)[0](a,...n??[],...i))),a=>E(aa(s,a),([,t,i])=>(sa(t,i??[e],void 0,t=>(h(t,a),b(t)?1:0)),ea(s,a),n(a),i)),t=>E(aa(s,t),([t,,e=[],n,s])=>{const i=(...r)=>{const o=T(r);o==T(e)?t(a,...r,...s(r)):u(e[o])?R(n[o]?.(...r)??[],a=>i(...r,a)):i(...r,e[o])};i()})]})(),x=a=>{a!=$&&($=a,U(C,void 0,$))},W=t=>{(S&&g(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},B=async a=>(2!=$&&(x(1),m++,await K(async()=>{await O(async()=>{const e=await t();g(e)?W(e):a?F(a):p("Content is not an array: "+e)},()=>{a&&F(a)}),x(0)})),V),H=async a=>(X(),await B(a),await O(async()=>N=await s(async(a,t)=>{t||a?2!=$&&(x(1),m++,W(t??a),x(0)):await B()}),r),V),X=async()=>(N&&(await O(()=>i(N),r),N=void 0),V),Y=async a=>(1!=$&&(x(2),v++,await K(async()=>{await O(()=>n(_,a),r),x(0)})),V),k=async()=>(z(),await Y(),A=a.addDidFinishTransactionListener(()=>{const a=f();P(a)&&Y(a)}),V),z=async()=>(A&&(a.delListener(A),A=void 0),V),J=async(a=!1)=>{const[t,e]=a?[z,X]:[X,z];return await t(),await e(),V},K=async(...a)=>(I(aa(ka,w),...a),await(async()=>{if(!aa(Ya,w)){for(ea(Ya,w,1);!y(d=L(aa(ka,w)));)await O(d,r);ea(Ya,w,0)}})(),V),V={load:B,startAutoLoad:H,stopAutoLoad:X,isAutoLoading:()=>!y(N),save:Y,startAutoSave:k,stopAutoSave:z,isAutoSaving:()=>!y(A),startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[k,H]:[H,k];return await e(a),await n(a),V},stopAutoPersisting:J,getStatus:()=>$,addStatusListener:a=>M(a,C),delListener:t=>(G(t),a),schedule:K,getStore:()=>a,destroy:()=>(aa(ka,w).splice(0,void 0),J()),getStats:()=>({loads:m,saves:v}),...c};return j(V)},za=(a,t,e,s,r,o=Ja,c,l)=>{const w=Z();return[async()=>{w.clear(),v(await e(a,t),({tn:a,cn:t})=>Ia(na(w,a,Sa),t))},async(t,e,n)=>((a,t)=>_(aa(w,a),t))(t,e)?x(S(v(await a(ga+Ra(t)+Ca(t,n)),a=>[a[e],l?X(B(a,e),l):B(a,e)]),([a,t])=>!y(a)&&!q(t))):{},async(t,e,s,l,u,d=!1,E=i)=>{const N=Sa();X(s??{},a=>v(G(a??{}),a=>Ia(N,a)));const g=f(N);if(!d&&u&&E==i&&C(g)&&_(w,t))return await a("DROP "+la+Ra(t)),void ea(w,t);const A=aa(w,t),T=Sa(f(A));if(C(g)||(_(w,t)?await $(v([e,...g],async(n,s)=>{h(T,n)||(await a(da+Ra(t)+"ADD"+Ra(n)+r),0==s&&await a("CREATE UNIQUE INDEX pk ON "+Ra(t)+`(${Ra(e)})`),Ia(A,n))})):(await a(Ta+Ra(t)+`(${Ra(e)}${r} PRIMARY KEY${m(v(g,a=>n+Ra(a)+r))});`),ea(w,t,Sa([e,...g])))),await $([...!d&&l?v(f(T),async n=>{n!=e&&(await a(da+Ra(t)+"DROP"+Ra(n)),h(A,n))}):[]]),d)y(s)?await a(Na+Ra(t)+Ca(t,E)):await $(H(s,async(n,s)=>{y(n)?await a(Na+Ra(t)+Ca(t,E)+`AND(${Ra(e)}=$1)`,[s]):C(g)||await o(a,t,e,G(n),{[s]:c?v(Y(n),c):Y(n)},A)}));else if(C(g))_(w,t)&&await a(Na+Ra(t)+Ca(t,E));else{const n=S(f(aa(w,t)),a=>a!=e),i={},r=[];X(s??{},(a,t)=>{i[t]=v(n,t=>c?c(a?.[t]):a?.[t]),I(r,t)}),await o(a,t,e,n,i),await a(Na+Ra(t)+Ca(t,E)+`AND${Ra(e)}NOT IN(${va(r)})`,r)}},async t=>{let e;return await a("BEGIN"),await O(async()=>e=await t(),s),await a("END"),e}]},Ja=async(a,t,e,s,i)=>{const r=[1];await a(wa+" INTO"+Ra(t)+"("+((...a)=>m(v(a,Ra),n))(e,...s)+")VALUES"+m(H(i,a=>"($"+r[0]+++","+va(a,r)+")"),n)+"ON CONFLICT("+Ra(e)+`)DO ${ua} SET`+m(v(s,a=>Ra(a)+"=excluded."+Ra(a)),n),H(i,(a,t)=>[t,...v(a,a=>a??null)]).flat())},Ka=(a,t,e,n,s,i,r,[o,c,l],w,y,u,d,E,N)=>{const[g,A,T,$]=za(t,w,y,s,E,N),p=qa(a,()=>$(async()=>{return await g(),a=(await A(o,c))[ia]?.[l]??"null",V(J(a));var a}),a=>$(async()=>{await g(),await T(o,c,{[ia]:{[l]:K(a()??null)}},!0,!0)}),e,n,s,r,{[d]:()=>u,destroy:async()=>(await p.stopAutoPersisting(),i(),p)},0,u);return p},Va=(a,t,e,n,s,i,r,[o,c,[l,w,u]],d,E,N,g,A,T,p,O)=>{const[R,m,v,C]=za(t,d,E,s,A,T,p,O),I=(a,t)=>$(ta(c,async([e,n,s,i,r],o)=>{t&&!(o in a)||await v(e,n,a[o],s,i,t,r)})),L=async(a,t)=>w?await v(u,ra,{[ia]:a},!0,!0,t):null,_=qa(a,()=>C(async()=>{await R();const a=await(async()=>x(S(await $(ta(o,async([a,t,e],n)=>[a,await m(n,t,e)])),a=>!q(a[1]))))(),t=await(async()=>l?(await m(u,ra))[ia]:{})();return q(a)&&y(t)?void 0:[a,t]}),(a,t)=>C(async()=>{if(await R(),y(t)){const[t,e]=a();await I(t),await L(e)}else await I(t[0],!0),await L(t[1],!0)}),e,n,s,r,{[g]:()=>N,destroy:async()=>(await _.stopAutoPersisting(),i(),_)},0,N);return _},Qa=/^([cd]:)(.+)/,Za=(a,n,s,o,c,l,w,y,u,d,g="getDb")=>{const T=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,l),[p,,O,C]=(a=>{const e=(a=>W(Wa,N(a)?{[fa]:a}:a??{}))(a),n=e[Pa];if(e.mode==ba){const a=e[fa]??t;return[1,n,[a,e[Da]??ra,e[ha]??_a],Sa(a)]}const{tables:{load:s={},save:r={}}={},values:o={}}=e,c=A(Y(W(Ba,o)),0,k(Ba)),l=c[2],w=Sa(l),y=Sa(l),u=Ha(s,{[Ma]:null,[Fa]:ra,[xa]:i},Ma,a=>_(y,a),a=>Ia(w,a)),d=Ha(r,{[Ua]:null,[Fa]:ra,[Ga]:0,[ja]:0,[xa]:null},Ua,(a,t)=>_(y,t),(a,t)=>Ia(w,t));var E;return E=(a,t)=>t[4]??=aa(u,t[0])?.[2]??i,D(d,(a,t)=>E(0,a)),[0,n,[u,d,c],w]})(n),S=e+(a=>{let t=2166136261;return R(Q.encode(a),a=>{t^=a,t+=(t<<1)+(t<<4)+(t<<7)+(t<<8)+(t<<24)}),t>>>0})(K(O)),I=t+"_"+S,L=async(a,e,n="",s="")=>{const i=ma(t,a,S);return await T(Aa+$a+pa+i+`()RETURNS ${n}trigger AS $$ ${s}BEGIN ${e}END;$$ LANGUAGE plpgsql;`),i},b=async(a,t,e,n)=>(await T(Aa+a+"TRIGGER"+t+e+"EXECUTE "+pa+n+"()"),t),h=a=>`PERFORM pg_notify('${I}',${a});`,P=(a,t)=>p?i:2===t?P(a,0)+" OR "+P(a,1):r(aa(O[0],a)?.[2]??i,Oa,0==t?"NEW":"OLD"),F=(a,e)=>$(v([wa,ya,ua],(n,s)=>b($a,ma(t,"d",S,a,n),`AFTER ${n} ON${Ra(a)}FOR EACH ROW WHEN(${P(a,s)})`,e)));return(p?Ka:Va)(a,T,async a=>{const e=await L("c",`FOR row IN SELECT object_identity FROM pg_event_trigger_ddl_commands()${ca} command_tag='${Ta}' LOOP ${h("'c:'||SPLIT_PART(row.object_identity,'.',2)")}END LOOP;`,"event_","DECLARE row record;");await b("EVENT ",ma(t,"c",S),`ON ddl_command_end WHEN TAG IN('${Ta}')`,e);const n=await L("d",h("'d:'||TG_TABLE_NAME")+"RETURN NULL;");return await $(v(f(C),async a=>(await T(Ta+` IF NOT EXISTS${Ra(a)}("_id"text PRIMARY KEY)`),await F(a,n)))),[await o(I,t=>{return E((e=t,s=Qa,e?.match(s)),async([,t,e])=>{_(C,e)&&("c:"==t&&await F(e,n),a())});var e,s}),[e,n]]},async([a,t])=>{c(a),await T(`DROP FUNCTION IF EXISTS${m(t,",")}CASCADE`)},w,y,u,O,f(C),async(a,t)=>await a(oa+` table_name tn,column_name cn FROM information_schema.columns ${ca} table_schema='public'AND table_name IN(${va(t)})`,t),d,g,"text",void 0,a=>z(a),a=>J(a))},at=async(a,t,e,n,s)=>{const i=await(t.reserve?.());return Za(a,e,i?.unsafe,async(a,e)=>t.listen(a,e),a=>O(a.unlisten,s),n,s,()=>i?.release?.(),3,t,"getSql")};export{at as createPostgresPersister};