tinybase 5.3.1 → 5.3.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (890) hide show
  1. package/cjs/common/index.cjs +5 -7
  2. package/cjs/common/with-schemas/index.cjs +5 -7
  3. package/cjs/es6/common/index.cjs +5 -7
  4. package/cjs/es6/common/with-schemas/index.cjs +5 -7
  5. package/cjs/es6/index.cjs +18 -12
  6. package/cjs/es6/indexes/index.cjs +0 -6
  7. package/cjs/es6/indexes/with-schemas/index.cjs +0 -6
  8. package/cjs/es6/mergeable-store/index.cjs +17 -11
  9. package/cjs/es6/mergeable-store/with-schemas/index.cjs +17 -11
  10. package/cjs/es6/metrics/index.cjs +1 -1
  11. package/cjs/es6/metrics/with-schemas/index.cjs +1 -1
  12. package/cjs/es6/min/common/index.cjs +1 -1
  13. package/cjs/es6/min/common/index.cjs.gz +0 -0
  14. package/cjs/es6/min/common/with-schemas/index.cjs +1 -1
  15. package/cjs/es6/min/common/with-schemas/index.cjs.gz +0 -0
  16. package/cjs/es6/min/index.cjs +1 -1
  17. package/cjs/es6/min/index.cjs.gz +0 -0
  18. package/cjs/es6/min/indexes/index.cjs +1 -1
  19. package/cjs/es6/min/indexes/index.cjs.gz +0 -0
  20. package/cjs/es6/min/indexes/with-schemas/index.cjs +1 -1
  21. package/cjs/es6/min/indexes/with-schemas/index.cjs.gz +0 -0
  22. package/cjs/es6/min/mergeable-store/index.cjs +1 -1
  23. package/cjs/es6/min/mergeable-store/index.cjs.gz +0 -0
  24. package/cjs/es6/min/mergeable-store/with-schemas/index.cjs +1 -1
  25. package/cjs/es6/min/mergeable-store/with-schemas/index.cjs.gz +0 -0
  26. package/cjs/es6/min/persisters/index.cjs +1 -1
  27. package/cjs/es6/min/persisters/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-libsql/index.cjs +1 -1
  41. package/cjs/es6/min/persisters/persister-libsql/index.cjs.gz +0 -0
  42. package/cjs/es6/min/persisters/persister-libsql/with-schemas/index.cjs +1 -1
  43. package/cjs/es6/min/persisters/persister-libsql/with-schemas/index.cjs.gz +0 -0
  44. package/cjs/es6/min/persisters/persister-pglite/index.cjs +1 -1
  45. package/cjs/es6/min/persisters/persister-pglite/index.cjs.gz +0 -0
  46. package/cjs/es6/min/persisters/persister-pglite/with-schemas/index.cjs +1 -1
  47. package/cjs/es6/min/persisters/persister-pglite/with-schemas/index.cjs.gz +0 -0
  48. package/cjs/es6/min/persisters/persister-postgres/index.cjs +1 -1
  49. package/cjs/es6/min/persisters/persister-postgres/index.cjs.gz +0 -0
  50. package/cjs/es6/min/persisters/persister-postgres/with-schemas/index.cjs +1 -1
  51. package/cjs/es6/min/persisters/persister-postgres/with-schemas/index.cjs.gz +0 -0
  52. package/cjs/es6/min/persisters/persister-powersync/index.cjs +1 -1
  53. package/cjs/es6/min/persisters/persister-powersync/index.cjs.gz +0 -0
  54. package/cjs/es6/min/persisters/persister-powersync/with-schemas/index.cjs +1 -1
  55. package/cjs/es6/min/persisters/persister-powersync/with-schemas/index.cjs.gz +0 -0
  56. package/cjs/es6/min/persisters/persister-sqlite-wasm/index.cjs +1 -1
  57. package/cjs/es6/min/persisters/persister-sqlite-wasm/index.cjs.gz +0 -0
  58. package/cjs/es6/min/persisters/persister-sqlite-wasm/with-schemas/index.cjs +1 -1
  59. package/cjs/es6/min/persisters/persister-sqlite-wasm/with-schemas/index.cjs.gz +0 -0
  60. package/cjs/es6/min/persisters/persister-sqlite3/index.cjs +1 -1
  61. package/cjs/es6/min/persisters/persister-sqlite3/index.cjs.gz +0 -0
  62. package/cjs/es6/min/persisters/persister-sqlite3/with-schemas/index.cjs +1 -1
  63. package/cjs/es6/min/persisters/persister-sqlite3/with-schemas/index.cjs.gz +0 -0
  64. package/cjs/es6/min/persisters/with-schemas/index.cjs +1 -1
  65. package/cjs/es6/min/persisters/with-schemas/index.cjs.gz +0 -0
  66. package/cjs/es6/min/store/index.cjs +1 -1
  67. package/cjs/es6/min/store/index.cjs.gz +0 -0
  68. package/cjs/es6/min/store/with-schemas/index.cjs +1 -1
  69. package/cjs/es6/min/store/with-schemas/index.cjs.gz +0 -0
  70. package/cjs/es6/min/synchronizers/index.cjs +1 -1
  71. package/cjs/es6/min/synchronizers/index.cjs.gz +0 -0
  72. package/cjs/es6/min/synchronizers/synchronizer-broadcast-channel/index.cjs +1 -1
  73. package/cjs/es6/min/synchronizers/synchronizer-broadcast-channel/index.cjs.gz +0 -0
  74. package/cjs/es6/min/synchronizers/synchronizer-broadcast-channel/with-schemas/index.cjs +1 -1
  75. package/cjs/es6/min/synchronizers/synchronizer-broadcast-channel/with-schemas/index.cjs.gz +0 -0
  76. package/cjs/es6/min/synchronizers/synchronizer-local/index.cjs +1 -1
  77. package/cjs/es6/min/synchronizers/synchronizer-local/index.cjs.gz +0 -0
  78. package/cjs/es6/min/synchronizers/synchronizer-local/with-schemas/index.cjs +1 -1
  79. package/cjs/es6/min/synchronizers/synchronizer-local/with-schemas/index.cjs.gz +0 -0
  80. package/cjs/es6/min/synchronizers/synchronizer-ws-client/index.cjs +1 -1
  81. package/cjs/es6/min/synchronizers/synchronizer-ws-client/index.cjs.gz +0 -0
  82. package/cjs/es6/min/synchronizers/synchronizer-ws-client/with-schemas/index.cjs +1 -1
  83. package/cjs/es6/min/synchronizers/synchronizer-ws-client/with-schemas/index.cjs.gz +0 -0
  84. package/cjs/es6/min/synchronizers/synchronizer-ws-server/index.cjs +1 -1
  85. package/cjs/es6/min/synchronizers/synchronizer-ws-server/index.cjs.gz +0 -0
  86. package/cjs/es6/min/synchronizers/synchronizer-ws-server/with-schemas/index.cjs +1 -1
  87. package/cjs/es6/min/synchronizers/synchronizer-ws-server/with-schemas/index.cjs.gz +0 -0
  88. package/cjs/es6/min/synchronizers/with-schemas/index.cjs +1 -1
  89. package/cjs/es6/min/synchronizers/with-schemas/index.cjs.gz +0 -0
  90. package/cjs/es6/min/tools/index.cjs +1 -1
  91. package/cjs/es6/min/tools/index.cjs.gz +0 -0
  92. package/cjs/es6/min/tools/with-schemas/index.cjs +1 -1
  93. package/cjs/es6/min/tools/with-schemas/index.cjs.gz +0 -0
  94. package/cjs/es6/min/ui-react/index.cjs +1 -1
  95. package/cjs/es6/min/ui-react/index.cjs.gz +0 -0
  96. package/cjs/es6/min/ui-react/with-schemas/index.cjs +1 -1
  97. package/cjs/es6/min/ui-react/with-schemas/index.cjs.gz +0 -0
  98. package/cjs/es6/min/ui-react-dom/index.cjs +1 -1
  99. package/cjs/es6/min/ui-react-dom/index.cjs.gz +0 -0
  100. package/cjs/es6/min/ui-react-dom/with-schemas/index.cjs +1 -1
  101. package/cjs/es6/min/ui-react-dom/with-schemas/index.cjs.gz +0 -0
  102. package/cjs/es6/min/ui-react-inspector/index.cjs +1 -1
  103. package/cjs/es6/min/ui-react-inspector/index.cjs.gz +0 -0
  104. package/cjs/es6/min/ui-react-inspector/with-schemas/index.cjs +1 -1
  105. package/cjs/es6/min/ui-react-inspector/with-schemas/index.cjs.gz +0 -0
  106. package/cjs/es6/min/with-schemas/index.cjs +1 -1
  107. package/cjs/es6/min/with-schemas/index.cjs.gz +0 -0
  108. package/cjs/es6/persisters/index.cjs +83 -103
  109. package/cjs/es6/persisters/persister-cr-sqlite-wasm/index.cjs +82 -102
  110. package/cjs/es6/persisters/persister-cr-sqlite-wasm/with-schemas/index.cjs +82 -102
  111. package/cjs/es6/persisters/persister-electric-sql/index.cjs +82 -102
  112. package/cjs/es6/persisters/persister-electric-sql/with-schemas/index.cjs +82 -102
  113. package/cjs/es6/persisters/persister-expo-sqlite/index.cjs +82 -102
  114. package/cjs/es6/persisters/persister-expo-sqlite/with-schemas/index.cjs +82 -102
  115. package/cjs/es6/persisters/persister-libsql/index.cjs +82 -102
  116. package/cjs/es6/persisters/persister-libsql/with-schemas/index.cjs +82 -102
  117. package/cjs/es6/persisters/persister-pglite/index.cjs +82 -102
  118. package/cjs/es6/persisters/persister-pglite/with-schemas/index.cjs +82 -102
  119. package/cjs/es6/persisters/persister-postgres/index.cjs +81 -101
  120. package/cjs/es6/persisters/persister-postgres/with-schemas/index.cjs +81 -101
  121. package/cjs/es6/persisters/persister-powersync/index.cjs +212 -147
  122. package/cjs/es6/persisters/persister-powersync/with-schemas/index.cjs +212 -147
  123. package/cjs/es6/persisters/persister-sqlite-wasm/index.cjs +82 -102
  124. package/cjs/es6/persisters/persister-sqlite-wasm/with-schemas/index.cjs +82 -102
  125. package/cjs/es6/persisters/persister-sqlite3/index.cjs +82 -102
  126. package/cjs/es6/persisters/persister-sqlite3/with-schemas/index.cjs +82 -102
  127. package/cjs/es6/persisters/with-schemas/index.cjs +83 -103
  128. package/cjs/es6/queries/index.cjs +1 -1
  129. package/cjs/es6/queries/with-schemas/index.cjs +1 -1
  130. package/cjs/es6/store/index.cjs +0 -6
  131. package/cjs/es6/store/with-schemas/index.cjs +0 -6
  132. package/cjs/es6/synchronizers/index.cjs +5 -7
  133. package/cjs/es6/synchronizers/synchronizer-broadcast-channel/index.cjs +5 -7
  134. package/cjs/es6/synchronizers/synchronizer-broadcast-channel/with-schemas/index.cjs +5 -7
  135. package/cjs/es6/synchronizers/synchronizer-local/index.cjs +5 -7
  136. package/cjs/es6/synchronizers/synchronizer-local/with-schemas/index.cjs +5 -7
  137. package/cjs/es6/synchronizers/synchronizer-ws-client/index.cjs +5 -7
  138. package/cjs/es6/synchronizers/synchronizer-ws-client/with-schemas/index.cjs +5 -7
  139. package/cjs/es6/synchronizers/synchronizer-ws-server/index.cjs +5 -7
  140. package/cjs/es6/synchronizers/synchronizer-ws-server/with-schemas/index.cjs +5 -7
  141. package/cjs/es6/synchronizers/with-schemas/index.cjs +5 -7
  142. package/cjs/es6/tools/index.cjs +7 -4
  143. package/cjs/es6/tools/with-schemas/index.cjs +7 -4
  144. package/cjs/es6/ui-react/index.cjs +101 -109
  145. package/cjs/es6/ui-react/with-schemas/index.cjs +101 -109
  146. package/cjs/es6/ui-react-dom/index.cjs +14 -8
  147. package/cjs/es6/ui-react-dom/with-schemas/index.cjs +14 -8
  148. package/cjs/es6/ui-react-inspector/index.cjs +17 -17
  149. package/cjs/es6/ui-react-inspector/with-schemas/index.cjs +17 -17
  150. package/cjs/es6/with-schemas/index.cjs +18 -12
  151. package/cjs/index.cjs +18 -12
  152. package/cjs/indexes/index.cjs +0 -6
  153. package/cjs/indexes/with-schemas/index.cjs +0 -6
  154. package/cjs/mergeable-store/index.cjs +17 -11
  155. package/cjs/mergeable-store/with-schemas/index.cjs +17 -11
  156. package/cjs/metrics/index.cjs +1 -1
  157. package/cjs/metrics/with-schemas/index.cjs +1 -1
  158. package/cjs/min/common/index.cjs +1 -1
  159. package/cjs/min/common/index.cjs.gz +0 -0
  160. package/cjs/min/common/with-schemas/index.cjs +1 -1
  161. package/cjs/min/common/with-schemas/index.cjs.gz +0 -0
  162. package/cjs/min/index.cjs +1 -1
  163. package/cjs/min/index.cjs.gz +0 -0
  164. package/cjs/min/indexes/index.cjs +1 -1
  165. package/cjs/min/indexes/index.cjs.gz +0 -0
  166. package/cjs/min/indexes/with-schemas/index.cjs +1 -1
  167. package/cjs/min/indexes/with-schemas/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-cr-sqlite-wasm/index.cjs +1 -1
  175. package/cjs/min/persisters/persister-cr-sqlite-wasm/index.cjs.gz +0 -0
  176. package/cjs/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.cjs +1 -1
  177. package/cjs/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.cjs.gz +0 -0
  178. package/cjs/min/persisters/persister-electric-sql/index.cjs +1 -1
  179. package/cjs/min/persisters/persister-electric-sql/index.cjs.gz +0 -0
  180. package/cjs/min/persisters/persister-electric-sql/with-schemas/index.cjs +1 -1
  181. package/cjs/min/persisters/persister-electric-sql/with-schemas/index.cjs.gz +0 -0
  182. package/cjs/min/persisters/persister-expo-sqlite/index.cjs +1 -1
  183. package/cjs/min/persisters/persister-expo-sqlite/index.cjs.gz +0 -0
  184. package/cjs/min/persisters/persister-expo-sqlite/with-schemas/index.cjs +1 -1
  185. package/cjs/min/persisters/persister-expo-sqlite/with-schemas/index.cjs.gz +0 -0
  186. package/cjs/min/persisters/persister-libsql/index.cjs +1 -1
  187. package/cjs/min/persisters/persister-libsql/index.cjs.gz +0 -0
  188. package/cjs/min/persisters/persister-libsql/with-schemas/index.cjs +1 -1
  189. package/cjs/min/persisters/persister-libsql/with-schemas/index.cjs.gz +0 -0
  190. package/cjs/min/persisters/persister-pglite/index.cjs +1 -1
  191. package/cjs/min/persisters/persister-pglite/index.cjs.gz +0 -0
  192. package/cjs/min/persisters/persister-pglite/with-schemas/index.cjs +1 -1
  193. package/cjs/min/persisters/persister-pglite/with-schemas/index.cjs.gz +0 -0
  194. package/cjs/min/persisters/persister-postgres/index.cjs +1 -1
  195. package/cjs/min/persisters/persister-postgres/index.cjs.gz +0 -0
  196. package/cjs/min/persisters/persister-postgres/with-schemas/index.cjs +1 -1
  197. package/cjs/min/persisters/persister-postgres/with-schemas/index.cjs.gz +0 -0
  198. package/cjs/min/persisters/persister-powersync/index.cjs +1 -1
  199. package/cjs/min/persisters/persister-powersync/index.cjs.gz +0 -0
  200. package/cjs/min/persisters/persister-powersync/with-schemas/index.cjs +1 -1
  201. package/cjs/min/persisters/persister-powersync/with-schemas/index.cjs.gz +0 -0
  202. package/cjs/min/persisters/persister-sqlite-wasm/index.cjs +1 -1
  203. package/cjs/min/persisters/persister-sqlite-wasm/index.cjs.gz +0 -0
  204. package/cjs/min/persisters/persister-sqlite-wasm/with-schemas/index.cjs +1 -1
  205. package/cjs/min/persisters/persister-sqlite-wasm/with-schemas/index.cjs.gz +0 -0
  206. package/cjs/min/persisters/persister-sqlite3/index.cjs +1 -1
  207. package/cjs/min/persisters/persister-sqlite3/index.cjs.gz +0 -0
  208. package/cjs/min/persisters/persister-sqlite3/with-schemas/index.cjs +1 -1
  209. package/cjs/min/persisters/persister-sqlite3/with-schemas/index.cjs.gz +0 -0
  210. package/cjs/min/persisters/with-schemas/index.cjs +1 -1
  211. package/cjs/min/persisters/with-schemas/index.cjs.gz +0 -0
  212. package/cjs/min/store/index.cjs +1 -1
  213. package/cjs/min/store/index.cjs.gz +0 -0
  214. package/cjs/min/store/with-schemas/index.cjs +1 -1
  215. package/cjs/min/store/with-schemas/index.cjs.gz +0 -0
  216. package/cjs/min/synchronizers/index.cjs +1 -1
  217. package/cjs/min/synchronizers/index.cjs.gz +0 -0
  218. package/cjs/min/synchronizers/synchronizer-broadcast-channel/index.cjs +1 -1
  219. package/cjs/min/synchronizers/synchronizer-broadcast-channel/index.cjs.gz +0 -0
  220. package/cjs/min/synchronizers/synchronizer-broadcast-channel/with-schemas/index.cjs +1 -1
  221. package/cjs/min/synchronizers/synchronizer-broadcast-channel/with-schemas/index.cjs.gz +0 -0
  222. package/cjs/min/synchronizers/synchronizer-local/index.cjs +1 -1
  223. package/cjs/min/synchronizers/synchronizer-local/index.cjs.gz +0 -0
  224. package/cjs/min/synchronizers/synchronizer-local/with-schemas/index.cjs +1 -1
  225. package/cjs/min/synchronizers/synchronizer-local/with-schemas/index.cjs.gz +0 -0
  226. package/cjs/min/synchronizers/synchronizer-ws-client/index.cjs +1 -1
  227. package/cjs/min/synchronizers/synchronizer-ws-client/index.cjs.gz +0 -0
  228. package/cjs/min/synchronizers/synchronizer-ws-client/with-schemas/index.cjs +1 -1
  229. package/cjs/min/synchronizers/synchronizer-ws-client/with-schemas/index.cjs.gz +0 -0
  230. package/cjs/min/synchronizers/synchronizer-ws-server/index.cjs +1 -1
  231. package/cjs/min/synchronizers/synchronizer-ws-server/index.cjs.gz +0 -0
  232. package/cjs/min/synchronizers/synchronizer-ws-server/with-schemas/index.cjs +1 -1
  233. package/cjs/min/synchronizers/synchronizer-ws-server/with-schemas/index.cjs.gz +0 -0
  234. package/cjs/min/synchronizers/with-schemas/index.cjs +1 -1
  235. package/cjs/min/synchronizers/with-schemas/index.cjs.gz +0 -0
  236. package/cjs/min/tools/index.cjs +1 -1
  237. package/cjs/min/tools/index.cjs.gz +0 -0
  238. package/cjs/min/tools/with-schemas/index.cjs +1 -1
  239. package/cjs/min/tools/with-schemas/index.cjs.gz +0 -0
  240. package/cjs/min/ui-react/index.cjs +1 -1
  241. package/cjs/min/ui-react/index.cjs.gz +0 -0
  242. package/cjs/min/ui-react/with-schemas/index.cjs +1 -1
  243. package/cjs/min/ui-react/with-schemas/index.cjs.gz +0 -0
  244. package/cjs/min/ui-react-dom/index.cjs +1 -1
  245. package/cjs/min/ui-react-dom/index.cjs.gz +0 -0
  246. package/cjs/min/ui-react-dom/with-schemas/index.cjs +1 -1
  247. package/cjs/min/ui-react-dom/with-schemas/index.cjs.gz +0 -0
  248. package/cjs/min/ui-react-inspector/index.cjs +1 -1
  249. package/cjs/min/ui-react-inspector/index.cjs.gz +0 -0
  250. package/cjs/min/ui-react-inspector/with-schemas/index.cjs +1 -1
  251. package/cjs/min/ui-react-inspector/with-schemas/index.cjs.gz +0 -0
  252. package/cjs/min/with-schemas/index.cjs +1 -1
  253. package/cjs/min/with-schemas/index.cjs.gz +0 -0
  254. package/cjs/persisters/index.cjs +80 -98
  255. package/cjs/persisters/persister-cr-sqlite-wasm/index.cjs +79 -97
  256. package/cjs/persisters/persister-cr-sqlite-wasm/with-schemas/index.cjs +79 -97
  257. package/cjs/persisters/persister-electric-sql/index.cjs +79 -97
  258. package/cjs/persisters/persister-electric-sql/with-schemas/index.cjs +79 -97
  259. package/cjs/persisters/persister-expo-sqlite/index.cjs +79 -97
  260. package/cjs/persisters/persister-expo-sqlite/with-schemas/index.cjs +79 -97
  261. package/cjs/persisters/persister-libsql/index.cjs +79 -97
  262. package/cjs/persisters/persister-libsql/with-schemas/index.cjs +79 -97
  263. package/cjs/persisters/persister-pglite/index.cjs +79 -97
  264. package/cjs/persisters/persister-pglite/with-schemas/index.cjs +79 -97
  265. package/cjs/persisters/persister-postgres/index.cjs +78 -96
  266. package/cjs/persisters/persister-postgres/with-schemas/index.cjs +78 -96
  267. package/cjs/persisters/persister-powersync/index.cjs +203 -142
  268. package/cjs/persisters/persister-powersync/with-schemas/index.cjs +203 -142
  269. package/cjs/persisters/persister-sqlite-wasm/index.cjs +79 -97
  270. package/cjs/persisters/persister-sqlite-wasm/with-schemas/index.cjs +79 -97
  271. package/cjs/persisters/persister-sqlite3/index.cjs +79 -97
  272. package/cjs/persisters/persister-sqlite3/with-schemas/index.cjs +79 -97
  273. package/cjs/persisters/with-schemas/index.cjs +80 -98
  274. package/cjs/queries/index.cjs +1 -1
  275. package/cjs/queries/with-schemas/index.cjs +1 -1
  276. package/cjs/store/index.cjs +0 -6
  277. package/cjs/store/with-schemas/index.cjs +0 -6
  278. package/cjs/synchronizers/index.cjs +5 -7
  279. package/cjs/synchronizers/synchronizer-broadcast-channel/index.cjs +5 -7
  280. package/cjs/synchronizers/synchronizer-broadcast-channel/with-schemas/index.cjs +5 -7
  281. package/cjs/synchronizers/synchronizer-local/index.cjs +5 -7
  282. package/cjs/synchronizers/synchronizer-local/with-schemas/index.cjs +5 -7
  283. package/cjs/synchronizers/synchronizer-ws-client/index.cjs +5 -7
  284. package/cjs/synchronizers/synchronizer-ws-client/with-schemas/index.cjs +5 -7
  285. package/cjs/synchronizers/synchronizer-ws-server/index.cjs +5 -7
  286. package/cjs/synchronizers/synchronizer-ws-server/with-schemas/index.cjs +5 -7
  287. package/cjs/synchronizers/with-schemas/index.cjs +5 -7
  288. package/cjs/tools/index.cjs +7 -4
  289. package/cjs/tools/with-schemas/index.cjs +7 -4
  290. package/cjs/ui-react/index.cjs +97 -107
  291. package/cjs/ui-react/with-schemas/index.cjs +97 -107
  292. package/cjs/ui-react-dom/index.cjs +14 -8
  293. package/cjs/ui-react-dom/with-schemas/index.cjs +14 -8
  294. package/cjs/ui-react-inspector/index.cjs +17 -17
  295. package/cjs/ui-react-inspector/with-schemas/index.cjs +17 -17
  296. package/cjs/with-schemas/index.cjs +18 -12
  297. package/common/index.js +5 -7
  298. package/common/with-schemas/index.js +5 -7
  299. package/es6/common/index.js +5 -7
  300. package/es6/common/with-schemas/index.js +5 -7
  301. package/es6/index.js +18 -12
  302. package/es6/indexes/index.js +0 -6
  303. package/es6/indexes/with-schemas/index.js +0 -6
  304. package/es6/mergeable-store/index.js +17 -11
  305. package/es6/mergeable-store/with-schemas/index.js +17 -11
  306. package/es6/metrics/index.js +1 -1
  307. package/es6/metrics/with-schemas/index.js +1 -1
  308. package/es6/min/common/index.js +1 -1
  309. package/es6/min/common/index.js.gz +0 -0
  310. package/es6/min/common/with-schemas/index.js +1 -1
  311. package/es6/min/common/with-schemas/index.js.gz +0 -0
  312. package/es6/min/index.js +1 -1
  313. package/es6/min/index.js.gz +0 -0
  314. package/es6/min/indexes/index.js +1 -1
  315. package/es6/min/indexes/index.js.gz +0 -0
  316. package/es6/min/indexes/with-schemas/index.js +1 -1
  317. package/es6/min/indexes/with-schemas/index.js.gz +0 -0
  318. package/es6/min/mergeable-store/index.js +1 -1
  319. package/es6/min/mergeable-store/index.js.gz +0 -0
  320. package/es6/min/mergeable-store/with-schemas/index.js +1 -1
  321. package/es6/min/mergeable-store/with-schemas/index.js.gz +0 -0
  322. package/es6/min/persisters/index.js +1 -1
  323. package/es6/min/persisters/index.js.gz +0 -0
  324. package/es6/min/persisters/persister-cr-sqlite-wasm/index.js +1 -1
  325. package/es6/min/persisters/persister-cr-sqlite-wasm/index.js.gz +0 -0
  326. package/es6/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.js +1 -1
  327. package/es6/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.js.gz +0 -0
  328. package/es6/min/persisters/persister-electric-sql/index.js +1 -1
  329. package/es6/min/persisters/persister-electric-sql/index.js.gz +0 -0
  330. package/es6/min/persisters/persister-electric-sql/with-schemas/index.js +1 -1
  331. package/es6/min/persisters/persister-electric-sql/with-schemas/index.js.gz +0 -0
  332. package/es6/min/persisters/persister-expo-sqlite/index.js +1 -1
  333. package/es6/min/persisters/persister-expo-sqlite/index.js.gz +0 -0
  334. package/es6/min/persisters/persister-expo-sqlite/with-schemas/index.js +1 -1
  335. package/es6/min/persisters/persister-expo-sqlite/with-schemas/index.js.gz +0 -0
  336. package/es6/min/persisters/persister-libsql/index.js +1 -1
  337. package/es6/min/persisters/persister-libsql/index.js.gz +0 -0
  338. package/es6/min/persisters/persister-libsql/with-schemas/index.js +1 -1
  339. package/es6/min/persisters/persister-libsql/with-schemas/index.js.gz +0 -0
  340. package/es6/min/persisters/persister-pglite/index.js +1 -1
  341. package/es6/min/persisters/persister-pglite/index.js.gz +0 -0
  342. package/es6/min/persisters/persister-pglite/with-schemas/index.js +1 -1
  343. package/es6/min/persisters/persister-pglite/with-schemas/index.js.gz +0 -0
  344. package/es6/min/persisters/persister-postgres/index.js +1 -1
  345. package/es6/min/persisters/persister-postgres/index.js.gz +0 -0
  346. package/es6/min/persisters/persister-postgres/with-schemas/index.js +1 -1
  347. package/es6/min/persisters/persister-postgres/with-schemas/index.js.gz +0 -0
  348. package/es6/min/persisters/persister-powersync/index.js +1 -1
  349. package/es6/min/persisters/persister-powersync/index.js.gz +0 -0
  350. package/es6/min/persisters/persister-powersync/with-schemas/index.js +1 -1
  351. package/es6/min/persisters/persister-powersync/with-schemas/index.js.gz +0 -0
  352. package/es6/min/persisters/persister-sqlite-wasm/index.js +1 -1
  353. package/es6/min/persisters/persister-sqlite-wasm/index.js.gz +0 -0
  354. package/es6/min/persisters/persister-sqlite-wasm/with-schemas/index.js +1 -1
  355. package/es6/min/persisters/persister-sqlite-wasm/with-schemas/index.js.gz +0 -0
  356. package/es6/min/persisters/persister-sqlite3/index.js +1 -1
  357. package/es6/min/persisters/persister-sqlite3/index.js.gz +0 -0
  358. package/es6/min/persisters/persister-sqlite3/with-schemas/index.js +1 -1
  359. package/es6/min/persisters/persister-sqlite3/with-schemas/index.js.gz +0 -0
  360. package/es6/min/persisters/with-schemas/index.js +1 -1
  361. package/es6/min/persisters/with-schemas/index.js.gz +0 -0
  362. package/es6/min/store/index.js +1 -1
  363. package/es6/min/store/index.js.gz +0 -0
  364. package/es6/min/store/with-schemas/index.js +1 -1
  365. package/es6/min/store/with-schemas/index.js.gz +0 -0
  366. package/es6/min/synchronizers/index.js +1 -1
  367. package/es6/min/synchronizers/index.js.gz +0 -0
  368. package/es6/min/synchronizers/synchronizer-broadcast-channel/index.js +1 -1
  369. package/es6/min/synchronizers/synchronizer-broadcast-channel/index.js.gz +0 -0
  370. package/es6/min/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js +1 -1
  371. package/es6/min/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js.gz +0 -0
  372. package/es6/min/synchronizers/synchronizer-local/index.js +1 -1
  373. package/es6/min/synchronizers/synchronizer-local/index.js.gz +0 -0
  374. package/es6/min/synchronizers/synchronizer-local/with-schemas/index.js +1 -1
  375. package/es6/min/synchronizers/synchronizer-local/with-schemas/index.js.gz +0 -0
  376. package/es6/min/synchronizers/synchronizer-ws-client/index.js +1 -1
  377. package/es6/min/synchronizers/synchronizer-ws-client/index.js.gz +0 -0
  378. package/es6/min/synchronizers/synchronizer-ws-client/with-schemas/index.js +1 -1
  379. package/es6/min/synchronizers/synchronizer-ws-client/with-schemas/index.js.gz +0 -0
  380. package/es6/min/synchronizers/synchronizer-ws-server/index.js +1 -1
  381. package/es6/min/synchronizers/synchronizer-ws-server/index.js.gz +0 -0
  382. package/es6/min/synchronizers/synchronizer-ws-server/with-schemas/index.js +1 -1
  383. package/es6/min/synchronizers/synchronizer-ws-server/with-schemas/index.js.gz +0 -0
  384. package/es6/min/synchronizers/with-schemas/index.js +1 -1
  385. package/es6/min/synchronizers/with-schemas/index.js.gz +0 -0
  386. package/es6/min/tools/index.js +1 -1
  387. package/es6/min/tools/index.js.gz +0 -0
  388. package/es6/min/tools/with-schemas/index.js +1 -1
  389. package/es6/min/tools/with-schemas/index.js.gz +0 -0
  390. package/es6/min/ui-react/index.js +1 -1
  391. package/es6/min/ui-react/index.js.gz +0 -0
  392. package/es6/min/ui-react/with-schemas/index.js +1 -1
  393. package/es6/min/ui-react/with-schemas/index.js.gz +0 -0
  394. package/es6/min/ui-react-dom/index.js +1 -1
  395. package/es6/min/ui-react-dom/index.js.gz +0 -0
  396. package/es6/min/ui-react-dom/with-schemas/index.js +1 -1
  397. package/es6/min/ui-react-dom/with-schemas/index.js.gz +0 -0
  398. package/es6/min/ui-react-inspector/index.js +1 -1
  399. package/es6/min/ui-react-inspector/index.js.gz +0 -0
  400. package/es6/min/ui-react-inspector/with-schemas/index.js +1 -1
  401. package/es6/min/ui-react-inspector/with-schemas/index.js.gz +0 -0
  402. package/es6/min/with-schemas/index.js +1 -1
  403. package/es6/min/with-schemas/index.js.gz +0 -0
  404. package/es6/persisters/index.js +83 -103
  405. package/es6/persisters/persister-cr-sqlite-wasm/index.js +82 -102
  406. package/es6/persisters/persister-cr-sqlite-wasm/with-schemas/index.js +82 -102
  407. package/es6/persisters/persister-electric-sql/index.js +82 -102
  408. package/es6/persisters/persister-electric-sql/with-schemas/index.js +82 -102
  409. package/es6/persisters/persister-expo-sqlite/index.js +82 -102
  410. package/es6/persisters/persister-expo-sqlite/with-schemas/index.js +82 -102
  411. package/es6/persisters/persister-libsql/index.js +82 -102
  412. package/es6/persisters/persister-libsql/with-schemas/index.js +82 -102
  413. package/es6/persisters/persister-pglite/index.js +82 -102
  414. package/es6/persisters/persister-pglite/with-schemas/index.js +82 -102
  415. package/es6/persisters/persister-postgres/index.js +81 -101
  416. package/es6/persisters/persister-postgres/with-schemas/index.js +81 -101
  417. package/es6/persisters/persister-powersync/index.js +212 -147
  418. package/es6/persisters/persister-powersync/with-schemas/index.js +212 -147
  419. package/es6/persisters/persister-sqlite-wasm/index.js +82 -102
  420. package/es6/persisters/persister-sqlite-wasm/with-schemas/index.js +82 -102
  421. package/es6/persisters/persister-sqlite3/index.js +82 -102
  422. package/es6/persisters/persister-sqlite3/with-schemas/index.js +82 -102
  423. package/es6/persisters/with-schemas/index.js +83 -103
  424. package/es6/queries/index.js +1 -1
  425. package/es6/queries/with-schemas/index.js +1 -1
  426. package/es6/store/index.js +0 -6
  427. package/es6/store/with-schemas/index.js +0 -6
  428. package/es6/synchronizers/index.js +5 -7
  429. package/es6/synchronizers/synchronizer-broadcast-channel/index.js +5 -7
  430. package/es6/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js +5 -7
  431. package/es6/synchronizers/synchronizer-local/index.js +5 -7
  432. package/es6/synchronizers/synchronizer-local/with-schemas/index.js +5 -7
  433. package/es6/synchronizers/synchronizer-ws-client/index.js +5 -7
  434. package/es6/synchronizers/synchronizer-ws-client/with-schemas/index.js +5 -7
  435. package/es6/synchronizers/synchronizer-ws-server/index.js +5 -7
  436. package/es6/synchronizers/synchronizer-ws-server/with-schemas/index.js +5 -7
  437. package/es6/synchronizers/with-schemas/index.js +5 -7
  438. package/es6/tools/index.js +7 -4
  439. package/es6/tools/with-schemas/index.js +7 -4
  440. package/es6/ui-react/index.js +101 -109
  441. package/es6/ui-react/with-schemas/index.js +101 -109
  442. package/es6/ui-react-dom/index.js +14 -8
  443. package/es6/ui-react-dom/with-schemas/index.js +14 -8
  444. package/es6/ui-react-inspector/index.js +17 -17
  445. package/es6/ui-react-inspector/with-schemas/index.js +17 -17
  446. package/es6/with-schemas/index.js +18 -12
  447. package/index.js +18 -12
  448. package/indexes/index.js +0 -6
  449. package/indexes/with-schemas/index.js +0 -6
  450. package/mergeable-store/index.js +17 -11
  451. package/mergeable-store/with-schemas/index.js +17 -11
  452. package/metrics/index.js +1 -1
  453. package/metrics/with-schemas/index.js +1 -1
  454. package/min/common/index.js +1 -1
  455. package/min/common/index.js.gz +0 -0
  456. package/min/common/with-schemas/index.js +1 -1
  457. package/min/common/with-schemas/index.js.gz +0 -0
  458. package/min/index.js +1 -1
  459. package/min/index.js.gz +0 -0
  460. package/min/indexes/index.js +1 -1
  461. package/min/indexes/index.js.gz +0 -0
  462. package/min/indexes/with-schemas/index.js +1 -1
  463. package/min/indexes/with-schemas/index.js.gz +0 -0
  464. package/min/mergeable-store/index.js +1 -1
  465. package/min/mergeable-store/index.js.gz +0 -0
  466. package/min/mergeable-store/with-schemas/index.js +1 -1
  467. package/min/mergeable-store/with-schemas/index.js.gz +0 -0
  468. package/min/persisters/index.js +1 -1
  469. package/min/persisters/index.js.gz +0 -0
  470. package/min/persisters/persister-cr-sqlite-wasm/index.js +1 -1
  471. package/min/persisters/persister-cr-sqlite-wasm/index.js.gz +0 -0
  472. package/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.js +1 -1
  473. package/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.js.gz +0 -0
  474. package/min/persisters/persister-electric-sql/index.js +1 -1
  475. package/min/persisters/persister-electric-sql/index.js.gz +0 -0
  476. package/min/persisters/persister-electric-sql/with-schemas/index.js +1 -1
  477. package/min/persisters/persister-electric-sql/with-schemas/index.js.gz +0 -0
  478. package/min/persisters/persister-expo-sqlite/index.js +1 -1
  479. package/min/persisters/persister-expo-sqlite/index.js.gz +0 -0
  480. package/min/persisters/persister-expo-sqlite/with-schemas/index.js +1 -1
  481. package/min/persisters/persister-expo-sqlite/with-schemas/index.js.gz +0 -0
  482. package/min/persisters/persister-libsql/index.js +1 -1
  483. package/min/persisters/persister-libsql/index.js.gz +0 -0
  484. package/min/persisters/persister-libsql/with-schemas/index.js +1 -1
  485. package/min/persisters/persister-libsql/with-schemas/index.js.gz +0 -0
  486. package/min/persisters/persister-pglite/index.js +1 -1
  487. package/min/persisters/persister-pglite/index.js.gz +0 -0
  488. package/min/persisters/persister-pglite/with-schemas/index.js +1 -1
  489. package/min/persisters/persister-pglite/with-schemas/index.js.gz +0 -0
  490. package/min/persisters/persister-postgres/index.js +1 -1
  491. package/min/persisters/persister-postgres/index.js.gz +0 -0
  492. package/min/persisters/persister-postgres/with-schemas/index.js +1 -1
  493. package/min/persisters/persister-postgres/with-schemas/index.js.gz +0 -0
  494. package/min/persisters/persister-powersync/index.js +1 -1
  495. package/min/persisters/persister-powersync/index.js.gz +0 -0
  496. package/min/persisters/persister-powersync/with-schemas/index.js +1 -1
  497. package/min/persisters/persister-powersync/with-schemas/index.js.gz +0 -0
  498. package/min/persisters/persister-sqlite-wasm/index.js +1 -1
  499. package/min/persisters/persister-sqlite-wasm/index.js.gz +0 -0
  500. package/min/persisters/persister-sqlite-wasm/with-schemas/index.js +1 -1
  501. package/min/persisters/persister-sqlite-wasm/with-schemas/index.js.gz +0 -0
  502. package/min/persisters/persister-sqlite3/index.js +1 -1
  503. package/min/persisters/persister-sqlite3/index.js.gz +0 -0
  504. package/min/persisters/persister-sqlite3/with-schemas/index.js +1 -1
  505. package/min/persisters/persister-sqlite3/with-schemas/index.js.gz +0 -0
  506. package/min/persisters/with-schemas/index.js +1 -1
  507. package/min/persisters/with-schemas/index.js.gz +0 -0
  508. package/min/store/index.js +1 -1
  509. package/min/store/index.js.gz +0 -0
  510. package/min/store/with-schemas/index.js +1 -1
  511. package/min/store/with-schemas/index.js.gz +0 -0
  512. package/min/synchronizers/index.js +1 -1
  513. package/min/synchronizers/index.js.gz +0 -0
  514. package/min/synchronizers/synchronizer-broadcast-channel/index.js +1 -1
  515. package/min/synchronizers/synchronizer-broadcast-channel/index.js.gz +0 -0
  516. package/min/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js +1 -1
  517. package/min/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js.gz +0 -0
  518. package/min/synchronizers/synchronizer-local/index.js +1 -1
  519. package/min/synchronizers/synchronizer-local/index.js.gz +0 -0
  520. package/min/synchronizers/synchronizer-local/with-schemas/index.js +1 -1
  521. package/min/synchronizers/synchronizer-local/with-schemas/index.js.gz +0 -0
  522. package/min/synchronizers/synchronizer-ws-client/index.js +1 -1
  523. package/min/synchronizers/synchronizer-ws-client/index.js.gz +0 -0
  524. package/min/synchronizers/synchronizer-ws-client/with-schemas/index.js +1 -1
  525. package/min/synchronizers/synchronizer-ws-client/with-schemas/index.js.gz +0 -0
  526. package/min/synchronizers/synchronizer-ws-server/index.js +1 -1
  527. package/min/synchronizers/synchronizer-ws-server/index.js.gz +0 -0
  528. package/min/synchronizers/synchronizer-ws-server/with-schemas/index.js +1 -1
  529. package/min/synchronizers/synchronizer-ws-server/with-schemas/index.js.gz +0 -0
  530. package/min/synchronizers/with-schemas/index.js +1 -1
  531. package/min/synchronizers/with-schemas/index.js.gz +0 -0
  532. package/min/tools/index.js +1 -1
  533. package/min/tools/index.js.gz +0 -0
  534. package/min/tools/with-schemas/index.js +1 -1
  535. package/min/tools/with-schemas/index.js.gz +0 -0
  536. package/min/ui-react/index.js +1 -1
  537. package/min/ui-react/index.js.gz +0 -0
  538. package/min/ui-react/with-schemas/index.js +1 -1
  539. package/min/ui-react/with-schemas/index.js.gz +0 -0
  540. package/min/ui-react-dom/index.js +1 -1
  541. package/min/ui-react-dom/index.js.gz +0 -0
  542. package/min/ui-react-dom/with-schemas/index.js +1 -1
  543. package/min/ui-react-dom/with-schemas/index.js.gz +0 -0
  544. package/min/ui-react-inspector/index.js +1 -1
  545. package/min/ui-react-inspector/index.js.gz +0 -0
  546. package/min/ui-react-inspector/with-schemas/index.js +1 -1
  547. package/min/ui-react-inspector/with-schemas/index.js.gz +0 -0
  548. package/min/with-schemas/index.js +1 -1
  549. package/min/with-schemas/index.js.gz +0 -0
  550. package/package.json +6 -6
  551. package/persisters/index.js +80 -98
  552. package/persisters/persister-cr-sqlite-wasm/index.js +79 -97
  553. package/persisters/persister-cr-sqlite-wasm/with-schemas/index.js +79 -97
  554. package/persisters/persister-electric-sql/index.js +79 -97
  555. package/persisters/persister-electric-sql/with-schemas/index.js +79 -97
  556. package/persisters/persister-expo-sqlite/index.js +79 -97
  557. package/persisters/persister-expo-sqlite/with-schemas/index.js +79 -97
  558. package/persisters/persister-libsql/index.js +79 -97
  559. package/persisters/persister-libsql/with-schemas/index.js +79 -97
  560. package/persisters/persister-pglite/index.js +79 -97
  561. package/persisters/persister-pglite/with-schemas/index.js +79 -97
  562. package/persisters/persister-postgres/index.js +78 -96
  563. package/persisters/persister-postgres/with-schemas/index.js +78 -96
  564. package/persisters/persister-powersync/index.js +203 -142
  565. package/persisters/persister-powersync/with-schemas/index.js +203 -142
  566. package/persisters/persister-sqlite-wasm/index.js +79 -97
  567. package/persisters/persister-sqlite-wasm/with-schemas/index.js +79 -97
  568. package/persisters/persister-sqlite3/index.js +79 -97
  569. package/persisters/persister-sqlite3/with-schemas/index.js +79 -97
  570. package/persisters/with-schemas/index.js +80 -98
  571. package/queries/index.js +1 -1
  572. package/queries/with-schemas/index.js +1 -1
  573. package/readme.md +2 -2
  574. package/store/index.js +0 -6
  575. package/store/with-schemas/index.js +0 -6
  576. package/synchronizers/index.js +5 -7
  577. package/synchronizers/synchronizer-broadcast-channel/index.js +5 -7
  578. package/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js +5 -7
  579. package/synchronizers/synchronizer-local/index.js +5 -7
  580. package/synchronizers/synchronizer-local/with-schemas/index.js +5 -7
  581. package/synchronizers/synchronizer-ws-client/index.js +5 -7
  582. package/synchronizers/synchronizer-ws-client/with-schemas/index.js +5 -7
  583. package/synchronizers/synchronizer-ws-server/index.js +5 -7
  584. package/synchronizers/synchronizer-ws-server/with-schemas/index.js +5 -7
  585. package/synchronizers/with-schemas/index.js +5 -7
  586. package/tools/index.js +7 -4
  587. package/tools/with-schemas/index.js +7 -4
  588. package/ui-react/index.js +97 -107
  589. package/ui-react/with-schemas/index.js +97 -107
  590. package/ui-react-dom/index.js +14 -8
  591. package/ui-react-dom/with-schemas/index.js +14 -8
  592. package/ui-react-inspector/index.js +17 -17
  593. package/ui-react-inspector/with-schemas/index.js +17 -17
  594. package/umd/common/index.js +5 -7
  595. package/umd/common/with-schemas/index.js +5 -7
  596. package/umd/es6/common/index.js +5 -7
  597. package/umd/es6/common/with-schemas/index.js +5 -7
  598. package/umd/es6/index.js +18 -12
  599. package/umd/es6/indexes/index.js +0 -6
  600. package/umd/es6/indexes/with-schemas/index.js +0 -6
  601. package/umd/es6/mergeable-store/index.js +17 -11
  602. package/umd/es6/mergeable-store/with-schemas/index.js +17 -11
  603. package/umd/es6/metrics/index.js +1 -1
  604. package/umd/es6/metrics/with-schemas/index.js +1 -1
  605. package/umd/es6/min/common/index.js +1 -1
  606. package/umd/es6/min/common/index.js.gz +0 -0
  607. package/umd/es6/min/common/with-schemas/index.js +1 -1
  608. package/umd/es6/min/common/with-schemas/index.js.gz +0 -0
  609. package/umd/es6/min/index.js +1 -1
  610. package/umd/es6/min/index.js.gz +0 -0
  611. package/umd/es6/min/indexes/index.js +1 -1
  612. package/umd/es6/min/indexes/index.js.gz +0 -0
  613. package/umd/es6/min/indexes/with-schemas/index.js +1 -1
  614. package/umd/es6/min/indexes/with-schemas/index.js.gz +0 -0
  615. package/umd/es6/min/mergeable-store/index.js +1 -1
  616. package/umd/es6/min/mergeable-store/index.js.gz +0 -0
  617. package/umd/es6/min/mergeable-store/with-schemas/index.js +1 -1
  618. package/umd/es6/min/mergeable-store/with-schemas/index.js.gz +0 -0
  619. package/umd/es6/min/persisters/index.js +1 -1
  620. package/umd/es6/min/persisters/index.js.gz +0 -0
  621. package/umd/es6/min/persisters/persister-cr-sqlite-wasm/index.js +1 -1
  622. package/umd/es6/min/persisters/persister-cr-sqlite-wasm/index.js.gz +0 -0
  623. package/umd/es6/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.js +1 -1
  624. package/umd/es6/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.js.gz +0 -0
  625. package/umd/es6/min/persisters/persister-electric-sql/index.js +1 -1
  626. package/umd/es6/min/persisters/persister-electric-sql/index.js.gz +0 -0
  627. package/umd/es6/min/persisters/persister-electric-sql/with-schemas/index.js +1 -1
  628. package/umd/es6/min/persisters/persister-electric-sql/with-schemas/index.js.gz +0 -0
  629. package/umd/es6/min/persisters/persister-expo-sqlite/index.js +1 -1
  630. package/umd/es6/min/persisters/persister-expo-sqlite/index.js.gz +0 -0
  631. package/umd/es6/min/persisters/persister-expo-sqlite/with-schemas/index.js +1 -1
  632. package/umd/es6/min/persisters/persister-expo-sqlite/with-schemas/index.js.gz +0 -0
  633. package/umd/es6/min/persisters/persister-libsql/index.js +1 -1
  634. package/umd/es6/min/persisters/persister-libsql/index.js.gz +0 -0
  635. package/umd/es6/min/persisters/persister-libsql/with-schemas/index.js +1 -1
  636. package/umd/es6/min/persisters/persister-libsql/with-schemas/index.js.gz +0 -0
  637. package/umd/es6/min/persisters/persister-pglite/index.js +1 -1
  638. package/umd/es6/min/persisters/persister-pglite/index.js.gz +0 -0
  639. package/umd/es6/min/persisters/persister-pglite/with-schemas/index.js +1 -1
  640. package/umd/es6/min/persisters/persister-pglite/with-schemas/index.js.gz +0 -0
  641. package/umd/es6/min/persisters/persister-postgres/index.js +1 -1
  642. package/umd/es6/min/persisters/persister-postgres/index.js.gz +0 -0
  643. package/umd/es6/min/persisters/persister-postgres/with-schemas/index.js +1 -1
  644. package/umd/es6/min/persisters/persister-postgres/with-schemas/index.js.gz +0 -0
  645. package/umd/es6/min/persisters/persister-powersync/index.js +1 -1
  646. package/umd/es6/min/persisters/persister-powersync/index.js.gz +0 -0
  647. package/umd/es6/min/persisters/persister-powersync/with-schemas/index.js +1 -1
  648. package/umd/es6/min/persisters/persister-powersync/with-schemas/index.js.gz +0 -0
  649. package/umd/es6/min/persisters/persister-sqlite-wasm/index.js +1 -1
  650. package/umd/es6/min/persisters/persister-sqlite-wasm/index.js.gz +0 -0
  651. package/umd/es6/min/persisters/persister-sqlite-wasm/with-schemas/index.js +1 -1
  652. package/umd/es6/min/persisters/persister-sqlite-wasm/with-schemas/index.js.gz +0 -0
  653. package/umd/es6/min/persisters/persister-sqlite3/index.js +1 -1
  654. package/umd/es6/min/persisters/persister-sqlite3/index.js.gz +0 -0
  655. package/umd/es6/min/persisters/persister-sqlite3/with-schemas/index.js +1 -1
  656. package/umd/es6/min/persisters/persister-sqlite3/with-schemas/index.js.gz +0 -0
  657. package/umd/es6/min/persisters/with-schemas/index.js +1 -1
  658. package/umd/es6/min/persisters/with-schemas/index.js.gz +0 -0
  659. package/umd/es6/min/store/index.js +1 -1
  660. package/umd/es6/min/store/index.js.gz +0 -0
  661. package/umd/es6/min/store/with-schemas/index.js +1 -1
  662. package/umd/es6/min/store/with-schemas/index.js.gz +0 -0
  663. package/umd/es6/min/synchronizers/index.js +1 -1
  664. package/umd/es6/min/synchronizers/index.js.gz +0 -0
  665. package/umd/es6/min/synchronizers/synchronizer-broadcast-channel/index.js +1 -1
  666. package/umd/es6/min/synchronizers/synchronizer-broadcast-channel/index.js.gz +0 -0
  667. package/umd/es6/min/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js +1 -1
  668. package/umd/es6/min/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js.gz +0 -0
  669. package/umd/es6/min/synchronizers/synchronizer-local/index.js +1 -1
  670. package/umd/es6/min/synchronizers/synchronizer-local/index.js.gz +0 -0
  671. package/umd/es6/min/synchronizers/synchronizer-local/with-schemas/index.js +1 -1
  672. package/umd/es6/min/synchronizers/synchronizer-local/with-schemas/index.js.gz +0 -0
  673. package/umd/es6/min/synchronizers/synchronizer-ws-client/index.js +1 -1
  674. package/umd/es6/min/synchronizers/synchronizer-ws-client/index.js.gz +0 -0
  675. package/umd/es6/min/synchronizers/synchronizer-ws-client/with-schemas/index.js +1 -1
  676. package/umd/es6/min/synchronizers/synchronizer-ws-client/with-schemas/index.js.gz +0 -0
  677. package/umd/es6/min/synchronizers/synchronizer-ws-server/index.js +1 -1
  678. package/umd/es6/min/synchronizers/synchronizer-ws-server/index.js.gz +0 -0
  679. package/umd/es6/min/synchronizers/synchronizer-ws-server/with-schemas/index.js +1 -1
  680. package/umd/es6/min/synchronizers/synchronizer-ws-server/with-schemas/index.js.gz +0 -0
  681. package/umd/es6/min/synchronizers/with-schemas/index.js +1 -1
  682. package/umd/es6/min/synchronizers/with-schemas/index.js.gz +0 -0
  683. package/umd/es6/min/tools/index.js +1 -1
  684. package/umd/es6/min/tools/index.js.gz +0 -0
  685. package/umd/es6/min/tools/with-schemas/index.js +1 -1
  686. package/umd/es6/min/tools/with-schemas/index.js.gz +0 -0
  687. package/umd/es6/min/ui-react/index.js +1 -1
  688. package/umd/es6/min/ui-react/index.js.gz +0 -0
  689. package/umd/es6/min/ui-react/with-schemas/index.js +1 -1
  690. package/umd/es6/min/ui-react/with-schemas/index.js.gz +0 -0
  691. package/umd/es6/min/ui-react-dom/index.js +1 -1
  692. package/umd/es6/min/ui-react-dom/index.js.gz +0 -0
  693. package/umd/es6/min/ui-react-dom/with-schemas/index.js +1 -1
  694. package/umd/es6/min/ui-react-dom/with-schemas/index.js.gz +0 -0
  695. package/umd/es6/min/ui-react-inspector/index.js +1 -1
  696. package/umd/es6/min/ui-react-inspector/index.js.gz +0 -0
  697. package/umd/es6/min/ui-react-inspector/with-schemas/index.js +1 -1
  698. package/umd/es6/min/ui-react-inspector/with-schemas/index.js.gz +0 -0
  699. package/umd/es6/min/with-schemas/index.js +1 -1
  700. package/umd/es6/min/with-schemas/index.js.gz +0 -0
  701. package/umd/es6/persisters/index.js +83 -103
  702. package/umd/es6/persisters/persister-cr-sqlite-wasm/index.js +82 -102
  703. package/umd/es6/persisters/persister-cr-sqlite-wasm/with-schemas/index.js +82 -102
  704. package/umd/es6/persisters/persister-electric-sql/index.js +82 -102
  705. package/umd/es6/persisters/persister-electric-sql/with-schemas/index.js +82 -102
  706. package/umd/es6/persisters/persister-expo-sqlite/index.js +82 -102
  707. package/umd/es6/persisters/persister-expo-sqlite/with-schemas/index.js +82 -102
  708. package/umd/es6/persisters/persister-libsql/index.js +82 -102
  709. package/umd/es6/persisters/persister-libsql/with-schemas/index.js +82 -102
  710. package/umd/es6/persisters/persister-pglite/index.js +82 -102
  711. package/umd/es6/persisters/persister-pglite/with-schemas/index.js +82 -102
  712. package/umd/es6/persisters/persister-postgres/index.js +81 -101
  713. package/umd/es6/persisters/persister-postgres/with-schemas/index.js +81 -101
  714. package/umd/es6/persisters/persister-powersync/index.js +212 -147
  715. package/umd/es6/persisters/persister-powersync/with-schemas/index.js +212 -147
  716. package/umd/es6/persisters/persister-sqlite-wasm/index.js +82 -102
  717. package/umd/es6/persisters/persister-sqlite-wasm/with-schemas/index.js +82 -102
  718. package/umd/es6/persisters/persister-sqlite3/index.js +82 -102
  719. package/umd/es6/persisters/persister-sqlite3/with-schemas/index.js +82 -102
  720. package/umd/es6/persisters/with-schemas/index.js +83 -103
  721. package/umd/es6/queries/index.js +1 -1
  722. package/umd/es6/queries/with-schemas/index.js +1 -1
  723. package/umd/es6/store/index.js +0 -6
  724. package/umd/es6/store/with-schemas/index.js +0 -6
  725. package/umd/es6/synchronizers/index.js +5 -7
  726. package/umd/es6/synchronizers/synchronizer-broadcast-channel/index.js +5 -7
  727. package/umd/es6/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js +5 -7
  728. package/umd/es6/synchronizers/synchronizer-local/index.js +5 -7
  729. package/umd/es6/synchronizers/synchronizer-local/with-schemas/index.js +5 -7
  730. package/umd/es6/synchronizers/synchronizer-ws-client/index.js +5 -7
  731. package/umd/es6/synchronizers/synchronizer-ws-client/with-schemas/index.js +5 -7
  732. package/umd/es6/synchronizers/synchronizer-ws-server/index.js +5 -7
  733. package/umd/es6/synchronizers/synchronizer-ws-server/with-schemas/index.js +5 -7
  734. package/umd/es6/synchronizers/with-schemas/index.js +5 -7
  735. package/umd/es6/tools/index.js +7 -4
  736. package/umd/es6/tools/with-schemas/index.js +7 -4
  737. package/umd/es6/ui-react/index.js +101 -118
  738. package/umd/es6/ui-react/with-schemas/index.js +101 -118
  739. package/umd/es6/ui-react-dom/index.js +14 -8
  740. package/umd/es6/ui-react-dom/with-schemas/index.js +14 -8
  741. package/umd/es6/ui-react-inspector/index.js +17 -17
  742. package/umd/es6/ui-react-inspector/with-schemas/index.js +17 -17
  743. package/umd/es6/with-schemas/index.js +18 -12
  744. package/umd/index.js +18 -12
  745. package/umd/indexes/index.js +0 -6
  746. package/umd/indexes/with-schemas/index.js +0 -6
  747. package/umd/mergeable-store/index.js +17 -11
  748. package/umd/mergeable-store/with-schemas/index.js +17 -11
  749. package/umd/metrics/index.js +1 -1
  750. package/umd/metrics/with-schemas/index.js +1 -1
  751. package/umd/min/common/index.js +1 -1
  752. package/umd/min/common/index.js.gz +0 -0
  753. package/umd/min/common/with-schemas/index.js +1 -1
  754. package/umd/min/common/with-schemas/index.js.gz +0 -0
  755. package/umd/min/index.js +1 -1
  756. package/umd/min/index.js.gz +0 -0
  757. package/umd/min/indexes/index.js +1 -1
  758. package/umd/min/indexes/index.js.gz +0 -0
  759. package/umd/min/indexes/with-schemas/index.js +1 -1
  760. package/umd/min/indexes/with-schemas/index.js.gz +0 -0
  761. package/umd/min/mergeable-store/index.js +1 -1
  762. package/umd/min/mergeable-store/index.js.gz +0 -0
  763. package/umd/min/mergeable-store/with-schemas/index.js +1 -1
  764. package/umd/min/mergeable-store/with-schemas/index.js.gz +0 -0
  765. package/umd/min/persisters/index.js +1 -1
  766. package/umd/min/persisters/index.js.gz +0 -0
  767. package/umd/min/persisters/persister-cr-sqlite-wasm/index.js +1 -1
  768. package/umd/min/persisters/persister-cr-sqlite-wasm/index.js.gz +0 -0
  769. package/umd/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.js +1 -1
  770. package/umd/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.js.gz +0 -0
  771. package/umd/min/persisters/persister-electric-sql/index.js +1 -1
  772. package/umd/min/persisters/persister-electric-sql/index.js.gz +0 -0
  773. package/umd/min/persisters/persister-electric-sql/with-schemas/index.js +1 -1
  774. package/umd/min/persisters/persister-electric-sql/with-schemas/index.js.gz +0 -0
  775. package/umd/min/persisters/persister-expo-sqlite/index.js +1 -1
  776. package/umd/min/persisters/persister-expo-sqlite/index.js.gz +0 -0
  777. package/umd/min/persisters/persister-expo-sqlite/with-schemas/index.js +1 -1
  778. package/umd/min/persisters/persister-expo-sqlite/with-schemas/index.js.gz +0 -0
  779. package/umd/min/persisters/persister-libsql/index.js +1 -1
  780. package/umd/min/persisters/persister-libsql/index.js.gz +0 -0
  781. package/umd/min/persisters/persister-libsql/with-schemas/index.js +1 -1
  782. package/umd/min/persisters/persister-libsql/with-schemas/index.js.gz +0 -0
  783. package/umd/min/persisters/persister-pglite/index.js +1 -1
  784. package/umd/min/persisters/persister-pglite/index.js.gz +0 -0
  785. package/umd/min/persisters/persister-pglite/with-schemas/index.js +1 -1
  786. package/umd/min/persisters/persister-pglite/with-schemas/index.js.gz +0 -0
  787. package/umd/min/persisters/persister-postgres/index.js +1 -1
  788. package/umd/min/persisters/persister-postgres/index.js.gz +0 -0
  789. package/umd/min/persisters/persister-postgres/with-schemas/index.js +1 -1
  790. package/umd/min/persisters/persister-postgres/with-schemas/index.js.gz +0 -0
  791. package/umd/min/persisters/persister-powersync/index.js +1 -1
  792. package/umd/min/persisters/persister-powersync/index.js.gz +0 -0
  793. package/umd/min/persisters/persister-powersync/with-schemas/index.js +1 -1
  794. package/umd/min/persisters/persister-powersync/with-schemas/index.js.gz +0 -0
  795. package/umd/min/persisters/persister-sqlite-wasm/index.js +1 -1
  796. package/umd/min/persisters/persister-sqlite-wasm/index.js.gz +0 -0
  797. package/umd/min/persisters/persister-sqlite-wasm/with-schemas/index.js +1 -1
  798. package/umd/min/persisters/persister-sqlite-wasm/with-schemas/index.js.gz +0 -0
  799. package/umd/min/persisters/persister-sqlite3/index.js +1 -1
  800. package/umd/min/persisters/persister-sqlite3/index.js.gz +0 -0
  801. package/umd/min/persisters/persister-sqlite3/with-schemas/index.js +1 -1
  802. package/umd/min/persisters/persister-sqlite3/with-schemas/index.js.gz +0 -0
  803. package/umd/min/persisters/with-schemas/index.js +1 -1
  804. package/umd/min/persisters/with-schemas/index.js.gz +0 -0
  805. package/umd/min/store/index.js +1 -1
  806. package/umd/min/store/index.js.gz +0 -0
  807. package/umd/min/store/with-schemas/index.js +1 -1
  808. package/umd/min/store/with-schemas/index.js.gz +0 -0
  809. package/umd/min/synchronizers/index.js +1 -1
  810. package/umd/min/synchronizers/index.js.gz +0 -0
  811. package/umd/min/synchronizers/synchronizer-broadcast-channel/index.js +1 -1
  812. package/umd/min/synchronizers/synchronizer-broadcast-channel/index.js.gz +0 -0
  813. package/umd/min/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js +1 -1
  814. package/umd/min/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js.gz +0 -0
  815. package/umd/min/synchronizers/synchronizer-local/index.js +1 -1
  816. package/umd/min/synchronizers/synchronizer-local/index.js.gz +0 -0
  817. package/umd/min/synchronizers/synchronizer-local/with-schemas/index.js +1 -1
  818. package/umd/min/synchronizers/synchronizer-local/with-schemas/index.js.gz +0 -0
  819. package/umd/min/synchronizers/synchronizer-ws-client/index.js +1 -1
  820. package/umd/min/synchronizers/synchronizer-ws-client/index.js.gz +0 -0
  821. package/umd/min/synchronizers/synchronizer-ws-client/with-schemas/index.js +1 -1
  822. package/umd/min/synchronizers/synchronizer-ws-client/with-schemas/index.js.gz +0 -0
  823. package/umd/min/synchronizers/synchronizer-ws-server/index.js +1 -1
  824. package/umd/min/synchronizers/synchronizer-ws-server/index.js.gz +0 -0
  825. package/umd/min/synchronizers/synchronizer-ws-server/with-schemas/index.js +1 -1
  826. package/umd/min/synchronizers/synchronizer-ws-server/with-schemas/index.js.gz +0 -0
  827. package/umd/min/synchronizers/with-schemas/index.js +1 -1
  828. package/umd/min/synchronizers/with-schemas/index.js.gz +0 -0
  829. package/umd/min/tools/index.js +1 -1
  830. package/umd/min/tools/index.js.gz +0 -0
  831. package/umd/min/tools/with-schemas/index.js +1 -1
  832. package/umd/min/tools/with-schemas/index.js.gz +0 -0
  833. package/umd/min/ui-react/index.js +1 -1
  834. package/umd/min/ui-react/index.js.gz +0 -0
  835. package/umd/min/ui-react/with-schemas/index.js +1 -1
  836. package/umd/min/ui-react/with-schemas/index.js.gz +0 -0
  837. package/umd/min/ui-react-dom/index.js +1 -1
  838. package/umd/min/ui-react-dom/index.js.gz +0 -0
  839. package/umd/min/ui-react-dom/with-schemas/index.js +1 -1
  840. package/umd/min/ui-react-dom/with-schemas/index.js.gz +0 -0
  841. package/umd/min/ui-react-inspector/index.js +1 -1
  842. package/umd/min/ui-react-inspector/index.js.gz +0 -0
  843. package/umd/min/ui-react-inspector/with-schemas/index.js +1 -1
  844. package/umd/min/ui-react-inspector/with-schemas/index.js.gz +0 -0
  845. package/umd/min/with-schemas/index.js +1 -1
  846. package/umd/min/with-schemas/index.js.gz +0 -0
  847. package/umd/persisters/index.js +80 -98
  848. package/umd/persisters/persister-cr-sqlite-wasm/index.js +79 -97
  849. package/umd/persisters/persister-cr-sqlite-wasm/with-schemas/index.js +79 -97
  850. package/umd/persisters/persister-electric-sql/index.js +79 -97
  851. package/umd/persisters/persister-electric-sql/with-schemas/index.js +79 -97
  852. package/umd/persisters/persister-expo-sqlite/index.js +79 -97
  853. package/umd/persisters/persister-expo-sqlite/with-schemas/index.js +79 -97
  854. package/umd/persisters/persister-libsql/index.js +79 -97
  855. package/umd/persisters/persister-libsql/with-schemas/index.js +79 -97
  856. package/umd/persisters/persister-pglite/index.js +79 -97
  857. package/umd/persisters/persister-pglite/with-schemas/index.js +79 -97
  858. package/umd/persisters/persister-postgres/index.js +78 -96
  859. package/umd/persisters/persister-postgres/with-schemas/index.js +78 -96
  860. package/umd/persisters/persister-powersync/index.js +203 -142
  861. package/umd/persisters/persister-powersync/with-schemas/index.js +203 -142
  862. package/umd/persisters/persister-sqlite-wasm/index.js +79 -97
  863. package/umd/persisters/persister-sqlite-wasm/with-schemas/index.js +79 -97
  864. package/umd/persisters/persister-sqlite3/index.js +79 -97
  865. package/umd/persisters/persister-sqlite3/with-schemas/index.js +79 -97
  866. package/umd/persisters/with-schemas/index.js +80 -98
  867. package/umd/queries/index.js +1 -1
  868. package/umd/queries/with-schemas/index.js +1 -1
  869. package/umd/store/index.js +0 -6
  870. package/umd/store/with-schemas/index.js +0 -6
  871. package/umd/synchronizers/index.js +5 -7
  872. package/umd/synchronizers/synchronizer-broadcast-channel/index.js +5 -7
  873. package/umd/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js +5 -7
  874. package/umd/synchronizers/synchronizer-local/index.js +5 -7
  875. package/umd/synchronizers/synchronizer-local/with-schemas/index.js +5 -7
  876. package/umd/synchronizers/synchronizer-ws-client/index.js +5 -7
  877. package/umd/synchronizers/synchronizer-ws-client/with-schemas/index.js +5 -7
  878. package/umd/synchronizers/synchronizer-ws-server/index.js +5 -7
  879. package/umd/synchronizers/synchronizer-ws-server/with-schemas/index.js +5 -7
  880. package/umd/synchronizers/with-schemas/index.js +5 -7
  881. package/umd/tools/index.js +7 -4
  882. package/umd/tools/with-schemas/index.js +7 -4
  883. package/umd/ui-react/index.js +97 -110
  884. package/umd/ui-react/with-schemas/index.js +97 -110
  885. package/umd/ui-react-dom/index.js +14 -8
  886. package/umd/ui-react-dom/with-schemas/index.js +14 -8
  887. package/umd/ui-react-inspector/index.js +17 -17
  888. package/umd/ui-react-inspector/with-schemas/index.js +17 -17
  889. package/umd/with-schemas/index.js +18 -12
  890. package/with-schemas/index.js +18 -12
