tinybase 5.0.0-beta.1 → 5.0.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 (313) hide show
  1. package/lib/cjs/mergeable-store.cjs +1 -0
  2. package/lib/cjs/mergeable-store.cjs.gz +0 -0
  3. package/lib/cjs/persisters/persister-automerge.cjs +1 -1
  4. package/lib/cjs/persisters/persister-automerge.cjs.gz +0 -0
  5. package/lib/cjs/persisters/persister-browser.cjs +1 -1
  6. package/lib/cjs/persisters/persister-browser.cjs.gz +0 -0
  7. package/lib/cjs/persisters/persister-cr-sqlite-wasm.cjs +1 -1
  8. package/lib/cjs/persisters/persister-cr-sqlite-wasm.cjs.gz +0 -0
  9. package/lib/cjs/persisters/persister-electric-sql.cjs +1 -1
  10. package/lib/cjs/persisters/persister-electric-sql.cjs.gz +0 -0
  11. package/lib/cjs/persisters/persister-expo-sqlite-next.cjs +1 -1
  12. package/lib/cjs/persisters/persister-expo-sqlite-next.cjs.gz +0 -0
  13. package/lib/cjs/persisters/persister-expo-sqlite.cjs +1 -1
  14. package/lib/cjs/persisters/persister-expo-sqlite.cjs.gz +0 -0
  15. package/lib/cjs/persisters/persister-file.cjs +1 -1
  16. package/lib/cjs/persisters/persister-file.cjs.gz +0 -0
  17. package/lib/cjs/persisters/persister-indexed-db.cjs +1 -1
  18. package/lib/cjs/persisters/persister-indexed-db.cjs.gz +0 -0
  19. package/lib/cjs/persisters/persister-partykit-client.cjs +1 -1
  20. package/lib/cjs/persisters/persister-partykit-client.cjs.gz +0 -0
  21. package/lib/cjs/persisters/persister-partykit-server.cjs +1 -1
  22. package/lib/cjs/persisters/persister-partykit-server.cjs.gz +0 -0
  23. package/lib/cjs/persisters/persister-remote.cjs +1 -1
  24. package/lib/cjs/persisters/persister-remote.cjs.gz +0 -0
  25. package/lib/cjs/persisters/persister-sqlite-wasm.cjs +1 -1
  26. package/lib/cjs/persisters/persister-sqlite-wasm.cjs.gz +0 -0
  27. package/lib/cjs/persisters/persister-sqlite3.cjs +1 -1
  28. package/lib/cjs/persisters/persister-sqlite3.cjs.gz +0 -0
  29. package/lib/cjs/persisters/persister-yjs.cjs +1 -1
  30. package/lib/cjs/persisters/persister-yjs.cjs.gz +0 -0
  31. package/lib/cjs/persisters.cjs +1 -1
  32. package/lib/cjs/persisters.cjs.gz +0 -0
  33. package/lib/cjs/store.cjs +1 -1
  34. package/lib/cjs/store.cjs.gz +0 -0
  35. package/lib/cjs/tinybase.cjs +1 -1
  36. package/lib/cjs/tinybase.cjs.gz +0 -0
  37. package/lib/cjs/tools.cjs +1 -1
  38. package/lib/cjs/tools.cjs.gz +0 -0
  39. package/lib/cjs/ui-react-dom-debug.cjs +1 -1
  40. package/lib/cjs/ui-react-dom-debug.cjs.gz +0 -0
  41. package/lib/cjs/ui-react-dom.cjs +1 -1
  42. package/lib/cjs/ui-react-dom.cjs.gz +0 -0
  43. package/lib/cjs-es6/mergeable-store.cjs +1 -0
  44. package/lib/cjs-es6/mergeable-store.cjs.gz +0 -0
  45. package/lib/cjs-es6/persisters/persister-automerge.cjs +1 -1
  46. package/lib/cjs-es6/persisters/persister-automerge.cjs.gz +0 -0
  47. package/lib/cjs-es6/persisters/persister-browser.cjs +1 -1
  48. package/lib/cjs-es6/persisters/persister-browser.cjs.gz +0 -0
  49. package/lib/cjs-es6/persisters/persister-cr-sqlite-wasm.cjs +1 -1
  50. package/lib/cjs-es6/persisters/persister-cr-sqlite-wasm.cjs.gz +0 -0
  51. package/lib/cjs-es6/persisters/persister-electric-sql.cjs +1 -1
  52. package/lib/cjs-es6/persisters/persister-electric-sql.cjs.gz +0 -0
  53. package/lib/cjs-es6/persisters/persister-expo-sqlite-next.cjs +1 -1
  54. package/lib/cjs-es6/persisters/persister-expo-sqlite-next.cjs.gz +0 -0
  55. package/lib/cjs-es6/persisters/persister-expo-sqlite.cjs +1 -1
  56. package/lib/cjs-es6/persisters/persister-expo-sqlite.cjs.gz +0 -0
  57. package/lib/cjs-es6/persisters/persister-file.cjs +1 -1
  58. package/lib/cjs-es6/persisters/persister-file.cjs.gz +0 -0
  59. package/lib/cjs-es6/persisters/persister-indexed-db.cjs +1 -1
  60. package/lib/cjs-es6/persisters/persister-indexed-db.cjs.gz +0 -0
  61. package/lib/cjs-es6/persisters/persister-partykit-client.cjs +1 -1
  62. package/lib/cjs-es6/persisters/persister-partykit-client.cjs.gz +0 -0
  63. package/lib/cjs-es6/persisters/persister-partykit-server.cjs +1 -1
  64. package/lib/cjs-es6/persisters/persister-partykit-server.cjs.gz +0 -0
  65. package/lib/cjs-es6/persisters/persister-remote.cjs +1 -1
  66. package/lib/cjs-es6/persisters/persister-remote.cjs.gz +0 -0
  67. package/lib/cjs-es6/persisters/persister-sqlite-wasm.cjs +1 -1
  68. package/lib/cjs-es6/persisters/persister-sqlite-wasm.cjs.gz +0 -0
  69. package/lib/cjs-es6/persisters/persister-sqlite3.cjs +1 -1
  70. package/lib/cjs-es6/persisters/persister-sqlite3.cjs.gz +0 -0
  71. package/lib/cjs-es6/persisters/persister-yjs.cjs +1 -1
  72. package/lib/cjs-es6/persisters/persister-yjs.cjs.gz +0 -0
  73. package/lib/cjs-es6/persisters.cjs +1 -1
  74. package/lib/cjs-es6/persisters.cjs.gz +0 -0
  75. package/lib/cjs-es6/store.cjs +1 -1
  76. package/lib/cjs-es6/store.cjs.gz +0 -0
  77. package/lib/cjs-es6/tinybase.cjs +1 -1
  78. package/lib/cjs-es6/tinybase.cjs.gz +0 -0
  79. package/lib/cjs-es6/tools.cjs +1 -1
  80. package/lib/cjs-es6/tools.cjs.gz +0 -0
  81. package/lib/cjs-es6/ui-react-dom-debug.cjs +1 -1
  82. package/lib/cjs-es6/ui-react-dom-debug.cjs.gz +0 -0
  83. package/lib/cjs-es6/ui-react-dom.cjs +1 -1
  84. package/lib/cjs-es6/ui-react-dom.cjs.gz +0 -0
  85. package/lib/debug/mergeable-store.js +1863 -0
  86. package/lib/debug/persisters/persister-automerge.js +54 -53
  87. package/lib/debug/persisters/persister-browser.js +28 -18
  88. package/lib/debug/persisters/persister-cr-sqlite-wasm.js +80 -57
  89. package/lib/debug/persisters/persister-electric-sql.js +80 -57
  90. package/lib/debug/persisters/persister-expo-sqlite-next.js +80 -57
  91. package/lib/debug/persisters/persister-expo-sqlite.js +80 -57
  92. package/lib/debug/persisters/persister-file.js +27 -18
  93. package/lib/debug/persisters/persister-indexed-db.js +34 -23
  94. package/lib/debug/persisters/persister-partykit-client.js +26 -23
  95. package/lib/debug/persisters/persister-partykit-server.js +11 -21
  96. package/lib/debug/persisters/persister-remote.js +28 -18
  97. package/lib/debug/persisters/persister-sqlite-wasm.js +80 -57
  98. package/lib/debug/persisters/persister-sqlite3.js +80 -57
  99. package/lib/debug/persisters/persister-yjs.js +50 -48
  100. package/lib/debug/persisters.js +27 -18
  101. package/lib/debug/queries.js +2 -2
  102. package/lib/debug/store.js +63 -71
  103. package/lib/debug/tinybase.js +354 -90
  104. package/lib/debug/tools.js +13 -15
  105. package/lib/debug/ui-react-dom.js +115 -119
  106. package/lib/es6/mergeable-store.js +1 -0
  107. package/lib/es6/mergeable-store.js.gz +0 -0
  108. package/lib/es6/persisters/persister-automerge.js +1 -1
  109. package/lib/es6/persisters/persister-automerge.js.gz +0 -0
  110. package/lib/es6/persisters/persister-browser.js +1 -1
  111. package/lib/es6/persisters/persister-browser.js.gz +0 -0
  112. package/lib/es6/persisters/persister-cr-sqlite-wasm.js +1 -1
  113. package/lib/es6/persisters/persister-cr-sqlite-wasm.js.gz +0 -0
  114. package/lib/es6/persisters/persister-electric-sql.js +1 -1
  115. package/lib/es6/persisters/persister-electric-sql.js.gz +0 -0
  116. package/lib/es6/persisters/persister-expo-sqlite-next.js +1 -1
  117. package/lib/es6/persisters/persister-expo-sqlite-next.js.gz +0 -0
  118. package/lib/es6/persisters/persister-expo-sqlite.js +1 -1
  119. package/lib/es6/persisters/persister-expo-sqlite.js.gz +0 -0
  120. package/lib/es6/persisters/persister-file.js +1 -1
  121. package/lib/es6/persisters/persister-file.js.gz +0 -0
  122. package/lib/es6/persisters/persister-indexed-db.js +1 -1
  123. package/lib/es6/persisters/persister-indexed-db.js.gz +0 -0
  124. package/lib/es6/persisters/persister-partykit-client.js +1 -1
  125. package/lib/es6/persisters/persister-partykit-client.js.gz +0 -0
  126. package/lib/es6/persisters/persister-partykit-server.js +1 -1
  127. package/lib/es6/persisters/persister-partykit-server.js.gz +0 -0
  128. package/lib/es6/persisters/persister-remote.js +1 -1
  129. package/lib/es6/persisters/persister-remote.js.gz +0 -0
  130. package/lib/es6/persisters/persister-sqlite-wasm.js +1 -1
  131. package/lib/es6/persisters/persister-sqlite-wasm.js.gz +0 -0
  132. package/lib/es6/persisters/persister-sqlite3.js +1 -1
  133. package/lib/es6/persisters/persister-sqlite3.js.gz +0 -0
  134. package/lib/es6/persisters/persister-yjs.js +1 -1
  135. package/lib/es6/persisters/persister-yjs.js.gz +0 -0
  136. package/lib/es6/persisters.js +1 -1
  137. package/lib/es6/persisters.js.gz +0 -0
  138. package/lib/es6/store.js +1 -1
  139. package/lib/es6/store.js.gz +0 -0
  140. package/lib/es6/tinybase.js +1 -1
  141. package/lib/es6/tinybase.js.gz +0 -0
  142. package/lib/es6/tools.js +1 -1
  143. package/lib/es6/tools.js.gz +0 -0
  144. package/lib/es6/ui-react-dom-debug.js +1 -1
  145. package/lib/es6/ui-react-dom-debug.js.gz +0 -0
  146. package/lib/es6/ui-react-dom.js +1 -1
  147. package/lib/es6/ui-react-dom.js.gz +0 -0
  148. package/lib/mergeable-store.js +1 -0
  149. package/lib/mergeable-store.js.gz +0 -0
  150. package/lib/persisters/persister-automerge.js +1 -1
  151. package/lib/persisters/persister-automerge.js.gz +0 -0
  152. package/lib/persisters/persister-browser.js +1 -1
  153. package/lib/persisters/persister-browser.js.gz +0 -0
  154. package/lib/persisters/persister-cr-sqlite-wasm.js +1 -1
  155. package/lib/persisters/persister-cr-sqlite-wasm.js.gz +0 -0
  156. package/lib/persisters/persister-electric-sql.js +1 -1
  157. package/lib/persisters/persister-electric-sql.js.gz +0 -0
  158. package/lib/persisters/persister-expo-sqlite-next.js +1 -1
  159. package/lib/persisters/persister-expo-sqlite-next.js.gz +0 -0
  160. package/lib/persisters/persister-expo-sqlite.js +1 -1
  161. package/lib/persisters/persister-expo-sqlite.js.gz +0 -0
  162. package/lib/persisters/persister-file.js +1 -1
  163. package/lib/persisters/persister-file.js.gz +0 -0
  164. package/lib/persisters/persister-indexed-db.js +1 -1
  165. package/lib/persisters/persister-indexed-db.js.gz +0 -0
  166. package/lib/persisters/persister-partykit-client.js +1 -1
  167. package/lib/persisters/persister-partykit-client.js.gz +0 -0
  168. package/lib/persisters/persister-partykit-server.js +1 -1
  169. package/lib/persisters/persister-partykit-server.js.gz +0 -0
  170. package/lib/persisters/persister-remote.js +1 -1
  171. package/lib/persisters/persister-remote.js.gz +0 -0
  172. package/lib/persisters/persister-sqlite-wasm.js +1 -1
  173. package/lib/persisters/persister-sqlite-wasm.js.gz +0 -0
  174. package/lib/persisters/persister-sqlite3.js +1 -1
  175. package/lib/persisters/persister-sqlite3.js.gz +0 -0
  176. package/lib/persisters/persister-yjs.js +1 -1
  177. package/lib/persisters/persister-yjs.js.gz +0 -0
  178. package/lib/persisters.js +1 -1
  179. package/lib/persisters.js.gz +0 -0
  180. package/lib/store.js +1 -1
  181. package/lib/store.js.gz +0 -0
  182. package/lib/tinybase.js +1 -1
  183. package/lib/tinybase.js.gz +0 -0
  184. package/lib/tools.js +1 -1
  185. package/lib/tools.js.gz +0 -0
  186. package/lib/types/mergeable-store.d.ts +79 -0
  187. package/lib/types/persisters/persister-automerge.d.ts +8 -7
  188. package/lib/types/persisters/persister-browser.d.ts +2 -0
  189. package/lib/types/persisters/persister-cr-sqlite-wasm.d.ts +1 -0
  190. package/lib/types/persisters/persister-electric-sql.d.ts +1 -0
  191. package/lib/types/persisters/persister-expo-sqlite-next.d.ts +1 -0
  192. package/lib/types/persisters/persister-expo-sqlite.d.ts +1 -0
  193. package/lib/types/persisters/persister-file.d.ts +1 -0
  194. package/lib/types/persisters/persister-indexed-db.d.ts +1 -0
  195. package/lib/types/persisters/persister-partykit-client.d.ts +1 -0
  196. package/lib/types/persisters/persister-partykit-server.d.ts +12 -8
  197. package/lib/types/persisters/persister-remote.d.ts +1 -0
  198. package/lib/types/persisters/persister-sqlite-wasm.d.ts +1 -0
  199. package/lib/types/persisters/persister-sqlite3.d.ts +1 -0
  200. package/lib/types/persisters/persister-yjs.d.ts +1 -0
  201. package/lib/types/persisters.d.ts +50 -30
  202. package/lib/types/store.d.ts +241 -186
  203. package/lib/types/tinybase.d.ts +1 -0
  204. package/lib/types/tools.d.ts +2 -2
  205. package/lib/types/ui-react.d.ts +1 -0
  206. package/lib/types/with-schemas/internal/store.d.ts +4 -0
  207. package/lib/types/with-schemas/mergeable-store.d.ts +112 -0
  208. package/lib/types/with-schemas/persisters/persister-automerge.d.ts +8 -7
  209. package/lib/types/with-schemas/persisters/persister-browser.d.ts +2 -0
  210. package/lib/types/with-schemas/persisters/persister-cr-sqlite-wasm.d.ts +1 -0
  211. package/lib/types/with-schemas/persisters/persister-electric-sql.d.ts +1 -0
  212. package/lib/types/with-schemas/persisters/persister-expo-sqlite-next.d.ts +1 -0
  213. package/lib/types/with-schemas/persisters/persister-expo-sqlite.d.ts +1 -0
  214. package/lib/types/with-schemas/persisters/persister-file.d.ts +1 -0
  215. package/lib/types/with-schemas/persisters/persister-indexed-db.d.ts +1 -0
  216. package/lib/types/with-schemas/persisters/persister-partykit-client.d.ts +1 -0
  217. package/lib/types/with-schemas/persisters/persister-partykit-server.d.ts +15 -11
  218. package/lib/types/with-schemas/persisters/persister-remote.d.ts +1 -0
  219. package/lib/types/with-schemas/persisters/persister-sqlite-wasm.d.ts +1 -0
  220. package/lib/types/with-schemas/persisters/persister-sqlite3.d.ts +1 -0
  221. package/lib/types/with-schemas/persisters/persister-yjs.d.ts +1 -0
  222. package/lib/types/with-schemas/persisters.d.ts +81 -45
  223. package/lib/types/with-schemas/store.d.ts +364 -273
  224. package/lib/types/with-schemas/tinybase.d.ts +1 -0
  225. package/lib/types/with-schemas/tools.d.ts +2 -2
  226. package/lib/ui-react-dom.js +1 -1
  227. package/lib/ui-react-dom.js.gz +0 -0
  228. package/lib/umd/mergeable-store.js +1 -0
  229. package/lib/umd/mergeable-store.js.gz +0 -0
  230. package/lib/umd/persisters/persister-automerge.js +1 -1
  231. package/lib/umd/persisters/persister-automerge.js.gz +0 -0
  232. package/lib/umd/persisters/persister-browser.js +1 -1
  233. package/lib/umd/persisters/persister-browser.js.gz +0 -0
  234. package/lib/umd/persisters/persister-cr-sqlite-wasm.js +1 -1
  235. package/lib/umd/persisters/persister-cr-sqlite-wasm.js.gz +0 -0
  236. package/lib/umd/persisters/persister-electric-sql.js +1 -1
  237. package/lib/umd/persisters/persister-electric-sql.js.gz +0 -0
  238. package/lib/umd/persisters/persister-expo-sqlite-next.js +1 -1
  239. package/lib/umd/persisters/persister-expo-sqlite-next.js.gz +0 -0
  240. package/lib/umd/persisters/persister-expo-sqlite.js +1 -1
  241. package/lib/umd/persisters/persister-expo-sqlite.js.gz +0 -0
  242. package/lib/umd/persisters/persister-file.js +1 -1
  243. package/lib/umd/persisters/persister-file.js.gz +0 -0
  244. package/lib/umd/persisters/persister-indexed-db.js +1 -1
  245. package/lib/umd/persisters/persister-indexed-db.js.gz +0 -0
  246. package/lib/umd/persisters/persister-partykit-client.js +1 -1
  247. package/lib/umd/persisters/persister-partykit-client.js.gz +0 -0
  248. package/lib/umd/persisters/persister-partykit-server.js +1 -1
  249. package/lib/umd/persisters/persister-partykit-server.js.gz +0 -0
  250. package/lib/umd/persisters/persister-remote.js +1 -1
  251. package/lib/umd/persisters/persister-remote.js.gz +0 -0
  252. package/lib/umd/persisters/persister-sqlite-wasm.js +1 -1
  253. package/lib/umd/persisters/persister-sqlite-wasm.js.gz +0 -0
  254. package/lib/umd/persisters/persister-sqlite3.js +1 -1
  255. package/lib/umd/persisters/persister-sqlite3.js.gz +0 -0
  256. package/lib/umd/persisters/persister-yjs.js +1 -1
  257. package/lib/umd/persisters/persister-yjs.js.gz +0 -0
  258. package/lib/umd/persisters.js +1 -1
  259. package/lib/umd/persisters.js.gz +0 -0
  260. package/lib/umd/store.js +1 -1
  261. package/lib/umd/store.js.gz +0 -0
  262. package/lib/umd/tinybase.js +1 -1
  263. package/lib/umd/tinybase.js.gz +0 -0
  264. package/lib/umd/tools.js +1 -1
  265. package/lib/umd/tools.js.gz +0 -0
  266. package/lib/umd/ui-react-dom-debug.js +1 -1
  267. package/lib/umd/ui-react-dom-debug.js.gz +0 -0
  268. package/lib/umd/ui-react-dom.js +1 -1
  269. package/lib/umd/ui-react-dom.js.gz +0 -0
  270. package/lib/umd-es6/mergeable-store.js +1 -0
  271. package/lib/umd-es6/mergeable-store.js.gz +0 -0
  272. package/lib/umd-es6/persisters/persister-automerge.js +1 -1
  273. package/lib/umd-es6/persisters/persister-automerge.js.gz +0 -0
  274. package/lib/umd-es6/persisters/persister-browser.js +1 -1
  275. package/lib/umd-es6/persisters/persister-browser.js.gz +0 -0
  276. package/lib/umd-es6/persisters/persister-cr-sqlite-wasm.js +1 -1
  277. package/lib/umd-es6/persisters/persister-cr-sqlite-wasm.js.gz +0 -0
  278. package/lib/umd-es6/persisters/persister-electric-sql.js +1 -1
  279. package/lib/umd-es6/persisters/persister-electric-sql.js.gz +0 -0
  280. package/lib/umd-es6/persisters/persister-expo-sqlite-next.js +1 -1
  281. package/lib/umd-es6/persisters/persister-expo-sqlite-next.js.gz +0 -0
  282. package/lib/umd-es6/persisters/persister-expo-sqlite.js +1 -1
  283. package/lib/umd-es6/persisters/persister-expo-sqlite.js.gz +0 -0
  284. package/lib/umd-es6/persisters/persister-file.js +1 -1
  285. package/lib/umd-es6/persisters/persister-file.js.gz +0 -0
  286. package/lib/umd-es6/persisters/persister-indexed-db.js +1 -1
  287. package/lib/umd-es6/persisters/persister-indexed-db.js.gz +0 -0
  288. package/lib/umd-es6/persisters/persister-partykit-client.js +1 -1
  289. package/lib/umd-es6/persisters/persister-partykit-client.js.gz +0 -0
  290. package/lib/umd-es6/persisters/persister-partykit-server.js +1 -1
  291. package/lib/umd-es6/persisters/persister-partykit-server.js.gz +0 -0
  292. package/lib/umd-es6/persisters/persister-remote.js +1 -1
  293. package/lib/umd-es6/persisters/persister-remote.js.gz +0 -0
  294. package/lib/umd-es6/persisters/persister-sqlite-wasm.js +1 -1
  295. package/lib/umd-es6/persisters/persister-sqlite-wasm.js.gz +0 -0
  296. package/lib/umd-es6/persisters/persister-sqlite3.js +1 -1
  297. package/lib/umd-es6/persisters/persister-sqlite3.js.gz +0 -0
  298. package/lib/umd-es6/persisters/persister-yjs.js +1 -1
  299. package/lib/umd-es6/persisters/persister-yjs.js.gz +0 -0
  300. package/lib/umd-es6/persisters.js +1 -1
  301. package/lib/umd-es6/persisters.js.gz +0 -0
  302. package/lib/umd-es6/store.js +1 -1
  303. package/lib/umd-es6/store.js.gz +0 -0
  304. package/lib/umd-es6/tinybase.js +1 -1
  305. package/lib/umd-es6/tinybase.js.gz +0 -0
  306. package/lib/umd-es6/tools.js +1 -1
  307. package/lib/umd-es6/tools.js.gz +0 -0
  308. package/lib/umd-es6/ui-react-dom-debug.js +1 -1
  309. package/lib/umd-es6/ui-react-dom-debug.js.gz +0 -0
  310. package/lib/umd-es6/ui-react-dom.js +1 -1
  311. package/lib/umd-es6/ui-react-dom.js.gz +0 -0
  312. package/package.json +39 -35
  313. package/readme.md +2 -2
