tinybase 7.0.0-beta.3 → 7.0.0

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 (261) hide show
  1. package/checkpoints/index.js +2 -5
  2. package/checkpoints/with-schemas/index.js +2 -5
  3. package/common/index.js +2 -5
  4. package/common/with-schemas/index.js +2 -5
  5. package/index.js +2 -4
  6. package/indexes/index.js +2 -5
  7. package/indexes/with-schemas/index.js +2 -5
  8. package/mergeable-store/index.js +2 -4
  9. package/mergeable-store/with-schemas/index.js +2 -4
  10. package/metrics/index.js +2 -5
  11. package/metrics/with-schemas/index.js +2 -5
  12. package/min/checkpoints/index.js +1 -1
  13. package/min/checkpoints/index.js.gz +0 -0
  14. package/min/checkpoints/with-schemas/index.js +1 -1
  15. package/min/checkpoints/with-schemas/index.js.gz +0 -0
  16. package/min/common/index.js +1 -1
  17. package/min/common/index.js.gz +0 -0
  18. package/min/common/with-schemas/index.js +1 -1
  19. package/min/common/with-schemas/index.js.gz +0 -0
  20. package/min/index.js +1 -1
  21. package/min/index.js.gz +0 -0
  22. package/min/indexes/index.js +1 -1
  23. package/min/indexes/index.js.gz +0 -0
  24. package/min/indexes/with-schemas/index.js +1 -1
  25. package/min/indexes/with-schemas/index.js.gz +0 -0
  26. package/min/mergeable-store/index.js +1 -1
  27. package/min/mergeable-store/index.js.gz +0 -0
  28. package/min/mergeable-store/with-schemas/index.js +1 -1
  29. package/min/mergeable-store/with-schemas/index.js.gz +0 -0
  30. package/min/metrics/index.js +1 -1
  31. package/min/metrics/index.js.gz +0 -0
  32. package/min/metrics/with-schemas/index.js +1 -1
  33. package/min/metrics/with-schemas/index.js.gz +0 -0
  34. package/min/omni/index.js +1 -1
  35. package/min/omni/index.js.gz +0 -0
  36. package/min/omni/with-schemas/index.js +1 -1
  37. package/min/omni/with-schemas/index.js.gz +0 -0
  38. package/min/persisters/index.js +1 -1
  39. package/min/persisters/index.js.gz +0 -0
  40. package/min/persisters/persister-automerge/index.js +1 -1
  41. package/min/persisters/persister-automerge/index.js.gz +0 -0
  42. package/min/persisters/persister-automerge/with-schemas/index.js +1 -1
  43. package/min/persisters/persister-automerge/with-schemas/index.js.gz +0 -0
  44. package/min/persisters/persister-browser/index.js +1 -1
  45. package/min/persisters/persister-browser/index.js.gz +0 -0
  46. package/min/persisters/persister-browser/with-schemas/index.js +1 -1
  47. package/min/persisters/persister-browser/with-schemas/index.js.gz +0 -0
  48. package/min/persisters/persister-cr-sqlite-wasm/index.js +1 -1
  49. package/min/persisters/persister-cr-sqlite-wasm/index.js.gz +0 -0
  50. package/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.js +1 -1
  51. package/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.js.gz +0 -0
  52. package/min/persisters/persister-durable-object-sql-storage/index.js +1 -1
  53. package/min/persisters/persister-durable-object-sql-storage/index.js.gz +0 -0
  54. package/min/persisters/persister-durable-object-sql-storage/with-schemas/index.js +1 -1
  55. package/min/persisters/persister-durable-object-sql-storage/with-schemas/index.js.gz +0 -0
  56. package/min/persisters/persister-durable-object-storage/index.js +1 -1
  57. package/min/persisters/persister-durable-object-storage/index.js.gz +0 -0
  58. package/min/persisters/persister-durable-object-storage/with-schemas/index.js +1 -1
  59. package/min/persisters/persister-durable-object-storage/with-schemas/index.js.gz +0 -0
  60. package/min/persisters/persister-electric-sql/index.js +1 -1
  61. package/min/persisters/persister-electric-sql/index.js.gz +0 -0
  62. package/min/persisters/persister-electric-sql/with-schemas/index.js +1 -1
  63. package/min/persisters/persister-electric-sql/with-schemas/index.js.gz +0 -0
  64. package/min/persisters/persister-expo-sqlite/index.js +1 -1
  65. package/min/persisters/persister-expo-sqlite/index.js.gz +0 -0
  66. package/min/persisters/persister-expo-sqlite/with-schemas/index.js +1 -1
  67. package/min/persisters/persister-expo-sqlite/with-schemas/index.js.gz +0 -0
  68. package/min/persisters/persister-file/index.js +1 -1
  69. package/min/persisters/persister-file/index.js.gz +0 -0
  70. package/min/persisters/persister-file/with-schemas/index.js +1 -1
  71. package/min/persisters/persister-file/with-schemas/index.js.gz +0 -0
  72. package/min/persisters/persister-indexed-db/index.js +1 -1
  73. package/min/persisters/persister-indexed-db/index.js.gz +0 -0
  74. package/min/persisters/persister-indexed-db/with-schemas/index.js +1 -1
  75. package/min/persisters/persister-indexed-db/with-schemas/index.js.gz +0 -0
  76. package/min/persisters/persister-libsql/index.js +1 -1
  77. package/min/persisters/persister-libsql/index.js.gz +0 -0
  78. package/min/persisters/persister-libsql/with-schemas/index.js +1 -1
  79. package/min/persisters/persister-libsql/with-schemas/index.js.gz +0 -0
  80. package/min/persisters/persister-partykit-client/index.js +1 -1
  81. package/min/persisters/persister-partykit-client/index.js.gz +0 -0
  82. package/min/persisters/persister-partykit-client/with-schemas/index.js +1 -1
  83. package/min/persisters/persister-partykit-client/with-schemas/index.js.gz +0 -0
  84. package/min/persisters/persister-partykit-server/index.js +1 -1
  85. package/min/persisters/persister-partykit-server/index.js.gz +0 -0
  86. package/min/persisters/persister-partykit-server/with-schemas/index.js +1 -1
  87. package/min/persisters/persister-partykit-server/with-schemas/index.js.gz +0 -0
  88. package/min/persisters/persister-pglite/index.js +1 -1
  89. package/min/persisters/persister-pglite/index.js.gz +0 -0
  90. package/min/persisters/persister-pglite/with-schemas/index.js +1 -1
  91. package/min/persisters/persister-pglite/with-schemas/index.js.gz +0 -0
  92. package/min/persisters/persister-postgres/index.js +1 -1
  93. package/min/persisters/persister-postgres/index.js.gz +0 -0
  94. package/min/persisters/persister-postgres/with-schemas/index.js +1 -1
  95. package/min/persisters/persister-postgres/with-schemas/index.js.gz +0 -0
  96. package/min/persisters/persister-powersync/index.js +1 -1
  97. package/min/persisters/persister-powersync/index.js.gz +0 -0
  98. package/min/persisters/persister-powersync/with-schemas/index.js +1 -1
  99. package/min/persisters/persister-powersync/with-schemas/index.js.gz +0 -0
  100. package/min/persisters/persister-react-native-mmkv/index.js +1 -1
  101. package/min/persisters/persister-react-native-mmkv/index.js.gz +0 -0
  102. package/min/persisters/persister-react-native-mmkv/with-schemas/index.js +1 -1
  103. package/min/persisters/persister-react-native-mmkv/with-schemas/index.js.gz +0 -0
  104. package/min/persisters/persister-react-native-sqlite/index.js +1 -1
  105. package/min/persisters/persister-react-native-sqlite/index.js.gz +0 -0
  106. package/min/persisters/persister-react-native-sqlite/with-schemas/index.js +1 -1
  107. package/min/persisters/persister-react-native-sqlite/with-schemas/index.js.gz +0 -0
  108. package/min/persisters/persister-remote/index.js +1 -1
  109. package/min/persisters/persister-remote/index.js.gz +0 -0
  110. package/min/persisters/persister-remote/with-schemas/index.js +1 -1
  111. package/min/persisters/persister-remote/with-schemas/index.js.gz +0 -0
  112. package/min/persisters/persister-sqlite-bun/index.js +1 -1
  113. package/min/persisters/persister-sqlite-bun/index.js.gz +0 -0
  114. package/min/persisters/persister-sqlite-bun/with-schemas/index.js +1 -1
  115. package/min/persisters/persister-sqlite-bun/with-schemas/index.js.gz +0 -0
  116. package/min/persisters/persister-sqlite-wasm/index.js +1 -1
  117. package/min/persisters/persister-sqlite-wasm/index.js.gz +0 -0
  118. package/min/persisters/persister-sqlite-wasm/with-schemas/index.js +1 -1
  119. package/min/persisters/persister-sqlite-wasm/with-schemas/index.js.gz +0 -0
  120. package/min/persisters/persister-sqlite3/index.js +1 -1
  121. package/min/persisters/persister-sqlite3/index.js.gz +0 -0
  122. package/min/persisters/persister-sqlite3/with-schemas/index.js +1 -1
  123. package/min/persisters/persister-sqlite3/with-schemas/index.js.gz +0 -0
  124. package/min/persisters/persister-yjs/index.js +1 -1
  125. package/min/persisters/persister-yjs/index.js.gz +0 -0
  126. package/min/persisters/persister-yjs/with-schemas/index.js +1 -1
  127. package/min/persisters/persister-yjs/with-schemas/index.js.gz +0 -0
  128. package/min/persisters/with-schemas/index.js +1 -1
  129. package/min/persisters/with-schemas/index.js.gz +0 -0
  130. package/min/queries/index.js +1 -1
  131. package/min/queries/index.js.gz +0 -0
  132. package/min/queries/with-schemas/index.js +1 -1
  133. package/min/queries/with-schemas/index.js.gz +0 -0
  134. package/min/relationships/index.js +1 -1
  135. package/min/relationships/index.js.gz +0 -0
  136. package/min/relationships/with-schemas/index.js +1 -1
  137. package/min/relationships/with-schemas/index.js.gz +0 -0
  138. package/min/store/index.js +1 -1
  139. package/min/store/index.js.gz +0 -0
  140. package/min/store/with-schemas/index.js +1 -1
  141. package/min/store/with-schemas/index.js.gz +0 -0
  142. package/min/synchronizers/index.js +1 -1
  143. package/min/synchronizers/index.js.gz +0 -0
  144. package/min/synchronizers/synchronizer-broadcast-channel/index.js +1 -1
  145. package/min/synchronizers/synchronizer-broadcast-channel/index.js.gz +0 -0
  146. package/min/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js +1 -1
  147. package/min/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js.gz +0 -0
  148. package/min/synchronizers/synchronizer-local/index.js +1 -1
  149. package/min/synchronizers/synchronizer-local/index.js.gz +0 -0
  150. package/min/synchronizers/synchronizer-local/with-schemas/index.js +1 -1
  151. package/min/synchronizers/synchronizer-local/with-schemas/index.js.gz +0 -0
  152. package/min/synchronizers/synchronizer-ws-client/index.js +1 -1
  153. package/min/synchronizers/synchronizer-ws-client/index.js.gz +0 -0
  154. package/min/synchronizers/synchronizer-ws-client/with-schemas/index.js +1 -1
  155. package/min/synchronizers/synchronizer-ws-client/with-schemas/index.js.gz +0 -0
  156. package/min/synchronizers/synchronizer-ws-server/index.js +1 -1
  157. package/min/synchronizers/synchronizer-ws-server/index.js.gz +0 -0
  158. package/min/synchronizers/synchronizer-ws-server/with-schemas/index.js +1 -1
  159. package/min/synchronizers/synchronizer-ws-server/with-schemas/index.js.gz +0 -0
  160. package/min/synchronizers/synchronizer-ws-server-durable-object/index.js +1 -1
  161. package/min/synchronizers/synchronizer-ws-server-durable-object/index.js.gz +0 -0
  162. package/min/synchronizers/synchronizer-ws-server-durable-object/with-schemas/index.js +1 -1
  163. package/min/synchronizers/synchronizer-ws-server-durable-object/with-schemas/index.js.gz +0 -0
  164. package/min/synchronizers/synchronizer-ws-server-simple/index.js +1 -1
  165. package/min/synchronizers/synchronizer-ws-server-simple/index.js.gz +0 -0
  166. package/min/synchronizers/synchronizer-ws-server-simple/with-schemas/index.js +1 -1
  167. package/min/synchronizers/synchronizer-ws-server-simple/with-schemas/index.js.gz +0 -0
  168. package/min/synchronizers/with-schemas/index.js +1 -1
  169. package/min/synchronizers/with-schemas/index.js.gz +0 -0
  170. package/min/ui-react/index.js +1 -1
  171. package/min/ui-react/index.js.gz +0 -0
  172. package/min/ui-react/with-schemas/index.js +1 -1
  173. package/min/ui-react/with-schemas/index.js.gz +0 -0
  174. package/min/ui-react-dom/index.js +1 -1
  175. package/min/ui-react-dom/index.js.gz +0 -0
  176. package/min/ui-react-dom/with-schemas/index.js +1 -1
  177. package/min/ui-react-dom/with-schemas/index.js.gz +0 -0
  178. package/min/ui-react-inspector/index.js +1 -1
  179. package/min/ui-react-inspector/index.js.gz +0 -0
  180. package/min/ui-react-inspector/with-schemas/index.js +1 -1
  181. package/min/ui-react-inspector/with-schemas/index.js.gz +0 -0
  182. package/min/with-schemas/index.js +1 -1
  183. package/min/with-schemas/index.js.gz +0 -0
  184. package/omni/index.js +2 -4
  185. package/omni/with-schemas/index.js +2 -4
  186. package/package.json +2 -2
  187. package/persisters/index.js +2 -4
  188. package/persisters/persister-automerge/index.js +2 -4
  189. package/persisters/persister-automerge/with-schemas/index.js +2 -4
  190. package/persisters/persister-browser/index.js +2 -4
  191. package/persisters/persister-browser/with-schemas/index.js +2 -4
  192. package/persisters/persister-cr-sqlite-wasm/index.js +2 -4
  193. package/persisters/persister-cr-sqlite-wasm/with-schemas/index.js +2 -4
  194. package/persisters/persister-durable-object-sql-storage/index.js +2 -4
  195. package/persisters/persister-durable-object-sql-storage/with-schemas/index.js +2 -4
  196. package/persisters/persister-durable-object-storage/index.js +2 -4
  197. package/persisters/persister-durable-object-storage/with-schemas/index.js +2 -4
  198. package/persisters/persister-electric-sql/index.js +2 -4
  199. package/persisters/persister-electric-sql/with-schemas/index.js +2 -4
  200. package/persisters/persister-expo-sqlite/index.js +2 -4
  201. package/persisters/persister-expo-sqlite/with-schemas/index.js +2 -4
  202. package/persisters/persister-file/index.js +2 -4
  203. package/persisters/persister-file/with-schemas/index.js +2 -4
  204. package/persisters/persister-indexed-db/index.js +2 -4
  205. package/persisters/persister-indexed-db/with-schemas/index.js +2 -4
  206. package/persisters/persister-libsql/index.js +2 -4
  207. package/persisters/persister-libsql/with-schemas/index.js +2 -4
  208. package/persisters/persister-partykit-client/index.js +2 -4
  209. package/persisters/persister-partykit-client/with-schemas/index.js +2 -4
  210. package/persisters/persister-partykit-server/index.js +2 -5
  211. package/persisters/persister-partykit-server/with-schemas/index.js +2 -5
  212. package/persisters/persister-pglite/index.js +2 -4
  213. package/persisters/persister-pglite/with-schemas/index.js +2 -4
  214. package/persisters/persister-postgres/index.js +2 -4
  215. package/persisters/persister-postgres/with-schemas/index.js +2 -4
  216. package/persisters/persister-powersync/index.js +2 -4
  217. package/persisters/persister-powersync/with-schemas/index.js +2 -4
  218. package/persisters/persister-react-native-mmkv/index.js +2 -4
  219. package/persisters/persister-react-native-mmkv/with-schemas/index.js +2 -4
  220. package/persisters/persister-react-native-sqlite/index.js +2 -4
  221. package/persisters/persister-react-native-sqlite/with-schemas/index.js +2 -4
  222. package/persisters/persister-remote/index.js +2 -4
  223. package/persisters/persister-remote/with-schemas/index.js +2 -4
  224. package/persisters/persister-sqlite-bun/index.js +2 -4
  225. package/persisters/persister-sqlite-bun/with-schemas/index.js +2 -4
  226. package/persisters/persister-sqlite-wasm/index.js +2 -4
  227. package/persisters/persister-sqlite-wasm/with-schemas/index.js +2 -4
  228. package/persisters/persister-sqlite3/index.js +2 -4
  229. package/persisters/persister-sqlite3/with-schemas/index.js +2 -4
  230. package/persisters/persister-yjs/index.js +2 -4
  231. package/persisters/persister-yjs/with-schemas/index.js +2 -4
  232. package/persisters/with-schemas/index.js +2 -4
  233. package/queries/index.js +2 -5
  234. package/queries/with-schemas/index.js +2 -5
  235. package/readme.md +13 -13
  236. package/relationships/index.js +2 -5
  237. package/relationships/with-schemas/index.js +2 -5
  238. package/releases.md +38 -38
  239. package/store/index.js +2 -4
  240. package/store/with-schemas/index.js +2 -4
  241. package/synchronizers/index.js +2 -4
  242. package/synchronizers/synchronizer-broadcast-channel/index.js +2 -4
  243. package/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js +2 -4
  244. package/synchronizers/synchronizer-local/index.js +2 -4
  245. package/synchronizers/synchronizer-local/with-schemas/index.js +2 -4
  246. package/synchronizers/synchronizer-ws-client/index.js +2 -4
  247. package/synchronizers/synchronizer-ws-client/with-schemas/index.js +2 -4
  248. package/synchronizers/synchronizer-ws-server/index.js +2 -4
  249. package/synchronizers/synchronizer-ws-server/with-schemas/index.js +2 -4
  250. package/synchronizers/synchronizer-ws-server-durable-object/index.js +2 -4
  251. package/synchronizers/synchronizer-ws-server-durable-object/with-schemas/index.js +2 -4
  252. package/synchronizers/synchronizer-ws-server-simple/index.js +2 -5
  253. package/synchronizers/synchronizer-ws-server-simple/with-schemas/index.js +2 -5
  254. package/synchronizers/with-schemas/index.js +2 -4
  255. package/ui-react/index.js +2 -4
  256. package/ui-react/with-schemas/index.js +2 -4
  257. package/ui-react-dom/index.js +2 -4
  258. package/ui-react-dom/with-schemas/index.js +2 -4
  259. package/ui-react-inspector/index.js +2 -4
  260. package/ui-react-inspector/with-schemas/index.js +2 -4
  261. package/with-schemas/index.js +2 -4
