tinybase 5.0.4 → 5.1.0-beta.1

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 (843) hide show
  1. package/@types/persisters/index.d.cts +3 -1
  2. package/@types/persisters/index.d.ts +3 -1
  3. package/@types/persisters/with-schemas/index.d.cts +3 -1
  4. package/@types/persisters/with-schemas/index.d.ts +3 -1
  5. package/@types/synchronizers/index.d.cts +39 -23
  6. package/@types/synchronizers/index.d.ts +39 -23
  7. package/@types/synchronizers/synchronizer-broadcast-channel/index.d.cts +12 -1
  8. package/@types/synchronizers/synchronizer-broadcast-channel/index.d.ts +12 -1
  9. package/@types/synchronizers/synchronizer-broadcast-channel/with-schemas/index.d.cts +14 -1
  10. package/@types/synchronizers/synchronizer-broadcast-channel/with-schemas/index.d.ts +14 -1
  11. package/@types/synchronizers/synchronizer-local/index.d.cts +12 -3
  12. package/@types/synchronizers/synchronizer-local/index.d.ts +12 -3
  13. package/@types/synchronizers/synchronizer-local/with-schemas/index.d.cts +14 -3
  14. package/@types/synchronizers/synchronizer-local/with-schemas/index.d.ts +14 -3
  15. package/@types/synchronizers/synchronizer-ws-client/index.d.cts +13 -1
  16. package/@types/synchronizers/synchronizer-ws-client/index.d.ts +13 -1
  17. package/@types/synchronizers/synchronizer-ws-client/with-schemas/index.d.cts +15 -1
  18. package/@types/synchronizers/synchronizer-ws-client/with-schemas/index.d.ts +15 -1
  19. package/@types/synchronizers/synchronizer-ws-server/index.d.cts +125 -2
  20. package/@types/synchronizers/synchronizer-ws-server/index.d.ts +125 -2
  21. package/@types/synchronizers/synchronizer-ws-server/with-schemas/index.d.cts +147 -3
  22. package/@types/synchronizers/synchronizer-ws-server/with-schemas/index.d.ts +147 -3
  23. package/@types/synchronizers/with-schemas/index.d.cts +41 -23
  24. package/@types/synchronizers/with-schemas/index.d.ts +41 -23
  25. package/cjs/es6/index.cjs +101 -86
  26. package/cjs/es6/min/index.cjs +1 -1
  27. package/cjs/es6/min/index.cjs.gz +0 -0
  28. package/cjs/es6/min/persisters/index.cjs +1 -1
  29. package/cjs/es6/min/persisters/index.cjs.gz +0 -0
  30. package/cjs/es6/min/persisters/persister-automerge/index.cjs +1 -1
  31. package/cjs/es6/min/persisters/persister-automerge/index.cjs.gz +0 -0
  32. package/cjs/es6/min/persisters/persister-automerge/with-schemas/index.cjs +1 -1
  33. package/cjs/es6/min/persisters/persister-automerge/with-schemas/index.cjs.gz +0 -0
  34. package/cjs/es6/min/persisters/persister-browser/index.cjs +1 -1
  35. package/cjs/es6/min/persisters/persister-browser/index.cjs.gz +0 -0
  36. package/cjs/es6/min/persisters/persister-browser/with-schemas/index.cjs +1 -1
  37. package/cjs/es6/min/persisters/persister-browser/with-schemas/index.cjs.gz +0 -0
  38. package/cjs/es6/min/persisters/persister-cr-sqlite-wasm/index.cjs +1 -1
  39. package/cjs/es6/min/persisters/persister-cr-sqlite-wasm/index.cjs.gz +0 -0
  40. package/cjs/es6/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.cjs +1 -1
  41. package/cjs/es6/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.cjs.gz +0 -0
  42. package/cjs/es6/min/persisters/persister-electric-sql/index.cjs +1 -1
  43. package/cjs/es6/min/persisters/persister-electric-sql/index.cjs.gz +0 -0
  44. package/cjs/es6/min/persisters/persister-electric-sql/with-schemas/index.cjs +1 -1
  45. package/cjs/es6/min/persisters/persister-electric-sql/with-schemas/index.cjs.gz +0 -0
  46. package/cjs/es6/min/persisters/persister-expo-sqlite/index.cjs +1 -1
  47. package/cjs/es6/min/persisters/persister-expo-sqlite/index.cjs.gz +0 -0
  48. package/cjs/es6/min/persisters/persister-expo-sqlite/with-schemas/index.cjs +1 -1
  49. package/cjs/es6/min/persisters/persister-expo-sqlite/with-schemas/index.cjs.gz +0 -0
  50. package/cjs/es6/min/persisters/persister-file/index.cjs +1 -1
  51. package/cjs/es6/min/persisters/persister-file/index.cjs.gz +0 -0
  52. package/cjs/es6/min/persisters/persister-file/with-schemas/index.cjs +1 -1
  53. package/cjs/es6/min/persisters/persister-file/with-schemas/index.cjs.gz +0 -0
  54. package/cjs/es6/min/persisters/persister-indexed-db/index.cjs +1 -1
  55. package/cjs/es6/min/persisters/persister-indexed-db/index.cjs.gz +0 -0
  56. package/cjs/es6/min/persisters/persister-indexed-db/with-schemas/index.cjs +1 -1
  57. package/cjs/es6/min/persisters/persister-indexed-db/with-schemas/index.cjs.gz +0 -0
  58. package/cjs/es6/min/persisters/persister-libsql/index.cjs +1 -1
  59. package/cjs/es6/min/persisters/persister-libsql/index.cjs.gz +0 -0
  60. package/cjs/es6/min/persisters/persister-libsql/with-schemas/index.cjs +1 -1
  61. package/cjs/es6/min/persisters/persister-libsql/with-schemas/index.cjs.gz +0 -0
  62. package/cjs/es6/min/persisters/persister-partykit-client/index.cjs +1 -1
  63. package/cjs/es6/min/persisters/persister-partykit-client/index.cjs.gz +0 -0
  64. package/cjs/es6/min/persisters/persister-partykit-client/with-schemas/index.cjs +1 -1
  65. package/cjs/es6/min/persisters/persister-partykit-client/with-schemas/index.cjs.gz +0 -0
  66. package/cjs/es6/min/persisters/persister-powersync/index.cjs +1 -1
  67. package/cjs/es6/min/persisters/persister-powersync/index.cjs.gz +0 -0
  68. package/cjs/es6/min/persisters/persister-powersync/with-schemas/index.cjs +1 -1
  69. package/cjs/es6/min/persisters/persister-powersync/with-schemas/index.cjs.gz +0 -0
  70. package/cjs/es6/min/persisters/persister-remote/index.cjs +1 -1
  71. package/cjs/es6/min/persisters/persister-remote/index.cjs.gz +0 -0
  72. package/cjs/es6/min/persisters/persister-remote/with-schemas/index.cjs +1 -1
  73. package/cjs/es6/min/persisters/persister-remote/with-schemas/index.cjs.gz +0 -0
  74. package/cjs/es6/min/persisters/persister-sqlite-wasm/index.cjs +1 -1
  75. package/cjs/es6/min/persisters/persister-sqlite-wasm/index.cjs.gz +0 -0
  76. package/cjs/es6/min/persisters/persister-sqlite-wasm/with-schemas/index.cjs +1 -1
  77. package/cjs/es6/min/persisters/persister-sqlite-wasm/with-schemas/index.cjs.gz +0 -0
  78. package/cjs/es6/min/persisters/persister-sqlite3/index.cjs +1 -1
  79. package/cjs/es6/min/persisters/persister-sqlite3/index.cjs.gz +0 -0
  80. package/cjs/es6/min/persisters/persister-sqlite3/with-schemas/index.cjs +1 -1
  81. package/cjs/es6/min/persisters/persister-sqlite3/with-schemas/index.cjs.gz +0 -0
  82. package/cjs/es6/min/persisters/persister-yjs/index.cjs +1 -1
  83. package/cjs/es6/min/persisters/persister-yjs/index.cjs.gz +0 -0
  84. package/cjs/es6/min/persisters/persister-yjs/with-schemas/index.cjs +1 -1
  85. package/cjs/es6/min/persisters/persister-yjs/with-schemas/index.cjs.gz +0 -0
  86. package/cjs/es6/min/persisters/with-schemas/index.cjs +1 -1
  87. package/cjs/es6/min/persisters/with-schemas/index.cjs.gz +0 -0
  88. package/cjs/es6/min/synchronizers/index.cjs +1 -1
  89. package/cjs/es6/min/synchronizers/index.cjs.gz +0 -0
  90. package/cjs/es6/min/synchronizers/synchronizer-broadcast-channel/index.cjs +1 -1
  91. package/cjs/es6/min/synchronizers/synchronizer-broadcast-channel/index.cjs.gz +0 -0
  92. package/cjs/es6/min/synchronizers/synchronizer-broadcast-channel/with-schemas/index.cjs +1 -1
  93. package/cjs/es6/min/synchronizers/synchronizer-broadcast-channel/with-schemas/index.cjs.gz +0 -0
  94. package/cjs/es6/min/synchronizers/synchronizer-local/index.cjs +1 -1
  95. package/cjs/es6/min/synchronizers/synchronizer-local/index.cjs.gz +0 -0
  96. package/cjs/es6/min/synchronizers/synchronizer-local/with-schemas/index.cjs +1 -1
  97. package/cjs/es6/min/synchronizers/synchronizer-local/with-schemas/index.cjs.gz +0 -0
  98. package/cjs/es6/min/synchronizers/synchronizer-ws-client/index.cjs +1 -1
  99. package/cjs/es6/min/synchronizers/synchronizer-ws-client/index.cjs.gz +0 -0
  100. package/cjs/es6/min/synchronizers/synchronizer-ws-client/with-schemas/index.cjs +1 -1
  101. package/cjs/es6/min/synchronizers/synchronizer-ws-client/with-schemas/index.cjs.gz +0 -0
  102. package/cjs/es6/min/synchronizers/synchronizer-ws-server/index.cjs +1 -1
  103. package/cjs/es6/min/synchronizers/synchronizer-ws-server/index.cjs.gz +0 -0
  104. package/cjs/es6/min/synchronizers/synchronizer-ws-server/with-schemas/index.cjs +1 -1
  105. package/cjs/es6/min/synchronizers/synchronizer-ws-server/with-schemas/index.cjs.gz +0 -0
  106. package/cjs/es6/min/synchronizers/with-schemas/index.cjs +1 -1
  107. package/cjs/es6/min/synchronizers/with-schemas/index.cjs.gz +0 -0
  108. package/cjs/es6/min/ui-react-inspector/index.cjs +1 -1
  109. package/cjs/es6/min/ui-react-inspector/index.cjs.gz +0 -0
  110. package/cjs/es6/min/ui-react-inspector/with-schemas/index.cjs +1 -1
  111. package/cjs/es6/min/ui-react-inspector/with-schemas/index.cjs.gz +0 -0
  112. package/cjs/es6/min/with-schemas/index.cjs +1 -1
  113. package/cjs/es6/min/with-schemas/index.cjs.gz +0 -0
  114. package/cjs/es6/persisters/index.cjs +30 -21
  115. package/cjs/es6/persisters/persister-automerge/index.cjs +29 -24
  116. package/cjs/es6/persisters/persister-automerge/with-schemas/index.cjs +29 -24
  117. package/cjs/es6/persisters/persister-browser/index.cjs +35 -30
  118. package/cjs/es6/persisters/persister-browser/with-schemas/index.cjs +35 -30
  119. package/cjs/es6/persisters/persister-cr-sqlite-wasm/index.cjs +29 -24
  120. package/cjs/es6/persisters/persister-cr-sqlite-wasm/with-schemas/index.cjs +29 -24
  121. package/cjs/es6/persisters/persister-electric-sql/index.cjs +29 -24
  122. package/cjs/es6/persisters/persister-electric-sql/with-schemas/index.cjs +29 -24
  123. package/cjs/es6/persisters/persister-expo-sqlite/index.cjs +29 -24
  124. package/cjs/es6/persisters/persister-expo-sqlite/with-schemas/index.cjs +29 -24
  125. package/cjs/es6/persisters/persister-file/index.cjs +41 -31
  126. package/cjs/es6/persisters/persister-file/with-schemas/index.cjs +41 -31
  127. package/cjs/es6/persisters/persister-indexed-db/index.cjs +29 -24
  128. package/cjs/es6/persisters/persister-indexed-db/with-schemas/index.cjs +29 -24
  129. package/cjs/es6/persisters/persister-libsql/index.cjs +286 -281
  130. package/cjs/es6/persisters/persister-libsql/with-schemas/index.cjs +286 -281
  131. package/cjs/es6/persisters/persister-partykit-client/index.cjs +29 -24
  132. package/cjs/es6/persisters/persister-partykit-client/with-schemas/index.cjs +29 -24
  133. package/cjs/es6/persisters/persister-powersync/index.cjs +29 -24
  134. package/cjs/es6/persisters/persister-powersync/with-schemas/index.cjs +29 -24
  135. package/cjs/es6/persisters/persister-remote/index.cjs +35 -30
  136. package/cjs/es6/persisters/persister-remote/with-schemas/index.cjs +35 -30
  137. package/cjs/es6/persisters/persister-sqlite-wasm/index.cjs +29 -24
  138. package/cjs/es6/persisters/persister-sqlite-wasm/with-schemas/index.cjs +29 -24
  139. package/cjs/es6/persisters/persister-sqlite3/index.cjs +29 -24
  140. package/cjs/es6/persisters/persister-sqlite3/with-schemas/index.cjs +29 -24
  141. package/cjs/es6/persisters/persister-yjs/index.cjs +29 -24
  142. package/cjs/es6/persisters/persister-yjs/with-schemas/index.cjs +29 -24
  143. package/cjs/es6/persisters/with-schemas/index.cjs +30 -21
  144. package/cjs/es6/synchronizers/index.cjs +113 -102
  145. package/cjs/es6/synchronizers/synchronizer-broadcast-channel/index.cjs +109 -104
  146. package/cjs/es6/synchronizers/synchronizer-broadcast-channel/with-schemas/index.cjs +109 -104
  147. package/cjs/es6/synchronizers/synchronizer-local/index.cjs +108 -105
  148. package/cjs/es6/synchronizers/synchronizer-local/with-schemas/index.cjs +108 -105
  149. package/cjs/es6/synchronizers/synchronizer-ws-client/index.cjs +130 -119
  150. package/cjs/es6/synchronizers/synchronizer-ws-client/with-schemas/index.cjs +130 -119
  151. package/cjs/es6/synchronizers/synchronizer-ws-server/index.cjs +691 -35
  152. package/cjs/es6/synchronizers/synchronizer-ws-server/with-schemas/index.cjs +691 -35
  153. package/cjs/es6/synchronizers/with-schemas/index.cjs +113 -102
  154. package/cjs/es6/ui-react-inspector/index.cjs +26 -24
  155. package/cjs/es6/ui-react-inspector/with-schemas/index.cjs +26 -24
  156. package/cjs/es6/with-schemas/index.cjs +101 -86
  157. package/cjs/index.cjs +105 -91
  158. package/cjs/indexes/index.cjs +1 -1
  159. package/cjs/indexes/with-schemas/index.cjs +1 -1
  160. package/cjs/metrics/index.cjs +3 -3
  161. package/cjs/metrics/with-schemas/index.cjs +3 -3
  162. package/cjs/min/index.cjs +1 -1
  163. package/cjs/min/index.cjs.gz +0 -0
  164. package/cjs/min/persisters/index.cjs +1 -1
  165. package/cjs/min/persisters/index.cjs.gz +0 -0
  166. package/cjs/min/persisters/persister-automerge/index.cjs +1 -1
  167. package/cjs/min/persisters/persister-automerge/index.cjs.gz +0 -0
  168. package/cjs/min/persisters/persister-automerge/with-schemas/index.cjs +1 -1
  169. package/cjs/min/persisters/persister-automerge/with-schemas/index.cjs.gz +0 -0
  170. package/cjs/min/persisters/persister-browser/index.cjs +1 -1
  171. package/cjs/min/persisters/persister-browser/index.cjs.gz +0 -0
  172. package/cjs/min/persisters/persister-browser/with-schemas/index.cjs +1 -1
  173. package/cjs/min/persisters/persister-browser/with-schemas/index.cjs.gz +0 -0
  174. package/cjs/min/persisters/persister-cr-sqlite-wasm/index.cjs +1 -1
  175. package/cjs/min/persisters/persister-cr-sqlite-wasm/index.cjs.gz +0 -0
  176. package/cjs/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.cjs +1 -1
  177. package/cjs/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.cjs.gz +0 -0
  178. package/cjs/min/persisters/persister-electric-sql/index.cjs +1 -1
  179. package/cjs/min/persisters/persister-electric-sql/index.cjs.gz +0 -0
  180. package/cjs/min/persisters/persister-electric-sql/with-schemas/index.cjs +1 -1
  181. package/cjs/min/persisters/persister-electric-sql/with-schemas/index.cjs.gz +0 -0
  182. package/cjs/min/persisters/persister-expo-sqlite/index.cjs +1 -1
  183. package/cjs/min/persisters/persister-expo-sqlite/index.cjs.gz +0 -0
  184. package/cjs/min/persisters/persister-expo-sqlite/with-schemas/index.cjs +1 -1
  185. package/cjs/min/persisters/persister-expo-sqlite/with-schemas/index.cjs.gz +0 -0
  186. package/cjs/min/persisters/persister-file/index.cjs +1 -1
  187. package/cjs/min/persisters/persister-file/index.cjs.gz +0 -0
  188. package/cjs/min/persisters/persister-file/with-schemas/index.cjs +1 -1
  189. package/cjs/min/persisters/persister-file/with-schemas/index.cjs.gz +0 -0
  190. package/cjs/min/persisters/persister-indexed-db/index.cjs +1 -1
  191. package/cjs/min/persisters/persister-indexed-db/index.cjs.gz +0 -0
  192. package/cjs/min/persisters/persister-indexed-db/with-schemas/index.cjs +1 -1
  193. package/cjs/min/persisters/persister-indexed-db/with-schemas/index.cjs.gz +0 -0
  194. package/cjs/min/persisters/persister-libsql/index.cjs +1 -1
  195. package/cjs/min/persisters/persister-libsql/index.cjs.gz +0 -0
  196. package/cjs/min/persisters/persister-libsql/with-schemas/index.cjs +1 -1
  197. package/cjs/min/persisters/persister-libsql/with-schemas/index.cjs.gz +0 -0
  198. package/cjs/min/persisters/persister-partykit-client/index.cjs +1 -1
  199. package/cjs/min/persisters/persister-partykit-client/index.cjs.gz +0 -0
  200. package/cjs/min/persisters/persister-partykit-client/with-schemas/index.cjs +1 -1
  201. package/cjs/min/persisters/persister-partykit-client/with-schemas/index.cjs.gz +0 -0
  202. package/cjs/min/persisters/persister-powersync/index.cjs +1 -1
  203. package/cjs/min/persisters/persister-powersync/index.cjs.gz +0 -0
  204. package/cjs/min/persisters/persister-powersync/with-schemas/index.cjs +1 -1
  205. package/cjs/min/persisters/persister-powersync/with-schemas/index.cjs.gz +0 -0
  206. package/cjs/min/persisters/persister-remote/index.cjs +1 -1
  207. package/cjs/min/persisters/persister-remote/index.cjs.gz +0 -0
  208. package/cjs/min/persisters/persister-remote/with-schemas/index.cjs +1 -1
  209. package/cjs/min/persisters/persister-remote/with-schemas/index.cjs.gz +0 -0
  210. package/cjs/min/persisters/persister-sqlite-wasm/index.cjs +1 -1
  211. package/cjs/min/persisters/persister-sqlite-wasm/index.cjs.gz +0 -0
  212. package/cjs/min/persisters/persister-sqlite-wasm/with-schemas/index.cjs +1 -1
  213. package/cjs/min/persisters/persister-sqlite-wasm/with-schemas/index.cjs.gz +0 -0
  214. package/cjs/min/persisters/persister-sqlite3/index.cjs +1 -1
  215. package/cjs/min/persisters/persister-sqlite3/index.cjs.gz +0 -0
  216. package/cjs/min/persisters/persister-sqlite3/with-schemas/index.cjs +1 -1
  217. package/cjs/min/persisters/persister-sqlite3/with-schemas/index.cjs.gz +0 -0
  218. package/cjs/min/persisters/persister-yjs/index.cjs +1 -1
  219. package/cjs/min/persisters/persister-yjs/index.cjs.gz +0 -0
  220. package/cjs/min/persisters/persister-yjs/with-schemas/index.cjs +1 -1
  221. package/cjs/min/persisters/persister-yjs/with-schemas/index.cjs.gz +0 -0
  222. package/cjs/min/persisters/with-schemas/index.cjs +1 -1
  223. package/cjs/min/persisters/with-schemas/index.cjs.gz +0 -0
  224. package/cjs/min/synchronizers/index.cjs +1 -1
  225. package/cjs/min/synchronizers/index.cjs.gz +0 -0
  226. package/cjs/min/synchronizers/synchronizer-broadcast-channel/index.cjs +1 -1
  227. package/cjs/min/synchronizers/synchronizer-broadcast-channel/index.cjs.gz +0 -0
  228. package/cjs/min/synchronizers/synchronizer-broadcast-channel/with-schemas/index.cjs +1 -1
  229. package/cjs/min/synchronizers/synchronizer-broadcast-channel/with-schemas/index.cjs.gz +0 -0
  230. package/cjs/min/synchronizers/synchronizer-local/index.cjs +1 -1
  231. package/cjs/min/synchronizers/synchronizer-local/index.cjs.gz +0 -0
  232. package/cjs/min/synchronizers/synchronizer-local/with-schemas/index.cjs +1 -1
  233. package/cjs/min/synchronizers/synchronizer-local/with-schemas/index.cjs.gz +0 -0
  234. package/cjs/min/synchronizers/synchronizer-ws-client/index.cjs +1 -1
  235. package/cjs/min/synchronizers/synchronizer-ws-client/index.cjs.gz +0 -0
  236. package/cjs/min/synchronizers/synchronizer-ws-client/with-schemas/index.cjs +1 -1
  237. package/cjs/min/synchronizers/synchronizer-ws-client/with-schemas/index.cjs.gz +0 -0
  238. package/cjs/min/synchronizers/synchronizer-ws-server/index.cjs +1 -1
  239. package/cjs/min/synchronizers/synchronizer-ws-server/index.cjs.gz +0 -0
  240. package/cjs/min/synchronizers/synchronizer-ws-server/with-schemas/index.cjs +1 -1
  241. package/cjs/min/synchronizers/synchronizer-ws-server/with-schemas/index.cjs.gz +0 -0
  242. package/cjs/min/synchronizers/with-schemas/index.cjs +1 -1
  243. package/cjs/min/synchronizers/with-schemas/index.cjs.gz +0 -0
  244. package/cjs/min/ui-react-inspector/index.cjs +1 -1
  245. package/cjs/min/ui-react-inspector/index.cjs.gz +0 -0
  246. package/cjs/min/ui-react-inspector/with-schemas/index.cjs +1 -1
  247. package/cjs/min/ui-react-inspector/with-schemas/index.cjs.gz +0 -0
  248. package/cjs/min/with-schemas/index.cjs +1 -1
  249. package/cjs/min/with-schemas/index.cjs.gz +0 -0
  250. package/cjs/persisters/index.cjs +28 -19
  251. package/cjs/persisters/persister-automerge/index.cjs +27 -22
  252. package/cjs/persisters/persister-automerge/with-schemas/index.cjs +27 -22
  253. package/cjs/persisters/persister-browser/index.cjs +33 -28
  254. package/cjs/persisters/persister-browser/with-schemas/index.cjs +33 -28
  255. package/cjs/persisters/persister-cr-sqlite-wasm/index.cjs +28 -23
  256. package/cjs/persisters/persister-cr-sqlite-wasm/with-schemas/index.cjs +28 -23
  257. package/cjs/persisters/persister-electric-sql/index.cjs +28 -23
  258. package/cjs/persisters/persister-electric-sql/with-schemas/index.cjs +28 -23
  259. package/cjs/persisters/persister-expo-sqlite/index.cjs +28 -23
  260. package/cjs/persisters/persister-expo-sqlite/with-schemas/index.cjs +28 -23
  261. package/cjs/persisters/persister-file/index.cjs +39 -29
  262. package/cjs/persisters/persister-file/with-schemas/index.cjs +39 -29
  263. package/cjs/persisters/persister-indexed-db/index.cjs +27 -22
  264. package/cjs/persisters/persister-indexed-db/with-schemas/index.cjs +27 -22
  265. package/cjs/persisters/persister-libsql/index.cjs +194 -189
  266. package/cjs/persisters/persister-libsql/with-schemas/index.cjs +194 -189
  267. package/cjs/persisters/persister-partykit-client/index.cjs +27 -22
  268. package/cjs/persisters/persister-partykit-client/with-schemas/index.cjs +27 -22
  269. package/cjs/persisters/persister-powersync/index.cjs +28 -23
  270. package/cjs/persisters/persister-powersync/with-schemas/index.cjs +28 -23
  271. package/cjs/persisters/persister-remote/index.cjs +33 -28
  272. package/cjs/persisters/persister-remote/with-schemas/index.cjs +33 -28
  273. package/cjs/persisters/persister-sqlite-wasm/index.cjs +28 -23
  274. package/cjs/persisters/persister-sqlite-wasm/with-schemas/index.cjs +28 -23
  275. package/cjs/persisters/persister-sqlite3/index.cjs +28 -23
  276. package/cjs/persisters/persister-sqlite3/with-schemas/index.cjs +28 -23
  277. package/cjs/persisters/persister-yjs/index.cjs +29 -24
  278. package/cjs/persisters/persister-yjs/with-schemas/index.cjs +29 -24
  279. package/cjs/persisters/with-schemas/index.cjs +28 -19
  280. package/cjs/queries/index.cjs +2 -2
  281. package/cjs/queries/with-schemas/index.cjs +2 -2
  282. package/cjs/relationships/index.cjs +1 -1
  283. package/cjs/relationships/with-schemas/index.cjs +1 -1
  284. package/cjs/synchronizers/index.cjs +105 -95
  285. package/cjs/synchronizers/synchronizer-broadcast-channel/index.cjs +101 -97
  286. package/cjs/synchronizers/synchronizer-broadcast-channel/with-schemas/index.cjs +101 -97
  287. package/cjs/synchronizers/synchronizer-local/index.cjs +100 -98
  288. package/cjs/synchronizers/synchronizer-local/with-schemas/index.cjs +100 -98
  289. package/cjs/synchronizers/synchronizer-ws-client/index.cjs +119 -112
  290. package/cjs/synchronizers/synchronizer-ws-client/with-schemas/index.cjs +119 -112
  291. package/cjs/synchronizers/synchronizer-ws-server/index.cjs +520 -20
  292. package/cjs/synchronizers/synchronizer-ws-server/with-schemas/index.cjs +520 -20
  293. package/cjs/synchronizers/with-schemas/index.cjs +105 -95
  294. package/cjs/ui-react-inspector/index.cjs +24 -22
  295. package/cjs/ui-react-inspector/with-schemas/index.cjs +24 -22
  296. package/cjs/with-schemas/index.cjs +105 -91
  297. package/es6/index.js +101 -86
  298. package/es6/min/index.js +1 -1
  299. package/es6/min/index.js.gz +0 -0
  300. package/es6/min/persisters/index.js +1 -1
  301. package/es6/min/persisters/index.js.gz +0 -0
  302. package/es6/min/persisters/persister-automerge/index.js +1 -1
  303. package/es6/min/persisters/persister-automerge/index.js.gz +0 -0
  304. package/es6/min/persisters/persister-automerge/with-schemas/index.js +1 -1
  305. package/es6/min/persisters/persister-automerge/with-schemas/index.js.gz +0 -0
  306. package/es6/min/persisters/persister-browser/index.js +1 -1
  307. package/es6/min/persisters/persister-browser/index.js.gz +0 -0
  308. package/es6/min/persisters/persister-browser/with-schemas/index.js +1 -1
  309. package/es6/min/persisters/persister-browser/with-schemas/index.js.gz +0 -0
  310. package/es6/min/persisters/persister-cr-sqlite-wasm/index.js +1 -1
  311. package/es6/min/persisters/persister-cr-sqlite-wasm/index.js.gz +0 -0
  312. package/es6/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.js +1 -1
  313. package/es6/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.js.gz +0 -0
  314. package/es6/min/persisters/persister-electric-sql/index.js +1 -1
  315. package/es6/min/persisters/persister-electric-sql/index.js.gz +0 -0
  316. package/es6/min/persisters/persister-electric-sql/with-schemas/index.js +1 -1
  317. package/es6/min/persisters/persister-electric-sql/with-schemas/index.js.gz +0 -0
  318. package/es6/min/persisters/persister-expo-sqlite/index.js +1 -1
  319. package/es6/min/persisters/persister-expo-sqlite/index.js.gz +0 -0
  320. package/es6/min/persisters/persister-expo-sqlite/with-schemas/index.js +1 -1
  321. package/es6/min/persisters/persister-expo-sqlite/with-schemas/index.js.gz +0 -0
  322. package/es6/min/persisters/persister-file/index.js +1 -1
  323. package/es6/min/persisters/persister-file/index.js.gz +0 -0
  324. package/es6/min/persisters/persister-file/with-schemas/index.js +1 -1
  325. package/es6/min/persisters/persister-file/with-schemas/index.js.gz +0 -0
  326. package/es6/min/persisters/persister-indexed-db/index.js +1 -1
  327. package/es6/min/persisters/persister-indexed-db/index.js.gz +0 -0
  328. package/es6/min/persisters/persister-indexed-db/with-schemas/index.js +1 -1
  329. package/es6/min/persisters/persister-indexed-db/with-schemas/index.js.gz +0 -0
  330. package/es6/min/persisters/persister-libsql/index.js +1 -1
  331. package/es6/min/persisters/persister-libsql/index.js.gz +0 -0
  332. package/es6/min/persisters/persister-libsql/with-schemas/index.js +1 -1
  333. package/es6/min/persisters/persister-libsql/with-schemas/index.js.gz +0 -0
  334. package/es6/min/persisters/persister-partykit-client/index.js +1 -1
  335. package/es6/min/persisters/persister-partykit-client/index.js.gz +0 -0
  336. package/es6/min/persisters/persister-partykit-client/with-schemas/index.js +1 -1
  337. package/es6/min/persisters/persister-partykit-client/with-schemas/index.js.gz +0 -0
  338. package/es6/min/persisters/persister-powersync/index.js +1 -1
  339. package/es6/min/persisters/persister-powersync/index.js.gz +0 -0
  340. package/es6/min/persisters/persister-powersync/with-schemas/index.js +1 -1
  341. package/es6/min/persisters/persister-powersync/with-schemas/index.js.gz +0 -0
  342. package/es6/min/persisters/persister-remote/index.js +1 -1
  343. package/es6/min/persisters/persister-remote/index.js.gz +0 -0
  344. package/es6/min/persisters/persister-remote/with-schemas/index.js +1 -1
  345. package/es6/min/persisters/persister-remote/with-schemas/index.js.gz +0 -0
  346. package/es6/min/persisters/persister-sqlite-wasm/index.js +1 -1
  347. package/es6/min/persisters/persister-sqlite-wasm/index.js.gz +0 -0
  348. package/es6/min/persisters/persister-sqlite-wasm/with-schemas/index.js +1 -1
  349. package/es6/min/persisters/persister-sqlite-wasm/with-schemas/index.js.gz +0 -0
  350. package/es6/min/persisters/persister-sqlite3/index.js +1 -1
  351. package/es6/min/persisters/persister-sqlite3/index.js.gz +0 -0
  352. package/es6/min/persisters/persister-sqlite3/with-schemas/index.js +1 -1
  353. package/es6/min/persisters/persister-sqlite3/with-schemas/index.js.gz +0 -0
  354. package/es6/min/persisters/persister-yjs/index.js +1 -1
  355. package/es6/min/persisters/persister-yjs/index.js.gz +0 -0
  356. package/es6/min/persisters/persister-yjs/with-schemas/index.js +1 -1
  357. package/es6/min/persisters/persister-yjs/with-schemas/index.js.gz +0 -0
  358. package/es6/min/persisters/with-schemas/index.js +1 -1
  359. package/es6/min/persisters/with-schemas/index.js.gz +0 -0
  360. package/es6/min/synchronizers/index.js +1 -1
  361. package/es6/min/synchronizers/index.js.gz +0 -0
  362. package/es6/min/synchronizers/synchronizer-broadcast-channel/index.js +1 -1
  363. package/es6/min/synchronizers/synchronizer-broadcast-channel/index.js.gz +0 -0
  364. package/es6/min/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js +1 -1
  365. package/es6/min/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js.gz +0 -0
  366. package/es6/min/synchronizers/synchronizer-local/index.js +1 -1
  367. package/es6/min/synchronizers/synchronizer-local/index.js.gz +0 -0
  368. package/es6/min/synchronizers/synchronizer-local/with-schemas/index.js +1 -1
  369. package/es6/min/synchronizers/synchronizer-local/with-schemas/index.js.gz +0 -0
  370. package/es6/min/synchronizers/synchronizer-ws-client/index.js +1 -1
  371. package/es6/min/synchronizers/synchronizer-ws-client/index.js.gz +0 -0
  372. package/es6/min/synchronizers/synchronizer-ws-client/with-schemas/index.js +1 -1
  373. package/es6/min/synchronizers/synchronizer-ws-client/with-schemas/index.js.gz +0 -0
  374. package/es6/min/synchronizers/synchronizer-ws-server/index.js +1 -1
  375. package/es6/min/synchronizers/synchronizer-ws-server/index.js.gz +0 -0
  376. package/es6/min/synchronizers/synchronizer-ws-server/with-schemas/index.js +1 -1
  377. package/es6/min/synchronizers/synchronizer-ws-server/with-schemas/index.js.gz +0 -0
  378. package/es6/min/synchronizers/with-schemas/index.js +1 -1
  379. package/es6/min/synchronizers/with-schemas/index.js.gz +0 -0
  380. package/es6/min/ui-react-inspector/index.js +1 -1
  381. package/es6/min/ui-react-inspector/index.js.gz +0 -0
  382. package/es6/min/ui-react-inspector/with-schemas/index.js +1 -1
  383. package/es6/min/ui-react-inspector/with-schemas/index.js.gz +0 -0
  384. package/es6/min/with-schemas/index.js +1 -1
  385. package/es6/min/with-schemas/index.js.gz +0 -0
  386. package/es6/persisters/index.js +30 -21
  387. package/es6/persisters/persister-automerge/index.js +29 -24
  388. package/es6/persisters/persister-automerge/with-schemas/index.js +29 -24
  389. package/es6/persisters/persister-browser/index.js +35 -30
  390. package/es6/persisters/persister-browser/with-schemas/index.js +35 -30
  391. package/es6/persisters/persister-cr-sqlite-wasm/index.js +29 -24
  392. package/es6/persisters/persister-cr-sqlite-wasm/with-schemas/index.js +29 -24
  393. package/es6/persisters/persister-electric-sql/index.js +29 -24
  394. package/es6/persisters/persister-electric-sql/with-schemas/index.js +29 -24
  395. package/es6/persisters/persister-expo-sqlite/index.js +29 -24
  396. package/es6/persisters/persister-expo-sqlite/with-schemas/index.js +29 -24
  397. package/es6/persisters/persister-file/index.js +42 -31
  398. package/es6/persisters/persister-file/with-schemas/index.js +42 -31
  399. package/es6/persisters/persister-indexed-db/index.js +29 -24
  400. package/es6/persisters/persister-indexed-db/with-schemas/index.js +29 -24
  401. package/es6/persisters/persister-libsql/index.js +286 -281
  402. package/es6/persisters/persister-libsql/with-schemas/index.js +286 -281
  403. package/es6/persisters/persister-partykit-client/index.js +29 -24
  404. package/es6/persisters/persister-partykit-client/with-schemas/index.js +29 -24
  405. package/es6/persisters/persister-powersync/index.js +29 -24
  406. package/es6/persisters/persister-powersync/with-schemas/index.js +29 -24
  407. package/es6/persisters/persister-remote/index.js +35 -30
  408. package/es6/persisters/persister-remote/with-schemas/index.js +35 -30
  409. package/es6/persisters/persister-sqlite-wasm/index.js +29 -24
  410. package/es6/persisters/persister-sqlite-wasm/with-schemas/index.js +29 -24
  411. package/es6/persisters/persister-sqlite3/index.js +29 -24
  412. package/es6/persisters/persister-sqlite3/with-schemas/index.js +29 -24
  413. package/es6/persisters/persister-yjs/index.js +29 -24
  414. package/es6/persisters/persister-yjs/with-schemas/index.js +29 -24
  415. package/es6/persisters/with-schemas/index.js +30 -21
  416. package/es6/synchronizers/index.js +113 -102
  417. package/es6/synchronizers/synchronizer-broadcast-channel/index.js +109 -104
  418. package/es6/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js +109 -104
  419. package/es6/synchronizers/synchronizer-local/index.js +108 -105
  420. package/es6/synchronizers/synchronizer-local/with-schemas/index.js +108 -105
  421. package/es6/synchronizers/synchronizer-ws-client/index.js +130 -119
  422. package/es6/synchronizers/synchronizer-ws-client/with-schemas/index.js +130 -119
  423. package/es6/synchronizers/synchronizer-ws-server/index.js +691 -35
  424. package/es6/synchronizers/synchronizer-ws-server/with-schemas/index.js +691 -35
  425. package/es6/synchronizers/with-schemas/index.js +113 -102
  426. package/es6/ui-react-inspector/index.js +26 -24
  427. package/es6/ui-react-inspector/with-schemas/index.js +26 -24
  428. package/es6/with-schemas/index.js +101 -86
  429. package/index.js +105 -91
  430. package/indexes/index.js +1 -1
  431. package/indexes/with-schemas/index.js +1 -1
  432. package/metrics/index.js +3 -3
  433. package/metrics/with-schemas/index.js +3 -3
  434. package/min/index.js +1 -1
  435. package/min/index.js.gz +0 -0
  436. package/min/persisters/index.js +1 -1
  437. package/min/persisters/index.js.gz +0 -0
  438. package/min/persisters/persister-automerge/index.js +1 -1
  439. package/min/persisters/persister-automerge/index.js.gz +0 -0
  440. package/min/persisters/persister-automerge/with-schemas/index.js +1 -1
  441. package/min/persisters/persister-automerge/with-schemas/index.js.gz +0 -0
  442. package/min/persisters/persister-browser/index.js +1 -1
  443. package/min/persisters/persister-browser/index.js.gz +0 -0
  444. package/min/persisters/persister-browser/with-schemas/index.js +1 -1
  445. package/min/persisters/persister-browser/with-schemas/index.js.gz +0 -0
  446. package/min/persisters/persister-cr-sqlite-wasm/index.js +1 -1
  447. package/min/persisters/persister-cr-sqlite-wasm/index.js.gz +0 -0
  448. package/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.js +1 -1
  449. package/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.js.gz +0 -0
  450. package/min/persisters/persister-electric-sql/index.js +1 -1
  451. package/min/persisters/persister-electric-sql/index.js.gz +0 -0
  452. package/min/persisters/persister-electric-sql/with-schemas/index.js +1 -1
  453. package/min/persisters/persister-electric-sql/with-schemas/index.js.gz +0 -0
  454. package/min/persisters/persister-expo-sqlite/index.js +1 -1
  455. package/min/persisters/persister-expo-sqlite/index.js.gz +0 -0
  456. package/min/persisters/persister-expo-sqlite/with-schemas/index.js +1 -1
  457. package/min/persisters/persister-expo-sqlite/with-schemas/index.js.gz +0 -0
  458. package/min/persisters/persister-file/index.js +1 -1
  459. package/min/persisters/persister-file/index.js.gz +0 -0
  460. package/min/persisters/persister-file/with-schemas/index.js +1 -1
  461. package/min/persisters/persister-file/with-schemas/index.js.gz +0 -0
  462. package/min/persisters/persister-indexed-db/index.js +1 -1
  463. package/min/persisters/persister-indexed-db/index.js.gz +0 -0
  464. package/min/persisters/persister-indexed-db/with-schemas/index.js +1 -1
  465. package/min/persisters/persister-indexed-db/with-schemas/index.js.gz +0 -0
  466. package/min/persisters/persister-libsql/index.js +1 -1
  467. package/min/persisters/persister-libsql/index.js.gz +0 -0
  468. package/min/persisters/persister-libsql/with-schemas/index.js +1 -1
  469. package/min/persisters/persister-libsql/with-schemas/index.js.gz +0 -0
  470. package/min/persisters/persister-partykit-client/index.js +1 -1
  471. package/min/persisters/persister-partykit-client/index.js.gz +0 -0
  472. package/min/persisters/persister-partykit-client/with-schemas/index.js +1 -1
  473. package/min/persisters/persister-partykit-client/with-schemas/index.js.gz +0 -0
  474. package/min/persisters/persister-powersync/index.js +1 -1
  475. package/min/persisters/persister-powersync/index.js.gz +0 -0
  476. package/min/persisters/persister-powersync/with-schemas/index.js +1 -1
  477. package/min/persisters/persister-powersync/with-schemas/index.js.gz +0 -0
  478. package/min/persisters/persister-remote/index.js +1 -1
  479. package/min/persisters/persister-remote/index.js.gz +0 -0
  480. package/min/persisters/persister-remote/with-schemas/index.js +1 -1
  481. package/min/persisters/persister-remote/with-schemas/index.js.gz +0 -0
  482. package/min/persisters/persister-sqlite-wasm/index.js +1 -1
  483. package/min/persisters/persister-sqlite-wasm/index.js.gz +0 -0
  484. package/min/persisters/persister-sqlite-wasm/with-schemas/index.js +1 -1
  485. package/min/persisters/persister-sqlite-wasm/with-schemas/index.js.gz +0 -0
  486. package/min/persisters/persister-sqlite3/index.js +1 -1
  487. package/min/persisters/persister-sqlite3/index.js.gz +0 -0
  488. package/min/persisters/persister-sqlite3/with-schemas/index.js +1 -1
  489. package/min/persisters/persister-sqlite3/with-schemas/index.js.gz +0 -0
  490. package/min/persisters/persister-yjs/index.js +1 -1
  491. package/min/persisters/persister-yjs/index.js.gz +0 -0
  492. package/min/persisters/persister-yjs/with-schemas/index.js +1 -1
  493. package/min/persisters/persister-yjs/with-schemas/index.js.gz +0 -0
  494. package/min/persisters/with-schemas/index.js +1 -1
  495. package/min/persisters/with-schemas/index.js.gz +0 -0
  496. package/min/synchronizers/index.js +1 -1
  497. package/min/synchronizers/index.js.gz +0 -0
  498. package/min/synchronizers/synchronizer-broadcast-channel/index.js +1 -1
  499. package/min/synchronizers/synchronizer-broadcast-channel/index.js.gz +0 -0
  500. package/min/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js +1 -1
  501. package/min/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js.gz +0 -0
  502. package/min/synchronizers/synchronizer-local/index.js +1 -1
  503. package/min/synchronizers/synchronizer-local/index.js.gz +0 -0
  504. package/min/synchronizers/synchronizer-local/with-schemas/index.js +1 -1
  505. package/min/synchronizers/synchronizer-local/with-schemas/index.js.gz +0 -0
  506. package/min/synchronizers/synchronizer-ws-client/index.js +1 -1
  507. package/min/synchronizers/synchronizer-ws-client/index.js.gz +0 -0
  508. package/min/synchronizers/synchronizer-ws-client/with-schemas/index.js +1 -1
  509. package/min/synchronizers/synchronizer-ws-client/with-schemas/index.js.gz +0 -0
  510. package/min/synchronizers/synchronizer-ws-server/index.js +1 -1
  511. package/min/synchronizers/synchronizer-ws-server/index.js.gz +0 -0
  512. package/min/synchronizers/synchronizer-ws-server/with-schemas/index.js +1 -1
  513. package/min/synchronizers/synchronizer-ws-server/with-schemas/index.js.gz +0 -0
  514. package/min/synchronizers/with-schemas/index.js +1 -1
  515. package/min/synchronizers/with-schemas/index.js.gz +0 -0
  516. package/min/ui-react-inspector/index.js +1 -1
  517. package/min/ui-react-inspector/index.js.gz +0 -0
  518. package/min/ui-react-inspector/with-schemas/index.js +1 -1
  519. package/min/ui-react-inspector/with-schemas/index.js.gz +0 -0
  520. package/min/with-schemas/index.js +1 -1
  521. package/min/with-schemas/index.js.gz +0 -0
  522. package/package.json +1 -1
  523. package/persisters/index.js +28 -19
  524. package/persisters/persister-automerge/index.js +27 -22
  525. package/persisters/persister-automerge/with-schemas/index.js +27 -22
  526. package/persisters/persister-browser/index.js +33 -28
  527. package/persisters/persister-browser/with-schemas/index.js +33 -28
  528. package/persisters/persister-cr-sqlite-wasm/index.js +28 -23
  529. package/persisters/persister-cr-sqlite-wasm/with-schemas/index.js +28 -23
  530. package/persisters/persister-electric-sql/index.js +28 -23
  531. package/persisters/persister-electric-sql/with-schemas/index.js +28 -23
  532. package/persisters/persister-expo-sqlite/index.js +28 -23
  533. package/persisters/persister-expo-sqlite/with-schemas/index.js +28 -23
  534. package/persisters/persister-file/index.js +40 -29
  535. package/persisters/persister-file/with-schemas/index.js +40 -29
  536. package/persisters/persister-indexed-db/index.js +27 -22
  537. package/persisters/persister-indexed-db/with-schemas/index.js +27 -22
  538. package/persisters/persister-libsql/index.js +194 -189
  539. package/persisters/persister-libsql/with-schemas/index.js +194 -189
  540. package/persisters/persister-partykit-client/index.js +27 -22
  541. package/persisters/persister-partykit-client/with-schemas/index.js +27 -22
  542. package/persisters/persister-powersync/index.js +28 -23
  543. package/persisters/persister-powersync/with-schemas/index.js +28 -23
  544. package/persisters/persister-remote/index.js +33 -28
  545. package/persisters/persister-remote/with-schemas/index.js +33 -28
  546. package/persisters/persister-sqlite-wasm/index.js +28 -23
  547. package/persisters/persister-sqlite-wasm/with-schemas/index.js +28 -23
  548. package/persisters/persister-sqlite3/index.js +28 -23
  549. package/persisters/persister-sqlite3/with-schemas/index.js +28 -23
  550. package/persisters/persister-yjs/index.js +29 -23
  551. package/persisters/persister-yjs/with-schemas/index.js +29 -23
  552. package/persisters/with-schemas/index.js +28 -19
  553. package/queries/index.js +2 -2
  554. package/queries/with-schemas/index.js +2 -2
  555. package/readme.md +14 -14
  556. package/relationships/index.js +1 -1
  557. package/relationships/with-schemas/index.js +1 -1
  558. package/releases.md +21 -21
  559. package/synchronizers/index.js +105 -95
  560. package/synchronizers/synchronizer-broadcast-channel/index.js +101 -97
  561. package/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js +101 -97
  562. package/synchronizers/synchronizer-local/index.js +100 -98
  563. package/synchronizers/synchronizer-local/with-schemas/index.js +100 -98
  564. package/synchronizers/synchronizer-ws-client/index.js +119 -112
  565. package/synchronizers/synchronizer-ws-client/with-schemas/index.js +119 -112
  566. package/synchronizers/synchronizer-ws-server/index.js +520 -20
  567. package/synchronizers/synchronizer-ws-server/with-schemas/index.js +520 -20
  568. package/synchronizers/with-schemas/index.js +105 -95
  569. package/ui-react-inspector/index.js +24 -22
  570. package/ui-react-inspector/with-schemas/index.js +24 -22
  571. package/umd/es6/index.js +106 -91
  572. package/umd/es6/min/index.js +1 -1
  573. package/umd/es6/min/index.js.gz +0 -0
  574. package/umd/es6/min/persisters/index.js +1 -1
  575. package/umd/es6/min/persisters/index.js.gz +0 -0
  576. package/umd/es6/min/persisters/persister-automerge/index.js +1 -1
  577. package/umd/es6/min/persisters/persister-automerge/index.js.gz +0 -0
  578. package/umd/es6/min/persisters/persister-automerge/with-schemas/index.js +1 -1
  579. package/umd/es6/min/persisters/persister-automerge/with-schemas/index.js.gz +0 -0
  580. package/umd/es6/min/persisters/persister-browser/index.js +1 -1
  581. package/umd/es6/min/persisters/persister-browser/index.js.gz +0 -0
  582. package/umd/es6/min/persisters/persister-browser/with-schemas/index.js +1 -1
  583. package/umd/es6/min/persisters/persister-browser/with-schemas/index.js.gz +0 -0
  584. package/umd/es6/min/persisters/persister-cr-sqlite-wasm/index.js +1 -1
  585. package/umd/es6/min/persisters/persister-cr-sqlite-wasm/index.js.gz +0 -0
  586. package/umd/es6/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.js +1 -1
  587. package/umd/es6/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.js.gz +0 -0
  588. package/umd/es6/min/persisters/persister-electric-sql/index.js +1 -1
  589. package/umd/es6/min/persisters/persister-electric-sql/index.js.gz +0 -0
  590. package/umd/es6/min/persisters/persister-electric-sql/with-schemas/index.js +1 -1
  591. package/umd/es6/min/persisters/persister-electric-sql/with-schemas/index.js.gz +0 -0
  592. package/umd/es6/min/persisters/persister-expo-sqlite/index.js +1 -1
  593. package/umd/es6/min/persisters/persister-expo-sqlite/index.js.gz +0 -0
  594. package/umd/es6/min/persisters/persister-expo-sqlite/with-schemas/index.js +1 -1
  595. package/umd/es6/min/persisters/persister-expo-sqlite/with-schemas/index.js.gz +0 -0
  596. package/umd/es6/min/persisters/persister-file/index.js +1 -1
  597. package/umd/es6/min/persisters/persister-file/index.js.gz +0 -0
  598. package/umd/es6/min/persisters/persister-file/with-schemas/index.js +1 -1
  599. package/umd/es6/min/persisters/persister-file/with-schemas/index.js.gz +0 -0
  600. package/umd/es6/min/persisters/persister-indexed-db/index.js +1 -1
  601. package/umd/es6/min/persisters/persister-indexed-db/index.js.gz +0 -0
  602. package/umd/es6/min/persisters/persister-indexed-db/with-schemas/index.js +1 -1
  603. package/umd/es6/min/persisters/persister-indexed-db/with-schemas/index.js.gz +0 -0
  604. package/umd/es6/min/persisters/persister-libsql/index.js +1 -1
  605. package/umd/es6/min/persisters/persister-libsql/index.js.gz +0 -0
  606. package/umd/es6/min/persisters/persister-libsql/with-schemas/index.js +1 -1
  607. package/umd/es6/min/persisters/persister-libsql/with-schemas/index.js.gz +0 -0
  608. package/umd/es6/min/persisters/persister-partykit-client/index.js +1 -1
  609. package/umd/es6/min/persisters/persister-partykit-client/index.js.gz +0 -0
  610. package/umd/es6/min/persisters/persister-partykit-client/with-schemas/index.js +1 -1
  611. package/umd/es6/min/persisters/persister-partykit-client/with-schemas/index.js.gz +0 -0
  612. package/umd/es6/min/persisters/persister-powersync/index.js +1 -1
  613. package/umd/es6/min/persisters/persister-powersync/index.js.gz +0 -0
  614. package/umd/es6/min/persisters/persister-powersync/with-schemas/index.js +1 -1
  615. package/umd/es6/min/persisters/persister-powersync/with-schemas/index.js.gz +0 -0
  616. package/umd/es6/min/persisters/persister-remote/index.js +1 -1
  617. package/umd/es6/min/persisters/persister-remote/index.js.gz +0 -0
  618. package/umd/es6/min/persisters/persister-remote/with-schemas/index.js +1 -1
  619. package/umd/es6/min/persisters/persister-remote/with-schemas/index.js.gz +0 -0
  620. package/umd/es6/min/persisters/persister-sqlite-wasm/index.js +1 -1
  621. package/umd/es6/min/persisters/persister-sqlite-wasm/index.js.gz +0 -0
  622. package/umd/es6/min/persisters/persister-sqlite-wasm/with-schemas/index.js +1 -1
  623. package/umd/es6/min/persisters/persister-sqlite-wasm/with-schemas/index.js.gz +0 -0
  624. package/umd/es6/min/persisters/persister-sqlite3/index.js +1 -1
  625. package/umd/es6/min/persisters/persister-sqlite3/index.js.gz +0 -0
  626. package/umd/es6/min/persisters/persister-sqlite3/with-schemas/index.js +1 -1
  627. package/umd/es6/min/persisters/persister-sqlite3/with-schemas/index.js.gz +0 -0
  628. package/umd/es6/min/persisters/persister-yjs/index.js +1 -1
  629. package/umd/es6/min/persisters/persister-yjs/index.js.gz +0 -0
  630. package/umd/es6/min/persisters/persister-yjs/with-schemas/index.js +1 -1
  631. package/umd/es6/min/persisters/persister-yjs/with-schemas/index.js.gz +0 -0
  632. package/umd/es6/min/persisters/with-schemas/index.js +1 -1
  633. package/umd/es6/min/persisters/with-schemas/index.js.gz +0 -0
  634. package/umd/es6/min/synchronizers/index.js +1 -1
  635. package/umd/es6/min/synchronizers/index.js.gz +0 -0
  636. package/umd/es6/min/synchronizers/synchronizer-broadcast-channel/index.js +1 -1
  637. package/umd/es6/min/synchronizers/synchronizer-broadcast-channel/index.js.gz +0 -0
  638. package/umd/es6/min/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js +1 -1
  639. package/umd/es6/min/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js.gz +0 -0
  640. package/umd/es6/min/synchronizers/synchronizer-local/index.js +1 -1
  641. package/umd/es6/min/synchronizers/synchronizer-local/index.js.gz +0 -0
  642. package/umd/es6/min/synchronizers/synchronizer-local/with-schemas/index.js +1 -1
  643. package/umd/es6/min/synchronizers/synchronizer-local/with-schemas/index.js.gz +0 -0
  644. package/umd/es6/min/synchronizers/synchronizer-ws-client/index.js +1 -1
  645. package/umd/es6/min/synchronizers/synchronizer-ws-client/index.js.gz +0 -0
  646. package/umd/es6/min/synchronizers/synchronizer-ws-client/with-schemas/index.js +1 -1
  647. package/umd/es6/min/synchronizers/synchronizer-ws-client/with-schemas/index.js.gz +0 -0
  648. package/umd/es6/min/synchronizers/synchronizer-ws-server/index.js +1 -1
  649. package/umd/es6/min/synchronizers/synchronizer-ws-server/index.js.gz +0 -0
  650. package/umd/es6/min/synchronizers/synchronizer-ws-server/with-schemas/index.js +1 -1
  651. package/umd/es6/min/synchronizers/synchronizer-ws-server/with-schemas/index.js.gz +0 -0
  652. package/umd/es6/min/synchronizers/with-schemas/index.js +1 -1
  653. package/umd/es6/min/synchronizers/with-schemas/index.js.gz +0 -0
  654. package/umd/es6/min/ui-react-inspector/index.js +1 -1
  655. package/umd/es6/min/ui-react-inspector/index.js.gz +0 -0
  656. package/umd/es6/min/ui-react-inspector/with-schemas/index.js +1 -1
  657. package/umd/es6/min/ui-react-inspector/with-schemas/index.js.gz +0 -0
  658. package/umd/es6/min/with-schemas/index.js +1 -1
  659. package/umd/es6/min/with-schemas/index.js.gz +0 -0
  660. package/umd/es6/persisters/index.js +30 -21
  661. package/umd/es6/persisters/persister-automerge/index.js +29 -24
  662. package/umd/es6/persisters/persister-automerge/with-schemas/index.js +29 -24
  663. package/umd/es6/persisters/persister-browser/index.js +37 -32
  664. package/umd/es6/persisters/persister-browser/with-schemas/index.js +37 -32
  665. package/umd/es6/persisters/persister-cr-sqlite-wasm/index.js +29 -24
  666. package/umd/es6/persisters/persister-cr-sqlite-wasm/with-schemas/index.js +29 -24
  667. package/umd/es6/persisters/persister-electric-sql/index.js +29 -24
  668. package/umd/es6/persisters/persister-electric-sql/with-schemas/index.js +29 -24
  669. package/umd/es6/persisters/persister-expo-sqlite/index.js +29 -24
  670. package/umd/es6/persisters/persister-expo-sqlite/with-schemas/index.js +29 -24
  671. package/umd/es6/persisters/persister-file/index.js +43 -33
  672. package/umd/es6/persisters/persister-file/with-schemas/index.js +43 -33
  673. package/umd/es6/persisters/persister-indexed-db/index.js +29 -24
  674. package/umd/es6/persisters/persister-indexed-db/with-schemas/index.js +29 -24
  675. package/umd/es6/persisters/persister-libsql/index.js +291 -286
  676. package/umd/es6/persisters/persister-libsql/with-schemas/index.js +291 -286
  677. package/umd/es6/persisters/persister-partykit-client/index.js +29 -24
  678. package/umd/es6/persisters/persister-partykit-client/with-schemas/index.js +29 -24
  679. package/umd/es6/persisters/persister-powersync/index.js +29 -24
  680. package/umd/es6/persisters/persister-powersync/with-schemas/index.js +29 -24
  681. package/umd/es6/persisters/persister-remote/index.js +35 -30
  682. package/umd/es6/persisters/persister-remote/with-schemas/index.js +35 -30
  683. package/umd/es6/persisters/persister-sqlite-wasm/index.js +29 -24
  684. package/umd/es6/persisters/persister-sqlite-wasm/with-schemas/index.js +29 -24
  685. package/umd/es6/persisters/persister-sqlite3/index.js +29 -24
  686. package/umd/es6/persisters/persister-sqlite3/with-schemas/index.js +29 -24
  687. package/umd/es6/persisters/persister-yjs/index.js +29 -24
  688. package/umd/es6/persisters/persister-yjs/with-schemas/index.js +29 -24
  689. package/umd/es6/persisters/with-schemas/index.js +30 -21
  690. package/umd/es6/synchronizers/index.js +118 -107
  691. package/umd/es6/synchronizers/synchronizer-broadcast-channel/index.js +114 -109
  692. package/umd/es6/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js +114 -109
  693. package/umd/es6/synchronizers/synchronizer-local/index.js +118 -110
  694. package/umd/es6/synchronizers/synchronizer-local/with-schemas/index.js +118 -110
  695. package/umd/es6/synchronizers/synchronizer-ws-client/index.js +135 -124
  696. package/umd/es6/synchronizers/synchronizer-ws-client/with-schemas/index.js +135 -124
  697. package/umd/es6/synchronizers/synchronizer-ws-server/index.js +710 -35
  698. package/umd/es6/synchronizers/synchronizer-ws-server/with-schemas/index.js +710 -35
  699. package/umd/es6/synchronizers/with-schemas/index.js +118 -107
  700. package/umd/es6/ui-react-inspector/index.js +26 -24
  701. package/umd/es6/ui-react-inspector/with-schemas/index.js +26 -24
  702. package/umd/es6/with-schemas/index.js +106 -91
  703. package/umd/index.js +108 -94
  704. package/umd/indexes/index.js +1 -1
  705. package/umd/indexes/with-schemas/index.js +1 -1
  706. package/umd/metrics/index.js +3 -3
  707. package/umd/metrics/with-schemas/index.js +3 -3
  708. package/umd/min/index.js +1 -1
  709. package/umd/min/index.js.gz +0 -0
  710. package/umd/min/persisters/index.js +1 -1
  711. package/umd/min/persisters/index.js.gz +0 -0
  712. package/umd/min/persisters/persister-automerge/index.js +1 -1
  713. package/umd/min/persisters/persister-automerge/index.js.gz +0 -0
  714. package/umd/min/persisters/persister-automerge/with-schemas/index.js +1 -1
  715. package/umd/min/persisters/persister-automerge/with-schemas/index.js.gz +0 -0
  716. package/umd/min/persisters/persister-browser/index.js +1 -1
  717. package/umd/min/persisters/persister-browser/index.js.gz +0 -0
  718. package/umd/min/persisters/persister-browser/with-schemas/index.js +1 -1
  719. package/umd/min/persisters/persister-browser/with-schemas/index.js.gz +0 -0
  720. package/umd/min/persisters/persister-cr-sqlite-wasm/index.js +1 -1
  721. package/umd/min/persisters/persister-cr-sqlite-wasm/index.js.gz +0 -0
  722. package/umd/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.js +1 -1
  723. package/umd/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.js.gz +0 -0
  724. package/umd/min/persisters/persister-electric-sql/index.js +1 -1
  725. package/umd/min/persisters/persister-electric-sql/index.js.gz +0 -0
  726. package/umd/min/persisters/persister-electric-sql/with-schemas/index.js +1 -1
  727. package/umd/min/persisters/persister-electric-sql/with-schemas/index.js.gz +0 -0
  728. package/umd/min/persisters/persister-expo-sqlite/index.js +1 -1
  729. package/umd/min/persisters/persister-expo-sqlite/index.js.gz +0 -0
  730. package/umd/min/persisters/persister-expo-sqlite/with-schemas/index.js +1 -1
  731. package/umd/min/persisters/persister-expo-sqlite/with-schemas/index.js.gz +0 -0
  732. package/umd/min/persisters/persister-file/index.js +1 -1
  733. package/umd/min/persisters/persister-file/index.js.gz +0 -0
  734. package/umd/min/persisters/persister-file/with-schemas/index.js +1 -1
  735. package/umd/min/persisters/persister-file/with-schemas/index.js.gz +0 -0
  736. package/umd/min/persisters/persister-indexed-db/index.js +1 -1
  737. package/umd/min/persisters/persister-indexed-db/index.js.gz +0 -0
  738. package/umd/min/persisters/persister-indexed-db/with-schemas/index.js +1 -1
  739. package/umd/min/persisters/persister-indexed-db/with-schemas/index.js.gz +0 -0
  740. package/umd/min/persisters/persister-libsql/index.js +1 -1
  741. package/umd/min/persisters/persister-libsql/index.js.gz +0 -0
  742. package/umd/min/persisters/persister-libsql/with-schemas/index.js +1 -1
  743. package/umd/min/persisters/persister-libsql/with-schemas/index.js.gz +0 -0
  744. package/umd/min/persisters/persister-partykit-client/index.js +1 -1
  745. package/umd/min/persisters/persister-partykit-client/index.js.gz +0 -0
  746. package/umd/min/persisters/persister-partykit-client/with-schemas/index.js +1 -1
  747. package/umd/min/persisters/persister-partykit-client/with-schemas/index.js.gz +0 -0
  748. package/umd/min/persisters/persister-powersync/index.js +1 -1
  749. package/umd/min/persisters/persister-powersync/index.js.gz +0 -0
  750. package/umd/min/persisters/persister-powersync/with-schemas/index.js +1 -1
  751. package/umd/min/persisters/persister-powersync/with-schemas/index.js.gz +0 -0
  752. package/umd/min/persisters/persister-remote/index.js +1 -1
  753. package/umd/min/persisters/persister-remote/index.js.gz +0 -0
  754. package/umd/min/persisters/persister-remote/with-schemas/index.js +1 -1
  755. package/umd/min/persisters/persister-remote/with-schemas/index.js.gz +0 -0
  756. package/umd/min/persisters/persister-sqlite-wasm/index.js +1 -1
  757. package/umd/min/persisters/persister-sqlite-wasm/index.js.gz +0 -0
  758. package/umd/min/persisters/persister-sqlite-wasm/with-schemas/index.js +1 -1
  759. package/umd/min/persisters/persister-sqlite-wasm/with-schemas/index.js.gz +0 -0
  760. package/umd/min/persisters/persister-sqlite3/index.js +1 -1
  761. package/umd/min/persisters/persister-sqlite3/index.js.gz +0 -0
  762. package/umd/min/persisters/persister-sqlite3/with-schemas/index.js +1 -1
  763. package/umd/min/persisters/persister-sqlite3/with-schemas/index.js.gz +0 -0
  764. package/umd/min/persisters/persister-yjs/index.js +1 -1
  765. package/umd/min/persisters/persister-yjs/index.js.gz +0 -0
  766. package/umd/min/persisters/persister-yjs/with-schemas/index.js +1 -1
  767. package/umd/min/persisters/persister-yjs/with-schemas/index.js.gz +0 -0
  768. package/umd/min/persisters/with-schemas/index.js +1 -1
  769. package/umd/min/persisters/with-schemas/index.js.gz +0 -0
  770. package/umd/min/synchronizers/index.js +1 -1
  771. package/umd/min/synchronizers/index.js.gz +0 -0
  772. package/umd/min/synchronizers/synchronizer-broadcast-channel/index.js +1 -1
  773. package/umd/min/synchronizers/synchronizer-broadcast-channel/index.js.gz +0 -0
  774. package/umd/min/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js +1 -1
  775. package/umd/min/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js.gz +0 -0
  776. package/umd/min/synchronizers/synchronizer-local/index.js +1 -1
  777. package/umd/min/synchronizers/synchronizer-local/index.js.gz +0 -0
  778. package/umd/min/synchronizers/synchronizer-local/with-schemas/index.js +1 -1
  779. package/umd/min/synchronizers/synchronizer-local/with-schemas/index.js.gz +0 -0
  780. package/umd/min/synchronizers/synchronizer-ws-client/index.js +1 -1
  781. package/umd/min/synchronizers/synchronizer-ws-client/index.js.gz +0 -0
  782. package/umd/min/synchronizers/synchronizer-ws-client/with-schemas/index.js +1 -1
  783. package/umd/min/synchronizers/synchronizer-ws-client/with-schemas/index.js.gz +0 -0
  784. package/umd/min/synchronizers/synchronizer-ws-server/index.js +1 -1
  785. package/umd/min/synchronizers/synchronizer-ws-server/index.js.gz +0 -0
  786. package/umd/min/synchronizers/synchronizer-ws-server/with-schemas/index.js +1 -1
  787. package/umd/min/synchronizers/synchronizer-ws-server/with-schemas/index.js.gz +0 -0
  788. package/umd/min/synchronizers/with-schemas/index.js +1 -1
  789. package/umd/min/synchronizers/with-schemas/index.js.gz +0 -0
  790. package/umd/min/ui-react-inspector/index.js +1 -1
  791. package/umd/min/ui-react-inspector/index.js.gz +0 -0
  792. package/umd/min/ui-react-inspector/with-schemas/index.js +1 -1
  793. package/umd/min/ui-react-inspector/with-schemas/index.js.gz +0 -0
  794. package/umd/min/with-schemas/index.js +1 -1
  795. package/umd/min/with-schemas/index.js.gz +0 -0
  796. package/umd/persisters/index.js +28 -19
  797. package/umd/persisters/persister-automerge/index.js +27 -22
  798. package/umd/persisters/persister-automerge/with-schemas/index.js +27 -22
  799. package/umd/persisters/persister-browser/index.js +35 -30
  800. package/umd/persisters/persister-browser/with-schemas/index.js +35 -30
  801. package/umd/persisters/persister-cr-sqlite-wasm/index.js +28 -23
  802. package/umd/persisters/persister-cr-sqlite-wasm/with-schemas/index.js +28 -23
  803. package/umd/persisters/persister-electric-sql/index.js +28 -23
  804. package/umd/persisters/persister-electric-sql/with-schemas/index.js +28 -23
  805. package/umd/persisters/persister-expo-sqlite/index.js +28 -23
  806. package/umd/persisters/persister-expo-sqlite/with-schemas/index.js +28 -23
  807. package/umd/persisters/persister-file/index.js +41 -31
  808. package/umd/persisters/persister-file/with-schemas/index.js +41 -31
  809. package/umd/persisters/persister-indexed-db/index.js +27 -22
  810. package/umd/persisters/persister-indexed-db/with-schemas/index.js +27 -22
  811. package/umd/persisters/persister-libsql/index.js +196 -191
  812. package/umd/persisters/persister-libsql/with-schemas/index.js +196 -191
  813. package/umd/persisters/persister-partykit-client/index.js +27 -22
  814. package/umd/persisters/persister-partykit-client/with-schemas/index.js +27 -22
  815. package/umd/persisters/persister-powersync/index.js +28 -23
  816. package/umd/persisters/persister-powersync/with-schemas/index.js +28 -23
  817. package/umd/persisters/persister-remote/index.js +33 -28
  818. package/umd/persisters/persister-remote/with-schemas/index.js +33 -28
  819. package/umd/persisters/persister-sqlite-wasm/index.js +28 -23
  820. package/umd/persisters/persister-sqlite-wasm/with-schemas/index.js +28 -23
  821. package/umd/persisters/persister-sqlite3/index.js +28 -23
  822. package/umd/persisters/persister-sqlite3/with-schemas/index.js +28 -23
  823. package/umd/persisters/persister-yjs/index.js +29 -24
  824. package/umd/persisters/persister-yjs/with-schemas/index.js +29 -24
  825. package/umd/persisters/with-schemas/index.js +28 -19
  826. package/umd/queries/index.js +2 -2
  827. package/umd/queries/with-schemas/index.js +2 -2
  828. package/umd/relationships/index.js +1 -1
  829. package/umd/relationships/with-schemas/index.js +1 -1
  830. package/umd/synchronizers/index.js +108 -98
  831. package/umd/synchronizers/synchronizer-broadcast-channel/index.js +104 -100
  832. package/umd/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js +104 -100
  833. package/umd/synchronizers/synchronizer-local/index.js +108 -101
  834. package/umd/synchronizers/synchronizer-local/with-schemas/index.js +108 -101
  835. package/umd/synchronizers/synchronizer-ws-client/index.js +122 -115
  836. package/umd/synchronizers/synchronizer-ws-client/with-schemas/index.js +122 -115
  837. package/umd/synchronizers/synchronizer-ws-server/index.js +544 -34
  838. package/umd/synchronizers/synchronizer-ws-server/with-schemas/index.js +544 -34
  839. package/umd/synchronizers/with-schemas/index.js +108 -98
  840. package/umd/ui-react-inspector/index.js +24 -22
  841. package/umd/ui-react-inspector/with-schemas/index.js +24 -22
  842. package/umd/with-schemas/index.js +108 -94
  843. package/with-schemas/index.js +105 -91