@@ -75,6 +75,7 @@ const createCustomPersister = (
75
75
  addPersisterListener,
76
76
  delPersisterListener,
77
77
  onIgnoredError,
78
+ supportsMergeableStore,
78
79
  [getThing, thing] = [],
79
80
  scheduleId = [],
80
81
  ) => {
@@ -87,6 +88,10 @@ const createCustomPersister = (
87
88
  let listeningHandle;
88
89
  mapEnsure(scheduleRunning, scheduleId, () => 0);
89
90
  mapEnsure(scheduleActions, scheduleId, () => []);
91
+ const getContent =
92
+ (supportsMergeableStore ? store.getMergeableContent : null) ??
93
+ store.getContent;
94
+ const getChanges = store.getTransactionChanges;
90
95
  const run = async () => {
91
96
  /* istanbul ignore else */
92
97
  if (!mapGet(scheduleRunning, scheduleId)) {
@@ -122,7 +127,10 @@ const createCustomPersister = (
122
127
  load: async (initialTables, initialValues) =>
123
128
  await loadLock(async () => {
124
129
  try {
125
- store.setContent(await getPersisted());
130
+ const content = await getPersisted();
131
+ (supportsMergeableStore && isString(content[0])
132
+ ? store.applyMergeableChanges
133
+ : store.setContent)(content);
126
134
  } catch {
127
135
  store.setContent([initialTables, initialValues]);
128
136
  }
@@ -132,16 +140,14 @@ const createCustomPersister = (
132
140
  await persister.load(initialTables, initialValues);
133
141
  listening = 1;
134
142
  listeningHandle = addPersisterListener(
135
- async (getContent, getTransactionChanges) => {
136
- if (getTransactionChanges) {
137
- const transactionChanges = getTransactionChanges();
138
- await loadLock(async () =>
139
- store.setTransactionChanges(transactionChanges),
140
- );
143
+ async (getContent2, getChanges2) => {
144
+ if (getChanges2) {
145
+ const changes = getChanges2();
146
+ await loadLock(async () => store.applyChanges(changes));
141
147
  } else {
142
148
  await loadLock(async () => {
143
149
  try {
144
- store.setContent(getContent?.() ?? (await getPersisted()));
150
+ store.setContent(getContent2?.() ?? (await getPersisted()));
145
151
  } catch (error) {
146
152
  onIgnoredError?.(error);
147
153
  }
@@ -159,7 +165,7 @@ const createCustomPersister = (
159
165
  }
160
166
  return persister;
161
167
  },
162
- save: async (getTransactionChanges) => {
168
+ save: async (getChanges2) => {
163
169
  /* istanbul ignore else */
164
170
  if (loadSave != 1) {
165
171
  loadSave = 2;
@@ -168,7 +174,7 @@ const createCustomPersister = (
168
174
  }
169
175
  await persister.schedule(async () => {
170
176
  try {
171
- await setPersisted(store.getContent, getTransactionChanges);
177
+ await setPersisted(getContent, getChanges2);
172
178
  } catch (error) {
173
179
  /* istanbul ignore next */
174
180
  onIgnoredError?.(error);
@@ -180,14 +186,12 @@ const createCustomPersister = (
180
186
  },
181
187
  startAutoSave: async () => {
182
188
  await persister.stopAutoSave().save();
183
- listenerId = store.addDidFinishTransactionListener(
184
- (_store, getTransactionChanges) => {
185
- const [tableChanges, valueChanges] = getTransactionChanges();
186
- if (!objIsEmpty(tableChanges) || !objIsEmpty(valueChanges)) {
187
- persister.save(() => [tableChanges, valueChanges]);
188
- }
189
- },
190
- );
189
+ listenerId = store.addDidFinishTransactionListener(() => {
190
+ const [tableChanges, valueChanges] = getChanges();
191
+ if (!objIsEmpty(tableChanges) || !objIsEmpty(valueChanges)) {
192
+ persister.save(() => [tableChanges, valueChanges]);
193
+ }
194
+ });
191
195
  return persister;
192
196
  },
193
197
  stopAutoSave: () => {
@@ -245,11 +249,9 @@ const createPartyKitPersister = (
245
249
  })
246
250
  ).json();
247
251
  const getPersisted = async () => await getOrSetStore();
248
- const setPersisted = async (getContent, getTransactionChanges) => {
249
- if (getTransactionChanges) {
250
- connection.send(
251
- construct(messagePrefix, SET_CHANGES, getTransactionChanges()),
252
- );
252
+ const setPersisted = async (getContent, getChanges) => {
253
+ if (getChanges) {
254
+ connection.send(construct(messagePrefix, SET_CHANGES, getChanges()));
253
255
  } else {
254
256
  await getOrSetStore(getContent());
255
257
  }
@@ -277,6 +279,7 @@ const createPartyKitPersister = (
277
279
  addPersisterListener,
278
280
  delPersisterListener,
279
281
  onIgnoredError,
282
+ false,
280
283
  ['getConnection', connection],
281
284
  );
282
285
  };
@@ -24,9 +24,8 @@ const arrayUnshift = (array, ...values) => array.unshift(...values);
24
24
  const object = Object;
25
25
  const objEntries = object.entries;
26
26
  const objNew = (entries = []) => object.fromEntries(entries);
27
- const objGet = (obj, id) => ifNotUndefined(obj, (obj2) => obj2[id]);
28
- const objHas = (obj, id) => !isUndefined(objGet(obj, id));
29
- const objMap = (obj, cb) =>
27
+ const objHas = (obj, id) => id in obj;
28
+ const objToArray = (obj, cb) =>
30
29
  arrayMap(objEntries(obj), ([id, value]) => cb(value, id));
31
30
  const objEnsure = (obj, id, getDefaultValue) => {
32
31
  if (!objHas(obj, id)) {
@@ -86,21 +85,12 @@ const loadStoreFromStorage = async (storage, storagePrefix = EMPTY_STRING) => {
86
85
  );
87
86
  return [tables, values];
88
87
  };
89
- const broadcastTransactionChanges = async (
90
- server,
91
- transactionChanges,
92
- without,
93
- ) =>
88
+ const broadcastChanges = async (server, changes, without) =>
94
89
  server.party.broadcast(
95
- construct(server.config.messagePrefix, SET_CHANGES, transactionChanges),
90
+ construct(server.config.messagePrefix, SET_CHANGES, changes),
96
91
  without,
97
92
  );
98
- const saveStore = async (
99
- that,
100
- transactionChanges,
101
- initialSave,
102
- requestOrConnection,
103
- ) => {
93
+ const saveStore = async (that, changes, initialSave, requestOrConnection) => {
104
94
  const storage = that.party.storage;
105
95
  const storagePrefix = that.config.storagePrefix;
106
96
  const keysToSet = {
@@ -109,7 +99,7 @@ const saveStore = async (
109
99
  const keysToDel = [];
110
100
  const keyPrefixesToDel = [];
111
101
  await promiseAll(
112
- objMap(transactionChanges[0], async (table, tableId) =>
102
+ objToArray(changes[0], async (table, tableId) =>
113
103
  isUndefined(table)
114
104
  ? !initialSave &&
115
105
  (await that.canDelTable(tableId, requestOrConnection)) &&
@@ -119,7 +109,7 @@ const saveStore = async (
119
109
  )
120
110
  : (await that.canSetTable(tableId, initialSave, requestOrConnection)) &&
121
111
  (await promiseAll(
122
- objMap(table, async (row, rowId) =>
112
+ objToArray(table, async (row, rowId) =>
123
113
  isUndefined(row)
124
114
  ? !initialSave &&
125
115
  (await that.canDelRow(tableId, rowId, requestOrConnection)) &&
@@ -134,7 +124,7 @@ const saveStore = async (
134
124
  requestOrConnection,
135
125
  )) &&
136
126
  (await promiseAll(
137
- objMap(row, async (cell, cellId) => {
127
+ objToArray(row, async (cell, cellId) => {
138
128
  const ids = [tableId, rowId, cellId];
139
129
  const key = constructStorageKey(storagePrefix, T, ...ids);
140
130
  isUndefined(cell)
@@ -158,7 +148,7 @@ const saveStore = async (
158
148
  ),
159
149
  );
160
150
  await promiseAll(
161
- objMap(transactionChanges[1], async (value, valueId) => {
151
+ objToArray(changes[1], async (value, valueId) => {
162
152
  const key = storagePrefix + V + valueId;
163
153
  isUndefined(value)
164
154
  ? !initialSave &&
@@ -239,7 +229,7 @@ class TinyBasePartyKitServer {
239
229
  (await hasStoreInStorage(this.party.storage, storagePrefix))
240
230
  ) {
241
231
  await saveStore(this, payload, false, connection);
242
- broadcastTransactionChanges(this, payload, [connection.id]);
232
+ broadcastChanges(this, payload, [connection.id]);
243
233
  }
244
234
  },
245
235
  );
@@ -286,7 +276,7 @@ class TinyBasePartyKitServer {
286
276
 
287
277
  export {
288
278
  TinyBasePartyKitServer,
289
- broadcastTransactionChanges,
279
+ broadcastChanges,
290
280
  hasStoreInStorage,
291
281
  loadStoreFromStorage,
292
282
  };
@@ -1,3 +1,7 @@
1
+ const getTypeOf = (thing) => typeof thing;
2
+ const EMPTY_STRING = '';
3
+ const STRING = getTypeOf(EMPTY_STRING);
4
+
1
5
  const startInterval = (callback, sec, immediate) => {
2
6
  immediate && callback();
3
7
  return setInterval(callback, sec * 1e3);
@@ -7,6 +11,7 @@ const isInstanceOf = (thing, cls) => thing instanceof cls;
7
11
  const isUndefined = (thing) => thing == void 0;
8
12
  const ifNotUndefined = (value, then, otherwise) =>
9
13
  isUndefined(value) ? otherwise?.() : then(value);
14
+ const isString = (thing) => getTypeOf(thing) == STRING;
10
15
  const size = (arrayOrString) => arrayOrString.length;
11
16
 
12
17
  const arrayPush = (array, ...values) => array.push(...values);
@@ -58,6 +63,7 @@ const createCustomPersister = (
58
63
  addPersisterListener,
59
64
  delPersisterListener,
60
65
  onIgnoredError,
66
+ supportsMergeableStore,
61
67
  [getThing, thing] = [],
62
68
  scheduleId = [],
63
69
  ) => {
@@ -70,6 +76,10 @@ const createCustomPersister = (
70
76
  let listeningHandle;
71
77
  mapEnsure(scheduleRunning, scheduleId, () => 0);
72
78
  mapEnsure(scheduleActions, scheduleId, () => []);
79
+ const getContent =
80
+ (supportsMergeableStore ? store.getMergeableContent : null) ??
81
+ store.getContent;
82
+ const getChanges = store.getTransactionChanges;
73
83
  const run = async () => {
74
84
  /* istanbul ignore else */
75
85
  if (!mapGet(scheduleRunning, scheduleId)) {
@@ -105,7 +115,10 @@ const createCustomPersister = (
105
115
  load: async (initialTables, initialValues) =>
106
116
  await loadLock(async () => {
107
117
  try {
108
- store.setContent(await getPersisted());
118
+ const content = await getPersisted();
119
+ (supportsMergeableStore && isString(content[0])
120
+ ? store.applyMergeableChanges
121
+ : store.setContent)(content);
109
122
  } catch {
110
123
  store.setContent([initialTables, initialValues]);
111
124
  }
@@ -115,16 +128,14 @@ const createCustomPersister = (
115
128
  await persister.load(initialTables, initialValues);
116
129
  listening = 1;
117
130
  listeningHandle = addPersisterListener(
118
- async (getContent, getTransactionChanges) => {
119
- if (getTransactionChanges) {
120
- const transactionChanges = getTransactionChanges();
121
- await loadLock(async () =>
122
- store.setTransactionChanges(transactionChanges),
123
- );
131
+ async (getContent2, getChanges2) => {
132
+ if (getChanges2) {
133
+ const changes = getChanges2();
134
+ await loadLock(async () => store.applyChanges(changes));
124
135
  } else {
125
136
  await loadLock(async () => {
126
137
  try {
127
- store.setContent(getContent?.() ?? (await getPersisted()));
138
+ store.setContent(getContent2?.() ?? (await getPersisted()));
128
139
  } catch (error) {
129
140
  onIgnoredError?.(error);
130
141
  }
@@ -142,7 +153,7 @@ const createCustomPersister = (
142
153
  }
143
154
  return persister;
144
155
  },
145
- save: async (getTransactionChanges) => {
156
+ save: async (getChanges2) => {
146
157
  /* istanbul ignore else */
147
158
  if (loadSave != 1) {
148
159
  loadSave = 2;
@@ -151,7 +162,7 @@ const createCustomPersister = (
151
162
  }
152
163
  await persister.schedule(async () => {
153
164
  try {
154
- await setPersisted(store.getContent, getTransactionChanges);
165
+ await setPersisted(getContent, getChanges2);
155
166
  } catch (error) {
156
167
  /* istanbul ignore next */
157
168
  onIgnoredError?.(error);
@@ -163,14 +174,12 @@ const createCustomPersister = (
163
174
  },
164
175
  startAutoSave: async () => {
165
176
  await persister.stopAutoSave().save();
166
- listenerId = store.addDidFinishTransactionListener(
167
- (_store, getTransactionChanges) => {
168
- const [tableChanges, valueChanges] = getTransactionChanges();
169
- if (!objIsEmpty(tableChanges) || !objIsEmpty(valueChanges)) {
170
- persister.save(() => [tableChanges, valueChanges]);
171
- }
172
- },
173
- );
177
+ listenerId = store.addDidFinishTransactionListener(() => {
178
+ const [tableChanges, valueChanges] = getChanges();
179
+ if (!objIsEmpty(tableChanges) || !objIsEmpty(valueChanges)) {
180
+ persister.save(() => [tableChanges, valueChanges]);
181
+ }
182
+ });
174
183
  return persister;
175
184
  },
176
185
  stopAutoSave: () => {
@@ -234,6 +243,7 @@ const createRemotePersister = (
234
243
  addPersisterListener,
235
244
  delPersisterListener,
236
245
  onIgnoredError,
246
+ false,
237
247
  ['getUrls', [loadUrl, saveUrl]],
238
248
  );
239
249
  };
@@ -55,13 +55,12 @@ const isObject = (obj) =>
55
55
  );
56
56
  const objNew = (entries = []) => object.fromEntries(entries);
57
57
  const objMerge = (...objs) => object.assign({}, ...objs);
58
- const objGet = (obj, id) => ifNotUndefined(obj, (obj2) => obj2[id]);
59
- const objHas = (obj, id) => !isUndefined(objGet(obj, id));
58
+ const objHas = (obj, id) => id in obj;
60
59
  const objDel = (obj, id) => {
61
60
  delete obj[id];
62
61
  return obj;
63
62
  };
64
- const objMap = (obj, cb) =>
63
+ const objToArray = (obj, cb) =>
65
64
  arrayMap(objEntries(obj), ([id, value]) => cb(value, id));
66
65
  const objValues = (obj) => object.values(obj);
67
66
  const objSize = (obj) => size(objIds(obj));
@@ -83,7 +82,7 @@ const mapEnsure = (map, key, getDefaultValue) => {
83
82
  return mapGet(map, key);
84
83
  };
85
84
  const mapMatch = (map, obj, set, del = mapSet) => {
86
- objMap(obj, (value, id) => set(map, id, value));
85
+ objToArray(obj, (value, id) => set(map, id, value));
87
86
  mapForEach(map, (id) => (objHas(obj, id) ? 0 : del(map, id)));
88
87
  return map;
89
88
  };
@@ -99,7 +98,12 @@ const setAdd = (set, value) => set?.add(value);
99
98
  const SELECT_STAR_FROM = SELECT + '*FROM';
100
99
  const FROM_PRAGMA_TABLE = 'FROM pragma_table_';
101
100
  const WHERE = 'WHERE';
102
- const getCommandFunctions = (cmd, managedTableNames, onIgnoredError) => {
101
+ const getCommandFunctions = (
102
+ cmd,
103
+ managedTableNames,
104
+ onIgnoredError,
105
+ useOnConflict,
106
+ ) => {
103
107
  const schemaMap = mapNew();
104
108
  const canSelect = (tableName, rowIdColumnName) =>
105
109
  !isUndefined(mapGet(mapGet(schemaMap, tableName), rowIdColumnName));
@@ -112,7 +116,7 @@ const getCommandFunctions = (cmd, managedTableNames, onIgnoredError) => {
112
116
  await cmd(
113
117
  'SELECT name ' +
114
118
  FROM_PRAGMA_TABLE +
115
- `list WHERE schema='main'AND type='table'AND name IN(` +
119
+ `list WHERE schema='main'AND(type='table'OR type='view')AND name IN(` +
116
120
  getPlaceholders(managedTableNames) +
117
121
  `)ORDER BY name`,
118
122
  managedTableNames,
@@ -167,16 +171,18 @@ const getCommandFunctions = (cmd, managedTableNames, onIgnoredError) => {
167
171
  const saveTable = async (
168
172
  tableName,
169
173
  rowIdColumnName,
170
- table,
174
+ content,
171
175
  deleteEmptyColumns,
172
176
  deleteEmptyTable,
173
177
  partial = false,
174
178
  ) => {
175
- const tableCellIds = setNew();
176
- objMap(table ?? {}, (row) =>
177
- arrayMap(objIds(row ?? {}), (cellId) => setAdd(tableCellIds, cellId)),
179
+ const tableCellOrValueIds = setNew();
180
+ objToArray(content ?? {}, (contentRow) =>
181
+ arrayMap(objIds(contentRow ?? {}), (cellOrValueId) =>
182
+ setAdd(tableCellOrValueIds, cellOrValueId),
183
+ ),
178
184
  );
179
- const tableColumnNames = collValues(tableCellIds);
185
+ const tableColumnNames = collValues(tableCellOrValueIds);
180
186
  if (
181
187
  !partial &&
182
188
  deleteEmptyTable &&
@@ -234,11 +240,11 @@ const getCommandFunctions = (cmd, managedTableNames, onIgnoredError) => {
234
240
  ]);
235
241
  }
236
242
  if (partial) {
237
- if (isUndefined(table)) {
243
+ if (isUndefined(content)) {
238
244
  await cmd('DELETE FROM' + escapeId(tableName) + 'WHERE 1');
239
245
  } else {
240
246
  await promiseAll(
241
- objMap(table, async (row, rowId) => {
247
+ objToArray(content, async (row, rowId) => {
242
248
  if (isUndefined(row)) {
243
249
  await cmd(
244
250
  'DELETE FROM' +
@@ -249,10 +255,14 @@ const getCommandFunctions = (cmd, managedTableNames, onIgnoredError) => {
249
255
  [rowId],
250
256
  );
251
257
  } else if (!arrayIsEmpty(tableColumnNames)) {
252
- await upsert(cmd, tableName, rowIdColumnName, objIds(row), [
253
- rowId,
254
- ...objValues(row),
255
- ]);
258
+ await upsert(
259
+ cmd,
260
+ tableName,
261
+ rowIdColumnName,
262
+ objIds(row),
263
+ [rowId, ...objValues(row)],
264
+ useOnConflict,
265
+ );
256
266
  }
257
267
  }),
258
268
  );
@@ -265,7 +275,7 @@ const getCommandFunctions = (cmd, managedTableNames, onIgnoredError) => {
265
275
  );
266
276
  const args = [];
267
277
  const deleteRowIds = [];
268
- objMap(table ?? {}, (row, rowId) => {
278
+ objToArray(content ?? {}, (row, rowId) => {
269
279
  arrayPush(
270
280
  args,
271
281
  rowId,
@@ -314,9 +324,12 @@ const upsert = async (
314
324
  rowIdColumnName,
315
325
  changingColumnNames,
316
326
  args,
327
+ useOnConflict = true,
317
328
  ) =>
318
329
  await cmd(
319
- 'INSERT INTO' +
330
+ 'INSERT ' +
331
+ (useOnConflict ? EMPTY_STRING : 'OR REPLACE ') +
332
+ 'INTO' +
320
333
  escapeId(tableName) +
321
334
  '(' +
322
335
  escapeId(rowIdColumnName) +
@@ -334,18 +347,20 @@ const upsert = async (
334
347
  ),
335
348
  1,
336
349
  ) +
337
- 'ON CONFLICT(' +
338
- escapeId(rowIdColumnName) +
339
- ')DO UPDATE SET' +
340
- arrayJoin(
341
- arrayMap(
342
- changingColumnNames,
343
- (columnName) =>
344
- escapeId(columnName) + '=excluded.' + escapeId(columnName),
345
- ),
346
- COMMA,
347
- ),
348
- args,
350
+ (useOnConflict
351
+ ? 'ON CONFLICT(' +
352
+ escapeId(rowIdColumnName) +
353
+ ')DO UPDATE SET' +
354
+ arrayJoin(
355
+ arrayMap(
356
+ changingColumnNames,
357
+ (columnName) =>
358
+ escapeId(columnName) + '=excluded.' + escapeId(columnName),
359
+ ),
360
+ COMMA,
361
+ )
362
+ : EMPTY_STRING),
363
+ arrayMap(args, (arg) => arg ?? null),
349
364
  );
350
365
  const getPlaceholders = (array) =>
351
366
  arrayJoin(
@@ -368,6 +383,7 @@ const createCustomPersister = (
368
383
  addPersisterListener,
369
384
  delPersisterListener,
370
385
  onIgnoredError,
386
+ supportsMergeableStore,
371
387
  [getThing, thing] = [],
372
388
  scheduleId = [],
373
389
  ) => {
@@ -380,6 +396,10 @@ const createCustomPersister = (
380
396
  let listeningHandle;
381
397
  mapEnsure(scheduleRunning, scheduleId, () => 0);
382
398
  mapEnsure(scheduleActions, scheduleId, () => []);
399
+ const getContent =
400
+ (supportsMergeableStore ? store.getMergeableContent : null) ??
401
+ store.getContent;
402
+ const getChanges = store.getTransactionChanges;
383
403
  const run = async () => {
384
404
  /* istanbul ignore else */
385
405
  if (!mapGet(scheduleRunning, scheduleId)) {
@@ -415,7 +435,10 @@ const createCustomPersister = (
415
435
  load: async (initialTables, initialValues) =>
416
436
  await loadLock(async () => {
417
437
  try {
418
- store.setContent(await getPersisted());
438
+ const content = await getPersisted();
439
+ (supportsMergeableStore && isString(content[0])
440
+ ? store.applyMergeableChanges
441
+ : store.setContent)(content);
419
442
  } catch {
420
443
  store.setContent([initialTables, initialValues]);
421
444
  }
@@ -425,16 +448,14 @@ const createCustomPersister = (
425
448
  await persister.load(initialTables, initialValues);
426
449
  listening = 1;
427
450
  listeningHandle = addPersisterListener(
428
- async (getContent, getTransactionChanges) => {
429
- if (getTransactionChanges) {
430
- const transactionChanges = getTransactionChanges();
431
- await loadLock(async () =>
432
- store.setTransactionChanges(transactionChanges),
433
- );
451
+ async (getContent2, getChanges2) => {
452
+ if (getChanges2) {
453
+ const changes = getChanges2();
454
+ await loadLock(async () => store.applyChanges(changes));
434
455
  } else {
435
456
  await loadLock(async () => {
436
457
  try {
437
- store.setContent(getContent?.() ?? (await getPersisted()));
458
+ store.setContent(getContent2?.() ?? (await getPersisted()));
438
459
  } catch (error) {
439
460
  onIgnoredError?.(error);
440
461
  }
@@ -452,7 +473,7 @@ const createCustomPersister = (
452
473
  }
453
474
  return persister;
454
475
  },
455
- save: async (getTransactionChanges) => {
476
+ save: async (getChanges2) => {
456
477
  /* istanbul ignore else */
457
478
  if (loadSave != 1) {
458
479
  loadSave = 2;
@@ -461,7 +482,7 @@ const createCustomPersister = (
461
482
  }
462
483
  await persister.schedule(async () => {
463
484
  try {
464
- await setPersisted(store.getContent, getTransactionChanges);
485
+ await setPersisted(getContent, getChanges2);
465
486
  } catch (error) {
466
487
  /* istanbul ignore next */
467
488
  onIgnoredError?.(error);
@@ -473,14 +494,12 @@ const createCustomPersister = (
473
494
  },
474
495
  startAutoSave: async () => {
475
496
  await persister.stopAutoSave().save();
476
- listenerId = store.addDidFinishTransactionListener(
477
- (_store, getTransactionChanges) => {
478
- const [tableChanges, valueChanges] = getTransactionChanges();
479
- if (!objIsEmpty(tableChanges) || !objIsEmpty(valueChanges)) {
480
- persister.save(() => [tableChanges, valueChanges]);
481
- }
482
- },
483
- );
497
+ listenerId = store.addDidFinishTransactionListener(() => {
498
+ const [tableChanges, valueChanges] = getChanges();
499
+ if (!objIsEmpty(tableChanges) || !objIsEmpty(valueChanges)) {
500
+ persister.save(() => [tableChanges, valueChanges]);
501
+ }
502
+ });
484
503
  return persister;
485
504
  },
486
505
  stopAutoSave: () => {
@@ -546,6 +565,7 @@ const createJsonSqlitePersister = (
546
565
  addPersisterListener,
547
566
  delPersisterListener,
548
567
  onIgnoredError,
568
+ false,
549
569
  [getThing, db],
550
570
  db,
551
571
  );
@@ -566,9 +586,10 @@ const createTabularSqlitePersister = (
566
586
  managedTableNames,
567
587
  db,
568
588
  getThing,
589
+ useOnConflict,
569
590
  ) => {
570
591
  const [refreshSchema, loadTable, saveTable, transaction] =
571
- getCommandFunctions(cmd, managedTableNames, onIgnoredError);
592
+ getCommandFunctions(cmd, managedTableNames, onIgnoredError, useOnConflict);
572
593
  const saveTables = async (tables, partial) =>
573
594
  await promiseAll(
574
595
  mapMap(
@@ -577,12 +598,11 @@ const createTabularSqlitePersister = (
577
598
  [tableName, rowIdColumnName, deleteEmptyColumns, deleteEmptyTable],
578
599
  tableId,
579
600
  ) => {
580
- const table = tables[tableId];
581
- if (!partial || table !== void 0) {
601
+ if (!partial || objHas(tables, tableId)) {
582
602
  await saveTable(
583
603
  tableName,
584
604
  rowIdColumnName,
585
- table,
605
+ tables[tableId],
586
606
  deleteEmptyColumns,
587
607
  deleteEmptyTable,
588
608
  partial,
@@ -632,11 +652,11 @@ const createTabularSqlitePersister = (
632
652
  ? [tables, values]
633
653
  : void 0;
634
654
  });
635
- const setPersisted = async (getContent, getTransactionChanges) =>
655
+ const setPersisted = async (getContent, getChanges) =>
636
656
  await transaction(async () => {
637
657
  await refreshSchema();
638
- if (!isUndefined(getTransactionChanges)) {
639
- const [tableChanges, valueChanges] = getTransactionChanges();
658
+ if (!isUndefined(getChanges)) {
659
+ const [tableChanges, valueChanges] = getChanges();
640
660
  await saveTables(tableChanges, true);
641
661
  await saveValues(valueChanges, true);
642
662
  } else {
@@ -652,6 +672,7 @@ const createTabularSqlitePersister = (
652
672
  addPersisterListener,
653
673
  delPersisterListener,
654
674
  onIgnoredError,
675
+ false,
655
676
  [getThing, db],
656
677
  db,
657
678
  );
@@ -689,7 +710,7 @@ const getDefaultedTabularConfigMap = (
689
710
  filter,
690
711
  ) => {
691
712
  const configMap = mapNew();
692
- objMap(configsObj, (configObj, id) => {
713
+ objToArray(configsObj, (configObj, id) => {
693
714
  const defaultedConfig = slice(
694
715
  objValues(
695
716
  objMerge(
@@ -764,6 +785,7 @@ const createSqlitePersister = (
764
785
  onIgnoredError,
765
786
  db,
766
787
  getThing = 'getDb',
788
+ useOnConflict,
767
789
  ) => {
768
790
  let dataVersion;
769
791
  let schemaVersion;
@@ -826,6 +848,7 @@ const createSqlitePersister = (
826
848
  collValues(managedTableNamesSet),
827
849
  db,
828
850
  getThing,
851
+ useOnConflict,
829
852
  );
830
853
  };
831
854