tinybase 8.0.0-beta.0 → 8.0.0-beta.1

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 (264) hide show
  1. package/@types/index.d.ts +1 -0
  2. package/@types/mergeable-store/with-schemas/index.d.ts +1 -1
  3. package/@types/middleware/index.d.ts +1064 -0
  4. package/@types/middleware/with-schemas/index.d.ts +1355 -0
  5. package/@types/omni/index.d.ts +1 -0
  6. package/@types/omni/with-schemas/index.d.ts +1 -0
  7. package/@types/store/index.d.ts +0 -1
  8. package/@types/with-schemas/index.d.ts +1 -0
  9. package/agents.md +33 -11
  10. package/checkpoints/index.js +20 -20
  11. package/checkpoints/with-schemas/index.js +20 -20
  12. package/common/index.js +3 -2
  13. package/common/with-schemas/index.js +3 -2
  14. package/index.js +574 -215
  15. package/indexes/index.js +13 -12
  16. package/indexes/with-schemas/index.js +13 -12
  17. package/mergeable-store/index.js +461 -197
  18. package/mergeable-store/with-schemas/index.js +461 -197
  19. package/metrics/index.js +13 -12
  20. package/metrics/with-schemas/index.js +13 -12
  21. package/middleware/index.js +130 -0
  22. package/middleware/with-schemas/index.js +130 -0
  23. package/min/checkpoints/index.js +1 -1
  24. package/min/checkpoints/index.js.gz +0 -0
  25. package/min/checkpoints/with-schemas/index.js +1 -1
  26. package/min/checkpoints/with-schemas/index.js.gz +0 -0
  27. package/min/common/index.js +1 -1
  28. package/min/common/index.js.gz +0 -0
  29. package/min/common/with-schemas/index.js +1 -1
  30. package/min/common/with-schemas/index.js.gz +0 -0
  31. package/min/index.js +1 -1
  32. package/min/index.js.gz +0 -0
  33. package/min/indexes/index.js +1 -1
  34. package/min/indexes/index.js.gz +0 -0
  35. package/min/indexes/with-schemas/index.js +1 -1
  36. package/min/indexes/with-schemas/index.js.gz +0 -0
  37. package/min/mergeable-store/index.js +1 -1
  38. package/min/mergeable-store/index.js.gz +0 -0
  39. package/min/mergeable-store/with-schemas/index.js +1 -1
  40. package/min/mergeable-store/with-schemas/index.js.gz +0 -0
  41. package/min/metrics/index.js +1 -1
  42. package/min/metrics/index.js.gz +0 -0
  43. package/min/metrics/with-schemas/index.js +1 -1
  44. package/min/metrics/with-schemas/index.js.gz +0 -0
  45. package/min/middleware/index.js +1 -0
  46. package/min/middleware/index.js.gz +0 -0
  47. package/min/middleware/with-schemas/index.js +1 -0
  48. package/min/middleware/with-schemas/index.js.gz +0 -0
  49. package/min/omni/index.js +1 -1
  50. package/min/omni/index.js.gz +0 -0
  51. package/min/omni/with-schemas/index.js +1 -1
  52. package/min/omni/with-schemas/index.js.gz +0 -0
  53. package/min/persisters/index.js +1 -1
  54. package/min/persisters/index.js.gz +0 -0
  55. package/min/persisters/persister-automerge/index.js +1 -1
  56. package/min/persisters/persister-automerge/index.js.gz +0 -0
  57. package/min/persisters/persister-automerge/with-schemas/index.js +1 -1
  58. package/min/persisters/persister-automerge/with-schemas/index.js.gz +0 -0
  59. package/min/persisters/persister-browser/index.js +1 -1
  60. package/min/persisters/persister-browser/index.js.gz +0 -0
  61. package/min/persisters/persister-browser/with-schemas/index.js +1 -1
  62. package/min/persisters/persister-browser/with-schemas/index.js.gz +0 -0
  63. package/min/persisters/persister-cr-sqlite-wasm/index.js +1 -1
  64. package/min/persisters/persister-cr-sqlite-wasm/index.js.gz +0 -0
  65. package/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.js +1 -1
  66. package/min/persisters/persister-cr-sqlite-wasm/with-schemas/index.js.gz +0 -0
  67. package/min/persisters/persister-durable-object-sql-storage/index.js +1 -1
  68. package/min/persisters/persister-durable-object-sql-storage/index.js.gz +0 -0
  69. package/min/persisters/persister-durable-object-sql-storage/with-schemas/index.js +1 -1
  70. package/min/persisters/persister-durable-object-sql-storage/with-schemas/index.js.gz +0 -0
  71. package/min/persisters/persister-durable-object-storage/index.js +1 -1
  72. package/min/persisters/persister-durable-object-storage/index.js.gz +0 -0
  73. package/min/persisters/persister-durable-object-storage/with-schemas/index.js +1 -1
  74. package/min/persisters/persister-durable-object-storage/with-schemas/index.js.gz +0 -0
  75. package/min/persisters/persister-electric-sql/index.js +1 -1
  76. package/min/persisters/persister-electric-sql/index.js.gz +0 -0
  77. package/min/persisters/persister-electric-sql/with-schemas/index.js +1 -1
  78. package/min/persisters/persister-electric-sql/with-schemas/index.js.gz +0 -0
  79. package/min/persisters/persister-expo-sqlite/index.js +1 -1
  80. package/min/persisters/persister-expo-sqlite/index.js.gz +0 -0
  81. package/min/persisters/persister-expo-sqlite/with-schemas/index.js +1 -1
  82. package/min/persisters/persister-expo-sqlite/with-schemas/index.js.gz +0 -0
  83. package/min/persisters/persister-file/index.js +1 -1
  84. package/min/persisters/persister-file/index.js.gz +0 -0
  85. package/min/persisters/persister-file/with-schemas/index.js +1 -1
  86. package/min/persisters/persister-file/with-schemas/index.js.gz +0 -0
  87. package/min/persisters/persister-indexed-db/index.js +1 -1
  88. package/min/persisters/persister-indexed-db/index.js.gz +0 -0
  89. package/min/persisters/persister-indexed-db/with-schemas/index.js +1 -1
  90. package/min/persisters/persister-indexed-db/with-schemas/index.js.gz +0 -0
  91. package/min/persisters/persister-libsql/index.js +1 -1
  92. package/min/persisters/persister-libsql/index.js.gz +0 -0
  93. package/min/persisters/persister-libsql/with-schemas/index.js +1 -1
  94. package/min/persisters/persister-libsql/with-schemas/index.js.gz +0 -0
  95. package/min/persisters/persister-partykit-client/index.js +1 -1
  96. package/min/persisters/persister-partykit-client/index.js.gz +0 -0
  97. package/min/persisters/persister-partykit-client/with-schemas/index.js +1 -1
  98. package/min/persisters/persister-partykit-client/with-schemas/index.js.gz +0 -0
  99. package/min/persisters/persister-partykit-server/index.js +1 -1
  100. package/min/persisters/persister-partykit-server/index.js.gz +0 -0
  101. package/min/persisters/persister-partykit-server/with-schemas/index.js +1 -1
  102. package/min/persisters/persister-partykit-server/with-schemas/index.js.gz +0 -0
  103. package/min/persisters/persister-pglite/index.js +1 -1
  104. package/min/persisters/persister-pglite/index.js.gz +0 -0
  105. package/min/persisters/persister-pglite/with-schemas/index.js +1 -1
  106. package/min/persisters/persister-pglite/with-schemas/index.js.gz +0 -0
  107. package/min/persisters/persister-postgres/index.js +1 -1
  108. package/min/persisters/persister-postgres/index.js.gz +0 -0
  109. package/min/persisters/persister-postgres/with-schemas/index.js +1 -1
  110. package/min/persisters/persister-postgres/with-schemas/index.js.gz +0 -0
  111. package/min/persisters/persister-powersync/index.js +1 -1
  112. package/min/persisters/persister-powersync/index.js.gz +0 -0
  113. package/min/persisters/persister-powersync/with-schemas/index.js +1 -1
  114. package/min/persisters/persister-powersync/with-schemas/index.js.gz +0 -0
  115. package/min/persisters/persister-react-native-mmkv/index.js +1 -1
  116. package/min/persisters/persister-react-native-mmkv/index.js.gz +0 -0
  117. package/min/persisters/persister-react-native-mmkv/with-schemas/index.js +1 -1
  118. package/min/persisters/persister-react-native-mmkv/with-schemas/index.js.gz +0 -0
  119. package/min/persisters/persister-react-native-sqlite/index.js +1 -1
  120. package/min/persisters/persister-react-native-sqlite/index.js.gz +0 -0
  121. package/min/persisters/persister-react-native-sqlite/with-schemas/index.js +1 -1
  122. package/min/persisters/persister-react-native-sqlite/with-schemas/index.js.gz +0 -0
  123. package/min/persisters/persister-remote/index.js +1 -1
  124. package/min/persisters/persister-remote/index.js.gz +0 -0
  125. package/min/persisters/persister-remote/with-schemas/index.js +1 -1
  126. package/min/persisters/persister-remote/with-schemas/index.js.gz +0 -0
  127. package/min/persisters/persister-sqlite-bun/index.js +1 -1
  128. package/min/persisters/persister-sqlite-bun/index.js.gz +0 -0
  129. package/min/persisters/persister-sqlite-bun/with-schemas/index.js +1 -1
  130. package/min/persisters/persister-sqlite-bun/with-schemas/index.js.gz +0 -0
  131. package/min/persisters/persister-sqlite-wasm/index.js +1 -1
  132. package/min/persisters/persister-sqlite-wasm/index.js.gz +0 -0
  133. package/min/persisters/persister-sqlite-wasm/with-schemas/index.js +1 -1
  134. package/min/persisters/persister-sqlite-wasm/with-schemas/index.js.gz +0 -0
  135. package/min/persisters/persister-sqlite3/index.js +1 -1
  136. package/min/persisters/persister-sqlite3/index.js.gz +0 -0
  137. package/min/persisters/persister-sqlite3/with-schemas/index.js +1 -1
  138. package/min/persisters/persister-sqlite3/with-schemas/index.js.gz +0 -0
  139. package/min/persisters/persister-yjs/index.js +1 -1
  140. package/min/persisters/persister-yjs/index.js.gz +0 -0
  141. package/min/persisters/persister-yjs/with-schemas/index.js +1 -1
  142. package/min/persisters/persister-yjs/with-schemas/index.js.gz +0 -0
  143. package/min/persisters/with-schemas/index.js +1 -1
  144. package/min/persisters/with-schemas/index.js.gz +0 -0
  145. package/min/queries/index.js +1 -1
  146. package/min/queries/index.js.gz +0 -0
  147. package/min/queries/with-schemas/index.js +1 -1
  148. package/min/queries/with-schemas/index.js.gz +0 -0
  149. package/min/relationships/index.js +1 -1
  150. package/min/relationships/index.js.gz +0 -0
  151. package/min/relationships/with-schemas/index.js +1 -1
  152. package/min/relationships/with-schemas/index.js.gz +0 -0
  153. package/min/store/index.js +1 -1
  154. package/min/store/index.js.gz +0 -0
  155. package/min/store/with-schemas/index.js +1 -1
  156. package/min/store/with-schemas/index.js.gz +0 -0
  157. package/min/synchronizers/index.js +1 -1
  158. package/min/synchronizers/index.js.gz +0 -0
  159. package/min/synchronizers/synchronizer-broadcast-channel/index.js +1 -1
  160. package/min/synchronizers/synchronizer-broadcast-channel/index.js.gz +0 -0
  161. package/min/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js +1 -1
  162. package/min/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js.gz +0 -0
  163. package/min/synchronizers/synchronizer-local/index.js +1 -1
  164. package/min/synchronizers/synchronizer-local/index.js.gz +0 -0
  165. package/min/synchronizers/synchronizer-local/with-schemas/index.js +1 -1
  166. package/min/synchronizers/synchronizer-local/with-schemas/index.js.gz +0 -0
  167. package/min/synchronizers/synchronizer-ws-client/index.js +1 -1
  168. package/min/synchronizers/synchronizer-ws-client/index.js.gz +0 -0
  169. package/min/synchronizers/synchronizer-ws-client/with-schemas/index.js +1 -1
  170. package/min/synchronizers/synchronizer-ws-client/with-schemas/index.js.gz +0 -0
  171. package/min/synchronizers/synchronizer-ws-server/index.js +1 -1
  172. package/min/synchronizers/synchronizer-ws-server/index.js.gz +0 -0
  173. package/min/synchronizers/synchronizer-ws-server/with-schemas/index.js +1 -1
  174. package/min/synchronizers/synchronizer-ws-server/with-schemas/index.js.gz +0 -0
  175. package/min/synchronizers/synchronizer-ws-server-durable-object/index.js +1 -1
  176. package/min/synchronizers/synchronizer-ws-server-durable-object/index.js.gz +0 -0
  177. package/min/synchronizers/synchronizer-ws-server-durable-object/with-schemas/index.js +1 -1
  178. package/min/synchronizers/synchronizer-ws-server-durable-object/with-schemas/index.js.gz +0 -0
  179. package/min/synchronizers/synchronizer-ws-server-simple/index.js +1 -1
  180. package/min/synchronizers/synchronizer-ws-server-simple/index.js.gz +0 -0
  181. package/min/synchronizers/synchronizer-ws-server-simple/with-schemas/index.js +1 -1
  182. package/min/synchronizers/synchronizer-ws-server-simple/with-schemas/index.js.gz +0 -0
  183. package/min/synchronizers/with-schemas/index.js +1 -1
  184. package/min/synchronizers/with-schemas/index.js.gz +0 -0
  185. package/min/ui-react-inspector/index.js +1 -1
  186. package/min/ui-react-inspector/index.js.gz +0 -0
  187. package/min/ui-react-inspector/with-schemas/index.js +1 -1
  188. package/min/ui-react-inspector/with-schemas/index.js.gz +0 -0
  189. package/min/with-schemas/index.js +1 -1
  190. package/min/with-schemas/index.js.gz +0 -0
  191. package/omni/index.js +610 -232
  192. package/omni/with-schemas/index.js +610 -232
  193. package/package.json +55 -19
  194. package/persisters/index.js +29 -12
  195. package/persisters/persister-automerge/index.js +17 -9
  196. package/persisters/persister-automerge/with-schemas/index.js +17 -9
  197. package/persisters/persister-browser/index.js +34 -10
  198. package/persisters/persister-browser/with-schemas/index.js +34 -10
  199. package/persisters/persister-cr-sqlite-wasm/index.js +29 -12
  200. package/persisters/persister-cr-sqlite-wasm/with-schemas/index.js +29 -12
  201. package/persisters/persister-durable-object-sql-storage/index.js +29 -12
  202. package/persisters/persister-durable-object-sql-storage/with-schemas/index.js +29 -12
  203. package/persisters/persister-durable-object-storage/index.js +24 -17
  204. package/persisters/persister-durable-object-storage/with-schemas/index.js +24 -17
  205. package/persisters/persister-electric-sql/index.js +29 -12
  206. package/persisters/persister-electric-sql/with-schemas/index.js +29 -12
  207. package/persisters/persister-expo-sqlite/index.js +29 -12
  208. package/persisters/persister-expo-sqlite/with-schemas/index.js +29 -12
  209. package/persisters/persister-file/index.js +34 -10
  210. package/persisters/persister-file/with-schemas/index.js +34 -10
  211. package/persisters/persister-indexed-db/index.js +17 -9
  212. package/persisters/persister-indexed-db/with-schemas/index.js +17 -9
  213. package/persisters/persister-libsql/index.js +29 -12
  214. package/persisters/persister-libsql/with-schemas/index.js +29 -12
  215. package/persisters/persister-partykit-client/index.js +44 -11
  216. package/persisters/persister-partykit-client/with-schemas/index.js +44 -11
  217. package/persisters/persister-partykit-server/index.js +39 -4
  218. package/persisters/persister-partykit-server/with-schemas/index.js +39 -4
  219. package/persisters/persister-pglite/index.js +29 -12
  220. package/persisters/persister-pglite/with-schemas/index.js +29 -12
  221. package/persisters/persister-postgres/index.js +29 -12
  222. package/persisters/persister-postgres/with-schemas/index.js +29 -12
  223. package/persisters/persister-powersync/index.js +29 -12
  224. package/persisters/persister-powersync/with-schemas/index.js +29 -12
  225. package/persisters/persister-react-native-mmkv/index.js +17 -9
  226. package/persisters/persister-react-native-mmkv/with-schemas/index.js +17 -9
  227. package/persisters/persister-react-native-sqlite/index.js +29 -12
  228. package/persisters/persister-react-native-sqlite/with-schemas/index.js +29 -12
  229. package/persisters/persister-remote/index.js +17 -9
  230. package/persisters/persister-remote/with-schemas/index.js +17 -9
  231. package/persisters/persister-sqlite-bun/index.js +29 -12
  232. package/persisters/persister-sqlite-bun/with-schemas/index.js +29 -12
  233. package/persisters/persister-sqlite-wasm/index.js +29 -12
  234. package/persisters/persister-sqlite-wasm/with-schemas/index.js +29 -12
  235. package/persisters/persister-sqlite3/index.js +29 -12
  236. package/persisters/persister-sqlite3/with-schemas/index.js +29 -12
  237. package/persisters/persister-yjs/index.js +19 -11
  238. package/persisters/persister-yjs/with-schemas/index.js +19 -11
  239. package/persisters/with-schemas/index.js +29 -12
  240. package/queries/index.js +16 -20
  241. package/queries/with-schemas/index.js +16 -20
  242. package/readme.md +21 -13
  243. package/relationships/index.js +13 -12
  244. package/relationships/with-schemas/index.js +13 -12
  245. package/releases.md +41 -41
  246. package/store/index.js +442 -192
  247. package/store/with-schemas/index.js +442 -192
  248. package/synchronizers/index.js +17 -9
  249. package/synchronizers/synchronizer-broadcast-channel/index.js +17 -9
  250. package/synchronizers/synchronizer-broadcast-channel/with-schemas/index.js +17 -9
  251. package/synchronizers/synchronizer-local/index.js +19 -11
  252. package/synchronizers/synchronizer-local/with-schemas/index.js +19 -11
  253. package/synchronizers/synchronizer-ws-client/index.js +31 -10
  254. package/synchronizers/synchronizer-ws-client/with-schemas/index.js +31 -10
  255. package/synchronizers/synchronizer-ws-server/index.js +34 -13
  256. package/synchronizers/synchronizer-ws-server/with-schemas/index.js +34 -13
  257. package/synchronizers/synchronizer-ws-server-durable-object/index.js +31 -10
  258. package/synchronizers/synchronizer-ws-server-durable-object/with-schemas/index.js +31 -10
  259. package/synchronizers/synchronizer-ws-server-simple/index.js +11 -10
  260. package/synchronizers/synchronizer-ws-server-simple/with-schemas/index.js +11 -10
  261. package/synchronizers/with-schemas/index.js +17 -9
  262. package/ui-react-inspector/index.js +438 -193
  263. package/ui-react-inspector/with-schemas/index.js +438 -193
  264. package/with-schemas/index.js +574 -215
