tinybase 5.3.2 → 5.3.3

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 (686) hide show
  1. package/cjs/common/index.cjs +1 -1
  2. package/cjs/common/with-schemas/index.cjs +1 -1
  3. package/cjs/es6/common/index.cjs +1 -1
  4. package/cjs/es6/common/with-schemas/index.cjs +1 -1
  5. package/cjs/es6/index.cjs +1 -1
  6. package/cjs/es6/mergeable-store/index.cjs +1 -1
  7. package/cjs/es6/mergeable-store/with-schemas/index.cjs +1 -1
  8. package/cjs/es6/min/common/index.cjs +1 -1
  9. package/cjs/es6/min/common/index.cjs.gz +0 -0
  10. package/cjs/es6/min/common/with-schemas/index.cjs +1 -1
  11. package/cjs/es6/min/common/with-schemas/index.cjs.gz +0 -0
  12. package/cjs/es6/min/index.cjs +1 -1
  13. package/cjs/es6/min/index.cjs.gz +0 -0
  14. package/cjs/es6/min/mergeable-store/index.cjs +1 -1
  15. package/cjs/es6/min/mergeable-store/index.cjs.gz +0 -0
  16. package/cjs/es6/min/mergeable-store/with-schemas/index.cjs +1 -1
  17. package/cjs/es6/min/mergeable-store/with-schemas/index.cjs.gz +0 -0
  18. package/cjs/es6/min/persisters/index.cjs +1 -1
  19. package/cjs/es6/min/persisters/index.cjs.gz +0 -0
  20. package/cjs/es6/min/persisters/persister-cr-sqlite-wasm/index.cjs +1 -1
  21. package/cjs/es6/min/persisters/persister-cr-sqlite-wasm/index.cjs.gz +0 -0
  22. package/cjs/es6/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.cjs +1 -1
  23. package/cjs/es6/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.cjs.gz +0 -0
  24. package/cjs/es6/min/persisters/persister-electric-sql/index.cjs +1 -1
  25. package/cjs/es6/min/persisters/persister-electric-sql/index.cjs.gz +0 -0
  26. package/cjs/es6/min/persisters/persister-electric-sql/with-schemas/index.cjs +1 -1
  27. package/cjs/es6/min/persisters/persister-electric-sql/with-schemas/index.cjs.gz +0 -0
  28. package/cjs/es6/min/persisters/persister-expo-sqlite/index.cjs +1 -1
  29. package/cjs/es6/min/persisters/persister-expo-sqlite/index.cjs.gz +0 -0
  30. package/cjs/es6/min/persisters/persister-expo-sqlite/with-schemas/index.cjs +1 -1
  31. package/cjs/es6/min/persisters/persister-expo-sqlite/with-schemas/index.cjs.gz +0 -0
  32. package/cjs/es6/min/persisters/persister-libsql/index.cjs +1 -1
  33. package/cjs/es6/min/persisters/persister-libsql/index.cjs.gz +0 -0
  34. package/cjs/es6/min/persisters/persister-libsql/with-schemas/index.cjs +1 -1
  35. package/cjs/es6/min/persisters/persister-libsql/with-schemas/index.cjs.gz +0 -0
  36. package/cjs/es6/min/persisters/persister-pglite/index.cjs +1 -1
  37. package/cjs/es6/min/persisters/persister-pglite/index.cjs.gz +0 -0
  38. package/cjs/es6/min/persisters/persister-pglite/with-schemas/index.cjs +1 -1
  39. package/cjs/es6/min/persisters/persister-pglite/with-schemas/index.cjs.gz +0 -0
  40. package/cjs/es6/min/persisters/persister-postgres/index.cjs +1 -1
  41. package/cjs/es6/min/persisters/persister-postgres/index.cjs.gz +0 -0
  42. package/cjs/es6/min/persisters/persister-postgres/with-schemas/index.cjs +1 -1
  43. package/cjs/es6/min/persisters/persister-postgres/with-schemas/index.cjs.gz +0 -0
  44. package/cjs/es6/min/persisters/persister-powersync/index.cjs +1 -1
  45. package/cjs/es6/min/persisters/persister-powersync/index.cjs.gz +0 -0
  46. package/cjs/es6/min/persisters/persister-powersync/with-schemas/index.cjs +1 -1
  47. package/cjs/es6/min/persisters/persister-powersync/with-schemas/index.cjs.gz +0 -0
  48. package/cjs/es6/min/persisters/persister-sqlite-wasm/index.cjs +1 -1
  49. package/cjs/es6/min/persisters/persister-sqlite-wasm/index.cjs.gz +0 -0
  50. package/cjs/es6/min/persisters/persister-sqlite-wasm/with-schemas/index.cjs +1 -1
  51. package/cjs/es6/min/persisters/persister-sqlite-wasm/with-schemas/index.cjs.gz +0 -0
  52. package/cjs/es6/min/persisters/persister-sqlite3/index.cjs +1 -1
  53. package/cjs/es6/min/persisters/persister-sqlite3/index.cjs.gz +0 -0
  54. package/cjs/es6/min/persisters/persister-sqlite3/with-schemas/index.cjs +1 -1
  55. package/cjs/es6/min/persisters/persister-sqlite3/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/synchronizers/index.cjs +1 -1
  59. package/cjs/es6/min/synchronizers/index.cjs.gz +0 -0
  60. package/cjs/es6/min/synchronizers/synchronizer-broadcast-channel/index.cjs +1 -1
  61. package/cjs/es6/min/synchronizers/synchronizer-broadcast-channel/index.cjs.gz +0 -0
  62. package/cjs/es6/min/synchronizers/synchronizer-broadcast-channel/with-schemas/index.cjs +1 -1
  63. package/cjs/es6/min/synchronizers/synchronizer-broadcast-channel/with-schemas/index.cjs.gz +0 -0
  64. package/cjs/es6/min/synchronizers/synchronizer-local/index.cjs +1 -1
  65. package/cjs/es6/min/synchronizers/synchronizer-local/index.cjs.gz +0 -0
  66. package/cjs/es6/min/synchronizers/synchronizer-local/with-schemas/index.cjs +1 -1
  67. package/cjs/es6/min/synchronizers/synchronizer-local/with-schemas/index.cjs.gz +0 -0
  68. package/cjs/es6/min/synchronizers/synchronizer-ws-client/index.cjs +1 -1
  69. package/cjs/es6/min/synchronizers/synchronizer-ws-client/index.cjs.gz +0 -0
  70. package/cjs/es6/min/synchronizers/synchronizer-ws-client/with-schemas/index.cjs +1 -1
  71. package/cjs/es6/min/synchronizers/synchronizer-ws-client/with-schemas/index.cjs.gz +0 -0
  72. package/cjs/es6/min/synchronizers/synchronizer-ws-server/index.cjs +1 -1
  73. package/cjs/es6/min/synchronizers/synchronizer-ws-server/index.cjs.gz +0 -0
  74. package/cjs/es6/min/synchronizers/synchronizer-ws-server/with-schemas/index.cjs +1 -1
  75. package/cjs/es6/min/synchronizers/synchronizer-ws-server/with-schemas/index.cjs.gz +0 -0
  76. package/cjs/es6/min/synchronizers/with-schemas/index.cjs +1 -1
  77. package/cjs/es6/min/synchronizers/with-schemas/index.cjs.gz +0 -0
  78. package/cjs/es6/min/ui-react-inspector/index.cjs +1 -1
  79. package/cjs/es6/min/ui-react-inspector/index.cjs.gz +0 -0
  80. package/cjs/es6/min/ui-react-inspector/with-schemas/index.cjs +1 -1
  81. package/cjs/es6/min/ui-react-inspector/with-schemas/index.cjs.gz +0 -0
  82. package/cjs/es6/min/with-schemas/index.cjs +1 -1
  83. package/cjs/es6/min/with-schemas/index.cjs.gz +0 -0
  84. package/cjs/es6/persisters/index.cjs +83 -103
  85. package/cjs/es6/persisters/persister-cr-sqlite-wasm/index.cjs +82 -102
  86. package/cjs/es6/persisters/persister-cr-sqlite-wasm/with-schemas/index.cjs +82 -102
  87. package/cjs/es6/persisters/persister-electric-sql/index.cjs +82 -102
  88. package/cjs/es6/persisters/persister-electric-sql/with-schemas/index.cjs +82 -102
  89. package/cjs/es6/persisters/persister-expo-sqlite/index.cjs +82 -102
  90. package/cjs/es6/persisters/persister-expo-sqlite/with-schemas/index.cjs +82 -102
  91. package/cjs/es6/persisters/persister-libsql/index.cjs +82 -102
  92. package/cjs/es6/persisters/persister-libsql/with-schemas/index.cjs +82 -102
  93. package/cjs/es6/persisters/persister-pglite/index.cjs +81 -101
  94. package/cjs/es6/persisters/persister-pglite/with-schemas/index.cjs +81 -101
  95. package/cjs/es6/persisters/persister-postgres/index.cjs +81 -101
  96. package/cjs/es6/persisters/persister-postgres/with-schemas/index.cjs +81 -101
  97. package/cjs/es6/persisters/persister-powersync/index.cjs +212 -147
  98. package/cjs/es6/persisters/persister-powersync/with-schemas/index.cjs +212 -147
  99. package/cjs/es6/persisters/persister-sqlite-wasm/index.cjs +82 -102
  100. package/cjs/es6/persisters/persister-sqlite-wasm/with-schemas/index.cjs +82 -102
  101. package/cjs/es6/persisters/persister-sqlite3/index.cjs +82 -102
  102. package/cjs/es6/persisters/persister-sqlite3/with-schemas/index.cjs +82 -102
  103. package/cjs/es6/persisters/with-schemas/index.cjs +83 -103
  104. package/cjs/es6/synchronizers/index.cjs +1 -1
  105. package/cjs/es6/synchronizers/synchronizer-broadcast-channel/index.cjs +1 -1
  106. package/cjs/es6/synchronizers/synchronizer-broadcast-channel/with-schemas/index.cjs +1 -1
  107. package/cjs/es6/synchronizers/synchronizer-local/index.cjs +1 -1
  108. package/cjs/es6/synchronizers/synchronizer-local/with-schemas/index.cjs +1 -1
  109. package/cjs/es6/synchronizers/synchronizer-ws-client/index.cjs +1 -1
  110. package/cjs/es6/synchronizers/synchronizer-ws-client/with-schemas/index.cjs +1 -1
  111. package/cjs/es6/synchronizers/synchronizer-ws-server/index.cjs +1 -1
  112. package/cjs/es6/synchronizers/synchronizer-ws-server/with-schemas/index.cjs +1 -1
  113. package/cjs/es6/synchronizers/with-schemas/index.cjs +1 -1
  114. package/cjs/es6/ui-react-inspector/index.cjs +0 -2
  115. package/cjs/es6/ui-react-inspector/with-schemas/index.cjs +0 -2
  116. package/cjs/es6/with-schemas/index.cjs +1 -1
  117. package/cjs/index.cjs +1 -1
  118. package/cjs/mergeable-store/index.cjs +1 -1
  119. package/cjs/mergeable-store/with-schemas/index.cjs +1 -1
  120. package/cjs/min/common/index.cjs +1 -1
  121. package/cjs/min/common/index.cjs.gz +0 -0
  122. package/cjs/min/common/with-schemas/index.cjs +1 -1
  123. package/cjs/min/common/with-schemas/index.cjs.gz +0 -0
  124. package/cjs/min/index.cjs +1 -1
  125. package/cjs/min/index.cjs.gz +0 -0
  126. package/cjs/min/mergeable-store/index.cjs +1 -1
  127. package/cjs/min/mergeable-store/index.cjs.gz +0 -0
  128. package/cjs/min/mergeable-store/with-schemas/index.cjs +1 -1
  129. package/cjs/min/mergeable-store/with-schemas/index.cjs.gz +0 -0
  130. package/cjs/min/persisters/index.cjs +1 -1
  131. package/cjs/min/persisters/index.cjs.gz +0 -0
  132. package/cjs/min/persisters/persister-cr-sqlite-wasm/index.cjs +1 -1
  133. package/cjs/min/persisters/persister-cr-sqlite-wasm/index.cjs.gz +0 -0
  134. package/cjs/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.cjs +1 -1
  135. package/cjs/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.cjs.gz +0 -0
  136. package/cjs/min/persisters/persister-electric-sql/index.cjs +1 -1
  137. package/cjs/min/persisters/persister-electric-sql/index.cjs.gz +0 -0
  138. package/cjs/min/persisters/persister-electric-sql/with-schemas/index.cjs +1 -1
  139. package/cjs/min/persisters/persister-electric-sql/with-schemas/index.cjs.gz +0 -0
  140. package/cjs/min/persisters/persister-expo-sqlite/index.cjs +1 -1
  141. package/cjs/min/persisters/persister-expo-sqlite/index.cjs.gz +0 -0
  142. package/cjs/min/persisters/persister-expo-sqlite/with-schemas/index.cjs +1 -1
  143. package/cjs/min/persisters/persister-expo-sqlite/with-schemas/index.cjs.gz +0 -0
  144. package/cjs/min/persisters/persister-libsql/index.cjs +1 -1
  145. package/cjs/min/persisters/persister-libsql/index.cjs.gz +0 -0
  146. package/cjs/min/persisters/persister-libsql/with-schemas/index.cjs +1 -1
  147. package/cjs/min/persisters/persister-libsql/with-schemas/index.cjs.gz +0 -0
  148. package/cjs/min/persisters/persister-pglite/index.cjs +1 -1
  149. package/cjs/min/persisters/persister-pglite/index.cjs.gz +0 -0
  150. package/cjs/min/persisters/persister-pglite/with-schemas/index.cjs +1 -1
  151. package/cjs/min/persisters/persister-pglite/with-schemas/index.cjs.gz +0 -0
  152. package/cjs/min/persisters/persister-postgres/index.cjs +1 -1
  153. package/cjs/min/persisters/persister-postgres/index.cjs.gz +0 -0
  154. package/cjs/min/persisters/persister-postgres/with-schemas/index.cjs +1 -1
  155. package/cjs/min/persisters/persister-postgres/with-schemas/index.cjs.gz +0 -0
  156. package/cjs/min/persisters/persister-powersync/index.cjs +1 -1
  157. package/cjs/min/persisters/persister-powersync/index.cjs.gz +0 -0
  158. package/cjs/min/persisters/persister-powersync/with-schemas/index.cjs +1 -1
  159. package/cjs/min/persisters/persister-powersync/with-schemas/index.cjs.gz +0 -0
  160. package/cjs/min/persisters/persister-sqlite-wasm/index.cjs +1 -1
  161. package/cjs/min/persisters/persister-sqlite-wasm/index.cjs.gz +0 -0
  162. package/cjs/min/persisters/persister-sqlite-wasm/with-schemas/index.cjs +1 -1
  163. package/cjs/min/persisters/persister-sqlite-wasm/with-schemas/index.cjs.gz +0 -0
  164. package/cjs/min/persisters/persister-sqlite3/index.cjs +1 -1
  165. package/cjs/min/persisters/persister-sqlite3/index.cjs.gz +0 -0
  166. package/cjs/min/persisters/persister-sqlite3/with-schemas/index.cjs +1 -1
  167. package/cjs/min/persisters/persister-sqlite3/with-schemas/index.cjs.gz +0 -0
  168. package/cjs/min/persisters/with-schemas/index.cjs +1 -1
  169. package/cjs/min/persisters/with-schemas/index.cjs.gz +0 -0
  170. package/cjs/min/synchronizers/index.cjs +1 -1
  171. package/cjs/min/synchronizers/index.cjs.gz +0 -0
  172. package/cjs/min/synchronizers/synchronizer-broadcast-channel/index.cjs +1 -1
  173. package/cjs/min/synchronizers/synchronizer-broadcast-channel/index.cjs.gz +0 -0
  174. package/cjs/min/synchronizers/synchronizer-broadcast-channel/with-schemas/index.cjs +1 -1
  175. package/cjs/min/synchronizers/synchronizer-broadcast-channel/with-schemas/index.cjs.gz +0 -0
  176. package/cjs/min/synchronizers/synchronizer-local/index.cjs +1 -1
  177. package/cjs/min/synchronizers/synchronizer-local/index.cjs.gz +0 -0
  178. package/cjs/min/synchronizers/synchronizer-local/with-schemas/index.cjs +1 -1
  179. package/cjs/min/synchronizers/synchronizer-local/with-schemas/index.cjs.gz +0 -0
  180. package/cjs/min/synchronizers/synchronizer-ws-client/index.cjs +1 -1
  181. package/cjs/min/synchronizers/synchronizer-ws-client/index.cjs.gz +0 -0
  182. package/cjs/min/synchronizers/synchronizer-ws-client/with-schemas/index.cjs +1 -1
  183. package/cjs/min/synchronizers/synchronizer-ws-client/with-schemas/index.cjs.gz +0 -0
  184. package/cjs/min/synchronizers/synchronizer-ws-server/index.cjs +1 -1
  185. package/cjs/min/synchronizers/synchronizer-ws-server/index.cjs.gz +0 -0
  186. package/cjs/min/synchronizers/synchronizer-ws-server/with-schemas/index.cjs +1 -1
  187. package/cjs/min/synchronizers/synchronizer-ws-server/with-schemas/index.cjs.gz +0 -0
  188. package/cjs/min/synchronizers/with-schemas/index.cjs +1 -1
  189. package/cjs/min/synchronizers/with-schemas/index.cjs.gz +0 -0
  190. package/cjs/min/ui-react-inspector/index.cjs +1 -1
  191. package/cjs/min/ui-react-inspector/index.cjs.gz +0 -0
  192. package/cjs/min/ui-react-inspector/with-schemas/index.cjs +1 -1
  193. package/cjs/min/ui-react-inspector/with-schemas/index.cjs.gz +0 -0
  194. package/cjs/min/with-schemas/index.cjs +1 -1
  195. package/cjs/min/with-schemas/index.cjs.gz +0 -0
  196. package/cjs/persisters/index.cjs +80 -98
  197. package/cjs/persisters/persister-cr-sqlite-wasm/index.cjs +79 -97
  198. package/cjs/persisters/persister-cr-sqlite-wasm/with-schemas/index.cjs +79 -97
  199. package/cjs/persisters/persister-electric-sql/index.cjs +79 -97
  200. package/cjs/persisters/persister-electric-sql/with-schemas/index.cjs +79 -97
  201. package/cjs/persisters/persister-expo-sqlite/index.cjs +79 -97
  202. package/cjs/persisters/persister-expo-sqlite/with-schemas/index.cjs +79 -97
  203. package/cjs/persisters/persister-libsql/index.cjs +79 -97
  204. package/cjs/persisters/persister-libsql/with-schemas/index.cjs +79 -97
  205. package/cjs/persisters/persister-pglite/index.cjs +78 -96
  206. package/cjs/persisters/persister-pglite/with-schemas/index.cjs +78 -96
  207. package/cjs/persisters/persister-postgres/index.cjs +78 -96
  208. package/cjs/persisters/persister-postgres/with-schemas/index.cjs +78 -96
  209. package/cjs/persisters/persister-powersync/index.cjs +203 -142
  210. package/cjs/persisters/persister-powersync/with-schemas/index.cjs +203 -142
  211. package/cjs/persisters/persister-sqlite-wasm/index.cjs +79 -97
  212. package/cjs/persisters/persister-sqlite-wasm/with-schemas/index.cjs +79 -97
  213. package/cjs/persisters/persister-sqlite3/index.cjs +79 -97
  214. package/cjs/persisters/persister-sqlite3/with-schemas/index.cjs +79 -97
  215. package/cjs/persisters/with-schemas/index.cjs +80 -98
  216. package/cjs/synchronizers/index.cjs +1 -1
  217. package/cjs/synchronizers/synchronizer-broadcast-channel/index.cjs +1 -1
  218. package/cjs/synchronizers/synchronizer-broadcast-channel/with-schemas/index.cjs +1 -1
  219. package/cjs/synchronizers/synchronizer-local/index.cjs +1 -1
  220. package/cjs/synchronizers/synchronizer-local/with-schemas/index.cjs +1 -1
  221. package/cjs/synchronizers/synchronizer-ws-client/index.cjs +1 -1
  222. package/cjs/synchronizers/synchronizer-ws-client/with-schemas/index.cjs +1 -1
  223. package/cjs/synchronizers/synchronizer-ws-server/index.cjs +1 -1
  224. package/cjs/synchronizers/synchronizer-ws-server/with-schemas/index.cjs +1 -1
  225. package/cjs/synchronizers/with-schemas/index.cjs +1 -1
  226. package/cjs/ui-react-inspector/index.cjs +0 -2
  227. package/cjs/ui-react-inspector/with-schemas/index.cjs +0 -2
  228. package/cjs/with-schemas/index.cjs +1 -1
  229. package/common/index.js +1 -1
  230. package/common/with-schemas/index.js +1 -1
  231. package/es6/common/index.js +1 -1
  232. package/es6/common/with-schemas/index.js +1 -1
  233. package/es6/index.js +1 -1
  234. package/es6/mergeable-store/index.js +1 -1
  235. package/es6/mergeable-store/with-schemas/index.js +1 -1
  236. package/es6/min/common/index.js +1 -1
  237. package/es6/min/common/index.js.gz +0 -0
  238. package/es6/min/common/with-schemas/index.js +1 -1
  239. package/es6/min/common/with-schemas/index.js.gz +0 -0
  240. package/es6/min/index.js +1 -1
  241. package/es6/min/index.js.gz +0 -0
  242. package/es6/min/mergeable-store/index.js +1 -1
  243. package/es6/min/mergeable-store/index.js.gz +0 -0
  244. package/es6/min/mergeable-store/with-schemas/index.js +1 -1
  245. package/es6/min/mergeable-store/with-schemas/index.js.gz +0 -0
  246. package/es6/min/persisters/index.js +1 -1
  247. package/es6/min/persisters/index.js.gz +0 -0
  248. package/es6/min/persisters/persister-cr-sqlite-wasm/index.js +1 -1
  249. package/es6/min/persisters/persister-cr-sqlite-wasm/index.js.gz +0 -0
  250. package/es6/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.js +1 -1
  251. package/es6/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.js.gz +0 -0
  252. package/es6/min/persisters/persister-electric-sql/index.js +1 -1
  253. package/es6/min/persisters/persister-electric-sql/index.js.gz +0 -0
  254. package/es6/min/persisters/persister-electric-sql/with-schemas/index.js +1 -1
  255. package/es6/min/persisters/persister-electric-sql/with-schemas/index.js.gz +0 -0
  256. package/es6/min/persisters/persister-expo-sqlite/index.js +1 -1
  257. package/es6/min/persisters/persister-expo-sqlite/index.js.gz +0 -0
  258. package/es6/min/persisters/persister-expo-sqlite/with-schemas/index.js +1 -1
  259. package/es6/min/persisters/persister-expo-sqlite/with-schemas/index.js.gz +0 -0
  260. package/es6/min/persisters/persister-libsql/index.js +1 -1
  261. package/es6/min/persisters/persister-libsql/index.js.gz +0 -0
  262. package/es6/min/persisters/persister-libsql/with-schemas/index.js +1 -1
  263. package/es6/min/persisters/persister-libsql/with-schemas/index.js.gz +0 -0
  264. package/es6/min/persisters/persister-pglite/index.js +1 -1
  265. package/es6/min/persisters/persister-pglite/index.js.gz +0 -0
  266. package/es6/min/persisters/persister-pglite/with-schemas/index.js +1 -1
  267. package/es6/min/persisters/persister-pglite/with-schemas/index.js.gz +0 -0
  268. package/es6/min/persisters/persister-postgres/index.js +1 -1
  269. package/es6/min/persisters/persister-postgres/index.js.gz +0 -0
  270. package/es6/min/persisters/persister-postgres/with-schemas/index.js +1 -1
  271. package/es6/min/persisters/persister-postgres/with-schemas/index.js.gz +0 -0
  272. package/es6/min/persisters/persister-powersync/index.js +1 -1
  273. package/es6/min/persisters/persister-powersync/index.js.gz +0 -0
  274. package/es6/min/persisters/persister-powersync/with-schemas/index.js +1 -1
  275. package/es6/min/persisters/persister-powersync/with-schemas/index.js.gz +0 -0
  276. package/es6/min/persisters/persister-sqlite-wasm/index.js +1 -1
  277. package/es6/min/persisters/persister-sqlite-wasm/index.js.gz +0 -0
  278. package/es6/min/persisters/persister-sqlite-wasm/with-schemas/index.js +1 -1
  279. package/es6/min/persisters/persister-sqlite-wasm/with-schemas/index.js.gz +0 -0
  280. package/es6/min/persisters/persister-sqlite3/index.js +1 -1
  281. package/es6/min/persisters/persister-sqlite3/index.js.gz +0 -0
  282. package/es6/min/persisters/persister-sqlite3/with-schemas/index.js +1 -1
  283. package/es6/min/persisters/persister-sqlite3/with-schemas/index.js.gz +0 -0
  284. package/es6/min/persisters/with-schemas/index.js +1 -1
  285. package/es6/min/persisters/with-schemas/index.js.gz +0 -0
  286. package/es6/min/synchronizers/index.js +1 -1
  287. package/es6/min/synchronizers/index.js.gz +0 -0
  288. package/es6/min/synchronizers/synchronizer-broadcast-channel/index.js +1 -1
  289. package/es6/min/synchronizers/synchronizer-broadcast-channel/index.js.gz +0 -0
  290. package/es6/min/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js +1 -1
  291. package/es6/min/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js.gz +0 -0
  292. package/es6/min/synchronizers/synchronizer-local/index.js +1 -1
  293. package/es6/min/synchronizers/synchronizer-local/index.js.gz +0 -0
  294. package/es6/min/synchronizers/synchronizer-local/with-schemas/index.js +1 -1
  295. package/es6/min/synchronizers/synchronizer-local/with-schemas/index.js.gz +0 -0
  296. package/es6/min/synchronizers/synchronizer-ws-client/index.js +1 -1
  297. package/es6/min/synchronizers/synchronizer-ws-client/index.js.gz +0 -0
  298. package/es6/min/synchronizers/synchronizer-ws-client/with-schemas/index.js +1 -1
  299. package/es6/min/synchronizers/synchronizer-ws-client/with-schemas/index.js.gz +0 -0
  300. package/es6/min/synchronizers/synchronizer-ws-server/index.js +1 -1
  301. package/es6/min/synchronizers/synchronizer-ws-server/index.js.gz +0 -0
  302. package/es6/min/synchronizers/synchronizer-ws-server/with-schemas/index.js +1 -1
  303. package/es6/min/synchronizers/synchronizer-ws-server/with-schemas/index.js.gz +0 -0
  304. package/es6/min/synchronizers/with-schemas/index.js +1 -1
  305. package/es6/min/synchronizers/with-schemas/index.js.gz +0 -0
  306. package/es6/min/ui-react-inspector/index.js +1 -1
  307. package/es6/min/ui-react-inspector/index.js.gz +0 -0
  308. package/es6/min/ui-react-inspector/with-schemas/index.js +1 -1
  309. package/es6/min/ui-react-inspector/with-schemas/index.js.gz +0 -0
  310. package/es6/min/with-schemas/index.js +1 -1
  311. package/es6/min/with-schemas/index.js.gz +0 -0
  312. package/es6/persisters/index.js +83 -103
  313. package/es6/persisters/persister-cr-sqlite-wasm/index.js +82 -102
  314. package/es6/persisters/persister-cr-sqlite-wasm/with-schemas/index.js +82 -102
  315. package/es6/persisters/persister-electric-sql/index.js +82 -102
  316. package/es6/persisters/persister-electric-sql/with-schemas/index.js +82 -102
  317. package/es6/persisters/persister-expo-sqlite/index.js +82 -102
  318. package/es6/persisters/persister-expo-sqlite/with-schemas/index.js +82 -102
  319. package/es6/persisters/persister-libsql/index.js +82 -102
  320. package/es6/persisters/persister-libsql/with-schemas/index.js +82 -102
  321. package/es6/persisters/persister-pglite/index.js +81 -101
  322. package/es6/persisters/persister-pglite/with-schemas/index.js +81 -101
  323. package/es6/persisters/persister-postgres/index.js +81 -101
  324. package/es6/persisters/persister-postgres/with-schemas/index.js +81 -101
  325. package/es6/persisters/persister-powersync/index.js +212 -147
  326. package/es6/persisters/persister-powersync/with-schemas/index.js +212 -147
  327. package/es6/persisters/persister-sqlite-wasm/index.js +82 -102
  328. package/es6/persisters/persister-sqlite-wasm/with-schemas/index.js +82 -102
  329. package/es6/persisters/persister-sqlite3/index.js +82 -102
  330. package/es6/persisters/persister-sqlite3/with-schemas/index.js +82 -102
  331. package/es6/persisters/with-schemas/index.js +83 -103
  332. package/es6/synchronizers/index.js +1 -1
  333. package/es6/synchronizers/synchronizer-broadcast-channel/index.js +1 -1
  334. package/es6/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js +1 -1
  335. package/es6/synchronizers/synchronizer-local/index.js +1 -1
  336. package/es6/synchronizers/synchronizer-local/with-schemas/index.js +1 -1
  337. package/es6/synchronizers/synchronizer-ws-client/index.js +1 -1
  338. package/es6/synchronizers/synchronizer-ws-client/with-schemas/index.js +1 -1
  339. package/es6/synchronizers/synchronizer-ws-server/index.js +1 -1
  340. package/es6/synchronizers/synchronizer-ws-server/with-schemas/index.js +1 -1
  341. package/es6/synchronizers/with-schemas/index.js +1 -1
  342. package/es6/ui-react-inspector/index.js +0 -2
  343. package/es6/ui-react-inspector/with-schemas/index.js +0 -2
  344. package/es6/with-schemas/index.js +1 -1
  345. package/index.js +1 -1
  346. package/mergeable-store/index.js +1 -1
  347. package/mergeable-store/with-schemas/index.js +1 -1
  348. package/min/common/index.js +1 -1
  349. package/min/common/index.js.gz +0 -0
  350. package/min/common/with-schemas/index.js +1 -1
  351. package/min/common/with-schemas/index.js.gz +0 -0
  352. package/min/index.js +1 -1
  353. package/min/index.js.gz +0 -0
  354. package/min/mergeable-store/index.js +1 -1
  355. package/min/mergeable-store/index.js.gz +0 -0
  356. package/min/mergeable-store/with-schemas/index.js +1 -1
  357. package/min/mergeable-store/with-schemas/index.js.gz +0 -0
  358. package/min/persisters/index.js +1 -1
  359. package/min/persisters/index.js.gz +0 -0
  360. package/min/persisters/persister-cr-sqlite-wasm/index.js +1 -1
  361. package/min/persisters/persister-cr-sqlite-wasm/index.js.gz +0 -0
  362. package/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.js +1 -1
  363. package/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.js.gz +0 -0
  364. package/min/persisters/persister-electric-sql/index.js +1 -1
  365. package/min/persisters/persister-electric-sql/index.js.gz +0 -0
  366. package/min/persisters/persister-electric-sql/with-schemas/index.js +1 -1
  367. package/min/persisters/persister-electric-sql/with-schemas/index.js.gz +0 -0
  368. package/min/persisters/persister-expo-sqlite/index.js +1 -1
  369. package/min/persisters/persister-expo-sqlite/index.js.gz +0 -0
  370. package/min/persisters/persister-expo-sqlite/with-schemas/index.js +1 -1
  371. package/min/persisters/persister-expo-sqlite/with-schemas/index.js.gz +0 -0
  372. package/min/persisters/persister-libsql/index.js +1 -1
  373. package/min/persisters/persister-libsql/index.js.gz +0 -0
  374. package/min/persisters/persister-libsql/with-schemas/index.js +1 -1
  375. package/min/persisters/persister-libsql/with-schemas/index.js.gz +0 -0
  376. package/min/persisters/persister-pglite/index.js +1 -1
  377. package/min/persisters/persister-pglite/index.js.gz +0 -0
  378. package/min/persisters/persister-pglite/with-schemas/index.js +1 -1
  379. package/min/persisters/persister-pglite/with-schemas/index.js.gz +0 -0
  380. package/min/persisters/persister-postgres/index.js +1 -1
  381. package/min/persisters/persister-postgres/index.js.gz +0 -0
  382. package/min/persisters/persister-postgres/with-schemas/index.js +1 -1
  383. package/min/persisters/persister-postgres/with-schemas/index.js.gz +0 -0
  384. package/min/persisters/persister-powersync/index.js +1 -1
  385. package/min/persisters/persister-powersync/index.js.gz +0 -0
  386. package/min/persisters/persister-powersync/with-schemas/index.js +1 -1
  387. package/min/persisters/persister-powersync/with-schemas/index.js.gz +0 -0
  388. package/min/persisters/persister-sqlite-wasm/index.js +1 -1
  389. package/min/persisters/persister-sqlite-wasm/index.js.gz +0 -0
  390. package/min/persisters/persister-sqlite-wasm/with-schemas/index.js +1 -1
  391. package/min/persisters/persister-sqlite-wasm/with-schemas/index.js.gz +0 -0
  392. package/min/persisters/persister-sqlite3/index.js +1 -1
  393. package/min/persisters/persister-sqlite3/index.js.gz +0 -0
  394. package/min/persisters/persister-sqlite3/with-schemas/index.js +1 -1
  395. package/min/persisters/persister-sqlite3/with-schemas/index.js.gz +0 -0
  396. package/min/persisters/with-schemas/index.js +1 -1
  397. package/min/persisters/with-schemas/index.js.gz +0 -0
  398. package/min/synchronizers/index.js +1 -1
  399. package/min/synchronizers/index.js.gz +0 -0
  400. package/min/synchronizers/synchronizer-broadcast-channel/index.js +1 -1
  401. package/min/synchronizers/synchronizer-broadcast-channel/index.js.gz +0 -0
  402. package/min/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js +1 -1
  403. package/min/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js.gz +0 -0
  404. package/min/synchronizers/synchronizer-local/index.js +1 -1
  405. package/min/synchronizers/synchronizer-local/index.js.gz +0 -0
  406. package/min/synchronizers/synchronizer-local/with-schemas/index.js +1 -1
  407. package/min/synchronizers/synchronizer-local/with-schemas/index.js.gz +0 -0
  408. package/min/synchronizers/synchronizer-ws-client/index.js +1 -1
  409. package/min/synchronizers/synchronizer-ws-client/index.js.gz +0 -0
  410. package/min/synchronizers/synchronizer-ws-client/with-schemas/index.js +1 -1
  411. package/min/synchronizers/synchronizer-ws-client/with-schemas/index.js.gz +0 -0
  412. package/min/synchronizers/synchronizer-ws-server/index.js +1 -1
  413. package/min/synchronizers/synchronizer-ws-server/index.js.gz +0 -0
  414. package/min/synchronizers/synchronizer-ws-server/with-schemas/index.js +1 -1
  415. package/min/synchronizers/synchronizer-ws-server/with-schemas/index.js.gz +0 -0
  416. package/min/synchronizers/with-schemas/index.js +1 -1
  417. package/min/synchronizers/with-schemas/index.js.gz +0 -0
  418. package/min/ui-react-inspector/index.js +1 -1
  419. package/min/ui-react-inspector/index.js.gz +0 -0
  420. package/min/ui-react-inspector/with-schemas/index.js +1 -1
  421. package/min/ui-react-inspector/with-schemas/index.js.gz +0 -0
  422. package/min/with-schemas/index.js +1 -1
  423. package/min/with-schemas/index.js.gz +0 -0
  424. package/package.json +5 -5
  425. package/persisters/index.js +80 -98
  426. package/persisters/persister-cr-sqlite-wasm/index.js +79 -97
  427. package/persisters/persister-cr-sqlite-wasm/with-schemas/index.js +79 -97
  428. package/persisters/persister-electric-sql/index.js +79 -97
  429. package/persisters/persister-electric-sql/with-schemas/index.js +79 -97
  430. package/persisters/persister-expo-sqlite/index.js +79 -97
  431. package/persisters/persister-expo-sqlite/with-schemas/index.js +79 -97
  432. package/persisters/persister-libsql/index.js +79 -97
  433. package/persisters/persister-libsql/with-schemas/index.js +79 -97
  434. package/persisters/persister-pglite/index.js +78 -96
  435. package/persisters/persister-pglite/with-schemas/index.js +78 -96
  436. package/persisters/persister-postgres/index.js +78 -96
  437. package/persisters/persister-postgres/with-schemas/index.js +78 -96
  438. package/persisters/persister-powersync/index.js +203 -142
  439. package/persisters/persister-powersync/with-schemas/index.js +203 -142
  440. package/persisters/persister-sqlite-wasm/index.js +79 -97
  441. package/persisters/persister-sqlite-wasm/with-schemas/index.js +79 -97
  442. package/persisters/persister-sqlite3/index.js +79 -97
  443. package/persisters/persister-sqlite3/with-schemas/index.js +79 -97
  444. package/persisters/with-schemas/index.js +80 -98
  445. package/readme.md +2 -2
  446. package/synchronizers/index.js +1 -1
  447. package/synchronizers/synchronizer-broadcast-channel/index.js +1 -1
  448. package/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js +1 -1
  449. package/synchronizers/synchronizer-local/index.js +1 -1
  450. package/synchronizers/synchronizer-local/with-schemas/index.js +1 -1
  451. package/synchronizers/synchronizer-ws-client/index.js +1 -1
  452. package/synchronizers/synchronizer-ws-client/with-schemas/index.js +1 -1
  453. package/synchronizers/synchronizer-ws-server/index.js +1 -1
  454. package/synchronizers/synchronizer-ws-server/with-schemas/index.js +1 -1
  455. package/synchronizers/with-schemas/index.js +1 -1
  456. package/ui-react-inspector/index.js +0 -2
  457. package/ui-react-inspector/with-schemas/index.js +0 -2
  458. package/umd/common/index.js +1 -1
  459. package/umd/common/with-schemas/index.js +1 -1
  460. package/umd/es6/common/index.js +1 -1
  461. package/umd/es6/common/with-schemas/index.js +1 -1
  462. package/umd/es6/index.js +1 -1
  463. package/umd/es6/mergeable-store/index.js +1 -1
  464. package/umd/es6/mergeable-store/with-schemas/index.js +1 -1
  465. package/umd/es6/min/common/index.js +1 -1
  466. package/umd/es6/min/common/index.js.gz +0 -0
  467. package/umd/es6/min/common/with-schemas/index.js +1 -1
  468. package/umd/es6/min/common/with-schemas/index.js.gz +0 -0
  469. package/umd/es6/min/index.js +1 -1
  470. package/umd/es6/min/index.js.gz +0 -0
  471. package/umd/es6/min/mergeable-store/index.js +1 -1
  472. package/umd/es6/min/mergeable-store/index.js.gz +0 -0
  473. package/umd/es6/min/mergeable-store/with-schemas/index.js +1 -1
  474. package/umd/es6/min/mergeable-store/with-schemas/index.js.gz +0 -0
  475. package/umd/es6/min/persisters/index.js +1 -1
  476. package/umd/es6/min/persisters/index.js.gz +0 -0
  477. package/umd/es6/min/persisters/persister-cr-sqlite-wasm/index.js +1 -1
  478. package/umd/es6/min/persisters/persister-cr-sqlite-wasm/index.js.gz +0 -0
  479. package/umd/es6/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.js +1 -1
  480. package/umd/es6/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.js.gz +0 -0
  481. package/umd/es6/min/persisters/persister-electric-sql/index.js +1 -1
  482. package/umd/es6/min/persisters/persister-electric-sql/index.js.gz +0 -0
  483. package/umd/es6/min/persisters/persister-electric-sql/with-schemas/index.js +1 -1
  484. package/umd/es6/min/persisters/persister-electric-sql/with-schemas/index.js.gz +0 -0
  485. package/umd/es6/min/persisters/persister-expo-sqlite/index.js +1 -1
  486. package/umd/es6/min/persisters/persister-expo-sqlite/index.js.gz +0 -0
  487. package/umd/es6/min/persisters/persister-expo-sqlite/with-schemas/index.js +1 -1
  488. package/umd/es6/min/persisters/persister-expo-sqlite/with-schemas/index.js.gz +0 -0
  489. package/umd/es6/min/persisters/persister-libsql/index.js +1 -1
  490. package/umd/es6/min/persisters/persister-libsql/index.js.gz +0 -0
  491. package/umd/es6/min/persisters/persister-libsql/with-schemas/index.js +1 -1
  492. package/umd/es6/min/persisters/persister-libsql/with-schemas/index.js.gz +0 -0
  493. package/umd/es6/min/persisters/persister-pglite/index.js +1 -1
  494. package/umd/es6/min/persisters/persister-pglite/index.js.gz +0 -0
  495. package/umd/es6/min/persisters/persister-pglite/with-schemas/index.js +1 -1
  496. package/umd/es6/min/persisters/persister-pglite/with-schemas/index.js.gz +0 -0
  497. package/umd/es6/min/persisters/persister-postgres/index.js +1 -1
  498. package/umd/es6/min/persisters/persister-postgres/index.js.gz +0 -0
  499. package/umd/es6/min/persisters/persister-postgres/with-schemas/index.js +1 -1
  500. package/umd/es6/min/persisters/persister-postgres/with-schemas/index.js.gz +0 -0
  501. package/umd/es6/min/persisters/persister-powersync/index.js +1 -1
  502. package/umd/es6/min/persisters/persister-powersync/index.js.gz +0 -0
  503. package/umd/es6/min/persisters/persister-powersync/with-schemas/index.js +1 -1
  504. package/umd/es6/min/persisters/persister-powersync/with-schemas/index.js.gz +0 -0
  505. package/umd/es6/min/persisters/persister-sqlite-wasm/index.js +1 -1
  506. package/umd/es6/min/persisters/persister-sqlite-wasm/index.js.gz +0 -0
  507. package/umd/es6/min/persisters/persister-sqlite-wasm/with-schemas/index.js +1 -1
  508. package/umd/es6/min/persisters/persister-sqlite-wasm/with-schemas/index.js.gz +0 -0
  509. package/umd/es6/min/persisters/persister-sqlite3/index.js +1 -1
  510. package/umd/es6/min/persisters/persister-sqlite3/index.js.gz +0 -0
  511. package/umd/es6/min/persisters/persister-sqlite3/with-schemas/index.js +1 -1
  512. package/umd/es6/min/persisters/persister-sqlite3/with-schemas/index.js.gz +0 -0
  513. package/umd/es6/min/persisters/with-schemas/index.js +1 -1
  514. package/umd/es6/min/persisters/with-schemas/index.js.gz +0 -0
  515. package/umd/es6/min/synchronizers/index.js +1 -1
  516. package/umd/es6/min/synchronizers/index.js.gz +0 -0
  517. package/umd/es6/min/synchronizers/synchronizer-broadcast-channel/index.js +1 -1
  518. package/umd/es6/min/synchronizers/synchronizer-broadcast-channel/index.js.gz +0 -0
  519. package/umd/es6/min/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js +1 -1
  520. package/umd/es6/min/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js.gz +0 -0
  521. package/umd/es6/min/synchronizers/synchronizer-local/index.js +1 -1
  522. package/umd/es6/min/synchronizers/synchronizer-local/index.js.gz +0 -0
  523. package/umd/es6/min/synchronizers/synchronizer-local/with-schemas/index.js +1 -1
  524. package/umd/es6/min/synchronizers/synchronizer-local/with-schemas/index.js.gz +0 -0
  525. package/umd/es6/min/synchronizers/synchronizer-ws-client/index.js +1 -1
  526. package/umd/es6/min/synchronizers/synchronizer-ws-client/index.js.gz +0 -0
  527. package/umd/es6/min/synchronizers/synchronizer-ws-client/with-schemas/index.js +1 -1
  528. package/umd/es6/min/synchronizers/synchronizer-ws-client/with-schemas/index.js.gz +0 -0
  529. package/umd/es6/min/synchronizers/synchronizer-ws-server/index.js +1 -1
  530. package/umd/es6/min/synchronizers/synchronizer-ws-server/index.js.gz +0 -0
  531. package/umd/es6/min/synchronizers/synchronizer-ws-server/with-schemas/index.js +1 -1
  532. package/umd/es6/min/synchronizers/synchronizer-ws-server/with-schemas/index.js.gz +0 -0
  533. package/umd/es6/min/synchronizers/with-schemas/index.js +1 -1
  534. package/umd/es6/min/synchronizers/with-schemas/index.js.gz +0 -0
  535. package/umd/es6/min/ui-react-inspector/index.js +1 -1
  536. package/umd/es6/min/ui-react-inspector/index.js.gz +0 -0
  537. package/umd/es6/min/ui-react-inspector/with-schemas/index.js +1 -1
  538. package/umd/es6/min/ui-react-inspector/with-schemas/index.js.gz +0 -0
  539. package/umd/es6/min/with-schemas/index.js +1 -1
  540. package/umd/es6/min/with-schemas/index.js.gz +0 -0
  541. package/umd/es6/persisters/index.js +83 -103
  542. package/umd/es6/persisters/persister-cr-sqlite-wasm/index.js +82 -102
  543. package/umd/es6/persisters/persister-cr-sqlite-wasm/with-schemas/index.js +82 -102
  544. package/umd/es6/persisters/persister-electric-sql/index.js +82 -102
  545. package/umd/es6/persisters/persister-electric-sql/with-schemas/index.js +82 -102
  546. package/umd/es6/persisters/persister-expo-sqlite/index.js +82 -102
  547. package/umd/es6/persisters/persister-expo-sqlite/with-schemas/index.js +82 -102
  548. package/umd/es6/persisters/persister-libsql/index.js +82 -102
  549. package/umd/es6/persisters/persister-libsql/with-schemas/index.js +82 -102
  550. package/umd/es6/persisters/persister-pglite/index.js +81 -101
  551. package/umd/es6/persisters/persister-pglite/with-schemas/index.js +81 -101
  552. package/umd/es6/persisters/persister-postgres/index.js +81 -101
  553. package/umd/es6/persisters/persister-postgres/with-schemas/index.js +81 -101
  554. package/umd/es6/persisters/persister-powersync/index.js +212 -147
  555. package/umd/es6/persisters/persister-powersync/with-schemas/index.js +212 -147
  556. package/umd/es6/persisters/persister-sqlite-wasm/index.js +82 -102
  557. package/umd/es6/persisters/persister-sqlite-wasm/with-schemas/index.js +82 -102
  558. package/umd/es6/persisters/persister-sqlite3/index.js +82 -102
  559. package/umd/es6/persisters/persister-sqlite3/with-schemas/index.js +82 -102
  560. package/umd/es6/persisters/with-schemas/index.js +83 -103
  561. package/umd/es6/synchronizers/index.js +1 -1
  562. package/umd/es6/synchronizers/synchronizer-broadcast-channel/index.js +1 -1
  563. package/umd/es6/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js +1 -1
  564. package/umd/es6/synchronizers/synchronizer-local/index.js +1 -1
  565. package/umd/es6/synchronizers/synchronizer-local/with-schemas/index.js +1 -1
  566. package/umd/es6/synchronizers/synchronizer-ws-client/index.js +1 -1
  567. package/umd/es6/synchronizers/synchronizer-ws-client/with-schemas/index.js +1 -1
  568. package/umd/es6/synchronizers/synchronizer-ws-server/index.js +1 -1
  569. package/umd/es6/synchronizers/synchronizer-ws-server/with-schemas/index.js +1 -1
  570. package/umd/es6/synchronizers/with-schemas/index.js +1 -1
  571. package/umd/es6/ui-react-inspector/index.js +0 -2
  572. package/umd/es6/ui-react-inspector/with-schemas/index.js +0 -2
  573. package/umd/es6/with-schemas/index.js +1 -1
  574. package/umd/index.js +1 -1
  575. package/umd/mergeable-store/index.js +1 -1
  576. package/umd/mergeable-store/with-schemas/index.js +1 -1
  577. package/umd/min/common/index.js +1 -1
  578. package/umd/min/common/index.js.gz +0 -0
  579. package/umd/min/common/with-schemas/index.js +1 -1
  580. package/umd/min/common/with-schemas/index.js.gz +0 -0
  581. package/umd/min/index.js +1 -1
  582. package/umd/min/index.js.gz +0 -0
  583. package/umd/min/mergeable-store/index.js +1 -1
  584. package/umd/min/mergeable-store/index.js.gz +0 -0
  585. package/umd/min/mergeable-store/with-schemas/index.js +1 -1
  586. package/umd/min/mergeable-store/with-schemas/index.js.gz +0 -0
  587. package/umd/min/persisters/index.js +1 -1
  588. package/umd/min/persisters/index.js.gz +0 -0
  589. package/umd/min/persisters/persister-cr-sqlite-wasm/index.js +1 -1
  590. package/umd/min/persisters/persister-cr-sqlite-wasm/index.js.gz +0 -0
  591. package/umd/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.js +1 -1
  592. package/umd/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.js.gz +0 -0
  593. package/umd/min/persisters/persister-electric-sql/index.js +1 -1
  594. package/umd/min/persisters/persister-electric-sql/index.js.gz +0 -0
  595. package/umd/min/persisters/persister-electric-sql/with-schemas/index.js +1 -1
  596. package/umd/min/persisters/persister-electric-sql/with-schemas/index.js.gz +0 -0
  597. package/umd/min/persisters/persister-expo-sqlite/index.js +1 -1
  598. package/umd/min/persisters/persister-expo-sqlite/index.js.gz +0 -0
  599. package/umd/min/persisters/persister-expo-sqlite/with-schemas/index.js +1 -1
  600. package/umd/min/persisters/persister-expo-sqlite/with-schemas/index.js.gz +0 -0
  601. package/umd/min/persisters/persister-libsql/index.js +1 -1
  602. package/umd/min/persisters/persister-libsql/index.js.gz +0 -0
  603. package/umd/min/persisters/persister-libsql/with-schemas/index.js +1 -1
  604. package/umd/min/persisters/persister-libsql/with-schemas/index.js.gz +0 -0
  605. package/umd/min/persisters/persister-pglite/index.js +1 -1
  606. package/umd/min/persisters/persister-pglite/index.js.gz +0 -0
  607. package/umd/min/persisters/persister-pglite/with-schemas/index.js +1 -1
  608. package/umd/min/persisters/persister-pglite/with-schemas/index.js.gz +0 -0
  609. package/umd/min/persisters/persister-postgres/index.js +1 -1
  610. package/umd/min/persisters/persister-postgres/index.js.gz +0 -0
  611. package/umd/min/persisters/persister-postgres/with-schemas/index.js +1 -1
  612. package/umd/min/persisters/persister-postgres/with-schemas/index.js.gz +0 -0
  613. package/umd/min/persisters/persister-powersync/index.js +1 -1
  614. package/umd/min/persisters/persister-powersync/index.js.gz +0 -0
  615. package/umd/min/persisters/persister-powersync/with-schemas/index.js +1 -1
  616. package/umd/min/persisters/persister-powersync/with-schemas/index.js.gz +0 -0
  617. package/umd/min/persisters/persister-sqlite-wasm/index.js +1 -1
  618. package/umd/min/persisters/persister-sqlite-wasm/index.js.gz +0 -0
  619. package/umd/min/persisters/persister-sqlite-wasm/with-schemas/index.js +1 -1
  620. package/umd/min/persisters/persister-sqlite-wasm/with-schemas/index.js.gz +0 -0
  621. package/umd/min/persisters/persister-sqlite3/index.js +1 -1
  622. package/umd/min/persisters/persister-sqlite3/index.js.gz +0 -0
  623. package/umd/min/persisters/persister-sqlite3/with-schemas/index.js +1 -1
  624. package/umd/min/persisters/persister-sqlite3/with-schemas/index.js.gz +0 -0
  625. package/umd/min/persisters/with-schemas/index.js +1 -1
  626. package/umd/min/persisters/with-schemas/index.js.gz +0 -0
  627. package/umd/min/synchronizers/index.js +1 -1
  628. package/umd/min/synchronizers/index.js.gz +0 -0
  629. package/umd/min/synchronizers/synchronizer-broadcast-channel/index.js +1 -1
  630. package/umd/min/synchronizers/synchronizer-broadcast-channel/index.js.gz +0 -0
  631. package/umd/min/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js +1 -1
  632. package/umd/min/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js.gz +0 -0
  633. package/umd/min/synchronizers/synchronizer-local/index.js +1 -1
  634. package/umd/min/synchronizers/synchronizer-local/index.js.gz +0 -0
  635. package/umd/min/synchronizers/synchronizer-local/with-schemas/index.js +1 -1
  636. package/umd/min/synchronizers/synchronizer-local/with-schemas/index.js.gz +0 -0
  637. package/umd/min/synchronizers/synchronizer-ws-client/index.js +1 -1
  638. package/umd/min/synchronizers/synchronizer-ws-client/index.js.gz +0 -0
  639. package/umd/min/synchronizers/synchronizer-ws-client/with-schemas/index.js +1 -1
  640. package/umd/min/synchronizers/synchronizer-ws-client/with-schemas/index.js.gz +0 -0
  641. package/umd/min/synchronizers/synchronizer-ws-server/index.js +1 -1
  642. package/umd/min/synchronizers/synchronizer-ws-server/index.js.gz +0 -0
  643. package/umd/min/synchronizers/synchronizer-ws-server/with-schemas/index.js +1 -1
  644. package/umd/min/synchronizers/synchronizer-ws-server/with-schemas/index.js.gz +0 -0
  645. package/umd/min/synchronizers/with-schemas/index.js +1 -1
  646. package/umd/min/synchronizers/with-schemas/index.js.gz +0 -0
  647. package/umd/min/ui-react-inspector/index.js +1 -1
  648. package/umd/min/ui-react-inspector/index.js.gz +0 -0
  649. package/umd/min/ui-react-inspector/with-schemas/index.js +1 -1
  650. package/umd/min/ui-react-inspector/with-schemas/index.js.gz +0 -0
  651. package/umd/min/with-schemas/index.js +1 -1
  652. package/umd/min/with-schemas/index.js.gz +0 -0
  653. package/umd/persisters/index.js +80 -98
  654. package/umd/persisters/persister-cr-sqlite-wasm/index.js +79 -97
  655. package/umd/persisters/persister-cr-sqlite-wasm/with-schemas/index.js +79 -97
  656. package/umd/persisters/persister-electric-sql/index.js +79 -97
  657. package/umd/persisters/persister-electric-sql/with-schemas/index.js +79 -97
  658. package/umd/persisters/persister-expo-sqlite/index.js +79 -97
  659. package/umd/persisters/persister-expo-sqlite/with-schemas/index.js +79 -97
  660. package/umd/persisters/persister-libsql/index.js +79 -97
  661. package/umd/persisters/persister-libsql/with-schemas/index.js +79 -97
  662. package/umd/persisters/persister-pglite/index.js +78 -96
  663. package/umd/persisters/persister-pglite/with-schemas/index.js +78 -96
  664. package/umd/persisters/persister-postgres/index.js +78 -96
  665. package/umd/persisters/persister-postgres/with-schemas/index.js +78 -96
  666. package/umd/persisters/persister-powersync/index.js +203 -142
  667. package/umd/persisters/persister-powersync/with-schemas/index.js +203 -142
  668. package/umd/persisters/persister-sqlite-wasm/index.js +79 -97
  669. package/umd/persisters/persister-sqlite-wasm/with-schemas/index.js +79 -97
  670. package/umd/persisters/persister-sqlite3/index.js +79 -97
  671. package/umd/persisters/persister-sqlite3/with-schemas/index.js +79 -97
  672. package/umd/persisters/with-schemas/index.js +80 -98
  673. package/umd/synchronizers/index.js +1 -1
  674. package/umd/synchronizers/synchronizer-broadcast-channel/index.js +1 -1
  675. package/umd/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js +1 -1
  676. package/umd/synchronizers/synchronizer-local/index.js +1 -1
  677. package/umd/synchronizers/synchronizer-local/with-schemas/index.js +1 -1
  678. package/umd/synchronizers/synchronizer-ws-client/index.js +1 -1
  679. package/umd/synchronizers/synchronizer-ws-client/with-schemas/index.js +1 -1
  680. package/umd/synchronizers/synchronizer-ws-server/index.js +1 -1
  681. package/umd/synchronizers/synchronizer-ws-server/with-schemas/index.js +1 -1
  682. package/umd/synchronizers/with-schemas/index.js +1 -1
  683. package/umd/ui-react-inspector/index.js +0 -2
  684. package/umd/ui-react-inspector/with-schemas/index.js +0 -2
  685. package/umd/with-schemas/index.js +1 -1
  686. package/with-schemas/index.js +1 -1
