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
- var t,e;t=this,e=function(t){"use strict";const e=t=>null==t,n=(t,n,a)=>e(t)?a?.():n(t),a=t=>Array.isArray(t),s=t=>t.length,o=t=>{throw Error(t)},r=(t,e)=>t.forEach(e),i=(t,...e)=>t.push(...e),c=t=>t.shift(),d=Object,u=t=>d.getPrototypeOf(t),l=d.entries,y=d.keys,g=d.freeze,h=(t=[])=>d.fromEntries(t),f=(t,e)=>n(t,(t=>t[e])),p=(t,e)=>e in t,v=(t,e)=>(delete t[e],t),w=(t,e)=>((t,e)=>t.map(e))(l(t),(([t,n])=>e(n,t))),b=t=>s(y(t)),A=t=>(t=>!e(t)&&n(u(t),(t=>t==d.prototype||e(u(t))),(()=>!0)))(t)&&0==b(t),C=(t,e,n)=>(p(t,e)||(t[e]=n()),t[e]),S=t=>e(t)||0==(t=>t?.size??0)(t),L=(t,e)=>t?.forEach(e),m=(t,e)=>t?.delete(e),M=t=>new Map(t),T=(t,e)=>t?.get(e),E=(t,n,a)=>e(a)?(m(t,n),t):t?.set(n,a),P=(t,e,n,a)=>{var s,o;return s=t,o=e,s?.has(o)?a?.(T(t,e)):E(t,e,n()),T(t,e)},x=(t,e,a,o,r=0)=>n((a?P:T)(t,e[r],r>s(e)-2?a:M),(n=>{if(r>s(e)-2)return o?.(n)&&E(t,e[r]),n;const i=x(n,e,a,o,r+1);return S(n)&&E(t,e[r]),i})),D=t=>new Set(a(t)||e(t)?t:[t]),j=/^\d+$/,z=M(),O=M(),k=(t,d,u,l,y,h,f,p={},v=0,w=[])=>{let b,C,k,B=0,F=0,H=0;P(z,w,(()=>0)),P(O,w,(()=>[]));const $=M(),[q,G,I,J,K]=((t=1,e,n)=>1!=t&&e.isMergeable()?[1,e.getMergeableContent,()=>e.getTransactionMergeableChanges(!n),([[t],[e]])=>!A(t)||!A(e),e.setDefaultContent]:2!=t?[0,e.getContent,e.getTransactionChanges,([t,e])=>!A(t)||!A(e),e.setContent]:o("Store type not supported by this Persister"))(f,t,v),[N,Q,R]=(()=>{let t;const[a,o]=(()=>{const t=[];let e=0;return[n=>(n?c(t):null)??""+e++,e=>{j.test(e)&&s(t)<1e3&&i(t,e)}]})(),d=M();return[(e,n,s,o=[],r=()=>[])=>{t??=tt;const i=a(1);var c,u;return E(d,i,[e,n,s,o,r]),c=x(n,s??[""],D),u=i,c?.add(u),i},(e,n,...a)=>r(((t,e=[""])=>{const n=[],a=(t,o)=>o==s(e)?i(n,t):null===e[o]?L(t,(t=>a(t,o+1))):r([e[o],null],(e=>a(T(t,e),o+1)));return a(t,0),n})(e,n),(e=>L(e,(e=>T(d,e)[0](t,...n??[],...a))))),t=>n(T(d,t),(([,e,n])=>(x(e,n??[""],void 0,(e=>(m(e,t),S(e)?1:0))),E(d,t),o(t),n))),a=>n(T(d,a),(([n,,a=[],o,i])=>{const c=(...d)=>{const u=s(d);u==s(a)?n(t,...d,...i(d)):e(a[u])?r(o[u]?.(...d)??[],(t=>c(...d,t))):c(...d,a[u])};c()}))]})(),U=t=>{t!=B&&(B=t,Q($,void 0,B))},V=e=>{(q&&a(e?.[0])?1===e?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===e?.[2]?t.applyChanges:t.setContent)(e)},W=async t=>(2!=B&&(U(1),F++,await _((async()=>{try{const e=await d();a(e)?V(e):t?K(t):o("Content is not an array: "+e)}catch(e){h?.(e),t&&K(t)}U(0)}))),tt),X=()=>(C&&(y(C),C=void 0),tt),Y=async t=>(1!=B&&(U(2),H++,await _((async()=>{try{await u(G,t)}catch(t){h?.(t)}U(0)}))),tt),Z=()=>(k&&(t.delListener(k),k=void 0),tt),_=async(...t)=>(i(T(O,w),...t),await(async()=>{if(!T(z,w)){for(E(z,w,1);!e(b=c(T(O,w)));)try{await b()}catch(t){h?.(t)}E(z,w,0)}})(),tt),tt={load:W,startAutoLoad:async t=>{X(),await W(t);try{C=await l((async(t,e)=>{e||t?2!=B&&(U(1),F++,V(e??t),U(0)):await W()}))}catch(t){h?.(t)}return tt},stopAutoLoad:X,isAutoLoading:()=>!e(C),save:Y,startAutoSave:async()=>(Z(),await Y(),k=t.addDidFinishTransactionListener((()=>{const t=I();J(t)&&Y(t)})),tt),stopAutoSave:Z,isAutoSaving:()=>!e(k),getStatus:()=>B,addStatusListener:t=>N(t,$),delListener:e=>(R(e),t),schedule:_,getStore:()=>t,destroy:()=>(T(O,w).splice(0,void 0),X().stopAutoSave()),getStats:()=>({loads:F,saves:H}),...p};return g(tt)},B=(t,e)=>[t[e].t,t[e].v],F=(t,n,a,s)=>{const o=e(n)?t:C(t,n,(()=>({})));let r;return w(a,((t,e)=>{s(o,e,t)&&(r=1)})),w(o,((t,e)=>{p(a,e)||(v(o,e),r=1)})),!e(n)&&A(o)&&v(t,n),r};t.createAutomergePersister=(t,a,s="tinybase",o)=>(a.change((t=>C(t,s,h))),k(t,(async()=>{const t=await a.doc();return 2==b(t?.[s])?B(t,s):void 0}),(async(t,o)=>a.change((a=>((t,a,s,o)=>{((t,e)=>{A(t[e])&&(t[e]={t:{},v:{}})})(t,a);const[r,i]=B(t,a),c=()=>{d=1};let d=1;if(n(o,(([t,a])=>{d=0,w(t,((t,a)=>d?0:e(t)?v(r,a):n(r[a],(a=>w(t,((t,s)=>d?0:e(t)?v(a,s):n(f(a,s),(n=>w(t,((t,a)=>e(t)?v(n,a):n[a]=t))),c)))),c))),w(a,((t,n)=>d?0:e(t)?v(i,n):i[n]=t))})),d){const[t,e]=s();F(r,void 0,t,((t,e,n)=>F(r,e,n,((t,e,n)=>F(t,e,n,((t,e,n)=>{if(f(t,e)!==n)return t[e]=n,1})))))),F(i,void 0,e,((t,e,n)=>{f(i,e)!==n&&(i[e]=n)}))}})(a,s,t,o)))),(t=>{const e=({doc:e})=>t(B(e,s));return a.on("change",e),e}),(t=>{a.removeListener("change",t)}),o,1,{getDocHandle:()=>a}))},"object"==typeof exports&&"undefined"!=typeof module?e(exports):"function"==typeof define&&define.amd?define(["exports"],e):e((t="undefined"!=typeof globalThis?globalThis:t||self).TinyBasePersisterAutomerge={});
1
+ var t,e;t=this,e=function(t){"use strict";const e=t=>null==t,n=(t,n,a)=>e(t)?a?.():n(t),a=t=>Array.isArray(t),s=t=>t.length,o=t=>{throw Error(t)},r=(t,e)=>t.forEach(e),i=(t,...e)=>t.push(...e),c=t=>t.shift(),d=Object,u=t=>d.getPrototypeOf(t),l=d.entries,y=d.keys,g=d.freeze,h=(t=[])=>d.fromEntries(t),f=(t,e)=>n(t,(t=>t[e])),p=(t,e)=>e in t,v=(t,e)=>(delete t[e],t),w=(t,e)=>h(((t,e)=>((t,e)=>t.map(e))(l(t),(([t,n])=>e(n,t))))(t,((t,n)=>[n,e(t,n)]))),b=t=>s(y(t)),A=t=>(t=>!e(t)&&n(u(t),(t=>t==d.prototype||e(u(t))),(()=>!0)))(t)&&0==b(t),C=(t,e,n)=>(p(t,e)||(t[e]=n()),t[e]),S=t=>e(t)||0==(t=>t?.size??0)(t),L=(t,e)=>t?.forEach(e),m=(t,e)=>t?.delete(e),M=t=>new Map(t),T=(t,e)=>t?.get(e),E=(t,n,a)=>e(a)?(m(t,n),t):t?.set(n,a),P=(t,e,n,a)=>{var s,o;return s=t,o=e,s?.has(o)?a?.(T(t,e)):E(t,e,n()),T(t,e)},x=(t,e,a,o,r=0)=>n((a?P:T)(t,e[r],r>s(e)-2?a:M),(n=>{if(r>s(e)-2)return o?.(n)&&E(t,e[r]),n;const i=x(n,e,a,o,r+1);return S(n)&&E(t,e[r]),i})),D=t=>new Set(a(t)||e(t)?t:[t]),j=/^\d+$/,z=M(),O=M(),k=(t,d,u,l,y,h,f,p={},v=0,w=[])=>{let b,C,k,B=0,F=0,H=0;P(z,w,(()=>0)),P(O,w,(()=>[]));const $=M(),[q,G,I,J,K]=((t=1,e,n)=>1!=t&&e.isMergeable()?[1,e.getMergeableContent,()=>e.getTransactionMergeableChanges(!n),([[t],[e]])=>!A(t)||!A(e),e.setDefaultContent]:2!=t?[0,e.getContent,e.getTransactionChanges,([t,e])=>!A(t)||!A(e),e.setContent]:o("Store type not supported by this Persister"))(f,t,v),[N,Q,R]=(()=>{let t;const[a,o]=(()=>{const t=[];let e=0;return[n=>(n?c(t):null)??""+e++,e=>{j.test(e)&&s(t)<1e3&&i(t,e)}]})(),d=M();return[(e,n,s,o=[],r=()=>[])=>{t??=tt;const i=a(1);var c,u;return E(d,i,[e,n,s,o,r]),c=x(n,s??[""],D),u=i,c?.add(u),i},(e,n,...a)=>r(((t,e=[""])=>{const n=[],a=(t,o)=>o==s(e)?i(n,t):null===e[o]?L(t,(t=>a(t,o+1))):r([e[o],null],(e=>a(T(t,e),o+1)));return a(t,0),n})(e,n),(e=>L(e,(e=>T(d,e)[0](t,...n??[],...a))))),t=>n(T(d,t),(([,e,n])=>(x(e,n??[""],void 0,(e=>(m(e,t),S(e)?1:0))),E(d,t),o(t),n))),a=>n(T(d,a),(([n,,a=[],o,i])=>{const c=(...d)=>{const u=s(d);u==s(a)?n(t,...d,...i(d)):e(a[u])?r(o[u]?.(...d)??[],(t=>c(...d,t))):c(...d,a[u])};c()}))]})(),U=t=>{t!=B&&(B=t,Q($,void 0,B))},V=e=>{(q&&a(e?.[0])?1===e?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===e?.[2]?t.applyChanges:t.setContent)(e)},W=async t=>(2!=B&&(U(1),F++,await _((async()=>{try{const e=await d();a(e)?V(e):t?K(t):o("Content is not an array: "+e)}catch(e){h?.(e),t&&K(t)}U(0)}))),tt),X=()=>(C&&(y(C),C=void 0),tt),Y=async t=>(1!=B&&(U(2),H++,await _((async()=>{try{await u(G,t)}catch(t){h?.(t)}U(0)}))),tt),Z=()=>(k&&(t.delListener(k),k=void 0),tt),_=async(...t)=>(i(T(O,w),...t),await(async()=>{if(!T(z,w)){for(E(z,w,1);!e(b=c(T(O,w)));)try{await b()}catch(t){h?.(t)}E(z,w,0)}})(),tt),tt={load:W,startAutoLoad:async t=>{X(),await W(t);try{C=await l((async(t,e)=>{e||t?2!=B&&(U(1),F++,V(e??t),U(0)):await W()}))}catch(t){h?.(t)}return tt},stopAutoLoad:X,isAutoLoading:()=>!e(C),save:Y,startAutoSave:async()=>(Z(),await Y(),k=t.addDidFinishTransactionListener((()=>{const t=I();J(t)&&Y(t)})),tt),stopAutoSave:Z,isAutoSaving:()=>!e(k),getStatus:()=>B,addStatusListener:t=>N(t,$),delListener:e=>(R(e),t),schedule:_,getStore:()=>t,destroy:()=>(T(O,w).splice(0,void 0),X().stopAutoSave()),getStats:()=>({loads:F,saves:H}),...p};return g(tt)},B=(t,e)=>[t[e].t,t[e].v],F=(t,n,a,s)=>{const o=e(n)?t:C(t,n,(()=>({})));let r;return w(a,((t,e)=>{s(o,e,t)&&(r=1)})),w(o,((t,e)=>{p(a,e)||(v(o,e),r=1)})),!e(n)&&A(o)&&v(t,n),r};t.createAutomergePersister=(t,a,s="tinybase",o)=>(a.change((t=>C(t,s,h))),k(t,(async()=>{const t=await a.doc();return 2==b(t?.[s])?B(t,s):void 0}),(async(t,o)=>a.change((a=>((t,a,s,o)=>{((t,e)=>{A(t[e])&&(t[e]={t:{},v:{}})})(t,a);const[r,i]=B(t,a),c=()=>{d=1};let d=1;if(n(o,(([t,a])=>{d=0,w(t,((t,a)=>d?0:e(t)?v(r,a):n(r[a],(a=>w(t,((t,s)=>d?0:e(t)?v(a,s):n(f(a,s),(n=>w(t,((t,a)=>e(t)?v(n,a):n[a]=t))),c)))),c))),w(a,((t,n)=>d?0:e(t)?v(i,n):i[n]=t))})),d){const[t,e]=s();F(r,void 0,t,((t,e,n)=>F(r,e,n,((t,e,n)=>F(t,e,n,((t,e,n)=>{if(f(t,e)!==n)return t[e]=n,1})))))),F(i,void 0,e,((t,e,n)=>{f(i,e)!==n&&(i[e]=n)}))}})(a,s,t,o)))),(t=>{const e=({doc:e})=>t(B(e,s));return a.on("change",e),e}),(t=>{a.removeListener("change",t)}),o,1,{getDocHandle:()=>a}))},"object"==typeof exports&&"undefined"!=typeof module?e(exports):"function"==typeof define&&define.amd?define(["exports"],e):e((t="undefined"!=typeof globalThis?globalThis:t||self).TinyBasePersisterAutomerge={});
@@ -1 +1 @@
1
- var t,e;t=this,e=function(t){"use strict";const e=t=>null==t,n=(t,n,a)=>e(t)?a?.():n(t),a=t=>Array.isArray(t),s=t=>t.length,o=t=>{throw Error(t)},r=(t,e)=>t.forEach(e),i=(t,...e)=>t.push(...e),c=t=>t.shift(),d=Object,u=t=>d.getPrototypeOf(t),l=d.entries,y=d.keys,g=d.freeze,h=(t=[])=>d.fromEntries(t),f=(t,e)=>n(t,(t=>t[e])),p=(t,e)=>e in t,v=(t,e)=>(delete t[e],t),w=(t,e)=>((t,e)=>t.map(e))(l(t),(([t,n])=>e(n,t))),b=t=>s(y(t)),A=t=>(t=>!e(t)&&n(u(t),(t=>t==d.prototype||e(u(t))),(()=>!0)))(t)&&0==b(t),C=(t,e,n)=>(p(t,e)||(t[e]=n()),t[e]),S=t=>e(t)||0==(t=>t?.size??0)(t),L=(t,e)=>t?.forEach(e),m=(t,e)=>t?.delete(e),M=t=>new Map(t),T=(t,e)=>t?.get(e),E=(t,n,a)=>e(a)?(m(t,n),t):t?.set(n,a),P=(t,e,n,a)=>{var s,o;return s=t,o=e,s?.has(o)?a?.(T(t,e)):E(t,e,n()),T(t,e)},x=(t,e,a,o,r=0)=>n((a?P:T)(t,e[r],r>s(e)-2?a:M),(n=>{if(r>s(e)-2)return o?.(n)&&E(t,e[r]),n;const i=x(n,e,a,o,r+1);return S(n)&&E(t,e[r]),i})),D=t=>new Set(a(t)||e(t)?t:[t]),j=/^\d+$/,z=M(),O=M(),k=(t,d,u,l,y,h,f,p={},v=0,w=[])=>{let b,C,k,B=0,F=0,H=0;P(z,w,(()=>0)),P(O,w,(()=>[]));const $=M(),[q,G,I,J,K]=((t=1,e,n)=>1!=t&&e.isMergeable()?[1,e.getMergeableContent,()=>e.getTransactionMergeableChanges(!n),([[t],[e]])=>!A(t)||!A(e),e.setDefaultContent]:2!=t?[0,e.getContent,e.getTransactionChanges,([t,e])=>!A(t)||!A(e),e.setContent]:o("Store type not supported by this Persister"))(f,t,v),[N,Q,R]=(()=>{let t;const[a,o]=(()=>{const t=[];let e=0;return[n=>(n?c(t):null)??""+e++,e=>{j.test(e)&&s(t)<1e3&&i(t,e)}]})(),d=M();return[(e,n,s,o=[],r=()=>[])=>{t??=tt;const i=a(1);var c,u;return E(d,i,[e,n,s,o,r]),c=x(n,s??[""],D),u=i,c?.add(u),i},(e,n,...a)=>r(((t,e=[""])=>{const n=[],a=(t,o)=>o==s(e)?i(n,t):null===e[o]?L(t,(t=>a(t,o+1))):r([e[o],null],(e=>a(T(t,e),o+1)));return a(t,0),n})(e,n),(e=>L(e,(e=>T(d,e)[0](t,...n??[],...a))))),t=>n(T(d,t),(([,e,n])=>(x(e,n??[""],void 0,(e=>(m(e,t),S(e)?1:0))),E(d,t),o(t),n))),a=>n(T(d,a),(([n,,a=[],o,i])=>{const c=(...d)=>{const u=s(d);u==s(a)?n(t,...d,...i(d)):e(a[u])?r(o[u]?.(...d)??[],(t=>c(...d,t))):c(...d,a[u])};c()}))]})(),U=t=>{t!=B&&(B=t,Q($,void 0,B))},V=e=>{(q&&a(e?.[0])?1===e?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===e?.[2]?t.applyChanges:t.setContent)(e)},W=async t=>(2!=B&&(U(1),F++,await _((async()=>{try{const e=await d();a(e)?V(e):t?K(t):o("Content is not an array: "+e)}catch(e){h?.(e),t&&K(t)}U(0)}))),tt),X=()=>(C&&(y(C),C=void 0),tt),Y=async t=>(1!=B&&(U(2),H++,await _((async()=>{try{await u(G,t)}catch(t){h?.(t)}U(0)}))),tt),Z=()=>(k&&(t.delListener(k),k=void 0),tt),_=async(...t)=>(i(T(O,w),...t),await(async()=>{if(!T(z,w)){for(E(z,w,1);!e(b=c(T(O,w)));)try{await b()}catch(t){h?.(t)}E(z,w,0)}})(),tt),tt={load:W,startAutoLoad:async t=>{X(),await W(t);try{C=await l((async(t,e)=>{e||t?2!=B&&(U(1),F++,V(e??t),U(0)):await W()}))}catch(t){h?.(t)}return tt},stopAutoLoad:X,isAutoLoading:()=>!e(C),save:Y,startAutoSave:async()=>(Z(),await Y(),k=t.addDidFinishTransactionListener((()=>{const t=I();J(t)&&Y(t)})),tt),stopAutoSave:Z,isAutoSaving:()=>!e(k),getStatus:()=>B,addStatusListener:t=>N(t,$),delListener:e=>(R(e),t),schedule:_,getStore:()=>t,destroy:()=>(T(O,w).splice(0,void 0),X().stopAutoSave()),getStats:()=>({loads:F,saves:H}),...p};return g(tt)},B=(t,e)=>[t[e].t,t[e].v],F=(t,n,a,s)=>{const o=e(n)?t:C(t,n,(()=>({})));let r;return w(a,((t,e)=>{s(o,e,t)&&(r=1)})),w(o,((t,e)=>{p(a,e)||(v(o,e),r=1)})),!e(n)&&A(o)&&v(t,n),r};t.createAutomergePersister=(t,a,s="tinybase",o)=>(a.change((t=>C(t,s,h))),k(t,(async()=>{const t=await a.doc();return 2==b(t?.[s])?B(t,s):void 0}),(async(t,o)=>a.change((a=>((t,a,s,o)=>{((t,e)=>{A(t[e])&&(t[e]={t:{},v:{}})})(t,a);const[r,i]=B(t,a),c=()=>{d=1};let d=1;if(n(o,(([t,a])=>{d=0,w(t,((t,a)=>d?0:e(t)?v(r,a):n(r[a],(a=>w(t,((t,s)=>d?0:e(t)?v(a,s):n(f(a,s),(n=>w(t,((t,a)=>e(t)?v(n,a):n[a]=t))),c)))),c))),w(a,((t,n)=>d?0:e(t)?v(i,n):i[n]=t))})),d){const[t,e]=s();F(r,void 0,t,((t,e,n)=>F(r,e,n,((t,e,n)=>F(t,e,n,((t,e,n)=>{if(f(t,e)!==n)return t[e]=n,1})))))),F(i,void 0,e,((t,e,n)=>{f(i,e)!==n&&(i[e]=n)}))}})(a,s,t,o)))),(t=>{const e=({doc:e})=>t(B(e,s));return a.on("change",e),e}),(t=>{a.removeListener("change",t)}),o,1,{getDocHandle:()=>a}))},"object"==typeof exports&&"undefined"!=typeof module?e(exports):"function"==typeof define&&define.amd?define(["exports"],e):e((t="undefined"!=typeof globalThis?globalThis:t||self).TinyBasePersisterAutomerge={});
1
+ var t,e;t=this,e=function(t){"use strict";const e=t=>null==t,n=(t,n,a)=>e(t)?a?.():n(t),a=t=>Array.isArray(t),s=t=>t.length,o=t=>{throw Error(t)},r=(t,e)=>t.forEach(e),i=(t,...e)=>t.push(...e),c=t=>t.shift(),d=Object,u=t=>d.getPrototypeOf(t),l=d.entries,y=d.keys,g=d.freeze,h=(t=[])=>d.fromEntries(t),f=(t,e)=>n(t,(t=>t[e])),p=(t,e)=>e in t,v=(t,e)=>(delete t[e],t),w=(t,e)=>h(((t,e)=>((t,e)=>t.map(e))(l(t),(([t,n])=>e(n,t))))(t,((t,n)=>[n,e(t,n)]))),b=t=>s(y(t)),A=t=>(t=>!e(t)&&n(u(t),(t=>t==d.prototype||e(u(t))),(()=>!0)))(t)&&0==b(t),C=(t,e,n)=>(p(t,e)||(t[e]=n()),t[e]),S=t=>e(t)||0==(t=>t?.size??0)(t),L=(t,e)=>t?.forEach(e),m=(t,e)=>t?.delete(e),M=t=>new Map(t),T=(t,e)=>t?.get(e),E=(t,n,a)=>e(a)?(m(t,n),t):t?.set(n,a),P=(t,e,n,a)=>{var s,o;return s=t,o=e,s?.has(o)?a?.(T(t,e)):E(t,e,n()),T(t,e)},x=(t,e,a,o,r=0)=>n((a?P:T)(t,e[r],r>s(e)-2?a:M),(n=>{if(r>s(e)-2)return o?.(n)&&E(t,e[r]),n;const i=x(n,e,a,o,r+1);return S(n)&&E(t,e[r]),i})),D=t=>new Set(a(t)||e(t)?t:[t]),j=/^\d+$/,z=M(),O=M(),k=(t,d,u,l,y,h,f,p={},v=0,w=[])=>{let b,C,k,B=0,F=0,H=0;P(z,w,(()=>0)),P(O,w,(()=>[]));const $=M(),[q,G,I,J,K]=((t=1,e,n)=>1!=t&&e.isMergeable()?[1,e.getMergeableContent,()=>e.getTransactionMergeableChanges(!n),([[t],[e]])=>!A(t)||!A(e),e.setDefaultContent]:2!=t?[0,e.getContent,e.getTransactionChanges,([t,e])=>!A(t)||!A(e),e.setContent]:o("Store type not supported by this Persister"))(f,t,v),[N,Q,R]=(()=>{let t;const[a,o]=(()=>{const t=[];let e=0;return[n=>(n?c(t):null)??""+e++,e=>{j.test(e)&&s(t)<1e3&&i(t,e)}]})(),d=M();return[(e,n,s,o=[],r=()=>[])=>{t??=tt;const i=a(1);var c,u;return E(d,i,[e,n,s,o,r]),c=x(n,s??[""],D),u=i,c?.add(u),i},(e,n,...a)=>r(((t,e=[""])=>{const n=[],a=(t,o)=>o==s(e)?i(n,t):null===e[o]?L(t,(t=>a(t,o+1))):r([e[o],null],(e=>a(T(t,e),o+1)));return a(t,0),n})(e,n),(e=>L(e,(e=>T(d,e)[0](t,...n??[],...a))))),t=>n(T(d,t),(([,e,n])=>(x(e,n??[""],void 0,(e=>(m(e,t),S(e)?1:0))),E(d,t),o(t),n))),a=>n(T(d,a),(([n,,a=[],o,i])=>{const c=(...d)=>{const u=s(d);u==s(a)?n(t,...d,...i(d)):e(a[u])?r(o[u]?.(...d)??[],(t=>c(...d,t))):c(...d,a[u])};c()}))]})(),U=t=>{t!=B&&(B=t,Q($,void 0,B))},V=e=>{(q&&a(e?.[0])?1===e?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===e?.[2]?t.applyChanges:t.setContent)(e)},W=async t=>(2!=B&&(U(1),F++,await _((async()=>{try{const e=await d();a(e)?V(e):t?K(t):o("Content is not an array: "+e)}catch(e){h?.(e),t&&K(t)}U(0)}))),tt),X=()=>(C&&(y(C),C=void 0),tt),Y=async t=>(1!=B&&(U(2),H++,await _((async()=>{try{await u(G,t)}catch(t){h?.(t)}U(0)}))),tt),Z=()=>(k&&(t.delListener(k),k=void 0),tt),_=async(...t)=>(i(T(O,w),...t),await(async()=>{if(!T(z,w)){for(E(z,w,1);!e(b=c(T(O,w)));)try{await b()}catch(t){h?.(t)}E(z,w,0)}})(),tt),tt={load:W,startAutoLoad:async t=>{X(),await W(t);try{C=await l((async(t,e)=>{e||t?2!=B&&(U(1),F++,V(e??t),U(0)):await W()}))}catch(t){h?.(t)}return tt},stopAutoLoad:X,isAutoLoading:()=>!e(C),save:Y,startAutoSave:async()=>(Z(),await Y(),k=t.addDidFinishTransactionListener((()=>{const t=I();J(t)&&Y(t)})),tt),stopAutoSave:Z,isAutoSaving:()=>!e(k),getStatus:()=>B,addStatusListener:t=>N(t,$),delListener:e=>(R(e),t),schedule:_,getStore:()=>t,destroy:()=>(T(O,w).splice(0,void 0),X().stopAutoSave()),getStats:()=>({loads:F,saves:H}),...p};return g(tt)},B=(t,e)=>[t[e].t,t[e].v],F=(t,n,a,s)=>{const o=e(n)?t:C(t,n,(()=>({})));let r;return w(a,((t,e)=>{s(o,e,t)&&(r=1)})),w(o,((t,e)=>{p(a,e)||(v(o,e),r=1)})),!e(n)&&A(o)&&v(t,n),r};t.createAutomergePersister=(t,a,s="tinybase",o)=>(a.change((t=>C(t,s,h))),k(t,(async()=>{const t=await a.doc();return 2==b(t?.[s])?B(t,s):void 0}),(async(t,o)=>a.change((a=>((t,a,s,o)=>{((t,e)=>{A(t[e])&&(t[e]={t:{},v:{}})})(t,a);const[r,i]=B(t,a),c=()=>{d=1};let d=1;if(n(o,(([t,a])=>{d=0,w(t,((t,a)=>d?0:e(t)?v(r,a):n(r[a],(a=>w(t,((t,s)=>d?0:e(t)?v(a,s):n(f(a,s),(n=>w(t,((t,a)=>e(t)?v(n,a):n[a]=t))),c)))),c))),w(a,((t,n)=>d?0:e(t)?v(i,n):i[n]=t))})),d){const[t,e]=s();F(r,void 0,t,((t,e,n)=>F(r,e,n,((t,e,n)=>F(t,e,n,((t,e,n)=>{if(f(t,e)!==n)return t[e]=n,1})))))),F(i,void 0,e,((t,e,n)=>{f(i,e)!==n&&(i[e]=n)}))}})(a,s,t,o)))),(t=>{const e=({doc:e})=>t(B(e,s));return a.on("change",e),e}),(t=>{a.removeListener("change",t)}),o,1,{getDocHandle:()=>a}))},"object"==typeof exports&&"undefined"!=typeof module?e(exports):"function"==typeof define&&define.amd?define(["exports"],e):e((t="undefined"!=typeof globalThis?globalThis:t||self).TinyBasePersisterAutomerge={});
@@ -1 +1 @@
1
- var t,a;t=this,a=function(t){"use strict";const a=t=>typeof t,e="tinybase",n="",s=",",i=a(n),o=Promise,r=clearInterval,c=t=>null==t,l=(t,a,e)=>c(t)?e?.():a(t),u=t=>a(t)==i,y=t=>Array.isArray(t),d=(t,a,e)=>t.slice(a,e),w=t=>t.length,p=async t=>o.all(t),v=t=>{throw Error(t)},f=(t,a)=>t.forEach(a),E=(t,a="")=>t.join(a),g=(t,a)=>t.map(a),m=t=>0==w(t),h=(t,a)=>t.filter(a),A=(t,...a)=>t.push(...a),N=t=>t.shift(),S="_",T="_id",$="SELECT",C="WHERE",O="TABLE",b="ALTER "+O,I="DELETE FROM",L=$+"*FROM",D="pragma_",R="data_version",M="schema_version",P="pragma_table_",_=t=>`"${t.replace(/"/g,'""')}"`,F=(t,a=[1])=>E(g(t,(()=>"$"+a[0]++)),s),x=(t,a)=>t?.has(a)??!1,U=t=>c(t)||0==(t=>t?.size??0)(t),j=t=>[...t?.values()??[]],B=(t,a)=>t?.forEach(a),J=(t,a)=>t?.delete(a),W=Object,Y=t=>W.getPrototypeOf(t),k=W.entries,q=W.keys,z=W.freeze,G=(t=[])=>W.fromEntries(t),H=(...t)=>W.assign({},...t),K=(t,a)=>(delete t[a],t),Q=(t,a)=>g(k(t),(([t,e])=>a(e,t))),V=t=>W.values(t),X=t=>w(q(t)),Z=t=>(t=>!c(t)&&l(Y(t),(t=>t==W.prototype||c(Y(t))),(()=>!0)))(t)&&0==X(t),tt=JSON.stringify,at=JSON.parse,et=t=>new Map(t),nt=(t,a)=>t?.get(a),st=(t,a)=>g([...t?.entries()??[]],(([t,e])=>a(e,t))),it=(t,a,e)=>c(e)?(J(t,a),t):t?.set(a,e),ot=(t,a,e,n)=>(x(t,a)?n?.(nt(t,a)):it(t,a,e()),nt(t,a)),rt=(t,a,e,n,s=0)=>l((e?ot:nt)(t,a[s],s>w(a)-2?e:et),(i=>{if(s>w(a)-2)return n?.(i)&&it(t,a[s]),i;const o=rt(i,a,e,n,s+1);return U(i)&&it(t,a[s]),o})),ct=t=>new Set(y(t)||c(t)?t:[t]),lt=(t,a)=>t?.add(a),ut=/^\d+$/,yt=et(),dt=et(),wt=(t,a,e,s,i,o,r,u={},d=0,p=[])=>{let E,g,m,h=0,S=0,T=0;ot(yt,p,(()=>0)),ot(dt,p,(()=>[]));const $=et(),[C,O,b,I,L]=((t=1,a,e)=>1!=t&&a.isMergeable()?[1,a.getMergeableContent,()=>a.getTransactionMergeableChanges(!e),([[t],[a]])=>!Z(t)||!Z(a),a.setDefaultContent]:2!=t?[0,a.getContent,a.getTransactionChanges,([t,a])=>!Z(t)||!Z(a),a.setContent]:v("Store type not supported by this Persister"))(r,t,d),[D,R,M]=(()=>{let t;const[a,e]=(()=>{const t=[];let a=0;return[e=>(e?N(t):null)??n+a++,a=>{ut.test(a)&&w(t)<1e3&&A(t,a)}]})(),s=et();return[(e,i,o,r=[],c=()=>[])=>{t??=k;const l=a(1);return it(s,l,[e,i,o,r,c]),lt(rt(i,o??[n],ct),l),l},(a,e,...i)=>f(((t,a=[n])=>{const e=[],s=(t,n)=>n==w(a)?A(e,t):null===a[n]?B(t,(t=>s(t,n+1))):f([a[n],null],(a=>s(nt(t,a),n+1)));return s(t,0),e})(a,e),(a=>B(a,(a=>nt(s,a)[0](t,...e??[],...i))))),t=>l(nt(s,t),(([,a,i])=>(rt(a,i??[n],void 0,(a=>(J(a,t),U(a)?1:0))),it(s,t),e(t),i))),a=>l(nt(s,a),(([a,,e=[],n,s])=>{const i=(...o)=>{const r=w(o);r==w(e)?a(t,...o,...s(o)):c(e[r])?f(n[r]?.(...o)??[],(t=>i(...o,t))):i(...o,e[r])};i()}))]})(),P=t=>{t!=h&&(h=t,R($,void 0,h))},_=a=>{(C&&y(a?.[0])?1===a?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===a?.[2]?t.applyChanges:t.setContent)(a)},F=async t=>(2!=h&&(P(1),S++,await Y((async()=>{try{const e=await a();y(e)?_(e):t?L(t):v("Content is not an array: "+e)}catch(a){o?.(a),t&&L(t)}P(0)}))),k),x=()=>(g&&(i(g),g=void 0),k),j=async t=>(1!=h&&(P(2),T++,await Y((async()=>{try{await e(O,t)}catch(t){o?.(t)}P(0)}))),k),W=()=>(m&&(t.delListener(m),m=void 0),k),Y=async(...t)=>(A(nt(dt,p),...t),await(async()=>{if(!nt(yt,p)){for(it(yt,p,1);!c(E=N(nt(dt,p)));)try{await E()}catch(t){o?.(t)}it(yt,p,0)}})(),k),k={load:F,startAutoLoad:async t=>{x(),await F(t);try{g=await s((async(t,a)=>{a||t?2!=h&&(P(1),S++,_(a??t),P(0)):await F()}))}catch(t){o?.(t)}return k},stopAutoLoad:x,isAutoLoading:()=>!c(g),save:j,startAutoSave:async()=>(W(),await j(),m=t.addDidFinishTransactionListener((()=>{const t=b();I(t)&&j(t)})),k),stopAutoSave:W,isAutoSaving:()=>!c(m),getStatus:()=>h,addStatusListener:t=>D(t,$),delListener:a=>(M(a),t),schedule:Y,getStore:()=>t,destroy:()=>(nt(dt,p).splice(0,void 0),x().stopAutoSave()),getStats:()=>({loads:S,saves:T}),...u};return z(k)},pt=(t,a,e,n,i,o=vt,r,l)=>{const u=et();return[async()=>{u.clear(),g(await e(t,a),(({tn:t,cn:a})=>lt(ot(u,t,ct),a)))},async(a,e)=>((t,a)=>x(nt(u,t),a))(a,e)?G(h(g(await t(L+_(a)),(t=>{return[t[e],l?(a=K(t,e),n=l,G(Q(a,((t,a)=>[a,n(t,a)])))):K(t,e)];var a,n})),(([t,a])=>!c(t)&&!Z(a)))):{},async(a,e,n,l,y,d=!1)=>{const w=ct();Q(n??{},(t=>g(q(t??{}),(t=>lt(w,t)))));const v=j(w);if(!d&&y&&m(v)&&x(u,a))return await t("DROP "+O+_(a)),void it(u,a);const f=nt(u,a),N=ct(j(f));if(m(v)||(x(u,a)?await p(g([e,...v],(async(n,s)=>{J(N,n)||(await t(b+_(a)+"ADD"+_(n)+i),0==s&&await t("CREATE UNIQUE INDEX pk ON "+_(a)+`(${_(e)})`),lt(f,n))}))):(await t("CREATE "+O+_(a)+`(${_(e)}${i} PRIMARY KEY${E(g(v,(t=>s+_(t)+i)))});`),it(u,a,ct([e,...v])))),await p([...!d&&l?g(j(N),(async n=>{n!=e&&(await t(b+_(a)+"DROP"+_(n)),J(f,n))})):[]]),d)c(n)?await t(I+_(a)+C+" true"):await p(Q(n,(async(n,s)=>{c(n)?await t(I+_(a)+C+_(e)+"=$1",[s]):m(v)||await o(t,a,e,q(n),{[s]:r?g(V(n),r):V(n)},f)})));else if(m(v))x(u,a)&&await t(I+_(a)+C+" true");else{const s=h(j(nt(u,a)),(t=>t!=e)),i={},c=[];Q(n??{},((t,a)=>{i[a]=g(s,(a=>r?r(t?.[a]):t?.[a])),A(c,a)})),await o(t,a,e,s,i),await t(I+_(a)+C+_(e)+`NOT IN(${F(c)})`,c)}},async a=>{let e;await t("BEGIN");try{e=await a()}catch(t){n?.(t)}return await t("END"),e}]},vt=async(t,a,e,n,i)=>{const o=[1];await t("INSERT INTO"+_(a)+"("+((...t)=>E(g(t,_),s))(e,...n)+")VALUES"+E(Q(i,(t=>"($"+o[0]+++","+F(t,o)+")")),s)+"ON CONFLICT("+_(e)+")DO UPDATE SET"+E(g(n,(t=>_(t)+"=excluded."+_(t))),s),Q(i,((t,a)=>[a,...g(t,(t=>t??null))])).flat())},ft=(t,a,e,n,s,i,o,[r,c,l],u,y,d,w,p,v)=>{const[f,E,g,m]=pt(a,u,y,s,p,v),h=wt(t,(async()=>await m((async()=>{return await f(),t=(await E(r,c))[S]?.[l]??"null",at(t,((t,a)=>""===a?void 0:a));var t}))),(async t=>await m((async()=>{var a;await f(),await g(r,c,{[S]:{[l]:(a=t()??null,tt(a,((t,a)=>void 0===a?"":a)))}},!0,!0)}))),e,n,s,o,{[w]:()=>d,destroy:()=>(h.stopAutoLoad().stopAutoSave(),i(),h)},0,d);return h},Et=(t,a,e,n,s,i,o,[r,l,[u,y,d]],w,v,f,E,g,m,A,N)=>{const[$,C,O,b]=pt(a,w,v,s,g,m,A,N),I=async(t,a)=>await p(st(l,(async([e,n,s,i],o)=>{a&&!(o in t)||await O(e,n,t[o],s,i,a)}))),L=async(t,a)=>y?await O(d,T,{[S]:t},!0,!0,a):null,D=wt(t,(async()=>await b((async()=>{await $();const t=await(async()=>G(h(await p(st(r,(async([t,a],e)=>[t,await C(e,a)]))),(t=>!Z(t[1])))))(),a=await(async()=>u?(await C(d,T))[S]:{})();return Z(t)&&c(a)?void 0:[t,a]}))),(async(t,a)=>await b((async()=>{if(await $(),c(a)){const[a,e]=t();await I(a),await L(e)}else await I(a[0],!0),await L(a[1],!0)}))),e,n,s,o,{[E]:()=>f,destroy:()=>(D.stopAutoLoad().stopAutoSave(),i(),D)},0,f);return D},gt="ColumnName",mt="store",ht="json",At=mt+"TableName",Nt=mt+"Id"+gt,St=mt+gt,Tt="autoLoadIntervalSeconds",$t="rowId"+gt,Ct="tableId",Ot="tableName",bt="deleteEmptyColumns",It="deleteEmptyTable",Lt={mode:ht,[Tt]:1},Dt={load:0,save:0,[Ot]:e+"_values"},Rt=(t,a,e,n,s)=>{const i=et();return Q(t,((t,o)=>{const r=d(V(H(a,u(t)?{[e]:t}:t)),0,X(a));c(r[0])||n(o,r[0])||(s(o,r[0]),it(i,o,r))})),i},Mt=(t,a,s,i,o,c,l,y,w,p,v="getDb",f)=>{let E,g,m;const h=((t,a)=>a?async(e,n)=>(a(e,n),await t(e,n)):t)(s,c),[A,N,S,O]=(t=>{const a=(t=>H(Lt,u(t)?{[At]:t}:t??{}))(t),n=a[Tt];if(a.mode==ht){const t=a[At]??e;return[1,n,[t,a[Nt]??T,a[St]??mt],ct(t)]}const{tables:{load:s={},save:i={}}={},values:o={}}=a,r=d(V(H(Dt,o)),0,X(Dt)),c=r[2],l=ct(c),y=ct(c);return[0,n,[Rt(s,{[Ct]:null,[$t]:T},Ct,(t=>x(y,t)),(t=>lt(l,t))),Rt(i,{[Ot]:null,[$t]:T,[bt]:0,[It]:0},Ot,((t,a)=>x(y,a)),((t,a)=>lt(l,a))),r],l]})(a);return(A?ft:Et)(t,h,(t=>{let a;const e=()=>a=setInterval((async()=>{try{const[{d:a,s:e,c:n}]=await h(`${$} ${R} d,${M} s,TOTAL_CHANGES() c FROM ${D}${R} JOIN ${D}${M}`);a==E&&e==g&&n==m||(null!=E&&t(),E=a,g=e,m=n)}catch{}}),1e3*N),n=()=>{E=g=m=null,r(a)},s=i((a=>{O.has(a)&&(n(),t(),e())}));return e(),()=>{n(),o(s)}}),(t=>t()),l,y,w,S,j(O),(async(t,a)=>await t(`${$} t.name tn,c.name cn FROM ${P}list()t,${P}info(t.name)c ${C} t.schema='main'AND t.type IN('table','view')AND t.name IN(${F(a)})ORDER BY t.name,c.name`,a)),p,v,n,f,(t=>!0===t?1:!1===t?0:t),void 0)};t.createCrSqliteWasmPersister=(t,a,e,n,s)=>Mt(t,e,(async(t,e=[])=>await a.execO(t,e)),(t=>a.onUpdate(((a,e,n)=>t(n)))),(t=>t()),n,s,(()=>0),1,a)},"object"==typeof exports&&"undefined"!=typeof module?a(exports):"function"==typeof define&&define.amd?define(["exports"],a):a((t="undefined"!=typeof globalThis?globalThis:t||self).TinyBasePersisterCrSqliteWasm={});
1
+ var t,a;t=this,a=function(t){"use strict";const a=t=>typeof t,e="tinybase",n="",s=",",i=a(n),o=Promise,r=clearInterval,c=t=>null==t,l=(t,a,e)=>c(t)?e?.():a(t),y=t=>a(t)==i,u=t=>Array.isArray(t),d=(t,a,e)=>t.slice(a,e),w=t=>t.length,p=async t=>o.all(t),v=t=>{throw Error(t)},f=(t,a)=>t.forEach(a),E=(t,a="")=>t.join(a),g=(t,a)=>t.map(a),m=t=>0==w(t),h=(t,a)=>t.filter(a),A=(t,...a)=>t.push(...a),N=t=>t.shift(),S="_",T="_id",$="SELECT",C="WHERE",O="TABLE",b="ALTER "+O,I="DELETE FROM",L=$+"*FROM",D="pragma_",R="data_version",M="schema_version",P="pragma_table_",_=t=>`"${t.replace(/"/g,'""')}"`,F=(t,a=[1])=>E(g(t,(()=>"$"+a[0]++)),s),x=(t,a)=>t?.has(a)??!1,U=t=>c(t)||0==(t=>t?.size??0)(t),j=t=>[...t?.values()??[]],B=(t,a)=>t?.forEach(a),J=(t,a)=>t?.delete(a),W=Object,Y=t=>W.getPrototypeOf(t),k=W.entries,q=W.keys,z=W.freeze,G=(t=[])=>W.fromEntries(t),H=(...t)=>W.assign({},...t),K=(t,a)=>(delete t[a],t),Q=(t,a)=>g(k(t),(([t,e])=>a(e,t))),V=(t,a)=>G(Q(t,((t,e)=>[e,a(t,e)]))),X=t=>W.values(t),Z=t=>w(q(t)),tt=t=>(t=>!c(t)&&l(Y(t),(t=>t==W.prototype||c(Y(t))),(()=>!0)))(t)&&0==Z(t),at=JSON.stringify,et=JSON.parse,nt=t=>new Map(t),st=(t,a)=>t?.get(a),it=(t,a)=>g([...t?.entries()??[]],(([t,e])=>a(e,t))),ot=(t,a,e)=>c(e)?(J(t,a),t):t?.set(a,e),rt=(t,a,e,n)=>(x(t,a)?n?.(st(t,a)):ot(t,a,e()),st(t,a)),ct=(t,a,e,n,s=0)=>l((e?rt:st)(t,a[s],s>w(a)-2?e:nt),(i=>{if(s>w(a)-2)return n?.(i)&&ot(t,a[s]),i;const o=ct(i,a,e,n,s+1);return U(i)&&ot(t,a[s]),o})),lt=t=>new Set(u(t)||c(t)?t:[t]),yt=(t,a)=>t?.add(a),ut=/^\d+$/,dt=nt(),wt=nt(),pt=(t,a,e,s,i,o,r,y={},d=0,p=[])=>{let E,g,m,h=0,S=0,T=0;rt(dt,p,(()=>0)),rt(wt,p,(()=>[]));const $=nt(),[C,O,b,I,L]=((t=1,a,e)=>1!=t&&a.isMergeable()?[1,a.getMergeableContent,()=>a.getTransactionMergeableChanges(!e),([[t],[a]])=>!tt(t)||!tt(a),a.setDefaultContent]:2!=t?[0,a.getContent,a.getTransactionChanges,([t,a])=>!tt(t)||!tt(a),a.setContent]:v("Store type not supported by this Persister"))(r,t,d),[D,R,M]=(()=>{let t;const[a,e]=(()=>{const t=[];let a=0;return[e=>(e?N(t):null)??n+a++,a=>{ut.test(a)&&w(t)<1e3&&A(t,a)}]})(),s=nt();return[(e,i,o,r=[],c=()=>[])=>{t??=k;const l=a(1);return ot(s,l,[e,i,o,r,c]),yt(ct(i,o??[n],lt),l),l},(a,e,...i)=>f(((t,a=[n])=>{const e=[],s=(t,n)=>n==w(a)?A(e,t):null===a[n]?B(t,(t=>s(t,n+1))):f([a[n],null],(a=>s(st(t,a),n+1)));return s(t,0),e})(a,e),(a=>B(a,(a=>st(s,a)[0](t,...e??[],...i))))),t=>l(st(s,t),(([,a,i])=>(ct(a,i??[n],void 0,(a=>(J(a,t),U(a)?1:0))),ot(s,t),e(t),i))),a=>l(st(s,a),(([a,,e=[],n,s])=>{const i=(...o)=>{const r=w(o);r==w(e)?a(t,...o,...s(o)):c(e[r])?f(n[r]?.(...o)??[],(t=>i(...o,t))):i(...o,e[r])};i()}))]})(),P=t=>{t!=h&&(h=t,R($,void 0,h))},_=a=>{(C&&u(a?.[0])?1===a?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===a?.[2]?t.applyChanges:t.setContent)(a)},F=async t=>(2!=h&&(P(1),S++,await Y((async()=>{try{const e=await a();u(e)?_(e):t?L(t):v("Content is not an array: "+e)}catch(a){o?.(a),t&&L(t)}P(0)}))),k),x=()=>(g&&(i(g),g=void 0),k),j=async t=>(1!=h&&(P(2),T++,await Y((async()=>{try{await e(O,t)}catch(t){o?.(t)}P(0)}))),k),W=()=>(m&&(t.delListener(m),m=void 0),k),Y=async(...t)=>(A(st(wt,p),...t),await(async()=>{if(!st(dt,p)){for(ot(dt,p,1);!c(E=N(st(wt,p)));)try{await E()}catch(t){o?.(t)}ot(dt,p,0)}})(),k),k={load:F,startAutoLoad:async t=>{x(),await F(t);try{g=await s((async(t,a)=>{a||t?2!=h&&(P(1),S++,_(a??t),P(0)):await F()}))}catch(t){o?.(t)}return k},stopAutoLoad:x,isAutoLoading:()=>!c(g),save:j,startAutoSave:async()=>(W(),await j(),m=t.addDidFinishTransactionListener((()=>{const t=b();I(t)&&j(t)})),k),stopAutoSave:W,isAutoSaving:()=>!c(m),getStatus:()=>h,addStatusListener:t=>D(t,$),delListener:a=>(M(a),t),schedule:Y,getStore:()=>t,destroy:()=>(st(wt,p).splice(0,void 0),x().stopAutoSave()),getStats:()=>({loads:S,saves:T}),...y};return z(k)},vt=(t,a,e,n,i,o=ft,r,l)=>{const y=nt();return[async()=>{y.clear(),g(await e(t,a),(({tn:t,cn:a})=>yt(rt(y,t,lt),a)))},async(a,e)=>((t,a)=>x(st(y,t),a))(a,e)?G(h(g(await t(L+_(a)),(t=>[t[e],l?V(K(t,e),l):K(t,e)])),(([t,a])=>!c(t)&&!tt(a)))):{},async(a,e,n,l,u,d=!1)=>{const w=lt();V(n??{},(t=>g(q(t??{}),(t=>yt(w,t)))));const v=j(w);if(!d&&u&&m(v)&&x(y,a))return await t("DROP "+O+_(a)),void ot(y,a);const f=st(y,a),N=lt(j(f));if(m(v)||(x(y,a)?await p(g([e,...v],(async(n,s)=>{J(N,n)||(await t(b+_(a)+"ADD"+_(n)+i),0==s&&await t("CREATE UNIQUE INDEX pk ON "+_(a)+`(${_(e)})`),yt(f,n))}))):(await t("CREATE "+O+_(a)+`(${_(e)}${i} PRIMARY KEY${E(g(v,(t=>s+_(t)+i)))});`),ot(y,a,lt([e,...v])))),await p([...!d&&l?g(j(N),(async n=>{n!=e&&(await t(b+_(a)+"DROP"+_(n)),J(f,n))})):[]]),d)c(n)?await t(I+_(a)+C+" true"):await p(Q(n,(async(n,s)=>{c(n)?await t(I+_(a)+C+_(e)+"=$1",[s]):m(v)||await o(t,a,e,q(n),{[s]:r?g(X(n),r):X(n)},f)})));else if(m(v))x(y,a)&&await t(I+_(a)+C+" true");else{const s=h(j(st(y,a)),(t=>t!=e)),i={},c=[];V(n??{},((t,a)=>{i[a]=g(s,(a=>r?r(t?.[a]):t?.[a])),A(c,a)})),await o(t,a,e,s,i),await t(I+_(a)+C+_(e)+`NOT IN(${F(c)})`,c)}},async a=>{let e;await t("BEGIN");try{e=await a()}catch(t){n?.(t)}return await t("END"),e}]},ft=async(t,a,e,n,i)=>{const o=[1];await t("INSERT INTO"+_(a)+"("+((...t)=>E(g(t,_),s))(e,...n)+")VALUES"+E(Q(i,(t=>"($"+o[0]+++","+F(t,o)+")")),s)+"ON CONFLICT("+_(e)+")DO UPDATE SET"+E(g(n,(t=>_(t)+"=excluded."+_(t))),s),Q(i,((t,a)=>[a,...g(t,(t=>t??null))])).flat())},Et=(t,a,e,n,s,i,o,[r,c,l],y,u,d,w,p,v)=>{const[f,E,g,m]=vt(a,y,u,s,p,v),h=pt(t,(async()=>await m((async()=>{return await f(),t=(await E(r,c))[S]?.[l]??"null",et(t,((t,a)=>""===a?void 0:a));var t}))),(async t=>await m((async()=>{var a;await f(),await g(r,c,{[S]:{[l]:(a=t()??null,at(a,((t,a)=>void 0===a?"":a)))}},!0,!0)}))),e,n,s,o,{[w]:()=>d,destroy:()=>(h.stopAutoLoad().stopAutoSave(),i(),h)},0,d);return h},gt=(t,a,e,n,s,i,o,[r,l,[y,u,d]],w,v,f,E,g,m,A,N)=>{const[$,C,O,b]=vt(a,w,v,s,g,m,A,N),I=async(t,a)=>await p(it(l,(async([e,n,s,i],o)=>{a&&!(o in t)||await O(e,n,t[o],s,i,a)}))),L=async(t,a)=>u?await O(d,T,{[S]:t},!0,!0,a):null,D=pt(t,(async()=>await b((async()=>{await $();const t=await(async()=>G(h(await p(it(r,(async([t,a],e)=>[t,await C(e,a)]))),(t=>!tt(t[1])))))(),a=await(async()=>y?(await C(d,T))[S]:{})();return tt(t)&&c(a)?void 0:[t,a]}))),(async(t,a)=>await b((async()=>{if(await $(),c(a)){const[a,e]=t();await I(a),await L(e)}else await I(a[0],!0),await L(a[1],!0)}))),e,n,s,o,{[E]:()=>f,destroy:()=>(D.stopAutoLoad().stopAutoSave(),i(),D)},0,f);return D},mt="ColumnName",ht="store",At="json",Nt=ht+"TableName",St=ht+"Id"+mt,Tt=ht+mt,$t="autoLoadIntervalSeconds",Ct="rowId"+mt,Ot="tableId",bt="tableName",It="deleteEmptyColumns",Lt="deleteEmptyTable",Dt={mode:At,[$t]:1},Rt={load:0,save:0,[bt]:e+"_values"},Mt=(t,a,e,n,s)=>{const i=nt();return V(t,((t,o)=>{const r=d(X(H(a,y(t)?{[e]:t}:t)),0,Z(a));c(r[0])||n(o,r[0])||(s(o,r[0]),ot(i,o,r))})),i},Pt=(t,a,s,i,o,c,l,u,w,p,v="getDb",f)=>{let E,g,m;const h=((t,a)=>a?async(e,n)=>(a(e,n),await t(e,n)):t)(s,c),[A,N,S,O]=(t=>{const a=(t=>H(Dt,y(t)?{[Nt]:t}:t??{}))(t),n=a[$t];if(a.mode==At){const t=a[Nt]??e;return[1,n,[t,a[St]??T,a[Tt]??ht],lt(t)]}const{tables:{load:s={},save:i={}}={},values:o={}}=a,r=d(X(H(Rt,o)),0,Z(Rt)),c=r[2],l=lt(c),u=lt(c);return[0,n,[Mt(s,{[Ot]:null,[Ct]:T},Ot,(t=>x(u,t)),(t=>yt(l,t))),Mt(i,{[bt]:null,[Ct]:T,[It]:0,[Lt]:0},bt,((t,a)=>x(u,a)),((t,a)=>yt(l,a))),r],l]})(a);return(A?Et:gt)(t,h,(t=>{let a;const e=()=>a=setInterval((async()=>{try{const[{d:a,s:e,c:n}]=await h(`${$} ${R} d,${M} s,TOTAL_CHANGES() c FROM ${D}${R} JOIN ${D}${M}`);a==E&&e==g&&n==m||(null!=E&&t(),E=a,g=e,m=n)}catch{}}),1e3*N),n=()=>{E=g=m=null,r(a)},s=i((a=>{O.has(a)&&(n(),t(),e())}));return e(),()=>{n(),o(s)}}),(t=>t()),l,u,w,S,j(O),(async(t,a)=>await t(`${$} t.name tn,c.name cn FROM ${P}list()t,${P}info(t.name)c ${C} t.schema='main'AND t.type IN('table','view')AND t.name IN(${F(a)})ORDER BY t.name,c.name`,a)),p,v,n,f,(t=>!0===t?1:!1===t?0:t),void 0)};t.createCrSqliteWasmPersister=(t,a,e,n,s)=>Pt(t,e,(async(t,e=[])=>await a.execO(t,e)),(t=>a.onUpdate(((a,e,n)=>t(n)))),(t=>t()),n,s,(()=>0),1,a)},"object"==typeof exports&&"undefined"!=typeof module?a(exports):"function"==typeof define&&define.amd?define(["exports"],a):a((t="undefined"!=typeof globalThis?globalThis:t||self).TinyBasePersisterCrSqliteWasm={});
@@ -1 +1 @@
1
- var t,a;t=this,a=function(t){"use strict";const a=t=>typeof t,e="tinybase",n="",s=",",i=a(n),o=Promise,r=clearInterval,c=t=>null==t,l=(t,a,e)=>c(t)?e?.():a(t),u=t=>a(t)==i,y=t=>Array.isArray(t),d=(t,a,e)=>t.slice(a,e),w=t=>t.length,p=async t=>o.all(t),v=t=>{throw Error(t)},f=(t,a)=>t.forEach(a),E=(t,a="")=>t.join(a),g=(t,a)=>t.map(a),m=t=>0==w(t),h=(t,a)=>t.filter(a),A=(t,...a)=>t.push(...a),N=t=>t.shift(),S="_",T="_id",$="SELECT",C="WHERE",O="TABLE",b="ALTER "+O,I="DELETE FROM",L=$+"*FROM",D="pragma_",R="data_version",M="schema_version",P="pragma_table_",_=t=>`"${t.replace(/"/g,'""')}"`,F=(t,a=[1])=>E(g(t,(()=>"$"+a[0]++)),s),x=(t,a)=>t?.has(a)??!1,U=t=>c(t)||0==(t=>t?.size??0)(t),j=t=>[...t?.values()??[]],B=(t,a)=>t?.forEach(a),J=(t,a)=>t?.delete(a),W=Object,Y=t=>W.getPrototypeOf(t),k=W.entries,q=W.keys,z=W.freeze,G=(t=[])=>W.fromEntries(t),H=(...t)=>W.assign({},...t),K=(t,a)=>(delete t[a],t),Q=(t,a)=>g(k(t),(([t,e])=>a(e,t))),V=t=>W.values(t),X=t=>w(q(t)),Z=t=>(t=>!c(t)&&l(Y(t),(t=>t==W.prototype||c(Y(t))),(()=>!0)))(t)&&0==X(t),tt=JSON.stringify,at=JSON.parse,et=t=>new Map(t),nt=(t,a)=>t?.get(a),st=(t,a)=>g([...t?.entries()??[]],(([t,e])=>a(e,t))),it=(t,a,e)=>c(e)?(J(t,a),t):t?.set(a,e),ot=(t,a,e,n)=>(x(t,a)?n?.(nt(t,a)):it(t,a,e()),nt(t,a)),rt=(t,a,e,n,s=0)=>l((e?ot:nt)(t,a[s],s>w(a)-2?e:et),(i=>{if(s>w(a)-2)return n?.(i)&&it(t,a[s]),i;const o=rt(i,a,e,n,s+1);return U(i)&&it(t,a[s]),o})),ct=t=>new Set(y(t)||c(t)?t:[t]),lt=(t,a)=>t?.add(a),ut=/^\d+$/,yt=et(),dt=et(),wt=(t,a,e,s,i,o,r,u={},d=0,p=[])=>{let E,g,m,h=0,S=0,T=0;ot(yt,p,(()=>0)),ot(dt,p,(()=>[]));const $=et(),[C,O,b,I,L]=((t=1,a,e)=>1!=t&&a.isMergeable()?[1,a.getMergeableContent,()=>a.getTransactionMergeableChanges(!e),([[t],[a]])=>!Z(t)||!Z(a),a.setDefaultContent]:2!=t?[0,a.getContent,a.getTransactionChanges,([t,a])=>!Z(t)||!Z(a),a.setContent]:v("Store type not supported by this Persister"))(r,t,d),[D,R,M]=(()=>{let t;const[a,e]=(()=>{const t=[];let a=0;return[e=>(e?N(t):null)??n+a++,a=>{ut.test(a)&&w(t)<1e3&&A(t,a)}]})(),s=et();return[(e,i,o,r=[],c=()=>[])=>{t??=k;const l=a(1);return it(s,l,[e,i,o,r,c]),lt(rt(i,o??[n],ct),l),l},(a,e,...i)=>f(((t,a=[n])=>{const e=[],s=(t,n)=>n==w(a)?A(e,t):null===a[n]?B(t,(t=>s(t,n+1))):f([a[n],null],(a=>s(nt(t,a),n+1)));return s(t,0),e})(a,e),(a=>B(a,(a=>nt(s,a)[0](t,...e??[],...i))))),t=>l(nt(s,t),(([,a,i])=>(rt(a,i??[n],void 0,(a=>(J(a,t),U(a)?1:0))),it(s,t),e(t),i))),a=>l(nt(s,a),(([a,,e=[],n,s])=>{const i=(...o)=>{const r=w(o);r==w(e)?a(t,...o,...s(o)):c(e[r])?f(n[r]?.(...o)??[],(t=>i(...o,t))):i(...o,e[r])};i()}))]})(),P=t=>{t!=h&&(h=t,R($,void 0,h))},_=a=>{(C&&y(a?.[0])?1===a?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===a?.[2]?t.applyChanges:t.setContent)(a)},F=async t=>(2!=h&&(P(1),S++,await Y((async()=>{try{const e=await a();y(e)?_(e):t?L(t):v("Content is not an array: "+e)}catch(a){o?.(a),t&&L(t)}P(0)}))),k),x=()=>(g&&(i(g),g=void 0),k),j=async t=>(1!=h&&(P(2),T++,await Y((async()=>{try{await e(O,t)}catch(t){o?.(t)}P(0)}))),k),W=()=>(m&&(t.delListener(m),m=void 0),k),Y=async(...t)=>(A(nt(dt,p),...t),await(async()=>{if(!nt(yt,p)){for(it(yt,p,1);!c(E=N(nt(dt,p)));)try{await E()}catch(t){o?.(t)}it(yt,p,0)}})(),k),k={load:F,startAutoLoad:async t=>{x(),await F(t);try{g=await s((async(t,a)=>{a||t?2!=h&&(P(1),S++,_(a??t),P(0)):await F()}))}catch(t){o?.(t)}return k},stopAutoLoad:x,isAutoLoading:()=>!c(g),save:j,startAutoSave:async()=>(W(),await j(),m=t.addDidFinishTransactionListener((()=>{const t=b();I(t)&&j(t)})),k),stopAutoSave:W,isAutoSaving:()=>!c(m),getStatus:()=>h,addStatusListener:t=>D(t,$),delListener:a=>(M(a),t),schedule:Y,getStore:()=>t,destroy:()=>(nt(dt,p).splice(0,void 0),x().stopAutoSave()),getStats:()=>({loads:S,saves:T}),...u};return z(k)},pt=(t,a,e,n,i,o=vt,r,l)=>{const u=et();return[async()=>{u.clear(),g(await e(t,a),(({tn:t,cn:a})=>lt(ot(u,t,ct),a)))},async(a,e)=>((t,a)=>x(nt(u,t),a))(a,e)?G(h(g(await t(L+_(a)),(t=>{return[t[e],l?(a=K(t,e),n=l,G(Q(a,((t,a)=>[a,n(t,a)])))):K(t,e)];var a,n})),(([t,a])=>!c(t)&&!Z(a)))):{},async(a,e,n,l,y,d=!1)=>{const w=ct();Q(n??{},(t=>g(q(t??{}),(t=>lt(w,t)))));const v=j(w);if(!d&&y&&m(v)&&x(u,a))return await t("DROP "+O+_(a)),void it(u,a);const f=nt(u,a),N=ct(j(f));if(m(v)||(x(u,a)?await p(g([e,...v],(async(n,s)=>{J(N,n)||(await t(b+_(a)+"ADD"+_(n)+i),0==s&&await t("CREATE UNIQUE INDEX pk ON "+_(a)+`(${_(e)})`),lt(f,n))}))):(await t("CREATE "+O+_(a)+`(${_(e)}${i} PRIMARY KEY${E(g(v,(t=>s+_(t)+i)))});`),it(u,a,ct([e,...v])))),await p([...!d&&l?g(j(N),(async n=>{n!=e&&(await t(b+_(a)+"DROP"+_(n)),J(f,n))})):[]]),d)c(n)?await t(I+_(a)+C+" true"):await p(Q(n,(async(n,s)=>{c(n)?await t(I+_(a)+C+_(e)+"=$1",[s]):m(v)||await o(t,a,e,q(n),{[s]:r?g(V(n),r):V(n)},f)})));else if(m(v))x(u,a)&&await t(I+_(a)+C+" true");else{const s=h(j(nt(u,a)),(t=>t!=e)),i={},c=[];Q(n??{},((t,a)=>{i[a]=g(s,(a=>r?r(t?.[a]):t?.[a])),A(c,a)})),await o(t,a,e,s,i),await t(I+_(a)+C+_(e)+`NOT IN(${F(c)})`,c)}},async a=>{let e;await t("BEGIN");try{e=await a()}catch(t){n?.(t)}return await t("END"),e}]},vt=async(t,a,e,n,i)=>{const o=[1];await t("INSERT INTO"+_(a)+"("+((...t)=>E(g(t,_),s))(e,...n)+")VALUES"+E(Q(i,(t=>"($"+o[0]+++","+F(t,o)+")")),s)+"ON CONFLICT("+_(e)+")DO UPDATE SET"+E(g(n,(t=>_(t)+"=excluded."+_(t))),s),Q(i,((t,a)=>[a,...g(t,(t=>t??null))])).flat())},ft=(t,a,e,n,s,i,o,[r,c,l],u,y,d,w,p,v)=>{const[f,E,g,m]=pt(a,u,y,s,p,v),h=wt(t,(async()=>await m((async()=>{return await f(),t=(await E(r,c))[S]?.[l]??"null",at(t,((t,a)=>""===a?void 0:a));var t}))),(async t=>await m((async()=>{var a;await f(),await g(r,c,{[S]:{[l]:(a=t()??null,tt(a,((t,a)=>void 0===a?"":a)))}},!0,!0)}))),e,n,s,o,{[w]:()=>d,destroy:()=>(h.stopAutoLoad().stopAutoSave(),i(),h)},0,d);return h},Et=(t,a,e,n,s,i,o,[r,l,[u,y,d]],w,v,f,E,g,m,A,N)=>{const[$,C,O,b]=pt(a,w,v,s,g,m,A,N),I=async(t,a)=>await p(st(l,(async([e,n,s,i],o)=>{a&&!(o in t)||await O(e,n,t[o],s,i,a)}))),L=async(t,a)=>y?await O(d,T,{[S]:t},!0,!0,a):null,D=wt(t,(async()=>await b((async()=>{await $();const t=await(async()=>G(h(await p(st(r,(async([t,a],e)=>[t,await C(e,a)]))),(t=>!Z(t[1])))))(),a=await(async()=>u?(await C(d,T))[S]:{})();return Z(t)&&c(a)?void 0:[t,a]}))),(async(t,a)=>await b((async()=>{if(await $(),c(a)){const[a,e]=t();await I(a),await L(e)}else await I(a[0],!0),await L(a[1],!0)}))),e,n,s,o,{[E]:()=>f,destroy:()=>(D.stopAutoLoad().stopAutoSave(),i(),D)},0,f);return D},gt="ColumnName",mt="store",ht="json",At=mt+"TableName",Nt=mt+"Id"+gt,St=mt+gt,Tt="autoLoadIntervalSeconds",$t="rowId"+gt,Ct="tableId",Ot="tableName",bt="deleteEmptyColumns",It="deleteEmptyTable",Lt={mode:ht,[Tt]:1},Dt={load:0,save:0,[Ot]:e+"_values"},Rt=(t,a,e,n,s)=>{const i=et();return Q(t,((t,o)=>{const r=d(V(H(a,u(t)?{[e]:t}:t)),0,X(a));c(r[0])||n(o,r[0])||(s(o,r[0]),it(i,o,r))})),i},Mt=(t,a,s,i,o,c,l,y,w,p,v="getDb",f)=>{let E,g,m;const h=((t,a)=>a?async(e,n)=>(a(e,n),await t(e,n)):t)(s,c),[A,N,S,O]=(t=>{const a=(t=>H(Lt,u(t)?{[At]:t}:t??{}))(t),n=a[Tt];if(a.mode==ht){const t=a[At]??e;return[1,n,[t,a[Nt]??T,a[St]??mt],ct(t)]}const{tables:{load:s={},save:i={}}={},values:o={}}=a,r=d(V(H(Dt,o)),0,X(Dt)),c=r[2],l=ct(c),y=ct(c);return[0,n,[Rt(s,{[Ct]:null,[$t]:T},Ct,(t=>x(y,t)),(t=>lt(l,t))),Rt(i,{[Ot]:null,[$t]:T,[bt]:0,[It]:0},Ot,((t,a)=>x(y,a)),((t,a)=>lt(l,a))),r],l]})(a);return(A?ft:Et)(t,h,(t=>{let a;const e=()=>a=setInterval((async()=>{try{const[{d:a,s:e,c:n}]=await h(`${$} ${R} d,${M} s,TOTAL_CHANGES() c FROM ${D}${R} JOIN ${D}${M}`);a==E&&e==g&&n==m||(null!=E&&t(),E=a,g=e,m=n)}catch{}}),1e3*N),n=()=>{E=g=m=null,r(a)},s=i((a=>{O.has(a)&&(n(),t(),e())}));return e(),()=>{n(),o(s)}}),(t=>t()),l,y,w,S,j(O),(async(t,a)=>await t(`${$} t.name tn,c.name cn FROM ${P}list()t,${P}info(t.name)c ${C} t.schema='main'AND t.type IN('table','view')AND t.name IN(${F(a)})ORDER BY t.name,c.name`,a)),p,v,n,f,(t=>!0===t?1:!1===t?0:t),void 0)};t.createCrSqliteWasmPersister=(t,a,e,n,s)=>Mt(t,e,(async(t,e=[])=>await a.execO(t,e)),(t=>a.onUpdate(((a,e,n)=>t(n)))),(t=>t()),n,s,(()=>0),1,a)},"object"==typeof exports&&"undefined"!=typeof module?a(exports):"function"==typeof define&&define.amd?define(["exports"],a):a((t="undefined"!=typeof globalThis?globalThis:t||self).TinyBasePersisterCrSqliteWasm={});
1
+ var t,a;t=this,a=function(t){"use strict";const a=t=>typeof t,e="tinybase",n="",s=",",i=a(n),o=Promise,r=clearInterval,c=t=>null==t,l=(t,a,e)=>c(t)?e?.():a(t),y=t=>a(t)==i,u=t=>Array.isArray(t),d=(t,a,e)=>t.slice(a,e),w=t=>t.length,p=async t=>o.all(t),v=t=>{throw Error(t)},f=(t,a)=>t.forEach(a),E=(t,a="")=>t.join(a),g=(t,a)=>t.map(a),m=t=>0==w(t),h=(t,a)=>t.filter(a),A=(t,...a)=>t.push(...a),N=t=>t.shift(),S="_",T="_id",$="SELECT",C="WHERE",O="TABLE",b="ALTER "+O,I="DELETE FROM",L=$+"*FROM",D="pragma_",R="data_version",M="schema_version",P="pragma_table_",_=t=>`"${t.replace(/"/g,'""')}"`,F=(t,a=[1])=>E(g(t,(()=>"$"+a[0]++)),s),x=(t,a)=>t?.has(a)??!1,U=t=>c(t)||0==(t=>t?.size??0)(t),j=t=>[...t?.values()??[]],B=(t,a)=>t?.forEach(a),J=(t,a)=>t?.delete(a),W=Object,Y=t=>W.getPrototypeOf(t),k=W.entries,q=W.keys,z=W.freeze,G=(t=[])=>W.fromEntries(t),H=(...t)=>W.assign({},...t),K=(t,a)=>(delete t[a],t),Q=(t,a)=>g(k(t),(([t,e])=>a(e,t))),V=(t,a)=>G(Q(t,((t,e)=>[e,a(t,e)]))),X=t=>W.values(t),Z=t=>w(q(t)),tt=t=>(t=>!c(t)&&l(Y(t),(t=>t==W.prototype||c(Y(t))),(()=>!0)))(t)&&0==Z(t),at=JSON.stringify,et=JSON.parse,nt=t=>new Map(t),st=(t,a)=>t?.get(a),it=(t,a)=>g([...t?.entries()??[]],(([t,e])=>a(e,t))),ot=(t,a,e)=>c(e)?(J(t,a),t):t?.set(a,e),rt=(t,a,e,n)=>(x(t,a)?n?.(st(t,a)):ot(t,a,e()),st(t,a)),ct=(t,a,e,n,s=0)=>l((e?rt:st)(t,a[s],s>w(a)-2?e:nt),(i=>{if(s>w(a)-2)return n?.(i)&&ot(t,a[s]),i;const o=ct(i,a,e,n,s+1);return U(i)&&ot(t,a[s]),o})),lt=t=>new Set(u(t)||c(t)?t:[t]),yt=(t,a)=>t?.add(a),ut=/^\d+$/,dt=nt(),wt=nt(),pt=(t,a,e,s,i,o,r,y={},d=0,p=[])=>{let E,g,m,h=0,S=0,T=0;rt(dt,p,(()=>0)),rt(wt,p,(()=>[]));const $=nt(),[C,O,b,I,L]=((t=1,a,e)=>1!=t&&a.isMergeable()?[1,a.getMergeableContent,()=>a.getTransactionMergeableChanges(!e),([[t],[a]])=>!tt(t)||!tt(a),a.setDefaultContent]:2!=t?[0,a.getContent,a.getTransactionChanges,([t,a])=>!tt(t)||!tt(a),a.setContent]:v("Store type not supported by this Persister"))(r,t,d),[D,R,M]=(()=>{let t;const[a,e]=(()=>{const t=[];let a=0;return[e=>(e?N(t):null)??n+a++,a=>{ut.test(a)&&w(t)<1e3&&A(t,a)}]})(),s=nt();return[(e,i,o,r=[],c=()=>[])=>{t??=k;const l=a(1);return ot(s,l,[e,i,o,r,c]),yt(ct(i,o??[n],lt),l),l},(a,e,...i)=>f(((t,a=[n])=>{const e=[],s=(t,n)=>n==w(a)?A(e,t):null===a[n]?B(t,(t=>s(t,n+1))):f([a[n],null],(a=>s(st(t,a),n+1)));return s(t,0),e})(a,e),(a=>B(a,(a=>st(s,a)[0](t,...e??[],...i))))),t=>l(st(s,t),(([,a,i])=>(ct(a,i??[n],void 0,(a=>(J(a,t),U(a)?1:0))),ot(s,t),e(t),i))),a=>l(st(s,a),(([a,,e=[],n,s])=>{const i=(...o)=>{const r=w(o);r==w(e)?a(t,...o,...s(o)):c(e[r])?f(n[r]?.(...o)??[],(t=>i(...o,t))):i(...o,e[r])};i()}))]})(),P=t=>{t!=h&&(h=t,R($,void 0,h))},_=a=>{(C&&u(a?.[0])?1===a?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===a?.[2]?t.applyChanges:t.setContent)(a)},F=async t=>(2!=h&&(P(1),S++,await Y((async()=>{try{const e=await a();u(e)?_(e):t?L(t):v("Content is not an array: "+e)}catch(a){o?.(a),t&&L(t)}P(0)}))),k),x=()=>(g&&(i(g),g=void 0),k),j=async t=>(1!=h&&(P(2),T++,await Y((async()=>{try{await e(O,t)}catch(t){o?.(t)}P(0)}))),k),W=()=>(m&&(t.delListener(m),m=void 0),k),Y=async(...t)=>(A(st(wt,p),...t),await(async()=>{if(!st(dt,p)){for(ot(dt,p,1);!c(E=N(st(wt,p)));)try{await E()}catch(t){o?.(t)}ot(dt,p,0)}})(),k),k={load:F,startAutoLoad:async t=>{x(),await F(t);try{g=await s((async(t,a)=>{a||t?2!=h&&(P(1),S++,_(a??t),P(0)):await F()}))}catch(t){o?.(t)}return k},stopAutoLoad:x,isAutoLoading:()=>!c(g),save:j,startAutoSave:async()=>(W(),await j(),m=t.addDidFinishTransactionListener((()=>{const t=b();I(t)&&j(t)})),k),stopAutoSave:W,isAutoSaving:()=>!c(m),getStatus:()=>h,addStatusListener:t=>D(t,$),delListener:a=>(M(a),t),schedule:Y,getStore:()=>t,destroy:()=>(st(wt,p).splice(0,void 0),x().stopAutoSave()),getStats:()=>({loads:S,saves:T}),...y};return z(k)},vt=(t,a,e,n,i,o=ft,r,l)=>{const y=nt();return[async()=>{y.clear(),g(await e(t,a),(({tn:t,cn:a})=>yt(rt(y,t,lt),a)))},async(a,e)=>((t,a)=>x(st(y,t),a))(a,e)?G(h(g(await t(L+_(a)),(t=>[t[e],l?V(K(t,e),l):K(t,e)])),(([t,a])=>!c(t)&&!tt(a)))):{},async(a,e,n,l,u,d=!1)=>{const w=lt();V(n??{},(t=>g(q(t??{}),(t=>yt(w,t)))));const v=j(w);if(!d&&u&&m(v)&&x(y,a))return await t("DROP "+O+_(a)),void ot(y,a);const f=st(y,a),N=lt(j(f));if(m(v)||(x(y,a)?await p(g([e,...v],(async(n,s)=>{J(N,n)||(await t(b+_(a)+"ADD"+_(n)+i),0==s&&await t("CREATE UNIQUE INDEX pk ON "+_(a)+`(${_(e)})`),yt(f,n))}))):(await t("CREATE "+O+_(a)+`(${_(e)}${i} PRIMARY KEY${E(g(v,(t=>s+_(t)+i)))});`),ot(y,a,lt([e,...v])))),await p([...!d&&l?g(j(N),(async n=>{n!=e&&(await t(b+_(a)+"DROP"+_(n)),J(f,n))})):[]]),d)c(n)?await t(I+_(a)+C+" true"):await p(Q(n,(async(n,s)=>{c(n)?await t(I+_(a)+C+_(e)+"=$1",[s]):m(v)||await o(t,a,e,q(n),{[s]:r?g(X(n),r):X(n)},f)})));else if(m(v))x(y,a)&&await t(I+_(a)+C+" true");else{const s=h(j(st(y,a)),(t=>t!=e)),i={},c=[];V(n??{},((t,a)=>{i[a]=g(s,(a=>r?r(t?.[a]):t?.[a])),A(c,a)})),await o(t,a,e,s,i),await t(I+_(a)+C+_(e)+`NOT IN(${F(c)})`,c)}},async a=>{let e;await t("BEGIN");try{e=await a()}catch(t){n?.(t)}return await t("END"),e}]},ft=async(t,a,e,n,i)=>{const o=[1];await t("INSERT INTO"+_(a)+"("+((...t)=>E(g(t,_),s))(e,...n)+")VALUES"+E(Q(i,(t=>"($"+o[0]+++","+F(t,o)+")")),s)+"ON CONFLICT("+_(e)+")DO UPDATE SET"+E(g(n,(t=>_(t)+"=excluded."+_(t))),s),Q(i,((t,a)=>[a,...g(t,(t=>t??null))])).flat())},Et=(t,a,e,n,s,i,o,[r,c,l],y,u,d,w,p,v)=>{const[f,E,g,m]=vt(a,y,u,s,p,v),h=pt(t,(async()=>await m((async()=>{return await f(),t=(await E(r,c))[S]?.[l]??"null",et(t,((t,a)=>""===a?void 0:a));var t}))),(async t=>await m((async()=>{var a;await f(),await g(r,c,{[S]:{[l]:(a=t()??null,at(a,((t,a)=>void 0===a?"":a)))}},!0,!0)}))),e,n,s,o,{[w]:()=>d,destroy:()=>(h.stopAutoLoad().stopAutoSave(),i(),h)},0,d);return h},gt=(t,a,e,n,s,i,o,[r,l,[y,u,d]],w,v,f,E,g,m,A,N)=>{const[$,C,O,b]=vt(a,w,v,s,g,m,A,N),I=async(t,a)=>await p(it(l,(async([e,n,s,i],o)=>{a&&!(o in t)||await O(e,n,t[o],s,i,a)}))),L=async(t,a)=>u?await O(d,T,{[S]:t},!0,!0,a):null,D=pt(t,(async()=>await b((async()=>{await $();const t=await(async()=>G(h(await p(it(r,(async([t,a],e)=>[t,await C(e,a)]))),(t=>!tt(t[1])))))(),a=await(async()=>y?(await C(d,T))[S]:{})();return tt(t)&&c(a)?void 0:[t,a]}))),(async(t,a)=>await b((async()=>{if(await $(),c(a)){const[a,e]=t();await I(a),await L(e)}else await I(a[0],!0),await L(a[1],!0)}))),e,n,s,o,{[E]:()=>f,destroy:()=>(D.stopAutoLoad().stopAutoSave(),i(),D)},0,f);return D},mt="ColumnName",ht="store",At="json",Nt=ht+"TableName",St=ht+"Id"+mt,Tt=ht+mt,$t="autoLoadIntervalSeconds",Ct="rowId"+mt,Ot="tableId",bt="tableName",It="deleteEmptyColumns",Lt="deleteEmptyTable",Dt={mode:At,[$t]:1},Rt={load:0,save:0,[bt]:e+"_values"},Mt=(t,a,e,n,s)=>{const i=nt();return V(t,((t,o)=>{const r=d(X(H(a,y(t)?{[e]:t}:t)),0,Z(a));c(r[0])||n(o,r[0])||(s(o,r[0]),ot(i,o,r))})),i},Pt=(t,a,s,i,o,c,l,u,w,p,v="getDb",f)=>{let E,g,m;const h=((t,a)=>a?async(e,n)=>(a(e,n),await t(e,n)):t)(s,c),[A,N,S,O]=(t=>{const a=(t=>H(Dt,y(t)?{[Nt]:t}:t??{}))(t),n=a[$t];if(a.mode==At){const t=a[Nt]??e;return[1,n,[t,a[St]??T,a[Tt]??ht],lt(t)]}const{tables:{load:s={},save:i={}}={},values:o={}}=a,r=d(X(H(Rt,o)),0,Z(Rt)),c=r[2],l=lt(c),u=lt(c);return[0,n,[Mt(s,{[Ot]:null,[Ct]:T},Ot,(t=>x(u,t)),(t=>yt(l,t))),Mt(i,{[bt]:null,[Ct]:T,[It]:0,[Lt]:0},bt,((t,a)=>x(u,a)),((t,a)=>yt(l,a))),r],l]})(a);return(A?Et:gt)(t,h,(t=>{let a;const e=()=>a=setInterval((async()=>{try{const[{d:a,s:e,c:n}]=await h(`${$} ${R} d,${M} s,TOTAL_CHANGES() c FROM ${D}${R} JOIN ${D}${M}`);a==E&&e==g&&n==m||(null!=E&&t(),E=a,g=e,m=n)}catch{}}),1e3*N),n=()=>{E=g=m=null,r(a)},s=i((a=>{O.has(a)&&(n(),t(),e())}));return e(),()=>{n(),o(s)}}),(t=>t()),l,u,w,S,j(O),(async(t,a)=>await t(`${$} t.name tn,c.name cn FROM ${P}list()t,${P}info(t.name)c ${C} t.schema='main'AND t.type IN('table','view')AND t.name IN(${F(a)})ORDER BY t.name,c.name`,a)),p,v,n,f,(t=>!0===t?1:!1===t?0:t),void 0)};t.createCrSqliteWasmPersister=(t,a,e,n,s)=>Pt(t,e,(async(t,e=[])=>await a.execO(t,e)),(t=>a.onUpdate(((a,e,n)=>t(n)))),(t=>t()),n,s,(()=>0),1,a)},"object"==typeof exports&&"undefined"!=typeof module?a(exports):"function"==typeof define&&define.amd?define(["exports"],a):a((t="undefined"!=typeof globalThis?globalThis:t||self).TinyBasePersisterCrSqliteWasm={});
@@ -1 +1 @@
1
- var t,a;t=this,a=function(t){"use strict";const a=t=>typeof t,e="tinybase",n="",s=",",i=a(n),r=Promise,o=clearInterval,c=t=>null==t,l=(t,a,e)=>c(t)?e?.():a(t),u=t=>a(t)==i,y=t=>Array.isArray(t),w=(t,a,e)=>t.slice(a,e),d=t=>t.length,p=async t=>r.all(t),f=t=>{throw Error(t)},v=(t,a)=>t.forEach(a),E=(t,a="")=>t.join(a),g=(t,a)=>t.map(a),h=t=>0==d(t),m=(t,a)=>t.filter(a),A=(t,...a)=>t.push(...a),b=t=>t.shift(),T="_",N="_id",S="SELECT",$="WHERE",C="TABLE",O="ALTER "+C,I="DELETE FROM",L=S+"*FROM",D="pragma_",R="data_version",M="schema_version",P="pragma_table_",_=t=>`"${t.replace(/"/g,'""')}"`,F=(t,a=[1])=>E(g(t,(()=>"$"+a[0]++)),s),j=(t,a)=>t?.has(a)??!1,x=t=>c(t)||0==(t=>t?.size??0)(t),B=t=>[...t?.values()??[]],U=(t,a)=>t?.forEach(a),q=(t,a)=>t?.delete(a),J=Object,Y=t=>J.getPrototypeOf(t),k=J.entries,z=J.keys,G=J.freeze,H=(t=[])=>J.fromEntries(t),K=(...t)=>J.assign({},...t),Q=(t,a)=>(delete t[a],t),V=(t,a)=>g(k(t),(([t,e])=>a(e,t))),W=t=>J.values(t),X=t=>d(z(t)),Z=t=>(t=>!c(t)&&l(Y(t),(t=>t==J.prototype||c(Y(t))),(()=>!0)))(t)&&0==X(t),tt=JSON.stringify,at=JSON.parse,et=t=>new Map(t),nt=(t,a)=>t?.get(a),st=(t,a)=>g([...t?.entries()??[]],(([t,e])=>a(e,t))),it=(t,a,e)=>c(e)?(q(t,a),t):t?.set(a,e),rt=(t,a,e,n)=>(j(t,a)?n?.(nt(t,a)):it(t,a,e()),nt(t,a)),ot=(t,a,e,n,s=0)=>l((e?rt:nt)(t,a[s],s>d(a)-2?e:et),(i=>{if(s>d(a)-2)return n?.(i)&&it(t,a[s]),i;const r=ot(i,a,e,n,s+1);return x(i)&&it(t,a[s]),r})),ct=t=>new Set(y(t)||c(t)?t:[t]),lt=(t,a)=>t?.add(a),ut=/^\d+$/,yt=et(),wt=et(),dt=(t,a,e,s,i,r,o,u={},w=0,p=[])=>{let E,g,h,m=0,T=0,N=0;rt(yt,p,(()=>0)),rt(wt,p,(()=>[]));const S=et(),[$,C,O,I,L]=((t=1,a,e)=>1!=t&&a.isMergeable()?[1,a.getMergeableContent,()=>a.getTransactionMergeableChanges(!e),([[t],[a]])=>!Z(t)||!Z(a),a.setDefaultContent]:2!=t?[0,a.getContent,a.getTransactionChanges,([t,a])=>!Z(t)||!Z(a),a.setContent]:f("Store type not supported by this Persister"))(o,t,w),[D,R,M]=(()=>{let t;const[a,e]=(()=>{const t=[];let a=0;return[e=>(e?b(t):null)??n+a++,a=>{ut.test(a)&&d(t)<1e3&&A(t,a)}]})(),s=et();return[(e,i,r,o=[],c=()=>[])=>{t??=k;const l=a(1);return it(s,l,[e,i,r,o,c]),lt(ot(i,r??[n],ct),l),l},(a,e,...i)=>v(((t,a=[n])=>{const e=[],s=(t,n)=>n==d(a)?A(e,t):null===a[n]?U(t,(t=>s(t,n+1))):v([a[n],null],(a=>s(nt(t,a),n+1)));return s(t,0),e})(a,e),(a=>U(a,(a=>nt(s,a)[0](t,...e??[],...i))))),t=>l(nt(s,t),(([,a,i])=>(ot(a,i??[n],void 0,(a=>(q(a,t),x(a)?1:0))),it(s,t),e(t),i))),a=>l(nt(s,a),(([a,,e=[],n,s])=>{const i=(...r)=>{const o=d(r);o==d(e)?a(t,...r,...s(r)):c(e[o])?v(n[o]?.(...r)??[],(t=>i(...r,t))):i(...r,e[o])};i()}))]})(),P=t=>{t!=m&&(m=t,R(S,void 0,m))},_=a=>{($&&y(a?.[0])?1===a?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===a?.[2]?t.applyChanges:t.setContent)(a)},F=async t=>(2!=m&&(P(1),T++,await Y((async()=>{try{const e=await a();y(e)?_(e):t?L(t):f("Content is not an array: "+e)}catch(a){r?.(a),t&&L(t)}P(0)}))),k),j=()=>(g&&(i(g),g=void 0),k),B=async t=>(1!=m&&(P(2),N++,await Y((async()=>{try{await e(C,t)}catch(t){r?.(t)}P(0)}))),k),J=()=>(h&&(t.delListener(h),h=void 0),k),Y=async(...t)=>(A(nt(wt,p),...t),await(async()=>{if(!nt(yt,p)){for(it(yt,p,1);!c(E=b(nt(wt,p)));)try{await E()}catch(t){r?.(t)}it(yt,p,0)}})(),k),k={load:F,startAutoLoad:async t=>{j(),await F(t);try{g=await s((async(t,a)=>{a||t?2!=m&&(P(1),T++,_(a??t),P(0)):await F()}))}catch(t){r?.(t)}return k},stopAutoLoad:j,isAutoLoading:()=>!c(g),save:B,startAutoSave:async()=>(J(),await B(),h=t.addDidFinishTransactionListener((()=>{const t=O();I(t)&&B(t)})),k),stopAutoSave:J,isAutoSaving:()=>!c(h),getStatus:()=>m,addStatusListener:t=>D(t,S),delListener:a=>(M(a),t),schedule:Y,getStore:()=>t,destroy:()=>(nt(wt,p).splice(0,void 0),j().stopAutoSave()),getStats:()=>({loads:T,saves:N}),...u};return G(k)},pt=(t,a,e,n,i,r=ft,o,l)=>{const u=et();return[async()=>{u.clear(),g(await e(t,a),(({tn:t,cn:a})=>lt(rt(u,t,ct),a)))},async(a,e)=>((t,a)=>j(nt(u,t),a))(a,e)?H(m(g(await t(L+_(a)),(t=>{return[t[e],l?(a=Q(t,e),n=l,H(V(a,((t,a)=>[a,n(t,a)])))):Q(t,e)];var a,n})),(([t,a])=>!c(t)&&!Z(a)))):{},async(a,e,n,l,y,w=!1)=>{const d=ct();V(n??{},(t=>g(z(t??{}),(t=>lt(d,t)))));const f=B(d);if(!w&&y&&h(f)&&j(u,a))return await t("DROP "+C+_(a)),void it(u,a);const v=nt(u,a),b=ct(B(v));if(h(f)||(j(u,a)?await p(g([e,...f],(async(n,s)=>{q(b,n)||(await t(O+_(a)+"ADD"+_(n)+i),0==s&&await t("CREATE UNIQUE INDEX pk ON "+_(a)+`(${_(e)})`),lt(v,n))}))):(await t("CREATE "+C+_(a)+`(${_(e)}${i} PRIMARY KEY${E(g(f,(t=>s+_(t)+i)))});`),it(u,a,ct([e,...f])))),await p([...!w&&l?g(B(b),(async n=>{n!=e&&(await t(O+_(a)+"DROP"+_(n)),q(v,n))})):[]]),w)c(n)?await t(I+_(a)+$+" true"):await p(V(n,(async(n,s)=>{c(n)?await t(I+_(a)+$+_(e)+"=$1",[s]):h(f)||await r(t,a,e,z(n),{[s]:o?g(W(n),o):W(n)},v)})));else if(h(f))j(u,a)&&await t(I+_(a)+$+" true");else{const s=m(B(nt(u,a)),(t=>t!=e)),i={},c=[];V(n??{},((t,a)=>{i[a]=g(s,(a=>o?o(t?.[a]):t?.[a])),A(c,a)})),await r(t,a,e,s,i),await t(I+_(a)+$+_(e)+`NOT IN(${F(c)})`,c)}},async a=>{let e;await t("BEGIN");try{e=await a()}catch(t){n?.(t)}return await t("END"),e}]},ft=async(t,a,e,n,i)=>{const r=[1];await t("INSERT INTO"+_(a)+"("+((...t)=>E(g(t,_),s))(e,...n)+")VALUES"+E(V(i,(t=>"($"+r[0]+++","+F(t,r)+")")),s)+"ON CONFLICT("+_(e)+")DO UPDATE SET"+E(g(n,(t=>_(t)+"=excluded."+_(t))),s),V(i,((t,a)=>[a,...g(t,(t=>t??null))])).flat())},vt=(t,a,e,n,s,i,r,[o,c,l],u,y,w,d,p,f)=>{const[v,E,g,h]=pt(a,u,y,s,p,f),m=dt(t,(async()=>await h((async()=>{return await v(),t=(await E(o,c))[T]?.[l]??"null",at(t,((t,a)=>""===a?void 0:a));var t}))),(async t=>await h((async()=>{var a;await v(),await g(o,c,{[T]:{[l]:(a=t()??null,tt(a,((t,a)=>void 0===a?"":a)))}},!0,!0)}))),e,n,s,r,{[d]:()=>w,destroy:()=>(m.stopAutoLoad().stopAutoSave(),i(),m)},0,w);return m},Et=(t,a,e,n,s,i,r,[o,l,[u,y,w]],d,f,v,E,g,h,A,b)=>{const[S,$,C,O]=pt(a,d,f,s,g,h,A,b),I=async(t,a)=>await p(st(l,(async([e,n,s,i],r)=>{a&&!(r in t)||await C(e,n,t[r],s,i,a)}))),L=async(t,a)=>y?await C(w,N,{[T]:t},!0,!0,a):null,D=dt(t,(async()=>await O((async()=>{await S();const t=await(async()=>H(m(await p(st(o,(async([t,a],e)=>[t,await $(e,a)]))),(t=>!Z(t[1])))))(),a=await(async()=>u?(await $(w,N))[T]:{})();return Z(t)&&c(a)?void 0:[t,a]}))),(async(t,a)=>await O((async()=>{if(await S(),c(a)){const[a,e]=t();await I(a),await L(e)}else await I(a[0],!0),await L(a[1],!0)}))),e,n,s,r,{[E]:()=>v,destroy:()=>(D.stopAutoLoad().stopAutoSave(),i(),D)},0,v);return D},gt="ColumnName",ht="store",mt="json",At=ht+"TableName",bt=ht+"Id"+gt,Tt=ht+gt,Nt="autoLoadIntervalSeconds",St="rowId"+gt,$t="tableId",Ct="tableName",Ot="deleteEmptyColumns",It="deleteEmptyTable",Lt={mode:mt,[Nt]:1},Dt={load:0,save:0,[Ct]:e+"_values"},Rt=(t,a,e,n,s)=>{const i=et();return V(t,((t,r)=>{const o=w(W(K(a,u(t)?{[e]:t}:t)),0,X(a));c(o[0])||n(r,o[0])||(s(r,o[0]),it(i,r,o))})),i},Mt=(t,a,s,i,r,c,l,y,d,p,f="getDb",v)=>{let E,g,h;const m=((t,a)=>a?async(e,n)=>(a(e,n),await t(e,n)):t)(s,c),[A,b,T,C]=(t=>{const a=(t=>K(Lt,u(t)?{[At]:t}:t??{}))(t),n=a[Nt];if(a.mode==mt){const t=a[At]??e;return[1,n,[t,a[bt]??N,a[Tt]??ht],ct(t)]}const{tables:{load:s={},save:i={}}={},values:r={}}=a,o=w(W(K(Dt,r)),0,X(Dt)),c=o[2],l=ct(c),y=ct(c);return[0,n,[Rt(s,{[$t]:null,[St]:N},$t,(t=>j(y,t)),(t=>lt(l,t))),Rt(i,{[Ct]:null,[St]:N,[Ot]:0,[It]:0},Ct,((t,a)=>j(y,a)),((t,a)=>lt(l,a))),o],l]})(a);return(A?vt:Et)(t,m,(t=>{let a;const e=()=>a=setInterval((async()=>{try{const[{d:a,s:e,c:n}]=await m(`${S} ${R} d,${M} s,TOTAL_CHANGES() c FROM ${D}${R} JOIN ${D}${M}`);a==E&&e==g&&n==h||(null!=E&&t(),E=a,g=e,h=n)}catch{}}),1e3*b),n=()=>{E=g=h=null,o(a)},s=i((a=>{C.has(a)&&(n(),t(),e())}));return e(),()=>{n(),r(s)}}),(t=>t()),l,y,d,T,B(C),(async(t,a)=>await t(`${S} t.name tn,c.name cn FROM ${P}list()t,${P}info(t.name)c ${$} t.schema='main'AND t.type IN('table','view')AND t.name IN(${F(a)})ORDER BY t.name,c.name`,a)),p,f,n,v,(t=>!0===t?1:!1===t?0:t),void 0)};t.createElectricSqlPersister=(t,a,e,n,s)=>Mt(t,e,(async(t,e=[])=>await a.db.raw({sql:t,args:e})),(t=>a.notifier.subscribeToDataChanges((e=>v(a.notifier.alias(e),(({tablename:a})=>t(a)))))),(t=>t()),n,s,(()=>0),1,a,"getElectricClient")},"object"==typeof exports&&"undefined"!=typeof module?a(exports):"function"==typeof define&&define.amd?define(["exports"],a):a((t="undefined"!=typeof globalThis?globalThis:t||self).TinyBasePersisterElectricSql={});
1
+ var t,a;t=this,a=function(t){"use strict";const a=t=>typeof t,e="tinybase",n="",s=",",i=a(n),o=Promise,r=clearInterval,c=t=>null==t,l=(t,a,e)=>c(t)?e?.():a(t),u=t=>a(t)==i,y=t=>Array.isArray(t),w=(t,a,e)=>t.slice(a,e),d=t=>t.length,p=async t=>o.all(t),f=t=>{throw Error(t)},v=(t,a)=>t.forEach(a),E=(t,a="")=>t.join(a),g=(t,a)=>t.map(a),h=t=>0==d(t),m=(t,a)=>t.filter(a),A=(t,...a)=>t.push(...a),b=t=>t.shift(),T="_",N="_id",S="SELECT",$="WHERE",C="TABLE",O="ALTER "+C,I="DELETE FROM",L=S+"*FROM",D="pragma_",R="data_version",M="schema_version",P="pragma_table_",_=t=>`"${t.replace(/"/g,'""')}"`,F=(t,a=[1])=>E(g(t,(()=>"$"+a[0]++)),s),j=(t,a)=>t?.has(a)??!1,x=t=>c(t)||0==(t=>t?.size??0)(t),B=t=>[...t?.values()??[]],U=(t,a)=>t?.forEach(a),q=(t,a)=>t?.delete(a),J=Object,Y=t=>J.getPrototypeOf(t),k=J.entries,z=J.keys,G=J.freeze,H=(t=[])=>J.fromEntries(t),K=(...t)=>J.assign({},...t),Q=(t,a)=>(delete t[a],t),V=(t,a)=>g(k(t),(([t,e])=>a(e,t))),W=(t,a)=>H(V(t,((t,e)=>[e,a(t,e)]))),X=t=>J.values(t),Z=t=>d(z(t)),tt=t=>(t=>!c(t)&&l(Y(t),(t=>t==J.prototype||c(Y(t))),(()=>!0)))(t)&&0==Z(t),at=JSON.stringify,et=JSON.parse,nt=t=>new Map(t),st=(t,a)=>t?.get(a),it=(t,a)=>g([...t?.entries()??[]],(([t,e])=>a(e,t))),ot=(t,a,e)=>c(e)?(q(t,a),t):t?.set(a,e),rt=(t,a,e,n)=>(j(t,a)?n?.(st(t,a)):ot(t,a,e()),st(t,a)),ct=(t,a,e,n,s=0)=>l((e?rt:st)(t,a[s],s>d(a)-2?e:nt),(i=>{if(s>d(a)-2)return n?.(i)&&ot(t,a[s]),i;const o=ct(i,a,e,n,s+1);return x(i)&&ot(t,a[s]),o})),lt=t=>new Set(y(t)||c(t)?t:[t]),ut=(t,a)=>t?.add(a),yt=/^\d+$/,wt=nt(),dt=nt(),pt=(t,a,e,s,i,o,r,u={},w=0,p=[])=>{let E,g,h,m=0,T=0,N=0;rt(wt,p,(()=>0)),rt(dt,p,(()=>[]));const S=nt(),[$,C,O,I,L]=((t=1,a,e)=>1!=t&&a.isMergeable()?[1,a.getMergeableContent,()=>a.getTransactionMergeableChanges(!e),([[t],[a]])=>!tt(t)||!tt(a),a.setDefaultContent]:2!=t?[0,a.getContent,a.getTransactionChanges,([t,a])=>!tt(t)||!tt(a),a.setContent]:f("Store type not supported by this Persister"))(r,t,w),[D,R,M]=(()=>{let t;const[a,e]=(()=>{const t=[];let a=0;return[e=>(e?b(t):null)??n+a++,a=>{yt.test(a)&&d(t)<1e3&&A(t,a)}]})(),s=nt();return[(e,i,o,r=[],c=()=>[])=>{t??=k;const l=a(1);return ot(s,l,[e,i,o,r,c]),ut(ct(i,o??[n],lt),l),l},(a,e,...i)=>v(((t,a=[n])=>{const e=[],s=(t,n)=>n==d(a)?A(e,t):null===a[n]?U(t,(t=>s(t,n+1))):v([a[n],null],(a=>s(st(t,a),n+1)));return s(t,0),e})(a,e),(a=>U(a,(a=>st(s,a)[0](t,...e??[],...i))))),t=>l(st(s,t),(([,a,i])=>(ct(a,i??[n],void 0,(a=>(q(a,t),x(a)?1:0))),ot(s,t),e(t),i))),a=>l(st(s,a),(([a,,e=[],n,s])=>{const i=(...o)=>{const r=d(o);r==d(e)?a(t,...o,...s(o)):c(e[r])?v(n[r]?.(...o)??[],(t=>i(...o,t))):i(...o,e[r])};i()}))]})(),P=t=>{t!=m&&(m=t,R(S,void 0,m))},_=a=>{($&&y(a?.[0])?1===a?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===a?.[2]?t.applyChanges:t.setContent)(a)},F=async t=>(2!=m&&(P(1),T++,await Y((async()=>{try{const e=await a();y(e)?_(e):t?L(t):f("Content is not an array: "+e)}catch(a){o?.(a),t&&L(t)}P(0)}))),k),j=()=>(g&&(i(g),g=void 0),k),B=async t=>(1!=m&&(P(2),N++,await Y((async()=>{try{await e(C,t)}catch(t){o?.(t)}P(0)}))),k),J=()=>(h&&(t.delListener(h),h=void 0),k),Y=async(...t)=>(A(st(dt,p),...t),await(async()=>{if(!st(wt,p)){for(ot(wt,p,1);!c(E=b(st(dt,p)));)try{await E()}catch(t){o?.(t)}ot(wt,p,0)}})(),k),k={load:F,startAutoLoad:async t=>{j(),await F(t);try{g=await s((async(t,a)=>{a||t?2!=m&&(P(1),T++,_(a??t),P(0)):await F()}))}catch(t){o?.(t)}return k},stopAutoLoad:j,isAutoLoading:()=>!c(g),save:B,startAutoSave:async()=>(J(),await B(),h=t.addDidFinishTransactionListener((()=>{const t=O();I(t)&&B(t)})),k),stopAutoSave:J,isAutoSaving:()=>!c(h),getStatus:()=>m,addStatusListener:t=>D(t,S),delListener:a=>(M(a),t),schedule:Y,getStore:()=>t,destroy:()=>(st(dt,p).splice(0,void 0),j().stopAutoSave()),getStats:()=>({loads:T,saves:N}),...u};return G(k)},ft=(t,a,e,n,i,o=vt,r,l)=>{const u=nt();return[async()=>{u.clear(),g(await e(t,a),(({tn:t,cn:a})=>ut(rt(u,t,lt),a)))},async(a,e)=>((t,a)=>j(st(u,t),a))(a,e)?H(m(g(await t(L+_(a)),(t=>[t[e],l?W(Q(t,e),l):Q(t,e)])),(([t,a])=>!c(t)&&!tt(a)))):{},async(a,e,n,l,y,w=!1)=>{const d=lt();W(n??{},(t=>g(z(t??{}),(t=>ut(d,t)))));const f=B(d);if(!w&&y&&h(f)&&j(u,a))return await t("DROP "+C+_(a)),void ot(u,a);const v=st(u,a),b=lt(B(v));if(h(f)||(j(u,a)?await p(g([e,...f],(async(n,s)=>{q(b,n)||(await t(O+_(a)+"ADD"+_(n)+i),0==s&&await t("CREATE UNIQUE INDEX pk ON "+_(a)+`(${_(e)})`),ut(v,n))}))):(await t("CREATE "+C+_(a)+`(${_(e)}${i} PRIMARY KEY${E(g(f,(t=>s+_(t)+i)))});`),ot(u,a,lt([e,...f])))),await p([...!w&&l?g(B(b),(async n=>{n!=e&&(await t(O+_(a)+"DROP"+_(n)),q(v,n))})):[]]),w)c(n)?await t(I+_(a)+$+" true"):await p(V(n,(async(n,s)=>{c(n)?await t(I+_(a)+$+_(e)+"=$1",[s]):h(f)||await o(t,a,e,z(n),{[s]:r?g(X(n),r):X(n)},v)})));else if(h(f))j(u,a)&&await t(I+_(a)+$+" true");else{const s=m(B(st(u,a)),(t=>t!=e)),i={},c=[];W(n??{},((t,a)=>{i[a]=g(s,(a=>r?r(t?.[a]):t?.[a])),A(c,a)})),await o(t,a,e,s,i),await t(I+_(a)+$+_(e)+`NOT IN(${F(c)})`,c)}},async a=>{let e;await t("BEGIN");try{e=await a()}catch(t){n?.(t)}return await t("END"),e}]},vt=async(t,a,e,n,i)=>{const o=[1];await t("INSERT INTO"+_(a)+"("+((...t)=>E(g(t,_),s))(e,...n)+")VALUES"+E(V(i,(t=>"($"+o[0]+++","+F(t,o)+")")),s)+"ON CONFLICT("+_(e)+")DO UPDATE SET"+E(g(n,(t=>_(t)+"=excluded."+_(t))),s),V(i,((t,a)=>[a,...g(t,(t=>t??null))])).flat())},Et=(t,a,e,n,s,i,o,[r,c,l],u,y,w,d,p,f)=>{const[v,E,g,h]=ft(a,u,y,s,p,f),m=pt(t,(async()=>await h((async()=>{return await v(),t=(await E(r,c))[T]?.[l]??"null",et(t,((t,a)=>""===a?void 0:a));var t}))),(async t=>await h((async()=>{var a;await v(),await g(r,c,{[T]:{[l]:(a=t()??null,at(a,((t,a)=>void 0===a?"":a)))}},!0,!0)}))),e,n,s,o,{[d]:()=>w,destroy:()=>(m.stopAutoLoad().stopAutoSave(),i(),m)},0,w);return m},gt=(t,a,e,n,s,i,o,[r,l,[u,y,w]],d,f,v,E,g,h,A,b)=>{const[S,$,C,O]=ft(a,d,f,s,g,h,A,b),I=async(t,a)=>await p(it(l,(async([e,n,s,i],o)=>{a&&!(o in t)||await C(e,n,t[o],s,i,a)}))),L=async(t,a)=>y?await C(w,N,{[T]:t},!0,!0,a):null,D=pt(t,(async()=>await O((async()=>{await S();const t=await(async()=>H(m(await p(it(r,(async([t,a],e)=>[t,await $(e,a)]))),(t=>!tt(t[1])))))(),a=await(async()=>u?(await $(w,N))[T]:{})();return tt(t)&&c(a)?void 0:[t,a]}))),(async(t,a)=>await O((async()=>{if(await S(),c(a)){const[a,e]=t();await I(a),await L(e)}else await I(a[0],!0),await L(a[1],!0)}))),e,n,s,o,{[E]:()=>v,destroy:()=>(D.stopAutoLoad().stopAutoSave(),i(),D)},0,v);return D},ht="ColumnName",mt="store",At="json",bt=mt+"TableName",Tt=mt+"Id"+ht,Nt=mt+ht,St="autoLoadIntervalSeconds",$t="rowId"+ht,Ct="tableId",Ot="tableName",It="deleteEmptyColumns",Lt="deleteEmptyTable",Dt={mode:At,[St]:1},Rt={load:0,save:0,[Ot]:e+"_values"},Mt=(t,a,e,n,s)=>{const i=nt();return W(t,((t,o)=>{const r=w(X(K(a,u(t)?{[e]:t}:t)),0,Z(a));c(r[0])||n(o,r[0])||(s(o,r[0]),ot(i,o,r))})),i},Pt=(t,a,s,i,o,c,l,y,d,p,f="getDb",v)=>{let E,g,h;const m=((t,a)=>a?async(e,n)=>(a(e,n),await t(e,n)):t)(s,c),[A,b,T,C]=(t=>{const a=(t=>K(Dt,u(t)?{[bt]:t}:t??{}))(t),n=a[St];if(a.mode==At){const t=a[bt]??e;return[1,n,[t,a[Tt]??N,a[Nt]??mt],lt(t)]}const{tables:{load:s={},save:i={}}={},values:o={}}=a,r=w(X(K(Rt,o)),0,Z(Rt)),c=r[2],l=lt(c),y=lt(c);return[0,n,[Mt(s,{[Ct]:null,[$t]:N},Ct,(t=>j(y,t)),(t=>ut(l,t))),Mt(i,{[Ot]:null,[$t]:N,[It]:0,[Lt]:0},Ot,((t,a)=>j(y,a)),((t,a)=>ut(l,a))),r],l]})(a);return(A?Et:gt)(t,m,(t=>{let a;const e=()=>a=setInterval((async()=>{try{const[{d:a,s:e,c:n}]=await m(`${S} ${R} d,${M} s,TOTAL_CHANGES() c FROM ${D}${R} JOIN ${D}${M}`);a==E&&e==g&&n==h||(null!=E&&t(),E=a,g=e,h=n)}catch{}}),1e3*b),n=()=>{E=g=h=null,r(a)},s=i((a=>{C.has(a)&&(n(),t(),e())}));return e(),()=>{n(),o(s)}}),(t=>t()),l,y,d,T,B(C),(async(t,a)=>await t(`${S} t.name tn,c.name cn FROM ${P}list()t,${P}info(t.name)c ${$} t.schema='main'AND t.type IN('table','view')AND t.name IN(${F(a)})ORDER BY t.name,c.name`,a)),p,f,n,v,(t=>!0===t?1:!1===t?0:t),void 0)};t.createElectricSqlPersister=(t,a,e,n,s)=>Pt(t,e,(async(t,e=[])=>await a.db.raw({sql:t,args:e})),(t=>a.notifier.subscribeToDataChanges((e=>v(a.notifier.alias(e),(({tablename:a})=>t(a)))))),(t=>t()),n,s,(()=>0),1,a,"getElectricClient")},"object"==typeof exports&&"undefined"!=typeof module?a(exports):"function"==typeof define&&define.amd?define(["exports"],a):a((t="undefined"!=typeof globalThis?globalThis:t||self).TinyBasePersisterElectricSql={});
@@ -1 +1 @@
1
- var t,a;t=this,a=function(t){"use strict";const a=t=>typeof t,e="tinybase",n="",s=",",i=a(n),r=Promise,o=clearInterval,c=t=>null==t,l=(t,a,e)=>c(t)?e?.():a(t),u=t=>a(t)==i,y=t=>Array.isArray(t),w=(t,a,e)=>t.slice(a,e),d=t=>t.length,p=async t=>r.all(t),f=t=>{throw Error(t)},v=(t,a)=>t.forEach(a),E=(t,a="")=>t.join(a),g=(t,a)=>t.map(a),h=t=>0==d(t),m=(t,a)=>t.filter(a),A=(t,...a)=>t.push(...a),b=t=>t.shift(),T="_",N="_id",S="SELECT",$="WHERE",C="TABLE",O="ALTER "+C,I="DELETE FROM",L=S+"*FROM",D="pragma_",R="data_version",M="schema_version",P="pragma_table_",_=t=>`"${t.replace(/"/g,'""')}"`,F=(t,a=[1])=>E(g(t,(()=>"$"+a[0]++)),s),j=(t,a)=>t?.has(a)??!1,x=t=>c(t)||0==(t=>t?.size??0)(t),B=t=>[...t?.values()??[]],U=(t,a)=>t?.forEach(a),q=(t,a)=>t?.delete(a),J=Object,Y=t=>J.getPrototypeOf(t),k=J.entries,z=J.keys,G=J.freeze,H=(t=[])=>J.fromEntries(t),K=(...t)=>J.assign({},...t),Q=(t,a)=>(delete t[a],t),V=(t,a)=>g(k(t),(([t,e])=>a(e,t))),W=t=>J.values(t),X=t=>d(z(t)),Z=t=>(t=>!c(t)&&l(Y(t),(t=>t==J.prototype||c(Y(t))),(()=>!0)))(t)&&0==X(t),tt=JSON.stringify,at=JSON.parse,et=t=>new Map(t),nt=(t,a)=>t?.get(a),st=(t,a)=>g([...t?.entries()??[]],(([t,e])=>a(e,t))),it=(t,a,e)=>c(e)?(q(t,a),t):t?.set(a,e),rt=(t,a,e,n)=>(j(t,a)?n?.(nt(t,a)):it(t,a,e()),nt(t,a)),ot=(t,a,e,n,s=0)=>l((e?rt:nt)(t,a[s],s>d(a)-2?e:et),(i=>{if(s>d(a)-2)return n?.(i)&&it(t,a[s]),i;const r=ot(i,a,e,n,s+1);return x(i)&&it(t,a[s]),r})),ct=t=>new Set(y(t)||c(t)?t:[t]),lt=(t,a)=>t?.add(a),ut=/^\d+$/,yt=et(),wt=et(),dt=(t,a,e,s,i,r,o,u={},w=0,p=[])=>{let E,g,h,m=0,T=0,N=0;rt(yt,p,(()=>0)),rt(wt,p,(()=>[]));const S=et(),[$,C,O,I,L]=((t=1,a,e)=>1!=t&&a.isMergeable()?[1,a.getMergeableContent,()=>a.getTransactionMergeableChanges(!e),([[t],[a]])=>!Z(t)||!Z(a),a.setDefaultContent]:2!=t?[0,a.getContent,a.getTransactionChanges,([t,a])=>!Z(t)||!Z(a),a.setContent]:f("Store type not supported by this Persister"))(o,t,w),[D,R,M]=(()=>{let t;const[a,e]=(()=>{const t=[];let a=0;return[e=>(e?b(t):null)??n+a++,a=>{ut.test(a)&&d(t)<1e3&&A(t,a)}]})(),s=et();return[(e,i,r,o=[],c=()=>[])=>{t??=k;const l=a(1);return it(s,l,[e,i,r,o,c]),lt(ot(i,r??[n],ct),l),l},(a,e,...i)=>v(((t,a=[n])=>{const e=[],s=(t,n)=>n==d(a)?A(e,t):null===a[n]?U(t,(t=>s(t,n+1))):v([a[n],null],(a=>s(nt(t,a),n+1)));return s(t,0),e})(a,e),(a=>U(a,(a=>nt(s,a)[0](t,...e??[],...i))))),t=>l(nt(s,t),(([,a,i])=>(ot(a,i??[n],void 0,(a=>(q(a,t),x(a)?1:0))),it(s,t),e(t),i))),a=>l(nt(s,a),(([a,,e=[],n,s])=>{const i=(...r)=>{const o=d(r);o==d(e)?a(t,...r,...s(r)):c(e[o])?v(n[o]?.(...r)??[],(t=>i(...r,t))):i(...r,e[o])};i()}))]})(),P=t=>{t!=m&&(m=t,R(S,void 0,m))},_=a=>{($&&y(a?.[0])?1===a?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===a?.[2]?t.applyChanges:t.setContent)(a)},F=async t=>(2!=m&&(P(1),T++,await Y((async()=>{try{const e=await a();y(e)?_(e):t?L(t):f("Content is not an array: "+e)}catch(a){r?.(a),t&&L(t)}P(0)}))),k),j=()=>(g&&(i(g),g=void 0),k),B=async t=>(1!=m&&(P(2),N++,await Y((async()=>{try{await e(C,t)}catch(t){r?.(t)}P(0)}))),k),J=()=>(h&&(t.delListener(h),h=void 0),k),Y=async(...t)=>(A(nt(wt,p),...t),await(async()=>{if(!nt(yt,p)){for(it(yt,p,1);!c(E=b(nt(wt,p)));)try{await E()}catch(t){r?.(t)}it(yt,p,0)}})(),k),k={load:F,startAutoLoad:async t=>{j(),await F(t);try{g=await s((async(t,a)=>{a||t?2!=m&&(P(1),T++,_(a??t),P(0)):await F()}))}catch(t){r?.(t)}return k},stopAutoLoad:j,isAutoLoading:()=>!c(g),save:B,startAutoSave:async()=>(J(),await B(),h=t.addDidFinishTransactionListener((()=>{const t=O();I(t)&&B(t)})),k),stopAutoSave:J,isAutoSaving:()=>!c(h),getStatus:()=>m,addStatusListener:t=>D(t,S),delListener:a=>(M(a),t),schedule:Y,getStore:()=>t,destroy:()=>(nt(wt,p).splice(0,void 0),j().stopAutoSave()),getStats:()=>({loads:T,saves:N}),...u};return G(k)},pt=(t,a,e,n,i,r=ft,o,l)=>{const u=et();return[async()=>{u.clear(),g(await e(t,a),(({tn:t,cn:a})=>lt(rt(u,t,ct),a)))},async(a,e)=>((t,a)=>j(nt(u,t),a))(a,e)?H(m(g(await t(L+_(a)),(t=>{return[t[e],l?(a=Q(t,e),n=l,H(V(a,((t,a)=>[a,n(t,a)])))):Q(t,e)];var a,n})),(([t,a])=>!c(t)&&!Z(a)))):{},async(a,e,n,l,y,w=!1)=>{const d=ct();V(n??{},(t=>g(z(t??{}),(t=>lt(d,t)))));const f=B(d);if(!w&&y&&h(f)&&j(u,a))return await t("DROP "+C+_(a)),void it(u,a);const v=nt(u,a),b=ct(B(v));if(h(f)||(j(u,a)?await p(g([e,...f],(async(n,s)=>{q(b,n)||(await t(O+_(a)+"ADD"+_(n)+i),0==s&&await t("CREATE UNIQUE INDEX pk ON "+_(a)+`(${_(e)})`),lt(v,n))}))):(await t("CREATE "+C+_(a)+`(${_(e)}${i} PRIMARY KEY${E(g(f,(t=>s+_(t)+i)))});`),it(u,a,ct([e,...f])))),await p([...!w&&l?g(B(b),(async n=>{n!=e&&(await t(O+_(a)+"DROP"+_(n)),q(v,n))})):[]]),w)c(n)?await t(I+_(a)+$+" true"):await p(V(n,(async(n,s)=>{c(n)?await t(I+_(a)+$+_(e)+"=$1",[s]):h(f)||await r(t,a,e,z(n),{[s]:o?g(W(n),o):W(n)},v)})));else if(h(f))j(u,a)&&await t(I+_(a)+$+" true");else{const s=m(B(nt(u,a)),(t=>t!=e)),i={},c=[];V(n??{},((t,a)=>{i[a]=g(s,(a=>o?o(t?.[a]):t?.[a])),A(c,a)})),await r(t,a,e,s,i),await t(I+_(a)+$+_(e)+`NOT IN(${F(c)})`,c)}},async a=>{let e;await t("BEGIN");try{e=await a()}catch(t){n?.(t)}return await t("END"),e}]},ft=async(t,a,e,n,i)=>{const r=[1];await t("INSERT INTO"+_(a)+"("+((...t)=>E(g(t,_),s))(e,...n)+")VALUES"+E(V(i,(t=>"($"+r[0]+++","+F(t,r)+")")),s)+"ON CONFLICT("+_(e)+")DO UPDATE SET"+E(g(n,(t=>_(t)+"=excluded."+_(t))),s),V(i,((t,a)=>[a,...g(t,(t=>t??null))])).flat())},vt=(t,a,e,n,s,i,r,[o,c,l],u,y,w,d,p,f)=>{const[v,E,g,h]=pt(a,u,y,s,p,f),m=dt(t,(async()=>await h((async()=>{return await v(),t=(await E(o,c))[T]?.[l]??"null",at(t,((t,a)=>""===a?void 0:a));var t}))),(async t=>await h((async()=>{var a;await v(),await g(o,c,{[T]:{[l]:(a=t()??null,tt(a,((t,a)=>void 0===a?"":a)))}},!0,!0)}))),e,n,s,r,{[d]:()=>w,destroy:()=>(m.stopAutoLoad().stopAutoSave(),i(),m)},0,w);return m},Et=(t,a,e,n,s,i,r,[o,l,[u,y,w]],d,f,v,E,g,h,A,b)=>{const[S,$,C,O]=pt(a,d,f,s,g,h,A,b),I=async(t,a)=>await p(st(l,(async([e,n,s,i],r)=>{a&&!(r in t)||await C(e,n,t[r],s,i,a)}))),L=async(t,a)=>y?await C(w,N,{[T]:t},!0,!0,a):null,D=dt(t,(async()=>await O((async()=>{await S();const t=await(async()=>H(m(await p(st(o,(async([t,a],e)=>[t,await $(e,a)]))),(t=>!Z(t[1])))))(),a=await(async()=>u?(await $(w,N))[T]:{})();return Z(t)&&c(a)?void 0:[t,a]}))),(async(t,a)=>await O((async()=>{if(await S(),c(a)){const[a,e]=t();await I(a),await L(e)}else await I(a[0],!0),await L(a[1],!0)}))),e,n,s,r,{[E]:()=>v,destroy:()=>(D.stopAutoLoad().stopAutoSave(),i(),D)},0,v);return D},gt="ColumnName",ht="store",mt="json",At=ht+"TableName",bt=ht+"Id"+gt,Tt=ht+gt,Nt="autoLoadIntervalSeconds",St="rowId"+gt,$t="tableId",Ct="tableName",Ot="deleteEmptyColumns",It="deleteEmptyTable",Lt={mode:mt,[Nt]:1},Dt={load:0,save:0,[Ct]:e+"_values"},Rt=(t,a,e,n,s)=>{const i=et();return V(t,((t,r)=>{const o=w(W(K(a,u(t)?{[e]:t}:t)),0,X(a));c(o[0])||n(r,o[0])||(s(r,o[0]),it(i,r,o))})),i},Mt=(t,a,s,i,r,c,l,y,d,p,f="getDb",v)=>{let E,g,h;const m=((t,a)=>a?async(e,n)=>(a(e,n),await t(e,n)):t)(s,c),[A,b,T,C]=(t=>{const a=(t=>K(Lt,u(t)?{[At]:t}:t??{}))(t),n=a[Nt];if(a.mode==mt){const t=a[At]??e;return[1,n,[t,a[bt]??N,a[Tt]??ht],ct(t)]}const{tables:{load:s={},save:i={}}={},values:r={}}=a,o=w(W(K(Dt,r)),0,X(Dt)),c=o[2],l=ct(c),y=ct(c);return[0,n,[Rt(s,{[$t]:null,[St]:N},$t,(t=>j(y,t)),(t=>lt(l,t))),Rt(i,{[Ct]:null,[St]:N,[Ot]:0,[It]:0},Ct,((t,a)=>j(y,a)),((t,a)=>lt(l,a))),o],l]})(a);return(A?vt:Et)(t,m,(t=>{let a;const e=()=>a=setInterval((async()=>{try{const[{d:a,s:e,c:n}]=await m(`${S} ${R} d,${M} s,TOTAL_CHANGES() c FROM ${D}${R} JOIN ${D}${M}`);a==E&&e==g&&n==h||(null!=E&&t(),E=a,g=e,h=n)}catch{}}),1e3*b),n=()=>{E=g=h=null,o(a)},s=i((a=>{C.has(a)&&(n(),t(),e())}));return e(),()=>{n(),r(s)}}),(t=>t()),l,y,d,T,B(C),(async(t,a)=>await t(`${S} t.name tn,c.name cn FROM ${P}list()t,${P}info(t.name)c ${$} t.schema='main'AND t.type IN('table','view')AND t.name IN(${F(a)})ORDER BY t.name,c.name`,a)),p,f,n,v,(t=>!0===t?1:!1===t?0:t),void 0)};t.createElectricSqlPersister=(t,a,e,n,s)=>Mt(t,e,(async(t,e=[])=>await a.db.raw({sql:t,args:e})),(t=>a.notifier.subscribeToDataChanges((e=>v(a.notifier.alias(e),(({tablename:a})=>t(a)))))),(t=>t()),n,s,(()=>0),1,a,"getElectricClient")},"object"==typeof exports&&"undefined"!=typeof module?a(exports):"function"==typeof define&&define.amd?define(["exports"],a):a((t="undefined"!=typeof globalThis?globalThis:t||self).TinyBasePersisterElectricSql={});
1
+ var t,a;t=this,a=function(t){"use strict";const a=t=>typeof t,e="tinybase",n="",s=",",i=a(n),o=Promise,r=clearInterval,c=t=>null==t,l=(t,a,e)=>c(t)?e?.():a(t),u=t=>a(t)==i,y=t=>Array.isArray(t),w=(t,a,e)=>t.slice(a,e),d=t=>t.length,p=async t=>o.all(t),f=t=>{throw Error(t)},v=(t,a)=>t.forEach(a),E=(t,a="")=>t.join(a),g=(t,a)=>t.map(a),h=t=>0==d(t),m=(t,a)=>t.filter(a),A=(t,...a)=>t.push(...a),b=t=>t.shift(),T="_",N="_id",S="SELECT",$="WHERE",C="TABLE",O="ALTER "+C,I="DELETE FROM",L=S+"*FROM",D="pragma_",R="data_version",M="schema_version",P="pragma_table_",_=t=>`"${t.replace(/"/g,'""')}"`,F=(t,a=[1])=>E(g(t,(()=>"$"+a[0]++)),s),j=(t,a)=>t?.has(a)??!1,x=t=>c(t)||0==(t=>t?.size??0)(t),B=t=>[...t?.values()??[]],U=(t,a)=>t?.forEach(a),q=(t,a)=>t?.delete(a),J=Object,Y=t=>J.getPrototypeOf(t),k=J.entries,z=J.keys,G=J.freeze,H=(t=[])=>J.fromEntries(t),K=(...t)=>J.assign({},...t),Q=(t,a)=>(delete t[a],t),V=(t,a)=>g(k(t),(([t,e])=>a(e,t))),W=(t,a)=>H(V(t,((t,e)=>[e,a(t,e)]))),X=t=>J.values(t),Z=t=>d(z(t)),tt=t=>(t=>!c(t)&&l(Y(t),(t=>t==J.prototype||c(Y(t))),(()=>!0)))(t)&&0==Z(t),at=JSON.stringify,et=JSON.parse,nt=t=>new Map(t),st=(t,a)=>t?.get(a),it=(t,a)=>g([...t?.entries()??[]],(([t,e])=>a(e,t))),ot=(t,a,e)=>c(e)?(q(t,a),t):t?.set(a,e),rt=(t,a,e,n)=>(j(t,a)?n?.(st(t,a)):ot(t,a,e()),st(t,a)),ct=(t,a,e,n,s=0)=>l((e?rt:st)(t,a[s],s>d(a)-2?e:nt),(i=>{if(s>d(a)-2)return n?.(i)&&ot(t,a[s]),i;const o=ct(i,a,e,n,s+1);return x(i)&&ot(t,a[s]),o})),lt=t=>new Set(y(t)||c(t)?t:[t]),ut=(t,a)=>t?.add(a),yt=/^\d+$/,wt=nt(),dt=nt(),pt=(t,a,e,s,i,o,r,u={},w=0,p=[])=>{let E,g,h,m=0,T=0,N=0;rt(wt,p,(()=>0)),rt(dt,p,(()=>[]));const S=nt(),[$,C,O,I,L]=((t=1,a,e)=>1!=t&&a.isMergeable()?[1,a.getMergeableContent,()=>a.getTransactionMergeableChanges(!e),([[t],[a]])=>!tt(t)||!tt(a),a.setDefaultContent]:2!=t?[0,a.getContent,a.getTransactionChanges,([t,a])=>!tt(t)||!tt(a),a.setContent]:f("Store type not supported by this Persister"))(r,t,w),[D,R,M]=(()=>{let t;const[a,e]=(()=>{const t=[];let a=0;return[e=>(e?b(t):null)??n+a++,a=>{yt.test(a)&&d(t)<1e3&&A(t,a)}]})(),s=nt();return[(e,i,o,r=[],c=()=>[])=>{t??=k;const l=a(1);return ot(s,l,[e,i,o,r,c]),ut(ct(i,o??[n],lt),l),l},(a,e,...i)=>v(((t,a=[n])=>{const e=[],s=(t,n)=>n==d(a)?A(e,t):null===a[n]?U(t,(t=>s(t,n+1))):v([a[n],null],(a=>s(st(t,a),n+1)));return s(t,0),e})(a,e),(a=>U(a,(a=>st(s,a)[0](t,...e??[],...i))))),t=>l(st(s,t),(([,a,i])=>(ct(a,i??[n],void 0,(a=>(q(a,t),x(a)?1:0))),ot(s,t),e(t),i))),a=>l(st(s,a),(([a,,e=[],n,s])=>{const i=(...o)=>{const r=d(o);r==d(e)?a(t,...o,...s(o)):c(e[r])?v(n[r]?.(...o)??[],(t=>i(...o,t))):i(...o,e[r])};i()}))]})(),P=t=>{t!=m&&(m=t,R(S,void 0,m))},_=a=>{($&&y(a?.[0])?1===a?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===a?.[2]?t.applyChanges:t.setContent)(a)},F=async t=>(2!=m&&(P(1),T++,await Y((async()=>{try{const e=await a();y(e)?_(e):t?L(t):f("Content is not an array: "+e)}catch(a){o?.(a),t&&L(t)}P(0)}))),k),j=()=>(g&&(i(g),g=void 0),k),B=async t=>(1!=m&&(P(2),N++,await Y((async()=>{try{await e(C,t)}catch(t){o?.(t)}P(0)}))),k),J=()=>(h&&(t.delListener(h),h=void 0),k),Y=async(...t)=>(A(st(dt,p),...t),await(async()=>{if(!st(wt,p)){for(ot(wt,p,1);!c(E=b(st(dt,p)));)try{await E()}catch(t){o?.(t)}ot(wt,p,0)}})(),k),k={load:F,startAutoLoad:async t=>{j(),await F(t);try{g=await s((async(t,a)=>{a||t?2!=m&&(P(1),T++,_(a??t),P(0)):await F()}))}catch(t){o?.(t)}return k},stopAutoLoad:j,isAutoLoading:()=>!c(g),save:B,startAutoSave:async()=>(J(),await B(),h=t.addDidFinishTransactionListener((()=>{const t=O();I(t)&&B(t)})),k),stopAutoSave:J,isAutoSaving:()=>!c(h),getStatus:()=>m,addStatusListener:t=>D(t,S),delListener:a=>(M(a),t),schedule:Y,getStore:()=>t,destroy:()=>(st(dt,p).splice(0,void 0),j().stopAutoSave()),getStats:()=>({loads:T,saves:N}),...u};return G(k)},ft=(t,a,e,n,i,o=vt,r,l)=>{const u=nt();return[async()=>{u.clear(),g(await e(t,a),(({tn:t,cn:a})=>ut(rt(u,t,lt),a)))},async(a,e)=>((t,a)=>j(st(u,t),a))(a,e)?H(m(g(await t(L+_(a)),(t=>[t[e],l?W(Q(t,e),l):Q(t,e)])),(([t,a])=>!c(t)&&!tt(a)))):{},async(a,e,n,l,y,w=!1)=>{const d=lt();W(n??{},(t=>g(z(t??{}),(t=>ut(d,t)))));const f=B(d);if(!w&&y&&h(f)&&j(u,a))return await t("DROP "+C+_(a)),void ot(u,a);const v=st(u,a),b=lt(B(v));if(h(f)||(j(u,a)?await p(g([e,...f],(async(n,s)=>{q(b,n)||(await t(O+_(a)+"ADD"+_(n)+i),0==s&&await t("CREATE UNIQUE INDEX pk ON "+_(a)+`(${_(e)})`),ut(v,n))}))):(await t("CREATE "+C+_(a)+`(${_(e)}${i} PRIMARY KEY${E(g(f,(t=>s+_(t)+i)))});`),ot(u,a,lt([e,...f])))),await p([...!w&&l?g(B(b),(async n=>{n!=e&&(await t(O+_(a)+"DROP"+_(n)),q(v,n))})):[]]),w)c(n)?await t(I+_(a)+$+" true"):await p(V(n,(async(n,s)=>{c(n)?await t(I+_(a)+$+_(e)+"=$1",[s]):h(f)||await o(t,a,e,z(n),{[s]:r?g(X(n),r):X(n)},v)})));else if(h(f))j(u,a)&&await t(I+_(a)+$+" true");else{const s=m(B(st(u,a)),(t=>t!=e)),i={},c=[];W(n??{},((t,a)=>{i[a]=g(s,(a=>r?r(t?.[a]):t?.[a])),A(c,a)})),await o(t,a,e,s,i),await t(I+_(a)+$+_(e)+`NOT IN(${F(c)})`,c)}},async a=>{let e;await t("BEGIN");try{e=await a()}catch(t){n?.(t)}return await t("END"),e}]},vt=async(t,a,e,n,i)=>{const o=[1];await t("INSERT INTO"+_(a)+"("+((...t)=>E(g(t,_),s))(e,...n)+")VALUES"+E(V(i,(t=>"($"+o[0]+++","+F(t,o)+")")),s)+"ON CONFLICT("+_(e)+")DO UPDATE SET"+E(g(n,(t=>_(t)+"=excluded."+_(t))),s),V(i,((t,a)=>[a,...g(t,(t=>t??null))])).flat())},Et=(t,a,e,n,s,i,o,[r,c,l],u,y,w,d,p,f)=>{const[v,E,g,h]=ft(a,u,y,s,p,f),m=pt(t,(async()=>await h((async()=>{return await v(),t=(await E(r,c))[T]?.[l]??"null",et(t,((t,a)=>""===a?void 0:a));var t}))),(async t=>await h((async()=>{var a;await v(),await g(r,c,{[T]:{[l]:(a=t()??null,at(a,((t,a)=>void 0===a?"":a)))}},!0,!0)}))),e,n,s,o,{[d]:()=>w,destroy:()=>(m.stopAutoLoad().stopAutoSave(),i(),m)},0,w);return m},gt=(t,a,e,n,s,i,o,[r,l,[u,y,w]],d,f,v,E,g,h,A,b)=>{const[S,$,C,O]=ft(a,d,f,s,g,h,A,b),I=async(t,a)=>await p(it(l,(async([e,n,s,i],o)=>{a&&!(o in t)||await C(e,n,t[o],s,i,a)}))),L=async(t,a)=>y?await C(w,N,{[T]:t},!0,!0,a):null,D=pt(t,(async()=>await O((async()=>{await S();const t=await(async()=>H(m(await p(it(r,(async([t,a],e)=>[t,await $(e,a)]))),(t=>!tt(t[1])))))(),a=await(async()=>u?(await $(w,N))[T]:{})();return tt(t)&&c(a)?void 0:[t,a]}))),(async(t,a)=>await O((async()=>{if(await S(),c(a)){const[a,e]=t();await I(a),await L(e)}else await I(a[0],!0),await L(a[1],!0)}))),e,n,s,o,{[E]:()=>v,destroy:()=>(D.stopAutoLoad().stopAutoSave(),i(),D)},0,v);return D},ht="ColumnName",mt="store",At="json",bt=mt+"TableName",Tt=mt+"Id"+ht,Nt=mt+ht,St="autoLoadIntervalSeconds",$t="rowId"+ht,Ct="tableId",Ot="tableName",It="deleteEmptyColumns",Lt="deleteEmptyTable",Dt={mode:At,[St]:1},Rt={load:0,save:0,[Ot]:e+"_values"},Mt=(t,a,e,n,s)=>{const i=nt();return W(t,((t,o)=>{const r=w(X(K(a,u(t)?{[e]:t}:t)),0,Z(a));c(r[0])||n(o,r[0])||(s(o,r[0]),ot(i,o,r))})),i},Pt=(t,a,s,i,o,c,l,y,d,p,f="getDb",v)=>{let E,g,h;const m=((t,a)=>a?async(e,n)=>(a(e,n),await t(e,n)):t)(s,c),[A,b,T,C]=(t=>{const a=(t=>K(Dt,u(t)?{[bt]:t}:t??{}))(t),n=a[St];if(a.mode==At){const t=a[bt]??e;return[1,n,[t,a[Tt]??N,a[Nt]??mt],lt(t)]}const{tables:{load:s={},save:i={}}={},values:o={}}=a,r=w(X(K(Rt,o)),0,Z(Rt)),c=r[2],l=lt(c),y=lt(c);return[0,n,[Mt(s,{[Ct]:null,[$t]:N},Ct,(t=>j(y,t)),(t=>ut(l,t))),Mt(i,{[Ot]:null,[$t]:N,[It]:0,[Lt]:0},Ot,((t,a)=>j(y,a)),((t,a)=>ut(l,a))),r],l]})(a);return(A?Et:gt)(t,m,(t=>{let a;const e=()=>a=setInterval((async()=>{try{const[{d:a,s:e,c:n}]=await m(`${S} ${R} d,${M} s,TOTAL_CHANGES() c FROM ${D}${R} JOIN ${D}${M}`);a==E&&e==g&&n==h||(null!=E&&t(),E=a,g=e,h=n)}catch{}}),1e3*b),n=()=>{E=g=h=null,r(a)},s=i((a=>{C.has(a)&&(n(),t(),e())}));return e(),()=>{n(),o(s)}}),(t=>t()),l,y,d,T,B(C),(async(t,a)=>await t(`${S} t.name tn,c.name cn FROM ${P}list()t,${P}info(t.name)c ${$} t.schema='main'AND t.type IN('table','view')AND t.name IN(${F(a)})ORDER BY t.name,c.name`,a)),p,f,n,v,(t=>!0===t?1:!1===t?0:t),void 0)};t.createElectricSqlPersister=(t,a,e,n,s)=>Pt(t,e,(async(t,e=[])=>await a.db.raw({sql:t,args:e})),(t=>a.notifier.subscribeToDataChanges((e=>v(a.notifier.alias(e),(({tablename:a})=>t(a)))))),(t=>t()),n,s,(()=>0),1,a,"getElectricClient")},"object"==typeof exports&&"undefined"!=typeof module?a(exports):"function"==typeof define&&define.amd?define(["exports"],a):a((t="undefined"!=typeof globalThis?globalThis:t||self).TinyBasePersisterElectricSql={});
@@ -1 +1 @@
1
- var t,a;t=this,a=function(t,a){"use strict";const e=t=>typeof t,n="tinybase",s="",i=",",o=e(s),r=Promise,c=clearInterval,l=t=>null==t,u=(t,a,e)=>l(t)?e?.():a(t),y=t=>e(t)==o,d=t=>Array.isArray(t),w=(t,a,e)=>t.slice(a,e),p=t=>t.length,v=async t=>r.all(t),f=t=>{throw Error(t)},E=(t,a)=>t.forEach(a),g=(t,a="")=>t.join(a),h=(t,a)=>t.map(a),m=t=>0==p(t),A=(t,a)=>t.filter(a),N=(t,...a)=>t.push(...a),S=t=>t.shift(),T="_",$="_id",b="SELECT",C="WHERE",O="TABLE",L="ALTER "+O,I="DELETE FROM",D=b+"*FROM",R="pragma_",M="data_version",x="schema_version",P="pragma_table_",_=t=>`"${t.replace(/"/g,'""')}"`,q=(t,a=[1])=>g(h(t,(()=>"$"+a[0]++)),i),F=(t,a)=>t?.has(a)??!1,j=t=>l(t)||0==(t=>t?.size??0)(t),B=t=>[...t?.values()??[]],U=(t,a)=>t?.forEach(a),J=(t,a)=>t?.delete(a),Y=Object,k=t=>Y.getPrototypeOf(t),z=Y.entries,G=Y.keys,H=Y.freeze,K=(t=[])=>Y.fromEntries(t),Q=(...t)=>Y.assign({},...t),V=(t,a)=>(delete t[a],t),W=(t,a)=>h(z(t),(([t,e])=>a(e,t))),X=t=>Y.values(t),Z=t=>p(G(t)),tt=t=>(t=>!l(t)&&u(k(t),(t=>t==Y.prototype||l(k(t))),(()=>!0)))(t)&&0==Z(t),at=JSON.stringify,et=JSON.parse,nt=t=>new Map(t),st=(t,a)=>t?.get(a),it=(t,a)=>h([...t?.entries()??[]],(([t,e])=>a(e,t))),ot=(t,a,e)=>l(e)?(J(t,a),t):t?.set(a,e),rt=(t,a,e,n)=>(F(t,a)?n?.(st(t,a)):ot(t,a,e()),st(t,a)),ct=(t,a,e,n,s=0)=>u((e?rt:st)(t,a[s],s>p(a)-2?e:nt),(i=>{if(s>p(a)-2)return n?.(i)&&ot(t,a[s]),i;const o=ct(i,a,e,n,s+1);return j(i)&&ot(t,a[s]),o})),lt=t=>new Set(d(t)||l(t)?t:[t]),ut=(t,a)=>t?.add(a),yt=/^\d+$/,dt=nt(),wt=nt(),pt=(t,a,e,n,i,o,r,c={},y=0,w=[])=>{let v,g,h,m=0,A=0,T=0;rt(dt,w,(()=>0)),rt(wt,w,(()=>[]));const $=nt(),[b,C,O,L,I]=((t=1,a,e)=>1!=t&&a.isMergeable()?[1,a.getMergeableContent,()=>a.getTransactionMergeableChanges(!e),([[t],[a]])=>!tt(t)||!tt(a),a.setDefaultContent]:2!=t?[0,a.getContent,a.getTransactionChanges,([t,a])=>!tt(t)||!tt(a),a.setContent]:f("Store type not supported by this Persister"))(r,t,y),[D,R,M]=(()=>{let t;const[a,e]=(()=>{const t=[];let a=0;return[e=>(e?S(t):null)??s+a++,a=>{yt.test(a)&&p(t)<1e3&&N(t,a)}]})(),n=nt();return[(e,i,o,r=[],c=()=>[])=>{t??=k;const l=a(1);return ot(n,l,[e,i,o,r,c]),ut(ct(i,o??[s],lt),l),l},(a,e,...i)=>E(((t,a=[s])=>{const e=[],n=(t,s)=>s==p(a)?N(e,t):null===a[s]?U(t,(t=>n(t,s+1))):E([a[s],null],(a=>n(st(t,a),s+1)));return n(t,0),e})(a,e),(a=>U(a,(a=>st(n,a)[0](t,...e??[],...i))))),t=>u(st(n,t),(([,a,i])=>(ct(a,i??[s],void 0,(a=>(J(a,t),j(a)?1:0))),ot(n,t),e(t),i))),a=>u(st(n,a),(([a,,e=[],n,s])=>{const i=(...o)=>{const r=p(o);r==p(e)?a(t,...o,...s(o)):l(e[r])?E(n[r]?.(...o)??[],(t=>i(...o,t))):i(...o,e[r])};i()}))]})(),x=t=>{t!=m&&(m=t,R($,void 0,m))},P=a=>{(b&&d(a?.[0])?1===a?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===a?.[2]?t.applyChanges:t.setContent)(a)},_=async t=>(2!=m&&(x(1),A++,await Y((async()=>{try{const e=await a();d(e)?P(e):t?I(t):f("Content is not an array: "+e)}catch(a){o?.(a),t&&I(t)}x(0)}))),k),q=()=>(g&&(i(g),g=void 0),k),F=async t=>(1!=m&&(x(2),T++,await Y((async()=>{try{await e(C,t)}catch(t){o?.(t)}x(0)}))),k),B=()=>(h&&(t.delListener(h),h=void 0),k),Y=async(...t)=>(N(st(wt,w),...t),await(async()=>{if(!st(dt,w)){for(ot(dt,w,1);!l(v=S(st(wt,w)));)try{await v()}catch(t){o?.(t)}ot(dt,w,0)}})(),k),k={load:_,startAutoLoad:async t=>{q(),await _(t);try{g=await n((async(t,a)=>{a||t?2!=m&&(x(1),A++,P(a??t),x(0)):await _()}))}catch(t){o?.(t)}return k},stopAutoLoad:q,isAutoLoading:()=>!l(g),save:F,startAutoSave:async()=>(B(),await F(),h=t.addDidFinishTransactionListener((()=>{const t=O();L(t)&&F(t)})),k),stopAutoSave:B,isAutoSaving:()=>!l(h),getStatus:()=>m,addStatusListener:t=>D(t,$),delListener:a=>(M(a),t),schedule:Y,getStore:()=>t,destroy:()=>(st(wt,w).splice(0,void 0),q().stopAutoSave()),getStats:()=>({loads:A,saves:T}),...c};return H(k)},vt=(t,a,e,n,s,o=ft,r,c)=>{const u=nt();return[async()=>{u.clear(),h(await e(t,a),(({tn:t,cn:a})=>ut(rt(u,t,lt),a)))},async(a,e)=>((t,a)=>F(st(u,t),a))(a,e)?K(A(h(await t(D+_(a)),(t=>{return[t[e],c?(a=V(t,e),n=c,K(W(a,((t,a)=>[a,n(t,a)])))):V(t,e)];var a,n})),(([t,a])=>!l(t)&&!tt(a)))):{},async(a,e,n,c,y,d=!1)=>{const w=lt();W(n??{},(t=>h(G(t??{}),(t=>ut(w,t)))));const p=B(w);if(!d&&y&&m(p)&&F(u,a))return await t("DROP "+O+_(a)),void ot(u,a);const f=st(u,a),E=lt(B(f));if(m(p)||(F(u,a)?await v(h([e,...p],(async(n,i)=>{J(E,n)||(await t(L+_(a)+"ADD"+_(n)+s),0==i&&await t("CREATE UNIQUE INDEX pk ON "+_(a)+`(${_(e)})`),ut(f,n))}))):(await t("CREATE "+O+_(a)+`(${_(e)}${s} PRIMARY KEY${g(h(p,(t=>i+_(t)+s)))});`),ot(u,a,lt([e,...p])))),await v([...!d&&c?h(B(E),(async n=>{n!=e&&(await t(L+_(a)+"DROP"+_(n)),J(f,n))})):[]]),d)l(n)?await t(I+_(a)+C+" true"):await v(W(n,(async(n,s)=>{l(n)?await t(I+_(a)+C+_(e)+"=$1",[s]):m(p)||await o(t,a,e,G(n),{[s]:r?h(X(n),r):X(n)},f)})));else if(m(p))F(u,a)&&await t(I+_(a)+C+" true");else{const s=A(B(st(u,a)),(t=>t!=e)),i={},c=[];W(n??{},((t,a)=>{i[a]=h(s,(a=>r?r(t?.[a]):t?.[a])),N(c,a)})),await o(t,a,e,s,i),await t(I+_(a)+C+_(e)+`NOT IN(${q(c)})`,c)}},async a=>{let e;await t("BEGIN");try{e=await a()}catch(t){n?.(t)}return await t("END"),e}]},ft=async(t,a,e,n,s)=>{const o=[1];await t("INSERT INTO"+_(a)+"("+((...t)=>g(h(t,_),i))(e,...n)+")VALUES"+g(W(s,(t=>"($"+o[0]+++","+q(t,o)+")")),i)+"ON CONFLICT("+_(e)+")DO UPDATE SET"+g(h(n,(t=>_(t)+"=excluded."+_(t))),i),W(s,((t,a)=>[a,...h(t,(t=>t??null))])).flat())},Et=(t,a,e,n,s,i,o,[r,c,l],u,y,d,w,p,v)=>{const[f,E,g,h]=vt(a,u,y,s,p,v),m=pt(t,(async()=>await h((async()=>{return await f(),t=(await E(r,c))[T]?.[l]??"null",et(t,((t,a)=>""===a?void 0:a));var t}))),(async t=>await h((async()=>{var a;await f(),await g(r,c,{[T]:{[l]:(a=t()??null,at(a,((t,a)=>void 0===a?"":a)))}},!0,!0)}))),e,n,s,o,{[w]:()=>d,destroy:()=>(m.stopAutoLoad().stopAutoSave(),i(),m)},0,d);return m},gt=(t,a,e,n,s,i,o,[r,c,[u,y,d]],w,p,f,E,g,h,m,N)=>{const[S,b,C,O]=vt(a,w,p,s,g,h,m,N),L=async(t,a)=>await v(it(c,(async([e,n,s,i],o)=>{a&&!(o in t)||await C(e,n,t[o],s,i,a)}))),I=async(t,a)=>y?await C(d,$,{[T]:t},!0,!0,a):null,D=pt(t,(async()=>await O((async()=>{await S();const t=await(async()=>K(A(await v(it(r,(async([t,a],e)=>[t,await b(e,a)]))),(t=>!tt(t[1])))))(),a=await(async()=>u?(await b(d,$))[T]:{})();return tt(t)&&l(a)?void 0:[t,a]}))),(async(t,a)=>await O((async()=>{if(await S(),l(a)){const[a,e]=t();await L(a),await I(e)}else await L(a[0],!0),await I(a[1],!0)}))),e,n,s,o,{[E]:()=>f,destroy:()=>(D.stopAutoLoad().stopAutoSave(),i(),D)},0,f);return D},ht="ColumnName",mt="store",At="json",Nt=mt+"TableName",St=mt+"Id"+ht,Tt=mt+ht,$t="autoLoadIntervalSeconds",bt="rowId"+ht,Ct="tableId",Ot="tableName",Lt="deleteEmptyColumns",It="deleteEmptyTable",Dt={mode:At,[$t]:1},Rt={load:0,save:0,[Ot]:n+"_values"},Mt=(t,a,e,n,s)=>{const i=nt();return W(t,((t,o)=>{const r=w(X(Q(a,y(t)?{[e]:t}:t)),0,Z(a));l(r[0])||n(o,r[0])||(s(o,r[0]),ot(i,o,r))})),i},xt=(t,a,e,i,o,r,l,u,d,p,v="getDb",f)=>{let E,g,h;const m=((t,a)=>a?async(e,n)=>(a(e,n),await t(e,n)):t)(e,r),[A,N,S,T]=(t=>{const a=(t=>Q(Dt,y(t)?{[Nt]:t}:t??{}))(t),e=a[$t];if(a.mode==At){const t=a[Nt]??n;return[1,e,[t,a[St]??$,a[Tt]??mt],lt(t)]}const{tables:{load:s={},save:i={}}={},values:o={}}=a,r=w(X(Q(Rt,o)),0,Z(Rt)),c=r[2],l=lt(c),u=lt(c);return[0,e,[Mt(s,{[Ct]:null,[bt]:$},Ct,(t=>F(u,t)),(t=>ut(l,t))),Mt(i,{[Ot]:null,[bt]:$,[Lt]:0,[It]:0},Ot,((t,a)=>F(u,a)),((t,a)=>ut(l,a))),r],l]})(a);return(A?Et:gt)(t,m,(t=>{let a;const e=()=>a=setInterval((async()=>{try{const[{d:a,s:e,c:n}]=await m(`${b} ${M} d,${x} s,TOTAL_CHANGES() c FROM ${R}${M} JOIN ${R}${x}`);a==E&&e==g&&n==h||(null!=E&&t(),E=a,g=e,h=n)}catch{}}),1e3*N),n=()=>{E=g=h=null,c(a)},s=i((a=>{T.has(a)&&(n(),t(),e())}));return e(),()=>{n(),o(s)}}),(t=>t()),l,u,d,S,B(T),(async(t,a)=>await t(`${b} t.name tn,c.name cn FROM ${P}list()t,${P}info(t.name)c ${C} t.schema='main'AND t.type IN('table','view')AND t.name IN(${q(a)})ORDER BY t.name,c.name`,a)),p,v,s,f,(t=>!0===t?1:!1===t?0:t),void 0)};t.createExpoSqlitePersister=(t,e,n,s,i)=>xt(t,n,(async(t,a=[])=>await e.getAllAsync(t,a)),(t=>a.addDatabaseChangeListener((({tableName:a})=>t(a)))),(t=>t.remove()),s,i,(()=>0),3,e)},"object"==typeof exports&&"undefined"!=typeof module?a(exports,require("expo-sqlite")):"function"==typeof define&&define.amd?define(["exports","expo-sqlite"],a):a((t="undefined"!=typeof globalThis?globalThis:t||self).TinyBasePersisterExpoSqlite={},t["expo-sqlite"]);
1
+ var t,a;t=this,a=function(t,a){"use strict";const e=t=>typeof t,n="tinybase",s="",i=",",o=e(s),r=Promise,c=clearInterval,l=t=>null==t,y=(t,a,e)=>l(t)?e?.():a(t),u=t=>e(t)==o,d=t=>Array.isArray(t),w=(t,a,e)=>t.slice(a,e),p=t=>t.length,v=async t=>r.all(t),f=t=>{throw Error(t)},E=(t,a)=>t.forEach(a),g=(t,a="")=>t.join(a),h=(t,a)=>t.map(a),m=t=>0==p(t),A=(t,a)=>t.filter(a),N=(t,...a)=>t.push(...a),S=t=>t.shift(),T="_",$="_id",b="SELECT",C="WHERE",O="TABLE",L="ALTER "+O,I="DELETE FROM",D=b+"*FROM",R="pragma_",M="data_version",x="schema_version",P="pragma_table_",_=t=>`"${t.replace(/"/g,'""')}"`,q=(t,a=[1])=>g(h(t,(()=>"$"+a[0]++)),i),F=(t,a)=>t?.has(a)??!1,j=t=>l(t)||0==(t=>t?.size??0)(t),B=t=>[...t?.values()??[]],U=(t,a)=>t?.forEach(a),J=(t,a)=>t?.delete(a),Y=Object,k=t=>Y.getPrototypeOf(t),z=Y.entries,G=Y.keys,H=Y.freeze,K=(t=[])=>Y.fromEntries(t),Q=(...t)=>Y.assign({},...t),V=(t,a)=>(delete t[a],t),W=(t,a)=>h(z(t),(([t,e])=>a(e,t))),X=(t,a)=>K(W(t,((t,e)=>[e,a(t,e)]))),Z=t=>Y.values(t),tt=t=>p(G(t)),at=t=>(t=>!l(t)&&y(k(t),(t=>t==Y.prototype||l(k(t))),(()=>!0)))(t)&&0==tt(t),et=JSON.stringify,nt=JSON.parse,st=t=>new Map(t),it=(t,a)=>t?.get(a),ot=(t,a)=>h([...t?.entries()??[]],(([t,e])=>a(e,t))),rt=(t,a,e)=>l(e)?(J(t,a),t):t?.set(a,e),ct=(t,a,e,n)=>(F(t,a)?n?.(it(t,a)):rt(t,a,e()),it(t,a)),lt=(t,a,e,n,s=0)=>y((e?ct:it)(t,a[s],s>p(a)-2?e:st),(i=>{if(s>p(a)-2)return n?.(i)&&rt(t,a[s]),i;const o=lt(i,a,e,n,s+1);return j(i)&&rt(t,a[s]),o})),yt=t=>new Set(d(t)||l(t)?t:[t]),ut=(t,a)=>t?.add(a),dt=/^\d+$/,wt=st(),pt=st(),vt=(t,a,e,n,i,o,r,c={},u=0,w=[])=>{let v,g,h,m=0,A=0,T=0;ct(wt,w,(()=>0)),ct(pt,w,(()=>[]));const $=st(),[b,C,O,L,I]=((t=1,a,e)=>1!=t&&a.isMergeable()?[1,a.getMergeableContent,()=>a.getTransactionMergeableChanges(!e),([[t],[a]])=>!at(t)||!at(a),a.setDefaultContent]:2!=t?[0,a.getContent,a.getTransactionChanges,([t,a])=>!at(t)||!at(a),a.setContent]:f("Store type not supported by this Persister"))(r,t,u),[D,R,M]=(()=>{let t;const[a,e]=(()=>{const t=[];let a=0;return[e=>(e?S(t):null)??s+a++,a=>{dt.test(a)&&p(t)<1e3&&N(t,a)}]})(),n=st();return[(e,i,o,r=[],c=()=>[])=>{t??=k;const l=a(1);return rt(n,l,[e,i,o,r,c]),ut(lt(i,o??[s],yt),l),l},(a,e,...i)=>E(((t,a=[s])=>{const e=[],n=(t,s)=>s==p(a)?N(e,t):null===a[s]?U(t,(t=>n(t,s+1))):E([a[s],null],(a=>n(it(t,a),s+1)));return n(t,0),e})(a,e),(a=>U(a,(a=>it(n,a)[0](t,...e??[],...i))))),t=>y(it(n,t),(([,a,i])=>(lt(a,i??[s],void 0,(a=>(J(a,t),j(a)?1:0))),rt(n,t),e(t),i))),a=>y(it(n,a),(([a,,e=[],n,s])=>{const i=(...o)=>{const r=p(o);r==p(e)?a(t,...o,...s(o)):l(e[r])?E(n[r]?.(...o)??[],(t=>i(...o,t))):i(...o,e[r])};i()}))]})(),x=t=>{t!=m&&(m=t,R($,void 0,m))},P=a=>{(b&&d(a?.[0])?1===a?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===a?.[2]?t.applyChanges:t.setContent)(a)},_=async t=>(2!=m&&(x(1),A++,await Y((async()=>{try{const e=await a();d(e)?P(e):t?I(t):f("Content is not an array: "+e)}catch(a){o?.(a),t&&I(t)}x(0)}))),k),q=()=>(g&&(i(g),g=void 0),k),F=async t=>(1!=m&&(x(2),T++,await Y((async()=>{try{await e(C,t)}catch(t){o?.(t)}x(0)}))),k),B=()=>(h&&(t.delListener(h),h=void 0),k),Y=async(...t)=>(N(it(pt,w),...t),await(async()=>{if(!it(wt,w)){for(rt(wt,w,1);!l(v=S(it(pt,w)));)try{await v()}catch(t){o?.(t)}rt(wt,w,0)}})(),k),k={load:_,startAutoLoad:async t=>{q(),await _(t);try{g=await n((async(t,a)=>{a||t?2!=m&&(x(1),A++,P(a??t),x(0)):await _()}))}catch(t){o?.(t)}return k},stopAutoLoad:q,isAutoLoading:()=>!l(g),save:F,startAutoSave:async()=>(B(),await F(),h=t.addDidFinishTransactionListener((()=>{const t=O();L(t)&&F(t)})),k),stopAutoSave:B,isAutoSaving:()=>!l(h),getStatus:()=>m,addStatusListener:t=>D(t,$),delListener:a=>(M(a),t),schedule:Y,getStore:()=>t,destroy:()=>(it(pt,w).splice(0,void 0),q().stopAutoSave()),getStats:()=>({loads:A,saves:T}),...c};return H(k)},ft=(t,a,e,n,s,o=Et,r,c)=>{const y=st();return[async()=>{y.clear(),h(await e(t,a),(({tn:t,cn:a})=>ut(ct(y,t,yt),a)))},async(a,e)=>((t,a)=>F(it(y,t),a))(a,e)?K(A(h(await t(D+_(a)),(t=>[t[e],c?X(V(t,e),c):V(t,e)])),(([t,a])=>!l(t)&&!at(a)))):{},async(a,e,n,c,u,d=!1)=>{const w=yt();X(n??{},(t=>h(G(t??{}),(t=>ut(w,t)))));const p=B(w);if(!d&&u&&m(p)&&F(y,a))return await t("DROP "+O+_(a)),void rt(y,a);const f=it(y,a),E=yt(B(f));if(m(p)||(F(y,a)?await v(h([e,...p],(async(n,i)=>{J(E,n)||(await t(L+_(a)+"ADD"+_(n)+s),0==i&&await t("CREATE UNIQUE INDEX pk ON "+_(a)+`(${_(e)})`),ut(f,n))}))):(await t("CREATE "+O+_(a)+`(${_(e)}${s} PRIMARY KEY${g(h(p,(t=>i+_(t)+s)))});`),rt(y,a,yt([e,...p])))),await v([...!d&&c?h(B(E),(async n=>{n!=e&&(await t(L+_(a)+"DROP"+_(n)),J(f,n))})):[]]),d)l(n)?await t(I+_(a)+C+" true"):await v(W(n,(async(n,s)=>{l(n)?await t(I+_(a)+C+_(e)+"=$1",[s]):m(p)||await o(t,a,e,G(n),{[s]:r?h(Z(n),r):Z(n)},f)})));else if(m(p))F(y,a)&&await t(I+_(a)+C+" true");else{const s=A(B(it(y,a)),(t=>t!=e)),i={},c=[];X(n??{},((t,a)=>{i[a]=h(s,(a=>r?r(t?.[a]):t?.[a])),N(c,a)})),await o(t,a,e,s,i),await t(I+_(a)+C+_(e)+`NOT IN(${q(c)})`,c)}},async a=>{let e;await t("BEGIN");try{e=await a()}catch(t){n?.(t)}return await t("END"),e}]},Et=async(t,a,e,n,s)=>{const o=[1];await t("INSERT INTO"+_(a)+"("+((...t)=>g(h(t,_),i))(e,...n)+")VALUES"+g(W(s,(t=>"($"+o[0]+++","+q(t,o)+")")),i)+"ON CONFLICT("+_(e)+")DO UPDATE SET"+g(h(n,(t=>_(t)+"=excluded."+_(t))),i),W(s,((t,a)=>[a,...h(t,(t=>t??null))])).flat())},gt=(t,a,e,n,s,i,o,[r,c,l],y,u,d,w,p,v)=>{const[f,E,g,h]=ft(a,y,u,s,p,v),m=vt(t,(async()=>await h((async()=>{return await f(),t=(await E(r,c))[T]?.[l]??"null",nt(t,((t,a)=>""===a?void 0:a));var t}))),(async t=>await h((async()=>{var a;await f(),await g(r,c,{[T]:{[l]:(a=t()??null,et(a,((t,a)=>void 0===a?"":a)))}},!0,!0)}))),e,n,s,o,{[w]:()=>d,destroy:()=>(m.stopAutoLoad().stopAutoSave(),i(),m)},0,d);return m},ht=(t,a,e,n,s,i,o,[r,c,[y,u,d]],w,p,f,E,g,h,m,N)=>{const[S,b,C,O]=ft(a,w,p,s,g,h,m,N),L=async(t,a)=>await v(ot(c,(async([e,n,s,i],o)=>{a&&!(o in t)||await C(e,n,t[o],s,i,a)}))),I=async(t,a)=>u?await C(d,$,{[T]:t},!0,!0,a):null,D=vt(t,(async()=>await O((async()=>{await S();const t=await(async()=>K(A(await v(ot(r,(async([t,a],e)=>[t,await b(e,a)]))),(t=>!at(t[1])))))(),a=await(async()=>y?(await b(d,$))[T]:{})();return at(t)&&l(a)?void 0:[t,a]}))),(async(t,a)=>await O((async()=>{if(await S(),l(a)){const[a,e]=t();await L(a),await I(e)}else await L(a[0],!0),await I(a[1],!0)}))),e,n,s,o,{[E]:()=>f,destroy:()=>(D.stopAutoLoad().stopAutoSave(),i(),D)},0,f);return D},mt="ColumnName",At="store",Nt="json",St=At+"TableName",Tt=At+"Id"+mt,$t=At+mt,bt="autoLoadIntervalSeconds",Ct="rowId"+mt,Ot="tableId",Lt="tableName",It="deleteEmptyColumns",Dt="deleteEmptyTable",Rt={mode:Nt,[bt]:1},Mt={load:0,save:0,[Lt]:n+"_values"},xt=(t,a,e,n,s)=>{const i=st();return X(t,((t,o)=>{const r=w(Z(Q(a,u(t)?{[e]:t}:t)),0,tt(a));l(r[0])||n(o,r[0])||(s(o,r[0]),rt(i,o,r))})),i},Pt=(t,a,e,i,o,r,l,y,d,p,v="getDb",f)=>{let E,g,h;const m=((t,a)=>a?async(e,n)=>(a(e,n),await t(e,n)):t)(e,r),[A,N,S,T]=(t=>{const a=(t=>Q(Rt,u(t)?{[St]:t}:t??{}))(t),e=a[bt];if(a.mode==Nt){const t=a[St]??n;return[1,e,[t,a[Tt]??$,a[$t]??At],yt(t)]}const{tables:{load:s={},save:i={}}={},values:o={}}=a,r=w(Z(Q(Mt,o)),0,tt(Mt)),c=r[2],l=yt(c),y=yt(c);return[0,e,[xt(s,{[Ot]:null,[Ct]:$},Ot,(t=>F(y,t)),(t=>ut(l,t))),xt(i,{[Lt]:null,[Ct]:$,[It]:0,[Dt]:0},Lt,((t,a)=>F(y,a)),((t,a)=>ut(l,a))),r],l]})(a);return(A?gt:ht)(t,m,(t=>{let a;const e=()=>a=setInterval((async()=>{try{const[{d:a,s:e,c:n}]=await m(`${b} ${M} d,${x} s,TOTAL_CHANGES() c FROM ${R}${M} JOIN ${R}${x}`);a==E&&e==g&&n==h||(null!=E&&t(),E=a,g=e,h=n)}catch{}}),1e3*N),n=()=>{E=g=h=null,c(a)},s=i((a=>{T.has(a)&&(n(),t(),e())}));return e(),()=>{n(),o(s)}}),(t=>t()),l,y,d,S,B(T),(async(t,a)=>await t(`${b} t.name tn,c.name cn FROM ${P}list()t,${P}info(t.name)c ${C} t.schema='main'AND t.type IN('table','view')AND t.name IN(${q(a)})ORDER BY t.name,c.name`,a)),p,v,s,f,(t=>!0===t?1:!1===t?0:t),void 0)};t.createExpoSqlitePersister=(t,e,n,s,i)=>Pt(t,n,(async(t,a=[])=>await e.getAllAsync(t,a)),(t=>a.addDatabaseChangeListener((({tableName:a})=>t(a)))),(t=>t.remove()),s,i,(()=>0),3,e)},"object"==typeof exports&&"undefined"!=typeof module?a(exports,require("expo-sqlite")):"function"==typeof define&&define.amd?define(["exports","expo-sqlite"],a):a((t="undefined"!=typeof globalThis?globalThis:t||self).TinyBasePersisterExpoSqlite={},t["expo-sqlite"]);
@@ -1 +1 @@
1
- var t,a;t=this,a=function(t,a){"use strict";const e=t=>typeof t,n="tinybase",s="",i=",",o=e(s),r=Promise,c=clearInterval,l=t=>null==t,u=(t,a,e)=>l(t)?e?.():a(t),y=t=>e(t)==o,d=t=>Array.isArray(t),w=(t,a,e)=>t.slice(a,e),p=t=>t.length,v=async t=>r.all(t),f=t=>{throw Error(t)},E=(t,a)=>t.forEach(a),g=(t,a="")=>t.join(a),h=(t,a)=>t.map(a),m=t=>0==p(t),A=(t,a)=>t.filter(a),N=(t,...a)=>t.push(...a),S=t=>t.shift(),T="_",$="_id",b="SELECT",C="WHERE",O="TABLE",L="ALTER "+O,I="DELETE FROM",D=b+"*FROM",R="pragma_",M="data_version",x="schema_version",P="pragma_table_",_=t=>`"${t.replace(/"/g,'""')}"`,q=(t,a=[1])=>g(h(t,(()=>"$"+a[0]++)),i),F=(t,a)=>t?.has(a)??!1,j=t=>l(t)||0==(t=>t?.size??0)(t),B=t=>[...t?.values()??[]],U=(t,a)=>t?.forEach(a),J=(t,a)=>t?.delete(a),Y=Object,k=t=>Y.getPrototypeOf(t),z=Y.entries,G=Y.keys,H=Y.freeze,K=(t=[])=>Y.fromEntries(t),Q=(...t)=>Y.assign({},...t),V=(t,a)=>(delete t[a],t),W=(t,a)=>h(z(t),(([t,e])=>a(e,t))),X=t=>Y.values(t),Z=t=>p(G(t)),tt=t=>(t=>!l(t)&&u(k(t),(t=>t==Y.prototype||l(k(t))),(()=>!0)))(t)&&0==Z(t),at=JSON.stringify,et=JSON.parse,nt=t=>new Map(t),st=(t,a)=>t?.get(a),it=(t,a)=>h([...t?.entries()??[]],(([t,e])=>a(e,t))),ot=(t,a,e)=>l(e)?(J(t,a),t):t?.set(a,e),rt=(t,a,e,n)=>(F(t,a)?n?.(st(t,a)):ot(t,a,e()),st(t,a)),ct=(t,a,e,n,s=0)=>u((e?rt:st)(t,a[s],s>p(a)-2?e:nt),(i=>{if(s>p(a)-2)return n?.(i)&&ot(t,a[s]),i;const o=ct(i,a,e,n,s+1);return j(i)&&ot(t,a[s]),o})),lt=t=>new Set(d(t)||l(t)?t:[t]),ut=(t,a)=>t?.add(a),yt=/^\d+$/,dt=nt(),wt=nt(),pt=(t,a,e,n,i,o,r,c={},y=0,w=[])=>{let v,g,h,m=0,A=0,T=0;rt(dt,w,(()=>0)),rt(wt,w,(()=>[]));const $=nt(),[b,C,O,L,I]=((t=1,a,e)=>1!=t&&a.isMergeable()?[1,a.getMergeableContent,()=>a.getTransactionMergeableChanges(!e),([[t],[a]])=>!tt(t)||!tt(a),a.setDefaultContent]:2!=t?[0,a.getContent,a.getTransactionChanges,([t,a])=>!tt(t)||!tt(a),a.setContent]:f("Store type not supported by this Persister"))(r,t,y),[D,R,M]=(()=>{let t;const[a,e]=(()=>{const t=[];let a=0;return[e=>(e?S(t):null)??s+a++,a=>{yt.test(a)&&p(t)<1e3&&N(t,a)}]})(),n=nt();return[(e,i,o,r=[],c=()=>[])=>{t??=k;const l=a(1);return ot(n,l,[e,i,o,r,c]),ut(ct(i,o??[s],lt),l),l},(a,e,...i)=>E(((t,a=[s])=>{const e=[],n=(t,s)=>s==p(a)?N(e,t):null===a[s]?U(t,(t=>n(t,s+1))):E([a[s],null],(a=>n(st(t,a),s+1)));return n(t,0),e})(a,e),(a=>U(a,(a=>st(n,a)[0](t,...e??[],...i))))),t=>u(st(n,t),(([,a,i])=>(ct(a,i??[s],void 0,(a=>(J(a,t),j(a)?1:0))),ot(n,t),e(t),i))),a=>u(st(n,a),(([a,,e=[],n,s])=>{const i=(...o)=>{const r=p(o);r==p(e)?a(t,...o,...s(o)):l(e[r])?E(n[r]?.(...o)??[],(t=>i(...o,t))):i(...o,e[r])};i()}))]})(),x=t=>{t!=m&&(m=t,R($,void 0,m))},P=a=>{(b&&d(a?.[0])?1===a?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===a?.[2]?t.applyChanges:t.setContent)(a)},_=async t=>(2!=m&&(x(1),A++,await Y((async()=>{try{const e=await a();d(e)?P(e):t?I(t):f("Content is not an array: "+e)}catch(a){o?.(a),t&&I(t)}x(0)}))),k),q=()=>(g&&(i(g),g=void 0),k),F=async t=>(1!=m&&(x(2),T++,await Y((async()=>{try{await e(C,t)}catch(t){o?.(t)}x(0)}))),k),B=()=>(h&&(t.delListener(h),h=void 0),k),Y=async(...t)=>(N(st(wt,w),...t),await(async()=>{if(!st(dt,w)){for(ot(dt,w,1);!l(v=S(st(wt,w)));)try{await v()}catch(t){o?.(t)}ot(dt,w,0)}})(),k),k={load:_,startAutoLoad:async t=>{q(),await _(t);try{g=await n((async(t,a)=>{a||t?2!=m&&(x(1),A++,P(a??t),x(0)):await _()}))}catch(t){o?.(t)}return k},stopAutoLoad:q,isAutoLoading:()=>!l(g),save:F,startAutoSave:async()=>(B(),await F(),h=t.addDidFinishTransactionListener((()=>{const t=O();L(t)&&F(t)})),k),stopAutoSave:B,isAutoSaving:()=>!l(h),getStatus:()=>m,addStatusListener:t=>D(t,$),delListener:a=>(M(a),t),schedule:Y,getStore:()=>t,destroy:()=>(st(wt,w).splice(0,void 0),q().stopAutoSave()),getStats:()=>({loads:A,saves:T}),...c};return H(k)},vt=(t,a,e,n,s,o=ft,r,c)=>{const u=nt();return[async()=>{u.clear(),h(await e(t,a),(({tn:t,cn:a})=>ut(rt(u,t,lt),a)))},async(a,e)=>((t,a)=>F(st(u,t),a))(a,e)?K(A(h(await t(D+_(a)),(t=>{return[t[e],c?(a=V(t,e),n=c,K(W(a,((t,a)=>[a,n(t,a)])))):V(t,e)];var a,n})),(([t,a])=>!l(t)&&!tt(a)))):{},async(a,e,n,c,y,d=!1)=>{const w=lt();W(n??{},(t=>h(G(t??{}),(t=>ut(w,t)))));const p=B(w);if(!d&&y&&m(p)&&F(u,a))return await t("DROP "+O+_(a)),void ot(u,a);const f=st(u,a),E=lt(B(f));if(m(p)||(F(u,a)?await v(h([e,...p],(async(n,i)=>{J(E,n)||(await t(L+_(a)+"ADD"+_(n)+s),0==i&&await t("CREATE UNIQUE INDEX pk ON "+_(a)+`(${_(e)})`),ut(f,n))}))):(await t("CREATE "+O+_(a)+`(${_(e)}${s} PRIMARY KEY${g(h(p,(t=>i+_(t)+s)))});`),ot(u,a,lt([e,...p])))),await v([...!d&&c?h(B(E),(async n=>{n!=e&&(await t(L+_(a)+"DROP"+_(n)),J(f,n))})):[]]),d)l(n)?await t(I+_(a)+C+" true"):await v(W(n,(async(n,s)=>{l(n)?await t(I+_(a)+C+_(e)+"=$1",[s]):m(p)||await o(t,a,e,G(n),{[s]:r?h(X(n),r):X(n)},f)})));else if(m(p))F(u,a)&&await t(I+_(a)+C+" true");else{const s=A(B(st(u,a)),(t=>t!=e)),i={},c=[];W(n??{},((t,a)=>{i[a]=h(s,(a=>r?r(t?.[a]):t?.[a])),N(c,a)})),await o(t,a,e,s,i),await t(I+_(a)+C+_(e)+`NOT IN(${q(c)})`,c)}},async a=>{let e;await t("BEGIN");try{e=await a()}catch(t){n?.(t)}return await t("END"),e}]},ft=async(t,a,e,n,s)=>{const o=[1];await t("INSERT INTO"+_(a)+"("+((...t)=>g(h(t,_),i))(e,...n)+")VALUES"+g(W(s,(t=>"($"+o[0]+++","+q(t,o)+")")),i)+"ON CONFLICT("+_(e)+")DO UPDATE SET"+g(h(n,(t=>_(t)+"=excluded."+_(t))),i),W(s,((t,a)=>[a,...h(t,(t=>t??null))])).flat())},Et=(t,a,e,n,s,i,o,[r,c,l],u,y,d,w,p,v)=>{const[f,E,g,h]=vt(a,u,y,s,p,v),m=pt(t,(async()=>await h((async()=>{return await f(),t=(await E(r,c))[T]?.[l]??"null",et(t,((t,a)=>""===a?void 0:a));var t}))),(async t=>await h((async()=>{var a;await f(),await g(r,c,{[T]:{[l]:(a=t()??null,at(a,((t,a)=>void 0===a?"":a)))}},!0,!0)}))),e,n,s,o,{[w]:()=>d,destroy:()=>(m.stopAutoLoad().stopAutoSave(),i(),m)},0,d);return m},gt=(t,a,e,n,s,i,o,[r,c,[u,y,d]],w,p,f,E,g,h,m,N)=>{const[S,b,C,O]=vt(a,w,p,s,g,h,m,N),L=async(t,a)=>await v(it(c,(async([e,n,s,i],o)=>{a&&!(o in t)||await C(e,n,t[o],s,i,a)}))),I=async(t,a)=>y?await C(d,$,{[T]:t},!0,!0,a):null,D=pt(t,(async()=>await O((async()=>{await S();const t=await(async()=>K(A(await v(it(r,(async([t,a],e)=>[t,await b(e,a)]))),(t=>!tt(t[1])))))(),a=await(async()=>u?(await b(d,$))[T]:{})();return tt(t)&&l(a)?void 0:[t,a]}))),(async(t,a)=>await O((async()=>{if(await S(),l(a)){const[a,e]=t();await L(a),await I(e)}else await L(a[0],!0),await I(a[1],!0)}))),e,n,s,o,{[E]:()=>f,destroy:()=>(D.stopAutoLoad().stopAutoSave(),i(),D)},0,f);return D},ht="ColumnName",mt="store",At="json",Nt=mt+"TableName",St=mt+"Id"+ht,Tt=mt+ht,$t="autoLoadIntervalSeconds",bt="rowId"+ht,Ct="tableId",Ot="tableName",Lt="deleteEmptyColumns",It="deleteEmptyTable",Dt={mode:At,[$t]:1},Rt={load:0,save:0,[Ot]:n+"_values"},Mt=(t,a,e,n,s)=>{const i=nt();return W(t,((t,o)=>{const r=w(X(Q(a,y(t)?{[e]:t}:t)),0,Z(a));l(r[0])||n(o,r[0])||(s(o,r[0]),ot(i,o,r))})),i},xt=(t,a,e,i,o,r,l,u,d,p,v="getDb",f)=>{let E,g,h;const m=((t,a)=>a?async(e,n)=>(a(e,n),await t(e,n)):t)(e,r),[A,N,S,T]=(t=>{const a=(t=>Q(Dt,y(t)?{[Nt]:t}:t??{}))(t),e=a[$t];if(a.mode==At){const t=a[Nt]??n;return[1,e,[t,a[St]??$,a[Tt]??mt],lt(t)]}const{tables:{load:s={},save:i={}}={},values:o={}}=a,r=w(X(Q(Rt,o)),0,Z(Rt)),c=r[2],l=lt(c),u=lt(c);return[0,e,[Mt(s,{[Ct]:null,[bt]:$},Ct,(t=>F(u,t)),(t=>ut(l,t))),Mt(i,{[Ot]:null,[bt]:$,[Lt]:0,[It]:0},Ot,((t,a)=>F(u,a)),((t,a)=>ut(l,a))),r],l]})(a);return(A?Et:gt)(t,m,(t=>{let a;const e=()=>a=setInterval((async()=>{try{const[{d:a,s:e,c:n}]=await m(`${b} ${M} d,${x} s,TOTAL_CHANGES() c FROM ${R}${M} JOIN ${R}${x}`);a==E&&e==g&&n==h||(null!=E&&t(),E=a,g=e,h=n)}catch{}}),1e3*N),n=()=>{E=g=h=null,c(a)},s=i((a=>{T.has(a)&&(n(),t(),e())}));return e(),()=>{n(),o(s)}}),(t=>t()),l,u,d,S,B(T),(async(t,a)=>await t(`${b} t.name tn,c.name cn FROM ${P}list()t,${P}info(t.name)c ${C} t.schema='main'AND t.type IN('table','view')AND t.name IN(${q(a)})ORDER BY t.name,c.name`,a)),p,v,s,f,(t=>!0===t?1:!1===t?0:t),void 0)};t.createExpoSqlitePersister=(t,e,n,s,i)=>xt(t,n,(async(t,a=[])=>await e.getAllAsync(t,a)),(t=>a.addDatabaseChangeListener((({tableName:a})=>t(a)))),(t=>t.remove()),s,i,(()=>0),3,e)},"object"==typeof exports&&"undefined"!=typeof module?a(exports,require("expo-sqlite")):"function"==typeof define&&define.amd?define(["exports","expo-sqlite"],a):a((t="undefined"!=typeof globalThis?globalThis:t||self).TinyBasePersisterExpoSqlite={},t["expo-sqlite"]);
1
+ var t,a;t=this,a=function(t,a){"use strict";const e=t=>typeof t,n="tinybase",s="",i=",",o=e(s),r=Promise,c=clearInterval,l=t=>null==t,y=(t,a,e)=>l(t)?e?.():a(t),u=t=>e(t)==o,d=t=>Array.isArray(t),w=(t,a,e)=>t.slice(a,e),p=t=>t.length,v=async t=>r.all(t),f=t=>{throw Error(t)},E=(t,a)=>t.forEach(a),g=(t,a="")=>t.join(a),h=(t,a)=>t.map(a),m=t=>0==p(t),A=(t,a)=>t.filter(a),N=(t,...a)=>t.push(...a),S=t=>t.shift(),T="_",$="_id",b="SELECT",C="WHERE",O="TABLE",L="ALTER "+O,I="DELETE FROM",D=b+"*FROM",R="pragma_",M="data_version",x="schema_version",P="pragma_table_",_=t=>`"${t.replace(/"/g,'""')}"`,q=(t,a=[1])=>g(h(t,(()=>"$"+a[0]++)),i),F=(t,a)=>t?.has(a)??!1,j=t=>l(t)||0==(t=>t?.size??0)(t),B=t=>[...t?.values()??[]],U=(t,a)=>t?.forEach(a),J=(t,a)=>t?.delete(a),Y=Object,k=t=>Y.getPrototypeOf(t),z=Y.entries,G=Y.keys,H=Y.freeze,K=(t=[])=>Y.fromEntries(t),Q=(...t)=>Y.assign({},...t),V=(t,a)=>(delete t[a],t),W=(t,a)=>h(z(t),(([t,e])=>a(e,t))),X=(t,a)=>K(W(t,((t,e)=>[e,a(t,e)]))),Z=t=>Y.values(t),tt=t=>p(G(t)),at=t=>(t=>!l(t)&&y(k(t),(t=>t==Y.prototype||l(k(t))),(()=>!0)))(t)&&0==tt(t),et=JSON.stringify,nt=JSON.parse,st=t=>new Map(t),it=(t,a)=>t?.get(a),ot=(t,a)=>h([...t?.entries()??[]],(([t,e])=>a(e,t))),rt=(t,a,e)=>l(e)?(J(t,a),t):t?.set(a,e),ct=(t,a,e,n)=>(F(t,a)?n?.(it(t,a)):rt(t,a,e()),it(t,a)),lt=(t,a,e,n,s=0)=>y((e?ct:it)(t,a[s],s>p(a)-2?e:st),(i=>{if(s>p(a)-2)return n?.(i)&&rt(t,a[s]),i;const o=lt(i,a,e,n,s+1);return j(i)&&rt(t,a[s]),o})),yt=t=>new Set(d(t)||l(t)?t:[t]),ut=(t,a)=>t?.add(a),dt=/^\d+$/,wt=st(),pt=st(),vt=(t,a,e,n,i,o,r,c={},u=0,w=[])=>{let v,g,h,m=0,A=0,T=0;ct(wt,w,(()=>0)),ct(pt,w,(()=>[]));const $=st(),[b,C,O,L,I]=((t=1,a,e)=>1!=t&&a.isMergeable()?[1,a.getMergeableContent,()=>a.getTransactionMergeableChanges(!e),([[t],[a]])=>!at(t)||!at(a),a.setDefaultContent]:2!=t?[0,a.getContent,a.getTransactionChanges,([t,a])=>!at(t)||!at(a),a.setContent]:f("Store type not supported by this Persister"))(r,t,u),[D,R,M]=(()=>{let t;const[a,e]=(()=>{const t=[];let a=0;return[e=>(e?S(t):null)??s+a++,a=>{dt.test(a)&&p(t)<1e3&&N(t,a)}]})(),n=st();return[(e,i,o,r=[],c=()=>[])=>{t??=k;const l=a(1);return rt(n,l,[e,i,o,r,c]),ut(lt(i,o??[s],yt),l),l},(a,e,...i)=>E(((t,a=[s])=>{const e=[],n=(t,s)=>s==p(a)?N(e,t):null===a[s]?U(t,(t=>n(t,s+1))):E([a[s],null],(a=>n(it(t,a),s+1)));return n(t,0),e})(a,e),(a=>U(a,(a=>it(n,a)[0](t,...e??[],...i))))),t=>y(it(n,t),(([,a,i])=>(lt(a,i??[s],void 0,(a=>(J(a,t),j(a)?1:0))),rt(n,t),e(t),i))),a=>y(it(n,a),(([a,,e=[],n,s])=>{const i=(...o)=>{const r=p(o);r==p(e)?a(t,...o,...s(o)):l(e[r])?E(n[r]?.(...o)??[],(t=>i(...o,t))):i(...o,e[r])};i()}))]})(),x=t=>{t!=m&&(m=t,R($,void 0,m))},P=a=>{(b&&d(a?.[0])?1===a?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===a?.[2]?t.applyChanges:t.setContent)(a)},_=async t=>(2!=m&&(x(1),A++,await Y((async()=>{try{const e=await a();d(e)?P(e):t?I(t):f("Content is not an array: "+e)}catch(a){o?.(a),t&&I(t)}x(0)}))),k),q=()=>(g&&(i(g),g=void 0),k),F=async t=>(1!=m&&(x(2),T++,await Y((async()=>{try{await e(C,t)}catch(t){o?.(t)}x(0)}))),k),B=()=>(h&&(t.delListener(h),h=void 0),k),Y=async(...t)=>(N(it(pt,w),...t),await(async()=>{if(!it(wt,w)){for(rt(wt,w,1);!l(v=S(it(pt,w)));)try{await v()}catch(t){o?.(t)}rt(wt,w,0)}})(),k),k={load:_,startAutoLoad:async t=>{q(),await _(t);try{g=await n((async(t,a)=>{a||t?2!=m&&(x(1),A++,P(a??t),x(0)):await _()}))}catch(t){o?.(t)}return k},stopAutoLoad:q,isAutoLoading:()=>!l(g),save:F,startAutoSave:async()=>(B(),await F(),h=t.addDidFinishTransactionListener((()=>{const t=O();L(t)&&F(t)})),k),stopAutoSave:B,isAutoSaving:()=>!l(h),getStatus:()=>m,addStatusListener:t=>D(t,$),delListener:a=>(M(a),t),schedule:Y,getStore:()=>t,destroy:()=>(it(pt,w).splice(0,void 0),q().stopAutoSave()),getStats:()=>({loads:A,saves:T}),...c};return H(k)},ft=(t,a,e,n,s,o=Et,r,c)=>{const y=st();return[async()=>{y.clear(),h(await e(t,a),(({tn:t,cn:a})=>ut(ct(y,t,yt),a)))},async(a,e)=>((t,a)=>F(it(y,t),a))(a,e)?K(A(h(await t(D+_(a)),(t=>[t[e],c?X(V(t,e),c):V(t,e)])),(([t,a])=>!l(t)&&!at(a)))):{},async(a,e,n,c,u,d=!1)=>{const w=yt();X(n??{},(t=>h(G(t??{}),(t=>ut(w,t)))));const p=B(w);if(!d&&u&&m(p)&&F(y,a))return await t("DROP "+O+_(a)),void rt(y,a);const f=it(y,a),E=yt(B(f));if(m(p)||(F(y,a)?await v(h([e,...p],(async(n,i)=>{J(E,n)||(await t(L+_(a)+"ADD"+_(n)+s),0==i&&await t("CREATE UNIQUE INDEX pk ON "+_(a)+`(${_(e)})`),ut(f,n))}))):(await t("CREATE "+O+_(a)+`(${_(e)}${s} PRIMARY KEY${g(h(p,(t=>i+_(t)+s)))});`),rt(y,a,yt([e,...p])))),await v([...!d&&c?h(B(E),(async n=>{n!=e&&(await t(L+_(a)+"DROP"+_(n)),J(f,n))})):[]]),d)l(n)?await t(I+_(a)+C+" true"):await v(W(n,(async(n,s)=>{l(n)?await t(I+_(a)+C+_(e)+"=$1",[s]):m(p)||await o(t,a,e,G(n),{[s]:r?h(Z(n),r):Z(n)},f)})));else if(m(p))F(y,a)&&await t(I+_(a)+C+" true");else{const s=A(B(it(y,a)),(t=>t!=e)),i={},c=[];X(n??{},((t,a)=>{i[a]=h(s,(a=>r?r(t?.[a]):t?.[a])),N(c,a)})),await o(t,a,e,s,i),await t(I+_(a)+C+_(e)+`NOT IN(${q(c)})`,c)}},async a=>{let e;await t("BEGIN");try{e=await a()}catch(t){n?.(t)}return await t("END"),e}]},Et=async(t,a,e,n,s)=>{const o=[1];await t("INSERT INTO"+_(a)+"("+((...t)=>g(h(t,_),i))(e,...n)+")VALUES"+g(W(s,(t=>"($"+o[0]+++","+q(t,o)+")")),i)+"ON CONFLICT("+_(e)+")DO UPDATE SET"+g(h(n,(t=>_(t)+"=excluded."+_(t))),i),W(s,((t,a)=>[a,...h(t,(t=>t??null))])).flat())},gt=(t,a,e,n,s,i,o,[r,c,l],y,u,d,w,p,v)=>{const[f,E,g,h]=ft(a,y,u,s,p,v),m=vt(t,(async()=>await h((async()=>{return await f(),t=(await E(r,c))[T]?.[l]??"null",nt(t,((t,a)=>""===a?void 0:a));var t}))),(async t=>await h((async()=>{var a;await f(),await g(r,c,{[T]:{[l]:(a=t()??null,et(a,((t,a)=>void 0===a?"":a)))}},!0,!0)}))),e,n,s,o,{[w]:()=>d,destroy:()=>(m.stopAutoLoad().stopAutoSave(),i(),m)},0,d);return m},ht=(t,a,e,n,s,i,o,[r,c,[y,u,d]],w,p,f,E,g,h,m,N)=>{const[S,b,C,O]=ft(a,w,p,s,g,h,m,N),L=async(t,a)=>await v(ot(c,(async([e,n,s,i],o)=>{a&&!(o in t)||await C(e,n,t[o],s,i,a)}))),I=async(t,a)=>u?await C(d,$,{[T]:t},!0,!0,a):null,D=vt(t,(async()=>await O((async()=>{await S();const t=await(async()=>K(A(await v(ot(r,(async([t,a],e)=>[t,await b(e,a)]))),(t=>!at(t[1])))))(),a=await(async()=>y?(await b(d,$))[T]:{})();return at(t)&&l(a)?void 0:[t,a]}))),(async(t,a)=>await O((async()=>{if(await S(),l(a)){const[a,e]=t();await L(a),await I(e)}else await L(a[0],!0),await I(a[1],!0)}))),e,n,s,o,{[E]:()=>f,destroy:()=>(D.stopAutoLoad().stopAutoSave(),i(),D)},0,f);return D},mt="ColumnName",At="store",Nt="json",St=At+"TableName",Tt=At+"Id"+mt,$t=At+mt,bt="autoLoadIntervalSeconds",Ct="rowId"+mt,Ot="tableId",Lt="tableName",It="deleteEmptyColumns",Dt="deleteEmptyTable",Rt={mode:Nt,[bt]:1},Mt={load:0,save:0,[Lt]:n+"_values"},xt=(t,a,e,n,s)=>{const i=st();return X(t,((t,o)=>{const r=w(Z(Q(a,u(t)?{[e]:t}:t)),0,tt(a));l(r[0])||n(o,r[0])||(s(o,r[0]),rt(i,o,r))})),i},Pt=(t,a,e,i,o,r,l,y,d,p,v="getDb",f)=>{let E,g,h;const m=((t,a)=>a?async(e,n)=>(a(e,n),await t(e,n)):t)(e,r),[A,N,S,T]=(t=>{const a=(t=>Q(Rt,u(t)?{[St]:t}:t??{}))(t),e=a[bt];if(a.mode==Nt){const t=a[St]??n;return[1,e,[t,a[Tt]??$,a[$t]??At],yt(t)]}const{tables:{load:s={},save:i={}}={},values:o={}}=a,r=w(Z(Q(Mt,o)),0,tt(Mt)),c=r[2],l=yt(c),y=yt(c);return[0,e,[xt(s,{[Ot]:null,[Ct]:$},Ot,(t=>F(y,t)),(t=>ut(l,t))),xt(i,{[Lt]:null,[Ct]:$,[It]:0,[Dt]:0},Lt,((t,a)=>F(y,a)),((t,a)=>ut(l,a))),r],l]})(a);return(A?gt:ht)(t,m,(t=>{let a;const e=()=>a=setInterval((async()=>{try{const[{d:a,s:e,c:n}]=await m(`${b} ${M} d,${x} s,TOTAL_CHANGES() c FROM ${R}${M} JOIN ${R}${x}`);a==E&&e==g&&n==h||(null!=E&&t(),E=a,g=e,h=n)}catch{}}),1e3*N),n=()=>{E=g=h=null,c(a)},s=i((a=>{T.has(a)&&(n(),t(),e())}));return e(),()=>{n(),o(s)}}),(t=>t()),l,y,d,S,B(T),(async(t,a)=>await t(`${b} t.name tn,c.name cn FROM ${P}list()t,${P}info(t.name)c ${C} t.schema='main'AND t.type IN('table','view')AND t.name IN(${q(a)})ORDER BY t.name,c.name`,a)),p,v,s,f,(t=>!0===t?1:!1===t?0:t),void 0)};t.createExpoSqlitePersister=(t,e,n,s,i)=>Pt(t,n,(async(t,a=[])=>await e.getAllAsync(t,a)),(t=>a.addDatabaseChangeListener((({tableName:a})=>t(a)))),(t=>t.remove()),s,i,(()=>0),3,e)},"object"==typeof exports&&"undefined"!=typeof module?a(exports,require("expo-sqlite")):"function"==typeof define&&define.amd?define(["exports","expo-sqlite"],a):a((t="undefined"!=typeof globalThis?globalThis:t||self).TinyBasePersisterExpoSqlite={},t["expo-sqlite"]);
@@ -1 +1 @@
1
- var t,a;t=this,a=function(t){"use strict";const a=t=>typeof t,e="tinybase",n="",s=",",i=a(n),o=Promise,r=clearInterval,c=t=>null==t,l=(t,a,e)=>c(t)?e?.():a(t),u=t=>a(t)==i,y=t=>Array.isArray(t),w=(t,a,e)=>t.slice(a,e),d=t=>t.length,p=async t=>o.all(t),v=t=>{throw Error(t)},f=(t,a)=>t.forEach(a),g=(t,a="")=>t.join(a),E=(t,a)=>t.map(a),h=t=>0==d(t),m=(t,a)=>t.filter(a),A=(t,...a)=>t.push(...a),N=t=>t.shift(),T="_",$="_id",b="SELECT",S="WHERE",C="TABLE",L="ALTER "+C,O="DELETE FROM",I=b+"*FROM",D="pragma_",R="data_version",M="schema_version",P="pragma_table_",_=t=>`"${t.replace(/"/g,'""')}"`,F=(t,a=[1])=>g(E(t,(()=>"$"+a[0]++)),s),x=(t,a)=>t?.has(a)??!1,j=t=>c(t)||0==(t=>t?.size??0)(t),B=t=>[...t?.values()??[]],U=(t,a)=>t?.forEach(a),q=(t,a)=>t?.delete(a),J=Object,Y=t=>J.getPrototypeOf(t),k=J.entries,z=J.keys,G=J.freeze,H=(t=[])=>J.fromEntries(t),K=(...t)=>J.assign({},...t),Q=(t,a)=>(delete t[a],t),V=(t,a)=>E(k(t),(([t,e])=>a(e,t))),W=t=>J.values(t),X=t=>d(z(t)),Z=t=>(t=>!c(t)&&l(Y(t),(t=>t==J.prototype||c(Y(t))),(()=>!0)))(t)&&0==X(t),tt=JSON.stringify,at=JSON.parse,et=t=>new Map(t),nt=(t,a)=>t?.get(a),st=(t,a)=>E([...t?.entries()??[]],(([t,e])=>a(e,t))),it=(t,a,e)=>c(e)?(q(t,a),t):t?.set(a,e),ot=(t,a,e,n)=>(x(t,a)?n?.(nt(t,a)):it(t,a,e()),nt(t,a)),rt=(t,a,e,n,s=0)=>l((e?ot:nt)(t,a[s],s>d(a)-2?e:et),(i=>{if(s>d(a)-2)return n?.(i)&&it(t,a[s]),i;const o=rt(i,a,e,n,s+1);return j(i)&&it(t,a[s]),o})),ct=t=>new Set(y(t)||c(t)?t:[t]),lt=(t,a)=>t?.add(a),ut=/^\d+$/,yt=et(),wt=et(),dt=(t,a,e,s,i,o,r,u={},w=0,p=[])=>{let g,E,h,m=0,T=0,$=0;ot(yt,p,(()=>0)),ot(wt,p,(()=>[]));const b=et(),[S,C,L,O,I]=((t=1,a,e)=>1!=t&&a.isMergeable()?[1,a.getMergeableContent,()=>a.getTransactionMergeableChanges(!e),([[t],[a]])=>!Z(t)||!Z(a),a.setDefaultContent]:2!=t?[0,a.getContent,a.getTransactionChanges,([t,a])=>!Z(t)||!Z(a),a.setContent]:v("Store type not supported by this Persister"))(r,t,w),[D,R,M]=(()=>{let t;const[a,e]=(()=>{const t=[];let a=0;return[e=>(e?N(t):null)??n+a++,a=>{ut.test(a)&&d(t)<1e3&&A(t,a)}]})(),s=et();return[(e,i,o,r=[],c=()=>[])=>{t??=k;const l=a(1);return it(s,l,[e,i,o,r,c]),lt(rt(i,o??[n],ct),l),l},(a,e,...i)=>f(((t,a=[n])=>{const e=[],s=(t,n)=>n==d(a)?A(e,t):null===a[n]?U(t,(t=>s(t,n+1))):f([a[n],null],(a=>s(nt(t,a),n+1)));return s(t,0),e})(a,e),(a=>U(a,(a=>nt(s,a)[0](t,...e??[],...i))))),t=>l(nt(s,t),(([,a,i])=>(rt(a,i??[n],void 0,(a=>(q(a,t),j(a)?1:0))),it(s,t),e(t),i))),a=>l(nt(s,a),(([a,,e=[],n,s])=>{const i=(...o)=>{const r=d(o);r==d(e)?a(t,...o,...s(o)):c(e[r])?f(n[r]?.(...o)??[],(t=>i(...o,t))):i(...o,e[r])};i()}))]})(),P=t=>{t!=m&&(m=t,R(b,void 0,m))},_=a=>{(S&&y(a?.[0])?1===a?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===a?.[2]?t.applyChanges:t.setContent)(a)},F=async t=>(2!=m&&(P(1),T++,await Y((async()=>{try{const e=await a();y(e)?_(e):t?I(t):v("Content is not an array: "+e)}catch(a){o?.(a),t&&I(t)}P(0)}))),k),x=()=>(E&&(i(E),E=void 0),k),B=async t=>(1!=m&&(P(2),$++,await Y((async()=>{try{await e(C,t)}catch(t){o?.(t)}P(0)}))),k),J=()=>(h&&(t.delListener(h),h=void 0),k),Y=async(...t)=>(A(nt(wt,p),...t),await(async()=>{if(!nt(yt,p)){for(it(yt,p,1);!c(g=N(nt(wt,p)));)try{await g()}catch(t){o?.(t)}it(yt,p,0)}})(),k),k={load:F,startAutoLoad:async t=>{x(),await F(t);try{E=await s((async(t,a)=>{a||t?2!=m&&(P(1),T++,_(a??t),P(0)):await F()}))}catch(t){o?.(t)}return k},stopAutoLoad:x,isAutoLoading:()=>!c(E),save:B,startAutoSave:async()=>(J(),await B(),h=t.addDidFinishTransactionListener((()=>{const t=L();O(t)&&B(t)})),k),stopAutoSave:J,isAutoSaving:()=>!c(h),getStatus:()=>m,addStatusListener:t=>D(t,b),delListener:a=>(M(a),t),schedule:Y,getStore:()=>t,destroy:()=>(nt(wt,p).splice(0,void 0),x().stopAutoSave()),getStats:()=>({loads:T,saves:$}),...u};return G(k)},pt=(t,a,e,n,i,o=vt,r,l)=>{const u=et();return[async()=>{u.clear(),E(await e(t,a),(({tn:t,cn:a})=>lt(ot(u,t,ct),a)))},async(a,e)=>((t,a)=>x(nt(u,t),a))(a,e)?H(m(E(await t(I+_(a)),(t=>{return[t[e],l?(a=Q(t,e),n=l,H(V(a,((t,a)=>[a,n(t,a)])))):Q(t,e)];var a,n})),(([t,a])=>!c(t)&&!Z(a)))):{},async(a,e,n,l,y,w=!1)=>{const d=ct();V(n??{},(t=>E(z(t??{}),(t=>lt(d,t)))));const v=B(d);if(!w&&y&&h(v)&&x(u,a))return await t("DROP "+C+_(a)),void it(u,a);const f=nt(u,a),N=ct(B(f));if(h(v)||(x(u,a)?await p(E([e,...v],(async(n,s)=>{q(N,n)||(await t(L+_(a)+"ADD"+_(n)+i),0==s&&await t("CREATE UNIQUE INDEX pk ON "+_(a)+`(${_(e)})`),lt(f,n))}))):(await t("CREATE "+C+_(a)+`(${_(e)}${i} PRIMARY KEY${g(E(v,(t=>s+_(t)+i)))});`),it(u,a,ct([e,...v])))),await p([...!w&&l?E(B(N),(async n=>{n!=e&&(await t(L+_(a)+"DROP"+_(n)),q(f,n))})):[]]),w)c(n)?await t(O+_(a)+S+" true"):await p(V(n,(async(n,s)=>{c(n)?await t(O+_(a)+S+_(e)+"=$1",[s]):h(v)||await o(t,a,e,z(n),{[s]:r?E(W(n),r):W(n)},f)})));else if(h(v))x(u,a)&&await t(O+_(a)+S+" true");else{const s=m(B(nt(u,a)),(t=>t!=e)),i={},c=[];V(n??{},((t,a)=>{i[a]=E(s,(a=>r?r(t?.[a]):t?.[a])),A(c,a)})),await o(t,a,e,s,i),await t(O+_(a)+S+_(e)+`NOT IN(${F(c)})`,c)}},async a=>{let e;await t("BEGIN");try{e=await a()}catch(t){n?.(t)}return await t("END"),e}]},vt=async(t,a,e,n,i)=>{const o=[1];await t("INSERT INTO"+_(a)+"("+((...t)=>g(E(t,_),s))(e,...n)+")VALUES"+g(V(i,(t=>"($"+o[0]+++","+F(t,o)+")")),s)+"ON CONFLICT("+_(e)+")DO UPDATE SET"+g(E(n,(t=>_(t)+"=excluded."+_(t))),s),V(i,((t,a)=>[a,...E(t,(t=>t??null))])).flat())},ft=(t,a,e,n,s,i,o,[r,c,l],u,y,w,d,p,v)=>{const[f,g,E,h]=pt(a,u,y,s,p,v),m=dt(t,(async()=>await h((async()=>{return await f(),t=(await g(r,c))[T]?.[l]??"null",at(t,((t,a)=>""===a?void 0:a));var t}))),(async t=>await h((async()=>{var a;await f(),await E(r,c,{[T]:{[l]:(a=t()??null,tt(a,((t,a)=>void 0===a?"":a)))}},!0,!0)}))),e,n,s,o,{[d]:()=>w,destroy:()=>(m.stopAutoLoad().stopAutoSave(),i(),m)},0,w);return m},gt=(t,a,e,n,s,i,o,[r,l,[u,y,w]],d,v,f,g,E,h,A,N)=>{const[b,S,C,L]=pt(a,d,v,s,E,h,A,N),O=async(t,a)=>await p(st(l,(async([e,n,s,i],o)=>{a&&!(o in t)||await C(e,n,t[o],s,i,a)}))),I=async(t,a)=>y?await C(w,$,{[T]:t},!0,!0,a):null,D=dt(t,(async()=>await L((async()=>{await b();const t=await(async()=>H(m(await p(st(r,(async([t,a],e)=>[t,await S(e,a)]))),(t=>!Z(t[1])))))(),a=await(async()=>u?(await S(w,$))[T]:{})();return Z(t)&&c(a)?void 0:[t,a]}))),(async(t,a)=>await L((async()=>{if(await b(),c(a)){const[a,e]=t();await O(a),await I(e)}else await O(a[0],!0),await I(a[1],!0)}))),e,n,s,o,{[g]:()=>f,destroy:()=>(D.stopAutoLoad().stopAutoSave(),i(),D)},0,f);return D},Et="ColumnName",ht="store",mt="json",At=ht+"TableName",Nt=ht+"Id"+Et,Tt=ht+Et,$t="autoLoadIntervalSeconds",bt="rowId"+Et,St="tableId",Ct="tableName",Lt="deleteEmptyColumns",Ot="deleteEmptyTable",It={mode:mt,[$t]:1},Dt={load:0,save:0,[Ct]:e+"_values"},Rt=(t,a,e,n,s)=>{const i=et();return V(t,((t,o)=>{const r=w(W(K(a,u(t)?{[e]:t}:t)),0,X(a));c(r[0])||n(o,r[0])||(s(o,r[0]),it(i,o,r))})),i},Mt=(t,a,s,i,o,c,l,y,d,p,v="getDb",f)=>{let g,E,h;const m=((t,a)=>a?async(e,n)=>(a(e,n),await t(e,n)):t)(s,c),[A,N,T,C]=(t=>{const a=(t=>K(It,u(t)?{[At]:t}:t??{}))(t),n=a[$t];if(a.mode==mt){const t=a[At]??e;return[1,n,[t,a[Nt]??$,a[Tt]??ht],ct(t)]}const{tables:{load:s={},save:i={}}={},values:o={}}=a,r=w(W(K(Dt,o)),0,X(Dt)),c=r[2],l=ct(c),y=ct(c);return[0,n,[Rt(s,{[St]:null,[bt]:$},St,(t=>x(y,t)),(t=>lt(l,t))),Rt(i,{[Ct]:null,[bt]:$,[Lt]:0,[Ot]:0},Ct,((t,a)=>x(y,a)),((t,a)=>lt(l,a))),r],l]})(a);return(A?ft:gt)(t,m,(t=>{let a;const e=()=>a=setInterval((async()=>{try{const[{d:a,s:e,c:n}]=await m(`${b} ${R} d,${M} s,TOTAL_CHANGES() c FROM ${D}${R} JOIN ${D}${M}`);a==g&&e==E&&n==h||(null!=g&&t(),g=a,E=e,h=n)}catch{}}),1e3*N),n=()=>{g=E=h=null,r(a)},s=i((a=>{C.has(a)&&(n(),t(),e())}));return e(),()=>{n(),o(s)}}),(t=>t()),l,y,d,T,B(C),(async(t,a)=>await t(`${b} t.name tn,c.name cn FROM ${P}list()t,${P}info(t.name)c ${S} t.schema='main'AND t.type IN('table','view')AND t.name IN(${F(a)})ORDER BY t.name,c.name`,a)),p,v,n,f,(t=>!0===t?1:!1===t?0:t),void 0)};t.createLibSqlPersister=(t,a,e,n,s)=>Mt(t,e,(async(t,e=[])=>(await a.execute({sql:t,args:e})).rows),(()=>()=>0),(t=>t()),n,s,(()=>0),1,a,"getClient")},"object"==typeof exports&&"undefined"!=typeof module?a(exports):"function"==typeof define&&define.amd?define(["exports"],a):a((t="undefined"!=typeof globalThis?globalThis:t||self).TinyBasePersisterLibsql={});
1
+ var t,a;t=this,a=function(t){"use strict";const a=t=>typeof t,e="tinybase",n="",s=",",i=a(n),o=Promise,r=clearInterval,c=t=>null==t,l=(t,a,e)=>c(t)?e?.():a(t),u=t=>a(t)==i,y=t=>Array.isArray(t),w=(t,a,e)=>t.slice(a,e),d=t=>t.length,p=async t=>o.all(t),v=t=>{throw Error(t)},f=(t,a)=>t.forEach(a),g=(t,a="")=>t.join(a),E=(t,a)=>t.map(a),h=t=>0==d(t),m=(t,a)=>t.filter(a),A=(t,...a)=>t.push(...a),N=t=>t.shift(),T="_",$="_id",b="SELECT",S="WHERE",C="TABLE",L="ALTER "+C,O="DELETE FROM",I=b+"*FROM",D="pragma_",R="data_version",M="schema_version",P="pragma_table_",_=t=>`"${t.replace(/"/g,'""')}"`,F=(t,a=[1])=>g(E(t,(()=>"$"+a[0]++)),s),x=(t,a)=>t?.has(a)??!1,j=t=>c(t)||0==(t=>t?.size??0)(t),B=t=>[...t?.values()??[]],U=(t,a)=>t?.forEach(a),q=(t,a)=>t?.delete(a),J=Object,Y=t=>J.getPrototypeOf(t),k=J.entries,z=J.keys,G=J.freeze,H=(t=[])=>J.fromEntries(t),K=(...t)=>J.assign({},...t),Q=(t,a)=>(delete t[a],t),V=(t,a)=>E(k(t),(([t,e])=>a(e,t))),W=(t,a)=>H(V(t,((t,e)=>[e,a(t,e)]))),X=t=>J.values(t),Z=t=>d(z(t)),tt=t=>(t=>!c(t)&&l(Y(t),(t=>t==J.prototype||c(Y(t))),(()=>!0)))(t)&&0==Z(t),at=JSON.stringify,et=JSON.parse,nt=t=>new Map(t),st=(t,a)=>t?.get(a),it=(t,a)=>E([...t?.entries()??[]],(([t,e])=>a(e,t))),ot=(t,a,e)=>c(e)?(q(t,a),t):t?.set(a,e),rt=(t,a,e,n)=>(x(t,a)?n?.(st(t,a)):ot(t,a,e()),st(t,a)),ct=(t,a,e,n,s=0)=>l((e?rt:st)(t,a[s],s>d(a)-2?e:nt),(i=>{if(s>d(a)-2)return n?.(i)&&ot(t,a[s]),i;const o=ct(i,a,e,n,s+1);return j(i)&&ot(t,a[s]),o})),lt=t=>new Set(y(t)||c(t)?t:[t]),ut=(t,a)=>t?.add(a),yt=/^\d+$/,wt=nt(),dt=nt(),pt=(t,a,e,s,i,o,r,u={},w=0,p=[])=>{let g,E,h,m=0,T=0,$=0;rt(wt,p,(()=>0)),rt(dt,p,(()=>[]));const b=nt(),[S,C,L,O,I]=((t=1,a,e)=>1!=t&&a.isMergeable()?[1,a.getMergeableContent,()=>a.getTransactionMergeableChanges(!e),([[t],[a]])=>!tt(t)||!tt(a),a.setDefaultContent]:2!=t?[0,a.getContent,a.getTransactionChanges,([t,a])=>!tt(t)||!tt(a),a.setContent]:v("Store type not supported by this Persister"))(r,t,w),[D,R,M]=(()=>{let t;const[a,e]=(()=>{const t=[];let a=0;return[e=>(e?N(t):null)??n+a++,a=>{yt.test(a)&&d(t)<1e3&&A(t,a)}]})(),s=nt();return[(e,i,o,r=[],c=()=>[])=>{t??=k;const l=a(1);return ot(s,l,[e,i,o,r,c]),ut(ct(i,o??[n],lt),l),l},(a,e,...i)=>f(((t,a=[n])=>{const e=[],s=(t,n)=>n==d(a)?A(e,t):null===a[n]?U(t,(t=>s(t,n+1))):f([a[n],null],(a=>s(st(t,a),n+1)));return s(t,0),e})(a,e),(a=>U(a,(a=>st(s,a)[0](t,...e??[],...i))))),t=>l(st(s,t),(([,a,i])=>(ct(a,i??[n],void 0,(a=>(q(a,t),j(a)?1:0))),ot(s,t),e(t),i))),a=>l(st(s,a),(([a,,e=[],n,s])=>{const i=(...o)=>{const r=d(o);r==d(e)?a(t,...o,...s(o)):c(e[r])?f(n[r]?.(...o)??[],(t=>i(...o,t))):i(...o,e[r])};i()}))]})(),P=t=>{t!=m&&(m=t,R(b,void 0,m))},_=a=>{(S&&y(a?.[0])?1===a?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===a?.[2]?t.applyChanges:t.setContent)(a)},F=async t=>(2!=m&&(P(1),T++,await Y((async()=>{try{const e=await a();y(e)?_(e):t?I(t):v("Content is not an array: "+e)}catch(a){o?.(a),t&&I(t)}P(0)}))),k),x=()=>(E&&(i(E),E=void 0),k),B=async t=>(1!=m&&(P(2),$++,await Y((async()=>{try{await e(C,t)}catch(t){o?.(t)}P(0)}))),k),J=()=>(h&&(t.delListener(h),h=void 0),k),Y=async(...t)=>(A(st(dt,p),...t),await(async()=>{if(!st(wt,p)){for(ot(wt,p,1);!c(g=N(st(dt,p)));)try{await g()}catch(t){o?.(t)}ot(wt,p,0)}})(),k),k={load:F,startAutoLoad:async t=>{x(),await F(t);try{E=await s((async(t,a)=>{a||t?2!=m&&(P(1),T++,_(a??t),P(0)):await F()}))}catch(t){o?.(t)}return k},stopAutoLoad:x,isAutoLoading:()=>!c(E),save:B,startAutoSave:async()=>(J(),await B(),h=t.addDidFinishTransactionListener((()=>{const t=L();O(t)&&B(t)})),k),stopAutoSave:J,isAutoSaving:()=>!c(h),getStatus:()=>m,addStatusListener:t=>D(t,b),delListener:a=>(M(a),t),schedule:Y,getStore:()=>t,destroy:()=>(st(dt,p).splice(0,void 0),x().stopAutoSave()),getStats:()=>({loads:T,saves:$}),...u};return G(k)},vt=(t,a,e,n,i,o=ft,r,l)=>{const u=nt();return[async()=>{u.clear(),E(await e(t,a),(({tn:t,cn:a})=>ut(rt(u,t,lt),a)))},async(a,e)=>((t,a)=>x(st(u,t),a))(a,e)?H(m(E(await t(I+_(a)),(t=>[t[e],l?W(Q(t,e),l):Q(t,e)])),(([t,a])=>!c(t)&&!tt(a)))):{},async(a,e,n,l,y,w=!1)=>{const d=lt();W(n??{},(t=>E(z(t??{}),(t=>ut(d,t)))));const v=B(d);if(!w&&y&&h(v)&&x(u,a))return await t("DROP "+C+_(a)),void ot(u,a);const f=st(u,a),N=lt(B(f));if(h(v)||(x(u,a)?await p(E([e,...v],(async(n,s)=>{q(N,n)||(await t(L+_(a)+"ADD"+_(n)+i),0==s&&await t("CREATE UNIQUE INDEX pk ON "+_(a)+`(${_(e)})`),ut(f,n))}))):(await t("CREATE "+C+_(a)+`(${_(e)}${i} PRIMARY KEY${g(E(v,(t=>s+_(t)+i)))});`),ot(u,a,lt([e,...v])))),await p([...!w&&l?E(B(N),(async n=>{n!=e&&(await t(L+_(a)+"DROP"+_(n)),q(f,n))})):[]]),w)c(n)?await t(O+_(a)+S+" true"):await p(V(n,(async(n,s)=>{c(n)?await t(O+_(a)+S+_(e)+"=$1",[s]):h(v)||await o(t,a,e,z(n),{[s]:r?E(X(n),r):X(n)},f)})));else if(h(v))x(u,a)&&await t(O+_(a)+S+" true");else{const s=m(B(st(u,a)),(t=>t!=e)),i={},c=[];W(n??{},((t,a)=>{i[a]=E(s,(a=>r?r(t?.[a]):t?.[a])),A(c,a)})),await o(t,a,e,s,i),await t(O+_(a)+S+_(e)+`NOT IN(${F(c)})`,c)}},async a=>{let e;await t("BEGIN");try{e=await a()}catch(t){n?.(t)}return await t("END"),e}]},ft=async(t,a,e,n,i)=>{const o=[1];await t("INSERT INTO"+_(a)+"("+((...t)=>g(E(t,_),s))(e,...n)+")VALUES"+g(V(i,(t=>"($"+o[0]+++","+F(t,o)+")")),s)+"ON CONFLICT("+_(e)+")DO UPDATE SET"+g(E(n,(t=>_(t)+"=excluded."+_(t))),s),V(i,((t,a)=>[a,...E(t,(t=>t??null))])).flat())},gt=(t,a,e,n,s,i,o,[r,c,l],u,y,w,d,p,v)=>{const[f,g,E,h]=vt(a,u,y,s,p,v),m=pt(t,(async()=>await h((async()=>{return await f(),t=(await g(r,c))[T]?.[l]??"null",et(t,((t,a)=>""===a?void 0:a));var t}))),(async t=>await h((async()=>{var a;await f(),await E(r,c,{[T]:{[l]:(a=t()??null,at(a,((t,a)=>void 0===a?"":a)))}},!0,!0)}))),e,n,s,o,{[d]:()=>w,destroy:()=>(m.stopAutoLoad().stopAutoSave(),i(),m)},0,w);return m},Et=(t,a,e,n,s,i,o,[r,l,[u,y,w]],d,v,f,g,E,h,A,N)=>{const[b,S,C,L]=vt(a,d,v,s,E,h,A,N),O=async(t,a)=>await p(it(l,(async([e,n,s,i],o)=>{a&&!(o in t)||await C(e,n,t[o],s,i,a)}))),I=async(t,a)=>y?await C(w,$,{[T]:t},!0,!0,a):null,D=pt(t,(async()=>await L((async()=>{await b();const t=await(async()=>H(m(await p(it(r,(async([t,a],e)=>[t,await S(e,a)]))),(t=>!tt(t[1])))))(),a=await(async()=>u?(await S(w,$))[T]:{})();return tt(t)&&c(a)?void 0:[t,a]}))),(async(t,a)=>await L((async()=>{if(await b(),c(a)){const[a,e]=t();await O(a),await I(e)}else await O(a[0],!0),await I(a[1],!0)}))),e,n,s,o,{[g]:()=>f,destroy:()=>(D.stopAutoLoad().stopAutoSave(),i(),D)},0,f);return D},ht="ColumnName",mt="store",At="json",Nt=mt+"TableName",Tt=mt+"Id"+ht,$t=mt+ht,bt="autoLoadIntervalSeconds",St="rowId"+ht,Ct="tableId",Lt="tableName",Ot="deleteEmptyColumns",It="deleteEmptyTable",Dt={mode:At,[bt]:1},Rt={load:0,save:0,[Lt]:e+"_values"},Mt=(t,a,e,n,s)=>{const i=nt();return W(t,((t,o)=>{const r=w(X(K(a,u(t)?{[e]:t}:t)),0,Z(a));c(r[0])||n(o,r[0])||(s(o,r[0]),ot(i,o,r))})),i},Pt=(t,a,s,i,o,c,l,y,d,p,v="getDb",f)=>{let g,E,h;const m=((t,a)=>a?async(e,n)=>(a(e,n),await t(e,n)):t)(s,c),[A,N,T,C]=(t=>{const a=(t=>K(Dt,u(t)?{[Nt]:t}:t??{}))(t),n=a[bt];if(a.mode==At){const t=a[Nt]??e;return[1,n,[t,a[Tt]??$,a[$t]??mt],lt(t)]}const{tables:{load:s={},save:i={}}={},values:o={}}=a,r=w(X(K(Rt,o)),0,Z(Rt)),c=r[2],l=lt(c),y=lt(c);return[0,n,[Mt(s,{[Ct]:null,[St]:$},Ct,(t=>x(y,t)),(t=>ut(l,t))),Mt(i,{[Lt]:null,[St]:$,[Ot]:0,[It]:0},Lt,((t,a)=>x(y,a)),((t,a)=>ut(l,a))),r],l]})(a);return(A?gt:Et)(t,m,(t=>{let a;const e=()=>a=setInterval((async()=>{try{const[{d:a,s:e,c:n}]=await m(`${b} ${R} d,${M} s,TOTAL_CHANGES() c FROM ${D}${R} JOIN ${D}${M}`);a==g&&e==E&&n==h||(null!=g&&t(),g=a,E=e,h=n)}catch{}}),1e3*N),n=()=>{g=E=h=null,r(a)},s=i((a=>{C.has(a)&&(n(),t(),e())}));return e(),()=>{n(),o(s)}}),(t=>t()),l,y,d,T,B(C),(async(t,a)=>await t(`${b} t.name tn,c.name cn FROM ${P}list()t,${P}info(t.name)c ${S} t.schema='main'AND t.type IN('table','view')AND t.name IN(${F(a)})ORDER BY t.name,c.name`,a)),p,v,n,f,(t=>!0===t?1:!1===t?0:t),void 0)};t.createLibSqlPersister=(t,a,e,n,s)=>Pt(t,e,(async(t,e=[])=>(await a.execute({sql:t,args:e})).rows),(()=>()=>0),(t=>t()),n,s,(()=>0),1,a,"getClient")},"object"==typeof exports&&"undefined"!=typeof module?a(exports):"function"==typeof define&&define.amd?define(["exports"],a):a((t="undefined"!=typeof globalThis?globalThis:t||self).TinyBasePersisterLibsql={});
@@ -1 +1 @@
1
- var t,a;t=this,a=function(t){"use strict";const a=t=>typeof t,e="tinybase",n="",s=",",i=a(n),o=Promise,r=clearInterval,c=t=>null==t,l=(t,a,e)=>c(t)?e?.():a(t),u=t=>a(t)==i,y=t=>Array.isArray(t),w=(t,a,e)=>t.slice(a,e),d=t=>t.length,p=async t=>o.all(t),v=t=>{throw Error(t)},f=(t,a)=>t.forEach(a),g=(t,a="")=>t.join(a),E=(t,a)=>t.map(a),h=t=>0==d(t),m=(t,a)=>t.filter(a),A=(t,...a)=>t.push(...a),N=t=>t.shift(),T="_",$="_id",b="SELECT",S="WHERE",C="TABLE",L="ALTER "+C,O="DELETE FROM",I=b+"*FROM",D="pragma_",R="data_version",M="schema_version",P="pragma_table_",_=t=>`"${t.replace(/"/g,'""')}"`,F=(t,a=[1])=>g(E(t,(()=>"$"+a[0]++)),s),x=(t,a)=>t?.has(a)??!1,j=t=>c(t)||0==(t=>t?.size??0)(t),B=t=>[...t?.values()??[]],U=(t,a)=>t?.forEach(a),q=(t,a)=>t?.delete(a),J=Object,Y=t=>J.getPrototypeOf(t),k=J.entries,z=J.keys,G=J.freeze,H=(t=[])=>J.fromEntries(t),K=(...t)=>J.assign({},...t),Q=(t,a)=>(delete t[a],t),V=(t,a)=>E(k(t),(([t,e])=>a(e,t))),W=t=>J.values(t),X=t=>d(z(t)),Z=t=>(t=>!c(t)&&l(Y(t),(t=>t==J.prototype||c(Y(t))),(()=>!0)))(t)&&0==X(t),tt=JSON.stringify,at=JSON.parse,et=t=>new Map(t),nt=(t,a)=>t?.get(a),st=(t,a)=>E([...t?.entries()??[]],(([t,e])=>a(e,t))),it=(t,a,e)=>c(e)?(q(t,a),t):t?.set(a,e),ot=(t,a,e,n)=>(x(t,a)?n?.(nt(t,a)):it(t,a,e()),nt(t,a)),rt=(t,a,e,n,s=0)=>l((e?ot:nt)(t,a[s],s>d(a)-2?e:et),(i=>{if(s>d(a)-2)return n?.(i)&&it(t,a[s]),i;const o=rt(i,a,e,n,s+1);return j(i)&&it(t,a[s]),o})),ct=t=>new Set(y(t)||c(t)?t:[t]),lt=(t,a)=>t?.add(a),ut=/^\d+$/,yt=et(),wt=et(),dt=(t,a,e,s,i,o,r,u={},w=0,p=[])=>{let g,E,h,m=0,T=0,$=0;ot(yt,p,(()=>0)),ot(wt,p,(()=>[]));const b=et(),[S,C,L,O,I]=((t=1,a,e)=>1!=t&&a.isMergeable()?[1,a.getMergeableContent,()=>a.getTransactionMergeableChanges(!e),([[t],[a]])=>!Z(t)||!Z(a),a.setDefaultContent]:2!=t?[0,a.getContent,a.getTransactionChanges,([t,a])=>!Z(t)||!Z(a),a.setContent]:v("Store type not supported by this Persister"))(r,t,w),[D,R,M]=(()=>{let t;const[a,e]=(()=>{const t=[];let a=0;return[e=>(e?N(t):null)??n+a++,a=>{ut.test(a)&&d(t)<1e3&&A(t,a)}]})(),s=et();return[(e,i,o,r=[],c=()=>[])=>{t??=k;const l=a(1);return it(s,l,[e,i,o,r,c]),lt(rt(i,o??[n],ct),l),l},(a,e,...i)=>f(((t,a=[n])=>{const e=[],s=(t,n)=>n==d(a)?A(e,t):null===a[n]?U(t,(t=>s(t,n+1))):f([a[n],null],(a=>s(nt(t,a),n+1)));return s(t,0),e})(a,e),(a=>U(a,(a=>nt(s,a)[0](t,...e??[],...i))))),t=>l(nt(s,t),(([,a,i])=>(rt(a,i??[n],void 0,(a=>(q(a,t),j(a)?1:0))),it(s,t),e(t),i))),a=>l(nt(s,a),(([a,,e=[],n,s])=>{const i=(...o)=>{const r=d(o);r==d(e)?a(t,...o,...s(o)):c(e[r])?f(n[r]?.(...o)??[],(t=>i(...o,t))):i(...o,e[r])};i()}))]})(),P=t=>{t!=m&&(m=t,R(b,void 0,m))},_=a=>{(S&&y(a?.[0])?1===a?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===a?.[2]?t.applyChanges:t.setContent)(a)},F=async t=>(2!=m&&(P(1),T++,await Y((async()=>{try{const e=await a();y(e)?_(e):t?I(t):v("Content is not an array: "+e)}catch(a){o?.(a),t&&I(t)}P(0)}))),k),x=()=>(E&&(i(E),E=void 0),k),B=async t=>(1!=m&&(P(2),$++,await Y((async()=>{try{await e(C,t)}catch(t){o?.(t)}P(0)}))),k),J=()=>(h&&(t.delListener(h),h=void 0),k),Y=async(...t)=>(A(nt(wt,p),...t),await(async()=>{if(!nt(yt,p)){for(it(yt,p,1);!c(g=N(nt(wt,p)));)try{await g()}catch(t){o?.(t)}it(yt,p,0)}})(),k),k={load:F,startAutoLoad:async t=>{x(),await F(t);try{E=await s((async(t,a)=>{a||t?2!=m&&(P(1),T++,_(a??t),P(0)):await F()}))}catch(t){o?.(t)}return k},stopAutoLoad:x,isAutoLoading:()=>!c(E),save:B,startAutoSave:async()=>(J(),await B(),h=t.addDidFinishTransactionListener((()=>{const t=L();O(t)&&B(t)})),k),stopAutoSave:J,isAutoSaving:()=>!c(h),getStatus:()=>m,addStatusListener:t=>D(t,b),delListener:a=>(M(a),t),schedule:Y,getStore:()=>t,destroy:()=>(nt(wt,p).splice(0,void 0),x().stopAutoSave()),getStats:()=>({loads:T,saves:$}),...u};return G(k)},pt=(t,a,e,n,i,o=vt,r,l)=>{const u=et();return[async()=>{u.clear(),E(await e(t,a),(({tn:t,cn:a})=>lt(ot(u,t,ct),a)))},async(a,e)=>((t,a)=>x(nt(u,t),a))(a,e)?H(m(E(await t(I+_(a)),(t=>{return[t[e],l?(a=Q(t,e),n=l,H(V(a,((t,a)=>[a,n(t,a)])))):Q(t,e)];var a,n})),(([t,a])=>!c(t)&&!Z(a)))):{},async(a,e,n,l,y,w=!1)=>{const d=ct();V(n??{},(t=>E(z(t??{}),(t=>lt(d,t)))));const v=B(d);if(!w&&y&&h(v)&&x(u,a))return await t("DROP "+C+_(a)),void it(u,a);const f=nt(u,a),N=ct(B(f));if(h(v)||(x(u,a)?await p(E([e,...v],(async(n,s)=>{q(N,n)||(await t(L+_(a)+"ADD"+_(n)+i),0==s&&await t("CREATE UNIQUE INDEX pk ON "+_(a)+`(${_(e)})`),lt(f,n))}))):(await t("CREATE "+C+_(a)+`(${_(e)}${i} PRIMARY KEY${g(E(v,(t=>s+_(t)+i)))});`),it(u,a,ct([e,...v])))),await p([...!w&&l?E(B(N),(async n=>{n!=e&&(await t(L+_(a)+"DROP"+_(n)),q(f,n))})):[]]),w)c(n)?await t(O+_(a)+S+" true"):await p(V(n,(async(n,s)=>{c(n)?await t(O+_(a)+S+_(e)+"=$1",[s]):h(v)||await o(t,a,e,z(n),{[s]:r?E(W(n),r):W(n)},f)})));else if(h(v))x(u,a)&&await t(O+_(a)+S+" true");else{const s=m(B(nt(u,a)),(t=>t!=e)),i={},c=[];V(n??{},((t,a)=>{i[a]=E(s,(a=>r?r(t?.[a]):t?.[a])),A(c,a)})),await o(t,a,e,s,i),await t(O+_(a)+S+_(e)+`NOT IN(${F(c)})`,c)}},async a=>{let e;await t("BEGIN");try{e=await a()}catch(t){n?.(t)}return await t("END"),e}]},vt=async(t,a,e,n,i)=>{const o=[1];await t("INSERT INTO"+_(a)+"("+((...t)=>g(E(t,_),s))(e,...n)+")VALUES"+g(V(i,(t=>"($"+o[0]+++","+F(t,o)+")")),s)+"ON CONFLICT("+_(e)+")DO UPDATE SET"+g(E(n,(t=>_(t)+"=excluded."+_(t))),s),V(i,((t,a)=>[a,...E(t,(t=>t??null))])).flat())},ft=(t,a,e,n,s,i,o,[r,c,l],u,y,w,d,p,v)=>{const[f,g,E,h]=pt(a,u,y,s,p,v),m=dt(t,(async()=>await h((async()=>{return await f(),t=(await g(r,c))[T]?.[l]??"null",at(t,((t,a)=>""===a?void 0:a));var t}))),(async t=>await h((async()=>{var a;await f(),await E(r,c,{[T]:{[l]:(a=t()??null,tt(a,((t,a)=>void 0===a?"":a)))}},!0,!0)}))),e,n,s,o,{[d]:()=>w,destroy:()=>(m.stopAutoLoad().stopAutoSave(),i(),m)},0,w);return m},gt=(t,a,e,n,s,i,o,[r,l,[u,y,w]],d,v,f,g,E,h,A,N)=>{const[b,S,C,L]=pt(a,d,v,s,E,h,A,N),O=async(t,a)=>await p(st(l,(async([e,n,s,i],o)=>{a&&!(o in t)||await C(e,n,t[o],s,i,a)}))),I=async(t,a)=>y?await C(w,$,{[T]:t},!0,!0,a):null,D=dt(t,(async()=>await L((async()=>{await b();const t=await(async()=>H(m(await p(st(r,(async([t,a],e)=>[t,await S(e,a)]))),(t=>!Z(t[1])))))(),a=await(async()=>u?(await S(w,$))[T]:{})();return Z(t)&&c(a)?void 0:[t,a]}))),(async(t,a)=>await L((async()=>{if(await b(),c(a)){const[a,e]=t();await O(a),await I(e)}else await O(a[0],!0),await I(a[1],!0)}))),e,n,s,o,{[g]:()=>f,destroy:()=>(D.stopAutoLoad().stopAutoSave(),i(),D)},0,f);return D},Et="ColumnName",ht="store",mt="json",At=ht+"TableName",Nt=ht+"Id"+Et,Tt=ht+Et,$t="autoLoadIntervalSeconds",bt="rowId"+Et,St="tableId",Ct="tableName",Lt="deleteEmptyColumns",Ot="deleteEmptyTable",It={mode:mt,[$t]:1},Dt={load:0,save:0,[Ct]:e+"_values"},Rt=(t,a,e,n,s)=>{const i=et();return V(t,((t,o)=>{const r=w(W(K(a,u(t)?{[e]:t}:t)),0,X(a));c(r[0])||n(o,r[0])||(s(o,r[0]),it(i,o,r))})),i},Mt=(t,a,s,i,o,c,l,y,d,p,v="getDb",f)=>{let g,E,h;const m=((t,a)=>a?async(e,n)=>(a(e,n),await t(e,n)):t)(s,c),[A,N,T,C]=(t=>{const a=(t=>K(It,u(t)?{[At]:t}:t??{}))(t),n=a[$t];if(a.mode==mt){const t=a[At]??e;return[1,n,[t,a[Nt]??$,a[Tt]??ht],ct(t)]}const{tables:{load:s={},save:i={}}={},values:o={}}=a,r=w(W(K(Dt,o)),0,X(Dt)),c=r[2],l=ct(c),y=ct(c);return[0,n,[Rt(s,{[St]:null,[bt]:$},St,(t=>x(y,t)),(t=>lt(l,t))),Rt(i,{[Ct]:null,[bt]:$,[Lt]:0,[Ot]:0},Ct,((t,a)=>x(y,a)),((t,a)=>lt(l,a))),r],l]})(a);return(A?ft:gt)(t,m,(t=>{let a;const e=()=>a=setInterval((async()=>{try{const[{d:a,s:e,c:n}]=await m(`${b} ${R} d,${M} s,TOTAL_CHANGES() c FROM ${D}${R} JOIN ${D}${M}`);a==g&&e==E&&n==h||(null!=g&&t(),g=a,E=e,h=n)}catch{}}),1e3*N),n=()=>{g=E=h=null,r(a)},s=i((a=>{C.has(a)&&(n(),t(),e())}));return e(),()=>{n(),o(s)}}),(t=>t()),l,y,d,T,B(C),(async(t,a)=>await t(`${b} t.name tn,c.name cn FROM ${P}list()t,${P}info(t.name)c ${S} t.schema='main'AND t.type IN('table','view')AND t.name IN(${F(a)})ORDER BY t.name,c.name`,a)),p,v,n,f,(t=>!0===t?1:!1===t?0:t),void 0)};t.createLibSqlPersister=(t,a,e,n,s)=>Mt(t,e,(async(t,e=[])=>(await a.execute({sql:t,args:e})).rows),(()=>()=>0),(t=>t()),n,s,(()=>0),1,a,"getClient")},"object"==typeof exports&&"undefined"!=typeof module?a(exports):"function"==typeof define&&define.amd?define(["exports"],a):a((t="undefined"!=typeof globalThis?globalThis:t||self).TinyBasePersisterLibsql={});
1
+ var t,a;t=this,a=function(t){"use strict";const a=t=>typeof t,e="tinybase",n="",s=",",i=a(n),o=Promise,r=clearInterval,c=t=>null==t,l=(t,a,e)=>c(t)?e?.():a(t),u=t=>a(t)==i,y=t=>Array.isArray(t),w=(t,a,e)=>t.slice(a,e),d=t=>t.length,p=async t=>o.all(t),v=t=>{throw Error(t)},f=(t,a)=>t.forEach(a),g=(t,a="")=>t.join(a),E=(t,a)=>t.map(a),h=t=>0==d(t),m=(t,a)=>t.filter(a),A=(t,...a)=>t.push(...a),N=t=>t.shift(),T="_",$="_id",b="SELECT",S="WHERE",C="TABLE",L="ALTER "+C,O="DELETE FROM",I=b+"*FROM",D="pragma_",R="data_version",M="schema_version",P="pragma_table_",_=t=>`"${t.replace(/"/g,'""')}"`,F=(t,a=[1])=>g(E(t,(()=>"$"+a[0]++)),s),x=(t,a)=>t?.has(a)??!1,j=t=>c(t)||0==(t=>t?.size??0)(t),B=t=>[...t?.values()??[]],U=(t,a)=>t?.forEach(a),q=(t,a)=>t?.delete(a),J=Object,Y=t=>J.getPrototypeOf(t),k=J.entries,z=J.keys,G=J.freeze,H=(t=[])=>J.fromEntries(t),K=(...t)=>J.assign({},...t),Q=(t,a)=>(delete t[a],t),V=(t,a)=>E(k(t),(([t,e])=>a(e,t))),W=(t,a)=>H(V(t,((t,e)=>[e,a(t,e)]))),X=t=>J.values(t),Z=t=>d(z(t)),tt=t=>(t=>!c(t)&&l(Y(t),(t=>t==J.prototype||c(Y(t))),(()=>!0)))(t)&&0==Z(t),at=JSON.stringify,et=JSON.parse,nt=t=>new Map(t),st=(t,a)=>t?.get(a),it=(t,a)=>E([...t?.entries()??[]],(([t,e])=>a(e,t))),ot=(t,a,e)=>c(e)?(q(t,a),t):t?.set(a,e),rt=(t,a,e,n)=>(x(t,a)?n?.(st(t,a)):ot(t,a,e()),st(t,a)),ct=(t,a,e,n,s=0)=>l((e?rt:st)(t,a[s],s>d(a)-2?e:nt),(i=>{if(s>d(a)-2)return n?.(i)&&ot(t,a[s]),i;const o=ct(i,a,e,n,s+1);return j(i)&&ot(t,a[s]),o})),lt=t=>new Set(y(t)||c(t)?t:[t]),ut=(t,a)=>t?.add(a),yt=/^\d+$/,wt=nt(),dt=nt(),pt=(t,a,e,s,i,o,r,u={},w=0,p=[])=>{let g,E,h,m=0,T=0,$=0;rt(wt,p,(()=>0)),rt(dt,p,(()=>[]));const b=nt(),[S,C,L,O,I]=((t=1,a,e)=>1!=t&&a.isMergeable()?[1,a.getMergeableContent,()=>a.getTransactionMergeableChanges(!e),([[t],[a]])=>!tt(t)||!tt(a),a.setDefaultContent]:2!=t?[0,a.getContent,a.getTransactionChanges,([t,a])=>!tt(t)||!tt(a),a.setContent]:v("Store type not supported by this Persister"))(r,t,w),[D,R,M]=(()=>{let t;const[a,e]=(()=>{const t=[];let a=0;return[e=>(e?N(t):null)??n+a++,a=>{yt.test(a)&&d(t)<1e3&&A(t,a)}]})(),s=nt();return[(e,i,o,r=[],c=()=>[])=>{t??=k;const l=a(1);return ot(s,l,[e,i,o,r,c]),ut(ct(i,o??[n],lt),l),l},(a,e,...i)=>f(((t,a=[n])=>{const e=[],s=(t,n)=>n==d(a)?A(e,t):null===a[n]?U(t,(t=>s(t,n+1))):f([a[n],null],(a=>s(st(t,a),n+1)));return s(t,0),e})(a,e),(a=>U(a,(a=>st(s,a)[0](t,...e??[],...i))))),t=>l(st(s,t),(([,a,i])=>(ct(a,i??[n],void 0,(a=>(q(a,t),j(a)?1:0))),ot(s,t),e(t),i))),a=>l(st(s,a),(([a,,e=[],n,s])=>{const i=(...o)=>{const r=d(o);r==d(e)?a(t,...o,...s(o)):c(e[r])?f(n[r]?.(...o)??[],(t=>i(...o,t))):i(...o,e[r])};i()}))]})(),P=t=>{t!=m&&(m=t,R(b,void 0,m))},_=a=>{(S&&y(a?.[0])?1===a?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===a?.[2]?t.applyChanges:t.setContent)(a)},F=async t=>(2!=m&&(P(1),T++,await Y((async()=>{try{const e=await a();y(e)?_(e):t?I(t):v("Content is not an array: "+e)}catch(a){o?.(a),t&&I(t)}P(0)}))),k),x=()=>(E&&(i(E),E=void 0),k),B=async t=>(1!=m&&(P(2),$++,await Y((async()=>{try{await e(C,t)}catch(t){o?.(t)}P(0)}))),k),J=()=>(h&&(t.delListener(h),h=void 0),k),Y=async(...t)=>(A(st(dt,p),...t),await(async()=>{if(!st(wt,p)){for(ot(wt,p,1);!c(g=N(st(dt,p)));)try{await g()}catch(t){o?.(t)}ot(wt,p,0)}})(),k),k={load:F,startAutoLoad:async t=>{x(),await F(t);try{E=await s((async(t,a)=>{a||t?2!=m&&(P(1),T++,_(a??t),P(0)):await F()}))}catch(t){o?.(t)}return k},stopAutoLoad:x,isAutoLoading:()=>!c(E),save:B,startAutoSave:async()=>(J(),await B(),h=t.addDidFinishTransactionListener((()=>{const t=L();O(t)&&B(t)})),k),stopAutoSave:J,isAutoSaving:()=>!c(h),getStatus:()=>m,addStatusListener:t=>D(t,b),delListener:a=>(M(a),t),schedule:Y,getStore:()=>t,destroy:()=>(st(dt,p).splice(0,void 0),x().stopAutoSave()),getStats:()=>({loads:T,saves:$}),...u};return G(k)},vt=(t,a,e,n,i,o=ft,r,l)=>{const u=nt();return[async()=>{u.clear(),E(await e(t,a),(({tn:t,cn:a})=>ut(rt(u,t,lt),a)))},async(a,e)=>((t,a)=>x(st(u,t),a))(a,e)?H(m(E(await t(I+_(a)),(t=>[t[e],l?W(Q(t,e),l):Q(t,e)])),(([t,a])=>!c(t)&&!tt(a)))):{},async(a,e,n,l,y,w=!1)=>{const d=lt();W(n??{},(t=>E(z(t??{}),(t=>ut(d,t)))));const v=B(d);if(!w&&y&&h(v)&&x(u,a))return await t("DROP "+C+_(a)),void ot(u,a);const f=st(u,a),N=lt(B(f));if(h(v)||(x(u,a)?await p(E([e,...v],(async(n,s)=>{q(N,n)||(await t(L+_(a)+"ADD"+_(n)+i),0==s&&await t("CREATE UNIQUE INDEX pk ON "+_(a)+`(${_(e)})`),ut(f,n))}))):(await t("CREATE "+C+_(a)+`(${_(e)}${i} PRIMARY KEY${g(E(v,(t=>s+_(t)+i)))});`),ot(u,a,lt([e,...v])))),await p([...!w&&l?E(B(N),(async n=>{n!=e&&(await t(L+_(a)+"DROP"+_(n)),q(f,n))})):[]]),w)c(n)?await t(O+_(a)+S+" true"):await p(V(n,(async(n,s)=>{c(n)?await t(O+_(a)+S+_(e)+"=$1",[s]):h(v)||await o(t,a,e,z(n),{[s]:r?E(X(n),r):X(n)},f)})));else if(h(v))x(u,a)&&await t(O+_(a)+S+" true");else{const s=m(B(st(u,a)),(t=>t!=e)),i={},c=[];W(n??{},((t,a)=>{i[a]=E(s,(a=>r?r(t?.[a]):t?.[a])),A(c,a)})),await o(t,a,e,s,i),await t(O+_(a)+S+_(e)+`NOT IN(${F(c)})`,c)}},async a=>{let e;await t("BEGIN");try{e=await a()}catch(t){n?.(t)}return await t("END"),e}]},ft=async(t,a,e,n,i)=>{const o=[1];await t("INSERT INTO"+_(a)+"("+((...t)=>g(E(t,_),s))(e,...n)+")VALUES"+g(V(i,(t=>"($"+o[0]+++","+F(t,o)+")")),s)+"ON CONFLICT("+_(e)+")DO UPDATE SET"+g(E(n,(t=>_(t)+"=excluded."+_(t))),s),V(i,((t,a)=>[a,...E(t,(t=>t??null))])).flat())},gt=(t,a,e,n,s,i,o,[r,c,l],u,y,w,d,p,v)=>{const[f,g,E,h]=vt(a,u,y,s,p,v),m=pt(t,(async()=>await h((async()=>{return await f(),t=(await g(r,c))[T]?.[l]??"null",et(t,((t,a)=>""===a?void 0:a));var t}))),(async t=>await h((async()=>{var a;await f(),await E(r,c,{[T]:{[l]:(a=t()??null,at(a,((t,a)=>void 0===a?"":a)))}},!0,!0)}))),e,n,s,o,{[d]:()=>w,destroy:()=>(m.stopAutoLoad().stopAutoSave(),i(),m)},0,w);return m},Et=(t,a,e,n,s,i,o,[r,l,[u,y,w]],d,v,f,g,E,h,A,N)=>{const[b,S,C,L]=vt(a,d,v,s,E,h,A,N),O=async(t,a)=>await p(it(l,(async([e,n,s,i],o)=>{a&&!(o in t)||await C(e,n,t[o],s,i,a)}))),I=async(t,a)=>y?await C(w,$,{[T]:t},!0,!0,a):null,D=pt(t,(async()=>await L((async()=>{await b();const t=await(async()=>H(m(await p(it(r,(async([t,a],e)=>[t,await S(e,a)]))),(t=>!tt(t[1])))))(),a=await(async()=>u?(await S(w,$))[T]:{})();return tt(t)&&c(a)?void 0:[t,a]}))),(async(t,a)=>await L((async()=>{if(await b(),c(a)){const[a,e]=t();await O(a),await I(e)}else await O(a[0],!0),await I(a[1],!0)}))),e,n,s,o,{[g]:()=>f,destroy:()=>(D.stopAutoLoad().stopAutoSave(),i(),D)},0,f);return D},ht="ColumnName",mt="store",At="json",Nt=mt+"TableName",Tt=mt+"Id"+ht,$t=mt+ht,bt="autoLoadIntervalSeconds",St="rowId"+ht,Ct="tableId",Lt="tableName",Ot="deleteEmptyColumns",It="deleteEmptyTable",Dt={mode:At,[bt]:1},Rt={load:0,save:0,[Lt]:e+"_values"},Mt=(t,a,e,n,s)=>{const i=nt();return W(t,((t,o)=>{const r=w(X(K(a,u(t)?{[e]:t}:t)),0,Z(a));c(r[0])||n(o,r[0])||(s(o,r[0]),ot(i,o,r))})),i},Pt=(t,a,s,i,o,c,l,y,d,p,v="getDb",f)=>{let g,E,h;const m=((t,a)=>a?async(e,n)=>(a(e,n),await t(e,n)):t)(s,c),[A,N,T,C]=(t=>{const a=(t=>K(Dt,u(t)?{[Nt]:t}:t??{}))(t),n=a[bt];if(a.mode==At){const t=a[Nt]??e;return[1,n,[t,a[Tt]??$,a[$t]??mt],lt(t)]}const{tables:{load:s={},save:i={}}={},values:o={}}=a,r=w(X(K(Rt,o)),0,Z(Rt)),c=r[2],l=lt(c),y=lt(c);return[0,n,[Mt(s,{[Ct]:null,[St]:$},Ct,(t=>x(y,t)),(t=>ut(l,t))),Mt(i,{[Lt]:null,[St]:$,[Ot]:0,[It]:0},Lt,((t,a)=>x(y,a)),((t,a)=>ut(l,a))),r],l]})(a);return(A?gt:Et)(t,m,(t=>{let a;const e=()=>a=setInterval((async()=>{try{const[{d:a,s:e,c:n}]=await m(`${b} ${R} d,${M} s,TOTAL_CHANGES() c FROM ${D}${R} JOIN ${D}${M}`);a==g&&e==E&&n==h||(null!=g&&t(),g=a,E=e,h=n)}catch{}}),1e3*N),n=()=>{g=E=h=null,r(a)},s=i((a=>{C.has(a)&&(n(),t(),e())}));return e(),()=>{n(),o(s)}}),(t=>t()),l,y,d,T,B(C),(async(t,a)=>await t(`${b} t.name tn,c.name cn FROM ${P}list()t,${P}info(t.name)c ${S} t.schema='main'AND t.type IN('table','view')AND t.name IN(${F(a)})ORDER BY t.name,c.name`,a)),p,v,n,f,(t=>!0===t?1:!1===t?0:t),void 0)};t.createLibSqlPersister=(t,a,e,n,s)=>Pt(t,e,(async(t,e=[])=>(await a.execute({sql:t,args:e})).rows),(()=>()=>0),(t=>t()),n,s,(()=>0),1,a,"getClient")},"object"==typeof exports&&"undefined"!=typeof module?a(exports):"function"==typeof define&&define.amd?define(["exports"],a):a((t="undefined"!=typeof globalThis?globalThis:t||self).TinyBasePersisterLibsql={});