tinybase 5.0.0-beta.1 → 5.0.0-beta.11

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 (491) hide show
  1. package/lib/checkpoints.js +1 -1
  2. package/lib/checkpoints.js.gz +0 -0
  3. package/lib/cjs/checkpoints.cjs +1 -1
  4. package/lib/cjs/checkpoints.cjs.gz +0 -0
  5. package/lib/cjs/indexes.cjs +1 -1
  6. package/lib/cjs/indexes.cjs.gz +0 -0
  7. package/lib/cjs/mergeable-store.cjs +1 -0
  8. package/lib/cjs/mergeable-store.cjs.gz +0 -0
  9. package/lib/cjs/metrics.cjs +1 -1
  10. package/lib/cjs/metrics.cjs.gz +0 -0
  11. package/lib/cjs/persisters/persister-automerge.cjs +1 -1
  12. package/lib/cjs/persisters/persister-automerge.cjs.gz +0 -0
  13. package/lib/cjs/persisters/persister-browser.cjs +1 -1
  14. package/lib/cjs/persisters/persister-browser.cjs.gz +0 -0
  15. package/lib/cjs/persisters/persister-cr-sqlite-wasm.cjs +1 -1
  16. package/lib/cjs/persisters/persister-cr-sqlite-wasm.cjs.gz +0 -0
  17. package/lib/cjs/persisters/persister-electric-sql.cjs +1 -1
  18. package/lib/cjs/persisters/persister-electric-sql.cjs.gz +0 -0
  19. package/lib/cjs/persisters/persister-expo-sqlite-next.cjs +1 -1
  20. package/lib/cjs/persisters/persister-expo-sqlite-next.cjs.gz +0 -0
  21. package/lib/cjs/persisters/persister-expo-sqlite.cjs +1 -1
  22. package/lib/cjs/persisters/persister-expo-sqlite.cjs.gz +0 -0
  23. package/lib/cjs/persisters/persister-file.cjs +1 -1
  24. package/lib/cjs/persisters/persister-file.cjs.gz +0 -0
  25. package/lib/cjs/persisters/persister-indexed-db.cjs +1 -1
  26. package/lib/cjs/persisters/persister-indexed-db.cjs.gz +0 -0
  27. package/lib/cjs/persisters/persister-libsql.cjs +1 -0
  28. package/lib/cjs/persisters/persister-libsql.cjs.gz +0 -0
  29. package/lib/cjs/persisters/persister-partykit-client.cjs +1 -1
  30. package/lib/cjs/persisters/persister-partykit-client.cjs.gz +0 -0
  31. package/lib/cjs/persisters/persister-partykit-server.cjs +1 -1
  32. package/lib/cjs/persisters/persister-partykit-server.cjs.gz +0 -0
  33. package/lib/cjs/persisters/persister-powersync.cjs +1 -0
  34. package/lib/cjs/persisters/persister-powersync.cjs.gz +0 -0
  35. package/lib/cjs/persisters/persister-remote.cjs +1 -1
  36. package/lib/cjs/persisters/persister-remote.cjs.gz +0 -0
  37. package/lib/cjs/persisters/persister-sqlite-wasm.cjs +1 -1
  38. package/lib/cjs/persisters/persister-sqlite-wasm.cjs.gz +0 -0
  39. package/lib/cjs/persisters/persister-sqlite3.cjs +1 -1
  40. package/lib/cjs/persisters/persister-sqlite3.cjs.gz +0 -0
  41. package/lib/cjs/persisters/persister-yjs.cjs +1 -1
  42. package/lib/cjs/persisters/persister-yjs.cjs.gz +0 -0
  43. package/lib/cjs/persisters.cjs +1 -1
  44. package/lib/cjs/persisters.cjs.gz +0 -0
  45. package/lib/cjs/queries.cjs +1 -1
  46. package/lib/cjs/queries.cjs.gz +0 -0
  47. package/lib/cjs/relationships.cjs +1 -1
  48. package/lib/cjs/relationships.cjs.gz +0 -0
  49. package/lib/cjs/store.cjs +1 -1
  50. package/lib/cjs/store.cjs.gz +0 -0
  51. package/lib/cjs/synchronizers/synchronizer-local.cjs +1 -0
  52. package/lib/cjs/synchronizers/synchronizer-local.cjs.gz +0 -0
  53. package/lib/cjs/synchronizers/synchronizer-ws-client.cjs +1 -0
  54. package/lib/cjs/synchronizers/synchronizer-ws-client.cjs.gz +0 -0
  55. package/lib/cjs/synchronizers/synchronizer-ws-server.cjs +1 -0
  56. package/lib/cjs/synchronizers/synchronizer-ws-server.cjs.gz +0 -0
  57. package/lib/cjs/synchronizers.cjs +1 -0
  58. package/lib/cjs/synchronizers.cjs.gz +0 -0
  59. package/lib/cjs/tinybase.cjs +1 -1
  60. package/lib/cjs/tinybase.cjs.gz +0 -0
  61. package/lib/cjs/tools.cjs +1 -1
  62. package/lib/cjs/tools.cjs.gz +0 -0
  63. package/lib/cjs/ui-react-dom-debug.cjs +1 -1
  64. package/lib/cjs/ui-react-dom-debug.cjs.gz +0 -0
  65. package/lib/cjs/ui-react-dom.cjs +1 -1
  66. package/lib/cjs/ui-react-dom.cjs.gz +0 -0
  67. package/lib/cjs/ui-react.cjs +1 -1
  68. package/lib/cjs/ui-react.cjs.gz +0 -0
  69. package/lib/cjs-es6/checkpoints.cjs +1 -1
  70. package/lib/cjs-es6/checkpoints.cjs.gz +0 -0
  71. package/lib/cjs-es6/indexes.cjs +1 -1
  72. package/lib/cjs-es6/indexes.cjs.gz +0 -0
  73. package/lib/cjs-es6/mergeable-store.cjs +1 -0
  74. package/lib/cjs-es6/mergeable-store.cjs.gz +0 -0
  75. package/lib/cjs-es6/metrics.cjs +1 -1
  76. package/lib/cjs-es6/metrics.cjs.gz +0 -0
  77. package/lib/cjs-es6/persisters/persister-automerge.cjs +1 -1
  78. package/lib/cjs-es6/persisters/persister-automerge.cjs.gz +0 -0
  79. package/lib/cjs-es6/persisters/persister-browser.cjs +1 -1
  80. package/lib/cjs-es6/persisters/persister-browser.cjs.gz +0 -0
  81. package/lib/cjs-es6/persisters/persister-cr-sqlite-wasm.cjs +1 -1
  82. package/lib/cjs-es6/persisters/persister-cr-sqlite-wasm.cjs.gz +0 -0
  83. package/lib/cjs-es6/persisters/persister-electric-sql.cjs +1 -1
  84. package/lib/cjs-es6/persisters/persister-electric-sql.cjs.gz +0 -0
  85. package/lib/cjs-es6/persisters/persister-expo-sqlite-next.cjs +1 -1
  86. package/lib/cjs-es6/persisters/persister-expo-sqlite-next.cjs.gz +0 -0
  87. package/lib/cjs-es6/persisters/persister-expo-sqlite.cjs +1 -1
  88. package/lib/cjs-es6/persisters/persister-expo-sqlite.cjs.gz +0 -0
  89. package/lib/cjs-es6/persisters/persister-file.cjs +1 -1
  90. package/lib/cjs-es6/persisters/persister-file.cjs.gz +0 -0
  91. package/lib/cjs-es6/persisters/persister-indexed-db.cjs +1 -1
  92. package/lib/cjs-es6/persisters/persister-indexed-db.cjs.gz +0 -0
  93. package/lib/cjs-es6/persisters/persister-libsql.cjs +1 -0
  94. package/lib/cjs-es6/persisters/persister-libsql.cjs.gz +0 -0
  95. package/lib/cjs-es6/persisters/persister-partykit-client.cjs +1 -1
  96. package/lib/cjs-es6/persisters/persister-partykit-client.cjs.gz +0 -0
  97. package/lib/cjs-es6/persisters/persister-partykit-server.cjs +1 -1
  98. package/lib/cjs-es6/persisters/persister-partykit-server.cjs.gz +0 -0
  99. package/lib/cjs-es6/persisters/persister-powersync.cjs +1 -0
  100. package/lib/cjs-es6/persisters/persister-powersync.cjs.gz +0 -0
  101. package/lib/cjs-es6/persisters/persister-remote.cjs +1 -1
  102. package/lib/cjs-es6/persisters/persister-remote.cjs.gz +0 -0
  103. package/lib/cjs-es6/persisters/persister-sqlite-wasm.cjs +1 -1
  104. package/lib/cjs-es6/persisters/persister-sqlite-wasm.cjs.gz +0 -0
  105. package/lib/cjs-es6/persisters/persister-sqlite3.cjs +1 -1
  106. package/lib/cjs-es6/persisters/persister-sqlite3.cjs.gz +0 -0
  107. package/lib/cjs-es6/persisters/persister-yjs.cjs +1 -1
  108. package/lib/cjs-es6/persisters/persister-yjs.cjs.gz +0 -0
  109. package/lib/cjs-es6/persisters.cjs +1 -1
  110. package/lib/cjs-es6/persisters.cjs.gz +0 -0
  111. package/lib/cjs-es6/queries.cjs +1 -1
  112. package/lib/cjs-es6/queries.cjs.gz +0 -0
  113. package/lib/cjs-es6/relationships.cjs +1 -1
  114. package/lib/cjs-es6/relationships.cjs.gz +0 -0
  115. package/lib/cjs-es6/store.cjs +1 -1
  116. package/lib/cjs-es6/store.cjs.gz +0 -0
  117. package/lib/cjs-es6/synchronizers/synchronizer-local.cjs +1 -0
  118. package/lib/cjs-es6/synchronizers/synchronizer-local.cjs.gz +0 -0
  119. package/lib/cjs-es6/synchronizers/synchronizer-ws-client.cjs +1 -0
  120. package/lib/cjs-es6/synchronizers/synchronizer-ws-client.cjs.gz +0 -0
  121. package/lib/cjs-es6/synchronizers/synchronizer-ws-server.cjs +1 -0
  122. package/lib/cjs-es6/synchronizers/synchronizer-ws-server.cjs.gz +0 -0
  123. package/lib/cjs-es6/synchronizers.cjs +1 -0
  124. package/lib/cjs-es6/synchronizers.cjs.gz +0 -0
  125. package/lib/cjs-es6/tinybase.cjs +1 -1
  126. package/lib/cjs-es6/tinybase.cjs.gz +0 -0
  127. package/lib/cjs-es6/tools.cjs +1 -1
  128. package/lib/cjs-es6/tools.cjs.gz +0 -0
  129. package/lib/cjs-es6/ui-react-dom-debug.cjs +1 -1
  130. package/lib/cjs-es6/ui-react-dom-debug.cjs.gz +0 -0
  131. package/lib/cjs-es6/ui-react-dom.cjs +1 -1
  132. package/lib/cjs-es6/ui-react-dom.cjs.gz +0 -0
  133. package/lib/cjs-es6/ui-react.cjs +1 -1
  134. package/lib/cjs-es6/ui-react.cjs.gz +0 -0
  135. package/lib/debug/checkpoints.js +3 -1
  136. package/lib/debug/indexes.js +3 -1
  137. package/lib/debug/mergeable-store.js +2230 -0
  138. package/lib/debug/metrics.js +3 -1
  139. package/lib/debug/persisters/persister-automerge.js +167 -131
  140. package/lib/debug/persisters/persister-browser.js +155 -102
  141. package/lib/debug/persisters/persister-cr-sqlite-wasm.js +225 -152
  142. package/lib/debug/persisters/persister-electric-sql.js +225 -152
  143. package/lib/debug/persisters/persister-expo-sqlite-next.js +225 -152
  144. package/lib/debug/persisters/persister-expo-sqlite.js +225 -152
  145. package/lib/debug/persisters/persister-file.js +149 -101
  146. package/lib/debug/persisters/persister-indexed-db.js +146 -100
  147. package/lib/debug/persisters/persister-libsql.js +924 -0
  148. package/lib/debug/persisters/persister-partykit-client.js +146 -104
  149. package/lib/debug/persisters/persister-partykit-server.js +17 -25
  150. package/lib/debug/persisters/persister-powersync.js +939 -0
  151. package/lib/debug/persisters/persister-remote.js +141 -97
  152. package/lib/debug/persisters/persister-sqlite-wasm.js +225 -152
  153. package/lib/debug/persisters/persister-sqlite3.js +225 -152
  154. package/lib/debug/persisters/persister-yjs.js +164 -127
  155. package/lib/debug/persisters.js +137 -94
  156. package/lib/debug/queries.js +9 -6
  157. package/lib/debug/relationships.js +3 -1
  158. package/lib/debug/store.js +147 -126
  159. package/lib/debug/synchronizers/synchronizer-local.js +571 -0
  160. package/lib/debug/synchronizers/synchronizer-ws-client.js +598 -0
  161. package/lib/debug/synchronizers/synchronizer-ws-server.js +241 -0
  162. package/lib/debug/synchronizers.js +531 -0
  163. package/lib/debug/tinybase.js +1080 -215
  164. package/lib/debug/tools.js +22 -21
  165. package/lib/debug/ui-react-dom.js +336 -258
  166. package/lib/debug/ui-react.js +55 -6
  167. package/lib/es6/checkpoints.js +1 -1
  168. package/lib/es6/checkpoints.js.gz +0 -0
  169. package/lib/es6/indexes.js +1 -1
  170. package/lib/es6/indexes.js.gz +0 -0
  171. package/lib/es6/mergeable-store.js +1 -0
  172. package/lib/es6/mergeable-store.js.gz +0 -0
  173. package/lib/es6/metrics.js +1 -1
  174. package/lib/es6/metrics.js.gz +0 -0
  175. package/lib/es6/persisters/persister-automerge.js +1 -1
  176. package/lib/es6/persisters/persister-automerge.js.gz +0 -0
  177. package/lib/es6/persisters/persister-browser.js +1 -1
  178. package/lib/es6/persisters/persister-browser.js.gz +0 -0
  179. package/lib/es6/persisters/persister-cr-sqlite-wasm.js +1 -1
  180. package/lib/es6/persisters/persister-cr-sqlite-wasm.js.gz +0 -0
  181. package/lib/es6/persisters/persister-electric-sql.js +1 -1
  182. package/lib/es6/persisters/persister-electric-sql.js.gz +0 -0
  183. package/lib/es6/persisters/persister-expo-sqlite-next.js +1 -1
  184. package/lib/es6/persisters/persister-expo-sqlite-next.js.gz +0 -0
  185. package/lib/es6/persisters/persister-expo-sqlite.js +1 -1
  186. package/lib/es6/persisters/persister-expo-sqlite.js.gz +0 -0
  187. package/lib/es6/persisters/persister-file.js +1 -1
  188. package/lib/es6/persisters/persister-file.js.gz +0 -0
  189. package/lib/es6/persisters/persister-indexed-db.js +1 -1
  190. package/lib/es6/persisters/persister-indexed-db.js.gz +0 -0
  191. package/lib/es6/persisters/persister-libsql.js +1 -0
  192. package/lib/es6/persisters/persister-libsql.js.gz +0 -0
  193. package/lib/es6/persisters/persister-partykit-client.js +1 -1
  194. package/lib/es6/persisters/persister-partykit-client.js.gz +0 -0
  195. package/lib/es6/persisters/persister-partykit-server.js +1 -1
  196. package/lib/es6/persisters/persister-partykit-server.js.gz +0 -0
  197. package/lib/es6/persisters/persister-powersync.js +1 -0
  198. package/lib/es6/persisters/persister-powersync.js.gz +0 -0
  199. package/lib/es6/persisters/persister-remote.js +1 -1
  200. package/lib/es6/persisters/persister-remote.js.gz +0 -0
  201. package/lib/es6/persisters/persister-sqlite-wasm.js +1 -1
  202. package/lib/es6/persisters/persister-sqlite-wasm.js.gz +0 -0
  203. package/lib/es6/persisters/persister-sqlite3.js +1 -1
  204. package/lib/es6/persisters/persister-sqlite3.js.gz +0 -0
  205. package/lib/es6/persisters/persister-yjs.js +1 -1
  206. package/lib/es6/persisters/persister-yjs.js.gz +0 -0
  207. package/lib/es6/persisters.js +1 -1
  208. package/lib/es6/persisters.js.gz +0 -0
  209. package/lib/es6/queries.js +1 -1
  210. package/lib/es6/queries.js.gz +0 -0
  211. package/lib/es6/relationships.js +1 -1
  212. package/lib/es6/relationships.js.gz +0 -0
  213. package/lib/es6/store.js +1 -1
  214. package/lib/es6/store.js.gz +0 -0
  215. package/lib/es6/synchronizers/synchronizer-local.js +1 -0
  216. package/lib/es6/synchronizers/synchronizer-local.js.gz +0 -0
  217. package/lib/es6/synchronizers/synchronizer-ws-client.js +1 -0
  218. package/lib/es6/synchronizers/synchronizer-ws-client.js.gz +0 -0
  219. package/lib/es6/synchronizers/synchronizer-ws-server.js +1 -0
  220. package/lib/es6/synchronizers/synchronizer-ws-server.js.gz +0 -0
  221. package/lib/es6/synchronizers.js +1 -0
  222. package/lib/es6/synchronizers.js.gz +0 -0
  223. package/lib/es6/tinybase.js +1 -1
  224. package/lib/es6/tinybase.js.gz +0 -0
  225. package/lib/es6/tools.js +1 -1
  226. package/lib/es6/tools.js.gz +0 -0
  227. package/lib/es6/ui-react-dom-debug.js +1 -1
  228. package/lib/es6/ui-react-dom-debug.js.gz +0 -0
  229. package/lib/es6/ui-react-dom.js +1 -1
  230. package/lib/es6/ui-react-dom.js.gz +0 -0
  231. package/lib/es6/ui-react.js +1 -1
  232. package/lib/es6/ui-react.js.gz +0 -0
  233. package/lib/indexes.js +1 -1
  234. package/lib/indexes.js.gz +0 -0
  235. package/lib/mergeable-store.js +1 -0
  236. package/lib/mergeable-store.js.gz +0 -0
  237. package/lib/metrics.js +1 -1
  238. package/lib/metrics.js.gz +0 -0
  239. package/lib/persisters/persister-automerge.js +1 -1
  240. package/lib/persisters/persister-automerge.js.gz +0 -0
  241. package/lib/persisters/persister-browser.js +1 -1
  242. package/lib/persisters/persister-browser.js.gz +0 -0
  243. package/lib/persisters/persister-cr-sqlite-wasm.js +1 -1
  244. package/lib/persisters/persister-cr-sqlite-wasm.js.gz +0 -0
  245. package/lib/persisters/persister-electric-sql.js +1 -1
  246. package/lib/persisters/persister-electric-sql.js.gz +0 -0
  247. package/lib/persisters/persister-expo-sqlite-next.js +1 -1
  248. package/lib/persisters/persister-expo-sqlite-next.js.gz +0 -0
  249. package/lib/persisters/persister-expo-sqlite.js +1 -1
  250. package/lib/persisters/persister-expo-sqlite.js.gz +0 -0
  251. package/lib/persisters/persister-file.js +1 -1
  252. package/lib/persisters/persister-file.js.gz +0 -0
  253. package/lib/persisters/persister-indexed-db.js +1 -1
  254. package/lib/persisters/persister-indexed-db.js.gz +0 -0
  255. package/lib/persisters/persister-libsql.js +1 -0
  256. package/lib/persisters/persister-libsql.js.gz +0 -0
  257. package/lib/persisters/persister-partykit-client.js +1 -1
  258. package/lib/persisters/persister-partykit-client.js.gz +0 -0
  259. package/lib/persisters/persister-partykit-server.js +1 -1
  260. package/lib/persisters/persister-partykit-server.js.gz +0 -0
  261. package/lib/persisters/persister-powersync.js +1 -0
  262. package/lib/persisters/persister-powersync.js.gz +0 -0
  263. package/lib/persisters/persister-remote.js +1 -1
  264. package/lib/persisters/persister-remote.js.gz +0 -0
  265. package/lib/persisters/persister-sqlite-wasm.js +1 -1
  266. package/lib/persisters/persister-sqlite-wasm.js.gz +0 -0
  267. package/lib/persisters/persister-sqlite3.js +1 -1
  268. package/lib/persisters/persister-sqlite3.js.gz +0 -0
  269. package/lib/persisters/persister-yjs.js +1 -1
  270. package/lib/persisters/persister-yjs.js.gz +0 -0
  271. package/lib/persisters.js +1 -1
  272. package/lib/persisters.js.gz +0 -0
  273. package/lib/queries.js +1 -1
  274. package/lib/queries.js.gz +0 -0
  275. package/lib/relationships.js +1 -1
  276. package/lib/relationships.js.gz +0 -0
  277. package/lib/store.js +1 -1
  278. package/lib/store.js.gz +0 -0
  279. package/lib/synchronizers/synchronizer-local.js +1 -0
  280. package/lib/synchronizers/synchronizer-local.js.gz +0 -0
  281. package/lib/synchronizers/synchronizer-ws-client.js +1 -0
  282. package/lib/synchronizers/synchronizer-ws-client.js.gz +0 -0
  283. package/lib/synchronizers/synchronizer-ws-server.js +1 -0
  284. package/lib/synchronizers/synchronizer-ws-server.js.gz +0 -0
  285. package/lib/synchronizers.js +1 -0
  286. package/lib/synchronizers.js.gz +0 -0
  287. package/lib/tinybase.js +1 -1
  288. package/lib/tinybase.js.gz +0 -0
  289. package/lib/tools.js +1 -1
  290. package/lib/tools.js.gz +0 -0
  291. package/lib/types/checkpoints.d.ts +2 -2
  292. package/lib/types/indexes.d.ts +2 -2
  293. package/lib/types/mergeable-store.d.ts +214 -0
  294. package/lib/types/metrics.d.ts +2 -2
  295. package/lib/types/persisters/persister-automerge.d.ts +11 -7
  296. package/lib/types/persisters/persister-browser.d.ts +13 -4
  297. package/lib/types/persisters/persister-cr-sqlite-wasm.d.ts +4 -0
  298. package/lib/types/persisters/persister-electric-sql.d.ts +4 -0
  299. package/lib/types/persisters/persister-expo-sqlite-next.d.ts +4 -0
  300. package/lib/types/persisters/persister-expo-sqlite.d.ts +4 -0
  301. package/lib/types/persisters/persister-file.d.ts +7 -2
  302. package/lib/types/persisters/persister-indexed-db.d.ts +4 -0
  303. package/lib/types/persisters/persister-libsql.d.ts +142 -0
  304. package/lib/types/persisters/persister-partykit-client.d.ts +4 -0
  305. package/lib/types/persisters/persister-partykit-server.d.ts +12 -8
  306. package/lib/types/persisters/persister-powersync.d.ts +157 -0
  307. package/lib/types/persisters/persister-remote.d.ts +4 -0
  308. package/lib/types/persisters/persister-sqlite-wasm.d.ts +4 -0
  309. package/lib/types/persisters/persister-sqlite3.d.ts +4 -0
  310. package/lib/types/persisters/persister-yjs.d.ts +6 -2
  311. package/lib/types/persisters.d.ts +162 -59
  312. package/lib/types/queries.d.ts +2 -2
  313. package/lib/types/relationships.d.ts +2 -2
  314. package/lib/types/store.d.ts +275 -187
  315. package/lib/types/synchronizers/synchronizer-local.d.ts +27 -0
  316. package/lib/types/synchronizers/synchronizer-ws-client.d.ts +35 -0
  317. package/lib/types/synchronizers/synchronizer-ws-server.d.ts +57 -0
  318. package/lib/types/synchronizers.d.ts +132 -0
  319. package/lib/types/tinybase.d.ts +10 -8
  320. package/lib/types/tools.d.ts +4 -4
  321. package/lib/types/ui-react.d.ts +160 -9
  322. package/lib/types/with-schemas/checkpoints.d.ts +2 -2
  323. package/lib/types/with-schemas/indexes.d.ts +2 -2
  324. package/lib/types/with-schemas/internal/store.d.ts +4 -0
  325. package/lib/types/with-schemas/mergeable-store.d.ts +492 -0
  326. package/lib/types/with-schemas/metrics.d.ts +2 -2
  327. package/lib/types/with-schemas/persisters/persister-automerge.d.ts +12 -8
  328. package/lib/types/with-schemas/persisters/persister-browser.d.ts +17 -8
  329. package/lib/types/with-schemas/persisters/persister-cr-sqlite-wasm.d.ts +5 -1
  330. package/lib/types/with-schemas/persisters/persister-electric-sql.d.ts +5 -1
  331. package/lib/types/with-schemas/persisters/persister-expo-sqlite-next.d.ts +5 -1
  332. package/lib/types/with-schemas/persisters/persister-expo-sqlite.d.ts +5 -1
  333. package/lib/types/with-schemas/persisters/persister-file.d.ts +9 -4
  334. package/lib/types/with-schemas/persisters/persister-indexed-db.d.ts +5 -1
  335. package/lib/types/with-schemas/persisters/persister-libsql.d.ts +155 -0
  336. package/lib/types/with-schemas/persisters/persister-partykit-client.d.ts +5 -1
  337. package/lib/types/with-schemas/persisters/persister-partykit-server.d.ts +15 -11
  338. package/lib/types/with-schemas/persisters/persister-powersync.d.ts +170 -0
  339. package/lib/types/with-schemas/persisters/persister-remote.d.ts +5 -1
  340. package/lib/types/with-schemas/persisters/persister-sqlite-wasm.d.ts +5 -1
  341. package/lib/types/with-schemas/persisters/persister-sqlite3.d.ts +5 -1
  342. package/lib/types/with-schemas/persisters/persister-yjs.d.ts +7 -3
  343. package/lib/types/with-schemas/persisters.d.ts +193 -121
  344. package/lib/types/with-schemas/queries.d.ts +3 -3
  345. package/lib/types/with-schemas/relationships.d.ts +2 -2
  346. package/lib/types/with-schemas/store.d.ts +483 -345
  347. package/lib/types/with-schemas/synchronizers/synchronizer-local.d.ts +29 -0
  348. package/lib/types/with-schemas/synchronizers/synchronizer-ws-client.d.ts +41 -0
  349. package/lib/types/with-schemas/synchronizers/synchronizer-ws-server.d.ts +57 -0
  350. package/lib/types/with-schemas/synchronizers.d.ts +146 -0
  351. package/lib/types/with-schemas/tinybase.d.ts +9 -8
  352. package/lib/types/with-schemas/tools.d.ts +4 -4
  353. package/lib/types/with-schemas/ui-react.d.ts +177 -9
  354. package/lib/ui-react-dom.js +1 -1
  355. package/lib/ui-react-dom.js.gz +0 -0
  356. package/lib/ui-react.js +1 -1
  357. package/lib/ui-react.js.gz +0 -0
  358. package/lib/umd/checkpoints.js +1 -1
  359. package/lib/umd/checkpoints.js.gz +0 -0
  360. package/lib/umd/indexes.js +1 -1
  361. package/lib/umd/indexes.js.gz +0 -0
  362. package/lib/umd/mergeable-store.js +1 -0
  363. package/lib/umd/mergeable-store.js.gz +0 -0
  364. package/lib/umd/metrics.js +1 -1
  365. package/lib/umd/metrics.js.gz +0 -0
  366. package/lib/umd/persisters/persister-automerge.js +1 -1
  367. package/lib/umd/persisters/persister-automerge.js.gz +0 -0
  368. package/lib/umd/persisters/persister-browser.js +1 -1
  369. package/lib/umd/persisters/persister-browser.js.gz +0 -0
  370. package/lib/umd/persisters/persister-cr-sqlite-wasm.js +1 -1
  371. package/lib/umd/persisters/persister-cr-sqlite-wasm.js.gz +0 -0
  372. package/lib/umd/persisters/persister-electric-sql.js +1 -1
  373. package/lib/umd/persisters/persister-electric-sql.js.gz +0 -0
  374. package/lib/umd/persisters/persister-expo-sqlite-next.js +1 -1
  375. package/lib/umd/persisters/persister-expo-sqlite-next.js.gz +0 -0
  376. package/lib/umd/persisters/persister-expo-sqlite.js +1 -1
  377. package/lib/umd/persisters/persister-expo-sqlite.js.gz +0 -0
  378. package/lib/umd/persisters/persister-file.js +1 -1
  379. package/lib/umd/persisters/persister-file.js.gz +0 -0
  380. package/lib/umd/persisters/persister-indexed-db.js +1 -1
  381. package/lib/umd/persisters/persister-indexed-db.js.gz +0 -0
  382. package/lib/umd/persisters/persister-libsql.js +1 -0
  383. package/lib/umd/persisters/persister-libsql.js.gz +0 -0
  384. package/lib/umd/persisters/persister-partykit-client.js +1 -1
  385. package/lib/umd/persisters/persister-partykit-client.js.gz +0 -0
  386. package/lib/umd/persisters/persister-partykit-server.js +1 -1
  387. package/lib/umd/persisters/persister-partykit-server.js.gz +0 -0
  388. package/lib/umd/persisters/persister-powersync.js +1 -0
  389. package/lib/umd/persisters/persister-powersync.js.gz +0 -0
  390. package/lib/umd/persisters/persister-remote.js +1 -1
  391. package/lib/umd/persisters/persister-remote.js.gz +0 -0
  392. package/lib/umd/persisters/persister-sqlite-wasm.js +1 -1
  393. package/lib/umd/persisters/persister-sqlite-wasm.js.gz +0 -0
  394. package/lib/umd/persisters/persister-sqlite3.js +1 -1
  395. package/lib/umd/persisters/persister-sqlite3.js.gz +0 -0
  396. package/lib/umd/persisters/persister-yjs.js +1 -1
  397. package/lib/umd/persisters/persister-yjs.js.gz +0 -0
  398. package/lib/umd/persisters.js +1 -1
  399. package/lib/umd/persisters.js.gz +0 -0
  400. package/lib/umd/queries.js +1 -1
  401. package/lib/umd/queries.js.gz +0 -0
  402. package/lib/umd/relationships.js +1 -1
  403. package/lib/umd/relationships.js.gz +0 -0
  404. package/lib/umd/store.js +1 -1
  405. package/lib/umd/store.js.gz +0 -0
  406. package/lib/umd/synchronizers/synchronizer-local.js +1 -0
  407. package/lib/umd/synchronizers/synchronizer-local.js.gz +0 -0
  408. package/lib/umd/synchronizers/synchronizer-ws-client.js +1 -0
  409. package/lib/umd/synchronizers/synchronizer-ws-client.js.gz +0 -0
  410. package/lib/umd/synchronizers/synchronizer-ws-server.js +1 -0
  411. package/lib/umd/synchronizers/synchronizer-ws-server.js.gz +0 -0
  412. package/lib/umd/synchronizers.js +1 -0
  413. package/lib/umd/synchronizers.js.gz +0 -0
  414. package/lib/umd/tinybase.js +1 -1
  415. package/lib/umd/tinybase.js.gz +0 -0
  416. package/lib/umd/tools.js +1 -1
  417. package/lib/umd/tools.js.gz +0 -0
  418. package/lib/umd/ui-react-dom-debug.js +1 -1
  419. package/lib/umd/ui-react-dom-debug.js.gz +0 -0
  420. package/lib/umd/ui-react-dom.js +1 -1
  421. package/lib/umd/ui-react-dom.js.gz +0 -0
  422. package/lib/umd/ui-react.js +1 -1
  423. package/lib/umd/ui-react.js.gz +0 -0
  424. package/lib/umd-es6/checkpoints.js +1 -1
  425. package/lib/umd-es6/checkpoints.js.gz +0 -0
  426. package/lib/umd-es6/indexes.js +1 -1
  427. package/lib/umd-es6/indexes.js.gz +0 -0
  428. package/lib/umd-es6/mergeable-store.js +1 -0
  429. package/lib/umd-es6/mergeable-store.js.gz +0 -0
  430. package/lib/umd-es6/metrics.js +1 -1
  431. package/lib/umd-es6/metrics.js.gz +0 -0
  432. package/lib/umd-es6/persisters/persister-automerge.js +1 -1
  433. package/lib/umd-es6/persisters/persister-automerge.js.gz +0 -0
  434. package/lib/umd-es6/persisters/persister-browser.js +1 -1
  435. package/lib/umd-es6/persisters/persister-browser.js.gz +0 -0
  436. package/lib/umd-es6/persisters/persister-cr-sqlite-wasm.js +1 -1
  437. package/lib/umd-es6/persisters/persister-cr-sqlite-wasm.js.gz +0 -0
  438. package/lib/umd-es6/persisters/persister-electric-sql.js +1 -1
  439. package/lib/umd-es6/persisters/persister-electric-sql.js.gz +0 -0
  440. package/lib/umd-es6/persisters/persister-expo-sqlite-next.js +1 -1
  441. package/lib/umd-es6/persisters/persister-expo-sqlite-next.js.gz +0 -0
  442. package/lib/umd-es6/persisters/persister-expo-sqlite.js +1 -1
  443. package/lib/umd-es6/persisters/persister-expo-sqlite.js.gz +0 -0
  444. package/lib/umd-es6/persisters/persister-file.js +1 -1
  445. package/lib/umd-es6/persisters/persister-file.js.gz +0 -0
  446. package/lib/umd-es6/persisters/persister-indexed-db.js +1 -1
  447. package/lib/umd-es6/persisters/persister-indexed-db.js.gz +0 -0
  448. package/lib/umd-es6/persisters/persister-libsql.js +1 -0
  449. package/lib/umd-es6/persisters/persister-libsql.js.gz +0 -0
  450. package/lib/umd-es6/persisters/persister-partykit-client.js +1 -1
  451. package/lib/umd-es6/persisters/persister-partykit-client.js.gz +0 -0
  452. package/lib/umd-es6/persisters/persister-partykit-server.js +1 -1
  453. package/lib/umd-es6/persisters/persister-partykit-server.js.gz +0 -0
  454. package/lib/umd-es6/persisters/persister-powersync.js +1 -0
  455. package/lib/umd-es6/persisters/persister-powersync.js.gz +0 -0
  456. package/lib/umd-es6/persisters/persister-remote.js +1 -1
  457. package/lib/umd-es6/persisters/persister-remote.js.gz +0 -0
  458. package/lib/umd-es6/persisters/persister-sqlite-wasm.js +1 -1
  459. package/lib/umd-es6/persisters/persister-sqlite-wasm.js.gz +0 -0
  460. package/lib/umd-es6/persisters/persister-sqlite3.js +1 -1
  461. package/lib/umd-es6/persisters/persister-sqlite3.js.gz +0 -0
  462. package/lib/umd-es6/persisters/persister-yjs.js +1 -1
  463. package/lib/umd-es6/persisters/persister-yjs.js.gz +0 -0
  464. package/lib/umd-es6/persisters.js +1 -1
  465. package/lib/umd-es6/persisters.js.gz +0 -0
  466. package/lib/umd-es6/queries.js +1 -1
  467. package/lib/umd-es6/queries.js.gz +0 -0
  468. package/lib/umd-es6/relationships.js +1 -1
  469. package/lib/umd-es6/relationships.js.gz +0 -0
  470. package/lib/umd-es6/store.js +1 -1
  471. package/lib/umd-es6/store.js.gz +0 -0
  472. package/lib/umd-es6/synchronizers/synchronizer-local.js +1 -0
  473. package/lib/umd-es6/synchronizers/synchronizer-local.js.gz +0 -0
  474. package/lib/umd-es6/synchronizers/synchronizer-ws-client.js +1 -0
  475. package/lib/umd-es6/synchronizers/synchronizer-ws-client.js.gz +0 -0
  476. package/lib/umd-es6/synchronizers/synchronizer-ws-server.js +1 -0
  477. package/lib/umd-es6/synchronizers/synchronizer-ws-server.js.gz +0 -0
  478. package/lib/umd-es6/synchronizers.js +1 -0
  479. package/lib/umd-es6/synchronizers.js.gz +0 -0
  480. package/lib/umd-es6/tinybase.js +1 -1
  481. package/lib/umd-es6/tinybase.js.gz +0 -0
  482. package/lib/umd-es6/tools.js +1 -1
  483. package/lib/umd-es6/tools.js.gz +0 -0
  484. package/lib/umd-es6/ui-react-dom-debug.js +1 -1
  485. package/lib/umd-es6/ui-react-dom-debug.js.gz +0 -0
  486. package/lib/umd-es6/ui-react-dom.js +1 -1
  487. package/lib/umd-es6/ui-react-dom.js.gz +0 -0
  488. package/lib/umd-es6/ui-react.js +1 -1
  489. package/lib/umd-es6/ui-react.js.gz +0 -0
  490. package/package.json +65 -45
  491. package/readme.md +2 -2