@@ -99,7 +99,16 @@ const jsonParse = JSON.parse;
99
99
  const jsonStringWithUndefined = (obj) =>
100
100
  jsonString(obj, (_key, value) => (isUndefined(value) ? UNDEFINED : value));
101
101
  const jsonParseWithUndefined = (str) =>
102
- jsonParse(str, (_key, value) => (value === UNDEFINED ? void 0 : value));
102
+ // JSON.parse reviver removes properties with undefined values
103
+ replaceUndefinedString(jsonParse(str));
104
+ const replaceUndefinedString = (obj) =>
105
+ obj === UNDEFINED
106
+ ? void 0
107
+ : isArray(obj)
108
+ ? arrayMap(obj, replaceUndefinedString)
109
+ : isObject(obj)
110
+ ? objMap(obj, replaceUndefinedString)
111
+ : obj;
103
112
 
104
113
  const collSize = (coll) => coll?.size ?? 0;
105
114
  const collHas = (coll, keyOrValue) => coll?.has(keyOrValue) ?? false;
@@ -109,21 +118,22 @@ const collClear = (coll) => coll.clear();
109
118
  const collForEach = (coll, cb) => coll?.forEach(cb);
110
119
  const collDel = (coll, keyOrValue) => coll?.delete(keyOrValue);
