tinybase 5.3.2 → 5.3.4

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 (938) hide show
  1. package/cjs/common/index.cjs +1 -1
  2. package/cjs/common/with-schemas/index.cjs +1 -1
  3. package/cjs/es6/common/index.cjs +1 -1
  4. package/cjs/es6/common/with-schemas/index.cjs +1 -1
  5. package/cjs/es6/index.cjs +1 -1
  6. package/cjs/es6/mergeable-store/index.cjs +1 -1
  7. package/cjs/es6/mergeable-store/with-schemas/index.cjs +1 -1
  8. package/cjs/es6/min/common/index.cjs +1 -1
  9. package/cjs/es6/min/common/index.cjs.gz +0 -0
  10. package/cjs/es6/min/common/with-schemas/index.cjs +1 -1
  11. package/cjs/es6/min/common/with-schemas/index.cjs.gz +0 -0
  12. package/cjs/es6/min/index.cjs +1 -1
  13. package/cjs/es6/min/index.cjs.gz +0 -0
  14. package/cjs/es6/min/mergeable-store/index.cjs +1 -1
  15. package/cjs/es6/min/mergeable-store/index.cjs.gz +0 -0
  16. package/cjs/es6/min/mergeable-store/with-schemas/index.cjs +1 -1
  17. package/cjs/es6/min/mergeable-store/with-schemas/index.cjs.gz +0 -0
  18. package/cjs/es6/min/persisters/index.cjs +1 -1
  19. package/cjs/es6/min/persisters/index.cjs.gz +0 -0
  20. package/cjs/es6/min/persisters/persister-automerge/index.cjs +1 -1
  21. package/cjs/es6/min/persisters/persister-automerge/index.cjs.gz +0 -0
  22. package/cjs/es6/min/persisters/persister-automerge/with-schemas/index.cjs +1 -1
  23. package/cjs/es6/min/persisters/persister-automerge/with-schemas/index.cjs.gz +0 -0
  24. package/cjs/es6/min/persisters/persister-browser/index.cjs +1 -1
  25. package/cjs/es6/min/persisters/persister-browser/index.cjs.gz +0 -0
  26. package/cjs/es6/min/persisters/persister-browser/with-schemas/index.cjs +1 -1
  27. package/cjs/es6/min/persisters/persister-browser/with-schemas/index.cjs.gz +0 -0
  28. package/cjs/es6/min/persisters/persister-cr-sqlite-wasm/index.cjs +1 -1
  29. package/cjs/es6/min/persisters/persister-cr-sqlite-wasm/index.cjs.gz +0 -0
  30. package/cjs/es6/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.cjs +1 -1
  31. package/cjs/es6/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.cjs.gz +0 -0
  32. package/cjs/es6/min/persisters/persister-electric-sql/index.cjs +1 -1
  33. package/cjs/es6/min/persisters/persister-electric-sql/index.cjs.gz +0 -0
  34. package/cjs/es6/min/persisters/persister-electric-sql/with-schemas/index.cjs +1 -1
  35. package/cjs/es6/min/persisters/persister-electric-sql/with-schemas/index.cjs.gz +0 -0
  36. package/cjs/es6/min/persisters/persister-expo-sqlite/index.cjs +1 -1
  37. package/cjs/es6/min/persisters/persister-expo-sqlite/index.cjs.gz +0 -0
  38. package/cjs/es6/min/persisters/persister-expo-sqlite/with-schemas/index.cjs +1 -1
  39. package/cjs/es6/min/persisters/persister-expo-sqlite/with-schemas/index.cjs.gz +0 -0
  40. package/cjs/es6/min/persisters/persister-file/index.cjs +1 -1
  41. package/cjs/es6/min/persisters/persister-file/index.cjs.gz +0 -0
  42. package/cjs/es6/min/persisters/persister-file/with-schemas/index.cjs +1 -1
  43. package/cjs/es6/min/persisters/persister-file/with-schemas/index.cjs.gz +0 -0
  44. package/cjs/es6/min/persisters/persister-indexed-db/index.cjs +1 -1
  45. package/cjs/es6/min/persisters/persister-indexed-db/index.cjs.gz +0 -0
  46. package/cjs/es6/min/persisters/persister-indexed-db/with-schemas/index.cjs +1 -1
  47. package/cjs/es6/min/persisters/persister-indexed-db/with-schemas/index.cjs.gz +0 -0
  48. package/cjs/es6/min/persisters/persister-libsql/index.cjs +1 -1
  49. package/cjs/es6/min/persisters/persister-libsql/index.cjs.gz +0 -0
  50. package/cjs/es6/min/persisters/persister-libsql/with-schemas/index.cjs +1 -1
  51. package/cjs/es6/min/persisters/persister-libsql/with-schemas/index.cjs.gz +0 -0
  52. package/cjs/es6/min/persisters/persister-partykit-client/index.cjs +1 -1
  53. package/cjs/es6/min/persisters/persister-partykit-client/index.cjs.gz +0 -0
  54. package/cjs/es6/min/persisters/persister-partykit-client/with-schemas/index.cjs +1 -1
  55. package/cjs/es6/min/persisters/persister-partykit-client/with-schemas/index.cjs.gz +0 -0
  56. package/cjs/es6/min/persisters/persister-pglite/index.cjs +1 -1
  57. package/cjs/es6/min/persisters/persister-pglite/index.cjs.gz +0 -0
  58. package/cjs/es6/min/persisters/persister-pglite/with-schemas/index.cjs +1 -1
  59. package/cjs/es6/min/persisters/persister-pglite/with-schemas/index.cjs.gz +0 -0
  60. package/cjs/es6/min/persisters/persister-postgres/index.cjs +1 -1
  61. package/cjs/es6/min/persisters/persister-postgres/index.cjs.gz +0 -0
  62. package/cjs/es6/min/persisters/persister-postgres/with-schemas/index.cjs +1 -1
  63. package/cjs/es6/min/persisters/persister-postgres/with-schemas/index.cjs.gz +0 -0
  64. package/cjs/es6/min/persisters/persister-powersync/index.cjs +1 -1
  65. package/cjs/es6/min/persisters/persister-powersync/index.cjs.gz +0 -0
  66. package/cjs/es6/min/persisters/persister-powersync/with-schemas/index.cjs +1 -1
  67. package/cjs/es6/min/persisters/persister-powersync/with-schemas/index.cjs.gz +0 -0
  68. package/cjs/es6/min/persisters/persister-remote/index.cjs +1 -1
  69. package/cjs/es6/min/persisters/persister-remote/index.cjs.gz +0 -0
  70. package/cjs/es6/min/persisters/persister-remote/with-schemas/index.cjs +1 -1
  71. package/cjs/es6/min/persisters/persister-remote/with-schemas/index.cjs.gz +0 -0
  72. package/cjs/es6/min/persisters/persister-sqlite-wasm/index.cjs +1 -1
  73. package/cjs/es6/min/persisters/persister-sqlite-wasm/index.cjs.gz +0 -0
  74. package/cjs/es6/min/persisters/persister-sqlite-wasm/with-schemas/index.cjs +1 -1
  75. package/cjs/es6/min/persisters/persister-sqlite-wasm/with-schemas/index.cjs.gz +0 -0
  76. package/cjs/es6/min/persisters/persister-sqlite3/index.cjs +1 -1
  77. package/cjs/es6/min/persisters/persister-sqlite3/index.cjs.gz +0 -0
  78. package/cjs/es6/min/persisters/persister-sqlite3/with-schemas/index.cjs +1 -1
  79. package/cjs/es6/min/persisters/persister-sqlite3/with-schemas/index.cjs.gz +0 -0
  80. package/cjs/es6/min/persisters/persister-yjs/index.cjs +1 -1
  81. package/cjs/es6/min/persisters/persister-yjs/index.cjs.gz +0 -0
  82. package/cjs/es6/min/persisters/persister-yjs/with-schemas/index.cjs +1 -1
  83. package/cjs/es6/min/persisters/persister-yjs/with-schemas/index.cjs.gz +0 -0
  84. package/cjs/es6/min/persisters/with-schemas/index.cjs +1 -1
  85. package/cjs/es6/min/persisters/with-schemas/index.cjs.gz +0 -0
  86. package/cjs/es6/min/synchronizers/index.cjs +1 -1
  87. package/cjs/es6/min/synchronizers/index.cjs.gz +0 -0
  88. package/cjs/es6/min/synchronizers/synchronizer-broadcast-channel/index.cjs +1 -1
  89. package/cjs/es6/min/synchronizers/synchronizer-broadcast-channel/index.cjs.gz +0 -0
  90. package/cjs/es6/min/synchronizers/synchronizer-broadcast-channel/with-schemas/index.cjs +1 -1
  91. package/cjs/es6/min/synchronizers/synchronizer-broadcast-channel/with-schemas/index.cjs.gz +0 -0
  92. package/cjs/es6/min/synchronizers/synchronizer-local/index.cjs +1 -1
  93. package/cjs/es6/min/synchronizers/synchronizer-local/index.cjs.gz +0 -0
  94. package/cjs/es6/min/synchronizers/synchronizer-local/with-schemas/index.cjs +1 -1
  95. package/cjs/es6/min/synchronizers/synchronizer-local/with-schemas/index.cjs.gz +0 -0
  96. package/cjs/es6/min/synchronizers/synchronizer-ws-client/index.cjs +1 -1
  97. package/cjs/es6/min/synchronizers/synchronizer-ws-client/index.cjs.gz +0 -0
  98. package/cjs/es6/min/synchronizers/synchronizer-ws-client/with-schemas/index.cjs +1 -1
  99. package/cjs/es6/min/synchronizers/synchronizer-ws-client/with-schemas/index.cjs.gz +0 -0
  100. package/cjs/es6/min/synchronizers/synchronizer-ws-server/index.cjs +1 -1
  101. package/cjs/es6/min/synchronizers/synchronizer-ws-server/index.cjs.gz +0 -0
  102. package/cjs/es6/min/synchronizers/synchronizer-ws-server/with-schemas/index.cjs +1 -1
  103. package/cjs/es6/min/synchronizers/synchronizer-ws-server/with-schemas/index.cjs.gz +0 -0
  104. package/cjs/es6/min/synchronizers/with-schemas/index.cjs +1 -1
  105. package/cjs/es6/min/synchronizers/with-schemas/index.cjs.gz +0 -0
  106. package/cjs/es6/min/ui-react-inspector/index.cjs +1 -1
  107. package/cjs/es6/min/ui-react-inspector/index.cjs.gz +0 -0
  108. package/cjs/es6/min/ui-react-inspector/with-schemas/index.cjs +1 -1
  109. package/cjs/es6/min/ui-react-inspector/with-schemas/index.cjs.gz +0 -0
  110. package/cjs/es6/min/with-schemas/index.cjs +1 -1
  111. package/cjs/es6/min/with-schemas/index.cjs.gz +0 -0
  112. package/cjs/es6/persisters/index.cjs +85 -103
  113. package/cjs/es6/persisters/persister-automerge/index.cjs +2 -0
  114. package/cjs/es6/persisters/persister-automerge/with-schemas/index.cjs +2 -0
  115. package/cjs/es6/persisters/persister-browser/index.cjs +2 -0
  116. package/cjs/es6/persisters/persister-browser/with-schemas/index.cjs +2 -0
  117. package/cjs/es6/persisters/persister-cr-sqlite-wasm/index.cjs +84 -102
  118. package/cjs/es6/persisters/persister-cr-sqlite-wasm/with-schemas/index.cjs +84 -102
  119. package/cjs/es6/persisters/persister-electric-sql/index.cjs +84 -102
  120. package/cjs/es6/persisters/persister-electric-sql/with-schemas/index.cjs +84 -102
  121. package/cjs/es6/persisters/persister-expo-sqlite/index.cjs +84 -102
  122. package/cjs/es6/persisters/persister-expo-sqlite/with-schemas/index.cjs +84 -102
  123. package/cjs/es6/persisters/persister-file/index.cjs +2 -0
  124. package/cjs/es6/persisters/persister-file/with-schemas/index.cjs +2 -0
  125. package/cjs/es6/persisters/persister-indexed-db/index.cjs +2 -0
  126. package/cjs/es6/persisters/persister-indexed-db/with-schemas/index.cjs +2 -0
  127. package/cjs/es6/persisters/persister-libsql/index.cjs +84 -102
  128. package/cjs/es6/persisters/persister-libsql/with-schemas/index.cjs +84 -102
  129. package/cjs/es6/persisters/persister-partykit-client/index.cjs +2 -0
  130. package/cjs/es6/persisters/persister-partykit-client/with-schemas/index.cjs +2 -0
  131. package/cjs/es6/persisters/persister-pglite/index.cjs +83 -101
  132. package/cjs/es6/persisters/persister-pglite/with-schemas/index.cjs +83 -101
  133. package/cjs/es6/persisters/persister-postgres/index.cjs +83 -101
  134. package/cjs/es6/persisters/persister-postgres/with-schemas/index.cjs +83 -101
  135. package/cjs/es6/persisters/persister-powersync/index.cjs +214 -147
  136. package/cjs/es6/persisters/persister-powersync/with-schemas/index.cjs +214 -147
  137. package/cjs/es6/persisters/persister-remote/index.cjs +2 -0
  138. package/cjs/es6/persisters/persister-remote/with-schemas/index.cjs +2 -0
  139. package/cjs/es6/persisters/persister-sqlite-wasm/index.cjs +84 -102
  140. package/cjs/es6/persisters/persister-sqlite-wasm/with-schemas/index.cjs +84 -102
  141. package/cjs/es6/persisters/persister-sqlite3/index.cjs +84 -102
  142. package/cjs/es6/persisters/persister-sqlite3/with-schemas/index.cjs +84 -102
  143. package/cjs/es6/persisters/persister-yjs/index.cjs +2 -0
  144. package/cjs/es6/persisters/persister-yjs/with-schemas/index.cjs +2 -0
  145. package/cjs/es6/persisters/with-schemas/index.cjs +85 -103
  146. package/cjs/es6/synchronizers/index.cjs +3 -1
  147. package/cjs/es6/synchronizers/synchronizer-broadcast-channel/index.cjs +3 -1
  148. package/cjs/es6/synchronizers/synchronizer-broadcast-channel/with-schemas/index.cjs +3 -1
  149. package/cjs/es6/synchronizers/synchronizer-local/index.cjs +3 -1
  150. package/cjs/es6/synchronizers/synchronizer-local/with-schemas/index.cjs +3 -1
  151. package/cjs/es6/synchronizers/synchronizer-ws-client/index.cjs +3 -1
  152. package/cjs/es6/synchronizers/synchronizer-ws-client/with-schemas/index.cjs +3 -1
  153. package/cjs/es6/synchronizers/synchronizer-ws-server/index.cjs +3 -1
  154. package/cjs/es6/synchronizers/synchronizer-ws-server/with-schemas/index.cjs +3 -1
  155. package/cjs/es6/synchronizers/with-schemas/index.cjs +3 -1
  156. package/cjs/es6/ui-react-inspector/index.cjs +2 -2
  157. package/cjs/es6/ui-react-inspector/with-schemas/index.cjs +2 -2
  158. package/cjs/es6/with-schemas/index.cjs +1 -1
  159. package/cjs/index.cjs +1 -1
  160. package/cjs/mergeable-store/index.cjs +1 -1
  161. package/cjs/mergeable-store/with-schemas/index.cjs +1 -1
  162. package/cjs/min/common/index.cjs +1 -1
  163. package/cjs/min/common/index.cjs.gz +0 -0
  164. package/cjs/min/common/with-schemas/index.cjs +1 -1
  165. package/cjs/min/common/with-schemas/index.cjs.gz +0 -0
  166. package/cjs/min/index.cjs +1 -1
  167. package/cjs/min/index.cjs.gz +0 -0
  168. package/cjs/min/mergeable-store/index.cjs +1 -1
  169. package/cjs/min/mergeable-store/index.cjs.gz +0 -0
  170. package/cjs/min/mergeable-store/with-schemas/index.cjs +1 -1
  171. package/cjs/min/mergeable-store/with-schemas/index.cjs.gz +0 -0
  172. package/cjs/min/persisters/index.cjs +1 -1
  173. package/cjs/min/persisters/index.cjs.gz +0 -0
  174. package/cjs/min/persisters/persister-automerge/index.cjs +1 -1
  175. package/cjs/min/persisters/persister-automerge/index.cjs.gz +0 -0
  176. package/cjs/min/persisters/persister-automerge/with-schemas/index.cjs +1 -1
  177. package/cjs/min/persisters/persister-automerge/with-schemas/index.cjs.gz +0 -0
  178. package/cjs/min/persisters/persister-browser/index.cjs +1 -1
  179. package/cjs/min/persisters/persister-browser/index.cjs.gz +0 -0
  180. package/cjs/min/persisters/persister-browser/with-schemas/index.cjs +1 -1
  181. package/cjs/min/persisters/persister-browser/with-schemas/index.cjs.gz +0 -0
  182. package/cjs/min/persisters/persister-cr-sqlite-wasm/index.cjs +1 -1
  183. package/cjs/min/persisters/persister-cr-sqlite-wasm/index.cjs.gz +0 -0
  184. package/cjs/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.cjs +1 -1
  185. package/cjs/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.cjs.gz +0 -0
  186. package/cjs/min/persisters/persister-electric-sql/index.cjs +1 -1
  187. package/cjs/min/persisters/persister-electric-sql/index.cjs.gz +0 -0
  188. package/cjs/min/persisters/persister-electric-sql/with-schemas/index.cjs +1 -1
  189. package/cjs/min/persisters/persister-electric-sql/with-schemas/index.cjs.gz +0 -0
  190. package/cjs/min/persisters/persister-expo-sqlite/index.cjs +1 -1
  191. package/cjs/min/persisters/persister-expo-sqlite/index.cjs.gz +0 -0
  192. package/cjs/min/persisters/persister-expo-sqlite/with-schemas/index.cjs +1 -1
  193. package/cjs/min/persisters/persister-expo-sqlite/with-schemas/index.cjs.gz +0 -0
  194. package/cjs/min/persisters/persister-file/index.cjs +1 -1
  195. package/cjs/min/persisters/persister-file/index.cjs.gz +0 -0
  196. package/cjs/min/persisters/persister-file/with-schemas/index.cjs +1 -1
  197. package/cjs/min/persisters/persister-file/with-schemas/index.cjs.gz +0 -0
  198. package/cjs/min/persisters/persister-indexed-db/index.cjs +1 -1
  199. package/cjs/min/persisters/persister-indexed-db/index.cjs.gz +0 -0
  200. package/cjs/min/persisters/persister-indexed-db/with-schemas/index.cjs +1 -1
  201. package/cjs/min/persisters/persister-indexed-db/with-schemas/index.cjs.gz +0 -0
  202. package/cjs/min/persisters/persister-libsql/index.cjs +1 -1
  203. package/cjs/min/persisters/persister-libsql/index.cjs.gz +0 -0
  204. package/cjs/min/persisters/persister-libsql/with-schemas/index.cjs +1 -1
  205. package/cjs/min/persisters/persister-libsql/with-schemas/index.cjs.gz +0 -0
  206. package/cjs/min/persisters/persister-partykit-client/index.cjs +1 -1
  207. package/cjs/min/persisters/persister-partykit-client/index.cjs.gz +0 -0
  208. package/cjs/min/persisters/persister-partykit-client/with-schemas/index.cjs +1 -1
  209. package/cjs/min/persisters/persister-partykit-client/with-schemas/index.cjs.gz +0 -0
  210. package/cjs/min/persisters/persister-pglite/index.cjs +1 -1
  211. package/cjs/min/persisters/persister-pglite/index.cjs.gz +0 -0
  212. package/cjs/min/persisters/persister-pglite/with-schemas/index.cjs +1 -1
  213. package/cjs/min/persisters/persister-pglite/with-schemas/index.cjs.gz +0 -0
  214. package/cjs/min/persisters/persister-postgres/index.cjs +1 -1
  215. package/cjs/min/persisters/persister-postgres/index.cjs.gz +0 -0
  216. package/cjs/min/persisters/persister-postgres/with-schemas/index.cjs +1 -1
  217. package/cjs/min/persisters/persister-postgres/with-schemas/index.cjs.gz +0 -0
  218. package/cjs/min/persisters/persister-powersync/index.cjs +1 -1
  219. package/cjs/min/persisters/persister-powersync/index.cjs.gz +0 -0
  220. package/cjs/min/persisters/persister-powersync/with-schemas/index.cjs +1 -1
  221. package/cjs/min/persisters/persister-powersync/with-schemas/index.cjs.gz +0 -0
  222. package/cjs/min/persisters/persister-remote/index.cjs +1 -1
  223. package/cjs/min/persisters/persister-remote/index.cjs.gz +0 -0
  224. package/cjs/min/persisters/persister-remote/with-schemas/index.cjs +1 -1
  225. package/cjs/min/persisters/persister-remote/with-schemas/index.cjs.gz +0 -0
  226. package/cjs/min/persisters/persister-sqlite-wasm/index.cjs +1 -1
  227. package/cjs/min/persisters/persister-sqlite-wasm/index.cjs.gz +0 -0
  228. package/cjs/min/persisters/persister-sqlite-wasm/with-schemas/index.cjs +1 -1
  229. package/cjs/min/persisters/persister-sqlite-wasm/with-schemas/index.cjs.gz +0 -0
  230. package/cjs/min/persisters/persister-sqlite3/index.cjs +1 -1
  231. package/cjs/min/persisters/persister-sqlite3/index.cjs.gz +0 -0
  232. package/cjs/min/persisters/persister-sqlite3/with-schemas/index.cjs +1 -1
  233. package/cjs/min/persisters/persister-sqlite3/with-schemas/index.cjs.gz +0 -0
  234. package/cjs/min/persisters/persister-yjs/index.cjs +1 -1
  235. package/cjs/min/persisters/persister-yjs/index.cjs.gz +0 -0
  236. package/cjs/min/persisters/persister-yjs/with-schemas/index.cjs +1 -1
  237. package/cjs/min/persisters/persister-yjs/with-schemas/index.cjs.gz +0 -0
  238. package/cjs/min/persisters/with-schemas/index.cjs +1 -1
  239. package/cjs/min/persisters/with-schemas/index.cjs.gz +0 -0
  240. package/cjs/min/synchronizers/index.cjs +1 -1
  241. package/cjs/min/synchronizers/index.cjs.gz +0 -0
  242. package/cjs/min/synchronizers/synchronizer-broadcast-channel/index.cjs +1 -1
  243. package/cjs/min/synchronizers/synchronizer-broadcast-channel/index.cjs.gz +0 -0
  244. package/cjs/min/synchronizers/synchronizer-broadcast-channel/with-schemas/index.cjs +1 -1
  245. package/cjs/min/synchronizers/synchronizer-broadcast-channel/with-schemas/index.cjs.gz +0 -0
  246. package/cjs/min/synchronizers/synchronizer-local/index.cjs +1 -1
  247. package/cjs/min/synchronizers/synchronizer-local/index.cjs.gz +0 -0
  248. package/cjs/min/synchronizers/synchronizer-local/with-schemas/index.cjs +1 -1
  249. package/cjs/min/synchronizers/synchronizer-local/with-schemas/index.cjs.gz +0 -0
  250. package/cjs/min/synchronizers/synchronizer-ws-client/index.cjs +1 -1
  251. package/cjs/min/synchronizers/synchronizer-ws-client/index.cjs.gz +0 -0
  252. package/cjs/min/synchronizers/synchronizer-ws-client/with-schemas/index.cjs +1 -1
  253. package/cjs/min/synchronizers/synchronizer-ws-client/with-schemas/index.cjs.gz +0 -0
  254. package/cjs/min/synchronizers/synchronizer-ws-server/index.cjs +1 -1
  255. package/cjs/min/synchronizers/synchronizer-ws-server/index.cjs.gz +0 -0
  256. package/cjs/min/synchronizers/synchronizer-ws-server/with-schemas/index.cjs +1 -1
  257. package/cjs/min/synchronizers/synchronizer-ws-server/with-schemas/index.cjs.gz +0 -0
  258. package/cjs/min/synchronizers/with-schemas/index.cjs +1 -1
  259. package/cjs/min/synchronizers/with-schemas/index.cjs.gz +0 -0
  260. package/cjs/min/ui-react-inspector/index.cjs +1 -1
  261. package/cjs/min/ui-react-inspector/index.cjs.gz +0 -0
  262. package/cjs/min/ui-react-inspector/with-schemas/index.cjs +1 -1
  263. package/cjs/min/ui-react-inspector/with-schemas/index.cjs.gz +0 -0
  264. package/cjs/min/with-schemas/index.cjs +1 -1
  265. package/cjs/min/with-schemas/index.cjs.gz +0 -0
  266. package/cjs/persisters/index.cjs +82 -98
  267. package/cjs/persisters/persister-automerge/index.cjs +2 -0
  268. package/cjs/persisters/persister-automerge/with-schemas/index.cjs +2 -0
  269. package/cjs/persisters/persister-browser/index.cjs +2 -0
  270. package/cjs/persisters/persister-browser/with-schemas/index.cjs +2 -0
  271. package/cjs/persisters/persister-cr-sqlite-wasm/index.cjs +81 -97
  272. package/cjs/persisters/persister-cr-sqlite-wasm/with-schemas/index.cjs +81 -97
  273. package/cjs/persisters/persister-electric-sql/index.cjs +81 -97
  274. package/cjs/persisters/persister-electric-sql/with-schemas/index.cjs +81 -97
  275. package/cjs/persisters/persister-expo-sqlite/index.cjs +81 -97
  276. package/cjs/persisters/persister-expo-sqlite/with-schemas/index.cjs +81 -97
  277. package/cjs/persisters/persister-file/index.cjs +2 -0
  278. package/cjs/persisters/persister-file/with-schemas/index.cjs +2 -0
  279. package/cjs/persisters/persister-indexed-db/index.cjs +2 -0
  280. package/cjs/persisters/persister-indexed-db/with-schemas/index.cjs +2 -0
  281. package/cjs/persisters/persister-libsql/index.cjs +81 -97
  282. package/cjs/persisters/persister-libsql/with-schemas/index.cjs +81 -97
  283. package/cjs/persisters/persister-partykit-client/index.cjs +2 -0
  284. package/cjs/persisters/persister-partykit-client/with-schemas/index.cjs +2 -0
  285. package/cjs/persisters/persister-pglite/index.cjs +80 -96
  286. package/cjs/persisters/persister-pglite/with-schemas/index.cjs +80 -96
  287. package/cjs/persisters/persister-postgres/index.cjs +80 -96
  288. package/cjs/persisters/persister-postgres/with-schemas/index.cjs +80 -96
  289. package/cjs/persisters/persister-powersync/index.cjs +205 -142
  290. package/cjs/persisters/persister-powersync/with-schemas/index.cjs +205 -142
  291. package/cjs/persisters/persister-remote/index.cjs +2 -0
  292. package/cjs/persisters/persister-remote/with-schemas/index.cjs +2 -0
  293. package/cjs/persisters/persister-sqlite-wasm/index.cjs +81 -97
  294. package/cjs/persisters/persister-sqlite-wasm/with-schemas/index.cjs +81 -97
  295. package/cjs/persisters/persister-sqlite3/index.cjs +81 -97
  296. package/cjs/persisters/persister-sqlite3/with-schemas/index.cjs +81 -97
  297. package/cjs/persisters/persister-yjs/index.cjs +2 -0
  298. package/cjs/persisters/persister-yjs/with-schemas/index.cjs +2 -0
  299. package/cjs/persisters/with-schemas/index.cjs +82 -98
  300. package/cjs/synchronizers/index.cjs +3 -1
  301. package/cjs/synchronizers/synchronizer-broadcast-channel/index.cjs +3 -1
  302. package/cjs/synchronizers/synchronizer-broadcast-channel/with-schemas/index.cjs +3 -1
  303. package/cjs/synchronizers/synchronizer-local/index.cjs +3 -1
  304. package/cjs/synchronizers/synchronizer-local/with-schemas/index.cjs +3 -1
  305. package/cjs/synchronizers/synchronizer-ws-client/index.cjs +3 -1
  306. package/cjs/synchronizers/synchronizer-ws-client/with-schemas/index.cjs +3 -1
  307. package/cjs/synchronizers/synchronizer-ws-server/index.cjs +3 -1
  308. package/cjs/synchronizers/synchronizer-ws-server/with-schemas/index.cjs +3 -1
  309. package/cjs/synchronizers/with-schemas/index.cjs +3 -1
  310. package/cjs/ui-react-inspector/index.cjs +2 -2
  311. package/cjs/ui-react-inspector/with-schemas/index.cjs +2 -2
  312. package/cjs/with-schemas/index.cjs +1 -1
  313. package/common/index.js +1 -1
  314. package/common/with-schemas/index.js +1 -1
  315. package/es6/common/index.js +1 -1
  316. package/es6/common/with-schemas/index.js +1 -1
  317. package/es6/index.js +1 -1
  318. package/es6/mergeable-store/index.js +1 -1
  319. package/es6/mergeable-store/with-schemas/index.js +1 -1
  320. package/es6/min/common/index.js +1 -1
  321. package/es6/min/common/index.js.gz +0 -0
  322. package/es6/min/common/with-schemas/index.js +1 -1
  323. package/es6/min/common/with-schemas/index.js.gz +0 -0
  324. package/es6/min/index.js +1 -1
  325. package/es6/min/index.js.gz +0 -0
  326. package/es6/min/mergeable-store/index.js +1 -1
  327. package/es6/min/mergeable-store/index.js.gz +0 -0
  328. package/es6/min/mergeable-store/with-schemas/index.js +1 -1
  329. package/es6/min/mergeable-store/with-schemas/index.js.gz +0 -0
  330. package/es6/min/persisters/index.js +1 -1
  331. package/es6/min/persisters/index.js.gz +0 -0
  332. package/es6/min/persisters/persister-automerge/index.js +1 -1
  333. package/es6/min/persisters/persister-automerge/index.js.gz +0 -0
  334. package/es6/min/persisters/persister-automerge/with-schemas/index.js +1 -1
  335. package/es6/min/persisters/persister-automerge/with-schemas/index.js.gz +0 -0
  336. package/es6/min/persisters/persister-browser/index.js +1 -1
  337. package/es6/min/persisters/persister-browser/index.js.gz +0 -0
  338. package/es6/min/persisters/persister-browser/with-schemas/index.js +1 -1
  339. package/es6/min/persisters/persister-browser/with-schemas/index.js.gz +0 -0
  340. package/es6/min/persisters/persister-cr-sqlite-wasm/index.js +1 -1
  341. package/es6/min/persisters/persister-cr-sqlite-wasm/index.js.gz +0 -0
  342. package/es6/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.js +1 -1
  343. package/es6/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.js.gz +0 -0
  344. package/es6/min/persisters/persister-electric-sql/index.js +1 -1
  345. package/es6/min/persisters/persister-electric-sql/index.js.gz +0 -0
  346. package/es6/min/persisters/persister-electric-sql/with-schemas/index.js +1 -1
  347. package/es6/min/persisters/persister-electric-sql/with-schemas/index.js.gz +0 -0
  348. package/es6/min/persisters/persister-expo-sqlite/index.js +1 -1
  349. package/es6/min/persisters/persister-expo-sqlite/index.js.gz +0 -0
  350. package/es6/min/persisters/persister-expo-sqlite/with-schemas/index.js +1 -1
  351. package/es6/min/persisters/persister-expo-sqlite/with-schemas/index.js.gz +0 -0
  352. package/es6/min/persisters/persister-file/index.js +1 -1
  353. package/es6/min/persisters/persister-file/index.js.gz +0 -0
  354. package/es6/min/persisters/persister-file/with-schemas/index.js +1 -1
  355. package/es6/min/persisters/persister-file/with-schemas/index.js.gz +0 -0
  356. package/es6/min/persisters/persister-indexed-db/index.js +1 -1
  357. package/es6/min/persisters/persister-indexed-db/index.js.gz +0 -0
  358. package/es6/min/persisters/persister-indexed-db/with-schemas/index.js +1 -1
  359. package/es6/min/persisters/persister-indexed-db/with-schemas/index.js.gz +0 -0
  360. package/es6/min/persisters/persister-libsql/index.js +1 -1
  361. package/es6/min/persisters/persister-libsql/index.js.gz +0 -0
  362. package/es6/min/persisters/persister-libsql/with-schemas/index.js +1 -1
  363. package/es6/min/persisters/persister-libsql/with-schemas/index.js.gz +0 -0
  364. package/es6/min/persisters/persister-partykit-client/index.js +1 -1
  365. package/es6/min/persisters/persister-partykit-client/index.js.gz +0 -0
  366. package/es6/min/persisters/persister-partykit-client/with-schemas/index.js +1 -1
  367. package/es6/min/persisters/persister-partykit-client/with-schemas/index.js.gz +0 -0
  368. package/es6/min/persisters/persister-pglite/index.js +1 -1
  369. package/es6/min/persisters/persister-pglite/index.js.gz +0 -0
  370. package/es6/min/persisters/persister-pglite/with-schemas/index.js +1 -1
  371. package/es6/min/persisters/persister-pglite/with-schemas/index.js.gz +0 -0
  372. package/es6/min/persisters/persister-postgres/index.js +1 -1
  373. package/es6/min/persisters/persister-postgres/index.js.gz +0 -0
  374. package/es6/min/persisters/persister-postgres/with-schemas/index.js +1 -1
  375. package/es6/min/persisters/persister-postgres/with-schemas/index.js.gz +0 -0
  376. package/es6/min/persisters/persister-powersync/index.js +1 -1
  377. package/es6/min/persisters/persister-powersync/index.js.gz +0 -0
  378. package/es6/min/persisters/persister-powersync/with-schemas/index.js +1 -1
  379. package/es6/min/persisters/persister-powersync/with-schemas/index.js.gz +0 -0
  380. package/es6/min/persisters/persister-remote/index.js +1 -1
  381. package/es6/min/persisters/persister-remote/index.js.gz +0 -0
  382. package/es6/min/persisters/persister-remote/with-schemas/index.js +1 -1
  383. package/es6/min/persisters/persister-remote/with-schemas/index.js.gz +0 -0
  384. package/es6/min/persisters/persister-sqlite-wasm/index.js +1 -1
  385. package/es6/min/persisters/persister-sqlite-wasm/index.js.gz +0 -0
  386. package/es6/min/persisters/persister-sqlite-wasm/with-schemas/index.js +1 -1
  387. package/es6/min/persisters/persister-sqlite-wasm/with-schemas/index.js.gz +0 -0
  388. package/es6/min/persisters/persister-sqlite3/index.js +1 -1
  389. package/es6/min/persisters/persister-sqlite3/index.js.gz +0 -0
  390. package/es6/min/persisters/persister-sqlite3/with-schemas/index.js +1 -1
  391. package/es6/min/persisters/persister-sqlite3/with-schemas/index.js.gz +0 -0
  392. package/es6/min/persisters/persister-yjs/index.js +1 -1
  393. package/es6/min/persisters/persister-yjs/index.js.gz +0 -0
  394. package/es6/min/persisters/persister-yjs/with-schemas/index.js +1 -1
  395. package/es6/min/persisters/persister-yjs/with-schemas/index.js.gz +0 -0
  396. package/es6/min/persisters/with-schemas/index.js +1 -1
  397. package/es6/min/persisters/with-schemas/index.js.gz +0 -0
  398. package/es6/min/synchronizers/index.js +1 -1
  399. package/es6/min/synchronizers/index.js.gz +0 -0
  400. package/es6/min/synchronizers/synchronizer-broadcast-channel/index.js +1 -1
  401. package/es6/min/synchronizers/synchronizer-broadcast-channel/index.js.gz +0 -0
  402. package/es6/min/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js +1 -1
  403. package/es6/min/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js.gz +0 -0
  404. package/es6/min/synchronizers/synchronizer-local/index.js +1 -1
  405. package/es6/min/synchronizers/synchronizer-local/index.js.gz +0 -0
  406. package/es6/min/synchronizers/synchronizer-local/with-schemas/index.js +1 -1
  407. package/es6/min/synchronizers/synchronizer-local/with-schemas/index.js.gz +0 -0
  408. package/es6/min/synchronizers/synchronizer-ws-client/index.js +1 -1
  409. package/es6/min/synchronizers/synchronizer-ws-client/index.js.gz +0 -0
  410. package/es6/min/synchronizers/synchronizer-ws-client/with-schemas/index.js +1 -1
  411. package/es6/min/synchronizers/synchronizer-ws-client/with-schemas/index.js.gz +0 -0
  412. package/es6/min/synchronizers/synchronizer-ws-server/index.js +1 -1
  413. package/es6/min/synchronizers/synchronizer-ws-server/index.js.gz +0 -0
  414. package/es6/min/synchronizers/synchronizer-ws-server/with-schemas/index.js +1 -1
  415. package/es6/min/synchronizers/synchronizer-ws-server/with-schemas/index.js.gz +0 -0
  416. package/es6/min/synchronizers/with-schemas/index.js +1 -1
  417. package/es6/min/synchronizers/with-schemas/index.js.gz +0 -0
  418. package/es6/min/ui-react-inspector/index.js +1 -1
  419. package/es6/min/ui-react-inspector/index.js.gz +0 -0
  420. package/es6/min/ui-react-inspector/with-schemas/index.js +1 -1
  421. package/es6/min/ui-react-inspector/with-schemas/index.js.gz +0 -0
  422. package/es6/min/with-schemas/index.js +1 -1
  423. package/es6/min/with-schemas/index.js.gz +0 -0
  424. package/es6/persisters/index.js +85 -103
  425. package/es6/persisters/persister-automerge/index.js +2 -0
  426. package/es6/persisters/persister-automerge/with-schemas/index.js +2 -0
  427. package/es6/persisters/persister-browser/index.js +2 -0
  428. package/es6/persisters/persister-browser/with-schemas/index.js +2 -0
  429. package/es6/persisters/persister-cr-sqlite-wasm/index.js +84 -102
  430. package/es6/persisters/persister-cr-sqlite-wasm/with-schemas/index.js +84 -102
  431. package/es6/persisters/persister-electric-sql/index.js +84 -102
  432. package/es6/persisters/persister-electric-sql/with-schemas/index.js +84 -102
  433. package/es6/persisters/persister-expo-sqlite/index.js +84 -102
  434. package/es6/persisters/persister-expo-sqlite/with-schemas/index.js +84 -102
  435. package/es6/persisters/persister-file/index.js +2 -0
  436. package/es6/persisters/persister-file/with-schemas/index.js +2 -0
  437. package/es6/persisters/persister-indexed-db/index.js +2 -0
  438. package/es6/persisters/persister-indexed-db/with-schemas/index.js +2 -0
  439. package/es6/persisters/persister-libsql/index.js +84 -102
  440. package/es6/persisters/persister-libsql/with-schemas/index.js +84 -102
  441. package/es6/persisters/persister-partykit-client/index.js +2 -0
  442. package/es6/persisters/persister-partykit-client/with-schemas/index.js +2 -0
  443. package/es6/persisters/persister-pglite/index.js +83 -101
  444. package/es6/persisters/persister-pglite/with-schemas/index.js +83 -101
  445. package/es6/persisters/persister-postgres/index.js +83 -101
  446. package/es6/persisters/persister-postgres/with-schemas/index.js +83 -101
  447. package/es6/persisters/persister-powersync/index.js +214 -147
  448. package/es6/persisters/persister-powersync/with-schemas/index.js +214 -147
  449. package/es6/persisters/persister-remote/index.js +2 -0
  450. package/es6/persisters/persister-remote/with-schemas/index.js +2 -0
  451. package/es6/persisters/persister-sqlite-wasm/index.js +84 -102
  452. package/es6/persisters/persister-sqlite-wasm/with-schemas/index.js +84 -102
  453. package/es6/persisters/persister-sqlite3/index.js +84 -102
  454. package/es6/persisters/persister-sqlite3/with-schemas/index.js +84 -102
  455. package/es6/persisters/persister-yjs/index.js +2 -0
  456. package/es6/persisters/persister-yjs/with-schemas/index.js +2 -0
  457. package/es6/persisters/with-schemas/index.js +85 -103
  458. package/es6/synchronizers/index.js +3 -1
  459. package/es6/synchronizers/synchronizer-broadcast-channel/index.js +3 -1
  460. package/es6/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js +3 -1
  461. package/es6/synchronizers/synchronizer-local/index.js +3 -1
  462. package/es6/synchronizers/synchronizer-local/with-schemas/index.js +3 -1
  463. package/es6/synchronizers/synchronizer-ws-client/index.js +3 -1
  464. package/es6/synchronizers/synchronizer-ws-client/with-schemas/index.js +3 -1
  465. package/es6/synchronizers/synchronizer-ws-server/index.js +3 -1
  466. package/es6/synchronizers/synchronizer-ws-server/with-schemas/index.js +3 -1
  467. package/es6/synchronizers/with-schemas/index.js +3 -1
  468. package/es6/ui-react-inspector/index.js +2 -2
  469. package/es6/ui-react-inspector/with-schemas/index.js +2 -2
  470. package/es6/with-schemas/index.js +1 -1
  471. package/index.js +1 -1
  472. package/mergeable-store/index.js +1 -1
  473. package/mergeable-store/with-schemas/index.js +1 -1
  474. package/min/common/index.js +1 -1
  475. package/min/common/index.js.gz +0 -0
  476. package/min/common/with-schemas/index.js +1 -1
  477. package/min/common/with-schemas/index.js.gz +0 -0
  478. package/min/index.js +1 -1
  479. package/min/index.js.gz +0 -0
  480. package/min/mergeable-store/index.js +1 -1
  481. package/min/mergeable-store/index.js.gz +0 -0
  482. package/min/mergeable-store/with-schemas/index.js +1 -1
  483. package/min/mergeable-store/with-schemas/index.js.gz +0 -0
  484. package/min/persisters/index.js +1 -1
  485. package/min/persisters/index.js.gz +0 -0
  486. package/min/persisters/persister-automerge/index.js +1 -1
  487. package/min/persisters/persister-automerge/index.js.gz +0 -0
  488. package/min/persisters/persister-automerge/with-schemas/index.js +1 -1
  489. package/min/persisters/persister-automerge/with-schemas/index.js.gz +0 -0
  490. package/min/persisters/persister-browser/index.js +1 -1
  491. package/min/persisters/persister-browser/index.js.gz +0 -0
  492. package/min/persisters/persister-browser/with-schemas/index.js +1 -1
  493. package/min/persisters/persister-browser/with-schemas/index.js.gz +0 -0
  494. package/min/persisters/persister-cr-sqlite-wasm/index.js +1 -1
  495. package/min/persisters/persister-cr-sqlite-wasm/index.js.gz +0 -0
  496. package/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.js +1 -1
  497. package/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.js.gz +0 -0
  498. package/min/persisters/persister-electric-sql/index.js +1 -1
  499. package/min/persisters/persister-electric-sql/index.js.gz +0 -0
  500. package/min/persisters/persister-electric-sql/with-schemas/index.js +1 -1
  501. package/min/persisters/persister-electric-sql/with-schemas/index.js.gz +0 -0
  502. package/min/persisters/persister-expo-sqlite/index.js +1 -1
  503. package/min/persisters/persister-expo-sqlite/index.js.gz +0 -0
  504. package/min/persisters/persister-expo-sqlite/with-schemas/index.js +1 -1
  505. package/min/persisters/persister-expo-sqlite/with-schemas/index.js.gz +0 -0
  506. package/min/persisters/persister-file/index.js +1 -1
  507. package/min/persisters/persister-file/index.js.gz +0 -0
  508. package/min/persisters/persister-file/with-schemas/index.js +1 -1
  509. package/min/persisters/persister-file/with-schemas/index.js.gz +0 -0
  510. package/min/persisters/persister-indexed-db/index.js +1 -1
  511. package/min/persisters/persister-indexed-db/index.js.gz +0 -0
  512. package/min/persisters/persister-indexed-db/with-schemas/index.js +1 -1
  513. package/min/persisters/persister-indexed-db/with-schemas/index.js.gz +0 -0
  514. package/min/persisters/persister-libsql/index.js +1 -1
  515. package/min/persisters/persister-libsql/index.js.gz +0 -0
  516. package/min/persisters/persister-libsql/with-schemas/index.js +1 -1
  517. package/min/persisters/persister-libsql/with-schemas/index.js.gz +0 -0
  518. package/min/persisters/persister-partykit-client/index.js +1 -1
  519. package/min/persisters/persister-partykit-client/index.js.gz +0 -0
  520. package/min/persisters/persister-partykit-client/with-schemas/index.js +1 -1
  521. package/min/persisters/persister-partykit-client/with-schemas/index.js.gz +0 -0
  522. package/min/persisters/persister-pglite/index.js +1 -1
  523. package/min/persisters/persister-pglite/index.js.gz +0 -0
  524. package/min/persisters/persister-pglite/with-schemas/index.js +1 -1
  525. package/min/persisters/persister-pglite/with-schemas/index.js.gz +0 -0
  526. package/min/persisters/persister-postgres/index.js +1 -1
  527. package/min/persisters/persister-postgres/index.js.gz +0 -0
  528. package/min/persisters/persister-postgres/with-schemas/index.js +1 -1
  529. package/min/persisters/persister-postgres/with-schemas/index.js.gz +0 -0
  530. package/min/persisters/persister-powersync/index.js +1 -1
  531. package/min/persisters/persister-powersync/index.js.gz +0 -0
  532. package/min/persisters/persister-powersync/with-schemas/index.js +1 -1
  533. package/min/persisters/persister-powersync/with-schemas/index.js.gz +0 -0
  534. package/min/persisters/persister-remote/index.js +1 -1
  535. package/min/persisters/persister-remote/index.js.gz +0 -0
  536. package/min/persisters/persister-remote/with-schemas/index.js +1 -1
  537. package/min/persisters/persister-remote/with-schemas/index.js.gz +0 -0
  538. package/min/persisters/persister-sqlite-wasm/index.js +1 -1
  539. package/min/persisters/persister-sqlite-wasm/index.js.gz +0 -0
  540. package/min/persisters/persister-sqlite-wasm/with-schemas/index.js +1 -1
  541. package/min/persisters/persister-sqlite-wasm/with-schemas/index.js.gz +0 -0
  542. package/min/persisters/persister-sqlite3/index.js +1 -1
  543. package/min/persisters/persister-sqlite3/index.js.gz +0 -0
  544. package/min/persisters/persister-sqlite3/with-schemas/index.js +1 -1
  545. package/min/persisters/persister-sqlite3/with-schemas/index.js.gz +0 -0
  546. package/min/persisters/persister-yjs/index.js +1 -1
  547. package/min/persisters/persister-yjs/index.js.gz +0 -0
  548. package/min/persisters/persister-yjs/with-schemas/index.js +1 -1
  549. package/min/persisters/persister-yjs/with-schemas/index.js.gz +0 -0
  550. package/min/persisters/with-schemas/index.js +1 -1
  551. package/min/persisters/with-schemas/index.js.gz +0 -0
  552. package/min/synchronizers/index.js +1 -1
  553. package/min/synchronizers/index.js.gz +0 -0
  554. package/min/synchronizers/synchronizer-broadcast-channel/index.js +1 -1
  555. package/min/synchronizers/synchronizer-broadcast-channel/index.js.gz +0 -0
  556. package/min/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js +1 -1
  557. package/min/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js.gz +0 -0
  558. package/min/synchronizers/synchronizer-local/index.js +1 -1
  559. package/min/synchronizers/synchronizer-local/index.js.gz +0 -0
  560. package/min/synchronizers/synchronizer-local/with-schemas/index.js +1 -1
  561. package/min/synchronizers/synchronizer-local/with-schemas/index.js.gz +0 -0
  562. package/min/synchronizers/synchronizer-ws-client/index.js +1 -1
  563. package/min/synchronizers/synchronizer-ws-client/index.js.gz +0 -0
  564. package/min/synchronizers/synchronizer-ws-client/with-schemas/index.js +1 -1
  565. package/min/synchronizers/synchronizer-ws-client/with-schemas/index.js.gz +0 -0
  566. package/min/synchronizers/synchronizer-ws-server/index.js +1 -1
  567. package/min/synchronizers/synchronizer-ws-server/index.js.gz +0 -0
  568. package/min/synchronizers/synchronizer-ws-server/with-schemas/index.js +1 -1
  569. package/min/synchronizers/synchronizer-ws-server/with-schemas/index.js.gz +0 -0
  570. package/min/synchronizers/with-schemas/index.js +1 -1
  571. package/min/synchronizers/with-schemas/index.js.gz +0 -0
  572. package/min/ui-react-inspector/index.js +1 -1
  573. package/min/ui-react-inspector/index.js.gz +0 -0
  574. package/min/ui-react-inspector/with-schemas/index.js +1 -1
  575. package/min/ui-react-inspector/with-schemas/index.js.gz +0 -0
  576. package/min/with-schemas/index.js +1 -1
  577. package/min/with-schemas/index.js.gz +0 -0
  578. package/package.json +5 -5
  579. package/persisters/index.js +82 -98
  580. package/persisters/persister-automerge/index.js +2 -0
  581. package/persisters/persister-automerge/with-schemas/index.js +2 -0
  582. package/persisters/persister-browser/index.js +2 -0
  583. package/persisters/persister-browser/with-schemas/index.js +2 -0
  584. package/persisters/persister-cr-sqlite-wasm/index.js +81 -97
  585. package/persisters/persister-cr-sqlite-wasm/with-schemas/index.js +81 -97
  586. package/persisters/persister-electric-sql/index.js +81 -97
  587. package/persisters/persister-electric-sql/with-schemas/index.js +81 -97
  588. package/persisters/persister-expo-sqlite/index.js +81 -97
  589. package/persisters/persister-expo-sqlite/with-schemas/index.js +81 -97
  590. package/persisters/persister-file/index.js +2 -0
  591. package/persisters/persister-file/with-schemas/index.js +2 -0
  592. package/persisters/persister-indexed-db/index.js +2 -0
  593. package/persisters/persister-indexed-db/with-schemas/index.js +2 -0
  594. package/persisters/persister-libsql/index.js +81 -97
  595. package/persisters/persister-libsql/with-schemas/index.js +81 -97
  596. package/persisters/persister-partykit-client/index.js +2 -0
  597. package/persisters/persister-partykit-client/with-schemas/index.js +2 -0
  598. package/persisters/persister-pglite/index.js +80 -96
  599. package/persisters/persister-pglite/with-schemas/index.js +80 -96
  600. package/persisters/persister-postgres/index.js +80 -96
  601. package/persisters/persister-postgres/with-schemas/index.js +80 -96
  602. package/persisters/persister-powersync/index.js +205 -142
  603. package/persisters/persister-powersync/with-schemas/index.js +205 -142
  604. package/persisters/persister-remote/index.js +2 -0
  605. package/persisters/persister-remote/with-schemas/index.js +2 -0
  606. package/persisters/persister-sqlite-wasm/index.js +81 -97
  607. package/persisters/persister-sqlite-wasm/with-schemas/index.js +81 -97
  608. package/persisters/persister-sqlite3/index.js +81 -97
  609. package/persisters/persister-sqlite3/with-schemas/index.js +81 -97
  610. package/persisters/persister-yjs/index.js +2 -0
  611. package/persisters/persister-yjs/with-schemas/index.js +2 -0
  612. package/persisters/with-schemas/index.js +82 -98
  613. package/readme.md +2 -2
  614. package/synchronizers/index.js +3 -1
  615. package/synchronizers/synchronizer-broadcast-channel/index.js +3 -1
  616. package/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js +3 -1
  617. package/synchronizers/synchronizer-local/index.js +3 -1
  618. package/synchronizers/synchronizer-local/with-schemas/index.js +3 -1
  619. package/synchronizers/synchronizer-ws-client/index.js +3 -1
  620. package/synchronizers/synchronizer-ws-client/with-schemas/index.js +3 -1
  621. package/synchronizers/synchronizer-ws-server/index.js +3 -1
  622. package/synchronizers/synchronizer-ws-server/with-schemas/index.js +3 -1
  623. package/synchronizers/with-schemas/index.js +3 -1
  624. package/ui-react-inspector/index.js +2 -2
  625. package/ui-react-inspector/with-schemas/index.js +2 -2
  626. package/umd/common/index.js +1 -1
  627. package/umd/common/with-schemas/index.js +1 -1
  628. package/umd/es6/common/index.js +1 -1
  629. package/umd/es6/common/with-schemas/index.js +1 -1
  630. package/umd/es6/index.js +1 -1
  631. package/umd/es6/mergeable-store/index.js +1 -1
  632. package/umd/es6/mergeable-store/with-schemas/index.js +1 -1
  633. package/umd/es6/min/common/index.js +1 -1
  634. package/umd/es6/min/common/index.js.gz +0 -0
  635. package/umd/es6/min/common/with-schemas/index.js +1 -1
  636. package/umd/es6/min/common/with-schemas/index.js.gz +0 -0
  637. package/umd/es6/min/index.js +1 -1
  638. package/umd/es6/min/index.js.gz +0 -0
  639. package/umd/es6/min/mergeable-store/index.js +1 -1
  640. package/umd/es6/min/mergeable-store/index.js.gz +0 -0
  641. package/umd/es6/min/mergeable-store/with-schemas/index.js +1 -1
  642. package/umd/es6/min/mergeable-store/with-schemas/index.js.gz +0 -0
  643. package/umd/es6/min/persisters/index.js +1 -1
  644. package/umd/es6/min/persisters/index.js.gz +0 -0
  645. package/umd/es6/min/persisters/persister-automerge/index.js +1 -1
  646. package/umd/es6/min/persisters/persister-automerge/index.js.gz +0 -0
  647. package/umd/es6/min/persisters/persister-automerge/with-schemas/index.js +1 -1
  648. package/umd/es6/min/persisters/persister-automerge/with-schemas/index.js.gz +0 -0
  649. package/umd/es6/min/persisters/persister-browser/index.js +1 -1
  650. package/umd/es6/min/persisters/persister-browser/index.js.gz +0 -0
  651. package/umd/es6/min/persisters/persister-browser/with-schemas/index.js +1 -1
  652. package/umd/es6/min/persisters/persister-browser/with-schemas/index.js.gz +0 -0
  653. package/umd/es6/min/persisters/persister-cr-sqlite-wasm/index.js +1 -1
  654. package/umd/es6/min/persisters/persister-cr-sqlite-wasm/index.js.gz +0 -0
  655. package/umd/es6/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.js +1 -1
  656. package/umd/es6/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.js.gz +0 -0
  657. package/umd/es6/min/persisters/persister-electric-sql/index.js +1 -1
  658. package/umd/es6/min/persisters/persister-electric-sql/index.js.gz +0 -0
  659. package/umd/es6/min/persisters/persister-electric-sql/with-schemas/index.js +1 -1
  660. package/umd/es6/min/persisters/persister-electric-sql/with-schemas/index.js.gz +0 -0
  661. package/umd/es6/min/persisters/persister-expo-sqlite/index.js +1 -1
  662. package/umd/es6/min/persisters/persister-expo-sqlite/index.js.gz +0 -0
  663. package/umd/es6/min/persisters/persister-expo-sqlite/with-schemas/index.js +1 -1
  664. package/umd/es6/min/persisters/persister-expo-sqlite/with-schemas/index.js.gz +0 -0
  665. package/umd/es6/min/persisters/persister-file/index.js +1 -1
  666. package/umd/es6/min/persisters/persister-file/index.js.gz +0 -0
  667. package/umd/es6/min/persisters/persister-file/with-schemas/index.js +1 -1
  668. package/umd/es6/min/persisters/persister-file/with-schemas/index.js.gz +0 -0
  669. package/umd/es6/min/persisters/persister-indexed-db/index.js +1 -1
  670. package/umd/es6/min/persisters/persister-indexed-db/index.js.gz +0 -0
  671. package/umd/es6/min/persisters/persister-indexed-db/with-schemas/index.js +1 -1
  672. package/umd/es6/min/persisters/persister-indexed-db/with-schemas/index.js.gz +0 -0
  673. package/umd/es6/min/persisters/persister-libsql/index.js +1 -1
  674. package/umd/es6/min/persisters/persister-libsql/index.js.gz +0 -0
  675. package/umd/es6/min/persisters/persister-libsql/with-schemas/index.js +1 -1
  676. package/umd/es6/min/persisters/persister-libsql/with-schemas/index.js.gz +0 -0
  677. package/umd/es6/min/persisters/persister-partykit-client/index.js +1 -1
  678. package/umd/es6/min/persisters/persister-partykit-client/index.js.gz +0 -0
  679. package/umd/es6/min/persisters/persister-partykit-client/with-schemas/index.js +1 -1
  680. package/umd/es6/min/persisters/persister-partykit-client/with-schemas/index.js.gz +0 -0
  681. package/umd/es6/min/persisters/persister-pglite/index.js +1 -1
  682. package/umd/es6/min/persisters/persister-pglite/index.js.gz +0 -0
  683. package/umd/es6/min/persisters/persister-pglite/with-schemas/index.js +1 -1
  684. package/umd/es6/min/persisters/persister-pglite/with-schemas/index.js.gz +0 -0
  685. package/umd/es6/min/persisters/persister-postgres/index.js +1 -1
  686. package/umd/es6/min/persisters/persister-postgres/index.js.gz +0 -0
  687. package/umd/es6/min/persisters/persister-postgres/with-schemas/index.js +1 -1
  688. package/umd/es6/min/persisters/persister-postgres/with-schemas/index.js.gz +0 -0
  689. package/umd/es6/min/persisters/persister-powersync/index.js +1 -1
  690. package/umd/es6/min/persisters/persister-powersync/index.js.gz +0 -0
  691. package/umd/es6/min/persisters/persister-powersync/with-schemas/index.js +1 -1
  692. package/umd/es6/min/persisters/persister-powersync/with-schemas/index.js.gz +0 -0
  693. package/umd/es6/min/persisters/persister-remote/index.js +1 -1
  694. package/umd/es6/min/persisters/persister-remote/index.js.gz +0 -0
  695. package/umd/es6/min/persisters/persister-remote/with-schemas/index.js +1 -1
  696. package/umd/es6/min/persisters/persister-remote/with-schemas/index.js.gz +0 -0
  697. package/umd/es6/min/persisters/persister-sqlite-wasm/index.js +1 -1
  698. package/umd/es6/min/persisters/persister-sqlite-wasm/index.js.gz +0 -0
  699. package/umd/es6/min/persisters/persister-sqlite-wasm/with-schemas/index.js +1 -1
  700. package/umd/es6/min/persisters/persister-sqlite-wasm/with-schemas/index.js.gz +0 -0
  701. package/umd/es6/min/persisters/persister-sqlite3/index.js +1 -1
  702. package/umd/es6/min/persisters/persister-sqlite3/index.js.gz +0 -0
  703. package/umd/es6/min/persisters/persister-sqlite3/with-schemas/index.js +1 -1
  704. package/umd/es6/min/persisters/persister-sqlite3/with-schemas/index.js.gz +0 -0
  705. package/umd/es6/min/persisters/persister-yjs/index.js +1 -1
  706. package/umd/es6/min/persisters/persister-yjs/index.js.gz +0 -0
  707. package/umd/es6/min/persisters/persister-yjs/with-schemas/index.js +1 -1
  708. package/umd/es6/min/persisters/persister-yjs/with-schemas/index.js.gz +0 -0
  709. package/umd/es6/min/persisters/with-schemas/index.js +1 -1
  710. package/umd/es6/min/persisters/with-schemas/index.js.gz +0 -0
  711. package/umd/es6/min/synchronizers/index.js +1 -1
  712. package/umd/es6/min/synchronizers/index.js.gz +0 -0
  713. package/umd/es6/min/synchronizers/synchronizer-broadcast-channel/index.js +1 -1
  714. package/umd/es6/min/synchronizers/synchronizer-broadcast-channel/index.js.gz +0 -0
  715. package/umd/es6/min/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js +1 -1
  716. package/umd/es6/min/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js.gz +0 -0
  717. package/umd/es6/min/synchronizers/synchronizer-local/index.js +1 -1
  718. package/umd/es6/min/synchronizers/synchronizer-local/index.js.gz +0 -0
  719. package/umd/es6/min/synchronizers/synchronizer-local/with-schemas/index.js +1 -1
  720. package/umd/es6/min/synchronizers/synchronizer-local/with-schemas/index.js.gz +0 -0
  721. package/umd/es6/min/synchronizers/synchronizer-ws-client/index.js +1 -1
  722. package/umd/es6/min/synchronizers/synchronizer-ws-client/index.js.gz +0 -0
  723. package/umd/es6/min/synchronizers/synchronizer-ws-client/with-schemas/index.js +1 -1
  724. package/umd/es6/min/synchronizers/synchronizer-ws-client/with-schemas/index.js.gz +0 -0
  725. package/umd/es6/min/synchronizers/synchronizer-ws-server/index.js +1 -1
  726. package/umd/es6/min/synchronizers/synchronizer-ws-server/index.js.gz +0 -0
  727. package/umd/es6/min/synchronizers/synchronizer-ws-server/with-schemas/index.js +1 -1
  728. package/umd/es6/min/synchronizers/synchronizer-ws-server/with-schemas/index.js.gz +0 -0
  729. package/umd/es6/min/synchronizers/with-schemas/index.js +1 -1
  730. package/umd/es6/min/synchronizers/with-schemas/index.js.gz +0 -0
  731. package/umd/es6/min/ui-react-inspector/index.js +1 -1
  732. package/umd/es6/min/ui-react-inspector/index.js.gz +0 -0
  733. package/umd/es6/min/ui-react-inspector/with-schemas/index.js +1 -1
  734. package/umd/es6/min/ui-react-inspector/with-schemas/index.js.gz +0 -0
  735. package/umd/es6/min/with-schemas/index.js +1 -1
  736. package/umd/es6/min/with-schemas/index.js.gz +0 -0
  737. package/umd/es6/persisters/index.js +85 -103
  738. package/umd/es6/persisters/persister-automerge/index.js +2 -0
  739. package/umd/es6/persisters/persister-automerge/with-schemas/index.js +2 -0
  740. package/umd/es6/persisters/persister-browser/index.js +2 -0
  741. package/umd/es6/persisters/persister-browser/with-schemas/index.js +2 -0
  742. package/umd/es6/persisters/persister-cr-sqlite-wasm/index.js +84 -102
  743. package/umd/es6/persisters/persister-cr-sqlite-wasm/with-schemas/index.js +84 -102
  744. package/umd/es6/persisters/persister-electric-sql/index.js +84 -102
  745. package/umd/es6/persisters/persister-electric-sql/with-schemas/index.js +84 -102
  746. package/umd/es6/persisters/persister-expo-sqlite/index.js +84 -102
  747. package/umd/es6/persisters/persister-expo-sqlite/with-schemas/index.js +84 -102
  748. package/umd/es6/persisters/persister-file/index.js +2 -0
  749. package/umd/es6/persisters/persister-file/with-schemas/index.js +2 -0
  750. package/umd/es6/persisters/persister-indexed-db/index.js +2 -0
  751. package/umd/es6/persisters/persister-indexed-db/with-schemas/index.js +2 -0
  752. package/umd/es6/persisters/persister-libsql/index.js +84 -102
  753. package/umd/es6/persisters/persister-libsql/with-schemas/index.js +84 -102
  754. package/umd/es6/persisters/persister-partykit-client/index.js +2 -0
  755. package/umd/es6/persisters/persister-partykit-client/with-schemas/index.js +2 -0
  756. package/umd/es6/persisters/persister-pglite/index.js +83 -101
  757. package/umd/es6/persisters/persister-pglite/with-schemas/index.js +83 -101
  758. package/umd/es6/persisters/persister-postgres/index.js +83 -101
  759. package/umd/es6/persisters/persister-postgres/with-schemas/index.js +83 -101
  760. package/umd/es6/persisters/persister-powersync/index.js +214 -147
  761. package/umd/es6/persisters/persister-powersync/with-schemas/index.js +214 -147
  762. package/umd/es6/persisters/persister-remote/index.js +2 -0
  763. package/umd/es6/persisters/persister-remote/with-schemas/index.js +2 -0
  764. package/umd/es6/persisters/persister-sqlite-wasm/index.js +84 -102
  765. package/umd/es6/persisters/persister-sqlite-wasm/with-schemas/index.js +84 -102
  766. package/umd/es6/persisters/persister-sqlite3/index.js +84 -102
  767. package/umd/es6/persisters/persister-sqlite3/with-schemas/index.js +84 -102
  768. package/umd/es6/persisters/persister-yjs/index.js +2 -0
  769. package/umd/es6/persisters/persister-yjs/with-schemas/index.js +2 -0
  770. package/umd/es6/persisters/with-schemas/index.js +85 -103
  771. package/umd/es6/synchronizers/index.js +3 -1
  772. package/umd/es6/synchronizers/synchronizer-broadcast-channel/index.js +3 -1
  773. package/umd/es6/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js +3 -1
  774. package/umd/es6/synchronizers/synchronizer-local/index.js +3 -1
  775. package/umd/es6/synchronizers/synchronizer-local/with-schemas/index.js +3 -1
  776. package/umd/es6/synchronizers/synchronizer-ws-client/index.js +3 -1
  777. package/umd/es6/synchronizers/synchronizer-ws-client/with-schemas/index.js +3 -1
  778. package/umd/es6/synchronizers/synchronizer-ws-server/index.js +3 -1
  779. package/umd/es6/synchronizers/synchronizer-ws-server/with-schemas/index.js +3 -1
  780. package/umd/es6/synchronizers/with-schemas/index.js +3 -1
  781. package/umd/es6/ui-react-inspector/index.js +2 -2
  782. package/umd/es6/ui-react-inspector/with-schemas/index.js +2 -2
  783. package/umd/es6/with-schemas/index.js +1 -1
  784. package/umd/index.js +1 -1
  785. package/umd/mergeable-store/index.js +1 -1
  786. package/umd/mergeable-store/with-schemas/index.js +1 -1
  787. package/umd/min/common/index.js +1 -1
  788. package/umd/min/common/index.js.gz +0 -0
  789. package/umd/min/common/with-schemas/index.js +1 -1
  790. package/umd/min/common/with-schemas/index.js.gz +0 -0
  791. package/umd/min/index.js +1 -1
  792. package/umd/min/index.js.gz +0 -0
  793. package/umd/min/mergeable-store/index.js +1 -1
  794. package/umd/min/mergeable-store/index.js.gz +0 -0
  795. package/umd/min/mergeable-store/with-schemas/index.js +1 -1
  796. package/umd/min/mergeable-store/with-schemas/index.js.gz +0 -0
  797. package/umd/min/persisters/index.js +1 -1
  798. package/umd/min/persisters/index.js.gz +0 -0
  799. package/umd/min/persisters/persister-automerge/index.js +1 -1
  800. package/umd/min/persisters/persister-automerge/index.js.gz +0 -0
  801. package/umd/min/persisters/persister-automerge/with-schemas/index.js +1 -1
  802. package/umd/min/persisters/persister-automerge/with-schemas/index.js.gz +0 -0
  803. package/umd/min/persisters/persister-browser/index.js +1 -1
  804. package/umd/min/persisters/persister-browser/index.js.gz +0 -0
  805. package/umd/min/persisters/persister-browser/with-schemas/index.js +1 -1
  806. package/umd/min/persisters/persister-browser/with-schemas/index.js.gz +0 -0
  807. package/umd/min/persisters/persister-cr-sqlite-wasm/index.js +1 -1
  808. package/umd/min/persisters/persister-cr-sqlite-wasm/index.js.gz +0 -0
  809. package/umd/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.js +1 -1
  810. package/umd/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.js.gz +0 -0
  811. package/umd/min/persisters/persister-electric-sql/index.js +1 -1
  812. package/umd/min/persisters/persister-electric-sql/index.js.gz +0 -0
  813. package/umd/min/persisters/persister-electric-sql/with-schemas/index.js +1 -1
  814. package/umd/min/persisters/persister-electric-sql/with-schemas/index.js.gz +0 -0
  815. package/umd/min/persisters/persister-expo-sqlite/index.js +1 -1
  816. package/umd/min/persisters/persister-expo-sqlite/index.js.gz +0 -0
  817. package/umd/min/persisters/persister-expo-sqlite/with-schemas/index.js +1 -1
  818. package/umd/min/persisters/persister-expo-sqlite/with-schemas/index.js.gz +0 -0
  819. package/umd/min/persisters/persister-file/index.js +1 -1
  820. package/umd/min/persisters/persister-file/index.js.gz +0 -0
  821. package/umd/min/persisters/persister-file/with-schemas/index.js +1 -1
  822. package/umd/min/persisters/persister-file/with-schemas/index.js.gz +0 -0
  823. package/umd/min/persisters/persister-indexed-db/index.js +1 -1
  824. package/umd/min/persisters/persister-indexed-db/index.js.gz +0 -0
  825. package/umd/min/persisters/persister-indexed-db/with-schemas/index.js +1 -1
  826. package/umd/min/persisters/persister-indexed-db/with-schemas/index.js.gz +0 -0
  827. package/umd/min/persisters/persister-libsql/index.js +1 -1
  828. package/umd/min/persisters/persister-libsql/index.js.gz +0 -0
  829. package/umd/min/persisters/persister-libsql/with-schemas/index.js +1 -1
  830. package/umd/min/persisters/persister-libsql/with-schemas/index.js.gz +0 -0
  831. package/umd/min/persisters/persister-partykit-client/index.js +1 -1
  832. package/umd/min/persisters/persister-partykit-client/index.js.gz +0 -0
  833. package/umd/min/persisters/persister-partykit-client/with-schemas/index.js +1 -1
  834. package/umd/min/persisters/persister-partykit-client/with-schemas/index.js.gz +0 -0
  835. package/umd/min/persisters/persister-pglite/index.js +1 -1
  836. package/umd/min/persisters/persister-pglite/index.js.gz +0 -0
  837. package/umd/min/persisters/persister-pglite/with-schemas/index.js +1 -1
  838. package/umd/min/persisters/persister-pglite/with-schemas/index.js.gz +0 -0
  839. package/umd/min/persisters/persister-postgres/index.js +1 -1
  840. package/umd/min/persisters/persister-postgres/index.js.gz +0 -0
  841. package/umd/min/persisters/persister-postgres/with-schemas/index.js +1 -1
  842. package/umd/min/persisters/persister-postgres/with-schemas/index.js.gz +0 -0
  843. package/umd/min/persisters/persister-powersync/index.js +1 -1
  844. package/umd/min/persisters/persister-powersync/index.js.gz +0 -0
  845. package/umd/min/persisters/persister-powersync/with-schemas/index.js +1 -1
  846. package/umd/min/persisters/persister-powersync/with-schemas/index.js.gz +0 -0
  847. package/umd/min/persisters/persister-remote/index.js +1 -1
  848. package/umd/min/persisters/persister-remote/index.js.gz +0 -0
  849. package/umd/min/persisters/persister-remote/with-schemas/index.js +1 -1
  850. package/umd/min/persisters/persister-remote/with-schemas/index.js.gz +0 -0
  851. package/umd/min/persisters/persister-sqlite-wasm/index.js +1 -1
  852. package/umd/min/persisters/persister-sqlite-wasm/index.js.gz +0 -0
  853. package/umd/min/persisters/persister-sqlite-wasm/with-schemas/index.js +1 -1
  854. package/umd/min/persisters/persister-sqlite-wasm/with-schemas/index.js.gz +0 -0
  855. package/umd/min/persisters/persister-sqlite3/index.js +1 -1
  856. package/umd/min/persisters/persister-sqlite3/index.js.gz +0 -0
  857. package/umd/min/persisters/persister-sqlite3/with-schemas/index.js +1 -1
  858. package/umd/min/persisters/persister-sqlite3/with-schemas/index.js.gz +0 -0
  859. package/umd/min/persisters/persister-yjs/index.js +1 -1
  860. package/umd/min/persisters/persister-yjs/index.js.gz +0 -0
  861. package/umd/min/persisters/persister-yjs/with-schemas/index.js +1 -1
  862. package/umd/min/persisters/persister-yjs/with-schemas/index.js.gz +0 -0
  863. package/umd/min/persisters/with-schemas/index.js +1 -1
  864. package/umd/min/persisters/with-schemas/index.js.gz +0 -0
  865. package/umd/min/synchronizers/index.js +1 -1
  866. package/umd/min/synchronizers/index.js.gz +0 -0
  867. package/umd/min/synchronizers/synchronizer-broadcast-channel/index.js +1 -1
  868. package/umd/min/synchronizers/synchronizer-broadcast-channel/index.js.gz +0 -0
  869. package/umd/min/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js +1 -1
  870. package/umd/min/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js.gz +0 -0
  871. package/umd/min/synchronizers/synchronizer-local/index.js +1 -1
  872. package/umd/min/synchronizers/synchronizer-local/index.js.gz +0 -0
  873. package/umd/min/synchronizers/synchronizer-local/with-schemas/index.js +1 -1
  874. package/umd/min/synchronizers/synchronizer-local/with-schemas/index.js.gz +0 -0
  875. package/umd/min/synchronizers/synchronizer-ws-client/index.js +1 -1
  876. package/umd/min/synchronizers/synchronizer-ws-client/index.js.gz +0 -0
  877. package/umd/min/synchronizers/synchronizer-ws-client/with-schemas/index.js +1 -1
  878. package/umd/min/synchronizers/synchronizer-ws-client/with-schemas/index.js.gz +0 -0
  879. package/umd/min/synchronizers/synchronizer-ws-server/index.js +1 -1
  880. package/umd/min/synchronizers/synchronizer-ws-server/index.js.gz +0 -0
  881. package/umd/min/synchronizers/synchronizer-ws-server/with-schemas/index.js +1 -1
  882. package/umd/min/synchronizers/synchronizer-ws-server/with-schemas/index.js.gz +0 -0
  883. package/umd/min/synchronizers/with-schemas/index.js +1 -1
  884. package/umd/min/synchronizers/with-schemas/index.js.gz +0 -0
  885. package/umd/min/ui-react-inspector/index.js +1 -1
  886. package/umd/min/ui-react-inspector/index.js.gz +0 -0
  887. package/umd/min/ui-react-inspector/with-schemas/index.js +1 -1
  888. package/umd/min/ui-react-inspector/with-schemas/index.js.gz +0 -0
  889. package/umd/min/with-schemas/index.js +1 -1
  890. package/umd/min/with-schemas/index.js.gz +0 -0
  891. package/umd/persisters/index.js +82 -98
  892. package/umd/persisters/persister-automerge/index.js +2 -0
  893. package/umd/persisters/persister-automerge/with-schemas/index.js +2 -0
  894. package/umd/persisters/persister-browser/index.js +2 -0
  895. package/umd/persisters/persister-browser/with-schemas/index.js +2 -0
  896. package/umd/persisters/persister-cr-sqlite-wasm/index.js +81 -97
  897. package/umd/persisters/persister-cr-sqlite-wasm/with-schemas/index.js +81 -97
  898. package/umd/persisters/persister-electric-sql/index.js +81 -97
  899. package/umd/persisters/persister-electric-sql/with-schemas/index.js +81 -97
  900. package/umd/persisters/persister-expo-sqlite/index.js +81 -97
  901. package/umd/persisters/persister-expo-sqlite/with-schemas/index.js +81 -97
  902. package/umd/persisters/persister-file/index.js +2 -0
  903. package/umd/persisters/persister-file/with-schemas/index.js +2 -0
  904. package/umd/persisters/persister-indexed-db/index.js +2 -0
  905. package/umd/persisters/persister-indexed-db/with-schemas/index.js +2 -0
  906. package/umd/persisters/persister-libsql/index.js +81 -97
  907. package/umd/persisters/persister-libsql/with-schemas/index.js +81 -97
  908. package/umd/persisters/persister-partykit-client/index.js +2 -0
  909. package/umd/persisters/persister-partykit-client/with-schemas/index.js +2 -0
  910. package/umd/persisters/persister-pglite/index.js +80 -96
  911. package/umd/persisters/persister-pglite/with-schemas/index.js +80 -96
  912. package/umd/persisters/persister-postgres/index.js +80 -96
  913. package/umd/persisters/persister-postgres/with-schemas/index.js +80 -96
  914. package/umd/persisters/persister-powersync/index.js +205 -142
  915. package/umd/persisters/persister-powersync/with-schemas/index.js +205 -142
  916. package/umd/persisters/persister-remote/index.js +2 -0
  917. package/umd/persisters/persister-remote/with-schemas/index.js +2 -0
  918. package/umd/persisters/persister-sqlite-wasm/index.js +81 -97
  919. package/umd/persisters/persister-sqlite-wasm/with-schemas/index.js +81 -97
  920. package/umd/persisters/persister-sqlite3/index.js +81 -97
  921. package/umd/persisters/persister-sqlite3/with-schemas/index.js +81 -97
  922. package/umd/persisters/persister-yjs/index.js +2 -0
  923. package/umd/persisters/persister-yjs/with-schemas/index.js +2 -0
  924. package/umd/persisters/with-schemas/index.js +82 -98
  925. package/umd/synchronizers/index.js +3 -1
  926. package/umd/synchronizers/synchronizer-broadcast-channel/index.js +3 -1
  927. package/umd/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js +3 -1
  928. package/umd/synchronizers/synchronizer-local/index.js +3 -1
  929. package/umd/synchronizers/synchronizer-local/with-schemas/index.js +3 -1
  930. package/umd/synchronizers/synchronizer-ws-client/index.js +3 -1
  931. package/umd/synchronizers/synchronizer-ws-client/with-schemas/index.js +3 -1
  932. package/umd/synchronizers/synchronizer-ws-server/index.js +3 -1
  933. package/umd/synchronizers/synchronizer-ws-server/with-schemas/index.js +3 -1
  934. package/umd/synchronizers/with-schemas/index.js +3 -1
  935. package/umd/ui-react-inspector/index.js +2 -2
  936. package/umd/ui-react-inspector/with-schemas/index.js +2 -2
  937. package/umd/with-schemas/index.js +1 -1
  938. package/with-schemas/index.js +1 -1