@@ -1 +1 @@
1
- "use strict";var t=require("fs"),e=require("fs/promises");const a="utf8",s=t=>null==t,r=(t,e,a)=>s(t)?a?.():e(t),n=Object,o=t=>n.getPrototypeOf(t),i=n.keys,c=n.freeze,y=t=>(t=>!s(t)&&r(o(t),(t=>t==n.prototype||s(o(t))),(()=>!0)))(t)&&0==(t=>i(t).length)(t),l=t=>new Map(t),g=(t,e)=>t?.get(e),u=(t,e,a)=>{return s(a)?(r=t,n=e,r?.delete(n),t):t?.set(e,a);var r,n},d=(t,e,a,s)=>{var r,n;return r=t,n=e,r?.has(n)||u(t,e,a()),g(t,e)},p=l(),v=l();exports.createFilePersister=(n,o,i)=>((t,e,a,n,o,i,l,h={},w=[])=>{let f,C,A,S=0,b=0,M=0;d(p,w,(()=>0)),d(v,w,(()=>[]));const[F,L,O,P,T]=((t=1,e)=>1!=t&&e.isMergeable()?[1,e.getMergeableContent,e.getTransactionMergeableChanges,([[t],[e]])=>!y(t)||!y(e),e.setDefaultContent]:2!=t?[0,e.getContent,e.getTransactionChanges,([t,e])=>!y(t)||!y(e),e.setContent]:(t=>{throw Error("Store type not supported by this Persister")})())(l,t),q=e=>{var a;(F&&(a=e?.[0],Array.isArray(a))?1===e?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===e?.[2]?t.applyChanges:t.setContent)(e)},D=async t=>(2!=S&&(S=1,b++,await k((async()=>{try{q(await e())}catch(e){i?.(e),t&&T(t)}S=0}))),m),J=()=>(C&&(o(C),C=void 0),m),N=async t=>(1!=S&&(S=2,M++,await k((async()=>{try{await a(L,t)}catch(t){i?.(t)}S=0}))),m),j=()=>(r(A,t.delListener),A=void 0,m),k=async(...t)=>(((t,...e)=>{t.push(...e)})(g(v,w),...t),await(async()=>{if(!g(p,w)){for(u(p,w,1);!s((t=g(v,w),f=t.shift()));)try{await f()}catch(t){i?.(t)}u(p,w,0)}var t})(),m),m={load:D,startAutoLoad:async t=>(await J().load(t),C=n((async(t,e)=>{e||t?2!=S&&(S=1,b++,q(e??t),S=0):await D()})),m),stopAutoLoad:J,isAutoLoading:()=>!s(C),save:N,startAutoSave:async()=>(await j().save(),A=t.addDidFinishTransactionListener((()=>{const t=O();P(t)&&N(t)})),m),stopAutoSave:j,isAutoSaving:()=>!s(A),schedule:k,getStore:()=>t,destroy:()=>J().stopAutoSave(),getStats:()=>({loads:b,saves:M}),...h};return c(m)})(n,(async()=>{return t=await e.readFile(o,a),JSON.parse(t,((t,e)=>""===e?void 0:e));var t}),(async t=>{return await e.writeFile(o,(s=t(),JSON.stringify(s,((t,e)=>void 0===e?"":e))),a);var s}),(e=>t.watch(o,(()=>e()))),(t=>t?.close()),i,3,{getFilePath:()=>o});
1
+ "use strict";var t=require("fs"),e=require("fs/promises");const a="utf8",s=t=>null==t,r=(t,e,a)=>s(t)?a?.():e(t),n=Object,i=t=>n.getPrototypeOf(t),o=n.keys,c=n.freeze,y=t=>(t=>!s(t)&&r(i(t),(t=>t==n.prototype||s(i(t))),(()=>!0)))(t)&&0==(t=>o(t).length)(t),l=t=>new Map(t),g=(t,e)=>t?.get(e),u=(t,e,a)=>{return s(a)?(r=t,n=e,r?.delete(n),t):t?.set(e,a);var r,n},d=(t,e,a,s)=>{var r,n;return r=t,n=e,r?.has(n)||u(t,e,a()),g(t,e)},p=l(),v=l();exports.createFilePersister=(n,i,o)=>((t,e,a,n,i,o,l,h={},w=[])=>{let S,f,C,A=0,b=0,F=0;d(p,w,(()=>0)),d(v,w,(()=>[]));const[M,L,O,P,T]=((t=1,e)=>1!=t&&e.isMergeable()?[1,e.getMergeableContent,e.getTransactionMergeableChanges,([[t],[e]])=>!y(t)||!y(e),e.setDefaultContent]:2!=t?[0,e.getContent,e.getTransactionChanges,([t,e])=>!y(t)||!y(e),e.setContent]:(t=>{throw Error("Store type not supported by this Persister")})())(l,t),q=e=>{var a;(M&&(a=e?.[0],Array.isArray(a))?1===e?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===e?.[2]?t.applyChanges:t.setContent)(e)},x=async t=>(2!=A&&(A=1,b++,await j((async()=>{try{q(await e())}catch(e){o?.(e),t&&T(t)}A=0}))),k),D=()=>(f&&(i(f),f=void 0),k),J=async t=>(1!=A&&(A=2,F++,await j((async()=>{try{await a(L,t)}catch(t){o?.(t)}A=0}))),k),N=()=>(r(C,t.delListener),C=void 0,k),j=async(...t)=>(((t,...e)=>{t.push(...e)})(g(v,w),...t),await(async()=>{if(!g(p,w)){for(u(p,w,1);!s((t=g(v,w),S=t.shift()));)try{await S()}catch(t){o?.(t)}u(p,w,0)}var t})(),k),k={load:x,startAutoLoad:async t=>{await D().load(t);try{f=n((async(t,e)=>{e||t?2!=A&&(A=1,b++,q(e??t),A=0):await x()}))}catch(t){o?.(t)}return k},stopAutoLoad:D,isAutoLoading:()=>!s(f),save:J,startAutoSave:async()=>(await N().save(),C=t.addDidFinishTransactionListener((()=>{const t=O();P(t)&&J(t)})),k),stopAutoSave:N,isAutoSaving:()=>!s(C),schedule:j,getStore:()=>t,destroy:()=>(g(v,w).splice(0,void 0),D().stopAutoSave()),getStats:()=>({loads:b,saves:F}),...h};return c(k)})(n,(async()=>{return t=await e.readFile(i,a),JSON.parse(t,((t,e)=>""===e?void 0:e));var t}),(async t=>{return await e.writeFile(i,(s=t(),JSON.stringify(s,((t,e)=>void 0===e?"":e))),a);var s}),(e=>(t.existsSync(i)||t.writeFileSync(i,"",a),t.watch(i,(()=>e())))),(t=>t?.close()),o,3,{getFilePath:()=>i});
@@ -1 +1 @@
1
- "use strict";const e=Promise,t=globalThis.window,a=clearInterval,s=e=>null==e,r=(e,t,a)=>s(e)?a?.():t(e),n=t=>new e(t),o=async t=>e.all(t),c=(e,t)=>e.map(t),i=(e,...t)=>e.push(...t),l=Object,y=e=>l.getPrototypeOf(e),d=l.entries,u=l.keys,g=l.freeze,w=e=>(e=>!s(e)&&r(y(e),(e=>e==l.prototype||s(y(e))),(()=>!0)))(e)&&0==(e=>u(e).length)(e),p=e=>new Map(e),h=(e,t)=>e?.get(t),v=(e,t,a)=>{return s(a)?(r=e,n=t,r?.delete(n),e):e?.set(t,a);var r,n},b=(e,t,a,s)=>{var r,n;return r=e,n=t,r?.has(n)||v(e,t,a()),h(e,t)},A=p(),S=p(),C=["t","v"],f={keyPath:"k"},D=async(e,t)=>{const a=((t,a)=>c(d(t),(([t,a])=>M(e,"put",{k:t,v:a}))))(t);c(await M(e,"getAllKeys"),(s=>((e,t)=>t in e)(t,s)?0:i(a,M(e,"delete",s)))),await o(a)},M=async(e,t,a)=>n(((s,r)=>{const n=e[t](a);n.onsuccess=()=>s(n.result),n.onerror=()=>r(`objectStore.${t} error`)}));exports.createIndexedDbPersister=(e,y,d=1,u)=>{const p=async(e,a=[],s=0)=>n(((r,n)=>{const i=(t?t.indexedDB:indexedDB).open(y,s?2:void 0);i.onupgradeneeded=()=>s&&c(C,(e=>{try{i.result.createObjectStore(e,f)}catch{}})),i.onsuccess=async()=>{try{const t=i.result.transaction(C,"readwrite"),s=await o(c(C,(async(s,r)=>await e(t.objectStore(s),a[r]))));i.result.close(),r(s)}catch(e){i.result.close(),n(e)}},i.onerror=()=>n("indexedDB.open error")}));return((e,t,a,n,o,c,l,y={},d=[])=>{let u,p,C,f=0,D=0,M=0;b(A,d,(()=>0)),b(S,d,(()=>[]));const[x,j,k,L,P]=((e=1,t)=>1!=e&&t.isMergeable()?[1,t.getMergeableContent,t.getTransactionMergeableChanges,([[e],[t]])=>!w(e)||!w(t),t.setDefaultContent]:2!=e?[0,t.getContent,t.getTransactionChanges,([e,t])=>!w(e)||!w(t),t.setContent]:(e=>{throw Error("Store type not supported by this Persister")})())(l,e),m=t=>{var a;(x&&(a=t?.[0],Array.isArray(a))?1===t?.[2]?e.applyMergeableChanges:e.setMergeableContent:1===t?.[2]?e.applyChanges:e.setContent)(t)},T=async e=>(2!=f&&(f=1,D++,await E((async()=>{try{m(await t())}catch(t){c?.(t),e&&P(e)}f=0}))),z),B=()=>(p&&(o(p),p=void 0),z),I=async e=>(1!=f&&(f=2,M++,await E((async()=>{try{await a(j,e)}catch(e){c?.(e)}f=0}))),z),O=()=>(r(C,e.delListener),C=void 0,z),E=async(...e)=>(i(h(S,d),...e),await(async()=>{if(!h(A,d)){for(v(A,d,1);!s((e=h(S,d),u=e.shift()));)try{await u()}catch(e){c?.(e)}v(A,d,0)}var e})(),z),z={load:T,startAutoLoad:async e=>(await B().load(e),p=n((async(e,t)=>{t||e?2!=f&&(f=1,D++,m(t??e),f=0):await T()})),z),stopAutoLoad:B,isAutoLoading:()=>!s(p),save:I,startAutoSave:async()=>(await O().save(),C=e.addDidFinishTransactionListener((()=>{const e=k();L(e)&&I(e)})),z),stopAutoSave:O,isAutoSaving:()=>!s(C),schedule:E,getStore:()=>e,destroy:()=>B().stopAutoSave(),getStats:()=>({loads:D,saves:M}),...y};return g(z)})(e,(async()=>await p((async e=>((e=[])=>l.fromEntries(e))(c(await M(e,"getAll"),(({k:e,v:t})=>[e,t])))))),(async e=>await p((async(e,t)=>await D(e,t)),e(),1)),(e=>setInterval(e,1e3*d)),(e=>a(e)),u,1,{getDbName:()=>y})},exports.objectStoreMatch=D;
1
+ "use strict";const e=Promise,t=globalThis.window,a=clearInterval,s=e=>null==e,r=(e,t,a)=>s(e)?a?.():t(e),n=t=>new e(t),o=async t=>e.all(t),c=(e,t)=>e.map(t),i=(e,...t)=>e.push(...t),l=Object,y=e=>l.getPrototypeOf(e),d=l.entries,u=l.keys,g=l.freeze,p=e=>(e=>!s(e)&&r(y(e),(e=>e==l.prototype||s(y(e))),(()=>!0)))(e)&&0==(e=>u(e).length)(e),w=e=>new Map(e),h=(e,t)=>e?.get(t),v=(e,t,a)=>{return s(a)?(r=e,n=t,r?.delete(n),e):e?.set(t,a);var r,n},b=(e,t,a,s)=>{var r,n;return r=e,n=t,r?.has(n)||v(e,t,a()),h(e,t)},A=w(),S=w(),C=["t","v"],f={keyPath:"k"},D=async(e,t)=>{const a=((t,a)=>c(d(t),(([t,a])=>M(e,"put",{k:t,v:a}))))(t);c(await M(e,"getAllKeys"),(s=>((e,t)=>t in e)(t,s)?0:i(a,M(e,"delete",s)))),await o(a)},M=async(e,t,a)=>n(((s,r)=>{const n=e[t](a);n.onsuccess=()=>s(n.result),n.onerror=()=>r(`objectStore.${t} error`)}));exports.createIndexedDbPersister=(e,y,d=1,u)=>{const w=async(e,a=[],s=0)=>n(((r,n)=>{const i=(t?t.indexedDB:indexedDB).open(y,s?2:void 0);i.onupgradeneeded=()=>s&&c(C,(e=>{try{i.result.createObjectStore(e,f)}catch{}})),i.onsuccess=async()=>{try{const t=i.result.transaction(C,"readwrite"),s=await o(c(C,(async(s,r)=>await e(t.objectStore(s),a[r]))));i.result.close(),r(s)}catch(e){i.result.close(),n(e)}},i.onerror=()=>n("indexedDB.open error")}));return((e,t,a,n,o,c,l,y={},d=[])=>{let u,w,C,f=0,D=0,M=0;b(A,d,(()=>0)),b(S,d,(()=>[]));const[x,j,k,L,P]=((e=1,t)=>1!=e&&t.isMergeable()?[1,t.getMergeableContent,t.getTransactionMergeableChanges,([[e],[t]])=>!p(e)||!p(t),t.setDefaultContent]:2!=e?[0,t.getContent,t.getTransactionChanges,([e,t])=>!p(e)||!p(t),t.setContent]:(e=>{throw Error("Store type not supported by this Persister")})())(l,e),m=t=>{var a;(x&&(a=t?.[0],Array.isArray(a))?1===t?.[2]?e.applyMergeableChanges:e.setMergeableContent:1===t?.[2]?e.applyChanges:e.setContent)(t)},T=async e=>(2!=f&&(f=1,D++,await E((async()=>{try{m(await t())}catch(t){c?.(t),e&&P(e)}f=0}))),z),B=()=>(w&&(o(w),w=void 0),z),I=async e=>(1!=f&&(f=2,M++,await E((async()=>{try{await a(j,e)}catch(e){c?.(e)}f=0}))),z),O=()=>(r(C,e.delListener),C=void 0,z),E=async(...e)=>(i(h(S,d),...e),await(async()=>{if(!h(A,d)){for(v(A,d,1);!s((e=h(S,d),u=e.shift()));)try{await u()}catch(e){c?.(e)}v(A,d,0)}var e})(),z),z={load:T,startAutoLoad:async e=>{await B().load(e);try{w=n((async(e,t)=>{t||e?2!=f&&(f=1,D++,m(t??e),f=0):await T()}))}catch(e){c?.(e)}return z},stopAutoLoad:B,isAutoLoading:()=>!s(w),save:I,startAutoSave:async()=>(await O().save(),C=e.addDidFinishTransactionListener((()=>{const e=k();L(e)&&I(e)})),z),stopAutoSave:O,isAutoSaving:()=>!s(C),schedule:E,getStore:()=>e,destroy:()=>(h(S,d).splice(0,void 0),B().stopAutoSave()),getStats:()=>({loads:D,saves:M}),...y};return g(z)})(e,(async()=>await w((async e=>((e=[])=>l.fromEntries(e))(c(await M(e,"getAll"),(({k:e,v:t})=>[e,t])))))),(async e=>await w((async(e,t)=>await D(e,t)),e(),1)),(e=>setInterval(e,1e3*d)),(e=>a(e)),u,1,{getDbName:()=>y})},exports.objectStoreMatch=D;
@@ -1 +1 @@
1
- "use strict";const e=Promise,t=globalThis.window,a=clearInterval,s=e=>null==e,r=(e,t,a)=>s(e)?a?.():t(e),n=t=>new e(t),o=async t=>e.all(t),c=(e,t)=>e.map(t),i=(e,...t)=>e.push(...t),l=Object,y=e=>l.getPrototypeOf(e),d=l.entries,u=l.keys,g=l.freeze,w=e=>(e=>!s(e)&&r(y(e),(e=>e==l.prototype||s(y(e))),(()=>!0)))(e)&&0==(e=>u(e).length)(e),p=e=>new Map(e),h=(e,t)=>e?.get(t),v=(e,t,a)=>{return s(a)?(r=e,n=t,r?.delete(n),e):e?.set(t,a);var r,n},b=(e,t,a,s)=>{var r,n;return r=e,n=t,r?.has(n)||v(e,t,a()),h(e,t)},A=p(),S=p(),C=["t","v"],f={keyPath:"k"},D=async(e,t)=>{const a=((t,a)=>c(d(t),(([t,a])=>M(e,"put",{k:t,v:a}))))(t);c(await M(e,"getAllKeys"),(s=>((e,t)=>t in e)(t,s)?0:i(a,M(e,"delete",s)))),await o(a)},M=async(e,t,a)=>n(((s,r)=>{const n=e[t](a);n.onsuccess=()=>s(n.result),n.onerror=()=>r(`objectStore.${t} error`)}));exports.createIndexedDbPersister=(e,y,d=1,u)=>{const p=async(e,a=[],s=0)=>n(((r,n)=>{const i=(t?t.indexedDB:indexedDB).open(y,s?2:void 0);i.onupgradeneeded=()=>s&&c(C,(e=>{try{i.result.createObjectStore(e,f)}catch{}})),i.onsuccess=async()=>{try{const t=i.result.transaction(C,"readwrite"),s=await o(c(C,(async(s,r)=>await e(t.objectStore(s),a[r]))));i.result.close(),r(s)}catch(e){i.result.close(),n(e)}},i.onerror=()=>n("indexedDB.open error")}));return((e,t,a,n,o,c,l,y={},d=[])=>{let u,p,C,f=0,D=0,M=0;b(A,d,(()=>0)),b(S,d,(()=>[]));const[x,j,k,L,P]=((e=1,t)=>1!=e&&t.isMergeable()?[1,t.getMergeableContent,t.getTransactionMergeableChanges,([[e],[t]])=>!w(e)||!w(t),t.setDefaultContent]:2!=e?[0,t.getContent,t.getTransactionChanges,([e,t])=>!w(e)||!w(t),t.setContent]:(e=>{throw Error("Store type not supported by this Persister")})())(l,e),m=t=>{var a;(x&&(a=t?.[0],Array.isArray(a))?1===t?.[2]?e.applyMergeableChanges:e.setMergeableContent:1===t?.[2]?e.applyChanges:e.setContent)(t)},T=async e=>(2!=f&&(f=1,D++,await E((async()=>{try{m(await t())}catch(t){c?.(t),e&&P(e)}f=0}))),z),B=()=>(p&&(o(p),p=void 0),z),I=async e=>(1!=f&&(f=2,M++,await E((async()=>{try{await a(j,e)}catch(e){c?.(e)}f=0}))),z),O=()=>(r(C,e.delListener),C=void 0,z),E=async(...e)=>(i(h(S,d),...e),await(async()=>{if(!h(A,d)){for(v(A,d,1);!s((e=h(S,d),u=e.shift()));)try{await u()}catch(e){c?.(e)}v(A,d,0)}var e})(),z),z={load:T,startAutoLoad:async e=>(await B().load(e),p=n((async(e,t)=>{t||e?2!=f&&(f=1,D++,m(t??e),f=0):await T()})),z),stopAutoLoad:B,isAutoLoading:()=>!s(p),save:I,startAutoSave:async()=>(await O().save(),C=e.addDidFinishTransactionListener((()=>{const e=k();L(e)&&I(e)})),z),stopAutoSave:O,isAutoSaving:()=>!s(C),schedule:E,getStore:()=>e,destroy:()=>B().stopAutoSave(),getStats:()=>({loads:D,saves:M}),...y};return g(z)})(e,(async()=>await p((async e=>((e=[])=>l.fromEntries(e))(c(await M(e,"getAll"),(({k:e,v:t})=>[e,t])))))),(async e=>await p((async(e,t)=>await D(e,t)),e(),1)),(e=>setInterval(e,1e3*d)),(e=>a(e)),u,1,{getDbName:()=>y})},exports.objectStoreMatch=D;
1
+ "use strict";const e=Promise,t=globalThis.window,a=clearInterval,s=e=>null==e,r=(e,t,a)=>s(e)?a?.():t(e),n=t=>new e(t),o=async t=>e.all(t),c=(e,t)=>e.map(t),i=(e,...t)=>e.push(...t),l=Object,y=e=>l.getPrototypeOf(e),d=l.entries,u=l.keys,g=l.freeze,p=e=>(e=>!s(e)&&r(y(e),(e=>e==l.prototype||s(y(e))),(()=>!0)))(e)&&0==(e=>u(e).length)(e),w=e=>new Map(e),h=(e,t)=>e?.get(t),v=(e,t,a)=>{return s(a)?(r=e,n=t,r?.delete(n),e):e?.set(t,a);var r,n},b=(e,t,a,s)=>{var r,n;return r=e,n=t,r?.has(n)||v(e,t,a()),h(e,t)},A=w(),S=w(),C=["t","v"],f={keyPath:"k"},D=async(e,t)=>{const a=((t,a)=>c(d(t),(([t,a])=>M(e,"put",{k:t,v:a}))))(t);c(await M(e,"getAllKeys"),(s=>((e,t)=>t in e)(t,s)?0:i(a,M(e,"delete",s)))),await o(a)},M=async(e,t,a)=>n(((s,r)=>{const n=e[t](a);n.onsuccess=()=>s(n.result),n.onerror=()=>r(`objectStore.${t} error`)}));exports.createIndexedDbPersister=(e,y,d=1,u)=>{const w=async(e,a=[],s=0)=>n(((r,n)=>{const i=(t?t.indexedDB:indexedDB).open(y,s?2:void 0);i.onupgradeneeded=()=>s&&c(C,(e=>{try{i.result.createObjectStore(e,f)}catch{}})),i.onsuccess=async()=>{try{const t=i.result.transaction(C,"readwrite"),s=await o(c(C,(async(s,r)=>await e(t.objectStore(s),a[r]))));i.result.close(),r(s)}catch(e){i.result.close(),n(e)}},i.onerror=()=>n("indexedDB.open error")}));return((e,t,a,n,o,c,l,y={},d=[])=>{let u,w,C,f=0,D=0,M=0;b(A,d,(()=>0)),b(S,d,(()=>[]));const[x,j,k,L,P]=((e=1,t)=>1!=e&&t.isMergeable()?[1,t.getMergeableContent,t.getTransactionMergeableChanges,([[e],[t]])=>!p(e)||!p(t),t.setDefaultContent]:2!=e?[0,t.getContent,t.getTransactionChanges,([e,t])=>!p(e)||!p(t),t.setContent]:(e=>{throw Error("Store type not supported by this Persister")})())(l,e),m=t=>{var a;(x&&(a=t?.[0],Array.isArray(a))?1===t?.[2]?e.applyMergeableChanges:e.setMergeableContent:1===t?.[2]?e.applyChanges:e.setContent)(t)},T=async e=>(2!=f&&(f=1,D++,await E((async()=>{try{m(await t())}catch(t){c?.(t),e&&P(e)}f=0}))),z),B=()=>(w&&(o(w),w=void 0),z),I=async e=>(1!=f&&(f=2,M++,await E((async()=>{try{await a(j,e)}catch(e){c?.(e)}f=0}))),z),O=()=>(r(C,e.delListener),C=void 0,z),E=async(...e)=>(i(h(S,d),...e),await(async()=>{if(!h(A,d)){for(v(A,d,1);!s((e=h(S,d),u=e.shift()));)try{await u()}catch(e){c?.(e)}v(A,d,0)}var e})(),z),z={load:T,startAutoLoad:async e=>{await B().load(e);try{w=n((async(e,t)=>{t||e?2!=f&&(f=1,D++,m(t??e),f=0):await T()}))}catch(e){c?.(e)}return z},stopAutoLoad:B,isAutoLoading:()=>!s(w),save:I,startAutoSave:async()=>(await O().save(),C=e.addDidFinishTransactionListener((()=>{const e=k();L(e)&&I(e)})),z),stopAutoSave:O,isAutoSaving:()=>!s(C),schedule:E,getStore:()=>e,destroy:()=>(h(S,d).splice(0,void 0),B().stopAutoSave()),getStats:()=>({loads:D,saves:M}),...y};return g(z)})(e,(async()=>await w((async e=>((e=[])=>l.fromEntries(e))(c(await M(e,"getAll"),(({k:e,v:t})=>[e,t])))))),(async e=>await w((async(e,t)=>await D(e,t)),e(),1)),(e=>setInterval(e,1e3*d)),(e=>a(e)),u,1,{getDbName:()=>y})},exports.objectStoreMatch=D;
@@ -1 +1 @@
1
- "use strict";const a=a=>typeof a,t="tinybase",e="",s=",",n=a(e),i=(a,t)=>a.repeat(t),r=Promise,o=clearInterval,c=a=>null==a,l=(a,t,e)=>c(a)?e?.():t(a),y=t=>a(t)==n,w=a=>Array.isArray(a),u=(a,t,e)=>a.slice(t,e),d=a=>a.length,E=async a=>r.all(a),v=(a,t="")=>a.join(t),p=(a,t)=>a.map(t),g=a=>0==d(a),C=(a,t)=>a.filter(t),m=(a,...t)=>a.push(...t),A=Object,O=a=>A.getPrototypeOf(a),h=A.entries,T=A.keys,N=A.freeze,L=(a=[])=>A.fromEntries(a),R=(...a)=>A.assign({},...a),S=(a,t)=>t in a,f=(a,t)=>p(h(a),(([a,e])=>t(e,a))),b=a=>A.values(a),I=a=>d(T(a)),D=a=>(a=>!c(a)&&l(O(a),(a=>a==A.prototype||c(O(a))),(()=>!0)))(a)&&0==I(a),M=(a,t)=>a?.has(t)??!1,P=a=>[...a?.values()??[]],$=(a,t)=>a?.delete(t),_=a=>new Map(a),F=a=>[...a?.keys()??[]],j=(a,t)=>a?.get(t),x=(a,t)=>p([...a?.entries()??[]],(([a,e])=>t(e,a))),B=(a,t,e)=>c(e)?($(a,t),a):a?.set(t,e),H=(a,t,e,s)=>(M(a,t)||B(a,t,e()),j(a,t)),J=(a,t,e,s=B)=>(f(t,((t,s)=>e(a,s,t))),((a,t)=>{((a,t)=>{a?.forEach(t)})(a,((a,e)=>t(e)))})(a,(e=>S(t,e)?0:s(a,e))),a),Y=_(),k=_(),q=(a,t,e,s,n,i,r,o={},y=[])=>{let u,d,E,v=0,p=0,g=0;H(Y,y,(()=>0)),H(k,y,(()=>[]));const[C,A,O,h,T]=((a=1,t)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,t.getTransactionMergeableChanges,([[a],[t]])=>!D(a)||!D(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!D(a)||!D(t),t.setContent]:(a=>{throw Error("Store type not supported by this Persister")})())(r,a),L=t=>{(C&&w(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},R=async a=>(2!=v&&(v=1,p++,await I((async()=>{try{L(await t())}catch(t){i?.(t),a&&T(a)}v=0}))),M),S=()=>(d&&(n(d),d=void 0),M),f=async a=>(1!=v&&(v=2,g++,await I((async()=>{try{await e(A,a)}catch(a){i?.(a)}v=0}))),M),b=()=>(l(E,a.delListener),E=void 0,M),I=async(...a)=>(m(j(k,y),...a),await(async()=>{if(!j(Y,y)){for(B(Y,y,1);!c((a=j(k,y),u=a.shift()));)try{await u()}catch(a){i?.(a)}B(Y,y,0)}var a})(),M),M={load:R,startAutoLoad:async a=>(await S().load(a),d=s((async(a,t)=>{t||a?2!=v&&(v=1,p++,L(t??a),v=0):await R()})),M),stopAutoLoad:S,isAutoLoading:()=>!c(d),save:f,startAutoSave:async()=>(await b().save(),E=a.addDidFinishTransactionListener((()=>{const a=O();h(a)&&f(a)})),M),stopAutoSave:b,isAutoSaving:()=>!c(E),schedule:I,getStore:()=>a,destroy:()=>S().stopAutoSave(),getStats:()=>({loads:p,saves:g}),...o};return N(M)},G="_",U="_id",W=a=>`"${a.replace(/"/g,'""')}"`,z="SELECT",K=a=>new Set(w(a)||c(a)?a:[a]),V=(a,t)=>a?.add(t),Q="TABLE",X="ALTER "+Q,Z="DELETE FROM",aa=z+"*FROM",ta="FROM pragma_table_",ea="WHERE",sa=(a,t,n,i)=>{const r=_();return[async()=>J(r,L(await E(p(await a("SELECT name "+ta+"list WHERE schema='main'AND(type='table'OR type='view')AND name IN("+ia(t)+")ORDER BY name",t),(async({name:t})=>[t,L(p(await a(z+" name,type "+ta+"info(?)",[t]),(({name:a,type:t})=>[a,t])))])))),((a,t,e)=>B(r,t,J(H(r,t,_),e,((a,t,e)=>{e!=j(a,t)&&B(a,t,e)}),((a,t)=>B(a,t))))),((a,t)=>B(r,t))),async(t,e)=>((a,t)=>!c(j(j(r,a),t)))(t,e)?L(C(p(await a(aa+W(t)),(a=>{return[a[e],(t={...a},s=e,delete t[s],t)];var t,s})),(([a,t])=>!c(a)&&!D(t)))):{},async(t,n,o,l,y,w=!1)=>{const u=K();f(o??{},(a=>p(T(a??{}),(a=>V(u,a)))));const d=P(u);if(!w&&y&&g(d)&&M(r,t))return await a("DROP "+Q+W(t)),void B(r,t);if(g(d)||M(r,t)){const s=j(r,t),i=K(F(s));await E([...p(d,(async n=>{$(i,n)||(await a(X+W(t)+"ADD"+W(n)),B(s,n,e))})),...!w&&l?p(P(i),(async e=>{e!=n&&(await a(X+W(t)+"DROP"+W(e)),B(s,e))})):[]])}else await a("CREATE "+Q+W(t)+"("+W(n)+` PRIMARY KEY ON CONFLICT REPLACE${v(p(d,(a=>s+W(a))))});`),B(r,t,_([[n,e],...p(d,(a=>[a,e]))]));if(w)c(o)?await a(Z+W(t)+ea+" 1"):await E(f(o,(async(e,s)=>{c(e)?await a(Z+W(t)+ea+W(n)+"=?",[s]):g(d)||await na(a,t,n,T(e),[s,...b(e)],i)})));else if(g(d))M(r,t)&&await a(Z+W(t)+ea+" 1");else{const e=C(F(j(r,t)),(a=>a!=n)),s=[],c=[];f(o??{},((a,t)=>{m(s,t,...p(e,(t=>a?.[t]))),m(c,t)})),await na(a,t,n,e,s,i),await a(Z+W(t)+ea+W(n)+"NOT IN("+ia(c)+")",c)}},async t=>{let e;await a("BEGIN");try{e=await t()}catch(a){n?.(a)}return await a("END"),e}]},na=async(a,t,n,r,o,c=!0)=>await a("INSERT "+(c?e:"OR REPLACE ")+"INTO"+W(t)+"("+W(n)+v(p(r,(a=>s+W(a))))+")VALUES"+u(i(`,(?${i(",?",d(r))})`,d(o)/(d(r)+1)),1)+(c?"ON CONFLICT("+W(n)+")DO UPDATE SET"+v(p(r,(a=>W(a)+"=excluded."+W(a))),s):e),p(o,(a=>a??null))),ia=a=>v(p(a,(()=>"?")),s),ra=(a,t,e,s,n,i,[r,o,c],l,y,w,u)=>{const[d,E,v,p]=sa(t,l,n,u);return q(a,(async()=>await p((async()=>{return await d(),a=(await E(r,o))[G]?.[c]??"null",JSON.parse(a,((a,t)=>""===t?void 0:t));var a}))),(async a=>await p((async()=>{var t;await d(),await v(r,o,{[G]:{[c]:(t=a()??null,JSON.stringify(t,((a,t)=>void 0===t?"":t)))}},!0,!0)}))),e,s,n,i,{[w]:()=>y},y)},oa=(a,t,e,s,n,i,[r,o,[l,y,w]],u,d,v,p)=>{const[g,m,A,O]=sa(t,u,n,p),h=async(a,t)=>await E(x(o,(async([e,s,n,i],r)=>{t&&!S(a,r)||await A(e,s,a[r],n,i,t)}))),T=async(a,t)=>y?await A(w,U,{[G]:a},!0,!0,t):null;return q(a,(async()=>await O((async()=>{await g();const a=await(async()=>L(C(await E(x(r,(async([a,t],e)=>[a,await m(e,t)]))),(a=>!D(a[1])))))(),t=await(async()=>l?(await m(w,U))[G]:{})();return D(a)&&c(t)?void 0:[a,t]}))),(async(a,t)=>await O((async()=>{if(await g(),c(t)){const[t,e]=a();await h(t),await T(e)}else await h(t[0],!0),await T(t[1],!0)}))),e,s,n,i,{[v]:()=>d},d)},ca="ColumnName",la="store",ya="json",wa=la+"TableName",ua=la+"Id"+ca,da=la+ca,Ea="autoLoadIntervalSeconds",va="rowId"+ca,pa="tableId",ga="tableName",Ca="deleteEmptyColumns",ma="deleteEmptyTable",Aa={mode:ya,[Ea]:1},Oa={load:0,save:0,[ga]:t+"_values"},ha=(a,t,e,s,n)=>{const i=_();return f(a,((a,r)=>{const o=u(b(R(t,y(a)?{[e]:a}:a)),0,I(t));c(o[0])||s(r,o[0])||(n(r,o[0]),B(i,r,o))})),i},Ta="pragma_",Na="data_version",La="schema_version";exports.createLibSqlPersister=(a,e,s,n,i)=>((a,e,s,n,i,r,c,l,w,d="getDb",E)=>{let v,p,g;const[C,m,A,O]=(a=>{const e=(a=>R(Aa,y(a)?{[wa]:a}:a??{}))(a),s=e[Ea];if(e.mode==ya){const a=e[wa]??t;return[1,s,[a,e[ua]??U,e[da]??la],K(a)]}const{tables:{load:n={},save:i={}}={},values:r={}}=e,o=u(b(R(Oa,r)),0,I(Oa)),c=o[2],l=K(c),w=K(c);return[0,s,[ha(n,{[pa]:null,[va]:U},pa,(a=>M(w,a)),(a=>V(l,a))),ha(i,{[ga]:null,[va]:U,[Ca]:0,[ma]:0},ga,((a,t)=>M(w,t)),((a,t)=>V(l,t))),o],l]})(e);return(C?ra:oa)(a,r?async(a,t)=>(r(a,t),await s(a,t)):s,(a=>{return[(t=async()=>{try{const[{d:t,s:e,c:n}]=await s(`SELECT ${Na} d,${La} s,TOTAL_CHANGES() c FROM ${Ta}${Na} JOIN ${Ta}${La}`);t==(v??=t)&&e==(p??=e)&&n==(g??=n)||(a(),v=t,p=e)}catch{}},e=m,t(),setInterval(t,1e3*e)),n((t=>O.has(t)?a():0))];var t,e}),(([a,t])=>{o(a),v=p=g=null,i(t)}),c,l,A,P(O),w,d,E)})(a,s,(async(a,t=[])=>(await e.execute({sql:a,args:t})).rows),(()=>()=>0),(a=>a()),n,i,1,e,"getClient");
1
+ "use strict";const a=a=>typeof a,t="tinybase",e="",s=",",n=a(e),i=(a,t)=>a.repeat(t),r=Promise,c=clearInterval,o=a=>null==a,l=(a,t,e)=>o(a)?e?.():t(a),y=t=>a(t)==n,w=a=>Array.isArray(a),u=(a,t,e)=>a.slice(t,e),d=a=>a.length,E=async a=>r.all(a),v=(a,t="")=>a.join(t),p=(a,t)=>a.map(t),g=a=>0==d(a),C=(a,t)=>a.filter(t),m=(a,...t)=>a.push(...t),h=(a,t)=>a?.has(t)??!1,A=a=>[...a?.values()??[]],O=(a,t)=>a?.delete(t),T=Object,N=a=>T.getPrototypeOf(a),L=T.entries,R=T.keys,S=T.freeze,f=(a=[])=>T.fromEntries(a),b=(...a)=>T.assign({},...a),I=(a,t)=>t in a,D=(a,t)=>p(L(a),(([a,e])=>t(e,a))),M=a=>T.values(a),P=a=>d(R(a)),$=a=>(a=>!o(a)&&l(N(a),(a=>a==T.prototype||o(N(a))),(()=>!0)))(a)&&0==P(a),_=a=>new Map(a),F=a=>[...a?.keys()??[]],j=(a,t)=>a?.get(t),x=(a,t)=>p([...a?.entries()??[]],(([a,e])=>t(e,a))),B=(a,t,e)=>o(e)?(O(a,t),a):a?.set(t,e),H=(a,t,e,s)=>(h(a,t)||B(a,t,e()),j(a,t)),J=(a,t,e,s=B)=>(D(t,((t,s)=>e(a,s,t))),((a,t)=>{((a,t)=>{a?.forEach(t)})(a,((a,e)=>t(e)))})(a,(e=>I(t,e)?0:s(a,e))),a),Y="_",k="_id",q=a=>`"${a.replace(/"/g,'""')}"`,G="SELECT",U=a=>new Set(w(a)||o(a)?a:[a]),W=(a,t)=>a?.add(t),z="TABLE",K="ALTER "+z,V="DELETE FROM",Q=G+"*FROM",X="FROM pragma_table_",Z="WHERE",aa=(a,t,n,i)=>{const r=_();return[async()=>J(r,f(await E(p(await a("SELECT name "+X+"list WHERE schema='main'AND(type='table'OR type='view')AND name IN("+ea(t)+")ORDER BY name",t),(async({name:t})=>[t,f(p(await a(G+" name,type "+X+"info(?)",[t]),(({name:a,type:t})=>[a,t])))])))),((a,t,e)=>B(r,t,J(H(r,t,_),e,((a,t,e)=>{e!=j(a,t)&&B(a,t,e)}),((a,t)=>B(a,t))))),((a,t)=>B(r,t))),async(t,e)=>((a,t)=>!o(j(j(r,a),t)))(t,e)?f(C(p(await a(Q+q(t)),(a=>{return[a[e],(t={...a},s=e,delete t[s],t)];var t,s})),(([a,t])=>!o(a)&&!$(t)))):{},async(t,n,c,l,y,w=!1)=>{const u=U();D(c??{},(a=>p(R(a??{}),(a=>W(u,a)))));const d=A(u);if(!w&&y&&g(d)&&h(r,t))return await a("DROP "+z+q(t)),void B(r,t);if(g(d)||h(r,t)){const s=j(r,t),i=U(F(s));await E([...p(d,(async n=>{O(i,n)||(await a(K+q(t)+"ADD"+q(n)),B(s,n,e))})),...!w&&l?p(A(i),(async e=>{e!=n&&(await a(K+q(t)+"DROP"+q(e)),B(s,e))})):[]])}else await a("CREATE "+z+q(t)+"("+q(n)+` PRIMARY KEY ON CONFLICT REPLACE${v(p(d,(a=>s+q(a))))});`),B(r,t,_([[n,e],...p(d,(a=>[a,e]))]));if(w)o(c)?await a(V+q(t)+Z+" 1"):await E(D(c,(async(e,s)=>{o(e)?await a(V+q(t)+Z+q(n)+"=?",[s]):g(d)||await ta(a,t,n,R(e),[s,...M(e)],i)})));else if(g(d))h(r,t)&&await a(V+q(t)+Z+" 1");else{const e=C(F(j(r,t)),(a=>a!=n)),s=[],o=[];D(c??{},((a,t)=>{m(s,t,...p(e,(t=>a?.[t]))),m(o,t)})),await ta(a,t,n,e,s,i),await a(V+q(t)+Z+q(n)+"NOT IN("+ea(o)+")",o)}},async t=>{let e;await a("BEGIN");try{e=await t()}catch(a){n?.(a)}return await a("END"),e}]},ta=async(a,t,n,r,c,o=!0)=>await a("INSERT "+(o?e:"OR REPLACE ")+"INTO"+q(t)+"("+q(n)+v(p(r,(a=>s+q(a))))+")VALUES"+u(i(`,(?${i(",?",d(r))})`,d(c)/(d(r)+1)),1)+(o?"ON CONFLICT("+q(n)+")DO UPDATE SET"+v(p(r,(a=>q(a)+"=excluded."+q(a))),s):e),p(c,(a=>a??null))),ea=a=>v(p(a,(()=>"?")),s),sa=_(),na=_(),ia=(a,t,e,s,n,i,r,c={},y=[])=>{let u,d,E,v=0,p=0,g=0;H(sa,y,(()=>0)),H(na,y,(()=>[]));const[C,h,A,O,T]=((a=1,t)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,t.getTransactionMergeableChanges,([[a],[t]])=>!$(a)||!$(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!$(a)||!$(t),t.setContent]:(a=>{throw Error("Store type not supported by this Persister")})())(r,a),N=t=>{(C&&w(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},L=async a=>(2!=v&&(v=1,p++,await I((async()=>{try{N(await t())}catch(t){i?.(t),a&&T(a)}v=0}))),D),R=()=>(d&&(n(d),d=void 0),D),f=async a=>(1!=v&&(v=2,g++,await I((async()=>{try{await e(h,a)}catch(a){i?.(a)}v=0}))),D),b=()=>(l(E,a.delListener),E=void 0,D),I=async(...a)=>(m(j(na,y),...a),await(async()=>{if(!j(sa,y)){for(B(sa,y,1);!o((a=j(na,y),u=a.shift()));)try{await u()}catch(a){i?.(a)}B(sa,y,0)}var a})(),D),D={load:L,startAutoLoad:async a=>{await R().load(a);try{d=s((async(a,t)=>{t||a?2!=v&&(v=1,p++,N(t??a),v=0):await L()}))}catch(a){i?.(a)}return D},stopAutoLoad:R,isAutoLoading:()=>!o(d),save:f,startAutoSave:async()=>(await b().save(),E=a.addDidFinishTransactionListener((()=>{const a=A();O(a)&&f(a)})),D),stopAutoSave:b,isAutoSaving:()=>!o(E),schedule:I,getStore:()=>a,destroy:()=>(j(na,y).splice(0,void 0),R().stopAutoSave()),getStats:()=>({loads:p,saves:g}),...c};return S(D)},ra=(a,t,e,s,n,i,[r,c,o],l,y,w,u)=>{const[d,E,v,p]=aa(t,l,n,u);return ia(a,(async()=>await p((async()=>{return await d(),a=(await E(r,c))[Y]?.[o]??"null",JSON.parse(a,((a,t)=>""===t?void 0:t));var a}))),(async a=>await p((async()=>{var t;await d(),await v(r,c,{[Y]:{[o]:(t=a()??null,JSON.stringify(t,((a,t)=>void 0===t?"":t)))}},!0,!0)}))),e,s,n,i,{[w]:()=>y},y)},ca=(a,t,e,s,n,i,[r,c,[l,y,w]],u,d,v,p)=>{const[g,m,h,A]=aa(t,u,n,p),O=async(a,t)=>await E(x(c,(async([e,s,n,i],r)=>{t&&!I(a,r)||await h(e,s,a[r],n,i,t)}))),T=async(a,t)=>y?await h(w,k,{[Y]:a},!0,!0,t):null;return ia(a,(async()=>await A((async()=>{await g();const a=await(async()=>f(C(await E(x(r,(async([a,t],e)=>[a,await m(e,t)]))),(a=>!$(a[1])))))(),t=await(async()=>l?(await m(w,k))[Y]:{})();return $(a)&&o(t)?void 0:[a,t]}))),(async(a,t)=>await A((async()=>{if(await g(),o(t)){const[t,e]=a();await O(t),await T(e)}else await O(t[0],!0),await T(t[1],!0)}))),e,s,n,i,{[v]:()=>d},d)},oa="ColumnName",la="store",ya="json",wa=la+"TableName",ua=la+"Id"+oa,da=la+oa,Ea="autoLoadIntervalSeconds",va="rowId"+oa,pa="tableId",ga="tableName",Ca="deleteEmptyColumns",ma="deleteEmptyTable",ha={mode:ya,[Ea]:1},Aa={load:0,save:0,[ga]:t+"_values"},Oa=(a,t,e,s,n)=>{const i=_();return D(a,((a,r)=>{const c=u(M(b(t,y(a)?{[e]:a}:a)),0,P(t));o(c[0])||s(r,c[0])||(n(r,c[0]),B(i,r,c))})),i},Ta="pragma_",Na="data_version",La="schema_version";exports.createLibSqlPersister=(a,e,s,n,i)=>((a,e,s,n,i,r,o,l,w,d="getDb",E)=>{let v,p,g;const[C,m,O,T]=(a=>{const e=(a=>b(ha,y(a)?{[wa]:a}:a??{}))(a),s=e[Ea];if(e.mode==ya){const a=e[wa]??t;return[1,s,[a,e[ua]??k,e[da]??la],U(a)]}const{tables:{load:n={},save:i={}}={},values:r={}}=e,c=u(M(b(Aa,r)),0,P(Aa)),o=c[2],l=U(o),w=U(o);return[0,s,[Oa(n,{[pa]:null,[va]:k},pa,(a=>h(w,a)),(a=>W(l,a))),Oa(i,{[ga]:null,[va]:k,[Ca]:0,[ma]:0},ga,((a,t)=>h(w,t)),((a,t)=>W(l,t))),c],l]})(e);return(C?ra:ca)(a,r?async(a,t)=>(r(a,t),await s(a,t)):s,(a=>{return[(t=async()=>{try{const[{d:t,s:e,c:n}]=await s(`SELECT ${Na} d,${La} s,TOTAL_CHANGES() c FROM ${Ta}${Na} JOIN ${Ta}${La}`);t==(v??=t)&&e==(p??=e)&&n==(g??=n)||(a(),v=t,p=e)}catch{}},e=m,t(),setInterval(t,1e3*e)),n((t=>T.has(t)?a():0))];var t,e}),(([a,t])=>{c(a),v=p=g=null,i(t)}),o,l,O,A(T),w,d,E)})(a,s,(async(a,t=[])=>(await e.execute({sql:a,args:t})).rows),(()=>()=>0),(a=>a()),n,i,1,e,"getClient");
@@ -1 +1 @@
1
- "use strict";const a=a=>typeof a,t="tinybase",e="",s=",",n=a(e),i=(a,t)=>a.repeat(t),r=Promise,o=clearInterval,c=a=>null==a,l=(a,t,e)=>c(a)?e?.():t(a),y=t=>a(t)==n,w=a=>Array.isArray(a),u=(a,t,e)=>a.slice(t,e),d=a=>a.length,E=async a=>r.all(a),v=(a,t="")=>a.join(t),p=(a,t)=>a.map(t),g=a=>0==d(a),C=(a,t)=>a.filter(t),m=(a,...t)=>a.push(...t),A=Object,O=a=>A.getPrototypeOf(a),h=A.entries,T=A.keys,N=A.freeze,L=(a=[])=>A.fromEntries(a),R=(...a)=>A.assign({},...a),S=(a,t)=>t in a,f=(a,t)=>p(h(a),(([a,e])=>t(e,a))),b=a=>A.values(a),I=a=>d(T(a)),D=a=>(a=>!c(a)&&l(O(a),(a=>a==A.prototype||c(O(a))),(()=>!0)))(a)&&0==I(a),M=(a,t)=>a?.has(t)??!1,P=a=>[...a?.values()??[]],$=(a,t)=>a?.delete(t),_=a=>new Map(a),F=a=>[...a?.keys()??[]],j=(a,t)=>a?.get(t),x=(a,t)=>p([...a?.entries()??[]],(([a,e])=>t(e,a))),B=(a,t,e)=>c(e)?($(a,t),a):a?.set(t,e),H=(a,t,e,s)=>(M(a,t)||B(a,t,e()),j(a,t)),J=(a,t,e,s=B)=>(f(t,((t,s)=>e(a,s,t))),((a,t)=>{((a,t)=>{a?.forEach(t)})(a,((a,e)=>t(e)))})(a,(e=>S(t,e)?0:s(a,e))),a),Y=_(),k=_(),q=(a,t,e,s,n,i,r,o={},y=[])=>{let u,d,E,v=0,p=0,g=0;H(Y,y,(()=>0)),H(k,y,(()=>[]));const[C,A,O,h,T]=((a=1,t)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,t.getTransactionMergeableChanges,([[a],[t]])=>!D(a)||!D(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!D(a)||!D(t),t.setContent]:(a=>{throw Error("Store type not supported by this Persister")})())(r,a),L=t=>{(C&&w(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},R=async a=>(2!=v&&(v=1,p++,await I((async()=>{try{L(await t())}catch(t){i?.(t),a&&T(a)}v=0}))),M),S=()=>(d&&(n(d),d=void 0),M),f=async a=>(1!=v&&(v=2,g++,await I((async()=>{try{await e(A,a)}catch(a){i?.(a)}v=0}))),M),b=()=>(l(E,a.delListener),E=void 0,M),I=async(...a)=>(m(j(k,y),...a),await(async()=>{if(!j(Y,y)){for(B(Y,y,1);!c((a=j(k,y),u=a.shift()));)try{await u()}catch(a){i?.(a)}B(Y,y,0)}var a})(),M),M={load:R,startAutoLoad:async a=>(await S().load(a),d=s((async(a,t)=>{t||a?2!=v&&(v=1,p++,L(t??a),v=0):await R()})),M),stopAutoLoad:S,isAutoLoading:()=>!c(d),save:f,startAutoSave:async()=>(await b().save(),E=a.addDidFinishTransactionListener((()=>{const a=O();h(a)&&f(a)})),M),stopAutoSave:b,isAutoSaving:()=>!c(E),schedule:I,getStore:()=>a,destroy:()=>S().stopAutoSave(),getStats:()=>({loads:p,saves:g}),...o};return N(M)},G="_",U="_id",W=a=>`"${a.replace(/"/g,'""')}"`,z="SELECT",K=a=>new Set(w(a)||c(a)?a:[a]),V=(a,t)=>a?.add(t),Q="TABLE",X="ALTER "+Q,Z="DELETE FROM",aa=z+"*FROM",ta="FROM pragma_table_",ea="WHERE",sa=(a,t,n,i)=>{const r=_();return[async()=>J(r,L(await E(p(await a("SELECT name "+ta+"list WHERE schema='main'AND(type='table'OR type='view')AND name IN("+ia(t)+")ORDER BY name",t),(async({name:t})=>[t,L(p(await a(z+" name,type "+ta+"info(?)",[t]),(({name:a,type:t})=>[a,t])))])))),((a,t,e)=>B(r,t,J(H(r,t,_),e,((a,t,e)=>{e!=j(a,t)&&B(a,t,e)}),((a,t)=>B(a,t))))),((a,t)=>B(r,t))),async(t,e)=>((a,t)=>!c(j(j(r,a),t)))(t,e)?L(C(p(await a(aa+W(t)),(a=>{return[a[e],(t={...a},s=e,delete t[s],t)];var t,s})),(([a,t])=>!c(a)&&!D(t)))):{},async(t,n,o,l,y,w=!1)=>{const u=K();f(o??{},(a=>p(T(a??{}),(a=>V(u,a)))));const d=P(u);if(!w&&y&&g(d)&&M(r,t))return await a("DROP "+Q+W(t)),void B(r,t);if(g(d)||M(r,t)){const s=j(r,t),i=K(F(s));await E([...p(d,(async n=>{$(i,n)||(await a(X+W(t)+"ADD"+W(n)),B(s,n,e))})),...!w&&l?p(P(i),(async e=>{e!=n&&(await a(X+W(t)+"DROP"+W(e)),B(s,e))})):[]])}else await a("CREATE "+Q+W(t)+"("+W(n)+` PRIMARY KEY ON CONFLICT REPLACE${v(p(d,(a=>s+W(a))))});`),B(r,t,_([[n,e],...p(d,(a=>[a,e]))]));if(w)c(o)?await a(Z+W(t)+ea+" 1"):await E(f(o,(async(e,s)=>{c(e)?await a(Z+W(t)+ea+W(n)+"=?",[s]):g(d)||await na(a,t,n,T(e),[s,...b(e)],i)})));else if(g(d))M(r,t)&&await a(Z+W(t)+ea+" 1");else{const e=C(F(j(r,t)),(a=>a!=n)),s=[],c=[];f(o??{},((a,t)=>{m(s,t,...p(e,(t=>a?.[t]))),m(c,t)})),await na(a,t,n,e,s,i),await a(Z+W(t)+ea+W(n)+"NOT IN("+ia(c)+")",c)}},async t=>{let e;await a("BEGIN");try{e=await t()}catch(a){n?.(a)}return await a("END"),e}]},na=async(a,t,n,r,o,c=!0)=>await a("INSERT "+(c?e:"OR REPLACE ")+"INTO"+W(t)+"("+W(n)+v(p(r,(a=>s+W(a))))+")VALUES"+u(i(`,(?${i(",?",d(r))})`,d(o)/(d(r)+1)),1)+(c?"ON CONFLICT("+W(n)+")DO UPDATE SET"+v(p(r,(a=>W(a)+"=excluded."+W(a))),s):e),p(o,(a=>a??null))),ia=a=>v(p(a,(()=>"?")),s),ra=(a,t,e,s,n,i,[r,o,c],l,y,w,u)=>{const[d,E,v,p]=sa(t,l,n,u);return q(a,(async()=>await p((async()=>{return await d(),a=(await E(r,o))[G]?.[c]??"null",JSON.parse(a,((a,t)=>""===t?void 0:t));var a}))),(async a=>await p((async()=>{var t;await d(),await v(r,o,{[G]:{[c]:(t=a()??null,JSON.stringify(t,((a,t)=>void 0===t?"":t)))}},!0,!0)}))),e,s,n,i,{[w]:()=>y},y)},oa=(a,t,e,s,n,i,[r,o,[l,y,w]],u,d,v,p)=>{const[g,m,A,O]=sa(t,u,n,p),h=async(a,t)=>await E(x(o,(async([e,s,n,i],r)=>{t&&!S(a,r)||await A(e,s,a[r],n,i,t)}))),T=async(a,t)=>y?await A(w,U,{[G]:a},!0,!0,t):null;return q(a,(async()=>await O((async()=>{await g();const a=await(async()=>L(C(await E(x(r,(async([a,t],e)=>[a,await m(e,t)]))),(a=>!D(a[1])))))(),t=await(async()=>l?(await m(w,U))[G]:{})();return D(a)&&c(t)?void 0:[a,t]}))),(async(a,t)=>await O((async()=>{if(await g(),c(t)){const[t,e]=a();await h(t),await T(e)}else await h(t[0],!0),await T(t[1],!0)}))),e,s,n,i,{[v]:()=>d},d)},ca="ColumnName",la="store",ya="json",wa=la+"TableName",ua=la+"Id"+ca,da=la+ca,Ea="autoLoadIntervalSeconds",va="rowId"+ca,pa="tableId",ga="tableName",Ca="deleteEmptyColumns",ma="deleteEmptyTable",Aa={mode:ya,[Ea]:1},Oa={load:0,save:0,[ga]:t+"_values"},ha=(a,t,e,s,n)=>{const i=_();return f(a,((a,r)=>{const o=u(b(R(t,y(a)?{[e]:a}:a)),0,I(t));c(o[0])||s(r,o[0])||(n(r,o[0]),B(i,r,o))})),i},Ta="pragma_",Na="data_version",La="schema_version";exports.createLibSqlPersister=(a,e,s,n,i)=>((a,e,s,n,i,r,c,l,w,d="getDb",E)=>{let v,p,g;const[C,m,A,O]=(a=>{const e=(a=>R(Aa,y(a)?{[wa]:a}:a??{}))(a),s=e[Ea];if(e.mode==ya){const a=e[wa]??t;return[1,s,[a,e[ua]??U,e[da]??la],K(a)]}const{tables:{load:n={},save:i={}}={},values:r={}}=e,o=u(b(R(Oa,r)),0,I(Oa)),c=o[2],l=K(c),w=K(c);return[0,s,[ha(n,{[pa]:null,[va]:U},pa,(a=>M(w,a)),(a=>V(l,a))),ha(i,{[ga]:null,[va]:U,[Ca]:0,[ma]:0},ga,((a,t)=>M(w,t)),((a,t)=>V(l,t))),o],l]})(e);return(C?ra:oa)(a,r?async(a,t)=>(r(a,t),await s(a,t)):s,(a=>{return[(t=async()=>{try{const[{d:t,s:e,c:n}]=await s(`SELECT ${Na} d,${La} s,TOTAL_CHANGES() c FROM ${Ta}${Na} JOIN ${Ta}${La}`);t==(v??=t)&&e==(p??=e)&&n==(g??=n)||(a(),v=t,p=e)}catch{}},e=m,t(),setInterval(t,1e3*e)),n((t=>O.has(t)?a():0))];var t,e}),(([a,t])=>{o(a),v=p=g=null,i(t)}),c,l,A,P(O),w,d,E)})(a,s,(async(a,t=[])=>(await e.execute({sql:a,args:t})).rows),(()=>()=>0),(a=>a()),n,i,1,e,"getClient");
1
+ "use strict";const a=a=>typeof a,t="tinybase",e="",s=",",n=a(e),i=(a,t)=>a.repeat(t),r=Promise,c=clearInterval,o=a=>null==a,l=(a,t,e)=>o(a)?e?.():t(a),y=t=>a(t)==n,w=a=>Array.isArray(a),u=(a,t,e)=>a.slice(t,e),d=a=>a.length,E=async a=>r.all(a),v=(a,t="")=>a.join(t),p=(a,t)=>a.map(t),g=a=>0==d(a),C=(a,t)=>a.filter(t),m=(a,...t)=>a.push(...t),h=(a,t)=>a?.has(t)??!1,A=a=>[...a?.values()??[]],O=(a,t)=>a?.delete(t),T=Object,N=a=>T.getPrototypeOf(a),L=T.entries,R=T.keys,S=T.freeze,f=(a=[])=>T.fromEntries(a),b=(...a)=>T.assign({},...a),I=(a,t)=>t in a,D=(a,t)=>p(L(a),(([a,e])=>t(e,a))),M=a=>T.values(a),P=a=>d(R(a)),$=a=>(a=>!o(a)&&l(N(a),(a=>a==T.prototype||o(N(a))),(()=>!0)))(a)&&0==P(a),_=a=>new Map(a),F=a=>[...a?.keys()??[]],j=(a,t)=>a?.get(t),x=(a,t)=>p([...a?.entries()??[]],(([a,e])=>t(e,a))),B=(a,t,e)=>o(e)?(O(a,t),a):a?.set(t,e),H=(a,t,e,s)=>(h(a,t)||B(a,t,e()),j(a,t)),J=(a,t,e,s=B)=>(D(t,((t,s)=>e(a,s,t))),((a,t)=>{((a,t)=>{a?.forEach(t)})(a,((a,e)=>t(e)))})(a,(e=>I(t,e)?0:s(a,e))),a),Y="_",k="_id",q=a=>`"${a.replace(/"/g,'""')}"`,G="SELECT",U=a=>new Set(w(a)||o(a)?a:[a]),W=(a,t)=>a?.add(t),z="TABLE",K="ALTER "+z,V="DELETE FROM",Q=G+"*FROM",X="FROM pragma_table_",Z="WHERE",aa=(a,t,n,i)=>{const r=_();return[async()=>J(r,f(await E(p(await a("SELECT name "+X+"list WHERE schema='main'AND(type='table'OR type='view')AND name IN("+ea(t)+")ORDER BY name",t),(async({name:t})=>[t,f(p(await a(G+" name,type "+X+"info(?)",[t]),(({name:a,type:t})=>[a,t])))])))),((a,t,e)=>B(r,t,J(H(r,t,_),e,((a,t,e)=>{e!=j(a,t)&&B(a,t,e)}),((a,t)=>B(a,t))))),((a,t)=>B(r,t))),async(t,e)=>((a,t)=>!o(j(j(r,a),t)))(t,e)?f(C(p(await a(Q+q(t)),(a=>{return[a[e],(t={...a},s=e,delete t[s],t)];var t,s})),(([a,t])=>!o(a)&&!$(t)))):{},async(t,n,c,l,y,w=!1)=>{const u=U();D(c??{},(a=>p(R(a??{}),(a=>W(u,a)))));const d=A(u);if(!w&&y&&g(d)&&h(r,t))return await a("DROP "+z+q(t)),void B(r,t);if(g(d)||h(r,t)){const s=j(r,t),i=U(F(s));await E([...p(d,(async n=>{O(i,n)||(await a(K+q(t)+"ADD"+q(n)),B(s,n,e))})),...!w&&l?p(A(i),(async e=>{e!=n&&(await a(K+q(t)+"DROP"+q(e)),B(s,e))})):[]])}else await a("CREATE "+z+q(t)+"("+q(n)+` PRIMARY KEY ON CONFLICT REPLACE${v(p(d,(a=>s+q(a))))});`),B(r,t,_([[n,e],...p(d,(a=>[a,e]))]));if(w)o(c)?await a(V+q(t)+Z+" 1"):await E(D(c,(async(e,s)=>{o(e)?await a(V+q(t)+Z+q(n)+"=?",[s]):g(d)||await ta(a,t,n,R(e),[s,...M(e)],i)})));else if(g(d))h(r,t)&&await a(V+q(t)+Z+" 1");else{const e=C(F(j(r,t)),(a=>a!=n)),s=[],o=[];D(c??{},((a,t)=>{m(s,t,...p(e,(t=>a?.[t]))),m(o,t)})),await ta(a,t,n,e,s,i),await a(V+q(t)+Z+q(n)+"NOT IN("+ea(o)+")",o)}},async t=>{let e;await a("BEGIN");try{e=await t()}catch(a){n?.(a)}return await a("END"),e}]},ta=async(a,t,n,r,c,o=!0)=>await a("INSERT "+(o?e:"OR REPLACE ")+"INTO"+q(t)+"("+q(n)+v(p(r,(a=>s+q(a))))+")VALUES"+u(i(`,(?${i(",?",d(r))})`,d(c)/(d(r)+1)),1)+(o?"ON CONFLICT("+q(n)+")DO UPDATE SET"+v(p(r,(a=>q(a)+"=excluded."+q(a))),s):e),p(c,(a=>a??null))),ea=a=>v(p(a,(()=>"?")),s),sa=_(),na=_(),ia=(a,t,e,s,n,i,r,c={},y=[])=>{let u,d,E,v=0,p=0,g=0;H(sa,y,(()=>0)),H(na,y,(()=>[]));const[C,h,A,O,T]=((a=1,t)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,t.getTransactionMergeableChanges,([[a],[t]])=>!$(a)||!$(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!$(a)||!$(t),t.setContent]:(a=>{throw Error("Store type not supported by this Persister")})())(r,a),N=t=>{(C&&w(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},L=async a=>(2!=v&&(v=1,p++,await I((async()=>{try{N(await t())}catch(t){i?.(t),a&&T(a)}v=0}))),D),R=()=>(d&&(n(d),d=void 0),D),f=async a=>(1!=v&&(v=2,g++,await I((async()=>{try{await e(h,a)}catch(a){i?.(a)}v=0}))),D),b=()=>(l(E,a.delListener),E=void 0,D),I=async(...a)=>(m(j(na,y),...a),await(async()=>{if(!j(sa,y)){for(B(sa,y,1);!o((a=j(na,y),u=a.shift()));)try{await u()}catch(a){i?.(a)}B(sa,y,0)}var a})(),D),D={load:L,startAutoLoad:async a=>{await R().load(a);try{d=s((async(a,t)=>{t||a?2!=v&&(v=1,p++,N(t??a),v=0):await L()}))}catch(a){i?.(a)}return D},stopAutoLoad:R,isAutoLoading:()=>!o(d),save:f,startAutoSave:async()=>(await b().save(),E=a.addDidFinishTransactionListener((()=>{const a=A();O(a)&&f(a)})),D),stopAutoSave:b,isAutoSaving:()=>!o(E),schedule:I,getStore:()=>a,destroy:()=>(j(na,y).splice(0,void 0),R().stopAutoSave()),getStats:()=>({loads:p,saves:g}),...c};return S(D)},ra=(a,t,e,s,n,i,[r,c,o],l,y,w,u)=>{const[d,E,v,p]=aa(t,l,n,u);return ia(a,(async()=>await p((async()=>{return await d(),a=(await E(r,c))[Y]?.[o]??"null",JSON.parse(a,((a,t)=>""===t?void 0:t));var a}))),(async a=>await p((async()=>{var t;await d(),await v(r,c,{[Y]:{[o]:(t=a()??null,JSON.stringify(t,((a,t)=>void 0===t?"":t)))}},!0,!0)}))),e,s,n,i,{[w]:()=>y},y)},ca=(a,t,e,s,n,i,[r,c,[l,y,w]],u,d,v,p)=>{const[g,m,h,A]=aa(t,u,n,p),O=async(a,t)=>await E(x(c,(async([e,s,n,i],r)=>{t&&!I(a,r)||await h(e,s,a[r],n,i,t)}))),T=async(a,t)=>y?await h(w,k,{[Y]:a},!0,!0,t):null;return ia(a,(async()=>await A((async()=>{await g();const a=await(async()=>f(C(await E(x(r,(async([a,t],e)=>[a,await m(e,t)]))),(a=>!$(a[1])))))(),t=await(async()=>l?(await m(w,k))[Y]:{})();return $(a)&&o(t)?void 0:[a,t]}))),(async(a,t)=>await A((async()=>{if(await g(),o(t)){const[t,e]=a();await O(t),await T(e)}else await O(t[0],!0),await T(t[1],!0)}))),e,s,n,i,{[v]:()=>d},d)},oa="ColumnName",la="store",ya="json",wa=la+"TableName",ua=la+"Id"+oa,da=la+oa,Ea="autoLoadIntervalSeconds",va="rowId"+oa,pa="tableId",ga="tableName",Ca="deleteEmptyColumns",ma="deleteEmptyTable",ha={mode:ya,[Ea]:1},Aa={load:0,save:0,[ga]:t+"_values"},Oa=(a,t,e,s,n)=>{const i=_();return D(a,((a,r)=>{const c=u(M(b(t,y(a)?{[e]:a}:a)),0,P(t));o(c[0])||s(r,c[0])||(n(r,c[0]),B(i,r,c))})),i},Ta="pragma_",Na="data_version",La="schema_version";exports.createLibSqlPersister=(a,e,s,n,i)=>((a,e,s,n,i,r,o,l,w,d="getDb",E)=>{let v,p,g;const[C,m,O,T]=(a=>{const e=(a=>b(ha,y(a)?{[wa]:a}:a??{}))(a),s=e[Ea];if(e.mode==ya){const a=e[wa]??t;return[1,s,[a,e[ua]??k,e[da]??la],U(a)]}const{tables:{load:n={},save:i={}}={},values:r={}}=e,c=u(M(b(Aa,r)),0,P(Aa)),o=c[2],l=U(o),w=U(o);return[0,s,[Oa(n,{[pa]:null,[va]:k},pa,(a=>h(w,a)),(a=>W(l,a))),Oa(i,{[ga]:null,[va]:k,[Ca]:0,[ma]:0},ga,((a,t)=>h(w,t)),((a,t)=>W(l,t))),c],l]})(e);return(C?ra:ca)(a,r?async(a,t)=>(r(a,t),await s(a,t)):s,(a=>{return[(t=async()=>{try{const[{d:t,s:e,c:n}]=await s(`SELECT ${Na} d,${La} s,TOTAL_CHANGES() c FROM ${Ta}${Na} JOIN ${Ta}${La}`);t==(v??=t)&&e==(p??=e)&&n==(g??=n)||(a(),v=t,p=e)}catch{}},e=m,t(),setInterval(t,1e3*e)),n((t=>T.has(t)?a():0))];var t,e}),(([a,t])=>{c(a),v=p=g=null,i(t)}),o,l,O,A(T),w,d,E)})(a,s,(async(a,t=[])=>(await e.execute({sql:a,args:t})).rows),(()=>()=>0),(a=>a()),n,i,1,e,"getClient");
@@ -1 +1 @@
1
- "use strict";const t=t=>typeof t,e="",a=t(e),s=t=>null==t,o=(t,e,a)=>s(t)?a?.():e(t),r=e=>t(e)==a,n=t=>t.length,i=Object,c=t=>i.getPrototypeOf(t),y=i.keys,d=i.freeze,g=t=>(t=>!s(t)&&o(c(t),(t=>t==i.prototype||s(c(t))),(()=>!0)))(t)&&0==(t=>n(y(t)))(t),p=t=>JSON.stringify(t,((t,e)=>e instanceof Map?i.fromEntries([...e]):e)),h=JSON.parse,l="/store",v=t=>new Map(t),u=(t,e)=>t?.get(e),w=(t,e,a)=>{return s(a)?(o=t,r=e,o?.delete(r),t):t?.set(e,a);var o,r},f=(t,e,a,s)=>{var o,r;return o=t,r=e,o?.has(r)||w(t,e,a()),u(t,e)},C=v(),S=v(),A="message";exports.createPartyKitPersister=(t,a,i,c)=>{const{host:y,room:v}=a.partySocketOptions,{storeProtocol:P="https",storePath:b=l,messagePrefix:m=e}={...r(i)?{storeProtocol:i}:i},L=P+"://"+y+"/parties/"+a.name+"/"+v+b,M=async t=>await(await fetch(L,{...t?{method:"PUT",body:p(t)}:{},mode:"cors",cache:"no-store"})).json();return((t,e,a,r,n,i,c,y={},p=[])=>{let h,l,v,A=0,P=0,b=0;f(C,p,(()=>0)),f(S,p,(()=>[]));const[m,L,M,O,E]=((t=1,e)=>1!=t&&e.isMergeable()?[1,e.getMergeableContent,e.getTransactionMergeableChanges,([[t],[e]])=>!g(t)||!g(e),e.setDefaultContent]:2!=t?[0,e.getContent,e.getTransactionChanges,([t,e])=>!g(t)||!g(e),e.setContent]:(t=>{throw Error("Store type not supported by this Persister")})())(c,t),T=e=>{var a;(m&&(a=e?.[0],Array.isArray(a))?1===e?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===e?.[2]?t.applyChanges:t.setContent)(e)},j=async t=>(2!=A&&(A=1,P++,await J((async()=>{try{T(await e())}catch(e){i?.(e),t&&E(t)}A=0}))),N),k=()=>(l&&(n(l),l=void 0),N),x=async t=>(1!=A&&(A=2,b++,await J((async()=>{try{await a(L,t)}catch(t){i?.(t)}A=0}))),N),D=()=>(o(v,t.delListener),v=void 0,N),J=async(...t)=>(((t,...e)=>{t.push(...e)})(u(S,p),...t),await(async()=>{if(!u(C,p)){for(w(C,p,1);!s((t=u(S,p),h=t.shift()));)try{await h()}catch(t){i?.(t)}w(C,p,0)}var t})(),N),N={load:j,startAutoLoad:async t=>(await k().load(t),l=r((async(t,e)=>{e||t?2!=A&&(A=1,P++,T(e??t),A=0):await j()})),N),stopAutoLoad:k,isAutoLoading:()=>!s(l),save:x,startAutoSave:async()=>(await D().save(),v=t.addDidFinishTransactionListener((()=>{const t=M();O(t)&&x(t)})),N),stopAutoSave:D,isAutoSaving:()=>!s(v),schedule:J,getStore:()=>t,destroy:()=>k().stopAutoSave(),getStats:()=>({loads:P,saves:b}),...y};return d(N)})(t,(async()=>await M()),(async(t,e)=>{var s;e?a.send(m+"s"+(r(s=e)?s:p(s))):await M(t())}),(t=>{const e=e=>o(((t,e,a)=>{const s=n(t);return((t,e)=>t.startsWith(e))(e,t)?[e[s],h((o=e,r=s+1,o.slice(r,void 0)))]:void 0;var o,r})(m,e.data),(([e,a])=>{"s"==e&&t(void 0,a)}));return a.addEventListener(A,e),e}),(t=>{a.removeEventListener(A,t)}),c,1,{getConnection:()=>a})};
1
+ "use strict";const t=t=>typeof t,e="",a=t(e),s=t=>null==t,r=(t,e,a)=>s(t)?a?.():e(t),o=e=>t(e)==a,n=t=>t.length,i=Object,c=t=>i.getPrototypeOf(t),y=i.keys,d=i.freeze,g=t=>(t=>!s(t)&&r(c(t),(t=>t==i.prototype||s(c(t))),(()=>!0)))(t)&&0==(t=>n(y(t)))(t),p=t=>JSON.stringify(t,((t,e)=>e instanceof Map?i.fromEntries([...e]):e)),h=JSON.parse,l="/store",v=t=>new Map(t),u=(t,e)=>t?.get(e),w=(t,e,a)=>{return s(a)?(r=t,o=e,r?.delete(o),t):t?.set(e,a);var r,o},f=(t,e,a,s)=>{var r,o;return r=t,o=e,r?.has(o)||w(t,e,a()),u(t,e)},C=v(),S=v(),A="message";exports.createPartyKitPersister=(t,a,i,c)=>{const{host:y,room:v}=a.partySocketOptions,{storeProtocol:P="https",storePath:b=l,messagePrefix:m=e}={...o(i)?{storeProtocol:i}:i},L=P+"://"+y+"/parties/"+a.name+"/"+v+b,M=async t=>await(await fetch(L,{...t?{method:"PUT",body:p(t)}:{},mode:"cors",cache:"no-store"})).json();return((t,e,a,o,n,i,c,y={},p=[])=>{let h,l,v,A=0,P=0,b=0;f(C,p,(()=>0)),f(S,p,(()=>[]));const[m,L,M,O,E]=((t=1,e)=>1!=t&&e.isMergeable()?[1,e.getMergeableContent,e.getTransactionMergeableChanges,([[t],[e]])=>!g(t)||!g(e),e.setDefaultContent]:2!=t?[0,e.getContent,e.getTransactionChanges,([t,e])=>!g(t)||!g(e),e.setContent]:(t=>{throw Error("Store type not supported by this Persister")})())(c,t),T=e=>{var a;(m&&(a=e?.[0],Array.isArray(a))?1===e?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===e?.[2]?t.applyChanges:t.setContent)(e)},j=async t=>(2!=A&&(A=1,P++,await J((async()=>{try{T(await e())}catch(e){i?.(e),t&&E(t)}A=0}))),N),k=()=>(l&&(n(l),l=void 0),N),x=async t=>(1!=A&&(A=2,b++,await J((async()=>{try{await a(L,t)}catch(t){i?.(t)}A=0}))),N),D=()=>(r(v,t.delListener),v=void 0,N),J=async(...t)=>(((t,...e)=>{t.push(...e)})(u(S,p),...t),await(async()=>{if(!u(C,p)){for(w(C,p,1);!s((t=u(S,p),h=t.shift()));)try{await h()}catch(t){i?.(t)}w(C,p,0)}var t})(),N),N={load:j,startAutoLoad:async t=>{await k().load(t);try{l=o((async(t,e)=>{e||t?2!=A&&(A=1,P++,T(e??t),A=0):await j()}))}catch(t){i?.(t)}return N},stopAutoLoad:k,isAutoLoading:()=>!s(l),save:x,startAutoSave:async()=>(await D().save(),v=t.addDidFinishTransactionListener((()=>{const t=M();O(t)&&x(t)})),N),stopAutoSave:D,isAutoSaving:()=>!s(v),schedule:J,getStore:()=>t,destroy:()=>(u(S,p).splice(0,void 0),k().stopAutoSave()),getStats:()=>({loads:P,saves:b}),...y};return d(N)})(t,(async()=>await M()),(async(t,e)=>{var s;e?a.send(m+"s"+(o(s=e)?s:p(s))):await M(t())}),(t=>{const e=e=>r(((t,e,a)=>{const s=n(t);return((t,e)=>t.startsWith(e))(e,t)?[e[s],h((r=e,o=s+1,r.slice(o,void 0)))]:void 0;var r,o})(m,e.data),(([e,a])=>{"s"==e&&t(void 0,a)}));return a.addEventListener(A,e),e}),(t=>{a.removeEventListener(A,t)}),c,1,{getConnection:()=>a})};
@@ -1 +1 @@
1
- "use strict";const t=t=>typeof t,e="",a=t(e),s=t=>null==t,o=(t,e,a)=>s(t)?a?.():e(t),r=e=>t(e)==a,n=t=>t.length,i=Object,c=t=>i.getPrototypeOf(t),y=i.keys,d=i.freeze,g=t=>(t=>!s(t)&&o(c(t),(t=>t==i.prototype||s(c(t))),(()=>!0)))(t)&&0==(t=>n(y(t)))(t),p=t=>JSON.stringify(t,((t,e)=>e instanceof Map?i.fromEntries([...e]):e)),h=JSON.parse,l="/store",v=t=>new Map(t),u=(t,e)=>t?.get(e),w=(t,e,a)=>{return s(a)?(o=t,r=e,o?.delete(r),t):t?.set(e,a);var o,r},f=(t,e,a,s)=>{var o,r;return o=t,r=e,o?.has(r)||w(t,e,a()),u(t,e)},C=v(),S=v(),A="message";exports.createPartyKitPersister=(t,a,i,c)=>{const{host:y,room:v}=a.partySocketOptions,{storeProtocol:P="https",storePath:b=l,messagePrefix:m=e}={...r(i)?{storeProtocol:i}:i},L=P+"://"+y+"/parties/"+a.name+"/"+v+b,M=async t=>await(await fetch(L,{...t?{method:"PUT",body:p(t)}:{},mode:"cors",cache:"no-store"})).json();return((t,e,a,r,n,i,c,y={},p=[])=>{let h,l,v,A=0,P=0,b=0;f(C,p,(()=>0)),f(S,p,(()=>[]));const[m,L,M,O,E]=((t=1,e)=>1!=t&&e.isMergeable()?[1,e.getMergeableContent,e.getTransactionMergeableChanges,([[t],[e]])=>!g(t)||!g(e),e.setDefaultContent]:2!=t?[0,e.getContent,e.getTransactionChanges,([t,e])=>!g(t)||!g(e),e.setContent]:(t=>{throw Error("Store type not supported by this Persister")})())(c,t),T=e=>{var a;(m&&(a=e?.[0],Array.isArray(a))?1===e?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===e?.[2]?t.applyChanges:t.setContent)(e)},j=async t=>(2!=A&&(A=1,P++,await J((async()=>{try{T(await e())}catch(e){i?.(e),t&&E(t)}A=0}))),N),k=()=>(l&&(n(l),l=void 0),N),x=async t=>(1!=A&&(A=2,b++,await J((async()=>{try{await a(L,t)}catch(t){i?.(t)}A=0}))),N),D=()=>(o(v,t.delListener),v=void 0,N),J=async(...t)=>(((t,...e)=>{t.push(...e)})(u(S,p),...t),await(async()=>{if(!u(C,p)){for(w(C,p,1);!s((t=u(S,p),h=t.shift()));)try{await h()}catch(t){i?.(t)}w(C,p,0)}var t})(),N),N={load:j,startAutoLoad:async t=>(await k().load(t),l=r((async(t,e)=>{e||t?2!=A&&(A=1,P++,T(e??t),A=0):await j()})),N),stopAutoLoad:k,isAutoLoading:()=>!s(l),save:x,startAutoSave:async()=>(await D().save(),v=t.addDidFinishTransactionListener((()=>{const t=M();O(t)&&x(t)})),N),stopAutoSave:D,isAutoSaving:()=>!s(v),schedule:J,getStore:()=>t,destroy:()=>k().stopAutoSave(),getStats:()=>({loads:P,saves:b}),...y};return d(N)})(t,(async()=>await M()),(async(t,e)=>{var s;e?a.send(m+"s"+(r(s=e)?s:p(s))):await M(t())}),(t=>{const e=e=>o(((t,e,a)=>{const s=n(t);return((t,e)=>t.startsWith(e))(e,t)?[e[s],h((o=e,r=s+1,o.slice(r,void 0)))]:void 0;var o,r})(m,e.data),(([e,a])=>{"s"==e&&t(void 0,a)}));return a.addEventListener(A,e),e}),(t=>{a.removeEventListener(A,t)}),c,1,{getConnection:()=>a})};
1
+ "use strict";const t=t=>typeof t,e="",a=t(e),s=t=>null==t,r=(t,e,a)=>s(t)?a?.():e(t),o=e=>t(e)==a,n=t=>t.length,i=Object,c=t=>i.getPrototypeOf(t),y=i.keys,d=i.freeze,g=t=>(t=>!s(t)&&r(c(t),(t=>t==i.prototype||s(c(t))),(()=>!0)))(t)&&0==(t=>n(y(t)))(t),p=t=>JSON.stringify(t,((t,e)=>e instanceof Map?i.fromEntries([...e]):e)),h=JSON.parse,l="/store",v=t=>new Map(t),u=(t,e)=>t?.get(e),w=(t,e,a)=>{return s(a)?(r=t,o=e,r?.delete(o),t):t?.set(e,a);var r,o},f=(t,e,a,s)=>{var r,o;return r=t,o=e,r?.has(o)||w(t,e,a()),u(t,e)},C=v(),S=v(),A="message";exports.createPartyKitPersister=(t,a,i,c)=>{const{host:y,room:v}=a.partySocketOptions,{storeProtocol:P="https",storePath:b=l,messagePrefix:m=e}={...o(i)?{storeProtocol:i}:i},L=P+"://"+y+"/parties/"+a.name+"/"+v+b,M=async t=>await(await fetch(L,{...t?{method:"PUT",body:p(t)}:{},mode:"cors",cache:"no-store"})).json();return((t,e,a,o,n,i,c,y={},p=[])=>{let h,l,v,A=0,P=0,b=0;f(C,p,(()=>0)),f(S,p,(()=>[]));const[m,L,M,O,E]=((t=1,e)=>1!=t&&e.isMergeable()?[1,e.getMergeableContent,e.getTransactionMergeableChanges,([[t],[e]])=>!g(t)||!g(e),e.setDefaultContent]:2!=t?[0,e.getContent,e.getTransactionChanges,([t,e])=>!g(t)||!g(e),e.setContent]:(t=>{throw Error("Store type not supported by this Persister")})())(c,t),T=e=>{var a;(m&&(a=e?.[0],Array.isArray(a))?1===e?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===e?.[2]?t.applyChanges:t.setContent)(e)},j=async t=>(2!=A&&(A=1,P++,await J((async()=>{try{T(await e())}catch(e){i?.(e),t&&E(t)}A=0}))),N),k=()=>(l&&(n(l),l=void 0),N),x=async t=>(1!=A&&(A=2,b++,await J((async()=>{try{await a(L,t)}catch(t){i?.(t)}A=0}))),N),D=()=>(r(v,t.delListener),v=void 0,N),J=async(...t)=>(((t,...e)=>{t.push(...e)})(u(S,p),...t),await(async()=>{if(!u(C,p)){for(w(C,p,1);!s((t=u(S,p),h=t.shift()));)try{await h()}catch(t){i?.(t)}w(C,p,0)}var t})(),N),N={load:j,startAutoLoad:async t=>{await k().load(t);try{l=o((async(t,e)=>{e||t?2!=A&&(A=1,P++,T(e??t),A=0):await j()}))}catch(t){i?.(t)}return N},stopAutoLoad:k,isAutoLoading:()=>!s(l),save:x,startAutoSave:async()=>(await D().save(),v=t.addDidFinishTransactionListener((()=>{const t=M();O(t)&&x(t)})),N),stopAutoSave:D,isAutoSaving:()=>!s(v),schedule:J,getStore:()=>t,destroy:()=>(u(S,p).splice(0,void 0),k().stopAutoSave()),getStats:()=>({loads:P,saves:b}),...y};return d(N)})(t,(async()=>await M()),(async(t,e)=>{var s;e?a.send(m+"s"+(o(s=e)?s:p(s))):await M(t())}),(t=>{const e=e=>r(((t,e,a)=>{const s=n(t);return((t,e)=>t.startsWith(e))(e,t)?[e[s],h((r=e,o=s+1,r.slice(o,void 0)))]:void 0;var r,o})(m,e.data),(([e,a])=>{"s"==e&&t(void 0,a)}));return a.addEventListener(A,e),e}),(t=>{a.removeEventListener(A,t)}),c,1,{getConnection:()=>a})};
@@ -1 +1 @@
1
- "use strict";const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),i=(a,t)=>a.repeat(t),r=Promise,o=clearInterval,c=a=>null==a,l=(a,t,e)=>c(a)?e?.():t(a),y=t=>a(t)==s,w=a=>Array.isArray(a),u=(a,t,e)=>a.slice(t,e),d=a=>a.length,E=async a=>r.all(a),g=(a,t="")=>a.join(t),v=(a,t)=>a.map(t),p=a=>0==d(a),C=(a,t)=>a.filter(t),h=(a,...t)=>a.push(...t),m=(a,t)=>a?.has(t)??!1,A=a=>[...a?.values()??[]],T=(a,t)=>a?.delete(t),O=Object,N=a=>O.getPrototypeOf(a),b=O.entries,f=O.keys,S=O.freeze,R=(a=[])=>O.fromEntries(a),L=(...a)=>O.assign({},...a),I=(a,t)=>t in a,D=(a,t)=>v(b(a),(([a,e])=>t(e,a))),P=a=>O.values(a),M=a=>d(f(a)),_=a=>(a=>!c(a)&&l(N(a),(a=>a==O.prototype||c(N(a))),(()=>!0)))(a)&&0==M(a),$=a=>new Map(a),F=a=>[...a?.keys()??[]],j=(a,t)=>a?.get(t),x=(a,t)=>v([...a?.entries()??[]],(([a,e])=>t(e,a))),B=(a,t,e)=>c(e)?(T(a,t),a):a?.set(t,e),H=(a,t,e,n)=>(m(a,t)||B(a,t,e()),j(a,t)),J=(a,t,e,n=B)=>(D(t,((t,n)=>e(a,n,t))),((a,t)=>{((a,t)=>{a?.forEach(t)})(a,((a,e)=>t(e)))})(a,(e=>I(t,e)?0:n(a,e))),a),Y="_",k="_id",G=a=>`"${a.replace(/"/g,'""')}"`,U="SELECT",W=a=>new Set(w(a)||c(a)?a:[a]),z=(a,t)=>a?.add(t),K="TABLE",V="ALTER "+K,q="DELETE FROM",Q=U+"*FROM",X="FROM pragma_table_",Z="WHERE",aa=(a,t,s,i)=>{const r=$();return[async()=>J(r,R(await E(v(await a("SELECT name "+X+"list WHERE schema='main'AND(type='table'OR type='view')AND name IN("+ea(t)+")ORDER BY name",t),(async({name:t})=>[t,R(v(await a(U+" name,type "+X+"info(?)",[t]),(({name:a,type:t})=>[a,t])))])))),((a,t,e)=>B(r,t,J(H(r,t,$),e,((a,t,e)=>{e!=j(a,t)&&B(a,t,e)}),((a,t)=>B(a,t))))),((a,t)=>B(r,t))),async(t,e)=>((a,t)=>!c(j(j(r,a),t)))(t,e)?R(C(v(await a(Q+G(t)),(a=>{return[a[e],(t={...a},n=e,delete t[n],t)];var t,n})),(([a,t])=>!c(a)&&!_(t)))):{},async(t,s,o,l,y,w=!1)=>{const u=W();D(o??{},(a=>v(f(a??{}),(a=>z(u,a)))));const d=A(u);if(!w&&y&&p(d)&&m(r,t))return await a("DROP "+K+G(t)),void B(r,t);if(p(d)||m(r,t)){const n=j(r,t),i=W(F(n));await E([...v(d,(async s=>{T(i,s)||(await a(V+G(t)+"ADD"+G(s)),B(n,s,e))})),...!w&&l?v(A(i),(async e=>{e!=s&&(await a(V+G(t)+"DROP"+G(e)),B(n,e))})):[]])}else await a("CREATE "+K+G(t)+"("+G(s)+` PRIMARY KEY ON CONFLICT REPLACE${g(v(d,(a=>n+G(a))))});`),B(r,t,$([[s,e],...v(d,(a=>[a,e]))]));if(w)c(o)?await a(q+G(t)+Z+" 1"):await E(D(o,(async(e,n)=>{c(e)?await a(q+G(t)+Z+G(s)+"=?",[n]):p(d)||await ta(a,t,s,f(e),[n,...P(e)],i)})));else if(p(d))m(r,t)&&await a(q+G(t)+Z+" 1");else{const e=C(F(j(r,t)),(a=>a!=s)),n=[],c=[];D(o??{},((a,t)=>{h(n,t,...v(e,(t=>a?.[t]))),h(c,t)})),await ta(a,t,s,e,n,i),await a(q+G(t)+Z+G(s)+"NOT IN("+ea(c)+")",c)}},async t=>{let e;await a("BEGIN");try{e=await t()}catch(a){s?.(a)}return await a("END"),e}]},ta=async(a,t,s,r,o,c=!0)=>await a("INSERT "+(c?e:"OR REPLACE ")+"INTO"+G(t)+"("+G(s)+g(v(r,(a=>n+G(a))))+")VALUES"+u(i(`,(?${i(",?",d(r))})`,d(o)/(d(r)+1)),1)+(c?"ON CONFLICT("+G(s)+")DO UPDATE SET"+g(v(r,(a=>G(a)+"=excluded."+G(a))),n):e),v(o,(a=>a??null))),ea=a=>g(v(a,(()=>"?")),n),na=$(),sa=$(),ia=(a,t,e,n,s,i,r,o={},y=[])=>{let u,d,E,g=0,v=0,p=0;H(na,y,(()=>0)),H(sa,y,(()=>[]));const[C,m,A,T,O]=((a=1,t)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,t.getTransactionMergeableChanges,([[a],[t]])=>!_(a)||!_(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!_(a)||!_(t),t.setContent]:(a=>{throw Error("Store type not supported by this Persister")})())(r,a),N=t=>{(C&&w(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},b=async a=>(2!=g&&(g=1,v++,await I((async()=>{try{N(await t())}catch(t){i?.(t),a&&O(a)}g=0}))),D),f=()=>(d&&(s(d),d=void 0),D),R=async a=>(1!=g&&(g=2,p++,await I((async()=>{try{await e(m,a)}catch(a){i?.(a)}g=0}))),D),L=()=>(l(E,a.delListener),E=void 0,D),I=async(...a)=>(h(j(sa,y),...a),await(async()=>{if(!j(na,y)){for(B(na,y,1);!c((a=j(sa,y),u=a.shift()));)try{await u()}catch(a){i?.(a)}B(na,y,0)}var a})(),D),D={load:b,startAutoLoad:async a=>(await f().load(a),d=n((async(a,t)=>{t||a?2!=g&&(g=1,v++,N(t??a),g=0):await b()})),D),stopAutoLoad:f,isAutoLoading:()=>!c(d),save:R,startAutoSave:async()=>(await L().save(),E=a.addDidFinishTransactionListener((()=>{const a=A();T(a)&&R(a)})),D),stopAutoSave:L,isAutoSaving:()=>!c(E),schedule:I,getStore:()=>a,destroy:()=>f().stopAutoSave(),getStats:()=>({loads:v,saves:p}),...o};return S(D)},ra=(a,t,e,n,s,i,[r,o,c],l,y,w,u)=>{const[d,E,g,v]=aa(t,l,s,u);return ia(a,(async()=>await v((async()=>{return await d(),a=(await E(r,o))[Y]?.[c]??"null",JSON.parse(a,((a,t)=>""===t?void 0:t));var a}))),(async a=>await v((async()=>{var t;await d(),await g(r,o,{[Y]:{[c]:(t=a()??null,JSON.stringify(t,((a,t)=>void 0===t?"":t)))}},!0,!0)}))),e,n,s,i,{[w]:()=>y},y)},oa=(a,t,e,n,s,i,[r,o,[l,y,w]],u,d,g,v)=>{const[p,h,m,A]=aa(t,u,s,v),T=async(a,t)=>await E(x(o,(async([e,n,s,i],r)=>{t&&!I(a,r)||await m(e,n,a[r],s,i,t)}))),O=async(a,t)=>y?await m(w,k,{[Y]:a},!0,!0,t):null;return ia(a,(async()=>await A((async()=>{await p();const a=await(async()=>R(C(await E(x(r,(async([a,t],e)=>[a,await h(e,t)]))),(a=>!_(a[1])))))(),t=await(async()=>l?(await h(w,k))[Y]:{})();return _(a)&&c(t)?void 0:[a,t]}))),(async(a,t)=>await A((async()=>{if(await p(),c(t)){const[t,e]=a();await T(t),await O(e)}else await T(t[0],!0),await O(t[1],!0)}))),e,n,s,i,{[g]:()=>d},d)},ca="ColumnName",la="store",ya="json",wa=la+"TableName",ua=la+"Id"+ca,da=la+ca,Ea="autoLoadIntervalSeconds",ga="rowId"+ca,va="tableId",pa="tableName",Ca="deleteEmptyColumns",ha="deleteEmptyTable",ma={mode:ya,[Ea]:1},Aa={load:0,save:0,[pa]:t+"_values"},Ta=(a,t,e,n,s)=>{const i=$();return D(a,((a,r)=>{const o=u(P(L(t,y(a)?{[e]:a}:a)),0,M(t));c(o[0])||n(r,o[0])||(s(r,o[0]),B(i,r,o))})),i},Oa="pragma_",Na="data_version",ba="schema_version";exports.createPowerSyncPersister=(a,e,n,s,i,r=!1)=>((a,e,n,s,i,r,c,l,w,d="getDb",E)=>{let g,v,p;const[C,h,T,O]=(a=>{const e=(a=>L(ma,y(a)?{[wa]:a}:a??{}))(a),n=e[Ea];if(e.mode==ya){const a=e[wa]??t;return[1,n,[a,e[ua]??k,e[da]??la],W(a)]}const{tables:{load:s={},save:i={}}={},values:r={}}=e,o=u(P(L(Aa,r)),0,M(Aa)),c=o[2],l=W(c),w=W(c);return[0,n,[Ta(s,{[va]:null,[ga]:k},va,(a=>m(w,a)),(a=>z(l,a))),Ta(i,{[pa]:null,[ga]:k,[Ca]:0,[ha]:0},pa,((a,t)=>m(w,t)),((a,t)=>z(l,t))),o],l]})(e);return(C?ra:oa)(a,r?async(a,t)=>(r(a,t),await n(a,t)):n,(a=>{return[(t=async()=>{try{const[{d:t,s:e,c:s}]=await n(`SELECT ${Na} d,${ba} s,TOTAL_CHANGES() c FROM ${Oa}${Na} JOIN ${Oa}${ba}`);t==(g??=t)&&e==(v??=e)&&s==(p??=s)||(a(),g=t,v=e)}catch{}},e=h,t(),setInterval(t,1e3*e)),s((t=>O.has(t)?a():0))];var t,e}),(([a,t])=>{o(a),g=v=p=null,i(t)}),c,l,T,A(O),w,d,E)})(a,n,(async(a,t=[])=>e.execute(a,t).then((a=>a.rows?._array??[]))),(a=>{const t=new AbortController,n=e.onChange({rawTableNames:!0,signal:t.signal});return(async()=>{for await(const t of n)v(t.changedTables,a)})(),t}),(a=>a.abort()),s,i,1,e,"getPowerSync",r);
1
+ "use strict";const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),r=(a,t)=>a.repeat(t),i=Promise,o=clearInterval,c=a=>null==a,l=(a,t,e)=>c(a)?e?.():t(a),y=t=>a(t)==s,w=a=>Array.isArray(a),u=(a,t,e)=>a.slice(t,e),d=a=>a.length,E=async a=>i.all(a),g=(a,t="")=>a.join(t),v=(a,t)=>a.map(t),p=a=>0==d(a),h=(a,t)=>a.filter(t),C=(a,...t)=>a.push(...t),m=(a,t)=>a?.has(t)??!1,A=a=>[...a?.values()??[]],T=(a,t)=>a?.delete(t),O=Object,N=a=>O.getPrototypeOf(a),b=O.entries,f=O.keys,S=O.freeze,R=(a=[])=>O.fromEntries(a),L=(...a)=>O.assign({},...a),I=(a,t)=>t in a,D=(a,t)=>v(b(a),(([a,e])=>t(e,a))),P=a=>O.values(a),M=a=>d(f(a)),_=a=>(a=>!c(a)&&l(N(a),(a=>a==O.prototype||c(N(a))),(()=>!0)))(a)&&0==M(a),$=a=>new Map(a),F=a=>[...a?.keys()??[]],j=(a,t)=>a?.get(t),x=(a,t)=>v([...a?.entries()??[]],(([a,e])=>t(e,a))),B=(a,t,e)=>c(e)?(T(a,t),a):a?.set(t,e),H=(a,t,e,n)=>(m(a,t)||B(a,t,e()),j(a,t)),J=(a,t,e,n=B)=>(D(t,((t,n)=>e(a,n,t))),((a,t)=>{((a,t)=>{a?.forEach(t)})(a,((a,e)=>t(e)))})(a,(e=>I(t,e)?0:n(a,e))),a),Y="_",k="_id",G=a=>`"${a.replace(/"/g,'""')}"`,U="SELECT",W=a=>new Set(w(a)||c(a)?a:[a]),z=(a,t)=>a?.add(t),K="TABLE",V="ALTER "+K,q="DELETE FROM",Q=U+"*FROM",X="FROM pragma_table_",Z="WHERE",aa=(a,t,s,r)=>{const i=$();return[async()=>J(i,R(await E(v(await a("SELECT name "+X+"list WHERE schema='main'AND(type='table'OR type='view')AND name IN("+ea(t)+")ORDER BY name",t),(async({name:t})=>[t,R(v(await a(U+" name,type "+X+"info(?)",[t]),(({name:a,type:t})=>[a,t])))])))),((a,t,e)=>B(i,t,J(H(i,t,$),e,((a,t,e)=>{e!=j(a,t)&&B(a,t,e)}),((a,t)=>B(a,t))))),((a,t)=>B(i,t))),async(t,e)=>((a,t)=>!c(j(j(i,a),t)))(t,e)?R(h(v(await a(Q+G(t)),(a=>{return[a[e],(t={...a},n=e,delete t[n],t)];var t,n})),(([a,t])=>!c(a)&&!_(t)))):{},async(t,s,o,l,y,w=!1)=>{const u=W();D(o??{},(a=>v(f(a??{}),(a=>z(u,a)))));const d=A(u);if(!w&&y&&p(d)&&m(i,t))return await a("DROP "+K+G(t)),void B(i,t);if(p(d)||m(i,t)){const n=j(i,t),r=W(F(n));await E([...v(d,(async s=>{T(r,s)||(await a(V+G(t)+"ADD"+G(s)),B(n,s,e))})),...!w&&l?v(A(r),(async e=>{e!=s&&(await a(V+G(t)+"DROP"+G(e)),B(n,e))})):[]])}else await a("CREATE "+K+G(t)+"("+G(s)+` PRIMARY KEY ON CONFLICT REPLACE${g(v(d,(a=>n+G(a))))});`),B(i,t,$([[s,e],...v(d,(a=>[a,e]))]));if(w)c(o)?await a(q+G(t)+Z+" 1"):await E(D(o,(async(e,n)=>{c(e)?await a(q+G(t)+Z+G(s)+"=?",[n]):p(d)||await ta(a,t,s,f(e),[n,...P(e)],r)})));else if(p(d))m(i,t)&&await a(q+G(t)+Z+" 1");else{const e=h(F(j(i,t)),(a=>a!=s)),n=[],c=[];D(o??{},((a,t)=>{C(n,t,...v(e,(t=>a?.[t]))),C(c,t)})),await ta(a,t,s,e,n,r),await a(q+G(t)+Z+G(s)+"NOT IN("+ea(c)+")",c)}},async t=>{let e;await a("BEGIN");try{e=await t()}catch(a){s?.(a)}return await a("END"),e}]},ta=async(a,t,s,i,o,c=!0)=>await a("INSERT "+(c?e:"OR REPLACE ")+"INTO"+G(t)+"("+G(s)+g(v(i,(a=>n+G(a))))+")VALUES"+u(r(`,(?${r(",?",d(i))})`,d(o)/(d(i)+1)),1)+(c?"ON CONFLICT("+G(s)+")DO UPDATE SET"+g(v(i,(a=>G(a)+"=excluded."+G(a))),n):e),v(o,(a=>a??null))),ea=a=>g(v(a,(()=>"?")),n),na=$(),sa=$(),ra=(a,t,e,n,s,r,i,o={},y=[])=>{let u,d,E,g=0,v=0,p=0;H(na,y,(()=>0)),H(sa,y,(()=>[]));const[h,m,A,T,O]=((a=1,t)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,t.getTransactionMergeableChanges,([[a],[t]])=>!_(a)||!_(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!_(a)||!_(t),t.setContent]:(a=>{throw Error("Store type not supported by this Persister")})())(i,a),N=t=>{(h&&w(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},b=async a=>(2!=g&&(g=1,v++,await I((async()=>{try{N(await t())}catch(t){r?.(t),a&&O(a)}g=0}))),D),f=()=>(d&&(s(d),d=void 0),D),R=async a=>(1!=g&&(g=2,p++,await I((async()=>{try{await e(m,a)}catch(a){r?.(a)}g=0}))),D),L=()=>(l(E,a.delListener),E=void 0,D),I=async(...a)=>(C(j(sa,y),...a),await(async()=>{if(!j(na,y)){for(B(na,y,1);!c((a=j(sa,y),u=a.shift()));)try{await u()}catch(a){r?.(a)}B(na,y,0)}var a})(),D),D={load:b,startAutoLoad:async a=>{await f().load(a);try{d=n((async(a,t)=>{t||a?2!=g&&(g=1,v++,N(t??a),g=0):await b()}))}catch(a){r?.(a)}return D},stopAutoLoad:f,isAutoLoading:()=>!c(d),save:R,startAutoSave:async()=>(await L().save(),E=a.addDidFinishTransactionListener((()=>{const a=A();T(a)&&R(a)})),D),stopAutoSave:L,isAutoSaving:()=>!c(E),schedule:I,getStore:()=>a,destroy:()=>(j(sa,y).splice(0,void 0),f().stopAutoSave()),getStats:()=>({loads:v,saves:p}),...o};return S(D)},ia=(a,t,e,n,s,r,[i,o,c],l,y,w,u)=>{const[d,E,g,v]=aa(t,l,s,u);return ra(a,(async()=>await v((async()=>{return await d(),a=(await E(i,o))[Y]?.[c]??"null",JSON.parse(a,((a,t)=>""===t?void 0:t));var a}))),(async a=>await v((async()=>{var t;await d(),await g(i,o,{[Y]:{[c]:(t=a()??null,JSON.stringify(t,((a,t)=>void 0===t?"":t)))}},!0,!0)}))),e,n,s,r,{[w]:()=>y},y)},oa=(a,t,e,n,s,r,[i,o,[l,y,w]],u,d,g,v)=>{const[p,C,m,A]=aa(t,u,s,v),T=async(a,t)=>await E(x(o,(async([e,n,s,r],i)=>{t&&!I(a,i)||await m(e,n,a[i],s,r,t)}))),O=async(a,t)=>y?await m(w,k,{[Y]:a},!0,!0,t):null;return ra(a,(async()=>await A((async()=>{await p();const a=await(async()=>R(h(await E(x(i,(async([a,t],e)=>[a,await C(e,t)]))),(a=>!_(a[1])))))(),t=await(async()=>l?(await C(w,k))[Y]:{})();return _(a)&&c(t)?void 0:[a,t]}))),(async(a,t)=>await A((async()=>{if(await p(),c(t)){const[t,e]=a();await T(t),await O(e)}else await T(t[0],!0),await O(t[1],!0)}))),e,n,s,r,{[g]:()=>d},d)},ca="ColumnName",la="store",ya="json",wa=la+"TableName",ua=la+"Id"+ca,da=la+ca,Ea="autoLoadIntervalSeconds",ga="rowId"+ca,va="tableId",pa="tableName",ha="deleteEmptyColumns",Ca="deleteEmptyTable",ma={mode:ya,[Ea]:1},Aa={load:0,save:0,[pa]:t+"_values"},Ta=(a,t,e,n,s)=>{const r=$();return D(a,((a,i)=>{const o=u(P(L(t,y(a)?{[e]:a}:a)),0,M(t));c(o[0])||n(i,o[0])||(s(i,o[0]),B(r,i,o))})),r},Oa="pragma_",Na="data_version",ba="schema_version";exports.createPowerSyncPersister=(a,e,n,s,r,i=!1)=>((a,e,n,s,r,i,c,l,w,d="getDb",E)=>{let g,v,p;const[h,C,T,O]=(a=>{const e=(a=>L(ma,y(a)?{[wa]:a}:a??{}))(a),n=e[Ea];if(e.mode==ya){const a=e[wa]??t;return[1,n,[a,e[ua]??k,e[da]??la],W(a)]}const{tables:{load:s={},save:r={}}={},values:i={}}=e,o=u(P(L(Aa,i)),0,M(Aa)),c=o[2],l=W(c),w=W(c);return[0,n,[Ta(s,{[va]:null,[ga]:k},va,(a=>m(w,a)),(a=>z(l,a))),Ta(r,{[pa]:null,[ga]:k,[ha]:0,[Ca]:0},pa,((a,t)=>m(w,t)),((a,t)=>z(l,t))),o],l]})(e);return(h?ia:oa)(a,i?async(a,t)=>(i(a,t),await n(a,t)):n,(a=>{return[(t=async()=>{try{const[{d:t,s:e,c:s}]=await n(`SELECT ${Na} d,${ba} s,TOTAL_CHANGES() c FROM ${Oa}${Na} JOIN ${Oa}${ba}`);t==(g??=t)&&e==(v??=e)&&s==(p??=s)||(a(),g=t,v=e)}catch{}},e=C,t(),setInterval(t,1e3*e)),s((t=>O.has(t)?a():0))];var t,e}),(([a,t])=>{o(a),g=v=p=null,r(t)}),c,l,T,A(O),w,d,E)})(a,n,(async(a,t=[])=>e.execute(a,t).then((a=>a.rows?._array??[]))),(a=>{const t=new AbortController,n=e.onChange({rawTableNames:!0,signal:t.signal});return(async()=>{for await(const t of n)v(t.changedTables,a)})(),t}),(a=>a.abort()),s,r,1,e,"getPowerSync",i);
@@ -1 +1 @@
1
- "use strict";const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),i=(a,t)=>a.repeat(t),r=Promise,o=clearInterval,c=a=>null==a,l=(a,t,e)=>c(a)?e?.():t(a),y=t=>a(t)==s,w=a=>Array.isArray(a),u=(a,t,e)=>a.slice(t,e),d=a=>a.length,E=async a=>r.all(a),g=(a,t="")=>a.join(t),v=(a,t)=>a.map(t),p=a=>0==d(a),C=(a,t)=>a.filter(t),h=(a,...t)=>a.push(...t),m=(a,t)=>a?.has(t)??!1,A=a=>[...a?.values()??[]],T=(a,t)=>a?.delete(t),O=Object,N=a=>O.getPrototypeOf(a),b=O.entries,f=O.keys,S=O.freeze,R=(a=[])=>O.fromEntries(a),L=(...a)=>O.assign({},...a),I=(a,t)=>t in a,D=(a,t)=>v(b(a),(([a,e])=>t(e,a))),P=a=>O.values(a),M=a=>d(f(a)),_=a=>(a=>!c(a)&&l(N(a),(a=>a==O.prototype||c(N(a))),(()=>!0)))(a)&&0==M(a),$=a=>new Map(a),F=a=>[...a?.keys()??[]],j=(a,t)=>a?.get(t),x=(a,t)=>v([...a?.entries()??[]],(([a,e])=>t(e,a))),B=(a,t,e)=>c(e)?(T(a,t),a):a?.set(t,e),H=(a,t,e,n)=>(m(a,t)||B(a,t,e()),j(a,t)),J=(a,t,e,n=B)=>(D(t,((t,n)=>e(a,n,t))),((a,t)=>{((a,t)=>{a?.forEach(t)})(a,((a,e)=>t(e)))})(a,(e=>I(t,e)?0:n(a,e))),a),Y="_",k="_id",G=a=>`"${a.replace(/"/g,'""')}"`,U="SELECT",W=a=>new Set(w(a)||c(a)?a:[a]),z=(a,t)=>a?.add(t),K="TABLE",V="ALTER "+K,q="DELETE FROM",Q=U+"*FROM",X="FROM pragma_table_",Z="WHERE",aa=(a,t,s,i)=>{const r=$();return[async()=>J(r,R(await E(v(await a("SELECT name "+X+"list WHERE schema='main'AND(type='table'OR type='view')AND name IN("+ea(t)+")ORDER BY name",t),(async({name:t})=>[t,R(v(await a(U+" name,type "+X+"info(?)",[t]),(({name:a,type:t})=>[a,t])))])))),((a,t,e)=>B(r,t,J(H(r,t,$),e,((a,t,e)=>{e!=j(a,t)&&B(a,t,e)}),((a,t)=>B(a,t))))),((a,t)=>B(r,t))),async(t,e)=>((a,t)=>!c(j(j(r,a),t)))(t,e)?R(C(v(await a(Q+G(t)),(a=>{return[a[e],(t={...a},n=e,delete t[n],t)];var t,n})),(([a,t])=>!c(a)&&!_(t)))):{},async(t,s,o,l,y,w=!1)=>{const u=W();D(o??{},(a=>v(f(a??{}),(a=>z(u,a)))));const d=A(u);if(!w&&y&&p(d)&&m(r,t))return await a("DROP "+K+G(t)),void B(r,t);if(p(d)||m(r,t)){const n=j(r,t),i=W(F(n));await E([...v(d,(async s=>{T(i,s)||(await a(V+G(t)+"ADD"+G(s)),B(n,s,e))})),...!w&&l?v(A(i),(async e=>{e!=s&&(await a(V+G(t)+"DROP"+G(e)),B(n,e))})):[]])}else await a("CREATE "+K+G(t)+"("+G(s)+` PRIMARY KEY ON CONFLICT REPLACE${g(v(d,(a=>n+G(a))))});`),B(r,t,$([[s,e],...v(d,(a=>[a,e]))]));if(w)c(o)?await a(q+G(t)+Z+" 1"):await E(D(o,(async(e,n)=>{c(e)?await a(q+G(t)+Z+G(s)+"=?",[n]):p(d)||await ta(a,t,s,f(e),[n,...P(e)],i)})));else if(p(d))m(r,t)&&await a(q+G(t)+Z+" 1");else{const e=C(F(j(r,t)),(a=>a!=s)),n=[],c=[];D(o??{},((a,t)=>{h(n,t,...v(e,(t=>a?.[t]))),h(c,t)})),await ta(a,t,s,e,n,i),await a(q+G(t)+Z+G(s)+"NOT IN("+ea(c)+")",c)}},async t=>{let e;await a("BEGIN");try{e=await t()}catch(a){s?.(a)}return await a("END"),e}]},ta=async(a,t,s,r,o,c=!0)=>await a("INSERT "+(c?e:"OR REPLACE ")+"INTO"+G(t)+"("+G(s)+g(v(r,(a=>n+G(a))))+")VALUES"+u(i(`,(?${i(",?",d(r))})`,d(o)/(d(r)+1)),1)+(c?"ON CONFLICT("+G(s)+")DO UPDATE SET"+g(v(r,(a=>G(a)+"=excluded."+G(a))),n):e),v(o,(a=>a??null))),ea=a=>g(v(a,(()=>"?")),n),na=$(),sa=$(),ia=(a,t,e,n,s,i,r,o={},y=[])=>{let u,d,E,g=0,v=0,p=0;H(na,y,(()=>0)),H(sa,y,(()=>[]));const[C,m,A,T,O]=((a=1,t)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,t.getTransactionMergeableChanges,([[a],[t]])=>!_(a)||!_(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!_(a)||!_(t),t.setContent]:(a=>{throw Error("Store type not supported by this Persister")})())(r,a),N=t=>{(C&&w(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},b=async a=>(2!=g&&(g=1,v++,await I((async()=>{try{N(await t())}catch(t){i?.(t),a&&O(a)}g=0}))),D),f=()=>(d&&(s(d),d=void 0),D),R=async a=>(1!=g&&(g=2,p++,await I((async()=>{try{await e(m,a)}catch(a){i?.(a)}g=0}))),D),L=()=>(l(E,a.delListener),E=void 0,D),I=async(...a)=>(h(j(sa,y),...a),await(async()=>{if(!j(na,y)){for(B(na,y,1);!c((a=j(sa,y),u=a.shift()));)try{await u()}catch(a){i?.(a)}B(na,y,0)}var a})(),D),D={load:b,startAutoLoad:async a=>(await f().load(a),d=n((async(a,t)=>{t||a?2!=g&&(g=1,v++,N(t??a),g=0):await b()})),D),stopAutoLoad:f,isAutoLoading:()=>!c(d),save:R,startAutoSave:async()=>(await L().save(),E=a.addDidFinishTransactionListener((()=>{const a=A();T(a)&&R(a)})),D),stopAutoSave:L,isAutoSaving:()=>!c(E),schedule:I,getStore:()=>a,destroy:()=>f().stopAutoSave(),getStats:()=>({loads:v,saves:p}),...o};return S(D)},ra=(a,t,e,n,s,i,[r,o,c],l,y,w,u)=>{const[d,E,g,v]=aa(t,l,s,u);return ia(a,(async()=>await v((async()=>{return await d(),a=(await E(r,o))[Y]?.[c]??"null",JSON.parse(a,((a,t)=>""===t?void 0:t));var a}))),(async a=>await v((async()=>{var t;await d(),await g(r,o,{[Y]:{[c]:(t=a()??null,JSON.stringify(t,((a,t)=>void 0===t?"":t)))}},!0,!0)}))),e,n,s,i,{[w]:()=>y},y)},oa=(a,t,e,n,s,i,[r,o,[l,y,w]],u,d,g,v)=>{const[p,h,m,A]=aa(t,u,s,v),T=async(a,t)=>await E(x(o,(async([e,n,s,i],r)=>{t&&!I(a,r)||await m(e,n,a[r],s,i,t)}))),O=async(a,t)=>y?await m(w,k,{[Y]:a},!0,!0,t):null;return ia(a,(async()=>await A((async()=>{await p();const a=await(async()=>R(C(await E(x(r,(async([a,t],e)=>[a,await h(e,t)]))),(a=>!_(a[1])))))(),t=await(async()=>l?(await h(w,k))[Y]:{})();return _(a)&&c(t)?void 0:[a,t]}))),(async(a,t)=>await A((async()=>{if(await p(),c(t)){const[t,e]=a();await T(t),await O(e)}else await T(t[0],!0),await O(t[1],!0)}))),e,n,s,i,{[g]:()=>d},d)},ca="ColumnName",la="store",ya="json",wa=la+"TableName",ua=la+"Id"+ca,da=la+ca,Ea="autoLoadIntervalSeconds",ga="rowId"+ca,va="tableId",pa="tableName",Ca="deleteEmptyColumns",ha="deleteEmptyTable",ma={mode:ya,[Ea]:1},Aa={load:0,save:0,[pa]:t+"_values"},Ta=(a,t,e,n,s)=>{const i=$();return D(a,((a,r)=>{const o=u(P(L(t,y(a)?{[e]:a}:a)),0,M(t));c(o[0])||n(r,o[0])||(s(r,o[0]),B(i,r,o))})),i},Oa="pragma_",Na="data_version",ba="schema_version";exports.createPowerSyncPersister=(a,e,n,s,i,r=!1)=>((a,e,n,s,i,r,c,l,w,d="getDb",E)=>{let g,v,p;const[C,h,T,O]=(a=>{const e=(a=>L(ma,y(a)?{[wa]:a}:a??{}))(a),n=e[Ea];if(e.mode==ya){const a=e[wa]??t;return[1,n,[a,e[ua]??k,e[da]??la],W(a)]}const{tables:{load:s={},save:i={}}={},values:r={}}=e,o=u(P(L(Aa,r)),0,M(Aa)),c=o[2],l=W(c),w=W(c);return[0,n,[Ta(s,{[va]:null,[ga]:k},va,(a=>m(w,a)),(a=>z(l,a))),Ta(i,{[pa]:null,[ga]:k,[Ca]:0,[ha]:0},pa,((a,t)=>m(w,t)),((a,t)=>z(l,t))),o],l]})(e);return(C?ra:oa)(a,r?async(a,t)=>(r(a,t),await n(a,t)):n,(a=>{return[(t=async()=>{try{const[{d:t,s:e,c:s}]=await n(`SELECT ${Na} d,${ba} s,TOTAL_CHANGES() c FROM ${Oa}${Na} JOIN ${Oa}${ba}`);t==(g??=t)&&e==(v??=e)&&s==(p??=s)||(a(),g=t,v=e)}catch{}},e=h,t(),setInterval(t,1e3*e)),s((t=>O.has(t)?a():0))];var t,e}),(([a,t])=>{o(a),g=v=p=null,i(t)}),c,l,T,A(O),w,d,E)})(a,n,(async(a,t=[])=>e.execute(a,t).then((a=>a.rows?._array??[]))),(a=>{const t=new AbortController,n=e.onChange({rawTableNames:!0,signal:t.signal});return(async()=>{for await(const t of n)v(t.changedTables,a)})(),t}),(a=>a.abort()),s,i,1,e,"getPowerSync",r);
1
+ "use strict";const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),r=(a,t)=>a.repeat(t),i=Promise,o=clearInterval,c=a=>null==a,l=(a,t,e)=>c(a)?e?.():t(a),y=t=>a(t)==s,w=a=>Array.isArray(a),u=(a,t,e)=>a.slice(t,e),d=a=>a.length,E=async a=>i.all(a),g=(a,t="")=>a.join(t),v=(a,t)=>a.map(t),p=a=>0==d(a),h=(a,t)=>a.filter(t),C=(a,...t)=>a.push(...t),m=(a,t)=>a?.has(t)??!1,A=a=>[...a?.values()??[]],T=(a,t)=>a?.delete(t),O=Object,N=a=>O.getPrototypeOf(a),b=O.entries,f=O.keys,S=O.freeze,R=(a=[])=>O.fromEntries(a),L=(...a)=>O.assign({},...a),I=(a,t)=>t in a,D=(a,t)=>v(b(a),(([a,e])=>t(e,a))),P=a=>O.values(a),M=a=>d(f(a)),_=a=>(a=>!c(a)&&l(N(a),(a=>a==O.prototype||c(N(a))),(()=>!0)))(a)&&0==M(a),$=a=>new Map(a),F=a=>[...a?.keys()??[]],j=(a,t)=>a?.get(t),x=(a,t)=>v([...a?.entries()??[]],(([a,e])=>t(e,a))),B=(a,t,e)=>c(e)?(T(a,t),a):a?.set(t,e),H=(a,t,e,n)=>(m(a,t)||B(a,t,e()),j(a,t)),J=(a,t,e,n=B)=>(D(t,((t,n)=>e(a,n,t))),((a,t)=>{((a,t)=>{a?.forEach(t)})(a,((a,e)=>t(e)))})(a,(e=>I(t,e)?0:n(a,e))),a),Y="_",k="_id",G=a=>`"${a.replace(/"/g,'""')}"`,U="SELECT",W=a=>new Set(w(a)||c(a)?a:[a]),z=(a,t)=>a?.add(t),K="TABLE",V="ALTER "+K,q="DELETE FROM",Q=U+"*FROM",X="FROM pragma_table_",Z="WHERE",aa=(a,t,s,r)=>{const i=$();return[async()=>J(i,R(await E(v(await a("SELECT name "+X+"list WHERE schema='main'AND(type='table'OR type='view')AND name IN("+ea(t)+")ORDER BY name",t),(async({name:t})=>[t,R(v(await a(U+" name,type "+X+"info(?)",[t]),(({name:a,type:t})=>[a,t])))])))),((a,t,e)=>B(i,t,J(H(i,t,$),e,((a,t,e)=>{e!=j(a,t)&&B(a,t,e)}),((a,t)=>B(a,t))))),((a,t)=>B(i,t))),async(t,e)=>((a,t)=>!c(j(j(i,a),t)))(t,e)?R(h(v(await a(Q+G(t)),(a=>{return[a[e],(t={...a},n=e,delete t[n],t)];var t,n})),(([a,t])=>!c(a)&&!_(t)))):{},async(t,s,o,l,y,w=!1)=>{const u=W();D(o??{},(a=>v(f(a??{}),(a=>z(u,a)))));const d=A(u);if(!w&&y&&p(d)&&m(i,t))return await a("DROP "+K+G(t)),void B(i,t);if(p(d)||m(i,t)){const n=j(i,t),r=W(F(n));await E([...v(d,(async s=>{T(r,s)||(await a(V+G(t)+"ADD"+G(s)),B(n,s,e))})),...!w&&l?v(A(r),(async e=>{e!=s&&(await a(V+G(t)+"DROP"+G(e)),B(n,e))})):[]])}else await a("CREATE "+K+G(t)+"("+G(s)+` PRIMARY KEY ON CONFLICT REPLACE${g(v(d,(a=>n+G(a))))});`),B(i,t,$([[s,e],...v(d,(a=>[a,e]))]));if(w)c(o)?await a(q+G(t)+Z+" 1"):await E(D(o,(async(e,n)=>{c(e)?await a(q+G(t)+Z+G(s)+"=?",[n]):p(d)||await ta(a,t,s,f(e),[n,...P(e)],r)})));else if(p(d))m(i,t)&&await a(q+G(t)+Z+" 1");else{const e=h(F(j(i,t)),(a=>a!=s)),n=[],c=[];D(o??{},((a,t)=>{C(n,t,...v(e,(t=>a?.[t]))),C(c,t)})),await ta(a,t,s,e,n,r),await a(q+G(t)+Z+G(s)+"NOT IN("+ea(c)+")",c)}},async t=>{let e;await a("BEGIN");try{e=await t()}catch(a){s?.(a)}return await a("END"),e}]},ta=async(a,t,s,i,o,c=!0)=>await a("INSERT "+(c?e:"OR REPLACE ")+"INTO"+G(t)+"("+G(s)+g(v(i,(a=>n+G(a))))+")VALUES"+u(r(`,(?${r(",?",d(i))})`,d(o)/(d(i)+1)),1)+(c?"ON CONFLICT("+G(s)+")DO UPDATE SET"+g(v(i,(a=>G(a)+"=excluded."+G(a))),n):e),v(o,(a=>a??null))),ea=a=>g(v(a,(()=>"?")),n),na=$(),sa=$(),ra=(a,t,e,n,s,r,i,o={},y=[])=>{let u,d,E,g=0,v=0,p=0;H(na,y,(()=>0)),H(sa,y,(()=>[]));const[h,m,A,T,O]=((a=1,t)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,t.getTransactionMergeableChanges,([[a],[t]])=>!_(a)||!_(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!_(a)||!_(t),t.setContent]:(a=>{throw Error("Store type not supported by this Persister")})())(i,a),N=t=>{(h&&w(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},b=async a=>(2!=g&&(g=1,v++,await I((async()=>{try{N(await t())}catch(t){r?.(t),a&&O(a)}g=0}))),D),f=()=>(d&&(s(d),d=void 0),D),R=async a=>(1!=g&&(g=2,p++,await I((async()=>{try{await e(m,a)}catch(a){r?.(a)}g=0}))),D),L=()=>(l(E,a.delListener),E=void 0,D),I=async(...a)=>(C(j(sa,y),...a),await(async()=>{if(!j(na,y)){for(B(na,y,1);!c((a=j(sa,y),u=a.shift()));)try{await u()}catch(a){r?.(a)}B(na,y,0)}var a})(),D),D={load:b,startAutoLoad:async a=>{await f().load(a);try{d=n((async(a,t)=>{t||a?2!=g&&(g=1,v++,N(t??a),g=0):await b()}))}catch(a){r?.(a)}return D},stopAutoLoad:f,isAutoLoading:()=>!c(d),save:R,startAutoSave:async()=>(await L().save(),E=a.addDidFinishTransactionListener((()=>{const a=A();T(a)&&R(a)})),D),stopAutoSave:L,isAutoSaving:()=>!c(E),schedule:I,getStore:()=>a,destroy:()=>(j(sa,y).splice(0,void 0),f().stopAutoSave()),getStats:()=>({loads:v,saves:p}),...o};return S(D)},ia=(a,t,e,n,s,r,[i,o,c],l,y,w,u)=>{const[d,E,g,v]=aa(t,l,s,u);return ra(a,(async()=>await v((async()=>{return await d(),a=(await E(i,o))[Y]?.[c]??"null",JSON.parse(a,((a,t)=>""===t?void 0:t));var a}))),(async a=>await v((async()=>{var t;await d(),await g(i,o,{[Y]:{[c]:(t=a()??null,JSON.stringify(t,((a,t)=>void 0===t?"":t)))}},!0,!0)}))),e,n,s,r,{[w]:()=>y},y)},oa=(a,t,e,n,s,r,[i,o,[l,y,w]],u,d,g,v)=>{const[p,C,m,A]=aa(t,u,s,v),T=async(a,t)=>await E(x(o,(async([e,n,s,r],i)=>{t&&!I(a,i)||await m(e,n,a[i],s,r,t)}))),O=async(a,t)=>y?await m(w,k,{[Y]:a},!0,!0,t):null;return ra(a,(async()=>await A((async()=>{await p();const a=await(async()=>R(h(await E(x(i,(async([a,t],e)=>[a,await C(e,t)]))),(a=>!_(a[1])))))(),t=await(async()=>l?(await C(w,k))[Y]:{})();return _(a)&&c(t)?void 0:[a,t]}))),(async(a,t)=>await A((async()=>{if(await p(),c(t)){const[t,e]=a();await T(t),await O(e)}else await T(t[0],!0),await O(t[1],!0)}))),e,n,s,r,{[g]:()=>d},d)},ca="ColumnName",la="store",ya="json",wa=la+"TableName",ua=la+"Id"+ca,da=la+ca,Ea="autoLoadIntervalSeconds",ga="rowId"+ca,va="tableId",pa="tableName",ha="deleteEmptyColumns",Ca="deleteEmptyTable",ma={mode:ya,[Ea]:1},Aa={load:0,save:0,[pa]:t+"_values"},Ta=(a,t,e,n,s)=>{const r=$();return D(a,((a,i)=>{const o=u(P(L(t,y(a)?{[e]:a}:a)),0,M(t));c(o[0])||n(i,o[0])||(s(i,o[0]),B(r,i,o))})),r},Oa="pragma_",Na="data_version",ba="schema_version";exports.createPowerSyncPersister=(a,e,n,s,r,i=!1)=>((a,e,n,s,r,i,c,l,w,d="getDb",E)=>{let g,v,p;const[h,C,T,O]=(a=>{const e=(a=>L(ma,y(a)?{[wa]:a}:a??{}))(a),n=e[Ea];if(e.mode==ya){const a=e[wa]??t;return[1,n,[a,e[ua]??k,e[da]??la],W(a)]}const{tables:{load:s={},save:r={}}={},values:i={}}=e,o=u(P(L(Aa,i)),0,M(Aa)),c=o[2],l=W(c),w=W(c);return[0,n,[Ta(s,{[va]:null,[ga]:k},va,(a=>m(w,a)),(a=>z(l,a))),Ta(r,{[pa]:null,[ga]:k,[ha]:0,[Ca]:0},pa,((a,t)=>m(w,t)),((a,t)=>z(l,t))),o],l]})(e);return(h?ia:oa)(a,i?async(a,t)=>(i(a,t),await n(a,t)):n,(a=>{return[(t=async()=>{try{const[{d:t,s:e,c:s}]=await n(`SELECT ${Na} d,${ba} s,TOTAL_CHANGES() c FROM ${Oa}${Na} JOIN ${Oa}${ba}`);t==(g??=t)&&e==(v??=e)&&s==(p??=s)||(a(),g=t,v=e)}catch{}},e=C,t(),setInterval(t,1e3*e)),s((t=>O.has(t)?a():0))];var t,e}),(([a,t])=>{o(a),g=v=p=null,r(t)}),c,l,T,A(O),w,d,E)})(a,n,(async(a,t=[])=>e.execute(a,t).then((a=>a.rows?._array??[]))),(a=>{const t=new AbortController,n=e.onChange({rawTableNames:!0,signal:t.signal});return(async()=>{for await(const t of n)v(t.changedTables,a)})(),t}),(a=>a.abort()),s,r,1,e,"getPowerSync",i);
@@ -1 +1 @@
1
- "use strict";const t=clearInterval,e=t=>null==t,a=(t,a,s)=>e(t)?s?.():a(t),s=Object,r=t=>s.getPrototypeOf(t),n=s.keys,o=s.freeze,i=t=>(t=>!e(t)&&a(r(t),(t=>t==s.prototype||e(r(t))),(()=>!0)))(t)&&0==(t=>n(t).length)(t),c=t=>new Map(t),y=(t,e)=>t?.get(e),g=(t,a,s)=>{return e(s)?(r=t,n=a,r?.delete(n),t):t?.set(a,s);var r,n},l=(t,e,a,s)=>{var r,n;return r=t,n=e,r?.has(n)||g(t,e,a()),y(t,e)},h=c(),d=c(),p=JSON.parse,u=t=>t.headers.get("ETag");exports.createRemotePersister=(r,n,c,v=5,w)=>{let f;return((t,s,r,n,c,p,u,v={},w=[])=>{let f,C,A,S=0,b=0,M=0;l(h,w,(()=>0)),l(d,w,(()=>[]));const[T,L,O,m,E]=((t=1,e)=>1!=t&&e.isMergeable()?[1,e.getMergeableContent,e.getTransactionMergeableChanges,([[t],[e]])=>!i(t)||!i(e),e.setDefaultContent]:2!=t?[0,e.getContent,e.getTransactionChanges,([t,e])=>!i(t)||!i(e),e.setContent]:(t=>{throw Error("Store type not supported by this Persister")})())(u,t),P=e=>{var a;(T&&(a=e?.[0],Array.isArray(a))?1===e?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===e?.[2]?t.applyChanges:t.setContent)(e)},D=async t=>(2!=S&&(S=1,b++,await J((async()=>{try{P(await s())}catch(e){p?.(e),t&&E(t)}S=0}))),N),j=()=>(C&&(c(C),C=void 0),N),x=async t=>(1!=S&&(S=2,M++,await J((async()=>{try{await r(L,t)}catch(t){p?.(t)}S=0}))),N),I=()=>(a(A,t.delListener),A=void 0,N),J=async(...t)=>(((t,...e)=>{t.push(...e)})(y(d,w),...t),await(async()=>{if(!y(h,w)){for(g(h,w,1);!e((t=y(d,w),f=t.shift()));)try{await f()}catch(t){p?.(t)}g(h,w,0)}var t})(),N),N={load:D,startAutoLoad:async t=>(await j().load(t),C=n((async(t,e)=>{e||t?2!=S&&(S=1,b++,P(e??t),S=0):await D()})),N),stopAutoLoad:j,isAutoLoading:()=>!e(C),save:x,startAutoSave:async()=>(await I().save(),A=t.addDidFinishTransactionListener((()=>{const t=O();m(t)&&x(t)})),N),stopAutoSave:I,isAutoSaving:()=>!e(A),schedule:J,getStore:()=>t,destroy:()=>j().stopAutoSave(),getStats:()=>({loads:b,saves:M}),...v};return o(N)})(r,(async()=>{const t=await fetch(n);return f=u(t),p(await t.text())}),(async t=>{return await fetch(c,{method:"POST",headers:{"Content-Type":"application/json"},body:(e=t(),JSON.stringify(e,((t,e)=>e instanceof Map?s.fromEntries([...e]):e)))});var e}),(t=>setInterval((async()=>{const a=await fetch(n,{method:"HEAD"}),s=u(a);e(f)||e(s)||s==f||(f=s,t())}),1e3*v)),(e=>t(e)),w,1,{getUrls:()=>[n,c]})};
1
+ "use strict";const t=clearInterval,e=t=>null==t,a=(t,a,s)=>e(t)?s?.():a(t),s=Object,r=t=>s.getPrototypeOf(t),n=s.keys,o=s.freeze,i=t=>(t=>!e(t)&&a(r(t),(t=>t==s.prototype||e(r(t))),(()=>!0)))(t)&&0==(t=>n(t).length)(t),c=JSON.parse,y=t=>new Map(t),l=(t,e)=>t?.get(e),g=(t,a,s)=>{return e(s)?(r=t,n=a,r?.delete(n),t):t?.set(a,s);var r,n},h=(t,e,a,s)=>{var r,n;return r=t,n=e,r?.has(n)||g(t,e,a()),l(t,e)},d=y(),p=y(),u=t=>t.headers.get("ETag");exports.createRemotePersister=(r,n,y,v=5,w)=>{let f;return((t,s,r,n,c,y,u,v={},w=[])=>{let f,C,A,S=0,b=0,M=0;h(d,w,(()=>0)),h(p,w,(()=>[]));const[T,L,O,m,E]=((t=1,e)=>1!=t&&e.isMergeable()?[1,e.getMergeableContent,e.getTransactionMergeableChanges,([[t],[e]])=>!i(t)||!i(e),e.setDefaultContent]:2!=t?[0,e.getContent,e.getTransactionChanges,([t,e])=>!i(t)||!i(e),e.setContent]:(t=>{throw Error("Store type not supported by this Persister")})())(u,t),P=e=>{var a;(T&&(a=e?.[0],Array.isArray(a))?1===e?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===e?.[2]?t.applyChanges:t.setContent)(e)},D=async t=>(2!=S&&(S=1,b++,await J((async()=>{try{P(await s())}catch(e){y?.(e),t&&E(t)}S=0}))),N),j=()=>(C&&(c(C),C=void 0),N),x=async t=>(1!=S&&(S=2,M++,await J((async()=>{try{await r(L,t)}catch(t){y?.(t)}S=0}))),N),I=()=>(a(A,t.delListener),A=void 0,N),J=async(...t)=>(((t,...e)=>{t.push(...e)})(l(p,w),...t),await(async()=>{if(!l(d,w)){for(g(d,w,1);!e((t=l(p,w),f=t.shift()));)try{await f()}catch(t){y?.(t)}g(d,w,0)}var t})(),N),N={load:D,startAutoLoad:async t=>{await j().load(t);try{C=n((async(t,e)=>{e||t?2!=S&&(S=1,b++,P(e??t),S=0):await D()}))}catch(t){y?.(t)}return N},stopAutoLoad:j,isAutoLoading:()=>!e(C),save:x,startAutoSave:async()=>(await I().save(),A=t.addDidFinishTransactionListener((()=>{const t=O();m(t)&&x(t)})),N),stopAutoSave:I,isAutoSaving:()=>!e(A),schedule:J,getStore:()=>t,destroy:()=>(l(p,w).splice(0,void 0),j().stopAutoSave()),getStats:()=>({loads:b,saves:M}),...v};return o(N)})(r,(async()=>{const t=await fetch(n);return f=u(t),c(await t.text())}),(async t=>{return await fetch(y,{method:"POST",headers:{"Content-Type":"application/json"},body:(e=t(),JSON.stringify(e,((t,e)=>e instanceof Map?s.fromEntries([...e]):e)))});var e}),(t=>setInterval((async()=>{const a=await fetch(n,{method:"HEAD"}),s=u(a);e(f)||e(s)||s==f||(f=s,t())}),1e3*v)),(e=>t(e)),w,1,{getUrls:()=>[n,y]})};
@@ -1 +1 @@
1
- "use strict";const t=clearInterval,e=t=>null==t,a=(t,a,s)=>e(t)?s?.():a(t),s=Object,r=t=>s.getPrototypeOf(t),n=s.keys,o=s.freeze,i=t=>(t=>!e(t)&&a(r(t),(t=>t==s.prototype||e(r(t))),(()=>!0)))(t)&&0==(t=>n(t).length)(t),c=t=>new Map(t),y=(t,e)=>t?.get(e),g=(t,a,s)=>{return e(s)?(r=t,n=a,r?.delete(n),t):t?.set(a,s);var r,n},l=(t,e,a,s)=>{var r,n;return r=t,n=e,r?.has(n)||g(t,e,a()),y(t,e)},h=c(),d=c(),p=JSON.parse,u=t=>t.headers.get("ETag");exports.createRemotePersister=(r,n,c,v=5,w)=>{let f;return((t,s,r,n,c,p,u,v={},w=[])=>{let f,C,A,S=0,b=0,M=0;l(h,w,(()=>0)),l(d,w,(()=>[]));const[T,L,O,m,E]=((t=1,e)=>1!=t&&e.isMergeable()?[1,e.getMergeableContent,e.getTransactionMergeableChanges,([[t],[e]])=>!i(t)||!i(e),e.setDefaultContent]:2!=t?[0,e.getContent,e.getTransactionChanges,([t,e])=>!i(t)||!i(e),e.setContent]:(t=>{throw Error("Store type not supported by this Persister")})())(u,t),P=e=>{var a;(T&&(a=e?.[0],Array.isArray(a))?1===e?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===e?.[2]?t.applyChanges:t.setContent)(e)},D=async t=>(2!=S&&(S=1,b++,await J((async()=>{try{P(await s())}catch(e){p?.(e),t&&E(t)}S=0}))),N),j=()=>(C&&(c(C),C=void 0),N),x=async t=>(1!=S&&(S=2,M++,await J((async()=>{try{await r(L,t)}catch(t){p?.(t)}S=0}))),N),I=()=>(a(A,t.delListener),A=void 0,N),J=async(...t)=>(((t,...e)=>{t.push(...e)})(y(d,w),...t),await(async()=>{if(!y(h,w)){for(g(h,w,1);!e((t=y(d,w),f=t.shift()));)try{await f()}catch(t){p?.(t)}g(h,w,0)}var t})(),N),N={load:D,startAutoLoad:async t=>(await j().load(t),C=n((async(t,e)=>{e||t?2!=S&&(S=1,b++,P(e??t),S=0):await D()})),N),stopAutoLoad:j,isAutoLoading:()=>!e(C),save:x,startAutoSave:async()=>(await I().save(),A=t.addDidFinishTransactionListener((()=>{const t=O();m(t)&&x(t)})),N),stopAutoSave:I,isAutoSaving:()=>!e(A),schedule:J,getStore:()=>t,destroy:()=>j().stopAutoSave(),getStats:()=>({loads:b,saves:M}),...v};return o(N)})(r,(async()=>{const t=await fetch(n);return f=u(t),p(await t.text())}),(async t=>{return await fetch(c,{method:"POST",headers:{"Content-Type":"application/json"},body:(e=t(),JSON.stringify(e,((t,e)=>e instanceof Map?s.fromEntries([...e]):e)))});var e}),(t=>setInterval((async()=>{const a=await fetch(n,{method:"HEAD"}),s=u(a);e(f)||e(s)||s==f||(f=s,t())}),1e3*v)),(e=>t(e)),w,1,{getUrls:()=>[n,c]})};
1
+ "use strict";const t=clearInterval,e=t=>null==t,a=(t,a,s)=>e(t)?s?.():a(t),s=Object,r=t=>s.getPrototypeOf(t),n=s.keys,o=s.freeze,i=t=>(t=>!e(t)&&a(r(t),(t=>t==s.prototype||e(r(t))),(()=>!0)))(t)&&0==(t=>n(t).length)(t),c=JSON.parse,y=t=>new Map(t),l=(t,e)=>t?.get(e),g=(t,a,s)=>{return e(s)?(r=t,n=a,r?.delete(n),t):t?.set(a,s);var r,n},h=(t,e,a,s)=>{var r,n;return r=t,n=e,r?.has(n)||g(t,e,a()),l(t,e)},d=y(),p=y(),u=t=>t.headers.get("ETag");exports.createRemotePersister=(r,n,y,v=5,w)=>{let f;return((t,s,r,n,c,y,u,v={},w=[])=>{let f,C,A,S=0,b=0,M=0;h(d,w,(()=>0)),h(p,w,(()=>[]));const[T,L,O,m,E]=((t=1,e)=>1!=t&&e.isMergeable()?[1,e.getMergeableContent,e.getTransactionMergeableChanges,([[t],[e]])=>!i(t)||!i(e),e.setDefaultContent]:2!=t?[0,e.getContent,e.getTransactionChanges,([t,e])=>!i(t)||!i(e),e.setContent]:(t=>{throw Error("Store type not supported by this Persister")})())(u,t),P=e=>{var a;(T&&(a=e?.[0],Array.isArray(a))?1===e?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===e?.[2]?t.applyChanges:t.setContent)(e)},D=async t=>(2!=S&&(S=1,b++,await J((async()=>{try{P(await s())}catch(e){y?.(e),t&&E(t)}S=0}))),N),j=()=>(C&&(c(C),C=void 0),N),x=async t=>(1!=S&&(S=2,M++,await J((async()=>{try{await r(L,t)}catch(t){y?.(t)}S=0}))),N),I=()=>(a(A,t.delListener),A=void 0,N),J=async(...t)=>(((t,...e)=>{t.push(...e)})(l(p,w),...t),await(async()=>{if(!l(d,w)){for(g(d,w,1);!e((t=l(p,w),f=t.shift()));)try{await f()}catch(t){y?.(t)}g(d,w,0)}var t})(),N),N={load:D,startAutoLoad:async t=>{await j().load(t);try{C=n((async(t,e)=>{e||t?2!=S&&(S=1,b++,P(e??t),S=0):await D()}))}catch(t){y?.(t)}return N},stopAutoLoad:j,isAutoLoading:()=>!e(C),save:x,startAutoSave:async()=>(await I().save(),A=t.addDidFinishTransactionListener((()=>{const t=O();m(t)&&x(t)})),N),stopAutoSave:I,isAutoSaving:()=>!e(A),schedule:J,getStore:()=>t,destroy:()=>(l(p,w).splice(0,void 0),j().stopAutoSave()),getStats:()=>({loads:b,saves:M}),...v};return o(N)})(r,(async()=>{const t=await fetch(n);return f=u(t),c(await t.text())}),(async t=>{return await fetch(y,{method:"POST",headers:{"Content-Type":"application/json"},body:(e=t(),JSON.stringify(e,((t,e)=>e instanceof Map?s.fromEntries([...e]):e)))});var e}),(t=>setInterval((async()=>{const a=await fetch(n,{method:"HEAD"}),s=u(a);e(f)||e(s)||s==f||(f=s,t())}),1e3*v)),(e=>t(e)),w,1,{getUrls:()=>[n,y]})};
@@ -1 +1 @@
1
- "use strict";const a=a=>typeof a,t="tinybase",e="",s=",",n=a(e),i=(a,t)=>a.repeat(t),r=Promise,o=clearInterval,c=a=>null==a,l=(a,t,e)=>c(a)?e?.():t(a),y=t=>a(t)==n,w=a=>Array.isArray(a),u=(a,t,e)=>a.slice(t,e),d=a=>a.length,E=async a=>r.all(a),p=(a,t="")=>a.join(t),v=(a,t)=>a.map(t),g=a=>0==d(a),m=(a,t)=>a.filter(t),h=(a,...t)=>a.push(...t),C=(a,t)=>a?.has(t)??!1,A=a=>[...a?.values()??[]],O=(a,t)=>a?.delete(t),T=Object,N=a=>T.getPrototypeOf(a),R=T.entries,S=T.keys,b=T.freeze,f=(a=[])=>T.fromEntries(a),L=(...a)=>T.assign({},...a),I=(a,t)=>t in a,D=(a,t)=>v(R(a),(([a,e])=>t(e,a))),_=a=>T.values(a),M=a=>d(S(a)),P=a=>(a=>!c(a)&&l(N(a),(a=>a==T.prototype||c(N(a))),(()=>!0)))(a)&&0==M(a),$=a=>new Map(a),F=a=>[...a?.keys()??[]],j=(a,t)=>a?.get(t),k=(a,t)=>v([...a?.entries()??[]],(([a,e])=>t(e,a))),q=(a,t,e)=>c(e)?(O(a,t),a):a?.set(t,e),x=(a,t,e,s)=>(C(a,t)||q(a,t,e()),j(a,t)),B=(a,t,e,s=q)=>(D(t,((t,s)=>e(a,s,t))),((a,t)=>{((a,t)=>{a?.forEach(t)})(a,((a,e)=>t(e)))})(a,(e=>I(t,e)?0:s(a,e))),a),H="_",J="_id",W=a=>`"${a.replace(/"/g,'""')}"`,Y="SELECT",G=a=>new Set(w(a)||c(a)?a:[a]),U=(a,t)=>a?.add(t),V="TABLE",z="ALTER "+V,K="DELETE FROM",Q=Y+"*FROM",X="FROM pragma_table_",Z="WHERE",aa=(a,t,n,i)=>{const r=$();return[async()=>B(r,f(await E(v(await a("SELECT name "+X+"list WHERE schema='main'AND(type='table'OR type='view')AND name IN("+ea(t)+")ORDER BY name",t),(async({name:t})=>[t,f(v(await a(Y+" name,type "+X+"info(?)",[t]),(({name:a,type:t})=>[a,t])))])))),((a,t,e)=>q(r,t,B(x(r,t,$),e,((a,t,e)=>{e!=j(a,t)&&q(a,t,e)}),((a,t)=>q(a,t))))),((a,t)=>q(r,t))),async(t,e)=>((a,t)=>!c(j(j(r,a),t)))(t,e)?f(m(v(await a(Q+W(t)),(a=>{return[a[e],(t={...a},s=e,delete t[s],t)];var t,s})),(([a,t])=>!c(a)&&!P(t)))):{},async(t,n,o,l,y,w=!1)=>{const u=G();D(o??{},(a=>v(S(a??{}),(a=>U(u,a)))));const d=A(u);if(!w&&y&&g(d)&&C(r,t))return await a("DROP "+V+W(t)),void q(r,t);if(g(d)||C(r,t)){const s=j(r,t),i=G(F(s));await E([...v(d,(async n=>{O(i,n)||(await a(z+W(t)+"ADD"+W(n)),q(s,n,e))})),...!w&&l?v(A(i),(async e=>{e!=n&&(await a(z+W(t)+"DROP"+W(e)),q(s,e))})):[]])}else await a("CREATE "+V+W(t)+"("+W(n)+` PRIMARY KEY ON CONFLICT REPLACE${p(v(d,(a=>s+W(a))))});`),q(r,t,$([[n,e],...v(d,(a=>[a,e]))]));if(w)c(o)?await a(K+W(t)+Z+" 1"):await E(D(o,(async(e,s)=>{c(e)?await a(K+W(t)+Z+W(n)+"=?",[s]):g(d)||await ta(a,t,n,S(e),[s,..._(e)],i)})));else if(g(d))C(r,t)&&await a(K+W(t)+Z+" 1");else{const e=m(F(j(r,t)),(a=>a!=n)),s=[],c=[];D(o??{},((a,t)=>{h(s,t,...v(e,(t=>a?.[t]))),h(c,t)})),await ta(a,t,n,e,s,i),await a(K+W(t)+Z+W(n)+"NOT IN("+ea(c)+")",c)}},async t=>{let e;await a("BEGIN");try{e=await t()}catch(a){n?.(a)}return await a("END"),e}]},ta=async(a,t,n,r,o,c=!0)=>await a("INSERT "+(c?e:"OR REPLACE ")+"INTO"+W(t)+"("+W(n)+p(v(r,(a=>s+W(a))))+")VALUES"+u(i(`,(?${i(",?",d(r))})`,d(o)/(d(r)+1)),1)+(c?"ON CONFLICT("+W(n)+")DO UPDATE SET"+p(v(r,(a=>W(a)+"=excluded."+W(a))),s):e),v(o,(a=>a??null))),ea=a=>p(v(a,(()=>"?")),s),sa=$(),na=$(),ia=(a,t,e,s,n,i,r,o={},y=[])=>{let u,d,E,p=0,v=0,g=0;x(sa,y,(()=>0)),x(na,y,(()=>[]));const[m,C,A,O,T]=((a=1,t)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,t.getTransactionMergeableChanges,([[a],[t]])=>!P(a)||!P(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!P(a)||!P(t),t.setContent]:(a=>{throw Error("Store type not supported by this Persister")})())(r,a),N=t=>{(m&&w(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},R=async a=>(2!=p&&(p=1,v++,await I((async()=>{try{N(await t())}catch(t){i?.(t),a&&T(a)}p=0}))),D),S=()=>(d&&(n(d),d=void 0),D),f=async a=>(1!=p&&(p=2,g++,await I((async()=>{try{await e(C,a)}catch(a){i?.(a)}p=0}))),D),L=()=>(l(E,a.delListener),E=void 0,D),I=async(...a)=>(h(j(na,y),...a),await(async()=>{if(!j(sa,y)){for(q(sa,y,1);!c((a=j(na,y),u=a.shift()));)try{await u()}catch(a){i?.(a)}q(sa,y,0)}var a})(),D),D={load:R,startAutoLoad:async a=>(await S().load(a),d=s((async(a,t)=>{t||a?2!=p&&(p=1,v++,N(t??a),p=0):await R()})),D),stopAutoLoad:S,isAutoLoading:()=>!c(d),save:f,startAutoSave:async()=>(await L().save(),E=a.addDidFinishTransactionListener((()=>{const a=A();O(a)&&f(a)})),D),stopAutoSave:L,isAutoSaving:()=>!c(E),schedule:I,getStore:()=>a,destroy:()=>S().stopAutoSave(),getStats:()=>({loads:v,saves:g}),...o};return b(D)},ra=(a,t,e,s,n,i,[r,o,c],l,y,w,u)=>{const[d,E,p,v]=aa(t,l,n,u);return ia(a,(async()=>await v((async()=>{return await d(),a=(await E(r,o))[H]?.[c]??"null",JSON.parse(a,((a,t)=>""===t?void 0:t));var a}))),(async a=>await v((async()=>{var t;await d(),await p(r,o,{[H]:{[c]:(t=a()??null,JSON.stringify(t,((a,t)=>void 0===t?"":t)))}},!0,!0)}))),e,s,n,i,{[w]:()=>y},y)},oa=(a,t,e,s,n,i,[r,o,[l,y,w]],u,d,p,v)=>{const[g,h,C,A]=aa(t,u,n,v),O=async(a,t)=>await E(k(o,(async([e,s,n,i],r)=>{t&&!I(a,r)||await C(e,s,a[r],n,i,t)}))),T=async(a,t)=>y?await C(w,J,{[H]:a},!0,!0,t):null;return ia(a,(async()=>await A((async()=>{await g();const a=await(async()=>f(m(await E(k(r,(async([a,t],e)=>[a,await h(e,t)]))),(a=>!P(a[1])))))(),t=await(async()=>l?(await h(w,J))[H]:{})();return P(a)&&c(t)?void 0:[a,t]}))),(async(a,t)=>await A((async()=>{if(await g(),c(t)){const[t,e]=a();await O(t),await T(e)}else await O(t[0],!0),await T(t[1],!0)}))),e,s,n,i,{[p]:()=>d},d)},ca="ColumnName",la="store",ya="json",wa=la+"TableName",ua=la+"Id"+ca,da=la+ca,Ea="autoLoadIntervalSeconds",pa="rowId"+ca,va="tableId",ga="tableName",ma="deleteEmptyColumns",ha="deleteEmptyTable",Ca={mode:ya,[Ea]:1},Aa={load:0,save:0,[ga]:t+"_values"},Oa=(a,t,e,s,n)=>{const i=$();return D(a,((a,r)=>{const o=u(_(L(t,y(a)?{[e]:a}:a)),0,M(t));c(o[0])||s(r,o[0])||(n(r,o[0]),q(i,r,o))})),i},Ta="pragma_",Na="data_version",Ra="schema_version";exports.createSqliteWasmPersister=(a,e,s,n,i,r)=>((a,e,s,n,i,r,c,l,w,d="getDb",E)=>{let p,v,g;const[m,h,O,T]=(a=>{const e=(a=>L(Ca,y(a)?{[wa]:a}:a??{}))(a),s=e[Ea];if(e.mode==ya){const a=e[wa]??t;return[1,s,[a,e[ua]??J,e[da]??la],G(a)]}const{tables:{load:n={},save:i={}}={},values:r={}}=e,o=u(_(L(Aa,r)),0,M(Aa)),c=o[2],l=G(c),w=G(c);return[0,s,[Oa(n,{[va]:null,[pa]:J},va,(a=>C(w,a)),(a=>U(l,a))),Oa(i,{[ga]:null,[pa]:J,[ma]:0,[ha]:0},ga,((a,t)=>C(w,t)),((a,t)=>U(l,t))),o],l]})(e);return(m?ra:oa)(a,r?async(a,t)=>(r(a,t),await s(a,t)):s,(a=>{return[(t=async()=>{try{const[{d:t,s:e,c:n}]=await s(`SELECT ${Na} d,${Ra} s,TOTAL_CHANGES() c FROM ${Ta}${Na} JOIN ${Ta}${Ra}`);t==(p??=t)&&e==(v??=e)&&n==(g??=n)||(a(),p=t,v=e)}catch{}},e=h,t(),setInterval(t,1e3*e)),n((t=>T.has(t)?a():0))];var t,e}),(([a,t])=>{o(a),p=v=g=null,i(t)}),c,l,O,A(T),w,d,E)})(a,n,(async(a,t=[])=>s.exec(a,{bind:t,rowMode:"object",returnValue:"resultRows"}).map((a=>({...a})))),(a=>e.capi.sqlite3_update_hook(s,((t,e,s,n)=>a(n)),0)),(()=>e.capi.sqlite3_update_hook(s,(()=>0),0)),i,r,3,s);
1
+ "use strict";const a=a=>typeof a,t="tinybase",e="",s=",",n=a(e),i=(a,t)=>a.repeat(t),r=Promise,o=clearInterval,c=a=>null==a,l=(a,t,e)=>c(a)?e?.():t(a),y=t=>a(t)==n,w=a=>Array.isArray(a),u=(a,t,e)=>a.slice(t,e),d=a=>a.length,p=async a=>r.all(a),E=(a,t="")=>a.join(t),v=(a,t)=>a.map(t),g=a=>0==d(a),m=(a,t)=>a.filter(t),h=(a,...t)=>a.push(...t),C=(a,t)=>a?.has(t)??!1,A=a=>[...a?.values()??[]],O=(a,t)=>a?.delete(t),T=Object,N=a=>T.getPrototypeOf(a),R=T.entries,S=T.keys,b=T.freeze,f=(a=[])=>T.fromEntries(a),L=(...a)=>T.assign({},...a),I=(a,t)=>t in a,D=(a,t)=>v(R(a),(([a,e])=>t(e,a))),_=a=>T.values(a),M=a=>d(S(a)),P=a=>(a=>!c(a)&&l(N(a),(a=>a==T.prototype||c(N(a))),(()=>!0)))(a)&&0==M(a),$=a=>new Map(a),F=a=>[...a?.keys()??[]],j=(a,t)=>a?.get(t),k=(a,t)=>v([...a?.entries()??[]],(([a,e])=>t(e,a))),q=(a,t,e)=>c(e)?(O(a,t),a):a?.set(t,e),x=(a,t,e,s)=>(C(a,t)||q(a,t,e()),j(a,t)),B=(a,t,e,s=q)=>(D(t,((t,s)=>e(a,s,t))),((a,t)=>{((a,t)=>{a?.forEach(t)})(a,((a,e)=>t(e)))})(a,(e=>I(t,e)?0:s(a,e))),a),H="_",J="_id",W=a=>`"${a.replace(/"/g,'""')}"`,Y="SELECT",G=a=>new Set(w(a)||c(a)?a:[a]),U=(a,t)=>a?.add(t),V="TABLE",z="ALTER "+V,K="DELETE FROM",Q=Y+"*FROM",X="FROM pragma_table_",Z="WHERE",aa=(a,t,n,i)=>{const r=$();return[async()=>B(r,f(await p(v(await a("SELECT name "+X+"list WHERE schema='main'AND(type='table'OR type='view')AND name IN("+ea(t)+")ORDER BY name",t),(async({name:t})=>[t,f(v(await a(Y+" name,type "+X+"info(?)",[t]),(({name:a,type:t})=>[a,t])))])))),((a,t,e)=>q(r,t,B(x(r,t,$),e,((a,t,e)=>{e!=j(a,t)&&q(a,t,e)}),((a,t)=>q(a,t))))),((a,t)=>q(r,t))),async(t,e)=>((a,t)=>!c(j(j(r,a),t)))(t,e)?f(m(v(await a(Q+W(t)),(a=>{return[a[e],(t={...a},s=e,delete t[s],t)];var t,s})),(([a,t])=>!c(a)&&!P(t)))):{},async(t,n,o,l,y,w=!1)=>{const u=G();D(o??{},(a=>v(S(a??{}),(a=>U(u,a)))));const d=A(u);if(!w&&y&&g(d)&&C(r,t))return await a("DROP "+V+W(t)),void q(r,t);if(g(d)||C(r,t)){const s=j(r,t),i=G(F(s));await p([...v(d,(async n=>{O(i,n)||(await a(z+W(t)+"ADD"+W(n)),q(s,n,e))})),...!w&&l?v(A(i),(async e=>{e!=n&&(await a(z+W(t)+"DROP"+W(e)),q(s,e))})):[]])}else await a("CREATE "+V+W(t)+"("+W(n)+` PRIMARY KEY ON CONFLICT REPLACE${E(v(d,(a=>s+W(a))))});`),q(r,t,$([[n,e],...v(d,(a=>[a,e]))]));if(w)c(o)?await a(K+W(t)+Z+" 1"):await p(D(o,(async(e,s)=>{c(e)?await a(K+W(t)+Z+W(n)+"=?",[s]):g(d)||await ta(a,t,n,S(e),[s,..._(e)],i)})));else if(g(d))C(r,t)&&await a(K+W(t)+Z+" 1");else{const e=m(F(j(r,t)),(a=>a!=n)),s=[],c=[];D(o??{},((a,t)=>{h(s,t,...v(e,(t=>a?.[t]))),h(c,t)})),await ta(a,t,n,e,s,i),await a(K+W(t)+Z+W(n)+"NOT IN("+ea(c)+")",c)}},async t=>{let e;await a("BEGIN");try{e=await t()}catch(a){n?.(a)}return await a("END"),e}]},ta=async(a,t,n,r,o,c=!0)=>await a("INSERT "+(c?e:"OR REPLACE ")+"INTO"+W(t)+"("+W(n)+E(v(r,(a=>s+W(a))))+")VALUES"+u(i(`,(?${i(",?",d(r))})`,d(o)/(d(r)+1)),1)+(c?"ON CONFLICT("+W(n)+")DO UPDATE SET"+E(v(r,(a=>W(a)+"=excluded."+W(a))),s):e),v(o,(a=>a??null))),ea=a=>E(v(a,(()=>"?")),s),sa=$(),na=$(),ia=(a,t,e,s,n,i,r,o={},y=[])=>{let u,d,p,E=0,v=0,g=0;x(sa,y,(()=>0)),x(na,y,(()=>[]));const[m,C,A,O,T]=((a=1,t)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,t.getTransactionMergeableChanges,([[a],[t]])=>!P(a)||!P(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!P(a)||!P(t),t.setContent]:(a=>{throw Error("Store type not supported by this Persister")})())(r,a),N=t=>{(m&&w(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},R=async a=>(2!=E&&(E=1,v++,await I((async()=>{try{N(await t())}catch(t){i?.(t),a&&T(a)}E=0}))),D),S=()=>(d&&(n(d),d=void 0),D),f=async a=>(1!=E&&(E=2,g++,await I((async()=>{try{await e(C,a)}catch(a){i?.(a)}E=0}))),D),L=()=>(l(p,a.delListener),p=void 0,D),I=async(...a)=>(h(j(na,y),...a),await(async()=>{if(!j(sa,y)){for(q(sa,y,1);!c((a=j(na,y),u=a.shift()));)try{await u()}catch(a){i?.(a)}q(sa,y,0)}var a})(),D),D={load:R,startAutoLoad:async a=>{await S().load(a);try{d=s((async(a,t)=>{t||a?2!=E&&(E=1,v++,N(t??a),E=0):await R()}))}catch(a){i?.(a)}return D},stopAutoLoad:S,isAutoLoading:()=>!c(d),save:f,startAutoSave:async()=>(await L().save(),p=a.addDidFinishTransactionListener((()=>{const a=A();O(a)&&f(a)})),D),stopAutoSave:L,isAutoSaving:()=>!c(p),schedule:I,getStore:()=>a,destroy:()=>(j(na,y).splice(0,void 0),S().stopAutoSave()),getStats:()=>({loads:v,saves:g}),...o};return b(D)},ra=(a,t,e,s,n,i,[r,o,c],l,y,w,u)=>{const[d,p,E,v]=aa(t,l,n,u);return ia(a,(async()=>await v((async()=>{return await d(),a=(await p(r,o))[H]?.[c]??"null",JSON.parse(a,((a,t)=>""===t?void 0:t));var a}))),(async a=>await v((async()=>{var t;await d(),await E(r,o,{[H]:{[c]:(t=a()??null,JSON.stringify(t,((a,t)=>void 0===t?"":t)))}},!0,!0)}))),e,s,n,i,{[w]:()=>y},y)},oa=(a,t,e,s,n,i,[r,o,[l,y,w]],u,d,E,v)=>{const[g,h,C,A]=aa(t,u,n,v),O=async(a,t)=>await p(k(o,(async([e,s,n,i],r)=>{t&&!I(a,r)||await C(e,s,a[r],n,i,t)}))),T=async(a,t)=>y?await C(w,J,{[H]:a},!0,!0,t):null;return ia(a,(async()=>await A((async()=>{await g();const a=await(async()=>f(m(await p(k(r,(async([a,t],e)=>[a,await h(e,t)]))),(a=>!P(a[1])))))(),t=await(async()=>l?(await h(w,J))[H]:{})();return P(a)&&c(t)?void 0:[a,t]}))),(async(a,t)=>await A((async()=>{if(await g(),c(t)){const[t,e]=a();await O(t),await T(e)}else await O(t[0],!0),await T(t[1],!0)}))),e,s,n,i,{[E]:()=>d},d)},ca="ColumnName",la="store",ya="json",wa=la+"TableName",ua=la+"Id"+ca,da=la+ca,pa="autoLoadIntervalSeconds",Ea="rowId"+ca,va="tableId",ga="tableName",ma="deleteEmptyColumns",ha="deleteEmptyTable",Ca={mode:ya,[pa]:1},Aa={load:0,save:0,[ga]:t+"_values"},Oa=(a,t,e,s,n)=>{const i=$();return D(a,((a,r)=>{const o=u(_(L(t,y(a)?{[e]:a}:a)),0,M(t));c(o[0])||s(r,o[0])||(n(r,o[0]),q(i,r,o))})),i},Ta="pragma_",Na="data_version",Ra="schema_version";exports.createSqliteWasmPersister=(a,e,s,n,i,r)=>((a,e,s,n,i,r,c,l,w,d="getDb",p)=>{let E,v,g;const[m,h,O,T]=(a=>{const e=(a=>L(Ca,y(a)?{[wa]:a}:a??{}))(a),s=e[pa];if(e.mode==ya){const a=e[wa]??t;return[1,s,[a,e[ua]??J,e[da]??la],G(a)]}const{tables:{load:n={},save:i={}}={},values:r={}}=e,o=u(_(L(Aa,r)),0,M(Aa)),c=o[2],l=G(c),w=G(c);return[0,s,[Oa(n,{[va]:null,[Ea]:J},va,(a=>C(w,a)),(a=>U(l,a))),Oa(i,{[ga]:null,[Ea]:J,[ma]:0,[ha]:0},ga,((a,t)=>C(w,t)),((a,t)=>U(l,t))),o],l]})(e);return(m?ra:oa)(a,r?async(a,t)=>(r(a,t),await s(a,t)):s,(a=>{return[(t=async()=>{try{const[{d:t,s:e,c:n}]=await s(`SELECT ${Na} d,${Ra} s,TOTAL_CHANGES() c FROM ${Ta}${Na} JOIN ${Ta}${Ra}`);t==(E??=t)&&e==(v??=e)&&n==(g??=n)||(a(),E=t,v=e)}catch{}},e=h,t(),setInterval(t,1e3*e)),n((t=>T.has(t)?a():0))];var t,e}),(([a,t])=>{o(a),E=v=g=null,i(t)}),c,l,O,A(T),w,d,p)})(a,n,(async(a,t=[])=>s.exec(a,{bind:t,rowMode:"object",returnValue:"resultRows"}).map((a=>({...a})))),(a=>e.capi.sqlite3_update_hook(s,((t,e,s,n)=>a(n)),0)),(()=>e.capi.sqlite3_update_hook(s,(()=>0),0)),i,r,3,s);
@@ -1 +1 @@
1
- "use strict";const a=a=>typeof a,t="tinybase",e="",s=",",n=a(e),i=(a,t)=>a.repeat(t),r=Promise,o=clearInterval,c=a=>null==a,l=(a,t,e)=>c(a)?e?.():t(a),y=t=>a(t)==n,w=a=>Array.isArray(a),u=(a,t,e)=>a.slice(t,e),d=a=>a.length,E=async a=>r.all(a),p=(a,t="")=>a.join(t),v=(a,t)=>a.map(t),g=a=>0==d(a),m=(a,t)=>a.filter(t),h=(a,...t)=>a.push(...t),C=(a,t)=>a?.has(t)??!1,A=a=>[...a?.values()??[]],O=(a,t)=>a?.delete(t),T=Object,N=a=>T.getPrototypeOf(a),R=T.entries,S=T.keys,b=T.freeze,f=(a=[])=>T.fromEntries(a),L=(...a)=>T.assign({},...a),I=(a,t)=>t in a,D=(a,t)=>v(R(a),(([a,e])=>t(e,a))),_=a=>T.values(a),M=a=>d(S(a)),P=a=>(a=>!c(a)&&l(N(a),(a=>a==T.prototype||c(N(a))),(()=>!0)))(a)&&0==M(a),$=a=>new Map(a),F=a=>[...a?.keys()??[]],j=(a,t)=>a?.get(t),k=(a,t)=>v([...a?.entries()??[]],(([a,e])=>t(e,a))),q=(a,t,e)=>c(e)?(O(a,t),a):a?.set(t,e),x=(a,t,e,s)=>(C(a,t)||q(a,t,e()),j(a,t)),B=(a,t,e,s=q)=>(D(t,((t,s)=>e(a,s,t))),((a,t)=>{((a,t)=>{a?.forEach(t)})(a,((a,e)=>t(e)))})(a,(e=>I(t,e)?0:s(a,e))),a),H="_",J="_id",W=a=>`"${a.replace(/"/g,'""')}"`,Y="SELECT",G=a=>new Set(w(a)||c(a)?a:[a]),U=(a,t)=>a?.add(t),V="TABLE",z="ALTER "+V,K="DELETE FROM",Q=Y+"*FROM",X="FROM pragma_table_",Z="WHERE",aa=(a,t,n,i)=>{const r=$();return[async()=>B(r,f(await E(v(await a("SELECT name "+X+"list WHERE schema='main'AND(type='table'OR type='view')AND name IN("+ea(t)+")ORDER BY name",t),(async({name:t})=>[t,f(v(await a(Y+" name,type "+X+"info(?)",[t]),(({name:a,type:t})=>[a,t])))])))),((a,t,e)=>q(r,t,B(x(r,t,$),e,((a,t,e)=>{e!=j(a,t)&&q(a,t,e)}),((a,t)=>q(a,t))))),((a,t)=>q(r,t))),async(t,e)=>((a,t)=>!c(j(j(r,a),t)))(t,e)?f(m(v(await a(Q+W(t)),(a=>{return[a[e],(t={...a},s=e,delete t[s],t)];var t,s})),(([a,t])=>!c(a)&&!P(t)))):{},async(t,n,o,l,y,w=!1)=>{const u=G();D(o??{},(a=>v(S(a??{}),(a=>U(u,a)))));const d=A(u);if(!w&&y&&g(d)&&C(r,t))return await a("DROP "+V+W(t)),void q(r,t);if(g(d)||C(r,t)){const s=j(r,t),i=G(F(s));await E([...v(d,(async n=>{O(i,n)||(await a(z+W(t)+"ADD"+W(n)),q(s,n,e))})),...!w&&l?v(A(i),(async e=>{e!=n&&(await a(z+W(t)+"DROP"+W(e)),q(s,e))})):[]])}else await a("CREATE "+V+W(t)+"("+W(n)+` PRIMARY KEY ON CONFLICT REPLACE${p(v(d,(a=>s+W(a))))});`),q(r,t,$([[n,e],...v(d,(a=>[a,e]))]));if(w)c(o)?await a(K+W(t)+Z+" 1"):await E(D(o,(async(e,s)=>{c(e)?await a(K+W(t)+Z+W(n)+"=?",[s]):g(d)||await ta(a,t,n,S(e),[s,..._(e)],i)})));else if(g(d))C(r,t)&&await a(K+W(t)+Z+" 1");else{const e=m(F(j(r,t)),(a=>a!=n)),s=[],c=[];D(o??{},((a,t)=>{h(s,t,...v(e,(t=>a?.[t]))),h(c,t)})),await ta(a,t,n,e,s,i),await a(K+W(t)+Z+W(n)+"NOT IN("+ea(c)+")",c)}},async t=>{let e;await a("BEGIN");try{e=await t()}catch(a){n?.(a)}return await a("END"),e}]},ta=async(a,t,n,r,o,c=!0)=>await a("INSERT "+(c?e:"OR REPLACE ")+"INTO"+W(t)+"("+W(n)+p(v(r,(a=>s+W(a))))+")VALUES"+u(i(`,(?${i(",?",d(r))})`,d(o)/(d(r)+1)),1)+(c?"ON CONFLICT("+W(n)+")DO UPDATE SET"+p(v(r,(a=>W(a)+"=excluded."+W(a))),s):e),v(o,(a=>a??null))),ea=a=>p(v(a,(()=>"?")),s),sa=$(),na=$(),ia=(a,t,e,s,n,i,r,o={},y=[])=>{let u,d,E,p=0,v=0,g=0;x(sa,y,(()=>0)),x(na,y,(()=>[]));const[m,C,A,O,T]=((a=1,t)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,t.getTransactionMergeableChanges,([[a],[t]])=>!P(a)||!P(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!P(a)||!P(t),t.setContent]:(a=>{throw Error("Store type not supported by this Persister")})())(r,a),N=t=>{(m&&w(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},R=async a=>(2!=p&&(p=1,v++,await I((async()=>{try{N(await t())}catch(t){i?.(t),a&&T(a)}p=0}))),D),S=()=>(d&&(n(d),d=void 0),D),f=async a=>(1!=p&&(p=2,g++,await I((async()=>{try{await e(C,a)}catch(a){i?.(a)}p=0}))),D),L=()=>(l(E,a.delListener),E=void 0,D),I=async(...a)=>(h(j(na,y),...a),await(async()=>{if(!j(sa,y)){for(q(sa,y,1);!c((a=j(na,y),u=a.shift()));)try{await u()}catch(a){i?.(a)}q(sa,y,0)}var a})(),D),D={load:R,startAutoLoad:async a=>(await S().load(a),d=s((async(a,t)=>{t||a?2!=p&&(p=1,v++,N(t??a),p=0):await R()})),D),stopAutoLoad:S,isAutoLoading:()=>!c(d),save:f,startAutoSave:async()=>(await L().save(),E=a.addDidFinishTransactionListener((()=>{const a=A();O(a)&&f(a)})),D),stopAutoSave:L,isAutoSaving:()=>!c(E),schedule:I,getStore:()=>a,destroy:()=>S().stopAutoSave(),getStats:()=>({loads:v,saves:g}),...o};return b(D)},ra=(a,t,e,s,n,i,[r,o,c],l,y,w,u)=>{const[d,E,p,v]=aa(t,l,n,u);return ia(a,(async()=>await v((async()=>{return await d(),a=(await E(r,o))[H]?.[c]??"null",JSON.parse(a,((a,t)=>""===t?void 0:t));var a}))),(async a=>await v((async()=>{var t;await d(),await p(r,o,{[H]:{[c]:(t=a()??null,JSON.stringify(t,((a,t)=>void 0===t?"":t)))}},!0,!0)}))),e,s,n,i,{[w]:()=>y},y)},oa=(a,t,e,s,n,i,[r,o,[l,y,w]],u,d,p,v)=>{const[g,h,C,A]=aa(t,u,n,v),O=async(a,t)=>await E(k(o,(async([e,s,n,i],r)=>{t&&!I(a,r)||await C(e,s,a[r],n,i,t)}))),T=async(a,t)=>y?await C(w,J,{[H]:a},!0,!0,t):null;return ia(a,(async()=>await A((async()=>{await g();const a=await(async()=>f(m(await E(k(r,(async([a,t],e)=>[a,await h(e,t)]))),(a=>!P(a[1])))))(),t=await(async()=>l?(await h(w,J))[H]:{})();return P(a)&&c(t)?void 0:[a,t]}))),(async(a,t)=>await A((async()=>{if(await g(),c(t)){const[t,e]=a();await O(t),await T(e)}else await O(t[0],!0),await T(t[1],!0)}))),e,s,n,i,{[p]:()=>d},d)},ca="ColumnName",la="store",ya="json",wa=la+"TableName",ua=la+"Id"+ca,da=la+ca,Ea="autoLoadIntervalSeconds",pa="rowId"+ca,va="tableId",ga="tableName",ma="deleteEmptyColumns",ha="deleteEmptyTable",Ca={mode:ya,[Ea]:1},Aa={load:0,save:0,[ga]:t+"_values"},Oa=(a,t,e,s,n)=>{const i=$();return D(a,((a,r)=>{const o=u(_(L(t,y(a)?{[e]:a}:a)),0,M(t));c(o[0])||s(r,o[0])||(n(r,o[0]),q(i,r,o))})),i},Ta="pragma_",Na="data_version",Ra="schema_version";exports.createSqliteWasmPersister=(a,e,s,n,i,r)=>((a,e,s,n,i,r,c,l,w,d="getDb",E)=>{let p,v,g;const[m,h,O,T]=(a=>{const e=(a=>L(Ca,y(a)?{[wa]:a}:a??{}))(a),s=e[Ea];if(e.mode==ya){const a=e[wa]??t;return[1,s,[a,e[ua]??J,e[da]??la],G(a)]}const{tables:{load:n={},save:i={}}={},values:r={}}=e,o=u(_(L(Aa,r)),0,M(Aa)),c=o[2],l=G(c),w=G(c);return[0,s,[Oa(n,{[va]:null,[pa]:J},va,(a=>C(w,a)),(a=>U(l,a))),Oa(i,{[ga]:null,[pa]:J,[ma]:0,[ha]:0},ga,((a,t)=>C(w,t)),((a,t)=>U(l,t))),o],l]})(e);return(m?ra:oa)(a,r?async(a,t)=>(r(a,t),await s(a,t)):s,(a=>{return[(t=async()=>{try{const[{d:t,s:e,c:n}]=await s(`SELECT ${Na} d,${Ra} s,TOTAL_CHANGES() c FROM ${Ta}${Na} JOIN ${Ta}${Ra}`);t==(p??=t)&&e==(v??=e)&&n==(g??=n)||(a(),p=t,v=e)}catch{}},e=h,t(),setInterval(t,1e3*e)),n((t=>T.has(t)?a():0))];var t,e}),(([a,t])=>{o(a),p=v=g=null,i(t)}),c,l,O,A(T),w,d,E)})(a,n,(async(a,t=[])=>s.exec(a,{bind:t,rowMode:"object",returnValue:"resultRows"}).map((a=>({...a})))),(a=>e.capi.sqlite3_update_hook(s,((t,e,s,n)=>a(n)),0)),(()=>e.capi.sqlite3_update_hook(s,(()=>0),0)),i,r,3,s);
1
+ "use strict";const a=a=>typeof a,t="tinybase",e="",s=",",n=a(e),i=(a,t)=>a.repeat(t),r=Promise,o=clearInterval,c=a=>null==a,l=(a,t,e)=>c(a)?e?.():t(a),y=t=>a(t)==n,w=a=>Array.isArray(a),u=(a,t,e)=>a.slice(t,e),d=a=>a.length,p=async a=>r.all(a),E=(a,t="")=>a.join(t),v=(a,t)=>a.map(t),g=a=>0==d(a),m=(a,t)=>a.filter(t),h=(a,...t)=>a.push(...t),C=(a,t)=>a?.has(t)??!1,A=a=>[...a?.values()??[]],O=(a,t)=>a?.delete(t),T=Object,N=a=>T.getPrototypeOf(a),R=T.entries,S=T.keys,b=T.freeze,f=(a=[])=>T.fromEntries(a),L=(...a)=>T.assign({},...a),I=(a,t)=>t in a,D=(a,t)=>v(R(a),(([a,e])=>t(e,a))),_=a=>T.values(a),M=a=>d(S(a)),P=a=>(a=>!c(a)&&l(N(a),(a=>a==T.prototype||c(N(a))),(()=>!0)))(a)&&0==M(a),$=a=>new Map(a),F=a=>[...a?.keys()??[]],j=(a,t)=>a?.get(t),k=(a,t)=>v([...a?.entries()??[]],(([a,e])=>t(e,a))),q=(a,t,e)=>c(e)?(O(a,t),a):a?.set(t,e),x=(a,t,e,s)=>(C(a,t)||q(a,t,e()),j(a,t)),B=(a,t,e,s=q)=>(D(t,((t,s)=>e(a,s,t))),((a,t)=>{((a,t)=>{a?.forEach(t)})(a,((a,e)=>t(e)))})(a,(e=>I(t,e)?0:s(a,e))),a),H="_",J="_id",W=a=>`"${a.replace(/"/g,'""')}"`,Y="SELECT",G=a=>new Set(w(a)||c(a)?a:[a]),U=(a,t)=>a?.add(t),V="TABLE",z="ALTER "+V,K="DELETE FROM",Q=Y+"*FROM",X="FROM pragma_table_",Z="WHERE",aa=(a,t,n,i)=>{const r=$();return[async()=>B(r,f(await p(v(await a("SELECT name "+X+"list WHERE schema='main'AND(type='table'OR type='view')AND name IN("+ea(t)+")ORDER BY name",t),(async({name:t})=>[t,f(v(await a(Y+" name,type "+X+"info(?)",[t]),(({name:a,type:t})=>[a,t])))])))),((a,t,e)=>q(r,t,B(x(r,t,$),e,((a,t,e)=>{e!=j(a,t)&&q(a,t,e)}),((a,t)=>q(a,t))))),((a,t)=>q(r,t))),async(t,e)=>((a,t)=>!c(j(j(r,a),t)))(t,e)?f(m(v(await a(Q+W(t)),(a=>{return[a[e],(t={...a},s=e,delete t[s],t)];var t,s})),(([a,t])=>!c(a)&&!P(t)))):{},async(t,n,o,l,y,w=!1)=>{const u=G();D(o??{},(a=>v(S(a??{}),(a=>U(u,a)))));const d=A(u);if(!w&&y&&g(d)&&C(r,t))return await a("DROP "+V+W(t)),void q(r,t);if(g(d)||C(r,t)){const s=j(r,t),i=G(F(s));await p([...v(d,(async n=>{O(i,n)||(await a(z+W(t)+"ADD"+W(n)),q(s,n,e))})),...!w&&l?v(A(i),(async e=>{e!=n&&(await a(z+W(t)+"DROP"+W(e)),q(s,e))})):[]])}else await a("CREATE "+V+W(t)+"("+W(n)+` PRIMARY KEY ON CONFLICT REPLACE${E(v(d,(a=>s+W(a))))});`),q(r,t,$([[n,e],...v(d,(a=>[a,e]))]));if(w)c(o)?await a(K+W(t)+Z+" 1"):await p(D(o,(async(e,s)=>{c(e)?await a(K+W(t)+Z+W(n)+"=?",[s]):g(d)||await ta(a,t,n,S(e),[s,..._(e)],i)})));else if(g(d))C(r,t)&&await a(K+W(t)+Z+" 1");else{const e=m(F(j(r,t)),(a=>a!=n)),s=[],c=[];D(o??{},((a,t)=>{h(s,t,...v(e,(t=>a?.[t]))),h(c,t)})),await ta(a,t,n,e,s,i),await a(K+W(t)+Z+W(n)+"NOT IN("+ea(c)+")",c)}},async t=>{let e;await a("BEGIN");try{e=await t()}catch(a){n?.(a)}return await a("END"),e}]},ta=async(a,t,n,r,o,c=!0)=>await a("INSERT "+(c?e:"OR REPLACE ")+"INTO"+W(t)+"("+W(n)+E(v(r,(a=>s+W(a))))+")VALUES"+u(i(`,(?${i(",?",d(r))})`,d(o)/(d(r)+1)),1)+(c?"ON CONFLICT("+W(n)+")DO UPDATE SET"+E(v(r,(a=>W(a)+"=excluded."+W(a))),s):e),v(o,(a=>a??null))),ea=a=>E(v(a,(()=>"?")),s),sa=$(),na=$(),ia=(a,t,e,s,n,i,r,o={},y=[])=>{let u,d,p,E=0,v=0,g=0;x(sa,y,(()=>0)),x(na,y,(()=>[]));const[m,C,A,O,T]=((a=1,t)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,t.getTransactionMergeableChanges,([[a],[t]])=>!P(a)||!P(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!P(a)||!P(t),t.setContent]:(a=>{throw Error("Store type not supported by this Persister")})())(r,a),N=t=>{(m&&w(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},R=async a=>(2!=E&&(E=1,v++,await I((async()=>{try{N(await t())}catch(t){i?.(t),a&&T(a)}E=0}))),D),S=()=>(d&&(n(d),d=void 0),D),f=async a=>(1!=E&&(E=2,g++,await I((async()=>{try{await e(C,a)}catch(a){i?.(a)}E=0}))),D),L=()=>(l(p,a.delListener),p=void 0,D),I=async(...a)=>(h(j(na,y),...a),await(async()=>{if(!j(sa,y)){for(q(sa,y,1);!c((a=j(na,y),u=a.shift()));)try{await u()}catch(a){i?.(a)}q(sa,y,0)}var a})(),D),D={load:R,startAutoLoad:async a=>{await S().load(a);try{d=s((async(a,t)=>{t||a?2!=E&&(E=1,v++,N(t??a),E=0):await R()}))}catch(a){i?.(a)}return D},stopAutoLoad:S,isAutoLoading:()=>!c(d),save:f,startAutoSave:async()=>(await L().save(),p=a.addDidFinishTransactionListener((()=>{const a=A();O(a)&&f(a)})),D),stopAutoSave:L,isAutoSaving:()=>!c(p),schedule:I,getStore:()=>a,destroy:()=>(j(na,y).splice(0,void 0),S().stopAutoSave()),getStats:()=>({loads:v,saves:g}),...o};return b(D)},ra=(a,t,e,s,n,i,[r,o,c],l,y,w,u)=>{const[d,p,E,v]=aa(t,l,n,u);return ia(a,(async()=>await v((async()=>{return await d(),a=(await p(r,o))[H]?.[c]??"null",JSON.parse(a,((a,t)=>""===t?void 0:t));var a}))),(async a=>await v((async()=>{var t;await d(),await E(r,o,{[H]:{[c]:(t=a()??null,JSON.stringify(t,((a,t)=>void 0===t?"":t)))}},!0,!0)}))),e,s,n,i,{[w]:()=>y},y)},oa=(a,t,e,s,n,i,[r,o,[l,y,w]],u,d,E,v)=>{const[g,h,C,A]=aa(t,u,n,v),O=async(a,t)=>await p(k(o,(async([e,s,n,i],r)=>{t&&!I(a,r)||await C(e,s,a[r],n,i,t)}))),T=async(a,t)=>y?await C(w,J,{[H]:a},!0,!0,t):null;return ia(a,(async()=>await A((async()=>{await g();const a=await(async()=>f(m(await p(k(r,(async([a,t],e)=>[a,await h(e,t)]))),(a=>!P(a[1])))))(),t=await(async()=>l?(await h(w,J))[H]:{})();return P(a)&&c(t)?void 0:[a,t]}))),(async(a,t)=>await A((async()=>{if(await g(),c(t)){const[t,e]=a();await O(t),await T(e)}else await O(t[0],!0),await T(t[1],!0)}))),e,s,n,i,{[E]:()=>d},d)},ca="ColumnName",la="store",ya="json",wa=la+"TableName",ua=la+"Id"+ca,da=la+ca,pa="autoLoadIntervalSeconds",Ea="rowId"+ca,va="tableId",ga="tableName",ma="deleteEmptyColumns",ha="deleteEmptyTable",Ca={mode:ya,[pa]:1},Aa={load:0,save:0,[ga]:t+"_values"},Oa=(a,t,e,s,n)=>{const i=$();return D(a,((a,r)=>{const o=u(_(L(t,y(a)?{[e]:a}:a)),0,M(t));c(o[0])||s(r,o[0])||(n(r,o[0]),q(i,r,o))})),i},Ta="pragma_",Na="data_version",Ra="schema_version";exports.createSqliteWasmPersister=(a,e,s,n,i,r)=>((a,e,s,n,i,r,c,l,w,d="getDb",p)=>{let E,v,g;const[m,h,O,T]=(a=>{const e=(a=>L(Ca,y(a)?{[wa]:a}:a??{}))(a),s=e[pa];if(e.mode==ya){const a=e[wa]??t;return[1,s,[a,e[ua]??J,e[da]??la],G(a)]}const{tables:{load:n={},save:i={}}={},values:r={}}=e,o=u(_(L(Aa,r)),0,M(Aa)),c=o[2],l=G(c),w=G(c);return[0,s,[Oa(n,{[va]:null,[Ea]:J},va,(a=>C(w,a)),(a=>U(l,a))),Oa(i,{[ga]:null,[Ea]:J,[ma]:0,[ha]:0},ga,((a,t)=>C(w,t)),((a,t)=>U(l,t))),o],l]})(e);return(m?ra:oa)(a,r?async(a,t)=>(r(a,t),await s(a,t)):s,(a=>{return[(t=async()=>{try{const[{d:t,s:e,c:n}]=await s(`SELECT ${Na} d,${Ra} s,TOTAL_CHANGES() c FROM ${Ta}${Na} JOIN ${Ta}${Ra}`);t==(E??=t)&&e==(v??=e)&&n==(g??=n)||(a(),E=t,v=e)}catch{}},e=h,t(),setInterval(t,1e3*e)),n((t=>T.has(t)?a():0))];var t,e}),(([a,t])=>{o(a),E=v=g=null,i(t)}),c,l,O,A(T),w,d,p)})(a,n,(async(a,t=[])=>s.exec(a,{bind:t,rowMode:"object",returnValue:"resultRows"}).map((a=>({...a})))),(a=>e.capi.sqlite3_update_hook(s,((t,e,s,n)=>a(n)),0)),(()=>e.capi.sqlite3_update_hook(s,(()=>0),0)),i,r,3,s);
@@ -1 +1 @@
1
- "use strict";const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),i=(a,t)=>a.repeat(t),r=Promise,o=clearInterval,c=a=>null==a,l=(a,t,e)=>c(a)?e?.():t(a),y=t=>a(t)==s,w=a=>Array.isArray(a),u=(a,t,e)=>a.slice(t,e),d=a=>a.length,E=async a=>r.all(a),v=(a,t="")=>a.join(t),p=(a,t)=>a.map(t),g=a=>0==d(a),m=(a,t)=>a.filter(t),C=(a,...t)=>a.push(...t),h=(a,t)=>a?.has(t)??!1,A=a=>[...a?.values()??[]],O=(a,t)=>a?.delete(t),T=Object,f=a=>T.getPrototypeOf(a),N=T.entries,R=T.keys,S=T.freeze,L=(a=[])=>T.fromEntries(a),b=(...a)=>T.assign({},...a),I=(a,t)=>t in a,D=(a,t)=>p(N(a),(([a,e])=>t(e,a))),M=a=>T.values(a),P=a=>d(R(a)),$=a=>(a=>!c(a)&&l(f(a),(a=>a==T.prototype||c(f(a))),(()=>!0)))(a)&&0==P(a),_=a=>new Map(a),F=a=>[...a?.keys()??[]],j=(a,t)=>a?.get(t),B=(a,t)=>p([...a?.entries()??[]],(([a,e])=>t(e,a))),H=(a,t,e)=>c(e)?(O(a,t),a):a?.set(t,e),J=(a,t,e,n)=>(h(a,t)||H(a,t,e()),j(a,t)),Y=(a,t,e,n=H)=>(D(t,((t,n)=>e(a,n,t))),((a,t)=>{((a,t)=>{a?.forEach(t)})(a,((a,e)=>t(e)))})(a,(e=>I(t,e)?0:n(a,e))),a),k="_",x="_id",G=a=>`"${a.replace(/"/g,'""')}"`,U="SELECT",W=a=>new Set(w(a)||c(a)?a:[a]),q=(a,t)=>a?.add(t),z="TABLE",K="ALTER "+z,V="DELETE FROM",Q=U+"*FROM",X="FROM pragma_table_",Z="WHERE",aa=(a,t,s,i)=>{const r=_();return[async()=>Y(r,L(await E(p(await a("SELECT name "+X+"list WHERE schema='main'AND(type='table'OR type='view')AND name IN("+ea(t)+")ORDER BY name",t),(async({name:t})=>[t,L(p(await a(U+" name,type "+X+"info(?)",[t]),(({name:a,type:t})=>[a,t])))])))),((a,t,e)=>H(r,t,Y(J(r,t,_),e,((a,t,e)=>{e!=j(a,t)&&H(a,t,e)}),((a,t)=>H(a,t))))),((a,t)=>H(r,t))),async(t,e)=>((a,t)=>!c(j(j(r,a),t)))(t,e)?L(m(p(await a(Q+G(t)),(a=>{return[a[e],(t={...a},n=e,delete t[n],t)];var t,n})),(([a,t])=>!c(a)&&!$(t)))):{},async(t,s,o,l,y,w=!1)=>{const u=W();D(o??{},(a=>p(R(a??{}),(a=>q(u,a)))));const d=A(u);if(!w&&y&&g(d)&&h(r,t))return await a("DROP "+z+G(t)),void H(r,t);if(g(d)||h(r,t)){const n=j(r,t),i=W(F(n));await E([...p(d,(async s=>{O(i,s)||(await a(K+G(t)+"ADD"+G(s)),H(n,s,e))})),...!w&&l?p(A(i),(async e=>{e!=s&&(await a(K+G(t)+"DROP"+G(e)),H(n,e))})):[]])}else await a("CREATE "+z+G(t)+"("+G(s)+` PRIMARY KEY ON CONFLICT REPLACE${v(p(d,(a=>n+G(a))))});`),H(r,t,_([[s,e],...p(d,(a=>[a,e]))]));if(w)c(o)?await a(V+G(t)+Z+" 1"):await E(D(o,(async(e,n)=>{c(e)?await a(V+G(t)+Z+G(s)+"=?",[n]):g(d)||await ta(a,t,s,R(e),[n,...M(e)],i)})));else if(g(d))h(r,t)&&await a(V+G(t)+Z+" 1");else{const e=m(F(j(r,t)),(a=>a!=s)),n=[],c=[];D(o??{},((a,t)=>{C(n,t,...p(e,(t=>a?.[t]))),C(c,t)})),await ta(a,t,s,e,n,i),await a(V+G(t)+Z+G(s)+"NOT IN("+ea(c)+")",c)}},async t=>{let e;await a("BEGIN");try{e=await t()}catch(a){s?.(a)}return await a("END"),e}]},ta=async(a,t,s,r,o,c=!0)=>await a("INSERT "+(c?e:"OR REPLACE ")+"INTO"+G(t)+"("+G(s)+v(p(r,(a=>n+G(a))))+")VALUES"+u(i(`,(?${i(",?",d(r))})`,d(o)/(d(r)+1)),1)+(c?"ON CONFLICT("+G(s)+")DO UPDATE SET"+v(p(r,(a=>G(a)+"=excluded."+G(a))),n):e),p(o,(a=>a??null))),ea=a=>v(p(a,(()=>"?")),n),na=_(),sa=_(),ia=(a,t,e,n,s,i,r,o={},y=[])=>{let u,d,E,v=0,p=0,g=0;J(na,y,(()=>0)),J(sa,y,(()=>[]));const[m,h,A,O,T]=((a=1,t)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,t.getTransactionMergeableChanges,([[a],[t]])=>!$(a)||!$(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!$(a)||!$(t),t.setContent]:(a=>{throw Error("Store type not supported by this Persister")})())(r,a),f=t=>{(m&&w(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},N=async a=>(2!=v&&(v=1,p++,await I((async()=>{try{f(await t())}catch(t){i?.(t),a&&T(a)}v=0}))),D),R=()=>(d&&(s(d),d=void 0),D),L=async a=>(1!=v&&(v=2,g++,await I((async()=>{try{await e(h,a)}catch(a){i?.(a)}v=0}))),D),b=()=>(l(E,a.delListener),E=void 0,D),I=async(...a)=>(C(j(sa,y),...a),await(async()=>{if(!j(na,y)){for(H(na,y,1);!c((a=j(sa,y),u=a.shift()));)try{await u()}catch(a){i?.(a)}H(na,y,0)}var a})(),D),D={load:N,startAutoLoad:async a=>(await R().load(a),d=n((async(a,t)=>{t||a?2!=v&&(v=1,p++,f(t??a),v=0):await N()})),D),stopAutoLoad:R,isAutoLoading:()=>!c(d),save:L,startAutoSave:async()=>(await b().save(),E=a.addDidFinishTransactionListener((()=>{const a=A();O(a)&&L(a)})),D),stopAutoSave:b,isAutoSaving:()=>!c(E),schedule:I,getStore:()=>a,destroy:()=>R().stopAutoSave(),getStats:()=>({loads:p,saves:g}),...o};return S(D)},ra=(a,t,e,n,s,i,[r,o,c],l,y,w,u)=>{const[d,E,v,p]=aa(t,l,s,u);return ia(a,(async()=>await p((async()=>{return await d(),a=(await E(r,o))[k]?.[c]??"null",JSON.parse(a,((a,t)=>""===t?void 0:t));var a}))),(async a=>await p((async()=>{var t;await d(),await v(r,o,{[k]:{[c]:(t=a()??null,JSON.stringify(t,((a,t)=>void 0===t?"":t)))}},!0,!0)}))),e,n,s,i,{[w]:()=>y},y)},oa=(a,t,e,n,s,i,[r,o,[l,y,w]],u,d,v,p)=>{const[g,C,h,A]=aa(t,u,s,p),O=async(a,t)=>await E(B(o,(async([e,n,s,i],r)=>{t&&!I(a,r)||await h(e,n,a[r],s,i,t)}))),T=async(a,t)=>y?await h(w,x,{[k]:a},!0,!0,t):null;return ia(a,(async()=>await A((async()=>{await g();const a=await(async()=>L(m(await E(B(r,(async([a,t],e)=>[a,await C(e,t)]))),(a=>!$(a[1])))))(),t=await(async()=>l?(await C(w,x))[k]:{})();return $(a)&&c(t)?void 0:[a,t]}))),(async(a,t)=>await A((async()=>{if(await g(),c(t)){const[t,e]=a();await O(t),await T(e)}else await O(t[0],!0),await T(t[1],!0)}))),e,n,s,i,{[v]:()=>d},d)},ca="ColumnName",la="store",ya="json",wa=la+"TableName",ua=la+"Id"+ca,da=la+ca,Ea="autoLoadIntervalSeconds",va="rowId"+ca,pa="tableId",ga="tableName",ma="deleteEmptyColumns",Ca="deleteEmptyTable",ha={mode:ya,[Ea]:1},Aa={load:0,save:0,[ga]:t+"_values"},Oa=(a,t,e,n,s)=>{const i=_();return D(a,((a,r)=>{const o=u(M(b(t,y(a)?{[e]:a}:a)),0,P(t));c(o[0])||n(r,o[0])||(s(r,o[0]),H(i,r,o))})),i},Ta="pragma_",fa="data_version",Na="schema_version",Ra="change";exports.createSqlite3Persister=(a,e,n,s,i)=>((a,e,n,s,i,r,c,l,w,d="getDb",E)=>{let v,p,g;const[m,C,O,T]=(a=>{const e=(a=>b(ha,y(a)?{[wa]:a}:a??{}))(a),n=e[Ea];if(e.mode==ya){const a=e[wa]??t;return[1,n,[a,e[ua]??x,e[da]??la],W(a)]}const{tables:{load:s={},save:i={}}={},values:r={}}=e,o=u(M(b(Aa,r)),0,P(Aa)),c=o[2],l=W(c),w=W(c);return[0,n,[Oa(s,{[pa]:null,[va]:x},pa,(a=>h(w,a)),(a=>q(l,a))),Oa(i,{[ga]:null,[va]:x,[ma]:0,[Ca]:0},ga,((a,t)=>h(w,t)),((a,t)=>q(l,t))),o],l]})(e);return(m?ra:oa)(a,r?async(a,t)=>(r(a,t),await n(a,t)):n,(a=>{return[(t=async()=>{try{const[{d:t,s:e,c:s}]=await n(`SELECT ${fa} d,${Na} s,TOTAL_CHANGES() c FROM ${Ta}${fa} JOIN ${Ta}${Na}`);t==(v??=t)&&e==(p??=e)&&s==(g??=s)||(a(),v=t,p=e)}catch{}},e=C,t(),setInterval(t,1e3*e)),s((t=>T.has(t)?a():0))];var t,e}),(([a,t])=>{o(a),v=p=g=null,i(t)}),c,l,O,A(T),w,d,E)})(a,n,(async(a,t=[])=>{return await(n=(n,s)=>e.all(a,t,((a,t)=>a?s(a):n(t))),new r(n));var n}),(a=>{const t=(t,e,n)=>a(n);return e.on(Ra,t),t}),(a=>e.off(Ra,a)),s,i,3,e);
1
+ "use strict";const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),i=(a,t)=>a.repeat(t),r=Promise,c=clearInterval,o=a=>null==a,l=(a,t,e)=>o(a)?e?.():t(a),y=t=>a(t)==s,w=a=>Array.isArray(a),u=(a,t,e)=>a.slice(t,e),d=a=>a.length,E=async a=>r.all(a),v=(a,t="")=>a.join(t),p=(a,t)=>a.map(t),g=a=>0==d(a),h=(a,t)=>a.filter(t),m=(a,...t)=>a.push(...t),C=(a,t)=>a?.has(t)??!1,A=a=>[...a?.values()??[]],O=(a,t)=>a?.delete(t),T=Object,f=a=>T.getPrototypeOf(a),N=T.entries,R=T.keys,S=T.freeze,L=(a=[])=>T.fromEntries(a),b=(...a)=>T.assign({},...a),I=(a,t)=>t in a,D=(a,t)=>p(N(a),(([a,e])=>t(e,a))),M=a=>T.values(a),P=a=>d(R(a)),$=a=>(a=>!o(a)&&l(f(a),(a=>a==T.prototype||o(f(a))),(()=>!0)))(a)&&0==P(a),_=a=>new Map(a),F=a=>[...a?.keys()??[]],j=(a,t)=>a?.get(t),B=(a,t)=>p([...a?.entries()??[]],(([a,e])=>t(e,a))),H=(a,t,e)=>o(e)?(O(a,t),a):a?.set(t,e),J=(a,t,e,n)=>(C(a,t)||H(a,t,e()),j(a,t)),Y=(a,t,e,n=H)=>(D(t,((t,n)=>e(a,n,t))),((a,t)=>{((a,t)=>{a?.forEach(t)})(a,((a,e)=>t(e)))})(a,(e=>I(t,e)?0:n(a,e))),a),k="_",x="_id",G=a=>`"${a.replace(/"/g,'""')}"`,U="SELECT",W=a=>new Set(w(a)||o(a)?a:[a]),q=(a,t)=>a?.add(t),z="TABLE",K="ALTER "+z,V="DELETE FROM",Q=U+"*FROM",X="FROM pragma_table_",Z="WHERE",aa=(a,t,s,i)=>{const r=_();return[async()=>Y(r,L(await E(p(await a("SELECT name "+X+"list WHERE schema='main'AND(type='table'OR type='view')AND name IN("+ea(t)+")ORDER BY name",t),(async({name:t})=>[t,L(p(await a(U+" name,type "+X+"info(?)",[t]),(({name:a,type:t})=>[a,t])))])))),((a,t,e)=>H(r,t,Y(J(r,t,_),e,((a,t,e)=>{e!=j(a,t)&&H(a,t,e)}),((a,t)=>H(a,t))))),((a,t)=>H(r,t))),async(t,e)=>((a,t)=>!o(j(j(r,a),t)))(t,e)?L(h(p(await a(Q+G(t)),(a=>{return[a[e],(t={...a},n=e,delete t[n],t)];var t,n})),(([a,t])=>!o(a)&&!$(t)))):{},async(t,s,c,l,y,w=!1)=>{const u=W();D(c??{},(a=>p(R(a??{}),(a=>q(u,a)))));const d=A(u);if(!w&&y&&g(d)&&C(r,t))return await a("DROP "+z+G(t)),void H(r,t);if(g(d)||C(r,t)){const n=j(r,t),i=W(F(n));await E([...p(d,(async s=>{O(i,s)||(await a(K+G(t)+"ADD"+G(s)),H(n,s,e))})),...!w&&l?p(A(i),(async e=>{e!=s&&(await a(K+G(t)+"DROP"+G(e)),H(n,e))})):[]])}else await a("CREATE "+z+G(t)+"("+G(s)+` PRIMARY KEY ON CONFLICT REPLACE${v(p(d,(a=>n+G(a))))});`),H(r,t,_([[s,e],...p(d,(a=>[a,e]))]));if(w)o(c)?await a(V+G(t)+Z+" 1"):await E(D(c,(async(e,n)=>{o(e)?await a(V+G(t)+Z+G(s)+"=?",[n]):g(d)||await ta(a,t,s,R(e),[n,...M(e)],i)})));else if(g(d))C(r,t)&&await a(V+G(t)+Z+" 1");else{const e=h(F(j(r,t)),(a=>a!=s)),n=[],o=[];D(c??{},((a,t)=>{m(n,t,...p(e,(t=>a?.[t]))),m(o,t)})),await ta(a,t,s,e,n,i),await a(V+G(t)+Z+G(s)+"NOT IN("+ea(o)+")",o)}},async t=>{let e;await a("BEGIN");try{e=await t()}catch(a){s?.(a)}return await a("END"),e}]},ta=async(a,t,s,r,c,o=!0)=>await a("INSERT "+(o?e:"OR REPLACE ")+"INTO"+G(t)+"("+G(s)+v(p(r,(a=>n+G(a))))+")VALUES"+u(i(`,(?${i(",?",d(r))})`,d(c)/(d(r)+1)),1)+(o?"ON CONFLICT("+G(s)+")DO UPDATE SET"+v(p(r,(a=>G(a)+"=excluded."+G(a))),n):e),p(c,(a=>a??null))),ea=a=>v(p(a,(()=>"?")),n),na=_(),sa=_(),ia=(a,t,e,n,s,i,r,c={},y=[])=>{let u,d,E,v=0,p=0,g=0;J(na,y,(()=>0)),J(sa,y,(()=>[]));const[h,C,A,O,T]=((a=1,t)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,t.getTransactionMergeableChanges,([[a],[t]])=>!$(a)||!$(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!$(a)||!$(t),t.setContent]:(a=>{throw Error("Store type not supported by this Persister")})())(r,a),f=t=>{(h&&w(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},N=async a=>(2!=v&&(v=1,p++,await I((async()=>{try{f(await t())}catch(t){i?.(t),a&&T(a)}v=0}))),D),R=()=>(d&&(s(d),d=void 0),D),L=async a=>(1!=v&&(v=2,g++,await I((async()=>{try{await e(C,a)}catch(a){i?.(a)}v=0}))),D),b=()=>(l(E,a.delListener),E=void 0,D),I=async(...a)=>(m(j(sa,y),...a),await(async()=>{if(!j(na,y)){for(H(na,y,1);!o((a=j(sa,y),u=a.shift()));)try{await u()}catch(a){i?.(a)}H(na,y,0)}var a})(),D),D={load:N,startAutoLoad:async a=>{await R().load(a);try{d=n((async(a,t)=>{t||a?2!=v&&(v=1,p++,f(t??a),v=0):await N()}))}catch(a){i?.(a)}return D},stopAutoLoad:R,isAutoLoading:()=>!o(d),save:L,startAutoSave:async()=>(await b().save(),E=a.addDidFinishTransactionListener((()=>{const a=A();O(a)&&L(a)})),D),stopAutoSave:b,isAutoSaving:()=>!o(E),schedule:I,getStore:()=>a,destroy:()=>(j(sa,y).splice(0,void 0),R().stopAutoSave()),getStats:()=>({loads:p,saves:g}),...c};return S(D)},ra=(a,t,e,n,s,i,[r,c,o],l,y,w,u)=>{const[d,E,v,p]=aa(t,l,s,u);return ia(a,(async()=>await p((async()=>{return await d(),a=(await E(r,c))[k]?.[o]??"null",JSON.parse(a,((a,t)=>""===t?void 0:t));var a}))),(async a=>await p((async()=>{var t;await d(),await v(r,c,{[k]:{[o]:(t=a()??null,JSON.stringify(t,((a,t)=>void 0===t?"":t)))}},!0,!0)}))),e,n,s,i,{[w]:()=>y},y)},ca=(a,t,e,n,s,i,[r,c,[l,y,w]],u,d,v,p)=>{const[g,m,C,A]=aa(t,u,s,p),O=async(a,t)=>await E(B(c,(async([e,n,s,i],r)=>{t&&!I(a,r)||await C(e,n,a[r],s,i,t)}))),T=async(a,t)=>y?await C(w,x,{[k]:a},!0,!0,t):null;return ia(a,(async()=>await A((async()=>{await g();const a=await(async()=>L(h(await E(B(r,(async([a,t],e)=>[a,await m(e,t)]))),(a=>!$(a[1])))))(),t=await(async()=>l?(await m(w,x))[k]:{})();return $(a)&&o(t)?void 0:[a,t]}))),(async(a,t)=>await A((async()=>{if(await g(),o(t)){const[t,e]=a();await O(t),await T(e)}else await O(t[0],!0),await T(t[1],!0)}))),e,n,s,i,{[v]:()=>d},d)},oa="ColumnName",la="store",ya="json",wa=la+"TableName",ua=la+"Id"+oa,da=la+oa,Ea="autoLoadIntervalSeconds",va="rowId"+oa,pa="tableId",ga="tableName",ha="deleteEmptyColumns",ma="deleteEmptyTable",Ca={mode:ya,[Ea]:1},Aa={load:0,save:0,[ga]:t+"_values"},Oa=(a,t,e,n,s)=>{const i=_();return D(a,((a,r)=>{const c=u(M(b(t,y(a)?{[e]:a}:a)),0,P(t));o(c[0])||n(r,c[0])||(s(r,c[0]),H(i,r,c))})),i},Ta="pragma_",fa="data_version",Na="schema_version",Ra="change";exports.createSqlite3Persister=(a,e,n,s,i)=>((a,e,n,s,i,r,o,l,w,d="getDb",E)=>{let v,p,g;const[h,m,O,T]=(a=>{const e=(a=>b(Ca,y(a)?{[wa]:a}:a??{}))(a),n=e[Ea];if(e.mode==ya){const a=e[wa]??t;return[1,n,[a,e[ua]??x,e[da]??la],W(a)]}const{tables:{load:s={},save:i={}}={},values:r={}}=e,c=u(M(b(Aa,r)),0,P(Aa)),o=c[2],l=W(o),w=W(o);return[0,n,[Oa(s,{[pa]:null,[va]:x},pa,(a=>C(w,a)),(a=>q(l,a))),Oa(i,{[ga]:null,[va]:x,[ha]:0,[ma]:0},ga,((a,t)=>C(w,t)),((a,t)=>q(l,t))),c],l]})(e);return(h?ra:ca)(a,r?async(a,t)=>(r(a,t),await n(a,t)):n,(a=>{return[(t=async()=>{try{const[{d:t,s:e,c:s}]=await n(`SELECT ${fa} d,${Na} s,TOTAL_CHANGES() c FROM ${Ta}${fa} JOIN ${Ta}${Na}`);t==(v??=t)&&e==(p??=e)&&s==(g??=s)||(a(),v=t,p=e)}catch{}},e=m,t(),setInterval(t,1e3*e)),s((t=>T.has(t)?a():0))];var t,e}),(([a,t])=>{c(a),v=p=g=null,i(t)}),o,l,O,A(T),w,d,E)})(a,n,(async(a,t=[])=>{return await(n=(n,s)=>e.all(a,t,((a,t)=>a?s(a):n(t))),new r(n));var n}),(a=>{const t=(t,e,n)=>a(n);return e.on(Ra,t),t}),(a=>e.off(Ra,a)),s,i,3,e);
@@ -1 +1 @@
1
- "use strict";const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),i=(a,t)=>a.repeat(t),r=Promise,o=clearInterval,c=a=>null==a,l=(a,t,e)=>c(a)?e?.():t(a),y=t=>a(t)==s,w=a=>Array.isArray(a),u=(a,t,e)=>a.slice(t,e),d=a=>a.length,E=async a=>r.all(a),v=(a,t="")=>a.join(t),p=(a,t)=>a.map(t),g=a=>0==d(a),m=(a,t)=>a.filter(t),C=(a,...t)=>a.push(...t),h=(a,t)=>a?.has(t)??!1,A=a=>[...a?.values()??[]],O=(a,t)=>a?.delete(t),T=Object,f=a=>T.getPrototypeOf(a),N=T.entries,R=T.keys,S=T.freeze,L=(a=[])=>T.fromEntries(a),b=(...a)=>T.assign({},...a),I=(a,t)=>t in a,D=(a,t)=>p(N(a),(([a,e])=>t(e,a))),M=a=>T.values(a),P=a=>d(R(a)),$=a=>(a=>!c(a)&&l(f(a),(a=>a==T.prototype||c(f(a))),(()=>!0)))(a)&&0==P(a),_=a=>new Map(a),F=a=>[...a?.keys()??[]],j=(a,t)=>a?.get(t),B=(a,t)=>p([...a?.entries()??[]],(([a,e])=>t(e,a))),H=(a,t,e)=>c(e)?(O(a,t),a):a?.set(t,e),J=(a,t,e,n)=>(h(a,t)||H(a,t,e()),j(a,t)),Y=(a,t,e,n=H)=>(D(t,((t,n)=>e(a,n,t))),((a,t)=>{((a,t)=>{a?.forEach(t)})(a,((a,e)=>t(e)))})(a,(e=>I(t,e)?0:n(a,e))),a),k="_",x="_id",G=a=>`"${a.replace(/"/g,'""')}"`,U="SELECT",W=a=>new Set(w(a)||c(a)?a:[a]),q=(a,t)=>a?.add(t),z="TABLE",K="ALTER "+z,V="DELETE FROM",Q=U+"*FROM",X="FROM pragma_table_",Z="WHERE",aa=(a,t,s,i)=>{const r=_();return[async()=>Y(r,L(await E(p(await a("SELECT name "+X+"list WHERE schema='main'AND(type='table'OR type='view')AND name IN("+ea(t)+")ORDER BY name",t),(async({name:t})=>[t,L(p(await a(U+" name,type "+X+"info(?)",[t]),(({name:a,type:t})=>[a,t])))])))),((a,t,e)=>H(r,t,Y(J(r,t,_),e,((a,t,e)=>{e!=j(a,t)&&H(a,t,e)}),((a,t)=>H(a,t))))),((a,t)=>H(r,t))),async(t,e)=>((a,t)=>!c(j(j(r,a),t)))(t,e)?L(m(p(await a(Q+G(t)),(a=>{return[a[e],(t={...a},n=e,delete t[n],t)];var t,n})),(([a,t])=>!c(a)&&!$(t)))):{},async(t,s,o,l,y,w=!1)=>{const u=W();D(o??{},(a=>p(R(a??{}),(a=>q(u,a)))));const d=A(u);if(!w&&y&&g(d)&&h(r,t))return await a("DROP "+z+G(t)),void H(r,t);if(g(d)||h(r,t)){const n=j(r,t),i=W(F(n));await E([...p(d,(async s=>{O(i,s)||(await a(K+G(t)+"ADD"+G(s)),H(n,s,e))})),...!w&&l?p(A(i),(async e=>{e!=s&&(await a(K+G(t)+"DROP"+G(e)),H(n,e))})):[]])}else await a("CREATE "+z+G(t)+"("+G(s)+` PRIMARY KEY ON CONFLICT REPLACE${v(p(d,(a=>n+G(a))))});`),H(r,t,_([[s,e],...p(d,(a=>[a,e]))]));if(w)c(o)?await a(V+G(t)+Z+" 1"):await E(D(o,(async(e,n)=>{c(e)?await a(V+G(t)+Z+G(s)+"=?",[n]):g(d)||await ta(a,t,s,R(e),[n,...M(e)],i)})));else if(g(d))h(r,t)&&await a(V+G(t)+Z+" 1");else{const e=m(F(j(r,t)),(a=>a!=s)),n=[],c=[];D(o??{},((a,t)=>{C(n,t,...p(e,(t=>a?.[t]))),C(c,t)})),await ta(a,t,s,e,n,i),await a(V+G(t)+Z+G(s)+"NOT IN("+ea(c)+")",c)}},async t=>{let e;await a("BEGIN");try{e=await t()}catch(a){s?.(a)}return await a("END"),e}]},ta=async(a,t,s,r,o,c=!0)=>await a("INSERT "+(c?e:"OR REPLACE ")+"INTO"+G(t)+"("+G(s)+v(p(r,(a=>n+G(a))))+")VALUES"+u(i(`,(?${i(",?",d(r))})`,d(o)/(d(r)+1)),1)+(c?"ON CONFLICT("+G(s)+")DO UPDATE SET"+v(p(r,(a=>G(a)+"=excluded."+G(a))),n):e),p(o,(a=>a??null))),ea=a=>v(p(a,(()=>"?")),n),na=_(),sa=_(),ia=(a,t,e,n,s,i,r,o={},y=[])=>{let u,d,E,v=0,p=0,g=0;J(na,y,(()=>0)),J(sa,y,(()=>[]));const[m,h,A,O,T]=((a=1,t)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,t.getTransactionMergeableChanges,([[a],[t]])=>!$(a)||!$(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!$(a)||!$(t),t.setContent]:(a=>{throw Error("Store type not supported by this Persister")})())(r,a),f=t=>{(m&&w(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},N=async a=>(2!=v&&(v=1,p++,await I((async()=>{try{f(await t())}catch(t){i?.(t),a&&T(a)}v=0}))),D),R=()=>(d&&(s(d),d=void 0),D),L=async a=>(1!=v&&(v=2,g++,await I((async()=>{try{await e(h,a)}catch(a){i?.(a)}v=0}))),D),b=()=>(l(E,a.delListener),E=void 0,D),I=async(...a)=>(C(j(sa,y),...a),await(async()=>{if(!j(na,y)){for(H(na,y,1);!c((a=j(sa,y),u=a.shift()));)try{await u()}catch(a){i?.(a)}H(na,y,0)}var a})(),D),D={load:N,startAutoLoad:async a=>(await R().load(a),d=n((async(a,t)=>{t||a?2!=v&&(v=1,p++,f(t??a),v=0):await N()})),D),stopAutoLoad:R,isAutoLoading:()=>!c(d),save:L,startAutoSave:async()=>(await b().save(),E=a.addDidFinishTransactionListener((()=>{const a=A();O(a)&&L(a)})),D),stopAutoSave:b,isAutoSaving:()=>!c(E),schedule:I,getStore:()=>a,destroy:()=>R().stopAutoSave(),getStats:()=>({loads:p,saves:g}),...o};return S(D)},ra=(a,t,e,n,s,i,[r,o,c],l,y,w,u)=>{const[d,E,v,p]=aa(t,l,s,u);return ia(a,(async()=>await p((async()=>{return await d(),a=(await E(r,o))[k]?.[c]??"null",JSON.parse(a,((a,t)=>""===t?void 0:t));var a}))),(async a=>await p((async()=>{var t;await d(),await v(r,o,{[k]:{[c]:(t=a()??null,JSON.stringify(t,((a,t)=>void 0===t?"":t)))}},!0,!0)}))),e,n,s,i,{[w]:()=>y},y)},oa=(a,t,e,n,s,i,[r,o,[l,y,w]],u,d,v,p)=>{const[g,C,h,A]=aa(t,u,s,p),O=async(a,t)=>await E(B(o,(async([e,n,s,i],r)=>{t&&!I(a,r)||await h(e,n,a[r],s,i,t)}))),T=async(a,t)=>y?await h(w,x,{[k]:a},!0,!0,t):null;return ia(a,(async()=>await A((async()=>{await g();const a=await(async()=>L(m(await E(B(r,(async([a,t],e)=>[a,await C(e,t)]))),(a=>!$(a[1])))))(),t=await(async()=>l?(await C(w,x))[k]:{})();return $(a)&&c(t)?void 0:[a,t]}))),(async(a,t)=>await A((async()=>{if(await g(),c(t)){const[t,e]=a();await O(t),await T(e)}else await O(t[0],!0),await T(t[1],!0)}))),e,n,s,i,{[v]:()=>d},d)},ca="ColumnName",la="store",ya="json",wa=la+"TableName",ua=la+"Id"+ca,da=la+ca,Ea="autoLoadIntervalSeconds",va="rowId"+ca,pa="tableId",ga="tableName",ma="deleteEmptyColumns",Ca="deleteEmptyTable",ha={mode:ya,[Ea]:1},Aa={load:0,save:0,[ga]:t+"_values"},Oa=(a,t,e,n,s)=>{const i=_();return D(a,((a,r)=>{const o=u(M(b(t,y(a)?{[e]:a}:a)),0,P(t));c(o[0])||n(r,o[0])||(s(r,o[0]),H(i,r,o))})),i},Ta="pragma_",fa="data_version",Na="schema_version",Ra="change";exports.createSqlite3Persister=(a,e,n,s,i)=>((a,e,n,s,i,r,c,l,w,d="getDb",E)=>{let v,p,g;const[m,C,O,T]=(a=>{const e=(a=>b(ha,y(a)?{[wa]:a}:a??{}))(a),n=e[Ea];if(e.mode==ya){const a=e[wa]??t;return[1,n,[a,e[ua]??x,e[da]??la],W(a)]}const{tables:{load:s={},save:i={}}={},values:r={}}=e,o=u(M(b(Aa,r)),0,P(Aa)),c=o[2],l=W(c),w=W(c);return[0,n,[Oa(s,{[pa]:null,[va]:x},pa,(a=>h(w,a)),(a=>q(l,a))),Oa(i,{[ga]:null,[va]:x,[ma]:0,[Ca]:0},ga,((a,t)=>h(w,t)),((a,t)=>q(l,t))),o],l]})(e);return(m?ra:oa)(a,r?async(a,t)=>(r(a,t),await n(a,t)):n,(a=>{return[(t=async()=>{try{const[{d:t,s:e,c:s}]=await n(`SELECT ${fa} d,${Na} s,TOTAL_CHANGES() c FROM ${Ta}${fa} JOIN ${Ta}${Na}`);t==(v??=t)&&e==(p??=e)&&s==(g??=s)||(a(),v=t,p=e)}catch{}},e=C,t(),setInterval(t,1e3*e)),s((t=>T.has(t)?a():0))];var t,e}),(([a,t])=>{o(a),v=p=g=null,i(t)}),c,l,O,A(T),w,d,E)})(a,n,(async(a,t=[])=>{return await(n=(n,s)=>e.all(a,t,((a,t)=>a?s(a):n(t))),new r(n));var n}),(a=>{const t=(t,e,n)=>a(n);return e.on(Ra,t),t}),(a=>e.off(Ra,a)),s,i,3,e);
1
+ "use strict";const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),i=(a,t)=>a.repeat(t),r=Promise,c=clearInterval,o=a=>null==a,l=(a,t,e)=>o(a)?e?.():t(a),y=t=>a(t)==s,w=a=>Array.isArray(a),u=(a,t,e)=>a.slice(t,e),d=a=>a.length,E=async a=>r.all(a),v=(a,t="")=>a.join(t),p=(a,t)=>a.map(t),g=a=>0==d(a),h=(a,t)=>a.filter(t),m=(a,...t)=>a.push(...t),C=(a,t)=>a?.has(t)??!1,A=a=>[...a?.values()??[]],O=(a,t)=>a?.delete(t),T=Object,f=a=>T.getPrototypeOf(a),N=T.entries,R=T.keys,S=T.freeze,L=(a=[])=>T.fromEntries(a),b=(...a)=>T.assign({},...a),I=(a,t)=>t in a,D=(a,t)=>p(N(a),(([a,e])=>t(e,a))),M=a=>T.values(a),P=a=>d(R(a)),$=a=>(a=>!o(a)&&l(f(a),(a=>a==T.prototype||o(f(a))),(()=>!0)))(a)&&0==P(a),_=a=>new Map(a),F=a=>[...a?.keys()??[]],j=(a,t)=>a?.get(t),B=(a,t)=>p([...a?.entries()??[]],(([a,e])=>t(e,a))),H=(a,t,e)=>o(e)?(O(a,t),a):a?.set(t,e),J=(a,t,e,n)=>(C(a,t)||H(a,t,e()),j(a,t)),Y=(a,t,e,n=H)=>(D(t,((t,n)=>e(a,n,t))),((a,t)=>{((a,t)=>{a?.forEach(t)})(a,((a,e)=>t(e)))})(a,(e=>I(t,e)?0:n(a,e))),a),k="_",x="_id",G=a=>`"${a.replace(/"/g,'""')}"`,U="SELECT",W=a=>new Set(w(a)||o(a)?a:[a]),q=(a,t)=>a?.add(t),z="TABLE",K="ALTER "+z,V="DELETE FROM",Q=U+"*FROM",X="FROM pragma_table_",Z="WHERE",aa=(a,t,s,i)=>{const r=_();return[async()=>Y(r,L(await E(p(await a("SELECT name "+X+"list WHERE schema='main'AND(type='table'OR type='view')AND name IN("+ea(t)+")ORDER BY name",t),(async({name:t})=>[t,L(p(await a(U+" name,type "+X+"info(?)",[t]),(({name:a,type:t})=>[a,t])))])))),((a,t,e)=>H(r,t,Y(J(r,t,_),e,((a,t,e)=>{e!=j(a,t)&&H(a,t,e)}),((a,t)=>H(a,t))))),((a,t)=>H(r,t))),async(t,e)=>((a,t)=>!o(j(j(r,a),t)))(t,e)?L(h(p(await a(Q+G(t)),(a=>{return[a[e],(t={...a},n=e,delete t[n],t)];var t,n})),(([a,t])=>!o(a)&&!$(t)))):{},async(t,s,c,l,y,w=!1)=>{const u=W();D(c??{},(a=>p(R(a??{}),(a=>q(u,a)))));const d=A(u);if(!w&&y&&g(d)&&C(r,t))return await a("DROP "+z+G(t)),void H(r,t);if(g(d)||C(r,t)){const n=j(r,t),i=W(F(n));await E([...p(d,(async s=>{O(i,s)||(await a(K+G(t)+"ADD"+G(s)),H(n,s,e))})),...!w&&l?p(A(i),(async e=>{e!=s&&(await a(K+G(t)+"DROP"+G(e)),H(n,e))})):[]])}else await a("CREATE "+z+G(t)+"("+G(s)+` PRIMARY KEY ON CONFLICT REPLACE${v(p(d,(a=>n+G(a))))});`),H(r,t,_([[s,e],...p(d,(a=>[a,e]))]));if(w)o(c)?await a(V+G(t)+Z+" 1"):await E(D(c,(async(e,n)=>{o(e)?await a(V+G(t)+Z+G(s)+"=?",[n]):g(d)||await ta(a,t,s,R(e),[n,...M(e)],i)})));else if(g(d))C(r,t)&&await a(V+G(t)+Z+" 1");else{const e=h(F(j(r,t)),(a=>a!=s)),n=[],o=[];D(c??{},((a,t)=>{m(n,t,...p(e,(t=>a?.[t]))),m(o,t)})),await ta(a,t,s,e,n,i),await a(V+G(t)+Z+G(s)+"NOT IN("+ea(o)+")",o)}},async t=>{let e;await a("BEGIN");try{e=await t()}catch(a){s?.(a)}return await a("END"),e}]},ta=async(a,t,s,r,c,o=!0)=>await a("INSERT "+(o?e:"OR REPLACE ")+"INTO"+G(t)+"("+G(s)+v(p(r,(a=>n+G(a))))+")VALUES"+u(i(`,(?${i(",?",d(r))})`,d(c)/(d(r)+1)),1)+(o?"ON CONFLICT("+G(s)+")DO UPDATE SET"+v(p(r,(a=>G(a)+"=excluded."+G(a))),n):e),p(c,(a=>a??null))),ea=a=>v(p(a,(()=>"?")),n),na=_(),sa=_(),ia=(a,t,e,n,s,i,r,c={},y=[])=>{let u,d,E,v=0,p=0,g=0;J(na,y,(()=>0)),J(sa,y,(()=>[]));const[h,C,A,O,T]=((a=1,t)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,t.getTransactionMergeableChanges,([[a],[t]])=>!$(a)||!$(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!$(a)||!$(t),t.setContent]:(a=>{throw Error("Store type not supported by this Persister")})())(r,a),f=t=>{(h&&w(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},N=async a=>(2!=v&&(v=1,p++,await I((async()=>{try{f(await t())}catch(t){i?.(t),a&&T(a)}v=0}))),D),R=()=>(d&&(s(d),d=void 0),D),L=async a=>(1!=v&&(v=2,g++,await I((async()=>{try{await e(C,a)}catch(a){i?.(a)}v=0}))),D),b=()=>(l(E,a.delListener),E=void 0,D),I=async(...a)=>(m(j(sa,y),...a),await(async()=>{if(!j(na,y)){for(H(na,y,1);!o((a=j(sa,y),u=a.shift()));)try{await u()}catch(a){i?.(a)}H(na,y,0)}var a})(),D),D={load:N,startAutoLoad:async a=>{await R().load(a);try{d=n((async(a,t)=>{t||a?2!=v&&(v=1,p++,f(t??a),v=0):await N()}))}catch(a){i?.(a)}return D},stopAutoLoad:R,isAutoLoading:()=>!o(d),save:L,startAutoSave:async()=>(await b().save(),E=a.addDidFinishTransactionListener((()=>{const a=A();O(a)&&L(a)})),D),stopAutoSave:b,isAutoSaving:()=>!o(E),schedule:I,getStore:()=>a,destroy:()=>(j(sa,y).splice(0,void 0),R().stopAutoSave()),getStats:()=>({loads:p,saves:g}),...c};return S(D)},ra=(a,t,e,n,s,i,[r,c,o],l,y,w,u)=>{const[d,E,v,p]=aa(t,l,s,u);return ia(a,(async()=>await p((async()=>{return await d(),a=(await E(r,c))[k]?.[o]??"null",JSON.parse(a,((a,t)=>""===t?void 0:t));var a}))),(async a=>await p((async()=>{var t;await d(),await v(r,c,{[k]:{[o]:(t=a()??null,JSON.stringify(t,((a,t)=>void 0===t?"":t)))}},!0,!0)}))),e,n,s,i,{[w]:()=>y},y)},ca=(a,t,e,n,s,i,[r,c,[l,y,w]],u,d,v,p)=>{const[g,m,C,A]=aa(t,u,s,p),O=async(a,t)=>await E(B(c,(async([e,n,s,i],r)=>{t&&!I(a,r)||await C(e,n,a[r],s,i,t)}))),T=async(a,t)=>y?await C(w,x,{[k]:a},!0,!0,t):null;return ia(a,(async()=>await A((async()=>{await g();const a=await(async()=>L(h(await E(B(r,(async([a,t],e)=>[a,await m(e,t)]))),(a=>!$(a[1])))))(),t=await(async()=>l?(await m(w,x))[k]:{})();return $(a)&&o(t)?void 0:[a,t]}))),(async(a,t)=>await A((async()=>{if(await g(),o(t)){const[t,e]=a();await O(t),await T(e)}else await O(t[0],!0),await T(t[1],!0)}))),e,n,s,i,{[v]:()=>d},d)},oa="ColumnName",la="store",ya="json",wa=la+"TableName",ua=la+"Id"+oa,da=la+oa,Ea="autoLoadIntervalSeconds",va="rowId"+oa,pa="tableId",ga="tableName",ha="deleteEmptyColumns",ma="deleteEmptyTable",Ca={mode:ya,[Ea]:1},Aa={load:0,save:0,[ga]:t+"_values"},Oa=(a,t,e,n,s)=>{const i=_();return D(a,((a,r)=>{const c=u(M(b(t,y(a)?{[e]:a}:a)),0,P(t));o(c[0])||n(r,c[0])||(s(r,c[0]),H(i,r,c))})),i},Ta="pragma_",fa="data_version",Na="schema_version",Ra="change";exports.createSqlite3Persister=(a,e,n,s,i)=>((a,e,n,s,i,r,o,l,w,d="getDb",E)=>{let v,p,g;const[h,m,O,T]=(a=>{const e=(a=>b(Ca,y(a)?{[wa]:a}:a??{}))(a),n=e[Ea];if(e.mode==ya){const a=e[wa]??t;return[1,n,[a,e[ua]??x,e[da]??la],W(a)]}const{tables:{load:s={},save:i={}}={},values:r={}}=e,c=u(M(b(Aa,r)),0,P(Aa)),o=c[2],l=W(o),w=W(o);return[0,n,[Oa(s,{[pa]:null,[va]:x},pa,(a=>C(w,a)),(a=>q(l,a))),Oa(i,{[ga]:null,[va]:x,[ha]:0,[ma]:0},ga,((a,t)=>C(w,t)),((a,t)=>q(l,t))),c],l]})(e);return(h?ra:ca)(a,r?async(a,t)=>(r(a,t),await n(a,t)):n,(a=>{return[(t=async()=>{try{const[{d:t,s:e,c:s}]=await n(`SELECT ${fa} d,${Na} s,TOTAL_CHANGES() c FROM ${Ta}${fa} JOIN ${Ta}${Na}`);t==(v??=t)&&e==(p??=e)&&s==(g??=s)||(a(),v=t,p=e)}catch{}},e=m,t(),setInterval(t,1e3*e)),s((t=>T.has(t)?a():0))];var t,e}),(([a,t])=>{c(a),v=p=g=null,i(t)}),o,l,O,A(T),w,d,E)})(a,n,(async(a,t=[])=>{return await(n=(n,s)=>e.all(a,t,((a,t)=>a?s(a):n(t))),new r(n));var n}),(a=>{const t=(t,e,n)=>a(n);return e.on(Ra,t),t}),(a=>e.off(Ra,a)),s,i,3,e);
@@ -1 +1 @@
1
- "use strict";var e=require("yjs");const t="t",a="v",s=e=>null==e,n=(e,t,a)=>s(e)?a?.():t(e),o=e=>e.length,r=e=>e.shift(),i=Object,c=e=>i.getPrototypeOf(e),g=i.entries,l=i.keys,u=i.freeze,d=(e=[])=>i.fromEntries(e),y=(e,t)=>t in e,p=(e,t)=>((e,t)=>e.map(t))(g(e),(([e,a])=>t(a,e))),h=e=>(e=>!s(e)&&n(c(e),(e=>e==i.prototype||s(c(e))),(()=>!0)))(e)&&0==(e=>o(l(e)))(e),v=(e,t,a)=>(y(e,t)||(e[t]=a()),e[t]),w=e=>new Map(e),f=(e,t)=>e?.get(t),S=(e,t)=>((e,t)=>e?.forEach(t))(e,((e,a)=>t(a,e))),b=(e,t,a)=>{return s(a)?(n=e,o=t,n?.delete(o),e):e?.set(t,a);var n,o},C=(e,t,a,s)=>{var n,o;return n=e,o=t,n?.has(o)||b(e,t,a()),f(e,t)},M=w(),A=w(),O="delete",J=e=>[e.get(t),e.get(a)],N=(t,a,n,o)=>{const r=s(a)?t:t.get(a)??t.set(a,new e.Map);let i;return p(n,((e,t)=>{o(r,t,e)&&(i=1)})),r.forEach(((e,t)=>{y(n,t)||(r.delete(t),i=1)})),s(a)||r.size||t.delete(a),i};exports.createYjsPersister=(i,c,g="tinybase",l)=>{const y=c.getMap(g);return((e,t,a,o,i,c,g,l={},d=[])=>{let y,p,v,w=0,S=0,O=0;C(M,d,(()=>0)),C(A,d,(()=>[]));const[J,N,D,E,L]=((e=1,t)=>1!=e&&t.isMergeable()?[1,t.getMergeableContent,t.getTransactionMergeableChanges,([[e],[t]])=>!h(e)||!h(t),t.setDefaultContent]:2!=e?[0,t.getContent,t.getTransactionChanges,([e,t])=>!h(e)||!h(t),t.setContent]:(e=>{throw Error("Store type not supported by this Persister")})())(g,e),z=t=>{var a;(J&&(a=t?.[0],Array.isArray(a))?1===t?.[2]?e.applyMergeableChanges:e.setMergeableContent:1===t?.[2]?e.applyChanges:e.setContent)(t)},j=async e=>(2!=w&&(w=1,S++,await m((async()=>{try{z(await t())}catch(t){c?.(t),e&&L(e)}w=0}))),Y),P=()=>(p&&(i(p),p=void 0),Y),T=async e=>(1!=w&&(w=2,O++,await m((async()=>{try{await a(N,e)}catch(e){c?.(e)}w=0}))),Y),k=()=>(n(v,e.delListener),v=void 0,Y),m=async(...e)=>(((e,...t)=>{e.push(...t)})(f(A,d),...e),await(async()=>{if(!f(M,d)){for(b(M,d,1);!s(y=r(f(A,d)));)try{await y()}catch(e){c?.(e)}b(M,d,0)}})(),Y),Y={load:j,startAutoLoad:async e=>(await P().load(e),p=o((async(e,t)=>{t||e?2!=w&&(w=1,S++,z(t??e),w=0):await j()})),Y),stopAutoLoad:P,isAutoLoading:()=>!s(p),save:T,startAutoSave:async()=>(await k().save(),v=e.addDidFinishTransactionListener((()=>{const e=D();E(e)&&T(e)})),Y),stopAutoSave:k,isAutoSaving:()=>!s(v),schedule:m,getStore:()=>e,destroy:()=>P().stopAutoSave(),getStats:()=>({loads:S,saves:O}),...l};return u(Y)})(i,(async()=>y.size?[y.get(t).toJSON(),y.get(a).toJSON()]:void 0),(async(o,r)=>c.transact((()=>((o,r,i)=>{o.size||(o.set(t,new e.Map),o.set(a,new e.Map));const[c,g]=J(o),l=()=>{u=1};let u=1;if(n(i,(([e,t])=>{u=0,p(e,((e,t)=>u?0:s(e)?c.delete(t):n(c.get(t),(t=>p(e,((e,a)=>u?0:s(e)?t.delete(a):n(t.get(a),(t=>p(e,((e,a)=>s(e)?t.delete(a):t.set(a,e)))),l)))),l))),p(t,((e,t)=>u?0:s(e)?g.delete(t):g.set(t,e)))})),u){const[e,t]=r();N(c,void 0,e,((e,t,a)=>N(c,t,a,((e,t,a)=>N(e,t,a,((e,t,a)=>{if(e.get(t)!==a)return e.set(t,a),1})))))),N(g,void 0,t,((e,t,a)=>{g.get(t)!==a&&g.set(t,a)}))}})(y,o,r)))),(e=>{const s=s=>e(void 0,((e,s)=>{if(1==o(s)&&(i=s[0].path,0==o(i)))return[e.get(t).toJSON(),e.get(a).toJSON(),1];var i;const[c,g]=J(e),l={},u={};return((e,a)=>{e.forEach((({path:e,changes:{keys:a}})=>r(e)==t?n(r(e),(t=>{const s=v(l,t,d),o=c.get(t);n(r(e),(e=>{const t=v(s,e,d),n=o.get(e);S(a,((e,{action:a})=>t[e]=a==O?null:n.get(e)))}),(()=>S(a,((e,{action:t})=>s[e]=t==O?null:o.get(e)?.toJSON()))))}),(()=>S(a,((e,{action:t})=>l[e]=t==O?null:c.get(e)?.toJSON())))):S(a,((e,{action:t})=>u[e]=t==O?null:g.get(e)))))})(s),[l,u,1]})(y,s));return y.observeDeep(s),s}),(e=>{y.unobserveDeep(e)}),l,1,{getYDoc:()=>c})};
1
+ "use strict";var t=require("yjs");const e="t",a="v",s=t=>null==t,n=(t,e,a)=>s(t)?a?.():e(t),r=t=>t.length,o=t=>t.shift(),i=Object,c=t=>i.getPrototypeOf(t),g=i.entries,l=i.keys,u=i.freeze,d=(t=[])=>i.fromEntries(t),y=(t,e)=>e in t,p=(t,e)=>((t,e)=>t.map(e))(g(t),(([t,a])=>e(a,t))),h=t=>(t=>!s(t)&&n(c(t),(t=>t==i.prototype||s(c(t))),(()=>!0)))(t)&&0==(t=>r(l(t)))(t),v=(t,e,a)=>(y(t,e)||(t[e]=a()),t[e]),w=t=>new Map(t),f=(t,e)=>t?.get(e),S=(t,e)=>((t,e)=>t?.forEach(e))(t,((t,a)=>e(a,t))),b=(t,e,a)=>{return s(a)?(n=t,r=e,n?.delete(r),t):t?.set(e,a);var n,r},C=(t,e,a,s)=>{var n,r;return n=t,r=e,n?.has(r)||b(t,e,a()),f(t,e)},M=w(),A=w(),O="delete",J=t=>[t.get(e),t.get(a)],N=(e,a,n,r)=>{const o=s(a)?e:e.get(a)??e.set(a,new t.Map);let i;return p(n,((t,e)=>{r(o,e,t)&&(i=1)})),o.forEach(((t,e)=>{y(n,e)||(o.delete(e),i=1)})),s(a)||o.size||e.delete(a),i};exports.createYjsPersister=(i,c,g="tinybase",l)=>{const y=c.getMap(g);return((t,e,a,r,i,c,g,l={},d=[])=>{let y,p,v,w=0,S=0,O=0;C(M,d,(()=>0)),C(A,d,(()=>[]));const[J,N,D,E,L]=((t=1,e)=>1!=t&&e.isMergeable()?[1,e.getMergeableContent,e.getTransactionMergeableChanges,([[t],[e]])=>!h(t)||!h(e),e.setDefaultContent]:2!=t?[0,e.getContent,e.getTransactionChanges,([t,e])=>!h(t)||!h(e),e.setContent]:(t=>{throw Error("Store type not supported by this Persister")})())(g,t),z=e=>{var a;(J&&(a=e?.[0],Array.isArray(a))?1===e?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===e?.[2]?t.applyChanges:t.setContent)(e)},j=async t=>(2!=w&&(w=1,S++,await m((async()=>{try{z(await e())}catch(e){c?.(e),t&&L(t)}w=0}))),Y),P=()=>(p&&(i(p),p=void 0),Y),T=async t=>(1!=w&&(w=2,O++,await m((async()=>{try{await a(N,t)}catch(t){c?.(t)}w=0}))),Y),k=()=>(n(v,t.delListener),v=void 0,Y),m=async(...t)=>(((t,...e)=>{t.push(...e)})(f(A,d),...t),await(async()=>{if(!f(M,d)){for(b(M,d,1);!s(y=o(f(A,d)));)try{await y()}catch(t){c?.(t)}b(M,d,0)}})(),Y),Y={load:j,startAutoLoad:async t=>{await P().load(t);try{p=r((async(t,e)=>{e||t?2!=w&&(w=1,S++,z(e??t),w=0):await j()}))}catch(t){c?.(t)}return Y},stopAutoLoad:P,isAutoLoading:()=>!s(p),save:T,startAutoSave:async()=>(await k().save(),v=t.addDidFinishTransactionListener((()=>{const t=D();E(t)&&T(t)})),Y),stopAutoSave:k,isAutoSaving:()=>!s(v),schedule:m,getStore:()=>t,destroy:()=>(f(A,d).splice(0,void 0),P().stopAutoSave()),getStats:()=>({loads:S,saves:O}),...l};return u(Y)})(i,(async()=>y.size?[y.get(e).toJSON(),y.get(a).toJSON()]:void 0),(async(r,o)=>c.transact((()=>((r,o,i)=>{r.size||(r.set(e,new t.Map),r.set(a,new t.Map));const[c,g]=J(r),l=()=>{u=1};let u=1;if(n(i,(([t,e])=>{u=0,p(t,((t,e)=>u?0:s(t)?c.delete(e):n(c.get(e),(e=>p(t,((t,a)=>u?0:s(t)?e.delete(a):n(e.get(a),(e=>p(t,((t,a)=>s(t)?e.delete(a):e.set(a,t)))),l)))),l))),p(e,((t,e)=>u?0:s(t)?g.delete(e):g.set(e,t)))})),u){const[t,e]=o();N(c,void 0,t,((t,e,a)=>N(c,e,a,((t,e,a)=>N(t,e,a,((t,e,a)=>{if(t.get(e)!==a)return t.set(e,a),1})))))),N(g,void 0,e,((t,e,a)=>{g.get(e)!==a&&g.set(e,a)}))}})(y,r,o)))),(t=>{const s=s=>t(void 0,((t,s)=>{if(1==r(s)&&(i=s[0].path,0==r(i)))return[t.get(e).toJSON(),t.get(a).toJSON(),1];var i;const[c,g]=J(t),l={},u={};return((t,a)=>{t.forEach((({path:t,changes:{keys:a}})=>o(t)==e?n(o(t),(e=>{const s=v(l,e,d),r=c.get(e);n(o(t),(t=>{const e=v(s,t,d),n=r.get(t);S(a,((t,{action:a})=>e[t]=a==O?null:n.get(t)))}),(()=>S(a,((t,{action:e})=>s[t]=e==O?null:r.get(t)?.toJSON()))))}),(()=>S(a,((t,{action:e})=>l[t]=e==O?null:c.get(t)?.toJSON())))):S(a,((t,{action:e})=>u[t]=e==O?null:g.get(t)))))})(s),[l,u,1]})(y,s));return y.observeDeep(s),s}),(t=>{y.unobserveDeep(t)}),l,1,{getYDoc:()=>c})};