tinybase 5.3.3 → 5.3.5

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 (830) hide show
  1. package/cjs/es6/min/persisters/index.cjs +1 -1
  2. package/cjs/es6/min/persisters/index.cjs.gz +0 -0
  3. package/cjs/es6/min/persisters/persister-automerge/index.cjs +1 -1
  4. package/cjs/es6/min/persisters/persister-automerge/index.cjs.gz +0 -0
  5. package/cjs/es6/min/persisters/persister-automerge/with-schemas/index.cjs +1 -1
  6. package/cjs/es6/min/persisters/persister-automerge/with-schemas/index.cjs.gz +0 -0
  7. package/cjs/es6/min/persisters/persister-browser/index.cjs +1 -1
  8. package/cjs/es6/min/persisters/persister-browser/index.cjs.gz +0 -0
  9. package/cjs/es6/min/persisters/persister-browser/with-schemas/index.cjs +1 -1
  10. package/cjs/es6/min/persisters/persister-browser/with-schemas/index.cjs.gz +0 -0
  11. package/cjs/es6/min/persisters/persister-cr-sqlite-wasm/index.cjs +1 -1
  12. package/cjs/es6/min/persisters/persister-cr-sqlite-wasm/index.cjs.gz +0 -0
  13. package/cjs/es6/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.cjs +1 -1
  14. package/cjs/es6/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.cjs.gz +0 -0
  15. package/cjs/es6/min/persisters/persister-electric-sql/index.cjs +1 -1
  16. package/cjs/es6/min/persisters/persister-electric-sql/index.cjs.gz +0 -0
  17. package/cjs/es6/min/persisters/persister-electric-sql/with-schemas/index.cjs +1 -1
  18. package/cjs/es6/min/persisters/persister-electric-sql/with-schemas/index.cjs.gz +0 -0
  19. package/cjs/es6/min/persisters/persister-expo-sqlite/index.cjs +1 -1
  20. package/cjs/es6/min/persisters/persister-expo-sqlite/index.cjs.gz +0 -0
  21. package/cjs/es6/min/persisters/persister-expo-sqlite/with-schemas/index.cjs +1 -1
  22. package/cjs/es6/min/persisters/persister-expo-sqlite/with-schemas/index.cjs.gz +0 -0
  23. package/cjs/es6/min/persisters/persister-file/index.cjs +1 -1
  24. package/cjs/es6/min/persisters/persister-file/index.cjs.gz +0 -0
  25. package/cjs/es6/min/persisters/persister-file/with-schemas/index.cjs +1 -1
  26. package/cjs/es6/min/persisters/persister-file/with-schemas/index.cjs.gz +0 -0
  27. package/cjs/es6/min/persisters/persister-indexed-db/index.cjs +1 -1
  28. package/cjs/es6/min/persisters/persister-indexed-db/index.cjs.gz +0 -0
  29. package/cjs/es6/min/persisters/persister-indexed-db/with-schemas/index.cjs +1 -1
  30. package/cjs/es6/min/persisters/persister-indexed-db/with-schemas/index.cjs.gz +0 -0
  31. package/cjs/es6/min/persisters/persister-libsql/index.cjs +1 -1
  32. package/cjs/es6/min/persisters/persister-libsql/index.cjs.gz +0 -0
  33. package/cjs/es6/min/persisters/persister-libsql/with-schemas/index.cjs +1 -1
  34. package/cjs/es6/min/persisters/persister-libsql/with-schemas/index.cjs.gz +0 -0
  35. package/cjs/es6/min/persisters/persister-partykit-client/index.cjs +1 -1
  36. package/cjs/es6/min/persisters/persister-partykit-client/index.cjs.gz +0 -0
  37. package/cjs/es6/min/persisters/persister-partykit-client/with-schemas/index.cjs +1 -1
  38. package/cjs/es6/min/persisters/persister-partykit-client/with-schemas/index.cjs.gz +0 -0
  39. package/cjs/es6/min/persisters/persister-pglite/index.cjs +1 -1
  40. package/cjs/es6/min/persisters/persister-pglite/index.cjs.gz +0 -0
  41. package/cjs/es6/min/persisters/persister-pglite/with-schemas/index.cjs +1 -1
  42. package/cjs/es6/min/persisters/persister-pglite/with-schemas/index.cjs.gz +0 -0
  43. package/cjs/es6/min/persisters/persister-postgres/index.cjs +1 -1
  44. package/cjs/es6/min/persisters/persister-postgres/index.cjs.gz +0 -0
  45. package/cjs/es6/min/persisters/persister-postgres/with-schemas/index.cjs +1 -1
  46. package/cjs/es6/min/persisters/persister-postgres/with-schemas/index.cjs.gz +0 -0
  47. package/cjs/es6/min/persisters/persister-powersync/index.cjs +1 -1
  48. package/cjs/es6/min/persisters/persister-powersync/index.cjs.gz +0 -0
  49. package/cjs/es6/min/persisters/persister-powersync/with-schemas/index.cjs +1 -1
  50. package/cjs/es6/min/persisters/persister-powersync/with-schemas/index.cjs.gz +0 -0
  51. package/cjs/es6/min/persisters/persister-remote/index.cjs +1 -1
  52. package/cjs/es6/min/persisters/persister-remote/index.cjs.gz +0 -0
  53. package/cjs/es6/min/persisters/persister-remote/with-schemas/index.cjs +1 -1
  54. package/cjs/es6/min/persisters/persister-remote/with-schemas/index.cjs.gz +0 -0
  55. package/cjs/es6/min/persisters/persister-sqlite-wasm/index.cjs +1 -1
  56. package/cjs/es6/min/persisters/persister-sqlite-wasm/index.cjs.gz +0 -0
  57. package/cjs/es6/min/persisters/persister-sqlite-wasm/with-schemas/index.cjs +1 -1
  58. package/cjs/es6/min/persisters/persister-sqlite-wasm/with-schemas/index.cjs.gz +0 -0
  59. package/cjs/es6/min/persisters/persister-sqlite3/index.cjs +1 -1
  60. package/cjs/es6/min/persisters/persister-sqlite3/index.cjs.gz +0 -0
  61. package/cjs/es6/min/persisters/persister-sqlite3/with-schemas/index.cjs +1 -1
  62. package/cjs/es6/min/persisters/persister-sqlite3/with-schemas/index.cjs.gz +0 -0
  63. package/cjs/es6/min/persisters/persister-yjs/index.cjs +1 -1
  64. package/cjs/es6/min/persisters/persister-yjs/index.cjs.gz +0 -0
  65. package/cjs/es6/min/persisters/persister-yjs/with-schemas/index.cjs +1 -1
  66. package/cjs/es6/min/persisters/persister-yjs/with-schemas/index.cjs.gz +0 -0
  67. package/cjs/es6/min/persisters/with-schemas/index.cjs +1 -1
  68. package/cjs/es6/min/persisters/with-schemas/index.cjs.gz +0 -0
  69. package/cjs/es6/min/synchronizers/index.cjs +1 -1
  70. package/cjs/es6/min/synchronizers/index.cjs.gz +0 -0
  71. package/cjs/es6/min/synchronizers/synchronizer-broadcast-channel/index.cjs +1 -1
  72. package/cjs/es6/min/synchronizers/synchronizer-broadcast-channel/index.cjs.gz +0 -0
  73. package/cjs/es6/min/synchronizers/synchronizer-broadcast-channel/with-schemas/index.cjs +1 -1
  74. package/cjs/es6/min/synchronizers/synchronizer-broadcast-channel/with-schemas/index.cjs.gz +0 -0
  75. package/cjs/es6/min/synchronizers/synchronizer-local/index.cjs +1 -1
  76. package/cjs/es6/min/synchronizers/synchronizer-local/index.cjs.gz +0 -0
  77. package/cjs/es6/min/synchronizers/synchronizer-local/with-schemas/index.cjs +1 -1
  78. package/cjs/es6/min/synchronizers/synchronizer-local/with-schemas/index.cjs.gz +0 -0
  79. package/cjs/es6/min/synchronizers/synchronizer-ws-client/index.cjs +1 -1
  80. package/cjs/es6/min/synchronizers/synchronizer-ws-client/index.cjs.gz +0 -0
  81. package/cjs/es6/min/synchronizers/synchronizer-ws-client/with-schemas/index.cjs +1 -1
  82. package/cjs/es6/min/synchronizers/synchronizer-ws-client/with-schemas/index.cjs.gz +0 -0
  83. package/cjs/es6/min/synchronizers/synchronizer-ws-server/index.cjs +1 -1
  84. package/cjs/es6/min/synchronizers/synchronizer-ws-server/index.cjs.gz +0 -0
  85. package/cjs/es6/min/synchronizers/synchronizer-ws-server/with-schemas/index.cjs +1 -1
  86. package/cjs/es6/min/synchronizers/synchronizer-ws-server/with-schemas/index.cjs.gz +0 -0
  87. package/cjs/es6/min/synchronizers/with-schemas/index.cjs +1 -1
  88. package/cjs/es6/min/synchronizers/with-schemas/index.cjs.gz +0 -0
  89. package/cjs/es6/min/ui-react-inspector/index.cjs +1 -1
  90. package/cjs/es6/min/ui-react-inspector/index.cjs.gz +0 -0
  91. package/cjs/es6/min/ui-react-inspector/with-schemas/index.cjs +1 -1
  92. package/cjs/es6/min/ui-react-inspector/with-schemas/index.cjs.gz +0 -0
  93. package/cjs/es6/persisters/index.cjs +2 -0
  94. package/cjs/es6/persisters/persister-automerge/index.cjs +2 -0
  95. package/cjs/es6/persisters/persister-automerge/with-schemas/index.cjs +2 -0
  96. package/cjs/es6/persisters/persister-browser/index.cjs +2 -0
  97. package/cjs/es6/persisters/persister-browser/with-schemas/index.cjs +2 -0
  98. package/cjs/es6/persisters/persister-cr-sqlite-wasm/index.cjs +2 -0
  99. package/cjs/es6/persisters/persister-cr-sqlite-wasm/with-schemas/index.cjs +2 -0
  100. package/cjs/es6/persisters/persister-electric-sql/index.cjs +2 -0
  101. package/cjs/es6/persisters/persister-electric-sql/with-schemas/index.cjs +2 -0
  102. package/cjs/es6/persisters/persister-expo-sqlite/index.cjs +2 -0
  103. package/cjs/es6/persisters/persister-expo-sqlite/with-schemas/index.cjs +2 -0
  104. package/cjs/es6/persisters/persister-file/index.cjs +2 -0
  105. package/cjs/es6/persisters/persister-file/with-schemas/index.cjs +2 -0
  106. package/cjs/es6/persisters/persister-indexed-db/index.cjs +2 -0
  107. package/cjs/es6/persisters/persister-indexed-db/with-schemas/index.cjs +2 -0
  108. package/cjs/es6/persisters/persister-libsql/index.cjs +2 -0
  109. package/cjs/es6/persisters/persister-libsql/with-schemas/index.cjs +2 -0
  110. package/cjs/es6/persisters/persister-partykit-client/index.cjs +2 -0
  111. package/cjs/es6/persisters/persister-partykit-client/with-schemas/index.cjs +2 -0
  112. package/cjs/es6/persisters/persister-pglite/index.cjs +2 -0
  113. package/cjs/es6/persisters/persister-pglite/with-schemas/index.cjs +2 -0
  114. package/cjs/es6/persisters/persister-postgres/index.cjs +2 -0
  115. package/cjs/es6/persisters/persister-postgres/with-schemas/index.cjs +2 -0
  116. package/cjs/es6/persisters/persister-powersync/index.cjs +2 -0
  117. package/cjs/es6/persisters/persister-powersync/with-schemas/index.cjs +2 -0
  118. package/cjs/es6/persisters/persister-remote/index.cjs +2 -0
  119. package/cjs/es6/persisters/persister-remote/with-schemas/index.cjs +2 -0
  120. package/cjs/es6/persisters/persister-sqlite-wasm/index.cjs +2 -0
  121. package/cjs/es6/persisters/persister-sqlite-wasm/with-schemas/index.cjs +2 -0
  122. package/cjs/es6/persisters/persister-sqlite3/index.cjs +2 -0
  123. package/cjs/es6/persisters/persister-sqlite3/with-schemas/index.cjs +2 -0
  124. package/cjs/es6/persisters/persister-yjs/index.cjs +2 -0
  125. package/cjs/es6/persisters/persister-yjs/with-schemas/index.cjs +2 -0
  126. package/cjs/es6/persisters/with-schemas/index.cjs +2 -0
  127. package/cjs/es6/synchronizers/index.cjs +2 -0
  128. package/cjs/es6/synchronizers/synchronizer-broadcast-channel/index.cjs +2 -0
  129. package/cjs/es6/synchronizers/synchronizer-broadcast-channel/with-schemas/index.cjs +2 -0
  130. package/cjs/es6/synchronizers/synchronizer-local/index.cjs +2 -0
  131. package/cjs/es6/synchronizers/synchronizer-local/with-schemas/index.cjs +2 -0
  132. package/cjs/es6/synchronizers/synchronizer-ws-client/index.cjs +2 -0
  133. package/cjs/es6/synchronizers/synchronizer-ws-client/with-schemas/index.cjs +2 -0
  134. package/cjs/es6/synchronizers/synchronizer-ws-server/index.cjs +2 -0
  135. package/cjs/es6/synchronizers/synchronizer-ws-server/with-schemas/index.cjs +2 -0
  136. package/cjs/es6/synchronizers/with-schemas/index.cjs +2 -0
  137. package/cjs/es6/ui-react-inspector/index.cjs +2 -0
  138. package/cjs/es6/ui-react-inspector/with-schemas/index.cjs +2 -0
  139. package/cjs/min/persisters/index.cjs +1 -1
  140. package/cjs/min/persisters/index.cjs.gz +0 -0
  141. package/cjs/min/persisters/persister-automerge/index.cjs +1 -1
  142. package/cjs/min/persisters/persister-automerge/index.cjs.gz +0 -0
  143. package/cjs/min/persisters/persister-automerge/with-schemas/index.cjs +1 -1
  144. package/cjs/min/persisters/persister-automerge/with-schemas/index.cjs.gz +0 -0
  145. package/cjs/min/persisters/persister-browser/index.cjs +1 -1
  146. package/cjs/min/persisters/persister-browser/index.cjs.gz +0 -0
  147. package/cjs/min/persisters/persister-browser/with-schemas/index.cjs +1 -1
  148. package/cjs/min/persisters/persister-browser/with-schemas/index.cjs.gz +0 -0
  149. package/cjs/min/persisters/persister-cr-sqlite-wasm/index.cjs +1 -1
  150. package/cjs/min/persisters/persister-cr-sqlite-wasm/index.cjs.gz +0 -0
  151. package/cjs/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.cjs +1 -1
  152. package/cjs/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.cjs.gz +0 -0
  153. package/cjs/min/persisters/persister-electric-sql/index.cjs +1 -1
  154. package/cjs/min/persisters/persister-electric-sql/index.cjs.gz +0 -0
  155. package/cjs/min/persisters/persister-electric-sql/with-schemas/index.cjs +1 -1
  156. package/cjs/min/persisters/persister-electric-sql/with-schemas/index.cjs.gz +0 -0
  157. package/cjs/min/persisters/persister-expo-sqlite/index.cjs +1 -1
  158. package/cjs/min/persisters/persister-expo-sqlite/index.cjs.gz +0 -0
  159. package/cjs/min/persisters/persister-expo-sqlite/with-schemas/index.cjs +1 -1
  160. package/cjs/min/persisters/persister-expo-sqlite/with-schemas/index.cjs.gz +0 -0
  161. package/cjs/min/persisters/persister-file/index.cjs +1 -1
  162. package/cjs/min/persisters/persister-file/index.cjs.gz +0 -0
  163. package/cjs/min/persisters/persister-file/with-schemas/index.cjs +1 -1
  164. package/cjs/min/persisters/persister-file/with-schemas/index.cjs.gz +0 -0
  165. package/cjs/min/persisters/persister-indexed-db/index.cjs +1 -1
  166. package/cjs/min/persisters/persister-indexed-db/index.cjs.gz +0 -0
  167. package/cjs/min/persisters/persister-indexed-db/with-schemas/index.cjs +1 -1
  168. package/cjs/min/persisters/persister-indexed-db/with-schemas/index.cjs.gz +0 -0
  169. package/cjs/min/persisters/persister-libsql/index.cjs +1 -1
  170. package/cjs/min/persisters/persister-libsql/index.cjs.gz +0 -0
  171. package/cjs/min/persisters/persister-libsql/with-schemas/index.cjs +1 -1
  172. package/cjs/min/persisters/persister-libsql/with-schemas/index.cjs.gz +0 -0
  173. package/cjs/min/persisters/persister-partykit-client/index.cjs +1 -1
  174. package/cjs/min/persisters/persister-partykit-client/index.cjs.gz +0 -0
  175. package/cjs/min/persisters/persister-partykit-client/with-schemas/index.cjs +1 -1
  176. package/cjs/min/persisters/persister-partykit-client/with-schemas/index.cjs.gz +0 -0
  177. package/cjs/min/persisters/persister-pglite/index.cjs +1 -1
  178. package/cjs/min/persisters/persister-pglite/index.cjs.gz +0 -0
  179. package/cjs/min/persisters/persister-pglite/with-schemas/index.cjs +1 -1
  180. package/cjs/min/persisters/persister-pglite/with-schemas/index.cjs.gz +0 -0
  181. package/cjs/min/persisters/persister-postgres/index.cjs +1 -1
  182. package/cjs/min/persisters/persister-postgres/index.cjs.gz +0 -0
  183. package/cjs/min/persisters/persister-postgres/with-schemas/index.cjs +1 -1
  184. package/cjs/min/persisters/persister-postgres/with-schemas/index.cjs.gz +0 -0
  185. package/cjs/min/persisters/persister-powersync/index.cjs +1 -1
  186. package/cjs/min/persisters/persister-powersync/index.cjs.gz +0 -0
  187. package/cjs/min/persisters/persister-powersync/with-schemas/index.cjs +1 -1
  188. package/cjs/min/persisters/persister-powersync/with-schemas/index.cjs.gz +0 -0
  189. package/cjs/min/persisters/persister-remote/index.cjs +1 -1
  190. package/cjs/min/persisters/persister-remote/index.cjs.gz +0 -0
  191. package/cjs/min/persisters/persister-remote/with-schemas/index.cjs +1 -1
  192. package/cjs/min/persisters/persister-remote/with-schemas/index.cjs.gz +0 -0
  193. package/cjs/min/persisters/persister-sqlite-wasm/index.cjs +1 -1
  194. package/cjs/min/persisters/persister-sqlite-wasm/index.cjs.gz +0 -0
  195. package/cjs/min/persisters/persister-sqlite-wasm/with-schemas/index.cjs +1 -1
  196. package/cjs/min/persisters/persister-sqlite-wasm/with-schemas/index.cjs.gz +0 -0
  197. package/cjs/min/persisters/persister-sqlite3/index.cjs +1 -1
  198. package/cjs/min/persisters/persister-sqlite3/index.cjs.gz +0 -0
  199. package/cjs/min/persisters/persister-sqlite3/with-schemas/index.cjs +1 -1
  200. package/cjs/min/persisters/persister-sqlite3/with-schemas/index.cjs.gz +0 -0
  201. package/cjs/min/persisters/persister-yjs/index.cjs +1 -1
  202. package/cjs/min/persisters/persister-yjs/index.cjs.gz +0 -0
  203. package/cjs/min/persisters/persister-yjs/with-schemas/index.cjs +1 -1
  204. package/cjs/min/persisters/persister-yjs/with-schemas/index.cjs.gz +0 -0
  205. package/cjs/min/persisters/with-schemas/index.cjs +1 -1
  206. package/cjs/min/persisters/with-schemas/index.cjs.gz +0 -0
  207. package/cjs/min/synchronizers/index.cjs +1 -1
  208. package/cjs/min/synchronizers/index.cjs.gz +0 -0
  209. package/cjs/min/synchronizers/synchronizer-broadcast-channel/index.cjs +1 -1
  210. package/cjs/min/synchronizers/synchronizer-broadcast-channel/index.cjs.gz +0 -0
  211. package/cjs/min/synchronizers/synchronizer-broadcast-channel/with-schemas/index.cjs +1 -1
  212. package/cjs/min/synchronizers/synchronizer-broadcast-channel/with-schemas/index.cjs.gz +0 -0
  213. package/cjs/min/synchronizers/synchronizer-local/index.cjs +1 -1
  214. package/cjs/min/synchronizers/synchronizer-local/index.cjs.gz +0 -0
  215. package/cjs/min/synchronizers/synchronizer-local/with-schemas/index.cjs +1 -1
  216. package/cjs/min/synchronizers/synchronizer-local/with-schemas/index.cjs.gz +0 -0
  217. package/cjs/min/synchronizers/synchronizer-ws-client/index.cjs +1 -1
  218. package/cjs/min/synchronizers/synchronizer-ws-client/index.cjs.gz +0 -0
  219. package/cjs/min/synchronizers/synchronizer-ws-client/with-schemas/index.cjs +1 -1
  220. package/cjs/min/synchronizers/synchronizer-ws-client/with-schemas/index.cjs.gz +0 -0
  221. package/cjs/min/synchronizers/synchronizer-ws-server/index.cjs +1 -1
  222. package/cjs/min/synchronizers/synchronizer-ws-server/index.cjs.gz +0 -0
  223. package/cjs/min/synchronizers/synchronizer-ws-server/with-schemas/index.cjs +1 -1
  224. package/cjs/min/synchronizers/synchronizer-ws-server/with-schemas/index.cjs.gz +0 -0
  225. package/cjs/min/synchronizers/with-schemas/index.cjs +1 -1
  226. package/cjs/min/synchronizers/with-schemas/index.cjs.gz +0 -0
  227. package/cjs/min/ui-react-inspector/index.cjs +1 -1
  228. package/cjs/min/ui-react-inspector/index.cjs.gz +0 -0
  229. package/cjs/min/ui-react-inspector/with-schemas/index.cjs +1 -1
  230. package/cjs/min/ui-react-inspector/with-schemas/index.cjs.gz +0 -0
  231. package/cjs/persisters/index.cjs +2 -0
  232. package/cjs/persisters/persister-automerge/index.cjs +2 -0
  233. package/cjs/persisters/persister-automerge/with-schemas/index.cjs +2 -0
  234. package/cjs/persisters/persister-browser/index.cjs +2 -0
  235. package/cjs/persisters/persister-browser/with-schemas/index.cjs +2 -0
  236. package/cjs/persisters/persister-cr-sqlite-wasm/index.cjs +2 -0
  237. package/cjs/persisters/persister-cr-sqlite-wasm/with-schemas/index.cjs +2 -0
  238. package/cjs/persisters/persister-electric-sql/index.cjs +2 -0
  239. package/cjs/persisters/persister-electric-sql/with-schemas/index.cjs +2 -0
  240. package/cjs/persisters/persister-expo-sqlite/index.cjs +2 -0
  241. package/cjs/persisters/persister-expo-sqlite/with-schemas/index.cjs +2 -0
  242. package/cjs/persisters/persister-file/index.cjs +2 -0
  243. package/cjs/persisters/persister-file/with-schemas/index.cjs +2 -0
  244. package/cjs/persisters/persister-indexed-db/index.cjs +2 -0
  245. package/cjs/persisters/persister-indexed-db/with-schemas/index.cjs +2 -0
  246. package/cjs/persisters/persister-libsql/index.cjs +2 -0
  247. package/cjs/persisters/persister-libsql/with-schemas/index.cjs +2 -0
  248. package/cjs/persisters/persister-partykit-client/index.cjs +2 -0
  249. package/cjs/persisters/persister-partykit-client/with-schemas/index.cjs +2 -0
  250. package/cjs/persisters/persister-pglite/index.cjs +2 -0
  251. package/cjs/persisters/persister-pglite/with-schemas/index.cjs +2 -0
  252. package/cjs/persisters/persister-postgres/index.cjs +2 -0
  253. package/cjs/persisters/persister-postgres/with-schemas/index.cjs +2 -0
  254. package/cjs/persisters/persister-powersync/index.cjs +2 -0
  255. package/cjs/persisters/persister-powersync/with-schemas/index.cjs +2 -0
  256. package/cjs/persisters/persister-remote/index.cjs +2 -0
  257. package/cjs/persisters/persister-remote/with-schemas/index.cjs +2 -0
  258. package/cjs/persisters/persister-sqlite-wasm/index.cjs +2 -0
  259. package/cjs/persisters/persister-sqlite-wasm/with-schemas/index.cjs +2 -0
  260. package/cjs/persisters/persister-sqlite3/index.cjs +2 -0
  261. package/cjs/persisters/persister-sqlite3/with-schemas/index.cjs +2 -0
  262. package/cjs/persisters/persister-yjs/index.cjs +2 -0
  263. package/cjs/persisters/persister-yjs/with-schemas/index.cjs +2 -0
  264. package/cjs/persisters/with-schemas/index.cjs +2 -0
  265. package/cjs/synchronizers/index.cjs +2 -0
  266. package/cjs/synchronizers/synchronizer-broadcast-channel/index.cjs +2 -0
  267. package/cjs/synchronizers/synchronizer-broadcast-channel/with-schemas/index.cjs +2 -0
  268. package/cjs/synchronizers/synchronizer-local/index.cjs +2 -0
  269. package/cjs/synchronizers/synchronizer-local/with-schemas/index.cjs +2 -0
  270. package/cjs/synchronizers/synchronizer-ws-client/index.cjs +2 -0
  271. package/cjs/synchronizers/synchronizer-ws-client/with-schemas/index.cjs +2 -0
  272. package/cjs/synchronizers/synchronizer-ws-server/index.cjs +2 -0
  273. package/cjs/synchronizers/synchronizer-ws-server/with-schemas/index.cjs +2 -0
  274. package/cjs/synchronizers/with-schemas/index.cjs +2 -0
  275. package/cjs/ui-react-inspector/index.cjs +2 -0
  276. package/cjs/ui-react-inspector/with-schemas/index.cjs +2 -0
  277. package/es6/min/persisters/index.js +1 -1
  278. package/es6/min/persisters/index.js.gz +0 -0
  279. package/es6/min/persisters/persister-automerge/index.js +1 -1
  280. package/es6/min/persisters/persister-automerge/index.js.gz +0 -0
  281. package/es6/min/persisters/persister-automerge/with-schemas/index.js +1 -1
  282. package/es6/min/persisters/persister-automerge/with-schemas/index.js.gz +0 -0
  283. package/es6/min/persisters/persister-browser/index.js +1 -1
  284. package/es6/min/persisters/persister-browser/index.js.gz +0 -0
  285. package/es6/min/persisters/persister-browser/with-schemas/index.js +1 -1
  286. package/es6/min/persisters/persister-browser/with-schemas/index.js.gz +0 -0
  287. package/es6/min/persisters/persister-cr-sqlite-wasm/index.js +1 -1
  288. package/es6/min/persisters/persister-cr-sqlite-wasm/index.js.gz +0 -0
  289. package/es6/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.js +1 -1
  290. package/es6/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.js.gz +0 -0
  291. package/es6/min/persisters/persister-electric-sql/index.js +1 -1
  292. package/es6/min/persisters/persister-electric-sql/index.js.gz +0 -0
  293. package/es6/min/persisters/persister-electric-sql/with-schemas/index.js +1 -1
  294. package/es6/min/persisters/persister-electric-sql/with-schemas/index.js.gz +0 -0
  295. package/es6/min/persisters/persister-expo-sqlite/index.js +1 -1
  296. package/es6/min/persisters/persister-expo-sqlite/index.js.gz +0 -0
  297. package/es6/min/persisters/persister-expo-sqlite/with-schemas/index.js +1 -1
  298. package/es6/min/persisters/persister-expo-sqlite/with-schemas/index.js.gz +0 -0
  299. package/es6/min/persisters/persister-file/index.js +1 -1
  300. package/es6/min/persisters/persister-file/index.js.gz +0 -0
  301. package/es6/min/persisters/persister-file/with-schemas/index.js +1 -1
  302. package/es6/min/persisters/persister-file/with-schemas/index.js.gz +0 -0
  303. package/es6/min/persisters/persister-indexed-db/index.js +1 -1
  304. package/es6/min/persisters/persister-indexed-db/index.js.gz +0 -0
  305. package/es6/min/persisters/persister-indexed-db/with-schemas/index.js +1 -1
  306. package/es6/min/persisters/persister-indexed-db/with-schemas/index.js.gz +0 -0
  307. package/es6/min/persisters/persister-libsql/index.js +1 -1
  308. package/es6/min/persisters/persister-libsql/index.js.gz +0 -0
  309. package/es6/min/persisters/persister-libsql/with-schemas/index.js +1 -1
  310. package/es6/min/persisters/persister-libsql/with-schemas/index.js.gz +0 -0
  311. package/es6/min/persisters/persister-partykit-client/index.js +1 -1
  312. package/es6/min/persisters/persister-partykit-client/index.js.gz +0 -0
  313. package/es6/min/persisters/persister-partykit-client/with-schemas/index.js +1 -1
  314. package/es6/min/persisters/persister-partykit-client/with-schemas/index.js.gz +0 -0
  315. package/es6/min/persisters/persister-pglite/index.js +1 -1
  316. package/es6/min/persisters/persister-pglite/index.js.gz +0 -0
  317. package/es6/min/persisters/persister-pglite/with-schemas/index.js +1 -1
  318. package/es6/min/persisters/persister-pglite/with-schemas/index.js.gz +0 -0
  319. package/es6/min/persisters/persister-postgres/index.js +1 -1
  320. package/es6/min/persisters/persister-postgres/index.js.gz +0 -0
  321. package/es6/min/persisters/persister-postgres/with-schemas/index.js +1 -1
  322. package/es6/min/persisters/persister-postgres/with-schemas/index.js.gz +0 -0
  323. package/es6/min/persisters/persister-powersync/index.js +1 -1
  324. package/es6/min/persisters/persister-powersync/index.js.gz +0 -0
  325. package/es6/min/persisters/persister-powersync/with-schemas/index.js +1 -1
  326. package/es6/min/persisters/persister-powersync/with-schemas/index.js.gz +0 -0
  327. package/es6/min/persisters/persister-remote/index.js +1 -1
  328. package/es6/min/persisters/persister-remote/index.js.gz +0 -0
  329. package/es6/min/persisters/persister-remote/with-schemas/index.js +1 -1
  330. package/es6/min/persisters/persister-remote/with-schemas/index.js.gz +0 -0
  331. package/es6/min/persisters/persister-sqlite-wasm/index.js +1 -1
  332. package/es6/min/persisters/persister-sqlite-wasm/index.js.gz +0 -0
  333. package/es6/min/persisters/persister-sqlite-wasm/with-schemas/index.js +1 -1
  334. package/es6/min/persisters/persister-sqlite-wasm/with-schemas/index.js.gz +0 -0
  335. package/es6/min/persisters/persister-sqlite3/index.js +1 -1
  336. package/es6/min/persisters/persister-sqlite3/index.js.gz +0 -0
  337. package/es6/min/persisters/persister-sqlite3/with-schemas/index.js +1 -1
  338. package/es6/min/persisters/persister-sqlite3/with-schemas/index.js.gz +0 -0
  339. package/es6/min/persisters/persister-yjs/index.js +1 -1
  340. package/es6/min/persisters/persister-yjs/index.js.gz +0 -0
  341. package/es6/min/persisters/persister-yjs/with-schemas/index.js +1 -1
  342. package/es6/min/persisters/persister-yjs/with-schemas/index.js.gz +0 -0
  343. package/es6/min/persisters/with-schemas/index.js +1 -1
  344. package/es6/min/persisters/with-schemas/index.js.gz +0 -0
  345. package/es6/min/synchronizers/index.js +1 -1
  346. package/es6/min/synchronizers/index.js.gz +0 -0
  347. package/es6/min/synchronizers/synchronizer-broadcast-channel/index.js +1 -1
  348. package/es6/min/synchronizers/synchronizer-broadcast-channel/index.js.gz +0 -0
  349. package/es6/min/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js +1 -1
  350. package/es6/min/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js.gz +0 -0
  351. package/es6/min/synchronizers/synchronizer-local/index.js +1 -1
  352. package/es6/min/synchronizers/synchronizer-local/index.js.gz +0 -0
  353. package/es6/min/synchronizers/synchronizer-local/with-schemas/index.js +1 -1
  354. package/es6/min/synchronizers/synchronizer-local/with-schemas/index.js.gz +0 -0
  355. package/es6/min/synchronizers/synchronizer-ws-client/index.js +1 -1
  356. package/es6/min/synchronizers/synchronizer-ws-client/index.js.gz +0 -0
  357. package/es6/min/synchronizers/synchronizer-ws-client/with-schemas/index.js +1 -1
  358. package/es6/min/synchronizers/synchronizer-ws-client/with-schemas/index.js.gz +0 -0
  359. package/es6/min/synchronizers/synchronizer-ws-server/index.js +1 -1
  360. package/es6/min/synchronizers/synchronizer-ws-server/index.js.gz +0 -0
  361. package/es6/min/synchronizers/synchronizer-ws-server/with-schemas/index.js +1 -1
  362. package/es6/min/synchronizers/synchronizer-ws-server/with-schemas/index.js.gz +0 -0
  363. package/es6/min/synchronizers/with-schemas/index.js +1 -1
  364. package/es6/min/synchronizers/with-schemas/index.js.gz +0 -0
  365. package/es6/min/ui-react-inspector/index.js +1 -1
  366. package/es6/min/ui-react-inspector/index.js.gz +0 -0
  367. package/es6/min/ui-react-inspector/with-schemas/index.js +1 -1
  368. package/es6/min/ui-react-inspector/with-schemas/index.js.gz +0 -0
  369. package/es6/persisters/index.js +2 -0
  370. package/es6/persisters/persister-automerge/index.js +2 -0
  371. package/es6/persisters/persister-automerge/with-schemas/index.js +2 -0
  372. package/es6/persisters/persister-browser/index.js +2 -0
  373. package/es6/persisters/persister-browser/with-schemas/index.js +2 -0
  374. package/es6/persisters/persister-cr-sqlite-wasm/index.js +2 -0
  375. package/es6/persisters/persister-cr-sqlite-wasm/with-schemas/index.js +2 -0
  376. package/es6/persisters/persister-electric-sql/index.js +2 -0
  377. package/es6/persisters/persister-electric-sql/with-schemas/index.js +2 -0
  378. package/es6/persisters/persister-expo-sqlite/index.js +2 -0
  379. package/es6/persisters/persister-expo-sqlite/with-schemas/index.js +2 -0
  380. package/es6/persisters/persister-file/index.js +2 -0
  381. package/es6/persisters/persister-file/with-schemas/index.js +2 -0
  382. package/es6/persisters/persister-indexed-db/index.js +2 -0
  383. package/es6/persisters/persister-indexed-db/with-schemas/index.js +2 -0
  384. package/es6/persisters/persister-libsql/index.js +2 -0
  385. package/es6/persisters/persister-libsql/with-schemas/index.js +2 -0
  386. package/es6/persisters/persister-partykit-client/index.js +2 -0
  387. package/es6/persisters/persister-partykit-client/with-schemas/index.js +2 -0
  388. package/es6/persisters/persister-pglite/index.js +2 -0
  389. package/es6/persisters/persister-pglite/with-schemas/index.js +2 -0
  390. package/es6/persisters/persister-postgres/index.js +2 -0
  391. package/es6/persisters/persister-postgres/with-schemas/index.js +2 -0
  392. package/es6/persisters/persister-powersync/index.js +2 -0
  393. package/es6/persisters/persister-powersync/with-schemas/index.js +2 -0
  394. package/es6/persisters/persister-remote/index.js +2 -0
  395. package/es6/persisters/persister-remote/with-schemas/index.js +2 -0
  396. package/es6/persisters/persister-sqlite-wasm/index.js +2 -0
  397. package/es6/persisters/persister-sqlite-wasm/with-schemas/index.js +2 -0
  398. package/es6/persisters/persister-sqlite3/index.js +2 -0
  399. package/es6/persisters/persister-sqlite3/with-schemas/index.js +2 -0
  400. package/es6/persisters/persister-yjs/index.js +2 -0
  401. package/es6/persisters/persister-yjs/with-schemas/index.js +2 -0
  402. package/es6/persisters/with-schemas/index.js +2 -0
  403. package/es6/synchronizers/index.js +2 -0
  404. package/es6/synchronizers/synchronizer-broadcast-channel/index.js +2 -0
  405. package/es6/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js +2 -0
  406. package/es6/synchronizers/synchronizer-local/index.js +2 -0
  407. package/es6/synchronizers/synchronizer-local/with-schemas/index.js +2 -0
  408. package/es6/synchronizers/synchronizer-ws-client/index.js +2 -0
  409. package/es6/synchronizers/synchronizer-ws-client/with-schemas/index.js +2 -0
  410. package/es6/synchronizers/synchronizer-ws-server/index.js +2 -0
  411. package/es6/synchronizers/synchronizer-ws-server/with-schemas/index.js +2 -0
  412. package/es6/synchronizers/with-schemas/index.js +2 -0
  413. package/es6/ui-react-inspector/index.js +2 -0
  414. package/es6/ui-react-inspector/with-schemas/index.js +2 -0
  415. package/min/persisters/index.js +1 -1
  416. package/min/persisters/index.js.gz +0 -0
  417. package/min/persisters/persister-automerge/index.js +1 -1
  418. package/min/persisters/persister-automerge/index.js.gz +0 -0
  419. package/min/persisters/persister-automerge/with-schemas/index.js +1 -1
  420. package/min/persisters/persister-automerge/with-schemas/index.js.gz +0 -0
  421. package/min/persisters/persister-browser/index.js +1 -1
  422. package/min/persisters/persister-browser/index.js.gz +0 -0
  423. package/min/persisters/persister-browser/with-schemas/index.js +1 -1
  424. package/min/persisters/persister-browser/with-schemas/index.js.gz +0 -0
  425. package/min/persisters/persister-cr-sqlite-wasm/index.js +1 -1
  426. package/min/persisters/persister-cr-sqlite-wasm/index.js.gz +0 -0
  427. package/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.js +1 -1
  428. package/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.js.gz +0 -0
  429. package/min/persisters/persister-electric-sql/index.js +1 -1
  430. package/min/persisters/persister-electric-sql/index.js.gz +0 -0
  431. package/min/persisters/persister-electric-sql/with-schemas/index.js +1 -1
  432. package/min/persisters/persister-electric-sql/with-schemas/index.js.gz +0 -0
  433. package/min/persisters/persister-expo-sqlite/index.js +1 -1
  434. package/min/persisters/persister-expo-sqlite/index.js.gz +0 -0
  435. package/min/persisters/persister-expo-sqlite/with-schemas/index.js +1 -1
  436. package/min/persisters/persister-expo-sqlite/with-schemas/index.js.gz +0 -0
  437. package/min/persisters/persister-file/index.js +1 -1
  438. package/min/persisters/persister-file/index.js.gz +0 -0
  439. package/min/persisters/persister-file/with-schemas/index.js +1 -1
  440. package/min/persisters/persister-file/with-schemas/index.js.gz +0 -0
  441. package/min/persisters/persister-indexed-db/index.js +1 -1
  442. package/min/persisters/persister-indexed-db/index.js.gz +0 -0
  443. package/min/persisters/persister-indexed-db/with-schemas/index.js +1 -1
  444. package/min/persisters/persister-indexed-db/with-schemas/index.js.gz +0 -0
  445. package/min/persisters/persister-libsql/index.js +1 -1
  446. package/min/persisters/persister-libsql/index.js.gz +0 -0
  447. package/min/persisters/persister-libsql/with-schemas/index.js +1 -1
  448. package/min/persisters/persister-libsql/with-schemas/index.js.gz +0 -0
  449. package/min/persisters/persister-partykit-client/index.js +1 -1
  450. package/min/persisters/persister-partykit-client/index.js.gz +0 -0
  451. package/min/persisters/persister-partykit-client/with-schemas/index.js +1 -1
  452. package/min/persisters/persister-partykit-client/with-schemas/index.js.gz +0 -0
  453. package/min/persisters/persister-pglite/index.js +1 -1
  454. package/min/persisters/persister-pglite/index.js.gz +0 -0
  455. package/min/persisters/persister-pglite/with-schemas/index.js +1 -1
  456. package/min/persisters/persister-pglite/with-schemas/index.js.gz +0 -0
  457. package/min/persisters/persister-postgres/index.js +1 -1
  458. package/min/persisters/persister-postgres/index.js.gz +0 -0
  459. package/min/persisters/persister-postgres/with-schemas/index.js +1 -1
  460. package/min/persisters/persister-postgres/with-schemas/index.js.gz +0 -0
  461. package/min/persisters/persister-powersync/index.js +1 -1
  462. package/min/persisters/persister-powersync/index.js.gz +0 -0
  463. package/min/persisters/persister-powersync/with-schemas/index.js +1 -1
  464. package/min/persisters/persister-powersync/with-schemas/index.js.gz +0 -0
  465. package/min/persisters/persister-remote/index.js +1 -1
  466. package/min/persisters/persister-remote/index.js.gz +0 -0
  467. package/min/persisters/persister-remote/with-schemas/index.js +1 -1
  468. package/min/persisters/persister-remote/with-schemas/index.js.gz +0 -0
  469. package/min/persisters/persister-sqlite-wasm/index.js +1 -1
  470. package/min/persisters/persister-sqlite-wasm/index.js.gz +0 -0
  471. package/min/persisters/persister-sqlite-wasm/with-schemas/index.js +1 -1
  472. package/min/persisters/persister-sqlite-wasm/with-schemas/index.js.gz +0 -0
  473. package/min/persisters/persister-sqlite3/index.js +1 -1
  474. package/min/persisters/persister-sqlite3/index.js.gz +0 -0
  475. package/min/persisters/persister-sqlite3/with-schemas/index.js +1 -1
  476. package/min/persisters/persister-sqlite3/with-schemas/index.js.gz +0 -0
  477. package/min/persisters/persister-yjs/index.js +1 -1
  478. package/min/persisters/persister-yjs/index.js.gz +0 -0
  479. package/min/persisters/persister-yjs/with-schemas/index.js +1 -1
  480. package/min/persisters/persister-yjs/with-schemas/index.js.gz +0 -0
  481. package/min/persisters/with-schemas/index.js +1 -1
  482. package/min/persisters/with-schemas/index.js.gz +0 -0
  483. package/min/synchronizers/index.js +1 -1
  484. package/min/synchronizers/index.js.gz +0 -0
  485. package/min/synchronizers/synchronizer-broadcast-channel/index.js +1 -1
  486. package/min/synchronizers/synchronizer-broadcast-channel/index.js.gz +0 -0
  487. package/min/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js +1 -1
  488. package/min/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js.gz +0 -0
  489. package/min/synchronizers/synchronizer-local/index.js +1 -1
  490. package/min/synchronizers/synchronizer-local/index.js.gz +0 -0
  491. package/min/synchronizers/synchronizer-local/with-schemas/index.js +1 -1
  492. package/min/synchronizers/synchronizer-local/with-schemas/index.js.gz +0 -0
  493. package/min/synchronizers/synchronizer-ws-client/index.js +1 -1
  494. package/min/synchronizers/synchronizer-ws-client/index.js.gz +0 -0
  495. package/min/synchronizers/synchronizer-ws-client/with-schemas/index.js +1 -1
  496. package/min/synchronizers/synchronizer-ws-client/with-schemas/index.js.gz +0 -0
  497. package/min/synchronizers/synchronizer-ws-server/index.js +1 -1
  498. package/min/synchronizers/synchronizer-ws-server/index.js.gz +0 -0
  499. package/min/synchronizers/synchronizer-ws-server/with-schemas/index.js +1 -1
  500. package/min/synchronizers/synchronizer-ws-server/with-schemas/index.js.gz +0 -0
  501. package/min/synchronizers/with-schemas/index.js +1 -1
  502. package/min/synchronizers/with-schemas/index.js.gz +0 -0
  503. package/min/ui-react-inspector/index.js +1 -1
  504. package/min/ui-react-inspector/index.js.gz +0 -0
  505. package/min/ui-react-inspector/with-schemas/index.js +1 -1
  506. package/min/ui-react-inspector/with-schemas/index.js.gz +0 -0
  507. package/package.json +2 -2
  508. package/persisters/index.js +2 -0
  509. package/persisters/persister-automerge/index.js +2 -0
  510. package/persisters/persister-automerge/with-schemas/index.js +2 -0
  511. package/persisters/persister-browser/index.js +2 -0
  512. package/persisters/persister-browser/with-schemas/index.js +2 -0
  513. package/persisters/persister-cr-sqlite-wasm/index.js +2 -0
  514. package/persisters/persister-cr-sqlite-wasm/with-schemas/index.js +2 -0
  515. package/persisters/persister-electric-sql/index.js +2 -0
  516. package/persisters/persister-electric-sql/with-schemas/index.js +2 -0
  517. package/persisters/persister-expo-sqlite/index.js +2 -0
  518. package/persisters/persister-expo-sqlite/with-schemas/index.js +2 -0
  519. package/persisters/persister-file/index.js +2 -0
  520. package/persisters/persister-file/with-schemas/index.js +2 -0
  521. package/persisters/persister-indexed-db/index.js +2 -0
  522. package/persisters/persister-indexed-db/with-schemas/index.js +2 -0
  523. package/persisters/persister-libsql/index.js +2 -0
  524. package/persisters/persister-libsql/with-schemas/index.js +2 -0
  525. package/persisters/persister-partykit-client/index.js +2 -0
  526. package/persisters/persister-partykit-client/with-schemas/index.js +2 -0
  527. package/persisters/persister-pglite/index.js +2 -0
  528. package/persisters/persister-pglite/with-schemas/index.js +2 -0
  529. package/persisters/persister-postgres/index.js +2 -0
  530. package/persisters/persister-postgres/with-schemas/index.js +2 -0
  531. package/persisters/persister-powersync/index.js +2 -0
  532. package/persisters/persister-powersync/with-schemas/index.js +2 -0
  533. package/persisters/persister-remote/index.js +2 -0
  534. package/persisters/persister-remote/with-schemas/index.js +2 -0
  535. package/persisters/persister-sqlite-wasm/index.js +2 -0
  536. package/persisters/persister-sqlite-wasm/with-schemas/index.js +2 -0
  537. package/persisters/persister-sqlite3/index.js +2 -0
  538. package/persisters/persister-sqlite3/with-schemas/index.js +2 -0
  539. package/persisters/persister-yjs/index.js +2 -0
  540. package/persisters/persister-yjs/with-schemas/index.js +2 -0
  541. package/persisters/with-schemas/index.js +2 -0
  542. package/readme.md +2 -2
  543. package/synchronizers/index.js +2 -0
  544. package/synchronizers/synchronizer-broadcast-channel/index.js +2 -0
  545. package/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js +2 -0
  546. package/synchronizers/synchronizer-local/index.js +2 -0
  547. package/synchronizers/synchronizer-local/with-schemas/index.js +2 -0
  548. package/synchronizers/synchronizer-ws-client/index.js +2 -0
  549. package/synchronizers/synchronizer-ws-client/with-schemas/index.js +2 -0
  550. package/synchronizers/synchronizer-ws-server/index.js +2 -0
  551. package/synchronizers/synchronizer-ws-server/with-schemas/index.js +2 -0
  552. package/synchronizers/with-schemas/index.js +2 -0
  553. package/ui-react-inspector/index.js +2 -0
  554. package/ui-react-inspector/with-schemas/index.js +2 -0
  555. package/umd/es6/min/persisters/index.js +1 -1
  556. package/umd/es6/min/persisters/index.js.gz +0 -0
  557. package/umd/es6/min/persisters/persister-automerge/index.js +1 -1
  558. package/umd/es6/min/persisters/persister-automerge/index.js.gz +0 -0
  559. package/umd/es6/min/persisters/persister-automerge/with-schemas/index.js +1 -1
  560. package/umd/es6/min/persisters/persister-automerge/with-schemas/index.js.gz +0 -0
  561. package/umd/es6/min/persisters/persister-browser/index.js +1 -1
  562. package/umd/es6/min/persisters/persister-browser/index.js.gz +0 -0
  563. package/umd/es6/min/persisters/persister-browser/with-schemas/index.js +1 -1
  564. package/umd/es6/min/persisters/persister-browser/with-schemas/index.js.gz +0 -0
  565. package/umd/es6/min/persisters/persister-cr-sqlite-wasm/index.js +1 -1
  566. package/umd/es6/min/persisters/persister-cr-sqlite-wasm/index.js.gz +0 -0
  567. package/umd/es6/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.js +1 -1
  568. package/umd/es6/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.js.gz +0 -0
  569. package/umd/es6/min/persisters/persister-electric-sql/index.js +1 -1
  570. package/umd/es6/min/persisters/persister-electric-sql/index.js.gz +0 -0
  571. package/umd/es6/min/persisters/persister-electric-sql/with-schemas/index.js +1 -1
  572. package/umd/es6/min/persisters/persister-electric-sql/with-schemas/index.js.gz +0 -0
  573. package/umd/es6/min/persisters/persister-expo-sqlite/index.js +1 -1
  574. package/umd/es6/min/persisters/persister-expo-sqlite/index.js.gz +0 -0
  575. package/umd/es6/min/persisters/persister-expo-sqlite/with-schemas/index.js +1 -1
  576. package/umd/es6/min/persisters/persister-expo-sqlite/with-schemas/index.js.gz +0 -0
  577. package/umd/es6/min/persisters/persister-file/index.js +1 -1
  578. package/umd/es6/min/persisters/persister-file/index.js.gz +0 -0
  579. package/umd/es6/min/persisters/persister-file/with-schemas/index.js +1 -1
  580. package/umd/es6/min/persisters/persister-file/with-schemas/index.js.gz +0 -0
  581. package/umd/es6/min/persisters/persister-indexed-db/index.js +1 -1
  582. package/umd/es6/min/persisters/persister-indexed-db/index.js.gz +0 -0
  583. package/umd/es6/min/persisters/persister-indexed-db/with-schemas/index.js +1 -1
  584. package/umd/es6/min/persisters/persister-indexed-db/with-schemas/index.js.gz +0 -0
  585. package/umd/es6/min/persisters/persister-libsql/index.js +1 -1
  586. package/umd/es6/min/persisters/persister-libsql/index.js.gz +0 -0
  587. package/umd/es6/min/persisters/persister-libsql/with-schemas/index.js +1 -1
  588. package/umd/es6/min/persisters/persister-libsql/with-schemas/index.js.gz +0 -0
  589. package/umd/es6/min/persisters/persister-partykit-client/index.js +1 -1
  590. package/umd/es6/min/persisters/persister-partykit-client/index.js.gz +0 -0
  591. package/umd/es6/min/persisters/persister-partykit-client/with-schemas/index.js +1 -1
  592. package/umd/es6/min/persisters/persister-partykit-client/with-schemas/index.js.gz +0 -0
  593. package/umd/es6/min/persisters/persister-pglite/index.js +1 -1
  594. package/umd/es6/min/persisters/persister-pglite/index.js.gz +0 -0
  595. package/umd/es6/min/persisters/persister-pglite/with-schemas/index.js +1 -1
  596. package/umd/es6/min/persisters/persister-pglite/with-schemas/index.js.gz +0 -0
  597. package/umd/es6/min/persisters/persister-postgres/index.js +1 -1
  598. package/umd/es6/min/persisters/persister-postgres/index.js.gz +0 -0
  599. package/umd/es6/min/persisters/persister-postgres/with-schemas/index.js +1 -1
  600. package/umd/es6/min/persisters/persister-postgres/with-schemas/index.js.gz +0 -0
  601. package/umd/es6/min/persisters/persister-powersync/index.js +1 -1
  602. package/umd/es6/min/persisters/persister-powersync/index.js.gz +0 -0
  603. package/umd/es6/min/persisters/persister-powersync/with-schemas/index.js +1 -1
  604. package/umd/es6/min/persisters/persister-powersync/with-schemas/index.js.gz +0 -0
  605. package/umd/es6/min/persisters/persister-remote/index.js +1 -1
  606. package/umd/es6/min/persisters/persister-remote/index.js.gz +0 -0
  607. package/umd/es6/min/persisters/persister-remote/with-schemas/index.js +1 -1
  608. package/umd/es6/min/persisters/persister-remote/with-schemas/index.js.gz +0 -0
  609. package/umd/es6/min/persisters/persister-sqlite-wasm/index.js +1 -1
  610. package/umd/es6/min/persisters/persister-sqlite-wasm/index.js.gz +0 -0
  611. package/umd/es6/min/persisters/persister-sqlite-wasm/with-schemas/index.js +1 -1
  612. package/umd/es6/min/persisters/persister-sqlite-wasm/with-schemas/index.js.gz +0 -0
  613. package/umd/es6/min/persisters/persister-sqlite3/index.js +1 -1
  614. package/umd/es6/min/persisters/persister-sqlite3/index.js.gz +0 -0
  615. package/umd/es6/min/persisters/persister-sqlite3/with-schemas/index.js +1 -1
  616. package/umd/es6/min/persisters/persister-sqlite3/with-schemas/index.js.gz +0 -0
  617. package/umd/es6/min/persisters/persister-yjs/index.js +1 -1
  618. package/umd/es6/min/persisters/persister-yjs/index.js.gz +0 -0
  619. package/umd/es6/min/persisters/persister-yjs/with-schemas/index.js +1 -1
  620. package/umd/es6/min/persisters/persister-yjs/with-schemas/index.js.gz +0 -0
  621. package/umd/es6/min/persisters/with-schemas/index.js +1 -1
  622. package/umd/es6/min/persisters/with-schemas/index.js.gz +0 -0
  623. package/umd/es6/min/synchronizers/index.js +1 -1
  624. package/umd/es6/min/synchronizers/index.js.gz +0 -0
  625. package/umd/es6/min/synchronizers/synchronizer-broadcast-channel/index.js +1 -1
  626. package/umd/es6/min/synchronizers/synchronizer-broadcast-channel/index.js.gz +0 -0
  627. package/umd/es6/min/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js +1 -1
  628. package/umd/es6/min/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js.gz +0 -0
  629. package/umd/es6/min/synchronizers/synchronizer-local/index.js +1 -1
  630. package/umd/es6/min/synchronizers/synchronizer-local/index.js.gz +0 -0
  631. package/umd/es6/min/synchronizers/synchronizer-local/with-schemas/index.js +1 -1
  632. package/umd/es6/min/synchronizers/synchronizer-local/with-schemas/index.js.gz +0 -0
  633. package/umd/es6/min/synchronizers/synchronizer-ws-client/index.js +1 -1
  634. package/umd/es6/min/synchronizers/synchronizer-ws-client/index.js.gz +0 -0
  635. package/umd/es6/min/synchronizers/synchronizer-ws-client/with-schemas/index.js +1 -1
  636. package/umd/es6/min/synchronizers/synchronizer-ws-client/with-schemas/index.js.gz +0 -0
  637. package/umd/es6/min/synchronizers/synchronizer-ws-server/index.js +1 -1
  638. package/umd/es6/min/synchronizers/synchronizer-ws-server/index.js.gz +0 -0
  639. package/umd/es6/min/synchronizers/synchronizer-ws-server/with-schemas/index.js +1 -1
  640. package/umd/es6/min/synchronizers/synchronizer-ws-server/with-schemas/index.js.gz +0 -0
  641. package/umd/es6/min/synchronizers/with-schemas/index.js +1 -1
  642. package/umd/es6/min/synchronizers/with-schemas/index.js.gz +0 -0
  643. package/umd/es6/min/ui-react-inspector/index.js +1 -1
  644. package/umd/es6/min/ui-react-inspector/index.js.gz +0 -0
  645. package/umd/es6/min/ui-react-inspector/with-schemas/index.js +1 -1
  646. package/umd/es6/min/ui-react-inspector/with-schemas/index.js.gz +0 -0
  647. package/umd/es6/persisters/index.js +2 -0
  648. package/umd/es6/persisters/persister-automerge/index.js +2 -0
  649. package/umd/es6/persisters/persister-automerge/with-schemas/index.js +2 -0
  650. package/umd/es6/persisters/persister-browser/index.js +2 -0
  651. package/umd/es6/persisters/persister-browser/with-schemas/index.js +2 -0
  652. package/umd/es6/persisters/persister-cr-sqlite-wasm/index.js +2 -0
  653. package/umd/es6/persisters/persister-cr-sqlite-wasm/with-schemas/index.js +2 -0
  654. package/umd/es6/persisters/persister-electric-sql/index.js +2 -0
  655. package/umd/es6/persisters/persister-electric-sql/with-schemas/index.js +2 -0
  656. package/umd/es6/persisters/persister-expo-sqlite/index.js +2 -0
  657. package/umd/es6/persisters/persister-expo-sqlite/with-schemas/index.js +2 -0
  658. package/umd/es6/persisters/persister-file/index.js +2 -0
  659. package/umd/es6/persisters/persister-file/with-schemas/index.js +2 -0
  660. package/umd/es6/persisters/persister-indexed-db/index.js +2 -0
  661. package/umd/es6/persisters/persister-indexed-db/with-schemas/index.js +2 -0
  662. package/umd/es6/persisters/persister-libsql/index.js +2 -0
  663. package/umd/es6/persisters/persister-libsql/with-schemas/index.js +2 -0
  664. package/umd/es6/persisters/persister-partykit-client/index.js +2 -0
  665. package/umd/es6/persisters/persister-partykit-client/with-schemas/index.js +2 -0
  666. package/umd/es6/persisters/persister-pglite/index.js +2 -0
  667. package/umd/es6/persisters/persister-pglite/with-schemas/index.js +2 -0
  668. package/umd/es6/persisters/persister-postgres/index.js +2 -0
  669. package/umd/es6/persisters/persister-postgres/with-schemas/index.js +2 -0
  670. package/umd/es6/persisters/persister-powersync/index.js +2 -0
  671. package/umd/es6/persisters/persister-powersync/with-schemas/index.js +2 -0
  672. package/umd/es6/persisters/persister-remote/index.js +2 -0
  673. package/umd/es6/persisters/persister-remote/with-schemas/index.js +2 -0
  674. package/umd/es6/persisters/persister-sqlite-wasm/index.js +2 -0
  675. package/umd/es6/persisters/persister-sqlite-wasm/with-schemas/index.js +2 -0
  676. package/umd/es6/persisters/persister-sqlite3/index.js +2 -0
  677. package/umd/es6/persisters/persister-sqlite3/with-schemas/index.js +2 -0
  678. package/umd/es6/persisters/persister-yjs/index.js +2 -0
  679. package/umd/es6/persisters/persister-yjs/with-schemas/index.js +2 -0
  680. package/umd/es6/persisters/with-schemas/index.js +2 -0
  681. package/umd/es6/synchronizers/index.js +2 -0
  682. package/umd/es6/synchronizers/synchronizer-broadcast-channel/index.js +2 -0
  683. package/umd/es6/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js +2 -0
  684. package/umd/es6/synchronizers/synchronizer-local/index.js +2 -0
  685. package/umd/es6/synchronizers/synchronizer-local/with-schemas/index.js +2 -0
  686. package/umd/es6/synchronizers/synchronizer-ws-client/index.js +2 -0
  687. package/umd/es6/synchronizers/synchronizer-ws-client/with-schemas/index.js +2 -0
  688. package/umd/es6/synchronizers/synchronizer-ws-server/index.js +2 -0
  689. package/umd/es6/synchronizers/synchronizer-ws-server/with-schemas/index.js +2 -0
  690. package/umd/es6/synchronizers/with-schemas/index.js +2 -0
  691. package/umd/es6/ui-react-inspector/index.js +2 -0
  692. package/umd/es6/ui-react-inspector/with-schemas/index.js +2 -0
  693. package/umd/min/persisters/index.js +1 -1
  694. package/umd/min/persisters/index.js.gz +0 -0
  695. package/umd/min/persisters/persister-automerge/index.js +1 -1
  696. package/umd/min/persisters/persister-automerge/index.js.gz +0 -0
  697. package/umd/min/persisters/persister-automerge/with-schemas/index.js +1 -1
  698. package/umd/min/persisters/persister-automerge/with-schemas/index.js.gz +0 -0
  699. package/umd/min/persisters/persister-browser/index.js +1 -1
  700. package/umd/min/persisters/persister-browser/index.js.gz +0 -0
  701. package/umd/min/persisters/persister-browser/with-schemas/index.js +1 -1
  702. package/umd/min/persisters/persister-browser/with-schemas/index.js.gz +0 -0
  703. package/umd/min/persisters/persister-cr-sqlite-wasm/index.js +1 -1
  704. package/umd/min/persisters/persister-cr-sqlite-wasm/index.js.gz +0 -0
  705. package/umd/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.js +1 -1
  706. package/umd/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.js.gz +0 -0
  707. package/umd/min/persisters/persister-electric-sql/index.js +1 -1
  708. package/umd/min/persisters/persister-electric-sql/index.js.gz +0 -0
  709. package/umd/min/persisters/persister-electric-sql/with-schemas/index.js +1 -1
  710. package/umd/min/persisters/persister-electric-sql/with-schemas/index.js.gz +0 -0
  711. package/umd/min/persisters/persister-expo-sqlite/index.js +1 -1
  712. package/umd/min/persisters/persister-expo-sqlite/index.js.gz +0 -0
  713. package/umd/min/persisters/persister-expo-sqlite/with-schemas/index.js +1 -1
  714. package/umd/min/persisters/persister-expo-sqlite/with-schemas/index.js.gz +0 -0
  715. package/umd/min/persisters/persister-file/index.js +1 -1
  716. package/umd/min/persisters/persister-file/index.js.gz +0 -0
  717. package/umd/min/persisters/persister-file/with-schemas/index.js +1 -1
  718. package/umd/min/persisters/persister-file/with-schemas/index.js.gz +0 -0
  719. package/umd/min/persisters/persister-indexed-db/index.js +1 -1
  720. package/umd/min/persisters/persister-indexed-db/index.js.gz +0 -0
  721. package/umd/min/persisters/persister-indexed-db/with-schemas/index.js +1 -1
  722. package/umd/min/persisters/persister-indexed-db/with-schemas/index.js.gz +0 -0
  723. package/umd/min/persisters/persister-libsql/index.js +1 -1
  724. package/umd/min/persisters/persister-libsql/index.js.gz +0 -0
  725. package/umd/min/persisters/persister-libsql/with-schemas/index.js +1 -1
  726. package/umd/min/persisters/persister-libsql/with-schemas/index.js.gz +0 -0
  727. package/umd/min/persisters/persister-partykit-client/index.js +1 -1
  728. package/umd/min/persisters/persister-partykit-client/index.js.gz +0 -0
  729. package/umd/min/persisters/persister-partykit-client/with-schemas/index.js +1 -1
  730. package/umd/min/persisters/persister-partykit-client/with-schemas/index.js.gz +0 -0
  731. package/umd/min/persisters/persister-pglite/index.js +1 -1
  732. package/umd/min/persisters/persister-pglite/index.js.gz +0 -0
  733. package/umd/min/persisters/persister-pglite/with-schemas/index.js +1 -1
  734. package/umd/min/persisters/persister-pglite/with-schemas/index.js.gz +0 -0
  735. package/umd/min/persisters/persister-postgres/index.js +1 -1
  736. package/umd/min/persisters/persister-postgres/index.js.gz +0 -0
  737. package/umd/min/persisters/persister-postgres/with-schemas/index.js +1 -1
  738. package/umd/min/persisters/persister-postgres/with-schemas/index.js.gz +0 -0
  739. package/umd/min/persisters/persister-powersync/index.js +1 -1
  740. package/umd/min/persisters/persister-powersync/index.js.gz +0 -0
  741. package/umd/min/persisters/persister-powersync/with-schemas/index.js +1 -1
  742. package/umd/min/persisters/persister-powersync/with-schemas/index.js.gz +0 -0
  743. package/umd/min/persisters/persister-remote/index.js +1 -1
  744. package/umd/min/persisters/persister-remote/index.js.gz +0 -0
  745. package/umd/min/persisters/persister-remote/with-schemas/index.js +1 -1
  746. package/umd/min/persisters/persister-remote/with-schemas/index.js.gz +0 -0
  747. package/umd/min/persisters/persister-sqlite-wasm/index.js +1 -1
  748. package/umd/min/persisters/persister-sqlite-wasm/index.js.gz +0 -0
  749. package/umd/min/persisters/persister-sqlite-wasm/with-schemas/index.js +1 -1
  750. package/umd/min/persisters/persister-sqlite-wasm/with-schemas/index.js.gz +0 -0
  751. package/umd/min/persisters/persister-sqlite3/index.js +1 -1
  752. package/umd/min/persisters/persister-sqlite3/index.js.gz +0 -0
  753. package/umd/min/persisters/persister-sqlite3/with-schemas/index.js +1 -1
  754. package/umd/min/persisters/persister-sqlite3/with-schemas/index.js.gz +0 -0
  755. package/umd/min/persisters/persister-yjs/index.js +1 -1
  756. package/umd/min/persisters/persister-yjs/index.js.gz +0 -0
  757. package/umd/min/persisters/persister-yjs/with-schemas/index.js +1 -1
  758. package/umd/min/persisters/persister-yjs/with-schemas/index.js.gz +0 -0
  759. package/umd/min/persisters/with-schemas/index.js +1 -1
  760. package/umd/min/persisters/with-schemas/index.js.gz +0 -0
  761. package/umd/min/synchronizers/index.js +1 -1
  762. package/umd/min/synchronizers/index.js.gz +0 -0
  763. package/umd/min/synchronizers/synchronizer-broadcast-channel/index.js +1 -1
  764. package/umd/min/synchronizers/synchronizer-broadcast-channel/index.js.gz +0 -0
  765. package/umd/min/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js +1 -1
  766. package/umd/min/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js.gz +0 -0
  767. package/umd/min/synchronizers/synchronizer-local/index.js +1 -1
  768. package/umd/min/synchronizers/synchronizer-local/index.js.gz +0 -0
  769. package/umd/min/synchronizers/synchronizer-local/with-schemas/index.js +1 -1
  770. package/umd/min/synchronizers/synchronizer-local/with-schemas/index.js.gz +0 -0
  771. package/umd/min/synchronizers/synchronizer-ws-client/index.js +1 -1
  772. package/umd/min/synchronizers/synchronizer-ws-client/index.js.gz +0 -0
  773. package/umd/min/synchronizers/synchronizer-ws-client/with-schemas/index.js +1 -1
  774. package/umd/min/synchronizers/synchronizer-ws-client/with-schemas/index.js.gz +0 -0
  775. package/umd/min/synchronizers/synchronizer-ws-server/index.js +1 -1
  776. package/umd/min/synchronizers/synchronizer-ws-server/index.js.gz +0 -0
  777. package/umd/min/synchronizers/synchronizer-ws-server/with-schemas/index.js +1 -1
  778. package/umd/min/synchronizers/synchronizer-ws-server/with-schemas/index.js.gz +0 -0
  779. package/umd/min/synchronizers/with-schemas/index.js +1 -1
  780. package/umd/min/synchronizers/with-schemas/index.js.gz +0 -0
  781. package/umd/min/ui-react-inspector/index.js +1 -1
  782. package/umd/min/ui-react-inspector/index.js.gz +0 -0
  783. package/umd/min/ui-react-inspector/with-schemas/index.js +1 -1
  784. package/umd/min/ui-react-inspector/with-schemas/index.js.gz +0 -0
  785. package/umd/persisters/index.js +2 -0
  786. package/umd/persisters/persister-automerge/index.js +2 -0
  787. package/umd/persisters/persister-automerge/with-schemas/index.js +2 -0
  788. package/umd/persisters/persister-browser/index.js +2 -0
  789. package/umd/persisters/persister-browser/with-schemas/index.js +2 -0
  790. package/umd/persisters/persister-cr-sqlite-wasm/index.js +2 -0
  791. package/umd/persisters/persister-cr-sqlite-wasm/with-schemas/index.js +2 -0
  792. package/umd/persisters/persister-electric-sql/index.js +2 -0
  793. package/umd/persisters/persister-electric-sql/with-schemas/index.js +2 -0
  794. package/umd/persisters/persister-expo-sqlite/index.js +2 -0
  795. package/umd/persisters/persister-expo-sqlite/with-schemas/index.js +2 -0
  796. package/umd/persisters/persister-file/index.js +2 -0
  797. package/umd/persisters/persister-file/with-schemas/index.js +2 -0
  798. package/umd/persisters/persister-indexed-db/index.js +2 -0
  799. package/umd/persisters/persister-indexed-db/with-schemas/index.js +2 -0
  800. package/umd/persisters/persister-libsql/index.js +2 -0
  801. package/umd/persisters/persister-libsql/with-schemas/index.js +2 -0
  802. package/umd/persisters/persister-partykit-client/index.js +2 -0
  803. package/umd/persisters/persister-partykit-client/with-schemas/index.js +2 -0
  804. package/umd/persisters/persister-pglite/index.js +2 -0
  805. package/umd/persisters/persister-pglite/with-schemas/index.js +2 -0
  806. package/umd/persisters/persister-postgres/index.js +2 -0
  807. package/umd/persisters/persister-postgres/with-schemas/index.js +2 -0
  808. package/umd/persisters/persister-powersync/index.js +2 -0
  809. package/umd/persisters/persister-powersync/with-schemas/index.js +2 -0
  810. package/umd/persisters/persister-remote/index.js +2 -0
  811. package/umd/persisters/persister-remote/with-schemas/index.js +2 -0
  812. package/umd/persisters/persister-sqlite-wasm/index.js +2 -0
  813. package/umd/persisters/persister-sqlite-wasm/with-schemas/index.js +2 -0
  814. package/umd/persisters/persister-sqlite3/index.js +2 -0
  815. package/umd/persisters/persister-sqlite3/with-schemas/index.js +2 -0
  816. package/umd/persisters/persister-yjs/index.js +2 -0
  817. package/umd/persisters/persister-yjs/with-schemas/index.js +2 -0
  818. package/umd/persisters/with-schemas/index.js +2 -0
  819. package/umd/synchronizers/index.js +2 -0
  820. package/umd/synchronizers/synchronizer-broadcast-channel/index.js +2 -0
  821. package/umd/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js +2 -0
  822. package/umd/synchronizers/synchronizer-local/index.js +2 -0
  823. package/umd/synchronizers/synchronizer-local/with-schemas/index.js +2 -0
  824. package/umd/synchronizers/synchronizer-ws-client/index.js +2 -0
  825. package/umd/synchronizers/synchronizer-ws-client/with-schemas/index.js +2 -0
  826. package/umd/synchronizers/synchronizer-ws-server/index.js +2 -0
  827. package/umd/synchronizers/synchronizer-ws-server/with-schemas/index.js +2 -0
  828. package/umd/synchronizers/with-schemas/index.js +2 -0
  829. package/umd/ui-react-inspector/index.js +2 -0
  830. package/umd/ui-react-inspector/with-schemas/index.js +2 -0
