tinybase 7.3.3 → 7.3.4

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 (244) hide show
  1. package/checkpoints/index.js +12 -11
  2. package/checkpoints/with-schemas/index.js +12 -11
  3. package/common/index.js +3 -2
  4. package/common/with-schemas/index.js +3 -2
  5. package/index.js +92 -64
  6. package/indexes/index.js +13 -12
  7. package/indexes/with-schemas/index.js +13 -12
  8. package/mergeable-store/index.js +92 -64
  9. package/mergeable-store/with-schemas/index.js +92 -64
  10. package/metrics/index.js +13 -12
  11. package/metrics/with-schemas/index.js +13 -12
  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-pglite/index.js +1 -1
  85. package/min/persisters/persister-pglite/index.js.gz +0 -0
  86. package/min/persisters/persister-pglite/with-schemas/index.js +1 -1
  87. package/min/persisters/persister-pglite/with-schemas/index.js.gz +0 -0
  88. package/min/persisters/persister-postgres/index.js +1 -1
  89. package/min/persisters/persister-postgres/index.js.gz +0 -0
  90. package/min/persisters/persister-postgres/with-schemas/index.js +1 -1
  91. package/min/persisters/persister-postgres/with-schemas/index.js.gz +0 -0
  92. package/min/persisters/persister-powersync/index.js +1 -1
  93. package/min/persisters/persister-powersync/index.js.gz +0 -0
  94. package/min/persisters/persister-powersync/with-schemas/index.js +1 -1
  95. package/min/persisters/persister-powersync/with-schemas/index.js.gz +0 -0
  96. package/min/persisters/persister-react-native-mmkv/index.js +1 -1
  97. package/min/persisters/persister-react-native-mmkv/index.js.gz +0 -0
  98. package/min/persisters/persister-react-native-mmkv/with-schemas/index.js +1 -1
  99. package/min/persisters/persister-react-native-mmkv/with-schemas/index.js.gz +0 -0
  100. package/min/persisters/persister-react-native-sqlite/index.js +1 -1
  101. package/min/persisters/persister-react-native-sqlite/index.js.gz +0 -0
  102. package/min/persisters/persister-react-native-sqlite/with-schemas/index.js +1 -1
  103. package/min/persisters/persister-react-native-sqlite/with-schemas/index.js.gz +0 -0
  104. package/min/persisters/persister-remote/index.js +1 -1
  105. package/min/persisters/persister-remote/index.js.gz +0 -0
  106. package/min/persisters/persister-remote/with-schemas/index.js +1 -1
  107. package/min/persisters/persister-remote/with-schemas/index.js.gz +0 -0
  108. package/min/persisters/persister-sqlite-bun/index.js +1 -1
  109. package/min/persisters/persister-sqlite-bun/index.js.gz +0 -0
  110. package/min/persisters/persister-sqlite-bun/with-schemas/index.js +1 -1
  111. package/min/persisters/persister-sqlite-bun/with-schemas/index.js.gz +0 -0
  112. package/min/persisters/persister-sqlite-wasm/index.js +1 -1
  113. package/min/persisters/persister-sqlite-wasm/index.js.gz +0 -0
  114. package/min/persisters/persister-sqlite-wasm/with-schemas/index.js +1 -1
  115. package/min/persisters/persister-sqlite-wasm/with-schemas/index.js.gz +0 -0
  116. package/min/persisters/persister-sqlite3/index.js +1 -1
  117. package/min/persisters/persister-sqlite3/index.js.gz +0 -0
  118. package/min/persisters/persister-sqlite3/with-schemas/index.js +1 -1
  119. package/min/persisters/persister-sqlite3/with-schemas/index.js.gz +0 -0
  120. package/min/persisters/persister-yjs/index.js +1 -1
  121. package/min/persisters/persister-yjs/index.js.gz +0 -0
  122. package/min/persisters/persister-yjs/with-schemas/index.js +1 -1
  123. package/min/persisters/persister-yjs/with-schemas/index.js.gz +0 -0
  124. package/min/persisters/with-schemas/index.js +1 -1
  125. package/min/persisters/with-schemas/index.js.gz +0 -0
  126. package/min/queries/index.js +1 -1
  127. package/min/queries/index.js.gz +0 -0
  128. package/min/queries/with-schemas/index.js +1 -1
  129. package/min/queries/with-schemas/index.js.gz +0 -0
  130. package/min/relationships/index.js +1 -1
  131. package/min/relationships/index.js.gz +0 -0
  132. package/min/relationships/with-schemas/index.js +1 -1
  133. package/min/relationships/with-schemas/index.js.gz +0 -0
  134. package/min/store/index.js +1 -1
  135. package/min/store/index.js.gz +0 -0
  136. package/min/store/with-schemas/index.js +1 -1
  137. package/min/store/with-schemas/index.js.gz +0 -0
  138. package/min/synchronizers/index.js +1 -1
  139. package/min/synchronizers/index.js.gz +0 -0
  140. package/min/synchronizers/synchronizer-broadcast-channel/index.js +1 -1
  141. package/min/synchronizers/synchronizer-broadcast-channel/index.js.gz +0 -0
  142. package/min/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js +1 -1
  143. package/min/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js.gz +0 -0
  144. package/min/synchronizers/synchronizer-local/index.js +1 -1
  145. package/min/synchronizers/synchronizer-local/index.js.gz +0 -0
  146. package/min/synchronizers/synchronizer-local/with-schemas/index.js +1 -1
  147. package/min/synchronizers/synchronizer-local/with-schemas/index.js.gz +0 -0
  148. package/min/synchronizers/synchronizer-ws-client/index.js +1 -1
  149. package/min/synchronizers/synchronizer-ws-client/index.js.gz +0 -0
  150. package/min/synchronizers/synchronizer-ws-client/with-schemas/index.js +1 -1
  151. package/min/synchronizers/synchronizer-ws-client/with-schemas/index.js.gz +0 -0
  152. package/min/synchronizers/synchronizer-ws-server/index.js +1 -1
  153. package/min/synchronizers/synchronizer-ws-server/index.js.gz +0 -0
  154. package/min/synchronizers/synchronizer-ws-server/with-schemas/index.js +1 -1
  155. package/min/synchronizers/synchronizer-ws-server/with-schemas/index.js.gz +0 -0
  156. package/min/synchronizers/synchronizer-ws-server-durable-object/index.js +1 -1
  157. package/min/synchronizers/synchronizer-ws-server-durable-object/index.js.gz +0 -0
  158. package/min/synchronizers/synchronizer-ws-server-durable-object/with-schemas/index.js +1 -1
  159. package/min/synchronizers/synchronizer-ws-server-durable-object/with-schemas/index.js.gz +0 -0
  160. package/min/synchronizers/synchronizer-ws-server-simple/index.js +1 -1
  161. package/min/synchronizers/synchronizer-ws-server-simple/index.js.gz +0 -0
  162. package/min/synchronizers/synchronizer-ws-server-simple/with-schemas/index.js +1 -1
  163. package/min/synchronizers/synchronizer-ws-server-simple/with-schemas/index.js.gz +0 -0
  164. package/min/synchronizers/with-schemas/index.js +1 -1
  165. package/min/synchronizers/with-schemas/index.js.gz +0 -0
  166. package/min/ui-react-inspector/index.js +1 -1
  167. package/min/ui-react-inspector/index.js.gz +0 -0
  168. package/min/ui-react-inspector/with-schemas/index.js +1 -1
  169. package/min/ui-react-inspector/with-schemas/index.js.gz +0 -0
  170. package/min/with-schemas/index.js +1 -1
  171. package/min/with-schemas/index.js.gz +0 -0
  172. package/omni/index.js +99 -64
  173. package/omni/with-schemas/index.js +99 -64
  174. package/package.json +3 -3
  175. package/persisters/index.js +19 -11
  176. package/persisters/persister-automerge/index.js +17 -9
  177. package/persisters/persister-automerge/with-schemas/index.js +17 -9
  178. package/persisters/persister-browser/index.js +17 -9
  179. package/persisters/persister-browser/with-schemas/index.js +17 -9
  180. package/persisters/persister-cr-sqlite-wasm/index.js +19 -11
  181. package/persisters/persister-cr-sqlite-wasm/with-schemas/index.js +19 -11
  182. package/persisters/persister-durable-object-sql-storage/index.js +19 -11
  183. package/persisters/persister-durable-object-sql-storage/with-schemas/index.js +19 -11
  184. package/persisters/persister-durable-object-storage/index.js +19 -11
  185. package/persisters/persister-durable-object-storage/with-schemas/index.js +19 -11
  186. package/persisters/persister-electric-sql/index.js +19 -11
  187. package/persisters/persister-electric-sql/with-schemas/index.js +19 -11
  188. package/persisters/persister-expo-sqlite/index.js +19 -11
  189. package/persisters/persister-expo-sqlite/with-schemas/index.js +19 -11
  190. package/persisters/persister-file/index.js +17 -9
  191. package/persisters/persister-file/with-schemas/index.js +17 -9
  192. package/persisters/persister-indexed-db/index.js +17 -9
  193. package/persisters/persister-indexed-db/with-schemas/index.js +17 -9
  194. package/persisters/persister-libsql/index.js +19 -11
  195. package/persisters/persister-libsql/with-schemas/index.js +19 -11
  196. package/persisters/persister-partykit-client/index.js +17 -9
  197. package/persisters/persister-partykit-client/with-schemas/index.js +17 -9
  198. package/persisters/persister-partykit-server/index.js +2 -2
  199. package/persisters/persister-partykit-server/with-schemas/index.js +2 -2
  200. package/persisters/persister-pglite/index.js +19 -11
  201. package/persisters/persister-pglite/with-schemas/index.js +19 -11
  202. package/persisters/persister-postgres/index.js +19 -11
  203. package/persisters/persister-postgres/with-schemas/index.js +19 -11
  204. package/persisters/persister-powersync/index.js +19 -11
  205. package/persisters/persister-powersync/with-schemas/index.js +19 -11
  206. package/persisters/persister-react-native-mmkv/index.js +17 -9
  207. package/persisters/persister-react-native-mmkv/with-schemas/index.js +17 -9
  208. package/persisters/persister-react-native-sqlite/index.js +19 -11
  209. package/persisters/persister-react-native-sqlite/with-schemas/index.js +19 -11
  210. package/persisters/persister-remote/index.js +17 -9
  211. package/persisters/persister-remote/with-schemas/index.js +17 -9
  212. package/persisters/persister-sqlite-bun/index.js +19 -11
  213. package/persisters/persister-sqlite-bun/with-schemas/index.js +19 -11
  214. package/persisters/persister-sqlite-wasm/index.js +19 -11
  215. package/persisters/persister-sqlite-wasm/with-schemas/index.js +19 -11
  216. package/persisters/persister-sqlite3/index.js +19 -11
  217. package/persisters/persister-sqlite3/with-schemas/index.js +19 -11
  218. package/persisters/persister-yjs/index.js +19 -11
  219. package/persisters/persister-yjs/with-schemas/index.js +19 -11
  220. package/persisters/with-schemas/index.js +19 -11
  221. package/queries/index.js +15 -14
  222. package/queries/with-schemas/index.js +15 -14
  223. package/readme.md +2 -2
  224. package/relationships/index.js +13 -12
  225. package/relationships/with-schemas/index.js +13 -12
  226. package/store/index.js +74 -60
  227. package/store/with-schemas/index.js +74 -60
  228. package/synchronizers/index.js +17 -9
  229. package/synchronizers/synchronizer-broadcast-channel/index.js +17 -9
  230. package/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js +17 -9
  231. package/synchronizers/synchronizer-local/index.js +19 -11
  232. package/synchronizers/synchronizer-local/with-schemas/index.js +19 -11
  233. package/synchronizers/synchronizer-ws-client/index.js +17 -9
  234. package/synchronizers/synchronizer-ws-client/with-schemas/index.js +17 -9
  235. package/synchronizers/synchronizer-ws-server/index.js +20 -12
  236. package/synchronizers/synchronizer-ws-server/with-schemas/index.js +20 -12
  237. package/synchronizers/synchronizer-ws-server-durable-object/index.js +17 -9
  238. package/synchronizers/synchronizer-ws-server-durable-object/with-schemas/index.js +17 -9
  239. package/synchronizers/synchronizer-ws-server-simple/index.js +11 -10
  240. package/synchronizers/synchronizer-ws-server-simple/with-schemas/index.js +11 -10
  241. package/synchronizers/with-schemas/index.js +17 -9
  242. package/ui-react-inspector/index.js +81 -60
  243. package/ui-react-inspector/with-schemas/index.js +81 -60
  244. package/with-schemas/index.js +92 -64