@@ -1 +1 @@
1
- const t=(t=e)=>(e,a,n)=>t(e)?n?.():a(e),e=t=>null==t,a=t=>void 0===t,n=t(e),s=t(a),r=t=>Array.isArray(t),o=t=>t.length,i=t=>{throw Error(t)},c=async(t,e,a)=>{try{return await t()}catch(t){e?.(t)}},u=(t,e)=>t.forEach(e),d=(t,...e)=>t.push(...e),l=t=>t.shift(),y=Object,g=t=>y.getPrototypeOf(t),w=y.entries,v=y.keys,h=y.freeze,p=(t=[])=>y.fromEntries(t),f=(t,e)=>s(t,t=>t[e]),C=(t,e)=>e in t,A=(t,e)=>(delete t[e],t),S=(t,e)=>p(((t,e)=>((t,e)=>t.map(e))(w(t),([t,a])=>e(a,t)))(t,(t,a)=>[a,e(t,a)])),b=t=>o(v(t)),L=t=>(t=>!e(t)&&n(g(t),t=>t==y.prototype||e(g(t)),()=>!0))(t)&&0==b(t),M=(t,e,a)=>(C(t,e)||(t[e]=a()),t[e]),E=t=>a(t)||0==(t=>t?.size??0)(t),P=(t,e)=>t?.forEach(e),m=(t,e)=>t?.delete(e),D=t=>new Map(t),T=(t,e)=>t?.get(e),z=(t,e,a)=>void 0===a?(m(t,e),t):t?.set(e,a),O=(t,e,a,n)=>{var s,r;return s=t,r=e,s?.has(r)?n?.(T(t,e)):z(t,e,a()),T(t,e)},j=(t,e,a,n,r=0)=>s((a?O:T)(t,e[r],r>o(e)-2?a:D),s=>{if(r>o(e)-2)return n?.(s)&&z(t,e[r]),s;const i=j(s,e,a,n,r+1);return E(s)&&z(t,e[r]),i}),k=/^\d+$/,x=t=>new Set(r(t)||a(t)?t:[t]),F=D(),H=D(),$=(t,e,n,y,g,w,v,p={},f=0,C=[])=>{let A,S,b,M=0,$=0,q=0;O(F,C,()=>0),O(H,C,()=>[]);const B=D(),[G,I,J,K,N]=((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]:i("Store type not supported by this Persister"))(v,t,f),[Q,R,U]=(()=>{let t;const[e,a]=(()=>{const t=[];let e=0;return[a=>(a?l(t):null)??""+e++,e=>{k.test(e)&&o(t)<1e3&&d(t,e)}]})(),n=D();return[(a,s,r,o=[],i=()=>[])=>{t??=st;const c=e(1);var u,d;return z(n,c,[a,s,r,o,i]),u=j(s,r??[""],x),d=c,u?.add(d),c},(e,a,...s)=>u(((t,e=[""])=>{const a=[],n=(t,s)=>s==o(e)?d(a,t):null===e[s]?P(t,t=>n(t,s+1)):u([e[s],null],e=>n(T(t,e),s+1));return n(t,0),a})(e,a),e=>P(e,e=>T(n,e)[0](t,...a??[],...s))),t=>s(T(n,t),([,e,s])=>(j(e,s??[""],void 0,e=>(m(e,t),E(e)?1:0)),z(n,t),a(t),s)),e=>s(T(n,e),([e,,a=[],n,s])=>{const r=(...i)=>{const c=o(i);c==o(a)?e(t,...i,...s(i)):(t=>null===t)(a[c])?u(n[c]?.(...i)??[],t=>r(...i,t)):r(...i,a[c])};r()})]})(),V=t=>{t!=M&&(M=t,R(B,void 0,M))},W=e=>{(G&&r(e?.[0])?1===e?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===e?.[2]?t.applyChanges:t.setContent)(e)},X=async t=>(2!=M&&(V(1),$++,await nt(async()=>{await c(async()=>{const a=await e();r(a)?W(a):t?N(t):i("Content is not an array: "+a)},()=>{t&&N(t)}),V(0)})),st),Y=async t=>(Z(),await X(t),await c(async()=>S=await y(async(t,e)=>{e||t?2!=M&&(V(1),$++,W(e??t),V(0)):await X()}),w),st),Z=async()=>(S&&(await c(()=>g(S),w),S=void 0),st),_=async t=>(1!=M&&(V(2),q++,await nt(async()=>{await c(()=>n(I,t),w),V(0)})),st),tt=async()=>(et(),await _(),b=t.addDidFinishTransactionListener(()=>{const t=J();K(t)&&_(t)}),st),et=async()=>(b&&(t.delListener(b),b=void 0),st),at=async(t=!1)=>{const[e,a]=t?[et,Z]:[Z,et];return await e(),await a(),st},nt=async(...t)=>(d(T(H,C),...t),await(async()=>{if(!T(F,C)){for(z(F,C,1);!a(A=l(T(H,C)));)await c(A,w);z(F,C,0)}})(),st),st={load:X,startAutoLoad:Y,stopAutoLoad:Z,isAutoLoading:()=>!a(S),save:_,startAutoSave:tt,stopAutoSave:et,isAutoSaving:()=>!a(b),startAutoPersisting:async(t,e=!1)=>{const[a,n]=e?[tt,Y]:[Y,tt];return await a(t),await n(t),st},stopAutoPersisting:at,getStatus:()=>M,addStatusListener:t=>Q(t,B),delListener:e=>(U(e),t),schedule:nt,getStore:()=>t,destroy:()=>(T(H,C).splice(0,void 0),at()),getStats:()=>({loads:$,saves:q}),...p};return h(st)},q=(t,e)=>[t[e].t,t[e].v],B=(t,e,n,s)=>{const r=a(e)?t:M(t,e,()=>({}));let o;return S(n,(t,e)=>{s(r,e,t)&&(o=1)}),S(r,(t,e)=>{C(n,e)||(A(r,e),o=1)}),!a(e)&&L(r)&&A(t,e),o},G=(t,e,n="tinybase",r)=>(e.change(t=>M(t,n,p)),$(t,async()=>{const t=e.doc();return 2==b(t?.[n])?q(t,n):void 0},async(t,r)=>e.change(e=>((t,e,n,r)=>{((t,e)=>{L(t[e])&&(t[e]={t:{},v:{}})})(t,e);const[o,i]=q(t,e),c=()=>{u=1};let u=1;if(s(r,([t,e])=>{u=0,S(t,(t,e)=>u?0:a(t)?A(o,e):s(o[e],e=>S(t,(t,n)=>u?0:a(t)?A(e,n):s(f(e,n),e=>S(t,(t,n)=>a(t)?A(e,n):e[n]=t),c)),c)),S(e,(t,e)=>u?0:a(t)?A(i,e):i[e]=t)}),u){const[t,e]=n();B(o,void 0,t,(t,e,a)=>B(o,e,a,(t,e,a)=>B(t,e,a,(t,e,a)=>{if(f(t,e)!==a)return t[e]=a,1}))),B(i,void 0,e,(t,e,a)=>{f(i,e)!==a&&(i[e]=a)})}})(e,n,t,r)),t=>{const a=({doc:e})=>t(q(e,n));return e.on("change",a),a},t=>{e.removeListener("change",t)},r,1,{getDocHandle:()=>e}));export{G as createAutomergePersister};
1
+ const t=t=>(e,a,n)=>t(e)?n?.():a(e),e=t=>null==t,a=t=>void 0===t,n=t(e),s=t(a),r=t=>Array.isArray(t),o=t=>t.length,i=t=>{throw Error(t)},c=async(t,e,a)=>{try{return await t()}catch(t){e?.(t)}},u=(t,e)=>t.forEach(e),d=(t,...e)=>t.push(...e),l=t=>t.shift(),y=Object,g=t=>y.getPrototypeOf(t),w=y.entries,v=y.keys,h=y.freeze,p=(t=[])=>y.fromEntries(t),f=(t,e)=>s(t,t=>t[e]),C=(t,e)=>e in t,A=(t,e)=>(delete t[e],t),S=(t,e)=>p(((t,e)=>((t,e)=>t.map(e))(w(t),([t,a])=>e(a,t)))(t,(t,a)=>[a,e(t,a)])),b=t=>o(v(t)),L=t=>(t=>!e(t)&&n(g(t),t=>t==y.prototype||e(g(t)),()=>!0))(t)&&0==b(t),M=(t,e,a)=>(C(t,e)||(t[e]=a()),t[e]),E=t=>a(t)||0==(t=>t?.size??0)(t),P=(t,e)=>t?.forEach(e),m=(t,e)=>t?.delete(e),D=t=>new Map(t),T=(t,e)=>t?.get(e),z=(t,e,a)=>void 0===a?(m(t,e),t):t?.set(e,a),O=(t,e,a,n)=>{var s,r;return s=t,r=e,s?.has(r)?n?.(T(t,e)):z(t,e,a()),T(t,e)},j=(t,e,a,n,r=0)=>s((a?O:T)(t,e[r],r>o(e)-2?a:D),s=>{if(r>o(e)-2)return n?.(s)&&z(t,e[r]),s;const i=j(s,e,a,n,r+1);return E(s)&&z(t,e[r]),i}),k=/^\d+$/,x=t=>new Set(r(t)||a(t)?t:[t]),F=D(),H=D(),$=(t,e,n,y,g,w,v,p={},f=0,C=[])=>{let A,S,b,M=0,$=0,q=0;O(F,C,()=>0),O(H,C,()=>[]);const B=D(),[G,I,J,K,N]=((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]:i("Store type not supported by this Persister"))(v,t,f),[Q,R,U]=(()=>{let t;const[e,a]=(()=>{const t=[];let e=0;return[a=>(a?l(t):null)??""+e++,e=>{k.test(e)&&o(t)<1e3&&d(t,e)}]})(),n=D();return[(a,s,r,o=[],i=()=>[])=>{t??=st;const c=e(1);var u,d;return z(n,c,[a,s,r,o,i]),u=j(s,r??[""],x),d=c,u?.add(d),c},(e,a,...s)=>u(((t,e=[""])=>{const a=[],n=(t,s)=>s==o(e)?d(a,t):null===e[s]?P(t,t=>n(t,s+1)):u([e[s],null],e=>n(T(t,e),s+1));return n(t,0),a})(e,a),e=>P(e,e=>T(n,e)[0](t,...a??[],...s))),t=>s(T(n,t),([,e,s])=>(j(e,s??[""],void 0,e=>(m(e,t),E(e)?1:0)),z(n,t),a(t),s)),e=>s(T(n,e),([e,,a=[],n,s])=>{const r=(...i)=>{const c=o(i);c==o(a)?e(t,...i,...s(i)):(t=>null===t)(a[c])?u(n[c]?.(...i)??[],t=>r(...i,t)):r(...i,a[c])};r()})]})(),V=t=>{t!=M&&(M=t,R(B,void 0,M))},W=e=>{(G&&r(e?.[0])?1===e?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===e?.[2]?t.applyChanges:t.setContent)(e)},X=async t=>(2!=M&&(V(1),$++,await nt(async()=>{await c(async()=>{const a=await e();r(a)?W(a):t?N(t):i("Content is not an array: "+a)},()=>{t&&N(t)}),V(0)})),st),Y=async t=>(Z(),await X(t),await c(async()=>S=await y(async(t,e)=>{e||t?2!=M&&(V(1),$++,W(e??t),V(0)):await X()}),w),st),Z=async()=>(S&&(await c(()=>g(S),w),S=void 0),st),_=async t=>(1!=M&&(V(2),q++,await nt(async()=>{await c(()=>n(I,t),w),V(0)})),st),tt=async()=>(et(),await _(),b=t.addDidFinishTransactionListener(()=>{const t=J();K(t)&&_(t)}),st),et=async()=>(b&&(t.delListener(b),b=void 0),st),at=async(t=!1)=>{const[e,a]=t?[et,Z]:[Z,et];return await e(),await a(),st},nt=async(...t)=>(d(T(H,C),...t),await(async()=>{if(!T(F,C)){for(z(F,C,1);!a(A=l(T(H,C)));)await c(A,w);z(F,C,0)}})(),st),st={load:X,startAutoLoad:Y,stopAutoLoad:Z,isAutoLoading:()=>!a(S),save:_,startAutoSave:tt,stopAutoSave:et,isAutoSaving:()=>!a(b),startAutoPersisting:async(t,e=!1)=>{const[a,n]=e?[tt,Y]:[Y,tt];return await a(t),await n(t),st},stopAutoPersisting:at,getStatus:()=>M,addStatusListener:t=>Q(t,B),delListener:e=>(U(e),t),schedule:nt,getStore:()=>t,destroy:()=>(T(H,C).splice(0,void 0),at()),getStats:()=>({loads:$,saves:q}),...p};return h(st)},q=(t,e)=>[t[e].t,t[e].v],B=(t,e,n,s)=>{const r=a(e)?t:M(t,e,()=>({}));let o;return S(n,(t,e)=>{s(r,e,t)&&(o=1)}),S(r,(t,e)=>{C(n,e)||(A(r,e),o=1)}),!a(e)&&L(r)&&A(t,e),o},G=(t,e,n="tinybase",r)=>(e.change(t=>M(t,n,p)),$(t,async()=>{const t=e.doc();return 2==b(t?.[n])?q(t,n):void 0},async(t,r)=>e.change(e=>((t,e,n,r)=>{((t,e)=>{L(t[e])&&(t[e]={t:{},v:{}})})(t,e);const[o,i]=q(t,e),c=()=>{u=1};let u=1;if(s(r,([t,e])=>{u=0,S(t,(t,e)=>u?0:a(t)?A(o,e):s(o[e],e=>S(t,(t,n)=>u?0:a(t)?A(e,n):s(f(e,n),e=>S(t,(t,n)=>a(t)?A(e,n):e[n]=t),c)),c)),S(e,(t,e)=>u?0:a(t)?A(i,e):i[e]=t)}),u){const[t,e]=n();B(o,void 0,t,(t,e,a)=>B(o,e,a,(t,e,a)=>B(t,e,a,(t,e,a)=>{if(f(t,e)!==a)return t[e]=a,1}))),B(i,void 0,e,(t,e,a)=>{f(i,e)!==a&&(i[e]=a)})}})(e,n,t,r)),t=>{const a=({doc:e})=>t(q(e,n));return e.on("change",a),a},t=>{e.removeListener("change",t)},r,1,{getDocHandle:()=>e}));export{G as createAutomergePersister};
@@ -1 +1 @@
1
- const t=(t=a)=>(e,a,n)=>t(e)?n?.():a(e),e=globalThis.window,a=t=>null==t,n=t=>void 0===t,s=t(a),r=t(n),o=t=>Array.isArray(t),i=t=>t.length,c=t=>{throw Error(t)},l=async(t,e,a)=>{try{return await t()}catch(t){e?.(t)}},y=(t,e)=>t.forEach(e),g=(t,...e)=>t.push(...e),d=t=>t.shift(),u=Object,w=t=>u.getPrototypeOf(t),v=u.keys,p=u.freeze,h=t=>(t=>!a(t)&&s(w(t),t=>t==u.prototype||a(w(t)),()=>!0))(t)&&0==(t=>i(v(t)))(t),S=JSON.stringify,b=JSON.parse,A=t=>S(t,(t,e)=>void 0===e?"":e),C=t=>b(t,(t,e)=>""===e?void 0:e),f=t=>n(t)||0==(t=>t?.size??0)(t),L=(t,e)=>t?.forEach(e),M=(t,e)=>t?.delete(e),m=t=>new Map(t),E=(t,e)=>t?.get(e),O=(t,e,a)=>void 0===a?(M(t,e),t):t?.set(e,a),P=(t,e,a,n)=>{var s,r;return s=t,r=e,s?.has(r)?n?.(E(t,e)):O(t,e,a()),E(t,e)},T=(t,e,a,n,s=0)=>r((a?P:E)(t,e[s],s>i(e)-2?a:m),r=>{if(s>i(e)-2)return n?.(r)&&O(t,e[s]),r;const o=T(r,e,a,n,s+1);return f(r)&&O(t,e[s]),o}),F=/^\d+$/,N=t=>new Set(o(t)||n(t)?t:[t]),k=m(),x=m(),z=(t,e,a,s,u,w,v,S={},b=0,A=[])=>{let C,z,D,I=0,J=0,j=0;P(k,A,()=>0),P(x,A,()=>[]);const H=m(),[V,W,$,q,B]=((t=1,e,a)=>1!=t&&e.isMergeable()?[1,e.getMergeableContent,()=>e.getTransactionMergeableChanges(!a),([[t],[e]])=>!h(t)||!h(e),e.setDefaultContent]:2!=t?[0,e.getContent,e.getTransactionChanges,([t,e])=>!h(t)||!h(e),e.setContent]:c("Store type not supported by this Persister"))(v,t,b),[G,K,Q]=(()=>{let t;const[e,a]=(()=>{const t=[];let e=0;return[a=>(a?d(t):null)??""+e++,e=>{F.test(e)&&i(t)<1e3&&g(t,e)}]})(),n=m();return[(a,s,r,o=[],i=()=>[])=>{t??=st;const c=e(1);var l,y;return O(n,c,[a,s,r,o,i]),l=T(s,r??[""],N),y=c,l?.add(y),c},(e,a,...s)=>y(((t,e=[""])=>{const a=[],n=(t,s)=>s==i(e)?g(a,t):null===e[s]?L(t,t=>n(t,s+1)):y([e[s],null],e=>n(E(t,e),s+1));return n(t,0),a})(e,a),e=>L(e,e=>E(n,e)[0](t,...a??[],...s))),t=>r(E(n,t),([,e,s])=>(T(e,s??[""],void 0,e=>(M(e,t),f(e)?1:0)),O(n,t),a(t),s)),e=>r(E(n,e),([e,,a=[],n,s])=>{const r=(...o)=>{const c=i(o);c==i(a)?e(t,...o,...s(o)):(t=>null===t)(a[c])?y(n[c]?.(...o)??[],t=>r(...o,t)):r(...o,a[c])};r()})]})(),R=t=>{t!=I&&(I=t,K(H,void 0,I))},U=e=>{(V&&o(e?.[0])?1===e?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===e?.[2]?t.applyChanges:t.setContent)(e)},X=async t=>(2!=I&&(R(1),J++,await nt(async()=>{await l(async()=>{const a=await e();o(a)?U(a):t?B(t):c("Content is not an array: "+a)},()=>{t&&B(t)}),R(0)})),st),Y=async t=>(Z(),await X(t),await l(async()=>z=await s(async(t,e)=>{e||t?2!=I&&(R(1),J++,U(e??t),R(0)):await X()}),w),st),Z=async()=>(z&&(await l(()=>u(z),w),z=void 0),st),_=async t=>(1!=I&&(R(2),j++,await nt(async()=>{await l(()=>a(W,t),w),R(0)})),st),tt=async()=>(et(),await _(),D=t.addDidFinishTransactionListener(()=>{const t=$();q(t)&&_(t)}),st),et=async()=>(D&&(t.delListener(D),D=void 0),st),at=async(t=!1)=>{const[e,a]=t?[et,Z]:[Z,et];return await e(),await a(),st},nt=async(...t)=>(g(E(x,A),...t),await(async()=>{if(!E(k,A)){for(O(k,A,1);!n(C=d(E(x,A)));)await l(C,w);O(k,A,0)}})(),st),st={load:X,startAutoLoad:Y,stopAutoLoad:Z,isAutoLoading:()=>!n(z),save:_,startAutoSave:tt,stopAutoSave:et,isAutoSaving:()=>!n(D),startAutoPersisting:async(t,e=!1)=>{const[a,n]=e?[tt,Y]:[Y,tt];return await a(t),await n(t),st},stopAutoPersisting:at,getStatus:()=>I,addStatusListener:t=>G(t,H),delListener:e=>(Q(e),t),schedule:nt,getStore:()=>t,destroy:()=>(E(x,A).splice(0,void 0),at()),getStats:()=>({loads:J,saves:j}),...S};return p(st)},D="storage",I=(t,a,n,s)=>z(t,async()=>C(n.getItem(a)),async t=>n.setItem(a,A(t())),t=>{const s=e=>{e.storageArea===n&&e.key===a&&l(()=>t(C(e.newValue)),t)};return e.addEventListener(D,s),s},t=>e.removeEventListener(D,t),s,3,{getStorageName:()=>a}),J=(t,e,a)=>I(t,e,localStorage,a),j=(t,e,a)=>I(t,e,sessionStorage,a),H=(t,e,a)=>z(t,async()=>C(await(await e.getFile()).text()),async t=>{const a=await e.createWritable();await a.write(A(t())),await a.close()},async t=>{const a=new FileSystemObserver(()=>t());return await a.observe(e),a},t=>t?.disconnect(),a,3,{getHandle:()=>e});export{J as createLocalPersister,H as createOpfsPersister,j as createSessionPersister};
1
+ const t=t=>(e,a,n)=>t(e)?n?.():a(e),e=globalThis.window,a=t=>null==t,n=t=>void 0===t,s=t(a),r=t(n),o=t=>Array.isArray(t),i=t=>t.length,c=t=>{throw Error(t)},l=async(t,e,a)=>{try{return await t()}catch(t){e?.(t)}},y=(t,e)=>t.forEach(e),g=(t,...e)=>t.push(...e),d=t=>t.shift(),u=Object,w=t=>u.getPrototypeOf(t),v=u.keys,p=u.freeze,h=t=>(t=>!a(t)&&s(w(t),t=>t==u.prototype||a(w(t)),()=>!0))(t)&&0==(t=>i(v(t)))(t),S=JSON.stringify,b=JSON.parse,A=t=>S(t,(t,e)=>void 0===e?"":e),C=t=>b(t,(t,e)=>""===e?void 0:e),f=t=>n(t)||0==(t=>t?.size??0)(t),L=(t,e)=>t?.forEach(e),M=(t,e)=>t?.delete(e),m=t=>new Map(t),E=(t,e)=>t?.get(e),O=(t,e,a)=>void 0===a?(M(t,e),t):t?.set(e,a),P=(t,e,a,n)=>{var s,r;return s=t,r=e,s?.has(r)?n?.(E(t,e)):O(t,e,a()),E(t,e)},T=(t,e,a,n,s=0)=>r((a?P:E)(t,e[s],s>i(e)-2?a:m),r=>{if(s>i(e)-2)return n?.(r)&&O(t,e[s]),r;const o=T(r,e,a,n,s+1);return f(r)&&O(t,e[s]),o}),F=/^\d+$/,N=t=>new Set(o(t)||n(t)?t:[t]),k=m(),x=m(),z=(t,e,a,s,u,w,v,S={},b=0,A=[])=>{let C,z,D,I=0,J=0,j=0;P(k,A,()=>0),P(x,A,()=>[]);const H=m(),[V,W,$,q,B]=((t=1,e,a)=>1!=t&&e.isMergeable()?[1,e.getMergeableContent,()=>e.getTransactionMergeableChanges(!a),([[t],[e]])=>!h(t)||!h(e),e.setDefaultContent]:2!=t?[0,e.getContent,e.getTransactionChanges,([t,e])=>!h(t)||!h(e),e.setContent]:c("Store type not supported by this Persister"))(v,t,b),[G,K,Q]=(()=>{let t;const[e,a]=(()=>{const t=[];let e=0;return[a=>(a?d(t):null)??""+e++,e=>{F.test(e)&&i(t)<1e3&&g(t,e)}]})(),n=m();return[(a,s,r,o=[],i=()=>[])=>{t??=st;const c=e(1);var l,y;return O(n,c,[a,s,r,o,i]),l=T(s,r??[""],N),y=c,l?.add(y),c},(e,a,...s)=>y(((t,e=[""])=>{const a=[],n=(t,s)=>s==i(e)?g(a,t):null===e[s]?L(t,t=>n(t,s+1)):y([e[s],null],e=>n(E(t,e),s+1));return n(t,0),a})(e,a),e=>L(e,e=>E(n,e)[0](t,...a??[],...s))),t=>r(E(n,t),([,e,s])=>(T(e,s??[""],void 0,e=>(M(e,t),f(e)?1:0)),O(n,t),a(t),s)),e=>r(E(n,e),([e,,a=[],n,s])=>{const r=(...o)=>{const c=i(o);c==i(a)?e(t,...o,...s(o)):(t=>null===t)(a[c])?y(n[c]?.(...o)??[],t=>r(...o,t)):r(...o,a[c])};r()})]})(),R=t=>{t!=I&&(I=t,K(H,void 0,I))},U=e=>{(V&&o(e?.[0])?1===e?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===e?.[2]?t.applyChanges:t.setContent)(e)},X=async t=>(2!=I&&(R(1),J++,await nt(async()=>{await l(async()=>{const a=await e();o(a)?U(a):t?B(t):c("Content is not an array: "+a)},()=>{t&&B(t)}),R(0)})),st),Y=async t=>(Z(),await X(t),await l(async()=>z=await s(async(t,e)=>{e||t?2!=I&&(R(1),J++,U(e??t),R(0)):await X()}),w),st),Z=async()=>(z&&(await l(()=>u(z),w),z=void 0),st),_=async t=>(1!=I&&(R(2),j++,await nt(async()=>{await l(()=>a(W,t),w),R(0)})),st),tt=async()=>(et(),await _(),D=t.addDidFinishTransactionListener(()=>{const t=$();q(t)&&_(t)}),st),et=async()=>(D&&(t.delListener(D),D=void 0),st),at=async(t=!1)=>{const[e,a]=t?[et,Z]:[Z,et];return await e(),await a(),st},nt=async(...t)=>(g(E(x,A),...t),await(async()=>{if(!E(k,A)){for(O(k,A,1);!n(C=d(E(x,A)));)await l(C,w);O(k,A,0)}})(),st),st={load:X,startAutoLoad:Y,stopAutoLoad:Z,isAutoLoading:()=>!n(z),save:_,startAutoSave:tt,stopAutoSave:et,isAutoSaving:()=>!n(D),startAutoPersisting:async(t,e=!1)=>{const[a,n]=e?[tt,Y]:[Y,tt];return await a(t),await n(t),st},stopAutoPersisting:at,getStatus:()=>I,addStatusListener:t=>G(t,H),delListener:e=>(Q(e),t),schedule:nt,getStore:()=>t,destroy:()=>(E(x,A).splice(0,void 0),at()),getStats:()=>({loads:J,saves:j}),...S};return p(st)},D="storage",I=(t,a,n,s)=>z(t,async()=>C(n.getItem(a)),async t=>n.setItem(a,A(t())),t=>{const s=e=>{e.storageArea===n&&e.key===a&&l(()=>t(C(e.newValue)),t)};return e.addEventListener(D,s),s},t=>e.removeEventListener(D,t),s,3,{getStorageName:()=>a}),J=(t,e,a)=>I(t,e,localStorage,a),j=(t,e,a)=>I(t,e,sessionStorage,a),H=(t,e,a)=>z(t,async()=>C(await(await e.getFile()).text()),async t=>{const a=await e.createWritable();await a.write(A(t())),await a.close()},async t=>{const a=new FileSystemObserver(()=>t());return await a.observe(e),a},t=>t?.disconnect(),a,3,{getHandle:()=>e});export{J as createLocalPersister,H as createOpfsPersister,j as createSessionPersister};
@@ -1 +1 @@
1
- const t=(t=a)=>(e,a,n)=>t(e)?n?.():a(e),e=globalThis.window,a=t=>null==t,n=t=>void 0===t,s=t(a),r=t(n),o=t=>Array.isArray(t),i=t=>t.length,c=t=>{throw Error(t)},l=async(t,e,a)=>{try{return await t()}catch(t){e?.(t)}},y=(t,e)=>t.forEach(e),g=(t,...e)=>t.push(...e),d=t=>t.shift(),u=Object,w=t=>u.getPrototypeOf(t),v=u.keys,p=u.freeze,h=t=>(t=>!a(t)&&s(w(t),t=>t==u.prototype||a(w(t)),()=>!0))(t)&&0==(t=>i(v(t)))(t),S=JSON.stringify,b=JSON.parse,A=t=>S(t,(t,e)=>void 0===e?"":e),C=t=>b(t,(t,e)=>""===e?void 0:e),f=t=>n(t)||0==(t=>t?.size??0)(t),L=(t,e)=>t?.forEach(e),M=(t,e)=>t?.delete(e),m=t=>new Map(t),E=(t,e)=>t?.get(e),O=(t,e,a)=>void 0===a?(M(t,e),t):t?.set(e,a),P=(t,e,a,n)=>{var s,r;return s=t,r=e,s?.has(r)?n?.(E(t,e)):O(t,e,a()),E(t,e)},T=(t,e,a,n,s=0)=>r((a?P:E)(t,e[s],s>i(e)-2?a:m),r=>{if(s>i(e)-2)return n?.(r)&&O(t,e[s]),r;const o=T(r,e,a,n,s+1);return f(r)&&O(t,e[s]),o}),F=/^\d+$/,N=t=>new Set(o(t)||n(t)?t:[t]),k=m(),x=m(),z=(t,e,a,s,u,w,v,S={},b=0,A=[])=>{let C,z,D,I=0,J=0,j=0;P(k,A,()=>0),P(x,A,()=>[]);const H=m(),[V,W,$,q,B]=((t=1,e,a)=>1!=t&&e.isMergeable()?[1,e.getMergeableContent,()=>e.getTransactionMergeableChanges(!a),([[t],[e]])=>!h(t)||!h(e),e.setDefaultContent]:2!=t?[0,e.getContent,e.getTransactionChanges,([t,e])=>!h(t)||!h(e),e.setContent]:c("Store type not supported by this Persister"))(v,t,b),[G,K,Q]=(()=>{let t;const[e,a]=(()=>{const t=[];let e=0;return[a=>(a?d(t):null)??""+e++,e=>{F.test(e)&&i(t)<1e3&&g(t,e)}]})(),n=m();return[(a,s,r,o=[],i=()=>[])=>{t??=st;const c=e(1);var l,y;return O(n,c,[a,s,r,o,i]),l=T(s,r??[""],N),y=c,l?.add(y),c},(e,a,...s)=>y(((t,e=[""])=>{const a=[],n=(t,s)=>s==i(e)?g(a,t):null===e[s]?L(t,t=>n(t,s+1)):y([e[s],null],e=>n(E(t,e),s+1));return n(t,0),a})(e,a),e=>L(e,e=>E(n,e)[0](t,...a??[],...s))),t=>r(E(n,t),([,e,s])=>(T(e,s??[""],void 0,e=>(M(e,t),f(e)?1:0)),O(n,t),a(t),s)),e=>r(E(n,e),([e,,a=[],n,s])=>{const r=(...o)=>{const c=i(o);c==i(a)?e(t,...o,...s(o)):(t=>null===t)(a[c])?y(n[c]?.(...o)??[],t=>r(...o,t)):r(...o,a[c])};r()})]})(),R=t=>{t!=I&&(I=t,K(H,void 0,I))},U=e=>{(V&&o(e?.[0])?1===e?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===e?.[2]?t.applyChanges:t.setContent)(e)},X=async t=>(2!=I&&(R(1),J++,await nt(async()=>{await l(async()=>{const a=await e();o(a)?U(a):t?B(t):c("Content is not an array: "+a)},()=>{t&&B(t)}),R(0)})),st),Y=async t=>(Z(),await X(t),await l(async()=>z=await s(async(t,e)=>{e||t?2!=I&&(R(1),J++,U(e??t),R(0)):await X()}),w),st),Z=async()=>(z&&(await l(()=>u(z),w),z=void 0),st),_=async t=>(1!=I&&(R(2),j++,await nt(async()=>{await l(()=>a(W,t),w),R(0)})),st),tt=async()=>(et(),await _(),D=t.addDidFinishTransactionListener(()=>{const t=$();q(t)&&_(t)}),st),et=async()=>(D&&(t.delListener(D),D=void 0),st),at=async(t=!1)=>{const[e,a]=t?[et,Z]:[Z,et];return await e(),await a(),st},nt=async(...t)=>(g(E(x,A),...t),await(async()=>{if(!E(k,A)){for(O(k,A,1);!n(C=d(E(x,A)));)await l(C,w);O(k,A,0)}})(),st),st={load:X,startAutoLoad:Y,stopAutoLoad:Z,isAutoLoading:()=>!n(z),save:_,startAutoSave:tt,stopAutoSave:et,isAutoSaving:()=>!n(D),startAutoPersisting:async(t,e=!1)=>{const[a,n]=e?[tt,Y]:[Y,tt];return await a(t),await n(t),st},stopAutoPersisting:at,getStatus:()=>I,addStatusListener:t=>G(t,H),delListener:e=>(Q(e),t),schedule:nt,getStore:()=>t,destroy:()=>(E(x,A).splice(0,void 0),at()),getStats:()=>({loads:J,saves:j}),...S};return p(st)},D="storage",I=(t,a,n,s)=>z(t,async()=>C(n.getItem(a)),async t=>n.setItem(a,A(t())),t=>{const s=e=>{e.storageArea===n&&e.key===a&&l(()=>t(C(e.newValue)),t)};return e.addEventListener(D,s),s},t=>e.removeEventListener(D,t),s,3,{getStorageName:()=>a}),J=(t,e,a)=>I(t,e,localStorage,a),j=(t,e,a)=>I(t,e,sessionStorage,a),H=(t,e,a)=>z(t,async()=>C(await(await e.getFile()).text()),async t=>{const a=await e.createWritable();await a.write(A(t())),await a.close()},async t=>{const a=new FileSystemObserver(()=>t());return await a.observe(e),a},t=>t?.disconnect(),a,3,{getHandle:()=>e});export{J as createLocalPersister,H as createOpfsPersister,j as createSessionPersister};
1
+ const t=t=>(e,a,n)=>t(e)?n?.():a(e),e=globalThis.window,a=t=>null==t,n=t=>void 0===t,s=t(a),r=t(n),o=t=>Array.isArray(t),i=t=>t.length,c=t=>{throw Error(t)},l=async(t,e,a)=>{try{return await t()}catch(t){e?.(t)}},y=(t,e)=>t.forEach(e),g=(t,...e)=>t.push(...e),d=t=>t.shift(),u=Object,w=t=>u.getPrototypeOf(t),v=u.keys,p=u.freeze,h=t=>(t=>!a(t)&&s(w(t),t=>t==u.prototype||a(w(t)),()=>!0))(t)&&0==(t=>i(v(t)))(t),S=JSON.stringify,b=JSON.parse,A=t=>S(t,(t,e)=>void 0===e?"":e),C=t=>b(t,(t,e)=>""===e?void 0:e),f=t=>n(t)||0==(t=>t?.size??0)(t),L=(t,e)=>t?.forEach(e),M=(t,e)=>t?.delete(e),m=t=>new Map(t),E=(t,e)=>t?.get(e),O=(t,e,a)=>void 0===a?(M(t,e),t):t?.set(e,a),P=(t,e,a,n)=>{var s,r;return s=t,r=e,s?.has(r)?n?.(E(t,e)):O(t,e,a()),E(t,e)},T=(t,e,a,n,s=0)=>r((a?P:E)(t,e[s],s>i(e)-2?a:m),r=>{if(s>i(e)-2)return n?.(r)&&O(t,e[s]),r;const o=T(r,e,a,n,s+1);return f(r)&&O(t,e[s]),o}),F=/^\d+$/,N=t=>new Set(o(t)||n(t)?t:[t]),k=m(),x=m(),z=(t,e,a,s,u,w,v,S={},b=0,A=[])=>{let C,z,D,I=0,J=0,j=0;P(k,A,()=>0),P(x,A,()=>[]);const H=m(),[V,W,$,q,B]=((t=1,e,a)=>1!=t&&e.isMergeable()?[1,e.getMergeableContent,()=>e.getTransactionMergeableChanges(!a),([[t],[e]])=>!h(t)||!h(e),e.setDefaultContent]:2!=t?[0,e.getContent,e.getTransactionChanges,([t,e])=>!h(t)||!h(e),e.setContent]:c("Store type not supported by this Persister"))(v,t,b),[G,K,Q]=(()=>{let t;const[e,a]=(()=>{const t=[];let e=0;return[a=>(a?d(t):null)??""+e++,e=>{F.test(e)&&i(t)<1e3&&g(t,e)}]})(),n=m();return[(a,s,r,o=[],i=()=>[])=>{t??=st;const c=e(1);var l,y;return O(n,c,[a,s,r,o,i]),l=T(s,r??[""],N),y=c,l?.add(y),c},(e,a,...s)=>y(((t,e=[""])=>{const a=[],n=(t,s)=>s==i(e)?g(a,t):null===e[s]?L(t,t=>n(t,s+1)):y([e[s],null],e=>n(E(t,e),s+1));return n(t,0),a})(e,a),e=>L(e,e=>E(n,e)[0](t,...a??[],...s))),t=>r(E(n,t),([,e,s])=>(T(e,s??[""],void 0,e=>(M(e,t),f(e)?1:0)),O(n,t),a(t),s)),e=>r(E(n,e),([e,,a=[],n,s])=>{const r=(...o)=>{const c=i(o);c==i(a)?e(t,...o,...s(o)):(t=>null===t)(a[c])?y(n[c]?.(...o)??[],t=>r(...o,t)):r(...o,a[c])};r()})]})(),R=t=>{t!=I&&(I=t,K(H,void 0,I))},U=e=>{(V&&o(e?.[0])?1===e?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===e?.[2]?t.applyChanges:t.setContent)(e)},X=async t=>(2!=I&&(R(1),J++,await nt(async()=>{await l(async()=>{const a=await e();o(a)?U(a):t?B(t):c("Content is not an array: "+a)},()=>{t&&B(t)}),R(0)})),st),Y=async t=>(Z(),await X(t),await l(async()=>z=await s(async(t,e)=>{e||t?2!=I&&(R(1),J++,U(e??t),R(0)):await X()}),w),st),Z=async()=>(z&&(await l(()=>u(z),w),z=void 0),st),_=async t=>(1!=I&&(R(2),j++,await nt(async()=>{await l(()=>a(W,t),w),R(0)})),st),tt=async()=>(et(),await _(),D=t.addDidFinishTransactionListener(()=>{const t=$();q(t)&&_(t)}),st),et=async()=>(D&&(t.delListener(D),D=void 0),st),at=async(t=!1)=>{const[e,a]=t?[et,Z]:[Z,et];return await e(),await a(),st},nt=async(...t)=>(g(E(x,A),...t),await(async()=>{if(!E(k,A)){for(O(k,A,1);!n(C=d(E(x,A)));)await l(C,w);O(k,A,0)}})(),st),st={load:X,startAutoLoad:Y,stopAutoLoad:Z,isAutoLoading:()=>!n(z),save:_,startAutoSave:tt,stopAutoSave:et,isAutoSaving:()=>!n(D),startAutoPersisting:async(t,e=!1)=>{const[a,n]=e?[tt,Y]:[Y,tt];return await a(t),await n(t),st},stopAutoPersisting:at,getStatus:()=>I,addStatusListener:t=>G(t,H),delListener:e=>(Q(e),t),schedule:nt,getStore:()=>t,destroy:()=>(E(x,A).splice(0,void 0),at()),getStats:()=>({loads:J,saves:j}),...S};return p(st)},D="storage",I=(t,a,n,s)=>z(t,async()=>C(n.getItem(a)),async t=>n.setItem(a,A(t())),t=>{const s=e=>{e.storageArea===n&&e.key===a&&l(()=>t(C(e.newValue)),t)};return e.addEventListener(D,s),s},t=>e.removeEventListener(D,t),s,3,{getStorageName:()=>a}),J=(t,e,a)=>I(t,e,localStorage,a),j=(t,e,a)=>I(t,e,sessionStorage,a),H=(t,e,a)=>z(t,async()=>C(await(await e.getFile()).text()),async t=>{const a=await e.createWritable();await a.write(A(t())),await a.close()},async t=>{const a=new FileSystemObserver(()=>t());return await a.observe(e),a},t=>t?.disconnect(),a,3,{getHandle:()=>e});export{J as createLocalPersister,H as createOpfsPersister,j as createSessionPersister};
@@ -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=w)=>(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),v=c(y),g=t=>a(t)==s,p=a=>Array.isArray(a),E=(a,t,e)=>a.slice(t,e),A=a=>a.length,N=()=>{},m=async a=>r.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),O=(a,t="")=>a.join(t),T=(a,t)=>a.map(t),h=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",K="pragma_table_",Q="CREATE "+x,V=a=>O(T(((a,t="",e)=>a.split(t,e))(a,"."),a=>`"${o(a,/"/g,'""')}"`),"."),W=(a,t=[1])=>O(T(a,()=>"$"+t[0]++),n),X=(a,t=i)=>j+`(${o(t,"$tableName",V(a))})`,q=Object,Z=a=>q.getPrototypeOf(a),aa=q.entries,ta=q.keys,ea=q.freeze,na=(a=[])=>q.fromEntries(a),sa=(...a)=>q.assign({},...a),ia=(a,t)=>(delete a[t],a),oa=(a,t)=>T(aa(a),([a,e])=>t(e,a)),ra=(a,t)=>na(oa(a,(a,e)=>[e,t(a,e)])),ca=a=>q.values(a),la=a=>A(ta(a)),wa=a=>(a=>!w(a)&&d(Z(a),a=>a==q.prototype||w(Z(a)),()=>!0))(a)&&0==la(a),ya=a=>new Map(a),ua=(a,t)=>a?.get(t),da=(a,t)=>T([...a?.entries()??[]],([a,e])=>t(e,a)),va=(a,t,e)=>void 0===e?(M(a,t),a):a?.set(t,e),ga=(a,t,e,n)=>(S(a,t)?n?.(ua(a,t)):va(a,t,e()),ua(a,t)),pa=(a,t,e,n,s=0)=>v((e?ga:ua)(a,t[s],s>A(t)-2?e:ya),i=>{if(s>A(t)-2)return n?.(i)&&va(a,t[s]),i;const o=pa(i,t,e,n,s+1);return L(i)&&va(a,t[s]),o}),Ea=a=>new Set(p(a)||y(a)?a:[a]),Aa=(a,t)=>a?.add(t),Na="ColumnName",ma="store",$a="json",fa=ma+"TableName",Ca=ma+"Id"+Na,Oa=ma+Na,Ta="autoLoadIntervalSeconds",ha="rowId"+Na,ba="tableId",Da="tableName",Ia="deleteEmptyColumns",Sa="deleteEmptyTable",La="condition",Ra={mode:$a,[Ta]:1},Pa={load:0,save:0,[Da]:t+"_values"},Ma=(a,t,e,n,s)=>{const i=ya();return ra(a,(a,o)=>{const r=E(ca(sa(t,g(a)?{[e]:a}:a)),0,la(t));u(r[0])||n(o,r[0])||(s(o,r[0]),va(i,o,r))}),i},_a=JSON.stringify,Fa=JSON.parse,Ua=/^\d+$/,ja=ya(),xa=ya(),Ba=(a,t,n,s,i,o,r,c={},l=0,w=[])=>{let d,g,E,N=0,m=0,O=0;ga(ja,w,()=>0),ga(xa,w,()=>[]);const T=ya(),[h,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"))(r,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,o,r=[],c=()=>[])=>{a??=V;const l=t(1);return va(s,l,[n,i,o,r,c]),Aa(pa(i,o??[e],Ea),l),l},(t,n,...i)=>C(((a,t=[e])=>{const n=[],s=(a,e)=>e==A(t)?D(n,a):null===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=>v(ua(s,a),([,t,i])=>(pa(t,i??[e],void 0,t=>(M(t,a),L(t)?1:0)),va(s,a),n(a),i)),t=>v(ua(s,t),([t,,e=[],n,s])=>{const i=(...o)=>{const r=A(o);r==A(e)?t(a,...o,...s(o)):u(e[r])?C(n[r]?.(...o)??[],a=>i(...o,a)):i(...o,e[r])};i()})]})(),x=a=>{a!=N&&(N=a,U(T,void 0,N))},B=t=>{(h&&p(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 Q(async()=>{await f(async()=>{const e=await t();p(e)?B(e):a?_(a):$("Content is not an array: "+e)},()=>{a&&_(a)}),x(0)})),V),Y=async a=>(k(),await J(a),await f(async()=>g=await s(async(a,t)=>{t||a?2!=N&&(x(1),m++,B(t??a),x(0)):await J()}),o),V),k=async()=>(g&&(await f(()=>i(g),o),g=void 0),V),z=async a=>(1!=N&&(x(2),O++,await Q(async()=>{await f(()=>n(b,a),o),x(0)})),V),G=async()=>(H(),await z(),E=a.addDidFinishTransactionListener(()=>{const a=S();R(a)&&z(a)}),V),H=async()=>(E&&(a.delListener(E),E=void 0),V),K=async(a=!1)=>{const[t,e]=a?[H,k]:[k,H];return await t(),await e(),V},Q=async(...a)=>(D(ua(xa,w),...a),await(async()=>{if(!ua(ja,w)){for(va(ja,w,1);!y(d=I(ua(xa,w)));)await f(d,o);va(ja,w,0)}})(),V),V={load:J,startAutoLoad:Y,stopAutoLoad:k,isAutoLoading:()=>!y(g),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),V},stopAutoPersisting:K,getStatus:()=>N,addStatusListener:a=>F(a,T),delListener:t=>(j(t),a),schedule:Q,getStore:()=>a,destroy:()=>(ua(xa,w).splice(0,void 0),K()),getStats:()=>({loads:m,saves:O}),...c};return ea(V)},Ja=(a,t,e,s,o,r=Ya,c,l)=>{const w=ya();return[async()=>{w.clear(),T(await e(a,t),({tn:a,cn:t})=>Aa(ga(w,a,Ea),t))},async(t,e,n)=>((a,t)=>S(ua(w,a),t))(t,e)?na(b(T(await a(k+V(t)+X(t,n)),a=>[a[e],l?ra(ia(a,e),l):ia(a,e)]),([a,t])=>!y(a)&&!wa(t))):{},async(t,e,s,l,u,d=!1,v=i)=>{const g=Ea();ra(s??{},a=>T(ta(a??{}),a=>Aa(g,a)));const p=R(g);if(!d&&u&&v==i&&h(p)&&S(w,t))return await a("DROP "+x+V(t)),void va(w,t);const E=ua(w,t),A=Ea(R(E));if(h(p)||(S(w,t)?await m(T([e,...p],async(n,s)=>{M(A,n)||(await a(B+V(t)+"ADD"+V(n)+o),0==s&&await a("CREATE UNIQUE INDEX pk ON "+V(t)+`(${V(e)})`),Aa(E,n))})):(await a(Q+V(t)+`(${V(e)}${o} PRIMARY KEY${O(T(p,a=>n+V(a)+o))});`),va(w,t,Ea([e,...p])))),await m([...!d&&l?T(R(A),async n=>{n!=e&&(await a(B+V(t)+"DROP"+V(n)),M(E,n))}):[]]),d)y(s)?await a(Y+V(t)+X(t,v)):await m(oa(s,async(n,s)=>{y(n)?await a(Y+V(t)+X(t,v)+`AND(${V(e)}=$1)`,[s]):h(p)||await r(a,t,e,ta(n),{[s]:c?T(ca(n),c):ca(n)},E)}));else if(h(p))S(w,t)&&await a(Y+V(t)+X(t,v));else{const n=b(R(ua(w,t)),a=>a!=e),i={},o=[];ra(s??{},(a,t)=>{i[t]=T(n,t=>c?c(a?.[t]):a?.[t]),D(o,t)}),await r(a,t,e,n,i),await a(Y+V(t)+X(t,v)+`AND${V(e)}NOT IN(${W(o)})`,o)}},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 o=[1];await a("INSERT INTO"+V(t)+"("+((...a)=>O(T(a,V),n))(e,...s)+")VALUES"+O(oa(i,a=>"($"+o[0]+++","+W(a,o)+")"),n)+"ON CONFLICT("+V(e)+")DO UPDATE SET"+O(T(s,a=>V(a)+"=excluded."+V(a)),n),oa(i,(a,t)=>[t,...T(a,a=>a??null)]).flat())},ka=(a,t,e,n,s,i,o,[r,c,l],w,y,u,d,v,g)=>{const[p,E,A,N]=Ja(t,w,y,s,v,g),m=Ba(a,()=>N(async()=>{return await p(),a=(await E(r,c))[_]?.[l]??"null",Fa(a,(a,t)=>""===t?void 0:t);var a}),a=>N(async()=>{var t;await p(),await A(r,c,{[_]:{[l]:(t=a()??null,_a(t,(a,t)=>void 0===t?"":t))}},!0,!0)}),e,n,s,o,{[d]:()=>u,destroy:async()=>(await m.stopAutoPersisting(),i(),m)},0,u);return m},za=(a,t,e,n,s,i,o,[r,c,[l,w,u]],d,v,g,p,E,A,N,$)=>{const[f,C,O,T]=Ja(t,d,v,s,E,A,N,$),h=(a,t)=>m(da(c,async([e,n,s,i,o],r)=>{t&&!(r in a)||await O(e,n,a[r],s,i,t,o)})),D=async(a,t)=>w?await O(u,F,{[_]:a},!0,!0,t):null,I=Ba(a,()=>T(async()=>{await f();const a=await(async()=>na(b(await m(da(r,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)=>T(async()=>{if(await f(),y(t)){const[t,e]=a();await h(t),await D(e)}else await h(t[0],!0),await D(t[1],!0)}),e,n,s,o,{[p]:()=>g,destroy:async()=>(await I.stopAutoPersisting(),i(),I)},0,g);return I},Ga=(a,n,s,o,r,c,y,u,d,v,p="getDb",A)=>{let N,m,$;const C=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,c),[O,T,h,b]=(a=>{const e=(a=>sa(Ra,g(a)?{[fa]:a}:a??{}))(a),n=e[Ta];if(e.mode==$a){const a=e[fa]??t;return[1,n,[a,e[Ca]??F,e[Oa]??ma],Ea(a)]}const{tables:{load:s={},save:o={}}={},values:r={}}=e,c=E(ca(sa(Pa,r)),0,la(Pa)),l=c[2],w=Ea(l),y=Ea(l),u=Ma(s,{[ba]:null,[ha]:F,[La]:i},ba,a=>S(y,a),a=>Aa(w,a)),d=Ma(o,{[Da]:null,[ha]:F,[Ia]:0,[Sa]:0,[La]:null},Da,(a,t)=>S(y,t),(a,t)=>Aa(w,t));var v;return v=(a,t)=>t[4]??=ua(u,t[0])?.[2]??i,P(d,(a,t)=>v(0,a)),[0,n,[u,d,c],w]})(n);return(O?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*T),n=()=>{N=m=$=null,l(t)},s=o(t=>{b.has(t)&&(n(),a(),e())});return e(),()=>{n(),r(s)}},a=>a(),y,u,d,h,R(b),async(a,t)=>await a(U+` t.name tn,c.name cn FROM ${K}list()t,${K}info(t.name)c ${j} t.schema='main'AND t.type IN('table','view')AND t.name IN(${W(t)})ORDER BY t.name,c.name`,t),v,p,e,A,a=>!0===a?1:!1===a?0:a,void 0)},Ha=(a,t,e,n,s)=>Ga(a,e,async(a,e=[])=>await t.execO(a,e),a=>t.onUpdate((t,e,n)=>a(n)),a=>a(),n,s,N,1,t);export{Ha as createCrSqliteWasmPersister};
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=clearInterval,w=a=>null==a,y=a=>void 0===a,u=a=>null===a,d=c(w),v=c(y),g=t=>a(t)==s,p=a=>Array.isArray(a),E=(a,t,e)=>a.slice(t,e),A=a=>a.length,N=()=>{},m=async a=>r.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),O=(a,t="")=>a.join(t),T=(a,t)=>a.map(t),h=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",K="pragma_table_",Q="CREATE "+x,V=a=>O(T(((a,t="",e)=>a.split(t,e))(a,"."),a=>`"${o(a,/"/g,'""')}"`),"."),W=(a,t=[1])=>O(T(a,()=>"$"+t[0]++),n),X=(a,t=i)=>j+`(${o(t,"$tableName",V(a))})`,q=Object,Z=a=>q.getPrototypeOf(a),aa=q.entries,ta=q.keys,ea=q.freeze,na=(a=[])=>q.fromEntries(a),sa=(...a)=>q.assign({},...a),ia=(a,t)=>(delete a[t],a),oa=(a,t)=>T(aa(a),([a,e])=>t(e,a)),ra=(a,t)=>na(oa(a,(a,e)=>[e,t(a,e)])),ca=a=>q.values(a),la=a=>A(ta(a)),wa=a=>(a=>!w(a)&&d(Z(a),a=>a==q.prototype||w(Z(a)),()=>!0))(a)&&0==la(a),ya=a=>new Map(a),ua=(a,t)=>a?.get(t),da=(a,t)=>T([...a?.entries()??[]],([a,e])=>t(e,a)),va=(a,t,e)=>void 0===e?(M(a,t),a):a?.set(t,e),ga=(a,t,e,n)=>(S(a,t)?n?.(ua(a,t)):va(a,t,e()),ua(a,t)),pa=(a,t,e,n,s=0)=>v((e?ga:ua)(a,t[s],s>A(t)-2?e:ya),i=>{if(s>A(t)-2)return n?.(i)&&va(a,t[s]),i;const o=pa(i,t,e,n,s+1);return L(i)&&va(a,t[s]),o}),Ea=a=>new Set(p(a)||y(a)?a:[a]),Aa=(a,t)=>a?.add(t),Na="ColumnName",ma="store",$a="json",fa=ma+"TableName",Ca=ma+"Id"+Na,Oa=ma+Na,Ta="autoLoadIntervalSeconds",ha="rowId"+Na,ba="tableId",Da="tableName",Ia="deleteEmptyColumns",Sa="deleteEmptyTable",La="condition",Ra={mode:$a,[Ta]:1},Pa={load:0,save:0,[Da]:t+"_values"},Ma=(a,t,e,n,s)=>{const i=ya();return ra(a,(a,o)=>{const r=E(ca(sa(t,g(a)?{[e]:a}:a)),0,la(t));u(r[0])||n(o,r[0])||(s(o,r[0]),va(i,o,r))}),i},_a=JSON.stringify,Fa=JSON.parse,Ua=/^\d+$/,ja=ya(),xa=ya(),Ba=(a,t,n,s,i,o,r,c={},l=0,w=[])=>{let d,g,E,N=0,m=0,O=0;ga(ja,w,()=>0),ga(xa,w,()=>[]);const T=ya(),[h,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"))(r,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,o,r=[],c=()=>[])=>{a??=V;const l=t(1);return va(s,l,[n,i,o,r,c]),Aa(pa(i,o??[e],Ea),l),l},(t,n,...i)=>C(((a,t=[e])=>{const n=[],s=(a,e)=>e==A(t)?D(n,a):null===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=>v(ua(s,a),([,t,i])=>(pa(t,i??[e],void 0,t=>(M(t,a),L(t)?1:0)),va(s,a),n(a),i)),t=>v(ua(s,t),([t,,e=[],n,s])=>{const i=(...o)=>{const r=A(o);r==A(e)?t(a,...o,...s(o)):u(e[r])?C(n[r]?.(...o)??[],a=>i(...o,a)):i(...o,e[r])};i()})]})(),x=a=>{a!=N&&(N=a,U(T,void 0,N))},B=t=>{(h&&p(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 Q(async()=>{await f(async()=>{const e=await t();p(e)?B(e):a?_(a):$("Content is not an array: "+e)},()=>{a&&_(a)}),x(0)})),V),Y=async a=>(k(),await J(a),await f(async()=>g=await s(async(a,t)=>{t||a?2!=N&&(x(1),m++,B(t??a),x(0)):await J()}),o),V),k=async()=>(g&&(await f(()=>i(g),o),g=void 0),V),z=async a=>(1!=N&&(x(2),O++,await Q(async()=>{await f(()=>n(b,a),o),x(0)})),V),G=async()=>(H(),await z(),E=a.addDidFinishTransactionListener(()=>{const a=S();R(a)&&z(a)}),V),H=async()=>(E&&(a.delListener(E),E=void 0),V),K=async(a=!1)=>{const[t,e]=a?[H,k]:[k,H];return await t(),await e(),V},Q=async(...a)=>(D(ua(xa,w),...a),await(async()=>{if(!ua(ja,w)){for(va(ja,w,1);!y(d=I(ua(xa,w)));)await f(d,o);va(ja,w,0)}})(),V),V={load:J,startAutoLoad:Y,stopAutoLoad:k,isAutoLoading:()=>!y(g),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),V},stopAutoPersisting:K,getStatus:()=>N,addStatusListener:a=>F(a,T),delListener:t=>(j(t),a),schedule:Q,getStore:()=>a,destroy:()=>(ua(xa,w).splice(0,void 0),K()),getStats:()=>({loads:m,saves:O}),...c};return ea(V)},Ja=(a,t,e,s,o,r=Ya,c,l)=>{const w=ya();return[async()=>{w.clear(),T(await e(a,t),({tn:a,cn:t})=>Aa(ga(w,a,Ea),t))},async(t,e,n)=>((a,t)=>S(ua(w,a),t))(t,e)?na(b(T(await a(k+V(t)+X(t,n)),a=>[a[e],l?ra(ia(a,e),l):ia(a,e)]),([a,t])=>!y(a)&&!wa(t))):{},async(t,e,s,l,u,d=!1,v=i)=>{const g=Ea();ra(s??{},a=>T(ta(a??{}),a=>Aa(g,a)));const p=R(g);if(!d&&u&&v==i&&h(p)&&S(w,t))return await a("DROP "+x+V(t)),void va(w,t);const E=ua(w,t),A=Ea(R(E));if(h(p)||(S(w,t)?await m(T([e,...p],async(n,s)=>{M(A,n)||(await a(B+V(t)+"ADD"+V(n)+o),0==s&&await a("CREATE UNIQUE INDEX pk ON "+V(t)+`(${V(e)})`),Aa(E,n))})):(await a(Q+V(t)+`(${V(e)}${o} PRIMARY KEY${O(T(p,a=>n+V(a)+o))});`),va(w,t,Ea([e,...p])))),await m([...!d&&l?T(R(A),async n=>{n!=e&&(await a(B+V(t)+"DROP"+V(n)),M(E,n))}):[]]),d)y(s)?await a(Y+V(t)+X(t,v)):await m(oa(s,async(n,s)=>{y(n)?await a(Y+V(t)+X(t,v)+`AND(${V(e)}=$1)`,[s]):h(p)||await r(a,t,e,ta(n),{[s]:c?T(ca(n),c):ca(n)},E)}));else if(h(p))S(w,t)&&await a(Y+V(t)+X(t,v));else{const n=b(R(ua(w,t)),a=>a!=e),i={},o=[];ra(s??{},(a,t)=>{i[t]=T(n,t=>c?c(a?.[t]):a?.[t]),D(o,t)}),await r(a,t,e,n,i),await a(Y+V(t)+X(t,v)+`AND${V(e)}NOT IN(${W(o)})`,o)}},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 o=[1];await a("INSERT INTO"+V(t)+"("+((...a)=>O(T(a,V),n))(e,...s)+")VALUES"+O(oa(i,a=>"($"+o[0]+++","+W(a,o)+")"),n)+"ON CONFLICT("+V(e)+")DO UPDATE SET"+O(T(s,a=>V(a)+"=excluded."+V(a)),n),oa(i,(a,t)=>[t,...T(a,a=>a??null)]).flat())},ka=(a,t,e,n,s,i,o,[r,c,l],w,y,u,d,v,g)=>{const[p,E,A,N]=Ja(t,w,y,s,v,g),m=Ba(a,()=>N(async()=>{return await p(),a=(await E(r,c))[_]?.[l]??"null",Fa(a,(a,t)=>""===t?void 0:t);var a}),a=>N(async()=>{var t;await p(),await A(r,c,{[_]:{[l]:(t=a()??null,_a(t,(a,t)=>void 0===t?"":t))}},!0,!0)}),e,n,s,o,{[d]:()=>u,destroy:async()=>(await m.stopAutoPersisting(),i(),m)},0,u);return m},za=(a,t,e,n,s,i,o,[r,c,[l,w,u]],d,v,g,p,E,A,N,$)=>{const[f,C,O,T]=Ja(t,d,v,s,E,A,N,$),h=(a,t)=>m(da(c,async([e,n,s,i,o],r)=>{t&&!(r in a)||await O(e,n,a[r],s,i,t,o)})),D=async(a,t)=>w?await O(u,F,{[_]:a},!0,!0,t):null,I=Ba(a,()=>T(async()=>{await f();const a=await(async()=>na(b(await m(da(r,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)=>T(async()=>{if(await f(),y(t)){const[t,e]=a();await h(t),await D(e)}else await h(t[0],!0),await D(t[1],!0)}),e,n,s,o,{[p]:()=>g,destroy:async()=>(await I.stopAutoPersisting(),i(),I)},0,g);return I},Ga=(a,n,s,o,r,c,y,u,d,v,p="getDb",A)=>{let N,m,$;const C=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,c),[O,T,h,b]=(a=>{const e=(a=>sa(Ra,g(a)?{[fa]:a}:a??{}))(a),n=e[Ta];if(e.mode==$a){const a=e[fa]??t;return[1,n,[a,e[Ca]??F,e[Oa]??ma],Ea(a)]}const{tables:{load:s={},save:o={}}={},values:r={}}=e,c=E(ca(sa(Pa,r)),0,la(Pa)),l=c[2],w=Ea(l),y=Ea(l),u=Ma(s,{[ba]:null,[ha]:F,[La]:i},ba,a=>S(y,a),a=>Aa(w,a)),d=Ma(o,{[Da]:null,[ha]:F,[Ia]:0,[Sa]:0,[La]:null},Da,(a,t)=>S(y,t),(a,t)=>Aa(w,t));var v;return v=(a,t)=>t[4]??=ua(u,t[0])?.[2]??i,P(d,(a,t)=>v(0,a)),[0,n,[u,d,c],w]})(n);return(O?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*T),n=()=>{N=m=$=null,l(t)},s=o(t=>{b.has(t)&&(n(),a(),e())});return e(),()=>{n(),r(s)}},a=>a(),y,u,d,h,R(b),async(a,t)=>await a(U+` t.name tn,c.name cn FROM ${K}list()t,${K}info(t.name)c ${j} t.schema='main'AND t.type IN('table','view')AND t.name IN(${W(t)})ORDER BY t.name,c.name`,t),v,p,e,A,a=>!0===a?1:!1===a?0:a,void 0)},Ha=(a,t,e,n,s)=>Ga(a,e,async(a,e=[])=>await t.execO(a,e),a=>t.onUpdate((t,e,n)=>a(n)),a=>a(),n,s,N,1,t);export{Ha as createCrSqliteWasmPersister};
@@ -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=w)=>(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),v=c(y),g=t=>a(t)==s,p=a=>Array.isArray(a),E=(a,t,e)=>a.slice(t,e),A=a=>a.length,N=()=>{},m=async a=>r.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),O=(a,t="")=>a.join(t),T=(a,t)=>a.map(t),h=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",K="pragma_table_",Q="CREATE "+x,V=a=>O(T(((a,t="",e)=>a.split(t,e))(a,"."),a=>`"${o(a,/"/g,'""')}"`),"."),W=(a,t=[1])=>O(T(a,()=>"$"+t[0]++),n),X=(a,t=i)=>j+`(${o(t,"$tableName",V(a))})`,q=Object,Z=a=>q.getPrototypeOf(a),aa=q.entries,ta=q.keys,ea=q.freeze,na=(a=[])=>q.fromEntries(a),sa=(...a)=>q.assign({},...a),ia=(a,t)=>(delete a[t],a),oa=(a,t)=>T(aa(a),([a,e])=>t(e,a)),ra=(a,t)=>na(oa(a,(a,e)=>[e,t(a,e)])),ca=a=>q.values(a),la=a=>A(ta(a)),wa=a=>(a=>!w(a)&&d(Z(a),a=>a==q.prototype||w(Z(a)),()=>!0))(a)&&0==la(a),ya=a=>new Map(a),ua=(a,t)=>a?.get(t),da=(a,t)=>T([...a?.entries()??[]],([a,e])=>t(e,a)),va=(a,t,e)=>void 0===e?(M(a,t),a):a?.set(t,e),ga=(a,t,e,n)=>(S(a,t)?n?.(ua(a,t)):va(a,t,e()),ua(a,t)),pa=(a,t,e,n,s=0)=>v((e?ga:ua)(a,t[s],s>A(t)-2?e:ya),i=>{if(s>A(t)-2)return n?.(i)&&va(a,t[s]),i;const o=pa(i,t,e,n,s+1);return L(i)&&va(a,t[s]),o}),Ea=a=>new Set(p(a)||y(a)?a:[a]),Aa=(a,t)=>a?.add(t),Na="ColumnName",ma="store",$a="json",fa=ma+"TableName",Ca=ma+"Id"+Na,Oa=ma+Na,Ta="autoLoadIntervalSeconds",ha="rowId"+Na,ba="tableId",Da="tableName",Ia="deleteEmptyColumns",Sa="deleteEmptyTable",La="condition",Ra={mode:$a,[Ta]:1},Pa={load:0,save:0,[Da]:t+"_values"},Ma=(a,t,e,n,s)=>{const i=ya();return ra(a,(a,o)=>{const r=E(ca(sa(t,g(a)?{[e]:a}:a)),0,la(t));u(r[0])||n(o,r[0])||(s(o,r[0]),va(i,o,r))}),i},_a=JSON.stringify,Fa=JSON.parse,Ua=/^\d+$/,ja=ya(),xa=ya(),Ba=(a,t,n,s,i,o,r,c={},l=0,w=[])=>{let d,g,E,N=0,m=0,O=0;ga(ja,w,()=>0),ga(xa,w,()=>[]);const T=ya(),[h,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"))(r,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,o,r=[],c=()=>[])=>{a??=V;const l=t(1);return va(s,l,[n,i,o,r,c]),Aa(pa(i,o??[e],Ea),l),l},(t,n,...i)=>C(((a,t=[e])=>{const n=[],s=(a,e)=>e==A(t)?D(n,a):null===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=>v(ua(s,a),([,t,i])=>(pa(t,i??[e],void 0,t=>(M(t,a),L(t)?1:0)),va(s,a),n(a),i)),t=>v(ua(s,t),([t,,e=[],n,s])=>{const i=(...o)=>{const r=A(o);r==A(e)?t(a,...o,...s(o)):u(e[r])?C(n[r]?.(...o)??[],a=>i(...o,a)):i(...o,e[r])};i()})]})(),x=a=>{a!=N&&(N=a,U(T,void 0,N))},B=t=>{(h&&p(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 Q(async()=>{await f(async()=>{const e=await t();p(e)?B(e):a?_(a):$("Content is not an array: "+e)},()=>{a&&_(a)}),x(0)})),V),Y=async a=>(k(),await J(a),await f(async()=>g=await s(async(a,t)=>{t||a?2!=N&&(x(1),m++,B(t??a),x(0)):await J()}),o),V),k=async()=>(g&&(await f(()=>i(g),o),g=void 0),V),z=async a=>(1!=N&&(x(2),O++,await Q(async()=>{await f(()=>n(b,a),o),x(0)})),V),G=async()=>(H(),await z(),E=a.addDidFinishTransactionListener(()=>{const a=S();R(a)&&z(a)}),V),H=async()=>(E&&(a.delListener(E),E=void 0),V),K=async(a=!1)=>{const[t,e]=a?[H,k]:[k,H];return await t(),await e(),V},Q=async(...a)=>(D(ua(xa,w),...a),await(async()=>{if(!ua(ja,w)){for(va(ja,w,1);!y(d=I(ua(xa,w)));)await f(d,o);va(ja,w,0)}})(),V),V={load:J,startAutoLoad:Y,stopAutoLoad:k,isAutoLoading:()=>!y(g),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),V},stopAutoPersisting:K,getStatus:()=>N,addStatusListener:a=>F(a,T),delListener:t=>(j(t),a),schedule:Q,getStore:()=>a,destroy:()=>(ua(xa,w).splice(0,void 0),K()),getStats:()=>({loads:m,saves:O}),...c};return ea(V)},Ja=(a,t,e,s,o,r=Ya,c,l)=>{const w=ya();return[async()=>{w.clear(),T(await e(a,t),({tn:a,cn:t})=>Aa(ga(w,a,Ea),t))},async(t,e,n)=>((a,t)=>S(ua(w,a),t))(t,e)?na(b(T(await a(k+V(t)+X(t,n)),a=>[a[e],l?ra(ia(a,e),l):ia(a,e)]),([a,t])=>!y(a)&&!wa(t))):{},async(t,e,s,l,u,d=!1,v=i)=>{const g=Ea();ra(s??{},a=>T(ta(a??{}),a=>Aa(g,a)));const p=R(g);if(!d&&u&&v==i&&h(p)&&S(w,t))return await a("DROP "+x+V(t)),void va(w,t);const E=ua(w,t),A=Ea(R(E));if(h(p)||(S(w,t)?await m(T([e,...p],async(n,s)=>{M(A,n)||(await a(B+V(t)+"ADD"+V(n)+o),0==s&&await a("CREATE UNIQUE INDEX pk ON "+V(t)+`(${V(e)})`),Aa(E,n))})):(await a(Q+V(t)+`(${V(e)}${o} PRIMARY KEY${O(T(p,a=>n+V(a)+o))});`),va(w,t,Ea([e,...p])))),await m([...!d&&l?T(R(A),async n=>{n!=e&&(await a(B+V(t)+"DROP"+V(n)),M(E,n))}):[]]),d)y(s)?await a(Y+V(t)+X(t,v)):await m(oa(s,async(n,s)=>{y(n)?await a(Y+V(t)+X(t,v)+`AND(${V(e)}=$1)`,[s]):h(p)||await r(a,t,e,ta(n),{[s]:c?T(ca(n),c):ca(n)},E)}));else if(h(p))S(w,t)&&await a(Y+V(t)+X(t,v));else{const n=b(R(ua(w,t)),a=>a!=e),i={},o=[];ra(s??{},(a,t)=>{i[t]=T(n,t=>c?c(a?.[t]):a?.[t]),D(o,t)}),await r(a,t,e,n,i),await a(Y+V(t)+X(t,v)+`AND${V(e)}NOT IN(${W(o)})`,o)}},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 o=[1];await a("INSERT INTO"+V(t)+"("+((...a)=>O(T(a,V),n))(e,...s)+")VALUES"+O(oa(i,a=>"($"+o[0]+++","+W(a,o)+")"),n)+"ON CONFLICT("+V(e)+")DO UPDATE SET"+O(T(s,a=>V(a)+"=excluded."+V(a)),n),oa(i,(a,t)=>[t,...T(a,a=>a??null)]).flat())},ka=(a,t,e,n,s,i,o,[r,c,l],w,y,u,d,v,g)=>{const[p,E,A,N]=Ja(t,w,y,s,v,g),m=Ba(a,()=>N(async()=>{return await p(),a=(await E(r,c))[_]?.[l]??"null",Fa(a,(a,t)=>""===t?void 0:t);var a}),a=>N(async()=>{var t;await p(),await A(r,c,{[_]:{[l]:(t=a()??null,_a(t,(a,t)=>void 0===t?"":t))}},!0,!0)}),e,n,s,o,{[d]:()=>u,destroy:async()=>(await m.stopAutoPersisting(),i(),m)},0,u);return m},za=(a,t,e,n,s,i,o,[r,c,[l,w,u]],d,v,g,p,E,A,N,$)=>{const[f,C,O,T]=Ja(t,d,v,s,E,A,N,$),h=(a,t)=>m(da(c,async([e,n,s,i,o],r)=>{t&&!(r in a)||await O(e,n,a[r],s,i,t,o)})),D=async(a,t)=>w?await O(u,F,{[_]:a},!0,!0,t):null,I=Ba(a,()=>T(async()=>{await f();const a=await(async()=>na(b(await m(da(r,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)=>T(async()=>{if(await f(),y(t)){const[t,e]=a();await h(t),await D(e)}else await h(t[0],!0),await D(t[1],!0)}),e,n,s,o,{[p]:()=>g,destroy:async()=>(await I.stopAutoPersisting(),i(),I)},0,g);return I},Ga=(a,n,s,o,r,c,y,u,d,v,p="getDb",A)=>{let N,m,$;const C=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,c),[O,T,h,b]=(a=>{const e=(a=>sa(Ra,g(a)?{[fa]:a}:a??{}))(a),n=e[Ta];if(e.mode==$a){const a=e[fa]??t;return[1,n,[a,e[Ca]??F,e[Oa]??ma],Ea(a)]}const{tables:{load:s={},save:o={}}={},values:r={}}=e,c=E(ca(sa(Pa,r)),0,la(Pa)),l=c[2],w=Ea(l),y=Ea(l),u=Ma(s,{[ba]:null,[ha]:F,[La]:i},ba,a=>S(y,a),a=>Aa(w,a)),d=Ma(o,{[Da]:null,[ha]:F,[Ia]:0,[Sa]:0,[La]:null},Da,(a,t)=>S(y,t),(a,t)=>Aa(w,t));var v;return v=(a,t)=>t[4]??=ua(u,t[0])?.[2]??i,P(d,(a,t)=>v(0,a)),[0,n,[u,d,c],w]})(n);return(O?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*T),n=()=>{N=m=$=null,l(t)},s=o(t=>{b.has(t)&&(n(),a(),e())});return e(),()=>{n(),r(s)}},a=>a(),y,u,d,h,R(b),async(a,t)=>await a(U+` t.name tn,c.name cn FROM ${K}list()t,${K}info(t.name)c ${j} t.schema='main'AND t.type IN('table','view')AND t.name IN(${W(t)})ORDER BY t.name,c.name`,t),v,p,e,A,a=>!0===a?1:!1===a?0:a,void 0)},Ha=(a,t,e,n,s)=>Ga(a,e,async(a,e=[])=>await t.execO(a,e),a=>t.onUpdate((t,e,n)=>a(n)),a=>a(),n,s,N,1,t);export{Ha as createCrSqliteWasmPersister};
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=clearInterval,w=a=>null==a,y=a=>void 0===a,u=a=>null===a,d=c(w),v=c(y),g=t=>a(t)==s,p=a=>Array.isArray(a),E=(a,t,e)=>a.slice(t,e),A=a=>a.length,N=()=>{},m=async a=>r.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),O=(a,t="")=>a.join(t),T=(a,t)=>a.map(t),h=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",K="pragma_table_",Q="CREATE "+x,V=a=>O(T(((a,t="",e)=>a.split(t,e))(a,"."),a=>`"${o(a,/"/g,'""')}"`),"."),W=(a,t=[1])=>O(T(a,()=>"$"+t[0]++),n),X=(a,t=i)=>j+`(${o(t,"$tableName",V(a))})`,q=Object,Z=a=>q.getPrototypeOf(a),aa=q.entries,ta=q.keys,ea=q.freeze,na=(a=[])=>q.fromEntries(a),sa=(...a)=>q.assign({},...a),ia=(a,t)=>(delete a[t],a),oa=(a,t)=>T(aa(a),([a,e])=>t(e,a)),ra=(a,t)=>na(oa(a,(a,e)=>[e,t(a,e)])),ca=a=>q.values(a),la=a=>A(ta(a)),wa=a=>(a=>!w(a)&&d(Z(a),a=>a==q.prototype||w(Z(a)),()=>!0))(a)&&0==la(a),ya=a=>new Map(a),ua=(a,t)=>a?.get(t),da=(a,t)=>T([...a?.entries()??[]],([a,e])=>t(e,a)),va=(a,t,e)=>void 0===e?(M(a,t),a):a?.set(t,e),ga=(a,t,e,n)=>(S(a,t)?n?.(ua(a,t)):va(a,t,e()),ua(a,t)),pa=(a,t,e,n,s=0)=>v((e?ga:ua)(a,t[s],s>A(t)-2?e:ya),i=>{if(s>A(t)-2)return n?.(i)&&va(a,t[s]),i;const o=pa(i,t,e,n,s+1);return L(i)&&va(a,t[s]),o}),Ea=a=>new Set(p(a)||y(a)?a:[a]),Aa=(a,t)=>a?.add(t),Na="ColumnName",ma="store",$a="json",fa=ma+"TableName",Ca=ma+"Id"+Na,Oa=ma+Na,Ta="autoLoadIntervalSeconds",ha="rowId"+Na,ba="tableId",Da="tableName",Ia="deleteEmptyColumns",Sa="deleteEmptyTable",La="condition",Ra={mode:$a,[Ta]:1},Pa={load:0,save:0,[Da]:t+"_values"},Ma=(a,t,e,n,s)=>{const i=ya();return ra(a,(a,o)=>{const r=E(ca(sa(t,g(a)?{[e]:a}:a)),0,la(t));u(r[0])||n(o,r[0])||(s(o,r[0]),va(i,o,r))}),i},_a=JSON.stringify,Fa=JSON.parse,Ua=/^\d+$/,ja=ya(),xa=ya(),Ba=(a,t,n,s,i,o,r,c={},l=0,w=[])=>{let d,g,E,N=0,m=0,O=0;ga(ja,w,()=>0),ga(xa,w,()=>[]);const T=ya(),[h,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"))(r,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,o,r=[],c=()=>[])=>{a??=V;const l=t(1);return va(s,l,[n,i,o,r,c]),Aa(pa(i,o??[e],Ea),l),l},(t,n,...i)=>C(((a,t=[e])=>{const n=[],s=(a,e)=>e==A(t)?D(n,a):null===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=>v(ua(s,a),([,t,i])=>(pa(t,i??[e],void 0,t=>(M(t,a),L(t)?1:0)),va(s,a),n(a),i)),t=>v(ua(s,t),([t,,e=[],n,s])=>{const i=(...o)=>{const r=A(o);r==A(e)?t(a,...o,...s(o)):u(e[r])?C(n[r]?.(...o)??[],a=>i(...o,a)):i(...o,e[r])};i()})]})(),x=a=>{a!=N&&(N=a,U(T,void 0,N))},B=t=>{(h&&p(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 Q(async()=>{await f(async()=>{const e=await t();p(e)?B(e):a?_(a):$("Content is not an array: "+e)},()=>{a&&_(a)}),x(0)})),V),Y=async a=>(k(),await J(a),await f(async()=>g=await s(async(a,t)=>{t||a?2!=N&&(x(1),m++,B(t??a),x(0)):await J()}),o),V),k=async()=>(g&&(await f(()=>i(g),o),g=void 0),V),z=async a=>(1!=N&&(x(2),O++,await Q(async()=>{await f(()=>n(b,a),o),x(0)})),V),G=async()=>(H(),await z(),E=a.addDidFinishTransactionListener(()=>{const a=S();R(a)&&z(a)}),V),H=async()=>(E&&(a.delListener(E),E=void 0),V),K=async(a=!1)=>{const[t,e]=a?[H,k]:[k,H];return await t(),await e(),V},Q=async(...a)=>(D(ua(xa,w),...a),await(async()=>{if(!ua(ja,w)){for(va(ja,w,1);!y(d=I(ua(xa,w)));)await f(d,o);va(ja,w,0)}})(),V),V={load:J,startAutoLoad:Y,stopAutoLoad:k,isAutoLoading:()=>!y(g),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),V},stopAutoPersisting:K,getStatus:()=>N,addStatusListener:a=>F(a,T),delListener:t=>(j(t),a),schedule:Q,getStore:()=>a,destroy:()=>(ua(xa,w).splice(0,void 0),K()),getStats:()=>({loads:m,saves:O}),...c};return ea(V)},Ja=(a,t,e,s,o,r=Ya,c,l)=>{const w=ya();return[async()=>{w.clear(),T(await e(a,t),({tn:a,cn:t})=>Aa(ga(w,a,Ea),t))},async(t,e,n)=>((a,t)=>S(ua(w,a),t))(t,e)?na(b(T(await a(k+V(t)+X(t,n)),a=>[a[e],l?ra(ia(a,e),l):ia(a,e)]),([a,t])=>!y(a)&&!wa(t))):{},async(t,e,s,l,u,d=!1,v=i)=>{const g=Ea();ra(s??{},a=>T(ta(a??{}),a=>Aa(g,a)));const p=R(g);if(!d&&u&&v==i&&h(p)&&S(w,t))return await a("DROP "+x+V(t)),void va(w,t);const E=ua(w,t),A=Ea(R(E));if(h(p)||(S(w,t)?await m(T([e,...p],async(n,s)=>{M(A,n)||(await a(B+V(t)+"ADD"+V(n)+o),0==s&&await a("CREATE UNIQUE INDEX pk ON "+V(t)+`(${V(e)})`),Aa(E,n))})):(await a(Q+V(t)+`(${V(e)}${o} PRIMARY KEY${O(T(p,a=>n+V(a)+o))});`),va(w,t,Ea([e,...p])))),await m([...!d&&l?T(R(A),async n=>{n!=e&&(await a(B+V(t)+"DROP"+V(n)),M(E,n))}):[]]),d)y(s)?await a(Y+V(t)+X(t,v)):await m(oa(s,async(n,s)=>{y(n)?await a(Y+V(t)+X(t,v)+`AND(${V(e)}=$1)`,[s]):h(p)||await r(a,t,e,ta(n),{[s]:c?T(ca(n),c):ca(n)},E)}));else if(h(p))S(w,t)&&await a(Y+V(t)+X(t,v));else{const n=b(R(ua(w,t)),a=>a!=e),i={},o=[];ra(s??{},(a,t)=>{i[t]=T(n,t=>c?c(a?.[t]):a?.[t]),D(o,t)}),await r(a,t,e,n,i),await a(Y+V(t)+X(t,v)+`AND${V(e)}NOT IN(${W(o)})`,o)}},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 o=[1];await a("INSERT INTO"+V(t)+"("+((...a)=>O(T(a,V),n))(e,...s)+")VALUES"+O(oa(i,a=>"($"+o[0]+++","+W(a,o)+")"),n)+"ON CONFLICT("+V(e)+")DO UPDATE SET"+O(T(s,a=>V(a)+"=excluded."+V(a)),n),oa(i,(a,t)=>[t,...T(a,a=>a??null)]).flat())},ka=(a,t,e,n,s,i,o,[r,c,l],w,y,u,d,v,g)=>{const[p,E,A,N]=Ja(t,w,y,s,v,g),m=Ba(a,()=>N(async()=>{return await p(),a=(await E(r,c))[_]?.[l]??"null",Fa(a,(a,t)=>""===t?void 0:t);var a}),a=>N(async()=>{var t;await p(),await A(r,c,{[_]:{[l]:(t=a()??null,_a(t,(a,t)=>void 0===t?"":t))}},!0,!0)}),e,n,s,o,{[d]:()=>u,destroy:async()=>(await m.stopAutoPersisting(),i(),m)},0,u);return m},za=(a,t,e,n,s,i,o,[r,c,[l,w,u]],d,v,g,p,E,A,N,$)=>{const[f,C,O,T]=Ja(t,d,v,s,E,A,N,$),h=(a,t)=>m(da(c,async([e,n,s,i,o],r)=>{t&&!(r in a)||await O(e,n,a[r],s,i,t,o)})),D=async(a,t)=>w?await O(u,F,{[_]:a},!0,!0,t):null,I=Ba(a,()=>T(async()=>{await f();const a=await(async()=>na(b(await m(da(r,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)=>T(async()=>{if(await f(),y(t)){const[t,e]=a();await h(t),await D(e)}else await h(t[0],!0),await D(t[1],!0)}),e,n,s,o,{[p]:()=>g,destroy:async()=>(await I.stopAutoPersisting(),i(),I)},0,g);return I},Ga=(a,n,s,o,r,c,y,u,d,v,p="getDb",A)=>{let N,m,$;const C=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,c),[O,T,h,b]=(a=>{const e=(a=>sa(Ra,g(a)?{[fa]:a}:a??{}))(a),n=e[Ta];if(e.mode==$a){const a=e[fa]??t;return[1,n,[a,e[Ca]??F,e[Oa]??ma],Ea(a)]}const{tables:{load:s={},save:o={}}={},values:r={}}=e,c=E(ca(sa(Pa,r)),0,la(Pa)),l=c[2],w=Ea(l),y=Ea(l),u=Ma(s,{[ba]:null,[ha]:F,[La]:i},ba,a=>S(y,a),a=>Aa(w,a)),d=Ma(o,{[Da]:null,[ha]:F,[Ia]:0,[Sa]:0,[La]:null},Da,(a,t)=>S(y,t),(a,t)=>Aa(w,t));var v;return v=(a,t)=>t[4]??=ua(u,t[0])?.[2]??i,P(d,(a,t)=>v(0,a)),[0,n,[u,d,c],w]})(n);return(O?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*T),n=()=>{N=m=$=null,l(t)},s=o(t=>{b.has(t)&&(n(),a(),e())});return e(),()=>{n(),r(s)}},a=>a(),y,u,d,h,R(b),async(a,t)=>await a(U+` t.name tn,c.name cn FROM ${K}list()t,${K}info(t.name)c ${j} t.schema='main'AND t.type IN('table','view')AND t.name IN(${W(t)})ORDER BY t.name,c.name`,t),v,p,e,A,a=>!0===a?1:!1===a?0:a,void 0)},Ha=(a,t,e,n,s)=>Ga(a,e,async(a,e=[])=>await t.execO(a,e),a=>t.onUpdate((t,e,n)=>a(n)),a=>a(),n,s,N,1,t);export{Ha as createCrSqliteWasmPersister};
@@ -1 +1 @@
1
- const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),i="true",l="t",r=(a,t,e)=>a.replace(t,e),o=Promise,c=(a=u)=>(t,e,n)=>a(t)?n?.():e(t),d=clearInterval,u=a=>null==a,y=a=>void 0===a,E=a=>null===a,w=c(u),T=c(y),N=t=>a(t)==s,p=a=>Array.isArray(a),_=(a,t,e)=>a.slice(t,e),O=a=>a.length,m=()=>{},v=async a=>o.all(a),A=a=>{throw Error(a)},S=async(a,t,e)=>{try{return await a()}catch(a){t?.(a)}},g=(a,t)=>a.forEach(t),L=(a,t="")=>a.join(t),R=(a,t)=>a.map(t),h=a=>0==O(a),f=(a,t)=>a.filter(t),I=(a,...t)=>a.push(...t),$=a=>a.shift(),b=Object,C=a=>b.getPrototypeOf(a),P=b.entries,D=b.keys,U=b.freeze,x=(a=[])=>b.fromEntries(a),M=(...a)=>b.assign({},...a),X=(a,t)=>t in a,J=(a,t)=>(delete a[t],a),F=(a,t)=>g(P(a),([a,e])=>t(e,a)),V=(a,t)=>R(P(a),([a,e])=>t(e,a)),B=(a,t)=>x(V(a,(a,e)=>[e,t(a,e)])),G=a=>b.values(a),Y=a=>O(D(a)),j=a=>(a=>!u(a)&&w(C(a),a=>a==b.prototype||u(C(a)),()=>!0))(a)&&0==Y(a),z=(a,t,e)=>(X(a,t)||(a[t]=e()),a[t]),k=JSON.stringify,q=JSON.parse,H=(a,t)=>a?.has(t)??!1,K=a=>y(a)||0==(a=>a?.size??0)(a),Q=a=>[...a?.values()??[]],W=(a,t)=>a?.forEach(t),Z=(a,t)=>a?.delete(t),aa=a=>new Map(a),ta=(a,t)=>a?.get(t),ea=(a,t)=>R([...a?.entries()??[]],([a,e])=>t(e,a)),na=(a,t,e)=>void 0===e?(Z(a,t),a):a?.set(t,e),sa=(a,t,e,n)=>(H(a,t)?n?.(ta(a,t)):na(a,t,e()),ta(a,t)),ia=(a,t,e,n,s=0)=>T((e?sa:ta)(a,t[s],s>O(t)-2?e:aa),i=>{if(s>O(t)-2)return n?.(i)&&na(a,t[s]),i;const l=ia(i,t,e,n,s+1);return K(i)&&na(a,t[s]),l}),la=(a,t,e)=>{t>a[1]&&(a[1]=t),a[2]=e>>>0},ra=/^\d+$/,oa=a=>new Set(p(a)||y(a)?a:[a]),ca=(a,t)=>a?.add(t),da=aa(),ua=aa(),ya=(a,t,n,s,i,l,r,o={},c=0,d=[])=>{let u,w,N,_=0,m=0,v=0;sa(da,d,()=>0),sa(ua,d,()=>[]);const L=aa(),[R,h,f,b,C]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!j(a)||!j(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!j(a)||!j(t),t.setContent]:A("Store type not supported by this Persister"))(r,a,c),[P,D,x]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?$(a):null)??e+t++,t=>{ra.test(t)&&O(a)<1e3&&I(a,t)}]})(),s=aa();return[(n,i,l,r=[],o=()=>[])=>{a??=q;const c=t(1);return na(s,c,[n,i,l,r,o]),ca(ia(i,l??[e],oa),c),c},(t,n,...i)=>g(((a,t=[e])=>{const n=[],s=(a,e)=>e==O(t)?I(n,a):null===t[e]?W(a,a=>s(a,e+1)):g([t[e],null],t=>s(ta(a,t),e+1));return s(a,0),n})(t,n),t=>W(t,t=>ta(s,t)[0](a,...n??[],...i))),a=>T(ta(s,a),([,t,i])=>(ia(t,i??[e],void 0,t=>(Z(t,a),K(t)?1:0)),na(s,a),n(a),i)),t=>T(ta(s,t),([t,,e=[],n,s])=>{const i=(...l)=>{const r=O(l);r==O(e)?t(a,...l,...s(l)):E(e[r])?g(n[r]?.(...l)??[],a=>i(...l,a)):i(...l,e[r])};i()})]})(),M=a=>{a!=_&&(_=a,D(L,void 0,_))},X=t=>{(R&&p(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},J=async a=>(2!=_&&(M(1),m++,await k(async()=>{await S(async()=>{const e=await t();p(e)?X(e):a?C(a):A("Content is not an array: "+e)},()=>{a&&C(a)}),M(0)})),q),F=async a=>(V(),await J(a),await S(async()=>w=await s(async(a,t)=>{t||a?2!=_&&(M(1),m++,X(t??a),M(0)):await J()}),l),q),V=async()=>(w&&(await S(()=>i(w),l),w=void 0),q),B=async a=>(1!=_&&(M(2),v++,await k(async()=>{await S(()=>n(h,a),l),M(0)})),q),G=async()=>(Y(),await B(),N=a.addDidFinishTransactionListener(()=>{const a=f();b(a)&&B(a)}),q),Y=async()=>(N&&(a.delListener(N),N=void 0),q),z=async(a=!1)=>{const[t,e]=a?[Y,V]:[V,Y];return await t(),await e(),q},k=async(...a)=>(I(ta(ua,d),...a),await(async()=>{if(!ta(da,d)){for(na(da,d,1);!y(u=$(ta(ua,d)));)await S(u,l);na(da,d,0)}})(),q),q={load:J,startAutoLoad:F,stopAutoLoad:V,isAutoLoading:()=>!y(w),save:B,startAutoSave:G,stopAutoSave:Y,isAutoSaving:()=>!y(N),startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[G,F]:[F,G];return await e(a),await n(a),q},stopAutoPersisting:z,getStatus:()=>_,addStatusListener:a=>P(a,L),delListener:t=>(x(t),a),schedule:k,getStore:()=>a,destroy:()=>(ta(ua,d).splice(0,void 0),z()),getStats:()=>({loads:m,saves:v}),...o};return U(q)},Ea="_",wa="_id",Ta="SELECT",Na="WHERE",pa="TABLE",_a="ALTER "+pa,Oa="FROM",ma="DELETE "+Oa,va=Ta+"*"+Oa,Aa="pragma_",Sa="data_version",ga="schema_version",La="pragma_table_",Ra="CREATE "+pa,ha=a=>L(R(((a,t="",e)=>a.split(t,e))(a,"."),a=>`"${r(a,/"/g,'""')}"`),"."),fa=(a,t=[1])=>L(R(a,()=>"$"+t[0]++),n),Ia=(a,t=i)=>Na+`(${r(t,"$tableName",ha(a))})`,$a="ColumnName",ba="store",Ca="json",Pa=ba+"TableName",Da=ba+"Id"+$a,Ua=ba+$a,xa="autoLoadIntervalSeconds",Ma="rowId"+$a,Xa="tableId",Ja="tableName",Fa="deleteEmptyColumns",Va="deleteEmptyTable",Ba="condition",Ga={mode:Ca,[xa]:1},Ya={load:0,save:0,[Ja]:t+"_values"},ja=(a,t,e,n,s)=>{const i=aa();return B(a,(a,l)=>{const r=_(G(M(t,N(a)?{[e]:a}:a)),0,Y(t));E(r[0])||n(l,r[0])||(s(l,r[0]),na(i,l,r))}),i},za=(a,t,e,s,l,r=ka,o,c)=>{const d=aa();return[async()=>{d.clear(),R(await e(a,t),({tn:a,cn:t})=>ca(sa(d,a,oa),t))},async(t,e,n)=>((a,t)=>H(ta(d,a),t))(t,e)?x(f(R(await a(va+ha(t)+Ia(t,n)),a=>[a[e],c?B(J(a,e),c):J(a,e)]),([a,t])=>!y(a)&&!j(t))):{},async(t,e,s,c,u,E=!1,w=i)=>{const T=oa();B(s??{},a=>R(D(a??{}),a=>ca(T,a)));const N=Q(T);if(!E&&u&&w==i&&h(N)&&H(d,t))return await a("DROP "+pa+ha(t)),void na(d,t);const p=ta(d,t),_=oa(Q(p));if(h(N)||(H(d,t)?await v(R([e,...N],async(n,s)=>{Z(_,n)||(await a(_a+ha(t)+"ADD"+ha(n)+l),0==s&&await a("CREATE UNIQUE INDEX pk ON "+ha(t)+`(${ha(e)})`),ca(p,n))})):(await a(Ra+ha(t)+`(${ha(e)}${l} PRIMARY KEY${L(R(N,a=>n+ha(a)+l))});`),na(d,t,oa([e,...N])))),await v([...!E&&c?R(Q(_),async n=>{n!=e&&(await a(_a+ha(t)+"DROP"+ha(n)),Z(p,n))}):[]]),E)y(s)?await a(ma+ha(t)+Ia(t,w)):await v(V(s,async(n,s)=>{y(n)?await a(ma+ha(t)+Ia(t,w)+`AND(${ha(e)}=$1)`,[s]):h(N)||await r(a,t,e,D(n),{[s]:o?R(G(n),o):G(n)},p)}));else if(h(N))H(d,t)&&await a(ma+ha(t)+Ia(t,w));else{const n=f(Q(ta(d,t)),a=>a!=e),i={},l=[];B(s??{},(a,t)=>{i[t]=R(n,t=>o?o(a?.[t]):a?.[t]),I(l,t)}),await r(a,t,e,n,i),await a(ma+ha(t)+Ia(t,w)+`AND${ha(e)}NOT IN(${fa(l)})`,l)}},async t=>{let e;return await a("BEGIN"),await S(async()=>e=await t(),s),await a("END"),e}]},ka=async(a,t,e,s,i)=>{const l=[1];await a("INSERT INTO"+ha(t)+"("+((...a)=>L(R(a,ha),n))(e,...s)+")VALUES"+L(V(i,a=>"($"+l[0]+++","+fa(a,l)+")"),n)+"ON CONFLICT("+ha(e)+")DO UPDATE SET"+L(R(s,a=>ha(a)+"=excluded."+ha(a)),n),V(i,(a,t)=>[t,...R(a,a=>a??null)]).flat())},qa=(a,t,e,n,s,i,l,[r,o,c],d,u,y,E,w,T)=>{const[N,p,_,O]=za(t,d,u,s,w,T),m=ya(a,()=>O(async()=>{return await N(),a=(await p(r,o))[Ea]?.[c]??"null",q(a,(a,t)=>""===t?void 0:t);var a}),a=>O(async()=>{var t;await N(),await _(r,o,{[Ea]:{[c]:(t=a()??null,k(t,(a,t)=>void 0===t?"":t))}},!0,!0)}),e,n,s,l,{[E]:()=>y,destroy:async()=>(await m.stopAutoPersisting(),i(),m)},0,y);return m},Ha=(a,t,e,n,s,i,l,[r,o,[c,d,u]],E,w,T,N,p,_,O,m)=>{const[A,S,g,L]=za(t,E,w,s,p,_,O,m),R=(a,t)=>v(ea(o,async([e,n,s,i,l],r)=>{t&&!X(a,r)||await g(e,n,a[r],s,i,t,l)})),h=async(a,t)=>d?await g(u,wa,{[Ea]:a},!0,!0,t):null,I=ya(a,()=>L(async()=>{await A();const a=await(async()=>x(f(await v(ea(r,async([a,t,e],n)=>[a,await S(n,t,e)])),a=>!j(a[1]))))(),t=await(async()=>c?(await S(u,wa))[Ea]:{})();return j(a)&&y(t)?void 0:[a,t]}),(a,t)=>L(async()=>{if(await A(),y(t)){const[t,e]=a();await R(t),await h(e)}else await R(t[0],!0),await h(t[1],!0)}),e,n,s,l,{[N]:()=>T,destroy:async()=>(await I.stopAutoPersisting(),i(),I)},0,T);return I},Ka=(a,n,s,l,r,o,c,y,E,w,T="getDb",p)=>{let O,m,v;const A=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,o),[g,L,R,h]=(a=>{const e=(a=>M(Ga,N(a)?{[Pa]:a}:a??{}))(a),n=e[xa];if(e.mode==Ca){const a=e[Pa]??t;return[1,n,[a,e[Da]??wa,e[Ua]??ba],oa(a)]}const{tables:{load:s={},save:l={}}={},values:r={}}=e,o=_(G(M(Ya,r)),0,Y(Ya)),c=o[2],d=oa(c),u=oa(c),y=ja(s,{[Xa]:null,[Ma]:wa,[Ba]:i},Xa,a=>H(u,a),a=>ca(d,a)),E=ja(l,{[Ja]:null,[Ma]:wa,[Fa]:0,[Va]:0,[Ba]:null},Ja,(a,t)=>H(u,t),(a,t)=>ca(d,t));var w;return w=(a,t)=>t[4]??=ta(y,t[0])?.[2]??i,W(E,(a,t)=>w(0,a)),[0,n,[y,E,o],d]})(n);return(g?qa:Ha)(a,A,a=>{let t;const e=()=>t=setInterval(()=>S(async()=>{const[{d:t,s:e,c:n}]=await A(Ta+` ${Sa} d,${ga} s,TOTAL_CHANGES() c FROM ${Aa}${Sa} JOIN ${Aa}${ga}`);t==O&&e==m&&n==v||(u(O)||a(),O=t,m=e,v=n)}),1e3*L),n=()=>{O=m=v=null,d(t)},s=l(t=>{h.has(t)&&(n(),a(),e())});return e(),()=>{n(),r(s)}},a=>a(),c,y,E,R,Q(h),async(a,t)=>await a(Ta+` t.name tn,c.name cn FROM ${La}list()t,${La}info(t.name)c ${Na} t.schema='main'AND t.type IN('table','view')AND t.name IN(${fa(t)})ORDER BY t.name,c.name`,t),w,T,e,p,a=>!0===a?1:!1===a?0:a,void 0)},Qa=(a,t,n,s,i)=>"object"==typeof n&&"fragmented"===n.mode?Za(a,t,n?.storagePrefix??e,i):Ka(a,n,async(a,e=[])=>["BEGIN","END"].includes(a)?[]:(a=a.replace(/\$\d+/g,"?"),t.exec(a,...e).toArray()),()=>m,a=>a(),s,i,m,2,t,"getSqlStorage"),Wa=()=>[{},e,0],Za=(a,t,e="",n)=>{const s=e.replace(/[^a-zA-Z0-9_]/g,"_"),i=s+"tinybase_tables",r=s+"tinybase_values";return t.exec(`\n CREATE TABLE IF NOT EXISTS ${i} (\n type TEXT NOT NULL,\n table_id TEXT,\n row_id TEXT,\n cell_id TEXT,\n value_data TEXT NOT NULL,\n timestamp TEXT NOT NULL,\n hash INTEGER NOT NULL,\n PRIMARY KEY (type, table_id, row_id, cell_id)\n );\n \n CREATE TABLE IF NOT EXISTS ${r} (\n value_id TEXT,\n value_data TEXT NOT NULL,\n timestamp TEXT NOT NULL,\n hash INTEGER NOT NULL\n );\n `),ya(a,async()=>{const a=Wa(),e=Wa(),n=t.exec("SELECT * FROM "+i);for(const t of n.toArray()){const e=t.type+"",n=t.table_id?t.table_id+"":null,s=t.row_id?t.row_id+"":null,i=t.cell_id?t.cell_id+"":null,r=t.value_data+"",o=t.timestamp+"",c=Number(t.hash),[d]=JSON.parse(r);if(e===l)if(n&&s&&i){const t=z(a[0],n,Wa);z(t[0],s,Wa)[0][i]=[d,o,c]}else if(n&&s){const t=z(a[0],n,Wa),e=z(t[0],s,Wa);la(e,o,c)}else if(n){const t=z(a[0],n,Wa);la(t,o,c)}else la(a,o,c)}const s=t.exec("SELECT * FROM "+r);for(const a of s.toArray()){const t=a.value_id?a.value_id+"":null,n=a.value_data+"",s=a.timestamp+"",i=Number(a.hash),[l]=JSON.parse(n);t?e[0][t]=[l,s,i]:la(e,s,i)}return[a,e]},async(a,[[e,n,s],[o,c,d]]=a())=>{t.exec(`INSERT OR REPLACE INTO ${i} (type, table_id, row_id, cell_id, value_data, timestamp, hash) VALUES (?, ?, ?, ?, ?, ?, ?)`,l,null,null,null,JSON.stringify([0]),n,s),F(e,([a,e,n],s)=>{t.exec(`INSERT OR REPLACE INTO ${i} (type, table_id, row_id, cell_id, value_data, timestamp, hash) VALUES (?, ?, ?, ?, ?, ?, ?)`,l,s,null,null,JSON.stringify([0]),e,n),F(a,([a,e,n],r)=>{t.exec(`INSERT OR REPLACE INTO ${i} (type, table_id, row_id, cell_id, value_data, timestamp, hash) VALUES (?, ?, ?, ?, ?, ?, ?)`,l,s,r,null,JSON.stringify([0]),e,n),F(a,(a,e)=>{t.exec(`INSERT OR REPLACE INTO ${i} (type, table_id, row_id, cell_id, value_data, timestamp, hash) VALUES (?, ?, ?, ?, ?, ?, ?)`,l,s,r,e,JSON.stringify([a[0]]),a[1],a[2])})})}),t.exec(`INSERT OR REPLACE INTO ${r} (value_id, value_data, timestamp, hash) VALUES (?, ?, ?, ?)`,null,JSON.stringify([0]),c,d),F(o,(a,e)=>{t.exec(`INSERT OR REPLACE INTO ${r} (value_id, value_data, timestamp, hash) VALUES (?, ?, ?, ?)`,e,JSON.stringify([a[0]]),a[1],a[2])})},m,m,n,2,{getSqlStorage:()=>t})};export{Qa as createDurableObjectSqlStoragePersister};
1
+ const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),i="true",l="t",r=(a,t,e)=>a.replace(t,e),o=Promise,c=a=>(t,e,n)=>a(t)?n?.():e(t),d=clearInterval,u=a=>null==a,y=a=>void 0===a,E=a=>null===a,w=c(u),T=c(y),N=t=>a(t)==s,p=a=>Array.isArray(a),_=(a,t,e)=>a.slice(t,e),O=a=>a.length,m=()=>{},v=async a=>o.all(a),A=a=>{throw Error(a)},S=async(a,t,e)=>{try{return await a()}catch(a){t?.(a)}},g=(a,t)=>a.forEach(t),L=(a,t="")=>a.join(t),R=(a,t)=>a.map(t),h=a=>0==O(a),f=(a,t)=>a.filter(t),I=(a,...t)=>a.push(...t),$=a=>a.shift(),b=Object,C=a=>b.getPrototypeOf(a),P=b.entries,D=b.keys,U=b.freeze,x=(a=[])=>b.fromEntries(a),M=(...a)=>b.assign({},...a),X=(a,t)=>t in a,J=(a,t)=>(delete a[t],a),F=(a,t)=>g(P(a),([a,e])=>t(e,a)),V=(a,t)=>R(P(a),([a,e])=>t(e,a)),B=(a,t)=>x(V(a,(a,e)=>[e,t(a,e)])),G=a=>b.values(a),Y=a=>O(D(a)),j=a=>(a=>!u(a)&&w(C(a),a=>a==b.prototype||u(C(a)),()=>!0))(a)&&0==Y(a),z=(a,t,e)=>(X(a,t)||(a[t]=e()),a[t]),k=JSON.stringify,q=JSON.parse,H=(a,t)=>a?.has(t)??!1,K=a=>y(a)||0==(a=>a?.size??0)(a),Q=a=>[...a?.values()??[]],W=(a,t)=>a?.forEach(t),Z=(a,t)=>a?.delete(t),aa=a=>new Map(a),ta=(a,t)=>a?.get(t),ea=(a,t)=>R([...a?.entries()??[]],([a,e])=>t(e,a)),na=(a,t,e)=>void 0===e?(Z(a,t),a):a?.set(t,e),sa=(a,t,e,n)=>(H(a,t)?n?.(ta(a,t)):na(a,t,e()),ta(a,t)),ia=(a,t,e,n,s=0)=>T((e?sa:ta)(a,t[s],s>O(t)-2?e:aa),i=>{if(s>O(t)-2)return n?.(i)&&na(a,t[s]),i;const l=ia(i,t,e,n,s+1);return K(i)&&na(a,t[s]),l}),la=(a,t,e)=>{t>a[1]&&(a[1]=t),a[2]=e>>>0},ra=/^\d+$/,oa=a=>new Set(p(a)||y(a)?a:[a]),ca=(a,t)=>a?.add(t),da=aa(),ua=aa(),ya=(a,t,n,s,i,l,r,o={},c=0,d=[])=>{let u,w,N,_=0,m=0,v=0;sa(da,d,()=>0),sa(ua,d,()=>[]);const L=aa(),[R,h,f,b,C]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!j(a)||!j(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!j(a)||!j(t),t.setContent]:A("Store type not supported by this Persister"))(r,a,c),[P,D,x]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?$(a):null)??e+t++,t=>{ra.test(t)&&O(a)<1e3&&I(a,t)}]})(),s=aa();return[(n,i,l,r=[],o=()=>[])=>{a??=q;const c=t(1);return na(s,c,[n,i,l,r,o]),ca(ia(i,l??[e],oa),c),c},(t,n,...i)=>g(((a,t=[e])=>{const n=[],s=(a,e)=>e==O(t)?I(n,a):null===t[e]?W(a,a=>s(a,e+1)):g([t[e],null],t=>s(ta(a,t),e+1));return s(a,0),n})(t,n),t=>W(t,t=>ta(s,t)[0](a,...n??[],...i))),a=>T(ta(s,a),([,t,i])=>(ia(t,i??[e],void 0,t=>(Z(t,a),K(t)?1:0)),na(s,a),n(a),i)),t=>T(ta(s,t),([t,,e=[],n,s])=>{const i=(...l)=>{const r=O(l);r==O(e)?t(a,...l,...s(l)):E(e[r])?g(n[r]?.(...l)??[],a=>i(...l,a)):i(...l,e[r])};i()})]})(),M=a=>{a!=_&&(_=a,D(L,void 0,_))},X=t=>{(R&&p(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},J=async a=>(2!=_&&(M(1),m++,await k(async()=>{await S(async()=>{const e=await t();p(e)?X(e):a?C(a):A("Content is not an array: "+e)},()=>{a&&C(a)}),M(0)})),q),F=async a=>(V(),await J(a),await S(async()=>w=await s(async(a,t)=>{t||a?2!=_&&(M(1),m++,X(t??a),M(0)):await J()}),l),q),V=async()=>(w&&(await S(()=>i(w),l),w=void 0),q),B=async a=>(1!=_&&(M(2),v++,await k(async()=>{await S(()=>n(h,a),l),M(0)})),q),G=async()=>(Y(),await B(),N=a.addDidFinishTransactionListener(()=>{const a=f();b(a)&&B(a)}),q),Y=async()=>(N&&(a.delListener(N),N=void 0),q),z=async(a=!1)=>{const[t,e]=a?[Y,V]:[V,Y];return await t(),await e(),q},k=async(...a)=>(I(ta(ua,d),...a),await(async()=>{if(!ta(da,d)){for(na(da,d,1);!y(u=$(ta(ua,d)));)await S(u,l);na(da,d,0)}})(),q),q={load:J,startAutoLoad:F,stopAutoLoad:V,isAutoLoading:()=>!y(w),save:B,startAutoSave:G,stopAutoSave:Y,isAutoSaving:()=>!y(N),startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[G,F]:[F,G];return await e(a),await n(a),q},stopAutoPersisting:z,getStatus:()=>_,addStatusListener:a=>P(a,L),delListener:t=>(x(t),a),schedule:k,getStore:()=>a,destroy:()=>(ta(ua,d).splice(0,void 0),z()),getStats:()=>({loads:m,saves:v}),...o};return U(q)},Ea="_",wa="_id",Ta="SELECT",Na="WHERE",pa="TABLE",_a="ALTER "+pa,Oa="FROM",ma="DELETE "+Oa,va=Ta+"*"+Oa,Aa="pragma_",Sa="data_version",ga="schema_version",La="pragma_table_",Ra="CREATE "+pa,ha=a=>L(R(((a,t="",e)=>a.split(t,e))(a,"."),a=>`"${r(a,/"/g,'""')}"`),"."),fa=(a,t=[1])=>L(R(a,()=>"$"+t[0]++),n),Ia=(a,t=i)=>Na+`(${r(t,"$tableName",ha(a))})`,$a="ColumnName",ba="store",Ca="json",Pa=ba+"TableName",Da=ba+"Id"+$a,Ua=ba+$a,xa="autoLoadIntervalSeconds",Ma="rowId"+$a,Xa="tableId",Ja="tableName",Fa="deleteEmptyColumns",Va="deleteEmptyTable",Ba="condition",Ga={mode:Ca,[xa]:1},Ya={load:0,save:0,[Ja]:t+"_values"},ja=(a,t,e,n,s)=>{const i=aa();return B(a,(a,l)=>{const r=_(G(M(t,N(a)?{[e]:a}:a)),0,Y(t));E(r[0])||n(l,r[0])||(s(l,r[0]),na(i,l,r))}),i},za=(a,t,e,s,l,r=ka,o,c)=>{const d=aa();return[async()=>{d.clear(),R(await e(a,t),({tn:a,cn:t})=>ca(sa(d,a,oa),t))},async(t,e,n)=>((a,t)=>H(ta(d,a),t))(t,e)?x(f(R(await a(va+ha(t)+Ia(t,n)),a=>[a[e],c?B(J(a,e),c):J(a,e)]),([a,t])=>!y(a)&&!j(t))):{},async(t,e,s,c,u,E=!1,w=i)=>{const T=oa();B(s??{},a=>R(D(a??{}),a=>ca(T,a)));const N=Q(T);if(!E&&u&&w==i&&h(N)&&H(d,t))return await a("DROP "+pa+ha(t)),void na(d,t);const p=ta(d,t),_=oa(Q(p));if(h(N)||(H(d,t)?await v(R([e,...N],async(n,s)=>{Z(_,n)||(await a(_a+ha(t)+"ADD"+ha(n)+l),0==s&&await a("CREATE UNIQUE INDEX pk ON "+ha(t)+`(${ha(e)})`),ca(p,n))})):(await a(Ra+ha(t)+`(${ha(e)}${l} PRIMARY KEY${L(R(N,a=>n+ha(a)+l))});`),na(d,t,oa([e,...N])))),await v([...!E&&c?R(Q(_),async n=>{n!=e&&(await a(_a+ha(t)+"DROP"+ha(n)),Z(p,n))}):[]]),E)y(s)?await a(ma+ha(t)+Ia(t,w)):await v(V(s,async(n,s)=>{y(n)?await a(ma+ha(t)+Ia(t,w)+`AND(${ha(e)}=$1)`,[s]):h(N)||await r(a,t,e,D(n),{[s]:o?R(G(n),o):G(n)},p)}));else if(h(N))H(d,t)&&await a(ma+ha(t)+Ia(t,w));else{const n=f(Q(ta(d,t)),a=>a!=e),i={},l=[];B(s??{},(a,t)=>{i[t]=R(n,t=>o?o(a?.[t]):a?.[t]),I(l,t)}),await r(a,t,e,n,i),await a(ma+ha(t)+Ia(t,w)+`AND${ha(e)}NOT IN(${fa(l)})`,l)}},async t=>{let e;return await a("BEGIN"),await S(async()=>e=await t(),s),await a("END"),e}]},ka=async(a,t,e,s,i)=>{const l=[1];await a("INSERT INTO"+ha(t)+"("+((...a)=>L(R(a,ha),n))(e,...s)+")VALUES"+L(V(i,a=>"($"+l[0]+++","+fa(a,l)+")"),n)+"ON CONFLICT("+ha(e)+")DO UPDATE SET"+L(R(s,a=>ha(a)+"=excluded."+ha(a)),n),V(i,(a,t)=>[t,...R(a,a=>a??null)]).flat())},qa=(a,t,e,n,s,i,l,[r,o,c],d,u,y,E,w,T)=>{const[N,p,_,O]=za(t,d,u,s,w,T),m=ya(a,()=>O(async()=>{return await N(),a=(await p(r,o))[Ea]?.[c]??"null",q(a,(a,t)=>""===t?void 0:t);var a}),a=>O(async()=>{var t;await N(),await _(r,o,{[Ea]:{[c]:(t=a()??null,k(t,(a,t)=>void 0===t?"":t))}},!0,!0)}),e,n,s,l,{[E]:()=>y,destroy:async()=>(await m.stopAutoPersisting(),i(),m)},0,y);return m},Ha=(a,t,e,n,s,i,l,[r,o,[c,d,u]],E,w,T,N,p,_,O,m)=>{const[A,S,g,L]=za(t,E,w,s,p,_,O,m),R=(a,t)=>v(ea(o,async([e,n,s,i,l],r)=>{t&&!X(a,r)||await g(e,n,a[r],s,i,t,l)})),h=async(a,t)=>d?await g(u,wa,{[Ea]:a},!0,!0,t):null,I=ya(a,()=>L(async()=>{await A();const a=await(async()=>x(f(await v(ea(r,async([a,t,e],n)=>[a,await S(n,t,e)])),a=>!j(a[1]))))(),t=await(async()=>c?(await S(u,wa))[Ea]:{})();return j(a)&&y(t)?void 0:[a,t]}),(a,t)=>L(async()=>{if(await A(),y(t)){const[t,e]=a();await R(t),await h(e)}else await R(t[0],!0),await h(t[1],!0)}),e,n,s,l,{[N]:()=>T,destroy:async()=>(await I.stopAutoPersisting(),i(),I)},0,T);return I},Ka=(a,n,s,l,r,o,c,y,E,w,T="getDb",p)=>{let O,m,v;const A=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,o),[g,L,R,h]=(a=>{const e=(a=>M(Ga,N(a)?{[Pa]:a}:a??{}))(a),n=e[xa];if(e.mode==Ca){const a=e[Pa]??t;return[1,n,[a,e[Da]??wa,e[Ua]??ba],oa(a)]}const{tables:{load:s={},save:l={}}={},values:r={}}=e,o=_(G(M(Ya,r)),0,Y(Ya)),c=o[2],d=oa(c),u=oa(c),y=ja(s,{[Xa]:null,[Ma]:wa,[Ba]:i},Xa,a=>H(u,a),a=>ca(d,a)),E=ja(l,{[Ja]:null,[Ma]:wa,[Fa]:0,[Va]:0,[Ba]:null},Ja,(a,t)=>H(u,t),(a,t)=>ca(d,t));var w;return w=(a,t)=>t[4]??=ta(y,t[0])?.[2]??i,W(E,(a,t)=>w(0,a)),[0,n,[y,E,o],d]})(n);return(g?qa:Ha)(a,A,a=>{let t;const e=()=>t=setInterval(()=>S(async()=>{const[{d:t,s:e,c:n}]=await A(Ta+` ${Sa} d,${ga} s,TOTAL_CHANGES() c FROM ${Aa}${Sa} JOIN ${Aa}${ga}`);t==O&&e==m&&n==v||(u(O)||a(),O=t,m=e,v=n)}),1e3*L),n=()=>{O=m=v=null,d(t)},s=l(t=>{h.has(t)&&(n(),a(),e())});return e(),()=>{n(),r(s)}},a=>a(),c,y,E,R,Q(h),async(a,t)=>await a(Ta+` t.name tn,c.name cn FROM ${La}list()t,${La}info(t.name)c ${Na} t.schema='main'AND t.type IN('table','view')AND t.name IN(${fa(t)})ORDER BY t.name,c.name`,t),w,T,e,p,a=>!0===a?1:!1===a?0:a,void 0)},Qa=(a,t,n,s,i)=>"object"==typeof n&&"fragmented"===n.mode?Za(a,t,n?.storagePrefix??e,i):Ka(a,n,async(a,e=[])=>["BEGIN","END"].includes(a)?[]:(a=a.replace(/\$\d+/g,"?"),t.exec(a,...e).toArray()),()=>m,a=>a(),s,i,m,2,t,"getSqlStorage"),Wa=()=>[{},e,0],Za=(a,t,e="",n)=>{const s=e.replace(/[^a-zA-Z0-9_]/g,"_"),i=s+"tinybase_tables",r=s+"tinybase_values";return t.exec(`\n CREATE TABLE IF NOT EXISTS ${i} (\n type TEXT NOT NULL,\n table_id TEXT,\n row_id TEXT,\n cell_id TEXT,\n value_data TEXT NOT NULL,\n timestamp TEXT NOT NULL,\n hash INTEGER NOT NULL,\n PRIMARY KEY (type, table_id, row_id, cell_id)\n );\n \n CREATE TABLE IF NOT EXISTS ${r} (\n value_id TEXT,\n value_data TEXT NOT NULL,\n timestamp TEXT NOT NULL,\n hash INTEGER NOT NULL\n );\n `),ya(a,async()=>{const a=Wa(),e=Wa(),n=t.exec("SELECT * FROM "+i);for(const t of n.toArray()){const e=t.type+"",n=t.table_id?t.table_id+"":null,s=t.row_id?t.row_id+"":null,i=t.cell_id?t.cell_id+"":null,r=t.value_data+"",o=t.timestamp+"",c=Number(t.hash),[d]=JSON.parse(r);if(e===l)if(n&&s&&i){const t=z(a[0],n,Wa);z(t[0],s,Wa)[0][i]=[d,o,c]}else if(n&&s){const t=z(a[0],n,Wa),e=z(t[0],s,Wa);la(e,o,c)}else if(n){const t=z(a[0],n,Wa);la(t,o,c)}else la(a,o,c)}const s=t.exec("SELECT * FROM "+r);for(const a of s.toArray()){const t=a.value_id?a.value_id+"":null,n=a.value_data+"",s=a.timestamp+"",i=Number(a.hash),[l]=JSON.parse(n);t?e[0][t]=[l,s,i]:la(e,s,i)}return[a,e]},async(a,[[e,n,s],[o,c,d]]=a())=>{t.exec(`INSERT OR REPLACE INTO ${i} (type, table_id, row_id, cell_id, value_data, timestamp, hash) VALUES (?, ?, ?, ?, ?, ?, ?)`,l,null,null,null,JSON.stringify([0]),n,s),F(e,([a,e,n],s)=>{t.exec(`INSERT OR REPLACE INTO ${i} (type, table_id, row_id, cell_id, value_data, timestamp, hash) VALUES (?, ?, ?, ?, ?, ?, ?)`,l,s,null,null,JSON.stringify([0]),e,n),F(a,([a,e,n],r)=>{t.exec(`INSERT OR REPLACE INTO ${i} (type, table_id, row_id, cell_id, value_data, timestamp, hash) VALUES (?, ?, ?, ?, ?, ?, ?)`,l,s,r,null,JSON.stringify([0]),e,n),F(a,(a,e)=>{t.exec(`INSERT OR REPLACE INTO ${i} (type, table_id, row_id, cell_id, value_data, timestamp, hash) VALUES (?, ?, ?, ?, ?, ?, ?)`,l,s,r,e,JSON.stringify([a[0]]),a[1],a[2])})})}),t.exec(`INSERT OR REPLACE INTO ${r} (value_id, value_data, timestamp, hash) VALUES (?, ?, ?, ?)`,null,JSON.stringify([0]),c,d),F(o,(a,e)=>{t.exec(`INSERT OR REPLACE INTO ${r} (value_id, value_data, timestamp, hash) VALUES (?, ?, ?, ?)`,e,JSON.stringify([a[0]]),a[1],a[2])})},m,m,n,2,{getSqlStorage:()=>t})};export{Qa as createDurableObjectSqlStoragePersister};
@@ -1 +1 @@
1
- const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),i="true",l="t",r=(a,t,e)=>a.replace(t,e),o=Promise,c=(a=u)=>(t,e,n)=>a(t)?n?.():e(t),d=clearInterval,u=a=>null==a,y=a=>void 0===a,E=a=>null===a,w=c(u),T=c(y),N=t=>a(t)==s,p=a=>Array.isArray(a),_=(a,t,e)=>a.slice(t,e),O=a=>a.length,m=()=>{},v=async a=>o.all(a),A=a=>{throw Error(a)},S=async(a,t,e)=>{try{return await a()}catch(a){t?.(a)}},g=(a,t)=>a.forEach(t),L=(a,t="")=>a.join(t),R=(a,t)=>a.map(t),h=a=>0==O(a),f=(a,t)=>a.filter(t),I=(a,...t)=>a.push(...t),$=a=>a.shift(),b=Object,C=a=>b.getPrototypeOf(a),P=b.entries,D=b.keys,U=b.freeze,x=(a=[])=>b.fromEntries(a),M=(...a)=>b.assign({},...a),X=(a,t)=>t in a,J=(a,t)=>(delete a[t],a),F=(a,t)=>g(P(a),([a,e])=>t(e,a)),V=(a,t)=>R(P(a),([a,e])=>t(e,a)),B=(a,t)=>x(V(a,(a,e)=>[e,t(a,e)])),G=a=>b.values(a),Y=a=>O(D(a)),j=a=>(a=>!u(a)&&w(C(a),a=>a==b.prototype||u(C(a)),()=>!0))(a)&&0==Y(a),z=(a,t,e)=>(X(a,t)||(a[t]=e()),a[t]),k=JSON.stringify,q=JSON.parse,H=(a,t)=>a?.has(t)??!1,K=a=>y(a)||0==(a=>a?.size??0)(a),Q=a=>[...a?.values()??[]],W=(a,t)=>a?.forEach(t),Z=(a,t)=>a?.delete(t),aa=a=>new Map(a),ta=(a,t)=>a?.get(t),ea=(a,t)=>R([...a?.entries()??[]],([a,e])=>t(e,a)),na=(a,t,e)=>void 0===e?(Z(a,t),a):a?.set(t,e),sa=(a,t,e,n)=>(H(a,t)?n?.(ta(a,t)):na(a,t,e()),ta(a,t)),ia=(a,t,e,n,s=0)=>T((e?sa:ta)(a,t[s],s>O(t)-2?e:aa),i=>{if(s>O(t)-2)return n?.(i)&&na(a,t[s]),i;const l=ia(i,t,e,n,s+1);return K(i)&&na(a,t[s]),l}),la=(a,t,e)=>{t>a[1]&&(a[1]=t),a[2]=e>>>0},ra=/^\d+$/,oa=a=>new Set(p(a)||y(a)?a:[a]),ca=(a,t)=>a?.add(t),da=aa(),ua=aa(),ya=(a,t,n,s,i,l,r,o={},c=0,d=[])=>{let u,w,N,_=0,m=0,v=0;sa(da,d,()=>0),sa(ua,d,()=>[]);const L=aa(),[R,h,f,b,C]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!j(a)||!j(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!j(a)||!j(t),t.setContent]:A("Store type not supported by this Persister"))(r,a,c),[P,D,x]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?$(a):null)??e+t++,t=>{ra.test(t)&&O(a)<1e3&&I(a,t)}]})(),s=aa();return[(n,i,l,r=[],o=()=>[])=>{a??=q;const c=t(1);return na(s,c,[n,i,l,r,o]),ca(ia(i,l??[e],oa),c),c},(t,n,...i)=>g(((a,t=[e])=>{const n=[],s=(a,e)=>e==O(t)?I(n,a):null===t[e]?W(a,a=>s(a,e+1)):g([t[e],null],t=>s(ta(a,t),e+1));return s(a,0),n})(t,n),t=>W(t,t=>ta(s,t)[0](a,...n??[],...i))),a=>T(ta(s,a),([,t,i])=>(ia(t,i??[e],void 0,t=>(Z(t,a),K(t)?1:0)),na(s,a),n(a),i)),t=>T(ta(s,t),([t,,e=[],n,s])=>{const i=(...l)=>{const r=O(l);r==O(e)?t(a,...l,...s(l)):E(e[r])?g(n[r]?.(...l)??[],a=>i(...l,a)):i(...l,e[r])};i()})]})(),M=a=>{a!=_&&(_=a,D(L,void 0,_))},X=t=>{(R&&p(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},J=async a=>(2!=_&&(M(1),m++,await k(async()=>{await S(async()=>{const e=await t();p(e)?X(e):a?C(a):A("Content is not an array: "+e)},()=>{a&&C(a)}),M(0)})),q),F=async a=>(V(),await J(a),await S(async()=>w=await s(async(a,t)=>{t||a?2!=_&&(M(1),m++,X(t??a),M(0)):await J()}),l),q),V=async()=>(w&&(await S(()=>i(w),l),w=void 0),q),B=async a=>(1!=_&&(M(2),v++,await k(async()=>{await S(()=>n(h,a),l),M(0)})),q),G=async()=>(Y(),await B(),N=a.addDidFinishTransactionListener(()=>{const a=f();b(a)&&B(a)}),q),Y=async()=>(N&&(a.delListener(N),N=void 0),q),z=async(a=!1)=>{const[t,e]=a?[Y,V]:[V,Y];return await t(),await e(),q},k=async(...a)=>(I(ta(ua,d),...a),await(async()=>{if(!ta(da,d)){for(na(da,d,1);!y(u=$(ta(ua,d)));)await S(u,l);na(da,d,0)}})(),q),q={load:J,startAutoLoad:F,stopAutoLoad:V,isAutoLoading:()=>!y(w),save:B,startAutoSave:G,stopAutoSave:Y,isAutoSaving:()=>!y(N),startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[G,F]:[F,G];return await e(a),await n(a),q},stopAutoPersisting:z,getStatus:()=>_,addStatusListener:a=>P(a,L),delListener:t=>(x(t),a),schedule:k,getStore:()=>a,destroy:()=>(ta(ua,d).splice(0,void 0),z()),getStats:()=>({loads:m,saves:v}),...o};return U(q)},Ea="_",wa="_id",Ta="SELECT",Na="WHERE",pa="TABLE",_a="ALTER "+pa,Oa="FROM",ma="DELETE "+Oa,va=Ta+"*"+Oa,Aa="pragma_",Sa="data_version",ga="schema_version",La="pragma_table_",Ra="CREATE "+pa,ha=a=>L(R(((a,t="",e)=>a.split(t,e))(a,"."),a=>`"${r(a,/"/g,'""')}"`),"."),fa=(a,t=[1])=>L(R(a,()=>"$"+t[0]++),n),Ia=(a,t=i)=>Na+`(${r(t,"$tableName",ha(a))})`,$a="ColumnName",ba="store",Ca="json",Pa=ba+"TableName",Da=ba+"Id"+$a,Ua=ba+$a,xa="autoLoadIntervalSeconds",Ma="rowId"+$a,Xa="tableId",Ja="tableName",Fa="deleteEmptyColumns",Va="deleteEmptyTable",Ba="condition",Ga={mode:Ca,[xa]:1},Ya={load:0,save:0,[Ja]:t+"_values"},ja=(a,t,e,n,s)=>{const i=aa();return B(a,(a,l)=>{const r=_(G(M(t,N(a)?{[e]:a}:a)),0,Y(t));E(r[0])||n(l,r[0])||(s(l,r[0]),na(i,l,r))}),i},za=(a,t,e,s,l,r=ka,o,c)=>{const d=aa();return[async()=>{d.clear(),R(await e(a,t),({tn:a,cn:t})=>ca(sa(d,a,oa),t))},async(t,e,n)=>((a,t)=>H(ta(d,a),t))(t,e)?x(f(R(await a(va+ha(t)+Ia(t,n)),a=>[a[e],c?B(J(a,e),c):J(a,e)]),([a,t])=>!y(a)&&!j(t))):{},async(t,e,s,c,u,E=!1,w=i)=>{const T=oa();B(s??{},a=>R(D(a??{}),a=>ca(T,a)));const N=Q(T);if(!E&&u&&w==i&&h(N)&&H(d,t))return await a("DROP "+pa+ha(t)),void na(d,t);const p=ta(d,t),_=oa(Q(p));if(h(N)||(H(d,t)?await v(R([e,...N],async(n,s)=>{Z(_,n)||(await a(_a+ha(t)+"ADD"+ha(n)+l),0==s&&await a("CREATE UNIQUE INDEX pk ON "+ha(t)+`(${ha(e)})`),ca(p,n))})):(await a(Ra+ha(t)+`(${ha(e)}${l} PRIMARY KEY${L(R(N,a=>n+ha(a)+l))});`),na(d,t,oa([e,...N])))),await v([...!E&&c?R(Q(_),async n=>{n!=e&&(await a(_a+ha(t)+"DROP"+ha(n)),Z(p,n))}):[]]),E)y(s)?await a(ma+ha(t)+Ia(t,w)):await v(V(s,async(n,s)=>{y(n)?await a(ma+ha(t)+Ia(t,w)+`AND(${ha(e)}=$1)`,[s]):h(N)||await r(a,t,e,D(n),{[s]:o?R(G(n),o):G(n)},p)}));else if(h(N))H(d,t)&&await a(ma+ha(t)+Ia(t,w));else{const n=f(Q(ta(d,t)),a=>a!=e),i={},l=[];B(s??{},(a,t)=>{i[t]=R(n,t=>o?o(a?.[t]):a?.[t]),I(l,t)}),await r(a,t,e,n,i),await a(ma+ha(t)+Ia(t,w)+`AND${ha(e)}NOT IN(${fa(l)})`,l)}},async t=>{let e;return await a("BEGIN"),await S(async()=>e=await t(),s),await a("END"),e}]},ka=async(a,t,e,s,i)=>{const l=[1];await a("INSERT INTO"+ha(t)+"("+((...a)=>L(R(a,ha),n))(e,...s)+")VALUES"+L(V(i,a=>"($"+l[0]+++","+fa(a,l)+")"),n)+"ON CONFLICT("+ha(e)+")DO UPDATE SET"+L(R(s,a=>ha(a)+"=excluded."+ha(a)),n),V(i,(a,t)=>[t,...R(a,a=>a??null)]).flat())},qa=(a,t,e,n,s,i,l,[r,o,c],d,u,y,E,w,T)=>{const[N,p,_,O]=za(t,d,u,s,w,T),m=ya(a,()=>O(async()=>{return await N(),a=(await p(r,o))[Ea]?.[c]??"null",q(a,(a,t)=>""===t?void 0:t);var a}),a=>O(async()=>{var t;await N(),await _(r,o,{[Ea]:{[c]:(t=a()??null,k(t,(a,t)=>void 0===t?"":t))}},!0,!0)}),e,n,s,l,{[E]:()=>y,destroy:async()=>(await m.stopAutoPersisting(),i(),m)},0,y);return m},Ha=(a,t,e,n,s,i,l,[r,o,[c,d,u]],E,w,T,N,p,_,O,m)=>{const[A,S,g,L]=za(t,E,w,s,p,_,O,m),R=(a,t)=>v(ea(o,async([e,n,s,i,l],r)=>{t&&!X(a,r)||await g(e,n,a[r],s,i,t,l)})),h=async(a,t)=>d?await g(u,wa,{[Ea]:a},!0,!0,t):null,I=ya(a,()=>L(async()=>{await A();const a=await(async()=>x(f(await v(ea(r,async([a,t,e],n)=>[a,await S(n,t,e)])),a=>!j(a[1]))))(),t=await(async()=>c?(await S(u,wa))[Ea]:{})();return j(a)&&y(t)?void 0:[a,t]}),(a,t)=>L(async()=>{if(await A(),y(t)){const[t,e]=a();await R(t),await h(e)}else await R(t[0],!0),await h(t[1],!0)}),e,n,s,l,{[N]:()=>T,destroy:async()=>(await I.stopAutoPersisting(),i(),I)},0,T);return I},Ka=(a,n,s,l,r,o,c,y,E,w,T="getDb",p)=>{let O,m,v;const A=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,o),[g,L,R,h]=(a=>{const e=(a=>M(Ga,N(a)?{[Pa]:a}:a??{}))(a),n=e[xa];if(e.mode==Ca){const a=e[Pa]??t;return[1,n,[a,e[Da]??wa,e[Ua]??ba],oa(a)]}const{tables:{load:s={},save:l={}}={},values:r={}}=e,o=_(G(M(Ya,r)),0,Y(Ya)),c=o[2],d=oa(c),u=oa(c),y=ja(s,{[Xa]:null,[Ma]:wa,[Ba]:i},Xa,a=>H(u,a),a=>ca(d,a)),E=ja(l,{[Ja]:null,[Ma]:wa,[Fa]:0,[Va]:0,[Ba]:null},Ja,(a,t)=>H(u,t),(a,t)=>ca(d,t));var w;return w=(a,t)=>t[4]??=ta(y,t[0])?.[2]??i,W(E,(a,t)=>w(0,a)),[0,n,[y,E,o],d]})(n);return(g?qa:Ha)(a,A,a=>{let t;const e=()=>t=setInterval(()=>S(async()=>{const[{d:t,s:e,c:n}]=await A(Ta+` ${Sa} d,${ga} s,TOTAL_CHANGES() c FROM ${Aa}${Sa} JOIN ${Aa}${ga}`);t==O&&e==m&&n==v||(u(O)||a(),O=t,m=e,v=n)}),1e3*L),n=()=>{O=m=v=null,d(t)},s=l(t=>{h.has(t)&&(n(),a(),e())});return e(),()=>{n(),r(s)}},a=>a(),c,y,E,R,Q(h),async(a,t)=>await a(Ta+` t.name tn,c.name cn FROM ${La}list()t,${La}info(t.name)c ${Na} t.schema='main'AND t.type IN('table','view')AND t.name IN(${fa(t)})ORDER BY t.name,c.name`,t),w,T,e,p,a=>!0===a?1:!1===a?0:a,void 0)},Qa=(a,t,n,s,i)=>"object"==typeof n&&"fragmented"===n.mode?Za(a,t,n?.storagePrefix??e,i):Ka(a,n,async(a,e=[])=>["BEGIN","END"].includes(a)?[]:(a=a.replace(/\$\d+/g,"?"),t.exec(a,...e).toArray()),()=>m,a=>a(),s,i,m,2,t,"getSqlStorage"),Wa=()=>[{},e,0],Za=(a,t,e="",n)=>{const s=e.replace(/[^a-zA-Z0-9_]/g,"_"),i=s+"tinybase_tables",r=s+"tinybase_values";return t.exec(`\n CREATE TABLE IF NOT EXISTS ${i} (\n type TEXT NOT NULL,\n table_id TEXT,\n row_id TEXT,\n cell_id TEXT,\n value_data TEXT NOT NULL,\n timestamp TEXT NOT NULL,\n hash INTEGER NOT NULL,\n PRIMARY KEY (type, table_id, row_id, cell_id)\n );\n \n CREATE TABLE IF NOT EXISTS ${r} (\n value_id TEXT,\n value_data TEXT NOT NULL,\n timestamp TEXT NOT NULL,\n hash INTEGER NOT NULL\n );\n `),ya(a,async()=>{const a=Wa(),e=Wa(),n=t.exec("SELECT * FROM "+i);for(const t of n.toArray()){const e=t.type+"",n=t.table_id?t.table_id+"":null,s=t.row_id?t.row_id+"":null,i=t.cell_id?t.cell_id+"":null,r=t.value_data+"",o=t.timestamp+"",c=Number(t.hash),[d]=JSON.parse(r);if(e===l)if(n&&s&&i){const t=z(a[0],n,Wa);z(t[0],s,Wa)[0][i]=[d,o,c]}else if(n&&s){const t=z(a[0],n,Wa),e=z(t[0],s,Wa);la(e,o,c)}else if(n){const t=z(a[0],n,Wa);la(t,o,c)}else la(a,o,c)}const s=t.exec("SELECT * FROM "+r);for(const a of s.toArray()){const t=a.value_id?a.value_id+"":null,n=a.value_data+"",s=a.timestamp+"",i=Number(a.hash),[l]=JSON.parse(n);t?e[0][t]=[l,s,i]:la(e,s,i)}return[a,e]},async(a,[[e,n,s],[o,c,d]]=a())=>{t.exec(`INSERT OR REPLACE INTO ${i} (type, table_id, row_id, cell_id, value_data, timestamp, hash) VALUES (?, ?, ?, ?, ?, ?, ?)`,l,null,null,null,JSON.stringify([0]),n,s),F(e,([a,e,n],s)=>{t.exec(`INSERT OR REPLACE INTO ${i} (type, table_id, row_id, cell_id, value_data, timestamp, hash) VALUES (?, ?, ?, ?, ?, ?, ?)`,l,s,null,null,JSON.stringify([0]),e,n),F(a,([a,e,n],r)=>{t.exec(`INSERT OR REPLACE INTO ${i} (type, table_id, row_id, cell_id, value_data, timestamp, hash) VALUES (?, ?, ?, ?, ?, ?, ?)`,l,s,r,null,JSON.stringify([0]),e,n),F(a,(a,e)=>{t.exec(`INSERT OR REPLACE INTO ${i} (type, table_id, row_id, cell_id, value_data, timestamp, hash) VALUES (?, ?, ?, ?, ?, ?, ?)`,l,s,r,e,JSON.stringify([a[0]]),a[1],a[2])})})}),t.exec(`INSERT OR REPLACE INTO ${r} (value_id, value_data, timestamp, hash) VALUES (?, ?, ?, ?)`,null,JSON.stringify([0]),c,d),F(o,(a,e)=>{t.exec(`INSERT OR REPLACE INTO ${r} (value_id, value_data, timestamp, hash) VALUES (?, ?, ?, ?)`,e,JSON.stringify([a[0]]),a[1],a[2])})},m,m,n,2,{getSqlStorage:()=>t})};export{Qa as createDurableObjectSqlStoragePersister};
1
+ const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),i="true",l="t",r=(a,t,e)=>a.replace(t,e),o=Promise,c=a=>(t,e,n)=>a(t)?n?.():e(t),d=clearInterval,u=a=>null==a,y=a=>void 0===a,E=a=>null===a,w=c(u),T=c(y),N=t=>a(t)==s,p=a=>Array.isArray(a),_=(a,t,e)=>a.slice(t,e),O=a=>a.length,m=()=>{},v=async a=>o.all(a),A=a=>{throw Error(a)},S=async(a,t,e)=>{try{return await a()}catch(a){t?.(a)}},g=(a,t)=>a.forEach(t),L=(a,t="")=>a.join(t),R=(a,t)=>a.map(t),h=a=>0==O(a),f=(a,t)=>a.filter(t),I=(a,...t)=>a.push(...t),$=a=>a.shift(),b=Object,C=a=>b.getPrototypeOf(a),P=b.entries,D=b.keys,U=b.freeze,x=(a=[])=>b.fromEntries(a),M=(...a)=>b.assign({},...a),X=(a,t)=>t in a,J=(a,t)=>(delete a[t],a),F=(a,t)=>g(P(a),([a,e])=>t(e,a)),V=(a,t)=>R(P(a),([a,e])=>t(e,a)),B=(a,t)=>x(V(a,(a,e)=>[e,t(a,e)])),G=a=>b.values(a),Y=a=>O(D(a)),j=a=>(a=>!u(a)&&w(C(a),a=>a==b.prototype||u(C(a)),()=>!0))(a)&&0==Y(a),z=(a,t,e)=>(X(a,t)||(a[t]=e()),a[t]),k=JSON.stringify,q=JSON.parse,H=(a,t)=>a?.has(t)??!1,K=a=>y(a)||0==(a=>a?.size??0)(a),Q=a=>[...a?.values()??[]],W=(a,t)=>a?.forEach(t),Z=(a,t)=>a?.delete(t),aa=a=>new Map(a),ta=(a,t)=>a?.get(t),ea=(a,t)=>R([...a?.entries()??[]],([a,e])=>t(e,a)),na=(a,t,e)=>void 0===e?(Z(a,t),a):a?.set(t,e),sa=(a,t,e,n)=>(H(a,t)?n?.(ta(a,t)):na(a,t,e()),ta(a,t)),ia=(a,t,e,n,s=0)=>T((e?sa:ta)(a,t[s],s>O(t)-2?e:aa),i=>{if(s>O(t)-2)return n?.(i)&&na(a,t[s]),i;const l=ia(i,t,e,n,s+1);return K(i)&&na(a,t[s]),l}),la=(a,t,e)=>{t>a[1]&&(a[1]=t),a[2]=e>>>0},ra=/^\d+$/,oa=a=>new Set(p(a)||y(a)?a:[a]),ca=(a,t)=>a?.add(t),da=aa(),ua=aa(),ya=(a,t,n,s,i,l,r,o={},c=0,d=[])=>{let u,w,N,_=0,m=0,v=0;sa(da,d,()=>0),sa(ua,d,()=>[]);const L=aa(),[R,h,f,b,C]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!j(a)||!j(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!j(a)||!j(t),t.setContent]:A("Store type not supported by this Persister"))(r,a,c),[P,D,x]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?$(a):null)??e+t++,t=>{ra.test(t)&&O(a)<1e3&&I(a,t)}]})(),s=aa();return[(n,i,l,r=[],o=()=>[])=>{a??=q;const c=t(1);return na(s,c,[n,i,l,r,o]),ca(ia(i,l??[e],oa),c),c},(t,n,...i)=>g(((a,t=[e])=>{const n=[],s=(a,e)=>e==O(t)?I(n,a):null===t[e]?W(a,a=>s(a,e+1)):g([t[e],null],t=>s(ta(a,t),e+1));return s(a,0),n})(t,n),t=>W(t,t=>ta(s,t)[0](a,...n??[],...i))),a=>T(ta(s,a),([,t,i])=>(ia(t,i??[e],void 0,t=>(Z(t,a),K(t)?1:0)),na(s,a),n(a),i)),t=>T(ta(s,t),([t,,e=[],n,s])=>{const i=(...l)=>{const r=O(l);r==O(e)?t(a,...l,...s(l)):E(e[r])?g(n[r]?.(...l)??[],a=>i(...l,a)):i(...l,e[r])};i()})]})(),M=a=>{a!=_&&(_=a,D(L,void 0,_))},X=t=>{(R&&p(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},J=async a=>(2!=_&&(M(1),m++,await k(async()=>{await S(async()=>{const e=await t();p(e)?X(e):a?C(a):A("Content is not an array: "+e)},()=>{a&&C(a)}),M(0)})),q),F=async a=>(V(),await J(a),await S(async()=>w=await s(async(a,t)=>{t||a?2!=_&&(M(1),m++,X(t??a),M(0)):await J()}),l),q),V=async()=>(w&&(await S(()=>i(w),l),w=void 0),q),B=async a=>(1!=_&&(M(2),v++,await k(async()=>{await S(()=>n(h,a),l),M(0)})),q),G=async()=>(Y(),await B(),N=a.addDidFinishTransactionListener(()=>{const a=f();b(a)&&B(a)}),q),Y=async()=>(N&&(a.delListener(N),N=void 0),q),z=async(a=!1)=>{const[t,e]=a?[Y,V]:[V,Y];return await t(),await e(),q},k=async(...a)=>(I(ta(ua,d),...a),await(async()=>{if(!ta(da,d)){for(na(da,d,1);!y(u=$(ta(ua,d)));)await S(u,l);na(da,d,0)}})(),q),q={load:J,startAutoLoad:F,stopAutoLoad:V,isAutoLoading:()=>!y(w),save:B,startAutoSave:G,stopAutoSave:Y,isAutoSaving:()=>!y(N),startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[G,F]:[F,G];return await e(a),await n(a),q},stopAutoPersisting:z,getStatus:()=>_,addStatusListener:a=>P(a,L),delListener:t=>(x(t),a),schedule:k,getStore:()=>a,destroy:()=>(ta(ua,d).splice(0,void 0),z()),getStats:()=>({loads:m,saves:v}),...o};return U(q)},Ea="_",wa="_id",Ta="SELECT",Na="WHERE",pa="TABLE",_a="ALTER "+pa,Oa="FROM",ma="DELETE "+Oa,va=Ta+"*"+Oa,Aa="pragma_",Sa="data_version",ga="schema_version",La="pragma_table_",Ra="CREATE "+pa,ha=a=>L(R(((a,t="",e)=>a.split(t,e))(a,"."),a=>`"${r(a,/"/g,'""')}"`),"."),fa=(a,t=[1])=>L(R(a,()=>"$"+t[0]++),n),Ia=(a,t=i)=>Na+`(${r(t,"$tableName",ha(a))})`,$a="ColumnName",ba="store",Ca="json",Pa=ba+"TableName",Da=ba+"Id"+$a,Ua=ba+$a,xa="autoLoadIntervalSeconds",Ma="rowId"+$a,Xa="tableId",Ja="tableName",Fa="deleteEmptyColumns",Va="deleteEmptyTable",Ba="condition",Ga={mode:Ca,[xa]:1},Ya={load:0,save:0,[Ja]:t+"_values"},ja=(a,t,e,n,s)=>{const i=aa();return B(a,(a,l)=>{const r=_(G(M(t,N(a)?{[e]:a}:a)),0,Y(t));E(r[0])||n(l,r[0])||(s(l,r[0]),na(i,l,r))}),i},za=(a,t,e,s,l,r=ka,o,c)=>{const d=aa();return[async()=>{d.clear(),R(await e(a,t),({tn:a,cn:t})=>ca(sa(d,a,oa),t))},async(t,e,n)=>((a,t)=>H(ta(d,a),t))(t,e)?x(f(R(await a(va+ha(t)+Ia(t,n)),a=>[a[e],c?B(J(a,e),c):J(a,e)]),([a,t])=>!y(a)&&!j(t))):{},async(t,e,s,c,u,E=!1,w=i)=>{const T=oa();B(s??{},a=>R(D(a??{}),a=>ca(T,a)));const N=Q(T);if(!E&&u&&w==i&&h(N)&&H(d,t))return await a("DROP "+pa+ha(t)),void na(d,t);const p=ta(d,t),_=oa(Q(p));if(h(N)||(H(d,t)?await v(R([e,...N],async(n,s)=>{Z(_,n)||(await a(_a+ha(t)+"ADD"+ha(n)+l),0==s&&await a("CREATE UNIQUE INDEX pk ON "+ha(t)+`(${ha(e)})`),ca(p,n))})):(await a(Ra+ha(t)+`(${ha(e)}${l} PRIMARY KEY${L(R(N,a=>n+ha(a)+l))});`),na(d,t,oa([e,...N])))),await v([...!E&&c?R(Q(_),async n=>{n!=e&&(await a(_a+ha(t)+"DROP"+ha(n)),Z(p,n))}):[]]),E)y(s)?await a(ma+ha(t)+Ia(t,w)):await v(V(s,async(n,s)=>{y(n)?await a(ma+ha(t)+Ia(t,w)+`AND(${ha(e)}=$1)`,[s]):h(N)||await r(a,t,e,D(n),{[s]:o?R(G(n),o):G(n)},p)}));else if(h(N))H(d,t)&&await a(ma+ha(t)+Ia(t,w));else{const n=f(Q(ta(d,t)),a=>a!=e),i={},l=[];B(s??{},(a,t)=>{i[t]=R(n,t=>o?o(a?.[t]):a?.[t]),I(l,t)}),await r(a,t,e,n,i),await a(ma+ha(t)+Ia(t,w)+`AND${ha(e)}NOT IN(${fa(l)})`,l)}},async t=>{let e;return await a("BEGIN"),await S(async()=>e=await t(),s),await a("END"),e}]},ka=async(a,t,e,s,i)=>{const l=[1];await a("INSERT INTO"+ha(t)+"("+((...a)=>L(R(a,ha),n))(e,...s)+")VALUES"+L(V(i,a=>"($"+l[0]+++","+fa(a,l)+")"),n)+"ON CONFLICT("+ha(e)+")DO UPDATE SET"+L(R(s,a=>ha(a)+"=excluded."+ha(a)),n),V(i,(a,t)=>[t,...R(a,a=>a??null)]).flat())},qa=(a,t,e,n,s,i,l,[r,o,c],d,u,y,E,w,T)=>{const[N,p,_,O]=za(t,d,u,s,w,T),m=ya(a,()=>O(async()=>{return await N(),a=(await p(r,o))[Ea]?.[c]??"null",q(a,(a,t)=>""===t?void 0:t);var a}),a=>O(async()=>{var t;await N(),await _(r,o,{[Ea]:{[c]:(t=a()??null,k(t,(a,t)=>void 0===t?"":t))}},!0,!0)}),e,n,s,l,{[E]:()=>y,destroy:async()=>(await m.stopAutoPersisting(),i(),m)},0,y);return m},Ha=(a,t,e,n,s,i,l,[r,o,[c,d,u]],E,w,T,N,p,_,O,m)=>{const[A,S,g,L]=za(t,E,w,s,p,_,O,m),R=(a,t)=>v(ea(o,async([e,n,s,i,l],r)=>{t&&!X(a,r)||await g(e,n,a[r],s,i,t,l)})),h=async(a,t)=>d?await g(u,wa,{[Ea]:a},!0,!0,t):null,I=ya(a,()=>L(async()=>{await A();const a=await(async()=>x(f(await v(ea(r,async([a,t,e],n)=>[a,await S(n,t,e)])),a=>!j(a[1]))))(),t=await(async()=>c?(await S(u,wa))[Ea]:{})();return j(a)&&y(t)?void 0:[a,t]}),(a,t)=>L(async()=>{if(await A(),y(t)){const[t,e]=a();await R(t),await h(e)}else await R(t[0],!0),await h(t[1],!0)}),e,n,s,l,{[N]:()=>T,destroy:async()=>(await I.stopAutoPersisting(),i(),I)},0,T);return I},Ka=(a,n,s,l,r,o,c,y,E,w,T="getDb",p)=>{let O,m,v;const A=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,o),[g,L,R,h]=(a=>{const e=(a=>M(Ga,N(a)?{[Pa]:a}:a??{}))(a),n=e[xa];if(e.mode==Ca){const a=e[Pa]??t;return[1,n,[a,e[Da]??wa,e[Ua]??ba],oa(a)]}const{tables:{load:s={},save:l={}}={},values:r={}}=e,o=_(G(M(Ya,r)),0,Y(Ya)),c=o[2],d=oa(c),u=oa(c),y=ja(s,{[Xa]:null,[Ma]:wa,[Ba]:i},Xa,a=>H(u,a),a=>ca(d,a)),E=ja(l,{[Ja]:null,[Ma]:wa,[Fa]:0,[Va]:0,[Ba]:null},Ja,(a,t)=>H(u,t),(a,t)=>ca(d,t));var w;return w=(a,t)=>t[4]??=ta(y,t[0])?.[2]??i,W(E,(a,t)=>w(0,a)),[0,n,[y,E,o],d]})(n);return(g?qa:Ha)(a,A,a=>{let t;const e=()=>t=setInterval(()=>S(async()=>{const[{d:t,s:e,c:n}]=await A(Ta+` ${Sa} d,${ga} s,TOTAL_CHANGES() c FROM ${Aa}${Sa} JOIN ${Aa}${ga}`);t==O&&e==m&&n==v||(u(O)||a(),O=t,m=e,v=n)}),1e3*L),n=()=>{O=m=v=null,d(t)},s=l(t=>{h.has(t)&&(n(),a(),e())});return e(),()=>{n(),r(s)}},a=>a(),c,y,E,R,Q(h),async(a,t)=>await a(Ta+` t.name tn,c.name cn FROM ${La}list()t,${La}info(t.name)c ${Na} t.schema='main'AND t.type IN('table','view')AND t.name IN(${fa(t)})ORDER BY t.name,c.name`,t),w,T,e,p,a=>!0===a?1:!1===a?0:a,void 0)},Qa=(a,t,n,s,i)=>"object"==typeof n&&"fragmented"===n.mode?Za(a,t,n?.storagePrefix??e,i):Ka(a,n,async(a,e=[])=>["BEGIN","END"].includes(a)?[]:(a=a.replace(/\$\d+/g,"?"),t.exec(a,...e).toArray()),()=>m,a=>a(),s,i,m,2,t,"getSqlStorage"),Wa=()=>[{},e,0],Za=(a,t,e="",n)=>{const s=e.replace(/[^a-zA-Z0-9_]/g,"_"),i=s+"tinybase_tables",r=s+"tinybase_values";return t.exec(`\n CREATE TABLE IF NOT EXISTS ${i} (\n type TEXT NOT NULL,\n table_id TEXT,\n row_id TEXT,\n cell_id TEXT,\n value_data TEXT NOT NULL,\n timestamp TEXT NOT NULL,\n hash INTEGER NOT NULL,\n PRIMARY KEY (type, table_id, row_id, cell_id)\n );\n \n CREATE TABLE IF NOT EXISTS ${r} (\n value_id TEXT,\n value_data TEXT NOT NULL,\n timestamp TEXT NOT NULL,\n hash INTEGER NOT NULL\n );\n `),ya(a,async()=>{const a=Wa(),e=Wa(),n=t.exec("SELECT * FROM "+i);for(const t of n.toArray()){const e=t.type+"",n=t.table_id?t.table_id+"":null,s=t.row_id?t.row_id+"":null,i=t.cell_id?t.cell_id+"":null,r=t.value_data+"",o=t.timestamp+"",c=Number(t.hash),[d]=JSON.parse(r);if(e===l)if(n&&s&&i){const t=z(a[0],n,Wa);z(t[0],s,Wa)[0][i]=[d,o,c]}else if(n&&s){const t=z(a[0],n,Wa),e=z(t[0],s,Wa);la(e,o,c)}else if(n){const t=z(a[0],n,Wa);la(t,o,c)}else la(a,o,c)}const s=t.exec("SELECT * FROM "+r);for(const a of s.toArray()){const t=a.value_id?a.value_id+"":null,n=a.value_data+"",s=a.timestamp+"",i=Number(a.hash),[l]=JSON.parse(n);t?e[0][t]=[l,s,i]:la(e,s,i)}return[a,e]},async(a,[[e,n,s],[o,c,d]]=a())=>{t.exec(`INSERT OR REPLACE INTO ${i} (type, table_id, row_id, cell_id, value_data, timestamp, hash) VALUES (?, ?, ?, ?, ?, ?, ?)`,l,null,null,null,JSON.stringify([0]),n,s),F(e,([a,e,n],s)=>{t.exec(`INSERT OR REPLACE INTO ${i} (type, table_id, row_id, cell_id, value_data, timestamp, hash) VALUES (?, ?, ?, ?, ?, ?, ?)`,l,s,null,null,JSON.stringify([0]),e,n),F(a,([a,e,n],r)=>{t.exec(`INSERT OR REPLACE INTO ${i} (type, table_id, row_id, cell_id, value_data, timestamp, hash) VALUES (?, ?, ?, ?, ?, ?, ?)`,l,s,r,null,JSON.stringify([0]),e,n),F(a,(a,e)=>{t.exec(`INSERT OR REPLACE INTO ${i} (type, table_id, row_id, cell_id, value_data, timestamp, hash) VALUES (?, ?, ?, ?, ?, ?, ?)`,l,s,r,e,JSON.stringify([a[0]]),a[1],a[2])})})}),t.exec(`INSERT OR REPLACE INTO ${r} (value_id, value_data, timestamp, hash) VALUES (?, ?, ?, ?)`,null,JSON.stringify([0]),c,d),F(o,(a,e)=>{t.exec(`INSERT OR REPLACE INTO ${r} (value_id, value_data, timestamp, hash) VALUES (?, ?, ?, ?)`,e,JSON.stringify([a[0]]),a[1],a[2])})},m,m,n,2,{getSqlStorage:()=>t})};export{Qa as createDurableObjectSqlStoragePersister};
@@ -1 +1 @@
1
- const t="t",a="v",e=(t=n)=>(a,e,n)=>t(a)?n?.():e(a),n=t=>null==t,s=t=>void 0===t,r=e(n),o=e(s),i=t=>Array.isArray(t),c=(t,a,e)=>t.slice(a,e),u=t=>t.length,l=()=>{},y=t=>{throw Error(t)},d=async(t,a,e)=>{try{return await t()}catch(t){a?.(t)}},g=(t,a)=>t.forEach(a),w=(t,...a)=>t.push(...a),p=t=>t.shift(),h=Object,v=t=>h.getPrototypeOf(t),f=h.entries,S=h.keys,C=h.freeze,A=(t,a)=>g(f(t),([t,e])=>a(e,t)),b=t=>(t=>!n(t)&&r(v(t),t=>t==h.prototype||n(v(t)),()=>!0))(t)&&0==(t=>u(S(t)))(t),L=(t,a,e)=>(((t,a)=>a in t)(t,a)||(t[a]=e()),t[a]),M=JSON.stringify,E=t=>s(t)||0==(t=>t?.size??0)(t),O=(t,a)=>t?.forEach(a),P=(t,a)=>t?.delete(a),T=t=>new Map(t),x=(t,a)=>t?.get(a),z=(t,a,e)=>void 0===e?(P(t,a),t):t?.set(a,e),D=(t,a,e,n)=>{var s,r;return s=t,r=a,s?.has(r)?n?.(x(t,a)):z(t,a,e()),x(t,a)},J=(t,a,e,n,s=0)=>o((e?D:x)(t,a[s],s>u(a)-2?e:T),r=>{if(s>u(a)-2)return n?.(r)&&z(t,a[s]),r;const o=J(r,a,e,n,s+1);return E(r)&&z(t,a[s]),o}),N=(t,a,e)=>{a>t[1]&&(t[1]=a),t[2]=e>>>0},j=/^\d+$/,k=t=>new Set(i(t)||s(t)?t:[t]),F=T(),W=T(),$=(t,a,e,n,r,c,l,h={},v=0,f=[])=>{let S,A,L,M=0,N=0,$=0;D(F,f,()=>0),D(W,f,()=>[]);const m=T(),[q,B,G,H,I]=((t=1,a,e)=>1!=t&&a.isMergeable()?[1,a.getMergeableContent,()=>a.getTransactionMergeableChanges(!e),([[t],[a]])=>!b(t)||!b(a),a.setDefaultContent]:2!=t?[0,a.getContent,a.getTransactionChanges,([t,a])=>!b(t)||!b(a),a.setContent]:y("Store type not supported by this Persister"))(l,t,v),[K,Q,R]=(()=>{let t;const[a,e]=(()=>{const t=[];let a=0;return[e=>(e?p(t):null)??""+a++,a=>{j.test(a)&&u(t)<1e3&&w(t,a)}]})(),n=T();return[(e,s,r,o=[],i=()=>[])=>{t??=st;const c=a(1);var u,l;return z(n,c,[e,s,r,o,i]),u=J(s,r??[""],k),l=c,u?.add(l),c},(a,e,...s)=>g(((t,a=[""])=>{const e=[],n=(t,s)=>s==u(a)?w(e,t):null===a[s]?O(t,t=>n(t,s+1)):g([a[s],null],a=>n(x(t,a),s+1));return n(t,0),e})(a,e),a=>O(a,a=>x(n,a)[0](t,...e??[],...s))),t=>o(x(n,t),([,a,s])=>(J(a,s??[""],void 0,a=>(P(a,t),E(a)?1:0)),z(n,t),e(t),s)),a=>o(x(n,a),([a,,e=[],n,s])=>{const r=(...o)=>{const i=u(o);i==u(e)?a(t,...o,...s(o)):(t=>null===t)(e[i])?g(n[i]?.(...o)??[],t=>r(...o,t)):r(...o,e[i])};r()})]})(),U=t=>{t!=M&&(M=t,Q(m,void 0,M))},V=a=>{(q&&i(a?.[0])?1===a?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===a?.[2]?t.applyChanges:t.setContent)(a)},X=async t=>(2!=M&&(U(1),N++,await nt(async()=>{await d(async()=>{const e=await a();i(e)?V(e):t?I(t):y("Content is not an array: "+e)},()=>{t&&I(t)}),U(0)})),st),Y=async t=>(Z(),await X(t),await d(async()=>A=await n(async(t,a)=>{a||t?2!=M&&(U(1),N++,V(a??t),U(0)):await X()}),c),st),Z=async()=>(A&&(await d(()=>r(A),c),A=void 0),st),_=async t=>(1!=M&&(U(2),$++,await nt(async()=>{await d(()=>e(B,t),c),U(0)})),st),tt=async()=>(at(),await _(),L=t.addDidFinishTransactionListener(()=>{const t=G();H(t)&&_(t)}),st),at=async()=>(L&&(t.delListener(L),L=void 0),st),et=async(t=!1)=>{const[a,e]=t?[at,Z]:[Z,at];return await a(),await e(),st},nt=async(...t)=>(w(x(W,f),...t),await(async()=>{if(!x(F,f)){for(z(F,f,1);!s(S=p(x(W,f)));)await d(S,c);z(F,f,0)}})(),st),st={load:X,startAutoLoad:Y,stopAutoLoad:Z,isAutoLoading:()=>!s(A),save:_,startAutoSave:tt,stopAutoSave:at,isAutoSaving:()=>!s(L),startAutoPersisting:async(t,a=!1)=>{const[e,n]=a?[tt,Y]:[Y,tt];return await e(t),await n(t),st},stopAutoPersisting:et,getStatus:()=>M,addStatusListener:t=>K(t,m),delListener:a=>(R(a),t),schedule:nt,getStore:()=>t,destroy:()=>(x(W,f).splice(0,void 0),et()),getStats:()=>({loads:N,saves:$}),...h};return C(st)},m=()=>[{},"",0],q=(e,n,s="",r)=>{const i=(t,...a)=>s+t+c(M(a,(t,a)=>void 0===a?"":a),1,-1);return $(e,async()=>{const e=[{},"",0],r=[{},"",0];return(await n.list({prefix:s})).forEach(async([n,i,u],l)=>o((e=>{if(n=s,e.startsWith(n)){const n=c(e,s.length,1);return n==t||n==a?[n,...JSON.parse("["+c(e,s.length+1)+"]")]:void 0}var n})(l),([s,...c])=>s==t?o(c[0],t=>{const a=L(e[0],t,m);o(c[1],t=>{const e=L(a[0],t,m);o(c[2],t=>e[0][t]=[n,i,u],()=>N(e,i,u))},()=>N(a,i,u))},()=>N(e,i,u)):s==a?o(c[0],t=>r[0][t]=[n,i,u],()=>N(r,i,u)):0)),[e,r]},async(e,[[s,r,o],[c,u,l]]=e())=>{const y=T();z(y,i(t),[0,r,o]),A(s,([a,e,n],s)=>{z(y,i(t,s),[0,e,n]),A(a,([a,e,n],r)=>{z(y,i(t,s,r),[0,e,n]),A(a,(a,e)=>z(y,i(t,s,r,e),a))})}),z(y,i(a),[0,u,l]),A(c,(t,e)=>z(y,i(a,e),t)),await n.put((t=>{const a={};return O(t,(t,e)=>{{const n=t;a[e]=n}}),a})(y))},l,l,r,2,{getStorage:()=>n})};export{q as createDurableObjectStoragePersister};
1
+ const t="t",a="v",e=t=>(a,e,n)=>t(a)?n?.():e(a),n=t=>null==t,s=t=>void 0===t,r=e(n),o=e(s),i=t=>Array.isArray(t),c=(t,a,e)=>t.slice(a,e),u=t=>t.length,l=()=>{},y=t=>{throw Error(t)},d=async(t,a,e)=>{try{return await t()}catch(t){a?.(t)}},g=(t,a)=>t.forEach(a),w=(t,...a)=>t.push(...a),p=t=>t.shift(),h=Object,v=t=>h.getPrototypeOf(t),f=h.entries,S=h.keys,C=h.freeze,A=(t,a)=>g(f(t),([t,e])=>a(e,t)),b=t=>(t=>!n(t)&&r(v(t),t=>t==h.prototype||n(v(t)),()=>!0))(t)&&0==(t=>u(S(t)))(t),L=(t,a,e)=>(((t,a)=>a in t)(t,a)||(t[a]=e()),t[a]),M=JSON.stringify,E=t=>s(t)||0==(t=>t?.size??0)(t),O=(t,a)=>t?.forEach(a),P=(t,a)=>t?.delete(a),T=t=>new Map(t),x=(t,a)=>t?.get(a),z=(t,a,e)=>void 0===e?(P(t,a),t):t?.set(a,e),D=(t,a,e,n)=>{var s,r;return s=t,r=a,s?.has(r)?n?.(x(t,a)):z(t,a,e()),x(t,a)},J=(t,a,e,n,s=0)=>o((e?D:x)(t,a[s],s>u(a)-2?e:T),r=>{if(s>u(a)-2)return n?.(r)&&z(t,a[s]),r;const o=J(r,a,e,n,s+1);return E(r)&&z(t,a[s]),o}),N=(t,a,e)=>{a>t[1]&&(t[1]=a),t[2]=e>>>0},j=/^\d+$/,k=t=>new Set(i(t)||s(t)?t:[t]),F=T(),W=T(),$=(t,a,e,n,r,c,l,h={},v=0,f=[])=>{let S,A,L,M=0,N=0,$=0;D(F,f,()=>0),D(W,f,()=>[]);const m=T(),[q,B,G,H,I]=((t=1,a,e)=>1!=t&&a.isMergeable()?[1,a.getMergeableContent,()=>a.getTransactionMergeableChanges(!e),([[t],[a]])=>!b(t)||!b(a),a.setDefaultContent]:2!=t?[0,a.getContent,a.getTransactionChanges,([t,a])=>!b(t)||!b(a),a.setContent]:y("Store type not supported by this Persister"))(l,t,v),[K,Q,R]=(()=>{let t;const[a,e]=(()=>{const t=[];let a=0;return[e=>(e?p(t):null)??""+a++,a=>{j.test(a)&&u(t)<1e3&&w(t,a)}]})(),n=T();return[(e,s,r,o=[],i=()=>[])=>{t??=st;const c=a(1);var u,l;return z(n,c,[e,s,r,o,i]),u=J(s,r??[""],k),l=c,u?.add(l),c},(a,e,...s)=>g(((t,a=[""])=>{const e=[],n=(t,s)=>s==u(a)?w(e,t):null===a[s]?O(t,t=>n(t,s+1)):g([a[s],null],a=>n(x(t,a),s+1));return n(t,0),e})(a,e),a=>O(a,a=>x(n,a)[0](t,...e??[],...s))),t=>o(x(n,t),([,a,s])=>(J(a,s??[""],void 0,a=>(P(a,t),E(a)?1:0)),z(n,t),e(t),s)),a=>o(x(n,a),([a,,e=[],n,s])=>{const r=(...o)=>{const i=u(o);i==u(e)?a(t,...o,...s(o)):(t=>null===t)(e[i])?g(n[i]?.(...o)??[],t=>r(...o,t)):r(...o,e[i])};r()})]})(),U=t=>{t!=M&&(M=t,Q(m,void 0,M))},V=a=>{(q&&i(a?.[0])?1===a?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===a?.[2]?t.applyChanges:t.setContent)(a)},X=async t=>(2!=M&&(U(1),N++,await nt(async()=>{await d(async()=>{const e=await a();i(e)?V(e):t?I(t):y("Content is not an array: "+e)},()=>{t&&I(t)}),U(0)})),st),Y=async t=>(Z(),await X(t),await d(async()=>A=await n(async(t,a)=>{a||t?2!=M&&(U(1),N++,V(a??t),U(0)):await X()}),c),st),Z=async()=>(A&&(await d(()=>r(A),c),A=void 0),st),_=async t=>(1!=M&&(U(2),$++,await nt(async()=>{await d(()=>e(B,t),c),U(0)})),st),tt=async()=>(at(),await _(),L=t.addDidFinishTransactionListener(()=>{const t=G();H(t)&&_(t)}),st),at=async()=>(L&&(t.delListener(L),L=void 0),st),et=async(t=!1)=>{const[a,e]=t?[at,Z]:[Z,at];return await a(),await e(),st},nt=async(...t)=>(w(x(W,f),...t),await(async()=>{if(!x(F,f)){for(z(F,f,1);!s(S=p(x(W,f)));)await d(S,c);z(F,f,0)}})(),st),st={load:X,startAutoLoad:Y,stopAutoLoad:Z,isAutoLoading:()=>!s(A),save:_,startAutoSave:tt,stopAutoSave:at,isAutoSaving:()=>!s(L),startAutoPersisting:async(t,a=!1)=>{const[e,n]=a?[tt,Y]:[Y,tt];return await e(t),await n(t),st},stopAutoPersisting:et,getStatus:()=>M,addStatusListener:t=>K(t,m),delListener:a=>(R(a),t),schedule:nt,getStore:()=>t,destroy:()=>(x(W,f).splice(0,void 0),et()),getStats:()=>({loads:N,saves:$}),...h};return C(st)},m=()=>[{},"",0],q=(e,n,s="",r)=>{const i=(t,...a)=>s+t+c(M(a,(t,a)=>void 0===a?"":a),1,-1);return $(e,async()=>{const e=[{},"",0],r=[{},"",0];return(await n.list({prefix:s})).forEach(async([n,i,u],l)=>o((e=>{if(n=s,e.startsWith(n)){const n=c(e,s.length,1);return n==t||n==a?[n,...JSON.parse("["+c(e,s.length+1)+"]")]:void 0}var n})(l),([s,...c])=>s==t?o(c[0],t=>{const a=L(e[0],t,m);o(c[1],t=>{const e=L(a[0],t,m);o(c[2],t=>e[0][t]=[n,i,u],()=>N(e,i,u))},()=>N(a,i,u))},()=>N(e,i,u)):s==a?o(c[0],t=>r[0][t]=[n,i,u],()=>N(r,i,u)):0)),[e,r]},async(e,[[s,r,o],[c,u,l]]=e())=>{const y=T();z(y,i(t),[0,r,o]),A(s,([a,e,n],s)=>{z(y,i(t,s),[0,e,n]),A(a,([a,e,n],r)=>{z(y,i(t,s,r),[0,e,n]),A(a,(a,e)=>z(y,i(t,s,r,e),a))})}),z(y,i(a),[0,u,l]),A(c,(t,e)=>z(y,i(a,e),t)),await n.put((t=>{const a={};return O(t,(t,e)=>{{const n=t;a[e]=n}}),a})(y))},l,l,r,2,{getStorage:()=>n})};export{q as createDurableObjectStoragePersister};
@@ -1 +1 @@
1
- const t="t",a="v",e=(t=n)=>(a,e,n)=>t(a)?n?.():e(a),n=t=>null==t,s=t=>void 0===t,r=e(n),o=e(s),i=t=>Array.isArray(t),c=(t,a,e)=>t.slice(a,e),u=t=>t.length,l=()=>{},y=t=>{throw Error(t)},d=async(t,a,e)=>{try{return await t()}catch(t){a?.(t)}},g=(t,a)=>t.forEach(a),w=(t,...a)=>t.push(...a),p=t=>t.shift(),h=Object,v=t=>h.getPrototypeOf(t),f=h.entries,S=h.keys,C=h.freeze,A=(t,a)=>g(f(t),([t,e])=>a(e,t)),b=t=>(t=>!n(t)&&r(v(t),t=>t==h.prototype||n(v(t)),()=>!0))(t)&&0==(t=>u(S(t)))(t),L=(t,a,e)=>(((t,a)=>a in t)(t,a)||(t[a]=e()),t[a]),M=JSON.stringify,E=t=>s(t)||0==(t=>t?.size??0)(t),O=(t,a)=>t?.forEach(a),P=(t,a)=>t?.delete(a),T=t=>new Map(t),x=(t,a)=>t?.get(a),z=(t,a,e)=>void 0===e?(P(t,a),t):t?.set(a,e),D=(t,a,e,n)=>{var s,r;return s=t,r=a,s?.has(r)?n?.(x(t,a)):z(t,a,e()),x(t,a)},J=(t,a,e,n,s=0)=>o((e?D:x)(t,a[s],s>u(a)-2?e:T),r=>{if(s>u(a)-2)return n?.(r)&&z(t,a[s]),r;const o=J(r,a,e,n,s+1);return E(r)&&z(t,a[s]),o}),N=(t,a,e)=>{a>t[1]&&(t[1]=a),t[2]=e>>>0},j=/^\d+$/,k=t=>new Set(i(t)||s(t)?t:[t]),F=T(),W=T(),$=(t,a,e,n,r,c,l,h={},v=0,f=[])=>{let S,A,L,M=0,N=0,$=0;D(F,f,()=>0),D(W,f,()=>[]);const m=T(),[q,B,G,H,I]=((t=1,a,e)=>1!=t&&a.isMergeable()?[1,a.getMergeableContent,()=>a.getTransactionMergeableChanges(!e),([[t],[a]])=>!b(t)||!b(a),a.setDefaultContent]:2!=t?[0,a.getContent,a.getTransactionChanges,([t,a])=>!b(t)||!b(a),a.setContent]:y("Store type not supported by this Persister"))(l,t,v),[K,Q,R]=(()=>{let t;const[a,e]=(()=>{const t=[];let a=0;return[e=>(e?p(t):null)??""+a++,a=>{j.test(a)&&u(t)<1e3&&w(t,a)}]})(),n=T();return[(e,s,r,o=[],i=()=>[])=>{t??=st;const c=a(1);var u,l;return z(n,c,[e,s,r,o,i]),u=J(s,r??[""],k),l=c,u?.add(l),c},(a,e,...s)=>g(((t,a=[""])=>{const e=[],n=(t,s)=>s==u(a)?w(e,t):null===a[s]?O(t,t=>n(t,s+1)):g([a[s],null],a=>n(x(t,a),s+1));return n(t,0),e})(a,e),a=>O(a,a=>x(n,a)[0](t,...e??[],...s))),t=>o(x(n,t),([,a,s])=>(J(a,s??[""],void 0,a=>(P(a,t),E(a)?1:0)),z(n,t),e(t),s)),a=>o(x(n,a),([a,,e=[],n,s])=>{const r=(...o)=>{const i=u(o);i==u(e)?a(t,...o,...s(o)):(t=>null===t)(e[i])?g(n[i]?.(...o)??[],t=>r(...o,t)):r(...o,e[i])};r()})]})(),U=t=>{t!=M&&(M=t,Q(m,void 0,M))},V=a=>{(q&&i(a?.[0])?1===a?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===a?.[2]?t.applyChanges:t.setContent)(a)},X=async t=>(2!=M&&(U(1),N++,await nt(async()=>{await d(async()=>{const e=await a();i(e)?V(e):t?I(t):y("Content is not an array: "+e)},()=>{t&&I(t)}),U(0)})),st),Y=async t=>(Z(),await X(t),await d(async()=>A=await n(async(t,a)=>{a||t?2!=M&&(U(1),N++,V(a??t),U(0)):await X()}),c),st),Z=async()=>(A&&(await d(()=>r(A),c),A=void 0),st),_=async t=>(1!=M&&(U(2),$++,await nt(async()=>{await d(()=>e(B,t),c),U(0)})),st),tt=async()=>(at(),await _(),L=t.addDidFinishTransactionListener(()=>{const t=G();H(t)&&_(t)}),st),at=async()=>(L&&(t.delListener(L),L=void 0),st),et=async(t=!1)=>{const[a,e]=t?[at,Z]:[Z,at];return await a(),await e(),st},nt=async(...t)=>(w(x(W,f),...t),await(async()=>{if(!x(F,f)){for(z(F,f,1);!s(S=p(x(W,f)));)await d(S,c);z(F,f,0)}})(),st),st={load:X,startAutoLoad:Y,stopAutoLoad:Z,isAutoLoading:()=>!s(A),save:_,startAutoSave:tt,stopAutoSave:at,isAutoSaving:()=>!s(L),startAutoPersisting:async(t,a=!1)=>{const[e,n]=a?[tt,Y]:[Y,tt];return await e(t),await n(t),st},stopAutoPersisting:et,getStatus:()=>M,addStatusListener:t=>K(t,m),delListener:a=>(R(a),t),schedule:nt,getStore:()=>t,destroy:()=>(x(W,f).splice(0,void 0),et()),getStats:()=>({loads:N,saves:$}),...h};return C(st)},m=()=>[{},"",0],q=(e,n,s="",r)=>{const i=(t,...a)=>s+t+c(M(a,(t,a)=>void 0===a?"":a),1,-1);return $(e,async()=>{const e=[{},"",0],r=[{},"",0];return(await n.list({prefix:s})).forEach(async([n,i,u],l)=>o((e=>{if(n=s,e.startsWith(n)){const n=c(e,s.length,1);return n==t||n==a?[n,...JSON.parse("["+c(e,s.length+1)+"]")]:void 0}var n})(l),([s,...c])=>s==t?o(c[0],t=>{const a=L(e[0],t,m);o(c[1],t=>{const e=L(a[0],t,m);o(c[2],t=>e[0][t]=[n,i,u],()=>N(e,i,u))},()=>N(a,i,u))},()=>N(e,i,u)):s==a?o(c[0],t=>r[0][t]=[n,i,u],()=>N(r,i,u)):0)),[e,r]},async(e,[[s,r,o],[c,u,l]]=e())=>{const y=T();z(y,i(t),[0,r,o]),A(s,([a,e,n],s)=>{z(y,i(t,s),[0,e,n]),A(a,([a,e,n],r)=>{z(y,i(t,s,r),[0,e,n]),A(a,(a,e)=>z(y,i(t,s,r,e),a))})}),z(y,i(a),[0,u,l]),A(c,(t,e)=>z(y,i(a,e),t)),await n.put((t=>{const a={};return O(t,(t,e)=>{{const n=t;a[e]=n}}),a})(y))},l,l,r,2,{getStorage:()=>n})};export{q as createDurableObjectStoragePersister};
1
+ const t="t",a="v",e=t=>(a,e,n)=>t(a)?n?.():e(a),n=t=>null==t,s=t=>void 0===t,r=e(n),o=e(s),i=t=>Array.isArray(t),c=(t,a,e)=>t.slice(a,e),u=t=>t.length,l=()=>{},y=t=>{throw Error(t)},d=async(t,a,e)=>{try{return await t()}catch(t){a?.(t)}},g=(t,a)=>t.forEach(a),w=(t,...a)=>t.push(...a),p=t=>t.shift(),h=Object,v=t=>h.getPrototypeOf(t),f=h.entries,S=h.keys,C=h.freeze,A=(t,a)=>g(f(t),([t,e])=>a(e,t)),b=t=>(t=>!n(t)&&r(v(t),t=>t==h.prototype||n(v(t)),()=>!0))(t)&&0==(t=>u(S(t)))(t),L=(t,a,e)=>(((t,a)=>a in t)(t,a)||(t[a]=e()),t[a]),M=JSON.stringify,E=t=>s(t)||0==(t=>t?.size??0)(t),O=(t,a)=>t?.forEach(a),P=(t,a)=>t?.delete(a),T=t=>new Map(t),x=(t,a)=>t?.get(a),z=(t,a,e)=>void 0===e?(P(t,a),t):t?.set(a,e),D=(t,a,e,n)=>{var s,r;return s=t,r=a,s?.has(r)?n?.(x(t,a)):z(t,a,e()),x(t,a)},J=(t,a,e,n,s=0)=>o((e?D:x)(t,a[s],s>u(a)-2?e:T),r=>{if(s>u(a)-2)return n?.(r)&&z(t,a[s]),r;const o=J(r,a,e,n,s+1);return E(r)&&z(t,a[s]),o}),N=(t,a,e)=>{a>t[1]&&(t[1]=a),t[2]=e>>>0},j=/^\d+$/,k=t=>new Set(i(t)||s(t)?t:[t]),F=T(),W=T(),$=(t,a,e,n,r,c,l,h={},v=0,f=[])=>{let S,A,L,M=0,N=0,$=0;D(F,f,()=>0),D(W,f,()=>[]);const m=T(),[q,B,G,H,I]=((t=1,a,e)=>1!=t&&a.isMergeable()?[1,a.getMergeableContent,()=>a.getTransactionMergeableChanges(!e),([[t],[a]])=>!b(t)||!b(a),a.setDefaultContent]:2!=t?[0,a.getContent,a.getTransactionChanges,([t,a])=>!b(t)||!b(a),a.setContent]:y("Store type not supported by this Persister"))(l,t,v),[K,Q,R]=(()=>{let t;const[a,e]=(()=>{const t=[];let a=0;return[e=>(e?p(t):null)??""+a++,a=>{j.test(a)&&u(t)<1e3&&w(t,a)}]})(),n=T();return[(e,s,r,o=[],i=()=>[])=>{t??=st;const c=a(1);var u,l;return z(n,c,[e,s,r,o,i]),u=J(s,r??[""],k),l=c,u?.add(l),c},(a,e,...s)=>g(((t,a=[""])=>{const e=[],n=(t,s)=>s==u(a)?w(e,t):null===a[s]?O(t,t=>n(t,s+1)):g([a[s],null],a=>n(x(t,a),s+1));return n(t,0),e})(a,e),a=>O(a,a=>x(n,a)[0](t,...e??[],...s))),t=>o(x(n,t),([,a,s])=>(J(a,s??[""],void 0,a=>(P(a,t),E(a)?1:0)),z(n,t),e(t),s)),a=>o(x(n,a),([a,,e=[],n,s])=>{const r=(...o)=>{const i=u(o);i==u(e)?a(t,...o,...s(o)):(t=>null===t)(e[i])?g(n[i]?.(...o)??[],t=>r(...o,t)):r(...o,e[i])};r()})]})(),U=t=>{t!=M&&(M=t,Q(m,void 0,M))},V=a=>{(q&&i(a?.[0])?1===a?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===a?.[2]?t.applyChanges:t.setContent)(a)},X=async t=>(2!=M&&(U(1),N++,await nt(async()=>{await d(async()=>{const e=await a();i(e)?V(e):t?I(t):y("Content is not an array: "+e)},()=>{t&&I(t)}),U(0)})),st),Y=async t=>(Z(),await X(t),await d(async()=>A=await n(async(t,a)=>{a||t?2!=M&&(U(1),N++,V(a??t),U(0)):await X()}),c),st),Z=async()=>(A&&(await d(()=>r(A),c),A=void 0),st),_=async t=>(1!=M&&(U(2),$++,await nt(async()=>{await d(()=>e(B,t),c),U(0)})),st),tt=async()=>(at(),await _(),L=t.addDidFinishTransactionListener(()=>{const t=G();H(t)&&_(t)}),st),at=async()=>(L&&(t.delListener(L),L=void 0),st),et=async(t=!1)=>{const[a,e]=t?[at,Z]:[Z,at];return await a(),await e(),st},nt=async(...t)=>(w(x(W,f),...t),await(async()=>{if(!x(F,f)){for(z(F,f,1);!s(S=p(x(W,f)));)await d(S,c);z(F,f,0)}})(),st),st={load:X,startAutoLoad:Y,stopAutoLoad:Z,isAutoLoading:()=>!s(A),save:_,startAutoSave:tt,stopAutoSave:at,isAutoSaving:()=>!s(L),startAutoPersisting:async(t,a=!1)=>{const[e,n]=a?[tt,Y]:[Y,tt];return await e(t),await n(t),st},stopAutoPersisting:et,getStatus:()=>M,addStatusListener:t=>K(t,m),delListener:a=>(R(a),t),schedule:nt,getStore:()=>t,destroy:()=>(x(W,f).splice(0,void 0),et()),getStats:()=>({loads:N,saves:$}),...h};return C(st)},m=()=>[{},"",0],q=(e,n,s="",r)=>{const i=(t,...a)=>s+t+c(M(a,(t,a)=>void 0===a?"":a),1,-1);return $(e,async()=>{const e=[{},"",0],r=[{},"",0];return(await n.list({prefix:s})).forEach(async([n,i,u],l)=>o((e=>{if(n=s,e.startsWith(n)){const n=c(e,s.length,1);return n==t||n==a?[n,...JSON.parse("["+c(e,s.length+1)+"]")]:void 0}var n})(l),([s,...c])=>s==t?o(c[0],t=>{const a=L(e[0],t,m);o(c[1],t=>{const e=L(a[0],t,m);o(c[2],t=>e[0][t]=[n,i,u],()=>N(e,i,u))},()=>N(a,i,u))},()=>N(e,i,u)):s==a?o(c[0],t=>r[0][t]=[n,i,u],()=>N(r,i,u)):0)),[e,r]},async(e,[[s,r,o],[c,u,l]]=e())=>{const y=T();z(y,i(t),[0,r,o]),A(s,([a,e,n],s)=>{z(y,i(t,s),[0,e,n]),A(a,([a,e,n],r)=>{z(y,i(t,s,r),[0,e,n]),A(a,(a,e)=>z(y,i(t,s,r,e),a))})}),z(y,i(a),[0,u,l]),A(c,(t,e)=>z(y,i(a,e),t)),await n.put((t=>{const a={};return O(t,(t,e)=>{{const n=t;a[e]=n}}),a})(y))},l,l,r,2,{getStorage:()=>n})};export{q as createDurableObjectStoragePersister};
@@ -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=w)=>(t,e,n)=>a(t)?n?.():e(t),l=clearInterval,w=a=>null==a,u=a=>void 0===a,y=a=>null===a,d=c(w),g=c(u),v=t=>a(t)==s,E=a=>Array.isArray(a),p=(a,t,e)=>a.slice(t,e),A=a=>a.length,m=()=>{},N=async a=>o.all(a),$=a=>{throw Error(a)},f=async(a,t,e)=>{try{return await a()}catch(a){t?.(a)}},b=(a,t)=>a.forEach(t),C=(a,t="")=>a.join(t),T=(a,t)=>a.map(t),h=a=>0==A(a),D=(a,t)=>a.filter(t),O=(a,...t)=>a.push(...t),I=a=>a.shift(),S=(a,t)=>a?.has(t)??!1,L=a=>u(a)||0==(a=>a?.size??0)(a),R=a=>[...a?.values()??[]],P=(a,t)=>a?.forEach(t),M=(a,t)=>a?.delete(t),_="_",F="_id",U="SELECT",j="WHERE",B="TABLE",J="ALTER "+B,Y="FROM",k="DELETE "+Y,x=U+"*"+Y,z="pragma_",G="data_version",H="schema_version",q="pragma_table_",K="CREATE "+B,Q=a=>C(T(((a,t="",e)=>a.split(t,e))(a,"."),a=>`"${r(a,/"/g,'""')}"`),"."),V=(a,t=[1])=>C(T(a,()=>"$"+t[0]++),n),W=(a,t=i)=>j+`(${r(t,"$tableName",Q(a))})`,X=Object,Z=a=>X.getPrototypeOf(a),aa=X.entries,ta=X.keys,ea=X.freeze,na=(a=[])=>X.fromEntries(a),sa=(...a)=>X.assign({},...a),ia=(a,t)=>(delete a[t],a),ra=(a,t)=>T(aa(a),([a,e])=>t(e,a)),oa=(a,t)=>na(ra(a,(a,e)=>[e,t(a,e)])),ca=a=>X.values(a),la=a=>A(ta(a)),wa=a=>(a=>!w(a)&&d(Z(a),a=>a==X.prototype||w(Z(a)),()=>!0))(a)&&0==la(a),ua=a=>new Map(a),ya=(a,t)=>a?.get(t),da=(a,t)=>T([...a?.entries()??[]],([a,e])=>t(e,a)),ga=(a,t,e)=>void 0===e?(M(a,t),a):a?.set(t,e),va=(a,t,e,n)=>(S(a,t)?n?.(ya(a,t)):ga(a,t,e()),ya(a,t)),Ea=(a,t,e,n,s=0)=>g((e?va:ya)(a,t[s],s>A(t)-2?e:ua),i=>{if(s>A(t)-2)return n?.(i)&&ga(a,t[s]),i;const r=Ea(i,t,e,n,s+1);return L(i)&&ga(a,t[s]),r}),pa=a=>new Set(E(a)||u(a)?a:[a]),Aa=(a,t)=>a?.add(t),ma="ColumnName",Na="store",$a="json",fa=Na+"TableName",ba=Na+"Id"+ma,Ca=Na+ma,Ta="autoLoadIntervalSeconds",ha="rowId"+ma,Da="tableId",Oa="tableName",Ia="deleteEmptyColumns",Sa="deleteEmptyTable",La="condition",Ra={mode:$a,[Ta]:1},Pa={load:0,save:0,[Oa]:t+"_values"},Ma=(a,t,e,n,s)=>{const i=ua();return oa(a,(a,r)=>{const o=p(ca(sa(t,v(a)?{[e]:a}:a)),0,la(t));y(o[0])||n(r,o[0])||(s(r,o[0]),ga(i,r,o))}),i},_a=JSON.stringify,Fa=JSON.parse,Ua=/^\d+$/,ja=ua(),Ba=ua(),Ja=(a,t,n,s,i,r,o,c={},l=0,w=[])=>{let d,v,p,m=0,N=0,C=0;va(ja,w,()=>0),va(Ba,w,()=>[]);const T=ua(),[h,D,S,R,_]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!wa(a)||!wa(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!wa(a)||!wa(t),t.setContent]:$("Store type not supported by this Persister"))(o,a,l),[F,U,j]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?I(a):null)??e+t++,t=>{Ua.test(t)&&A(a)<1e3&&O(a,t)}]})(),s=ua();return[(n,i,r,o=[],c=()=>[])=>{a??=Q;const l=t(1);return ga(s,l,[n,i,r,o,c]),Aa(Ea(i,r??[e],pa),l),l},(t,n,...i)=>b(((a,t=[e])=>{const n=[],s=(a,e)=>e==A(t)?O(n,a):null===t[e]?P(a,a=>s(a,e+1)):b([t[e],null],t=>s(ya(a,t),e+1));return s(a,0),n})(t,n),t=>P(t,t=>ya(s,t)[0](a,...n??[],...i))),a=>g(ya(s,a),([,t,i])=>(Ea(t,i??[e],void 0,t=>(M(t,a),L(t)?1:0)),ga(s,a),n(a),i)),t=>g(ya(s,t),([t,,e=[],n,s])=>{const i=(...r)=>{const o=A(r);o==A(e)?t(a,...r,...s(r)):y(e[o])?b(n[o]?.(...r)??[],a=>i(...r,a)):i(...r,e[o])};i()})]})(),B=a=>{a!=m&&(m=a,U(T,void 0,m))},J=t=>{(h&&E(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},Y=async a=>(2!=m&&(B(1),N++,await K(async()=>{await f(async()=>{const e=await t();E(e)?J(e):a?_(a):$("Content is not an array: "+e)},()=>{a&&_(a)}),B(0)})),Q),k=async a=>(x(),await Y(a),await f(async()=>v=await s(async(a,t)=>{t||a?2!=m&&(B(1),N++,J(t??a),B(0)):await Y()}),r),Q),x=async()=>(v&&(await f(()=>i(v),r),v=void 0),Q),z=async a=>(1!=m&&(B(2),C++,await K(async()=>{await f(()=>n(D,a),r),B(0)})),Q),G=async()=>(H(),await z(),p=a.addDidFinishTransactionListener(()=>{const a=S();R(a)&&z(a)}),Q),H=async()=>(p&&(a.delListener(p),p=void 0),Q),q=async(a=!1)=>{const[t,e]=a?[H,x]:[x,H];return await t(),await e(),Q},K=async(...a)=>(O(ya(Ba,w),...a),await(async()=>{if(!ya(ja,w)){for(ga(ja,w,1);!u(d=I(ya(Ba,w)));)await f(d,r);ga(ja,w,0)}})(),Q),Q={load:Y,startAutoLoad:k,stopAutoLoad:x,isAutoLoading:()=>!u(v),save:z,startAutoSave:G,stopAutoSave:H,isAutoSaving:()=>!u(p),startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[G,k]:[k,G];return await e(a),await n(a),Q},stopAutoPersisting:q,getStatus:()=>m,addStatusListener:a=>F(a,T),delListener:t=>(j(t),a),schedule:K,getStore:()=>a,destroy:()=>(ya(Ba,w).splice(0,void 0),q()),getStats:()=>({loads:N,saves:C}),...c};return ea(Q)},Ya=(a,t,e,s,r,o=ka,c,l)=>{const w=ua();return[async()=>{w.clear(),T(await e(a,t),({tn:a,cn:t})=>Aa(va(w,a,pa),t))},async(t,e,n)=>((a,t)=>S(ya(w,a),t))(t,e)?na(D(T(await a(x+Q(t)+W(t,n)),a=>[a[e],l?oa(ia(a,e),l):ia(a,e)]),([a,t])=>!u(a)&&!wa(t))):{},async(t,e,s,l,y,d=!1,g=i)=>{const v=pa();oa(s??{},a=>T(ta(a??{}),a=>Aa(v,a)));const E=R(v);if(!d&&y&&g==i&&h(E)&&S(w,t))return await a("DROP "+B+Q(t)),void ga(w,t);const p=ya(w,t),A=pa(R(p));if(h(E)||(S(w,t)?await N(T([e,...E],async(n,s)=>{M(A,n)||(await a(J+Q(t)+"ADD"+Q(n)+r),0==s&&await a("CREATE UNIQUE INDEX pk ON "+Q(t)+`(${Q(e)})`),Aa(p,n))})):(await a(K+Q(t)+`(${Q(e)}${r} PRIMARY KEY${C(T(E,a=>n+Q(a)+r))});`),ga(w,t,pa([e,...E])))),await N([...!d&&l?T(R(A),async n=>{n!=e&&(await a(J+Q(t)+"DROP"+Q(n)),M(p,n))}):[]]),d)u(s)?await a(k+Q(t)+W(t,g)):await N(ra(s,async(n,s)=>{u(n)?await a(k+Q(t)+W(t,g)+`AND(${Q(e)}=$1)`,[s]):h(E)||await o(a,t,e,ta(n),{[s]:c?T(ca(n),c):ca(n)},p)}));else if(h(E))S(w,t)&&await a(k+Q(t)+W(t,g));else{const n=D(R(ya(w,t)),a=>a!=e),i={},r=[];oa(s??{},(a,t)=>{i[t]=T(n,t=>c?c(a?.[t]):a?.[t]),O(r,t)}),await o(a,t,e,n,i),await a(k+Q(t)+W(t,g)+`AND${Q(e)}NOT IN(${V(r)})`,r)}},async t=>{let e;return await a("BEGIN"),await f(async()=>e=await t(),s),await a("END"),e}]},ka=async(a,t,e,s,i)=>{const r=[1];await a("INSERT INTO"+Q(t)+"("+((...a)=>C(T(a,Q),n))(e,...s)+")VALUES"+C(ra(i,a=>"($"+r[0]+++","+V(a,r)+")"),n)+"ON CONFLICT("+Q(e)+")DO UPDATE SET"+C(T(s,a=>Q(a)+"=excluded."+Q(a)),n),ra(i,(a,t)=>[t,...T(a,a=>a??null)]).flat())},xa=(a,t,e,n,s,i,r,[o,c,l],w,u,y,d,g,v)=>{const[E,p,A,m]=Ya(t,w,u,s,g,v),N=Ja(a,()=>m(async()=>{return await E(),a=(await p(o,c))[_]?.[l]??"null",Fa(a,(a,t)=>""===t?void 0:t);var a}),a=>m(async()=>{var t;await E(),await A(o,c,{[_]:{[l]:(t=a()??null,_a(t,(a,t)=>void 0===t?"":t))}},!0,!0)}),e,n,s,r,{[d]:()=>y,destroy:async()=>(await N.stopAutoPersisting(),i(),N)},0,y);return N},za=(a,t,e,n,s,i,r,[o,c,[l,w,y]],d,g,v,E,p,A,m,$)=>{const[f,b,C,T]=Ya(t,d,g,s,p,A,m,$),h=(a,t)=>N(da(c,async([e,n,s,i,r],o)=>{t&&!(o in a)||await C(e,n,a[o],s,i,t,r)})),O=async(a,t)=>w?await C(y,F,{[_]:a},!0,!0,t):null,I=Ja(a,()=>T(async()=>{await f();const a=await(async()=>na(D(await N(da(o,async([a,t,e],n)=>[a,await b(n,t,e)])),a=>!wa(a[1]))))(),t=await(async()=>l?(await b(y,F))[_]:{})();return wa(a)&&u(t)?void 0:[a,t]}),(a,t)=>T(async()=>{if(await f(),u(t)){const[t,e]=a();await h(t),await O(e)}else await h(t[0],!0),await O(t[1],!0)}),e,n,s,r,{[E]:()=>v,destroy:async()=>(await I.stopAutoPersisting(),i(),I)},0,v);return I},Ga=(a,n,s,r,o,c,u,y,d,g,E="getDb",A)=>{let m,N,$;const b=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,c),[C,T,h,D]=(a=>{const e=(a=>sa(Ra,v(a)?{[fa]:a}:a??{}))(a),n=e[Ta];if(e.mode==$a){const a=e[fa]??t;return[1,n,[a,e[ba]??F,e[Ca]??Na],pa(a)]}const{tables:{load:s={},save:r={}}={},values:o={}}=e,c=p(ca(sa(Pa,o)),0,la(Pa)),l=c[2],w=pa(l),u=pa(l),y=Ma(s,{[Da]:null,[ha]:F,[La]:i},Da,a=>S(u,a),a=>Aa(w,a)),d=Ma(r,{[Oa]:null,[ha]:F,[Ia]:0,[Sa]:0,[La]:null},Oa,(a,t)=>S(u,t),(a,t)=>Aa(w,t));var g;return g=(a,t)=>t[4]??=ya(y,t[0])?.[2]??i,P(d,(a,t)=>g(0,a)),[0,n,[y,d,c],w]})(n);return(C?xa:za)(a,b,a=>{let t;const e=()=>t=setInterval(()=>f(async()=>{const[{d:t,s:e,c:n}]=await b(U+` ${G} d,${H} s,TOTAL_CHANGES() c FROM ${z}${G} JOIN ${z}${H}`);t==m&&e==N&&n==$||(w(m)||a(),m=t,N=e,$=n)}),1e3*T),n=()=>{m=N=$=null,l(t)},s=r(t=>{D.has(t)&&(n(),a(),e())});return e(),()=>{n(),o(s)}},a=>a(),u,y,d,h,R(D),async(a,t)=>await a(U+` t.name tn,c.name cn FROM ${q}list()t,${q}info(t.name)c ${j} t.schema='main'AND t.type IN('table','view')AND t.name IN(${V(t)})ORDER BY t.name,c.name`,t),g,E,e,A,a=>!0===a?1:!1===a?0:a,void 0)},Ha=(a,t,e,n,s)=>Ga(a,e,async(a,e=[])=>await t.db.raw({sql:a,args:e}),a=>t.notifier.subscribeToDataChanges(e=>b(t.notifier.alias(e),({tablename:t})=>a(t))),a=>a(),n,s,m,1,t,"getElectricClient");export{Ha as createElectricSqlPersister};
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,u=a=>void 0===a,y=a=>null===a,d=c(w),g=c(u),v=t=>a(t)==s,E=a=>Array.isArray(a),p=(a,t,e)=>a.slice(t,e),A=a=>a.length,m=()=>{},N=async a=>o.all(a),$=a=>{throw Error(a)},f=async(a,t,e)=>{try{return await a()}catch(a){t?.(a)}},b=(a,t)=>a.forEach(t),C=(a,t="")=>a.join(t),T=(a,t)=>a.map(t),h=a=>0==A(a),D=(a,t)=>a.filter(t),O=(a,...t)=>a.push(...t),I=a=>a.shift(),S=(a,t)=>a?.has(t)??!1,L=a=>u(a)||0==(a=>a?.size??0)(a),R=a=>[...a?.values()??[]],P=(a,t)=>a?.forEach(t),M=(a,t)=>a?.delete(t),_="_",F="_id",U="SELECT",j="WHERE",B="TABLE",J="ALTER "+B,Y="FROM",k="DELETE "+Y,x=U+"*"+Y,z="pragma_",G="data_version",H="schema_version",q="pragma_table_",K="CREATE "+B,Q=a=>C(T(((a,t="",e)=>a.split(t,e))(a,"."),a=>`"${r(a,/"/g,'""')}"`),"."),V=(a,t=[1])=>C(T(a,()=>"$"+t[0]++),n),W=(a,t=i)=>j+`(${r(t,"$tableName",Q(a))})`,X=Object,Z=a=>X.getPrototypeOf(a),aa=X.entries,ta=X.keys,ea=X.freeze,na=(a=[])=>X.fromEntries(a),sa=(...a)=>X.assign({},...a),ia=(a,t)=>(delete a[t],a),ra=(a,t)=>T(aa(a),([a,e])=>t(e,a)),oa=(a,t)=>na(ra(a,(a,e)=>[e,t(a,e)])),ca=a=>X.values(a),la=a=>A(ta(a)),wa=a=>(a=>!w(a)&&d(Z(a),a=>a==X.prototype||w(Z(a)),()=>!0))(a)&&0==la(a),ua=a=>new Map(a),ya=(a,t)=>a?.get(t),da=(a,t)=>T([...a?.entries()??[]],([a,e])=>t(e,a)),ga=(a,t,e)=>void 0===e?(M(a,t),a):a?.set(t,e),va=(a,t,e,n)=>(S(a,t)?n?.(ya(a,t)):ga(a,t,e()),ya(a,t)),Ea=(a,t,e,n,s=0)=>g((e?va:ya)(a,t[s],s>A(t)-2?e:ua),i=>{if(s>A(t)-2)return n?.(i)&&ga(a,t[s]),i;const r=Ea(i,t,e,n,s+1);return L(i)&&ga(a,t[s]),r}),pa=a=>new Set(E(a)||u(a)?a:[a]),Aa=(a,t)=>a?.add(t),ma="ColumnName",Na="store",$a="json",fa=Na+"TableName",ba=Na+"Id"+ma,Ca=Na+ma,Ta="autoLoadIntervalSeconds",ha="rowId"+ma,Da="tableId",Oa="tableName",Ia="deleteEmptyColumns",Sa="deleteEmptyTable",La="condition",Ra={mode:$a,[Ta]:1},Pa={load:0,save:0,[Oa]:t+"_values"},Ma=(a,t,e,n,s)=>{const i=ua();return oa(a,(a,r)=>{const o=p(ca(sa(t,v(a)?{[e]:a}:a)),0,la(t));y(o[0])||n(r,o[0])||(s(r,o[0]),ga(i,r,o))}),i},_a=JSON.stringify,Fa=JSON.parse,Ua=/^\d+$/,ja=ua(),Ba=ua(),Ja=(a,t,n,s,i,r,o,c={},l=0,w=[])=>{let d,v,p,m=0,N=0,C=0;va(ja,w,()=>0),va(Ba,w,()=>[]);const T=ua(),[h,D,S,R,_]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!wa(a)||!wa(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!wa(a)||!wa(t),t.setContent]:$("Store type not supported by this Persister"))(o,a,l),[F,U,j]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?I(a):null)??e+t++,t=>{Ua.test(t)&&A(a)<1e3&&O(a,t)}]})(),s=ua();return[(n,i,r,o=[],c=()=>[])=>{a??=Q;const l=t(1);return ga(s,l,[n,i,r,o,c]),Aa(Ea(i,r??[e],pa),l),l},(t,n,...i)=>b(((a,t=[e])=>{const n=[],s=(a,e)=>e==A(t)?O(n,a):null===t[e]?P(a,a=>s(a,e+1)):b([t[e],null],t=>s(ya(a,t),e+1));return s(a,0),n})(t,n),t=>P(t,t=>ya(s,t)[0](a,...n??[],...i))),a=>g(ya(s,a),([,t,i])=>(Ea(t,i??[e],void 0,t=>(M(t,a),L(t)?1:0)),ga(s,a),n(a),i)),t=>g(ya(s,t),([t,,e=[],n,s])=>{const i=(...r)=>{const o=A(r);o==A(e)?t(a,...r,...s(r)):y(e[o])?b(n[o]?.(...r)??[],a=>i(...r,a)):i(...r,e[o])};i()})]})(),B=a=>{a!=m&&(m=a,U(T,void 0,m))},J=t=>{(h&&E(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},Y=async a=>(2!=m&&(B(1),N++,await K(async()=>{await f(async()=>{const e=await t();E(e)?J(e):a?_(a):$("Content is not an array: "+e)},()=>{a&&_(a)}),B(0)})),Q),k=async a=>(x(),await Y(a),await f(async()=>v=await s(async(a,t)=>{t||a?2!=m&&(B(1),N++,J(t??a),B(0)):await Y()}),r),Q),x=async()=>(v&&(await f(()=>i(v),r),v=void 0),Q),z=async a=>(1!=m&&(B(2),C++,await K(async()=>{await f(()=>n(D,a),r),B(0)})),Q),G=async()=>(H(),await z(),p=a.addDidFinishTransactionListener(()=>{const a=S();R(a)&&z(a)}),Q),H=async()=>(p&&(a.delListener(p),p=void 0),Q),q=async(a=!1)=>{const[t,e]=a?[H,x]:[x,H];return await t(),await e(),Q},K=async(...a)=>(O(ya(Ba,w),...a),await(async()=>{if(!ya(ja,w)){for(ga(ja,w,1);!u(d=I(ya(Ba,w)));)await f(d,r);ga(ja,w,0)}})(),Q),Q={load:Y,startAutoLoad:k,stopAutoLoad:x,isAutoLoading:()=>!u(v),save:z,startAutoSave:G,stopAutoSave:H,isAutoSaving:()=>!u(p),startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[G,k]:[k,G];return await e(a),await n(a),Q},stopAutoPersisting:q,getStatus:()=>m,addStatusListener:a=>F(a,T),delListener:t=>(j(t),a),schedule:K,getStore:()=>a,destroy:()=>(ya(Ba,w).splice(0,void 0),q()),getStats:()=>({loads:N,saves:C}),...c};return ea(Q)},Ya=(a,t,e,s,r,o=ka,c,l)=>{const w=ua();return[async()=>{w.clear(),T(await e(a,t),({tn:a,cn:t})=>Aa(va(w,a,pa),t))},async(t,e,n)=>((a,t)=>S(ya(w,a),t))(t,e)?na(D(T(await a(x+Q(t)+W(t,n)),a=>[a[e],l?oa(ia(a,e),l):ia(a,e)]),([a,t])=>!u(a)&&!wa(t))):{},async(t,e,s,l,y,d=!1,g=i)=>{const v=pa();oa(s??{},a=>T(ta(a??{}),a=>Aa(v,a)));const E=R(v);if(!d&&y&&g==i&&h(E)&&S(w,t))return await a("DROP "+B+Q(t)),void ga(w,t);const p=ya(w,t),A=pa(R(p));if(h(E)||(S(w,t)?await N(T([e,...E],async(n,s)=>{M(A,n)||(await a(J+Q(t)+"ADD"+Q(n)+r),0==s&&await a("CREATE UNIQUE INDEX pk ON "+Q(t)+`(${Q(e)})`),Aa(p,n))})):(await a(K+Q(t)+`(${Q(e)}${r} PRIMARY KEY${C(T(E,a=>n+Q(a)+r))});`),ga(w,t,pa([e,...E])))),await N([...!d&&l?T(R(A),async n=>{n!=e&&(await a(J+Q(t)+"DROP"+Q(n)),M(p,n))}):[]]),d)u(s)?await a(k+Q(t)+W(t,g)):await N(ra(s,async(n,s)=>{u(n)?await a(k+Q(t)+W(t,g)+`AND(${Q(e)}=$1)`,[s]):h(E)||await o(a,t,e,ta(n),{[s]:c?T(ca(n),c):ca(n)},p)}));else if(h(E))S(w,t)&&await a(k+Q(t)+W(t,g));else{const n=D(R(ya(w,t)),a=>a!=e),i={},r=[];oa(s??{},(a,t)=>{i[t]=T(n,t=>c?c(a?.[t]):a?.[t]),O(r,t)}),await o(a,t,e,n,i),await a(k+Q(t)+W(t,g)+`AND${Q(e)}NOT IN(${V(r)})`,r)}},async t=>{let e;return await a("BEGIN"),await f(async()=>e=await t(),s),await a("END"),e}]},ka=async(a,t,e,s,i)=>{const r=[1];await a("INSERT INTO"+Q(t)+"("+((...a)=>C(T(a,Q),n))(e,...s)+")VALUES"+C(ra(i,a=>"($"+r[0]+++","+V(a,r)+")"),n)+"ON CONFLICT("+Q(e)+")DO UPDATE SET"+C(T(s,a=>Q(a)+"=excluded."+Q(a)),n),ra(i,(a,t)=>[t,...T(a,a=>a??null)]).flat())},xa=(a,t,e,n,s,i,r,[o,c,l],w,u,y,d,g,v)=>{const[E,p,A,m]=Ya(t,w,u,s,g,v),N=Ja(a,()=>m(async()=>{return await E(),a=(await p(o,c))[_]?.[l]??"null",Fa(a,(a,t)=>""===t?void 0:t);var a}),a=>m(async()=>{var t;await E(),await A(o,c,{[_]:{[l]:(t=a()??null,_a(t,(a,t)=>void 0===t?"":t))}},!0,!0)}),e,n,s,r,{[d]:()=>y,destroy:async()=>(await N.stopAutoPersisting(),i(),N)},0,y);return N},za=(a,t,e,n,s,i,r,[o,c,[l,w,y]],d,g,v,E,p,A,m,$)=>{const[f,b,C,T]=Ya(t,d,g,s,p,A,m,$),h=(a,t)=>N(da(c,async([e,n,s,i,r],o)=>{t&&!(o in a)||await C(e,n,a[o],s,i,t,r)})),O=async(a,t)=>w?await C(y,F,{[_]:a},!0,!0,t):null,I=Ja(a,()=>T(async()=>{await f();const a=await(async()=>na(D(await N(da(o,async([a,t,e],n)=>[a,await b(n,t,e)])),a=>!wa(a[1]))))(),t=await(async()=>l?(await b(y,F))[_]:{})();return wa(a)&&u(t)?void 0:[a,t]}),(a,t)=>T(async()=>{if(await f(),u(t)){const[t,e]=a();await h(t),await O(e)}else await h(t[0],!0),await O(t[1],!0)}),e,n,s,r,{[E]:()=>v,destroy:async()=>(await I.stopAutoPersisting(),i(),I)},0,v);return I},Ga=(a,n,s,r,o,c,u,y,d,g,E="getDb",A)=>{let m,N,$;const b=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,c),[C,T,h,D]=(a=>{const e=(a=>sa(Ra,v(a)?{[fa]:a}:a??{}))(a),n=e[Ta];if(e.mode==$a){const a=e[fa]??t;return[1,n,[a,e[ba]??F,e[Ca]??Na],pa(a)]}const{tables:{load:s={},save:r={}}={},values:o={}}=e,c=p(ca(sa(Pa,o)),0,la(Pa)),l=c[2],w=pa(l),u=pa(l),y=Ma(s,{[Da]:null,[ha]:F,[La]:i},Da,a=>S(u,a),a=>Aa(w,a)),d=Ma(r,{[Oa]:null,[ha]:F,[Ia]:0,[Sa]:0,[La]:null},Oa,(a,t)=>S(u,t),(a,t)=>Aa(w,t));var g;return g=(a,t)=>t[4]??=ya(y,t[0])?.[2]??i,P(d,(a,t)=>g(0,a)),[0,n,[y,d,c],w]})(n);return(C?xa:za)(a,b,a=>{let t;const e=()=>t=setInterval(()=>f(async()=>{const[{d:t,s:e,c:n}]=await b(U+` ${G} d,${H} s,TOTAL_CHANGES() c FROM ${z}${G} JOIN ${z}${H}`);t==m&&e==N&&n==$||(w(m)||a(),m=t,N=e,$=n)}),1e3*T),n=()=>{m=N=$=null,l(t)},s=r(t=>{D.has(t)&&(n(),a(),e())});return e(),()=>{n(),o(s)}},a=>a(),u,y,d,h,R(D),async(a,t)=>await a(U+` t.name tn,c.name cn FROM ${q}list()t,${q}info(t.name)c ${j} t.schema='main'AND t.type IN('table','view')AND t.name IN(${V(t)})ORDER BY t.name,c.name`,t),g,E,e,A,a=>!0===a?1:!1===a?0:a,void 0)},Ha=(a,t,e,n,s)=>Ga(a,e,async(a,e=[])=>await t.db.raw({sql:a,args:e}),a=>t.notifier.subscribeToDataChanges(e=>b(t.notifier.alias(e),({tablename:t})=>a(t))),a=>a(),n,s,m,1,t,"getElectricClient");export{Ha as createElectricSqlPersister};
@@ -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=w)=>(t,e,n)=>a(t)?n?.():e(t),l=clearInterval,w=a=>null==a,u=a=>void 0===a,y=a=>null===a,d=c(w),g=c(u),v=t=>a(t)==s,E=a=>Array.isArray(a),p=(a,t,e)=>a.slice(t,e),A=a=>a.length,m=()=>{},N=async a=>o.all(a),$=a=>{throw Error(a)},f=async(a,t,e)=>{try{return await a()}catch(a){t?.(a)}},b=(a,t)=>a.forEach(t),C=(a,t="")=>a.join(t),T=(a,t)=>a.map(t),h=a=>0==A(a),D=(a,t)=>a.filter(t),O=(a,...t)=>a.push(...t),I=a=>a.shift(),S=(a,t)=>a?.has(t)??!1,L=a=>u(a)||0==(a=>a?.size??0)(a),R=a=>[...a?.values()??[]],P=(a,t)=>a?.forEach(t),M=(a,t)=>a?.delete(t),_="_",F="_id",U="SELECT",j="WHERE",B="TABLE",J="ALTER "+B,Y="FROM",k="DELETE "+Y,x=U+"*"+Y,z="pragma_",G="data_version",H="schema_version",q="pragma_table_",K="CREATE "+B,Q=a=>C(T(((a,t="",e)=>a.split(t,e))(a,"."),a=>`"${r(a,/"/g,'""')}"`),"."),V=(a,t=[1])=>C(T(a,()=>"$"+t[0]++),n),W=(a,t=i)=>j+`(${r(t,"$tableName",Q(a))})`,X=Object,Z=a=>X.getPrototypeOf(a),aa=X.entries,ta=X.keys,ea=X.freeze,na=(a=[])=>X.fromEntries(a),sa=(...a)=>X.assign({},...a),ia=(a,t)=>(delete a[t],a),ra=(a,t)=>T(aa(a),([a,e])=>t(e,a)),oa=(a,t)=>na(ra(a,(a,e)=>[e,t(a,e)])),ca=a=>X.values(a),la=a=>A(ta(a)),wa=a=>(a=>!w(a)&&d(Z(a),a=>a==X.prototype||w(Z(a)),()=>!0))(a)&&0==la(a),ua=a=>new Map(a),ya=(a,t)=>a?.get(t),da=(a,t)=>T([...a?.entries()??[]],([a,e])=>t(e,a)),ga=(a,t,e)=>void 0===e?(M(a,t),a):a?.set(t,e),va=(a,t,e,n)=>(S(a,t)?n?.(ya(a,t)):ga(a,t,e()),ya(a,t)),Ea=(a,t,e,n,s=0)=>g((e?va:ya)(a,t[s],s>A(t)-2?e:ua),i=>{if(s>A(t)-2)return n?.(i)&&ga(a,t[s]),i;const r=Ea(i,t,e,n,s+1);return L(i)&&ga(a,t[s]),r}),pa=a=>new Set(E(a)||u(a)?a:[a]),Aa=(a,t)=>a?.add(t),ma="ColumnName",Na="store",$a="json",fa=Na+"TableName",ba=Na+"Id"+ma,Ca=Na+ma,Ta="autoLoadIntervalSeconds",ha="rowId"+ma,Da="tableId",Oa="tableName",Ia="deleteEmptyColumns",Sa="deleteEmptyTable",La="condition",Ra={mode:$a,[Ta]:1},Pa={load:0,save:0,[Oa]:t+"_values"},Ma=(a,t,e,n,s)=>{const i=ua();return oa(a,(a,r)=>{const o=p(ca(sa(t,v(a)?{[e]:a}:a)),0,la(t));y(o[0])||n(r,o[0])||(s(r,o[0]),ga(i,r,o))}),i},_a=JSON.stringify,Fa=JSON.parse,Ua=/^\d+$/,ja=ua(),Ba=ua(),Ja=(a,t,n,s,i,r,o,c={},l=0,w=[])=>{let d,v,p,m=0,N=0,C=0;va(ja,w,()=>0),va(Ba,w,()=>[]);const T=ua(),[h,D,S,R,_]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!wa(a)||!wa(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!wa(a)||!wa(t),t.setContent]:$("Store type not supported by this Persister"))(o,a,l),[F,U,j]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?I(a):null)??e+t++,t=>{Ua.test(t)&&A(a)<1e3&&O(a,t)}]})(),s=ua();return[(n,i,r,o=[],c=()=>[])=>{a??=Q;const l=t(1);return ga(s,l,[n,i,r,o,c]),Aa(Ea(i,r??[e],pa),l),l},(t,n,...i)=>b(((a,t=[e])=>{const n=[],s=(a,e)=>e==A(t)?O(n,a):null===t[e]?P(a,a=>s(a,e+1)):b([t[e],null],t=>s(ya(a,t),e+1));return s(a,0),n})(t,n),t=>P(t,t=>ya(s,t)[0](a,...n??[],...i))),a=>g(ya(s,a),([,t,i])=>(Ea(t,i??[e],void 0,t=>(M(t,a),L(t)?1:0)),ga(s,a),n(a),i)),t=>g(ya(s,t),([t,,e=[],n,s])=>{const i=(...r)=>{const o=A(r);o==A(e)?t(a,...r,...s(r)):y(e[o])?b(n[o]?.(...r)??[],a=>i(...r,a)):i(...r,e[o])};i()})]})(),B=a=>{a!=m&&(m=a,U(T,void 0,m))},J=t=>{(h&&E(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},Y=async a=>(2!=m&&(B(1),N++,await K(async()=>{await f(async()=>{const e=await t();E(e)?J(e):a?_(a):$("Content is not an array: "+e)},()=>{a&&_(a)}),B(0)})),Q),k=async a=>(x(),await Y(a),await f(async()=>v=await s(async(a,t)=>{t||a?2!=m&&(B(1),N++,J(t??a),B(0)):await Y()}),r),Q),x=async()=>(v&&(await f(()=>i(v),r),v=void 0),Q),z=async a=>(1!=m&&(B(2),C++,await K(async()=>{await f(()=>n(D,a),r),B(0)})),Q),G=async()=>(H(),await z(),p=a.addDidFinishTransactionListener(()=>{const a=S();R(a)&&z(a)}),Q),H=async()=>(p&&(a.delListener(p),p=void 0),Q),q=async(a=!1)=>{const[t,e]=a?[H,x]:[x,H];return await t(),await e(),Q},K=async(...a)=>(O(ya(Ba,w),...a),await(async()=>{if(!ya(ja,w)){for(ga(ja,w,1);!u(d=I(ya(Ba,w)));)await f(d,r);ga(ja,w,0)}})(),Q),Q={load:Y,startAutoLoad:k,stopAutoLoad:x,isAutoLoading:()=>!u(v),save:z,startAutoSave:G,stopAutoSave:H,isAutoSaving:()=>!u(p),startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[G,k]:[k,G];return await e(a),await n(a),Q},stopAutoPersisting:q,getStatus:()=>m,addStatusListener:a=>F(a,T),delListener:t=>(j(t),a),schedule:K,getStore:()=>a,destroy:()=>(ya(Ba,w).splice(0,void 0),q()),getStats:()=>({loads:N,saves:C}),...c};return ea(Q)},Ya=(a,t,e,s,r,o=ka,c,l)=>{const w=ua();return[async()=>{w.clear(),T(await e(a,t),({tn:a,cn:t})=>Aa(va(w,a,pa),t))},async(t,e,n)=>((a,t)=>S(ya(w,a),t))(t,e)?na(D(T(await a(x+Q(t)+W(t,n)),a=>[a[e],l?oa(ia(a,e),l):ia(a,e)]),([a,t])=>!u(a)&&!wa(t))):{},async(t,e,s,l,y,d=!1,g=i)=>{const v=pa();oa(s??{},a=>T(ta(a??{}),a=>Aa(v,a)));const E=R(v);if(!d&&y&&g==i&&h(E)&&S(w,t))return await a("DROP "+B+Q(t)),void ga(w,t);const p=ya(w,t),A=pa(R(p));if(h(E)||(S(w,t)?await N(T([e,...E],async(n,s)=>{M(A,n)||(await a(J+Q(t)+"ADD"+Q(n)+r),0==s&&await a("CREATE UNIQUE INDEX pk ON "+Q(t)+`(${Q(e)})`),Aa(p,n))})):(await a(K+Q(t)+`(${Q(e)}${r} PRIMARY KEY${C(T(E,a=>n+Q(a)+r))});`),ga(w,t,pa([e,...E])))),await N([...!d&&l?T(R(A),async n=>{n!=e&&(await a(J+Q(t)+"DROP"+Q(n)),M(p,n))}):[]]),d)u(s)?await a(k+Q(t)+W(t,g)):await N(ra(s,async(n,s)=>{u(n)?await a(k+Q(t)+W(t,g)+`AND(${Q(e)}=$1)`,[s]):h(E)||await o(a,t,e,ta(n),{[s]:c?T(ca(n),c):ca(n)},p)}));else if(h(E))S(w,t)&&await a(k+Q(t)+W(t,g));else{const n=D(R(ya(w,t)),a=>a!=e),i={},r=[];oa(s??{},(a,t)=>{i[t]=T(n,t=>c?c(a?.[t]):a?.[t]),O(r,t)}),await o(a,t,e,n,i),await a(k+Q(t)+W(t,g)+`AND${Q(e)}NOT IN(${V(r)})`,r)}},async t=>{let e;return await a("BEGIN"),await f(async()=>e=await t(),s),await a("END"),e}]},ka=async(a,t,e,s,i)=>{const r=[1];await a("INSERT INTO"+Q(t)+"("+((...a)=>C(T(a,Q),n))(e,...s)+")VALUES"+C(ra(i,a=>"($"+r[0]+++","+V(a,r)+")"),n)+"ON CONFLICT("+Q(e)+")DO UPDATE SET"+C(T(s,a=>Q(a)+"=excluded."+Q(a)),n),ra(i,(a,t)=>[t,...T(a,a=>a??null)]).flat())},xa=(a,t,e,n,s,i,r,[o,c,l],w,u,y,d,g,v)=>{const[E,p,A,m]=Ya(t,w,u,s,g,v),N=Ja(a,()=>m(async()=>{return await E(),a=(await p(o,c))[_]?.[l]??"null",Fa(a,(a,t)=>""===t?void 0:t);var a}),a=>m(async()=>{var t;await E(),await A(o,c,{[_]:{[l]:(t=a()??null,_a(t,(a,t)=>void 0===t?"":t))}},!0,!0)}),e,n,s,r,{[d]:()=>y,destroy:async()=>(await N.stopAutoPersisting(),i(),N)},0,y);return N},za=(a,t,e,n,s,i,r,[o,c,[l,w,y]],d,g,v,E,p,A,m,$)=>{const[f,b,C,T]=Ya(t,d,g,s,p,A,m,$),h=(a,t)=>N(da(c,async([e,n,s,i,r],o)=>{t&&!(o in a)||await C(e,n,a[o],s,i,t,r)})),O=async(a,t)=>w?await C(y,F,{[_]:a},!0,!0,t):null,I=Ja(a,()=>T(async()=>{await f();const a=await(async()=>na(D(await N(da(o,async([a,t,e],n)=>[a,await b(n,t,e)])),a=>!wa(a[1]))))(),t=await(async()=>l?(await b(y,F))[_]:{})();return wa(a)&&u(t)?void 0:[a,t]}),(a,t)=>T(async()=>{if(await f(),u(t)){const[t,e]=a();await h(t),await O(e)}else await h(t[0],!0),await O(t[1],!0)}),e,n,s,r,{[E]:()=>v,destroy:async()=>(await I.stopAutoPersisting(),i(),I)},0,v);return I},Ga=(a,n,s,r,o,c,u,y,d,g,E="getDb",A)=>{let m,N,$;const b=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,c),[C,T,h,D]=(a=>{const e=(a=>sa(Ra,v(a)?{[fa]:a}:a??{}))(a),n=e[Ta];if(e.mode==$a){const a=e[fa]??t;return[1,n,[a,e[ba]??F,e[Ca]??Na],pa(a)]}const{tables:{load:s={},save:r={}}={},values:o={}}=e,c=p(ca(sa(Pa,o)),0,la(Pa)),l=c[2],w=pa(l),u=pa(l),y=Ma(s,{[Da]:null,[ha]:F,[La]:i},Da,a=>S(u,a),a=>Aa(w,a)),d=Ma(r,{[Oa]:null,[ha]:F,[Ia]:0,[Sa]:0,[La]:null},Oa,(a,t)=>S(u,t),(a,t)=>Aa(w,t));var g;return g=(a,t)=>t[4]??=ya(y,t[0])?.[2]??i,P(d,(a,t)=>g(0,a)),[0,n,[y,d,c],w]})(n);return(C?xa:za)(a,b,a=>{let t;const e=()=>t=setInterval(()=>f(async()=>{const[{d:t,s:e,c:n}]=await b(U+` ${G} d,${H} s,TOTAL_CHANGES() c FROM ${z}${G} JOIN ${z}${H}`);t==m&&e==N&&n==$||(w(m)||a(),m=t,N=e,$=n)}),1e3*T),n=()=>{m=N=$=null,l(t)},s=r(t=>{D.has(t)&&(n(),a(),e())});return e(),()=>{n(),o(s)}},a=>a(),u,y,d,h,R(D),async(a,t)=>await a(U+` t.name tn,c.name cn FROM ${q}list()t,${q}info(t.name)c ${j} t.schema='main'AND t.type IN('table','view')AND t.name IN(${V(t)})ORDER BY t.name,c.name`,t),g,E,e,A,a=>!0===a?1:!1===a?0:a,void 0)},Ha=(a,t,e,n,s)=>Ga(a,e,async(a,e=[])=>await t.db.raw({sql:a,args:e}),a=>t.notifier.subscribeToDataChanges(e=>b(t.notifier.alias(e),({tablename:t})=>a(t))),a=>a(),n,s,m,1,t,"getElectricClient");export{Ha as createElectricSqlPersister};
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,u=a=>void 0===a,y=a=>null===a,d=c(w),g=c(u),v=t=>a(t)==s,E=a=>Array.isArray(a),p=(a,t,e)=>a.slice(t,e),A=a=>a.length,m=()=>{},N=async a=>o.all(a),$=a=>{throw Error(a)},f=async(a,t,e)=>{try{return await a()}catch(a){t?.(a)}},b=(a,t)=>a.forEach(t),C=(a,t="")=>a.join(t),T=(a,t)=>a.map(t),h=a=>0==A(a),D=(a,t)=>a.filter(t),O=(a,...t)=>a.push(...t),I=a=>a.shift(),S=(a,t)=>a?.has(t)??!1,L=a=>u(a)||0==(a=>a?.size??0)(a),R=a=>[...a?.values()??[]],P=(a,t)=>a?.forEach(t),M=(a,t)=>a?.delete(t),_="_",F="_id",U="SELECT",j="WHERE",B="TABLE",J="ALTER "+B,Y="FROM",k="DELETE "+Y,x=U+"*"+Y,z="pragma_",G="data_version",H="schema_version",q="pragma_table_",K="CREATE "+B,Q=a=>C(T(((a,t="",e)=>a.split(t,e))(a,"."),a=>`"${r(a,/"/g,'""')}"`),"."),V=(a,t=[1])=>C(T(a,()=>"$"+t[0]++),n),W=(a,t=i)=>j+`(${r(t,"$tableName",Q(a))})`,X=Object,Z=a=>X.getPrototypeOf(a),aa=X.entries,ta=X.keys,ea=X.freeze,na=(a=[])=>X.fromEntries(a),sa=(...a)=>X.assign({},...a),ia=(a,t)=>(delete a[t],a),ra=(a,t)=>T(aa(a),([a,e])=>t(e,a)),oa=(a,t)=>na(ra(a,(a,e)=>[e,t(a,e)])),ca=a=>X.values(a),la=a=>A(ta(a)),wa=a=>(a=>!w(a)&&d(Z(a),a=>a==X.prototype||w(Z(a)),()=>!0))(a)&&0==la(a),ua=a=>new Map(a),ya=(a,t)=>a?.get(t),da=(a,t)=>T([...a?.entries()??[]],([a,e])=>t(e,a)),ga=(a,t,e)=>void 0===e?(M(a,t),a):a?.set(t,e),va=(a,t,e,n)=>(S(a,t)?n?.(ya(a,t)):ga(a,t,e()),ya(a,t)),Ea=(a,t,e,n,s=0)=>g((e?va:ya)(a,t[s],s>A(t)-2?e:ua),i=>{if(s>A(t)-2)return n?.(i)&&ga(a,t[s]),i;const r=Ea(i,t,e,n,s+1);return L(i)&&ga(a,t[s]),r}),pa=a=>new Set(E(a)||u(a)?a:[a]),Aa=(a,t)=>a?.add(t),ma="ColumnName",Na="store",$a="json",fa=Na+"TableName",ba=Na+"Id"+ma,Ca=Na+ma,Ta="autoLoadIntervalSeconds",ha="rowId"+ma,Da="tableId",Oa="tableName",Ia="deleteEmptyColumns",Sa="deleteEmptyTable",La="condition",Ra={mode:$a,[Ta]:1},Pa={load:0,save:0,[Oa]:t+"_values"},Ma=(a,t,e,n,s)=>{const i=ua();return oa(a,(a,r)=>{const o=p(ca(sa(t,v(a)?{[e]:a}:a)),0,la(t));y(o[0])||n(r,o[0])||(s(r,o[0]),ga(i,r,o))}),i},_a=JSON.stringify,Fa=JSON.parse,Ua=/^\d+$/,ja=ua(),Ba=ua(),Ja=(a,t,n,s,i,r,o,c={},l=0,w=[])=>{let d,v,p,m=0,N=0,C=0;va(ja,w,()=>0),va(Ba,w,()=>[]);const T=ua(),[h,D,S,R,_]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!wa(a)||!wa(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!wa(a)||!wa(t),t.setContent]:$("Store type not supported by this Persister"))(o,a,l),[F,U,j]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?I(a):null)??e+t++,t=>{Ua.test(t)&&A(a)<1e3&&O(a,t)}]})(),s=ua();return[(n,i,r,o=[],c=()=>[])=>{a??=Q;const l=t(1);return ga(s,l,[n,i,r,o,c]),Aa(Ea(i,r??[e],pa),l),l},(t,n,...i)=>b(((a,t=[e])=>{const n=[],s=(a,e)=>e==A(t)?O(n,a):null===t[e]?P(a,a=>s(a,e+1)):b([t[e],null],t=>s(ya(a,t),e+1));return s(a,0),n})(t,n),t=>P(t,t=>ya(s,t)[0](a,...n??[],...i))),a=>g(ya(s,a),([,t,i])=>(Ea(t,i??[e],void 0,t=>(M(t,a),L(t)?1:0)),ga(s,a),n(a),i)),t=>g(ya(s,t),([t,,e=[],n,s])=>{const i=(...r)=>{const o=A(r);o==A(e)?t(a,...r,...s(r)):y(e[o])?b(n[o]?.(...r)??[],a=>i(...r,a)):i(...r,e[o])};i()})]})(),B=a=>{a!=m&&(m=a,U(T,void 0,m))},J=t=>{(h&&E(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},Y=async a=>(2!=m&&(B(1),N++,await K(async()=>{await f(async()=>{const e=await t();E(e)?J(e):a?_(a):$("Content is not an array: "+e)},()=>{a&&_(a)}),B(0)})),Q),k=async a=>(x(),await Y(a),await f(async()=>v=await s(async(a,t)=>{t||a?2!=m&&(B(1),N++,J(t??a),B(0)):await Y()}),r),Q),x=async()=>(v&&(await f(()=>i(v),r),v=void 0),Q),z=async a=>(1!=m&&(B(2),C++,await K(async()=>{await f(()=>n(D,a),r),B(0)})),Q),G=async()=>(H(),await z(),p=a.addDidFinishTransactionListener(()=>{const a=S();R(a)&&z(a)}),Q),H=async()=>(p&&(a.delListener(p),p=void 0),Q),q=async(a=!1)=>{const[t,e]=a?[H,x]:[x,H];return await t(),await e(),Q},K=async(...a)=>(O(ya(Ba,w),...a),await(async()=>{if(!ya(ja,w)){for(ga(ja,w,1);!u(d=I(ya(Ba,w)));)await f(d,r);ga(ja,w,0)}})(),Q),Q={load:Y,startAutoLoad:k,stopAutoLoad:x,isAutoLoading:()=>!u(v),save:z,startAutoSave:G,stopAutoSave:H,isAutoSaving:()=>!u(p),startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[G,k]:[k,G];return await e(a),await n(a),Q},stopAutoPersisting:q,getStatus:()=>m,addStatusListener:a=>F(a,T),delListener:t=>(j(t),a),schedule:K,getStore:()=>a,destroy:()=>(ya(Ba,w).splice(0,void 0),q()),getStats:()=>({loads:N,saves:C}),...c};return ea(Q)},Ya=(a,t,e,s,r,o=ka,c,l)=>{const w=ua();return[async()=>{w.clear(),T(await e(a,t),({tn:a,cn:t})=>Aa(va(w,a,pa),t))},async(t,e,n)=>((a,t)=>S(ya(w,a),t))(t,e)?na(D(T(await a(x+Q(t)+W(t,n)),a=>[a[e],l?oa(ia(a,e),l):ia(a,e)]),([a,t])=>!u(a)&&!wa(t))):{},async(t,e,s,l,y,d=!1,g=i)=>{const v=pa();oa(s??{},a=>T(ta(a??{}),a=>Aa(v,a)));const E=R(v);if(!d&&y&&g==i&&h(E)&&S(w,t))return await a("DROP "+B+Q(t)),void ga(w,t);const p=ya(w,t),A=pa(R(p));if(h(E)||(S(w,t)?await N(T([e,...E],async(n,s)=>{M(A,n)||(await a(J+Q(t)+"ADD"+Q(n)+r),0==s&&await a("CREATE UNIQUE INDEX pk ON "+Q(t)+`(${Q(e)})`),Aa(p,n))})):(await a(K+Q(t)+`(${Q(e)}${r} PRIMARY KEY${C(T(E,a=>n+Q(a)+r))});`),ga(w,t,pa([e,...E])))),await N([...!d&&l?T(R(A),async n=>{n!=e&&(await a(J+Q(t)+"DROP"+Q(n)),M(p,n))}):[]]),d)u(s)?await a(k+Q(t)+W(t,g)):await N(ra(s,async(n,s)=>{u(n)?await a(k+Q(t)+W(t,g)+`AND(${Q(e)}=$1)`,[s]):h(E)||await o(a,t,e,ta(n),{[s]:c?T(ca(n),c):ca(n)},p)}));else if(h(E))S(w,t)&&await a(k+Q(t)+W(t,g));else{const n=D(R(ya(w,t)),a=>a!=e),i={},r=[];oa(s??{},(a,t)=>{i[t]=T(n,t=>c?c(a?.[t]):a?.[t]),O(r,t)}),await o(a,t,e,n,i),await a(k+Q(t)+W(t,g)+`AND${Q(e)}NOT IN(${V(r)})`,r)}},async t=>{let e;return await a("BEGIN"),await f(async()=>e=await t(),s),await a("END"),e}]},ka=async(a,t,e,s,i)=>{const r=[1];await a("INSERT INTO"+Q(t)+"("+((...a)=>C(T(a,Q),n))(e,...s)+")VALUES"+C(ra(i,a=>"($"+r[0]+++","+V(a,r)+")"),n)+"ON CONFLICT("+Q(e)+")DO UPDATE SET"+C(T(s,a=>Q(a)+"=excluded."+Q(a)),n),ra(i,(a,t)=>[t,...T(a,a=>a??null)]).flat())},xa=(a,t,e,n,s,i,r,[o,c,l],w,u,y,d,g,v)=>{const[E,p,A,m]=Ya(t,w,u,s,g,v),N=Ja(a,()=>m(async()=>{return await E(),a=(await p(o,c))[_]?.[l]??"null",Fa(a,(a,t)=>""===t?void 0:t);var a}),a=>m(async()=>{var t;await E(),await A(o,c,{[_]:{[l]:(t=a()??null,_a(t,(a,t)=>void 0===t?"":t))}},!0,!0)}),e,n,s,r,{[d]:()=>y,destroy:async()=>(await N.stopAutoPersisting(),i(),N)},0,y);return N},za=(a,t,e,n,s,i,r,[o,c,[l,w,y]],d,g,v,E,p,A,m,$)=>{const[f,b,C,T]=Ya(t,d,g,s,p,A,m,$),h=(a,t)=>N(da(c,async([e,n,s,i,r],o)=>{t&&!(o in a)||await C(e,n,a[o],s,i,t,r)})),O=async(a,t)=>w?await C(y,F,{[_]:a},!0,!0,t):null,I=Ja(a,()=>T(async()=>{await f();const a=await(async()=>na(D(await N(da(o,async([a,t,e],n)=>[a,await b(n,t,e)])),a=>!wa(a[1]))))(),t=await(async()=>l?(await b(y,F))[_]:{})();return wa(a)&&u(t)?void 0:[a,t]}),(a,t)=>T(async()=>{if(await f(),u(t)){const[t,e]=a();await h(t),await O(e)}else await h(t[0],!0),await O(t[1],!0)}),e,n,s,r,{[E]:()=>v,destroy:async()=>(await I.stopAutoPersisting(),i(),I)},0,v);return I},Ga=(a,n,s,r,o,c,u,y,d,g,E="getDb",A)=>{let m,N,$;const b=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,c),[C,T,h,D]=(a=>{const e=(a=>sa(Ra,v(a)?{[fa]:a}:a??{}))(a),n=e[Ta];if(e.mode==$a){const a=e[fa]??t;return[1,n,[a,e[ba]??F,e[Ca]??Na],pa(a)]}const{tables:{load:s={},save:r={}}={},values:o={}}=e,c=p(ca(sa(Pa,o)),0,la(Pa)),l=c[2],w=pa(l),u=pa(l),y=Ma(s,{[Da]:null,[ha]:F,[La]:i},Da,a=>S(u,a),a=>Aa(w,a)),d=Ma(r,{[Oa]:null,[ha]:F,[Ia]:0,[Sa]:0,[La]:null},Oa,(a,t)=>S(u,t),(a,t)=>Aa(w,t));var g;return g=(a,t)=>t[4]??=ya(y,t[0])?.[2]??i,P(d,(a,t)=>g(0,a)),[0,n,[y,d,c],w]})(n);return(C?xa:za)(a,b,a=>{let t;const e=()=>t=setInterval(()=>f(async()=>{const[{d:t,s:e,c:n}]=await b(U+` ${G} d,${H} s,TOTAL_CHANGES() c FROM ${z}${G} JOIN ${z}${H}`);t==m&&e==N&&n==$||(w(m)||a(),m=t,N=e,$=n)}),1e3*T),n=()=>{m=N=$=null,l(t)},s=r(t=>{D.has(t)&&(n(),a(),e())});return e(),()=>{n(),o(s)}},a=>a(),u,y,d,h,R(D),async(a,t)=>await a(U+` t.name tn,c.name cn FROM ${q}list()t,${q}info(t.name)c ${j} t.schema='main'AND t.type IN('table','view')AND t.name IN(${V(t)})ORDER BY t.name,c.name`,t),g,E,e,A,a=>!0===a?1:!1===a?0:a,void 0)},Ha=(a,t,e,n,s)=>Ga(a,e,async(a,e=[])=>await t.db.raw({sql:a,args:e}),a=>t.notifier.subscribeToDataChanges(e=>b(t.notifier.alias(e),({tablename:t})=>a(t))),a=>a(),n,s,m,1,t,"getElectricClient");export{Ha as createElectricSqlPersister};
@@ -1 +1 @@
1
- import{addDatabaseChangeListener as a}from"expo-sqlite";const t=a=>typeof a,e="tinybase",n="",s=",",i=t(n),o="true",r=(a,t,e)=>a.replace(t,e),c=Promise,l=(a=y)=>(t,e,n)=>a(t)?n?.():e(t),w=clearInterval,y=a=>null==a,u=a=>void 0===a,d=a=>null===a,v=l(y),g=l(u),p=a=>t(a)==i,E=a=>Array.isArray(a),m=(a,t,e)=>a.slice(t,e),A=a=>a.length,N=()=>{},$=async a=>c.all(a),f=a=>{throw Error(a)},C=async(a,t,e)=>{try{return await a()}catch(a){t?.(a)}},T=(a,t)=>a.forEach(t),b=(a,t="")=>a.join(t),h=(a,t)=>a.map(t),O=a=>0==A(a),D=(a,t)=>a.filter(t),I=(a,...t)=>a.push(...t),S=a=>a.shift(),L=(a,t)=>a?.has(t)??!1,R=a=>u(a)||0==(a=>a?.size??0)(a),P=a=>[...a?.values()??[]],M=(a,t)=>a?.forEach(t),_=(a,t)=>a?.delete(t),F="_",U="_id",j="SELECT",x="WHERE",B="TABLE",J="ALTER "+B,Y="FROM",k="DELETE "+Y,z=j+"*"+Y,G="pragma_",H="data_version",q="schema_version",K="pragma_table_",Q="CREATE "+B,V=a=>b(h(((a,t="",e)=>a.split(t,e))(a,"."),a=>`"${r(a,/"/g,'""')}"`),"."),W=(a,t=[1])=>b(h(a,()=>"$"+t[0]++),s),X=(a,t=o)=>x+`(${r(t,"$tableName",V(a))})`,Z=Object,aa=a=>Z.getPrototypeOf(a),ta=Z.entries,ea=Z.keys,na=Z.freeze,sa=(a=[])=>Z.fromEntries(a),ia=(...a)=>Z.assign({},...a),oa=(a,t)=>(delete a[t],a),ra=(a,t)=>h(ta(a),([a,e])=>t(e,a)),ca=(a,t)=>sa(ra(a,(a,e)=>[e,t(a,e)])),la=a=>Z.values(a),wa=a=>A(ea(a)),ya=a=>(a=>!y(a)&&v(aa(a),a=>a==Z.prototype||y(aa(a)),()=>!0))(a)&&0==wa(a),ua=a=>new Map(a),da=(a,t)=>a?.get(t),va=(a,t)=>h([...a?.entries()??[]],([a,e])=>t(e,a)),ga=(a,t,e)=>void 0===e?(_(a,t),a):a?.set(t,e),pa=(a,t,e,n)=>(L(a,t)?n?.(da(a,t)):ga(a,t,e()),da(a,t)),Ea=(a,t,e,n,s=0)=>g((e?pa:da)(a,t[s],s>A(t)-2?e:ua),i=>{if(s>A(t)-2)return n?.(i)&&ga(a,t[s]),i;const o=Ea(i,t,e,n,s+1);return R(i)&&ga(a,t[s]),o}),ma=a=>new Set(E(a)||u(a)?a:[a]),Aa=(a,t)=>a?.add(t),Na="ColumnName",$a="store",fa="json",Ca=$a+"TableName",Ta=$a+"Id"+Na,ba=$a+Na,ha="autoLoadIntervalSeconds",Oa="rowId"+Na,Da="tableId",Ia="tableName",Sa="deleteEmptyColumns",La="deleteEmptyTable",Ra="condition",Pa={mode:fa,[ha]:1},Ma={load:0,save:0,[Ia]:e+"_values"},_a=(a,t,e,n,s)=>{const i=ua();return ca(a,(a,o)=>{const r=m(la(ia(t,p(a)?{[e]:a}:a)),0,wa(t));d(r[0])||n(o,r[0])||(s(o,r[0]),ga(i,o,r))}),i},Fa=JSON.stringify,Ua=JSON.parse,ja=/^\d+$/,xa=ua(),Ba=ua(),Ja=(a,t,e,s,i,o,r,c={},l=0,w=[])=>{let y,v,p,m=0,N=0,$=0;pa(xa,w,()=>0),pa(Ba,w,()=>[]);const b=ua(),[h,O,D,L,P]=((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]:f("Store type not supported by this Persister"))(r,a,l),[F,U,j]=(()=>{let a;const[t,e]=(()=>{const a=[];let t=0;return[e=>(e?S(a):null)??n+t++,t=>{ja.test(t)&&A(a)<1e3&&I(a,t)}]})(),s=ua();return[(e,i,o,r=[],c=()=>[])=>{a??=Q;const l=t(1);return ga(s,l,[e,i,o,r,c]),Aa(Ea(i,o??[n],ma),l),l},(t,e,...i)=>T(((a,t=[n])=>{const e=[],s=(a,n)=>n==A(t)?I(e,a):null===t[n]?M(a,a=>s(a,n+1)):T([t[n],null],t=>s(da(a,t),n+1));return s(a,0),e})(t,e),t=>M(t,t=>da(s,t)[0](a,...e??[],...i))),a=>g(da(s,a),([,t,i])=>(Ea(t,i??[n],void 0,t=>(_(t,a),R(t)?1:0)),ga(s,a),e(a),i)),t=>g(da(s,t),([t,,e=[],n,s])=>{const i=(...o)=>{const r=A(o);r==A(e)?t(a,...o,...s(o)):d(e[r])?T(n[r]?.(...o)??[],a=>i(...o,a)):i(...o,e[r])};i()})]})(),x=a=>{a!=m&&(m=a,U(b,void 0,m))},B=t=>{(h&&E(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},J=async a=>(2!=m&&(x(1),N++,await K(async()=>{await C(async()=>{const e=await t();E(e)?B(e):a?P(a):f("Content is not an array: "+e)},()=>{a&&P(a)}),x(0)})),Q),Y=async a=>(k(),await J(a),await C(async()=>v=await s(async(a,t)=>{t||a?2!=m&&(x(1),N++,B(t??a),x(0)):await J()}),o),Q),k=async()=>(v&&(await C(()=>i(v),o),v=void 0),Q),z=async a=>(1!=m&&(x(2),$++,await K(async()=>{await C(()=>e(O,a),o),x(0)})),Q),G=async()=>(H(),await z(),p=a.addDidFinishTransactionListener(()=>{const a=D();L(a)&&z(a)}),Q),H=async()=>(p&&(a.delListener(p),p=void 0),Q),q=async(a=!1)=>{const[t,e]=a?[H,k]:[k,H];return await t(),await e(),Q},K=async(...a)=>(I(da(Ba,w),...a),await(async()=>{if(!da(xa,w)){for(ga(xa,w,1);!u(y=S(da(Ba,w)));)await C(y,o);ga(xa,w,0)}})(),Q),Q={load:J,startAutoLoad:Y,stopAutoLoad:k,isAutoLoading:()=>!u(v),save:z,startAutoSave:G,stopAutoSave:H,isAutoSaving:()=>!u(p),startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[G,Y]:[Y,G];return await e(a),await n(a),Q},stopAutoPersisting:q,getStatus:()=>m,addStatusListener:a=>F(a,b),delListener:t=>(j(t),a),schedule:K,getStore:()=>a,destroy:()=>(da(Ba,w).splice(0,void 0),q()),getStats:()=>({loads:N,saves:$}),...c};return na(Q)},Ya=(a,t,e,n,i,r=ka,c,l)=>{const w=ua();return[async()=>{w.clear(),h(await e(a,t),({tn:a,cn:t})=>Aa(pa(w,a,ma),t))},async(t,e,n)=>((a,t)=>L(da(w,a),t))(t,e)?sa(D(h(await a(z+V(t)+X(t,n)),a=>[a[e],l?ca(oa(a,e),l):oa(a,e)]),([a,t])=>!u(a)&&!ya(t))):{},async(t,e,n,l,y,d=!1,v=o)=>{const g=ma();ca(n??{},a=>h(ea(a??{}),a=>Aa(g,a)));const p=P(g);if(!d&&y&&v==o&&O(p)&&L(w,t))return await a("DROP "+B+V(t)),void ga(w,t);const E=da(w,t),m=ma(P(E));if(O(p)||(L(w,t)?await $(h([e,...p],async(n,s)=>{_(m,n)||(await a(J+V(t)+"ADD"+V(n)+i),0==s&&await a("CREATE UNIQUE INDEX pk ON "+V(t)+`(${V(e)})`),Aa(E,n))})):(await a(Q+V(t)+`(${V(e)}${i} PRIMARY KEY${b(h(p,a=>s+V(a)+i))});`),ga(w,t,ma([e,...p])))),await $([...!d&&l?h(P(m),async n=>{n!=e&&(await a(J+V(t)+"DROP"+V(n)),_(E,n))}):[]]),d)u(n)?await a(k+V(t)+X(t,v)):await $(ra(n,async(n,s)=>{u(n)?await a(k+V(t)+X(t,v)+`AND(${V(e)}=$1)`,[s]):O(p)||await r(a,t,e,ea(n),{[s]:c?h(la(n),c):la(n)},E)}));else if(O(p))L(w,t)&&await a(k+V(t)+X(t,v));else{const s=D(P(da(w,t)),a=>a!=e),i={},o=[];ca(n??{},(a,t)=>{i[t]=h(s,t=>c?c(a?.[t]):a?.[t]),I(o,t)}),await r(a,t,e,s,i),await a(k+V(t)+X(t,v)+`AND${V(e)}NOT IN(${W(o)})`,o)}},async t=>{let e;return await a("BEGIN"),await C(async()=>e=await t(),n),await a("END"),e}]},ka=async(a,t,e,n,i)=>{const o=[1];await a("INSERT INTO"+V(t)+"("+((...a)=>b(h(a,V),s))(e,...n)+")VALUES"+b(ra(i,a=>"($"+o[0]+++","+W(a,o)+")"),s)+"ON CONFLICT("+V(e)+")DO UPDATE SET"+b(h(n,a=>V(a)+"=excluded."+V(a)),s),ra(i,(a,t)=>[t,...h(a,a=>a??null)]).flat())},za=(a,t,e,n,s,i,o,[r,c,l],w,y,u,d,v,g)=>{const[p,E,m,A]=Ya(t,w,y,s,v,g),N=Ja(a,()=>A(async()=>{return await p(),a=(await E(r,c))[F]?.[l]??"null",Ua(a,(a,t)=>""===t?void 0:t);var a}),a=>A(async()=>{var t;await p(),await m(r,c,{[F]:{[l]:(t=a()??null,Fa(t,(a,t)=>void 0===t?"":t))}},!0,!0)}),e,n,s,o,{[d]:()=>u,destroy:async()=>(await N.stopAutoPersisting(),i(),N)},0,u);return N},Ga=(a,t,e,n,s,i,o,[r,c,[l,w,y]],d,v,g,p,E,m,A,N)=>{const[f,C,T,b]=Ya(t,d,v,s,E,m,A,N),h=(a,t)=>$(va(c,async([e,n,s,i,o],r)=>{t&&!(r in a)||await T(e,n,a[r],s,i,t,o)})),O=async(a,t)=>w?await T(y,U,{[F]:a},!0,!0,t):null,I=Ja(a,()=>b(async()=>{await f();const a=await(async()=>sa(D(await $(va(r,async([a,t,e],n)=>[a,await C(n,t,e)])),a=>!ya(a[1]))))(),t=await(async()=>l?(await C(y,U))[F]:{})();return ya(a)&&u(t)?void 0:[a,t]}),(a,t)=>b(async()=>{if(await f(),u(t)){const[t,e]=a();await h(t),await O(e)}else await h(t[0],!0),await O(t[1],!0)}),e,n,s,o,{[p]:()=>g,destroy:async()=>(await I.stopAutoPersisting(),i(),I)},0,g);return I},Ha=(a,t,s,i,r,c,l,u,d,v,g="getDb",E)=>{let A,N,$;const f=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,c),[T,b,h,O]=(a=>{const t=(a=>ia(Pa,p(a)?{[Ca]:a}:a??{}))(a),n=t[ha];if(t.mode==fa){const a=t[Ca]??e;return[1,n,[a,t[Ta]??U,t[ba]??$a],ma(a)]}const{tables:{load:s={},save:i={}}={},values:r={}}=t,c=m(la(ia(Ma,r)),0,wa(Ma)),l=c[2],w=ma(l),y=ma(l),u=_a(s,{[Da]:null,[Oa]:U,[Ra]:o},Da,a=>L(y,a),a=>Aa(w,a)),d=_a(i,{[Ia]:null,[Oa]:U,[Sa]:0,[La]:0,[Ra]:null},Ia,(a,t)=>L(y,t),(a,t)=>Aa(w,t));var v;return v=(a,t)=>t[4]??=da(u,t[0])?.[2]??o,M(d,(a,t)=>v(0,a)),[0,n,[u,d,c],w]})(t);return(T?za:Ga)(a,f,a=>{let t;const e=()=>t=setInterval(()=>C(async()=>{const[{d:t,s:e,c:n}]=await f(j+` ${H} d,${q} s,TOTAL_CHANGES() c FROM ${G}${H} JOIN ${G}${q}`);t==A&&e==N&&n==$||(y(A)||a(),A=t,N=e,$=n)}),1e3*b),n=()=>{A=N=$=null,w(t)},s=i(t=>{O.has(t)&&(n(),a(),e())});return e(),()=>{n(),r(s)}},a=>a(),l,u,d,h,P(O),async(a,t)=>await a(j+` t.name tn,c.name cn FROM ${K}list()t,${K}info(t.name)c ${x} t.schema='main'AND t.type IN('table','view')AND t.name IN(${W(t)})ORDER BY t.name,c.name`,t),v,g,n,E,a=>!0===a?1:!1===a?0:a,void 0)},qa=(t,e,n,s,i)=>Ha(t,n,async(a,t=[])=>await e.getAllAsync(a,t),t=>a(({tableName:a})=>t(a)),a=>a.remove(),s,i,N,3,e);export{qa as createExpoSqlitePersister};
1
+ import{addDatabaseChangeListener as a}from"expo-sqlite";const t=a=>typeof a,e="tinybase",n="",s=",",i=t(n),o="true",r=(a,t,e)=>a.replace(t,e),c=Promise,l=a=>(t,e,n)=>a(t)?n?.():e(t),w=clearInterval,y=a=>null==a,u=a=>void 0===a,d=a=>null===a,v=l(y),g=l(u),p=a=>t(a)==i,E=a=>Array.isArray(a),m=(a,t,e)=>a.slice(t,e),A=a=>a.length,N=()=>{},$=async a=>c.all(a),f=a=>{throw Error(a)},C=async(a,t,e)=>{try{return await a()}catch(a){t?.(a)}},T=(a,t)=>a.forEach(t),b=(a,t="")=>a.join(t),h=(a,t)=>a.map(t),O=a=>0==A(a),D=(a,t)=>a.filter(t),I=(a,...t)=>a.push(...t),S=a=>a.shift(),L=(a,t)=>a?.has(t)??!1,R=a=>u(a)||0==(a=>a?.size??0)(a),P=a=>[...a?.values()??[]],M=(a,t)=>a?.forEach(t),_=(a,t)=>a?.delete(t),F="_",U="_id",j="SELECT",x="WHERE",B="TABLE",J="ALTER "+B,Y="FROM",k="DELETE "+Y,z=j+"*"+Y,G="pragma_",H="data_version",q="schema_version",K="pragma_table_",Q="CREATE "+B,V=a=>b(h(((a,t="",e)=>a.split(t,e))(a,"."),a=>`"${r(a,/"/g,'""')}"`),"."),W=(a,t=[1])=>b(h(a,()=>"$"+t[0]++),s),X=(a,t=o)=>x+`(${r(t,"$tableName",V(a))})`,Z=Object,aa=a=>Z.getPrototypeOf(a),ta=Z.entries,ea=Z.keys,na=Z.freeze,sa=(a=[])=>Z.fromEntries(a),ia=(...a)=>Z.assign({},...a),oa=(a,t)=>(delete a[t],a),ra=(a,t)=>h(ta(a),([a,e])=>t(e,a)),ca=(a,t)=>sa(ra(a,(a,e)=>[e,t(a,e)])),la=a=>Z.values(a),wa=a=>A(ea(a)),ya=a=>(a=>!y(a)&&v(aa(a),a=>a==Z.prototype||y(aa(a)),()=>!0))(a)&&0==wa(a),ua=a=>new Map(a),da=(a,t)=>a?.get(t),va=(a,t)=>h([...a?.entries()??[]],([a,e])=>t(e,a)),ga=(a,t,e)=>void 0===e?(_(a,t),a):a?.set(t,e),pa=(a,t,e,n)=>(L(a,t)?n?.(da(a,t)):ga(a,t,e()),da(a,t)),Ea=(a,t,e,n,s=0)=>g((e?pa:da)(a,t[s],s>A(t)-2?e:ua),i=>{if(s>A(t)-2)return n?.(i)&&ga(a,t[s]),i;const o=Ea(i,t,e,n,s+1);return R(i)&&ga(a,t[s]),o}),ma=a=>new Set(E(a)||u(a)?a:[a]),Aa=(a,t)=>a?.add(t),Na="ColumnName",$a="store",fa="json",Ca=$a+"TableName",Ta=$a+"Id"+Na,ba=$a+Na,ha="autoLoadIntervalSeconds",Oa="rowId"+Na,Da="tableId",Ia="tableName",Sa="deleteEmptyColumns",La="deleteEmptyTable",Ra="condition",Pa={mode:fa,[ha]:1},Ma={load:0,save:0,[Ia]:e+"_values"},_a=(a,t,e,n,s)=>{const i=ua();return ca(a,(a,o)=>{const r=m(la(ia(t,p(a)?{[e]:a}:a)),0,wa(t));d(r[0])||n(o,r[0])||(s(o,r[0]),ga(i,o,r))}),i},Fa=JSON.stringify,Ua=JSON.parse,ja=/^\d+$/,xa=ua(),Ba=ua(),Ja=(a,t,e,s,i,o,r,c={},l=0,w=[])=>{let y,v,p,m=0,N=0,$=0;pa(xa,w,()=>0),pa(Ba,w,()=>[]);const b=ua(),[h,O,D,L,P]=((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]:f("Store type not supported by this Persister"))(r,a,l),[F,U,j]=(()=>{let a;const[t,e]=(()=>{const a=[];let t=0;return[e=>(e?S(a):null)??n+t++,t=>{ja.test(t)&&A(a)<1e3&&I(a,t)}]})(),s=ua();return[(e,i,o,r=[],c=()=>[])=>{a??=Q;const l=t(1);return ga(s,l,[e,i,o,r,c]),Aa(Ea(i,o??[n],ma),l),l},(t,e,...i)=>T(((a,t=[n])=>{const e=[],s=(a,n)=>n==A(t)?I(e,a):null===t[n]?M(a,a=>s(a,n+1)):T([t[n],null],t=>s(da(a,t),n+1));return s(a,0),e})(t,e),t=>M(t,t=>da(s,t)[0](a,...e??[],...i))),a=>g(da(s,a),([,t,i])=>(Ea(t,i??[n],void 0,t=>(_(t,a),R(t)?1:0)),ga(s,a),e(a),i)),t=>g(da(s,t),([t,,e=[],n,s])=>{const i=(...o)=>{const r=A(o);r==A(e)?t(a,...o,...s(o)):d(e[r])?T(n[r]?.(...o)??[],a=>i(...o,a)):i(...o,e[r])};i()})]})(),x=a=>{a!=m&&(m=a,U(b,void 0,m))},B=t=>{(h&&E(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},J=async a=>(2!=m&&(x(1),N++,await K(async()=>{await C(async()=>{const e=await t();E(e)?B(e):a?P(a):f("Content is not an array: "+e)},()=>{a&&P(a)}),x(0)})),Q),Y=async a=>(k(),await J(a),await C(async()=>v=await s(async(a,t)=>{t||a?2!=m&&(x(1),N++,B(t??a),x(0)):await J()}),o),Q),k=async()=>(v&&(await C(()=>i(v),o),v=void 0),Q),z=async a=>(1!=m&&(x(2),$++,await K(async()=>{await C(()=>e(O,a),o),x(0)})),Q),G=async()=>(H(),await z(),p=a.addDidFinishTransactionListener(()=>{const a=D();L(a)&&z(a)}),Q),H=async()=>(p&&(a.delListener(p),p=void 0),Q),q=async(a=!1)=>{const[t,e]=a?[H,k]:[k,H];return await t(),await e(),Q},K=async(...a)=>(I(da(Ba,w),...a),await(async()=>{if(!da(xa,w)){for(ga(xa,w,1);!u(y=S(da(Ba,w)));)await C(y,o);ga(xa,w,0)}})(),Q),Q={load:J,startAutoLoad:Y,stopAutoLoad:k,isAutoLoading:()=>!u(v),save:z,startAutoSave:G,stopAutoSave:H,isAutoSaving:()=>!u(p),startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[G,Y]:[Y,G];return await e(a),await n(a),Q},stopAutoPersisting:q,getStatus:()=>m,addStatusListener:a=>F(a,b),delListener:t=>(j(t),a),schedule:K,getStore:()=>a,destroy:()=>(da(Ba,w).splice(0,void 0),q()),getStats:()=>({loads:N,saves:$}),...c};return na(Q)},Ya=(a,t,e,n,i,r=ka,c,l)=>{const w=ua();return[async()=>{w.clear(),h(await e(a,t),({tn:a,cn:t})=>Aa(pa(w,a,ma),t))},async(t,e,n)=>((a,t)=>L(da(w,a),t))(t,e)?sa(D(h(await a(z+V(t)+X(t,n)),a=>[a[e],l?ca(oa(a,e),l):oa(a,e)]),([a,t])=>!u(a)&&!ya(t))):{},async(t,e,n,l,y,d=!1,v=o)=>{const g=ma();ca(n??{},a=>h(ea(a??{}),a=>Aa(g,a)));const p=P(g);if(!d&&y&&v==o&&O(p)&&L(w,t))return await a("DROP "+B+V(t)),void ga(w,t);const E=da(w,t),m=ma(P(E));if(O(p)||(L(w,t)?await $(h([e,...p],async(n,s)=>{_(m,n)||(await a(J+V(t)+"ADD"+V(n)+i),0==s&&await a("CREATE UNIQUE INDEX pk ON "+V(t)+`(${V(e)})`),Aa(E,n))})):(await a(Q+V(t)+`(${V(e)}${i} PRIMARY KEY${b(h(p,a=>s+V(a)+i))});`),ga(w,t,ma([e,...p])))),await $([...!d&&l?h(P(m),async n=>{n!=e&&(await a(J+V(t)+"DROP"+V(n)),_(E,n))}):[]]),d)u(n)?await a(k+V(t)+X(t,v)):await $(ra(n,async(n,s)=>{u(n)?await a(k+V(t)+X(t,v)+`AND(${V(e)}=$1)`,[s]):O(p)||await r(a,t,e,ea(n),{[s]:c?h(la(n),c):la(n)},E)}));else if(O(p))L(w,t)&&await a(k+V(t)+X(t,v));else{const s=D(P(da(w,t)),a=>a!=e),i={},o=[];ca(n??{},(a,t)=>{i[t]=h(s,t=>c?c(a?.[t]):a?.[t]),I(o,t)}),await r(a,t,e,s,i),await a(k+V(t)+X(t,v)+`AND${V(e)}NOT IN(${W(o)})`,o)}},async t=>{let e;return await a("BEGIN"),await C(async()=>e=await t(),n),await a("END"),e}]},ka=async(a,t,e,n,i)=>{const o=[1];await a("INSERT INTO"+V(t)+"("+((...a)=>b(h(a,V),s))(e,...n)+")VALUES"+b(ra(i,a=>"($"+o[0]+++","+W(a,o)+")"),s)+"ON CONFLICT("+V(e)+")DO UPDATE SET"+b(h(n,a=>V(a)+"=excluded."+V(a)),s),ra(i,(a,t)=>[t,...h(a,a=>a??null)]).flat())},za=(a,t,e,n,s,i,o,[r,c,l],w,y,u,d,v,g)=>{const[p,E,m,A]=Ya(t,w,y,s,v,g),N=Ja(a,()=>A(async()=>{return await p(),a=(await E(r,c))[F]?.[l]??"null",Ua(a,(a,t)=>""===t?void 0:t);var a}),a=>A(async()=>{var t;await p(),await m(r,c,{[F]:{[l]:(t=a()??null,Fa(t,(a,t)=>void 0===t?"":t))}},!0,!0)}),e,n,s,o,{[d]:()=>u,destroy:async()=>(await N.stopAutoPersisting(),i(),N)},0,u);return N},Ga=(a,t,e,n,s,i,o,[r,c,[l,w,y]],d,v,g,p,E,m,A,N)=>{const[f,C,T,b]=Ya(t,d,v,s,E,m,A,N),h=(a,t)=>$(va(c,async([e,n,s,i,o],r)=>{t&&!(r in a)||await T(e,n,a[r],s,i,t,o)})),O=async(a,t)=>w?await T(y,U,{[F]:a},!0,!0,t):null,I=Ja(a,()=>b(async()=>{await f();const a=await(async()=>sa(D(await $(va(r,async([a,t,e],n)=>[a,await C(n,t,e)])),a=>!ya(a[1]))))(),t=await(async()=>l?(await C(y,U))[F]:{})();return ya(a)&&u(t)?void 0:[a,t]}),(a,t)=>b(async()=>{if(await f(),u(t)){const[t,e]=a();await h(t),await O(e)}else await h(t[0],!0),await O(t[1],!0)}),e,n,s,o,{[p]:()=>g,destroy:async()=>(await I.stopAutoPersisting(),i(),I)},0,g);return I},Ha=(a,t,s,i,r,c,l,u,d,v,g="getDb",E)=>{let A,N,$;const f=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,c),[T,b,h,O]=(a=>{const t=(a=>ia(Pa,p(a)?{[Ca]:a}:a??{}))(a),n=t[ha];if(t.mode==fa){const a=t[Ca]??e;return[1,n,[a,t[Ta]??U,t[ba]??$a],ma(a)]}const{tables:{load:s={},save:i={}}={},values:r={}}=t,c=m(la(ia(Ma,r)),0,wa(Ma)),l=c[2],w=ma(l),y=ma(l),u=_a(s,{[Da]:null,[Oa]:U,[Ra]:o},Da,a=>L(y,a),a=>Aa(w,a)),d=_a(i,{[Ia]:null,[Oa]:U,[Sa]:0,[La]:0,[Ra]:null},Ia,(a,t)=>L(y,t),(a,t)=>Aa(w,t));var v;return v=(a,t)=>t[4]??=da(u,t[0])?.[2]??o,M(d,(a,t)=>v(0,a)),[0,n,[u,d,c],w]})(t);return(T?za:Ga)(a,f,a=>{let t;const e=()=>t=setInterval(()=>C(async()=>{const[{d:t,s:e,c:n}]=await f(j+` ${H} d,${q} s,TOTAL_CHANGES() c FROM ${G}${H} JOIN ${G}${q}`);t==A&&e==N&&n==$||(y(A)||a(),A=t,N=e,$=n)}),1e3*b),n=()=>{A=N=$=null,w(t)},s=i(t=>{O.has(t)&&(n(),a(),e())});return e(),()=>{n(),r(s)}},a=>a(),l,u,d,h,P(O),async(a,t)=>await a(j+` t.name tn,c.name cn FROM ${K}list()t,${K}info(t.name)c ${x} t.schema='main'AND t.type IN('table','view')AND t.name IN(${W(t)})ORDER BY t.name,c.name`,t),v,g,n,E,a=>!0===a?1:!1===a?0:a,void 0)},qa=(t,e,n,s,i)=>Ha(t,n,async(a,t=[])=>await e.getAllAsync(a,t),t=>a(({tableName:a})=>t(a)),a=>a.remove(),s,i,N,3,e);export{qa as createExpoSqlitePersister};
@@ -1 +1 @@
1
- import{addDatabaseChangeListener as a}from"expo-sqlite";const t=a=>typeof a,e="tinybase",n="",s=",",i=t(n),o="true",r=(a,t,e)=>a.replace(t,e),c=Promise,l=(a=y)=>(t,e,n)=>a(t)?n?.():e(t),w=clearInterval,y=a=>null==a,u=a=>void 0===a,d=a=>null===a,v=l(y),g=l(u),p=a=>t(a)==i,E=a=>Array.isArray(a),m=(a,t,e)=>a.slice(t,e),A=a=>a.length,N=()=>{},$=async a=>c.all(a),f=a=>{throw Error(a)},C=async(a,t,e)=>{try{return await a()}catch(a){t?.(a)}},T=(a,t)=>a.forEach(t),b=(a,t="")=>a.join(t),h=(a,t)=>a.map(t),O=a=>0==A(a),D=(a,t)=>a.filter(t),I=(a,...t)=>a.push(...t),S=a=>a.shift(),L=(a,t)=>a?.has(t)??!1,R=a=>u(a)||0==(a=>a?.size??0)(a),P=a=>[...a?.values()??[]],M=(a,t)=>a?.forEach(t),_=(a,t)=>a?.delete(t),F="_",U="_id",j="SELECT",x="WHERE",B="TABLE",J="ALTER "+B,Y="FROM",k="DELETE "+Y,z=j+"*"+Y,G="pragma_",H="data_version",q="schema_version",K="pragma_table_",Q="CREATE "+B,V=a=>b(h(((a,t="",e)=>a.split(t,e))(a,"."),a=>`"${r(a,/"/g,'""')}"`),"."),W=(a,t=[1])=>b(h(a,()=>"$"+t[0]++),s),X=(a,t=o)=>x+`(${r(t,"$tableName",V(a))})`,Z=Object,aa=a=>Z.getPrototypeOf(a),ta=Z.entries,ea=Z.keys,na=Z.freeze,sa=(a=[])=>Z.fromEntries(a),ia=(...a)=>Z.assign({},...a),oa=(a,t)=>(delete a[t],a),ra=(a,t)=>h(ta(a),([a,e])=>t(e,a)),ca=(a,t)=>sa(ra(a,(a,e)=>[e,t(a,e)])),la=a=>Z.values(a),wa=a=>A(ea(a)),ya=a=>(a=>!y(a)&&v(aa(a),a=>a==Z.prototype||y(aa(a)),()=>!0))(a)&&0==wa(a),ua=a=>new Map(a),da=(a,t)=>a?.get(t),va=(a,t)=>h([...a?.entries()??[]],([a,e])=>t(e,a)),ga=(a,t,e)=>void 0===e?(_(a,t),a):a?.set(t,e),pa=(a,t,e,n)=>(L(a,t)?n?.(da(a,t)):ga(a,t,e()),da(a,t)),Ea=(a,t,e,n,s=0)=>g((e?pa:da)(a,t[s],s>A(t)-2?e:ua),i=>{if(s>A(t)-2)return n?.(i)&&ga(a,t[s]),i;const o=Ea(i,t,e,n,s+1);return R(i)&&ga(a,t[s]),o}),ma=a=>new Set(E(a)||u(a)?a:[a]),Aa=(a,t)=>a?.add(t),Na="ColumnName",$a="store",fa="json",Ca=$a+"TableName",Ta=$a+"Id"+Na,ba=$a+Na,ha="autoLoadIntervalSeconds",Oa="rowId"+Na,Da="tableId",Ia="tableName",Sa="deleteEmptyColumns",La="deleteEmptyTable",Ra="condition",Pa={mode:fa,[ha]:1},Ma={load:0,save:0,[Ia]:e+"_values"},_a=(a,t,e,n,s)=>{const i=ua();return ca(a,(a,o)=>{const r=m(la(ia(t,p(a)?{[e]:a}:a)),0,wa(t));d(r[0])||n(o,r[0])||(s(o,r[0]),ga(i,o,r))}),i},Fa=JSON.stringify,Ua=JSON.parse,ja=/^\d+$/,xa=ua(),Ba=ua(),Ja=(a,t,e,s,i,o,r,c={},l=0,w=[])=>{let y,v,p,m=0,N=0,$=0;pa(xa,w,()=>0),pa(Ba,w,()=>[]);const b=ua(),[h,O,D,L,P]=((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]:f("Store type not supported by this Persister"))(r,a,l),[F,U,j]=(()=>{let a;const[t,e]=(()=>{const a=[];let t=0;return[e=>(e?S(a):null)??n+t++,t=>{ja.test(t)&&A(a)<1e3&&I(a,t)}]})(),s=ua();return[(e,i,o,r=[],c=()=>[])=>{a??=Q;const l=t(1);return ga(s,l,[e,i,o,r,c]),Aa(Ea(i,o??[n],ma),l),l},(t,e,...i)=>T(((a,t=[n])=>{const e=[],s=(a,n)=>n==A(t)?I(e,a):null===t[n]?M(a,a=>s(a,n+1)):T([t[n],null],t=>s(da(a,t),n+1));return s(a,0),e})(t,e),t=>M(t,t=>da(s,t)[0](a,...e??[],...i))),a=>g(da(s,a),([,t,i])=>(Ea(t,i??[n],void 0,t=>(_(t,a),R(t)?1:0)),ga(s,a),e(a),i)),t=>g(da(s,t),([t,,e=[],n,s])=>{const i=(...o)=>{const r=A(o);r==A(e)?t(a,...o,...s(o)):d(e[r])?T(n[r]?.(...o)??[],a=>i(...o,a)):i(...o,e[r])};i()})]})(),x=a=>{a!=m&&(m=a,U(b,void 0,m))},B=t=>{(h&&E(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},J=async a=>(2!=m&&(x(1),N++,await K(async()=>{await C(async()=>{const e=await t();E(e)?B(e):a?P(a):f("Content is not an array: "+e)},()=>{a&&P(a)}),x(0)})),Q),Y=async a=>(k(),await J(a),await C(async()=>v=await s(async(a,t)=>{t||a?2!=m&&(x(1),N++,B(t??a),x(0)):await J()}),o),Q),k=async()=>(v&&(await C(()=>i(v),o),v=void 0),Q),z=async a=>(1!=m&&(x(2),$++,await K(async()=>{await C(()=>e(O,a),o),x(0)})),Q),G=async()=>(H(),await z(),p=a.addDidFinishTransactionListener(()=>{const a=D();L(a)&&z(a)}),Q),H=async()=>(p&&(a.delListener(p),p=void 0),Q),q=async(a=!1)=>{const[t,e]=a?[H,k]:[k,H];return await t(),await e(),Q},K=async(...a)=>(I(da(Ba,w),...a),await(async()=>{if(!da(xa,w)){for(ga(xa,w,1);!u(y=S(da(Ba,w)));)await C(y,o);ga(xa,w,0)}})(),Q),Q={load:J,startAutoLoad:Y,stopAutoLoad:k,isAutoLoading:()=>!u(v),save:z,startAutoSave:G,stopAutoSave:H,isAutoSaving:()=>!u(p),startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[G,Y]:[Y,G];return await e(a),await n(a),Q},stopAutoPersisting:q,getStatus:()=>m,addStatusListener:a=>F(a,b),delListener:t=>(j(t),a),schedule:K,getStore:()=>a,destroy:()=>(da(Ba,w).splice(0,void 0),q()),getStats:()=>({loads:N,saves:$}),...c};return na(Q)},Ya=(a,t,e,n,i,r=ka,c,l)=>{const w=ua();return[async()=>{w.clear(),h(await e(a,t),({tn:a,cn:t})=>Aa(pa(w,a,ma),t))},async(t,e,n)=>((a,t)=>L(da(w,a),t))(t,e)?sa(D(h(await a(z+V(t)+X(t,n)),a=>[a[e],l?ca(oa(a,e),l):oa(a,e)]),([a,t])=>!u(a)&&!ya(t))):{},async(t,e,n,l,y,d=!1,v=o)=>{const g=ma();ca(n??{},a=>h(ea(a??{}),a=>Aa(g,a)));const p=P(g);if(!d&&y&&v==o&&O(p)&&L(w,t))return await a("DROP "+B+V(t)),void ga(w,t);const E=da(w,t),m=ma(P(E));if(O(p)||(L(w,t)?await $(h([e,...p],async(n,s)=>{_(m,n)||(await a(J+V(t)+"ADD"+V(n)+i),0==s&&await a("CREATE UNIQUE INDEX pk ON "+V(t)+`(${V(e)})`),Aa(E,n))})):(await a(Q+V(t)+`(${V(e)}${i} PRIMARY KEY${b(h(p,a=>s+V(a)+i))});`),ga(w,t,ma([e,...p])))),await $([...!d&&l?h(P(m),async n=>{n!=e&&(await a(J+V(t)+"DROP"+V(n)),_(E,n))}):[]]),d)u(n)?await a(k+V(t)+X(t,v)):await $(ra(n,async(n,s)=>{u(n)?await a(k+V(t)+X(t,v)+`AND(${V(e)}=$1)`,[s]):O(p)||await r(a,t,e,ea(n),{[s]:c?h(la(n),c):la(n)},E)}));else if(O(p))L(w,t)&&await a(k+V(t)+X(t,v));else{const s=D(P(da(w,t)),a=>a!=e),i={},o=[];ca(n??{},(a,t)=>{i[t]=h(s,t=>c?c(a?.[t]):a?.[t]),I(o,t)}),await r(a,t,e,s,i),await a(k+V(t)+X(t,v)+`AND${V(e)}NOT IN(${W(o)})`,o)}},async t=>{let e;return await a("BEGIN"),await C(async()=>e=await t(),n),await a("END"),e}]},ka=async(a,t,e,n,i)=>{const o=[1];await a("INSERT INTO"+V(t)+"("+((...a)=>b(h(a,V),s))(e,...n)+")VALUES"+b(ra(i,a=>"($"+o[0]+++","+W(a,o)+")"),s)+"ON CONFLICT("+V(e)+")DO UPDATE SET"+b(h(n,a=>V(a)+"=excluded."+V(a)),s),ra(i,(a,t)=>[t,...h(a,a=>a??null)]).flat())},za=(a,t,e,n,s,i,o,[r,c,l],w,y,u,d,v,g)=>{const[p,E,m,A]=Ya(t,w,y,s,v,g),N=Ja(a,()=>A(async()=>{return await p(),a=(await E(r,c))[F]?.[l]??"null",Ua(a,(a,t)=>""===t?void 0:t);var a}),a=>A(async()=>{var t;await p(),await m(r,c,{[F]:{[l]:(t=a()??null,Fa(t,(a,t)=>void 0===t?"":t))}},!0,!0)}),e,n,s,o,{[d]:()=>u,destroy:async()=>(await N.stopAutoPersisting(),i(),N)},0,u);return N},Ga=(a,t,e,n,s,i,o,[r,c,[l,w,y]],d,v,g,p,E,m,A,N)=>{const[f,C,T,b]=Ya(t,d,v,s,E,m,A,N),h=(a,t)=>$(va(c,async([e,n,s,i,o],r)=>{t&&!(r in a)||await T(e,n,a[r],s,i,t,o)})),O=async(a,t)=>w?await T(y,U,{[F]:a},!0,!0,t):null,I=Ja(a,()=>b(async()=>{await f();const a=await(async()=>sa(D(await $(va(r,async([a,t,e],n)=>[a,await C(n,t,e)])),a=>!ya(a[1]))))(),t=await(async()=>l?(await C(y,U))[F]:{})();return ya(a)&&u(t)?void 0:[a,t]}),(a,t)=>b(async()=>{if(await f(),u(t)){const[t,e]=a();await h(t),await O(e)}else await h(t[0],!0),await O(t[1],!0)}),e,n,s,o,{[p]:()=>g,destroy:async()=>(await I.stopAutoPersisting(),i(),I)},0,g);return I},Ha=(a,t,s,i,r,c,l,u,d,v,g="getDb",E)=>{let A,N,$;const f=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,c),[T,b,h,O]=(a=>{const t=(a=>ia(Pa,p(a)?{[Ca]:a}:a??{}))(a),n=t[ha];if(t.mode==fa){const a=t[Ca]??e;return[1,n,[a,t[Ta]??U,t[ba]??$a],ma(a)]}const{tables:{load:s={},save:i={}}={},values:r={}}=t,c=m(la(ia(Ma,r)),0,wa(Ma)),l=c[2],w=ma(l),y=ma(l),u=_a(s,{[Da]:null,[Oa]:U,[Ra]:o},Da,a=>L(y,a),a=>Aa(w,a)),d=_a(i,{[Ia]:null,[Oa]:U,[Sa]:0,[La]:0,[Ra]:null},Ia,(a,t)=>L(y,t),(a,t)=>Aa(w,t));var v;return v=(a,t)=>t[4]??=da(u,t[0])?.[2]??o,M(d,(a,t)=>v(0,a)),[0,n,[u,d,c],w]})(t);return(T?za:Ga)(a,f,a=>{let t;const e=()=>t=setInterval(()=>C(async()=>{const[{d:t,s:e,c:n}]=await f(j+` ${H} d,${q} s,TOTAL_CHANGES() c FROM ${G}${H} JOIN ${G}${q}`);t==A&&e==N&&n==$||(y(A)||a(),A=t,N=e,$=n)}),1e3*b),n=()=>{A=N=$=null,w(t)},s=i(t=>{O.has(t)&&(n(),a(),e())});return e(),()=>{n(),r(s)}},a=>a(),l,u,d,h,P(O),async(a,t)=>await a(j+` t.name tn,c.name cn FROM ${K}list()t,${K}info(t.name)c ${x} t.schema='main'AND t.type IN('table','view')AND t.name IN(${W(t)})ORDER BY t.name,c.name`,t),v,g,n,E,a=>!0===a?1:!1===a?0:a,void 0)},qa=(t,e,n,s,i)=>Ha(t,n,async(a,t=[])=>await e.getAllAsync(a,t),t=>a(({tableName:a})=>t(a)),a=>a.remove(),s,i,N,3,e);export{qa as createExpoSqlitePersister};
1
+ import{addDatabaseChangeListener as a}from"expo-sqlite";const t=a=>typeof a,e="tinybase",n="",s=",",i=t(n),o="true",r=(a,t,e)=>a.replace(t,e),c=Promise,l=a=>(t,e,n)=>a(t)?n?.():e(t),w=clearInterval,y=a=>null==a,u=a=>void 0===a,d=a=>null===a,v=l(y),g=l(u),p=a=>t(a)==i,E=a=>Array.isArray(a),m=(a,t,e)=>a.slice(t,e),A=a=>a.length,N=()=>{},$=async a=>c.all(a),f=a=>{throw Error(a)},C=async(a,t,e)=>{try{return await a()}catch(a){t?.(a)}},T=(a,t)=>a.forEach(t),b=(a,t="")=>a.join(t),h=(a,t)=>a.map(t),O=a=>0==A(a),D=(a,t)=>a.filter(t),I=(a,...t)=>a.push(...t),S=a=>a.shift(),L=(a,t)=>a?.has(t)??!1,R=a=>u(a)||0==(a=>a?.size??0)(a),P=a=>[...a?.values()??[]],M=(a,t)=>a?.forEach(t),_=(a,t)=>a?.delete(t),F="_",U="_id",j="SELECT",x="WHERE",B="TABLE",J="ALTER "+B,Y="FROM",k="DELETE "+Y,z=j+"*"+Y,G="pragma_",H="data_version",q="schema_version",K="pragma_table_",Q="CREATE "+B,V=a=>b(h(((a,t="",e)=>a.split(t,e))(a,"."),a=>`"${r(a,/"/g,'""')}"`),"."),W=(a,t=[1])=>b(h(a,()=>"$"+t[0]++),s),X=(a,t=o)=>x+`(${r(t,"$tableName",V(a))})`,Z=Object,aa=a=>Z.getPrototypeOf(a),ta=Z.entries,ea=Z.keys,na=Z.freeze,sa=(a=[])=>Z.fromEntries(a),ia=(...a)=>Z.assign({},...a),oa=(a,t)=>(delete a[t],a),ra=(a,t)=>h(ta(a),([a,e])=>t(e,a)),ca=(a,t)=>sa(ra(a,(a,e)=>[e,t(a,e)])),la=a=>Z.values(a),wa=a=>A(ea(a)),ya=a=>(a=>!y(a)&&v(aa(a),a=>a==Z.prototype||y(aa(a)),()=>!0))(a)&&0==wa(a),ua=a=>new Map(a),da=(a,t)=>a?.get(t),va=(a,t)=>h([...a?.entries()??[]],([a,e])=>t(e,a)),ga=(a,t,e)=>void 0===e?(_(a,t),a):a?.set(t,e),pa=(a,t,e,n)=>(L(a,t)?n?.(da(a,t)):ga(a,t,e()),da(a,t)),Ea=(a,t,e,n,s=0)=>g((e?pa:da)(a,t[s],s>A(t)-2?e:ua),i=>{if(s>A(t)-2)return n?.(i)&&ga(a,t[s]),i;const o=Ea(i,t,e,n,s+1);return R(i)&&ga(a,t[s]),o}),ma=a=>new Set(E(a)||u(a)?a:[a]),Aa=(a,t)=>a?.add(t),Na="ColumnName",$a="store",fa="json",Ca=$a+"TableName",Ta=$a+"Id"+Na,ba=$a+Na,ha="autoLoadIntervalSeconds",Oa="rowId"+Na,Da="tableId",Ia="tableName",Sa="deleteEmptyColumns",La="deleteEmptyTable",Ra="condition",Pa={mode:fa,[ha]:1},Ma={load:0,save:0,[Ia]:e+"_values"},_a=(a,t,e,n,s)=>{const i=ua();return ca(a,(a,o)=>{const r=m(la(ia(t,p(a)?{[e]:a}:a)),0,wa(t));d(r[0])||n(o,r[0])||(s(o,r[0]),ga(i,o,r))}),i},Fa=JSON.stringify,Ua=JSON.parse,ja=/^\d+$/,xa=ua(),Ba=ua(),Ja=(a,t,e,s,i,o,r,c={},l=0,w=[])=>{let y,v,p,m=0,N=0,$=0;pa(xa,w,()=>0),pa(Ba,w,()=>[]);const b=ua(),[h,O,D,L,P]=((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]:f("Store type not supported by this Persister"))(r,a,l),[F,U,j]=(()=>{let a;const[t,e]=(()=>{const a=[];let t=0;return[e=>(e?S(a):null)??n+t++,t=>{ja.test(t)&&A(a)<1e3&&I(a,t)}]})(),s=ua();return[(e,i,o,r=[],c=()=>[])=>{a??=Q;const l=t(1);return ga(s,l,[e,i,o,r,c]),Aa(Ea(i,o??[n],ma),l),l},(t,e,...i)=>T(((a,t=[n])=>{const e=[],s=(a,n)=>n==A(t)?I(e,a):null===t[n]?M(a,a=>s(a,n+1)):T([t[n],null],t=>s(da(a,t),n+1));return s(a,0),e})(t,e),t=>M(t,t=>da(s,t)[0](a,...e??[],...i))),a=>g(da(s,a),([,t,i])=>(Ea(t,i??[n],void 0,t=>(_(t,a),R(t)?1:0)),ga(s,a),e(a),i)),t=>g(da(s,t),([t,,e=[],n,s])=>{const i=(...o)=>{const r=A(o);r==A(e)?t(a,...o,...s(o)):d(e[r])?T(n[r]?.(...o)??[],a=>i(...o,a)):i(...o,e[r])};i()})]})(),x=a=>{a!=m&&(m=a,U(b,void 0,m))},B=t=>{(h&&E(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},J=async a=>(2!=m&&(x(1),N++,await K(async()=>{await C(async()=>{const e=await t();E(e)?B(e):a?P(a):f("Content is not an array: "+e)},()=>{a&&P(a)}),x(0)})),Q),Y=async a=>(k(),await J(a),await C(async()=>v=await s(async(a,t)=>{t||a?2!=m&&(x(1),N++,B(t??a),x(0)):await J()}),o),Q),k=async()=>(v&&(await C(()=>i(v),o),v=void 0),Q),z=async a=>(1!=m&&(x(2),$++,await K(async()=>{await C(()=>e(O,a),o),x(0)})),Q),G=async()=>(H(),await z(),p=a.addDidFinishTransactionListener(()=>{const a=D();L(a)&&z(a)}),Q),H=async()=>(p&&(a.delListener(p),p=void 0),Q),q=async(a=!1)=>{const[t,e]=a?[H,k]:[k,H];return await t(),await e(),Q},K=async(...a)=>(I(da(Ba,w),...a),await(async()=>{if(!da(xa,w)){for(ga(xa,w,1);!u(y=S(da(Ba,w)));)await C(y,o);ga(xa,w,0)}})(),Q),Q={load:J,startAutoLoad:Y,stopAutoLoad:k,isAutoLoading:()=>!u(v),save:z,startAutoSave:G,stopAutoSave:H,isAutoSaving:()=>!u(p),startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[G,Y]:[Y,G];return await e(a),await n(a),Q},stopAutoPersisting:q,getStatus:()=>m,addStatusListener:a=>F(a,b),delListener:t=>(j(t),a),schedule:K,getStore:()=>a,destroy:()=>(da(Ba,w).splice(0,void 0),q()),getStats:()=>({loads:N,saves:$}),...c};return na(Q)},Ya=(a,t,e,n,i,r=ka,c,l)=>{const w=ua();return[async()=>{w.clear(),h(await e(a,t),({tn:a,cn:t})=>Aa(pa(w,a,ma),t))},async(t,e,n)=>((a,t)=>L(da(w,a),t))(t,e)?sa(D(h(await a(z+V(t)+X(t,n)),a=>[a[e],l?ca(oa(a,e),l):oa(a,e)]),([a,t])=>!u(a)&&!ya(t))):{},async(t,e,n,l,y,d=!1,v=o)=>{const g=ma();ca(n??{},a=>h(ea(a??{}),a=>Aa(g,a)));const p=P(g);if(!d&&y&&v==o&&O(p)&&L(w,t))return await a("DROP "+B+V(t)),void ga(w,t);const E=da(w,t),m=ma(P(E));if(O(p)||(L(w,t)?await $(h([e,...p],async(n,s)=>{_(m,n)||(await a(J+V(t)+"ADD"+V(n)+i),0==s&&await a("CREATE UNIQUE INDEX pk ON "+V(t)+`(${V(e)})`),Aa(E,n))})):(await a(Q+V(t)+`(${V(e)}${i} PRIMARY KEY${b(h(p,a=>s+V(a)+i))});`),ga(w,t,ma([e,...p])))),await $([...!d&&l?h(P(m),async n=>{n!=e&&(await a(J+V(t)+"DROP"+V(n)),_(E,n))}):[]]),d)u(n)?await a(k+V(t)+X(t,v)):await $(ra(n,async(n,s)=>{u(n)?await a(k+V(t)+X(t,v)+`AND(${V(e)}=$1)`,[s]):O(p)||await r(a,t,e,ea(n),{[s]:c?h(la(n),c):la(n)},E)}));else if(O(p))L(w,t)&&await a(k+V(t)+X(t,v));else{const s=D(P(da(w,t)),a=>a!=e),i={},o=[];ca(n??{},(a,t)=>{i[t]=h(s,t=>c?c(a?.[t]):a?.[t]),I(o,t)}),await r(a,t,e,s,i),await a(k+V(t)+X(t,v)+`AND${V(e)}NOT IN(${W(o)})`,o)}},async t=>{let e;return await a("BEGIN"),await C(async()=>e=await t(),n),await a("END"),e}]},ka=async(a,t,e,n,i)=>{const o=[1];await a("INSERT INTO"+V(t)+"("+((...a)=>b(h(a,V),s))(e,...n)+")VALUES"+b(ra(i,a=>"($"+o[0]+++","+W(a,o)+")"),s)+"ON CONFLICT("+V(e)+")DO UPDATE SET"+b(h(n,a=>V(a)+"=excluded."+V(a)),s),ra(i,(a,t)=>[t,...h(a,a=>a??null)]).flat())},za=(a,t,e,n,s,i,o,[r,c,l],w,y,u,d,v,g)=>{const[p,E,m,A]=Ya(t,w,y,s,v,g),N=Ja(a,()=>A(async()=>{return await p(),a=(await E(r,c))[F]?.[l]??"null",Ua(a,(a,t)=>""===t?void 0:t);var a}),a=>A(async()=>{var t;await p(),await m(r,c,{[F]:{[l]:(t=a()??null,Fa(t,(a,t)=>void 0===t?"":t))}},!0,!0)}),e,n,s,o,{[d]:()=>u,destroy:async()=>(await N.stopAutoPersisting(),i(),N)},0,u);return N},Ga=(a,t,e,n,s,i,o,[r,c,[l,w,y]],d,v,g,p,E,m,A,N)=>{const[f,C,T,b]=Ya(t,d,v,s,E,m,A,N),h=(a,t)=>$(va(c,async([e,n,s,i,o],r)=>{t&&!(r in a)||await T(e,n,a[r],s,i,t,o)})),O=async(a,t)=>w?await T(y,U,{[F]:a},!0,!0,t):null,I=Ja(a,()=>b(async()=>{await f();const a=await(async()=>sa(D(await $(va(r,async([a,t,e],n)=>[a,await C(n,t,e)])),a=>!ya(a[1]))))(),t=await(async()=>l?(await C(y,U))[F]:{})();return ya(a)&&u(t)?void 0:[a,t]}),(a,t)=>b(async()=>{if(await f(),u(t)){const[t,e]=a();await h(t),await O(e)}else await h(t[0],!0),await O(t[1],!0)}),e,n,s,o,{[p]:()=>g,destroy:async()=>(await I.stopAutoPersisting(),i(),I)},0,g);return I},Ha=(a,t,s,i,r,c,l,u,d,v,g="getDb",E)=>{let A,N,$;const f=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,c),[T,b,h,O]=(a=>{const t=(a=>ia(Pa,p(a)?{[Ca]:a}:a??{}))(a),n=t[ha];if(t.mode==fa){const a=t[Ca]??e;return[1,n,[a,t[Ta]??U,t[ba]??$a],ma(a)]}const{tables:{load:s={},save:i={}}={},values:r={}}=t,c=m(la(ia(Ma,r)),0,wa(Ma)),l=c[2],w=ma(l),y=ma(l),u=_a(s,{[Da]:null,[Oa]:U,[Ra]:o},Da,a=>L(y,a),a=>Aa(w,a)),d=_a(i,{[Ia]:null,[Oa]:U,[Sa]:0,[La]:0,[Ra]:null},Ia,(a,t)=>L(y,t),(a,t)=>Aa(w,t));var v;return v=(a,t)=>t[4]??=da(u,t[0])?.[2]??o,M(d,(a,t)=>v(0,a)),[0,n,[u,d,c],w]})(t);return(T?za:Ga)(a,f,a=>{let t;const e=()=>t=setInterval(()=>C(async()=>{const[{d:t,s:e,c:n}]=await f(j+` ${H} d,${q} s,TOTAL_CHANGES() c FROM ${G}${H} JOIN ${G}${q}`);t==A&&e==N&&n==$||(y(A)||a(),A=t,N=e,$=n)}),1e3*b),n=()=>{A=N=$=null,w(t)},s=i(t=>{O.has(t)&&(n(),a(),e())});return e(),()=>{n(),r(s)}},a=>a(),l,u,d,h,P(O),async(a,t)=>await a(j+` t.name tn,c.name cn FROM ${K}list()t,${K}info(t.name)c ${x} t.schema='main'AND t.type IN('table','view')AND t.name IN(${W(t)})ORDER BY t.name,c.name`,t),v,g,n,E,a=>!0===a?1:!1===a?0:a,void 0)},qa=(t,e,n,s,i)=>Ha(t,n,async(a,t=[])=>await e.getAllAsync(a,t),t=>a(({tableName:a})=>t(a)),a=>a.remove(),s,i,N,3,e);export{qa as createExpoSqlitePersister};