tinybase 5.4.6 → 5.4.7

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