@@ -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)=>a.listen(t,e)),(async t=>{try{await t()}catch(t){i?.(t)}}),s,i,(()=>0),3,a,"getPglite")},"object"==typeof exports&&"undefined"!=typeof module?a(exports):"function"==typeof define&&define.amd?define(["exports"],a):a((t="undefined"!=typeof globalThis?globalThis:t||self).TinyBasePersisterPglite={});
1
+ var t,a;t=this,a=function(t){"use strict";const a=t=>typeof t,e="tinybase",n=",",s=a(""),i=Promise,o=t=>null==t,r=(t,a,e)=>o(t)?e?.():a(t),c=t=>a(t)==s,l=t=>Array.isArray(t),E=(t,a,e)=>t.slice(a,e),y=t=>t.length,w=async t=>i.all(t),d=t=>{throw Error(t)},u=(t,a)=>t.forEach(a),T=(t,a="")=>t.join(a),R=(t,a)=>t.map(a),A=t=>0==y(t),N=(t,a)=>t.filter(a),g=(t,...a)=>t.push(...a),p=t=>t.shift(),C="_",O="_id",f="SELECT",v="WHERE",L="TABLE",$="ALTER "+L,m="DELETE FROM",I=f+"*FROM",S=t=>`"${t.replace(/"/g,'""')}"`,h=(t,a=[1])=>T(R(t,(()=>"$"+a[0]++)),n),_=(t,a)=>t?.has(a)??!1,b=t=>o(t)||0==(t=>t?.size??0)(t),P=t=>[...t?.values()??[]],D=(t,a)=>t?.forEach(a),U=(t,a)=>t?.delete(a),F=Object,M=t=>F.getPrototypeOf(t),G=F.entries,B=F.keys,j=F.freeze,x=(t=[])=>F.fromEntries(t),X=(...t)=>F.assign({},...t),Y=(t,a)=>(delete t[a],t),q=(t,a)=>R(G(t),(([t,e])=>a(e,t))),H=t=>F.values(t),W=t=>y(B(t)),k=t=>(t=>!o(t)&&r(M(t),(t=>t==F.prototype||o(M(t))),(()=>!0)))(t)&&0==W(t),z=JSON.stringify,J=JSON.parse,K=t=>new Map(t),V=(t,a)=>t?.get(a),Q=(t,a)=>R([...t?.entries()??[]],(([t,e])=>a(e,t))),Z=(t,a,e)=>o(e)?(U(t,a),t):t?.set(a,e),tt=(t,a,e,n)=>(_(t,a)?n?.(V(t,a)):Z(t,a,e()),V(t,a)),at=(t,a,e,n,s=0)=>r((e?tt:V)(t,a[s],s>y(a)-2?e:K),(i=>{if(s>y(a)-2)return n?.(i)&&Z(t,a[s]),i;const o=at(i,a,e,n,s+1);return b(i)&&Z(t,a[s]),o})),et=t=>new Set(l(t)||o(t)?t:[t]),nt=(t,a)=>t?.add(a),st=/^\d+$/,it=K(),ot=K(),rt=(t,a,e,n,s,i,c,E={},w=[])=>{let T,R,A,N=0,C=0,O=0;tt(it,w,(()=>0)),tt(ot,w,(()=>[]));const f=K(),[v,L,$,m,I]=((t=1,a)=>1!=t&&a.isMergeable()?[1,a.getMergeableContent,a.getTransactionMergeableChanges,([[t],[a]])=>!k(t)||!k(a),a.setDefaultContent]:2!=t?[0,a.getContent,a.getTransactionChanges,([t,a])=>!k(t)||!k(a),a.setContent]:d("Store type not supported by this Persister"))(c,t),[S,h,_]=(()=>{let t;const[a,e]=(()=>{const t=[];let a=0;return[e=>(e?p(t):null)??""+a++,a=>{st.test(a)&&y(t)<1e3&&g(t,a)}]})(),n=K();return[(e,s,i,o=[],r=()=>[])=>{t??=Y;const c=a(1);return Z(n,c,[e,s,i,o,r]),nt(at(s,i??[""],et),c),c},(a,e,...s)=>u(((t,a=[""])=>{const e=[],n=(t,s)=>s==y(a)?g(e,t):null===a[s]?D(t,(t=>n(t,s+1))):u([a[s],null],(a=>n(V(t,a),s+1)));return n(t,0),e})(a,e),(a=>D(a,(a=>V(n,a)[0](t,...e??[],...s))))),t=>r(V(n,t),(([,a,s])=>(at(a,s??[""],void 0,(a=>(U(a,t),b(a)?1:0))),Z(n,t),e(t),s))),a=>r(V(n,a),(([a,,e=[],n,s])=>{const i=(...r)=>{const c=y(r);c==y(e)?a(t,...r,...s(r)):o(e[c])?u(n[c]?.(...r)??[],(t=>i(...r,t))):i(...r,e[c])};i()}))]})(),P=t=>{t!=N&&(N=t,h(f,void 0,N))},F=a=>{(v&&l(a?.[0])?1===a?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===a?.[2]?t.applyChanges:t.setContent)(a)},M=async t=>(2!=N&&(P(1),C++,await X((async()=>{try{const t=await a();l(t)?F(t):d("Content is not an array "+t)}catch(a){i?.(a),t&&I(t)}P(0)}))),Y),G=()=>(R&&(s(R),R=void 0),Y),B=async t=>(1!=N&&(P(2),O++,await X((async()=>{try{await e(L,t)}catch(t){i?.(t)}P(0)}))),Y),x=()=>(r(A,t.delListener),A=void 0,Y),X=async(...t)=>(g(V(ot,w),...t),await(async()=>{if(!V(it,w)){for(Z(it,w,1);!o(T=p(V(ot,w)));)try{await T()}catch(t){i?.(t)}Z(it,w,0)}})(),Y),Y={load:M,startAutoLoad:async t=>{await G().load(t);try{R=await n((async(t,a)=>{a||t?2!=N&&(P(1),C++,F(a??t),P(0)):await M()}))}catch(t){i?.(t)}return Y},stopAutoLoad:G,isAutoLoading:()=>!o(R),save:B,startAutoSave:async()=>(await x().save(),A=t.addDidFinishTransactionListener((()=>{const t=$();m(t)&&B(t)})),Y),stopAutoSave:x,isAutoSaving:()=>!o(A),getStatus:()=>N,addStatusListener:t=>S(t,f),delListener:a=>(_(a),t),schedule:X,getStore:()=>t,destroy:()=>(V(ot,w).splice(0,void 0),G().stopAutoSave()),getStats:()=>({loads:C,saves:O}),...E};return j(Y)},ct=(t,a,e,s,i,r=lt,c,l)=>{const E=K();return[async()=>{E.clear(),R(await e(t,a),(({tn:t,cn:a})=>nt(tt(E,t,et),a)))},async(a,e)=>((t,a)=>_(V(E,t),a))(a,e)?x(N(R(await t(I+S(a)),(t=>{return[t[e],l?(a=Y(t,e),n=l,x(q(a,((t,a)=>[a,n(t,a)])))):Y(t,e)];var a,n})),(([t,a])=>!o(t)&&!k(a)))):{},async(a,e,s,l,y,d=!1)=>{const u=et();q(s??{},(t=>R(B(t??{}),(t=>nt(u,t)))));const p=P(u);if(!d&&y&&A(p)&&_(E,a))return await t("DROP "+L+S(a)),void Z(E,a);const C=V(E,a),O=et(P(C));if(A(p)||(_(E,a)?await w(R([e,...p],(async(n,s)=>{U(O,n)||(await t($+S(a)+"ADD"+S(n)+i),0==s&&await t("CREATE UNIQUE INDEX pk ON "+S(a)+`(${S(e)})`),nt(C,n))}))):(await t("CREATE "+L+S(a)+`(${S(e)}${i} PRIMARY KEY${T(R(p,(t=>n+S(t)+i)))});`),Z(E,a,et([e,...p])))),await w([...!d&&l?R(P(O),(async n=>{n!=e&&(await t($+S(a)+"DROP"+S(n)),U(C,n))})):[]]),d)o(s)?await t(m+S(a)+v+" true"):await w(q(s,(async(n,s)=>{o(n)?await t(m+S(a)+v+S(e)+"=$1",[s]):A(p)||await r(t,a,e,B(n),{[s]:c?R(H(n),c):H(n)},C)})));else if(A(p))_(E,a)&&await t(m+S(a)+v+" true");else{const n=N(P(V(E,a)),(t=>t!=e)),i={},o=[];q(s??{},((t,a)=>{i[a]=R(n,(a=>c?c(t?.[a]):t?.[a])),g(o,a)})),await r(t,a,e,n,i),await t(m+S(a)+v+S(e)+`NOT IN(${h(o)})`,o)}},async a=>{let e;await t("BEGIN");try{e=await a()}catch(t){s?.(t)}return await t("END"),e}]},lt=async(t,a,e,s,i)=>{const o=[1];await t("INSERT INTO"+S(a)+"("+((...t)=>T(R(t,S),n))(e,...s)+")VALUES"+T(q(i,(t=>"($"+o[0]+++","+h(t,o)+")")),n)+"ON CONFLICT("+S(e)+")DO UPDATE SET"+T(R(s,(t=>S(t)+"=excluded."+S(t))),n),q(i,((t,a)=>[a,...R(t,(t=>t??null))])).flat())},Et=(t,a,e,n,s,i,o,[r,c,l],E,y,w,d,u,T)=>{const[R,A,N,g]=ct(a,E,y,s,u,T),p=rt(t,(async()=>await g((async()=>{return await R(),t=(await A(r,c))[C]?.[l]??"null",J(t,((t,a)=>""===a?void 0:a));var t}))),(async t=>await g((async()=>{var a;await R(),await N(r,c,{[C]:{[l]:(a=t()??null,z(a,((t,a)=>void 0===a?"":a)))}},!0,!0)}))),e,n,s,o,{[d]:()=>w,destroy:()=>(p.stopAutoLoad().stopAutoSave(),i(),p)},w);return p},yt=(t,a,e,n,s,i,r,[c,l,[E,y,d]],u,T,R,A,g,p,f,v)=>{const[L,$,m,I]=ct(a,u,T,s,g,p,f,v),S=async(t,a)=>await w(Q(l,(async([e,n,s,i],o)=>{a&&!(o in t)||await m(e,n,t[o],s,i,a)}))),h=async(t,a)=>y?await m(d,O,{[C]:t},!0,!0,a):null,_=rt(t,(async()=>await I((async()=>{await L();const t=await(async()=>x(N(await w(Q(c,(async([t,a],e)=>[t,await $(e,a)]))),(t=>!k(t[1])))))(),a=await(async()=>E?(await $(d,O))[C]:{})();return k(t)&&o(a)?void 0:[t,a]}))),(async(t,a)=>await I((async()=>{if(await L(),o(a)){const[a,e]=t();await S(a),await h(e)}else await S(a[0],!0),await h(a[1],!0)}))),e,n,s,r,{[A]:()=>R,destroy:()=>(_.stopAutoLoad().stopAutoSave(),i(),_)},R);return _},wt="ColumnName",dt="store",ut="json",Tt=dt+"TableName",Rt=dt+"Id"+wt,At=dt+wt,Nt="autoLoadIntervalSeconds",gt="rowId"+wt,pt="tableId",Ct="tableName",Ot="deleteEmptyColumns",ft="deleteEmptyTable",vt={mode:ut,[Nt]:1},Lt={load:0,save:0,[Ct]:e+"_values"},$t=(t,a,e,n,s)=>{const i=K();return q(t,((t,r)=>{const l=E(H(X(a,c(t)?{[e]:t}:t)),0,W(a));o(l[0])||n(r,l[0])||(s(r,l[0]),Z(i,r,l))})),i},mt=e,It=/^([cd]:)(.+)/,St=e+"_data",ht=e+"_table";t.createPglitePersister=async(t,a,n,s,i)=>((t,a,n,s,i,o,l,y,d,u,T="getDb")=>{const A=((t,a)=>a?async(e,n)=>(a(e,n),await t(e,n)):t)(n,o),[N,,g,p]=(t=>{const a=(t=>X(vt,c(t)?{[Tt]:t}:t??{}))(t),n=a[Nt];if(a.mode==ut){const t=a[Tt]??e;return[1,n,[t,a[Rt]??O,a[At]??dt],et(t)]}const{tables:{load:s={},save:i={}}={},values:o={}}=a,r=E(H(X(Lt,o)),0,W(Lt)),l=r[2],y=et(l),w=et(l);return[0,n,[$t(s,{[pt]:null,[gt]:O},pt,(t=>_(w,t)),(t=>nt(y,t))),$t(i,{[Ct]:null,[gt]:O,[Ot]:0,[ft]:0},Ct,((t,a)=>_(w,a)),((t,a)=>nt(y,a))),r],y]})(a),C=async t=>{await A(`CREATE OR REPLACE TRIGGER ${S(St+"_"+t)} AFTER INSERT OR UPDATE OR DELETE ON ${S(t)} EXECUTE FUNCTION ${St}()`)};return(N?Et:yt)(t,A,(async t=>{await A(`CREATE OR REPLACE FUNCTION ${ht}()RETURNS event_trigger AS $t2$ DECLARE row record; BEGIN FOR row IN SELECT object_identity FROM pg_event_trigger_ddl_commands()WHERE command_tag='CREATE TABLE' LOOP PERFORM pg_notify('${mt}','c:'||SPLIT_PART(row.object_identity,'.',2));END LOOP;END;$t2$ LANGUAGE plpgsql;`);try{await A(`CREATE EVENT TRIGGER ${ht} ON ddl_command_end WHEN TAG IN('CREATE TABLE')EXECUTE FUNCTION ${ht}();`)}catch{}return await A(`CREATE OR REPLACE FUNCTION ${St}()RETURNS trigger AS $t1$ BEGIN PERFORM pg_notify('${mt}','d:'||TG_TABLE_NAME);RETURN NULL;END;$t1$ LANGUAGE plpgsql;`),await w(R(P(p),(async t=>{await A(`CREATE TABLE IF NOT EXISTS ${S(t)}("_id"text PRIMARY KEY)`),await C(t)}))),await s(mt,(async a=>{return await r((e=a,n=It,e?.match(n)),(async([,a,e])=>{_(p,e)&&("c:"==a&&await C(e),t())}));var e,n}))}),i,l,y,d,g,P(p),(async(t,a)=>await t(`${f} table_name tn,column_name cn FROM information_schema.columns ${v} table_schema='public'AND table_name IN(${h(a)})`,a)),u,T,"text",void 0,(t=>z(t)),(t=>J(t)))})(t,n,(async(t,e=[])=>(await a.query(t,e)).rows),(async(t,e)=>await a.listen(t,e)),(async t=>{try{await t()}catch(t){i?.(t)}}),s,i,(()=>0),3,a,"getPglite")},"object"==typeof exports&&"undefined"!=typeof module?a(exports):"function"==typeof define&&define.amd?define(["exports"],a):a((t="undefined"!=typeof globalThis?globalThis:t||self).TinyBasePersisterPglite={});
@@ -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)=>a.listen(t,e)),(async t=>{try{await t()}catch(t){i?.(t)}}),s,i,(()=>0),3,a,"getPglite")},"object"==typeof exports&&"undefined"!=typeof module?a(exports):"function"==typeof define&&define.amd?define(["exports"],a):a((t="undefined"!=typeof globalThis?globalThis:t||self).TinyBasePersisterPglite={});
1
+ var t,a;t=this,a=function(t){"use strict";const a=t=>typeof t,e="tinybase",n=",",s=a(""),i=Promise,o=t=>null==t,r=(t,a,e)=>o(t)?e?.():a(t),c=t=>a(t)==s,l=t=>Array.isArray(t),E=(t,a,e)=>t.slice(a,e),y=t=>t.length,w=async t=>i.all(t),d=t=>{throw Error(t)},u=(t,a)=>t.forEach(a),T=(t,a="")=>t.join(a),R=(t,a)=>t.map(a),A=t=>0==y(t),N=(t,a)=>t.filter(a),g=(t,...a)=>t.push(...a),p=t=>t.shift(),C="_",O="_id",f="SELECT",v="WHERE",L="TABLE",$="ALTER "+L,m="DELETE FROM",I=f+"*FROM",S=t=>`"${t.replace(/"/g,'""')}"`,h=(t,a=[1])=>T(R(t,(()=>"$"+a[0]++)),n),_=(t,a)=>t?.has(a)??!1,b=t=>o(t)||0==(t=>t?.size??0)(t),P=t=>[...t?.values()??[]],D=(t,a)=>t?.forEach(a),U=(t,a)=>t?.delete(a),F=Object,M=t=>F.getPrototypeOf(t),G=F.entries,B=F.keys,j=F.freeze,x=(t=[])=>F.fromEntries(t),X=(...t)=>F.assign({},...t),Y=(t,a)=>(delete t[a],t),q=(t,a)=>R(G(t),(([t,e])=>a(e,t))),H=t=>F.values(t),W=t=>y(B(t)),k=t=>(t=>!o(t)&&r(M(t),(t=>t==F.prototype||o(M(t))),(()=>!0)))(t)&&0==W(t),z=JSON.stringify,J=JSON.parse,K=t=>new Map(t),V=(t,a)=>t?.get(a),Q=(t,a)=>R([...t?.entries()??[]],(([t,e])=>a(e,t))),Z=(t,a,e)=>o(e)?(U(t,a),t):t?.set(a,e),tt=(t,a,e,n)=>(_(t,a)?n?.(V(t,a)):Z(t,a,e()),V(t,a)),at=(t,a,e,n,s=0)=>r((e?tt:V)(t,a[s],s>y(a)-2?e:K),(i=>{if(s>y(a)-2)return n?.(i)&&Z(t,a[s]),i;const o=at(i,a,e,n,s+1);return b(i)&&Z(t,a[s]),o})),et=t=>new Set(l(t)||o(t)?t:[t]),nt=(t,a)=>t?.add(a),st=/^\d+$/,it=K(),ot=K(),rt=(t,a,e,n,s,i,c,E={},w=[])=>{let T,R,A,N=0,C=0,O=0;tt(it,w,(()=>0)),tt(ot,w,(()=>[]));const f=K(),[v,L,$,m,I]=((t=1,a)=>1!=t&&a.isMergeable()?[1,a.getMergeableContent,a.getTransactionMergeableChanges,([[t],[a]])=>!k(t)||!k(a),a.setDefaultContent]:2!=t?[0,a.getContent,a.getTransactionChanges,([t,a])=>!k(t)||!k(a),a.setContent]:d("Store type not supported by this Persister"))(c,t),[S,h,_]=(()=>{let t;const[a,e]=(()=>{const t=[];let a=0;return[e=>(e?p(t):null)??""+a++,a=>{st.test(a)&&y(t)<1e3&&g(t,a)}]})(),n=K();return[(e,s,i,o=[],r=()=>[])=>{t??=Y;const c=a(1);return Z(n,c,[e,s,i,o,r]),nt(at(s,i??[""],et),c),c},(a,e,...s)=>u(((t,a=[""])=>{const e=[],n=(t,s)=>s==y(a)?g(e,t):null===a[s]?D(t,(t=>n(t,s+1))):u([a[s],null],(a=>n(V(t,a),s+1)));return n(t,0),e})(a,e),(a=>D(a,(a=>V(n,a)[0](t,...e??[],...s))))),t=>r(V(n,t),(([,a,s])=>(at(a,s??[""],void 0,(a=>(U(a,t),b(a)?1:0))),Z(n,t),e(t),s))),a=>r(V(n,a),(([a,,e=[],n,s])=>{const i=(...r)=>{const c=y(r);c==y(e)?a(t,...r,...s(r)):o(e[c])?u(n[c]?.(...r)??[],(t=>i(...r,t))):i(...r,e[c])};i()}))]})(),P=t=>{t!=N&&(N=t,h(f,void 0,N))},F=a=>{(v&&l(a?.[0])?1===a?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===a?.[2]?t.applyChanges:t.setContent)(a)},M=async t=>(2!=N&&(P(1),C++,await X((async()=>{try{const t=await a();l(t)?F(t):d("Content is not an array "+t)}catch(a){i?.(a),t&&I(t)}P(0)}))),Y),G=()=>(R&&(s(R),R=void 0),Y),B=async t=>(1!=N&&(P(2),O++,await X((async()=>{try{await e(L,t)}catch(t){i?.(t)}P(0)}))),Y),x=()=>(r(A,t.delListener),A=void 0,Y),X=async(...t)=>(g(V(ot,w),...t),await(async()=>{if(!V(it,w)){for(Z(it,w,1);!o(T=p(V(ot,w)));)try{await T()}catch(t){i?.(t)}Z(it,w,0)}})(),Y),Y={load:M,startAutoLoad:async t=>{await G().load(t);try{R=await n((async(t,a)=>{a||t?2!=N&&(P(1),C++,F(a??t),P(0)):await M()}))}catch(t){i?.(t)}return Y},stopAutoLoad:G,isAutoLoading:()=>!o(R),save:B,startAutoSave:async()=>(await x().save(),A=t.addDidFinishTransactionListener((()=>{const t=$();m(t)&&B(t)})),Y),stopAutoSave:x,isAutoSaving:()=>!o(A),getStatus:()=>N,addStatusListener:t=>S(t,f),delListener:a=>(_(a),t),schedule:X,getStore:()=>t,destroy:()=>(V(ot,w).splice(0,void 0),G().stopAutoSave()),getStats:()=>({loads:C,saves:O}),...E};return j(Y)},ct=(t,a,e,s,i,r=lt,c,l)=>{const E=K();return[async()=>{E.clear(),R(await e(t,a),(({tn:t,cn:a})=>nt(tt(E,t,et),a)))},async(a,e)=>((t,a)=>_(V(E,t),a))(a,e)?x(N(R(await t(I+S(a)),(t=>{return[t[e],l?(a=Y(t,e),n=l,x(q(a,((t,a)=>[a,n(t,a)])))):Y(t,e)];var a,n})),(([t,a])=>!o(t)&&!k(a)))):{},async(a,e,s,l,y,d=!1)=>{const u=et();q(s??{},(t=>R(B(t??{}),(t=>nt(u,t)))));const p=P(u);if(!d&&y&&A(p)&&_(E,a))return await t("DROP "+L+S(a)),void Z(E,a);const C=V(E,a),O=et(P(C));if(A(p)||(_(E,a)?await w(R([e,...p],(async(n,s)=>{U(O,n)||(await t($+S(a)+"ADD"+S(n)+i),0==s&&await t("CREATE UNIQUE INDEX pk ON "+S(a)+`(${S(e)})`),nt(C,n))}))):(await t("CREATE "+L+S(a)+`(${S(e)}${i} PRIMARY KEY${T(R(p,(t=>n+S(t)+i)))});`),Z(E,a,et([e,...p])))),await w([...!d&&l?R(P(O),(async n=>{n!=e&&(await t($+S(a)+"DROP"+S(n)),U(C,n))})):[]]),d)o(s)?await t(m+S(a)+v+" true"):await w(q(s,(async(n,s)=>{o(n)?await t(m+S(a)+v+S(e)+"=$1",[s]):A(p)||await r(t,a,e,B(n),{[s]:c?R(H(n),c):H(n)},C)})));else if(A(p))_(E,a)&&await t(m+S(a)+v+" true");else{const n=N(P(V(E,a)),(t=>t!=e)),i={},o=[];q(s??{},((t,a)=>{i[a]=R(n,(a=>c?c(t?.[a]):t?.[a])),g(o,a)})),await r(t,a,e,n,i),await t(m+S(a)+v+S(e)+`NOT IN(${h(o)})`,o)}},async a=>{let e;await t("BEGIN");try{e=await a()}catch(t){s?.(t)}return await t("END"),e}]},lt=async(t,a,e,s,i)=>{const o=[1];await t("INSERT INTO"+S(a)+"("+((...t)=>T(R(t,S),n))(e,...s)+")VALUES"+T(q(i,(t=>"($"+o[0]+++","+h(t,o)+")")),n)+"ON CONFLICT("+S(e)+")DO UPDATE SET"+T(R(s,(t=>S(t)+"=excluded."+S(t))),n),q(i,((t,a)=>[a,...R(t,(t=>t??null))])).flat())},Et=(t,a,e,n,s,i,o,[r,c,l],E,y,w,d,u,T)=>{const[R,A,N,g]=ct(a,E,y,s,u,T),p=rt(t,(async()=>await g((async()=>{return await R(),t=(await A(r,c))[C]?.[l]??"null",J(t,((t,a)=>""===a?void 0:a));var t}))),(async t=>await g((async()=>{var a;await R(),await N(r,c,{[C]:{[l]:(a=t()??null,z(a,((t,a)=>void 0===a?"":a)))}},!0,!0)}))),e,n,s,o,{[d]:()=>w,destroy:()=>(p.stopAutoLoad().stopAutoSave(),i(),p)},w);return p},yt=(t,a,e,n,s,i,r,[c,l,[E,y,d]],u,T,R,A,g,p,f,v)=>{const[L,$,m,I]=ct(a,u,T,s,g,p,f,v),S=async(t,a)=>await w(Q(l,(async([e,n,s,i],o)=>{a&&!(o in t)||await m(e,n,t[o],s,i,a)}))),h=async(t,a)=>y?await m(d,O,{[C]:t},!0,!0,a):null,_=rt(t,(async()=>await I((async()=>{await L();const t=await(async()=>x(N(await w(Q(c,(async([t,a],e)=>[t,await $(e,a)]))),(t=>!k(t[1])))))(),a=await(async()=>E?(await $(d,O))[C]:{})();return k(t)&&o(a)?void 0:[t,a]}))),(async(t,a)=>await I((async()=>{if(await L(),o(a)){const[a,e]=t();await S(a),await h(e)}else await S(a[0],!0),await h(a[1],!0)}))),e,n,s,r,{[A]:()=>R,destroy:()=>(_.stopAutoLoad().stopAutoSave(),i(),_)},R);return _},wt="ColumnName",dt="store",ut="json",Tt=dt+"TableName",Rt=dt+"Id"+wt,At=dt+wt,Nt="autoLoadIntervalSeconds",gt="rowId"+wt,pt="tableId",Ct="tableName",Ot="deleteEmptyColumns",ft="deleteEmptyTable",vt={mode:ut,[Nt]:1},Lt={load:0,save:0,[Ct]:e+"_values"},$t=(t,a,e,n,s)=>{const i=K();return q(t,((t,r)=>{const l=E(H(X(a,c(t)?{[e]:t}:t)),0,W(a));o(l[0])||n(r,l[0])||(s(r,l[0]),Z(i,r,l))})),i},mt=e,It=/^([cd]:)(.+)/,St=e+"_data",ht=e+"_table";t.createPglitePersister=async(t,a,n,s,i)=>((t,a,n,s,i,o,l,y,d,u,T="getDb")=>{const A=((t,a)=>a?async(e,n)=>(a(e,n),await t(e,n)):t)(n,o),[N,,g,p]=(t=>{const a=(t=>X(vt,c(t)?{[Tt]:t}:t??{}))(t),n=a[Nt];if(a.mode==ut){const t=a[Tt]??e;return[1,n,[t,a[Rt]??O,a[At]??dt],et(t)]}const{tables:{load:s={},save:i={}}={},values:o={}}=a,r=E(H(X(Lt,o)),0,W(Lt)),l=r[2],y=et(l),w=et(l);return[0,n,[$t(s,{[pt]:null,[gt]:O},pt,(t=>_(w,t)),(t=>nt(y,t))),$t(i,{[Ct]:null,[gt]:O,[Ot]:0,[ft]:0},Ct,((t,a)=>_(w,a)),((t,a)=>nt(y,a))),r],y]})(a),C=async t=>{await A(`CREATE OR REPLACE TRIGGER ${S(St+"_"+t)} AFTER INSERT OR UPDATE OR DELETE ON ${S(t)} EXECUTE FUNCTION ${St}()`)};return(N?Et:yt)(t,A,(async t=>{await A(`CREATE OR REPLACE FUNCTION ${ht}()RETURNS event_trigger AS $t2$ DECLARE row record; BEGIN FOR row IN SELECT object_identity FROM pg_event_trigger_ddl_commands()WHERE command_tag='CREATE TABLE' LOOP PERFORM pg_notify('${mt}','c:'||SPLIT_PART(row.object_identity,'.',2));END LOOP;END;$t2$ LANGUAGE plpgsql;`);try{await A(`CREATE EVENT TRIGGER ${ht} ON ddl_command_end WHEN TAG IN('CREATE TABLE')EXECUTE FUNCTION ${ht}();`)}catch{}return await A(`CREATE OR REPLACE FUNCTION ${St}()RETURNS trigger AS $t1$ BEGIN PERFORM pg_notify('${mt}','d:'||TG_TABLE_NAME);RETURN NULL;END;$t1$ LANGUAGE plpgsql;`),await w(R(P(p),(async t=>{await A(`CREATE TABLE IF NOT EXISTS ${S(t)}("_id"text PRIMARY KEY)`),await C(t)}))),await s(mt,(async a=>{return await r((e=a,n=It,e?.match(n)),(async([,a,e])=>{_(p,e)&&("c:"==a&&await C(e),t())}));var e,n}))}),i,l,y,d,g,P(p),(async(t,a)=>await t(`${f} table_name tn,column_name cn FROM information_schema.columns ${v} table_schema='public'AND table_name IN(${h(a)})`,a)),u,T,"text",void 0,(t=>z(t)),(t=>J(t)))})(t,n,(async(t,e=[])=>(await a.query(t,e)).rows),(async(t,e)=>await a.listen(t,e)),(async t=>{try{await t()}catch(t){i?.(t)}}),s,i,(()=>0),3,a,"getPglite")},"object"==typeof exports&&"undefined"!=typeof module?a(exports):"function"==typeof define&&define.amd?define(["exports"],a):a((t="undefined"!=typeof globalThis?globalThis:t||self).TinyBasePersisterPglite={});
@@ -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 t=await a();l(t)?F(t):w("Content is not an array "+t)}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 t=await a();l(t)?F(t):w("Content is not an array "+t)}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 a,t;a=this,t=function(a){"use strict";const t=a=>typeof a,e="tinybase",n="",s=",",r=t(n),o=Promise,i=clearInterval,c=a=>null==a,l=(a,t,e)=>c(a)?e?.():t(a),y=a=>t(a)==r,u=a=>Array.isArray(a),w=(a,t,e)=>a.slice(t,e),d=a=>a.length,p=async a=>o.all(a),v=a=>{throw Error(a)},f=(a,t)=>h(Array(a).fill(0),((a,e)=>t(e))),g=(a,t)=>a.forEach(t),E=(a,t="")=>a.join(t),h=(a,t)=>a.map(t),A=a=>0==d(a),m=(a,t)=>a.filter(t),T=(a,...t)=>a.push(...t),b=a=>a.shift(),N="_",C="_id",S="SELECT",$="WHERE",O="TABLE",L="ALTER "+O,I="DELETE FROM",R=S+"*FROM",D="pragma_",P="data_version",M="schema_version",_="pragma_table_",F=a=>`"${a.replace(/"/g,'""')}"`,x=a=>E(h(a,((a,t)=>"$"+(t+1))),s),j=(a,t)=>a?.has(t)??!1,B=a=>c(a)||0==(a=>a?.size??0)(a),U=a=>[...a?.values()??[]],J=(a,t)=>a?.forEach(t),Y=(a,t)=>a?.delete(t),k=Object,z=a=>k.getPrototypeOf(a),G=k.entries,H=k.keys,K=k.freeze,Q=(a=[])=>k.fromEntries(a),V=(...a)=>k.assign({},...a),W=(a,t)=>(delete a[t],a),X=(a,t)=>h(G(a),(([a,e])=>t(e,a))),q=a=>k.values(a),Z=a=>d(H(a)),aa=a=>(a=>!c(a)&&l(z(a),(a=>a==k.prototype||c(z(a))),(()=>!0)))(a)&&0==Z(a),ta=JSON.stringify,ea=JSON.parse,na=a=>new Map(a),sa=(a,t)=>a?.get(t),ra=(a,t)=>h([...a?.entries()??[]],(([a,e])=>t(e,a))),oa=(a,t,e)=>c(e)?(Y(a,t),a):a?.set(t,e),ia=(a,t,e,n)=>(j(a,t)?n?.(sa(a,t)):oa(a,t,e()),sa(a,t)),ca=(a,t,e,n,s=0)=>l((e?ia:sa)(a,t[s],s>d(t)-2?e:na),(r=>{if(s>d(t)-2)return n?.(r)&&oa(a,t[s]),r;const o=ca(r,t,e,n,s+1);return B(r)&&oa(a,t[s]),o})),la=a=>new Set(u(a)||c(a)?a:[a]),ya=(a,t)=>a?.add(t),ua=/^\d+$/,wa=na(),da=na(),pa=(a,t,e,s,r,o,i,y={},w=[])=>{let p,f,E,h=0,A=0,m=0;ia(wa,w,(()=>0)),ia(da,w,(()=>[]));const N=na(),[C,S,$,O,L]=((a=1,t)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,t.getTransactionMergeableChanges,([[a],[t]])=>!aa(a)||!aa(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!aa(a)||!aa(t),t.setContent]:v("Store type not supported by this Persister"))(i,a),[I,R,D]=(()=>{let a;const[t,e]=(()=>{const a=[];let t=0;return[e=>(e?b(a):null)??n+t++,t=>{ua.test(t)&&d(a)<1e3&&T(a,t)}]})(),s=na();return[(e,r,o,i=[],c=()=>[])=>{a??=k;const l=t(1);return oa(s,l,[e,r,o,i,c]),ya(ca(r,o??[n],la),l),l},(t,e,...r)=>g(((a,t=[n])=>{const e=[],s=(a,n)=>n==d(t)?T(e,a):null===t[n]?J(a,(a=>s(a,n+1))):g([t[n],null],(t=>s(sa(a,t),n+1)));return s(a,0),e})(t,e),(t=>J(t,(t=>sa(s,t)[0](a,...e??[],...r))))),a=>l(sa(s,a),(([,t,r])=>(ca(t,r??[n],void 0,(t=>(Y(t,a),B(t)?1:0))),oa(s,a),e(a),r))),t=>l(sa(s,t),(([t,,e=[],n,s])=>{const r=(...o)=>{const i=d(o);i==d(e)?t(a,...o,...s(o)):c(e[i])?g(n[i]?.(...o)??[],(a=>r(...o,a))):r(...o,e[i])};r()}))]})(),P=a=>{a!=h&&(h=a,R(N,void 0,h))},M=t=>{(C&&u(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},_=async a=>(2!=h&&(P(1),A++,await U((async()=>{try{const a=await t();u(a)?M(a):v("Content is not an array "+a)}catch(t){o?.(t),a&&L(a)}P(0)}))),k),F=()=>(f&&(r(f),f=void 0),k),x=async a=>(1!=h&&(P(2),m++,await U((async()=>{try{await e(S,a)}catch(a){o?.(a)}P(0)}))),k),j=()=>(l(E,a.delListener),E=void 0,k),U=async(...a)=>(T(sa(da,w),...a),await(async()=>{if(!sa(wa,w)){for(oa(wa,w,1);!c(p=b(sa(da,w)));)try{await p()}catch(a){o?.(a)}oa(wa,w,0)}})(),k),k={load:_,startAutoLoad:async a=>{await F().load(a);try{f=await s((async(a,t)=>{t||a?2!=h&&(P(1),A++,M(t??a),P(0)):await _()}))}catch(a){o?.(a)}return k},stopAutoLoad:F,isAutoLoading:()=>!c(f),save:x,startAutoSave:async()=>(await j().save(),E=a.addDidFinishTransactionListener((()=>{const a=$();O(a)&&x(a)})),k),stopAutoSave:j,isAutoSaving:()=>!c(E),getStatus:()=>h,addStatusListener:a=>I(a,N),delListener:t=>(D(t),a),schedule:U,getStore:()=>a,destroy:()=>(sa(da,w).splice(0,void 0),F().stopAutoSave()),getStats:()=>({loads:A,saves:m}),...y};return K(k)},va=(a,t,e,n,r,o,i,l)=>{const y=na();return[async()=>{y.clear(),h(await e(a,t),(({tn:a,cn:t})=>ya(ia(y,a,la),t)))},async(t,e)=>((a,t)=>j(sa(y,a),t))(t,e)?Q(m(h(await a(R+F(t)),(a=>{return[a[e],l?(t=W(a,e),n=l,Q(X(t,((a,t)=>[t,n(a,t)])))):W(a,e)];var t,n})),(([a,t])=>!c(a)&&!aa(t)))):{},async(t,e,n,l,u,w=!1)=>{const d=la();X(n??{},(a=>h(H(a??{}),(a=>ya(d,a)))));const v=U(d);if(!w&&u&&A(v)&&j(y,t))return await a("DROP "+O+F(t)),void oa(y,t);const f=sa(y,t),g=la(U(f));if(A(v)||(j(y,t)?await p(h([e,...v],(async(n,s)=>{Y(g,n)||(await a(L+F(t)+"ADD"+F(n)+r),0==s&&await a("CREATE UNIQUE INDEX pk ON "+F(t)+`(${F(e)})`),ya(f,n))}))):(await a("CREATE "+O+F(t)+`(${F(e)}${r} PRIMARY KEY${E(h(v,(a=>s+F(a)+r)))});`),oa(y,t,la([e,...v])))),await p([...!w&&l?h(U(g),(async n=>{n!=e&&(await a(L+F(t)+"DROP"+F(n)),Y(f,n))})):[]]),w)c(n)?await a(I+F(t)+$+" true"):await p(X(n,(async(n,s)=>{c(n)?await a(I+F(t)+$+F(e)+"=$1",[s]):A(v)||await fa(a,t,e,H(n),[s,...i?h(q(n),i):q(n)],o)})));else if(A(v))j(y,t)&&await a(I+F(t)+$+" true");else{const s=m(U(sa(y,t)),(a=>a!=e)),r=[],c=[];X(n??{},((a,t)=>{T(r,t,...h(s,(t=>i?i(a?.[t]):a?.[t]))),T(c,t)})),await fa(a,t,e,s,r,o),await a(I+F(t)+$+F(e)+`NOT IN(${x(c)})`,c)}},async t=>{let e;await a("BEGIN");try{e=await t()}catch(a){n?.(a)}return await a("END"),e}]},fa=async(a,t,e,r,o,i=0)=>await a("INSERT "+(i?"OR REPLACE ":n)+"INTO"+F(t)+"("+F(e)+E(h(r,(a=>s+F(a))))+")VALUES"+ga(o,d(r)+1)+(i?n:"ON CONFLICT("+F(e)+")DO UPDATE SET"+E(h(r,(a=>F(a)+"=excluded."+F(a))),s)),h(o,(a=>a??null))),ga=(a,t)=>E(f(d(a)/t,(a=>"("+E(f(t,(e=>"$"+(a*t+e+1))),s)+")")),s),Ea=(a,t,e,n,s,r,o,[i,c,l],y,u,w,d,p,v)=>{const[f,g,E,h]=va(t,y,u,s,p,v),A=pa(a,(async()=>await h((async()=>{return await f(),a=(await g(i,c))[N]?.[l]??"null",ea(a,((a,t)=>""===t?void 0:t));var a}))),(async a=>await h((async()=>{var t;await f(),await E(i,c,{[N]:{[l]:(t=a()??null,ta(t,((a,t)=>void 0===t?"":t)))}},!0,!0)}))),e,n,s,o,{[d]:()=>w,destroy:()=>(A.stopAutoLoad().stopAutoSave(),r(),A)},w);return A},ha=(a,t,e,n,s,r,o,[i,l,[y,u,w]],d,v,f,g,E,h,A,T)=>{const[b,S,$,O]=va(t,d,v,s,E,h,A,T),L=async(a,t)=>await p(ra(l,(async([e,n,s,r],o)=>{t&&!(o in a)||await $(e,n,a[o],s,r,t)}))),I=async(a,t)=>u?await $(w,C,{[N]:a},!0,!0,t):null,R=pa(a,(async()=>await O((async()=>{await b();const a=await(async()=>Q(m(await p(ra(i,(async([a,t],e)=>[a,await S(e,t)]))),(a=>!aa(a[1])))))(),t=await(async()=>y?(await S(w,C))[N]:{})();return aa(a)&&c(t)?void 0:[a,t]}))),(async(a,t)=>await O((async()=>{if(await b(),c(t)){const[t,e]=a();await L(t),await I(e)}else await L(t[0],!0),await I(t[1],!0)}))),e,n,s,o,{[g]:()=>f,destroy:()=>(R.stopAutoLoad().stopAutoSave(),r(),R)},f);return R},Aa="ColumnName",ma="store",Ta="json",ba=ma+"TableName",Na=ma+"Id"+Aa,Ca=ma+Aa,Sa="autoLoadIntervalSeconds",$a="rowId"+Aa,Oa="tableId",La="tableName",Ia="deleteEmptyColumns",Ra="deleteEmptyTable",Da={mode:Ta,[Sa]:1},Pa={load:0,save:0,[La]:e+"_values"},Ma=(a,t,e,n,s)=>{const r=na();return X(a,((a,o)=>{const i=w(q(V(t,y(a)?{[e]:a}:a)),0,Z(t));c(i[0])||n(o,i[0])||(s(o,i[0]),oa(r,o,i))})),r},_a=(a,t,s,r,o,c,l,u,d,p,v="getDb",f)=>{let g,E,h;const A=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,c),[m,T,b,N]=(a=>{const t=(a=>V(Da,y(a)?{[ba]:a}:a??{}))(a),n=t[Sa];if(t.mode==Ta){const a=t[ba]??e;return[1,n,[a,t[Na]??C,t[Ca]??ma],la(a)]}const{tables:{load:s={},save:r={}}={},values:o={}}=t,i=w(q(V(Pa,o)),0,Z(Pa)),c=i[2],l=la(c),u=la(c);return[0,n,[Ma(s,{[Oa]:null,[$a]:C},Oa,(a=>j(u,a)),(a=>ya(l,a))),Ma(r,{[La]:null,[$a]:C,[Ia]:0,[Ra]:0},La,((a,t)=>j(u,t)),((a,t)=>ya(l,t))),i],l]})(t);return(m?Ea:ha)(a,A,(a=>{let t;const e=()=>t=setInterval((async()=>{try{const[{d:t,s:e,c:n}]=await A(`${S} ${P} d,${M} s,TOTAL_CHANGES() c FROM ${D}${P} JOIN ${D}${M}`);t==g&&e==E&&n==h||(null!=g&&a(),g=t,E=e,h=n)}catch{}}),1e3*T),n=()=>{g=E=h=null,i(t)},s=r((t=>{N.has(t)&&(n(),a(),e())}));return e(),()=>{n(),o(s)}}),(a=>a()),l,u,d,b,U(N),(async(a,t)=>await a(`${S} t.name tn,c.name cn FROM ${_}list()t,${_}info(t.name)c ${$} t.schema='main'AND t.type IN('table','view')AND t.name IN(${x(t)})ORDER BY t.name,c.name`,t)),p,v,n,f,(a=>!0===a?1:!1===a?0:a),void 0)};a.createPowerSyncPersister=(a,t,e,n,s,r=1)=>_a(a,e,(async(a,e=[])=>t.execute(a,e).then((a=>a.rows?._array??[]))),(a=>{const e=new AbortController,n=t.onChange({rawTableNames:!0,signal:e.signal});return(async()=>{for await(const t of n)h(t.changedTables,a)})(),e}),(a=>a.abort()),n,s,(()=>0),1,t,"getPowerSync",r)},"object"==typeof exports&&"undefined"!=typeof module?t(exports):"function"==typeof define&&define.amd?define(["exports"],t):t((a="undefined"!=typeof globalThis?globalThis:a||self).TinyBasePersisterPowersync={});
1
+ var t,a;t=this,a=function(t){"use strict";const a=t=>typeof t,e="tinybase",n="",s=",",o=a(n),r=Promise,i=clearInterval,c=t=>null==t,l=(t,a,e)=>c(t)?e?.():a(t),y=t=>a(t)==o,u=t=>Array.isArray(t),w=(t,a,e)=>t.slice(a,e),d=t=>t.length,E=async t=>r.all(t),p=t=>{throw Error(t)},f=(t,a)=>t.forEach(a),v=(t,a="")=>t.join(a),g=(t,a)=>t.map(a),h=t=>0==d(t),A=(t,a)=>t.filter(a),T=(t,...a)=>t.push(...a),m=t=>t.shift(),N=Object,S=t=>N.getPrototypeOf(t),b=N.entries,C=N.keys,$=N.freeze,O=(t=[])=>N.fromEntries(t),I=(...t)=>N.assign({},...t),L=(t,a)=>(delete t[a],t),R=(t,a)=>g(b(t),(([t,e])=>a(e,t))),D=t=>N.values(t),P=t=>d(C(t)),M=t=>(t=>!c(t)&&l(S(t),(t=>t==N.prototype||c(S(t))),(()=>!0)))(t)&&0==P(t),_=t=>new Set(u(t)||c(t)?t:[t]),F=(t,a)=>t?.add(a),x="_",U="_id",j="SELECT",B="WHERE",H="TABLE",J="ALTER "+H,Y="DELETE FROM",k=j+"*FROM",z="pragma_",G="data_version",V="schema_version",W="pragma_table_",K=t=>`"${t.replace(/"/g,'""')}"`,Q=(...t)=>v(g(t,K),s),X=(t,a=[1])=>v(g(t,(()=>"$"+a[0]++)),s),q=(t,a)=>t?.has(a)??!1,Z=t=>c(t)||0==(t=>t?.size??0)(t),tt=t=>[...t?.values()??[]],at=(t,a)=>t?.forEach(a),et=(t,a)=>t?.delete(a),nt=JSON.stringify,st=JSON.parse,ot=t=>new Map(t),rt=(t,a)=>t?.get(a),it=(t,a)=>g([...t?.entries()??[]],(([t,e])=>a(e,t))),ct=(t,a,e)=>c(e)?(et(t,a),t):t?.set(a,e),lt=(t,a,e,n)=>(q(t,a)?n?.(rt(t,a)):ct(t,a,e()),rt(t,a)),yt=(t,a,e,n,s=0)=>l((e?lt:rt)(t,a[s],s>d(a)-2?e:ot),(o=>{if(s>d(a)-2)return n?.(o)&&ct(t,a[s]),o;const r=yt(o,a,e,n,s+1);return Z(o)&&ct(t,a[s]),r})),ut=/^\d+$/,wt=ot(),dt=ot(),Et=(t,a,e,s,o,r,i,y={},w=[])=>{let E,v,g,h=0,A=0,N=0;lt(wt,w,(()=>0)),lt(dt,w,(()=>[]));const S=ot(),[b,C,O,I,L]=((t=1,a)=>1!=t&&a.isMergeable()?[1,a.getMergeableContent,a.getTransactionMergeableChanges,([[t],[a]])=>!M(t)||!M(a),a.setDefaultContent]:2!=t?[0,a.getContent,a.getTransactionChanges,([t,a])=>!M(t)||!M(a),a.setContent]:p("Store type not supported by this Persister"))(i,t),[R,D,P]=(()=>{let t;const[a,e]=(()=>{const t=[];let a=0;return[e=>(e?m(t):null)??n+a++,a=>{ut.test(a)&&d(t)<1e3&&T(t,a)}]})(),s=ot();return[(e,o,r,i=[],c=()=>[])=>{t??=k;const l=a(1);return ct(s,l,[e,o,r,i,c]),F(yt(o,r??[n],_),l),l},(a,e,...o)=>f(((t,a=[n])=>{const e=[],s=(t,n)=>n==d(a)?T(e,t):null===a[n]?at(t,(t=>s(t,n+1))):f([a[n],null],(a=>s(rt(t,a),n+1)));return s(t,0),e})(a,e),(a=>at(a,(a=>rt(s,a)[0](t,...e??[],...o))))),t=>l(rt(s,t),(([,a,o])=>(yt(a,o??[n],void 0,(a=>(et(a,t),Z(a)?1:0))),ct(s,t),e(t),o))),a=>l(rt(s,a),(([a,,e=[],n,s])=>{const o=(...r)=>{const i=d(r);i==d(e)?a(t,...r,...s(r)):c(e[i])?f(n[i]?.(...r)??[],(t=>o(...r,t))):o(...r,e[i])};o()}))]})(),x=t=>{t!=h&&(h=t,D(S,void 0,h))},U=a=>{(b&&u(a?.[0])?1===a?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===a?.[2]?t.applyChanges:t.setContent)(a)},j=async t=>(2!=h&&(x(1),A++,await Y((async()=>{try{const t=await a();u(t)?U(t):p("Content is not an array "+t)}catch(a){r?.(a),t&&L(t)}x(0)}))),k),B=()=>(v&&(o(v),v=void 0),k),H=async t=>(1!=h&&(x(2),N++,await Y((async()=>{try{await e(C,t)}catch(t){r?.(t)}x(0)}))),k),J=()=>(l(g,t.delListener),g=void 0,k),Y=async(...t)=>(T(rt(dt,w),...t),await(async()=>{if(!rt(wt,w)){for(ct(wt,w,1);!c(E=m(rt(dt,w)));)try{await E()}catch(t){r?.(t)}ct(wt,w,0)}})(),k),k={load:j,startAutoLoad:async t=>{await B().load(t);try{v=await s((async(t,a)=>{a||t?2!=h&&(x(1),A++,U(a??t),x(0)):await j()}))}catch(t){r?.(t)}return k},stopAutoLoad:B,isAutoLoading:()=>!c(v),save:H,startAutoSave:async()=>(await J().save(),g=t.addDidFinishTransactionListener((()=>{const t=O();I(t)&&H(t)})),k),stopAutoSave:J,isAutoSaving:()=>!c(g),getStatus:()=>h,addStatusListener:t=>R(t,S),delListener:a=>(P(a),t),schedule:Y,getStore:()=>t,destroy:()=>(rt(dt,w).splice(0,void 0),B().stopAutoSave()),getStats:()=>({loads:A,saves:N}),...y};return $(k)},pt=(t,a,e,n,o,r=ft,i,l)=>{const y=ot();return[async()=>{y.clear(),g(await e(t,a),(({tn:t,cn:a})=>F(lt(y,t,_),a)))},async(a,e)=>((t,a)=>q(rt(y,t),a))(a,e)?O(A(g(await t(k+K(a)),(t=>{return[t[e],l?(a=L(t,e),n=l,O(R(a,((t,a)=>[a,n(t,a)])))):L(t,e)];var a,n})),(([t,a])=>!c(t)&&!M(a)))):{},async(a,e,n,l,u,w=!1)=>{const d=_();R(n??{},(t=>g(C(t??{}),(t=>F(d,t)))));const p=tt(d);if(!w&&u&&h(p)&&q(y,a))return await t("DROP "+H+K(a)),void ct(y,a);const f=rt(y,a),m=_(tt(f));if(h(p)||(q(y,a)?await E(g([e,...p],(async(n,s)=>{et(m,n)||(await t(J+K(a)+"ADD"+K(n)+o),0==s&&await t("CREATE UNIQUE INDEX pk ON "+K(a)+`(${K(e)})`),F(f,n))}))):(await t("CREATE "+H+K(a)+`(${K(e)}${o} PRIMARY KEY${v(g(p,(t=>s+K(t)+o)))});`),ct(y,a,_([e,...p])))),await E([...!w&&l?g(tt(m),(async n=>{n!=e&&(await t(J+K(a)+"DROP"+K(n)),et(f,n))})):[]]),w)c(n)?await t(Y+K(a)+B+" true"):await E(R(n,(async(n,s)=>{c(n)?await t(Y+K(a)+B+K(e)+"=$1",[s]):h(p)||await r(t,a,e,C(n),{[s]:i?g(D(n),i):D(n)},f)})));else if(h(p))q(y,a)&&await t(Y+K(a)+B+" true");else{const s=A(tt(rt(y,a)),(t=>t!=e)),o={},c=[];R(n??{},((t,a)=>{o[a]=g(s,(a=>i?i(t?.[a]):t?.[a])),T(c,a)})),await r(t,a,e,s,o),await t(Y+K(a)+B+K(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,n,o)=>{const r=[1];await t("INSERT INTO"+K(a)+"("+Q(e,...n)+")VALUES"+v(R(o,(t=>"($"+r[0]+++","+X(t,r)+")")),s)+"ON CONFLICT("+K(e)+")DO UPDATE SET"+v(g(n,(t=>K(t)+"=excluded."+K(t))),s),R(o,((t,a)=>[a,...g(t,(t=>t??null))])).flat())},vt=(t,a,e,n,s,o,r,[i,c,l],y,u,w,d,E,p)=>{const[f,v,g,h]=pt(a,y,u,s,E,p),A=Et(t,(async()=>await h((async()=>{return await f(),t=(await v(i,c))[x]?.[l]??"null",st(t,((t,a)=>""===a?void 0:a));var t}))),(async t=>await h((async()=>{var a;await f(),await g(i,c,{[x]:{[l]:(a=t()??null,nt(a,((t,a)=>void 0===a?"":a)))}},!0,!0)}))),e,n,s,r,{[d]:()=>w,destroy:()=>(A.stopAutoLoad().stopAutoSave(),o(),A)},w);return A},gt=(t,a,e,n,s,o,r,[i,l,[y,u,w]],d,p,f,v,g,h,T,m)=>{const[N,S,b,C]=pt(a,d,p,s,g,h,T,m),$=async(t,a)=>await E(it(l,(async([e,n,s,o],r)=>{a&&!(r in t)||await b(e,n,t[r],s,o,a)}))),I=async(t,a)=>u?await b(w,U,{[x]:t},!0,!0,a):null,L=Et(t,(async()=>await C((async()=>{await N();const t=await(async()=>O(A(await E(it(i,(async([t,a],e)=>[t,await S(e,a)]))),(t=>!M(t[1])))))(),a=await(async()=>y?(await S(w,U))[x]:{})();return M(t)&&c(a)?void 0:[t,a]}))),(async(t,a)=>await C((async()=>{if(await N(),c(a)){const[a,e]=t();await $(a),await I(e)}else await $(a[0],!0),await I(a[1],!0)}))),e,n,s,r,{[v]:()=>f,destroy:()=>(L.stopAutoLoad().stopAutoSave(),o(),L)},f);return L},ht="ColumnName",At="store",Tt="json",mt=At+"TableName",Nt=At+"Id"+ht,St=At+ht,bt="autoLoadIntervalSeconds",Ct="rowId"+ht,$t="tableId",Ot="tableName",It="deleteEmptyColumns",Lt="deleteEmptyTable",Rt={mode:Tt,[bt]:1},Dt={load:0,save:0,[Ot]:e+"_values"},Pt=(t,a,e,n,s)=>{const o=ot();return R(t,((t,r)=>{const i=w(D(I(a,y(t)?{[e]:t}:t)),0,P(a));c(i[0])||n(r,i[0])||(s(r,i[0]),ct(o,r,i))})),o},Mt=(t,a,s,o,r,c,l,u,d,E,p="getDb",f)=>{let v,g,h;const A=((t,a)=>a?async(e,n)=>(a(e,n),await t(e,n)):t)(s,c),[T,m,N,S]=(t=>{const a=(t=>I(Rt,y(t)?{[mt]:t}:t??{}))(t),n=a[bt];if(a.mode==Tt){const t=a[mt]??e;return[1,n,[t,a[Nt]??U,a[St]??At],_(t)]}const{tables:{load:s={},save:o={}}={},values:r={}}=a,i=w(D(I(Dt,r)),0,P(Dt)),c=i[2],l=_(c),u=_(c);return[0,n,[Pt(s,{[$t]:null,[Ct]:U},$t,(t=>q(u,t)),(t=>F(l,t))),Pt(o,{[Ot]:null,[Ct]:U,[It]:0,[Lt]:0},Ot,((t,a)=>q(u,a)),((t,a)=>F(l,a))),i],l]})(a);return(T?vt:gt)(t,A,(t=>{let a;const e=()=>a=setInterval((async()=>{try{const[{d:a,s:e,c:n}]=await A(`${j} ${G} d,${V} s,TOTAL_CHANGES() c FROM ${z}${G} JOIN ${z}${V}`);a==v&&e==g&&n==h||(null!=v&&t(),v=a,g=e,h=n)}catch{}}),1e3*m),n=()=>{v=g=h=null,i(a)},s=o((a=>{S.has(a)&&(n(),t(),e())}));return e(),()=>{n(),r(s)}}),(t=>t()),l,u,d,N,tt(S),(async(t,a)=>await t(`${j} t.name tn,c.name cn FROM ${W}list()t,${W}info(t.name)c ${B} t.schema='main'AND t.type IN('table','view')AND t.name IN(${X(a)})ORDER BY t.name,c.name`,a)),E,p,n,f,(t=>!0===t?1:!1===t?0:t),void 0)},_t=async(t,a,e,n,o,r)=>{const i=[1],c=_(n),l=r?A([...r],(t=>t!=e&&!q(c,t))):[];if(!h(l)){const n=C(o),s=O(g(await t("SELECT"+Q(e,...l)+"FROM"+K(a)+"WHERE"+K(e)+"IN("+X(n)+")",n),(t=>[t[e],t])));f(n,(t=>T(o[t],...g(l,(a=>s?.[t]?.[a]??null)))))}await t("INSERT OR REPLACE INTO"+K(a)+"("+Q(e,...n,...l)+")VALUES"+v(R(o,(t=>"($"+i[0]+++","+X(t,i)+")")),s),R(o,((t,a)=>[a,...g(t,(t=>t??null))])).flat())};t.createPowerSyncPersister=(t,a,e,n,s)=>{let o;return Mt(t,e,(async(t,e=[])=>a.execute(t,e).then((t=>t.rows?._array??[]))),(t=>{const e=new AbortController,n=a.onChange({rawTableNames:!0,signal:e.signal});return(async()=>{for await(const t of n)o&&g(t.changedTables,o)})(),o=t,e}),(t=>{o=void 0,t.abort()}),n,s,(()=>0),1,a,"getPowerSync",_t)}},"object"==typeof exports&&"undefined"!=typeof module?a(exports):"function"==typeof define&&define.amd?define(["exports"],a):a((t="undefined"!=typeof globalThis?globalThis:t||self).TinyBasePersisterPowersync={});
@@ -1 +1 @@
1
- var a,t;a=this,t=function(a){"use strict";const t=a=>typeof a,e="tinybase",n="",s=",",r=t(n),o=Promise,i=clearInterval,c=a=>null==a,l=(a,t,e)=>c(a)?e?.():t(a),y=a=>t(a)==r,u=a=>Array.isArray(a),w=(a,t,e)=>a.slice(t,e),d=a=>a.length,p=async a=>o.all(a),v=a=>{throw Error(a)},f=(a,t)=>h(Array(a).fill(0),((a,e)=>t(e))),g=(a,t)=>a.forEach(t),E=(a,t="")=>a.join(t),h=(a,t)=>a.map(t),A=a=>0==d(a),m=(a,t)=>a.filter(t),T=(a,...t)=>a.push(...t),b=a=>a.shift(),N="_",C="_id",S="SELECT",$="WHERE",O="TABLE",L="ALTER "+O,I="DELETE FROM",R=S+"*FROM",D="pragma_",P="data_version",M="schema_version",_="pragma_table_",F=a=>`"${a.replace(/"/g,'""')}"`,x=a=>E(h(a,((a,t)=>"$"+(t+1))),s),j=(a,t)=>a?.has(t)??!1,B=a=>c(a)||0==(a=>a?.size??0)(a),U=a=>[...a?.values()??[]],J=(a,t)=>a?.forEach(t),Y=(a,t)=>a?.delete(t),k=Object,z=a=>k.getPrototypeOf(a),G=k.entries,H=k.keys,K=k.freeze,Q=(a=[])=>k.fromEntries(a),V=(...a)=>k.assign({},...a),W=(a,t)=>(delete a[t],a),X=(a,t)=>h(G(a),(([a,e])=>t(e,a))),q=a=>k.values(a),Z=a=>d(H(a)),aa=a=>(a=>!c(a)&&l(z(a),(a=>a==k.prototype||c(z(a))),(()=>!0)))(a)&&0==Z(a),ta=JSON.stringify,ea=JSON.parse,na=a=>new Map(a),sa=(a,t)=>a?.get(t),ra=(a,t)=>h([...a?.entries()??[]],(([a,e])=>t(e,a))),oa=(a,t,e)=>c(e)?(Y(a,t),a):a?.set(t,e),ia=(a,t,e,n)=>(j(a,t)?n?.(sa(a,t)):oa(a,t,e()),sa(a,t)),ca=(a,t,e,n,s=0)=>l((e?ia:sa)(a,t[s],s>d(t)-2?e:na),(r=>{if(s>d(t)-2)return n?.(r)&&oa(a,t[s]),r;const o=ca(r,t,e,n,s+1);return B(r)&&oa(a,t[s]),o})),la=a=>new Set(u(a)||c(a)?a:[a]),ya=(a,t)=>a?.add(t),ua=/^\d+$/,wa=na(),da=na(),pa=(a,t,e,s,r,o,i,y={},w=[])=>{let p,f,E,h=0,A=0,m=0;ia(wa,w,(()=>0)),ia(da,w,(()=>[]));const N=na(),[C,S,$,O,L]=((a=1,t)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,t.getTransactionMergeableChanges,([[a],[t]])=>!aa(a)||!aa(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!aa(a)||!aa(t),t.setContent]:v("Store type not supported by this Persister"))(i,a),[I,R,D]=(()=>{let a;const[t,e]=(()=>{const a=[];let t=0;return[e=>(e?b(a):null)??n+t++,t=>{ua.test(t)&&d(a)<1e3&&T(a,t)}]})(),s=na();return[(e,r,o,i=[],c=()=>[])=>{a??=k;const l=t(1);return oa(s,l,[e,r,o,i,c]),ya(ca(r,o??[n],la),l),l},(t,e,...r)=>g(((a,t=[n])=>{const e=[],s=(a,n)=>n==d(t)?T(e,a):null===t[n]?J(a,(a=>s(a,n+1))):g([t[n],null],(t=>s(sa(a,t),n+1)));return s(a,0),e})(t,e),(t=>J(t,(t=>sa(s,t)[0](a,...e??[],...r))))),a=>l(sa(s,a),(([,t,r])=>(ca(t,r??[n],void 0,(t=>(Y(t,a),B(t)?1:0))),oa(s,a),e(a),r))),t=>l(sa(s,t),(([t,,e=[],n,s])=>{const r=(...o)=>{const i=d(o);i==d(e)?t(a,...o,...s(o)):c(e[i])?g(n[i]?.(...o)??[],(a=>r(...o,a))):r(...o,e[i])};r()}))]})(),P=a=>{a!=h&&(h=a,R(N,void 0,h))},M=t=>{(C&&u(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},_=async a=>(2!=h&&(P(1),A++,await U((async()=>{try{const a=await t();u(a)?M(a):v("Content is not an array "+a)}catch(t){o?.(t),a&&L(a)}P(0)}))),k),F=()=>(f&&(r(f),f=void 0),k),x=async a=>(1!=h&&(P(2),m++,await U((async()=>{try{await e(S,a)}catch(a){o?.(a)}P(0)}))),k),j=()=>(l(E,a.delListener),E=void 0,k),U=async(...a)=>(T(sa(da,w),...a),await(async()=>{if(!sa(wa,w)){for(oa(wa,w,1);!c(p=b(sa(da,w)));)try{await p()}catch(a){o?.(a)}oa(wa,w,0)}})(),k),k={load:_,startAutoLoad:async a=>{await F().load(a);try{f=await s((async(a,t)=>{t||a?2!=h&&(P(1),A++,M(t??a),P(0)):await _()}))}catch(a){o?.(a)}return k},stopAutoLoad:F,isAutoLoading:()=>!c(f),save:x,startAutoSave:async()=>(await j().save(),E=a.addDidFinishTransactionListener((()=>{const a=$();O(a)&&x(a)})),k),stopAutoSave:j,isAutoSaving:()=>!c(E),getStatus:()=>h,addStatusListener:a=>I(a,N),delListener:t=>(D(t),a),schedule:U,getStore:()=>a,destroy:()=>(sa(da,w).splice(0,void 0),F().stopAutoSave()),getStats:()=>({loads:A,saves:m}),...y};return K(k)},va=(a,t,e,n,r,o,i,l)=>{const y=na();return[async()=>{y.clear(),h(await e(a,t),(({tn:a,cn:t})=>ya(ia(y,a,la),t)))},async(t,e)=>((a,t)=>j(sa(y,a),t))(t,e)?Q(m(h(await a(R+F(t)),(a=>{return[a[e],l?(t=W(a,e),n=l,Q(X(t,((a,t)=>[t,n(a,t)])))):W(a,e)];var t,n})),(([a,t])=>!c(a)&&!aa(t)))):{},async(t,e,n,l,u,w=!1)=>{const d=la();X(n??{},(a=>h(H(a??{}),(a=>ya(d,a)))));const v=U(d);if(!w&&u&&A(v)&&j(y,t))return await a("DROP "+O+F(t)),void oa(y,t);const f=sa(y,t),g=la(U(f));if(A(v)||(j(y,t)?await p(h([e,...v],(async(n,s)=>{Y(g,n)||(await a(L+F(t)+"ADD"+F(n)+r),0==s&&await a("CREATE UNIQUE INDEX pk ON "+F(t)+`(${F(e)})`),ya(f,n))}))):(await a("CREATE "+O+F(t)+`(${F(e)}${r} PRIMARY KEY${E(h(v,(a=>s+F(a)+r)))});`),oa(y,t,la([e,...v])))),await p([...!w&&l?h(U(g),(async n=>{n!=e&&(await a(L+F(t)+"DROP"+F(n)),Y(f,n))})):[]]),w)c(n)?await a(I+F(t)+$+" true"):await p(X(n,(async(n,s)=>{c(n)?await a(I+F(t)+$+F(e)+"=$1",[s]):A(v)||await fa(a,t,e,H(n),[s,...i?h(q(n),i):q(n)],o)})));else if(A(v))j(y,t)&&await a(I+F(t)+$+" true");else{const s=m(U(sa(y,t)),(a=>a!=e)),r=[],c=[];X(n??{},((a,t)=>{T(r,t,...h(s,(t=>i?i(a?.[t]):a?.[t]))),T(c,t)})),await fa(a,t,e,s,r,o),await a(I+F(t)+$+F(e)+`NOT IN(${x(c)})`,c)}},async t=>{let e;await a("BEGIN");try{e=await t()}catch(a){n?.(a)}return await a("END"),e}]},fa=async(a,t,e,r,o,i=0)=>await a("INSERT "+(i?"OR REPLACE ":n)+"INTO"+F(t)+"("+F(e)+E(h(r,(a=>s+F(a))))+")VALUES"+ga(o,d(r)+1)+(i?n:"ON CONFLICT("+F(e)+")DO UPDATE SET"+E(h(r,(a=>F(a)+"=excluded."+F(a))),s)),h(o,(a=>a??null))),ga=(a,t)=>E(f(d(a)/t,(a=>"("+E(f(t,(e=>"$"+(a*t+e+1))),s)+")")),s),Ea=(a,t,e,n,s,r,o,[i,c,l],y,u,w,d,p,v)=>{const[f,g,E,h]=va(t,y,u,s,p,v),A=pa(a,(async()=>await h((async()=>{return await f(),a=(await g(i,c))[N]?.[l]??"null",ea(a,((a,t)=>""===t?void 0:t));var a}))),(async a=>await h((async()=>{var t;await f(),await E(i,c,{[N]:{[l]:(t=a()??null,ta(t,((a,t)=>void 0===t?"":t)))}},!0,!0)}))),e,n,s,o,{[d]:()=>w,destroy:()=>(A.stopAutoLoad().stopAutoSave(),r(),A)},w);return A},ha=(a,t,e,n,s,r,o,[i,l,[y,u,w]],d,v,f,g,E,h,A,T)=>{const[b,S,$,O]=va(t,d,v,s,E,h,A,T),L=async(a,t)=>await p(ra(l,(async([e,n,s,r],o)=>{t&&!(o in a)||await $(e,n,a[o],s,r,t)}))),I=async(a,t)=>u?await $(w,C,{[N]:a},!0,!0,t):null,R=pa(a,(async()=>await O((async()=>{await b();const a=await(async()=>Q(m(await p(ra(i,(async([a,t],e)=>[a,await S(e,t)]))),(a=>!aa(a[1])))))(),t=await(async()=>y?(await S(w,C))[N]:{})();return aa(a)&&c(t)?void 0:[a,t]}))),(async(a,t)=>await O((async()=>{if(await b(),c(t)){const[t,e]=a();await L(t),await I(e)}else await L(t[0],!0),await I(t[1],!0)}))),e,n,s,o,{[g]:()=>f,destroy:()=>(R.stopAutoLoad().stopAutoSave(),r(),R)},f);return R},Aa="ColumnName",ma="store",Ta="json",ba=ma+"TableName",Na=ma+"Id"+Aa,Ca=ma+Aa,Sa="autoLoadIntervalSeconds",$a="rowId"+Aa,Oa="tableId",La="tableName",Ia="deleteEmptyColumns",Ra="deleteEmptyTable",Da={mode:Ta,[Sa]:1},Pa={load:0,save:0,[La]:e+"_values"},Ma=(a,t,e,n,s)=>{const r=na();return X(a,((a,o)=>{const i=w(q(V(t,y(a)?{[e]:a}:a)),0,Z(t));c(i[0])||n(o,i[0])||(s(o,i[0]),oa(r,o,i))})),r},_a=(a,t,s,r,o,c,l,u,d,p,v="getDb",f)=>{let g,E,h;const A=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,c),[m,T,b,N]=(a=>{const t=(a=>V(Da,y(a)?{[ba]:a}:a??{}))(a),n=t[Sa];if(t.mode==Ta){const a=t[ba]??e;return[1,n,[a,t[Na]??C,t[Ca]??ma],la(a)]}const{tables:{load:s={},save:r={}}={},values:o={}}=t,i=w(q(V(Pa,o)),0,Z(Pa)),c=i[2],l=la(c),u=la(c);return[0,n,[Ma(s,{[Oa]:null,[$a]:C},Oa,(a=>j(u,a)),(a=>ya(l,a))),Ma(r,{[La]:null,[$a]:C,[Ia]:0,[Ra]:0},La,((a,t)=>j(u,t)),((a,t)=>ya(l,t))),i],l]})(t);return(m?Ea:ha)(a,A,(a=>{let t;const e=()=>t=setInterval((async()=>{try{const[{d:t,s:e,c:n}]=await A(`${S} ${P} d,${M} s,TOTAL_CHANGES() c FROM ${D}${P} JOIN ${D}${M}`);t==g&&e==E&&n==h||(null!=g&&a(),g=t,E=e,h=n)}catch{}}),1e3*T),n=()=>{g=E=h=null,i(t)},s=r((t=>{N.has(t)&&(n(),a(),e())}));return e(),()=>{n(),o(s)}}),(a=>a()),l,u,d,b,U(N),(async(a,t)=>await a(`${S} t.name tn,c.name cn FROM ${_}list()t,${_}info(t.name)c ${$} t.schema='main'AND t.type IN('table','view')AND t.name IN(${x(t)})ORDER BY t.name,c.name`,t)),p,v,n,f,(a=>!0===a?1:!1===a?0:a),void 0)};a.createPowerSyncPersister=(a,t,e,n,s,r=1)=>_a(a,e,(async(a,e=[])=>t.execute(a,e).then((a=>a.rows?._array??[]))),(a=>{const e=new AbortController,n=t.onChange({rawTableNames:!0,signal:e.signal});return(async()=>{for await(const t of n)h(t.changedTables,a)})(),e}),(a=>a.abort()),n,s,(()=>0),1,t,"getPowerSync",r)},"object"==typeof exports&&"undefined"!=typeof module?t(exports):"function"==typeof define&&define.amd?define(["exports"],t):t((a="undefined"!=typeof globalThis?globalThis:a||self).TinyBasePersisterPowersync={});
1
+ var t,a;t=this,a=function(t){"use strict";const a=t=>typeof t,e="tinybase",n="",s=",",o=a(n),r=Promise,i=clearInterval,c=t=>null==t,l=(t,a,e)=>c(t)?e?.():a(t),y=t=>a(t)==o,u=t=>Array.isArray(t),w=(t,a,e)=>t.slice(a,e),d=t=>t.length,E=async t=>r.all(t),p=t=>{throw Error(t)},f=(t,a)=>t.forEach(a),v=(t,a="")=>t.join(a),g=(t,a)=>t.map(a),h=t=>0==d(t),A=(t,a)=>t.filter(a),T=(t,...a)=>t.push(...a),m=t=>t.shift(),N=Object,S=t=>N.getPrototypeOf(t),b=N.entries,C=N.keys,$=N.freeze,O=(t=[])=>N.fromEntries(t),I=(...t)=>N.assign({},...t),L=(t,a)=>(delete t[a],t),R=(t,a)=>g(b(t),(([t,e])=>a(e,t))),D=t=>N.values(t),P=t=>d(C(t)),M=t=>(t=>!c(t)&&l(S(t),(t=>t==N.prototype||c(S(t))),(()=>!0)))(t)&&0==P(t),_=t=>new Set(u(t)||c(t)?t:[t]),F=(t,a)=>t?.add(a),x="_",U="_id",j="SELECT",B="WHERE",H="TABLE",J="ALTER "+H,Y="DELETE FROM",k=j+"*FROM",z="pragma_",G="data_version",V="schema_version",W="pragma_table_",K=t=>`"${t.replace(/"/g,'""')}"`,Q=(...t)=>v(g(t,K),s),X=(t,a=[1])=>v(g(t,(()=>"$"+a[0]++)),s),q=(t,a)=>t?.has(a)??!1,Z=t=>c(t)||0==(t=>t?.size??0)(t),tt=t=>[...t?.values()??[]],at=(t,a)=>t?.forEach(a),et=(t,a)=>t?.delete(a),nt=JSON.stringify,st=JSON.parse,ot=t=>new Map(t),rt=(t,a)=>t?.get(a),it=(t,a)=>g([...t?.entries()??[]],(([t,e])=>a(e,t))),ct=(t,a,e)=>c(e)?(et(t,a),t):t?.set(a,e),lt=(t,a,e,n)=>(q(t,a)?n?.(rt(t,a)):ct(t,a,e()),rt(t,a)),yt=(t,a,e,n,s=0)=>l((e?lt:rt)(t,a[s],s>d(a)-2?e:ot),(o=>{if(s>d(a)-2)return n?.(o)&&ct(t,a[s]),o;const r=yt(o,a,e,n,s+1);return Z(o)&&ct(t,a[s]),r})),ut=/^\d+$/,wt=ot(),dt=ot(),Et=(t,a,e,s,o,r,i,y={},w=[])=>{let E,v,g,h=0,A=0,N=0;lt(wt,w,(()=>0)),lt(dt,w,(()=>[]));const S=ot(),[b,C,O,I,L]=((t=1,a)=>1!=t&&a.isMergeable()?[1,a.getMergeableContent,a.getTransactionMergeableChanges,([[t],[a]])=>!M(t)||!M(a),a.setDefaultContent]:2!=t?[0,a.getContent,a.getTransactionChanges,([t,a])=>!M(t)||!M(a),a.setContent]:p("Store type not supported by this Persister"))(i,t),[R,D,P]=(()=>{let t;const[a,e]=(()=>{const t=[];let a=0;return[e=>(e?m(t):null)??n+a++,a=>{ut.test(a)&&d(t)<1e3&&T(t,a)}]})(),s=ot();return[(e,o,r,i=[],c=()=>[])=>{t??=k;const l=a(1);return ct(s,l,[e,o,r,i,c]),F(yt(o,r??[n],_),l),l},(a,e,...o)=>f(((t,a=[n])=>{const e=[],s=(t,n)=>n==d(a)?T(e,t):null===a[n]?at(t,(t=>s(t,n+1))):f([a[n],null],(a=>s(rt(t,a),n+1)));return s(t,0),e})(a,e),(a=>at(a,(a=>rt(s,a)[0](t,...e??[],...o))))),t=>l(rt(s,t),(([,a,o])=>(yt(a,o??[n],void 0,(a=>(et(a,t),Z(a)?1:0))),ct(s,t),e(t),o))),a=>l(rt(s,a),(([a,,e=[],n,s])=>{const o=(...r)=>{const i=d(r);i==d(e)?a(t,...r,...s(r)):c(e[i])?f(n[i]?.(...r)??[],(t=>o(...r,t))):o(...r,e[i])};o()}))]})(),x=t=>{t!=h&&(h=t,D(S,void 0,h))},U=a=>{(b&&u(a?.[0])?1===a?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===a?.[2]?t.applyChanges:t.setContent)(a)},j=async t=>(2!=h&&(x(1),A++,await Y((async()=>{try{const t=await a();u(t)?U(t):p("Content is not an array "+t)}catch(a){r?.(a),t&&L(t)}x(0)}))),k),B=()=>(v&&(o(v),v=void 0),k),H=async t=>(1!=h&&(x(2),N++,await Y((async()=>{try{await e(C,t)}catch(t){r?.(t)}x(0)}))),k),J=()=>(l(g,t.delListener),g=void 0,k),Y=async(...t)=>(T(rt(dt,w),...t),await(async()=>{if(!rt(wt,w)){for(ct(wt,w,1);!c(E=m(rt(dt,w)));)try{await E()}catch(t){r?.(t)}ct(wt,w,0)}})(),k),k={load:j,startAutoLoad:async t=>{await B().load(t);try{v=await s((async(t,a)=>{a||t?2!=h&&(x(1),A++,U(a??t),x(0)):await j()}))}catch(t){r?.(t)}return k},stopAutoLoad:B,isAutoLoading:()=>!c(v),save:H,startAutoSave:async()=>(await J().save(),g=t.addDidFinishTransactionListener((()=>{const t=O();I(t)&&H(t)})),k),stopAutoSave:J,isAutoSaving:()=>!c(g),getStatus:()=>h,addStatusListener:t=>R(t,S),delListener:a=>(P(a),t),schedule:Y,getStore:()=>t,destroy:()=>(rt(dt,w).splice(0,void 0),B().stopAutoSave()),getStats:()=>({loads:A,saves:N}),...y};return $(k)},pt=(t,a,e,n,o,r=ft,i,l)=>{const y=ot();return[async()=>{y.clear(),g(await e(t,a),(({tn:t,cn:a})=>F(lt(y,t,_),a)))},async(a,e)=>((t,a)=>q(rt(y,t),a))(a,e)?O(A(g(await t(k+K(a)),(t=>{return[t[e],l?(a=L(t,e),n=l,O(R(a,((t,a)=>[a,n(t,a)])))):L(t,e)];var a,n})),(([t,a])=>!c(t)&&!M(a)))):{},async(a,e,n,l,u,w=!1)=>{const d=_();R(n??{},(t=>g(C(t??{}),(t=>F(d,t)))));const p=tt(d);if(!w&&u&&h(p)&&q(y,a))return await t("DROP "+H+K(a)),void ct(y,a);const f=rt(y,a),m=_(tt(f));if(h(p)||(q(y,a)?await E(g([e,...p],(async(n,s)=>{et(m,n)||(await t(J+K(a)+"ADD"+K(n)+o),0==s&&await t("CREATE UNIQUE INDEX pk ON "+K(a)+`(${K(e)})`),F(f,n))}))):(await t("CREATE "+H+K(a)+`(${K(e)}${o} PRIMARY KEY${v(g(p,(t=>s+K(t)+o)))});`),ct(y,a,_([e,...p])))),await E([...!w&&l?g(tt(m),(async n=>{n!=e&&(await t(J+K(a)+"DROP"+K(n)),et(f,n))})):[]]),w)c(n)?await t(Y+K(a)+B+" true"):await E(R(n,(async(n,s)=>{c(n)?await t(Y+K(a)+B+K(e)+"=$1",[s]):h(p)||await r(t,a,e,C(n),{[s]:i?g(D(n),i):D(n)},f)})));else if(h(p))q(y,a)&&await t(Y+K(a)+B+" true");else{const s=A(tt(rt(y,a)),(t=>t!=e)),o={},c=[];R(n??{},((t,a)=>{o[a]=g(s,(a=>i?i(t?.[a]):t?.[a])),T(c,a)})),await r(t,a,e,s,o),await t(Y+K(a)+B+K(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,n,o)=>{const r=[1];await t("INSERT INTO"+K(a)+"("+Q(e,...n)+")VALUES"+v(R(o,(t=>"($"+r[0]+++","+X(t,r)+")")),s)+"ON CONFLICT("+K(e)+")DO UPDATE SET"+v(g(n,(t=>K(t)+"=excluded."+K(t))),s),R(o,((t,a)=>[a,...g(t,(t=>t??null))])).flat())},vt=(t,a,e,n,s,o,r,[i,c,l],y,u,w,d,E,p)=>{const[f,v,g,h]=pt(a,y,u,s,E,p),A=Et(t,(async()=>await h((async()=>{return await f(),t=(await v(i,c))[x]?.[l]??"null",st(t,((t,a)=>""===a?void 0:a));var t}))),(async t=>await h((async()=>{var a;await f(),await g(i,c,{[x]:{[l]:(a=t()??null,nt(a,((t,a)=>void 0===a?"":a)))}},!0,!0)}))),e,n,s,r,{[d]:()=>w,destroy:()=>(A.stopAutoLoad().stopAutoSave(),o(),A)},w);return A},gt=(t,a,e,n,s,o,r,[i,l,[y,u,w]],d,p,f,v,g,h,T,m)=>{const[N,S,b,C]=pt(a,d,p,s,g,h,T,m),$=async(t,a)=>await E(it(l,(async([e,n,s,o],r)=>{a&&!(r in t)||await b(e,n,t[r],s,o,a)}))),I=async(t,a)=>u?await b(w,U,{[x]:t},!0,!0,a):null,L=Et(t,(async()=>await C((async()=>{await N();const t=await(async()=>O(A(await E(it(i,(async([t,a],e)=>[t,await S(e,a)]))),(t=>!M(t[1])))))(),a=await(async()=>y?(await S(w,U))[x]:{})();return M(t)&&c(a)?void 0:[t,a]}))),(async(t,a)=>await C((async()=>{if(await N(),c(a)){const[a,e]=t();await $(a),await I(e)}else await $(a[0],!0),await I(a[1],!0)}))),e,n,s,r,{[v]:()=>f,destroy:()=>(L.stopAutoLoad().stopAutoSave(),o(),L)},f);return L},ht="ColumnName",At="store",Tt="json",mt=At+"TableName",Nt=At+"Id"+ht,St=At+ht,bt="autoLoadIntervalSeconds",Ct="rowId"+ht,$t="tableId",Ot="tableName",It="deleteEmptyColumns",Lt="deleteEmptyTable",Rt={mode:Tt,[bt]:1},Dt={load:0,save:0,[Ot]:e+"_values"},Pt=(t,a,e,n,s)=>{const o=ot();return R(t,((t,r)=>{const i=w(D(I(a,y(t)?{[e]:t}:t)),0,P(a));c(i[0])||n(r,i[0])||(s(r,i[0]),ct(o,r,i))})),o},Mt=(t,a,s,o,r,c,l,u,d,E,p="getDb",f)=>{let v,g,h;const A=((t,a)=>a?async(e,n)=>(a(e,n),await t(e,n)):t)(s,c),[T,m,N,S]=(t=>{const a=(t=>I(Rt,y(t)?{[mt]:t}:t??{}))(t),n=a[bt];if(a.mode==Tt){const t=a[mt]??e;return[1,n,[t,a[Nt]??U,a[St]??At],_(t)]}const{tables:{load:s={},save:o={}}={},values:r={}}=a,i=w(D(I(Dt,r)),0,P(Dt)),c=i[2],l=_(c),u=_(c);return[0,n,[Pt(s,{[$t]:null,[Ct]:U},$t,(t=>q(u,t)),(t=>F(l,t))),Pt(o,{[Ot]:null,[Ct]:U,[It]:0,[Lt]:0},Ot,((t,a)=>q(u,a)),((t,a)=>F(l,a))),i],l]})(a);return(T?vt:gt)(t,A,(t=>{let a;const e=()=>a=setInterval((async()=>{try{const[{d:a,s:e,c:n}]=await A(`${j} ${G} d,${V} s,TOTAL_CHANGES() c FROM ${z}${G} JOIN ${z}${V}`);a==v&&e==g&&n==h||(null!=v&&t(),v=a,g=e,h=n)}catch{}}),1e3*m),n=()=>{v=g=h=null,i(a)},s=o((a=>{S.has(a)&&(n(),t(),e())}));return e(),()=>{n(),r(s)}}),(t=>t()),l,u,d,N,tt(S),(async(t,a)=>await t(`${j} t.name tn,c.name cn FROM ${W}list()t,${W}info(t.name)c ${B} t.schema='main'AND t.type IN('table','view')AND t.name IN(${X(a)})ORDER BY t.name,c.name`,a)),E,p,n,f,(t=>!0===t?1:!1===t?0:t),void 0)},_t=async(t,a,e,n,o,r)=>{const i=[1],c=_(n),l=r?A([...r],(t=>t!=e&&!q(c,t))):[];if(!h(l)){const n=C(o),s=O(g(await t("SELECT"+Q(e,...l)+"FROM"+K(a)+"WHERE"+K(e)+"IN("+X(n)+")",n),(t=>[t[e],t])));f(n,(t=>T(o[t],...g(l,(a=>s?.[t]?.[a]??null)))))}await t("INSERT OR REPLACE INTO"+K(a)+"("+Q(e,...n,...l)+")VALUES"+v(R(o,(t=>"($"+i[0]+++","+X(t,i)+")")),s),R(o,((t,a)=>[a,...g(t,(t=>t??null))])).flat())};t.createPowerSyncPersister=(t,a,e,n,s)=>{let o;return Mt(t,e,(async(t,e=[])=>a.execute(t,e).then((t=>t.rows?._array??[]))),(t=>{const e=new AbortController,n=a.onChange({rawTableNames:!0,signal:e.signal});return(async()=>{for await(const t of n)o&&g(t.changedTables,o)})(),o=t,e}),(t=>{o=void 0,t.abort()}),n,s,(()=>0),1,a,"getPowerSync",_t)}},"object"==typeof exports&&"undefined"!=typeof module?a(exports):"function"==typeof define&&define.amd?define(["exports"],a):a((t="undefined"!=typeof globalThis?globalThis:t||self).TinyBasePersisterPowersync={});