tinybase 5.4.6 → 5.4.7

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 (627) hide show
  1. package/cjs/es6/index.cjs +13 -11
  2. package/cjs/es6/mergeable-store/index.cjs +12 -10
  3. package/cjs/es6/mergeable-store/with-schemas/index.cjs +12 -10
  4. package/cjs/es6/min/index.cjs +1 -1
  5. package/cjs/es6/min/index.cjs.gz +0 -0
  6. package/cjs/es6/min/mergeable-store/index.cjs +1 -1
  7. package/cjs/es6/min/mergeable-store/index.cjs.gz +0 -0
  8. package/cjs/es6/min/mergeable-store/with-schemas/index.cjs +1 -1
  9. package/cjs/es6/min/mergeable-store/with-schemas/index.cjs.gz +0 -0
  10. package/cjs/es6/min/persisters/index.cjs +1 -1
  11. package/cjs/es6/min/persisters/index.cjs.gz +0 -0
  12. package/cjs/es6/min/persisters/persister-automerge/index.cjs +1 -1
  13. package/cjs/es6/min/persisters/persister-automerge/index.cjs.gz +0 -0
  14. package/cjs/es6/min/persisters/persister-automerge/with-schemas/index.cjs +1 -1
  15. package/cjs/es6/min/persisters/persister-automerge/with-schemas/index.cjs.gz +0 -0
  16. package/cjs/es6/min/persisters/persister-cr-sqlite-wasm/index.cjs +1 -1
  17. package/cjs/es6/min/persisters/persister-cr-sqlite-wasm/index.cjs.gz +0 -0
  18. package/cjs/es6/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.cjs +1 -1
  19. package/cjs/es6/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.cjs.gz +0 -0
  20. package/cjs/es6/min/persisters/persister-electric-sql/index.cjs +1 -1
  21. package/cjs/es6/min/persisters/persister-electric-sql/index.cjs.gz +0 -0
  22. package/cjs/es6/min/persisters/persister-electric-sql/with-schemas/index.cjs +1 -1
  23. package/cjs/es6/min/persisters/persister-electric-sql/with-schemas/index.cjs.gz +0 -0
  24. package/cjs/es6/min/persisters/persister-expo-sqlite/index.cjs +1 -1
  25. package/cjs/es6/min/persisters/persister-expo-sqlite/index.cjs.gz +0 -0
  26. package/cjs/es6/min/persisters/persister-expo-sqlite/with-schemas/index.cjs +1 -1
  27. package/cjs/es6/min/persisters/persister-expo-sqlite/with-schemas/index.cjs.gz +0 -0
  28. package/cjs/es6/min/persisters/persister-libsql/index.cjs +1 -1
  29. package/cjs/es6/min/persisters/persister-libsql/index.cjs.gz +0 -0
  30. package/cjs/es6/min/persisters/persister-libsql/with-schemas/index.cjs +1 -1
  31. package/cjs/es6/min/persisters/persister-libsql/with-schemas/index.cjs.gz +0 -0
  32. package/cjs/es6/min/persisters/persister-pglite/index.cjs +1 -1
  33. package/cjs/es6/min/persisters/persister-pglite/index.cjs.gz +0 -0
  34. package/cjs/es6/min/persisters/persister-pglite/with-schemas/index.cjs +1 -1
  35. package/cjs/es6/min/persisters/persister-pglite/with-schemas/index.cjs.gz +0 -0
  36. package/cjs/es6/min/persisters/persister-postgres/index.cjs +1 -1
  37. package/cjs/es6/min/persisters/persister-postgres/index.cjs.gz +0 -0
  38. package/cjs/es6/min/persisters/persister-postgres/with-schemas/index.cjs +1 -1
  39. package/cjs/es6/min/persisters/persister-postgres/with-schemas/index.cjs.gz +0 -0
  40. package/cjs/es6/min/persisters/persister-powersync/index.cjs +1 -1
  41. package/cjs/es6/min/persisters/persister-powersync/index.cjs.gz +0 -0
  42. package/cjs/es6/min/persisters/persister-powersync/with-schemas/index.cjs +1 -1
  43. package/cjs/es6/min/persisters/persister-powersync/with-schemas/index.cjs.gz +0 -0
  44. package/cjs/es6/min/persisters/persister-sqlite-wasm/index.cjs +1 -1
  45. package/cjs/es6/min/persisters/persister-sqlite-wasm/index.cjs.gz +0 -0
  46. package/cjs/es6/min/persisters/persister-sqlite-wasm/with-schemas/index.cjs +1 -1
  47. package/cjs/es6/min/persisters/persister-sqlite-wasm/with-schemas/index.cjs.gz +0 -0
  48. package/cjs/es6/min/persisters/persister-sqlite3/index.cjs +1 -1
  49. package/cjs/es6/min/persisters/persister-sqlite3/index.cjs.gz +0 -0
  50. package/cjs/es6/min/persisters/persister-sqlite3/with-schemas/index.cjs +1 -1
  51. package/cjs/es6/min/persisters/persister-sqlite3/with-schemas/index.cjs.gz +0 -0
  52. package/cjs/es6/min/persisters/persister-yjs/index.cjs +1 -1
  53. package/cjs/es6/min/persisters/persister-yjs/index.cjs.gz +0 -0
  54. package/cjs/es6/min/persisters/persister-yjs/with-schemas/index.cjs +1 -1
  55. package/cjs/es6/min/persisters/persister-yjs/with-schemas/index.cjs.gz +0 -0
  56. package/cjs/es6/min/persisters/with-schemas/index.cjs +1 -1
  57. package/cjs/es6/min/persisters/with-schemas/index.cjs.gz +0 -0
  58. package/cjs/es6/min/queries/index.cjs +1 -1
  59. package/cjs/es6/min/queries/index.cjs.gz +0 -0
  60. package/cjs/es6/min/queries/with-schemas/index.cjs +1 -1
  61. package/cjs/es6/min/queries/with-schemas/index.cjs.gz +0 -0
  62. package/cjs/es6/min/store/index.cjs +1 -1
  63. package/cjs/es6/min/store/index.cjs.gz +0 -0
  64. package/cjs/es6/min/store/with-schemas/index.cjs +1 -1
  65. package/cjs/es6/min/store/with-schemas/index.cjs.gz +0 -0
  66. package/cjs/es6/min/ui-react-inspector/index.cjs +1 -1
  67. package/cjs/es6/min/ui-react-inspector/index.cjs.gz +0 -0
  68. package/cjs/es6/min/ui-react-inspector/with-schemas/index.cjs +1 -1
  69. package/cjs/es6/min/ui-react-inspector/with-schemas/index.cjs.gz +0 -0
  70. package/cjs/es6/min/with-schemas/index.cjs +1 -1
  71. package/cjs/es6/min/with-schemas/index.cjs.gz +0 -0
  72. package/cjs/es6/persisters/index.cjs +3 -3
  73. package/cjs/es6/persisters/persister-automerge/index.cjs +8 -6
  74. package/cjs/es6/persisters/persister-automerge/with-schemas/index.cjs +8 -6
  75. package/cjs/es6/persisters/persister-cr-sqlite-wasm/index.cjs +3 -3
  76. package/cjs/es6/persisters/persister-cr-sqlite-wasm/with-schemas/index.cjs +3 -3
  77. package/cjs/es6/persisters/persister-electric-sql/index.cjs +3 -3
  78. package/cjs/es6/persisters/persister-electric-sql/with-schemas/index.cjs +3 -3
  79. package/cjs/es6/persisters/persister-expo-sqlite/index.cjs +3 -3
  80. package/cjs/es6/persisters/persister-expo-sqlite/with-schemas/index.cjs +3 -3
  81. package/cjs/es6/persisters/persister-libsql/index.cjs +3 -3
  82. package/cjs/es6/persisters/persister-libsql/with-schemas/index.cjs +3 -3
  83. package/cjs/es6/persisters/persister-pglite/index.cjs +3 -3
  84. package/cjs/es6/persisters/persister-pglite/with-schemas/index.cjs +3 -3
  85. package/cjs/es6/persisters/persister-postgres/index.cjs +3 -3
  86. package/cjs/es6/persisters/persister-postgres/with-schemas/index.cjs +3 -3
  87. package/cjs/es6/persisters/persister-powersync/index.cjs +3 -3
  88. package/cjs/es6/persisters/persister-powersync/with-schemas/index.cjs +3 -3
  89. package/cjs/es6/persisters/persister-sqlite-wasm/index.cjs +3 -3
  90. package/cjs/es6/persisters/persister-sqlite-wasm/with-schemas/index.cjs +3 -3
  91. package/cjs/es6/persisters/persister-sqlite3/index.cjs +3 -3
  92. package/cjs/es6/persisters/persister-sqlite3/with-schemas/index.cjs +3 -3
  93. package/cjs/es6/persisters/persister-yjs/index.cjs +7 -5
  94. package/cjs/es6/persisters/persister-yjs/with-schemas/index.cjs +7 -5
  95. package/cjs/es6/persisters/with-schemas/index.cjs +3 -3
  96. package/cjs/es6/queries/index.cjs +4 -1
  97. package/cjs/es6/queries/with-schemas/index.cjs +4 -1
  98. package/cjs/es6/store/index.cjs +14 -9
  99. package/cjs/es6/store/with-schemas/index.cjs +14 -9
  100. package/cjs/es6/tools/index.cjs +4 -4
  101. package/cjs/es6/tools/with-schemas/index.cjs +4 -4
  102. package/cjs/es6/ui-react-inspector/index.cjs +11 -9
  103. package/cjs/es6/ui-react-inspector/with-schemas/index.cjs +11 -9
  104. package/cjs/es6/with-schemas/index.cjs +13 -11
  105. package/cjs/index.cjs +13 -11
  106. package/cjs/mergeable-store/index.cjs +12 -10
  107. package/cjs/mergeable-store/with-schemas/index.cjs +12 -10
  108. package/cjs/min/index.cjs +1 -1
  109. package/cjs/min/index.cjs.gz +0 -0
  110. package/cjs/min/mergeable-store/index.cjs +1 -1
  111. package/cjs/min/mergeable-store/index.cjs.gz +0 -0
  112. package/cjs/min/mergeable-store/with-schemas/index.cjs +1 -1
  113. package/cjs/min/mergeable-store/with-schemas/index.cjs.gz +0 -0
  114. package/cjs/min/persisters/index.cjs +1 -1
  115. package/cjs/min/persisters/index.cjs.gz +0 -0
  116. package/cjs/min/persisters/persister-automerge/index.cjs +1 -1
  117. package/cjs/min/persisters/persister-automerge/index.cjs.gz +0 -0
  118. package/cjs/min/persisters/persister-automerge/with-schemas/index.cjs +1 -1
  119. package/cjs/min/persisters/persister-automerge/with-schemas/index.cjs.gz +0 -0
  120. package/cjs/min/persisters/persister-cr-sqlite-wasm/index.cjs +1 -1
  121. package/cjs/min/persisters/persister-cr-sqlite-wasm/index.cjs.gz +0 -0
  122. package/cjs/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.cjs +1 -1
  123. package/cjs/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.cjs.gz +0 -0
  124. package/cjs/min/persisters/persister-electric-sql/index.cjs +1 -1
  125. package/cjs/min/persisters/persister-electric-sql/index.cjs.gz +0 -0
  126. package/cjs/min/persisters/persister-electric-sql/with-schemas/index.cjs +1 -1
  127. package/cjs/min/persisters/persister-electric-sql/with-schemas/index.cjs.gz +0 -0
  128. package/cjs/min/persisters/persister-expo-sqlite/index.cjs +1 -1
  129. package/cjs/min/persisters/persister-expo-sqlite/index.cjs.gz +0 -0
  130. package/cjs/min/persisters/persister-expo-sqlite/with-schemas/index.cjs +1 -1
  131. package/cjs/min/persisters/persister-expo-sqlite/with-schemas/index.cjs.gz +0 -0
  132. package/cjs/min/persisters/persister-libsql/index.cjs +1 -1
  133. package/cjs/min/persisters/persister-libsql/index.cjs.gz +0 -0
  134. package/cjs/min/persisters/persister-libsql/with-schemas/index.cjs +1 -1
  135. package/cjs/min/persisters/persister-libsql/with-schemas/index.cjs.gz +0 -0
  136. package/cjs/min/persisters/persister-pglite/index.cjs +1 -1
  137. package/cjs/min/persisters/persister-pglite/index.cjs.gz +0 -0
  138. package/cjs/min/persisters/persister-pglite/with-schemas/index.cjs +1 -1
  139. package/cjs/min/persisters/persister-pglite/with-schemas/index.cjs.gz +0 -0
  140. package/cjs/min/persisters/persister-postgres/index.cjs +1 -1
  141. package/cjs/min/persisters/persister-postgres/index.cjs.gz +0 -0
  142. package/cjs/min/persisters/persister-postgres/with-schemas/index.cjs +1 -1
  143. package/cjs/min/persisters/persister-postgres/with-schemas/index.cjs.gz +0 -0
  144. package/cjs/min/persisters/persister-powersync/index.cjs +1 -1
  145. package/cjs/min/persisters/persister-powersync/index.cjs.gz +0 -0
  146. package/cjs/min/persisters/persister-powersync/with-schemas/index.cjs +1 -1
  147. package/cjs/min/persisters/persister-powersync/with-schemas/index.cjs.gz +0 -0
  148. package/cjs/min/persisters/persister-sqlite-wasm/index.cjs +1 -1
  149. package/cjs/min/persisters/persister-sqlite-wasm/index.cjs.gz +0 -0
  150. package/cjs/min/persisters/persister-sqlite-wasm/with-schemas/index.cjs +1 -1
  151. package/cjs/min/persisters/persister-sqlite-wasm/with-schemas/index.cjs.gz +0 -0
  152. package/cjs/min/persisters/persister-sqlite3/index.cjs +1 -1
  153. package/cjs/min/persisters/persister-sqlite3/index.cjs.gz +0 -0
  154. package/cjs/min/persisters/persister-sqlite3/with-schemas/index.cjs +1 -1
  155. package/cjs/min/persisters/persister-sqlite3/with-schemas/index.cjs.gz +0 -0
  156. package/cjs/min/persisters/persister-yjs/index.cjs +1 -1
  157. package/cjs/min/persisters/persister-yjs/index.cjs.gz +0 -0
  158. package/cjs/min/persisters/persister-yjs/with-schemas/index.cjs +1 -1
  159. package/cjs/min/persisters/persister-yjs/with-schemas/index.cjs.gz +0 -0
  160. package/cjs/min/persisters/with-schemas/index.cjs +1 -1
  161. package/cjs/min/persisters/with-schemas/index.cjs.gz +0 -0
  162. package/cjs/min/queries/index.cjs +1 -1
  163. package/cjs/min/queries/index.cjs.gz +0 -0
  164. package/cjs/min/queries/with-schemas/index.cjs +1 -1
  165. package/cjs/min/queries/with-schemas/index.cjs.gz +0 -0
  166. package/cjs/min/store/index.cjs +1 -1
  167. package/cjs/min/store/index.cjs.gz +0 -0
  168. package/cjs/min/store/with-schemas/index.cjs +1 -1
  169. package/cjs/min/store/with-schemas/index.cjs.gz +0 -0
  170. package/cjs/min/ui-react-inspector/index.cjs +1 -1
  171. package/cjs/min/ui-react-inspector/index.cjs.gz +0 -0
  172. package/cjs/min/ui-react-inspector/with-schemas/index.cjs +1 -1
  173. package/cjs/min/ui-react-inspector/with-schemas/index.cjs.gz +0 -0
  174. package/cjs/min/with-schemas/index.cjs +1 -1
  175. package/cjs/min/with-schemas/index.cjs.gz +0 -0
  176. package/cjs/persisters/index.cjs +3 -3
  177. package/cjs/persisters/persister-automerge/index.cjs +8 -6
  178. package/cjs/persisters/persister-automerge/with-schemas/index.cjs +8 -6
  179. package/cjs/persisters/persister-cr-sqlite-wasm/index.cjs +3 -3
  180. package/cjs/persisters/persister-cr-sqlite-wasm/with-schemas/index.cjs +3 -3
  181. package/cjs/persisters/persister-electric-sql/index.cjs +3 -3
  182. package/cjs/persisters/persister-electric-sql/with-schemas/index.cjs +3 -3
  183. package/cjs/persisters/persister-expo-sqlite/index.cjs +3 -3
  184. package/cjs/persisters/persister-expo-sqlite/with-schemas/index.cjs +3 -3
  185. package/cjs/persisters/persister-libsql/index.cjs +3 -3
  186. package/cjs/persisters/persister-libsql/with-schemas/index.cjs +3 -3
  187. package/cjs/persisters/persister-pglite/index.cjs +3 -3
  188. package/cjs/persisters/persister-pglite/with-schemas/index.cjs +3 -3
  189. package/cjs/persisters/persister-postgres/index.cjs +3 -3
  190. package/cjs/persisters/persister-postgres/with-schemas/index.cjs +3 -3
  191. package/cjs/persisters/persister-powersync/index.cjs +3 -3
  192. package/cjs/persisters/persister-powersync/with-schemas/index.cjs +3 -3
  193. package/cjs/persisters/persister-sqlite-wasm/index.cjs +3 -3
  194. package/cjs/persisters/persister-sqlite-wasm/with-schemas/index.cjs +3 -3
  195. package/cjs/persisters/persister-sqlite3/index.cjs +3 -3
  196. package/cjs/persisters/persister-sqlite3/with-schemas/index.cjs +3 -3
  197. package/cjs/persisters/persister-yjs/index.cjs +7 -5
  198. package/cjs/persisters/persister-yjs/with-schemas/index.cjs +7 -5
  199. package/cjs/persisters/with-schemas/index.cjs +3 -3
  200. package/cjs/queries/index.cjs +4 -1
  201. package/cjs/queries/with-schemas/index.cjs +4 -1
  202. package/cjs/store/index.cjs +14 -9
  203. package/cjs/store/with-schemas/index.cjs +14 -9
  204. package/cjs/tools/index.cjs +4 -4
  205. package/cjs/tools/with-schemas/index.cjs +4 -4
  206. package/cjs/ui-react-inspector/index.cjs +11 -9
  207. package/cjs/ui-react-inspector/with-schemas/index.cjs +11 -9
  208. package/cjs/with-schemas/index.cjs +13 -11
  209. package/cli/index.js +4 -1
  210. package/es6/index.js +13 -11
  211. package/es6/mergeable-store/index.js +12 -10
  212. package/es6/mergeable-store/with-schemas/index.js +12 -10
  213. package/es6/min/index.js +1 -1
  214. package/es6/min/index.js.gz +0 -0
  215. package/es6/min/mergeable-store/index.js +1 -1
  216. package/es6/min/mergeable-store/index.js.gz +0 -0
  217. package/es6/min/mergeable-store/with-schemas/index.js +1 -1
  218. package/es6/min/mergeable-store/with-schemas/index.js.gz +0 -0
  219. package/es6/min/persisters/index.js +1 -1
  220. package/es6/min/persisters/index.js.gz +0 -0
  221. package/es6/min/persisters/persister-automerge/index.js +1 -1
  222. package/es6/min/persisters/persister-automerge/index.js.gz +0 -0
  223. package/es6/min/persisters/persister-automerge/with-schemas/index.js +1 -1
  224. package/es6/min/persisters/persister-automerge/with-schemas/index.js.gz +0 -0
  225. package/es6/min/persisters/persister-cr-sqlite-wasm/index.js +1 -1
  226. package/es6/min/persisters/persister-cr-sqlite-wasm/index.js.gz +0 -0
  227. package/es6/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.js +1 -1
  228. package/es6/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.js.gz +0 -0
  229. package/es6/min/persisters/persister-electric-sql/index.js +1 -1
  230. package/es6/min/persisters/persister-electric-sql/index.js.gz +0 -0
  231. package/es6/min/persisters/persister-electric-sql/with-schemas/index.js +1 -1
  232. package/es6/min/persisters/persister-electric-sql/with-schemas/index.js.gz +0 -0
  233. package/es6/min/persisters/persister-expo-sqlite/index.js +1 -1
  234. package/es6/min/persisters/persister-expo-sqlite/index.js.gz +0 -0
  235. package/es6/min/persisters/persister-expo-sqlite/with-schemas/index.js +1 -1
  236. package/es6/min/persisters/persister-expo-sqlite/with-schemas/index.js.gz +0 -0
  237. package/es6/min/persisters/persister-libsql/index.js +1 -1
  238. package/es6/min/persisters/persister-libsql/index.js.gz +0 -0
  239. package/es6/min/persisters/persister-libsql/with-schemas/index.js +1 -1
  240. package/es6/min/persisters/persister-libsql/with-schemas/index.js.gz +0 -0
  241. package/es6/min/persisters/persister-pglite/index.js +1 -1
  242. package/es6/min/persisters/persister-pglite/index.js.gz +0 -0
  243. package/es6/min/persisters/persister-pglite/with-schemas/index.js +1 -1
  244. package/es6/min/persisters/persister-pglite/with-schemas/index.js.gz +0 -0
  245. package/es6/min/persisters/persister-postgres/index.js +1 -1
  246. package/es6/min/persisters/persister-postgres/index.js.gz +0 -0
  247. package/es6/min/persisters/persister-postgres/with-schemas/index.js +1 -1
  248. package/es6/min/persisters/persister-postgres/with-schemas/index.js.gz +0 -0
  249. package/es6/min/persisters/persister-powersync/index.js +1 -1
  250. package/es6/min/persisters/persister-powersync/index.js.gz +0 -0
  251. package/es6/min/persisters/persister-powersync/with-schemas/index.js +1 -1
  252. package/es6/min/persisters/persister-powersync/with-schemas/index.js.gz +0 -0
  253. package/es6/min/persisters/persister-sqlite-wasm/index.js +1 -1
  254. package/es6/min/persisters/persister-sqlite-wasm/index.js.gz +0 -0
  255. package/es6/min/persisters/persister-sqlite-wasm/with-schemas/index.js +1 -1
  256. package/es6/min/persisters/persister-sqlite-wasm/with-schemas/index.js.gz +0 -0
  257. package/es6/min/persisters/persister-sqlite3/index.js +1 -1
  258. package/es6/min/persisters/persister-sqlite3/index.js.gz +0 -0
  259. package/es6/min/persisters/persister-sqlite3/with-schemas/index.js +1 -1
  260. package/es6/min/persisters/persister-sqlite3/with-schemas/index.js.gz +0 -0
  261. package/es6/min/persisters/persister-yjs/index.js +1 -1
  262. package/es6/min/persisters/persister-yjs/index.js.gz +0 -0
  263. package/es6/min/persisters/persister-yjs/with-schemas/index.js +1 -1
  264. package/es6/min/persisters/persister-yjs/with-schemas/index.js.gz +0 -0
  265. package/es6/min/persisters/with-schemas/index.js +1 -1
  266. package/es6/min/persisters/with-schemas/index.js.gz +0 -0
  267. package/es6/min/queries/index.js +1 -1
  268. package/es6/min/queries/index.js.gz +0 -0
  269. package/es6/min/queries/with-schemas/index.js +1 -1
  270. package/es6/min/queries/with-schemas/index.js.gz +0 -0
  271. package/es6/min/store/index.js +1 -1
  272. package/es6/min/store/index.js.gz +0 -0
  273. package/es6/min/store/with-schemas/index.js +1 -1
  274. package/es6/min/store/with-schemas/index.js.gz +0 -0
  275. package/es6/min/ui-react-inspector/index.js +1 -1
  276. package/es6/min/ui-react-inspector/index.js.gz +0 -0
  277. package/es6/min/ui-react-inspector/with-schemas/index.js +1 -1
  278. package/es6/min/ui-react-inspector/with-schemas/index.js.gz +0 -0
  279. package/es6/min/with-schemas/index.js +1 -1
  280. package/es6/min/with-schemas/index.js.gz +0 -0
  281. package/es6/persisters/index.js +3 -3
  282. package/es6/persisters/persister-automerge/index.js +8 -6
  283. package/es6/persisters/persister-automerge/with-schemas/index.js +8 -6
  284. package/es6/persisters/persister-cr-sqlite-wasm/index.js +3 -3
  285. package/es6/persisters/persister-cr-sqlite-wasm/with-schemas/index.js +3 -3
  286. package/es6/persisters/persister-electric-sql/index.js +3 -3
  287. package/es6/persisters/persister-electric-sql/with-schemas/index.js +3 -3
  288. package/es6/persisters/persister-expo-sqlite/index.js +3 -3
  289. package/es6/persisters/persister-expo-sqlite/with-schemas/index.js +3 -3
  290. package/es6/persisters/persister-libsql/index.js +3 -3
  291. package/es6/persisters/persister-libsql/with-schemas/index.js +3 -3
  292. package/es6/persisters/persister-pglite/index.js +3 -3
  293. package/es6/persisters/persister-pglite/with-schemas/index.js +3 -3
  294. package/es6/persisters/persister-postgres/index.js +3 -3
  295. package/es6/persisters/persister-postgres/with-schemas/index.js +3 -3
  296. package/es6/persisters/persister-powersync/index.js +3 -3
  297. package/es6/persisters/persister-powersync/with-schemas/index.js +3 -3
  298. package/es6/persisters/persister-sqlite-wasm/index.js +3 -3
  299. package/es6/persisters/persister-sqlite-wasm/with-schemas/index.js +3 -3
  300. package/es6/persisters/persister-sqlite3/index.js +3 -3
  301. package/es6/persisters/persister-sqlite3/with-schemas/index.js +3 -3
  302. package/es6/persisters/persister-yjs/index.js +7 -5
  303. package/es6/persisters/persister-yjs/with-schemas/index.js +7 -5
  304. package/es6/persisters/with-schemas/index.js +3 -3
  305. package/es6/queries/index.js +4 -1
  306. package/es6/queries/with-schemas/index.js +4 -1
  307. package/es6/store/index.js +14 -9
  308. package/es6/store/with-schemas/index.js +14 -9
  309. package/es6/tools/index.js +4 -4
  310. package/es6/tools/with-schemas/index.js +4 -4
  311. package/es6/ui-react-inspector/index.js +11 -9
  312. package/es6/ui-react-inspector/with-schemas/index.js +11 -9
  313. package/es6/with-schemas/index.js +13 -11
  314. package/index.js +13 -11
  315. package/mergeable-store/index.js +12 -10
  316. package/mergeable-store/with-schemas/index.js +12 -10
  317. package/min/index.js +1 -1
  318. package/min/index.js.gz +0 -0
  319. package/min/mergeable-store/index.js +1 -1
  320. package/min/mergeable-store/index.js.gz +0 -0
  321. package/min/mergeable-store/with-schemas/index.js +1 -1
  322. package/min/mergeable-store/with-schemas/index.js.gz +0 -0
  323. package/min/persisters/index.js +1 -1
  324. package/min/persisters/index.js.gz +0 -0
  325. package/min/persisters/persister-automerge/index.js +1 -1
  326. package/min/persisters/persister-automerge/index.js.gz +0 -0
  327. package/min/persisters/persister-automerge/with-schemas/index.js +1 -1
  328. package/min/persisters/persister-automerge/with-schemas/index.js.gz +0 -0
  329. package/min/persisters/persister-cr-sqlite-wasm/index.js +1 -1
  330. package/min/persisters/persister-cr-sqlite-wasm/index.js.gz +0 -0
  331. package/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.js +1 -1
  332. package/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.js.gz +0 -0
  333. package/min/persisters/persister-electric-sql/index.js +1 -1
  334. package/min/persisters/persister-electric-sql/index.js.gz +0 -0
  335. package/min/persisters/persister-electric-sql/with-schemas/index.js +1 -1
  336. package/min/persisters/persister-electric-sql/with-schemas/index.js.gz +0 -0
  337. package/min/persisters/persister-expo-sqlite/index.js +1 -1
  338. package/min/persisters/persister-expo-sqlite/index.js.gz +0 -0
  339. package/min/persisters/persister-expo-sqlite/with-schemas/index.js +1 -1
  340. package/min/persisters/persister-expo-sqlite/with-schemas/index.js.gz +0 -0
  341. package/min/persisters/persister-libsql/index.js +1 -1
  342. package/min/persisters/persister-libsql/index.js.gz +0 -0
  343. package/min/persisters/persister-libsql/with-schemas/index.js +1 -1
  344. package/min/persisters/persister-libsql/with-schemas/index.js.gz +0 -0
  345. package/min/persisters/persister-pglite/index.js +1 -1
  346. package/min/persisters/persister-pglite/index.js.gz +0 -0
  347. package/min/persisters/persister-pglite/with-schemas/index.js +1 -1
  348. package/min/persisters/persister-pglite/with-schemas/index.js.gz +0 -0
  349. package/min/persisters/persister-postgres/index.js +1 -1
  350. package/min/persisters/persister-postgres/index.js.gz +0 -0
  351. package/min/persisters/persister-postgres/with-schemas/index.js +1 -1
  352. package/min/persisters/persister-postgres/with-schemas/index.js.gz +0 -0
  353. package/min/persisters/persister-powersync/index.js +1 -1
  354. package/min/persisters/persister-powersync/index.js.gz +0 -0
  355. package/min/persisters/persister-powersync/with-schemas/index.js +1 -1
  356. package/min/persisters/persister-powersync/with-schemas/index.js.gz +0 -0
  357. package/min/persisters/persister-sqlite-wasm/index.js +1 -1
  358. package/min/persisters/persister-sqlite-wasm/index.js.gz +0 -0
  359. package/min/persisters/persister-sqlite-wasm/with-schemas/index.js +1 -1
  360. package/min/persisters/persister-sqlite-wasm/with-schemas/index.js.gz +0 -0
  361. package/min/persisters/persister-sqlite3/index.js +1 -1
  362. package/min/persisters/persister-sqlite3/index.js.gz +0 -0
  363. package/min/persisters/persister-sqlite3/with-schemas/index.js +1 -1
  364. package/min/persisters/persister-sqlite3/with-schemas/index.js.gz +0 -0
  365. package/min/persisters/persister-yjs/index.js +1 -1
  366. package/min/persisters/persister-yjs/index.js.gz +0 -0
  367. package/min/persisters/persister-yjs/with-schemas/index.js +1 -1
  368. package/min/persisters/persister-yjs/with-schemas/index.js.gz +0 -0
  369. package/min/persisters/with-schemas/index.js +1 -1
  370. package/min/persisters/with-schemas/index.js.gz +0 -0
  371. package/min/queries/index.js +1 -1
  372. package/min/queries/index.js.gz +0 -0
  373. package/min/queries/with-schemas/index.js +1 -1
  374. package/min/queries/with-schemas/index.js.gz +0 -0
  375. package/min/store/index.js +1 -1
  376. package/min/store/index.js.gz +0 -0
  377. package/min/store/with-schemas/index.js +1 -1
  378. package/min/store/with-schemas/index.js.gz +0 -0
  379. package/min/ui-react-inspector/index.js +1 -1
  380. package/min/ui-react-inspector/index.js.gz +0 -0
  381. package/min/ui-react-inspector/with-schemas/index.js +1 -1
  382. package/min/ui-react-inspector/with-schemas/index.js.gz +0 -0
  383. package/min/with-schemas/index.js +1 -1
  384. package/min/with-schemas/index.js.gz +0 -0
  385. package/package.json +7 -7
  386. package/persisters/index.js +3 -3
  387. package/persisters/persister-automerge/index.js +8 -6
  388. package/persisters/persister-automerge/with-schemas/index.js +8 -6
  389. package/persisters/persister-cr-sqlite-wasm/index.js +3 -3
  390. package/persisters/persister-cr-sqlite-wasm/with-schemas/index.js +3 -3
  391. package/persisters/persister-electric-sql/index.js +3 -3
  392. package/persisters/persister-electric-sql/with-schemas/index.js +3 -3
  393. package/persisters/persister-expo-sqlite/index.js +3 -3
  394. package/persisters/persister-expo-sqlite/with-schemas/index.js +3 -3
  395. package/persisters/persister-libsql/index.js +3 -3
  396. package/persisters/persister-libsql/with-schemas/index.js +3 -3
  397. package/persisters/persister-pglite/index.js +3 -3
  398. package/persisters/persister-pglite/with-schemas/index.js +3 -3
  399. package/persisters/persister-postgres/index.js +3 -3
  400. package/persisters/persister-postgres/with-schemas/index.js +3 -3
  401. package/persisters/persister-powersync/index.js +3 -3
  402. package/persisters/persister-powersync/with-schemas/index.js +3 -3
  403. package/persisters/persister-sqlite-wasm/index.js +3 -3
  404. package/persisters/persister-sqlite-wasm/with-schemas/index.js +3 -3
  405. package/persisters/persister-sqlite3/index.js +3 -3
  406. package/persisters/persister-sqlite3/with-schemas/index.js +3 -3
  407. package/persisters/persister-yjs/index.js +7 -5
  408. package/persisters/persister-yjs/with-schemas/index.js +7 -5
  409. package/persisters/with-schemas/index.js +3 -3
  410. package/queries/index.js +4 -1
  411. package/queries/with-schemas/index.js +4 -1
  412. package/readme.md +2 -2
  413. package/store/index.js +14 -9
  414. package/store/with-schemas/index.js +14 -9
  415. package/tools/index.js +4 -4
  416. package/tools/with-schemas/index.js +4 -4
  417. package/ui-react-inspector/index.js +11 -9
  418. package/ui-react-inspector/with-schemas/index.js +11 -9
  419. package/umd/es6/index.js +13 -11
  420. package/umd/es6/mergeable-store/index.js +12 -10
  421. package/umd/es6/mergeable-store/with-schemas/index.js +12 -10
  422. package/umd/es6/min/index.js +1 -1
  423. package/umd/es6/min/index.js.gz +0 -0
  424. package/umd/es6/min/mergeable-store/index.js +1 -1
  425. package/umd/es6/min/mergeable-store/index.js.gz +0 -0
  426. package/umd/es6/min/mergeable-store/with-schemas/index.js +1 -1
  427. package/umd/es6/min/mergeable-store/with-schemas/index.js.gz +0 -0
  428. package/umd/es6/min/persisters/index.js +1 -1
  429. package/umd/es6/min/persisters/index.js.gz +0 -0
  430. package/umd/es6/min/persisters/persister-automerge/index.js +1 -1
  431. package/umd/es6/min/persisters/persister-automerge/index.js.gz +0 -0
  432. package/umd/es6/min/persisters/persister-automerge/with-schemas/index.js +1 -1
  433. package/umd/es6/min/persisters/persister-automerge/with-schemas/index.js.gz +0 -0
  434. package/umd/es6/min/persisters/persister-cr-sqlite-wasm/index.js +1 -1
  435. package/umd/es6/min/persisters/persister-cr-sqlite-wasm/index.js.gz +0 -0
  436. package/umd/es6/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.js +1 -1
  437. package/umd/es6/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.js.gz +0 -0
  438. package/umd/es6/min/persisters/persister-electric-sql/index.js +1 -1
  439. package/umd/es6/min/persisters/persister-electric-sql/index.js.gz +0 -0
  440. package/umd/es6/min/persisters/persister-electric-sql/with-schemas/index.js +1 -1
  441. package/umd/es6/min/persisters/persister-electric-sql/with-schemas/index.js.gz +0 -0
  442. package/umd/es6/min/persisters/persister-expo-sqlite/index.js +1 -1
  443. package/umd/es6/min/persisters/persister-expo-sqlite/index.js.gz +0 -0
  444. package/umd/es6/min/persisters/persister-expo-sqlite/with-schemas/index.js +1 -1
  445. package/umd/es6/min/persisters/persister-expo-sqlite/with-schemas/index.js.gz +0 -0
  446. package/umd/es6/min/persisters/persister-libsql/index.js +1 -1
  447. package/umd/es6/min/persisters/persister-libsql/index.js.gz +0 -0
  448. package/umd/es6/min/persisters/persister-libsql/with-schemas/index.js +1 -1
  449. package/umd/es6/min/persisters/persister-libsql/with-schemas/index.js.gz +0 -0
  450. package/umd/es6/min/persisters/persister-pglite/index.js +1 -1
  451. package/umd/es6/min/persisters/persister-pglite/index.js.gz +0 -0
  452. package/umd/es6/min/persisters/persister-pglite/with-schemas/index.js +1 -1
  453. package/umd/es6/min/persisters/persister-pglite/with-schemas/index.js.gz +0 -0
  454. package/umd/es6/min/persisters/persister-postgres/index.js +1 -1
  455. package/umd/es6/min/persisters/persister-postgres/index.js.gz +0 -0
  456. package/umd/es6/min/persisters/persister-postgres/with-schemas/index.js +1 -1
  457. package/umd/es6/min/persisters/persister-postgres/with-schemas/index.js.gz +0 -0
  458. package/umd/es6/min/persisters/persister-powersync/index.js +1 -1
  459. package/umd/es6/min/persisters/persister-powersync/index.js.gz +0 -0
  460. package/umd/es6/min/persisters/persister-powersync/with-schemas/index.js +1 -1
  461. package/umd/es6/min/persisters/persister-powersync/with-schemas/index.js.gz +0 -0
  462. package/umd/es6/min/persisters/persister-sqlite-wasm/index.js +1 -1
  463. package/umd/es6/min/persisters/persister-sqlite-wasm/index.js.gz +0 -0
  464. package/umd/es6/min/persisters/persister-sqlite-wasm/with-schemas/index.js +1 -1
  465. package/umd/es6/min/persisters/persister-sqlite-wasm/with-schemas/index.js.gz +0 -0
  466. package/umd/es6/min/persisters/persister-sqlite3/index.js +1 -1
  467. package/umd/es6/min/persisters/persister-sqlite3/index.js.gz +0 -0
  468. package/umd/es6/min/persisters/persister-sqlite3/with-schemas/index.js +1 -1
  469. package/umd/es6/min/persisters/persister-sqlite3/with-schemas/index.js.gz +0 -0
  470. package/umd/es6/min/persisters/persister-yjs/index.js +1 -1
  471. package/umd/es6/min/persisters/persister-yjs/index.js.gz +0 -0
  472. package/umd/es6/min/persisters/persister-yjs/with-schemas/index.js +1 -1
  473. package/umd/es6/min/persisters/persister-yjs/with-schemas/index.js.gz +0 -0
  474. package/umd/es6/min/persisters/with-schemas/index.js +1 -1
  475. package/umd/es6/min/persisters/with-schemas/index.js.gz +0 -0
  476. package/umd/es6/min/queries/index.js +1 -1
  477. package/umd/es6/min/queries/index.js.gz +0 -0
  478. package/umd/es6/min/queries/with-schemas/index.js +1 -1
  479. package/umd/es6/min/queries/with-schemas/index.js.gz +0 -0
  480. package/umd/es6/min/store/index.js +1 -1
  481. package/umd/es6/min/store/index.js.gz +0 -0
  482. package/umd/es6/min/store/with-schemas/index.js +1 -1
  483. package/umd/es6/min/store/with-schemas/index.js.gz +0 -0
  484. package/umd/es6/min/ui-react-inspector/index.js +1 -1
  485. package/umd/es6/min/ui-react-inspector/index.js.gz +0 -0
  486. package/umd/es6/min/ui-react-inspector/with-schemas/index.js +1 -1
  487. package/umd/es6/min/ui-react-inspector/with-schemas/index.js.gz +0 -0
  488. package/umd/es6/min/with-schemas/index.js +1 -1
  489. package/umd/es6/min/with-schemas/index.js.gz +0 -0
  490. package/umd/es6/persisters/index.js +3 -3
  491. package/umd/es6/persisters/persister-automerge/index.js +8 -6
  492. package/umd/es6/persisters/persister-automerge/with-schemas/index.js +8 -6
  493. package/umd/es6/persisters/persister-cr-sqlite-wasm/index.js +3 -3
  494. package/umd/es6/persisters/persister-cr-sqlite-wasm/with-schemas/index.js +3 -3
  495. package/umd/es6/persisters/persister-electric-sql/index.js +3 -3
  496. package/umd/es6/persisters/persister-electric-sql/with-schemas/index.js +3 -3
  497. package/umd/es6/persisters/persister-expo-sqlite/index.js +3 -3
  498. package/umd/es6/persisters/persister-expo-sqlite/with-schemas/index.js +3 -3
  499. package/umd/es6/persisters/persister-libsql/index.js +3 -3
  500. package/umd/es6/persisters/persister-libsql/with-schemas/index.js +3 -3
  501. package/umd/es6/persisters/persister-pglite/index.js +3 -3
  502. package/umd/es6/persisters/persister-pglite/with-schemas/index.js +3 -3
  503. package/umd/es6/persisters/persister-postgres/index.js +3 -3
  504. package/umd/es6/persisters/persister-postgres/with-schemas/index.js +3 -3
  505. package/umd/es6/persisters/persister-powersync/index.js +3 -3
  506. package/umd/es6/persisters/persister-powersync/with-schemas/index.js +3 -3
  507. package/umd/es6/persisters/persister-sqlite-wasm/index.js +3 -3
  508. package/umd/es6/persisters/persister-sqlite-wasm/with-schemas/index.js +3 -3
  509. package/umd/es6/persisters/persister-sqlite3/index.js +3 -3
  510. package/umd/es6/persisters/persister-sqlite3/with-schemas/index.js +3 -3
  511. package/umd/es6/persisters/persister-yjs/index.js +7 -5
  512. package/umd/es6/persisters/persister-yjs/with-schemas/index.js +7 -5
  513. package/umd/es6/persisters/with-schemas/index.js +3 -3
  514. package/umd/es6/queries/index.js +4 -1
  515. package/umd/es6/queries/with-schemas/index.js +4 -1
  516. package/umd/es6/store/index.js +14 -9
  517. package/umd/es6/store/with-schemas/index.js +14 -9
  518. package/umd/es6/tools/index.js +4 -4
  519. package/umd/es6/tools/with-schemas/index.js +4 -4
  520. package/umd/es6/ui-react-inspector/index.js +11 -9
  521. package/umd/es6/ui-react-inspector/with-schemas/index.js +11 -9
  522. package/umd/es6/with-schemas/index.js +13 -11
  523. package/umd/index.js +13 -11
  524. package/umd/mergeable-store/index.js +12 -10
  525. package/umd/mergeable-store/with-schemas/index.js +12 -10
  526. package/umd/min/index.js +1 -1
  527. package/umd/min/index.js.gz +0 -0
  528. package/umd/min/mergeable-store/index.js +1 -1
  529. package/umd/min/mergeable-store/index.js.gz +0 -0
  530. package/umd/min/mergeable-store/with-schemas/index.js +1 -1
  531. package/umd/min/mergeable-store/with-schemas/index.js.gz +0 -0
  532. package/umd/min/persisters/index.js +1 -1
  533. package/umd/min/persisters/index.js.gz +0 -0
  534. package/umd/min/persisters/persister-automerge/index.js +1 -1
  535. package/umd/min/persisters/persister-automerge/index.js.gz +0 -0
  536. package/umd/min/persisters/persister-automerge/with-schemas/index.js +1 -1
  537. package/umd/min/persisters/persister-automerge/with-schemas/index.js.gz +0 -0
  538. package/umd/min/persisters/persister-cr-sqlite-wasm/index.js +1 -1
  539. package/umd/min/persisters/persister-cr-sqlite-wasm/index.js.gz +0 -0
  540. package/umd/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.js +1 -1
  541. package/umd/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.js.gz +0 -0
  542. package/umd/min/persisters/persister-electric-sql/index.js +1 -1
  543. package/umd/min/persisters/persister-electric-sql/index.js.gz +0 -0
  544. package/umd/min/persisters/persister-electric-sql/with-schemas/index.js +1 -1
  545. package/umd/min/persisters/persister-electric-sql/with-schemas/index.js.gz +0 -0
  546. package/umd/min/persisters/persister-expo-sqlite/index.js +1 -1
  547. package/umd/min/persisters/persister-expo-sqlite/index.js.gz +0 -0
  548. package/umd/min/persisters/persister-expo-sqlite/with-schemas/index.js +1 -1
  549. package/umd/min/persisters/persister-expo-sqlite/with-schemas/index.js.gz +0 -0
  550. package/umd/min/persisters/persister-libsql/index.js +1 -1
  551. package/umd/min/persisters/persister-libsql/index.js.gz +0 -0
  552. package/umd/min/persisters/persister-libsql/with-schemas/index.js +1 -1
  553. package/umd/min/persisters/persister-libsql/with-schemas/index.js.gz +0 -0
  554. package/umd/min/persisters/persister-pglite/index.js +1 -1
  555. package/umd/min/persisters/persister-pglite/index.js.gz +0 -0
  556. package/umd/min/persisters/persister-pglite/with-schemas/index.js +1 -1
  557. package/umd/min/persisters/persister-pglite/with-schemas/index.js.gz +0 -0
  558. package/umd/min/persisters/persister-postgres/index.js +1 -1
  559. package/umd/min/persisters/persister-postgres/index.js.gz +0 -0
  560. package/umd/min/persisters/persister-postgres/with-schemas/index.js +1 -1
  561. package/umd/min/persisters/persister-postgres/with-schemas/index.js.gz +0 -0
  562. package/umd/min/persisters/persister-powersync/index.js +1 -1
  563. package/umd/min/persisters/persister-powersync/index.js.gz +0 -0
  564. package/umd/min/persisters/persister-powersync/with-schemas/index.js +1 -1
  565. package/umd/min/persisters/persister-powersync/with-schemas/index.js.gz +0 -0
  566. package/umd/min/persisters/persister-sqlite-wasm/index.js +1 -1
  567. package/umd/min/persisters/persister-sqlite-wasm/index.js.gz +0 -0
  568. package/umd/min/persisters/persister-sqlite-wasm/with-schemas/index.js +1 -1
  569. package/umd/min/persisters/persister-sqlite-wasm/with-schemas/index.js.gz +0 -0
  570. package/umd/min/persisters/persister-sqlite3/index.js +1 -1
  571. package/umd/min/persisters/persister-sqlite3/index.js.gz +0 -0
  572. package/umd/min/persisters/persister-sqlite3/with-schemas/index.js +1 -1
  573. package/umd/min/persisters/persister-sqlite3/with-schemas/index.js.gz +0 -0
  574. package/umd/min/persisters/persister-yjs/index.js +1 -1
  575. package/umd/min/persisters/persister-yjs/index.js.gz +0 -0
  576. package/umd/min/persisters/persister-yjs/with-schemas/index.js +1 -1
  577. package/umd/min/persisters/persister-yjs/with-schemas/index.js.gz +0 -0
  578. package/umd/min/persisters/with-schemas/index.js +1 -1
  579. package/umd/min/persisters/with-schemas/index.js.gz +0 -0
  580. package/umd/min/queries/index.js +1 -1
  581. package/umd/min/queries/index.js.gz +0 -0
  582. package/umd/min/queries/with-schemas/index.js +1 -1
  583. package/umd/min/queries/with-schemas/index.js.gz +0 -0
  584. package/umd/min/store/index.js +1 -1
  585. package/umd/min/store/index.js.gz +0 -0
  586. package/umd/min/store/with-schemas/index.js +1 -1
  587. package/umd/min/store/with-schemas/index.js.gz +0 -0
  588. package/umd/min/ui-react-inspector/index.js +1 -1
  589. package/umd/min/ui-react-inspector/index.js.gz +0 -0
  590. package/umd/min/ui-react-inspector/with-schemas/index.js +1 -1
  591. package/umd/min/ui-react-inspector/with-schemas/index.js.gz +0 -0
  592. package/umd/min/with-schemas/index.js +1 -1
  593. package/umd/min/with-schemas/index.js.gz +0 -0
  594. package/umd/persisters/index.js +3 -3
  595. package/umd/persisters/persister-automerge/index.js +8 -6
  596. package/umd/persisters/persister-automerge/with-schemas/index.js +8 -6
  597. package/umd/persisters/persister-cr-sqlite-wasm/index.js +3 -3
  598. package/umd/persisters/persister-cr-sqlite-wasm/with-schemas/index.js +3 -3
  599. package/umd/persisters/persister-electric-sql/index.js +3 -3
  600. package/umd/persisters/persister-electric-sql/with-schemas/index.js +3 -3
  601. package/umd/persisters/persister-expo-sqlite/index.js +3 -3
  602. package/umd/persisters/persister-expo-sqlite/with-schemas/index.js +3 -3
  603. package/umd/persisters/persister-libsql/index.js +3 -3
  604. package/umd/persisters/persister-libsql/with-schemas/index.js +3 -3
  605. package/umd/persisters/persister-pglite/index.js +3 -3
  606. package/umd/persisters/persister-pglite/with-schemas/index.js +3 -3
  607. package/umd/persisters/persister-postgres/index.js +3 -3
  608. package/umd/persisters/persister-postgres/with-schemas/index.js +3 -3
  609. package/umd/persisters/persister-powersync/index.js +3 -3
  610. package/umd/persisters/persister-powersync/with-schemas/index.js +3 -3
  611. package/umd/persisters/persister-sqlite-wasm/index.js +3 -3
  612. package/umd/persisters/persister-sqlite-wasm/with-schemas/index.js +3 -3
  613. package/umd/persisters/persister-sqlite3/index.js +3 -3
  614. package/umd/persisters/persister-sqlite3/with-schemas/index.js +3 -3
  615. package/umd/persisters/persister-yjs/index.js +7 -5
  616. package/umd/persisters/persister-yjs/with-schemas/index.js +7 -5
  617. package/umd/persisters/with-schemas/index.js +3 -3
  618. package/umd/queries/index.js +4 -1
  619. package/umd/queries/with-schemas/index.js +4 -1
  620. package/umd/store/index.js +14 -9
  621. package/umd/store/with-schemas/index.js +14 -9
  622. package/umd/tools/index.js +4 -4
  623. package/umd/tools/with-schemas/index.js +4 -4
  624. package/umd/ui-react-inspector/index.js +11 -9
  625. package/umd/ui-react-inspector/with-schemas/index.js +11 -9
  626. package/umd/with-schemas/index.js +13 -11
  627. package/with-schemas/index.js +13 -11
