@verdant-web/store 2.0.1 → 2.0.2

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