@verdant-web/store 2.0.1 → 2.0.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 (569) hide show
  1. package/dist/cjs/BackoffScheduler.d.ts +19 -19
  2. package/dist/cjs/BackoffScheduler.js +44 -44
  3. package/dist/cjs/DocumentManager.d.ts +28 -28
  4. package/dist/cjs/DocumentManager.js +44 -44
  5. package/dist/cjs/IDBService.d.ts +9 -9
  6. package/dist/cjs/IDBService.js +46 -46
  7. package/dist/cjs/UndoHistory.d.ts +16 -16
  8. package/dist/cjs/UndoHistory.js +50 -50
  9. package/dist/cjs/__tests__/batching.test.d.ts +1 -1
  10. package/dist/cjs/__tests__/batching.test.js +44 -44
  11. package/dist/cjs/__tests__/documents.test.d.ts +1 -1
  12. package/dist/cjs/__tests__/documents.test.js +398 -398
  13. package/dist/cjs/__tests__/fixtures/testStorage.d.ts +118 -118
  14. package/dist/cjs/__tests__/fixtures/testStorage.js +115 -115
  15. package/dist/cjs/__tests__/queries.test.d.ts +1 -1
  16. package/dist/cjs/__tests__/queries.test.js +262 -262
  17. package/dist/cjs/__tests__/setup/indexedDB.d.ts +1 -1
  18. package/dist/cjs/__tests__/setup/indexedDB.js +3 -3
  19. package/dist/cjs/__tests__/undo.test.d.ts +1 -1
  20. package/dist/cjs/__tests__/undo.test.js +86 -86
  21. package/dist/cjs/client/Client.d.ts +86 -86
  22. package/dist/cjs/client/Client.js +226 -226
  23. package/dist/cjs/client/ClientDescriptor.d.ts +62 -62
  24. package/dist/cjs/client/ClientDescriptor.js +108 -108
  25. package/dist/cjs/constants.d.ts +1 -1
  26. package/dist/cjs/constants.js +4 -4
  27. package/dist/cjs/context.d.ts +17 -17
  28. package/dist/cjs/context.js +2 -2
  29. package/dist/cjs/files/EntityFile.d.ts +27 -27
  30. package/dist/cjs/files/EntityFile.js +71 -71
  31. package/dist/cjs/files/FileManager.d.ts +42 -42
  32. package/dist/cjs/files/FileManager.js +145 -145
  33. package/dist/cjs/files/FileStorage.d.ts +27 -27
  34. package/dist/cjs/files/FileStorage.js +93 -93
  35. package/dist/cjs/files/utils.d.ts +8 -8
  36. package/dist/cjs/files/utils.js +55 -55
  37. package/dist/cjs/files/utils.test.d.ts +1 -1
  38. package/dist/cjs/files/utils.test.js +80 -80
  39. package/dist/cjs/idb.d.ts +8 -8
  40. package/dist/cjs/idb.js +87 -87
  41. package/dist/cjs/index.d.ts +19 -19
  42. package/dist/cjs/index.js +20 -20
  43. package/dist/cjs/indexes.d.ts +3 -3
  44. package/dist/cjs/indexes.js +19 -19
  45. package/dist/cjs/metadata/AckInfoStore.d.ts +10 -10
  46. package/dist/cjs/metadata/AckInfoStore.js +25 -25
  47. package/dist/cjs/metadata/BaselinesStore.d.ts +33 -33
  48. package/dist/cjs/metadata/BaselinesStore.js +59 -59
  49. package/dist/cjs/metadata/LocalReplicaStore.d.ts +17 -17
  50. package/dist/cjs/metadata/LocalReplicaStore.js +47 -47
  51. package/dist/cjs/metadata/MessageCreator.d.ts +19 -19
  52. package/dist/cjs/metadata/MessageCreator.js +127 -127
  53. package/dist/cjs/metadata/Metadata.d.ts +106 -106
  54. package/dist/cjs/metadata/Metadata.js +336 -336
  55. package/dist/cjs/metadata/OperationsStore.d.ts +50 -50
  56. package/dist/cjs/metadata/OperationsStore.js +145 -145
  57. package/dist/cjs/metadata/SchemaStore.d.ts +9 -9
  58. package/dist/cjs/metadata/SchemaStore.js +38 -38
  59. package/dist/cjs/metadata/openMetadataDatabase.d.ts +8 -8
  60. package/dist/cjs/metadata/openMetadataDatabase.js +105 -105
  61. package/dist/cjs/openDocumentDatabase.d.ts +12 -12
  62. package/dist/cjs/openDocumentDatabase.js +424 -424
  63. package/dist/cjs/queries2/BaseQuery.d.ts +39 -39
  64. package/dist/cjs/queries2/BaseQuery.js +98 -98
  65. package/dist/cjs/queries2/CollectionQueries.d.ts +55 -55
  66. package/dist/cjs/queries2/CollectionQueries.js +82 -82
  67. package/dist/cjs/queries2/FindAllQuery.d.ts +11 -11
  68. package/dist/cjs/queries2/FindAllQuery.js +33 -33
  69. package/dist/cjs/queries2/FindInfiniteQuery.d.ts +18 -18
  70. package/dist/cjs/queries2/FindInfiniteQuery.js +60 -60
  71. package/dist/cjs/queries2/FindOneQuery.d.ts +11 -11
  72. package/dist/cjs/queries2/FindOneQuery.js +33 -33
  73. package/dist/cjs/queries2/FindPageQuery.d.ts +23 -23
  74. package/dist/cjs/queries2/FindPageQuery.js +67 -67
  75. package/dist/cjs/queries2/GetQuery.d.ts +10 -10
  76. package/dist/cjs/queries2/GetQuery.js +29 -29
  77. package/dist/cjs/queries2/QueryCache.d.ts +16 -16
  78. package/dist/cjs/queries2/QueryCache.js +39 -39
  79. package/dist/cjs/queries2/dbQueries.d.ts +22 -22
  80. package/dist/cjs/queries2/dbQueries.js +125 -125
  81. package/dist/cjs/queries2/keys.d.ts +10 -10
  82. package/dist/cjs/queries2/keys.js +33 -33
  83. package/dist/cjs/queries2/ranges.d.ts +2 -2
  84. package/dist/cjs/queries2/ranges.js +69 -69
  85. package/dist/cjs/queries2/types.d.ts +6 -6
  86. package/dist/cjs/queries2/types.js +2 -2
  87. package/dist/cjs/queries2/utils.d.ts +1 -1
  88. package/dist/cjs/queries2/utils.js +19 -19
  89. package/dist/cjs/reactives/DocumentFamiliyCache.d.ts +51 -47
  90. package/dist/cjs/reactives/DocumentFamiliyCache.js +214 -210
  91. package/dist/cjs/reactives/DocumentFamiliyCache.js.map +1 -1
  92. package/dist/cjs/reactives/Entity.d.ts +192 -191
  93. package/dist/cjs/reactives/Entity.js +466 -462
  94. package/dist/cjs/reactives/Entity.js.map +1 -1
  95. package/dist/cjs/reactives/EntityStore.d.ts +84 -84
  96. package/dist/cjs/reactives/EntityStore.js +425 -421
  97. package/dist/cjs/reactives/EntityStore.js.map +1 -1
  98. package/dist/cjs/reactives/FakeWeakRef.d.ts +11 -11
  99. package/dist/cjs/reactives/FakeWeakRef.js +18 -18
  100. package/dist/cjs/sync/FileSync.d.ts +23 -23
  101. package/dist/cjs/sync/FileSync.js +84 -84
  102. package/dist/cjs/sync/Heartbeat.d.ts +24 -24
  103. package/dist/cjs/sync/Heartbeat.js +55 -55
  104. package/dist/cjs/sync/PresenceManager.d.ts +41 -41
  105. package/dist/cjs/sync/PresenceManager.js +107 -107
  106. package/dist/cjs/sync/PushPullSync.d.ts +36 -36
  107. package/dist/cjs/sync/PushPullSync.js +141 -141
  108. package/dist/cjs/sync/ServerSyncEndpointProvider.d.ts +27 -27
  109. package/dist/cjs/sync/ServerSyncEndpointProvider.js +64 -64
  110. package/dist/cjs/sync/Sync.d.ts +127 -127
  111. package/dist/cjs/sync/Sync.js +244 -244
  112. package/dist/cjs/sync/WebSocketSync.d.ts +41 -41
  113. package/dist/cjs/sync/WebSocketSync.js +183 -183
  114. package/dist/cjs/types.d.ts +5 -5
  115. package/dist/cjs/types.js +2 -2
  116. package/dist/cjs/utils/Disposable.d.ts +6 -6
  117. package/dist/cjs/utils/Disposable.js +18 -18
  118. package/dist/cjs/utils/Resolvable.d.ts +8 -8
  119. package/dist/cjs/utils/Resolvable.js +22 -22
  120. package/dist/esm/BackoffScheduler.d.ts +19 -19
  121. package/dist/esm/BackoffScheduler.js +39 -39
  122. package/dist/esm/DocumentManager.d.ts +28 -28
  123. package/dist/esm/DocumentManager.js +40 -40
  124. package/dist/esm/IDBService.d.ts +9 -9
  125. package/dist/esm/IDBService.js +42 -42
  126. package/dist/esm/UndoHistory.d.ts +16 -16
  127. package/dist/esm/UndoHistory.js +46 -46
  128. package/dist/esm/__tests__/batching.test.d.ts +1 -1
  129. package/dist/esm/__tests__/batching.test.js +42 -42
  130. package/dist/esm/__tests__/documents.test.d.ts +1 -1
  131. package/dist/esm/__tests__/documents.test.js +396 -396
  132. package/dist/esm/__tests__/fixtures/testStorage.d.ts +118 -118
  133. package/dist/esm/__tests__/fixtures/testStorage.js +111 -111
  134. package/dist/esm/__tests__/queries.test.d.ts +1 -1
  135. package/dist/esm/__tests__/queries.test.js +260 -260
  136. package/dist/esm/__tests__/setup/indexedDB.d.ts +1 -1
  137. package/dist/esm/__tests__/setup/indexedDB.js +1 -1
  138. package/dist/esm/__tests__/undo.test.d.ts +1 -1
  139. package/dist/esm/__tests__/undo.test.js +84 -84
  140. package/dist/esm/client/Client.d.ts +86 -86
  141. package/dist/esm/client/Client.js +222 -222
  142. package/dist/esm/client/ClientDescriptor.d.ts +62 -62
  143. package/dist/esm/client/ClientDescriptor.js +104 -104
  144. package/dist/esm/constants.d.ts +1 -1
  145. package/dist/esm/constants.js +1 -1
  146. package/dist/esm/context.d.ts +17 -17
  147. package/dist/esm/context.js +1 -1
  148. package/dist/esm/files/EntityFile.d.ts +27 -27
  149. package/dist/esm/files/EntityFile.js +67 -67
  150. package/dist/esm/files/FileManager.d.ts +42 -42
  151. package/dist/esm/files/FileManager.js +141 -141
  152. package/dist/esm/files/FileStorage.d.ts +27 -27
  153. package/dist/esm/files/FileStorage.js +88 -88
  154. package/dist/esm/files/utils.d.ts +8 -8
  155. package/dist/esm/files/utils.js +46 -46
  156. package/dist/esm/files/utils.test.d.ts +1 -1
  157. package/dist/esm/files/utils.test.js +78 -78
  158. package/dist/esm/idb.d.ts +8 -8
  159. package/dist/esm/idb.js +79 -79
  160. package/dist/esm/index.d.ts +19 -19
  161. package/dist/esm/index.js +11 -11
  162. package/dist/esm/indexes.d.ts +3 -3
  163. package/dist/esm/indexes.js +14 -14
  164. package/dist/esm/metadata/AckInfoStore.d.ts +10 -10
  165. package/dist/esm/metadata/AckInfoStore.js +21 -21
  166. package/dist/esm/metadata/BaselinesStore.d.ts +33 -33
  167. package/dist/esm/metadata/BaselinesStore.js +55 -55
  168. package/dist/esm/metadata/LocalReplicaStore.d.ts +17 -17
  169. package/dist/esm/metadata/LocalReplicaStore.js +40 -40
  170. package/dist/esm/metadata/MessageCreator.d.ts +19 -19
  171. package/dist/esm/metadata/MessageCreator.js +123 -123
  172. package/dist/esm/metadata/Metadata.d.ts +106 -106
  173. package/dist/esm/metadata/Metadata.js +332 -332
  174. package/dist/esm/metadata/OperationsStore.d.ts +50 -50
  175. package/dist/esm/metadata/OperationsStore.js +141 -141
  176. package/dist/esm/metadata/SchemaStore.d.ts +9 -9
  177. package/dist/esm/metadata/SchemaStore.js +34 -34
  178. package/dist/esm/metadata/openMetadataDatabase.d.ts +8 -8
  179. package/dist/esm/metadata/openMetadataDatabase.js +101 -101
  180. package/dist/esm/openDocumentDatabase.d.ts +12 -12
  181. package/dist/esm/openDocumentDatabase.js +420 -420
  182. package/dist/esm/queries2/BaseQuery.d.ts +39 -39
  183. package/dist/esm/queries2/BaseQuery.js +94 -94
  184. package/dist/esm/queries2/CollectionQueries.d.ts +55 -55
  185. package/dist/esm/queries2/CollectionQueries.js +78 -78
  186. package/dist/esm/queries2/FindAllQuery.d.ts +11 -11
  187. package/dist/esm/queries2/FindAllQuery.js +29 -29
  188. package/dist/esm/queries2/FindInfiniteQuery.d.ts +18 -18
  189. package/dist/esm/queries2/FindInfiniteQuery.js +56 -56
  190. package/dist/esm/queries2/FindOneQuery.d.ts +11 -11
  191. package/dist/esm/queries2/FindOneQuery.js +29 -29
  192. package/dist/esm/queries2/FindPageQuery.d.ts +23 -23
  193. package/dist/esm/queries2/FindPageQuery.js +63 -63
  194. package/dist/esm/queries2/GetQuery.d.ts +10 -10
  195. package/dist/esm/queries2/GetQuery.js +25 -25
  196. package/dist/esm/queries2/QueryCache.d.ts +16 -16
  197. package/dist/esm/queries2/QueryCache.js +35 -35
  198. package/dist/esm/queries2/dbQueries.d.ts +22 -22
  199. package/dist/esm/queries2/dbQueries.js +119 -119
  200. package/dist/esm/queries2/keys.d.ts +10 -10
  201. package/dist/esm/queries2/keys.js +29 -29
  202. package/dist/esm/queries2/ranges.d.ts +2 -2
  203. package/dist/esm/queries2/ranges.js +65 -65
  204. package/dist/esm/queries2/types.d.ts +6 -6
  205. package/dist/esm/queries2/types.js +1 -1
  206. package/dist/esm/queries2/utils.d.ts +1 -1
  207. package/dist/esm/queries2/utils.js +15 -15
  208. package/dist/esm/reactives/DocumentFamiliyCache.d.ts +51 -47
  209. package/dist/esm/reactives/DocumentFamiliyCache.js +210 -206
  210. package/dist/esm/reactives/DocumentFamiliyCache.js.map +1 -1
  211. package/dist/esm/reactives/Entity.d.ts +192 -191
  212. package/dist/esm/reactives/Entity.js +461 -457
  213. package/dist/esm/reactives/Entity.js.map +1 -1
  214. package/dist/esm/reactives/EntityStore.d.ts +84 -84
  215. package/dist/esm/reactives/EntityStore.js +421 -417
  216. package/dist/esm/reactives/EntityStore.js.map +1 -1
  217. package/dist/esm/reactives/FakeWeakRef.d.ts +11 -11
  218. package/dist/esm/reactives/FakeWeakRef.js +14 -14
  219. package/dist/esm/sync/FileSync.d.ts +23 -23
  220. package/dist/esm/sync/FileSync.js +80 -80
  221. package/dist/esm/sync/Heartbeat.d.ts +24 -24
  222. package/dist/esm/sync/Heartbeat.js +51 -51
  223. package/dist/esm/sync/PresenceManager.d.ts +41 -41
  224. package/dist/esm/sync/PresenceManager.js +103 -103
  225. package/dist/esm/sync/PushPullSync.d.ts +36 -36
  226. package/dist/esm/sync/PushPullSync.js +137 -137
  227. package/dist/esm/sync/ServerSyncEndpointProvider.d.ts +27 -27
  228. package/dist/esm/sync/ServerSyncEndpointProvider.js +57 -57
  229. package/dist/esm/sync/Sync.d.ts +127 -127
  230. package/dist/esm/sync/Sync.js +239 -239
  231. package/dist/esm/sync/{WebsocketSync.d.ts → WebSocketSync.d.ts} +41 -41
  232. package/dist/esm/sync/{WebsocketSync.js → WebSocketSync.js} +179 -179
  233. package/dist/esm/types.d.ts +5 -5
  234. package/dist/esm/types.js +1 -1
  235. package/dist/esm/utils/Disposable.d.ts +6 -6
  236. package/dist/esm/utils/Disposable.js +14 -14
  237. package/dist/esm/utils/Resolvable.d.ts +8 -8
  238. package/dist/esm/utils/Resolvable.js +18 -18
  239. package/dist/tsconfig-cjs.tsbuildinfo +1 -1
  240. package/dist/tsconfig.tsbuildinfo +1 -1
  241. package/package.json +2 -2
  242. package/src/reactives/DocumentFamiliyCache.ts +4 -0
  243. package/src/reactives/Entity.ts +8 -1
  244. package/src/reactives/EntityStore.ts +18 -13
  245. package/dist/cjs/AckInfoStore.d.ts +0 -10
  246. package/dist/cjs/AckInfoStore.js +0 -26
  247. package/dist/cjs/AckInfoStore.js.map +0 -1
  248. package/dist/cjs/BaselinesStore.d.ts +0 -10
  249. package/dist/cjs/BaselinesStore.js +0 -36
  250. package/dist/cjs/BaselinesStore.js.map +0 -1
  251. package/dist/cjs/Entity.d.ts +0 -96
  252. package/dist/cjs/Entity.js +0 -345
  253. package/dist/cjs/Entity.js.map +0 -1
  254. package/dist/cjs/EntityStore.d.ts +0 -36
  255. package/dist/cjs/EntityStore.js +0 -172
  256. package/dist/cjs/EntityStore.js.map +0 -1
  257. package/dist/cjs/LocalHistoryStore.d.ts +0 -15
  258. package/dist/cjs/LocalHistoryStore.js +0 -53
  259. package/dist/cjs/LocalHistoryStore.js.map +0 -1
  260. package/dist/cjs/LocalReplicaStore.d.ts +0 -13
  261. package/dist/cjs/LocalReplicaStore.js +0 -49
  262. package/dist/cjs/LocalReplicaStore.js.map +0 -1
  263. package/dist/cjs/MessageCreator.d.ts +0 -19
  264. package/dist/cjs/MessageCreator.js +0 -104
  265. package/dist/cjs/MessageCreator.js.map +0 -1
  266. package/dist/cjs/Metadata.d.ts +0 -91
  267. package/dist/cjs/Metadata.js +0 -250
  268. package/dist/cjs/Metadata.js.map +0 -1
  269. package/dist/cjs/OperationsStore.d.ts +0 -38
  270. package/dist/cjs/OperationsStore.js +0 -146
  271. package/dist/cjs/OperationsStore.js.map +0 -1
  272. package/dist/cjs/PresenceManager.d.ts +0 -30
  273. package/dist/cjs/PresenceManager.js +0 -89
  274. package/dist/cjs/PresenceManager.js.map +0 -1
  275. package/dist/cjs/Query.d.ts +0 -26
  276. package/dist/cjs/Query.js +0 -86
  277. package/dist/cjs/Query.js.map +0 -1
  278. package/dist/cjs/QueryMaker.d.ts +0 -18
  279. package/dist/cjs/QueryMaker.js +0 -98
  280. package/dist/cjs/QueryMaker.js.map +0 -1
  281. package/dist/cjs/QueryStore.d.ts +0 -38
  282. package/dist/cjs/QueryStore.js +0 -146
  283. package/dist/cjs/QueryStore.js.map +0 -1
  284. package/dist/cjs/SchemaStore.d.ts +0 -9
  285. package/dist/cjs/SchemaStore.js +0 -35
  286. package/dist/cjs/SchemaStore.js.map +0 -1
  287. package/dist/cjs/Storage.d.ts +0 -147
  288. package/dist/cjs/Storage.js +0 -346
  289. package/dist/cjs/Storage.js.map +0 -1
  290. package/dist/cjs/Sync.d.ts +0 -117
  291. package/dist/cjs/Sync.js +0 -561
  292. package/dist/cjs/Sync.js.map +0 -1
  293. package/dist/cjs/SyncHarness.d.ts +0 -45
  294. package/dist/cjs/SyncHarness.js +0 -110
  295. package/dist/cjs/SyncHarness.js.map +0 -1
  296. package/dist/cjs/metadata/LocalHistoryStore.d.ts +0 -15
  297. package/dist/cjs/metadata/LocalHistoryStore.js +0 -53
  298. package/dist/cjs/metadata/LocalHistoryStore.js.map +0 -1
  299. package/dist/cjs/queries/LiveQuery.d.ts +0 -28
  300. package/dist/cjs/queries/LiveQuery.js +0 -96
  301. package/dist/cjs/queries/LiveQuery.js.map +0 -1
  302. package/dist/cjs/queries/LiveQueryMaker.d.ts +0 -15
  303. package/dist/cjs/queries/LiveQueryMaker.js +0 -42
  304. package/dist/cjs/queries/LiveQueryMaker.js.map +0 -1
  305. package/dist/cjs/queries/LiveQueryStore.d.ts +0 -33
  306. package/dist/cjs/queries/LiveQueryStore.js +0 -85
  307. package/dist/cjs/queries/LiveQueryStore.js.map +0 -1
  308. package/dist/cjs/queries/Query.d.ts +0 -18
  309. package/dist/cjs/queries/Query.js +0 -36
  310. package/dist/cjs/queries/Query.js.map +0 -1
  311. package/dist/cjs/queries/QueryMaker.d.ts +0 -14
  312. package/dist/cjs/queries/QueryMaker.js +0 -42
  313. package/dist/cjs/queries/QueryMaker.js.map +0 -1
  314. package/dist/cjs/queries/QueryStore.d.ts +0 -35
  315. package/dist/cjs/queries/QueryStore.js +0 -130
  316. package/dist/cjs/queries/QueryStore.js.map +0 -1
  317. package/dist/cjs/queries/ranges.d.ts +0 -2
  318. package/dist/cjs/queries/ranges.js +0 -70
  319. package/dist/cjs/queries/ranges.js.map +0 -1
  320. package/dist/cjs/v2/AckInfoStore.d.ts +0 -10
  321. package/dist/cjs/v2/AckInfoStore.js +0 -26
  322. package/dist/cjs/v2/AckInfoStore.js.map +0 -1
  323. package/dist/cjs/v2/BaselinesStore.d.ts +0 -10
  324. package/dist/cjs/v2/BaselinesStore.js +0 -36
  325. package/dist/cjs/v2/BaselinesStore.js.map +0 -1
  326. package/dist/cjs/v2/DocumentManager.d.ts +0 -19
  327. package/dist/cjs/v2/DocumentManager.js +0 -47
  328. package/dist/cjs/v2/DocumentManager.js.map +0 -1
  329. package/dist/cjs/v2/Entity.d.ts +0 -87
  330. package/dist/cjs/v2/Entity.js +0 -305
  331. package/dist/cjs/v2/Entity.js.map +0 -1
  332. package/dist/cjs/v2/EntityStore.d.ts +0 -37
  333. package/dist/cjs/v2/EntityStore.js +0 -165
  334. package/dist/cjs/v2/EntityStore.js.map +0 -1
  335. package/dist/cjs/v2/IDBService.d.ts +0 -7
  336. package/dist/cjs/v2/IDBService.js +0 -26
  337. package/dist/cjs/v2/IDBService.js.map +0 -1
  338. package/dist/cjs/v2/LocalHistoryStore.d.ts +0 -15
  339. package/dist/cjs/v2/LocalHistoryStore.js +0 -53
  340. package/dist/cjs/v2/LocalHistoryStore.js.map +0 -1
  341. package/dist/cjs/v2/LocalReplicaStore.d.ts +0 -14
  342. package/dist/cjs/v2/LocalReplicaStore.js +0 -49
  343. package/dist/cjs/v2/LocalReplicaStore.js.map +0 -1
  344. package/dist/cjs/v2/MessageCreator.d.ts +0 -19
  345. package/dist/cjs/v2/MessageCreator.js +0 -99
  346. package/dist/cjs/v2/MessageCreator.js.map +0 -1
  347. package/dist/cjs/v2/Metadata.d.ts +0 -90
  348. package/dist/cjs/v2/Metadata.js +0 -251
  349. package/dist/cjs/v2/Metadata.js.map +0 -1
  350. package/dist/cjs/v2/OperationsStore.d.ts +0 -38
  351. package/dist/cjs/v2/OperationsStore.js +0 -146
  352. package/dist/cjs/v2/OperationsStore.js.map +0 -1
  353. package/dist/cjs/v2/PresenceManager.d.ts +0 -24
  354. package/dist/cjs/v2/PresenceManager.js +0 -73
  355. package/dist/cjs/v2/PresenceManager.js.map +0 -1
  356. package/dist/cjs/v2/Query.d.ts +0 -24
  357. package/dist/cjs/v2/Query.js +0 -79
  358. package/dist/cjs/v2/Query.js.map +0 -1
  359. package/dist/cjs/v2/QueryMaker.d.ts +0 -16
  360. package/dist/cjs/v2/QueryMaker.js +0 -84
  361. package/dist/cjs/v2/QueryMaker.js.map +0 -1
  362. package/dist/cjs/v2/QueryStore.d.ts +0 -26
  363. package/dist/cjs/v2/QueryStore.js +0 -136
  364. package/dist/cjs/v2/QueryStore.js.map +0 -1
  365. package/dist/cjs/v2/SchemaStore.d.ts +0 -9
  366. package/dist/cjs/v2/SchemaStore.js +0 -35
  367. package/dist/cjs/v2/SchemaStore.js.map +0 -1
  368. package/dist/cjs/v2/Storage.d.ts +0 -80
  369. package/dist/cjs/v2/Storage.js +0 -154
  370. package/dist/cjs/v2/Storage.js.map +0 -1
  371. package/dist/cjs/v2/Sync.d.ts +0 -42
  372. package/dist/cjs/v2/Sync.js +0 -98
  373. package/dist/cjs/v2/Sync.js.map +0 -1
  374. package/dist/cjs/v2/SyncHarness.d.ts +0 -45
  375. package/dist/cjs/v2/SyncHarness.js +0 -110
  376. package/dist/cjs/v2/SyncHarness.js.map +0 -1
  377. package/dist/cjs/v2/__tests__/documents.test.d.ts +0 -1
  378. package/dist/cjs/v2/__tests__/documents.test.js +0 -185
  379. package/dist/cjs/v2/__tests__/documents.test.js.map +0 -1
  380. package/dist/cjs/v2/__tests__/fixtures/testStorage.d.ts +0 -189
  381. package/dist/cjs/v2/__tests__/fixtures/testStorage.js +0 -93
  382. package/dist/cjs/v2/__tests__/fixtures/testStorage.js.map +0 -1
  383. package/dist/cjs/v2/__tests__/queries.test.d.ts +0 -1
  384. package/dist/cjs/v2/__tests__/queries.test.js +0 -92
  385. package/dist/cjs/v2/__tests__/queries.test.js.map +0 -1
  386. package/dist/cjs/v2/__tests__/setup/indexedDB.d.ts +0 -1
  387. package/dist/cjs/v2/__tests__/setup/indexedDB.js +0 -4
  388. package/dist/cjs/v2/__tests__/setup/indexedDB.js.map +0 -1
  389. package/dist/cjs/v2/constants.d.ts +0 -1
  390. package/dist/cjs/v2/constants.js +0 -5
  391. package/dist/cjs/v2/constants.js.map +0 -1
  392. package/dist/cjs/v2/idb.d.ts +0 -6
  393. package/dist/cjs/v2/idb.js +0 -71
  394. package/dist/cjs/v2/idb.js.map +0 -1
  395. package/dist/cjs/v2/index.d.ts +0 -6
  396. package/dist/cjs/v2/index.js +0 -14
  397. package/dist/cjs/v2/index.js.map +0 -1
  398. package/dist/cjs/v2/indexes.d.ts +0 -3
  399. package/dist/cjs/v2/indexes.js +0 -20
  400. package/dist/cjs/v2/indexes.js.map +0 -1
  401. package/dist/cjs/v2/openDocumentDatabase.d.ts +0 -9
  402. package/dist/cjs/v2/openDocumentDatabase.js +0 -100
  403. package/dist/cjs/v2/openDocumentDatabase.js.map +0 -1
  404. package/dist/cjs/v2/types.d.ts +0 -3
  405. package/dist/cjs/v2/types.js +0 -3
  406. package/dist/cjs/v2/types.js.map +0 -1
  407. package/dist/esm/AckInfoStore.d.ts +0 -10
  408. package/dist/esm/AckInfoStore.js +0 -22
  409. package/dist/esm/AckInfoStore.js.map +0 -1
  410. package/dist/esm/BaselinesStore.d.ts +0 -10
  411. package/dist/esm/BaselinesStore.js +0 -32
  412. package/dist/esm/BaselinesStore.js.map +0 -1
  413. package/dist/esm/Entity.d.ts +0 -96
  414. package/dist/esm/Entity.js +0 -337
  415. package/dist/esm/Entity.js.map +0 -1
  416. package/dist/esm/EntityStore.d.ts +0 -36
  417. package/dist/esm/EntityStore.js +0 -168
  418. package/dist/esm/EntityStore.js.map +0 -1
  419. package/dist/esm/LocalHistoryStore.d.ts +0 -15
  420. package/dist/esm/LocalHistoryStore.js +0 -49
  421. package/dist/esm/LocalHistoryStore.js.map +0 -1
  422. package/dist/esm/LocalReplicaStore.d.ts +0 -13
  423. package/dist/esm/LocalReplicaStore.js +0 -42
  424. package/dist/esm/LocalReplicaStore.js.map +0 -1
  425. package/dist/esm/MessageCreator.d.ts +0 -19
  426. package/dist/esm/MessageCreator.js +0 -97
  427. package/dist/esm/MessageCreator.js.map +0 -1
  428. package/dist/esm/Metadata.d.ts +0 -91
  429. package/dist/esm/Metadata.js +0 -245
  430. package/dist/esm/Metadata.js.map +0 -1
  431. package/dist/esm/OperationsStore.d.ts +0 -38
  432. package/dist/esm/OperationsStore.js +0 -142
  433. package/dist/esm/OperationsStore.js.map +0 -1
  434. package/dist/esm/PresenceManager.d.ts +0 -30
  435. package/dist/esm/PresenceManager.js +0 -85
  436. package/dist/esm/PresenceManager.js.map +0 -1
  437. package/dist/esm/Query.d.ts +0 -26
  438. package/dist/esm/Query.js +0 -82
  439. package/dist/esm/Query.js.map +0 -1
  440. package/dist/esm/QueryMaker.d.ts +0 -18
  441. package/dist/esm/QueryMaker.js +0 -94
  442. package/dist/esm/QueryMaker.js.map +0 -1
  443. package/dist/esm/QueryStore.d.ts +0 -38
  444. package/dist/esm/QueryStore.js +0 -142
  445. package/dist/esm/QueryStore.js.map +0 -1
  446. package/dist/esm/SchemaStore.d.ts +0 -9
  447. package/dist/esm/SchemaStore.js +0 -31
  448. package/dist/esm/SchemaStore.js.map +0 -1
  449. package/dist/esm/Storage.d.ts +0 -147
  450. package/dist/esm/Storage.js +0 -341
  451. package/dist/esm/Storage.js.map +0 -1
  452. package/dist/esm/Sync.d.ts +0 -117
  453. package/dist/esm/Sync.js +0 -553
  454. package/dist/esm/Sync.js.map +0 -1
  455. package/dist/esm/SyncHarness.d.ts +0 -45
  456. package/dist/esm/SyncHarness.js +0 -105
  457. package/dist/esm/SyncHarness.js.map +0 -1
  458. package/dist/esm/metadata/LocalHistoryStore.d.ts +0 -15
  459. package/dist/esm/metadata/LocalHistoryStore.js +0 -49
  460. package/dist/esm/metadata/LocalHistoryStore.js.map +0 -1
  461. package/dist/esm/queries/LiveQuery.d.ts +0 -28
  462. package/dist/esm/queries/LiveQuery.js +0 -92
  463. package/dist/esm/queries/LiveQuery.js.map +0 -1
  464. package/dist/esm/queries/LiveQueryMaker.d.ts +0 -15
  465. package/dist/esm/queries/LiveQueryMaker.js +0 -38
  466. package/dist/esm/queries/LiveQueryMaker.js.map +0 -1
  467. package/dist/esm/queries/LiveQueryStore.d.ts +0 -33
  468. package/dist/esm/queries/LiveQueryStore.js +0 -81
  469. package/dist/esm/queries/LiveQueryStore.js.map +0 -1
  470. package/dist/esm/queries/Query.d.ts +0 -18
  471. package/dist/esm/queries/Query.js +0 -32
  472. package/dist/esm/queries/Query.js.map +0 -1
  473. package/dist/esm/queries/QueryMaker.d.ts +0 -14
  474. package/dist/esm/queries/QueryMaker.js +0 -38
  475. package/dist/esm/queries/QueryMaker.js.map +0 -1
  476. package/dist/esm/queries/QueryStore.d.ts +0 -35
  477. package/dist/esm/queries/QueryStore.js +0 -126
  478. package/dist/esm/queries/QueryStore.js.map +0 -1
  479. package/dist/esm/queries/ranges.d.ts +0 -2
  480. package/dist/esm/queries/ranges.js +0 -66
  481. package/dist/esm/queries/ranges.js.map +0 -1
  482. package/dist/esm/v2/AckInfoStore.d.ts +0 -10
  483. package/dist/esm/v2/AckInfoStore.js +0 -22
  484. package/dist/esm/v2/AckInfoStore.js.map +0 -1
  485. package/dist/esm/v2/BaselinesStore.d.ts +0 -10
  486. package/dist/esm/v2/BaselinesStore.js +0 -32
  487. package/dist/esm/v2/BaselinesStore.js.map +0 -1
  488. package/dist/esm/v2/DocumentManager.d.ts +0 -19
  489. package/dist/esm/v2/DocumentManager.js +0 -43
  490. package/dist/esm/v2/DocumentManager.js.map +0 -1
  491. package/dist/esm/v2/Entity.d.ts +0 -91
  492. package/dist/esm/v2/Entity.js +0 -305
  493. package/dist/esm/v2/Entity.js.map +0 -1
  494. package/dist/esm/v2/EntityStore.d.ts +0 -37
  495. package/dist/esm/v2/EntityStore.js +0 -166
  496. package/dist/esm/v2/EntityStore.js.map +0 -1
  497. package/dist/esm/v2/IDBService.d.ts +0 -7
  498. package/dist/esm/v2/IDBService.js +0 -22
  499. package/dist/esm/v2/IDBService.js.map +0 -1
  500. package/dist/esm/v2/LocalHistoryStore.d.ts +0 -15
  501. package/dist/esm/v2/LocalHistoryStore.js +0 -49
  502. package/dist/esm/v2/LocalHistoryStore.js.map +0 -1
  503. package/dist/esm/v2/LocalReplicaStore.d.ts +0 -14
  504. package/dist/esm/v2/LocalReplicaStore.js +0 -42
  505. package/dist/esm/v2/LocalReplicaStore.js.map +0 -1
  506. package/dist/esm/v2/MessageCreator.d.ts +0 -19
  507. package/dist/esm/v2/MessageCreator.js +0 -92
  508. package/dist/esm/v2/MessageCreator.js.map +0 -1
  509. package/dist/esm/v2/Metadata.d.ts +0 -90
  510. package/dist/esm/v2/Metadata.js +0 -246
  511. package/dist/esm/v2/Metadata.js.map +0 -1
  512. package/dist/esm/v2/OperationsStore.d.ts +0 -38
  513. package/dist/esm/v2/OperationsStore.js +0 -142
  514. package/dist/esm/v2/OperationsStore.js.map +0 -1
  515. package/dist/esm/v2/PresenceManager.d.ts +0 -24
  516. package/dist/esm/v2/PresenceManager.js +0 -69
  517. package/dist/esm/v2/PresenceManager.js.map +0 -1
  518. package/dist/esm/v2/Query.d.ts +0 -24
  519. package/dist/esm/v2/Query.js +0 -75
  520. package/dist/esm/v2/Query.js.map +0 -1
  521. package/dist/esm/v2/QueryMaker.d.ts +0 -16
  522. package/dist/esm/v2/QueryMaker.js +0 -80
  523. package/dist/esm/v2/QueryMaker.js.map +0 -1
  524. package/dist/esm/v2/QueryStore.d.ts +0 -26
  525. package/dist/esm/v2/QueryStore.js +0 -132
  526. package/dist/esm/v2/QueryStore.js.map +0 -1
  527. package/dist/esm/v2/SchemaStore.d.ts +0 -9
  528. package/dist/esm/v2/SchemaStore.js +0 -31
  529. package/dist/esm/v2/SchemaStore.js.map +0 -1
  530. package/dist/esm/v2/Storage.d.ts +0 -80
  531. package/dist/esm/v2/Storage.js +0 -149
  532. package/dist/esm/v2/Storage.js.map +0 -1
  533. package/dist/esm/v2/Sync.d.ts +0 -42
  534. package/dist/esm/v2/Sync.js +0 -94
  535. package/dist/esm/v2/Sync.js.map +0 -1
  536. package/dist/esm/v2/SyncHarness.d.ts +0 -45
  537. package/dist/esm/v2/SyncHarness.js +0 -105
  538. package/dist/esm/v2/SyncHarness.js.map +0 -1
  539. package/dist/esm/v2/__tests__/documents.test.d.ts +0 -1
  540. package/dist/esm/v2/__tests__/documents.test.js +0 -208
  541. package/dist/esm/v2/__tests__/documents.test.js.map +0 -1
  542. package/dist/esm/v2/__tests__/fixtures/testStorage.d.ts +0 -223
  543. package/dist/esm/v2/__tests__/fixtures/testStorage.js +0 -106
  544. package/dist/esm/v2/__tests__/fixtures/testStorage.js.map +0 -1
  545. package/dist/esm/v2/__tests__/queries.test.d.ts +0 -1
  546. package/dist/esm/v2/__tests__/queries.test.js +0 -90
  547. package/dist/esm/v2/__tests__/queries.test.js.map +0 -1
  548. package/dist/esm/v2/__tests__/setup/indexedDB.d.ts +0 -1
  549. package/dist/esm/v2/__tests__/setup/indexedDB.js +0 -2
  550. package/dist/esm/v2/__tests__/setup/indexedDB.js.map +0 -1
  551. package/dist/esm/v2/constants.d.ts +0 -1
  552. package/dist/esm/v2/constants.js +0 -2
  553. package/dist/esm/v2/constants.js.map +0 -1
  554. package/dist/esm/v2/idb.d.ts +0 -6
  555. package/dist/esm/v2/idb.js +0 -65
  556. package/dist/esm/v2/idb.js.map +0 -1
  557. package/dist/esm/v2/index.d.ts +0 -6
  558. package/dist/esm/v2/index.js +0 -5
  559. package/dist/esm/v2/index.js.map +0 -1
  560. package/dist/esm/v2/indexes.d.ts +0 -3
  561. package/dist/esm/v2/indexes.js +0 -15
  562. package/dist/esm/v2/indexes.js.map +0 -1
  563. package/dist/esm/v2/openDocumentDatabase.d.ts +0 -9
  564. package/dist/esm/v2/openDocumentDatabase.js +0 -96
  565. package/dist/esm/v2/openDocumentDatabase.js.map +0 -1
  566. package/dist/esm/v2/types.d.ts +0 -3
  567. package/dist/esm/v2/types.js +0 -2
  568. package/dist/esm/v2/types.js.map +0 -1
  569. /package/dist/esm/sync/{WebsocketSync.js.map → WebSocketSync.js.map} +0 -0