@@ -1 +1 @@
1
- const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),r=Promise,o=clearInterval,i=a=>null==a,c=(a,t,e)=>i(a)?e?.():t(a),l=t=>a(t)==s,w=a=>Array.isArray(a),u=(a,t,e)=>a.slice(t,e),y=a=>a.length,d=async a=>r.all(a),E=a=>{throw Error(a)},v=(a,t)=>a.forEach(t),g=(a,t="")=>a.join(t),p=(a,t)=>a.map(t),A=a=>0==y(a),h=(a,t)=>a.filter(t),N=(a,...t)=>a.push(...t),f=a=>a.shift(),m=Object,S=a=>m.getPrototypeOf(a),T=m.entries,C=m.keys,$=m.freeze,O=(a=[])=>m.fromEntries(a),b=(...a)=>m.assign({},...a),I=(a,t)=>(delete a[t],a),L=(a,t)=>p(T(a),(([a,e])=>t(e,a))),R=a=>m.values(a),D=a=>y(C(a)),M=a=>(a=>!i(a)&&c(S(a),(a=>a==m.prototype||i(S(a))),(()=>!0)))(a)&&0==D(a),_=a=>new Set(w(a)||i(a)?a:[a]),P=(a,t)=>a?.add(t),F="_",U="_id",j="SELECT",x="WHERE",B="TABLE",H="ALTER "+B,J="DELETE FROM",Y=j+"*FROM",k="pragma_",z="data_version",G="schema_version",V="pragma_table_",W=a=>`"${a.replace(/"/g,'""')}"`,K=(...a)=>g(p(a,W),n),Q=(a,t=[1])=>g(p(a,(()=>"$"+t[0]++)),n),X=(a,t)=>a?.has(t)??!1,q=a=>i(a)||0==(a=>a?.size??0)(a),Z=a=>[...a?.values()??[]],aa=(a,t)=>a?.forEach(t),ta=(a,t)=>a?.delete(t),ea=JSON.stringify,na=JSON.parse,sa=a=>new Map(a),ra=(a,t)=>a?.get(t),oa=(a,t)=>p([...a?.entries()??[]],(([a,e])=>t(e,a))),ia=(a,t,e)=>i(e)?(ta(a,t),a):a?.set(t,e),ca=(a,t,e,n)=>(X(a,t)?n?.(ra(a,t)):ia(a,t,e()),ra(a,t)),la=(a,t,e,n,s=0)=>c((e?ca:ra)(a,t[s],s>y(t)-2?e:sa),(r=>{if(s>y(t)-2)return n?.(r)&&ia(a,t[s]),r;const o=la(r,t,e,n,s+1);return q(r)&&ia(a,t[s]),o})),wa=/^\d+$/,ua=sa(),ya=sa(),da=(a,t,n,s,r,o,l,u={},d=0,g=[])=>{let p,A,h,m=0,S=0,T=0;ca(ua,g,(()=>0)),ca(ya,g,(()=>[]));const C=sa(),[O,b,I,L,R]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!M(a)||!M(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!M(a)||!M(t),t.setContent]:E("Store type not supported by this Persister"))(l,a,d),[D,F,U]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?f(a):null)??e+t++,t=>{wa.test(t)&&y(a)<1e3&&N(a,t)}]})(),s=sa();return[(n,r,o,i=[],c=()=>[])=>{a??=z;const l=t(1);return ia(s,l,[n,r,o,i,c]),P(la(r,o??[e],_),l),l},(t,n,...r)=>v(((a,t=[e])=>{const n=[],s=(a,e)=>e==y(t)?N(n,a):null===t[e]?aa(a,(a=>s(a,e+1))):v([t[e],null],(t=>s(ra(a,t),e+1)));return s(a,0),n})(t,n),(t=>aa(t,(t=>ra(s,t)[0](a,...n??[],...r))))),a=>c(ra(s,a),(([,t,r])=>(la(t,r??[e],void 0,(t=>(ta(t,a),q(t)?1:0))),ia(s,a),n(a),r))),t=>c(ra(s,t),(([t,,e=[],n,s])=>{const r=(...o)=>{const c=y(o);c==y(e)?t(a,...o,...s(o)):i(e[c])?v(n[c]?.(...o)??[],(a=>r(...o,a))):r(...o,e[c])};r()}))]})(),j=a=>{a!=m&&(m=a,F(C,void 0,m))},x=t=>{(O&&w(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},B=async a=>(2!=m&&(j(1),S++,await k((async()=>{try{const e=await t();w(e)?x(e):a?R(a):E("Content is not an array: "+e)}catch(t){o?.(t),a&&R(a)}j(0)}))),z),H=()=>(A&&(r(A),A=void 0),z),J=async a=>(1!=m&&(j(2),T++,await k((async()=>{try{await n(b,a)}catch(a){o?.(a)}j(0)}))),z),Y=()=>(h&&(a.delListener(h),h=void 0),z),k=async(...a)=>(N(ra(ya,g),...a),await(async()=>{if(!ra(ua,g)){for(ia(ua,g,1);!i(p=f(ra(ya,g)));)try{await p()}catch(a){o?.(a)}ia(ua,g,0)}})(),z),z={load:B,startAutoLoad:async a=>{H(),await B(a);try{A=await s((async(a,t)=>{t||a?2!=m&&(j(1),S++,x(t??a),j(0)):await B()}))}catch(a){o?.(a)}return z},stopAutoLoad:H,isAutoLoading:()=>!i(A),save:J,startAutoSave:async()=>(Y(),await J(),h=a.addDidFinishTransactionListener((()=>{const a=I();L(a)&&J(a)})),z),stopAutoSave:Y,isAutoSaving:()=>!i(h),getStatus:()=>m,addStatusListener:a=>D(a,C),delListener:t=>(U(t),a),schedule:k,getStore:()=>a,destroy:()=>(ra(ya,g).splice(0,void 0),H().stopAutoSave()),getStats:()=>({loads:S,saves:T}),...u};return $(z)},Ea=(a,t,e,s,r,o=va,c,l)=>{const w=sa();return[async()=>{w.clear(),p(await e(a,t),(({tn:a,cn:t})=>P(ca(w,a,_),t)))},async(t,e)=>((a,t)=>X(ra(w,a),t))(t,e)?O(h(p(await a(Y+W(t)),(a=>{return[a[e],l?(t=I(a,e),n=l,O(L(t,((a,t)=>[t,n(a,t)])))):I(a,e)];var t,n})),(([a,t])=>!i(a)&&!M(t)))):{},async(t,e,s,l,u,y=!1)=>{const E=_();L(s??{},(a=>p(C(a??{}),(a=>P(E,a)))));const v=Z(E);if(!y&&u&&A(v)&&X(w,t))return await a("DROP "+B+W(t)),void ia(w,t);const f=ra(w,t),m=_(Z(f));if(A(v)||(X(w,t)?await d(p([e,...v],(async(n,s)=>{ta(m,n)||(await a(H+W(t)+"ADD"+W(n)+r),0==s&&await a("CREATE UNIQUE INDEX pk ON "+W(t)+`(${W(e)})`),P(f,n))}))):(await a("CREATE "+B+W(t)+`(${W(e)}${r} PRIMARY KEY${g(p(v,(a=>n+W(a)+r)))});`),ia(w,t,_([e,...v])))),await d([...!y&&l?p(Z(m),(async n=>{n!=e&&(await a(H+W(t)+"DROP"+W(n)),ta(f,n))})):[]]),y)i(s)?await a(J+W(t)+x+" true"):await d(L(s,(async(n,s)=>{i(n)?await a(J+W(t)+x+W(e)+"=$1",[s]):A(v)||await o(a,t,e,C(n),{[s]:c?p(R(n),c):R(n)},f)})));else if(A(v))X(w,t)&&await a(J+W(t)+x+" true");else{const n=h(Z(ra(w,t)),(a=>a!=e)),r={},i=[];L(s??{},((a,t)=>{r[t]=p(n,(t=>c?c(a?.[t]):a?.[t])),N(i,t)})),await o(a,t,e,n,r),await a(J+W(t)+x+W(e)+`NOT IN(${Q(i)})`,i)}},async t=>{let e;await a("BEGIN");try{e=await t()}catch(a){s?.(a)}return await a("END"),e}]},va=async(a,t,e,s,r)=>{const o=[1];await a("INSERT INTO"+W(t)+"("+K(e,...s)+")VALUES"+g(L(r,(a=>"($"+o[0]+++","+Q(a,o)+")")),n)+"ON CONFLICT("+W(e)+")DO UPDATE SET"+g(p(s,(a=>W(a)+"=excluded."+W(a))),n),L(r,((a,t)=>[t,...p(a,(a=>a??null))])).flat())},ga=(a,t,e,n,s,r,o,[i,c,l],w,u,y,d,E,v)=>{const[g,p,A,h]=Ea(t,w,u,s,E,v),N=da(a,(async()=>await h((async()=>{return await g(),a=(await p(i,c))[F]?.[l]??"null",na(a,((a,t)=>""===t?void 0:t));var a}))),(async a=>await h((async()=>{var t;await g(),await A(i,c,{[F]:{[l]:(t=a()??null,ea(t,((a,t)=>void 0===t?"":t)))}},!0,!0)}))),e,n,s,o,{[d]:()=>y,destroy:()=>(N.stopAutoLoad().stopAutoSave(),r(),N)},0,y);return N},pa=(a,t,e,n,s,r,o,[c,l,[w,u,y]],E,v,g,p,A,N,f,m)=>{const[S,T,C,$]=Ea(t,E,v,s,A,N,f,m),b=async(a,t)=>await d(oa(l,(async([e,n,s,r],o)=>{t&&!(o in a)||await C(e,n,a[o],s,r,t)}))),I=async(a,t)=>u?await C(y,U,{[F]:a},!0,!0,t):null,L=da(a,(async()=>await $((async()=>{await S();const a=await(async()=>O(h(await d(oa(c,(async([a,t],e)=>[a,await T(e,t)]))),(a=>!M(a[1])))))(),t=await(async()=>w?(await T(y,U))[F]:{})();return M(a)&&i(t)?void 0:[a,t]}))),(async(a,t)=>await $((async()=>{if(await S(),i(t)){const[t,e]=a();await b(t),await I(e)}else await b(t[0],!0),await I(t[1],!0)}))),e,n,s,o,{[p]:()=>g,destroy:()=>(L.stopAutoLoad().stopAutoSave(),r(),L)},0,g);return L},Aa="ColumnName",ha="store",Na="json",fa=ha+"TableName",ma=ha+"Id"+Aa,Sa=ha+Aa,Ta="autoLoadIntervalSeconds",Ca="rowId"+Aa,$a="tableId",Oa="tableName",ba="deleteEmptyColumns",Ia="deleteEmptyTable",La={mode:Na,[Ta]:1},Ra={load:0,save:0,[Oa]:t+"_values"},Da=(a,t,e,n,s)=>{const r=sa();return L(a,((a,o)=>{const c=u(R(b(t,l(a)?{[e]:a}:a)),0,D(t));i(c[0])||n(o,c[0])||(s(o,c[0]),ia(r,o,c))})),r},Ma=(a,n,s,r,i,c,w,y,d,E,v="getDb",g)=>{let p,A,h;const N=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,c),[f,m,S,T]=(a=>{const e=(a=>b(La,l(a)?{[fa]:a}:a??{}))(a),n=e[Ta];if(e.mode==Na){const a=e[fa]??t;return[1,n,[a,e[ma]??U,e[Sa]??ha],_(a)]}const{tables:{load:s={},save:r={}}={},values:o={}}=e,i=u(R(b(Ra,o)),0,D(Ra)),c=i[2],w=_(c),y=_(c);return[0,n,[Da(s,{[$a]:null,[Ca]:U},$a,(a=>X(y,a)),(a=>P(w,a))),Da(r,{[Oa]:null,[Ca]:U,[ba]:0,[Ia]:0},Oa,((a,t)=>X(y,t)),((a,t)=>P(w,t))),i],w]})(n);return(f?ga:pa)(a,N,(a=>{let t;const e=()=>t=setInterval((async()=>{try{const[{d:t,s:e,c:n}]=await N(`${j} ${z} d,${G} s,TOTAL_CHANGES() c FROM ${k}${z} JOIN ${k}${G}`);t==p&&e==A&&n==h||(null!=p&&a(),p=t,A=e,h=n)}catch{}}),1e3*m),n=()=>{p=A=h=null,o(t)},s=r((t=>{T.has(t)&&(n(),a(),e())}));return e(),()=>{n(),i(s)}}),(a=>a()),w,y,d,S,Z(T),(async(a,t)=>await a(`${j} t.name tn,c.name cn FROM ${V}list()t,${V}info(t.name)c ${x} t.schema='main'AND t.type IN('table','view')AND t.name IN(${Q(t)})ORDER BY t.name,c.name`,t)),E,v,e,g,(a=>!0===a?1:!1===a?0:a),void 0)},_a=(a,t,e,n,s)=>{let r;return Ma(a,e,(async(a,e=[])=>t.execute(a,e).then((a=>a.rows?._array??[]))),(a=>{const e=new AbortController,n=t.onChange({rawTableNames:!0,signal:e.signal});return(async()=>{for await(const a of n)r&&p(a.changedTables,r)})(),r=a,e}),(a=>{r=void 0,a.abort()}),n,s,(()=>0),1,t,"getPowerSync",Pa)},Pa=async(a,t,e,s,r,o)=>{const i=[1],c=_(s),l=o?h([...o],(a=>a!=e&&!X(c,a))):[];if(!A(l)){const n=C(r),s=O(p(await a("SELECT"+K(e,...l)+"FROM"+W(t)+"WHERE"+W(e)+"IN("+Q(n)+")",n),(a=>[a[e],a])));v(n,(a=>N(r[a],...p(l,(t=>s?.[a]?.[t]??null)))))}await a("INSERT OR REPLACE INTO"+W(t)+"("+K(e,...s,...l)+")VALUES"+g(L(r,(a=>"($"+i[0]+++","+Q(a,i)+")")),n),L(r,((a,t)=>[t,...p(a,(a=>a??null))])).flat())};export{_a as createPowerSyncPersister};
1
+ const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),o=Promise,r=clearInterval,i=a=>null==a,c=(a,t,e)=>i(a)?e?.():t(a),l=t=>a(t)==s,w=a=>Array.isArray(a),y=(a,t,e)=>a.slice(t,e),u=a=>a.length,d=async a=>o.all(a),E=a=>{throw Error(a)},v=(a,t)=>a.forEach(t),g=(a,t="")=>a.join(t),p=(a,t)=>a.map(t),A=a=>0==u(a),h=(a,t)=>a.filter(t),N=(a,...t)=>a.push(...t),f=a=>a.shift(),m=Object,S=a=>m.getPrototypeOf(a),T=m.entries,C=m.keys,$=m.freeze,O=(a=[])=>m.fromEntries(a),b=(...a)=>m.assign({},...a),I=(a,t)=>(delete a[t],a),L=(a,t)=>p(T(a),(([a,e])=>t(e,a))),R=(a,t)=>O(L(a,((a,e)=>[e,t(a,e)]))),D=a=>m.values(a),M=a=>u(C(a)),_=a=>(a=>!i(a)&&c(S(a),(a=>a==m.prototype||i(S(a))),(()=>!0)))(a)&&0==M(a),P=a=>new Set(w(a)||i(a)?a:[a]),F=(a,t)=>a?.add(t),U="_",j="_id",x="SELECT",B="WHERE",H="TABLE",J="ALTER "+H,Y="DELETE FROM",k=x+"*FROM",z="pragma_",G="data_version",V="schema_version",W="pragma_table_",K=a=>`"${a.replace(/"/g,'""')}"`,Q=(...a)=>g(p(a,K),n),X=(a,t=[1])=>g(p(a,(()=>"$"+t[0]++)),n),q=(a,t)=>a?.has(t)??!1,Z=a=>i(a)||0==(a=>a?.size??0)(a),aa=a=>[...a?.values()??[]],ta=(a,t)=>a?.forEach(t),ea=(a,t)=>a?.delete(t),na=JSON.stringify,sa=JSON.parse,oa=a=>new Map(a),ra=(a,t)=>a?.get(t),ia=(a,t)=>p([...a?.entries()??[]],(([a,e])=>t(e,a))),ca=(a,t,e)=>i(e)?(ea(a,t),a):a?.set(t,e),la=(a,t,e,n)=>(q(a,t)?n?.(ra(a,t)):ca(a,t,e()),ra(a,t)),wa=(a,t,e,n,s=0)=>c((e?la:ra)(a,t[s],s>u(t)-2?e:oa),(o=>{if(s>u(t)-2)return n?.(o)&&ca(a,t[s]),o;const r=wa(o,t,e,n,s+1);return Z(o)&&ca(a,t[s]),r})),ya=/^\d+$/,ua=oa(),da=oa(),Ea=(a,t,n,s,o,r,l,y={},d=0,g=[])=>{let p,A,h,m=0,S=0,T=0;la(ua,g,(()=>0)),la(da,g,(()=>[]));const C=oa(),[O,b,I,L,R]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!_(a)||!_(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!_(a)||!_(t),t.setContent]:E("Store type not supported by this Persister"))(l,a,d),[D,M,U]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?f(a):null)??e+t++,t=>{ya.test(t)&&u(a)<1e3&&N(a,t)}]})(),s=oa();return[(n,o,r,i=[],c=()=>[])=>{a??=z;const l=t(1);return ca(s,l,[n,o,r,i,c]),F(wa(o,r??[e],P),l),l},(t,n,...o)=>v(((a,t=[e])=>{const n=[],s=(a,e)=>e==u(t)?N(n,a):null===t[e]?ta(a,(a=>s(a,e+1))):v([t[e],null],(t=>s(ra(a,t),e+1)));return s(a,0),n})(t,n),(t=>ta(t,(t=>ra(s,t)[0](a,...n??[],...o))))),a=>c(ra(s,a),(([,t,o])=>(wa(t,o??[e],void 0,(t=>(ea(t,a),Z(t)?1:0))),ca(s,a),n(a),o))),t=>c(ra(s,t),(([t,,e=[],n,s])=>{const o=(...r)=>{const c=u(r);c==u(e)?t(a,...r,...s(r)):i(e[c])?v(n[c]?.(...r)??[],(a=>o(...r,a))):o(...r,e[c])};o()}))]})(),j=a=>{a!=m&&(m=a,M(C,void 0,m))},x=t=>{(O&&w(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},B=async a=>(2!=m&&(j(1),S++,await k((async()=>{try{const e=await t();w(e)?x(e):a?R(a):E("Content is not an array: "+e)}catch(t){r?.(t),a&&R(a)}j(0)}))),z),H=()=>(A&&(o(A),A=void 0),z),J=async a=>(1!=m&&(j(2),T++,await k((async()=>{try{await n(b,a)}catch(a){r?.(a)}j(0)}))),z),Y=()=>(h&&(a.delListener(h),h=void 0),z),k=async(...a)=>(N(ra(da,g),...a),await(async()=>{if(!ra(ua,g)){for(ca(ua,g,1);!i(p=f(ra(da,g)));)try{await p()}catch(a){r?.(a)}ca(ua,g,0)}})(),z),z={load:B,startAutoLoad:async a=>{H(),await B(a);try{A=await s((async(a,t)=>{t||a?2!=m&&(j(1),S++,x(t??a),j(0)):await B()}))}catch(a){r?.(a)}return z},stopAutoLoad:H,isAutoLoading:()=>!i(A),save:J,startAutoSave:async()=>(Y(),await J(),h=a.addDidFinishTransactionListener((()=>{const a=I();L(a)&&J(a)})),z),stopAutoSave:Y,isAutoSaving:()=>!i(h),getStatus:()=>m,addStatusListener:a=>D(a,C),delListener:t=>(U(t),a),schedule:k,getStore:()=>a,destroy:()=>(ra(da,g).splice(0,void 0),H().stopAutoSave()),getStats:()=>({loads:S,saves:T}),...y};return $(z)},va=(a,t,e,s,o,r=ga,c,l)=>{const w=oa();return[async()=>{w.clear(),p(await e(a,t),(({tn:a,cn:t})=>F(la(w,a,P),t)))},async(t,e)=>((a,t)=>q(ra(w,a),t))(t,e)?O(h(p(await a(k+K(t)),(a=>[a[e],l?R(I(a,e),l):I(a,e)])),(([a,t])=>!i(a)&&!_(t)))):{},async(t,e,s,l,y,u=!1)=>{const E=P();R(s??{},(a=>p(C(a??{}),(a=>F(E,a)))));const v=aa(E);if(!u&&y&&A(v)&&q(w,t))return await a("DROP "+H+K(t)),void ca(w,t);const f=ra(w,t),m=P(aa(f));if(A(v)||(q(w,t)?await d(p([e,...v],(async(n,s)=>{ea(m,n)||(await a(J+K(t)+"ADD"+K(n)+o),0==s&&await a("CREATE UNIQUE INDEX pk ON "+K(t)+`(${K(e)})`),F(f,n))}))):(await a("CREATE "+H+K(t)+`(${K(e)}${o} PRIMARY KEY${g(p(v,(a=>n+K(a)+o)))});`),ca(w,t,P([e,...v])))),await d([...!u&&l?p(aa(m),(async n=>{n!=e&&(await a(J+K(t)+"DROP"+K(n)),ea(f,n))})):[]]),u)i(s)?await a(Y+K(t)+B+" true"):await d(L(s,(async(n,s)=>{i(n)?await a(Y+K(t)+B+K(e)+"=$1",[s]):A(v)||await r(a,t,e,C(n),{[s]:c?p(D(n),c):D(n)},f)})));else if(A(v))q(w,t)&&await a(Y+K(t)+B+" true");else{const n=h(aa(ra(w,t)),(a=>a!=e)),o={},i=[];R(s??{},((a,t)=>{o[t]=p(n,(t=>c?c(a?.[t]):a?.[t])),N(i,t)})),await r(a,t,e,n,o),await a(Y+K(t)+B+K(e)+`NOT IN(${X(i)})`,i)}},async t=>{let e;await a("BEGIN");try{e=await t()}catch(a){s?.(a)}return await a("END"),e}]},ga=async(a,t,e,s,o)=>{const r=[1];await a("INSERT INTO"+K(t)+"("+Q(e,...s)+")VALUES"+g(L(o,(a=>"($"+r[0]+++","+X(a,r)+")")),n)+"ON CONFLICT("+K(e)+")DO UPDATE SET"+g(p(s,(a=>K(a)+"=excluded."+K(a))),n),L(o,((a,t)=>[t,...p(a,(a=>a??null))])).flat())},pa=(a,t,e,n,s,o,r,[i,c,l],w,y,u,d,E,v)=>{const[g,p,A,h]=va(t,w,y,s,E,v),N=Ea(a,(async()=>await h((async()=>{return await g(),a=(await p(i,c))[U]?.[l]??"null",sa(a,((a,t)=>""===t?void 0:t));var a}))),(async a=>await h((async()=>{var t;await g(),await A(i,c,{[U]:{[l]:(t=a()??null,na(t,((a,t)=>void 0===t?"":t)))}},!0,!0)}))),e,n,s,r,{[d]:()=>u,destroy:()=>(N.stopAutoLoad().stopAutoSave(),o(),N)},0,u);return N},Aa=(a,t,e,n,s,o,r,[c,l,[w,y,u]],E,v,g,p,A,N,f,m)=>{const[S,T,C,$]=va(t,E,v,s,A,N,f,m),b=async(a,t)=>await d(ia(l,(async([e,n,s,o],r)=>{t&&!(r in a)||await C(e,n,a[r],s,o,t)}))),I=async(a,t)=>y?await C(u,j,{[U]:a},!0,!0,t):null,L=Ea(a,(async()=>await $((async()=>{await S();const a=await(async()=>O(h(await d(ia(c,(async([a,t],e)=>[a,await T(e,t)]))),(a=>!_(a[1])))))(),t=await(async()=>w?(await T(u,j))[U]:{})();return _(a)&&i(t)?void 0:[a,t]}))),(async(a,t)=>await $((async()=>{if(await S(),i(t)){const[t,e]=a();await b(t),await I(e)}else await b(t[0],!0),await I(t[1],!0)}))),e,n,s,r,{[p]:()=>g,destroy:()=>(L.stopAutoLoad().stopAutoSave(),o(),L)},0,g);return L},ha="ColumnName",Na="store",fa="json",ma=Na+"TableName",Sa=Na+"Id"+ha,Ta=Na+ha,Ca="autoLoadIntervalSeconds",$a="rowId"+ha,Oa="tableId",ba="tableName",Ia="deleteEmptyColumns",La="deleteEmptyTable",Ra={mode:fa,[Ca]:1},Da={load:0,save:0,[ba]:t+"_values"},Ma=(a,t,e,n,s)=>{const o=oa();return R(a,((a,r)=>{const c=y(D(b(t,l(a)?{[e]:a}:a)),0,M(t));i(c[0])||n(r,c[0])||(s(r,c[0]),ca(o,r,c))})),o},_a=(a,n,s,o,i,c,w,u,d,E,v="getDb",g)=>{let p,A,h;const N=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,c),[f,m,S,T]=(a=>{const e=(a=>b(Ra,l(a)?{[ma]:a}:a??{}))(a),n=e[Ca];if(e.mode==fa){const a=e[ma]??t;return[1,n,[a,e[Sa]??j,e[Ta]??Na],P(a)]}const{tables:{load:s={},save:o={}}={},values:r={}}=e,i=y(D(b(Da,r)),0,M(Da)),c=i[2],w=P(c),u=P(c);return[0,n,[Ma(s,{[Oa]:null,[$a]:j},Oa,(a=>q(u,a)),(a=>F(w,a))),Ma(o,{[ba]:null,[$a]:j,[Ia]:0,[La]:0},ba,((a,t)=>q(u,t)),((a,t)=>F(w,t))),i],w]})(n);return(f?pa:Aa)(a,N,(a=>{let t;const e=()=>t=setInterval((async()=>{try{const[{d:t,s:e,c:n}]=await N(`${x} ${G} d,${V} s,TOTAL_CHANGES() c FROM ${z}${G} JOIN ${z}${V}`);t==p&&e==A&&n==h||(null!=p&&a(),p=t,A=e,h=n)}catch{}}),1e3*m),n=()=>{p=A=h=null,r(t)},s=o((t=>{T.has(t)&&(n(),a(),e())}));return e(),()=>{n(),i(s)}}),(a=>a()),w,u,d,S,aa(T),(async(a,t)=>await a(`${x} t.name tn,c.name cn FROM ${W}list()t,${W}info(t.name)c ${B} t.schema='main'AND t.type IN('table','view')AND t.name IN(${X(t)})ORDER BY t.name,c.name`,t)),E,v,e,g,(a=>!0===a?1:!1===a?0:a),void 0)},Pa=(a,t,e,n,s)=>{let o;return _a(a,e,(async(a,e=[])=>t.execute(a,e).then((a=>a.rows?._array??[]))),(a=>{const e=new AbortController,n=t.onChange({rawTableNames:!0,signal:e.signal});return(async()=>{for await(const a of n)o&&p(a.changedTables,o)})(),o=a,e}),(a=>{o=void 0,a.abort()}),n,s,(()=>0),1,t,"getPowerSync",Fa)},Fa=async(a,t,e,s,o,r)=>{const i=[1],c=P(s),l=r?h([...r],(a=>a!=e&&!q(c,a))):[];if(!A(l)){const n=C(o),s=O(p(await a("SELECT"+Q(e,...l)+"FROM"+K(t)+"WHERE"+K(e)+"IN("+X(n)+")",n),(a=>[a[e],a])));v(n,(a=>N(o[a],...p(l,(t=>s?.[a]?.[t]??null)))))}await a("INSERT OR REPLACE INTO"+K(t)+"("+Q(e,...s,...l)+")VALUES"+g(L(o,(a=>"($"+i[0]+++","+X(a,i)+")")),n),L(o,((a,t)=>[t,...p(a,(a=>a??null))])).flat())};export{Pa as createPowerSyncPersister};
@@ -1 +1 @@
1
- const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),o=Promise,i=clearInterval,r=a=>null==a,c=(a,t,e)=>r(a)?e?.():t(a),l=t=>a(t)==s,u=a=>Array.isArray(a),w=(a,t,e)=>a.slice(t,e),y=a=>a.length,d=async a=>o.all(a),p=a=>{throw Error(a)},v=(a,t)=>a.forEach(t),E=(a,t="")=>a.join(t),g=(a,t)=>a.map(t),h=a=>0==y(a),A=(a,t)=>a.filter(t),m=(a,...t)=>a.push(...t),N=a=>a.shift(),$="_",f="_id",S="SELECT",C="WHERE",O="TABLE",T="ALTER "+O,b="DELETE FROM",I=S+"*FROM",L="pragma_",R="data_version",D="schema_version",_="pragma_table_",M=a=>`"${a.replace(/"/g,'""')}"`,P=(a,t=[1])=>E(g(a,(()=>"$"+t[0]++)),n),F=(a,t)=>a?.has(t)??!1,j=a=>r(a)||0==(a=>a?.size??0)(a),k=a=>[...a?.values()??[]],U=(a,t)=>a?.forEach(t),x=(a,t)=>a?.delete(t),B=Object,J=a=>B.getPrototypeOf(a),Y=B.entries,q=B.keys,z=B.freeze,G=(a=[])=>B.fromEntries(a),H=(...a)=>B.assign({},...a),V=(a,t)=>(delete a[t],a),K=(a,t)=>g(Y(a),(([a,e])=>t(e,a))),Q=a=>B.values(a),W=a=>y(q(a)),X=a=>(a=>!r(a)&&c(J(a),(a=>a==B.prototype||r(J(a))),(()=>!0)))(a)&&0==W(a),Z=JSON.stringify,aa=JSON.parse,ta=a=>new Map(a),ea=(a,t)=>a?.get(t),na=(a,t)=>g([...a?.entries()??[]],(([a,e])=>t(e,a))),sa=(a,t,e)=>r(e)?(x(a,t),a):a?.set(t,e),oa=(a,t,e,n)=>(F(a,t)?n?.(ea(a,t)):sa(a,t,e()),ea(a,t)),ia=(a,t,e,n,s=0)=>c((e?oa:ea)(a,t[s],s>y(t)-2?e:ta),(o=>{if(s>y(t)-2)return n?.(o)&&sa(a,t[s]),o;const i=ia(o,t,e,n,s+1);return j(o)&&sa(a,t[s]),i})),ra=a=>new Set(u(a)||r(a)?a:[a]),ca=(a,t)=>a?.add(t),la=/^\d+$/,ua=ta(),wa=ta(),ya=(a,t,n,s,o,i,l,w={},d=0,E=[])=>{let g,h,A,$=0,f=0,S=0;oa(ua,E,(()=>0)),oa(wa,E,(()=>[]));const C=ta(),[O,T,b,I,L]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!X(a)||!X(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!X(a)||!X(t),t.setContent]:p("Store type not supported by this Persister"))(l,a,d),[R,D,_]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?N(a):null)??e+t++,t=>{la.test(t)&&y(a)<1e3&&m(a,t)}]})(),s=ta();return[(n,o,i,r=[],c=()=>[])=>{a??=q;const l=t(1);return sa(s,l,[n,o,i,r,c]),ca(ia(o,i??[e],ra),l),l},(t,n,...o)=>v(((a,t=[e])=>{const n=[],s=(a,e)=>e==y(t)?m(n,a):null===t[e]?U(a,(a=>s(a,e+1))):v([t[e],null],(t=>s(ea(a,t),e+1)));return s(a,0),n})(t,n),(t=>U(t,(t=>ea(s,t)[0](a,...n??[],...o))))),a=>c(ea(s,a),(([,t,o])=>(ia(t,o??[e],void 0,(t=>(x(t,a),j(t)?1:0))),sa(s,a),n(a),o))),t=>c(ea(s,t),(([t,,e=[],n,s])=>{const o=(...i)=>{const c=y(i);c==y(e)?t(a,...i,...s(i)):r(e[c])?v(n[c]?.(...i)??[],(a=>o(...i,a))):o(...i,e[c])};o()}))]})(),M=a=>{a!=$&&($=a,D(C,void 0,$))},P=t=>{(O&&u(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},F=async a=>(2!=$&&(M(1),f++,await Y((async()=>{try{const e=await t();u(e)?P(e):a?L(a):p("Content is not an array: "+e)}catch(t){i?.(t),a&&L(a)}M(0)}))),q),k=()=>(h&&(o(h),h=void 0),q),B=async a=>(1!=$&&(M(2),S++,await Y((async()=>{try{await n(T,a)}catch(a){i?.(a)}M(0)}))),q),J=()=>(A&&(a.delListener(A),A=void 0),q),Y=async(...a)=>(m(ea(wa,E),...a),await(async()=>{if(!ea(ua,E)){for(sa(ua,E,1);!r(g=N(ea(wa,E)));)try{await g()}catch(a){i?.(a)}sa(ua,E,0)}})(),q),q={load:F,startAutoLoad:async a=>{k(),await F(a);try{h=await s((async(a,t)=>{t||a?2!=$&&(M(1),f++,P(t??a),M(0)):await F()}))}catch(a){i?.(a)}return q},stopAutoLoad:k,isAutoLoading:()=>!r(h),save:B,startAutoSave:async()=>(J(),await B(),A=a.addDidFinishTransactionListener((()=>{const a=b();I(a)&&B(a)})),q),stopAutoSave:J,isAutoSaving:()=>!r(A),getStatus:()=>$,addStatusListener:a=>R(a,C),delListener:t=>(_(t),a),schedule:Y,getStore:()=>a,destroy:()=>(ea(wa,E).splice(0,void 0),k().stopAutoSave()),getStats:()=>({loads:f,saves:S}),...w};return z(q)},da=(a,t,e,s,o,i=pa,c,l)=>{const u=ta();return[async()=>{u.clear(),g(await e(a,t),(({tn:a,cn:t})=>ca(oa(u,a,ra),t)))},async(t,e)=>((a,t)=>F(ea(u,a),t))(t,e)?G(A(g(await a(I+M(t)),(a=>{return[a[e],l?(t=V(a,e),n=l,G(K(t,((a,t)=>[t,n(a,t)])))):V(a,e)];var t,n})),(([a,t])=>!r(a)&&!X(t)))):{},async(t,e,s,l,w,y=!1)=>{const p=ra();K(s??{},(a=>g(q(a??{}),(a=>ca(p,a)))));const v=k(p);if(!y&&w&&h(v)&&F(u,t))return await a("DROP "+O+M(t)),void sa(u,t);const N=ea(u,t),$=ra(k(N));if(h(v)||(F(u,t)?await d(g([e,...v],(async(n,s)=>{x($,n)||(await a(T+M(t)+"ADD"+M(n)+o),0==s&&await a("CREATE UNIQUE INDEX pk ON "+M(t)+`(${M(e)})`),ca(N,n))}))):(await a("CREATE "+O+M(t)+`(${M(e)}${o} PRIMARY KEY${E(g(v,(a=>n+M(a)+o)))});`),sa(u,t,ra([e,...v])))),await d([...!y&&l?g(k($),(async n=>{n!=e&&(await a(T+M(t)+"DROP"+M(n)),x(N,n))})):[]]),y)r(s)?await a(b+M(t)+C+" true"):await d(K(s,(async(n,s)=>{r(n)?await a(b+M(t)+C+M(e)+"=$1",[s]):h(v)||await i(a,t,e,q(n),{[s]:c?g(Q(n),c):Q(n)},N)})));else if(h(v))F(u,t)&&await a(b+M(t)+C+" true");else{const n=A(k(ea(u,t)),(a=>a!=e)),o={},r=[];K(s??{},((a,t)=>{o[t]=g(n,(t=>c?c(a?.[t]):a?.[t])),m(r,t)})),await i(a,t,e,n,o),await a(b+M(t)+C+M(e)+`NOT IN(${P(r)})`,r)}},async t=>{let e;await a("BEGIN");try{e=await t()}catch(a){s?.(a)}return await a("END"),e}]},pa=async(a,t,e,s,o)=>{const i=[1];await a("INSERT INTO"+M(t)+"("+((...a)=>E(g(a,M),n))(e,...s)+")VALUES"+E(K(o,(a=>"($"+i[0]+++","+P(a,i)+")")),n)+"ON CONFLICT("+M(e)+")DO UPDATE SET"+E(g(s,(a=>M(a)+"=excluded."+M(a))),n),K(o,((a,t)=>[t,...g(a,(a=>a??null))])).flat())},va=(a,t,e,n,s,o,i,[r,c,l],u,w,y,d,p,v)=>{const[E,g,h,A]=da(t,u,w,s,p,v),m=ya(a,(async()=>await A((async()=>{return await E(),a=(await g(r,c))[$]?.[l]??"null",aa(a,((a,t)=>""===t?void 0:t));var a}))),(async a=>await A((async()=>{var t;await E(),await h(r,c,{[$]:{[l]:(t=a()??null,Z(t,((a,t)=>void 0===t?"":t)))}},!0,!0)}))),e,n,s,i,{[d]:()=>y,destroy:()=>(m.stopAutoLoad().stopAutoSave(),o(),m)},0,y);return m},Ea=(a,t,e,n,s,o,i,[c,l,[u,w,y]],p,v,E,g,h,m,N,S)=>{const[C,O,T,b]=da(t,p,v,s,h,m,N,S),I=async(a,t)=>await d(na(l,(async([e,n,s,o],i)=>{t&&!(i in a)||await T(e,n,a[i],s,o,t)}))),L=async(a,t)=>w?await T(y,f,{[$]:a},!0,!0,t):null,R=ya(a,(async()=>await b((async()=>{await C();const a=await(async()=>G(A(await d(na(c,(async([a,t],e)=>[a,await O(e,t)]))),(a=>!X(a[1])))))(),t=await(async()=>u?(await O(y,f))[$]:{})();return X(a)&&r(t)?void 0:[a,t]}))),(async(a,t)=>await b((async()=>{if(await C(),r(t)){const[t,e]=a();await I(t),await L(e)}else await I(t[0],!0),await L(t[1],!0)}))),e,n,s,i,{[g]:()=>E,destroy:()=>(R.stopAutoLoad().stopAutoSave(),o(),R)},0,E);return R},ga="ColumnName",ha="store",Aa="json",ma=ha+"TableName",Na=ha+"Id"+ga,$a=ha+ga,fa="autoLoadIntervalSeconds",Sa="rowId"+ga,Ca="tableId",Oa="tableName",Ta="deleteEmptyColumns",ba="deleteEmptyTable",Ia={mode:Aa,[fa]:1},La={load:0,save:0,[Oa]:t+"_values"},Ra=(a,t,e,n,s)=>{const o=ta();return K(a,((a,i)=>{const c=w(Q(H(t,l(a)?{[e]:a}:a)),0,W(t));r(c[0])||n(i,c[0])||(s(i,c[0]),sa(o,i,c))})),o},Da=(a,n,s,o,r,c,u,y,d,p,v="getDb",E)=>{let g,h,A;const m=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,c),[N,$,O,T]=(a=>{const e=(a=>H(Ia,l(a)?{[ma]:a}:a??{}))(a),n=e[fa];if(e.mode==Aa){const a=e[ma]??t;return[1,n,[a,e[Na]??f,e[$a]??ha],ra(a)]}const{tables:{load:s={},save:o={}}={},values:i={}}=e,r=w(Q(H(La,i)),0,W(La)),c=r[2],u=ra(c),y=ra(c);return[0,n,[Ra(s,{[Ca]:null,[Sa]:f},Ca,(a=>F(y,a)),(a=>ca(u,a))),Ra(o,{[Oa]:null,[Sa]:f,[Ta]:0,[ba]:0},Oa,((a,t)=>F(y,t)),((a,t)=>ca(u,t))),r],u]})(n);return(N?va:Ea)(a,m,(a=>{let t;const e=()=>t=setInterval((async()=>{try{const[{d:t,s:e,c:n}]=await m(`${S} ${R} d,${D} s,TOTAL_CHANGES() c FROM ${L}${R} JOIN ${L}${D}`);t==g&&e==h&&n==A||(null!=g&&a(),g=t,h=e,A=n)}catch{}}),1e3*$),n=()=>{g=h=A=null,i(t)},s=o((t=>{T.has(t)&&(n(),a(),e())}));return e(),()=>{n(),r(s)}}),(a=>a()),u,y,d,O,k(T),(async(a,t)=>await a(`${S} t.name tn,c.name cn FROM ${_}list()t,${_}info(t.name)c ${C} t.schema='main'AND t.type IN('table','view')AND t.name IN(${P(t)})ORDER BY t.name,c.name`,t)),p,v,e,E,(a=>!0===a?1:!1===a?0:a),void 0)},_a=(a,t,e,n,s,o)=>Da(a,n,(async(a,t=[])=>e.exec(a,{bind:t,rowMode:"object",returnValue:"resultRows"}).map((a=>({...a})))),(a=>t.capi.sqlite3_update_hook(e,((t,e,n,s)=>a(s)),0)),(()=>t.capi.sqlite3_update_hook(e,(()=>0),0)),s,o,(()=>0),3,e);export{_a as createSqliteWasmPersister};
1
+ const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),o=Promise,i=clearInterval,r=a=>null==a,c=(a,t,e)=>r(a)?e?.():t(a),l=t=>a(t)==s,u=a=>Array.isArray(a),w=(a,t,e)=>a.slice(t,e),y=a=>a.length,d=async a=>o.all(a),p=a=>{throw Error(a)},v=(a,t)=>a.forEach(t),E=(a,t="")=>a.join(t),g=(a,t)=>a.map(t),h=a=>0==y(a),A=(a,t)=>a.filter(t),m=(a,...t)=>a.push(...t),N=a=>a.shift(),$="_",f="_id",S="SELECT",C="WHERE",O="TABLE",T="ALTER "+O,b="DELETE FROM",I=S+"*FROM",L="pragma_",R="data_version",D="schema_version",_="pragma_table_",M=a=>`"${a.replace(/"/g,'""')}"`,P=(a,t=[1])=>E(g(a,(()=>"$"+t[0]++)),n),F=(a,t)=>a?.has(t)??!1,j=a=>r(a)||0==(a=>a?.size??0)(a),k=a=>[...a?.values()??[]],U=(a,t)=>a?.forEach(t),x=(a,t)=>a?.delete(t),B=Object,J=a=>B.getPrototypeOf(a),Y=B.entries,q=B.keys,z=B.freeze,G=(a=[])=>B.fromEntries(a),H=(...a)=>B.assign({},...a),V=(a,t)=>(delete a[t],a),K=(a,t)=>g(Y(a),(([a,e])=>t(e,a))),Q=(a,t)=>G(K(a,((a,e)=>[e,t(a,e)]))),W=a=>B.values(a),X=a=>y(q(a)),Z=a=>(a=>!r(a)&&c(J(a),(a=>a==B.prototype||r(J(a))),(()=>!0)))(a)&&0==X(a),aa=JSON.stringify,ta=JSON.parse,ea=a=>new Map(a),na=(a,t)=>a?.get(t),sa=(a,t)=>g([...a?.entries()??[]],(([a,e])=>t(e,a))),oa=(a,t,e)=>r(e)?(x(a,t),a):a?.set(t,e),ia=(a,t,e,n)=>(F(a,t)?n?.(na(a,t)):oa(a,t,e()),na(a,t)),ra=(a,t,e,n,s=0)=>c((e?ia:na)(a,t[s],s>y(t)-2?e:ea),(o=>{if(s>y(t)-2)return n?.(o)&&oa(a,t[s]),o;const i=ra(o,t,e,n,s+1);return j(o)&&oa(a,t[s]),i})),ca=a=>new Set(u(a)||r(a)?a:[a]),la=(a,t)=>a?.add(t),ua=/^\d+$/,wa=ea(),ya=ea(),da=(a,t,n,s,o,i,l,w={},d=0,E=[])=>{let g,h,A,$=0,f=0,S=0;ia(wa,E,(()=>0)),ia(ya,E,(()=>[]));const C=ea(),[O,T,b,I,L]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!Z(a)||!Z(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!Z(a)||!Z(t),t.setContent]:p("Store type not supported by this Persister"))(l,a,d),[R,D,_]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?N(a):null)??e+t++,t=>{ua.test(t)&&y(a)<1e3&&m(a,t)}]})(),s=ea();return[(n,o,i,r=[],c=()=>[])=>{a??=q;const l=t(1);return oa(s,l,[n,o,i,r,c]),la(ra(o,i??[e],ca),l),l},(t,n,...o)=>v(((a,t=[e])=>{const n=[],s=(a,e)=>e==y(t)?m(n,a):null===t[e]?U(a,(a=>s(a,e+1))):v([t[e],null],(t=>s(na(a,t),e+1)));return s(a,0),n})(t,n),(t=>U(t,(t=>na(s,t)[0](a,...n??[],...o))))),a=>c(na(s,a),(([,t,o])=>(ra(t,o??[e],void 0,(t=>(x(t,a),j(t)?1:0))),oa(s,a),n(a),o))),t=>c(na(s,t),(([t,,e=[],n,s])=>{const o=(...i)=>{const c=y(i);c==y(e)?t(a,...i,...s(i)):r(e[c])?v(n[c]?.(...i)??[],(a=>o(...i,a))):o(...i,e[c])};o()}))]})(),M=a=>{a!=$&&($=a,D(C,void 0,$))},P=t=>{(O&&u(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},F=async a=>(2!=$&&(M(1),f++,await Y((async()=>{try{const e=await t();u(e)?P(e):a?L(a):p("Content is not an array: "+e)}catch(t){i?.(t),a&&L(a)}M(0)}))),q),k=()=>(h&&(o(h),h=void 0),q),B=async a=>(1!=$&&(M(2),S++,await Y((async()=>{try{await n(T,a)}catch(a){i?.(a)}M(0)}))),q),J=()=>(A&&(a.delListener(A),A=void 0),q),Y=async(...a)=>(m(na(ya,E),...a),await(async()=>{if(!na(wa,E)){for(oa(wa,E,1);!r(g=N(na(ya,E)));)try{await g()}catch(a){i?.(a)}oa(wa,E,0)}})(),q),q={load:F,startAutoLoad:async a=>{k(),await F(a);try{h=await s((async(a,t)=>{t||a?2!=$&&(M(1),f++,P(t??a),M(0)):await F()}))}catch(a){i?.(a)}return q},stopAutoLoad:k,isAutoLoading:()=>!r(h),save:B,startAutoSave:async()=>(J(),await B(),A=a.addDidFinishTransactionListener((()=>{const a=b();I(a)&&B(a)})),q),stopAutoSave:J,isAutoSaving:()=>!r(A),getStatus:()=>$,addStatusListener:a=>R(a,C),delListener:t=>(_(t),a),schedule:Y,getStore:()=>a,destroy:()=>(na(ya,E).splice(0,void 0),k().stopAutoSave()),getStats:()=>({loads:f,saves:S}),...w};return z(q)},pa=(a,t,e,s,o,i=va,c,l)=>{const u=ea();return[async()=>{u.clear(),g(await e(a,t),(({tn:a,cn:t})=>la(ia(u,a,ca),t)))},async(t,e)=>((a,t)=>F(na(u,a),t))(t,e)?G(A(g(await a(I+M(t)),(a=>[a[e],l?Q(V(a,e),l):V(a,e)])),(([a,t])=>!r(a)&&!Z(t)))):{},async(t,e,s,l,w,y=!1)=>{const p=ca();Q(s??{},(a=>g(q(a??{}),(a=>la(p,a)))));const v=k(p);if(!y&&w&&h(v)&&F(u,t))return await a("DROP "+O+M(t)),void oa(u,t);const N=na(u,t),$=ca(k(N));if(h(v)||(F(u,t)?await d(g([e,...v],(async(n,s)=>{x($,n)||(await a(T+M(t)+"ADD"+M(n)+o),0==s&&await a("CREATE UNIQUE INDEX pk ON "+M(t)+`(${M(e)})`),la(N,n))}))):(await a("CREATE "+O+M(t)+`(${M(e)}${o} PRIMARY KEY${E(g(v,(a=>n+M(a)+o)))});`),oa(u,t,ca([e,...v])))),await d([...!y&&l?g(k($),(async n=>{n!=e&&(await a(T+M(t)+"DROP"+M(n)),x(N,n))})):[]]),y)r(s)?await a(b+M(t)+C+" true"):await d(K(s,(async(n,s)=>{r(n)?await a(b+M(t)+C+M(e)+"=$1",[s]):h(v)||await i(a,t,e,q(n),{[s]:c?g(W(n),c):W(n)},N)})));else if(h(v))F(u,t)&&await a(b+M(t)+C+" true");else{const n=A(k(na(u,t)),(a=>a!=e)),o={},r=[];Q(s??{},((a,t)=>{o[t]=g(n,(t=>c?c(a?.[t]):a?.[t])),m(r,t)})),await i(a,t,e,n,o),await a(b+M(t)+C+M(e)+`NOT IN(${P(r)})`,r)}},async t=>{let e;await a("BEGIN");try{e=await t()}catch(a){s?.(a)}return await a("END"),e}]},va=async(a,t,e,s,o)=>{const i=[1];await a("INSERT INTO"+M(t)+"("+((...a)=>E(g(a,M),n))(e,...s)+")VALUES"+E(K(o,(a=>"($"+i[0]+++","+P(a,i)+")")),n)+"ON CONFLICT("+M(e)+")DO UPDATE SET"+E(g(s,(a=>M(a)+"=excluded."+M(a))),n),K(o,((a,t)=>[t,...g(a,(a=>a??null))])).flat())},Ea=(a,t,e,n,s,o,i,[r,c,l],u,w,y,d,p,v)=>{const[E,g,h,A]=pa(t,u,w,s,p,v),m=da(a,(async()=>await A((async()=>{return await E(),a=(await g(r,c))[$]?.[l]??"null",ta(a,((a,t)=>""===t?void 0:t));var a}))),(async a=>await A((async()=>{var t;await E(),await h(r,c,{[$]:{[l]:(t=a()??null,aa(t,((a,t)=>void 0===t?"":t)))}},!0,!0)}))),e,n,s,i,{[d]:()=>y,destroy:()=>(m.stopAutoLoad().stopAutoSave(),o(),m)},0,y);return m},ga=(a,t,e,n,s,o,i,[c,l,[u,w,y]],p,v,E,g,h,m,N,S)=>{const[C,O,T,b]=pa(t,p,v,s,h,m,N,S),I=async(a,t)=>await d(sa(l,(async([e,n,s,o],i)=>{t&&!(i in a)||await T(e,n,a[i],s,o,t)}))),L=async(a,t)=>w?await T(y,f,{[$]:a},!0,!0,t):null,R=da(a,(async()=>await b((async()=>{await C();const a=await(async()=>G(A(await d(sa(c,(async([a,t],e)=>[a,await O(e,t)]))),(a=>!Z(a[1])))))(),t=await(async()=>u?(await O(y,f))[$]:{})();return Z(a)&&r(t)?void 0:[a,t]}))),(async(a,t)=>await b((async()=>{if(await C(),r(t)){const[t,e]=a();await I(t),await L(e)}else await I(t[0],!0),await L(t[1],!0)}))),e,n,s,i,{[g]:()=>E,destroy:()=>(R.stopAutoLoad().stopAutoSave(),o(),R)},0,E);return R},ha="ColumnName",Aa="store",ma="json",Na=Aa+"TableName",$a=Aa+"Id"+ha,fa=Aa+ha,Sa="autoLoadIntervalSeconds",Ca="rowId"+ha,Oa="tableId",Ta="tableName",ba="deleteEmptyColumns",Ia="deleteEmptyTable",La={mode:ma,[Sa]:1},Ra={load:0,save:0,[Ta]:t+"_values"},Da=(a,t,e,n,s)=>{const o=ea();return Q(a,((a,i)=>{const c=w(W(H(t,l(a)?{[e]:a}:a)),0,X(t));r(c[0])||n(i,c[0])||(s(i,c[0]),oa(o,i,c))})),o},_a=(a,n,s,o,r,c,u,y,d,p,v="getDb",E)=>{let g,h,A;const m=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,c),[N,$,O,T]=(a=>{const e=(a=>H(La,l(a)?{[Na]:a}:a??{}))(a),n=e[Sa];if(e.mode==ma){const a=e[Na]??t;return[1,n,[a,e[$a]??f,e[fa]??Aa],ca(a)]}const{tables:{load:s={},save:o={}}={},values:i={}}=e,r=w(W(H(Ra,i)),0,X(Ra)),c=r[2],u=ca(c),y=ca(c);return[0,n,[Da(s,{[Oa]:null,[Ca]:f},Oa,(a=>F(y,a)),(a=>la(u,a))),Da(o,{[Ta]:null,[Ca]:f,[ba]:0,[Ia]:0},Ta,((a,t)=>F(y,t)),((a,t)=>la(u,t))),r],u]})(n);return(N?Ea:ga)(a,m,(a=>{let t;const e=()=>t=setInterval((async()=>{try{const[{d:t,s:e,c:n}]=await m(`${S} ${R} d,${D} s,TOTAL_CHANGES() c FROM ${L}${R} JOIN ${L}${D}`);t==g&&e==h&&n==A||(null!=g&&a(),g=t,h=e,A=n)}catch{}}),1e3*$),n=()=>{g=h=A=null,i(t)},s=o((t=>{T.has(t)&&(n(),a(),e())}));return e(),()=>{n(),r(s)}}),(a=>a()),u,y,d,O,k(T),(async(a,t)=>await a(`${S} t.name tn,c.name cn FROM ${_}list()t,${_}info(t.name)c ${C} t.schema='main'AND t.type IN('table','view')AND t.name IN(${P(t)})ORDER BY t.name,c.name`,t)),p,v,e,E,(a=>!0===a?1:!1===a?0:a),void 0)},Ma=(a,t,e,n,s,o)=>_a(a,n,(async(a,t=[])=>e.exec(a,{bind:t,rowMode:"object",returnValue:"resultRows"}).map((a=>({...a})))),(a=>t.capi.sqlite3_update_hook(e,((t,e,n,s)=>a(s)),0)),(()=>t.capi.sqlite3_update_hook(e,(()=>0),0)),s,o,(()=>0),3,e);export{Ma as createSqliteWasmPersister};
@@ -1 +1 @@
1
- const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),o=Promise,i=clearInterval,r=a=>null==a,c=(a,t,e)=>r(a)?e?.():t(a),l=t=>a(t)==s,u=a=>Array.isArray(a),w=(a,t,e)=>a.slice(t,e),y=a=>a.length,d=async a=>o.all(a),p=a=>{throw Error(a)},v=(a,t)=>a.forEach(t),E=(a,t="")=>a.join(t),g=(a,t)=>a.map(t),h=a=>0==y(a),A=(a,t)=>a.filter(t),m=(a,...t)=>a.push(...t),N=a=>a.shift(),$="_",f="_id",S="SELECT",C="WHERE",O="TABLE",T="ALTER "+O,b="DELETE FROM",I=S+"*FROM",L="pragma_",R="data_version",D="schema_version",_="pragma_table_",M=a=>`"${a.replace(/"/g,'""')}"`,P=(a,t=[1])=>E(g(a,(()=>"$"+t[0]++)),n),F=(a,t)=>a?.has(t)??!1,j=a=>r(a)||0==(a=>a?.size??0)(a),k=a=>[...a?.values()??[]],U=(a,t)=>a?.forEach(t),x=(a,t)=>a?.delete(t),B=Object,J=a=>B.getPrototypeOf(a),Y=B.entries,q=B.keys,z=B.freeze,G=(a=[])=>B.fromEntries(a),H=(...a)=>B.assign({},...a),V=(a,t)=>(delete a[t],a),K=(a,t)=>g(Y(a),(([a,e])=>t(e,a))),Q=a=>B.values(a),W=a=>y(q(a)),X=a=>(a=>!r(a)&&c(J(a),(a=>a==B.prototype||r(J(a))),(()=>!0)))(a)&&0==W(a),Z=JSON.stringify,aa=JSON.parse,ta=a=>new Map(a),ea=(a,t)=>a?.get(t),na=(a,t)=>g([...a?.entries()??[]],(([a,e])=>t(e,a))),sa=(a,t,e)=>r(e)?(x(a,t),a):a?.set(t,e),oa=(a,t,e,n)=>(F(a,t)?n?.(ea(a,t)):sa(a,t,e()),ea(a,t)),ia=(a,t,e,n,s=0)=>c((e?oa:ea)(a,t[s],s>y(t)-2?e:ta),(o=>{if(s>y(t)-2)return n?.(o)&&sa(a,t[s]),o;const i=ia(o,t,e,n,s+1);return j(o)&&sa(a,t[s]),i})),ra=a=>new Set(u(a)||r(a)?a:[a]),ca=(a,t)=>a?.add(t),la=/^\d+$/,ua=ta(),wa=ta(),ya=(a,t,n,s,o,i,l,w={},d=0,E=[])=>{let g,h,A,$=0,f=0,S=0;oa(ua,E,(()=>0)),oa(wa,E,(()=>[]));const C=ta(),[O,T,b,I,L]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!X(a)||!X(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!X(a)||!X(t),t.setContent]:p("Store type not supported by this Persister"))(l,a,d),[R,D,_]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?N(a):null)??e+t++,t=>{la.test(t)&&y(a)<1e3&&m(a,t)}]})(),s=ta();return[(n,o,i,r=[],c=()=>[])=>{a??=q;const l=t(1);return sa(s,l,[n,o,i,r,c]),ca(ia(o,i??[e],ra),l),l},(t,n,...o)=>v(((a,t=[e])=>{const n=[],s=(a,e)=>e==y(t)?m(n,a):null===t[e]?U(a,(a=>s(a,e+1))):v([t[e],null],(t=>s(ea(a,t),e+1)));return s(a,0),n})(t,n),(t=>U(t,(t=>ea(s,t)[0](a,...n??[],...o))))),a=>c(ea(s,a),(([,t,o])=>(ia(t,o??[e],void 0,(t=>(x(t,a),j(t)?1:0))),sa(s,a),n(a),o))),t=>c(ea(s,t),(([t,,e=[],n,s])=>{const o=(...i)=>{const c=y(i);c==y(e)?t(a,...i,...s(i)):r(e[c])?v(n[c]?.(...i)??[],(a=>o(...i,a))):o(...i,e[c])};o()}))]})(),M=a=>{a!=$&&($=a,D(C,void 0,$))},P=t=>{(O&&u(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},F=async a=>(2!=$&&(M(1),f++,await Y((async()=>{try{const e=await t();u(e)?P(e):a?L(a):p("Content is not an array: "+e)}catch(t){i?.(t),a&&L(a)}M(0)}))),q),k=()=>(h&&(o(h),h=void 0),q),B=async a=>(1!=$&&(M(2),S++,await Y((async()=>{try{await n(T,a)}catch(a){i?.(a)}M(0)}))),q),J=()=>(A&&(a.delListener(A),A=void 0),q),Y=async(...a)=>(m(ea(wa,E),...a),await(async()=>{if(!ea(ua,E)){for(sa(ua,E,1);!r(g=N(ea(wa,E)));)try{await g()}catch(a){i?.(a)}sa(ua,E,0)}})(),q),q={load:F,startAutoLoad:async a=>{k(),await F(a);try{h=await s((async(a,t)=>{t||a?2!=$&&(M(1),f++,P(t??a),M(0)):await F()}))}catch(a){i?.(a)}return q},stopAutoLoad:k,isAutoLoading:()=>!r(h),save:B,startAutoSave:async()=>(J(),await B(),A=a.addDidFinishTransactionListener((()=>{const a=b();I(a)&&B(a)})),q),stopAutoSave:J,isAutoSaving:()=>!r(A),getStatus:()=>$,addStatusListener:a=>R(a,C),delListener:t=>(_(t),a),schedule:Y,getStore:()=>a,destroy:()=>(ea(wa,E).splice(0,void 0),k().stopAutoSave()),getStats:()=>({loads:f,saves:S}),...w};return z(q)},da=(a,t,e,s,o,i=pa,c,l)=>{const u=ta();return[async()=>{u.clear(),g(await e(a,t),(({tn:a,cn:t})=>ca(oa(u,a,ra),t)))},async(t,e)=>((a,t)=>F(ea(u,a),t))(t,e)?G(A(g(await a(I+M(t)),(a=>{return[a[e],l?(t=V(a,e),n=l,G(K(t,((a,t)=>[t,n(a,t)])))):V(a,e)];var t,n})),(([a,t])=>!r(a)&&!X(t)))):{},async(t,e,s,l,w,y=!1)=>{const p=ra();K(s??{},(a=>g(q(a??{}),(a=>ca(p,a)))));const v=k(p);if(!y&&w&&h(v)&&F(u,t))return await a("DROP "+O+M(t)),void sa(u,t);const N=ea(u,t),$=ra(k(N));if(h(v)||(F(u,t)?await d(g([e,...v],(async(n,s)=>{x($,n)||(await a(T+M(t)+"ADD"+M(n)+o),0==s&&await a("CREATE UNIQUE INDEX pk ON "+M(t)+`(${M(e)})`),ca(N,n))}))):(await a("CREATE "+O+M(t)+`(${M(e)}${o} PRIMARY KEY${E(g(v,(a=>n+M(a)+o)))});`),sa(u,t,ra([e,...v])))),await d([...!y&&l?g(k($),(async n=>{n!=e&&(await a(T+M(t)+"DROP"+M(n)),x(N,n))})):[]]),y)r(s)?await a(b+M(t)+C+" true"):await d(K(s,(async(n,s)=>{r(n)?await a(b+M(t)+C+M(e)+"=$1",[s]):h(v)||await i(a,t,e,q(n),{[s]:c?g(Q(n),c):Q(n)},N)})));else if(h(v))F(u,t)&&await a(b+M(t)+C+" true");else{const n=A(k(ea(u,t)),(a=>a!=e)),o={},r=[];K(s??{},((a,t)=>{o[t]=g(n,(t=>c?c(a?.[t]):a?.[t])),m(r,t)})),await i(a,t,e,n,o),await a(b+M(t)+C+M(e)+`NOT IN(${P(r)})`,r)}},async t=>{let e;await a("BEGIN");try{e=await t()}catch(a){s?.(a)}return await a("END"),e}]},pa=async(a,t,e,s,o)=>{const i=[1];await a("INSERT INTO"+M(t)+"("+((...a)=>E(g(a,M),n))(e,...s)+")VALUES"+E(K(o,(a=>"($"+i[0]+++","+P(a,i)+")")),n)+"ON CONFLICT("+M(e)+")DO UPDATE SET"+E(g(s,(a=>M(a)+"=excluded."+M(a))),n),K(o,((a,t)=>[t,...g(a,(a=>a??null))])).flat())},va=(a,t,e,n,s,o,i,[r,c,l],u,w,y,d,p,v)=>{const[E,g,h,A]=da(t,u,w,s,p,v),m=ya(a,(async()=>await A((async()=>{return await E(),a=(await g(r,c))[$]?.[l]??"null",aa(a,((a,t)=>""===t?void 0:t));var a}))),(async a=>await A((async()=>{var t;await E(),await h(r,c,{[$]:{[l]:(t=a()??null,Z(t,((a,t)=>void 0===t?"":t)))}},!0,!0)}))),e,n,s,i,{[d]:()=>y,destroy:()=>(m.stopAutoLoad().stopAutoSave(),o(),m)},0,y);return m},Ea=(a,t,e,n,s,o,i,[c,l,[u,w,y]],p,v,E,g,h,m,N,S)=>{const[C,O,T,b]=da(t,p,v,s,h,m,N,S),I=async(a,t)=>await d(na(l,(async([e,n,s,o],i)=>{t&&!(i in a)||await T(e,n,a[i],s,o,t)}))),L=async(a,t)=>w?await T(y,f,{[$]:a},!0,!0,t):null,R=ya(a,(async()=>await b((async()=>{await C();const a=await(async()=>G(A(await d(na(c,(async([a,t],e)=>[a,await O(e,t)]))),(a=>!X(a[1])))))(),t=await(async()=>u?(await O(y,f))[$]:{})();return X(a)&&r(t)?void 0:[a,t]}))),(async(a,t)=>await b((async()=>{if(await C(),r(t)){const[t,e]=a();await I(t),await L(e)}else await I(t[0],!0),await L(t[1],!0)}))),e,n,s,i,{[g]:()=>E,destroy:()=>(R.stopAutoLoad().stopAutoSave(),o(),R)},0,E);return R},ga="ColumnName",ha="store",Aa="json",ma=ha+"TableName",Na=ha+"Id"+ga,$a=ha+ga,fa="autoLoadIntervalSeconds",Sa="rowId"+ga,Ca="tableId",Oa="tableName",Ta="deleteEmptyColumns",ba="deleteEmptyTable",Ia={mode:Aa,[fa]:1},La={load:0,save:0,[Oa]:t+"_values"},Ra=(a,t,e,n,s)=>{const o=ta();return K(a,((a,i)=>{const c=w(Q(H(t,l(a)?{[e]:a}:a)),0,W(t));r(c[0])||n(i,c[0])||(s(i,c[0]),sa(o,i,c))})),o},Da=(a,n,s,o,r,c,u,y,d,p,v="getDb",E)=>{let g,h,A;const m=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,c),[N,$,O,T]=(a=>{const e=(a=>H(Ia,l(a)?{[ma]:a}:a??{}))(a),n=e[fa];if(e.mode==Aa){const a=e[ma]??t;return[1,n,[a,e[Na]??f,e[$a]??ha],ra(a)]}const{tables:{load:s={},save:o={}}={},values:i={}}=e,r=w(Q(H(La,i)),0,W(La)),c=r[2],u=ra(c),y=ra(c);return[0,n,[Ra(s,{[Ca]:null,[Sa]:f},Ca,(a=>F(y,a)),(a=>ca(u,a))),Ra(o,{[Oa]:null,[Sa]:f,[Ta]:0,[ba]:0},Oa,((a,t)=>F(y,t)),((a,t)=>ca(u,t))),r],u]})(n);return(N?va:Ea)(a,m,(a=>{let t;const e=()=>t=setInterval((async()=>{try{const[{d:t,s:e,c:n}]=await m(`${S} ${R} d,${D} s,TOTAL_CHANGES() c FROM ${L}${R} JOIN ${L}${D}`);t==g&&e==h&&n==A||(null!=g&&a(),g=t,h=e,A=n)}catch{}}),1e3*$),n=()=>{g=h=A=null,i(t)},s=o((t=>{T.has(t)&&(n(),a(),e())}));return e(),()=>{n(),r(s)}}),(a=>a()),u,y,d,O,k(T),(async(a,t)=>await a(`${S} t.name tn,c.name cn FROM ${_}list()t,${_}info(t.name)c ${C} t.schema='main'AND t.type IN('table','view')AND t.name IN(${P(t)})ORDER BY t.name,c.name`,t)),p,v,e,E,(a=>!0===a?1:!1===a?0:a),void 0)},_a=(a,t,e,n,s,o)=>Da(a,n,(async(a,t=[])=>e.exec(a,{bind:t,rowMode:"object",returnValue:"resultRows"}).map((a=>({...a})))),(a=>t.capi.sqlite3_update_hook(e,((t,e,n,s)=>a(s)),0)),(()=>t.capi.sqlite3_update_hook(e,(()=>0),0)),s,o,(()=>0),3,e);export{_a as createSqliteWasmPersister};
1
+ const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),o=Promise,i=clearInterval,r=a=>null==a,c=(a,t,e)=>r(a)?e?.():t(a),l=t=>a(t)==s,u=a=>Array.isArray(a),w=(a,t,e)=>a.slice(t,e),y=a=>a.length,d=async a=>o.all(a),p=a=>{throw Error(a)},v=(a,t)=>a.forEach(t),E=(a,t="")=>a.join(t),g=(a,t)=>a.map(t),h=a=>0==y(a),A=(a,t)=>a.filter(t),m=(a,...t)=>a.push(...t),N=a=>a.shift(),$="_",f="_id",S="SELECT",C="WHERE",O="TABLE",T="ALTER "+O,b="DELETE FROM",I=S+"*FROM",L="pragma_",R="data_version",D="schema_version",_="pragma_table_",M=a=>`"${a.replace(/"/g,'""')}"`,P=(a,t=[1])=>E(g(a,(()=>"$"+t[0]++)),n),F=(a,t)=>a?.has(t)??!1,j=a=>r(a)||0==(a=>a?.size??0)(a),k=a=>[...a?.values()??[]],U=(a,t)=>a?.forEach(t),x=(a,t)=>a?.delete(t),B=Object,J=a=>B.getPrototypeOf(a),Y=B.entries,q=B.keys,z=B.freeze,G=(a=[])=>B.fromEntries(a),H=(...a)=>B.assign({},...a),V=(a,t)=>(delete a[t],a),K=(a,t)=>g(Y(a),(([a,e])=>t(e,a))),Q=(a,t)=>G(K(a,((a,e)=>[e,t(a,e)]))),W=a=>B.values(a),X=a=>y(q(a)),Z=a=>(a=>!r(a)&&c(J(a),(a=>a==B.prototype||r(J(a))),(()=>!0)))(a)&&0==X(a),aa=JSON.stringify,ta=JSON.parse,ea=a=>new Map(a),na=(a,t)=>a?.get(t),sa=(a,t)=>g([...a?.entries()??[]],(([a,e])=>t(e,a))),oa=(a,t,e)=>r(e)?(x(a,t),a):a?.set(t,e),ia=(a,t,e,n)=>(F(a,t)?n?.(na(a,t)):oa(a,t,e()),na(a,t)),ra=(a,t,e,n,s=0)=>c((e?ia:na)(a,t[s],s>y(t)-2?e:ea),(o=>{if(s>y(t)-2)return n?.(o)&&oa(a,t[s]),o;const i=ra(o,t,e,n,s+1);return j(o)&&oa(a,t[s]),i})),ca=a=>new Set(u(a)||r(a)?a:[a]),la=(a,t)=>a?.add(t),ua=/^\d+$/,wa=ea(),ya=ea(),da=(a,t,n,s,o,i,l,w={},d=0,E=[])=>{let g,h,A,$=0,f=0,S=0;ia(wa,E,(()=>0)),ia(ya,E,(()=>[]));const C=ea(),[O,T,b,I,L]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!Z(a)||!Z(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!Z(a)||!Z(t),t.setContent]:p("Store type not supported by this Persister"))(l,a,d),[R,D,_]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?N(a):null)??e+t++,t=>{ua.test(t)&&y(a)<1e3&&m(a,t)}]})(),s=ea();return[(n,o,i,r=[],c=()=>[])=>{a??=q;const l=t(1);return oa(s,l,[n,o,i,r,c]),la(ra(o,i??[e],ca),l),l},(t,n,...o)=>v(((a,t=[e])=>{const n=[],s=(a,e)=>e==y(t)?m(n,a):null===t[e]?U(a,(a=>s(a,e+1))):v([t[e],null],(t=>s(na(a,t),e+1)));return s(a,0),n})(t,n),(t=>U(t,(t=>na(s,t)[0](a,...n??[],...o))))),a=>c(na(s,a),(([,t,o])=>(ra(t,o??[e],void 0,(t=>(x(t,a),j(t)?1:0))),oa(s,a),n(a),o))),t=>c(na(s,t),(([t,,e=[],n,s])=>{const o=(...i)=>{const c=y(i);c==y(e)?t(a,...i,...s(i)):r(e[c])?v(n[c]?.(...i)??[],(a=>o(...i,a))):o(...i,e[c])};o()}))]})(),M=a=>{a!=$&&($=a,D(C,void 0,$))},P=t=>{(O&&u(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},F=async a=>(2!=$&&(M(1),f++,await Y((async()=>{try{const e=await t();u(e)?P(e):a?L(a):p("Content is not an array: "+e)}catch(t){i?.(t),a&&L(a)}M(0)}))),q),k=()=>(h&&(o(h),h=void 0),q),B=async a=>(1!=$&&(M(2),S++,await Y((async()=>{try{await n(T,a)}catch(a){i?.(a)}M(0)}))),q),J=()=>(A&&(a.delListener(A),A=void 0),q),Y=async(...a)=>(m(na(ya,E),...a),await(async()=>{if(!na(wa,E)){for(oa(wa,E,1);!r(g=N(na(ya,E)));)try{await g()}catch(a){i?.(a)}oa(wa,E,0)}})(),q),q={load:F,startAutoLoad:async a=>{k(),await F(a);try{h=await s((async(a,t)=>{t||a?2!=$&&(M(1),f++,P(t??a),M(0)):await F()}))}catch(a){i?.(a)}return q},stopAutoLoad:k,isAutoLoading:()=>!r(h),save:B,startAutoSave:async()=>(J(),await B(),A=a.addDidFinishTransactionListener((()=>{const a=b();I(a)&&B(a)})),q),stopAutoSave:J,isAutoSaving:()=>!r(A),getStatus:()=>$,addStatusListener:a=>R(a,C),delListener:t=>(_(t),a),schedule:Y,getStore:()=>a,destroy:()=>(na(ya,E).splice(0,void 0),k().stopAutoSave()),getStats:()=>({loads:f,saves:S}),...w};return z(q)},pa=(a,t,e,s,o,i=va,c,l)=>{const u=ea();return[async()=>{u.clear(),g(await e(a,t),(({tn:a,cn:t})=>la(ia(u,a,ca),t)))},async(t,e)=>((a,t)=>F(na(u,a),t))(t,e)?G(A(g(await a(I+M(t)),(a=>[a[e],l?Q(V(a,e),l):V(a,e)])),(([a,t])=>!r(a)&&!Z(t)))):{},async(t,e,s,l,w,y=!1)=>{const p=ca();Q(s??{},(a=>g(q(a??{}),(a=>la(p,a)))));const v=k(p);if(!y&&w&&h(v)&&F(u,t))return await a("DROP "+O+M(t)),void oa(u,t);const N=na(u,t),$=ca(k(N));if(h(v)||(F(u,t)?await d(g([e,...v],(async(n,s)=>{x($,n)||(await a(T+M(t)+"ADD"+M(n)+o),0==s&&await a("CREATE UNIQUE INDEX pk ON "+M(t)+`(${M(e)})`),la(N,n))}))):(await a("CREATE "+O+M(t)+`(${M(e)}${o} PRIMARY KEY${E(g(v,(a=>n+M(a)+o)))});`),oa(u,t,ca([e,...v])))),await d([...!y&&l?g(k($),(async n=>{n!=e&&(await a(T+M(t)+"DROP"+M(n)),x(N,n))})):[]]),y)r(s)?await a(b+M(t)+C+" true"):await d(K(s,(async(n,s)=>{r(n)?await a(b+M(t)+C+M(e)+"=$1",[s]):h(v)||await i(a,t,e,q(n),{[s]:c?g(W(n),c):W(n)},N)})));else if(h(v))F(u,t)&&await a(b+M(t)+C+" true");else{const n=A(k(na(u,t)),(a=>a!=e)),o={},r=[];Q(s??{},((a,t)=>{o[t]=g(n,(t=>c?c(a?.[t]):a?.[t])),m(r,t)})),await i(a,t,e,n,o),await a(b+M(t)+C+M(e)+`NOT IN(${P(r)})`,r)}},async t=>{let e;await a("BEGIN");try{e=await t()}catch(a){s?.(a)}return await a("END"),e}]},va=async(a,t,e,s,o)=>{const i=[1];await a("INSERT INTO"+M(t)+"("+((...a)=>E(g(a,M),n))(e,...s)+")VALUES"+E(K(o,(a=>"($"+i[0]+++","+P(a,i)+")")),n)+"ON CONFLICT("+M(e)+")DO UPDATE SET"+E(g(s,(a=>M(a)+"=excluded."+M(a))),n),K(o,((a,t)=>[t,...g(a,(a=>a??null))])).flat())},Ea=(a,t,e,n,s,o,i,[r,c,l],u,w,y,d,p,v)=>{const[E,g,h,A]=pa(t,u,w,s,p,v),m=da(a,(async()=>await A((async()=>{return await E(),a=(await g(r,c))[$]?.[l]??"null",ta(a,((a,t)=>""===t?void 0:t));var a}))),(async a=>await A((async()=>{var t;await E(),await h(r,c,{[$]:{[l]:(t=a()??null,aa(t,((a,t)=>void 0===t?"":t)))}},!0,!0)}))),e,n,s,i,{[d]:()=>y,destroy:()=>(m.stopAutoLoad().stopAutoSave(),o(),m)},0,y);return m},ga=(a,t,e,n,s,o,i,[c,l,[u,w,y]],p,v,E,g,h,m,N,S)=>{const[C,O,T,b]=pa(t,p,v,s,h,m,N,S),I=async(a,t)=>await d(sa(l,(async([e,n,s,o],i)=>{t&&!(i in a)||await T(e,n,a[i],s,o,t)}))),L=async(a,t)=>w?await T(y,f,{[$]:a},!0,!0,t):null,R=da(a,(async()=>await b((async()=>{await C();const a=await(async()=>G(A(await d(sa(c,(async([a,t],e)=>[a,await O(e,t)]))),(a=>!Z(a[1])))))(),t=await(async()=>u?(await O(y,f))[$]:{})();return Z(a)&&r(t)?void 0:[a,t]}))),(async(a,t)=>await b((async()=>{if(await C(),r(t)){const[t,e]=a();await I(t),await L(e)}else await I(t[0],!0),await L(t[1],!0)}))),e,n,s,i,{[g]:()=>E,destroy:()=>(R.stopAutoLoad().stopAutoSave(),o(),R)},0,E);return R},ha="ColumnName",Aa="store",ma="json",Na=Aa+"TableName",$a=Aa+"Id"+ha,fa=Aa+ha,Sa="autoLoadIntervalSeconds",Ca="rowId"+ha,Oa="tableId",Ta="tableName",ba="deleteEmptyColumns",Ia="deleteEmptyTable",La={mode:ma,[Sa]:1},Ra={load:0,save:0,[Ta]:t+"_values"},Da=(a,t,e,n,s)=>{const o=ea();return Q(a,((a,i)=>{const c=w(W(H(t,l(a)?{[e]:a}:a)),0,X(t));r(c[0])||n(i,c[0])||(s(i,c[0]),oa(o,i,c))})),o},_a=(a,n,s,o,r,c,u,y,d,p,v="getDb",E)=>{let g,h,A;const m=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,c),[N,$,O,T]=(a=>{const e=(a=>H(La,l(a)?{[Na]:a}:a??{}))(a),n=e[Sa];if(e.mode==ma){const a=e[Na]??t;return[1,n,[a,e[$a]??f,e[fa]??Aa],ca(a)]}const{tables:{load:s={},save:o={}}={},values:i={}}=e,r=w(W(H(Ra,i)),0,X(Ra)),c=r[2],u=ca(c),y=ca(c);return[0,n,[Da(s,{[Oa]:null,[Ca]:f},Oa,(a=>F(y,a)),(a=>la(u,a))),Da(o,{[Ta]:null,[Ca]:f,[ba]:0,[Ia]:0},Ta,((a,t)=>F(y,t)),((a,t)=>la(u,t))),r],u]})(n);return(N?Ea:ga)(a,m,(a=>{let t;const e=()=>t=setInterval((async()=>{try{const[{d:t,s:e,c:n}]=await m(`${S} ${R} d,${D} s,TOTAL_CHANGES() c FROM ${L}${R} JOIN ${L}${D}`);t==g&&e==h&&n==A||(null!=g&&a(),g=t,h=e,A=n)}catch{}}),1e3*$),n=()=>{g=h=A=null,i(t)},s=o((t=>{T.has(t)&&(n(),a(),e())}));return e(),()=>{n(),r(s)}}),(a=>a()),u,y,d,O,k(T),(async(a,t)=>await a(`${S} t.name tn,c.name cn FROM ${_}list()t,${_}info(t.name)c ${C} t.schema='main'AND t.type IN('table','view')AND t.name IN(${P(t)})ORDER BY t.name,c.name`,t)),p,v,e,E,(a=>!0===a?1:!1===a?0:a),void 0)},Ma=(a,t,e,n,s,o)=>_a(a,n,(async(a,t=[])=>e.exec(a,{bind:t,rowMode:"object",returnValue:"resultRows"}).map((a=>({...a})))),(a=>t.capi.sqlite3_update_hook(e,((t,e,n,s)=>a(s)),0)),(()=>t.capi.sqlite3_update_hook(e,(()=>0),0)),s,o,(()=>0),3,e);export{Ma as createSqliteWasmPersister};
@@ -1 +1 @@
1
- const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),r=Promise,i=clearInterval,o=a=>null==a,c=(a,t,e)=>o(a)?e?.():t(a),l=t=>a(t)==s,u=a=>Array.isArray(a),w=(a,t,e)=>a.slice(t,e),y=a=>a.length,d=async a=>r.all(a),v=a=>{throw Error(a)},p=(a,t)=>a.forEach(t),E=(a,t="")=>a.join(t),g=(a,t)=>a.map(t),A=a=>0==y(a),h=(a,t)=>a.filter(t),m=(a,...t)=>a.push(...t),f=a=>a.shift(),N="_",$="_id",S="SELECT",C="WHERE",O="TABLE",T="ALTER "+O,I="DELETE FROM",L=S+"*FROM",b="pragma_",D="data_version",R="schema_version",M="pragma_table_",_=a=>`"${a.replace(/"/g,'""')}"`,P=(a,t=[1])=>E(g(a,(()=>"$"+t[0]++)),n),F=(a,t)=>a?.has(t)??!1,U=a=>o(a)||0==(a=>a?.size??0)(a),j=a=>[...a?.values()??[]],B=(a,t)=>a?.forEach(t),J=(a,t)=>a?.delete(t),Y=Object,k=a=>Y.getPrototypeOf(a),x=Y.entries,z=Y.keys,G=Y.freeze,H=(a=[])=>Y.fromEntries(a),K=(...a)=>Y.assign({},...a),Q=(a,t)=>(delete a[t],a),V=(a,t)=>g(x(a),(([a,e])=>t(e,a))),W=a=>Y.values(a),X=a=>y(z(a)),q=a=>(a=>!o(a)&&c(k(a),(a=>a==Y.prototype||o(k(a))),(()=>!0)))(a)&&0==X(a),Z=JSON.stringify,aa=JSON.parse,ta=a=>new Map(a),ea=(a,t)=>a?.get(t),na=(a,t)=>g([...a?.entries()??[]],(([a,e])=>t(e,a))),sa=(a,t,e)=>o(e)?(J(a,t),a):a?.set(t,e),ra=(a,t,e,n)=>(F(a,t)?n?.(ea(a,t)):sa(a,t,e()),ea(a,t)),ia=(a,t,e,n,s=0)=>c((e?ra:ea)(a,t[s],s>y(t)-2?e:ta),(r=>{if(s>y(t)-2)return n?.(r)&&sa(a,t[s]),r;const i=ia(r,t,e,n,s+1);return U(r)&&sa(a,t[s]),i})),oa=a=>new Set(u(a)||o(a)?a:[a]),ca=(a,t)=>a?.add(t),la=/^\d+$/,ua=ta(),wa=ta(),ya=(a,t,n,s,r,i,l,w={},d=0,E=[])=>{let g,A,h,N=0,$=0,S=0;ra(ua,E,(()=>0)),ra(wa,E,(()=>[]));const C=ta(),[O,T,I,L,b]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!q(a)||!q(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!q(a)||!q(t),t.setContent]:v("Store type not supported by this Persister"))(l,a,d),[D,R,M]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?f(a):null)??e+t++,t=>{la.test(t)&&y(a)<1e3&&m(a,t)}]})(),s=ta();return[(n,r,i,o=[],c=()=>[])=>{a??=z;const l=t(1);return sa(s,l,[n,r,i,o,c]),ca(ia(r,i??[e],oa),l),l},(t,n,...r)=>p(((a,t=[e])=>{const n=[],s=(a,e)=>e==y(t)?m(n,a):null===t[e]?B(a,(a=>s(a,e+1))):p([t[e],null],(t=>s(ea(a,t),e+1)));return s(a,0),n})(t,n),(t=>B(t,(t=>ea(s,t)[0](a,...n??[],...r))))),a=>c(ea(s,a),(([,t,r])=>(ia(t,r??[e],void 0,(t=>(J(t,a),U(t)?1:0))),sa(s,a),n(a),r))),t=>c(ea(s,t),(([t,,e=[],n,s])=>{const r=(...i)=>{const c=y(i);c==y(e)?t(a,...i,...s(i)):o(e[c])?p(n[c]?.(...i)??[],(a=>r(...i,a))):r(...i,e[c])};r()}))]})(),_=a=>{a!=N&&(N=a,R(C,void 0,N))},P=t=>{(O&&u(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},F=async a=>(2!=N&&(_(1),$++,await x((async()=>{try{const e=await t();u(e)?P(e):a?b(a):v("Content is not an array: "+e)}catch(t){i?.(t),a&&b(a)}_(0)}))),z),j=()=>(A&&(r(A),A=void 0),z),Y=async a=>(1!=N&&(_(2),S++,await x((async()=>{try{await n(T,a)}catch(a){i?.(a)}_(0)}))),z),k=()=>(h&&(a.delListener(h),h=void 0),z),x=async(...a)=>(m(ea(wa,E),...a),await(async()=>{if(!ea(ua,E)){for(sa(ua,E,1);!o(g=f(ea(wa,E)));)try{await g()}catch(a){i?.(a)}sa(ua,E,0)}})(),z),z={load:F,startAutoLoad:async a=>{j(),await F(a);try{A=await s((async(a,t)=>{t||a?2!=N&&(_(1),$++,P(t??a),_(0)):await F()}))}catch(a){i?.(a)}return z},stopAutoLoad:j,isAutoLoading:()=>!o(A),save:Y,startAutoSave:async()=>(k(),await Y(),h=a.addDidFinishTransactionListener((()=>{const a=I();L(a)&&Y(a)})),z),stopAutoSave:k,isAutoSaving:()=>!o(h),getStatus:()=>N,addStatusListener:a=>D(a,C),delListener:t=>(M(t),a),schedule:x,getStore:()=>a,destroy:()=>(ea(wa,E).splice(0,void 0),j().stopAutoSave()),getStats:()=>({loads:$,saves:S}),...w};return G(z)},da=(a,t,e,s,r,i=va,c,l)=>{const u=ta();return[async()=>{u.clear(),g(await e(a,t),(({tn:a,cn:t})=>ca(ra(u,a,oa),t)))},async(t,e)=>((a,t)=>F(ea(u,a),t))(t,e)?H(h(g(await a(L+_(t)),(a=>{return[a[e],l?(t=Q(a,e),n=l,H(V(t,((a,t)=>[t,n(a,t)])))):Q(a,e)];var t,n})),(([a,t])=>!o(a)&&!q(t)))):{},async(t,e,s,l,w,y=!1)=>{const v=oa();V(s??{},(a=>g(z(a??{}),(a=>ca(v,a)))));const p=j(v);if(!y&&w&&A(p)&&F(u,t))return await a("DROP "+O+_(t)),void sa(u,t);const f=ea(u,t),N=oa(j(f));if(A(p)||(F(u,t)?await d(g([e,...p],(async(n,s)=>{J(N,n)||(await a(T+_(t)+"ADD"+_(n)+r),0==s&&await a("CREATE UNIQUE INDEX pk ON "+_(t)+`(${_(e)})`),ca(f,n))}))):(await a("CREATE "+O+_(t)+`(${_(e)}${r} PRIMARY KEY${E(g(p,(a=>n+_(a)+r)))});`),sa(u,t,oa([e,...p])))),await d([...!y&&l?g(j(N),(async n=>{n!=e&&(await a(T+_(t)+"DROP"+_(n)),J(f,n))})):[]]),y)o(s)?await a(I+_(t)+C+" true"):await d(V(s,(async(n,s)=>{o(n)?await a(I+_(t)+C+_(e)+"=$1",[s]):A(p)||await i(a,t,e,z(n),{[s]:c?g(W(n),c):W(n)},f)})));else if(A(p))F(u,t)&&await a(I+_(t)+C+" true");else{const n=h(j(ea(u,t)),(a=>a!=e)),r={},o=[];V(s??{},((a,t)=>{r[t]=g(n,(t=>c?c(a?.[t]):a?.[t])),m(o,t)})),await i(a,t,e,n,r),await a(I+_(t)+C+_(e)+`NOT IN(${P(o)})`,o)}},async t=>{let e;await a("BEGIN");try{e=await t()}catch(a){s?.(a)}return await a("END"),e}]},va=async(a,t,e,s,r)=>{const i=[1];await a("INSERT INTO"+_(t)+"("+((...a)=>E(g(a,_),n))(e,...s)+")VALUES"+E(V(r,(a=>"($"+i[0]+++","+P(a,i)+")")),n)+"ON CONFLICT("+_(e)+")DO UPDATE SET"+E(g(s,(a=>_(a)+"=excluded."+_(a))),n),V(r,((a,t)=>[t,...g(a,(a=>a??null))])).flat())},pa=(a,t,e,n,s,r,i,[o,c,l],u,w,y,d,v,p)=>{const[E,g,A,h]=da(t,u,w,s,v,p),m=ya(a,(async()=>await h((async()=>{return await E(),a=(await g(o,c))[N]?.[l]??"null",aa(a,((a,t)=>""===t?void 0:t));var a}))),(async a=>await h((async()=>{var t;await E(),await A(o,c,{[N]:{[l]:(t=a()??null,Z(t,((a,t)=>void 0===t?"":t)))}},!0,!0)}))),e,n,s,i,{[d]:()=>y,destroy:()=>(m.stopAutoLoad().stopAutoSave(),r(),m)},0,y);return m},Ea=(a,t,e,n,s,r,i,[c,l,[u,w,y]],v,p,E,g,A,m,f,S)=>{const[C,O,T,I]=da(t,v,p,s,A,m,f,S),L=async(a,t)=>await d(na(l,(async([e,n,s,r],i)=>{t&&!(i in a)||await T(e,n,a[i],s,r,t)}))),b=async(a,t)=>w?await T(y,$,{[N]:a},!0,!0,t):null,D=ya(a,(async()=>await I((async()=>{await C();const a=await(async()=>H(h(await d(na(c,(async([a,t],e)=>[a,await O(e,t)]))),(a=>!q(a[1])))))(),t=await(async()=>u?(await O(y,$))[N]:{})();return q(a)&&o(t)?void 0:[a,t]}))),(async(a,t)=>await I((async()=>{if(await C(),o(t)){const[t,e]=a();await L(t),await b(e)}else await L(t[0],!0),await b(t[1],!0)}))),e,n,s,i,{[g]:()=>E,destroy:()=>(D.stopAutoLoad().stopAutoSave(),r(),D)},0,E);return D},ga="ColumnName",Aa="store",ha="json",ma=Aa+"TableName",fa=Aa+"Id"+ga,Na=Aa+ga,$a="autoLoadIntervalSeconds",Sa="rowId"+ga,Ca="tableId",Oa="tableName",Ta="deleteEmptyColumns",Ia="deleteEmptyTable",La={mode:ha,[$a]:1},ba={load:0,save:0,[Oa]:t+"_values"},Da=(a,t,e,n,s)=>{const r=ta();return V(a,((a,i)=>{const c=w(W(K(t,l(a)?{[e]:a}:a)),0,X(t));o(c[0])||n(i,c[0])||(s(i,c[0]),sa(r,i,c))})),r},Ra=(a,n,s,r,o,c,u,y,d,v,p="getDb",E)=>{let g,A,h;const m=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,c),[f,N,O,T]=(a=>{const e=(a=>K(La,l(a)?{[ma]:a}:a??{}))(a),n=e[$a];if(e.mode==ha){const a=e[ma]??t;return[1,n,[a,e[fa]??$,e[Na]??Aa],oa(a)]}const{tables:{load:s={},save:r={}}={},values:i={}}=e,o=w(W(K(ba,i)),0,X(ba)),c=o[2],u=oa(c),y=oa(c);return[0,n,[Da(s,{[Ca]:null,[Sa]:$},Ca,(a=>F(y,a)),(a=>ca(u,a))),Da(r,{[Oa]:null,[Sa]:$,[Ta]:0,[Ia]:0},Oa,((a,t)=>F(y,t)),((a,t)=>ca(u,t))),o],u]})(n);return(f?pa:Ea)(a,m,(a=>{let t;const e=()=>t=setInterval((async()=>{try{const[{d:t,s:e,c:n}]=await m(`${S} ${D} d,${R} s,TOTAL_CHANGES() c FROM ${b}${D} JOIN ${b}${R}`);t==g&&e==A&&n==h||(null!=g&&a(),g=t,A=e,h=n)}catch{}}),1e3*N),n=()=>{g=A=h=null,i(t)},s=r((t=>{T.has(t)&&(n(),a(),e())}));return e(),()=>{n(),o(s)}}),(a=>a()),u,y,d,O,j(T),(async(a,t)=>await a(`${S} t.name tn,c.name cn FROM ${M}list()t,${M}info(t.name)c ${C} t.schema='main'AND t.type IN('table','view')AND t.name IN(${P(t)})ORDER BY t.name,c.name`,t)),v,p,e,E,(a=>!0===a?1:!1===a?0:a),void 0)},Ma="change",_a=(a,t,e,n,s)=>Ra(a,e,(async(a,e=[])=>{return await(n=(n,s)=>t.all(a,e,((a,t)=>a?s(a):n(t))),new r(n));var n}),(a=>{const e=(t,e,n)=>a(n);return t.on(Ma,e),e}),(a=>t.off(Ma,a)),n,s,(()=>0),3,t);export{_a as createSqlite3Persister};
1
+ const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),i=Promise,o=clearInterval,r=a=>null==a,c=(a,t,e)=>r(a)?e?.():t(a),l=t=>a(t)==s,w=a=>Array.isArray(a),u=(a,t,e)=>a.slice(t,e),y=a=>a.length,d=async a=>i.all(a),v=a=>{throw Error(a)},p=(a,t)=>a.forEach(t),E=(a,t="")=>a.join(t),g=(a,t)=>a.map(t),A=a=>0==y(a),h=(a,t)=>a.filter(t),m=(a,...t)=>a.push(...t),f=a=>a.shift(),N="_",$="_id",S="SELECT",C="WHERE",O="TABLE",T="ALTER "+O,I="DELETE FROM",L=S+"*FROM",b="pragma_",D="data_version",R="schema_version",M="pragma_table_",_=a=>`"${a.replace(/"/g,'""')}"`,P=(a,t=[1])=>E(g(a,(()=>"$"+t[0]++)),n),F=(a,t)=>a?.has(t)??!1,U=a=>r(a)||0==(a=>a?.size??0)(a),j=a=>[...a?.values()??[]],B=(a,t)=>a?.forEach(t),J=(a,t)=>a?.delete(t),Y=Object,k=a=>Y.getPrototypeOf(a),x=Y.entries,z=Y.keys,G=Y.freeze,H=(a=[])=>Y.fromEntries(a),K=(...a)=>Y.assign({},...a),Q=(a,t)=>(delete a[t],a),V=(a,t)=>g(x(a),(([a,e])=>t(e,a))),W=(a,t)=>H(V(a,((a,e)=>[e,t(a,e)]))),X=a=>Y.values(a),q=a=>y(z(a)),Z=a=>(a=>!r(a)&&c(k(a),(a=>a==Y.prototype||r(k(a))),(()=>!0)))(a)&&0==q(a),aa=JSON.stringify,ta=JSON.parse,ea=a=>new Map(a),na=(a,t)=>a?.get(t),sa=(a,t)=>g([...a?.entries()??[]],(([a,e])=>t(e,a))),ia=(a,t,e)=>r(e)?(J(a,t),a):a?.set(t,e),oa=(a,t,e,n)=>(F(a,t)?n?.(na(a,t)):ia(a,t,e()),na(a,t)),ra=(a,t,e,n,s=0)=>c((e?oa:na)(a,t[s],s>y(t)-2?e:ea),(i=>{if(s>y(t)-2)return n?.(i)&&ia(a,t[s]),i;const o=ra(i,t,e,n,s+1);return U(i)&&ia(a,t[s]),o})),ca=a=>new Set(w(a)||r(a)?a:[a]),la=(a,t)=>a?.add(t),wa=/^\d+$/,ua=ea(),ya=ea(),da=(a,t,n,s,i,o,l,u={},d=0,E=[])=>{let g,A,h,N=0,$=0,S=0;oa(ua,E,(()=>0)),oa(ya,E,(()=>[]));const C=ea(),[O,T,I,L,b]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!Z(a)||!Z(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!Z(a)||!Z(t),t.setContent]:v("Store type not supported by this Persister"))(l,a,d),[D,R,M]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?f(a):null)??e+t++,t=>{wa.test(t)&&y(a)<1e3&&m(a,t)}]})(),s=ea();return[(n,i,o,r=[],c=()=>[])=>{a??=z;const l=t(1);return ia(s,l,[n,i,o,r,c]),la(ra(i,o??[e],ca),l),l},(t,n,...i)=>p(((a,t=[e])=>{const n=[],s=(a,e)=>e==y(t)?m(n,a):null===t[e]?B(a,(a=>s(a,e+1))):p([t[e],null],(t=>s(na(a,t),e+1)));return s(a,0),n})(t,n),(t=>B(t,(t=>na(s,t)[0](a,...n??[],...i))))),a=>c(na(s,a),(([,t,i])=>(ra(t,i??[e],void 0,(t=>(J(t,a),U(t)?1:0))),ia(s,a),n(a),i))),t=>c(na(s,t),(([t,,e=[],n,s])=>{const i=(...o)=>{const c=y(o);c==y(e)?t(a,...o,...s(o)):r(e[c])?p(n[c]?.(...o)??[],(a=>i(...o,a))):i(...o,e[c])};i()}))]})(),_=a=>{a!=N&&(N=a,R(C,void 0,N))},P=t=>{(O&&w(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},F=async a=>(2!=N&&(_(1),$++,await x((async()=>{try{const e=await t();w(e)?P(e):a?b(a):v("Content is not an array: "+e)}catch(t){o?.(t),a&&b(a)}_(0)}))),z),j=()=>(A&&(i(A),A=void 0),z),Y=async a=>(1!=N&&(_(2),S++,await x((async()=>{try{await n(T,a)}catch(a){o?.(a)}_(0)}))),z),k=()=>(h&&(a.delListener(h),h=void 0),z),x=async(...a)=>(m(na(ya,E),...a),await(async()=>{if(!na(ua,E)){for(ia(ua,E,1);!r(g=f(na(ya,E)));)try{await g()}catch(a){o?.(a)}ia(ua,E,0)}})(),z),z={load:F,startAutoLoad:async a=>{j(),await F(a);try{A=await s((async(a,t)=>{t||a?2!=N&&(_(1),$++,P(t??a),_(0)):await F()}))}catch(a){o?.(a)}return z},stopAutoLoad:j,isAutoLoading:()=>!r(A),save:Y,startAutoSave:async()=>(k(),await Y(),h=a.addDidFinishTransactionListener((()=>{const a=I();L(a)&&Y(a)})),z),stopAutoSave:k,isAutoSaving:()=>!r(h),getStatus:()=>N,addStatusListener:a=>D(a,C),delListener:t=>(M(t),a),schedule:x,getStore:()=>a,destroy:()=>(na(ya,E).splice(0,void 0),j().stopAutoSave()),getStats:()=>({loads:$,saves:S}),...u};return G(z)},va=(a,t,e,s,i,o=pa,c,l)=>{const w=ea();return[async()=>{w.clear(),g(await e(a,t),(({tn:a,cn:t})=>la(oa(w,a,ca),t)))},async(t,e)=>((a,t)=>F(na(w,a),t))(t,e)?H(h(g(await a(L+_(t)),(a=>[a[e],l?W(Q(a,e),l):Q(a,e)])),(([a,t])=>!r(a)&&!Z(t)))):{},async(t,e,s,l,u,y=!1)=>{const v=ca();W(s??{},(a=>g(z(a??{}),(a=>la(v,a)))));const p=j(v);if(!y&&u&&A(p)&&F(w,t))return await a("DROP "+O+_(t)),void ia(w,t);const f=na(w,t),N=ca(j(f));if(A(p)||(F(w,t)?await d(g([e,...p],(async(n,s)=>{J(N,n)||(await a(T+_(t)+"ADD"+_(n)+i),0==s&&await a("CREATE UNIQUE INDEX pk ON "+_(t)+`(${_(e)})`),la(f,n))}))):(await a("CREATE "+O+_(t)+`(${_(e)}${i} PRIMARY KEY${E(g(p,(a=>n+_(a)+i)))});`),ia(w,t,ca([e,...p])))),await d([...!y&&l?g(j(N),(async n=>{n!=e&&(await a(T+_(t)+"DROP"+_(n)),J(f,n))})):[]]),y)r(s)?await a(I+_(t)+C+" true"):await d(V(s,(async(n,s)=>{r(n)?await a(I+_(t)+C+_(e)+"=$1",[s]):A(p)||await o(a,t,e,z(n),{[s]:c?g(X(n),c):X(n)},f)})));else if(A(p))F(w,t)&&await a(I+_(t)+C+" true");else{const n=h(j(na(w,t)),(a=>a!=e)),i={},r=[];W(s??{},((a,t)=>{i[t]=g(n,(t=>c?c(a?.[t]):a?.[t])),m(r,t)})),await o(a,t,e,n,i),await a(I+_(t)+C+_(e)+`NOT IN(${P(r)})`,r)}},async t=>{let e;await a("BEGIN");try{e=await t()}catch(a){s?.(a)}return await a("END"),e}]},pa=async(a,t,e,s,i)=>{const o=[1];await a("INSERT INTO"+_(t)+"("+((...a)=>E(g(a,_),n))(e,...s)+")VALUES"+E(V(i,(a=>"($"+o[0]+++","+P(a,o)+")")),n)+"ON CONFLICT("+_(e)+")DO UPDATE SET"+E(g(s,(a=>_(a)+"=excluded."+_(a))),n),V(i,((a,t)=>[t,...g(a,(a=>a??null))])).flat())},Ea=(a,t,e,n,s,i,o,[r,c,l],w,u,y,d,v,p)=>{const[E,g,A,h]=va(t,w,u,s,v,p),m=da(a,(async()=>await h((async()=>{return await E(),a=(await g(r,c))[N]?.[l]??"null",ta(a,((a,t)=>""===t?void 0:t));var a}))),(async a=>await h((async()=>{var t;await E(),await A(r,c,{[N]:{[l]:(t=a()??null,aa(t,((a,t)=>void 0===t?"":t)))}},!0,!0)}))),e,n,s,o,{[d]:()=>y,destroy:()=>(m.stopAutoLoad().stopAutoSave(),i(),m)},0,y);return m},ga=(a,t,e,n,s,i,o,[c,l,[w,u,y]],v,p,E,g,A,m,f,S)=>{const[C,O,T,I]=va(t,v,p,s,A,m,f,S),L=async(a,t)=>await d(sa(l,(async([e,n,s,i],o)=>{t&&!(o in a)||await T(e,n,a[o],s,i,t)}))),b=async(a,t)=>u?await T(y,$,{[N]:a},!0,!0,t):null,D=da(a,(async()=>await I((async()=>{await C();const a=await(async()=>H(h(await d(sa(c,(async([a,t],e)=>[a,await O(e,t)]))),(a=>!Z(a[1])))))(),t=await(async()=>w?(await O(y,$))[N]:{})();return Z(a)&&r(t)?void 0:[a,t]}))),(async(a,t)=>await I((async()=>{if(await C(),r(t)){const[t,e]=a();await L(t),await b(e)}else await L(t[0],!0),await b(t[1],!0)}))),e,n,s,o,{[g]:()=>E,destroy:()=>(D.stopAutoLoad().stopAutoSave(),i(),D)},0,E);return D},Aa="ColumnName",ha="store",ma="json",fa=ha+"TableName",Na=ha+"Id"+Aa,$a=ha+Aa,Sa="autoLoadIntervalSeconds",Ca="rowId"+Aa,Oa="tableId",Ta="tableName",Ia="deleteEmptyColumns",La="deleteEmptyTable",ba={mode:ma,[Sa]:1},Da={load:0,save:0,[Ta]:t+"_values"},Ra=(a,t,e,n,s)=>{const i=ea();return W(a,((a,o)=>{const c=u(X(K(t,l(a)?{[e]:a}:a)),0,q(t));r(c[0])||n(o,c[0])||(s(o,c[0]),ia(i,o,c))})),i},Ma=(a,n,s,i,r,c,w,y,d,v,p="getDb",E)=>{let g,A,h;const m=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,c),[f,N,O,T]=(a=>{const e=(a=>K(ba,l(a)?{[fa]:a}:a??{}))(a),n=e[Sa];if(e.mode==ma){const a=e[fa]??t;return[1,n,[a,e[Na]??$,e[$a]??ha],ca(a)]}const{tables:{load:s={},save:i={}}={},values:o={}}=e,r=u(X(K(Da,o)),0,q(Da)),c=r[2],w=ca(c),y=ca(c);return[0,n,[Ra(s,{[Oa]:null,[Ca]:$},Oa,(a=>F(y,a)),(a=>la(w,a))),Ra(i,{[Ta]:null,[Ca]:$,[Ia]:0,[La]:0},Ta,((a,t)=>F(y,t)),((a,t)=>la(w,t))),r],w]})(n);return(f?Ea:ga)(a,m,(a=>{let t;const e=()=>t=setInterval((async()=>{try{const[{d:t,s:e,c:n}]=await m(`${S} ${D} d,${R} s,TOTAL_CHANGES() c FROM ${b}${D} JOIN ${b}${R}`);t==g&&e==A&&n==h||(null!=g&&a(),g=t,A=e,h=n)}catch{}}),1e3*N),n=()=>{g=A=h=null,o(t)},s=i((t=>{T.has(t)&&(n(),a(),e())}));return e(),()=>{n(),r(s)}}),(a=>a()),w,y,d,O,j(T),(async(a,t)=>await a(`${S} t.name tn,c.name cn FROM ${M}list()t,${M}info(t.name)c ${C} t.schema='main'AND t.type IN('table','view')AND t.name IN(${P(t)})ORDER BY t.name,c.name`,t)),v,p,e,E,(a=>!0===a?1:!1===a?0:a),void 0)},_a="change",Pa=(a,t,e,n,s)=>Ma(a,e,(async(a,e=[])=>{return await(n=(n,s)=>t.all(a,e,((a,t)=>a?s(a):n(t))),new i(n));var n}),(a=>{const e=(t,e,n)=>a(n);return t.on(_a,e),e}),(a=>t.off(_a,a)),n,s,(()=>0),3,t);export{Pa as createSqlite3Persister};
@@ -1 +1 @@
1
- const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),r=Promise,i=clearInterval,o=a=>null==a,c=(a,t,e)=>o(a)?e?.():t(a),l=t=>a(t)==s,u=a=>Array.isArray(a),w=(a,t,e)=>a.slice(t,e),y=a=>a.length,d=async a=>r.all(a),v=a=>{throw Error(a)},p=(a,t)=>a.forEach(t),E=(a,t="")=>a.join(t),g=(a,t)=>a.map(t),A=a=>0==y(a),h=(a,t)=>a.filter(t),m=(a,...t)=>a.push(...t),f=a=>a.shift(),N="_",$="_id",S="SELECT",C="WHERE",O="TABLE",T="ALTER "+O,I="DELETE FROM",L=S+"*FROM",b="pragma_",D="data_version",R="schema_version",M="pragma_table_",_=a=>`"${a.replace(/"/g,'""')}"`,P=(a,t=[1])=>E(g(a,(()=>"$"+t[0]++)),n),F=(a,t)=>a?.has(t)??!1,U=a=>o(a)||0==(a=>a?.size??0)(a),j=a=>[...a?.values()??[]],B=(a,t)=>a?.forEach(t),J=(a,t)=>a?.delete(t),Y=Object,k=a=>Y.getPrototypeOf(a),x=Y.entries,z=Y.keys,G=Y.freeze,H=(a=[])=>Y.fromEntries(a),K=(...a)=>Y.assign({},...a),Q=(a,t)=>(delete a[t],a),V=(a,t)=>g(x(a),(([a,e])=>t(e,a))),W=a=>Y.values(a),X=a=>y(z(a)),q=a=>(a=>!o(a)&&c(k(a),(a=>a==Y.prototype||o(k(a))),(()=>!0)))(a)&&0==X(a),Z=JSON.stringify,aa=JSON.parse,ta=a=>new Map(a),ea=(a,t)=>a?.get(t),na=(a,t)=>g([...a?.entries()??[]],(([a,e])=>t(e,a))),sa=(a,t,e)=>o(e)?(J(a,t),a):a?.set(t,e),ra=(a,t,e,n)=>(F(a,t)?n?.(ea(a,t)):sa(a,t,e()),ea(a,t)),ia=(a,t,e,n,s=0)=>c((e?ra:ea)(a,t[s],s>y(t)-2?e:ta),(r=>{if(s>y(t)-2)return n?.(r)&&sa(a,t[s]),r;const i=ia(r,t,e,n,s+1);return U(r)&&sa(a,t[s]),i})),oa=a=>new Set(u(a)||o(a)?a:[a]),ca=(a,t)=>a?.add(t),la=/^\d+$/,ua=ta(),wa=ta(),ya=(a,t,n,s,r,i,l,w={},d=0,E=[])=>{let g,A,h,N=0,$=0,S=0;ra(ua,E,(()=>0)),ra(wa,E,(()=>[]));const C=ta(),[O,T,I,L,b]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!q(a)||!q(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!q(a)||!q(t),t.setContent]:v("Store type not supported by this Persister"))(l,a,d),[D,R,M]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?f(a):null)??e+t++,t=>{la.test(t)&&y(a)<1e3&&m(a,t)}]})(),s=ta();return[(n,r,i,o=[],c=()=>[])=>{a??=z;const l=t(1);return sa(s,l,[n,r,i,o,c]),ca(ia(r,i??[e],oa),l),l},(t,n,...r)=>p(((a,t=[e])=>{const n=[],s=(a,e)=>e==y(t)?m(n,a):null===t[e]?B(a,(a=>s(a,e+1))):p([t[e],null],(t=>s(ea(a,t),e+1)));return s(a,0),n})(t,n),(t=>B(t,(t=>ea(s,t)[0](a,...n??[],...r))))),a=>c(ea(s,a),(([,t,r])=>(ia(t,r??[e],void 0,(t=>(J(t,a),U(t)?1:0))),sa(s,a),n(a),r))),t=>c(ea(s,t),(([t,,e=[],n,s])=>{const r=(...i)=>{const c=y(i);c==y(e)?t(a,...i,...s(i)):o(e[c])?p(n[c]?.(...i)??[],(a=>r(...i,a))):r(...i,e[c])};r()}))]})(),_=a=>{a!=N&&(N=a,R(C,void 0,N))},P=t=>{(O&&u(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},F=async a=>(2!=N&&(_(1),$++,await x((async()=>{try{const e=await t();u(e)?P(e):a?b(a):v("Content is not an array: "+e)}catch(t){i?.(t),a&&b(a)}_(0)}))),z),j=()=>(A&&(r(A),A=void 0),z),Y=async a=>(1!=N&&(_(2),S++,await x((async()=>{try{await n(T,a)}catch(a){i?.(a)}_(0)}))),z),k=()=>(h&&(a.delListener(h),h=void 0),z),x=async(...a)=>(m(ea(wa,E),...a),await(async()=>{if(!ea(ua,E)){for(sa(ua,E,1);!o(g=f(ea(wa,E)));)try{await g()}catch(a){i?.(a)}sa(ua,E,0)}})(),z),z={load:F,startAutoLoad:async a=>{j(),await F(a);try{A=await s((async(a,t)=>{t||a?2!=N&&(_(1),$++,P(t??a),_(0)):await F()}))}catch(a){i?.(a)}return z},stopAutoLoad:j,isAutoLoading:()=>!o(A),save:Y,startAutoSave:async()=>(k(),await Y(),h=a.addDidFinishTransactionListener((()=>{const a=I();L(a)&&Y(a)})),z),stopAutoSave:k,isAutoSaving:()=>!o(h),getStatus:()=>N,addStatusListener:a=>D(a,C),delListener:t=>(M(t),a),schedule:x,getStore:()=>a,destroy:()=>(ea(wa,E).splice(0,void 0),j().stopAutoSave()),getStats:()=>({loads:$,saves:S}),...w};return G(z)},da=(a,t,e,s,r,i=va,c,l)=>{const u=ta();return[async()=>{u.clear(),g(await e(a,t),(({tn:a,cn:t})=>ca(ra(u,a,oa),t)))},async(t,e)=>((a,t)=>F(ea(u,a),t))(t,e)?H(h(g(await a(L+_(t)),(a=>{return[a[e],l?(t=Q(a,e),n=l,H(V(t,((a,t)=>[t,n(a,t)])))):Q(a,e)];var t,n})),(([a,t])=>!o(a)&&!q(t)))):{},async(t,e,s,l,w,y=!1)=>{const v=oa();V(s??{},(a=>g(z(a??{}),(a=>ca(v,a)))));const p=j(v);if(!y&&w&&A(p)&&F(u,t))return await a("DROP "+O+_(t)),void sa(u,t);const f=ea(u,t),N=oa(j(f));if(A(p)||(F(u,t)?await d(g([e,...p],(async(n,s)=>{J(N,n)||(await a(T+_(t)+"ADD"+_(n)+r),0==s&&await a("CREATE UNIQUE INDEX pk ON "+_(t)+`(${_(e)})`),ca(f,n))}))):(await a("CREATE "+O+_(t)+`(${_(e)}${r} PRIMARY KEY${E(g(p,(a=>n+_(a)+r)))});`),sa(u,t,oa([e,...p])))),await d([...!y&&l?g(j(N),(async n=>{n!=e&&(await a(T+_(t)+"DROP"+_(n)),J(f,n))})):[]]),y)o(s)?await a(I+_(t)+C+" true"):await d(V(s,(async(n,s)=>{o(n)?await a(I+_(t)+C+_(e)+"=$1",[s]):A(p)||await i(a,t,e,z(n),{[s]:c?g(W(n),c):W(n)},f)})));else if(A(p))F(u,t)&&await a(I+_(t)+C+" true");else{const n=h(j(ea(u,t)),(a=>a!=e)),r={},o=[];V(s??{},((a,t)=>{r[t]=g(n,(t=>c?c(a?.[t]):a?.[t])),m(o,t)})),await i(a,t,e,n,r),await a(I+_(t)+C+_(e)+`NOT IN(${P(o)})`,o)}},async t=>{let e;await a("BEGIN");try{e=await t()}catch(a){s?.(a)}return await a("END"),e}]},va=async(a,t,e,s,r)=>{const i=[1];await a("INSERT INTO"+_(t)+"("+((...a)=>E(g(a,_),n))(e,...s)+")VALUES"+E(V(r,(a=>"($"+i[0]+++","+P(a,i)+")")),n)+"ON CONFLICT("+_(e)+")DO UPDATE SET"+E(g(s,(a=>_(a)+"=excluded."+_(a))),n),V(r,((a,t)=>[t,...g(a,(a=>a??null))])).flat())},pa=(a,t,e,n,s,r,i,[o,c,l],u,w,y,d,v,p)=>{const[E,g,A,h]=da(t,u,w,s,v,p),m=ya(a,(async()=>await h((async()=>{return await E(),a=(await g(o,c))[N]?.[l]??"null",aa(a,((a,t)=>""===t?void 0:t));var a}))),(async a=>await h((async()=>{var t;await E(),await A(o,c,{[N]:{[l]:(t=a()??null,Z(t,((a,t)=>void 0===t?"":t)))}},!0,!0)}))),e,n,s,i,{[d]:()=>y,destroy:()=>(m.stopAutoLoad().stopAutoSave(),r(),m)},0,y);return m},Ea=(a,t,e,n,s,r,i,[c,l,[u,w,y]],v,p,E,g,A,m,f,S)=>{const[C,O,T,I]=da(t,v,p,s,A,m,f,S),L=async(a,t)=>await d(na(l,(async([e,n,s,r],i)=>{t&&!(i in a)||await T(e,n,a[i],s,r,t)}))),b=async(a,t)=>w?await T(y,$,{[N]:a},!0,!0,t):null,D=ya(a,(async()=>await I((async()=>{await C();const a=await(async()=>H(h(await d(na(c,(async([a,t],e)=>[a,await O(e,t)]))),(a=>!q(a[1])))))(),t=await(async()=>u?(await O(y,$))[N]:{})();return q(a)&&o(t)?void 0:[a,t]}))),(async(a,t)=>await I((async()=>{if(await C(),o(t)){const[t,e]=a();await L(t),await b(e)}else await L(t[0],!0),await b(t[1],!0)}))),e,n,s,i,{[g]:()=>E,destroy:()=>(D.stopAutoLoad().stopAutoSave(),r(),D)},0,E);return D},ga="ColumnName",Aa="store",ha="json",ma=Aa+"TableName",fa=Aa+"Id"+ga,Na=Aa+ga,$a="autoLoadIntervalSeconds",Sa="rowId"+ga,Ca="tableId",Oa="tableName",Ta="deleteEmptyColumns",Ia="deleteEmptyTable",La={mode:ha,[$a]:1},ba={load:0,save:0,[Oa]:t+"_values"},Da=(a,t,e,n,s)=>{const r=ta();return V(a,((a,i)=>{const c=w(W(K(t,l(a)?{[e]:a}:a)),0,X(t));o(c[0])||n(i,c[0])||(s(i,c[0]),sa(r,i,c))})),r},Ra=(a,n,s,r,o,c,u,y,d,v,p="getDb",E)=>{let g,A,h;const m=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,c),[f,N,O,T]=(a=>{const e=(a=>K(La,l(a)?{[ma]:a}:a??{}))(a),n=e[$a];if(e.mode==ha){const a=e[ma]??t;return[1,n,[a,e[fa]??$,e[Na]??Aa],oa(a)]}const{tables:{load:s={},save:r={}}={},values:i={}}=e,o=w(W(K(ba,i)),0,X(ba)),c=o[2],u=oa(c),y=oa(c);return[0,n,[Da(s,{[Ca]:null,[Sa]:$},Ca,(a=>F(y,a)),(a=>ca(u,a))),Da(r,{[Oa]:null,[Sa]:$,[Ta]:0,[Ia]:0},Oa,((a,t)=>F(y,t)),((a,t)=>ca(u,t))),o],u]})(n);return(f?pa:Ea)(a,m,(a=>{let t;const e=()=>t=setInterval((async()=>{try{const[{d:t,s:e,c:n}]=await m(`${S} ${D} d,${R} s,TOTAL_CHANGES() c FROM ${b}${D} JOIN ${b}${R}`);t==g&&e==A&&n==h||(null!=g&&a(),g=t,A=e,h=n)}catch{}}),1e3*N),n=()=>{g=A=h=null,i(t)},s=r((t=>{T.has(t)&&(n(),a(),e())}));return e(),()=>{n(),o(s)}}),(a=>a()),u,y,d,O,j(T),(async(a,t)=>await a(`${S} t.name tn,c.name cn FROM ${M}list()t,${M}info(t.name)c ${C} t.schema='main'AND t.type IN('table','view')AND t.name IN(${P(t)})ORDER BY t.name,c.name`,t)),v,p,e,E,(a=>!0===a?1:!1===a?0:a),void 0)},Ma="change",_a=(a,t,e,n,s)=>Ra(a,e,(async(a,e=[])=>{return await(n=(n,s)=>t.all(a,e,((a,t)=>a?s(a):n(t))),new r(n));var n}),(a=>{const e=(t,e,n)=>a(n);return t.on(Ma,e),e}),(a=>t.off(Ma,a)),n,s,(()=>0),3,t);export{_a as createSqlite3Persister};
1
+ const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),i=Promise,o=clearInterval,r=a=>null==a,c=(a,t,e)=>r(a)?e?.():t(a),l=t=>a(t)==s,w=a=>Array.isArray(a),u=(a,t,e)=>a.slice(t,e),y=a=>a.length,d=async a=>i.all(a),v=a=>{throw Error(a)},p=(a,t)=>a.forEach(t),E=(a,t="")=>a.join(t),g=(a,t)=>a.map(t),A=a=>0==y(a),h=(a,t)=>a.filter(t),m=(a,...t)=>a.push(...t),f=a=>a.shift(),N="_",$="_id",S="SELECT",C="WHERE",O="TABLE",T="ALTER "+O,I="DELETE FROM",L=S+"*FROM",b="pragma_",D="data_version",R="schema_version",M="pragma_table_",_=a=>`"${a.replace(/"/g,'""')}"`,P=(a,t=[1])=>E(g(a,(()=>"$"+t[0]++)),n),F=(a,t)=>a?.has(t)??!1,U=a=>r(a)||0==(a=>a?.size??0)(a),j=a=>[...a?.values()??[]],B=(a,t)=>a?.forEach(t),J=(a,t)=>a?.delete(t),Y=Object,k=a=>Y.getPrototypeOf(a),x=Y.entries,z=Y.keys,G=Y.freeze,H=(a=[])=>Y.fromEntries(a),K=(...a)=>Y.assign({},...a),Q=(a,t)=>(delete a[t],a),V=(a,t)=>g(x(a),(([a,e])=>t(e,a))),W=(a,t)=>H(V(a,((a,e)=>[e,t(a,e)]))),X=a=>Y.values(a),q=a=>y(z(a)),Z=a=>(a=>!r(a)&&c(k(a),(a=>a==Y.prototype||r(k(a))),(()=>!0)))(a)&&0==q(a),aa=JSON.stringify,ta=JSON.parse,ea=a=>new Map(a),na=(a,t)=>a?.get(t),sa=(a,t)=>g([...a?.entries()??[]],(([a,e])=>t(e,a))),ia=(a,t,e)=>r(e)?(J(a,t),a):a?.set(t,e),oa=(a,t,e,n)=>(F(a,t)?n?.(na(a,t)):ia(a,t,e()),na(a,t)),ra=(a,t,e,n,s=0)=>c((e?oa:na)(a,t[s],s>y(t)-2?e:ea),(i=>{if(s>y(t)-2)return n?.(i)&&ia(a,t[s]),i;const o=ra(i,t,e,n,s+1);return U(i)&&ia(a,t[s]),o})),ca=a=>new Set(w(a)||r(a)?a:[a]),la=(a,t)=>a?.add(t),wa=/^\d+$/,ua=ea(),ya=ea(),da=(a,t,n,s,i,o,l,u={},d=0,E=[])=>{let g,A,h,N=0,$=0,S=0;oa(ua,E,(()=>0)),oa(ya,E,(()=>[]));const C=ea(),[O,T,I,L,b]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!Z(a)||!Z(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!Z(a)||!Z(t),t.setContent]:v("Store type not supported by this Persister"))(l,a,d),[D,R,M]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?f(a):null)??e+t++,t=>{wa.test(t)&&y(a)<1e3&&m(a,t)}]})(),s=ea();return[(n,i,o,r=[],c=()=>[])=>{a??=z;const l=t(1);return ia(s,l,[n,i,o,r,c]),la(ra(i,o??[e],ca),l),l},(t,n,...i)=>p(((a,t=[e])=>{const n=[],s=(a,e)=>e==y(t)?m(n,a):null===t[e]?B(a,(a=>s(a,e+1))):p([t[e],null],(t=>s(na(a,t),e+1)));return s(a,0),n})(t,n),(t=>B(t,(t=>na(s,t)[0](a,...n??[],...i))))),a=>c(na(s,a),(([,t,i])=>(ra(t,i??[e],void 0,(t=>(J(t,a),U(t)?1:0))),ia(s,a),n(a),i))),t=>c(na(s,t),(([t,,e=[],n,s])=>{const i=(...o)=>{const c=y(o);c==y(e)?t(a,...o,...s(o)):r(e[c])?p(n[c]?.(...o)??[],(a=>i(...o,a))):i(...o,e[c])};i()}))]})(),_=a=>{a!=N&&(N=a,R(C,void 0,N))},P=t=>{(O&&w(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},F=async a=>(2!=N&&(_(1),$++,await x((async()=>{try{const e=await t();w(e)?P(e):a?b(a):v("Content is not an array: "+e)}catch(t){o?.(t),a&&b(a)}_(0)}))),z),j=()=>(A&&(i(A),A=void 0),z),Y=async a=>(1!=N&&(_(2),S++,await x((async()=>{try{await n(T,a)}catch(a){o?.(a)}_(0)}))),z),k=()=>(h&&(a.delListener(h),h=void 0),z),x=async(...a)=>(m(na(ya,E),...a),await(async()=>{if(!na(ua,E)){for(ia(ua,E,1);!r(g=f(na(ya,E)));)try{await g()}catch(a){o?.(a)}ia(ua,E,0)}})(),z),z={load:F,startAutoLoad:async a=>{j(),await F(a);try{A=await s((async(a,t)=>{t||a?2!=N&&(_(1),$++,P(t??a),_(0)):await F()}))}catch(a){o?.(a)}return z},stopAutoLoad:j,isAutoLoading:()=>!r(A),save:Y,startAutoSave:async()=>(k(),await Y(),h=a.addDidFinishTransactionListener((()=>{const a=I();L(a)&&Y(a)})),z),stopAutoSave:k,isAutoSaving:()=>!r(h),getStatus:()=>N,addStatusListener:a=>D(a,C),delListener:t=>(M(t),a),schedule:x,getStore:()=>a,destroy:()=>(na(ya,E).splice(0,void 0),j().stopAutoSave()),getStats:()=>({loads:$,saves:S}),...u};return G(z)},va=(a,t,e,s,i,o=pa,c,l)=>{const w=ea();return[async()=>{w.clear(),g(await e(a,t),(({tn:a,cn:t})=>la(oa(w,a,ca),t)))},async(t,e)=>((a,t)=>F(na(w,a),t))(t,e)?H(h(g(await a(L+_(t)),(a=>[a[e],l?W(Q(a,e),l):Q(a,e)])),(([a,t])=>!r(a)&&!Z(t)))):{},async(t,e,s,l,u,y=!1)=>{const v=ca();W(s??{},(a=>g(z(a??{}),(a=>la(v,a)))));const p=j(v);if(!y&&u&&A(p)&&F(w,t))return await a("DROP "+O+_(t)),void ia(w,t);const f=na(w,t),N=ca(j(f));if(A(p)||(F(w,t)?await d(g([e,...p],(async(n,s)=>{J(N,n)||(await a(T+_(t)+"ADD"+_(n)+i),0==s&&await a("CREATE UNIQUE INDEX pk ON "+_(t)+`(${_(e)})`),la(f,n))}))):(await a("CREATE "+O+_(t)+`(${_(e)}${i} PRIMARY KEY${E(g(p,(a=>n+_(a)+i)))});`),ia(w,t,ca([e,...p])))),await d([...!y&&l?g(j(N),(async n=>{n!=e&&(await a(T+_(t)+"DROP"+_(n)),J(f,n))})):[]]),y)r(s)?await a(I+_(t)+C+" true"):await d(V(s,(async(n,s)=>{r(n)?await a(I+_(t)+C+_(e)+"=$1",[s]):A(p)||await o(a,t,e,z(n),{[s]:c?g(X(n),c):X(n)},f)})));else if(A(p))F(w,t)&&await a(I+_(t)+C+" true");else{const n=h(j(na(w,t)),(a=>a!=e)),i={},r=[];W(s??{},((a,t)=>{i[t]=g(n,(t=>c?c(a?.[t]):a?.[t])),m(r,t)})),await o(a,t,e,n,i),await a(I+_(t)+C+_(e)+`NOT IN(${P(r)})`,r)}},async t=>{let e;await a("BEGIN");try{e=await t()}catch(a){s?.(a)}return await a("END"),e}]},pa=async(a,t,e,s,i)=>{const o=[1];await a("INSERT INTO"+_(t)+"("+((...a)=>E(g(a,_),n))(e,...s)+")VALUES"+E(V(i,(a=>"($"+o[0]+++","+P(a,o)+")")),n)+"ON CONFLICT("+_(e)+")DO UPDATE SET"+E(g(s,(a=>_(a)+"=excluded."+_(a))),n),V(i,((a,t)=>[t,...g(a,(a=>a??null))])).flat())},Ea=(a,t,e,n,s,i,o,[r,c,l],w,u,y,d,v,p)=>{const[E,g,A,h]=va(t,w,u,s,v,p),m=da(a,(async()=>await h((async()=>{return await E(),a=(await g(r,c))[N]?.[l]??"null",ta(a,((a,t)=>""===t?void 0:t));var a}))),(async a=>await h((async()=>{var t;await E(),await A(r,c,{[N]:{[l]:(t=a()??null,aa(t,((a,t)=>void 0===t?"":t)))}},!0,!0)}))),e,n,s,o,{[d]:()=>y,destroy:()=>(m.stopAutoLoad().stopAutoSave(),i(),m)},0,y);return m},ga=(a,t,e,n,s,i,o,[c,l,[w,u,y]],v,p,E,g,A,m,f,S)=>{const[C,O,T,I]=va(t,v,p,s,A,m,f,S),L=async(a,t)=>await d(sa(l,(async([e,n,s,i],o)=>{t&&!(o in a)||await T(e,n,a[o],s,i,t)}))),b=async(a,t)=>u?await T(y,$,{[N]:a},!0,!0,t):null,D=da(a,(async()=>await I((async()=>{await C();const a=await(async()=>H(h(await d(sa(c,(async([a,t],e)=>[a,await O(e,t)]))),(a=>!Z(a[1])))))(),t=await(async()=>w?(await O(y,$))[N]:{})();return Z(a)&&r(t)?void 0:[a,t]}))),(async(a,t)=>await I((async()=>{if(await C(),r(t)){const[t,e]=a();await L(t),await b(e)}else await L(t[0],!0),await b(t[1],!0)}))),e,n,s,o,{[g]:()=>E,destroy:()=>(D.stopAutoLoad().stopAutoSave(),i(),D)},0,E);return D},Aa="ColumnName",ha="store",ma="json",fa=ha+"TableName",Na=ha+"Id"+Aa,$a=ha+Aa,Sa="autoLoadIntervalSeconds",Ca="rowId"+Aa,Oa="tableId",Ta="tableName",Ia="deleteEmptyColumns",La="deleteEmptyTable",ba={mode:ma,[Sa]:1},Da={load:0,save:0,[Ta]:t+"_values"},Ra=(a,t,e,n,s)=>{const i=ea();return W(a,((a,o)=>{const c=u(X(K(t,l(a)?{[e]:a}:a)),0,q(t));r(c[0])||n(o,c[0])||(s(o,c[0]),ia(i,o,c))})),i},Ma=(a,n,s,i,r,c,w,y,d,v,p="getDb",E)=>{let g,A,h;const m=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,c),[f,N,O,T]=(a=>{const e=(a=>K(ba,l(a)?{[fa]:a}:a??{}))(a),n=e[Sa];if(e.mode==ma){const a=e[fa]??t;return[1,n,[a,e[Na]??$,e[$a]??ha],ca(a)]}const{tables:{load:s={},save:i={}}={},values:o={}}=e,r=u(X(K(Da,o)),0,q(Da)),c=r[2],w=ca(c),y=ca(c);return[0,n,[Ra(s,{[Oa]:null,[Ca]:$},Oa,(a=>F(y,a)),(a=>la(w,a))),Ra(i,{[Ta]:null,[Ca]:$,[Ia]:0,[La]:0},Ta,((a,t)=>F(y,t)),((a,t)=>la(w,t))),r],w]})(n);return(f?Ea:ga)(a,m,(a=>{let t;const e=()=>t=setInterval((async()=>{try{const[{d:t,s:e,c:n}]=await m(`${S} ${D} d,${R} s,TOTAL_CHANGES() c FROM ${b}${D} JOIN ${b}${R}`);t==g&&e==A&&n==h||(null!=g&&a(),g=t,A=e,h=n)}catch{}}),1e3*N),n=()=>{g=A=h=null,o(t)},s=i((t=>{T.has(t)&&(n(),a(),e())}));return e(),()=>{n(),r(s)}}),(a=>a()),w,y,d,O,j(T),(async(a,t)=>await a(`${S} t.name tn,c.name cn FROM ${M}list()t,${M}info(t.name)c ${C} t.schema='main'AND t.type IN('table','view')AND t.name IN(${P(t)})ORDER BY t.name,c.name`,t)),v,p,e,E,(a=>!0===a?1:!1===a?0:a),void 0)},_a="change",Pa=(a,t,e,n,s)=>Ma(a,e,(async(a,e=[])=>{return await(n=(n,s)=>t.all(a,e,((a,t)=>a?s(a):n(t))),new i(n));var n}),(a=>{const e=(t,e,n)=>a(n);return t.on(_a,e),e}),(a=>t.off(_a,a)),n,s,(()=>0),3,t);export{Pa as createSqlite3Persister};
@@ -1 +1 @@
1
- import{Map as t}from"yjs";const e="t",n="v",a=t=>null==t,s=(t,e,n)=>a(t)?n?.():e(t),o=t=>Array.isArray(t),r=t=>t.length,i=t=>{throw Error(t)},c=(t,e)=>t.forEach(e),l=(t,...e)=>t.push(...e),g=t=>t.shift(),u=Object,d=t=>u.getPrototypeOf(t),y=u.entries,p=u.keys,h=u.freeze,v=(t=[])=>u.fromEntries(t),w=(t,e)=>e in t,S=(t,e)=>((t,e)=>t.map(e))(y(t),(([t,n])=>e(n,t))),f=t=>(t=>!a(t)&&s(d(t),(t=>t==u.prototype||a(d(t))),(()=>!0)))(t)&&0==(t=>r(p(t)))(t),C=(t,e,n)=>(w(t,e)||(t[e]=n()),t[e]),b=t=>a(t)||0==(t=>t?.size??0)(t),A=(t,e)=>t?.forEach(e),M=(t,e)=>t?.delete(e),O=t=>new Map(t),L=(t,e)=>t?.get(e),J=(t,e)=>A(t,((t,n)=>e(n,t))),N=(t,e,n)=>a(n)?(M(t,e),t):t?.set(e,n),z=(t,e,n,a)=>{var s,o;return s=t,o=e,s?.has(o)?a?.(L(t,e)):N(t,e,n()),L(t,e)},D=(t,e,n,a,o=0)=>s((n?z:L)(t,e[o],o>r(e)-2?n:O),(s=>{if(o>r(e)-2)return a?.(s)&&N(t,e[o]),s;const i=D(s,e,n,a,o+1);return b(s)&&N(t,e[o]),i})),E=t=>new Set(o(t)||a(t)?t:[t]),m=/^\d+$/,T=O(),j=O(),k=(t,e,n,u,d,y,p,v={},w=0,S=[])=>{let C,J,k,P=0,x=0,F=0;z(T,S,(()=>0)),z(j,S,(()=>[]));const Y=O(),[$,q,B,G,H]=((t=1,e,n)=>1!=t&&e.isMergeable()?[1,e.getMergeableContent,()=>e.getTransactionMergeableChanges(!n),([[t],[e]])=>!f(t)||!f(e),e.setDefaultContent]:2!=t?[0,e.getContent,e.getTransactionChanges,([t,e])=>!f(t)||!f(e),e.setContent]:i("Store type not supported by this Persister"))(p,t,w),[I,K,Q]=(()=>{let t;const[e,n]=(()=>{const t=[];let e=0;return[n=>(n?g(t):null)??""+e++,e=>{m.test(e)&&r(t)<1e3&&l(t,e)}]})(),o=O();return[(n,a,s,r=[],i=()=>[])=>{t??=tt;const c=e(1);var l,g;return N(o,c,[n,a,s,r,i]),l=D(a,s??[""],E),g=c,l?.add(g),c},(e,n,...a)=>c(((t,e=[""])=>{const n=[],a=(t,s)=>s==r(e)?l(n,t):null===e[s]?A(t,(t=>a(t,s+1))):c([e[s],null],(e=>a(L(t,e),s+1)));return a(t,0),n})(e,n),(e=>A(e,(e=>L(o,e)[0](t,...n??[],...a))))),t=>s(L(o,t),(([,e,a])=>(D(e,a??[""],void 0,(e=>(M(e,t),b(e)?1:0))),N(o,t),n(t),a))),e=>s(L(o,e),(([e,,n=[],s,o])=>{const i=(...l)=>{const g=r(l);g==r(n)?e(t,...l,...o(l)):a(n[g])?c(s[g]?.(...l)??[],(t=>i(...l,t))):i(...l,n[g])};i()}))]})(),R=t=>{t!=P&&(P=t,K(Y,void 0,P))},U=e=>{($&&o(e?.[0])?1===e?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===e?.[2]?t.applyChanges:t.setContent)(e)},V=async t=>(2!=P&&(R(1),x++,await _((async()=>{try{const n=await e();o(n)?U(n):t?H(t):i("Content is not an array: "+n)}catch(e){y?.(e),t&&H(t)}R(0)}))),tt),W=()=>(J&&(d(J),J=void 0),tt),X=async t=>(1!=P&&(R(2),F++,await _((async()=>{try{await n(q,t)}catch(t){y?.(t)}R(0)}))),tt),Z=()=>(k&&(t.delListener(k),k=void 0),tt),_=async(...t)=>(l(L(j,S),...t),await(async()=>{if(!L(T,S)){for(N(T,S,1);!a(C=g(L(j,S)));)try{await C()}catch(t){y?.(t)}N(T,S,0)}})(),tt),tt={load:V,startAutoLoad:async t=>{W(),await V(t);try{J=await u((async(t,e)=>{e||t?2!=P&&(R(1),x++,U(e??t),R(0)):await V()}))}catch(t){y?.(t)}return tt},stopAutoLoad:W,isAutoLoading:()=>!a(J),save:X,startAutoSave:async()=>(Z(),await X(),k=t.addDidFinishTransactionListener((()=>{const t=B();G(t)&&X(t)})),tt),stopAutoSave:Z,isAutoSaving:()=>!a(k),getStatus:()=>P,addStatusListener:t=>I(t,Y),delListener:e=>(Q(e),t),schedule:_,getStore:()=>t,destroy:()=>(L(j,S).splice(0,void 0),W().stopAutoSave()),getStats:()=>({loads:x,saves:F}),...v};return h(tt)},P="delete",x=t=>[t.get(e),t.get(n)],F=(e,n,s,o)=>{const r=a(n)?e:e.get(n)??e.set(n,new t);let i;return S(s,((t,e)=>{o(r,e,t)&&(i=1)})),r.forEach(((t,e)=>{w(s,e)||(r.delete(e),i=1)})),a(n)||r.size||e.delete(n),i},Y=(o,i,l="tinybase",u)=>{const d=i.getMap(l);return k(o,(async()=>d.size?[d.get(e).toJSON(),d.get(n).toJSON()]:void 0),(async(o,r)=>i.transact((()=>((o,r,i)=>{o.size||(o.set(e,new t),o.set(n,new t));const[c,l]=x(o),g=()=>{u=1};let u=1;if(s(i,(([t,e])=>{u=0,S(t,((t,e)=>u?0:a(t)?c.delete(e):s(c.get(e),(e=>S(t,((t,n)=>u?0:a(t)?e.delete(n):s(e.get(n),(e=>S(t,((t,n)=>a(t)?e.delete(n):e.set(n,t)))),g)))),g))),S(e,((t,e)=>u?0:a(t)?l.delete(e):l.set(e,t)))})),u){const[t,e]=r();F(c,void 0,t,((t,e,n)=>F(c,e,n,((t,e,n)=>F(t,e,n,((t,e,n)=>{if(t.get(e)!==n)return t.set(e,n),1})))))),F(l,void 0,e,((t,e,n)=>{l.get(e)!==n&&l.set(e,n)}))}})(d,o,r)))),(t=>{const a=a=>t(void 0,((t,a)=>{if(1==r(a)&&(o=a[0].path,0==r(o)))return[t.get(e).toJSON(),t.get(n).toJSON(),1];var o;const[i,l]=x(t),u={},d={};return c(a,(({path:t,changes:{keys:n}})=>g(t)==e?s(g(t),(e=>{const a=C(u,e,v),o=i.get(e);s(g(t),(t=>{const e=C(a,t,v),s=o.get(t);J(n,((t,{action:n})=>e[t]=n==P?null:s.get(t)))}),(()=>J(n,((t,{action:e})=>a[t]=e==P?null:o.get(t)?.toJSON()))))}),(()=>J(n,((t,{action:e})=>u[t]=e==P?null:i.get(t)?.toJSON())))):J(n,((t,{action:e})=>d[t]=e==P?null:l.get(t))))),[u,d,1]})(d,a));return d.observeDeep(a),a}),(t=>{d.unobserveDeep(t)}),u,1,{getYDoc:()=>i})};export{Y as createYjsPersister};
1
+ import{Map as t}from"yjs";const e="t",n="v",a=t=>null==t,s=(t,e,n)=>a(t)?n?.():e(t),o=t=>Array.isArray(t),r=t=>t.length,i=t=>{throw Error(t)},c=(t,e)=>t.forEach(e),l=(t,...e)=>t.push(...e),g=t=>t.shift(),u=Object,d=t=>u.getPrototypeOf(t),y=u.entries,p=u.keys,h=u.freeze,v=(t=[])=>u.fromEntries(t),w=(t,e)=>e in t,S=(t,e)=>v(((t,e)=>((t,e)=>t.map(e))(y(t),(([t,n])=>e(n,t))))(t,((t,n)=>[n,e(t,n)]))),f=t=>(t=>!a(t)&&s(d(t),(t=>t==u.prototype||a(d(t))),(()=>!0)))(t)&&0==(t=>r(p(t)))(t),C=(t,e,n)=>(w(t,e)||(t[e]=n()),t[e]),b=t=>a(t)||0==(t=>t?.size??0)(t),A=(t,e)=>t?.forEach(e),M=(t,e)=>t?.delete(e),O=t=>new Map(t),L=(t,e)=>t?.get(e),J=(t,e)=>A(t,((t,n)=>e(n,t))),N=(t,e,n)=>a(n)?(M(t,e),t):t?.set(e,n),z=(t,e,n,a)=>{var s,o;return s=t,o=e,s?.has(o)?a?.(L(t,e)):N(t,e,n()),L(t,e)},D=(t,e,n,a,o=0)=>s((n?z:L)(t,e[o],o>r(e)-2?n:O),(s=>{if(o>r(e)-2)return a?.(s)&&N(t,e[o]),s;const i=D(s,e,n,a,o+1);return b(s)&&N(t,e[o]),i})),E=t=>new Set(o(t)||a(t)?t:[t]),m=/^\d+$/,T=O(),j=O(),k=(t,e,n,u,d,y,p,v={},w=0,S=[])=>{let C,J,k,P=0,x=0,F=0;z(T,S,(()=>0)),z(j,S,(()=>[]));const Y=O(),[$,q,B,G,H]=((t=1,e,n)=>1!=t&&e.isMergeable()?[1,e.getMergeableContent,()=>e.getTransactionMergeableChanges(!n),([[t],[e]])=>!f(t)||!f(e),e.setDefaultContent]:2!=t?[0,e.getContent,e.getTransactionChanges,([t,e])=>!f(t)||!f(e),e.setContent]:i("Store type not supported by this Persister"))(p,t,w),[I,K,Q]=(()=>{let t;const[e,n]=(()=>{const t=[];let e=0;return[n=>(n?g(t):null)??""+e++,e=>{m.test(e)&&r(t)<1e3&&l(t,e)}]})(),o=O();return[(n,a,s,r=[],i=()=>[])=>{t??=tt;const c=e(1);var l,g;return N(o,c,[n,a,s,r,i]),l=D(a,s??[""],E),g=c,l?.add(g),c},(e,n,...a)=>c(((t,e=[""])=>{const n=[],a=(t,s)=>s==r(e)?l(n,t):null===e[s]?A(t,(t=>a(t,s+1))):c([e[s],null],(e=>a(L(t,e),s+1)));return a(t,0),n})(e,n),(e=>A(e,(e=>L(o,e)[0](t,...n??[],...a))))),t=>s(L(o,t),(([,e,a])=>(D(e,a??[""],void 0,(e=>(M(e,t),b(e)?1:0))),N(o,t),n(t),a))),e=>s(L(o,e),(([e,,n=[],s,o])=>{const i=(...l)=>{const g=r(l);g==r(n)?e(t,...l,...o(l)):a(n[g])?c(s[g]?.(...l)??[],(t=>i(...l,t))):i(...l,n[g])};i()}))]})(),R=t=>{t!=P&&(P=t,K(Y,void 0,P))},U=e=>{($&&o(e?.[0])?1===e?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===e?.[2]?t.applyChanges:t.setContent)(e)},V=async t=>(2!=P&&(R(1),x++,await _((async()=>{try{const n=await e();o(n)?U(n):t?H(t):i("Content is not an array: "+n)}catch(e){y?.(e),t&&H(t)}R(0)}))),tt),W=()=>(J&&(d(J),J=void 0),tt),X=async t=>(1!=P&&(R(2),F++,await _((async()=>{try{await n(q,t)}catch(t){y?.(t)}R(0)}))),tt),Z=()=>(k&&(t.delListener(k),k=void 0),tt),_=async(...t)=>(l(L(j,S),...t),await(async()=>{if(!L(T,S)){for(N(T,S,1);!a(C=g(L(j,S)));)try{await C()}catch(t){y?.(t)}N(T,S,0)}})(),tt),tt={load:V,startAutoLoad:async t=>{W(),await V(t);try{J=await u((async(t,e)=>{e||t?2!=P&&(R(1),x++,U(e??t),R(0)):await V()}))}catch(t){y?.(t)}return tt},stopAutoLoad:W,isAutoLoading:()=>!a(J),save:X,startAutoSave:async()=>(Z(),await X(),k=t.addDidFinishTransactionListener((()=>{const t=B();G(t)&&X(t)})),tt),stopAutoSave:Z,isAutoSaving:()=>!a(k),getStatus:()=>P,addStatusListener:t=>I(t,Y),delListener:e=>(Q(e),t),schedule:_,getStore:()=>t,destroy:()=>(L(j,S).splice(0,void 0),W().stopAutoSave()),getStats:()=>({loads:x,saves:F}),...v};return h(tt)},P="delete",x=t=>[t.get(e),t.get(n)],F=(e,n,s,o)=>{const r=a(n)?e:e.get(n)??e.set(n,new t);let i;return S(s,((t,e)=>{o(r,e,t)&&(i=1)})),r.forEach(((t,e)=>{w(s,e)||(r.delete(e),i=1)})),a(n)||r.size||e.delete(n),i},Y=(o,i,l="tinybase",u)=>{const d=i.getMap(l);return k(o,(async()=>d.size?[d.get(e).toJSON(),d.get(n).toJSON()]:void 0),(async(o,r)=>i.transact((()=>((o,r,i)=>{o.size||(o.set(e,new t),o.set(n,new t));const[c,l]=x(o),g=()=>{u=1};let u=1;if(s(i,(([t,e])=>{u=0,S(t,((t,e)=>u?0:a(t)?c.delete(e):s(c.get(e),(e=>S(t,((t,n)=>u?0:a(t)?e.delete(n):s(e.get(n),(e=>S(t,((t,n)=>a(t)?e.delete(n):e.set(n,t)))),g)))),g))),S(e,((t,e)=>u?0:a(t)?l.delete(e):l.set(e,t)))})),u){const[t,e]=r();F(c,void 0,t,((t,e,n)=>F(c,e,n,((t,e,n)=>F(t,e,n,((t,e,n)=>{if(t.get(e)!==n)return t.set(e,n),1})))))),F(l,void 0,e,((t,e,n)=>{l.get(e)!==n&&l.set(e,n)}))}})(d,o,r)))),(t=>{const a=a=>t(void 0,((t,a)=>{if(1==r(a)&&(o=a[0].path,0==r(o)))return[t.get(e).toJSON(),t.get(n).toJSON(),1];var o;const[i,l]=x(t),u={},d={};return c(a,(({path:t,changes:{keys:n}})=>g(t)==e?s(g(t),(e=>{const a=C(u,e,v),o=i.get(e);s(g(t),(t=>{const e=C(a,t,v),s=o.get(t);J(n,((t,{action:n})=>e[t]=n==P?null:s.get(t)))}),(()=>J(n,((t,{action:e})=>a[t]=e==P?null:o.get(t)?.toJSON()))))}),(()=>J(n,((t,{action:e})=>u[t]=e==P?null:i.get(t)?.toJSON())))):J(n,((t,{action:e})=>d[t]=e==P?null:l.get(t))))),[u,d,1]})(d,a));return d.observeDeep(a),a}),(t=>{d.unobserveDeep(t)}),u,1,{getYDoc:()=>i})};export{Y as createYjsPersister};
@@ -1 +1 @@
1
- import{Map as t}from"yjs";const e="t",n="v",a=t=>null==t,s=(t,e,n)=>a(t)?n?.():e(t),o=t=>Array.isArray(t),r=t=>t.length,i=t=>{throw Error(t)},c=(t,e)=>t.forEach(e),l=(t,...e)=>t.push(...e),g=t=>t.shift(),u=Object,d=t=>u.getPrototypeOf(t),y=u.entries,p=u.keys,h=u.freeze,v=(t=[])=>u.fromEntries(t),w=(t,e)=>e in t,S=(t,e)=>((t,e)=>t.map(e))(y(t),(([t,n])=>e(n,t))),f=t=>(t=>!a(t)&&s(d(t),(t=>t==u.prototype||a(d(t))),(()=>!0)))(t)&&0==(t=>r(p(t)))(t),C=(t,e,n)=>(w(t,e)||(t[e]=n()),t[e]),b=t=>a(t)||0==(t=>t?.size??0)(t),A=(t,e)=>t?.forEach(e),M=(t,e)=>t?.delete(e),O=t=>new Map(t),L=(t,e)=>t?.get(e),J=(t,e)=>A(t,((t,n)=>e(n,t))),N=(t,e,n)=>a(n)?(M(t,e),t):t?.set(e,n),z=(t,e,n,a)=>{var s,o;return s=t,o=e,s?.has(o)?a?.(L(t,e)):N(t,e,n()),L(t,e)},D=(t,e,n,a,o=0)=>s((n?z:L)(t,e[o],o>r(e)-2?n:O),(s=>{if(o>r(e)-2)return a?.(s)&&N(t,e[o]),s;const i=D(s,e,n,a,o+1);return b(s)&&N(t,e[o]),i})),E=t=>new Set(o(t)||a(t)?t:[t]),m=/^\d+$/,T=O(),j=O(),k=(t,e,n,u,d,y,p,v={},w=0,S=[])=>{let C,J,k,P=0,x=0,F=0;z(T,S,(()=>0)),z(j,S,(()=>[]));const Y=O(),[$,q,B,G,H]=((t=1,e,n)=>1!=t&&e.isMergeable()?[1,e.getMergeableContent,()=>e.getTransactionMergeableChanges(!n),([[t],[e]])=>!f(t)||!f(e),e.setDefaultContent]:2!=t?[0,e.getContent,e.getTransactionChanges,([t,e])=>!f(t)||!f(e),e.setContent]:i("Store type not supported by this Persister"))(p,t,w),[I,K,Q]=(()=>{let t;const[e,n]=(()=>{const t=[];let e=0;return[n=>(n?g(t):null)??""+e++,e=>{m.test(e)&&r(t)<1e3&&l(t,e)}]})(),o=O();return[(n,a,s,r=[],i=()=>[])=>{t??=tt;const c=e(1);var l,g;return N(o,c,[n,a,s,r,i]),l=D(a,s??[""],E),g=c,l?.add(g),c},(e,n,...a)=>c(((t,e=[""])=>{const n=[],a=(t,s)=>s==r(e)?l(n,t):null===e[s]?A(t,(t=>a(t,s+1))):c([e[s],null],(e=>a(L(t,e),s+1)));return a(t,0),n})(e,n),(e=>A(e,(e=>L(o,e)[0](t,...n??[],...a))))),t=>s(L(o,t),(([,e,a])=>(D(e,a??[""],void 0,(e=>(M(e,t),b(e)?1:0))),N(o,t),n(t),a))),e=>s(L(o,e),(([e,,n=[],s,o])=>{const i=(...l)=>{const g=r(l);g==r(n)?e(t,...l,...o(l)):a(n[g])?c(s[g]?.(...l)??[],(t=>i(...l,t))):i(...l,n[g])};i()}))]})(),R=t=>{t!=P&&(P=t,K(Y,void 0,P))},U=e=>{($&&o(e?.[0])?1===e?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===e?.[2]?t.applyChanges:t.setContent)(e)},V=async t=>(2!=P&&(R(1),x++,await _((async()=>{try{const n=await e();o(n)?U(n):t?H(t):i("Content is not an array: "+n)}catch(e){y?.(e),t&&H(t)}R(0)}))),tt),W=()=>(J&&(d(J),J=void 0),tt),X=async t=>(1!=P&&(R(2),F++,await _((async()=>{try{await n(q,t)}catch(t){y?.(t)}R(0)}))),tt),Z=()=>(k&&(t.delListener(k),k=void 0),tt),_=async(...t)=>(l(L(j,S),...t),await(async()=>{if(!L(T,S)){for(N(T,S,1);!a(C=g(L(j,S)));)try{await C()}catch(t){y?.(t)}N(T,S,0)}})(),tt),tt={load:V,startAutoLoad:async t=>{W(),await V(t);try{J=await u((async(t,e)=>{e||t?2!=P&&(R(1),x++,U(e??t),R(0)):await V()}))}catch(t){y?.(t)}return tt},stopAutoLoad:W,isAutoLoading:()=>!a(J),save:X,startAutoSave:async()=>(Z(),await X(),k=t.addDidFinishTransactionListener((()=>{const t=B();G(t)&&X(t)})),tt),stopAutoSave:Z,isAutoSaving:()=>!a(k),getStatus:()=>P,addStatusListener:t=>I(t,Y),delListener:e=>(Q(e),t),schedule:_,getStore:()=>t,destroy:()=>(L(j,S).splice(0,void 0),W().stopAutoSave()),getStats:()=>({loads:x,saves:F}),...v};return h(tt)},P="delete",x=t=>[t.get(e),t.get(n)],F=(e,n,s,o)=>{const r=a(n)?e:e.get(n)??e.set(n,new t);let i;return S(s,((t,e)=>{o(r,e,t)&&(i=1)})),r.forEach(((t,e)=>{w(s,e)||(r.delete(e),i=1)})),a(n)||r.size||e.delete(n),i},Y=(o,i,l="tinybase",u)=>{const d=i.getMap(l);return k(o,(async()=>d.size?[d.get(e).toJSON(),d.get(n).toJSON()]:void 0),(async(o,r)=>i.transact((()=>((o,r,i)=>{o.size||(o.set(e,new t),o.set(n,new t));const[c,l]=x(o),g=()=>{u=1};let u=1;if(s(i,(([t,e])=>{u=0,S(t,((t,e)=>u?0:a(t)?c.delete(e):s(c.get(e),(e=>S(t,((t,n)=>u?0:a(t)?e.delete(n):s(e.get(n),(e=>S(t,((t,n)=>a(t)?e.delete(n):e.set(n,t)))),g)))),g))),S(e,((t,e)=>u?0:a(t)?l.delete(e):l.set(e,t)))})),u){const[t,e]=r();F(c,void 0,t,((t,e,n)=>F(c,e,n,((t,e,n)=>F(t,e,n,((t,e,n)=>{if(t.get(e)!==n)return t.set(e,n),1})))))),F(l,void 0,e,((t,e,n)=>{l.get(e)!==n&&l.set(e,n)}))}})(d,o,r)))),(t=>{const a=a=>t(void 0,((t,a)=>{if(1==r(a)&&(o=a[0].path,0==r(o)))return[t.get(e).toJSON(),t.get(n).toJSON(),1];var o;const[i,l]=x(t),u={},d={};return c(a,(({path:t,changes:{keys:n}})=>g(t)==e?s(g(t),(e=>{const a=C(u,e,v),o=i.get(e);s(g(t),(t=>{const e=C(a,t,v),s=o.get(t);J(n,((t,{action:n})=>e[t]=n==P?null:s.get(t)))}),(()=>J(n,((t,{action:e})=>a[t]=e==P?null:o.get(t)?.toJSON()))))}),(()=>J(n,((t,{action:e})=>u[t]=e==P?null:i.get(t)?.toJSON())))):J(n,((t,{action:e})=>d[t]=e==P?null:l.get(t))))),[u,d,1]})(d,a));return d.observeDeep(a),a}),(t=>{d.unobserveDeep(t)}),u,1,{getYDoc:()=>i})};export{Y as createYjsPersister};
1
+ import{Map as t}from"yjs";const e="t",n="v",a=t=>null==t,s=(t,e,n)=>a(t)?n?.():e(t),o=t=>Array.isArray(t),r=t=>t.length,i=t=>{throw Error(t)},c=(t,e)=>t.forEach(e),l=(t,...e)=>t.push(...e),g=t=>t.shift(),u=Object,d=t=>u.getPrototypeOf(t),y=u.entries,p=u.keys,h=u.freeze,v=(t=[])=>u.fromEntries(t),w=(t,e)=>e in t,S=(t,e)=>v(((t,e)=>((t,e)=>t.map(e))(y(t),(([t,n])=>e(n,t))))(t,((t,n)=>[n,e(t,n)]))),f=t=>(t=>!a(t)&&s(d(t),(t=>t==u.prototype||a(d(t))),(()=>!0)))(t)&&0==(t=>r(p(t)))(t),C=(t,e,n)=>(w(t,e)||(t[e]=n()),t[e]),b=t=>a(t)||0==(t=>t?.size??0)(t),A=(t,e)=>t?.forEach(e),M=(t,e)=>t?.delete(e),O=t=>new Map(t),L=(t,e)=>t?.get(e),J=(t,e)=>A(t,((t,n)=>e(n,t))),N=(t,e,n)=>a(n)?(M(t,e),t):t?.set(e,n),z=(t,e,n,a)=>{var s,o;return s=t,o=e,s?.has(o)?a?.(L(t,e)):N(t,e,n()),L(t,e)},D=(t,e,n,a,o=0)=>s((n?z:L)(t,e[o],o>r(e)-2?n:O),(s=>{if(o>r(e)-2)return a?.(s)&&N(t,e[o]),s;const i=D(s,e,n,a,o+1);return b(s)&&N(t,e[o]),i})),E=t=>new Set(o(t)||a(t)?t:[t]),m=/^\d+$/,T=O(),j=O(),k=(t,e,n,u,d,y,p,v={},w=0,S=[])=>{let C,J,k,P=0,x=0,F=0;z(T,S,(()=>0)),z(j,S,(()=>[]));const Y=O(),[$,q,B,G,H]=((t=1,e,n)=>1!=t&&e.isMergeable()?[1,e.getMergeableContent,()=>e.getTransactionMergeableChanges(!n),([[t],[e]])=>!f(t)||!f(e),e.setDefaultContent]:2!=t?[0,e.getContent,e.getTransactionChanges,([t,e])=>!f(t)||!f(e),e.setContent]:i("Store type not supported by this Persister"))(p,t,w),[I,K,Q]=(()=>{let t;const[e,n]=(()=>{const t=[];let e=0;return[n=>(n?g(t):null)??""+e++,e=>{m.test(e)&&r(t)<1e3&&l(t,e)}]})(),o=O();return[(n,a,s,r=[],i=()=>[])=>{t??=tt;const c=e(1);var l,g;return N(o,c,[n,a,s,r,i]),l=D(a,s??[""],E),g=c,l?.add(g),c},(e,n,...a)=>c(((t,e=[""])=>{const n=[],a=(t,s)=>s==r(e)?l(n,t):null===e[s]?A(t,(t=>a(t,s+1))):c([e[s],null],(e=>a(L(t,e),s+1)));return a(t,0),n})(e,n),(e=>A(e,(e=>L(o,e)[0](t,...n??[],...a))))),t=>s(L(o,t),(([,e,a])=>(D(e,a??[""],void 0,(e=>(M(e,t),b(e)?1:0))),N(o,t),n(t),a))),e=>s(L(o,e),(([e,,n=[],s,o])=>{const i=(...l)=>{const g=r(l);g==r(n)?e(t,...l,...o(l)):a(n[g])?c(s[g]?.(...l)??[],(t=>i(...l,t))):i(...l,n[g])};i()}))]})(),R=t=>{t!=P&&(P=t,K(Y,void 0,P))},U=e=>{($&&o(e?.[0])?1===e?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===e?.[2]?t.applyChanges:t.setContent)(e)},V=async t=>(2!=P&&(R(1),x++,await _((async()=>{try{const n=await e();o(n)?U(n):t?H(t):i("Content is not an array: "+n)}catch(e){y?.(e),t&&H(t)}R(0)}))),tt),W=()=>(J&&(d(J),J=void 0),tt),X=async t=>(1!=P&&(R(2),F++,await _((async()=>{try{await n(q,t)}catch(t){y?.(t)}R(0)}))),tt),Z=()=>(k&&(t.delListener(k),k=void 0),tt),_=async(...t)=>(l(L(j,S),...t),await(async()=>{if(!L(T,S)){for(N(T,S,1);!a(C=g(L(j,S)));)try{await C()}catch(t){y?.(t)}N(T,S,0)}})(),tt),tt={load:V,startAutoLoad:async t=>{W(),await V(t);try{J=await u((async(t,e)=>{e||t?2!=P&&(R(1),x++,U(e??t),R(0)):await V()}))}catch(t){y?.(t)}return tt},stopAutoLoad:W,isAutoLoading:()=>!a(J),save:X,startAutoSave:async()=>(Z(),await X(),k=t.addDidFinishTransactionListener((()=>{const t=B();G(t)&&X(t)})),tt),stopAutoSave:Z,isAutoSaving:()=>!a(k),getStatus:()=>P,addStatusListener:t=>I(t,Y),delListener:e=>(Q(e),t),schedule:_,getStore:()=>t,destroy:()=>(L(j,S).splice(0,void 0),W().stopAutoSave()),getStats:()=>({loads:x,saves:F}),...v};return h(tt)},P="delete",x=t=>[t.get(e),t.get(n)],F=(e,n,s,o)=>{const r=a(n)?e:e.get(n)??e.set(n,new t);let i;return S(s,((t,e)=>{o(r,e,t)&&(i=1)})),r.forEach(((t,e)=>{w(s,e)||(r.delete(e),i=1)})),a(n)||r.size||e.delete(n),i},Y=(o,i,l="tinybase",u)=>{const d=i.getMap(l);return k(o,(async()=>d.size?[d.get(e).toJSON(),d.get(n).toJSON()]:void 0),(async(o,r)=>i.transact((()=>((o,r,i)=>{o.size||(o.set(e,new t),o.set(n,new t));const[c,l]=x(o),g=()=>{u=1};let u=1;if(s(i,(([t,e])=>{u=0,S(t,((t,e)=>u?0:a(t)?c.delete(e):s(c.get(e),(e=>S(t,((t,n)=>u?0:a(t)?e.delete(n):s(e.get(n),(e=>S(t,((t,n)=>a(t)?e.delete(n):e.set(n,t)))),g)))),g))),S(e,((t,e)=>u?0:a(t)?l.delete(e):l.set(e,t)))})),u){const[t,e]=r();F(c,void 0,t,((t,e,n)=>F(c,e,n,((t,e,n)=>F(t,e,n,((t,e,n)=>{if(t.get(e)!==n)return t.set(e,n),1})))))),F(l,void 0,e,((t,e,n)=>{l.get(e)!==n&&l.set(e,n)}))}})(d,o,r)))),(t=>{const a=a=>t(void 0,((t,a)=>{if(1==r(a)&&(o=a[0].path,0==r(o)))return[t.get(e).toJSON(),t.get(n).toJSON(),1];var o;const[i,l]=x(t),u={},d={};return c(a,(({path:t,changes:{keys:n}})=>g(t)==e?s(g(t),(e=>{const a=C(u,e,v),o=i.get(e);s(g(t),(t=>{const e=C(a,t,v),s=o.get(t);J(n,((t,{action:n})=>e[t]=n==P?null:s.get(t)))}),(()=>J(n,((t,{action:e})=>a[t]=e==P?null:o.get(t)?.toJSON()))))}),(()=>J(n,((t,{action:e})=>u[t]=e==P?null:i.get(t)?.toJSON())))):J(n,((t,{action:e})=>d[t]=e==P?null:l.get(t))))),[u,d,1]})(d,a));return d.observeDeep(a),a}),(t=>{d.unobserveDeep(t)}),u,1,{getYDoc:()=>i})};export{Y as createYjsPersister};
@@ -1 +1 @@
1
- const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),i=Promise,r=clearInterval,o=a=>null==a,c=(a,t,e)=>o(a)?e?.():t(a),l=t=>a(t)==s,E=a=>Array.isArray(a),w=(a,t,e)=>a.slice(t,e),y=a=>a.length,d=async a=>i.all(a),u=a=>{throw Error(a)},R=(a,t)=>a.forEach(t),A=(a,t="")=>a.join(t),T=(a,t)=>a.map(t),N=a=>0==y(a),g=(a,t)=>a.filter(t),O=(a,...t)=>a.push(...t),$=a=>a.shift(),p=Object,m=a=>p.getPrototypeOf(a),v=p.entries,C=p.keys,L=p.freeze,I=(a=[])=>p.fromEntries(a),S=(...a)=>p.assign({},...a),_=(a,t)=>(delete a[t],a),h=(a,t)=>T(v(a),(([a,e])=>t(e,a))),b=a=>p.values(a),f=a=>y(C(a)),D=a=>(a=>!o(a)&&c(m(a),(a=>a==p.prototype||o(m(a))),(()=>!0)))(a)&&0==f(a),M=(a,t)=>a?.has(t)??!1,P=a=>o(a)||0==(a=>a?.size??0)(a),F=a=>[...a?.values()??[]],U=(a,t)=>a?.forEach(t),G=(a,t)=>a?.delete(t),B=a=>new Map(a),j=(a,t)=>a?.get(t),Y=(a,t)=>T([...a?.entries()??[]],(([a,e])=>t(e,a))),x=(a,t,e)=>o(e)?(G(a,t),a):a?.set(t,e),H=(a,t,e,n)=>(M(a,t)?n?.(j(a,t)):x(a,t,e()),j(a,t)),X=(a,t,e,n,s=0)=>c((e?H:j)(a,t[s],s>y(t)-2?e:B),(i=>{if(s>y(t)-2)return n?.(i)&&x(a,t[s]),i;const r=X(i,t,e,n,s+1);return P(i)&&x(a,t[s]),r})),J=a=>new Set(E(a)||o(a)?a:[a]),W=(a,t)=>a?.add(t),k=/^\d+$/,q={Idle:0,Loading:1,Saving:2},z={StoreOnly:1,MergeableStoreOnly:2,StoreOrMergeableStore:3},K=B(),V=B(),Q=(a,t,n,s,i,r,l,w={},d=0,A=[])=>{let T,N,g,p=0,m=0,v=0;H(K,A,(()=>0)),H(V,A,(()=>[]));const C=B(),[I,S,_,h,b]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!D(a)||!D(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!D(a)||!D(t),t.setContent]:u("Store type not supported by this Persister"))(l,a,d),[f,M,F]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?$(a):null)??e+t++,t=>{k.test(t)&&y(a)<1e3&&O(a,t)}]})(),s=B();return[(n,i,r,o=[],c=()=>[])=>{a??=ea;const l=t(1);return x(s,l,[n,i,r,o,c]),W(X(i,r??[e],J),l),l},(t,n,...i)=>R(((a,t=[e])=>{const n=[],s=(a,e)=>e==y(t)?O(n,a):null===t[e]?U(a,(a=>s(a,e+1))):R([t[e],null],(t=>s(j(a,t),e+1)));return s(a,0),n})(t,n),(t=>U(t,(t=>j(s,t)[0](a,...n??[],...i))))),a=>c(j(s,a),(([,t,i])=>(X(t,i??[e],void 0,(t=>(G(t,a),P(t)?1:0))),x(s,a),n(a),i))),t=>c(j(s,t),(([t,,e=[],n,s])=>{const i=(...r)=>{const c=y(r);c==y(e)?t(a,...r,...s(r)):o(e[c])?R(n[c]?.(...r)??[],(a=>i(...r,a))):i(...r,e[c])};i()}))]})(),Y=a=>{a!=p&&(p=a,M(C,void 0,p))},q=t=>{(I&&E(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},z=async a=>(2!=p&&(Y(1),m++,await ta((async()=>{try{const e=await t();E(e)?q(e):a?b(a):u("Content is not an array: "+e)}catch(t){r?.(t),a&&b(a)}Y(0)}))),ea),Q=()=>(N&&(i(N),N=void 0),ea),Z=async a=>(1!=p&&(Y(2),v++,await ta((async()=>{try{await n(S,a)}catch(a){r?.(a)}Y(0)}))),ea),aa=()=>(g&&(a.delListener(g),g=void 0),ea),ta=async(...a)=>(O(j(V,A),...a),await(async()=>{if(!j(K,A)){for(x(K,A,1);!o(T=$(j(V,A)));)try{await T()}catch(a){r?.(a)}x(K,A,0)}})(),ea),ea={load:z,startAutoLoad:async a=>{Q(),await z(a);try{N=await s((async(a,t)=>{t||a?2!=p&&(Y(1),m++,q(t??a),Y(0)):await z()}))}catch(a){r?.(a)}return ea},stopAutoLoad:Q,isAutoLoading:()=>!o(N),save:Z,startAutoSave:async()=>(aa(),await Z(),g=a.addDidFinishTransactionListener((()=>{const a=_();h(a)&&Z(a)})),ea),stopAutoSave:aa,isAutoSaving:()=>!o(g),getStatus:()=>p,addStatusListener:a=>f(a,C),delListener:t=>(F(t),a),schedule:ta,getStore:()=>a,destroy:()=>(j(V,A).splice(0,void 0),Q().stopAutoSave()),getStats:()=>({loads:m,saves:v}),...w};return L(ea)},Z="_",aa="_id",ta="SELECT",ea="WHERE",na="TABLE",sa="ALTER "+na,ia="DELETE FROM",ra=ta+"*FROM",oa="pragma_",ca="data_version",la="schema_version",Ea="pragma_table_",wa=(a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a,ya=a=>`"${a.replace(/"/g,'""')}"`,da=(a,t=[1])=>A(T(a,(()=>"$"+t[0]++)),n),ua=JSON.stringify,Ra=JSON.parse,Aa=(a,t,e,s,i,r=Ta,c,l)=>{const E=B();return[async()=>{E.clear(),T(await e(a,t),(({tn:a,cn:t})=>W(H(E,a,J),t)))},async(t,e)=>((a,t)=>M(j(E,a),t))(t,e)?I(g(T(await a(ra+ya(t)),(a=>{return[a[e],l?(t=_(a,e),n=l,I(h(t,((a,t)=>[t,n(a,t)])))):_(a,e)];var t,n})),(([a,t])=>!o(a)&&!D(t)))):{},async(t,e,s,l,w,y=!1)=>{const u=J();h(s??{},(a=>T(C(a??{}),(a=>W(u,a)))));const R=F(u);if(!y&&w&&N(R)&&M(E,t))return await a("DROP "+na+ya(t)),void x(E,t);const $=j(E,t),p=J(F($));if(N(R)||(M(E,t)?await d(T([e,...R],(async(n,s)=>{G(p,n)||(await a(sa+ya(t)+"ADD"+ya(n)+i),0==s&&await a("CREATE UNIQUE INDEX pk ON "+ya(t)+`(${ya(e)})`),W($,n))}))):(await a("CREATE "+na+ya(t)+`(${ya(e)}${i} PRIMARY KEY${A(T(R,(a=>n+ya(a)+i)))});`),x(E,t,J([e,...R])))),await d([...!y&&l?T(F(p),(async n=>{n!=e&&(await a(sa+ya(t)+"DROP"+ya(n)),G($,n))})):[]]),y)o(s)?await a(ia+ya(t)+ea+" true"):await d(h(s,(async(n,s)=>{o(n)?await a(ia+ya(t)+ea+ya(e)+"=$1",[s]):N(R)||await r(a,t,e,C(n),{[s]:c?T(b(n),c):b(n)},$)})));else if(N(R))M(E,t)&&await a(ia+ya(t)+ea+" true");else{const n=g(F(j(E,t)),(a=>a!=e)),i={},o=[];h(s??{},((a,t)=>{i[t]=T(n,(t=>c?c(a?.[t]):a?.[t])),O(o,t)})),await r(a,t,e,n,i),await a(ia+ya(t)+ea+ya(e)+`NOT IN(${da(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,e,s,i)=>{const r=[1];await a("INSERT INTO"+ya(t)+"("+((...a)=>A(T(a,ya),n))(e,...s)+")VALUES"+A(h(i,(a=>"($"+r[0]+++","+da(a,r)+")")),n)+"ON CONFLICT("+ya(e)+")DO UPDATE SET"+A(T(s,(a=>ya(a)+"=excluded."+ya(a))),n),h(i,((a,t)=>[t,...T(a,(a=>a??null))])).flat())},Na=(a,t,e,n,s,i,r,[o,c,l],E,w,y,d,u,R)=>{const[A,T,N,g]=Aa(t,E,w,s,u,R),O=Q(a,(async()=>await g((async()=>{return await A(),a=(await T(o,c))[Z]?.[l]??"null",Ra(a,((a,t)=>""===t?void 0:t));var a}))),(async a=>await g((async()=>{var t;await A(),await N(o,c,{[Z]:{[l]:(t=a()??null,ua(t,((a,t)=>void 0===t?"":t)))}},!0,!0)}))),e,n,s,r,{[d]:()=>y,destroy:()=>(O.stopAutoLoad().stopAutoSave(),i(),O)},0,y);return O},ga=(a,t,e,n,s,i,r,[c,l,[E,w,y]],u,R,A,T,N,O,$,p)=>{const[m,v,C,L]=Aa(t,u,R,s,N,O,$,p),S=async(a,t)=>await d(Y(l,(async([e,n,s,i],r)=>{t&&!(r in a)||await C(e,n,a[r],s,i,t)}))),_=async(a,t)=>w?await C(y,aa,{[Z]:a},!0,!0,t):null,h=Q(a,(async()=>await L((async()=>{await m();const a=await(async()=>I(g(await d(Y(c,(async([a,t],e)=>[a,await v(e,t)]))),(a=>!D(a[1])))))(),t=await(async()=>E?(await v(y,aa))[Z]:{})();return D(a)&&o(t)?void 0:[a,t]}))),(async(a,t)=>await L((async()=>{if(await m(),o(t)){const[t,e]=a();await S(t),await _(e)}else await S(t[0],!0),await _(t[1],!0)}))),e,n,s,r,{[T]:()=>A,destroy:()=>(h.stopAutoLoad().stopAutoSave(),i(),h)},0,A);return h},Oa="ColumnName",$a="store",pa="json",ma=$a+"TableName",va=$a+"Id"+Oa,Ca=$a+Oa,La="autoLoadIntervalSeconds",Ia="rowId"+Oa,Sa="tableId",_a="tableName",ha="deleteEmptyColumns",ba="deleteEmptyTable",fa={mode:pa,[La]:1},Da={load:0,save:0,[_a]:t+"_values"},Ma=(a,t,e,n,s)=>{const i=B();return h(a,((a,r)=>{const c=w(b(S(t,l(a)?{[e]:a}:a)),0,f(t));o(c[0])||n(r,c[0])||(s(r,c[0]),x(i,r,c))})),i},Pa=a=>{const e=(a=>S(fa,l(a)?{[ma]:a}:a??{}))(a),n=e[La];if(e.mode==pa){const a=e[ma]??t;return[1,n,[a,e[va]??aa,e[Ca]??$a],J(a)]}const{tables:{load:s={},save:i={}}={},values:r={}}=e,o=w(b(S(Da,r)),0,f(Da)),c=o[2],E=J(c),y=J(c);return[0,n,[Ma(s,{[Sa]:null,[Ia]:aa},Sa,(a=>M(y,a)),(a=>W(E,a))),Ma(i,{[_a]:null,[Ia]:aa,[ha]:0,[ba]:0},_a,((a,t)=>M(y,t)),((a,t)=>W(E,t))),o],E]},Fa=(a,t,n,s,i,o,c,l,E,w,y="getDb",d)=>{let u,R,A;const T=wa(n,o),[N,g,O,$]=Pa(t);return(N?Na:ga)(a,T,(a=>{let t;const e=()=>t=setInterval((async()=>{try{const[{d:t,s:e,c:n}]=await T(`${ta} ${ca} d,${la} s,TOTAL_CHANGES() c FROM ${oa}${ca} JOIN ${oa}${la}`);t==u&&e==R&&n==A||(null!=u&&a(),u=t,R=e,A=n)}catch{}}),1e3*g),n=()=>{u=R=A=null,r(t)},o=s((t=>{$.has(t)&&(n(),a(),e())}));return e(),()=>{n(),i(o)}}),(a=>a()),c,l,E,O,F($),(async(a,t)=>await a(`${ta} t.name tn,c.name cn FROM ${Ea}list()t,${Ea}info(t.name)c ${ea} t.schema='main'AND t.type IN('table','view')AND t.name IN(${da(t)})ORDER BY t.name,c.name`,t)),w,y,e,d,(a=>!0===a?1:!1===a?0:a),void 0)},Ua=t,Ga=/^([cd]:)(.+)/,Ba=t+"_data",ja=t+"_table",Ya=(a,t,e,n,s,i,r,o,l,E,w="getDb")=>{const y=wa(e,i),[u,,R,A]=Pa(t),N=async a=>{await y(`CREATE OR REPLACE TRIGGER ${ya(Ba+"_"+a)} AFTER INSERT OR UPDATE OR DELETE ON ${ya(a)} EXECUTE FUNCTION ${Ba}()`)};return(u?Na:ga)(a,y,(async a=>{await y(`CREATE OR REPLACE FUNCTION ${ja}()RETURNS event_trigger AS $t2$ DECLARE row record; BEGIN FOR row IN SELECT object_identity FROM pg_event_trigger_ddl_commands()WHERE command_tag='CREATE TABLE' LOOP PERFORM pg_notify('${Ua}','c:'||SPLIT_PART(row.object_identity,'.',2));END LOOP;END;$t2$ LANGUAGE plpgsql;`);try{await y(`CREATE EVENT TRIGGER ${ja} ON ddl_command_end WHEN TAG IN('CREATE TABLE')EXECUTE FUNCTION ${ja}();`)}catch{}return await y(`CREATE OR REPLACE FUNCTION ${Ba}()RETURNS trigger AS $t1$ BEGIN PERFORM pg_notify('${Ua}','d:'||TG_TABLE_NAME);RETURN NULL;END;$t1$ LANGUAGE plpgsql;`),await d(T(F(A),(async a=>{await y(`CREATE TABLE IF NOT EXISTS ${ya(a)}("_id"text PRIMARY KEY)`),await N(a)}))),await n(Ua,(async t=>{return await c((e=t,n=Ga,e?.match(n)),(async([,t,e])=>{M(A,e)&&("c:"==t&&await N(e),a())}));var e,n}))}),s,r,o,l,R,F(A),(async(a,t)=>await a(`${ta} table_name tn,column_name cn FROM information_schema.columns ${ea} table_schema='public'AND table_name IN(${da(t)})`,t)),E,w,"text",void 0,(a=>ua(a)),(a=>Ra(a)))};export{z as Persists,q as Status,Q as createCustomPersister,Ya as createCustomPostgreSqlPersister,Fa as createCustomSqlitePersister};
1
+ const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),i=Promise,r=clearInterval,o=a=>null==a,c=(a,t,e)=>o(a)?e?.():t(a),l=t=>a(t)==s,E=a=>Array.isArray(a),w=(a,t,e)=>a.slice(t,e),y=a=>a.length,d=async a=>i.all(a),u=a=>{throw Error(a)},R=(a,t)=>a.forEach(t),A=(a,t="")=>a.join(t),T=(a,t)=>a.map(t),N=a=>0==y(a),g=(a,t)=>a.filter(t),O=(a,...t)=>a.push(...t),$=a=>a.shift(),p=Object,m=a=>p.getPrototypeOf(a),v=p.entries,C=p.keys,L=p.freeze,I=(a=[])=>p.fromEntries(a),S=(...a)=>p.assign({},...a),_=(a,t)=>(delete a[t],a),h=(a,t)=>T(v(a),(([a,e])=>t(e,a))),b=(a,t)=>I(h(a,((a,e)=>[e,t(a,e)]))),f=a=>p.values(a),D=a=>y(C(a)),M=a=>(a=>!o(a)&&c(m(a),(a=>a==p.prototype||o(m(a))),(()=>!0)))(a)&&0==D(a),P=(a,t)=>a?.has(t)??!1,F=a=>o(a)||0==(a=>a?.size??0)(a),U=a=>[...a?.values()??[]],G=(a,t)=>a?.forEach(t),B=(a,t)=>a?.delete(t),j=a=>new Map(a),Y=(a,t)=>a?.get(t),x=(a,t)=>T([...a?.entries()??[]],(([a,e])=>t(e,a))),H=(a,t,e)=>o(e)?(B(a,t),a):a?.set(t,e),X=(a,t,e,n)=>(P(a,t)?n?.(Y(a,t)):H(a,t,e()),Y(a,t)),J=(a,t,e,n,s=0)=>c((e?X:Y)(a,t[s],s>y(t)-2?e:j),(i=>{if(s>y(t)-2)return n?.(i)&&H(a,t[s]),i;const r=J(i,t,e,n,s+1);return F(i)&&H(a,t[s]),r})),W=a=>new Set(E(a)||o(a)?a:[a]),k=(a,t)=>a?.add(t),q=/^\d+$/,z={Idle:0,Loading:1,Saving:2},K={StoreOnly:1,MergeableStoreOnly:2,StoreOrMergeableStore:3},V=j(),Q=j(),Z=(a,t,n,s,i,r,l,w={},d=0,A=[])=>{let T,N,g,p=0,m=0,v=0;X(V,A,(()=>0)),X(Q,A,(()=>[]));const C=j(),[I,S,_,h,b]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!M(a)||!M(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!M(a)||!M(t),t.setContent]:u("Store type not supported by this Persister"))(l,a,d),[f,D,P]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?$(a):null)??e+t++,t=>{q.test(t)&&y(a)<1e3&&O(a,t)}]})(),s=j();return[(n,i,r,o=[],c=()=>[])=>{a??=ea;const l=t(1);return H(s,l,[n,i,r,o,c]),k(J(i,r??[e],W),l),l},(t,n,...i)=>R(((a,t=[e])=>{const n=[],s=(a,e)=>e==y(t)?O(n,a):null===t[e]?G(a,(a=>s(a,e+1))):R([t[e],null],(t=>s(Y(a,t),e+1)));return s(a,0),n})(t,n),(t=>G(t,(t=>Y(s,t)[0](a,...n??[],...i))))),a=>c(Y(s,a),(([,t,i])=>(J(t,i??[e],void 0,(t=>(B(t,a),F(t)?1:0))),H(s,a),n(a),i))),t=>c(Y(s,t),(([t,,e=[],n,s])=>{const i=(...r)=>{const c=y(r);c==y(e)?t(a,...r,...s(r)):o(e[c])?R(n[c]?.(...r)??[],(a=>i(...r,a))):i(...r,e[c])};i()}))]})(),U=a=>{a!=p&&(p=a,D(C,void 0,p))},x=t=>{(I&&E(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},z=async a=>(2!=p&&(U(1),m++,await ta((async()=>{try{const e=await t();E(e)?x(e):a?b(a):u("Content is not an array: "+e)}catch(t){r?.(t),a&&b(a)}U(0)}))),ea),K=()=>(N&&(i(N),N=void 0),ea),Z=async a=>(1!=p&&(U(2),v++,await ta((async()=>{try{await n(S,a)}catch(a){r?.(a)}U(0)}))),ea),aa=()=>(g&&(a.delListener(g),g=void 0),ea),ta=async(...a)=>(O(Y(Q,A),...a),await(async()=>{if(!Y(V,A)){for(H(V,A,1);!o(T=$(Y(Q,A)));)try{await T()}catch(a){r?.(a)}H(V,A,0)}})(),ea),ea={load:z,startAutoLoad:async a=>{K(),await z(a);try{N=await s((async(a,t)=>{t||a?2!=p&&(U(1),m++,x(t??a),U(0)):await z()}))}catch(a){r?.(a)}return ea},stopAutoLoad:K,isAutoLoading:()=>!o(N),save:Z,startAutoSave:async()=>(aa(),await Z(),g=a.addDidFinishTransactionListener((()=>{const a=_();h(a)&&Z(a)})),ea),stopAutoSave:aa,isAutoSaving:()=>!o(g),getStatus:()=>p,addStatusListener:a=>f(a,C),delListener:t=>(P(t),a),schedule:ta,getStore:()=>a,destroy:()=>(Y(Q,A).splice(0,void 0),K().stopAutoSave()),getStats:()=>({loads:m,saves:v}),...w};return L(ea)},aa="_",ta="_id",ea="SELECT",na="WHERE",sa="TABLE",ia="ALTER "+sa,ra="DELETE FROM",oa=ea+"*FROM",ca="pragma_",la="data_version",Ea="schema_version",wa="pragma_table_",ya=(a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a,da=a=>`"${a.replace(/"/g,'""')}"`,ua=(a,t=[1])=>A(T(a,(()=>"$"+t[0]++)),n),Ra=JSON.stringify,Aa=JSON.parse,Ta=(a,t,e,s,i,r=Na,c,l)=>{const E=j();return[async()=>{E.clear(),T(await e(a,t),(({tn:a,cn:t})=>k(X(E,a,W),t)))},async(t,e)=>((a,t)=>P(Y(E,a),t))(t,e)?I(g(T(await a(oa+da(t)),(a=>[a[e],l?b(_(a,e),l):_(a,e)])),(([a,t])=>!o(a)&&!M(t)))):{},async(t,e,s,l,w,y=!1)=>{const u=W();b(s??{},(a=>T(C(a??{}),(a=>k(u,a)))));const R=U(u);if(!y&&w&&N(R)&&P(E,t))return await a("DROP "+sa+da(t)),void H(E,t);const $=Y(E,t),p=W(U($));if(N(R)||(P(E,t)?await d(T([e,...R],(async(n,s)=>{B(p,n)||(await a(ia+da(t)+"ADD"+da(n)+i),0==s&&await a("CREATE UNIQUE INDEX pk ON "+da(t)+`(${da(e)})`),k($,n))}))):(await a("CREATE "+sa+da(t)+`(${da(e)}${i} PRIMARY KEY${A(T(R,(a=>n+da(a)+i)))});`),H(E,t,W([e,...R])))),await d([...!y&&l?T(U(p),(async n=>{n!=e&&(await a(ia+da(t)+"DROP"+da(n)),B($,n))})):[]]),y)o(s)?await a(ra+da(t)+na+" true"):await d(h(s,(async(n,s)=>{o(n)?await a(ra+da(t)+na+da(e)+"=$1",[s]):N(R)||await r(a,t,e,C(n),{[s]:c?T(f(n),c):f(n)},$)})));else if(N(R))P(E,t)&&await a(ra+da(t)+na+" true");else{const n=g(U(Y(E,t)),(a=>a!=e)),i={},o=[];b(s??{},((a,t)=>{i[t]=T(n,(t=>c?c(a?.[t]):a?.[t])),O(o,t)})),await r(a,t,e,n,i),await a(ra+da(t)+na+da(e)+`NOT IN(${ua(o)})`,o)}},async t=>{let e;await a("BEGIN");try{e=await t()}catch(a){s?.(a)}return await a("END"),e}]},Na=async(a,t,e,s,i)=>{const r=[1];await a("INSERT INTO"+da(t)+"("+((...a)=>A(T(a,da),n))(e,...s)+")VALUES"+A(h(i,(a=>"($"+r[0]+++","+ua(a,r)+")")),n)+"ON CONFLICT("+da(e)+")DO UPDATE SET"+A(T(s,(a=>da(a)+"=excluded."+da(a))),n),h(i,((a,t)=>[t,...T(a,(a=>a??null))])).flat())},ga=(a,t,e,n,s,i,r,[o,c,l],E,w,y,d,u,R)=>{const[A,T,N,g]=Ta(t,E,w,s,u,R),O=Z(a,(async()=>await g((async()=>{return await A(),a=(await T(o,c))[aa]?.[l]??"null",Aa(a,((a,t)=>""===t?void 0:t));var a}))),(async a=>await g((async()=>{var t;await A(),await N(o,c,{[aa]:{[l]:(t=a()??null,Ra(t,((a,t)=>void 0===t?"":t)))}},!0,!0)}))),e,n,s,r,{[d]:()=>y,destroy:()=>(O.stopAutoLoad().stopAutoSave(),i(),O)},0,y);return O},Oa=(a,t,e,n,s,i,r,[c,l,[E,w,y]],u,R,A,T,N,O,$,p)=>{const[m,v,C,L]=Ta(t,u,R,s,N,O,$,p),S=async(a,t)=>await d(x(l,(async([e,n,s,i],r)=>{t&&!(r in a)||await C(e,n,a[r],s,i,t)}))),_=async(a,t)=>w?await C(y,ta,{[aa]:a},!0,!0,t):null,h=Z(a,(async()=>await L((async()=>{await m();const a=await(async()=>I(g(await d(x(c,(async([a,t],e)=>[a,await v(e,t)]))),(a=>!M(a[1])))))(),t=await(async()=>E?(await v(y,ta))[aa]:{})();return M(a)&&o(t)?void 0:[a,t]}))),(async(a,t)=>await L((async()=>{if(await m(),o(t)){const[t,e]=a();await S(t),await _(e)}else await S(t[0],!0),await _(t[1],!0)}))),e,n,s,r,{[T]:()=>A,destroy:()=>(h.stopAutoLoad().stopAutoSave(),i(),h)},0,A);return h},$a="ColumnName",pa="store",ma="json",va=pa+"TableName",Ca=pa+"Id"+$a,La=pa+$a,Ia="autoLoadIntervalSeconds",Sa="rowId"+$a,_a="tableId",ha="tableName",ba="deleteEmptyColumns",fa="deleteEmptyTable",Da={mode:ma,[Ia]:1},Ma={load:0,save:0,[ha]:t+"_values"},Pa=(a,t,e,n,s)=>{const i=j();return b(a,((a,r)=>{const c=w(f(S(t,l(a)?{[e]:a}:a)),0,D(t));o(c[0])||n(r,c[0])||(s(r,c[0]),H(i,r,c))})),i},Fa=a=>{const e=(a=>S(Da,l(a)?{[va]:a}:a??{}))(a),n=e[Ia];if(e.mode==ma){const a=e[va]??t;return[1,n,[a,e[Ca]??ta,e[La]??pa],W(a)]}const{tables:{load:s={},save:i={}}={},values:r={}}=e,o=w(f(S(Ma,r)),0,D(Ma)),c=o[2],E=W(c),y=W(c);return[0,n,[Pa(s,{[_a]:null,[Sa]:ta},_a,(a=>P(y,a)),(a=>k(E,a))),Pa(i,{[ha]:null,[Sa]:ta,[ba]:0,[fa]:0},ha,((a,t)=>P(y,t)),((a,t)=>k(E,t))),o],E]},Ua=(a,t,n,s,i,o,c,l,E,w,y="getDb",d)=>{let u,R,A;const T=ya(n,o),[N,g,O,$]=Fa(t);return(N?ga:Oa)(a,T,(a=>{let t;const e=()=>t=setInterval((async()=>{try{const[{d:t,s:e,c:n}]=await T(`${ea} ${la} d,${Ea} s,TOTAL_CHANGES() c FROM ${ca}${la} JOIN ${ca}${Ea}`);t==u&&e==R&&n==A||(null!=u&&a(),u=t,R=e,A=n)}catch{}}),1e3*g),n=()=>{u=R=A=null,r(t)},o=s((t=>{$.has(t)&&(n(),a(),e())}));return e(),()=>{n(),i(o)}}),(a=>a()),c,l,E,O,U($),(async(a,t)=>await a(`${ea} t.name tn,c.name cn FROM ${wa}list()t,${wa}info(t.name)c ${na} t.schema='main'AND t.type IN('table','view')AND t.name IN(${ua(t)})ORDER BY t.name,c.name`,t)),w,y,e,d,(a=>!0===a?1:!1===a?0:a),void 0)},Ga=t,Ba=/^([cd]:)(.+)/,ja=t+"_data",Ya=t+"_table",xa=(a,t,e,n,s,i,r,o,l,E,w="getDb")=>{const y=ya(e,i),[u,,R,A]=Fa(t),N=async a=>{await y(`CREATE OR REPLACE TRIGGER ${da(ja+"_"+a)} AFTER INSERT OR UPDATE OR DELETE ON ${da(a)} EXECUTE FUNCTION ${ja}()`)};return(u?ga:Oa)(a,y,(async a=>{await y(`CREATE OR REPLACE FUNCTION ${Ya}()RETURNS event_trigger AS $t2$ DECLARE row record; BEGIN FOR row IN SELECT object_identity FROM pg_event_trigger_ddl_commands()WHERE command_tag='CREATE TABLE' LOOP PERFORM pg_notify('${Ga}','c:'||SPLIT_PART(row.object_identity,'.',2));END LOOP;END;$t2$ LANGUAGE plpgsql;`);try{await y(`CREATE EVENT TRIGGER ${Ya} ON ddl_command_end WHEN TAG IN('CREATE TABLE')EXECUTE FUNCTION ${Ya}();`)}catch{}return await y(`CREATE OR REPLACE FUNCTION ${ja}()RETURNS trigger AS $t1$ BEGIN PERFORM pg_notify('${Ga}','d:'||TG_TABLE_NAME);RETURN NULL;END;$t1$ LANGUAGE plpgsql;`),await d(T(U(A),(async a=>{await y(`CREATE TABLE IF NOT EXISTS ${da(a)}("_id"text PRIMARY KEY)`),await N(a)}))),await n(Ga,(async t=>{return await c((e=t,n=Ba,e?.match(n)),(async([,t,e])=>{P(A,e)&&("c:"==t&&await N(e),a())}));var e,n}))}),s,r,o,l,R,U(A),(async(a,t)=>await a(`${ea} table_name tn,column_name cn FROM information_schema.columns ${na} table_schema='public'AND table_name IN(${ua(t)})`,t)),E,w,"text",void 0,(a=>Ra(a)),(a=>Aa(a)))};export{K as Persists,z as Status,Z as createCustomPersister,xa as createCustomPostgreSqlPersister,Ua as createCustomSqlitePersister};
@@ -1 +1 @@
1
- const e=e=>typeof e,t=e(""),n=e(!0),s=e(0),r=e(e),o="Listener",a="Result",l="Ids",i="Table",d="Row",c=d+"Count",u=d+l,h="Sorted"+d+l,g="Cell",v=g+l,w=Math,L=w.max,f=w.min,R=isFinite,y=e=>null==e,T=(e,t,n)=>y(e)?n?.():t(e),b=t=>e(t)==r,C=e=>Array.isArray(e),p=e=>e.length,S=()=>{},m=(e,t)=>e.every(t),I=(e,t)=>e.forEach(t),Q=e=>x(e,((e,t)=>e+t),0),E=e=>0==p(e),x=(e,t,n)=>e.reduce(t,n),D=(e,...t)=>e.push(...t),M=Object,j=M.entries,k=M.freeze,z=e=>e?.size??0,A=(e,t)=>e?.has(t)??!1,F=e=>y(e)||0==z(e),O=e=>[...e?.values()??[]],W=e=>e.clear(),q=(e,t)=>e?.forEach(t),B=(e,t)=>e?.delete(t),G=e=>new Map(e),H=(e,t)=>e?.get(t),J=(e,t)=>q(e,((e,n)=>t(n,e))),K=(e,t,n)=>y(n)?(B(e,t),e):e?.set(t,n),N=(e,t,n,s)=>(A(e,t)?s?.(H(e,t)):K(e,t,n()),H(e,t)),P=(e,t,n,s,r=0)=>T((n?N:H)(e,t[r],r>p(t)-2?n:G),(o=>{if(r>p(t)-2)return s?.(o)&&K(e,t[r]),o;const a=P(o,t,n,s,r+1);return F(o)&&K(e,t[r]),a})),U=e=>new Set(C(e)||y(e)?e:[e]),V=(e,t)=>e?.add(t),X=G([["avg",[(e,t)=>Q(e)/t,(e,t,n)=>e+(t-e)/(n+1),(e,t,n)=>e+(e-t)/(n-1),(e,t,n,s)=>e+(t-n)/s]],["max",[e=>L(...e),(e,t)=>L(t,e),(e,t)=>t==e?void 0:e,(e,t,n)=>n==e?void 0:L(t,e)]],["min",[e=>f(...e),(e,t)=>f(t,e),(e,t)=>t==e?void 0:e,(e,t,n)=>n==e?void 0:f(t,e)]],["sum",[e=>Q(e),(e,t)=>e+t,(e,t)=>e-t,(e,t,n)=>e-n+t]]]),Y=(()=>{const r=new WeakMap;return l=>(r.has(l)||r.set(l,(r=>{const l=r.createStore,w=l(),L=l(),f=G(),{addListener:Q,callListeners:x,delListener:M}=L,[Y,Z,$,_,ee,,,te,,ne,se,re,oe,ae]=((e,t,n,s,r)=>{const o=e.hasRow,a=G(),l=G(),i=G(),d=G(),c=G(),u=G(),h=(t,n,...s)=>{const r=N(u,t,U);return I(s,(t=>V(r,t)&&n&&e.callListener(t))),s},g=(t,...n)=>T(H(u,t),(s=>{I(E(n)?O(s):n,(t=>{e.delListener(t),B(s,t)})),F(s)&&K(u,t)})),v=(e,t)=>{K(a,e,t),A(l,e)||(K(l,e,!0),K(d,e,G()),K(c,e,G()),r(i))},w=e=>{K(a,e),K(l,e),K(d,e),K(c,e),g(e),r(i)};return[()=>e,()=>{return e=a,[...e?.keys()??[]];var e},e=>J(l,e),e=>A(l,e),e=>H(a,e),e=>H(l,e),(e,t)=>K(l,e,t),v,(t,s,r,a,l)=>{v(t,s);const i=G(),u=G(),w=H(d,t),L=H(c,t),f=t=>{const r=n=>e.getCell(s,t,n),d=H(w,t),c=o(s,t)?n(a(r,t)):void 0;var h,g;if(d===c||C(d)&&C(c)&&(g=c,p(h=d)===p(g)&&m(h,((e,t)=>g[t]===e)))||K(i,t,[d,c]),!y(l)){const e=H(L,t),n=o(s,t)?l(r,t):void 0;e!=n&&K(u,t,n)}},R=e=>{r((()=>{q(i,(([,e],t)=>K(w,t,e))),q(u,((e,t)=>K(L,t,e)))}),i,u,w,L,e),W(i),W(u)};J(w,f),e.hasTable(s)&&I(e.getRowIds(s),(e=>{A(w,e)||f(e)})),R(!0),g(t),h(t,0,e.addRowListener(s,null,((e,t,n)=>f(n))),e.addTableListener(s,(()=>R())))},w,e=>s(e,i),()=>J(u,w),h,g]})(r,0,S,Q,x),le=(e,t,...n)=>I(n,(n=>V(N(N(f,t,G),e,U),n))),ie=e=>{T(H(f,e),(e=>{J(e,((e,t)=>q(t,(t=>e.delListener(t))))),W(e)})),I([L,w],(t=>t.delTable(e)))},de=(e,t,n)=>le(t,e,t.addStartTransactionListener(n.startTransaction),t.addDidFinishTransactionListener((()=>n.finishTransaction()))),ce={setQueryDefinition:(o,a,l)=>{te(o,a),ie(o);const i=[],d=[[null,[a,null,null,[],G()]]],c=[],u=[],h=[];l({select:(e,t)=>{const n=b(e)?[p(i)+"",e]:[y(t)?e:t,n=>n(e,t)];return D(i,n),{as:e=>n[0]=e}},join:(e,t,n)=>{const s=y(n)||b(t)?null:t,r=y(s)?t:n,o=[e,[e,s,b(r)?r:e=>e(r),[],G()]];return D(d,o),{as:e=>o[0]=e}},where:(e,t,n)=>D(c,b(e)?e:y(n)?n=>n(e)===t:s=>s(e,t)===n),group:(e,t,n,s,r)=>{const o=[e,[e,b(t)?[t,n,s,r]:H(X,t)??[(e,t)=>t]]];return D(u,o),{as:e=>o[0]=e}},having:(e,t)=>D(h,b(e)?e:n=>n(e)===t)});const g=G(i);if(F(g))return ce;const v=G(d);J(v,((e,[,t])=>T(H(v,t),(({3:t})=>y(e)?0:D(t,e)))));const f=G(u);let C=w;if(F(f)&&E(h))C=L;else{de(o,C,L);const r=G();J(f,((e,[t,n])=>V(N(r,t,U),[e,n])));const a=U();J(g,(e=>A(r,e)?0:V(a,e)));const l=G(),i=(a,l,i,d)=>T(a,(([c,u,g,v])=>{J(l,((o,[a])=>{const l=N(c,o,G),u=H(l,i),h=d?void 0:a;if(u!==h){const a=U([[u,h]]),d=z(l);K(l,i,h),q(H(r,o),(([r,o])=>{const i=((e,t,n,s,r,o=!1)=>{if(F(n))return;const[a,l,i,d]=r;return o||=y(e),q(s,(([n,s])=>{o||(e=y(n)?l?.(e,s,t++):y(s)?i?.(e,n,t--):d?.(e,s,n,t),o||=y(e))})),o?a(O(n),z(n)):e})(v[r],d,l,a,o);v[r]=y((r=>{const o=e(r);return(e=>e==t||e==n)(o)||o==s&&R(r)?o:void 0})(i))?null:i}))}})),F(u)||!m(h,(e=>e((e=>v[e]))))?L.delRow(o,g):y(g)?a[2]=L.addRow(o,v):L.setRow(o,g,v)}));le(C,o,C.addRowListener(o,null,((e,t,n,s)=>{const d=[],c=[],u=G(),h=C.hasRow(o,n);let g=!h;q(a,(e=>{const[t,r,a]=s(o,n,e);D(d,r),D(c,a),g||=t})),J(r,(e=>{const[t,,r]=s(o,n,e);(g||t)&&K(u,e,[r])})),g&&i(P(l,d,void 0,(([,e])=>(B(e,n),F(e)))),u,n,1),h&&i(P(l,c,(()=>{const e={};return q(a,(t=>e[t]=C.getCell(o,n,t))),[G(),U(),void 0,e]}),(([,e])=>{V(e,n)})),u,n)})))}de(o,r,C);const S=(e,t,n,s)=>{const l=e=>r.getCell(t,n,e);I(s,(t=>{const[n,,s,a,i]=H(v,t),d=s?.(l,e),[c,u]=H(i,e)??[];d!=c&&(y(u)||ae(o,u),K(i,e,y(d)?null:[d,...oe(o,1,r.addRowListener(n,d,(()=>S(e,n,d,a))))]))})),(e=>{const t=(t,n)=>r.getCell(...y(n)?[a,e,t]:t===a?[a,e,n]:[H(v,t)?.[0],H(H(v,t)?.[4],e)?.[0],n]);C.transaction((()=>m(c,(e=>e(t)))?J(g,((n,s)=>((e,t,n,s,r)=>y(r)?e.delCell(t,n,s,!0):e.setCell(t,n,s,r))(C,o,e,n,s(t,e)))):C.delRow(o,e)))})(e)},{3:Q}=H(v,null);return C.transaction((()=>oe(o,1,r.addRowListener(a,null,((e,t,n)=>{r.hasRow(a,n)?S(n,a,n,Q):(C.delRow(o,n),q(v,(({4:e})=>T(H(e,n),(([,t])=>{ae(o,t),K(e,n)})))))}))))),ce},delQueryDefinition:e=>(ie(e),ne(e),ce),getStore:Y,getQueryIds:Z,forEachQuery:$,hasQuery:_,getTableId:ee,addQueryIdsListener:e=>se((()=>e(ce))),delListener:e=>(M(e),ce),destroy:re,getListenerStats:()=>{const{tables:e,tableIds:t,transaction:n,...s}=L.getListenerStats();return s}};var ue;return ue=([e,t],n)=>{I(e?["get","has","forEach"]:["get"],(e=>ce[e+a+n]=(...t)=>L[e+n](...t))),ce["add"+a+n+o]=(...e)=>{return L["add"+n+o](...(s=e,r=t,s.slice(0,r)),((n,...s)=>e[t](ce,...s)),!0);var s,r}},((e,t)=>{j({[i]:[1,1],[i+v]:[0,1],[c]:[0,1],[u]:[0,1],[h]:[0,5],[d]:[1,2],[v]:[0,2],[g]:[1,3]}).map(t)})(0,(([e,t])=>ue(t,e))),k(ce)})(l)),r.get(l))})();export{Y as createQueries};
1
+ const e=e=>typeof e,t=e(""),n=e(!0),s=e(0),r=e(e),o="Listener",a="Result",l="Ids",i="Table",d="Row",c=d+"Count",u=d+l,h="Sorted"+d+l,g="Cell",v=g+l,w=Math,L=w.max,f=w.min,R=isFinite,y=e=>null==e,T=(e,t,n)=>y(e)?n?.():t(e),b=t=>e(t)==r,C=e=>Array.isArray(e),m=e=>e.length,p=()=>{},S=(e,t)=>e.every(t),I=(e,t)=>e.forEach(t),Q=e=>x(e,((e,t)=>e+t),0),E=e=>0==m(e),x=(e,t,n)=>e.reduce(t,n),D=(e,...t)=>e.push(...t),M=Object,j=M.entries,k=M.freeze,z=e=>e?.size??0,A=(e,t)=>e?.has(t)??!1,F=e=>y(e)||0==z(e),O=e=>[...e?.values()??[]],W=e=>e.clear(),q=(e,t)=>e?.forEach(t),B=(e,t)=>e?.delete(t),G=e=>new Map(e),H=(e,t)=>e?.get(t),J=(e,t)=>q(e,((e,n)=>t(n,e))),K=(e,t,n)=>y(n)?(B(e,t),e):e?.set(t,n),N=(e,t,n,s)=>(A(e,t)?s?.(H(e,t)):K(e,t,n()),H(e,t)),P=(e,t,n,s,r=0)=>T((n?N:H)(e,t[r],r>m(t)-2?n:G),(o=>{if(r>m(t)-2)return s?.(o)&&K(e,t[r]),o;const a=P(o,t,n,s,r+1);return F(o)&&K(e,t[r]),a})),U=e=>new Set(C(e)||y(e)?e:[e]),V=(e,t)=>e?.add(t),X=G([["avg",[(e,t)=>Q(e)/t,(e,t,n)=>e+(t-e)/(n+1),(e,t,n)=>e+(e-t)/(n-1),(e,t,n,s)=>e+(t-n)/s]],["max",[e=>L(...e),(e,t)=>L(t,e),(e,t)=>t==e?void 0:e,(e,t,n)=>n==e?void 0:L(t,e)]],["min",[e=>f(...e),(e,t)=>f(t,e),(e,t)=>t==e?void 0:e,(e,t,n)=>n==e?void 0:f(t,e)]],["sum",[e=>Q(e),(e,t)=>e+t,(e,t)=>e-t,(e,t,n)=>e-n+t]]]),Y=(()=>{const r=new WeakMap;return l=>(r.has(l)||r.set(l,(r=>{const l=r.createStore,w=l(),L=l(),f=G(),{addListener:Q,callListeners:x,delListener:Y}=L,[Z,$,_,ee,te,,,ne,,se,re,oe,ae,le]=((e,t,n,s,r)=>{const o=e.hasRow,a=G(),l=G(),i=G(),d=G(),c=G(),u=G(),h=(t,n,...s)=>{const r=N(u,t,U);return I(s,(t=>V(r,t)&&n&&e.callListener(t))),s},g=(t,...n)=>T(H(u,t),(s=>{I(E(n)?O(s):n,(t=>{e.delListener(t),B(s,t)})),F(s)&&K(u,t)})),v=(e,t)=>{K(a,e,t),A(l,e)||(K(l,e,!0),K(d,e,G()),K(c,e,G()),r(i))},w=e=>{K(a,e),K(l,e),K(d,e),K(c,e),g(e),r(i)};return[()=>e,()=>{return e=a,[...e?.keys()??[]];var e},e=>J(l,e),e=>A(l,e),e=>H(a,e),e=>H(l,e),(e,t)=>K(l,e,t),v,(t,s,r,a,l)=>{v(t,s);const i=G(),u=G(),w=H(d,t),L=H(c,t),f=t=>{const r=n=>e.getCell(s,t,n),d=H(w,t),c=o(s,t)?n(a(r,t)):void 0;var h,g;if(d===c||C(d)&&C(c)&&(g=c,m(h=d)===m(g)&&S(h,((e,t)=>g[t]===e)))||K(i,t,[d,c]),!y(l)){const e=H(L,t),n=o(s,t)?l(r,t):void 0;e!=n&&K(u,t,n)}},R=e=>{r((()=>{q(i,(([,e],t)=>K(w,t,e))),q(u,((e,t)=>K(L,t,e)))}),i,u,w,L,e),W(i),W(u)};J(w,f),e.hasTable(s)&&I(e.getRowIds(s),(e=>{A(w,e)||f(e)})),R(!0),g(t),h(t,0,e.addRowListener(s,null,((e,t,n)=>f(n))),e.addTableListener(s,(()=>R())))},w,e=>s(e,i),()=>J(u,w),h,g]})(r,0,p,Q,x),ie=(e,t,...n)=>I(n,(n=>V(N(N(f,t,G),e,U),n))),de=e=>{T(H(f,e),(e=>{J(e,((e,t)=>q(t,(t=>e.delListener(t))))),W(e)})),I([L,w],(t=>t.delTable(e)))},ce=(e,t,n)=>ie(t,e,t.addStartTransactionListener(n.startTransaction),t.addDidFinishTransactionListener((()=>n.finishTransaction()))),ue={setQueryDefinition:(o,a,l)=>{ne(o,a),de(o);const i=[],d=[[null,[a,null,null,[],G()]]],c=[],u=[],h=[];l({select:(e,t)=>{const n=b(e)?[m(i)+"",e]:[y(t)?e:t,n=>n(e,t)];return D(i,n),{as:e=>n[0]=e}},join:(e,t,n)=>{const s=y(n)||b(t)?null:t,r=y(s)?t:n,o=[e,[e,s,b(r)?r:e=>e(r),[],G()]];return D(d,o),{as:e=>o[0]=e}},where:(e,t,n)=>D(c,b(e)?e:y(n)?n=>n(e)===t:s=>s(e,t)===n),group:(e,t,n,s,r)=>{const o=[e,[e,b(t)?[t,n,s,r]:H(X,t)??[(e,t)=>t]]];return D(u,o),{as:e=>o[0]=e}},having:(e,t)=>D(h,b(e)?e:n=>n(e)===t)});const g=G(i);if(F(g))return ue;const v=G(d);J(v,((e,[,t])=>T(H(v,t),(({3:t})=>y(e)?0:D(t,e)))));const f=G(u);let C=w;if(F(f)&&E(h))C=L;else{ce(o,C,L);const r=G();J(f,((e,[t,n])=>V(N(r,t,U),[e,n])));const a=U();J(g,(e=>A(r,e)?0:V(a,e)));const l=G(),i=(a,l,i,d)=>T(a,(([c,u,g,v])=>{J(l,((o,[a])=>{const l=N(c,o,G),u=H(l,i),h=d?void 0:a;if(u!==h){const a=U([[u,h]]),d=z(l);K(l,i,h),q(H(r,o),(([r,o])=>{const i=((e,t,n,s,r,o=!1)=>{if(F(n))return;const[a,l,i,d]=r;return o||=y(e),q(s,(([n,s])=>{o||(e=y(n)?l?.(e,s,t++):y(s)?i?.(e,n,t--):d?.(e,s,n,t),o||=y(e))})),o?a(O(n),z(n)):e})(v[r],d,l,a,o);v[r]=y((r=>{const o=e(r);return(e=>e==t||e==n)(o)||o==s&&R(r)?o:void 0})(i))?null:i}))}})),F(u)||!S(h,(e=>e((e=>v[e]))))?L.delRow(o,g):y(g)?a[2]=L.addRow(o,v):L.setRow(o,g,v)}));ie(C,o,C.addRowListener(o,null,((e,t,n,s)=>{const d=[],c=[],u=G(),h=C.hasRow(o,n);let g=!h;q(a,(e=>{const[t,r,a]=s(o,n,e);D(d,r),D(c,a),g||=t})),J(r,(e=>{const[t,,r]=s(o,n,e);(g||t)&&K(u,e,[r])})),g&&i(P(l,d,void 0,(([,e])=>(B(e,n),F(e)))),u,n,1),h&&i(P(l,c,(()=>{const e={};return q(a,(t=>e[t]=C.getCell(o,n,t))),[G(),U(),void 0,e]}),(([,e])=>{V(e,n)})),u,n)})))}ce(o,r,C);const p=(e,t,n,s)=>{const l=e=>r.getCell(t,n,e);I(s,(t=>{const[n,,s,a,i]=H(v,t),d=s?.(l,e),[c,u]=H(i,e)??[];d!=c&&(y(u)||le(o,u),K(i,e,y(d)?null:[d,...ae(o,1,r.addRowListener(n,d,(()=>p(e,n,d,a))))]))})),(e=>{const t=(t,n)=>r.getCell(...y(n)?[a,e,t]:t===a?[a,e,n]:[H(v,t)?.[0],H(H(v,t)?.[4],e)?.[0],n]);C.transaction((()=>S(c,(e=>e(t)))?J(g,((n,s)=>((e,t,n,s,r)=>y(r)?e.delCell(t,n,s,!0):e.setCell(t,n,s,r))(C,o,e,n,s(t,e)))):C.delRow(o,e)))})(e)},{3:Q}=H(v,null);return C.transaction((()=>ae(o,1,r.addRowListener(a,null,((e,t,n)=>{r.hasRow(a,n)?p(n,a,n,Q):(C.delRow(o,n),q(v,(({4:e})=>T(H(e,n),(([,t])=>{le(o,t),K(e,n)})))))}))))),ue},delQueryDefinition:e=>(de(e),se(e),ue),getStore:Z,getQueryIds:$,forEachQuery:_,hasQuery:ee,getTableId:te,addQueryIdsListener:e=>re((()=>e(ue))),delListener:e=>(Y(e),ue),destroy:oe,getListenerStats:()=>{const{tables:e,tableIds:t,transaction:n,...s}=L.getListenerStats();return s}};return he=([e,t],n)=>{I(e?["get","has","forEach"]:["get"],(e=>ue[e+a+n]=(...t)=>L[e+n](...t))),ue["add"+a+n+o]=(...e)=>{return L["add"+n+o](...(s=e,r=t,s.slice(0,r)),((n,...s)=>e[t](ue,...s)),!0);var s,r}},((e=[])=>{M.fromEntries(e)})(((e,t)=>((e,t)=>e.map(t))(j(e),(([e,n])=>t(n,e))))({[i]:[1,1],[i+v]:[0,1],[c]:[0,1],[u]:[0,1],[h]:[0,5],[d]:[1,2],[v]:[0,2],[g]:[1,3]},((e,t)=>[t,he(e,t)]))),k(ue);var he})(l)),r.get(l))})();export{Y as createQueries};
Binary file
@@ -1 +1 @@
1
- const e=e=>typeof e,t=e(""),n=e(!0),s=e(0),r=e(e),o="Listener",a="Result",l="Ids",i="Table",d="Row",c=d+"Count",u=d+l,h="Sorted"+d+l,g="Cell",v=g+l,w=Math,L=w.max,f=w.min,R=isFinite,y=e=>null==e,T=(e,t,n)=>y(e)?n?.():t(e),b=t=>e(t)==r,C=e=>Array.isArray(e),p=e=>e.length,S=()=>{},m=(e,t)=>e.every(t),I=(e,t)=>e.forEach(t),Q=e=>x(e,((e,t)=>e+t),0),E=e=>0==p(e),x=(e,t,n)=>e.reduce(t,n),D=(e,...t)=>e.push(...t),M=Object,j=M.entries,k=M.freeze,z=e=>e?.size??0,A=(e,t)=>e?.has(t)??!1,F=e=>y(e)||0==z(e),O=e=>[...e?.values()??[]],W=e=>e.clear(),q=(e,t)=>e?.forEach(t),B=(e,t)=>e?.delete(t),G=e=>new Map(e),H=(e,t)=>e?.get(t),J=(e,t)=>q(e,((e,n)=>t(n,e))),K=(e,t,n)=>y(n)?(B(e,t),e):e?.set(t,n),N=(e,t,n,s)=>(A(e,t)?s?.(H(e,t)):K(e,t,n()),H(e,t)),P=(e,t,n,s,r=0)=>T((n?N:H)(e,t[r],r>p(t)-2?n:G),(o=>{if(r>p(t)-2)return s?.(o)&&K(e,t[r]),o;const a=P(o,t,n,s,r+1);return F(o)&&K(e,t[r]),a})),U=e=>new Set(C(e)||y(e)?e:[e]),V=(e,t)=>e?.add(t),X=G([["avg",[(e,t)=>Q(e)/t,(e,t,n)=>e+(t-e)/(n+1),(e,t,n)=>e+(e-t)/(n-1),(e,t,n,s)=>e+(t-n)/s]],["max",[e=>L(...e),(e,t)=>L(t,e),(e,t)=>t==e?void 0:e,(e,t,n)=>n==e?void 0:L(t,e)]],["min",[e=>f(...e),(e,t)=>f(t,e),(e,t)=>t==e?void 0:e,(e,t,n)=>n==e?void 0:f(t,e)]],["sum",[e=>Q(e),(e,t)=>e+t,(e,t)=>e-t,(e,t,n)=>e-n+t]]]),Y=(()=>{const r=new WeakMap;return l=>(r.has(l)||r.set(l,(r=>{const l=r.createStore,w=l(),L=l(),f=G(),{addListener:Q,callListeners:x,delListener:M}=L,[Y,Z,$,_,ee,,,te,,ne,se,re,oe,ae]=((e,t,n,s,r)=>{const o=e.hasRow,a=G(),l=G(),i=G(),d=G(),c=G(),u=G(),h=(t,n,...s)=>{const r=N(u,t,U);return I(s,(t=>V(r,t)&&n&&e.callListener(t))),s},g=(t,...n)=>T(H(u,t),(s=>{I(E(n)?O(s):n,(t=>{e.delListener(t),B(s,t)})),F(s)&&K(u,t)})),v=(e,t)=>{K(a,e,t),A(l,e)||(K(l,e,!0),K(d,e,G()),K(c,e,G()),r(i))},w=e=>{K(a,e),K(l,e),K(d,e),K(c,e),g(e),r(i)};return[()=>e,()=>{return e=a,[...e?.keys()??[]];var e},e=>J(l,e),e=>A(l,e),e=>H(a,e),e=>H(l,e),(e,t)=>K(l,e,t),v,(t,s,r,a,l)=>{v(t,s);const i=G(),u=G(),w=H(d,t),L=H(c,t),f=t=>{const r=n=>e.getCell(s,t,n),d=H(w,t),c=o(s,t)?n(a(r,t)):void 0;var h,g;if(d===c||C(d)&&C(c)&&(g=c,p(h=d)===p(g)&&m(h,((e,t)=>g[t]===e)))||K(i,t,[d,c]),!y(l)){const e=H(L,t),n=o(s,t)?l(r,t):void 0;e!=n&&K(u,t,n)}},R=e=>{r((()=>{q(i,(([,e],t)=>K(w,t,e))),q(u,((e,t)=>K(L,t,e)))}),i,u,w,L,e),W(i),W(u)};J(w,f),e.hasTable(s)&&I(e.getRowIds(s),(e=>{A(w,e)||f(e)})),R(!0),g(t),h(t,0,e.addRowListener(s,null,((e,t,n)=>f(n))),e.addTableListener(s,(()=>R())))},w,e=>s(e,i),()=>J(u,w),h,g]})(r,0,S,Q,x),le=(e,t,...n)=>I(n,(n=>V(N(N(f,t,G),e,U),n))),ie=e=>{T(H(f,e),(e=>{J(e,((e,t)=>q(t,(t=>e.delListener(t))))),W(e)})),I([L,w],(t=>t.delTable(e)))},de=(e,t,n)=>le(t,e,t.addStartTransactionListener(n.startTransaction),t.addDidFinishTransactionListener((()=>n.finishTransaction()))),ce={setQueryDefinition:(o,a,l)=>{te(o,a),ie(o);const i=[],d=[[null,[a,null,null,[],G()]]],c=[],u=[],h=[];l({select:(e,t)=>{const n=b(e)?[p(i)+"",e]:[y(t)?e:t,n=>n(e,t)];return D(i,n),{as:e=>n[0]=e}},join:(e,t,n)=>{const s=y(n)||b(t)?null:t,r=y(s)?t:n,o=[e,[e,s,b(r)?r:e=>e(r),[],G()]];return D(d,o),{as:e=>o[0]=e}},where:(e,t,n)=>D(c,b(e)?e:y(n)?n=>n(e)===t:s=>s(e,t)===n),group:(e,t,n,s,r)=>{const o=[e,[e,b(t)?[t,n,s,r]:H(X,t)??[(e,t)=>t]]];return D(u,o),{as:e=>o[0]=e}},having:(e,t)=>D(h,b(e)?e:n=>n(e)===t)});const g=G(i);if(F(g))return ce;const v=G(d);J(v,((e,[,t])=>T(H(v,t),(({3:t})=>y(e)?0:D(t,e)))));const f=G(u);let C=w;if(F(f)&&E(h))C=L;else{de(o,C,L);const r=G();J(f,((e,[t,n])=>V(N(r,t,U),[e,n])));const a=U();J(g,(e=>A(r,e)?0:V(a,e)));const l=G(),i=(a,l,i,d)=>T(a,(([c,u,g,v])=>{J(l,((o,[a])=>{const l=N(c,o,G),u=H(l,i),h=d?void 0:a;if(u!==h){const a=U([[u,h]]),d=z(l);K(l,i,h),q(H(r,o),(([r,o])=>{const i=((e,t,n,s,r,o=!1)=>{if(F(n))return;const[a,l,i,d]=r;return o||=y(e),q(s,(([n,s])=>{o||(e=y(n)?l?.(e,s,t++):y(s)?i?.(e,n,t--):d?.(e,s,n,t),o||=y(e))})),o?a(O(n),z(n)):e})(v[r],d,l,a,o);v[r]=y((r=>{const o=e(r);return(e=>e==t||e==n)(o)||o==s&&R(r)?o:void 0})(i))?null:i}))}})),F(u)||!m(h,(e=>e((e=>v[e]))))?L.delRow(o,g):y(g)?a[2]=L.addRow(o,v):L.setRow(o,g,v)}));le(C,o,C.addRowListener(o,null,((e,t,n,s)=>{const d=[],c=[],u=G(),h=C.hasRow(o,n);let g=!h;q(a,(e=>{const[t,r,a]=s(o,n,e);D(d,r),D(c,a),g||=t})),J(r,(e=>{const[t,,r]=s(o,n,e);(g||t)&&K(u,e,[r])})),g&&i(P(l,d,void 0,(([,e])=>(B(e,n),F(e)))),u,n,1),h&&i(P(l,c,(()=>{const e={};return q(a,(t=>e[t]=C.getCell(o,n,t))),[G(),U(),void 0,e]}),(([,e])=>{V(e,n)})),u,n)})))}de(o,r,C);const S=(e,t,n,s)=>{const l=e=>r.getCell(t,n,e);I(s,(t=>{const[n,,s,a,i]=H(v,t),d=s?.(l,e),[c,u]=H(i,e)??[];d!=c&&(y(u)||ae(o,u),K(i,e,y(d)?null:[d,...oe(o,1,r.addRowListener(n,d,(()=>S(e,n,d,a))))]))})),(e=>{const t=(t,n)=>r.getCell(...y(n)?[a,e,t]:t===a?[a,e,n]:[H(v,t)?.[0],H(H(v,t)?.[4],e)?.[0],n]);C.transaction((()=>m(c,(e=>e(t)))?J(g,((n,s)=>((e,t,n,s,r)=>y(r)?e.delCell(t,n,s,!0):e.setCell(t,n,s,r))(C,o,e,n,s(t,e)))):C.delRow(o,e)))})(e)},{3:Q}=H(v,null);return C.transaction((()=>oe(o,1,r.addRowListener(a,null,((e,t,n)=>{r.hasRow(a,n)?S(n,a,n,Q):(C.delRow(o,n),q(v,(({4:e})=>T(H(e,n),(([,t])=>{ae(o,t),K(e,n)})))))}))))),ce},delQueryDefinition:e=>(ie(e),ne(e),ce),getStore:Y,getQueryIds:Z,forEachQuery:$,hasQuery:_,getTableId:ee,addQueryIdsListener:e=>se((()=>e(ce))),delListener:e=>(M(e),ce),destroy:re,getListenerStats:()=>{const{tables:e,tableIds:t,transaction:n,...s}=L.getListenerStats();return s}};var ue;return ue=([e,t],n)=>{I(e?["get","has","forEach"]:["get"],(e=>ce[e+a+n]=(...t)=>L[e+n](...t))),ce["add"+a+n+o]=(...e)=>{return L["add"+n+o](...(s=e,r=t,s.slice(0,r)),((n,...s)=>e[t](ce,...s)),!0);var s,r}},((e,t)=>{j({[i]:[1,1],[i+v]:[0,1],[c]:[0,1],[u]:[0,1],[h]:[0,5],[d]:[1,2],[v]:[0,2],[g]:[1,3]}).map(t)})(0,(([e,t])=>ue(t,e))),k(ce)})(l)),r.get(l))})();export{Y as createQueries};
1
+ const e=e=>typeof e,t=e(""),n=e(!0),s=e(0),r=e(e),o="Listener",a="Result",l="Ids",i="Table",d="Row",c=d+"Count",u=d+l,h="Sorted"+d+l,g="Cell",v=g+l,w=Math,L=w.max,f=w.min,R=isFinite,y=e=>null==e,T=(e,t,n)=>y(e)?n?.():t(e),b=t=>e(t)==r,C=e=>Array.isArray(e),m=e=>e.length,p=()=>{},S=(e,t)=>e.every(t),I=(e,t)=>e.forEach(t),Q=e=>x(e,((e,t)=>e+t),0),E=e=>0==m(e),x=(e,t,n)=>e.reduce(t,n),D=(e,...t)=>e.push(...t),M=Object,j=M.entries,k=M.freeze,z=e=>e?.size??0,A=(e,t)=>e?.has(t)??!1,F=e=>y(e)||0==z(e),O=e=>[...e?.values()??[]],W=e=>e.clear(),q=(e,t)=>e?.forEach(t),B=(e,t)=>e?.delete(t),G=e=>new Map(e),H=(e,t)=>e?.get(t),J=(e,t)=>q(e,((e,n)=>t(n,e))),K=(e,t,n)=>y(n)?(B(e,t),e):e?.set(t,n),N=(e,t,n,s)=>(A(e,t)?s?.(H(e,t)):K(e,t,n()),H(e,t)),P=(e,t,n,s,r=0)=>T((n?N:H)(e,t[r],r>m(t)-2?n:G),(o=>{if(r>m(t)-2)return s?.(o)&&K(e,t[r]),o;const a=P(o,t,n,s,r+1);return F(o)&&K(e,t[r]),a})),U=e=>new Set(C(e)||y(e)?e:[e]),V=(e,t)=>e?.add(t),X=G([["avg",[(e,t)=>Q(e)/t,(e,t,n)=>e+(t-e)/(n+1),(e,t,n)=>e+(e-t)/(n-1),(e,t,n,s)=>e+(t-n)/s]],["max",[e=>L(...e),(e,t)=>L(t,e),(e,t)=>t==e?void 0:e,(e,t,n)=>n==e?void 0:L(t,e)]],["min",[e=>f(...e),(e,t)=>f(t,e),(e,t)=>t==e?void 0:e,(e,t,n)=>n==e?void 0:f(t,e)]],["sum",[e=>Q(e),(e,t)=>e+t,(e,t)=>e-t,(e,t,n)=>e-n+t]]]),Y=(()=>{const r=new WeakMap;return l=>(r.has(l)||r.set(l,(r=>{const l=r.createStore,w=l(),L=l(),f=G(),{addListener:Q,callListeners:x,delListener:Y}=L,[Z,$,_,ee,te,,,ne,,se,re,oe,ae,le]=((e,t,n,s,r)=>{const o=e.hasRow,a=G(),l=G(),i=G(),d=G(),c=G(),u=G(),h=(t,n,...s)=>{const r=N(u,t,U);return I(s,(t=>V(r,t)&&n&&e.callListener(t))),s},g=(t,...n)=>T(H(u,t),(s=>{I(E(n)?O(s):n,(t=>{e.delListener(t),B(s,t)})),F(s)&&K(u,t)})),v=(e,t)=>{K(a,e,t),A(l,e)||(K(l,e,!0),K(d,e,G()),K(c,e,G()),r(i))},w=e=>{K(a,e),K(l,e),K(d,e),K(c,e),g(e),r(i)};return[()=>e,()=>{return e=a,[...e?.keys()??[]];var e},e=>J(l,e),e=>A(l,e),e=>H(a,e),e=>H(l,e),(e,t)=>K(l,e,t),v,(t,s,r,a,l)=>{v(t,s);const i=G(),u=G(),w=H(d,t),L=H(c,t),f=t=>{const r=n=>e.getCell(s,t,n),d=H(w,t),c=o(s,t)?n(a(r,t)):void 0;var h,g;if(d===c||C(d)&&C(c)&&(g=c,m(h=d)===m(g)&&S(h,((e,t)=>g[t]===e)))||K(i,t,[d,c]),!y(l)){const e=H(L,t),n=o(s,t)?l(r,t):void 0;e!=n&&K(u,t,n)}},R=e=>{r((()=>{q(i,(([,e],t)=>K(w,t,e))),q(u,((e,t)=>K(L,t,e)))}),i,u,w,L,e),W(i),W(u)};J(w,f),e.hasTable(s)&&I(e.getRowIds(s),(e=>{A(w,e)||f(e)})),R(!0),g(t),h(t,0,e.addRowListener(s,null,((e,t,n)=>f(n))),e.addTableListener(s,(()=>R())))},w,e=>s(e,i),()=>J(u,w),h,g]})(r,0,p,Q,x),ie=(e,t,...n)=>I(n,(n=>V(N(N(f,t,G),e,U),n))),de=e=>{T(H(f,e),(e=>{J(e,((e,t)=>q(t,(t=>e.delListener(t))))),W(e)})),I([L,w],(t=>t.delTable(e)))},ce=(e,t,n)=>ie(t,e,t.addStartTransactionListener(n.startTransaction),t.addDidFinishTransactionListener((()=>n.finishTransaction()))),ue={setQueryDefinition:(o,a,l)=>{ne(o,a),de(o);const i=[],d=[[null,[a,null,null,[],G()]]],c=[],u=[],h=[];l({select:(e,t)=>{const n=b(e)?[m(i)+"",e]:[y(t)?e:t,n=>n(e,t)];return D(i,n),{as:e=>n[0]=e}},join:(e,t,n)=>{const s=y(n)||b(t)?null:t,r=y(s)?t:n,o=[e,[e,s,b(r)?r:e=>e(r),[],G()]];return D(d,o),{as:e=>o[0]=e}},where:(e,t,n)=>D(c,b(e)?e:y(n)?n=>n(e)===t:s=>s(e,t)===n),group:(e,t,n,s,r)=>{const o=[e,[e,b(t)?[t,n,s,r]:H(X,t)??[(e,t)=>t]]];return D(u,o),{as:e=>o[0]=e}},having:(e,t)=>D(h,b(e)?e:n=>n(e)===t)});const g=G(i);if(F(g))return ue;const v=G(d);J(v,((e,[,t])=>T(H(v,t),(({3:t})=>y(e)?0:D(t,e)))));const f=G(u);let C=w;if(F(f)&&E(h))C=L;else{ce(o,C,L);const r=G();J(f,((e,[t,n])=>V(N(r,t,U),[e,n])));const a=U();J(g,(e=>A(r,e)?0:V(a,e)));const l=G(),i=(a,l,i,d)=>T(a,(([c,u,g,v])=>{J(l,((o,[a])=>{const l=N(c,o,G),u=H(l,i),h=d?void 0:a;if(u!==h){const a=U([[u,h]]),d=z(l);K(l,i,h),q(H(r,o),(([r,o])=>{const i=((e,t,n,s,r,o=!1)=>{if(F(n))return;const[a,l,i,d]=r;return o||=y(e),q(s,(([n,s])=>{o||(e=y(n)?l?.(e,s,t++):y(s)?i?.(e,n,t--):d?.(e,s,n,t),o||=y(e))})),o?a(O(n),z(n)):e})(v[r],d,l,a,o);v[r]=y((r=>{const o=e(r);return(e=>e==t||e==n)(o)||o==s&&R(r)?o:void 0})(i))?null:i}))}})),F(u)||!S(h,(e=>e((e=>v[e]))))?L.delRow(o,g):y(g)?a[2]=L.addRow(o,v):L.setRow(o,g,v)}));ie(C,o,C.addRowListener(o,null,((e,t,n,s)=>{const d=[],c=[],u=G(),h=C.hasRow(o,n);let g=!h;q(a,(e=>{const[t,r,a]=s(o,n,e);D(d,r),D(c,a),g||=t})),J(r,(e=>{const[t,,r]=s(o,n,e);(g||t)&&K(u,e,[r])})),g&&i(P(l,d,void 0,(([,e])=>(B(e,n),F(e)))),u,n,1),h&&i(P(l,c,(()=>{const e={};return q(a,(t=>e[t]=C.getCell(o,n,t))),[G(),U(),void 0,e]}),(([,e])=>{V(e,n)})),u,n)})))}ce(o,r,C);const p=(e,t,n,s)=>{const l=e=>r.getCell(t,n,e);I(s,(t=>{const[n,,s,a,i]=H(v,t),d=s?.(l,e),[c,u]=H(i,e)??[];d!=c&&(y(u)||le(o,u),K(i,e,y(d)?null:[d,...ae(o,1,r.addRowListener(n,d,(()=>p(e,n,d,a))))]))})),(e=>{const t=(t,n)=>r.getCell(...y(n)?[a,e,t]:t===a?[a,e,n]:[H(v,t)?.[0],H(H(v,t)?.[4],e)?.[0],n]);C.transaction((()=>S(c,(e=>e(t)))?J(g,((n,s)=>((e,t,n,s,r)=>y(r)?e.delCell(t,n,s,!0):e.setCell(t,n,s,r))(C,o,e,n,s(t,e)))):C.delRow(o,e)))})(e)},{3:Q}=H(v,null);return C.transaction((()=>ae(o,1,r.addRowListener(a,null,((e,t,n)=>{r.hasRow(a,n)?p(n,a,n,Q):(C.delRow(o,n),q(v,(({4:e})=>T(H(e,n),(([,t])=>{le(o,t),K(e,n)})))))}))))),ue},delQueryDefinition:e=>(de(e),se(e),ue),getStore:Z,getQueryIds:$,forEachQuery:_,hasQuery:ee,getTableId:te,addQueryIdsListener:e=>re((()=>e(ue))),delListener:e=>(Y(e),ue),destroy:oe,getListenerStats:()=>{const{tables:e,tableIds:t,transaction:n,...s}=L.getListenerStats();return s}};return he=([e,t],n)=>{I(e?["get","has","forEach"]:["get"],(e=>ue[e+a+n]=(...t)=>L[e+n](...t))),ue["add"+a+n+o]=(...e)=>{return L["add"+n+o](...(s=e,r=t,s.slice(0,r)),((n,...s)=>e[t](ue,...s)),!0);var s,r}},((e=[])=>{M.fromEntries(e)})(((e,t)=>((e,t)=>e.map(t))(j(e),(([e,n])=>t(n,e))))({[i]:[1,1],[i+v]:[0,1],[c]:[0,1],[u]:[0,1],[h]:[0,5],[d]:[1,2],[v]:[0,2],[g]:[1,3]},((e,t)=>[t,he(e,t)]))),k(ue);var he})(l)),r.get(l))})();export{Y as createQueries};