@@ -1 +1 @@
1
- var e,t;e=this,t=function(e){"use strict";const t=Promise,a=globalThis.window,n=clearInterval,s=e=>null==e,r=(e,t,a)=>s(e)?a?.():t(e),o=e=>Array.isArray(e),c=e=>e.length,i=e=>new t(e),l=async e=>t.all(e),d=e=>{throw Error(e)},y=(e,t)=>e.forEach(t),u=(e,t)=>e.map(t),g=(e,...t)=>e.push(...t),p=e=>e.shift(),h=Object,w=e=>h.getPrototypeOf(e),f=h.entries,v=h.keys,b=h.freeze,S=e=>(e=>!s(e)&&r(w(e),(e=>e==h.prototype||s(w(e))),(()=>!0)))(e)&&0==(e=>c(v(e)))(e),A=e=>s(e)||0==(e=>e?.size??0)(e),C=(e,t)=>e?.forEach(t),x=(e,t)=>e?.delete(t),D=e=>new Map(e),L=(e,t)=>e?.get(t),M=(e,t,a)=>s(a)?(x(e,t),e):e?.set(t,a),T=(e,t,a,n)=>{var s,r;return s=e,r=t,s?.has(r)?n?.(L(e,t)):M(e,t,a()),L(e,t)},j=(e,t,a,n,s=0)=>r((a?T:L)(e,t[s],s>c(t)-2?a:D),(r=>{if(s>c(t)-2)return n?.(r)&&M(e,t[s]),r;const o=j(r,t,a,n,s+1);return A(r)&&M(e,t[s]),o})),m=e=>new Set(o(e)||s(e)?e:[e]),P=/^\d+$/,k=D(),B=D(),E=(e,t,a,n,i,l,u,h={},w=[])=>{let f,v,E,I=0,O=0,z=0;T(k,w,(()=>0)),T(B,w,(()=>[]));const $=D(),[F,K,N,q,G]=((e=1,t)=>1!=e&&t.isMergeable()?[1,t.getMergeableContent,t.getTransactionMergeableChanges,([[e],[t]])=>!S(e)||!S(t),t.setDefaultContent]:2!=e?[0,t.getContent,t.getTransactionChanges,([e,t])=>!S(e)||!S(t),t.setContent]:d("Store type not supported by this Persister"))(u,e),[H,J,Q]=(()=>{let e;const[t,a]=(()=>{const e=[];let t=0;return[a=>(a?p(e):null)??""+t++,t=>{P.test(t)&&c(e)<1e3&&g(e,t)}]})(),n=D();return[(a,s,r,o=[],c=()=>[])=>{e??=_;const i=t(1);var l,d;return M(n,i,[a,s,r,o,c]),l=j(s,r??[""],m),d=i,l?.add(d),i},(t,a,...s)=>y(((e,t=[""])=>{const a=[],n=(e,s)=>s==c(t)?g(a,e):null===t[s]?C(e,(e=>n(e,s+1))):y([t[s],null],(t=>n(L(e,t),s+1)));return n(e,0),a})(t,a),(t=>C(t,(t=>L(n,t)[0](e,...a??[],...s))))),e=>r(L(n,e),(([,t,s])=>(j(t,s??[""],void 0,(t=>(x(t,e),A(t)?1:0))),M(n,e),a(e),s))),t=>r(L(n,t),(([t,,a=[],n,r])=>{const o=(...i)=>{const l=c(i);l==c(a)?t(e,...i,...r(i)):s(a[l])?y(n[l]?.(...i)??[],(e=>o(...i,e))):o(...i,a[l])};o()}))]})(),R=e=>{e!=I&&(I=e,J($,void 0,I))},U=t=>{(F&&o(t?.[0])?1===t?.[2]?e.applyMergeableChanges:e.setMergeableContent:1===t?.[2]?e.applyChanges:e.setContent)(t)},V=async e=>(2!=I&&(R(1),O++,await Z((async()=>{try{const e=await t();o(e)?U(e):d("Content is not an array "+e)}catch(t){l?.(t),e&&G(e)}R(0)}))),_),W=()=>(v&&(i(v),v=void 0),_),X=async e=>(1!=I&&(R(2),z++,await Z((async()=>{try{await a(K,e)}catch(e){l?.(e)}R(0)}))),_),Y=()=>(r(E,e.delListener),E=void 0,_),Z=async(...e)=>(g(L(B,w),...e),await(async()=>{if(!L(k,w)){for(M(k,w,1);!s(f=p(L(B,w)));)try{await f()}catch(e){l?.(e)}M(k,w,0)}})(),_),_={load:V,startAutoLoad:async e=>{await W().load(e);try{v=await n((async(e,t)=>{t||e?2!=I&&(R(1),O++,U(t??e),R(0)):await V()}))}catch(e){l?.(e)}return _},stopAutoLoad:W,isAutoLoading:()=>!s(v),save:X,startAutoSave:async()=>(await Y().save(),E=e.addDidFinishTransactionListener((()=>{const e=N();q(e)&&X(e)})),_),stopAutoSave:Y,isAutoSaving:()=>!s(E),getStatus:()=>I,addStatusListener:e=>H(e,$),delListener:t=>(Q(t),e),schedule:Z,getStore:()=>e,destroy:()=>(L(B,w).splice(0,void 0),W().stopAutoSave()),getStats:()=>({loads:O,saves:z}),...h};return b(_)},I=["t","v"],O={keyPath:"k"},z=async(e,t)=>{const a=(t=>u(f(t),(([t,a])=>$(e,"put",{k:t,v:a}))))(t);u(await $(e,"getAllKeys"),(n=>((e,t)=>t in e)(t,n)?0:g(a,$(e,"delete",n)))),await l(a)},$=async(e,t,a)=>i(((n,s)=>{const r=e[t](a);r.onsuccess=()=>n(r.result),r.onerror=()=>s(`objectStore.${t} error`)}));e.createIndexedDbPersister=(e,t,s=1,r)=>{const o=async(e,n=[],s=0)=>i(((r,o)=>{const c=(a?a.indexedDB:indexedDB).open(t,s?2:void 0);c.onupgradeneeded=()=>s&&u(I,(e=>{try{c.result.createObjectStore(e,O)}catch{}})),c.onsuccess=async()=>{try{const t=c.result.transaction(I,"readwrite"),a=await l(u(I,(async(a,s)=>await e(t.objectStore(a),n[s]))));c.result.close(),r(a)}catch(e){c.result.close(),o(e)}},c.onerror=()=>o("indexedDB.open error")}));return E(e,(async()=>await o((async e=>((e=[])=>h.fromEntries(e))(u(await $(e,"getAll"),(({k:e,v:t})=>[e,t])))))),(async e=>await o((async(e,t)=>await z(e,t)),e(),1)),(e=>setInterval(e,1e3*s)),(e=>n(e)),r,1,{getDbName:()=>t})},e.objectStoreMatch=z},"object"==typeof exports&&"undefined"!=typeof module?t(exports):"function"==typeof define&&define.amd?define(["exports"],t):t((e="undefined"!=typeof globalThis?globalThis:e||self).TinyBasePersisterIndexedDb={});
1
+ var e,t;e=this,t=function(e){"use strict";const t=Promise,a=globalThis.window,n=clearInterval,s=e=>null==e,r=(e,t,a)=>s(e)?a?.():t(e),o=e=>Array.isArray(e),c=e=>e.length,i=e=>new t(e),l=async e=>t.all(e),d=e=>{throw Error(e)},y=(e,t)=>e.forEach(t),u=(e,t)=>e.map(t),g=(e,...t)=>e.push(...t),p=e=>e.shift(),h=Object,w=e=>h.getPrototypeOf(e),f=h.entries,v=h.keys,b=h.freeze,S=e=>(e=>!s(e)&&r(w(e),(e=>e==h.prototype||s(w(e))),(()=>!0)))(e)&&0==(e=>c(v(e)))(e),A=e=>s(e)||0==(e=>e?.size??0)(e),C=(e,t)=>e?.forEach(t),x=(e,t)=>e?.delete(t),D=e=>new Map(e),L=(e,t)=>e?.get(t),M=(e,t,a)=>s(a)?(x(e,t),e):e?.set(t,a),T=(e,t,a,n)=>{var s,r;return s=e,r=t,s?.has(r)?n?.(L(e,t)):M(e,t,a()),L(e,t)},j=(e,t,a,n,s=0)=>r((a?T:L)(e,t[s],s>c(t)-2?a:D),(r=>{if(s>c(t)-2)return n?.(r)&&M(e,t[s]),r;const o=j(r,t,a,n,s+1);return A(r)&&M(e,t[s]),o})),m=e=>new Set(o(e)||s(e)?e:[e]),P=/^\d+$/,k=D(),B=D(),E=(e,t,a,n,i,l,u,h={},w=[])=>{let f,v,E,I=0,O=0,z=0;T(k,w,(()=>0)),T(B,w,(()=>[]));const $=D(),[F,K,N,q,G]=((e=1,t)=>1!=e&&t.isMergeable()?[1,t.getMergeableContent,t.getTransactionMergeableChanges,([[e],[t]])=>!S(e)||!S(t),t.setDefaultContent]:2!=e?[0,t.getContent,t.getTransactionChanges,([e,t])=>!S(e)||!S(t),t.setContent]:d("Store type not supported by this Persister"))(u,e),[H,J,Q]=(()=>{let e;const[t,a]=(()=>{const e=[];let t=0;return[a=>(a?p(e):null)??""+t++,t=>{P.test(t)&&c(e)<1e3&&g(e,t)}]})(),n=D();return[(a,s,r,o=[],c=()=>[])=>{e??=_;const i=t(1);var l,d;return M(n,i,[a,s,r,o,c]),l=j(s,r??[""],m),d=i,l?.add(d),i},(t,a,...s)=>y(((e,t=[""])=>{const a=[],n=(e,s)=>s==c(t)?g(a,e):null===t[s]?C(e,(e=>n(e,s+1))):y([t[s],null],(t=>n(L(e,t),s+1)));return n(e,0),a})(t,a),(t=>C(t,(t=>L(n,t)[0](e,...a??[],...s))))),e=>r(L(n,e),(([,t,s])=>(j(t,s??[""],void 0,(t=>(x(t,e),A(t)?1:0))),M(n,e),a(e),s))),t=>r(L(n,t),(([t,,a=[],n,r])=>{const o=(...i)=>{const l=c(i);l==c(a)?t(e,...i,...r(i)):s(a[l])?y(n[l]?.(...i)??[],(e=>o(...i,e))):o(...i,a[l])};o()}))]})(),R=e=>{e!=I&&(I=e,J($,void 0,I))},U=t=>{(F&&o(t?.[0])?1===t?.[2]?e.applyMergeableChanges:e.setMergeableContent:1===t?.[2]?e.applyChanges:e.setContent)(t)},V=async e=>(2!=I&&(R(1),O++,await Z((async()=>{try{const a=await t();o(a)?U(a):e?G(e):d("Content is not an array "+a)}catch(t){l?.(t),e&&G(e)}R(0)}))),_),W=()=>(v&&(i(v),v=void 0),_),X=async e=>(1!=I&&(R(2),z++,await Z((async()=>{try{await a(K,e)}catch(e){l?.(e)}R(0)}))),_),Y=()=>(r(E,e.delListener),E=void 0,_),Z=async(...e)=>(g(L(B,w),...e),await(async()=>{if(!L(k,w)){for(M(k,w,1);!s(f=p(L(B,w)));)try{await f()}catch(e){l?.(e)}M(k,w,0)}})(),_),_={load:V,startAutoLoad:async e=>{await W().load(e);try{v=await n((async(e,t)=>{t||e?2!=I&&(R(1),O++,U(t??e),R(0)):await V()}))}catch(e){l?.(e)}return _},stopAutoLoad:W,isAutoLoading:()=>!s(v),save:X,startAutoSave:async()=>(await Y().save(),E=e.addDidFinishTransactionListener((()=>{const e=N();q(e)&&X(e)})),_),stopAutoSave:Y,isAutoSaving:()=>!s(E),getStatus:()=>I,addStatusListener:e=>H(e,$),delListener:t=>(Q(t),e),schedule:Z,getStore:()=>e,destroy:()=>(L(B,w).splice(0,void 0),W().stopAutoSave()),getStats:()=>({loads:O,saves:z}),...h};return b(_)},I=["t","v"],O={keyPath:"k"},z=async(e,t)=>{const a=(t=>u(f(t),(([t,a])=>$(e,"put",{k:t,v:a}))))(t);u(await $(e,"getAllKeys"),(n=>((e,t)=>t in e)(t,n)?0:g(a,$(e,"delete",n)))),await l(a)},$=async(e,t,a)=>i(((n,s)=>{const r=e[t](a);r.onsuccess=()=>n(r.result),r.onerror=()=>s(`objectStore.${t} error`)}));e.createIndexedDbPersister=(e,t,s=1,r)=>{const o=async(e,n=[],s=0)=>i(((r,o)=>{const c=(a?a.indexedDB:indexedDB).open(t,s?2:void 0);c.onupgradeneeded=()=>s&&u(I,(e=>{try{c.result.createObjectStore(e,O)}catch{}})),c.onsuccess=async()=>{try{const t=c.result.transaction(I,"readwrite"),a=await l(u(I,(async(a,s)=>await e(t.objectStore(a),n[s]))));c.result.close(),r(a)}catch(e){c.result.close(),o(e)}},c.onerror=()=>o("indexedDB.open error")}));return E(e,(async()=>await o((async e=>((e=[])=>h.fromEntries(e))(u(await $(e,"getAll"),(({k:e,v:t})=>[e,t])))))),(async e=>await o((async(e,t)=>await z(e,t)),e(),1)),(e=>setInterval(e,1e3*s)),(e=>n(e)),r,1,{getDbName:()=>t})},e.objectStoreMatch=z},"object"==typeof exports&&"undefined"!=typeof module?t(exports):"function"==typeof define&&define.amd?define(["exports"],t):t((e="undefined"!=typeof globalThis?globalThis:e||self).TinyBasePersisterIndexedDb={});
@@ -1 +1 @@
1
- var e,t;e=this,t=function(e){"use strict";const t=Promise,a=globalThis.window,n=clearInterval,s=e=>null==e,r=(e,t,a)=>s(e)?a?.():t(e),o=e=>Array.isArray(e),c=e=>e.length,i=e=>new t(e),l=async e=>t.all(e),d=e=>{throw Error(e)},y=(e,t)=>e.forEach(t),u=(e,t)=>e.map(t),g=(e,...t)=>e.push(...t),p=e=>e.shift(),h=Object,w=e=>h.getPrototypeOf(e),f=h.entries,v=h.keys,b=h.freeze,S=e=>(e=>!s(e)&&r(w(e),(e=>e==h.prototype||s(w(e))),(()=>!0)))(e)&&0==(e=>c(v(e)))(e),A=e=>s(e)||0==(e=>e?.size??0)(e),C=(e,t)=>e?.forEach(t),x=(e,t)=>e?.delete(t),D=e=>new Map(e),L=(e,t)=>e?.get(t),M=(e,t,a)=>s(a)?(x(e,t),e):e?.set(t,a),T=(e,t,a,n)=>{var s,r;return s=e,r=t,s?.has(r)?n?.(L(e,t)):M(e,t,a()),L(e,t)},j=(e,t,a,n,s=0)=>r((a?T:L)(e,t[s],s>c(t)-2?a:D),(r=>{if(s>c(t)-2)return n?.(r)&&M(e,t[s]),r;const o=j(r,t,a,n,s+1);return A(r)&&M(e,t[s]),o})),m=e=>new Set(o(e)||s(e)?e:[e]),P=/^\d+$/,k=D(),B=D(),E=(e,t,a,n,i,l,u,h={},w=[])=>{let f,v,E,I=0,O=0,z=0;T(k,w,(()=>0)),T(B,w,(()=>[]));const $=D(),[F,K,N,q,G]=((e=1,t)=>1!=e&&t.isMergeable()?[1,t.getMergeableContent,t.getTransactionMergeableChanges,([[e],[t]])=>!S(e)||!S(t),t.setDefaultContent]:2!=e?[0,t.getContent,t.getTransactionChanges,([e,t])=>!S(e)||!S(t),t.setContent]:d("Store type not supported by this Persister"))(u,e),[H,J,Q]=(()=>{let e;const[t,a]=(()=>{const e=[];let t=0;return[a=>(a?p(e):null)??""+t++,t=>{P.test(t)&&c(e)<1e3&&g(e,t)}]})(),n=D();return[(a,s,r,o=[],c=()=>[])=>{e??=_;const i=t(1);var l,d;return M(n,i,[a,s,r,o,c]),l=j(s,r??[""],m),d=i,l?.add(d),i},(t,a,...s)=>y(((e,t=[""])=>{const a=[],n=(e,s)=>s==c(t)?g(a,e):null===t[s]?C(e,(e=>n(e,s+1))):y([t[s],null],(t=>n(L(e,t),s+1)));return n(e,0),a})(t,a),(t=>C(t,(t=>L(n,t)[0](e,...a??[],...s))))),e=>r(L(n,e),(([,t,s])=>(j(t,s??[""],void 0,(t=>(x(t,e),A(t)?1:0))),M(n,e),a(e),s))),t=>r(L(n,t),(([t,,a=[],n,r])=>{const o=(...i)=>{const l=c(i);l==c(a)?t(e,...i,...r(i)):s(a[l])?y(n[l]?.(...i)??[],(e=>o(...i,e))):o(...i,a[l])};o()}))]})(),R=e=>{e!=I&&(I=e,J($,void 0,I))},U=t=>{(F&&o(t?.[0])?1===t?.[2]?e.applyMergeableChanges:e.setMergeableContent:1===t?.[2]?e.applyChanges:e.setContent)(t)},V=async e=>(2!=I&&(R(1),O++,await Z((async()=>{try{const e=await t();o(e)?U(e):d("Content is not an array "+e)}catch(t){l?.(t),e&&G(e)}R(0)}))),_),W=()=>(v&&(i(v),v=void 0),_),X=async e=>(1!=I&&(R(2),z++,await Z((async()=>{try{await a(K,e)}catch(e){l?.(e)}R(0)}))),_),Y=()=>(r(E,e.delListener),E=void 0,_),Z=async(...e)=>(g(L(B,w),...e),await(async()=>{if(!L(k,w)){for(M(k,w,1);!s(f=p(L(B,w)));)try{await f()}catch(e){l?.(e)}M(k,w,0)}})(),_),_={load:V,startAutoLoad:async e=>{await W().load(e);try{v=await n((async(e,t)=>{t||e?2!=I&&(R(1),O++,U(t??e),R(0)):await V()}))}catch(e){l?.(e)}return _},stopAutoLoad:W,isAutoLoading:()=>!s(v),save:X,startAutoSave:async()=>(await Y().save(),E=e.addDidFinishTransactionListener((()=>{const e=N();q(e)&&X(e)})),_),stopAutoSave:Y,isAutoSaving:()=>!s(E),getStatus:()=>I,addStatusListener:e=>H(e,$),delListener:t=>(Q(t),e),schedule:Z,getStore:()=>e,destroy:()=>(L(B,w).splice(0,void 0),W().stopAutoSave()),getStats:()=>({loads:O,saves:z}),...h};return b(_)},I=["t","v"],O={keyPath:"k"},z=async(e,t)=>{const a=(t=>u(f(t),(([t,a])=>$(e,"put",{k:t,v:a}))))(t);u(await $(e,"getAllKeys"),(n=>((e,t)=>t in e)(t,n)?0:g(a,$(e,"delete",n)))),await l(a)},$=async(e,t,a)=>i(((n,s)=>{const r=e[t](a);r.onsuccess=()=>n(r.result),r.onerror=()=>s(`objectStore.${t} error`)}));e.createIndexedDbPersister=(e,t,s=1,r)=>{const o=async(e,n=[],s=0)=>i(((r,o)=>{const c=(a?a.indexedDB:indexedDB).open(t,s?2:void 0);c.onupgradeneeded=()=>s&&u(I,(e=>{try{c.result.createObjectStore(e,O)}catch{}})),c.onsuccess=async()=>{try{const t=c.result.transaction(I,"readwrite"),a=await l(u(I,(async(a,s)=>await e(t.objectStore(a),n[s]))));c.result.close(),r(a)}catch(e){c.result.close(),o(e)}},c.onerror=()=>o("indexedDB.open error")}));return E(e,(async()=>await o((async e=>((e=[])=>h.fromEntries(e))(u(await $(e,"getAll"),(({k:e,v:t})=>[e,t])))))),(async e=>await o((async(e,t)=>await z(e,t)),e(),1)),(e=>setInterval(e,1e3*s)),(e=>n(e)),r,1,{getDbName:()=>t})},e.objectStoreMatch=z},"object"==typeof exports&&"undefined"!=typeof module?t(exports):"function"==typeof define&&define.amd?define(["exports"],t):t((e="undefined"!=typeof globalThis?globalThis:e||self).TinyBasePersisterIndexedDb={});
1
+ var e,t;e=this,t=function(e){"use strict";const t=Promise,a=globalThis.window,n=clearInterval,s=e=>null==e,r=(e,t,a)=>s(e)?a?.():t(e),o=e=>Array.isArray(e),c=e=>e.length,i=e=>new t(e),l=async e=>t.all(e),d=e=>{throw Error(e)},y=(e,t)=>e.forEach(t),u=(e,t)=>e.map(t),g=(e,...t)=>e.push(...t),p=e=>e.shift(),h=Object,w=e=>h.getPrototypeOf(e),f=h.entries,v=h.keys,b=h.freeze,S=e=>(e=>!s(e)&&r(w(e),(e=>e==h.prototype||s(w(e))),(()=>!0)))(e)&&0==(e=>c(v(e)))(e),A=e=>s(e)||0==(e=>e?.size??0)(e),C=(e,t)=>e?.forEach(t),x=(e,t)=>e?.delete(t),D=e=>new Map(e),L=(e,t)=>e?.get(t),M=(e,t,a)=>s(a)?(x(e,t),e):e?.set(t,a),T=(e,t,a,n)=>{var s,r;return s=e,r=t,s?.has(r)?n?.(L(e,t)):M(e,t,a()),L(e,t)},j=(e,t,a,n,s=0)=>r((a?T:L)(e,t[s],s>c(t)-2?a:D),(r=>{if(s>c(t)-2)return n?.(r)&&M(e,t[s]),r;const o=j(r,t,a,n,s+1);return A(r)&&M(e,t[s]),o})),m=e=>new Set(o(e)||s(e)?e:[e]),P=/^\d+$/,k=D(),B=D(),E=(e,t,a,n,i,l,u,h={},w=[])=>{let f,v,E,I=0,O=0,z=0;T(k,w,(()=>0)),T(B,w,(()=>[]));const $=D(),[F,K,N,q,G]=((e=1,t)=>1!=e&&t.isMergeable()?[1,t.getMergeableContent,t.getTransactionMergeableChanges,([[e],[t]])=>!S(e)||!S(t),t.setDefaultContent]:2!=e?[0,t.getContent,t.getTransactionChanges,([e,t])=>!S(e)||!S(t),t.setContent]:d("Store type not supported by this Persister"))(u,e),[H,J,Q]=(()=>{let e;const[t,a]=(()=>{const e=[];let t=0;return[a=>(a?p(e):null)??""+t++,t=>{P.test(t)&&c(e)<1e3&&g(e,t)}]})(),n=D();return[(a,s,r,o=[],c=()=>[])=>{e??=_;const i=t(1);var l,d;return M(n,i,[a,s,r,o,c]),l=j(s,r??[""],m),d=i,l?.add(d),i},(t,a,...s)=>y(((e,t=[""])=>{const a=[],n=(e,s)=>s==c(t)?g(a,e):null===t[s]?C(e,(e=>n(e,s+1))):y([t[s],null],(t=>n(L(e,t),s+1)));return n(e,0),a})(t,a),(t=>C(t,(t=>L(n,t)[0](e,...a??[],...s))))),e=>r(L(n,e),(([,t,s])=>(j(t,s??[""],void 0,(t=>(x(t,e),A(t)?1:0))),M(n,e),a(e),s))),t=>r(L(n,t),(([t,,a=[],n,r])=>{const o=(...i)=>{const l=c(i);l==c(a)?t(e,...i,...r(i)):s(a[l])?y(n[l]?.(...i)??[],(e=>o(...i,e))):o(...i,a[l])};o()}))]})(),R=e=>{e!=I&&(I=e,J($,void 0,I))},U=t=>{(F&&o(t?.[0])?1===t?.[2]?e.applyMergeableChanges:e.setMergeableContent:1===t?.[2]?e.applyChanges:e.setContent)(t)},V=async e=>(2!=I&&(R(1),O++,await Z((async()=>{try{const a=await t();o(a)?U(a):e?G(e):d("Content is not an array "+a)}catch(t){l?.(t),e&&G(e)}R(0)}))),_),W=()=>(v&&(i(v),v=void 0),_),X=async e=>(1!=I&&(R(2),z++,await Z((async()=>{try{await a(K,e)}catch(e){l?.(e)}R(0)}))),_),Y=()=>(r(E,e.delListener),E=void 0,_),Z=async(...e)=>(g(L(B,w),...e),await(async()=>{if(!L(k,w)){for(M(k,w,1);!s(f=p(L(B,w)));)try{await f()}catch(e){l?.(e)}M(k,w,0)}})(),_),_={load:V,startAutoLoad:async e=>{await W().load(e);try{v=await n((async(e,t)=>{t||e?2!=I&&(R(1),O++,U(t??e),R(0)):await V()}))}catch(e){l?.(e)}return _},stopAutoLoad:W,isAutoLoading:()=>!s(v),save:X,startAutoSave:async()=>(await Y().save(),E=e.addDidFinishTransactionListener((()=>{const e=N();q(e)&&X(e)})),_),stopAutoSave:Y,isAutoSaving:()=>!s(E),getStatus:()=>I,addStatusListener:e=>H(e,$),delListener:t=>(Q(t),e),schedule:Z,getStore:()=>e,destroy:()=>(L(B,w).splice(0,void 0),W().stopAutoSave()),getStats:()=>({loads:O,saves:z}),...h};return b(_)},I=["t","v"],O={keyPath:"k"},z=async(e,t)=>{const a=(t=>u(f(t),(([t,a])=>$(e,"put",{k:t,v:a}))))(t);u(await $(e,"getAllKeys"),(n=>((e,t)=>t in e)(t,n)?0:g(a,$(e,"delete",n)))),await l(a)},$=async(e,t,a)=>i(((n,s)=>{const r=e[t](a);r.onsuccess=()=>n(r.result),r.onerror=()=>s(`objectStore.${t} error`)}));e.createIndexedDbPersister=(e,t,s=1,r)=>{const o=async(e,n=[],s=0)=>i(((r,o)=>{const c=(a?a.indexedDB:indexedDB).open(t,s?2:void 0);c.onupgradeneeded=()=>s&&u(I,(e=>{try{c.result.createObjectStore(e,O)}catch{}})),c.onsuccess=async()=>{try{const t=c.result.transaction(I,"readwrite"),a=await l(u(I,(async(a,s)=>await e(t.objectStore(a),n[s]))));c.result.close(),r(a)}catch(e){c.result.close(),o(e)}},c.onerror=()=>o("indexedDB.open error")}));return E(e,(async()=>await o((async e=>((e=[])=>h.fromEntries(e))(u(await $(e,"getAll"),(({k:e,v:t})=>[e,t])))))),(async e=>await o((async(e,t)=>await z(e,t)),e(),1)),(e=>setInterval(e,1e3*s)),(e=>n(e)),r,1,{getDbName:()=>t})},e.objectStoreMatch=z},"object"==typeof exports&&"undefined"!=typeof module?t(exports):"function"==typeof define&&define.amd?define(["exports"],t):t((e="undefined"!=typeof globalThis?globalThis:e||self).TinyBasePersisterIndexedDb={});
@@ -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),o=Promise,r=clearInterval,c=t=>null==t,l=(t,a,e)=>c(t)?e?.():a(t),u=t=>a(t)==i,y=t=>Array.isArray(t),w=(t,a,e)=>t.slice(a,e),d=t=>t.length,p=async t=>o.all(t),v=t=>{throw Error(t)},f=(t,a)=>t.forEach(a),g=(t,a="")=>t.join(a),E=(t,a)=>t.map(a),h=t=>0==d(t),m=(t,a)=>t.filter(a),A=(t,...a)=>t.push(...a),N=t=>t.shift(),T="_",$="_id",b="SELECT",S="WHERE",C="TABLE",L="ALTER "+C,O="DELETE FROM",I=b+"*FROM",D="pragma_",R="data_version",M="schema_version",P="pragma_table_",_=t=>`"${t.replace(/"/g,'""')}"`,F=(t,a=[1])=>g(E(t,(()=>"$"+a[0]++)),s),x=(t,a)=>t?.has(a)??!1,j=t=>c(t)||0==(t=>t?.size??0)(t),B=t=>[...t?.values()??[]],U=(t,a)=>t?.forEach(a),q=(t,a)=>t?.delete(a),J=Object,Y=t=>J.getPrototypeOf(t),k=J.entries,z=J.keys,G=J.freeze,H=(t=[])=>J.fromEntries(t),K=(...t)=>J.assign({},...t),Q=(t,a)=>(delete t[a],t),V=(t,a)=>E(k(t),(([t,e])=>a(e,t))),W=t=>J.values(t),X=t=>d(z(t)),Z=t=>(t=>!c(t)&&l(Y(t),(t=>t==J.prototype||c(Y(t))),(()=>!0)))(t)&&0==X(t),tt=JSON.stringify,at=JSON.parse,et=t=>new Map(t),nt=(t,a)=>t?.get(a),st=(t,a)=>E([...t?.entries()??[]],(([t,e])=>a(e,t))),it=(t,a,e)=>c(e)?(q(t,a),t):t?.set(a,e),ot=(t,a,e,n)=>(x(t,a)?n?.(nt(t,a)):it(t,a,e()),nt(t,a)),rt=(t,a,e,n,s=0)=>l((e?ot:nt)(t,a[s],s>d(a)-2?e:et),(i=>{if(s>d(a)-2)return n?.(i)&&it(t,a[s]),i;const o=rt(i,a,e,n,s+1);return j(i)&&it(t,a[s]),o})),ct=t=>new Set(y(t)||c(t)?t:[t]),lt=(t,a)=>t?.add(a),ut=/^\d+$/,yt=et(),wt=et(),dt=(t,a,e,s,i,o,r,u={},w=[])=>{let p,g,E,h=0,m=0,T=0;ot(yt,w,(()=>0)),ot(wt,w,(()=>[]));const $=et(),[b,S,C,L,O]=((t=1,a)=>1!=t&&a.isMergeable()?[1,a.getMergeableContent,a.getTransactionMergeableChanges,([[t],[a]])=>!Z(t)||!Z(a),a.setDefaultContent]:2!=t?[0,a.getContent,a.getTransactionChanges,([t,a])=>!Z(t)||!Z(a),a.setContent]:v("Store type not supported by this Persister"))(r,t),[I,D,R]=(()=>{let t;const[a,e]=(()=>{const t=[];let a=0;return[e=>(e?N(t):null)??n+a++,a=>{ut.test(a)&&d(t)<1e3&&A(t,a)}]})(),s=et();return[(e,i,o,r=[],c=()=>[])=>{t??=Y;const l=a(1);return it(s,l,[e,i,o,r,c]),lt(rt(i,o??[n],ct),l),l},(a,e,...i)=>f(((t,a=[n])=>{const e=[],s=(t,n)=>n==d(a)?A(e,t):null===a[n]?U(t,(t=>s(t,n+1))):f([a[n],null],(a=>s(nt(t,a),n+1)));return s(t,0),e})(a,e),(a=>U(a,(a=>nt(s,a)[0](t,...e??[],...i))))),t=>l(nt(s,t),(([,a,i])=>(rt(a,i??[n],void 0,(a=>(q(a,t),j(a)?1:0))),it(s,t),e(t),i))),a=>l(nt(s,a),(([a,,e=[],n,s])=>{const i=(...o)=>{const r=d(o);r==d(e)?a(t,...o,...s(o)):c(e[r])?f(n[r]?.(...o)??[],(t=>i(...o,t))):i(...o,e[r])};i()}))]})(),M=t=>{t!=h&&(h=t,D($,void 0,h))},P=a=>{(b&&y(a?.[0])?1===a?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===a?.[2]?t.applyChanges:t.setContent)(a)},_=async t=>(2!=h&&(M(1),m++,await J((async()=>{try{const t=await a();y(t)?P(t):v("Content is not an array "+t)}catch(a){o?.(a),t&&O(t)}M(0)}))),Y),F=()=>(g&&(i(g),g=void 0),Y),x=async t=>(1!=h&&(M(2),T++,await J((async()=>{try{await e(S,t)}catch(t){o?.(t)}M(0)}))),Y),B=()=>(l(E,t.delListener),E=void 0,Y),J=async(...t)=>(A(nt(wt,w),...t),await(async()=>{if(!nt(yt,w)){for(it(yt,w,1);!c(p=N(nt(wt,w)));)try{await p()}catch(t){o?.(t)}it(yt,w,0)}})(),Y),Y={load:_,startAutoLoad:async t=>{await F().load(t);try{g=await s((async(t,a)=>{a||t?2!=h&&(M(1),m++,P(a??t),M(0)):await _()}))}catch(t){o?.(t)}return Y},stopAutoLoad:F,isAutoLoading:()=>!c(g),save:x,startAutoSave:async()=>(await B().save(),E=t.addDidFinishTransactionListener((()=>{const t=C();L(t)&&x(t)})),Y),stopAutoSave:B,isAutoSaving:()=>!c(E),getStatus:()=>h,addStatusListener:t=>I(t,$),delListener:a=>(R(a),t),schedule:J,getStore:()=>t,destroy:()=>(nt(wt,w).splice(0,void 0),F().stopAutoSave()),getStats:()=>({loads:m,saves:T}),...u};return G(Y)},pt=(t,a,e,n,i,o=vt,r,l)=>{const u=et();return[async()=>{u.clear(),E(await e(t,a),(({tn:t,cn:a})=>lt(ot(u,t,ct),a)))},async(a,e)=>((t,a)=>x(nt(u,t),a))(a,e)?H(m(E(await t(I+_(a)),(t=>{return[t[e],l?(a=Q(t,e),n=l,H(V(a,((t,a)=>[a,n(t,a)])))):Q(t,e)];var a,n})),(([t,a])=>!c(t)&&!Z(a)))):{},async(a,e,n,l,y,w=!1)=>{const d=ct();V(n??{},(t=>E(z(t??{}),(t=>lt(d,t)))));const v=B(d);if(!w&&y&&h(v)&&x(u,a))return await t("DROP "+C+_(a)),void it(u,a);const f=nt(u,a),N=ct(B(f));if(h(v)||(x(u,a)?await p(E([e,...v],(async(n,s)=>{q(N,n)||(await t(L+_(a)+"ADD"+_(n)+i),0==s&&await t("CREATE UNIQUE INDEX pk ON "+_(a)+`(${_(e)})`),lt(f,n))}))):(await t("CREATE "+C+_(a)+`(${_(e)}${i} PRIMARY KEY${g(E(v,(t=>s+_(t)+i)))});`),it(u,a,ct([e,...v])))),await p([...!w&&l?E(B(N),(async n=>{n!=e&&(await t(L+_(a)+"DROP"+_(n)),q(f,n))})):[]]),w)c(n)?await t(O+_(a)+S+" true"):await p(V(n,(async(n,s)=>{c(n)?await t(O+_(a)+S+_(e)+"=$1",[s]):h(v)||await o(t,a,e,z(n),{[s]:r?E(W(n),r):W(n)},f)})));else if(h(v))x(u,a)&&await t(O+_(a)+S+" true");else{const s=m(B(nt(u,a)),(t=>t!=e)),i={},c=[];V(n??{},((t,a)=>{i[a]=E(s,(a=>r?r(t?.[a]):t?.[a])),A(c,a)})),await o(t,a,e,s,i),await t(O+_(a)+S+_(e)+`NOT IN(${F(c)})`,c)}},async a=>{let e;await t("BEGIN");try{e=await a()}catch(t){n?.(t)}return await t("END"),e}]},vt=async(t,a,e,n,i)=>{const o=[1];await t("INSERT INTO"+_(a)+"("+((...t)=>g(E(t,_),s))(e,...n)+")VALUES"+g(V(i,(t=>"($"+o[0]+++","+F(t,o)+")")),s)+"ON CONFLICT("+_(e)+")DO UPDATE SET"+g(E(n,(t=>_(t)+"=excluded."+_(t))),s),V(i,((t,a)=>[a,...E(t,(t=>t??null))])).flat())},ft=(t,a,e,n,s,i,o,[r,c,l],u,y,w,d,p,v)=>{const[f,g,E,h]=pt(a,u,y,s,p,v),m=dt(t,(async()=>await h((async()=>{return await f(),t=(await g(r,c))[T]?.[l]??"null",at(t,((t,a)=>""===a?void 0:a));var t}))),(async t=>await h((async()=>{var a;await f(),await E(r,c,{[T]:{[l]:(a=t()??null,tt(a,((t,a)=>void 0===a?"":a)))}},!0,!0)}))),e,n,s,o,{[d]:()=>w,destroy:()=>(m.stopAutoLoad().stopAutoSave(),i(),m)},w);return m},gt=(t,a,e,n,s,i,o,[r,l,[u,y,w]],d,v,f,g,E,h,A,N)=>{const[b,S,C,L]=pt(a,d,v,s,E,h,A,N),O=async(t,a)=>await p(st(l,(async([e,n,s,i],o)=>{a&&!(o in t)||await C(e,n,t[o],s,i,a)}))),I=async(t,a)=>y?await C(w,$,{[T]:t},!0,!0,a):null,D=dt(t,(async()=>await L((async()=>{await b();const t=await(async()=>H(m(await p(st(r,(async([t,a],e)=>[t,await S(e,a)]))),(t=>!Z(t[1])))))(),a=await(async()=>u?(await S(w,$))[T]:{})();return Z(t)&&c(a)?void 0:[t,a]}))),(async(t,a)=>await L((async()=>{if(await b(),c(a)){const[a,e]=t();await O(a),await I(e)}else await O(a[0],!0),await I(a[1],!0)}))),e,n,s,o,{[g]:()=>f,destroy:()=>(D.stopAutoLoad().stopAutoSave(),i(),D)},f);return D},Et="ColumnName",ht="store",mt="json",At=ht+"TableName",Nt=ht+"Id"+Et,Tt=ht+Et,$t="autoLoadIntervalSeconds",bt="rowId"+Et,St="tableId",Ct="tableName",Lt="deleteEmptyColumns",Ot="deleteEmptyTable",It={mode:mt,[$t]:1},Dt={load:0,save:0,[Ct]:e+"_values"},Rt=(t,a,e,n,s)=>{const i=et();return V(t,((t,o)=>{const r=w(W(K(a,u(t)?{[e]:t}:t)),0,X(a));c(r[0])||n(o,r[0])||(s(o,r[0]),it(i,o,r))})),i},Mt=(t,a,s,i,o,c,l,y,d,p,v="getDb",f)=>{let g,E,h;const m=((t,a)=>a?async(e,n)=>(a(e,n),await t(e,n)):t)(s,c),[A,N,T,C]=(t=>{const a=(t=>K(It,u(t)?{[At]:t}:t??{}))(t),n=a[$t];if(a.mode==mt){const t=a[At]??e;return[1,n,[t,a[Nt]??$,a[Tt]??ht],ct(t)]}const{tables:{load:s={},save:i={}}={},values:o={}}=a,r=w(W(K(Dt,o)),0,X(Dt)),c=r[2],l=ct(c),y=ct(c);return[0,n,[Rt(s,{[St]:null,[bt]:$},St,(t=>x(y,t)),(t=>lt(l,t))),Rt(i,{[Ct]:null,[bt]:$,[Lt]:0,[Ot]:0},Ct,((t,a)=>x(y,a)),((t,a)=>lt(l,a))),r],l]})(a);return(A?ft:gt)(t,m,(t=>{let a;const e=()=>a=setInterval((async()=>{try{const[{d:a,s:e,c:n}]=await m(`${b} ${R} d,${M} s,TOTAL_CHANGES() c FROM ${D}${R} JOIN ${D}${M}`);a==g&&e==E&&n==h||(null!=g&&t(),g=a,E=e,h=n)}catch{}}),1e3*N),n=()=>{g=E=h=null,r(a)},s=i((a=>{C.has(a)&&(n(),t(),e())}));return e(),()=>{n(),o(s)}}),(t=>t()),l,y,d,T,B(C),(async(t,a)=>await t(`${b} t.name tn,c.name cn FROM ${P}list()t,${P}info(t.name)c ${S} t.schema='main'AND t.type IN('table','view')AND t.name IN(${F(a)})ORDER BY t.name,c.name`,a)),p,v,n,f,(t=>!0===t?1:!1===t?0:t),void 0)};t.createLibSqlPersister=(t,a,e,n,s)=>Mt(t,e,(async(t,e=[])=>(await a.execute({sql:t,args:e})).rows),(()=>()=>0),(t=>t()),n,s,(()=>0),1,a,"getClient")},"object"==typeof exports&&"undefined"!=typeof module?a(exports):"function"==typeof define&&define.amd?define(["exports"],a):a((t="undefined"!=typeof globalThis?globalThis:t||self).TinyBasePersisterLibsql={});
1
+ var t,a;t=this,a=function(t){"use strict";const a=t=>typeof t,e="tinybase",n="",s=",",i=a(n),o=Promise,r=clearInterval,c=t=>null==t,l=(t,a,e)=>c(t)?e?.():a(t),u=t=>a(t)==i,y=t=>Array.isArray(t),w=(t,a,e)=>t.slice(a,e),d=t=>t.length,p=async t=>o.all(t),v=t=>{throw Error(t)},f=(t,a)=>t.forEach(a),g=(t,a="")=>t.join(a),E=(t,a)=>t.map(a),h=t=>0==d(t),m=(t,a)=>t.filter(a),A=(t,...a)=>t.push(...a),N=t=>t.shift(),T="_",$="_id",b="SELECT",S="WHERE",C="TABLE",L="ALTER "+C,O="DELETE FROM",I=b+"*FROM",D="pragma_",R="data_version",M="schema_version",P="pragma_table_",_=t=>`"${t.replace(/"/g,'""')}"`,F=(t,a=[1])=>g(E(t,(()=>"$"+a[0]++)),s),x=(t,a)=>t?.has(a)??!1,j=t=>c(t)||0==(t=>t?.size??0)(t),B=t=>[...t?.values()??[]],U=(t,a)=>t?.forEach(a),q=(t,a)=>t?.delete(a),J=Object,Y=t=>J.getPrototypeOf(t),k=J.entries,z=J.keys,G=J.freeze,H=(t=[])=>J.fromEntries(t),K=(...t)=>J.assign({},...t),Q=(t,a)=>(delete t[a],t),V=(t,a)=>E(k(t),(([t,e])=>a(e,t))),W=t=>J.values(t),X=t=>d(z(t)),Z=t=>(t=>!c(t)&&l(Y(t),(t=>t==J.prototype||c(Y(t))),(()=>!0)))(t)&&0==X(t),tt=JSON.stringify,at=JSON.parse,et=t=>new Map(t),nt=(t,a)=>t?.get(a),st=(t,a)=>E([...t?.entries()??[]],(([t,e])=>a(e,t))),it=(t,a,e)=>c(e)?(q(t,a),t):t?.set(a,e),ot=(t,a,e,n)=>(x(t,a)?n?.(nt(t,a)):it(t,a,e()),nt(t,a)),rt=(t,a,e,n,s=0)=>l((e?ot:nt)(t,a[s],s>d(a)-2?e:et),(i=>{if(s>d(a)-2)return n?.(i)&&it(t,a[s]),i;const o=rt(i,a,e,n,s+1);return j(i)&&it(t,a[s]),o})),ct=t=>new Set(y(t)||c(t)?t:[t]),lt=(t,a)=>t?.add(a),ut=/^\d+$/,yt=et(),wt=et(),dt=(t,a,e,s,i,o,r,u={},w=[])=>{let p,g,E,h=0,m=0,T=0;ot(yt,w,(()=>0)),ot(wt,w,(()=>[]));const $=et(),[b,S,C,L,O]=((t=1,a)=>1!=t&&a.isMergeable()?[1,a.getMergeableContent,a.getTransactionMergeableChanges,([[t],[a]])=>!Z(t)||!Z(a),a.setDefaultContent]:2!=t?[0,a.getContent,a.getTransactionChanges,([t,a])=>!Z(t)||!Z(a),a.setContent]:v("Store type not supported by this Persister"))(r,t),[I,D,R]=(()=>{let t;const[a,e]=(()=>{const t=[];let a=0;return[e=>(e?N(t):null)??n+a++,a=>{ut.test(a)&&d(t)<1e3&&A(t,a)}]})(),s=et();return[(e,i,o,r=[],c=()=>[])=>{t??=Y;const l=a(1);return it(s,l,[e,i,o,r,c]),lt(rt(i,o??[n],ct),l),l},(a,e,...i)=>f(((t,a=[n])=>{const e=[],s=(t,n)=>n==d(a)?A(e,t):null===a[n]?U(t,(t=>s(t,n+1))):f([a[n],null],(a=>s(nt(t,a),n+1)));return s(t,0),e})(a,e),(a=>U(a,(a=>nt(s,a)[0](t,...e??[],...i))))),t=>l(nt(s,t),(([,a,i])=>(rt(a,i??[n],void 0,(a=>(q(a,t),j(a)?1:0))),it(s,t),e(t),i))),a=>l(nt(s,a),(([a,,e=[],n,s])=>{const i=(...o)=>{const r=d(o);r==d(e)?a(t,...o,...s(o)):c(e[r])?f(n[r]?.(...o)??[],(t=>i(...o,t))):i(...o,e[r])};i()}))]})(),M=t=>{t!=h&&(h=t,D($,void 0,h))},P=a=>{(b&&y(a?.[0])?1===a?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===a?.[2]?t.applyChanges:t.setContent)(a)},_=async t=>(2!=h&&(M(1),m++,await J((async()=>{try{const e=await a();y(e)?P(e):t?O(t):v("Content is not an array "+e)}catch(a){o?.(a),t&&O(t)}M(0)}))),Y),F=()=>(g&&(i(g),g=void 0),Y),x=async t=>(1!=h&&(M(2),T++,await J((async()=>{try{await e(S,t)}catch(t){o?.(t)}M(0)}))),Y),B=()=>(l(E,t.delListener),E=void 0,Y),J=async(...t)=>(A(nt(wt,w),...t),await(async()=>{if(!nt(yt,w)){for(it(yt,w,1);!c(p=N(nt(wt,w)));)try{await p()}catch(t){o?.(t)}it(yt,w,0)}})(),Y),Y={load:_,startAutoLoad:async t=>{await F().load(t);try{g=await s((async(t,a)=>{a||t?2!=h&&(M(1),m++,P(a??t),M(0)):await _()}))}catch(t){o?.(t)}return Y},stopAutoLoad:F,isAutoLoading:()=>!c(g),save:x,startAutoSave:async()=>(await B().save(),E=t.addDidFinishTransactionListener((()=>{const t=C();L(t)&&x(t)})),Y),stopAutoSave:B,isAutoSaving:()=>!c(E),getStatus:()=>h,addStatusListener:t=>I(t,$),delListener:a=>(R(a),t),schedule:J,getStore:()=>t,destroy:()=>(nt(wt,w).splice(0,void 0),F().stopAutoSave()),getStats:()=>({loads:m,saves:T}),...u};return G(Y)},pt=(t,a,e,n,i,o=vt,r,l)=>{const u=et();return[async()=>{u.clear(),E(await e(t,a),(({tn:t,cn:a})=>lt(ot(u,t,ct),a)))},async(a,e)=>((t,a)=>x(nt(u,t),a))(a,e)?H(m(E(await t(I+_(a)),(t=>{return[t[e],l?(a=Q(t,e),n=l,H(V(a,((t,a)=>[a,n(t,a)])))):Q(t,e)];var a,n})),(([t,a])=>!c(t)&&!Z(a)))):{},async(a,e,n,l,y,w=!1)=>{const d=ct();V(n??{},(t=>E(z(t??{}),(t=>lt(d,t)))));const v=B(d);if(!w&&y&&h(v)&&x(u,a))return await t("DROP "+C+_(a)),void it(u,a);const f=nt(u,a),N=ct(B(f));if(h(v)||(x(u,a)?await p(E([e,...v],(async(n,s)=>{q(N,n)||(await t(L+_(a)+"ADD"+_(n)+i),0==s&&await t("CREATE UNIQUE INDEX pk ON "+_(a)+`(${_(e)})`),lt(f,n))}))):(await t("CREATE "+C+_(a)+`(${_(e)}${i} PRIMARY KEY${g(E(v,(t=>s+_(t)+i)))});`),it(u,a,ct([e,...v])))),await p([...!w&&l?E(B(N),(async n=>{n!=e&&(await t(L+_(a)+"DROP"+_(n)),q(f,n))})):[]]),w)c(n)?await t(O+_(a)+S+" true"):await p(V(n,(async(n,s)=>{c(n)?await t(O+_(a)+S+_(e)+"=$1",[s]):h(v)||await o(t,a,e,z(n),{[s]:r?E(W(n),r):W(n)},f)})));else if(h(v))x(u,a)&&await t(O+_(a)+S+" true");else{const s=m(B(nt(u,a)),(t=>t!=e)),i={},c=[];V(n??{},((t,a)=>{i[a]=E(s,(a=>r?r(t?.[a]):t?.[a])),A(c,a)})),await o(t,a,e,s,i),await t(O+_(a)+S+_(e)+`NOT IN(${F(c)})`,c)}},async a=>{let e;await t("BEGIN");try{e=await a()}catch(t){n?.(t)}return await t("END"),e}]},vt=async(t,a,e,n,i)=>{const o=[1];await t("INSERT INTO"+_(a)+"("+((...t)=>g(E(t,_),s))(e,...n)+")VALUES"+g(V(i,(t=>"($"+o[0]+++","+F(t,o)+")")),s)+"ON CONFLICT("+_(e)+")DO UPDATE SET"+g(E(n,(t=>_(t)+"=excluded."+_(t))),s),V(i,((t,a)=>[a,...E(t,(t=>t??null))])).flat())},ft=(t,a,e,n,s,i,o,[r,c,l],u,y,w,d,p,v)=>{const[f,g,E,h]=pt(a,u,y,s,p,v),m=dt(t,(async()=>await h((async()=>{return await f(),t=(await g(r,c))[T]?.[l]??"null",at(t,((t,a)=>""===a?void 0:a));var t}))),(async t=>await h((async()=>{var a;await f(),await E(r,c,{[T]:{[l]:(a=t()??null,tt(a,((t,a)=>void 0===a?"":a)))}},!0,!0)}))),e,n,s,o,{[d]:()=>w,destroy:()=>(m.stopAutoLoad().stopAutoSave(),i(),m)},w);return m},gt=(t,a,e,n,s,i,o,[r,l,[u,y,w]],d,v,f,g,E,h,A,N)=>{const[b,S,C,L]=pt(a,d,v,s,E,h,A,N),O=async(t,a)=>await p(st(l,(async([e,n,s,i],o)=>{a&&!(o in t)||await C(e,n,t[o],s,i,a)}))),I=async(t,a)=>y?await C(w,$,{[T]:t},!0,!0,a):null,D=dt(t,(async()=>await L((async()=>{await b();const t=await(async()=>H(m(await p(st(r,(async([t,a],e)=>[t,await S(e,a)]))),(t=>!Z(t[1])))))(),a=await(async()=>u?(await S(w,$))[T]:{})();return Z(t)&&c(a)?void 0:[t,a]}))),(async(t,a)=>await L((async()=>{if(await b(),c(a)){const[a,e]=t();await O(a),await I(e)}else await O(a[0],!0),await I(a[1],!0)}))),e,n,s,o,{[g]:()=>f,destroy:()=>(D.stopAutoLoad().stopAutoSave(),i(),D)},f);return D},Et="ColumnName",ht="store",mt="json",At=ht+"TableName",Nt=ht+"Id"+Et,Tt=ht+Et,$t="autoLoadIntervalSeconds",bt="rowId"+Et,St="tableId",Ct="tableName",Lt="deleteEmptyColumns",Ot="deleteEmptyTable",It={mode:mt,[$t]:1},Dt={load:0,save:0,[Ct]:e+"_values"},Rt=(t,a,e,n,s)=>{const i=et();return V(t,((t,o)=>{const r=w(W(K(a,u(t)?{[e]:t}:t)),0,X(a));c(r[0])||n(o,r[0])||(s(o,r[0]),it(i,o,r))})),i},Mt=(t,a,s,i,o,c,l,y,d,p,v="getDb",f)=>{let g,E,h;const m=((t,a)=>a?async(e,n)=>(a(e,n),await t(e,n)):t)(s,c),[A,N,T,C]=(t=>{const a=(t=>K(It,u(t)?{[At]:t}:t??{}))(t),n=a[$t];if(a.mode==mt){const t=a[At]??e;return[1,n,[t,a[Nt]??$,a[Tt]??ht],ct(t)]}const{tables:{load:s={},save:i={}}={},values:o={}}=a,r=w(W(K(Dt,o)),0,X(Dt)),c=r[2],l=ct(c),y=ct(c);return[0,n,[Rt(s,{[St]:null,[bt]:$},St,(t=>x(y,t)),(t=>lt(l,t))),Rt(i,{[Ct]:null,[bt]:$,[Lt]:0,[Ot]:0},Ct,((t,a)=>x(y,a)),((t,a)=>lt(l,a))),r],l]})(a);return(A?ft:gt)(t,m,(t=>{let a;const e=()=>a=setInterval((async()=>{try{const[{d:a,s:e,c:n}]=await m(`${b} ${R} d,${M} s,TOTAL_CHANGES() c FROM ${D}${R} JOIN ${D}${M}`);a==g&&e==E&&n==h||(null!=g&&t(),g=a,E=e,h=n)}catch{}}),1e3*N),n=()=>{g=E=h=null,r(a)},s=i((a=>{C.has(a)&&(n(),t(),e())}));return e(),()=>{n(),o(s)}}),(t=>t()),l,y,d,T,B(C),(async(t,a)=>await t(`${b} t.name tn,c.name cn FROM ${P}list()t,${P}info(t.name)c ${S} t.schema='main'AND t.type IN('table','view')AND t.name IN(${F(a)})ORDER BY t.name,c.name`,a)),p,v,n,f,(t=>!0===t?1:!1===t?0:t),void 0)};t.createLibSqlPersister=(t,a,e,n,s)=>Mt(t,e,(async(t,e=[])=>(await a.execute({sql:t,args:e})).rows),(()=>()=>0),(t=>t()),n,s,(()=>0),1,a,"getClient")},"object"==typeof exports&&"undefined"!=typeof module?a(exports):"function"==typeof define&&define.amd?define(["exports"],a):a((t="undefined"!=typeof globalThis?globalThis:t||self).TinyBasePersisterLibsql={});
@@ -1 +1 @@
1
- var t,a;t=this,a=function(t){"use strict";const a=t=>typeof t,e="tinybase",n="",s=",",i=a(n),o=Promise,r=clearInterval,c=t=>null==t,l=(t,a,e)=>c(t)?e?.():a(t),u=t=>a(t)==i,y=t=>Array.isArray(t),w=(t,a,e)=>t.slice(a,e),d=t=>t.length,p=async t=>o.all(t),v=t=>{throw Error(t)},f=(t,a)=>t.forEach(a),g=(t,a="")=>t.join(a),E=(t,a)=>t.map(a),h=t=>0==d(t),m=(t,a)=>t.filter(a),A=(t,...a)=>t.push(...a),N=t=>t.shift(),T="_",$="_id",b="SELECT",S="WHERE",C="TABLE",L="ALTER "+C,O="DELETE FROM",I=b+"*FROM",D="pragma_",R="data_version",M="schema_version",P="pragma_table_",_=t=>`"${t.replace(/"/g,'""')}"`,F=(t,a=[1])=>g(E(t,(()=>"$"+a[0]++)),s),x=(t,a)=>t?.has(a)??!1,j=t=>c(t)||0==(t=>t?.size??0)(t),B=t=>[...t?.values()??[]],U=(t,a)=>t?.forEach(a),q=(t,a)=>t?.delete(a),J=Object,Y=t=>J.getPrototypeOf(t),k=J.entries,z=J.keys,G=J.freeze,H=(t=[])=>J.fromEntries(t),K=(...t)=>J.assign({},...t),Q=(t,a)=>(delete t[a],t),V=(t,a)=>E(k(t),(([t,e])=>a(e,t))),W=t=>J.values(t),X=t=>d(z(t)),Z=t=>(t=>!c(t)&&l(Y(t),(t=>t==J.prototype||c(Y(t))),(()=>!0)))(t)&&0==X(t),tt=JSON.stringify,at=JSON.parse,et=t=>new Map(t),nt=(t,a)=>t?.get(a),st=(t,a)=>E([...t?.entries()??[]],(([t,e])=>a(e,t))),it=(t,a,e)=>c(e)?(q(t,a),t):t?.set(a,e),ot=(t,a,e,n)=>(x(t,a)?n?.(nt(t,a)):it(t,a,e()),nt(t,a)),rt=(t,a,e,n,s=0)=>l((e?ot:nt)(t,a[s],s>d(a)-2?e:et),(i=>{if(s>d(a)-2)return n?.(i)&&it(t,a[s]),i;const o=rt(i,a,e,n,s+1);return j(i)&&it(t,a[s]),o})),ct=t=>new Set(y(t)||c(t)?t:[t]),lt=(t,a)=>t?.add(a),ut=/^\d+$/,yt=et(),wt=et(),dt=(t,a,e,s,i,o,r,u={},w=[])=>{let p,g,E,h=0,m=0,T=0;ot(yt,w,(()=>0)),ot(wt,w,(()=>[]));const $=et(),[b,S,C,L,O]=((t=1,a)=>1!=t&&a.isMergeable()?[1,a.getMergeableContent,a.getTransactionMergeableChanges,([[t],[a]])=>!Z(t)||!Z(a),a.setDefaultContent]:2!=t?[0,a.getContent,a.getTransactionChanges,([t,a])=>!Z(t)||!Z(a),a.setContent]:v("Store type not supported by this Persister"))(r,t),[I,D,R]=(()=>{let t;const[a,e]=(()=>{const t=[];let a=0;return[e=>(e?N(t):null)??n+a++,a=>{ut.test(a)&&d(t)<1e3&&A(t,a)}]})(),s=et();return[(e,i,o,r=[],c=()=>[])=>{t??=Y;const l=a(1);return it(s,l,[e,i,o,r,c]),lt(rt(i,o??[n],ct),l),l},(a,e,...i)=>f(((t,a=[n])=>{const e=[],s=(t,n)=>n==d(a)?A(e,t):null===a[n]?U(t,(t=>s(t,n+1))):f([a[n],null],(a=>s(nt(t,a),n+1)));return s(t,0),e})(a,e),(a=>U(a,(a=>nt(s,a)[0](t,...e??[],...i))))),t=>l(nt(s,t),(([,a,i])=>(rt(a,i??[n],void 0,(a=>(q(a,t),j(a)?1:0))),it(s,t),e(t),i))),a=>l(nt(s,a),(([a,,e=[],n,s])=>{const i=(...o)=>{const r=d(o);r==d(e)?a(t,...o,...s(o)):c(e[r])?f(n[r]?.(...o)??[],(t=>i(...o,t))):i(...o,e[r])};i()}))]})(),M=t=>{t!=h&&(h=t,D($,void 0,h))},P=a=>{(b&&y(a?.[0])?1===a?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===a?.[2]?t.applyChanges:t.setContent)(a)},_=async t=>(2!=h&&(M(1),m++,await J((async()=>{try{const t=await a();y(t)?P(t):v("Content is not an array "+t)}catch(a){o?.(a),t&&O(t)}M(0)}))),Y),F=()=>(g&&(i(g),g=void 0),Y),x=async t=>(1!=h&&(M(2),T++,await J((async()=>{try{await e(S,t)}catch(t){o?.(t)}M(0)}))),Y),B=()=>(l(E,t.delListener),E=void 0,Y),J=async(...t)=>(A(nt(wt,w),...t),await(async()=>{if(!nt(yt,w)){for(it(yt,w,1);!c(p=N(nt(wt,w)));)try{await p()}catch(t){o?.(t)}it(yt,w,0)}})(),Y),Y={load:_,startAutoLoad:async t=>{await F().load(t);try{g=await s((async(t,a)=>{a||t?2!=h&&(M(1),m++,P(a??t),M(0)):await _()}))}catch(t){o?.(t)}return Y},stopAutoLoad:F,isAutoLoading:()=>!c(g),save:x,startAutoSave:async()=>(await B().save(),E=t.addDidFinishTransactionListener((()=>{const t=C();L(t)&&x(t)})),Y),stopAutoSave:B,isAutoSaving:()=>!c(E),getStatus:()=>h,addStatusListener:t=>I(t,$),delListener:a=>(R(a),t),schedule:J,getStore:()=>t,destroy:()=>(nt(wt,w).splice(0,void 0),F().stopAutoSave()),getStats:()=>({loads:m,saves:T}),...u};return G(Y)},pt=(t,a,e,n,i,o=vt,r,l)=>{const u=et();return[async()=>{u.clear(),E(await e(t,a),(({tn:t,cn:a})=>lt(ot(u,t,ct),a)))},async(a,e)=>((t,a)=>x(nt(u,t),a))(a,e)?H(m(E(await t(I+_(a)),(t=>{return[t[e],l?(a=Q(t,e),n=l,H(V(a,((t,a)=>[a,n(t,a)])))):Q(t,e)];var a,n})),(([t,a])=>!c(t)&&!Z(a)))):{},async(a,e,n,l,y,w=!1)=>{const d=ct();V(n??{},(t=>E(z(t??{}),(t=>lt(d,t)))));const v=B(d);if(!w&&y&&h(v)&&x(u,a))return await t("DROP "+C+_(a)),void it(u,a);const f=nt(u,a),N=ct(B(f));if(h(v)||(x(u,a)?await p(E([e,...v],(async(n,s)=>{q(N,n)||(await t(L+_(a)+"ADD"+_(n)+i),0==s&&await t("CREATE UNIQUE INDEX pk ON "+_(a)+`(${_(e)})`),lt(f,n))}))):(await t("CREATE "+C+_(a)+`(${_(e)}${i} PRIMARY KEY${g(E(v,(t=>s+_(t)+i)))});`),it(u,a,ct([e,...v])))),await p([...!w&&l?E(B(N),(async n=>{n!=e&&(await t(L+_(a)+"DROP"+_(n)),q(f,n))})):[]]),w)c(n)?await t(O+_(a)+S+" true"):await p(V(n,(async(n,s)=>{c(n)?await t(O+_(a)+S+_(e)+"=$1",[s]):h(v)||await o(t,a,e,z(n),{[s]:r?E(W(n),r):W(n)},f)})));else if(h(v))x(u,a)&&await t(O+_(a)+S+" true");else{const s=m(B(nt(u,a)),(t=>t!=e)),i={},c=[];V(n??{},((t,a)=>{i[a]=E(s,(a=>r?r(t?.[a]):t?.[a])),A(c,a)})),await o(t,a,e,s,i),await t(O+_(a)+S+_(e)+`NOT IN(${F(c)})`,c)}},async a=>{let e;await t("BEGIN");try{e=await a()}catch(t){n?.(t)}return await t("END"),e}]},vt=async(t,a,e,n,i)=>{const o=[1];await t("INSERT INTO"+_(a)+"("+((...t)=>g(E(t,_),s))(e,...n)+")VALUES"+g(V(i,(t=>"($"+o[0]+++","+F(t,o)+")")),s)+"ON CONFLICT("+_(e)+")DO UPDATE SET"+g(E(n,(t=>_(t)+"=excluded."+_(t))),s),V(i,((t,a)=>[a,...E(t,(t=>t??null))])).flat())},ft=(t,a,e,n,s,i,o,[r,c,l],u,y,w,d,p,v)=>{const[f,g,E,h]=pt(a,u,y,s,p,v),m=dt(t,(async()=>await h((async()=>{return await f(),t=(await g(r,c))[T]?.[l]??"null",at(t,((t,a)=>""===a?void 0:a));var t}))),(async t=>await h((async()=>{var a;await f(),await E(r,c,{[T]:{[l]:(a=t()??null,tt(a,((t,a)=>void 0===a?"":a)))}},!0,!0)}))),e,n,s,o,{[d]:()=>w,destroy:()=>(m.stopAutoLoad().stopAutoSave(),i(),m)},w);return m},gt=(t,a,e,n,s,i,o,[r,l,[u,y,w]],d,v,f,g,E,h,A,N)=>{const[b,S,C,L]=pt(a,d,v,s,E,h,A,N),O=async(t,a)=>await p(st(l,(async([e,n,s,i],o)=>{a&&!(o in t)||await C(e,n,t[o],s,i,a)}))),I=async(t,a)=>y?await C(w,$,{[T]:t},!0,!0,a):null,D=dt(t,(async()=>await L((async()=>{await b();const t=await(async()=>H(m(await p(st(r,(async([t,a],e)=>[t,await S(e,a)]))),(t=>!Z(t[1])))))(),a=await(async()=>u?(await S(w,$))[T]:{})();return Z(t)&&c(a)?void 0:[t,a]}))),(async(t,a)=>await L((async()=>{if(await b(),c(a)){const[a,e]=t();await O(a),await I(e)}else await O(a[0],!0),await I(a[1],!0)}))),e,n,s,o,{[g]:()=>f,destroy:()=>(D.stopAutoLoad().stopAutoSave(),i(),D)},f);return D},Et="ColumnName",ht="store",mt="json",At=ht+"TableName",Nt=ht+"Id"+Et,Tt=ht+Et,$t="autoLoadIntervalSeconds",bt="rowId"+Et,St="tableId",Ct="tableName",Lt="deleteEmptyColumns",Ot="deleteEmptyTable",It={mode:mt,[$t]:1},Dt={load:0,save:0,[Ct]:e+"_values"},Rt=(t,a,e,n,s)=>{const i=et();return V(t,((t,o)=>{const r=w(W(K(a,u(t)?{[e]:t}:t)),0,X(a));c(r[0])||n(o,r[0])||(s(o,r[0]),it(i,o,r))})),i},Mt=(t,a,s,i,o,c,l,y,d,p,v="getDb",f)=>{let g,E,h;const m=((t,a)=>a?async(e,n)=>(a(e,n),await t(e,n)):t)(s,c),[A,N,T,C]=(t=>{const a=(t=>K(It,u(t)?{[At]:t}:t??{}))(t),n=a[$t];if(a.mode==mt){const t=a[At]??e;return[1,n,[t,a[Nt]??$,a[Tt]??ht],ct(t)]}const{tables:{load:s={},save:i={}}={},values:o={}}=a,r=w(W(K(Dt,o)),0,X(Dt)),c=r[2],l=ct(c),y=ct(c);return[0,n,[Rt(s,{[St]:null,[bt]:$},St,(t=>x(y,t)),(t=>lt(l,t))),Rt(i,{[Ct]:null,[bt]:$,[Lt]:0,[Ot]:0},Ct,((t,a)=>x(y,a)),((t,a)=>lt(l,a))),r],l]})(a);return(A?ft:gt)(t,m,(t=>{let a;const e=()=>a=setInterval((async()=>{try{const[{d:a,s:e,c:n}]=await m(`${b} ${R} d,${M} s,TOTAL_CHANGES() c FROM ${D}${R} JOIN ${D}${M}`);a==g&&e==E&&n==h||(null!=g&&t(),g=a,E=e,h=n)}catch{}}),1e3*N),n=()=>{g=E=h=null,r(a)},s=i((a=>{C.has(a)&&(n(),t(),e())}));return e(),()=>{n(),o(s)}}),(t=>t()),l,y,d,T,B(C),(async(t,a)=>await t(`${b} t.name tn,c.name cn FROM ${P}list()t,${P}info(t.name)c ${S} t.schema='main'AND t.type IN('table','view')AND t.name IN(${F(a)})ORDER BY t.name,c.name`,a)),p,v,n,f,(t=>!0===t?1:!1===t?0:t),void 0)};t.createLibSqlPersister=(t,a,e,n,s)=>Mt(t,e,(async(t,e=[])=>(await a.execute({sql:t,args:e})).rows),(()=>()=>0),(t=>t()),n,s,(()=>0),1,a,"getClient")},"object"==typeof exports&&"undefined"!=typeof module?a(exports):"function"==typeof define&&define.amd?define(["exports"],a):a((t="undefined"!=typeof globalThis?globalThis:t||self).TinyBasePersisterLibsql={});
1
+ var t,a;t=this,a=function(t){"use strict";const a=t=>typeof t,e="tinybase",n="",s=",",i=a(n),o=Promise,r=clearInterval,c=t=>null==t,l=(t,a,e)=>c(t)?e?.():a(t),u=t=>a(t)==i,y=t=>Array.isArray(t),w=(t,a,e)=>t.slice(a,e),d=t=>t.length,p=async t=>o.all(t),v=t=>{throw Error(t)},f=(t,a)=>t.forEach(a),g=(t,a="")=>t.join(a),E=(t,a)=>t.map(a),h=t=>0==d(t),m=(t,a)=>t.filter(a),A=(t,...a)=>t.push(...a),N=t=>t.shift(),T="_",$="_id",b="SELECT",S="WHERE",C="TABLE",L="ALTER "+C,O="DELETE FROM",I=b+"*FROM",D="pragma_",R="data_version",M="schema_version",P="pragma_table_",_=t=>`"${t.replace(/"/g,'""')}"`,F=(t,a=[1])=>g(E(t,(()=>"$"+a[0]++)),s),x=(t,a)=>t?.has(a)??!1,j=t=>c(t)||0==(t=>t?.size??0)(t),B=t=>[...t?.values()??[]],U=(t,a)=>t?.forEach(a),q=(t,a)=>t?.delete(a),J=Object,Y=t=>J.getPrototypeOf(t),k=J.entries,z=J.keys,G=J.freeze,H=(t=[])=>J.fromEntries(t),K=(...t)=>J.assign({},...t),Q=(t,a)=>(delete t[a],t),V=(t,a)=>E(k(t),(([t,e])=>a(e,t))),W=t=>J.values(t),X=t=>d(z(t)),Z=t=>(t=>!c(t)&&l(Y(t),(t=>t==J.prototype||c(Y(t))),(()=>!0)))(t)&&0==X(t),tt=JSON.stringify,at=JSON.parse,et=t=>new Map(t),nt=(t,a)=>t?.get(a),st=(t,a)=>E([...t?.entries()??[]],(([t,e])=>a(e,t))),it=(t,a,e)=>c(e)?(q(t,a),t):t?.set(a,e),ot=(t,a,e,n)=>(x(t,a)?n?.(nt(t,a)):it(t,a,e()),nt(t,a)),rt=(t,a,e,n,s=0)=>l((e?ot:nt)(t,a[s],s>d(a)-2?e:et),(i=>{if(s>d(a)-2)return n?.(i)&&it(t,a[s]),i;const o=rt(i,a,e,n,s+1);return j(i)&&it(t,a[s]),o})),ct=t=>new Set(y(t)||c(t)?t:[t]),lt=(t,a)=>t?.add(a),ut=/^\d+$/,yt=et(),wt=et(),dt=(t,a,e,s,i,o,r,u={},w=[])=>{let p,g,E,h=0,m=0,T=0;ot(yt,w,(()=>0)),ot(wt,w,(()=>[]));const $=et(),[b,S,C,L,O]=((t=1,a)=>1!=t&&a.isMergeable()?[1,a.getMergeableContent,a.getTransactionMergeableChanges,([[t],[a]])=>!Z(t)||!Z(a),a.setDefaultContent]:2!=t?[0,a.getContent,a.getTransactionChanges,([t,a])=>!Z(t)||!Z(a),a.setContent]:v("Store type not supported by this Persister"))(r,t),[I,D,R]=(()=>{let t;const[a,e]=(()=>{const t=[];let a=0;return[e=>(e?N(t):null)??n+a++,a=>{ut.test(a)&&d(t)<1e3&&A(t,a)}]})(),s=et();return[(e,i,o,r=[],c=()=>[])=>{t??=Y;const l=a(1);return it(s,l,[e,i,o,r,c]),lt(rt(i,o??[n],ct),l),l},(a,e,...i)=>f(((t,a=[n])=>{const e=[],s=(t,n)=>n==d(a)?A(e,t):null===a[n]?U(t,(t=>s(t,n+1))):f([a[n],null],(a=>s(nt(t,a),n+1)));return s(t,0),e})(a,e),(a=>U(a,(a=>nt(s,a)[0](t,...e??[],...i))))),t=>l(nt(s,t),(([,a,i])=>(rt(a,i??[n],void 0,(a=>(q(a,t),j(a)?1:0))),it(s,t),e(t),i))),a=>l(nt(s,a),(([a,,e=[],n,s])=>{const i=(...o)=>{const r=d(o);r==d(e)?a(t,...o,...s(o)):c(e[r])?f(n[r]?.(...o)??[],(t=>i(...o,t))):i(...o,e[r])};i()}))]})(),M=t=>{t!=h&&(h=t,D($,void 0,h))},P=a=>{(b&&y(a?.[0])?1===a?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===a?.[2]?t.applyChanges:t.setContent)(a)},_=async t=>(2!=h&&(M(1),m++,await J((async()=>{try{const e=await a();y(e)?P(e):t?O(t):v("Content is not an array "+e)}catch(a){o?.(a),t&&O(t)}M(0)}))),Y),F=()=>(g&&(i(g),g=void 0),Y),x=async t=>(1!=h&&(M(2),T++,await J((async()=>{try{await e(S,t)}catch(t){o?.(t)}M(0)}))),Y),B=()=>(l(E,t.delListener),E=void 0,Y),J=async(...t)=>(A(nt(wt,w),...t),await(async()=>{if(!nt(yt,w)){for(it(yt,w,1);!c(p=N(nt(wt,w)));)try{await p()}catch(t){o?.(t)}it(yt,w,0)}})(),Y),Y={load:_,startAutoLoad:async t=>{await F().load(t);try{g=await s((async(t,a)=>{a||t?2!=h&&(M(1),m++,P(a??t),M(0)):await _()}))}catch(t){o?.(t)}return Y},stopAutoLoad:F,isAutoLoading:()=>!c(g),save:x,startAutoSave:async()=>(await B().save(),E=t.addDidFinishTransactionListener((()=>{const t=C();L(t)&&x(t)})),Y),stopAutoSave:B,isAutoSaving:()=>!c(E),getStatus:()=>h,addStatusListener:t=>I(t,$),delListener:a=>(R(a),t),schedule:J,getStore:()=>t,destroy:()=>(nt(wt,w).splice(0,void 0),F().stopAutoSave()),getStats:()=>({loads:m,saves:T}),...u};return G(Y)},pt=(t,a,e,n,i,o=vt,r,l)=>{const u=et();return[async()=>{u.clear(),E(await e(t,a),(({tn:t,cn:a})=>lt(ot(u,t,ct),a)))},async(a,e)=>((t,a)=>x(nt(u,t),a))(a,e)?H(m(E(await t(I+_(a)),(t=>{return[t[e],l?(a=Q(t,e),n=l,H(V(a,((t,a)=>[a,n(t,a)])))):Q(t,e)];var a,n})),(([t,a])=>!c(t)&&!Z(a)))):{},async(a,e,n,l,y,w=!1)=>{const d=ct();V(n??{},(t=>E(z(t??{}),(t=>lt(d,t)))));const v=B(d);if(!w&&y&&h(v)&&x(u,a))return await t("DROP "+C+_(a)),void it(u,a);const f=nt(u,a),N=ct(B(f));if(h(v)||(x(u,a)?await p(E([e,...v],(async(n,s)=>{q(N,n)||(await t(L+_(a)+"ADD"+_(n)+i),0==s&&await t("CREATE UNIQUE INDEX pk ON "+_(a)+`(${_(e)})`),lt(f,n))}))):(await t("CREATE "+C+_(a)+`(${_(e)}${i} PRIMARY KEY${g(E(v,(t=>s+_(t)+i)))});`),it(u,a,ct([e,...v])))),await p([...!w&&l?E(B(N),(async n=>{n!=e&&(await t(L+_(a)+"DROP"+_(n)),q(f,n))})):[]]),w)c(n)?await t(O+_(a)+S+" true"):await p(V(n,(async(n,s)=>{c(n)?await t(O+_(a)+S+_(e)+"=$1",[s]):h(v)||await o(t,a,e,z(n),{[s]:r?E(W(n),r):W(n)},f)})));else if(h(v))x(u,a)&&await t(O+_(a)+S+" true");else{const s=m(B(nt(u,a)),(t=>t!=e)),i={},c=[];V(n??{},((t,a)=>{i[a]=E(s,(a=>r?r(t?.[a]):t?.[a])),A(c,a)})),await o(t,a,e,s,i),await t(O+_(a)+S+_(e)+`NOT IN(${F(c)})`,c)}},async a=>{let e;await t("BEGIN");try{e=await a()}catch(t){n?.(t)}return await t("END"),e}]},vt=async(t,a,e,n,i)=>{const o=[1];await t("INSERT INTO"+_(a)+"("+((...t)=>g(E(t,_),s))(e,...n)+")VALUES"+g(V(i,(t=>"($"+o[0]+++","+F(t,o)+")")),s)+"ON CONFLICT("+_(e)+")DO UPDATE SET"+g(E(n,(t=>_(t)+"=excluded."+_(t))),s),V(i,((t,a)=>[a,...E(t,(t=>t??null))])).flat())},ft=(t,a,e,n,s,i,o,[r,c,l],u,y,w,d,p,v)=>{const[f,g,E,h]=pt(a,u,y,s,p,v),m=dt(t,(async()=>await h((async()=>{return await f(),t=(await g(r,c))[T]?.[l]??"null",at(t,((t,a)=>""===a?void 0:a));var t}))),(async t=>await h((async()=>{var a;await f(),await E(r,c,{[T]:{[l]:(a=t()??null,tt(a,((t,a)=>void 0===a?"":a)))}},!0,!0)}))),e,n,s,o,{[d]:()=>w,destroy:()=>(m.stopAutoLoad().stopAutoSave(),i(),m)},w);return m},gt=(t,a,e,n,s,i,o,[r,l,[u,y,w]],d,v,f,g,E,h,A,N)=>{const[b,S,C,L]=pt(a,d,v,s,E,h,A,N),O=async(t,a)=>await p(st(l,(async([e,n,s,i],o)=>{a&&!(o in t)||await C(e,n,t[o],s,i,a)}))),I=async(t,a)=>y?await C(w,$,{[T]:t},!0,!0,a):null,D=dt(t,(async()=>await L((async()=>{await b();const t=await(async()=>H(m(await p(st(r,(async([t,a],e)=>[t,await S(e,a)]))),(t=>!Z(t[1])))))(),a=await(async()=>u?(await S(w,$))[T]:{})();return Z(t)&&c(a)?void 0:[t,a]}))),(async(t,a)=>await L((async()=>{if(await b(),c(a)){const[a,e]=t();await O(a),await I(e)}else await O(a[0],!0),await I(a[1],!0)}))),e,n,s,o,{[g]:()=>f,destroy:()=>(D.stopAutoLoad().stopAutoSave(),i(),D)},f);return D},Et="ColumnName",ht="store",mt="json",At=ht+"TableName",Nt=ht+"Id"+Et,Tt=ht+Et,$t="autoLoadIntervalSeconds",bt="rowId"+Et,St="tableId",Ct="tableName",Lt="deleteEmptyColumns",Ot="deleteEmptyTable",It={mode:mt,[$t]:1},Dt={load:0,save:0,[Ct]:e+"_values"},Rt=(t,a,e,n,s)=>{const i=et();return V(t,((t,o)=>{const r=w(W(K(a,u(t)?{[e]:t}:t)),0,X(a));c(r[0])||n(o,r[0])||(s(o,r[0]),it(i,o,r))})),i},Mt=(t,a,s,i,o,c,l,y,d,p,v="getDb",f)=>{let g,E,h;const m=((t,a)=>a?async(e,n)=>(a(e,n),await t(e,n)):t)(s,c),[A,N,T,C]=(t=>{const a=(t=>K(It,u(t)?{[At]:t}:t??{}))(t),n=a[$t];if(a.mode==mt){const t=a[At]??e;return[1,n,[t,a[Nt]??$,a[Tt]??ht],ct(t)]}const{tables:{load:s={},save:i={}}={},values:o={}}=a,r=w(W(K(Dt,o)),0,X(Dt)),c=r[2],l=ct(c),y=ct(c);return[0,n,[Rt(s,{[St]:null,[bt]:$},St,(t=>x(y,t)),(t=>lt(l,t))),Rt(i,{[Ct]:null,[bt]:$,[Lt]:0,[Ot]:0},Ct,((t,a)=>x(y,a)),((t,a)=>lt(l,a))),r],l]})(a);return(A?ft:gt)(t,m,(t=>{let a;const e=()=>a=setInterval((async()=>{try{const[{d:a,s:e,c:n}]=await m(`${b} ${R} d,${M} s,TOTAL_CHANGES() c FROM ${D}${R} JOIN ${D}${M}`);a==g&&e==E&&n==h||(null!=g&&t(),g=a,E=e,h=n)}catch{}}),1e3*N),n=()=>{g=E=h=null,r(a)},s=i((a=>{C.has(a)&&(n(),t(),e())}));return e(),()=>{n(),o(s)}}),(t=>t()),l,y,d,T,B(C),(async(t,a)=>await t(`${b} t.name tn,c.name cn FROM ${P}list()t,${P}info(t.name)c ${S} t.schema='main'AND t.type IN('table','view')AND t.name IN(${F(a)})ORDER BY t.name,c.name`,a)),p,v,n,f,(t=>!0===t?1:!1===t?0:t),void 0)};t.createLibSqlPersister=(t,a,e,n,s)=>Mt(t,e,(async(t,e=[])=>(await a.execute({sql:t,args:e})).rows),(()=>()=>0),(t=>t()),n,s,(()=>0),1,a,"getClient")},"object"==typeof exports&&"undefined"!=typeof module?a(exports):"function"==typeof define&&define.amd?define(["exports"],a):a((t="undefined"!=typeof globalThis?globalThis:t||self).TinyBasePersisterLibsql={});
@@ -1 +1 @@
1
- var t,e;t=this,e=function(t){"use strict";const e=t=>typeof t,a="",s=e(a),n=t=>null==t,o=(t,e,a)=>n(t)?a?.():e(t),r=t=>e(t)==s,i=t=>Array.isArray(t),c=t=>t.length,d=t=>{throw Error(t)},l=(t,e)=>t.forEach(e),y=(t,...e)=>t.push(...e),u=t=>t.shift(),p=Object,h=t=>p.getPrototypeOf(t),f=p.keys,g=p.freeze,v=t=>(t=>!n(t)&&o(h(t),(t=>t==p.prototype||n(h(t))),(()=>!0)))(t)&&0==(t=>c(f(t)))(t),w=JSON.stringify,C=JSON.parse,S=t=>w(t,((t,e)=>e instanceof Map?p.fromEntries([...e]):e)),b="/store",P=t=>n(t)||0==(t=>t?.size??0)(t),m=(t,e)=>t?.forEach(e),A=(t,e)=>t?.delete(e),L=t=>new Map(t),M=(t,e)=>t?.get(e),T=(t,e,a)=>n(a)?(A(t,e),t):t?.set(e,a),E=(t,e,a,s)=>{var n,o;return n=t,o=e,n?.has(o)?s?.(M(t,e)):T(t,e,a()),M(t,e)},O=(t,e,a,s,n=0)=>o((a?E:M)(t,e[n],n>c(e)-2?a:L),(o=>{if(n>c(e)-2)return s?.(o)&&T(t,e[n]),o;const r=O(o,e,a,s,n+1);return P(o)&&T(t,e[n]),r})),x=t=>new Set(i(t)||n(t)?t:[t]),j=/^\d+$/,k=L(),z=L(),D=(t,e,s,r,p,h,f,w={},C=[])=>{let S,b,D,J=0,K=0,N=0;E(k,C,(()=>0)),E(z,C,(()=>[]));const B=L(),[F,U,W,$,q]=((t=1,e)=>1!=t&&e.isMergeable()?[1,e.getMergeableContent,e.getTransactionMergeableChanges,([[t],[e]])=>!v(t)||!v(e),e.setDefaultContent]:2!=t?[0,e.getContent,e.getTransactionChanges,([t,e])=>!v(t)||!v(e),e.setContent]:d("Store type not supported by this Persister"))(f,t),[G,H,I]=(()=>{let t;const[e,s]=(()=>{const t=[];let e=0;return[s=>(s?u(t):null)??a+e++,e=>{j.test(e)&&c(t)<1e3&&y(t,e)}]})(),r=L();return[(s,n,o,i=[],c=()=>[])=>{t??=tt;const d=e(1);var l,y;return T(r,d,[s,n,o,i,c]),l=O(n,o??[a],x),y=d,l?.add(y),d},(e,s,...n)=>l(((t,e=[a])=>{const s=[],n=(t,a)=>a==c(e)?y(s,t):null===e[a]?m(t,(t=>n(t,a+1))):l([e[a],null],(e=>n(M(t,e),a+1)));return n(t,0),s})(e,s),(e=>m(e,(e=>M(r,e)[0](t,...s??[],...n))))),t=>o(M(r,t),(([,e,n])=>(O(e,n??[a],void 0,(e=>(A(e,t),P(e)?1:0))),T(r,t),s(t),n))),e=>o(M(r,e),(([e,,a=[],s,o])=>{const r=(...i)=>{const d=c(i);d==c(a)?e(t,...i,...o(i)):n(a[d])?l(s[d]?.(...i)??[],(t=>r(...i,t))):r(...i,a[d])};r()}))]})(),Q=t=>{t!=J&&(J=t,H(B,void 0,J))},R=e=>{(F&&i(e?.[0])?1===e?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===e?.[2]?t.applyChanges:t.setContent)(e)},V=async t=>(2!=J&&(Q(1),K++,await _((async()=>{try{const t=await e();i(t)?R(t):d("Content is not an array "+t)}catch(e){h?.(e),t&&q(t)}Q(0)}))),tt),X=()=>(b&&(p(b),b=void 0),tt),Y=async t=>(1!=J&&(Q(2),N++,await _((async()=>{try{await s(U,t)}catch(t){h?.(t)}Q(0)}))),tt),Z=()=>(o(D,t.delListener),D=void 0,tt),_=async(...t)=>(y(M(z,C),...t),await(async()=>{if(!M(k,C)){for(T(k,C,1);!n(S=u(M(z,C)));)try{await S()}catch(t){h?.(t)}T(k,C,0)}})(),tt),tt={load:V,startAutoLoad:async t=>{await X().load(t);try{b=await r((async(t,e)=>{e||t?2!=J&&(Q(1),K++,R(e??t),Q(0)):await V()}))}catch(t){h?.(t)}return tt},stopAutoLoad:X,isAutoLoading:()=>!n(b),save:Y,startAutoSave:async()=>(await Z().save(),D=t.addDidFinishTransactionListener((()=>{const t=W();$(t)&&Y(t)})),tt),stopAutoSave:Z,isAutoSaving:()=>!n(D),getStatus:()=>J,addStatusListener:t=>G(t,B),delListener:e=>(I(e),t),schedule:_,getStore:()=>t,destroy:()=>(M(z,C).splice(0,void 0),X().stopAutoSave()),getStats:()=>({loads:K,saves:N}),...w};return g(tt)},J="message";t.createPartyKitPersister=(t,e,s,n)=>{const{host:i,room:d}=e.partySocketOptions,{storeProtocol:l="https",storePath:y=b,messagePrefix:u=a}={...r(s)?{storeProtocol:s}:s},p=l+"://"+i+"/parties/"+e.name+"/"+d+y,h=async t=>await(await fetch(p,{...t?{method:"PUT",body:S(t)}:{},mode:"cors",cache:"no-store"})).json();return D(t,(async()=>await h()),(async(t,a)=>{var s;a?e.send(u+"s"+(r(s=a)?s:S(s))):await h(t())}),(t=>{const a=e=>o(((t,e)=>{const a=c(t);return((t,e)=>t.startsWith(e))(e,t)?[e[a],C((s=e,n=a+1,s.slice(n,void 0)))]:void 0;var s,n})(u,e.data),(([e,a])=>{"s"==e&&t(void 0,a)}));return e.addEventListener(J,a),a}),(t=>{e.removeEventListener(J,t)}),n,1,{getConnection:()=>e})}},"object"==typeof exports&&"undefined"!=typeof module?e(exports):"function"==typeof define&&define.amd?define(["exports"],e):e((t="undefined"!=typeof globalThis?globalThis:t||self).TinyBasePersisterPartyKitClient={});
1
+ var t,e;t=this,e=function(t){"use strict";const e=t=>typeof t,a="",s=e(a),n=t=>null==t,o=(t,e,a)=>n(t)?a?.():e(t),r=t=>e(t)==s,i=t=>Array.isArray(t),c=t=>t.length,d=t=>{throw Error(t)},l=(t,e)=>t.forEach(e),y=(t,...e)=>t.push(...e),u=t=>t.shift(),p=Object,h=t=>p.getPrototypeOf(t),f=p.keys,g=p.freeze,v=t=>(t=>!n(t)&&o(h(t),(t=>t==p.prototype||n(h(t))),(()=>!0)))(t)&&0==(t=>c(f(t)))(t),w=JSON.stringify,C=JSON.parse,S=t=>w(t,((t,e)=>e instanceof Map?p.fromEntries([...e]):e)),b="/store",P=t=>n(t)||0==(t=>t?.size??0)(t),m=(t,e)=>t?.forEach(e),A=(t,e)=>t?.delete(e),L=t=>new Map(t),M=(t,e)=>t?.get(e),T=(t,e,a)=>n(a)?(A(t,e),t):t?.set(e,a),E=(t,e,a,s)=>{var n,o;return n=t,o=e,n?.has(o)?s?.(M(t,e)):T(t,e,a()),M(t,e)},O=(t,e,a,s,n=0)=>o((a?E:M)(t,e[n],n>c(e)-2?a:L),(o=>{if(n>c(e)-2)return s?.(o)&&T(t,e[n]),o;const r=O(o,e,a,s,n+1);return P(o)&&T(t,e[n]),r})),x=t=>new Set(i(t)||n(t)?t:[t]),j=/^\d+$/,k=L(),z=L(),D=(t,e,s,r,p,h,f,w={},C=[])=>{let S,b,D,J=0,K=0,N=0;E(k,C,(()=>0)),E(z,C,(()=>[]));const B=L(),[F,U,W,$,q]=((t=1,e)=>1!=t&&e.isMergeable()?[1,e.getMergeableContent,e.getTransactionMergeableChanges,([[t],[e]])=>!v(t)||!v(e),e.setDefaultContent]:2!=t?[0,e.getContent,e.getTransactionChanges,([t,e])=>!v(t)||!v(e),e.setContent]:d("Store type not supported by this Persister"))(f,t),[G,H,I]=(()=>{let t;const[e,s]=(()=>{const t=[];let e=0;return[s=>(s?u(t):null)??a+e++,e=>{j.test(e)&&c(t)<1e3&&y(t,e)}]})(),r=L();return[(s,n,o,i=[],c=()=>[])=>{t??=tt;const d=e(1);var l,y;return T(r,d,[s,n,o,i,c]),l=O(n,o??[a],x),y=d,l?.add(y),d},(e,s,...n)=>l(((t,e=[a])=>{const s=[],n=(t,a)=>a==c(e)?y(s,t):null===e[a]?m(t,(t=>n(t,a+1))):l([e[a],null],(e=>n(M(t,e),a+1)));return n(t,0),s})(e,s),(e=>m(e,(e=>M(r,e)[0](t,...s??[],...n))))),t=>o(M(r,t),(([,e,n])=>(O(e,n??[a],void 0,(e=>(A(e,t),P(e)?1:0))),T(r,t),s(t),n))),e=>o(M(r,e),(([e,,a=[],s,o])=>{const r=(...i)=>{const d=c(i);d==c(a)?e(t,...i,...o(i)):n(a[d])?l(s[d]?.(...i)??[],(t=>r(...i,t))):r(...i,a[d])};r()}))]})(),Q=t=>{t!=J&&(J=t,H(B,void 0,J))},R=e=>{(F&&i(e?.[0])?1===e?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===e?.[2]?t.applyChanges:t.setContent)(e)},V=async t=>(2!=J&&(Q(1),K++,await _((async()=>{try{const a=await e();i(a)?R(a):t?q(t):d("Content is not an array "+a)}catch(e){h?.(e),t&&q(t)}Q(0)}))),tt),X=()=>(b&&(p(b),b=void 0),tt),Y=async t=>(1!=J&&(Q(2),N++,await _((async()=>{try{await s(U,t)}catch(t){h?.(t)}Q(0)}))),tt),Z=()=>(o(D,t.delListener),D=void 0,tt),_=async(...t)=>(y(M(z,C),...t),await(async()=>{if(!M(k,C)){for(T(k,C,1);!n(S=u(M(z,C)));)try{await S()}catch(t){h?.(t)}T(k,C,0)}})(),tt),tt={load:V,startAutoLoad:async t=>{await X().load(t);try{b=await r((async(t,e)=>{e||t?2!=J&&(Q(1),K++,R(e??t),Q(0)):await V()}))}catch(t){h?.(t)}return tt},stopAutoLoad:X,isAutoLoading:()=>!n(b),save:Y,startAutoSave:async()=>(await Z().save(),D=t.addDidFinishTransactionListener((()=>{const t=W();$(t)&&Y(t)})),tt),stopAutoSave:Z,isAutoSaving:()=>!n(D),getStatus:()=>J,addStatusListener:t=>G(t,B),delListener:e=>(I(e),t),schedule:_,getStore:()=>t,destroy:()=>(M(z,C).splice(0,void 0),X().stopAutoSave()),getStats:()=>({loads:K,saves:N}),...w};return g(tt)},J="message";t.createPartyKitPersister=(t,e,s,n)=>{const{host:i,room:d}=e.partySocketOptions,{storeProtocol:l="https",storePath:y=b,messagePrefix:u=a}={...r(s)?{storeProtocol:s}:s},p=l+"://"+i+"/parties/"+e.name+"/"+d+y,h=async t=>await(await fetch(p,{...t?{method:"PUT",body:S(t)}:{},mode:"cors",cache:"no-store"})).json();return D(t,(async()=>await h()),(async(t,a)=>{var s;a?e.send(u+"s"+(r(s=a)?s:S(s))):await h(t())}),(t=>{const a=e=>o(((t,e)=>{const a=c(t);return((t,e)=>t.startsWith(e))(e,t)?[e[a],C((s=e,n=a+1,s.slice(n,void 0)))]:void 0;var s,n})(u,e.data),(([e,a])=>{"s"==e&&t(void 0,a)}));return e.addEventListener(J,a),a}),(t=>{e.removeEventListener(J,t)}),n,1,{getConnection:()=>e})}},"object"==typeof exports&&"undefined"!=typeof module?e(exports):"function"==typeof define&&define.amd?define(["exports"],e):e((t="undefined"!=typeof globalThis?globalThis:t||self).TinyBasePersisterPartyKitClient={});
@@ -1 +1 @@
1
- var t,e;t=this,e=function(t){"use strict";const e=t=>typeof t,a="",s=e(a),n=t=>null==t,o=(t,e,a)=>n(t)?a?.():e(t),r=t=>e(t)==s,i=t=>Array.isArray(t),c=t=>t.length,d=t=>{throw Error(t)},l=(t,e)=>t.forEach(e),y=(t,...e)=>t.push(...e),u=t=>t.shift(),p=Object,h=t=>p.getPrototypeOf(t),f=p.keys,g=p.freeze,v=t=>(t=>!n(t)&&o(h(t),(t=>t==p.prototype||n(h(t))),(()=>!0)))(t)&&0==(t=>c(f(t)))(t),w=JSON.stringify,C=JSON.parse,S=t=>w(t,((t,e)=>e instanceof Map?p.fromEntries([...e]):e)),b="/store",P=t=>n(t)||0==(t=>t?.size??0)(t),m=(t,e)=>t?.forEach(e),A=(t,e)=>t?.delete(e),L=t=>new Map(t),M=(t,e)=>t?.get(e),T=(t,e,a)=>n(a)?(A(t,e),t):t?.set(e,a),E=(t,e,a,s)=>{var n,o;return n=t,o=e,n?.has(o)?s?.(M(t,e)):T(t,e,a()),M(t,e)},O=(t,e,a,s,n=0)=>o((a?E:M)(t,e[n],n>c(e)-2?a:L),(o=>{if(n>c(e)-2)return s?.(o)&&T(t,e[n]),o;const r=O(o,e,a,s,n+1);return P(o)&&T(t,e[n]),r})),x=t=>new Set(i(t)||n(t)?t:[t]),j=/^\d+$/,k=L(),z=L(),D=(t,e,s,r,p,h,f,w={},C=[])=>{let S,b,D,J=0,K=0,N=0;E(k,C,(()=>0)),E(z,C,(()=>[]));const B=L(),[F,U,W,$,q]=((t=1,e)=>1!=t&&e.isMergeable()?[1,e.getMergeableContent,e.getTransactionMergeableChanges,([[t],[e]])=>!v(t)||!v(e),e.setDefaultContent]:2!=t?[0,e.getContent,e.getTransactionChanges,([t,e])=>!v(t)||!v(e),e.setContent]:d("Store type not supported by this Persister"))(f,t),[G,H,I]=(()=>{let t;const[e,s]=(()=>{const t=[];let e=0;return[s=>(s?u(t):null)??a+e++,e=>{j.test(e)&&c(t)<1e3&&y(t,e)}]})(),r=L();return[(s,n,o,i=[],c=()=>[])=>{t??=tt;const d=e(1);var l,y;return T(r,d,[s,n,o,i,c]),l=O(n,o??[a],x),y=d,l?.add(y),d},(e,s,...n)=>l(((t,e=[a])=>{const s=[],n=(t,a)=>a==c(e)?y(s,t):null===e[a]?m(t,(t=>n(t,a+1))):l([e[a],null],(e=>n(M(t,e),a+1)));return n(t,0),s})(e,s),(e=>m(e,(e=>M(r,e)[0](t,...s??[],...n))))),t=>o(M(r,t),(([,e,n])=>(O(e,n??[a],void 0,(e=>(A(e,t),P(e)?1:0))),T(r,t),s(t),n))),e=>o(M(r,e),(([e,,a=[],s,o])=>{const r=(...i)=>{const d=c(i);d==c(a)?e(t,...i,...o(i)):n(a[d])?l(s[d]?.(...i)??[],(t=>r(...i,t))):r(...i,a[d])};r()}))]})(),Q=t=>{t!=J&&(J=t,H(B,void 0,J))},R=e=>{(F&&i(e?.[0])?1===e?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===e?.[2]?t.applyChanges:t.setContent)(e)},V=async t=>(2!=J&&(Q(1),K++,await _((async()=>{try{const t=await e();i(t)?R(t):d("Content is not an array "+t)}catch(e){h?.(e),t&&q(t)}Q(0)}))),tt),X=()=>(b&&(p(b),b=void 0),tt),Y=async t=>(1!=J&&(Q(2),N++,await _((async()=>{try{await s(U,t)}catch(t){h?.(t)}Q(0)}))),tt),Z=()=>(o(D,t.delListener),D=void 0,tt),_=async(...t)=>(y(M(z,C),...t),await(async()=>{if(!M(k,C)){for(T(k,C,1);!n(S=u(M(z,C)));)try{await S()}catch(t){h?.(t)}T(k,C,0)}})(),tt),tt={load:V,startAutoLoad:async t=>{await X().load(t);try{b=await r((async(t,e)=>{e||t?2!=J&&(Q(1),K++,R(e??t),Q(0)):await V()}))}catch(t){h?.(t)}return tt},stopAutoLoad:X,isAutoLoading:()=>!n(b),save:Y,startAutoSave:async()=>(await Z().save(),D=t.addDidFinishTransactionListener((()=>{const t=W();$(t)&&Y(t)})),tt),stopAutoSave:Z,isAutoSaving:()=>!n(D),getStatus:()=>J,addStatusListener:t=>G(t,B),delListener:e=>(I(e),t),schedule:_,getStore:()=>t,destroy:()=>(M(z,C).splice(0,void 0),X().stopAutoSave()),getStats:()=>({loads:K,saves:N}),...w};return g(tt)},J="message";t.createPartyKitPersister=(t,e,s,n)=>{const{host:i,room:d}=e.partySocketOptions,{storeProtocol:l="https",storePath:y=b,messagePrefix:u=a}={...r(s)?{storeProtocol:s}:s},p=l+"://"+i+"/parties/"+e.name+"/"+d+y,h=async t=>await(await fetch(p,{...t?{method:"PUT",body:S(t)}:{},mode:"cors",cache:"no-store"})).json();return D(t,(async()=>await h()),(async(t,a)=>{var s;a?e.send(u+"s"+(r(s=a)?s:S(s))):await h(t())}),(t=>{const a=e=>o(((t,e)=>{const a=c(t);return((t,e)=>t.startsWith(e))(e,t)?[e[a],C((s=e,n=a+1,s.slice(n,void 0)))]:void 0;var s,n})(u,e.data),(([e,a])=>{"s"==e&&t(void 0,a)}));return e.addEventListener(J,a),a}),(t=>{e.removeEventListener(J,t)}),n,1,{getConnection:()=>e})}},"object"==typeof exports&&"undefined"!=typeof module?e(exports):"function"==typeof define&&define.amd?define(["exports"],e):e((t="undefined"!=typeof globalThis?globalThis:t||self).TinyBasePersisterPartyKitClient={});
1
+ var t,e;t=this,e=function(t){"use strict";const e=t=>typeof t,a="",s=e(a),n=t=>null==t,o=(t,e,a)=>n(t)?a?.():e(t),r=t=>e(t)==s,i=t=>Array.isArray(t),c=t=>t.length,d=t=>{throw Error(t)},l=(t,e)=>t.forEach(e),y=(t,...e)=>t.push(...e),u=t=>t.shift(),p=Object,h=t=>p.getPrototypeOf(t),f=p.keys,g=p.freeze,v=t=>(t=>!n(t)&&o(h(t),(t=>t==p.prototype||n(h(t))),(()=>!0)))(t)&&0==(t=>c(f(t)))(t),w=JSON.stringify,C=JSON.parse,S=t=>w(t,((t,e)=>e instanceof Map?p.fromEntries([...e]):e)),b="/store",P=t=>n(t)||0==(t=>t?.size??0)(t),m=(t,e)=>t?.forEach(e),A=(t,e)=>t?.delete(e),L=t=>new Map(t),M=(t,e)=>t?.get(e),T=(t,e,a)=>n(a)?(A(t,e),t):t?.set(e,a),E=(t,e,a,s)=>{var n,o;return n=t,o=e,n?.has(o)?s?.(M(t,e)):T(t,e,a()),M(t,e)},O=(t,e,a,s,n=0)=>o((a?E:M)(t,e[n],n>c(e)-2?a:L),(o=>{if(n>c(e)-2)return s?.(o)&&T(t,e[n]),o;const r=O(o,e,a,s,n+1);return P(o)&&T(t,e[n]),r})),x=t=>new Set(i(t)||n(t)?t:[t]),j=/^\d+$/,k=L(),z=L(),D=(t,e,s,r,p,h,f,w={},C=[])=>{let S,b,D,J=0,K=0,N=0;E(k,C,(()=>0)),E(z,C,(()=>[]));const B=L(),[F,U,W,$,q]=((t=1,e)=>1!=t&&e.isMergeable()?[1,e.getMergeableContent,e.getTransactionMergeableChanges,([[t],[e]])=>!v(t)||!v(e),e.setDefaultContent]:2!=t?[0,e.getContent,e.getTransactionChanges,([t,e])=>!v(t)||!v(e),e.setContent]:d("Store type not supported by this Persister"))(f,t),[G,H,I]=(()=>{let t;const[e,s]=(()=>{const t=[];let e=0;return[s=>(s?u(t):null)??a+e++,e=>{j.test(e)&&c(t)<1e3&&y(t,e)}]})(),r=L();return[(s,n,o,i=[],c=()=>[])=>{t??=tt;const d=e(1);var l,y;return T(r,d,[s,n,o,i,c]),l=O(n,o??[a],x),y=d,l?.add(y),d},(e,s,...n)=>l(((t,e=[a])=>{const s=[],n=(t,a)=>a==c(e)?y(s,t):null===e[a]?m(t,(t=>n(t,a+1))):l([e[a],null],(e=>n(M(t,e),a+1)));return n(t,0),s})(e,s),(e=>m(e,(e=>M(r,e)[0](t,...s??[],...n))))),t=>o(M(r,t),(([,e,n])=>(O(e,n??[a],void 0,(e=>(A(e,t),P(e)?1:0))),T(r,t),s(t),n))),e=>o(M(r,e),(([e,,a=[],s,o])=>{const r=(...i)=>{const d=c(i);d==c(a)?e(t,...i,...o(i)):n(a[d])?l(s[d]?.(...i)??[],(t=>r(...i,t))):r(...i,a[d])};r()}))]})(),Q=t=>{t!=J&&(J=t,H(B,void 0,J))},R=e=>{(F&&i(e?.[0])?1===e?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===e?.[2]?t.applyChanges:t.setContent)(e)},V=async t=>(2!=J&&(Q(1),K++,await _((async()=>{try{const a=await e();i(a)?R(a):t?q(t):d("Content is not an array "+a)}catch(e){h?.(e),t&&q(t)}Q(0)}))),tt),X=()=>(b&&(p(b),b=void 0),tt),Y=async t=>(1!=J&&(Q(2),N++,await _((async()=>{try{await s(U,t)}catch(t){h?.(t)}Q(0)}))),tt),Z=()=>(o(D,t.delListener),D=void 0,tt),_=async(...t)=>(y(M(z,C),...t),await(async()=>{if(!M(k,C)){for(T(k,C,1);!n(S=u(M(z,C)));)try{await S()}catch(t){h?.(t)}T(k,C,0)}})(),tt),tt={load:V,startAutoLoad:async t=>{await X().load(t);try{b=await r((async(t,e)=>{e||t?2!=J&&(Q(1),K++,R(e??t),Q(0)):await V()}))}catch(t){h?.(t)}return tt},stopAutoLoad:X,isAutoLoading:()=>!n(b),save:Y,startAutoSave:async()=>(await Z().save(),D=t.addDidFinishTransactionListener((()=>{const t=W();$(t)&&Y(t)})),tt),stopAutoSave:Z,isAutoSaving:()=>!n(D),getStatus:()=>J,addStatusListener:t=>G(t,B),delListener:e=>(I(e),t),schedule:_,getStore:()=>t,destroy:()=>(M(z,C).splice(0,void 0),X().stopAutoSave()),getStats:()=>({loads:K,saves:N}),...w};return g(tt)},J="message";t.createPartyKitPersister=(t,e,s,n)=>{const{host:i,room:d}=e.partySocketOptions,{storeProtocol:l="https",storePath:y=b,messagePrefix:u=a}={...r(s)?{storeProtocol:s}:s},p=l+"://"+i+"/parties/"+e.name+"/"+d+y,h=async t=>await(await fetch(p,{...t?{method:"PUT",body:S(t)}:{},mode:"cors",cache:"no-store"})).json();return D(t,(async()=>await h()),(async(t,a)=>{var s;a?e.send(u+"s"+(r(s=a)?s:S(s))):await h(t())}),(t=>{const a=e=>o(((t,e)=>{const a=c(t);return((t,e)=>t.startsWith(e))(e,t)?[e[a],C((s=e,n=a+1,s.slice(n,void 0)))]:void 0;var s,n})(u,e.data),(([e,a])=>{"s"==e&&t(void 0,a)}));return e.addEventListener(J,a),a}),(t=>{e.removeEventListener(J,t)}),n,1,{getConnection:()=>e})}},"object"==typeof exports&&"undefined"!=typeof module?e(exports):"function"==typeof define&&define.amd?define(["exports"],e):e((t="undefined"!=typeof globalThis?globalThis:t||self).TinyBasePersisterPartyKitClient={});
@@ -1 +1 @@
1
- var t,a;t=this,a=function(t){"use strict";const a=t=>typeof t,e="tinybase",n=",",s=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
+ var t,a;t=this,a=function(t){"use strict";const a=t=>typeof t,e="tinybase",n=",",s=a(""),i=Promise,o=t=>null==t,r=(t,a,e)=>o(t)?e?.():a(t),c=t=>a(t)==s,l=t=>Array.isArray(t),E=(t,a,e)=>t.slice(a,e),y=t=>t.length,w=async t=>i.all(t),d=t=>{throw Error(t)},u=(t,a)=>t.forEach(a),T=(t,a="")=>t.join(a),R=(t,a)=>t.map(a),A=t=>0==y(t),N=(t,a)=>t.filter(a),g=(t,...a)=>t.push(...a),p=t=>t.shift(),C="_",O="_id",f="SELECT",v="WHERE",L="TABLE",$="ALTER "+L,m="DELETE FROM",I=f+"*FROM",S=t=>`"${t.replace(/"/g,'""')}"`,h=(t,a=[1])=>T(R(t,(()=>"$"+a[0]++)),n),_=(t,a)=>t?.has(a)??!1,b=t=>o(t)||0==(t=>t?.size??0)(t),P=t=>[...t?.values()??[]],D=(t,a)=>t?.forEach(a),U=(t,a)=>t?.delete(a),F=Object,M=t=>F.getPrototypeOf(t),G=F.entries,B=F.keys,j=F.freeze,x=(t=[])=>F.fromEntries(t),X=(...t)=>F.assign({},...t),Y=(t,a)=>(delete t[a],t),q=(t,a)=>R(G(t),(([t,e])=>a(e,t))),H=t=>F.values(t),W=t=>y(B(t)),k=t=>(t=>!o(t)&&r(M(t),(t=>t==F.prototype||o(M(t))),(()=>!0)))(t)&&0==W(t),z=JSON.stringify,J=JSON.parse,K=t=>new Map(t),V=(t,a)=>t?.get(a),Q=(t,a)=>R([...t?.entries()??[]],(([t,e])=>a(e,t))),Z=(t,a,e)=>o(e)?(U(t,a),t):t?.set(a,e),tt=(t,a,e,n)=>(_(t,a)?n?.(V(t,a)):Z(t,a,e()),V(t,a)),at=(t,a,e,n,s=0)=>r((e?tt:V)(t,a[s],s>y(a)-2?e:K),(i=>{if(s>y(a)-2)return n?.(i)&&Z(t,a[s]),i;const o=at(i,a,e,n,s+1);return b(i)&&Z(t,a[s]),o})),et=t=>new Set(l(t)||o(t)?t:[t]),nt=(t,a)=>t?.add(a),st=/^\d+$/,it=K(),ot=K(),rt=(t,a,e,n,s,i,c,E={},w=[])=>{let T,R,A,N=0,C=0,O=0;tt(it,w,(()=>0)),tt(ot,w,(()=>[]));const f=K(),[v,L,$,m,I]=((t=1,a)=>1!=t&&a.isMergeable()?[1,a.getMergeableContent,a.getTransactionMergeableChanges,([[t],[a]])=>!k(t)||!k(a),a.setDefaultContent]:2!=t?[0,a.getContent,a.getTransactionChanges,([t,a])=>!k(t)||!k(a),a.setContent]:d("Store type not supported by this Persister"))(c,t),[S,h,_]=(()=>{let t;const[a,e]=(()=>{const t=[];let a=0;return[e=>(e?p(t):null)??""+a++,a=>{st.test(a)&&y(t)<1e3&&g(t,a)}]})(),n=K();return[(e,s,i,o=[],r=()=>[])=>{t??=Y;const c=a(1);return Z(n,c,[e,s,i,o,r]),nt(at(s,i??[""],et),c),c},(a,e,...s)=>u(((t,a=[""])=>{const e=[],n=(t,s)=>s==y(a)?g(e,t):null===a[s]?D(t,(t=>n(t,s+1))):u([a[s],null],(a=>n(V(t,a),s+1)));return n(t,0),e})(a,e),(a=>D(a,(a=>V(n,a)[0](t,...e??[],...s))))),t=>r(V(n,t),(([,a,s])=>(at(a,s??[""],void 0,(a=>(U(a,t),b(a)?1:0))),Z(n,t),e(t),s))),a=>r(V(n,a),(([a,,e=[],n,s])=>{const i=(...r)=>{const c=y(r);c==y(e)?a(t,...r,...s(r)):o(e[c])?u(n[c]?.(...r)??[],(t=>i(...r,t))):i(...r,e[c])};i()}))]})(),P=t=>{t!=N&&(N=t,h(f,void 0,N))},F=a=>{(v&&l(a?.[0])?1===a?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===a?.[2]?t.applyChanges:t.setContent)(a)},M=async t=>(2!=N&&(P(1),C++,await X((async()=>{try{const e=await a();l(e)?F(e):t?I(t):d("Content is not an array "+e)}catch(a){i?.(a),t&&I(t)}P(0)}))),Y),G=()=>(R&&(s(R),R=void 0),Y),B=async t=>(1!=N&&(P(2),O++,await X((async()=>{try{await e(L,t)}catch(t){i?.(t)}P(0)}))),Y),x=()=>(r(A,t.delListener),A=void 0,Y),X=async(...t)=>(g(V(ot,w),...t),await(async()=>{if(!V(it,w)){for(Z(it,w,1);!o(T=p(V(ot,w)));)try{await T()}catch(t){i?.(t)}Z(it,w,0)}})(),Y),Y={load:M,startAutoLoad:async t=>{await G().load(t);try{R=await n((async(t,a)=>{a||t?2!=N&&(P(1),C++,F(a??t),P(0)):await M()}))}catch(t){i?.(t)}return Y},stopAutoLoad:G,isAutoLoading:()=>!o(R),save:B,startAutoSave:async()=>(await x().save(),A=t.addDidFinishTransactionListener((()=>{const t=$();m(t)&&B(t)})),Y),stopAutoSave:x,isAutoSaving:()=>!o(A),getStatus:()=>N,addStatusListener:t=>S(t,f),delListener:a=>(_(a),t),schedule:X,getStore:()=>t,destroy:()=>(V(ot,w).splice(0,void 0),G().stopAutoSave()),getStats:()=>({loads:C,saves:O}),...E};return j(Y)},ct=(t,a,e,s,i,r=lt,c,l)=>{const E=K();return[async()=>{E.clear(),R(await e(t,a),(({tn:t,cn:a})=>nt(tt(E,t,et),a)))},async(a,e)=>((t,a)=>_(V(E,t),a))(a,e)?x(N(R(await t(I+S(a)),(t=>{return[t[e],l?(a=Y(t,e),n=l,x(q(a,((t,a)=>[a,n(t,a)])))):Y(t,e)];var a,n})),(([t,a])=>!o(t)&&!k(a)))):{},async(a,e,s,l,y,d=!1)=>{const u=et();q(s??{},(t=>R(B(t??{}),(t=>nt(u,t)))));const p=P(u);if(!d&&y&&A(p)&&_(E,a))return await t("DROP "+L+S(a)),void Z(E,a);const C=V(E,a),O=et(P(C));if(A(p)||(_(E,a)?await w(R([e,...p],(async(n,s)=>{U(O,n)||(await t($+S(a)+"ADD"+S(n)+i),0==s&&await t("CREATE UNIQUE INDEX pk ON "+S(a)+`(${S(e)})`),nt(C,n))}))):(await t("CREATE "+L+S(a)+`(${S(e)}${i} PRIMARY KEY${T(R(p,(t=>n+S(t)+i)))});`),Z(E,a,et([e,...p])))),await w([...!d&&l?R(P(O),(async n=>{n!=e&&(await t($+S(a)+"DROP"+S(n)),U(C,n))})):[]]),d)o(s)?await t(m+S(a)+v+" true"):await w(q(s,(async(n,s)=>{o(n)?await t(m+S(a)+v+S(e)+"=$1",[s]):A(p)||await r(t,a,e,B(n),{[s]:c?R(H(n),c):H(n)},C)})));else if(A(p))_(E,a)&&await t(m+S(a)+v+" true");else{const n=N(P(V(E,a)),(t=>t!=e)),i={},o=[];q(s??{},((t,a)=>{i[a]=R(n,(a=>c?c(t?.[a]):t?.[a])),g(o,a)})),await r(t,a,e,n,i),await t(m+S(a)+v+S(e)+`NOT IN(${h(o)})`,o)}},async a=>{let e;await t("BEGIN");try{e=await a()}catch(t){s?.(t)}return await t("END"),e}]},lt=async(t,a,e,s,i)=>{const o=[1];await t("INSERT INTO"+S(a)+"("+((...t)=>T(R(t,S),n))(e,...s)+")VALUES"+T(q(i,(t=>"($"+o[0]+++","+h(t,o)+")")),n)+"ON CONFLICT("+S(e)+")DO UPDATE SET"+T(R(s,(t=>S(t)+"=excluded."+S(t))),n),q(i,((t,a)=>[a,...R(t,(t=>t??null))])).flat())},Et=(t,a,e,n,s,i,o,[r,c,l],E,y,w,d,u,T)=>{const[R,A,N,g]=ct(a,E,y,s,u,T),p=rt(t,(async()=>await g((async()=>{return await R(),t=(await A(r,c))[C]?.[l]??"null",J(t,((t,a)=>""===a?void 0:a));var t}))),(async t=>await g((async()=>{var a;await R(),await N(r,c,{[C]:{[l]:(a=t()??null,z(a,((t,a)=>void 0===a?"":a)))}},!0,!0)}))),e,n,s,o,{[d]:()=>w,destroy:()=>(p.stopAutoLoad().stopAutoSave(),i(),p)},w);return p},yt=(t,a,e,n,s,i,r,[c,l,[E,y,d]],u,T,R,A,g,p,f,v)=>{const[L,$,m,I]=ct(a,u,T,s,g,p,f,v),S=async(t,a)=>await w(Q(l,(async([e,n,s,i],o)=>{a&&!(o in t)||await m(e,n,t[o],s,i,a)}))),h=async(t,a)=>y?await m(d,O,{[C]:t},!0,!0,a):null,_=rt(t,(async()=>await I((async()=>{await L();const t=await(async()=>x(N(await w(Q(c,(async([t,a],e)=>[t,await $(e,a)]))),(t=>!k(t[1])))))(),a=await(async()=>E?(await $(d,O))[C]:{})();return k(t)&&o(a)?void 0:[t,a]}))),(async(t,a)=>await I((async()=>{if(await L(),o(a)){const[a,e]=t();await S(a),await h(e)}else await S(a[0],!0),await h(a[1],!0)}))),e,n,s,r,{[A]:()=>R,destroy:()=>(_.stopAutoLoad().stopAutoSave(),i(),_)},R);return _},wt="ColumnName",dt="store",ut="json",Tt=dt+"TableName",Rt=dt+"Id"+wt,At=dt+wt,Nt="autoLoadIntervalSeconds",gt="rowId"+wt,pt="tableId",Ct="tableName",Ot="deleteEmptyColumns",ft="deleteEmptyTable",vt={mode:ut,[Nt]:1},Lt={load:0,save:0,[Ct]:e+"_values"},$t=(t,a,e,n,s)=>{const i=K();return q(t,((t,r)=>{const l=E(H(X(a,c(t)?{[e]:t}:t)),0,W(a));o(l[0])||n(r,l[0])||(s(r,l[0]),Z(i,r,l))})),i},mt=e,It=/^([cd]:)(.+)/,St=e+"_data",ht=e+"_table";t.createPglitePersister=async(t,a,n,s,i)=>((t,a,n,s,i,o,l,y,d,u,T="getDb")=>{const A=((t,a)=>a?async(e,n)=>(a(e,n),await t(e,n)):t)(n,o),[N,,g,p]=(t=>{const a=(t=>X(vt,c(t)?{[Tt]:t}:t??{}))(t),n=a[Nt];if(a.mode==ut){const t=a[Tt]??e;return[1,n,[t,a[Rt]??O,a[At]??dt],et(t)]}const{tables:{load:s={},save:i={}}={},values:o={}}=a,r=E(H(X(Lt,o)),0,W(Lt)),l=r[2],y=et(l),w=et(l);return[0,n,[$t(s,{[pt]:null,[gt]:O},pt,(t=>_(w,t)),(t=>nt(y,t))),$t(i,{[Ct]:null,[gt]:O,[Ot]:0,[ft]:0},Ct,((t,a)=>_(w,a)),((t,a)=>nt(y,a))),r],y]})(a),C=async t=>{await A(`CREATE OR REPLACE TRIGGER ${S(St+"_"+t)} AFTER INSERT OR UPDATE OR DELETE ON ${S(t)} EXECUTE FUNCTION ${St}()`)};return(N?Et:yt)(t,A,(async t=>{await A(`CREATE OR REPLACE FUNCTION ${ht}()RETURNS event_trigger AS $t2$ DECLARE row record; BEGIN FOR row IN SELECT object_identity FROM pg_event_trigger_ddl_commands()WHERE command_tag='CREATE TABLE' LOOP PERFORM pg_notify('${mt}','c:'||SPLIT_PART(row.object_identity,'.',2));END LOOP;END;$t2$ LANGUAGE plpgsql;`);try{await A(`CREATE EVENT TRIGGER ${ht} ON ddl_command_end WHEN TAG IN('CREATE TABLE')EXECUTE FUNCTION ${ht}();`)}catch{}return await A(`CREATE OR REPLACE FUNCTION ${St}()RETURNS trigger AS $t1$ BEGIN PERFORM pg_notify('${mt}','d:'||TG_TABLE_NAME);RETURN NULL;END;$t1$ LANGUAGE plpgsql;`),await w(R(P(p),(async t=>{await A(`CREATE TABLE IF NOT EXISTS ${S(t)}("_id"text PRIMARY KEY)`),await C(t)}))),await s(mt,(async a=>{return await r((e=a,n=It,e?.match(n)),(async([,a,e])=>{_(p,e)&&("c:"==a&&await C(e),t())}));var e,n}))}),i,l,y,d,g,P(p),(async(t,a)=>await t(`${f} table_name tn,column_name cn FROM information_schema.columns ${v} table_schema='public'AND table_name IN(${h(a)})`,a)),u,T,"text",void 0,(t=>z(t)),(t=>J(t)))})(t,n,(async(t,e=[])=>(await a.query(t,e)).rows),(async(t,e)=>await a.listen(t,e)),(async t=>{try{await t()}catch(t){i?.(t)}}),s,i,(()=>0),3,a,"getPglite")},"object"==typeof exports&&"undefined"!=typeof module?a(exports):"function"==typeof define&&define.amd?define(["exports"],a):a((t="undefined"!=typeof globalThis?globalThis:t||self).TinyBasePersisterPglite={});
@@ -1 +1 @@
1
- var t,a;t=this,a=function(t){"use strict";const a=t=>typeof t,e="tinybase",n=",",s=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
+ var t,a;t=this,a=function(t){"use strict";const a=t=>typeof t,e="tinybase",n=",",s=a(""),i=Promise,o=t=>null==t,r=(t,a,e)=>o(t)?e?.():a(t),c=t=>a(t)==s,l=t=>Array.isArray(t),E=(t,a,e)=>t.slice(a,e),y=t=>t.length,w=async t=>i.all(t),d=t=>{throw Error(t)},u=(t,a)=>t.forEach(a),T=(t,a="")=>t.join(a),R=(t,a)=>t.map(a),A=t=>0==y(t),N=(t,a)=>t.filter(a),g=(t,...a)=>t.push(...a),p=t=>t.shift(),C="_",O="_id",f="SELECT",v="WHERE",L="TABLE",$="ALTER "+L,m="DELETE FROM",I=f+"*FROM",S=t=>`"${t.replace(/"/g,'""')}"`,h=(t,a=[1])=>T(R(t,(()=>"$"+a[0]++)),n),_=(t,a)=>t?.has(a)??!1,b=t=>o(t)||0==(t=>t?.size??0)(t),P=t=>[...t?.values()??[]],D=(t,a)=>t?.forEach(a),U=(t,a)=>t?.delete(a),F=Object,M=t=>F.getPrototypeOf(t),G=F.entries,B=F.keys,j=F.freeze,x=(t=[])=>F.fromEntries(t),X=(...t)=>F.assign({},...t),Y=(t,a)=>(delete t[a],t),q=(t,a)=>R(G(t),(([t,e])=>a(e,t))),H=t=>F.values(t),W=t=>y(B(t)),k=t=>(t=>!o(t)&&r(M(t),(t=>t==F.prototype||o(M(t))),(()=>!0)))(t)&&0==W(t),z=JSON.stringify,J=JSON.parse,K=t=>new Map(t),V=(t,a)=>t?.get(a),Q=(t,a)=>R([...t?.entries()??[]],(([t,e])=>a(e,t))),Z=(t,a,e)=>o(e)?(U(t,a),t):t?.set(a,e),tt=(t,a,e,n)=>(_(t,a)?n?.(V(t,a)):Z(t,a,e()),V(t,a)),at=(t,a,e,n,s=0)=>r((e?tt:V)(t,a[s],s>y(a)-2?e:K),(i=>{if(s>y(a)-2)return n?.(i)&&Z(t,a[s]),i;const o=at(i,a,e,n,s+1);return b(i)&&Z(t,a[s]),o})),et=t=>new Set(l(t)||o(t)?t:[t]),nt=(t,a)=>t?.add(a),st=/^\d+$/,it=K(),ot=K(),rt=(t,a,e,n,s,i,c,E={},w=[])=>{let T,R,A,N=0,C=0,O=0;tt(it,w,(()=>0)),tt(ot,w,(()=>[]));const f=K(),[v,L,$,m,I]=((t=1,a)=>1!=t&&a.isMergeable()?[1,a.getMergeableContent,a.getTransactionMergeableChanges,([[t],[a]])=>!k(t)||!k(a),a.setDefaultContent]:2!=t?[0,a.getContent,a.getTransactionChanges,([t,a])=>!k(t)||!k(a),a.setContent]:d("Store type not supported by this Persister"))(c,t),[S,h,_]=(()=>{let t;const[a,e]=(()=>{const t=[];let a=0;return[e=>(e?p(t):null)??""+a++,a=>{st.test(a)&&y(t)<1e3&&g(t,a)}]})(),n=K();return[(e,s,i,o=[],r=()=>[])=>{t??=Y;const c=a(1);return Z(n,c,[e,s,i,o,r]),nt(at(s,i??[""],et),c),c},(a,e,...s)=>u(((t,a=[""])=>{const e=[],n=(t,s)=>s==y(a)?g(e,t):null===a[s]?D(t,(t=>n(t,s+1))):u([a[s],null],(a=>n(V(t,a),s+1)));return n(t,0),e})(a,e),(a=>D(a,(a=>V(n,a)[0](t,...e??[],...s))))),t=>r(V(n,t),(([,a,s])=>(at(a,s??[""],void 0,(a=>(U(a,t),b(a)?1:0))),Z(n,t),e(t),s))),a=>r(V(n,a),(([a,,e=[],n,s])=>{const i=(...r)=>{const c=y(r);c==y(e)?a(t,...r,...s(r)):o(e[c])?u(n[c]?.(...r)??[],(t=>i(...r,t))):i(...r,e[c])};i()}))]})(),P=t=>{t!=N&&(N=t,h(f,void 0,N))},F=a=>{(v&&l(a?.[0])?1===a?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===a?.[2]?t.applyChanges:t.setContent)(a)},M=async t=>(2!=N&&(P(1),C++,await X((async()=>{try{const e=await a();l(e)?F(e):t?I(t):d("Content is not an array "+e)}catch(a){i?.(a),t&&I(t)}P(0)}))),Y),G=()=>(R&&(s(R),R=void 0),Y),B=async t=>(1!=N&&(P(2),O++,await X((async()=>{try{await e(L,t)}catch(t){i?.(t)}P(0)}))),Y),x=()=>(r(A,t.delListener),A=void 0,Y),X=async(...t)=>(g(V(ot,w),...t),await(async()=>{if(!V(it,w)){for(Z(it,w,1);!o(T=p(V(ot,w)));)try{await T()}catch(t){i?.(t)}Z(it,w,0)}})(),Y),Y={load:M,startAutoLoad:async t=>{await G().load(t);try{R=await n((async(t,a)=>{a||t?2!=N&&(P(1),C++,F(a??t),P(0)):await M()}))}catch(t){i?.(t)}return Y},stopAutoLoad:G,isAutoLoading:()=>!o(R),save:B,startAutoSave:async()=>(await x().save(),A=t.addDidFinishTransactionListener((()=>{const t=$();m(t)&&B(t)})),Y),stopAutoSave:x,isAutoSaving:()=>!o(A),getStatus:()=>N,addStatusListener:t=>S(t,f),delListener:a=>(_(a),t),schedule:X,getStore:()=>t,destroy:()=>(V(ot,w).splice(0,void 0),G().stopAutoSave()),getStats:()=>({loads:C,saves:O}),...E};return j(Y)},ct=(t,a,e,s,i,r=lt,c,l)=>{const E=K();return[async()=>{E.clear(),R(await e(t,a),(({tn:t,cn:a})=>nt(tt(E,t,et),a)))},async(a,e)=>((t,a)=>_(V(E,t),a))(a,e)?x(N(R(await t(I+S(a)),(t=>{return[t[e],l?(a=Y(t,e),n=l,x(q(a,((t,a)=>[a,n(t,a)])))):Y(t,e)];var a,n})),(([t,a])=>!o(t)&&!k(a)))):{},async(a,e,s,l,y,d=!1)=>{const u=et();q(s??{},(t=>R(B(t??{}),(t=>nt(u,t)))));const p=P(u);if(!d&&y&&A(p)&&_(E,a))return await t("DROP "+L+S(a)),void Z(E,a);const C=V(E,a),O=et(P(C));if(A(p)||(_(E,a)?await w(R([e,...p],(async(n,s)=>{U(O,n)||(await t($+S(a)+"ADD"+S(n)+i),0==s&&await t("CREATE UNIQUE INDEX pk ON "+S(a)+`(${S(e)})`),nt(C,n))}))):(await t("CREATE "+L+S(a)+`(${S(e)}${i} PRIMARY KEY${T(R(p,(t=>n+S(t)+i)))});`),Z(E,a,et([e,...p])))),await w([...!d&&l?R(P(O),(async n=>{n!=e&&(await t($+S(a)+"DROP"+S(n)),U(C,n))})):[]]),d)o(s)?await t(m+S(a)+v+" true"):await w(q(s,(async(n,s)=>{o(n)?await t(m+S(a)+v+S(e)+"=$1",[s]):A(p)||await r(t,a,e,B(n),{[s]:c?R(H(n),c):H(n)},C)})));else if(A(p))_(E,a)&&await t(m+S(a)+v+" true");else{const n=N(P(V(E,a)),(t=>t!=e)),i={},o=[];q(s??{},((t,a)=>{i[a]=R(n,(a=>c?c(t?.[a]):t?.[a])),g(o,a)})),await r(t,a,e,n,i),await t(m+S(a)+v+S(e)+`NOT IN(${h(o)})`,o)}},async a=>{let e;await t("BEGIN");try{e=await a()}catch(t){s?.(t)}return await t("END"),e}]},lt=async(t,a,e,s,i)=>{const o=[1];await t("INSERT INTO"+S(a)+"("+((...t)=>T(R(t,S),n))(e,...s)+")VALUES"+T(q(i,(t=>"($"+o[0]+++","+h(t,o)+")")),n)+"ON CONFLICT("+S(e)+")DO UPDATE SET"+T(R(s,(t=>S(t)+"=excluded."+S(t))),n),q(i,((t,a)=>[a,...R(t,(t=>t??null))])).flat())},Et=(t,a,e,n,s,i,o,[r,c,l],E,y,w,d,u,T)=>{const[R,A,N,g]=ct(a,E,y,s,u,T),p=rt(t,(async()=>await g((async()=>{return await R(),t=(await A(r,c))[C]?.[l]??"null",J(t,((t,a)=>""===a?void 0:a));var t}))),(async t=>await g((async()=>{var a;await R(),await N(r,c,{[C]:{[l]:(a=t()??null,z(a,((t,a)=>void 0===a?"":a)))}},!0,!0)}))),e,n,s,o,{[d]:()=>w,destroy:()=>(p.stopAutoLoad().stopAutoSave(),i(),p)},w);return p},yt=(t,a,e,n,s,i,r,[c,l,[E,y,d]],u,T,R,A,g,p,f,v)=>{const[L,$,m,I]=ct(a,u,T,s,g,p,f,v),S=async(t,a)=>await w(Q(l,(async([e,n,s,i],o)=>{a&&!(o in t)||await m(e,n,t[o],s,i,a)}))),h=async(t,a)=>y?await m(d,O,{[C]:t},!0,!0,a):null,_=rt(t,(async()=>await I((async()=>{await L();const t=await(async()=>x(N(await w(Q(c,(async([t,a],e)=>[t,await $(e,a)]))),(t=>!k(t[1])))))(),a=await(async()=>E?(await $(d,O))[C]:{})();return k(t)&&o(a)?void 0:[t,a]}))),(async(t,a)=>await I((async()=>{if(await L(),o(a)){const[a,e]=t();await S(a),await h(e)}else await S(a[0],!0),await h(a[1],!0)}))),e,n,s,r,{[A]:()=>R,destroy:()=>(_.stopAutoLoad().stopAutoSave(),i(),_)},R);return _},wt="ColumnName",dt="store",ut="json",Tt=dt+"TableName",Rt=dt+"Id"+wt,At=dt+wt,Nt="autoLoadIntervalSeconds",gt="rowId"+wt,pt="tableId",Ct="tableName",Ot="deleteEmptyColumns",ft="deleteEmptyTable",vt={mode:ut,[Nt]:1},Lt={load:0,save:0,[Ct]:e+"_values"},$t=(t,a,e,n,s)=>{const i=K();return q(t,((t,r)=>{const l=E(H(X(a,c(t)?{[e]:t}:t)),0,W(a));o(l[0])||n(r,l[0])||(s(r,l[0]),Z(i,r,l))})),i},mt=e,It=/^([cd]:)(.+)/,St=e+"_data",ht=e+"_table";t.createPglitePersister=async(t,a,n,s,i)=>((t,a,n,s,i,o,l,y,d,u,T="getDb")=>{const A=((t,a)=>a?async(e,n)=>(a(e,n),await t(e,n)):t)(n,o),[N,,g,p]=(t=>{const a=(t=>X(vt,c(t)?{[Tt]:t}:t??{}))(t),n=a[Nt];if(a.mode==ut){const t=a[Tt]??e;return[1,n,[t,a[Rt]??O,a[At]??dt],et(t)]}const{tables:{load:s={},save:i={}}={},values:o={}}=a,r=E(H(X(Lt,o)),0,W(Lt)),l=r[2],y=et(l),w=et(l);return[0,n,[$t(s,{[pt]:null,[gt]:O},pt,(t=>_(w,t)),(t=>nt(y,t))),$t(i,{[Ct]:null,[gt]:O,[Ot]:0,[ft]:0},Ct,((t,a)=>_(w,a)),((t,a)=>nt(y,a))),r],y]})(a),C=async t=>{await A(`CREATE OR REPLACE TRIGGER ${S(St+"_"+t)} AFTER INSERT OR UPDATE OR DELETE ON ${S(t)} EXECUTE FUNCTION ${St}()`)};return(N?Et:yt)(t,A,(async t=>{await A(`CREATE OR REPLACE FUNCTION ${ht}()RETURNS event_trigger AS $t2$ DECLARE row record; BEGIN FOR row IN SELECT object_identity FROM pg_event_trigger_ddl_commands()WHERE command_tag='CREATE TABLE' LOOP PERFORM pg_notify('${mt}','c:'||SPLIT_PART(row.object_identity,'.',2));END LOOP;END;$t2$ LANGUAGE plpgsql;`);try{await A(`CREATE EVENT TRIGGER ${ht} ON ddl_command_end WHEN TAG IN('CREATE TABLE')EXECUTE FUNCTION ${ht}();`)}catch{}return await A(`CREATE OR REPLACE FUNCTION ${St}()RETURNS trigger AS $t1$ BEGIN PERFORM pg_notify('${mt}','d:'||TG_TABLE_NAME);RETURN NULL;END;$t1$ LANGUAGE plpgsql;`),await w(R(P(p),(async t=>{await A(`CREATE TABLE IF NOT EXISTS ${S(t)}("_id"text PRIMARY KEY)`),await C(t)}))),await s(mt,(async a=>{return await r((e=a,n=It,e?.match(n)),(async([,a,e])=>{_(p,e)&&("c:"==a&&await C(e),t())}));var e,n}))}),i,l,y,d,g,P(p),(async(t,a)=>await t(`${f} table_name tn,column_name cn FROM information_schema.columns ${v} table_schema='public'AND table_name IN(${h(a)})`,a)),u,T,"text",void 0,(t=>z(t)),(t=>J(t)))})(t,n,(async(t,e=[])=>(await a.query(t,e)).rows),(async(t,e)=>await a.listen(t,e)),(async t=>{try{await t()}catch(t){i?.(t)}}),s,i,(()=>0),3,a,"getPglite")},"object"==typeof exports&&"undefined"!=typeof module?a(exports):"function"==typeof define&&define.amd?define(["exports"],a):a((t="undefined"!=typeof globalThis?globalThis:t||self).TinyBasePersisterPglite={});
@@ -1 +1 @@
1
- var t,a;t=this,a=function(t){"use strict";const a=t=>typeof t,e="tinybase",n=",",s=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
+ var t,a;t=this,a=function(t){"use strict";const a=t=>typeof t,e="tinybase",n=",",s=a(""),i=Promise,o=t=>null==t,r=(t,a,e)=>o(t)?e?.():a(t),c=t=>a(t)==s,l=t=>Array.isArray(t),E=(t,a,e)=>t.slice(a,e),y=t=>t.length,d=async t=>i.all(t),w=t=>{throw Error(t)},u=(t,a)=>t.forEach(a),T=(t,a="")=>t.join(a),R=(t,a)=>t.map(a),A=t=>0==y(t),N=(t,a)=>t.filter(a),g=(t,...a)=>t.push(...a),p=t=>t.shift(),C="_",f="_id",O="SELECT",v="WHERE",L="TABLE",$="ALTER "+L,m="DELETE FROM",S=O+"*FROM",I=t=>`"${t.replace(/"/g,'""')}"`,h=(t,a=[1])=>T(R(t,(()=>"$"+a[0]++)),n),_=(t,a)=>t?.has(a)??!1,b=t=>o(t)||0==(t=>t?.size??0)(t),P=t=>[...t?.values()??[]],D=(t,a)=>t?.forEach(a),U=(t,a)=>t?.delete(a),F=Object,M=t=>F.getPrototypeOf(t),G=F.entries,B=F.keys,j=F.freeze,x=(t=[])=>F.fromEntries(t),X=(...t)=>F.assign({},...t),Y=(t,a)=>(delete t[a],t),q=(t,a)=>R(G(t),(([t,e])=>a(e,t))),H=t=>F.values(t),W=t=>y(B(t)),k=t=>(t=>!o(t)&&r(M(t),(t=>t==F.prototype||o(M(t))),(()=>!0)))(t)&&0==W(t),z=JSON.stringify,J=JSON.parse,K=t=>new Map(t),V=(t,a)=>t?.get(a),Q=(t,a)=>R([...t?.entries()??[]],(([t,e])=>a(e,t))),Z=(t,a,e)=>o(e)?(U(t,a),t):t?.set(a,e),tt=(t,a,e,n)=>(_(t,a)?n?.(V(t,a)):Z(t,a,e()),V(t,a)),at=(t,a,e,n,s=0)=>r((e?tt:V)(t,a[s],s>y(a)-2?e:K),(i=>{if(s>y(a)-2)return n?.(i)&&Z(t,a[s]),i;const o=at(i,a,e,n,s+1);return b(i)&&Z(t,a[s]),o})),et=t=>new Set(l(t)||o(t)?t:[t]),nt=(t,a)=>t?.add(a),st=/^\d+$/,it=K(),ot=K(),rt=(t,a,e,n,s,i,c,E={},d=[])=>{let T,R,A,N=0,C=0,f=0;tt(it,d,(()=>0)),tt(ot,d,(()=>[]));const O=K(),[v,L,$,m,S]=((t=1,a)=>1!=t&&a.isMergeable()?[1,a.getMergeableContent,a.getTransactionMergeableChanges,([[t],[a]])=>!k(t)||!k(a),a.setDefaultContent]:2!=t?[0,a.getContent,a.getTransactionChanges,([t,a])=>!k(t)||!k(a),a.setContent]:w("Store type not supported by this Persister"))(c,t),[I,h,_]=(()=>{let t;const[a,e]=(()=>{const t=[];let a=0;return[e=>(e?p(t):null)??""+a++,a=>{st.test(a)&&y(t)<1e3&&g(t,a)}]})(),n=K();return[(e,s,i,o=[],r=()=>[])=>{t??=Y;const c=a(1);return Z(n,c,[e,s,i,o,r]),nt(at(s,i??[""],et),c),c},(a,e,...s)=>u(((t,a=[""])=>{const e=[],n=(t,s)=>s==y(a)?g(e,t):null===a[s]?D(t,(t=>n(t,s+1))):u([a[s],null],(a=>n(V(t,a),s+1)));return n(t,0),e})(a,e),(a=>D(a,(a=>V(n,a)[0](t,...e??[],...s))))),t=>r(V(n,t),(([,a,s])=>(at(a,s??[""],void 0,(a=>(U(a,t),b(a)?1:0))),Z(n,t),e(t),s))),a=>r(V(n,a),(([a,,e=[],n,s])=>{const i=(...r)=>{const c=y(r);c==y(e)?a(t,...r,...s(r)):o(e[c])?u(n[c]?.(...r)??[],(t=>i(...r,t))):i(...r,e[c])};i()}))]})(),P=t=>{t!=N&&(N=t,h(O,void 0,N))},F=a=>{(v&&l(a?.[0])?1===a?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===a?.[2]?t.applyChanges:t.setContent)(a)},M=async t=>(2!=N&&(P(1),C++,await X((async()=>{try{const e=await a();l(e)?F(e):t?S(t):w("Content is not an array "+e)}catch(a){i?.(a),t&&S(t)}P(0)}))),Y),G=()=>(R&&(s(R),R=void 0),Y),B=async t=>(1!=N&&(P(2),f++,await X((async()=>{try{await e(L,t)}catch(t){i?.(t)}P(0)}))),Y),x=()=>(r(A,t.delListener),A=void 0,Y),X=async(...t)=>(g(V(ot,d),...t),await(async()=>{if(!V(it,d)){for(Z(it,d,1);!o(T=p(V(ot,d)));)try{await T()}catch(t){i?.(t)}Z(it,d,0)}})(),Y),Y={load:M,startAutoLoad:async t=>{await G().load(t);try{R=await n((async(t,a)=>{a||t?2!=N&&(P(1),C++,F(a??t),P(0)):await M()}))}catch(t){i?.(t)}return Y},stopAutoLoad:G,isAutoLoading:()=>!o(R),save:B,startAutoSave:async()=>(await x().save(),A=t.addDidFinishTransactionListener((()=>{const t=$();m(t)&&B(t)})),Y),stopAutoSave:x,isAutoSaving:()=>!o(A),getStatus:()=>N,addStatusListener:t=>I(t,O),delListener:a=>(_(a),t),schedule:X,getStore:()=>t,destroy:()=>(V(ot,d).splice(0,void 0),G().stopAutoSave()),getStats:()=>({loads:C,saves:f}),...E};return j(Y)},ct=(t,a,e,s,i,r=lt,c,l)=>{const E=K();return[async()=>{E.clear(),R(await e(t,a),(({tn:t,cn:a})=>nt(tt(E,t,et),a)))},async(a,e)=>((t,a)=>_(V(E,t),a))(a,e)?x(N(R(await t(S+I(a)),(t=>{return[t[e],l?(a=Y(t,e),n=l,x(q(a,((t,a)=>[a,n(t,a)])))):Y(t,e)];var a,n})),(([t,a])=>!o(t)&&!k(a)))):{},async(a,e,s,l,y,w=!1)=>{const u=et();q(s??{},(t=>R(B(t??{}),(t=>nt(u,t)))));const p=P(u);if(!w&&y&&A(p)&&_(E,a))return await t("DROP "+L+I(a)),void Z(E,a);const C=V(E,a),f=et(P(C));if(A(p)||(_(E,a)?await d(R([e,...p],(async(n,s)=>{U(f,n)||(await t($+I(a)+"ADD"+I(n)+i),0==s&&await t("CREATE UNIQUE INDEX pk ON "+I(a)+`(${I(e)})`),nt(C,n))}))):(await t("CREATE "+L+I(a)+`(${I(e)}${i} PRIMARY KEY${T(R(p,(t=>n+I(t)+i)))});`),Z(E,a,et([e,...p])))),await d([...!w&&l?R(P(f),(async n=>{n!=e&&(await t($+I(a)+"DROP"+I(n)),U(C,n))})):[]]),w)o(s)?await t(m+I(a)+v+" true"):await d(q(s,(async(n,s)=>{o(n)?await t(m+I(a)+v+I(e)+"=$1",[s]):A(p)||await r(t,a,e,B(n),{[s]:c?R(H(n),c):H(n)},C)})));else if(A(p))_(E,a)&&await t(m+I(a)+v+" true");else{const n=N(P(V(E,a)),(t=>t!=e)),i={},o=[];q(s??{},((t,a)=>{i[a]=R(n,(a=>c?c(t?.[a]):t?.[a])),g(o,a)})),await r(t,a,e,n,i),await t(m+I(a)+v+I(e)+`NOT IN(${h(o)})`,o)}},async a=>{let e;await t("BEGIN");try{e=await a()}catch(t){s?.(t)}return await t("END"),e}]},lt=async(t,a,e,s,i)=>{const o=[1];await t("INSERT INTO"+I(a)+"("+((...t)=>T(R(t,I),n))(e,...s)+")VALUES"+T(q(i,(t=>"($"+o[0]+++","+h(t,o)+")")),n)+"ON CONFLICT("+I(e)+")DO UPDATE SET"+T(R(s,(t=>I(t)+"=excluded."+I(t))),n),q(i,((t,a)=>[a,...R(t,(t=>t??null))])).flat())},Et=(t,a,e,n,s,i,o,[r,c,l],E,y,d,w,u,T)=>{const[R,A,N,g]=ct(a,E,y,s,u,T),p=rt(t,(async()=>await g((async()=>{return await R(),t=(await A(r,c))[C]?.[l]??"null",J(t,((t,a)=>""===a?void 0:a));var t}))),(async t=>await g((async()=>{var a;await R(),await N(r,c,{[C]:{[l]:(a=t()??null,z(a,((t,a)=>void 0===a?"":a)))}},!0,!0)}))),e,n,s,o,{[w]:()=>d,destroy:()=>(p.stopAutoLoad().stopAutoSave(),i(),p)},d);return p},yt=(t,a,e,n,s,i,r,[c,l,[E,y,w]],u,T,R,A,g,p,O,v)=>{const[L,$,m,S]=ct(a,u,T,s,g,p,O,v),I=async(t,a)=>await d(Q(l,(async([e,n,s,i],o)=>{a&&!(o in t)||await m(e,n,t[o],s,i,a)}))),h=async(t,a)=>y?await m(w,f,{[C]:t},!0,!0,a):null,_=rt(t,(async()=>await S((async()=>{await L();const t=await(async()=>x(N(await d(Q(c,(async([t,a],e)=>[t,await $(e,a)]))),(t=>!k(t[1])))))(),a=await(async()=>E?(await $(w,f))[C]:{})();return k(t)&&o(a)?void 0:[t,a]}))),(async(t,a)=>await S((async()=>{if(await L(),o(a)){const[a,e]=t();await I(a),await h(e)}else await I(a[0],!0),await h(a[1],!0)}))),e,n,s,r,{[A]:()=>R,destroy:()=>(_.stopAutoLoad().stopAutoSave(),i(),_)},R);return _},dt="ColumnName",wt="store",ut="json",Tt=wt+"TableName",Rt=wt+"Id"+dt,At=wt+dt,Nt="autoLoadIntervalSeconds",gt="rowId"+dt,pt="tableId",Ct="tableName",ft="deleteEmptyColumns",Ot="deleteEmptyTable",vt={mode:ut,[Nt]:1},Lt={load:0,save:0,[Ct]:e+"_values"},$t=(t,a,e,n,s)=>{const i=K();return q(t,((t,r)=>{const l=E(H(X(a,c(t)?{[e]:t}:t)),0,W(a));o(l[0])||n(r,l[0])||(s(r,l[0]),Z(i,r,l))})),i},mt=e,St=/^([cd]:)(.+)/,It=e+"_data",ht=e+"_table";t.createPostgresPersister=async(t,a,n,s,i)=>{const o=await(a.reserve?.());return((t,a,n,s,i,o,l,y,w,u,T="getDb")=>{const A=((t,a)=>a?async(e,n)=>(a(e,n),await t(e,n)):t)(n,o),[N,,g,p]=(t=>{const a=(t=>X(vt,c(t)?{[Tt]:t}:t??{}))(t),n=a[Nt];if(a.mode==ut){const t=a[Tt]??e;return[1,n,[t,a[Rt]??f,a[At]??wt],et(t)]}const{tables:{load:s={},save:i={}}={},values:o={}}=a,r=E(H(X(Lt,o)),0,W(Lt)),l=r[2],y=et(l),d=et(l);return[0,n,[$t(s,{[pt]:null,[gt]:f},pt,(t=>_(d,t)),(t=>nt(y,t))),$t(i,{[Ct]:null,[gt]:f,[ft]:0,[Ot]:0},Ct,((t,a)=>_(d,a)),((t,a)=>nt(y,a))),r],y]})(a),C=async t=>{await A(`CREATE OR REPLACE TRIGGER ${I(It+"_"+t)} AFTER INSERT OR UPDATE OR DELETE ON ${I(t)} EXECUTE FUNCTION ${It}()`)};return(N?Et:yt)(t,A,(async t=>{await A(`CREATE OR REPLACE FUNCTION ${ht}()RETURNS event_trigger AS $t2$ DECLARE row record; BEGIN FOR row IN SELECT object_identity FROM pg_event_trigger_ddl_commands()WHERE command_tag='CREATE TABLE' LOOP PERFORM pg_notify('${mt}','c:'||SPLIT_PART(row.object_identity,'.',2));END LOOP;END;$t2$ LANGUAGE plpgsql;`);try{await A(`CREATE EVENT TRIGGER ${ht} ON ddl_command_end WHEN TAG IN('CREATE TABLE')EXECUTE FUNCTION ${ht}();`)}catch{}return await A(`CREATE OR REPLACE FUNCTION ${It}()RETURNS trigger AS $t1$ BEGIN PERFORM pg_notify('${mt}','d:'||TG_TABLE_NAME);RETURN NULL;END;$t1$ LANGUAGE plpgsql;`),await d(R(P(p),(async t=>{await A(`CREATE TABLE IF NOT EXISTS ${I(t)}("_id"text PRIMARY KEY)`),await C(t)}))),await s(mt,(async a=>{return await r((e=a,n=St,e?.match(n)),(async([,a,e])=>{_(p,e)&&("c:"==a&&await C(e),t())}));var e,n}))}),i,l,y,w,g,P(p),(async(t,a)=>await t(`${O} table_name tn,column_name cn FROM information_schema.columns ${v} table_schema='public'AND table_name IN(${h(a)})`,a)),u,T,"text",void 0,(t=>z(t)),(t=>J(t)))})(t,n,o?.unsafe,(async(t,e)=>a.listen(t,e)),(async t=>{try{await t.unlisten()}catch(t){i?.(t)}}),s,i,(()=>o?.release?.()),3,a,"getSql")}},"object"==typeof exports&&"undefined"!=typeof module?a(exports):"function"==typeof define&&define.amd?define(["exports"],a):a((t="undefined"!=typeof globalThis?globalThis:t||self).TinyBasePersisterPostgres={});
@@ -1 +1 @@
1
- var t,a;t=this,a=function(t){"use strict";const a=t=>typeof t,e="tinybase",n=",",s=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
+ var t,a;t=this,a=function(t){"use strict";const a=t=>typeof t,e="tinybase",n=",",s=a(""),i=Promise,o=t=>null==t,r=(t,a,e)=>o(t)?e?.():a(t),c=t=>a(t)==s,l=t=>Array.isArray(t),E=(t,a,e)=>t.slice(a,e),y=t=>t.length,d=async t=>i.all(t),w=t=>{throw Error(t)},u=(t,a)=>t.forEach(a),T=(t,a="")=>t.join(a),R=(t,a)=>t.map(a),A=t=>0==y(t),N=(t,a)=>t.filter(a),g=(t,...a)=>t.push(...a),p=t=>t.shift(),C="_",f="_id",O="SELECT",v="WHERE",L="TABLE",$="ALTER "+L,m="DELETE FROM",S=O+"*FROM",I=t=>`"${t.replace(/"/g,'""')}"`,h=(t,a=[1])=>T(R(t,(()=>"$"+a[0]++)),n),_=(t,a)=>t?.has(a)??!1,b=t=>o(t)||0==(t=>t?.size??0)(t),P=t=>[...t?.values()??[]],D=(t,a)=>t?.forEach(a),U=(t,a)=>t?.delete(a),F=Object,M=t=>F.getPrototypeOf(t),G=F.entries,B=F.keys,j=F.freeze,x=(t=[])=>F.fromEntries(t),X=(...t)=>F.assign({},...t),Y=(t,a)=>(delete t[a],t),q=(t,a)=>R(G(t),(([t,e])=>a(e,t))),H=t=>F.values(t),W=t=>y(B(t)),k=t=>(t=>!o(t)&&r(M(t),(t=>t==F.prototype||o(M(t))),(()=>!0)))(t)&&0==W(t),z=JSON.stringify,J=JSON.parse,K=t=>new Map(t),V=(t,a)=>t?.get(a),Q=(t,a)=>R([...t?.entries()??[]],(([t,e])=>a(e,t))),Z=(t,a,e)=>o(e)?(U(t,a),t):t?.set(a,e),tt=(t,a,e,n)=>(_(t,a)?n?.(V(t,a)):Z(t,a,e()),V(t,a)),at=(t,a,e,n,s=0)=>r((e?tt:V)(t,a[s],s>y(a)-2?e:K),(i=>{if(s>y(a)-2)return n?.(i)&&Z(t,a[s]),i;const o=at(i,a,e,n,s+1);return b(i)&&Z(t,a[s]),o})),et=t=>new Set(l(t)||o(t)?t:[t]),nt=(t,a)=>t?.add(a),st=/^\d+$/,it=K(),ot=K(),rt=(t,a,e,n,s,i,c,E={},d=[])=>{let T,R,A,N=0,C=0,f=0;tt(it,d,(()=>0)),tt(ot,d,(()=>[]));const O=K(),[v,L,$,m,S]=((t=1,a)=>1!=t&&a.isMergeable()?[1,a.getMergeableContent,a.getTransactionMergeableChanges,([[t],[a]])=>!k(t)||!k(a),a.setDefaultContent]:2!=t?[0,a.getContent,a.getTransactionChanges,([t,a])=>!k(t)||!k(a),a.setContent]:w("Store type not supported by this Persister"))(c,t),[I,h,_]=(()=>{let t;const[a,e]=(()=>{const t=[];let a=0;return[e=>(e?p(t):null)??""+a++,a=>{st.test(a)&&y(t)<1e3&&g(t,a)}]})(),n=K();return[(e,s,i,o=[],r=()=>[])=>{t??=Y;const c=a(1);return Z(n,c,[e,s,i,o,r]),nt(at(s,i??[""],et),c),c},(a,e,...s)=>u(((t,a=[""])=>{const e=[],n=(t,s)=>s==y(a)?g(e,t):null===a[s]?D(t,(t=>n(t,s+1))):u([a[s],null],(a=>n(V(t,a),s+1)));return n(t,0),e})(a,e),(a=>D(a,(a=>V(n,a)[0](t,...e??[],...s))))),t=>r(V(n,t),(([,a,s])=>(at(a,s??[""],void 0,(a=>(U(a,t),b(a)?1:0))),Z(n,t),e(t),s))),a=>r(V(n,a),(([a,,e=[],n,s])=>{const i=(...r)=>{const c=y(r);c==y(e)?a(t,...r,...s(r)):o(e[c])?u(n[c]?.(...r)??[],(t=>i(...r,t))):i(...r,e[c])};i()}))]})(),P=t=>{t!=N&&(N=t,h(O,void 0,N))},F=a=>{(v&&l(a?.[0])?1===a?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===a?.[2]?t.applyChanges:t.setContent)(a)},M=async t=>(2!=N&&(P(1),C++,await X((async()=>{try{const e=await a();l(e)?F(e):t?S(t):w("Content is not an array "+e)}catch(a){i?.(a),t&&S(t)}P(0)}))),Y),G=()=>(R&&(s(R),R=void 0),Y),B=async t=>(1!=N&&(P(2),f++,await X((async()=>{try{await e(L,t)}catch(t){i?.(t)}P(0)}))),Y),x=()=>(r(A,t.delListener),A=void 0,Y),X=async(...t)=>(g(V(ot,d),...t),await(async()=>{if(!V(it,d)){for(Z(it,d,1);!o(T=p(V(ot,d)));)try{await T()}catch(t){i?.(t)}Z(it,d,0)}})(),Y),Y={load:M,startAutoLoad:async t=>{await G().load(t);try{R=await n((async(t,a)=>{a||t?2!=N&&(P(1),C++,F(a??t),P(0)):await M()}))}catch(t){i?.(t)}return Y},stopAutoLoad:G,isAutoLoading:()=>!o(R),save:B,startAutoSave:async()=>(await x().save(),A=t.addDidFinishTransactionListener((()=>{const t=$();m(t)&&B(t)})),Y),stopAutoSave:x,isAutoSaving:()=>!o(A),getStatus:()=>N,addStatusListener:t=>I(t,O),delListener:a=>(_(a),t),schedule:X,getStore:()=>t,destroy:()=>(V(ot,d).splice(0,void 0),G().stopAutoSave()),getStats:()=>({loads:C,saves:f}),...E};return j(Y)},ct=(t,a,e,s,i,r=lt,c,l)=>{const E=K();return[async()=>{E.clear(),R(await e(t,a),(({tn:t,cn:a})=>nt(tt(E,t,et),a)))},async(a,e)=>((t,a)=>_(V(E,t),a))(a,e)?x(N(R(await t(S+I(a)),(t=>{return[t[e],l?(a=Y(t,e),n=l,x(q(a,((t,a)=>[a,n(t,a)])))):Y(t,e)];var a,n})),(([t,a])=>!o(t)&&!k(a)))):{},async(a,e,s,l,y,w=!1)=>{const u=et();q(s??{},(t=>R(B(t??{}),(t=>nt(u,t)))));const p=P(u);if(!w&&y&&A(p)&&_(E,a))return await t("DROP "+L+I(a)),void Z(E,a);const C=V(E,a),f=et(P(C));if(A(p)||(_(E,a)?await d(R([e,...p],(async(n,s)=>{U(f,n)||(await t($+I(a)+"ADD"+I(n)+i),0==s&&await t("CREATE UNIQUE INDEX pk ON "+I(a)+`(${I(e)})`),nt(C,n))}))):(await t("CREATE "+L+I(a)+`(${I(e)}${i} PRIMARY KEY${T(R(p,(t=>n+I(t)+i)))});`),Z(E,a,et([e,...p])))),await d([...!w&&l?R(P(f),(async n=>{n!=e&&(await t($+I(a)+"DROP"+I(n)),U(C,n))})):[]]),w)o(s)?await t(m+I(a)+v+" true"):await d(q(s,(async(n,s)=>{o(n)?await t(m+I(a)+v+I(e)+"=$1",[s]):A(p)||await r(t,a,e,B(n),{[s]:c?R(H(n),c):H(n)},C)})));else if(A(p))_(E,a)&&await t(m+I(a)+v+" true");else{const n=N(P(V(E,a)),(t=>t!=e)),i={},o=[];q(s??{},((t,a)=>{i[a]=R(n,(a=>c?c(t?.[a]):t?.[a])),g(o,a)})),await r(t,a,e,n,i),await t(m+I(a)+v+I(e)+`NOT IN(${h(o)})`,o)}},async a=>{let e;await t("BEGIN");try{e=await a()}catch(t){s?.(t)}return await t("END"),e}]},lt=async(t,a,e,s,i)=>{const o=[1];await t("INSERT INTO"+I(a)+"("+((...t)=>T(R(t,I),n))(e,...s)+")VALUES"+T(q(i,(t=>"($"+o[0]+++","+h(t,o)+")")),n)+"ON CONFLICT("+I(e)+")DO UPDATE SET"+T(R(s,(t=>I(t)+"=excluded."+I(t))),n),q(i,((t,a)=>[a,...R(t,(t=>t??null))])).flat())},Et=(t,a,e,n,s,i,o,[r,c,l],E,y,d,w,u,T)=>{const[R,A,N,g]=ct(a,E,y,s,u,T),p=rt(t,(async()=>await g((async()=>{return await R(),t=(await A(r,c))[C]?.[l]??"null",J(t,((t,a)=>""===a?void 0:a));var t}))),(async t=>await g((async()=>{var a;await R(),await N(r,c,{[C]:{[l]:(a=t()??null,z(a,((t,a)=>void 0===a?"":a)))}},!0,!0)}))),e,n,s,o,{[w]:()=>d,destroy:()=>(p.stopAutoLoad().stopAutoSave(),i(),p)},d);return p},yt=(t,a,e,n,s,i,r,[c,l,[E,y,w]],u,T,R,A,g,p,O,v)=>{const[L,$,m,S]=ct(a,u,T,s,g,p,O,v),I=async(t,a)=>await d(Q(l,(async([e,n,s,i],o)=>{a&&!(o in t)||await m(e,n,t[o],s,i,a)}))),h=async(t,a)=>y?await m(w,f,{[C]:t},!0,!0,a):null,_=rt(t,(async()=>await S((async()=>{await L();const t=await(async()=>x(N(await d(Q(c,(async([t,a],e)=>[t,await $(e,a)]))),(t=>!k(t[1])))))(),a=await(async()=>E?(await $(w,f))[C]:{})();return k(t)&&o(a)?void 0:[t,a]}))),(async(t,a)=>await S((async()=>{if(await L(),o(a)){const[a,e]=t();await I(a),await h(e)}else await I(a[0],!0),await h(a[1],!0)}))),e,n,s,r,{[A]:()=>R,destroy:()=>(_.stopAutoLoad().stopAutoSave(),i(),_)},R);return _},dt="ColumnName",wt="store",ut="json",Tt=wt+"TableName",Rt=wt+"Id"+dt,At=wt+dt,Nt="autoLoadIntervalSeconds",gt="rowId"+dt,pt="tableId",Ct="tableName",ft="deleteEmptyColumns",Ot="deleteEmptyTable",vt={mode:ut,[Nt]:1},Lt={load:0,save:0,[Ct]:e+"_values"},$t=(t,a,e,n,s)=>{const i=K();return q(t,((t,r)=>{const l=E(H(X(a,c(t)?{[e]:t}:t)),0,W(a));o(l[0])||n(r,l[0])||(s(r,l[0]),Z(i,r,l))})),i},mt=e,St=/^([cd]:)(.+)/,It=e+"_data",ht=e+"_table";t.createPostgresPersister=async(t,a,n,s,i)=>{const o=await(a.reserve?.());return((t,a,n,s,i,o,l,y,w,u,T="getDb")=>{const A=((t,a)=>a?async(e,n)=>(a(e,n),await t(e,n)):t)(n,o),[N,,g,p]=(t=>{const a=(t=>X(vt,c(t)?{[Tt]:t}:t??{}))(t),n=a[Nt];if(a.mode==ut){const t=a[Tt]??e;return[1,n,[t,a[Rt]??f,a[At]??wt],et(t)]}const{tables:{load:s={},save:i={}}={},values:o={}}=a,r=E(H(X(Lt,o)),0,W(Lt)),l=r[2],y=et(l),d=et(l);return[0,n,[$t(s,{[pt]:null,[gt]:f},pt,(t=>_(d,t)),(t=>nt(y,t))),$t(i,{[Ct]:null,[gt]:f,[ft]:0,[Ot]:0},Ct,((t,a)=>_(d,a)),((t,a)=>nt(y,a))),r],y]})(a),C=async t=>{await A(`CREATE OR REPLACE TRIGGER ${I(It+"_"+t)} AFTER INSERT OR UPDATE OR DELETE ON ${I(t)} EXECUTE FUNCTION ${It}()`)};return(N?Et:yt)(t,A,(async t=>{await A(`CREATE OR REPLACE FUNCTION ${ht}()RETURNS event_trigger AS $t2$ DECLARE row record; BEGIN FOR row IN SELECT object_identity FROM pg_event_trigger_ddl_commands()WHERE command_tag='CREATE TABLE' LOOP PERFORM pg_notify('${mt}','c:'||SPLIT_PART(row.object_identity,'.',2));END LOOP;END;$t2$ LANGUAGE plpgsql;`);try{await A(`CREATE EVENT TRIGGER ${ht} ON ddl_command_end WHEN TAG IN('CREATE TABLE')EXECUTE FUNCTION ${ht}();`)}catch{}return await A(`CREATE OR REPLACE FUNCTION ${It}()RETURNS trigger AS $t1$ BEGIN PERFORM pg_notify('${mt}','d:'||TG_TABLE_NAME);RETURN NULL;END;$t1$ LANGUAGE plpgsql;`),await d(R(P(p),(async t=>{await A(`CREATE TABLE IF NOT EXISTS ${I(t)}("_id"text PRIMARY KEY)`),await C(t)}))),await s(mt,(async a=>{return await r((e=a,n=St,e?.match(n)),(async([,a,e])=>{_(p,e)&&("c:"==a&&await C(e),t())}));var e,n}))}),i,l,y,w,g,P(p),(async(t,a)=>await t(`${O} table_name tn,column_name cn FROM information_schema.columns ${v} table_schema='public'AND table_name IN(${h(a)})`,a)),u,T,"text",void 0,(t=>z(t)),(t=>J(t)))})(t,n,o?.unsafe,(async(t,e)=>a.listen(t,e)),(async t=>{try{await t.unlisten()}catch(t){i?.(t)}}),s,i,(()=>o?.release?.()),3,a,"getSql")}},"object"==typeof exports&&"undefined"!=typeof module?a(exports):"function"==typeof define&&define.amd?define(["exports"],a):a((t="undefined"!=typeof globalThis?globalThis:t||self).TinyBasePersisterPostgres={});
@@ -1 +1 @@
1
- var t,a;t=this,a=function(t){"use strict";const a=t=>typeof t,e="tinybase",n="",s=",",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
+ 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 e=await a();u(e)?U(e):t?L(t):p("Content is not an array "+e)}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 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
+ 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 e=await a();u(e)?U(e):t?L(t):p("Content is not an array "+e)}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 t,e;t=this,e=function(t){"use strict";const e=clearInterval,a=t=>null==t,n=(t,e,n)=>a(t)?n?.():e(t),s=t=>Array.isArray(t),r=t=>t.length,o=t=>{throw Error(t)},i=(t,e)=>t.forEach(e),c=(t,...e)=>t.push(...e),l=t=>t.shift(),d=Object,u=t=>d.getPrototypeOf(t),y=d.keys,h=d.freeze,p=t=>(t=>!a(t)&&n(u(t),(t=>t==d.prototype||a(u(t))),(()=>!0)))(t)&&0==(t=>r(y(t)))(t),f=JSON.stringify,g=JSON.parse,v=t=>a(t)||0==(t=>t?.size??0)(t),w=(t,e)=>t?.forEach(e),S=(t,e)=>t?.delete(e),C=t=>new Map(t),b=(t,e)=>t?.get(e),A=(t,e,n)=>a(n)?(S(t,e),t):t?.set(e,n),T=(t,e,a,n)=>{var s,r;return s=t,r=e,s?.has(r)?n?.(b(t,e)):A(t,e,a()),b(t,e)},m=(t,e,a,s,o=0)=>n((a?T:b)(t,e[o],o>r(e)-2?a:C),(n=>{if(o>r(e)-2)return s?.(n)&&A(t,e[o]),n;const i=m(n,e,a,s,o+1);return v(n)&&A(t,e[o]),i})),L=t=>new Set(s(t)||a(t)?t:[t]),M=/^\d+$/,E=C(),O=C(),P=(t,e,d,u,y,f,g,P={},x=[])=>{let j,D,z,I=0,J=0,N=0;T(E,x,(()=>0)),T(O,x,(()=>[]));const R=C(),[k,B,F,H,U]=((t=1,e)=>1!=t&&e.isMergeable()?[1,e.getMergeableContent,e.getTransactionMergeableChanges,([[t],[e]])=>!p(t)||!p(e),e.setDefaultContent]:2!=t?[0,e.getContent,e.getTransactionChanges,([t,e])=>!p(t)||!p(e),e.setContent]:o("Store type not supported by this Persister"))(g,t),[$,q,G]=(()=>{let t;const[e,s]=(()=>{const t=[];let e=0;return[a=>(a?l(t):null)??""+e++,e=>{M.test(e)&&r(t)<1e3&&c(t,e)}]})(),o=C();return[(a,n,s,r=[],i=()=>[])=>{t??=_;const c=e(1);var l,d;return A(o,c,[a,n,s,r,i]),l=m(n,s??[""],L),d=c,l?.add(d),c},(e,a,...n)=>i(((t,e=[""])=>{const a=[],n=(t,s)=>s==r(e)?c(a,t):null===e[s]?w(t,(t=>n(t,s+1))):i([e[s],null],(e=>n(b(t,e),s+1)));return n(t,0),a})(e,a),(e=>w(e,(e=>b(o,e)[0](t,...a??[],...n))))),t=>n(b(o,t),(([,e,a])=>(m(e,a??[""],void 0,(e=>(S(e,t),v(e)?1:0))),A(o,t),s(t),a))),e=>n(b(o,e),(([e,,n=[],s,o])=>{const c=(...l)=>{const d=r(l);d==r(n)?e(t,...l,...o(l)):a(n[d])?i(s[d]?.(...l)??[],(t=>c(...l,t))):c(...l,n[d])};c()}))]})(),K=t=>{t!=I&&(I=t,q(R,void 0,I))},Q=e=>{(k&&s(e?.[0])?1===e?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===e?.[2]?t.applyChanges:t.setContent)(e)},V=async t=>(2!=I&&(K(1),J++,await Z((async()=>{try{const t=await e();s(t)?Q(t):o("Content is not an array "+t)}catch(e){f?.(e),t&&U(t)}K(0)}))),_),W=()=>(D&&(y(D),D=void 0),_),X=async t=>(1!=I&&(K(2),N++,await Z((async()=>{try{await d(B,t)}catch(t){f?.(t)}K(0)}))),_),Y=()=>(n(z,t.delListener),z=void 0,_),Z=async(...t)=>(c(b(O,x),...t),await(async()=>{if(!b(E,x)){for(A(E,x,1);!a(j=l(b(O,x)));)try{await j()}catch(t){f?.(t)}A(E,x,0)}})(),_),_={load:V,startAutoLoad:async t=>{await W().load(t);try{D=await u((async(t,e)=>{e||t?2!=I&&(K(1),J++,Q(e??t),K(0)):await V()}))}catch(t){f?.(t)}return _},stopAutoLoad:W,isAutoLoading:()=>!a(D),save:X,startAutoSave:async()=>(await Y().save(),z=t.addDidFinishTransactionListener((()=>{const t=F();H(t)&&X(t)})),_),stopAutoSave:Y,isAutoSaving:()=>!a(z),getStatus:()=>I,addStatusListener:t=>$(t,R),delListener:e=>(G(e),t),schedule:Z,getStore:()=>t,destroy:()=>(b(O,x).splice(0,void 0),W().stopAutoSave()),getStats:()=>({loads:J,saves:N}),...P};return h(_)},x=t=>t.headers.get("ETag");t.createRemotePersister=(t,n,s,r=5,o)=>{let i;return P(t,(async()=>{const t=await fetch(n);return i=x(t),g(await t.text())}),(async t=>{return await fetch(s,{method:"POST",headers:{"Content-Type":"application/json"},body:(e=t(),f(e,((t,e)=>e instanceof Map?d.fromEntries([...e]):e)))});var e}),(t=>setInterval((async()=>{const e=await fetch(n,{method:"HEAD"}),s=x(e);a(i)||a(s)||s==i||(i=s,t())}),1e3*r)),(t=>e(t)),o,1,{getUrls:()=>[n,s]})}},"object"==typeof exports&&"undefined"!=typeof module?e(exports):"function"==typeof define&&define.amd?define(["exports"],e):e((t="undefined"!=typeof globalThis?globalThis:t||self).TinyBasePersisterRemote={});
1
+ var t,e;t=this,e=function(t){"use strict";const e=clearInterval,a=t=>null==t,n=(t,e,n)=>a(t)?n?.():e(t),s=t=>Array.isArray(t),r=t=>t.length,o=t=>{throw Error(t)},i=(t,e)=>t.forEach(e),c=(t,...e)=>t.push(...e),l=t=>t.shift(),d=Object,u=t=>d.getPrototypeOf(t),y=d.keys,h=d.freeze,p=t=>(t=>!a(t)&&n(u(t),(t=>t==d.prototype||a(u(t))),(()=>!0)))(t)&&0==(t=>r(y(t)))(t),f=JSON.stringify,g=JSON.parse,v=t=>a(t)||0==(t=>t?.size??0)(t),w=(t,e)=>t?.forEach(e),S=(t,e)=>t?.delete(e),C=t=>new Map(t),b=(t,e)=>t?.get(e),A=(t,e,n)=>a(n)?(S(t,e),t):t?.set(e,n),T=(t,e,a,n)=>{var s,r;return s=t,r=e,s?.has(r)?n?.(b(t,e)):A(t,e,a()),b(t,e)},m=(t,e,a,s,o=0)=>n((a?T:b)(t,e[o],o>r(e)-2?a:C),(n=>{if(o>r(e)-2)return s?.(n)&&A(t,e[o]),n;const i=m(n,e,a,s,o+1);return v(n)&&A(t,e[o]),i})),L=t=>new Set(s(t)||a(t)?t:[t]),M=/^\d+$/,E=C(),O=C(),P=(t,e,d,u,y,f,g,P={},x=[])=>{let j,D,z,I=0,J=0,N=0;T(E,x,(()=>0)),T(O,x,(()=>[]));const R=C(),[k,B,F,H,U]=((t=1,e)=>1!=t&&e.isMergeable()?[1,e.getMergeableContent,e.getTransactionMergeableChanges,([[t],[e]])=>!p(t)||!p(e),e.setDefaultContent]:2!=t?[0,e.getContent,e.getTransactionChanges,([t,e])=>!p(t)||!p(e),e.setContent]:o("Store type not supported by this Persister"))(g,t),[$,q,G]=(()=>{let t;const[e,s]=(()=>{const t=[];let e=0;return[a=>(a?l(t):null)??""+e++,e=>{M.test(e)&&r(t)<1e3&&c(t,e)}]})(),o=C();return[(a,n,s,r=[],i=()=>[])=>{t??=_;const c=e(1);var l,d;return A(o,c,[a,n,s,r,i]),l=m(n,s??[""],L),d=c,l?.add(d),c},(e,a,...n)=>i(((t,e=[""])=>{const a=[],n=(t,s)=>s==r(e)?c(a,t):null===e[s]?w(t,(t=>n(t,s+1))):i([e[s],null],(e=>n(b(t,e),s+1)));return n(t,0),a})(e,a),(e=>w(e,(e=>b(o,e)[0](t,...a??[],...n))))),t=>n(b(o,t),(([,e,a])=>(m(e,a??[""],void 0,(e=>(S(e,t),v(e)?1:0))),A(o,t),s(t),a))),e=>n(b(o,e),(([e,,n=[],s,o])=>{const c=(...l)=>{const d=r(l);d==r(n)?e(t,...l,...o(l)):a(n[d])?i(s[d]?.(...l)??[],(t=>c(...l,t))):c(...l,n[d])};c()}))]})(),K=t=>{t!=I&&(I=t,q(R,void 0,I))},Q=e=>{(k&&s(e?.[0])?1===e?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===e?.[2]?t.applyChanges:t.setContent)(e)},V=async t=>(2!=I&&(K(1),J++,await Z((async()=>{try{const a=await e();s(a)?Q(a):t?U(t):o("Content is not an array "+a)}catch(e){f?.(e),t&&U(t)}K(0)}))),_),W=()=>(D&&(y(D),D=void 0),_),X=async t=>(1!=I&&(K(2),N++,await Z((async()=>{try{await d(B,t)}catch(t){f?.(t)}K(0)}))),_),Y=()=>(n(z,t.delListener),z=void 0,_),Z=async(...t)=>(c(b(O,x),...t),await(async()=>{if(!b(E,x)){for(A(E,x,1);!a(j=l(b(O,x)));)try{await j()}catch(t){f?.(t)}A(E,x,0)}})(),_),_={load:V,startAutoLoad:async t=>{await W().load(t);try{D=await u((async(t,e)=>{e||t?2!=I&&(K(1),J++,Q(e??t),K(0)):await V()}))}catch(t){f?.(t)}return _},stopAutoLoad:W,isAutoLoading:()=>!a(D),save:X,startAutoSave:async()=>(await Y().save(),z=t.addDidFinishTransactionListener((()=>{const t=F();H(t)&&X(t)})),_),stopAutoSave:Y,isAutoSaving:()=>!a(z),getStatus:()=>I,addStatusListener:t=>$(t,R),delListener:e=>(G(e),t),schedule:Z,getStore:()=>t,destroy:()=>(b(O,x).splice(0,void 0),W().stopAutoSave()),getStats:()=>({loads:J,saves:N}),...P};return h(_)},x=t=>t.headers.get("ETag");t.createRemotePersister=(t,n,s,r=5,o)=>{let i;return P(t,(async()=>{const t=await fetch(n);return i=x(t),g(await t.text())}),(async t=>{return await fetch(s,{method:"POST",headers:{"Content-Type":"application/json"},body:(e=t(),f(e,((t,e)=>e instanceof Map?d.fromEntries([...e]):e)))});var e}),(t=>setInterval((async()=>{const e=await fetch(n,{method:"HEAD"}),s=x(e);a(i)||a(s)||s==i||(i=s,t())}),1e3*r)),(t=>e(t)),o,1,{getUrls:()=>[n,s]})}},"object"==typeof exports&&"undefined"!=typeof module?e(exports):"function"==typeof define&&define.amd?define(["exports"],e):e((t="undefined"!=typeof globalThis?globalThis:t||self).TinyBasePersisterRemote={});
@@ -1 +1 @@
1
- var t,e;t=this,e=function(t){"use strict";const e=clearInterval,a=t=>null==t,n=(t,e,n)=>a(t)?n?.():e(t),s=t=>Array.isArray(t),r=t=>t.length,o=t=>{throw Error(t)},i=(t,e)=>t.forEach(e),c=(t,...e)=>t.push(...e),l=t=>t.shift(),d=Object,u=t=>d.getPrototypeOf(t),y=d.keys,h=d.freeze,p=t=>(t=>!a(t)&&n(u(t),(t=>t==d.prototype||a(u(t))),(()=>!0)))(t)&&0==(t=>r(y(t)))(t),f=JSON.stringify,g=JSON.parse,v=t=>a(t)||0==(t=>t?.size??0)(t),w=(t,e)=>t?.forEach(e),S=(t,e)=>t?.delete(e),C=t=>new Map(t),b=(t,e)=>t?.get(e),A=(t,e,n)=>a(n)?(S(t,e),t):t?.set(e,n),T=(t,e,a,n)=>{var s,r;return s=t,r=e,s?.has(r)?n?.(b(t,e)):A(t,e,a()),b(t,e)},m=(t,e,a,s,o=0)=>n((a?T:b)(t,e[o],o>r(e)-2?a:C),(n=>{if(o>r(e)-2)return s?.(n)&&A(t,e[o]),n;const i=m(n,e,a,s,o+1);return v(n)&&A(t,e[o]),i})),L=t=>new Set(s(t)||a(t)?t:[t]),M=/^\d+$/,E=C(),O=C(),P=(t,e,d,u,y,f,g,P={},x=[])=>{let j,D,z,I=0,J=0,N=0;T(E,x,(()=>0)),T(O,x,(()=>[]));const R=C(),[k,B,F,H,U]=((t=1,e)=>1!=t&&e.isMergeable()?[1,e.getMergeableContent,e.getTransactionMergeableChanges,([[t],[e]])=>!p(t)||!p(e),e.setDefaultContent]:2!=t?[0,e.getContent,e.getTransactionChanges,([t,e])=>!p(t)||!p(e),e.setContent]:o("Store type not supported by this Persister"))(g,t),[$,q,G]=(()=>{let t;const[e,s]=(()=>{const t=[];let e=0;return[a=>(a?l(t):null)??""+e++,e=>{M.test(e)&&r(t)<1e3&&c(t,e)}]})(),o=C();return[(a,n,s,r=[],i=()=>[])=>{t??=_;const c=e(1);var l,d;return A(o,c,[a,n,s,r,i]),l=m(n,s??[""],L),d=c,l?.add(d),c},(e,a,...n)=>i(((t,e=[""])=>{const a=[],n=(t,s)=>s==r(e)?c(a,t):null===e[s]?w(t,(t=>n(t,s+1))):i([e[s],null],(e=>n(b(t,e),s+1)));return n(t,0),a})(e,a),(e=>w(e,(e=>b(o,e)[0](t,...a??[],...n))))),t=>n(b(o,t),(([,e,a])=>(m(e,a??[""],void 0,(e=>(S(e,t),v(e)?1:0))),A(o,t),s(t),a))),e=>n(b(o,e),(([e,,n=[],s,o])=>{const c=(...l)=>{const d=r(l);d==r(n)?e(t,...l,...o(l)):a(n[d])?i(s[d]?.(...l)??[],(t=>c(...l,t))):c(...l,n[d])};c()}))]})(),K=t=>{t!=I&&(I=t,q(R,void 0,I))},Q=e=>{(k&&s(e?.[0])?1===e?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===e?.[2]?t.applyChanges:t.setContent)(e)},V=async t=>(2!=I&&(K(1),J++,await Z((async()=>{try{const t=await e();s(t)?Q(t):o("Content is not an array "+t)}catch(e){f?.(e),t&&U(t)}K(0)}))),_),W=()=>(D&&(y(D),D=void 0),_),X=async t=>(1!=I&&(K(2),N++,await Z((async()=>{try{await d(B,t)}catch(t){f?.(t)}K(0)}))),_),Y=()=>(n(z,t.delListener),z=void 0,_),Z=async(...t)=>(c(b(O,x),...t),await(async()=>{if(!b(E,x)){for(A(E,x,1);!a(j=l(b(O,x)));)try{await j()}catch(t){f?.(t)}A(E,x,0)}})(),_),_={load:V,startAutoLoad:async t=>{await W().load(t);try{D=await u((async(t,e)=>{e||t?2!=I&&(K(1),J++,Q(e??t),K(0)):await V()}))}catch(t){f?.(t)}return _},stopAutoLoad:W,isAutoLoading:()=>!a(D),save:X,startAutoSave:async()=>(await Y().save(),z=t.addDidFinishTransactionListener((()=>{const t=F();H(t)&&X(t)})),_),stopAutoSave:Y,isAutoSaving:()=>!a(z),getStatus:()=>I,addStatusListener:t=>$(t,R),delListener:e=>(G(e),t),schedule:Z,getStore:()=>t,destroy:()=>(b(O,x).splice(0,void 0),W().stopAutoSave()),getStats:()=>({loads:J,saves:N}),...P};return h(_)},x=t=>t.headers.get("ETag");t.createRemotePersister=(t,n,s,r=5,o)=>{let i;return P(t,(async()=>{const t=await fetch(n);return i=x(t),g(await t.text())}),(async t=>{return await fetch(s,{method:"POST",headers:{"Content-Type":"application/json"},body:(e=t(),f(e,((t,e)=>e instanceof Map?d.fromEntries([...e]):e)))});var e}),(t=>setInterval((async()=>{const e=await fetch(n,{method:"HEAD"}),s=x(e);a(i)||a(s)||s==i||(i=s,t())}),1e3*r)),(t=>e(t)),o,1,{getUrls:()=>[n,s]})}},"object"==typeof exports&&"undefined"!=typeof module?e(exports):"function"==typeof define&&define.amd?define(["exports"],e):e((t="undefined"!=typeof globalThis?globalThis:t||self).TinyBasePersisterRemote={});
1
+ var t,e;t=this,e=function(t){"use strict";const e=clearInterval,a=t=>null==t,n=(t,e,n)=>a(t)?n?.():e(t),s=t=>Array.isArray(t),r=t=>t.length,o=t=>{throw Error(t)},i=(t,e)=>t.forEach(e),c=(t,...e)=>t.push(...e),l=t=>t.shift(),d=Object,u=t=>d.getPrototypeOf(t),y=d.keys,h=d.freeze,p=t=>(t=>!a(t)&&n(u(t),(t=>t==d.prototype||a(u(t))),(()=>!0)))(t)&&0==(t=>r(y(t)))(t),f=JSON.stringify,g=JSON.parse,v=t=>a(t)||0==(t=>t?.size??0)(t),w=(t,e)=>t?.forEach(e),S=(t,e)=>t?.delete(e),C=t=>new Map(t),b=(t,e)=>t?.get(e),A=(t,e,n)=>a(n)?(S(t,e),t):t?.set(e,n),T=(t,e,a,n)=>{var s,r;return s=t,r=e,s?.has(r)?n?.(b(t,e)):A(t,e,a()),b(t,e)},m=(t,e,a,s,o=0)=>n((a?T:b)(t,e[o],o>r(e)-2?a:C),(n=>{if(o>r(e)-2)return s?.(n)&&A(t,e[o]),n;const i=m(n,e,a,s,o+1);return v(n)&&A(t,e[o]),i})),L=t=>new Set(s(t)||a(t)?t:[t]),M=/^\d+$/,E=C(),O=C(),P=(t,e,d,u,y,f,g,P={},x=[])=>{let j,D,z,I=0,J=0,N=0;T(E,x,(()=>0)),T(O,x,(()=>[]));const R=C(),[k,B,F,H,U]=((t=1,e)=>1!=t&&e.isMergeable()?[1,e.getMergeableContent,e.getTransactionMergeableChanges,([[t],[e]])=>!p(t)||!p(e),e.setDefaultContent]:2!=t?[0,e.getContent,e.getTransactionChanges,([t,e])=>!p(t)||!p(e),e.setContent]:o("Store type not supported by this Persister"))(g,t),[$,q,G]=(()=>{let t;const[e,s]=(()=>{const t=[];let e=0;return[a=>(a?l(t):null)??""+e++,e=>{M.test(e)&&r(t)<1e3&&c(t,e)}]})(),o=C();return[(a,n,s,r=[],i=()=>[])=>{t??=_;const c=e(1);var l,d;return A(o,c,[a,n,s,r,i]),l=m(n,s??[""],L),d=c,l?.add(d),c},(e,a,...n)=>i(((t,e=[""])=>{const a=[],n=(t,s)=>s==r(e)?c(a,t):null===e[s]?w(t,(t=>n(t,s+1))):i([e[s],null],(e=>n(b(t,e),s+1)));return n(t,0),a})(e,a),(e=>w(e,(e=>b(o,e)[0](t,...a??[],...n))))),t=>n(b(o,t),(([,e,a])=>(m(e,a??[""],void 0,(e=>(S(e,t),v(e)?1:0))),A(o,t),s(t),a))),e=>n(b(o,e),(([e,,n=[],s,o])=>{const c=(...l)=>{const d=r(l);d==r(n)?e(t,...l,...o(l)):a(n[d])?i(s[d]?.(...l)??[],(t=>c(...l,t))):c(...l,n[d])};c()}))]})(),K=t=>{t!=I&&(I=t,q(R,void 0,I))},Q=e=>{(k&&s(e?.[0])?1===e?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===e?.[2]?t.applyChanges:t.setContent)(e)},V=async t=>(2!=I&&(K(1),J++,await Z((async()=>{try{const a=await e();s(a)?Q(a):t?U(t):o("Content is not an array "+a)}catch(e){f?.(e),t&&U(t)}K(0)}))),_),W=()=>(D&&(y(D),D=void 0),_),X=async t=>(1!=I&&(K(2),N++,await Z((async()=>{try{await d(B,t)}catch(t){f?.(t)}K(0)}))),_),Y=()=>(n(z,t.delListener),z=void 0,_),Z=async(...t)=>(c(b(O,x),...t),await(async()=>{if(!b(E,x)){for(A(E,x,1);!a(j=l(b(O,x)));)try{await j()}catch(t){f?.(t)}A(E,x,0)}})(),_),_={load:V,startAutoLoad:async t=>{await W().load(t);try{D=await u((async(t,e)=>{e||t?2!=I&&(K(1),J++,Q(e??t),K(0)):await V()}))}catch(t){f?.(t)}return _},stopAutoLoad:W,isAutoLoading:()=>!a(D),save:X,startAutoSave:async()=>(await Y().save(),z=t.addDidFinishTransactionListener((()=>{const t=F();H(t)&&X(t)})),_),stopAutoSave:Y,isAutoSaving:()=>!a(z),getStatus:()=>I,addStatusListener:t=>$(t,R),delListener:e=>(G(e),t),schedule:Z,getStore:()=>t,destroy:()=>(b(O,x).splice(0,void 0),W().stopAutoSave()),getStats:()=>({loads:J,saves:N}),...P};return h(_)},x=t=>t.headers.get("ETag");t.createRemotePersister=(t,n,s,r=5,o)=>{let i;return P(t,(async()=>{const t=await fetch(n);return i=x(t),g(await t.text())}),(async t=>{return await fetch(s,{method:"POST",headers:{"Content-Type":"application/json"},body:(e=t(),f(e,((t,e)=>e instanceof Map?d.fromEntries([...e]):e)))});var e}),(t=>setInterval((async()=>{const e=await fetch(n,{method:"HEAD"}),s=x(e);a(i)||a(s)||s==i||(i=s,t())}),1e3*r)),(t=>e(t)),o,1,{getUrls:()=>[n,s]})}},"object"==typeof exports&&"undefined"!=typeof module?e(exports):"function"==typeof define&&define.amd?define(["exports"],e):e((t="undefined"!=typeof globalThis?globalThis:t||self).TinyBasePersisterRemote={});