111
120
 
112
- const mapNew = (entries) => new Map(entries);
113
- const mapGet = (map, key) => map?.get(key);
114
- const mapForEach = (map, cb) =>
115
- collForEach(map, (value, key) => cb(key, value));
121
+ const map = Map;
122
+ const mapNew = (entries) => new map(entries);
123
+ const mapGet = (map2, key) => map2?.get(key);
124
+ const mapForEach = (map2, cb) =>
125
+ collForEach(map2, (value, key) => cb(key, value));
116
126
  const mapMap = (coll, cb) =>
117
127
  arrayMap([...(coll?.entries() ?? [])], ([key, value]) => cb(value, key));
118
- const mapSet = (map, key, value) =>
119
- isUndefined(value) ? (collDel(map, key), map) : map?.set(key, value);
120
- const mapEnsure = (map, key, getDefaultValue, hadExistingValue) => {
121
- if (!collHas(map, key)) {
122
- mapSet(map, key, getDefaultValue());
128
+ const mapSet = (map2, key, value) =>
129
+ isUndefined(value) ? (collDel(map2, key), map2) : map2?.set(key, value);
130
+ const mapEnsure = (map2, key, getDefaultValue, hadExistingValue) => {
131
+ if (!collHas(map2, key)) {
132
+ mapSet(map2, key, getDefaultValue());
123
133
  } else {
124
- hadExistingValue?.(mapGet(map, key));
134
+ hadExistingValue?.(mapGet(map2, key));
125
135
  }
126
- return mapGet(map, key);
136
+ return mapGet(map2, key);
127
137
  };
128
138
  const visitTree = (node, path, ensureLeaf, pruneLeaf, p = 0) =>
129
139
  ifNotUndefined(
@@ -333,6 +343,11 @@ const createCustomPersister = (
333
343
  ? store.applyChanges
334
344
  : store.setContent)(contentOrChanges);
335
345
  };
346
+ const saveAfterMutated = async () => {
347
+ if (isAutoSaving() && store.hadMutated?.()) {
348
+ await save();
349
+ }
350
+ };
336
351
  const load = async (initialContent) => {
337
352
  /* istanbul ignore else */
338
353
  if (status != 2 /* Saving */) {
@@ -357,6 +372,7 @@ const createCustomPersister = (
357
372
  },
358
373
  );
359
374
  setStatus(0 /* Idle */);
375
+ await saveAfterMutated();
360
376
  });
361
377
  }