@@ -1,403 +1,403 @@
1
- "use strict";
2
- var __rest = (this && this.__rest) || function (s, e) {
3
- var t = {};
4
- for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
5
- t[p] = s[p];
6
- if (s != null && typeof Object.getOwnPropertySymbols === "function")
7
- for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
8
- if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
9
- t[p[i]] = s[p[i]];
10
- }
11
- return t;
12
- };
13
- Object.defineProperty(exports, "__esModule", { value: true });
14
- const common_1 = require("@verdant-web/common");
15
- const vitest_1 = require("vitest");
16
- const testStorage_js_1 = require("./fixtures/testStorage.js");
17
- async function waitForStoragePropagation(mock) {
18
- await new Promise((resolve, reject) => {
19
- // timeout after 3s waiting
20
- const timeout = setTimeout(() => reject(new Error('Waiting for storage change timed out')), 3000);
21
- const interval = setInterval(() => {
22
- if (mock.mock.calls.length > 0) {
23
- clearInterval(interval);
24
- clearTimeout(timeout);
25
- resolve();
26
- }
27
- }, 0);
28
- });
29
- }
30
- (0, vitest_1.describe)('storage documents', () => {
31
- (0, vitest_1.it)('should fill in default values', async () => {
32
- const storage = await (0, testStorage_js_1.createTestStorage)();
33
- const item = await storage.todos.put({
34
- content: 'item',
35
- category: 'general',
36
- attachments: [
37
- {
38
- name: 'thing',
39
- },
40
- ],
41
- });
42
- (0, vitest_1.expect)(item.get('id')).toBeDefined();
43
- (0, vitest_1.expect)(item.get('done')).toBe(false);
44
- (0, vitest_1.expect)(item.get('tags').length).toBe(0);
45
- (0, vitest_1.expect)(item.get('attachments').get(0).get('test')).toBe(1);
46
- });
47
- (0, vitest_1.it)('should have a stable identity across different queries when subscribed', async () => {
48
- const storage = await (0, testStorage_js_1.createTestStorage)();
49
- const item1 = await storage.todos.put({
50
- content: 'item 1',
51
- done: false,
52
- tags: [],
53
- category: 'general',
54
- attachments: [],
55
- });
56
- await storage.todos.put({
57
- content: 'item 2',
58
- done: true,
59
- tags: [],
60
- category: 'general',
61
- attachments: [],
62
- });
63
- const singleItemQuery = storage.todos.get(item1.get('id'));
64
- const singleItemResult = await singleItemQuery.resolved;
65
- (0, vitest_1.expect)(singleItemResult).toBeTruthy();
66
- (0, common_1.assert)(!!singleItemResult);
67
- singleItemResult.subscribe('change', vitest_1.vi.fn());
68
- const allItemsQuery = storage.todos.findAll();
69
- const allItemsResult = await allItemsQuery.resolved;
70
- const allItemsReferenceToItem1 = allItemsResult.find((item) => item.get('id') === item1.get('id'));
71
- (0, vitest_1.expect)(singleItemResult).toBe(allItemsReferenceToItem1);
72
- });
73
- (0, vitest_1.it)('should immediately reflect mutations', async () => {
74
- const storage = await (0, testStorage_js_1.createTestStorage)();
75
- const item1 = await storage.todos.put({
76
- content: 'item 1',
77
- done: false,
78
- tags: [],
79
- category: 'general',
80
- attachments: [],
81
- });
82
- item1.set('done', true);
83
- (0, vitest_1.expect)(item1.get('done')).toBe(true);
84
- });
85
- (0, vitest_1.it)('should notify about changes', async () => {
86
- const storage = await (0, testStorage_js_1.createTestStorage)();
87
- const item1 = await storage.todos.put({
88
- content: 'item 1',
89
- done: false,
90
- tags: [],
91
- category: 'general',
92
- attachments: [],
93
- });
94
- const liveItem1 = await storage.todos.get(item1.get('id')).resolved;
95
- (0, vitest_1.expect)(liveItem1).toBeTruthy();
96
- (0, common_1.assert)(!!liveItem1);
97
- const callback = vitest_1.vi.fn();
98
- liveItem1.subscribe('change', callback);
99
- liveItem1.set('done', true);
100
- liveItem1.set('content', 'item 1 updated');
101
- await waitForStoragePropagation(callback);
102
- // only 1 callback - changes are batched.
103
- // expect(callback).toBeCalledTimes(1); // FIXME: called twice, once for immediate in-memory change and once after propagation. can this be 1?
104
- (0, vitest_1.expect)(liveItem1.getSnapshot()).toEqual({
105
- id: liveItem1.get('id'),
106
- content: 'item 1 updated',
107
- done: true,
108
- tags: [],
109
- category: 'general',
110
- attachments: [],
111
- });
112
- const callbackDeep = vitest_1.vi.fn();
113
- liveItem1.subscribe('changeDeep', callbackDeep);
114
- liveItem1.update({
115
- tags: ['tag 1', 'tag 2'],
116
- });
117
- await waitForStoragePropagation(callbackDeep);
118
- (0, vitest_1.expect)(liveItem1.getSnapshot().tags).toEqual(['tag 1', 'tag 2']);
119
- });
120
- (0, vitest_1.it)('should expose array mutators on nested arrays', async () => {
121
- const storage = await (0, testStorage_js_1.createTestStorage)();
122
- const item1 = await storage.todos.put({
123
- content: 'item 1',
124
- done: false,
125
- tags: [],
126
- category: 'general',
127
- attachments: [],
128
- });
129
- const callback = vitest_1.vi.fn();
130
- item1.get('tags').subscribe('change', callback);
131
- item1.get('tags').push('tag 1');
132
- item1.get('tags').push('tag 2');
133
- item1.get('tags').push('tag 3');
134
- item1.get('tags').move(1, 2);
135
- // fields are immediately updated
136
- (0, vitest_1.expect)(item1.get('tags').get(0)).toEqual('tag 1');
137
- (0, vitest_1.expect)(item1.get('tags').get(1)).toEqual('tag 3');
138
- (0, vitest_1.expect)(item1.get('tags').get(2)).toEqual('tag 2');
139
- await waitForStoragePropagation(callback);
140
- (0, vitest_1.expect)(callback).toBeCalledTimes(4);
141
- (0, vitest_1.expect)(item1.getSnapshot()).toEqual({
142
- id: item1.get('id'),
143
- content: 'item 1',
144
- done: false,
145
- tags: ['tag 1', 'tag 3', 'tag 2'],
146
- category: 'general',
147
- attachments: [],
148
- });
149
- });
150
- (0, vitest_1.it)('should expose array accessors on nested arrays', async () => {
151
- const storage = await (0, testStorage_js_1.createTestStorage)();
152
- const item1 = await storage.todos.put({
153
- content: 'item 1',
154
- done: false,
155
- tags: ['tag 1', 'tag 2'],
156
- category: 'general',
157
- attachments: [
158
- {
159
- name: 'attachment 1',
160
- },
161
- ],
162
- });
163
- for (const attachment of item1.get('attachments')) {
164
- (0, vitest_1.expect)(attachment.get('name')).toBe('attachment 1');
165
- }
166
- let i = 0;
167
- for (const tag of item1.get('tags')) {
168
- (0, vitest_1.expect)(tag).toBe('tag ' + ++i);
169
- }
170
- (0, vitest_1.expect)(item1.get('tags').filter((tag) => tag === 'tag 1')).toEqual([
171
- 'tag 1',
172
- ]);
173
- item1.get('attachments').push({
174
- name: 'attachment 2',
175
- });
176
- (0, vitest_1.expect)(item1.get('attachments').getSnapshot()).toEqual([
177
- { name: 'attachment 1', test: 1 },
178
- { name: 'attachment 2', test: 1 },
179
- ]);
180
- });
181
- (0, vitest_1.it)('should provide a reasonable way to interact with unknown data', async () => {
182
- /**
183
- * 'any' field types should basically just stop type checking, but still
184
- * provide full reactive entity access for nested data.
185
- */
186
- const storage = await (0, testStorage_js_1.createTestStorage)();
187
- const item1 = await storage.weirds.put({
188
- weird: {
189
- foo: 'bar',
190
- baz: [
191
- {
192
- corge: 3,
193
- },
194
- ],
195
- },
196
- map: {},
197
- objectMap: {},
198
- });
199
- (0, vitest_1.expect)(item1.get('weird').get('foo')).toBe('bar');
200
- (0, vitest_1.expect)(item1.get('weird').get('baz').get(0).get('corge')).toBe(3);
201
- (0, vitest_1.expect)(item1.get('weird').getSnapshot()).toEqual({
202
- foo: 'bar',
203
- baz: [{ corge: 3 }],
204
- });
205
- item1.get('weird').get('baz').push({ corge: 4 });
206
- (0, vitest_1.expect)(item1.get('weird').get('baz').getSnapshot()).toEqual([
207
- { corge: 3 },
208
- { corge: 4 },
209
- ]);
210
- });
211
- (0, vitest_1.it)('should provide access and updates for map-type fields', async () => {
212
- const storage = await (0, testStorage_js_1.createTestStorage)();
213
- const item1 = await storage.weirds.put({
214
- weird: null,
215
- map: {
216
- foo: 'bar',
217
- baz: 'qux',
218
- },
219
- objectMap: {
220
- foo: {
221
- content: 'bar',
222
- },
223
- },
224
- });
225
- (0, vitest_1.expect)(item1.get('map').get('foo')).toBe('bar');
226
- (0, vitest_1.expect)(item1.get('map').get('baz')).toBe('qux');
227
- (0, vitest_1.expect)(item1.get('map').getSnapshot()).toEqual({
228
- foo: 'bar',
229
- baz: 'qux',
230
- });
231
- (0, vitest_1.expect)(item1.get('objectMap').get('foo').get('content')).toBe('bar');
232
- (0, vitest_1.expect)(item1.get('objectMap').get('baz')).toBe(undefined);
233
- item1.get('objectMap').set('baz', { content: 'qux' });
234
- (0, vitest_1.expect)(item1.get('objectMap').get('baz').get('content')).toBe('qux');
235
- });
236
- (0, vitest_1.it)('should merge .update fields and not discard undefined ones', async () => {
237
- const storage = await (0, testStorage_js_1.createTestStorage)();
238
- const item1 = await storage.weirds.put({
239
- weird: null,
240
- map: {
241
- foo: 'bar',
242
- baz: 'qux',
243
- },
244
- objectMap: {
245
- foo: {
246
- content: 'bar',
247
- },
248
- },
249
- });
250
- item1.update({
251
- weird: 'foo',
252
- });
253
- (0, vitest_1.expect)(item1.get('weird')).toBe('foo');
254
- (0, vitest_1.expect)(item1.get('map').get('foo')).toBe('bar');
255
- item1.update({
256
- weird: undefined,
257
- });
258
- (0, vitest_1.expect)(item1.get('weird')).toBe('foo');
259
- });
260
- (0, vitest_1.it)('should delete undefined fields in .update if merge is false', async () => {
261
- const storage = await (0, testStorage_js_1.createTestStorage)();
262
- const item1 = await storage.weirds.put({
263
- weird: {
264
- bar: 2,
265
- qux: 3,
266
- },
267
- map: {
268
- foo: 'bar',
269
- baz: 'qux',
270
- },
271
- objectMap: {
272
- foo: {
273
- content: 'bar',
274
- },
275
- },
276
- });
277
- item1.get('weird').update({
278
- bar: 1,
279
- }, {
280
- merge: false,
281
- });
1
+ "use strict";
2
+ var __rest = (this && this.__rest) || function (s, e) {
3
+ var t = {};
4
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
5
+ t[p] = s[p];
6
+ if (s != null && typeof Object.getOwnPropertySymbols === "function")
7
+ for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
8
+ if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
9
+ t[p[i]] = s[p[i]];
10
+ }
11
+ return t;
12
+ };
13
+ Object.defineProperty(exports, "__esModule", { value: true });
14
+ const common_1 = require("@verdant-web/common");
15
+ const vitest_1 = require("vitest");
16
+ const testStorage_js_1 = require("./fixtures/testStorage.js");
17
+ async function waitForStoragePropagation(mock) {
18
+ await new Promise((resolve, reject) => {
19
+ // timeout after 3s waiting
20
+ const timeout = setTimeout(() => reject(new Error('Waiting for storage change timed out')), 3000);
21
+ const interval = setInterval(() => {
22
+ if (mock.mock.calls.length > 0) {
23
+ clearInterval(interval);
24
+ clearTimeout(timeout);
25
+ resolve();
26
+ }
27
+ }, 0);
28
+ });
29
+ }
30
+ (0, vitest_1.describe)('storage documents', () => {
31
+ (0, vitest_1.it)('should fill in default values', async () => {
32
+ const storage = await (0, testStorage_js_1.createTestStorage)();
33
+ const item = await storage.todos.put({
34
+ content: 'item',
35
+ category: 'general',
36
+ attachments: [
37
+ {
38
+ name: 'thing',
39
+ },
40
+ ],
41
+ });
42
+ (0, vitest_1.expect)(item.get('id')).toBeDefined();
43
+ (0, vitest_1.expect)(item.get('done')).toBe(false);
44
+ (0, vitest_1.expect)(item.get('tags').length).toBe(0);
45
+ (0, vitest_1.expect)(item.get('attachments').get(0).get('test')).toBe(1);
46
+ });
47
+ (0, vitest_1.it)('should have a stable identity across different queries when subscribed', async () => {
48
+ const storage = await (0, testStorage_js_1.createTestStorage)();
49
+ const item1 = await storage.todos.put({
50
+ content: 'item 1',
51
+ done: false,
52
+ tags: [],
53
+ category: 'general',
54
+ attachments: [],
55
+ });
56
+ await storage.todos.put({
57
+ content: 'item 2',
58
+ done: true,
59
+ tags: [],
60
+ category: 'general',
61
+ attachments: [],
62
+ });
63
+ const singleItemQuery = storage.todos.get(item1.get('id'));
64
+ const singleItemResult = await singleItemQuery.resolved;
65
+ (0, vitest_1.expect)(singleItemResult).toBeTruthy();
66
+ (0, common_1.assert)(!!singleItemResult);
67
+ singleItemResult.subscribe('change', vitest_1.vi.fn());
68
+ const allItemsQuery = storage.todos.findAll();
69
+ const allItemsResult = await allItemsQuery.resolved;
70
+ const allItemsReferenceToItem1 = allItemsResult.find((item) => item.get('id') === item1.get('id'));
71
+ (0, vitest_1.expect)(singleItemResult).toBe(allItemsReferenceToItem1);
72
+ });
73
+ (0, vitest_1.it)('should immediately reflect mutations', async () => {
74
+ const storage = await (0, testStorage_js_1.createTestStorage)();
75
+ const item1 = await storage.todos.put({
76
+ content: 'item 1',
77
+ done: false,
78
+ tags: [],
79
+ category: 'general',
80
+ attachments: [],
81
+ });
82
+ item1.set('done', true);
83
+ (0, vitest_1.expect)(item1.get('done')).toBe(true);
84
+ });
85
+ (0, vitest_1.it)('should notify about changes', async () => {
86
+ const storage = await (0, testStorage_js_1.createTestStorage)();
87
+ const item1 = await storage.todos.put({
88
+ content: 'item 1',
89
+ done: false,
90
+ tags: [],
91
+ category: 'general',
92
+ attachments: [],
93
+ });
94
+ const liveItem1 = await storage.todos.get(item1.get('id')).resolved;
95
+ (0, vitest_1.expect)(liveItem1).toBeTruthy();
96
+ (0, common_1.assert)(!!liveItem1);
97
+ const callback = vitest_1.vi.fn();
98
+ liveItem1.subscribe('change', callback);
99
+ liveItem1.set('done', true);
100
+ liveItem1.set('content', 'item 1 updated');
101
+ await waitForStoragePropagation(callback);
102
+ // only 1 callback - changes are batched.
103
+ // expect(callback).toBeCalledTimes(1); // FIXME: called twice, once for immediate in-memory change and once after propagation. can this be 1?
104
+ (0, vitest_1.expect)(liveItem1.getSnapshot()).toEqual({
105
+ id: liveItem1.get('id'),
106
+ content: 'item 1 updated',
107
+ done: true,
108
+ tags: [],
109
+ category: 'general',
110
+ attachments: [],
111
+ });
112
+ const callbackDeep = vitest_1.vi.fn();
113
+ liveItem1.subscribe('changeDeep', callbackDeep);
114
+ liveItem1.update({
115
+ tags: ['tag 1', 'tag 2'],
116
+ });
117
+ await waitForStoragePropagation(callbackDeep);
118
+ (0, vitest_1.expect)(liveItem1.getSnapshot().tags).toEqual(['tag 1', 'tag 2']);
119
+ });
120
+ (0, vitest_1.it)('should expose array mutators on nested arrays', async () => {
121
+ const storage = await (0, testStorage_js_1.createTestStorage)();
122
+ const item1 = await storage.todos.put({
123
+ content: 'item 1',
124
+ done: false,
125
+ tags: [],
126
+ category: 'general',
127
+ attachments: [],
128
+ });
129
+ const callback = vitest_1.vi.fn();
130
+ item1.get('tags').subscribe('change', callback);
131
+ item1.get('tags').push('tag 1');
132
+ item1.get('tags').push('tag 2');
133
+ item1.get('tags').push('tag 3');
134
+ item1.get('tags').move(1, 2);
135
+ // fields are immediately updated
136
+ (0, vitest_1.expect)(item1.get('tags').get(0)).toEqual('tag 1');
137
+ (0, vitest_1.expect)(item1.get('tags').get(1)).toEqual('tag 3');
138
+ (0, vitest_1.expect)(item1.get('tags').get(2)).toEqual('tag 2');
139
+ await waitForStoragePropagation(callback);
140
+ (0, vitest_1.expect)(callback).toBeCalledTimes(4);
141
+ (0, vitest_1.expect)(item1.getSnapshot()).toEqual({
142
+ id: item1.get('id'),
143
+ content: 'item 1',
144
+ done: false,
145
+ tags: ['tag 1', 'tag 3', 'tag 2'],
146
+ category: 'general',
147
+ attachments: [],
148
+ });
149
+ });
150
+ (0, vitest_1.it)('should expose array accessors on nested arrays', async () => {
151
+ const storage = await (0, testStorage_js_1.createTestStorage)();
152
+ const item1 = await storage.todos.put({
153
+ content: 'item 1',
154
+ done: false,
155
+ tags: ['tag 1', 'tag 2'],
156
+ category: 'general',
157
+ attachments: [
158
+ {
159
+ name: 'attachment 1',
160
+ },
161
+ ],
162
+ });
163
+ for (const attachment of item1.get('attachments')) {
164
+ (0, vitest_1.expect)(attachment.get('name')).toBe('attachment 1');
165
+ }
166
+ let i = 0;
167
+ for (const tag of item1.get('tags')) {
168
+ (0, vitest_1.expect)(tag).toBe('tag ' + ++i);
169
+ }
170
+ (0, vitest_1.expect)(item1.get('tags').filter((tag) => tag === 'tag 1')).toEqual([
171
+ 'tag 1',
172
+ ]);
173
+ item1.get('attachments').push({
174
+ name: 'attachment 2',
175
+ });
176
+ (0, vitest_1.expect)(item1.get('attachments').getSnapshot()).toEqual([
177
+ { name: 'attachment 1', test: 1 },
178
+ { name: 'attachment 2', test: 1 },
179
+ ]);
180
+ });
181
+ (0, vitest_1.it)('should provide a reasonable way to interact with unknown data', async () => {
182
+ /**
183
+ * 'any' field types should basically just stop type checking, but still
184
+ * provide full reactive entity access for nested data.
185
+ */
186
+ const storage = await (0, testStorage_js_1.createTestStorage)();
187
+ const item1 = await storage.weirds.put({
188
+ weird: {
189
+ foo: 'bar',
190
+ baz: [
191
+ {
192
+ corge: 3,
193
+ },
194
+ ],
195
+ },
196
+ map: {},
197
+ objectMap: {},
198
+ });
199
+ (0, vitest_1.expect)(item1.get('weird').get('foo')).toBe('bar');
200
+ (0, vitest_1.expect)(item1.get('weird').get('baz').get(0).get('corge')).toBe(3);
201
+ (0, vitest_1.expect)(item1.get('weird').getSnapshot()).toEqual({
202
+ foo: 'bar',
203
+ baz: [{ corge: 3 }],
204
+ });
205
+ item1.get('weird').get('baz').push({ corge: 4 });
206
+ (0, vitest_1.expect)(item1.get('weird').get('baz').getSnapshot()).toEqual([
207
+ { corge: 3 },
208
+ { corge: 4 },
209
+ ]);
210
+ });
211
+ (0, vitest_1.it)('should provide access and updates for map-type fields', async () => {
212
+ const storage = await (0, testStorage_js_1.createTestStorage)();
213
+ const item1 = await storage.weirds.put({
214
+ weird: null,
215
+ map: {
216
+ foo: 'bar',
217
+ baz: 'qux',
218
+ },
219
+ objectMap: {
220
+ foo: {
221
+ content: 'bar',
222
+ },
223
+ },
224
+ });
225
+ (0, vitest_1.expect)(item1.get('map').get('foo')).toBe('bar');
226
+ (0, vitest_1.expect)(item1.get('map').get('baz')).toBe('qux');
227
+ (0, vitest_1.expect)(item1.get('map').getSnapshot()).toEqual({
228
+ foo: 'bar',
229
+ baz: 'qux',
230
+ });
231
+ (0, vitest_1.expect)(item1.get('objectMap').get('foo').get('content')).toBe('bar');
232
+ (0, vitest_1.expect)(item1.get('objectMap').get('baz')).toBe(undefined);
233
+ item1.get('objectMap').set('baz', { content: 'qux' });
234
+ (0, vitest_1.expect)(item1.get('objectMap').get('baz').get('content')).toBe('qux');
235
+ });
236
+ (0, vitest_1.it)('should merge .update fields and not discard undefined ones', async () => {
237
+ const storage = await (0, testStorage_js_1.createTestStorage)();
238
+ const item1 = await storage.weirds.put({
239
+ weird: null,
240
+ map: {
241
+ foo: 'bar',
242
+ baz: 'qux',
243
+ },
244
+ objectMap: {
245
+ foo: {
246
+ content: 'bar',
247
+ },
248
+ },
249
+ });
250
+ item1.update({
251
+ weird: 'foo',
252
+ });
253
+ (0, vitest_1.expect)(item1.get('weird')).toBe('foo');
254
+ (0, vitest_1.expect)(item1.get('map').get('foo')).toBe('bar');
255
+ item1.update({
256
+ weird: undefined,
257
+ });
258
+ (0, vitest_1.expect)(item1.get('weird')).toBe('foo');
259
+ });
260
+ (0, vitest_1.it)('should delete undefined fields in .update if merge is false', async () => {
261
+ const storage = await (0, testStorage_js_1.createTestStorage)();
262
+ const item1 = await storage.weirds.put({
263
+ weird: {
264
+ bar: 2,
265
+ qux: 3,
266
+ },
267
+ map: {
268
+ foo: 'bar',
269
+ baz: 'qux',
270
+ },
271
+ objectMap: {
272
+ foo: {
273
+ content: 'bar',
274
+ },
275
+ },
276
+ });
277
+ item1.get('weird').update({
278
+ bar: 1,
279
+ }, {
280
+ merge: false,
281
+ });
282
282
  (0, vitest_1.expect)(item1.get('weird').getSnapshot()).toMatchInlineSnapshot(`
283
283
  {
284
284
  "bar": 1,
285
285
  }
286
- `);
287
- });
288
- (0, vitest_1.it)('should not allow merge: false in strict schema field updates', async () => {
289
- const storage = await (0, testStorage_js_1.createTestStorage)();
290
- const item1 = await storage.todos.put({
291
- content: 'item 1',
292
- done: false,
293
- tags: [],
294
- category: 'general',
295
- attachments: [],
296
- });
297
- (0, vitest_1.expect)(() => {
298
- item1.update({ content: 'bar' }, { merge: false });
299
- }).toThrowErrorMatchingInlineSnapshot('"Cannot use .update without merge if the field has a strict schema type. merge: false is only available on \\"any\\" or \\"map\\" types."');
300
- });
301
- (0, vitest_1.it)('should apply defaults to created sub-objects in .update', async () => {
302
- const storage = await (0, testStorage_js_1.createTestStorage)();
303
- const item1 = await storage.todos.put({
304
- content: 'item 1',
305
- done: false,
306
- tags: [],
307
- category: 'general',
308
- attachments: [],
309
- });
310
- item1.update({
311
- attachments: [
312
- {
313
- name: 'attachment 1',
314
- },
315
- ],
316
- });
317
- (0, vitest_1.expect)(item1.get('attachments').get(0).get('test')).toBe(1);
318
- });
319
- (0, vitest_1.it)('should remove items from list when .delete is called', async () => {
320
- const storage = await (0, testStorage_js_1.createTestStorage)();
321
- const item1 = await storage.todos.put({
322
- content: 'item 1',
323
- done: false,
324
- tags: [],
325
- category: 'general',
326
- attachments: [],
327
- });
328
- item1.get('attachments').push({
329
- name: 'attachment 1',
330
- });
331
- item1.get('attachments').push({
332
- name: 'attachment 2',
333
- });
334
- item1.get('attachments').push({
335
- name: 'attachment 3',
336
- });
337
- item1.get('attachments').delete(1);
338
- (0, vitest_1.expect)(item1.get('attachments').length).toBe(2);
339
- (0, vitest_1.expect)(item1.get('attachments').get(0).get('name')).toBe('attachment 1');
340
- (0, vitest_1.expect)(item1.get('attachments').get(1).get('name')).toBe('attachment 3');
341
- // should work on lists which are not field-validated
342
- const item2 = await storage.weirds.put({
343
- weird: ['foo', 'bar', 'baz'],
344
- });
345
- item2.get('weird').delete(1);
346
- (0, vitest_1.expect)(item2.get('weird').length).toBe(2);
347
- (0, vitest_1.expect)(item2.get('weird').get(0)).toBe('foo');
348
- (0, vitest_1.expect)(item2.get('weird').get(1)).toBe('baz');
349
- });
350
- (0, vitest_1.it)('should expose updatedAt', async () => {
351
- const storage = await (0, testStorage_js_1.createTestStorage)();
352
- let time = new Date();
353
- vitest_1.vitest.setSystemTime(time);
354
- const item1 = await storage.todos.put({
355
- content: 'item 1',
356
- done: false,
357
- tags: [],
358
- category: 'general',
359
- attachments: [],
360
- });
361
- (0, vitest_1.expect)(item1.updatedAt).toEqual(time.getTime());
362
- time = new Date(time.getTime() + 1000);
363
- vitest_1.vitest.setSystemTime(time);
364
- item1.update({
365
- content: 'item 1 updated',
366
- });
367
- (0, vitest_1.expect)(item1.updatedAt).toEqual(time.getTime());
368
- // works on nested fields
369
- time = new Date(time.getTime() + 1000);
370
- vitest_1.vitest.setSystemTime(time);
371
- item1.get('attachments').push({
372
- name: 'attachment 1',
373
- });
374
- (0, vitest_1.expect)(item1.deepUpdatedAt).toEqual(time.getTime());
375
- time = new Date(time.getTime() + 1000);
376
- vitest_1.vitest.setSystemTime(time);
377
- item1.get('attachments').get(0).set('name', 'attachment 1 updated');
378
- (0, vitest_1.expect)(item1.deepUpdatedAt).toEqual(time.getTime());
379
- // but other items have their own updatedAt
380
- (0, vitest_1.expect)(item1.get('tags').deepUpdatedAt).not.toEqual(time.getTime());
381
- });
382
- (0, vitest_1.it)('should allow creating a new document from another document snapshot', async () => {
383
- const storage = await (0, testStorage_js_1.createTestStorage)();
384
- const item1 = await storage.todos.put({
385
- content: 'item 1',
386
- done: false,
387
- tags: ['tag 1'],
388
- category: 'general',
389
- attachments: [
390
- {
391
- name: 'attachment 1',
392
- },
393
- ],
394
- });
395
- const _a = item1.getSnapshot(), { id } = _a, snapshot = __rest(_a, ["id"]);
396
- const item2 = await storage.todos.put(snapshot);
397
- (0, vitest_1.expect)(item2.get('tags').length).toBe(1);
398
- (0, vitest_1.expect)(item2.get('attachments').length).toBe(1);
399
- item2.get('attachments').get(0).set('name', 'attachment 2');
400
- (0, vitest_1.expect)(item1.get('attachments').get(0).get('name')).toBe('attachment 1');
401
- });
402
- });
286
+ `);
287
+ });
288
+ (0, vitest_1.it)('should not allow merge: false in strict schema field updates', async () => {
289
+ const storage = await (0, testStorage_js_1.createTestStorage)();
290
+ const item1 = await storage.todos.put({
291
+ content: 'item 1',
292
+ done: false,
293
+ tags: [],
294
+ category: 'general',
295
+ attachments: [],
296
+ });
297
+ (0, vitest_1.expect)(() => {
298
+ item1.update({ content: 'bar' }, { merge: false });
299
+ }).toThrowErrorMatchingInlineSnapshot('"Cannot use .update without merge if the field has a strict schema type. merge: false is only available on \\"any\\" or \\"map\\" types."');
300
+ });
301
+ (0, vitest_1.it)('should apply defaults to created sub-objects in .update', async () => {
302
+ const storage = await (0, testStorage_js_1.createTestStorage)();
303
+ const item1 = await storage.todos.put({
304
+ content: 'item 1',
305
+ done: false,
306
+ tags: [],
307
+ category: 'general',
308
+ attachments: [],
309
+ });
310
+ item1.update({
311
+ attachments: [
312
+ {
313
+ name: 'attachment 1',
314
+ },
315
+ ],
316
+ });
317
+ (0, vitest_1.expect)(item1.get('attachments').get(0).get('test')).toBe(1);
318
+ });
319
+ (0, vitest_1.it)('should remove items from list when .delete is called', async () => {
320
+ const storage = await (0, testStorage_js_1.createTestStorage)();
321
+ const item1 = await storage.todos.put({
322
+ content: 'item 1',
323
+ done: false,
324
+ tags: [],
325
+ category: 'general',
326
+ attachments: [],
327
+ });
328
+ item1.get('attachments').push({
329
+ name: 'attachment 1',
330
+ });
331
+ item1.get('attachments').push({
332
+ name: 'attachment 2',
333
+ });
334
+ item1.get('attachments').push({
335
+ name: 'attachment 3',
336
+ });
337
+ item1.get('attachments').delete(1);
338
+ (0, vitest_1.expect)(item1.get('attachments').length).toBe(2);
339
+ (0, vitest_1.expect)(item1.get('attachments').get(0).get('name')).toBe('attachment 1');
340
+ (0, vitest_1.expect)(item1.get('attachments').get(1).get('name')).toBe('attachment 3');
341
+ // should work on lists which are not field-validated
342
+ const item2 = await storage.weirds.put({
343
+ weird: ['foo', 'bar', 'baz'],
344
+ });
345
+ item2.get('weird').delete(1);
346
+ (0, vitest_1.expect)(item2.get('weird').length).toBe(2);
347
+ (0, vitest_1.expect)(item2.get('weird').get(0)).toBe('foo');
348
+ (0, vitest_1.expect)(item2.get('weird').get(1)).toBe('baz');
349
+ });
350
+ (0, vitest_1.it)('should expose updatedAt', async () => {
351
+ const storage = await (0, testStorage_js_1.createTestStorage)();
352
+ let time = new Date();
353
+ vitest_1.vitest.setSystemTime(time);
354
+ const item1 = await storage.todos.put({
355
+ content: 'item 1',
356
+ done: false,
357
+ tags: [],
358
+ category: 'general',
359
+ attachments: [],
360
+ });
361
+ (0, vitest_1.expect)(item1.updatedAt).toEqual(time.getTime());
362
+ time = new Date(time.getTime() + 1000);
363
+ vitest_1.vitest.setSystemTime(time);
364
+ item1.update({
365
+ content: 'item 1 updated',
366
+ });
367
+ (0, vitest_1.expect)(item1.updatedAt).toEqual(time.getTime());
368
+ // works on nested fields
369
+ time = new Date(time.getTime() + 1000);
370
+ vitest_1.vitest.setSystemTime(time);
371
+ item1.get('attachments').push({
372
+ name: 'attachment 1',
373
+ });
374
+ (0, vitest_1.expect)(item1.deepUpdatedAt).toEqual(time.getTime());
375
+ time = new Date(time.getTime() + 1000);
376
+ vitest_1.vitest.setSystemTime(time);
377
+ item1.get('attachments').get(0).set('name', 'attachment 1 updated');
378
+ (0, vitest_1.expect)(item1.deepUpdatedAt).toEqual(time.getTime());
379
+ // but other items have their own updatedAt
380
+ (0, vitest_1.expect)(item1.get('tags').deepUpdatedAt).not.toEqual(time.getTime());
381
+ });
382
+ (0, vitest_1.it)('should allow creating a new document from another document snapshot', async () => {
383
+ const storage = await (0, testStorage_js_1.createTestStorage)();
384
+ const item1 = await storage.todos.put({
385
+ content: 'item 1',
386
+ done: false,
387
+ tags: ['tag 1'],
388
+ category: 'general',
389
+ attachments: [
390
+ {
391
+ name: 'attachment 1',
392
+ },
393
+ ],
394
+ });
395
+ const _a = item1.getSnapshot(), { id } = _a, snapshot = __rest(_a, ["id"]);
396
+ const item2 = await storage.todos.put(snapshot);
397
+ (0, vitest_1.expect)(item2.get('tags').length).toBe(1);
398
+ (0, vitest_1.expect)(item2.get('attachments').length).toBe(1);
399
+ item2.get('attachments').get(0).set('name', 'attachment 2');
400
+ (0, vitest_1.expect)(item1.get('attachments').get(0).get('name')).toBe('attachment 1');
401
+ });
402
+ });
403
403
  //# sourceMappingURL=documents.test.js.map