@@ -1 +1 @@
1
- const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),i="true",r=(a,t,e)=>a.replace(t,e),o=Promise,c=a=>(t,e,n)=>a(t)?n?.():e(t),l=clearInterval,w=a=>null==a,y=a=>void 0===a,u=a=>null===a,d=c(w),g=c(y),p=t=>a(t)==s,v=a=>Array.isArray(a),E=(a,t,e)=>a.slice(t,e),A=a=>a.length,N=()=>{},m=async a=>o.all(a),$=a=>{throw Error(a)},f=async(a,t,e)=>{try{return await a()}catch(a){t?.(a)}},C=(a,t)=>a.forEach(t),T=(a,t="")=>a.join(t),O=(a,t)=>a.map(t),S=a=>0==A(a),b=(a,t)=>a.filter(t),h=(a,...t)=>a.push(...t),D=a=>a.shift(),I=(a,t)=>a?.has(t)??!1,L=a=>y(a)||0==(a=>a?.size??0)(a),R=a=>[...a?.values()??[]],P=(a,t)=>a?.forEach(t),M=(a,t)=>a?.delete(t),_="_",F="_id",U="SELECT",j="WHERE",x="TABLE",B="ALTER "+x,J="FROM",Y="DELETE "+J,k=U+"*"+J,z="pragma_",G="data_version",H="schema_version",q="pragma_table_",K="CREATE "+x,Q=a=>T(O(((a,t="",e)=>a.split(t,e))(a,"."),a=>`"${r(a,/"/g,'""')}"`),"."),V=(a,t=[1])=>T(O(a,()=>"$"+t[0]++),n),W=(a,t=i)=>j+`(${r(t,"$tableName",Q(a))})`,X=Object,Z=a=>X.getPrototypeOf(a),aa=X.entries,ta=a=>!w(a)&&d(Z(a),a=>a==X.prototype||w(Z(a)),()=>!0),ea=X.keys,na=X.freeze,sa=(a=[])=>X.fromEntries(a),ia=(...a)=>X.assign({},...a),ra=(a,t)=>(delete a[t],a),oa=(a,t)=>O(aa(a),([a,e])=>t(e,a)),ca=(a,t)=>sa(oa(a,(a,e)=>[e,t(a,e)])),la=a=>X.values(a),wa=a=>A(ea(a)),ya=a=>ta(a)&&0==wa(a),ua=a=>new Map(a),da=(a,t)=>a?.get(t),ga=(a,t)=>O([...a?.entries()??[]],([a,e])=>t(e,a)),pa=(a,t,e)=>y(e)?(M(a,t),a):a?.set(t,e),va=(a,t,e,n)=>(I(a,t)?n?.(da(a,t)):pa(a,t,e()),da(a,t)),Ea=(a,t,e,n,s=0)=>g((e?va:da)(a,t[s],s>A(t)-2?e:ua),i=>{if(s>A(t)-2)return n?.(i)&&pa(a,t[s]),i;const r=Ea(i,t,e,n,s+1);return L(i)&&pa(a,t[s]),r}),Aa=a=>new Set(v(a)||y(a)?a:[a]),Na=(a,t)=>a?.add(t),ma="ColumnName",$a="store",fa="json",Ca=$a+"TableName",Ta=$a+"Id"+ma,Oa=$a+ma,Sa="autoLoadIntervalSeconds",ba="rowId"+ma,ha="tableId",Da="tableName",Ia="deleteEmptyColumns",La="deleteEmptyTable",Ra="condition",Pa={mode:fa,[Sa]:1},Ma={load:0,save:0,[Da]:t+"_values"},_a=(a,t,e,n,s)=>{const i=ua();return ca(a,(a,r)=>{const o=E(la(ia(t,p(a)?{[e]:a}:a)),0,wa(t));u(o[0])||n(r,o[0])||(s(r,o[0]),pa(i,r,o))}),i},Fa=JSON.stringify,Ua=JSON.parse,ja=a=>""===a?void 0:v(a)?O(a,ja):ta(a)?ca(a,ja):a,xa=/^\d+$/,Ba=ua(),Ja=ua(),Ya=(a,t,n,s,i,r,o,c={},l=0,w=[])=>{let d,p,E,N=0,m=0,T=0;va(Ba,w,()=>0),va(Ja,w,()=>[]);const O=ua(),[S,b,I,R,_]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!ya(a)||!ya(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!ya(a)||!ya(t),t.setContent]:$("Store type not supported by this Persister"))(o,a,l),[F,U,j]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?D(a):null)??e+t++,t=>{xa.test(t)&&A(a)<1e3&&h(a,t)}]})(),s=ua();return[(n,i,r,o=[],c=()=>[])=>{a??=Q;const l=t(1);return pa(s,l,[n,i,r,o,c]),Na(Ea(i,r??[e],Aa),l),l},(t,n,...i)=>C(((a,t=[e])=>{const n=[],s=(a,e)=>e==A(t)?h(n,a):u(t[e])?P(a,a=>s(a,e+1)):C([t[e],null],t=>s(da(a,t),e+1));return s(a,0),n})(t,n),t=>P(t,t=>da(s,t)[0](a,...n??[],...i))),a=>g(da(s,a),([,t,i])=>(Ea(t,i??[e],void 0,t=>(M(t,a),L(t)?1:0)),pa(s,a),n(a),i)),t=>g(da(s,t),([t,,e=[],n,s])=>{const i=(...r)=>{const o=A(r);o==A(e)?t(a,...r,...s(r)):u(e[o])?C(n[o]?.(...r)??[],a=>i(...r,a)):i(...r,e[o])};i()})]})(),x=a=>{a!=N&&(N=a,U(O,void 0,N))},B=t=>{(S&&v(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},J=async a=>(2!=N&&(x(1),m++,await K(async()=>{await f(async()=>{const e=await t();v(e)?B(e):a?_(a):$("Content is not an array: "+e)},()=>{a&&_(a)}),x(0)})),Q),Y=async a=>(k(),await J(a),await f(async()=>p=await s(async(a,t)=>{t||a?2!=N&&(x(1),m++,B(t??a),x(0)):await J()}),r),Q),k=async()=>(p&&(await f(()=>i(p),r),p=void 0),Q),z=async a=>(1!=N&&(x(2),T++,await K(async()=>{await f(()=>n(b,a),r),x(0)})),Q),G=async()=>(H(),await z(),E=a.addDidFinishTransactionListener(()=>{const a=I();R(a)&&z(a)}),Q),H=async()=>(E&&(a.delListener(E),E=void 0),Q),q=async(a=!1)=>{const[t,e]=a?[H,k]:[k,H];return await t(),await e(),Q},K=async(...a)=>(h(da(Ja,w),...a),await(async()=>{if(!da(Ba,w)){for(pa(Ba,w,1);!y(d=D(da(Ja,w)));)await f(d,r);pa(Ba,w,0)}})(),Q),Q={load:J,startAutoLoad:Y,stopAutoLoad:k,isAutoLoading:()=>!y(p),save:z,startAutoSave:G,stopAutoSave:H,isAutoSaving:()=>!y(E),startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[G,Y]:[Y,G];return await e(a),await n(a),Q},stopAutoPersisting:q,getStatus:()=>N,addStatusListener:a=>F(a,O),delListener:t=>(j(t),a),schedule:K,getStore:()=>a,destroy:()=>(da(Ja,w).splice(0,void 0),q()),getStats:()=>({loads:m,saves:T}),...c};return na(Q)},ka=(a,t,e,s,r,o=za,c,l)=>{const w=ua();return[async()=>{w.clear(),O(await e(a,t),({tn:a,cn:t})=>Na(va(w,a,Aa),t))},async(t,e,n)=>((a,t)=>I(da(w,a),t))(t,e)?sa(b(O(await a(k+Q(t)+W(t,n)),a=>[a[e],l?ca(ra(a,e),l):ra(a,e)]),([a,t])=>!y(a)&&!ya(t))):{},async(t,e,s,l,u,d=!1,g=i)=>{const p=Aa();ca(s??{},a=>O(ea(a??{}),a=>Na(p,a)));const v=R(p);if(!d&&u&&g==i&&S(v)&&I(w,t))return await a("DROP "+x+Q(t)),void pa(w,t);const E=da(w,t),A=Aa(R(E));if(S(v)||(I(w,t)?await m(O([e,...v],async(n,s)=>{M(A,n)||(await a(B+Q(t)+"ADD"+Q(n)+r),0==s&&await a("CREATE UNIQUE INDEX pk ON "+Q(t)+`(${Q(e)})`),Na(E,n))})):(await a(K+Q(t)+`(${Q(e)}${r} PRIMARY KEY${T(O(v,a=>n+Q(a)+r))});`),pa(w,t,Aa([e,...v])))),await m([...!d&&l?O(R(A),async n=>{n!=e&&(await a(B+Q(t)+"DROP"+Q(n)),M(E,n))}):[]]),d)y(s)?await a(Y+Q(t)+W(t,g)):await m(oa(s,async(n,s)=>{y(n)?await a(Y+Q(t)+W(t,g)+`AND(${Q(e)}=$1)`,[s]):S(v)||await o(a,t,e,ea(n),{[s]:c?O(la(n),c):la(n)},E)}));else if(S(v))I(w,t)&&await a(Y+Q(t)+W(t,g));else{const n=b(R(da(w,t)),a=>a!=e),i={},r=[];ca(s??{},(a,t)=>{i[t]=O(n,t=>c?c(a?.[t]):a?.[t]),h(r,t)}),await o(a,t,e,n,i),await a(Y+Q(t)+W(t,g)+`AND${Q(e)}NOT IN(${V(r)})`,r)}},async t=>{let e;return await a("BEGIN"),await f(async()=>e=await t(),s),await a("END"),e}]},za=async(a,t,e,s,i)=>{const r=[1];await a("INSERT INTO"+Q(t)+"("+((...a)=>T(O(a,Q),n))(e,...s)+")VALUES"+T(oa(i,a=>"($"+r[0]+++","+V(a,r)+")"),n)+"ON CONFLICT("+Q(e)+")DO UPDATE SET"+T(O(s,a=>Q(a)+"=excluded."+Q(a)),n),oa(i,(a,t)=>[t,...O(a,a=>a??null)]).flat())},Ga=(a,t,e,n,s,i,r,[o,c,l],w,u,d,g,p,v)=>{const[E,A,N,m]=ka(t,w,u,s,p,v),$=Ya(a,()=>m(async()=>{return await E(),a=(await A(o,c))[_]?.[l]??"null",ja(Ua(a));var a}),a=>m(async()=>{var t;await E(),await N(o,c,{[_]:{[l]:(t=a()??null,Fa(t,(a,t)=>y(t)?"":t))}},!0,!0)}),e,n,s,r,{[g]:()=>d,destroy:async()=>(await $.stopAutoPersisting(),i(),$)},0,d);return $},Ha=(a,t,e,n,s,i,r,[o,c,[l,w,u]],d,g,p,v,E,A,N,$)=>{const[f,C,T,O]=ka(t,d,g,s,E,A,N,$),S=(a,t)=>m(ga(c,async([e,n,s,i,r],o)=>{t&&!(o in a)||await T(e,n,a[o],s,i,t,r)})),h=async(a,t)=>w?await T(u,F,{[_]:a},!0,!0,t):null,D=Ya(a,()=>O(async()=>{await f();const a=await(async()=>sa(b(await m(ga(o,async([a,t,e],n)=>[a,await C(n,t,e)])),a=>!ya(a[1]))))(),t=await(async()=>l?(await C(u,F))[_]:{})();return ya(a)&&y(t)?void 0:[a,t]}),(a,t)=>O(async()=>{if(await f(),y(t)){const[t,e]=a();await S(t),await h(e)}else await S(t[0],!0),await h(t[1],!0)}),e,n,s,r,{[v]:()=>p,destroy:async()=>(await D.stopAutoPersisting(),i(),D)},0,p);return D},qa=(a,n,s,r,o,c,y,u,d,g,v="getDb",A)=>{let N,m,$;const C=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,c),[T,O,S,b]=(a=>{const e=(a=>ia(Pa,p(a)?{[Ca]:a}:a??{}))(a),n=e[Sa];if(e.mode==fa){const a=e[Ca]??t;return[1,n,[a,e[Ta]??F,e[Oa]??$a],Aa(a)]}const{tables:{load:s={},save:r={}}={},values:o={}}=e,c=E(la(ia(Ma,o)),0,wa(Ma)),l=c[2],w=Aa(l),y=Aa(l),u=_a(s,{[ha]:null,[ba]:F,[Ra]:i},ha,a=>I(y,a),a=>Na(w,a)),d=_a(r,{[Da]:null,[ba]:F,[Ia]:0,[La]:0,[Ra]:null},Da,(a,t)=>I(y,t),(a,t)=>Na(w,t));var g;return g=(a,t)=>t[4]??=da(u,t[0])?.[2]??i,P(d,(a,t)=>g(0,a)),[0,n,[u,d,c],w]})(n);return(T?Ga:Ha)(a,C,a=>{let t;return t=setInterval(()=>f(async()=>{const[{d:t,s:e,c:n}]=await C(U+` ${G} d,${H} s,TOTAL_CHANGES() c FROM ${z}${G} JOIN ${z}${H}`);t==N&&e==m&&n==$||(w(N)||a(),N=t,m=e,$=n)}),1e3*O),()=>{N=m=$=null,l(t)}},a=>a(),y,u,d,S,R(b),async(a,t)=>await a(U+` t.name tn,c.name cn FROM ${q}list()t,${q}info(t.name)c ${j} t.schema='main'AND t.type IN('table','view')AND t.name IN(${V(t)})ORDER BY t.name,c.name`,t),g,v,e,A,a=>(a=>!0===a)(a)?1:(a=>!1===a)(a)?0:a,void 0)},Ka=(a,t,e,n,s)=>qa(a,e,async(a,e=[])=>(await t.executeSql(a,e))[0].rows.raw(),0,0,n,s,N,3,t);export{Ka as createReactNativeSqlitePersister};
1
+ const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),i="true",r=(a,t,e)=>a.replace(t,e),o=Promise,c=a=>(t,e,n)=>a(t)?n?.():e(t),l=clearInterval,w=a=>null==a,y=a=>void 0===a,u=a=>null===a,d=c(w),g=c(y),p=t=>a(t)==s,v=a=>Array.isArray(a),E=(a,t,e)=>a.slice(t,e),A=a=>a.length,N=()=>{},m=async a=>o.all(a),$=a=>{throw Error(a)},f=async(a,t,e)=>{try{return await a()}catch(a){t?.(a)}},C=(a,t)=>a.forEach(t),T=(a,t="")=>a.join(t),h=(a,t)=>a.map(t),O=a=>0==A(a),S=(a,t)=>a.filter(t),b=(a,...t)=>a.push(...t),D=a=>a.shift(),I=(a,t)=>a?.has(t)??!1,L=a=>y(a)||0==(a=>a?.size??0)(a),R=a=>[...a?.values()??[]],M=(a,t)=>a?.forEach(t),P=(a,t)=>a?.delete(t),_="_",F="_id",U="SELECT",j="WHERE",x="TABLE",B="ALTER "+x,J="FROM",Y="DELETE "+J,k=U+"*"+J,z="pragma_",G="data_version",H="schema_version",q="pragma_table_",K="CREATE "+x,Q=a=>T(h(((a,t="",e)=>a.split(t,e))(a,"."),a=>`"${r(a,/"/g,'""')}"`),"."),V=(a,t=[1])=>T(h(a,()=>"$"+t[0]++),n),W=(a,t=i)=>j+`(${r(t,"$tableName",Q(a))})`,X=Object,Z=a=>X.getPrototypeOf(a),aa=X.entries,ta=a=>!w(a)&&d(Z(a),a=>a==X.prototype||w(Z(a)),()=>!0),ea=X.keys,na=X.freeze,sa=(a=[])=>X.fromEntries(a),ia=(...a)=>X.assign({},...a),ra=(a,t)=>(delete a[t],a),oa=(a,t)=>h(aa(a),([a,e])=>t(e,a)),ca=(a,t)=>sa(oa(a,(a,e)=>[e,t(a,e)])),la=a=>X.values(a),wa=a=>A(ea(a)),ya=a=>ta(a)&&0==wa(a),ua=Map,da=a=>new ua(a),ga=(a,t)=>a?.get(t),pa=(a,t)=>h([...a?.entries()??[]],([a,e])=>t(e,a)),va=(a,t,e)=>y(e)?(P(a,t),a):a?.set(t,e),Ea=(a,t,e,n)=>(I(a,t)?n?.(ga(a,t)):va(a,t,e()),ga(a,t)),Aa=(a,t,e,n,s=0)=>g((e?Ea:ga)(a,t[s],s>A(t)-2?e:da),i=>{if(s>A(t)-2)return n?.(i)&&va(a,t[s]),i;const r=Aa(i,t,e,n,s+1);return L(i)&&va(a,t[s]),r}),Na=a=>new Set(v(a)||y(a)?a:[a]),ma=(a,t)=>a?.add(t),$a="ColumnName",fa="store",Ca="json",Ta=fa+"TableName",ha=fa+"Id"+$a,Oa=fa+$a,Sa="autoLoadIntervalSeconds",ba="rowId"+$a,Da="tableId",Ia="tableName",La="deleteEmptyColumns",Ra="deleteEmptyTable",Ma="condition",Pa={mode:Ca,[Sa]:1},_a={load:0,save:0,[Ia]:t+"_values"},Fa=(a,t,e,n,s)=>{const i=da();return ca(a,(a,r)=>{const o=E(la(ia(t,p(a)?{[e]:a}:a)),0,wa(t));u(o[0])||n(r,o[0])||(s(r,o[0]),va(i,r,o))}),i},Ua=JSON.stringify,ja=JSON.parse,xa=a=>""===a?void 0:v(a)?h(a,xa):ta(a)?ca(a,xa):a,Ba=/^\d+$/,Ja=da(),Ya=da(),ka=(a,t,n,s,i,r,o,c={},l=0,w=[])=>{let d,p,E,N=0,m=0,T=0;Ea(Ja,w,()=>0),Ea(Ya,w,()=>[]);const h=da(),[O,S,I,R,_]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!ya(a)||!ya(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!ya(a)||!ya(t),t.setContent]:$("Store type not supported by this Persister"))(o,a,l),[F,U,j]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?D(a):null)??e+t++,t=>{Ba.test(t)&&A(a)<1e3&&b(a,t)}]})(),s=da();return[(n,i,r,o=[],c=()=>[])=>{a??=W;const l=t(1);return va(s,l,[n,i,r,o,c]),ma(Aa(i,r??[e],Na),l),l},(t,n,...i)=>C(((a,t=[e])=>{const n=[],s=(a,e)=>e==A(t)?b(n,a):u(t[e])?M(a,a=>s(a,e+1)):C([t[e],null],t=>s(ga(a,t),e+1));return s(a,0),n})(t,n),t=>M(t,t=>ga(s,t)[0](a,...n??[],...i))),a=>g(ga(s,a),([,t,i])=>(Aa(t,i??[e],void 0,t=>(P(t,a),L(t)?1:0)),va(s,a),n(a),i)),t=>g(ga(s,t),([t,,e=[],n,s])=>{const i=(...r)=>{const o=A(r);o==A(e)?t(a,...r,...s(r)):u(e[o])?C(n[o]?.(...r)??[],a=>i(...r,a)):i(...r,e[o])};i()})]})(),x=a=>{a!=N&&(N=a,U(h,void 0,N))},B=t=>{(O&&v(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},J=async()=>{K()&&a.hadMutated?.()&&await G()},Y=async a=>(2!=N&&(x(1),m++,await V(async()=>{await f(async()=>{const e=await t();v(e)?B(e):a?_(a):$("Content is not an array: "+e)},()=>{a&&_(a)}),x(0),await J()})),W),k=async a=>(z(),await Y(a),await f(async()=>p=await s(async(a,t)=>{t||a?2!=N&&(x(1),m++,B(t??a),x(0),await J()):await Y()}),r),W),z=async()=>(p&&(await f(()=>i(p),r),p=void 0),W),G=async a=>(1!=N&&(x(2),T++,await V(async()=>{await f(()=>n(S,a),r),x(0)})),W),H=async()=>(q(),await G(),E=a.addDidFinishTransactionListener(()=>{const a=I();R(a)&&G(a)}),W),q=async()=>(E&&(a.delListener(E),E=void 0),W),K=()=>!y(E),Q=async(a=!1)=>{const[t,e]=a?[q,z]:[z,q];return await t(),await e(),W},V=async(...a)=>(b(ga(Ya,w),...a),await(async()=>{if(!ga(Ja,w)){for(va(Ja,w,1);!y(d=D(ga(Ya,w)));)await f(d,r);va(Ja,w,0)}})(),W),W={load:Y,startAutoLoad:k,stopAutoLoad:z,isAutoLoading:()=>!y(p),save:G,startAutoSave:H,stopAutoSave:q,isAutoSaving:K,startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[H,k]:[k,H];return await e(a),await n(a),W},stopAutoPersisting:Q,getStatus:()=>N,addStatusListener:a=>F(a,h),delListener:t=>(j(t),a),schedule:V,getStore:()=>a,destroy:()=>(ga(Ya,w).splice(0,void 0),Q()),getStats:()=>({loads:m,saves:T}),...c};return na(W)},za=(a,t,e,s,r,o=Ga,c,l)=>{const w=da();return[async()=>{w.clear(),h(await e(a,t),({tn:a,cn:t})=>ma(Ea(w,a,Na),t))},async(t,e,n)=>((a,t)=>I(ga(w,a),t))(t,e)?sa(S(h(await a(k+Q(t)+W(t,n)),a=>[a[e],l?ca(ra(a,e),l):ra(a,e)]),([a,t])=>!y(a)&&!ya(t))):{},async(t,e,s,l,u,d=!1,g=i)=>{const p=Na();ca(s??{},a=>h(ea(a??{}),a=>ma(p,a)));const v=R(p);if(!d&&u&&g==i&&O(v)&&I(w,t))return await a("DROP "+x+Q(t)),void va(w,t);const E=ga(w,t),A=Na(R(E));if(O(v)||(I(w,t)?await m(h([e,...v],async(n,s)=>{P(A,n)||(await a(B+Q(t)+"ADD"+Q(n)+r),0==s&&await a("CREATE UNIQUE INDEX pk ON "+Q(t)+`(${Q(e)})`),ma(E,n))})):(await a(K+Q(t)+`(${Q(e)}${r} PRIMARY KEY${T(h(v,a=>n+Q(a)+r))});`),va(w,t,Na([e,...v])))),await m([...!d&&l?h(R(A),async n=>{n!=e&&(await a(B+Q(t)+"DROP"+Q(n)),P(E,n))}):[]]),d)y(s)?await a(Y+Q(t)+W(t,g)):await m(oa(s,async(n,s)=>{y(n)?await a(Y+Q(t)+W(t,g)+`AND(${Q(e)}=$1)`,[s]):O(v)||await o(a,t,e,ea(n),{[s]:c?h(la(n),c):la(n)},E)}));else if(O(v))I(w,t)&&await a(Y+Q(t)+W(t,g));else{const n=S(R(ga(w,t)),a=>a!=e),i={},r=[];ca(s??{},(a,t)=>{i[t]=h(n,t=>c?c(a?.[t]):a?.[t]),b(r,t)}),await o(a,t,e,n,i),await a(Y+Q(t)+W(t,g)+`AND${Q(e)}NOT IN(${V(r)})`,r)}},async t=>{let e;return await a("BEGIN"),await f(async()=>e=await t(),s),await a("END"),e}]},Ga=async(a,t,e,s,i)=>{const r=[1];await a("INSERT INTO"+Q(t)+"("+((...a)=>T(h(a,Q),n))(e,...s)+")VALUES"+T(oa(i,a=>"($"+r[0]+++","+V(a,r)+")"),n)+"ON CONFLICT("+Q(e)+")DO UPDATE SET"+T(h(s,a=>Q(a)+"=excluded."+Q(a)),n),oa(i,(a,t)=>[t,...h(a,a=>a??null)]).flat())},Ha=(a,t,e,n,s,i,r,[o,c,l],w,u,d,g,p,v)=>{const[E,A,N,m]=za(t,w,u,s,p,v),$=ka(a,()=>m(async()=>{return await E(),a=(await A(o,c))[_]?.[l]??"null",xa(ja(a));var a}),a=>m(async()=>{var t;await E(),await N(o,c,{[_]:{[l]:(t=a()??null,Ua(t,(a,t)=>y(t)?"":t))}},!0,!0)}),e,n,s,r,{[g]:()=>d,destroy:async()=>(await $.stopAutoPersisting(),i(),$)},0,d);return $},qa=(a,t,e,n,s,i,r,[o,c,[l,w,u]],d,g,p,v,E,A,N,$)=>{const[f,C,T,h]=za(t,d,g,s,E,A,N,$),O=(a,t)=>m(pa(c,async([e,n,s,i,r],o)=>{t&&!(o in a)||await T(e,n,a[o],s,i,t,r)})),b=async(a,t)=>w?await T(u,F,{[_]:a},!0,!0,t):null,D=ka(a,()=>h(async()=>{await f();const a=await(async()=>sa(S(await m(pa(o,async([a,t,e],n)=>[a,await C(n,t,e)])),a=>!ya(a[1]))))(),t=await(async()=>l?(await C(u,F))[_]:{})();return ya(a)&&y(t)?void 0:[a,t]}),(a,t)=>h(async()=>{if(await f(),y(t)){const[t,e]=a();await O(t),await b(e)}else await O(t[0],!0),await b(t[1],!0)}),e,n,s,r,{[v]:()=>p,destroy:async()=>(await D.stopAutoPersisting(),i(),D)},0,p);return D},Ka=(a,n,s,r,o,c,y,u,d,g,v="getDb",A)=>{let N,m,$;const C=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,c),[T,h,O,S]=(a=>{const e=(a=>ia(Pa,p(a)?{[Ta]:a}:a??{}))(a),n=e[Sa];if(e.mode==Ca){const a=e[Ta]??t;return[1,n,[a,e[ha]??F,e[Oa]??fa],Na(a)]}const{tables:{load:s={},save:r={}}={},values:o={}}=e,c=E(la(ia(_a,o)),0,wa(_a)),l=c[2],w=Na(l),y=Na(l),u=Fa(s,{[Da]:null,[ba]:F,[Ma]:i},Da,a=>I(y,a),a=>ma(w,a)),d=Fa(r,{[Ia]:null,[ba]:F,[La]:0,[Ra]:0,[Ma]:null},Ia,(a,t)=>I(y,t),(a,t)=>ma(w,t));var g;return g=(a,t)=>t[4]??=ga(u,t[0])?.[2]??i,M(d,(a,t)=>g(0,a)),[0,n,[u,d,c],w]})(n);return(T?Ha:qa)(a,C,a=>{let t;return t=setInterval(()=>f(async()=>{const[{d:t,s:e,c:n}]=await C(U+` ${G} d,${H} s,TOTAL_CHANGES() c FROM ${z}${G} JOIN ${z}${H}`);t==N&&e==m&&n==$||(w(N)||a(),N=t,m=e,$=n)}),1e3*h),()=>{N=m=$=null,l(t)}},a=>a(),y,u,d,O,R(S),async(a,t)=>await a(U+` t.name tn,c.name cn FROM ${q}list()t,${q}info(t.name)c ${j} t.schema='main'AND t.type IN('table','view')AND t.name IN(${V(t)})ORDER BY t.name,c.name`,t),g,v,e,A,a=>(a=>!0===a)(a)?1:(a=>!1===a)(a)?0:a,void 0)},Qa=(a,t,e,n,s)=>Ka(a,e,async(a,e=[])=>(await t.executeSql(a,e))[0].rows.raw(),0,0,n,s,N,3,t);export{Qa as createReactNativeSqlitePersister};
@@ -1 +1 @@
1
- const t=t=>(e,a,n)=>t(e)?n?.():a(e),e=clearInterval,a=t=>null==t,n=t=>void 0===t,s=t=>null===t,r=t(a),o=t(n),i=t=>Array.isArray(t),c=t=>t.length,y=t=>{throw Error(t)},l=async(t,e,a)=>{try{return await t()}catch(t){e?.(t)}},u=(t,e)=>t.forEach(e),d=(t,...e)=>t.push(...e),g=t=>t.shift(),w=Object,h=t=>w.getPrototypeOf(t),p=w.keys,v=w.freeze,f=t=>(t=>!a(t)&&r(h(t),t=>t==w.prototype||a(h(t)),()=>!0))(t)&&0==(t=>c(p(t)))(t),C=JSON.stringify,S=JSON.parse,A=t=>n(t)||0==(t=>t?.size??0)(t),b=(t,e)=>t?.forEach(e),L=(t,e)=>t?.delete(e),M=t=>new Map(t),E=(t,e)=>t?.get(e),T=(t,e,a)=>n(a)?(L(t,e),t):t?.set(e,a),O=(t,e,a,n)=>{var s,r;return s=t,r=e,s?.has(r)?n?.(E(t,e)):T(t,e,a()),E(t,e)},P=(t,e,a,n,s=0)=>o((a?O:E)(t,e[s],s>c(e)-2?a:M),r=>{if(s>c(e)-2)return n?.(r)&&T(t,e[s]),r;const o=P(r,e,a,n,s+1);return A(r)&&T(t,e[s]),o}),m=/^\d+$/,D=t=>new Set(i(t)||n(t)?t:[t]),j=M(),x=M(),z=(t,e,a,r,w,h,p,C={},S=0,z=[])=>{let I,J,N,k=0,F=0,H=0;O(j,z,()=>0),O(x,z,()=>[]);const U=M(),[$,q,B,G,K]=((t=1,e,a)=>1!=t&&e.isMergeable()?[1,e.getMergeableContent,()=>e.getTransactionMergeableChanges(!a),([[t],[e]])=>!f(t)||!f(e),e.setDefaultContent]:2!=t?[0,e.getContent,e.getTransactionChanges,([t,e])=>!f(t)||!f(e),e.setContent]:y("Store type not supported by this Persister"))(p,t,S),[Q,R,V]=(()=>{let t;const[e,a]=(()=>{const t=[];let e=0;return[a=>(a?g(t):null)??""+e++,e=>{m.test(e)&&c(t)<1e3&&d(t,e)}]})(),n=M();return[(a,s,r,o=[],i=()=>[])=>{t??=rt;const c=e(1);var y,l;return T(n,c,[a,s,r,o,i]),y=P(s,r??[""],D),l=c,y?.add(l),c},(e,a,...r)=>u(((t,e=[""])=>{const a=[],n=(t,r)=>r==c(e)?d(a,t):s(e[r])?b(t,t=>n(t,r+1)):u([e[r],null],e=>n(E(t,e),r+1));return n(t,0),a})(e,a),e=>b(e,e=>E(n,e)[0](t,...a??[],...r))),t=>o(E(n,t),([,e,s])=>(P(e,s??[""],void 0,e=>(L(e,t),A(e)?1:0)),T(n,t),a(t),s)),e=>o(E(n,e),([e,,a=[],n,r])=>{const o=(...i)=>{const y=c(i);y==c(a)?e(t,...i,...r(i)):s(a[y])?u(n[y]?.(...i)??[],t=>o(...i,t)):o(...i,a[y])};o()})]})(),W=t=>{t!=k&&(k=t,R(U,void 0,k))},X=e=>{($&&i(e?.[0])?1===e?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===e?.[2]?t.applyChanges:t.setContent)(e)},Y=async t=>(2!=k&&(W(1),F++,await st(async()=>{await l(async()=>{const a=await e();i(a)?X(a):t?K(t):y("Content is not an array: "+a)},()=>{t&&K(t)}),W(0)})),rt),Z=async t=>(_(),await Y(t),await l(async()=>J=await r(async(t,e)=>{e||t?2!=k&&(W(1),F++,X(e??t),W(0)):await Y()}),h),rt),_=async()=>(J&&(await l(()=>w(J),h),J=void 0),rt),tt=async t=>(1!=k&&(W(2),H++,await st(async()=>{await l(()=>a(q,t),h),W(0)})),rt),et=async()=>(at(),await tt(),N=t.addDidFinishTransactionListener(()=>{const t=B();G(t)&&tt(t)}),rt),at=async()=>(N&&(t.delListener(N),N=void 0),rt),nt=async(t=!1)=>{const[e,a]=t?[at,_]:[_,at];return await e(),await a(),rt},st=async(...t)=>(d(E(x,z),...t),await(async()=>{if(!E(j,z)){for(T(j,z,1);!n(I=g(E(x,z)));)await l(I,h);T(j,z,0)}})(),rt),rt={load:Y,startAutoLoad:Z,stopAutoLoad:_,isAutoLoading:()=>!n(J),save:tt,startAutoSave:et,stopAutoSave:at,isAutoSaving:()=>!n(N),startAutoPersisting:async(t,e=!1)=>{const[a,n]=e?[et,Z]:[Z,et];return await a(t),await n(t),rt},stopAutoPersisting:nt,getStatus:()=>k,addStatusListener:t=>Q(t,U),delListener:e=>(V(e),t),schedule:st,getStore:()=>t,destroy:()=>(E(x,z).splice(0,void 0),nt()),getStats:()=>({loads:F,saves:H}),...C};return v(rt)},I=t=>t.headers.get("ETag"),J=(t,a,n,r=5,o)=>{let i;return z(t,async()=>{const t=await fetch(a);return i=I(t),S(await t.text())},async t=>{return await fetch(n,{method:"POST",headers:{"Content-Type":"application/json"},body:(e=t(),C(e,(t,e)=>e instanceof Map?w.fromEntries([...e]):e))});var e},t=>setInterval(async()=>{const e=await fetch(a,{method:"HEAD"}),n=I(e);s(i)||s(n)||n==i||(i=n,t())},1e3*r),t=>e(t),o,1,{getUrls:()=>[a,n]})};export{J as createRemotePersister};
1
+ const t=t=>(a,e,n)=>t(a)?n?.():e(a),a=clearInterval,e=t=>null==t,n=t=>void 0===t,s=t=>null===t,r=t(e),o=t(n),i=t=>Array.isArray(t),c=t=>t.length,y=t=>{throw Error(t)},l=async(t,a,e)=>{try{return await t()}catch(t){a?.(t)}},u=(t,a)=>t.forEach(a),d=(t,...a)=>t.push(...a),w=t=>t.shift(),g=Object,h=t=>g.getPrototypeOf(t),p=g.keys,v=g.freeze,f=t=>(t=>!e(t)&&r(h(t),t=>t==g.prototype||e(h(t)),()=>!0))(t)&&0==(t=>c(p(t)))(t),C=JSON.stringify,S=JSON.parse,A=t=>n(t)||0==(t=>t?.size??0)(t),b=(t,a)=>t?.forEach(a),M=(t,a)=>t?.delete(a),L=Map,E=t=>new L(t),T=(t,a)=>t?.get(a),O=(t,a,e)=>n(e)?(M(t,a),t):t?.set(a,e),P=(t,a,e,n)=>{var s,r;return s=t,r=a,s?.has(r)?n?.(T(t,a)):O(t,a,e()),T(t,a)},m=(t,a,e,n,s=0)=>o((e?P:T)(t,a[s],s>c(a)-2?e:E),r=>{if(s>c(a)-2)return n?.(r)&&O(t,a[s]),r;const o=m(r,a,e,n,s+1);return A(r)&&O(t,a[s]),o}),D=/^\d+$/,j=t=>new Set(i(t)||n(t)?t:[t]),x=E(),z=E(),I=(t,a,e,r,g,h,p,C={},S=0,L=[])=>{let I,J,N,k=0,F=0,H=0;P(x,L,()=>0),P(z,L,()=>[]);const U=E(),[$,q,B,G,K]=((t=1,a,e)=>1!=t&&a.isMergeable()?[1,a.getMergeableContent,()=>a.getTransactionMergeableChanges(!e),([[t],[a]])=>!f(t)||!f(a),a.setDefaultContent]:2!=t?[0,a.getContent,a.getTransactionChanges,([t,a])=>!f(t)||!f(a),a.setContent]:y("Store type not supported by this Persister"))(p,t,S),[Q,R,V]=(()=>{let t;const[a,e]=(()=>{const t=[];let a=0;return[e=>(e?w(t):null)??""+a++,a=>{D.test(a)&&c(t)<1e3&&d(t,a)}]})(),n=E();return[(e,s,r,o=[],i=()=>[])=>{t??=it;const c=a(1);var y,l;return O(n,c,[e,s,r,o,i]),y=m(s,r??[""],j),l=c,y?.add(l),c},(a,e,...r)=>u(((t,a=[""])=>{const e=[],n=(t,r)=>r==c(a)?d(e,t):s(a[r])?b(t,t=>n(t,r+1)):u([a[r],null],a=>n(T(t,a),r+1));return n(t,0),e})(a,e),a=>b(a,a=>T(n,a)[0](t,...e??[],...r))),t=>o(T(n,t),([,a,s])=>(m(a,s??[""],void 0,a=>(M(a,t),A(a)?1:0)),O(n,t),e(t),s)),a=>o(T(n,a),([a,,e=[],n,r])=>{const o=(...i)=>{const y=c(i);y==c(e)?a(t,...i,...r(i)):s(e[y])?u(n[y]?.(...i)??[],t=>o(...i,t)):o(...i,e[y])};o()})]})(),W=t=>{t!=k&&(k=t,R(U,void 0,k))},X=a=>{($&&i(a?.[0])?1===a?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===a?.[2]?t.applyChanges:t.setContent)(a)},Y=async()=>{st()&&t.hadMutated?.()&&await at()},Z=async t=>(2!=k&&(W(1),F++,await ot(async()=>{await l(async()=>{const e=await a();i(e)?X(e):t?K(t):y("Content is not an array: "+e)},()=>{t&&K(t)}),W(0),await Y()})),it),_=async t=>(tt(),await Z(t),await l(async()=>J=await r(async(t,a)=>{a||t?2!=k&&(W(1),F++,X(a??t),W(0),await Y()):await Z()}),h),it),tt=async()=>(J&&(await l(()=>g(J),h),J=void 0),it),at=async t=>(1!=k&&(W(2),H++,await ot(async()=>{await l(()=>e(q,t),h),W(0)})),it),et=async()=>(nt(),await at(),N=t.addDidFinishTransactionListener(()=>{const t=B();G(t)&&at(t)}),it),nt=async()=>(N&&(t.delListener(N),N=void 0),it),st=()=>!n(N),rt=async(t=!1)=>{const[a,e]=t?[nt,tt]:[tt,nt];return await a(),await e(),it},ot=async(...t)=>(d(T(z,L),...t),await(async()=>{if(!T(x,L)){for(O(x,L,1);!n(I=w(T(z,L)));)await l(I,h);O(x,L,0)}})(),it),it={load:Z,startAutoLoad:_,stopAutoLoad:tt,isAutoLoading:()=>!n(J),save:at,startAutoSave:et,stopAutoSave:nt,isAutoSaving:st,startAutoPersisting:async(t,a=!1)=>{const[e,n]=a?[et,_]:[_,et];return await e(t),await n(t),it},stopAutoPersisting:rt,getStatus:()=>k,addStatusListener:t=>Q(t,U),delListener:a=>(V(a),t),schedule:ot,getStore:()=>t,destroy:()=>(T(z,L).splice(0,void 0),rt()),getStats:()=>({loads:F,saves:H}),...C};return v(it)},J=t=>t.headers.get("ETag"),N=(t,e,n,r=5,o)=>{let i;return I(t,async()=>{const t=await fetch(e);return i=J(t),S(await t.text())},async t=>{return await fetch(n,{method:"POST",headers:{"Content-Type":"application/json"},body:(a=t(),C(a,(t,a)=>a instanceof Map?g.fromEntries([...a]):a))});var a},t=>setInterval(async()=>{const a=await fetch(e,{method:"HEAD"}),n=J(a);s(i)||s(n)||n==i||(i=n,t())},1e3*r),t=>a(t),o,1,{getUrls:()=>[e,n]})};export{N as createRemotePersister};
@@ -1 +1 @@
1
- const t=t=>(e,a,n)=>t(e)?n?.():a(e),e=clearInterval,a=t=>null==t,n=t=>void 0===t,s=t=>null===t,r=t(a),o=t(n),i=t=>Array.isArray(t),c=t=>t.length,y=t=>{throw Error(t)},l=async(t,e,a)=>{try{return await t()}catch(t){e?.(t)}},u=(t,e)=>t.forEach(e),d=(t,...e)=>t.push(...e),g=t=>t.shift(),w=Object,h=t=>w.getPrototypeOf(t),p=w.keys,v=w.freeze,f=t=>(t=>!a(t)&&r(h(t),t=>t==w.prototype||a(h(t)),()=>!0))(t)&&0==(t=>c(p(t)))(t),C=JSON.stringify,S=JSON.parse,A=t=>n(t)||0==(t=>t?.size??0)(t),b=(t,e)=>t?.forEach(e),L=(t,e)=>t?.delete(e),M=t=>new Map(t),E=(t,e)=>t?.get(e),T=(t,e,a)=>n(a)?(L(t,e),t):t?.set(e,a),O=(t,e,a,n)=>{var s,r;return s=t,r=e,s?.has(r)?n?.(E(t,e)):T(t,e,a()),E(t,e)},P=(t,e,a,n,s=0)=>o((a?O:E)(t,e[s],s>c(e)-2?a:M),r=>{if(s>c(e)-2)return n?.(r)&&T(t,e[s]),r;const o=P(r,e,a,n,s+1);return A(r)&&T(t,e[s]),o}),m=/^\d+$/,D=t=>new Set(i(t)||n(t)?t:[t]),j=M(),x=M(),z=(t,e,a,r,w,h,p,C={},S=0,z=[])=>{let I,J,N,k=0,F=0,H=0;O(j,z,()=>0),O(x,z,()=>[]);const U=M(),[$,q,B,G,K]=((t=1,e,a)=>1!=t&&e.isMergeable()?[1,e.getMergeableContent,()=>e.getTransactionMergeableChanges(!a),([[t],[e]])=>!f(t)||!f(e),e.setDefaultContent]:2!=t?[0,e.getContent,e.getTransactionChanges,([t,e])=>!f(t)||!f(e),e.setContent]:y("Store type not supported by this Persister"))(p,t,S),[Q,R,V]=(()=>{let t;const[e,a]=(()=>{const t=[];let e=0;return[a=>(a?g(t):null)??""+e++,e=>{m.test(e)&&c(t)<1e3&&d(t,e)}]})(),n=M();return[(a,s,r,o=[],i=()=>[])=>{t??=rt;const c=e(1);var y,l;return T(n,c,[a,s,r,o,i]),y=P(s,r??[""],D),l=c,y?.add(l),c},(e,a,...r)=>u(((t,e=[""])=>{const a=[],n=(t,r)=>r==c(e)?d(a,t):s(e[r])?b(t,t=>n(t,r+1)):u([e[r],null],e=>n(E(t,e),r+1));return n(t,0),a})(e,a),e=>b(e,e=>E(n,e)[0](t,...a??[],...r))),t=>o(E(n,t),([,e,s])=>(P(e,s??[""],void 0,e=>(L(e,t),A(e)?1:0)),T(n,t),a(t),s)),e=>o(E(n,e),([e,,a=[],n,r])=>{const o=(...i)=>{const y=c(i);y==c(a)?e(t,...i,...r(i)):s(a[y])?u(n[y]?.(...i)??[],t=>o(...i,t)):o(...i,a[y])};o()})]})(),W=t=>{t!=k&&(k=t,R(U,void 0,k))},X=e=>{($&&i(e?.[0])?1===e?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===e?.[2]?t.applyChanges:t.setContent)(e)},Y=async t=>(2!=k&&(W(1),F++,await st(async()=>{await l(async()=>{const a=await e();i(a)?X(a):t?K(t):y("Content is not an array: "+a)},()=>{t&&K(t)}),W(0)})),rt),Z=async t=>(_(),await Y(t),await l(async()=>J=await r(async(t,e)=>{e||t?2!=k&&(W(1),F++,X(e??t),W(0)):await Y()}),h),rt),_=async()=>(J&&(await l(()=>w(J),h),J=void 0),rt),tt=async t=>(1!=k&&(W(2),H++,await st(async()=>{await l(()=>a(q,t),h),W(0)})),rt),et=async()=>(at(),await tt(),N=t.addDidFinishTransactionListener(()=>{const t=B();G(t)&&tt(t)}),rt),at=async()=>(N&&(t.delListener(N),N=void 0),rt),nt=async(t=!1)=>{const[e,a]=t?[at,_]:[_,at];return await e(),await a(),rt},st=async(...t)=>(d(E(x,z),...t),await(async()=>{if(!E(j,z)){for(T(j,z,1);!n(I=g(E(x,z)));)await l(I,h);T(j,z,0)}})(),rt),rt={load:Y,startAutoLoad:Z,stopAutoLoad:_,isAutoLoading:()=>!n(J),save:tt,startAutoSave:et,stopAutoSave:at,isAutoSaving:()=>!n(N),startAutoPersisting:async(t,e=!1)=>{const[a,n]=e?[et,Z]:[Z,et];return await a(t),await n(t),rt},stopAutoPersisting:nt,getStatus:()=>k,addStatusListener:t=>Q(t,U),delListener:e=>(V(e),t),schedule:st,getStore:()=>t,destroy:()=>(E(x,z).splice(0,void 0),nt()),getStats:()=>({loads:F,saves:H}),...C};return v(rt)},I=t=>t.headers.get("ETag"),J=(t,a,n,r=5,o)=>{let i;return z(t,async()=>{const t=await fetch(a);return i=I(t),S(await t.text())},async t=>{return await fetch(n,{method:"POST",headers:{"Content-Type":"application/json"},body:(e=t(),C(e,(t,e)=>e instanceof Map?w.fromEntries([...e]):e))});var e},t=>setInterval(async()=>{const e=await fetch(a,{method:"HEAD"}),n=I(e);s(i)||s(n)||n==i||(i=n,t())},1e3*r),t=>e(t),o,1,{getUrls:()=>[a,n]})};export{J as createRemotePersister};
1
+ const t=t=>(a,e,n)=>t(a)?n?.():e(a),a=clearInterval,e=t=>null==t,n=t=>void 0===t,s=t=>null===t,r=t(e),o=t(n),i=t=>Array.isArray(t),c=t=>t.length,y=t=>{throw Error(t)},l=async(t,a,e)=>{try{return await t()}catch(t){a?.(t)}},u=(t,a)=>t.forEach(a),d=(t,...a)=>t.push(...a),w=t=>t.shift(),g=Object,h=t=>g.getPrototypeOf(t),p=g.keys,v=g.freeze,f=t=>(t=>!e(t)&&r(h(t),t=>t==g.prototype||e(h(t)),()=>!0))(t)&&0==(t=>c(p(t)))(t),C=JSON.stringify,S=JSON.parse,A=t=>n(t)||0==(t=>t?.size??0)(t),b=(t,a)=>t?.forEach(a),M=(t,a)=>t?.delete(a),L=Map,E=t=>new L(t),T=(t,a)=>t?.get(a),O=(t,a,e)=>n(e)?(M(t,a),t):t?.set(a,e),P=(t,a,e,n)=>{var s,r;return s=t,r=a,s?.has(r)?n?.(T(t,a)):O(t,a,e()),T(t,a)},m=(t,a,e,n,s=0)=>o((e?P:T)(t,a[s],s>c(a)-2?e:E),r=>{if(s>c(a)-2)return n?.(r)&&O(t,a[s]),r;const o=m(r,a,e,n,s+1);return A(r)&&O(t,a[s]),o}),D=/^\d+$/,j=t=>new Set(i(t)||n(t)?t:[t]),x=E(),z=E(),I=(t,a,e,r,g,h,p,C={},S=0,L=[])=>{let I,J,N,k=0,F=0,H=0;P(x,L,()=>0),P(z,L,()=>[]);const U=E(),[$,q,B,G,K]=((t=1,a,e)=>1!=t&&a.isMergeable()?[1,a.getMergeableContent,()=>a.getTransactionMergeableChanges(!e),([[t],[a]])=>!f(t)||!f(a),a.setDefaultContent]:2!=t?[0,a.getContent,a.getTransactionChanges,([t,a])=>!f(t)||!f(a),a.setContent]:y("Store type not supported by this Persister"))(p,t,S),[Q,R,V]=(()=>{let t;const[a,e]=(()=>{const t=[];let a=0;return[e=>(e?w(t):null)??""+a++,a=>{D.test(a)&&c(t)<1e3&&d(t,a)}]})(),n=E();return[(e,s,r,o=[],i=()=>[])=>{t??=it;const c=a(1);var y,l;return O(n,c,[e,s,r,o,i]),y=m(s,r??[""],j),l=c,y?.add(l),c},(a,e,...r)=>u(((t,a=[""])=>{const e=[],n=(t,r)=>r==c(a)?d(e,t):s(a[r])?b(t,t=>n(t,r+1)):u([a[r],null],a=>n(T(t,a),r+1));return n(t,0),e})(a,e),a=>b(a,a=>T(n,a)[0](t,...e??[],...r))),t=>o(T(n,t),([,a,s])=>(m(a,s??[""],void 0,a=>(M(a,t),A(a)?1:0)),O(n,t),e(t),s)),a=>o(T(n,a),([a,,e=[],n,r])=>{const o=(...i)=>{const y=c(i);y==c(e)?a(t,...i,...r(i)):s(e[y])?u(n[y]?.(...i)??[],t=>o(...i,t)):o(...i,e[y])};o()})]})(),W=t=>{t!=k&&(k=t,R(U,void 0,k))},X=a=>{($&&i(a?.[0])?1===a?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===a?.[2]?t.applyChanges:t.setContent)(a)},Y=async()=>{st()&&t.hadMutated?.()&&await at()},Z=async t=>(2!=k&&(W(1),F++,await ot(async()=>{await l(async()=>{const e=await a();i(e)?X(e):t?K(t):y("Content is not an array: "+e)},()=>{t&&K(t)}),W(0),await Y()})),it),_=async t=>(tt(),await Z(t),await l(async()=>J=await r(async(t,a)=>{a||t?2!=k&&(W(1),F++,X(a??t),W(0),await Y()):await Z()}),h),it),tt=async()=>(J&&(await l(()=>g(J),h),J=void 0),it),at=async t=>(1!=k&&(W(2),H++,await ot(async()=>{await l(()=>e(q,t),h),W(0)})),it),et=async()=>(nt(),await at(),N=t.addDidFinishTransactionListener(()=>{const t=B();G(t)&&at(t)}),it),nt=async()=>(N&&(t.delListener(N),N=void 0),it),st=()=>!n(N),rt=async(t=!1)=>{const[a,e]=t?[nt,tt]:[tt,nt];return await a(),await e(),it},ot=async(...t)=>(d(T(z,L),...t),await(async()=>{if(!T(x,L)){for(O(x,L,1);!n(I=w(T(z,L)));)await l(I,h);O(x,L,0)}})(),it),it={load:Z,startAutoLoad:_,stopAutoLoad:tt,isAutoLoading:()=>!n(J),save:at,startAutoSave:et,stopAutoSave:nt,isAutoSaving:st,startAutoPersisting:async(t,a=!1)=>{const[e,n]=a?[et,_]:[_,et];return await e(t),await n(t),it},stopAutoPersisting:rt,getStatus:()=>k,addStatusListener:t=>Q(t,U),delListener:a=>(V(a),t),schedule:ot,getStore:()=>t,destroy:()=>(T(z,L).splice(0,void 0),rt()),getStats:()=>({loads:F,saves:H}),...C};return v(it)},J=t=>t.headers.get("ETag"),N=(t,e,n,r=5,o)=>{let i;return I(t,async()=>{const t=await fetch(e);return i=J(t),S(await t.text())},async t=>{return await fetch(n,{method:"POST",headers:{"Content-Type":"application/json"},body:(a=t(),C(a,(t,a)=>a instanceof Map?g.fromEntries([...a]):a))});var a},t=>setInterval(async()=>{const a=await fetch(e,{method:"HEAD"}),n=J(a);s(i)||s(n)||n==i||(i=n,t())},1e3*r),t=>a(t),o,1,{getUrls:()=>[e,n]})};export{N as createRemotePersister};
@@ -1 +1 @@
1
- const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),i="true",r=(a,t,e)=>a.replace(t,e),o=Promise,c=a=>(t,e,n)=>a(t)?n?.():e(t),l=clearInterval,w=a=>null==a,y=a=>void 0===a,u=a=>null===a,d=c(w),g=c(y),p=t=>a(t)==s,v=a=>Array.isArray(a),E=(a,t,e)=>a.slice(t,e),A=a=>a.length,N=()=>{},m=async a=>o.all(a),$=a=>{throw Error(a)},f=async(a,t,e)=>{try{return await a()}catch(a){t?.(a)}},C=(a,t)=>a.forEach(t),T=(a,t="")=>a.join(t),h=(a,t)=>a.map(t),O=a=>0==A(a),b=(a,t)=>a.filter(t),D=(a,...t)=>a.push(...t),I=a=>a.shift(),S=(a,t)=>a?.has(t)??!1,L=a=>y(a)||0==(a=>a?.size??0)(a),R=a=>[...a?.values()??[]],P=(a,t)=>a?.forEach(t),M=(a,t)=>a?.delete(t),_="_",F="_id",U="SELECT",j="WHERE",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=>T(h(((a,t="",e)=>a.split(t,e))(a,"."),a=>`"${r(a,/"/g,'""')}"`),"."),V=(a,t=[1])=>T(h(a,()=>"$"+t[0]++),n),W=(a,t=i)=>j+`(${r(t,"$tableName",Q(a))})`,X=Object,Z=a=>X.getPrototypeOf(a),aa=X.entries,ta=a=>!w(a)&&d(Z(a),a=>a==X.prototype||w(Z(a)),()=>!0),ea=X.keys,na=X.freeze,sa=(a=[])=>X.fromEntries(a),ia=(...a)=>X.assign({},...a),ra=(a,t)=>(delete a[t],a),oa=(a,t)=>h(aa(a),([a,e])=>t(e,a)),ca=(a,t)=>sa(oa(a,(a,e)=>[e,t(a,e)])),la=a=>X.values(a),wa=a=>A(ea(a)),ya=a=>ta(a)&&0==wa(a),ua=a=>new Map(a),da=(a,t)=>a?.get(t),ga=(a,t)=>h([...a?.entries()??[]],([a,e])=>t(e,a)),pa=(a,t,e)=>y(e)?(M(a,t),a):a?.set(t,e),va=(a,t,e,n)=>(S(a,t)?n?.(da(a,t)):pa(a,t,e()),da(a,t)),Ea=(a,t,e,n,s=0)=>g((e?va:da)(a,t[s],s>A(t)-2?e:ua),i=>{if(s>A(t)-2)return n?.(i)&&pa(a,t[s]),i;const r=Ea(i,t,e,n,s+1);return L(i)&&pa(a,t[s]),r}),Aa=a=>new Set(v(a)||y(a)?a:[a]),Na=(a,t)=>a?.add(t),ma="ColumnName",$a="store",fa="json",Ca=$a+"TableName",Ta=$a+"Id"+ma,ha=$a+ma,Oa="autoLoadIntervalSeconds",ba="rowId"+ma,Da="tableId",Ia="tableName",Sa="deleteEmptyColumns",La="deleteEmptyTable",Ra="condition",Pa={mode:fa,[Oa]:1},Ma={load:0,save:0,[Ia]:t+"_values"},_a=(a,t,e,n,s)=>{const i=ua();return ca(a,(a,r)=>{const o=E(la(ia(t,p(a)?{[e]:a}:a)),0,wa(t));u(o[0])||n(r,o[0])||(s(r,o[0]),pa(i,r,o))}),i},Fa=JSON.stringify,Ua=JSON.parse,ja=a=>""===a?void 0:v(a)?h(a,ja):ta(a)?ca(a,ja):a,Ba=/^\d+$/,Ja=ua(),Ya=ua(),ka=(a,t,n,s,i,r,o,c={},l=0,w=[])=>{let d,p,E,N=0,m=0,T=0;va(Ja,w,()=>0),va(Ya,w,()=>[]);const h=ua(),[O,b,S,R,_]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!ya(a)||!ya(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!ya(a)||!ya(t),t.setContent]:$("Store type not supported by this Persister"))(o,a,l),[F,U,j]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?I(a):null)??e+t++,t=>{Ba.test(t)&&A(a)<1e3&&D(a,t)}]})(),s=ua();return[(n,i,r,o=[],c=()=>[])=>{a??=Q;const l=t(1);return pa(s,l,[n,i,r,o,c]),Na(Ea(i,r??[e],Aa),l),l},(t,n,...i)=>C(((a,t=[e])=>{const n=[],s=(a,e)=>e==A(t)?D(n,a):u(t[e])?P(a,a=>s(a,e+1)):C([t[e],null],t=>s(da(a,t),e+1));return s(a,0),n})(t,n),t=>P(t,t=>da(s,t)[0](a,...n??[],...i))),a=>g(da(s,a),([,t,i])=>(Ea(t,i??[e],void 0,t=>(M(t,a),L(t)?1:0)),pa(s,a),n(a),i)),t=>g(da(s,t),([t,,e=[],n,s])=>{const i=(...r)=>{const o=A(r);o==A(e)?t(a,...r,...s(r)):u(e[o])?C(n[o]?.(...r)??[],a=>i(...r,a)):i(...r,e[o])};i()})]})(),B=a=>{a!=N&&(N=a,U(h,void 0,N))},J=t=>{(O&&v(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},Y=async a=>(2!=N&&(B(1),m++,await K(async()=>{await f(async()=>{const e=await t();v(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()=>p=await s(async(a,t)=>{t||a?2!=N&&(B(1),m++,J(t??a),B(0)):await Y()}),r),Q),x=async()=>(p&&(await f(()=>i(p),r),p=void 0),Q),z=async a=>(1!=N&&(B(2),T++,await K(async()=>{await f(()=>n(b,a),r),B(0)})),Q),G=async()=>(H(),await z(),E=a.addDidFinishTransactionListener(()=>{const a=S();R(a)&&z(a)}),Q),H=async()=>(E&&(a.delListener(E),E=void 0),Q),q=async(a=!1)=>{const[t,e]=a?[H,x]:[x,H];return await t(),await e(),Q},K=async(...a)=>(D(da(Ya,w),...a),await(async()=>{if(!da(Ja,w)){for(pa(Ja,w,1);!y(d=I(da(Ya,w)));)await f(d,r);pa(Ja,w,0)}})(),Q),Q={load:Y,startAutoLoad:k,stopAutoLoad:x,isAutoLoading:()=>!y(p),save:z,startAutoSave:G,stopAutoSave:H,isAutoSaving:()=>!y(E),startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[G,k]:[k,G];return await e(a),await n(a),Q},stopAutoPersisting:q,getStatus:()=>N,addStatusListener:a=>F(a,h),delListener:t=>(j(t),a),schedule:K,getStore:()=>a,destroy:()=>(da(Ya,w).splice(0,void 0),q()),getStats:()=>({loads:m,saves:T}),...c};return na(Q)},xa=(a,t,e,s,r,o=za,c,l)=>{const w=ua();return[async()=>{w.clear(),h(await e(a,t),({tn:a,cn:t})=>Na(va(w,a,Aa),t))},async(t,e,n)=>((a,t)=>S(da(w,a),t))(t,e)?sa(b(h(await a(x+Q(t)+W(t,n)),a=>[a[e],l?ca(ra(a,e),l):ra(a,e)]),([a,t])=>!y(a)&&!ya(t))):{},async(t,e,s,l,u,d=!1,g=i)=>{const p=Aa();ca(s??{},a=>h(ea(a??{}),a=>Na(p,a)));const v=R(p);if(!d&&u&&g==i&&O(v)&&S(w,t))return await a("DROP "+B+Q(t)),void pa(w,t);const E=da(w,t),A=Aa(R(E));if(O(v)||(S(w,t)?await m(h([e,...v],async(n,s)=>{M(A,n)||(await a(J+Q(t)+"ADD"+Q(n)+r),0==s&&await a("CREATE UNIQUE INDEX pk ON "+Q(t)+`(${Q(e)})`),Na(E,n))})):(await a(K+Q(t)+`(${Q(e)}${r} PRIMARY KEY${T(h(v,a=>n+Q(a)+r))});`),pa(w,t,Aa([e,...v])))),await m([...!d&&l?h(R(A),async n=>{n!=e&&(await a(J+Q(t)+"DROP"+Q(n)),M(E,n))}):[]]),d)y(s)?await a(k+Q(t)+W(t,g)):await m(oa(s,async(n,s)=>{y(n)?await a(k+Q(t)+W(t,g)+`AND(${Q(e)}=$1)`,[s]):O(v)||await o(a,t,e,ea(n),{[s]:c?h(la(n),c):la(n)},E)}));else if(O(v))S(w,t)&&await a(k+Q(t)+W(t,g));else{const n=b(R(da(w,t)),a=>a!=e),i={},r=[];ca(s??{},(a,t)=>{i[t]=h(n,t=>c?c(a?.[t]):a?.[t]),D(r,t)}),await o(a,t,e,n,i),await a(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}]},za=async(a,t,e,s,i)=>{const r=[1];await a("INSERT INTO"+Q(t)+"("+((...a)=>T(h(a,Q),n))(e,...s)+")VALUES"+T(oa(i,a=>"($"+r[0]+++","+V(a,r)+")"),n)+"ON CONFLICT("+Q(e)+")DO UPDATE SET"+T(h(s,a=>Q(a)+"=excluded."+Q(a)),n),oa(i,(a,t)=>[t,...h(a,a=>a??null)]).flat())},Ga=(a,t,e,n,s,i,r,[o,c,l],w,u,d,g,p,v)=>{const[E,A,N,m]=xa(t,w,u,s,p,v),$=ka(a,()=>m(async()=>{return await E(),a=(await A(o,c))[_]?.[l]??"null",ja(Ua(a));var a}),a=>m(async()=>{var t;await E(),await N(o,c,{[_]:{[l]:(t=a()??null,Fa(t,(a,t)=>y(t)?"":t))}},!0,!0)}),e,n,s,r,{[g]:()=>d,destroy:async()=>(await $.stopAutoPersisting(),i(),$)},0,d);return $},Ha=(a,t,e,n,s,i,r,[o,c,[l,w,u]],d,g,p,v,E,A,N,$)=>{const[f,C,T,h]=xa(t,d,g,s,E,A,N,$),O=(a,t)=>m(ga(c,async([e,n,s,i,r],o)=>{t&&!(o in a)||await T(e,n,a[o],s,i,t,r)})),D=async(a,t)=>w?await T(u,F,{[_]:a},!0,!0,t):null,I=ka(a,()=>h(async()=>{await f();const a=await(async()=>sa(b(await m(ga(o,async([a,t,e],n)=>[a,await C(n,t,e)])),a=>!ya(a[1]))))(),t=await(async()=>l?(await C(u,F))[_]:{})();return ya(a)&&y(t)?void 0:[a,t]}),(a,t)=>h(async()=>{if(await f(),y(t)){const[t,e]=a();await O(t),await D(e)}else await O(t[0],!0),await D(t[1],!0)}),e,n,s,r,{[v]:()=>p,destroy:async()=>(await I.stopAutoPersisting(),i(),I)},0,p);return I},qa=(a,n,s,r,o,c,y,u,d,g,v="getDb",A)=>{let N,m,$;const C=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,c),[T,h,O,b]=(a=>{const e=(a=>ia(Pa,p(a)?{[Ca]:a}:a??{}))(a),n=e[Oa];if(e.mode==fa){const a=e[Ca]??t;return[1,n,[a,e[Ta]??F,e[ha]??$a],Aa(a)]}const{tables:{load:s={},save:r={}}={},values:o={}}=e,c=E(la(ia(Ma,o)),0,wa(Ma)),l=c[2],w=Aa(l),y=Aa(l),u=_a(s,{[Da]:null,[ba]:F,[Ra]:i},Da,a=>S(y,a),a=>Na(w,a)),d=_a(r,{[Ia]:null,[ba]:F,[Sa]:0,[La]:0,[Ra]:null},Ia,(a,t)=>S(y,t),(a,t)=>Na(w,t));var g;return g=(a,t)=>t[4]??=da(u,t[0])?.[2]??i,P(d,(a,t)=>g(0,a)),[0,n,[u,d,c],w]})(n);return(T?Ga:Ha)(a,C,a=>{let t;const e=()=>t=setInterval(()=>f(async()=>{const[{d:t,s:e,c:n}]=await C(U+` ${G} d,${H} s,TOTAL_CHANGES() c FROM ${z}${G} JOIN ${z}${H}`);t==N&&e==m&&n==$||(w(N)||a(),N=t,m=e,$=n)}),1e3*h),n=()=>{N=m=$=null,l(t)},s=r(t=>{b.has(t)&&(n(),a(),e())});return e(),()=>{n(),o(s)}},a=>a(),y,u,d,O,R(b),async(a,t)=>await a(U+` t.name tn,c.name cn FROM ${q}list()t,${q}info(t.name)c ${j} t.schema='main'AND t.type IN('table','view')AND t.name IN(${V(t)})ORDER BY t.name,c.name`,t),g,v,e,A,a=>(a=>!0===a)(a)?1:(a=>!1===a)(a)?0:a,void 0)},Ka=(a,t,e,n,s)=>qa(a,e,async(a,e=[])=>t.query(a).all(...e),()=>N,a=>a(),n,s,N,3,t);export{Ka as createSqliteBunPersister};
1
+ const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),i="true",r=(a,t,e)=>a.replace(t,e),o=Promise,c=a=>(t,e,n)=>a(t)?n?.():e(t),l=clearInterval,w=a=>null==a,y=a=>void 0===a,u=a=>null===a,d=c(w),g=c(y),p=t=>a(t)==s,v=a=>Array.isArray(a),E=(a,t,e)=>a.slice(t,e),A=a=>a.length,N=()=>{},m=async a=>o.all(a),$=a=>{throw Error(a)},f=async(a,t,e)=>{try{return await a()}catch(a){t?.(a)}},h=(a,t)=>a.forEach(t),C=(a,t="")=>a.join(t),T=(a,t)=>a.map(t),O=a=>0==A(a),b=(a,t)=>a.filter(t),D=(a,...t)=>a.push(...t),I=a=>a.shift(),S=(a,t)=>a?.has(t)??!1,L=a=>y(a)||0==(a=>a?.size??0)(a),R=a=>[...a?.values()??[]],M=(a,t)=>a?.forEach(t),P=(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=a=>!w(a)&&d(Z(a),a=>a==X.prototype||w(Z(a)),()=>!0),ea=X.keys,na=X.freeze,sa=(a=[])=>X.fromEntries(a),ia=(...a)=>X.assign({},...a),ra=(a,t)=>(delete a[t],a),oa=(a,t)=>T(aa(a),([a,e])=>t(e,a)),ca=(a,t)=>sa(oa(a,(a,e)=>[e,t(a,e)])),la=a=>X.values(a),wa=a=>A(ea(a)),ya=a=>ta(a)&&0==wa(a),ua=Map,da=a=>new ua(a),ga=(a,t)=>a?.get(t),pa=(a,t)=>T([...a?.entries()??[]],([a,e])=>t(e,a)),va=(a,t,e)=>y(e)?(P(a,t),a):a?.set(t,e),Ea=(a,t,e,n)=>(S(a,t)?n?.(ga(a,t)):va(a,t,e()),ga(a,t)),Aa=(a,t,e,n,s=0)=>g((e?Ea:ga)(a,t[s],s>A(t)-2?e:da),i=>{if(s>A(t)-2)return n?.(i)&&va(a,t[s]),i;const r=Aa(i,t,e,n,s+1);return L(i)&&va(a,t[s]),r}),Na=a=>new Set(v(a)||y(a)?a:[a]),ma=(a,t)=>a?.add(t),$a="ColumnName",fa="store",ha="json",Ca=fa+"TableName",Ta=fa+"Id"+$a,Oa=fa+$a,ba="autoLoadIntervalSeconds",Da="rowId"+$a,Ia="tableId",Sa="tableName",La="deleteEmptyColumns",Ra="deleteEmptyTable",Ma="condition",Pa={mode:ha,[ba]:1},_a={load:0,save:0,[Sa]:t+"_values"},Fa=(a,t,e,n,s)=>{const i=da();return ca(a,(a,r)=>{const o=E(la(ia(t,p(a)?{[e]:a}:a)),0,wa(t));u(o[0])||n(r,o[0])||(s(r,o[0]),va(i,r,o))}),i},Ua=JSON.stringify,ja=JSON.parse,Ba=a=>""===a?void 0:v(a)?T(a,Ba):ta(a)?ca(a,Ba):a,Ja=/^\d+$/,Ya=da(),ka=da(),xa=(a,t,n,s,i,r,o,c={},l=0,w=[])=>{let d,p,E,N=0,m=0,C=0;Ea(Ya,w,()=>0),Ea(ka,w,()=>[]);const T=da(),[O,b,S,R,_]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!ya(a)||!ya(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!ya(a)||!ya(t),t.setContent]:$("Store type not supported by this Persister"))(o,a,l),[F,U,j]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?I(a):null)??e+t++,t=>{Ja.test(t)&&A(a)<1e3&&D(a,t)}]})(),s=da();return[(n,i,r,o=[],c=()=>[])=>{a??=W;const l=t(1);return va(s,l,[n,i,r,o,c]),ma(Aa(i,r??[e],Na),l),l},(t,n,...i)=>h(((a,t=[e])=>{const n=[],s=(a,e)=>e==A(t)?D(n,a):u(t[e])?M(a,a=>s(a,e+1)):h([t[e],null],t=>s(ga(a,t),e+1));return s(a,0),n})(t,n),t=>M(t,t=>ga(s,t)[0](a,...n??[],...i))),a=>g(ga(s,a),([,t,i])=>(Aa(t,i??[e],void 0,t=>(P(t,a),L(t)?1:0)),va(s,a),n(a),i)),t=>g(ga(s,t),([t,,e=[],n,s])=>{const i=(...r)=>{const o=A(r);o==A(e)?t(a,...r,...s(r)):u(e[o])?h(n[o]?.(...r)??[],a=>i(...r,a)):i(...r,e[o])};i()})]})(),B=a=>{a!=N&&(N=a,U(T,void 0,N))},J=t=>{(O&&v(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},Y=async()=>{K()&&a.hadMutated?.()&&await G()},k=async a=>(2!=N&&(B(1),m++,await V(async()=>{await f(async()=>{const e=await t();v(e)?J(e):a?_(a):$("Content is not an array: "+e)},()=>{a&&_(a)}),B(0),await Y()})),W),x=async a=>(z(),await k(a),await f(async()=>p=await s(async(a,t)=>{t||a?2!=N&&(B(1),m++,J(t??a),B(0),await Y()):await k()}),r),W),z=async()=>(p&&(await f(()=>i(p),r),p=void 0),W),G=async a=>(1!=N&&(B(2),C++,await V(async()=>{await f(()=>n(b,a),r),B(0)})),W),H=async()=>(q(),await G(),E=a.addDidFinishTransactionListener(()=>{const a=S();R(a)&&G(a)}),W),q=async()=>(E&&(a.delListener(E),E=void 0),W),K=()=>!y(E),Q=async(a=!1)=>{const[t,e]=a?[q,z]:[z,q];return await t(),await e(),W},V=async(...a)=>(D(ga(ka,w),...a),await(async()=>{if(!ga(Ya,w)){for(va(Ya,w,1);!y(d=I(ga(ka,w)));)await f(d,r);va(Ya,w,0)}})(),W),W={load:k,startAutoLoad:x,stopAutoLoad:z,isAutoLoading:()=>!y(p),save:G,startAutoSave:H,stopAutoSave:q,isAutoSaving:K,startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[H,x]:[x,H];return await e(a),await n(a),W},stopAutoPersisting:Q,getStatus:()=>N,addStatusListener:a=>F(a,T),delListener:t=>(j(t),a),schedule:V,getStore:()=>a,destroy:()=>(ga(ka,w).splice(0,void 0),Q()),getStats:()=>({loads:m,saves:C}),...c};return na(W)},za=(a,t,e,s,r,o=Ga,c,l)=>{const w=da();return[async()=>{w.clear(),T(await e(a,t),({tn:a,cn:t})=>ma(Ea(w,a,Na),t))},async(t,e,n)=>((a,t)=>S(ga(w,a),t))(t,e)?sa(b(T(await a(x+Q(t)+W(t,n)),a=>[a[e],l?ca(ra(a,e),l):ra(a,e)]),([a,t])=>!y(a)&&!ya(t))):{},async(t,e,s,l,u,d=!1,g=i)=>{const p=Na();ca(s??{},a=>T(ea(a??{}),a=>ma(p,a)));const v=R(p);if(!d&&u&&g==i&&O(v)&&S(w,t))return await a("DROP "+B+Q(t)),void va(w,t);const E=ga(w,t),A=Na(R(E));if(O(v)||(S(w,t)?await m(T([e,...v],async(n,s)=>{P(A,n)||(await a(J+Q(t)+"ADD"+Q(n)+r),0==s&&await a("CREATE UNIQUE INDEX pk ON "+Q(t)+`(${Q(e)})`),ma(E,n))})):(await a(K+Q(t)+`(${Q(e)}${r} PRIMARY KEY${C(T(v,a=>n+Q(a)+r))});`),va(w,t,Na([e,...v])))),await m([...!d&&l?T(R(A),async n=>{n!=e&&(await a(J+Q(t)+"DROP"+Q(n)),P(E,n))}):[]]),d)y(s)?await a(k+Q(t)+W(t,g)):await m(oa(s,async(n,s)=>{y(n)?await a(k+Q(t)+W(t,g)+`AND(${Q(e)}=$1)`,[s]):O(v)||await o(a,t,e,ea(n),{[s]:c?T(la(n),c):la(n)},E)}));else if(O(v))S(w,t)&&await a(k+Q(t)+W(t,g));else{const n=b(R(ga(w,t)),a=>a!=e),i={},r=[];ca(s??{},(a,t)=>{i[t]=T(n,t=>c?c(a?.[t]):a?.[t]),D(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}]},Ga=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(oa(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),oa(i,(a,t)=>[t,...T(a,a=>a??null)]).flat())},Ha=(a,t,e,n,s,i,r,[o,c,l],w,u,d,g,p,v)=>{const[E,A,N,m]=za(t,w,u,s,p,v),$=xa(a,()=>m(async()=>{return await E(),a=(await A(o,c))[_]?.[l]??"null",Ba(ja(a));var a}),a=>m(async()=>{var t;await E(),await N(o,c,{[_]:{[l]:(t=a()??null,Ua(t,(a,t)=>y(t)?"":t))}},!0,!0)}),e,n,s,r,{[g]:()=>d,destroy:async()=>(await $.stopAutoPersisting(),i(),$)},0,d);return $},qa=(a,t,e,n,s,i,r,[o,c,[l,w,u]],d,g,p,v,E,A,N,$)=>{const[f,h,C,T]=za(t,d,g,s,E,A,N,$),O=(a,t)=>m(pa(c,async([e,n,s,i,r],o)=>{t&&!(o in a)||await C(e,n,a[o],s,i,t,r)})),D=async(a,t)=>w?await C(u,F,{[_]:a},!0,!0,t):null,I=xa(a,()=>T(async()=>{await f();const a=await(async()=>sa(b(await m(pa(o,async([a,t,e],n)=>[a,await h(n,t,e)])),a=>!ya(a[1]))))(),t=await(async()=>l?(await h(u,F))[_]:{})();return ya(a)&&y(t)?void 0:[a,t]}),(a,t)=>T(async()=>{if(await f(),y(t)){const[t,e]=a();await O(t),await D(e)}else await O(t[0],!0),await D(t[1],!0)}),e,n,s,r,{[v]:()=>p,destroy:async()=>(await I.stopAutoPersisting(),i(),I)},0,p);return I},Ka=(a,n,s,r,o,c,y,u,d,g,v="getDb",A)=>{let N,m,$;const h=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,c),[C,T,O,b]=(a=>{const e=(a=>ia(Pa,p(a)?{[Ca]:a}:a??{}))(a),n=e[ba];if(e.mode==ha){const a=e[Ca]??t;return[1,n,[a,e[Ta]??F,e[Oa]??fa],Na(a)]}const{tables:{load:s={},save:r={}}={},values:o={}}=e,c=E(la(ia(_a,o)),0,wa(_a)),l=c[2],w=Na(l),y=Na(l),u=Fa(s,{[Ia]:null,[Da]:F,[Ma]:i},Ia,a=>S(y,a),a=>ma(w,a)),d=Fa(r,{[Sa]:null,[Da]:F,[La]:0,[Ra]:0,[Ma]:null},Sa,(a,t)=>S(y,t),(a,t)=>ma(w,t));var g;return g=(a,t)=>t[4]??=ga(u,t[0])?.[2]??i,M(d,(a,t)=>g(0,a)),[0,n,[u,d,c],w]})(n);return(C?Ha:qa)(a,h,a=>{let t;const e=()=>t=setInterval(()=>f(async()=>{const[{d:t,s:e,c:n}]=await h(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=r(t=>{b.has(t)&&(n(),a(),e())});return e(),()=>{n(),o(s)}},a=>a(),y,u,d,O,R(b),async(a,t)=>await a(U+` t.name tn,c.name cn FROM ${q}list()t,${q}info(t.name)c ${j} t.schema='main'AND t.type IN('table','view')AND t.name IN(${V(t)})ORDER BY t.name,c.name`,t),g,v,e,A,a=>(a=>!0===a)(a)?1:(a=>!1===a)(a)?0:a,void 0)},Qa=(a,t,e,n,s)=>Ka(a,e,async(a,e=[])=>t.query(a).all(...e),()=>N,a=>a(),n,s,N,3,t);export{Qa as createSqliteBunPersister};
@@ -1 +1 @@
1
- const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),i="true",r=(a,t,e)=>a.replace(t,e),o=Promise,c=a=>(t,e,n)=>a(t)?n?.():e(t),l=clearInterval,w=a=>null==a,y=a=>void 0===a,u=a=>null===a,d=c(w),g=c(y),p=t=>a(t)==s,v=a=>Array.isArray(a),E=(a,t,e)=>a.slice(t,e),A=a=>a.length,N=()=>{},m=async a=>o.all(a),$=a=>{throw Error(a)},f=async(a,t,e)=>{try{return await a()}catch(a){t?.(a)}},C=(a,t)=>a.forEach(t),T=(a,t="")=>a.join(t),h=(a,t)=>a.map(t),O=a=>0==A(a),b=(a,t)=>a.filter(t),D=(a,...t)=>a.push(...t),I=a=>a.shift(),S=(a,t)=>a?.has(t)??!1,L=a=>y(a)||0==(a=>a?.size??0)(a),R=a=>[...a?.values()??[]],P=(a,t)=>a?.forEach(t),M=(a,t)=>a?.delete(t),_="_",F="_id",U="SELECT",j="WHERE",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=>T(h(((a,t="",e)=>a.split(t,e))(a,"."),a=>`"${r(a,/"/g,'""')}"`),"."),V=(a,t=[1])=>T(h(a,()=>"$"+t[0]++),n),W=(a,t=i)=>j+`(${r(t,"$tableName",Q(a))})`,X=Object,Z=a=>X.getPrototypeOf(a),aa=X.entries,ta=a=>!w(a)&&d(Z(a),a=>a==X.prototype||w(Z(a)),()=>!0),ea=X.keys,na=X.freeze,sa=(a=[])=>X.fromEntries(a),ia=(...a)=>X.assign({},...a),ra=(a,t)=>(delete a[t],a),oa=(a,t)=>h(aa(a),([a,e])=>t(e,a)),ca=(a,t)=>sa(oa(a,(a,e)=>[e,t(a,e)])),la=a=>X.values(a),wa=a=>A(ea(a)),ya=a=>ta(a)&&0==wa(a),ua=a=>new Map(a),da=(a,t)=>a?.get(t),ga=(a,t)=>h([...a?.entries()??[]],([a,e])=>t(e,a)),pa=(a,t,e)=>y(e)?(M(a,t),a):a?.set(t,e),va=(a,t,e,n)=>(S(a,t)?n?.(da(a,t)):pa(a,t,e()),da(a,t)),Ea=(a,t,e,n,s=0)=>g((e?va:da)(a,t[s],s>A(t)-2?e:ua),i=>{if(s>A(t)-2)return n?.(i)&&pa(a,t[s]),i;const r=Ea(i,t,e,n,s+1);return L(i)&&pa(a,t[s]),r}),Aa=a=>new Set(v(a)||y(a)?a:[a]),Na=(a,t)=>a?.add(t),ma="ColumnName",$a="store",fa="json",Ca=$a+"TableName",Ta=$a+"Id"+ma,ha=$a+ma,Oa="autoLoadIntervalSeconds",ba="rowId"+ma,Da="tableId",Ia="tableName",Sa="deleteEmptyColumns",La="deleteEmptyTable",Ra="condition",Pa={mode:fa,[Oa]:1},Ma={load:0,save:0,[Ia]:t+"_values"},_a=(a,t,e,n,s)=>{const i=ua();return ca(a,(a,r)=>{const o=E(la(ia(t,p(a)?{[e]:a}:a)),0,wa(t));u(o[0])||n(r,o[0])||(s(r,o[0]),pa(i,r,o))}),i},Fa=JSON.stringify,Ua=JSON.parse,ja=a=>""===a?void 0:v(a)?h(a,ja):ta(a)?ca(a,ja):a,Ba=/^\d+$/,Ja=ua(),Ya=ua(),ka=(a,t,n,s,i,r,o,c={},l=0,w=[])=>{let d,p,E,N=0,m=0,T=0;va(Ja,w,()=>0),va(Ya,w,()=>[]);const h=ua(),[O,b,S,R,_]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!ya(a)||!ya(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!ya(a)||!ya(t),t.setContent]:$("Store type not supported by this Persister"))(o,a,l),[F,U,j]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?I(a):null)??e+t++,t=>{Ba.test(t)&&A(a)<1e3&&D(a,t)}]})(),s=ua();return[(n,i,r,o=[],c=()=>[])=>{a??=Q;const l=t(1);return pa(s,l,[n,i,r,o,c]),Na(Ea(i,r??[e],Aa),l),l},(t,n,...i)=>C(((a,t=[e])=>{const n=[],s=(a,e)=>e==A(t)?D(n,a):u(t[e])?P(a,a=>s(a,e+1)):C([t[e],null],t=>s(da(a,t),e+1));return s(a,0),n})(t,n),t=>P(t,t=>da(s,t)[0](a,...n??[],...i))),a=>g(da(s,a),([,t,i])=>(Ea(t,i??[e],void 0,t=>(M(t,a),L(t)?1:0)),pa(s,a),n(a),i)),t=>g(da(s,t),([t,,e=[],n,s])=>{const i=(...r)=>{const o=A(r);o==A(e)?t(a,...r,...s(r)):u(e[o])?C(n[o]?.(...r)??[],a=>i(...r,a)):i(...r,e[o])};i()})]})(),B=a=>{a!=N&&(N=a,U(h,void 0,N))},J=t=>{(O&&v(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},Y=async a=>(2!=N&&(B(1),m++,await K(async()=>{await f(async()=>{const e=await t();v(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()=>p=await s(async(a,t)=>{t||a?2!=N&&(B(1),m++,J(t??a),B(0)):await Y()}),r),Q),x=async()=>(p&&(await f(()=>i(p),r),p=void 0),Q),z=async a=>(1!=N&&(B(2),T++,await K(async()=>{await f(()=>n(b,a),r),B(0)})),Q),G=async()=>(H(),await z(),E=a.addDidFinishTransactionListener(()=>{const a=S();R(a)&&z(a)}),Q),H=async()=>(E&&(a.delListener(E),E=void 0),Q),q=async(a=!1)=>{const[t,e]=a?[H,x]:[x,H];return await t(),await e(),Q},K=async(...a)=>(D(da(Ya,w),...a),await(async()=>{if(!da(Ja,w)){for(pa(Ja,w,1);!y(d=I(da(Ya,w)));)await f(d,r);pa(Ja,w,0)}})(),Q),Q={load:Y,startAutoLoad:k,stopAutoLoad:x,isAutoLoading:()=>!y(p),save:z,startAutoSave:G,stopAutoSave:H,isAutoSaving:()=>!y(E),startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[G,k]:[k,G];return await e(a),await n(a),Q},stopAutoPersisting:q,getStatus:()=>N,addStatusListener:a=>F(a,h),delListener:t=>(j(t),a),schedule:K,getStore:()=>a,destroy:()=>(da(Ya,w).splice(0,void 0),q()),getStats:()=>({loads:m,saves:T}),...c};return na(Q)},xa=(a,t,e,s,r,o=za,c,l)=>{const w=ua();return[async()=>{w.clear(),h(await e(a,t),({tn:a,cn:t})=>Na(va(w,a,Aa),t))},async(t,e,n)=>((a,t)=>S(da(w,a),t))(t,e)?sa(b(h(await a(x+Q(t)+W(t,n)),a=>[a[e],l?ca(ra(a,e),l):ra(a,e)]),([a,t])=>!y(a)&&!ya(t))):{},async(t,e,s,l,u,d=!1,g=i)=>{const p=Aa();ca(s??{},a=>h(ea(a??{}),a=>Na(p,a)));const v=R(p);if(!d&&u&&g==i&&O(v)&&S(w,t))return await a("DROP "+B+Q(t)),void pa(w,t);const E=da(w,t),A=Aa(R(E));if(O(v)||(S(w,t)?await m(h([e,...v],async(n,s)=>{M(A,n)||(await a(J+Q(t)+"ADD"+Q(n)+r),0==s&&await a("CREATE UNIQUE INDEX pk ON "+Q(t)+`(${Q(e)})`),Na(E,n))})):(await a(K+Q(t)+`(${Q(e)}${r} PRIMARY KEY${T(h(v,a=>n+Q(a)+r))});`),pa(w,t,Aa([e,...v])))),await m([...!d&&l?h(R(A),async n=>{n!=e&&(await a(J+Q(t)+"DROP"+Q(n)),M(E,n))}):[]]),d)y(s)?await a(k+Q(t)+W(t,g)):await m(oa(s,async(n,s)=>{y(n)?await a(k+Q(t)+W(t,g)+`AND(${Q(e)}=$1)`,[s]):O(v)||await o(a,t,e,ea(n),{[s]:c?h(la(n),c):la(n)},E)}));else if(O(v))S(w,t)&&await a(k+Q(t)+W(t,g));else{const n=b(R(da(w,t)),a=>a!=e),i={},r=[];ca(s??{},(a,t)=>{i[t]=h(n,t=>c?c(a?.[t]):a?.[t]),D(r,t)}),await o(a,t,e,n,i),await a(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}]},za=async(a,t,e,s,i)=>{const r=[1];await a("INSERT INTO"+Q(t)+"("+((...a)=>T(h(a,Q),n))(e,...s)+")VALUES"+T(oa(i,a=>"($"+r[0]+++","+V(a,r)+")"),n)+"ON CONFLICT("+Q(e)+")DO UPDATE SET"+T(h(s,a=>Q(a)+"=excluded."+Q(a)),n),oa(i,(a,t)=>[t,...h(a,a=>a??null)]).flat())},Ga=(a,t,e,n,s,i,r,[o,c,l],w,u,d,g,p,v)=>{const[E,A,N,m]=xa(t,w,u,s,p,v),$=ka(a,()=>m(async()=>{return await E(),a=(await A(o,c))[_]?.[l]??"null",ja(Ua(a));var a}),a=>m(async()=>{var t;await E(),await N(o,c,{[_]:{[l]:(t=a()??null,Fa(t,(a,t)=>y(t)?"":t))}},!0,!0)}),e,n,s,r,{[g]:()=>d,destroy:async()=>(await $.stopAutoPersisting(),i(),$)},0,d);return $},Ha=(a,t,e,n,s,i,r,[o,c,[l,w,u]],d,g,p,v,E,A,N,$)=>{const[f,C,T,h]=xa(t,d,g,s,E,A,N,$),O=(a,t)=>m(ga(c,async([e,n,s,i,r],o)=>{t&&!(o in a)||await T(e,n,a[o],s,i,t,r)})),D=async(a,t)=>w?await T(u,F,{[_]:a},!0,!0,t):null,I=ka(a,()=>h(async()=>{await f();const a=await(async()=>sa(b(await m(ga(o,async([a,t,e],n)=>[a,await C(n,t,e)])),a=>!ya(a[1]))))(),t=await(async()=>l?(await C(u,F))[_]:{})();return ya(a)&&y(t)?void 0:[a,t]}),(a,t)=>h(async()=>{if(await f(),y(t)){const[t,e]=a();await O(t),await D(e)}else await O(t[0],!0),await D(t[1],!0)}),e,n,s,r,{[v]:()=>p,destroy:async()=>(await I.stopAutoPersisting(),i(),I)},0,p);return I},qa=(a,n,s,r,o,c,y,u,d,g,v="getDb",A)=>{let N,m,$;const C=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,c),[T,h,O,b]=(a=>{const e=(a=>ia(Pa,p(a)?{[Ca]:a}:a??{}))(a),n=e[Oa];if(e.mode==fa){const a=e[Ca]??t;return[1,n,[a,e[Ta]??F,e[ha]??$a],Aa(a)]}const{tables:{load:s={},save:r={}}={},values:o={}}=e,c=E(la(ia(Ma,o)),0,wa(Ma)),l=c[2],w=Aa(l),y=Aa(l),u=_a(s,{[Da]:null,[ba]:F,[Ra]:i},Da,a=>S(y,a),a=>Na(w,a)),d=_a(r,{[Ia]:null,[ba]:F,[Sa]:0,[La]:0,[Ra]:null},Ia,(a,t)=>S(y,t),(a,t)=>Na(w,t));var g;return g=(a,t)=>t[4]??=da(u,t[0])?.[2]??i,P(d,(a,t)=>g(0,a)),[0,n,[u,d,c],w]})(n);return(T?Ga:Ha)(a,C,a=>{let t;const e=()=>t=setInterval(()=>f(async()=>{const[{d:t,s:e,c:n}]=await C(U+` ${G} d,${H} s,TOTAL_CHANGES() c FROM ${z}${G} JOIN ${z}${H}`);t==N&&e==m&&n==$||(w(N)||a(),N=t,m=e,$=n)}),1e3*h),n=()=>{N=m=$=null,l(t)},s=r(t=>{b.has(t)&&(n(),a(),e())});return e(),()=>{n(),o(s)}},a=>a(),y,u,d,O,R(b),async(a,t)=>await a(U+` t.name tn,c.name cn FROM ${q}list()t,${q}info(t.name)c ${j} t.schema='main'AND t.type IN('table','view')AND t.name IN(${V(t)})ORDER BY t.name,c.name`,t),g,v,e,A,a=>(a=>!0===a)(a)?1:(a=>!1===a)(a)?0:a,void 0)},Ka=(a,t,e,n,s)=>qa(a,e,async(a,e=[])=>t.query(a).all(...e),()=>N,a=>a(),n,s,N,3,t);export{Ka as createSqliteBunPersister};
1
+ const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),i="true",r=(a,t,e)=>a.replace(t,e),o=Promise,c=a=>(t,e,n)=>a(t)?n?.():e(t),l=clearInterval,w=a=>null==a,y=a=>void 0===a,u=a=>null===a,d=c(w),g=c(y),p=t=>a(t)==s,v=a=>Array.isArray(a),E=(a,t,e)=>a.slice(t,e),A=a=>a.length,N=()=>{},m=async a=>o.all(a),$=a=>{throw Error(a)},f=async(a,t,e)=>{try{return await a()}catch(a){t?.(a)}},h=(a,t)=>a.forEach(t),C=(a,t="")=>a.join(t),T=(a,t)=>a.map(t),O=a=>0==A(a),b=(a,t)=>a.filter(t),D=(a,...t)=>a.push(...t),I=a=>a.shift(),S=(a,t)=>a?.has(t)??!1,L=a=>y(a)||0==(a=>a?.size??0)(a),R=a=>[...a?.values()??[]],M=(a,t)=>a?.forEach(t),P=(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=a=>!w(a)&&d(Z(a),a=>a==X.prototype||w(Z(a)),()=>!0),ea=X.keys,na=X.freeze,sa=(a=[])=>X.fromEntries(a),ia=(...a)=>X.assign({},...a),ra=(a,t)=>(delete a[t],a),oa=(a,t)=>T(aa(a),([a,e])=>t(e,a)),ca=(a,t)=>sa(oa(a,(a,e)=>[e,t(a,e)])),la=a=>X.values(a),wa=a=>A(ea(a)),ya=a=>ta(a)&&0==wa(a),ua=Map,da=a=>new ua(a),ga=(a,t)=>a?.get(t),pa=(a,t)=>T([...a?.entries()??[]],([a,e])=>t(e,a)),va=(a,t,e)=>y(e)?(P(a,t),a):a?.set(t,e),Ea=(a,t,e,n)=>(S(a,t)?n?.(ga(a,t)):va(a,t,e()),ga(a,t)),Aa=(a,t,e,n,s=0)=>g((e?Ea:ga)(a,t[s],s>A(t)-2?e:da),i=>{if(s>A(t)-2)return n?.(i)&&va(a,t[s]),i;const r=Aa(i,t,e,n,s+1);return L(i)&&va(a,t[s]),r}),Na=a=>new Set(v(a)||y(a)?a:[a]),ma=(a,t)=>a?.add(t),$a="ColumnName",fa="store",ha="json",Ca=fa+"TableName",Ta=fa+"Id"+$a,Oa=fa+$a,ba="autoLoadIntervalSeconds",Da="rowId"+$a,Ia="tableId",Sa="tableName",La="deleteEmptyColumns",Ra="deleteEmptyTable",Ma="condition",Pa={mode:ha,[ba]:1},_a={load:0,save:0,[Sa]:t+"_values"},Fa=(a,t,e,n,s)=>{const i=da();return ca(a,(a,r)=>{const o=E(la(ia(t,p(a)?{[e]:a}:a)),0,wa(t));u(o[0])||n(r,o[0])||(s(r,o[0]),va(i,r,o))}),i},Ua=JSON.stringify,ja=JSON.parse,Ba=a=>""===a?void 0:v(a)?T(a,Ba):ta(a)?ca(a,Ba):a,Ja=/^\d+$/,Ya=da(),ka=da(),xa=(a,t,n,s,i,r,o,c={},l=0,w=[])=>{let d,p,E,N=0,m=0,C=0;Ea(Ya,w,()=>0),Ea(ka,w,()=>[]);const T=da(),[O,b,S,R,_]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!ya(a)||!ya(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!ya(a)||!ya(t),t.setContent]:$("Store type not supported by this Persister"))(o,a,l),[F,U,j]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?I(a):null)??e+t++,t=>{Ja.test(t)&&A(a)<1e3&&D(a,t)}]})(),s=da();return[(n,i,r,o=[],c=()=>[])=>{a??=W;const l=t(1);return va(s,l,[n,i,r,o,c]),ma(Aa(i,r??[e],Na),l),l},(t,n,...i)=>h(((a,t=[e])=>{const n=[],s=(a,e)=>e==A(t)?D(n,a):u(t[e])?M(a,a=>s(a,e+1)):h([t[e],null],t=>s(ga(a,t),e+1));return s(a,0),n})(t,n),t=>M(t,t=>ga(s,t)[0](a,...n??[],...i))),a=>g(ga(s,a),([,t,i])=>(Aa(t,i??[e],void 0,t=>(P(t,a),L(t)?1:0)),va(s,a),n(a),i)),t=>g(ga(s,t),([t,,e=[],n,s])=>{const i=(...r)=>{const o=A(r);o==A(e)?t(a,...r,...s(r)):u(e[o])?h(n[o]?.(...r)??[],a=>i(...r,a)):i(...r,e[o])};i()})]})(),B=a=>{a!=N&&(N=a,U(T,void 0,N))},J=t=>{(O&&v(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},Y=async()=>{K()&&a.hadMutated?.()&&await G()},k=async a=>(2!=N&&(B(1),m++,await V(async()=>{await f(async()=>{const e=await t();v(e)?J(e):a?_(a):$("Content is not an array: "+e)},()=>{a&&_(a)}),B(0),await Y()})),W),x=async a=>(z(),await k(a),await f(async()=>p=await s(async(a,t)=>{t||a?2!=N&&(B(1),m++,J(t??a),B(0),await Y()):await k()}),r),W),z=async()=>(p&&(await f(()=>i(p),r),p=void 0),W),G=async a=>(1!=N&&(B(2),C++,await V(async()=>{await f(()=>n(b,a),r),B(0)})),W),H=async()=>(q(),await G(),E=a.addDidFinishTransactionListener(()=>{const a=S();R(a)&&G(a)}),W),q=async()=>(E&&(a.delListener(E),E=void 0),W),K=()=>!y(E),Q=async(a=!1)=>{const[t,e]=a?[q,z]:[z,q];return await t(),await e(),W},V=async(...a)=>(D(ga(ka,w),...a),await(async()=>{if(!ga(Ya,w)){for(va(Ya,w,1);!y(d=I(ga(ka,w)));)await f(d,r);va(Ya,w,0)}})(),W),W={load:k,startAutoLoad:x,stopAutoLoad:z,isAutoLoading:()=>!y(p),save:G,startAutoSave:H,stopAutoSave:q,isAutoSaving:K,startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[H,x]:[x,H];return await e(a),await n(a),W},stopAutoPersisting:Q,getStatus:()=>N,addStatusListener:a=>F(a,T),delListener:t=>(j(t),a),schedule:V,getStore:()=>a,destroy:()=>(ga(ka,w).splice(0,void 0),Q()),getStats:()=>({loads:m,saves:C}),...c};return na(W)},za=(a,t,e,s,r,o=Ga,c,l)=>{const w=da();return[async()=>{w.clear(),T(await e(a,t),({tn:a,cn:t})=>ma(Ea(w,a,Na),t))},async(t,e,n)=>((a,t)=>S(ga(w,a),t))(t,e)?sa(b(T(await a(x+Q(t)+W(t,n)),a=>[a[e],l?ca(ra(a,e),l):ra(a,e)]),([a,t])=>!y(a)&&!ya(t))):{},async(t,e,s,l,u,d=!1,g=i)=>{const p=Na();ca(s??{},a=>T(ea(a??{}),a=>ma(p,a)));const v=R(p);if(!d&&u&&g==i&&O(v)&&S(w,t))return await a("DROP "+B+Q(t)),void va(w,t);const E=ga(w,t),A=Na(R(E));if(O(v)||(S(w,t)?await m(T([e,...v],async(n,s)=>{P(A,n)||(await a(J+Q(t)+"ADD"+Q(n)+r),0==s&&await a("CREATE UNIQUE INDEX pk ON "+Q(t)+`(${Q(e)})`),ma(E,n))})):(await a(K+Q(t)+`(${Q(e)}${r} PRIMARY KEY${C(T(v,a=>n+Q(a)+r))});`),va(w,t,Na([e,...v])))),await m([...!d&&l?T(R(A),async n=>{n!=e&&(await a(J+Q(t)+"DROP"+Q(n)),P(E,n))}):[]]),d)y(s)?await a(k+Q(t)+W(t,g)):await m(oa(s,async(n,s)=>{y(n)?await a(k+Q(t)+W(t,g)+`AND(${Q(e)}=$1)`,[s]):O(v)||await o(a,t,e,ea(n),{[s]:c?T(la(n),c):la(n)},E)}));else if(O(v))S(w,t)&&await a(k+Q(t)+W(t,g));else{const n=b(R(ga(w,t)),a=>a!=e),i={},r=[];ca(s??{},(a,t)=>{i[t]=T(n,t=>c?c(a?.[t]):a?.[t]),D(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}]},Ga=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(oa(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),oa(i,(a,t)=>[t,...T(a,a=>a??null)]).flat())},Ha=(a,t,e,n,s,i,r,[o,c,l],w,u,d,g,p,v)=>{const[E,A,N,m]=za(t,w,u,s,p,v),$=xa(a,()=>m(async()=>{return await E(),a=(await A(o,c))[_]?.[l]??"null",Ba(ja(a));var a}),a=>m(async()=>{var t;await E(),await N(o,c,{[_]:{[l]:(t=a()??null,Ua(t,(a,t)=>y(t)?"":t))}},!0,!0)}),e,n,s,r,{[g]:()=>d,destroy:async()=>(await $.stopAutoPersisting(),i(),$)},0,d);return $},qa=(a,t,e,n,s,i,r,[o,c,[l,w,u]],d,g,p,v,E,A,N,$)=>{const[f,h,C,T]=za(t,d,g,s,E,A,N,$),O=(a,t)=>m(pa(c,async([e,n,s,i,r],o)=>{t&&!(o in a)||await C(e,n,a[o],s,i,t,r)})),D=async(a,t)=>w?await C(u,F,{[_]:a},!0,!0,t):null,I=xa(a,()=>T(async()=>{await f();const a=await(async()=>sa(b(await m(pa(o,async([a,t,e],n)=>[a,await h(n,t,e)])),a=>!ya(a[1]))))(),t=await(async()=>l?(await h(u,F))[_]:{})();return ya(a)&&y(t)?void 0:[a,t]}),(a,t)=>T(async()=>{if(await f(),y(t)){const[t,e]=a();await O(t),await D(e)}else await O(t[0],!0),await D(t[1],!0)}),e,n,s,r,{[v]:()=>p,destroy:async()=>(await I.stopAutoPersisting(),i(),I)},0,p);return I},Ka=(a,n,s,r,o,c,y,u,d,g,v="getDb",A)=>{let N,m,$;const h=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,c),[C,T,O,b]=(a=>{const e=(a=>ia(Pa,p(a)?{[Ca]:a}:a??{}))(a),n=e[ba];if(e.mode==ha){const a=e[Ca]??t;return[1,n,[a,e[Ta]??F,e[Oa]??fa],Na(a)]}const{tables:{load:s={},save:r={}}={},values:o={}}=e,c=E(la(ia(_a,o)),0,wa(_a)),l=c[2],w=Na(l),y=Na(l),u=Fa(s,{[Ia]:null,[Da]:F,[Ma]:i},Ia,a=>S(y,a),a=>ma(w,a)),d=Fa(r,{[Sa]:null,[Da]:F,[La]:0,[Ra]:0,[Ma]:null},Sa,(a,t)=>S(y,t),(a,t)=>ma(w,t));var g;return g=(a,t)=>t[4]??=ga(u,t[0])?.[2]??i,M(d,(a,t)=>g(0,a)),[0,n,[u,d,c],w]})(n);return(C?Ha:qa)(a,h,a=>{let t;const e=()=>t=setInterval(()=>f(async()=>{const[{d:t,s:e,c:n}]=await h(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=r(t=>{b.has(t)&&(n(),a(),e())});return e(),()=>{n(),o(s)}},a=>a(),y,u,d,O,R(b),async(a,t)=>await a(U+` t.name tn,c.name cn FROM ${q}list()t,${q}info(t.name)c ${j} t.schema='main'AND t.type IN('table','view')AND t.name IN(${V(t)})ORDER BY t.name,c.name`,t),g,v,e,A,a=>(a=>!0===a)(a)?1:(a=>!1===a)(a)?0:a,void 0)},Qa=(a,t,e,n,s)=>Ka(a,e,async(a,e=[])=>t.query(a).all(...e),()=>N,a=>a(),n,s,N,3,t);export{Qa as createSqliteBunPersister};
@@ -1 +1 @@
1
- const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),i="true",o=(a,t,e)=>a.replace(t,e),r=Promise,c=a=>(t,e,n)=>a(t)?n?.():e(t),l=clearInterval,w=a=>null==a,u=a=>void 0===a,y=a=>null===a,d=c(w),p=c(u),g=t=>a(t)==s,v=a=>Array.isArray(a),E=(a,t,e)=>a.slice(t,e),A=a=>a.length,m=()=>{},N=async a=>r.all(a),$=a=>{throw Error(a)},f=async(a,t,e)=>{try{return await a()}catch(a){t?.(a)}},h=(a,t)=>a.forEach(t),b=(a,t="")=>a.join(t),C=(a,t)=>a.map(t),T=a=>0==A(a),O=(a,t)=>a.filter(t),D=(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()??[]],_=(a,t)=>a?.forEach(t),M=(a,t)=>a?.delete(t),P="_",F="_id",j="SELECT",k="WHERE",U="TABLE",x="ALTER "+U,B="FROM",J="DELETE "+B,Y=j+"*"+B,q="pragma_",z="data_version",G="schema_version",H="pragma_table_",V="CREATE "+U,K=a=>b(C(((a,t="",e)=>a.split(t,e))(a,"."),a=>`"${o(a,/"/g,'""')}"`),"."),Q=(a,t=[1])=>b(C(a,()=>"$"+t[0]++),n),W=(a,t=i)=>k+`(${o(t,"$tableName",K(a))})`,X=Object,Z=a=>X.getPrototypeOf(a),aa=X.entries,ta=a=>!w(a)&&d(Z(a),a=>a==X.prototype||w(Z(a)),()=>!0),ea=X.keys,na=X.freeze,sa=(a=[])=>X.fromEntries(a),ia=(...a)=>X.assign({},...a),oa=(a,t)=>(delete a[t],a),ra=(a,t)=>C(aa(a),([a,e])=>t(e,a)),ca=(a,t)=>sa(ra(a,(a,e)=>[e,t(a,e)])),la=a=>X.values(a),wa=a=>A(ea(a)),ua=a=>ta(a)&&0==wa(a),ya=a=>new Map(a),da=(a,t)=>a?.get(t),pa=(a,t)=>C([...a?.entries()??[]],([a,e])=>t(e,a)),ga=(a,t,e)=>u(e)?(M(a,t),a):a?.set(t,e),va=(a,t,e,n)=>(S(a,t)?n?.(da(a,t)):ga(a,t,e()),da(a,t)),Ea=(a,t,e,n,s=0)=>p((e?va:da)(a,t[s],s>A(t)-2?e:ya),i=>{if(s>A(t)-2)return n?.(i)&&ga(a,t[s]),i;const o=Ea(i,t,e,n,s+1);return L(i)&&ga(a,t[s]),o}),Aa=a=>new Set(v(a)||u(a)?a:[a]),ma=(a,t)=>a?.add(t),Na="ColumnName",$a="store",fa="json",ha=$a+"TableName",ba=$a+"Id"+Na,Ca=$a+Na,Ta="autoLoadIntervalSeconds",Oa="rowId"+Na,Da="tableId",Ia="tableName",Sa="deleteEmptyColumns",La="deleteEmptyTable",Ra="condition",_a={mode:fa,[Ta]:1},Ma={load:0,save:0,[Ia]:t+"_values"},Pa=(a,t,e,n,s)=>{const i=ya();return ca(a,(a,o)=>{const r=E(la(ia(t,g(a)?{[e]:a}:a)),0,wa(t));y(r[0])||n(o,r[0])||(s(o,r[0]),ga(i,o,r))}),i},Fa=JSON.stringify,ja=JSON.parse,ka=a=>""===a?void 0:v(a)?C(a,ka):ta(a)?ca(a,ka):a,Ua=/^\d+$/,xa=ya(),Ba=ya(),Ja=(a,t,n,s,i,o,r,c={},l=0,w=[])=>{let d,g,E,m=0,N=0,b=0;va(xa,w,()=>0),va(Ba,w,()=>[]);const C=ya(),[T,O,S,R,P]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!ua(a)||!ua(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!ua(a)||!ua(t),t.setContent]:$("Store type not supported by this Persister"))(r,a,l),[F,j,k]=(()=>{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??=K;const l=t(1);return ga(s,l,[n,i,o,r,c]),ma(Ea(i,o??[e],Aa),l),l},(t,n,...i)=>h(((a,t=[e])=>{const n=[],s=(a,e)=>e==A(t)?D(n,a):y(t[e])?_(a,a=>s(a,e+1)):h([t[e],null],t=>s(da(a,t),e+1));return s(a,0),n})(t,n),t=>_(t,t=>da(s,t)[0](a,...n??[],...i))),a=>p(da(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=>p(da(s,t),([t,,e=[],n,s])=>{const i=(...o)=>{const r=A(o);r==A(e)?t(a,...o,...s(o)):y(e[r])?h(n[r]?.(...o)??[],a=>i(...o,a)):i(...o,e[r])};i()})]})(),U=a=>{a!=m&&(m=a,j(C,void 0,m))},x=t=>{(T&&v(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},B=async a=>(2!=m&&(U(1),N++,await V(async()=>{await f(async()=>{const e=await t();v(e)?x(e):a?P(a):$("Content is not an array: "+e)},()=>{a&&P(a)}),U(0)})),K),J=async a=>(Y(),await B(a),await f(async()=>g=await s(async(a,t)=>{t||a?2!=m&&(U(1),N++,x(t??a),U(0)):await B()}),o),K),Y=async()=>(g&&(await f(()=>i(g),o),g=void 0),K),q=async a=>(1!=m&&(U(2),b++,await V(async()=>{await f(()=>n(O,a),o),U(0)})),K),z=async()=>(G(),await q(),E=a.addDidFinishTransactionListener(()=>{const a=S();R(a)&&q(a)}),K),G=async()=>(E&&(a.delListener(E),E=void 0),K),H=async(a=!1)=>{const[t,e]=a?[G,Y]:[Y,G];return await t(),await e(),K},V=async(...a)=>(D(da(Ba,w),...a),await(async()=>{if(!da(xa,w)){for(ga(xa,w,1);!u(d=I(da(Ba,w)));)await f(d,o);ga(xa,w,0)}})(),K),K={load:B,startAutoLoad:J,stopAutoLoad:Y,isAutoLoading:()=>!u(g),save:q,startAutoSave:z,stopAutoSave:G,isAutoSaving:()=>!u(E),startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[z,J]:[J,z];return await e(a),await n(a),K},stopAutoPersisting:H,getStatus:()=>m,addStatusListener:a=>F(a,C),delListener:t=>(k(t),a),schedule:V,getStore:()=>a,destroy:()=>(da(Ba,w).splice(0,void 0),H()),getStats:()=>({loads:N,saves:b}),...c};return na(K)},Ya=(a,t,e,s,o,r=qa,c,l)=>{const w=ya();return[async()=>{w.clear(),C(await e(a,t),({tn:a,cn:t})=>ma(va(w,a,Aa),t))},async(t,e,n)=>((a,t)=>S(da(w,a),t))(t,e)?sa(O(C(await a(Y+K(t)+W(t,n)),a=>[a[e],l?ca(oa(a,e),l):oa(a,e)]),([a,t])=>!u(a)&&!ua(t))):{},async(t,e,s,l,y,d=!1,p=i)=>{const g=Aa();ca(s??{},a=>C(ea(a??{}),a=>ma(g,a)));const v=R(g);if(!d&&y&&p==i&&T(v)&&S(w,t))return await a("DROP "+U+K(t)),void ga(w,t);const E=da(w,t),A=Aa(R(E));if(T(v)||(S(w,t)?await N(C([e,...v],async(n,s)=>{M(A,n)||(await a(x+K(t)+"ADD"+K(n)+o),0==s&&await a("CREATE UNIQUE INDEX pk ON "+K(t)+`(${K(e)})`),ma(E,n))})):(await a(V+K(t)+`(${K(e)}${o} PRIMARY KEY${b(C(v,a=>n+K(a)+o))});`),ga(w,t,Aa([e,...v])))),await N([...!d&&l?C(R(A),async n=>{n!=e&&(await a(x+K(t)+"DROP"+K(n)),M(E,n))}):[]]),d)u(s)?await a(J+K(t)+W(t,p)):await N(ra(s,async(n,s)=>{u(n)?await a(J+K(t)+W(t,p)+`AND(${K(e)}=$1)`,[s]):T(v)||await r(a,t,e,ea(n),{[s]:c?C(la(n),c):la(n)},E)}));else if(T(v))S(w,t)&&await a(J+K(t)+W(t,p));else{const n=O(R(da(w,t)),a=>a!=e),i={},o=[];ca(s??{},(a,t)=>{i[t]=C(n,t=>c?c(a?.[t]):a?.[t]),D(o,t)}),await r(a,t,e,n,i),await a(J+K(t)+W(t,p)+`AND${K(e)}NOT IN(${Q(o)})`,o)}},async t=>{let e;return await a("BEGIN"),await f(async()=>e=await t(),s),await a("END"),e}]},qa=async(a,t,e,s,i)=>{const o=[1];await a("INSERT INTO"+K(t)+"("+((...a)=>b(C(a,K),n))(e,...s)+")VALUES"+b(ra(i,a=>"($"+o[0]+++","+Q(a,o)+")"),n)+"ON CONFLICT("+K(e)+")DO UPDATE SET"+b(C(s,a=>K(a)+"=excluded."+K(a)),n),ra(i,(a,t)=>[t,...C(a,a=>a??null)]).flat())},za=(a,t,e,n,s,i,o,[r,c,l],w,y,d,p,g,v)=>{const[E,A,m,N]=Ya(t,w,y,s,g,v),$=Ja(a,()=>N(async()=>{return await E(),a=(await A(r,c))[P]?.[l]??"null",ka(ja(a));var a}),a=>N(async()=>{var t;await E(),await m(r,c,{[P]:{[l]:(t=a()??null,Fa(t,(a,t)=>u(t)?"":t))}},!0,!0)}),e,n,s,o,{[p]:()=>d,destroy:async()=>(await $.stopAutoPersisting(),i(),$)},0,d);return $},Ga=(a,t,e,n,s,i,o,[r,c,[l,w,y]],d,p,g,v,E,A,m,$)=>{const[f,h,b,C]=Ya(t,d,p,s,E,A,m,$),T=(a,t)=>N(pa(c,async([e,n,s,i,o],r)=>{t&&!(r in a)||await b(e,n,a[r],s,i,t,o)})),D=async(a,t)=>w?await b(y,F,{[P]:a},!0,!0,t):null,I=Ja(a,()=>C(async()=>{await f();const a=await(async()=>sa(O(await N(pa(r,async([a,t,e],n)=>[a,await h(n,t,e)])),a=>!ua(a[1]))))(),t=await(async()=>l?(await h(y,F))[P]:{})();return ua(a)&&u(t)?void 0:[a,t]}),(a,t)=>C(async()=>{if(await f(),u(t)){const[t,e]=a();await T(t),await D(e)}else await T(t[0],!0),await D(t[1],!0)}),e,n,s,o,{[v]:()=>g,destroy:async()=>(await I.stopAutoPersisting(),i(),I)},0,g);return I},Ha=(a,n,s,o,r,c,u,y,d,p,v="getDb",A)=>{let m,N,$;const h=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,c),[b,C,T,O]=(a=>{const e=(a=>ia(_a,g(a)?{[ha]:a}:a??{}))(a),n=e[Ta];if(e.mode==fa){const a=e[ha]??t;return[1,n,[a,e[ba]??F,e[Ca]??$a],Aa(a)]}const{tables:{load:s={},save:o={}}={},values:r={}}=e,c=E(la(ia(Ma,r)),0,wa(Ma)),l=c[2],w=Aa(l),u=Aa(l),y=Pa(s,{[Da]:null,[Oa]:F,[Ra]:i},Da,a=>S(u,a),a=>ma(w,a)),d=Pa(o,{[Ia]:null,[Oa]:F,[Sa]:0,[La]:0,[Ra]:null},Ia,(a,t)=>S(u,t),(a,t)=>ma(w,t));var p;return p=(a,t)=>t[4]??=da(y,t[0])?.[2]??i,_(d,(a,t)=>p(0,a)),[0,n,[y,d,c],w]})(n);return(b?za:Ga)(a,h,a=>{let t;const e=()=>t=setInterval(()=>f(async()=>{const[{d:t,s:e,c:n}]=await h(j+` ${z} d,${G} s,TOTAL_CHANGES() c FROM ${q}${z} JOIN ${q}${G}`);t==m&&e==N&&n==$||(w(m)||a(),m=t,N=e,$=n)}),1e3*C),n=()=>{m=N=$=null,l(t)},s=o(t=>{O.has(t)&&(n(),a(),e())});return e(),()=>{n(),r(s)}},a=>a(),u,y,d,T,R(O),async(a,t)=>await a(j+` t.name tn,c.name cn FROM ${H}list()t,${H}info(t.name)c ${k} t.schema='main'AND t.type IN('table','view')AND t.name IN(${Q(t)})ORDER BY t.name,c.name`,t),p,v,e,A,a=>(a=>!0===a)(a)?1:(a=>!1===a)(a)?0:a,void 0)},Va=(a,t,e,n,s,i)=>Ha(a,n,async(a,t=[])=>e.exec(a,{bind:t,rowMode:"object",returnValue:"resultRows"}).map(a=>({...a})),a=>t.capi.sqlite3_update_hook(e,(t,e,n,s)=>a(s),0),()=>t.capi.sqlite3_update_hook(e,m,0),s,i,m,3,e);export{Va as createSqliteWasmPersister};
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,u=a=>void 0===a,y=a=>null===a,d=c(w),p=c(u),g=t=>a(t)==s,v=a=>Array.isArray(a),E=(a,t,e)=>a.slice(t,e),A=a=>a.length,m=()=>{},N=async a=>r.all(a),$=a=>{throw Error(a)},h=async(a,t,e)=>{try{return await a()}catch(a){t?.(a)}},f=(a,t)=>a.forEach(t),b=(a,t="")=>a.join(t),C=(a,t)=>a.map(t),T=a=>0==A(a),O=(a,t)=>a.filter(t),D=(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()??[]],_=(a,t)=>a?.forEach(t),M=(a,t)=>a?.delete(t),P="_",F="_id",j="SELECT",k="WHERE",U="TABLE",x="ALTER "+U,B="FROM",J="DELETE "+B,Y=j+"*"+B,q="pragma_",z="data_version",G="schema_version",H="pragma_table_",V="CREATE "+U,K=a=>b(C(((a,t="",e)=>a.split(t,e))(a,"."),a=>`"${o(a,/"/g,'""')}"`),"."),Q=(a,t=[1])=>b(C(a,()=>"$"+t[0]++),n),W=(a,t=i)=>k+`(${o(t,"$tableName",K(a))})`,X=Object,Z=a=>X.getPrototypeOf(a),aa=X.entries,ta=a=>!w(a)&&d(Z(a),a=>a==X.prototype||w(Z(a)),()=>!0),ea=X.keys,na=X.freeze,sa=(a=[])=>X.fromEntries(a),ia=(...a)=>X.assign({},...a),oa=(a,t)=>(delete a[t],a),ra=(a,t)=>C(aa(a),([a,e])=>t(e,a)),ca=(a,t)=>sa(ra(a,(a,e)=>[e,t(a,e)])),la=a=>X.values(a),wa=a=>A(ea(a)),ua=a=>ta(a)&&0==wa(a),ya=Map,da=a=>new ya(a),pa=(a,t)=>a?.get(t),ga=(a,t)=>C([...a?.entries()??[]],([a,e])=>t(e,a)),va=(a,t,e)=>u(e)?(M(a,t),a):a?.set(t,e),Ea=(a,t,e,n)=>(S(a,t)?n?.(pa(a,t)):va(a,t,e()),pa(a,t)),Aa=(a,t,e,n,s=0)=>p((e?Ea:pa)(a,t[s],s>A(t)-2?e:da),i=>{if(s>A(t)-2)return n?.(i)&&va(a,t[s]),i;const o=Aa(i,t,e,n,s+1);return L(i)&&va(a,t[s]),o}),ma=a=>new Set(v(a)||u(a)?a:[a]),Na=(a,t)=>a?.add(t),$a="ColumnName",ha="store",fa="json",ba=ha+"TableName",Ca=ha+"Id"+$a,Ta=ha+$a,Oa="autoLoadIntervalSeconds",Da="rowId"+$a,Ia="tableId",Sa="tableName",La="deleteEmptyColumns",Ra="deleteEmptyTable",_a="condition",Ma={mode:fa,[Oa]:1},Pa={load:0,save:0,[Sa]:t+"_values"},Fa=(a,t,e,n,s)=>{const i=da();return ca(a,(a,o)=>{const r=E(la(ia(t,g(a)?{[e]:a}:a)),0,wa(t));y(r[0])||n(o,r[0])||(s(o,r[0]),va(i,o,r))}),i},ja=JSON.stringify,ka=JSON.parse,Ua=a=>""===a?void 0:v(a)?C(a,Ua):ta(a)?ca(a,Ua):a,xa=/^\d+$/,Ba=da(),Ja=da(),Ya=(a,t,n,s,i,o,r,c={},l=0,w=[])=>{let d,g,E,m=0,N=0,b=0;Ea(Ba,w,()=>0),Ea(Ja,w,()=>[]);const C=da(),[T,O,S,R,P]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!ua(a)||!ua(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!ua(a)||!ua(t),t.setContent]:$("Store type not supported by this Persister"))(r,a,l),[F,j,k]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?I(a):null)??e+t++,t=>{xa.test(t)&&A(a)<1e3&&D(a,t)}]})(),s=da();return[(n,i,o,r=[],c=()=>[])=>{a??=W;const l=t(1);return va(s,l,[n,i,o,r,c]),Na(Aa(i,o??[e],ma),l),l},(t,n,...i)=>f(((a,t=[e])=>{const n=[],s=(a,e)=>e==A(t)?D(n,a):y(t[e])?_(a,a=>s(a,e+1)):f([t[e],null],t=>s(pa(a,t),e+1));return s(a,0),n})(t,n),t=>_(t,t=>pa(s,t)[0](a,...n??[],...i))),a=>p(pa(s,a),([,t,i])=>(Aa(t,i??[e],void 0,t=>(M(t,a),L(t)?1:0)),va(s,a),n(a),i)),t=>p(pa(s,t),([t,,e=[],n,s])=>{const i=(...o)=>{const r=A(o);r==A(e)?t(a,...o,...s(o)):y(e[r])?f(n[r]?.(...o)??[],a=>i(...o,a)):i(...o,e[r])};i()})]})(),U=a=>{a!=m&&(m=a,j(C,void 0,m))},x=t=>{(T&&v(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},B=async()=>{V()&&a.hadMutated?.()&&await z()},J=async a=>(2!=m&&(U(1),N++,await Q(async()=>{await h(async()=>{const e=await t();v(e)?x(e):a?P(a):$("Content is not an array: "+e)},()=>{a&&P(a)}),U(0),await B()})),W),Y=async a=>(q(),await J(a),await h(async()=>g=await s(async(a,t)=>{t||a?2!=m&&(U(1),N++,x(t??a),U(0),await B()):await J()}),o),W),q=async()=>(g&&(await h(()=>i(g),o),g=void 0),W),z=async a=>(1!=m&&(U(2),b++,await Q(async()=>{await h(()=>n(O,a),o),U(0)})),W),G=async()=>(H(),await z(),E=a.addDidFinishTransactionListener(()=>{const a=S();R(a)&&z(a)}),W),H=async()=>(E&&(a.delListener(E),E=void 0),W),V=()=>!u(E),K=async(a=!1)=>{const[t,e]=a?[H,q]:[q,H];return await t(),await e(),W},Q=async(...a)=>(D(pa(Ja,w),...a),await(async()=>{if(!pa(Ba,w)){for(va(Ba,w,1);!u(d=I(pa(Ja,w)));)await h(d,o);va(Ba,w,0)}})(),W),W={load:J,startAutoLoad:Y,stopAutoLoad:q,isAutoLoading:()=>!u(g),save:z,startAutoSave:G,stopAutoSave:H,isAutoSaving:V,startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[G,Y]:[Y,G];return await e(a),await n(a),W},stopAutoPersisting:K,getStatus:()=>m,addStatusListener:a=>F(a,C),delListener:t=>(k(t),a),schedule:Q,getStore:()=>a,destroy:()=>(pa(Ja,w).splice(0,void 0),K()),getStats:()=>({loads:N,saves:b}),...c};return na(W)},qa=(a,t,e,s,o,r=za,c,l)=>{const w=da();return[async()=>{w.clear(),C(await e(a,t),({tn:a,cn:t})=>Na(Ea(w,a,ma),t))},async(t,e,n)=>((a,t)=>S(pa(w,a),t))(t,e)?sa(O(C(await a(Y+K(t)+W(t,n)),a=>[a[e],l?ca(oa(a,e),l):oa(a,e)]),([a,t])=>!u(a)&&!ua(t))):{},async(t,e,s,l,y,d=!1,p=i)=>{const g=ma();ca(s??{},a=>C(ea(a??{}),a=>Na(g,a)));const v=R(g);if(!d&&y&&p==i&&T(v)&&S(w,t))return await a("DROP "+U+K(t)),void va(w,t);const E=pa(w,t),A=ma(R(E));if(T(v)||(S(w,t)?await N(C([e,...v],async(n,s)=>{M(A,n)||(await a(x+K(t)+"ADD"+K(n)+o),0==s&&await a("CREATE UNIQUE INDEX pk ON "+K(t)+`(${K(e)})`),Na(E,n))})):(await a(V+K(t)+`(${K(e)}${o} PRIMARY KEY${b(C(v,a=>n+K(a)+o))});`),va(w,t,ma([e,...v])))),await N([...!d&&l?C(R(A),async n=>{n!=e&&(await a(x+K(t)+"DROP"+K(n)),M(E,n))}):[]]),d)u(s)?await a(J+K(t)+W(t,p)):await N(ra(s,async(n,s)=>{u(n)?await a(J+K(t)+W(t,p)+`AND(${K(e)}=$1)`,[s]):T(v)||await r(a,t,e,ea(n),{[s]:c?C(la(n),c):la(n)},E)}));else if(T(v))S(w,t)&&await a(J+K(t)+W(t,p));else{const n=O(R(pa(w,t)),a=>a!=e),i={},o=[];ca(s??{},(a,t)=>{i[t]=C(n,t=>c?c(a?.[t]):a?.[t]),D(o,t)}),await r(a,t,e,n,i),await a(J+K(t)+W(t,p)+`AND${K(e)}NOT IN(${Q(o)})`,o)}},async t=>{let e;return await a("BEGIN"),await h(async()=>e=await t(),s),await a("END"),e}]},za=async(a,t,e,s,i)=>{const o=[1];await a("INSERT INTO"+K(t)+"("+((...a)=>b(C(a,K),n))(e,...s)+")VALUES"+b(ra(i,a=>"($"+o[0]+++","+Q(a,o)+")"),n)+"ON CONFLICT("+K(e)+")DO UPDATE SET"+b(C(s,a=>K(a)+"=excluded."+K(a)),n),ra(i,(a,t)=>[t,...C(a,a=>a??null)]).flat())},Ga=(a,t,e,n,s,i,o,[r,c,l],w,y,d,p,g,v)=>{const[E,A,m,N]=qa(t,w,y,s,g,v),$=Ya(a,()=>N(async()=>{return await E(),a=(await A(r,c))[P]?.[l]??"null",Ua(ka(a));var a}),a=>N(async()=>{var t;await E(),await m(r,c,{[P]:{[l]:(t=a()??null,ja(t,(a,t)=>u(t)?"":t))}},!0,!0)}),e,n,s,o,{[p]:()=>d,destroy:async()=>(await $.stopAutoPersisting(),i(),$)},0,d);return $},Ha=(a,t,e,n,s,i,o,[r,c,[l,w,y]],d,p,g,v,E,A,m,$)=>{const[h,f,b,C]=qa(t,d,p,s,E,A,m,$),T=(a,t)=>N(ga(c,async([e,n,s,i,o],r)=>{t&&!(r in a)||await b(e,n,a[r],s,i,t,o)})),D=async(a,t)=>w?await b(y,F,{[P]:a},!0,!0,t):null,I=Ya(a,()=>C(async()=>{await h();const a=await(async()=>sa(O(await N(ga(r,async([a,t,e],n)=>[a,await f(n,t,e)])),a=>!ua(a[1]))))(),t=await(async()=>l?(await f(y,F))[P]:{})();return ua(a)&&u(t)?void 0:[a,t]}),(a,t)=>C(async()=>{if(await h(),u(t)){const[t,e]=a();await T(t),await D(e)}else await T(t[0],!0),await D(t[1],!0)}),e,n,s,o,{[v]:()=>g,destroy:async()=>(await I.stopAutoPersisting(),i(),I)},0,g);return I},Va=(a,n,s,o,r,c,u,y,d,p,v="getDb",A)=>{let m,N,$;const f=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,c),[b,C,T,O]=(a=>{const e=(a=>ia(Ma,g(a)?{[ba]:a}:a??{}))(a),n=e[Oa];if(e.mode==fa){const a=e[ba]??t;return[1,n,[a,e[Ca]??F,e[Ta]??ha],ma(a)]}const{tables:{load:s={},save:o={}}={},values:r={}}=e,c=E(la(ia(Pa,r)),0,wa(Pa)),l=c[2],w=ma(l),u=ma(l),y=Fa(s,{[Ia]:null,[Da]:F,[_a]:i},Ia,a=>S(u,a),a=>Na(w,a)),d=Fa(o,{[Sa]:null,[Da]:F,[La]:0,[Ra]:0,[_a]:null},Sa,(a,t)=>S(u,t),(a,t)=>Na(w,t));var p;return p=(a,t)=>t[4]??=pa(y,t[0])?.[2]??i,_(d,(a,t)=>p(0,a)),[0,n,[y,d,c],w]})(n);return(b?Ga:Ha)(a,f,a=>{let t;const e=()=>t=setInterval(()=>h(async()=>{const[{d:t,s:e,c:n}]=await f(j+` ${z} d,${G} s,TOTAL_CHANGES() c FROM ${q}${z} JOIN ${q}${G}`);t==m&&e==N&&n==$||(w(m)||a(),m=t,N=e,$=n)}),1e3*C),n=()=>{m=N=$=null,l(t)},s=o(t=>{O.has(t)&&(n(),a(),e())});return e(),()=>{n(),r(s)}},a=>a(),u,y,d,T,R(O),async(a,t)=>await a(j+` t.name tn,c.name cn FROM ${H}list()t,${H}info(t.name)c ${k} t.schema='main'AND t.type IN('table','view')AND t.name IN(${Q(t)})ORDER BY t.name,c.name`,t),p,v,e,A,a=>(a=>!0===a)(a)?1:(a=>!1===a)(a)?0:a,void 0)},Ka=(a,t,e,n,s,i)=>Va(a,n,async(a,t=[])=>e.exec(a,{bind:t,rowMode:"object",returnValue:"resultRows"}).map(a=>({...a})),a=>t.capi.sqlite3_update_hook(e,(t,e,n,s)=>a(s),0),()=>t.capi.sqlite3_update_hook(e,m,0),s,i,m,3,e);export{Ka as createSqliteWasmPersister};
@@ -1 +1 @@
1
- const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),i="true",o=(a,t,e)=>a.replace(t,e),r=Promise,c=a=>(t,e,n)=>a(t)?n?.():e(t),l=clearInterval,w=a=>null==a,u=a=>void 0===a,y=a=>null===a,d=c(w),p=c(u),g=t=>a(t)==s,v=a=>Array.isArray(a),E=(a,t,e)=>a.slice(t,e),A=a=>a.length,m=()=>{},N=async a=>r.all(a),$=a=>{throw Error(a)},f=async(a,t,e)=>{try{return await a()}catch(a){t?.(a)}},h=(a,t)=>a.forEach(t),b=(a,t="")=>a.join(t),C=(a,t)=>a.map(t),T=a=>0==A(a),O=(a,t)=>a.filter(t),D=(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()??[]],_=(a,t)=>a?.forEach(t),M=(a,t)=>a?.delete(t),P="_",F="_id",j="SELECT",k="WHERE",U="TABLE",x="ALTER "+U,B="FROM",J="DELETE "+B,Y=j+"*"+B,q="pragma_",z="data_version",G="schema_version",H="pragma_table_",V="CREATE "+U,K=a=>b(C(((a,t="",e)=>a.split(t,e))(a,"."),a=>`"${o(a,/"/g,'""')}"`),"."),Q=(a,t=[1])=>b(C(a,()=>"$"+t[0]++),n),W=(a,t=i)=>k+`(${o(t,"$tableName",K(a))})`,X=Object,Z=a=>X.getPrototypeOf(a),aa=X.entries,ta=a=>!w(a)&&d(Z(a),a=>a==X.prototype||w(Z(a)),()=>!0),ea=X.keys,na=X.freeze,sa=(a=[])=>X.fromEntries(a),ia=(...a)=>X.assign({},...a),oa=(a,t)=>(delete a[t],a),ra=(a,t)=>C(aa(a),([a,e])=>t(e,a)),ca=(a,t)=>sa(ra(a,(a,e)=>[e,t(a,e)])),la=a=>X.values(a),wa=a=>A(ea(a)),ua=a=>ta(a)&&0==wa(a),ya=a=>new Map(a),da=(a,t)=>a?.get(t),pa=(a,t)=>C([...a?.entries()??[]],([a,e])=>t(e,a)),ga=(a,t,e)=>u(e)?(M(a,t),a):a?.set(t,e),va=(a,t,e,n)=>(S(a,t)?n?.(da(a,t)):ga(a,t,e()),da(a,t)),Ea=(a,t,e,n,s=0)=>p((e?va:da)(a,t[s],s>A(t)-2?e:ya),i=>{if(s>A(t)-2)return n?.(i)&&ga(a,t[s]),i;const o=Ea(i,t,e,n,s+1);return L(i)&&ga(a,t[s]),o}),Aa=a=>new Set(v(a)||u(a)?a:[a]),ma=(a,t)=>a?.add(t),Na="ColumnName",$a="store",fa="json",ha=$a+"TableName",ba=$a+"Id"+Na,Ca=$a+Na,Ta="autoLoadIntervalSeconds",Oa="rowId"+Na,Da="tableId",Ia="tableName",Sa="deleteEmptyColumns",La="deleteEmptyTable",Ra="condition",_a={mode:fa,[Ta]:1},Ma={load:0,save:0,[Ia]:t+"_values"},Pa=(a,t,e,n,s)=>{const i=ya();return ca(a,(a,o)=>{const r=E(la(ia(t,g(a)?{[e]:a}:a)),0,wa(t));y(r[0])||n(o,r[0])||(s(o,r[0]),ga(i,o,r))}),i},Fa=JSON.stringify,ja=JSON.parse,ka=a=>""===a?void 0:v(a)?C(a,ka):ta(a)?ca(a,ka):a,Ua=/^\d+$/,xa=ya(),Ba=ya(),Ja=(a,t,n,s,i,o,r,c={},l=0,w=[])=>{let d,g,E,m=0,N=0,b=0;va(xa,w,()=>0),va(Ba,w,()=>[]);const C=ya(),[T,O,S,R,P]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!ua(a)||!ua(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!ua(a)||!ua(t),t.setContent]:$("Store type not supported by this Persister"))(r,a,l),[F,j,k]=(()=>{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??=K;const l=t(1);return ga(s,l,[n,i,o,r,c]),ma(Ea(i,o??[e],Aa),l),l},(t,n,...i)=>h(((a,t=[e])=>{const n=[],s=(a,e)=>e==A(t)?D(n,a):y(t[e])?_(a,a=>s(a,e+1)):h([t[e],null],t=>s(da(a,t),e+1));return s(a,0),n})(t,n),t=>_(t,t=>da(s,t)[0](a,...n??[],...i))),a=>p(da(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=>p(da(s,t),([t,,e=[],n,s])=>{const i=(...o)=>{const r=A(o);r==A(e)?t(a,...o,...s(o)):y(e[r])?h(n[r]?.(...o)??[],a=>i(...o,a)):i(...o,e[r])};i()})]})(),U=a=>{a!=m&&(m=a,j(C,void 0,m))},x=t=>{(T&&v(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},B=async a=>(2!=m&&(U(1),N++,await V(async()=>{await f(async()=>{const e=await t();v(e)?x(e):a?P(a):$("Content is not an array: "+e)},()=>{a&&P(a)}),U(0)})),K),J=async a=>(Y(),await B(a),await f(async()=>g=await s(async(a,t)=>{t||a?2!=m&&(U(1),N++,x(t??a),U(0)):await B()}),o),K),Y=async()=>(g&&(await f(()=>i(g),o),g=void 0),K),q=async a=>(1!=m&&(U(2),b++,await V(async()=>{await f(()=>n(O,a),o),U(0)})),K),z=async()=>(G(),await q(),E=a.addDidFinishTransactionListener(()=>{const a=S();R(a)&&q(a)}),K),G=async()=>(E&&(a.delListener(E),E=void 0),K),H=async(a=!1)=>{const[t,e]=a?[G,Y]:[Y,G];return await t(),await e(),K},V=async(...a)=>(D(da(Ba,w),...a),await(async()=>{if(!da(xa,w)){for(ga(xa,w,1);!u(d=I(da(Ba,w)));)await f(d,o);ga(xa,w,0)}})(),K),K={load:B,startAutoLoad:J,stopAutoLoad:Y,isAutoLoading:()=>!u(g),save:q,startAutoSave:z,stopAutoSave:G,isAutoSaving:()=>!u(E),startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[z,J]:[J,z];return await e(a),await n(a),K},stopAutoPersisting:H,getStatus:()=>m,addStatusListener:a=>F(a,C),delListener:t=>(k(t),a),schedule:V,getStore:()=>a,destroy:()=>(da(Ba,w).splice(0,void 0),H()),getStats:()=>({loads:N,saves:b}),...c};return na(K)},Ya=(a,t,e,s,o,r=qa,c,l)=>{const w=ya();return[async()=>{w.clear(),C(await e(a,t),({tn:a,cn:t})=>ma(va(w,a,Aa),t))},async(t,e,n)=>((a,t)=>S(da(w,a),t))(t,e)?sa(O(C(await a(Y+K(t)+W(t,n)),a=>[a[e],l?ca(oa(a,e),l):oa(a,e)]),([a,t])=>!u(a)&&!ua(t))):{},async(t,e,s,l,y,d=!1,p=i)=>{const g=Aa();ca(s??{},a=>C(ea(a??{}),a=>ma(g,a)));const v=R(g);if(!d&&y&&p==i&&T(v)&&S(w,t))return await a("DROP "+U+K(t)),void ga(w,t);const E=da(w,t),A=Aa(R(E));if(T(v)||(S(w,t)?await N(C([e,...v],async(n,s)=>{M(A,n)||(await a(x+K(t)+"ADD"+K(n)+o),0==s&&await a("CREATE UNIQUE INDEX pk ON "+K(t)+`(${K(e)})`),ma(E,n))})):(await a(V+K(t)+`(${K(e)}${o} PRIMARY KEY${b(C(v,a=>n+K(a)+o))});`),ga(w,t,Aa([e,...v])))),await N([...!d&&l?C(R(A),async n=>{n!=e&&(await a(x+K(t)+"DROP"+K(n)),M(E,n))}):[]]),d)u(s)?await a(J+K(t)+W(t,p)):await N(ra(s,async(n,s)=>{u(n)?await a(J+K(t)+W(t,p)+`AND(${K(e)}=$1)`,[s]):T(v)||await r(a,t,e,ea(n),{[s]:c?C(la(n),c):la(n)},E)}));else if(T(v))S(w,t)&&await a(J+K(t)+W(t,p));else{const n=O(R(da(w,t)),a=>a!=e),i={},o=[];ca(s??{},(a,t)=>{i[t]=C(n,t=>c?c(a?.[t]):a?.[t]),D(o,t)}),await r(a,t,e,n,i),await a(J+K(t)+W(t,p)+`AND${K(e)}NOT IN(${Q(o)})`,o)}},async t=>{let e;return await a("BEGIN"),await f(async()=>e=await t(),s),await a("END"),e}]},qa=async(a,t,e,s,i)=>{const o=[1];await a("INSERT INTO"+K(t)+"("+((...a)=>b(C(a,K),n))(e,...s)+")VALUES"+b(ra(i,a=>"($"+o[0]+++","+Q(a,o)+")"),n)+"ON CONFLICT("+K(e)+")DO UPDATE SET"+b(C(s,a=>K(a)+"=excluded."+K(a)),n),ra(i,(a,t)=>[t,...C(a,a=>a??null)]).flat())},za=(a,t,e,n,s,i,o,[r,c,l],w,y,d,p,g,v)=>{const[E,A,m,N]=Ya(t,w,y,s,g,v),$=Ja(a,()=>N(async()=>{return await E(),a=(await A(r,c))[P]?.[l]??"null",ka(ja(a));var a}),a=>N(async()=>{var t;await E(),await m(r,c,{[P]:{[l]:(t=a()??null,Fa(t,(a,t)=>u(t)?"":t))}},!0,!0)}),e,n,s,o,{[p]:()=>d,destroy:async()=>(await $.stopAutoPersisting(),i(),$)},0,d);return $},Ga=(a,t,e,n,s,i,o,[r,c,[l,w,y]],d,p,g,v,E,A,m,$)=>{const[f,h,b,C]=Ya(t,d,p,s,E,A,m,$),T=(a,t)=>N(pa(c,async([e,n,s,i,o],r)=>{t&&!(r in a)||await b(e,n,a[r],s,i,t,o)})),D=async(a,t)=>w?await b(y,F,{[P]:a},!0,!0,t):null,I=Ja(a,()=>C(async()=>{await f();const a=await(async()=>sa(O(await N(pa(r,async([a,t,e],n)=>[a,await h(n,t,e)])),a=>!ua(a[1]))))(),t=await(async()=>l?(await h(y,F))[P]:{})();return ua(a)&&u(t)?void 0:[a,t]}),(a,t)=>C(async()=>{if(await f(),u(t)){const[t,e]=a();await T(t),await D(e)}else await T(t[0],!0),await D(t[1],!0)}),e,n,s,o,{[v]:()=>g,destroy:async()=>(await I.stopAutoPersisting(),i(),I)},0,g);return I},Ha=(a,n,s,o,r,c,u,y,d,p,v="getDb",A)=>{let m,N,$;const h=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,c),[b,C,T,O]=(a=>{const e=(a=>ia(_a,g(a)?{[ha]:a}:a??{}))(a),n=e[Ta];if(e.mode==fa){const a=e[ha]??t;return[1,n,[a,e[ba]??F,e[Ca]??$a],Aa(a)]}const{tables:{load:s={},save:o={}}={},values:r={}}=e,c=E(la(ia(Ma,r)),0,wa(Ma)),l=c[2],w=Aa(l),u=Aa(l),y=Pa(s,{[Da]:null,[Oa]:F,[Ra]:i},Da,a=>S(u,a),a=>ma(w,a)),d=Pa(o,{[Ia]:null,[Oa]:F,[Sa]:0,[La]:0,[Ra]:null},Ia,(a,t)=>S(u,t),(a,t)=>ma(w,t));var p;return p=(a,t)=>t[4]??=da(y,t[0])?.[2]??i,_(d,(a,t)=>p(0,a)),[0,n,[y,d,c],w]})(n);return(b?za:Ga)(a,h,a=>{let t;const e=()=>t=setInterval(()=>f(async()=>{const[{d:t,s:e,c:n}]=await h(j+` ${z} d,${G} s,TOTAL_CHANGES() c FROM ${q}${z} JOIN ${q}${G}`);t==m&&e==N&&n==$||(w(m)||a(),m=t,N=e,$=n)}),1e3*C),n=()=>{m=N=$=null,l(t)},s=o(t=>{O.has(t)&&(n(),a(),e())});return e(),()=>{n(),r(s)}},a=>a(),u,y,d,T,R(O),async(a,t)=>await a(j+` t.name tn,c.name cn FROM ${H}list()t,${H}info(t.name)c ${k} t.schema='main'AND t.type IN('table','view')AND t.name IN(${Q(t)})ORDER BY t.name,c.name`,t),p,v,e,A,a=>(a=>!0===a)(a)?1:(a=>!1===a)(a)?0:a,void 0)},Va=(a,t,e,n,s,i)=>Ha(a,n,async(a,t=[])=>e.exec(a,{bind:t,rowMode:"object",returnValue:"resultRows"}).map(a=>({...a})),a=>t.capi.sqlite3_update_hook(e,(t,e,n,s)=>a(s),0),()=>t.capi.sqlite3_update_hook(e,m,0),s,i,m,3,e);export{Va as createSqliteWasmPersister};
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,u=a=>void 0===a,y=a=>null===a,d=c(w),p=c(u),g=t=>a(t)==s,v=a=>Array.isArray(a),E=(a,t,e)=>a.slice(t,e),A=a=>a.length,m=()=>{},N=async a=>r.all(a),$=a=>{throw Error(a)},h=async(a,t,e)=>{try{return await a()}catch(a){t?.(a)}},f=(a,t)=>a.forEach(t),b=(a,t="")=>a.join(t),C=(a,t)=>a.map(t),T=a=>0==A(a),O=(a,t)=>a.filter(t),D=(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()??[]],_=(a,t)=>a?.forEach(t),M=(a,t)=>a?.delete(t),P="_",F="_id",j="SELECT",k="WHERE",U="TABLE",x="ALTER "+U,B="FROM",J="DELETE "+B,Y=j+"*"+B,q="pragma_",z="data_version",G="schema_version",H="pragma_table_",V="CREATE "+U,K=a=>b(C(((a,t="",e)=>a.split(t,e))(a,"."),a=>`"${o(a,/"/g,'""')}"`),"."),Q=(a,t=[1])=>b(C(a,()=>"$"+t[0]++),n),W=(a,t=i)=>k+`(${o(t,"$tableName",K(a))})`,X=Object,Z=a=>X.getPrototypeOf(a),aa=X.entries,ta=a=>!w(a)&&d(Z(a),a=>a==X.prototype||w(Z(a)),()=>!0),ea=X.keys,na=X.freeze,sa=(a=[])=>X.fromEntries(a),ia=(...a)=>X.assign({},...a),oa=(a,t)=>(delete a[t],a),ra=(a,t)=>C(aa(a),([a,e])=>t(e,a)),ca=(a,t)=>sa(ra(a,(a,e)=>[e,t(a,e)])),la=a=>X.values(a),wa=a=>A(ea(a)),ua=a=>ta(a)&&0==wa(a),ya=Map,da=a=>new ya(a),pa=(a,t)=>a?.get(t),ga=(a,t)=>C([...a?.entries()??[]],([a,e])=>t(e,a)),va=(a,t,e)=>u(e)?(M(a,t),a):a?.set(t,e),Ea=(a,t,e,n)=>(S(a,t)?n?.(pa(a,t)):va(a,t,e()),pa(a,t)),Aa=(a,t,e,n,s=0)=>p((e?Ea:pa)(a,t[s],s>A(t)-2?e:da),i=>{if(s>A(t)-2)return n?.(i)&&va(a,t[s]),i;const o=Aa(i,t,e,n,s+1);return L(i)&&va(a,t[s]),o}),ma=a=>new Set(v(a)||u(a)?a:[a]),Na=(a,t)=>a?.add(t),$a="ColumnName",ha="store",fa="json",ba=ha+"TableName",Ca=ha+"Id"+$a,Ta=ha+$a,Oa="autoLoadIntervalSeconds",Da="rowId"+$a,Ia="tableId",Sa="tableName",La="deleteEmptyColumns",Ra="deleteEmptyTable",_a="condition",Ma={mode:fa,[Oa]:1},Pa={load:0,save:0,[Sa]:t+"_values"},Fa=(a,t,e,n,s)=>{const i=da();return ca(a,(a,o)=>{const r=E(la(ia(t,g(a)?{[e]:a}:a)),0,wa(t));y(r[0])||n(o,r[0])||(s(o,r[0]),va(i,o,r))}),i},ja=JSON.stringify,ka=JSON.parse,Ua=a=>""===a?void 0:v(a)?C(a,Ua):ta(a)?ca(a,Ua):a,xa=/^\d+$/,Ba=da(),Ja=da(),Ya=(a,t,n,s,i,o,r,c={},l=0,w=[])=>{let d,g,E,m=0,N=0,b=0;Ea(Ba,w,()=>0),Ea(Ja,w,()=>[]);const C=da(),[T,O,S,R,P]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!ua(a)||!ua(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!ua(a)||!ua(t),t.setContent]:$("Store type not supported by this Persister"))(r,a,l),[F,j,k]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?I(a):null)??e+t++,t=>{xa.test(t)&&A(a)<1e3&&D(a,t)}]})(),s=da();return[(n,i,o,r=[],c=()=>[])=>{a??=W;const l=t(1);return va(s,l,[n,i,o,r,c]),Na(Aa(i,o??[e],ma),l),l},(t,n,...i)=>f(((a,t=[e])=>{const n=[],s=(a,e)=>e==A(t)?D(n,a):y(t[e])?_(a,a=>s(a,e+1)):f([t[e],null],t=>s(pa(a,t),e+1));return s(a,0),n})(t,n),t=>_(t,t=>pa(s,t)[0](a,...n??[],...i))),a=>p(pa(s,a),([,t,i])=>(Aa(t,i??[e],void 0,t=>(M(t,a),L(t)?1:0)),va(s,a),n(a),i)),t=>p(pa(s,t),([t,,e=[],n,s])=>{const i=(...o)=>{const r=A(o);r==A(e)?t(a,...o,...s(o)):y(e[r])?f(n[r]?.(...o)??[],a=>i(...o,a)):i(...o,e[r])};i()})]})(),U=a=>{a!=m&&(m=a,j(C,void 0,m))},x=t=>{(T&&v(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},B=async()=>{V()&&a.hadMutated?.()&&await z()},J=async a=>(2!=m&&(U(1),N++,await Q(async()=>{await h(async()=>{const e=await t();v(e)?x(e):a?P(a):$("Content is not an array: "+e)},()=>{a&&P(a)}),U(0),await B()})),W),Y=async a=>(q(),await J(a),await h(async()=>g=await s(async(a,t)=>{t||a?2!=m&&(U(1),N++,x(t??a),U(0),await B()):await J()}),o),W),q=async()=>(g&&(await h(()=>i(g),o),g=void 0),W),z=async a=>(1!=m&&(U(2),b++,await Q(async()=>{await h(()=>n(O,a),o),U(0)})),W),G=async()=>(H(),await z(),E=a.addDidFinishTransactionListener(()=>{const a=S();R(a)&&z(a)}),W),H=async()=>(E&&(a.delListener(E),E=void 0),W),V=()=>!u(E),K=async(a=!1)=>{const[t,e]=a?[H,q]:[q,H];return await t(),await e(),W},Q=async(...a)=>(D(pa(Ja,w),...a),await(async()=>{if(!pa(Ba,w)){for(va(Ba,w,1);!u(d=I(pa(Ja,w)));)await h(d,o);va(Ba,w,0)}})(),W),W={load:J,startAutoLoad:Y,stopAutoLoad:q,isAutoLoading:()=>!u(g),save:z,startAutoSave:G,stopAutoSave:H,isAutoSaving:V,startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[G,Y]:[Y,G];return await e(a),await n(a),W},stopAutoPersisting:K,getStatus:()=>m,addStatusListener:a=>F(a,C),delListener:t=>(k(t),a),schedule:Q,getStore:()=>a,destroy:()=>(pa(Ja,w).splice(0,void 0),K()),getStats:()=>({loads:N,saves:b}),...c};return na(W)},qa=(a,t,e,s,o,r=za,c,l)=>{const w=da();return[async()=>{w.clear(),C(await e(a,t),({tn:a,cn:t})=>Na(Ea(w,a,ma),t))},async(t,e,n)=>((a,t)=>S(pa(w,a),t))(t,e)?sa(O(C(await a(Y+K(t)+W(t,n)),a=>[a[e],l?ca(oa(a,e),l):oa(a,e)]),([a,t])=>!u(a)&&!ua(t))):{},async(t,e,s,l,y,d=!1,p=i)=>{const g=ma();ca(s??{},a=>C(ea(a??{}),a=>Na(g,a)));const v=R(g);if(!d&&y&&p==i&&T(v)&&S(w,t))return await a("DROP "+U+K(t)),void va(w,t);const E=pa(w,t),A=ma(R(E));if(T(v)||(S(w,t)?await N(C([e,...v],async(n,s)=>{M(A,n)||(await a(x+K(t)+"ADD"+K(n)+o),0==s&&await a("CREATE UNIQUE INDEX pk ON "+K(t)+`(${K(e)})`),Na(E,n))})):(await a(V+K(t)+`(${K(e)}${o} PRIMARY KEY${b(C(v,a=>n+K(a)+o))});`),va(w,t,ma([e,...v])))),await N([...!d&&l?C(R(A),async n=>{n!=e&&(await a(x+K(t)+"DROP"+K(n)),M(E,n))}):[]]),d)u(s)?await a(J+K(t)+W(t,p)):await N(ra(s,async(n,s)=>{u(n)?await a(J+K(t)+W(t,p)+`AND(${K(e)}=$1)`,[s]):T(v)||await r(a,t,e,ea(n),{[s]:c?C(la(n),c):la(n)},E)}));else if(T(v))S(w,t)&&await a(J+K(t)+W(t,p));else{const n=O(R(pa(w,t)),a=>a!=e),i={},o=[];ca(s??{},(a,t)=>{i[t]=C(n,t=>c?c(a?.[t]):a?.[t]),D(o,t)}),await r(a,t,e,n,i),await a(J+K(t)+W(t,p)+`AND${K(e)}NOT IN(${Q(o)})`,o)}},async t=>{let e;return await a("BEGIN"),await h(async()=>e=await t(),s),await a("END"),e}]},za=async(a,t,e,s,i)=>{const o=[1];await a("INSERT INTO"+K(t)+"("+((...a)=>b(C(a,K),n))(e,...s)+")VALUES"+b(ra(i,a=>"($"+o[0]+++","+Q(a,o)+")"),n)+"ON CONFLICT("+K(e)+")DO UPDATE SET"+b(C(s,a=>K(a)+"=excluded."+K(a)),n),ra(i,(a,t)=>[t,...C(a,a=>a??null)]).flat())},Ga=(a,t,e,n,s,i,o,[r,c,l],w,y,d,p,g,v)=>{const[E,A,m,N]=qa(t,w,y,s,g,v),$=Ya(a,()=>N(async()=>{return await E(),a=(await A(r,c))[P]?.[l]??"null",Ua(ka(a));var a}),a=>N(async()=>{var t;await E(),await m(r,c,{[P]:{[l]:(t=a()??null,ja(t,(a,t)=>u(t)?"":t))}},!0,!0)}),e,n,s,o,{[p]:()=>d,destroy:async()=>(await $.stopAutoPersisting(),i(),$)},0,d);return $},Ha=(a,t,e,n,s,i,o,[r,c,[l,w,y]],d,p,g,v,E,A,m,$)=>{const[h,f,b,C]=qa(t,d,p,s,E,A,m,$),T=(a,t)=>N(ga(c,async([e,n,s,i,o],r)=>{t&&!(r in a)||await b(e,n,a[r],s,i,t,o)})),D=async(a,t)=>w?await b(y,F,{[P]:a},!0,!0,t):null,I=Ya(a,()=>C(async()=>{await h();const a=await(async()=>sa(O(await N(ga(r,async([a,t,e],n)=>[a,await f(n,t,e)])),a=>!ua(a[1]))))(),t=await(async()=>l?(await f(y,F))[P]:{})();return ua(a)&&u(t)?void 0:[a,t]}),(a,t)=>C(async()=>{if(await h(),u(t)){const[t,e]=a();await T(t),await D(e)}else await T(t[0],!0),await D(t[1],!0)}),e,n,s,o,{[v]:()=>g,destroy:async()=>(await I.stopAutoPersisting(),i(),I)},0,g);return I},Va=(a,n,s,o,r,c,u,y,d,p,v="getDb",A)=>{let m,N,$;const f=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,c),[b,C,T,O]=(a=>{const e=(a=>ia(Ma,g(a)?{[ba]:a}:a??{}))(a),n=e[Oa];if(e.mode==fa){const a=e[ba]??t;return[1,n,[a,e[Ca]??F,e[Ta]??ha],ma(a)]}const{tables:{load:s={},save:o={}}={},values:r={}}=e,c=E(la(ia(Pa,r)),0,wa(Pa)),l=c[2],w=ma(l),u=ma(l),y=Fa(s,{[Ia]:null,[Da]:F,[_a]:i},Ia,a=>S(u,a),a=>Na(w,a)),d=Fa(o,{[Sa]:null,[Da]:F,[La]:0,[Ra]:0,[_a]:null},Sa,(a,t)=>S(u,t),(a,t)=>Na(w,t));var p;return p=(a,t)=>t[4]??=pa(y,t[0])?.[2]??i,_(d,(a,t)=>p(0,a)),[0,n,[y,d,c],w]})(n);return(b?Ga:Ha)(a,f,a=>{let t;const e=()=>t=setInterval(()=>h(async()=>{const[{d:t,s:e,c:n}]=await f(j+` ${z} d,${G} s,TOTAL_CHANGES() c FROM ${q}${z} JOIN ${q}${G}`);t==m&&e==N&&n==$||(w(m)||a(),m=t,N=e,$=n)}),1e3*C),n=()=>{m=N=$=null,l(t)},s=o(t=>{O.has(t)&&(n(),a(),e())});return e(),()=>{n(),r(s)}},a=>a(),u,y,d,T,R(O),async(a,t)=>await a(j+` t.name tn,c.name cn FROM ${H}list()t,${H}info(t.name)c ${k} t.schema='main'AND t.type IN('table','view')AND t.name IN(${Q(t)})ORDER BY t.name,c.name`,t),p,v,e,A,a=>(a=>!0===a)(a)?1:(a=>!1===a)(a)?0:a,void 0)},Ka=(a,t,e,n,s,i)=>Va(a,n,async(a,t=[])=>e.exec(a,{bind:t,rowMode:"object",returnValue:"resultRows"}).map(a=>({...a})),a=>t.capi.sqlite3_update_hook(e,(t,e,n,s)=>a(s),0),()=>t.capi.sqlite3_update_hook(e,m,0),s,i,m,3,e);export{Ka as createSqliteWasmPersister};
@@ -1 +1 @@
1
- const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),i="true",r=(a,t,e)=>a.replace(t,e),o=Promise,c=a=>(t,e,n)=>a(t)?n?.():e(t),l=clearInterval,w=a=>null==a,u=a=>void 0===a,y=a=>null===a,d=c(w),g=c(u),v=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=>o.all(a),$=a=>{throw Error(a)},f=async(a,t,e)=>{try{return await a()}catch(a){t?.(a)}},h=(a,t)=>a.forEach(t),C=(a,t="")=>a.join(t),T=(a,t)=>a.map(t),O=a=>0==A(a),b=(a,t)=>a.filter(t),D=(a,...t)=>a.push(...t),I=a=>a.shift(),S=(a,t)=>a?.has(t)??!1,L=a=>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",K="pragma_table_",Q="CREATE "+B,V=a=>C(T(((a,t="",e)=>a.split(t,e))(a,"."),a=>`"${r(a,/"/g,'""')}"`),"."),W=(a,t=[1])=>C(T(a,()=>"$"+t[0]++),n),X=(a,t=i)=>j+`(${r(t,"$tableName",V(a))})`,q=Object,Z=a=>q.getPrototypeOf(a),aa=q.entries,ta=a=>!w(a)&&d(Z(a),a=>a==q.prototype||w(Z(a)),()=>!0),ea=q.keys,na=q.freeze,sa=(a=[])=>q.fromEntries(a),ia=(...a)=>q.assign({},...a),ra=(a,t)=>(delete a[t],a),oa=(a,t)=>T(aa(a),([a,e])=>t(e,a)),ca=(a,t)=>sa(oa(a,(a,e)=>[e,t(a,e)])),la=a=>q.values(a),wa=a=>A(ea(a)),ua=a=>ta(a)&&0==wa(a),ya=a=>new Map(a),da=(a,t)=>a?.get(t),ga=(a,t)=>T([...a?.entries()??[]],([a,e])=>t(e,a)),va=(a,t,e)=>u(e)?(M(a,t),a):a?.set(t,e),pa=(a,t,e,n)=>(S(a,t)?n?.(da(a,t)):va(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:ya),i=>{if(s>A(t)-2)return n?.(i)&&va(a,t[s]),i;const r=Ea(i,t,e,n,s+1);return L(i)&&va(a,t[s]),r}),Aa=a=>new Set(p(a)||u(a)?a:[a]),Na=(a,t)=>a?.add(t),ma="ColumnName",$a="store",fa="json",ha=$a+"TableName",Ca=$a+"Id"+ma,Ta=$a+ma,Oa="autoLoadIntervalSeconds",ba="rowId"+ma,Da="tableId",Ia="tableName",Sa="deleteEmptyColumns",La="deleteEmptyTable",Ra="condition",Pa={mode:fa,[Oa]:1},Ma={load:0,save:0,[Ia]:t+"_values"},_a=(a,t,e,n,s)=>{const i=ya();return ca(a,(a,r)=>{const o=E(la(ia(t,v(a)?{[e]:a}:a)),0,wa(t));y(o[0])||n(r,o[0])||(s(r,o[0]),va(i,r,o))}),i},Fa=JSON.stringify,Ua=JSON.parse,ja=a=>""===a?void 0:p(a)?T(a,ja):ta(a)?ca(a,ja):a,Ba=/^\d+$/,Ja=ya(),Ya=ya(),ka=(a,t,n,s,i,r,o,c={},l=0,w=[])=>{let d,v,E,N=0,m=0,C=0;pa(Ja,w,()=>0),pa(Ya,w,()=>[]);const T=ya(),[O,b,S,R,_]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!ua(a)||!ua(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!ua(a)||!ua(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=>{Ba.test(t)&&A(a)<1e3&&D(a,t)}]})(),s=ya();return[(n,i,r,o=[],c=()=>[])=>{a??=V;const l=t(1);return va(s,l,[n,i,r,o,c]),Na(Ea(i,r??[e],Aa),l),l},(t,n,...i)=>h(((a,t=[e])=>{const n=[],s=(a,e)=>e==A(t)?D(n,a):y(t[e])?P(a,a=>s(a,e+1)):h([t[e],null],t=>s(da(a,t),e+1));return s(a,0),n})(t,n),t=>P(t,t=>da(s,t)[0](a,...n??[],...i))),a=>g(da(s,a),([,t,i])=>(Ea(t,i??[e],void 0,t=>(M(t,a),L(t)?1:0)),va(s,a),n(a),i)),t=>g(da(s,t),([t,,e=[],n,s])=>{const i=(...r)=>{const o=A(r);o==A(e)?t(a,...r,...s(r)):y(e[o])?h(n[o]?.(...r)??[],a=>i(...r,a)):i(...r,e[o])};i()})]})(),B=a=>{a!=N&&(N=a,U(T,void 0,N))},J=t=>{(O&&p(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},Y=async a=>(2!=N&&(B(1),m++,await Q(async()=>{await f(async()=>{const e=await t();p(e)?J(e):a?_(a):$("Content is not an array: "+e)},()=>{a&&_(a)}),B(0)})),V),k=async a=>(x(),await Y(a),await f(async()=>v=await s(async(a,t)=>{t||a?2!=N&&(B(1),m++,J(t??a),B(0)):await Y()}),r),V),x=async()=>(v&&(await f(()=>i(v),r),v=void 0),V),z=async a=>(1!=N&&(B(2),C++,await Q(async()=>{await f(()=>n(b,a),r),B(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,x]:[x,H];return await t(),await e(),V},Q=async(...a)=>(D(da(Ya,w),...a),await(async()=>{if(!da(Ja,w)){for(va(Ja,w,1);!u(d=I(da(Ya,w)));)await f(d,r);va(Ja,w,0)}})(),V),V={load:Y,startAutoLoad:k,stopAutoLoad:x,isAutoLoading:()=>!u(v),save:z,startAutoSave:G,stopAutoSave:H,isAutoSaving:()=>!u(E),startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[G,k]:[k,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:()=>(da(Ya,w).splice(0,void 0),K()),getStats:()=>({loads:m,saves:C}),...c};return na(V)},xa=(a,t,e,s,r,o=za,c,l)=>{const w=ya();return[async()=>{w.clear(),T(await e(a,t),({tn:a,cn:t})=>Na(pa(w,a,Aa),t))},async(t,e,n)=>((a,t)=>S(da(w,a),t))(t,e)?sa(b(T(await a(x+V(t)+X(t,n)),a=>[a[e],l?ca(ra(a,e),l):ra(a,e)]),([a,t])=>!u(a)&&!ua(t))):{},async(t,e,s,l,y,d=!1,g=i)=>{const v=Aa();ca(s??{},a=>T(ea(a??{}),a=>Na(v,a)));const p=R(v);if(!d&&y&&g==i&&O(p)&&S(w,t))return await a("DROP "+B+V(t)),void va(w,t);const E=da(w,t),A=Aa(R(E));if(O(p)||(S(w,t)?await m(T([e,...p],async(n,s)=>{M(A,n)||(await a(J+V(t)+"ADD"+V(n)+r),0==s&&await a("CREATE UNIQUE INDEX pk ON "+V(t)+`(${V(e)})`),Na(E,n))})):(await a(Q+V(t)+`(${V(e)}${r} PRIMARY KEY${C(T(p,a=>n+V(a)+r))});`),va(w,t,Aa([e,...p])))),await m([...!d&&l?T(R(A),async n=>{n!=e&&(await a(J+V(t)+"DROP"+V(n)),M(E,n))}):[]]),d)u(s)?await a(k+V(t)+X(t,g)):await m(oa(s,async(n,s)=>{u(n)?await a(k+V(t)+X(t,g)+`AND(${V(e)}=$1)`,[s]):O(p)||await o(a,t,e,ea(n),{[s]:c?T(la(n),c):la(n)},E)}));else if(O(p))S(w,t)&&await a(k+V(t)+X(t,g));else{const n=b(R(da(w,t)),a=>a!=e),i={},r=[];ca(s??{},(a,t)=>{i[t]=T(n,t=>c?c(a?.[t]):a?.[t]),D(r,t)}),await o(a,t,e,n,i),await a(k+V(t)+X(t,g)+`AND${V(e)}NOT IN(${W(r)})`,r)}},async t=>{let e;return await a("BEGIN"),await f(async()=>e=await t(),s),await a("END"),e}]},za=async(a,t,e,s,i)=>{const r=[1];await a("INSERT INTO"+V(t)+"("+((...a)=>C(T(a,V),n))(e,...s)+")VALUES"+C(oa(i,a=>"($"+r[0]+++","+W(a,r)+")"),n)+"ON CONFLICT("+V(e)+")DO UPDATE SET"+C(T(s,a=>V(a)+"=excluded."+V(a)),n),oa(i,(a,t)=>[t,...T(a,a=>a??null)]).flat())},Ga=(a,t,e,n,s,i,r,[o,c,l],w,y,d,g,v,p)=>{const[E,A,N,m]=xa(t,w,y,s,v,p),$=ka(a,()=>m(async()=>{return await E(),a=(await A(o,c))[_]?.[l]??"null",ja(Ua(a));var a}),a=>m(async()=>{var t;await E(),await N(o,c,{[_]:{[l]:(t=a()??null,Fa(t,(a,t)=>u(t)?"":t))}},!0,!0)}),e,n,s,r,{[g]:()=>d,destroy:async()=>(await $.stopAutoPersisting(),i(),$)},0,d);return $},Ha=(a,t,e,n,s,i,r,[o,c,[l,w,y]],d,g,v,p,E,A,N,$)=>{const[f,h,C,T]=xa(t,d,g,s,E,A,N,$),O=(a,t)=>m(ga(c,async([e,n,s,i,r],o)=>{t&&!(o in a)||await C(e,n,a[o],s,i,t,r)})),D=async(a,t)=>w?await C(y,F,{[_]:a},!0,!0,t):null,I=ka(a,()=>T(async()=>{await f();const a=await(async()=>sa(b(await m(ga(o,async([a,t,e],n)=>[a,await h(n,t,e)])),a=>!ua(a[1]))))(),t=await(async()=>l?(await h(y,F))[_]:{})();return ua(a)&&u(t)?void 0:[a,t]}),(a,t)=>T(async()=>{if(await f(),u(t)){const[t,e]=a();await O(t),await D(e)}else await O(t[0],!0),await D(t[1],!0)}),e,n,s,r,{[p]:()=>v,destroy:async()=>(await I.stopAutoPersisting(),i(),I)},0,v);return I},Ka=(a,n,s,r,o,c,u,y,d,g,p="getDb",A)=>{let N,m,$;const h=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,c),[C,T,O,b]=(a=>{const e=(a=>ia(Pa,v(a)?{[ha]:a}:a??{}))(a),n=e[Oa];if(e.mode==fa){const a=e[ha]??t;return[1,n,[a,e[Ca]??F,e[Ta]??$a],Aa(a)]}const{tables:{load:s={},save:r={}}={},values:o={}}=e,c=E(la(ia(Ma,o)),0,wa(Ma)),l=c[2],w=Aa(l),u=Aa(l),y=_a(s,{[Da]:null,[ba]:F,[Ra]:i},Da,a=>S(u,a),a=>Na(w,a)),d=_a(r,{[Ia]:null,[ba]:F,[Sa]:0,[La]:0,[Ra]:null},Ia,(a,t)=>S(u,t),(a,t)=>Na(w,t));var g;return g=(a,t)=>t[4]??=da(y,t[0])?.[2]??i,P(d,(a,t)=>g(0,a)),[0,n,[y,d,c],w]})(n);return(C?Ga:Ha)(a,h,a=>{let t;const e=()=>t=setInterval(()=>f(async()=>{const[{d:t,s:e,c:n}]=await h(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=r(t=>{b.has(t)&&(n(),a(),e())});return e(),()=>{n(),o(s)}},a=>a(),u,y,d,O,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),g,p,e,A,a=>(a=>!0===a)(a)?1:(a=>!1===a)(a)?0:a,void 0)},Qa="change",Va=(a,t,e,n,s)=>Ka(a,e,async(a,e=[])=>{return await(n=(n,s)=>t.all(a,e,(a,t)=>a?s(a):n(t)),new o(n));var n},a=>{const e=(t,e,n)=>a(n);return t.on(Qa,e),e},a=>t.off(Qa,a),n,s,N,3,t);export{Va as createSqlite3Persister};
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,p=a=>Array.isArray(a),E=(a,t,e)=>a.slice(t,e),A=a=>a.length,N=()=>{},m=async a=>o.all(a),$=a=>{throw Error(a)},f=async(a,t,e)=>{try{return await a()}catch(a){t?.(a)}},h=(a,t)=>a.forEach(t),C=(a,t="")=>a.join(t),T=(a,t)=>a.map(t),O=a=>0==A(a),b=(a,t)=>a.filter(t),D=(a,...t)=>a.push(...t),I=a=>a.shift(),S=(a,t)=>a?.has(t)??!1,L=a=>u(a)||0==(a=>a?.size??0)(a),R=a=>[...a?.values()??[]],M=(a,t)=>a?.forEach(t),P=(a,t)=>a?.delete(t),_="_",F="_id",U="SELECT",j="WHERE",B="TABLE",J="ALTER "+B,Y="FROM",k="DELETE "+Y,x=U+"*"+Y,z="pragma_",G="data_version",H="schema_version",K="pragma_table_",Q="CREATE "+B,V=a=>C(T(((a,t="",e)=>a.split(t,e))(a,"."),a=>`"${r(a,/"/g,'""')}"`),"."),W=(a,t=[1])=>C(T(a,()=>"$"+t[0]++),n),X=(a,t=i)=>j+`(${r(t,"$tableName",V(a))})`,q=Object,Z=a=>q.getPrototypeOf(a),aa=q.entries,ta=a=>!w(a)&&d(Z(a),a=>a==q.prototype||w(Z(a)),()=>!0),ea=q.keys,na=q.freeze,sa=(a=[])=>q.fromEntries(a),ia=(...a)=>q.assign({},...a),ra=(a,t)=>(delete a[t],a),oa=(a,t)=>T(aa(a),([a,e])=>t(e,a)),ca=(a,t)=>sa(oa(a,(a,e)=>[e,t(a,e)])),la=a=>q.values(a),wa=a=>A(ea(a)),ua=a=>ta(a)&&0==wa(a),ya=Map,da=a=>new ya(a),ga=(a,t)=>a?.get(t),va=(a,t)=>T([...a?.entries()??[]],([a,e])=>t(e,a)),pa=(a,t,e)=>u(e)?(P(a,t),a):a?.set(t,e),Ea=(a,t,e,n)=>(S(a,t)?n?.(ga(a,t)):pa(a,t,e()),ga(a,t)),Aa=(a,t,e,n,s=0)=>g((e?Ea:ga)(a,t[s],s>A(t)-2?e:da),i=>{if(s>A(t)-2)return n?.(i)&&pa(a,t[s]),i;const r=Aa(i,t,e,n,s+1);return L(i)&&pa(a,t[s]),r}),Na=a=>new Set(p(a)||u(a)?a:[a]),ma=(a,t)=>a?.add(t),$a="ColumnName",fa="store",ha="json",Ca=fa+"TableName",Ta=fa+"Id"+$a,Oa=fa+$a,ba="autoLoadIntervalSeconds",Da="rowId"+$a,Ia="tableId",Sa="tableName",La="deleteEmptyColumns",Ra="deleteEmptyTable",Ma="condition",Pa={mode:ha,[ba]:1},_a={load:0,save:0,[Sa]:t+"_values"},Fa=(a,t,e,n,s)=>{const i=da();return ca(a,(a,r)=>{const o=E(la(ia(t,v(a)?{[e]:a}:a)),0,wa(t));y(o[0])||n(r,o[0])||(s(r,o[0]),pa(i,r,o))}),i},Ua=JSON.stringify,ja=JSON.parse,Ba=a=>""===a?void 0:p(a)?T(a,Ba):ta(a)?ca(a,Ba):a,Ja=/^\d+$/,Ya=da(),ka=da(),xa=(a,t,n,s,i,r,o,c={},l=0,w=[])=>{let d,v,E,N=0,m=0,C=0;Ea(Ya,w,()=>0),Ea(ka,w,()=>[]);const T=da(),[O,b,S,R,_]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!ua(a)||!ua(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!ua(a)||!ua(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=>{Ja.test(t)&&A(a)<1e3&&D(a,t)}]})(),s=da();return[(n,i,r,o=[],c=()=>[])=>{a??=X;const l=t(1);return pa(s,l,[n,i,r,o,c]),ma(Aa(i,r??[e],Na),l),l},(t,n,...i)=>h(((a,t=[e])=>{const n=[],s=(a,e)=>e==A(t)?D(n,a):y(t[e])?M(a,a=>s(a,e+1)):h([t[e],null],t=>s(ga(a,t),e+1));return s(a,0),n})(t,n),t=>M(t,t=>ga(s,t)[0](a,...n??[],...i))),a=>g(ga(s,a),([,t,i])=>(Aa(t,i??[e],void 0,t=>(P(t,a),L(t)?1:0)),pa(s,a),n(a),i)),t=>g(ga(s,t),([t,,e=[],n,s])=>{const i=(...r)=>{const o=A(r);o==A(e)?t(a,...r,...s(r)):y(e[o])?h(n[o]?.(...r)??[],a=>i(...r,a)):i(...r,e[o])};i()})]})(),B=a=>{a!=N&&(N=a,U(T,void 0,N))},J=t=>{(O&&p(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},Y=async()=>{Q()&&a.hadMutated?.()&&await G()},k=async a=>(2!=N&&(B(1),m++,await W(async()=>{await f(async()=>{const e=await t();p(e)?J(e):a?_(a):$("Content is not an array: "+e)},()=>{a&&_(a)}),B(0),await Y()})),X),x=async a=>(z(),await k(a),await f(async()=>v=await s(async(a,t)=>{t||a?2!=N&&(B(1),m++,J(t??a),B(0),await Y()):await k()}),r),X),z=async()=>(v&&(await f(()=>i(v),r),v=void 0),X),G=async a=>(1!=N&&(B(2),C++,await W(async()=>{await f(()=>n(b,a),r),B(0)})),X),H=async()=>(K(),await G(),E=a.addDidFinishTransactionListener(()=>{const a=S();R(a)&&G(a)}),X),K=async()=>(E&&(a.delListener(E),E=void 0),X),Q=()=>!u(E),V=async(a=!1)=>{const[t,e]=a?[K,z]:[z,K];return await t(),await e(),X},W=async(...a)=>(D(ga(ka,w),...a),await(async()=>{if(!ga(Ya,w)){for(pa(Ya,w,1);!u(d=I(ga(ka,w)));)await f(d,r);pa(Ya,w,0)}})(),X),X={load:k,startAutoLoad:x,stopAutoLoad:z,isAutoLoading:()=>!u(v),save:G,startAutoSave:H,stopAutoSave:K,isAutoSaving:Q,startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[H,x]:[x,H];return await e(a),await n(a),X},stopAutoPersisting:V,getStatus:()=>N,addStatusListener:a=>F(a,T),delListener:t=>(j(t),a),schedule:W,getStore:()=>a,destroy:()=>(ga(ka,w).splice(0,void 0),V()),getStats:()=>({loads:m,saves:C}),...c};return na(X)},za=(a,t,e,s,r,o=Ga,c,l)=>{const w=da();return[async()=>{w.clear(),T(await e(a,t),({tn:a,cn:t})=>ma(Ea(w,a,Na),t))},async(t,e,n)=>((a,t)=>S(ga(w,a),t))(t,e)?sa(b(T(await a(x+V(t)+X(t,n)),a=>[a[e],l?ca(ra(a,e),l):ra(a,e)]),([a,t])=>!u(a)&&!ua(t))):{},async(t,e,s,l,y,d=!1,g=i)=>{const v=Na();ca(s??{},a=>T(ea(a??{}),a=>ma(v,a)));const p=R(v);if(!d&&y&&g==i&&O(p)&&S(w,t))return await a("DROP "+B+V(t)),void pa(w,t);const E=ga(w,t),A=Na(R(E));if(O(p)||(S(w,t)?await m(T([e,...p],async(n,s)=>{P(A,n)||(await a(J+V(t)+"ADD"+V(n)+r),0==s&&await a("CREATE UNIQUE INDEX pk ON "+V(t)+`(${V(e)})`),ma(E,n))})):(await a(Q+V(t)+`(${V(e)}${r} PRIMARY KEY${C(T(p,a=>n+V(a)+r))});`),pa(w,t,Na([e,...p])))),await m([...!d&&l?T(R(A),async n=>{n!=e&&(await a(J+V(t)+"DROP"+V(n)),P(E,n))}):[]]),d)u(s)?await a(k+V(t)+X(t,g)):await m(oa(s,async(n,s)=>{u(n)?await a(k+V(t)+X(t,g)+`AND(${V(e)}=$1)`,[s]):O(p)||await o(a,t,e,ea(n),{[s]:c?T(la(n),c):la(n)},E)}));else if(O(p))S(w,t)&&await a(k+V(t)+X(t,g));else{const n=b(R(ga(w,t)),a=>a!=e),i={},r=[];ca(s??{},(a,t)=>{i[t]=T(n,t=>c?c(a?.[t]):a?.[t]),D(r,t)}),await o(a,t,e,n,i),await a(k+V(t)+X(t,g)+`AND${V(e)}NOT IN(${W(r)})`,r)}},async t=>{let e;return await a("BEGIN"),await f(async()=>e=await t(),s),await a("END"),e}]},Ga=async(a,t,e,s,i)=>{const r=[1];await a("INSERT INTO"+V(t)+"("+((...a)=>C(T(a,V),n))(e,...s)+")VALUES"+C(oa(i,a=>"($"+r[0]+++","+W(a,r)+")"),n)+"ON CONFLICT("+V(e)+")DO UPDATE SET"+C(T(s,a=>V(a)+"=excluded."+V(a)),n),oa(i,(a,t)=>[t,...T(a,a=>a??null)]).flat())},Ha=(a,t,e,n,s,i,r,[o,c,l],w,y,d,g,v,p)=>{const[E,A,N,m]=za(t,w,y,s,v,p),$=xa(a,()=>m(async()=>{return await E(),a=(await A(o,c))[_]?.[l]??"null",Ba(ja(a));var a}),a=>m(async()=>{var t;await E(),await N(o,c,{[_]:{[l]:(t=a()??null,Ua(t,(a,t)=>u(t)?"":t))}},!0,!0)}),e,n,s,r,{[g]:()=>d,destroy:async()=>(await $.stopAutoPersisting(),i(),$)},0,d);return $},Ka=(a,t,e,n,s,i,r,[o,c,[l,w,y]],d,g,v,p,E,A,N,$)=>{const[f,h,C,T]=za(t,d,g,s,E,A,N,$),O=(a,t)=>m(va(c,async([e,n,s,i,r],o)=>{t&&!(o in a)||await C(e,n,a[o],s,i,t,r)})),D=async(a,t)=>w?await C(y,F,{[_]:a},!0,!0,t):null,I=xa(a,()=>T(async()=>{await f();const a=await(async()=>sa(b(await m(va(o,async([a,t,e],n)=>[a,await h(n,t,e)])),a=>!ua(a[1]))))(),t=await(async()=>l?(await h(y,F))[_]:{})();return ua(a)&&u(t)?void 0:[a,t]}),(a,t)=>T(async()=>{if(await f(),u(t)){const[t,e]=a();await O(t),await D(e)}else await O(t[0],!0),await D(t[1],!0)}),e,n,s,r,{[p]:()=>v,destroy:async()=>(await I.stopAutoPersisting(),i(),I)},0,v);return I},Qa=(a,n,s,r,o,c,u,y,d,g,p="getDb",A)=>{let N,m,$;const h=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,c),[C,T,O,b]=(a=>{const e=(a=>ia(Pa,v(a)?{[Ca]:a}:a??{}))(a),n=e[ba];if(e.mode==ha){const a=e[Ca]??t;return[1,n,[a,e[Ta]??F,e[Oa]??fa],Na(a)]}const{tables:{load:s={},save:r={}}={},values:o={}}=e,c=E(la(ia(_a,o)),0,wa(_a)),l=c[2],w=Na(l),u=Na(l),y=Fa(s,{[Ia]:null,[Da]:F,[Ma]:i},Ia,a=>S(u,a),a=>ma(w,a)),d=Fa(r,{[Sa]:null,[Da]:F,[La]:0,[Ra]:0,[Ma]:null},Sa,(a,t)=>S(u,t),(a,t)=>ma(w,t));var g;return g=(a,t)=>t[4]??=ga(y,t[0])?.[2]??i,M(d,(a,t)=>g(0,a)),[0,n,[y,d,c],w]})(n);return(C?Ha:Ka)(a,h,a=>{let t;const e=()=>t=setInterval(()=>f(async()=>{const[{d:t,s:e,c:n}]=await h(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=r(t=>{b.has(t)&&(n(),a(),e())});return e(),()=>{n(),o(s)}},a=>a(),u,y,d,O,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),g,p,e,A,a=>(a=>!0===a)(a)?1:(a=>!1===a)(a)?0:a,void 0)},Va="change",Wa=(a,t,e,n,s)=>Qa(a,e,async(a,e=[])=>{return await(n=(n,s)=>t.all(a,e,(a,t)=>a?s(a):n(t)),new o(n));var n},a=>{const e=(t,e,n)=>a(n);return t.on(Va,e),e},a=>t.off(Va,a),n,s,N,3,t);export{Wa as createSqlite3Persister};
@@ -1 +1 @@
1
- const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),i="true",r=(a,t,e)=>a.replace(t,e),o=Promise,c=a=>(t,e,n)=>a(t)?n?.():e(t),l=clearInterval,w=a=>null==a,u=a=>void 0===a,y=a=>null===a,d=c(w),g=c(u),v=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=>o.all(a),$=a=>{throw Error(a)},f=async(a,t,e)=>{try{return await a()}catch(a){t?.(a)}},h=(a,t)=>a.forEach(t),C=(a,t="")=>a.join(t),T=(a,t)=>a.map(t),O=a=>0==A(a),b=(a,t)=>a.filter(t),D=(a,...t)=>a.push(...t),I=a=>a.shift(),S=(a,t)=>a?.has(t)??!1,L=a=>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",K="pragma_table_",Q="CREATE "+B,V=a=>C(T(((a,t="",e)=>a.split(t,e))(a,"."),a=>`"${r(a,/"/g,'""')}"`),"."),W=(a,t=[1])=>C(T(a,()=>"$"+t[0]++),n),X=(a,t=i)=>j+`(${r(t,"$tableName",V(a))})`,q=Object,Z=a=>q.getPrototypeOf(a),aa=q.entries,ta=a=>!w(a)&&d(Z(a),a=>a==q.prototype||w(Z(a)),()=>!0),ea=q.keys,na=q.freeze,sa=(a=[])=>q.fromEntries(a),ia=(...a)=>q.assign({},...a),ra=(a,t)=>(delete a[t],a),oa=(a,t)=>T(aa(a),([a,e])=>t(e,a)),ca=(a,t)=>sa(oa(a,(a,e)=>[e,t(a,e)])),la=a=>q.values(a),wa=a=>A(ea(a)),ua=a=>ta(a)&&0==wa(a),ya=a=>new Map(a),da=(a,t)=>a?.get(t),ga=(a,t)=>T([...a?.entries()??[]],([a,e])=>t(e,a)),va=(a,t,e)=>u(e)?(M(a,t),a):a?.set(t,e),pa=(a,t,e,n)=>(S(a,t)?n?.(da(a,t)):va(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:ya),i=>{if(s>A(t)-2)return n?.(i)&&va(a,t[s]),i;const r=Ea(i,t,e,n,s+1);return L(i)&&va(a,t[s]),r}),Aa=a=>new Set(p(a)||u(a)?a:[a]),Na=(a,t)=>a?.add(t),ma="ColumnName",$a="store",fa="json",ha=$a+"TableName",Ca=$a+"Id"+ma,Ta=$a+ma,Oa="autoLoadIntervalSeconds",ba="rowId"+ma,Da="tableId",Ia="tableName",Sa="deleteEmptyColumns",La="deleteEmptyTable",Ra="condition",Pa={mode:fa,[Oa]:1},Ma={load:0,save:0,[Ia]:t+"_values"},_a=(a,t,e,n,s)=>{const i=ya();return ca(a,(a,r)=>{const o=E(la(ia(t,v(a)?{[e]:a}:a)),0,wa(t));y(o[0])||n(r,o[0])||(s(r,o[0]),va(i,r,o))}),i},Fa=JSON.stringify,Ua=JSON.parse,ja=a=>""===a?void 0:p(a)?T(a,ja):ta(a)?ca(a,ja):a,Ba=/^\d+$/,Ja=ya(),Ya=ya(),ka=(a,t,n,s,i,r,o,c={},l=0,w=[])=>{let d,v,E,N=0,m=0,C=0;pa(Ja,w,()=>0),pa(Ya,w,()=>[]);const T=ya(),[O,b,S,R,_]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!ua(a)||!ua(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!ua(a)||!ua(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=>{Ba.test(t)&&A(a)<1e3&&D(a,t)}]})(),s=ya();return[(n,i,r,o=[],c=()=>[])=>{a??=V;const l=t(1);return va(s,l,[n,i,r,o,c]),Na(Ea(i,r??[e],Aa),l),l},(t,n,...i)=>h(((a,t=[e])=>{const n=[],s=(a,e)=>e==A(t)?D(n,a):y(t[e])?P(a,a=>s(a,e+1)):h([t[e],null],t=>s(da(a,t),e+1));return s(a,0),n})(t,n),t=>P(t,t=>da(s,t)[0](a,...n??[],...i))),a=>g(da(s,a),([,t,i])=>(Ea(t,i??[e],void 0,t=>(M(t,a),L(t)?1:0)),va(s,a),n(a),i)),t=>g(da(s,t),([t,,e=[],n,s])=>{const i=(...r)=>{const o=A(r);o==A(e)?t(a,...r,...s(r)):y(e[o])?h(n[o]?.(...r)??[],a=>i(...r,a)):i(...r,e[o])};i()})]})(),B=a=>{a!=N&&(N=a,U(T,void 0,N))},J=t=>{(O&&p(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},Y=async a=>(2!=N&&(B(1),m++,await Q(async()=>{await f(async()=>{const e=await t();p(e)?J(e):a?_(a):$("Content is not an array: "+e)},()=>{a&&_(a)}),B(0)})),V),k=async a=>(x(),await Y(a),await f(async()=>v=await s(async(a,t)=>{t||a?2!=N&&(B(1),m++,J(t??a),B(0)):await Y()}),r),V),x=async()=>(v&&(await f(()=>i(v),r),v=void 0),V),z=async a=>(1!=N&&(B(2),C++,await Q(async()=>{await f(()=>n(b,a),r),B(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,x]:[x,H];return await t(),await e(),V},Q=async(...a)=>(D(da(Ya,w),...a),await(async()=>{if(!da(Ja,w)){for(va(Ja,w,1);!u(d=I(da(Ya,w)));)await f(d,r);va(Ja,w,0)}})(),V),V={load:Y,startAutoLoad:k,stopAutoLoad:x,isAutoLoading:()=>!u(v),save:z,startAutoSave:G,stopAutoSave:H,isAutoSaving:()=>!u(E),startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[G,k]:[k,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:()=>(da(Ya,w).splice(0,void 0),K()),getStats:()=>({loads:m,saves:C}),...c};return na(V)},xa=(a,t,e,s,r,o=za,c,l)=>{const w=ya();return[async()=>{w.clear(),T(await e(a,t),({tn:a,cn:t})=>Na(pa(w,a,Aa),t))},async(t,e,n)=>((a,t)=>S(da(w,a),t))(t,e)?sa(b(T(await a(x+V(t)+X(t,n)),a=>[a[e],l?ca(ra(a,e),l):ra(a,e)]),([a,t])=>!u(a)&&!ua(t))):{},async(t,e,s,l,y,d=!1,g=i)=>{const v=Aa();ca(s??{},a=>T(ea(a??{}),a=>Na(v,a)));const p=R(v);if(!d&&y&&g==i&&O(p)&&S(w,t))return await a("DROP "+B+V(t)),void va(w,t);const E=da(w,t),A=Aa(R(E));if(O(p)||(S(w,t)?await m(T([e,...p],async(n,s)=>{M(A,n)||(await a(J+V(t)+"ADD"+V(n)+r),0==s&&await a("CREATE UNIQUE INDEX pk ON "+V(t)+`(${V(e)})`),Na(E,n))})):(await a(Q+V(t)+`(${V(e)}${r} PRIMARY KEY${C(T(p,a=>n+V(a)+r))});`),va(w,t,Aa([e,...p])))),await m([...!d&&l?T(R(A),async n=>{n!=e&&(await a(J+V(t)+"DROP"+V(n)),M(E,n))}):[]]),d)u(s)?await a(k+V(t)+X(t,g)):await m(oa(s,async(n,s)=>{u(n)?await a(k+V(t)+X(t,g)+`AND(${V(e)}=$1)`,[s]):O(p)||await o(a,t,e,ea(n),{[s]:c?T(la(n),c):la(n)},E)}));else if(O(p))S(w,t)&&await a(k+V(t)+X(t,g));else{const n=b(R(da(w,t)),a=>a!=e),i={},r=[];ca(s??{},(a,t)=>{i[t]=T(n,t=>c?c(a?.[t]):a?.[t]),D(r,t)}),await o(a,t,e,n,i),await a(k+V(t)+X(t,g)+`AND${V(e)}NOT IN(${W(r)})`,r)}},async t=>{let e;return await a("BEGIN"),await f(async()=>e=await t(),s),await a("END"),e}]},za=async(a,t,e,s,i)=>{const r=[1];await a("INSERT INTO"+V(t)+"("+((...a)=>C(T(a,V),n))(e,...s)+")VALUES"+C(oa(i,a=>"($"+r[0]+++","+W(a,r)+")"),n)+"ON CONFLICT("+V(e)+")DO UPDATE SET"+C(T(s,a=>V(a)+"=excluded."+V(a)),n),oa(i,(a,t)=>[t,...T(a,a=>a??null)]).flat())},Ga=(a,t,e,n,s,i,r,[o,c,l],w,y,d,g,v,p)=>{const[E,A,N,m]=xa(t,w,y,s,v,p),$=ka(a,()=>m(async()=>{return await E(),a=(await A(o,c))[_]?.[l]??"null",ja(Ua(a));var a}),a=>m(async()=>{var t;await E(),await N(o,c,{[_]:{[l]:(t=a()??null,Fa(t,(a,t)=>u(t)?"":t))}},!0,!0)}),e,n,s,r,{[g]:()=>d,destroy:async()=>(await $.stopAutoPersisting(),i(),$)},0,d);return $},Ha=(a,t,e,n,s,i,r,[o,c,[l,w,y]],d,g,v,p,E,A,N,$)=>{const[f,h,C,T]=xa(t,d,g,s,E,A,N,$),O=(a,t)=>m(ga(c,async([e,n,s,i,r],o)=>{t&&!(o in a)||await C(e,n,a[o],s,i,t,r)})),D=async(a,t)=>w?await C(y,F,{[_]:a},!0,!0,t):null,I=ka(a,()=>T(async()=>{await f();const a=await(async()=>sa(b(await m(ga(o,async([a,t,e],n)=>[a,await h(n,t,e)])),a=>!ua(a[1]))))(),t=await(async()=>l?(await h(y,F))[_]:{})();return ua(a)&&u(t)?void 0:[a,t]}),(a,t)=>T(async()=>{if(await f(),u(t)){const[t,e]=a();await O(t),await D(e)}else await O(t[0],!0),await D(t[1],!0)}),e,n,s,r,{[p]:()=>v,destroy:async()=>(await I.stopAutoPersisting(),i(),I)},0,v);return I},Ka=(a,n,s,r,o,c,u,y,d,g,p="getDb",A)=>{let N,m,$;const h=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,c),[C,T,O,b]=(a=>{const e=(a=>ia(Pa,v(a)?{[ha]:a}:a??{}))(a),n=e[Oa];if(e.mode==fa){const a=e[ha]??t;return[1,n,[a,e[Ca]??F,e[Ta]??$a],Aa(a)]}const{tables:{load:s={},save:r={}}={},values:o={}}=e,c=E(la(ia(Ma,o)),0,wa(Ma)),l=c[2],w=Aa(l),u=Aa(l),y=_a(s,{[Da]:null,[ba]:F,[Ra]:i},Da,a=>S(u,a),a=>Na(w,a)),d=_a(r,{[Ia]:null,[ba]:F,[Sa]:0,[La]:0,[Ra]:null},Ia,(a,t)=>S(u,t),(a,t)=>Na(w,t));var g;return g=(a,t)=>t[4]??=da(y,t[0])?.[2]??i,P(d,(a,t)=>g(0,a)),[0,n,[y,d,c],w]})(n);return(C?Ga:Ha)(a,h,a=>{let t;const e=()=>t=setInterval(()=>f(async()=>{const[{d:t,s:e,c:n}]=await h(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=r(t=>{b.has(t)&&(n(),a(),e())});return e(),()=>{n(),o(s)}},a=>a(),u,y,d,O,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),g,p,e,A,a=>(a=>!0===a)(a)?1:(a=>!1===a)(a)?0:a,void 0)},Qa="change",Va=(a,t,e,n,s)=>Ka(a,e,async(a,e=[])=>{return await(n=(n,s)=>t.all(a,e,(a,t)=>a?s(a):n(t)),new o(n));var n},a=>{const e=(t,e,n)=>a(n);return t.on(Qa,e),e},a=>t.off(Qa,a),n,s,N,3,t);export{Va as createSqlite3Persister};
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,p=a=>Array.isArray(a),E=(a,t,e)=>a.slice(t,e),A=a=>a.length,N=()=>{},m=async a=>o.all(a),$=a=>{throw Error(a)},f=async(a,t,e)=>{try{return await a()}catch(a){t?.(a)}},h=(a,t)=>a.forEach(t),C=(a,t="")=>a.join(t),T=(a,t)=>a.map(t),O=a=>0==A(a),b=(a,t)=>a.filter(t),D=(a,...t)=>a.push(...t),I=a=>a.shift(),S=(a,t)=>a?.has(t)??!1,L=a=>u(a)||0==(a=>a?.size??0)(a),R=a=>[...a?.values()??[]],M=(a,t)=>a?.forEach(t),P=(a,t)=>a?.delete(t),_="_",F="_id",U="SELECT",j="WHERE",B="TABLE",J="ALTER "+B,Y="FROM",k="DELETE "+Y,x=U+"*"+Y,z="pragma_",G="data_version",H="schema_version",K="pragma_table_",Q="CREATE "+B,V=a=>C(T(((a,t="",e)=>a.split(t,e))(a,"."),a=>`"${r(a,/"/g,'""')}"`),"."),W=(a,t=[1])=>C(T(a,()=>"$"+t[0]++),n),X=(a,t=i)=>j+`(${r(t,"$tableName",V(a))})`,q=Object,Z=a=>q.getPrototypeOf(a),aa=q.entries,ta=a=>!w(a)&&d(Z(a),a=>a==q.prototype||w(Z(a)),()=>!0),ea=q.keys,na=q.freeze,sa=(a=[])=>q.fromEntries(a),ia=(...a)=>q.assign({},...a),ra=(a,t)=>(delete a[t],a),oa=(a,t)=>T(aa(a),([a,e])=>t(e,a)),ca=(a,t)=>sa(oa(a,(a,e)=>[e,t(a,e)])),la=a=>q.values(a),wa=a=>A(ea(a)),ua=a=>ta(a)&&0==wa(a),ya=Map,da=a=>new ya(a),ga=(a,t)=>a?.get(t),va=(a,t)=>T([...a?.entries()??[]],([a,e])=>t(e,a)),pa=(a,t,e)=>u(e)?(P(a,t),a):a?.set(t,e),Ea=(a,t,e,n)=>(S(a,t)?n?.(ga(a,t)):pa(a,t,e()),ga(a,t)),Aa=(a,t,e,n,s=0)=>g((e?Ea:ga)(a,t[s],s>A(t)-2?e:da),i=>{if(s>A(t)-2)return n?.(i)&&pa(a,t[s]),i;const r=Aa(i,t,e,n,s+1);return L(i)&&pa(a,t[s]),r}),Na=a=>new Set(p(a)||u(a)?a:[a]),ma=(a,t)=>a?.add(t),$a="ColumnName",fa="store",ha="json",Ca=fa+"TableName",Ta=fa+"Id"+$a,Oa=fa+$a,ba="autoLoadIntervalSeconds",Da="rowId"+$a,Ia="tableId",Sa="tableName",La="deleteEmptyColumns",Ra="deleteEmptyTable",Ma="condition",Pa={mode:ha,[ba]:1},_a={load:0,save:0,[Sa]:t+"_values"},Fa=(a,t,e,n,s)=>{const i=da();return ca(a,(a,r)=>{const o=E(la(ia(t,v(a)?{[e]:a}:a)),0,wa(t));y(o[0])||n(r,o[0])||(s(r,o[0]),pa(i,r,o))}),i},Ua=JSON.stringify,ja=JSON.parse,Ba=a=>""===a?void 0:p(a)?T(a,Ba):ta(a)?ca(a,Ba):a,Ja=/^\d+$/,Ya=da(),ka=da(),xa=(a,t,n,s,i,r,o,c={},l=0,w=[])=>{let d,v,E,N=0,m=0,C=0;Ea(Ya,w,()=>0),Ea(ka,w,()=>[]);const T=da(),[O,b,S,R,_]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!ua(a)||!ua(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!ua(a)||!ua(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=>{Ja.test(t)&&A(a)<1e3&&D(a,t)}]})(),s=da();return[(n,i,r,o=[],c=()=>[])=>{a??=X;const l=t(1);return pa(s,l,[n,i,r,o,c]),ma(Aa(i,r??[e],Na),l),l},(t,n,...i)=>h(((a,t=[e])=>{const n=[],s=(a,e)=>e==A(t)?D(n,a):y(t[e])?M(a,a=>s(a,e+1)):h([t[e],null],t=>s(ga(a,t),e+1));return s(a,0),n})(t,n),t=>M(t,t=>ga(s,t)[0](a,...n??[],...i))),a=>g(ga(s,a),([,t,i])=>(Aa(t,i??[e],void 0,t=>(P(t,a),L(t)?1:0)),pa(s,a),n(a),i)),t=>g(ga(s,t),([t,,e=[],n,s])=>{const i=(...r)=>{const o=A(r);o==A(e)?t(a,...r,...s(r)):y(e[o])?h(n[o]?.(...r)??[],a=>i(...r,a)):i(...r,e[o])};i()})]})(),B=a=>{a!=N&&(N=a,U(T,void 0,N))},J=t=>{(O&&p(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},Y=async()=>{Q()&&a.hadMutated?.()&&await G()},k=async a=>(2!=N&&(B(1),m++,await W(async()=>{await f(async()=>{const e=await t();p(e)?J(e):a?_(a):$("Content is not an array: "+e)},()=>{a&&_(a)}),B(0),await Y()})),X),x=async a=>(z(),await k(a),await f(async()=>v=await s(async(a,t)=>{t||a?2!=N&&(B(1),m++,J(t??a),B(0),await Y()):await k()}),r),X),z=async()=>(v&&(await f(()=>i(v),r),v=void 0),X),G=async a=>(1!=N&&(B(2),C++,await W(async()=>{await f(()=>n(b,a),r),B(0)})),X),H=async()=>(K(),await G(),E=a.addDidFinishTransactionListener(()=>{const a=S();R(a)&&G(a)}),X),K=async()=>(E&&(a.delListener(E),E=void 0),X),Q=()=>!u(E),V=async(a=!1)=>{const[t,e]=a?[K,z]:[z,K];return await t(),await e(),X},W=async(...a)=>(D(ga(ka,w),...a),await(async()=>{if(!ga(Ya,w)){for(pa(Ya,w,1);!u(d=I(ga(ka,w)));)await f(d,r);pa(Ya,w,0)}})(),X),X={load:k,startAutoLoad:x,stopAutoLoad:z,isAutoLoading:()=>!u(v),save:G,startAutoSave:H,stopAutoSave:K,isAutoSaving:Q,startAutoPersisting:async(a,t=!1)=>{const[e,n]=t?[H,x]:[x,H];return await e(a),await n(a),X},stopAutoPersisting:V,getStatus:()=>N,addStatusListener:a=>F(a,T),delListener:t=>(j(t),a),schedule:W,getStore:()=>a,destroy:()=>(ga(ka,w).splice(0,void 0),V()),getStats:()=>({loads:m,saves:C}),...c};return na(X)},za=(a,t,e,s,r,o=Ga,c,l)=>{const w=da();return[async()=>{w.clear(),T(await e(a,t),({tn:a,cn:t})=>ma(Ea(w,a,Na),t))},async(t,e,n)=>((a,t)=>S(ga(w,a),t))(t,e)?sa(b(T(await a(x+V(t)+X(t,n)),a=>[a[e],l?ca(ra(a,e),l):ra(a,e)]),([a,t])=>!u(a)&&!ua(t))):{},async(t,e,s,l,y,d=!1,g=i)=>{const v=Na();ca(s??{},a=>T(ea(a??{}),a=>ma(v,a)));const p=R(v);if(!d&&y&&g==i&&O(p)&&S(w,t))return await a("DROP "+B+V(t)),void pa(w,t);const E=ga(w,t),A=Na(R(E));if(O(p)||(S(w,t)?await m(T([e,...p],async(n,s)=>{P(A,n)||(await a(J+V(t)+"ADD"+V(n)+r),0==s&&await a("CREATE UNIQUE INDEX pk ON "+V(t)+`(${V(e)})`),ma(E,n))})):(await a(Q+V(t)+`(${V(e)}${r} PRIMARY KEY${C(T(p,a=>n+V(a)+r))});`),pa(w,t,Na([e,...p])))),await m([...!d&&l?T(R(A),async n=>{n!=e&&(await a(J+V(t)+"DROP"+V(n)),P(E,n))}):[]]),d)u(s)?await a(k+V(t)+X(t,g)):await m(oa(s,async(n,s)=>{u(n)?await a(k+V(t)+X(t,g)+`AND(${V(e)}=$1)`,[s]):O(p)||await o(a,t,e,ea(n),{[s]:c?T(la(n),c):la(n)},E)}));else if(O(p))S(w,t)&&await a(k+V(t)+X(t,g));else{const n=b(R(ga(w,t)),a=>a!=e),i={},r=[];ca(s??{},(a,t)=>{i[t]=T(n,t=>c?c(a?.[t]):a?.[t]),D(r,t)}),await o(a,t,e,n,i),await a(k+V(t)+X(t,g)+`AND${V(e)}NOT IN(${W(r)})`,r)}},async t=>{let e;return await a("BEGIN"),await f(async()=>e=await t(),s),await a("END"),e}]},Ga=async(a,t,e,s,i)=>{const r=[1];await a("INSERT INTO"+V(t)+"("+((...a)=>C(T(a,V),n))(e,...s)+")VALUES"+C(oa(i,a=>"($"+r[0]+++","+W(a,r)+")"),n)+"ON CONFLICT("+V(e)+")DO UPDATE SET"+C(T(s,a=>V(a)+"=excluded."+V(a)),n),oa(i,(a,t)=>[t,...T(a,a=>a??null)]).flat())},Ha=(a,t,e,n,s,i,r,[o,c,l],w,y,d,g,v,p)=>{const[E,A,N,m]=za(t,w,y,s,v,p),$=xa(a,()=>m(async()=>{return await E(),a=(await A(o,c))[_]?.[l]??"null",Ba(ja(a));var a}),a=>m(async()=>{var t;await E(),await N(o,c,{[_]:{[l]:(t=a()??null,Ua(t,(a,t)=>u(t)?"":t))}},!0,!0)}),e,n,s,r,{[g]:()=>d,destroy:async()=>(await $.stopAutoPersisting(),i(),$)},0,d);return $},Ka=(a,t,e,n,s,i,r,[o,c,[l,w,y]],d,g,v,p,E,A,N,$)=>{const[f,h,C,T]=za(t,d,g,s,E,A,N,$),O=(a,t)=>m(va(c,async([e,n,s,i,r],o)=>{t&&!(o in a)||await C(e,n,a[o],s,i,t,r)})),D=async(a,t)=>w?await C(y,F,{[_]:a},!0,!0,t):null,I=xa(a,()=>T(async()=>{await f();const a=await(async()=>sa(b(await m(va(o,async([a,t,e],n)=>[a,await h(n,t,e)])),a=>!ua(a[1]))))(),t=await(async()=>l?(await h(y,F))[_]:{})();return ua(a)&&u(t)?void 0:[a,t]}),(a,t)=>T(async()=>{if(await f(),u(t)){const[t,e]=a();await O(t),await D(e)}else await O(t[0],!0),await D(t[1],!0)}),e,n,s,r,{[p]:()=>v,destroy:async()=>(await I.stopAutoPersisting(),i(),I)},0,v);return I},Qa=(a,n,s,r,o,c,u,y,d,g,p="getDb",A)=>{let N,m,$;const h=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,c),[C,T,O,b]=(a=>{const e=(a=>ia(Pa,v(a)?{[Ca]:a}:a??{}))(a),n=e[ba];if(e.mode==ha){const a=e[Ca]??t;return[1,n,[a,e[Ta]??F,e[Oa]??fa],Na(a)]}const{tables:{load:s={},save:r={}}={},values:o={}}=e,c=E(la(ia(_a,o)),0,wa(_a)),l=c[2],w=Na(l),u=Na(l),y=Fa(s,{[Ia]:null,[Da]:F,[Ma]:i},Ia,a=>S(u,a),a=>ma(w,a)),d=Fa(r,{[Sa]:null,[Da]:F,[La]:0,[Ra]:0,[Ma]:null},Sa,(a,t)=>S(u,t),(a,t)=>ma(w,t));var g;return g=(a,t)=>t[4]??=ga(y,t[0])?.[2]??i,M(d,(a,t)=>g(0,a)),[0,n,[y,d,c],w]})(n);return(C?Ha:Ka)(a,h,a=>{let t;const e=()=>t=setInterval(()=>f(async()=>{const[{d:t,s:e,c:n}]=await h(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=r(t=>{b.has(t)&&(n(),a(),e())});return e(),()=>{n(),o(s)}},a=>a(),u,y,d,O,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),g,p,e,A,a=>(a=>!0===a)(a)?1:(a=>!1===a)(a)?0:a,void 0)},Va="change",Wa=(a,t,e,n,s)=>Qa(a,e,async(a,e=[])=>{return await(n=(n,s)=>t.all(a,e,(a,t)=>a?s(a):n(t)),new o(n));var n},a=>{const e=(t,e,n)=>a(n);return t.on(Va,e),e},a=>t.off(Va,a),n,s,N,3,t);export{Wa as createSqlite3Persister};
@@ -1 +1 @@
1
- import{Map as t}from"yjs";const e="t",a="v",n=t=>(e,a,n)=>t(e)?n?.():a(e),s=t=>null==t,o=t=>void 0===t,r=t=>null===t,i=n(s),c=n(o),g=t=>Array.isArray(t),d=t=>t.length,l=t=>{throw Error(t)},u=async(t,e,a)=>{try{return await t()}catch(t){e?.(t)}},y=(t,e)=>t.forEach(e),p=(t,...e)=>t.push(...e),v=t=>t.shift(),w=t=>o(t)||0==(t=>t?.size??0)(t),h=(t,e)=>t?.forEach(e),f=(t,e)=>t?.delete(e),S=Object,C=t=>S.getPrototypeOf(t),b=S.entries,A=S.keys,M=S.freeze,O=(t=[])=>S.fromEntries(t),L=(t,e)=>e in t,J=(t,e)=>O(((t,e)=>((t,e)=>t.map(e))(b(t),([t,a])=>e(a,t)))(t,(t,a)=>[a,e(t,a)])),N=t=>(t=>!s(t)&&i(C(t),t=>t==S.prototype||s(C(t)),()=>!0))(t)&&0==(t=>d(A(t)))(t),z=(t,e,a)=>(L(t,e)||(t[e]=a()),t[e]),D=t=>new Map(t),E=(t,e)=>t?.get(e),m=(t,e)=>h(t,(t,a)=>e(a,t)),P=(t,e,a)=>o(a)?(f(t,e),t):t?.set(e,a),T=(t,e,a,n)=>{var s,o;return s=t,o=e,s?.has(o)?n?.(E(t,e)):P(t,e,a()),E(t,e)},j=(t,e,a,n,s=0)=>c((a?T:E)(t,e[s],s>d(e)-2?a:D),o=>{if(s>d(e)-2)return n?.(o)&&P(t,e[s]),o;const r=j(o,e,a,n,s+1);return w(o)&&P(t,e[s]),r}),k=/^\d+$/,x=t=>new Set(g(t)||o(t)?t:[t]),F=D(),Y=D(),$=(t,e,a,n,s,i,S,C={},b=0,A=[])=>{let O,L,J,z=0,m=0,$=0;T(F,A,()=>0),T(Y,A,()=>[]);const q=D(),[B,G,H,I,K]=((t=1,e,a)=>1!=t&&e.isMergeable()?[1,e.getMergeableContent,()=>e.getTransactionMergeableChanges(!a),([[t],[e]])=>!N(t)||!N(e),e.setDefaultContent]:2!=t?[0,e.getContent,e.getTransactionChanges,([t,e])=>!N(t)||!N(e),e.setContent]:l("Store type not supported by this Persister"))(S,t,b),[Q,R,U]=(()=>{let t;const[e,a]=(()=>{const t=[];let e=0;return[a=>(a?v(t):null)??""+e++,e=>{k.test(e)&&d(t)<1e3&&p(t,e)}]})(),n=D();return[(a,s,o,r=[],i=()=>[])=>{t??=ot;const c=e(1);var g,d;return P(n,c,[a,s,o,r,i]),g=j(s,o??[""],x),d=c,g?.add(d),c},(e,a,...s)=>y(((t,e=[""])=>{const a=[],n=(t,s)=>s==d(e)?p(a,t):r(e[s])?h(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=>h(e,e=>E(n,e)[0](t,...a??[],...s))),t=>c(E(n,t),([,e,s])=>(j(e,s??[""],void 0,e=>(f(e,t),w(e)?1:0)),P(n,t),a(t),s)),e=>c(E(n,e),([e,,a=[],n,s])=>{const o=(...i)=>{const c=d(i);c==d(a)?e(t,...i,...s(i)):r(a[c])?y(n[c]?.(...i)??[],t=>o(...i,t)):o(...i,a[c])};o()})]})(),V=t=>{t!=z&&(z=t,R(q,void 0,z))},W=e=>{(B&&g(e?.[0])?1===e?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===e?.[2]?t.applyChanges:t.setContent)(e)},X=async t=>(2!=z&&(V(1),m++,await st(async()=>{await u(async()=>{const a=await e();g(a)?W(a):t?K(t):l("Content is not an array: "+a)},()=>{t&&K(t)}),V(0)})),ot),Z=async t=>(_(),await X(t),await u(async()=>L=await n(async(t,e)=>{e||t?2!=z&&(V(1),m++,W(e??t),V(0)):await X()}),i),ot),_=async()=>(L&&(await u(()=>s(L),i),L=void 0),ot),tt=async t=>(1!=z&&(V(2),$++,await st(async()=>{await u(()=>a(G,t),i),V(0)})),ot),et=async()=>(at(),await tt(),J=t.addDidFinishTransactionListener(()=>{const t=H();I(t)&&tt(t)}),ot),at=async()=>(J&&(t.delListener(J),J=void 0),ot),nt=async(t=!1)=>{const[e,a]=t?[at,_]:[_,at];return await e(),await a(),ot},st=async(...t)=>(p(E(Y,A),...t),await(async()=>{if(!E(F,A)){for(P(F,A,1);!o(O=v(E(Y,A)));)await u(O,i);P(F,A,0)}})(),ot),ot={load:X,startAutoLoad:Z,stopAutoLoad:_,isAutoLoading:()=>!o(L),save:tt,startAutoSave:et,stopAutoSave:at,isAutoSaving:()=>!o(J),startAutoPersisting:async(t,e=!1)=>{const[a,n]=e?[et,Z]:[Z,et];return await a(t),await n(t),ot},stopAutoPersisting:nt,getStatus:()=>z,addStatusListener:t=>Q(t,q),delListener:e=>(U(e),t),schedule:st,getStore:()=>t,destroy:()=>(E(Y,A).splice(0,void 0),nt()),getStats:()=>({loads:m,saves:$}),...C};return M(ot)},q="delete",B=t=>[t.get(e),t.get(a)],G=(e,a,n,s)=>{const r=o(a)?e:e.get(a)??e.set(a,new t);let i;return J(n,(t,e)=>{s(r,e,t)&&(i=1)}),r.forEach((t,e)=>{L(n,e)||(r.delete(e),i=1)}),o(a)||r.size||e.delete(a),i},H=(n,s,r="tinybase",i)=>{const g=s.getMap(r);return $(n,async()=>g.size?[g.get(e).toJSON(),g.get(a).toJSON()]:void 0,async(n,r)=>s.transact(()=>((n,s,r)=>{n.size||(n.set(e,new t),n.set(a,new t));const[i,g]=B(n),d=()=>{l=1};let l=1;if(c(r,([t,e])=>{l=0,J(t,(t,e)=>l?0:o(t)?i.delete(e):c(i.get(e),e=>J(t,(t,a)=>l?0:o(t)?e.delete(a):c(e.get(a),e=>J(t,(t,a)=>o(t)?e.delete(a):e.set(a,t)),d)),d)),J(e,(t,e)=>l?0:o(t)?g.delete(e):g.set(e,t))}),l){const[t,e]=s();G(i,void 0,t,(t,e,a)=>G(i,e,a,(t,e,a)=>G(t,e,a,(t,e,a)=>{if(t.get(e)!==a)return t.set(e,a),1}))),G(g,void 0,e,(t,e,a)=>{g.get(e)!==a&&g.set(e,a)})}})(g,n,r)),t=>{const n=n=>t(void 0,((t,n)=>{if(1==d(n)&&(s=n[0].path,0==d(s)))return[t.get(e).toJSON(),t.get(a).toJSON(),1];var s;const[o,r]=B(t),i={},g={};return y(n,({path:t,changes:{keys:a}})=>v(t)==e?c(v(t),e=>{const n=z(i,e,O),s=o.get(e);c(v(t),t=>{const e=z(n,t,O),o=s.get(t);m(a,(t,{action:a})=>e[t]=a==q?void 0:o.get(t))},()=>m(a,(t,{action:e})=>n[t]=e==q?void 0:s.get(t)?.toJSON()))},()=>m(a,(t,{action:e})=>i[t]=e==q?void 0:o.get(t)?.toJSON())):m(a,(t,{action:e})=>g[t]=e==q?void 0:r.get(t))),[i,g,1]})(g,n));return g.observeDeep(n),n},t=>{g.unobserveDeep(t)},i,1,{getYDoc:()=>s})};export{H as createYjsPersister};
1
+ import{Map as t}from"yjs";const e="t",a="v",n=t=>(e,a,n)=>t(e)?n?.():a(e),s=t=>null==t,o=t=>void 0===t,r=t=>null===t,i=n(s),c=n(o),g=t=>Array.isArray(t),d=t=>t.length,u=t=>{throw Error(t)},l=async(t,e,a)=>{try{return await t()}catch(t){e?.(t)}},y=(t,e)=>t.forEach(e),w=(t,...e)=>t.push(...e),p=t=>t.shift(),v=t=>o(t)||0==(t=>t?.size??0)(t),h=(t,e)=>t?.forEach(e),f=(t,e)=>t?.delete(e),S=Object,C=t=>S.getPrototypeOf(t),b=S.entries,A=S.keys,M=S.freeze,O=(t=[])=>S.fromEntries(t),L=(t,e)=>e in t,J=(t,e)=>O(((t,e)=>((t,e)=>t.map(e))(b(t),([t,a])=>e(a,t)))(t,(t,a)=>[a,e(t,a)])),N=t=>(t=>!s(t)&&i(C(t),t=>t==S.prototype||s(C(t)),()=>!0))(t)&&0==(t=>d(A(t)))(t),z=(t,e,a)=>(L(t,e)||(t[e]=a()),t[e]),D=Map,E=t=>new D(t),m=(t,e)=>t?.get(e),P=(t,e)=>h(t,(t,a)=>e(a,t)),T=(t,e,a)=>o(a)?(f(t,e),t):t?.set(e,a),j=(t,e,a,n)=>{var s,o;return s=t,o=e,s?.has(o)?n?.(m(t,e)):T(t,e,a()),m(t,e)},k=(t,e,a,n,s=0)=>c((a?j:m)(t,e[s],s>d(e)-2?a:E),o=>{if(s>d(e)-2)return n?.(o)&&T(t,e[s]),o;const r=k(o,e,a,n,s+1);return v(o)&&T(t,e[s]),r}),x=/^\d+$/,F=t=>new Set(g(t)||o(t)?t:[t]),Y=E(),$=E(),q=(t,e,a,n,s,i,S,C={},b=0,A=[])=>{let O,L,J,z=0,D=0,P=0;j(Y,A,()=>0),j($,A,()=>[]);const q=E(),[B,G,H,I,K]=((t=1,e,a)=>1!=t&&e.isMergeable()?[1,e.getMergeableContent,()=>e.getTransactionMergeableChanges(!a),([[t],[e]])=>!N(t)||!N(e),e.setDefaultContent]:2!=t?[0,e.getContent,e.getTransactionChanges,([t,e])=>!N(t)||!N(e),e.setContent]:u("Store type not supported by this Persister"))(S,t,b),[Q,R,U]=(()=>{let t;const[e,a]=(()=>{const t=[];let e=0;return[a=>(a?p(t):null)??""+e++,e=>{x.test(e)&&d(t)<1e3&&w(t,e)}]})(),n=E();return[(a,s,o,r=[],i=()=>[])=>{t??=it;const c=e(1);var g,d;return T(n,c,[a,s,o,r,i]),g=k(s,o??[""],F),d=c,g?.add(d),c},(e,a,...s)=>y(((t,e=[""])=>{const a=[],n=(t,s)=>s==d(e)?w(a,t):r(e[s])?h(t,t=>n(t,s+1)):y([e[s],null],e=>n(m(t,e),s+1));return n(t,0),a})(e,a),e=>h(e,e=>m(n,e)[0](t,...a??[],...s))),t=>c(m(n,t),([,e,s])=>(k(e,s??[""],void 0,e=>(f(e,t),v(e)?1:0)),T(n,t),a(t),s)),e=>c(m(n,e),([e,,a=[],n,s])=>{const o=(...i)=>{const c=d(i);c==d(a)?e(t,...i,...s(i)):r(a[c])?y(n[c]?.(...i)??[],t=>o(...i,t)):o(...i,a[c])};o()})]})(),V=t=>{t!=z&&(z=t,R(q,void 0,z))},W=e=>{(B&&g(e?.[0])?1===e?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===e?.[2]?t.applyChanges:t.setContent)(e)},X=async()=>{st()&&t.hadMutated?.()&&await et()},Z=async t=>(2!=z&&(V(1),D++,await rt(async()=>{await l(async()=>{const a=await e();g(a)?W(a):t?K(t):u("Content is not an array: "+a)},()=>{t&&K(t)}),V(0),await X()})),it),_=async t=>(tt(),await Z(t),await l(async()=>L=await n(async(t,e)=>{e||t?2!=z&&(V(1),D++,W(e??t),V(0),await X()):await Z()}),i),it),tt=async()=>(L&&(await l(()=>s(L),i),L=void 0),it),et=async t=>(1!=z&&(V(2),P++,await rt(async()=>{await l(()=>a(G,t),i),V(0)})),it),at=async()=>(nt(),await et(),J=t.addDidFinishTransactionListener(()=>{const t=H();I(t)&&et(t)}),it),nt=async()=>(J&&(t.delListener(J),J=void 0),it),st=()=>!o(J),ot=async(t=!1)=>{const[e,a]=t?[nt,tt]:[tt,nt];return await e(),await a(),it},rt=async(...t)=>(w(m($,A),...t),await(async()=>{if(!m(Y,A)){for(T(Y,A,1);!o(O=p(m($,A)));)await l(O,i);T(Y,A,0)}})(),it),it={load:Z,startAutoLoad:_,stopAutoLoad:tt,isAutoLoading:()=>!o(L),save:et,startAutoSave:at,stopAutoSave:nt,isAutoSaving:st,startAutoPersisting:async(t,e=!1)=>{const[a,n]=e?[at,_]:[_,at];return await a(t),await n(t),it},stopAutoPersisting:ot,getStatus:()=>z,addStatusListener:t=>Q(t,q),delListener:e=>(U(e),t),schedule:rt,getStore:()=>t,destroy:()=>(m($,A).splice(0,void 0),ot()),getStats:()=>({loads:D,saves:P}),...C};return M(it)},B="delete",G=t=>[t.get(e),t.get(a)],H=(e,a,n,s)=>{const r=o(a)?e:e.get(a)??e.set(a,new t);let i;return J(n,(t,e)=>{s(r,e,t)&&(i=1)}),r.forEach((t,e)=>{L(n,e)||(r.delete(e),i=1)}),o(a)||r.size||e.delete(a),i},I=(n,s,r="tinybase",i)=>{const g=s.getMap(r);return q(n,async()=>g.size?[g.get(e).toJSON(),g.get(a).toJSON()]:void 0,async(n,r)=>s.transact(()=>((n,s,r)=>{n.size||(n.set(e,new t),n.set(a,new t));const[i,g]=G(n),d=()=>{u=1};let u=1;if(c(r,([t,e])=>{u=0,J(t,(t,e)=>u?0:o(t)?i.delete(e):c(i.get(e),e=>J(t,(t,a)=>u?0:o(t)?e.delete(a):c(e.get(a),e=>J(t,(t,a)=>o(t)?e.delete(a):e.set(a,t)),d)),d)),J(e,(t,e)=>u?0:o(t)?g.delete(e):g.set(e,t))}),u){const[t,e]=s();H(i,void 0,t,(t,e,a)=>H(i,e,a,(t,e,a)=>H(t,e,a,(t,e,a)=>{if(t.get(e)!==a)return t.set(e,a),1}))),H(g,void 0,e,(t,e,a)=>{g.get(e)!==a&&g.set(e,a)})}})(g,n,r)),t=>{const n=n=>t(void 0,((t,n)=>{if(1==d(n)&&(s=n[0].path,0==d(s)))return[t.get(e).toJSON(),t.get(a).toJSON(),1];var s;const[o,r]=G(t),i={},g={};return y(n,({path:t,changes:{keys:a}})=>p(t)==e?c(p(t),e=>{const n=z(i,e,O),s=o.get(e);c(p(t),t=>{const e=z(n,t,O),o=s.get(t);P(a,(t,{action:a})=>e[t]=a==B?void 0:o.get(t))},()=>P(a,(t,{action:e})=>n[t]=e==B?void 0:s.get(t)?.toJSON()))},()=>P(a,(t,{action:e})=>i[t]=e==B?void 0:o.get(t)?.toJSON())):P(a,(t,{action:e})=>g[t]=e==B?void 0:r.get(t))),[i,g,1]})(g,n));return g.observeDeep(n),n},t=>{g.unobserveDeep(t)},i,1,{getYDoc:()=>s})};export{I as createYjsPersister};