@@ -1 +1 @@
1
- var t,a;t=this,a=function(t){"use strict";const a=t=>typeof t,e="tinybase",n="",s=",",i=a(n),r=Promise,o=clearInterval,c=t=>null==t,l=(t,a,e)=>c(t)?e?.():a(t),u=t=>a(t)==i,y=t=>Array.isArray(t),w=(t,a,e)=>t.slice(a,e),d=t=>t.length,p=async t=>r.all(t),v=t=>{throw Error(t)},f=(t,a)=>A(Array(t).fill(0),((t,e)=>a(e))),E=(t,a)=>t.forEach(a),g=(t,a="")=>t.join(a),A=(t,a)=>t.map(a),h=t=>0==d(t),m=(t,a)=>t.filter(a),N=(t,...a)=>t.push(...a),T=t=>t.shift(),$="_",b="_id",C="SELECT",S="WHERE",L="TABLE",O="ALTER "+L,I="DELETE FROM",R=C+"*FROM",D="pragma_",M="data_version",P="schema_version",_="pragma_table_",F=t=>`"${t.replace(/"/g,'""')}"`,x=t=>g(A(t,((t,a)=>"$"+(a+1))),s),j=(t,a)=>t?.has(a)??!1,B=t=>c(t)||0==(t=>t?.size??0)(t),U=t=>[...t?.values()??[]],q=(t,a)=>t?.forEach(a),J=(t,a)=>t?.delete(a),Y=Object,k=t=>Y.getPrototypeOf(t),z=Y.entries,G=Y.keys,H=Y.freeze,K=(t=[])=>Y.fromEntries(t),Q=(...t)=>Y.assign({},...t),V=(t,a)=>(delete t[a],t),W=(t,a)=>A(z(t),(([t,e])=>a(e,t))),X=t=>Y.values(t),Z=t=>d(G(t)),tt=t=>(t=>!c(t)&&l(k(t),(t=>t==Y.prototype||c(k(t))),(()=>!0)))(t)&&0==Z(t),at=JSON.stringify,et=JSON.parse,nt=t=>new Map(t),st=(t,a)=>t?.get(a),it=(t,a)=>A([...t?.entries()??[]],(([t,e])=>a(e,t))),rt=(t,a,e)=>c(e)?(J(t,a),t):t?.set(a,e),ot=(t,a,e,n)=>(j(t,a)?n?.(st(t,a)):rt(t,a,e()),st(t,a)),ct=(t,a,e,n,s=0)=>l((e?ot:st)(t,a[s],s>d(a)-2?e:nt),(i=>{if(s>d(a)-2)return n?.(i)&&rt(t,a[s]),i;const r=ct(i,a,e,n,s+1);return B(i)&&rt(t,a[s]),r})),lt=t=>new Set(y(t)||c(t)?t:[t]),ut=(t,a)=>t?.add(a),yt=/^\d+$/,wt=nt(),dt=nt(),pt=(t,a,e,s,i,r,o,u={},w=[])=>{let p,f,g,A=0,h=0,m=0;ot(wt,w,(()=>0)),ot(dt,w,(()=>[]));const $=nt(),[b,C,S,L,O]=((t=1,a)=>1!=t&&a.isMergeable()?[1,a.getMergeableContent,a.getTransactionMergeableChanges,([[t],[a]])=>!tt(t)||!tt(a),a.setDefaultContent]:2!=t?[0,a.getContent,a.getTransactionChanges,([t,a])=>!tt(t)||!tt(a),a.setContent]:v("Store type not supported by this Persister"))(o,t),[I,R,D]=(()=>{let t;const[a,e]=(()=>{const t=[];let a=0;return[e=>(e?T(t):null)??n+a++,a=>{yt.test(a)&&d(t)<1e3&&N(t,a)}]})(),s=nt();return[(e,i,r,o=[],c=()=>[])=>{t??=Y;const l=a(1);return rt(s,l,[e,i,r,o,c]),ut(ct(i,r??[n],lt),l),l},(a,e,...i)=>E(((t,a=[n])=>{const e=[],s=(t,n)=>n==d(a)?N(e,t):null===a[n]?q(t,(t=>s(t,n+1))):E([a[n],null],(a=>s(st(t,a),n+1)));return s(t,0),e})(a,e),(a=>q(a,(a=>st(s,a)[0](t,...e??[],...i))))),t=>l(st(s,t),(([,a,i])=>(ct(a,i??[n],void 0,(a=>(J(a,t),B(a)?1:0))),rt(s,t),e(t),i))),a=>l(st(s,a),(([a,,e=[],n,s])=>{const i=(...r)=>{const o=d(r);o==d(e)?a(t,...r,...s(r)):c(e[o])?E(n[o]?.(...r)??[],(t=>i(...r,t))):i(...r,e[o])};i()}))]})(),M=t=>{t!=A&&(A=t,R($,void 0,A))},P=a=>{(b&&y(a?.[0])?1===a?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===a?.[2]?t.applyChanges:t.setContent)(a)},_=async t=>(2!=A&&(M(1),h++,await U((async()=>{try{const t=await a();y(t)?P(t):v("Content is not an array "+t)}catch(a){r?.(a),t&&O(t)}M(0)}))),Y),F=()=>(f&&(i(f),f=void 0),Y),x=async t=>(1!=A&&(M(2),m++,await U((async()=>{try{await e(C,t)}catch(t){r?.(t)}M(0)}))),Y),j=()=>(l(g,t.delListener),g=void 0,Y),U=async(...t)=>(N(st(dt,w),...t),await(async()=>{if(!st(wt,w)){for(rt(wt,w,1);!c(p=T(st(dt,w)));)try{await p()}catch(t){r?.(t)}rt(wt,w,0)}})(),Y),Y={load:_,startAutoLoad:async t=>{await F().load(t);try{f=await s((async(t,a)=>{a||t?2!=A&&(M(1),h++,P(a??t),M(0)):await _()}))}catch(t){r?.(t)}return Y},stopAutoLoad:F,isAutoLoading:()=>!c(f),save:x,startAutoSave:async()=>(await j().save(),g=t.addDidFinishTransactionListener((()=>{const t=S();L(t)&&x(t)})),Y),stopAutoSave:j,isAutoSaving:()=>!c(g),getStatus:()=>A,addStatusListener:t=>I(t,$),delListener:a=>(D(a),t),schedule:U,getStore:()=>t,destroy:()=>(st(dt,w).splice(0,void 0),F().stopAutoSave()),getStats:()=>({loads:h,saves:m}),...u};return H(Y)},vt=(t,a,e,n,i,r,o,l)=>{const u=nt();return[async()=>{u.clear(),A(await e(t,a),(({tn:t,cn:a})=>ut(ot(u,t,lt),a)))},async(a,e)=>((t,a)=>j(st(u,t),a))(a,e)?K(m(A(await t(R+F(a)),(t=>{return[t[e],l?(a=V(t,e),n=l,K(W(a,((t,a)=>[a,n(t,a)])))):V(t,e)];var a,n})),(([t,a])=>!c(t)&&!tt(a)))):{},async(a,e,n,l,y,w=!1)=>{const d=lt();W(n??{},(t=>A(G(t??{}),(t=>ut(d,t)))));const v=U(d);if(!w&&y&&h(v)&&j(u,a))return await t("DROP "+L+F(a)),void rt(u,a);const f=st(u,a),E=lt(U(f));if(h(v)||(j(u,a)?await p(A([e,...v],(async(n,s)=>{J(E,n)||(await t(O+F(a)+"ADD"+F(n)+i),0==s&&await t("CREATE UNIQUE INDEX pk ON "+F(a)+`(${F(e)})`),ut(f,n))}))):(await t("CREATE "+L+F(a)+`(${F(e)}${i} PRIMARY KEY${g(A(v,(t=>s+F(t)+i)))});`),rt(u,a,lt([e,...v])))),await p([...!w&&l?A(U(E),(async n=>{n!=e&&(await t(O+F(a)+"DROP"+F(n)),J(f,n))})):[]]),w)c(n)?await t(I+F(a)+S+" true"):await p(W(n,(async(n,s)=>{c(n)?await t(I+F(a)+S+F(e)+"=$1",[s]):h(v)||await ft(t,a,e,G(n),[s,...o?A(X(n),o):X(n)],r)})));else if(h(v))j(u,a)&&await t(I+F(a)+S+" true");else{const s=m(U(st(u,a)),(t=>t!=e)),i=[],c=[];W(n??{},((t,a)=>{N(i,a,...A(s,(a=>o?o(t?.[a]):t?.[a]))),N(c,a)})),await ft(t,a,e,s,i,r),await t(I+F(a)+S+F(e)+`NOT IN(${x(c)})`,c)}},async a=>{let e;await t("BEGIN");try{e=await a()}catch(t){n?.(t)}return await t("END"),e}]},ft=async(t,a,e,i,r,o=0)=>await t("INSERT "+(o?"OR REPLACE ":n)+"INTO"+F(a)+"("+F(e)+g(A(i,(t=>s+F(t))))+")VALUES"+Et(r,d(i)+1)+(o?n:"ON CONFLICT("+F(e)+")DO UPDATE SET"+g(A(i,(t=>F(t)+"=excluded."+F(t))),s)),A(r,(t=>t??null))),Et=(t,a)=>g(f(d(t)/a,(t=>"("+g(f(a,(e=>"$"+(t*a+e+1))),s)+")")),s),gt=(t,a,e,n,s,i,r,[o,c,l],u,y,w,d,p,v)=>{const[f,E,g,A]=vt(a,u,y,s,p,v),h=pt(t,(async()=>await A((async()=>{return await f(),t=(await E(o,c))[$]?.[l]??"null",et(t,((t,a)=>""===a?void 0:a));var t}))),(async t=>await A((async()=>{var a;await f(),await g(o,c,{[$]:{[l]:(a=t()??null,at(a,((t,a)=>void 0===a?"":a)))}},!0,!0)}))),e,n,s,r,{[d]:()=>w,destroy:()=>(h.stopAutoLoad().stopAutoSave(),i(),h)},w);return h},At=(t,a,e,n,s,i,r,[o,l,[u,y,w]],d,v,f,E,g,A,h,N)=>{const[T,C,S,L]=vt(a,d,v,s,g,A,h,N),O=async(t,a)=>await p(it(l,(async([e,n,s,i],r)=>{a&&!(r in t)||await S(e,n,t[r],s,i,a)}))),I=async(t,a)=>y?await S(w,b,{[$]:t},!0,!0,a):null,R=pt(t,(async()=>await L((async()=>{await T();const t=await(async()=>K(m(await p(it(o,(async([t,a],e)=>[t,await C(e,a)]))),(t=>!tt(t[1])))))(),a=await(async()=>u?(await C(w,b))[$]:{})();return tt(t)&&c(a)?void 0:[t,a]}))),(async(t,a)=>await L((async()=>{if(await T(),c(a)){const[a,e]=t();await O(a),await I(e)}else await O(a[0],!0),await I(a[1],!0)}))),e,n,s,r,{[E]:()=>f,destroy:()=>(R.stopAutoLoad().stopAutoSave(),i(),R)},f);return R},ht="ColumnName",mt="store",Nt="json",Tt=mt+"TableName",$t=mt+"Id"+ht,bt=mt+ht,Ct="autoLoadIntervalSeconds",St="rowId"+ht,Lt="tableId",Ot="tableName",It="deleteEmptyColumns",Rt="deleteEmptyTable",Dt={mode:Nt,[Ct]:1},Mt={load:0,save:0,[Ot]:e+"_values"},Pt=(t,a,e,n,s)=>{const i=nt();return W(t,((t,r)=>{const o=w(X(Q(a,u(t)?{[e]:t}:t)),0,Z(a));c(o[0])||n(r,o[0])||(s(r,o[0]),rt(i,r,o))})),i},_t=(t,a,s,i,r,c,l,y,d,p,v="getDb",f)=>{let E,g,A;const h=((t,a)=>a?async(e,n)=>(a(e,n),await t(e,n)):t)(s,c),[m,N,T,$]=(t=>{const a=(t=>Q(Dt,u(t)?{[Tt]:t}:t??{}))(t),n=a[Ct];if(a.mode==Nt){const t=a[Tt]??e;return[1,n,[t,a[$t]??b,a[bt]??mt],lt(t)]}const{tables:{load:s={},save:i={}}={},values:r={}}=a,o=w(X(Q(Mt,r)),0,Z(Mt)),c=o[2],l=lt(c),y=lt(c);return[0,n,[Pt(s,{[Lt]:null,[St]:b},Lt,(t=>j(y,t)),(t=>ut(l,t))),Pt(i,{[Ot]:null,[St]:b,[It]:0,[Rt]:0},Ot,((t,a)=>j(y,a)),((t,a)=>ut(l,a))),o],l]})(a);return(m?gt:At)(t,h,(t=>{let a;const e=()=>a=setInterval((async()=>{try{const[{d:a,s:e,c:n}]=await h(`${C} ${M} d,${P} s,TOTAL_CHANGES() c FROM ${D}${M} JOIN ${D}${P}`);a==E&&e==g&&n==A||(null!=E&&t(),E=a,g=e,A=n)}catch{}}),1e3*N),n=()=>{E=g=A=null,o(a)},s=i((a=>{$.has(a)&&(n(),t(),e())}));return e(),()=>{n(),r(s)}}),(t=>t()),l,y,d,T,U($),(async(t,a)=>await t(`${C} t.name tn,c.name cn FROM ${_}list()t,${_}info(t.name)c ${S} t.schema='main'AND t.type IN('table','view')AND t.name IN(${x(a)})ORDER BY t.name,c.name`,a)),p,v,n,f,(t=>!0===t?1:!1===t?0:t),void 0)};t.createLibSqlPersister=(t,a,e,n,s)=>_t(t,e,(async(t,e=[])=>(await a.execute({sql:t,args:e})).rows),(()=>()=>0),(t=>t()),n,s,(()=>0),1,a,"getClient")},"object"==typeof exports&&"undefined"!=typeof module?a(exports):"function"==typeof define&&define.amd?define(["exports"],a):a((t="undefined"!=typeof globalThis?globalThis:t||self).TinyBasePersisterLibsql={});
1
+ var t,a;t=this,a=function(t){"use strict";const a=t=>typeof t,e="tinybase",n="",s=",",i=a(n),o=Promise,r=clearInterval,c=t=>null==t,l=(t,a,e)=>c(t)?e?.():a(t),u=t=>a(t)==i,y=t=>Array.isArray(t),w=(t,a,e)=>t.slice(a,e),d=t=>t.length,p=async t=>o.all(t),v=t=>{throw Error(t)},f=(t,a)=>t.forEach(a),g=(t,a="")=>t.join(a),E=(t,a)=>t.map(a),h=t=>0==d(t),m=(t,a)=>t.filter(a),A=(t,...a)=>t.push(...a),N=t=>t.shift(),T="_",$="_id",b="SELECT",S="WHERE",C="TABLE",L="ALTER "+C,O="DELETE FROM",I=b+"*FROM",D="pragma_",R="data_version",M="schema_version",P="pragma_table_",_=t=>`"${t.replace(/"/g,'""')}"`,F=(t,a=[1])=>g(E(t,(()=>"$"+a[0]++)),s),x=(t,a)=>t?.has(a)??!1,j=t=>c(t)||0==(t=>t?.size??0)(t),B=t=>[...t?.values()??[]],U=(t,a)=>t?.forEach(a),q=(t,a)=>t?.delete(a),J=Object,Y=t=>J.getPrototypeOf(t),k=J.entries,z=J.keys,G=J.freeze,H=(t=[])=>J.fromEntries(t),K=(...t)=>J.assign({},...t),Q=(t,a)=>(delete t[a],t),V=(t,a)=>E(k(t),(([t,e])=>a(e,t))),W=t=>J.values(t),X=t=>d(z(t)),Z=t=>(t=>!c(t)&&l(Y(t),(t=>t==J.prototype||c(Y(t))),(()=>!0)))(t)&&0==X(t),tt=JSON.stringify,at=JSON.parse,et=t=>new Map(t),nt=(t,a)=>t?.get(a),st=(t,a)=>E([...t?.entries()??[]],(([t,e])=>a(e,t))),it=(t,a,e)=>c(e)?(q(t,a),t):t?.set(a,e),ot=(t,a,e,n)=>(x(t,a)?n?.(nt(t,a)):it(t,a,e()),nt(t,a)),rt=(t,a,e,n,s=0)=>l((e?ot:nt)(t,a[s],s>d(a)-2?e:et),(i=>{if(s>d(a)-2)return n?.(i)&&it(t,a[s]),i;const o=rt(i,a,e,n,s+1);return j(i)&&it(t,a[s]),o})),ct=t=>new Set(y(t)||c(t)?t:[t]),lt=(t,a)=>t?.add(a),ut=/^\d+$/,yt=et(),wt=et(),dt=(t,a,e,s,i,o,r,u={},w=[])=>{let p,g,E,h=0,m=0,T=0;ot(yt,w,(()=>0)),ot(wt,w,(()=>[]));const $=et(),[b,S,C,L,O]=((t=1,a)=>1!=t&&a.isMergeable()?[1,a.getMergeableContent,a.getTransactionMergeableChanges,([[t],[a]])=>!Z(t)||!Z(a),a.setDefaultContent]:2!=t?[0,a.getContent,a.getTransactionChanges,([t,a])=>!Z(t)||!Z(a),a.setContent]:v("Store type not supported by this Persister"))(r,t),[I,D,R]=(()=>{let t;const[a,e]=(()=>{const t=[];let a=0;return[e=>(e?N(t):null)??n+a++,a=>{ut.test(a)&&d(t)<1e3&&A(t,a)}]})(),s=et();return[(e,i,o,r=[],c=()=>[])=>{t??=Y;const l=a(1);return it(s,l,[e,i,o,r,c]),lt(rt(i,o??[n],ct),l),l},(a,e,...i)=>f(((t,a=[n])=>{const e=[],s=(t,n)=>n==d(a)?A(e,t):null===a[n]?U(t,(t=>s(t,n+1))):f([a[n],null],(a=>s(nt(t,a),n+1)));return s(t,0),e})(a,e),(a=>U(a,(a=>nt(s,a)[0](t,...e??[],...i))))),t=>l(nt(s,t),(([,a,i])=>(rt(a,i??[n],void 0,(a=>(q(a,t),j(a)?1:0))),it(s,t),e(t),i))),a=>l(nt(s,a),(([a,,e=[],n,s])=>{const i=(...o)=>{const r=d(o);r==d(e)?a(t,...o,...s(o)):c(e[r])?f(n[r]?.(...o)??[],(t=>i(...o,t))):i(...o,e[r])};i()}))]})(),M=t=>{t!=h&&(h=t,D($,void 0,h))},P=a=>{(b&&y(a?.[0])?1===a?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===a?.[2]?t.applyChanges:t.setContent)(a)},_=async t=>(2!=h&&(M(1),m++,await J((async()=>{try{const e=await a();y(e)?P(e):t?O(t):v("Content is not an array "+e)}catch(a){o?.(a),t&&O(t)}M(0)}))),Y),F=()=>(g&&(i(g),g=void 0),Y),x=async t=>(1!=h&&(M(2),T++,await J((async()=>{try{await e(S,t)}catch(t){o?.(t)}M(0)}))),Y),B=()=>(l(E,t.delListener),E=void 0,Y),J=async(...t)=>(A(nt(wt,w),...t),await(async()=>{if(!nt(yt,w)){for(it(yt,w,1);!c(p=N(nt(wt,w)));)try{await p()}catch(t){o?.(t)}it(yt,w,0)}})(),Y),Y={load:_,startAutoLoad:async t=>{await F().load(t);try{g=await s((async(t,a)=>{a||t?2!=h&&(M(1),m++,P(a??t),M(0)):await _()}))}catch(t){o?.(t)}return Y},stopAutoLoad:F,isAutoLoading:()=>!c(g),save:x,startAutoSave:async()=>(await B().save(),E=t.addDidFinishTransactionListener((()=>{const t=C();L(t)&&x(t)})),Y),stopAutoSave:B,isAutoSaving:()=>!c(E),getStatus:()=>h,addStatusListener:t=>I(t,$),delListener:a=>(R(a),t),schedule:J,getStore:()=>t,destroy:()=>(nt(wt,w).splice(0,void 0),F().stopAutoSave()),getStats:()=>({loads:m,saves:T}),...u};return G(Y)},pt=(t,a,e,n,i,o=vt,r,l)=>{const u=et();return[async()=>{u.clear(),E(await e(t,a),(({tn:t,cn:a})=>lt(ot(u,t,ct),a)))},async(a,e)=>((t,a)=>x(nt(u,t),a))(a,e)?H(m(E(await t(I+_(a)),(t=>{return[t[e],l?(a=Q(t,e),n=l,H(V(a,((t,a)=>[a,n(t,a)])))):Q(t,e)];var a,n})),(([t,a])=>!c(t)&&!Z(a)))):{},async(a,e,n,l,y,w=!1)=>{const d=ct();V(n??{},(t=>E(z(t??{}),(t=>lt(d,t)))));const v=B(d);if(!w&&y&&h(v)&&x(u,a))return await t("DROP "+C+_(a)),void it(u,a);const f=nt(u,a),N=ct(B(f));if(h(v)||(x(u,a)?await p(E([e,...v],(async(n,s)=>{q(N,n)||(await t(L+_(a)+"ADD"+_(n)+i),0==s&&await t("CREATE UNIQUE INDEX pk ON "+_(a)+`(${_(e)})`),lt(f,n))}))):(await t("CREATE "+C+_(a)+`(${_(e)}${i} PRIMARY KEY${g(E(v,(t=>s+_(t)+i)))});`),it(u,a,ct([e,...v])))),await p([...!w&&l?E(B(N),(async n=>{n!=e&&(await t(L+_(a)+"DROP"+_(n)),q(f,n))})):[]]),w)c(n)?await t(O+_(a)+S+" true"):await p(V(n,(async(n,s)=>{c(n)?await t(O+_(a)+S+_(e)+"=$1",[s]):h(v)||await o(t,a,e,z(n),{[s]:r?E(W(n),r):W(n)},f)})));else if(h(v))x(u,a)&&await t(O+_(a)+S+" true");else{const s=m(B(nt(u,a)),(t=>t!=e)),i={},c=[];V(n??{},((t,a)=>{i[a]=E(s,(a=>r?r(t?.[a]):t?.[a])),A(c,a)})),await o(t,a,e,s,i),await t(O+_(a)+S+_(e)+`NOT IN(${F(c)})`,c)}},async a=>{let e;await t("BEGIN");try{e=await a()}catch(t){n?.(t)}return await t("END"),e}]},vt=async(t,a,e,n,i)=>{const o=[1];await t("INSERT INTO"+_(a)+"("+((...t)=>g(E(t,_),s))(e,...n)+")VALUES"+g(V(i,(t=>"($"+o[0]+++","+F(t,o)+")")),s)+"ON CONFLICT("+_(e)+")DO UPDATE SET"+g(E(n,(t=>_(t)+"=excluded."+_(t))),s),V(i,((t,a)=>[a,...E(t,(t=>t??null))])).flat())},ft=(t,a,e,n,s,i,o,[r,c,l],u,y,w,d,p,v)=>{const[f,g,E,h]=pt(a,u,y,s,p,v),m=dt(t,(async()=>await h((async()=>{return await f(),t=(await g(r,c))[T]?.[l]??"null",at(t,((t,a)=>""===a?void 0:a));var t}))),(async t=>await h((async()=>{var a;await f(),await E(r,c,{[T]:{[l]:(a=t()??null,tt(a,((t,a)=>void 0===a?"":a)))}},!0,!0)}))),e,n,s,o,{[d]:()=>w,destroy:()=>(m.stopAutoLoad().stopAutoSave(),i(),m)},w);return m},gt=(t,a,e,n,s,i,o,[r,l,[u,y,w]],d,v,f,g,E,h,A,N)=>{const[b,S,C,L]=pt(a,d,v,s,E,h,A,N),O=async(t,a)=>await p(st(l,(async([e,n,s,i],o)=>{a&&!(o in t)||await C(e,n,t[o],s,i,a)}))),I=async(t,a)=>y?await C(w,$,{[T]:t},!0,!0,a):null,D=dt(t,(async()=>await L((async()=>{await b();const t=await(async()=>H(m(await p(st(r,(async([t,a],e)=>[t,await S(e,a)]))),(t=>!Z(t[1])))))(),a=await(async()=>u?(await S(w,$))[T]:{})();return Z(t)&&c(a)?void 0:[t,a]}))),(async(t,a)=>await L((async()=>{if(await b(),c(a)){const[a,e]=t();await O(a),await I(e)}else await O(a[0],!0),await I(a[1],!0)}))),e,n,s,o,{[g]:()=>f,destroy:()=>(D.stopAutoLoad().stopAutoSave(),i(),D)},f);return D},Et="ColumnName",ht="store",mt="json",At=ht+"TableName",Nt=ht+"Id"+Et,Tt=ht+Et,$t="autoLoadIntervalSeconds",bt="rowId"+Et,St="tableId",Ct="tableName",Lt="deleteEmptyColumns",Ot="deleteEmptyTable",It={mode:mt,[$t]:1},Dt={load:0,save:0,[Ct]:e+"_values"},Rt=(t,a,e,n,s)=>{const i=et();return V(t,((t,o)=>{const r=w(W(K(a,u(t)?{[e]:t}:t)),0,X(a));c(r[0])||n(o,r[0])||(s(o,r[0]),it(i,o,r))})),i},Mt=(t,a,s,i,o,c,l,y,d,p,v="getDb",f)=>{let g,E,h;const m=((t,a)=>a?async(e,n)=>(a(e,n),await t(e,n)):t)(s,c),[A,N,T,C]=(t=>{const a=(t=>K(It,u(t)?{[At]:t}:t??{}))(t),n=a[$t];if(a.mode==mt){const t=a[At]??e;return[1,n,[t,a[Nt]??$,a[Tt]??ht],ct(t)]}const{tables:{load:s={},save:i={}}={},values:o={}}=a,r=w(W(K(Dt,o)),0,X(Dt)),c=r[2],l=ct(c),y=ct(c);return[0,n,[Rt(s,{[St]:null,[bt]:$},St,(t=>x(y,t)),(t=>lt(l,t))),Rt(i,{[Ct]:null,[bt]:$,[Lt]:0,[Ot]:0},Ct,((t,a)=>x(y,a)),((t,a)=>lt(l,a))),r],l]})(a);return(A?ft:gt)(t,m,(t=>{let a;const e=()=>a=setInterval((async()=>{try{const[{d:a,s:e,c:n}]=await m(`${b} ${R} d,${M} s,TOTAL_CHANGES() c FROM ${D}${R} JOIN ${D}${M}`);a==g&&e==E&&n==h||(null!=g&&t(),g=a,E=e,h=n)}catch{}}),1e3*N),n=()=>{g=E=h=null,r(a)},s=i((a=>{C.has(a)&&(n(),t(),e())}));return e(),()=>{n(),o(s)}}),(t=>t()),l,y,d,T,B(C),(async(t,a)=>await t(`${b} t.name tn,c.name cn FROM ${P}list()t,${P}info(t.name)c ${S} t.schema='main'AND t.type IN('table','view')AND t.name IN(${F(a)})ORDER BY t.name,c.name`,a)),p,v,n,f,(t=>!0===t?1:!1===t?0:t),void 0)};t.createLibSqlPersister=(t,a,e,n,s)=>Mt(t,e,(async(t,e=[])=>(await a.execute({sql:t,args:e})).rows),(()=>()=>0),(t=>t()),n,s,(()=>0),1,a,"getClient")},"object"==typeof exports&&"undefined"!=typeof module?a(exports):"function"==typeof define&&define.amd?define(["exports"],a):a((t="undefined"!=typeof globalThis?globalThis:t||self).TinyBasePersisterLibsql={});
@@ -1 +1 @@
1
- var t,a;t=this,a=function(t){"use strict";const a=t=>typeof t,e="tinybase",n="",s=",",i=a(n),r=Promise,o=clearInterval,c=t=>null==t,l=(t,a,e)=>c(t)?e?.():a(t),u=t=>a(t)==i,y=t=>Array.isArray(t),w=(t,a,e)=>t.slice(a,e),d=t=>t.length,p=async t=>r.all(t),v=t=>{throw Error(t)},f=(t,a)=>A(Array(t).fill(0),((t,e)=>a(e))),E=(t,a)=>t.forEach(a),g=(t,a="")=>t.join(a),A=(t,a)=>t.map(a),h=t=>0==d(t),m=(t,a)=>t.filter(a),N=(t,...a)=>t.push(...a),T=t=>t.shift(),$="_",b="_id",C="SELECT",S="WHERE",L="TABLE",O="ALTER "+L,I="DELETE FROM",R=C+"*FROM",D="pragma_",M="data_version",P="schema_version",_="pragma_table_",F=t=>`"${t.replace(/"/g,'""')}"`,x=t=>g(A(t,((t,a)=>"$"+(a+1))),s),j=(t,a)=>t?.has(a)??!1,B=t=>c(t)||0==(t=>t?.size??0)(t),U=t=>[...t?.values()??[]],q=(t,a)=>t?.forEach(a),J=(t,a)=>t?.delete(a),Y=Object,k=t=>Y.getPrototypeOf(t),z=Y.entries,G=Y.keys,H=Y.freeze,K=(t=[])=>Y.fromEntries(t),Q=(...t)=>Y.assign({},...t),V=(t,a)=>(delete t[a],t),W=(t,a)=>A(z(t),(([t,e])=>a(e,t))),X=t=>Y.values(t),Z=t=>d(G(t)),tt=t=>(t=>!c(t)&&l(k(t),(t=>t==Y.prototype||c(k(t))),(()=>!0)))(t)&&0==Z(t),at=JSON.stringify,et=JSON.parse,nt=t=>new Map(t),st=(t,a)=>t?.get(a),it=(t,a)=>A([...t?.entries()??[]],(([t,e])=>a(e,t))),rt=(t,a,e)=>c(e)?(J(t,a),t):t?.set(a,e),ot=(t,a,e,n)=>(j(t,a)?n?.(st(t,a)):rt(t,a,e()),st(t,a)),ct=(t,a,e,n,s=0)=>l((e?ot:st)(t,a[s],s>d(a)-2?e:nt),(i=>{if(s>d(a)-2)return n?.(i)&&rt(t,a[s]),i;const r=ct(i,a,e,n,s+1);return B(i)&&rt(t,a[s]),r})),lt=t=>new Set(y(t)||c(t)?t:[t]),ut=(t,a)=>t?.add(a),yt=/^\d+$/,wt=nt(),dt=nt(),pt=(t,a,e,s,i,r,o,u={},w=[])=>{let p,f,g,A=0,h=0,m=0;ot(wt,w,(()=>0)),ot(dt,w,(()=>[]));const $=nt(),[b,C,S,L,O]=((t=1,a)=>1!=t&&a.isMergeable()?[1,a.getMergeableContent,a.getTransactionMergeableChanges,([[t],[a]])=>!tt(t)||!tt(a),a.setDefaultContent]:2!=t?[0,a.getContent,a.getTransactionChanges,([t,a])=>!tt(t)||!tt(a),a.setContent]:v("Store type not supported by this Persister"))(o,t),[I,R,D]=(()=>{let t;const[a,e]=(()=>{const t=[];let a=0;return[e=>(e?T(t):null)??n+a++,a=>{yt.test(a)&&d(t)<1e3&&N(t,a)}]})(),s=nt();return[(e,i,r,o=[],c=()=>[])=>{t??=Y;const l=a(1);return rt(s,l,[e,i,r,o,c]),ut(ct(i,r??[n],lt),l),l},(a,e,...i)=>E(((t,a=[n])=>{const e=[],s=(t,n)=>n==d(a)?N(e,t):null===a[n]?q(t,(t=>s(t,n+1))):E([a[n],null],(a=>s(st(t,a),n+1)));return s(t,0),e})(a,e),(a=>q(a,(a=>st(s,a)[0](t,...e??[],...i))))),t=>l(st(s,t),(([,a,i])=>(ct(a,i??[n],void 0,(a=>(J(a,t),B(a)?1:0))),rt(s,t),e(t),i))),a=>l(st(s,a),(([a,,e=[],n,s])=>{const i=(...r)=>{const o=d(r);o==d(e)?a(t,...r,...s(r)):c(e[o])?E(n[o]?.(...r)??[],(t=>i(...r,t))):i(...r,e[o])};i()}))]})(),M=t=>{t!=A&&(A=t,R($,void 0,A))},P=a=>{(b&&y(a?.[0])?1===a?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===a?.[2]?t.applyChanges:t.setContent)(a)},_=async t=>(2!=A&&(M(1),h++,await U((async()=>{try{const t=await a();y(t)?P(t):v("Content is not an array "+t)}catch(a){r?.(a),t&&O(t)}M(0)}))),Y),F=()=>(f&&(i(f),f=void 0),Y),x=async t=>(1!=A&&(M(2),m++,await U((async()=>{try{await e(C,t)}catch(t){r?.(t)}M(0)}))),Y),j=()=>(l(g,t.delListener),g=void 0,Y),U=async(...t)=>(N(st(dt,w),...t),await(async()=>{if(!st(wt,w)){for(rt(wt,w,1);!c(p=T(st(dt,w)));)try{await p()}catch(t){r?.(t)}rt(wt,w,0)}})(),Y),Y={load:_,startAutoLoad:async t=>{await F().load(t);try{f=await s((async(t,a)=>{a||t?2!=A&&(M(1),h++,P(a??t),M(0)):await _()}))}catch(t){r?.(t)}return Y},stopAutoLoad:F,isAutoLoading:()=>!c(f),save:x,startAutoSave:async()=>(await j().save(),g=t.addDidFinishTransactionListener((()=>{const t=S();L(t)&&x(t)})),Y),stopAutoSave:j,isAutoSaving:()=>!c(g),getStatus:()=>A,addStatusListener:t=>I(t,$),delListener:a=>(D(a),t),schedule:U,getStore:()=>t,destroy:()=>(st(dt,w).splice(0,void 0),F().stopAutoSave()),getStats:()=>({loads:h,saves:m}),...u};return H(Y)},vt=(t,a,e,n,i,r,o,l)=>{const u=nt();return[async()=>{u.clear(),A(await e(t,a),(({tn:t,cn:a})=>ut(ot(u,t,lt),a)))},async(a,e)=>((t,a)=>j(st(u,t),a))(a,e)?K(m(A(await t(R+F(a)),(t=>{return[t[e],l?(a=V(t,e),n=l,K(W(a,((t,a)=>[a,n(t,a)])))):V(t,e)];var a,n})),(([t,a])=>!c(t)&&!tt(a)))):{},async(a,e,n,l,y,w=!1)=>{const d=lt();W(n??{},(t=>A(G(t??{}),(t=>ut(d,t)))));const v=U(d);if(!w&&y&&h(v)&&j(u,a))return await t("DROP "+L+F(a)),void rt(u,a);const f=st(u,a),E=lt(U(f));if(h(v)||(j(u,a)?await p(A([e,...v],(async(n,s)=>{J(E,n)||(await t(O+F(a)+"ADD"+F(n)+i),0==s&&await t("CREATE UNIQUE INDEX pk ON "+F(a)+`(${F(e)})`),ut(f,n))}))):(await t("CREATE "+L+F(a)+`(${F(e)}${i} PRIMARY KEY${g(A(v,(t=>s+F(t)+i)))});`),rt(u,a,lt([e,...v])))),await p([...!w&&l?A(U(E),(async n=>{n!=e&&(await t(O+F(a)+"DROP"+F(n)),J(f,n))})):[]]),w)c(n)?await t(I+F(a)+S+" true"):await p(W(n,(async(n,s)=>{c(n)?await t(I+F(a)+S+F(e)+"=$1",[s]):h(v)||await ft(t,a,e,G(n),[s,...o?A(X(n),o):X(n)],r)})));else if(h(v))j(u,a)&&await t(I+F(a)+S+" true");else{const s=m(U(st(u,a)),(t=>t!=e)),i=[],c=[];W(n??{},((t,a)=>{N(i,a,...A(s,(a=>o?o(t?.[a]):t?.[a]))),N(c,a)})),await ft(t,a,e,s,i,r),await t(I+F(a)+S+F(e)+`NOT IN(${x(c)})`,c)}},async a=>{let e;await t("BEGIN");try{e=await a()}catch(t){n?.(t)}return await t("END"),e}]},ft=async(t,a,e,i,r,o=0)=>await t("INSERT "+(o?"OR REPLACE ":n)+"INTO"+F(a)+"("+F(e)+g(A(i,(t=>s+F(t))))+")VALUES"+Et(r,d(i)+1)+(o?n:"ON CONFLICT("+F(e)+")DO UPDATE SET"+g(A(i,(t=>F(t)+"=excluded."+F(t))),s)),A(r,(t=>t??null))),Et=(t,a)=>g(f(d(t)/a,(t=>"("+g(f(a,(e=>"$"+(t*a+e+1))),s)+")")),s),gt=(t,a,e,n,s,i,r,[o,c,l],u,y,w,d,p,v)=>{const[f,E,g,A]=vt(a,u,y,s,p,v),h=pt(t,(async()=>await A((async()=>{return await f(),t=(await E(o,c))[$]?.[l]??"null",et(t,((t,a)=>""===a?void 0:a));var t}))),(async t=>await A((async()=>{var a;await f(),await g(o,c,{[$]:{[l]:(a=t()??null,at(a,((t,a)=>void 0===a?"":a)))}},!0,!0)}))),e,n,s,r,{[d]:()=>w,destroy:()=>(h.stopAutoLoad().stopAutoSave(),i(),h)},w);return h},At=(t,a,e,n,s,i,r,[o,l,[u,y,w]],d,v,f,E,g,A,h,N)=>{const[T,C,S,L]=vt(a,d,v,s,g,A,h,N),O=async(t,a)=>await p(it(l,(async([e,n,s,i],r)=>{a&&!(r in t)||await S(e,n,t[r],s,i,a)}))),I=async(t,a)=>y?await S(w,b,{[$]:t},!0,!0,a):null,R=pt(t,(async()=>await L((async()=>{await T();const t=await(async()=>K(m(await p(it(o,(async([t,a],e)=>[t,await C(e,a)]))),(t=>!tt(t[1])))))(),a=await(async()=>u?(await C(w,b))[$]:{})();return tt(t)&&c(a)?void 0:[t,a]}))),(async(t,a)=>await L((async()=>{if(await T(),c(a)){const[a,e]=t();await O(a),await I(e)}else await O(a[0],!0),await I(a[1],!0)}))),e,n,s,r,{[E]:()=>f,destroy:()=>(R.stopAutoLoad().stopAutoSave(),i(),R)},f);return R},ht="ColumnName",mt="store",Nt="json",Tt=mt+"TableName",$t=mt+"Id"+ht,bt=mt+ht,Ct="autoLoadIntervalSeconds",St="rowId"+ht,Lt="tableId",Ot="tableName",It="deleteEmptyColumns",Rt="deleteEmptyTable",Dt={mode:Nt,[Ct]:1},Mt={load:0,save:0,[Ot]:e+"_values"},Pt=(t,a,e,n,s)=>{const i=nt();return W(t,((t,r)=>{const o=w(X(Q(a,u(t)?{[e]:t}:t)),0,Z(a));c(o[0])||n(r,o[0])||(s(r,o[0]),rt(i,r,o))})),i},_t=(t,a,s,i,r,c,l,y,d,p,v="getDb",f)=>{let E,g,A;const h=((t,a)=>a?async(e,n)=>(a(e,n),await t(e,n)):t)(s,c),[m,N,T,$]=(t=>{const a=(t=>Q(Dt,u(t)?{[Tt]:t}:t??{}))(t),n=a[Ct];if(a.mode==Nt){const t=a[Tt]??e;return[1,n,[t,a[$t]??b,a[bt]??mt],lt(t)]}const{tables:{load:s={},save:i={}}={},values:r={}}=a,o=w(X(Q(Mt,r)),0,Z(Mt)),c=o[2],l=lt(c),y=lt(c);return[0,n,[Pt(s,{[Lt]:null,[St]:b},Lt,(t=>j(y,t)),(t=>ut(l,t))),Pt(i,{[Ot]:null,[St]:b,[It]:0,[Rt]:0},Ot,((t,a)=>j(y,a)),((t,a)=>ut(l,a))),o],l]})(a);return(m?gt:At)(t,h,(t=>{let a;const e=()=>a=setInterval((async()=>{try{const[{d:a,s:e,c:n}]=await h(`${C} ${M} d,${P} s,TOTAL_CHANGES() c FROM ${D}${M} JOIN ${D}${P}`);a==E&&e==g&&n==A||(null!=E&&t(),E=a,g=e,A=n)}catch{}}),1e3*N),n=()=>{E=g=A=null,o(a)},s=i((a=>{$.has(a)&&(n(),t(),e())}));return e(),()=>{n(),r(s)}}),(t=>t()),l,y,d,T,U($),(async(t,a)=>await t(`${C} t.name tn,c.name cn FROM ${_}list()t,${_}info(t.name)c ${S} t.schema='main'AND t.type IN('table','view')AND t.name IN(${x(a)})ORDER BY t.name,c.name`,a)),p,v,n,f,(t=>!0===t?1:!1===t?0:t),void 0)};t.createLibSqlPersister=(t,a,e,n,s)=>_t(t,e,(async(t,e=[])=>(await a.execute({sql:t,args:e})).rows),(()=>()=>0),(t=>t()),n,s,(()=>0),1,a,"getClient")},"object"==typeof exports&&"undefined"!=typeof module?a(exports):"function"==typeof define&&define.amd?define(["exports"],a):a((t="undefined"!=typeof globalThis?globalThis:t||self).TinyBasePersisterLibsql={});
1
+ var t,a;t=this,a=function(t){"use strict";const a=t=>typeof t,e="tinybase",n="",s=",",i=a(n),o=Promise,r=clearInterval,c=t=>null==t,l=(t,a,e)=>c(t)?e?.():a(t),u=t=>a(t)==i,y=t=>Array.isArray(t),w=(t,a,e)=>t.slice(a,e),d=t=>t.length,p=async t=>o.all(t),v=t=>{throw Error(t)},f=(t,a)=>t.forEach(a),g=(t,a="")=>t.join(a),E=(t,a)=>t.map(a),h=t=>0==d(t),m=(t,a)=>t.filter(a),A=(t,...a)=>t.push(...a),N=t=>t.shift(),T="_",$="_id",b="SELECT",S="WHERE",C="TABLE",L="ALTER "+C,O="DELETE FROM",I=b+"*FROM",D="pragma_",R="data_version",M="schema_version",P="pragma_table_",_=t=>`"${t.replace(/"/g,'""')}"`,F=(t,a=[1])=>g(E(t,(()=>"$"+a[0]++)),s),x=(t,a)=>t?.has(a)??!1,j=t=>c(t)||0==(t=>t?.size??0)(t),B=t=>[...t?.values()??[]],U=(t,a)=>t?.forEach(a),q=(t,a)=>t?.delete(a),J=Object,Y=t=>J.getPrototypeOf(t),k=J.entries,z=J.keys,G=J.freeze,H=(t=[])=>J.fromEntries(t),K=(...t)=>J.assign({},...t),Q=(t,a)=>(delete t[a],t),V=(t,a)=>E(k(t),(([t,e])=>a(e,t))),W=t=>J.values(t),X=t=>d(z(t)),Z=t=>(t=>!c(t)&&l(Y(t),(t=>t==J.prototype||c(Y(t))),(()=>!0)))(t)&&0==X(t),tt=JSON.stringify,at=JSON.parse,et=t=>new Map(t),nt=(t,a)=>t?.get(a),st=(t,a)=>E([...t?.entries()??[]],(([t,e])=>a(e,t))),it=(t,a,e)=>c(e)?(q(t,a),t):t?.set(a,e),ot=(t,a,e,n)=>(x(t,a)?n?.(nt(t,a)):it(t,a,e()),nt(t,a)),rt=(t,a,e,n,s=0)=>l((e?ot:nt)(t,a[s],s>d(a)-2?e:et),(i=>{if(s>d(a)-2)return n?.(i)&&it(t,a[s]),i;const o=rt(i,a,e,n,s+1);return j(i)&&it(t,a[s]),o})),ct=t=>new Set(y(t)||c(t)?t:[t]),lt=(t,a)=>t?.add(a),ut=/^\d+$/,yt=et(),wt=et(),dt=(t,a,e,s,i,o,r,u={},w=[])=>{let p,g,E,h=0,m=0,T=0;ot(yt,w,(()=>0)),ot(wt,w,(()=>[]));const $=et(),[b,S,C,L,O]=((t=1,a)=>1!=t&&a.isMergeable()?[1,a.getMergeableContent,a.getTransactionMergeableChanges,([[t],[a]])=>!Z(t)||!Z(a),a.setDefaultContent]:2!=t?[0,a.getContent,a.getTransactionChanges,([t,a])=>!Z(t)||!Z(a),a.setContent]:v("Store type not supported by this Persister"))(r,t),[I,D,R]=(()=>{let t;const[a,e]=(()=>{const t=[];let a=0;return[e=>(e?N(t):null)??n+a++,a=>{ut.test(a)&&d(t)<1e3&&A(t,a)}]})(),s=et();return[(e,i,o,r=[],c=()=>[])=>{t??=Y;const l=a(1);return it(s,l,[e,i,o,r,c]),lt(rt(i,o??[n],ct),l),l},(a,e,...i)=>f(((t,a=[n])=>{const e=[],s=(t,n)=>n==d(a)?A(e,t):null===a[n]?U(t,(t=>s(t,n+1))):f([a[n],null],(a=>s(nt(t,a),n+1)));return s(t,0),e})(a,e),(a=>U(a,(a=>nt(s,a)[0](t,...e??[],...i))))),t=>l(nt(s,t),(([,a,i])=>(rt(a,i??[n],void 0,(a=>(q(a,t),j(a)?1:0))),it(s,t),e(t),i))),a=>l(nt(s,a),(([a,,e=[],n,s])=>{const i=(...o)=>{const r=d(o);r==d(e)?a(t,...o,...s(o)):c(e[r])?f(n[r]?.(...o)??[],(t=>i(...o,t))):i(...o,e[r])};i()}))]})(),M=t=>{t!=h&&(h=t,D($,void 0,h))},P=a=>{(b&&y(a?.[0])?1===a?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===a?.[2]?t.applyChanges:t.setContent)(a)},_=async t=>(2!=h&&(M(1),m++,await J((async()=>{try{const e=await a();y(e)?P(e):t?O(t):v("Content is not an array "+e)}catch(a){o?.(a),t&&O(t)}M(0)}))),Y),F=()=>(g&&(i(g),g=void 0),Y),x=async t=>(1!=h&&(M(2),T++,await J((async()=>{try{await e(S,t)}catch(t){o?.(t)}M(0)}))),Y),B=()=>(l(E,t.delListener),E=void 0,Y),J=async(...t)=>(A(nt(wt,w),...t),await(async()=>{if(!nt(yt,w)){for(it(yt,w,1);!c(p=N(nt(wt,w)));)try{await p()}catch(t){o?.(t)}it(yt,w,0)}})(),Y),Y={load:_,startAutoLoad:async t=>{await F().load(t);try{g=await s((async(t,a)=>{a||t?2!=h&&(M(1),m++,P(a??t),M(0)):await _()}))}catch(t){o?.(t)}return Y},stopAutoLoad:F,isAutoLoading:()=>!c(g),save:x,startAutoSave:async()=>(await B().save(),E=t.addDidFinishTransactionListener((()=>{const t=C();L(t)&&x(t)})),Y),stopAutoSave:B,isAutoSaving:()=>!c(E),getStatus:()=>h,addStatusListener:t=>I(t,$),delListener:a=>(R(a),t),schedule:J,getStore:()=>t,destroy:()=>(nt(wt,w).splice(0,void 0),F().stopAutoSave()),getStats:()=>({loads:m,saves:T}),...u};return G(Y)},pt=(t,a,e,n,i,o=vt,r,l)=>{const u=et();return[async()=>{u.clear(),E(await e(t,a),(({tn:t,cn:a})=>lt(ot(u,t,ct),a)))},async(a,e)=>((t,a)=>x(nt(u,t),a))(a,e)?H(m(E(await t(I+_(a)),(t=>{return[t[e],l?(a=Q(t,e),n=l,H(V(a,((t,a)=>[a,n(t,a)])))):Q(t,e)];var a,n})),(([t,a])=>!c(t)&&!Z(a)))):{},async(a,e,n,l,y,w=!1)=>{const d=ct();V(n??{},(t=>E(z(t??{}),(t=>lt(d,t)))));const v=B(d);if(!w&&y&&h(v)&&x(u,a))return await t("DROP "+C+_(a)),void it(u,a);const f=nt(u,a),N=ct(B(f));if(h(v)||(x(u,a)?await p(E([e,...v],(async(n,s)=>{q(N,n)||(await t(L+_(a)+"ADD"+_(n)+i),0==s&&await t("CREATE UNIQUE INDEX pk ON "+_(a)+`(${_(e)})`),lt(f,n))}))):(await t("CREATE "+C+_(a)+`(${_(e)}${i} PRIMARY KEY${g(E(v,(t=>s+_(t)+i)))});`),it(u,a,ct([e,...v])))),await p([...!w&&l?E(B(N),(async n=>{n!=e&&(await t(L+_(a)+"DROP"+_(n)),q(f,n))})):[]]),w)c(n)?await t(O+_(a)+S+" true"):await p(V(n,(async(n,s)=>{c(n)?await t(O+_(a)+S+_(e)+"=$1",[s]):h(v)||await o(t,a,e,z(n),{[s]:r?E(W(n),r):W(n)},f)})));else if(h(v))x(u,a)&&await t(O+_(a)+S+" true");else{const s=m(B(nt(u,a)),(t=>t!=e)),i={},c=[];V(n??{},((t,a)=>{i[a]=E(s,(a=>r?r(t?.[a]):t?.[a])),A(c,a)})),await o(t,a,e,s,i),await t(O+_(a)+S+_(e)+`NOT IN(${F(c)})`,c)}},async a=>{let e;await t("BEGIN");try{e=await a()}catch(t){n?.(t)}return await t("END"),e}]},vt=async(t,a,e,n,i)=>{const o=[1];await t("INSERT INTO"+_(a)+"("+((...t)=>g(E(t,_),s))(e,...n)+")VALUES"+g(V(i,(t=>"($"+o[0]+++","+F(t,o)+")")),s)+"ON CONFLICT("+_(e)+")DO UPDATE SET"+g(E(n,(t=>_(t)+"=excluded."+_(t))),s),V(i,((t,a)=>[a,...E(t,(t=>t??null))])).flat())},ft=(t,a,e,n,s,i,o,[r,c,l],u,y,w,d,p,v)=>{const[f,g,E,h]=pt(a,u,y,s,p,v),m=dt(t,(async()=>await h((async()=>{return await f(),t=(await g(r,c))[T]?.[l]??"null",at(t,((t,a)=>""===a?void 0:a));var t}))),(async t=>await h((async()=>{var a;await f(),await E(r,c,{[T]:{[l]:(a=t()??null,tt(a,((t,a)=>void 0===a?"":a)))}},!0,!0)}))),e,n,s,o,{[d]:()=>w,destroy:()=>(m.stopAutoLoad().stopAutoSave(),i(),m)},w);return m},gt=(t,a,e,n,s,i,o,[r,l,[u,y,w]],d,v,f,g,E,h,A,N)=>{const[b,S,C,L]=pt(a,d,v,s,E,h,A,N),O=async(t,a)=>await p(st(l,(async([e,n,s,i],o)=>{a&&!(o in t)||await C(e,n,t[o],s,i,a)}))),I=async(t,a)=>y?await C(w,$,{[T]:t},!0,!0,a):null,D=dt(t,(async()=>await L((async()=>{await b();const t=await(async()=>H(m(await p(st(r,(async([t,a],e)=>[t,await S(e,a)]))),(t=>!Z(t[1])))))(),a=await(async()=>u?(await S(w,$))[T]:{})();return Z(t)&&c(a)?void 0:[t,a]}))),(async(t,a)=>await L((async()=>{if(await b(),c(a)){const[a,e]=t();await O(a),await I(e)}else await O(a[0],!0),await I(a[1],!0)}))),e,n,s,o,{[g]:()=>f,destroy:()=>(D.stopAutoLoad().stopAutoSave(),i(),D)},f);return D},Et="ColumnName",ht="store",mt="json",At=ht+"TableName",Nt=ht+"Id"+Et,Tt=ht+Et,$t="autoLoadIntervalSeconds",bt="rowId"+Et,St="tableId",Ct="tableName",Lt="deleteEmptyColumns",Ot="deleteEmptyTable",It={mode:mt,[$t]:1},Dt={load:0,save:0,[Ct]:e+"_values"},Rt=(t,a,e,n,s)=>{const i=et();return V(t,((t,o)=>{const r=w(W(K(a,u(t)?{[e]:t}:t)),0,X(a));c(r[0])||n(o,r[0])||(s(o,r[0]),it(i,o,r))})),i},Mt=(t,a,s,i,o,c,l,y,d,p,v="getDb",f)=>{let g,E,h;const m=((t,a)=>a?async(e,n)=>(a(e,n),await t(e,n)):t)(s,c),[A,N,T,C]=(t=>{const a=(t=>K(It,u(t)?{[At]:t}:t??{}))(t),n=a[$t];if(a.mode==mt){const t=a[At]??e;return[1,n,[t,a[Nt]??$,a[Tt]??ht],ct(t)]}const{tables:{load:s={},save:i={}}={},values:o={}}=a,r=w(W(K(Dt,o)),0,X(Dt)),c=r[2],l=ct(c),y=ct(c);return[0,n,[Rt(s,{[St]:null,[bt]:$},St,(t=>x(y,t)),(t=>lt(l,t))),Rt(i,{[Ct]:null,[bt]:$,[Lt]:0,[Ot]:0},Ct,((t,a)=>x(y,a)),((t,a)=>lt(l,a))),r],l]})(a);return(A?ft:gt)(t,m,(t=>{let a;const e=()=>a=setInterval((async()=>{try{const[{d:a,s:e,c:n}]=await m(`${b} ${R} d,${M} s,TOTAL_CHANGES() c FROM ${D}${R} JOIN ${D}${M}`);a==g&&e==E&&n==h||(null!=g&&t(),g=a,E=e,h=n)}catch{}}),1e3*N),n=()=>{g=E=h=null,r(a)},s=i((a=>{C.has(a)&&(n(),t(),e())}));return e(),()=>{n(),o(s)}}),(t=>t()),l,y,d,T,B(C),(async(t,a)=>await t(`${b} t.name tn,c.name cn FROM ${P}list()t,${P}info(t.name)c ${S} t.schema='main'AND t.type IN('table','view')AND t.name IN(${F(a)})ORDER BY t.name,c.name`,a)),p,v,n,f,(t=>!0===t?1:!1===t?0:t),void 0)};t.createLibSqlPersister=(t,a,e,n,s)=>Mt(t,e,(async(t,e=[])=>(await a.execute({sql:t,args:e})).rows),(()=>()=>0),(t=>t()),n,s,(()=>0),1,a,"getClient")},"object"==typeof exports&&"undefined"!=typeof module?a(exports):"function"==typeof define&&define.amd?define(["exports"],a):a((t="undefined"!=typeof globalThis?globalThis:t||self).TinyBasePersisterLibsql={});
@@ -1 +1 @@
1
- var t,e;t=this,e=function(t){"use strict";const e=t=>typeof t,a="",s=e(a),n=t=>null==t,o=(t,e,a)=>n(t)?a?.():e(t),r=t=>e(t)==s,i=t=>Array.isArray(t),c=t=>t.length,d=t=>{throw Error(t)},l=(t,e)=>t.forEach(e),y=(t,...e)=>t.push(...e),u=t=>t.shift(),p=Object,h=t=>p.getPrototypeOf(t),f=p.keys,g=p.freeze,v=t=>(t=>!n(t)&&o(h(t),(t=>t==p.prototype||n(h(t))),(()=>!0)))(t)&&0==(t=>c(f(t)))(t),w=JSON.stringify,C=JSON.parse,S=t=>w(t,((t,e)=>e instanceof Map?p.fromEntries([...e]):e)),b="/store",P=t=>n(t)||0==(t=>t?.size??0)(t),m=(t,e)=>t?.forEach(e),A=(t,e)=>t?.delete(e),L=t=>new Map(t),M=(t,e)=>t?.get(e),T=(t,e,a)=>n(a)?(A(t,e),t):t?.set(e,a),E=(t,e,a,s)=>{var n,o;return n=t,o=e,n?.has(o)?s?.(M(t,e)):T(t,e,a()),M(t,e)},O=(t,e,a,s,n=0)=>o((a?E:M)(t,e[n],n>c(e)-2?a:L),(o=>{if(n>c(e)-2)return s?.(o)&&T(t,e[n]),o;const r=O(o,e,a,s,n+1);return P(o)&&T(t,e[n]),r})),x=t=>new Set(i(t)||n(t)?t:[t]),j=/^\d+$/,k=L(),z=L(),D=(t,e,s,r,p,h,f,w={},C=[])=>{let S,b,D,J=0,K=0,N=0;E(k,C,(()=>0)),E(z,C,(()=>[]));const B=L(),[F,U,W,$,q]=((t=1,e)=>1!=t&&e.isMergeable()?[1,e.getMergeableContent,e.getTransactionMergeableChanges,([[t],[e]])=>!v(t)||!v(e),e.setDefaultContent]:2!=t?[0,e.getContent,e.getTransactionChanges,([t,e])=>!v(t)||!v(e),e.setContent]:d("Store type not supported by this Persister"))(f,t),[G,H,I]=(()=>{let t;const[e,s]=(()=>{const t=[];let e=0;return[s=>(s?u(t):null)??a+e++,e=>{j.test(e)&&c(t)<1e3&&y(t,e)}]})(),r=L();return[(s,n,o,i=[],c=()=>[])=>{t??=tt;const d=e(1);var l,y;return T(r,d,[s,n,o,i,c]),l=O(n,o??[a],x),y=d,l?.add(y),d},(e,s,...n)=>l(((t,e=[a])=>{const s=[],n=(t,a)=>a==c(e)?y(s,t):null===e[a]?m(t,(t=>n(t,a+1))):l([e[a],null],(e=>n(M(t,e),a+1)));return n(t,0),s})(e,s),(e=>m(e,(e=>M(r,e)[0](t,...s??[],...n))))),t=>o(M(r,t),(([,e,n])=>(O(e,n??[a],void 0,(e=>(A(e,t),P(e)?1:0))),T(r,t),s(t),n))),e=>o(M(r,e),(([e,,a=[],s,o])=>{const r=(...i)=>{const d=c(i);d==c(a)?e(t,...i,...o(i)):n(a[d])?l(s[d]?.(...i)??[],(t=>r(...i,t))):r(...i,a[d])};r()}))]})(),Q=t=>{t!=J&&(J=t,H(B,void 0,J))},R=e=>{(F&&i(e?.[0])?1===e?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===e?.[2]?t.applyChanges:t.setContent)(e)},V=async t=>(2!=J&&(Q(1),K++,await _((async()=>{try{const t=await e();i(t)?R(t):d("Content is not an array "+t)}catch(e){h?.(e),t&&q(t)}Q(0)}))),tt),X=()=>(b&&(p(b),b=void 0),tt),Y=async t=>(1!=J&&(Q(2),N++,await _((async()=>{try{await s(U,t)}catch(t){h?.(t)}Q(0)}))),tt),Z=()=>(o(D,t.delListener),D=void 0,tt),_=async(...t)=>(y(M(z,C),...t),await(async()=>{if(!M(k,C)){for(T(k,C,1);!n(S=u(M(z,C)));)try{await S()}catch(t){h?.(t)}T(k,C,0)}})(),tt),tt={load:V,startAutoLoad:async t=>{await X().load(t);try{b=await r((async(t,e)=>{e||t?2!=J&&(Q(1),K++,R(e??t),Q(0)):await V()}))}catch(t){h?.(t)}return tt},stopAutoLoad:X,isAutoLoading:()=>!n(b),save:Y,startAutoSave:async()=>(await Z().save(),D=t.addDidFinishTransactionListener((()=>{const t=W();$(t)&&Y(t)})),tt),stopAutoSave:Z,isAutoSaving:()=>!n(D),getStatus:()=>J,addStatusListener:t=>G(t,B),delListener:e=>(I(e),t),schedule:_,getStore:()=>t,destroy:()=>(M(z,C).splice(0,void 0),X().stopAutoSave()),getStats:()=>({loads:K,saves:N}),...w};return g(tt)},J="message";t.createPartyKitPersister=(t,e,s,n)=>{const{host:i,room:d}=e.partySocketOptions,{storeProtocol:l="https",storePath:y=b,messagePrefix:u=a}={...r(s)?{storeProtocol:s}:s},p=l+"://"+i+"/parties/"+e.name+"/"+d+y,h=async t=>await(await fetch(p,{...t?{method:"PUT",body:S(t)}:{},mode:"cors",cache:"no-store"})).json();return D(t,(async()=>await h()),(async(t,a)=>{var s;a?e.send(u+"s"+(r(s=a)?s:S(s))):await h(t())}),(t=>{const a=e=>o(((t,e)=>{const a=c(t);return((t,e)=>t.startsWith(e))(e,t)?[e[a],C((s=e,n=a+1,s.slice(n,void 0)))]:void 0;var s,n})(u,e.data),(([e,a])=>{"s"==e&&t(void 0,a)}));return e.addEventListener(J,a),a}),(t=>{e.removeEventListener(J,t)}),n,1,{getConnection:()=>e})}},"object"==typeof exports&&"undefined"!=typeof module?e(exports):"function"==typeof define&&define.amd?define(["exports"],e):e((t="undefined"!=typeof globalThis?globalThis:t||self).TinyBasePersisterPartyKitClient={});
1
+ var t,e;t=this,e=function(t){"use strict";const e=t=>typeof t,a="",s=e(a),n=t=>null==t,o=(t,e,a)=>n(t)?a?.():e(t),r=t=>e(t)==s,i=t=>Array.isArray(t),c=t=>t.length,d=t=>{throw Error(t)},l=(t,e)=>t.forEach(e),y=(t,...e)=>t.push(...e),u=t=>t.shift(),p=Object,h=t=>p.getPrototypeOf(t),f=p.keys,g=p.freeze,v=t=>(t=>!n(t)&&o(h(t),(t=>t==p.prototype||n(h(t))),(()=>!0)))(t)&&0==(t=>c(f(t)))(t),w=JSON.stringify,C=JSON.parse,S=t=>w(t,((t,e)=>e instanceof Map?p.fromEntries([...e]):e)),b="/store",P=t=>n(t)||0==(t=>t?.size??0)(t),m=(t,e)=>t?.forEach(e),A=(t,e)=>t?.delete(e),L=t=>new Map(t),M=(t,e)=>t?.get(e),T=(t,e,a)=>n(a)?(A(t,e),t):t?.set(e,a),E=(t,e,a,s)=>{var n,o;return n=t,o=e,n?.has(o)?s?.(M(t,e)):T(t,e,a()),M(t,e)},O=(t,e,a,s,n=0)=>o((a?E:M)(t,e[n],n>c(e)-2?a:L),(o=>{if(n>c(e)-2)return s?.(o)&&T(t,e[n]),o;const r=O(o,e,a,s,n+1);return P(o)&&T(t,e[n]),r})),x=t=>new Set(i(t)||n(t)?t:[t]),j=/^\d+$/,k=L(),z=L(),D=(t,e,s,r,p,h,f,w={},C=[])=>{let S,b,D,J=0,K=0,N=0;E(k,C,(()=>0)),E(z,C,(()=>[]));const B=L(),[F,U,W,$,q]=((t=1,e)=>1!=t&&e.isMergeable()?[1,e.getMergeableContent,e.getTransactionMergeableChanges,([[t],[e]])=>!v(t)||!v(e),e.setDefaultContent]:2!=t?[0,e.getContent,e.getTransactionChanges,([t,e])=>!v(t)||!v(e),e.setContent]:d("Store type not supported by this Persister"))(f,t),[G,H,I]=(()=>{let t;const[e,s]=(()=>{const t=[];let e=0;return[s=>(s?u(t):null)??a+e++,e=>{j.test(e)&&c(t)<1e3&&y(t,e)}]})(),r=L();return[(s,n,o,i=[],c=()=>[])=>{t??=tt;const d=e(1);var l,y;return T(r,d,[s,n,o,i,c]),l=O(n,o??[a],x),y=d,l?.add(y),d},(e,s,...n)=>l(((t,e=[a])=>{const s=[],n=(t,a)=>a==c(e)?y(s,t):null===e[a]?m(t,(t=>n(t,a+1))):l([e[a],null],(e=>n(M(t,e),a+1)));return n(t,0),s})(e,s),(e=>m(e,(e=>M(r,e)[0](t,...s??[],...n))))),t=>o(M(r,t),(([,e,n])=>(O(e,n??[a],void 0,(e=>(A(e,t),P(e)?1:0))),T(r,t),s(t),n))),e=>o(M(r,e),(([e,,a=[],s,o])=>{const r=(...i)=>{const d=c(i);d==c(a)?e(t,...i,...o(i)):n(a[d])?l(s[d]?.(...i)??[],(t=>r(...i,t))):r(...i,a[d])};r()}))]})(),Q=t=>{t!=J&&(J=t,H(B,void 0,J))},R=e=>{(F&&i(e?.[0])?1===e?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===e?.[2]?t.applyChanges:t.setContent)(e)},V=async t=>(2!=J&&(Q(1),K++,await _((async()=>{try{const a=await e();i(a)?R(a):t?q(t):d("Content is not an array "+a)}catch(e){h?.(e),t&&q(t)}Q(0)}))),tt),X=()=>(b&&(p(b),b=void 0),tt),Y=async t=>(1!=J&&(Q(2),N++,await _((async()=>{try{await s(U,t)}catch(t){h?.(t)}Q(0)}))),tt),Z=()=>(o(D,t.delListener),D=void 0,tt),_=async(...t)=>(y(M(z,C),...t),await(async()=>{if(!M(k,C)){for(T(k,C,1);!n(S=u(M(z,C)));)try{await S()}catch(t){h?.(t)}T(k,C,0)}})(),tt),tt={load:V,startAutoLoad:async t=>{await X().load(t);try{b=await r((async(t,e)=>{e||t?2!=J&&(Q(1),K++,R(e??t),Q(0)):await V()}))}catch(t){h?.(t)}return tt},stopAutoLoad:X,isAutoLoading:()=>!n(b),save:Y,startAutoSave:async()=>(await Z().save(),D=t.addDidFinishTransactionListener((()=>{const t=W();$(t)&&Y(t)})),tt),stopAutoSave:Z,isAutoSaving:()=>!n(D),getStatus:()=>J,addStatusListener:t=>G(t,B),delListener:e=>(I(e),t),schedule:_,getStore:()=>t,destroy:()=>(M(z,C).splice(0,void 0),X().stopAutoSave()),getStats:()=>({loads:K,saves:N}),...w};return g(tt)},J="message";t.createPartyKitPersister=(t,e,s,n)=>{const{host:i,room:d}=e.partySocketOptions,{storeProtocol:l="https",storePath:y=b,messagePrefix:u=a}={...r(s)?{storeProtocol:s}:s},p=l+"://"+i+"/parties/"+e.name+"/"+d+y,h=async t=>await(await fetch(p,{...t?{method:"PUT",body:S(t)}:{},mode:"cors",cache:"no-store"})).json();return D(t,(async()=>await h()),(async(t,a)=>{var s;a?e.send(u+"s"+(r(s=a)?s:S(s))):await h(t())}),(t=>{const a=e=>o(((t,e)=>{const a=c(t);return((t,e)=>t.startsWith(e))(e,t)?[e[a],C((s=e,n=a+1,s.slice(n,void 0)))]:void 0;var s,n})(u,e.data),(([e,a])=>{"s"==e&&t(void 0,a)}));return e.addEventListener(J,a),a}),(t=>{e.removeEventListener(J,t)}),n,1,{getConnection:()=>e})}},"object"==typeof exports&&"undefined"!=typeof module?e(exports):"function"==typeof define&&define.amd?define(["exports"],e):e((t="undefined"!=typeof globalThis?globalThis:t||self).TinyBasePersisterPartyKitClient={});
@@ -1 +1 @@
1
- var t,e;t=this,e=function(t){"use strict";const e=t=>typeof t,a="",s=e(a),n=t=>null==t,o=(t,e,a)=>n(t)?a?.():e(t),r=t=>e(t)==s,i=t=>Array.isArray(t),c=t=>t.length,d=t=>{throw Error(t)},l=(t,e)=>t.forEach(e),y=(t,...e)=>t.push(...e),u=t=>t.shift(),p=Object,h=t=>p.getPrototypeOf(t),f=p.keys,g=p.freeze,v=t=>(t=>!n(t)&&o(h(t),(t=>t==p.prototype||n(h(t))),(()=>!0)))(t)&&0==(t=>c(f(t)))(t),w=JSON.stringify,C=JSON.parse,S=t=>w(t,((t,e)=>e instanceof Map?p.fromEntries([...e]):e)),b="/store",P=t=>n(t)||0==(t=>t?.size??0)(t),m=(t,e)=>t?.forEach(e),A=(t,e)=>t?.delete(e),L=t=>new Map(t),M=(t,e)=>t?.get(e),T=(t,e,a)=>n(a)?(A(t,e),t):t?.set(e,a),E=(t,e,a,s)=>{var n,o;return n=t,o=e,n?.has(o)?s?.(M(t,e)):T(t,e,a()),M(t,e)},O=(t,e,a,s,n=0)=>o((a?E:M)(t,e[n],n>c(e)-2?a:L),(o=>{if(n>c(e)-2)return s?.(o)&&T(t,e[n]),o;const r=O(o,e,a,s,n+1);return P(o)&&T(t,e[n]),r})),x=t=>new Set(i(t)||n(t)?t:[t]),j=/^\d+$/,k=L(),z=L(),D=(t,e,s,r,p,h,f,w={},C=[])=>{let S,b,D,J=0,K=0,N=0;E(k,C,(()=>0)),E(z,C,(()=>[]));const B=L(),[F,U,W,$,q]=((t=1,e)=>1!=t&&e.isMergeable()?[1,e.getMergeableContent,e.getTransactionMergeableChanges,([[t],[e]])=>!v(t)||!v(e),e.setDefaultContent]:2!=t?[0,e.getContent,e.getTransactionChanges,([t,e])=>!v(t)||!v(e),e.setContent]:d("Store type not supported by this Persister"))(f,t),[G,H,I]=(()=>{let t;const[e,s]=(()=>{const t=[];let e=0;return[s=>(s?u(t):null)??a+e++,e=>{j.test(e)&&c(t)<1e3&&y(t,e)}]})(),r=L();return[(s,n,o,i=[],c=()=>[])=>{t??=tt;const d=e(1);var l,y;return T(r,d,[s,n,o,i,c]),l=O(n,o??[a],x),y=d,l?.add(y),d},(e,s,...n)=>l(((t,e=[a])=>{const s=[],n=(t,a)=>a==c(e)?y(s,t):null===e[a]?m(t,(t=>n(t,a+1))):l([e[a],null],(e=>n(M(t,e),a+1)));return n(t,0),s})(e,s),(e=>m(e,(e=>M(r,e)[0](t,...s??[],...n))))),t=>o(M(r,t),(([,e,n])=>(O(e,n??[a],void 0,(e=>(A(e,t),P(e)?1:0))),T(r,t),s(t),n))),e=>o(M(r,e),(([e,,a=[],s,o])=>{const r=(...i)=>{const d=c(i);d==c(a)?e(t,...i,...o(i)):n(a[d])?l(s[d]?.(...i)??[],(t=>r(...i,t))):r(...i,a[d])};r()}))]})(),Q=t=>{t!=J&&(J=t,H(B,void 0,J))},R=e=>{(F&&i(e?.[0])?1===e?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===e?.[2]?t.applyChanges:t.setContent)(e)},V=async t=>(2!=J&&(Q(1),K++,await _((async()=>{try{const t=await e();i(t)?R(t):d("Content is not an array "+t)}catch(e){h?.(e),t&&q(t)}Q(0)}))),tt),X=()=>(b&&(p(b),b=void 0),tt),Y=async t=>(1!=J&&(Q(2),N++,await _((async()=>{try{await s(U,t)}catch(t){h?.(t)}Q(0)}))),tt),Z=()=>(o(D,t.delListener),D=void 0,tt),_=async(...t)=>(y(M(z,C),...t),await(async()=>{if(!M(k,C)){for(T(k,C,1);!n(S=u(M(z,C)));)try{await S()}catch(t){h?.(t)}T(k,C,0)}})(),tt),tt={load:V,startAutoLoad:async t=>{await X().load(t);try{b=await r((async(t,e)=>{e||t?2!=J&&(Q(1),K++,R(e??t),Q(0)):await V()}))}catch(t){h?.(t)}return tt},stopAutoLoad:X,isAutoLoading:()=>!n(b),save:Y,startAutoSave:async()=>(await Z().save(),D=t.addDidFinishTransactionListener((()=>{const t=W();$(t)&&Y(t)})),tt),stopAutoSave:Z,isAutoSaving:()=>!n(D),getStatus:()=>J,addStatusListener:t=>G(t,B),delListener:e=>(I(e),t),schedule:_,getStore:()=>t,destroy:()=>(M(z,C).splice(0,void 0),X().stopAutoSave()),getStats:()=>({loads:K,saves:N}),...w};return g(tt)},J="message";t.createPartyKitPersister=(t,e,s,n)=>{const{host:i,room:d}=e.partySocketOptions,{storeProtocol:l="https",storePath:y=b,messagePrefix:u=a}={...r(s)?{storeProtocol:s}:s},p=l+"://"+i+"/parties/"+e.name+"/"+d+y,h=async t=>await(await fetch(p,{...t?{method:"PUT",body:S(t)}:{},mode:"cors",cache:"no-store"})).json();return D(t,(async()=>await h()),(async(t,a)=>{var s;a?e.send(u+"s"+(r(s=a)?s:S(s))):await h(t())}),(t=>{const a=e=>o(((t,e)=>{const a=c(t);return((t,e)=>t.startsWith(e))(e,t)?[e[a],C((s=e,n=a+1,s.slice(n,void 0)))]:void 0;var s,n})(u,e.data),(([e,a])=>{"s"==e&&t(void 0,a)}));return e.addEventListener(J,a),a}),(t=>{e.removeEventListener(J,t)}),n,1,{getConnection:()=>e})}},"object"==typeof exports&&"undefined"!=typeof module?e(exports):"function"==typeof define&&define.amd?define(["exports"],e):e((t="undefined"!=typeof globalThis?globalThis:t||self).TinyBasePersisterPartyKitClient={});
1
+ var t,e;t=this,e=function(t){"use strict";const e=t=>typeof t,a="",s=e(a),n=t=>null==t,o=(t,e,a)=>n(t)?a?.():e(t),r=t=>e(t)==s,i=t=>Array.isArray(t),c=t=>t.length,d=t=>{throw Error(t)},l=(t,e)=>t.forEach(e),y=(t,...e)=>t.push(...e),u=t=>t.shift(),p=Object,h=t=>p.getPrototypeOf(t),f=p.keys,g=p.freeze,v=t=>(t=>!n(t)&&o(h(t),(t=>t==p.prototype||n(h(t))),(()=>!0)))(t)&&0==(t=>c(f(t)))(t),w=JSON.stringify,C=JSON.parse,S=t=>w(t,((t,e)=>e instanceof Map?p.fromEntries([...e]):e)),b="/store",P=t=>n(t)||0==(t=>t?.size??0)(t),m=(t,e)=>t?.forEach(e),A=(t,e)=>t?.delete(e),L=t=>new Map(t),M=(t,e)=>t?.get(e),T=(t,e,a)=>n(a)?(A(t,e),t):t?.set(e,a),E=(t,e,a,s)=>{var n,o;return n=t,o=e,n?.has(o)?s?.(M(t,e)):T(t,e,a()),M(t,e)},O=(t,e,a,s,n=0)=>o((a?E:M)(t,e[n],n>c(e)-2?a:L),(o=>{if(n>c(e)-2)return s?.(o)&&T(t,e[n]),o;const r=O(o,e,a,s,n+1);return P(o)&&T(t,e[n]),r})),x=t=>new Set(i(t)||n(t)?t:[t]),j=/^\d+$/,k=L(),z=L(),D=(t,e,s,r,p,h,f,w={},C=[])=>{let S,b,D,J=0,K=0,N=0;E(k,C,(()=>0)),E(z,C,(()=>[]));const B=L(),[F,U,W,$,q]=((t=1,e)=>1!=t&&e.isMergeable()?[1,e.getMergeableContent,e.getTransactionMergeableChanges,([[t],[e]])=>!v(t)||!v(e),e.setDefaultContent]:2!=t?[0,e.getContent,e.getTransactionChanges,([t,e])=>!v(t)||!v(e),e.setContent]:d("Store type not supported by this Persister"))(f,t),[G,H,I]=(()=>{let t;const[e,s]=(()=>{const t=[];let e=0;return[s=>(s?u(t):null)??a+e++,e=>{j.test(e)&&c(t)<1e3&&y(t,e)}]})(),r=L();return[(s,n,o,i=[],c=()=>[])=>{t??=tt;const d=e(1);var l,y;return T(r,d,[s,n,o,i,c]),l=O(n,o??[a],x),y=d,l?.add(y),d},(e,s,...n)=>l(((t,e=[a])=>{const s=[],n=(t,a)=>a==c(e)?y(s,t):null===e[a]?m(t,(t=>n(t,a+1))):l([e[a],null],(e=>n(M(t,e),a+1)));return n(t,0),s})(e,s),(e=>m(e,(e=>M(r,e)[0](t,...s??[],...n))))),t=>o(M(r,t),(([,e,n])=>(O(e,n??[a],void 0,(e=>(A(e,t),P(e)?1:0))),T(r,t),s(t),n))),e=>o(M(r,e),(([e,,a=[],s,o])=>{const r=(...i)=>{const d=c(i);d==c(a)?e(t,...i,...o(i)):n(a[d])?l(s[d]?.(...i)??[],(t=>r(...i,t))):r(...i,a[d])};r()}))]})(),Q=t=>{t!=J&&(J=t,H(B,void 0,J))},R=e=>{(F&&i(e?.[0])?1===e?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===e?.[2]?t.applyChanges:t.setContent)(e)},V=async t=>(2!=J&&(Q(1),K++,await _((async()=>{try{const a=await e();i(a)?R(a):t?q(t):d("Content is not an array "+a)}catch(e){h?.(e),t&&q(t)}Q(0)}))),tt),X=()=>(b&&(p(b),b=void 0),tt),Y=async t=>(1!=J&&(Q(2),N++,await _((async()=>{try{await s(U,t)}catch(t){h?.(t)}Q(0)}))),tt),Z=()=>(o(D,t.delListener),D=void 0,tt),_=async(...t)=>(y(M(z,C),...t),await(async()=>{if(!M(k,C)){for(T(k,C,1);!n(S=u(M(z,C)));)try{await S()}catch(t){h?.(t)}T(k,C,0)}})(),tt),tt={load:V,startAutoLoad:async t=>{await X().load(t);try{b=await r((async(t,e)=>{e||t?2!=J&&(Q(1),K++,R(e??t),Q(0)):await V()}))}catch(t){h?.(t)}return tt},stopAutoLoad:X,isAutoLoading:()=>!n(b),save:Y,startAutoSave:async()=>(await Z().save(),D=t.addDidFinishTransactionListener((()=>{const t=W();$(t)&&Y(t)})),tt),stopAutoSave:Z,isAutoSaving:()=>!n(D),getStatus:()=>J,addStatusListener:t=>G(t,B),delListener:e=>(I(e),t),schedule:_,getStore:()=>t,destroy:()=>(M(z,C).splice(0,void 0),X().stopAutoSave()),getStats:()=>({loads:K,saves:N}),...w};return g(tt)},J="message";t.createPartyKitPersister=(t,e,s,n)=>{const{host:i,room:d}=e.partySocketOptions,{storeProtocol:l="https",storePath:y=b,messagePrefix:u=a}={...r(s)?{storeProtocol:s}:s},p=l+"://"+i+"/parties/"+e.name+"/"+d+y,h=async t=>await(await fetch(p,{...t?{method:"PUT",body:S(t)}:{},mode:"cors",cache:"no-store"})).json();return D(t,(async()=>await h()),(async(t,a)=>{var s;a?e.send(u+"s"+(r(s=a)?s:S(s))):await h(t())}),(t=>{const a=e=>o(((t,e)=>{const a=c(t);return((t,e)=>t.startsWith(e))(e,t)?[e[a],C((s=e,n=a+1,s.slice(n,void 0)))]:void 0;var s,n})(u,e.data),(([e,a])=>{"s"==e&&t(void 0,a)}));return e.addEventListener(J,a),a}),(t=>{e.removeEventListener(J,t)}),n,1,{getConnection:()=>e})}},"object"==typeof exports&&"undefined"!=typeof module?e(exports):"function"==typeof define&&define.amd?define(["exports"],e):e((t="undefined"!=typeof globalThis?globalThis:t||self).TinyBasePersisterPartyKitClient={});
@@ -1 +1 @@
1
- var t,a;t=this,a=function(t){"use strict";const a=t=>typeof t,e="tinybase",n="",s=",",i=a(n),r=Promise,o=t=>null==t,c=(t,a,e)=>o(t)?e?.():a(t),l=t=>a(t)==i,E=t=>Array.isArray(t),y=(t,a,e)=>t.slice(a,e),w=t=>t.length,d=async t=>r.all(t),u=t=>{throw Error(t)},T=(t,a)=>N(Array(t).fill(0),((t,e)=>a(e))),R=(t,a)=>t.forEach(a),A=(t,a="")=>t.join(a),N=(t,a)=>t.map(a),g=t=>0==w(t),p=(t,a)=>t.filter(a),C=(t,...a)=>t.push(...a),O=t=>t.shift(),f="_",L="_id",v="SELECT",$="WHERE",m="TABLE",I="ALTER "+m,S="DELETE FROM",h=v+"*FROM",_=t=>`"${t.replace(/"/g,'""')}"`,b=t=>A(N(t,((t,a)=>"$"+(a+1))),s),P=(t,a)=>t?.has(a)??!1,D=t=>o(t)||0==(t=>t?.size??0)(t),U=t=>[...t?.values()??[]],F=(t,a)=>t?.forEach(a),M=(t,a)=>t?.delete(a),G=Object,B=t=>G.getPrototypeOf(t),j=G.entries,x=G.keys,X=G.freeze,Y=(t=[])=>G.fromEntries(t),q=(...t)=>G.assign({},...t),H=(t,a)=>(delete t[a],t),W=(t,a)=>N(j(t),(([t,e])=>a(e,t))),k=t=>G.values(t),z=t=>w(x(t)),J=t=>(t=>!o(t)&&c(B(t),(t=>t==G.prototype||o(B(t))),(()=>!0)))(t)&&0==z(t),K=JSON.stringify,V=JSON.parse,Q=t=>new Map(t),Z=(t,a)=>t?.get(a),tt=(t,a)=>N([...t?.entries()??[]],(([t,e])=>a(e,t))),at=(t,a,e)=>o(e)?(M(t,a),t):t?.set(a,e),et=(t,a,e,n)=>(P(t,a)?n?.(Z(t,a)):at(t,a,e()),Z(t,a)),nt=(t,a,e,n,s=0)=>c((e?et:Z)(t,a[s],s>w(a)-2?e:Q),(i=>{if(s>w(a)-2)return n?.(i)&&at(t,a[s]),i;const r=nt(i,a,e,n,s+1);return D(i)&&at(t,a[s]),r})),st=t=>new Set(E(t)||o(t)?t:[t]),it=(t,a)=>t?.add(a),rt=/^\d+$/,ot=Q(),ct=Q(),lt=(t,a,e,s,i,r,l,y={},d=[])=>{let T,A,N,g=0,p=0,f=0;et(ot,d,(()=>0)),et(ct,d,(()=>[]));const L=Q(),[v,$,m,I,S]=((t=1,a)=>1!=t&&a.isMergeable()?[1,a.getMergeableContent,a.getTransactionMergeableChanges,([[t],[a]])=>!J(t)||!J(a),a.setDefaultContent]:2!=t?[0,a.getContent,a.getTransactionChanges,([t,a])=>!J(t)||!J(a),a.setContent]:u("Store type not supported by this Persister"))(l,t),[h,_,b]=(()=>{let t;const[a,e]=(()=>{const t=[];let a=0;return[e=>(e?O(t):null)??n+a++,a=>{rt.test(a)&&w(t)<1e3&&C(t,a)}]})(),s=Q();return[(e,i,r,o=[],c=()=>[])=>{t??=q;const l=a(1);return at(s,l,[e,i,r,o,c]),it(nt(i,r??[n],st),l),l},(a,e,...i)=>R(((t,a=[n])=>{const e=[],s=(t,n)=>n==w(a)?C(e,t):null===a[n]?F(t,(t=>s(t,n+1))):R([a[n],null],(a=>s(Z(t,a),n+1)));return s(t,0),e})(a,e),(a=>F(a,(a=>Z(s,a)[0](t,...e??[],...i))))),t=>c(Z(s,t),(([,a,i])=>(nt(a,i??[n],void 0,(a=>(M(a,t),D(a)?1:0))),at(s,t),e(t),i))),a=>c(Z(s,a),(([a,,e=[],n,s])=>{const i=(...r)=>{const c=w(r);c==w(e)?a(t,...r,...s(r)):o(e[c])?R(n[c]?.(...r)??[],(t=>i(...r,t))):i(...r,e[c])};i()}))]})(),P=t=>{t!=g&&(g=t,_(L,void 0,g))},U=a=>{(v&&E(a?.[0])?1===a?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===a?.[2]?t.applyChanges:t.setContent)(a)},G=async t=>(2!=g&&(P(1),p++,await Y((async()=>{try{const t=await a();E(t)?U(t):u("Content is not an array "+t)}catch(a){r?.(a),t&&S(t)}P(0)}))),q),B=()=>(A&&(i(A),A=void 0),q),j=async t=>(1!=g&&(P(2),f++,await Y((async()=>{try{await e($,t)}catch(t){r?.(t)}P(0)}))),q),x=()=>(c(N,t.delListener),N=void 0,q),Y=async(...t)=>(C(Z(ct,d),...t),await(async()=>{if(!Z(ot,d)){for(at(ot,d,1);!o(T=O(Z(ct,d)));)try{await T()}catch(t){r?.(t)}at(ot,d,0)}})(),q),q={load:G,startAutoLoad:async t=>{await B().load(t);try{A=await s((async(t,a)=>{a||t?2!=g&&(P(1),p++,U(a??t),P(0)):await G()}))}catch(t){r?.(t)}return q},stopAutoLoad:B,isAutoLoading:()=>!o(A),save:j,startAutoSave:async()=>(await x().save(),N=t.addDidFinishTransactionListener((()=>{const t=m();I(t)&&j(t)})),q),stopAutoSave:x,isAutoSaving:()=>!o(N),getStatus:()=>g,addStatusListener:t=>h(t,L),delListener:a=>(b(a),t),schedule:Y,getStore:()=>t,destroy:()=>(Z(ct,d).splice(0,void 0),B().stopAutoSave()),getStats:()=>({loads:p,saves:f}),...y};return X(q)},Et=(t,a,e,n,i,r,c,l)=>{const E=Q();return[async()=>{E.clear(),N(await e(t,a),(({tn:t,cn:a})=>it(et(E,t,st),a)))},async(a,e)=>((t,a)=>P(Z(E,t),a))(a,e)?Y(p(N(await t(h+_(a)),(t=>{return[t[e],l?(a=H(t,e),n=l,Y(W(a,((t,a)=>[a,n(t,a)])))):H(t,e)];var a,n})),(([t,a])=>!o(t)&&!J(a)))):{},async(a,e,n,l,y,w=!1)=>{const u=st();W(n??{},(t=>N(x(t??{}),(t=>it(u,t)))));const T=U(u);if(!w&&y&&g(T)&&P(E,a))return await t("DROP "+m+_(a)),void at(E,a);const R=Z(E,a),O=st(U(R));if(g(T)||(P(E,a)?await d(N([e,...T],(async(n,s)=>{M(O,n)||(await t(I+_(a)+"ADD"+_(n)+i),0==s&&await t("CREATE UNIQUE INDEX pk ON "+_(a)+`(${_(e)})`),it(R,n))}))):(await t("CREATE "+m+_(a)+`(${_(e)}${i} PRIMARY KEY${A(N(T,(t=>s+_(t)+i)))});`),at(E,a,st([e,...T])))),await d([...!w&&l?N(U(O),(async n=>{n!=e&&(await t(I+_(a)+"DROP"+_(n)),M(R,n))})):[]]),w)o(n)?await t(S+_(a)+$+" true"):await d(W(n,(async(n,s)=>{o(n)?await t(S+_(a)+$+_(e)+"=$1",[s]):g(T)||await yt(t,a,e,x(n),[s,...c?N(k(n),c):k(n)],r)})));else if(g(T))P(E,a)&&await t(S+_(a)+$+" true");else{const s=p(U(Z(E,a)),(t=>t!=e)),i=[],o=[];W(n??{},((t,a)=>{C(i,a,...N(s,(a=>c?c(t?.[a]):t?.[a]))),C(o,a)})),await yt(t,a,e,s,i,r),await t(S+_(a)+$+_(e)+`NOT IN(${b(o)})`,o)}},async a=>{let e;await t("BEGIN");try{e=await a()}catch(t){n?.(t)}return await t("END"),e}]},yt=async(t,a,e,i,r,o=0)=>await t("INSERT "+(o?"OR REPLACE ":n)+"INTO"+_(a)+"("+_(e)+A(N(i,(t=>s+_(t))))+")VALUES"+wt(r,w(i)+1)+(o?n:"ON CONFLICT("+_(e)+")DO UPDATE SET"+A(N(i,(t=>_(t)+"=excluded."+_(t))),s)),N(r,(t=>t??null))),wt=(t,a)=>A(T(w(t)/a,(t=>"("+A(T(a,(e=>"$"+(t*a+e+1))),s)+")")),s),dt=(t,a,e,n,s,i,r,[o,c,l],E,y,w,d,u,T)=>{const[R,A,N,g]=Et(a,E,y,s,u,T),p=lt(t,(async()=>await g((async()=>{return await R(),t=(await A(o,c))[f]?.[l]??"null",V(t,((t,a)=>""===a?void 0:a));var t}))),(async t=>await g((async()=>{var a;await R(),await N(o,c,{[f]:{[l]:(a=t()??null,K(a,((t,a)=>void 0===a?"":a)))}},!0,!0)}))),e,n,s,r,{[d]:()=>w,destroy:()=>(p.stopAutoLoad().stopAutoSave(),i(),p)},w);return p},ut=(t,a,e,n,s,i,r,[c,l,[E,y,w]],u,T,R,A,N,g,C,O)=>{const[v,$,m,I]=Et(a,u,T,s,N,g,C,O),S=async(t,a)=>await d(tt(l,(async([e,n,s,i],r)=>{a&&!(r in t)||await m(e,n,t[r],s,i,a)}))),h=async(t,a)=>y?await m(w,L,{[f]:t},!0,!0,a):null,_=lt(t,(async()=>await I((async()=>{await v();const t=await(async()=>Y(p(await d(tt(c,(async([t,a],e)=>[t,await $(e,a)]))),(t=>!J(t[1])))))(),a=await(async()=>E?(await $(w,L))[f]:{})();return J(t)&&o(a)?void 0:[t,a]}))),(async(t,a)=>await I((async()=>{if(await v(),o(a)){const[a,e]=t();await S(a),await h(e)}else await S(a[0],!0),await h(a[1],!0)}))),e,n,s,r,{[A]:()=>R,destroy:()=>(_.stopAutoLoad().stopAutoSave(),i(),_)},R);return _},Tt="ColumnName",Rt="store",At="json",Nt=Rt+"TableName",gt=Rt+"Id"+Tt,pt=Rt+Tt,Ct="autoLoadIntervalSeconds",Ot="rowId"+Tt,ft="tableId",Lt="tableName",vt="deleteEmptyColumns",$t="deleteEmptyTable",mt={mode:At,[Ct]:1},It={load:0,save:0,[Lt]:e+"_values"},St=(t,a,e,n,s)=>{const i=Q();return W(t,((t,r)=>{const c=y(k(q(a,l(t)?{[e]:t}:t)),0,z(a));o(c[0])||n(r,c[0])||(s(r,c[0]),at(i,r,c))})),i},ht=e,_t=/^([cd]:)(.+)/,bt=e+"_data",Pt=e+"_table";t.createPglitePersister=async(t,a,n,s,i)=>((t,a,n,s,i,r,o,E,w,u,T="getDb")=>{const R=((t,a)=>a?async(e,n)=>(a(e,n),await t(e,n)):t)(n,r),[A,,g,p]=(t=>{const a=(t=>q(mt,l(t)?{[Nt]:t}:t??{}))(t),n=a[Ct];if(a.mode==At){const t=a[Nt]??e;return[1,n,[t,a[gt]??L,a[pt]??Rt],st(t)]}const{tables:{load:s={},save:i={}}={},values:r={}}=a,o=y(k(q(It,r)),0,z(It)),c=o[2],E=st(c),w=st(c);return[0,n,[St(s,{[ft]:null,[Ot]:L},ft,(t=>P(w,t)),(t=>it(E,t))),St(i,{[Lt]:null,[Ot]:L,[vt]:0,[$t]:0},Lt,((t,a)=>P(w,a)),((t,a)=>it(E,a))),o],E]})(a),C=async t=>{await R(`CREATE OR REPLACE TRIGGER ${_(bt+"_"+t)} AFTER INSERT OR UPDATE OR DELETE ON ${_(t)} EXECUTE FUNCTION ${bt}()`)};return(A?dt:ut)(t,R,(async t=>{await R(`CREATE OR REPLACE FUNCTION ${Pt}()RETURNS event_trigger AS $t2$ DECLARE row record; BEGIN FOR row IN SELECT object_identity FROM pg_event_trigger_ddl_commands()WHERE command_tag='CREATE TABLE' LOOP PERFORM pg_notify('${ht}','c:'||SPLIT_PART(row.object_identity,'.',2));END LOOP;END;$t2$ LANGUAGE plpgsql;`);try{await R(`CREATE EVENT TRIGGER ${Pt} ON ddl_command_end WHEN TAG IN('CREATE TABLE')EXECUTE FUNCTION ${Pt}();`)}catch{}return await R(`CREATE OR REPLACE FUNCTION ${bt}()RETURNS trigger AS $t1$ BEGIN PERFORM pg_notify('${ht}','d:'||TG_TABLE_NAME);RETURN NULL;END;$t1$ LANGUAGE plpgsql;`),await d(N(U(p),(async t=>{await R(`CREATE TABLE IF NOT EXISTS ${_(t)}("_id"text PRIMARY KEY)`),await C(t)}))),await s(ht,(async a=>{return await c((e=a,n=_t,e?.match(n)),(async([,a,e])=>{P(p,e)&&("c:"==a&&await C(e),t())}));var e,n}))}),i,o,E,w,g,U(p),(async(t,a)=>await t(`${v} table_name tn,column_name cn FROM information_schema.columns ${$} table_schema='public'AND table_name IN(${b(a)})`,a)),u,T,"text",0,(t=>K(t)),(t=>V(t)))})(t,n,(async(t,e=[])=>(await a.query(t,e)).rows),(async(t,e)=>await a.listen(t,e)),(async t=>{try{await t()}catch(t){i?.(t)}}),s,i,(()=>0),3,a,"getPglite")},"object"==typeof exports&&"undefined"!=typeof module?a(exports):"function"==typeof define&&define.amd?define(["exports"],a):a((t="undefined"!=typeof globalThis?globalThis:t||self).TinyBasePersisterPglite={});
1
+ var t,a;t=this,a=function(t){"use strict";const a=t=>typeof t,e="tinybase",n=",",s=a(""),i=Promise,o=t=>null==t,r=(t,a,e)=>o(t)?e?.():a(t),c=t=>a(t)==s,l=t=>Array.isArray(t),E=(t,a,e)=>t.slice(a,e),y=t=>t.length,w=async t=>i.all(t),d=t=>{throw Error(t)},u=(t,a)=>t.forEach(a),T=(t,a="")=>t.join(a),R=(t,a)=>t.map(a),A=t=>0==y(t),N=(t,a)=>t.filter(a),g=(t,...a)=>t.push(...a),p=t=>t.shift(),C="_",O="_id",f="SELECT",v="WHERE",L="TABLE",$="ALTER "+L,m="DELETE FROM",I=f+"*FROM",S=t=>`"${t.replace(/"/g,'""')}"`,h=(t,a=[1])=>T(R(t,(()=>"$"+a[0]++)),n),_=(t,a)=>t?.has(a)??!1,b=t=>o(t)||0==(t=>t?.size??0)(t),P=t=>[...t?.values()??[]],D=(t,a)=>t?.forEach(a),U=(t,a)=>t?.delete(a),F=Object,M=t=>F.getPrototypeOf(t),G=F.entries,B=F.keys,j=F.freeze,x=(t=[])=>F.fromEntries(t),X=(...t)=>F.assign({},...t),Y=(t,a)=>(delete t[a],t),q=(t,a)=>R(G(t),(([t,e])=>a(e,t))),H=t=>F.values(t),W=t=>y(B(t)),k=t=>(t=>!o(t)&&r(M(t),(t=>t==F.prototype||o(M(t))),(()=>!0)))(t)&&0==W(t),z=JSON.stringify,J=JSON.parse,K=t=>new Map(t),V=(t,a)=>t?.get(a),Q=(t,a)=>R([...t?.entries()??[]],(([t,e])=>a(e,t))),Z=(t,a,e)=>o(e)?(U(t,a),t):t?.set(a,e),tt=(t,a,e,n)=>(_(t,a)?n?.(V(t,a)):Z(t,a,e()),V(t,a)),at=(t,a,e,n,s=0)=>r((e?tt:V)(t,a[s],s>y(a)-2?e:K),(i=>{if(s>y(a)-2)return n?.(i)&&Z(t,a[s]),i;const o=at(i,a,e,n,s+1);return b(i)&&Z(t,a[s]),o})),et=t=>new Set(l(t)||o(t)?t:[t]),nt=(t,a)=>t?.add(a),st=/^\d+$/,it=K(),ot=K(),rt=(t,a,e,n,s,i,c,E={},w=[])=>{let T,R,A,N=0,C=0,O=0;tt(it,w,(()=>0)),tt(ot,w,(()=>[]));const f=K(),[v,L,$,m,I]=((t=1,a)=>1!=t&&a.isMergeable()?[1,a.getMergeableContent,a.getTransactionMergeableChanges,([[t],[a]])=>!k(t)||!k(a),a.setDefaultContent]:2!=t?[0,a.getContent,a.getTransactionChanges,([t,a])=>!k(t)||!k(a),a.setContent]:d("Store type not supported by this Persister"))(c,t),[S,h,_]=(()=>{let t;const[a,e]=(()=>{const t=[];let a=0;return[e=>(e?p(t):null)??""+a++,a=>{st.test(a)&&y(t)<1e3&&g(t,a)}]})(),n=K();return[(e,s,i,o=[],r=()=>[])=>{t??=Y;const c=a(1);return Z(n,c,[e,s,i,o,r]),nt(at(s,i??[""],et),c),c},(a,e,...s)=>u(((t,a=[""])=>{const e=[],n=(t,s)=>s==y(a)?g(e,t):null===a[s]?D(t,(t=>n(t,s+1))):u([a[s],null],(a=>n(V(t,a),s+1)));return n(t,0),e})(a,e),(a=>D(a,(a=>V(n,a)[0](t,...e??[],...s))))),t=>r(V(n,t),(([,a,s])=>(at(a,s??[""],void 0,(a=>(U(a,t),b(a)?1:0))),Z(n,t),e(t),s))),a=>r(V(n,a),(([a,,e=[],n,s])=>{const i=(...r)=>{const c=y(r);c==y(e)?a(t,...r,...s(r)):o(e[c])?u(n[c]?.(...r)??[],(t=>i(...r,t))):i(...r,e[c])};i()}))]})(),P=t=>{t!=N&&(N=t,h(f,void 0,N))},F=a=>{(v&&l(a?.[0])?1===a?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===a?.[2]?t.applyChanges:t.setContent)(a)},M=async t=>(2!=N&&(P(1),C++,await X((async()=>{try{const e=await a();l(e)?F(e):t?I(t):d("Content is not an array "+e)}catch(a){i?.(a),t&&I(t)}P(0)}))),Y),G=()=>(R&&(s(R),R=void 0),Y),B=async t=>(1!=N&&(P(2),O++,await X((async()=>{try{await e(L,t)}catch(t){i?.(t)}P(0)}))),Y),x=()=>(r(A,t.delListener),A=void 0,Y),X=async(...t)=>(g(V(ot,w),...t),await(async()=>{if(!V(it,w)){for(Z(it,w,1);!o(T=p(V(ot,w)));)try{await T()}catch(t){i?.(t)}Z(it,w,0)}})(),Y),Y={load:M,startAutoLoad:async t=>{await G().load(t);try{R=await n((async(t,a)=>{a||t?2!=N&&(P(1),C++,F(a??t),P(0)):await M()}))}catch(t){i?.(t)}return Y},stopAutoLoad:G,isAutoLoading:()=>!o(R),save:B,startAutoSave:async()=>(await x().save(),A=t.addDidFinishTransactionListener((()=>{const t=$();m(t)&&B(t)})),Y),stopAutoSave:x,isAutoSaving:()=>!o(A),getStatus:()=>N,addStatusListener:t=>S(t,f),delListener:a=>(_(a),t),schedule:X,getStore:()=>t,destroy:()=>(V(ot,w).splice(0,void 0),G().stopAutoSave()),getStats:()=>({loads:C,saves:O}),...E};return j(Y)},ct=(t,a,e,s,i,r=lt,c,l)=>{const E=K();return[async()=>{E.clear(),R(await e(t,a),(({tn:t,cn:a})=>nt(tt(E,t,et),a)))},async(a,e)=>((t,a)=>_(V(E,t),a))(a,e)?x(N(R(await t(I+S(a)),(t=>{return[t[e],l?(a=Y(t,e),n=l,x(q(a,((t,a)=>[a,n(t,a)])))):Y(t,e)];var a,n})),(([t,a])=>!o(t)&&!k(a)))):{},async(a,e,s,l,y,d=!1)=>{const u=et();q(s??{},(t=>R(B(t??{}),(t=>nt(u,t)))));const p=P(u);if(!d&&y&&A(p)&&_(E,a))return await t("DROP "+L+S(a)),void Z(E,a);const C=V(E,a),O=et(P(C));if(A(p)||(_(E,a)?await w(R([e,...p],(async(n,s)=>{U(O,n)||(await t($+S(a)+"ADD"+S(n)+i),0==s&&await t("CREATE UNIQUE INDEX pk ON "+S(a)+`(${S(e)})`),nt(C,n))}))):(await t("CREATE "+L+S(a)+`(${S(e)}${i} PRIMARY KEY${T(R(p,(t=>n+S(t)+i)))});`),Z(E,a,et([e,...p])))),await w([...!d&&l?R(P(O),(async n=>{n!=e&&(await t($+S(a)+"DROP"+S(n)),U(C,n))})):[]]),d)o(s)?await t(m+S(a)+v+" true"):await w(q(s,(async(n,s)=>{o(n)?await t(m+S(a)+v+S(e)+"=$1",[s]):A(p)||await r(t,a,e,B(n),{[s]:c?R(H(n),c):H(n)},C)})));else if(A(p))_(E,a)&&await t(m+S(a)+v+" true");else{const n=N(P(V(E,a)),(t=>t!=e)),i={},o=[];q(s??{},((t,a)=>{i[a]=R(n,(a=>c?c(t?.[a]):t?.[a])),g(o,a)})),await r(t,a,e,n,i),await t(m+S(a)+v+S(e)+`NOT IN(${h(o)})`,o)}},async a=>{let e;await t("BEGIN");try{e=await a()}catch(t){s?.(t)}return await t("END"),e}]},lt=async(t,a,e,s,i)=>{const o=[1];await t("INSERT INTO"+S(a)+"("+((...t)=>T(R(t,S),n))(e,...s)+")VALUES"+T(q(i,(t=>"($"+o[0]+++","+h(t,o)+")")),n)+"ON CONFLICT("+S(e)+")DO UPDATE SET"+T(R(s,(t=>S(t)+"=excluded."+S(t))),n),q(i,((t,a)=>[a,...R(t,(t=>t??null))])).flat())},Et=(t,a,e,n,s,i,o,[r,c,l],E,y,w,d,u,T)=>{const[R,A,N,g]=ct(a,E,y,s,u,T),p=rt(t,(async()=>await g((async()=>{return await R(),t=(await A(r,c))[C]?.[l]??"null",J(t,((t,a)=>""===a?void 0:a));var t}))),(async t=>await g((async()=>{var a;await R(),await N(r,c,{[C]:{[l]:(a=t()??null,z(a,((t,a)=>void 0===a?"":a)))}},!0,!0)}))),e,n,s,o,{[d]:()=>w,destroy:()=>(p.stopAutoLoad().stopAutoSave(),i(),p)},w);return p},yt=(t,a,e,n,s,i,r,[c,l,[E,y,d]],u,T,R,A,g,p,f,v)=>{const[L,$,m,I]=ct(a,u,T,s,g,p,f,v),S=async(t,a)=>await w(Q(l,(async([e,n,s,i],o)=>{a&&!(o in t)||await m(e,n,t[o],s,i,a)}))),h=async(t,a)=>y?await m(d,O,{[C]:t},!0,!0,a):null,_=rt(t,(async()=>await I((async()=>{await L();const t=await(async()=>x(N(await w(Q(c,(async([t,a],e)=>[t,await $(e,a)]))),(t=>!k(t[1])))))(),a=await(async()=>E?(await $(d,O))[C]:{})();return k(t)&&o(a)?void 0:[t,a]}))),(async(t,a)=>await I((async()=>{if(await L(),o(a)){const[a,e]=t();await S(a),await h(e)}else await S(a[0],!0),await h(a[1],!0)}))),e,n,s,r,{[A]:()=>R,destroy:()=>(_.stopAutoLoad().stopAutoSave(),i(),_)},R);return _},wt="ColumnName",dt="store",ut="json",Tt=dt+"TableName",Rt=dt+"Id"+wt,At=dt+wt,Nt="autoLoadIntervalSeconds",gt="rowId"+wt,pt="tableId",Ct="tableName",Ot="deleteEmptyColumns",ft="deleteEmptyTable",vt={mode:ut,[Nt]:1},Lt={load:0,save:0,[Ct]:e+"_values"},$t=(t,a,e,n,s)=>{const i=K();return q(t,((t,r)=>{const l=E(H(X(a,c(t)?{[e]:t}:t)),0,W(a));o(l[0])||n(r,l[0])||(s(r,l[0]),Z(i,r,l))})),i},mt=e,It=/^([cd]:)(.+)/,St=e+"_data",ht=e+"_table";t.createPglitePersister=async(t,a,n,s,i)=>((t,a,n,s,i,o,l,y,d,u,T="getDb")=>{const A=((t,a)=>a?async(e,n)=>(a(e,n),await t(e,n)):t)(n,o),[N,,g,p]=(t=>{const a=(t=>X(vt,c(t)?{[Tt]:t}:t??{}))(t),n=a[Nt];if(a.mode==ut){const t=a[Tt]??e;return[1,n,[t,a[Rt]??O,a[At]??dt],et(t)]}const{tables:{load:s={},save:i={}}={},values:o={}}=a,r=E(H(X(Lt,o)),0,W(Lt)),l=r[2],y=et(l),w=et(l);return[0,n,[$t(s,{[pt]:null,[gt]:O},pt,(t=>_(w,t)),(t=>nt(y,t))),$t(i,{[Ct]:null,[gt]:O,[Ot]:0,[ft]:0},Ct,((t,a)=>_(w,a)),((t,a)=>nt(y,a))),r],y]})(a),C=async t=>{await A(`CREATE OR REPLACE TRIGGER ${S(St+"_"+t)} AFTER INSERT OR UPDATE OR DELETE ON ${S(t)} EXECUTE FUNCTION ${St}()`)};return(N?Et:yt)(t,A,(async t=>{await A(`CREATE OR REPLACE FUNCTION ${ht}()RETURNS event_trigger AS $t2$ DECLARE row record; BEGIN FOR row IN SELECT object_identity FROM pg_event_trigger_ddl_commands()WHERE command_tag='CREATE TABLE' LOOP PERFORM pg_notify('${mt}','c:'||SPLIT_PART(row.object_identity,'.',2));END LOOP;END;$t2$ LANGUAGE plpgsql;`);try{await A(`CREATE EVENT TRIGGER ${ht} ON ddl_command_end WHEN TAG IN('CREATE TABLE')EXECUTE FUNCTION ${ht}();`)}catch{}return await A(`CREATE OR REPLACE FUNCTION ${St}()RETURNS trigger AS $t1$ BEGIN PERFORM pg_notify('${mt}','d:'||TG_TABLE_NAME);RETURN NULL;END;$t1$ LANGUAGE plpgsql;`),await w(R(P(p),(async t=>{await A(`CREATE TABLE IF NOT EXISTS ${S(t)}("_id"text PRIMARY KEY)`),await C(t)}))),await s(mt,(async a=>{return await r((e=a,n=It,e?.match(n)),(async([,a,e])=>{_(p,e)&&("c:"==a&&await C(e),t())}));var e,n}))}),i,l,y,d,g,P(p),(async(t,a)=>await t(`${f} table_name tn,column_name cn FROM information_schema.columns ${v} table_schema='public'AND table_name IN(${h(a)})`,a)),u,T,"text",void 0,(t=>z(t)),(t=>J(t)))})(t,n,(async(t,e=[])=>(await a.query(t,e)).rows),(async(t,e)=>await a.listen(t,e)),(async t=>{try{await t()}catch(t){i?.(t)}}),s,i,(()=>0),3,a,"getPglite")},"object"==typeof exports&&"undefined"!=typeof module?a(exports):"function"==typeof define&&define.amd?define(["exports"],a):a((t="undefined"!=typeof globalThis?globalThis:t||self).TinyBasePersisterPglite={});
@@ -1 +1 @@
1
- var t,a;t=this,a=function(t){"use strict";const a=t=>typeof t,e="tinybase",n="",s=",",i=a(n),r=Promise,o=t=>null==t,c=(t,a,e)=>o(t)?e?.():a(t),l=t=>a(t)==i,E=t=>Array.isArray(t),y=(t,a,e)=>t.slice(a,e),w=t=>t.length,d=async t=>r.all(t),u=t=>{throw Error(t)},T=(t,a)=>N(Array(t).fill(0),((t,e)=>a(e))),R=(t,a)=>t.forEach(a),A=(t,a="")=>t.join(a),N=(t,a)=>t.map(a),g=t=>0==w(t),p=(t,a)=>t.filter(a),C=(t,...a)=>t.push(...a),O=t=>t.shift(),f="_",L="_id",v="SELECT",$="WHERE",m="TABLE",I="ALTER "+m,S="DELETE FROM",h=v+"*FROM",_=t=>`"${t.replace(/"/g,'""')}"`,b=t=>A(N(t,((t,a)=>"$"+(a+1))),s),P=(t,a)=>t?.has(a)??!1,D=t=>o(t)||0==(t=>t?.size??0)(t),U=t=>[...t?.values()??[]],F=(t,a)=>t?.forEach(a),M=(t,a)=>t?.delete(a),G=Object,B=t=>G.getPrototypeOf(t),j=G.entries,x=G.keys,X=G.freeze,Y=(t=[])=>G.fromEntries(t),q=(...t)=>G.assign({},...t),H=(t,a)=>(delete t[a],t),W=(t,a)=>N(j(t),(([t,e])=>a(e,t))),k=t=>G.values(t),z=t=>w(x(t)),J=t=>(t=>!o(t)&&c(B(t),(t=>t==G.prototype||o(B(t))),(()=>!0)))(t)&&0==z(t),K=JSON.stringify,V=JSON.parse,Q=t=>new Map(t),Z=(t,a)=>t?.get(a),tt=(t,a)=>N([...t?.entries()??[]],(([t,e])=>a(e,t))),at=(t,a,e)=>o(e)?(M(t,a),t):t?.set(a,e),et=(t,a,e,n)=>(P(t,a)?n?.(Z(t,a)):at(t,a,e()),Z(t,a)),nt=(t,a,e,n,s=0)=>c((e?et:Z)(t,a[s],s>w(a)-2?e:Q),(i=>{if(s>w(a)-2)return n?.(i)&&at(t,a[s]),i;const r=nt(i,a,e,n,s+1);return D(i)&&at(t,a[s]),r})),st=t=>new Set(E(t)||o(t)?t:[t]),it=(t,a)=>t?.add(a),rt=/^\d+$/,ot=Q(),ct=Q(),lt=(t,a,e,s,i,r,l,y={},d=[])=>{let T,A,N,g=0,p=0,f=0;et(ot,d,(()=>0)),et(ct,d,(()=>[]));const L=Q(),[v,$,m,I,S]=((t=1,a)=>1!=t&&a.isMergeable()?[1,a.getMergeableContent,a.getTransactionMergeableChanges,([[t],[a]])=>!J(t)||!J(a),a.setDefaultContent]:2!=t?[0,a.getContent,a.getTransactionChanges,([t,a])=>!J(t)||!J(a),a.setContent]:u("Store type not supported by this Persister"))(l,t),[h,_,b]=(()=>{let t;const[a,e]=(()=>{const t=[];let a=0;return[e=>(e?O(t):null)??n+a++,a=>{rt.test(a)&&w(t)<1e3&&C(t,a)}]})(),s=Q();return[(e,i,r,o=[],c=()=>[])=>{t??=q;const l=a(1);return at(s,l,[e,i,r,o,c]),it(nt(i,r??[n],st),l),l},(a,e,...i)=>R(((t,a=[n])=>{const e=[],s=(t,n)=>n==w(a)?C(e,t):null===a[n]?F(t,(t=>s(t,n+1))):R([a[n],null],(a=>s(Z(t,a),n+1)));return s(t,0),e})(a,e),(a=>F(a,(a=>Z(s,a)[0](t,...e??[],...i))))),t=>c(Z(s,t),(([,a,i])=>(nt(a,i??[n],void 0,(a=>(M(a,t),D(a)?1:0))),at(s,t),e(t),i))),a=>c(Z(s,a),(([a,,e=[],n,s])=>{const i=(...r)=>{const c=w(r);c==w(e)?a(t,...r,...s(r)):o(e[c])?R(n[c]?.(...r)??[],(t=>i(...r,t))):i(...r,e[c])};i()}))]})(),P=t=>{t!=g&&(g=t,_(L,void 0,g))},U=a=>{(v&&E(a?.[0])?1===a?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===a?.[2]?t.applyChanges:t.setContent)(a)},G=async t=>(2!=g&&(P(1),p++,await Y((async()=>{try{const t=await a();E(t)?U(t):u("Content is not an array "+t)}catch(a){r?.(a),t&&S(t)}P(0)}))),q),B=()=>(A&&(i(A),A=void 0),q),j=async t=>(1!=g&&(P(2),f++,await Y((async()=>{try{await e($,t)}catch(t){r?.(t)}P(0)}))),q),x=()=>(c(N,t.delListener),N=void 0,q),Y=async(...t)=>(C(Z(ct,d),...t),await(async()=>{if(!Z(ot,d)){for(at(ot,d,1);!o(T=O(Z(ct,d)));)try{await T()}catch(t){r?.(t)}at(ot,d,0)}})(),q),q={load:G,startAutoLoad:async t=>{await B().load(t);try{A=await s((async(t,a)=>{a||t?2!=g&&(P(1),p++,U(a??t),P(0)):await G()}))}catch(t){r?.(t)}return q},stopAutoLoad:B,isAutoLoading:()=>!o(A),save:j,startAutoSave:async()=>(await x().save(),N=t.addDidFinishTransactionListener((()=>{const t=m();I(t)&&j(t)})),q),stopAutoSave:x,isAutoSaving:()=>!o(N),getStatus:()=>g,addStatusListener:t=>h(t,L),delListener:a=>(b(a),t),schedule:Y,getStore:()=>t,destroy:()=>(Z(ct,d).splice(0,void 0),B().stopAutoSave()),getStats:()=>({loads:p,saves:f}),...y};return X(q)},Et=(t,a,e,n,i,r,c,l)=>{const E=Q();return[async()=>{E.clear(),N(await e(t,a),(({tn:t,cn:a})=>it(et(E,t,st),a)))},async(a,e)=>((t,a)=>P(Z(E,t),a))(a,e)?Y(p(N(await t(h+_(a)),(t=>{return[t[e],l?(a=H(t,e),n=l,Y(W(a,((t,a)=>[a,n(t,a)])))):H(t,e)];var a,n})),(([t,a])=>!o(t)&&!J(a)))):{},async(a,e,n,l,y,w=!1)=>{const u=st();W(n??{},(t=>N(x(t??{}),(t=>it(u,t)))));const T=U(u);if(!w&&y&&g(T)&&P(E,a))return await t("DROP "+m+_(a)),void at(E,a);const R=Z(E,a),O=st(U(R));if(g(T)||(P(E,a)?await d(N([e,...T],(async(n,s)=>{M(O,n)||(await t(I+_(a)+"ADD"+_(n)+i),0==s&&await t("CREATE UNIQUE INDEX pk ON "+_(a)+`(${_(e)})`),it(R,n))}))):(await t("CREATE "+m+_(a)+`(${_(e)}${i} PRIMARY KEY${A(N(T,(t=>s+_(t)+i)))});`),at(E,a,st([e,...T])))),await d([...!w&&l?N(U(O),(async n=>{n!=e&&(await t(I+_(a)+"DROP"+_(n)),M(R,n))})):[]]),w)o(n)?await t(S+_(a)+$+" true"):await d(W(n,(async(n,s)=>{o(n)?await t(S+_(a)+$+_(e)+"=$1",[s]):g(T)||await yt(t,a,e,x(n),[s,...c?N(k(n),c):k(n)],r)})));else if(g(T))P(E,a)&&await t(S+_(a)+$+" true");else{const s=p(U(Z(E,a)),(t=>t!=e)),i=[],o=[];W(n??{},((t,a)=>{C(i,a,...N(s,(a=>c?c(t?.[a]):t?.[a]))),C(o,a)})),await yt(t,a,e,s,i,r),await t(S+_(a)+$+_(e)+`NOT IN(${b(o)})`,o)}},async a=>{let e;await t("BEGIN");try{e=await a()}catch(t){n?.(t)}return await t("END"),e}]},yt=async(t,a,e,i,r,o=0)=>await t("INSERT "+(o?"OR REPLACE ":n)+"INTO"+_(a)+"("+_(e)+A(N(i,(t=>s+_(t))))+")VALUES"+wt(r,w(i)+1)+(o?n:"ON CONFLICT("+_(e)+")DO UPDATE SET"+A(N(i,(t=>_(t)+"=excluded."+_(t))),s)),N(r,(t=>t??null))),wt=(t,a)=>A(T(w(t)/a,(t=>"("+A(T(a,(e=>"$"+(t*a+e+1))),s)+")")),s),dt=(t,a,e,n,s,i,r,[o,c,l],E,y,w,d,u,T)=>{const[R,A,N,g]=Et(a,E,y,s,u,T),p=lt(t,(async()=>await g((async()=>{return await R(),t=(await A(o,c))[f]?.[l]??"null",V(t,((t,a)=>""===a?void 0:a));var t}))),(async t=>await g((async()=>{var a;await R(),await N(o,c,{[f]:{[l]:(a=t()??null,K(a,((t,a)=>void 0===a?"":a)))}},!0,!0)}))),e,n,s,r,{[d]:()=>w,destroy:()=>(p.stopAutoLoad().stopAutoSave(),i(),p)},w);return p},ut=(t,a,e,n,s,i,r,[c,l,[E,y,w]],u,T,R,A,N,g,C,O)=>{const[v,$,m,I]=Et(a,u,T,s,N,g,C,O),S=async(t,a)=>await d(tt(l,(async([e,n,s,i],r)=>{a&&!(r in t)||await m(e,n,t[r],s,i,a)}))),h=async(t,a)=>y?await m(w,L,{[f]:t},!0,!0,a):null,_=lt(t,(async()=>await I((async()=>{await v();const t=await(async()=>Y(p(await d(tt(c,(async([t,a],e)=>[t,await $(e,a)]))),(t=>!J(t[1])))))(),a=await(async()=>E?(await $(w,L))[f]:{})();return J(t)&&o(a)?void 0:[t,a]}))),(async(t,a)=>await I((async()=>{if(await v(),o(a)){const[a,e]=t();await S(a),await h(e)}else await S(a[0],!0),await h(a[1],!0)}))),e,n,s,r,{[A]:()=>R,destroy:()=>(_.stopAutoLoad().stopAutoSave(),i(),_)},R);return _},Tt="ColumnName",Rt="store",At="json",Nt=Rt+"TableName",gt=Rt+"Id"+Tt,pt=Rt+Tt,Ct="autoLoadIntervalSeconds",Ot="rowId"+Tt,ft="tableId",Lt="tableName",vt="deleteEmptyColumns",$t="deleteEmptyTable",mt={mode:At,[Ct]:1},It={load:0,save:0,[Lt]:e+"_values"},St=(t,a,e,n,s)=>{const i=Q();return W(t,((t,r)=>{const c=y(k(q(a,l(t)?{[e]:t}:t)),0,z(a));o(c[0])||n(r,c[0])||(s(r,c[0]),at(i,r,c))})),i},ht=e,_t=/^([cd]:)(.+)/,bt=e+"_data",Pt=e+"_table";t.createPglitePersister=async(t,a,n,s,i)=>((t,a,n,s,i,r,o,E,w,u,T="getDb")=>{const R=((t,a)=>a?async(e,n)=>(a(e,n),await t(e,n)):t)(n,r),[A,,g,p]=(t=>{const a=(t=>q(mt,l(t)?{[Nt]:t}:t??{}))(t),n=a[Ct];if(a.mode==At){const t=a[Nt]??e;return[1,n,[t,a[gt]??L,a[pt]??Rt],st(t)]}const{tables:{load:s={},save:i={}}={},values:r={}}=a,o=y(k(q(It,r)),0,z(It)),c=o[2],E=st(c),w=st(c);return[0,n,[St(s,{[ft]:null,[Ot]:L},ft,(t=>P(w,t)),(t=>it(E,t))),St(i,{[Lt]:null,[Ot]:L,[vt]:0,[$t]:0},Lt,((t,a)=>P(w,a)),((t,a)=>it(E,a))),o],E]})(a),C=async t=>{await R(`CREATE OR REPLACE TRIGGER ${_(bt+"_"+t)} AFTER INSERT OR UPDATE OR DELETE ON ${_(t)} EXECUTE FUNCTION ${bt}()`)};return(A?dt:ut)(t,R,(async t=>{await R(`CREATE OR REPLACE FUNCTION ${Pt}()RETURNS event_trigger AS $t2$ DECLARE row record; BEGIN FOR row IN SELECT object_identity FROM pg_event_trigger_ddl_commands()WHERE command_tag='CREATE TABLE' LOOP PERFORM pg_notify('${ht}','c:'||SPLIT_PART(row.object_identity,'.',2));END LOOP;END;$t2$ LANGUAGE plpgsql;`);try{await R(`CREATE EVENT TRIGGER ${Pt} ON ddl_command_end WHEN TAG IN('CREATE TABLE')EXECUTE FUNCTION ${Pt}();`)}catch{}return await R(`CREATE OR REPLACE FUNCTION ${bt}()RETURNS trigger AS $t1$ BEGIN PERFORM pg_notify('${ht}','d:'||TG_TABLE_NAME);RETURN NULL;END;$t1$ LANGUAGE plpgsql;`),await d(N(U(p),(async t=>{await R(`CREATE TABLE IF NOT EXISTS ${_(t)}("_id"text PRIMARY KEY)`),await C(t)}))),await s(ht,(async a=>{return await c((e=a,n=_t,e?.match(n)),(async([,a,e])=>{P(p,e)&&("c:"==a&&await C(e),t())}));var e,n}))}),i,o,E,w,g,U(p),(async(t,a)=>await t(`${v} table_name tn,column_name cn FROM information_schema.columns ${$} table_schema='public'AND table_name IN(${b(a)})`,a)),u,T,"text",0,(t=>K(t)),(t=>V(t)))})(t,n,(async(t,e=[])=>(await a.query(t,e)).rows),(async(t,e)=>await a.listen(t,e)),(async t=>{try{await t()}catch(t){i?.(t)}}),s,i,(()=>0),3,a,"getPglite")},"object"==typeof exports&&"undefined"!=typeof module?a(exports):"function"==typeof define&&define.amd?define(["exports"],a):a((t="undefined"!=typeof globalThis?globalThis:t||self).TinyBasePersisterPglite={});
1
+ var t,a;t=this,a=function(t){"use strict";const a=t=>typeof t,e="tinybase",n=",",s=a(""),i=Promise,o=t=>null==t,r=(t,a,e)=>o(t)?e?.():a(t),c=t=>a(t)==s,l=t=>Array.isArray(t),E=(t,a,e)=>t.slice(a,e),y=t=>t.length,w=async t=>i.all(t),d=t=>{throw Error(t)},u=(t,a)=>t.forEach(a),T=(t,a="")=>t.join(a),R=(t,a)=>t.map(a),A=t=>0==y(t),N=(t,a)=>t.filter(a),g=(t,...a)=>t.push(...a),p=t=>t.shift(),C="_",O="_id",f="SELECT",v="WHERE",L="TABLE",$="ALTER "+L,m="DELETE FROM",I=f+"*FROM",S=t=>`"${t.replace(/"/g,'""')}"`,h=(t,a=[1])=>T(R(t,(()=>"$"+a[0]++)),n),_=(t,a)=>t?.has(a)??!1,b=t=>o(t)||0==(t=>t?.size??0)(t),P=t=>[...t?.values()??[]],D=(t,a)=>t?.forEach(a),U=(t,a)=>t?.delete(a),F=Object,M=t=>F.getPrototypeOf(t),G=F.entries,B=F.keys,j=F.freeze,x=(t=[])=>F.fromEntries(t),X=(...t)=>F.assign({},...t),Y=(t,a)=>(delete t[a],t),q=(t,a)=>R(G(t),(([t,e])=>a(e,t))),H=t=>F.values(t),W=t=>y(B(t)),k=t=>(t=>!o(t)&&r(M(t),(t=>t==F.prototype||o(M(t))),(()=>!0)))(t)&&0==W(t),z=JSON.stringify,J=JSON.parse,K=t=>new Map(t),V=(t,a)=>t?.get(a),Q=(t,a)=>R([...t?.entries()??[]],(([t,e])=>a(e,t))),Z=(t,a,e)=>o(e)?(U(t,a),t):t?.set(a,e),tt=(t,a,e,n)=>(_(t,a)?n?.(V(t,a)):Z(t,a,e()),V(t,a)),at=(t,a,e,n,s=0)=>r((e?tt:V)(t,a[s],s>y(a)-2?e:K),(i=>{if(s>y(a)-2)return n?.(i)&&Z(t,a[s]),i;const o=at(i,a,e,n,s+1);return b(i)&&Z(t,a[s]),o})),et=t=>new Set(l(t)||o(t)?t:[t]),nt=(t,a)=>t?.add(a),st=/^\d+$/,it=K(),ot=K(),rt=(t,a,e,n,s,i,c,E={},w=[])=>{let T,R,A,N=0,C=0,O=0;tt(it,w,(()=>0)),tt(ot,w,(()=>[]));const f=K(),[v,L,$,m,I]=((t=1,a)=>1!=t&&a.isMergeable()?[1,a.getMergeableContent,a.getTransactionMergeableChanges,([[t],[a]])=>!k(t)||!k(a),a.setDefaultContent]:2!=t?[0,a.getContent,a.getTransactionChanges,([t,a])=>!k(t)||!k(a),a.setContent]:d("Store type not supported by this Persister"))(c,t),[S,h,_]=(()=>{let t;const[a,e]=(()=>{const t=[];let a=0;return[e=>(e?p(t):null)??""+a++,a=>{st.test(a)&&y(t)<1e3&&g(t,a)}]})(),n=K();return[(e,s,i,o=[],r=()=>[])=>{t??=Y;const c=a(1);return Z(n,c,[e,s,i,o,r]),nt(at(s,i??[""],et),c),c},(a,e,...s)=>u(((t,a=[""])=>{const e=[],n=(t,s)=>s==y(a)?g(e,t):null===a[s]?D(t,(t=>n(t,s+1))):u([a[s],null],(a=>n(V(t,a),s+1)));return n(t,0),e})(a,e),(a=>D(a,(a=>V(n,a)[0](t,...e??[],...s))))),t=>r(V(n,t),(([,a,s])=>(at(a,s??[""],void 0,(a=>(U(a,t),b(a)?1:0))),Z(n,t),e(t),s))),a=>r(V(n,a),(([a,,e=[],n,s])=>{const i=(...r)=>{const c=y(r);c==y(e)?a(t,...r,...s(r)):o(e[c])?u(n[c]?.(...r)??[],(t=>i(...r,t))):i(...r,e[c])};i()}))]})(),P=t=>{t!=N&&(N=t,h(f,void 0,N))},F=a=>{(v&&l(a?.[0])?1===a?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===a?.[2]?t.applyChanges:t.setContent)(a)},M=async t=>(2!=N&&(P(1),C++,await X((async()=>{try{const e=await a();l(e)?F(e):t?I(t):d("Content is not an array "+e)}catch(a){i?.(a),t&&I(t)}P(0)}))),Y),G=()=>(R&&(s(R),R=void 0),Y),B=async t=>(1!=N&&(P(2),O++,await X((async()=>{try{await e(L,t)}catch(t){i?.(t)}P(0)}))),Y),x=()=>(r(A,t.delListener),A=void 0,Y),X=async(...t)=>(g(V(ot,w),...t),await(async()=>{if(!V(it,w)){for(Z(it,w,1);!o(T=p(V(ot,w)));)try{await T()}catch(t){i?.(t)}Z(it,w,0)}})(),Y),Y={load:M,startAutoLoad:async t=>{await G().load(t);try{R=await n((async(t,a)=>{a||t?2!=N&&(P(1),C++,F(a??t),P(0)):await M()}))}catch(t){i?.(t)}return Y},stopAutoLoad:G,isAutoLoading:()=>!o(R),save:B,startAutoSave:async()=>(await x().save(),A=t.addDidFinishTransactionListener((()=>{const t=$();m(t)&&B(t)})),Y),stopAutoSave:x,isAutoSaving:()=>!o(A),getStatus:()=>N,addStatusListener:t=>S(t,f),delListener:a=>(_(a),t),schedule:X,getStore:()=>t,destroy:()=>(V(ot,w).splice(0,void 0),G().stopAutoSave()),getStats:()=>({loads:C,saves:O}),...E};return j(Y)},ct=(t,a,e,s,i,r=lt,c,l)=>{const E=K();return[async()=>{E.clear(),R(await e(t,a),(({tn:t,cn:a})=>nt(tt(E,t,et),a)))},async(a,e)=>((t,a)=>_(V(E,t),a))(a,e)?x(N(R(await t(I+S(a)),(t=>{return[t[e],l?(a=Y(t,e),n=l,x(q(a,((t,a)=>[a,n(t,a)])))):Y(t,e)];var a,n})),(([t,a])=>!o(t)&&!k(a)))):{},async(a,e,s,l,y,d=!1)=>{const u=et();q(s??{},(t=>R(B(t??{}),(t=>nt(u,t)))));const p=P(u);if(!d&&y&&A(p)&&_(E,a))return await t("DROP "+L+S(a)),void Z(E,a);const C=V(E,a),O=et(P(C));if(A(p)||(_(E,a)?await w(R([e,...p],(async(n,s)=>{U(O,n)||(await t($+S(a)+"ADD"+S(n)+i),0==s&&await t("CREATE UNIQUE INDEX pk ON "+S(a)+`(${S(e)})`),nt(C,n))}))):(await t("CREATE "+L+S(a)+`(${S(e)}${i} PRIMARY KEY${T(R(p,(t=>n+S(t)+i)))});`),Z(E,a,et([e,...p])))),await w([...!d&&l?R(P(O),(async n=>{n!=e&&(await t($+S(a)+"DROP"+S(n)),U(C,n))})):[]]),d)o(s)?await t(m+S(a)+v+" true"):await w(q(s,(async(n,s)=>{o(n)?await t(m+S(a)+v+S(e)+"=$1",[s]):A(p)||await r(t,a,e,B(n),{[s]:c?R(H(n),c):H(n)},C)})));else if(A(p))_(E,a)&&await t(m+S(a)+v+" true");else{const n=N(P(V(E,a)),(t=>t!=e)),i={},o=[];q(s??{},((t,a)=>{i[a]=R(n,(a=>c?c(t?.[a]):t?.[a])),g(o,a)})),await r(t,a,e,n,i),await t(m+S(a)+v+S(e)+`NOT IN(${h(o)})`,o)}},async a=>{let e;await t("BEGIN");try{e=await a()}catch(t){s?.(t)}return await t("END"),e}]},lt=async(t,a,e,s,i)=>{const o=[1];await t("INSERT INTO"+S(a)+"("+((...t)=>T(R(t,S),n))(e,...s)+")VALUES"+T(q(i,(t=>"($"+o[0]+++","+h(t,o)+")")),n)+"ON CONFLICT("+S(e)+")DO UPDATE SET"+T(R(s,(t=>S(t)+"=excluded."+S(t))),n),q(i,((t,a)=>[a,...R(t,(t=>t??null))])).flat())},Et=(t,a,e,n,s,i,o,[r,c,l],E,y,w,d,u,T)=>{const[R,A,N,g]=ct(a,E,y,s,u,T),p=rt(t,(async()=>await g((async()=>{return await R(),t=(await A(r,c))[C]?.[l]??"null",J(t,((t,a)=>""===a?void 0:a));var t}))),(async t=>await g((async()=>{var a;await R(),await N(r,c,{[C]:{[l]:(a=t()??null,z(a,((t,a)=>void 0===a?"":a)))}},!0,!0)}))),e,n,s,o,{[d]:()=>w,destroy:()=>(p.stopAutoLoad().stopAutoSave(),i(),p)},w);return p},yt=(t,a,e,n,s,i,r,[c,l,[E,y,d]],u,T,R,A,g,p,f,v)=>{const[L,$,m,I]=ct(a,u,T,s,g,p,f,v),S=async(t,a)=>await w(Q(l,(async([e,n,s,i],o)=>{a&&!(o in t)||await m(e,n,t[o],s,i,a)}))),h=async(t,a)=>y?await m(d,O,{[C]:t},!0,!0,a):null,_=rt(t,(async()=>await I((async()=>{await L();const t=await(async()=>x(N(await w(Q(c,(async([t,a],e)=>[t,await $(e,a)]))),(t=>!k(t[1])))))(),a=await(async()=>E?(await $(d,O))[C]:{})();return k(t)&&o(a)?void 0:[t,a]}))),(async(t,a)=>await I((async()=>{if(await L(),o(a)){const[a,e]=t();await S(a),await h(e)}else await S(a[0],!0),await h(a[1],!0)}))),e,n,s,r,{[A]:()=>R,destroy:()=>(_.stopAutoLoad().stopAutoSave(),i(),_)},R);return _},wt="ColumnName",dt="store",ut="json",Tt=dt+"TableName",Rt=dt+"Id"+wt,At=dt+wt,Nt="autoLoadIntervalSeconds",gt="rowId"+wt,pt="tableId",Ct="tableName",Ot="deleteEmptyColumns",ft="deleteEmptyTable",vt={mode:ut,[Nt]:1},Lt={load:0,save:0,[Ct]:e+"_values"},$t=(t,a,e,n,s)=>{const i=K();return q(t,((t,r)=>{const l=E(H(X(a,c(t)?{[e]:t}:t)),0,W(a));o(l[0])||n(r,l[0])||(s(r,l[0]),Z(i,r,l))})),i},mt=e,It=/^([cd]:)(.+)/,St=e+"_data",ht=e+"_table";t.createPglitePersister=async(t,a,n,s,i)=>((t,a,n,s,i,o,l,y,d,u,T="getDb")=>{const A=((t,a)=>a?async(e,n)=>(a(e,n),await t(e,n)):t)(n,o),[N,,g,p]=(t=>{const a=(t=>X(vt,c(t)?{[Tt]:t}:t??{}))(t),n=a[Nt];if(a.mode==ut){const t=a[Tt]??e;return[1,n,[t,a[Rt]??O,a[At]??dt],et(t)]}const{tables:{load:s={},save:i={}}={},values:o={}}=a,r=E(H(X(Lt,o)),0,W(Lt)),l=r[2],y=et(l),w=et(l);return[0,n,[$t(s,{[pt]:null,[gt]:O},pt,(t=>_(w,t)),(t=>nt(y,t))),$t(i,{[Ct]:null,[gt]:O,[Ot]:0,[ft]:0},Ct,((t,a)=>_(w,a)),((t,a)=>nt(y,a))),r],y]})(a),C=async t=>{await A(`CREATE OR REPLACE TRIGGER ${S(St+"_"+t)} AFTER INSERT OR UPDATE OR DELETE ON ${S(t)} EXECUTE FUNCTION ${St}()`)};return(N?Et:yt)(t,A,(async t=>{await A(`CREATE OR REPLACE FUNCTION ${ht}()RETURNS event_trigger AS $t2$ DECLARE row record; BEGIN FOR row IN SELECT object_identity FROM pg_event_trigger_ddl_commands()WHERE command_tag='CREATE TABLE' LOOP PERFORM pg_notify('${mt}','c:'||SPLIT_PART(row.object_identity,'.',2));END LOOP;END;$t2$ LANGUAGE plpgsql;`);try{await A(`CREATE EVENT TRIGGER ${ht} ON ddl_command_end WHEN TAG IN('CREATE TABLE')EXECUTE FUNCTION ${ht}();`)}catch{}return await A(`CREATE OR REPLACE FUNCTION ${St}()RETURNS trigger AS $t1$ BEGIN PERFORM pg_notify('${mt}','d:'||TG_TABLE_NAME);RETURN NULL;END;$t1$ LANGUAGE plpgsql;`),await w(R(P(p),(async t=>{await A(`CREATE TABLE IF NOT EXISTS ${S(t)}("_id"text PRIMARY KEY)`),await C(t)}))),await s(mt,(async a=>{return await r((e=a,n=It,e?.match(n)),(async([,a,e])=>{_(p,e)&&("c:"==a&&await C(e),t())}));var e,n}))}),i,l,y,d,g,P(p),(async(t,a)=>await t(`${f} table_name tn,column_name cn FROM information_schema.columns ${v} table_schema='public'AND table_name IN(${h(a)})`,a)),u,T,"text",void 0,(t=>z(t)),(t=>J(t)))})(t,n,(async(t,e=[])=>(await a.query(t,e)).rows),(async(t,e)=>await a.listen(t,e)),(async t=>{try{await t()}catch(t){i?.(t)}}),s,i,(()=>0),3,a,"getPglite")},"object"==typeof exports&&"undefined"!=typeof module?a(exports):"function"==typeof define&&define.amd?define(["exports"],a):a((t="undefined"!=typeof globalThis?globalThis:t||self).TinyBasePersisterPglite={});
@@ -1 +1 @@
1
- var t,a;t=this,a=function(t){"use strict";const a=t=>typeof t,e="tinybase",n="",s=",",i=a(n),r=Promise,o=t=>null==t,c=(t,a,e)=>o(t)?e?.():a(t),l=t=>a(t)==i,E=t=>Array.isArray(t),y=(t,a,e)=>t.slice(a,e),w=t=>t.length,d=async t=>r.all(t),u=t=>{throw Error(t)},T=(t,a)=>N(Array(t).fill(0),((t,e)=>a(e))),R=(t,a)=>t.forEach(a),A=(t,a="")=>t.join(a),N=(t,a)=>t.map(a),g=t=>0==w(t),p=(t,a)=>t.filter(a),C=(t,...a)=>t.push(...a),O=t=>t.shift(),f="_",L="_id",v="SELECT",$="WHERE",m="TABLE",S="ALTER "+m,I="DELETE FROM",h=v+"*FROM",_=t=>`"${t.replace(/"/g,'""')}"`,b=t=>A(N(t,((t,a)=>"$"+(a+1))),s),P=(t,a)=>t?.has(a)??!1,D=t=>o(t)||0==(t=>t?.size??0)(t),U=t=>[...t?.values()??[]],F=(t,a)=>t?.forEach(a),M=(t,a)=>t?.delete(a),G=Object,B=t=>G.getPrototypeOf(t),j=G.entries,x=G.keys,X=G.freeze,Y=(t=[])=>G.fromEntries(t),q=(...t)=>G.assign({},...t),H=(t,a)=>(delete t[a],t),W=(t,a)=>N(j(t),(([t,e])=>a(e,t))),k=t=>G.values(t),z=t=>w(x(t)),J=t=>(t=>!o(t)&&c(B(t),(t=>t==G.prototype||o(B(t))),(()=>!0)))(t)&&0==z(t),K=JSON.stringify,V=JSON.parse,Q=t=>new Map(t),Z=(t,a)=>t?.get(a),tt=(t,a)=>N([...t?.entries()??[]],(([t,e])=>a(e,t))),at=(t,a,e)=>o(e)?(M(t,a),t):t?.set(a,e),et=(t,a,e,n)=>(P(t,a)?n?.(Z(t,a)):at(t,a,e()),Z(t,a)),nt=(t,a,e,n,s=0)=>c((e?et:Z)(t,a[s],s>w(a)-2?e:Q),(i=>{if(s>w(a)-2)return n?.(i)&&at(t,a[s]),i;const r=nt(i,a,e,n,s+1);return D(i)&&at(t,a[s]),r})),st=t=>new Set(E(t)||o(t)?t:[t]),it=(t,a)=>t?.add(a),rt=/^\d+$/,ot=Q(),ct=Q(),lt=(t,a,e,s,i,r,l,y={},d=[])=>{let T,A,N,g=0,p=0,f=0;et(ot,d,(()=>0)),et(ct,d,(()=>[]));const L=Q(),[v,$,m,S,I]=((t=1,a)=>1!=t&&a.isMergeable()?[1,a.getMergeableContent,a.getTransactionMergeableChanges,([[t],[a]])=>!J(t)||!J(a),a.setDefaultContent]:2!=t?[0,a.getContent,a.getTransactionChanges,([t,a])=>!J(t)||!J(a),a.setContent]:u("Store type not supported by this Persister"))(l,t),[h,_,b]=(()=>{let t;const[a,e]=(()=>{const t=[];let a=0;return[e=>(e?O(t):null)??n+a++,a=>{rt.test(a)&&w(t)<1e3&&C(t,a)}]})(),s=Q();return[(e,i,r,o=[],c=()=>[])=>{t??=q;const l=a(1);return at(s,l,[e,i,r,o,c]),it(nt(i,r??[n],st),l),l},(a,e,...i)=>R(((t,a=[n])=>{const e=[],s=(t,n)=>n==w(a)?C(e,t):null===a[n]?F(t,(t=>s(t,n+1))):R([a[n],null],(a=>s(Z(t,a),n+1)));return s(t,0),e})(a,e),(a=>F(a,(a=>Z(s,a)[0](t,...e??[],...i))))),t=>c(Z(s,t),(([,a,i])=>(nt(a,i??[n],void 0,(a=>(M(a,t),D(a)?1:0))),at(s,t),e(t),i))),a=>c(Z(s,a),(([a,,e=[],n,s])=>{const i=(...r)=>{const c=w(r);c==w(e)?a(t,...r,...s(r)):o(e[c])?R(n[c]?.(...r)??[],(t=>i(...r,t))):i(...r,e[c])};i()}))]})(),P=t=>{t!=g&&(g=t,_(L,void 0,g))},U=a=>{(v&&E(a?.[0])?1===a?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===a?.[2]?t.applyChanges:t.setContent)(a)},G=async t=>(2!=g&&(P(1),p++,await Y((async()=>{try{const t=await a();E(t)?U(t):u("Content is not an array "+t)}catch(a){r?.(a),t&&I(t)}P(0)}))),q),B=()=>(A&&(i(A),A=void 0),q),j=async t=>(1!=g&&(P(2),f++,await Y((async()=>{try{await e($,t)}catch(t){r?.(t)}P(0)}))),q),x=()=>(c(N,t.delListener),N=void 0,q),Y=async(...t)=>(C(Z(ct,d),...t),await(async()=>{if(!Z(ot,d)){for(at(ot,d,1);!o(T=O(Z(ct,d)));)try{await T()}catch(t){r?.(t)}at(ot,d,0)}})(),q),q={load:G,startAutoLoad:async t=>{await B().load(t);try{A=await s((async(t,a)=>{a||t?2!=g&&(P(1),p++,U(a??t),P(0)):await G()}))}catch(t){r?.(t)}return q},stopAutoLoad:B,isAutoLoading:()=>!o(A),save:j,startAutoSave:async()=>(await x().save(),N=t.addDidFinishTransactionListener((()=>{const t=m();S(t)&&j(t)})),q),stopAutoSave:x,isAutoSaving:()=>!o(N),getStatus:()=>g,addStatusListener:t=>h(t,L),delListener:a=>(b(a),t),schedule:Y,getStore:()=>t,destroy:()=>(Z(ct,d).splice(0,void 0),B().stopAutoSave()),getStats:()=>({loads:p,saves:f}),...y};return X(q)},Et=(t,a,e,n,i,r,c,l)=>{const E=Q();return[async()=>{E.clear(),N(await e(t,a),(({tn:t,cn:a})=>it(et(E,t,st),a)))},async(a,e)=>((t,a)=>P(Z(E,t),a))(a,e)?Y(p(N(await t(h+_(a)),(t=>{return[t[e],l?(a=H(t,e),n=l,Y(W(a,((t,a)=>[a,n(t,a)])))):H(t,e)];var a,n})),(([t,a])=>!o(t)&&!J(a)))):{},async(a,e,n,l,y,w=!1)=>{const u=st();W(n??{},(t=>N(x(t??{}),(t=>it(u,t)))));const T=U(u);if(!w&&y&&g(T)&&P(E,a))return await t("DROP "+m+_(a)),void at(E,a);const R=Z(E,a),O=st(U(R));if(g(T)||(P(E,a)?await d(N([e,...T],(async(n,s)=>{M(O,n)||(await t(S+_(a)+"ADD"+_(n)+i),0==s&&await t("CREATE UNIQUE INDEX pk ON "+_(a)+`(${_(e)})`),it(R,n))}))):(await t("CREATE "+m+_(a)+`(${_(e)}${i} PRIMARY KEY${A(N(T,(t=>s+_(t)+i)))});`),at(E,a,st([e,...T])))),await d([...!w&&l?N(U(O),(async n=>{n!=e&&(await t(S+_(a)+"DROP"+_(n)),M(R,n))})):[]]),w)o(n)?await t(I+_(a)+$+" true"):await d(W(n,(async(n,s)=>{o(n)?await t(I+_(a)+$+_(e)+"=$1",[s]):g(T)||await yt(t,a,e,x(n),[s,...c?N(k(n),c):k(n)],r)})));else if(g(T))P(E,a)&&await t(I+_(a)+$+" true");else{const s=p(U(Z(E,a)),(t=>t!=e)),i=[],o=[];W(n??{},((t,a)=>{C(i,a,...N(s,(a=>c?c(t?.[a]):t?.[a]))),C(o,a)})),await yt(t,a,e,s,i,r),await t(I+_(a)+$+_(e)+`NOT IN(${b(o)})`,o)}},async a=>{let e;await t("BEGIN");try{e=await a()}catch(t){n?.(t)}return await t("END"),e}]},yt=async(t,a,e,i,r,o=0)=>await t("INSERT "+(o?"OR REPLACE ":n)+"INTO"+_(a)+"("+_(e)+A(N(i,(t=>s+_(t))))+")VALUES"+wt(r,w(i)+1)+(o?n:"ON CONFLICT("+_(e)+")DO UPDATE SET"+A(N(i,(t=>_(t)+"=excluded."+_(t))),s)),N(r,(t=>t??null))),wt=(t,a)=>A(T(w(t)/a,(t=>"("+A(T(a,(e=>"$"+(t*a+e+1))),s)+")")),s),dt=(t,a,e,n,s,i,r,[o,c,l],E,y,w,d,u,T)=>{const[R,A,N,g]=Et(a,E,y,s,u,T),p=lt(t,(async()=>await g((async()=>{return await R(),t=(await A(o,c))[f]?.[l]??"null",V(t,((t,a)=>""===a?void 0:a));var t}))),(async t=>await g((async()=>{var a;await R(),await N(o,c,{[f]:{[l]:(a=t()??null,K(a,((t,a)=>void 0===a?"":a)))}},!0,!0)}))),e,n,s,r,{[d]:()=>w,destroy:()=>(p.stopAutoLoad().stopAutoSave(),i(),p)},w);return p},ut=(t,a,e,n,s,i,r,[c,l,[E,y,w]],u,T,R,A,N,g,C,O)=>{const[v,$,m,S]=Et(a,u,T,s,N,g,C,O),I=async(t,a)=>await d(tt(l,(async([e,n,s,i],r)=>{a&&!(r in t)||await m(e,n,t[r],s,i,a)}))),h=async(t,a)=>y?await m(w,L,{[f]:t},!0,!0,a):null,_=lt(t,(async()=>await S((async()=>{await v();const t=await(async()=>Y(p(await d(tt(c,(async([t,a],e)=>[t,await $(e,a)]))),(t=>!J(t[1])))))(),a=await(async()=>E?(await $(w,L))[f]:{})();return J(t)&&o(a)?void 0:[t,a]}))),(async(t,a)=>await S((async()=>{if(await v(),o(a)){const[a,e]=t();await I(a),await h(e)}else await I(a[0],!0),await h(a[1],!0)}))),e,n,s,r,{[A]:()=>R,destroy:()=>(_.stopAutoLoad().stopAutoSave(),i(),_)},R);return _},Tt="ColumnName",Rt="store",At="json",Nt=Rt+"TableName",gt=Rt+"Id"+Tt,pt=Rt+Tt,Ct="autoLoadIntervalSeconds",Ot="rowId"+Tt,ft="tableId",Lt="tableName",vt="deleteEmptyColumns",$t="deleteEmptyTable",mt={mode:At,[Ct]:1},St={load:0,save:0,[Lt]:e+"_values"},It=(t,a,e,n,s)=>{const i=Q();return W(t,((t,r)=>{const c=y(k(q(a,l(t)?{[e]:t}:t)),0,z(a));o(c[0])||n(r,c[0])||(s(r,c[0]),at(i,r,c))})),i},ht=e,_t=/^([cd]:)(.+)/,bt=e+"_data",Pt=e+"_table";t.createPostgresPersister=async(t,a,n,s,i)=>{const r=await(a.reserve?.());return((t,a,n,s,i,r,o,E,w,u,T="getDb")=>{const R=((t,a)=>a?async(e,n)=>(a(e,n),await t(e,n)):t)(n,r),[A,,g,p]=(t=>{const a=(t=>q(mt,l(t)?{[Nt]:t}:t??{}))(t),n=a[Ct];if(a.mode==At){const t=a[Nt]??e;return[1,n,[t,a[gt]??L,a[pt]??Rt],st(t)]}const{tables:{load:s={},save:i={}}={},values:r={}}=a,o=y(k(q(St,r)),0,z(St)),c=o[2],E=st(c),w=st(c);return[0,n,[It(s,{[ft]:null,[Ot]:L},ft,(t=>P(w,t)),(t=>it(E,t))),It(i,{[Lt]:null,[Ot]:L,[vt]:0,[$t]:0},Lt,((t,a)=>P(w,a)),((t,a)=>it(E,a))),o],E]})(a),C=async t=>{await R(`CREATE OR REPLACE TRIGGER ${_(bt+"_"+t)} AFTER INSERT OR UPDATE OR DELETE ON ${_(t)} EXECUTE FUNCTION ${bt}()`)};return(A?dt:ut)(t,R,(async t=>{await R(`CREATE OR REPLACE FUNCTION ${Pt}()RETURNS event_trigger AS $t2$ DECLARE row record; BEGIN FOR row IN SELECT object_identity FROM pg_event_trigger_ddl_commands()WHERE command_tag='CREATE TABLE' LOOP PERFORM pg_notify('${ht}','c:'||SPLIT_PART(row.object_identity,'.',2));END LOOP;END;$t2$ LANGUAGE plpgsql;`);try{await R(`CREATE EVENT TRIGGER ${Pt} ON ddl_command_end WHEN TAG IN('CREATE TABLE')EXECUTE FUNCTION ${Pt}();`)}catch{}return await R(`CREATE OR REPLACE FUNCTION ${bt}()RETURNS trigger AS $t1$ BEGIN PERFORM pg_notify('${ht}','d:'||TG_TABLE_NAME);RETURN NULL;END;$t1$ LANGUAGE plpgsql;`),await d(N(U(p),(async t=>{await R(`CREATE TABLE IF NOT EXISTS ${_(t)}("_id"text PRIMARY KEY)`),await C(t)}))),await s(ht,(async a=>{return await c((e=a,n=_t,e?.match(n)),(async([,a,e])=>{P(p,e)&&("c:"==a&&await C(e),t())}));var e,n}))}),i,o,E,w,g,U(p),(async(t,a)=>await t(`${v} table_name tn,column_name cn FROM information_schema.columns ${$} table_schema='public'AND table_name IN(${b(a)})`,a)),u,T,"text",0,(t=>K(t)),(t=>V(t)))})(t,n,r?.unsafe,(async(t,e)=>a.listen(t,e)),(async t=>{try{await t.unlisten()}catch(t){i?.(t)}}),s,i,(()=>r?.release?.()),3,a,"getSql")}},"object"==typeof exports&&"undefined"!=typeof module?a(exports):"function"==typeof define&&define.amd?define(["exports"],a):a((t="undefined"!=typeof globalThis?globalThis:t||self).TinyBasePersisterPostgres={});
1
+ var t,a;t=this,a=function(t){"use strict";const a=t=>typeof t,e="tinybase",n=",",s=a(""),i=Promise,o=t=>null==t,r=(t,a,e)=>o(t)?e?.():a(t),c=t=>a(t)==s,l=t=>Array.isArray(t),E=(t,a,e)=>t.slice(a,e),y=t=>t.length,d=async t=>i.all(t),w=t=>{throw Error(t)},u=(t,a)=>t.forEach(a),T=(t,a="")=>t.join(a),R=(t,a)=>t.map(a),A=t=>0==y(t),N=(t,a)=>t.filter(a),g=(t,...a)=>t.push(...a),p=t=>t.shift(),C="_",f="_id",O="SELECT",v="WHERE",L="TABLE",$="ALTER "+L,m="DELETE FROM",S=O+"*FROM",I=t=>`"${t.replace(/"/g,'""')}"`,h=(t,a=[1])=>T(R(t,(()=>"$"+a[0]++)),n),_=(t,a)=>t?.has(a)??!1,b=t=>o(t)||0==(t=>t?.size??0)(t),P=t=>[...t?.values()??[]],D=(t,a)=>t?.forEach(a),U=(t,a)=>t?.delete(a),F=Object,M=t=>F.getPrototypeOf(t),G=F.entries,B=F.keys,j=F.freeze,x=(t=[])=>F.fromEntries(t),X=(...t)=>F.assign({},...t),Y=(t,a)=>(delete t[a],t),q=(t,a)=>R(G(t),(([t,e])=>a(e,t))),H=t=>F.values(t),W=t=>y(B(t)),k=t=>(t=>!o(t)&&r(M(t),(t=>t==F.prototype||o(M(t))),(()=>!0)))(t)&&0==W(t),z=JSON.stringify,J=JSON.parse,K=t=>new Map(t),V=(t,a)=>t?.get(a),Q=(t,a)=>R([...t?.entries()??[]],(([t,e])=>a(e,t))),Z=(t,a,e)=>o(e)?(U(t,a),t):t?.set(a,e),tt=(t,a,e,n)=>(_(t,a)?n?.(V(t,a)):Z(t,a,e()),V(t,a)),at=(t,a,e,n,s=0)=>r((e?tt:V)(t,a[s],s>y(a)-2?e:K),(i=>{if(s>y(a)-2)return n?.(i)&&Z(t,a[s]),i;const o=at(i,a,e,n,s+1);return b(i)&&Z(t,a[s]),o})),et=t=>new Set(l(t)||o(t)?t:[t]),nt=(t,a)=>t?.add(a),st=/^\d+$/,it=K(),ot=K(),rt=(t,a,e,n,s,i,c,E={},d=[])=>{let T,R,A,N=0,C=0,f=0;tt(it,d,(()=>0)),tt(ot,d,(()=>[]));const O=K(),[v,L,$,m,S]=((t=1,a)=>1!=t&&a.isMergeable()?[1,a.getMergeableContent,a.getTransactionMergeableChanges,([[t],[a]])=>!k(t)||!k(a),a.setDefaultContent]:2!=t?[0,a.getContent,a.getTransactionChanges,([t,a])=>!k(t)||!k(a),a.setContent]:w("Store type not supported by this Persister"))(c,t),[I,h,_]=(()=>{let t;const[a,e]=(()=>{const t=[];let a=0;return[e=>(e?p(t):null)??""+a++,a=>{st.test(a)&&y(t)<1e3&&g(t,a)}]})(),n=K();return[(e,s,i,o=[],r=()=>[])=>{t??=Y;const c=a(1);return Z(n,c,[e,s,i,o,r]),nt(at(s,i??[""],et),c),c},(a,e,...s)=>u(((t,a=[""])=>{const e=[],n=(t,s)=>s==y(a)?g(e,t):null===a[s]?D(t,(t=>n(t,s+1))):u([a[s],null],(a=>n(V(t,a),s+1)));return n(t,0),e})(a,e),(a=>D(a,(a=>V(n,a)[0](t,...e??[],...s))))),t=>r(V(n,t),(([,a,s])=>(at(a,s??[""],void 0,(a=>(U(a,t),b(a)?1:0))),Z(n,t),e(t),s))),a=>r(V(n,a),(([a,,e=[],n,s])=>{const i=(...r)=>{const c=y(r);c==y(e)?a(t,...r,...s(r)):o(e[c])?u(n[c]?.(...r)??[],(t=>i(...r,t))):i(...r,e[c])};i()}))]})(),P=t=>{t!=N&&(N=t,h(O,void 0,N))},F=a=>{(v&&l(a?.[0])?1===a?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===a?.[2]?t.applyChanges:t.setContent)(a)},M=async t=>(2!=N&&(P(1),C++,await X((async()=>{try{const e=await a();l(e)?F(e):t?S(t):w("Content is not an array "+e)}catch(a){i?.(a),t&&S(t)}P(0)}))),Y),G=()=>(R&&(s(R),R=void 0),Y),B=async t=>(1!=N&&(P(2),f++,await X((async()=>{try{await e(L,t)}catch(t){i?.(t)}P(0)}))),Y),x=()=>(r(A,t.delListener),A=void 0,Y),X=async(...t)=>(g(V(ot,d),...t),await(async()=>{if(!V(it,d)){for(Z(it,d,1);!o(T=p(V(ot,d)));)try{await T()}catch(t){i?.(t)}Z(it,d,0)}})(),Y),Y={load:M,startAutoLoad:async t=>{await G().load(t);try{R=await n((async(t,a)=>{a||t?2!=N&&(P(1),C++,F(a??t),P(0)):await M()}))}catch(t){i?.(t)}return Y},stopAutoLoad:G,isAutoLoading:()=>!o(R),save:B,startAutoSave:async()=>(await x().save(),A=t.addDidFinishTransactionListener((()=>{const t=$();m(t)&&B(t)})),Y),stopAutoSave:x,isAutoSaving:()=>!o(A),getStatus:()=>N,addStatusListener:t=>I(t,O),delListener:a=>(_(a),t),schedule:X,getStore:()=>t,destroy:()=>(V(ot,d).splice(0,void 0),G().stopAutoSave()),getStats:()=>({loads:C,saves:f}),...E};return j(Y)},ct=(t,a,e,s,i,r=lt,c,l)=>{const E=K();return[async()=>{E.clear(),R(await e(t,a),(({tn:t,cn:a})=>nt(tt(E,t,et),a)))},async(a,e)=>((t,a)=>_(V(E,t),a))(a,e)?x(N(R(await t(S+I(a)),(t=>{return[t[e],l?(a=Y(t,e),n=l,x(q(a,((t,a)=>[a,n(t,a)])))):Y(t,e)];var a,n})),(([t,a])=>!o(t)&&!k(a)))):{},async(a,e,s,l,y,w=!1)=>{const u=et();q(s??{},(t=>R(B(t??{}),(t=>nt(u,t)))));const p=P(u);if(!w&&y&&A(p)&&_(E,a))return await t("DROP "+L+I(a)),void Z(E,a);const C=V(E,a),f=et(P(C));if(A(p)||(_(E,a)?await d(R([e,...p],(async(n,s)=>{U(f,n)||(await t($+I(a)+"ADD"+I(n)+i),0==s&&await t("CREATE UNIQUE INDEX pk ON "+I(a)+`(${I(e)})`),nt(C,n))}))):(await t("CREATE "+L+I(a)+`(${I(e)}${i} PRIMARY KEY${T(R(p,(t=>n+I(t)+i)))});`),Z(E,a,et([e,...p])))),await d([...!w&&l?R(P(f),(async n=>{n!=e&&(await t($+I(a)+"DROP"+I(n)),U(C,n))})):[]]),w)o(s)?await t(m+I(a)+v+" true"):await d(q(s,(async(n,s)=>{o(n)?await t(m+I(a)+v+I(e)+"=$1",[s]):A(p)||await r(t,a,e,B(n),{[s]:c?R(H(n),c):H(n)},C)})));else if(A(p))_(E,a)&&await t(m+I(a)+v+" true");else{const n=N(P(V(E,a)),(t=>t!=e)),i={},o=[];q(s??{},((t,a)=>{i[a]=R(n,(a=>c?c(t?.[a]):t?.[a])),g(o,a)})),await r(t,a,e,n,i),await t(m+I(a)+v+I(e)+`NOT IN(${h(o)})`,o)}},async a=>{let e;await t("BEGIN");try{e=await a()}catch(t){s?.(t)}return await t("END"),e}]},lt=async(t,a,e,s,i)=>{const o=[1];await t("INSERT INTO"+I(a)+"("+((...t)=>T(R(t,I),n))(e,...s)+")VALUES"+T(q(i,(t=>"($"+o[0]+++","+h(t,o)+")")),n)+"ON CONFLICT("+I(e)+")DO UPDATE SET"+T(R(s,(t=>I(t)+"=excluded."+I(t))),n),q(i,((t,a)=>[a,...R(t,(t=>t??null))])).flat())},Et=(t,a,e,n,s,i,o,[r,c,l],E,y,d,w,u,T)=>{const[R,A,N,g]=ct(a,E,y,s,u,T),p=rt(t,(async()=>await g((async()=>{return await R(),t=(await A(r,c))[C]?.[l]??"null",J(t,((t,a)=>""===a?void 0:a));var t}))),(async t=>await g((async()=>{var a;await R(),await N(r,c,{[C]:{[l]:(a=t()??null,z(a,((t,a)=>void 0===a?"":a)))}},!0,!0)}))),e,n,s,o,{[w]:()=>d,destroy:()=>(p.stopAutoLoad().stopAutoSave(),i(),p)},d);return p},yt=(t,a,e,n,s,i,r,[c,l,[E,y,w]],u,T,R,A,g,p,O,v)=>{const[L,$,m,S]=ct(a,u,T,s,g,p,O,v),I=async(t,a)=>await d(Q(l,(async([e,n,s,i],o)=>{a&&!(o in t)||await m(e,n,t[o],s,i,a)}))),h=async(t,a)=>y?await m(w,f,{[C]:t},!0,!0,a):null,_=rt(t,(async()=>await S((async()=>{await L();const t=await(async()=>x(N(await d(Q(c,(async([t,a],e)=>[t,await $(e,a)]))),(t=>!k(t[1])))))(),a=await(async()=>E?(await $(w,f))[C]:{})();return k(t)&&o(a)?void 0:[t,a]}))),(async(t,a)=>await S((async()=>{if(await L(),o(a)){const[a,e]=t();await I(a),await h(e)}else await I(a[0],!0),await h(a[1],!0)}))),e,n,s,r,{[A]:()=>R,destroy:()=>(_.stopAutoLoad().stopAutoSave(),i(),_)},R);return _},dt="ColumnName",wt="store",ut="json",Tt=wt+"TableName",Rt=wt+"Id"+dt,At=wt+dt,Nt="autoLoadIntervalSeconds",gt="rowId"+dt,pt="tableId",Ct="tableName",ft="deleteEmptyColumns",Ot="deleteEmptyTable",vt={mode:ut,[Nt]:1},Lt={load:0,save:0,[Ct]:e+"_values"},$t=(t,a,e,n,s)=>{const i=K();return q(t,((t,r)=>{const l=E(H(X(a,c(t)?{[e]:t}:t)),0,W(a));o(l[0])||n(r,l[0])||(s(r,l[0]),Z(i,r,l))})),i},mt=e,St=/^([cd]:)(.+)/,It=e+"_data",ht=e+"_table";t.createPostgresPersister=async(t,a,n,s,i)=>{const o=await(a.reserve?.());return((t,a,n,s,i,o,l,y,w,u,T="getDb")=>{const A=((t,a)=>a?async(e,n)=>(a(e,n),await t(e,n)):t)(n,o),[N,,g,p]=(t=>{const a=(t=>X(vt,c(t)?{[Tt]:t}:t??{}))(t),n=a[Nt];if(a.mode==ut){const t=a[Tt]??e;return[1,n,[t,a[Rt]??f,a[At]??wt],et(t)]}const{tables:{load:s={},save:i={}}={},values:o={}}=a,r=E(H(X(Lt,o)),0,W(Lt)),l=r[2],y=et(l),d=et(l);return[0,n,[$t(s,{[pt]:null,[gt]:f},pt,(t=>_(d,t)),(t=>nt(y,t))),$t(i,{[Ct]:null,[gt]:f,[ft]:0,[Ot]:0},Ct,((t,a)=>_(d,a)),((t,a)=>nt(y,a))),r],y]})(a),C=async t=>{await A(`CREATE OR REPLACE TRIGGER ${I(It+"_"+t)} AFTER INSERT OR UPDATE OR DELETE ON ${I(t)} EXECUTE FUNCTION ${It}()`)};return(N?Et:yt)(t,A,(async t=>{await A(`CREATE OR REPLACE FUNCTION ${ht}()RETURNS event_trigger AS $t2$ DECLARE row record; BEGIN FOR row IN SELECT object_identity FROM pg_event_trigger_ddl_commands()WHERE command_tag='CREATE TABLE' LOOP PERFORM pg_notify('${mt}','c:'||SPLIT_PART(row.object_identity,'.',2));END LOOP;END;$t2$ LANGUAGE plpgsql;`);try{await A(`CREATE EVENT TRIGGER ${ht} ON ddl_command_end WHEN TAG IN('CREATE TABLE')EXECUTE FUNCTION ${ht}();`)}catch{}return await A(`CREATE OR REPLACE FUNCTION ${It}()RETURNS trigger AS $t1$ BEGIN PERFORM pg_notify('${mt}','d:'||TG_TABLE_NAME);RETURN NULL;END;$t1$ LANGUAGE plpgsql;`),await d(R(P(p),(async t=>{await A(`CREATE TABLE IF NOT EXISTS ${I(t)}("_id"text PRIMARY KEY)`),await C(t)}))),await s(mt,(async a=>{return await r((e=a,n=St,e?.match(n)),(async([,a,e])=>{_(p,e)&&("c:"==a&&await C(e),t())}));var e,n}))}),i,l,y,w,g,P(p),(async(t,a)=>await t(`${O} table_name tn,column_name cn FROM information_schema.columns ${v} table_schema='public'AND table_name IN(${h(a)})`,a)),u,T,"text",void 0,(t=>z(t)),(t=>J(t)))})(t,n,o?.unsafe,(async(t,e)=>a.listen(t,e)),(async t=>{try{await t.unlisten()}catch(t){i?.(t)}}),s,i,(()=>o?.release?.()),3,a,"getSql")}},"object"==typeof exports&&"undefined"!=typeof module?a(exports):"function"==typeof define&&define.amd?define(["exports"],a):a((t="undefined"!=typeof globalThis?globalThis:t||self).TinyBasePersisterPostgres={});
@@ -1 +1 @@
1
- var t,a;t=this,a=function(t){"use strict";const a=t=>typeof t,e="tinybase",n="",s=",",i=a(n),r=Promise,o=t=>null==t,c=(t,a,e)=>o(t)?e?.():a(t),l=t=>a(t)==i,E=t=>Array.isArray(t),y=(t,a,e)=>t.slice(a,e),w=t=>t.length,d=async t=>r.all(t),u=t=>{throw Error(t)},T=(t,a)=>N(Array(t).fill(0),((t,e)=>a(e))),R=(t,a)=>t.forEach(a),A=(t,a="")=>t.join(a),N=(t,a)=>t.map(a),g=t=>0==w(t),p=(t,a)=>t.filter(a),C=(t,...a)=>t.push(...a),O=t=>t.shift(),f="_",L="_id",v="SELECT",$="WHERE",m="TABLE",S="ALTER "+m,I="DELETE FROM",h=v+"*FROM",_=t=>`"${t.replace(/"/g,'""')}"`,b=t=>A(N(t,((t,a)=>"$"+(a+1))),s),P=(t,a)=>t?.has(a)??!1,D=t=>o(t)||0==(t=>t?.size??0)(t),U=t=>[...t?.values()??[]],F=(t,a)=>t?.forEach(a),M=(t,a)=>t?.delete(a),G=Object,B=t=>G.getPrototypeOf(t),j=G.entries,x=G.keys,X=G.freeze,Y=(t=[])=>G.fromEntries(t),q=(...t)=>G.assign({},...t),H=(t,a)=>(delete t[a],t),W=(t,a)=>N(j(t),(([t,e])=>a(e,t))),k=t=>G.values(t),z=t=>w(x(t)),J=t=>(t=>!o(t)&&c(B(t),(t=>t==G.prototype||o(B(t))),(()=>!0)))(t)&&0==z(t),K=JSON.stringify,V=JSON.parse,Q=t=>new Map(t),Z=(t,a)=>t?.get(a),tt=(t,a)=>N([...t?.entries()??[]],(([t,e])=>a(e,t))),at=(t,a,e)=>o(e)?(M(t,a),t):t?.set(a,e),et=(t,a,e,n)=>(P(t,a)?n?.(Z(t,a)):at(t,a,e()),Z(t,a)),nt=(t,a,e,n,s=0)=>c((e?et:Z)(t,a[s],s>w(a)-2?e:Q),(i=>{if(s>w(a)-2)return n?.(i)&&at(t,a[s]),i;const r=nt(i,a,e,n,s+1);return D(i)&&at(t,a[s]),r})),st=t=>new Set(E(t)||o(t)?t:[t]),it=(t,a)=>t?.add(a),rt=/^\d+$/,ot=Q(),ct=Q(),lt=(t,a,e,s,i,r,l,y={},d=[])=>{let T,A,N,g=0,p=0,f=0;et(ot,d,(()=>0)),et(ct,d,(()=>[]));const L=Q(),[v,$,m,S,I]=((t=1,a)=>1!=t&&a.isMergeable()?[1,a.getMergeableContent,a.getTransactionMergeableChanges,([[t],[a]])=>!J(t)||!J(a),a.setDefaultContent]:2!=t?[0,a.getContent,a.getTransactionChanges,([t,a])=>!J(t)||!J(a),a.setContent]:u("Store type not supported by this Persister"))(l,t),[h,_,b]=(()=>{let t;const[a,e]=(()=>{const t=[];let a=0;return[e=>(e?O(t):null)??n+a++,a=>{rt.test(a)&&w(t)<1e3&&C(t,a)}]})(),s=Q();return[(e,i,r,o=[],c=()=>[])=>{t??=q;const l=a(1);return at(s,l,[e,i,r,o,c]),it(nt(i,r??[n],st),l),l},(a,e,...i)=>R(((t,a=[n])=>{const e=[],s=(t,n)=>n==w(a)?C(e,t):null===a[n]?F(t,(t=>s(t,n+1))):R([a[n],null],(a=>s(Z(t,a),n+1)));return s(t,0),e})(a,e),(a=>F(a,(a=>Z(s,a)[0](t,...e??[],...i))))),t=>c(Z(s,t),(([,a,i])=>(nt(a,i??[n],void 0,(a=>(M(a,t),D(a)?1:0))),at(s,t),e(t),i))),a=>c(Z(s,a),(([a,,e=[],n,s])=>{const i=(...r)=>{const c=w(r);c==w(e)?a(t,...r,...s(r)):o(e[c])?R(n[c]?.(...r)??[],(t=>i(...r,t))):i(...r,e[c])};i()}))]})(),P=t=>{t!=g&&(g=t,_(L,void 0,g))},U=a=>{(v&&E(a?.[0])?1===a?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===a?.[2]?t.applyChanges:t.setContent)(a)},G=async t=>(2!=g&&(P(1),p++,await Y((async()=>{try{const t=await a();E(t)?U(t):u("Content is not an array "+t)}catch(a){r?.(a),t&&I(t)}P(0)}))),q),B=()=>(A&&(i(A),A=void 0),q),j=async t=>(1!=g&&(P(2),f++,await Y((async()=>{try{await e($,t)}catch(t){r?.(t)}P(0)}))),q),x=()=>(c(N,t.delListener),N=void 0,q),Y=async(...t)=>(C(Z(ct,d),...t),await(async()=>{if(!Z(ot,d)){for(at(ot,d,1);!o(T=O(Z(ct,d)));)try{await T()}catch(t){r?.(t)}at(ot,d,0)}})(),q),q={load:G,startAutoLoad:async t=>{await B().load(t);try{A=await s((async(t,a)=>{a||t?2!=g&&(P(1),p++,U(a??t),P(0)):await G()}))}catch(t){r?.(t)}return q},stopAutoLoad:B,isAutoLoading:()=>!o(A),save:j,startAutoSave:async()=>(await x().save(),N=t.addDidFinishTransactionListener((()=>{const t=m();S(t)&&j(t)})),q),stopAutoSave:x,isAutoSaving:()=>!o(N),getStatus:()=>g,addStatusListener:t=>h(t,L),delListener:a=>(b(a),t),schedule:Y,getStore:()=>t,destroy:()=>(Z(ct,d).splice(0,void 0),B().stopAutoSave()),getStats:()=>({loads:p,saves:f}),...y};return X(q)},Et=(t,a,e,n,i,r,c,l)=>{const E=Q();return[async()=>{E.clear(),N(await e(t,a),(({tn:t,cn:a})=>it(et(E,t,st),a)))},async(a,e)=>((t,a)=>P(Z(E,t),a))(a,e)?Y(p(N(await t(h+_(a)),(t=>{return[t[e],l?(a=H(t,e),n=l,Y(W(a,((t,a)=>[a,n(t,a)])))):H(t,e)];var a,n})),(([t,a])=>!o(t)&&!J(a)))):{},async(a,e,n,l,y,w=!1)=>{const u=st();W(n??{},(t=>N(x(t??{}),(t=>it(u,t)))));const T=U(u);if(!w&&y&&g(T)&&P(E,a))return await t("DROP "+m+_(a)),void at(E,a);const R=Z(E,a),O=st(U(R));if(g(T)||(P(E,a)?await d(N([e,...T],(async(n,s)=>{M(O,n)||(await t(S+_(a)+"ADD"+_(n)+i),0==s&&await t("CREATE UNIQUE INDEX pk ON "+_(a)+`(${_(e)})`),it(R,n))}))):(await t("CREATE "+m+_(a)+`(${_(e)}${i} PRIMARY KEY${A(N(T,(t=>s+_(t)+i)))});`),at(E,a,st([e,...T])))),await d([...!w&&l?N(U(O),(async n=>{n!=e&&(await t(S+_(a)+"DROP"+_(n)),M(R,n))})):[]]),w)o(n)?await t(I+_(a)+$+" true"):await d(W(n,(async(n,s)=>{o(n)?await t(I+_(a)+$+_(e)+"=$1",[s]):g(T)||await yt(t,a,e,x(n),[s,...c?N(k(n),c):k(n)],r)})));else if(g(T))P(E,a)&&await t(I+_(a)+$+" true");else{const s=p(U(Z(E,a)),(t=>t!=e)),i=[],o=[];W(n??{},((t,a)=>{C(i,a,...N(s,(a=>c?c(t?.[a]):t?.[a]))),C(o,a)})),await yt(t,a,e,s,i,r),await t(I+_(a)+$+_(e)+`NOT IN(${b(o)})`,o)}},async a=>{let e;await t("BEGIN");try{e=await a()}catch(t){n?.(t)}return await t("END"),e}]},yt=async(t,a,e,i,r,o=0)=>await t("INSERT "+(o?"OR REPLACE ":n)+"INTO"+_(a)+"("+_(e)+A(N(i,(t=>s+_(t))))+")VALUES"+wt(r,w(i)+1)+(o?n:"ON CONFLICT("+_(e)+")DO UPDATE SET"+A(N(i,(t=>_(t)+"=excluded."+_(t))),s)),N(r,(t=>t??null))),wt=(t,a)=>A(T(w(t)/a,(t=>"("+A(T(a,(e=>"$"+(t*a+e+1))),s)+")")),s),dt=(t,a,e,n,s,i,r,[o,c,l],E,y,w,d,u,T)=>{const[R,A,N,g]=Et(a,E,y,s,u,T),p=lt(t,(async()=>await g((async()=>{return await R(),t=(await A(o,c))[f]?.[l]??"null",V(t,((t,a)=>""===a?void 0:a));var t}))),(async t=>await g((async()=>{var a;await R(),await N(o,c,{[f]:{[l]:(a=t()??null,K(a,((t,a)=>void 0===a?"":a)))}},!0,!0)}))),e,n,s,r,{[d]:()=>w,destroy:()=>(p.stopAutoLoad().stopAutoSave(),i(),p)},w);return p},ut=(t,a,e,n,s,i,r,[c,l,[E,y,w]],u,T,R,A,N,g,C,O)=>{const[v,$,m,S]=Et(a,u,T,s,N,g,C,O),I=async(t,a)=>await d(tt(l,(async([e,n,s,i],r)=>{a&&!(r in t)||await m(e,n,t[r],s,i,a)}))),h=async(t,a)=>y?await m(w,L,{[f]:t},!0,!0,a):null,_=lt(t,(async()=>await S((async()=>{await v();const t=await(async()=>Y(p(await d(tt(c,(async([t,a],e)=>[t,await $(e,a)]))),(t=>!J(t[1])))))(),a=await(async()=>E?(await $(w,L))[f]:{})();return J(t)&&o(a)?void 0:[t,a]}))),(async(t,a)=>await S((async()=>{if(await v(),o(a)){const[a,e]=t();await I(a),await h(e)}else await I(a[0],!0),await h(a[1],!0)}))),e,n,s,r,{[A]:()=>R,destroy:()=>(_.stopAutoLoad().stopAutoSave(),i(),_)},R);return _},Tt="ColumnName",Rt="store",At="json",Nt=Rt+"TableName",gt=Rt+"Id"+Tt,pt=Rt+Tt,Ct="autoLoadIntervalSeconds",Ot="rowId"+Tt,ft="tableId",Lt="tableName",vt="deleteEmptyColumns",$t="deleteEmptyTable",mt={mode:At,[Ct]:1},St={load:0,save:0,[Lt]:e+"_values"},It=(t,a,e,n,s)=>{const i=Q();return W(t,((t,r)=>{const c=y(k(q(a,l(t)?{[e]:t}:t)),0,z(a));o(c[0])||n(r,c[0])||(s(r,c[0]),at(i,r,c))})),i},ht=e,_t=/^([cd]:)(.+)/,bt=e+"_data",Pt=e+"_table";t.createPostgresPersister=async(t,a,n,s,i)=>{const r=await(a.reserve?.());return((t,a,n,s,i,r,o,E,w,u,T="getDb")=>{const R=((t,a)=>a?async(e,n)=>(a(e,n),await t(e,n)):t)(n,r),[A,,g,p]=(t=>{const a=(t=>q(mt,l(t)?{[Nt]:t}:t??{}))(t),n=a[Ct];if(a.mode==At){const t=a[Nt]??e;return[1,n,[t,a[gt]??L,a[pt]??Rt],st(t)]}const{tables:{load:s={},save:i={}}={},values:r={}}=a,o=y(k(q(St,r)),0,z(St)),c=o[2],E=st(c),w=st(c);return[0,n,[It(s,{[ft]:null,[Ot]:L},ft,(t=>P(w,t)),(t=>it(E,t))),It(i,{[Lt]:null,[Ot]:L,[vt]:0,[$t]:0},Lt,((t,a)=>P(w,a)),((t,a)=>it(E,a))),o],E]})(a),C=async t=>{await R(`CREATE OR REPLACE TRIGGER ${_(bt+"_"+t)} AFTER INSERT OR UPDATE OR DELETE ON ${_(t)} EXECUTE FUNCTION ${bt}()`)};return(A?dt:ut)(t,R,(async t=>{await R(`CREATE OR REPLACE FUNCTION ${Pt}()RETURNS event_trigger AS $t2$ DECLARE row record; BEGIN FOR row IN SELECT object_identity FROM pg_event_trigger_ddl_commands()WHERE command_tag='CREATE TABLE' LOOP PERFORM pg_notify('${ht}','c:'||SPLIT_PART(row.object_identity,'.',2));END LOOP;END;$t2$ LANGUAGE plpgsql;`);try{await R(`CREATE EVENT TRIGGER ${Pt} ON ddl_command_end WHEN TAG IN('CREATE TABLE')EXECUTE FUNCTION ${Pt}();`)}catch{}return await R(`CREATE OR REPLACE FUNCTION ${bt}()RETURNS trigger AS $t1$ BEGIN PERFORM pg_notify('${ht}','d:'||TG_TABLE_NAME);RETURN NULL;END;$t1$ LANGUAGE plpgsql;`),await d(N(U(p),(async t=>{await R(`CREATE TABLE IF NOT EXISTS ${_(t)}("_id"text PRIMARY KEY)`),await C(t)}))),await s(ht,(async a=>{return await c((e=a,n=_t,e?.match(n)),(async([,a,e])=>{P(p,e)&&("c:"==a&&await C(e),t())}));var e,n}))}),i,o,E,w,g,U(p),(async(t,a)=>await t(`${v} table_name tn,column_name cn FROM information_schema.columns ${$} table_schema='public'AND table_name IN(${b(a)})`,a)),u,T,"text",0,(t=>K(t)),(t=>V(t)))})(t,n,r?.unsafe,(async(t,e)=>a.listen(t,e)),(async t=>{try{await t.unlisten()}catch(t){i?.(t)}}),s,i,(()=>r?.release?.()),3,a,"getSql")}},"object"==typeof exports&&"undefined"!=typeof module?a(exports):"function"==typeof define&&define.amd?define(["exports"],a):a((t="undefined"!=typeof globalThis?globalThis:t||self).TinyBasePersisterPostgres={});
1
+ var t,a;t=this,a=function(t){"use strict";const a=t=>typeof t,e="tinybase",n=",",s=a(""),i=Promise,o=t=>null==t,r=(t,a,e)=>o(t)?e?.():a(t),c=t=>a(t)==s,l=t=>Array.isArray(t),E=(t,a,e)=>t.slice(a,e),y=t=>t.length,d=async t=>i.all(t),w=t=>{throw Error(t)},u=(t,a)=>t.forEach(a),T=(t,a="")=>t.join(a),R=(t,a)=>t.map(a),A=t=>0==y(t),N=(t,a)=>t.filter(a),g=(t,...a)=>t.push(...a),p=t=>t.shift(),C="_",f="_id",O="SELECT",v="WHERE",L="TABLE",$="ALTER "+L,m="DELETE FROM",S=O+"*FROM",I=t=>`"${t.replace(/"/g,'""')}"`,h=(t,a=[1])=>T(R(t,(()=>"$"+a[0]++)),n),_=(t,a)=>t?.has(a)??!1,b=t=>o(t)||0==(t=>t?.size??0)(t),P=t=>[...t?.values()??[]],D=(t,a)=>t?.forEach(a),U=(t,a)=>t?.delete(a),F=Object,M=t=>F.getPrototypeOf(t),G=F.entries,B=F.keys,j=F.freeze,x=(t=[])=>F.fromEntries(t),X=(...t)=>F.assign({},...t),Y=(t,a)=>(delete t[a],t),q=(t,a)=>R(G(t),(([t,e])=>a(e,t))),H=t=>F.values(t),W=t=>y(B(t)),k=t=>(t=>!o(t)&&r(M(t),(t=>t==F.prototype||o(M(t))),(()=>!0)))(t)&&0==W(t),z=JSON.stringify,J=JSON.parse,K=t=>new Map(t),V=(t,a)=>t?.get(a),Q=(t,a)=>R([...t?.entries()??[]],(([t,e])=>a(e,t))),Z=(t,a,e)=>o(e)?(U(t,a),t):t?.set(a,e),tt=(t,a,e,n)=>(_(t,a)?n?.(V(t,a)):Z(t,a,e()),V(t,a)),at=(t,a,e,n,s=0)=>r((e?tt:V)(t,a[s],s>y(a)-2?e:K),(i=>{if(s>y(a)-2)return n?.(i)&&Z(t,a[s]),i;const o=at(i,a,e,n,s+1);return b(i)&&Z(t,a[s]),o})),et=t=>new Set(l(t)||o(t)?t:[t]),nt=(t,a)=>t?.add(a),st=/^\d+$/,it=K(),ot=K(),rt=(t,a,e,n,s,i,c,E={},d=[])=>{let T,R,A,N=0,C=0,f=0;tt(it,d,(()=>0)),tt(ot,d,(()=>[]));const O=K(),[v,L,$,m,S]=((t=1,a)=>1!=t&&a.isMergeable()?[1,a.getMergeableContent,a.getTransactionMergeableChanges,([[t],[a]])=>!k(t)||!k(a),a.setDefaultContent]:2!=t?[0,a.getContent,a.getTransactionChanges,([t,a])=>!k(t)||!k(a),a.setContent]:w("Store type not supported by this Persister"))(c,t),[I,h,_]=(()=>{let t;const[a,e]=(()=>{const t=[];let a=0;return[e=>(e?p(t):null)??""+a++,a=>{st.test(a)&&y(t)<1e3&&g(t,a)}]})(),n=K();return[(e,s,i,o=[],r=()=>[])=>{t??=Y;const c=a(1);return Z(n,c,[e,s,i,o,r]),nt(at(s,i??[""],et),c),c},(a,e,...s)=>u(((t,a=[""])=>{const e=[],n=(t,s)=>s==y(a)?g(e,t):null===a[s]?D(t,(t=>n(t,s+1))):u([a[s],null],(a=>n(V(t,a),s+1)));return n(t,0),e})(a,e),(a=>D(a,(a=>V(n,a)[0](t,...e??[],...s))))),t=>r(V(n,t),(([,a,s])=>(at(a,s??[""],void 0,(a=>(U(a,t),b(a)?1:0))),Z(n,t),e(t),s))),a=>r(V(n,a),(([a,,e=[],n,s])=>{const i=(...r)=>{const c=y(r);c==y(e)?a(t,...r,...s(r)):o(e[c])?u(n[c]?.(...r)??[],(t=>i(...r,t))):i(...r,e[c])};i()}))]})(),P=t=>{t!=N&&(N=t,h(O,void 0,N))},F=a=>{(v&&l(a?.[0])?1===a?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===a?.[2]?t.applyChanges:t.setContent)(a)},M=async t=>(2!=N&&(P(1),C++,await X((async()=>{try{const e=await a();l(e)?F(e):t?S(t):w("Content is not an array "+e)}catch(a){i?.(a),t&&S(t)}P(0)}))),Y),G=()=>(R&&(s(R),R=void 0),Y),B=async t=>(1!=N&&(P(2),f++,await X((async()=>{try{await e(L,t)}catch(t){i?.(t)}P(0)}))),Y),x=()=>(r(A,t.delListener),A=void 0,Y),X=async(...t)=>(g(V(ot,d),...t),await(async()=>{if(!V(it,d)){for(Z(it,d,1);!o(T=p(V(ot,d)));)try{await T()}catch(t){i?.(t)}Z(it,d,0)}})(),Y),Y={load:M,startAutoLoad:async t=>{await G().load(t);try{R=await n((async(t,a)=>{a||t?2!=N&&(P(1),C++,F(a??t),P(0)):await M()}))}catch(t){i?.(t)}return Y},stopAutoLoad:G,isAutoLoading:()=>!o(R),save:B,startAutoSave:async()=>(await x().save(),A=t.addDidFinishTransactionListener((()=>{const t=$();m(t)&&B(t)})),Y),stopAutoSave:x,isAutoSaving:()=>!o(A),getStatus:()=>N,addStatusListener:t=>I(t,O),delListener:a=>(_(a),t),schedule:X,getStore:()=>t,destroy:()=>(V(ot,d).splice(0,void 0),G().stopAutoSave()),getStats:()=>({loads:C,saves:f}),...E};return j(Y)},ct=(t,a,e,s,i,r=lt,c,l)=>{const E=K();return[async()=>{E.clear(),R(await e(t,a),(({tn:t,cn:a})=>nt(tt(E,t,et),a)))},async(a,e)=>((t,a)=>_(V(E,t),a))(a,e)?x(N(R(await t(S+I(a)),(t=>{return[t[e],l?(a=Y(t,e),n=l,x(q(a,((t,a)=>[a,n(t,a)])))):Y(t,e)];var a,n})),(([t,a])=>!o(t)&&!k(a)))):{},async(a,e,s,l,y,w=!1)=>{const u=et();q(s??{},(t=>R(B(t??{}),(t=>nt(u,t)))));const p=P(u);if(!w&&y&&A(p)&&_(E,a))return await t("DROP "+L+I(a)),void Z(E,a);const C=V(E,a),f=et(P(C));if(A(p)||(_(E,a)?await d(R([e,...p],(async(n,s)=>{U(f,n)||(await t($+I(a)+"ADD"+I(n)+i),0==s&&await t("CREATE UNIQUE INDEX pk ON "+I(a)+`(${I(e)})`),nt(C,n))}))):(await t("CREATE "+L+I(a)+`(${I(e)}${i} PRIMARY KEY${T(R(p,(t=>n+I(t)+i)))});`),Z(E,a,et([e,...p])))),await d([...!w&&l?R(P(f),(async n=>{n!=e&&(await t($+I(a)+"DROP"+I(n)),U(C,n))})):[]]),w)o(s)?await t(m+I(a)+v+" true"):await d(q(s,(async(n,s)=>{o(n)?await t(m+I(a)+v+I(e)+"=$1",[s]):A(p)||await r(t,a,e,B(n),{[s]:c?R(H(n),c):H(n)},C)})));else if(A(p))_(E,a)&&await t(m+I(a)+v+" true");else{const n=N(P(V(E,a)),(t=>t!=e)),i={},o=[];q(s??{},((t,a)=>{i[a]=R(n,(a=>c?c(t?.[a]):t?.[a])),g(o,a)})),await r(t,a,e,n,i),await t(m+I(a)+v+I(e)+`NOT IN(${h(o)})`,o)}},async a=>{let e;await t("BEGIN");try{e=await a()}catch(t){s?.(t)}return await t("END"),e}]},lt=async(t,a,e,s,i)=>{const o=[1];await t("INSERT INTO"+I(a)+"("+((...t)=>T(R(t,I),n))(e,...s)+")VALUES"+T(q(i,(t=>"($"+o[0]+++","+h(t,o)+")")),n)+"ON CONFLICT("+I(e)+")DO UPDATE SET"+T(R(s,(t=>I(t)+"=excluded."+I(t))),n),q(i,((t,a)=>[a,...R(t,(t=>t??null))])).flat())},Et=(t,a,e,n,s,i,o,[r,c,l],E,y,d,w,u,T)=>{const[R,A,N,g]=ct(a,E,y,s,u,T),p=rt(t,(async()=>await g((async()=>{return await R(),t=(await A(r,c))[C]?.[l]??"null",J(t,((t,a)=>""===a?void 0:a));var t}))),(async t=>await g((async()=>{var a;await R(),await N(r,c,{[C]:{[l]:(a=t()??null,z(a,((t,a)=>void 0===a?"":a)))}},!0,!0)}))),e,n,s,o,{[w]:()=>d,destroy:()=>(p.stopAutoLoad().stopAutoSave(),i(),p)},d);return p},yt=(t,a,e,n,s,i,r,[c,l,[E,y,w]],u,T,R,A,g,p,O,v)=>{const[L,$,m,S]=ct(a,u,T,s,g,p,O,v),I=async(t,a)=>await d(Q(l,(async([e,n,s,i],o)=>{a&&!(o in t)||await m(e,n,t[o],s,i,a)}))),h=async(t,a)=>y?await m(w,f,{[C]:t},!0,!0,a):null,_=rt(t,(async()=>await S((async()=>{await L();const t=await(async()=>x(N(await d(Q(c,(async([t,a],e)=>[t,await $(e,a)]))),(t=>!k(t[1])))))(),a=await(async()=>E?(await $(w,f))[C]:{})();return k(t)&&o(a)?void 0:[t,a]}))),(async(t,a)=>await S((async()=>{if(await L(),o(a)){const[a,e]=t();await I(a),await h(e)}else await I(a[0],!0),await h(a[1],!0)}))),e,n,s,r,{[A]:()=>R,destroy:()=>(_.stopAutoLoad().stopAutoSave(),i(),_)},R);return _},dt="ColumnName",wt="store",ut="json",Tt=wt+"TableName",Rt=wt+"Id"+dt,At=wt+dt,Nt="autoLoadIntervalSeconds",gt="rowId"+dt,pt="tableId",Ct="tableName",ft="deleteEmptyColumns",Ot="deleteEmptyTable",vt={mode:ut,[Nt]:1},Lt={load:0,save:0,[Ct]:e+"_values"},$t=(t,a,e,n,s)=>{const i=K();return q(t,((t,r)=>{const l=E(H(X(a,c(t)?{[e]:t}:t)),0,W(a));o(l[0])||n(r,l[0])||(s(r,l[0]),Z(i,r,l))})),i},mt=e,St=/^([cd]:)(.+)/,It=e+"_data",ht=e+"_table";t.createPostgresPersister=async(t,a,n,s,i)=>{const o=await(a.reserve?.());return((t,a,n,s,i,o,l,y,w,u,T="getDb")=>{const A=((t,a)=>a?async(e,n)=>(a(e,n),await t(e,n)):t)(n,o),[N,,g,p]=(t=>{const a=(t=>X(vt,c(t)?{[Tt]:t}:t??{}))(t),n=a[Nt];if(a.mode==ut){const t=a[Tt]??e;return[1,n,[t,a[Rt]??f,a[At]??wt],et(t)]}const{tables:{load:s={},save:i={}}={},values:o={}}=a,r=E(H(X(Lt,o)),0,W(Lt)),l=r[2],y=et(l),d=et(l);return[0,n,[$t(s,{[pt]:null,[gt]:f},pt,(t=>_(d,t)),(t=>nt(y,t))),$t(i,{[Ct]:null,[gt]:f,[ft]:0,[Ot]:0},Ct,((t,a)=>_(d,a)),((t,a)=>nt(y,a))),r],y]})(a),C=async t=>{await A(`CREATE OR REPLACE TRIGGER ${I(It+"_"+t)} AFTER INSERT OR UPDATE OR DELETE ON ${I(t)} EXECUTE FUNCTION ${It}()`)};return(N?Et:yt)(t,A,(async t=>{await A(`CREATE OR REPLACE FUNCTION ${ht}()RETURNS event_trigger AS $t2$ DECLARE row record; BEGIN FOR row IN SELECT object_identity FROM pg_event_trigger_ddl_commands()WHERE command_tag='CREATE TABLE' LOOP PERFORM pg_notify('${mt}','c:'||SPLIT_PART(row.object_identity,'.',2));END LOOP;END;$t2$ LANGUAGE plpgsql;`);try{await A(`CREATE EVENT TRIGGER ${ht} ON ddl_command_end WHEN TAG IN('CREATE TABLE')EXECUTE FUNCTION ${ht}();`)}catch{}return await A(`CREATE OR REPLACE FUNCTION ${It}()RETURNS trigger AS $t1$ BEGIN PERFORM pg_notify('${mt}','d:'||TG_TABLE_NAME);RETURN NULL;END;$t1$ LANGUAGE plpgsql;`),await d(R(P(p),(async t=>{await A(`CREATE TABLE IF NOT EXISTS ${I(t)}("_id"text PRIMARY KEY)`),await C(t)}))),await s(mt,(async a=>{return await r((e=a,n=St,e?.match(n)),(async([,a,e])=>{_(p,e)&&("c:"==a&&await C(e),t())}));var e,n}))}),i,l,y,w,g,P(p),(async(t,a)=>await t(`${O} table_name tn,column_name cn FROM information_schema.columns ${v} table_schema='public'AND table_name IN(${h(a)})`,a)),u,T,"text",void 0,(t=>z(t)),(t=>J(t)))})(t,n,o?.unsafe,(async(t,e)=>a.listen(t,e)),(async t=>{try{await t.unlisten()}catch(t){i?.(t)}}),s,i,(()=>o?.release?.()),3,a,"getSql")}},"object"==typeof exports&&"undefined"!=typeof module?a(exports):"function"==typeof define&&define.amd?define(["exports"],a):a((t="undefined"!=typeof globalThis?globalThis:t||self).TinyBasePersisterPostgres={});