@@ -22,6 +22,8 @@
22
22
  * |persister-expo-sqlite|createExpoSqlitePersister|SQLite in React Native, via [expo-sqlite](https://github.com/expo/expo/tree/main/packages/expo-sqlite)|
23
23
  * |persister-expo-sqlite-next|createExpoSqliteNextPersister|SQLite in React Native, via [expo-sqlite/next](https://github.com/expo/expo/tree/main/packages/expo-sqlite/next)|
24
24
  * |persister-electric-sql|createElectricSqlPersister|Electric SQL, via [electric-sql](https://github.com/electric-sql/electric)|
25
+ * |persister-libsql|createLibSqlPersister|LibSQL for Turso, via [libsql-client](https://github.com/tursodatabase/libsql-client-ts)|
26
+ * |persister-powersync|createPowerSyncPersister|PowerSync, via [powersync-sdk](https://github.com/powersync-ja/powersync-js)|
25
27
  * |persister-yjs|createYjsPersister|Yjs CRDTs, via [yjs](https://github.com/yjs/yjs)|
26
28
  * |persister-automerge|createSqliteWasmPersister|Automerge CRDTs, via [automerge-repo](https://github.com/automerge/automerge-repo)|
27
29
  *
@@ -38,8 +40,73 @@
38
40
  * @module persisters
39
41
  */
40
42
 
41
- import {GetTransactionChanges, Store, Tables, Values} from './store.d';
42
- import {Id} from './common.d';
43
+ import {Changes, Content, Store} from './store.d.ts';
44
+ import {
45
+ MergeableChanges,
46
+ MergeableContent,
47
+ MergeableStore,
48
+ } from './mergeable-store';
49
+ import {Id} from './common.d.ts';
50
+
51
+ /**
52
+ * The StoreTypes type
53
+ */
54
+ export type StoreTypes =
55
+ | 1 // Store only
56
+ | 2 // MergeableStore only
57
+ | 3; // Store and MergeableStore
58
+
59
+ /**
60
+ * The PersistedStore type
61
+ */
62
+ export type PersistedStore<StoreType extends StoreTypes = 1> =
63
+ StoreType extends 3
64
+ ? Store | MergeableStore
65
+ : StoreType extends 2
66
+ ? MergeableStore
67
+ : Store;
68
+
69
+ /**
70
+ * The PersistedContent type
71
+ */
72
+ export type PersistedContent<StoreType extends StoreTypes = 1> =
73
+ StoreType extends 3
74
+ ? Content | MergeableContent
75
+ : StoreType extends 2
76
+ ? MergeableContent
77
+ : Content;
78
+
79
+ /**
80
+ * The PersistedChanges type
81
+ */
82
+ export type PersistedChanges<StoreType extends StoreTypes = 1> =
83
+ StoreType extends 3
84
+ ? Changes | MergeableChanges
85
+ : StoreType extends 2
86
+ ? MergeableChanges
87
+ : Changes;
88
+
89
+ /**
90
+ * A PersisterListener is a callback that lets a Persister inform the Store that
91
+ * a change has happened to the underlying data.
92
+ *
93
+ * If the listener is called with the `changes` parameter, it will be used to
94
+ * make an incremental change to the Store. If not, but the `content` parameter
95
+ * is available, that will be used to make a wholesale change to the Store. If
96
+ * neither are present, the content will be loaded using the Persister's load
97
+ * method. Prior to v5.0, these parameters were callbacks.
98
+ * @param content If provided, this is a Content object from the the Persister
99
+ * that will be used to immediately wholesale update the Store.
100
+ * @param changes If provided, this is a Changes object from the the Persister
101
+ * that will be used to immediately incrementally update the Store. This takes
102
+ * priority over the content argument above if present.
103
+ * @category Creation
104
+ * @since v4.0.0
105
+ */
106
+ export type PersisterListener<StoreType extends StoreTypes = 1> = (
107
+ content?: PersistedContent<StoreType>,
108
+ changes?: PersistedChanges<StoreType>,
109
+ ) => void;
43
110
 
44
111
  /**
45
112
  * The PersisterStats type describes the number of times a Persister object has
@@ -60,28 +127,6 @@ export type PersisterStats = {
60
127
  saves?: number;
61
128
  };
62
129
 
63
- /**
64
- * A PersisterListener is a callback that lets a Persister inform the Store that
65
- * a change has happened to the underlying data.
66
- *
67
- * If the listener has the `getTransactionChanges` parameter, it will be used to
68
- * make an incremental change to the Store. If not, but the `getContent`
69
- * function _is_ available, that will be used to make a wholesale change to the
70
- * Store. If neither are present, the content will be loaded from the
71
- * Persister's load method.
72
- * @param getContent An optional function that, if provided, returns an array of
73
- * Store content and can be used to immediately wholesale update the Store.
74
- * @param getTransactionChanges An optional function that, if provided, returns
75
- * a TransactionChanges object and can be used to immediately incrementally
76
- * update the Store.
77
- * @category Creation
78
- * @since v4.0.0
79
- */
80
- export type PersisterListener = (
81
- getContent?: () => [Tables, Values],
82
- getTransactionChanges?: GetTransactionChanges,
83
- ) => void;
84
-
85
130
  /**
86
131
  * The DatabasePersisterConfig type describes the configuration of a
87
132
  * database-oriented Persister, such as those for SQLite.
@@ -548,9 +593,9 @@ export type DpcTabularValues = {
548
593
  *
549
594
  * Creating a Persister depends on the choice of underlying storage where the
550
595
  * data is to be stored. Options include the createSessionPersister function,
551
- * the createLocalPersister, the createRemotePersister function, and the
552
- * createFilePersister function. The createCustomPersister function can also be
553
- * used to easily create a fully customized way to save and load Store data.
596
+ * the createLocalPersister function, the createRemotePersister function, and
597
+ * the createFilePersister function. The createCustomPersister function can also
598
+ * be used to easily create a fully customized way to save and load Store data.
554
599
  *
555
600
  * A Persister lets you explicit save or load data, with the save method and the
556
601
  * load method respectively. These methods are both asynchronous (since the
@@ -619,7 +664,7 @@ export type DpcTabularValues = {
619
664
  * const store = createStore();
620
665
  * const persister = createSessionPersister(store, 'pets');
621
666
  *
622
- * await persister.startAutoLoad({pets: {fido: {species: 'dog'}}});
667
+ * await persister.startAutoLoad([{pets: {fido: {species: 'dog'}}}, {}]);
623
668
  * await persister.startAutoSave();
624
669
  *
625
670
  * store.setTables({pets: {felix: {species: 'cat'}}});
@@ -640,13 +685,13 @@ export type DpcTabularValues = {
640
685
  * ```
641
686
  * @category Persister
642
687
  */
643
- export interface Persister {
688
+ export interface Persister<StoreType extends StoreTypes = 1> {
644
689
  //
645
690
  /**
646
691
  * The load method gets persisted data from storage, and loads it into the
647
692
  * Store with which the Persister is associated, once.
648
693
  *
649
- * The optional parameters allow you to specify what the initial content for
694
+ * The optional parameter allows you to specify what the initial content for
650
695
  * the Store will be if there is nothing currently persisted or if the load
651
696
  * fails (for example when the Persister is remote and the environment is
652
697
  * offline). This allows you to fallback or instantiate a Store whether it's
@@ -656,10 +701,8 @@ export interface Persister {
656
701
  * machine or a filesystem. Even for those storage types that are synchronous
657
702
  * (like browser storage) it is still recommended that you `await` calls to
658
703
  * this method or handle the return type natively as a Promise.
659
- * @param initialTables An optional Tables object used when the underlying
704
+ * @param initialContent An optional Content object used when the underlying
660
705
  * storage has not previously been populated.
661
- * @param initialValues An optional Values object used when the underlying
662
- * storage has not previously been populated, since v3.0.
663
706
  * @returns A Promise containing a reference to the Persister object.
664
707
  * @example
665
708
  * This example creates an empty Store, and loads data into it from the
@@ -688,7 +731,7 @@ export interface Persister {
688
731
  * const store = createStore();
689
732
  * const persister = createSessionPersister(store, 'pets');
690
733
  *
691
- * await persister.load({pets: {fido: {species: 'dog'}}});
734
+ * await persister.load([{pets: {fido: {species: 'dog'}}}, {}]);
692
735
  * console.log(store.getTables());
693
736
  * // -> {pets: {fido: {species: 'dog'}}}
694
737
  *
@@ -701,14 +744,14 @@ export interface Persister {
701
744
  * ```
702
745
  * @category Load
703
746
  */
704
- load(initialTables?: Tables, initialValues?: Values): Promise<Persister>;
747
+ load(initialContent?: Content): Promise<this>;
705
748
 
706
749
  /**
707
750
  * The startAutoLoad method gets persisted data from storage, and loads it
708
751
  * into the Store with which the Persister is associated, once, and then
709
752
  * continuously.
710
753
  *
711
- * The optional parameters allow you to specify what the initial content for
754
+ * The optional parameter allows you to specify what the initial content for
712
755
  * the Store will be if there is nothing currently persisted or if the load
713
756
  * fails (for example when the Persister is remote and the environment is
714
757
  * offline). This allows you to fallback or instantiate a Store whether it's
@@ -723,10 +766,8 @@ export interface Persister {
723
766
  * the asynchronous load method. Even for those storage types that are
724
767
  * synchronous (like browser storage) it is still recommended that you `await`
725
768
  * calls to this method or handle the return type natively as a Promise.
726
- * @param initialTables An optional Tables object used when the underlying
769
+ * @param initialContent An optional Content object used when the underlying
727
770
  * storage has not previously been populated.
728
- * @param initialValues An optional Values object used when the underlying
729
- * storage has not previously been populated, since v3.0.
730
771
  * @returns A Promise containing a reference to the Persister object.
731
772
  * @example
732
773
  * This example creates an empty Store, and loads data into it from the
@@ -739,7 +780,7 @@ export interface Persister {
739
780
  * const store = createStore();
740
781
  * const persister = createSessionPersister(store, 'pets');
741
782
  *
742
- * await persister.startAutoLoad({pets: {fido: {species: 'dog'}}});
783
+ * await persister.startAutoLoad([{pets: {fido: {species: 'dog'}}}, {}]);
743
784
  * console.log(store.getTables());
744
785
  * // -> {pets: {fido: {species: 'dog'}}}
745
786
  *
@@ -756,10 +797,7 @@ export interface Persister {
756
797
  * ```
757
798
  * @category Load
758
799
  */
759
- startAutoLoad(
760
- initialTables?: Tables,
761
- initialValues?: Values,
762
- ): Promise<Persister>;
800
+ startAutoLoad(initialContent?: Content): Promise<this>;
763
801
 
764
802
  /**
765
803
  * The stopAutoLoad method stops the automatic loading of data from storage
@@ -803,7 +841,34 @@ export interface Persister {
803
841
  * ```
804
842
  * @category Load
805
843
  */
806
- stopAutoLoad(): Persister;
844
+ stopAutoLoad(): this;
845
+
846
+ /**
847
+ * The isAutoLoading method lets you find out if the Persister is currently
848
+ * automatically loading its content.
849
+ * @returns A boolean indicating whether the Persister is currently
850
+ * autoLoading.
851
+ * @example
852
+ * This example creates a Persister and queries whether it is autoLoading.
853
+ *
854
+ * ```js
855
+ * const persister = createSessionPersister(createStore(), 'pets');
856
+ *
857
+ * console.log(persister.isAutoLoading());
858
+ * // -> false
859
+ *
860
+ * await persister.startAutoLoad();
861
+ * console.log(persister.isAutoLoading());
862
+ * // -> true
863
+ *
864
+ * await persister.stopAutoLoad();
865
+ * console.log(persister.isAutoLoading());
866
+ * // -> false
867
+ * ```
868
+ * @category Load
869
+ * @since v5.0.0
870
+ */
871
+ isAutoLoading(): boolean;
807
872
 
808
873
  /**
809
874
  * The save method takes data from the Store with which the Persister is
@@ -831,7 +896,7 @@ export interface Persister {
831
896
  * ```
832
897
  * @category Save
833
898
  */
834
- save(): Promise<Persister>;
899
+ save(): Promise<this>;
835
900
 
836
901
  /**
837
902
  * The save method takes data from the Store with which the Persister is
@@ -868,7 +933,7 @@ export interface Persister {
868
933
  * ```
869
934
  * @category Save
870
935
  */
871
- startAutoSave(): Promise<Persister>;
936
+ startAutoSave(): Promise<this>;
872
937
 
873
938
  /**
874
939
  * The stopAutoSave method stops the automatic save of data to storage
@@ -905,7 +970,34 @@ export interface Persister {
905
970
  * ```
906
971
  * @category Save
907
972
  */
908
- stopAutoSave(): Persister;
973
+ stopAutoSave(): this;
974
+
975
+ /**
976
+ * The isAutoSaving method lets you find out if the Persister is currently
977
+ * automatically saving its content.
978
+ * @returns A boolean indicating whether the Persister is currently
979
+ * autoSaving.
980
+ * @example
981
+ * This example creates a Persister and queries whether it is autoSaving.
982
+ *
983
+ * ```js
984
+ * const persister = createSessionPersister(createStore(), 'pets');
985
+ *
986
+ * console.log(persister.isAutoSaving());
987
+ * // -> false
988
+ *
989
+ * await persister.startAutoSave();
990
+ * console.log(persister.isAutoSaving());
991
+ * // -> true
992
+ *
993
+ * await persister.stopAutoSave();
994
+ * console.log(persister.isAutoSaving());
995
+ * // -> false
996
+ * ```
997
+ * @category Save
998
+ * @since v5.0.0
999
+ */
1000
+ isAutoSaving(): boolean;
909
1001
 
910
1002
  /**
911
1003
  * The schedule method allows you to queue up a series of asynchronous actions
@@ -948,7 +1040,7 @@ export interface Persister {
948
1040
  * @category Lifecycle
949
1041
  * @since v4.0.0
950
1042
  */
951
- schedule(...actions: Promise<any>[]): Promise<Persister>;
1043
+ schedule(...actions: Promise<any>[]): Promise<this>;
952
1044
 
953
1045
  /**
954
1046
  * The getStore method returns a reference to the underlying Store that is
@@ -971,7 +1063,7 @@ export interface Persister {
971
1063
  * ```
972
1064
  * @category Getter
973
1065
  */
974
- getStore(): Store;
1066
+ getStore(): PersistedStore<StoreType>;
975
1067
 
976
1068
  /**
977
1069
  * The destroy method should be called when this Persister object is no longer
@@ -1001,7 +1093,7 @@ export interface Persister {
1001
1093
  * ```
1002
1094
  * @category Lifecycle
1003
1095
  */
1004
- destroy(): Persister;
1096
+ destroy(): this;
1005
1097
 
1006
1098
  /**
1007
1099
  * The getStats method provides a set of statistics about the Persister, and
@@ -1075,7 +1167,9 @@ export interface Persister {
1075
1167
  * the persistence layer (or `undefined` if not present).
1076
1168
  * @param setPersisted An asynchronous function which will send content to the
1077
1169
  * persistence layer. Since v4.0, it receives functions for getting the Store
1078
- * content and information about the changes made during a transaction.
1170
+ * content and information about the changes made during a transaction. Since
1171
+ * v5.0, the changes are received directly by reference, rather than an
1172
+ * accessor.
1079
1173
  * @param addPersisterListener A function that will register a `listener`
1080
1174
  * listener on underlying changes to the persistence layer. You can return a
1081
1175
  * listening handle that will be provided again when `delPersisterListener` is
@@ -1086,6 +1180,9 @@ export interface Persister {
1086
1180
  * @param onIgnoredError An optional handler for the errors that the Persister
1087
1181
  * would otherwise ignore when trying to save or load data. This is suitable for
1088
1182
  * debugging persistence issues in a development environment, since v4.0.4.
1183
+ * @param supportsMergeableStore An optional boolean to indicate that this
1184
+ * Persister will be able to handle MergeableStore persistence as well as
1185
+ * regular Store persistence, since v5.0.
1089
1186
  * @returns A reference to the new Persister object.
1090
1187
  * @example
1091
1188
  * This example creates a custom Persister object and persists the Store to a
@@ -1124,14 +1221,20 @@ export interface Persister {
1124
1221
  * ```
1125
1222
  * @category Creation
1126
1223
  */
1127
- export function createCustomPersister<ListeningHandle>(
1128
- store: Store,
1129
- getPersisted: () => Promise<[Tables, Values] | undefined>,
1224
+ export function createCustomPersister<
1225
+ ListeningHandle,
1226
+ StoreType extends StoreTypes = 1,
1227
+ >(
1228
+ store: PersistedStore<StoreType>,
1229
+ getPersisted: () => Promise<PersistedContent<StoreType> | undefined>,
1130
1230
  setPersisted: (
1131
- getContent: () => [Tables, Values],
1132
- getTransactionChanges?: GetTransactionChanges,
1231
+ getContent: () => PersistedContent<StoreType>,
1232
+ changes?: PersistedChanges<StoreType>,
1133
1233
  ) => Promise<void>,
1134
- addPersisterListener: (listener: PersisterListener) => ListeningHandle,
1234
+ addPersisterListener: (
1235
+ listener: PersisterListener<StoreType>,
1236
+ ) => ListeningHandle,
1135
1237
  delPersisterListener: (listeningHandle: ListeningHandle) => void,
1136
1238
  onIgnoredError?: (error: any) => void,
1137
- ): Persister;
1239
+ supportedStoreType?: StoreType,
1240
+ ): Persister<StoreType>;
@@ -11,8 +11,8 @@
11
11
  * @since v2.0.0
12
12
  */
13
13
 
14
- import {Cell, CellOrUndefined, GetCell, GetIdChanges, Store} from './store.d';
15
- import {Id, IdOrNull, Ids} from './common.d';
14
+ import {Cell, CellOrUndefined, GetCell, GetIdChanges, Store} from './store.d.ts';
15
+ import {Id, IdOrNull, Ids} from './common.d.ts';
16
16
 
17
17
  /**
18
18
  * The ResultTable type is the data structure representing the results of a
@@ -10,8 +10,8 @@
10
10
  * @module relationships
11
11
  */
12
12
 
13
- import {GetCell, RowCallback, Store} from './store.d';
14
- import {Id, IdOrNull, Ids} from './common.d';
13
+ import {GetCell, RowCallback, Store} from './store.d.ts';
14
+ import {Id, IdOrNull, Ids} from './common.d.ts';
15
15
 
16
16
  /**
17
17
  * The Relationship type represents the concept of a map that connects one Row