tinybase 5.4.0-beta.2 → 5.4.0-beta.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (1091) hide show
  1. package/@types/mergeable-store/index.d.cts +7 -5
  2. package/@types/mergeable-store/index.d.ts +7 -5
  3. package/@types/mergeable-store/with-schemas/index.d.cts +16 -9
  4. package/@types/mergeable-store/with-schemas/index.d.ts +16 -9
  5. package/@types/persisters/index.d.cts +14 -10
  6. package/@types/persisters/index.d.ts +14 -10
  7. package/@types/persisters/persister-durable-object-storage/index.d.cts +108 -0
  8. package/@types/persisters/persister-durable-object-storage/index.d.ts +108 -0
  9. package/@types/persisters/persister-durable-object-storage/with-schemas/index.d.cts +122 -0
  10. package/@types/persisters/persister-durable-object-storage/with-schemas/index.d.ts +122 -0
  11. package/@types/persisters/with-schemas/index.d.cts +14 -10
  12. package/@types/persisters/with-schemas/index.d.ts +14 -10
  13. package/@types/synchronizers/synchronizer-ws-server/index.d.cts +4 -0
  14. package/@types/synchronizers/synchronizer-ws-server/index.d.ts +4 -0
  15. package/@types/synchronizers/synchronizer-ws-server/with-schemas/index.d.cts +5 -0
  16. package/@types/synchronizers/synchronizer-ws-server/with-schemas/index.d.ts +5 -0
  17. package/@types/synchronizers/synchronizer-ws-server-durable-object/index.d.cts +60 -3
  18. package/@types/synchronizers/synchronizer-ws-server-durable-object/index.d.ts +60 -3
  19. package/@types/synchronizers/synchronizer-ws-server-durable-object/with-schemas/index.d.cts +89 -7
  20. package/@types/synchronizers/synchronizer-ws-server-durable-object/with-schemas/index.d.ts +89 -7
  21. package/cjs/es6/index.cjs +32 -27
  22. package/cjs/es6/indexes/index.cjs +1 -1
  23. package/cjs/es6/indexes/with-schemas/index.cjs +1 -1
  24. package/cjs/es6/mergeable-store/index.cjs +31 -27
  25. package/cjs/es6/mergeable-store/with-schemas/index.cjs +31 -27
  26. package/cjs/es6/metrics/index.cjs +1 -1
  27. package/cjs/es6/metrics/with-schemas/index.cjs +1 -1
  28. package/cjs/es6/min/index.cjs +1 -1
  29. package/cjs/es6/min/index.cjs.gz +0 -0
  30. package/cjs/es6/min/indexes/index.cjs +1 -1
  31. package/cjs/es6/min/indexes/index.cjs.gz +0 -0
  32. package/cjs/es6/min/indexes/with-schemas/index.cjs +1 -1
  33. package/cjs/es6/min/indexes/with-schemas/index.cjs.gz +0 -0
  34. package/cjs/es6/min/mergeable-store/index.cjs +1 -1
  35. package/cjs/es6/min/mergeable-store/index.cjs.gz +0 -0
  36. package/cjs/es6/min/mergeable-store/with-schemas/index.cjs +1 -1
  37. package/cjs/es6/min/mergeable-store/with-schemas/index.cjs.gz +0 -0
  38. package/cjs/es6/min/metrics/index.cjs +1 -1
  39. package/cjs/es6/min/metrics/index.cjs.gz +0 -0
  40. package/cjs/es6/min/metrics/with-schemas/index.cjs +1 -1
  41. package/cjs/es6/min/metrics/with-schemas/index.cjs.gz +0 -0
  42. package/cjs/es6/min/persisters/index.cjs +1 -1
  43. package/cjs/es6/min/persisters/index.cjs.gz +0 -0
  44. package/cjs/es6/min/persisters/persister-automerge/index.cjs +1 -1
  45. package/cjs/es6/min/persisters/persister-automerge/index.cjs.gz +0 -0
  46. package/cjs/es6/min/persisters/persister-automerge/with-schemas/index.cjs +1 -1
  47. package/cjs/es6/min/persisters/persister-automerge/with-schemas/index.cjs.gz +0 -0
  48. package/cjs/es6/min/persisters/persister-browser/index.cjs +1 -1
  49. package/cjs/es6/min/persisters/persister-browser/index.cjs.gz +0 -0
  50. package/cjs/es6/min/persisters/persister-browser/with-schemas/index.cjs +1 -1
  51. package/cjs/es6/min/persisters/persister-browser/with-schemas/index.cjs.gz +0 -0
  52. package/cjs/es6/min/persisters/persister-cr-sqlite-wasm/index.cjs +1 -1
  53. package/cjs/es6/min/persisters/persister-cr-sqlite-wasm/index.cjs.gz +0 -0
  54. package/cjs/es6/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.cjs +1 -1
  55. package/cjs/es6/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.cjs.gz +0 -0
  56. package/cjs/es6/min/persisters/persister-durable-object-storage/index.cjs +1 -0
  57. package/cjs/es6/min/persisters/persister-durable-object-storage/index.cjs.gz +0 -0
  58. package/cjs/es6/min/persisters/persister-durable-object-storage/with-schemas/index.cjs +1 -0
  59. package/cjs/es6/min/persisters/persister-durable-object-storage/with-schemas/index.cjs.gz +0 -0
  60. package/cjs/es6/min/persisters/persister-electric-sql/index.cjs +1 -1
  61. package/cjs/es6/min/persisters/persister-electric-sql/index.cjs.gz +0 -0
  62. package/cjs/es6/min/persisters/persister-electric-sql/with-schemas/index.cjs +1 -1
  63. package/cjs/es6/min/persisters/persister-electric-sql/with-schemas/index.cjs.gz +0 -0
  64. package/cjs/es6/min/persisters/persister-expo-sqlite/index.cjs +1 -1
  65. package/cjs/es6/min/persisters/persister-expo-sqlite/index.cjs.gz +0 -0
  66. package/cjs/es6/min/persisters/persister-expo-sqlite/with-schemas/index.cjs +1 -1
  67. package/cjs/es6/min/persisters/persister-expo-sqlite/with-schemas/index.cjs.gz +0 -0
  68. package/cjs/es6/min/persisters/persister-file/index.cjs +1 -1
  69. package/cjs/es6/min/persisters/persister-file/index.cjs.gz +0 -0
  70. package/cjs/es6/min/persisters/persister-file/with-schemas/index.cjs +1 -1
  71. package/cjs/es6/min/persisters/persister-file/with-schemas/index.cjs.gz +0 -0
  72. package/cjs/es6/min/persisters/persister-indexed-db/index.cjs +1 -1
  73. package/cjs/es6/min/persisters/persister-indexed-db/index.cjs.gz +0 -0
  74. package/cjs/es6/min/persisters/persister-indexed-db/with-schemas/index.cjs +1 -1
  75. package/cjs/es6/min/persisters/persister-indexed-db/with-schemas/index.cjs.gz +0 -0
  76. package/cjs/es6/min/persisters/persister-libsql/index.cjs +1 -1
  77. package/cjs/es6/min/persisters/persister-libsql/index.cjs.gz +0 -0
  78. package/cjs/es6/min/persisters/persister-libsql/with-schemas/index.cjs +1 -1
  79. package/cjs/es6/min/persisters/persister-libsql/with-schemas/index.cjs.gz +0 -0
  80. package/cjs/es6/min/persisters/persister-partykit-client/index.cjs +1 -1
  81. package/cjs/es6/min/persisters/persister-partykit-client/index.cjs.gz +0 -0
  82. package/cjs/es6/min/persisters/persister-partykit-client/with-schemas/index.cjs +1 -1
  83. package/cjs/es6/min/persisters/persister-partykit-client/with-schemas/index.cjs.gz +0 -0
  84. package/cjs/es6/min/persisters/persister-pglite/index.cjs +1 -1
  85. package/cjs/es6/min/persisters/persister-pglite/index.cjs.gz +0 -0
  86. package/cjs/es6/min/persisters/persister-pglite/with-schemas/index.cjs +1 -1
  87. package/cjs/es6/min/persisters/persister-pglite/with-schemas/index.cjs.gz +0 -0
  88. package/cjs/es6/min/persisters/persister-postgres/index.cjs +1 -1
  89. package/cjs/es6/min/persisters/persister-postgres/index.cjs.gz +0 -0
  90. package/cjs/es6/min/persisters/persister-postgres/with-schemas/index.cjs +1 -1
  91. package/cjs/es6/min/persisters/persister-postgres/with-schemas/index.cjs.gz +0 -0
  92. package/cjs/es6/min/persisters/persister-powersync/index.cjs +1 -1
  93. package/cjs/es6/min/persisters/persister-powersync/index.cjs.gz +0 -0
  94. package/cjs/es6/min/persisters/persister-powersync/with-schemas/index.cjs +1 -1
  95. package/cjs/es6/min/persisters/persister-powersync/with-schemas/index.cjs.gz +0 -0
  96. package/cjs/es6/min/persisters/persister-remote/index.cjs +1 -1
  97. package/cjs/es6/min/persisters/persister-remote/index.cjs.gz +0 -0
  98. package/cjs/es6/min/persisters/persister-remote/with-schemas/index.cjs +1 -1
  99. package/cjs/es6/min/persisters/persister-remote/with-schemas/index.cjs.gz +0 -0
  100. package/cjs/es6/min/persisters/persister-sqlite-wasm/index.cjs +1 -1
  101. package/cjs/es6/min/persisters/persister-sqlite-wasm/index.cjs.gz +0 -0
  102. package/cjs/es6/min/persisters/persister-sqlite-wasm/with-schemas/index.cjs +1 -1
  103. package/cjs/es6/min/persisters/persister-sqlite-wasm/with-schemas/index.cjs.gz +0 -0
  104. package/cjs/es6/min/persisters/persister-sqlite3/index.cjs +1 -1
  105. package/cjs/es6/min/persisters/persister-sqlite3/index.cjs.gz +0 -0
  106. package/cjs/es6/min/persisters/persister-sqlite3/with-schemas/index.cjs +1 -1
  107. package/cjs/es6/min/persisters/persister-sqlite3/with-schemas/index.cjs.gz +0 -0
  108. package/cjs/es6/min/persisters/persister-yjs/index.cjs +1 -1
  109. package/cjs/es6/min/persisters/persister-yjs/index.cjs.gz +0 -0
  110. package/cjs/es6/min/persisters/persister-yjs/with-schemas/index.cjs +1 -1
  111. package/cjs/es6/min/persisters/persister-yjs/with-schemas/index.cjs.gz +0 -0
  112. package/cjs/es6/min/persisters/with-schemas/index.cjs +1 -1
  113. package/cjs/es6/min/persisters/with-schemas/index.cjs.gz +0 -0
  114. package/cjs/es6/min/queries/index.cjs +1 -1
  115. package/cjs/es6/min/queries/index.cjs.gz +0 -0
  116. package/cjs/es6/min/queries/with-schemas/index.cjs +1 -1
  117. package/cjs/es6/min/queries/with-schemas/index.cjs.gz +0 -0
  118. package/cjs/es6/min/relationships/index.cjs +1 -1
  119. package/cjs/es6/min/relationships/index.cjs.gz +0 -0
  120. package/cjs/es6/min/relationships/with-schemas/index.cjs +1 -1
  121. package/cjs/es6/min/relationships/with-schemas/index.cjs.gz +0 -0
  122. package/cjs/es6/min/synchronizers/index.cjs +1 -1
  123. package/cjs/es6/min/synchronizers/index.cjs.gz +0 -0
  124. package/cjs/es6/min/synchronizers/synchronizer-broadcast-channel/index.cjs +1 -1
  125. package/cjs/es6/min/synchronizers/synchronizer-broadcast-channel/index.cjs.gz +0 -0
  126. package/cjs/es6/min/synchronizers/synchronizer-broadcast-channel/with-schemas/index.cjs +1 -1
  127. package/cjs/es6/min/synchronizers/synchronizer-broadcast-channel/with-schemas/index.cjs.gz +0 -0
  128. package/cjs/es6/min/synchronizers/synchronizer-local/index.cjs +1 -1
  129. package/cjs/es6/min/synchronizers/synchronizer-local/index.cjs.gz +0 -0
  130. package/cjs/es6/min/synchronizers/synchronizer-local/with-schemas/index.cjs +1 -1
  131. package/cjs/es6/min/synchronizers/synchronizer-local/with-schemas/index.cjs.gz +0 -0
  132. package/cjs/es6/min/synchronizers/synchronizer-ws-client/index.cjs +1 -1
  133. package/cjs/es6/min/synchronizers/synchronizer-ws-client/index.cjs.gz +0 -0
  134. package/cjs/es6/min/synchronizers/synchronizer-ws-client/with-schemas/index.cjs +1 -1
  135. package/cjs/es6/min/synchronizers/synchronizer-ws-client/with-schemas/index.cjs.gz +0 -0
  136. package/cjs/es6/min/synchronizers/synchronizer-ws-server/index.cjs +1 -1
  137. package/cjs/es6/min/synchronizers/synchronizer-ws-server/index.cjs.gz +0 -0
  138. package/cjs/es6/min/synchronizers/synchronizer-ws-server/with-schemas/index.cjs +1 -1
  139. package/cjs/es6/min/synchronizers/synchronizer-ws-server/with-schemas/index.cjs.gz +0 -0
  140. package/cjs/es6/min/synchronizers/synchronizer-ws-server-durable-object/index.cjs +1 -1
  141. package/cjs/es6/min/synchronizers/synchronizer-ws-server-durable-object/index.cjs.gz +0 -0
  142. package/cjs/es6/min/synchronizers/synchronizer-ws-server-durable-object/with-schemas/index.cjs +1 -1
  143. package/cjs/es6/min/synchronizers/synchronizer-ws-server-durable-object/with-schemas/index.cjs.gz +0 -0
  144. package/cjs/es6/min/synchronizers/with-schemas/index.cjs +1 -1
  145. package/cjs/es6/min/synchronizers/with-schemas/index.cjs.gz +0 -0
  146. package/cjs/es6/min/ui-react-inspector/index.cjs +1 -1
  147. package/cjs/es6/min/ui-react-inspector/index.cjs.gz +0 -0
  148. package/cjs/es6/min/ui-react-inspector/with-schemas/index.cjs +1 -1
  149. package/cjs/es6/min/ui-react-inspector/with-schemas/index.cjs.gz +0 -0
  150. package/cjs/es6/min/with-schemas/index.cjs +1 -1
  151. package/cjs/es6/min/with-schemas/index.cjs.gz +0 -0
  152. package/cjs/es6/persisters/index.cjs +21 -9
  153. package/cjs/es6/persisters/persister-automerge/index.cjs +17 -8
  154. package/cjs/es6/persisters/persister-automerge/with-schemas/index.cjs +17 -8
  155. package/cjs/es6/persisters/persister-browser/index.cjs +17 -8
  156. package/cjs/es6/persisters/persister-browser/with-schemas/index.cjs +17 -8
  157. package/cjs/es6/persisters/persister-cr-sqlite-wasm/index.cjs +21 -9
  158. package/cjs/es6/persisters/persister-cr-sqlite-wasm/with-schemas/index.cjs +21 -9
  159. package/cjs/es6/persisters/persister-durable-object-storage/index.cjs +687 -0
  160. package/cjs/es6/persisters/persister-durable-object-storage/with-schemas/index.cjs +687 -0
  161. package/cjs/es6/persisters/persister-electric-sql/index.cjs +21 -9
  162. package/cjs/es6/persisters/persister-electric-sql/with-schemas/index.cjs +21 -9
  163. package/cjs/es6/persisters/persister-expo-sqlite/index.cjs +21 -9
  164. package/cjs/es6/persisters/persister-expo-sqlite/with-schemas/index.cjs +21 -9
  165. package/cjs/es6/persisters/persister-file/index.cjs +17 -8
  166. package/cjs/es6/persisters/persister-file/with-schemas/index.cjs +17 -8
  167. package/cjs/es6/persisters/persister-indexed-db/index.cjs +19 -9
  168. package/cjs/es6/persisters/persister-indexed-db/with-schemas/index.cjs +19 -9
  169. package/cjs/es6/persisters/persister-libsql/index.cjs +21 -9
  170. package/cjs/es6/persisters/persister-libsql/with-schemas/index.cjs +21 -9
  171. package/cjs/es6/persisters/persister-partykit-client/index.cjs +23 -11
  172. package/cjs/es6/persisters/persister-partykit-client/with-schemas/index.cjs +23 -11
  173. package/cjs/es6/persisters/persister-pglite/index.cjs +19 -8
  174. package/cjs/es6/persisters/persister-pglite/with-schemas/index.cjs +19 -8
  175. package/cjs/es6/persisters/persister-postgres/index.cjs +19 -8
  176. package/cjs/es6/persisters/persister-postgres/with-schemas/index.cjs +19 -8
  177. package/cjs/es6/persisters/persister-powersync/index.cjs +21 -9
  178. package/cjs/es6/persisters/persister-powersync/with-schemas/index.cjs +21 -9
  179. package/cjs/es6/persisters/persister-remote/index.cjs +19 -9
  180. package/cjs/es6/persisters/persister-remote/with-schemas/index.cjs +19 -9
  181. package/cjs/es6/persisters/persister-sqlite-wasm/index.cjs +21 -9
  182. package/cjs/es6/persisters/persister-sqlite-wasm/with-schemas/index.cjs +21 -9
  183. package/cjs/es6/persisters/persister-sqlite3/index.cjs +21 -9
  184. package/cjs/es6/persisters/persister-sqlite3/with-schemas/index.cjs +21 -9
  185. package/cjs/es6/persisters/persister-yjs/index.cjs +17 -8
  186. package/cjs/es6/persisters/persister-yjs/with-schemas/index.cjs +17 -8
  187. package/cjs/es6/persisters/with-schemas/index.cjs +21 -9
  188. package/cjs/es6/queries/index.cjs +1 -0
  189. package/cjs/es6/queries/with-schemas/index.cjs +1 -0
  190. package/cjs/es6/relationships/index.cjs +1 -1
  191. package/cjs/es6/relationships/with-schemas/index.cjs +1 -1
  192. package/cjs/es6/synchronizers/index.cjs +142 -93
  193. package/cjs/es6/synchronizers/synchronizer-broadcast-channel/index.cjs +142 -93
  194. package/cjs/es6/synchronizers/synchronizer-broadcast-channel/with-schemas/index.cjs +142 -93
  195. package/cjs/es6/synchronizers/synchronizer-local/index.cjs +145 -97
  196. package/cjs/es6/synchronizers/synchronizer-local/with-schemas/index.cjs +145 -97
  197. package/cjs/es6/synchronizers/synchronizer-ws-client/index.cjs +160 -98
  198. package/cjs/es6/synchronizers/synchronizer-ws-client/with-schemas/index.cjs +160 -98
  199. package/cjs/es6/synchronizers/synchronizer-ws-server/index.cjs +171 -97
  200. package/cjs/es6/synchronizers/synchronizer-ws-server/with-schemas/index.cjs +171 -97
  201. package/cjs/es6/synchronizers/synchronizer-ws-server-durable-object/index.cjs +980 -20
  202. package/cjs/es6/synchronizers/synchronizer-ws-server-durable-object/with-schemas/index.cjs +980 -20
  203. package/cjs/es6/synchronizers/synchronizer-ws-server-simple/index.cjs +2 -1
  204. package/cjs/es6/synchronizers/synchronizer-ws-server-simple/with-schemas/index.cjs +2 -1
  205. package/cjs/es6/synchronizers/with-schemas/index.cjs +142 -93
  206. package/cjs/es6/ui-react-inspector/index.cjs +17 -8
  207. package/cjs/es6/ui-react-inspector/with-schemas/index.cjs +17 -8
  208. package/cjs/es6/with-schemas/index.cjs +32 -27
  209. package/cjs/index.cjs +31 -27
  210. package/cjs/mergeable-store/index.cjs +31 -27
  211. package/cjs/mergeable-store/with-schemas/index.cjs +31 -27
  212. package/cjs/min/index.cjs +1 -1
  213. package/cjs/min/index.cjs.gz +0 -0
  214. package/cjs/min/mergeable-store/index.cjs +1 -1
  215. package/cjs/min/mergeable-store/index.cjs.gz +0 -0
  216. package/cjs/min/mergeable-store/with-schemas/index.cjs +1 -1
  217. package/cjs/min/mergeable-store/with-schemas/index.cjs.gz +0 -0
  218. package/cjs/min/persisters/index.cjs +1 -1
  219. package/cjs/min/persisters/index.cjs.gz +0 -0
  220. package/cjs/min/persisters/persister-automerge/index.cjs +1 -1
  221. package/cjs/min/persisters/persister-automerge/index.cjs.gz +0 -0
  222. package/cjs/min/persisters/persister-automerge/with-schemas/index.cjs +1 -1
  223. package/cjs/min/persisters/persister-automerge/with-schemas/index.cjs.gz +0 -0
  224. package/cjs/min/persisters/persister-browser/index.cjs +1 -1
  225. package/cjs/min/persisters/persister-browser/index.cjs.gz +0 -0
  226. package/cjs/min/persisters/persister-browser/with-schemas/index.cjs +1 -1
  227. package/cjs/min/persisters/persister-browser/with-schemas/index.cjs.gz +0 -0
  228. package/cjs/min/persisters/persister-cr-sqlite-wasm/index.cjs +1 -1
  229. package/cjs/min/persisters/persister-cr-sqlite-wasm/index.cjs.gz +0 -0
  230. package/cjs/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.cjs +1 -1
  231. package/cjs/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.cjs.gz +0 -0
  232. package/cjs/min/persisters/persister-durable-object-storage/index.cjs +1 -0
  233. package/cjs/min/persisters/persister-durable-object-storage/index.cjs.gz +0 -0
  234. package/cjs/min/persisters/persister-durable-object-storage/with-schemas/index.cjs +1 -0
  235. package/cjs/min/persisters/persister-durable-object-storage/with-schemas/index.cjs.gz +0 -0
  236. package/cjs/min/persisters/persister-electric-sql/index.cjs +1 -1
  237. package/cjs/min/persisters/persister-electric-sql/index.cjs.gz +0 -0
  238. package/cjs/min/persisters/persister-electric-sql/with-schemas/index.cjs +1 -1
  239. package/cjs/min/persisters/persister-electric-sql/with-schemas/index.cjs.gz +0 -0
  240. package/cjs/min/persisters/persister-expo-sqlite/index.cjs +1 -1
  241. package/cjs/min/persisters/persister-expo-sqlite/index.cjs.gz +0 -0
  242. package/cjs/min/persisters/persister-expo-sqlite/with-schemas/index.cjs +1 -1
  243. package/cjs/min/persisters/persister-expo-sqlite/with-schemas/index.cjs.gz +0 -0
  244. package/cjs/min/persisters/persister-file/index.cjs +1 -1
  245. package/cjs/min/persisters/persister-file/index.cjs.gz +0 -0
  246. package/cjs/min/persisters/persister-file/with-schemas/index.cjs +1 -1
  247. package/cjs/min/persisters/persister-file/with-schemas/index.cjs.gz +0 -0
  248. package/cjs/min/persisters/persister-indexed-db/index.cjs +1 -1
  249. package/cjs/min/persisters/persister-indexed-db/index.cjs.gz +0 -0
  250. package/cjs/min/persisters/persister-indexed-db/with-schemas/index.cjs +1 -1
  251. package/cjs/min/persisters/persister-indexed-db/with-schemas/index.cjs.gz +0 -0
  252. package/cjs/min/persisters/persister-libsql/index.cjs +1 -1
  253. package/cjs/min/persisters/persister-libsql/index.cjs.gz +0 -0
  254. package/cjs/min/persisters/persister-libsql/with-schemas/index.cjs +1 -1
  255. package/cjs/min/persisters/persister-libsql/with-schemas/index.cjs.gz +0 -0
  256. package/cjs/min/persisters/persister-partykit-client/index.cjs +1 -1
  257. package/cjs/min/persisters/persister-partykit-client/index.cjs.gz +0 -0
  258. package/cjs/min/persisters/persister-partykit-client/with-schemas/index.cjs +1 -1
  259. package/cjs/min/persisters/persister-partykit-client/with-schemas/index.cjs.gz +0 -0
  260. package/cjs/min/persisters/persister-pglite/index.cjs +1 -1
  261. package/cjs/min/persisters/persister-pglite/index.cjs.gz +0 -0
  262. package/cjs/min/persisters/persister-pglite/with-schemas/index.cjs +1 -1
  263. package/cjs/min/persisters/persister-pglite/with-schemas/index.cjs.gz +0 -0
  264. package/cjs/min/persisters/persister-postgres/index.cjs +1 -1
  265. package/cjs/min/persisters/persister-postgres/index.cjs.gz +0 -0
  266. package/cjs/min/persisters/persister-postgres/with-schemas/index.cjs +1 -1
  267. package/cjs/min/persisters/persister-postgres/with-schemas/index.cjs.gz +0 -0
  268. package/cjs/min/persisters/persister-powersync/index.cjs +1 -1
  269. package/cjs/min/persisters/persister-powersync/index.cjs.gz +0 -0
  270. package/cjs/min/persisters/persister-powersync/with-schemas/index.cjs +1 -1
  271. package/cjs/min/persisters/persister-powersync/with-schemas/index.cjs.gz +0 -0
  272. package/cjs/min/persisters/persister-remote/index.cjs +1 -1
  273. package/cjs/min/persisters/persister-remote/index.cjs.gz +0 -0
  274. package/cjs/min/persisters/persister-remote/with-schemas/index.cjs +1 -1
  275. package/cjs/min/persisters/persister-remote/with-schemas/index.cjs.gz +0 -0
  276. package/cjs/min/persisters/persister-sqlite-wasm/index.cjs +1 -1
  277. package/cjs/min/persisters/persister-sqlite-wasm/index.cjs.gz +0 -0
  278. package/cjs/min/persisters/persister-sqlite-wasm/with-schemas/index.cjs +1 -1
  279. package/cjs/min/persisters/persister-sqlite-wasm/with-schemas/index.cjs.gz +0 -0
  280. package/cjs/min/persisters/persister-sqlite3/index.cjs +1 -1
  281. package/cjs/min/persisters/persister-sqlite3/index.cjs.gz +0 -0
  282. package/cjs/min/persisters/persister-sqlite3/with-schemas/index.cjs +1 -1
  283. package/cjs/min/persisters/persister-sqlite3/with-schemas/index.cjs.gz +0 -0
  284. package/cjs/min/persisters/persister-yjs/index.cjs +1 -1
  285. package/cjs/min/persisters/persister-yjs/index.cjs.gz +0 -0
  286. package/cjs/min/persisters/persister-yjs/with-schemas/index.cjs +1 -1
  287. package/cjs/min/persisters/persister-yjs/with-schemas/index.cjs.gz +0 -0
  288. package/cjs/min/persisters/with-schemas/index.cjs +1 -1
  289. package/cjs/min/persisters/with-schemas/index.cjs.gz +0 -0
  290. package/cjs/min/synchronizers/index.cjs +1 -1
  291. package/cjs/min/synchronizers/index.cjs.gz +0 -0
  292. package/cjs/min/synchronizers/synchronizer-broadcast-channel/index.cjs +1 -1
  293. package/cjs/min/synchronizers/synchronizer-broadcast-channel/index.cjs.gz +0 -0
  294. package/cjs/min/synchronizers/synchronizer-broadcast-channel/with-schemas/index.cjs +1 -1
  295. package/cjs/min/synchronizers/synchronizer-broadcast-channel/with-schemas/index.cjs.gz +0 -0
  296. package/cjs/min/synchronizers/synchronizer-local/index.cjs +1 -1
  297. package/cjs/min/synchronizers/synchronizer-local/index.cjs.gz +0 -0
  298. package/cjs/min/synchronizers/synchronizer-local/with-schemas/index.cjs +1 -1
  299. package/cjs/min/synchronizers/synchronizer-local/with-schemas/index.cjs.gz +0 -0
  300. package/cjs/min/synchronizers/synchronizer-ws-client/index.cjs +1 -1
  301. package/cjs/min/synchronizers/synchronizer-ws-client/index.cjs.gz +0 -0
  302. package/cjs/min/synchronizers/synchronizer-ws-client/with-schemas/index.cjs +1 -1
  303. package/cjs/min/synchronizers/synchronizer-ws-client/with-schemas/index.cjs.gz +0 -0
  304. package/cjs/min/synchronizers/synchronizer-ws-server/index.cjs +1 -1
  305. package/cjs/min/synchronizers/synchronizer-ws-server/index.cjs.gz +0 -0
  306. package/cjs/min/synchronizers/synchronizer-ws-server/with-schemas/index.cjs +1 -1
  307. package/cjs/min/synchronizers/synchronizer-ws-server/with-schemas/index.cjs.gz +0 -0
  308. package/cjs/min/synchronizers/synchronizer-ws-server-durable-object/index.cjs +1 -1
  309. package/cjs/min/synchronizers/synchronizer-ws-server-durable-object/index.cjs.gz +0 -0
  310. package/cjs/min/synchronizers/synchronizer-ws-server-durable-object/with-schemas/index.cjs +1 -1
  311. package/cjs/min/synchronizers/synchronizer-ws-server-durable-object/with-schemas/index.cjs.gz +0 -0
  312. package/cjs/min/synchronizers/with-schemas/index.cjs +1 -1
  313. package/cjs/min/synchronizers/with-schemas/index.cjs.gz +0 -0
  314. package/cjs/min/ui-react-inspector/index.cjs +1 -1
  315. package/cjs/min/ui-react-inspector/index.cjs.gz +0 -0
  316. package/cjs/min/ui-react-inspector/with-schemas/index.cjs +1 -1
  317. package/cjs/min/ui-react-inspector/with-schemas/index.cjs.gz +0 -0
  318. package/cjs/min/with-schemas/index.cjs +1 -1
  319. package/cjs/min/with-schemas/index.cjs.gz +0 -0
  320. package/cjs/persisters/index.cjs +21 -9
  321. package/cjs/persisters/persister-automerge/index.cjs +17 -8
  322. package/cjs/persisters/persister-automerge/with-schemas/index.cjs +17 -8
  323. package/cjs/persisters/persister-browser/index.cjs +17 -8
  324. package/cjs/persisters/persister-browser/with-schemas/index.cjs +17 -8
  325. package/cjs/persisters/persister-cr-sqlite-wasm/index.cjs +21 -9
  326. package/cjs/persisters/persister-cr-sqlite-wasm/with-schemas/index.cjs +21 -9
  327. package/cjs/persisters/persister-durable-object-storage/index.cjs +542 -0
  328. package/cjs/persisters/persister-durable-object-storage/with-schemas/index.cjs +542 -0
  329. package/cjs/persisters/persister-electric-sql/index.cjs +21 -9
  330. package/cjs/persisters/persister-electric-sql/with-schemas/index.cjs +21 -9
  331. package/cjs/persisters/persister-expo-sqlite/index.cjs +21 -9
  332. package/cjs/persisters/persister-expo-sqlite/with-schemas/index.cjs +21 -9
  333. package/cjs/persisters/persister-file/index.cjs +17 -8
  334. package/cjs/persisters/persister-file/with-schemas/index.cjs +17 -8
  335. package/cjs/persisters/persister-indexed-db/index.cjs +19 -9
  336. package/cjs/persisters/persister-indexed-db/with-schemas/index.cjs +19 -9
  337. package/cjs/persisters/persister-libsql/index.cjs +21 -9
  338. package/cjs/persisters/persister-libsql/with-schemas/index.cjs +21 -9
  339. package/cjs/persisters/persister-partykit-client/index.cjs +18 -9
  340. package/cjs/persisters/persister-partykit-client/with-schemas/index.cjs +18 -9
  341. package/cjs/persisters/persister-pglite/index.cjs +19 -8
  342. package/cjs/persisters/persister-pglite/with-schemas/index.cjs +19 -8
  343. package/cjs/persisters/persister-postgres/index.cjs +19 -8
  344. package/cjs/persisters/persister-postgres/with-schemas/index.cjs +19 -8
  345. package/cjs/persisters/persister-powersync/index.cjs +21 -9
  346. package/cjs/persisters/persister-powersync/with-schemas/index.cjs +21 -9
  347. package/cjs/persisters/persister-remote/index.cjs +19 -9
  348. package/cjs/persisters/persister-remote/with-schemas/index.cjs +19 -9
  349. package/cjs/persisters/persister-sqlite-wasm/index.cjs +21 -9
  350. package/cjs/persisters/persister-sqlite-wasm/with-schemas/index.cjs +21 -9
  351. package/cjs/persisters/persister-sqlite3/index.cjs +21 -9
  352. package/cjs/persisters/persister-sqlite3/with-schemas/index.cjs +21 -9
  353. package/cjs/persisters/persister-yjs/index.cjs +17 -8
  354. package/cjs/persisters/persister-yjs/with-schemas/index.cjs +17 -8
  355. package/cjs/persisters/with-schemas/index.cjs +21 -9
  356. package/cjs/synchronizers/index.cjs +119 -73
  357. package/cjs/synchronizers/synchronizer-broadcast-channel/index.cjs +119 -73
  358. package/cjs/synchronizers/synchronizer-broadcast-channel/with-schemas/index.cjs +119 -73
  359. package/cjs/synchronizers/synchronizer-local/index.cjs +128 -85
  360. package/cjs/synchronizers/synchronizer-local/with-schemas/index.cjs +128 -85
  361. package/cjs/synchronizers/synchronizer-ws-client/index.cjs +137 -78
  362. package/cjs/synchronizers/synchronizer-ws-client/with-schemas/index.cjs +137 -78
  363. package/cjs/synchronizers/synchronizer-ws-server/index.cjs +148 -77
  364. package/cjs/synchronizers/synchronizer-ws-server/with-schemas/index.cjs +148 -77
  365. package/cjs/synchronizers/synchronizer-ws-server-durable-object/index.cjs +712 -17
  366. package/cjs/synchronizers/synchronizer-ws-server-durable-object/with-schemas/index.cjs +712 -17
  367. package/cjs/synchronizers/synchronizer-ws-server-simple/index.cjs +2 -1
  368. package/cjs/synchronizers/synchronizer-ws-server-simple/with-schemas/index.cjs +2 -1
  369. package/cjs/synchronizers/with-schemas/index.cjs +119 -73
  370. package/cjs/ui-react-inspector/index.cjs +17 -8
  371. package/cjs/ui-react-inspector/with-schemas/index.cjs +17 -8
  372. package/cjs/with-schemas/index.cjs +31 -27
  373. package/es6/index.js +32 -27
  374. package/es6/indexes/index.js +1 -1
  375. package/es6/indexes/with-schemas/index.js +1 -1
  376. package/es6/mergeable-store/index.js +31 -27
  377. package/es6/mergeable-store/with-schemas/index.js +31 -27
  378. package/es6/metrics/index.js +1 -1
  379. package/es6/metrics/with-schemas/index.js +1 -1
  380. package/es6/min/index.js +1 -1
  381. package/es6/min/index.js.gz +0 -0
  382. package/es6/min/indexes/index.js +1 -1
  383. package/es6/min/indexes/index.js.gz +0 -0
  384. package/es6/min/indexes/with-schemas/index.js +1 -1
  385. package/es6/min/indexes/with-schemas/index.js.gz +0 -0
  386. package/es6/min/mergeable-store/index.js +1 -1
  387. package/es6/min/mergeable-store/index.js.gz +0 -0
  388. package/es6/min/mergeable-store/with-schemas/index.js +1 -1
  389. package/es6/min/mergeable-store/with-schemas/index.js.gz +0 -0
  390. package/es6/min/metrics/index.js +1 -1
  391. package/es6/min/metrics/index.js.gz +0 -0
  392. package/es6/min/metrics/with-schemas/index.js +1 -1
  393. package/es6/min/metrics/with-schemas/index.js.gz +0 -0
  394. package/es6/min/persisters/index.js +1 -1
  395. package/es6/min/persisters/index.js.gz +0 -0
  396. package/es6/min/persisters/persister-automerge/index.js +1 -1
  397. package/es6/min/persisters/persister-automerge/index.js.gz +0 -0
  398. package/es6/min/persisters/persister-automerge/with-schemas/index.js +1 -1
  399. package/es6/min/persisters/persister-automerge/with-schemas/index.js.gz +0 -0
  400. package/es6/min/persisters/persister-browser/index.js +1 -1
  401. package/es6/min/persisters/persister-browser/index.js.gz +0 -0
  402. package/es6/min/persisters/persister-browser/with-schemas/index.js +1 -1
  403. package/es6/min/persisters/persister-browser/with-schemas/index.js.gz +0 -0
  404. package/es6/min/persisters/persister-cr-sqlite-wasm/index.js +1 -1
  405. package/es6/min/persisters/persister-cr-sqlite-wasm/index.js.gz +0 -0
  406. package/es6/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.js +1 -1
  407. package/es6/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.js.gz +0 -0
  408. package/es6/min/persisters/persister-durable-object-storage/index.js +1 -0
  409. package/es6/min/persisters/persister-durable-object-storage/index.js.gz +0 -0
  410. package/es6/min/persisters/persister-durable-object-storage/with-schemas/index.js +1 -0
  411. package/es6/min/persisters/persister-durable-object-storage/with-schemas/index.js.gz +0 -0
  412. package/es6/min/persisters/persister-electric-sql/index.js +1 -1
  413. package/es6/min/persisters/persister-electric-sql/index.js.gz +0 -0
  414. package/es6/min/persisters/persister-electric-sql/with-schemas/index.js +1 -1
  415. package/es6/min/persisters/persister-electric-sql/with-schemas/index.js.gz +0 -0
  416. package/es6/min/persisters/persister-expo-sqlite/index.js +1 -1
  417. package/es6/min/persisters/persister-expo-sqlite/index.js.gz +0 -0
  418. package/es6/min/persisters/persister-expo-sqlite/with-schemas/index.js +1 -1
  419. package/es6/min/persisters/persister-expo-sqlite/with-schemas/index.js.gz +0 -0
  420. package/es6/min/persisters/persister-file/index.js +1 -1
  421. package/es6/min/persisters/persister-file/index.js.gz +0 -0
  422. package/es6/min/persisters/persister-file/with-schemas/index.js +1 -1
  423. package/es6/min/persisters/persister-file/with-schemas/index.js.gz +0 -0
  424. package/es6/min/persisters/persister-indexed-db/index.js +1 -1
  425. package/es6/min/persisters/persister-indexed-db/index.js.gz +0 -0
  426. package/es6/min/persisters/persister-indexed-db/with-schemas/index.js +1 -1
  427. package/es6/min/persisters/persister-indexed-db/with-schemas/index.js.gz +0 -0
  428. package/es6/min/persisters/persister-libsql/index.js +1 -1
  429. package/es6/min/persisters/persister-libsql/index.js.gz +0 -0
  430. package/es6/min/persisters/persister-libsql/with-schemas/index.js +1 -1
  431. package/es6/min/persisters/persister-libsql/with-schemas/index.js.gz +0 -0
  432. package/es6/min/persisters/persister-partykit-client/index.js +1 -1
  433. package/es6/min/persisters/persister-partykit-client/index.js.gz +0 -0
  434. package/es6/min/persisters/persister-partykit-client/with-schemas/index.js +1 -1
  435. package/es6/min/persisters/persister-partykit-client/with-schemas/index.js.gz +0 -0
  436. package/es6/min/persisters/persister-pglite/index.js +1 -1
  437. package/es6/min/persisters/persister-pglite/index.js.gz +0 -0
  438. package/es6/min/persisters/persister-pglite/with-schemas/index.js +1 -1
  439. package/es6/min/persisters/persister-pglite/with-schemas/index.js.gz +0 -0
  440. package/es6/min/persisters/persister-postgres/index.js +1 -1
  441. package/es6/min/persisters/persister-postgres/index.js.gz +0 -0
  442. package/es6/min/persisters/persister-postgres/with-schemas/index.js +1 -1
  443. package/es6/min/persisters/persister-postgres/with-schemas/index.js.gz +0 -0
  444. package/es6/min/persisters/persister-powersync/index.js +1 -1
  445. package/es6/min/persisters/persister-powersync/index.js.gz +0 -0
  446. package/es6/min/persisters/persister-powersync/with-schemas/index.js +1 -1
  447. package/es6/min/persisters/persister-powersync/with-schemas/index.js.gz +0 -0
  448. package/es6/min/persisters/persister-remote/index.js +1 -1
  449. package/es6/min/persisters/persister-remote/index.js.gz +0 -0
  450. package/es6/min/persisters/persister-remote/with-schemas/index.js +1 -1
  451. package/es6/min/persisters/persister-remote/with-schemas/index.js.gz +0 -0
  452. package/es6/min/persisters/persister-sqlite-wasm/index.js +1 -1
  453. package/es6/min/persisters/persister-sqlite-wasm/index.js.gz +0 -0
  454. package/es6/min/persisters/persister-sqlite-wasm/with-schemas/index.js +1 -1
  455. package/es6/min/persisters/persister-sqlite-wasm/with-schemas/index.js.gz +0 -0
  456. package/es6/min/persisters/persister-sqlite3/index.js +1 -1
  457. package/es6/min/persisters/persister-sqlite3/index.js.gz +0 -0
  458. package/es6/min/persisters/persister-sqlite3/with-schemas/index.js +1 -1
  459. package/es6/min/persisters/persister-sqlite3/with-schemas/index.js.gz +0 -0
  460. package/es6/min/persisters/persister-yjs/index.js +1 -1
  461. package/es6/min/persisters/persister-yjs/index.js.gz +0 -0
  462. package/es6/min/persisters/persister-yjs/with-schemas/index.js +1 -1
  463. package/es6/min/persisters/persister-yjs/with-schemas/index.js.gz +0 -0
  464. package/es6/min/persisters/with-schemas/index.js +1 -1
  465. package/es6/min/persisters/with-schemas/index.js.gz +0 -0
  466. package/es6/min/queries/index.js +1 -1
  467. package/es6/min/queries/index.js.gz +0 -0
  468. package/es6/min/queries/with-schemas/index.js +1 -1
  469. package/es6/min/queries/with-schemas/index.js.gz +0 -0
  470. package/es6/min/relationships/index.js +1 -1
  471. package/es6/min/relationships/index.js.gz +0 -0
  472. package/es6/min/relationships/with-schemas/index.js +1 -1
  473. package/es6/min/relationships/with-schemas/index.js.gz +0 -0
  474. package/es6/min/synchronizers/index.js +1 -1
  475. package/es6/min/synchronizers/index.js.gz +0 -0
  476. package/es6/min/synchronizers/synchronizer-broadcast-channel/index.js +1 -1
  477. package/es6/min/synchronizers/synchronizer-broadcast-channel/index.js.gz +0 -0
  478. package/es6/min/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js +1 -1
  479. package/es6/min/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js.gz +0 -0
  480. package/es6/min/synchronizers/synchronizer-local/index.js +1 -1
  481. package/es6/min/synchronizers/synchronizer-local/index.js.gz +0 -0
  482. package/es6/min/synchronizers/synchronizer-local/with-schemas/index.js +1 -1
  483. package/es6/min/synchronizers/synchronizer-local/with-schemas/index.js.gz +0 -0
  484. package/es6/min/synchronizers/synchronizer-ws-client/index.js +1 -1
  485. package/es6/min/synchronizers/synchronizer-ws-client/index.js.gz +0 -0
  486. package/es6/min/synchronizers/synchronizer-ws-client/with-schemas/index.js +1 -1
  487. package/es6/min/synchronizers/synchronizer-ws-client/with-schemas/index.js.gz +0 -0
  488. package/es6/min/synchronizers/synchronizer-ws-server/index.js +1 -1
  489. package/es6/min/synchronizers/synchronizer-ws-server/index.js.gz +0 -0
  490. package/es6/min/synchronizers/synchronizer-ws-server/with-schemas/index.js +1 -1
  491. package/es6/min/synchronizers/synchronizer-ws-server/with-schemas/index.js.gz +0 -0
  492. package/es6/min/synchronizers/synchronizer-ws-server-durable-object/index.js +1 -1
  493. package/es6/min/synchronizers/synchronizer-ws-server-durable-object/index.js.gz +0 -0
  494. package/es6/min/synchronizers/synchronizer-ws-server-durable-object/with-schemas/index.js +1 -1
  495. package/es6/min/synchronizers/synchronizer-ws-server-durable-object/with-schemas/index.js.gz +0 -0
  496. package/es6/min/synchronizers/with-schemas/index.js +1 -1
  497. package/es6/min/synchronizers/with-schemas/index.js.gz +0 -0
  498. package/es6/min/ui-react-dom/index.js +1 -1
  499. package/es6/min/ui-react-dom/index.js.gz +0 -0
  500. package/es6/min/ui-react-dom/with-schemas/index.js +1 -1
  501. package/es6/min/ui-react-dom/with-schemas/index.js.gz +0 -0
  502. package/es6/min/ui-react-inspector/index.js +1 -1
  503. package/es6/min/ui-react-inspector/index.js.gz +0 -0
  504. package/es6/min/ui-react-inspector/with-schemas/index.js +1 -1
  505. package/es6/min/ui-react-inspector/with-schemas/index.js.gz +0 -0
  506. package/es6/min/with-schemas/index.js +1 -1
  507. package/es6/min/with-schemas/index.js.gz +0 -0
  508. package/es6/persisters/index.js +21 -9
  509. package/es6/persisters/persister-automerge/index.js +17 -8
  510. package/es6/persisters/persister-automerge/with-schemas/index.js +17 -8
  511. package/es6/persisters/persister-browser/index.js +17 -8
  512. package/es6/persisters/persister-browser/with-schemas/index.js +17 -8
  513. package/es6/persisters/persister-cr-sqlite-wasm/index.js +21 -9
  514. package/es6/persisters/persister-cr-sqlite-wasm/with-schemas/index.js +21 -9
  515. package/es6/persisters/persister-durable-object-storage/index.js +684 -0
  516. package/es6/persisters/persister-durable-object-storage/with-schemas/index.js +684 -0
  517. package/es6/persisters/persister-electric-sql/index.js +21 -9
  518. package/es6/persisters/persister-electric-sql/with-schemas/index.js +21 -9
  519. package/es6/persisters/persister-expo-sqlite/index.js +21 -9
  520. package/es6/persisters/persister-expo-sqlite/with-schemas/index.js +21 -9
  521. package/es6/persisters/persister-file/index.js +18 -9
  522. package/es6/persisters/persister-file/with-schemas/index.js +18 -9
  523. package/es6/persisters/persister-indexed-db/index.js +19 -9
  524. package/es6/persisters/persister-indexed-db/with-schemas/index.js +19 -9
  525. package/es6/persisters/persister-libsql/index.js +21 -9
  526. package/es6/persisters/persister-libsql/with-schemas/index.js +21 -9
  527. package/es6/persisters/persister-partykit-client/index.js +23 -11
  528. package/es6/persisters/persister-partykit-client/with-schemas/index.js +23 -11
  529. package/es6/persisters/persister-pglite/index.js +19 -8
  530. package/es6/persisters/persister-pglite/with-schemas/index.js +19 -8
  531. package/es6/persisters/persister-postgres/index.js +19 -8
  532. package/es6/persisters/persister-postgres/with-schemas/index.js +19 -8
  533. package/es6/persisters/persister-powersync/index.js +21 -9
  534. package/es6/persisters/persister-powersync/with-schemas/index.js +21 -9
  535. package/es6/persisters/persister-remote/index.js +19 -9
  536. package/es6/persisters/persister-remote/with-schemas/index.js +19 -9
  537. package/es6/persisters/persister-sqlite-wasm/index.js +21 -9
  538. package/es6/persisters/persister-sqlite-wasm/with-schemas/index.js +21 -9
  539. package/es6/persisters/persister-sqlite3/index.js +21 -9
  540. package/es6/persisters/persister-sqlite3/with-schemas/index.js +21 -9
  541. package/es6/persisters/persister-yjs/index.js +17 -8
  542. package/es6/persisters/persister-yjs/with-schemas/index.js +17 -8
  543. package/es6/persisters/with-schemas/index.js +21 -9
  544. package/es6/queries/index.js +1 -0
  545. package/es6/queries/with-schemas/index.js +1 -0
  546. package/es6/relationships/index.js +1 -1
  547. package/es6/relationships/with-schemas/index.js +1 -1
  548. package/es6/synchronizers/index.js +142 -93
  549. package/es6/synchronizers/synchronizer-broadcast-channel/index.js +142 -93
  550. package/es6/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js +142 -93
  551. package/es6/synchronizers/synchronizer-local/index.js +145 -97
  552. package/es6/synchronizers/synchronizer-local/with-schemas/index.js +145 -97
  553. package/es6/synchronizers/synchronizer-ws-client/index.js +160 -98
  554. package/es6/synchronizers/synchronizer-ws-client/with-schemas/index.js +160 -98
  555. package/es6/synchronizers/synchronizer-ws-server/index.js +171 -97
  556. package/es6/synchronizers/synchronizer-ws-server/with-schemas/index.js +171 -97
  557. package/es6/synchronizers/synchronizer-ws-server-durable-object/index.js +980 -20
  558. package/es6/synchronizers/synchronizer-ws-server-durable-object/with-schemas/index.js +980 -20
  559. package/es6/synchronizers/synchronizer-ws-server-simple/index.js +2 -1
  560. package/es6/synchronizers/synchronizer-ws-server-simple/with-schemas/index.js +2 -1
  561. package/es6/synchronizers/with-schemas/index.js +142 -93
  562. package/es6/ui-react-dom/index.js +8 -8
  563. package/es6/ui-react-dom/with-schemas/index.js +8 -8
  564. package/es6/ui-react-inspector/index.js +21 -12
  565. package/es6/ui-react-inspector/with-schemas/index.js +21 -12
  566. package/es6/with-schemas/index.js +32 -27
  567. package/index.js +31 -27
  568. package/mergeable-store/index.js +31 -27
  569. package/mergeable-store/with-schemas/index.js +31 -27
  570. package/min/index.js +1 -1
  571. package/min/index.js.gz +0 -0
  572. package/min/mergeable-store/index.js +1 -1
  573. package/min/mergeable-store/index.js.gz +0 -0
  574. package/min/mergeable-store/with-schemas/index.js +1 -1
  575. package/min/mergeable-store/with-schemas/index.js.gz +0 -0
  576. package/min/persisters/index.js +1 -1
  577. package/min/persisters/index.js.gz +0 -0
  578. package/min/persisters/persister-automerge/index.js +1 -1
  579. package/min/persisters/persister-automerge/index.js.gz +0 -0
  580. package/min/persisters/persister-automerge/with-schemas/index.js +1 -1
  581. package/min/persisters/persister-automerge/with-schemas/index.js.gz +0 -0
  582. package/min/persisters/persister-browser/index.js +1 -1
  583. package/min/persisters/persister-browser/index.js.gz +0 -0
  584. package/min/persisters/persister-browser/with-schemas/index.js +1 -1
  585. package/min/persisters/persister-browser/with-schemas/index.js.gz +0 -0
  586. package/min/persisters/persister-cr-sqlite-wasm/index.js +1 -1
  587. package/min/persisters/persister-cr-sqlite-wasm/index.js.gz +0 -0
  588. package/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.js +1 -1
  589. package/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.js.gz +0 -0
  590. package/min/persisters/persister-durable-object-storage/index.js +1 -0
  591. package/min/persisters/persister-durable-object-storage/index.js.gz +0 -0
  592. package/min/persisters/persister-durable-object-storage/with-schemas/index.js +1 -0
  593. package/min/persisters/persister-durable-object-storage/with-schemas/index.js.gz +0 -0
  594. package/min/persisters/persister-electric-sql/index.js +1 -1
  595. package/min/persisters/persister-electric-sql/index.js.gz +0 -0
  596. package/min/persisters/persister-electric-sql/with-schemas/index.js +1 -1
  597. package/min/persisters/persister-electric-sql/with-schemas/index.js.gz +0 -0
  598. package/min/persisters/persister-expo-sqlite/index.js +1 -1
  599. package/min/persisters/persister-expo-sqlite/index.js.gz +0 -0
  600. package/min/persisters/persister-expo-sqlite/with-schemas/index.js +1 -1
  601. package/min/persisters/persister-expo-sqlite/with-schemas/index.js.gz +0 -0
  602. package/min/persisters/persister-file/index.js +1 -1
  603. package/min/persisters/persister-file/index.js.gz +0 -0
  604. package/min/persisters/persister-file/with-schemas/index.js +1 -1
  605. package/min/persisters/persister-file/with-schemas/index.js.gz +0 -0
  606. package/min/persisters/persister-indexed-db/index.js +1 -1
  607. package/min/persisters/persister-indexed-db/index.js.gz +0 -0
  608. package/min/persisters/persister-indexed-db/with-schemas/index.js +1 -1
  609. package/min/persisters/persister-indexed-db/with-schemas/index.js.gz +0 -0
  610. package/min/persisters/persister-libsql/index.js +1 -1
  611. package/min/persisters/persister-libsql/index.js.gz +0 -0
  612. package/min/persisters/persister-libsql/with-schemas/index.js +1 -1
  613. package/min/persisters/persister-libsql/with-schemas/index.js.gz +0 -0
  614. package/min/persisters/persister-partykit-client/index.js +1 -1
  615. package/min/persisters/persister-partykit-client/index.js.gz +0 -0
  616. package/min/persisters/persister-partykit-client/with-schemas/index.js +1 -1
  617. package/min/persisters/persister-partykit-client/with-schemas/index.js.gz +0 -0
  618. package/min/persisters/persister-pglite/index.js +1 -1
  619. package/min/persisters/persister-pglite/index.js.gz +0 -0
  620. package/min/persisters/persister-pglite/with-schemas/index.js +1 -1
  621. package/min/persisters/persister-pglite/with-schemas/index.js.gz +0 -0
  622. package/min/persisters/persister-postgres/index.js +1 -1
  623. package/min/persisters/persister-postgres/index.js.gz +0 -0
  624. package/min/persisters/persister-postgres/with-schemas/index.js +1 -1
  625. package/min/persisters/persister-postgres/with-schemas/index.js.gz +0 -0
  626. package/min/persisters/persister-powersync/index.js +1 -1
  627. package/min/persisters/persister-powersync/index.js.gz +0 -0
  628. package/min/persisters/persister-powersync/with-schemas/index.js +1 -1
  629. package/min/persisters/persister-powersync/with-schemas/index.js.gz +0 -0
  630. package/min/persisters/persister-remote/index.js +1 -1
  631. package/min/persisters/persister-remote/index.js.gz +0 -0
  632. package/min/persisters/persister-remote/with-schemas/index.js +1 -1
  633. package/min/persisters/persister-remote/with-schemas/index.js.gz +0 -0
  634. package/min/persisters/persister-sqlite-wasm/index.js +1 -1
  635. package/min/persisters/persister-sqlite-wasm/index.js.gz +0 -0
  636. package/min/persisters/persister-sqlite-wasm/with-schemas/index.js +1 -1
  637. package/min/persisters/persister-sqlite-wasm/with-schemas/index.js.gz +0 -0
  638. package/min/persisters/persister-sqlite3/index.js +1 -1
  639. package/min/persisters/persister-sqlite3/index.js.gz +0 -0
  640. package/min/persisters/persister-sqlite3/with-schemas/index.js +1 -1
  641. package/min/persisters/persister-sqlite3/with-schemas/index.js.gz +0 -0
  642. package/min/persisters/persister-yjs/index.js +1 -1
  643. package/min/persisters/persister-yjs/index.js.gz +0 -0
  644. package/min/persisters/persister-yjs/with-schemas/index.js +1 -1
  645. package/min/persisters/persister-yjs/with-schemas/index.js.gz +0 -0
  646. package/min/persisters/with-schemas/index.js +1 -1
  647. package/min/persisters/with-schemas/index.js.gz +0 -0
  648. package/min/synchronizers/index.js +1 -1
  649. package/min/synchronizers/index.js.gz +0 -0
  650. package/min/synchronizers/synchronizer-broadcast-channel/index.js +1 -1
  651. package/min/synchronizers/synchronizer-broadcast-channel/index.js.gz +0 -0
  652. package/min/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js +1 -1
  653. package/min/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js.gz +0 -0
  654. package/min/synchronizers/synchronizer-local/index.js +1 -1
  655. package/min/synchronizers/synchronizer-local/index.js.gz +0 -0
  656. package/min/synchronizers/synchronizer-local/with-schemas/index.js +1 -1
  657. package/min/synchronizers/synchronizer-local/with-schemas/index.js.gz +0 -0
  658. package/min/synchronizers/synchronizer-ws-client/index.js +1 -1
  659. package/min/synchronizers/synchronizer-ws-client/index.js.gz +0 -0
  660. package/min/synchronizers/synchronizer-ws-client/with-schemas/index.js +1 -1
  661. package/min/synchronizers/synchronizer-ws-client/with-schemas/index.js.gz +0 -0
  662. package/min/synchronizers/synchronizer-ws-server/index.js +1 -1
  663. package/min/synchronizers/synchronizer-ws-server/index.js.gz +0 -0
  664. package/min/synchronizers/synchronizer-ws-server/with-schemas/index.js +1 -1
  665. package/min/synchronizers/synchronizer-ws-server/with-schemas/index.js.gz +0 -0
  666. package/min/synchronizers/synchronizer-ws-server-durable-object/index.js +1 -1
  667. package/min/synchronizers/synchronizer-ws-server-durable-object/index.js.gz +0 -0
  668. package/min/synchronizers/synchronizer-ws-server-durable-object/with-schemas/index.js +1 -1
  669. package/min/synchronizers/synchronizer-ws-server-durable-object/with-schemas/index.js.gz +0 -0
  670. package/min/synchronizers/with-schemas/index.js +1 -1
  671. package/min/synchronizers/with-schemas/index.js.gz +0 -0
  672. package/min/ui-react-dom/index.js +1 -1
  673. package/min/ui-react-dom/index.js.gz +0 -0
  674. package/min/ui-react-dom/with-schemas/index.js +1 -1
  675. package/min/ui-react-dom/with-schemas/index.js.gz +0 -0
  676. package/min/ui-react-inspector/index.js +1 -1
  677. package/min/ui-react-inspector/index.js.gz +0 -0
  678. package/min/ui-react-inspector/with-schemas/index.js +1 -1
  679. package/min/ui-react-inspector/with-schemas/index.js.gz +0 -0
  680. package/min/with-schemas/index.js +1 -1
  681. package/min/with-schemas/index.js.gz +0 -0
  682. package/package.json +112 -8
  683. package/persisters/index.js +21 -9
  684. package/persisters/persister-automerge/index.js +17 -8
  685. package/persisters/persister-automerge/with-schemas/index.js +17 -8
  686. package/persisters/persister-browser/index.js +17 -8
  687. package/persisters/persister-browser/with-schemas/index.js +17 -8
  688. package/persisters/persister-cr-sqlite-wasm/index.js +21 -9
  689. package/persisters/persister-cr-sqlite-wasm/with-schemas/index.js +21 -9
  690. package/persisters/persister-durable-object-storage/index.js +539 -0
  691. package/persisters/persister-durable-object-storage/with-schemas/index.js +539 -0
  692. package/persisters/persister-electric-sql/index.js +21 -9
  693. package/persisters/persister-electric-sql/with-schemas/index.js +21 -9
  694. package/persisters/persister-expo-sqlite/index.js +21 -9
  695. package/persisters/persister-expo-sqlite/with-schemas/index.js +21 -9
  696. package/persisters/persister-file/index.js +18 -9
  697. package/persisters/persister-file/with-schemas/index.js +18 -9
  698. package/persisters/persister-indexed-db/index.js +19 -9
  699. package/persisters/persister-indexed-db/with-schemas/index.js +19 -9
  700. package/persisters/persister-libsql/index.js +21 -9
  701. package/persisters/persister-libsql/with-schemas/index.js +21 -9
  702. package/persisters/persister-partykit-client/index.js +18 -9
  703. package/persisters/persister-partykit-client/with-schemas/index.js +18 -9
  704. package/persisters/persister-pglite/index.js +19 -8
  705. package/persisters/persister-pglite/with-schemas/index.js +19 -8
  706. package/persisters/persister-postgres/index.js +19 -8
  707. package/persisters/persister-postgres/with-schemas/index.js +19 -8
  708. package/persisters/persister-powersync/index.js +21 -9
  709. package/persisters/persister-powersync/with-schemas/index.js +21 -9
  710. package/persisters/persister-remote/index.js +19 -9
  711. package/persisters/persister-remote/with-schemas/index.js +19 -9
  712. package/persisters/persister-sqlite-wasm/index.js +21 -9
  713. package/persisters/persister-sqlite-wasm/with-schemas/index.js +21 -9
  714. package/persisters/persister-sqlite3/index.js +21 -9
  715. package/persisters/persister-sqlite3/with-schemas/index.js +21 -9
  716. package/persisters/persister-yjs/index.js +17 -8
  717. package/persisters/persister-yjs/with-schemas/index.js +17 -8
  718. package/persisters/with-schemas/index.js +21 -9
  719. package/readme.md +2 -2
  720. package/releases.md +23 -1
  721. package/synchronizers/index.js +119 -73
  722. package/synchronizers/synchronizer-broadcast-channel/index.js +119 -73
  723. package/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js +119 -73
  724. package/synchronizers/synchronizer-local/index.js +128 -85
  725. package/synchronizers/synchronizer-local/with-schemas/index.js +128 -85
  726. package/synchronizers/synchronizer-ws-client/index.js +137 -78
  727. package/synchronizers/synchronizer-ws-client/with-schemas/index.js +137 -78
  728. package/synchronizers/synchronizer-ws-server/index.js +148 -77
  729. package/synchronizers/synchronizer-ws-server/with-schemas/index.js +148 -77
  730. package/synchronizers/synchronizer-ws-server-durable-object/index.js +712 -17
  731. package/synchronizers/synchronizer-ws-server-durable-object/with-schemas/index.js +712 -17
  732. package/synchronizers/synchronizer-ws-server-simple/index.js +2 -1
  733. package/synchronizers/synchronizer-ws-server-simple/with-schemas/index.js +2 -1
  734. package/synchronizers/with-schemas/index.js +119 -73
  735. package/ui-react-dom/index.js +8 -8
  736. package/ui-react-dom/with-schemas/index.js +8 -8
  737. package/ui-react-inspector/index.js +21 -12
  738. package/ui-react-inspector/with-schemas/index.js +21 -12
  739. package/umd/es6/index.js +32 -27
  740. package/umd/es6/indexes/index.js +5 -1
  741. package/umd/es6/indexes/with-schemas/index.js +5 -1
  742. package/umd/es6/mergeable-store/index.js +31 -27
  743. package/umd/es6/mergeable-store/with-schemas/index.js +31 -27
  744. package/umd/es6/metrics/index.js +5 -1
  745. package/umd/es6/metrics/with-schemas/index.js +5 -1
  746. package/umd/es6/min/index.js +1 -1
  747. package/umd/es6/min/index.js.gz +0 -0
  748. package/umd/es6/min/indexes/index.js +1 -1
  749. package/umd/es6/min/indexes/index.js.gz +0 -0
  750. package/umd/es6/min/indexes/with-schemas/index.js +1 -1
  751. package/umd/es6/min/indexes/with-schemas/index.js.gz +0 -0
  752. package/umd/es6/min/mergeable-store/index.js +1 -1
  753. package/umd/es6/min/mergeable-store/index.js.gz +0 -0
  754. package/umd/es6/min/mergeable-store/with-schemas/index.js +1 -1
  755. package/umd/es6/min/mergeable-store/with-schemas/index.js.gz +0 -0
  756. package/umd/es6/min/metrics/index.js +1 -1
  757. package/umd/es6/min/metrics/index.js.gz +0 -0
  758. package/umd/es6/min/metrics/with-schemas/index.js +1 -1
  759. package/umd/es6/min/metrics/with-schemas/index.js.gz +0 -0
  760. package/umd/es6/min/persisters/index.js +1 -1
  761. package/umd/es6/min/persisters/index.js.gz +0 -0
  762. package/umd/es6/min/persisters/persister-automerge/index.js +1 -1
  763. package/umd/es6/min/persisters/persister-automerge/index.js.gz +0 -0
  764. package/umd/es6/min/persisters/persister-automerge/with-schemas/index.js +1 -1
  765. package/umd/es6/min/persisters/persister-automerge/with-schemas/index.js.gz +0 -0
  766. package/umd/es6/min/persisters/persister-browser/index.js +1 -1
  767. package/umd/es6/min/persisters/persister-browser/index.js.gz +0 -0
  768. package/umd/es6/min/persisters/persister-browser/with-schemas/index.js +1 -1
  769. package/umd/es6/min/persisters/persister-browser/with-schemas/index.js.gz +0 -0
  770. package/umd/es6/min/persisters/persister-cr-sqlite-wasm/index.js +1 -1
  771. package/umd/es6/min/persisters/persister-cr-sqlite-wasm/index.js.gz +0 -0
  772. package/umd/es6/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.js +1 -1
  773. package/umd/es6/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.js.gz +0 -0
  774. package/umd/es6/min/persisters/persister-durable-object-storage/index.js +1 -0
  775. package/umd/es6/min/persisters/persister-durable-object-storage/index.js.gz +0 -0
  776. package/umd/es6/min/persisters/persister-durable-object-storage/with-schemas/index.js +1 -0
  777. package/umd/es6/min/persisters/persister-durable-object-storage/with-schemas/index.js.gz +0 -0
  778. package/umd/es6/min/persisters/persister-electric-sql/index.js +1 -1
  779. package/umd/es6/min/persisters/persister-electric-sql/index.js.gz +0 -0
  780. package/umd/es6/min/persisters/persister-electric-sql/with-schemas/index.js +1 -1
  781. package/umd/es6/min/persisters/persister-electric-sql/with-schemas/index.js.gz +0 -0
  782. package/umd/es6/min/persisters/persister-expo-sqlite/index.js +1 -1
  783. package/umd/es6/min/persisters/persister-expo-sqlite/index.js.gz +0 -0
  784. package/umd/es6/min/persisters/persister-expo-sqlite/with-schemas/index.js +1 -1
  785. package/umd/es6/min/persisters/persister-expo-sqlite/with-schemas/index.js.gz +0 -0
  786. package/umd/es6/min/persisters/persister-file/index.js +1 -1
  787. package/umd/es6/min/persisters/persister-file/index.js.gz +0 -0
  788. package/umd/es6/min/persisters/persister-file/with-schemas/index.js +1 -1
  789. package/umd/es6/min/persisters/persister-file/with-schemas/index.js.gz +0 -0
  790. package/umd/es6/min/persisters/persister-indexed-db/index.js +1 -1
  791. package/umd/es6/min/persisters/persister-indexed-db/index.js.gz +0 -0
  792. package/umd/es6/min/persisters/persister-indexed-db/with-schemas/index.js +1 -1
  793. package/umd/es6/min/persisters/persister-indexed-db/with-schemas/index.js.gz +0 -0
  794. package/umd/es6/min/persisters/persister-libsql/index.js +1 -1
  795. package/umd/es6/min/persisters/persister-libsql/index.js.gz +0 -0
  796. package/umd/es6/min/persisters/persister-libsql/with-schemas/index.js +1 -1
  797. package/umd/es6/min/persisters/persister-libsql/with-schemas/index.js.gz +0 -0
  798. package/umd/es6/min/persisters/persister-partykit-client/index.js +1 -1
  799. package/umd/es6/min/persisters/persister-partykit-client/index.js.gz +0 -0
  800. package/umd/es6/min/persisters/persister-partykit-client/with-schemas/index.js +1 -1
  801. package/umd/es6/min/persisters/persister-partykit-client/with-schemas/index.js.gz +0 -0
  802. package/umd/es6/min/persisters/persister-pglite/index.js +1 -1
  803. package/umd/es6/min/persisters/persister-pglite/index.js.gz +0 -0
  804. package/umd/es6/min/persisters/persister-pglite/with-schemas/index.js +1 -1
  805. package/umd/es6/min/persisters/persister-pglite/with-schemas/index.js.gz +0 -0
  806. package/umd/es6/min/persisters/persister-postgres/index.js +1 -1
  807. package/umd/es6/min/persisters/persister-postgres/index.js.gz +0 -0
  808. package/umd/es6/min/persisters/persister-postgres/with-schemas/index.js +1 -1
  809. package/umd/es6/min/persisters/persister-postgres/with-schemas/index.js.gz +0 -0
  810. package/umd/es6/min/persisters/persister-powersync/index.js +1 -1
  811. package/umd/es6/min/persisters/persister-powersync/index.js.gz +0 -0
  812. package/umd/es6/min/persisters/persister-powersync/with-schemas/index.js +1 -1
  813. package/umd/es6/min/persisters/persister-powersync/with-schemas/index.js.gz +0 -0
  814. package/umd/es6/min/persisters/persister-remote/index.js +1 -1
  815. package/umd/es6/min/persisters/persister-remote/index.js.gz +0 -0
  816. package/umd/es6/min/persisters/persister-remote/with-schemas/index.js +1 -1
  817. package/umd/es6/min/persisters/persister-remote/with-schemas/index.js.gz +0 -0
  818. package/umd/es6/min/persisters/persister-sqlite-wasm/index.js +1 -1
  819. package/umd/es6/min/persisters/persister-sqlite-wasm/index.js.gz +0 -0
  820. package/umd/es6/min/persisters/persister-sqlite-wasm/with-schemas/index.js +1 -1
  821. package/umd/es6/min/persisters/persister-sqlite-wasm/with-schemas/index.js.gz +0 -0
  822. package/umd/es6/min/persisters/persister-sqlite3/index.js +1 -1
  823. package/umd/es6/min/persisters/persister-sqlite3/index.js.gz +0 -0
  824. package/umd/es6/min/persisters/persister-sqlite3/with-schemas/index.js +1 -1
  825. package/umd/es6/min/persisters/persister-sqlite3/with-schemas/index.js.gz +0 -0
  826. package/umd/es6/min/persisters/persister-yjs/index.js +1 -1
  827. package/umd/es6/min/persisters/persister-yjs/index.js.gz +0 -0
  828. package/umd/es6/min/persisters/persister-yjs/with-schemas/index.js +1 -1
  829. package/umd/es6/min/persisters/persister-yjs/with-schemas/index.js.gz +0 -0
  830. package/umd/es6/min/persisters/with-schemas/index.js +1 -1
  831. package/umd/es6/min/persisters/with-schemas/index.js.gz +0 -0
  832. package/umd/es6/min/queries/index.js +1 -1
  833. package/umd/es6/min/queries/index.js.gz +0 -0
  834. package/umd/es6/min/queries/with-schemas/index.js +1 -1
  835. package/umd/es6/min/queries/with-schemas/index.js.gz +0 -0
  836. package/umd/es6/min/relationships/index.js +1 -1
  837. package/umd/es6/min/relationships/index.js.gz +0 -0
  838. package/umd/es6/min/relationships/with-schemas/index.js +1 -1
  839. package/umd/es6/min/relationships/with-schemas/index.js.gz +0 -0
  840. package/umd/es6/min/synchronizers/index.js +1 -1
  841. package/umd/es6/min/synchronizers/index.js.gz +0 -0
  842. package/umd/es6/min/synchronizers/synchronizer-broadcast-channel/index.js +1 -1
  843. package/umd/es6/min/synchronizers/synchronizer-broadcast-channel/index.js.gz +0 -0
  844. package/umd/es6/min/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js +1 -1
  845. package/umd/es6/min/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js.gz +0 -0
  846. package/umd/es6/min/synchronizers/synchronizer-local/index.js +1 -1
  847. package/umd/es6/min/synchronizers/synchronizer-local/index.js.gz +0 -0
  848. package/umd/es6/min/synchronizers/synchronizer-local/with-schemas/index.js +1 -1
  849. package/umd/es6/min/synchronizers/synchronizer-local/with-schemas/index.js.gz +0 -0
  850. package/umd/es6/min/synchronizers/synchronizer-ws-client/index.js +1 -1
  851. package/umd/es6/min/synchronizers/synchronizer-ws-client/index.js.gz +0 -0
  852. package/umd/es6/min/synchronizers/synchronizer-ws-client/with-schemas/index.js +1 -1
  853. package/umd/es6/min/synchronizers/synchronizer-ws-client/with-schemas/index.js.gz +0 -0
  854. package/umd/es6/min/synchronizers/synchronizer-ws-server/index.js +1 -1
  855. package/umd/es6/min/synchronizers/synchronizer-ws-server/index.js.gz +0 -0
  856. package/umd/es6/min/synchronizers/synchronizer-ws-server/with-schemas/index.js +1 -1
  857. package/umd/es6/min/synchronizers/synchronizer-ws-server/with-schemas/index.js.gz +0 -0
  858. package/umd/es6/min/synchronizers/synchronizer-ws-server-durable-object/index.js +1 -1
  859. package/umd/es6/min/synchronizers/synchronizer-ws-server-durable-object/index.js.gz +0 -0
  860. package/umd/es6/min/synchronizers/synchronizer-ws-server-durable-object/with-schemas/index.js +1 -1
  861. package/umd/es6/min/synchronizers/synchronizer-ws-server-durable-object/with-schemas/index.js.gz +0 -0
  862. package/umd/es6/min/synchronizers/with-schemas/index.js +1 -1
  863. package/umd/es6/min/synchronizers/with-schemas/index.js.gz +0 -0
  864. package/umd/es6/min/ui-react-inspector/index.js +1 -1
  865. package/umd/es6/min/ui-react-inspector/index.js.gz +0 -0
  866. package/umd/es6/min/ui-react-inspector/with-schemas/index.js +1 -1
  867. package/umd/es6/min/ui-react-inspector/with-schemas/index.js.gz +0 -0
  868. package/umd/es6/min/with-schemas/index.js +1 -1
  869. package/umd/es6/min/with-schemas/index.js.gz +0 -0
  870. package/umd/es6/persisters/index.js +21 -9
  871. package/umd/es6/persisters/persister-automerge/index.js +17 -8
  872. package/umd/es6/persisters/persister-automerge/with-schemas/index.js +17 -8
  873. package/umd/es6/persisters/persister-browser/index.js +17 -8
  874. package/umd/es6/persisters/persister-browser/with-schemas/index.js +17 -8
  875. package/umd/es6/persisters/persister-cr-sqlite-wasm/index.js +21 -9
  876. package/umd/es6/persisters/persister-cr-sqlite-wasm/with-schemas/index.js +21 -9
  877. package/umd/es6/persisters/persister-durable-object-storage/index.js +707 -0
  878. package/umd/es6/persisters/persister-durable-object-storage/with-schemas/index.js +707 -0
  879. package/umd/es6/persisters/persister-electric-sql/index.js +21 -9
  880. package/umd/es6/persisters/persister-electric-sql/with-schemas/index.js +21 -9
  881. package/umd/es6/persisters/persister-expo-sqlite/index.js +21 -9
  882. package/umd/es6/persisters/persister-expo-sqlite/with-schemas/index.js +21 -9
  883. package/umd/es6/persisters/persister-file/index.js +17 -8
  884. package/umd/es6/persisters/persister-file/with-schemas/index.js +17 -8
  885. package/umd/es6/persisters/persister-indexed-db/index.js +19 -9
  886. package/umd/es6/persisters/persister-indexed-db/with-schemas/index.js +19 -9
  887. package/umd/es6/persisters/persister-libsql/index.js +21 -9
  888. package/umd/es6/persisters/persister-libsql/with-schemas/index.js +21 -9
  889. package/umd/es6/persisters/persister-partykit-client/index.js +23 -11
  890. package/umd/es6/persisters/persister-partykit-client/with-schemas/index.js +23 -11
  891. package/umd/es6/persisters/persister-pglite/index.js +19 -8
  892. package/umd/es6/persisters/persister-pglite/with-schemas/index.js +19 -8
  893. package/umd/es6/persisters/persister-postgres/index.js +19 -8
  894. package/umd/es6/persisters/persister-postgres/with-schemas/index.js +19 -8
  895. package/umd/es6/persisters/persister-powersync/index.js +21 -9
  896. package/umd/es6/persisters/persister-powersync/with-schemas/index.js +21 -9
  897. package/umd/es6/persisters/persister-remote/index.js +19 -9
  898. package/umd/es6/persisters/persister-remote/with-schemas/index.js +19 -9
  899. package/umd/es6/persisters/persister-sqlite-wasm/index.js +21 -9
  900. package/umd/es6/persisters/persister-sqlite-wasm/with-schemas/index.js +21 -9
  901. package/umd/es6/persisters/persister-sqlite3/index.js +21 -9
  902. package/umd/es6/persisters/persister-sqlite3/with-schemas/index.js +21 -9
  903. package/umd/es6/persisters/persister-yjs/index.js +17 -8
  904. package/umd/es6/persisters/persister-yjs/with-schemas/index.js +17 -8
  905. package/umd/es6/persisters/with-schemas/index.js +21 -9
  906. package/umd/es6/queries/index.js +1 -0
  907. package/umd/es6/queries/with-schemas/index.js +1 -0
  908. package/umd/es6/relationships/index.js +5 -1
  909. package/umd/es6/relationships/with-schemas/index.js +5 -1
  910. package/umd/es6/synchronizers/index.js +143 -101
  911. package/umd/es6/synchronizers/synchronizer-broadcast-channel/index.js +143 -101
  912. package/umd/es6/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js +143 -101
  913. package/umd/es6/synchronizers/synchronizer-local/index.js +146 -105
  914. package/umd/es6/synchronizers/synchronizer-local/with-schemas/index.js +146 -105
  915. package/umd/es6/synchronizers/synchronizer-ws-client/index.js +161 -106
  916. package/umd/es6/synchronizers/synchronizer-ws-client/with-schemas/index.js +161 -106
  917. package/umd/es6/synchronizers/synchronizer-ws-server/index.js +172 -105
  918. package/umd/es6/synchronizers/synchronizer-ws-server/with-schemas/index.js +172 -105
  919. package/umd/es6/synchronizers/synchronizer-ws-server-durable-object/index.js +989 -21
  920. package/umd/es6/synchronizers/synchronizer-ws-server-durable-object/with-schemas/index.js +989 -21
  921. package/umd/es6/synchronizers/synchronizer-ws-server-simple/index.js +2 -1
  922. package/umd/es6/synchronizers/synchronizer-ws-server-simple/with-schemas/index.js +2 -1
  923. package/umd/es6/synchronizers/with-schemas/index.js +143 -101
  924. package/umd/es6/ui-react-inspector/index.js +17 -8
  925. package/umd/es6/ui-react-inspector/with-schemas/index.js +17 -8
  926. package/umd/es6/with-schemas/index.js +32 -27
  927. package/umd/index.js +31 -27
  928. package/umd/mergeable-store/index.js +31 -27
  929. package/umd/mergeable-store/with-schemas/index.js +31 -27
  930. package/umd/min/index.js +1 -1
  931. package/umd/min/index.js.gz +0 -0
  932. package/umd/min/mergeable-store/index.js +1 -1
  933. package/umd/min/mergeable-store/index.js.gz +0 -0
  934. package/umd/min/mergeable-store/with-schemas/index.js +1 -1
  935. package/umd/min/mergeable-store/with-schemas/index.js.gz +0 -0
  936. package/umd/min/persisters/index.js +1 -1
  937. package/umd/min/persisters/index.js.gz +0 -0
  938. package/umd/min/persisters/persister-automerge/index.js +1 -1
  939. package/umd/min/persisters/persister-automerge/index.js.gz +0 -0
  940. package/umd/min/persisters/persister-automerge/with-schemas/index.js +1 -1
  941. package/umd/min/persisters/persister-automerge/with-schemas/index.js.gz +0 -0
  942. package/umd/min/persisters/persister-browser/index.js +1 -1
  943. package/umd/min/persisters/persister-browser/index.js.gz +0 -0
  944. package/umd/min/persisters/persister-browser/with-schemas/index.js +1 -1
  945. package/umd/min/persisters/persister-browser/with-schemas/index.js.gz +0 -0
  946. package/umd/min/persisters/persister-cr-sqlite-wasm/index.js +1 -1
  947. package/umd/min/persisters/persister-cr-sqlite-wasm/index.js.gz +0 -0
  948. package/umd/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.js +1 -1
  949. package/umd/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.js.gz +0 -0
  950. package/umd/min/persisters/persister-durable-object-storage/index.js +1 -0
  951. package/umd/min/persisters/persister-durable-object-storage/index.js.gz +0 -0
  952. package/umd/min/persisters/persister-durable-object-storage/with-schemas/index.js +1 -0
  953. package/umd/min/persisters/persister-durable-object-storage/with-schemas/index.js.gz +0 -0
  954. package/umd/min/persisters/persister-electric-sql/index.js +1 -1
  955. package/umd/min/persisters/persister-electric-sql/index.js.gz +0 -0
  956. package/umd/min/persisters/persister-electric-sql/with-schemas/index.js +1 -1
  957. package/umd/min/persisters/persister-electric-sql/with-schemas/index.js.gz +0 -0
  958. package/umd/min/persisters/persister-expo-sqlite/index.js +1 -1
  959. package/umd/min/persisters/persister-expo-sqlite/index.js.gz +0 -0
  960. package/umd/min/persisters/persister-expo-sqlite/with-schemas/index.js +1 -1
  961. package/umd/min/persisters/persister-expo-sqlite/with-schemas/index.js.gz +0 -0
  962. package/umd/min/persisters/persister-file/index.js +1 -1
  963. package/umd/min/persisters/persister-file/index.js.gz +0 -0
  964. package/umd/min/persisters/persister-file/with-schemas/index.js +1 -1
  965. package/umd/min/persisters/persister-file/with-schemas/index.js.gz +0 -0
  966. package/umd/min/persisters/persister-indexed-db/index.js +1 -1
  967. package/umd/min/persisters/persister-indexed-db/index.js.gz +0 -0
  968. package/umd/min/persisters/persister-indexed-db/with-schemas/index.js +1 -1
  969. package/umd/min/persisters/persister-indexed-db/with-schemas/index.js.gz +0 -0
  970. package/umd/min/persisters/persister-libsql/index.js +1 -1
  971. package/umd/min/persisters/persister-libsql/index.js.gz +0 -0
  972. package/umd/min/persisters/persister-libsql/with-schemas/index.js +1 -1
  973. package/umd/min/persisters/persister-libsql/with-schemas/index.js.gz +0 -0
  974. package/umd/min/persisters/persister-partykit-client/index.js +1 -1
  975. package/umd/min/persisters/persister-partykit-client/index.js.gz +0 -0
  976. package/umd/min/persisters/persister-partykit-client/with-schemas/index.js +1 -1
  977. package/umd/min/persisters/persister-partykit-client/with-schemas/index.js.gz +0 -0
  978. package/umd/min/persisters/persister-pglite/index.js +1 -1
  979. package/umd/min/persisters/persister-pglite/index.js.gz +0 -0
  980. package/umd/min/persisters/persister-pglite/with-schemas/index.js +1 -1
  981. package/umd/min/persisters/persister-pglite/with-schemas/index.js.gz +0 -0
  982. package/umd/min/persisters/persister-postgres/index.js +1 -1
  983. package/umd/min/persisters/persister-postgres/index.js.gz +0 -0
  984. package/umd/min/persisters/persister-postgres/with-schemas/index.js +1 -1
  985. package/umd/min/persisters/persister-postgres/with-schemas/index.js.gz +0 -0
  986. package/umd/min/persisters/persister-powersync/index.js +1 -1
  987. package/umd/min/persisters/persister-powersync/index.js.gz +0 -0
  988. package/umd/min/persisters/persister-powersync/with-schemas/index.js +1 -1
  989. package/umd/min/persisters/persister-powersync/with-schemas/index.js.gz +0 -0
  990. package/umd/min/persisters/persister-remote/index.js +1 -1
  991. package/umd/min/persisters/persister-remote/index.js.gz +0 -0
  992. package/umd/min/persisters/persister-remote/with-schemas/index.js +1 -1
  993. package/umd/min/persisters/persister-remote/with-schemas/index.js.gz +0 -0
  994. package/umd/min/persisters/persister-sqlite-wasm/index.js +1 -1
  995. package/umd/min/persisters/persister-sqlite-wasm/index.js.gz +0 -0
  996. package/umd/min/persisters/persister-sqlite-wasm/with-schemas/index.js +1 -1
  997. package/umd/min/persisters/persister-sqlite-wasm/with-schemas/index.js.gz +0 -0
  998. package/umd/min/persisters/persister-sqlite3/index.js +1 -1
  999. package/umd/min/persisters/persister-sqlite3/index.js.gz +0 -0
  1000. package/umd/min/persisters/persister-sqlite3/with-schemas/index.js +1 -1
  1001. package/umd/min/persisters/persister-sqlite3/with-schemas/index.js.gz +0 -0
  1002. package/umd/min/persisters/persister-yjs/index.js +1 -1
  1003. package/umd/min/persisters/persister-yjs/index.js.gz +0 -0
  1004. package/umd/min/persisters/persister-yjs/with-schemas/index.js +1 -1
  1005. package/umd/min/persisters/persister-yjs/with-schemas/index.js.gz +0 -0
  1006. package/umd/min/persisters/with-schemas/index.js +1 -1
  1007. package/umd/min/persisters/with-schemas/index.js.gz +0 -0
  1008. package/umd/min/synchronizers/index.js +1 -1
  1009. package/umd/min/synchronizers/index.js.gz +0 -0
  1010. package/umd/min/synchronizers/synchronizer-broadcast-channel/index.js +1 -1
  1011. package/umd/min/synchronizers/synchronizer-broadcast-channel/index.js.gz +0 -0
  1012. package/umd/min/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js +1 -1
  1013. package/umd/min/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js.gz +0 -0
  1014. package/umd/min/synchronizers/synchronizer-local/index.js +1 -1
  1015. package/umd/min/synchronizers/synchronizer-local/index.js.gz +0 -0
  1016. package/umd/min/synchronizers/synchronizer-local/with-schemas/index.js +1 -1
  1017. package/umd/min/synchronizers/synchronizer-local/with-schemas/index.js.gz +0 -0
  1018. package/umd/min/synchronizers/synchronizer-ws-client/index.js +1 -1
  1019. package/umd/min/synchronizers/synchronizer-ws-client/index.js.gz +0 -0
  1020. package/umd/min/synchronizers/synchronizer-ws-client/with-schemas/index.js +1 -1
  1021. package/umd/min/synchronizers/synchronizer-ws-client/with-schemas/index.js.gz +0 -0
  1022. package/umd/min/synchronizers/synchronizer-ws-server/index.js +1 -1
  1023. package/umd/min/synchronizers/synchronizer-ws-server/index.js.gz +0 -0
  1024. package/umd/min/synchronizers/synchronizer-ws-server/with-schemas/index.js +1 -1
  1025. package/umd/min/synchronizers/synchronizer-ws-server/with-schemas/index.js.gz +0 -0
  1026. package/umd/min/synchronizers/synchronizer-ws-server-durable-object/index.js +1 -1
  1027. package/umd/min/synchronizers/synchronizer-ws-server-durable-object/index.js.gz +0 -0
  1028. package/umd/min/synchronizers/synchronizer-ws-server-durable-object/with-schemas/index.js +1 -1
  1029. package/umd/min/synchronizers/synchronizer-ws-server-durable-object/with-schemas/index.js.gz +0 -0
  1030. package/umd/min/synchronizers/with-schemas/index.js +1 -1
  1031. package/umd/min/synchronizers/with-schemas/index.js.gz +0 -0
  1032. package/umd/min/ui-react-inspector/index.js +1 -1
  1033. package/umd/min/ui-react-inspector/index.js.gz +0 -0
  1034. package/umd/min/ui-react-inspector/with-schemas/index.js +1 -1
  1035. package/umd/min/ui-react-inspector/with-schemas/index.js.gz +0 -0
  1036. package/umd/min/with-schemas/index.js +1 -1
  1037. package/umd/min/with-schemas/index.js.gz +0 -0
  1038. package/umd/persisters/index.js +21 -9
  1039. package/umd/persisters/persister-automerge/index.js +17 -8
  1040. package/umd/persisters/persister-automerge/with-schemas/index.js +17 -8
  1041. package/umd/persisters/persister-browser/index.js +17 -8
  1042. package/umd/persisters/persister-browser/with-schemas/index.js +17 -8
  1043. package/umd/persisters/persister-cr-sqlite-wasm/index.js +21 -9
  1044. package/umd/persisters/persister-cr-sqlite-wasm/with-schemas/index.js +21 -9
  1045. package/umd/persisters/persister-durable-object-storage/index.js +562 -0
  1046. package/umd/persisters/persister-durable-object-storage/with-schemas/index.js +562 -0
  1047. package/umd/persisters/persister-electric-sql/index.js +21 -9
  1048. package/umd/persisters/persister-electric-sql/with-schemas/index.js +21 -9
  1049. package/umd/persisters/persister-expo-sqlite/index.js +21 -9
  1050. package/umd/persisters/persister-expo-sqlite/with-schemas/index.js +21 -9
  1051. package/umd/persisters/persister-file/index.js +17 -8
  1052. package/umd/persisters/persister-file/with-schemas/index.js +17 -8
  1053. package/umd/persisters/persister-indexed-db/index.js +19 -9
  1054. package/umd/persisters/persister-indexed-db/with-schemas/index.js +19 -9
  1055. package/umd/persisters/persister-libsql/index.js +21 -9
  1056. package/umd/persisters/persister-libsql/with-schemas/index.js +21 -9
  1057. package/umd/persisters/persister-partykit-client/index.js +18 -9
  1058. package/umd/persisters/persister-partykit-client/with-schemas/index.js +18 -9
  1059. package/umd/persisters/persister-pglite/index.js +19 -8
  1060. package/umd/persisters/persister-pglite/with-schemas/index.js +19 -8
  1061. package/umd/persisters/persister-postgres/index.js +19 -8
  1062. package/umd/persisters/persister-postgres/with-schemas/index.js +19 -8
  1063. package/umd/persisters/persister-powersync/index.js +21 -9
  1064. package/umd/persisters/persister-powersync/with-schemas/index.js +21 -9
  1065. package/umd/persisters/persister-remote/index.js +19 -9
  1066. package/umd/persisters/persister-remote/with-schemas/index.js +19 -9
  1067. package/umd/persisters/persister-sqlite-wasm/index.js +21 -9
  1068. package/umd/persisters/persister-sqlite-wasm/with-schemas/index.js +21 -9
  1069. package/umd/persisters/persister-sqlite3/index.js +21 -9
  1070. package/umd/persisters/persister-sqlite3/with-schemas/index.js +21 -9
  1071. package/umd/persisters/persister-yjs/index.js +17 -8
  1072. package/umd/persisters/persister-yjs/with-schemas/index.js +17 -8
  1073. package/umd/persisters/with-schemas/index.js +21 -9
  1074. package/umd/synchronizers/index.js +120 -76
  1075. package/umd/synchronizers/synchronizer-broadcast-channel/index.js +120 -76
  1076. package/umd/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js +120 -76
  1077. package/umd/synchronizers/synchronizer-local/index.js +129 -88
  1078. package/umd/synchronizers/synchronizer-local/with-schemas/index.js +129 -88
  1079. package/umd/synchronizers/synchronizer-ws-client/index.js +138 -81
  1080. package/umd/synchronizers/synchronizer-ws-client/with-schemas/index.js +138 -81
  1081. package/umd/synchronizers/synchronizer-ws-server/index.js +149 -80
  1082. package/umd/synchronizers/synchronizer-ws-server/with-schemas/index.js +149 -80
  1083. package/umd/synchronizers/synchronizer-ws-server-durable-object/index.js +720 -18
  1084. package/umd/synchronizers/synchronizer-ws-server-durable-object/with-schemas/index.js +720 -18
  1085. package/umd/synchronizers/synchronizer-ws-server-simple/index.js +2 -1
  1086. package/umd/synchronizers/synchronizer-ws-server-simple/with-schemas/index.js +2 -1
  1087. package/umd/synchronizers/with-schemas/index.js +120 -76
  1088. package/umd/ui-react-inspector/index.js +17 -8
  1089. package/umd/ui-react-inspector/with-schemas/index.js +17 -8
  1090. package/umd/with-schemas/index.js +31 -27
  1091. package/with-schemas/index.js +31 -27
@@ -1 +1 @@
1
- const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),i=Promise,r=clearInterval,o=a=>null==a,c=(a,t,e)=>o(a)?e?.():t(a),l=t=>a(t)==s,w=a=>Array.isArray(a),u=(a,t,e)=>a.slice(t,e),y=a=>a.length,d=async a=>i.all(a),v=a=>{throw Error(a)},p=(a,t)=>a.forEach(t),E=(a,t="")=>a.join(t),g=(a,t)=>a.map(t),A=a=>0==y(a),h=(a,t)=>a.filter(t),m=(a,...t)=>a.push(...t),N=a=>a.shift(),$="_",f="_id",C="SELECT",S="WHERE",O="TABLE",T="ALTER "+O,I="DELETE FROM",L=C+"*FROM",b="pragma_",D="data_version",R="schema_version",M="pragma_table_",_=a=>`"${a.replace(/"/g,'""')}"`,P=(a,t=[1])=>E(g(a,(()=>"$"+t[0]++)),n),F=(a,t)=>a?.has(t)??!1,U=a=>o(a)||0==(a=>a?.size??0)(a),j=a=>[...a?.values()??[]],x=(a,t)=>a?.forEach(t),B=(a,t)=>a?.delete(t),J=Object,Y=a=>J.getPrototypeOf(a),k=J.entries,z=J.keys,G=J.freeze,H=(a=[])=>J.fromEntries(a),q=(...a)=>J.assign({},...a),K=(a,t)=>(delete a[t],a),Q=(a,t)=>g(k(a),(([a,e])=>t(e,a))),V=a=>J.values(a),W=a=>y(z(a)),X=a=>(a=>!o(a)&&c(Y(a),(a=>a==J.prototype||o(Y(a))),(()=>!0)))(a)&&0==W(a),Z=JSON.stringify,aa=JSON.parse,ta=a=>new Map(a),ea=(a,t)=>a?.get(t),na=(a,t)=>g([...a?.entries()??[]],(([a,e])=>t(e,a))),sa=(a,t,e)=>o(e)?(B(a,t),a):a?.set(t,e),ia=(a,t,e,n)=>(F(a,t)?n?.(ea(a,t)):sa(a,t,e()),ea(a,t)),ra=(a,t,e,n,s=0)=>c((e?ia:ea)(a,t[s],s>y(t)-2?e:ta),(i=>{if(s>y(t)-2)return n?.(i)&&sa(a,t[s]),i;const r=ra(i,t,e,n,s+1);return U(i)&&sa(a,t[s]),r})),oa=a=>new Set(w(a)||o(a)?a:[a]),ca=(a,t)=>a?.add(t),la=/^\d+$/,wa=ta(),ua=ta(),ya=(a,t,n,s,i,r,l,u={},d=[])=>{let E,g,A,h=0,$=0,f=0;ia(wa,d,(()=>0)),ia(ua,d,(()=>[]));const C=ta(),[S,O,T,I,L]=((a=1,t)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,t.getTransactionMergeableChanges,([[a],[t]])=>!X(a)||!X(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!X(a)||!X(t),t.setContent]:v("Store type not supported by this Persister"))(l,a),[b,D,R]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?N(a):null)??e+t++,t=>{la.test(t)&&y(a)<1e3&&m(a,t)}]})(),s=ta();return[(n,i,r,o=[],c=()=>[])=>{a??=k;const l=t(1);return sa(s,l,[n,i,r,o,c]),ca(ra(i,r??[e],oa),l),l},(t,n,...i)=>p(((a,t=[e])=>{const n=[],s=(a,e)=>e==y(t)?m(n,a):null===t[e]?x(a,(a=>s(a,e+1))):p([t[e],null],(t=>s(ea(a,t),e+1)));return s(a,0),n})(t,n),(t=>x(t,(t=>ea(s,t)[0](a,...n??[],...i))))),a=>c(ea(s,a),(([,t,i])=>(ra(t,i??[e],void 0,(t=>(B(t,a),U(t)?1:0))),sa(s,a),n(a),i))),t=>c(ea(s,t),(([t,,e=[],n,s])=>{const i=(...r)=>{const c=y(r);c==y(e)?t(a,...r,...s(r)):o(e[c])?p(n[c]?.(...r)??[],(a=>i(...r,a))):i(...r,e[c])};i()}))]})(),M=a=>{a!=h&&(h=a,D(C,void 0,h))},_=t=>{(S&&w(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},P=async a=>(2!=h&&(M(1),$++,await Y((async()=>{try{const e=await t();w(e)?_(e):a?L(a):v("Content is not an array "+e)}catch(t){r?.(t),a&&L(a)}M(0)}))),k),F=()=>(g&&(i(g),g=void 0),k),j=async a=>(1!=h&&(M(2),f++,await Y((async()=>{try{await n(O,a)}catch(a){r?.(a)}M(0)}))),k),J=()=>(c(A,a.delListener),A=void 0,k),Y=async(...a)=>(m(ea(ua,d),...a),await(async()=>{if(!ea(wa,d)){for(sa(wa,d,1);!o(E=N(ea(ua,d)));)try{await E()}catch(a){r?.(a)}sa(wa,d,0)}})(),k),k={load:P,startAutoLoad:async a=>{await F().load(a);try{g=await s((async(a,t)=>{t||a?2!=h&&(M(1),$++,_(t??a),M(0)):await P()}))}catch(a){r?.(a)}return k},stopAutoLoad:F,isAutoLoading:()=>!o(g),save:j,startAutoSave:async()=>(await J().save(),A=a.addDidFinishTransactionListener((()=>{const a=T();I(a)&&j(a)})),k),stopAutoSave:J,isAutoSaving:()=>!o(A),getStatus:()=>h,addStatusListener:a=>b(a,C),delListener:t=>(R(t),a),schedule:Y,getStore:()=>a,destroy:()=>(ea(ua,d).splice(0,void 0),F().stopAutoSave()),getStats:()=>({loads:$,saves:f}),...u};return G(k)},da=(a,t,e,s,i,r=va,c,l)=>{const w=ta();return[async()=>{w.clear(),g(await e(a,t),(({tn:a,cn:t})=>ca(ia(w,a,oa),t)))},async(t,e)=>((a,t)=>F(ea(w,a),t))(t,e)?H(h(g(await a(L+_(t)),(a=>{return[a[e],l?(t=K(a,e),n=l,H(Q(t,((a,t)=>[t,n(a,t)])))):K(a,e)];var t,n})),(([a,t])=>!o(a)&&!X(t)))):{},async(t,e,s,l,u,y=!1)=>{const v=oa();Q(s??{},(a=>g(z(a??{}),(a=>ca(v,a)))));const p=j(v);if(!y&&u&&A(p)&&F(w,t))return await a("DROP "+O+_(t)),void sa(w,t);const N=ea(w,t),$=oa(j(N));if(A(p)||(F(w,t)?await d(g([e,...p],(async(n,s)=>{B($,n)||(await a(T+_(t)+"ADD"+_(n)+i),0==s&&await a("CREATE UNIQUE INDEX pk ON "+_(t)+`(${_(e)})`),ca(N,n))}))):(await a("CREATE "+O+_(t)+`(${_(e)}${i} PRIMARY KEY${E(g(p,(a=>n+_(a)+i)))});`),sa(w,t,oa([e,...p])))),await d([...!y&&l?g(j($),(async n=>{n!=e&&(await a(T+_(t)+"DROP"+_(n)),B(N,n))})):[]]),y)o(s)?await a(I+_(t)+S+" true"):await d(Q(s,(async(n,s)=>{o(n)?await a(I+_(t)+S+_(e)+"=$1",[s]):A(p)||await r(a,t,e,z(n),{[s]:c?g(V(n),c):V(n)},N)})));else if(A(p))F(w,t)&&await a(I+_(t)+S+" true");else{const n=h(j(ea(w,t)),(a=>a!=e)),i={},o=[];Q(s??{},((a,t)=>{i[t]=g(n,(t=>c?c(a?.[t]):a?.[t])),m(o,t)})),await r(a,t,e,n,i),await a(I+_(t)+S+_(e)+`NOT IN(${P(o)})`,o)}},async t=>{let e;await a("BEGIN");try{e=await t()}catch(a){s?.(a)}return await a("END"),e}]},va=async(a,t,e,s,i)=>{const r=[1];await a("INSERT INTO"+_(t)+"("+((...a)=>E(g(a,_),n))(e,...s)+")VALUES"+E(Q(i,(a=>"($"+r[0]+++","+P(a,r)+")")),n)+"ON CONFLICT("+_(e)+")DO UPDATE SET"+E(g(s,(a=>_(a)+"=excluded."+_(a))),n),Q(i,((a,t)=>[t,...g(a,(a=>a??null))])).flat())},pa=(a,t,e,n,s,i,r,[o,c,l],w,u,y,d,v,p)=>{const[E,g,A,h]=da(t,w,u,s,v,p),m=ya(a,(async()=>await h((async()=>{return await E(),a=(await g(o,c))[$]?.[l]??"null",aa(a,((a,t)=>""===t?void 0:t));var a}))),(async a=>await h((async()=>{var t;await E(),await A(o,c,{[$]:{[l]:(t=a()??null,Z(t,((a,t)=>void 0===t?"":t)))}},!0,!0)}))),e,n,s,r,{[d]:()=>y,destroy:()=>(m.stopAutoLoad().stopAutoSave(),i(),m)},y);return m},Ea=(a,t,e,n,s,i,r,[c,l,[w,u,y]],v,p,E,g,A,m,N,C)=>{const[S,O,T,I]=da(t,v,p,s,A,m,N,C),L=async(a,t)=>await d(na(l,(async([e,n,s,i],r)=>{t&&!(r in a)||await T(e,n,a[r],s,i,t)}))),b=async(a,t)=>u?await T(y,f,{[$]:a},!0,!0,t):null,D=ya(a,(async()=>await I((async()=>{await S();const a=await(async()=>H(h(await d(na(c,(async([a,t],e)=>[a,await O(e,t)]))),(a=>!X(a[1])))))(),t=await(async()=>w?(await O(y,f))[$]:{})();return X(a)&&o(t)?void 0:[a,t]}))),(async(a,t)=>await I((async()=>{if(await S(),o(t)){const[t,e]=a();await L(t),await b(e)}else await L(t[0],!0),await b(t[1],!0)}))),e,n,s,r,{[g]:()=>E,destroy:()=>(D.stopAutoLoad().stopAutoSave(),i(),D)},E);return D},ga="ColumnName",Aa="store",ha="json",ma=Aa+"TableName",Na=Aa+"Id"+ga,$a=Aa+ga,fa="autoLoadIntervalSeconds",Ca="rowId"+ga,Sa="tableId",Oa="tableName",Ta="deleteEmptyColumns",Ia="deleteEmptyTable",La={mode:ha,[fa]:1},ba={load:0,save:0,[Oa]:t+"_values"},Da=(a,t,e,n,s)=>{const i=ta();return Q(a,((a,r)=>{const c=u(V(q(t,l(a)?{[e]:a}:a)),0,W(t));o(c[0])||n(r,c[0])||(s(r,c[0]),sa(i,r,c))})),i},Ra=(a,n,s,i,o,c,w,y,d,v,p="getDb",E)=>{let g,A,h;const m=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,c),[N,$,O,T]=(a=>{const e=(a=>q(La,l(a)?{[ma]:a}:a??{}))(a),n=e[fa];if(e.mode==ha){const a=e[ma]??t;return[1,n,[a,e[Na]??f,e[$a]??Aa],oa(a)]}const{tables:{load:s={},save:i={}}={},values:r={}}=e,o=u(V(q(ba,r)),0,W(ba)),c=o[2],w=oa(c),y=oa(c);return[0,n,[Da(s,{[Sa]:null,[Ca]:f},Sa,(a=>F(y,a)),(a=>ca(w,a))),Da(i,{[Oa]:null,[Ca]:f,[Ta]:0,[Ia]:0},Oa,((a,t)=>F(y,t)),((a,t)=>ca(w,t))),o],w]})(n);return(N?pa:Ea)(a,m,(a=>{let t;const e=()=>t=setInterval((async()=>{try{const[{d:t,s:e,c:n}]=await m(`${C} ${D} d,${R} s,TOTAL_CHANGES() c FROM ${b}${D} JOIN ${b}${R}`);t==g&&e==A&&n==h||(null!=g&&a(),g=t,A=e,h=n)}catch{}}),1e3*$),n=()=>{g=A=h=null,r(t)},s=i((t=>{T.has(t)&&(n(),a(),e())}));return e(),()=>{n(),o(s)}}),(a=>a()),w,y,d,O,j(T),(async(a,t)=>await a(`${C} t.name tn,c.name cn FROM ${M}list()t,${M}info(t.name)c ${S} t.schema='main'AND t.type IN('table','view')AND t.name IN(${P(t)})ORDER BY t.name,c.name`,t)),v,p,e,E,(a=>!0===a?1:!1===a?0:a),void 0)},Ma=(a,t,e,n,s)=>Ra(a,e,(async(a,e=[])=>(await t.execute({sql:a,args:e})).rows),(()=>()=>0),(a=>a()),n,s,(()=>0),1,t,"getClient");export{Ma as createLibSqlPersister};
1
+ const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),i=Promise,r=clearInterval,o=a=>null==a,c=(a,t,e)=>o(a)?e?.():t(a),l=t=>a(t)==s,w=a=>Array.isArray(a),u=(a,t,e)=>a.slice(t,e),y=a=>a.length,d=async a=>i.all(a),v=a=>{throw Error(a)},p=(a,t)=>a.forEach(t),E=(a,t="")=>a.join(t),g=(a,t)=>a.map(t),A=a=>0==y(a),h=(a,t)=>a.filter(t),m=(a,...t)=>a.push(...t),N=a=>a.shift(),$="_",f="_id",C="SELECT",S="WHERE",O="TABLE",T="ALTER "+O,I="DELETE FROM",L=C+"*FROM",b="pragma_",D="data_version",R="schema_version",M="pragma_table_",_=a=>`"${a.replace(/"/g,'""')}"`,P=(a,t=[1])=>E(g(a,(()=>"$"+t[0]++)),n),F=(a,t)=>a?.has(t)??!1,U=a=>o(a)||0==(a=>a?.size??0)(a),j=a=>[...a?.values()??[]],x=(a,t)=>a?.forEach(t),B=(a,t)=>a?.delete(t),J=Object,Y=a=>J.getPrototypeOf(a),k=J.entries,z=J.keys,G=J.freeze,H=(a=[])=>J.fromEntries(a),q=(...a)=>J.assign({},...a),K=(a,t)=>(delete a[t],a),Q=(a,t)=>g(k(a),(([a,e])=>t(e,a))),V=a=>J.values(a),W=a=>y(z(a)),X=a=>(a=>!o(a)&&c(Y(a),(a=>a==J.prototype||o(Y(a))),(()=>!0)))(a)&&0==W(a),Z=JSON.stringify,aa=JSON.parse,ta=a=>new Map(a),ea=(a,t)=>a?.get(t),na=(a,t)=>g([...a?.entries()??[]],(([a,e])=>t(e,a))),sa=(a,t,e)=>o(e)?(B(a,t),a):a?.set(t,e),ia=(a,t,e,n)=>(F(a,t)?n?.(ea(a,t)):sa(a,t,e()),ea(a,t)),ra=(a,t,e,n,s=0)=>c((e?ia:ea)(a,t[s],s>y(t)-2?e:ta),(i=>{if(s>y(t)-2)return n?.(i)&&sa(a,t[s]),i;const r=ra(i,t,e,n,s+1);return U(i)&&sa(a,t[s]),r})),oa=a=>new Set(w(a)||o(a)?a:[a]),ca=(a,t)=>a?.add(t),la=/^\d+$/,wa=ta(),ua=ta(),ya=(a,t,n,s,i,r,l,u={},d=0,E=[])=>{let g,A,h,$=0,f=0,C=0;ia(wa,E,(()=>0)),ia(ua,E,(()=>[]));const S=ta(),[O,T,I,L,b]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!X(a)||!X(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!X(a)||!X(t),t.setContent]:v("Store type not supported by this Persister"))(l,a,d),[D,R,M]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?N(a):null)??e+t++,t=>{la.test(t)&&y(a)<1e3&&m(a,t)}]})(),s=ta();return[(n,i,r,o=[],c=()=>[])=>{a??=z;const l=t(1);return sa(s,l,[n,i,r,o,c]),ca(ra(i,r??[e],oa),l),l},(t,n,...i)=>p(((a,t=[e])=>{const n=[],s=(a,e)=>e==y(t)?m(n,a):null===t[e]?x(a,(a=>s(a,e+1))):p([t[e],null],(t=>s(ea(a,t),e+1)));return s(a,0),n})(t,n),(t=>x(t,(t=>ea(s,t)[0](a,...n??[],...i))))),a=>c(ea(s,a),(([,t,i])=>(ra(t,i??[e],void 0,(t=>(B(t,a),U(t)?1:0))),sa(s,a),n(a),i))),t=>c(ea(s,t),(([t,,e=[],n,s])=>{const i=(...r)=>{const c=y(r);c==y(e)?t(a,...r,...s(r)):o(e[c])?p(n[c]?.(...r)??[],(a=>i(...r,a))):i(...r,e[c])};i()}))]})(),_=a=>{a!=$&&($=a,R(S,void 0,$))},P=t=>{(O&&w(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},F=async a=>(2!=$&&(_(1),f++,await k((async()=>{try{const e=await t();w(e)?P(e):a?b(a):v("Content is not an array: "+e)}catch(t){r?.(t),a&&b(a)}_(0)}))),z),j=()=>(A&&(i(A),A=void 0),z),J=async a=>(1!=$&&(_(2),C++,await k((async()=>{try{await n(T,a)}catch(a){r?.(a)}_(0)}))),z),Y=()=>(h&&(a.delListener(h),h=void 0),z),k=async(...a)=>(m(ea(ua,E),...a),await(async()=>{if(!ea(wa,E)){for(sa(wa,E,1);!o(g=N(ea(ua,E)));)try{await g()}catch(a){r?.(a)}sa(wa,E,0)}})(),z),z={load:F,startAutoLoad:async a=>{j(),await F(a);try{A=await s((async(a,t)=>{t||a?2!=$&&(_(1),f++,P(t??a),_(0)):await F()}))}catch(a){r?.(a)}return z},stopAutoLoad:j,isAutoLoading:()=>!o(A),save:J,startAutoSave:async()=>(Y(),await J(),h=a.addDidFinishTransactionListener((()=>{const a=I();L(a)&&J(a)})),z),stopAutoSave:Y,isAutoSaving:()=>!o(h),getStatus:()=>$,addStatusListener:a=>D(a,S),delListener:t=>(M(t),a),schedule:k,getStore:()=>a,destroy:()=>(ea(ua,E).splice(0,void 0),j().stopAutoSave()),getStats:()=>({loads:f,saves:C}),...u};return G(z)},da=(a,t,e,s,i,r=va,c,l)=>{const w=ta();return[async()=>{w.clear(),g(await e(a,t),(({tn:a,cn:t})=>ca(ia(w,a,oa),t)))},async(t,e)=>((a,t)=>F(ea(w,a),t))(t,e)?H(h(g(await a(L+_(t)),(a=>{return[a[e],l?(t=K(a,e),n=l,H(Q(t,((a,t)=>[t,n(a,t)])))):K(a,e)];var t,n})),(([a,t])=>!o(a)&&!X(t)))):{},async(t,e,s,l,u,y=!1)=>{const v=oa();Q(s??{},(a=>g(z(a??{}),(a=>ca(v,a)))));const p=j(v);if(!y&&u&&A(p)&&F(w,t))return await a("DROP "+O+_(t)),void sa(w,t);const N=ea(w,t),$=oa(j(N));if(A(p)||(F(w,t)?await d(g([e,...p],(async(n,s)=>{B($,n)||(await a(T+_(t)+"ADD"+_(n)+i),0==s&&await a("CREATE UNIQUE INDEX pk ON "+_(t)+`(${_(e)})`),ca(N,n))}))):(await a("CREATE "+O+_(t)+`(${_(e)}${i} PRIMARY KEY${E(g(p,(a=>n+_(a)+i)))});`),sa(w,t,oa([e,...p])))),await d([...!y&&l?g(j($),(async n=>{n!=e&&(await a(T+_(t)+"DROP"+_(n)),B(N,n))})):[]]),y)o(s)?await a(I+_(t)+S+" true"):await d(Q(s,(async(n,s)=>{o(n)?await a(I+_(t)+S+_(e)+"=$1",[s]):A(p)||await r(a,t,e,z(n),{[s]:c?g(V(n),c):V(n)},N)})));else if(A(p))F(w,t)&&await a(I+_(t)+S+" true");else{const n=h(j(ea(w,t)),(a=>a!=e)),i={},o=[];Q(s??{},((a,t)=>{i[t]=g(n,(t=>c?c(a?.[t]):a?.[t])),m(o,t)})),await r(a,t,e,n,i),await a(I+_(t)+S+_(e)+`NOT IN(${P(o)})`,o)}},async t=>{let e;await a("BEGIN");try{e=await t()}catch(a){s?.(a)}return await a("END"),e}]},va=async(a,t,e,s,i)=>{const r=[1];await a("INSERT INTO"+_(t)+"("+((...a)=>E(g(a,_),n))(e,...s)+")VALUES"+E(Q(i,(a=>"($"+r[0]+++","+P(a,r)+")")),n)+"ON CONFLICT("+_(e)+")DO UPDATE SET"+E(g(s,(a=>_(a)+"=excluded."+_(a))),n),Q(i,((a,t)=>[t,...g(a,(a=>a??null))])).flat())},pa=(a,t,e,n,s,i,r,[o,c,l],w,u,y,d,v,p)=>{const[E,g,A,h]=da(t,w,u,s,v,p),m=ya(a,(async()=>await h((async()=>{return await E(),a=(await g(o,c))[$]?.[l]??"null",aa(a,((a,t)=>""===t?void 0:t));var a}))),(async a=>await h((async()=>{var t;await E(),await A(o,c,{[$]:{[l]:(t=a()??null,Z(t,((a,t)=>void 0===t?"":t)))}},!0,!0)}))),e,n,s,r,{[d]:()=>y,destroy:()=>(m.stopAutoLoad().stopAutoSave(),i(),m)},0,y);return m},Ea=(a,t,e,n,s,i,r,[c,l,[w,u,y]],v,p,E,g,A,m,N,C)=>{const[S,O,T,I]=da(t,v,p,s,A,m,N,C),L=async(a,t)=>await d(na(l,(async([e,n,s,i],r)=>{t&&!(r in a)||await T(e,n,a[r],s,i,t)}))),b=async(a,t)=>u?await T(y,f,{[$]:a},!0,!0,t):null,D=ya(a,(async()=>await I((async()=>{await S();const a=await(async()=>H(h(await d(na(c,(async([a,t],e)=>[a,await O(e,t)]))),(a=>!X(a[1])))))(),t=await(async()=>w?(await O(y,f))[$]:{})();return X(a)&&o(t)?void 0:[a,t]}))),(async(a,t)=>await I((async()=>{if(await S(),o(t)){const[t,e]=a();await L(t),await b(e)}else await L(t[0],!0),await b(t[1],!0)}))),e,n,s,r,{[g]:()=>E,destroy:()=>(D.stopAutoLoad().stopAutoSave(),i(),D)},0,E);return D},ga="ColumnName",Aa="store",ha="json",ma=Aa+"TableName",Na=Aa+"Id"+ga,$a=Aa+ga,fa="autoLoadIntervalSeconds",Ca="rowId"+ga,Sa="tableId",Oa="tableName",Ta="deleteEmptyColumns",Ia="deleteEmptyTable",La={mode:ha,[fa]:1},ba={load:0,save:0,[Oa]:t+"_values"},Da=(a,t,e,n,s)=>{const i=ta();return Q(a,((a,r)=>{const c=u(V(q(t,l(a)?{[e]:a}:a)),0,W(t));o(c[0])||n(r,c[0])||(s(r,c[0]),sa(i,r,c))})),i},Ra=(a,n,s,i,o,c,w,y,d,v,p="getDb",E)=>{let g,A,h;const m=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,c),[N,$,O,T]=(a=>{const e=(a=>q(La,l(a)?{[ma]:a}:a??{}))(a),n=e[fa];if(e.mode==ha){const a=e[ma]??t;return[1,n,[a,e[Na]??f,e[$a]??Aa],oa(a)]}const{tables:{load:s={},save:i={}}={},values:r={}}=e,o=u(V(q(ba,r)),0,W(ba)),c=o[2],w=oa(c),y=oa(c);return[0,n,[Da(s,{[Sa]:null,[Ca]:f},Sa,(a=>F(y,a)),(a=>ca(w,a))),Da(i,{[Oa]:null,[Ca]:f,[Ta]:0,[Ia]:0},Oa,((a,t)=>F(y,t)),((a,t)=>ca(w,t))),o],w]})(n);return(N?pa:Ea)(a,m,(a=>{let t;const e=()=>t=setInterval((async()=>{try{const[{d:t,s:e,c:n}]=await m(`${C} ${D} d,${R} s,TOTAL_CHANGES() c FROM ${b}${D} JOIN ${b}${R}`);t==g&&e==A&&n==h||(null!=g&&a(),g=t,A=e,h=n)}catch{}}),1e3*$),n=()=>{g=A=h=null,r(t)},s=i((t=>{T.has(t)&&(n(),a(),e())}));return e(),()=>{n(),o(s)}}),(a=>a()),w,y,d,O,j(T),(async(a,t)=>await a(`${C} t.name tn,c.name cn FROM ${M}list()t,${M}info(t.name)c ${S} t.schema='main'AND t.type IN('table','view')AND t.name IN(${P(t)})ORDER BY t.name,c.name`,t)),v,p,e,E,(a=>!0===a?1:!1===a?0:a),void 0)},Ma=(a,t,e,n,s)=>Ra(a,e,(async(a,e=[])=>(await t.execute({sql:a,args:e})).rows),(()=>()=>0),(a=>a()),n,s,(()=>0),1,t,"getClient");export{Ma as createLibSqlPersister};
@@ -1 +1 @@
1
- const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),i=Promise,r=clearInterval,o=a=>null==a,c=(a,t,e)=>o(a)?e?.():t(a),l=t=>a(t)==s,w=a=>Array.isArray(a),u=(a,t,e)=>a.slice(t,e),y=a=>a.length,d=async a=>i.all(a),v=a=>{throw Error(a)},p=(a,t)=>a.forEach(t),E=(a,t="")=>a.join(t),g=(a,t)=>a.map(t),A=a=>0==y(a),h=(a,t)=>a.filter(t),m=(a,...t)=>a.push(...t),N=a=>a.shift(),$="_",f="_id",C="SELECT",S="WHERE",O="TABLE",T="ALTER "+O,I="DELETE FROM",L=C+"*FROM",b="pragma_",D="data_version",R="schema_version",M="pragma_table_",_=a=>`"${a.replace(/"/g,'""')}"`,P=(a,t=[1])=>E(g(a,(()=>"$"+t[0]++)),n),F=(a,t)=>a?.has(t)??!1,U=a=>o(a)||0==(a=>a?.size??0)(a),j=a=>[...a?.values()??[]],x=(a,t)=>a?.forEach(t),B=(a,t)=>a?.delete(t),J=Object,Y=a=>J.getPrototypeOf(a),k=J.entries,z=J.keys,G=J.freeze,H=(a=[])=>J.fromEntries(a),q=(...a)=>J.assign({},...a),K=(a,t)=>(delete a[t],a),Q=(a,t)=>g(k(a),(([a,e])=>t(e,a))),V=a=>J.values(a),W=a=>y(z(a)),X=a=>(a=>!o(a)&&c(Y(a),(a=>a==J.prototype||o(Y(a))),(()=>!0)))(a)&&0==W(a),Z=JSON.stringify,aa=JSON.parse,ta=a=>new Map(a),ea=(a,t)=>a?.get(t),na=(a,t)=>g([...a?.entries()??[]],(([a,e])=>t(e,a))),sa=(a,t,e)=>o(e)?(B(a,t),a):a?.set(t,e),ia=(a,t,e,n)=>(F(a,t)?n?.(ea(a,t)):sa(a,t,e()),ea(a,t)),ra=(a,t,e,n,s=0)=>c((e?ia:ea)(a,t[s],s>y(t)-2?e:ta),(i=>{if(s>y(t)-2)return n?.(i)&&sa(a,t[s]),i;const r=ra(i,t,e,n,s+1);return U(i)&&sa(a,t[s]),r})),oa=a=>new Set(w(a)||o(a)?a:[a]),ca=(a,t)=>a?.add(t),la=/^\d+$/,wa=ta(),ua=ta(),ya=(a,t,n,s,i,r,l,u={},d=[])=>{let E,g,A,h=0,$=0,f=0;ia(wa,d,(()=>0)),ia(ua,d,(()=>[]));const C=ta(),[S,O,T,I,L]=((a=1,t)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,t.getTransactionMergeableChanges,([[a],[t]])=>!X(a)||!X(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!X(a)||!X(t),t.setContent]:v("Store type not supported by this Persister"))(l,a),[b,D,R]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?N(a):null)??e+t++,t=>{la.test(t)&&y(a)<1e3&&m(a,t)}]})(),s=ta();return[(n,i,r,o=[],c=()=>[])=>{a??=k;const l=t(1);return sa(s,l,[n,i,r,o,c]),ca(ra(i,r??[e],oa),l),l},(t,n,...i)=>p(((a,t=[e])=>{const n=[],s=(a,e)=>e==y(t)?m(n,a):null===t[e]?x(a,(a=>s(a,e+1))):p([t[e],null],(t=>s(ea(a,t),e+1)));return s(a,0),n})(t,n),(t=>x(t,(t=>ea(s,t)[0](a,...n??[],...i))))),a=>c(ea(s,a),(([,t,i])=>(ra(t,i??[e],void 0,(t=>(B(t,a),U(t)?1:0))),sa(s,a),n(a),i))),t=>c(ea(s,t),(([t,,e=[],n,s])=>{const i=(...r)=>{const c=y(r);c==y(e)?t(a,...r,...s(r)):o(e[c])?p(n[c]?.(...r)??[],(a=>i(...r,a))):i(...r,e[c])};i()}))]})(),M=a=>{a!=h&&(h=a,D(C,void 0,h))},_=t=>{(S&&w(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},P=async a=>(2!=h&&(M(1),$++,await Y((async()=>{try{const e=await t();w(e)?_(e):a?L(a):v("Content is not an array "+e)}catch(t){r?.(t),a&&L(a)}M(0)}))),k),F=()=>(g&&(i(g),g=void 0),k),j=async a=>(1!=h&&(M(2),f++,await Y((async()=>{try{await n(O,a)}catch(a){r?.(a)}M(0)}))),k),J=()=>(c(A,a.delListener),A=void 0,k),Y=async(...a)=>(m(ea(ua,d),...a),await(async()=>{if(!ea(wa,d)){for(sa(wa,d,1);!o(E=N(ea(ua,d)));)try{await E()}catch(a){r?.(a)}sa(wa,d,0)}})(),k),k={load:P,startAutoLoad:async a=>{await F().load(a);try{g=await s((async(a,t)=>{t||a?2!=h&&(M(1),$++,_(t??a),M(0)):await P()}))}catch(a){r?.(a)}return k},stopAutoLoad:F,isAutoLoading:()=>!o(g),save:j,startAutoSave:async()=>(await J().save(),A=a.addDidFinishTransactionListener((()=>{const a=T();I(a)&&j(a)})),k),stopAutoSave:J,isAutoSaving:()=>!o(A),getStatus:()=>h,addStatusListener:a=>b(a,C),delListener:t=>(R(t),a),schedule:Y,getStore:()=>a,destroy:()=>(ea(ua,d).splice(0,void 0),F().stopAutoSave()),getStats:()=>({loads:$,saves:f}),...u};return G(k)},da=(a,t,e,s,i,r=va,c,l)=>{const w=ta();return[async()=>{w.clear(),g(await e(a,t),(({tn:a,cn:t})=>ca(ia(w,a,oa),t)))},async(t,e)=>((a,t)=>F(ea(w,a),t))(t,e)?H(h(g(await a(L+_(t)),(a=>{return[a[e],l?(t=K(a,e),n=l,H(Q(t,((a,t)=>[t,n(a,t)])))):K(a,e)];var t,n})),(([a,t])=>!o(a)&&!X(t)))):{},async(t,e,s,l,u,y=!1)=>{const v=oa();Q(s??{},(a=>g(z(a??{}),(a=>ca(v,a)))));const p=j(v);if(!y&&u&&A(p)&&F(w,t))return await a("DROP "+O+_(t)),void sa(w,t);const N=ea(w,t),$=oa(j(N));if(A(p)||(F(w,t)?await d(g([e,...p],(async(n,s)=>{B($,n)||(await a(T+_(t)+"ADD"+_(n)+i),0==s&&await a("CREATE UNIQUE INDEX pk ON "+_(t)+`(${_(e)})`),ca(N,n))}))):(await a("CREATE "+O+_(t)+`(${_(e)}${i} PRIMARY KEY${E(g(p,(a=>n+_(a)+i)))});`),sa(w,t,oa([e,...p])))),await d([...!y&&l?g(j($),(async n=>{n!=e&&(await a(T+_(t)+"DROP"+_(n)),B(N,n))})):[]]),y)o(s)?await a(I+_(t)+S+" true"):await d(Q(s,(async(n,s)=>{o(n)?await a(I+_(t)+S+_(e)+"=$1",[s]):A(p)||await r(a,t,e,z(n),{[s]:c?g(V(n),c):V(n)},N)})));else if(A(p))F(w,t)&&await a(I+_(t)+S+" true");else{const n=h(j(ea(w,t)),(a=>a!=e)),i={},o=[];Q(s??{},((a,t)=>{i[t]=g(n,(t=>c?c(a?.[t]):a?.[t])),m(o,t)})),await r(a,t,e,n,i),await a(I+_(t)+S+_(e)+`NOT IN(${P(o)})`,o)}},async t=>{let e;await a("BEGIN");try{e=await t()}catch(a){s?.(a)}return await a("END"),e}]},va=async(a,t,e,s,i)=>{const r=[1];await a("INSERT INTO"+_(t)+"("+((...a)=>E(g(a,_),n))(e,...s)+")VALUES"+E(Q(i,(a=>"($"+r[0]+++","+P(a,r)+")")),n)+"ON CONFLICT("+_(e)+")DO UPDATE SET"+E(g(s,(a=>_(a)+"=excluded."+_(a))),n),Q(i,((a,t)=>[t,...g(a,(a=>a??null))])).flat())},pa=(a,t,e,n,s,i,r,[o,c,l],w,u,y,d,v,p)=>{const[E,g,A,h]=da(t,w,u,s,v,p),m=ya(a,(async()=>await h((async()=>{return await E(),a=(await g(o,c))[$]?.[l]??"null",aa(a,((a,t)=>""===t?void 0:t));var a}))),(async a=>await h((async()=>{var t;await E(),await A(o,c,{[$]:{[l]:(t=a()??null,Z(t,((a,t)=>void 0===t?"":t)))}},!0,!0)}))),e,n,s,r,{[d]:()=>y,destroy:()=>(m.stopAutoLoad().stopAutoSave(),i(),m)},y);return m},Ea=(a,t,e,n,s,i,r,[c,l,[w,u,y]],v,p,E,g,A,m,N,C)=>{const[S,O,T,I]=da(t,v,p,s,A,m,N,C),L=async(a,t)=>await d(na(l,(async([e,n,s,i],r)=>{t&&!(r in a)||await T(e,n,a[r],s,i,t)}))),b=async(a,t)=>u?await T(y,f,{[$]:a},!0,!0,t):null,D=ya(a,(async()=>await I((async()=>{await S();const a=await(async()=>H(h(await d(na(c,(async([a,t],e)=>[a,await O(e,t)]))),(a=>!X(a[1])))))(),t=await(async()=>w?(await O(y,f))[$]:{})();return X(a)&&o(t)?void 0:[a,t]}))),(async(a,t)=>await I((async()=>{if(await S(),o(t)){const[t,e]=a();await L(t),await b(e)}else await L(t[0],!0),await b(t[1],!0)}))),e,n,s,r,{[g]:()=>E,destroy:()=>(D.stopAutoLoad().stopAutoSave(),i(),D)},E);return D},ga="ColumnName",Aa="store",ha="json",ma=Aa+"TableName",Na=Aa+"Id"+ga,$a=Aa+ga,fa="autoLoadIntervalSeconds",Ca="rowId"+ga,Sa="tableId",Oa="tableName",Ta="deleteEmptyColumns",Ia="deleteEmptyTable",La={mode:ha,[fa]:1},ba={load:0,save:0,[Oa]:t+"_values"},Da=(a,t,e,n,s)=>{const i=ta();return Q(a,((a,r)=>{const c=u(V(q(t,l(a)?{[e]:a}:a)),0,W(t));o(c[0])||n(r,c[0])||(s(r,c[0]),sa(i,r,c))})),i},Ra=(a,n,s,i,o,c,w,y,d,v,p="getDb",E)=>{let g,A,h;const m=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,c),[N,$,O,T]=(a=>{const e=(a=>q(La,l(a)?{[ma]:a}:a??{}))(a),n=e[fa];if(e.mode==ha){const a=e[ma]??t;return[1,n,[a,e[Na]??f,e[$a]??Aa],oa(a)]}const{tables:{load:s={},save:i={}}={},values:r={}}=e,o=u(V(q(ba,r)),0,W(ba)),c=o[2],w=oa(c),y=oa(c);return[0,n,[Da(s,{[Sa]:null,[Ca]:f},Sa,(a=>F(y,a)),(a=>ca(w,a))),Da(i,{[Oa]:null,[Ca]:f,[Ta]:0,[Ia]:0},Oa,((a,t)=>F(y,t)),((a,t)=>ca(w,t))),o],w]})(n);return(N?pa:Ea)(a,m,(a=>{let t;const e=()=>t=setInterval((async()=>{try{const[{d:t,s:e,c:n}]=await m(`${C} ${D} d,${R} s,TOTAL_CHANGES() c FROM ${b}${D} JOIN ${b}${R}`);t==g&&e==A&&n==h||(null!=g&&a(),g=t,A=e,h=n)}catch{}}),1e3*$),n=()=>{g=A=h=null,r(t)},s=i((t=>{T.has(t)&&(n(),a(),e())}));return e(),()=>{n(),o(s)}}),(a=>a()),w,y,d,O,j(T),(async(a,t)=>await a(`${C} t.name tn,c.name cn FROM ${M}list()t,${M}info(t.name)c ${S} t.schema='main'AND t.type IN('table','view')AND t.name IN(${P(t)})ORDER BY t.name,c.name`,t)),v,p,e,E,(a=>!0===a?1:!1===a?0:a),void 0)},Ma=(a,t,e,n,s)=>Ra(a,e,(async(a,e=[])=>(await t.execute({sql:a,args:e})).rows),(()=>()=>0),(a=>a()),n,s,(()=>0),1,t,"getClient");export{Ma as createLibSqlPersister};
1
+ const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),i=Promise,r=clearInterval,o=a=>null==a,c=(a,t,e)=>o(a)?e?.():t(a),l=t=>a(t)==s,w=a=>Array.isArray(a),u=(a,t,e)=>a.slice(t,e),y=a=>a.length,d=async a=>i.all(a),v=a=>{throw Error(a)},p=(a,t)=>a.forEach(t),E=(a,t="")=>a.join(t),g=(a,t)=>a.map(t),A=a=>0==y(a),h=(a,t)=>a.filter(t),m=(a,...t)=>a.push(...t),N=a=>a.shift(),$="_",f="_id",C="SELECT",S="WHERE",O="TABLE",T="ALTER "+O,I="DELETE FROM",L=C+"*FROM",b="pragma_",D="data_version",R="schema_version",M="pragma_table_",_=a=>`"${a.replace(/"/g,'""')}"`,P=(a,t=[1])=>E(g(a,(()=>"$"+t[0]++)),n),F=(a,t)=>a?.has(t)??!1,U=a=>o(a)||0==(a=>a?.size??0)(a),j=a=>[...a?.values()??[]],x=(a,t)=>a?.forEach(t),B=(a,t)=>a?.delete(t),J=Object,Y=a=>J.getPrototypeOf(a),k=J.entries,z=J.keys,G=J.freeze,H=(a=[])=>J.fromEntries(a),q=(...a)=>J.assign({},...a),K=(a,t)=>(delete a[t],a),Q=(a,t)=>g(k(a),(([a,e])=>t(e,a))),V=a=>J.values(a),W=a=>y(z(a)),X=a=>(a=>!o(a)&&c(Y(a),(a=>a==J.prototype||o(Y(a))),(()=>!0)))(a)&&0==W(a),Z=JSON.stringify,aa=JSON.parse,ta=a=>new Map(a),ea=(a,t)=>a?.get(t),na=(a,t)=>g([...a?.entries()??[]],(([a,e])=>t(e,a))),sa=(a,t,e)=>o(e)?(B(a,t),a):a?.set(t,e),ia=(a,t,e,n)=>(F(a,t)?n?.(ea(a,t)):sa(a,t,e()),ea(a,t)),ra=(a,t,e,n,s=0)=>c((e?ia:ea)(a,t[s],s>y(t)-2?e:ta),(i=>{if(s>y(t)-2)return n?.(i)&&sa(a,t[s]),i;const r=ra(i,t,e,n,s+1);return U(i)&&sa(a,t[s]),r})),oa=a=>new Set(w(a)||o(a)?a:[a]),ca=(a,t)=>a?.add(t),la=/^\d+$/,wa=ta(),ua=ta(),ya=(a,t,n,s,i,r,l,u={},d=0,E=[])=>{let g,A,h,$=0,f=0,C=0;ia(wa,E,(()=>0)),ia(ua,E,(()=>[]));const S=ta(),[O,T,I,L,b]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!X(a)||!X(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!X(a)||!X(t),t.setContent]:v("Store type not supported by this Persister"))(l,a,d),[D,R,M]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?N(a):null)??e+t++,t=>{la.test(t)&&y(a)<1e3&&m(a,t)}]})(),s=ta();return[(n,i,r,o=[],c=()=>[])=>{a??=z;const l=t(1);return sa(s,l,[n,i,r,o,c]),ca(ra(i,r??[e],oa),l),l},(t,n,...i)=>p(((a,t=[e])=>{const n=[],s=(a,e)=>e==y(t)?m(n,a):null===t[e]?x(a,(a=>s(a,e+1))):p([t[e],null],(t=>s(ea(a,t),e+1)));return s(a,0),n})(t,n),(t=>x(t,(t=>ea(s,t)[0](a,...n??[],...i))))),a=>c(ea(s,a),(([,t,i])=>(ra(t,i??[e],void 0,(t=>(B(t,a),U(t)?1:0))),sa(s,a),n(a),i))),t=>c(ea(s,t),(([t,,e=[],n,s])=>{const i=(...r)=>{const c=y(r);c==y(e)?t(a,...r,...s(r)):o(e[c])?p(n[c]?.(...r)??[],(a=>i(...r,a))):i(...r,e[c])};i()}))]})(),_=a=>{a!=$&&($=a,R(S,void 0,$))},P=t=>{(O&&w(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},F=async a=>(2!=$&&(_(1),f++,await k((async()=>{try{const e=await t();w(e)?P(e):a?b(a):v("Content is not an array: "+e)}catch(t){r?.(t),a&&b(a)}_(0)}))),z),j=()=>(A&&(i(A),A=void 0),z),J=async a=>(1!=$&&(_(2),C++,await k((async()=>{try{await n(T,a)}catch(a){r?.(a)}_(0)}))),z),Y=()=>(h&&(a.delListener(h),h=void 0),z),k=async(...a)=>(m(ea(ua,E),...a),await(async()=>{if(!ea(wa,E)){for(sa(wa,E,1);!o(g=N(ea(ua,E)));)try{await g()}catch(a){r?.(a)}sa(wa,E,0)}})(),z),z={load:F,startAutoLoad:async a=>{j(),await F(a);try{A=await s((async(a,t)=>{t||a?2!=$&&(_(1),f++,P(t??a),_(0)):await F()}))}catch(a){r?.(a)}return z},stopAutoLoad:j,isAutoLoading:()=>!o(A),save:J,startAutoSave:async()=>(Y(),await J(),h=a.addDidFinishTransactionListener((()=>{const a=I();L(a)&&J(a)})),z),stopAutoSave:Y,isAutoSaving:()=>!o(h),getStatus:()=>$,addStatusListener:a=>D(a,S),delListener:t=>(M(t),a),schedule:k,getStore:()=>a,destroy:()=>(ea(ua,E).splice(0,void 0),j().stopAutoSave()),getStats:()=>({loads:f,saves:C}),...u};return G(z)},da=(a,t,e,s,i,r=va,c,l)=>{const w=ta();return[async()=>{w.clear(),g(await e(a,t),(({tn:a,cn:t})=>ca(ia(w,a,oa),t)))},async(t,e)=>((a,t)=>F(ea(w,a),t))(t,e)?H(h(g(await a(L+_(t)),(a=>{return[a[e],l?(t=K(a,e),n=l,H(Q(t,((a,t)=>[t,n(a,t)])))):K(a,e)];var t,n})),(([a,t])=>!o(a)&&!X(t)))):{},async(t,e,s,l,u,y=!1)=>{const v=oa();Q(s??{},(a=>g(z(a??{}),(a=>ca(v,a)))));const p=j(v);if(!y&&u&&A(p)&&F(w,t))return await a("DROP "+O+_(t)),void sa(w,t);const N=ea(w,t),$=oa(j(N));if(A(p)||(F(w,t)?await d(g([e,...p],(async(n,s)=>{B($,n)||(await a(T+_(t)+"ADD"+_(n)+i),0==s&&await a("CREATE UNIQUE INDEX pk ON "+_(t)+`(${_(e)})`),ca(N,n))}))):(await a("CREATE "+O+_(t)+`(${_(e)}${i} PRIMARY KEY${E(g(p,(a=>n+_(a)+i)))});`),sa(w,t,oa([e,...p])))),await d([...!y&&l?g(j($),(async n=>{n!=e&&(await a(T+_(t)+"DROP"+_(n)),B(N,n))})):[]]),y)o(s)?await a(I+_(t)+S+" true"):await d(Q(s,(async(n,s)=>{o(n)?await a(I+_(t)+S+_(e)+"=$1",[s]):A(p)||await r(a,t,e,z(n),{[s]:c?g(V(n),c):V(n)},N)})));else if(A(p))F(w,t)&&await a(I+_(t)+S+" true");else{const n=h(j(ea(w,t)),(a=>a!=e)),i={},o=[];Q(s??{},((a,t)=>{i[t]=g(n,(t=>c?c(a?.[t]):a?.[t])),m(o,t)})),await r(a,t,e,n,i),await a(I+_(t)+S+_(e)+`NOT IN(${P(o)})`,o)}},async t=>{let e;await a("BEGIN");try{e=await t()}catch(a){s?.(a)}return await a("END"),e}]},va=async(a,t,e,s,i)=>{const r=[1];await a("INSERT INTO"+_(t)+"("+((...a)=>E(g(a,_),n))(e,...s)+")VALUES"+E(Q(i,(a=>"($"+r[0]+++","+P(a,r)+")")),n)+"ON CONFLICT("+_(e)+")DO UPDATE SET"+E(g(s,(a=>_(a)+"=excluded."+_(a))),n),Q(i,((a,t)=>[t,...g(a,(a=>a??null))])).flat())},pa=(a,t,e,n,s,i,r,[o,c,l],w,u,y,d,v,p)=>{const[E,g,A,h]=da(t,w,u,s,v,p),m=ya(a,(async()=>await h((async()=>{return await E(),a=(await g(o,c))[$]?.[l]??"null",aa(a,((a,t)=>""===t?void 0:t));var a}))),(async a=>await h((async()=>{var t;await E(),await A(o,c,{[$]:{[l]:(t=a()??null,Z(t,((a,t)=>void 0===t?"":t)))}},!0,!0)}))),e,n,s,r,{[d]:()=>y,destroy:()=>(m.stopAutoLoad().stopAutoSave(),i(),m)},0,y);return m},Ea=(a,t,e,n,s,i,r,[c,l,[w,u,y]],v,p,E,g,A,m,N,C)=>{const[S,O,T,I]=da(t,v,p,s,A,m,N,C),L=async(a,t)=>await d(na(l,(async([e,n,s,i],r)=>{t&&!(r in a)||await T(e,n,a[r],s,i,t)}))),b=async(a,t)=>u?await T(y,f,{[$]:a},!0,!0,t):null,D=ya(a,(async()=>await I((async()=>{await S();const a=await(async()=>H(h(await d(na(c,(async([a,t],e)=>[a,await O(e,t)]))),(a=>!X(a[1])))))(),t=await(async()=>w?(await O(y,f))[$]:{})();return X(a)&&o(t)?void 0:[a,t]}))),(async(a,t)=>await I((async()=>{if(await S(),o(t)){const[t,e]=a();await L(t),await b(e)}else await L(t[0],!0),await b(t[1],!0)}))),e,n,s,r,{[g]:()=>E,destroy:()=>(D.stopAutoLoad().stopAutoSave(),i(),D)},0,E);return D},ga="ColumnName",Aa="store",ha="json",ma=Aa+"TableName",Na=Aa+"Id"+ga,$a=Aa+ga,fa="autoLoadIntervalSeconds",Ca="rowId"+ga,Sa="tableId",Oa="tableName",Ta="deleteEmptyColumns",Ia="deleteEmptyTable",La={mode:ha,[fa]:1},ba={load:0,save:0,[Oa]:t+"_values"},Da=(a,t,e,n,s)=>{const i=ta();return Q(a,((a,r)=>{const c=u(V(q(t,l(a)?{[e]:a}:a)),0,W(t));o(c[0])||n(r,c[0])||(s(r,c[0]),sa(i,r,c))})),i},Ra=(a,n,s,i,o,c,w,y,d,v,p="getDb",E)=>{let g,A,h;const m=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,c),[N,$,O,T]=(a=>{const e=(a=>q(La,l(a)?{[ma]:a}:a??{}))(a),n=e[fa];if(e.mode==ha){const a=e[ma]??t;return[1,n,[a,e[Na]??f,e[$a]??Aa],oa(a)]}const{tables:{load:s={},save:i={}}={},values:r={}}=e,o=u(V(q(ba,r)),0,W(ba)),c=o[2],w=oa(c),y=oa(c);return[0,n,[Da(s,{[Sa]:null,[Ca]:f},Sa,(a=>F(y,a)),(a=>ca(w,a))),Da(i,{[Oa]:null,[Ca]:f,[Ta]:0,[Ia]:0},Oa,((a,t)=>F(y,t)),((a,t)=>ca(w,t))),o],w]})(n);return(N?pa:Ea)(a,m,(a=>{let t;const e=()=>t=setInterval((async()=>{try{const[{d:t,s:e,c:n}]=await m(`${C} ${D} d,${R} s,TOTAL_CHANGES() c FROM ${b}${D} JOIN ${b}${R}`);t==g&&e==A&&n==h||(null!=g&&a(),g=t,A=e,h=n)}catch{}}),1e3*$),n=()=>{g=A=h=null,r(t)},s=i((t=>{T.has(t)&&(n(),a(),e())}));return e(),()=>{n(),o(s)}}),(a=>a()),w,y,d,O,j(T),(async(a,t)=>await a(`${C} t.name tn,c.name cn FROM ${M}list()t,${M}info(t.name)c ${S} t.schema='main'AND t.type IN('table','view')AND t.name IN(${P(t)})ORDER BY t.name,c.name`,t)),v,p,e,E,(a=>!0===a?1:!1===a?0:a),void 0)},Ma=(a,t,e,n,s)=>Ra(a,e,(async(a,e=[])=>(await t.execute({sql:a,args:e})).rows),(()=>()=>0),(a=>a()),n,s,(()=>0),1,t,"getClient");export{Ma as createLibSqlPersister};
@@ -1 +1 @@
1
- const t=t=>typeof t,e="",a=t(e),s=t=>null==t,n=(t,e,a)=>s(t)?a?.():e(t),o=e=>t(e)==a,r=t=>Array.isArray(t),i=t=>t.length,c=t=>{throw Error(t)},d=(t,e)=>t.forEach(e),l=(t,...e)=>t.push(...e),y=t=>t.shift(),u=Object,g=t=>u.getPrototypeOf(t),h=u.keys,p=u.freeze,v=t=>(t=>!s(t)&&n(g(t),(t=>t==u.prototype||s(g(t))),(()=>!0)))(t)&&0==(t=>i(h(t)))(t),w=JSON.stringify,f=JSON.parse,S=t=>w(t,((t,e)=>e instanceof Map?u.fromEntries([...e]):e)),C="/store",A=t=>s(t)||0==(t=>t?.size??0)(t),L=(t,e)=>t?.forEach(e),b=(t,e)=>t?.delete(e),m=t=>new Map(t),M=(t,e)=>t?.get(e),P=(t,e,a)=>s(a)?(b(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)):P(t,e,a()),M(t,e)},O=(t,e,a,s,o=0)=>n((a?E:M)(t,e[o],o>i(e)-2?a:m),(n=>{if(o>i(e)-2)return s?.(n)&&P(t,e[o]),n;const r=O(n,e,a,s,o+1);return A(n)&&P(t,e[o]),r})),T=t=>new Set(r(t)||s(t)?t:[t]),j=/^\d+$/,k=m(),x=m(),z=(t,a,o,u,g,h,w,f={},S=[])=>{let C,z,D,J=0,N=0,F=0;E(k,S,(()=>0)),E(x,S,(()=>[]));const U=m(),[W,$,q,B,G]=((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]:c("Store type not supported by this Persister"))(w,t),[H,I,K]=(()=>{let t;const[a,o]=(()=>{const t=[];let a=0;return[s=>(s?y(t):null)??e+a++,e=>{j.test(e)&&i(t)<1e3&&l(t,e)}]})(),r=m();return[(s,n,o,i=[],c=()=>[])=>{t??=tt;const d=a(1);var l,y;return P(r,d,[s,n,o,i,c]),l=O(n,o??[e],T),y=d,l?.add(y),d},(a,s,...n)=>d(((t,a=[e])=>{const s=[],n=(t,e)=>e==i(a)?l(s,t):null===a[e]?L(t,(t=>n(t,e+1))):d([a[e],null],(a=>n(M(t,a),e+1)));return n(t,0),s})(a,s),(e=>L(e,(e=>M(r,e)[0](t,...s??[],...n))))),t=>n(M(r,t),(([,a,s])=>(O(a,s??[e],void 0,(e=>(b(e,t),A(e)?1:0))),P(r,t),o(t),s))),e=>n(M(r,e),(([e,,a=[],n,o])=>{const r=(...c)=>{const l=i(c);l==i(a)?e(t,...c,...o(c)):s(a[l])?d(n[l]?.(...c)??[],(t=>r(...c,t))):r(...c,a[l])};r()}))]})(),Q=t=>{t!=J&&(J=t,I(U,void 0,J))},R=e=>{(W&&r(e?.[0])?1===e?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===e?.[2]?t.applyChanges:t.setContent)(e)},V=async t=>(2!=J&&(Q(1),N++,await _((async()=>{try{const e=await a();r(e)?R(e):t?G(t):c("Content is not an array "+e)}catch(e){h?.(e),t&&G(t)}Q(0)}))),tt),X=()=>(z&&(g(z),z=void 0),tt),Y=async t=>(1!=J&&(Q(2),F++,await _((async()=>{try{await o($,t)}catch(t){h?.(t)}Q(0)}))),tt),Z=()=>(n(D,t.delListener),D=void 0,tt),_=async(...t)=>(l(M(x,S),...t),await(async()=>{if(!M(k,S)){for(P(k,S,1);!s(C=y(M(x,S)));)try{await C()}catch(t){h?.(t)}P(k,S,0)}})(),tt),tt={load:V,startAutoLoad:async t=>{await X().load(t);try{z=await u((async(t,e)=>{e||t?2!=J&&(Q(1),N++,R(e??t),Q(0)):await V()}))}catch(t){h?.(t)}return tt},stopAutoLoad:X,isAutoLoading:()=>!s(z),save:Y,startAutoSave:async()=>(await Z().save(),D=t.addDidFinishTransactionListener((()=>{const t=q();B(t)&&Y(t)})),tt),stopAutoSave:Z,isAutoSaving:()=>!s(D),getStatus:()=>J,addStatusListener:t=>H(t,U),delListener:e=>(K(e),t),schedule:_,getStore:()=>t,destroy:()=>(M(x,S).splice(0,void 0),X().stopAutoSave()),getStats:()=>({loads:N,saves:F}),...f};return p(tt)},D="message",J=(t,a,s,r)=>{const{host:c,room:d}=a.partySocketOptions,{storeProtocol:l="https",storePath:y=C,messagePrefix:u=e}={...o(s)?{storeProtocol:s}:s},g=l+"://"+c+"/parties/"+a.name+"/"+d+y,h=async t=>await(await fetch(g,{...t?{method:"PUT",body:S(t)}:{},mode:"cors",cache:"no-store"})).json();return z(t,(async()=>await h()),(async(t,e)=>{var s;e?a.send(u+"s"+(o(s=e)?s:S(s))):await h(t())}),(t=>{const e=e=>n(((t,e)=>{const a=i(t);return((t,e)=>t.startsWith(e))(e,t)?[e[a],f((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 a.addEventListener(D,e),e}),(t=>{a.removeEventListener(D,t)}),r,1,{getConnection:()=>a})};export{J as createPartyKitPersister};
1
+ const t=t=>typeof t,e="",a=t(e),s="message",n=t=>null==t,o=(t,e,a)=>n(t)?a?.():e(t),r=e=>t(e)==a,i=t=>Array.isArray(t),c=t=>t.length,d=t=>{throw Error(t)},y=(t,e)=>t.forEach(e),l=(t,...e)=>t.push(...e),u=t=>t.shift(),g=Object,h=t=>g.getPrototypeOf(t),p=g.keys,v=g.freeze,w=t=>(t=>!n(t)&&o(h(t),(t=>t==g.prototype||n(h(t))),(()=>!0)))(t)&&0==(t=>c(p(t)))(t),f=JSON.stringify,S=JSON.parse,C=t=>f(t,((t,e)=>e instanceof Map?g.fromEntries([...e]):e)),A="/store",L=t=>n(t)||0==(t=>t?.size??0)(t),b=(t,e)=>t?.forEach(e),m=(t,e)=>t?.delete(e),M=t=>new Map(t),P=(t,e)=>t?.get(e),E=(t,e,a)=>n(a)?(m(t,e),t):t?.set(e,a),O=(t,e,a,s)=>{var n,o;return n=t,o=e,n?.has(o)?s?.(P(t,e)):E(t,e,a()),P(t,e)},T=(t,e,a,s,n=0)=>o((a?O:P)(t,e[n],n>c(e)-2?a:M),(o=>{if(n>c(e)-2)return s?.(o)&&E(t,e[n]),o;const r=T(o,e,a,s,n+1);return L(o)&&E(t,e[n]),r})),j=t=>new Set(i(t)||n(t)?t:[t]),k=/^\d+$/,x=M(),z=M(),D=(t,a,s,r,g,h,p,f={},S=0,C=[])=>{let A,D,J,N=0,F=0,U=0;O(x,C,(()=>0)),O(z,C,(()=>[]));const W=M(),[$,q,B,G,H]=((t=1,e,a)=>1!=t&&e.isMergeable()?[1,e.getMergeableContent,()=>e.getTransactionMergeableChanges(!a),([[t],[e]])=>!w(t)||!w(e),e.setDefaultContent]:2!=t?[0,e.getContent,e.getTransactionChanges,([t,e])=>!w(t)||!w(e),e.setContent]:d("Store type not supported by this Persister"))(p,t,S),[I,K,Q]=(()=>{let t;const[a,s]=(()=>{const t=[];let a=0;return[s=>(s?u(t):null)??e+a++,e=>{k.test(e)&&c(t)<1e3&&l(t,e)}]})(),r=M();return[(s,n,o,i=[],c=()=>[])=>{t??=et;const d=a(1);var y,l;return E(r,d,[s,n,o,i,c]),y=T(n,o??[e],j),l=d,y?.add(l),d},(a,s,...n)=>y(((t,a=[e])=>{const s=[],n=(t,e)=>e==c(a)?l(s,t):null===a[e]?b(t,(t=>n(t,e+1))):y([a[e],null],(a=>n(P(t,a),e+1)));return n(t,0),s})(a,s),(e=>b(e,(e=>P(r,e)[0](t,...s??[],...n))))),t=>o(P(r,t),(([,a,n])=>(T(a,n??[e],void 0,(e=>(m(e,t),L(e)?1:0))),E(r,t),s(t),n))),e=>o(P(r,e),(([e,,a=[],s,o])=>{const r=(...i)=>{const d=c(i);d==c(a)?e(t,...i,...o(i)):n(a[d])?y(s[d]?.(...i)??[],(t=>r(...i,t))):r(...i,a[d])};r()}))]})(),R=t=>{t!=N&&(N=t,K(W,void 0,N))},V=e=>{($&&i(e?.[0])?1===e?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===e?.[2]?t.applyChanges:t.setContent)(e)},X=async t=>(2!=N&&(R(1),F++,await tt((async()=>{try{const e=await a();i(e)?V(e):t?H(t):d("Content is not an array: "+e)}catch(e){h?.(e),t&&H(t)}R(0)}))),et),Y=()=>(D&&(g(D),D=void 0),et),Z=async t=>(1!=N&&(R(2),U++,await tt((async()=>{try{await s(q,t)}catch(t){h?.(t)}R(0)}))),et),_=()=>(J&&(t.delListener(J),J=void 0),et),tt=async(...t)=>(l(P(z,C),...t),await(async()=>{if(!P(x,C)){for(E(x,C,1);!n(A=u(P(z,C)));)try{await A()}catch(t){h?.(t)}E(x,C,0)}})(),et),et={load:X,startAutoLoad:async t=>{Y(),await X(t);try{D=await r((async(t,e)=>{e||t?2!=N&&(R(1),F++,V(e??t),R(0)):await X()}))}catch(t){h?.(t)}return et},stopAutoLoad:Y,isAutoLoading:()=>!n(D),save:Z,startAutoSave:async()=>(_(),await Z(),J=t.addDidFinishTransactionListener((()=>{const t=B();G(t)&&Z(t)})),et),stopAutoSave:_,isAutoSaving:()=>!n(J),getStatus:()=>N,addStatusListener:t=>I(t,W),delListener:e=>(Q(e),t),schedule:tt,getStore:()=>t,destroy:()=>(P(z,C).splice(0,void 0),Y().stopAutoSave()),getStats:()=>({loads:F,saves:U}),...f};return v(et)},J=(t,a,n,i)=>{const{host:d,room:y}=a.partySocketOptions,{storeProtocol:l="https",storePath:u=A,messagePrefix:g=e}={...r(n)?{storeProtocol:n}:n},h=l+"://"+d+"/parties/"+a.name+"/"+y+u,p=async t=>await(await fetch(h,{...t?{method:"PUT",body:C(t)}:{},mode:"cors",cache:"no-store"})).json();return D(t,(async()=>await p()),(async(t,e)=>{var s;e?a.send(g+"s"+(r(s=e)?s:C(s))):await p(t())}),(t=>{const e=e=>o(((t,e)=>{const a=c(t);return((t,e)=>t.startsWith(e))(e,t)?[e[a],S((s=e,n=a+1,s.slice(n,void 0)))]:void 0;var s,n})(g,e.data),(([e,a])=>{"s"==e&&t(void 0,a)}));return a.addEventListener(s,e),e}),(t=>{a.removeEventListener(s,t)}),i,1,{getConnection:()=>a})};export{J as createPartyKitPersister};
@@ -1 +1 @@
1
- const t=t=>typeof t,e="",a=t(e),s=t=>null==t,n=(t,e,a)=>s(t)?a?.():e(t),o=e=>t(e)==a,r=t=>Array.isArray(t),i=t=>t.length,c=t=>{throw Error(t)},d=(t,e)=>t.forEach(e),l=(t,...e)=>t.push(...e),y=t=>t.shift(),u=Object,g=t=>u.getPrototypeOf(t),h=u.keys,p=u.freeze,v=t=>(t=>!s(t)&&n(g(t),(t=>t==u.prototype||s(g(t))),(()=>!0)))(t)&&0==(t=>i(h(t)))(t),w=JSON.stringify,f=JSON.parse,S=t=>w(t,((t,e)=>e instanceof Map?u.fromEntries([...e]):e)),C="/store",A=t=>s(t)||0==(t=>t?.size??0)(t),L=(t,e)=>t?.forEach(e),b=(t,e)=>t?.delete(e),m=t=>new Map(t),M=(t,e)=>t?.get(e),P=(t,e,a)=>s(a)?(b(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)):P(t,e,a()),M(t,e)},O=(t,e,a,s,o=0)=>n((a?E:M)(t,e[o],o>i(e)-2?a:m),(n=>{if(o>i(e)-2)return s?.(n)&&P(t,e[o]),n;const r=O(n,e,a,s,o+1);return A(n)&&P(t,e[o]),r})),T=t=>new Set(r(t)||s(t)?t:[t]),j=/^\d+$/,k=m(),x=m(),z=(t,a,o,u,g,h,w,f={},S=[])=>{let C,z,D,J=0,N=0,F=0;E(k,S,(()=>0)),E(x,S,(()=>[]));const U=m(),[W,$,q,B,G]=((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]:c("Store type not supported by this Persister"))(w,t),[H,I,K]=(()=>{let t;const[a,o]=(()=>{const t=[];let a=0;return[s=>(s?y(t):null)??e+a++,e=>{j.test(e)&&i(t)<1e3&&l(t,e)}]})(),r=m();return[(s,n,o,i=[],c=()=>[])=>{t??=tt;const d=a(1);var l,y;return P(r,d,[s,n,o,i,c]),l=O(n,o??[e],T),y=d,l?.add(y),d},(a,s,...n)=>d(((t,a=[e])=>{const s=[],n=(t,e)=>e==i(a)?l(s,t):null===a[e]?L(t,(t=>n(t,e+1))):d([a[e],null],(a=>n(M(t,a),e+1)));return n(t,0),s})(a,s),(e=>L(e,(e=>M(r,e)[0](t,...s??[],...n))))),t=>n(M(r,t),(([,a,s])=>(O(a,s??[e],void 0,(e=>(b(e,t),A(e)?1:0))),P(r,t),o(t),s))),e=>n(M(r,e),(([e,,a=[],n,o])=>{const r=(...c)=>{const l=i(c);l==i(a)?e(t,...c,...o(c)):s(a[l])?d(n[l]?.(...c)??[],(t=>r(...c,t))):r(...c,a[l])};r()}))]})(),Q=t=>{t!=J&&(J=t,I(U,void 0,J))},R=e=>{(W&&r(e?.[0])?1===e?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===e?.[2]?t.applyChanges:t.setContent)(e)},V=async t=>(2!=J&&(Q(1),N++,await _((async()=>{try{const e=await a();r(e)?R(e):t?G(t):c("Content is not an array "+e)}catch(e){h?.(e),t&&G(t)}Q(0)}))),tt),X=()=>(z&&(g(z),z=void 0),tt),Y=async t=>(1!=J&&(Q(2),F++,await _((async()=>{try{await o($,t)}catch(t){h?.(t)}Q(0)}))),tt),Z=()=>(n(D,t.delListener),D=void 0,tt),_=async(...t)=>(l(M(x,S),...t),await(async()=>{if(!M(k,S)){for(P(k,S,1);!s(C=y(M(x,S)));)try{await C()}catch(t){h?.(t)}P(k,S,0)}})(),tt),tt={load:V,startAutoLoad:async t=>{await X().load(t);try{z=await u((async(t,e)=>{e||t?2!=J&&(Q(1),N++,R(e??t),Q(0)):await V()}))}catch(t){h?.(t)}return tt},stopAutoLoad:X,isAutoLoading:()=>!s(z),save:Y,startAutoSave:async()=>(await Z().save(),D=t.addDidFinishTransactionListener((()=>{const t=q();B(t)&&Y(t)})),tt),stopAutoSave:Z,isAutoSaving:()=>!s(D),getStatus:()=>J,addStatusListener:t=>H(t,U),delListener:e=>(K(e),t),schedule:_,getStore:()=>t,destroy:()=>(M(x,S).splice(0,void 0),X().stopAutoSave()),getStats:()=>({loads:N,saves:F}),...f};return p(tt)},D="message",J=(t,a,s,r)=>{const{host:c,room:d}=a.partySocketOptions,{storeProtocol:l="https",storePath:y=C,messagePrefix:u=e}={...o(s)?{storeProtocol:s}:s},g=l+"://"+c+"/parties/"+a.name+"/"+d+y,h=async t=>await(await fetch(g,{...t?{method:"PUT",body:S(t)}:{},mode:"cors",cache:"no-store"})).json();return z(t,(async()=>await h()),(async(t,e)=>{var s;e?a.send(u+"s"+(o(s=e)?s:S(s))):await h(t())}),(t=>{const e=e=>n(((t,e)=>{const a=i(t);return((t,e)=>t.startsWith(e))(e,t)?[e[a],f((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 a.addEventListener(D,e),e}),(t=>{a.removeEventListener(D,t)}),r,1,{getConnection:()=>a})};export{J as createPartyKitPersister};
1
+ const t=t=>typeof t,e="",a=t(e),s="message",n=t=>null==t,o=(t,e,a)=>n(t)?a?.():e(t),r=e=>t(e)==a,i=t=>Array.isArray(t),c=t=>t.length,d=t=>{throw Error(t)},y=(t,e)=>t.forEach(e),l=(t,...e)=>t.push(...e),u=t=>t.shift(),g=Object,h=t=>g.getPrototypeOf(t),p=g.keys,v=g.freeze,w=t=>(t=>!n(t)&&o(h(t),(t=>t==g.prototype||n(h(t))),(()=>!0)))(t)&&0==(t=>c(p(t)))(t),f=JSON.stringify,S=JSON.parse,C=t=>f(t,((t,e)=>e instanceof Map?g.fromEntries([...e]):e)),A="/store",L=t=>n(t)||0==(t=>t?.size??0)(t),b=(t,e)=>t?.forEach(e),m=(t,e)=>t?.delete(e),M=t=>new Map(t),P=(t,e)=>t?.get(e),E=(t,e,a)=>n(a)?(m(t,e),t):t?.set(e,a),O=(t,e,a,s)=>{var n,o;return n=t,o=e,n?.has(o)?s?.(P(t,e)):E(t,e,a()),P(t,e)},T=(t,e,a,s,n=0)=>o((a?O:P)(t,e[n],n>c(e)-2?a:M),(o=>{if(n>c(e)-2)return s?.(o)&&E(t,e[n]),o;const r=T(o,e,a,s,n+1);return L(o)&&E(t,e[n]),r})),j=t=>new Set(i(t)||n(t)?t:[t]),k=/^\d+$/,x=M(),z=M(),D=(t,a,s,r,g,h,p,f={},S=0,C=[])=>{let A,D,J,N=0,F=0,U=0;O(x,C,(()=>0)),O(z,C,(()=>[]));const W=M(),[$,q,B,G,H]=((t=1,e,a)=>1!=t&&e.isMergeable()?[1,e.getMergeableContent,()=>e.getTransactionMergeableChanges(!a),([[t],[e]])=>!w(t)||!w(e),e.setDefaultContent]:2!=t?[0,e.getContent,e.getTransactionChanges,([t,e])=>!w(t)||!w(e),e.setContent]:d("Store type not supported by this Persister"))(p,t,S),[I,K,Q]=(()=>{let t;const[a,s]=(()=>{const t=[];let a=0;return[s=>(s?u(t):null)??e+a++,e=>{k.test(e)&&c(t)<1e3&&l(t,e)}]})(),r=M();return[(s,n,o,i=[],c=()=>[])=>{t??=et;const d=a(1);var y,l;return E(r,d,[s,n,o,i,c]),y=T(n,o??[e],j),l=d,y?.add(l),d},(a,s,...n)=>y(((t,a=[e])=>{const s=[],n=(t,e)=>e==c(a)?l(s,t):null===a[e]?b(t,(t=>n(t,e+1))):y([a[e],null],(a=>n(P(t,a),e+1)));return n(t,0),s})(a,s),(e=>b(e,(e=>P(r,e)[0](t,...s??[],...n))))),t=>o(P(r,t),(([,a,n])=>(T(a,n??[e],void 0,(e=>(m(e,t),L(e)?1:0))),E(r,t),s(t),n))),e=>o(P(r,e),(([e,,a=[],s,o])=>{const r=(...i)=>{const d=c(i);d==c(a)?e(t,...i,...o(i)):n(a[d])?y(s[d]?.(...i)??[],(t=>r(...i,t))):r(...i,a[d])};r()}))]})(),R=t=>{t!=N&&(N=t,K(W,void 0,N))},V=e=>{($&&i(e?.[0])?1===e?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===e?.[2]?t.applyChanges:t.setContent)(e)},X=async t=>(2!=N&&(R(1),F++,await tt((async()=>{try{const e=await a();i(e)?V(e):t?H(t):d("Content is not an array: "+e)}catch(e){h?.(e),t&&H(t)}R(0)}))),et),Y=()=>(D&&(g(D),D=void 0),et),Z=async t=>(1!=N&&(R(2),U++,await tt((async()=>{try{await s(q,t)}catch(t){h?.(t)}R(0)}))),et),_=()=>(J&&(t.delListener(J),J=void 0),et),tt=async(...t)=>(l(P(z,C),...t),await(async()=>{if(!P(x,C)){for(E(x,C,1);!n(A=u(P(z,C)));)try{await A()}catch(t){h?.(t)}E(x,C,0)}})(),et),et={load:X,startAutoLoad:async t=>{Y(),await X(t);try{D=await r((async(t,e)=>{e||t?2!=N&&(R(1),F++,V(e??t),R(0)):await X()}))}catch(t){h?.(t)}return et},stopAutoLoad:Y,isAutoLoading:()=>!n(D),save:Z,startAutoSave:async()=>(_(),await Z(),J=t.addDidFinishTransactionListener((()=>{const t=B();G(t)&&Z(t)})),et),stopAutoSave:_,isAutoSaving:()=>!n(J),getStatus:()=>N,addStatusListener:t=>I(t,W),delListener:e=>(Q(e),t),schedule:tt,getStore:()=>t,destroy:()=>(P(z,C).splice(0,void 0),Y().stopAutoSave()),getStats:()=>({loads:F,saves:U}),...f};return v(et)},J=(t,a,n,i)=>{const{host:d,room:y}=a.partySocketOptions,{storeProtocol:l="https",storePath:u=A,messagePrefix:g=e}={...r(n)?{storeProtocol:n}:n},h=l+"://"+d+"/parties/"+a.name+"/"+y+u,p=async t=>await(await fetch(h,{...t?{method:"PUT",body:C(t)}:{},mode:"cors",cache:"no-store"})).json();return D(t,(async()=>await p()),(async(t,e)=>{var s;e?a.send(g+"s"+(r(s=e)?s:C(s))):await p(t())}),(t=>{const e=e=>o(((t,e)=>{const a=c(t);return((t,e)=>t.startsWith(e))(e,t)?[e[a],S((s=e,n=a+1,s.slice(n,void 0)))]:void 0;var s,n})(g,e.data),(([e,a])=>{"s"==e&&t(void 0,a)}));return a.addEventListener(s,e),e}),(t=>{a.removeEventListener(s,t)}),i,1,{getConnection:()=>a})};export{J as createPartyKitPersister};
@@ -1 +1 @@
1
- const a=a=>typeof a,t="tinybase",e=",",n=a(""),s=Promise,i=a=>null==a,o=(a,t,e)=>i(a)?e?.():t(a),r=t=>a(t)==n,c=a=>Array.isArray(a),E=(a,t,e)=>a.slice(t,e),l=a=>a.length,w=async a=>s.all(a),y=a=>{throw Error(a)},d=(a,t)=>a.forEach(t),u=(a,t="")=>a.join(t),T=(a,t)=>a.map(t),R=a=>0==l(a),A=(a,t)=>a.filter(t),N=(a,...t)=>a.push(...t),g=a=>a.shift(),p="_",C="_id",O="SELECT",L="WHERE",v="TABLE",$="ALTER "+v,I="DELETE FROM",S=O+"*FROM",m=a=>`"${a.replace(/"/g,'""')}"`,_=(a,t=[1])=>u(T(a,(()=>"$"+t[0]++)),e),h=(a,t)=>a?.has(t)??!1,f=a=>i(a)||0==(a=>a?.size??0)(a),b=a=>[...a?.values()??[]],D=(a,t)=>a?.forEach(t),P=(a,t)=>a?.delete(t),U=Object,F=a=>U.getPrototypeOf(a),M=U.entries,G=U.keys,B=U.freeze,j=(a=[])=>U.fromEntries(a),x=(...a)=>U.assign({},...a),X=(a,t)=>(delete a[t],a),Y=(a,t)=>T(M(a),(([a,e])=>t(e,a))),q=a=>U.values(a),H=a=>l(G(a)),W=a=>(a=>!i(a)&&o(F(a),(a=>a==U.prototype||i(F(a))),(()=>!0)))(a)&&0==H(a),k=JSON.stringify,z=JSON.parse,J=a=>new Map(a),K=(a,t)=>a?.get(t),V=(a,t)=>T([...a?.entries()??[]],(([a,e])=>t(e,a))),Q=(a,t,e)=>i(e)?(P(a,t),a):a?.set(t,e),Z=(a,t,e,n)=>(h(a,t)?n?.(K(a,t)):Q(a,t,e()),K(a,t)),aa=(a,t,e,n,s=0)=>o((e?Z:K)(a,t[s],s>l(t)-2?e:J),(i=>{if(s>l(t)-2)return n?.(i)&&Q(a,t[s]),i;const o=aa(i,t,e,n,s+1);return f(i)&&Q(a,t[s]),o})),ta=a=>new Set(c(a)||i(a)?a:[a]),ea=(a,t)=>a?.add(t),na=/^\d+$/,sa=J(),ia=J(),oa=(a,t,e,n,s,r,E,w={},u=[])=>{let T,R,A,p=0,C=0,O=0;Z(sa,u,(()=>0)),Z(ia,u,(()=>[]));const L=J(),[v,$,I,S,m]=((a=1,t)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,t.getTransactionMergeableChanges,([[a],[t]])=>!W(a)||!W(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!W(a)||!W(t),t.setContent]:y("Store type not supported by this Persister"))(E,a),[_,h,b]=(()=>{let a;const[t,e]=(()=>{const a=[];let t=0;return[e=>(e?g(a):null)??""+t++,t=>{na.test(t)&&l(a)<1e3&&N(a,t)}]})(),n=J();return[(e,s,i,o=[],r=()=>[])=>{a??=Y;const c=t(1);return Q(n,c,[e,s,i,o,r]),ea(aa(s,i??[""],ta),c),c},(t,e,...s)=>d(((a,t=[""])=>{const e=[],n=(a,s)=>s==l(t)?N(e,a):null===t[s]?D(a,(a=>n(a,s+1))):d([t[s],null],(t=>n(K(a,t),s+1)));return n(a,0),e})(t,e),(t=>D(t,(t=>K(n,t)[0](a,...e??[],...s))))),a=>o(K(n,a),(([,t,s])=>(aa(t,s??[""],void 0,(t=>(P(t,a),f(t)?1:0))),Q(n,a),e(a),s))),t=>o(K(n,t),(([t,,e=[],n,s])=>{const o=(...r)=>{const c=l(r);c==l(e)?t(a,...r,...s(r)):i(e[c])?d(n[c]?.(...r)??[],(a=>o(...r,a))):o(...r,e[c])};o()}))]})(),U=a=>{a!=p&&(p=a,h(L,void 0,p))},F=t=>{(v&&c(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},M=async a=>(2!=p&&(U(1),C++,await X((async()=>{try{const e=await t();c(e)?F(e):a?m(a):y("Content is not an array "+e)}catch(t){r?.(t),a&&m(a)}U(0)}))),Y),G=()=>(R&&(s(R),R=void 0),Y),j=async a=>(1!=p&&(U(2),O++,await X((async()=>{try{await e($,a)}catch(a){r?.(a)}U(0)}))),Y),x=()=>(o(A,a.delListener),A=void 0,Y),X=async(...a)=>(N(K(ia,u),...a),await(async()=>{if(!K(sa,u)){for(Q(sa,u,1);!i(T=g(K(ia,u)));)try{await T()}catch(a){r?.(a)}Q(sa,u,0)}})(),Y),Y={load:M,startAutoLoad:async a=>{await G().load(a);try{R=await n((async(a,t)=>{t||a?2!=p&&(U(1),C++,F(t??a),U(0)):await M()}))}catch(a){r?.(a)}return Y},stopAutoLoad:G,isAutoLoading:()=>!i(R),save:j,startAutoSave:async()=>(await x().save(),A=a.addDidFinishTransactionListener((()=>{const a=I();S(a)&&j(a)})),Y),stopAutoSave:x,isAutoSaving:()=>!i(A),getStatus:()=>p,addStatusListener:a=>_(a,L),delListener:t=>(b(t),a),schedule:X,getStore:()=>a,destroy:()=>(K(ia,u).splice(0,void 0),G().stopAutoSave()),getStats:()=>({loads:C,saves:O}),...w};return B(Y)},ra=(a,t,n,s,o,r=ca,c,E)=>{const l=J();return[async()=>{l.clear(),T(await n(a,t),(({tn:a,cn:t})=>ea(Z(l,a,ta),t)))},async(t,e)=>((a,t)=>h(K(l,a),t))(t,e)?j(A(T(await a(S+m(t)),(a=>{return[a[e],E?(t=X(a,e),n=E,j(Y(t,((a,t)=>[t,n(a,t)])))):X(a,e)];var t,n})),(([a,t])=>!i(a)&&!W(t)))):{},async(t,n,s,E,y,d=!1)=>{const g=ta();Y(s??{},(a=>T(G(a??{}),(a=>ea(g,a)))));const p=b(g);if(!d&&y&&R(p)&&h(l,t))return await a("DROP "+v+m(t)),void Q(l,t);const C=K(l,t),O=ta(b(C));if(R(p)||(h(l,t)?await w(T([n,...p],(async(e,s)=>{P(O,e)||(await a($+m(t)+"ADD"+m(e)+o),0==s&&await a("CREATE UNIQUE INDEX pk ON "+m(t)+`(${m(n)})`),ea(C,e))}))):(await a("CREATE "+v+m(t)+`(${m(n)}${o} PRIMARY KEY${u(T(p,(a=>e+m(a)+o)))});`),Q(l,t,ta([n,...p])))),await w([...!d&&E?T(b(O),(async e=>{e!=n&&(await a($+m(t)+"DROP"+m(e)),P(C,e))})):[]]),d)i(s)?await a(I+m(t)+L+" true"):await w(Y(s,(async(e,s)=>{i(e)?await a(I+m(t)+L+m(n)+"=$1",[s]):R(p)||await r(a,t,n,G(e),{[s]:c?T(q(e),c):q(e)},C)})));else if(R(p))h(l,t)&&await a(I+m(t)+L+" true");else{const e=A(b(K(l,t)),(a=>a!=n)),i={},o=[];Y(s??{},((a,t)=>{i[t]=T(e,(t=>c?c(a?.[t]):a?.[t])),N(o,t)})),await r(a,t,n,e,i),await a(I+m(t)+L+m(n)+`NOT IN(${_(o)})`,o)}},async t=>{let e;await a("BEGIN");try{e=await t()}catch(a){s?.(a)}return await a("END"),e}]},ca=async(a,t,n,s,i)=>{const o=[1];await a("INSERT INTO"+m(t)+"("+((...a)=>u(T(a,m),e))(n,...s)+")VALUES"+u(Y(i,(a=>"($"+o[0]+++","+_(a,o)+")")),e)+"ON CONFLICT("+m(n)+")DO UPDATE SET"+u(T(s,(a=>m(a)+"=excluded."+m(a))),e),Y(i,((a,t)=>[t,...T(a,(a=>a??null))])).flat())},Ea=(a,t,e,n,s,i,o,[r,c,E],l,w,y,d,u,T)=>{const[R,A,N,g]=ra(t,l,w,s,u,T),C=oa(a,(async()=>await g((async()=>{return await R(),a=(await A(r,c))[p]?.[E]??"null",z(a,((a,t)=>""===t?void 0:t));var a}))),(async a=>await g((async()=>{var t;await R(),await N(r,c,{[p]:{[E]:(t=a()??null,k(t,((a,t)=>void 0===t?"":t)))}},!0,!0)}))),e,n,s,o,{[d]:()=>y,destroy:()=>(C.stopAutoLoad().stopAutoSave(),i(),C)},y);return C},la=(a,t,e,n,s,o,r,[c,E,[l,y,d]],u,T,R,N,g,O,L,v)=>{const[$,I,S,m]=ra(t,u,T,s,g,O,L,v),_=async(a,t)=>await w(V(E,(async([e,n,s,i],o)=>{t&&!(o in a)||await S(e,n,a[o],s,i,t)}))),h=async(a,t)=>y?await S(d,C,{[p]:a},!0,!0,t):null,f=oa(a,(async()=>await m((async()=>{await $();const a=await(async()=>j(A(await w(V(c,(async([a,t],e)=>[a,await I(e,t)]))),(a=>!W(a[1])))))(),t=await(async()=>l?(await I(d,C))[p]:{})();return W(a)&&i(t)?void 0:[a,t]}))),(async(a,t)=>await m((async()=>{if(await $(),i(t)){const[t,e]=a();await _(t),await h(e)}else await _(t[0],!0),await h(t[1],!0)}))),e,n,s,r,{[N]:()=>R,destroy:()=>(f.stopAutoLoad().stopAutoSave(),o(),f)},R);return f},wa="ColumnName",ya="store",da="json",ua=ya+"TableName",Ta=ya+"Id"+wa,Ra=ya+wa,Aa="autoLoadIntervalSeconds",Na="rowId"+wa,ga="tableId",pa="tableName",Ca="deleteEmptyColumns",Oa="deleteEmptyTable",La={mode:da,[Aa]:1},va={load:0,save:0,[pa]:t+"_values"},$a=(a,t,e,n,s)=>{const o=J();return Y(a,((a,c)=>{const l=E(q(x(t,r(a)?{[e]:a}:a)),0,H(t));i(l[0])||n(c,l[0])||(s(c,l[0]),Q(o,c,l))})),o},Ia=t,Sa=/^([cd]:)(.+)/,ma=t+"_data",_a=t+"_table",ha=async(a,e,n,s,i)=>((a,e,n,s,i,c,l,y,d,u,R="getDb")=>{const A=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(n,c),[N,,g,p]=(a=>{const e=(a=>x(La,r(a)?{[ua]:a}:a??{}))(a),n=e[Aa];if(e.mode==da){const a=e[ua]??t;return[1,n,[a,e[Ta]??C,e[Ra]??ya],ta(a)]}const{tables:{load:s={},save:i={}}={},values:o={}}=e,c=E(q(x(va,o)),0,H(va)),l=c[2],w=ta(l),y=ta(l);return[0,n,[$a(s,{[ga]:null,[Na]:C},ga,(a=>h(y,a)),(a=>ea(w,a))),$a(i,{[pa]:null,[Na]:C,[Ca]:0,[Oa]:0},pa,((a,t)=>h(y,t)),((a,t)=>ea(w,t))),c],w]})(e),v=async a=>{await A(`CREATE OR REPLACE TRIGGER ${m(ma+"_"+a)} AFTER INSERT OR UPDATE OR DELETE ON ${m(a)} EXECUTE FUNCTION ${ma}()`)};return(N?Ea:la)(a,A,(async a=>{await A(`CREATE OR REPLACE FUNCTION ${_a}()RETURNS event_trigger AS $t2$ DECLARE row record; BEGIN FOR row IN SELECT object_identity FROM pg_event_trigger_ddl_commands()WHERE command_tag='CREATE TABLE' LOOP PERFORM pg_notify('${Ia}','c:'||SPLIT_PART(row.object_identity,'.',2));END LOOP;END;$t2$ LANGUAGE plpgsql;`);try{await A(`CREATE EVENT TRIGGER ${_a} ON ddl_command_end WHEN TAG IN('CREATE TABLE')EXECUTE FUNCTION ${_a}();`)}catch{}return await A(`CREATE OR REPLACE FUNCTION ${ma}()RETURNS trigger AS $t1$ BEGIN PERFORM pg_notify('${Ia}','d:'||TG_TABLE_NAME);RETURN NULL;END;$t1$ LANGUAGE plpgsql;`),await w(T(b(p),(async a=>{await A(`CREATE TABLE IF NOT EXISTS ${m(a)}("_id"text PRIMARY KEY)`),await v(a)}))),await s(Ia,(async t=>{return await o((e=t,n=Sa,e?.match(n)),(async([,t,e])=>{h(p,e)&&("c:"==t&&await v(e),a())}));var e,n}))}),i,l,y,d,g,b(p),(async(a,t)=>await a(`${O} table_name tn,column_name cn FROM information_schema.columns ${L} table_schema='public'AND table_name IN(${_(t)})`,t)),u,R,"text",void 0,(a=>k(a)),(a=>z(a)))})(a,n,(async(a,t=[])=>(await e.query(a,t)).rows),(async(a,t)=>await e.listen(a,t)),(async a=>{try{await a()}catch(a){i?.(a)}}),s,i,(()=>0),3,e,"getPglite");export{ha as createPglitePersister};
1
+ const a=a=>typeof a,t="tinybase",e=",",n=a(""),s=Promise,i=a=>null==a,r=(a,t,e)=>i(a)?e?.():t(a),o=t=>a(t)==n,c=a=>Array.isArray(a),E=(a,t,e)=>a.slice(t,e),l=a=>a.length,w=async a=>s.all(a),y=a=>{throw Error(a)},d=(a,t)=>a.forEach(t),u=(a,t="")=>a.join(t),T=(a,t)=>a.map(t),R=a=>0==l(a),A=(a,t)=>a.filter(t),N=(a,...t)=>a.push(...t),g=a=>a.shift(),p="_",C="_id",O="SELECT",L="WHERE",v="TABLE",$="ALTER "+v,I="DELETE FROM",S=O+"*FROM",m=a=>`"${a.replace(/"/g,'""')}"`,_=(a,t=[1])=>u(T(a,(()=>"$"+t[0]++)),e),h=(a,t)=>a?.has(t)??!1,f=a=>i(a)||0==(a=>a?.size??0)(a),b=a=>[...a?.values()??[]],D=(a,t)=>a?.forEach(t),P=(a,t)=>a?.delete(t),U=Object,F=a=>U.getPrototypeOf(a),M=U.entries,G=U.keys,B=U.freeze,j=(a=[])=>U.fromEntries(a),x=(...a)=>U.assign({},...a),X=(a,t)=>(delete a[t],a),Y=(a,t)=>T(M(a),(([a,e])=>t(e,a))),q=a=>U.values(a),H=a=>l(G(a)),W=a=>(a=>!i(a)&&r(F(a),(a=>a==U.prototype||i(F(a))),(()=>!0)))(a)&&0==H(a),k=JSON.stringify,z=JSON.parse,J=a=>new Map(a),K=(a,t)=>a?.get(t),V=(a,t)=>T([...a?.entries()??[]],(([a,e])=>t(e,a))),Q=(a,t,e)=>i(e)?(P(a,t),a):a?.set(t,e),Z=(a,t,e,n)=>(h(a,t)?n?.(K(a,t)):Q(a,t,e()),K(a,t)),aa=(a,t,e,n,s=0)=>r((e?Z:K)(a,t[s],s>l(t)-2?e:J),(i=>{if(s>l(t)-2)return n?.(i)&&Q(a,t[s]),i;const r=aa(i,t,e,n,s+1);return f(i)&&Q(a,t[s]),r})),ta=a=>new Set(c(a)||i(a)?a:[a]),ea=(a,t)=>a?.add(t),na=/^\d+$/,sa=J(),ia=J(),ra=(a,t,e,n,s,o,E,w={},u=0,T=[])=>{let R,A,p,C=0,O=0,L=0;Z(sa,T,(()=>0)),Z(ia,T,(()=>[]));const v=J(),[$,I,S,m,_]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!W(a)||!W(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!W(a)||!W(t),t.setContent]:y("Store type not supported by this Persister"))(E,a,u),[h,b,U]=(()=>{let a;const[t,e]=(()=>{const a=[];let t=0;return[e=>(e?g(a):null)??""+t++,t=>{na.test(t)&&l(a)<1e3&&N(a,t)}]})(),n=J();return[(e,s,i,r=[],o=()=>[])=>{a??=q;const c=t(1);return Q(n,c,[e,s,i,r,o]),ea(aa(s,i??[""],ta),c),c},(t,e,...s)=>d(((a,t=[""])=>{const e=[],n=(a,s)=>s==l(t)?N(e,a):null===t[s]?D(a,(a=>n(a,s+1))):d([t[s],null],(t=>n(K(a,t),s+1)));return n(a,0),e})(t,e),(t=>D(t,(t=>K(n,t)[0](a,...e??[],...s))))),a=>r(K(n,a),(([,t,s])=>(aa(t,s??[""],void 0,(t=>(P(t,a),f(t)?1:0))),Q(n,a),e(a),s))),t=>r(K(n,t),(([t,,e=[],n,s])=>{const r=(...o)=>{const c=l(o);c==l(e)?t(a,...o,...s(o)):i(e[c])?d(n[c]?.(...o)??[],(a=>r(...o,a))):r(...o,e[c])};r()}))]})(),F=a=>{a!=C&&(C=a,b(v,void 0,C))},M=t=>{($&&c(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},G=async a=>(2!=C&&(F(1),O++,await Y((async()=>{try{const e=await t();c(e)?M(e):a?_(a):y("Content is not an array: "+e)}catch(t){o?.(t),a&&_(a)}F(0)}))),q),j=()=>(A&&(s(A),A=void 0),q),x=async a=>(1!=C&&(F(2),L++,await Y((async()=>{try{await e(I,a)}catch(a){o?.(a)}F(0)}))),q),X=()=>(p&&(a.delListener(p),p=void 0),q),Y=async(...a)=>(N(K(ia,T),...a),await(async()=>{if(!K(sa,T)){for(Q(sa,T,1);!i(R=g(K(ia,T)));)try{await R()}catch(a){o?.(a)}Q(sa,T,0)}})(),q),q={load:G,startAutoLoad:async a=>{j(),await G(a);try{A=await n((async(a,t)=>{t||a?2!=C&&(F(1),O++,M(t??a),F(0)):await G()}))}catch(a){o?.(a)}return q},stopAutoLoad:j,isAutoLoading:()=>!i(A),save:x,startAutoSave:async()=>(X(),await x(),p=a.addDidFinishTransactionListener((()=>{const a=S();m(a)&&x(a)})),q),stopAutoSave:X,isAutoSaving:()=>!i(p),getStatus:()=>C,addStatusListener:a=>h(a,v),delListener:t=>(U(t),a),schedule:Y,getStore:()=>a,destroy:()=>(K(ia,T).splice(0,void 0),j().stopAutoSave()),getStats:()=>({loads:O,saves:L}),...w};return B(q)},oa=(a,t,n,s,r,o=ca,c,E)=>{const l=J();return[async()=>{l.clear(),T(await n(a,t),(({tn:a,cn:t})=>ea(Z(l,a,ta),t)))},async(t,e)=>((a,t)=>h(K(l,a),t))(t,e)?j(A(T(await a(S+m(t)),(a=>{return[a[e],E?(t=X(a,e),n=E,j(Y(t,((a,t)=>[t,n(a,t)])))):X(a,e)];var t,n})),(([a,t])=>!i(a)&&!W(t)))):{},async(t,n,s,E,y,d=!1)=>{const g=ta();Y(s??{},(a=>T(G(a??{}),(a=>ea(g,a)))));const p=b(g);if(!d&&y&&R(p)&&h(l,t))return await a("DROP "+v+m(t)),void Q(l,t);const C=K(l,t),O=ta(b(C));if(R(p)||(h(l,t)?await w(T([n,...p],(async(e,s)=>{P(O,e)||(await a($+m(t)+"ADD"+m(e)+r),0==s&&await a("CREATE UNIQUE INDEX pk ON "+m(t)+`(${m(n)})`),ea(C,e))}))):(await a("CREATE "+v+m(t)+`(${m(n)}${r} PRIMARY KEY${u(T(p,(a=>e+m(a)+r)))});`),Q(l,t,ta([n,...p])))),await w([...!d&&E?T(b(O),(async e=>{e!=n&&(await a($+m(t)+"DROP"+m(e)),P(C,e))})):[]]),d)i(s)?await a(I+m(t)+L+" true"):await w(Y(s,(async(e,s)=>{i(e)?await a(I+m(t)+L+m(n)+"=$1",[s]):R(p)||await o(a,t,n,G(e),{[s]:c?T(q(e),c):q(e)},C)})));else if(R(p))h(l,t)&&await a(I+m(t)+L+" true");else{const e=A(b(K(l,t)),(a=>a!=n)),i={},r=[];Y(s??{},((a,t)=>{i[t]=T(e,(t=>c?c(a?.[t]):a?.[t])),N(r,t)})),await o(a,t,n,e,i),await a(I+m(t)+L+m(n)+`NOT IN(${_(r)})`,r)}},async t=>{let e;await a("BEGIN");try{e=await t()}catch(a){s?.(a)}return await a("END"),e}]},ca=async(a,t,n,s,i)=>{const r=[1];await a("INSERT INTO"+m(t)+"("+((...a)=>u(T(a,m),e))(n,...s)+")VALUES"+u(Y(i,(a=>"($"+r[0]+++","+_(a,r)+")")),e)+"ON CONFLICT("+m(n)+")DO UPDATE SET"+u(T(s,(a=>m(a)+"=excluded."+m(a))),e),Y(i,((a,t)=>[t,...T(a,(a=>a??null))])).flat())},Ea=(a,t,e,n,s,i,r,[o,c,E],l,w,y,d,u,T)=>{const[R,A,N,g]=oa(t,l,w,s,u,T),C=ra(a,(async()=>await g((async()=>{return await R(),a=(await A(o,c))[p]?.[E]??"null",z(a,((a,t)=>""===t?void 0:t));var a}))),(async a=>await g((async()=>{var t;await R(),await N(o,c,{[p]:{[E]:(t=a()??null,k(t,((a,t)=>void 0===t?"":t)))}},!0,!0)}))),e,n,s,r,{[d]:()=>y,destroy:()=>(C.stopAutoLoad().stopAutoSave(),i(),C)},0,y);return C},la=(a,t,e,n,s,r,o,[c,E,[l,y,d]],u,T,R,N,g,O,L,v)=>{const[$,I,S,m]=oa(t,u,T,s,g,O,L,v),_=async(a,t)=>await w(V(E,(async([e,n,s,i],r)=>{t&&!(r in a)||await S(e,n,a[r],s,i,t)}))),h=async(a,t)=>y?await S(d,C,{[p]:a},!0,!0,t):null,f=ra(a,(async()=>await m((async()=>{await $();const a=await(async()=>j(A(await w(V(c,(async([a,t],e)=>[a,await I(e,t)]))),(a=>!W(a[1])))))(),t=await(async()=>l?(await I(d,C))[p]:{})();return W(a)&&i(t)?void 0:[a,t]}))),(async(a,t)=>await m((async()=>{if(await $(),i(t)){const[t,e]=a();await _(t),await h(e)}else await _(t[0],!0),await h(t[1],!0)}))),e,n,s,o,{[N]:()=>R,destroy:()=>(f.stopAutoLoad().stopAutoSave(),r(),f)},0,R);return f},wa="ColumnName",ya="store",da="json",ua=ya+"TableName",Ta=ya+"Id"+wa,Ra=ya+wa,Aa="autoLoadIntervalSeconds",Na="rowId"+wa,ga="tableId",pa="tableName",Ca="deleteEmptyColumns",Oa="deleteEmptyTable",La={mode:da,[Aa]:1},va={load:0,save:0,[pa]:t+"_values"},$a=(a,t,e,n,s)=>{const r=J();return Y(a,((a,c)=>{const l=E(q(x(t,o(a)?{[e]:a}:a)),0,H(t));i(l[0])||n(c,l[0])||(s(c,l[0]),Q(r,c,l))})),r},Ia=t,Sa=/^([cd]:)(.+)/,ma=t+"_data",_a=t+"_table",ha=async(a,e,n,s,i)=>((a,e,n,s,i,c,l,y,d,u,R="getDb")=>{const A=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(n,c),[N,,g,p]=(a=>{const e=(a=>x(La,o(a)?{[ua]:a}:a??{}))(a),n=e[Aa];if(e.mode==da){const a=e[ua]??t;return[1,n,[a,e[Ta]??C,e[Ra]??ya],ta(a)]}const{tables:{load:s={},save:i={}}={},values:r={}}=e,c=E(q(x(va,r)),0,H(va)),l=c[2],w=ta(l),y=ta(l);return[0,n,[$a(s,{[ga]:null,[Na]:C},ga,(a=>h(y,a)),(a=>ea(w,a))),$a(i,{[pa]:null,[Na]:C,[Ca]:0,[Oa]:0},pa,((a,t)=>h(y,t)),((a,t)=>ea(w,t))),c],w]})(e),v=async a=>{await A(`CREATE OR REPLACE TRIGGER ${m(ma+"_"+a)} AFTER INSERT OR UPDATE OR DELETE ON ${m(a)} EXECUTE FUNCTION ${ma}()`)};return(N?Ea:la)(a,A,(async a=>{await A(`CREATE OR REPLACE FUNCTION ${_a}()RETURNS event_trigger AS $t2$ DECLARE row record; BEGIN FOR row IN SELECT object_identity FROM pg_event_trigger_ddl_commands()WHERE command_tag='CREATE TABLE' LOOP PERFORM pg_notify('${Ia}','c:'||SPLIT_PART(row.object_identity,'.',2));END LOOP;END;$t2$ LANGUAGE plpgsql;`);try{await A(`CREATE EVENT TRIGGER ${_a} ON ddl_command_end WHEN TAG IN('CREATE TABLE')EXECUTE FUNCTION ${_a}();`)}catch{}return await A(`CREATE OR REPLACE FUNCTION ${ma}()RETURNS trigger AS $t1$ BEGIN PERFORM pg_notify('${Ia}','d:'||TG_TABLE_NAME);RETURN NULL;END;$t1$ LANGUAGE plpgsql;`),await w(T(b(p),(async a=>{await A(`CREATE TABLE IF NOT EXISTS ${m(a)}("_id"text PRIMARY KEY)`),await v(a)}))),await s(Ia,(async t=>{return await r((e=t,n=Sa,e?.match(n)),(async([,t,e])=>{h(p,e)&&("c:"==t&&await v(e),a())}));var e,n}))}),i,l,y,d,g,b(p),(async(a,t)=>await a(`${O} table_name tn,column_name cn FROM information_schema.columns ${L} table_schema='public'AND table_name IN(${_(t)})`,t)),u,R,"text",void 0,(a=>k(a)),(a=>z(a)))})(a,n,(async(a,t=[])=>(await e.query(a,t)).rows),(async(a,t)=>await e.listen(a,t)),(async a=>{try{await a()}catch(a){i?.(a)}}),s,i,(()=>0),3,e,"getPglite");export{ha as createPglitePersister};
@@ -1 +1 @@
1
- const a=a=>typeof a,t="tinybase",e=",",n=a(""),s=Promise,i=a=>null==a,o=(a,t,e)=>i(a)?e?.():t(a),r=t=>a(t)==n,c=a=>Array.isArray(a),E=(a,t,e)=>a.slice(t,e),l=a=>a.length,w=async a=>s.all(a),y=a=>{throw Error(a)},d=(a,t)=>a.forEach(t),u=(a,t="")=>a.join(t),T=(a,t)=>a.map(t),R=a=>0==l(a),A=(a,t)=>a.filter(t),N=(a,...t)=>a.push(...t),g=a=>a.shift(),p="_",C="_id",O="SELECT",L="WHERE",v="TABLE",$="ALTER "+v,I="DELETE FROM",S=O+"*FROM",m=a=>`"${a.replace(/"/g,'""')}"`,_=(a,t=[1])=>u(T(a,(()=>"$"+t[0]++)),e),h=(a,t)=>a?.has(t)??!1,f=a=>i(a)||0==(a=>a?.size??0)(a),b=a=>[...a?.values()??[]],D=(a,t)=>a?.forEach(t),P=(a,t)=>a?.delete(t),U=Object,F=a=>U.getPrototypeOf(a),M=U.entries,G=U.keys,B=U.freeze,j=(a=[])=>U.fromEntries(a),x=(...a)=>U.assign({},...a),X=(a,t)=>(delete a[t],a),Y=(a,t)=>T(M(a),(([a,e])=>t(e,a))),q=a=>U.values(a),H=a=>l(G(a)),W=a=>(a=>!i(a)&&o(F(a),(a=>a==U.prototype||i(F(a))),(()=>!0)))(a)&&0==H(a),k=JSON.stringify,z=JSON.parse,J=a=>new Map(a),K=(a,t)=>a?.get(t),V=(a,t)=>T([...a?.entries()??[]],(([a,e])=>t(e,a))),Q=(a,t,e)=>i(e)?(P(a,t),a):a?.set(t,e),Z=(a,t,e,n)=>(h(a,t)?n?.(K(a,t)):Q(a,t,e()),K(a,t)),aa=(a,t,e,n,s=0)=>o((e?Z:K)(a,t[s],s>l(t)-2?e:J),(i=>{if(s>l(t)-2)return n?.(i)&&Q(a,t[s]),i;const o=aa(i,t,e,n,s+1);return f(i)&&Q(a,t[s]),o})),ta=a=>new Set(c(a)||i(a)?a:[a]),ea=(a,t)=>a?.add(t),na=/^\d+$/,sa=J(),ia=J(),oa=(a,t,e,n,s,r,E,w={},u=[])=>{let T,R,A,p=0,C=0,O=0;Z(sa,u,(()=>0)),Z(ia,u,(()=>[]));const L=J(),[v,$,I,S,m]=((a=1,t)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,t.getTransactionMergeableChanges,([[a],[t]])=>!W(a)||!W(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!W(a)||!W(t),t.setContent]:y("Store type not supported by this Persister"))(E,a),[_,h,b]=(()=>{let a;const[t,e]=(()=>{const a=[];let t=0;return[e=>(e?g(a):null)??""+t++,t=>{na.test(t)&&l(a)<1e3&&N(a,t)}]})(),n=J();return[(e,s,i,o=[],r=()=>[])=>{a??=Y;const c=t(1);return Q(n,c,[e,s,i,o,r]),ea(aa(s,i??[""],ta),c),c},(t,e,...s)=>d(((a,t=[""])=>{const e=[],n=(a,s)=>s==l(t)?N(e,a):null===t[s]?D(a,(a=>n(a,s+1))):d([t[s],null],(t=>n(K(a,t),s+1)));return n(a,0),e})(t,e),(t=>D(t,(t=>K(n,t)[0](a,...e??[],...s))))),a=>o(K(n,a),(([,t,s])=>(aa(t,s??[""],void 0,(t=>(P(t,a),f(t)?1:0))),Q(n,a),e(a),s))),t=>o(K(n,t),(([t,,e=[],n,s])=>{const o=(...r)=>{const c=l(r);c==l(e)?t(a,...r,...s(r)):i(e[c])?d(n[c]?.(...r)??[],(a=>o(...r,a))):o(...r,e[c])};o()}))]})(),U=a=>{a!=p&&(p=a,h(L,void 0,p))},F=t=>{(v&&c(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},M=async a=>(2!=p&&(U(1),C++,await X((async()=>{try{const e=await t();c(e)?F(e):a?m(a):y("Content is not an array "+e)}catch(t){r?.(t),a&&m(a)}U(0)}))),Y),G=()=>(R&&(s(R),R=void 0),Y),j=async a=>(1!=p&&(U(2),O++,await X((async()=>{try{await e($,a)}catch(a){r?.(a)}U(0)}))),Y),x=()=>(o(A,a.delListener),A=void 0,Y),X=async(...a)=>(N(K(ia,u),...a),await(async()=>{if(!K(sa,u)){for(Q(sa,u,1);!i(T=g(K(ia,u)));)try{await T()}catch(a){r?.(a)}Q(sa,u,0)}})(),Y),Y={load:M,startAutoLoad:async a=>{await G().load(a);try{R=await n((async(a,t)=>{t||a?2!=p&&(U(1),C++,F(t??a),U(0)):await M()}))}catch(a){r?.(a)}return Y},stopAutoLoad:G,isAutoLoading:()=>!i(R),save:j,startAutoSave:async()=>(await x().save(),A=a.addDidFinishTransactionListener((()=>{const a=I();S(a)&&j(a)})),Y),stopAutoSave:x,isAutoSaving:()=>!i(A),getStatus:()=>p,addStatusListener:a=>_(a,L),delListener:t=>(b(t),a),schedule:X,getStore:()=>a,destroy:()=>(K(ia,u).splice(0,void 0),G().stopAutoSave()),getStats:()=>({loads:C,saves:O}),...w};return B(Y)},ra=(a,t,n,s,o,r=ca,c,E)=>{const l=J();return[async()=>{l.clear(),T(await n(a,t),(({tn:a,cn:t})=>ea(Z(l,a,ta),t)))},async(t,e)=>((a,t)=>h(K(l,a),t))(t,e)?j(A(T(await a(S+m(t)),(a=>{return[a[e],E?(t=X(a,e),n=E,j(Y(t,((a,t)=>[t,n(a,t)])))):X(a,e)];var t,n})),(([a,t])=>!i(a)&&!W(t)))):{},async(t,n,s,E,y,d=!1)=>{const g=ta();Y(s??{},(a=>T(G(a??{}),(a=>ea(g,a)))));const p=b(g);if(!d&&y&&R(p)&&h(l,t))return await a("DROP "+v+m(t)),void Q(l,t);const C=K(l,t),O=ta(b(C));if(R(p)||(h(l,t)?await w(T([n,...p],(async(e,s)=>{P(O,e)||(await a($+m(t)+"ADD"+m(e)+o),0==s&&await a("CREATE UNIQUE INDEX pk ON "+m(t)+`(${m(n)})`),ea(C,e))}))):(await a("CREATE "+v+m(t)+`(${m(n)}${o} PRIMARY KEY${u(T(p,(a=>e+m(a)+o)))});`),Q(l,t,ta([n,...p])))),await w([...!d&&E?T(b(O),(async e=>{e!=n&&(await a($+m(t)+"DROP"+m(e)),P(C,e))})):[]]),d)i(s)?await a(I+m(t)+L+" true"):await w(Y(s,(async(e,s)=>{i(e)?await a(I+m(t)+L+m(n)+"=$1",[s]):R(p)||await r(a,t,n,G(e),{[s]:c?T(q(e),c):q(e)},C)})));else if(R(p))h(l,t)&&await a(I+m(t)+L+" true");else{const e=A(b(K(l,t)),(a=>a!=n)),i={},o=[];Y(s??{},((a,t)=>{i[t]=T(e,(t=>c?c(a?.[t]):a?.[t])),N(o,t)})),await r(a,t,n,e,i),await a(I+m(t)+L+m(n)+`NOT IN(${_(o)})`,o)}},async t=>{let e;await a("BEGIN");try{e=await t()}catch(a){s?.(a)}return await a("END"),e}]},ca=async(a,t,n,s,i)=>{const o=[1];await a("INSERT INTO"+m(t)+"("+((...a)=>u(T(a,m),e))(n,...s)+")VALUES"+u(Y(i,(a=>"($"+o[0]+++","+_(a,o)+")")),e)+"ON CONFLICT("+m(n)+")DO UPDATE SET"+u(T(s,(a=>m(a)+"=excluded."+m(a))),e),Y(i,((a,t)=>[t,...T(a,(a=>a??null))])).flat())},Ea=(a,t,e,n,s,i,o,[r,c,E],l,w,y,d,u,T)=>{const[R,A,N,g]=ra(t,l,w,s,u,T),C=oa(a,(async()=>await g((async()=>{return await R(),a=(await A(r,c))[p]?.[E]??"null",z(a,((a,t)=>""===t?void 0:t));var a}))),(async a=>await g((async()=>{var t;await R(),await N(r,c,{[p]:{[E]:(t=a()??null,k(t,((a,t)=>void 0===t?"":t)))}},!0,!0)}))),e,n,s,o,{[d]:()=>y,destroy:()=>(C.stopAutoLoad().stopAutoSave(),i(),C)},y);return C},la=(a,t,e,n,s,o,r,[c,E,[l,y,d]],u,T,R,N,g,O,L,v)=>{const[$,I,S,m]=ra(t,u,T,s,g,O,L,v),_=async(a,t)=>await w(V(E,(async([e,n,s,i],o)=>{t&&!(o in a)||await S(e,n,a[o],s,i,t)}))),h=async(a,t)=>y?await S(d,C,{[p]:a},!0,!0,t):null,f=oa(a,(async()=>await m((async()=>{await $();const a=await(async()=>j(A(await w(V(c,(async([a,t],e)=>[a,await I(e,t)]))),(a=>!W(a[1])))))(),t=await(async()=>l?(await I(d,C))[p]:{})();return W(a)&&i(t)?void 0:[a,t]}))),(async(a,t)=>await m((async()=>{if(await $(),i(t)){const[t,e]=a();await _(t),await h(e)}else await _(t[0],!0),await h(t[1],!0)}))),e,n,s,r,{[N]:()=>R,destroy:()=>(f.stopAutoLoad().stopAutoSave(),o(),f)},R);return f},wa="ColumnName",ya="store",da="json",ua=ya+"TableName",Ta=ya+"Id"+wa,Ra=ya+wa,Aa="autoLoadIntervalSeconds",Na="rowId"+wa,ga="tableId",pa="tableName",Ca="deleteEmptyColumns",Oa="deleteEmptyTable",La={mode:da,[Aa]:1},va={load:0,save:0,[pa]:t+"_values"},$a=(a,t,e,n,s)=>{const o=J();return Y(a,((a,c)=>{const l=E(q(x(t,r(a)?{[e]:a}:a)),0,H(t));i(l[0])||n(c,l[0])||(s(c,l[0]),Q(o,c,l))})),o},Ia=t,Sa=/^([cd]:)(.+)/,ma=t+"_data",_a=t+"_table",ha=async(a,e,n,s,i)=>((a,e,n,s,i,c,l,y,d,u,R="getDb")=>{const A=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(n,c),[N,,g,p]=(a=>{const e=(a=>x(La,r(a)?{[ua]:a}:a??{}))(a),n=e[Aa];if(e.mode==da){const a=e[ua]??t;return[1,n,[a,e[Ta]??C,e[Ra]??ya],ta(a)]}const{tables:{load:s={},save:i={}}={},values:o={}}=e,c=E(q(x(va,o)),0,H(va)),l=c[2],w=ta(l),y=ta(l);return[0,n,[$a(s,{[ga]:null,[Na]:C},ga,(a=>h(y,a)),(a=>ea(w,a))),$a(i,{[pa]:null,[Na]:C,[Ca]:0,[Oa]:0},pa,((a,t)=>h(y,t)),((a,t)=>ea(w,t))),c],w]})(e),v=async a=>{await A(`CREATE OR REPLACE TRIGGER ${m(ma+"_"+a)} AFTER INSERT OR UPDATE OR DELETE ON ${m(a)} EXECUTE FUNCTION ${ma}()`)};return(N?Ea:la)(a,A,(async a=>{await A(`CREATE OR REPLACE FUNCTION ${_a}()RETURNS event_trigger AS $t2$ DECLARE row record; BEGIN FOR row IN SELECT object_identity FROM pg_event_trigger_ddl_commands()WHERE command_tag='CREATE TABLE' LOOP PERFORM pg_notify('${Ia}','c:'||SPLIT_PART(row.object_identity,'.',2));END LOOP;END;$t2$ LANGUAGE plpgsql;`);try{await A(`CREATE EVENT TRIGGER ${_a} ON ddl_command_end WHEN TAG IN('CREATE TABLE')EXECUTE FUNCTION ${_a}();`)}catch{}return await A(`CREATE OR REPLACE FUNCTION ${ma}()RETURNS trigger AS $t1$ BEGIN PERFORM pg_notify('${Ia}','d:'||TG_TABLE_NAME);RETURN NULL;END;$t1$ LANGUAGE plpgsql;`),await w(T(b(p),(async a=>{await A(`CREATE TABLE IF NOT EXISTS ${m(a)}("_id"text PRIMARY KEY)`),await v(a)}))),await s(Ia,(async t=>{return await o((e=t,n=Sa,e?.match(n)),(async([,t,e])=>{h(p,e)&&("c:"==t&&await v(e),a())}));var e,n}))}),i,l,y,d,g,b(p),(async(a,t)=>await a(`${O} table_name tn,column_name cn FROM information_schema.columns ${L} table_schema='public'AND table_name IN(${_(t)})`,t)),u,R,"text",void 0,(a=>k(a)),(a=>z(a)))})(a,n,(async(a,t=[])=>(await e.query(a,t)).rows),(async(a,t)=>await e.listen(a,t)),(async a=>{try{await a()}catch(a){i?.(a)}}),s,i,(()=>0),3,e,"getPglite");export{ha as createPglitePersister};
1
+ const a=a=>typeof a,t="tinybase",e=",",n=a(""),s=Promise,i=a=>null==a,r=(a,t,e)=>i(a)?e?.():t(a),o=t=>a(t)==n,c=a=>Array.isArray(a),E=(a,t,e)=>a.slice(t,e),l=a=>a.length,w=async a=>s.all(a),y=a=>{throw Error(a)},d=(a,t)=>a.forEach(t),u=(a,t="")=>a.join(t),T=(a,t)=>a.map(t),R=a=>0==l(a),A=(a,t)=>a.filter(t),N=(a,...t)=>a.push(...t),g=a=>a.shift(),p="_",C="_id",O="SELECT",L="WHERE",v="TABLE",$="ALTER "+v,I="DELETE FROM",S=O+"*FROM",m=a=>`"${a.replace(/"/g,'""')}"`,_=(a,t=[1])=>u(T(a,(()=>"$"+t[0]++)),e),h=(a,t)=>a?.has(t)??!1,f=a=>i(a)||0==(a=>a?.size??0)(a),b=a=>[...a?.values()??[]],D=(a,t)=>a?.forEach(t),P=(a,t)=>a?.delete(t),U=Object,F=a=>U.getPrototypeOf(a),M=U.entries,G=U.keys,B=U.freeze,j=(a=[])=>U.fromEntries(a),x=(...a)=>U.assign({},...a),X=(a,t)=>(delete a[t],a),Y=(a,t)=>T(M(a),(([a,e])=>t(e,a))),q=a=>U.values(a),H=a=>l(G(a)),W=a=>(a=>!i(a)&&r(F(a),(a=>a==U.prototype||i(F(a))),(()=>!0)))(a)&&0==H(a),k=JSON.stringify,z=JSON.parse,J=a=>new Map(a),K=(a,t)=>a?.get(t),V=(a,t)=>T([...a?.entries()??[]],(([a,e])=>t(e,a))),Q=(a,t,e)=>i(e)?(P(a,t),a):a?.set(t,e),Z=(a,t,e,n)=>(h(a,t)?n?.(K(a,t)):Q(a,t,e()),K(a,t)),aa=(a,t,e,n,s=0)=>r((e?Z:K)(a,t[s],s>l(t)-2?e:J),(i=>{if(s>l(t)-2)return n?.(i)&&Q(a,t[s]),i;const r=aa(i,t,e,n,s+1);return f(i)&&Q(a,t[s]),r})),ta=a=>new Set(c(a)||i(a)?a:[a]),ea=(a,t)=>a?.add(t),na=/^\d+$/,sa=J(),ia=J(),ra=(a,t,e,n,s,o,E,w={},u=0,T=[])=>{let R,A,p,C=0,O=0,L=0;Z(sa,T,(()=>0)),Z(ia,T,(()=>[]));const v=J(),[$,I,S,m,_]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!W(a)||!W(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!W(a)||!W(t),t.setContent]:y("Store type not supported by this Persister"))(E,a,u),[h,b,U]=(()=>{let a;const[t,e]=(()=>{const a=[];let t=0;return[e=>(e?g(a):null)??""+t++,t=>{na.test(t)&&l(a)<1e3&&N(a,t)}]})(),n=J();return[(e,s,i,r=[],o=()=>[])=>{a??=q;const c=t(1);return Q(n,c,[e,s,i,r,o]),ea(aa(s,i??[""],ta),c),c},(t,e,...s)=>d(((a,t=[""])=>{const e=[],n=(a,s)=>s==l(t)?N(e,a):null===t[s]?D(a,(a=>n(a,s+1))):d([t[s],null],(t=>n(K(a,t),s+1)));return n(a,0),e})(t,e),(t=>D(t,(t=>K(n,t)[0](a,...e??[],...s))))),a=>r(K(n,a),(([,t,s])=>(aa(t,s??[""],void 0,(t=>(P(t,a),f(t)?1:0))),Q(n,a),e(a),s))),t=>r(K(n,t),(([t,,e=[],n,s])=>{const r=(...o)=>{const c=l(o);c==l(e)?t(a,...o,...s(o)):i(e[c])?d(n[c]?.(...o)??[],(a=>r(...o,a))):r(...o,e[c])};r()}))]})(),F=a=>{a!=C&&(C=a,b(v,void 0,C))},M=t=>{($&&c(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},G=async a=>(2!=C&&(F(1),O++,await Y((async()=>{try{const e=await t();c(e)?M(e):a?_(a):y("Content is not an array: "+e)}catch(t){o?.(t),a&&_(a)}F(0)}))),q),j=()=>(A&&(s(A),A=void 0),q),x=async a=>(1!=C&&(F(2),L++,await Y((async()=>{try{await e(I,a)}catch(a){o?.(a)}F(0)}))),q),X=()=>(p&&(a.delListener(p),p=void 0),q),Y=async(...a)=>(N(K(ia,T),...a),await(async()=>{if(!K(sa,T)){for(Q(sa,T,1);!i(R=g(K(ia,T)));)try{await R()}catch(a){o?.(a)}Q(sa,T,0)}})(),q),q={load:G,startAutoLoad:async a=>{j(),await G(a);try{A=await n((async(a,t)=>{t||a?2!=C&&(F(1),O++,M(t??a),F(0)):await G()}))}catch(a){o?.(a)}return q},stopAutoLoad:j,isAutoLoading:()=>!i(A),save:x,startAutoSave:async()=>(X(),await x(),p=a.addDidFinishTransactionListener((()=>{const a=S();m(a)&&x(a)})),q),stopAutoSave:X,isAutoSaving:()=>!i(p),getStatus:()=>C,addStatusListener:a=>h(a,v),delListener:t=>(U(t),a),schedule:Y,getStore:()=>a,destroy:()=>(K(ia,T).splice(0,void 0),j().stopAutoSave()),getStats:()=>({loads:O,saves:L}),...w};return B(q)},oa=(a,t,n,s,r,o=ca,c,E)=>{const l=J();return[async()=>{l.clear(),T(await n(a,t),(({tn:a,cn:t})=>ea(Z(l,a,ta),t)))},async(t,e)=>((a,t)=>h(K(l,a),t))(t,e)?j(A(T(await a(S+m(t)),(a=>{return[a[e],E?(t=X(a,e),n=E,j(Y(t,((a,t)=>[t,n(a,t)])))):X(a,e)];var t,n})),(([a,t])=>!i(a)&&!W(t)))):{},async(t,n,s,E,y,d=!1)=>{const g=ta();Y(s??{},(a=>T(G(a??{}),(a=>ea(g,a)))));const p=b(g);if(!d&&y&&R(p)&&h(l,t))return await a("DROP "+v+m(t)),void Q(l,t);const C=K(l,t),O=ta(b(C));if(R(p)||(h(l,t)?await w(T([n,...p],(async(e,s)=>{P(O,e)||(await a($+m(t)+"ADD"+m(e)+r),0==s&&await a("CREATE UNIQUE INDEX pk ON "+m(t)+`(${m(n)})`),ea(C,e))}))):(await a("CREATE "+v+m(t)+`(${m(n)}${r} PRIMARY KEY${u(T(p,(a=>e+m(a)+r)))});`),Q(l,t,ta([n,...p])))),await w([...!d&&E?T(b(O),(async e=>{e!=n&&(await a($+m(t)+"DROP"+m(e)),P(C,e))})):[]]),d)i(s)?await a(I+m(t)+L+" true"):await w(Y(s,(async(e,s)=>{i(e)?await a(I+m(t)+L+m(n)+"=$1",[s]):R(p)||await o(a,t,n,G(e),{[s]:c?T(q(e),c):q(e)},C)})));else if(R(p))h(l,t)&&await a(I+m(t)+L+" true");else{const e=A(b(K(l,t)),(a=>a!=n)),i={},r=[];Y(s??{},((a,t)=>{i[t]=T(e,(t=>c?c(a?.[t]):a?.[t])),N(r,t)})),await o(a,t,n,e,i),await a(I+m(t)+L+m(n)+`NOT IN(${_(r)})`,r)}},async t=>{let e;await a("BEGIN");try{e=await t()}catch(a){s?.(a)}return await a("END"),e}]},ca=async(a,t,n,s,i)=>{const r=[1];await a("INSERT INTO"+m(t)+"("+((...a)=>u(T(a,m),e))(n,...s)+")VALUES"+u(Y(i,(a=>"($"+r[0]+++","+_(a,r)+")")),e)+"ON CONFLICT("+m(n)+")DO UPDATE SET"+u(T(s,(a=>m(a)+"=excluded."+m(a))),e),Y(i,((a,t)=>[t,...T(a,(a=>a??null))])).flat())},Ea=(a,t,e,n,s,i,r,[o,c,E],l,w,y,d,u,T)=>{const[R,A,N,g]=oa(t,l,w,s,u,T),C=ra(a,(async()=>await g((async()=>{return await R(),a=(await A(o,c))[p]?.[E]??"null",z(a,((a,t)=>""===t?void 0:t));var a}))),(async a=>await g((async()=>{var t;await R(),await N(o,c,{[p]:{[E]:(t=a()??null,k(t,((a,t)=>void 0===t?"":t)))}},!0,!0)}))),e,n,s,r,{[d]:()=>y,destroy:()=>(C.stopAutoLoad().stopAutoSave(),i(),C)},0,y);return C},la=(a,t,e,n,s,r,o,[c,E,[l,y,d]],u,T,R,N,g,O,L,v)=>{const[$,I,S,m]=oa(t,u,T,s,g,O,L,v),_=async(a,t)=>await w(V(E,(async([e,n,s,i],r)=>{t&&!(r in a)||await S(e,n,a[r],s,i,t)}))),h=async(a,t)=>y?await S(d,C,{[p]:a},!0,!0,t):null,f=ra(a,(async()=>await m((async()=>{await $();const a=await(async()=>j(A(await w(V(c,(async([a,t],e)=>[a,await I(e,t)]))),(a=>!W(a[1])))))(),t=await(async()=>l?(await I(d,C))[p]:{})();return W(a)&&i(t)?void 0:[a,t]}))),(async(a,t)=>await m((async()=>{if(await $(),i(t)){const[t,e]=a();await _(t),await h(e)}else await _(t[0],!0),await h(t[1],!0)}))),e,n,s,o,{[N]:()=>R,destroy:()=>(f.stopAutoLoad().stopAutoSave(),r(),f)},0,R);return f},wa="ColumnName",ya="store",da="json",ua=ya+"TableName",Ta=ya+"Id"+wa,Ra=ya+wa,Aa="autoLoadIntervalSeconds",Na="rowId"+wa,ga="tableId",pa="tableName",Ca="deleteEmptyColumns",Oa="deleteEmptyTable",La={mode:da,[Aa]:1},va={load:0,save:0,[pa]:t+"_values"},$a=(a,t,e,n,s)=>{const r=J();return Y(a,((a,c)=>{const l=E(q(x(t,o(a)?{[e]:a}:a)),0,H(t));i(l[0])||n(c,l[0])||(s(c,l[0]),Q(r,c,l))})),r},Ia=t,Sa=/^([cd]:)(.+)/,ma=t+"_data",_a=t+"_table",ha=async(a,e,n,s,i)=>((a,e,n,s,i,c,l,y,d,u,R="getDb")=>{const A=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(n,c),[N,,g,p]=(a=>{const e=(a=>x(La,o(a)?{[ua]:a}:a??{}))(a),n=e[Aa];if(e.mode==da){const a=e[ua]??t;return[1,n,[a,e[Ta]??C,e[Ra]??ya],ta(a)]}const{tables:{load:s={},save:i={}}={},values:r={}}=e,c=E(q(x(va,r)),0,H(va)),l=c[2],w=ta(l),y=ta(l);return[0,n,[$a(s,{[ga]:null,[Na]:C},ga,(a=>h(y,a)),(a=>ea(w,a))),$a(i,{[pa]:null,[Na]:C,[Ca]:0,[Oa]:0},pa,((a,t)=>h(y,t)),((a,t)=>ea(w,t))),c],w]})(e),v=async a=>{await A(`CREATE OR REPLACE TRIGGER ${m(ma+"_"+a)} AFTER INSERT OR UPDATE OR DELETE ON ${m(a)} EXECUTE FUNCTION ${ma}()`)};return(N?Ea:la)(a,A,(async a=>{await A(`CREATE OR REPLACE FUNCTION ${_a}()RETURNS event_trigger AS $t2$ DECLARE row record; BEGIN FOR row IN SELECT object_identity FROM pg_event_trigger_ddl_commands()WHERE command_tag='CREATE TABLE' LOOP PERFORM pg_notify('${Ia}','c:'||SPLIT_PART(row.object_identity,'.',2));END LOOP;END;$t2$ LANGUAGE plpgsql;`);try{await A(`CREATE EVENT TRIGGER ${_a} ON ddl_command_end WHEN TAG IN('CREATE TABLE')EXECUTE FUNCTION ${_a}();`)}catch{}return await A(`CREATE OR REPLACE FUNCTION ${ma}()RETURNS trigger AS $t1$ BEGIN PERFORM pg_notify('${Ia}','d:'||TG_TABLE_NAME);RETURN NULL;END;$t1$ LANGUAGE plpgsql;`),await w(T(b(p),(async a=>{await A(`CREATE TABLE IF NOT EXISTS ${m(a)}("_id"text PRIMARY KEY)`),await v(a)}))),await s(Ia,(async t=>{return await r((e=t,n=Sa,e?.match(n)),(async([,t,e])=>{h(p,e)&&("c:"==t&&await v(e),a())}));var e,n}))}),i,l,y,d,g,b(p),(async(a,t)=>await a(`${O} table_name tn,column_name cn FROM information_schema.columns ${L} table_schema='public'AND table_name IN(${_(t)})`,t)),u,R,"text",void 0,(a=>k(a)),(a=>z(a)))})(a,n,(async(a,t=[])=>(await e.query(a,t)).rows),(async(a,t)=>await e.listen(a,t)),(async a=>{try{await a()}catch(a){i?.(a)}}),s,i,(()=>0),3,e,"getPglite");export{ha as createPglitePersister};
@@ -1 +1 @@
1
- const a=a=>typeof a,t="tinybase",e=",",n=a(""),s=Promise,i=a=>null==a,r=(a,t,e)=>i(a)?e?.():t(a),o=t=>a(t)==n,c=a=>Array.isArray(a),E=(a,t,e)=>a.slice(t,e),l=a=>a.length,w=async a=>s.all(a),y=a=>{throw Error(a)},u=(a,t)=>a.forEach(t),d=(a,t="")=>a.join(t),T=(a,t)=>a.map(t),R=a=>0==l(a),A=(a,t)=>a.filter(t),N=(a,...t)=>a.push(...t),g=a=>a.shift(),p="_",C="_id",O="SELECT",v="WHERE",L="TABLE",$="ALTER "+L,S="DELETE FROM",I=O+"*FROM",m=a=>`"${a.replace(/"/g,'""')}"`,_=(a,t=[1])=>d(T(a,(()=>"$"+t[0]++)),e),h=(a,t)=>a?.has(t)??!1,f=a=>i(a)||0==(a=>a?.size??0)(a),b=a=>[...a?.values()??[]],D=(a,t)=>a?.forEach(t),P=(a,t)=>a?.delete(t),U=Object,F=a=>U.getPrototypeOf(a),M=U.entries,G=U.keys,B=U.freeze,j=(a=[])=>U.fromEntries(a),x=(...a)=>U.assign({},...a),X=(a,t)=>(delete a[t],a),Y=(a,t)=>T(M(a),(([a,e])=>t(e,a))),q=a=>U.values(a),H=a=>l(G(a)),W=a=>(a=>!i(a)&&r(F(a),(a=>a==U.prototype||i(F(a))),(()=>!0)))(a)&&0==H(a),k=JSON.stringify,z=JSON.parse,J=a=>new Map(a),K=(a,t)=>a?.get(t),V=(a,t)=>T([...a?.entries()??[]],(([a,e])=>t(e,a))),Q=(a,t,e)=>i(e)?(P(a,t),a):a?.set(t,e),Z=(a,t,e,n)=>(h(a,t)?n?.(K(a,t)):Q(a,t,e()),K(a,t)),aa=(a,t,e,n,s=0)=>r((e?Z:K)(a,t[s],s>l(t)-2?e:J),(i=>{if(s>l(t)-2)return n?.(i)&&Q(a,t[s]),i;const r=aa(i,t,e,n,s+1);return f(i)&&Q(a,t[s]),r})),ta=a=>new Set(c(a)||i(a)?a:[a]),ea=(a,t)=>a?.add(t),na=/^\d+$/,sa=J(),ia=J(),ra=(a,t,e,n,s,o,E,w={},d=[])=>{let T,R,A,p=0,C=0,O=0;Z(sa,d,(()=>0)),Z(ia,d,(()=>[]));const v=J(),[L,$,S,I,m]=((a=1,t)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,t.getTransactionMergeableChanges,([[a],[t]])=>!W(a)||!W(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!W(a)||!W(t),t.setContent]:y("Store type not supported by this Persister"))(E,a),[_,h,b]=(()=>{let a;const[t,e]=(()=>{const a=[];let t=0;return[e=>(e?g(a):null)??""+t++,t=>{na.test(t)&&l(a)<1e3&&N(a,t)}]})(),n=J();return[(e,s,i,r=[],o=()=>[])=>{a??=Y;const c=t(1);return Q(n,c,[e,s,i,r,o]),ea(aa(s,i??[""],ta),c),c},(t,e,...s)=>u(((a,t=[""])=>{const e=[],n=(a,s)=>s==l(t)?N(e,a):null===t[s]?D(a,(a=>n(a,s+1))):u([t[s],null],(t=>n(K(a,t),s+1)));return n(a,0),e})(t,e),(t=>D(t,(t=>K(n,t)[0](a,...e??[],...s))))),a=>r(K(n,a),(([,t,s])=>(aa(t,s??[""],void 0,(t=>(P(t,a),f(t)?1:0))),Q(n,a),e(a),s))),t=>r(K(n,t),(([t,,e=[],n,s])=>{const r=(...o)=>{const c=l(o);c==l(e)?t(a,...o,...s(o)):i(e[c])?u(n[c]?.(...o)??[],(a=>r(...o,a))):r(...o,e[c])};r()}))]})(),U=a=>{a!=p&&(p=a,h(v,void 0,p))},F=t=>{(L&&c(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},M=async a=>(2!=p&&(U(1),C++,await X((async()=>{try{const e=await t();c(e)?F(e):a?m(a):y("Content is not an array "+e)}catch(t){o?.(t),a&&m(a)}U(0)}))),Y),G=()=>(R&&(s(R),R=void 0),Y),j=async a=>(1!=p&&(U(2),O++,await X((async()=>{try{await e($,a)}catch(a){o?.(a)}U(0)}))),Y),x=()=>(r(A,a.delListener),A=void 0,Y),X=async(...a)=>(N(K(ia,d),...a),await(async()=>{if(!K(sa,d)){for(Q(sa,d,1);!i(T=g(K(ia,d)));)try{await T()}catch(a){o?.(a)}Q(sa,d,0)}})(),Y),Y={load:M,startAutoLoad:async a=>{await G().load(a);try{R=await n((async(a,t)=>{t||a?2!=p&&(U(1),C++,F(t??a),U(0)):await M()}))}catch(a){o?.(a)}return Y},stopAutoLoad:G,isAutoLoading:()=>!i(R),save:j,startAutoSave:async()=>(await x().save(),A=a.addDidFinishTransactionListener((()=>{const a=S();I(a)&&j(a)})),Y),stopAutoSave:x,isAutoSaving:()=>!i(A),getStatus:()=>p,addStatusListener:a=>_(a,v),delListener:t=>(b(t),a),schedule:X,getStore:()=>a,destroy:()=>(K(ia,d).splice(0,void 0),G().stopAutoSave()),getStats:()=>({loads:C,saves:O}),...w};return B(Y)},oa=(a,t,n,s,r,o=ca,c,E)=>{const l=J();return[async()=>{l.clear(),T(await n(a,t),(({tn:a,cn:t})=>ea(Z(l,a,ta),t)))},async(t,e)=>((a,t)=>h(K(l,a),t))(t,e)?j(A(T(await a(I+m(t)),(a=>{return[a[e],E?(t=X(a,e),n=E,j(Y(t,((a,t)=>[t,n(a,t)])))):X(a,e)];var t,n})),(([a,t])=>!i(a)&&!W(t)))):{},async(t,n,s,E,y,u=!1)=>{const g=ta();Y(s??{},(a=>T(G(a??{}),(a=>ea(g,a)))));const p=b(g);if(!u&&y&&R(p)&&h(l,t))return await a("DROP "+L+m(t)),void Q(l,t);const C=K(l,t),O=ta(b(C));if(R(p)||(h(l,t)?await w(T([n,...p],(async(e,s)=>{P(O,e)||(await a($+m(t)+"ADD"+m(e)+r),0==s&&await a("CREATE UNIQUE INDEX pk ON "+m(t)+`(${m(n)})`),ea(C,e))}))):(await a("CREATE "+L+m(t)+`(${m(n)}${r} PRIMARY KEY${d(T(p,(a=>e+m(a)+r)))});`),Q(l,t,ta([n,...p])))),await w([...!u&&E?T(b(O),(async e=>{e!=n&&(await a($+m(t)+"DROP"+m(e)),P(C,e))})):[]]),u)i(s)?await a(S+m(t)+v+" true"):await w(Y(s,(async(e,s)=>{i(e)?await a(S+m(t)+v+m(n)+"=$1",[s]):R(p)||await o(a,t,n,G(e),{[s]:c?T(q(e),c):q(e)},C)})));else if(R(p))h(l,t)&&await a(S+m(t)+v+" true");else{const e=A(b(K(l,t)),(a=>a!=n)),i={},r=[];Y(s??{},((a,t)=>{i[t]=T(e,(t=>c?c(a?.[t]):a?.[t])),N(r,t)})),await o(a,t,n,e,i),await a(S+m(t)+v+m(n)+`NOT IN(${_(r)})`,r)}},async t=>{let e;await a("BEGIN");try{e=await t()}catch(a){s?.(a)}return await a("END"),e}]},ca=async(a,t,n,s,i)=>{const r=[1];await a("INSERT INTO"+m(t)+"("+((...a)=>d(T(a,m),e))(n,...s)+")VALUES"+d(Y(i,(a=>"($"+r[0]+++","+_(a,r)+")")),e)+"ON CONFLICT("+m(n)+")DO UPDATE SET"+d(T(s,(a=>m(a)+"=excluded."+m(a))),e),Y(i,((a,t)=>[t,...T(a,(a=>a??null))])).flat())},Ea=(a,t,e,n,s,i,r,[o,c,E],l,w,y,u,d,T)=>{const[R,A,N,g]=oa(t,l,w,s,d,T),C=ra(a,(async()=>await g((async()=>{return await R(),a=(await A(o,c))[p]?.[E]??"null",z(a,((a,t)=>""===t?void 0:t));var a}))),(async a=>await g((async()=>{var t;await R(),await N(o,c,{[p]:{[E]:(t=a()??null,k(t,((a,t)=>void 0===t?"":t)))}},!0,!0)}))),e,n,s,r,{[u]:()=>y,destroy:()=>(C.stopAutoLoad().stopAutoSave(),i(),C)},y);return C},la=(a,t,e,n,s,r,o,[c,E,[l,y,u]],d,T,R,N,g,O,v,L)=>{const[$,S,I,m]=oa(t,d,T,s,g,O,v,L),_=async(a,t)=>await w(V(E,(async([e,n,s,i],r)=>{t&&!(r in a)||await I(e,n,a[r],s,i,t)}))),h=async(a,t)=>y?await I(u,C,{[p]:a},!0,!0,t):null,f=ra(a,(async()=>await m((async()=>{await $();const a=await(async()=>j(A(await w(V(c,(async([a,t],e)=>[a,await S(e,t)]))),(a=>!W(a[1])))))(),t=await(async()=>l?(await S(u,C))[p]:{})();return W(a)&&i(t)?void 0:[a,t]}))),(async(a,t)=>await m((async()=>{if(await $(),i(t)){const[t,e]=a();await _(t),await h(e)}else await _(t[0],!0),await h(t[1],!0)}))),e,n,s,o,{[N]:()=>R,destroy:()=>(f.stopAutoLoad().stopAutoSave(),r(),f)},R);return f},wa="ColumnName",ya="store",ua="json",da=ya+"TableName",Ta=ya+"Id"+wa,Ra=ya+wa,Aa="autoLoadIntervalSeconds",Na="rowId"+wa,ga="tableId",pa="tableName",Ca="deleteEmptyColumns",Oa="deleteEmptyTable",va={mode:ua,[Aa]:1},La={load:0,save:0,[pa]:t+"_values"},$a=(a,t,e,n,s)=>{const r=J();return Y(a,((a,c)=>{const l=E(q(x(t,o(a)?{[e]:a}:a)),0,H(t));i(l[0])||n(c,l[0])||(s(c,l[0]),Q(r,c,l))})),r},Sa=t,Ia=/^([cd]:)(.+)/,ma=t+"_data",_a=t+"_table",ha=async(a,e,n,s,i)=>{const c=await(e.reserve?.());return((a,e,n,s,i,c,l,y,u,d,R="getDb")=>{const A=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(n,c),[N,,g,p]=(a=>{const e=(a=>x(va,o(a)?{[da]:a}:a??{}))(a),n=e[Aa];if(e.mode==ua){const a=e[da]??t;return[1,n,[a,e[Ta]??C,e[Ra]??ya],ta(a)]}const{tables:{load:s={},save:i={}}={},values:r={}}=e,c=E(q(x(La,r)),0,H(La)),l=c[2],w=ta(l),y=ta(l);return[0,n,[$a(s,{[ga]:null,[Na]:C},ga,(a=>h(y,a)),(a=>ea(w,a))),$a(i,{[pa]:null,[Na]:C,[Ca]:0,[Oa]:0},pa,((a,t)=>h(y,t)),((a,t)=>ea(w,t))),c],w]})(e),L=async a=>{await A(`CREATE OR REPLACE TRIGGER ${m(ma+"_"+a)} AFTER INSERT OR UPDATE OR DELETE ON ${m(a)} EXECUTE FUNCTION ${ma}()`)};return(N?Ea:la)(a,A,(async a=>{await A(`CREATE OR REPLACE FUNCTION ${_a}()RETURNS event_trigger AS $t2$ DECLARE row record; BEGIN FOR row IN SELECT object_identity FROM pg_event_trigger_ddl_commands()WHERE command_tag='CREATE TABLE' LOOP PERFORM pg_notify('${Sa}','c:'||SPLIT_PART(row.object_identity,'.',2));END LOOP;END;$t2$ LANGUAGE plpgsql;`);try{await A(`CREATE EVENT TRIGGER ${_a} ON ddl_command_end WHEN TAG IN('CREATE TABLE')EXECUTE FUNCTION ${_a}();`)}catch{}return await A(`CREATE OR REPLACE FUNCTION ${ma}()RETURNS trigger AS $t1$ BEGIN PERFORM pg_notify('${Sa}','d:'||TG_TABLE_NAME);RETURN NULL;END;$t1$ LANGUAGE plpgsql;`),await w(T(b(p),(async a=>{await A(`CREATE TABLE IF NOT EXISTS ${m(a)}("_id"text PRIMARY KEY)`),await L(a)}))),await s(Sa,(async t=>{return await r((e=t,n=Ia,e?.match(n)),(async([,t,e])=>{h(p,e)&&("c:"==t&&await L(e),a())}));var e,n}))}),i,l,y,u,g,b(p),(async(a,t)=>await a(`${O} table_name tn,column_name cn FROM information_schema.columns ${v} table_schema='public'AND table_name IN(${_(t)})`,t)),d,R,"text",void 0,(a=>k(a)),(a=>z(a)))})(a,n,c?.unsafe,(async(a,t)=>e.listen(a,t)),(async a=>{try{await a.unlisten()}catch(a){i?.(a)}}),s,i,(()=>c?.release?.()),3,e,"getSql")};export{ha as createPostgresPersister};
1
+ const a=a=>typeof a,t="tinybase",e=",",n=a(""),s=Promise,i=a=>null==a,r=(a,t,e)=>i(a)?e?.():t(a),o=t=>a(t)==n,c=a=>Array.isArray(a),E=(a,t,e)=>a.slice(t,e),l=a=>a.length,w=async a=>s.all(a),y=a=>{throw Error(a)},u=(a,t)=>a.forEach(t),d=(a,t="")=>a.join(t),T=(a,t)=>a.map(t),R=a=>0==l(a),A=(a,t)=>a.filter(t),N=(a,...t)=>a.push(...t),g=a=>a.shift(),p="_",C="_id",O="SELECT",L="WHERE",v="TABLE",$="ALTER "+v,S="DELETE FROM",I=O+"*FROM",m=a=>`"${a.replace(/"/g,'""')}"`,_=(a,t=[1])=>d(T(a,(()=>"$"+t[0]++)),e),h=(a,t)=>a?.has(t)??!1,f=a=>i(a)||0==(a=>a?.size??0)(a),b=a=>[...a?.values()??[]],D=(a,t)=>a?.forEach(t),P=(a,t)=>a?.delete(t),U=Object,F=a=>U.getPrototypeOf(a),M=U.entries,G=U.keys,B=U.freeze,j=(a=[])=>U.fromEntries(a),x=(...a)=>U.assign({},...a),X=(a,t)=>(delete a[t],a),Y=(a,t)=>T(M(a),(([a,e])=>t(e,a))),q=a=>U.values(a),H=a=>l(G(a)),W=a=>(a=>!i(a)&&r(F(a),(a=>a==U.prototype||i(F(a))),(()=>!0)))(a)&&0==H(a),k=JSON.stringify,z=JSON.parse,J=a=>new Map(a),K=(a,t)=>a?.get(t),V=(a,t)=>T([...a?.entries()??[]],(([a,e])=>t(e,a))),Q=(a,t,e)=>i(e)?(P(a,t),a):a?.set(t,e),Z=(a,t,e,n)=>(h(a,t)?n?.(K(a,t)):Q(a,t,e()),K(a,t)),aa=(a,t,e,n,s=0)=>r((e?Z:K)(a,t[s],s>l(t)-2?e:J),(i=>{if(s>l(t)-2)return n?.(i)&&Q(a,t[s]),i;const r=aa(i,t,e,n,s+1);return f(i)&&Q(a,t[s]),r})),ta=a=>new Set(c(a)||i(a)?a:[a]),ea=(a,t)=>a?.add(t),na=/^\d+$/,sa=J(),ia=J(),ra=(a,t,e,n,s,o,E,w={},d=0,T=[])=>{let R,A,p,C=0,O=0,L=0;Z(sa,T,(()=>0)),Z(ia,T,(()=>[]));const v=J(),[$,S,I,m,_]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!W(a)||!W(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!W(a)||!W(t),t.setContent]:y("Store type not supported by this Persister"))(E,a,d),[h,b,U]=(()=>{let a;const[t,e]=(()=>{const a=[];let t=0;return[e=>(e?g(a):null)??""+t++,t=>{na.test(t)&&l(a)<1e3&&N(a,t)}]})(),n=J();return[(e,s,i,r=[],o=()=>[])=>{a??=q;const c=t(1);return Q(n,c,[e,s,i,r,o]),ea(aa(s,i??[""],ta),c),c},(t,e,...s)=>u(((a,t=[""])=>{const e=[],n=(a,s)=>s==l(t)?N(e,a):null===t[s]?D(a,(a=>n(a,s+1))):u([t[s],null],(t=>n(K(a,t),s+1)));return n(a,0),e})(t,e),(t=>D(t,(t=>K(n,t)[0](a,...e??[],...s))))),a=>r(K(n,a),(([,t,s])=>(aa(t,s??[""],void 0,(t=>(P(t,a),f(t)?1:0))),Q(n,a),e(a),s))),t=>r(K(n,t),(([t,,e=[],n,s])=>{const r=(...o)=>{const c=l(o);c==l(e)?t(a,...o,...s(o)):i(e[c])?u(n[c]?.(...o)??[],(a=>r(...o,a))):r(...o,e[c])};r()}))]})(),F=a=>{a!=C&&(C=a,b(v,void 0,C))},M=t=>{($&&c(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},G=async a=>(2!=C&&(F(1),O++,await Y((async()=>{try{const e=await t();c(e)?M(e):a?_(a):y("Content is not an array: "+e)}catch(t){o?.(t),a&&_(a)}F(0)}))),q),j=()=>(A&&(s(A),A=void 0),q),x=async a=>(1!=C&&(F(2),L++,await Y((async()=>{try{await e(S,a)}catch(a){o?.(a)}F(0)}))),q),X=()=>(p&&(a.delListener(p),p=void 0),q),Y=async(...a)=>(N(K(ia,T),...a),await(async()=>{if(!K(sa,T)){for(Q(sa,T,1);!i(R=g(K(ia,T)));)try{await R()}catch(a){o?.(a)}Q(sa,T,0)}})(),q),q={load:G,startAutoLoad:async a=>{j(),await G(a);try{A=await n((async(a,t)=>{t||a?2!=C&&(F(1),O++,M(t??a),F(0)):await G()}))}catch(a){o?.(a)}return q},stopAutoLoad:j,isAutoLoading:()=>!i(A),save:x,startAutoSave:async()=>(X(),await x(),p=a.addDidFinishTransactionListener((()=>{const a=I();m(a)&&x(a)})),q),stopAutoSave:X,isAutoSaving:()=>!i(p),getStatus:()=>C,addStatusListener:a=>h(a,v),delListener:t=>(U(t),a),schedule:Y,getStore:()=>a,destroy:()=>(K(ia,T).splice(0,void 0),j().stopAutoSave()),getStats:()=>({loads:O,saves:L}),...w};return B(q)},oa=(a,t,n,s,r,o=ca,c,E)=>{const l=J();return[async()=>{l.clear(),T(await n(a,t),(({tn:a,cn:t})=>ea(Z(l,a,ta),t)))},async(t,e)=>((a,t)=>h(K(l,a),t))(t,e)?j(A(T(await a(I+m(t)),(a=>{return[a[e],E?(t=X(a,e),n=E,j(Y(t,((a,t)=>[t,n(a,t)])))):X(a,e)];var t,n})),(([a,t])=>!i(a)&&!W(t)))):{},async(t,n,s,E,y,u=!1)=>{const g=ta();Y(s??{},(a=>T(G(a??{}),(a=>ea(g,a)))));const p=b(g);if(!u&&y&&R(p)&&h(l,t))return await a("DROP "+v+m(t)),void Q(l,t);const C=K(l,t),O=ta(b(C));if(R(p)||(h(l,t)?await w(T([n,...p],(async(e,s)=>{P(O,e)||(await a($+m(t)+"ADD"+m(e)+r),0==s&&await a("CREATE UNIQUE INDEX pk ON "+m(t)+`(${m(n)})`),ea(C,e))}))):(await a("CREATE "+v+m(t)+`(${m(n)}${r} PRIMARY KEY${d(T(p,(a=>e+m(a)+r)))});`),Q(l,t,ta([n,...p])))),await w([...!u&&E?T(b(O),(async e=>{e!=n&&(await a($+m(t)+"DROP"+m(e)),P(C,e))})):[]]),u)i(s)?await a(S+m(t)+L+" true"):await w(Y(s,(async(e,s)=>{i(e)?await a(S+m(t)+L+m(n)+"=$1",[s]):R(p)||await o(a,t,n,G(e),{[s]:c?T(q(e),c):q(e)},C)})));else if(R(p))h(l,t)&&await a(S+m(t)+L+" true");else{const e=A(b(K(l,t)),(a=>a!=n)),i={},r=[];Y(s??{},((a,t)=>{i[t]=T(e,(t=>c?c(a?.[t]):a?.[t])),N(r,t)})),await o(a,t,n,e,i),await a(S+m(t)+L+m(n)+`NOT IN(${_(r)})`,r)}},async t=>{let e;await a("BEGIN");try{e=await t()}catch(a){s?.(a)}return await a("END"),e}]},ca=async(a,t,n,s,i)=>{const r=[1];await a("INSERT INTO"+m(t)+"("+((...a)=>d(T(a,m),e))(n,...s)+")VALUES"+d(Y(i,(a=>"($"+r[0]+++","+_(a,r)+")")),e)+"ON CONFLICT("+m(n)+")DO UPDATE SET"+d(T(s,(a=>m(a)+"=excluded."+m(a))),e),Y(i,((a,t)=>[t,...T(a,(a=>a??null))])).flat())},Ea=(a,t,e,n,s,i,r,[o,c,E],l,w,y,u,d,T)=>{const[R,A,N,g]=oa(t,l,w,s,d,T),C=ra(a,(async()=>await g((async()=>{return await R(),a=(await A(o,c))[p]?.[E]??"null",z(a,((a,t)=>""===t?void 0:t));var a}))),(async a=>await g((async()=>{var t;await R(),await N(o,c,{[p]:{[E]:(t=a()??null,k(t,((a,t)=>void 0===t?"":t)))}},!0,!0)}))),e,n,s,r,{[u]:()=>y,destroy:()=>(C.stopAutoLoad().stopAutoSave(),i(),C)},0,y);return C},la=(a,t,e,n,s,r,o,[c,E,[l,y,u]],d,T,R,N,g,O,L,v)=>{const[$,S,I,m]=oa(t,d,T,s,g,O,L,v),_=async(a,t)=>await w(V(E,(async([e,n,s,i],r)=>{t&&!(r in a)||await I(e,n,a[r],s,i,t)}))),h=async(a,t)=>y?await I(u,C,{[p]:a},!0,!0,t):null,f=ra(a,(async()=>await m((async()=>{await $();const a=await(async()=>j(A(await w(V(c,(async([a,t],e)=>[a,await S(e,t)]))),(a=>!W(a[1])))))(),t=await(async()=>l?(await S(u,C))[p]:{})();return W(a)&&i(t)?void 0:[a,t]}))),(async(a,t)=>await m((async()=>{if(await $(),i(t)){const[t,e]=a();await _(t),await h(e)}else await _(t[0],!0),await h(t[1],!0)}))),e,n,s,o,{[N]:()=>R,destroy:()=>(f.stopAutoLoad().stopAutoSave(),r(),f)},0,R);return f},wa="ColumnName",ya="store",ua="json",da=ya+"TableName",Ta=ya+"Id"+wa,Ra=ya+wa,Aa="autoLoadIntervalSeconds",Na="rowId"+wa,ga="tableId",pa="tableName",Ca="deleteEmptyColumns",Oa="deleteEmptyTable",La={mode:ua,[Aa]:1},va={load:0,save:0,[pa]:t+"_values"},$a=(a,t,e,n,s)=>{const r=J();return Y(a,((a,c)=>{const l=E(q(x(t,o(a)?{[e]:a}:a)),0,H(t));i(l[0])||n(c,l[0])||(s(c,l[0]),Q(r,c,l))})),r},Sa=t,Ia=/^([cd]:)(.+)/,ma=t+"_data",_a=t+"_table",ha=async(a,e,n,s,i)=>{const c=await(e.reserve?.());return((a,e,n,s,i,c,l,y,u,d,R="getDb")=>{const A=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(n,c),[N,,g,p]=(a=>{const e=(a=>x(La,o(a)?{[da]:a}:a??{}))(a),n=e[Aa];if(e.mode==ua){const a=e[da]??t;return[1,n,[a,e[Ta]??C,e[Ra]??ya],ta(a)]}const{tables:{load:s={},save:i={}}={},values:r={}}=e,c=E(q(x(va,r)),0,H(va)),l=c[2],w=ta(l),y=ta(l);return[0,n,[$a(s,{[ga]:null,[Na]:C},ga,(a=>h(y,a)),(a=>ea(w,a))),$a(i,{[pa]:null,[Na]:C,[Ca]:0,[Oa]:0},pa,((a,t)=>h(y,t)),((a,t)=>ea(w,t))),c],w]})(e),v=async a=>{await A(`CREATE OR REPLACE TRIGGER ${m(ma+"_"+a)} AFTER INSERT OR UPDATE OR DELETE ON ${m(a)} EXECUTE FUNCTION ${ma}()`)};return(N?Ea:la)(a,A,(async a=>{await A(`CREATE OR REPLACE FUNCTION ${_a}()RETURNS event_trigger AS $t2$ DECLARE row record; BEGIN FOR row IN SELECT object_identity FROM pg_event_trigger_ddl_commands()WHERE command_tag='CREATE TABLE' LOOP PERFORM pg_notify('${Sa}','c:'||SPLIT_PART(row.object_identity,'.',2));END LOOP;END;$t2$ LANGUAGE plpgsql;`);try{await A(`CREATE EVENT TRIGGER ${_a} ON ddl_command_end WHEN TAG IN('CREATE TABLE')EXECUTE FUNCTION ${_a}();`)}catch{}return await A(`CREATE OR REPLACE FUNCTION ${ma}()RETURNS trigger AS $t1$ BEGIN PERFORM pg_notify('${Sa}','d:'||TG_TABLE_NAME);RETURN NULL;END;$t1$ LANGUAGE plpgsql;`),await w(T(b(p),(async a=>{await A(`CREATE TABLE IF NOT EXISTS ${m(a)}("_id"text PRIMARY KEY)`),await v(a)}))),await s(Sa,(async t=>{return await r((e=t,n=Ia,e?.match(n)),(async([,t,e])=>{h(p,e)&&("c:"==t&&await v(e),a())}));var e,n}))}),i,l,y,u,g,b(p),(async(a,t)=>await a(`${O} table_name tn,column_name cn FROM information_schema.columns ${L} table_schema='public'AND table_name IN(${_(t)})`,t)),d,R,"text",void 0,(a=>k(a)),(a=>z(a)))})(a,n,c?.unsafe,(async(a,t)=>e.listen(a,t)),(async a=>{try{await a.unlisten()}catch(a){i?.(a)}}),s,i,(()=>c?.release?.()),3,e,"getSql")};export{ha as createPostgresPersister};
@@ -1 +1 @@
1
- const a=a=>typeof a,t="tinybase",e=",",n=a(""),s=Promise,i=a=>null==a,r=(a,t,e)=>i(a)?e?.():t(a),o=t=>a(t)==n,c=a=>Array.isArray(a),E=(a,t,e)=>a.slice(t,e),l=a=>a.length,w=async a=>s.all(a),y=a=>{throw Error(a)},u=(a,t)=>a.forEach(t),d=(a,t="")=>a.join(t),T=(a,t)=>a.map(t),R=a=>0==l(a),A=(a,t)=>a.filter(t),N=(a,...t)=>a.push(...t),g=a=>a.shift(),p="_",C="_id",O="SELECT",v="WHERE",L="TABLE",$="ALTER "+L,S="DELETE FROM",I=O+"*FROM",m=a=>`"${a.replace(/"/g,'""')}"`,_=(a,t=[1])=>d(T(a,(()=>"$"+t[0]++)),e),h=(a,t)=>a?.has(t)??!1,f=a=>i(a)||0==(a=>a?.size??0)(a),b=a=>[...a?.values()??[]],D=(a,t)=>a?.forEach(t),P=(a,t)=>a?.delete(t),U=Object,F=a=>U.getPrototypeOf(a),M=U.entries,G=U.keys,B=U.freeze,j=(a=[])=>U.fromEntries(a),x=(...a)=>U.assign({},...a),X=(a,t)=>(delete a[t],a),Y=(a,t)=>T(M(a),(([a,e])=>t(e,a))),q=a=>U.values(a),H=a=>l(G(a)),W=a=>(a=>!i(a)&&r(F(a),(a=>a==U.prototype||i(F(a))),(()=>!0)))(a)&&0==H(a),k=JSON.stringify,z=JSON.parse,J=a=>new Map(a),K=(a,t)=>a?.get(t),V=(a,t)=>T([...a?.entries()??[]],(([a,e])=>t(e,a))),Q=(a,t,e)=>i(e)?(P(a,t),a):a?.set(t,e),Z=(a,t,e,n)=>(h(a,t)?n?.(K(a,t)):Q(a,t,e()),K(a,t)),aa=(a,t,e,n,s=0)=>r((e?Z:K)(a,t[s],s>l(t)-2?e:J),(i=>{if(s>l(t)-2)return n?.(i)&&Q(a,t[s]),i;const r=aa(i,t,e,n,s+1);return f(i)&&Q(a,t[s]),r})),ta=a=>new Set(c(a)||i(a)?a:[a]),ea=(a,t)=>a?.add(t),na=/^\d+$/,sa=J(),ia=J(),ra=(a,t,e,n,s,o,E,w={},d=[])=>{let T,R,A,p=0,C=0,O=0;Z(sa,d,(()=>0)),Z(ia,d,(()=>[]));const v=J(),[L,$,S,I,m]=((a=1,t)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,t.getTransactionMergeableChanges,([[a],[t]])=>!W(a)||!W(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!W(a)||!W(t),t.setContent]:y("Store type not supported by this Persister"))(E,a),[_,h,b]=(()=>{let a;const[t,e]=(()=>{const a=[];let t=0;return[e=>(e?g(a):null)??""+t++,t=>{na.test(t)&&l(a)<1e3&&N(a,t)}]})(),n=J();return[(e,s,i,r=[],o=()=>[])=>{a??=Y;const c=t(1);return Q(n,c,[e,s,i,r,o]),ea(aa(s,i??[""],ta),c),c},(t,e,...s)=>u(((a,t=[""])=>{const e=[],n=(a,s)=>s==l(t)?N(e,a):null===t[s]?D(a,(a=>n(a,s+1))):u([t[s],null],(t=>n(K(a,t),s+1)));return n(a,0),e})(t,e),(t=>D(t,(t=>K(n,t)[0](a,...e??[],...s))))),a=>r(K(n,a),(([,t,s])=>(aa(t,s??[""],void 0,(t=>(P(t,a),f(t)?1:0))),Q(n,a),e(a),s))),t=>r(K(n,t),(([t,,e=[],n,s])=>{const r=(...o)=>{const c=l(o);c==l(e)?t(a,...o,...s(o)):i(e[c])?u(n[c]?.(...o)??[],(a=>r(...o,a))):r(...o,e[c])};r()}))]})(),U=a=>{a!=p&&(p=a,h(v,void 0,p))},F=t=>{(L&&c(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},M=async a=>(2!=p&&(U(1),C++,await X((async()=>{try{const e=await t();c(e)?F(e):a?m(a):y("Content is not an array "+e)}catch(t){o?.(t),a&&m(a)}U(0)}))),Y),G=()=>(R&&(s(R),R=void 0),Y),j=async a=>(1!=p&&(U(2),O++,await X((async()=>{try{await e($,a)}catch(a){o?.(a)}U(0)}))),Y),x=()=>(r(A,a.delListener),A=void 0,Y),X=async(...a)=>(N(K(ia,d),...a),await(async()=>{if(!K(sa,d)){for(Q(sa,d,1);!i(T=g(K(ia,d)));)try{await T()}catch(a){o?.(a)}Q(sa,d,0)}})(),Y),Y={load:M,startAutoLoad:async a=>{await G().load(a);try{R=await n((async(a,t)=>{t||a?2!=p&&(U(1),C++,F(t??a),U(0)):await M()}))}catch(a){o?.(a)}return Y},stopAutoLoad:G,isAutoLoading:()=>!i(R),save:j,startAutoSave:async()=>(await x().save(),A=a.addDidFinishTransactionListener((()=>{const a=S();I(a)&&j(a)})),Y),stopAutoSave:x,isAutoSaving:()=>!i(A),getStatus:()=>p,addStatusListener:a=>_(a,v),delListener:t=>(b(t),a),schedule:X,getStore:()=>a,destroy:()=>(K(ia,d).splice(0,void 0),G().stopAutoSave()),getStats:()=>({loads:C,saves:O}),...w};return B(Y)},oa=(a,t,n,s,r,o=ca,c,E)=>{const l=J();return[async()=>{l.clear(),T(await n(a,t),(({tn:a,cn:t})=>ea(Z(l,a,ta),t)))},async(t,e)=>((a,t)=>h(K(l,a),t))(t,e)?j(A(T(await a(I+m(t)),(a=>{return[a[e],E?(t=X(a,e),n=E,j(Y(t,((a,t)=>[t,n(a,t)])))):X(a,e)];var t,n})),(([a,t])=>!i(a)&&!W(t)))):{},async(t,n,s,E,y,u=!1)=>{const g=ta();Y(s??{},(a=>T(G(a??{}),(a=>ea(g,a)))));const p=b(g);if(!u&&y&&R(p)&&h(l,t))return await a("DROP "+L+m(t)),void Q(l,t);const C=K(l,t),O=ta(b(C));if(R(p)||(h(l,t)?await w(T([n,...p],(async(e,s)=>{P(O,e)||(await a($+m(t)+"ADD"+m(e)+r),0==s&&await a("CREATE UNIQUE INDEX pk ON "+m(t)+`(${m(n)})`),ea(C,e))}))):(await a("CREATE "+L+m(t)+`(${m(n)}${r} PRIMARY KEY${d(T(p,(a=>e+m(a)+r)))});`),Q(l,t,ta([n,...p])))),await w([...!u&&E?T(b(O),(async e=>{e!=n&&(await a($+m(t)+"DROP"+m(e)),P(C,e))})):[]]),u)i(s)?await a(S+m(t)+v+" true"):await w(Y(s,(async(e,s)=>{i(e)?await a(S+m(t)+v+m(n)+"=$1",[s]):R(p)||await o(a,t,n,G(e),{[s]:c?T(q(e),c):q(e)},C)})));else if(R(p))h(l,t)&&await a(S+m(t)+v+" true");else{const e=A(b(K(l,t)),(a=>a!=n)),i={},r=[];Y(s??{},((a,t)=>{i[t]=T(e,(t=>c?c(a?.[t]):a?.[t])),N(r,t)})),await o(a,t,n,e,i),await a(S+m(t)+v+m(n)+`NOT IN(${_(r)})`,r)}},async t=>{let e;await a("BEGIN");try{e=await t()}catch(a){s?.(a)}return await a("END"),e}]},ca=async(a,t,n,s,i)=>{const r=[1];await a("INSERT INTO"+m(t)+"("+((...a)=>d(T(a,m),e))(n,...s)+")VALUES"+d(Y(i,(a=>"($"+r[0]+++","+_(a,r)+")")),e)+"ON CONFLICT("+m(n)+")DO UPDATE SET"+d(T(s,(a=>m(a)+"=excluded."+m(a))),e),Y(i,((a,t)=>[t,...T(a,(a=>a??null))])).flat())},Ea=(a,t,e,n,s,i,r,[o,c,E],l,w,y,u,d,T)=>{const[R,A,N,g]=oa(t,l,w,s,d,T),C=ra(a,(async()=>await g((async()=>{return await R(),a=(await A(o,c))[p]?.[E]??"null",z(a,((a,t)=>""===t?void 0:t));var a}))),(async a=>await g((async()=>{var t;await R(),await N(o,c,{[p]:{[E]:(t=a()??null,k(t,((a,t)=>void 0===t?"":t)))}},!0,!0)}))),e,n,s,r,{[u]:()=>y,destroy:()=>(C.stopAutoLoad().stopAutoSave(),i(),C)},y);return C},la=(a,t,e,n,s,r,o,[c,E,[l,y,u]],d,T,R,N,g,O,v,L)=>{const[$,S,I,m]=oa(t,d,T,s,g,O,v,L),_=async(a,t)=>await w(V(E,(async([e,n,s,i],r)=>{t&&!(r in a)||await I(e,n,a[r],s,i,t)}))),h=async(a,t)=>y?await I(u,C,{[p]:a},!0,!0,t):null,f=ra(a,(async()=>await m((async()=>{await $();const a=await(async()=>j(A(await w(V(c,(async([a,t],e)=>[a,await S(e,t)]))),(a=>!W(a[1])))))(),t=await(async()=>l?(await S(u,C))[p]:{})();return W(a)&&i(t)?void 0:[a,t]}))),(async(a,t)=>await m((async()=>{if(await $(),i(t)){const[t,e]=a();await _(t),await h(e)}else await _(t[0],!0),await h(t[1],!0)}))),e,n,s,o,{[N]:()=>R,destroy:()=>(f.stopAutoLoad().stopAutoSave(),r(),f)},R);return f},wa="ColumnName",ya="store",ua="json",da=ya+"TableName",Ta=ya+"Id"+wa,Ra=ya+wa,Aa="autoLoadIntervalSeconds",Na="rowId"+wa,ga="tableId",pa="tableName",Ca="deleteEmptyColumns",Oa="deleteEmptyTable",va={mode:ua,[Aa]:1},La={load:0,save:0,[pa]:t+"_values"},$a=(a,t,e,n,s)=>{const r=J();return Y(a,((a,c)=>{const l=E(q(x(t,o(a)?{[e]:a}:a)),0,H(t));i(l[0])||n(c,l[0])||(s(c,l[0]),Q(r,c,l))})),r},Sa=t,Ia=/^([cd]:)(.+)/,ma=t+"_data",_a=t+"_table",ha=async(a,e,n,s,i)=>{const c=await(e.reserve?.());return((a,e,n,s,i,c,l,y,u,d,R="getDb")=>{const A=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(n,c),[N,,g,p]=(a=>{const e=(a=>x(va,o(a)?{[da]:a}:a??{}))(a),n=e[Aa];if(e.mode==ua){const a=e[da]??t;return[1,n,[a,e[Ta]??C,e[Ra]??ya],ta(a)]}const{tables:{load:s={},save:i={}}={},values:r={}}=e,c=E(q(x(La,r)),0,H(La)),l=c[2],w=ta(l),y=ta(l);return[0,n,[$a(s,{[ga]:null,[Na]:C},ga,(a=>h(y,a)),(a=>ea(w,a))),$a(i,{[pa]:null,[Na]:C,[Ca]:0,[Oa]:0},pa,((a,t)=>h(y,t)),((a,t)=>ea(w,t))),c],w]})(e),L=async a=>{await A(`CREATE OR REPLACE TRIGGER ${m(ma+"_"+a)} AFTER INSERT OR UPDATE OR DELETE ON ${m(a)} EXECUTE FUNCTION ${ma}()`)};return(N?Ea:la)(a,A,(async a=>{await A(`CREATE OR REPLACE FUNCTION ${_a}()RETURNS event_trigger AS $t2$ DECLARE row record; BEGIN FOR row IN SELECT object_identity FROM pg_event_trigger_ddl_commands()WHERE command_tag='CREATE TABLE' LOOP PERFORM pg_notify('${Sa}','c:'||SPLIT_PART(row.object_identity,'.',2));END LOOP;END;$t2$ LANGUAGE plpgsql;`);try{await A(`CREATE EVENT TRIGGER ${_a} ON ddl_command_end WHEN TAG IN('CREATE TABLE')EXECUTE FUNCTION ${_a}();`)}catch{}return await A(`CREATE OR REPLACE FUNCTION ${ma}()RETURNS trigger AS $t1$ BEGIN PERFORM pg_notify('${Sa}','d:'||TG_TABLE_NAME);RETURN NULL;END;$t1$ LANGUAGE plpgsql;`),await w(T(b(p),(async a=>{await A(`CREATE TABLE IF NOT EXISTS ${m(a)}("_id"text PRIMARY KEY)`),await L(a)}))),await s(Sa,(async t=>{return await r((e=t,n=Ia,e?.match(n)),(async([,t,e])=>{h(p,e)&&("c:"==t&&await L(e),a())}));var e,n}))}),i,l,y,u,g,b(p),(async(a,t)=>await a(`${O} table_name tn,column_name cn FROM information_schema.columns ${v} table_schema='public'AND table_name IN(${_(t)})`,t)),d,R,"text",void 0,(a=>k(a)),(a=>z(a)))})(a,n,c?.unsafe,(async(a,t)=>e.listen(a,t)),(async a=>{try{await a.unlisten()}catch(a){i?.(a)}}),s,i,(()=>c?.release?.()),3,e,"getSql")};export{ha as createPostgresPersister};
1
+ const a=a=>typeof a,t="tinybase",e=",",n=a(""),s=Promise,i=a=>null==a,r=(a,t,e)=>i(a)?e?.():t(a),o=t=>a(t)==n,c=a=>Array.isArray(a),E=(a,t,e)=>a.slice(t,e),l=a=>a.length,w=async a=>s.all(a),y=a=>{throw Error(a)},u=(a,t)=>a.forEach(t),d=(a,t="")=>a.join(t),T=(a,t)=>a.map(t),R=a=>0==l(a),A=(a,t)=>a.filter(t),N=(a,...t)=>a.push(...t),g=a=>a.shift(),p="_",C="_id",O="SELECT",L="WHERE",v="TABLE",$="ALTER "+v,S="DELETE FROM",I=O+"*FROM",m=a=>`"${a.replace(/"/g,'""')}"`,_=(a,t=[1])=>d(T(a,(()=>"$"+t[0]++)),e),h=(a,t)=>a?.has(t)??!1,f=a=>i(a)||0==(a=>a?.size??0)(a),b=a=>[...a?.values()??[]],D=(a,t)=>a?.forEach(t),P=(a,t)=>a?.delete(t),U=Object,F=a=>U.getPrototypeOf(a),M=U.entries,G=U.keys,B=U.freeze,j=(a=[])=>U.fromEntries(a),x=(...a)=>U.assign({},...a),X=(a,t)=>(delete a[t],a),Y=(a,t)=>T(M(a),(([a,e])=>t(e,a))),q=a=>U.values(a),H=a=>l(G(a)),W=a=>(a=>!i(a)&&r(F(a),(a=>a==U.prototype||i(F(a))),(()=>!0)))(a)&&0==H(a),k=JSON.stringify,z=JSON.parse,J=a=>new Map(a),K=(a,t)=>a?.get(t),V=(a,t)=>T([...a?.entries()??[]],(([a,e])=>t(e,a))),Q=(a,t,e)=>i(e)?(P(a,t),a):a?.set(t,e),Z=(a,t,e,n)=>(h(a,t)?n?.(K(a,t)):Q(a,t,e()),K(a,t)),aa=(a,t,e,n,s=0)=>r((e?Z:K)(a,t[s],s>l(t)-2?e:J),(i=>{if(s>l(t)-2)return n?.(i)&&Q(a,t[s]),i;const r=aa(i,t,e,n,s+1);return f(i)&&Q(a,t[s]),r})),ta=a=>new Set(c(a)||i(a)?a:[a]),ea=(a,t)=>a?.add(t),na=/^\d+$/,sa=J(),ia=J(),ra=(a,t,e,n,s,o,E,w={},d=0,T=[])=>{let R,A,p,C=0,O=0,L=0;Z(sa,T,(()=>0)),Z(ia,T,(()=>[]));const v=J(),[$,S,I,m,_]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!W(a)||!W(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!W(a)||!W(t),t.setContent]:y("Store type not supported by this Persister"))(E,a,d),[h,b,U]=(()=>{let a;const[t,e]=(()=>{const a=[];let t=0;return[e=>(e?g(a):null)??""+t++,t=>{na.test(t)&&l(a)<1e3&&N(a,t)}]})(),n=J();return[(e,s,i,r=[],o=()=>[])=>{a??=q;const c=t(1);return Q(n,c,[e,s,i,r,o]),ea(aa(s,i??[""],ta),c),c},(t,e,...s)=>u(((a,t=[""])=>{const e=[],n=(a,s)=>s==l(t)?N(e,a):null===t[s]?D(a,(a=>n(a,s+1))):u([t[s],null],(t=>n(K(a,t),s+1)));return n(a,0),e})(t,e),(t=>D(t,(t=>K(n,t)[0](a,...e??[],...s))))),a=>r(K(n,a),(([,t,s])=>(aa(t,s??[""],void 0,(t=>(P(t,a),f(t)?1:0))),Q(n,a),e(a),s))),t=>r(K(n,t),(([t,,e=[],n,s])=>{const r=(...o)=>{const c=l(o);c==l(e)?t(a,...o,...s(o)):i(e[c])?u(n[c]?.(...o)??[],(a=>r(...o,a))):r(...o,e[c])};r()}))]})(),F=a=>{a!=C&&(C=a,b(v,void 0,C))},M=t=>{($&&c(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},G=async a=>(2!=C&&(F(1),O++,await Y((async()=>{try{const e=await t();c(e)?M(e):a?_(a):y("Content is not an array: "+e)}catch(t){o?.(t),a&&_(a)}F(0)}))),q),j=()=>(A&&(s(A),A=void 0),q),x=async a=>(1!=C&&(F(2),L++,await Y((async()=>{try{await e(S,a)}catch(a){o?.(a)}F(0)}))),q),X=()=>(p&&(a.delListener(p),p=void 0),q),Y=async(...a)=>(N(K(ia,T),...a),await(async()=>{if(!K(sa,T)){for(Q(sa,T,1);!i(R=g(K(ia,T)));)try{await R()}catch(a){o?.(a)}Q(sa,T,0)}})(),q),q={load:G,startAutoLoad:async a=>{j(),await G(a);try{A=await n((async(a,t)=>{t||a?2!=C&&(F(1),O++,M(t??a),F(0)):await G()}))}catch(a){o?.(a)}return q},stopAutoLoad:j,isAutoLoading:()=>!i(A),save:x,startAutoSave:async()=>(X(),await x(),p=a.addDidFinishTransactionListener((()=>{const a=I();m(a)&&x(a)})),q),stopAutoSave:X,isAutoSaving:()=>!i(p),getStatus:()=>C,addStatusListener:a=>h(a,v),delListener:t=>(U(t),a),schedule:Y,getStore:()=>a,destroy:()=>(K(ia,T).splice(0,void 0),j().stopAutoSave()),getStats:()=>({loads:O,saves:L}),...w};return B(q)},oa=(a,t,n,s,r,o=ca,c,E)=>{const l=J();return[async()=>{l.clear(),T(await n(a,t),(({tn:a,cn:t})=>ea(Z(l,a,ta),t)))},async(t,e)=>((a,t)=>h(K(l,a),t))(t,e)?j(A(T(await a(I+m(t)),(a=>{return[a[e],E?(t=X(a,e),n=E,j(Y(t,((a,t)=>[t,n(a,t)])))):X(a,e)];var t,n})),(([a,t])=>!i(a)&&!W(t)))):{},async(t,n,s,E,y,u=!1)=>{const g=ta();Y(s??{},(a=>T(G(a??{}),(a=>ea(g,a)))));const p=b(g);if(!u&&y&&R(p)&&h(l,t))return await a("DROP "+v+m(t)),void Q(l,t);const C=K(l,t),O=ta(b(C));if(R(p)||(h(l,t)?await w(T([n,...p],(async(e,s)=>{P(O,e)||(await a($+m(t)+"ADD"+m(e)+r),0==s&&await a("CREATE UNIQUE INDEX pk ON "+m(t)+`(${m(n)})`),ea(C,e))}))):(await a("CREATE "+v+m(t)+`(${m(n)}${r} PRIMARY KEY${d(T(p,(a=>e+m(a)+r)))});`),Q(l,t,ta([n,...p])))),await w([...!u&&E?T(b(O),(async e=>{e!=n&&(await a($+m(t)+"DROP"+m(e)),P(C,e))})):[]]),u)i(s)?await a(S+m(t)+L+" true"):await w(Y(s,(async(e,s)=>{i(e)?await a(S+m(t)+L+m(n)+"=$1",[s]):R(p)||await o(a,t,n,G(e),{[s]:c?T(q(e),c):q(e)},C)})));else if(R(p))h(l,t)&&await a(S+m(t)+L+" true");else{const e=A(b(K(l,t)),(a=>a!=n)),i={},r=[];Y(s??{},((a,t)=>{i[t]=T(e,(t=>c?c(a?.[t]):a?.[t])),N(r,t)})),await o(a,t,n,e,i),await a(S+m(t)+L+m(n)+`NOT IN(${_(r)})`,r)}},async t=>{let e;await a("BEGIN");try{e=await t()}catch(a){s?.(a)}return await a("END"),e}]},ca=async(a,t,n,s,i)=>{const r=[1];await a("INSERT INTO"+m(t)+"("+((...a)=>d(T(a,m),e))(n,...s)+")VALUES"+d(Y(i,(a=>"($"+r[0]+++","+_(a,r)+")")),e)+"ON CONFLICT("+m(n)+")DO UPDATE SET"+d(T(s,(a=>m(a)+"=excluded."+m(a))),e),Y(i,((a,t)=>[t,...T(a,(a=>a??null))])).flat())},Ea=(a,t,e,n,s,i,r,[o,c,E],l,w,y,u,d,T)=>{const[R,A,N,g]=oa(t,l,w,s,d,T),C=ra(a,(async()=>await g((async()=>{return await R(),a=(await A(o,c))[p]?.[E]??"null",z(a,((a,t)=>""===t?void 0:t));var a}))),(async a=>await g((async()=>{var t;await R(),await N(o,c,{[p]:{[E]:(t=a()??null,k(t,((a,t)=>void 0===t?"":t)))}},!0,!0)}))),e,n,s,r,{[u]:()=>y,destroy:()=>(C.stopAutoLoad().stopAutoSave(),i(),C)},0,y);return C},la=(a,t,e,n,s,r,o,[c,E,[l,y,u]],d,T,R,N,g,O,L,v)=>{const[$,S,I,m]=oa(t,d,T,s,g,O,L,v),_=async(a,t)=>await w(V(E,(async([e,n,s,i],r)=>{t&&!(r in a)||await I(e,n,a[r],s,i,t)}))),h=async(a,t)=>y?await I(u,C,{[p]:a},!0,!0,t):null,f=ra(a,(async()=>await m((async()=>{await $();const a=await(async()=>j(A(await w(V(c,(async([a,t],e)=>[a,await S(e,t)]))),(a=>!W(a[1])))))(),t=await(async()=>l?(await S(u,C))[p]:{})();return W(a)&&i(t)?void 0:[a,t]}))),(async(a,t)=>await m((async()=>{if(await $(),i(t)){const[t,e]=a();await _(t),await h(e)}else await _(t[0],!0),await h(t[1],!0)}))),e,n,s,o,{[N]:()=>R,destroy:()=>(f.stopAutoLoad().stopAutoSave(),r(),f)},0,R);return f},wa="ColumnName",ya="store",ua="json",da=ya+"TableName",Ta=ya+"Id"+wa,Ra=ya+wa,Aa="autoLoadIntervalSeconds",Na="rowId"+wa,ga="tableId",pa="tableName",Ca="deleteEmptyColumns",Oa="deleteEmptyTable",La={mode:ua,[Aa]:1},va={load:0,save:0,[pa]:t+"_values"},$a=(a,t,e,n,s)=>{const r=J();return Y(a,((a,c)=>{const l=E(q(x(t,o(a)?{[e]:a}:a)),0,H(t));i(l[0])||n(c,l[0])||(s(c,l[0]),Q(r,c,l))})),r},Sa=t,Ia=/^([cd]:)(.+)/,ma=t+"_data",_a=t+"_table",ha=async(a,e,n,s,i)=>{const c=await(e.reserve?.());return((a,e,n,s,i,c,l,y,u,d,R="getDb")=>{const A=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(n,c),[N,,g,p]=(a=>{const e=(a=>x(La,o(a)?{[da]:a}:a??{}))(a),n=e[Aa];if(e.mode==ua){const a=e[da]??t;return[1,n,[a,e[Ta]??C,e[Ra]??ya],ta(a)]}const{tables:{load:s={},save:i={}}={},values:r={}}=e,c=E(q(x(va,r)),0,H(va)),l=c[2],w=ta(l),y=ta(l);return[0,n,[$a(s,{[ga]:null,[Na]:C},ga,(a=>h(y,a)),(a=>ea(w,a))),$a(i,{[pa]:null,[Na]:C,[Ca]:0,[Oa]:0},pa,((a,t)=>h(y,t)),((a,t)=>ea(w,t))),c],w]})(e),v=async a=>{await A(`CREATE OR REPLACE TRIGGER ${m(ma+"_"+a)} AFTER INSERT OR UPDATE OR DELETE ON ${m(a)} EXECUTE FUNCTION ${ma}()`)};return(N?Ea:la)(a,A,(async a=>{await A(`CREATE OR REPLACE FUNCTION ${_a}()RETURNS event_trigger AS $t2$ DECLARE row record; BEGIN FOR row IN SELECT object_identity FROM pg_event_trigger_ddl_commands()WHERE command_tag='CREATE TABLE' LOOP PERFORM pg_notify('${Sa}','c:'||SPLIT_PART(row.object_identity,'.',2));END LOOP;END;$t2$ LANGUAGE plpgsql;`);try{await A(`CREATE EVENT TRIGGER ${_a} ON ddl_command_end WHEN TAG IN('CREATE TABLE')EXECUTE FUNCTION ${_a}();`)}catch{}return await A(`CREATE OR REPLACE FUNCTION ${ma}()RETURNS trigger AS $t1$ BEGIN PERFORM pg_notify('${Sa}','d:'||TG_TABLE_NAME);RETURN NULL;END;$t1$ LANGUAGE plpgsql;`),await w(T(b(p),(async a=>{await A(`CREATE TABLE IF NOT EXISTS ${m(a)}("_id"text PRIMARY KEY)`),await v(a)}))),await s(Sa,(async t=>{return await r((e=t,n=Ia,e?.match(n)),(async([,t,e])=>{h(p,e)&&("c:"==t&&await v(e),a())}));var e,n}))}),i,l,y,u,g,b(p),(async(a,t)=>await a(`${O} table_name tn,column_name cn FROM information_schema.columns ${L} table_schema='public'AND table_name IN(${_(t)})`,t)),d,R,"text",void 0,(a=>k(a)),(a=>z(a)))})(a,n,c?.unsafe,(async(a,t)=>e.listen(a,t)),(async a=>{try{await a.unlisten()}catch(a){i?.(a)}}),s,i,(()=>c?.release?.()),3,e,"getSql")};export{ha as createPostgresPersister};
@@ -1 +1 @@
1
- const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),o=Promise,r=clearInterval,i=a=>null==a,c=(a,t,e)=>i(a)?e?.():t(a),l=t=>a(t)==s,w=a=>Array.isArray(a),u=(a,t,e)=>a.slice(t,e),y=a=>a.length,d=async a=>o.all(a),E=a=>{throw Error(a)},v=(a,t)=>a.forEach(t),g=(a,t="")=>a.join(t),p=(a,t)=>a.map(t),A=a=>0==y(a),h=(a,t)=>a.filter(t),N=(a,...t)=>a.push(...t),f=a=>a.shift(),m=Object,S=a=>m.getPrototypeOf(a),T=m.entries,C=m.keys,$=m.freeze,O=(a=[])=>m.fromEntries(a),b=(...a)=>m.assign({},...a),I=(a,t)=>(delete a[t],a),L=(a,t)=>p(T(a),(([a,e])=>t(e,a))),R=a=>m.values(a),D=a=>y(C(a)),M=a=>(a=>!i(a)&&c(S(a),(a=>a==m.prototype||i(S(a))),(()=>!0)))(a)&&0==D(a),_=a=>new Set(w(a)||i(a)?a:[a]),P=(a,t)=>a?.add(t),F="_",U="_id",j="SELECT",x="WHERE",B="TABLE",H="ALTER "+B,J="DELETE FROM",Y=j+"*FROM",k="pragma_",z="data_version",G="schema_version",V="pragma_table_",W=a=>`"${a.replace(/"/g,'""')}"`,K=(...a)=>g(p(a,W),n),Q=(a,t=[1])=>g(p(a,(()=>"$"+t[0]++)),n),X=(a,t)=>a?.has(t)??!1,q=a=>i(a)||0==(a=>a?.size??0)(a),Z=a=>[...a?.values()??[]],aa=(a,t)=>a?.forEach(t),ta=(a,t)=>a?.delete(t),ea=JSON.stringify,na=JSON.parse,sa=a=>new Map(a),oa=(a,t)=>a?.get(t),ra=(a,t)=>p([...a?.entries()??[]],(([a,e])=>t(e,a))),ia=(a,t,e)=>i(e)?(ta(a,t),a):a?.set(t,e),ca=(a,t,e,n)=>(X(a,t)?n?.(oa(a,t)):ia(a,t,e()),oa(a,t)),la=(a,t,e,n,s=0)=>c((e?ca:oa)(a,t[s],s>y(t)-2?e:sa),(o=>{if(s>y(t)-2)return n?.(o)&&ia(a,t[s]),o;const r=la(o,t,e,n,s+1);return q(o)&&ia(a,t[s]),r})),wa=/^\d+$/,ua=sa(),ya=sa(),da=(a,t,n,s,o,r,l,u={},d=[])=>{let g,p,A,h=0,m=0,S=0;ca(ua,d,(()=>0)),ca(ya,d,(()=>[]));const T=sa(),[C,O,b,I,L]=((a=1,t)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,t.getTransactionMergeableChanges,([[a],[t]])=>!M(a)||!M(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!M(a)||!M(t),t.setContent]:E("Store type not supported by this Persister"))(l,a),[R,D,F]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?f(a):null)??e+t++,t=>{wa.test(t)&&y(a)<1e3&&N(a,t)}]})(),s=sa();return[(n,o,r,i=[],c=()=>[])=>{a??=k;const l=t(1);return ia(s,l,[n,o,r,i,c]),P(la(o,r??[e],_),l),l},(t,n,...o)=>v(((a,t=[e])=>{const n=[],s=(a,e)=>e==y(t)?N(n,a):null===t[e]?aa(a,(a=>s(a,e+1))):v([t[e],null],(t=>s(oa(a,t),e+1)));return s(a,0),n})(t,n),(t=>aa(t,(t=>oa(s,t)[0](a,...n??[],...o))))),a=>c(oa(s,a),(([,t,o])=>(la(t,o??[e],void 0,(t=>(ta(t,a),q(t)?1:0))),ia(s,a),n(a),o))),t=>c(oa(s,t),(([t,,e=[],n,s])=>{const o=(...r)=>{const c=y(r);c==y(e)?t(a,...r,...s(r)):i(e[c])?v(n[c]?.(...r)??[],(a=>o(...r,a))):o(...r,e[c])};o()}))]})(),U=a=>{a!=h&&(h=a,D(T,void 0,h))},j=t=>{(C&&w(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},x=async a=>(2!=h&&(U(1),m++,await Y((async()=>{try{const e=await t();w(e)?j(e):a?L(a):E("Content is not an array "+e)}catch(t){r?.(t),a&&L(a)}U(0)}))),k),B=()=>(p&&(o(p),p=void 0),k),H=async a=>(1!=h&&(U(2),S++,await Y((async()=>{try{await n(O,a)}catch(a){r?.(a)}U(0)}))),k),J=()=>(c(A,a.delListener),A=void 0,k),Y=async(...a)=>(N(oa(ya,d),...a),await(async()=>{if(!oa(ua,d)){for(ia(ua,d,1);!i(g=f(oa(ya,d)));)try{await g()}catch(a){r?.(a)}ia(ua,d,0)}})(),k),k={load:x,startAutoLoad:async a=>{await B().load(a);try{p=await s((async(a,t)=>{t||a?2!=h&&(U(1),m++,j(t??a),U(0)):await x()}))}catch(a){r?.(a)}return k},stopAutoLoad:B,isAutoLoading:()=>!i(p),save:H,startAutoSave:async()=>(await J().save(),A=a.addDidFinishTransactionListener((()=>{const a=b();I(a)&&H(a)})),k),stopAutoSave:J,isAutoSaving:()=>!i(A),getStatus:()=>h,addStatusListener:a=>R(a,T),delListener:t=>(F(t),a),schedule:Y,getStore:()=>a,destroy:()=>(oa(ya,d).splice(0,void 0),B().stopAutoSave()),getStats:()=>({loads:m,saves:S}),...u};return $(k)},Ea=(a,t,e,s,o,r=va,c,l)=>{const w=sa();return[async()=>{w.clear(),p(await e(a,t),(({tn:a,cn:t})=>P(ca(w,a,_),t)))},async(t,e)=>((a,t)=>X(oa(w,a),t))(t,e)?O(h(p(await a(Y+W(t)),(a=>{return[a[e],l?(t=I(a,e),n=l,O(L(t,((a,t)=>[t,n(a,t)])))):I(a,e)];var t,n})),(([a,t])=>!i(a)&&!M(t)))):{},async(t,e,s,l,u,y=!1)=>{const E=_();L(s??{},(a=>p(C(a??{}),(a=>P(E,a)))));const v=Z(E);if(!y&&u&&A(v)&&X(w,t))return await a("DROP "+B+W(t)),void ia(w,t);const f=oa(w,t),m=_(Z(f));if(A(v)||(X(w,t)?await d(p([e,...v],(async(n,s)=>{ta(m,n)||(await a(H+W(t)+"ADD"+W(n)+o),0==s&&await a("CREATE UNIQUE INDEX pk ON "+W(t)+`(${W(e)})`),P(f,n))}))):(await a("CREATE "+B+W(t)+`(${W(e)}${o} PRIMARY KEY${g(p(v,(a=>n+W(a)+o)))});`),ia(w,t,_([e,...v])))),await d([...!y&&l?p(Z(m),(async n=>{n!=e&&(await a(H+W(t)+"DROP"+W(n)),ta(f,n))})):[]]),y)i(s)?await a(J+W(t)+x+" true"):await d(L(s,(async(n,s)=>{i(n)?await a(J+W(t)+x+W(e)+"=$1",[s]):A(v)||await r(a,t,e,C(n),{[s]:c?p(R(n),c):R(n)},f)})));else if(A(v))X(w,t)&&await a(J+W(t)+x+" true");else{const n=h(Z(oa(w,t)),(a=>a!=e)),o={},i=[];L(s??{},((a,t)=>{o[t]=p(n,(t=>c?c(a?.[t]):a?.[t])),N(i,t)})),await r(a,t,e,n,o),await a(J+W(t)+x+W(e)+`NOT IN(${Q(i)})`,i)}},async t=>{let e;await a("BEGIN");try{e=await t()}catch(a){s?.(a)}return await a("END"),e}]},va=async(a,t,e,s,o)=>{const r=[1];await a("INSERT INTO"+W(t)+"("+K(e,...s)+")VALUES"+g(L(o,(a=>"($"+r[0]+++","+Q(a,r)+")")),n)+"ON CONFLICT("+W(e)+")DO UPDATE SET"+g(p(s,(a=>W(a)+"=excluded."+W(a))),n),L(o,((a,t)=>[t,...p(a,(a=>a??null))])).flat())},ga=(a,t,e,n,s,o,r,[i,c,l],w,u,y,d,E,v)=>{const[g,p,A,h]=Ea(t,w,u,s,E,v),N=da(a,(async()=>await h((async()=>{return await g(),a=(await p(i,c))[F]?.[l]??"null",na(a,((a,t)=>""===t?void 0:t));var a}))),(async a=>await h((async()=>{var t;await g(),await A(i,c,{[F]:{[l]:(t=a()??null,ea(t,((a,t)=>void 0===t?"":t)))}},!0,!0)}))),e,n,s,r,{[d]:()=>y,destroy:()=>(N.stopAutoLoad().stopAutoSave(),o(),N)},y);return N},pa=(a,t,e,n,s,o,r,[c,l,[w,u,y]],E,v,g,p,A,N,f,m)=>{const[S,T,C,$]=Ea(t,E,v,s,A,N,f,m),b=async(a,t)=>await d(ra(l,(async([e,n,s,o],r)=>{t&&!(r in a)||await C(e,n,a[r],s,o,t)}))),I=async(a,t)=>u?await C(y,U,{[F]:a},!0,!0,t):null,L=da(a,(async()=>await $((async()=>{await S();const a=await(async()=>O(h(await d(ra(c,(async([a,t],e)=>[a,await T(e,t)]))),(a=>!M(a[1])))))(),t=await(async()=>w?(await T(y,U))[F]:{})();return M(a)&&i(t)?void 0:[a,t]}))),(async(a,t)=>await $((async()=>{if(await S(),i(t)){const[t,e]=a();await b(t),await I(e)}else await b(t[0],!0),await I(t[1],!0)}))),e,n,s,r,{[p]:()=>g,destroy:()=>(L.stopAutoLoad().stopAutoSave(),o(),L)},g);return L},Aa="ColumnName",ha="store",Na="json",fa=ha+"TableName",ma=ha+"Id"+Aa,Sa=ha+Aa,Ta="autoLoadIntervalSeconds",Ca="rowId"+Aa,$a="tableId",Oa="tableName",ba="deleteEmptyColumns",Ia="deleteEmptyTable",La={mode:Na,[Ta]:1},Ra={load:0,save:0,[Oa]:t+"_values"},Da=(a,t,e,n,s)=>{const o=sa();return L(a,((a,r)=>{const c=u(R(b(t,l(a)?{[e]:a}:a)),0,D(t));i(c[0])||n(r,c[0])||(s(r,c[0]),ia(o,r,c))})),o},Ma=(a,n,s,o,i,c,w,y,d,E,v="getDb",g)=>{let p,A,h;const N=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,c),[f,m,S,T]=(a=>{const e=(a=>b(La,l(a)?{[fa]:a}:a??{}))(a),n=e[Ta];if(e.mode==Na){const a=e[fa]??t;return[1,n,[a,e[ma]??U,e[Sa]??ha],_(a)]}const{tables:{load:s={},save:o={}}={},values:r={}}=e,i=u(R(b(Ra,r)),0,D(Ra)),c=i[2],w=_(c),y=_(c);return[0,n,[Da(s,{[$a]:null,[Ca]:U},$a,(a=>X(y,a)),(a=>P(w,a))),Da(o,{[Oa]:null,[Ca]:U,[ba]:0,[Ia]:0},Oa,((a,t)=>X(y,t)),((a,t)=>P(w,t))),i],w]})(n);return(f?ga:pa)(a,N,(a=>{let t;const e=()=>t=setInterval((async()=>{try{const[{d:t,s:e,c:n}]=await N(`${j} ${z} d,${G} s,TOTAL_CHANGES() c FROM ${k}${z} JOIN ${k}${G}`);t==p&&e==A&&n==h||(null!=p&&a(),p=t,A=e,h=n)}catch{}}),1e3*m),n=()=>{p=A=h=null,r(t)},s=o((t=>{T.has(t)&&(n(),a(),e())}));return e(),()=>{n(),i(s)}}),(a=>a()),w,y,d,S,Z(T),(async(a,t)=>await a(`${j} t.name tn,c.name cn FROM ${V}list()t,${V}info(t.name)c ${x} t.schema='main'AND t.type IN('table','view')AND t.name IN(${Q(t)})ORDER BY t.name,c.name`,t)),E,v,e,g,(a=>!0===a?1:!1===a?0:a),void 0)},_a=(a,t,e,n,s)=>{let o;return Ma(a,e,(async(a,e=[])=>t.execute(a,e).then((a=>a.rows?._array??[]))),(a=>{const e=new AbortController,n=t.onChange({rawTableNames:!0,signal:e.signal});return(async()=>{for await(const a of n)o&&p(a.changedTables,o)})(),o=a,e}),(a=>{o=void 0,a.abort()}),n,s,(()=>0),1,t,"getPowerSync",Pa)},Pa=async(a,t,e,s,o,r)=>{const i=[1],c=_(s),l=r?h([...r],(a=>a!=e&&!X(c,a))):[];if(!A(l)){const n=C(o),s=O(p(await a("SELECT"+K(e,...l)+"FROM"+W(t)+"WHERE"+W(e)+"IN("+Q(n)+")",n),(a=>[a[e],a])));v(n,(a=>N(o[a],...p(l,(t=>s?.[a]?.[t]??null)))))}await a("INSERT OR REPLACE INTO"+W(t)+"("+K(e,...s,...l)+")VALUES"+g(L(o,(a=>"($"+i[0]+++","+Q(a,i)+")")),n),L(o,((a,t)=>[t,...p(a,(a=>a??null))])).flat())};export{_a as createPowerSyncPersister};
1
+ const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),r=Promise,o=clearInterval,i=a=>null==a,c=(a,t,e)=>i(a)?e?.():t(a),l=t=>a(t)==s,w=a=>Array.isArray(a),u=(a,t,e)=>a.slice(t,e),y=a=>a.length,d=async a=>r.all(a),E=a=>{throw Error(a)},v=(a,t)=>a.forEach(t),g=(a,t="")=>a.join(t),p=(a,t)=>a.map(t),A=a=>0==y(a),h=(a,t)=>a.filter(t),N=(a,...t)=>a.push(...t),f=a=>a.shift(),m=Object,S=a=>m.getPrototypeOf(a),T=m.entries,C=m.keys,$=m.freeze,O=(a=[])=>m.fromEntries(a),b=(...a)=>m.assign({},...a),I=(a,t)=>(delete a[t],a),L=(a,t)=>p(T(a),(([a,e])=>t(e,a))),R=a=>m.values(a),D=a=>y(C(a)),M=a=>(a=>!i(a)&&c(S(a),(a=>a==m.prototype||i(S(a))),(()=>!0)))(a)&&0==D(a),_=a=>new Set(w(a)||i(a)?a:[a]),P=(a,t)=>a?.add(t),F="_",U="_id",j="SELECT",x="WHERE",B="TABLE",H="ALTER "+B,J="DELETE FROM",Y=j+"*FROM",k="pragma_",z="data_version",G="schema_version",V="pragma_table_",W=a=>`"${a.replace(/"/g,'""')}"`,K=(...a)=>g(p(a,W),n),Q=(a,t=[1])=>g(p(a,(()=>"$"+t[0]++)),n),X=(a,t)=>a?.has(t)??!1,q=a=>i(a)||0==(a=>a?.size??0)(a),Z=a=>[...a?.values()??[]],aa=(a,t)=>a?.forEach(t),ta=(a,t)=>a?.delete(t),ea=JSON.stringify,na=JSON.parse,sa=a=>new Map(a),ra=(a,t)=>a?.get(t),oa=(a,t)=>p([...a?.entries()??[]],(([a,e])=>t(e,a))),ia=(a,t,e)=>i(e)?(ta(a,t),a):a?.set(t,e),ca=(a,t,e,n)=>(X(a,t)?n?.(ra(a,t)):ia(a,t,e()),ra(a,t)),la=(a,t,e,n,s=0)=>c((e?ca:ra)(a,t[s],s>y(t)-2?e:sa),(r=>{if(s>y(t)-2)return n?.(r)&&ia(a,t[s]),r;const o=la(r,t,e,n,s+1);return q(r)&&ia(a,t[s]),o})),wa=/^\d+$/,ua=sa(),ya=sa(),da=(a,t,n,s,r,o,l,u={},d=0,g=[])=>{let p,A,h,m=0,S=0,T=0;ca(ua,g,(()=>0)),ca(ya,g,(()=>[]));const C=sa(),[O,b,I,L,R]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!M(a)||!M(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!M(a)||!M(t),t.setContent]:E("Store type not supported by this Persister"))(l,a,d),[D,F,U]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?f(a):null)??e+t++,t=>{wa.test(t)&&y(a)<1e3&&N(a,t)}]})(),s=sa();return[(n,r,o,i=[],c=()=>[])=>{a??=z;const l=t(1);return ia(s,l,[n,r,o,i,c]),P(la(r,o??[e],_),l),l},(t,n,...r)=>v(((a,t=[e])=>{const n=[],s=(a,e)=>e==y(t)?N(n,a):null===t[e]?aa(a,(a=>s(a,e+1))):v([t[e],null],(t=>s(ra(a,t),e+1)));return s(a,0),n})(t,n),(t=>aa(t,(t=>ra(s,t)[0](a,...n??[],...r))))),a=>c(ra(s,a),(([,t,r])=>(la(t,r??[e],void 0,(t=>(ta(t,a),q(t)?1:0))),ia(s,a),n(a),r))),t=>c(ra(s,t),(([t,,e=[],n,s])=>{const r=(...o)=>{const c=y(o);c==y(e)?t(a,...o,...s(o)):i(e[c])?v(n[c]?.(...o)??[],(a=>r(...o,a))):r(...o,e[c])};r()}))]})(),j=a=>{a!=m&&(m=a,F(C,void 0,m))},x=t=>{(O&&w(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},B=async a=>(2!=m&&(j(1),S++,await k((async()=>{try{const e=await t();w(e)?x(e):a?R(a):E("Content is not an array: "+e)}catch(t){o?.(t),a&&R(a)}j(0)}))),z),H=()=>(A&&(r(A),A=void 0),z),J=async a=>(1!=m&&(j(2),T++,await k((async()=>{try{await n(b,a)}catch(a){o?.(a)}j(0)}))),z),Y=()=>(h&&(a.delListener(h),h=void 0),z),k=async(...a)=>(N(ra(ya,g),...a),await(async()=>{if(!ra(ua,g)){for(ia(ua,g,1);!i(p=f(ra(ya,g)));)try{await p()}catch(a){o?.(a)}ia(ua,g,0)}})(),z),z={load:B,startAutoLoad:async a=>{H(),await B(a);try{A=await s((async(a,t)=>{t||a?2!=m&&(j(1),S++,x(t??a),j(0)):await B()}))}catch(a){o?.(a)}return z},stopAutoLoad:H,isAutoLoading:()=>!i(A),save:J,startAutoSave:async()=>(Y(),await J(),h=a.addDidFinishTransactionListener((()=>{const a=I();L(a)&&J(a)})),z),stopAutoSave:Y,isAutoSaving:()=>!i(h),getStatus:()=>m,addStatusListener:a=>D(a,C),delListener:t=>(U(t),a),schedule:k,getStore:()=>a,destroy:()=>(ra(ya,g).splice(0,void 0),H().stopAutoSave()),getStats:()=>({loads:S,saves:T}),...u};return $(z)},Ea=(a,t,e,s,r,o=va,c,l)=>{const w=sa();return[async()=>{w.clear(),p(await e(a,t),(({tn:a,cn:t})=>P(ca(w,a,_),t)))},async(t,e)=>((a,t)=>X(ra(w,a),t))(t,e)?O(h(p(await a(Y+W(t)),(a=>{return[a[e],l?(t=I(a,e),n=l,O(L(t,((a,t)=>[t,n(a,t)])))):I(a,e)];var t,n})),(([a,t])=>!i(a)&&!M(t)))):{},async(t,e,s,l,u,y=!1)=>{const E=_();L(s??{},(a=>p(C(a??{}),(a=>P(E,a)))));const v=Z(E);if(!y&&u&&A(v)&&X(w,t))return await a("DROP "+B+W(t)),void ia(w,t);const f=ra(w,t),m=_(Z(f));if(A(v)||(X(w,t)?await d(p([e,...v],(async(n,s)=>{ta(m,n)||(await a(H+W(t)+"ADD"+W(n)+r),0==s&&await a("CREATE UNIQUE INDEX pk ON "+W(t)+`(${W(e)})`),P(f,n))}))):(await a("CREATE "+B+W(t)+`(${W(e)}${r} PRIMARY KEY${g(p(v,(a=>n+W(a)+r)))});`),ia(w,t,_([e,...v])))),await d([...!y&&l?p(Z(m),(async n=>{n!=e&&(await a(H+W(t)+"DROP"+W(n)),ta(f,n))})):[]]),y)i(s)?await a(J+W(t)+x+" true"):await d(L(s,(async(n,s)=>{i(n)?await a(J+W(t)+x+W(e)+"=$1",[s]):A(v)||await o(a,t,e,C(n),{[s]:c?p(R(n),c):R(n)},f)})));else if(A(v))X(w,t)&&await a(J+W(t)+x+" true");else{const n=h(Z(ra(w,t)),(a=>a!=e)),r={},i=[];L(s??{},((a,t)=>{r[t]=p(n,(t=>c?c(a?.[t]):a?.[t])),N(i,t)})),await o(a,t,e,n,r),await a(J+W(t)+x+W(e)+`NOT IN(${Q(i)})`,i)}},async t=>{let e;await a("BEGIN");try{e=await t()}catch(a){s?.(a)}return await a("END"),e}]},va=async(a,t,e,s,r)=>{const o=[1];await a("INSERT INTO"+W(t)+"("+K(e,...s)+")VALUES"+g(L(r,(a=>"($"+o[0]+++","+Q(a,o)+")")),n)+"ON CONFLICT("+W(e)+")DO UPDATE SET"+g(p(s,(a=>W(a)+"=excluded."+W(a))),n),L(r,((a,t)=>[t,...p(a,(a=>a??null))])).flat())},ga=(a,t,e,n,s,r,o,[i,c,l],w,u,y,d,E,v)=>{const[g,p,A,h]=Ea(t,w,u,s,E,v),N=da(a,(async()=>await h((async()=>{return await g(),a=(await p(i,c))[F]?.[l]??"null",na(a,((a,t)=>""===t?void 0:t));var a}))),(async a=>await h((async()=>{var t;await g(),await A(i,c,{[F]:{[l]:(t=a()??null,ea(t,((a,t)=>void 0===t?"":t)))}},!0,!0)}))),e,n,s,o,{[d]:()=>y,destroy:()=>(N.stopAutoLoad().stopAutoSave(),r(),N)},0,y);return N},pa=(a,t,e,n,s,r,o,[c,l,[w,u,y]],E,v,g,p,A,N,f,m)=>{const[S,T,C,$]=Ea(t,E,v,s,A,N,f,m),b=async(a,t)=>await d(oa(l,(async([e,n,s,r],o)=>{t&&!(o in a)||await C(e,n,a[o],s,r,t)}))),I=async(a,t)=>u?await C(y,U,{[F]:a},!0,!0,t):null,L=da(a,(async()=>await $((async()=>{await S();const a=await(async()=>O(h(await d(oa(c,(async([a,t],e)=>[a,await T(e,t)]))),(a=>!M(a[1])))))(),t=await(async()=>w?(await T(y,U))[F]:{})();return M(a)&&i(t)?void 0:[a,t]}))),(async(a,t)=>await $((async()=>{if(await S(),i(t)){const[t,e]=a();await b(t),await I(e)}else await b(t[0],!0),await I(t[1],!0)}))),e,n,s,o,{[p]:()=>g,destroy:()=>(L.stopAutoLoad().stopAutoSave(),r(),L)},0,g);return L},Aa="ColumnName",ha="store",Na="json",fa=ha+"TableName",ma=ha+"Id"+Aa,Sa=ha+Aa,Ta="autoLoadIntervalSeconds",Ca="rowId"+Aa,$a="tableId",Oa="tableName",ba="deleteEmptyColumns",Ia="deleteEmptyTable",La={mode:Na,[Ta]:1},Ra={load:0,save:0,[Oa]:t+"_values"},Da=(a,t,e,n,s)=>{const r=sa();return L(a,((a,o)=>{const c=u(R(b(t,l(a)?{[e]:a}:a)),0,D(t));i(c[0])||n(o,c[0])||(s(o,c[0]),ia(r,o,c))})),r},Ma=(a,n,s,r,i,c,w,y,d,E,v="getDb",g)=>{let p,A,h;const N=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,c),[f,m,S,T]=(a=>{const e=(a=>b(La,l(a)?{[fa]:a}:a??{}))(a),n=e[Ta];if(e.mode==Na){const a=e[fa]??t;return[1,n,[a,e[ma]??U,e[Sa]??ha],_(a)]}const{tables:{load:s={},save:r={}}={},values:o={}}=e,i=u(R(b(Ra,o)),0,D(Ra)),c=i[2],w=_(c),y=_(c);return[0,n,[Da(s,{[$a]:null,[Ca]:U},$a,(a=>X(y,a)),(a=>P(w,a))),Da(r,{[Oa]:null,[Ca]:U,[ba]:0,[Ia]:0},Oa,((a,t)=>X(y,t)),((a,t)=>P(w,t))),i],w]})(n);return(f?ga:pa)(a,N,(a=>{let t;const e=()=>t=setInterval((async()=>{try{const[{d:t,s:e,c:n}]=await N(`${j} ${z} d,${G} s,TOTAL_CHANGES() c FROM ${k}${z} JOIN ${k}${G}`);t==p&&e==A&&n==h||(null!=p&&a(),p=t,A=e,h=n)}catch{}}),1e3*m),n=()=>{p=A=h=null,o(t)},s=r((t=>{T.has(t)&&(n(),a(),e())}));return e(),()=>{n(),i(s)}}),(a=>a()),w,y,d,S,Z(T),(async(a,t)=>await a(`${j} t.name tn,c.name cn FROM ${V}list()t,${V}info(t.name)c ${x} t.schema='main'AND t.type IN('table','view')AND t.name IN(${Q(t)})ORDER BY t.name,c.name`,t)),E,v,e,g,(a=>!0===a?1:!1===a?0:a),void 0)},_a=(a,t,e,n,s)=>{let r;return Ma(a,e,(async(a,e=[])=>t.execute(a,e).then((a=>a.rows?._array??[]))),(a=>{const e=new AbortController,n=t.onChange({rawTableNames:!0,signal:e.signal});return(async()=>{for await(const a of n)r&&p(a.changedTables,r)})(),r=a,e}),(a=>{r=void 0,a.abort()}),n,s,(()=>0),1,t,"getPowerSync",Pa)},Pa=async(a,t,e,s,r,o)=>{const i=[1],c=_(s),l=o?h([...o],(a=>a!=e&&!X(c,a))):[];if(!A(l)){const n=C(r),s=O(p(await a("SELECT"+K(e,...l)+"FROM"+W(t)+"WHERE"+W(e)+"IN("+Q(n)+")",n),(a=>[a[e],a])));v(n,(a=>N(r[a],...p(l,(t=>s?.[a]?.[t]??null)))))}await a("INSERT OR REPLACE INTO"+W(t)+"("+K(e,...s,...l)+")VALUES"+g(L(r,(a=>"($"+i[0]+++","+Q(a,i)+")")),n),L(r,((a,t)=>[t,...p(a,(a=>a??null))])).flat())};export{_a as createPowerSyncPersister};
@@ -1 +1 @@
1
- const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),o=Promise,r=clearInterval,i=a=>null==a,c=(a,t,e)=>i(a)?e?.():t(a),l=t=>a(t)==s,w=a=>Array.isArray(a),u=(a,t,e)=>a.slice(t,e),y=a=>a.length,d=async a=>o.all(a),E=a=>{throw Error(a)},v=(a,t)=>a.forEach(t),g=(a,t="")=>a.join(t),p=(a,t)=>a.map(t),A=a=>0==y(a),h=(a,t)=>a.filter(t),N=(a,...t)=>a.push(...t),f=a=>a.shift(),m=Object,S=a=>m.getPrototypeOf(a),T=m.entries,C=m.keys,$=m.freeze,O=(a=[])=>m.fromEntries(a),b=(...a)=>m.assign({},...a),I=(a,t)=>(delete a[t],a),L=(a,t)=>p(T(a),(([a,e])=>t(e,a))),R=a=>m.values(a),D=a=>y(C(a)),M=a=>(a=>!i(a)&&c(S(a),(a=>a==m.prototype||i(S(a))),(()=>!0)))(a)&&0==D(a),_=a=>new Set(w(a)||i(a)?a:[a]),P=(a,t)=>a?.add(t),F="_",U="_id",j="SELECT",x="WHERE",B="TABLE",H="ALTER "+B,J="DELETE FROM",Y=j+"*FROM",k="pragma_",z="data_version",G="schema_version",V="pragma_table_",W=a=>`"${a.replace(/"/g,'""')}"`,K=(...a)=>g(p(a,W),n),Q=(a,t=[1])=>g(p(a,(()=>"$"+t[0]++)),n),X=(a,t)=>a?.has(t)??!1,q=a=>i(a)||0==(a=>a?.size??0)(a),Z=a=>[...a?.values()??[]],aa=(a,t)=>a?.forEach(t),ta=(a,t)=>a?.delete(t),ea=JSON.stringify,na=JSON.parse,sa=a=>new Map(a),oa=(a,t)=>a?.get(t),ra=(a,t)=>p([...a?.entries()??[]],(([a,e])=>t(e,a))),ia=(a,t,e)=>i(e)?(ta(a,t),a):a?.set(t,e),ca=(a,t,e,n)=>(X(a,t)?n?.(oa(a,t)):ia(a,t,e()),oa(a,t)),la=(a,t,e,n,s=0)=>c((e?ca:oa)(a,t[s],s>y(t)-2?e:sa),(o=>{if(s>y(t)-2)return n?.(o)&&ia(a,t[s]),o;const r=la(o,t,e,n,s+1);return q(o)&&ia(a,t[s]),r})),wa=/^\d+$/,ua=sa(),ya=sa(),da=(a,t,n,s,o,r,l,u={},d=[])=>{let g,p,A,h=0,m=0,S=0;ca(ua,d,(()=>0)),ca(ya,d,(()=>[]));const T=sa(),[C,O,b,I,L]=((a=1,t)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,t.getTransactionMergeableChanges,([[a],[t]])=>!M(a)||!M(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!M(a)||!M(t),t.setContent]:E("Store type not supported by this Persister"))(l,a),[R,D,F]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?f(a):null)??e+t++,t=>{wa.test(t)&&y(a)<1e3&&N(a,t)}]})(),s=sa();return[(n,o,r,i=[],c=()=>[])=>{a??=k;const l=t(1);return ia(s,l,[n,o,r,i,c]),P(la(o,r??[e],_),l),l},(t,n,...o)=>v(((a,t=[e])=>{const n=[],s=(a,e)=>e==y(t)?N(n,a):null===t[e]?aa(a,(a=>s(a,e+1))):v([t[e],null],(t=>s(oa(a,t),e+1)));return s(a,0),n})(t,n),(t=>aa(t,(t=>oa(s,t)[0](a,...n??[],...o))))),a=>c(oa(s,a),(([,t,o])=>(la(t,o??[e],void 0,(t=>(ta(t,a),q(t)?1:0))),ia(s,a),n(a),o))),t=>c(oa(s,t),(([t,,e=[],n,s])=>{const o=(...r)=>{const c=y(r);c==y(e)?t(a,...r,...s(r)):i(e[c])?v(n[c]?.(...r)??[],(a=>o(...r,a))):o(...r,e[c])};o()}))]})(),U=a=>{a!=h&&(h=a,D(T,void 0,h))},j=t=>{(C&&w(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},x=async a=>(2!=h&&(U(1),m++,await Y((async()=>{try{const e=await t();w(e)?j(e):a?L(a):E("Content is not an array "+e)}catch(t){r?.(t),a&&L(a)}U(0)}))),k),B=()=>(p&&(o(p),p=void 0),k),H=async a=>(1!=h&&(U(2),S++,await Y((async()=>{try{await n(O,a)}catch(a){r?.(a)}U(0)}))),k),J=()=>(c(A,a.delListener),A=void 0,k),Y=async(...a)=>(N(oa(ya,d),...a),await(async()=>{if(!oa(ua,d)){for(ia(ua,d,1);!i(g=f(oa(ya,d)));)try{await g()}catch(a){r?.(a)}ia(ua,d,0)}})(),k),k={load:x,startAutoLoad:async a=>{await B().load(a);try{p=await s((async(a,t)=>{t||a?2!=h&&(U(1),m++,j(t??a),U(0)):await x()}))}catch(a){r?.(a)}return k},stopAutoLoad:B,isAutoLoading:()=>!i(p),save:H,startAutoSave:async()=>(await J().save(),A=a.addDidFinishTransactionListener((()=>{const a=b();I(a)&&H(a)})),k),stopAutoSave:J,isAutoSaving:()=>!i(A),getStatus:()=>h,addStatusListener:a=>R(a,T),delListener:t=>(F(t),a),schedule:Y,getStore:()=>a,destroy:()=>(oa(ya,d).splice(0,void 0),B().stopAutoSave()),getStats:()=>({loads:m,saves:S}),...u};return $(k)},Ea=(a,t,e,s,o,r=va,c,l)=>{const w=sa();return[async()=>{w.clear(),p(await e(a,t),(({tn:a,cn:t})=>P(ca(w,a,_),t)))},async(t,e)=>((a,t)=>X(oa(w,a),t))(t,e)?O(h(p(await a(Y+W(t)),(a=>{return[a[e],l?(t=I(a,e),n=l,O(L(t,((a,t)=>[t,n(a,t)])))):I(a,e)];var t,n})),(([a,t])=>!i(a)&&!M(t)))):{},async(t,e,s,l,u,y=!1)=>{const E=_();L(s??{},(a=>p(C(a??{}),(a=>P(E,a)))));const v=Z(E);if(!y&&u&&A(v)&&X(w,t))return await a("DROP "+B+W(t)),void ia(w,t);const f=oa(w,t),m=_(Z(f));if(A(v)||(X(w,t)?await d(p([e,...v],(async(n,s)=>{ta(m,n)||(await a(H+W(t)+"ADD"+W(n)+o),0==s&&await a("CREATE UNIQUE INDEX pk ON "+W(t)+`(${W(e)})`),P(f,n))}))):(await a("CREATE "+B+W(t)+`(${W(e)}${o} PRIMARY KEY${g(p(v,(a=>n+W(a)+o)))});`),ia(w,t,_([e,...v])))),await d([...!y&&l?p(Z(m),(async n=>{n!=e&&(await a(H+W(t)+"DROP"+W(n)),ta(f,n))})):[]]),y)i(s)?await a(J+W(t)+x+" true"):await d(L(s,(async(n,s)=>{i(n)?await a(J+W(t)+x+W(e)+"=$1",[s]):A(v)||await r(a,t,e,C(n),{[s]:c?p(R(n),c):R(n)},f)})));else if(A(v))X(w,t)&&await a(J+W(t)+x+" true");else{const n=h(Z(oa(w,t)),(a=>a!=e)),o={},i=[];L(s??{},((a,t)=>{o[t]=p(n,(t=>c?c(a?.[t]):a?.[t])),N(i,t)})),await r(a,t,e,n,o),await a(J+W(t)+x+W(e)+`NOT IN(${Q(i)})`,i)}},async t=>{let e;await a("BEGIN");try{e=await t()}catch(a){s?.(a)}return await a("END"),e}]},va=async(a,t,e,s,o)=>{const r=[1];await a("INSERT INTO"+W(t)+"("+K(e,...s)+")VALUES"+g(L(o,(a=>"($"+r[0]+++","+Q(a,r)+")")),n)+"ON CONFLICT("+W(e)+")DO UPDATE SET"+g(p(s,(a=>W(a)+"=excluded."+W(a))),n),L(o,((a,t)=>[t,...p(a,(a=>a??null))])).flat())},ga=(a,t,e,n,s,o,r,[i,c,l],w,u,y,d,E,v)=>{const[g,p,A,h]=Ea(t,w,u,s,E,v),N=da(a,(async()=>await h((async()=>{return await g(),a=(await p(i,c))[F]?.[l]??"null",na(a,((a,t)=>""===t?void 0:t));var a}))),(async a=>await h((async()=>{var t;await g(),await A(i,c,{[F]:{[l]:(t=a()??null,ea(t,((a,t)=>void 0===t?"":t)))}},!0,!0)}))),e,n,s,r,{[d]:()=>y,destroy:()=>(N.stopAutoLoad().stopAutoSave(),o(),N)},y);return N},pa=(a,t,e,n,s,o,r,[c,l,[w,u,y]],E,v,g,p,A,N,f,m)=>{const[S,T,C,$]=Ea(t,E,v,s,A,N,f,m),b=async(a,t)=>await d(ra(l,(async([e,n,s,o],r)=>{t&&!(r in a)||await C(e,n,a[r],s,o,t)}))),I=async(a,t)=>u?await C(y,U,{[F]:a},!0,!0,t):null,L=da(a,(async()=>await $((async()=>{await S();const a=await(async()=>O(h(await d(ra(c,(async([a,t],e)=>[a,await T(e,t)]))),(a=>!M(a[1])))))(),t=await(async()=>w?(await T(y,U))[F]:{})();return M(a)&&i(t)?void 0:[a,t]}))),(async(a,t)=>await $((async()=>{if(await S(),i(t)){const[t,e]=a();await b(t),await I(e)}else await b(t[0],!0),await I(t[1],!0)}))),e,n,s,r,{[p]:()=>g,destroy:()=>(L.stopAutoLoad().stopAutoSave(),o(),L)},g);return L},Aa="ColumnName",ha="store",Na="json",fa=ha+"TableName",ma=ha+"Id"+Aa,Sa=ha+Aa,Ta="autoLoadIntervalSeconds",Ca="rowId"+Aa,$a="tableId",Oa="tableName",ba="deleteEmptyColumns",Ia="deleteEmptyTable",La={mode:Na,[Ta]:1},Ra={load:0,save:0,[Oa]:t+"_values"},Da=(a,t,e,n,s)=>{const o=sa();return L(a,((a,r)=>{const c=u(R(b(t,l(a)?{[e]:a}:a)),0,D(t));i(c[0])||n(r,c[0])||(s(r,c[0]),ia(o,r,c))})),o},Ma=(a,n,s,o,i,c,w,y,d,E,v="getDb",g)=>{let p,A,h;const N=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,c),[f,m,S,T]=(a=>{const e=(a=>b(La,l(a)?{[fa]:a}:a??{}))(a),n=e[Ta];if(e.mode==Na){const a=e[fa]??t;return[1,n,[a,e[ma]??U,e[Sa]??ha],_(a)]}const{tables:{load:s={},save:o={}}={},values:r={}}=e,i=u(R(b(Ra,r)),0,D(Ra)),c=i[2],w=_(c),y=_(c);return[0,n,[Da(s,{[$a]:null,[Ca]:U},$a,(a=>X(y,a)),(a=>P(w,a))),Da(o,{[Oa]:null,[Ca]:U,[ba]:0,[Ia]:0},Oa,((a,t)=>X(y,t)),((a,t)=>P(w,t))),i],w]})(n);return(f?ga:pa)(a,N,(a=>{let t;const e=()=>t=setInterval((async()=>{try{const[{d:t,s:e,c:n}]=await N(`${j} ${z} d,${G} s,TOTAL_CHANGES() c FROM ${k}${z} JOIN ${k}${G}`);t==p&&e==A&&n==h||(null!=p&&a(),p=t,A=e,h=n)}catch{}}),1e3*m),n=()=>{p=A=h=null,r(t)},s=o((t=>{T.has(t)&&(n(),a(),e())}));return e(),()=>{n(),i(s)}}),(a=>a()),w,y,d,S,Z(T),(async(a,t)=>await a(`${j} t.name tn,c.name cn FROM ${V}list()t,${V}info(t.name)c ${x} t.schema='main'AND t.type IN('table','view')AND t.name IN(${Q(t)})ORDER BY t.name,c.name`,t)),E,v,e,g,(a=>!0===a?1:!1===a?0:a),void 0)},_a=(a,t,e,n,s)=>{let o;return Ma(a,e,(async(a,e=[])=>t.execute(a,e).then((a=>a.rows?._array??[]))),(a=>{const e=new AbortController,n=t.onChange({rawTableNames:!0,signal:e.signal});return(async()=>{for await(const a of n)o&&p(a.changedTables,o)})(),o=a,e}),(a=>{o=void 0,a.abort()}),n,s,(()=>0),1,t,"getPowerSync",Pa)},Pa=async(a,t,e,s,o,r)=>{const i=[1],c=_(s),l=r?h([...r],(a=>a!=e&&!X(c,a))):[];if(!A(l)){const n=C(o),s=O(p(await a("SELECT"+K(e,...l)+"FROM"+W(t)+"WHERE"+W(e)+"IN("+Q(n)+")",n),(a=>[a[e],a])));v(n,(a=>N(o[a],...p(l,(t=>s?.[a]?.[t]??null)))))}await a("INSERT OR REPLACE INTO"+W(t)+"("+K(e,...s,...l)+")VALUES"+g(L(o,(a=>"($"+i[0]+++","+Q(a,i)+")")),n),L(o,((a,t)=>[t,...p(a,(a=>a??null))])).flat())};export{_a as createPowerSyncPersister};
1
+ const a=a=>typeof a,t="tinybase",e="",n=",",s=a(e),r=Promise,o=clearInterval,i=a=>null==a,c=(a,t,e)=>i(a)?e?.():t(a),l=t=>a(t)==s,w=a=>Array.isArray(a),u=(a,t,e)=>a.slice(t,e),y=a=>a.length,d=async a=>r.all(a),E=a=>{throw Error(a)},v=(a,t)=>a.forEach(t),g=(a,t="")=>a.join(t),p=(a,t)=>a.map(t),A=a=>0==y(a),h=(a,t)=>a.filter(t),N=(a,...t)=>a.push(...t),f=a=>a.shift(),m=Object,S=a=>m.getPrototypeOf(a),T=m.entries,C=m.keys,$=m.freeze,O=(a=[])=>m.fromEntries(a),b=(...a)=>m.assign({},...a),I=(a,t)=>(delete a[t],a),L=(a,t)=>p(T(a),(([a,e])=>t(e,a))),R=a=>m.values(a),D=a=>y(C(a)),M=a=>(a=>!i(a)&&c(S(a),(a=>a==m.prototype||i(S(a))),(()=>!0)))(a)&&0==D(a),_=a=>new Set(w(a)||i(a)?a:[a]),P=(a,t)=>a?.add(t),F="_",U="_id",j="SELECT",x="WHERE",B="TABLE",H="ALTER "+B,J="DELETE FROM",Y=j+"*FROM",k="pragma_",z="data_version",G="schema_version",V="pragma_table_",W=a=>`"${a.replace(/"/g,'""')}"`,K=(...a)=>g(p(a,W),n),Q=(a,t=[1])=>g(p(a,(()=>"$"+t[0]++)),n),X=(a,t)=>a?.has(t)??!1,q=a=>i(a)||0==(a=>a?.size??0)(a),Z=a=>[...a?.values()??[]],aa=(a,t)=>a?.forEach(t),ta=(a,t)=>a?.delete(t),ea=JSON.stringify,na=JSON.parse,sa=a=>new Map(a),ra=(a,t)=>a?.get(t),oa=(a,t)=>p([...a?.entries()??[]],(([a,e])=>t(e,a))),ia=(a,t,e)=>i(e)?(ta(a,t),a):a?.set(t,e),ca=(a,t,e,n)=>(X(a,t)?n?.(ra(a,t)):ia(a,t,e()),ra(a,t)),la=(a,t,e,n,s=0)=>c((e?ca:ra)(a,t[s],s>y(t)-2?e:sa),(r=>{if(s>y(t)-2)return n?.(r)&&ia(a,t[s]),r;const o=la(r,t,e,n,s+1);return q(r)&&ia(a,t[s]),o})),wa=/^\d+$/,ua=sa(),ya=sa(),da=(a,t,n,s,r,o,l,u={},d=0,g=[])=>{let p,A,h,m=0,S=0,T=0;ca(ua,g,(()=>0)),ca(ya,g,(()=>[]));const C=sa(),[O,b,I,L,R]=((a=1,t,e)=>1!=a&&t.isMergeable()?[1,t.getMergeableContent,()=>t.getTransactionMergeableChanges(!e),([[a],[t]])=>!M(a)||!M(t),t.setDefaultContent]:2!=a?[0,t.getContent,t.getTransactionChanges,([a,t])=>!M(a)||!M(t),t.setContent]:E("Store type not supported by this Persister"))(l,a,d),[D,F,U]=(()=>{let a;const[t,n]=(()=>{const a=[];let t=0;return[n=>(n?f(a):null)??e+t++,t=>{wa.test(t)&&y(a)<1e3&&N(a,t)}]})(),s=sa();return[(n,r,o,i=[],c=()=>[])=>{a??=z;const l=t(1);return ia(s,l,[n,r,o,i,c]),P(la(r,o??[e],_),l),l},(t,n,...r)=>v(((a,t=[e])=>{const n=[],s=(a,e)=>e==y(t)?N(n,a):null===t[e]?aa(a,(a=>s(a,e+1))):v([t[e],null],(t=>s(ra(a,t),e+1)));return s(a,0),n})(t,n),(t=>aa(t,(t=>ra(s,t)[0](a,...n??[],...r))))),a=>c(ra(s,a),(([,t,r])=>(la(t,r??[e],void 0,(t=>(ta(t,a),q(t)?1:0))),ia(s,a),n(a),r))),t=>c(ra(s,t),(([t,,e=[],n,s])=>{const r=(...o)=>{const c=y(o);c==y(e)?t(a,...o,...s(o)):i(e[c])?v(n[c]?.(...o)??[],(a=>r(...o,a))):r(...o,e[c])};r()}))]})(),j=a=>{a!=m&&(m=a,F(C,void 0,m))},x=t=>{(O&&w(t?.[0])?1===t?.[2]?a.applyMergeableChanges:a.setMergeableContent:1===t?.[2]?a.applyChanges:a.setContent)(t)},B=async a=>(2!=m&&(j(1),S++,await k((async()=>{try{const e=await t();w(e)?x(e):a?R(a):E("Content is not an array: "+e)}catch(t){o?.(t),a&&R(a)}j(0)}))),z),H=()=>(A&&(r(A),A=void 0),z),J=async a=>(1!=m&&(j(2),T++,await k((async()=>{try{await n(b,a)}catch(a){o?.(a)}j(0)}))),z),Y=()=>(h&&(a.delListener(h),h=void 0),z),k=async(...a)=>(N(ra(ya,g),...a),await(async()=>{if(!ra(ua,g)){for(ia(ua,g,1);!i(p=f(ra(ya,g)));)try{await p()}catch(a){o?.(a)}ia(ua,g,0)}})(),z),z={load:B,startAutoLoad:async a=>{H(),await B(a);try{A=await s((async(a,t)=>{t||a?2!=m&&(j(1),S++,x(t??a),j(0)):await B()}))}catch(a){o?.(a)}return z},stopAutoLoad:H,isAutoLoading:()=>!i(A),save:J,startAutoSave:async()=>(Y(),await J(),h=a.addDidFinishTransactionListener((()=>{const a=I();L(a)&&J(a)})),z),stopAutoSave:Y,isAutoSaving:()=>!i(h),getStatus:()=>m,addStatusListener:a=>D(a,C),delListener:t=>(U(t),a),schedule:k,getStore:()=>a,destroy:()=>(ra(ya,g).splice(0,void 0),H().stopAutoSave()),getStats:()=>({loads:S,saves:T}),...u};return $(z)},Ea=(a,t,e,s,r,o=va,c,l)=>{const w=sa();return[async()=>{w.clear(),p(await e(a,t),(({tn:a,cn:t})=>P(ca(w,a,_),t)))},async(t,e)=>((a,t)=>X(ra(w,a),t))(t,e)?O(h(p(await a(Y+W(t)),(a=>{return[a[e],l?(t=I(a,e),n=l,O(L(t,((a,t)=>[t,n(a,t)])))):I(a,e)];var t,n})),(([a,t])=>!i(a)&&!M(t)))):{},async(t,e,s,l,u,y=!1)=>{const E=_();L(s??{},(a=>p(C(a??{}),(a=>P(E,a)))));const v=Z(E);if(!y&&u&&A(v)&&X(w,t))return await a("DROP "+B+W(t)),void ia(w,t);const f=ra(w,t),m=_(Z(f));if(A(v)||(X(w,t)?await d(p([e,...v],(async(n,s)=>{ta(m,n)||(await a(H+W(t)+"ADD"+W(n)+r),0==s&&await a("CREATE UNIQUE INDEX pk ON "+W(t)+`(${W(e)})`),P(f,n))}))):(await a("CREATE "+B+W(t)+`(${W(e)}${r} PRIMARY KEY${g(p(v,(a=>n+W(a)+r)))});`),ia(w,t,_([e,...v])))),await d([...!y&&l?p(Z(m),(async n=>{n!=e&&(await a(H+W(t)+"DROP"+W(n)),ta(f,n))})):[]]),y)i(s)?await a(J+W(t)+x+" true"):await d(L(s,(async(n,s)=>{i(n)?await a(J+W(t)+x+W(e)+"=$1",[s]):A(v)||await o(a,t,e,C(n),{[s]:c?p(R(n),c):R(n)},f)})));else if(A(v))X(w,t)&&await a(J+W(t)+x+" true");else{const n=h(Z(ra(w,t)),(a=>a!=e)),r={},i=[];L(s??{},((a,t)=>{r[t]=p(n,(t=>c?c(a?.[t]):a?.[t])),N(i,t)})),await o(a,t,e,n,r),await a(J+W(t)+x+W(e)+`NOT IN(${Q(i)})`,i)}},async t=>{let e;await a("BEGIN");try{e=await t()}catch(a){s?.(a)}return await a("END"),e}]},va=async(a,t,e,s,r)=>{const o=[1];await a("INSERT INTO"+W(t)+"("+K(e,...s)+")VALUES"+g(L(r,(a=>"($"+o[0]+++","+Q(a,o)+")")),n)+"ON CONFLICT("+W(e)+")DO UPDATE SET"+g(p(s,(a=>W(a)+"=excluded."+W(a))),n),L(r,((a,t)=>[t,...p(a,(a=>a??null))])).flat())},ga=(a,t,e,n,s,r,o,[i,c,l],w,u,y,d,E,v)=>{const[g,p,A,h]=Ea(t,w,u,s,E,v),N=da(a,(async()=>await h((async()=>{return await g(),a=(await p(i,c))[F]?.[l]??"null",na(a,((a,t)=>""===t?void 0:t));var a}))),(async a=>await h((async()=>{var t;await g(),await A(i,c,{[F]:{[l]:(t=a()??null,ea(t,((a,t)=>void 0===t?"":t)))}},!0,!0)}))),e,n,s,o,{[d]:()=>y,destroy:()=>(N.stopAutoLoad().stopAutoSave(),r(),N)},0,y);return N},pa=(a,t,e,n,s,r,o,[c,l,[w,u,y]],E,v,g,p,A,N,f,m)=>{const[S,T,C,$]=Ea(t,E,v,s,A,N,f,m),b=async(a,t)=>await d(oa(l,(async([e,n,s,r],o)=>{t&&!(o in a)||await C(e,n,a[o],s,r,t)}))),I=async(a,t)=>u?await C(y,U,{[F]:a},!0,!0,t):null,L=da(a,(async()=>await $((async()=>{await S();const a=await(async()=>O(h(await d(oa(c,(async([a,t],e)=>[a,await T(e,t)]))),(a=>!M(a[1])))))(),t=await(async()=>w?(await T(y,U))[F]:{})();return M(a)&&i(t)?void 0:[a,t]}))),(async(a,t)=>await $((async()=>{if(await S(),i(t)){const[t,e]=a();await b(t),await I(e)}else await b(t[0],!0),await I(t[1],!0)}))),e,n,s,o,{[p]:()=>g,destroy:()=>(L.stopAutoLoad().stopAutoSave(),r(),L)},0,g);return L},Aa="ColumnName",ha="store",Na="json",fa=ha+"TableName",ma=ha+"Id"+Aa,Sa=ha+Aa,Ta="autoLoadIntervalSeconds",Ca="rowId"+Aa,$a="tableId",Oa="tableName",ba="deleteEmptyColumns",Ia="deleteEmptyTable",La={mode:Na,[Ta]:1},Ra={load:0,save:0,[Oa]:t+"_values"},Da=(a,t,e,n,s)=>{const r=sa();return L(a,((a,o)=>{const c=u(R(b(t,l(a)?{[e]:a}:a)),0,D(t));i(c[0])||n(o,c[0])||(s(o,c[0]),ia(r,o,c))})),r},Ma=(a,n,s,r,i,c,w,y,d,E,v="getDb",g)=>{let p,A,h;const N=((a,t)=>t?async(e,n)=>(t(e,n),await a(e,n)):a)(s,c),[f,m,S,T]=(a=>{const e=(a=>b(La,l(a)?{[fa]:a}:a??{}))(a),n=e[Ta];if(e.mode==Na){const a=e[fa]??t;return[1,n,[a,e[ma]??U,e[Sa]??ha],_(a)]}const{tables:{load:s={},save:r={}}={},values:o={}}=e,i=u(R(b(Ra,o)),0,D(Ra)),c=i[2],w=_(c),y=_(c);return[0,n,[Da(s,{[$a]:null,[Ca]:U},$a,(a=>X(y,a)),(a=>P(w,a))),Da(r,{[Oa]:null,[Ca]:U,[ba]:0,[Ia]:0},Oa,((a,t)=>X(y,t)),((a,t)=>P(w,t))),i],w]})(n);return(f?ga:pa)(a,N,(a=>{let t;const e=()=>t=setInterval((async()=>{try{const[{d:t,s:e,c:n}]=await N(`${j} ${z} d,${G} s,TOTAL_CHANGES() c FROM ${k}${z} JOIN ${k}${G}`);t==p&&e==A&&n==h||(null!=p&&a(),p=t,A=e,h=n)}catch{}}),1e3*m),n=()=>{p=A=h=null,o(t)},s=r((t=>{T.has(t)&&(n(),a(),e())}));return e(),()=>{n(),i(s)}}),(a=>a()),w,y,d,S,Z(T),(async(a,t)=>await a(`${j} t.name tn,c.name cn FROM ${V}list()t,${V}info(t.name)c ${x} t.schema='main'AND t.type IN('table','view')AND t.name IN(${Q(t)})ORDER BY t.name,c.name`,t)),E,v,e,g,(a=>!0===a?1:!1===a?0:a),void 0)},_a=(a,t,e,n,s)=>{let r;return Ma(a,e,(async(a,e=[])=>t.execute(a,e).then((a=>a.rows?._array??[]))),(a=>{const e=new AbortController,n=t.onChange({rawTableNames:!0,signal:e.signal});return(async()=>{for await(const a of n)r&&p(a.changedTables,r)})(),r=a,e}),(a=>{r=void 0,a.abort()}),n,s,(()=>0),1,t,"getPowerSync",Pa)},Pa=async(a,t,e,s,r,o)=>{const i=[1],c=_(s),l=o?h([...o],(a=>a!=e&&!X(c,a))):[];if(!A(l)){const n=C(r),s=O(p(await a("SELECT"+K(e,...l)+"FROM"+W(t)+"WHERE"+W(e)+"IN("+Q(n)+")",n),(a=>[a[e],a])));v(n,(a=>N(r[a],...p(l,(t=>s?.[a]?.[t]??null)))))}await a("INSERT OR REPLACE INTO"+W(t)+"("+K(e,...s,...l)+")VALUES"+g(L(r,(a=>"($"+i[0]+++","+Q(a,i)+")")),n),L(r,((a,t)=>[t,...p(a,(a=>a??null))])).flat())};export{_a as createPowerSyncPersister};
@@ -1 +1 @@
1
- const t=clearInterval,e=t=>null==t,a=(t,a,n)=>e(t)?n?.():a(t),n=t=>Array.isArray(t),s=t=>t.length,r=t=>{throw Error(t)},o=(t,e)=>t.forEach(e),i=(t,...e)=>t.push(...e),c=t=>t.shift(),l=Object,d=t=>l.getPrototypeOf(t),y=l.keys,u=l.freeze,g=t=>(t=>!e(t)&&a(d(t),(t=>t==l.prototype||e(d(t))),(()=>!0)))(t)&&0==(t=>s(y(t)))(t),h=JSON.stringify,p=JSON.parse,v=t=>e(t)||0==(t=>t?.size??0)(t),w=(t,e)=>t?.forEach(e),f=(t,e)=>t?.delete(e),S=t=>new Map(t),C=(t,e)=>t?.get(e),A=(t,a,n)=>e(n)?(f(t,a),t):t?.set(a,n),b=(t,e,a,n)=>{var s,r;return s=t,r=e,s?.has(r)?n?.(C(t,e)):A(t,e,a()),C(t,e)},L=(t,e,n,r,o=0)=>a((n?b:C)(t,e[o],o>s(e)-2?n:S),(a=>{if(o>s(e)-2)return r?.(a)&&A(t,e[o]),a;const i=L(a,e,n,r,o+1);return v(a)&&A(t,e[o]),i})),M=t=>new Set(n(t)||e(t)?t:[t]),E=/^\d+$/,T=S(),O=S(),m=(t,l,d,y,h,p,m,D={},P=[])=>{let j,x,z,I=0,J=0,N=0;b(T,P,(()=>0)),b(O,P,(()=>[]));const k=S(),[F,H,U,$,q]=((t=1,e)=>1!=t&&e.isMergeable()?[1,e.getMergeableContent,e.getTransactionMergeableChanges,([[t],[e]])=>!g(t)||!g(e),e.setDefaultContent]:2!=t?[0,e.getContent,e.getTransactionChanges,([t,e])=>!g(t)||!g(e),e.setContent]:r("Store type not supported by this Persister"))(m,t),[B,G,K]=(()=>{let t;const[n,r]=(()=>{const t=[];let e=0;return[a=>(a?c(t):null)??""+e++,e=>{E.test(e)&&s(t)<1e3&&i(t,e)}]})(),l=S();return[(e,a,s,r=[],o=()=>[])=>{t??=_;const i=n(1);var c,d;return A(l,i,[e,a,s,r,o]),c=L(a,s??[""],M),d=i,c?.add(d),i},(e,a,...n)=>o(((t,e=[""])=>{const a=[],n=(t,r)=>r==s(e)?i(a,t):null===e[r]?w(t,(t=>n(t,r+1))):o([e[r],null],(e=>n(C(t,e),r+1)));return n(t,0),a})(e,a),(e=>w(e,(e=>C(l,e)[0](t,...a??[],...n))))),t=>a(C(l,t),(([,e,a])=>(L(e,a??[""],void 0,(e=>(f(e,t),v(e)?1:0))),A(l,t),r(t),a))),n=>a(C(l,n),(([a,,n=[],r,i])=>{const c=(...l)=>{const d=s(l);d==s(n)?a(t,...l,...i(l)):e(n[d])?o(r[d]?.(...l)??[],(t=>c(...l,t))):c(...l,n[d])};c()}))]})(),Q=t=>{t!=I&&(I=t,G(k,void 0,I))},R=e=>{(F&&n(e?.[0])?1===e?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===e?.[2]?t.applyChanges:t.setContent)(e)},V=async t=>(2!=I&&(Q(1),J++,await Z((async()=>{try{const e=await l();n(e)?R(e):t?q(t):r("Content is not an array "+e)}catch(e){p?.(e),t&&q(t)}Q(0)}))),_),W=()=>(x&&(h(x),x=void 0),_),X=async t=>(1!=I&&(Q(2),N++,await Z((async()=>{try{await d(H,t)}catch(t){p?.(t)}Q(0)}))),_),Y=()=>(a(z,t.delListener),z=void 0,_),Z=async(...t)=>(i(C(O,P),...t),await(async()=>{if(!C(T,P)){for(A(T,P,1);!e(j=c(C(O,P)));)try{await j()}catch(t){p?.(t)}A(T,P,0)}})(),_),_={load:V,startAutoLoad:async t=>{await W().load(t);try{x=await y((async(t,e)=>{e||t?2!=I&&(Q(1),J++,R(e??t),Q(0)):await V()}))}catch(t){p?.(t)}return _},stopAutoLoad:W,isAutoLoading:()=>!e(x),save:X,startAutoSave:async()=>(await Y().save(),z=t.addDidFinishTransactionListener((()=>{const t=U();$(t)&&X(t)})),_),stopAutoSave:Y,isAutoSaving:()=>!e(z),getStatus:()=>I,addStatusListener:t=>B(t,k),delListener:e=>(K(e),t),schedule:Z,getStore:()=>t,destroy:()=>(C(O,P).splice(0,void 0),W().stopAutoSave()),getStats:()=>({loads:J,saves:N}),...D};return u(_)},D=t=>t.headers.get("ETag"),P=(a,n,s,r=5,o)=>{let i;return m(a,(async()=>{const t=await fetch(n);return i=D(t),p(await t.text())}),(async t=>{return await fetch(s,{method:"POST",headers:{"Content-Type":"application/json"},body:(e=t(),h(e,((t,e)=>e instanceof Map?l.fromEntries([...e]):e)))});var e}),(t=>setInterval((async()=>{const a=await fetch(n,{method:"HEAD"}),s=D(a);e(i)||e(s)||s==i||(i=s,t())}),1e3*r)),(e=>t(e)),o,1,{getUrls:()=>[n,s]})};export{P as createRemotePersister};
1
+ const t=clearInterval,e=t=>null==t,a=(t,a,n)=>e(t)?n?.():a(t),n=t=>Array.isArray(t),s=t=>t.length,r=t=>{throw Error(t)},o=(t,e)=>t.forEach(e),i=(t,...e)=>t.push(...e),c=t=>t.shift(),l=Object,y=t=>l.getPrototypeOf(t),d=l.keys,u=l.freeze,g=t=>(t=>!e(t)&&a(y(t),(t=>t==l.prototype||e(y(t))),(()=>!0)))(t)&&0==(t=>s(d(t)))(t),h=JSON.stringify,p=JSON.parse,w=t=>e(t)||0==(t=>t?.size??0)(t),v=(t,e)=>t?.forEach(e),f=(t,e)=>t?.delete(e),S=t=>new Map(t),C=(t,e)=>t?.get(e),A=(t,a,n)=>e(n)?(f(t,a),t):t?.set(a,n),b=(t,e,a,n)=>{var s,r;return s=t,r=e,s?.has(r)?n?.(C(t,e)):A(t,e,a()),C(t,e)},L=(t,e,n,r,o=0)=>a((n?b:C)(t,e[o],o>s(e)-2?n:S),(a=>{if(o>s(e)-2)return r?.(a)&&A(t,e[o]),a;const i=L(a,e,n,r,o+1);return w(a)&&A(t,e[o]),i})),M=t=>new Set(n(t)||e(t)?t:[t]),E=/^\d+$/,T=S(),O=S(),m=(t,l,y,d,h,p,m,D={},P=0,j=[])=>{let x,z,I,J=0,N=0,k=0;b(T,j,(()=>0)),b(O,j,(()=>[]));const F=S(),[H,U,$,q,B]=((t=1,e,a)=>1!=t&&e.isMergeable()?[1,e.getMergeableContent,()=>e.getTransactionMergeableChanges(!a),([[t],[e]])=>!g(t)||!g(e),e.setDefaultContent]:2!=t?[0,e.getContent,e.getTransactionChanges,([t,e])=>!g(t)||!g(e),e.setContent]:r("Store type not supported by this Persister"))(m,t,P),[G,K,Q]=(()=>{let t;const[n,r]=(()=>{const t=[];let e=0;return[a=>(a?c(t):null)??""+e++,e=>{E.test(e)&&s(t)<1e3&&i(t,e)}]})(),l=S();return[(e,a,s,r=[],o=()=>[])=>{t??=tt;const i=n(1);var c,y;return A(l,i,[e,a,s,r,o]),c=L(a,s??[""],M),y=i,c?.add(y),i},(e,a,...n)=>o(((t,e=[""])=>{const a=[],n=(t,r)=>r==s(e)?i(a,t):null===e[r]?v(t,(t=>n(t,r+1))):o([e[r],null],(e=>n(C(t,e),r+1)));return n(t,0),a})(e,a),(e=>v(e,(e=>C(l,e)[0](t,...a??[],...n))))),t=>a(C(l,t),(([,e,a])=>(L(e,a??[""],void 0,(e=>(f(e,t),w(e)?1:0))),A(l,t),r(t),a))),n=>a(C(l,n),(([a,,n=[],r,i])=>{const c=(...l)=>{const y=s(l);y==s(n)?a(t,...l,...i(l)):e(n[y])?o(r[y]?.(...l)??[],(t=>c(...l,t))):c(...l,n[y])};c()}))]})(),R=t=>{t!=J&&(J=t,K(F,void 0,J))},V=e=>{(H&&n(e?.[0])?1===e?.[2]?t.applyMergeableChanges:t.setMergeableContent:1===e?.[2]?t.applyChanges:t.setContent)(e)},W=async t=>(2!=J&&(R(1),N++,await _((async()=>{try{const e=await l();n(e)?V(e):t?B(t):r("Content is not an array: "+e)}catch(e){p?.(e),t&&B(t)}R(0)}))),tt),X=()=>(z&&(h(z),z=void 0),tt),Y=async t=>(1!=J&&(R(2),k++,await _((async()=>{try{await y(U,t)}catch(t){p?.(t)}R(0)}))),tt),Z=()=>(I&&(t.delListener(I),I=void 0),tt),_=async(...t)=>(i(C(O,j),...t),await(async()=>{if(!C(T,j)){for(A(T,j,1);!e(x=c(C(O,j)));)try{await x()}catch(t){p?.(t)}A(T,j,0)}})(),tt),tt={load:W,startAutoLoad:async t=>{X(),await W(t);try{z=await d((async(t,e)=>{e||t?2!=J&&(R(1),N++,V(e??t),R(0)):await W()}))}catch(t){p?.(t)}return tt},stopAutoLoad:X,isAutoLoading:()=>!e(z),save:Y,startAutoSave:async()=>(Z(),await Y(),I=t.addDidFinishTransactionListener((()=>{const t=$();q(t)&&Y(t)})),tt),stopAutoSave:Z,isAutoSaving:()=>!e(I),getStatus:()=>J,addStatusListener:t=>G(t,F),delListener:e=>(Q(e),t),schedule:_,getStore:()=>t,destroy:()=>(C(O,j).splice(0,void 0),X().stopAutoSave()),getStats:()=>({loads:N,saves:k}),...D};return u(tt)},D=t=>t.headers.get("ETag"),P=(a,n,s,r=5,o)=>{let i;return m(a,(async()=>{const t=await fetch(n);return i=D(t),p(await t.text())}),(async t=>{return await fetch(s,{method:"POST",headers:{"Content-Type":"application/json"},body:(e=t(),h(e,((t,e)=>e instanceof Map?l.fromEntries([...e]):e)))});var e}),(t=>setInterval((async()=>{const a=await fetch(n,{method:"HEAD"}),s=D(a);e(i)||e(s)||s==i||(i=s,t())}),1e3*r)),(e=>t(e)),o,1,{getUrls:()=>[n,s]})};export{P as createRemotePersister};