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
- "use strict";const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),i=Promise,r=clearInterval,o=a=>null==a,c=(a,t,e)=>o(a)?e?.():t(a),l=t=>a(t)==s,u=a=>Array.isArray(a),w=(a,t,e)=>a.slice(t,e),y=a=>a.length,d=async a=>i.all(a),v=a=>{throw Error(a)},E=(a,t)=>A(Array(a).fill(0),((a,e)=>t(e))),p=(a,t)=>a.forEach(t),g=(a,t="")=>a.join(t),A=(a,t)=>a.map(t),h=a=>0==y(a),m=(a,t)=>a.filter(t),f=(a,...t)=>a.push(...t),C=a=>a.shift(),N="_",$="_id",S="SELECT",b="WHERE",O="TABLE",T="ALTER "+O,L="DELETE FROM",I=S+"*FROM",R="pragma_",D="data_version",M="schema_version",P="pragma_table_",_=a=>`"${a.replace(/"/g,'""')}"`,F=a=>g(A(a,((a,t)=>"$"+(t+1))),n),U=(a,t)=>a?.has(t)??!1,j=a=>o(a)||0==(a=>a?.size??0)(a),B=a=>[...a?.values()??[]],J=(a,t)=>a?.forEach(t),Y=(a,t)=>a?.delete(t),k=Object,q=a=>k.getPrototypeOf(a),x=k.entries,z=k.keys,G=k.freeze,H=(a=[])=>k.fromEntries(a),K=(...a)=>k.assign({},...a),Q=(a,t)=>(delete a[t],a),V=(a,t)=>A(x(a),(([a,e])=>t(e,a))),W=a=>k.values(a),X=a=>y(z(a)),Z=a=>(a=>!o(a)&&c(q(a),(a=>a==k.prototype||o(q(a))),(()=>!0)))(a)&&0==X(a),aa=JSON.stringify,ta=JSON.parse,ea=a=>new Map(a),na=(a,t)=>a?.get(t),sa=(a,t)=>A([...a?.entries()??[]],(([a,e])=>t(e,a))),ia=(a,t,e)=>o(e)?(Y(a,t),a):a?.set(t,e),ra=(a,t,e,n)=>(U(a,t)?n?.(na(a,t)):ia(a,t,e()),na(a,t)),oa=(a,t,e,n,s=0)=>c((e?ra:na)(a,t[s],s>y(t)-2?e:ea),(i=>{if(s>y(t)-2)return n?.(i)&&ia(a,t[s]),i;const r=oa(i,t,e,n,s+1);return j(i)&&ia(a,t[s]),r})),ca=a=>new Set(u(a)||o(a)?a:[a]),la=(a,t)=>a?.add(t),ua=/^\d+$/,wa=ea(),ya=ea(),da=(a,t,n,s,i,r,l,w={},d=[])=>{let E,g,A,h=0,m=0,N=0;ra(wa,d,(()=>0)),ra(ya,d,(()=>[]));const $=ea(),[S,b,O,T,L]=((a=1,t)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,t.getTransactionMergeableChanges,([[a],[t]])=>!Z(a)||!Z(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!Z(a)||!Z(t),t.setContent]:v("Store type not supported by this Persister"))(l,a),[I,R,D]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?C(a):null)??e+t++,t=>{ua.test(t)&&y(a)<1e3&&f(a,t)}]})(),s=ea();return[(n,i,r,o=[],c=()=>[])=>{a??=q;const l=t(1);return ia(s,l,[n,i,r,o,c]),la(oa(i,r??[e],ca),l),l},(t,n,...i)=>p(((a,t=[e])=>{const n=[],s=(a,e)=>e==y(t)?f(n,a):null===t[e]?J(a,(a=>s(a,e+1))):p([t[e],null],(t=>s(na(a,t),e+1)));return s(a,0),n})(t,n),(t=>J(t,(t=>na(s,t)[0](a,...n??[],...i))))),a=>c(na(s,a),(([,t,i])=>(oa(t,i??[e],void 0,(t=>(Y(t,a),j(t)?1:0))),ia(s,a),n(a),i))),t=>c(na(s,t),(([t,,e=[],n,s])=>{const i=(...r)=>{const c=y(r);c==y(e)?t(a,...r,...s(r)):o(e[c])?p(n[c]?.(...r)??[],(a=>i(...r,a))):i(...r,e[c])};i()}))]})(),M=a=>{a!=h&&(h=a,R($,void 0,h))},P=t=>{(S&&u(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},_=async a=>(2!=h&&(M(1),m++,await k((async()=>{try{const a=await t();u(a)?P(a):v("Content is not an array "+a)}catch(t){r?.(t),a&&L(a)}M(0)}))),q),F=()=>(g&&(i(g),g=void 0),q),U=async a=>(1!=h&&(M(2),N++,await k((async()=>{try{await n(b,a)}catch(a){r?.(a)}M(0)}))),q),B=()=>(c(A,a.delListener),A=void 0,q),k=async(...a)=>(f(na(ya,d),...a),await(async()=>{if(!na(wa,d)){for(ia(wa,d,1);!o(E=C(na(ya,d)));)try{await E()}catch(a){r?.(a)}ia(wa,d,0)}})(),q),q={load:_,startAutoLoad:async a=>{await F().load(a);try{g=await s((async(a,t)=>{t||a?2!=h&&(M(1),m++,P(t??a),M(0)):await _()}))}catch(a){r?.(a)}return q},stopAutoLoad:F,isAutoLoading:()=>!o(g),save:U,startAutoSave:async()=>(await B().save(),A=a.addDidFinishTransactionListener((()=>{const a=O();T(a)&&U(a)})),q),stopAutoSave:B,isAutoSaving:()=>!o(A),getStatus:()=>h,addStatusListener:a=>I(a,$),delListener:t=>(D(t),a),schedule:k,getStore:()=>a,destroy:()=>(na(ya,d).splice(0,void 0),F().stopAutoSave()),getStats:()=>({loads:m,saves:N}),...w};return G(q)},va=(a,t,e,s,i,r,c,l)=>{const u=ea();return[async()=>{u.clear(),A(await e(a,t),(({tn:a,cn:t})=>la(ra(u,a,ca),t)))},async(t,e)=>((a,t)=>U(na(u,a),t))(t,e)?H(m(A(await a(I+_(t)),(a=>{return[a[e],l?(t=Q(a,e),n=l,H(V(t,((a,t)=>[t,n(a,t)])))):Q(a,e)];var t,n})),(([a,t])=>!o(a)&&!Z(t)))):{},async(t,e,s,l,w,y=!1)=>{const v=ca();V(s??{},(a=>A(z(a??{}),(a=>la(v,a)))));const E=B(v);if(!y&&w&&h(E)&&U(u,t))return await a("DROP "+O+_(t)),void ia(u,t);const p=na(u,t),C=ca(B(p));if(h(E)||(U(u,t)?await d(A([e,...E],(async(n,s)=>{Y(C,n)||(await a(T+_(t)+"ADD"+_(n)+i),0==s&&await a("CREATE UNIQUE INDEX pk ON "+_(t)+`(${_(e)})`),la(p,n))}))):(await a("CREATE "+O+_(t)+`(${_(e)}${i} PRIMARY KEY${g(A(E,(a=>n+_(a)+i)))});`),ia(u,t,ca([e,...E])))),await d([...!y&&l?A(B(C),(async n=>{n!=e&&(await a(T+_(t)+"DROP"+_(n)),Y(p,n))})):[]]),y)o(s)?await a(L+_(t)+b+" true"):await d(V(s,(async(n,s)=>{o(n)?await a(L+_(t)+b+_(e)+"=$1",[s]):h(E)||await Ea(a,t,e,z(n),[s,...c?A(W(n),c):W(n)],r)})));else if(h(E))U(u,t)&&await a(L+_(t)+b+" true");else{const n=m(B(na(u,t)),(a=>a!=e)),i=[],o=[];V(s??{},((a,t)=>{f(i,t,...A(n,(t=>c?c(a?.[t]):a?.[t]))),f(o,t)})),await Ea(a,t,e,n,i,r),await a(L+_(t)+b+_(e)+`NOT IN(${F(o)})`,o)}},async t=>{let e;await a("BEGIN");try{e=await t()}catch(a){s?.(a)}return await a("END"),e}]},Ea=async(a,t,s,i,r,o=0)=>await a("INSERT "+(o?"OR REPLACE ":e)+"INTO"+_(t)+"("+_(s)+g(A(i,(a=>n+_(a))))+")VALUES"+pa(r,y(i)+1)+(o?e:"ON CONFLICT("+_(s)+")DO UPDATE SET"+g(A(i,(a=>_(a)+"=excluded."+_(a))),n)),A(r,(a=>a??null))),pa=(a,t)=>g(E(y(a)/t,(a=>"("+g(E(t,(e=>"$"+(a*t+e+1))),n)+")")),n),ga=(a,t,e,n,s,i,r,[o,c,l],u,w,y,d,v,E)=>{const[p,g,A,h]=va(t,u,w,s,v,E),m=da(a,(async()=>await h((async()=>{return await p(),a=(await g(o,c))[N]?.[l]??"null",ta(a,((a,t)=>""===t?void 0:t));var a}))),(async a=>await h((async()=>{var t;await p(),await A(o,c,{[N]:{[l]:(t=a()??null,aa(t,((a,t)=>void 0===t?"":t)))}},!0,!0)}))),e,n,s,r,{[d]:()=>y,destroy:()=>(m.stopAutoLoad().stopAutoSave(),i(),m)},y);return m},Aa=(a,t,e,n,s,i,r,[c,l,[u,w,y]],v,E,p,g,A,h,f,C)=>{const[S,b,O,T]=va(t,v,E,s,A,h,f,C),L=async(a,t)=>await d(sa(l,(async([e,n,s,i],r)=>{t&&!(r in a)||await O(e,n,a[r],s,i,t)}))),I=async(a,t)=>w?await O(y,$,{[N]:a},!0,!0,t):null,R=da(a,(async()=>await T((async()=>{await S();const a=await(async()=>H(m(await d(sa(c,(async([a,t],e)=>[a,await b(e,t)]))),(a=>!Z(a[1])))))(),t=await(async()=>u?(await b(y,$))[N]:{})();return Z(a)&&o(t)?void 0:[a,t]}))),(async(a,t)=>await T((async()=>{if(await S(),o(t)){const[t,e]=a();await L(t),await I(e)}else await L(t[0],!0),await I(t[1],!0)}))),e,n,s,r,{[g]:()=>p,destroy:()=>(R.stopAutoLoad().stopAutoSave(),i(),R)},p);return R},ha="ColumnName",ma="store",fa="json",Ca=ma+"TableName",Na=ma+"Id"+ha,$a=ma+ha,Sa="autoLoadIntervalSeconds",ba="rowId"+ha,Oa="tableId",Ta="tableName",La="deleteEmptyColumns",Ia="deleteEmptyTable",Ra={mode:fa,[Sa]:1},Da={load:0,save:0,[Ta]:t+"_values"},Ma=(a,t,e,n,s)=>{const i=ea();return V(a,((a,r)=>{const c=w(W(K(t,l(a)?{[e]:a}:a)),0,X(t));o(c[0])||n(r,c[0])||(s(r,c[0]),ia(i,r,c))})),i},Pa=(a,n,s,i,o,c,u,y,d,v,E="getDb",p)=>{let g,A,h;const m=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,c),[f,C,N,O]=(a=>{const e=(a=>K(Ra,l(a)?{[Ca]:a}:a??{}))(a),n=e[Sa];if(e.mode==fa){const a=e[Ca]??t;return[1,n,[a,e[Na]??$,e[$a]??ma],ca(a)]}const{tables:{load:s={},save:i={}}={},values:r={}}=e,o=w(W(K(Da,r)),0,X(Da)),c=o[2],u=ca(c),y=ca(c);return[0,n,[Ma(s,{[Oa]:null,[ba]:$},Oa,(a=>U(y,a)),(a=>la(u,a))),Ma(i,{[Ta]:null,[ba]:$,[La]:0,[Ia]:0},Ta,((a,t)=>U(y,t)),((a,t)=>la(u,t))),o],u]})(n);return(f?ga:Aa)(a,m,(a=>{let t;const e=()=>t=setInterval((async()=>{try{const[{d:t,s:e,c:n}]=await m(`${S} ${D} d,${M} s,TOTAL_CHANGES() c FROM ${R}${D} JOIN ${R}${M}`);t==g&&e==A&&n==h||(null!=g&&a(),g=t,A=e,h=n)}catch{}}),1e3*C),n=()=>{g=A=h=null,r(t)},s=i((t=>{O.has(t)&&(n(),a(),e())}));return e(),()=>{n(),o(s)}}),(a=>a()),u,y,d,N,B(O),(async(a,t)=>await a(`${S} t.name tn,c.name cn FROM ${P}list()t,${P}info(t.name)c ${b} t.schema='main'AND t.type IN('table','view')AND t.name IN(${F(t)})ORDER BY t.name,c.name`,t)),v,E,e,p,(a=>!0===a?1:!1===a?0:a),void 0)};exports.createElectricSqlPersister=(a,t,e,n,s)=>Pa(a,e,(async(a,e=[])=>await t.db.raw({sql:a,args:e})),(a=>t.notifier.subscribeToDataChanges((e=>p(t.notifier.alias(e),(({tablename:t})=>a(t)))))),(a=>a()),n,s,(()=>0),1,t,"getElectricClient");
1
+ "use strict";const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),i=Promise,r=clearInterval,o=a=>null==a,c=(a,t,e)=>o(a)?e?.():t(a),l=t=>a(t)==s,u=a=>Array.isArray(a),w=(a,t,e)=>a.slice(t,e),y=a=>a.length,d=async a=>i.all(a),v=a=>{throw Error(a)},E=(a,t)=>a.forEach(t),p=(a,t="")=>a.join(t),g=(a,t)=>a.map(t),A=a=>0==y(a),h=(a,t)=>a.filter(t),m=(a,...t)=>a.push(...t),f=a=>a.shift(),N="_",$="_id",C="SELECT",S="WHERE",b="TABLE",T="ALTER "+b,O="DELETE FROM",I=C+"*FROM",L="pragma_",D="data_version",R="schema_version",M="pragma_table_",_=a=>`"${a.replace(/"/g,'""')}"`,P=(a,t=[1])=>p(g(a,(()=>"$"+t[0]++)),n),F=(a,t)=>a?.has(t)??!1,U=a=>o(a)||0==(a=>a?.size??0)(a),j=a=>[...a?.values()??[]],B=(a,t)=>a?.forEach(t),J=(a,t)=>a?.delete(t),Y=Object,k=a=>Y.getPrototypeOf(a),q=Y.entries,x=Y.keys,z=Y.freeze,G=(a=[])=>Y.fromEntries(a),H=(...a)=>Y.assign({},...a),K=(a,t)=>(delete a[t],a),Q=(a,t)=>g(q(a),(([a,e])=>t(e,a))),V=a=>Y.values(a),W=a=>y(x(a)),X=a=>(a=>!o(a)&&c(k(a),(a=>a==Y.prototype||o(k(a))),(()=>!0)))(a)&&0==W(a),Z=JSON.stringify,aa=JSON.parse,ta=a=>new Map(a),ea=(a,t)=>a?.get(t),na=(a,t)=>g([...a?.entries()??[]],(([a,e])=>t(e,a))),sa=(a,t,e)=>o(e)?(J(a,t),a):a?.set(t,e),ia=(a,t,e,n)=>(F(a,t)?n?.(ea(a,t)):sa(a,t,e()),ea(a,t)),ra=(a,t,e,n,s=0)=>c((e?ia:ea)(a,t[s],s>y(t)-2?e:ta),(i=>{if(s>y(t)-2)return n?.(i)&&sa(a,t[s]),i;const r=ra(i,t,e,n,s+1);return U(i)&&sa(a,t[s]),r})),oa=a=>new Set(u(a)||o(a)?a:[a]),ca=(a,t)=>a?.add(t),la=/^\d+$/,ua=ta(),wa=ta(),ya=(a,t,n,s,i,r,l,w={},d=[])=>{let p,g,A,h=0,N=0,$=0;ia(ua,d,(()=>0)),ia(wa,d,(()=>[]));const C=ta(),[S,b,T,O,I]=((a=1,t)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,t.getTransactionMergeableChanges,([[a],[t]])=>!X(a)||!X(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!X(a)||!X(t),t.setContent]:v("Store type not supported by this Persister"))(l,a),[L,D,R]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?f(a):null)??e+t++,t=>{la.test(t)&&y(a)<1e3&&m(a,t)}]})(),s=ta();return[(n,i,r,o=[],c=()=>[])=>{a??=q;const l=t(1);return sa(s,l,[n,i,r,o,c]),ca(ra(i,r??[e],oa),l),l},(t,n,...i)=>E(((a,t=[e])=>{const n=[],s=(a,e)=>e==y(t)?m(n,a):null===t[e]?B(a,(a=>s(a,e+1))):E([t[e],null],(t=>s(ea(a,t),e+1)));return s(a,0),n})(t,n),(t=>B(t,(t=>ea(s,t)[0](a,...n??[],...i))))),a=>c(ea(s,a),(([,t,i])=>(ra(t,i??[e],void 0,(t=>(J(t,a),U(t)?1:0))),sa(s,a),n(a),i))),t=>c(ea(s,t),(([t,,e=[],n,s])=>{const i=(...r)=>{const c=y(r);c==y(e)?t(a,...r,...s(r)):o(e[c])?E(n[c]?.(...r)??[],(a=>i(...r,a))):i(...r,e[c])};i()}))]})(),M=a=>{a!=h&&(h=a,D(C,void 0,h))},_=t=>{(S&&u(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},P=async a=>(2!=h&&(M(1),N++,await k((async()=>{try{const a=await t();u(a)?_(a):v("Content is not an array "+a)}catch(t){r?.(t),a&&I(a)}M(0)}))),q),F=()=>(g&&(i(g),g=void 0),q),j=async a=>(1!=h&&(M(2),$++,await k((async()=>{try{await n(b,a)}catch(a){r?.(a)}M(0)}))),q),Y=()=>(c(A,a.delListener),A=void 0,q),k=async(...a)=>(m(ea(wa,d),...a),await(async()=>{if(!ea(ua,d)){for(sa(ua,d,1);!o(p=f(ea(wa,d)));)try{await p()}catch(a){r?.(a)}sa(ua,d,0)}})(),q),q={load:P,startAutoLoad:async a=>{await F().load(a);try{g=await s((async(a,t)=>{t||a?2!=h&&(M(1),N++,_(t??a),M(0)):await P()}))}catch(a){r?.(a)}return q},stopAutoLoad:F,isAutoLoading:()=>!o(g),save:j,startAutoSave:async()=>(await Y().save(),A=a.addDidFinishTransactionListener((()=>{const a=T();O(a)&&j(a)})),q),stopAutoSave:Y,isAutoSaving:()=>!o(A),getStatus:()=>h,addStatusListener:a=>L(a,C),delListener:t=>(R(t),a),schedule:k,getStore:()=>a,destroy:()=>(ea(wa,d).splice(0,void 0),F().stopAutoSave()),getStats:()=>({loads:N,saves:$}),...w};return z(q)},da=(a,t,e,s,i,r=va,c,l)=>{const u=ta();return[async()=>{u.clear(),g(await e(a,t),(({tn:a,cn:t})=>ca(ia(u,a,oa),t)))},async(t,e)=>((a,t)=>F(ea(u,a),t))(t,e)?G(h(g(await a(I+_(t)),(a=>{return[a[e],l?(t=K(a,e),n=l,G(Q(t,((a,t)=>[t,n(a,t)])))):K(a,e)];var t,n})),(([a,t])=>!o(a)&&!X(t)))):{},async(t,e,s,l,w,y=!1)=>{const v=oa();Q(s??{},(a=>g(x(a??{}),(a=>ca(v,a)))));const E=j(v);if(!y&&w&&A(E)&&F(u,t))return await a("DROP "+b+_(t)),void sa(u,t);const f=ea(u,t),N=oa(j(f));if(A(E)||(F(u,t)?await d(g([e,...E],(async(n,s)=>{J(N,n)||(await a(T+_(t)+"ADD"+_(n)+i),0==s&&await a("CREATE UNIQUE INDEX pk ON "+_(t)+`(${_(e)})`),ca(f,n))}))):(await a("CREATE "+b+_(t)+`(${_(e)}${i} PRIMARY KEY${p(g(E,(a=>n+_(a)+i)))});`),sa(u,t,oa([e,...E])))),await d([...!y&&l?g(j(N),(async n=>{n!=e&&(await a(T+_(t)+"DROP"+_(n)),J(f,n))})):[]]),y)o(s)?await a(O+_(t)+S+" true"):await d(Q(s,(async(n,s)=>{o(n)?await a(O+_(t)+S+_(e)+"=$1",[s]):A(E)||await r(a,t,e,x(n),{[s]:c?g(V(n),c):V(n)},f)})));else if(A(E))F(u,t)&&await a(O+_(t)+S+" true");else{const n=h(j(ea(u,t)),(a=>a!=e)),i={},o=[];Q(s??{},((a,t)=>{i[t]=g(n,(t=>c?c(a?.[t]):a?.[t])),m(o,t)})),await r(a,t,e,n,i),await a(O+_(t)+S+_(e)+`NOT IN(${P(o)})`,o)}},async t=>{let e;await a("BEGIN");try{e=await t()}catch(a){s?.(a)}return await a("END"),e}]},va=async(a,t,e,s,i)=>{const r=[1];await a("INSERT INTO"+_(t)+"("+((...a)=>p(g(a,_),n))(e,...s)+")VALUES"+p(Q(i,(a=>"($"+r[0]+++","+P(a,r)+")")),n)+"ON CONFLICT("+_(e)+")DO UPDATE SET"+p(g(s,(a=>_(a)+"=excluded."+_(a))),n),Q(i,((a,t)=>[t,...g(a,(a=>a??null))])).flat())},Ea=(a,t,e,n,s,i,r,[o,c,l],u,w,y,d,v,E)=>{const[p,g,A,h]=da(t,u,w,s,v,E),m=ya(a,(async()=>await h((async()=>{return await p(),a=(await g(o,c))[N]?.[l]??"null",aa(a,((a,t)=>""===t?void 0:t));var a}))),(async a=>await h((async()=>{var t;await p(),await A(o,c,{[N]:{[l]:(t=a()??null,Z(t,((a,t)=>void 0===t?"":t)))}},!0,!0)}))),e,n,s,r,{[d]:()=>y,destroy:()=>(m.stopAutoLoad().stopAutoSave(),i(),m)},y);return m},pa=(a,t,e,n,s,i,r,[c,l,[u,w,y]],v,E,p,g,A,m,f,C)=>{const[S,b,T,O]=da(t,v,E,s,A,m,f,C),I=async(a,t)=>await d(na(l,(async([e,n,s,i],r)=>{t&&!(r in a)||await T(e,n,a[r],s,i,t)}))),L=async(a,t)=>w?await T(y,$,{[N]:a},!0,!0,t):null,D=ya(a,(async()=>await O((async()=>{await S();const a=await(async()=>G(h(await d(na(c,(async([a,t],e)=>[a,await b(e,t)]))),(a=>!X(a[1])))))(),t=await(async()=>u?(await b(y,$))[N]:{})();return X(a)&&o(t)?void 0:[a,t]}))),(async(a,t)=>await O((async()=>{if(await S(),o(t)){const[t,e]=a();await I(t),await L(e)}else await I(t[0],!0),await L(t[1],!0)}))),e,n,s,r,{[g]:()=>p,destroy:()=>(D.stopAutoLoad().stopAutoSave(),i(),D)},p);return D},ga="ColumnName",Aa="store",ha="json",ma=Aa+"TableName",fa=Aa+"Id"+ga,Na=Aa+ga,$a="autoLoadIntervalSeconds",Ca="rowId"+ga,Sa="tableId",ba="tableName",Ta="deleteEmptyColumns",Oa="deleteEmptyTable",Ia={mode:ha,[$a]:1},La={load:0,save:0,[ba]:t+"_values"},Da=(a,t,e,n,s)=>{const i=ta();return Q(a,((a,r)=>{const c=w(V(H(t,l(a)?{[e]:a}:a)),0,W(t));o(c[0])||n(r,c[0])||(s(r,c[0]),sa(i,r,c))})),i},Ra=(a,n,s,i,o,c,u,y,d,v,E="getDb",p)=>{let g,A,h;const m=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,c),[f,N,b,T]=(a=>{const e=(a=>H(Ia,l(a)?{[ma]:a}:a??{}))(a),n=e[$a];if(e.mode==ha){const a=e[ma]??t;return[1,n,[a,e[fa]??$,e[Na]??Aa],oa(a)]}const{tables:{load:s={},save:i={}}={},values:r={}}=e,o=w(V(H(La,r)),0,W(La)),c=o[2],u=oa(c),y=oa(c);return[0,n,[Da(s,{[Sa]:null,[Ca]:$},Sa,(a=>F(y,a)),(a=>ca(u,a))),Da(i,{[ba]:null,[Ca]:$,[Ta]:0,[Oa]:0},ba,((a,t)=>F(y,t)),((a,t)=>ca(u,t))),o],u]})(n);return(f?Ea:pa)(a,m,(a=>{let t;const e=()=>t=setInterval((async()=>{try{const[{d:t,s:e,c:n}]=await m(`${C} ${D} d,${R} s,TOTAL_CHANGES() c FROM ${L}${D} JOIN ${L}${R}`);t==g&&e==A&&n==h||(null!=g&&a(),g=t,A=e,h=n)}catch{}}),1e3*N),n=()=>{g=A=h=null,r(t)},s=i((t=>{T.has(t)&&(n(),a(),e())}));return e(),()=>{n(),o(s)}}),(a=>a()),u,y,d,b,j(T),(async(a,t)=>await a(`${C} t.name tn,c.name cn FROM ${M}list()t,${M}info(t.name)c ${S} t.schema='main'AND t.type IN('table','view')AND t.name IN(${P(t)})ORDER BY t.name,c.name`,t)),v,E,e,p,(a=>!0===a?1:!1===a?0:a),void 0)};exports.createElectricSqlPersister=(a,t,e,n,s)=>Ra(a,e,(async(a,e=[])=>await t.db.raw({sql:a,args:e})),(a=>t.notifier.subscribeToDataChanges((e=>E(t.notifier.alias(e),(({tablename:t})=>a(t)))))),(a=>a()),n,s,(()=>0),1,t,"getElectricClient");
@@ -1 +1 @@
1
- "use strict";const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),i=Promise,r=clearInterval,o=a=>null==a,c=(a,t,e)=>o(a)?e?.():t(a),l=t=>a(t)==s,u=a=>Array.isArray(a),w=(a,t,e)=>a.slice(t,e),y=a=>a.length,d=async a=>i.all(a),v=a=>{throw Error(a)},E=(a,t)=>A(Array(a).fill(0),((a,e)=>t(e))),p=(a,t)=>a.forEach(t),g=(a,t="")=>a.join(t),A=(a,t)=>a.map(t),h=a=>0==y(a),m=(a,t)=>a.filter(t),f=(a,...t)=>a.push(...t),C=a=>a.shift(),N="_",$="_id",S="SELECT",b="WHERE",O="TABLE",T="ALTER "+O,L="DELETE FROM",I=S+"*FROM",R="pragma_",D="data_version",M="schema_version",P="pragma_table_",_=a=>`"${a.replace(/"/g,'""')}"`,F=a=>g(A(a,((a,t)=>"$"+(t+1))),n),U=(a,t)=>a?.has(t)??!1,j=a=>o(a)||0==(a=>a?.size??0)(a),B=a=>[...a?.values()??[]],J=(a,t)=>a?.forEach(t),Y=(a,t)=>a?.delete(t),k=Object,q=a=>k.getPrototypeOf(a),x=k.entries,z=k.keys,G=k.freeze,H=(a=[])=>k.fromEntries(a),K=(...a)=>k.assign({},...a),Q=(a,t)=>(delete a[t],a),V=(a,t)=>A(x(a),(([a,e])=>t(e,a))),W=a=>k.values(a),X=a=>y(z(a)),Z=a=>(a=>!o(a)&&c(q(a),(a=>a==k.prototype||o(q(a))),(()=>!0)))(a)&&0==X(a),aa=JSON.stringify,ta=JSON.parse,ea=a=>new Map(a),na=(a,t)=>a?.get(t),sa=(a,t)=>A([...a?.entries()??[]],(([a,e])=>t(e,a))),ia=(a,t,e)=>o(e)?(Y(a,t),a):a?.set(t,e),ra=(a,t,e,n)=>(U(a,t)?n?.(na(a,t)):ia(a,t,e()),na(a,t)),oa=(a,t,e,n,s=0)=>c((e?ra:na)(a,t[s],s>y(t)-2?e:ea),(i=>{if(s>y(t)-2)return n?.(i)&&ia(a,t[s]),i;const r=oa(i,t,e,n,s+1);return j(i)&&ia(a,t[s]),r})),ca=a=>new Set(u(a)||o(a)?a:[a]),la=(a,t)=>a?.add(t),ua=/^\d+$/,wa=ea(),ya=ea(),da=(a,t,n,s,i,r,l,w={},d=[])=>{let E,g,A,h=0,m=0,N=0;ra(wa,d,(()=>0)),ra(ya,d,(()=>[]));const $=ea(),[S,b,O,T,L]=((a=1,t)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,t.getTransactionMergeableChanges,([[a],[t]])=>!Z(a)||!Z(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!Z(a)||!Z(t),t.setContent]:v("Store type not supported by this Persister"))(l,a),[I,R,D]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?C(a):null)??e+t++,t=>{ua.test(t)&&y(a)<1e3&&f(a,t)}]})(),s=ea();return[(n,i,r,o=[],c=()=>[])=>{a??=q;const l=t(1);return ia(s,l,[n,i,r,o,c]),la(oa(i,r??[e],ca),l),l},(t,n,...i)=>p(((a,t=[e])=>{const n=[],s=(a,e)=>e==y(t)?f(n,a):null===t[e]?J(a,(a=>s(a,e+1))):p([t[e],null],(t=>s(na(a,t),e+1)));return s(a,0),n})(t,n),(t=>J(t,(t=>na(s,t)[0](a,...n??[],...i))))),a=>c(na(s,a),(([,t,i])=>(oa(t,i??[e],void 0,(t=>(Y(t,a),j(t)?1:0))),ia(s,a),n(a),i))),t=>c(na(s,t),(([t,,e=[],n,s])=>{const i=(...r)=>{const c=y(r);c==y(e)?t(a,...r,...s(r)):o(e[c])?p(n[c]?.(...r)??[],(a=>i(...r,a))):i(...r,e[c])};i()}))]})(),M=a=>{a!=h&&(h=a,R($,void 0,h))},P=t=>{(S&&u(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},_=async a=>(2!=h&&(M(1),m++,await k((async()=>{try{const a=await t();u(a)?P(a):v("Content is not an array "+a)}catch(t){r?.(t),a&&L(a)}M(0)}))),q),F=()=>(g&&(i(g),g=void 0),q),U=async a=>(1!=h&&(M(2),N++,await k((async()=>{try{await n(b,a)}catch(a){r?.(a)}M(0)}))),q),B=()=>(c(A,a.delListener),A=void 0,q),k=async(...a)=>(f(na(ya,d),...a),await(async()=>{if(!na(wa,d)){for(ia(wa,d,1);!o(E=C(na(ya,d)));)try{await E()}catch(a){r?.(a)}ia(wa,d,0)}})(),q),q={load:_,startAutoLoad:async a=>{await F().load(a);try{g=await s((async(a,t)=>{t||a?2!=h&&(M(1),m++,P(t??a),M(0)):await _()}))}catch(a){r?.(a)}return q},stopAutoLoad:F,isAutoLoading:()=>!o(g),save:U,startAutoSave:async()=>(await B().save(),A=a.addDidFinishTransactionListener((()=>{const a=O();T(a)&&U(a)})),q),stopAutoSave:B,isAutoSaving:()=>!o(A),getStatus:()=>h,addStatusListener:a=>I(a,$),delListener:t=>(D(t),a),schedule:k,getStore:()=>a,destroy:()=>(na(ya,d).splice(0,void 0),F().stopAutoSave()),getStats:()=>({loads:m,saves:N}),...w};return G(q)},va=(a,t,e,s,i,r,c,l)=>{const u=ea();return[async()=>{u.clear(),A(await e(a,t),(({tn:a,cn:t})=>la(ra(u,a,ca),t)))},async(t,e)=>((a,t)=>U(na(u,a),t))(t,e)?H(m(A(await a(I+_(t)),(a=>{return[a[e],l?(t=Q(a,e),n=l,H(V(t,((a,t)=>[t,n(a,t)])))):Q(a,e)];var t,n})),(([a,t])=>!o(a)&&!Z(t)))):{},async(t,e,s,l,w,y=!1)=>{const v=ca();V(s??{},(a=>A(z(a??{}),(a=>la(v,a)))));const E=B(v);if(!y&&w&&h(E)&&U(u,t))return await a("DROP "+O+_(t)),void ia(u,t);const p=na(u,t),C=ca(B(p));if(h(E)||(U(u,t)?await d(A([e,...E],(async(n,s)=>{Y(C,n)||(await a(T+_(t)+"ADD"+_(n)+i),0==s&&await a("CREATE UNIQUE INDEX pk ON "+_(t)+`(${_(e)})`),la(p,n))}))):(await a("CREATE "+O+_(t)+`(${_(e)}${i} PRIMARY KEY${g(A(E,(a=>n+_(a)+i)))});`),ia(u,t,ca([e,...E])))),await d([...!y&&l?A(B(C),(async n=>{n!=e&&(await a(T+_(t)+"DROP"+_(n)),Y(p,n))})):[]]),y)o(s)?await a(L+_(t)+b+" true"):await d(V(s,(async(n,s)=>{o(n)?await a(L+_(t)+b+_(e)+"=$1",[s]):h(E)||await Ea(a,t,e,z(n),[s,...c?A(W(n),c):W(n)],r)})));else if(h(E))U(u,t)&&await a(L+_(t)+b+" true");else{const n=m(B(na(u,t)),(a=>a!=e)),i=[],o=[];V(s??{},((a,t)=>{f(i,t,...A(n,(t=>c?c(a?.[t]):a?.[t]))),f(o,t)})),await Ea(a,t,e,n,i,r),await a(L+_(t)+b+_(e)+`NOT IN(${F(o)})`,o)}},async t=>{let e;await a("BEGIN");try{e=await t()}catch(a){s?.(a)}return await a("END"),e}]},Ea=async(a,t,s,i,r,o=0)=>await a("INSERT "+(o?"OR REPLACE ":e)+"INTO"+_(t)+"("+_(s)+g(A(i,(a=>n+_(a))))+")VALUES"+pa(r,y(i)+1)+(o?e:"ON CONFLICT("+_(s)+")DO UPDATE SET"+g(A(i,(a=>_(a)+"=excluded."+_(a))),n)),A(r,(a=>a??null))),pa=(a,t)=>g(E(y(a)/t,(a=>"("+g(E(t,(e=>"$"+(a*t+e+1))),n)+")")),n),ga=(a,t,e,n,s,i,r,[o,c,l],u,w,y,d,v,E)=>{const[p,g,A,h]=va(t,u,w,s,v,E),m=da(a,(async()=>await h((async()=>{return await p(),a=(await g(o,c))[N]?.[l]??"null",ta(a,((a,t)=>""===t?void 0:t));var a}))),(async a=>await h((async()=>{var t;await p(),await A(o,c,{[N]:{[l]:(t=a()??null,aa(t,((a,t)=>void 0===t?"":t)))}},!0,!0)}))),e,n,s,r,{[d]:()=>y,destroy:()=>(m.stopAutoLoad().stopAutoSave(),i(),m)},y);return m},Aa=(a,t,e,n,s,i,r,[c,l,[u,w,y]],v,E,p,g,A,h,f,C)=>{const[S,b,O,T]=va(t,v,E,s,A,h,f,C),L=async(a,t)=>await d(sa(l,(async([e,n,s,i],r)=>{t&&!(r in a)||await O(e,n,a[r],s,i,t)}))),I=async(a,t)=>w?await O(y,$,{[N]:a},!0,!0,t):null,R=da(a,(async()=>await T((async()=>{await S();const a=await(async()=>H(m(await d(sa(c,(async([a,t],e)=>[a,await b(e,t)]))),(a=>!Z(a[1])))))(),t=await(async()=>u?(await b(y,$))[N]:{})();return Z(a)&&o(t)?void 0:[a,t]}))),(async(a,t)=>await T((async()=>{if(await S(),o(t)){const[t,e]=a();await L(t),await I(e)}else await L(t[0],!0),await I(t[1],!0)}))),e,n,s,r,{[g]:()=>p,destroy:()=>(R.stopAutoLoad().stopAutoSave(),i(),R)},p);return R},ha="ColumnName",ma="store",fa="json",Ca=ma+"TableName",Na=ma+"Id"+ha,$a=ma+ha,Sa="autoLoadIntervalSeconds",ba="rowId"+ha,Oa="tableId",Ta="tableName",La="deleteEmptyColumns",Ia="deleteEmptyTable",Ra={mode:fa,[Sa]:1},Da={load:0,save:0,[Ta]:t+"_values"},Ma=(a,t,e,n,s)=>{const i=ea();return V(a,((a,r)=>{const c=w(W(K(t,l(a)?{[e]:a}:a)),0,X(t));o(c[0])||n(r,c[0])||(s(r,c[0]),ia(i,r,c))})),i},Pa=(a,n,s,i,o,c,u,y,d,v,E="getDb",p)=>{let g,A,h;const m=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,c),[f,C,N,O]=(a=>{const e=(a=>K(Ra,l(a)?{[Ca]:a}:a??{}))(a),n=e[Sa];if(e.mode==fa){const a=e[Ca]??t;return[1,n,[a,e[Na]??$,e[$a]??ma],ca(a)]}const{tables:{load:s={},save:i={}}={},values:r={}}=e,o=w(W(K(Da,r)),0,X(Da)),c=o[2],u=ca(c),y=ca(c);return[0,n,[Ma(s,{[Oa]:null,[ba]:$},Oa,(a=>U(y,a)),(a=>la(u,a))),Ma(i,{[Ta]:null,[ba]:$,[La]:0,[Ia]:0},Ta,((a,t)=>U(y,t)),((a,t)=>la(u,t))),o],u]})(n);return(f?ga:Aa)(a,m,(a=>{let t;const e=()=>t=setInterval((async()=>{try{const[{d:t,s:e,c:n}]=await m(`${S} ${D} d,${M} s,TOTAL_CHANGES() c FROM ${R}${D} JOIN ${R}${M}`);t==g&&e==A&&n==h||(null!=g&&a(),g=t,A=e,h=n)}catch{}}),1e3*C),n=()=>{g=A=h=null,r(t)},s=i((t=>{O.has(t)&&(n(),a(),e())}));return e(),()=>{n(),o(s)}}),(a=>a()),u,y,d,N,B(O),(async(a,t)=>await a(`${S} t.name tn,c.name cn FROM ${P}list()t,${P}info(t.name)c ${b} t.schema='main'AND t.type IN('table','view')AND t.name IN(${F(t)})ORDER BY t.name,c.name`,t)),v,E,e,p,(a=>!0===a?1:!1===a?0:a),void 0)};exports.createElectricSqlPersister=(a,t,e,n,s)=>Pa(a,e,(async(a,e=[])=>await t.db.raw({sql:a,args:e})),(a=>t.notifier.subscribeToDataChanges((e=>p(t.notifier.alias(e),(({tablename:t})=>a(t)))))),(a=>a()),n,s,(()=>0),1,t,"getElectricClient");
1
+ "use strict";const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),i=Promise,r=clearInterval,o=a=>null==a,c=(a,t,e)=>o(a)?e?.():t(a),l=t=>a(t)==s,u=a=>Array.isArray(a),w=(a,t,e)=>a.slice(t,e),y=a=>a.length,d=async a=>i.all(a),v=a=>{throw Error(a)},E=(a,t)=>a.forEach(t),p=(a,t="")=>a.join(t),g=(a,t)=>a.map(t),A=a=>0==y(a),h=(a,t)=>a.filter(t),m=(a,...t)=>a.push(...t),f=a=>a.shift(),N="_",$="_id",C="SELECT",S="WHERE",b="TABLE",T="ALTER "+b,O="DELETE FROM",I=C+"*FROM",L="pragma_",D="data_version",R="schema_version",M="pragma_table_",_=a=>`"${a.replace(/"/g,'""')}"`,P=(a,t=[1])=>p(g(a,(()=>"$"+t[0]++)),n),F=(a,t)=>a?.has(t)??!1,U=a=>o(a)||0==(a=>a?.size??0)(a),j=a=>[...a?.values()??[]],B=(a,t)=>a?.forEach(t),J=(a,t)=>a?.delete(t),Y=Object,k=a=>Y.getPrototypeOf(a),q=Y.entries,x=Y.keys,z=Y.freeze,G=(a=[])=>Y.fromEntries(a),H=(...a)=>Y.assign({},...a),K=(a,t)=>(delete a[t],a),Q=(a,t)=>g(q(a),(([a,e])=>t(e,a))),V=a=>Y.values(a),W=a=>y(x(a)),X=a=>(a=>!o(a)&&c(k(a),(a=>a==Y.prototype||o(k(a))),(()=>!0)))(a)&&0==W(a),Z=JSON.stringify,aa=JSON.parse,ta=a=>new Map(a),ea=(a,t)=>a?.get(t),na=(a,t)=>g([...a?.entries()??[]],(([a,e])=>t(e,a))),sa=(a,t,e)=>o(e)?(J(a,t),a):a?.set(t,e),ia=(a,t,e,n)=>(F(a,t)?n?.(ea(a,t)):sa(a,t,e()),ea(a,t)),ra=(a,t,e,n,s=0)=>c((e?ia:ea)(a,t[s],s>y(t)-2?e:ta),(i=>{if(s>y(t)-2)return n?.(i)&&sa(a,t[s]),i;const r=ra(i,t,e,n,s+1);return U(i)&&sa(a,t[s]),r})),oa=a=>new Set(u(a)||o(a)?a:[a]),ca=(a,t)=>a?.add(t),la=/^\d+$/,ua=ta(),wa=ta(),ya=(a,t,n,s,i,r,l,w={},d=[])=>{let p,g,A,h=0,N=0,$=0;ia(ua,d,(()=>0)),ia(wa,d,(()=>[]));const C=ta(),[S,b,T,O,I]=((a=1,t)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,t.getTransactionMergeableChanges,([[a],[t]])=>!X(a)||!X(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!X(a)||!X(t),t.setContent]:v("Store type not supported by this Persister"))(l,a),[L,D,R]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?f(a):null)??e+t++,t=>{la.test(t)&&y(a)<1e3&&m(a,t)}]})(),s=ta();return[(n,i,r,o=[],c=()=>[])=>{a??=q;const l=t(1);return sa(s,l,[n,i,r,o,c]),ca(ra(i,r??[e],oa),l),l},(t,n,...i)=>E(((a,t=[e])=>{const n=[],s=(a,e)=>e==y(t)?m(n,a):null===t[e]?B(a,(a=>s(a,e+1))):E([t[e],null],(t=>s(ea(a,t),e+1)));return s(a,0),n})(t,n),(t=>B(t,(t=>ea(s,t)[0](a,...n??[],...i))))),a=>c(ea(s,a),(([,t,i])=>(ra(t,i??[e],void 0,(t=>(J(t,a),U(t)?1:0))),sa(s,a),n(a),i))),t=>c(ea(s,t),(([t,,e=[],n,s])=>{const i=(...r)=>{const c=y(r);c==y(e)?t(a,...r,...s(r)):o(e[c])?E(n[c]?.(...r)??[],(a=>i(...r,a))):i(...r,e[c])};i()}))]})(),M=a=>{a!=h&&(h=a,D(C,void 0,h))},_=t=>{(S&&u(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},P=async a=>(2!=h&&(M(1),N++,await k((async()=>{try{const a=await t();u(a)?_(a):v("Content is not an array "+a)}catch(t){r?.(t),a&&I(a)}M(0)}))),q),F=()=>(g&&(i(g),g=void 0),q),j=async a=>(1!=h&&(M(2),$++,await k((async()=>{try{await n(b,a)}catch(a){r?.(a)}M(0)}))),q),Y=()=>(c(A,a.delListener),A=void 0,q),k=async(...a)=>(m(ea(wa,d),...a),await(async()=>{if(!ea(ua,d)){for(sa(ua,d,1);!o(p=f(ea(wa,d)));)try{await p()}catch(a){r?.(a)}sa(ua,d,0)}})(),q),q={load:P,startAutoLoad:async a=>{await F().load(a);try{g=await s((async(a,t)=>{t||a?2!=h&&(M(1),N++,_(t??a),M(0)):await P()}))}catch(a){r?.(a)}return q},stopAutoLoad:F,isAutoLoading:()=>!o(g),save:j,startAutoSave:async()=>(await Y().save(),A=a.addDidFinishTransactionListener((()=>{const a=T();O(a)&&j(a)})),q),stopAutoSave:Y,isAutoSaving:()=>!o(A),getStatus:()=>h,addStatusListener:a=>L(a,C),delListener:t=>(R(t),a),schedule:k,getStore:()=>a,destroy:()=>(ea(wa,d).splice(0,void 0),F().stopAutoSave()),getStats:()=>({loads:N,saves:$}),...w};return z(q)},da=(a,t,e,s,i,r=va,c,l)=>{const u=ta();return[async()=>{u.clear(),g(await e(a,t),(({tn:a,cn:t})=>ca(ia(u,a,oa),t)))},async(t,e)=>((a,t)=>F(ea(u,a),t))(t,e)?G(h(g(await a(I+_(t)),(a=>{return[a[e],l?(t=K(a,e),n=l,G(Q(t,((a,t)=>[t,n(a,t)])))):K(a,e)];var t,n})),(([a,t])=>!o(a)&&!X(t)))):{},async(t,e,s,l,w,y=!1)=>{const v=oa();Q(s??{},(a=>g(x(a??{}),(a=>ca(v,a)))));const E=j(v);if(!y&&w&&A(E)&&F(u,t))return await a("DROP "+b+_(t)),void sa(u,t);const f=ea(u,t),N=oa(j(f));if(A(E)||(F(u,t)?await d(g([e,...E],(async(n,s)=>{J(N,n)||(await a(T+_(t)+"ADD"+_(n)+i),0==s&&await a("CREATE UNIQUE INDEX pk ON "+_(t)+`(${_(e)})`),ca(f,n))}))):(await a("CREATE "+b+_(t)+`(${_(e)}${i} PRIMARY KEY${p(g(E,(a=>n+_(a)+i)))});`),sa(u,t,oa([e,...E])))),await d([...!y&&l?g(j(N),(async n=>{n!=e&&(await a(T+_(t)+"DROP"+_(n)),J(f,n))})):[]]),y)o(s)?await a(O+_(t)+S+" true"):await d(Q(s,(async(n,s)=>{o(n)?await a(O+_(t)+S+_(e)+"=$1",[s]):A(E)||await r(a,t,e,x(n),{[s]:c?g(V(n),c):V(n)},f)})));else if(A(E))F(u,t)&&await a(O+_(t)+S+" true");else{const n=h(j(ea(u,t)),(a=>a!=e)),i={},o=[];Q(s??{},((a,t)=>{i[t]=g(n,(t=>c?c(a?.[t]):a?.[t])),m(o,t)})),await r(a,t,e,n,i),await a(O+_(t)+S+_(e)+`NOT IN(${P(o)})`,o)}},async t=>{let e;await a("BEGIN");try{e=await t()}catch(a){s?.(a)}return await a("END"),e}]},va=async(a,t,e,s,i)=>{const r=[1];await a("INSERT INTO"+_(t)+"("+((...a)=>p(g(a,_),n))(e,...s)+")VALUES"+p(Q(i,(a=>"($"+r[0]+++","+P(a,r)+")")),n)+"ON CONFLICT("+_(e)+")DO UPDATE SET"+p(g(s,(a=>_(a)+"=excluded."+_(a))),n),Q(i,((a,t)=>[t,...g(a,(a=>a??null))])).flat())},Ea=(a,t,e,n,s,i,r,[o,c,l],u,w,y,d,v,E)=>{const[p,g,A,h]=da(t,u,w,s,v,E),m=ya(a,(async()=>await h((async()=>{return await p(),a=(await g(o,c))[N]?.[l]??"null",aa(a,((a,t)=>""===t?void 0:t));var a}))),(async a=>await h((async()=>{var t;await p(),await A(o,c,{[N]:{[l]:(t=a()??null,Z(t,((a,t)=>void 0===t?"":t)))}},!0,!0)}))),e,n,s,r,{[d]:()=>y,destroy:()=>(m.stopAutoLoad().stopAutoSave(),i(),m)},y);return m},pa=(a,t,e,n,s,i,r,[c,l,[u,w,y]],v,E,p,g,A,m,f,C)=>{const[S,b,T,O]=da(t,v,E,s,A,m,f,C),I=async(a,t)=>await d(na(l,(async([e,n,s,i],r)=>{t&&!(r in a)||await T(e,n,a[r],s,i,t)}))),L=async(a,t)=>w?await T(y,$,{[N]:a},!0,!0,t):null,D=ya(a,(async()=>await O((async()=>{await S();const a=await(async()=>G(h(await d(na(c,(async([a,t],e)=>[a,await b(e,t)]))),(a=>!X(a[1])))))(),t=await(async()=>u?(await b(y,$))[N]:{})();return X(a)&&o(t)?void 0:[a,t]}))),(async(a,t)=>await O((async()=>{if(await S(),o(t)){const[t,e]=a();await I(t),await L(e)}else await I(t[0],!0),await L(t[1],!0)}))),e,n,s,r,{[g]:()=>p,destroy:()=>(D.stopAutoLoad().stopAutoSave(),i(),D)},p);return D},ga="ColumnName",Aa="store",ha="json",ma=Aa+"TableName",fa=Aa+"Id"+ga,Na=Aa+ga,$a="autoLoadIntervalSeconds",Ca="rowId"+ga,Sa="tableId",ba="tableName",Ta="deleteEmptyColumns",Oa="deleteEmptyTable",Ia={mode:ha,[$a]:1},La={load:0,save:0,[ba]:t+"_values"},Da=(a,t,e,n,s)=>{const i=ta();return Q(a,((a,r)=>{const c=w(V(H(t,l(a)?{[e]:a}:a)),0,W(t));o(c[0])||n(r,c[0])||(s(r,c[0]),sa(i,r,c))})),i},Ra=(a,n,s,i,o,c,u,y,d,v,E="getDb",p)=>{let g,A,h;const m=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,c),[f,N,b,T]=(a=>{const e=(a=>H(Ia,l(a)?{[ma]:a}:a??{}))(a),n=e[$a];if(e.mode==ha){const a=e[ma]??t;return[1,n,[a,e[fa]??$,e[Na]??Aa],oa(a)]}const{tables:{load:s={},save:i={}}={},values:r={}}=e,o=w(V(H(La,r)),0,W(La)),c=o[2],u=oa(c),y=oa(c);return[0,n,[Da(s,{[Sa]:null,[Ca]:$},Sa,(a=>F(y,a)),(a=>ca(u,a))),Da(i,{[ba]:null,[Ca]:$,[Ta]:0,[Oa]:0},ba,((a,t)=>F(y,t)),((a,t)=>ca(u,t))),o],u]})(n);return(f?Ea:pa)(a,m,(a=>{let t;const e=()=>t=setInterval((async()=>{try{const[{d:t,s:e,c:n}]=await m(`${C} ${D} d,${R} s,TOTAL_CHANGES() c FROM ${L}${D} JOIN ${L}${R}`);t==g&&e==A&&n==h||(null!=g&&a(),g=t,A=e,h=n)}catch{}}),1e3*N),n=()=>{g=A=h=null,r(t)},s=i((t=>{T.has(t)&&(n(),a(),e())}));return e(),()=>{n(),o(s)}}),(a=>a()),u,y,d,b,j(T),(async(a,t)=>await a(`${C} t.name tn,c.name cn FROM ${M}list()t,${M}info(t.name)c ${S} t.schema='main'AND t.type IN('table','view')AND t.name IN(${P(t)})ORDER BY t.name,c.name`,t)),v,E,e,p,(a=>!0===a?1:!1===a?0:a),void 0)};exports.createElectricSqlPersister=(a,t,e,n,s)=>Ra(a,e,(async(a,e=[])=>await t.db.raw({sql:a,args:e})),(a=>t.notifier.subscribeToDataChanges((e=>E(t.notifier.alias(e),(({tablename:t})=>a(t)))))),(a=>a()),n,s,(()=>0),1,t,"getElectricClient");
@@ -1 +1 @@
1
- "use strict";var a=require("expo-sqlite");const t=a=>typeof a,e="tinybase",n="",s=",",r=t(n),i=Promise,o=clearInterval,c=a=>null==a,l=(a,t,e)=>c(a)?e?.():t(a),y=a=>t(a)==r,u=a=>Array.isArray(a),w=(a,t,e)=>a.slice(t,e),d=a=>a.length,v=async a=>i.all(a),p=a=>{throw Error(a)},E=(a,t)=>m(Array(a).fill(0),((a,e)=>t(e))),g=(a,t)=>a.forEach(t),A=(a,t="")=>a.join(t),m=(a,t)=>a.map(t),h=a=>0==d(a),N=(a,t)=>a.filter(t),$=(a,...t)=>a.push(...t),C=a=>a.shift(),S="_",f="_id",O="SELECT",L="WHERE",T="TABLE",b="ALTER "+T,I="DELETE FROM",R=O+"*FROM",D="pragma_",M="data_version",P="schema_version",_="pragma_table_",F=a=>`"${a.replace(/"/g,'""')}"`,x=a=>A(m(a,((a,t)=>"$"+(t+1))),s),U=(a,t)=>a?.has(t)??!1,j=a=>c(a)||0==(a=>a?.size??0)(a),q=a=>[...a?.values()??[]],B=(a,t)=>a?.forEach(t),J=(a,t)=>a?.delete(t),Y=Object,k=a=>Y.getPrototypeOf(a),z=Y.entries,G=Y.keys,H=Y.freeze,K=(a=[])=>Y.fromEntries(a),Q=(...a)=>Y.assign({},...a),V=(a,t)=>(delete a[t],a),W=(a,t)=>m(z(a),(([a,e])=>t(e,a))),X=a=>Y.values(a),Z=a=>d(G(a)),aa=a=>(a=>!c(a)&&l(k(a),(a=>a==Y.prototype||c(k(a))),(()=>!0)))(a)&&0==Z(a),ta=JSON.stringify,ea=JSON.parse,na=a=>new Map(a),sa=(a,t)=>a?.get(t),ra=(a,t)=>m([...a?.entries()??[]],(([a,e])=>t(e,a))),ia=(a,t,e)=>c(e)?(J(a,t),a):a?.set(t,e),oa=(a,t,e,n)=>(U(a,t)?n?.(sa(a,t)):ia(a,t,e()),sa(a,t)),ca=(a,t,e,n,s=0)=>l((e?oa:sa)(a,t[s],s>d(t)-2?e:na),(r=>{if(s>d(t)-2)return n?.(r)&&ia(a,t[s]),r;const i=ca(r,t,e,n,s+1);return j(r)&&ia(a,t[s]),i})),la=a=>new Set(u(a)||c(a)?a:[a]),ya=(a,t)=>a?.add(t),ua=/^\d+$/,wa=na(),da=na(),va=(a,t,e,s,r,i,o,y={},w=[])=>{let v,E,A,m=0,h=0,N=0;oa(wa,w,(()=>0)),oa(da,w,(()=>[]));const S=na(),[f,O,L,T,b]=((a=1,t)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,t.getTransactionMergeableChanges,([[a],[t]])=>!aa(a)||!aa(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!aa(a)||!aa(t),t.setContent]:p("Store type not supported by this Persister"))(o,a),[I,R,D]=(()=>{let a;const[t,e]=(()=>{const a=[];let t=0;return[e=>(e?C(a):null)??n+t++,t=>{ua.test(t)&&d(a)<1e3&&$(a,t)}]})(),s=na();return[(e,r,i,o=[],c=()=>[])=>{a??=Y;const l=t(1);return ia(s,l,[e,r,i,o,c]),ya(ca(r,i??[n],la),l),l},(t,e,...r)=>g(((a,t=[n])=>{const e=[],s=(a,n)=>n==d(t)?$(e,a):null===t[n]?B(a,(a=>s(a,n+1))):g([t[n],null],(t=>s(sa(a,t),n+1)));return s(a,0),e})(t,e),(t=>B(t,(t=>sa(s,t)[0](a,...e??[],...r))))),a=>l(sa(s,a),(([,t,r])=>(ca(t,r??[n],void 0,(t=>(J(t,a),j(t)?1:0))),ia(s,a),e(a),r))),t=>l(sa(s,t),(([t,,e=[],n,s])=>{const r=(...i)=>{const o=d(i);o==d(e)?t(a,...i,...s(i)):c(e[o])?g(n[o]?.(...i)??[],(a=>r(...i,a))):r(...i,e[o])};r()}))]})(),M=a=>{a!=m&&(m=a,R(S,void 0,m))},P=t=>{(f&&u(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},_=async a=>(2!=m&&(M(1),h++,await q((async()=>{try{const a=await t();u(a)?P(a):p("Content is not an array "+a)}catch(t){i?.(t),a&&b(a)}M(0)}))),Y),F=()=>(E&&(r(E),E=void 0),Y),x=async a=>(1!=m&&(M(2),N++,await q((async()=>{try{await e(O,a)}catch(a){i?.(a)}M(0)}))),Y),U=()=>(l(A,a.delListener),A=void 0,Y),q=async(...a)=>($(sa(da,w),...a),await(async()=>{if(!sa(wa,w)){for(ia(wa,w,1);!c(v=C(sa(da,w)));)try{await v()}catch(a){i?.(a)}ia(wa,w,0)}})(),Y),Y={load:_,startAutoLoad:async a=>{await F().load(a);try{E=await s((async(a,t)=>{t||a?2!=m&&(M(1),h++,P(t??a),M(0)):await _()}))}catch(a){i?.(a)}return Y},stopAutoLoad:F,isAutoLoading:()=>!c(E),save:x,startAutoSave:async()=>(await U().save(),A=a.addDidFinishTransactionListener((()=>{const a=L();T(a)&&x(a)})),Y),stopAutoSave:U,isAutoSaving:()=>!c(A),getStatus:()=>m,addStatusListener:a=>I(a,S),delListener:t=>(D(t),a),schedule:q,getStore:()=>a,destroy:()=>(sa(da,w).splice(0,void 0),F().stopAutoSave()),getStats:()=>({loads:h,saves:N}),...y};return H(Y)},pa=(a,t,e,n,r,i,o,l)=>{const y=na();return[async()=>{y.clear(),m(await e(a,t),(({tn:a,cn:t})=>ya(oa(y,a,la),t)))},async(t,e)=>((a,t)=>U(sa(y,a),t))(t,e)?K(N(m(await a(R+F(t)),(a=>{return[a[e],l?(t=V(a,e),n=l,K(W(t,((a,t)=>[t,n(a,t)])))):V(a,e)];var t,n})),(([a,t])=>!c(a)&&!aa(t)))):{},async(t,e,n,l,u,w=!1)=>{const d=la();W(n??{},(a=>m(G(a??{}),(a=>ya(d,a)))));const p=q(d);if(!w&&u&&h(p)&&U(y,t))return await a("DROP "+T+F(t)),void ia(y,t);const E=sa(y,t),g=la(q(E));if(h(p)||(U(y,t)?await v(m([e,...p],(async(n,s)=>{J(g,n)||(await a(b+F(t)+"ADD"+F(n)+r),0==s&&await a("CREATE UNIQUE INDEX pk ON "+F(t)+`(${F(e)})`),ya(E,n))}))):(await a("CREATE "+T+F(t)+`(${F(e)}${r} PRIMARY KEY${A(m(p,(a=>s+F(a)+r)))});`),ia(y,t,la([e,...p])))),await v([...!w&&l?m(q(g),(async n=>{n!=e&&(await a(b+F(t)+"DROP"+F(n)),J(E,n))})):[]]),w)c(n)?await a(I+F(t)+L+" true"):await v(W(n,(async(n,s)=>{c(n)?await a(I+F(t)+L+F(e)+"=$1",[s]):h(p)||await Ea(a,t,e,G(n),[s,...o?m(X(n),o):X(n)],i)})));else if(h(p))U(y,t)&&await a(I+F(t)+L+" true");else{const s=N(q(sa(y,t)),(a=>a!=e)),r=[],c=[];W(n??{},((a,t)=>{$(r,t,...m(s,(t=>o?o(a?.[t]):a?.[t]))),$(c,t)})),await Ea(a,t,e,s,r,i),await a(I+F(t)+L+F(e)+`NOT IN(${x(c)})`,c)}},async t=>{let e;await a("BEGIN");try{e=await t()}catch(a){n?.(a)}return await a("END"),e}]},Ea=async(a,t,e,r,i,o=0)=>await a("INSERT "+(o?"OR REPLACE ":n)+"INTO"+F(t)+"("+F(e)+A(m(r,(a=>s+F(a))))+")VALUES"+ga(i,d(r)+1)+(o?n:"ON CONFLICT("+F(e)+")DO UPDATE SET"+A(m(r,(a=>F(a)+"=excluded."+F(a))),s)),m(i,(a=>a??null))),ga=(a,t)=>A(E(d(a)/t,(a=>"("+A(E(t,(e=>"$"+(a*t+e+1))),s)+")")),s),Aa=(a,t,e,n,s,r,i,[o,c,l],y,u,w,d,v,p)=>{const[E,g,A,m]=pa(t,y,u,s,v,p),h=va(a,(async()=>await m((async()=>{return await E(),a=(await g(o,c))[S]?.[l]??"null",ea(a,((a,t)=>""===t?void 0:t));var a}))),(async a=>await m((async()=>{var t;await E(),await A(o,c,{[S]:{[l]:(t=a()??null,ta(t,((a,t)=>void 0===t?"":t)))}},!0,!0)}))),e,n,s,i,{[d]:()=>w,destroy:()=>(h.stopAutoLoad().stopAutoSave(),r(),h)},w);return h},ma=(a,t,e,n,s,r,i,[o,l,[y,u,w]],d,p,E,g,A,m,h,$)=>{const[C,O,L,T]=pa(t,d,p,s,A,m,h,$),b=async(a,t)=>await v(ra(l,(async([e,n,s,r],i)=>{t&&!(i in a)||await L(e,n,a[i],s,r,t)}))),I=async(a,t)=>u?await L(w,f,{[S]:a},!0,!0,t):null,R=va(a,(async()=>await T((async()=>{await C();const a=await(async()=>K(N(await v(ra(o,(async([a,t],e)=>[a,await O(e,t)]))),(a=>!aa(a[1])))))(),t=await(async()=>y?(await O(w,f))[S]:{})();return aa(a)&&c(t)?void 0:[a,t]}))),(async(a,t)=>await T((async()=>{if(await C(),c(t)){const[t,e]=a();await b(t),await I(e)}else await b(t[0],!0),await I(t[1],!0)}))),e,n,s,i,{[g]:()=>E,destroy:()=>(R.stopAutoLoad().stopAutoSave(),r(),R)},E);return R},ha="ColumnName",Na="store",$a="json",Ca=Na+"TableName",Sa=Na+"Id"+ha,fa=Na+ha,Oa="autoLoadIntervalSeconds",La="rowId"+ha,Ta="tableId",ba="tableName",Ia="deleteEmptyColumns",Ra="deleteEmptyTable",Da={mode:$a,[Oa]:1},Ma={load:0,save:0,[ba]:e+"_values"},Pa=(a,t,e,n,s)=>{const r=na();return W(a,((a,i)=>{const o=w(X(Q(t,y(a)?{[e]:a}:a)),0,Z(t));c(o[0])||n(i,o[0])||(s(i,o[0]),ia(r,i,o))})),r},_a=(a,t,s,r,i,c,l,u,d,v,p="getDb",E)=>{let g,A,m;const h=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,c),[N,$,C,S]=(a=>{const t=(a=>Q(Da,y(a)?{[Ca]:a}:a??{}))(a),n=t[Oa];if(t.mode==$a){const a=t[Ca]??e;return[1,n,[a,t[Sa]??f,t[fa]??Na],la(a)]}const{tables:{load:s={},save:r={}}={},values:i={}}=t,o=w(X(Q(Ma,i)),0,Z(Ma)),c=o[2],l=la(c),u=la(c);return[0,n,[Pa(s,{[Ta]:null,[La]:f},Ta,(a=>U(u,a)),(a=>ya(l,a))),Pa(r,{[ba]:null,[La]:f,[Ia]:0,[Ra]:0},ba,((a,t)=>U(u,t)),((a,t)=>ya(l,t))),o],l]})(t);return(N?Aa:ma)(a,h,(a=>{let t;const e=()=>t=setInterval((async()=>{try{const[{d:t,s:e,c:n}]=await h(`${O} ${M} d,${P} s,TOTAL_CHANGES() c FROM ${D}${M} JOIN ${D}${P}`);t==g&&e==A&&n==m||(null!=g&&a(),g=t,A=e,m=n)}catch{}}),1e3*$),n=()=>{g=A=m=null,o(t)},s=r((t=>{S.has(t)&&(n(),a(),e())}));return e(),()=>{n(),i(s)}}),(a=>a()),l,u,d,C,q(S),(async(a,t)=>await a(`${O} t.name tn,c.name cn FROM ${_}list()t,${_}info(t.name)c ${L} t.schema='main'AND t.type IN('table','view')AND t.name IN(${x(t)})ORDER BY t.name,c.name`,t)),v,p,n,E,(a=>!0===a?1:!1===a?0:a),void 0)};exports.createExpoSqlitePersister=(t,e,n,s,r)=>_a(t,n,(async(a,t=[])=>await e.getAllAsync(a,t)),(t=>a.addDatabaseChangeListener((({tableName:a})=>t(a)))),(a=>a.remove()),s,r,(()=>0),3,e);
1
+ "use strict";var a=require("expo-sqlite");const t=a=>typeof a,e="tinybase",n="",s=",",r=t(n),i=Promise,o=clearInterval,c=a=>null==a,l=(a,t,e)=>c(a)?e?.():t(a),u=a=>t(a)==r,y=a=>Array.isArray(a),w=(a,t,e)=>a.slice(t,e),d=a=>a.length,v=async a=>i.all(a),p=a=>{throw Error(a)},E=(a,t)=>a.forEach(t),g=(a,t="")=>a.join(t),A=(a,t)=>a.map(t),m=a=>0==d(a),h=(a,t)=>a.filter(t),N=(a,...t)=>a.push(...t),$=a=>a.shift(),S="_",f="_id",C="SELECT",O="WHERE",T="TABLE",b="ALTER "+T,L="DELETE FROM",I=C+"*FROM",D="pragma_",R="data_version",M="schema_version",_="pragma_table_",P=a=>`"${a.replace(/"/g,'""')}"`,F=(a,t=[1])=>g(A(a,(()=>"$"+t[0]++)),s),x=(a,t)=>a?.has(t)??!1,U=a=>c(a)||0==(a=>a?.size??0)(a),j=a=>[...a?.values()??[]],q=(a,t)=>a?.forEach(t),B=(a,t)=>a?.delete(t),J=Object,Y=a=>J.getPrototypeOf(a),k=J.entries,z=J.keys,G=J.freeze,H=(a=[])=>J.fromEntries(a),K=(...a)=>J.assign({},...a),Q=(a,t)=>(delete a[t],a),V=(a,t)=>A(k(a),(([a,e])=>t(e,a))),W=a=>J.values(a),X=a=>d(z(a)),Z=a=>(a=>!c(a)&&l(Y(a),(a=>a==J.prototype||c(Y(a))),(()=>!0)))(a)&&0==X(a),aa=JSON.stringify,ta=JSON.parse,ea=a=>new Map(a),na=(a,t)=>a?.get(t),sa=(a,t)=>A([...a?.entries()??[]],(([a,e])=>t(e,a))),ra=(a,t,e)=>c(e)?(B(a,t),a):a?.set(t,e),ia=(a,t,e,n)=>(x(a,t)?n?.(na(a,t)):ra(a,t,e()),na(a,t)),oa=(a,t,e,n,s=0)=>l((e?ia:na)(a,t[s],s>d(t)-2?e:ea),(r=>{if(s>d(t)-2)return n?.(r)&&ra(a,t[s]),r;const i=oa(r,t,e,n,s+1);return U(r)&&ra(a,t[s]),i})),ca=a=>new Set(y(a)||c(a)?a:[a]),la=(a,t)=>a?.add(t),ua=/^\d+$/,ya=ea(),wa=ea(),da=(a,t,e,s,r,i,o,u={},w=[])=>{let v,g,A,m=0,h=0,S=0;ia(ya,w,(()=>0)),ia(wa,w,(()=>[]));const f=ea(),[C,O,T,b,L]=((a=1,t)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,t.getTransactionMergeableChanges,([[a],[t]])=>!Z(a)||!Z(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!Z(a)||!Z(t),t.setContent]:p("Store type not supported by this Persister"))(o,a),[I,D,R]=(()=>{let a;const[t,e]=(()=>{const a=[];let t=0;return[e=>(e?$(a):null)??n+t++,t=>{ua.test(t)&&d(a)<1e3&&N(a,t)}]})(),s=ea();return[(e,r,i,o=[],c=()=>[])=>{a??=Y;const l=t(1);return ra(s,l,[e,r,i,o,c]),la(oa(r,i??[n],ca),l),l},(t,e,...r)=>E(((a,t=[n])=>{const e=[],s=(a,n)=>n==d(t)?N(e,a):null===t[n]?q(a,(a=>s(a,n+1))):E([t[n],null],(t=>s(na(a,t),n+1)));return s(a,0),e})(t,e),(t=>q(t,(t=>na(s,t)[0](a,...e??[],...r))))),a=>l(na(s,a),(([,t,r])=>(oa(t,r??[n],void 0,(t=>(B(t,a),U(t)?1:0))),ra(s,a),e(a),r))),t=>l(na(s,t),(([t,,e=[],n,s])=>{const r=(...i)=>{const o=d(i);o==d(e)?t(a,...i,...s(i)):c(e[o])?E(n[o]?.(...i)??[],(a=>r(...i,a))):r(...i,e[o])};r()}))]})(),M=a=>{a!=m&&(m=a,D(f,void 0,m))},_=t=>{(C&&y(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},P=async a=>(2!=m&&(M(1),h++,await J((async()=>{try{const a=await t();y(a)?_(a):p("Content is not an array "+a)}catch(t){i?.(t),a&&L(a)}M(0)}))),Y),F=()=>(g&&(r(g),g=void 0),Y),x=async a=>(1!=m&&(M(2),S++,await J((async()=>{try{await e(O,a)}catch(a){i?.(a)}M(0)}))),Y),j=()=>(l(A,a.delListener),A=void 0,Y),J=async(...a)=>(N(na(wa,w),...a),await(async()=>{if(!na(ya,w)){for(ra(ya,w,1);!c(v=$(na(wa,w)));)try{await v()}catch(a){i?.(a)}ra(ya,w,0)}})(),Y),Y={load:P,startAutoLoad:async a=>{await F().load(a);try{g=await s((async(a,t)=>{t||a?2!=m&&(M(1),h++,_(t??a),M(0)):await P()}))}catch(a){i?.(a)}return Y},stopAutoLoad:F,isAutoLoading:()=>!c(g),save:x,startAutoSave:async()=>(await j().save(),A=a.addDidFinishTransactionListener((()=>{const a=T();b(a)&&x(a)})),Y),stopAutoSave:j,isAutoSaving:()=>!c(A),getStatus:()=>m,addStatusListener:a=>I(a,f),delListener:t=>(R(t),a),schedule:J,getStore:()=>a,destroy:()=>(na(wa,w).splice(0,void 0),F().stopAutoSave()),getStats:()=>({loads:h,saves:S}),...u};return G(Y)},va=(a,t,e,n,r,i=pa,o,l)=>{const u=ea();return[async()=>{u.clear(),A(await e(a,t),(({tn:a,cn:t})=>la(ia(u,a,ca),t)))},async(t,e)=>((a,t)=>x(na(u,a),t))(t,e)?H(h(A(await a(I+P(t)),(a=>{return[a[e],l?(t=Q(a,e),n=l,H(V(t,((a,t)=>[t,n(a,t)])))):Q(a,e)];var t,n})),(([a,t])=>!c(a)&&!Z(t)))):{},async(t,e,n,l,y,w=!1)=>{const d=ca();V(n??{},(a=>A(z(a??{}),(a=>la(d,a)))));const p=j(d);if(!w&&y&&m(p)&&x(u,t))return await a("DROP "+T+P(t)),void ra(u,t);const E=na(u,t),$=ca(j(E));if(m(p)||(x(u,t)?await v(A([e,...p],(async(n,s)=>{B($,n)||(await a(b+P(t)+"ADD"+P(n)+r),0==s&&await a("CREATE UNIQUE INDEX pk ON "+P(t)+`(${P(e)})`),la(E,n))}))):(await a("CREATE "+T+P(t)+`(${P(e)}${r} PRIMARY KEY${g(A(p,(a=>s+P(a)+r)))});`),ra(u,t,ca([e,...p])))),await v([...!w&&l?A(j($),(async n=>{n!=e&&(await a(b+P(t)+"DROP"+P(n)),B(E,n))})):[]]),w)c(n)?await a(L+P(t)+O+" true"):await v(V(n,(async(n,s)=>{c(n)?await a(L+P(t)+O+P(e)+"=$1",[s]):m(p)||await i(a,t,e,z(n),{[s]:o?A(W(n),o):W(n)},E)})));else if(m(p))x(u,t)&&await a(L+P(t)+O+" true");else{const s=h(j(na(u,t)),(a=>a!=e)),r={},c=[];V(n??{},((a,t)=>{r[t]=A(s,(t=>o?o(a?.[t]):a?.[t])),N(c,t)})),await i(a,t,e,s,r),await a(L+P(t)+O+P(e)+`NOT IN(${F(c)})`,c)}},async t=>{let e;await a("BEGIN");try{e=await t()}catch(a){n?.(a)}return await a("END"),e}]},pa=async(a,t,e,n,r)=>{const i=[1];await a("INSERT INTO"+P(t)+"("+((...a)=>g(A(a,P),s))(e,...n)+")VALUES"+g(V(r,(a=>"($"+i[0]+++","+F(a,i)+")")),s)+"ON CONFLICT("+P(e)+")DO UPDATE SET"+g(A(n,(a=>P(a)+"=excluded."+P(a))),s),V(r,((a,t)=>[t,...A(a,(a=>a??null))])).flat())},Ea=(a,t,e,n,s,r,i,[o,c,l],u,y,w,d,v,p)=>{const[E,g,A,m]=va(t,u,y,s,v,p),h=da(a,(async()=>await m((async()=>{return await E(),a=(await g(o,c))[S]?.[l]??"null",ta(a,((a,t)=>""===t?void 0:t));var a}))),(async a=>await m((async()=>{var t;await E(),await A(o,c,{[S]:{[l]:(t=a()??null,aa(t,((a,t)=>void 0===t?"":t)))}},!0,!0)}))),e,n,s,i,{[d]:()=>w,destroy:()=>(h.stopAutoLoad().stopAutoSave(),r(),h)},w);return h},ga=(a,t,e,n,s,r,i,[o,l,[u,y,w]],d,p,E,g,A,m,N,$)=>{const[C,O,T,b]=va(t,d,p,s,A,m,N,$),L=async(a,t)=>await v(sa(l,(async([e,n,s,r],i)=>{t&&!(i in a)||await T(e,n,a[i],s,r,t)}))),I=async(a,t)=>y?await T(w,f,{[S]:a},!0,!0,t):null,D=da(a,(async()=>await b((async()=>{await C();const a=await(async()=>H(h(await v(sa(o,(async([a,t],e)=>[a,await O(e,t)]))),(a=>!Z(a[1])))))(),t=await(async()=>u?(await O(w,f))[S]:{})();return Z(a)&&c(t)?void 0:[a,t]}))),(async(a,t)=>await b((async()=>{if(await C(),c(t)){const[t,e]=a();await L(t),await I(e)}else await L(t[0],!0),await I(t[1],!0)}))),e,n,s,i,{[g]:()=>E,destroy:()=>(D.stopAutoLoad().stopAutoSave(),r(),D)},E);return D},Aa="ColumnName",ma="store",ha="json",Na=ma+"TableName",$a=ma+"Id"+Aa,Sa=ma+Aa,fa="autoLoadIntervalSeconds",Ca="rowId"+Aa,Oa="tableId",Ta="tableName",ba="deleteEmptyColumns",La="deleteEmptyTable",Ia={mode:ha,[fa]:1},Da={load:0,save:0,[Ta]:e+"_values"},Ra=(a,t,e,n,s)=>{const r=ea();return V(a,((a,i)=>{const o=w(W(K(t,u(a)?{[e]:a}:a)),0,X(t));c(o[0])||n(i,o[0])||(s(i,o[0]),ra(r,i,o))})),r},Ma=(a,t,s,r,i,c,l,y,d,v,p="getDb",E)=>{let g,A,m;const h=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,c),[N,$,S,T]=(a=>{const t=(a=>K(Ia,u(a)?{[Na]:a}:a??{}))(a),n=t[fa];if(t.mode==ha){const a=t[Na]??e;return[1,n,[a,t[$a]??f,t[Sa]??ma],ca(a)]}const{tables:{load:s={},save:r={}}={},values:i={}}=t,o=w(W(K(Da,i)),0,X(Da)),c=o[2],l=ca(c),y=ca(c);return[0,n,[Ra(s,{[Oa]:null,[Ca]:f},Oa,(a=>x(y,a)),(a=>la(l,a))),Ra(r,{[Ta]:null,[Ca]:f,[ba]:0,[La]:0},Ta,((a,t)=>x(y,t)),((a,t)=>la(l,t))),o],l]})(t);return(N?Ea:ga)(a,h,(a=>{let t;const e=()=>t=setInterval((async()=>{try{const[{d:t,s:e,c:n}]=await h(`${C} ${R} d,${M} s,TOTAL_CHANGES() c FROM ${D}${R} JOIN ${D}${M}`);t==g&&e==A&&n==m||(null!=g&&a(),g=t,A=e,m=n)}catch{}}),1e3*$),n=()=>{g=A=m=null,o(t)},s=r((t=>{T.has(t)&&(n(),a(),e())}));return e(),()=>{n(),i(s)}}),(a=>a()),l,y,d,S,j(T),(async(a,t)=>await a(`${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(t)})ORDER BY t.name,c.name`,t)),v,p,n,E,(a=>!0===a?1:!1===a?0:a),void 0)};exports.createExpoSqlitePersister=(t,e,n,s,r)=>Ma(t,n,(async(a,t=[])=>await e.getAllAsync(a,t)),(t=>a.addDatabaseChangeListener((({tableName:a})=>t(a)))),(a=>a.remove()),s,r,(()=>0),3,e);
@@ -1 +1 @@
1
- "use strict";var a=require("expo-sqlite");const t=a=>typeof a,e="tinybase",n="",s=",",r=t(n),i=Promise,o=clearInterval,c=a=>null==a,l=(a,t,e)=>c(a)?e?.():t(a),y=a=>t(a)==r,u=a=>Array.isArray(a),w=(a,t,e)=>a.slice(t,e),d=a=>a.length,v=async a=>i.all(a),p=a=>{throw Error(a)},E=(a,t)=>m(Array(a).fill(0),((a,e)=>t(e))),g=(a,t)=>a.forEach(t),A=(a,t="")=>a.join(t),m=(a,t)=>a.map(t),h=a=>0==d(a),N=(a,t)=>a.filter(t),$=(a,...t)=>a.push(...t),C=a=>a.shift(),S="_",f="_id",O="SELECT",L="WHERE",T="TABLE",b="ALTER "+T,I="DELETE FROM",R=O+"*FROM",D="pragma_",M="data_version",P="schema_version",_="pragma_table_",F=a=>`"${a.replace(/"/g,'""')}"`,x=a=>A(m(a,((a,t)=>"$"+(t+1))),s),U=(a,t)=>a?.has(t)??!1,j=a=>c(a)||0==(a=>a?.size??0)(a),q=a=>[...a?.values()??[]],B=(a,t)=>a?.forEach(t),J=(a,t)=>a?.delete(t),Y=Object,k=a=>Y.getPrototypeOf(a),z=Y.entries,G=Y.keys,H=Y.freeze,K=(a=[])=>Y.fromEntries(a),Q=(...a)=>Y.assign({},...a),V=(a,t)=>(delete a[t],a),W=(a,t)=>m(z(a),(([a,e])=>t(e,a))),X=a=>Y.values(a),Z=a=>d(G(a)),aa=a=>(a=>!c(a)&&l(k(a),(a=>a==Y.prototype||c(k(a))),(()=>!0)))(a)&&0==Z(a),ta=JSON.stringify,ea=JSON.parse,na=a=>new Map(a),sa=(a,t)=>a?.get(t),ra=(a,t)=>m([...a?.entries()??[]],(([a,e])=>t(e,a))),ia=(a,t,e)=>c(e)?(J(a,t),a):a?.set(t,e),oa=(a,t,e,n)=>(U(a,t)?n?.(sa(a,t)):ia(a,t,e()),sa(a,t)),ca=(a,t,e,n,s=0)=>l((e?oa:sa)(a,t[s],s>d(t)-2?e:na),(r=>{if(s>d(t)-2)return n?.(r)&&ia(a,t[s]),r;const i=ca(r,t,e,n,s+1);return j(r)&&ia(a,t[s]),i})),la=a=>new Set(u(a)||c(a)?a:[a]),ya=(a,t)=>a?.add(t),ua=/^\d+$/,wa=na(),da=na(),va=(a,t,e,s,r,i,o,y={},w=[])=>{let v,E,A,m=0,h=0,N=0;oa(wa,w,(()=>0)),oa(da,w,(()=>[]));const S=na(),[f,O,L,T,b]=((a=1,t)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,t.getTransactionMergeableChanges,([[a],[t]])=>!aa(a)||!aa(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!aa(a)||!aa(t),t.setContent]:p("Store type not supported by this Persister"))(o,a),[I,R,D]=(()=>{let a;const[t,e]=(()=>{const a=[];let t=0;return[e=>(e?C(a):null)??n+t++,t=>{ua.test(t)&&d(a)<1e3&&$(a,t)}]})(),s=na();return[(e,r,i,o=[],c=()=>[])=>{a??=Y;const l=t(1);return ia(s,l,[e,r,i,o,c]),ya(ca(r,i??[n],la),l),l},(t,e,...r)=>g(((a,t=[n])=>{const e=[],s=(a,n)=>n==d(t)?$(e,a):null===t[n]?B(a,(a=>s(a,n+1))):g([t[n],null],(t=>s(sa(a,t),n+1)));return s(a,0),e})(t,e),(t=>B(t,(t=>sa(s,t)[0](a,...e??[],...r))))),a=>l(sa(s,a),(([,t,r])=>(ca(t,r??[n],void 0,(t=>(J(t,a),j(t)?1:0))),ia(s,a),e(a),r))),t=>l(sa(s,t),(([t,,e=[],n,s])=>{const r=(...i)=>{const o=d(i);o==d(e)?t(a,...i,...s(i)):c(e[o])?g(n[o]?.(...i)??[],(a=>r(...i,a))):r(...i,e[o])};r()}))]})(),M=a=>{a!=m&&(m=a,R(S,void 0,m))},P=t=>{(f&&u(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},_=async a=>(2!=m&&(M(1),h++,await q((async()=>{try{const a=await t();u(a)?P(a):p("Content is not an array "+a)}catch(t){i?.(t),a&&b(a)}M(0)}))),Y),F=()=>(E&&(r(E),E=void 0),Y),x=async a=>(1!=m&&(M(2),N++,await q((async()=>{try{await e(O,a)}catch(a){i?.(a)}M(0)}))),Y),U=()=>(l(A,a.delListener),A=void 0,Y),q=async(...a)=>($(sa(da,w),...a),await(async()=>{if(!sa(wa,w)){for(ia(wa,w,1);!c(v=C(sa(da,w)));)try{await v()}catch(a){i?.(a)}ia(wa,w,0)}})(),Y),Y={load:_,startAutoLoad:async a=>{await F().load(a);try{E=await s((async(a,t)=>{t||a?2!=m&&(M(1),h++,P(t??a),M(0)):await _()}))}catch(a){i?.(a)}return Y},stopAutoLoad:F,isAutoLoading:()=>!c(E),save:x,startAutoSave:async()=>(await U().save(),A=a.addDidFinishTransactionListener((()=>{const a=L();T(a)&&x(a)})),Y),stopAutoSave:U,isAutoSaving:()=>!c(A),getStatus:()=>m,addStatusListener:a=>I(a,S),delListener:t=>(D(t),a),schedule:q,getStore:()=>a,destroy:()=>(sa(da,w).splice(0,void 0),F().stopAutoSave()),getStats:()=>({loads:h,saves:N}),...y};return H(Y)},pa=(a,t,e,n,r,i,o,l)=>{const y=na();return[async()=>{y.clear(),m(await e(a,t),(({tn:a,cn:t})=>ya(oa(y,a,la),t)))},async(t,e)=>((a,t)=>U(sa(y,a),t))(t,e)?K(N(m(await a(R+F(t)),(a=>{return[a[e],l?(t=V(a,e),n=l,K(W(t,((a,t)=>[t,n(a,t)])))):V(a,e)];var t,n})),(([a,t])=>!c(a)&&!aa(t)))):{},async(t,e,n,l,u,w=!1)=>{const d=la();W(n??{},(a=>m(G(a??{}),(a=>ya(d,a)))));const p=q(d);if(!w&&u&&h(p)&&U(y,t))return await a("DROP "+T+F(t)),void ia(y,t);const E=sa(y,t),g=la(q(E));if(h(p)||(U(y,t)?await v(m([e,...p],(async(n,s)=>{J(g,n)||(await a(b+F(t)+"ADD"+F(n)+r),0==s&&await a("CREATE UNIQUE INDEX pk ON "+F(t)+`(${F(e)})`),ya(E,n))}))):(await a("CREATE "+T+F(t)+`(${F(e)}${r} PRIMARY KEY${A(m(p,(a=>s+F(a)+r)))});`),ia(y,t,la([e,...p])))),await v([...!w&&l?m(q(g),(async n=>{n!=e&&(await a(b+F(t)+"DROP"+F(n)),J(E,n))})):[]]),w)c(n)?await a(I+F(t)+L+" true"):await v(W(n,(async(n,s)=>{c(n)?await a(I+F(t)+L+F(e)+"=$1",[s]):h(p)||await Ea(a,t,e,G(n),[s,...o?m(X(n),o):X(n)],i)})));else if(h(p))U(y,t)&&await a(I+F(t)+L+" true");else{const s=N(q(sa(y,t)),(a=>a!=e)),r=[],c=[];W(n??{},((a,t)=>{$(r,t,...m(s,(t=>o?o(a?.[t]):a?.[t]))),$(c,t)})),await Ea(a,t,e,s,r,i),await a(I+F(t)+L+F(e)+`NOT IN(${x(c)})`,c)}},async t=>{let e;await a("BEGIN");try{e=await t()}catch(a){n?.(a)}return await a("END"),e}]},Ea=async(a,t,e,r,i,o=0)=>await a("INSERT "+(o?"OR REPLACE ":n)+"INTO"+F(t)+"("+F(e)+A(m(r,(a=>s+F(a))))+")VALUES"+ga(i,d(r)+1)+(o?n:"ON CONFLICT("+F(e)+")DO UPDATE SET"+A(m(r,(a=>F(a)+"=excluded."+F(a))),s)),m(i,(a=>a??null))),ga=(a,t)=>A(E(d(a)/t,(a=>"("+A(E(t,(e=>"$"+(a*t+e+1))),s)+")")),s),Aa=(a,t,e,n,s,r,i,[o,c,l],y,u,w,d,v,p)=>{const[E,g,A,m]=pa(t,y,u,s,v,p),h=va(a,(async()=>await m((async()=>{return await E(),a=(await g(o,c))[S]?.[l]??"null",ea(a,((a,t)=>""===t?void 0:t));var a}))),(async a=>await m((async()=>{var t;await E(),await A(o,c,{[S]:{[l]:(t=a()??null,ta(t,((a,t)=>void 0===t?"":t)))}},!0,!0)}))),e,n,s,i,{[d]:()=>w,destroy:()=>(h.stopAutoLoad().stopAutoSave(),r(),h)},w);return h},ma=(a,t,e,n,s,r,i,[o,l,[y,u,w]],d,p,E,g,A,m,h,$)=>{const[C,O,L,T]=pa(t,d,p,s,A,m,h,$),b=async(a,t)=>await v(ra(l,(async([e,n,s,r],i)=>{t&&!(i in a)||await L(e,n,a[i],s,r,t)}))),I=async(a,t)=>u?await L(w,f,{[S]:a},!0,!0,t):null,R=va(a,(async()=>await T((async()=>{await C();const a=await(async()=>K(N(await v(ra(o,(async([a,t],e)=>[a,await O(e,t)]))),(a=>!aa(a[1])))))(),t=await(async()=>y?(await O(w,f))[S]:{})();return aa(a)&&c(t)?void 0:[a,t]}))),(async(a,t)=>await T((async()=>{if(await C(),c(t)){const[t,e]=a();await b(t),await I(e)}else await b(t[0],!0),await I(t[1],!0)}))),e,n,s,i,{[g]:()=>E,destroy:()=>(R.stopAutoLoad().stopAutoSave(),r(),R)},E);return R},ha="ColumnName",Na="store",$a="json",Ca=Na+"TableName",Sa=Na+"Id"+ha,fa=Na+ha,Oa="autoLoadIntervalSeconds",La="rowId"+ha,Ta="tableId",ba="tableName",Ia="deleteEmptyColumns",Ra="deleteEmptyTable",Da={mode:$a,[Oa]:1},Ma={load:0,save:0,[ba]:e+"_values"},Pa=(a,t,e,n,s)=>{const r=na();return W(a,((a,i)=>{const o=w(X(Q(t,y(a)?{[e]:a}:a)),0,Z(t));c(o[0])||n(i,o[0])||(s(i,o[0]),ia(r,i,o))})),r},_a=(a,t,s,r,i,c,l,u,d,v,p="getDb",E)=>{let g,A,m;const h=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,c),[N,$,C,S]=(a=>{const t=(a=>Q(Da,y(a)?{[Ca]:a}:a??{}))(a),n=t[Oa];if(t.mode==$a){const a=t[Ca]??e;return[1,n,[a,t[Sa]??f,t[fa]??Na],la(a)]}const{tables:{load:s={},save:r={}}={},values:i={}}=t,o=w(X(Q(Ma,i)),0,Z(Ma)),c=o[2],l=la(c),u=la(c);return[0,n,[Pa(s,{[Ta]:null,[La]:f},Ta,(a=>U(u,a)),(a=>ya(l,a))),Pa(r,{[ba]:null,[La]:f,[Ia]:0,[Ra]:0},ba,((a,t)=>U(u,t)),((a,t)=>ya(l,t))),o],l]})(t);return(N?Aa:ma)(a,h,(a=>{let t;const e=()=>t=setInterval((async()=>{try{const[{d:t,s:e,c:n}]=await h(`${O} ${M} d,${P} s,TOTAL_CHANGES() c FROM ${D}${M} JOIN ${D}${P}`);t==g&&e==A&&n==m||(null!=g&&a(),g=t,A=e,m=n)}catch{}}),1e3*$),n=()=>{g=A=m=null,o(t)},s=r((t=>{S.has(t)&&(n(),a(),e())}));return e(),()=>{n(),i(s)}}),(a=>a()),l,u,d,C,q(S),(async(a,t)=>await a(`${O} t.name tn,c.name cn FROM ${_}list()t,${_}info(t.name)c ${L} t.schema='main'AND t.type IN('table','view')AND t.name IN(${x(t)})ORDER BY t.name,c.name`,t)),v,p,n,E,(a=>!0===a?1:!1===a?0:a),void 0)};exports.createExpoSqlitePersister=(t,e,n,s,r)=>_a(t,n,(async(a,t=[])=>await e.getAllAsync(a,t)),(t=>a.addDatabaseChangeListener((({tableName:a})=>t(a)))),(a=>a.remove()),s,r,(()=>0),3,e);
1
+ "use strict";var a=require("expo-sqlite");const t=a=>typeof a,e="tinybase",n="",s=",",r=t(n),i=Promise,o=clearInterval,c=a=>null==a,l=(a,t,e)=>c(a)?e?.():t(a),u=a=>t(a)==r,y=a=>Array.isArray(a),w=(a,t,e)=>a.slice(t,e),d=a=>a.length,v=async a=>i.all(a),p=a=>{throw Error(a)},E=(a,t)=>a.forEach(t),g=(a,t="")=>a.join(t),A=(a,t)=>a.map(t),m=a=>0==d(a),h=(a,t)=>a.filter(t),N=(a,...t)=>a.push(...t),$=a=>a.shift(),S="_",f="_id",C="SELECT",O="WHERE",T="TABLE",b="ALTER "+T,L="DELETE FROM",I=C+"*FROM",D="pragma_",R="data_version",M="schema_version",_="pragma_table_",P=a=>`"${a.replace(/"/g,'""')}"`,F=(a,t=[1])=>g(A(a,(()=>"$"+t[0]++)),s),x=(a,t)=>a?.has(t)??!1,U=a=>c(a)||0==(a=>a?.size??0)(a),j=a=>[...a?.values()??[]],q=(a,t)=>a?.forEach(t),B=(a,t)=>a?.delete(t),J=Object,Y=a=>J.getPrototypeOf(a),k=J.entries,z=J.keys,G=J.freeze,H=(a=[])=>J.fromEntries(a),K=(...a)=>J.assign({},...a),Q=(a,t)=>(delete a[t],a),V=(a,t)=>A(k(a),(([a,e])=>t(e,a))),W=a=>J.values(a),X=a=>d(z(a)),Z=a=>(a=>!c(a)&&l(Y(a),(a=>a==J.prototype||c(Y(a))),(()=>!0)))(a)&&0==X(a),aa=JSON.stringify,ta=JSON.parse,ea=a=>new Map(a),na=(a,t)=>a?.get(t),sa=(a,t)=>A([...a?.entries()??[]],(([a,e])=>t(e,a))),ra=(a,t,e)=>c(e)?(B(a,t),a):a?.set(t,e),ia=(a,t,e,n)=>(x(a,t)?n?.(na(a,t)):ra(a,t,e()),na(a,t)),oa=(a,t,e,n,s=0)=>l((e?ia:na)(a,t[s],s>d(t)-2?e:ea),(r=>{if(s>d(t)-2)return n?.(r)&&ra(a,t[s]),r;const i=oa(r,t,e,n,s+1);return U(r)&&ra(a,t[s]),i})),ca=a=>new Set(y(a)||c(a)?a:[a]),la=(a,t)=>a?.add(t),ua=/^\d+$/,ya=ea(),wa=ea(),da=(a,t,e,s,r,i,o,u={},w=[])=>{let v,g,A,m=0,h=0,S=0;ia(ya,w,(()=>0)),ia(wa,w,(()=>[]));const f=ea(),[C,O,T,b,L]=((a=1,t)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,t.getTransactionMergeableChanges,([[a],[t]])=>!Z(a)||!Z(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!Z(a)||!Z(t),t.setContent]:p("Store type not supported by this Persister"))(o,a),[I,D,R]=(()=>{let a;const[t,e]=(()=>{const a=[];let t=0;return[e=>(e?$(a):null)??n+t++,t=>{ua.test(t)&&d(a)<1e3&&N(a,t)}]})(),s=ea();return[(e,r,i,o=[],c=()=>[])=>{a??=Y;const l=t(1);return ra(s,l,[e,r,i,o,c]),la(oa(r,i??[n],ca),l),l},(t,e,...r)=>E(((a,t=[n])=>{const e=[],s=(a,n)=>n==d(t)?N(e,a):null===t[n]?q(a,(a=>s(a,n+1))):E([t[n],null],(t=>s(na(a,t),n+1)));return s(a,0),e})(t,e),(t=>q(t,(t=>na(s,t)[0](a,...e??[],...r))))),a=>l(na(s,a),(([,t,r])=>(oa(t,r??[n],void 0,(t=>(B(t,a),U(t)?1:0))),ra(s,a),e(a),r))),t=>l(na(s,t),(([t,,e=[],n,s])=>{const r=(...i)=>{const o=d(i);o==d(e)?t(a,...i,...s(i)):c(e[o])?E(n[o]?.(...i)??[],(a=>r(...i,a))):r(...i,e[o])};r()}))]})(),M=a=>{a!=m&&(m=a,D(f,void 0,m))},_=t=>{(C&&y(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},P=async a=>(2!=m&&(M(1),h++,await J((async()=>{try{const a=await t();y(a)?_(a):p("Content is not an array "+a)}catch(t){i?.(t),a&&L(a)}M(0)}))),Y),F=()=>(g&&(r(g),g=void 0),Y),x=async a=>(1!=m&&(M(2),S++,await J((async()=>{try{await e(O,a)}catch(a){i?.(a)}M(0)}))),Y),j=()=>(l(A,a.delListener),A=void 0,Y),J=async(...a)=>(N(na(wa,w),...a),await(async()=>{if(!na(ya,w)){for(ra(ya,w,1);!c(v=$(na(wa,w)));)try{await v()}catch(a){i?.(a)}ra(ya,w,0)}})(),Y),Y={load:P,startAutoLoad:async a=>{await F().load(a);try{g=await s((async(a,t)=>{t||a?2!=m&&(M(1),h++,_(t??a),M(0)):await P()}))}catch(a){i?.(a)}return Y},stopAutoLoad:F,isAutoLoading:()=>!c(g),save:x,startAutoSave:async()=>(await j().save(),A=a.addDidFinishTransactionListener((()=>{const a=T();b(a)&&x(a)})),Y),stopAutoSave:j,isAutoSaving:()=>!c(A),getStatus:()=>m,addStatusListener:a=>I(a,f),delListener:t=>(R(t),a),schedule:J,getStore:()=>a,destroy:()=>(na(wa,w).splice(0,void 0),F().stopAutoSave()),getStats:()=>({loads:h,saves:S}),...u};return G(Y)},va=(a,t,e,n,r,i=pa,o,l)=>{const u=ea();return[async()=>{u.clear(),A(await e(a,t),(({tn:a,cn:t})=>la(ia(u,a,ca),t)))},async(t,e)=>((a,t)=>x(na(u,a),t))(t,e)?H(h(A(await a(I+P(t)),(a=>{return[a[e],l?(t=Q(a,e),n=l,H(V(t,((a,t)=>[t,n(a,t)])))):Q(a,e)];var t,n})),(([a,t])=>!c(a)&&!Z(t)))):{},async(t,e,n,l,y,w=!1)=>{const d=ca();V(n??{},(a=>A(z(a??{}),(a=>la(d,a)))));const p=j(d);if(!w&&y&&m(p)&&x(u,t))return await a("DROP "+T+P(t)),void ra(u,t);const E=na(u,t),$=ca(j(E));if(m(p)||(x(u,t)?await v(A([e,...p],(async(n,s)=>{B($,n)||(await a(b+P(t)+"ADD"+P(n)+r),0==s&&await a("CREATE UNIQUE INDEX pk ON "+P(t)+`(${P(e)})`),la(E,n))}))):(await a("CREATE "+T+P(t)+`(${P(e)}${r} PRIMARY KEY${g(A(p,(a=>s+P(a)+r)))});`),ra(u,t,ca([e,...p])))),await v([...!w&&l?A(j($),(async n=>{n!=e&&(await a(b+P(t)+"DROP"+P(n)),B(E,n))})):[]]),w)c(n)?await a(L+P(t)+O+" true"):await v(V(n,(async(n,s)=>{c(n)?await a(L+P(t)+O+P(e)+"=$1",[s]):m(p)||await i(a,t,e,z(n),{[s]:o?A(W(n),o):W(n)},E)})));else if(m(p))x(u,t)&&await a(L+P(t)+O+" true");else{const s=h(j(na(u,t)),(a=>a!=e)),r={},c=[];V(n??{},((a,t)=>{r[t]=A(s,(t=>o?o(a?.[t]):a?.[t])),N(c,t)})),await i(a,t,e,s,r),await a(L+P(t)+O+P(e)+`NOT IN(${F(c)})`,c)}},async t=>{let e;await a("BEGIN");try{e=await t()}catch(a){n?.(a)}return await a("END"),e}]},pa=async(a,t,e,n,r)=>{const i=[1];await a("INSERT INTO"+P(t)+"("+((...a)=>g(A(a,P),s))(e,...n)+")VALUES"+g(V(r,(a=>"($"+i[0]+++","+F(a,i)+")")),s)+"ON CONFLICT("+P(e)+")DO UPDATE SET"+g(A(n,(a=>P(a)+"=excluded."+P(a))),s),V(r,((a,t)=>[t,...A(a,(a=>a??null))])).flat())},Ea=(a,t,e,n,s,r,i,[o,c,l],u,y,w,d,v,p)=>{const[E,g,A,m]=va(t,u,y,s,v,p),h=da(a,(async()=>await m((async()=>{return await E(),a=(await g(o,c))[S]?.[l]??"null",ta(a,((a,t)=>""===t?void 0:t));var a}))),(async a=>await m((async()=>{var t;await E(),await A(o,c,{[S]:{[l]:(t=a()??null,aa(t,((a,t)=>void 0===t?"":t)))}},!0,!0)}))),e,n,s,i,{[d]:()=>w,destroy:()=>(h.stopAutoLoad().stopAutoSave(),r(),h)},w);return h},ga=(a,t,e,n,s,r,i,[o,l,[u,y,w]],d,p,E,g,A,m,N,$)=>{const[C,O,T,b]=va(t,d,p,s,A,m,N,$),L=async(a,t)=>await v(sa(l,(async([e,n,s,r],i)=>{t&&!(i in a)||await T(e,n,a[i],s,r,t)}))),I=async(a,t)=>y?await T(w,f,{[S]:a},!0,!0,t):null,D=da(a,(async()=>await b((async()=>{await C();const a=await(async()=>H(h(await v(sa(o,(async([a,t],e)=>[a,await O(e,t)]))),(a=>!Z(a[1])))))(),t=await(async()=>u?(await O(w,f))[S]:{})();return Z(a)&&c(t)?void 0:[a,t]}))),(async(a,t)=>await b((async()=>{if(await C(),c(t)){const[t,e]=a();await L(t),await I(e)}else await L(t[0],!0),await I(t[1],!0)}))),e,n,s,i,{[g]:()=>E,destroy:()=>(D.stopAutoLoad().stopAutoSave(),r(),D)},E);return D},Aa="ColumnName",ma="store",ha="json",Na=ma+"TableName",$a=ma+"Id"+Aa,Sa=ma+Aa,fa="autoLoadIntervalSeconds",Ca="rowId"+Aa,Oa="tableId",Ta="tableName",ba="deleteEmptyColumns",La="deleteEmptyTable",Ia={mode:ha,[fa]:1},Da={load:0,save:0,[Ta]:e+"_values"},Ra=(a,t,e,n,s)=>{const r=ea();return V(a,((a,i)=>{const o=w(W(K(t,u(a)?{[e]:a}:a)),0,X(t));c(o[0])||n(i,o[0])||(s(i,o[0]),ra(r,i,o))})),r},Ma=(a,t,s,r,i,c,l,y,d,v,p="getDb",E)=>{let g,A,m;const h=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,c),[N,$,S,T]=(a=>{const t=(a=>K(Ia,u(a)?{[Na]:a}:a??{}))(a),n=t[fa];if(t.mode==ha){const a=t[Na]??e;return[1,n,[a,t[$a]??f,t[Sa]??ma],ca(a)]}const{tables:{load:s={},save:r={}}={},values:i={}}=t,o=w(W(K(Da,i)),0,X(Da)),c=o[2],l=ca(c),y=ca(c);return[0,n,[Ra(s,{[Oa]:null,[Ca]:f},Oa,(a=>x(y,a)),(a=>la(l,a))),Ra(r,{[Ta]:null,[Ca]:f,[ba]:0,[La]:0},Ta,((a,t)=>x(y,t)),((a,t)=>la(l,t))),o],l]})(t);return(N?Ea:ga)(a,h,(a=>{let t;const e=()=>t=setInterval((async()=>{try{const[{d:t,s:e,c:n}]=await h(`${C} ${R} d,${M} s,TOTAL_CHANGES() c FROM ${D}${R} JOIN ${D}${M}`);t==g&&e==A&&n==m||(null!=g&&a(),g=t,A=e,m=n)}catch{}}),1e3*$),n=()=>{g=A=m=null,o(t)},s=r((t=>{T.has(t)&&(n(),a(),e())}));return e(),()=>{n(),i(s)}}),(a=>a()),l,y,d,S,j(T),(async(a,t)=>await a(`${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(t)})ORDER BY t.name,c.name`,t)),v,p,n,E,(a=>!0===a?1:!1===a?0:a),void 0)};exports.createExpoSqlitePersister=(t,e,n,s,r)=>Ma(t,n,(async(a,t=[])=>await e.getAllAsync(a,t)),(t=>a.addDatabaseChangeListener((({tableName:a})=>t(a)))),(a=>a.remove()),s,r,(()=>0),3,e);
@@ -1 +1 @@
1
- "use strict";const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),r=Promise,i=clearInterval,o=a=>null==a,c=(a,t,e)=>o(a)?e?.():t(a),l=t=>a(t)==s,u=a=>Array.isArray(a),w=(a,t,e)=>a.slice(t,e),y=a=>a.length,d=async a=>r.all(a),v=a=>{throw Error(a)},E=(a,t)=>A(Array(a).fill(0),((a,e)=>t(e))),p=(a,t)=>a.forEach(t),g=(a,t="")=>a.join(t),A=(a,t)=>a.map(t),h=a=>0==y(a),m=(a,t)=>a.filter(t),N=(a,...t)=>a.push(...t),$=a=>a.shift(),C="_",S="_id",f="SELECT",O="WHERE",L="TABLE",T="ALTER "+L,b="DELETE FROM",I=f+"*FROM",R="pragma_",D="data_version",M="schema_version",P="pragma_table_",_=a=>`"${a.replace(/"/g,'""')}"`,F=a=>g(A(a,((a,t)=>"$"+(t+1))),n),U=(a,t)=>a?.has(t)??!1,j=a=>o(a)||0==(a=>a?.size??0)(a),x=a=>[...a?.values()??[]],B=(a,t)=>a?.forEach(t),J=(a,t)=>a?.delete(t),Y=Object,k=a=>Y.getPrototypeOf(a),q=Y.entries,z=Y.keys,G=Y.freeze,H=(a=[])=>Y.fromEntries(a),K=(...a)=>Y.assign({},...a),Q=(a,t)=>(delete a[t],a),V=(a,t)=>A(q(a),(([a,e])=>t(e,a))),W=a=>Y.values(a),X=a=>y(z(a)),Z=a=>(a=>!o(a)&&c(k(a),(a=>a==Y.prototype||o(k(a))),(()=>!0)))(a)&&0==X(a),aa=JSON.stringify,ta=JSON.parse,ea=a=>new Map(a),na=(a,t)=>a?.get(t),sa=(a,t)=>A([...a?.entries()??[]],(([a,e])=>t(e,a))),ra=(a,t,e)=>o(e)?(J(a,t),a):a?.set(t,e),ia=(a,t,e,n)=>(U(a,t)?n?.(na(a,t)):ra(a,t,e()),na(a,t)),oa=(a,t,e,n,s=0)=>c((e?ia:na)(a,t[s],s>y(t)-2?e:ea),(r=>{if(s>y(t)-2)return n?.(r)&&ra(a,t[s]),r;const i=oa(r,t,e,n,s+1);return j(r)&&ra(a,t[s]),i})),ca=a=>new Set(u(a)||o(a)?a:[a]),la=(a,t)=>a?.add(t),ua=/^\d+$/,wa=ea(),ya=ea(),da=(a,t,n,s,r,i,l,w={},d=[])=>{let E,g,A,h=0,m=0,C=0;ia(wa,d,(()=>0)),ia(ya,d,(()=>[]));const S=ea(),[f,O,L,T,b]=((a=1,t)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,t.getTransactionMergeableChanges,([[a],[t]])=>!Z(a)||!Z(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!Z(a)||!Z(t),t.setContent]:v("Store type not supported by this Persister"))(l,a),[I,R,D]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?$(a):null)??e+t++,t=>{ua.test(t)&&y(a)<1e3&&N(a,t)}]})(),s=ea();return[(n,r,i,o=[],c=()=>[])=>{a??=k;const l=t(1);return ra(s,l,[n,r,i,o,c]),la(oa(r,i??[e],ca),l),l},(t,n,...r)=>p(((a,t=[e])=>{const n=[],s=(a,e)=>e==y(t)?N(n,a):null===t[e]?B(a,(a=>s(a,e+1))):p([t[e],null],(t=>s(na(a,t),e+1)));return s(a,0),n})(t,n),(t=>B(t,(t=>na(s,t)[0](a,...n??[],...r))))),a=>c(na(s,a),(([,t,r])=>(oa(t,r??[e],void 0,(t=>(J(t,a),j(t)?1:0))),ra(s,a),n(a),r))),t=>c(na(s,t),(([t,,e=[],n,s])=>{const r=(...i)=>{const c=y(i);c==y(e)?t(a,...i,...s(i)):o(e[c])?p(n[c]?.(...i)??[],(a=>r(...i,a))):r(...i,e[c])};r()}))]})(),M=a=>{a!=h&&(h=a,R(S,void 0,h))},P=t=>{(f&&u(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},_=async a=>(2!=h&&(M(1),m++,await Y((async()=>{try{const a=await t();u(a)?P(a):v("Content is not an array "+a)}catch(t){i?.(t),a&&b(a)}M(0)}))),k),F=()=>(g&&(r(g),g=void 0),k),U=async a=>(1!=h&&(M(2),C++,await Y((async()=>{try{await n(O,a)}catch(a){i?.(a)}M(0)}))),k),x=()=>(c(A,a.delListener),A=void 0,k),Y=async(...a)=>(N(na(ya,d),...a),await(async()=>{if(!na(wa,d)){for(ra(wa,d,1);!o(E=$(na(ya,d)));)try{await E()}catch(a){i?.(a)}ra(wa,d,0)}})(),k),k={load:_,startAutoLoad:async a=>{await F().load(a);try{g=await s((async(a,t)=>{t||a?2!=h&&(M(1),m++,P(t??a),M(0)):await _()}))}catch(a){i?.(a)}return k},stopAutoLoad:F,isAutoLoading:()=>!o(g),save:U,startAutoSave:async()=>(await x().save(),A=a.addDidFinishTransactionListener((()=>{const a=L();T(a)&&U(a)})),k),stopAutoSave:x,isAutoSaving:()=>!o(A),getStatus:()=>h,addStatusListener:a=>I(a,S),delListener:t=>(D(t),a),schedule:Y,getStore:()=>a,destroy:()=>(na(ya,d).splice(0,void 0),F().stopAutoSave()),getStats:()=>({loads:m,saves:C}),...w};return G(k)},va=(a,t,e,s,r,i,c,l)=>{const u=ea();return[async()=>{u.clear(),A(await e(a,t),(({tn:a,cn:t})=>la(ia(u,a,ca),t)))},async(t,e)=>((a,t)=>U(na(u,a),t))(t,e)?H(m(A(await a(I+_(t)),(a=>{return[a[e],l?(t=Q(a,e),n=l,H(V(t,((a,t)=>[t,n(a,t)])))):Q(a,e)];var t,n})),(([a,t])=>!o(a)&&!Z(t)))):{},async(t,e,s,l,w,y=!1)=>{const v=ca();V(s??{},(a=>A(z(a??{}),(a=>la(v,a)))));const E=x(v);if(!y&&w&&h(E)&&U(u,t))return await a("DROP "+L+_(t)),void ra(u,t);const p=na(u,t),$=ca(x(p));if(h(E)||(U(u,t)?await d(A([e,...E],(async(n,s)=>{J($,n)||(await a(T+_(t)+"ADD"+_(n)+r),0==s&&await a("CREATE UNIQUE INDEX pk ON "+_(t)+`(${_(e)})`),la(p,n))}))):(await a("CREATE "+L+_(t)+`(${_(e)}${r} PRIMARY KEY${g(A(E,(a=>n+_(a)+r)))});`),ra(u,t,ca([e,...E])))),await d([...!y&&l?A(x($),(async n=>{n!=e&&(await a(T+_(t)+"DROP"+_(n)),J(p,n))})):[]]),y)o(s)?await a(b+_(t)+O+" true"):await d(V(s,(async(n,s)=>{o(n)?await a(b+_(t)+O+_(e)+"=$1",[s]):h(E)||await Ea(a,t,e,z(n),[s,...c?A(W(n),c):W(n)],i)})));else if(h(E))U(u,t)&&await a(b+_(t)+O+" true");else{const n=m(x(na(u,t)),(a=>a!=e)),r=[],o=[];V(s??{},((a,t)=>{N(r,t,...A(n,(t=>c?c(a?.[t]):a?.[t]))),N(o,t)})),await Ea(a,t,e,n,r,i),await a(b+_(t)+O+_(e)+`NOT IN(${F(o)})`,o)}},async t=>{let e;await a("BEGIN");try{e=await t()}catch(a){s?.(a)}return await a("END"),e}]},Ea=async(a,t,s,r,i,o=0)=>await a("INSERT "+(o?"OR REPLACE ":e)+"INTO"+_(t)+"("+_(s)+g(A(r,(a=>n+_(a))))+")VALUES"+pa(i,y(r)+1)+(o?e:"ON CONFLICT("+_(s)+")DO UPDATE SET"+g(A(r,(a=>_(a)+"=excluded."+_(a))),n)),A(i,(a=>a??null))),pa=(a,t)=>g(E(y(a)/t,(a=>"("+g(E(t,(e=>"$"+(a*t+e+1))),n)+")")),n),ga=(a,t,e,n,s,r,i,[o,c,l],u,w,y,d,v,E)=>{const[p,g,A,h]=va(t,u,w,s,v,E),m=da(a,(async()=>await h((async()=>{return await p(),a=(await g(o,c))[C]?.[l]??"null",ta(a,((a,t)=>""===t?void 0:t));var a}))),(async a=>await h((async()=>{var t;await p(),await A(o,c,{[C]:{[l]:(t=a()??null,aa(t,((a,t)=>void 0===t?"":t)))}},!0,!0)}))),e,n,s,i,{[d]:()=>y,destroy:()=>(m.stopAutoLoad().stopAutoSave(),r(),m)},y);return m},Aa=(a,t,e,n,s,r,i,[c,l,[u,w,y]],v,E,p,g,A,h,N,$)=>{const[f,O,L,T]=va(t,v,E,s,A,h,N,$),b=async(a,t)=>await d(sa(l,(async([e,n,s,r],i)=>{t&&!(i in a)||await L(e,n,a[i],s,r,t)}))),I=async(a,t)=>w?await L(y,S,{[C]:a},!0,!0,t):null,R=da(a,(async()=>await T((async()=>{await f();const a=await(async()=>H(m(await d(sa(c,(async([a,t],e)=>[a,await O(e,t)]))),(a=>!Z(a[1])))))(),t=await(async()=>u?(await O(y,S))[C]:{})();return Z(a)&&o(t)?void 0:[a,t]}))),(async(a,t)=>await T((async()=>{if(await f(),o(t)){const[t,e]=a();await b(t),await I(e)}else await b(t[0],!0),await I(t[1],!0)}))),e,n,s,i,{[g]:()=>p,destroy:()=>(R.stopAutoLoad().stopAutoSave(),r(),R)},p);return R},ha="ColumnName",ma="store",Na="json",$a=ma+"TableName",Ca=ma+"Id"+ha,Sa=ma+ha,fa="autoLoadIntervalSeconds",Oa="rowId"+ha,La="tableId",Ta="tableName",ba="deleteEmptyColumns",Ia="deleteEmptyTable",Ra={mode:Na,[fa]:1},Da={load:0,save:0,[Ta]:t+"_values"},Ma=(a,t,e,n,s)=>{const r=ea();return V(a,((a,i)=>{const c=w(W(K(t,l(a)?{[e]:a}:a)),0,X(t));o(c[0])||n(i,c[0])||(s(i,c[0]),ra(r,i,c))})),r},Pa=(a,n,s,r,o,c,u,y,d,v,E="getDb",p)=>{let g,A,h;const m=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,c),[N,$,C,L]=(a=>{const e=(a=>K(Ra,l(a)?{[$a]:a}:a??{}))(a),n=e[fa];if(e.mode==Na){const a=e[$a]??t;return[1,n,[a,e[Ca]??S,e[Sa]??ma],ca(a)]}const{tables:{load:s={},save:r={}}={},values:i={}}=e,o=w(W(K(Da,i)),0,X(Da)),c=o[2],u=ca(c),y=ca(c);return[0,n,[Ma(s,{[La]:null,[Oa]:S},La,(a=>U(y,a)),(a=>la(u,a))),Ma(r,{[Ta]:null,[Oa]:S,[ba]:0,[Ia]:0},Ta,((a,t)=>U(y,t)),((a,t)=>la(u,t))),o],u]})(n);return(N?ga:Aa)(a,m,(a=>{let t;const e=()=>t=setInterval((async()=>{try{const[{d:t,s:e,c:n}]=await m(`${f} ${D} d,${M} s,TOTAL_CHANGES() c FROM ${R}${D} JOIN ${R}${M}`);t==g&&e==A&&n==h||(null!=g&&a(),g=t,A=e,h=n)}catch{}}),1e3*$),n=()=>{g=A=h=null,i(t)},s=r((t=>{L.has(t)&&(n(),a(),e())}));return e(),()=>{n(),o(s)}}),(a=>a()),u,y,d,C,x(L),(async(a,t)=>await a(`${f} t.name tn,c.name cn FROM ${P}list()t,${P}info(t.name)c ${O} t.schema='main'AND t.type IN('table','view')AND t.name IN(${F(t)})ORDER BY t.name,c.name`,t)),v,E,e,p,(a=>!0===a?1:!1===a?0:a),void 0)};exports.createLibSqlPersister=(a,t,e,n,s)=>Pa(a,e,(async(a,e=[])=>(await t.execute({sql:a,args:e})).rows),(()=>()=>0),(a=>a()),n,s,(()=>0),1,t,"getClient");
1
+ "use strict";const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),i=Promise,r=clearInterval,o=a=>null==a,c=(a,t,e)=>o(a)?e?.():t(a),l=t=>a(t)==s,u=a=>Array.isArray(a),w=(a,t,e)=>a.slice(t,e),y=a=>a.length,d=async a=>i.all(a),v=a=>{throw Error(a)},p=(a,t)=>a.forEach(t),E=(a,t="")=>a.join(t),g=(a,t)=>a.map(t),A=a=>0==y(a),h=(a,t)=>a.filter(t),m=(a,...t)=>a.push(...t),N=a=>a.shift(),$="_",S="_id",f="SELECT",C="WHERE",O="TABLE",T="ALTER "+O,L="DELETE FROM",b=f+"*FROM",I="pragma_",D="data_version",R="schema_version",M="pragma_table_",_=a=>`"${a.replace(/"/g,'""')}"`,P=(a,t=[1])=>E(g(a,(()=>"$"+t[0]++)),n),F=(a,t)=>a?.has(t)??!1,U=a=>o(a)||0==(a=>a?.size??0)(a),j=a=>[...a?.values()??[]],x=(a,t)=>a?.forEach(t),B=(a,t)=>a?.delete(t),J=Object,Y=a=>J.getPrototypeOf(a),k=J.entries,q=J.keys,z=J.freeze,G=(a=[])=>J.fromEntries(a),H=(...a)=>J.assign({},...a),K=(a,t)=>(delete a[t],a),Q=(a,t)=>g(k(a),(([a,e])=>t(e,a))),V=a=>J.values(a),W=a=>y(q(a)),X=a=>(a=>!o(a)&&c(Y(a),(a=>a==J.prototype||o(Y(a))),(()=>!0)))(a)&&0==W(a),Z=JSON.stringify,aa=JSON.parse,ta=a=>new Map(a),ea=(a,t)=>a?.get(t),na=(a,t)=>g([...a?.entries()??[]],(([a,e])=>t(e,a))),sa=(a,t,e)=>o(e)?(B(a,t),a):a?.set(t,e),ia=(a,t,e,n)=>(F(a,t)?n?.(ea(a,t)):sa(a,t,e()),ea(a,t)),ra=(a,t,e,n,s=0)=>c((e?ia:ea)(a,t[s],s>y(t)-2?e:ta),(i=>{if(s>y(t)-2)return n?.(i)&&sa(a,t[s]),i;const r=ra(i,t,e,n,s+1);return U(i)&&sa(a,t[s]),r})),oa=a=>new Set(u(a)||o(a)?a:[a]),ca=(a,t)=>a?.add(t),la=/^\d+$/,ua=ta(),wa=ta(),ya=(a,t,n,s,i,r,l,w={},d=[])=>{let E,g,A,h=0,$=0,S=0;ia(ua,d,(()=>0)),ia(wa,d,(()=>[]));const f=ta(),[C,O,T,L,b]=((a=1,t)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,t.getTransactionMergeableChanges,([[a],[t]])=>!X(a)||!X(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!X(a)||!X(t),t.setContent]:v("Store type not supported by this Persister"))(l,a),[I,D,R]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?N(a):null)??e+t++,t=>{la.test(t)&&y(a)<1e3&&m(a,t)}]})(),s=ta();return[(n,i,r,o=[],c=()=>[])=>{a??=k;const l=t(1);return sa(s,l,[n,i,r,o,c]),ca(ra(i,r??[e],oa),l),l},(t,n,...i)=>p(((a,t=[e])=>{const n=[],s=(a,e)=>e==y(t)?m(n,a):null===t[e]?x(a,(a=>s(a,e+1))):p([t[e],null],(t=>s(ea(a,t),e+1)));return s(a,0),n})(t,n),(t=>x(t,(t=>ea(s,t)[0](a,...n??[],...i))))),a=>c(ea(s,a),(([,t,i])=>(ra(t,i??[e],void 0,(t=>(B(t,a),U(t)?1:0))),sa(s,a),n(a),i))),t=>c(ea(s,t),(([t,,e=[],n,s])=>{const i=(...r)=>{const c=y(r);c==y(e)?t(a,...r,...s(r)):o(e[c])?p(n[c]?.(...r)??[],(a=>i(...r,a))):i(...r,e[c])};i()}))]})(),M=a=>{a!=h&&(h=a,D(f,void 0,h))},_=t=>{(C&&u(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},P=async a=>(2!=h&&(M(1),$++,await Y((async()=>{try{const a=await t();u(a)?_(a):v("Content is not an array "+a)}catch(t){r?.(t),a&&b(a)}M(0)}))),k),F=()=>(g&&(i(g),g=void 0),k),j=async a=>(1!=h&&(M(2),S++,await Y((async()=>{try{await n(O,a)}catch(a){r?.(a)}M(0)}))),k),J=()=>(c(A,a.delListener),A=void 0,k),Y=async(...a)=>(m(ea(wa,d),...a),await(async()=>{if(!ea(ua,d)){for(sa(ua,d,1);!o(E=N(ea(wa,d)));)try{await E()}catch(a){r?.(a)}sa(ua,d,0)}})(),k),k={load:P,startAutoLoad:async a=>{await F().load(a);try{g=await s((async(a,t)=>{t||a?2!=h&&(M(1),$++,_(t??a),M(0)):await P()}))}catch(a){r?.(a)}return k},stopAutoLoad:F,isAutoLoading:()=>!o(g),save:j,startAutoSave:async()=>(await J().save(),A=a.addDidFinishTransactionListener((()=>{const a=T();L(a)&&j(a)})),k),stopAutoSave:J,isAutoSaving:()=>!o(A),getStatus:()=>h,addStatusListener:a=>I(a,f),delListener:t=>(R(t),a),schedule:Y,getStore:()=>a,destroy:()=>(ea(wa,d).splice(0,void 0),F().stopAutoSave()),getStats:()=>({loads:$,saves:S}),...w};return z(k)},da=(a,t,e,s,i,r=va,c,l)=>{const u=ta();return[async()=>{u.clear(),g(await e(a,t),(({tn:a,cn:t})=>ca(ia(u,a,oa),t)))},async(t,e)=>((a,t)=>F(ea(u,a),t))(t,e)?G(h(g(await a(b+_(t)),(a=>{return[a[e],l?(t=K(a,e),n=l,G(Q(t,((a,t)=>[t,n(a,t)])))):K(a,e)];var t,n})),(([a,t])=>!o(a)&&!X(t)))):{},async(t,e,s,l,w,y=!1)=>{const v=oa();Q(s??{},(a=>g(q(a??{}),(a=>ca(v,a)))));const p=j(v);if(!y&&w&&A(p)&&F(u,t))return await a("DROP "+O+_(t)),void sa(u,t);const N=ea(u,t),$=oa(j(N));if(A(p)||(F(u,t)?await d(g([e,...p],(async(n,s)=>{B($,n)||(await a(T+_(t)+"ADD"+_(n)+i),0==s&&await a("CREATE UNIQUE INDEX pk ON "+_(t)+`(${_(e)})`),ca(N,n))}))):(await a("CREATE "+O+_(t)+`(${_(e)}${i} PRIMARY KEY${E(g(p,(a=>n+_(a)+i)))});`),sa(u,t,oa([e,...p])))),await d([...!y&&l?g(j($),(async n=>{n!=e&&(await a(T+_(t)+"DROP"+_(n)),B(N,n))})):[]]),y)o(s)?await a(L+_(t)+C+" true"):await d(Q(s,(async(n,s)=>{o(n)?await a(L+_(t)+C+_(e)+"=$1",[s]):A(p)||await r(a,t,e,q(n),{[s]:c?g(V(n),c):V(n)},N)})));else if(A(p))F(u,t)&&await a(L+_(t)+C+" true");else{const n=h(j(ea(u,t)),(a=>a!=e)),i={},o=[];Q(s??{},((a,t)=>{i[t]=g(n,(t=>c?c(a?.[t]):a?.[t])),m(o,t)})),await r(a,t,e,n,i),await a(L+_(t)+C+_(e)+`NOT IN(${P(o)})`,o)}},async t=>{let e;await a("BEGIN");try{e=await t()}catch(a){s?.(a)}return await a("END"),e}]},va=async(a,t,e,s,i)=>{const r=[1];await a("INSERT INTO"+_(t)+"("+((...a)=>E(g(a,_),n))(e,...s)+")VALUES"+E(Q(i,(a=>"($"+r[0]+++","+P(a,r)+")")),n)+"ON CONFLICT("+_(e)+")DO UPDATE SET"+E(g(s,(a=>_(a)+"=excluded."+_(a))),n),Q(i,((a,t)=>[t,...g(a,(a=>a??null))])).flat())},pa=(a,t,e,n,s,i,r,[o,c,l],u,w,y,d,v,p)=>{const[E,g,A,h]=da(t,u,w,s,v,p),m=ya(a,(async()=>await h((async()=>{return await E(),a=(await g(o,c))[$]?.[l]??"null",aa(a,((a,t)=>""===t?void 0:t));var a}))),(async a=>await h((async()=>{var t;await E(),await A(o,c,{[$]:{[l]:(t=a()??null,Z(t,((a,t)=>void 0===t?"":t)))}},!0,!0)}))),e,n,s,r,{[d]:()=>y,destroy:()=>(m.stopAutoLoad().stopAutoSave(),i(),m)},y);return m},Ea=(a,t,e,n,s,i,r,[c,l,[u,w,y]],v,p,E,g,A,m,N,f)=>{const[C,O,T,L]=da(t,v,p,s,A,m,N,f),b=async(a,t)=>await d(na(l,(async([e,n,s,i],r)=>{t&&!(r in a)||await T(e,n,a[r],s,i,t)}))),I=async(a,t)=>w?await T(y,S,{[$]:a},!0,!0,t):null,D=ya(a,(async()=>await L((async()=>{await C();const a=await(async()=>G(h(await d(na(c,(async([a,t],e)=>[a,await O(e,t)]))),(a=>!X(a[1])))))(),t=await(async()=>u?(await O(y,S))[$]:{})();return X(a)&&o(t)?void 0:[a,t]}))),(async(a,t)=>await L((async()=>{if(await C(),o(t)){const[t,e]=a();await b(t),await I(e)}else await b(t[0],!0),await I(t[1],!0)}))),e,n,s,r,{[g]:()=>E,destroy:()=>(D.stopAutoLoad().stopAutoSave(),i(),D)},E);return D},ga="ColumnName",Aa="store",ha="json",ma=Aa+"TableName",Na=Aa+"Id"+ga,$a=Aa+ga,Sa="autoLoadIntervalSeconds",fa="rowId"+ga,Ca="tableId",Oa="tableName",Ta="deleteEmptyColumns",La="deleteEmptyTable",ba={mode:ha,[Sa]:1},Ia={load:0,save:0,[Oa]:t+"_values"},Da=(a,t,e,n,s)=>{const i=ta();return Q(a,((a,r)=>{const c=w(V(H(t,l(a)?{[e]:a}:a)),0,W(t));o(c[0])||n(r,c[0])||(s(r,c[0]),sa(i,r,c))})),i},Ra=(a,n,s,i,o,c,u,y,d,v,p="getDb",E)=>{let g,A,h;const m=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,c),[N,$,O,T]=(a=>{const e=(a=>H(ba,l(a)?{[ma]:a}:a??{}))(a),n=e[Sa];if(e.mode==ha){const a=e[ma]??t;return[1,n,[a,e[Na]??S,e[$a]??Aa],oa(a)]}const{tables:{load:s={},save:i={}}={},values:r={}}=e,o=w(V(H(Ia,r)),0,W(Ia)),c=o[2],u=oa(c),y=oa(c);return[0,n,[Da(s,{[Ca]:null,[fa]:S},Ca,(a=>F(y,a)),(a=>ca(u,a))),Da(i,{[Oa]:null,[fa]:S,[Ta]:0,[La]:0},Oa,((a,t)=>F(y,t)),((a,t)=>ca(u,t))),o],u]})(n);return(N?pa:Ea)(a,m,(a=>{let t;const e=()=>t=setInterval((async()=>{try{const[{d:t,s:e,c:n}]=await m(`${f} ${D} d,${R} s,TOTAL_CHANGES() c FROM ${I}${D} JOIN ${I}${R}`);t==g&&e==A&&n==h||(null!=g&&a(),g=t,A=e,h=n)}catch{}}),1e3*$),n=()=>{g=A=h=null,r(t)},s=i((t=>{T.has(t)&&(n(),a(),e())}));return e(),()=>{n(),o(s)}}),(a=>a()),u,y,d,O,j(T),(async(a,t)=>await a(`${f} t.name tn,c.name cn FROM ${M}list()t,${M}info(t.name)c ${C} t.schema='main'AND t.type IN('table','view')AND t.name IN(${P(t)})ORDER BY t.name,c.name`,t)),v,p,e,E,(a=>!0===a?1:!1===a?0:a),void 0)};exports.createLibSqlPersister=(a,t,e,n,s)=>Ra(a,e,(async(a,e=[])=>(await t.execute({sql:a,args:e})).rows),(()=>()=>0),(a=>a()),n,s,(()=>0),1,t,"getClient");
@@ -1 +1 @@
1
- "use strict";const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),r=Promise,i=clearInterval,o=a=>null==a,c=(a,t,e)=>o(a)?e?.():t(a),l=t=>a(t)==s,u=a=>Array.isArray(a),w=(a,t,e)=>a.slice(t,e),y=a=>a.length,d=async a=>r.all(a),v=a=>{throw Error(a)},E=(a,t)=>A(Array(a).fill(0),((a,e)=>t(e))),p=(a,t)=>a.forEach(t),g=(a,t="")=>a.join(t),A=(a,t)=>a.map(t),h=a=>0==y(a),m=(a,t)=>a.filter(t),N=(a,...t)=>a.push(...t),$=a=>a.shift(),C="_",S="_id",f="SELECT",O="WHERE",L="TABLE",T="ALTER "+L,b="DELETE FROM",I=f+"*FROM",R="pragma_",D="data_version",M="schema_version",P="pragma_table_",_=a=>`"${a.replace(/"/g,'""')}"`,F=a=>g(A(a,((a,t)=>"$"+(t+1))),n),U=(a,t)=>a?.has(t)??!1,j=a=>o(a)||0==(a=>a?.size??0)(a),x=a=>[...a?.values()??[]],B=(a,t)=>a?.forEach(t),J=(a,t)=>a?.delete(t),Y=Object,k=a=>Y.getPrototypeOf(a),q=Y.entries,z=Y.keys,G=Y.freeze,H=(a=[])=>Y.fromEntries(a),K=(...a)=>Y.assign({},...a),Q=(a,t)=>(delete a[t],a),V=(a,t)=>A(q(a),(([a,e])=>t(e,a))),W=a=>Y.values(a),X=a=>y(z(a)),Z=a=>(a=>!o(a)&&c(k(a),(a=>a==Y.prototype||o(k(a))),(()=>!0)))(a)&&0==X(a),aa=JSON.stringify,ta=JSON.parse,ea=a=>new Map(a),na=(a,t)=>a?.get(t),sa=(a,t)=>A([...a?.entries()??[]],(([a,e])=>t(e,a))),ra=(a,t,e)=>o(e)?(J(a,t),a):a?.set(t,e),ia=(a,t,e,n)=>(U(a,t)?n?.(na(a,t)):ra(a,t,e()),na(a,t)),oa=(a,t,e,n,s=0)=>c((e?ia:na)(a,t[s],s>y(t)-2?e:ea),(r=>{if(s>y(t)-2)return n?.(r)&&ra(a,t[s]),r;const i=oa(r,t,e,n,s+1);return j(r)&&ra(a,t[s]),i})),ca=a=>new Set(u(a)||o(a)?a:[a]),la=(a,t)=>a?.add(t),ua=/^\d+$/,wa=ea(),ya=ea(),da=(a,t,n,s,r,i,l,w={},d=[])=>{let E,g,A,h=0,m=0,C=0;ia(wa,d,(()=>0)),ia(ya,d,(()=>[]));const S=ea(),[f,O,L,T,b]=((a=1,t)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,t.getTransactionMergeableChanges,([[a],[t]])=>!Z(a)||!Z(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!Z(a)||!Z(t),t.setContent]:v("Store type not supported by this Persister"))(l,a),[I,R,D]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?$(a):null)??e+t++,t=>{ua.test(t)&&y(a)<1e3&&N(a,t)}]})(),s=ea();return[(n,r,i,o=[],c=()=>[])=>{a??=k;const l=t(1);return ra(s,l,[n,r,i,o,c]),la(oa(r,i??[e],ca),l),l},(t,n,...r)=>p(((a,t=[e])=>{const n=[],s=(a,e)=>e==y(t)?N(n,a):null===t[e]?B(a,(a=>s(a,e+1))):p([t[e],null],(t=>s(na(a,t),e+1)));return s(a,0),n})(t,n),(t=>B(t,(t=>na(s,t)[0](a,...n??[],...r))))),a=>c(na(s,a),(([,t,r])=>(oa(t,r??[e],void 0,(t=>(J(t,a),j(t)?1:0))),ra(s,a),n(a),r))),t=>c(na(s,t),(([t,,e=[],n,s])=>{const r=(...i)=>{const c=y(i);c==y(e)?t(a,...i,...s(i)):o(e[c])?p(n[c]?.(...i)??[],(a=>r(...i,a))):r(...i,e[c])};r()}))]})(),M=a=>{a!=h&&(h=a,R(S,void 0,h))},P=t=>{(f&&u(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},_=async a=>(2!=h&&(M(1),m++,await Y((async()=>{try{const a=await t();u(a)?P(a):v("Content is not an array "+a)}catch(t){i?.(t),a&&b(a)}M(0)}))),k),F=()=>(g&&(r(g),g=void 0),k),U=async a=>(1!=h&&(M(2),C++,await Y((async()=>{try{await n(O,a)}catch(a){i?.(a)}M(0)}))),k),x=()=>(c(A,a.delListener),A=void 0,k),Y=async(...a)=>(N(na(ya,d),...a),await(async()=>{if(!na(wa,d)){for(ra(wa,d,1);!o(E=$(na(ya,d)));)try{await E()}catch(a){i?.(a)}ra(wa,d,0)}})(),k),k={load:_,startAutoLoad:async a=>{await F().load(a);try{g=await s((async(a,t)=>{t||a?2!=h&&(M(1),m++,P(t??a),M(0)):await _()}))}catch(a){i?.(a)}return k},stopAutoLoad:F,isAutoLoading:()=>!o(g),save:U,startAutoSave:async()=>(await x().save(),A=a.addDidFinishTransactionListener((()=>{const a=L();T(a)&&U(a)})),k),stopAutoSave:x,isAutoSaving:()=>!o(A),getStatus:()=>h,addStatusListener:a=>I(a,S),delListener:t=>(D(t),a),schedule:Y,getStore:()=>a,destroy:()=>(na(ya,d).splice(0,void 0),F().stopAutoSave()),getStats:()=>({loads:m,saves:C}),...w};return G(k)},va=(a,t,e,s,r,i,c,l)=>{const u=ea();return[async()=>{u.clear(),A(await e(a,t),(({tn:a,cn:t})=>la(ia(u,a,ca),t)))},async(t,e)=>((a,t)=>U(na(u,a),t))(t,e)?H(m(A(await a(I+_(t)),(a=>{return[a[e],l?(t=Q(a,e),n=l,H(V(t,((a,t)=>[t,n(a,t)])))):Q(a,e)];var t,n})),(([a,t])=>!o(a)&&!Z(t)))):{},async(t,e,s,l,w,y=!1)=>{const v=ca();V(s??{},(a=>A(z(a??{}),(a=>la(v,a)))));const E=x(v);if(!y&&w&&h(E)&&U(u,t))return await a("DROP "+L+_(t)),void ra(u,t);const p=na(u,t),$=ca(x(p));if(h(E)||(U(u,t)?await d(A([e,...E],(async(n,s)=>{J($,n)||(await a(T+_(t)+"ADD"+_(n)+r),0==s&&await a("CREATE UNIQUE INDEX pk ON "+_(t)+`(${_(e)})`),la(p,n))}))):(await a("CREATE "+L+_(t)+`(${_(e)}${r} PRIMARY KEY${g(A(E,(a=>n+_(a)+r)))});`),ra(u,t,ca([e,...E])))),await d([...!y&&l?A(x($),(async n=>{n!=e&&(await a(T+_(t)+"DROP"+_(n)),J(p,n))})):[]]),y)o(s)?await a(b+_(t)+O+" true"):await d(V(s,(async(n,s)=>{o(n)?await a(b+_(t)+O+_(e)+"=$1",[s]):h(E)||await Ea(a,t,e,z(n),[s,...c?A(W(n),c):W(n)],i)})));else if(h(E))U(u,t)&&await a(b+_(t)+O+" true");else{const n=m(x(na(u,t)),(a=>a!=e)),r=[],o=[];V(s??{},((a,t)=>{N(r,t,...A(n,(t=>c?c(a?.[t]):a?.[t]))),N(o,t)})),await Ea(a,t,e,n,r,i),await a(b+_(t)+O+_(e)+`NOT IN(${F(o)})`,o)}},async t=>{let e;await a("BEGIN");try{e=await t()}catch(a){s?.(a)}return await a("END"),e}]},Ea=async(a,t,s,r,i,o=0)=>await a("INSERT "+(o?"OR REPLACE ":e)+"INTO"+_(t)+"("+_(s)+g(A(r,(a=>n+_(a))))+")VALUES"+pa(i,y(r)+1)+(o?e:"ON CONFLICT("+_(s)+")DO UPDATE SET"+g(A(r,(a=>_(a)+"=excluded."+_(a))),n)),A(i,(a=>a??null))),pa=(a,t)=>g(E(y(a)/t,(a=>"("+g(E(t,(e=>"$"+(a*t+e+1))),n)+")")),n),ga=(a,t,e,n,s,r,i,[o,c,l],u,w,y,d,v,E)=>{const[p,g,A,h]=va(t,u,w,s,v,E),m=da(a,(async()=>await h((async()=>{return await p(),a=(await g(o,c))[C]?.[l]??"null",ta(a,((a,t)=>""===t?void 0:t));var a}))),(async a=>await h((async()=>{var t;await p(),await A(o,c,{[C]:{[l]:(t=a()??null,aa(t,((a,t)=>void 0===t?"":t)))}},!0,!0)}))),e,n,s,i,{[d]:()=>y,destroy:()=>(m.stopAutoLoad().stopAutoSave(),r(),m)},y);return m},Aa=(a,t,e,n,s,r,i,[c,l,[u,w,y]],v,E,p,g,A,h,N,$)=>{const[f,O,L,T]=va(t,v,E,s,A,h,N,$),b=async(a,t)=>await d(sa(l,(async([e,n,s,r],i)=>{t&&!(i in a)||await L(e,n,a[i],s,r,t)}))),I=async(a,t)=>w?await L(y,S,{[C]:a},!0,!0,t):null,R=da(a,(async()=>await T((async()=>{await f();const a=await(async()=>H(m(await d(sa(c,(async([a,t],e)=>[a,await O(e,t)]))),(a=>!Z(a[1])))))(),t=await(async()=>u?(await O(y,S))[C]:{})();return Z(a)&&o(t)?void 0:[a,t]}))),(async(a,t)=>await T((async()=>{if(await f(),o(t)){const[t,e]=a();await b(t),await I(e)}else await b(t[0],!0),await I(t[1],!0)}))),e,n,s,i,{[g]:()=>p,destroy:()=>(R.stopAutoLoad().stopAutoSave(),r(),R)},p);return R},ha="ColumnName",ma="store",Na="json",$a=ma+"TableName",Ca=ma+"Id"+ha,Sa=ma+ha,fa="autoLoadIntervalSeconds",Oa="rowId"+ha,La="tableId",Ta="tableName",ba="deleteEmptyColumns",Ia="deleteEmptyTable",Ra={mode:Na,[fa]:1},Da={load:0,save:0,[Ta]:t+"_values"},Ma=(a,t,e,n,s)=>{const r=ea();return V(a,((a,i)=>{const c=w(W(K(t,l(a)?{[e]:a}:a)),0,X(t));o(c[0])||n(i,c[0])||(s(i,c[0]),ra(r,i,c))})),r},Pa=(a,n,s,r,o,c,u,y,d,v,E="getDb",p)=>{let g,A,h;const m=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,c),[N,$,C,L]=(a=>{const e=(a=>K(Ra,l(a)?{[$a]:a}:a??{}))(a),n=e[fa];if(e.mode==Na){const a=e[$a]??t;return[1,n,[a,e[Ca]??S,e[Sa]??ma],ca(a)]}const{tables:{load:s={},save:r={}}={},values:i={}}=e,o=w(W(K(Da,i)),0,X(Da)),c=o[2],u=ca(c),y=ca(c);return[0,n,[Ma(s,{[La]:null,[Oa]:S},La,(a=>U(y,a)),(a=>la(u,a))),Ma(r,{[Ta]:null,[Oa]:S,[ba]:0,[Ia]:0},Ta,((a,t)=>U(y,t)),((a,t)=>la(u,t))),o],u]})(n);return(N?ga:Aa)(a,m,(a=>{let t;const e=()=>t=setInterval((async()=>{try{const[{d:t,s:e,c:n}]=await m(`${f} ${D} d,${M} s,TOTAL_CHANGES() c FROM ${R}${D} JOIN ${R}${M}`);t==g&&e==A&&n==h||(null!=g&&a(),g=t,A=e,h=n)}catch{}}),1e3*$),n=()=>{g=A=h=null,i(t)},s=r((t=>{L.has(t)&&(n(),a(),e())}));return e(),()=>{n(),o(s)}}),(a=>a()),u,y,d,C,x(L),(async(a,t)=>await a(`${f} t.name tn,c.name cn FROM ${P}list()t,${P}info(t.name)c ${O} t.schema='main'AND t.type IN('table','view')AND t.name IN(${F(t)})ORDER BY t.name,c.name`,t)),v,E,e,p,(a=>!0===a?1:!1===a?0:a),void 0)};exports.createLibSqlPersister=(a,t,e,n,s)=>Pa(a,e,(async(a,e=[])=>(await t.execute({sql:a,args:e})).rows),(()=>()=>0),(a=>a()),n,s,(()=>0),1,t,"getClient");
1
+ "use strict";const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),i=Promise,r=clearInterval,o=a=>null==a,c=(a,t,e)=>o(a)?e?.():t(a),l=t=>a(t)==s,u=a=>Array.isArray(a),w=(a,t,e)=>a.slice(t,e),y=a=>a.length,d=async a=>i.all(a),v=a=>{throw Error(a)},p=(a,t)=>a.forEach(t),E=(a,t="")=>a.join(t),g=(a,t)=>a.map(t),A=a=>0==y(a),h=(a,t)=>a.filter(t),m=(a,...t)=>a.push(...t),N=a=>a.shift(),$="_",S="_id",f="SELECT",C="WHERE",O="TABLE",T="ALTER "+O,L="DELETE FROM",b=f+"*FROM",I="pragma_",D="data_version",R="schema_version",M="pragma_table_",_=a=>`"${a.replace(/"/g,'""')}"`,P=(a,t=[1])=>E(g(a,(()=>"$"+t[0]++)),n),F=(a,t)=>a?.has(t)??!1,U=a=>o(a)||0==(a=>a?.size??0)(a),j=a=>[...a?.values()??[]],x=(a,t)=>a?.forEach(t),B=(a,t)=>a?.delete(t),J=Object,Y=a=>J.getPrototypeOf(a),k=J.entries,q=J.keys,z=J.freeze,G=(a=[])=>J.fromEntries(a),H=(...a)=>J.assign({},...a),K=(a,t)=>(delete a[t],a),Q=(a,t)=>g(k(a),(([a,e])=>t(e,a))),V=a=>J.values(a),W=a=>y(q(a)),X=a=>(a=>!o(a)&&c(Y(a),(a=>a==J.prototype||o(Y(a))),(()=>!0)))(a)&&0==W(a),Z=JSON.stringify,aa=JSON.parse,ta=a=>new Map(a),ea=(a,t)=>a?.get(t),na=(a,t)=>g([...a?.entries()??[]],(([a,e])=>t(e,a))),sa=(a,t,e)=>o(e)?(B(a,t),a):a?.set(t,e),ia=(a,t,e,n)=>(F(a,t)?n?.(ea(a,t)):sa(a,t,e()),ea(a,t)),ra=(a,t,e,n,s=0)=>c((e?ia:ea)(a,t[s],s>y(t)-2?e:ta),(i=>{if(s>y(t)-2)return n?.(i)&&sa(a,t[s]),i;const r=ra(i,t,e,n,s+1);return U(i)&&sa(a,t[s]),r})),oa=a=>new Set(u(a)||o(a)?a:[a]),ca=(a,t)=>a?.add(t),la=/^\d+$/,ua=ta(),wa=ta(),ya=(a,t,n,s,i,r,l,w={},d=[])=>{let E,g,A,h=0,$=0,S=0;ia(ua,d,(()=>0)),ia(wa,d,(()=>[]));const f=ta(),[C,O,T,L,b]=((a=1,t)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,t.getTransactionMergeableChanges,([[a],[t]])=>!X(a)||!X(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!X(a)||!X(t),t.setContent]:v("Store type not supported by this Persister"))(l,a),[I,D,R]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?N(a):null)??e+t++,t=>{la.test(t)&&y(a)<1e3&&m(a,t)}]})(),s=ta();return[(n,i,r,o=[],c=()=>[])=>{a??=k;const l=t(1);return sa(s,l,[n,i,r,o,c]),ca(ra(i,r??[e],oa),l),l},(t,n,...i)=>p(((a,t=[e])=>{const n=[],s=(a,e)=>e==y(t)?m(n,a):null===t[e]?x(a,(a=>s(a,e+1))):p([t[e],null],(t=>s(ea(a,t),e+1)));return s(a,0),n})(t,n),(t=>x(t,(t=>ea(s,t)[0](a,...n??[],...i))))),a=>c(ea(s,a),(([,t,i])=>(ra(t,i??[e],void 0,(t=>(B(t,a),U(t)?1:0))),sa(s,a),n(a),i))),t=>c(ea(s,t),(([t,,e=[],n,s])=>{const i=(...r)=>{const c=y(r);c==y(e)?t(a,...r,...s(r)):o(e[c])?p(n[c]?.(...r)??[],(a=>i(...r,a))):i(...r,e[c])};i()}))]})(),M=a=>{a!=h&&(h=a,D(f,void 0,h))},_=t=>{(C&&u(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},P=async a=>(2!=h&&(M(1),$++,await Y((async()=>{try{const a=await t();u(a)?_(a):v("Content is not an array "+a)}catch(t){r?.(t),a&&b(a)}M(0)}))),k),F=()=>(g&&(i(g),g=void 0),k),j=async a=>(1!=h&&(M(2),S++,await Y((async()=>{try{await n(O,a)}catch(a){r?.(a)}M(0)}))),k),J=()=>(c(A,a.delListener),A=void 0,k),Y=async(...a)=>(m(ea(wa,d),...a),await(async()=>{if(!ea(ua,d)){for(sa(ua,d,1);!o(E=N(ea(wa,d)));)try{await E()}catch(a){r?.(a)}sa(ua,d,0)}})(),k),k={load:P,startAutoLoad:async a=>{await F().load(a);try{g=await s((async(a,t)=>{t||a?2!=h&&(M(1),$++,_(t??a),M(0)):await P()}))}catch(a){r?.(a)}return k},stopAutoLoad:F,isAutoLoading:()=>!o(g),save:j,startAutoSave:async()=>(await J().save(),A=a.addDidFinishTransactionListener((()=>{const a=T();L(a)&&j(a)})),k),stopAutoSave:J,isAutoSaving:()=>!o(A),getStatus:()=>h,addStatusListener:a=>I(a,f),delListener:t=>(R(t),a),schedule:Y,getStore:()=>a,destroy:()=>(ea(wa,d).splice(0,void 0),F().stopAutoSave()),getStats:()=>({loads:$,saves:S}),...w};return z(k)},da=(a,t,e,s,i,r=va,c,l)=>{const u=ta();return[async()=>{u.clear(),g(await e(a,t),(({tn:a,cn:t})=>ca(ia(u,a,oa),t)))},async(t,e)=>((a,t)=>F(ea(u,a),t))(t,e)?G(h(g(await a(b+_(t)),(a=>{return[a[e],l?(t=K(a,e),n=l,G(Q(t,((a,t)=>[t,n(a,t)])))):K(a,e)];var t,n})),(([a,t])=>!o(a)&&!X(t)))):{},async(t,e,s,l,w,y=!1)=>{const v=oa();Q(s??{},(a=>g(q(a??{}),(a=>ca(v,a)))));const p=j(v);if(!y&&w&&A(p)&&F(u,t))return await a("DROP "+O+_(t)),void sa(u,t);const N=ea(u,t),$=oa(j(N));if(A(p)||(F(u,t)?await d(g([e,...p],(async(n,s)=>{B($,n)||(await a(T+_(t)+"ADD"+_(n)+i),0==s&&await a("CREATE UNIQUE INDEX pk ON "+_(t)+`(${_(e)})`),ca(N,n))}))):(await a("CREATE "+O+_(t)+`(${_(e)}${i} PRIMARY KEY${E(g(p,(a=>n+_(a)+i)))});`),sa(u,t,oa([e,...p])))),await d([...!y&&l?g(j($),(async n=>{n!=e&&(await a(T+_(t)+"DROP"+_(n)),B(N,n))})):[]]),y)o(s)?await a(L+_(t)+C+" true"):await d(Q(s,(async(n,s)=>{o(n)?await a(L+_(t)+C+_(e)+"=$1",[s]):A(p)||await r(a,t,e,q(n),{[s]:c?g(V(n),c):V(n)},N)})));else if(A(p))F(u,t)&&await a(L+_(t)+C+" true");else{const n=h(j(ea(u,t)),(a=>a!=e)),i={},o=[];Q(s??{},((a,t)=>{i[t]=g(n,(t=>c?c(a?.[t]):a?.[t])),m(o,t)})),await r(a,t,e,n,i),await a(L+_(t)+C+_(e)+`NOT IN(${P(o)})`,o)}},async t=>{let e;await a("BEGIN");try{e=await t()}catch(a){s?.(a)}return await a("END"),e}]},va=async(a,t,e,s,i)=>{const r=[1];await a("INSERT INTO"+_(t)+"("+((...a)=>E(g(a,_),n))(e,...s)+")VALUES"+E(Q(i,(a=>"($"+r[0]+++","+P(a,r)+")")),n)+"ON CONFLICT("+_(e)+")DO UPDATE SET"+E(g(s,(a=>_(a)+"=excluded."+_(a))),n),Q(i,((a,t)=>[t,...g(a,(a=>a??null))])).flat())},pa=(a,t,e,n,s,i,r,[o,c,l],u,w,y,d,v,p)=>{const[E,g,A,h]=da(t,u,w,s,v,p),m=ya(a,(async()=>await h((async()=>{return await E(),a=(await g(o,c))[$]?.[l]??"null",aa(a,((a,t)=>""===t?void 0:t));var a}))),(async a=>await h((async()=>{var t;await E(),await A(o,c,{[$]:{[l]:(t=a()??null,Z(t,((a,t)=>void 0===t?"":t)))}},!0,!0)}))),e,n,s,r,{[d]:()=>y,destroy:()=>(m.stopAutoLoad().stopAutoSave(),i(),m)},y);return m},Ea=(a,t,e,n,s,i,r,[c,l,[u,w,y]],v,p,E,g,A,m,N,f)=>{const[C,O,T,L]=da(t,v,p,s,A,m,N,f),b=async(a,t)=>await d(na(l,(async([e,n,s,i],r)=>{t&&!(r in a)||await T(e,n,a[r],s,i,t)}))),I=async(a,t)=>w?await T(y,S,{[$]:a},!0,!0,t):null,D=ya(a,(async()=>await L((async()=>{await C();const a=await(async()=>G(h(await d(na(c,(async([a,t],e)=>[a,await O(e,t)]))),(a=>!X(a[1])))))(),t=await(async()=>u?(await O(y,S))[$]:{})();return X(a)&&o(t)?void 0:[a,t]}))),(async(a,t)=>await L((async()=>{if(await C(),o(t)){const[t,e]=a();await b(t),await I(e)}else await b(t[0],!0),await I(t[1],!0)}))),e,n,s,r,{[g]:()=>E,destroy:()=>(D.stopAutoLoad().stopAutoSave(),i(),D)},E);return D},ga="ColumnName",Aa="store",ha="json",ma=Aa+"TableName",Na=Aa+"Id"+ga,$a=Aa+ga,Sa="autoLoadIntervalSeconds",fa="rowId"+ga,Ca="tableId",Oa="tableName",Ta="deleteEmptyColumns",La="deleteEmptyTable",ba={mode:ha,[Sa]:1},Ia={load:0,save:0,[Oa]:t+"_values"},Da=(a,t,e,n,s)=>{const i=ta();return Q(a,((a,r)=>{const c=w(V(H(t,l(a)?{[e]:a}:a)),0,W(t));o(c[0])||n(r,c[0])||(s(r,c[0]),sa(i,r,c))})),i},Ra=(a,n,s,i,o,c,u,y,d,v,p="getDb",E)=>{let g,A,h;const m=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,c),[N,$,O,T]=(a=>{const e=(a=>H(ba,l(a)?{[ma]:a}:a??{}))(a),n=e[Sa];if(e.mode==ha){const a=e[ma]??t;return[1,n,[a,e[Na]??S,e[$a]??Aa],oa(a)]}const{tables:{load:s={},save:i={}}={},values:r={}}=e,o=w(V(H(Ia,r)),0,W(Ia)),c=o[2],u=oa(c),y=oa(c);return[0,n,[Da(s,{[Ca]:null,[fa]:S},Ca,(a=>F(y,a)),(a=>ca(u,a))),Da(i,{[Oa]:null,[fa]:S,[Ta]:0,[La]:0},Oa,((a,t)=>F(y,t)),((a,t)=>ca(u,t))),o],u]})(n);return(N?pa:Ea)(a,m,(a=>{let t;const e=()=>t=setInterval((async()=>{try{const[{d:t,s:e,c:n}]=await m(`${f} ${D} d,${R} s,TOTAL_CHANGES() c FROM ${I}${D} JOIN ${I}${R}`);t==g&&e==A&&n==h||(null!=g&&a(),g=t,A=e,h=n)}catch{}}),1e3*$),n=()=>{g=A=h=null,r(t)},s=i((t=>{T.has(t)&&(n(),a(),e())}));return e(),()=>{n(),o(s)}}),(a=>a()),u,y,d,O,j(T),(async(a,t)=>await a(`${f} t.name tn,c.name cn FROM ${M}list()t,${M}info(t.name)c ${C} t.schema='main'AND t.type IN('table','view')AND t.name IN(${P(t)})ORDER BY t.name,c.name`,t)),v,p,e,E,(a=>!0===a?1:!1===a?0:a),void 0)};exports.createLibSqlPersister=(a,t,e,n,s)=>Ra(a,e,(async(a,e=[])=>(await t.execute({sql:a,args:e})).rows),(()=>()=>0),(a=>a()),n,s,(()=>0),1,t,"getClient");
@@ -1 +1 @@
1
- "use strict";const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),i=Promise,r=a=>null==a,o=(a,t,e)=>r(a)?e?.():t(a),c=t=>a(t)==s,E=a=>Array.isArray(a),l=(a,t,e)=>a.slice(t,e),w=a=>a.length,y=async a=>i.all(a),u=a=>{throw Error(a)},d=(a,t)=>T(Array(a).fill(0),((a,e)=>t(e))),R=(a,t)=>a.forEach(t),A=(a,t="")=>a.join(t),T=(a,t)=>a.map(t),N=a=>0==w(a),g=(a,t)=>a.filter(t),C=(a,...t)=>a.push(...t),p=a=>a.shift(),O="_",L="_id",v="SELECT",$="WHERE",I="TABLE",S="ALTER "+I,m="DELETE FROM",_=v+"*FROM",h=a=>`"${a.replace(/"/g,'""')}"`,f=a=>A(T(a,((a,t)=>"$"+(t+1))),n),P=(a,t)=>a?.has(t)??!1,b=a=>r(a)||0==(a=>a?.size??0)(a),D=a=>[...a?.values()??[]],U=(a,t)=>a?.forEach(t),F=(a,t)=>a?.delete(t),M=Object,G=a=>M.getPrototypeOf(a),B=M.entries,j=M.keys,x=M.freeze,X=(a=[])=>M.fromEntries(a),Y=(...a)=>M.assign({},...a),q=(a,t)=>(delete a[t],a),H=(a,t)=>T(B(a),(([a,e])=>t(e,a))),W=a=>M.values(a),k=a=>w(j(a)),z=a=>(a=>!r(a)&&o(G(a),(a=>a==M.prototype||r(G(a))),(()=>!0)))(a)&&0==k(a),J=JSON.stringify,K=JSON.parse,V=a=>new Map(a),Q=(a,t)=>a?.get(t),Z=(a,t)=>T([...a?.entries()??[]],(([a,e])=>t(e,a))),aa=(a,t,e)=>r(e)?(F(a,t),a):a?.set(t,e),ta=(a,t,e,n)=>(P(a,t)?n?.(Q(a,t)):aa(a,t,e()),Q(a,t)),ea=(a,t,e,n,s=0)=>o((e?ta:Q)(a,t[s],s>w(t)-2?e:V),(i=>{if(s>w(t)-2)return n?.(i)&&aa(a,t[s]),i;const r=ea(i,t,e,n,s+1);return b(i)&&aa(a,t[s]),r})),na=a=>new Set(E(a)||r(a)?a:[a]),sa=(a,t)=>a?.add(t),ia=/^\d+$/,ra=V(),oa=V(),ca=(a,t,n,s,i,c,l,y={},d=[])=>{let A,T,N,g=0,O=0,L=0;ta(ra,d,(()=>0)),ta(oa,d,(()=>[]));const v=V(),[$,I,S,m,_]=((a=1,t)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,t.getTransactionMergeableChanges,([[a],[t]])=>!z(a)||!z(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!z(a)||!z(t),t.setContent]:u("Store type not supported by this Persister"))(l,a),[h,f,P]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?p(a):null)??e+t++,t=>{ia.test(t)&&w(a)<1e3&&C(a,t)}]})(),s=V();return[(n,i,r,o=[],c=()=>[])=>{a??=q;const E=t(1);return aa(s,E,[n,i,r,o,c]),sa(ea(i,r??[e],na),E),E},(t,n,...i)=>R(((a,t=[e])=>{const n=[],s=(a,e)=>e==w(t)?C(n,a):null===t[e]?U(a,(a=>s(a,e+1))):R([t[e],null],(t=>s(Q(a,t),e+1)));return s(a,0),n})(t,n),(t=>U(t,(t=>Q(s,t)[0](a,...n??[],...i))))),a=>o(Q(s,a),(([,t,i])=>(ea(t,i??[e],void 0,(t=>(F(t,a),b(t)?1:0))),aa(s,a),n(a),i))),t=>o(Q(s,t),(([t,,e=[],n,s])=>{const i=(...o)=>{const c=w(o);c==w(e)?t(a,...o,...s(o)):r(e[c])?R(n[c]?.(...o)??[],(a=>i(...o,a))):i(...o,e[c])};i()}))]})(),D=a=>{a!=g&&(g=a,f(v,void 0,g))},M=t=>{($&&E(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},G=async a=>(2!=g&&(D(1),O++,await Y((async()=>{try{const a=await t();E(a)?M(a):u("Content is not an array "+a)}catch(t){c?.(t),a&&_(a)}D(0)}))),q),B=()=>(T&&(i(T),T=void 0),q),j=async a=>(1!=g&&(D(2),L++,await Y((async()=>{try{await n(I,a)}catch(a){c?.(a)}D(0)}))),q),X=()=>(o(N,a.delListener),N=void 0,q),Y=async(...a)=>(C(Q(oa,d),...a),await(async()=>{if(!Q(ra,d)){for(aa(ra,d,1);!r(A=p(Q(oa,d)));)try{await A()}catch(a){c?.(a)}aa(ra,d,0)}})(),q),q={load:G,startAutoLoad:async a=>{await B().load(a);try{T=await s((async(a,t)=>{t||a?2!=g&&(D(1),O++,M(t??a),D(0)):await G()}))}catch(a){c?.(a)}return q},stopAutoLoad:B,isAutoLoading:()=>!r(T),save:j,startAutoSave:async()=>(await X().save(),N=a.addDidFinishTransactionListener((()=>{const a=S();m(a)&&j(a)})),q),stopAutoSave:X,isAutoSaving:()=>!r(N),getStatus:()=>g,addStatusListener:a=>h(a,v),delListener:t=>(P(t),a),schedule:Y,getStore:()=>a,destroy:()=>(Q(oa,d).splice(0,void 0),B().stopAutoSave()),getStats:()=>({loads:O,saves:L}),...y};return x(q)},Ea=(a,t,e,s,i,o,c,E)=>{const l=V();return[async()=>{l.clear(),T(await e(a,t),(({tn:a,cn:t})=>sa(ta(l,a,na),t)))},async(t,e)=>((a,t)=>P(Q(l,a),t))(t,e)?X(g(T(await a(_+h(t)),(a=>{return[a[e],E?(t=q(a,e),n=E,X(H(t,((a,t)=>[t,n(a,t)])))):q(a,e)];var t,n})),(([a,t])=>!r(a)&&!z(t)))):{},async(t,e,s,E,w,u=!1)=>{const d=na();H(s??{},(a=>T(j(a??{}),(a=>sa(d,a)))));const R=D(d);if(!u&&w&&N(R)&&P(l,t))return await a("DROP "+I+h(t)),void aa(l,t);const p=Q(l,t),O=na(D(p));if(N(R)||(P(l,t)?await y(T([e,...R],(async(n,s)=>{F(O,n)||(await a(S+h(t)+"ADD"+h(n)+i),0==s&&await a("CREATE UNIQUE INDEX pk ON "+h(t)+`(${h(e)})`),sa(p,n))}))):(await a("CREATE "+I+h(t)+`(${h(e)}${i} PRIMARY KEY${A(T(R,(a=>n+h(a)+i)))});`),aa(l,t,na([e,...R])))),await y([...!u&&E?T(D(O),(async n=>{n!=e&&(await a(S+h(t)+"DROP"+h(n)),F(p,n))})):[]]),u)r(s)?await a(m+h(t)+$+" true"):await y(H(s,(async(n,s)=>{r(n)?await a(m+h(t)+$+h(e)+"=$1",[s]):N(R)||await la(a,t,e,j(n),[s,...c?T(W(n),c):W(n)],o)})));else if(N(R))P(l,t)&&await a(m+h(t)+$+" true");else{const n=g(D(Q(l,t)),(a=>a!=e)),i=[],r=[];H(s??{},((a,t)=>{C(i,t,...T(n,(t=>c?c(a?.[t]):a?.[t]))),C(r,t)})),await la(a,t,e,n,i,o),await a(m+h(t)+$+h(e)+`NOT IN(${f(r)})`,r)}},async t=>{let e;await a("BEGIN");try{e=await t()}catch(a){s?.(a)}return await a("END"),e}]},la=async(a,t,s,i,r,o=0)=>await a("INSERT "+(o?"OR REPLACE ":e)+"INTO"+h(t)+"("+h(s)+A(T(i,(a=>n+h(a))))+")VALUES"+wa(r,w(i)+1)+(o?e:"ON CONFLICT("+h(s)+")DO UPDATE SET"+A(T(i,(a=>h(a)+"=excluded."+h(a))),n)),T(r,(a=>a??null))),wa=(a,t)=>A(d(w(a)/t,(a=>"("+A(d(t,(e=>"$"+(a*t+e+1))),n)+")")),n),ya=(a,t,e,n,s,i,r,[o,c,E],l,w,y,u,d,R)=>{const[A,T,N,g]=Ea(t,l,w,s,d,R),C=ca(a,(async()=>await g((async()=>{return await A(),a=(await T(o,c))[O]?.[E]??"null",K(a,((a,t)=>""===t?void 0:t));var a}))),(async a=>await g((async()=>{var t;await A(),await N(o,c,{[O]:{[E]:(t=a()??null,J(t,((a,t)=>void 0===t?"":t)))}},!0,!0)}))),e,n,s,r,{[u]:()=>y,destroy:()=>(C.stopAutoLoad().stopAutoSave(),i(),C)},y);return C},ua=(a,t,e,n,s,i,o,[c,E,[l,w,u]],d,R,A,T,N,C,p,v)=>{const[$,I,S,m]=Ea(t,d,R,s,N,C,p,v),_=async(a,t)=>await y(Z(E,(async([e,n,s,i],r)=>{t&&!(r in a)||await S(e,n,a[r],s,i,t)}))),h=async(a,t)=>w?await S(u,L,{[O]:a},!0,!0,t):null,f=ca(a,(async()=>await m((async()=>{await $();const a=await(async()=>X(g(await y(Z(c,(async([a,t],e)=>[a,await I(e,t)]))),(a=>!z(a[1])))))(),t=await(async()=>l?(await I(u,L))[O]:{})();return z(a)&&r(t)?void 0:[a,t]}))),(async(a,t)=>await m((async()=>{if(await $(),r(t)){const[t,e]=a();await _(t),await h(e)}else await _(t[0],!0),await h(t[1],!0)}))),e,n,s,o,{[T]:()=>A,destroy:()=>(f.stopAutoLoad().stopAutoSave(),i(),f)},A);return f},da="ColumnName",Ra="store",Aa="json",Ta=Ra+"TableName",Na=Ra+"Id"+da,ga=Ra+da,Ca="autoLoadIntervalSeconds",pa="rowId"+da,Oa="tableId",La="tableName",va="deleteEmptyColumns",$a="deleteEmptyTable",Ia={mode:Aa,[Ca]:1},Sa={load:0,save:0,[La]:t+"_values"},ma=(a,t,e,n,s)=>{const i=V();return H(a,((a,o)=>{const E=l(W(Y(t,c(a)?{[e]:a}:a)),0,k(t));r(E[0])||n(o,E[0])||(s(o,E[0]),aa(i,o,E))})),i},_a=t,ha=/^([cd]:)(.+)/,fa=t+"_data",Pa=t+"_table";exports.createPglitePersister=async(a,e,n,s,i)=>((a,e,n,s,i,r,E,w,u,d,R="getDb")=>{const A=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(n,r),[N,,g,C]=(a=>{const e=(a=>Y(Ia,c(a)?{[Ta]:a}:a??{}))(a),n=e[Ca];if(e.mode==Aa){const a=e[Ta]??t;return[1,n,[a,e[Na]??L,e[ga]??Ra],na(a)]}const{tables:{load:s={},save:i={}}={},values:r={}}=e,o=l(W(Y(Sa,r)),0,k(Sa)),E=o[2],w=na(E),y=na(E);return[0,n,[ma(s,{[Oa]:null,[pa]:L},Oa,(a=>P(y,a)),(a=>sa(w,a))),ma(i,{[La]:null,[pa]:L,[va]:0,[$a]:0},La,((a,t)=>P(y,t)),((a,t)=>sa(w,t))),o],w]})(e),p=async a=>{await A(`CREATE OR REPLACE TRIGGER ${h(fa+"_"+a)} AFTER INSERT OR UPDATE OR DELETE ON ${h(a)} EXECUTE FUNCTION ${fa}()`)};return(N?ya:ua)(a,A,(async a=>{await A(`CREATE OR REPLACE FUNCTION ${Pa}()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('${_a}','c:'||SPLIT_PART(row.object_identity,'.',2));END LOOP;END;$t2$ LANGUAGE plpgsql;`);try{await A(`CREATE EVENT TRIGGER ${Pa} ON ddl_command_end WHEN TAG IN('CREATE TABLE')EXECUTE FUNCTION ${Pa}();`)}catch{}return await A(`CREATE OR REPLACE FUNCTION ${fa}()RETURNS trigger AS $t1$ BEGIN PERFORM pg_notify('${_a}','d:'||TG_TABLE_NAME);RETURN NULL;END;$t1$ LANGUAGE plpgsql;`),await y(T(D(C),(async a=>{await A(`CREATE TABLE IF NOT EXISTS ${h(a)}("_id"text PRIMARY KEY)`),await p(a)}))),await s(_a,(async t=>{return await o((e=t,n=ha,e?.match(n)),(async([,t,e])=>{P(C,e)&&("c:"==t&&await p(e),a())}));var e,n}))}),i,E,w,u,g,D(C),(async(a,t)=>await a(`${v} table_name tn,column_name cn FROM information_schema.columns ${$} table_schema='public'AND table_name IN(${f(t)})`,t)),d,R,"text",0,(a=>J(a)),(a=>K(a)))})(a,n,(async(a,t=[])=>(await e.query(a,t)).rows),(async(a,t)=>await e.listen(a,t)),(async a=>{try{await a()}catch(a){i?.(a)}}),s,i,(()=>0),3,e,"getPglite");
1
+ "use strict";const a=a=>typeof a,t="tinybase",e=",",n=a(""),s=Promise,i=a=>null==a,r=(a,t,e)=>i(a)?e?.():t(a),o=t=>a(t)==n,c=a=>Array.isArray(a),E=(a,t,e)=>a.slice(t,e),l=a=>a.length,w=async a=>s.all(a),y=a=>{throw Error(a)},d=(a,t)=>a.forEach(t),u=(a,t="")=>a.join(t),T=(a,t)=>a.map(t),R=a=>0==l(a),A=(a,t)=>a.filter(t),N=(a,...t)=>a.push(...t),g=a=>a.shift(),p="_",C="_id",O="SELECT",L="WHERE",v="TABLE",$="ALTER "+v,I="DELETE FROM",S=O+"*FROM",m=a=>`"${a.replace(/"/g,'""')}"`,_=(a,t=[1])=>u(T(a,(()=>"$"+t[0]++)),e),h=(a,t)=>a?.has(t)??!1,f=a=>i(a)||0==(a=>a?.size??0)(a),b=a=>[...a?.values()??[]],P=(a,t)=>a?.forEach(t),D=(a,t)=>a?.delete(t),U=Object,F=a=>U.getPrototypeOf(a),M=U.entries,G=U.keys,B=U.freeze,j=(a=[])=>U.fromEntries(a),x=(...a)=>U.assign({},...a),X=(a,t)=>(delete a[t],a),Y=(a,t)=>T(M(a),(([a,e])=>t(e,a))),q=a=>U.values(a),H=a=>l(G(a)),W=a=>(a=>!i(a)&&r(F(a),(a=>a==U.prototype||i(F(a))),(()=>!0)))(a)&&0==H(a),k=JSON.stringify,z=JSON.parse,J=a=>new Map(a),K=(a,t)=>a?.get(t),V=(a,t)=>T([...a?.entries()??[]],(([a,e])=>t(e,a))),Q=(a,t,e)=>i(e)?(D(a,t),a):a?.set(t,e),Z=(a,t,e,n)=>(h(a,t)?n?.(K(a,t)):Q(a,t,e()),K(a,t)),aa=(a,t,e,n,s=0)=>r((e?Z:K)(a,t[s],s>l(t)-2?e:J),(i=>{if(s>l(t)-2)return n?.(i)&&Q(a,t[s]),i;const r=aa(i,t,e,n,s+1);return f(i)&&Q(a,t[s]),r})),ta=a=>new Set(c(a)||i(a)?a:[a]),ea=(a,t)=>a?.add(t),na=/^\d+$/,sa=J(),ia=J(),ra=(a,t,e,n,s,o,E,w={},u=[])=>{let T,R,A,p=0,C=0,O=0;Z(sa,u,(()=>0)),Z(ia,u,(()=>[]));const L=J(),[v,$,I,S,m]=((a=1,t)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,t.getTransactionMergeableChanges,([[a],[t]])=>!W(a)||!W(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!W(a)||!W(t),t.setContent]:y("Store type not supported by this Persister"))(E,a),[_,h,b]=(()=>{let a;const[t,e]=(()=>{const a=[];let t=0;return[e=>(e?g(a):null)??""+t++,t=>{na.test(t)&&l(a)<1e3&&N(a,t)}]})(),n=J();return[(e,s,i,r=[],o=()=>[])=>{a??=Y;const c=t(1);return Q(n,c,[e,s,i,r,o]),ea(aa(s,i??[""],ta),c),c},(t,e,...s)=>d(((a,t=[""])=>{const e=[],n=(a,s)=>s==l(t)?N(e,a):null===t[s]?P(a,(a=>n(a,s+1))):d([t[s],null],(t=>n(K(a,t),s+1)));return n(a,0),e})(t,e),(t=>P(t,(t=>K(n,t)[0](a,...e??[],...s))))),a=>r(K(n,a),(([,t,s])=>(aa(t,s??[""],void 0,(t=>(D(t,a),f(t)?1:0))),Q(n,a),e(a),s))),t=>r(K(n,t),(([t,,e=[],n,s])=>{const r=(...o)=>{const c=l(o);c==l(e)?t(a,...o,...s(o)):i(e[c])?d(n[c]?.(...o)??[],(a=>r(...o,a))):r(...o,e[c])};r()}))]})(),U=a=>{a!=p&&(p=a,h(L,void 0,p))},F=t=>{(v&&c(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},M=async a=>(2!=p&&(U(1),C++,await X((async()=>{try{const a=await t();c(a)?F(a):y("Content is not an array "+a)}catch(t){o?.(t),a&&m(a)}U(0)}))),Y),G=()=>(R&&(s(R),R=void 0),Y),j=async a=>(1!=p&&(U(2),O++,await X((async()=>{try{await e($,a)}catch(a){o?.(a)}U(0)}))),Y),x=()=>(r(A,a.delListener),A=void 0,Y),X=async(...a)=>(N(K(ia,u),...a),await(async()=>{if(!K(sa,u)){for(Q(sa,u,1);!i(T=g(K(ia,u)));)try{await T()}catch(a){o?.(a)}Q(sa,u,0)}})(),Y),Y={load:M,startAutoLoad:async a=>{await G().load(a);try{R=await n((async(a,t)=>{t||a?2!=p&&(U(1),C++,F(t??a),U(0)):await M()}))}catch(a){o?.(a)}return Y},stopAutoLoad:G,isAutoLoading:()=>!i(R),save:j,startAutoSave:async()=>(await x().save(),A=a.addDidFinishTransactionListener((()=>{const a=I();S(a)&&j(a)})),Y),stopAutoSave:x,isAutoSaving:()=>!i(A),getStatus:()=>p,addStatusListener:a=>_(a,L),delListener:t=>(b(t),a),schedule:X,getStore:()=>a,destroy:()=>(K(ia,u).splice(0,void 0),G().stopAutoSave()),getStats:()=>({loads:C,saves:O}),...w};return B(Y)},oa=(a,t,n,s,r,o=ca,c,E)=>{const l=J();return[async()=>{l.clear(),T(await n(a,t),(({tn:a,cn:t})=>ea(Z(l,a,ta),t)))},async(t,e)=>((a,t)=>h(K(l,a),t))(t,e)?j(A(T(await a(S+m(t)),(a=>{return[a[e],E?(t=X(a,e),n=E,j(Y(t,((a,t)=>[t,n(a,t)])))):X(a,e)];var t,n})),(([a,t])=>!i(a)&&!W(t)))):{},async(t,n,s,E,y,d=!1)=>{const g=ta();Y(s??{},(a=>T(G(a??{}),(a=>ea(g,a)))));const p=b(g);if(!d&&y&&R(p)&&h(l,t))return await a("DROP "+v+m(t)),void Q(l,t);const C=K(l,t),O=ta(b(C));if(R(p)||(h(l,t)?await w(T([n,...p],(async(e,s)=>{D(O,e)||(await a($+m(t)+"ADD"+m(e)+r),0==s&&await a("CREATE UNIQUE INDEX pk ON "+m(t)+`(${m(n)})`),ea(C,e))}))):(await a("CREATE "+v+m(t)+`(${m(n)}${r} PRIMARY KEY${u(T(p,(a=>e+m(a)+r)))});`),Q(l,t,ta([n,...p])))),await w([...!d&&E?T(b(O),(async e=>{e!=n&&(await a($+m(t)+"DROP"+m(e)),D(C,e))})):[]]),d)i(s)?await a(I+m(t)+L+" true"):await w(Y(s,(async(e,s)=>{i(e)?await a(I+m(t)+L+m(n)+"=$1",[s]):R(p)||await o(a,t,n,G(e),{[s]:c?T(q(e),c):q(e)},C)})));else if(R(p))h(l,t)&&await a(I+m(t)+L+" true");else{const e=A(b(K(l,t)),(a=>a!=n)),i={},r=[];Y(s??{},((a,t)=>{i[t]=T(e,(t=>c?c(a?.[t]):a?.[t])),N(r,t)})),await o(a,t,n,e,i),await a(I+m(t)+L+m(n)+`NOT IN(${_(r)})`,r)}},async t=>{let e;await a("BEGIN");try{e=await t()}catch(a){s?.(a)}return await a("END"),e}]},ca=async(a,t,n,s,i)=>{const r=[1];await a("INSERT INTO"+m(t)+"("+((...a)=>u(T(a,m),e))(n,...s)+")VALUES"+u(Y(i,(a=>"($"+r[0]+++","+_(a,r)+")")),e)+"ON CONFLICT("+m(n)+")DO UPDATE SET"+u(T(s,(a=>m(a)+"=excluded."+m(a))),e),Y(i,((a,t)=>[t,...T(a,(a=>a??null))])).flat())},Ea=(a,t,e,n,s,i,r,[o,c,E],l,w,y,d,u,T)=>{const[R,A,N,g]=oa(t,l,w,s,u,T),C=ra(a,(async()=>await g((async()=>{return await R(),a=(await A(o,c))[p]?.[E]??"null",z(a,((a,t)=>""===t?void 0:t));var a}))),(async a=>await g((async()=>{var t;await R(),await N(o,c,{[p]:{[E]:(t=a()??null,k(t,((a,t)=>void 0===t?"":t)))}},!0,!0)}))),e,n,s,r,{[d]:()=>y,destroy:()=>(C.stopAutoLoad().stopAutoSave(),i(),C)},y);return C},la=(a,t,e,n,s,r,o,[c,E,[l,y,d]],u,T,R,N,g,O,L,v)=>{const[$,I,S,m]=oa(t,u,T,s,g,O,L,v),_=async(a,t)=>await w(V(E,(async([e,n,s,i],r)=>{t&&!(r in a)||await S(e,n,a[r],s,i,t)}))),h=async(a,t)=>y?await S(d,C,{[p]:a},!0,!0,t):null,f=ra(a,(async()=>await m((async()=>{await $();const a=await(async()=>j(A(await w(V(c,(async([a,t],e)=>[a,await I(e,t)]))),(a=>!W(a[1])))))(),t=await(async()=>l?(await I(d,C))[p]:{})();return W(a)&&i(t)?void 0:[a,t]}))),(async(a,t)=>await m((async()=>{if(await $(),i(t)){const[t,e]=a();await _(t),await h(e)}else await _(t[0],!0),await h(t[1],!0)}))),e,n,s,o,{[N]:()=>R,destroy:()=>(f.stopAutoLoad().stopAutoSave(),r(),f)},R);return f},wa="ColumnName",ya="store",da="json",ua=ya+"TableName",Ta=ya+"Id"+wa,Ra=ya+wa,Aa="autoLoadIntervalSeconds",Na="rowId"+wa,ga="tableId",pa="tableName",Ca="deleteEmptyColumns",Oa="deleteEmptyTable",La={mode:da,[Aa]:1},va={load:0,save:0,[pa]:t+"_values"},$a=(a,t,e,n,s)=>{const r=J();return Y(a,((a,c)=>{const l=E(q(x(t,o(a)?{[e]:a}:a)),0,H(t));i(l[0])||n(c,l[0])||(s(c,l[0]),Q(r,c,l))})),r},Ia=t,Sa=/^([cd]:)(.+)/,ma=t+"_data",_a=t+"_table";exports.createPglitePersister=async(a,e,n,s,i)=>((a,e,n,s,i,c,l,y,d,u,R="getDb")=>{const A=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(n,c),[N,,g,p]=(a=>{const e=(a=>x(La,o(a)?{[ua]:a}:a??{}))(a),n=e[Aa];if(e.mode==da){const a=e[ua]??t;return[1,n,[a,e[Ta]??C,e[Ra]??ya],ta(a)]}const{tables:{load:s={},save:i={}}={},values:r={}}=e,c=E(q(x(va,r)),0,H(va)),l=c[2],w=ta(l),y=ta(l);return[0,n,[$a(s,{[ga]:null,[Na]:C},ga,(a=>h(y,a)),(a=>ea(w,a))),$a(i,{[pa]:null,[Na]:C,[Ca]:0,[Oa]:0},pa,((a,t)=>h(y,t)),((a,t)=>ea(w,t))),c],w]})(e),v=async a=>{await A(`CREATE OR REPLACE TRIGGER ${m(ma+"_"+a)} AFTER INSERT OR UPDATE OR DELETE ON ${m(a)} EXECUTE FUNCTION ${ma}()`)};return(N?Ea:la)(a,A,(async a=>{await A(`CREATE OR REPLACE FUNCTION ${_a}()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('${Ia}','c:'||SPLIT_PART(row.object_identity,'.',2));END LOOP;END;$t2$ LANGUAGE plpgsql;`);try{await A(`CREATE EVENT TRIGGER ${_a} ON ddl_command_end WHEN TAG IN('CREATE TABLE')EXECUTE FUNCTION ${_a}();`)}catch{}return await A(`CREATE OR REPLACE FUNCTION ${ma}()RETURNS trigger AS $t1$ BEGIN PERFORM pg_notify('${Ia}','d:'||TG_TABLE_NAME);RETURN NULL;END;$t1$ LANGUAGE plpgsql;`),await w(T(b(p),(async a=>{await A(`CREATE TABLE IF NOT EXISTS ${m(a)}("_id"text PRIMARY KEY)`),await v(a)}))),await s(Ia,(async t=>{return await r((e=t,n=Sa,e?.match(n)),(async([,t,e])=>{h(p,e)&&("c:"==t&&await v(e),a())}));var e,n}))}),i,l,y,d,g,b(p),(async(a,t)=>await a(`${O} table_name tn,column_name cn FROM information_schema.columns ${L} table_schema='public'AND table_name IN(${_(t)})`,t)),u,R,"text",void 0,(a=>k(a)),(a=>z(a)))})(a,n,(async(a,t=[])=>(await e.query(a,t)).rows),(async(a,t)=>await e.listen(a,t)),(async a=>{try{await a()}catch(a){i?.(a)}}),s,i,(()=>0),3,e,"getPglite");
@@ -1 +1 @@
1
- "use strict";const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),i=Promise,r=a=>null==a,o=(a,t,e)=>r(a)?e?.():t(a),c=t=>a(t)==s,E=a=>Array.isArray(a),l=(a,t,e)=>a.slice(t,e),w=a=>a.length,y=async a=>i.all(a),u=a=>{throw Error(a)},d=(a,t)=>T(Array(a).fill(0),((a,e)=>t(e))),R=(a,t)=>a.forEach(t),A=(a,t="")=>a.join(t),T=(a,t)=>a.map(t),N=a=>0==w(a),g=(a,t)=>a.filter(t),C=(a,...t)=>a.push(...t),p=a=>a.shift(),O="_",L="_id",v="SELECT",$="WHERE",I="TABLE",S="ALTER "+I,m="DELETE FROM",_=v+"*FROM",h=a=>`"${a.replace(/"/g,'""')}"`,f=a=>A(T(a,((a,t)=>"$"+(t+1))),n),P=(a,t)=>a?.has(t)??!1,b=a=>r(a)||0==(a=>a?.size??0)(a),D=a=>[...a?.values()??[]],U=(a,t)=>a?.forEach(t),F=(a,t)=>a?.delete(t),M=Object,G=a=>M.getPrototypeOf(a),B=M.entries,j=M.keys,x=M.freeze,X=(a=[])=>M.fromEntries(a),Y=(...a)=>M.assign({},...a),q=(a,t)=>(delete a[t],a),H=(a,t)=>T(B(a),(([a,e])=>t(e,a))),W=a=>M.values(a),k=a=>w(j(a)),z=a=>(a=>!r(a)&&o(G(a),(a=>a==M.prototype||r(G(a))),(()=>!0)))(a)&&0==k(a),J=JSON.stringify,K=JSON.parse,V=a=>new Map(a),Q=(a,t)=>a?.get(t),Z=(a,t)=>T([...a?.entries()??[]],(([a,e])=>t(e,a))),aa=(a,t,e)=>r(e)?(F(a,t),a):a?.set(t,e),ta=(a,t,e,n)=>(P(a,t)?n?.(Q(a,t)):aa(a,t,e()),Q(a,t)),ea=(a,t,e,n,s=0)=>o((e?ta:Q)(a,t[s],s>w(t)-2?e:V),(i=>{if(s>w(t)-2)return n?.(i)&&aa(a,t[s]),i;const r=ea(i,t,e,n,s+1);return b(i)&&aa(a,t[s]),r})),na=a=>new Set(E(a)||r(a)?a:[a]),sa=(a,t)=>a?.add(t),ia=/^\d+$/,ra=V(),oa=V(),ca=(a,t,n,s,i,c,l,y={},d=[])=>{let A,T,N,g=0,O=0,L=0;ta(ra,d,(()=>0)),ta(oa,d,(()=>[]));const v=V(),[$,I,S,m,_]=((a=1,t)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,t.getTransactionMergeableChanges,([[a],[t]])=>!z(a)||!z(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!z(a)||!z(t),t.setContent]:u("Store type not supported by this Persister"))(l,a),[h,f,P]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?p(a):null)??e+t++,t=>{ia.test(t)&&w(a)<1e3&&C(a,t)}]})(),s=V();return[(n,i,r,o=[],c=()=>[])=>{a??=q;const E=t(1);return aa(s,E,[n,i,r,o,c]),sa(ea(i,r??[e],na),E),E},(t,n,...i)=>R(((a,t=[e])=>{const n=[],s=(a,e)=>e==w(t)?C(n,a):null===t[e]?U(a,(a=>s(a,e+1))):R([t[e],null],(t=>s(Q(a,t),e+1)));return s(a,0),n})(t,n),(t=>U(t,(t=>Q(s,t)[0](a,...n??[],...i))))),a=>o(Q(s,a),(([,t,i])=>(ea(t,i??[e],void 0,(t=>(F(t,a),b(t)?1:0))),aa(s,a),n(a),i))),t=>o(Q(s,t),(([t,,e=[],n,s])=>{const i=(...o)=>{const c=w(o);c==w(e)?t(a,...o,...s(o)):r(e[c])?R(n[c]?.(...o)??[],(a=>i(...o,a))):i(...o,e[c])};i()}))]})(),D=a=>{a!=g&&(g=a,f(v,void 0,g))},M=t=>{($&&E(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},G=async a=>(2!=g&&(D(1),O++,await Y((async()=>{try{const a=await t();E(a)?M(a):u("Content is not an array "+a)}catch(t){c?.(t),a&&_(a)}D(0)}))),q),B=()=>(T&&(i(T),T=void 0),q),j=async a=>(1!=g&&(D(2),L++,await Y((async()=>{try{await n(I,a)}catch(a){c?.(a)}D(0)}))),q),X=()=>(o(N,a.delListener),N=void 0,q),Y=async(...a)=>(C(Q(oa,d),...a),await(async()=>{if(!Q(ra,d)){for(aa(ra,d,1);!r(A=p(Q(oa,d)));)try{await A()}catch(a){c?.(a)}aa(ra,d,0)}})(),q),q={load:G,startAutoLoad:async a=>{await B().load(a);try{T=await s((async(a,t)=>{t||a?2!=g&&(D(1),O++,M(t??a),D(0)):await G()}))}catch(a){c?.(a)}return q},stopAutoLoad:B,isAutoLoading:()=>!r(T),save:j,startAutoSave:async()=>(await X().save(),N=a.addDidFinishTransactionListener((()=>{const a=S();m(a)&&j(a)})),q),stopAutoSave:X,isAutoSaving:()=>!r(N),getStatus:()=>g,addStatusListener:a=>h(a,v),delListener:t=>(P(t),a),schedule:Y,getStore:()=>a,destroy:()=>(Q(oa,d).splice(0,void 0),B().stopAutoSave()),getStats:()=>({loads:O,saves:L}),...y};return x(q)},Ea=(a,t,e,s,i,o,c,E)=>{const l=V();return[async()=>{l.clear(),T(await e(a,t),(({tn:a,cn:t})=>sa(ta(l,a,na),t)))},async(t,e)=>((a,t)=>P(Q(l,a),t))(t,e)?X(g(T(await a(_+h(t)),(a=>{return[a[e],E?(t=q(a,e),n=E,X(H(t,((a,t)=>[t,n(a,t)])))):q(a,e)];var t,n})),(([a,t])=>!r(a)&&!z(t)))):{},async(t,e,s,E,w,u=!1)=>{const d=na();H(s??{},(a=>T(j(a??{}),(a=>sa(d,a)))));const R=D(d);if(!u&&w&&N(R)&&P(l,t))return await a("DROP "+I+h(t)),void aa(l,t);const p=Q(l,t),O=na(D(p));if(N(R)||(P(l,t)?await y(T([e,...R],(async(n,s)=>{F(O,n)||(await a(S+h(t)+"ADD"+h(n)+i),0==s&&await a("CREATE UNIQUE INDEX pk ON "+h(t)+`(${h(e)})`),sa(p,n))}))):(await a("CREATE "+I+h(t)+`(${h(e)}${i} PRIMARY KEY${A(T(R,(a=>n+h(a)+i)))});`),aa(l,t,na([e,...R])))),await y([...!u&&E?T(D(O),(async n=>{n!=e&&(await a(S+h(t)+"DROP"+h(n)),F(p,n))})):[]]),u)r(s)?await a(m+h(t)+$+" true"):await y(H(s,(async(n,s)=>{r(n)?await a(m+h(t)+$+h(e)+"=$1",[s]):N(R)||await la(a,t,e,j(n),[s,...c?T(W(n),c):W(n)],o)})));else if(N(R))P(l,t)&&await a(m+h(t)+$+" true");else{const n=g(D(Q(l,t)),(a=>a!=e)),i=[],r=[];H(s??{},((a,t)=>{C(i,t,...T(n,(t=>c?c(a?.[t]):a?.[t]))),C(r,t)})),await la(a,t,e,n,i,o),await a(m+h(t)+$+h(e)+`NOT IN(${f(r)})`,r)}},async t=>{let e;await a("BEGIN");try{e=await t()}catch(a){s?.(a)}return await a("END"),e}]},la=async(a,t,s,i,r,o=0)=>await a("INSERT "+(o?"OR REPLACE ":e)+"INTO"+h(t)+"("+h(s)+A(T(i,(a=>n+h(a))))+")VALUES"+wa(r,w(i)+1)+(o?e:"ON CONFLICT("+h(s)+")DO UPDATE SET"+A(T(i,(a=>h(a)+"=excluded."+h(a))),n)),T(r,(a=>a??null))),wa=(a,t)=>A(d(w(a)/t,(a=>"("+A(d(t,(e=>"$"+(a*t+e+1))),n)+")")),n),ya=(a,t,e,n,s,i,r,[o,c,E],l,w,y,u,d,R)=>{const[A,T,N,g]=Ea(t,l,w,s,d,R),C=ca(a,(async()=>await g((async()=>{return await A(),a=(await T(o,c))[O]?.[E]??"null",K(a,((a,t)=>""===t?void 0:t));var a}))),(async a=>await g((async()=>{var t;await A(),await N(o,c,{[O]:{[E]:(t=a()??null,J(t,((a,t)=>void 0===t?"":t)))}},!0,!0)}))),e,n,s,r,{[u]:()=>y,destroy:()=>(C.stopAutoLoad().stopAutoSave(),i(),C)},y);return C},ua=(a,t,e,n,s,i,o,[c,E,[l,w,u]],d,R,A,T,N,C,p,v)=>{const[$,I,S,m]=Ea(t,d,R,s,N,C,p,v),_=async(a,t)=>await y(Z(E,(async([e,n,s,i],r)=>{t&&!(r in a)||await S(e,n,a[r],s,i,t)}))),h=async(a,t)=>w?await S(u,L,{[O]:a},!0,!0,t):null,f=ca(a,(async()=>await m((async()=>{await $();const a=await(async()=>X(g(await y(Z(c,(async([a,t],e)=>[a,await I(e,t)]))),(a=>!z(a[1])))))(),t=await(async()=>l?(await I(u,L))[O]:{})();return z(a)&&r(t)?void 0:[a,t]}))),(async(a,t)=>await m((async()=>{if(await $(),r(t)){const[t,e]=a();await _(t),await h(e)}else await _(t[0],!0),await h(t[1],!0)}))),e,n,s,o,{[T]:()=>A,destroy:()=>(f.stopAutoLoad().stopAutoSave(),i(),f)},A);return f},da="ColumnName",Ra="store",Aa="json",Ta=Ra+"TableName",Na=Ra+"Id"+da,ga=Ra+da,Ca="autoLoadIntervalSeconds",pa="rowId"+da,Oa="tableId",La="tableName",va="deleteEmptyColumns",$a="deleteEmptyTable",Ia={mode:Aa,[Ca]:1},Sa={load:0,save:0,[La]:t+"_values"},ma=(a,t,e,n,s)=>{const i=V();return H(a,((a,o)=>{const E=l(W(Y(t,c(a)?{[e]:a}:a)),0,k(t));r(E[0])||n(o,E[0])||(s(o,E[0]),aa(i,o,E))})),i},_a=t,ha=/^([cd]:)(.+)/,fa=t+"_data",Pa=t+"_table";exports.createPglitePersister=async(a,e,n,s,i)=>((a,e,n,s,i,r,E,w,u,d,R="getDb")=>{const A=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(n,r),[N,,g,C]=(a=>{const e=(a=>Y(Ia,c(a)?{[Ta]:a}:a??{}))(a),n=e[Ca];if(e.mode==Aa){const a=e[Ta]??t;return[1,n,[a,e[Na]??L,e[ga]??Ra],na(a)]}const{tables:{load:s={},save:i={}}={},values:r={}}=e,o=l(W(Y(Sa,r)),0,k(Sa)),E=o[2],w=na(E),y=na(E);return[0,n,[ma(s,{[Oa]:null,[pa]:L},Oa,(a=>P(y,a)),(a=>sa(w,a))),ma(i,{[La]:null,[pa]:L,[va]:0,[$a]:0},La,((a,t)=>P(y,t)),((a,t)=>sa(w,t))),o],w]})(e),p=async a=>{await A(`CREATE OR REPLACE TRIGGER ${h(fa+"_"+a)} AFTER INSERT OR UPDATE OR DELETE ON ${h(a)} EXECUTE FUNCTION ${fa}()`)};return(N?ya:ua)(a,A,(async a=>{await A(`CREATE OR REPLACE FUNCTION ${Pa}()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('${_a}','c:'||SPLIT_PART(row.object_identity,'.',2));END LOOP;END;$t2$ LANGUAGE plpgsql;`);try{await A(`CREATE EVENT TRIGGER ${Pa} ON ddl_command_end WHEN TAG IN('CREATE TABLE')EXECUTE FUNCTION ${Pa}();`)}catch{}return await A(`CREATE OR REPLACE FUNCTION ${fa}()RETURNS trigger AS $t1$ BEGIN PERFORM pg_notify('${_a}','d:'||TG_TABLE_NAME);RETURN NULL;END;$t1$ LANGUAGE plpgsql;`),await y(T(D(C),(async a=>{await A(`CREATE TABLE IF NOT EXISTS ${h(a)}("_id"text PRIMARY KEY)`),await p(a)}))),await s(_a,(async t=>{return await o((e=t,n=ha,e?.match(n)),(async([,t,e])=>{P(C,e)&&("c:"==t&&await p(e),a())}));var e,n}))}),i,E,w,u,g,D(C),(async(a,t)=>await a(`${v} table_name tn,column_name cn FROM information_schema.columns ${$} table_schema='public'AND table_name IN(${f(t)})`,t)),d,R,"text",0,(a=>J(a)),(a=>K(a)))})(a,n,(async(a,t=[])=>(await e.query(a,t)).rows),(async(a,t)=>await e.listen(a,t)),(async a=>{try{await a()}catch(a){i?.(a)}}),s,i,(()=>0),3,e,"getPglite");
1
+ "use strict";const a=a=>typeof a,t="tinybase",e=",",n=a(""),s=Promise,i=a=>null==a,r=(a,t,e)=>i(a)?e?.():t(a),o=t=>a(t)==n,c=a=>Array.isArray(a),E=(a,t,e)=>a.slice(t,e),l=a=>a.length,w=async a=>s.all(a),y=a=>{throw Error(a)},d=(a,t)=>a.forEach(t),u=(a,t="")=>a.join(t),T=(a,t)=>a.map(t),R=a=>0==l(a),A=(a,t)=>a.filter(t),N=(a,...t)=>a.push(...t),g=a=>a.shift(),p="_",C="_id",O="SELECT",L="WHERE",v="TABLE",$="ALTER "+v,I="DELETE FROM",S=O+"*FROM",m=a=>`"${a.replace(/"/g,'""')}"`,_=(a,t=[1])=>u(T(a,(()=>"$"+t[0]++)),e),h=(a,t)=>a?.has(t)??!1,f=a=>i(a)||0==(a=>a?.size??0)(a),b=a=>[...a?.values()??[]],P=(a,t)=>a?.forEach(t),D=(a,t)=>a?.delete(t),U=Object,F=a=>U.getPrototypeOf(a),M=U.entries,G=U.keys,B=U.freeze,j=(a=[])=>U.fromEntries(a),x=(...a)=>U.assign({},...a),X=(a,t)=>(delete a[t],a),Y=(a,t)=>T(M(a),(([a,e])=>t(e,a))),q=a=>U.values(a),H=a=>l(G(a)),W=a=>(a=>!i(a)&&r(F(a),(a=>a==U.prototype||i(F(a))),(()=>!0)))(a)&&0==H(a),k=JSON.stringify,z=JSON.parse,J=a=>new Map(a),K=(a,t)=>a?.get(t),V=(a,t)=>T([...a?.entries()??[]],(([a,e])=>t(e,a))),Q=(a,t,e)=>i(e)?(D(a,t),a):a?.set(t,e),Z=(a,t,e,n)=>(h(a,t)?n?.(K(a,t)):Q(a,t,e()),K(a,t)),aa=(a,t,e,n,s=0)=>r((e?Z:K)(a,t[s],s>l(t)-2?e:J),(i=>{if(s>l(t)-2)return n?.(i)&&Q(a,t[s]),i;const r=aa(i,t,e,n,s+1);return f(i)&&Q(a,t[s]),r})),ta=a=>new Set(c(a)||i(a)?a:[a]),ea=(a,t)=>a?.add(t),na=/^\d+$/,sa=J(),ia=J(),ra=(a,t,e,n,s,o,E,w={},u=[])=>{let T,R,A,p=0,C=0,O=0;Z(sa,u,(()=>0)),Z(ia,u,(()=>[]));const L=J(),[v,$,I,S,m]=((a=1,t)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,t.getTransactionMergeableChanges,([[a],[t]])=>!W(a)||!W(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!W(a)||!W(t),t.setContent]:y("Store type not supported by this Persister"))(E,a),[_,h,b]=(()=>{let a;const[t,e]=(()=>{const a=[];let t=0;return[e=>(e?g(a):null)??""+t++,t=>{na.test(t)&&l(a)<1e3&&N(a,t)}]})(),n=J();return[(e,s,i,r=[],o=()=>[])=>{a??=Y;const c=t(1);return Q(n,c,[e,s,i,r,o]),ea(aa(s,i??[""],ta),c),c},(t,e,...s)=>d(((a,t=[""])=>{const e=[],n=(a,s)=>s==l(t)?N(e,a):null===t[s]?P(a,(a=>n(a,s+1))):d([t[s],null],(t=>n(K(a,t),s+1)));return n(a,0),e})(t,e),(t=>P(t,(t=>K(n,t)[0](a,...e??[],...s))))),a=>r(K(n,a),(([,t,s])=>(aa(t,s??[""],void 0,(t=>(D(t,a),f(t)?1:0))),Q(n,a),e(a),s))),t=>r(K(n,t),(([t,,e=[],n,s])=>{const r=(...o)=>{const c=l(o);c==l(e)?t(a,...o,...s(o)):i(e[c])?d(n[c]?.(...o)??[],(a=>r(...o,a))):r(...o,e[c])};r()}))]})(),U=a=>{a!=p&&(p=a,h(L,void 0,p))},F=t=>{(v&&c(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},M=async a=>(2!=p&&(U(1),C++,await X((async()=>{try{const a=await t();c(a)?F(a):y("Content is not an array "+a)}catch(t){o?.(t),a&&m(a)}U(0)}))),Y),G=()=>(R&&(s(R),R=void 0),Y),j=async a=>(1!=p&&(U(2),O++,await X((async()=>{try{await e($,a)}catch(a){o?.(a)}U(0)}))),Y),x=()=>(r(A,a.delListener),A=void 0,Y),X=async(...a)=>(N(K(ia,u),...a),await(async()=>{if(!K(sa,u)){for(Q(sa,u,1);!i(T=g(K(ia,u)));)try{await T()}catch(a){o?.(a)}Q(sa,u,0)}})(),Y),Y={load:M,startAutoLoad:async a=>{await G().load(a);try{R=await n((async(a,t)=>{t||a?2!=p&&(U(1),C++,F(t??a),U(0)):await M()}))}catch(a){o?.(a)}return Y},stopAutoLoad:G,isAutoLoading:()=>!i(R),save:j,startAutoSave:async()=>(await x().save(),A=a.addDidFinishTransactionListener((()=>{const a=I();S(a)&&j(a)})),Y),stopAutoSave:x,isAutoSaving:()=>!i(A),getStatus:()=>p,addStatusListener:a=>_(a,L),delListener:t=>(b(t),a),schedule:X,getStore:()=>a,destroy:()=>(K(ia,u).splice(0,void 0),G().stopAutoSave()),getStats:()=>({loads:C,saves:O}),...w};return B(Y)},oa=(a,t,n,s,r,o=ca,c,E)=>{const l=J();return[async()=>{l.clear(),T(await n(a,t),(({tn:a,cn:t})=>ea(Z(l,a,ta),t)))},async(t,e)=>((a,t)=>h(K(l,a),t))(t,e)?j(A(T(await a(S+m(t)),(a=>{return[a[e],E?(t=X(a,e),n=E,j(Y(t,((a,t)=>[t,n(a,t)])))):X(a,e)];var t,n})),(([a,t])=>!i(a)&&!W(t)))):{},async(t,n,s,E,y,d=!1)=>{const g=ta();Y(s??{},(a=>T(G(a??{}),(a=>ea(g,a)))));const p=b(g);if(!d&&y&&R(p)&&h(l,t))return await a("DROP "+v+m(t)),void Q(l,t);const C=K(l,t),O=ta(b(C));if(R(p)||(h(l,t)?await w(T([n,...p],(async(e,s)=>{D(O,e)||(await a($+m(t)+"ADD"+m(e)+r),0==s&&await a("CREATE UNIQUE INDEX pk ON "+m(t)+`(${m(n)})`),ea(C,e))}))):(await a("CREATE "+v+m(t)+`(${m(n)}${r} PRIMARY KEY${u(T(p,(a=>e+m(a)+r)))});`),Q(l,t,ta([n,...p])))),await w([...!d&&E?T(b(O),(async e=>{e!=n&&(await a($+m(t)+"DROP"+m(e)),D(C,e))})):[]]),d)i(s)?await a(I+m(t)+L+" true"):await w(Y(s,(async(e,s)=>{i(e)?await a(I+m(t)+L+m(n)+"=$1",[s]):R(p)||await o(a,t,n,G(e),{[s]:c?T(q(e),c):q(e)},C)})));else if(R(p))h(l,t)&&await a(I+m(t)+L+" true");else{const e=A(b(K(l,t)),(a=>a!=n)),i={},r=[];Y(s??{},((a,t)=>{i[t]=T(e,(t=>c?c(a?.[t]):a?.[t])),N(r,t)})),await o(a,t,n,e,i),await a(I+m(t)+L+m(n)+`NOT IN(${_(r)})`,r)}},async t=>{let e;await a("BEGIN");try{e=await t()}catch(a){s?.(a)}return await a("END"),e}]},ca=async(a,t,n,s,i)=>{const r=[1];await a("INSERT INTO"+m(t)+"("+((...a)=>u(T(a,m),e))(n,...s)+")VALUES"+u(Y(i,(a=>"($"+r[0]+++","+_(a,r)+")")),e)+"ON CONFLICT("+m(n)+")DO UPDATE SET"+u(T(s,(a=>m(a)+"=excluded."+m(a))),e),Y(i,((a,t)=>[t,...T(a,(a=>a??null))])).flat())},Ea=(a,t,e,n,s,i,r,[o,c,E],l,w,y,d,u,T)=>{const[R,A,N,g]=oa(t,l,w,s,u,T),C=ra(a,(async()=>await g((async()=>{return await R(),a=(await A(o,c))[p]?.[E]??"null",z(a,((a,t)=>""===t?void 0:t));var a}))),(async a=>await g((async()=>{var t;await R(),await N(o,c,{[p]:{[E]:(t=a()??null,k(t,((a,t)=>void 0===t?"":t)))}},!0,!0)}))),e,n,s,r,{[d]:()=>y,destroy:()=>(C.stopAutoLoad().stopAutoSave(),i(),C)},y);return C},la=(a,t,e,n,s,r,o,[c,E,[l,y,d]],u,T,R,N,g,O,L,v)=>{const[$,I,S,m]=oa(t,u,T,s,g,O,L,v),_=async(a,t)=>await w(V(E,(async([e,n,s,i],r)=>{t&&!(r in a)||await S(e,n,a[r],s,i,t)}))),h=async(a,t)=>y?await S(d,C,{[p]:a},!0,!0,t):null,f=ra(a,(async()=>await m((async()=>{await $();const a=await(async()=>j(A(await w(V(c,(async([a,t],e)=>[a,await I(e,t)]))),(a=>!W(a[1])))))(),t=await(async()=>l?(await I(d,C))[p]:{})();return W(a)&&i(t)?void 0:[a,t]}))),(async(a,t)=>await m((async()=>{if(await $(),i(t)){const[t,e]=a();await _(t),await h(e)}else await _(t[0],!0),await h(t[1],!0)}))),e,n,s,o,{[N]:()=>R,destroy:()=>(f.stopAutoLoad().stopAutoSave(),r(),f)},R);return f},wa="ColumnName",ya="store",da="json",ua=ya+"TableName",Ta=ya+"Id"+wa,Ra=ya+wa,Aa="autoLoadIntervalSeconds",Na="rowId"+wa,ga="tableId",pa="tableName",Ca="deleteEmptyColumns",Oa="deleteEmptyTable",La={mode:da,[Aa]:1},va={load:0,save:0,[pa]:t+"_values"},$a=(a,t,e,n,s)=>{const r=J();return Y(a,((a,c)=>{const l=E(q(x(t,o(a)?{[e]:a}:a)),0,H(t));i(l[0])||n(c,l[0])||(s(c,l[0]),Q(r,c,l))})),r},Ia=t,Sa=/^([cd]:)(.+)/,ma=t+"_data",_a=t+"_table";exports.createPglitePersister=async(a,e,n,s,i)=>((a,e,n,s,i,c,l,y,d,u,R="getDb")=>{const A=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(n,c),[N,,g,p]=(a=>{const e=(a=>x(La,o(a)?{[ua]:a}:a??{}))(a),n=e[Aa];if(e.mode==da){const a=e[ua]??t;return[1,n,[a,e[Ta]??C,e[Ra]??ya],ta(a)]}const{tables:{load:s={},save:i={}}={},values:r={}}=e,c=E(q(x(va,r)),0,H(va)),l=c[2],w=ta(l),y=ta(l);return[0,n,[$a(s,{[ga]:null,[Na]:C},ga,(a=>h(y,a)),(a=>ea(w,a))),$a(i,{[pa]:null,[Na]:C,[Ca]:0,[Oa]:0},pa,((a,t)=>h(y,t)),((a,t)=>ea(w,t))),c],w]})(e),v=async a=>{await A(`CREATE OR REPLACE TRIGGER ${m(ma+"_"+a)} AFTER INSERT OR UPDATE OR DELETE ON ${m(a)} EXECUTE FUNCTION ${ma}()`)};return(N?Ea:la)(a,A,(async a=>{await A(`CREATE OR REPLACE FUNCTION ${_a}()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('${Ia}','c:'||SPLIT_PART(row.object_identity,'.',2));END LOOP;END;$t2$ LANGUAGE plpgsql;`);try{await A(`CREATE EVENT TRIGGER ${_a} ON ddl_command_end WHEN TAG IN('CREATE TABLE')EXECUTE FUNCTION ${_a}();`)}catch{}return await A(`CREATE OR REPLACE FUNCTION ${ma}()RETURNS trigger AS $t1$ BEGIN PERFORM pg_notify('${Ia}','d:'||TG_TABLE_NAME);RETURN NULL;END;$t1$ LANGUAGE plpgsql;`),await w(T(b(p),(async a=>{await A(`CREATE TABLE IF NOT EXISTS ${m(a)}("_id"text PRIMARY KEY)`),await v(a)}))),await s(Ia,(async t=>{return await r((e=t,n=Sa,e?.match(n)),(async([,t,e])=>{h(p,e)&&("c:"==t&&await v(e),a())}));var e,n}))}),i,l,y,d,g,b(p),(async(a,t)=>await a(`${O} table_name tn,column_name cn FROM information_schema.columns ${L} table_schema='public'AND table_name IN(${_(t)})`,t)),u,R,"text",void 0,(a=>k(a)),(a=>z(a)))})(a,n,(async(a,t=[])=>(await e.query(a,t)).rows),(async(a,t)=>await e.listen(a,t)),(async a=>{try{await a()}catch(a){i?.(a)}}),s,i,(()=>0),3,e,"getPglite");