362
378
  return persister;
@@ -375,6 +391,7 @@ const createCustomPersister = (
375
391
  loads++;
376
392
  setContentOrChanges(changes ?? content);
377
393
  setStatus(0 /* Idle */);
394
+ await saveAfterMutated();
378
395
  }
379
396
  } else {
380
397
  await load();
@@ -99,7 +99,16 @@ const jsonParse = JSON.parse;
99
99
  const jsonStringWithUndefined = (obj) =>
100
100
  jsonString(obj, (_key, value) => (isUndefined(value) ? UNDEFINED : value));
101
101
  const jsonParseWithUndefined = (str) =>
102
- jsonParse(str, (_key, value) => (value === UNDEFINED ? void 0 : value));
102
+ // JSON.parse reviver removes properties with undefined values
103
+ replaceUndefinedString(jsonParse(str));
104
+ const replaceUndefinedString = (obj) =>
105
+ obj === UNDEFINED
106
+ ? void 0
107
+ : isArray(obj)
108
+ ? arrayMap(obj, replaceUndefinedString)
109
+ : isObject(obj)
110
+ ? objMap(obj, replaceUndefinedString)
111
+ : obj;
103
112
 
104
113
  const collSize = (coll) => coll?.size ?? 0;
105
114
  const collHas = (coll, keyOrValue) => coll?.has(keyOrValue) ?? false;
@@ -109,21 +118,22 @@ const collClear = (coll) => coll.clear();
109
118
  const collForEach = (coll, cb) => coll?.forEach(cb);
110
119
  const collDel = (coll, keyOrValue) => coll?.delete(keyOrValue);
111
120
 
112
- const mapNew = (entries) => new Map(entries);
113
- const mapGet = (map, key) => map?.get(key);
114
- const mapForEach = (map, cb) =>
115
- collForEach(map, (value, key) => cb(key, value));
121
+ const map = Map;
122
+ const mapNew = (entries) => new map(entries);
123
+ const mapGet = (map2, key) => map2?.get(key);
124
+ const mapForEach = (map2, cb) =>
125
+ collForEach(map2, (value, key) => cb(key, value));
116
126
  const mapMap = (coll, cb) =>
117
127
  arrayMap([...(coll?.entries() ?? [])], ([key, value]) => cb(value, key));
118
- const mapSet = (map, key, value) =>
119
- isUndefined(value) ? (collDel(map, key), map) : map?.set(key, value);
120
- const mapEnsure = (map, key, getDefaultValue, hadExistingValue) => {
121
- if (!collHas(map, key)) {
122
- mapSet(map, key, getDefaultValue());
128
+ const mapSet = (map2, key, value) =>
129
+ isUndefined(value) ? (collDel(map2, key), map2) : map2?.set(key, value);
130
+ const mapEnsure = (map2, key, getDefaultValue, hadExistingValue) => {
131
+ if (!collHas(map2, key)) {
132
+ mapSet(map2, key, getDefaultValue());
123
133
  } else {
124
- hadExistingValue?.(mapGet(map, key));
134
+ hadExistingValue?.(mapGet(map2, key));
125
135
  }
126
- return mapGet(map, key);
136
+ return mapGet(map2, key);
127
137
  };
128
138
  const visitTree = (node, path, ensureLeaf, pruneLeaf, p = 0) =>
129
139
  ifNotUndefined(
@@ -333,6 +343,11 @@ const createCustomPersister = (
333
343
  ? store.applyChanges
334
344
  : store.setContent)(contentOrChanges);
335
345
  };
346
+ const saveAfterMutated = async () => {
347
+ if (isAutoSaving() && store.hadMutated?.()) {
348
+ await save();
349
+ }
350
+ };
336
351
  const load = async (initialContent) => {
337
352
  /* istanbul ignore else */
338
353
  if (status != 2 /* Saving */) {
@@ -357,6 +372,7 @@ const createCustomPersister = (
357
372
  },
358
373
  );
359
374
  setStatus(0 /* Idle */);
375
+ await saveAfterMutated();
360
376
  });
361
377
  }
362
378
  return persister;
@@ -375,6 +391,7 @@ const createCustomPersister = (
375
391
  loads++;
376
392
  setContentOrChanges(changes ?? content);
377
393
  setStatus(0 /* Idle */);
394
+ await saveAfterMutated();
378
395
  }
379
396
  } else {
380
397
  await load();
@@ -71,21 +71,22 @@ const collIsEmpty = (coll) => isUndefined(coll) || collSize(coll) == 0;
71
71
  const collForEach = (coll, cb) => coll?.forEach(cb);
72
72
  const collDel = (coll, keyOrValue) => coll?.delete(keyOrValue);
73
73
 
74
- const mapNew = (entries) => new Map(entries);
75
- const mapGet = (map, key) => map?.get(key);
76
- const mapSet = (map, key, value) =>
77
- isUndefined(value) ? (collDel(map, key), map) : map?.set(key, value);
78
- const mapEnsure = (map, key, getDefaultValue, hadExistingValue) => {
79
- if (!collHas(map, key)) {
80
- mapSet(map, key, getDefaultValue());
74
+ const map = Map;
75
+ const mapNew = (entries) => new map(entries);
76
+ const mapGet = (map2, key) => map2?.get(key);
77
+ const mapSet = (map2, key, value) =>
78
+ isUndefined(value) ? (collDel(map2, key), map2) : map2?.set(key, value);
79
+ const mapEnsure = (map2, key, getDefaultValue, hadExistingValue) => {
80
+ if (!collHas(map2, key)) {
81
+ mapSet(map2, key, getDefaultValue());
81
82
  } else {
82
- hadExistingValue?.(mapGet(map, key));
83
+ hadExistingValue?.(mapGet(map2, key));
83
84
  }
84
- return mapGet(map, key);
85
+ return mapGet(map2, key);
85
86
  };
86
- const mapToObj = (map, valueMapper, excludeMapValue, excludeObjValue) => {
87
+ const mapToObj = (map2, valueMapper, excludeMapValue, excludeObjValue) => {
87
88
  const obj = {};
88
- collForEach(map, (mapValue, id) => {
89
+ collForEach(map2, (mapValue, id) => {
89
90
  {
90
91
  const objValue = mapValue;
91
92
  {
@@ -303,6 +304,11 @@ const createCustomPersister = (
303
304
  ? store.applyChanges
304
305
  : store.setContent)(contentOrChanges);
305
306
  };
307
+ const saveAfterMutated = async () => {
308
+ if (isAutoSaving() && store.hadMutated?.()) {
309
+ await save();
310
+ }
311
+ };
306
312
  const load = async (initialContent) => {
307
313
  /* istanbul ignore else */
308
314
  if (status != 2 /* Saving */) {
@@ -327,6 +333,7 @@ const createCustomPersister = (
327
333
  },
328
334
  );
329
335
  setStatus(0 /* Idle */);
336
+ await saveAfterMutated();
330
337
  });
331
338
  }
332
339
  return persister;
@@ -345,6 +352,7 @@ const createCustomPersister = (
345
352
  loads++;
346
353
  setContentOrChanges(changes ?? content);
347
354
  setStatus(0 /* Idle */);
355
+ await saveAfterMutated();
348
356
  }
349
357
  } else {
350
358
  await load();
@@ -468,12 +476,9 @@ const createDurableObjectStoragePersister = (
468
476
  storagePrefix + type + slice(jsonStringWithUndefined(ids), 1, -1);
469
477
  const deconstructKey = (key) => {
470
478
  if (strStartsWith(key, storagePrefix)) {
471
- const type = slice(key, storagePrefix.length, 1);
479
+ const type = slice(key, size(storagePrefix), size(storagePrefix) + 1);
472
480
  return type == T || type == V
473
- ? [
474
- type,
475
- ...JSON.parse('[' + slice(key, storagePrefix.length + 1) + ']'),
476
- ]
481
+ ? [type, ...JSON.parse('[' + slice(key, size(storagePrefix) + 1) + ']')]
477
482
  : void 0;
478
483
  }
479
484
  };
@@ -522,7 +527,9 @@ const createDurableObjectStoragePersister = (
522
527
  : 0,
523
528
  ),
524
529
  );
525
- return [tables, values];
530
+ return objIsEmpty(tables[0]) && objIsEmpty(values[0])
531
+ ? void 0
532
+ : [tables, values];
526
533
  };
527
534
  const setPersisted = async (
528
535
  getContent,
@@ -71,21 +71,22 @@ const collIsEmpty = (coll) => isUndefined(coll) || collSize(coll) == 0;
71
71
  const collForEach = (coll, cb) => coll?.forEach(cb);
72
72
  const collDel = (coll, keyOrValue) => coll?.delete(keyOrValue);
73
73
 
74
- const mapNew = (entries) => new Map(entries);
75
- const mapGet = (map, key) => map?.get(key);
76
- const mapSet = (map, key, value) =>
77
- isUndefined(value) ? (collDel(map, key), map) : map?.set(key, value);
78
- const mapEnsure = (map, key, getDefaultValue, hadExistingValue) => {
79
- if (!collHas(map, key)) {
80
- mapSet(map, key, getDefaultValue());
74
+ const map = Map;
75
+ const mapNew = (entries) => new map(entries);
76
+ const mapGet = (map2, key) => map2?.get(key);
77
+ const mapSet = (map2, key, value) =>
78
+ isUndefined(value) ? (collDel(map2, key), map2) : map2?.set(key, value);
79
+ const mapEnsure = (map2, key, getDefaultValue, hadExistingValue) => {
80
+ if (!collHas(map2, key)) {
81
+ mapSet(map2, key, getDefaultValue());
81
82
  } else {
82
- hadExistingValue?.(mapGet(map, key));
83
+ hadExistingValue?.(mapGet(map2, key));
83
84
  }
84
- return mapGet(map, key);
85
+ return mapGet(map2, key);
85
86
  };
86
- const mapToObj = (map, valueMapper, excludeMapValue, excludeObjValue) => {
87
+ const mapToObj = (map2, valueMapper, excludeMapValue, excludeObjValue) => {
87
88
  const obj = {};
88
- collForEach(map, (mapValue, id) => {
89
+ collForEach(map2, (mapValue, id) => {
89
90
  {
90
91
  const objValue = mapValue;
91
92
  {
@@ -303,6 +304,11 @@ const createCustomPersister = (
303
304
  ? store.applyChanges
304
305
  : store.setContent)(contentOrChanges);
305
306
  };
307
+ const saveAfterMutated = async () => {
308
+ if (isAutoSaving() && store.hadMutated?.()) {
309
+ await save();
310
+ }
311
+ };
306
312
  const load = async (initialContent) => {
307
313
  /* istanbul ignore else */
308
314
  if (status != 2 /* Saving */) {
@@ -327,6 +333,7 @@ const createCustomPersister = (
327
333
  },
328
334
  );
329
335
  setStatus(0 /* Idle */);
336
+ await saveAfterMutated();
330
337
  });
331
338
  }
332
339
  return persister;
@@ -345,6 +352,7 @@ const createCustomPersister = (
345
352
  loads++;
346
353
  setContentOrChanges(changes ?? content);
347
354
  setStatus(0 /* Idle */);
355
+ await saveAfterMutated();
348
356
  }
349
357
  } else {
350
358
  await load();
@@ -468,12 +476,9 @@ const createDurableObjectStoragePersister = (
468
476
  storagePrefix + type + slice(jsonStringWithUndefined(ids), 1, -1);
469
477
  const deconstructKey = (key) => {
470
478
  if (strStartsWith(key, storagePrefix)) {
471
- const type = slice(key, storagePrefix.length, 1);
479
+ const type = slice(key, size(storagePrefix), size(storagePrefix) + 1);
472
480
  return type == T || type == V
473
- ? [
474
- type,
475
- ...JSON.parse('[' + slice(key, storagePrefix.length + 1) + ']'),
476
- ]
481
+ ? [type, ...JSON.parse('[' + slice(key, size(storagePrefix) + 1) + ']')]
477
482
  : void 0;
478
483
  }
479
484
  };
@@ -522,7 +527,9 @@ const createDurableObjectStoragePersister = (
522
527
  : 0,
523
528
  ),
524
529
  );
525
- return [tables, values];
530
+ return objIsEmpty(tables[0]) && objIsEmpty(values[0])
531
+ ? void 0
532
+ : [tables, values];
526
533
  };
527
534
  const setPersisted = async (
528
535
  getContent,
@@ -135,21 +135,22 @@ const objValues = (obj) => object.values(obj);
135
135
  const objSize = (obj) => size(objIds(obj));
136
136
  const objIsEmpty = (obj) => isObject(obj) && objSize(obj) == 0;
137
137
 
138
- const mapNew = (entries) => new Map(entries);
139
- const mapGet = (map, key) => map?.get(key);
140
- const mapForEach = (map, cb) =>
141
- collForEach(map, (value, key) => cb(key, value));
138
+ const map = Map;
139
+ const mapNew = (entries) => new map(entries);
140
+ const mapGet = (map2, key) => map2?.get(key);
141
+ const mapForEach = (map2, cb) =>
142
+ collForEach(map2, (value, key) => cb(key, value));
142
143
  const mapMap = (coll, cb) =>
143
144
  arrayMap([...(coll?.entries() ?? [])], ([key, value]) => cb(value, key));
144
- const mapSet = (map, key, value) =>
145
- isUndefined(value) ? (collDel(map, key), map) : map?.set(key, value);
146
- const mapEnsure = (map, key, getDefaultValue, hadExistingValue) => {
147
- if (!collHas(map, key)) {
148
- mapSet(map, key, getDefaultValue());
145
+ const mapSet = (map2, key, value) =>
146
+ isUndefined(value) ? (collDel(map2, key), map2) : map2?.set(key, value);
147
+ const mapEnsure = (map2, key, getDefaultValue, hadExistingValue) => {
148
+ if (!collHas(map2, key)) {
149
+ mapSet(map2, key, getDefaultValue());
149
150
  } else {
150
- hadExistingValue?.(mapGet(map, key));
151
+ hadExistingValue?.(mapGet(map2, key));
151
152
  }
152
- return mapGet(map, key);
153
+ return mapGet(map2, key);
153
154
  };
154
155
  const visitTree = (node, path, ensureLeaf, pruneLeaf, p = 0) =>
155
156
  ifNotUndefined(
@@ -304,7 +305,16 @@ const jsonParse = JSON.parse;
304
305
  const jsonStringWithUndefined = (obj) =>
305
306
  jsonString(obj, (_key, value) => (isUndefined(value) ? UNDEFINED : value));
306
307
  const jsonParseWithUndefined = (str) =>
307
- jsonParse(str, (_key, value) => (value === UNDEFINED ? void 0 : value));
308
+ // JSON.parse reviver removes properties with undefined values
309
+ replaceUndefinedString(jsonParse(str));
310
+ const replaceUndefinedString = (obj) =>
311
+ obj === UNDEFINED
312
+ ? void 0
313
+ : isArray(obj)
314
+ ? arrayMap(obj, replaceUndefinedString)
315
+ : isObject(obj)
316
+ ? objMap(obj, replaceUndefinedString)
317
+ : obj;
308
318
 
309
319
  const INTEGER = /^\d+$/;
310
320
  const getPoolFunctions = () => {
@@ -476,6 +486,11 @@ const createCustomPersister = (
476
486
  ? store.applyChanges
477
487
  : store.setContent)(contentOrChanges);
478
488
  };
489
+ const saveAfterMutated = async () => {
490
+ if (isAutoSaving() && store.hadMutated?.()) {
491
+ await save();
492
+ }
493
+ };
479
494
  const load = async (initialContent) => {
480
495
  /* istanbul ignore else */
481
496
  if (status != 2 /* Saving */) {
@@ -500,6 +515,7 @@ const createCustomPersister = (
500
515
  },
501
516
  );
502
517
  setStatus(0 /* Idle */);
518
+ await saveAfterMutated();
503
519
  });
504
520
  }
505
521
  return persister;
@@ -518,6 +534,7 @@ const createCustomPersister = (
518
534
  loads++;
519
535
  setContentOrChanges(changes ?? content);
520
536
  setStatus(0 /* Idle */);
537
+ await saveAfterMutated();
521
538
  }
522
539
  } else {
523
540
  await load();
@@ -135,21 +135,22 @@ const objValues = (obj) => object.values(obj);
135
135
  const objSize = (obj) => size(objIds(obj));
136
136
  const objIsEmpty = (obj) => isObject(obj) && objSize(obj) == 0;
137
137
 
138
- const mapNew = (entries) => new Map(entries);
139
- const mapGet = (map, key) => map?.get(key);
140
- const mapForEach = (map, cb) =>
141
- collForEach(map, (value, key) => cb(key, value));
138
+ const map = Map;
139
+ const mapNew = (entries) => new map(entries);
140
+ const mapGet = (map2, key) => map2?.get(key);
141
+ const mapForEach = (map2, cb) =>
142
+ collForEach(map2, (value, key) => cb(key, value));
142
143
  const mapMap = (coll, cb) =>
143
144
  arrayMap([...(coll?.entries() ?? [])], ([key, value]) => cb(value, key));
144
- const mapSet = (map, key, value) =>
145
- isUndefined(value) ? (collDel(map, key), map) : map?.set(key, value);
146
- const mapEnsure = (map, key, getDefaultValue, hadExistingValue) => {
147
- if (!collHas(map, key)) {
148
- mapSet(map, key, getDefaultValue());
145
+ const mapSet = (map2, key, value) =>
146
+ isUndefined(value) ? (collDel(map2, key), map2) : map2?.set(key, value);
147
+ const mapEnsure = (map2, key, getDefaultValue, hadExistingValue) => {
148
+ if (!collHas(map2, key)) {
149
+ mapSet(map2, key, getDefaultValue());
149
150
  } else {
150
- hadExistingValue?.(mapGet(map, key));
151
+ hadExistingValue?.(mapGet(map2, key));
151
152
  }
152
- return mapGet(map, key);
153
+ return mapGet(map2, key);
153
154
  };
154
155
  const visitTree = (node, path, ensureLeaf, pruneLeaf, p = 0) =>
155
156
  ifNotUndefined(
@@ -304,7 +305,16 @@ const jsonParse = JSON.parse;
304
305
  const jsonStringWithUndefined = (obj) =>
305
306
  jsonString(obj, (_key, value) => (isUndefined(value) ? UNDEFINED : value));
306
307
  const jsonParseWithUndefined = (str) =>
307
- jsonParse(str, (_key, value) => (value === UNDEFINED ? void 0 : value));
308
+ // JSON.parse reviver removes properties with undefined values
309
+ replaceUndefinedString(jsonParse(str));
310
+ const replaceUndefinedString = (obj) =>
311
+ obj === UNDEFINED
312
+ ? void 0
313
+ : isArray(obj)
314
+ ? arrayMap(obj, replaceUndefinedString)
315
+ : isObject(obj)
316
+ ? objMap(obj, replaceUndefinedString)
317
+ : obj;
308
318
 
309
319
  const INTEGER = /^\d+$/;
310
320
  const getPoolFunctions = () => {
@@ -476,6 +486,11 @@ const createCustomPersister = (
476
486
  ? store.applyChanges
477
487
  : store.setContent)(contentOrChanges);
478
488
  };
489
+ const saveAfterMutated = async () => {
490
+ if (isAutoSaving() && store.hadMutated?.()) {
491
+ await save();
492
+ }
493
+ };
479
494
  const load = async (initialContent) => {
480
495
  /* istanbul ignore else */
481
496
  if (status != 2 /* Saving */) {
@@ -500,6 +515,7 @@ const createCustomPersister = (
500
515
  },
501
516
  );
502
517
  setStatus(0 /* Idle */);
518
+ await saveAfterMutated();
503
519
  });
504
520
  }
505
521
  return persister;
@@ -518,6 +534,7 @@ const createCustomPersister = (
518
534
  loads++;
519
535
  setContentOrChanges(changes ?? content);
520
536
  setStatus(0 /* Idle */);
537
+ await saveAfterMutated();
521
538
  }
522
539
  } else {
523
540
  await load();
@@ -137,21 +137,22 @@ const objValues = (obj) => object.values(obj);
137
137
  const objSize = (obj) => size(objIds(obj));
138
138
  const objIsEmpty = (obj) => isObject(obj) && objSize(obj) == 0;
139
139
 
140
- const mapNew = (entries) => new Map(entries);
141
- const mapGet = (map, key) => map?.get(key);
142
- const mapForEach = (map, cb) =>
143
- collForEach(map, (value, key) => cb(key, value));
140
+ const map = Map;
141
+ const mapNew = (entries) => new map(entries);
142
+ const mapGet = (map2, key) => map2?.get(key);
143
+ const mapForEach = (map2, cb) =>
144
+ collForEach(map2, (value, key) => cb(key, value));
144
145
  const mapMap = (coll, cb) =>
145
146
  arrayMap([...(coll?.entries() ?? [])], ([key, value]) => cb(value, key));
146
- const mapSet = (map, key, value) =>
147
- isUndefined(value) ? (collDel(map, key), map) : map?.set(key, value);
148
- const mapEnsure = (map, key, getDefaultValue, hadExistingValue) => {
149
- if (!collHas(map, key)) {
150
- mapSet(map, key, getDefaultValue());
147
+ const mapSet = (map2, key, value) =>
148
+ isUndefined(value) ? (collDel(map2, key), map2) : map2?.set(key, value);
149
+ const mapEnsure = (map2, key, getDefaultValue, hadExistingValue) => {
150
+ if (!collHas(map2, key)) {
151
+ mapSet(map2, key, getDefaultValue());
151
152
  } else {
152
- hadExistingValue?.(mapGet(map, key));
153
+ hadExistingValue?.(mapGet(map2, key));
153
154
  }
154
- return mapGet(map, key);
155
+ return mapGet(map2, key);
155
156
  };
156
157
  const visitTree = (node, path, ensureLeaf, pruneLeaf, p = 0) =>
157
158
  ifNotUndefined(
@@ -306,7 +307,16 @@ const jsonParse = JSON.parse;
306
307
  const jsonStringWithUndefined = (obj) =>
307
308
  jsonString(obj, (_key, value) => (isUndefined(value) ? UNDEFINED : value));
308
309
  const jsonParseWithUndefined = (str) =>
309
- jsonParse(str, (_key, value) => (value === UNDEFINED ? void 0 : value));
310
+ // JSON.parse reviver removes properties with undefined values
311
+ replaceUndefinedString(jsonParse(str));
312
+ const replaceUndefinedString = (obj) =>
313
+ obj === UNDEFINED
314
+ ? void 0
315
+ : isArray(obj)
316
+ ? arrayMap(obj, replaceUndefinedString)
317
+ : isObject(obj)
318
+ ? objMap(obj, replaceUndefinedString)
319
+ : obj;
310
320
 
311
321
  const INTEGER = /^\d+$/;
312
322
  const getPoolFunctions = () => {
@@ -478,6 +488,11 @@ const createCustomPersister = (
478
488
  ? store.applyChanges
479
489
  : store.setContent)(contentOrChanges);
480
490
  };
491
+ const saveAfterMutated = async () => {
492
+ if (isAutoSaving() && store.hadMutated?.()) {
493
+ await save();
494
+ }
495
+ };
481
496
  const load = async (initialContent) => {
482
497
  /* istanbul ignore else */
483
498
  if (status != 2 /* Saving */) {
@@ -502,6 +517,7 @@ const createCustomPersister = (
502
517
  },
503
518
  );
504
519
  setStatus(0 /* Idle */);
520
+ await saveAfterMutated();
505
521
  });
506
522
  }
507
523
  return persister;
@@ -520,6 +536,7 @@ const createCustomPersister = (
520
536
  loads++;
521
537
  setContentOrChanges(changes ?? content);
522
538
  setStatus(0 /* Idle */);
539
+ await saveAfterMutated();
523
540
  }
524
541
  } else {
525
542
  await load();
@@ -137,21 +137,22 @@ const objValues = (obj) => object.values(obj);
137
137
  const objSize = (obj) => size(objIds(obj));
138
138
  const objIsEmpty = (obj) => isObject(obj) && objSize(obj) == 0;
139
139
 
140
- const mapNew = (entries) => new Map(entries);
141
- const mapGet = (map, key) => map?.get(key);
142
- const mapForEach = (map, cb) =>
143
- collForEach(map, (value, key) => cb(key, value));
140
+ const map = Map;
141
+ const mapNew = (entries) => new map(entries);
142
+ const mapGet = (map2, key) => map2?.get(key);
143
+ const mapForEach = (map2, cb) =>
144
+ collForEach(map2, (value, key) => cb(key, value));
144
145
  const mapMap = (coll, cb) =>
145
146
  arrayMap([...(coll?.entries() ?? [])], ([key, value]) => cb(value, key));
146
- const mapSet = (map, key, value) =>
147
- isUndefined(value) ? (collDel(map, key), map) : map?.set(key, value);
148
- const mapEnsure = (map, key, getDefaultValue, hadExistingValue) => {
149
- if (!collHas(map, key)) {
150
- mapSet(map, key, getDefaultValue());
147
+ const mapSet = (map2, key, value) =>
148
+ isUndefined(value) ? (collDel(map2, key), map2) : map2?.set(key, value);
149
+ const mapEnsure = (map2, key, getDefaultValue, hadExistingValue) => {
150
+ if (!collHas(map2, key)) {
151
+ mapSet(map2, key, getDefaultValue());
151
152
  } else {
152
- hadExistingValue?.(mapGet(map, key));
153
+ hadExistingValue?.(mapGet(map2, key));
153
154
  }
154
- return mapGet(map, key);
155
+ return mapGet(map2, key);
155
156
  };
156
157
  const visitTree = (node, path, ensureLeaf, pruneLeaf, p = 0) =>
157
158
  ifNotUndefined(
@@ -306,7 +307,16 @@ const jsonParse = JSON.parse;
306
307
  const jsonStringWithUndefined = (obj) =>
307
308
  jsonString(obj, (_key, value) => (isUndefined(value) ? UNDEFINED : value));
308
309
  const jsonParseWithUndefined = (str) =>
309
- jsonParse(str, (_key, value) => (value === UNDEFINED ? void 0 : value));
310
+ // JSON.parse reviver removes properties with undefined values
311
+ replaceUndefinedString(jsonParse(str));
312
+ const replaceUndefinedString = (obj) =>
313
+ obj === UNDEFINED
314
+ ? void 0
315
+ : isArray(obj)
316
+ ? arrayMap(obj, replaceUndefinedString)
317
+ : isObject(obj)
318
+ ? objMap(obj, replaceUndefinedString)
319
+ : obj;
310
320
 
311
321
  const INTEGER = /^\d+$/;
312
322
  const getPoolFunctions = () => {
@@ -478,6 +488,11 @@ const createCustomPersister = (
478
488
  ? store.applyChanges
479
489
  : store.setContent)(contentOrChanges);
480
490
  };
491
+ const saveAfterMutated = async () => {
492
+ if (isAutoSaving() && store.hadMutated?.()) {
493
+ await save();
494
+ }
495
+ };
481
496
  const load = async (initialContent) => {
482
497
  /* istanbul ignore else */
483
498
  if (status != 2 /* Saving */) {
@@ -502,6 +517,7 @@ const createCustomPersister = (
502
517
  },
503
518
  );
504
519
  setStatus(0 /* Idle */);
520
+ await saveAfterMutated();
505
521
  });
506
522
  }
507
523
  return persister;
@@ -520,6 +536,7 @@ const createCustomPersister = (
520
536
  loads++;
521
537
  setContentOrChanges(changes ?? content);
522
538
  setStatus(0 /* Idle */);
539
+ await saveAfterMutated();
523
540
  }
524
541
  } else {
525
542
  await load();