@@ -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),d=(t,a,e)=>t.slice(a,e),w=t=>t.length,p=async t=>r.all(t),v=t=>{throw Error(t)},E=(t,a)=>h(Array(t).fill(0),((t,e)=>a(e))),f=(t,a)=>t.forEach(a),g=(t,a="")=>t.join(a),h=(t,a)=>t.map(a),A=t=>0==w(t),m=(t,a)=>t.filter(a),b=(t,...a)=>t.push(...a),T=t=>t.shift(),C="_",N="_id",S="SELECT",$="WHERE",O="TABLE",L="ALTER "+O,I="DELETE FROM",R=S+"*FROM",D="pragma_",M="data_version",P="schema_version",_="pragma_table_",F=t=>`"${t.replace(/"/g,'""')}"`,j=t=>g(h(t,((t,a)=>"$"+(a+1))),s),x=(t,a)=>t?.has(a)??!1,B=t=>c(t)||0==(t=>t?.size??0)(t),U=t=>[...t?.values()??[]],q=(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=>w(G(t)),tt=t=>(t=>!c(t)&&l(k(t),(t=>t==Y.prototype||c(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))),rt=(t,a,e)=>c(e)?(J(t,a),t):t?.set(a,e),ot=(t,a,e,n)=>(x(t,a)?n?.(st(t,a)):rt(t,a,e()),st(t,a)),ct=(t,a,e,n,s=0)=>l((e?ot:st)(t,a[s],s>w(a)-2?e:nt),(i=>{if(s>w(a)-2)return n?.(i)&&rt(t,a[s]),i;const r=ct(i,a,e,n,s+1);return B(i)&&rt(t,a[s]),r})),lt=t=>new Set(y(t)||c(t)?t:[t]),ut=(t,a)=>t?.add(a),yt=/^\d+$/,dt=nt(),wt=nt(),pt=(t,a,e,s,i,r,o,u={},d=[])=>{let p,E,g,h=0,A=0,m=0;ot(dt,d,(()=>0)),ot(wt,d,(()=>[]));const C=nt(),[N,S,$,O,L]=((t=1,a)=>1!=t&&a.isMergeable()?[1,a.getMergeableContent,a.getTransactionMergeableChanges,([[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"))(o,t),[I,R,D]=(()=>{let t;const[a,e]=(()=>{const t=[];let a=0;return[e=>(e?T(t):null)??n+a++,a=>{yt.test(a)&&w(t)<1e3&&b(t,a)}]})(),s=nt();return[(e,i,r,o=[],c=()=>[])=>{t??=Y;const l=a(1);return rt(s,l,[e,i,r,o,c]),ut(ct(i,r??[n],lt),l),l},(a,e,...i)=>f(((t,a=[n])=>{const e=[],s=(t,n)=>n==w(a)?b(e,t):null===a[n]?q(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=>q(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),B(a)?1:0))),rt(s,t),e(t),i))),a=>l(st(s,a),(([a,,e=[],n,s])=>{const i=(...r)=>{const o=w(r);o==w(e)?a(t,...r,...s(r)):c(e[o])?f(n[o]?.(...r)??[],(t=>i(...r,t))):i(...r,e[o])};i()}))]})(),M=t=>{t!=h&&(h=t,R(C,void 0,h))},P=a=>{(N&&y(a?.[0])?1===a?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===a?.[2]?t.applyChanges:t.setContent)(a)},_=async t=>(2!=h&&(M(1),A++,await U((async()=>{try{const t=await a();y(t)?P(t):v("Content is not an array "+t)}catch(a){r?.(a),t&&L(t)}M(0)}))),Y),F=()=>(E&&(i(E),E=void 0),Y),j=async t=>(1!=h&&(M(2),m++,await U((async()=>{try{await e(S,t)}catch(t){r?.(t)}M(0)}))),Y),x=()=>(l(g,t.delListener),g=void 0,Y),U=async(...t)=>(b(st(wt,d),...t),await(async()=>{if(!st(dt,d)){for(rt(dt,d,1);!c(p=T(st(wt,d)));)try{await p()}catch(t){r?.(t)}rt(dt,d,0)}})(),Y),Y={load:_,startAutoLoad:async t=>{await F().load(t);try{E=await s((async(t,a)=>{a||t?2!=h&&(M(1),A++,P(a??t),M(0)):await _()}))}catch(t){r?.(t)}return Y},stopAutoLoad:F,isAutoLoading:()=>!c(E),save:j,startAutoSave:async()=>(await x().save(),g=t.addDidFinishTransactionListener((()=>{const t=$();O(t)&&j(t)})),Y),stopAutoSave:x,isAutoSaving:()=>!c(g),getStatus:()=>h,addStatusListener:t=>I(t,C),delListener:a=>(D(a),t),schedule:U,getStore:()=>t,destroy:()=>(st(wt,d).splice(0,void 0),F().stopAutoSave()),getStats:()=>({loads:A,saves:m}),...u};return H(Y)},vt=(t,a,e,n,i,r,o,l)=>{const u=nt();return[async()=>{u.clear(),h(await e(t,a),(({tn:t,cn:a})=>ut(ot(u,t,lt),a)))},async(a,e)=>((t,a)=>x(st(u,t),a))(a,e)?K(m(h(await t(R+F(a)),(t=>{return[t[e],l?(a=V(t,e),n=l,K(W(a,((t,a)=>[a,n(t,a)])))):V(t,e)];var a,n})),(([t,a])=>!c(t)&&!tt(a)))):{},async(a,e,n,l,y,d=!1)=>{const w=lt();W(n??{},(t=>h(G(t??{}),(t=>ut(w,t)))));const v=U(w);if(!d&&y&&A(v)&&x(u,a))return await t("DROP "+O+F(a)),void rt(u,a);const E=st(u,a),f=lt(U(E));if(A(v)||(x(u,a)?await p(h([e,...v],(async(n,s)=>{J(f,n)||(await t(L+F(a)+"ADD"+F(n)+i),0==s&&await t("CREATE UNIQUE INDEX pk ON "+F(a)+`(${F(e)})`),ut(E,n))}))):(await t("CREATE "+O+F(a)+`(${F(e)}${i} PRIMARY KEY${g(h(v,(t=>s+F(t)+i)))});`),rt(u,a,lt([e,...v])))),await p([...!d&&l?h(U(f),(async n=>{n!=e&&(await t(L+F(a)+"DROP"+F(n)),J(E,n))})):[]]),d)c(n)?await t(I+F(a)+$+" true"):await p(W(n,(async(n,s)=>{c(n)?await t(I+F(a)+$+F(e)+"=$1",[s]):A(v)||await Et(t,a,e,G(n),[s,...o?h(X(n),o):X(n)],r)})));else if(A(v))x(u,a)&&await t(I+F(a)+$+" true");else{const s=m(U(st(u,a)),(t=>t!=e)),i=[],c=[];W(n??{},((t,a)=>{b(i,a,...h(s,(a=>o?o(t?.[a]):t?.[a]))),b(c,a)})),await Et(t,a,e,s,i,r),await t(I+F(a)+$+F(e)+`NOT IN(${j(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,i,r,o=0)=>await t("INSERT "+(o?"OR REPLACE ":n)+"INTO"+F(a)+"("+F(e)+g(h(i,(t=>s+F(t))))+")VALUES"+ft(r,w(i)+1)+(o?n:"ON CONFLICT("+F(e)+")DO UPDATE SET"+g(h(i,(t=>F(t)+"=excluded."+F(t))),s)),h(r,(t=>t??null))),ft=(t,a)=>g(E(w(t)/a,(t=>"("+g(E(a,(e=>"$"+(t*a+e+1))),s)+")")),s),gt=(t,a,e,n,s,i,r,[o,c,l],u,y,d,w,p,v)=>{const[E,f,g,h]=vt(a,u,y,s,p,v),A=pt(t,(async()=>await h((async()=>{return await E(),t=(await f(o,c))[C]?.[l]??"null",et(t,((t,a)=>""===a?void 0:a));var t}))),(async t=>await h((async()=>{var a;await E(),await g(o,c,{[C]:{[l]:(a=t()??null,at(a,((t,a)=>void 0===a?"":a)))}},!0,!0)}))),e,n,s,r,{[w]:()=>d,destroy:()=>(A.stopAutoLoad().stopAutoSave(),i(),A)},d);return A},ht=(t,a,e,n,s,i,r,[o,l,[u,y,d]],w,v,E,f,g,h,A,b)=>{const[T,S,$,O]=vt(a,w,v,s,g,h,A,b),L=async(t,a)=>await p(it(l,(async([e,n,s,i],r)=>{a&&!(r in t)||await $(e,n,t[r],s,i,a)}))),I=async(t,a)=>y?await $(d,N,{[C]:t},!0,!0,a):null,R=pt(t,(async()=>await O((async()=>{await T();const t=await(async()=>K(m(await p(it(o,(async([t,a],e)=>[t,await S(e,a)]))),(t=>!tt(t[1])))))(),a=await(async()=>u?(await S(d,N))[C]:{})();return tt(t)&&c(a)?void 0:[t,a]}))),(async(t,a)=>await O((async()=>{if(await T(),c(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,r,{[f]:()=>E,destroy:()=>(R.stopAutoLoad().stopAutoSave(),i(),R)},E);return R},At="ColumnName",mt="store",bt="json",Tt=mt+"TableName",Ct=mt+"Id"+At,Nt=mt+At,St="autoLoadIntervalSeconds",$t="rowId"+At,Ot="tableId",Lt="tableName",It="deleteEmptyColumns",Rt="deleteEmptyTable",Dt={mode:bt,[St]:1},Mt={load:0,save:0,[Lt]:e+"_values"},Pt=(t,a,e,n,s)=>{const i=nt();return W(t,((t,r)=>{const o=d(X(Q(a,u(t)?{[e]:t}:t)),0,Z(a));c(o[0])||n(r,o[0])||(s(r,o[0]),rt(i,r,o))})),i},_t=(t,a,s,i,r,c,l,y,w,p,v="getDb",E)=>{let f,g,h;const A=((t,a)=>a?async(e,n)=>(a(e,n),await t(e,n)):t)(s,c),[m,b,T,C]=(t=>{const a=(t=>Q(Dt,u(t)?{[Tt]:t}:t??{}))(t),n=a[St];if(a.mode==bt){const t=a[Tt]??e;return[1,n,[t,a[Ct]??N,a[Nt]??mt],lt(t)]}const{tables:{load:s={},save:i={}}={},values:r={}}=a,o=d(X(Q(Mt,r)),0,Z(Mt)),c=o[2],l=lt(c),y=lt(c);return[0,n,[Pt(s,{[Ot]:null,[$t]:N},Ot,(t=>x(y,t)),(t=>ut(l,t))),Pt(i,{[Lt]:null,[$t]:N,[It]:0,[Rt]:0},Lt,((t,a)=>x(y,a)),((t,a)=>ut(l,a))),o],l]})(a);return(m?gt:ht)(t,A,(t=>{let a;const e=()=>a=setInterval((async()=>{try{const[{d:a,s:e,c:n}]=await A(`${S} ${M} d,${P} s,TOTAL_CHANGES() c FROM ${D}${M} JOIN ${D}${P}`);a==f&&e==g&&n==h||(null!=f&&t(),f=a,g=e,h=n)}catch{}}),1e3*b),n=()=>{f=g=h=null,o(a)},s=i((a=>{C.has(a)&&(n(),t(),e())}));return e(),()=>{n(),r(s)}}),(t=>t()),l,y,w,T,U(C),(async(t,a)=>await t(`${S} t.name tn,c.name cn FROM ${_}list()t,${_}info(t.name)c ${$} t.schema='main'AND t.type IN('table','view')AND t.name IN(${j(a)})ORDER BY t.name,c.name`,a)),p,v,n,E,(t=>!0===t?1:!1===t?0:t),void 0)};t.createElectricSqlPersister=(t,a,e,n,s)=>_t(t,e,(async(t,e=[])=>await a.db.raw({sql:t,args:e})),(t=>a.notifier.subscribeToDataChanges((e=>f(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),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),d=(t,a,e)=>t.slice(a,e),w=t=>t.length,p=async t=>r.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),h=t=>0==w(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=>w(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>w(a)-2?e:et),(i=>{if(s>w(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(),dt=et(),wt=(t,a,e,s,i,r,o,u={},d=[])=>{let p,E,g,h=0,m=0,T=0;rt(yt,d,(()=>0)),rt(dt,d,(()=>[]));const N=et(),[S,$,C,O,I]=((t=1,a)=>1!=t&&a.isMergeable()?[1,a.getMergeableContent,a.getTransactionMergeableChanges,([[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"))(o,t),[L,D,R]=(()=>{let t;const[a,e]=(()=>{const t=[];let a=0;return[e=>(e?b(t):null)??n+a++,a=>{ut.test(a)&&w(t)<1e3&&A(t,a)}]})(),s=et();return[(e,i,r,o=[],c=()=>[])=>{t??=Y;const l=a(1);return it(s,l,[e,i,r,o,c]),lt(ot(i,r??[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]?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])=>(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=w(r);o==w(e)?a(t,...r,...s(r)):c(e[o])?f(n[o]?.(...r)??[],(t=>i(...r,t))):i(...r,e[o])};i()}))]})(),M=t=>{t!=h&&(h=t,D(N,void 0,h))},P=a=>{(S&&y(a?.[0])?1===a?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===a?.[2]?t.applyChanges:t.setContent)(a)},_=async t=>(2!=h&&(M(1),m++,await J((async()=>{try{const t=await a();y(t)?P(t):v("Content is not an array "+t)}catch(a){r?.(a),t&&I(t)}M(0)}))),Y),F=()=>(E&&(i(E),E=void 0),Y),j=async t=>(1!=h&&(M(2),T++,await J((async()=>{try{await e($,t)}catch(t){r?.(t)}M(0)}))),Y),B=()=>(l(g,t.delListener),g=void 0,Y),J=async(...t)=>(A(nt(dt,d),...t),await(async()=>{if(!nt(yt,d)){for(it(yt,d,1);!c(p=b(nt(dt,d)));)try{await p()}catch(t){r?.(t)}it(yt,d,0)}})(),Y),Y={load:_,startAutoLoad:async t=>{await F().load(t);try{E=await s((async(t,a)=>{a||t?2!=h&&(M(1),m++,P(a??t),M(0)):await _()}))}catch(t){r?.(t)}return Y},stopAutoLoad:F,isAutoLoading:()=>!c(E),save:j,startAutoSave:async()=>(await B().save(),g=t.addDidFinishTransactionListener((()=>{const t=C();O(t)&&j(t)})),Y),stopAutoSave:B,isAutoSaving:()=>!c(g),getStatus:()=>h,addStatusListener:t=>L(t,N),delListener:a=>(R(a),t),schedule:J,getStore:()=>t,destroy:()=>(nt(dt,d).splice(0,void 0),F().stopAutoSave()),getStats:()=>({loads:m,saves:T}),...u};return G(Y)},pt=(t,a,e,n,i,r=vt,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,d=!1)=>{const w=ct();V(n??{},(t=>g(z(t??{}),(t=>lt(w,t)))));const v=B(w);if(!d&&y&&h(v)&&j(u,a))return await t("DROP "+C+_(a)),void it(u,a);const f=nt(u,a),b=ct(B(f));if(h(v)||(j(u,a)?await p(g([e,...v],(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(f,n))}))):(await t("CREATE "+C+_(a)+`(${_(e)}${i} PRIMARY KEY${E(g(v,(t=>s+_(t)+i)))});`),it(u,a,ct([e,...v])))),await p([...!d&&l?g(B(b),(async n=>{n!=e&&(await t(O+_(a)+"DROP"+_(n)),q(f,n))})):[]]),d)c(n)?await t(I+_(a)+$+" true"):await p(V(n,(async(n,s)=>{c(n)?await t(I+_(a)+$+_(e)+"=$1",[s]):h(v)||await r(t,a,e,z(n),{[s]:o?g(W(n),o):W(n)},f)})));else if(h(v))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}]},vt=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())},ft=(t,a,e,n,s,i,r,[o,c,l],u,y,d,w,p,v)=>{const[f,E,g,h]=pt(a,u,y,s,p,v),m=wt(t,(async()=>await h((async()=>{return await f(),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 f(),await g(o,c,{[T]:{[l]:(a=t()??null,tt(a,((t,a)=>void 0===a?"":a)))}},!0,!0)}))),e,n,s,r,{[w]:()=>d,destroy:()=>(m.stopAutoLoad().stopAutoSave(),i(),m)},d);return m},Et=(t,a,e,n,s,i,r,[o,l,[u,y,d]],w,v,f,E,g,h,A,b)=>{const[S,$,C,O]=pt(a,w,v,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(d,N,{[T]:t},!0,!0,a):null,D=wt(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 $(d,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]:()=>f,destroy:()=>(D.stopAutoLoad().stopAutoSave(),i(),D)},f);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=d(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,w,p,v="getDb",f)=>{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=d(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?ft: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,w,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,v,n,f,(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=>f(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),d=(t,a,e)=>t.slice(a,e),w=t=>t.length,p=async t=>r.all(t),v=t=>{throw Error(t)},E=(t,a)=>h(Array(t).fill(0),((t,e)=>a(e))),f=(t,a)=>t.forEach(a),g=(t,a="")=>t.join(a),h=(t,a)=>t.map(a),A=t=>0==w(t),m=(t,a)=>t.filter(a),b=(t,...a)=>t.push(...a),T=t=>t.shift(),C="_",N="_id",S="SELECT",$="WHERE",O="TABLE",L="ALTER "+O,I="DELETE FROM",R=S+"*FROM",D="pragma_",M="data_version",P="schema_version",_="pragma_table_",F=t=>`"${t.replace(/"/g,'""')}"`,j=t=>g(h(t,((t,a)=>"$"+(a+1))),s),x=(t,a)=>t?.has(a)??!1,B=t=>c(t)||0==(t=>t?.size??0)(t),U=t=>[...t?.values()??[]],q=(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=>w(G(t)),tt=t=>(t=>!c(t)&&l(k(t),(t=>t==Y.prototype||c(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))),rt=(t,a,e)=>c(e)?(J(t,a),t):t?.set(a,e),ot=(t,a,e,n)=>(x(t,a)?n?.(st(t,a)):rt(t,a,e()),st(t,a)),ct=(t,a,e,n,s=0)=>l((e?ot:st)(t,a[s],s>w(a)-2?e:nt),(i=>{if(s>w(a)-2)return n?.(i)&&rt(t,a[s]),i;const r=ct(i,a,e,n,s+1);return B(i)&&rt(t,a[s]),r})),lt=t=>new Set(y(t)||c(t)?t:[t]),ut=(t,a)=>t?.add(a),yt=/^\d+$/,dt=nt(),wt=nt(),pt=(t,a,e,s,i,r,o,u={},d=[])=>{let p,E,g,h=0,A=0,m=0;ot(dt,d,(()=>0)),ot(wt,d,(()=>[]));const C=nt(),[N,S,$,O,L]=((t=1,a)=>1!=t&&a.isMergeable()?[1,a.getMergeableContent,a.getTransactionMergeableChanges,([[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"))(o,t),[I,R,D]=(()=>{let t;const[a,e]=(()=>{const t=[];let a=0;return[e=>(e?T(t):null)??n+a++,a=>{yt.test(a)&&w(t)<1e3&&b(t,a)}]})(),s=nt();return[(e,i,r,o=[],c=()=>[])=>{t??=Y;const l=a(1);return rt(s,l,[e,i,r,o,c]),ut(ct(i,r??[n],lt),l),l},(a,e,...i)=>f(((t,a=[n])=>{const e=[],s=(t,n)=>n==w(a)?b(e,t):null===a[n]?q(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=>q(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),B(a)?1:0))),rt(s,t),e(t),i))),a=>l(st(s,a),(([a,,e=[],n,s])=>{const i=(...r)=>{const o=w(r);o==w(e)?a(t,...r,...s(r)):c(e[o])?f(n[o]?.(...r)??[],(t=>i(...r,t))):i(...r,e[o])};i()}))]})(),M=t=>{t!=h&&(h=t,R(C,void 0,h))},P=a=>{(N&&y(a?.[0])?1===a?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===a?.[2]?t.applyChanges:t.setContent)(a)},_=async t=>(2!=h&&(M(1),A++,await U((async()=>{try{const t=await a();y(t)?P(t):v("Content is not an array "+t)}catch(a){r?.(a),t&&L(t)}M(0)}))),Y),F=()=>(E&&(i(E),E=void 0),Y),j=async t=>(1!=h&&(M(2),m++,await U((async()=>{try{await e(S,t)}catch(t){r?.(t)}M(0)}))),Y),x=()=>(l(g,t.delListener),g=void 0,Y),U=async(...t)=>(b(st(wt,d),...t),await(async()=>{if(!st(dt,d)){for(rt(dt,d,1);!c(p=T(st(wt,d)));)try{await p()}catch(t){r?.(t)}rt(dt,d,0)}})(),Y),Y={load:_,startAutoLoad:async t=>{await F().load(t);try{E=await s((async(t,a)=>{a||t?2!=h&&(M(1),A++,P(a??t),M(0)):await _()}))}catch(t){r?.(t)}return Y},stopAutoLoad:F,isAutoLoading:()=>!c(E),save:j,startAutoSave:async()=>(await x().save(),g=t.addDidFinishTransactionListener((()=>{const t=$();O(t)&&j(t)})),Y),stopAutoSave:x,isAutoSaving:()=>!c(g),getStatus:()=>h,addStatusListener:t=>I(t,C),delListener:a=>(D(a),t),schedule:U,getStore:()=>t,destroy:()=>(st(wt,d).splice(0,void 0),F().stopAutoSave()),getStats:()=>({loads:A,saves:m}),...u};return H(Y)},vt=(t,a,e,n,i,r,o,l)=>{const u=nt();return[async()=>{u.clear(),h(await e(t,a),(({tn:t,cn:a})=>ut(ot(u,t,lt),a)))},async(a,e)=>((t,a)=>x(st(u,t),a))(a,e)?K(m(h(await t(R+F(a)),(t=>{return[t[e],l?(a=V(t,e),n=l,K(W(a,((t,a)=>[a,n(t,a)])))):V(t,e)];var a,n})),(([t,a])=>!c(t)&&!tt(a)))):{},async(a,e,n,l,y,d=!1)=>{const w=lt();W(n??{},(t=>h(G(t??{}),(t=>ut(w,t)))));const v=U(w);if(!d&&y&&A(v)&&x(u,a))return await t("DROP "+O+F(a)),void rt(u,a);const E=st(u,a),f=lt(U(E));if(A(v)||(x(u,a)?await p(h([e,...v],(async(n,s)=>{J(f,n)||(await t(L+F(a)+"ADD"+F(n)+i),0==s&&await t("CREATE UNIQUE INDEX pk ON "+F(a)+`(${F(e)})`),ut(E,n))}))):(await t("CREATE "+O+F(a)+`(${F(e)}${i} PRIMARY KEY${g(h(v,(t=>s+F(t)+i)))});`),rt(u,a,lt([e,...v])))),await p([...!d&&l?h(U(f),(async n=>{n!=e&&(await t(L+F(a)+"DROP"+F(n)),J(E,n))})):[]]),d)c(n)?await t(I+F(a)+$+" true"):await p(W(n,(async(n,s)=>{c(n)?await t(I+F(a)+$+F(e)+"=$1",[s]):A(v)||await Et(t,a,e,G(n),[s,...o?h(X(n),o):X(n)],r)})));else if(A(v))x(u,a)&&await t(I+F(a)+$+" true");else{const s=m(U(st(u,a)),(t=>t!=e)),i=[],c=[];W(n??{},((t,a)=>{b(i,a,...h(s,(a=>o?o(t?.[a]):t?.[a]))),b(c,a)})),await Et(t,a,e,s,i,r),await t(I+F(a)+$+F(e)+`NOT IN(${j(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,i,r,o=0)=>await t("INSERT "+(o?"OR REPLACE ":n)+"INTO"+F(a)+"("+F(e)+g(h(i,(t=>s+F(t))))+")VALUES"+ft(r,w(i)+1)+(o?n:"ON CONFLICT("+F(e)+")DO UPDATE SET"+g(h(i,(t=>F(t)+"=excluded."+F(t))),s)),h(r,(t=>t??null))),ft=(t,a)=>g(E(w(t)/a,(t=>"("+g(E(a,(e=>"$"+(t*a+e+1))),s)+")")),s),gt=(t,a,e,n,s,i,r,[o,c,l],u,y,d,w,p,v)=>{const[E,f,g,h]=vt(a,u,y,s,p,v),A=pt(t,(async()=>await h((async()=>{return await E(),t=(await f(o,c))[C]?.[l]??"null",et(t,((t,a)=>""===a?void 0:a));var t}))),(async t=>await h((async()=>{var a;await E(),await g(o,c,{[C]:{[l]:(a=t()??null,at(a,((t,a)=>void 0===a?"":a)))}},!0,!0)}))),e,n,s,r,{[w]:()=>d,destroy:()=>(A.stopAutoLoad().stopAutoSave(),i(),A)},d);return A},ht=(t,a,e,n,s,i,r,[o,l,[u,y,d]],w,v,E,f,g,h,A,b)=>{const[T,S,$,O]=vt(a,w,v,s,g,h,A,b),L=async(t,a)=>await p(it(l,(async([e,n,s,i],r)=>{a&&!(r in t)||await $(e,n,t[r],s,i,a)}))),I=async(t,a)=>y?await $(d,N,{[C]:t},!0,!0,a):null,R=pt(t,(async()=>await O((async()=>{await T();const t=await(async()=>K(m(await p(it(o,(async([t,a],e)=>[t,await S(e,a)]))),(t=>!tt(t[1])))))(),a=await(async()=>u?(await S(d,N))[C]:{})();return tt(t)&&c(a)?void 0:[t,a]}))),(async(t,a)=>await O((async()=>{if(await T(),c(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,r,{[f]:()=>E,destroy:()=>(R.stopAutoLoad().stopAutoSave(),i(),R)},E);return R},At="ColumnName",mt="store",bt="json",Tt=mt+"TableName",Ct=mt+"Id"+At,Nt=mt+At,St="autoLoadIntervalSeconds",$t="rowId"+At,Ot="tableId",Lt="tableName",It="deleteEmptyColumns",Rt="deleteEmptyTable",Dt={mode:bt,[St]:1},Mt={load:0,save:0,[Lt]:e+"_values"},Pt=(t,a,e,n,s)=>{const i=nt();return W(t,((t,r)=>{const o=d(X(Q(a,u(t)?{[e]:t}:t)),0,Z(a));c(o[0])||n(r,o[0])||(s(r,o[0]),rt(i,r,o))})),i},_t=(t,a,s,i,r,c,l,y,w,p,v="getDb",E)=>{let f,g,h;const A=((t,a)=>a?async(e,n)=>(a(e,n),await t(e,n)):t)(s,c),[m,b,T,C]=(t=>{const a=(t=>Q(Dt,u(t)?{[Tt]:t}:t??{}))(t),n=a[St];if(a.mode==bt){const t=a[Tt]??e;return[1,n,[t,a[Ct]??N,a[Nt]??mt],lt(t)]}const{tables:{load:s={},save:i={}}={},values:r={}}=a,o=d(X(Q(Mt,r)),0,Z(Mt)),c=o[2],l=lt(c),y=lt(c);return[0,n,[Pt(s,{[Ot]:null,[$t]:N},Ot,(t=>x(y,t)),(t=>ut(l,t))),Pt(i,{[Lt]:null,[$t]:N,[It]:0,[Rt]:0},Lt,((t,a)=>x(y,a)),((t,a)=>ut(l,a))),o],l]})(a);return(m?gt:ht)(t,A,(t=>{let a;const e=()=>a=setInterval((async()=>{try{const[{d:a,s:e,c:n}]=await A(`${S} ${M} d,${P} s,TOTAL_CHANGES() c FROM ${D}${M} JOIN ${D}${P}`);a==f&&e==g&&n==h||(null!=f&&t(),f=a,g=e,h=n)}catch{}}),1e3*b),n=()=>{f=g=h=null,o(a)},s=i((a=>{C.has(a)&&(n(),t(),e())}));return e(),()=>{n(),r(s)}}),(t=>t()),l,y,w,T,U(C),(async(t,a)=>await t(`${S} t.name tn,c.name cn FROM ${_}list()t,${_}info(t.name)c ${$} t.schema='main'AND t.type IN('table','view')AND t.name IN(${j(a)})ORDER BY t.name,c.name`,a)),p,v,n,E,(t=>!0===t?1:!1===t?0:t),void 0)};t.createElectricSqlPersister=(t,a,e,n,s)=>_t(t,e,(async(t,e=[])=>await a.db.raw({sql:t,args:e})),(t=>a.notifier.subscribeToDataChanges((e=>f(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),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),d=(t,a,e)=>t.slice(a,e),w=t=>t.length,p=async t=>r.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),h=t=>0==w(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=>w(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>w(a)-2?e:et),(i=>{if(s>w(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(),dt=et(),wt=(t,a,e,s,i,r,o,u={},d=[])=>{let p,E,g,h=0,m=0,T=0;rt(yt,d,(()=>0)),rt(dt,d,(()=>[]));const N=et(),[S,$,C,O,I]=((t=1,a)=>1!=t&&a.isMergeable()?[1,a.getMergeableContent,a.getTransactionMergeableChanges,([[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"))(o,t),[L,D,R]=(()=>{let t;const[a,e]=(()=>{const t=[];let a=0;return[e=>(e?b(t):null)??n+a++,a=>{ut.test(a)&&w(t)<1e3&&A(t,a)}]})(),s=et();return[(e,i,r,o=[],c=()=>[])=>{t??=Y;const l=a(1);return it(s,l,[e,i,r,o,c]),lt(ot(i,r??[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]?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])=>(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=w(r);o==w(e)?a(t,...r,...s(r)):c(e[o])?f(n[o]?.(...r)??[],(t=>i(...r,t))):i(...r,e[o])};i()}))]})(),M=t=>{t!=h&&(h=t,D(N,void 0,h))},P=a=>{(S&&y(a?.[0])?1===a?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===a?.[2]?t.applyChanges:t.setContent)(a)},_=async t=>(2!=h&&(M(1),m++,await J((async()=>{try{const t=await a();y(t)?P(t):v("Content is not an array "+t)}catch(a){r?.(a),t&&I(t)}M(0)}))),Y),F=()=>(E&&(i(E),E=void 0),Y),j=async t=>(1!=h&&(M(2),T++,await J((async()=>{try{await e($,t)}catch(t){r?.(t)}M(0)}))),Y),B=()=>(l(g,t.delListener),g=void 0,Y),J=async(...t)=>(A(nt(dt,d),...t),await(async()=>{if(!nt(yt,d)){for(it(yt,d,1);!c(p=b(nt(dt,d)));)try{await p()}catch(t){r?.(t)}it(yt,d,0)}})(),Y),Y={load:_,startAutoLoad:async t=>{await F().load(t);try{E=await s((async(t,a)=>{a||t?2!=h&&(M(1),m++,P(a??t),M(0)):await _()}))}catch(t){r?.(t)}return Y},stopAutoLoad:F,isAutoLoading:()=>!c(E),save:j,startAutoSave:async()=>(await B().save(),g=t.addDidFinishTransactionListener((()=>{const t=C();O(t)&&j(t)})),Y),stopAutoSave:B,isAutoSaving:()=>!c(g),getStatus:()=>h,addStatusListener:t=>L(t,N),delListener:a=>(R(a),t),schedule:J,getStore:()=>t,destroy:()=>(nt(dt,d).splice(0,void 0),F().stopAutoSave()),getStats:()=>({loads:m,saves:T}),...u};return G(Y)},pt=(t,a,e,n,i,r=vt,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,d=!1)=>{const w=ct();V(n??{},(t=>g(z(t??{}),(t=>lt(w,t)))));const v=B(w);if(!d&&y&&h(v)&&j(u,a))return await t("DROP "+C+_(a)),void it(u,a);const f=nt(u,a),b=ct(B(f));if(h(v)||(j(u,a)?await p(g([e,...v],(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(f,n))}))):(await t("CREATE "+C+_(a)+`(${_(e)}${i} PRIMARY KEY${E(g(v,(t=>s+_(t)+i)))});`),it(u,a,ct([e,...v])))),await p([...!d&&l?g(B(b),(async n=>{n!=e&&(await t(O+_(a)+"DROP"+_(n)),q(f,n))})):[]]),d)c(n)?await t(I+_(a)+$+" true"):await p(V(n,(async(n,s)=>{c(n)?await t(I+_(a)+$+_(e)+"=$1",[s]):h(v)||await r(t,a,e,z(n),{[s]:o?g(W(n),o):W(n)},f)})));else if(h(v))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}]},vt=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())},ft=(t,a,e,n,s,i,r,[o,c,l],u,y,d,w,p,v)=>{const[f,E,g,h]=pt(a,u,y,s,p,v),m=wt(t,(async()=>await h((async()=>{return await f(),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 f(),await g(o,c,{[T]:{[l]:(a=t()??null,tt(a,((t,a)=>void 0===a?"":a)))}},!0,!0)}))),e,n,s,r,{[w]:()=>d,destroy:()=>(m.stopAutoLoad().stopAutoSave(),i(),m)},d);return m},Et=(t,a,e,n,s,i,r,[o,l,[u,y,d]],w,v,f,E,g,h,A,b)=>{const[S,$,C,O]=pt(a,w,v,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(d,N,{[T]:t},!0,!0,a):null,D=wt(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 $(d,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]:()=>f,destroy:()=>(D.stopAutoLoad().stopAutoSave(),i(),D)},f);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=d(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,w,p,v="getDb",f)=>{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=d(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?ft: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,w,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,v,n,f,(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=>f(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,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),E=t=>{throw Error(t)},f=(t,a)=>h(Array(t).fill(0),((t,e)=>a(e))),g=(t,a)=>t.forEach(a),A=(t,a="")=>t.join(a),h=(t,a)=>t.map(a),m=t=>0==p(t),N=(t,a)=>t.filter(a),S=(t,...a)=>t.push(...a),T=t=>t.shift(),$="_",b="_id",C="SELECT",O="WHERE",L="TABLE",I="ALTER "+L,R="DELETE FROM",D=C+"*FROM",M="pragma_",P="data_version",x="schema_version",_="pragma_table_",q=t=>`"${t.replace(/"/g,'""')}"`,F=t=>A(h(t,((t,a)=>"$"+(a+1))),i),j=(t,a)=>t?.has(a)??!1,B=t=>l(t)||0==(t=>t?.size??0)(t),U=t=>[...t?.values()??[]],J=(t,a)=>t?.forEach(a),Y=(t,a)=>t?.delete(a),k=Object,z=t=>k.getPrototypeOf(t),G=k.entries,H=k.keys,K=k.freeze,Q=(t=[])=>k.fromEntries(t),V=(...t)=>k.assign({},...t),W=(t,a)=>(delete t[a],t),X=(t,a)=>h(G(t),(([t,e])=>a(e,t))),Z=t=>k.values(t),tt=t=>p(H(t)),at=t=>(t=>!l(t)&&y(z(t),(t=>t==k.prototype||l(z(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)?(Y(t,a),t):t?.set(a,e),ct=(t,a,e,n)=>(j(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 B(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=[])=>{let w,v,f,A=0,h=0,m=0;ct(wt,u,(()=>0)),ct(pt,u,(()=>[]));const N=st(),[$,b,C,O,L]=((t=1,a)=>1!=t&&a.isMergeable()?[1,a.getMergeableContent,a.getTransactionMergeableChanges,([[t],[a]])=>!at(t)||!at(a),a.setDefaultContent]:2!=t?[0,a.getContent,a.getTransactionChanges,([t,a])=>!at(t)||!at(a),a.setContent]:E("Store type not supported by this Persister"))(r,t),[I,R,D]=(()=>{let t;const[a,e]=(()=>{const t=[];let a=0;return[e=>(e?T(t):null)??s+a++,a=>{dt.test(a)&&p(t)<1e3&&S(t,a)}]})(),n=st();return[(e,i,o,r=[],c=()=>[])=>{t??=U;const l=a(1);return rt(n,l,[e,i,o,r,c]),ut(lt(i,o??[s],yt),l),l},(a,e,...i)=>g(((t,a=[s])=>{const e=[],n=(t,s)=>s==p(a)?S(e,t):null===a[s]?J(t,(t=>n(t,s+1))):g([a[s],null],(a=>n(it(t,a),s+1)));return n(t,0),e})(a,e),(a=>J(a,(a=>it(n,a)[0](t,...e??[],...i))))),t=>y(it(n,t),(([,a,i])=>(lt(a,i??[s],void 0,(a=>(Y(a,t),B(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])?g(n[r]?.(...o)??[],(t=>i(...o,t))):i(...o,e[r])};i()}))]})(),M=t=>{t!=A&&(A=t,R(N,void 0,A))},P=a=>{($&&d(a?.[0])?1===a?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===a?.[2]?t.applyChanges:t.setContent)(a)},x=async t=>(2!=A&&(M(1),h++,await j((async()=>{try{const t=await a();d(t)?P(t):E("Content is not an array "+t)}catch(a){o?.(a),t&&L(t)}M(0)}))),U),_=()=>(v&&(i(v),v=void 0),U),q=async t=>(1!=A&&(M(2),m++,await j((async()=>{try{await e(b,t)}catch(t){o?.(t)}M(0)}))),U),F=()=>(y(f,t.delListener),f=void 0,U),j=async(...t)=>(S(it(pt,u),...t),await(async()=>{if(!it(wt,u)){for(rt(wt,u,1);!l(w=T(it(pt,u)));)try{await w()}catch(t){o?.(t)}rt(wt,u,0)}})(),U),U={load:x,startAutoLoad:async t=>{await _().load(t);try{v=await n((async(t,a)=>{a||t?2!=A&&(M(1),h++,P(a??t),M(0)):await x()}))}catch(t){o?.(t)}return U},stopAutoLoad:_,isAutoLoading:()=>!l(v),save:q,startAutoSave:async()=>(await F().save(),f=t.addDidFinishTransactionListener((()=>{const t=C();O(t)&&q(t)})),U),stopAutoSave:F,isAutoSaving:()=>!l(f),getStatus:()=>A,addStatusListener:t=>I(t,N),delListener:a=>(D(a),t),schedule:j,getStore:()=>t,destroy:()=>(it(pt,u).splice(0,void 0),_().stopAutoSave()),getStats:()=>({loads:h,saves:m}),...c};return K(U)},Et=(t,a,e,n,s,o,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)=>j(it(y,t),a))(a,e)?Q(N(h(await t(D+q(a)),(t=>{return[t[e],c?(a=W(t,e),n=c,Q(X(a,((t,a)=>[a,n(t,a)])))):W(t,e)];var a,n})),(([t,a])=>!l(t)&&!at(a)))):{},async(a,e,n,c,u,d=!1)=>{const w=yt();X(n??{},(t=>h(H(t??{}),(t=>ut(w,t)))));const p=U(w);if(!d&&u&&m(p)&&j(y,a))return await t("DROP "+L+q(a)),void rt(y,a);const E=it(y,a),f=yt(U(E));if(m(p)||(j(y,a)?await v(h([e,...p],(async(n,i)=>{Y(f,n)||(await t(I+q(a)+"ADD"+q(n)+s),0==i&&await t("CREATE UNIQUE INDEX pk ON "+q(a)+`(${q(e)})`),ut(E,n))}))):(await t("CREATE "+L+q(a)+`(${q(e)}${s} PRIMARY KEY${A(h(p,(t=>i+q(t)+s)))});`),rt(y,a,yt([e,...p])))),await v([...!d&&c?h(U(f),(async n=>{n!=e&&(await t(I+q(a)+"DROP"+q(n)),Y(E,n))})):[]]),d)l(n)?await t(R+q(a)+O+" true"):await v(X(n,(async(n,s)=>{l(n)?await t(R+q(a)+O+q(e)+"=$1",[s]):m(p)||await ft(t,a,e,H(n),[s,...r?h(Z(n),r):Z(n)],o)})));else if(m(p))j(y,a)&&await t(R+q(a)+O+" true");else{const s=N(U(it(y,a)),(t=>t!=e)),i=[],c=[];X(n??{},((t,a)=>{S(i,a,...h(s,(a=>r?r(t?.[a]):t?.[a]))),S(c,a)})),await ft(t,a,e,s,i,o),await t(R+q(a)+O+q(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,o,r=0)=>await t("INSERT "+(r?"OR REPLACE ":s)+"INTO"+q(a)+"("+q(e)+A(h(n,(t=>i+q(t))))+")VALUES"+gt(o,p(n)+1)+(r?s:"ON CONFLICT("+q(e)+")DO UPDATE SET"+A(h(n,(t=>q(t)+"=excluded."+q(t))),i)),h(o,(t=>t??null))),gt=(t,a)=>A(f(p(t)/a,(t=>"("+A(f(a,(e=>"$"+(t*a+e+1))),i)+")")),i),At=(t,a,e,n,s,i,o,[r,c,l],y,u,d,w,p,v)=>{const[E,f,g,A]=Et(a,y,u,s,p,v),h=vt(t,(async()=>await A((async()=>{return await E(),t=(await f(r,c))[$]?.[l]??"null",nt(t,((t,a)=>""===a?void 0:a));var t}))),(async t=>await A((async()=>{var a;await E(),await g(r,c,{[$]:{[l]:(a=t()??null,et(a,((t,a)=>void 0===a?"":a)))}},!0,!0)}))),e,n,s,o,{[w]:()=>d,destroy:()=>(h.stopAutoLoad().stopAutoSave(),i(),h)},d);return h},ht=(t,a,e,n,s,i,o,[r,c,[y,u,d]],w,p,E,f,g,A,h,m)=>{const[S,T,C,O]=Et(a,w,p,s,g,A,h,m),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,b,{[$]:t},!0,!0,a):null,R=vt(t,(async()=>await O((async()=>{await S();const t=await(async()=>Q(N(await v(ot(r,(async([t,a],e)=>[t,await T(e,a)]))),(t=>!at(t[1])))))(),a=await(async()=>y?(await T(d,b))[$]:{})();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,{[f]:()=>E,destroy:()=>(R.stopAutoLoad().stopAutoSave(),i(),R)},E);return R},mt="ColumnName",Nt="store",St="json",Tt=Nt+"TableName",$t=Nt+"Id"+mt,bt=Nt+mt,Ct="autoLoadIntervalSeconds",Ot="rowId"+mt,Lt="tableId",It="tableName",Rt="deleteEmptyColumns",Dt="deleteEmptyTable",Mt={mode:St,[Ct]:1},Pt={load:0,save:0,[It]:n+"_values"},xt=(t,a,e,n,s)=>{const i=st();return X(t,((t,o)=>{const r=w(Z(V(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},_t=(t,a,e,i,o,r,l,y,d,p,v="getDb",E)=>{let f,g,A;const h=((t,a)=>a?async(e,n)=>(a(e,n),await t(e,n)):t)(e,r),[m,N,S,T]=(t=>{const a=(t=>V(Mt,u(t)?{[Tt]:t}:t??{}))(t),e=a[Ct];if(a.mode==St){const t=a[Tt]??n;return[1,e,[t,a[$t]??b,a[bt]??Nt],yt(t)]}const{tables:{load:s={},save:i={}}={},values:o={}}=a,r=w(Z(V(Pt,o)),0,tt(Pt)),c=r[2],l=yt(c),y=yt(c);return[0,e,[xt(s,{[Lt]:null,[Ot]:b},Lt,(t=>j(y,t)),(t=>ut(l,t))),xt(i,{[It]:null,[Ot]:b,[Rt]:0,[Dt]:0},It,((t,a)=>j(y,a)),((t,a)=>ut(l,a))),r],l]})(a);return(m?At:ht)(t,h,(t=>{let a;const e=()=>a=setInterval((async()=>{try{const[{d:a,s:e,c:n}]=await h(`${C} ${P} d,${x} s,TOTAL_CHANGES() c FROM ${M}${P} JOIN ${M}${x}`);a==f&&e==g&&n==A||(null!=f&&t(),f=a,g=e,A=n)}catch{}}),1e3*N),n=()=>{f=g=A=null,c(a)},s=i((a=>{T.has(a)&&(n(),t(),e())}));return e(),()=>{n(),o(s)}}),(t=>t()),l,y,d,S,U(T),(async(t,a)=>await t(`${C} t.name tn,c.name cn FROM ${_}list()t,${_}info(t.name)c ${O} t.schema='main'AND t.type IN('table','view')AND t.name IN(${F(a)})ORDER BY t.name,c.name`,a)),p,v,s,E,(t=>!0===t?1:!1===t?0:t),void 0)};t.createExpoSqlitePersister=(t,e,n,s,i)=>_t(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,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=[])=>{let w,v,g,h=0,m=0,A=0;rt(dt,y,(()=>0)),rt(wt,y,(()=>[]));const T=nt(),[$,b,C,O,L]=((t=1,a)=>1!=t&&a.isMergeable()?[1,a.getMergeableContent,a.getTransactionMergeableChanges,([[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),[I,D,R]=(()=>{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??=Y;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()}))]})(),M=t=>{t!=h&&(h=t,D(T,void 0,h))},x=a=>{($&&d(a?.[0])?1===a?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===a?.[2]?t.applyChanges:t.setContent)(a)},P=async t=>(2!=h&&(M(1),m++,await B((async()=>{try{const t=await a();d(t)?x(t):f("Content is not an array "+t)}catch(a){o?.(a),t&&L(t)}M(0)}))),Y),_=()=>(v&&(i(v),v=void 0),Y),q=async t=>(1!=h&&(M(2),A++,await B((async()=>{try{await e(b,t)}catch(t){o?.(t)}M(0)}))),Y),F=()=>(u(g,t.delListener),g=void 0,Y),B=async(...t)=>(N(st(wt,y),...t),await(async()=>{if(!st(dt,y)){for(ot(dt,y,1);!l(w=S(st(wt,y)));)try{await w()}catch(t){o?.(t)}ot(dt,y,0)}})(),Y),Y={load:P,startAutoLoad:async t=>{await _().load(t);try{v=await n((async(t,a)=>{a||t?2!=h&&(M(1),m++,x(a??t),M(0)):await P()}))}catch(t){o?.(t)}return Y},stopAutoLoad:_,isAutoLoading:()=>!l(v),save:q,startAutoSave:async()=>(await F().save(),g=t.addDidFinishTransactionListener((()=>{const t=C();O(t)&&q(t)})),Y),stopAutoSave:F,isAutoSaving:()=>!l(g),getStatus:()=>h,addStatusListener:t=>I(t,T),delListener:a=>(R(a),t),schedule:B,getStore:()=>t,destroy:()=>(st(wt,y).splice(0,void 0),_().stopAutoSave()),getStats:()=>({loads:m,saves:A}),...c};return H(Y)},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)},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)},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 +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,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),E=t=>{throw Error(t)},f=(t,a)=>h(Array(t).fill(0),((t,e)=>a(e))),g=(t,a)=>t.forEach(a),A=(t,a="")=>t.join(a),h=(t,a)=>t.map(a),m=t=>0==p(t),N=(t,a)=>t.filter(a),S=(t,...a)=>t.push(...a),T=t=>t.shift(),$="_",b="_id",C="SELECT",O="WHERE",L="TABLE",I="ALTER "+L,R="DELETE FROM",D=C+"*FROM",M="pragma_",P="data_version",x="schema_version",_="pragma_table_",q=t=>`"${t.replace(/"/g,'""')}"`,F=t=>A(h(t,((t,a)=>"$"+(a+1))),i),j=(t,a)=>t?.has(a)??!1,B=t=>l(t)||0==(t=>t?.size??0)(t),U=t=>[...t?.values()??[]],J=(t,a)=>t?.forEach(a),Y=(t,a)=>t?.delete(a),k=Object,z=t=>k.getPrototypeOf(t),G=k.entries,H=k.keys,K=k.freeze,Q=(t=[])=>k.fromEntries(t),V=(...t)=>k.assign({},...t),W=(t,a)=>(delete t[a],t),X=(t,a)=>h(G(t),(([t,e])=>a(e,t))),Z=t=>k.values(t),tt=t=>p(H(t)),at=t=>(t=>!l(t)&&y(z(t),(t=>t==k.prototype||l(z(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)?(Y(t,a),t):t?.set(a,e),ct=(t,a,e,n)=>(j(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 B(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=[])=>{let w,v,f,A=0,h=0,m=0;ct(wt,u,(()=>0)),ct(pt,u,(()=>[]));const N=st(),[$,b,C,O,L]=((t=1,a)=>1!=t&&a.isMergeable()?[1,a.getMergeableContent,a.getTransactionMergeableChanges,([[t],[a]])=>!at(t)||!at(a),a.setDefaultContent]:2!=t?[0,a.getContent,a.getTransactionChanges,([t,a])=>!at(t)||!at(a),a.setContent]:E("Store type not supported by this Persister"))(r,t),[I,R,D]=(()=>{let t;const[a,e]=(()=>{const t=[];let a=0;return[e=>(e?T(t):null)??s+a++,a=>{dt.test(a)&&p(t)<1e3&&S(t,a)}]})(),n=st();return[(e,i,o,r=[],c=()=>[])=>{t??=U;const l=a(1);return rt(n,l,[e,i,o,r,c]),ut(lt(i,o??[s],yt),l),l},(a,e,...i)=>g(((t,a=[s])=>{const e=[],n=(t,s)=>s==p(a)?S(e,t):null===a[s]?J(t,(t=>n(t,s+1))):g([a[s],null],(a=>n(it(t,a),s+1)));return n(t,0),e})(a,e),(a=>J(a,(a=>it(n,a)[0](t,...e??[],...i))))),t=>y(it(n,t),(([,a,i])=>(lt(a,i??[s],void 0,(a=>(Y(a,t),B(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])?g(n[r]?.(...o)??[],(t=>i(...o,t))):i(...o,e[r])};i()}))]})(),M=t=>{t!=A&&(A=t,R(N,void 0,A))},P=a=>{($&&d(a?.[0])?1===a?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===a?.[2]?t.applyChanges:t.setContent)(a)},x=async t=>(2!=A&&(M(1),h++,await j((async()=>{try{const t=await a();d(t)?P(t):E("Content is not an array "+t)}catch(a){o?.(a),t&&L(t)}M(0)}))),U),_=()=>(v&&(i(v),v=void 0),U),q=async t=>(1!=A&&(M(2),m++,await j((async()=>{try{await e(b,t)}catch(t){o?.(t)}M(0)}))),U),F=()=>(y(f,t.delListener),f=void 0,U),j=async(...t)=>(S(it(pt,u),...t),await(async()=>{if(!it(wt,u)){for(rt(wt,u,1);!l(w=T(it(pt,u)));)try{await w()}catch(t){o?.(t)}rt(wt,u,0)}})(),U),U={load:x,startAutoLoad:async t=>{await _().load(t);try{v=await n((async(t,a)=>{a||t?2!=A&&(M(1),h++,P(a??t),M(0)):await x()}))}catch(t){o?.(t)}return U},stopAutoLoad:_,isAutoLoading:()=>!l(v),save:q,startAutoSave:async()=>(await F().save(),f=t.addDidFinishTransactionListener((()=>{const t=C();O(t)&&q(t)})),U),stopAutoSave:F,isAutoSaving:()=>!l(f),getStatus:()=>A,addStatusListener:t=>I(t,N),delListener:a=>(D(a),t),schedule:j,getStore:()=>t,destroy:()=>(it(pt,u).splice(0,void 0),_().stopAutoSave()),getStats:()=>({loads:h,saves:m}),...c};return K(U)},Et=(t,a,e,n,s,o,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)=>j(it(y,t),a))(a,e)?Q(N(h(await t(D+q(a)),(t=>{return[t[e],c?(a=W(t,e),n=c,Q(X(a,((t,a)=>[a,n(t,a)])))):W(t,e)];var a,n})),(([t,a])=>!l(t)&&!at(a)))):{},async(a,e,n,c,u,d=!1)=>{const w=yt();X(n??{},(t=>h(H(t??{}),(t=>ut(w,t)))));const p=U(w);if(!d&&u&&m(p)&&j(y,a))return await t("DROP "+L+q(a)),void rt(y,a);const E=it(y,a),f=yt(U(E));if(m(p)||(j(y,a)?await v(h([e,...p],(async(n,i)=>{Y(f,n)||(await t(I+q(a)+"ADD"+q(n)+s),0==i&&await t("CREATE UNIQUE INDEX pk ON "+q(a)+`(${q(e)})`),ut(E,n))}))):(await t("CREATE "+L+q(a)+`(${q(e)}${s} PRIMARY KEY${A(h(p,(t=>i+q(t)+s)))});`),rt(y,a,yt([e,...p])))),await v([...!d&&c?h(U(f),(async n=>{n!=e&&(await t(I+q(a)+"DROP"+q(n)),Y(E,n))})):[]]),d)l(n)?await t(R+q(a)+O+" true"):await v(X(n,(async(n,s)=>{l(n)?await t(R+q(a)+O+q(e)+"=$1",[s]):m(p)||await ft(t,a,e,H(n),[s,...r?h(Z(n),r):Z(n)],o)})));else if(m(p))j(y,a)&&await t(R+q(a)+O+" true");else{const s=N(U(it(y,a)),(t=>t!=e)),i=[],c=[];X(n??{},((t,a)=>{S(i,a,...h(s,(a=>r?r(t?.[a]):t?.[a]))),S(c,a)})),await ft(t,a,e,s,i,o),await t(R+q(a)+O+q(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,o,r=0)=>await t("INSERT "+(r?"OR REPLACE ":s)+"INTO"+q(a)+"("+q(e)+A(h(n,(t=>i+q(t))))+")VALUES"+gt(o,p(n)+1)+(r?s:"ON CONFLICT("+q(e)+")DO UPDATE SET"+A(h(n,(t=>q(t)+"=excluded."+q(t))),i)),h(o,(t=>t??null))),gt=(t,a)=>A(f(p(t)/a,(t=>"("+A(f(a,(e=>"$"+(t*a+e+1))),i)+")")),i),At=(t,a,e,n,s,i,o,[r,c,l],y,u,d,w,p,v)=>{const[E,f,g,A]=Et(a,y,u,s,p,v),h=vt(t,(async()=>await A((async()=>{return await E(),t=(await f(r,c))[$]?.[l]??"null",nt(t,((t,a)=>""===a?void 0:a));var t}))),(async t=>await A((async()=>{var a;await E(),await g(r,c,{[$]:{[l]:(a=t()??null,et(a,((t,a)=>void 0===a?"":a)))}},!0,!0)}))),e,n,s,o,{[w]:()=>d,destroy:()=>(h.stopAutoLoad().stopAutoSave(),i(),h)},d);return h},ht=(t,a,e,n,s,i,o,[r,c,[y,u,d]],w,p,E,f,g,A,h,m)=>{const[S,T,C,O]=Et(a,w,p,s,g,A,h,m),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,b,{[$]:t},!0,!0,a):null,R=vt(t,(async()=>await O((async()=>{await S();const t=await(async()=>Q(N(await v(ot(r,(async([t,a],e)=>[t,await T(e,a)]))),(t=>!at(t[1])))))(),a=await(async()=>y?(await T(d,b))[$]:{})();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,{[f]:()=>E,destroy:()=>(R.stopAutoLoad().stopAutoSave(),i(),R)},E);return R},mt="ColumnName",Nt="store",St="json",Tt=Nt+"TableName",$t=Nt+"Id"+mt,bt=Nt+mt,Ct="autoLoadIntervalSeconds",Ot="rowId"+mt,Lt="tableId",It="tableName",Rt="deleteEmptyColumns",Dt="deleteEmptyTable",Mt={mode:St,[Ct]:1},Pt={load:0,save:0,[It]:n+"_values"},xt=(t,a,e,n,s)=>{const i=st();return X(t,((t,o)=>{const r=w(Z(V(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},_t=(t,a,e,i,o,r,l,y,d,p,v="getDb",E)=>{let f,g,A;const h=((t,a)=>a?async(e,n)=>(a(e,n),await t(e,n)):t)(e,r),[m,N,S,T]=(t=>{const a=(t=>V(Mt,u(t)?{[Tt]:t}:t??{}))(t),e=a[Ct];if(a.mode==St){const t=a[Tt]??n;return[1,e,[t,a[$t]??b,a[bt]??Nt],yt(t)]}const{tables:{load:s={},save:i={}}={},values:o={}}=a,r=w(Z(V(Pt,o)),0,tt(Pt)),c=r[2],l=yt(c),y=yt(c);return[0,e,[xt(s,{[Lt]:null,[Ot]:b},Lt,(t=>j(y,t)),(t=>ut(l,t))),xt(i,{[It]:null,[Ot]:b,[Rt]:0,[Dt]:0},It,((t,a)=>j(y,a)),((t,a)=>ut(l,a))),r],l]})(a);return(m?At:ht)(t,h,(t=>{let a;const e=()=>a=setInterval((async()=>{try{const[{d:a,s:e,c:n}]=await h(`${C} ${P} d,${x} s,TOTAL_CHANGES() c FROM ${M}${P} JOIN ${M}${x}`);a==f&&e==g&&n==A||(null!=f&&t(),f=a,g=e,A=n)}catch{}}),1e3*N),n=()=>{f=g=A=null,c(a)},s=i((a=>{T.has(a)&&(n(),t(),e())}));return e(),()=>{n(),o(s)}}),(t=>t()),l,y,d,S,U(T),(async(t,a)=>await t(`${C} t.name tn,c.name cn FROM ${_}list()t,${_}info(t.name)c ${O} t.schema='main'AND t.type IN('table','view')AND t.name IN(${F(a)})ORDER BY t.name,c.name`,a)),p,v,s,E,(t=>!0===t?1:!1===t?0:t),void 0)};t.createExpoSqlitePersister=(t,e,n,s,i)=>_t(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,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=[])=>{let w,v,g,h=0,m=0,A=0;rt(dt,y,(()=>0)),rt(wt,y,(()=>[]));const T=nt(),[$,b,C,O,L]=((t=1,a)=>1!=t&&a.isMergeable()?[1,a.getMergeableContent,a.getTransactionMergeableChanges,([[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),[I,D,R]=(()=>{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??=Y;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()}))]})(),M=t=>{t!=h&&(h=t,D(T,void 0,h))},x=a=>{($&&d(a?.[0])?1===a?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===a?.[2]?t.applyChanges:t.setContent)(a)},P=async t=>(2!=h&&(M(1),m++,await B((async()=>{try{const t=await a();d(t)?x(t):f("Content is not an array "+t)}catch(a){o?.(a),t&&L(t)}M(0)}))),Y),_=()=>(v&&(i(v),v=void 0),Y),q=async t=>(1!=h&&(M(2),A++,await B((async()=>{try{await e(b,t)}catch(t){o?.(t)}M(0)}))),Y),F=()=>(u(g,t.delListener),g=void 0,Y),B=async(...t)=>(N(st(wt,y),...t),await(async()=>{if(!st(dt,y)){for(ot(dt,y,1);!l(w=S(st(wt,y)));)try{await w()}catch(t){o?.(t)}ot(dt,y,0)}})(),Y),Y={load:P,startAutoLoad:async t=>{await _().load(t);try{v=await n((async(t,a)=>{a||t?2!=h&&(M(1),m++,x(a??t),M(0)):await P()}))}catch(t){o?.(t)}return Y},stopAutoLoad:_,isAutoLoading:()=>!l(v),save:q,startAutoSave:async()=>(await F().save(),g=t.addDidFinishTransactionListener((()=>{const t=C();O(t)&&q(t)})),Y),stopAutoSave:F,isAutoSaving:()=>!l(g),getStatus:()=>h,addStatusListener:t=>I(t,T),delListener:a=>(R(a),t),schedule:B,getStore:()=>t,destroy:()=>(st(wt,y).splice(0,void 0),_().stopAutoSave()),getStats:()=>({loads:m,saves:A}),...c};return H(Y)},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)},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)},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 +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),v=t=>{throw Error(t)},f=(t,a)=>A(Array(t).fill(0),((t,e)=>a(e))),E=(t,a)=>t.forEach(a),g=(t,a="")=>t.join(a),A=(t,a)=>t.map(a),h=t=>0==d(t),m=(t,a)=>t.filter(a),N=(t,...a)=>t.push(...a),T=t=>t.shift(),$="_",b="_id",C="SELECT",S="WHERE",L="TABLE",O="ALTER "+L,I="DELETE FROM",R=C+"*FROM",D="pragma_",M="data_version",P="schema_version",_="pragma_table_",F=t=>`"${t.replace(/"/g,'""')}"`,x=t=>g(A(t,((t,a)=>"$"+(a+1))),s),j=(t,a)=>t?.has(a)??!1,B=t=>c(t)||0==(t=>t?.size??0)(t),U=t=>[...t?.values()??[]],q=(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)=>A(z(t),(([t,e])=>a(e,t))),X=t=>Y.values(t),Z=t=>d(G(t)),tt=t=>(t=>!c(t)&&l(k(t),(t=>t==Y.prototype||c(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)=>A([...t?.entries()??[]],(([t,e])=>a(e,t))),rt=(t,a,e)=>c(e)?(J(t,a),t):t?.set(a,e),ot=(t,a,e,n)=>(j(t,a)?n?.(st(t,a)):rt(t,a,e()),st(t,a)),ct=(t,a,e,n,s=0)=>l((e?ot:st)(t,a[s],s>d(a)-2?e:nt),(i=>{if(s>d(a)-2)return n?.(i)&&rt(t,a[s]),i;const r=ct(i,a,e,n,s+1);return B(i)&&rt(t,a[s]),r})),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,r,o,u={},w=[])=>{let p,f,g,A=0,h=0,m=0;ot(wt,w,(()=>0)),ot(dt,w,(()=>[]));const $=nt(),[b,C,S,L,O]=((t=1,a)=>1!=t&&a.isMergeable()?[1,a.getMergeableContent,a.getTransactionMergeableChanges,([[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"))(o,t),[I,R,D]=(()=>{let t;const[a,e]=(()=>{const t=[];let a=0;return[e=>(e?T(t):null)??n+a++,a=>{yt.test(a)&&d(t)<1e3&&N(t,a)}]})(),s=nt();return[(e,i,r,o=[],c=()=>[])=>{t??=Y;const l=a(1);return rt(s,l,[e,i,r,o,c]),ut(ct(i,r??[n],lt),l),l},(a,e,...i)=>E(((t,a=[n])=>{const e=[],s=(t,n)=>n==d(a)?N(e,t):null===a[n]?q(t,(t=>s(t,n+1))):E([a[n],null],(a=>s(st(t,a),n+1)));return s(t,0),e})(a,e),(a=>q(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),B(a)?1:0))),rt(s,t),e(t),i))),a=>l(st(s,a),(([a,,e=[],n,s])=>{const i=(...r)=>{const o=d(r);o==d(e)?a(t,...r,...s(r)):c(e[o])?E(n[o]?.(...r)??[],(t=>i(...r,t))):i(...r,e[o])};i()}))]})(),M=t=>{t!=A&&(A=t,R($,void 0,A))},P=a=>{(b&&y(a?.[0])?1===a?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===a?.[2]?t.applyChanges:t.setContent)(a)},_=async t=>(2!=A&&(M(1),h++,await U((async()=>{try{const t=await a();y(t)?P(t):v("Content is not an array "+t)}catch(a){r?.(a),t&&O(t)}M(0)}))),Y),F=()=>(f&&(i(f),f=void 0),Y),x=async t=>(1!=A&&(M(2),m++,await U((async()=>{try{await e(C,t)}catch(t){r?.(t)}M(0)}))),Y),j=()=>(l(g,t.delListener),g=void 0,Y),U=async(...t)=>(N(st(dt,w),...t),await(async()=>{if(!st(wt,w)){for(rt(wt,w,1);!c(p=T(st(dt,w)));)try{await p()}catch(t){r?.(t)}rt(wt,w,0)}})(),Y),Y={load:_,startAutoLoad:async t=>{await F().load(t);try{f=await s((async(t,a)=>{a||t?2!=A&&(M(1),h++,P(a??t),M(0)):await _()}))}catch(t){r?.(t)}return Y},stopAutoLoad:F,isAutoLoading:()=>!c(f),save:x,startAutoSave:async()=>(await j().save(),g=t.addDidFinishTransactionListener((()=>{const t=S();L(t)&&x(t)})),Y),stopAutoSave:j,isAutoSaving:()=>!c(g),getStatus:()=>A,addStatusListener:t=>I(t,$),delListener:a=>(D(a),t),schedule:U,getStore:()=>t,destroy:()=>(st(dt,w).splice(0,void 0),F().stopAutoSave()),getStats:()=>({loads:h,saves:m}),...u};return H(Y)},vt=(t,a,e,n,i,r,o,l)=>{const u=nt();return[async()=>{u.clear(),A(await e(t,a),(({tn:t,cn:a})=>ut(ot(u,t,lt),a)))},async(a,e)=>((t,a)=>j(st(u,t),a))(a,e)?K(m(A(await t(R+F(a)),(t=>{return[t[e],l?(a=V(t,e),n=l,K(W(a,((t,a)=>[a,n(t,a)])))):V(t,e)];var a,n})),(([t,a])=>!c(t)&&!tt(a)))):{},async(a,e,n,l,y,w=!1)=>{const d=lt();W(n??{},(t=>A(G(t??{}),(t=>ut(d,t)))));const v=U(d);if(!w&&y&&h(v)&&j(u,a))return await t("DROP "+L+F(a)),void rt(u,a);const f=st(u,a),E=lt(U(f));if(h(v)||(j(u,a)?await p(A([e,...v],(async(n,s)=>{J(E,n)||(await t(O+F(a)+"ADD"+F(n)+i),0==s&&await t("CREATE UNIQUE INDEX pk ON "+F(a)+`(${F(e)})`),ut(f,n))}))):(await t("CREATE "+L+F(a)+`(${F(e)}${i} PRIMARY KEY${g(A(v,(t=>s+F(t)+i)))});`),rt(u,a,lt([e,...v])))),await p([...!w&&l?A(U(E),(async n=>{n!=e&&(await t(O+F(a)+"DROP"+F(n)),J(f,n))})):[]]),w)c(n)?await t(I+F(a)+S+" true"):await p(W(n,(async(n,s)=>{c(n)?await t(I+F(a)+S+F(e)+"=$1",[s]):h(v)||await ft(t,a,e,G(n),[s,...o?A(X(n),o):X(n)],r)})));else if(h(v))j(u,a)&&await t(I+F(a)+S+" true");else{const s=m(U(st(u,a)),(t=>t!=e)),i=[],c=[];W(n??{},((t,a)=>{N(i,a,...A(s,(a=>o?o(t?.[a]):t?.[a]))),N(c,a)})),await ft(t,a,e,s,i,r),await t(I+F(a)+S+F(e)+`NOT IN(${x(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,i,r,o=0)=>await t("INSERT "+(o?"OR REPLACE ":n)+"INTO"+F(a)+"("+F(e)+g(A(i,(t=>s+F(t))))+")VALUES"+Et(r,d(i)+1)+(o?n:"ON CONFLICT("+F(e)+")DO UPDATE SET"+g(A(i,(t=>F(t)+"=excluded."+F(t))),s)),A(r,(t=>t??null))),Et=(t,a)=>g(f(d(t)/a,(t=>"("+g(f(a,(e=>"$"+(t*a+e+1))),s)+")")),s),gt=(t,a,e,n,s,i,r,[o,c,l],u,y,w,d,p,v)=>{const[f,E,g,A]=vt(a,u,y,s,p,v),h=pt(t,(async()=>await A((async()=>{return await f(),t=(await E(o,c))[$]?.[l]??"null",et(t,((t,a)=>""===a?void 0:a));var t}))),(async t=>await A((async()=>{var a;await f(),await g(o,c,{[$]:{[l]:(a=t()??null,at(a,((t,a)=>void 0===a?"":a)))}},!0,!0)}))),e,n,s,r,{[d]:()=>w,destroy:()=>(h.stopAutoLoad().stopAutoSave(),i(),h)},w);return h},At=(t,a,e,n,s,i,r,[o,l,[u,y,w]],d,v,f,E,g,A,h,N)=>{const[T,C,S,L]=vt(a,d,v,s,g,A,h,N),O=async(t,a)=>await p(it(l,(async([e,n,s,i],r)=>{a&&!(r in t)||await S(e,n,t[r],s,i,a)}))),I=async(t,a)=>y?await S(w,b,{[$]:t},!0,!0,a):null,R=pt(t,(async()=>await L((async()=>{await T();const t=await(async()=>K(m(await p(it(o,(async([t,a],e)=>[t,await C(e,a)]))),(t=>!tt(t[1])))))(),a=await(async()=>u?(await C(w,b))[$]:{})();return tt(t)&&c(a)?void 0:[t,a]}))),(async(t,a)=>await L((async()=>{if(await T(),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,r,{[E]:()=>f,destroy:()=>(R.stopAutoLoad().stopAutoSave(),i(),R)},f);return R},ht="ColumnName",mt="store",Nt="json",Tt=mt+"TableName",$t=mt+"Id"+ht,bt=mt+ht,Ct="autoLoadIntervalSeconds",St="rowId"+ht,Lt="tableId",Ot="tableName",It="deleteEmptyColumns",Rt="deleteEmptyTable",Dt={mode:Nt,[Ct]:1},Mt={load:0,save:0,[Ot]:e+"_values"},Pt=(t,a,e,n,s)=>{const i=nt();return W(t,((t,r)=>{const o=w(X(Q(a,u(t)?{[e]:t}:t)),0,Z(a));c(o[0])||n(r,o[0])||(s(r,o[0]),rt(i,r,o))})),i},_t=(t,a,s,i,r,c,l,y,d,p,v="getDb",f)=>{let E,g,A;const h=((t,a)=>a?async(e,n)=>(a(e,n),await t(e,n)):t)(s,c),[m,N,T,$]=(t=>{const a=(t=>Q(Dt,u(t)?{[Tt]:t}:t??{}))(t),n=a[Ct];if(a.mode==Nt){const t=a[Tt]??e;return[1,n,[t,a[$t]??b,a[bt]??mt],lt(t)]}const{tables:{load:s={},save:i={}}={},values:r={}}=a,o=w(X(Q(Mt,r)),0,Z(Mt)),c=o[2],l=lt(c),y=lt(c);return[0,n,[Pt(s,{[Lt]:null,[St]:b},Lt,(t=>j(y,t)),(t=>ut(l,t))),Pt(i,{[Ot]:null,[St]:b,[It]:0,[Rt]:0},Ot,((t,a)=>j(y,a)),((t,a)=>ut(l,a))),o],l]})(a);return(m?gt:At)(t,h,(t=>{let a;const e=()=>a=setInterval((async()=>{try{const[{d:a,s:e,c:n}]=await h(`${C} ${M} d,${P} s,TOTAL_CHANGES() c FROM ${D}${M} JOIN ${D}${P}`);a==E&&e==g&&n==A||(null!=E&&t(),E=a,g=e,A=n)}catch{}}),1e3*N),n=()=>{E=g=A=null,o(a)},s=i((a=>{$.has(a)&&(n(),t(),e())}));return e(),()=>{n(),r(s)}}),(t=>t()),l,y,d,T,U($),(async(t,a)=>await t(`${C} t.name tn,c.name cn FROM ${_}list()t,${_}info(t.name)c ${S} t.schema='main'AND t.type IN('table','view')AND t.name IN(${x(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)=>_t(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=>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=[])=>{let p,g,E,h=0,m=0,T=0;ot(yt,w,(()=>0)),ot(wt,w,(()=>[]));const $=et(),[b,S,C,L,O]=((t=1,a)=>1!=t&&a.isMergeable()?[1,a.getMergeableContent,a.getTransactionMergeableChanges,([[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),[I,D,R]=(()=>{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??=Y;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()}))]})(),M=t=>{t!=h&&(h=t,D($,void 0,h))},P=a=>{(b&&y(a?.[0])?1===a?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===a?.[2]?t.applyChanges:t.setContent)(a)},_=async t=>(2!=h&&(M(1),m++,await J((async()=>{try{const t=await a();y(t)?P(t):v("Content is not an array "+t)}catch(a){o?.(a),t&&O(t)}M(0)}))),Y),F=()=>(g&&(i(g),g=void 0),Y),x=async t=>(1!=h&&(M(2),T++,await J((async()=>{try{await e(S,t)}catch(t){o?.(t)}M(0)}))),Y),B=()=>(l(E,t.delListener),E=void 0,Y),J=async(...t)=>(A(nt(wt,w),...t),await(async()=>{if(!nt(yt,w)){for(it(yt,w,1);!c(p=N(nt(wt,w)));)try{await p()}catch(t){o?.(t)}it(yt,w,0)}})(),Y),Y={load:_,startAutoLoad:async t=>{await F().load(t);try{g=await s((async(t,a)=>{a||t?2!=h&&(M(1),m++,P(a??t),M(0)):await _()}))}catch(t){o?.(t)}return Y},stopAutoLoad:F,isAutoLoading:()=>!c(g),save:x,startAutoSave:async()=>(await B().save(),E=t.addDidFinishTransactionListener((()=>{const t=C();L(t)&&x(t)})),Y),stopAutoSave:B,isAutoSaving:()=>!c(E),getStatus:()=>h,addStatusListener:t=>I(t,$),delListener:a=>(R(a),t),schedule:J,getStore:()=>t,destroy:()=>(nt(wt,w).splice(0,void 0),F().stopAutoSave()),getStats:()=>({loads:m,saves:T}),...u};return G(Y)},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)},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)},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 +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),v=t=>{throw Error(t)},f=(t,a)=>A(Array(t).fill(0),((t,e)=>a(e))),E=(t,a)=>t.forEach(a),g=(t,a="")=>t.join(a),A=(t,a)=>t.map(a),h=t=>0==d(t),m=(t,a)=>t.filter(a),N=(t,...a)=>t.push(...a),T=t=>t.shift(),$="_",b="_id",C="SELECT",S="WHERE",L="TABLE",O="ALTER "+L,I="DELETE FROM",R=C+"*FROM",D="pragma_",M="data_version",P="schema_version",_="pragma_table_",F=t=>`"${t.replace(/"/g,'""')}"`,x=t=>g(A(t,((t,a)=>"$"+(a+1))),s),j=(t,a)=>t?.has(a)??!1,B=t=>c(t)||0==(t=>t?.size??0)(t),U=t=>[...t?.values()??[]],q=(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)=>A(z(t),(([t,e])=>a(e,t))),X=t=>Y.values(t),Z=t=>d(G(t)),tt=t=>(t=>!c(t)&&l(k(t),(t=>t==Y.prototype||c(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)=>A([...t?.entries()??[]],(([t,e])=>a(e,t))),rt=(t,a,e)=>c(e)?(J(t,a),t):t?.set(a,e),ot=(t,a,e,n)=>(j(t,a)?n?.(st(t,a)):rt(t,a,e()),st(t,a)),ct=(t,a,e,n,s=0)=>l((e?ot:st)(t,a[s],s>d(a)-2?e:nt),(i=>{if(s>d(a)-2)return n?.(i)&&rt(t,a[s]),i;const r=ct(i,a,e,n,s+1);return B(i)&&rt(t,a[s]),r})),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,r,o,u={},w=[])=>{let p,f,g,A=0,h=0,m=0;ot(wt,w,(()=>0)),ot(dt,w,(()=>[]));const $=nt(),[b,C,S,L,O]=((t=1,a)=>1!=t&&a.isMergeable()?[1,a.getMergeableContent,a.getTransactionMergeableChanges,([[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"))(o,t),[I,R,D]=(()=>{let t;const[a,e]=(()=>{const t=[];let a=0;return[e=>(e?T(t):null)??n+a++,a=>{yt.test(a)&&d(t)<1e3&&N(t,a)}]})(),s=nt();return[(e,i,r,o=[],c=()=>[])=>{t??=Y;const l=a(1);return rt(s,l,[e,i,r,o,c]),ut(ct(i,r??[n],lt),l),l},(a,e,...i)=>E(((t,a=[n])=>{const e=[],s=(t,n)=>n==d(a)?N(e,t):null===a[n]?q(t,(t=>s(t,n+1))):E([a[n],null],(a=>s(st(t,a),n+1)));return s(t,0),e})(a,e),(a=>q(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),B(a)?1:0))),rt(s,t),e(t),i))),a=>l(st(s,a),(([a,,e=[],n,s])=>{const i=(...r)=>{const o=d(r);o==d(e)?a(t,...r,...s(r)):c(e[o])?E(n[o]?.(...r)??[],(t=>i(...r,t))):i(...r,e[o])};i()}))]})(),M=t=>{t!=A&&(A=t,R($,void 0,A))},P=a=>{(b&&y(a?.[0])?1===a?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===a?.[2]?t.applyChanges:t.setContent)(a)},_=async t=>(2!=A&&(M(1),h++,await U((async()=>{try{const t=await a();y(t)?P(t):v("Content is not an array "+t)}catch(a){r?.(a),t&&O(t)}M(0)}))),Y),F=()=>(f&&(i(f),f=void 0),Y),x=async t=>(1!=A&&(M(2),m++,await U((async()=>{try{await e(C,t)}catch(t){r?.(t)}M(0)}))),Y),j=()=>(l(g,t.delListener),g=void 0,Y),U=async(...t)=>(N(st(dt,w),...t),await(async()=>{if(!st(wt,w)){for(rt(wt,w,1);!c(p=T(st(dt,w)));)try{await p()}catch(t){r?.(t)}rt(wt,w,0)}})(),Y),Y={load:_,startAutoLoad:async t=>{await F().load(t);try{f=await s((async(t,a)=>{a||t?2!=A&&(M(1),h++,P(a??t),M(0)):await _()}))}catch(t){r?.(t)}return Y},stopAutoLoad:F,isAutoLoading:()=>!c(f),save:x,startAutoSave:async()=>(await j().save(),g=t.addDidFinishTransactionListener((()=>{const t=S();L(t)&&x(t)})),Y),stopAutoSave:j,isAutoSaving:()=>!c(g),getStatus:()=>A,addStatusListener:t=>I(t,$),delListener:a=>(D(a),t),schedule:U,getStore:()=>t,destroy:()=>(st(dt,w).splice(0,void 0),F().stopAutoSave()),getStats:()=>({loads:h,saves:m}),...u};return H(Y)},vt=(t,a,e,n,i,r,o,l)=>{const u=nt();return[async()=>{u.clear(),A(await e(t,a),(({tn:t,cn:a})=>ut(ot(u,t,lt),a)))},async(a,e)=>((t,a)=>j(st(u,t),a))(a,e)?K(m(A(await t(R+F(a)),(t=>{return[t[e],l?(a=V(t,e),n=l,K(W(a,((t,a)=>[a,n(t,a)])))):V(t,e)];var a,n})),(([t,a])=>!c(t)&&!tt(a)))):{},async(a,e,n,l,y,w=!1)=>{const d=lt();W(n??{},(t=>A(G(t??{}),(t=>ut(d,t)))));const v=U(d);if(!w&&y&&h(v)&&j(u,a))return await t("DROP "+L+F(a)),void rt(u,a);const f=st(u,a),E=lt(U(f));if(h(v)||(j(u,a)?await p(A([e,...v],(async(n,s)=>{J(E,n)||(await t(O+F(a)+"ADD"+F(n)+i),0==s&&await t("CREATE UNIQUE INDEX pk ON "+F(a)+`(${F(e)})`),ut(f,n))}))):(await t("CREATE "+L+F(a)+`(${F(e)}${i} PRIMARY KEY${g(A(v,(t=>s+F(t)+i)))});`),rt(u,a,lt([e,...v])))),await p([...!w&&l?A(U(E),(async n=>{n!=e&&(await t(O+F(a)+"DROP"+F(n)),J(f,n))})):[]]),w)c(n)?await t(I+F(a)+S+" true"):await p(W(n,(async(n,s)=>{c(n)?await t(I+F(a)+S+F(e)+"=$1",[s]):h(v)||await ft(t,a,e,G(n),[s,...o?A(X(n),o):X(n)],r)})));else if(h(v))j(u,a)&&await t(I+F(a)+S+" true");else{const s=m(U(st(u,a)),(t=>t!=e)),i=[],c=[];W(n??{},((t,a)=>{N(i,a,...A(s,(a=>o?o(t?.[a]):t?.[a]))),N(c,a)})),await ft(t,a,e,s,i,r),await t(I+F(a)+S+F(e)+`NOT IN(${x(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,i,r,o=0)=>await t("INSERT "+(o?"OR REPLACE ":n)+"INTO"+F(a)+"("+F(e)+g(A(i,(t=>s+F(t))))+")VALUES"+Et(r,d(i)+1)+(o?n:"ON CONFLICT("+F(e)+")DO UPDATE SET"+g(A(i,(t=>F(t)+"=excluded."+F(t))),s)),A(r,(t=>t??null))),Et=(t,a)=>g(f(d(t)/a,(t=>"("+g(f(a,(e=>"$"+(t*a+e+1))),s)+")")),s),gt=(t,a,e,n,s,i,r,[o,c,l],u,y,w,d,p,v)=>{const[f,E,g,A]=vt(a,u,y,s,p,v),h=pt(t,(async()=>await A((async()=>{return await f(),t=(await E(o,c))[$]?.[l]??"null",et(t,((t,a)=>""===a?void 0:a));var t}))),(async t=>await A((async()=>{var a;await f(),await g(o,c,{[$]:{[l]:(a=t()??null,at(a,((t,a)=>void 0===a?"":a)))}},!0,!0)}))),e,n,s,r,{[d]:()=>w,destroy:()=>(h.stopAutoLoad().stopAutoSave(),i(),h)},w);return h},At=(t,a,e,n,s,i,r,[o,l,[u,y,w]],d,v,f,E,g,A,h,N)=>{const[T,C,S,L]=vt(a,d,v,s,g,A,h,N),O=async(t,a)=>await p(it(l,(async([e,n,s,i],r)=>{a&&!(r in t)||await S(e,n,t[r],s,i,a)}))),I=async(t,a)=>y?await S(w,b,{[$]:t},!0,!0,a):null,R=pt(t,(async()=>await L((async()=>{await T();const t=await(async()=>K(m(await p(it(o,(async([t,a],e)=>[t,await C(e,a)]))),(t=>!tt(t[1])))))(),a=await(async()=>u?(await C(w,b))[$]:{})();return tt(t)&&c(a)?void 0:[t,a]}))),(async(t,a)=>await L((async()=>{if(await T(),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,r,{[E]:()=>f,destroy:()=>(R.stopAutoLoad().stopAutoSave(),i(),R)},f);return R},ht="ColumnName",mt="store",Nt="json",Tt=mt+"TableName",$t=mt+"Id"+ht,bt=mt+ht,Ct="autoLoadIntervalSeconds",St="rowId"+ht,Lt="tableId",Ot="tableName",It="deleteEmptyColumns",Rt="deleteEmptyTable",Dt={mode:Nt,[Ct]:1},Mt={load:0,save:0,[Ot]:e+"_values"},Pt=(t,a,e,n,s)=>{const i=nt();return W(t,((t,r)=>{const o=w(X(Q(a,u(t)?{[e]:t}:t)),0,Z(a));c(o[0])||n(r,o[0])||(s(r,o[0]),rt(i,r,o))})),i},_t=(t,a,s,i,r,c,l,y,d,p,v="getDb",f)=>{let E,g,A;const h=((t,a)=>a?async(e,n)=>(a(e,n),await t(e,n)):t)(s,c),[m,N,T,$]=(t=>{const a=(t=>Q(Dt,u(t)?{[Tt]:t}:t??{}))(t),n=a[Ct];if(a.mode==Nt){const t=a[Tt]??e;return[1,n,[t,a[$t]??b,a[bt]??mt],lt(t)]}const{tables:{load:s={},save:i={}}={},values:r={}}=a,o=w(X(Q(Mt,r)),0,Z(Mt)),c=o[2],l=lt(c),y=lt(c);return[0,n,[Pt(s,{[Lt]:null,[St]:b},Lt,(t=>j(y,t)),(t=>ut(l,t))),Pt(i,{[Ot]:null,[St]:b,[It]:0,[Rt]:0},Ot,((t,a)=>j(y,a)),((t,a)=>ut(l,a))),o],l]})(a);return(m?gt:At)(t,h,(t=>{let a;const e=()=>a=setInterval((async()=>{try{const[{d:a,s:e,c:n}]=await h(`${C} ${M} d,${P} s,TOTAL_CHANGES() c FROM ${D}${M} JOIN ${D}${P}`);a==E&&e==g&&n==A||(null!=E&&t(),E=a,g=e,A=n)}catch{}}),1e3*N),n=()=>{E=g=A=null,o(a)},s=i((a=>{$.has(a)&&(n(),t(),e())}));return e(),()=>{n(),r(s)}}),(t=>t()),l,y,d,T,U($),(async(t,a)=>await t(`${C} t.name tn,c.name cn FROM ${_}list()t,${_}info(t.name)c ${S} t.schema='main'AND t.type IN('table','view')AND t.name IN(${x(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)=>_t(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=>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=[])=>{let p,g,E,h=0,m=0,T=0;ot(yt,w,(()=>0)),ot(wt,w,(()=>[]));const $=et(),[b,S,C,L,O]=((t=1,a)=>1!=t&&a.isMergeable()?[1,a.getMergeableContent,a.getTransactionMergeableChanges,([[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),[I,D,R]=(()=>{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??=Y;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()}))]})(),M=t=>{t!=h&&(h=t,D($,void 0,h))},P=a=>{(b&&y(a?.[0])?1===a?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===a?.[2]?t.applyChanges:t.setContent)(a)},_=async t=>(2!=h&&(M(1),m++,await J((async()=>{try{const t=await a();y(t)?P(t):v("Content is not an array "+t)}catch(a){o?.(a),t&&O(t)}M(0)}))),Y),F=()=>(g&&(i(g),g=void 0),Y),x=async t=>(1!=h&&(M(2),T++,await J((async()=>{try{await e(S,t)}catch(t){o?.(t)}M(0)}))),Y),B=()=>(l(E,t.delListener),E=void 0,Y),J=async(...t)=>(A(nt(wt,w),...t),await(async()=>{if(!nt(yt,w)){for(it(yt,w,1);!c(p=N(nt(wt,w)));)try{await p()}catch(t){o?.(t)}it(yt,w,0)}})(),Y),Y={load:_,startAutoLoad:async t=>{await F().load(t);try{g=await s((async(t,a)=>{a||t?2!=h&&(M(1),m++,P(a??t),M(0)):await _()}))}catch(t){o?.(t)}return Y},stopAutoLoad:F,isAutoLoading:()=>!c(g),save:x,startAutoSave:async()=>(await B().save(),E=t.addDidFinishTransactionListener((()=>{const t=C();L(t)&&x(t)})),Y),stopAutoSave:B,isAutoSaving:()=>!c(E),getStatus:()=>h,addStatusListener:t=>I(t,$),delListener:a=>(R(a),t),schedule:J,getStore:()=>t,destroy:()=>(nt(wt,w).splice(0,void 0),F().stopAutoSave()),getStats:()=>({loads:m,saves:T}),...u};return G(Y)},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)},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)},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 +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=t=>null==t,c=(t,a,e)=>o(t)?e?.():a(t),l=t=>a(t)==i,E=t=>Array.isArray(t),y=(t,a,e)=>t.slice(a,e),w=t=>t.length,d=async t=>r.all(t),u=t=>{throw Error(t)},T=(t,a)=>N(Array(t).fill(0),((t,e)=>a(e))),R=(t,a)=>t.forEach(a),A=(t,a="")=>t.join(a),N=(t,a)=>t.map(a),g=t=>0==w(t),p=(t,a)=>t.filter(a),C=(t,...a)=>t.push(...a),O=t=>t.shift(),f="_",L="_id",v="SELECT",$="WHERE",m="TABLE",I="ALTER "+m,S="DELETE FROM",h=v+"*FROM",_=t=>`"${t.replace(/"/g,'""')}"`,b=t=>A(N(t,((t,a)=>"$"+(a+1))),s),P=(t,a)=>t?.has(a)??!1,D=t=>o(t)||0==(t=>t?.size??0)(t),U=t=>[...t?.values()??[]],F=(t,a)=>t?.forEach(a),M=(t,a)=>t?.delete(a),G=Object,B=t=>G.getPrototypeOf(t),j=G.entries,x=G.keys,X=G.freeze,Y=(t=[])=>G.fromEntries(t),q=(...t)=>G.assign({},...t),H=(t,a)=>(delete t[a],t),W=(t,a)=>N(j(t),(([t,e])=>a(e,t))),k=t=>G.values(t),z=t=>w(x(t)),J=t=>(t=>!o(t)&&c(B(t),(t=>t==G.prototype||o(B(t))),(()=>!0)))(t)&&0==z(t),K=JSON.stringify,V=JSON.parse,Q=t=>new Map(t),Z=(t,a)=>t?.get(a),tt=(t,a)=>N([...t?.entries()??[]],(([t,e])=>a(e,t))),at=(t,a,e)=>o(e)?(M(t,a),t):t?.set(a,e),et=(t,a,e,n)=>(P(t,a)?n?.(Z(t,a)):at(t,a,e()),Z(t,a)),nt=(t,a,e,n,s=0)=>c((e?et:Z)(t,a[s],s>w(a)-2?e:Q),(i=>{if(s>w(a)-2)return n?.(i)&&at(t,a[s]),i;const r=nt(i,a,e,n,s+1);return D(i)&&at(t,a[s]),r})),st=t=>new Set(E(t)||o(t)?t:[t]),it=(t,a)=>t?.add(a),rt=/^\d+$/,ot=Q(),ct=Q(),lt=(t,a,e,s,i,r,l,y={},d=[])=>{let T,A,N,g=0,p=0,f=0;et(ot,d,(()=>0)),et(ct,d,(()=>[]));const L=Q(),[v,$,m,I,S]=((t=1,a)=>1!=t&&a.isMergeable()?[1,a.getMergeableContent,a.getTransactionMergeableChanges,([[t],[a]])=>!J(t)||!J(a),a.setDefaultContent]:2!=t?[0,a.getContent,a.getTransactionChanges,([t,a])=>!J(t)||!J(a),a.setContent]:u("Store type not supported by this Persister"))(l,t),[h,_,b]=(()=>{let t;const[a,e]=(()=>{const t=[];let a=0;return[e=>(e?O(t):null)??n+a++,a=>{rt.test(a)&&w(t)<1e3&&C(t,a)}]})(),s=Q();return[(e,i,r,o=[],c=()=>[])=>{t??=q;const l=a(1);return at(s,l,[e,i,r,o,c]),it(nt(i,r??[n],st),l),l},(a,e,...i)=>R(((t,a=[n])=>{const e=[],s=(t,n)=>n==w(a)?C(e,t):null===a[n]?F(t,(t=>s(t,n+1))):R([a[n],null],(a=>s(Z(t,a),n+1)));return s(t,0),e})(a,e),(a=>F(a,(a=>Z(s,a)[0](t,...e??[],...i))))),t=>c(Z(s,t),(([,a,i])=>(nt(a,i??[n],void 0,(a=>(M(a,t),D(a)?1:0))),at(s,t),e(t),i))),a=>c(Z(s,a),(([a,,e=[],n,s])=>{const i=(...r)=>{const c=w(r);c==w(e)?a(t,...r,...s(r)):o(e[c])?R(n[c]?.(...r)??[],(t=>i(...r,t))):i(...r,e[c])};i()}))]})(),P=t=>{t!=g&&(g=t,_(L,void 0,g))},U=a=>{(v&&E(a?.[0])?1===a?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===a?.[2]?t.applyChanges:t.setContent)(a)},G=async t=>(2!=g&&(P(1),p++,await Y((async()=>{try{const t=await a();E(t)?U(t):u("Content is not an array "+t)}catch(a){r?.(a),t&&S(t)}P(0)}))),q),B=()=>(A&&(i(A),A=void 0),q),j=async t=>(1!=g&&(P(2),f++,await Y((async()=>{try{await e($,t)}catch(t){r?.(t)}P(0)}))),q),x=()=>(c(N,t.delListener),N=void 0,q),Y=async(...t)=>(C(Z(ct,d),...t),await(async()=>{if(!Z(ot,d)){for(at(ot,d,1);!o(T=O(Z(ct,d)));)try{await T()}catch(t){r?.(t)}at(ot,d,0)}})(),q),q={load:G,startAutoLoad:async t=>{await B().load(t);try{A=await s((async(t,a)=>{a||t?2!=g&&(P(1),p++,U(a??t),P(0)):await G()}))}catch(t){r?.(t)}return q},stopAutoLoad:B,isAutoLoading:()=>!o(A),save:j,startAutoSave:async()=>(await x().save(),N=t.addDidFinishTransactionListener((()=>{const t=m();I(t)&&j(t)})),q),stopAutoSave:x,isAutoSaving:()=>!o(N),getStatus:()=>g,addStatusListener:t=>h(t,L),delListener:a=>(b(a),t),schedule:Y,getStore:()=>t,destroy:()=>(Z(ct,d).splice(0,void 0),B().stopAutoSave()),getStats:()=>({loads:p,saves:f}),...y};return X(q)},Et=(t,a,e,n,i,r,c,l)=>{const E=Q();return[async()=>{E.clear(),N(await e(t,a),(({tn:t,cn:a})=>it(et(E,t,st),a)))},async(a,e)=>((t,a)=>P(Z(E,t),a))(a,e)?Y(p(N(await t(h+_(a)),(t=>{return[t[e],l?(a=H(t,e),n=l,Y(W(a,((t,a)=>[a,n(t,a)])))):H(t,e)];var a,n})),(([t,a])=>!o(t)&&!J(a)))):{},async(a,e,n,l,y,w=!1)=>{const u=st();W(n??{},(t=>N(x(t??{}),(t=>it(u,t)))));const T=U(u);if(!w&&y&&g(T)&&P(E,a))return await t("DROP "+m+_(a)),void at(E,a);const R=Z(E,a),O=st(U(R));if(g(T)||(P(E,a)?await d(N([e,...T],(async(n,s)=>{M(O,n)||(await t(I+_(a)+"ADD"+_(n)+i),0==s&&await t("CREATE UNIQUE INDEX pk ON "+_(a)+`(${_(e)})`),it(R,n))}))):(await t("CREATE "+m+_(a)+`(${_(e)}${i} PRIMARY KEY${A(N(T,(t=>s+_(t)+i)))});`),at(E,a,st([e,...T])))),await d([...!w&&l?N(U(O),(async n=>{n!=e&&(await t(I+_(a)+"DROP"+_(n)),M(R,n))})):[]]),w)o(n)?await t(S+_(a)+$+" true"):await d(W(n,(async(n,s)=>{o(n)?await t(S+_(a)+$+_(e)+"=$1",[s]):g(T)||await yt(t,a,e,x(n),[s,...c?N(k(n),c):k(n)],r)})));else if(g(T))P(E,a)&&await t(S+_(a)+$+" true");else{const s=p(U(Z(E,a)),(t=>t!=e)),i=[],o=[];W(n??{},((t,a)=>{C(i,a,...N(s,(a=>c?c(t?.[a]):t?.[a]))),C(o,a)})),await yt(t,a,e,s,i,r),await t(S+_(a)+$+_(e)+`NOT IN(${b(o)})`,o)}},async a=>{let e;await t("BEGIN");try{e=await a()}catch(t){n?.(t)}return await t("END"),e}]},yt=async(t,a,e,i,r,o=0)=>await t("INSERT "+(o?"OR REPLACE ":n)+"INTO"+_(a)+"("+_(e)+A(N(i,(t=>s+_(t))))+")VALUES"+wt(r,w(i)+1)+(o?n:"ON CONFLICT("+_(e)+")DO UPDATE SET"+A(N(i,(t=>_(t)+"=excluded."+_(t))),s)),N(r,(t=>t??null))),wt=(t,a)=>A(T(w(t)/a,(t=>"("+A(T(a,(e=>"$"+(t*a+e+1))),s)+")")),s),dt=(t,a,e,n,s,i,r,[o,c,l],E,y,w,d,u,T)=>{const[R,A,N,g]=Et(a,E,y,s,u,T),p=lt(t,(async()=>await g((async()=>{return await R(),t=(await A(o,c))[f]?.[l]??"null",V(t,((t,a)=>""===a?void 0:a));var t}))),(async t=>await g((async()=>{var a;await R(),await N(o,c,{[f]:{[l]:(a=t()??null,K(a,((t,a)=>void 0===a?"":a)))}},!0,!0)}))),e,n,s,r,{[d]:()=>w,destroy:()=>(p.stopAutoLoad().stopAutoSave(),i(),p)},w);return p},ut=(t,a,e,n,s,i,r,[c,l,[E,y,w]],u,T,R,A,N,g,C,O)=>{const[v,$,m,I]=Et(a,u,T,s,N,g,C,O),S=async(t,a)=>await d(tt(l,(async([e,n,s,i],r)=>{a&&!(r in t)||await m(e,n,t[r],s,i,a)}))),h=async(t,a)=>y?await m(w,L,{[f]:t},!0,!0,a):null,_=lt(t,(async()=>await I((async()=>{await v();const t=await(async()=>Y(p(await d(tt(c,(async([t,a],e)=>[t,await $(e,a)]))),(t=>!J(t[1])))))(),a=await(async()=>E?(await $(w,L))[f]:{})();return J(t)&&o(a)?void 0:[t,a]}))),(async(t,a)=>await I((async()=>{if(await v(),o(a)){const[a,e]=t();await S(a),await h(e)}else await S(a[0],!0),await h(a[1],!0)}))),e,n,s,r,{[A]:()=>R,destroy:()=>(_.stopAutoLoad().stopAutoSave(),i(),_)},R);return _},Tt="ColumnName",Rt="store",At="json",Nt=Rt+"TableName",gt=Rt+"Id"+Tt,pt=Rt+Tt,Ct="autoLoadIntervalSeconds",Ot="rowId"+Tt,ft="tableId",Lt="tableName",vt="deleteEmptyColumns",$t="deleteEmptyTable",mt={mode:At,[Ct]:1},It={load:0,save:0,[Lt]:e+"_values"},St=(t,a,e,n,s)=>{const i=Q();return W(t,((t,r)=>{const c=y(k(q(a,l(t)?{[e]:t}:t)),0,z(a));o(c[0])||n(r,c[0])||(s(r,c[0]),at(i,r,c))})),i},ht=e,_t=/^([cd]:)(.+)/,bt=e+"_data",Pt=e+"_table";t.createPglitePersister=async(t,a,n,s,i)=>((t,a,n,s,i,r,o,E,w,u,T="getDb")=>{const R=((t,a)=>a?async(e,n)=>(a(e,n),await t(e,n)):t)(n,r),[A,,g,p]=(t=>{const a=(t=>q(mt,l(t)?{[Nt]:t}:t??{}))(t),n=a[Ct];if(a.mode==At){const t=a[Nt]??e;return[1,n,[t,a[gt]??L,a[pt]??Rt],st(t)]}const{tables:{load:s={},save:i={}}={},values:r={}}=a,o=y(k(q(It,r)),0,z(It)),c=o[2],E=st(c),w=st(c);return[0,n,[St(s,{[ft]:null,[Ot]:L},ft,(t=>P(w,t)),(t=>it(E,t))),St(i,{[Lt]:null,[Ot]:L,[vt]:0,[$t]:0},Lt,((t,a)=>P(w,a)),((t,a)=>it(E,a))),o],E]})(a),C=async t=>{await R(`CREATE OR REPLACE TRIGGER ${_(bt+"_"+t)} AFTER INSERT OR UPDATE OR DELETE ON ${_(t)} EXECUTE FUNCTION ${bt}()`)};return(A?dt:ut)(t,R,(async t=>{await R(`CREATE OR REPLACE FUNCTION ${Pt}()RETURNS event_trigger AS $t2$ DECLARE row record; BEGIN FOR row IN SELECT object_identity FROM pg_event_trigger_ddl_commands()WHERE command_tag='CREATE TABLE' LOOP PERFORM pg_notify('${ht}','c:'||SPLIT_PART(row.object_identity,'.',2));END LOOP;END;$t2$ LANGUAGE plpgsql;`);try{await R(`CREATE EVENT TRIGGER ${Pt} ON ddl_command_end WHEN TAG IN('CREATE TABLE')EXECUTE FUNCTION ${Pt}();`)}catch{}return await R(`CREATE OR REPLACE FUNCTION ${bt}()RETURNS trigger AS $t1$ BEGIN PERFORM pg_notify('${ht}','d:'||TG_TABLE_NAME);RETURN NULL;END;$t1$ LANGUAGE plpgsql;`),await d(N(U(p),(async t=>{await R(`CREATE TABLE IF NOT EXISTS ${_(t)}("_id"text PRIMARY KEY)`),await C(t)}))),await s(ht,(async a=>{return await c((e=a,n=_t,e?.match(n)),(async([,a,e])=>{P(p,e)&&("c:"==a&&await C(e),t())}));var e,n}))}),i,o,E,w,g,U(p),(async(t,a)=>await t(`${v} table_name tn,column_name cn FROM information_schema.columns ${$} table_schema='public'AND table_name IN(${b(a)})`,a)),u,T,"text",0,(t=>K(t)),(t=>V(t)))})(t,n,(async(t,e=[])=>(await a.query(t,e)).rows),(async(t,e)=>await a.listen(t,e)),(async t=>{try{await t()}catch(t){i?.(t)}}),s,i,(()=>0),3,a,"getPglite")},"object"==typeof exports&&"undefined"!=typeof module?a(exports):"function"==typeof define&&define.amd?define(["exports"],a):a((t="undefined"!=typeof globalThis?globalThis:t||self).TinyBasePersisterPglite={});
1
+ var t,a;t=this,a=function(t){"use strict";const a=t=>typeof t,e="tinybase",n=",",s=a(""),i=Promise,o=t=>null==t,r=(t,a,e)=>o(t)?e?.():a(t),c=t=>a(t)==s,l=t=>Array.isArray(t),E=(t,a,e)=>t.slice(a,e),y=t=>t.length,w=async t=>i.all(t),d=t=>{throw Error(t)},u=(t,a)=>t.forEach(a),T=(t,a="")=>t.join(a),R=(t,a)=>t.map(a),A=t=>0==y(t),N=(t,a)=>t.filter(a),g=(t,...a)=>t.push(...a),p=t=>t.shift(),C="_",O="_id",f="SELECT",v="WHERE",L="TABLE",$="ALTER "+L,m="DELETE FROM",I=f+"*FROM",S=t=>`"${t.replace(/"/g,'""')}"`,h=(t,a=[1])=>T(R(t,(()=>"$"+a[0]++)),n),_=(t,a)=>t?.has(a)??!1,b=t=>o(t)||0==(t=>t?.size??0)(t),P=t=>[...t?.values()??[]],D=(t,a)=>t?.forEach(a),U=(t,a)=>t?.delete(a),F=Object,M=t=>F.getPrototypeOf(t),G=F.entries,B=F.keys,j=F.freeze,x=(t=[])=>F.fromEntries(t),X=(...t)=>F.assign({},...t),Y=(t,a)=>(delete t[a],t),q=(t,a)=>R(G(t),(([t,e])=>a(e,t))),H=t=>F.values(t),W=t=>y(B(t)),k=t=>(t=>!o(t)&&r(M(t),(t=>t==F.prototype||o(M(t))),(()=>!0)))(t)&&0==W(t),z=JSON.stringify,J=JSON.parse,K=t=>new Map(t),V=(t,a)=>t?.get(a),Q=(t,a)=>R([...t?.entries()??[]],(([t,e])=>a(e,t))),Z=(t,a,e)=>o(e)?(U(t,a),t):t?.set(a,e),tt=(t,a,e,n)=>(_(t,a)?n?.(V(t,a)):Z(t,a,e()),V(t,a)),at=(t,a,e,n,s=0)=>r((e?tt:V)(t,a[s],s>y(a)-2?e:K),(i=>{if(s>y(a)-2)return n?.(i)&&Z(t,a[s]),i;const o=at(i,a,e,n,s+1);return b(i)&&Z(t,a[s]),o})),et=t=>new Set(l(t)||o(t)?t:[t]),nt=(t,a)=>t?.add(a),st=/^\d+$/,it=K(),ot=K(),rt=(t,a,e,n,s,i,c,E={},w=[])=>{let T,R,A,N=0,C=0,O=0;tt(it,w,(()=>0)),tt(ot,w,(()=>[]));const f=K(),[v,L,$,m,I]=((t=1,a)=>1!=t&&a.isMergeable()?[1,a.getMergeableContent,a.getTransactionMergeableChanges,([[t],[a]])=>!k(t)||!k(a),a.setDefaultContent]:2!=t?[0,a.getContent,a.getTransactionChanges,([t,a])=>!k(t)||!k(a),a.setContent]:d("Store type not supported by this Persister"))(c,t),[S,h,_]=(()=>{let t;const[a,e]=(()=>{const t=[];let a=0;return[e=>(e?p(t):null)??""+a++,a=>{st.test(a)&&y(t)<1e3&&g(t,a)}]})(),n=K();return[(e,s,i,o=[],r=()=>[])=>{t??=Y;const c=a(1);return Z(n,c,[e,s,i,o,r]),nt(at(s,i??[""],et),c),c},(a,e,...s)=>u(((t,a=[""])=>{const e=[],n=(t,s)=>s==y(a)?g(e,t):null===a[s]?D(t,(t=>n(t,s+1))):u([a[s],null],(a=>n(V(t,a),s+1)));return n(t,0),e})(a,e),(a=>D(a,(a=>V(n,a)[0](t,...e??[],...s))))),t=>r(V(n,t),(([,a,s])=>(at(a,s??[""],void 0,(a=>(U(a,t),b(a)?1:0))),Z(n,t),e(t),s))),a=>r(V(n,a),(([a,,e=[],n,s])=>{const i=(...r)=>{const c=y(r);c==y(e)?a(t,...r,...s(r)):o(e[c])?u(n[c]?.(...r)??[],(t=>i(...r,t))):i(...r,e[c])};i()}))]})(),P=t=>{t!=N&&(N=t,h(f,void 0,N))},F=a=>{(v&&l(a?.[0])?1===a?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===a?.[2]?t.applyChanges:t.setContent)(a)},M=async t=>(2!=N&&(P(1),C++,await X((async()=>{try{const t=await a();l(t)?F(t):d("Content is not an array "+t)}catch(a){i?.(a),t&&I(t)}P(0)}))),Y),G=()=>(R&&(s(R),R=void 0),Y),B=async t=>(1!=N&&(P(2),O++,await X((async()=>{try{await e(L,t)}catch(t){i?.(t)}P(0)}))),Y),x=()=>(r(A,t.delListener),A=void 0,Y),X=async(...t)=>(g(V(ot,w),...t),await(async()=>{if(!V(it,w)){for(Z(it,w,1);!o(T=p(V(ot,w)));)try{await T()}catch(t){i?.(t)}Z(it,w,0)}})(),Y),Y={load:M,startAutoLoad:async t=>{await G().load(t);try{R=await n((async(t,a)=>{a||t?2!=N&&(P(1),C++,F(a??t),P(0)):await M()}))}catch(t){i?.(t)}return Y},stopAutoLoad:G,isAutoLoading:()=>!o(R),save:B,startAutoSave:async()=>(await x().save(),A=t.addDidFinishTransactionListener((()=>{const t=$();m(t)&&B(t)})),Y),stopAutoSave:x,isAutoSaving:()=>!o(A),getStatus:()=>N,addStatusListener:t=>S(t,f),delListener:a=>(_(a),t),schedule:X,getStore:()=>t,destroy:()=>(V(ot,w).splice(0,void 0),G().stopAutoSave()),getStats:()=>({loads:C,saves:O}),...E};return j(Y)},ct=(t,a,e,s,i,r=lt,c,l)=>{const E=K();return[async()=>{E.clear(),R(await e(t,a),(({tn:t,cn:a})=>nt(tt(E,t,et),a)))},async(a,e)=>((t,a)=>_(V(E,t),a))(a,e)?x(N(R(await t(I+S(a)),(t=>{return[t[e],l?(a=Y(t,e),n=l,x(q(a,((t,a)=>[a,n(t,a)])))):Y(t,e)];var a,n})),(([t,a])=>!o(t)&&!k(a)))):{},async(a,e,s,l,y,d=!1)=>{const u=et();q(s??{},(t=>R(B(t??{}),(t=>nt(u,t)))));const p=P(u);if(!d&&y&&A(p)&&_(E,a))return await t("DROP "+L+S(a)),void Z(E,a);const C=V(E,a),O=et(P(C));if(A(p)||(_(E,a)?await w(R([e,...p],(async(n,s)=>{U(O,n)||(await t($+S(a)+"ADD"+S(n)+i),0==s&&await t("CREATE UNIQUE INDEX pk ON "+S(a)+`(${S(e)})`),nt(C,n))}))):(await t("CREATE "+L+S(a)+`(${S(e)}${i} PRIMARY KEY${T(R(p,(t=>n+S(t)+i)))});`),Z(E,a,et([e,...p])))),await w([...!d&&l?R(P(O),(async n=>{n!=e&&(await t($+S(a)+"DROP"+S(n)),U(C,n))})):[]]),d)o(s)?await t(m+S(a)+v+" true"):await w(q(s,(async(n,s)=>{o(n)?await t(m+S(a)+v+S(e)+"=$1",[s]):A(p)||await r(t,a,e,B(n),{[s]:c?R(H(n),c):H(n)},C)})));else if(A(p))_(E,a)&&await t(m+S(a)+v+" true");else{const n=N(P(V(E,a)),(t=>t!=e)),i={},o=[];q(s??{},((t,a)=>{i[a]=R(n,(a=>c?c(t?.[a]):t?.[a])),g(o,a)})),await r(t,a,e,n,i),await t(m+S(a)+v+S(e)+`NOT IN(${h(o)})`,o)}},async a=>{let e;await t("BEGIN");try{e=await a()}catch(t){s?.(t)}return await t("END"),e}]},lt=async(t,a,e,s,i)=>{const o=[1];await t("INSERT INTO"+S(a)+"("+((...t)=>T(R(t,S),n))(e,...s)+")VALUES"+T(q(i,(t=>"($"+o[0]+++","+h(t,o)+")")),n)+"ON CONFLICT("+S(e)+")DO UPDATE SET"+T(R(s,(t=>S(t)+"=excluded."+S(t))),n),q(i,((t,a)=>[a,...R(t,(t=>t??null))])).flat())},Et=(t,a,e,n,s,i,o,[r,c,l],E,y,w,d,u,T)=>{const[R,A,N,g]=ct(a,E,y,s,u,T),p=rt(t,(async()=>await g((async()=>{return await R(),t=(await A(r,c))[C]?.[l]??"null",J(t,((t,a)=>""===a?void 0:a));var t}))),(async t=>await g((async()=>{var a;await R(),await N(r,c,{[C]:{[l]:(a=t()??null,z(a,((t,a)=>void 0===a?"":a)))}},!0,!0)}))),e,n,s,o,{[d]:()=>w,destroy:()=>(p.stopAutoLoad().stopAutoSave(),i(),p)},w);return p},yt=(t,a,e,n,s,i,r,[c,l,[E,y,d]],u,T,R,A,g,p,f,v)=>{const[L,$,m,I]=ct(a,u,T,s,g,p,f,v),S=async(t,a)=>await w(Q(l,(async([e,n,s,i],o)=>{a&&!(o in t)||await m(e,n,t[o],s,i,a)}))),h=async(t,a)=>y?await m(d,O,{[C]:t},!0,!0,a):null,_=rt(t,(async()=>await I((async()=>{await L();const t=await(async()=>x(N(await w(Q(c,(async([t,a],e)=>[t,await $(e,a)]))),(t=>!k(t[1])))))(),a=await(async()=>E?(await $(d,O))[C]:{})();return k(t)&&o(a)?void 0:[t,a]}))),(async(t,a)=>await I((async()=>{if(await L(),o(a)){const[a,e]=t();await S(a),await h(e)}else await S(a[0],!0),await h(a[1],!0)}))),e,n,s,r,{[A]:()=>R,destroy:()=>(_.stopAutoLoad().stopAutoSave(),i(),_)},R);return _},wt="ColumnName",dt="store",ut="json",Tt=dt+"TableName",Rt=dt+"Id"+wt,At=dt+wt,Nt="autoLoadIntervalSeconds",gt="rowId"+wt,pt="tableId",Ct="tableName",Ot="deleteEmptyColumns",ft="deleteEmptyTable",vt={mode:ut,[Nt]:1},Lt={load:0,save:0,[Ct]:e+"_values"},$t=(t,a,e,n,s)=>{const i=K();return q(t,((t,r)=>{const l=E(H(X(a,c(t)?{[e]:t}:t)),0,W(a));o(l[0])||n(r,l[0])||(s(r,l[0]),Z(i,r,l))})),i},mt=e,It=/^([cd]:)(.+)/,St=e+"_data",ht=e+"_table";t.createPglitePersister=async(t,a,n,s,i)=>((t,a,n,s,i,o,l,y,d,u,T="getDb")=>{const A=((t,a)=>a?async(e,n)=>(a(e,n),await t(e,n)):t)(n,o),[N,,g,p]=(t=>{const a=(t=>X(vt,c(t)?{[Tt]:t}:t??{}))(t),n=a[Nt];if(a.mode==ut){const t=a[Tt]??e;return[1,n,[t,a[Rt]??O,a[At]??dt],et(t)]}const{tables:{load:s={},save:i={}}={},values:o={}}=a,r=E(H(X(Lt,o)),0,W(Lt)),l=r[2],y=et(l),w=et(l);return[0,n,[$t(s,{[pt]:null,[gt]:O},pt,(t=>_(w,t)),(t=>nt(y,t))),$t(i,{[Ct]:null,[gt]:O,[Ot]:0,[ft]:0},Ct,((t,a)=>_(w,a)),((t,a)=>nt(y,a))),r],y]})(a),C=async t=>{await A(`CREATE OR REPLACE TRIGGER ${S(St+"_"+t)} AFTER INSERT OR UPDATE OR DELETE ON ${S(t)} EXECUTE FUNCTION ${St}()`)};return(N?Et:yt)(t,A,(async t=>{await A(`CREATE OR REPLACE FUNCTION ${ht}()RETURNS event_trigger AS $t2$ DECLARE row record; BEGIN FOR row IN SELECT object_identity FROM pg_event_trigger_ddl_commands()WHERE command_tag='CREATE TABLE' LOOP PERFORM pg_notify('${mt}','c:'||SPLIT_PART(row.object_identity,'.',2));END LOOP;END;$t2$ LANGUAGE plpgsql;`);try{await A(`CREATE EVENT TRIGGER ${ht} ON ddl_command_end WHEN TAG IN('CREATE TABLE')EXECUTE FUNCTION ${ht}();`)}catch{}return await A(`CREATE OR REPLACE FUNCTION ${St}()RETURNS trigger AS $t1$ BEGIN PERFORM pg_notify('${mt}','d:'||TG_TABLE_NAME);RETURN NULL;END;$t1$ LANGUAGE plpgsql;`),await w(R(P(p),(async t=>{await A(`CREATE TABLE IF NOT EXISTS ${S(t)}("_id"text PRIMARY KEY)`),await C(t)}))),await s(mt,(async a=>{return await r((e=a,n=It,e?.match(n)),(async([,a,e])=>{_(p,e)&&("c:"==a&&await C(e),t())}));var e,n}))}),i,l,y,d,g,P(p),(async(t,a)=>await t(`${f} table_name tn,column_name cn FROM information_schema.columns ${v} table_schema='public'AND table_name IN(${h(a)})`,a)),u,T,"text",void 0,(t=>z(t)),(t=>J(t)))})(t,n,(async(t,e=[])=>(await a.query(t,e)).rows),(async(t,e)=>await a.listen(t,e)),(async t=>{try{await t()}catch(t){i?.(t)}}),s,i,(()=>0),3,a,"getPglite")},"object"==typeof exports&&"undefined"!=typeof module?a(exports):"function"==typeof define&&define.amd?define(["exports"],a):a((t="undefined"!=typeof globalThis?globalThis:t||self).TinyBasePersisterPglite={});