jazz-tools 0.14.28 → 0.15.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (887) hide show
  1. package/.svelte-kit/__package__/Provider.svelte +61 -0
  2. package/.svelte-kit/__package__/Provider.svelte.d.ts +19 -0
  3. package/.svelte-kit/__package__/Provider.svelte.d.ts.map +1 -0
  4. package/.svelte-kit/__package__/auth/PasskeyAuth.svelte.d.ts +11 -0
  5. package/.svelte-kit/__package__/auth/PasskeyAuth.svelte.d.ts.map +1 -0
  6. package/.svelte-kit/__package__/auth/PasskeyAuth.svelte.js +20 -0
  7. package/.svelte-kit/__package__/auth/PasskeyAuthBasicUI.svelte +81 -0
  8. package/.svelte-kit/__package__/auth/PasskeyAuthBasicUI.svelte.d.ts +9 -0
  9. package/.svelte-kit/__package__/auth/PasskeyAuthBasicUI.svelte.d.ts.map +1 -0
  10. package/.svelte-kit/__package__/auth/PassphraseAuth.svelte.d.ts +12 -0
  11. package/.svelte-kit/__package__/auth/PassphraseAuth.svelte.d.ts.map +1 -0
  12. package/.svelte-kit/__package__/auth/PassphraseAuth.svelte.js +30 -0
  13. package/.svelte-kit/__package__/auth/index.d.ts +4 -0
  14. package/.svelte-kit/__package__/auth/index.d.ts.map +1 -0
  15. package/.svelte-kit/__package__/auth/index.js +3 -0
  16. package/.svelte-kit/__package__/auth/useIsAuthenticated.svelte.d.ts +6 -0
  17. package/.svelte-kit/__package__/auth/useIsAuthenticated.svelte.d.ts.map +1 -0
  18. package/.svelte-kit/__package__/auth/useIsAuthenticated.svelte.js +22 -0
  19. package/.svelte-kit/__package__/index.d.ts +6 -0
  20. package/.svelte-kit/__package__/index.d.ts.map +1 -0
  21. package/.svelte-kit/__package__/index.js +5 -0
  22. package/.svelte-kit/__package__/jazz.class.svelte.d.ts +21 -0
  23. package/.svelte-kit/__package__/jazz.class.svelte.d.ts.map +1 -0
  24. package/.svelte-kit/__package__/jazz.class.svelte.js +117 -0
  25. package/.svelte-kit/__package__/jazz.svelte.d.ts +39 -0
  26. package/.svelte-kit/__package__/jazz.svelte.d.ts.map +1 -0
  27. package/.svelte-kit/__package__/jazz.svelte.js +70 -0
  28. package/.svelte-kit/__package__/testing.d.ts +10 -0
  29. package/.svelte-kit/__package__/testing.d.ts.map +1 -0
  30. package/.svelte-kit/__package__/testing.js +23 -0
  31. package/.turbo/turbo-build.log +180 -11
  32. package/CHANGELOG.md +26 -0
  33. package/README.md +2 -2
  34. package/dist/browser/BrowserContextManager.d.ts +31 -0
  35. package/dist/browser/BrowserContextManager.d.ts.map +1 -0
  36. package/dist/browser/auth/LocalStorageKVStore.d.ts +9 -0
  37. package/dist/browser/auth/LocalStorageKVStore.d.ts.map +1 -0
  38. package/dist/browser/auth/PasskeyAuth.d.ts +27 -0
  39. package/dist/browser/auth/PasskeyAuth.d.ts.map +1 -0
  40. package/dist/browser/createBrowserContext.d.ts +47 -0
  41. package/dist/browser/createBrowserContext.d.ts.map +1 -0
  42. package/dist/browser/index.d.ts +23 -0
  43. package/dist/browser/index.d.ts.map +1 -0
  44. package/dist/browser/index.js +469 -0
  45. package/dist/browser/index.js.map +1 -0
  46. package/dist/browser/storageOptions.d.ts +8 -0
  47. package/dist/browser/storageOptions.d.ts.map +1 -0
  48. package/dist/browser/tests/LocalStorageKVStore.test.d.ts +2 -0
  49. package/dist/browser/tests/LocalStorageKVStore.test.d.ts.map +1 -0
  50. package/dist/browser/tests/PasskeyAuth.test.d.ts +2 -0
  51. package/dist/browser/tests/PasskeyAuth.test.d.ts.map +1 -0
  52. package/dist/browser/tests/createInviteLink.test.d.ts +2 -0
  53. package/dist/browser/tests/createInviteLink.test.d.ts.map +1 -0
  54. package/dist/browser/tests/storageOptions.test.d.ts +2 -0
  55. package/dist/browser/tests/storageOptions.test.d.ts.map +1 -0
  56. package/dist/browser/tests/utils.d.ts +11 -0
  57. package/dist/browser/tests/utils.d.ts.map +1 -0
  58. package/dist/browser/utils/export-account-inspector.d.ts +6 -0
  59. package/dist/browser/utils/export-account-inspector.d.ts.map +1 -0
  60. package/dist/browser-media-images/index.d.ts +7 -0
  61. package/dist/browser-media-images/index.d.ts.map +1 -0
  62. package/dist/browser-media-images/index.js +70 -0
  63. package/dist/browser-media-images/index.js.map +1 -0
  64. package/dist/chunk-VBDJM6Z5.js +4938 -0
  65. package/dist/chunk-VBDJM6Z5.js.map +1 -0
  66. package/dist/expo/auth/clerk/index.d.ts +7 -0
  67. package/dist/expo/auth/clerk/index.d.ts.map +1 -0
  68. package/dist/expo/crypto.d.ts +2 -0
  69. package/dist/expo/crypto.d.ts.map +1 -0
  70. package/dist/expo/crypto.js +3 -0
  71. package/dist/expo/crypto.js.map +1 -0
  72. package/dist/expo/index.d.ts +6 -0
  73. package/dist/expo/index.d.ts.map +1 -0
  74. package/dist/expo/index.js +168 -0
  75. package/dist/expo/index.js.map +1 -0
  76. package/dist/expo/provider.d.ts +4 -0
  77. package/dist/expo/provider.d.ts.map +1 -0
  78. package/dist/expo/storage/expo-secure-store-adapter.d.ts +8 -0
  79. package/dist/expo/storage/expo-secure-store-adapter.d.ts.map +1 -0
  80. package/dist/expo/storage/expo-sqlite-adapter.d.ts +18 -0
  81. package/dist/expo/storage/expo-sqlite-adapter.d.ts.map +1 -0
  82. package/dist/expo/testing.d.ts +2 -0
  83. package/dist/expo/testing.d.ts.map +1 -0
  84. package/dist/expo/testing.js +3 -0
  85. package/dist/expo/testing.js.map +1 -0
  86. package/dist/index.d.ts +1 -2
  87. package/dist/index.d.ts.map +1 -1
  88. package/dist/index.js +172 -6
  89. package/dist/index.js.map +1 -1
  90. package/dist/inspector/custom-element-CWW72LEG.js +31971 -0
  91. package/dist/inspector/custom-element-CWW72LEG.js.map +1 -0
  92. package/dist/inspector/custom-element.d.ts +13 -0
  93. package/dist/inspector/custom-element.d.ts.map +1 -0
  94. package/dist/inspector/index.d.ts +12 -0
  95. package/dist/inspector/index.d.ts.map +1 -0
  96. package/dist/inspector/index.js +2053 -0
  97. package/dist/inspector/index.js.map +1 -0
  98. package/dist/inspector/register-custom-element.d.ts +2 -0
  99. package/dist/inspector/register-custom-element.d.ts.map +1 -0
  100. package/dist/inspector/register-custom-element.js +5 -0
  101. package/dist/inspector/register-custom-element.js.map +1 -0
  102. package/dist/inspector/ui/badge.d.ts +4 -0
  103. package/dist/inspector/ui/badge.d.ts.map +1 -0
  104. package/dist/inspector/ui/button.d.ts +9 -0
  105. package/dist/inspector/ui/button.d.ts.map +1 -0
  106. package/dist/inspector/ui/card.d.ts +10 -0
  107. package/dist/inspector/ui/card.d.ts.map +1 -0
  108. package/dist/inspector/ui/global-styles.d.ts +4 -0
  109. package/dist/inspector/ui/global-styles.d.ts.map +1 -0
  110. package/dist/inspector/ui/grid.d.ts +4 -0
  111. package/dist/inspector/ui/grid.d.ts.map +1 -0
  112. package/dist/inspector/ui/heading.d.ts +4 -0
  113. package/dist/inspector/ui/heading.d.ts.map +1 -0
  114. package/dist/inspector/ui/icon.d.ts +30 -0
  115. package/dist/inspector/ui/icon.d.ts.map +1 -0
  116. package/dist/inspector/ui/icons/chevron-down-icon.d.ts +2 -0
  117. package/dist/inspector/ui/icons/chevron-down-icon.d.ts.map +1 -0
  118. package/dist/inspector/ui/icons/delete-icon.d.ts +2 -0
  119. package/dist/inspector/ui/icons/delete-icon.d.ts.map +1 -0
  120. package/dist/inspector/ui/icons/link-icon.d.ts +2 -0
  121. package/dist/inspector/ui/icons/link-icon.d.ts.map +1 -0
  122. package/dist/inspector/ui/input.d.ts +11 -0
  123. package/dist/inspector/ui/input.d.ts.map +1 -0
  124. package/dist/inspector/ui/select.d.ts +5 -0
  125. package/dist/inspector/ui/select.d.ts.map +1 -0
  126. package/dist/inspector/ui/table.d.ts +8 -0
  127. package/dist/inspector/ui/table.d.ts.map +1 -0
  128. package/dist/inspector/ui/text.d.ts +10 -0
  129. package/dist/inspector/ui/text.d.ts.map +1 -0
  130. package/dist/inspector/viewer/account-or-group-text.d.ts +8 -0
  131. package/dist/inspector/viewer/account-or-group-text.d.ts.map +1 -0
  132. package/dist/inspector/viewer/account-view.d.ts +8 -0
  133. package/dist/inspector/viewer/account-view.d.ts.map +1 -0
  134. package/dist/inspector/viewer/breadcrumbs.d.ts +9 -0
  135. package/dist/inspector/viewer/breadcrumbs.d.ts.map +1 -0
  136. package/dist/inspector/viewer/co-stream-view.d.ts +18 -0
  137. package/dist/inspector/viewer/co-stream-view.d.ts.map +1 -0
  138. package/dist/inspector/viewer/grid-view.d.ts +9 -0
  139. package/dist/inspector/viewer/grid-view.d.ts.map +1 -0
  140. package/dist/inspector/viewer/group-view.d.ts +8 -0
  141. package/dist/inspector/viewer/group-view.d.ts.map +1 -0
  142. package/dist/inspector/viewer/inpsector-button.d.ts +6 -0
  143. package/dist/inspector/viewer/inpsector-button.d.ts.map +1 -0
  144. package/dist/inspector/viewer/new-app.d.ts +11 -0
  145. package/dist/inspector/viewer/new-app.d.ts.map +1 -0
  146. package/dist/inspector/viewer/page-stack.d.ts +15 -0
  147. package/dist/inspector/viewer/page-stack.d.ts.map +1 -0
  148. package/dist/inspector/viewer/page.d.ts +16 -0
  149. package/dist/inspector/viewer/page.d.ts.map +1 -0
  150. package/dist/inspector/viewer/raw-data-card.d.ts +5 -0
  151. package/dist/inspector/viewer/raw-data-card.d.ts.map +1 -0
  152. package/dist/inspector/viewer/role-display.d.ts +6 -0
  153. package/dist/inspector/viewer/role-display.d.ts.map +1 -0
  154. package/dist/inspector/viewer/table-viewer.d.ts +9 -0
  155. package/dist/inspector/viewer/table-viewer.d.ts.map +1 -0
  156. package/dist/inspector/viewer/type-icon.d.ts +11 -0
  157. package/dist/inspector/viewer/type-icon.d.ts.map +1 -0
  158. package/dist/inspector/viewer/types.d.ts +7 -0
  159. package/dist/inspector/viewer/types.d.ts.map +1 -0
  160. package/dist/inspector/viewer/use-open-inspector.d.ts +2 -0
  161. package/dist/inspector/viewer/use-open-inspector.d.ts.map +1 -0
  162. package/dist/inspector/viewer/use-page-path.d.ts +10 -0
  163. package/dist/inspector/viewer/use-page-path.d.ts.map +1 -0
  164. package/dist/inspector/viewer/use-resolve-covalue.d.ts +67 -0
  165. package/dist/inspector/viewer/use-resolve-covalue.d.ts.map +1 -0
  166. package/dist/inspector/viewer/value-renderer.d.ts +12 -0
  167. package/dist/inspector/viewer/value-renderer.d.ts.map +1 -0
  168. package/dist/prosemirror/index.d.ts +3 -0
  169. package/dist/prosemirror/index.d.ts.map +1 -0
  170. package/dist/prosemirror/index.js +2185 -0
  171. package/dist/prosemirror/index.js.map +1 -0
  172. package/dist/prosemirror/lib/converter.d.ts +33 -0
  173. package/dist/prosemirror/lib/converter.d.ts.map +1 -0
  174. package/dist/prosemirror/lib/plugin.d.ts +43 -0
  175. package/dist/prosemirror/lib/plugin.d.ts.map +1 -0
  176. package/dist/prosemirror/lib/sync.d.ts +35 -0
  177. package/dist/prosemirror/lib/sync.d.ts.map +1 -0
  178. package/dist/prosemirror/tests/plugin.test.d.ts +2 -0
  179. package/dist/prosemirror/tests/plugin.test.d.ts.map +1 -0
  180. package/dist/react/auth/Clerk.d.ts +7 -0
  181. package/dist/react/auth/Clerk.d.ts.map +1 -0
  182. package/dist/react/auth/DemoAuth.d.ts +5 -0
  183. package/dist/react/auth/DemoAuth.d.ts.map +1 -0
  184. package/dist/react/auth/PasskeyAuth.d.ts +24 -0
  185. package/dist/react/auth/PasskeyAuth.d.ts.map +1 -0
  186. package/dist/react/auth/PassphraseAuth.d.ts +6 -0
  187. package/dist/react/auth/PassphraseAuth.d.ts.map +1 -0
  188. package/dist/react/auth/auth.d.ts +6 -0
  189. package/dist/react/auth/auth.d.ts.map +1 -0
  190. package/dist/react/hooks.d.ts +9 -0
  191. package/dist/react/hooks.d.ts.map +1 -0
  192. package/dist/react/index.d.ts +8 -0
  193. package/dist/react/index.d.ts.map +1 -0
  194. package/dist/react/index.js +698 -0
  195. package/dist/react/index.js.map +1 -0
  196. package/dist/react/media.d.ts +24 -0
  197. package/dist/react/media.d.ts.map +1 -0
  198. package/dist/react/provider.d.ts +10 -0
  199. package/dist/react/provider.d.ts.map +1 -0
  200. package/dist/react/ssr.d.ts +4 -0
  201. package/dist/react/ssr.d.ts.map +1 -0
  202. package/dist/react/ssr.js +25 -0
  203. package/dist/react/ssr.js.map +1 -0
  204. package/dist/react/testing.d.ts +2 -0
  205. package/dist/react/testing.d.ts.map +1 -0
  206. package/dist/react/testing.js +3 -0
  207. package/dist/react/testing.js.map +1 -0
  208. package/dist/react/tests/testUtils.d.ts +14 -0
  209. package/dist/react/tests/testUtils.d.ts.map +1 -0
  210. package/dist/react/tests/useAcceptInvite.test.d.ts +2 -0
  211. package/dist/react/tests/useAcceptInvite.test.d.ts.map +1 -0
  212. package/dist/react-core/auth/DemoAuth.d.ts +17 -0
  213. package/dist/react-core/auth/DemoAuth.d.ts.map +1 -0
  214. package/dist/react-core/auth/PassphraseAuth.d.ts +21 -0
  215. package/dist/react-core/auth/PassphraseAuth.d.ts.map +1 -0
  216. package/dist/react-core/auth/index.d.ts +3 -0
  217. package/dist/react-core/auth/index.d.ts.map +1 -0
  218. package/dist/react-core/chunk-7DYMJ74I.js +12 -0
  219. package/dist/react-core/chunk-7DYMJ74I.js.map +1 -0
  220. package/dist/react-core/hooks.d.ts +17 -0
  221. package/dist/react-core/hooks.d.ts.map +1 -0
  222. package/dist/react-core/index.d.ts +4 -0
  223. package/dist/react-core/index.d.ts.map +1 -0
  224. package/dist/react-core/index.js +302 -0
  225. package/dist/react-core/index.js.map +1 -0
  226. package/dist/react-core/provider.d.ts +5 -0
  227. package/dist/react-core/provider.d.ts.map +1 -0
  228. package/dist/react-core/testing.d.ts +10 -0
  229. package/dist/react-core/testing.d.ts.map +1 -0
  230. package/dist/react-core/testing.js +43 -0
  231. package/dist/react-core/testing.js.map +1 -0
  232. package/dist/react-core/tests/fixtures.d.ts.map +1 -0
  233. package/dist/react-core/tests/testUtils.d.ts +15 -0
  234. package/dist/react-core/tests/testUtils.d.ts.map +1 -0
  235. package/dist/react-core/tests/useAccount.test.d.ts +2 -0
  236. package/dist/react-core/tests/useAccount.test.d.ts.map +1 -0
  237. package/dist/react-core/tests/useCoState.test.d.ts +2 -0
  238. package/dist/react-core/tests/useCoState.test.d.ts.map +1 -0
  239. package/dist/react-core/tests/useInboxSender.test.d.ts +2 -0
  240. package/dist/react-core/tests/useInboxSender.test.d.ts.map +1 -0
  241. package/dist/react-core/tests/useIsAuthenticated.test.d.ts +2 -0
  242. package/dist/react-core/tests/useIsAuthenticated.test.d.ts.map +1 -0
  243. package/dist/react-core/tests/usePassPhraseAuth.test.d.ts +2 -0
  244. package/dist/react-core/tests/usePassPhraseAuth.test.d.ts.map +1 -0
  245. package/dist/react-core/utils.d.ts +4 -0
  246. package/dist/react-core/utils.d.ts.map +1 -0
  247. package/dist/react-native/crypto.d.ts +2 -0
  248. package/dist/react-native/crypto.d.ts.map +1 -0
  249. package/dist/react-native/crypto.js +3 -0
  250. package/dist/react-native/crypto.js.map +1 -0
  251. package/dist/react-native/index.d.ts +5 -0
  252. package/dist/react-native/index.d.ts.map +1 -0
  253. package/dist/react-native/index.js +103 -0
  254. package/dist/react-native/index.js.map +1 -0
  255. package/dist/react-native/provider.d.ts +4 -0
  256. package/dist/react-native/provider.d.ts.map +1 -0
  257. package/dist/react-native/storage/mmkv-store-adapter.d.ts +8 -0
  258. package/dist/react-native/storage/mmkv-store-adapter.d.ts.map +1 -0
  259. package/dist/react-native/storage/op-sqlite-adapter.d.ts +13 -0
  260. package/dist/react-native/storage/op-sqlite-adapter.d.ts.map +1 -0
  261. package/dist/react-native/testing.d.ts +2 -0
  262. package/dist/react-native/testing.d.ts.map +1 -0
  263. package/dist/react-native/testing.js +3 -0
  264. package/dist/react-native/testing.js.map +1 -0
  265. package/dist/react-native-core/ReactNativeContextManager.d.ts +31 -0
  266. package/dist/react-native-core/ReactNativeContextManager.d.ts.map +1 -0
  267. package/dist/react-native-core/auth/DemoAuthUI.d.ts +8 -0
  268. package/dist/react-native-core/auth/DemoAuthUI.d.ts.map +1 -0
  269. package/dist/react-native-core/auth/auth.d.ts +3 -0
  270. package/dist/react-native-core/auth/auth.d.ts.map +1 -0
  271. package/dist/react-native-core/crypto/RNQuickCrypto.d.ts +15 -0
  272. package/dist/react-native-core/crypto/RNQuickCrypto.d.ts.map +1 -0
  273. package/dist/react-native-core/crypto/index.d.ts +2 -0
  274. package/dist/react-native-core/crypto/index.d.ts.map +1 -0
  275. package/dist/react-native-core/crypto.js +65 -0
  276. package/dist/react-native-core/crypto.js.map +1 -0
  277. package/dist/react-native-core/hooks.d.ts +8 -0
  278. package/dist/react-native-core/hooks.d.ts.map +1 -0
  279. package/dist/react-native-core/index.d.ts +9 -0
  280. package/dist/react-native-core/index.d.ts.map +1 -0
  281. package/dist/react-native-core/index.js +653 -0
  282. package/dist/react-native-core/index.js.map +1 -0
  283. package/dist/react-native-core/media.d.ts +24 -0
  284. package/dist/react-native-core/media.d.ts.map +1 -0
  285. package/dist/react-native-core/platform.d.ts +45 -0
  286. package/dist/react-native-core/platform.d.ts.map +1 -0
  287. package/dist/react-native-core/provider.d.ts +10 -0
  288. package/dist/react-native-core/provider.d.ts.map +1 -0
  289. package/dist/react-native-core/storage/kv-store-context.d.ts +17 -0
  290. package/dist/react-native-core/storage/kv-store-context.d.ts.map +1 -0
  291. package/dist/react-native-core/storage/sqlite-react-native.d.ts +9 -0
  292. package/dist/react-native-core/storage/sqlite-react-native.d.ts.map +1 -0
  293. package/dist/react-native-core/testing.js +3 -0
  294. package/dist/react-native-core/testing.js.map +1 -0
  295. package/dist/react-native-media-images/index.d.ts +7 -0
  296. package/dist/react-native-media-images/index.d.ts.map +1 -0
  297. package/dist/react-native-media-images/index.js +177 -0
  298. package/dist/react-native-media-images/index.js.map +1 -0
  299. package/dist/svelte/Provider.svelte +61 -0
  300. package/dist/svelte/Provider.svelte.d.ts +19 -0
  301. package/dist/svelte/Provider.svelte.d.ts.map +1 -0
  302. package/dist/svelte/auth/PasskeyAuth.svelte.d.ts +11 -0
  303. package/dist/svelte/auth/PasskeyAuth.svelte.d.ts.map +1 -0
  304. package/dist/svelte/auth/PasskeyAuth.svelte.js +20 -0
  305. package/dist/svelte/auth/PasskeyAuthBasicUI.svelte +81 -0
  306. package/dist/svelte/auth/PasskeyAuthBasicUI.svelte.d.ts +9 -0
  307. package/dist/svelte/auth/PasskeyAuthBasicUI.svelte.d.ts.map +1 -0
  308. package/dist/svelte/auth/PassphraseAuth.svelte.d.ts +12 -0
  309. package/dist/svelte/auth/PassphraseAuth.svelte.d.ts.map +1 -0
  310. package/dist/svelte/auth/PassphraseAuth.svelte.js +30 -0
  311. package/dist/svelte/auth/index.d.ts +4 -0
  312. package/dist/svelte/auth/index.d.ts.map +1 -0
  313. package/dist/svelte/auth/index.js +3 -0
  314. package/dist/svelte/auth/useIsAuthenticated.svelte.d.ts +6 -0
  315. package/dist/svelte/auth/useIsAuthenticated.svelte.d.ts.map +1 -0
  316. package/dist/svelte/auth/useIsAuthenticated.svelte.js +22 -0
  317. package/dist/svelte/index.d.ts +6 -0
  318. package/dist/svelte/index.d.ts.map +1 -0
  319. package/dist/svelte/index.js +5 -0
  320. package/dist/svelte/jazz.class.svelte.d.ts +21 -0
  321. package/dist/svelte/jazz.class.svelte.d.ts.map +1 -0
  322. package/dist/svelte/jazz.class.svelte.js +117 -0
  323. package/dist/svelte/jazz.svelte.d.ts +39 -0
  324. package/dist/svelte/jazz.svelte.d.ts.map +1 -0
  325. package/dist/svelte/jazz.svelte.js +70 -0
  326. package/dist/svelte/testing.d.ts +10 -0
  327. package/dist/svelte/testing.d.ts.map +1 -0
  328. package/dist/svelte/testing.js +23 -0
  329. package/dist/testing.d.ts +1 -42
  330. package/dist/testing.d.ts.map +1 -1
  331. package/dist/testing.js +2 -2
  332. package/dist/testing.js.map +1 -1
  333. package/dist/tiptap/index.d.ts +11 -0
  334. package/dist/tiptap/index.d.ts.map +1 -0
  335. package/dist/tiptap/index.js +22 -0
  336. package/dist/tiptap/index.js.map +1 -0
  337. package/dist/tools/auth/AuthSecretStorage.d.ts.map +1 -0
  338. package/dist/tools/auth/DemoAuth.d.ts.map +1 -0
  339. package/dist/tools/auth/InMemoryKVStore.d.ts.map +1 -0
  340. package/dist/tools/auth/KvStoreContext.d.ts.map +1 -0
  341. package/dist/tools/auth/PassphraseAuth.d.ts.map +1 -0
  342. package/dist/tools/auth/clerk/getClerkUsername.d.ts +3 -0
  343. package/dist/tools/auth/clerk/getClerkUsername.d.ts.map +1 -0
  344. package/dist/tools/auth/clerk/index.d.ts +25 -0
  345. package/dist/tools/auth/clerk/index.d.ts.map +1 -0
  346. package/dist/tools/auth/clerk/tests/JazzClerkAuth.test.d.ts +2 -0
  347. package/dist/tools/auth/clerk/tests/JazzClerkAuth.test.d.ts.map +1 -0
  348. package/dist/tools/auth/clerk/tests/getClerkUsername.test.d.ts +2 -0
  349. package/dist/tools/auth/clerk/tests/getClerkUsername.test.d.ts.map +1 -0
  350. package/dist/tools/auth/clerk/tests/types.test.d.ts +2 -0
  351. package/dist/tools/auth/clerk/tests/types.test.d.ts.map +1 -0
  352. package/dist/tools/auth/clerk/types.d.ts +32 -0
  353. package/dist/tools/auth/clerk/types.d.ts.map +1 -0
  354. package/dist/tools/coValues/CoValueBase.d.ts.map +1 -0
  355. package/dist/tools/coValues/account.d.ts.map +1 -0
  356. package/dist/tools/coValues/coFeed.d.ts +377 -0
  357. package/dist/tools/coValues/coFeed.d.ts.map +1 -0
  358. package/dist/tools/coValues/coList.d.ts.map +1 -0
  359. package/dist/tools/coValues/coMap.d.ts +625 -0
  360. package/dist/tools/coValues/coMap.d.ts.map +1 -0
  361. package/dist/tools/coValues/coPlainText.d.ts.map +1 -0
  362. package/dist/tools/coValues/coRichText.d.ts.map +1 -0
  363. package/dist/tools/coValues/deepLoading.d.ts.map +1 -0
  364. package/dist/tools/coValues/extensions/imageDef.d.ts.map +1 -0
  365. package/dist/tools/coValues/group.d.ts.map +1 -0
  366. package/dist/tools/coValues/inbox.d.ts.map +1 -0
  367. package/dist/tools/coValues/interfaces.d.ts +116 -0
  368. package/dist/tools/coValues/interfaces.d.ts.map +1 -0
  369. package/dist/tools/coValues/profile.d.ts.map +1 -0
  370. package/dist/tools/coValues/registeredSchemas.d.ts.map +1 -0
  371. package/dist/tools/coValues/schemaUnion.d.ts.map +1 -0
  372. package/dist/tools/exports.d.ts +24 -0
  373. package/dist/tools/exports.d.ts.map +1 -0
  374. package/dist/tools/implementation/ContextManager.d.ts.map +1 -0
  375. package/dist/tools/implementation/activeAccountContext.d.ts.map +1 -0
  376. package/dist/tools/implementation/anonymousJazzAgent.d.ts.map +1 -0
  377. package/dist/tools/implementation/createContext.d.ts.map +1 -0
  378. package/dist/tools/implementation/devtoolsFormatters.d.ts.map +1 -0
  379. package/dist/tools/implementation/errors.d.ts.map +1 -0
  380. package/dist/tools/implementation/inspect.d.ts.map +1 -0
  381. package/dist/tools/implementation/invites.d.ts.map +1 -0
  382. package/dist/tools/implementation/refs.d.ts.map +1 -0
  383. package/dist/tools/implementation/schema.d.ts.map +1 -0
  384. package/dist/tools/implementation/symbols.d.ts.map +1 -0
  385. package/dist/tools/implementation/zodSchema/coExport.d.ts.map +1 -0
  386. package/dist/tools/implementation/zodSchema/runtimeConverters/zodFieldToCoFieldDef.d.ts.map +1 -0
  387. package/dist/tools/implementation/zodSchema/runtimeConverters/zodSchemaToCoSchema.d.ts.map +1 -0
  388. package/dist/tools/implementation/zodSchema/schemaTypes/AccountSchema.d.ts.map +1 -0
  389. package/dist/tools/implementation/zodSchema/schemaTypes/CoFeedSchema.d.ts.map +1 -0
  390. package/dist/tools/implementation/zodSchema/schemaTypes/CoListSchema.d.ts.map +1 -0
  391. package/dist/tools/implementation/zodSchema/schemaTypes/CoMapSchema.d.ts +64 -0
  392. package/dist/tools/implementation/zodSchema/schemaTypes/CoMapSchema.d.ts.map +1 -0
  393. package/dist/tools/implementation/zodSchema/schemaTypes/CoRecordSchema.d.ts.map +1 -0
  394. package/dist/tools/implementation/zodSchema/schemaTypes/FileStreamSchema.d.ts.map +1 -0
  395. package/dist/tools/implementation/zodSchema/schemaTypes/PlainTextSchema.d.ts.map +1 -0
  396. package/dist/tools/implementation/zodSchema/schemaTypes/RichTextSchema.d.ts.map +1 -0
  397. package/dist/tools/implementation/zodSchema/typeConverters/InstanceOfSchema.d.ts.map +1 -0
  398. package/dist/tools/implementation/zodSchema/typeConverters/InstanceOfSchemaCoValuesNullable.d.ts.map +1 -0
  399. package/dist/tools/implementation/zodSchema/typeConverters/InstanceOrPrimitiveOfSchema.d.ts.map +1 -0
  400. package/dist/tools/implementation/zodSchema/typeConverters/InstanceOrPrimitiveOfSchemaCoValuesNullable.d.ts.map +1 -0
  401. package/dist/tools/implementation/zodSchema/unionUtils.d.ts.map +1 -0
  402. package/dist/tools/implementation/zodSchema/zodCo.d.ts.map +1 -0
  403. package/dist/tools/implementation/zodSchema/zodReExport.d.ts.map +1 -0
  404. package/dist/tools/implementation/zodSchema/zodSchema.d.ts.map +1 -0
  405. package/dist/tools/index.d.ts +3 -0
  406. package/dist/tools/index.d.ts.map +1 -0
  407. package/dist/tools/internal.d.ts.map +1 -0
  408. package/dist/tools/lib/cache.d.ts.map +1 -0
  409. package/dist/tools/lib/cache.test.d.ts.map +1 -0
  410. package/dist/tools/lib/migration.d.ts.map +1 -0
  411. package/dist/tools/subscribe/CoValueCoreSubscription.d.ts +15 -0
  412. package/dist/tools/subscribe/CoValueCoreSubscription.d.ts.map +1 -0
  413. package/dist/tools/subscribe/JazzError.d.ts.map +1 -0
  414. package/dist/tools/subscribe/SubscriptionScope.d.ts +47 -0
  415. package/dist/tools/subscribe/SubscriptionScope.d.ts.map +1 -0
  416. package/dist/tools/subscribe/index.d.ts.map +1 -0
  417. package/dist/tools/subscribe/types.d.ts.map +1 -0
  418. package/dist/tools/subscribe/utils.d.ts.map +1 -0
  419. package/dist/tools/testing.d.ts +43 -0
  420. package/dist/tools/testing.d.ts.map +1 -0
  421. package/dist/tools/tests/AuthSecretStorage.test.d.ts.map +1 -0
  422. package/dist/tools/tests/ContextManager.test.d.ts.map +1 -0
  423. package/dist/tools/tests/DemoAuth.test.d.ts.map +1 -0
  424. package/dist/tools/tests/PassphraseAuth.test.d.ts.map +1 -0
  425. package/dist/tools/tests/account.test.d.ts.map +1 -0
  426. package/dist/tools/tests/coFeed.test-d.d.ts.map +1 -0
  427. package/dist/tools/tests/coFeed.test.d.ts.map +1 -0
  428. package/dist/tools/tests/coList.test-d.d.ts.map +1 -0
  429. package/dist/tools/tests/coList.test.d.ts.map +1 -0
  430. package/dist/tools/tests/coMap.record.test-d.d.ts.map +1 -0
  431. package/dist/tools/tests/coMap.record.test.d.ts.map +1 -0
  432. package/dist/tools/tests/coMap.test-d.d.ts.map +1 -0
  433. package/dist/tools/tests/coMap.test.d.ts.map +1 -0
  434. package/dist/tools/tests/coPlainText.test.d.ts.map +1 -0
  435. package/dist/tools/tests/createContext.test.d.ts.map +1 -0
  436. package/dist/tools/tests/deepLoading.test.d.ts.map +1 -0
  437. package/dist/tools/tests/fixtures.d.ts +2 -0
  438. package/dist/tools/tests/fixtures.d.ts.map +1 -0
  439. package/dist/tools/tests/groupsAndAccounts.test.d.ts.map +1 -0
  440. package/dist/tools/tests/imageDef.test.d.ts.map +1 -0
  441. package/dist/tools/tests/inbox.test.d.ts.map +1 -0
  442. package/dist/tools/tests/interfaces.test.d.ts.map +1 -0
  443. package/dist/tools/tests/invites.test.d.ts.map +1 -0
  444. package/dist/tools/tests/load.test.d.ts.map +1 -0
  445. package/dist/tools/tests/patterns/notifications.test.d.ts.map +1 -0
  446. package/dist/tools/tests/patterns/requestToJoin.test.d.ts.map +1 -0
  447. package/dist/tools/tests/schema.test.d.ts.map +1 -0
  448. package/dist/tools/tests/schemaUnion.test.d.ts.map +1 -0
  449. package/dist/tools/tests/subscribe.test.d.ts.map +1 -0
  450. package/dist/tools/tests/testing.test.d.ts.map +1 -0
  451. package/dist/tools/tests/utils.d.ts.map +1 -0
  452. package/dist/tools/tests/zod.test.d.ts.map +1 -0
  453. package/dist/tools/types.d.ts.map +1 -0
  454. package/dist/worker/index.d.ts +25 -0
  455. package/dist/worker/index.d.ts.map +1 -0
  456. package/dist/worker/index.js +93 -0
  457. package/dist/worker/index.js.map +1 -0
  458. package/package.json +193 -11
  459. package/src/browser/BrowserContextManager.ts +85 -0
  460. package/src/browser/auth/LocalStorageKVStore.ts +21 -0
  461. package/src/browser/auth/PasskeyAuth.ts +175 -0
  462. package/src/browser/createBrowserContext.ts +326 -0
  463. package/src/browser/index.ts +72 -0
  464. package/src/browser/storageOptions.ts +17 -0
  465. package/src/browser/tests/LocalStorageKVStore.test.ts +67 -0
  466. package/src/browser/tests/PasskeyAuth.test.ts +242 -0
  467. package/src/browser/tests/createInviteLink.test.ts +18 -0
  468. package/src/browser/tests/storageOptions.test.ts +33 -0
  469. package/src/browser/tests/utils.ts +93 -0
  470. package/src/browser/utils/export-account-inspector.ts +58 -0
  471. package/src/browser-media-images/index.ts +130 -0
  472. package/src/expo/auth/clerk/README.md +44 -0
  473. package/src/expo/auth/clerk/index.tsx +80 -0
  474. package/src/expo/crypto.ts +1 -0
  475. package/src/expo/index.ts +6 -0
  476. package/src/expo/provider.tsx +29 -0
  477. package/src/expo/storage/expo-secure-store-adapter.ts +29 -0
  478. package/src/expo/storage/expo-sqlite-adapter.ts +94 -0
  479. package/src/expo/testing.ts +1 -0
  480. package/src/index.ts +1 -3
  481. package/src/inspector/custom-element.tsx +63 -0
  482. package/src/inspector/index.ts +23 -0
  483. package/src/inspector/register-custom-element.ts +3 -0
  484. package/src/inspector/ui/badge.tsx +20 -0
  485. package/src/inspector/ui/button.tsx +81 -0
  486. package/src/inspector/ui/card.tsx +23 -0
  487. package/src/inspector/ui/global-styles.tsx +74 -0
  488. package/src/inspector/ui/grid.tsx +48 -0
  489. package/src/inspector/ui/heading.tsx +15 -0
  490. package/src/inspector/ui/icon.tsx +71 -0
  491. package/src/inspector/ui/icons/chevron-down-icon.tsx +16 -0
  492. package/src/inspector/ui/icons/delete-icon.tsx +19 -0
  493. package/src/inspector/ui/icons/link-icon.tsx +18 -0
  494. package/src/inspector/ui/input.tsx +51 -0
  495. package/src/inspector/ui/select.tsx +73 -0
  496. package/src/inspector/ui/table.tsx +90 -0
  497. package/src/inspector/ui/text.tsx +62 -0
  498. package/src/inspector/viewer/account-or-group-text.tsx +52 -0
  499. package/src/inspector/viewer/account-view.tsx +34 -0
  500. package/src/inspector/viewer/breadcrumbs.tsx +52 -0
  501. package/src/inspector/viewer/co-stream-view.tsx +374 -0
  502. package/src/inspector/viewer/grid-view.tsx +90 -0
  503. package/src/inspector/viewer/group-view.tsx +67 -0
  504. package/src/inspector/viewer/inpsector-button.tsx +89 -0
  505. package/src/inspector/viewer/new-app.tsx +172 -0
  506. package/src/inspector/viewer/page-stack.tsx +56 -0
  507. package/src/inspector/viewer/page.tsx +199 -0
  508. package/src/inspector/viewer/raw-data-card.tsx +53 -0
  509. package/src/inspector/viewer/role-display.tsx +28 -0
  510. package/src/inspector/viewer/table-viewer.tsx +184 -0
  511. package/src/inspector/viewer/type-icon.tsx +63 -0
  512. package/src/inspector/viewer/types.ts +11 -0
  513. package/src/inspector/viewer/use-open-inspector.ts +18 -0
  514. package/src/inspector/viewer/use-page-path.ts +65 -0
  515. package/src/inspector/viewer/use-resolve-covalue.ts +214 -0
  516. package/src/inspector/viewer/value-renderer.tsx +266 -0
  517. package/src/prosemirror/index.ts +2 -0
  518. package/src/prosemirror/lib/converter.ts +50 -0
  519. package/src/prosemirror/lib/plugin.ts +120 -0
  520. package/src/prosemirror/lib/sync.ts +96 -0
  521. package/src/prosemirror/tests/plugin.test.ts +127 -0
  522. package/src/react/auth/Clerk.tsx +82 -0
  523. package/src/react/auth/DemoAuth.tsx +121 -0
  524. package/src/react/auth/PasskeyAuth.tsx +168 -0
  525. package/src/react/auth/PassphraseAuth.tsx +196 -0
  526. package/src/react/auth/auth.ts +9 -0
  527. package/src/react/hooks.tsx +53 -0
  528. package/src/react/index.ts +16 -0
  529. package/src/react/media.tsx +74 -0
  530. package/src/react/provider.tsx +114 -0
  531. package/src/react/scratch.tsx +50 -0
  532. package/src/react/ssr.ts +25 -0
  533. package/src/react/testing.tsx +1 -0
  534. package/src/react/tests/testUtils.tsx +54 -0
  535. package/src/react/tests/useAcceptInvite.test.ts +55 -0
  536. package/src/react-core/auth/DemoAuth.tsx +47 -0
  537. package/src/react-core/auth/PassphraseAuth.tsx +58 -0
  538. package/src/react-core/auth/index.ts +2 -0
  539. package/src/react-core/hooks.ts +310 -0
  540. package/src/react-core/index.ts +3 -0
  541. package/src/react-core/provider.tsx +11 -0
  542. package/src/react-core/testing.tsx +42 -0
  543. package/src/react-core/tests/testUtils.tsx +65 -0
  544. package/src/react-core/tests/useAccount.test.ts +238 -0
  545. package/src/react-core/tests/useCoState.test.ts +553 -0
  546. package/src/react-core/tests/useDemoAuth.test.tsx +84 -0
  547. package/src/react-core/tests/useInboxSender.test.ts +58 -0
  548. package/src/react-core/tests/useIsAuthenticated.test.ts +34 -0
  549. package/src/react-core/tests/usePassPhraseAuth.test.ts +180 -0
  550. package/src/react-core/utils.ts +28 -0
  551. package/src/react-native/crypto.ts +1 -0
  552. package/src/react-native/index.ts +5 -0
  553. package/src/react-native/provider.tsx +30 -0
  554. package/src/react-native/storage/mmkv-store-adapter.ts +24 -0
  555. package/src/react-native/storage/op-sqlite-adapter.ts +79 -0
  556. package/src/react-native/testing.ts +1 -0
  557. package/src/react-native-core/ReactNativeContextManager.ts +84 -0
  558. package/src/react-native-core/auth/DemoAuthUI.tsx +202 -0
  559. package/src/react-native-core/auth/auth.ts +14 -0
  560. package/src/react-native-core/crypto/RNQuickCrypto.ts +92 -0
  561. package/src/react-native-core/crypto/index.ts +1 -0
  562. package/src/react-native-core/hooks.tsx +64 -0
  563. package/src/react-native-core/index.ts +9 -0
  564. package/src/react-native-core/media.tsx +79 -0
  565. package/src/react-native-core/platform.ts +250 -0
  566. package/src/react-native-core/provider.tsx +115 -0
  567. package/src/react-native-core/storage/sqlite-react-native.ts +19 -0
  568. package/src/react-native-core/testing.tsx +1 -0
  569. package/src/react-native-media-images/index.ts +238 -0
  570. package/src/svelte/Provider.svelte +61 -0
  571. package/src/svelte/auth/PasskeyAuth.svelte.ts +42 -0
  572. package/src/svelte/auth/PasskeyAuthBasicUI.svelte +81 -0
  573. package/src/svelte/auth/PassphraseAuth.svelte.ts +49 -0
  574. package/src/svelte/auth/index.ts +3 -0
  575. package/src/svelte/auth/useIsAuthenticated.svelte.ts +28 -0
  576. package/src/svelte/index.ts +5 -0
  577. package/src/svelte/jazz.class.svelte.ts +172 -0
  578. package/src/svelte/jazz.svelte.ts +109 -0
  579. package/src/svelte/testing.ts +42 -0
  580. package/src/testing.ts +1 -312
  581. package/src/tiptap/index.ts +28 -0
  582. package/src/tools/auth/KvStoreContext.ts +39 -0
  583. package/src/tools/auth/clerk/getClerkUsername.ts +36 -0
  584. package/src/tools/auth/clerk/index.ts +174 -0
  585. package/src/tools/auth/clerk/tests/JazzClerkAuth.test.ts +284 -0
  586. package/src/tools/auth/clerk/tests/getClerkUsername.test.ts +81 -0
  587. package/src/tools/auth/clerk/tests/types.test.ts +49 -0
  588. package/src/tools/auth/clerk/types.ts +56 -0
  589. package/src/tools/coValues/coFeed.ts +981 -0
  590. package/src/tools/coValues/coMap.ts +929 -0
  591. package/src/tools/coValues/interfaces.ts +464 -0
  592. package/src/tools/exports.ts +117 -0
  593. package/src/tools/implementation/zodSchema/schemaTypes/CoMapSchema.ts +188 -0
  594. package/src/tools/implementation/zodSchema/zodCo.ts +370 -0
  595. package/src/tools/index.ts +8 -0
  596. package/src/tools/subscribe/CoValueCoreSubscription.ts +74 -0
  597. package/src/tools/subscribe/SubscriptionScope.ts +626 -0
  598. package/src/tools/testing.ts +301 -0
  599. package/src/tools/tests/coFeed.test.ts +840 -0
  600. package/src/tools/tests/coMap.test.ts +2113 -0
  601. package/src/tools/tests/fixtures.ts +2050 -0
  602. package/src/tools/tests/load.test.ts +117 -0
  603. package/src/worker/index.ts +127 -0
  604. package/tsconfig.json +10 -3
  605. package/tsconfig.svelte.json +6 -0
  606. package/tsup.config.ts +143 -9
  607. package/dist/auth/AuthSecretStorage.d.ts.map +0 -1
  608. package/dist/auth/DemoAuth.d.ts.map +0 -1
  609. package/dist/auth/InMemoryKVStore.d.ts.map +0 -1
  610. package/dist/auth/KvStoreContext.d.ts.map +0 -1
  611. package/dist/auth/PassphraseAuth.d.ts.map +0 -1
  612. package/dist/chunk-AUQIX4E7.js +0 -4827
  613. package/dist/chunk-AUQIX4E7.js.map +0 -1
  614. package/dist/coValues/CoValueBase.d.ts.map +0 -1
  615. package/dist/coValues/account.d.ts.map +0 -1
  616. package/dist/coValues/coFeed.d.ts +0 -368
  617. package/dist/coValues/coFeed.d.ts.map +0 -1
  618. package/dist/coValues/coList.d.ts.map +0 -1
  619. package/dist/coValues/coMap.d.ts +0 -529
  620. package/dist/coValues/coMap.d.ts.map +0 -1
  621. package/dist/coValues/coPlainText.d.ts.map +0 -1
  622. package/dist/coValues/coRichText.d.ts.map +0 -1
  623. package/dist/coValues/deepLoading.d.ts.map +0 -1
  624. package/dist/coValues/extensions/imageDef.d.ts.map +0 -1
  625. package/dist/coValues/group.d.ts.map +0 -1
  626. package/dist/coValues/inbox.d.ts.map +0 -1
  627. package/dist/coValues/interfaces.d.ts +0 -113
  628. package/dist/coValues/interfaces.d.ts.map +0 -1
  629. package/dist/coValues/profile.d.ts.map +0 -1
  630. package/dist/coValues/registeredSchemas.d.ts.map +0 -1
  631. package/dist/coValues/schemaUnion.d.ts.map +0 -1
  632. package/dist/exports.d.ts +0 -23
  633. package/dist/exports.d.ts.map +0 -1
  634. package/dist/implementation/ContextManager.d.ts.map +0 -1
  635. package/dist/implementation/activeAccountContext.d.ts.map +0 -1
  636. package/dist/implementation/anonymousJazzAgent.d.ts.map +0 -1
  637. package/dist/implementation/createContext.d.ts.map +0 -1
  638. package/dist/implementation/devtoolsFormatters.d.ts.map +0 -1
  639. package/dist/implementation/errors.d.ts.map +0 -1
  640. package/dist/implementation/inspect.d.ts.map +0 -1
  641. package/dist/implementation/invites.d.ts.map +0 -1
  642. package/dist/implementation/refs.d.ts.map +0 -1
  643. package/dist/implementation/schema.d.ts.map +0 -1
  644. package/dist/implementation/symbols.d.ts.map +0 -1
  645. package/dist/implementation/zodSchema/coExport.d.ts.map +0 -1
  646. package/dist/implementation/zodSchema/runtimeConverters/zodFieldToCoFieldDef.d.ts.map +0 -1
  647. package/dist/implementation/zodSchema/runtimeConverters/zodSchemaToCoSchema.d.ts.map +0 -1
  648. package/dist/implementation/zodSchema/schemaTypes/AccountSchema.d.ts.map +0 -1
  649. package/dist/implementation/zodSchema/schemaTypes/CoFeedSchema.d.ts.map +0 -1
  650. package/dist/implementation/zodSchema/schemaTypes/CoListSchema.d.ts.map +0 -1
  651. package/dist/implementation/zodSchema/schemaTypes/CoMapSchema.d.ts +0 -52
  652. package/dist/implementation/zodSchema/schemaTypes/CoMapSchema.d.ts.map +0 -1
  653. package/dist/implementation/zodSchema/schemaTypes/CoRecordSchema.d.ts.map +0 -1
  654. package/dist/implementation/zodSchema/schemaTypes/FileStreamSchema.d.ts.map +0 -1
  655. package/dist/implementation/zodSchema/schemaTypes/PlainTextSchema.d.ts.map +0 -1
  656. package/dist/implementation/zodSchema/schemaTypes/RichTextSchema.d.ts.map +0 -1
  657. package/dist/implementation/zodSchema/typeConverters/InstanceOfSchema.d.ts.map +0 -1
  658. package/dist/implementation/zodSchema/typeConverters/InstanceOfSchemaCoValuesNullable.d.ts.map +0 -1
  659. package/dist/implementation/zodSchema/typeConverters/InstanceOrPrimitiveOfSchema.d.ts.map +0 -1
  660. package/dist/implementation/zodSchema/typeConverters/InstanceOrPrimitiveOfSchemaCoValuesNullable.d.ts.map +0 -1
  661. package/dist/implementation/zodSchema/unionUtils.d.ts.map +0 -1
  662. package/dist/implementation/zodSchema/zodCo.d.ts.map +0 -1
  663. package/dist/implementation/zodSchema/zodReExport.d.ts.map +0 -1
  664. package/dist/implementation/zodSchema/zodSchema.d.ts.map +0 -1
  665. package/dist/internal.d.ts.map +0 -1
  666. package/dist/lib/cache.d.ts.map +0 -1
  667. package/dist/lib/cache.test.d.ts.map +0 -1
  668. package/dist/lib/migration.d.ts.map +0 -1
  669. package/dist/subscribe/CoValueCoreSubscription.d.ts +0 -14
  670. package/dist/subscribe/CoValueCoreSubscription.d.ts.map +0 -1
  671. package/dist/subscribe/JazzError.d.ts.map +0 -1
  672. package/dist/subscribe/SubscriptionScope.d.ts +0 -46
  673. package/dist/subscribe/SubscriptionScope.d.ts.map +0 -1
  674. package/dist/subscribe/index.d.ts.map +0 -1
  675. package/dist/subscribe/types.d.ts.map +0 -1
  676. package/dist/subscribe/utils.d.ts.map +0 -1
  677. package/dist/tests/AuthSecretStorage.test.d.ts.map +0 -1
  678. package/dist/tests/ContextManager.test.d.ts.map +0 -1
  679. package/dist/tests/DemoAuth.test.d.ts.map +0 -1
  680. package/dist/tests/PassphraseAuth.test.d.ts.map +0 -1
  681. package/dist/tests/account.test.d.ts.map +0 -1
  682. package/dist/tests/coFeed.test-d.d.ts.map +0 -1
  683. package/dist/tests/coFeed.test.d.ts.map +0 -1
  684. package/dist/tests/coList.test-d.d.ts.map +0 -1
  685. package/dist/tests/coList.test.d.ts.map +0 -1
  686. package/dist/tests/coMap.record.test-d.d.ts.map +0 -1
  687. package/dist/tests/coMap.record.test.d.ts.map +0 -1
  688. package/dist/tests/coMap.test-d.d.ts.map +0 -1
  689. package/dist/tests/coMap.test.d.ts.map +0 -1
  690. package/dist/tests/coPlainText.test.d.ts.map +0 -1
  691. package/dist/tests/createContext.test.d.ts.map +0 -1
  692. package/dist/tests/deepLoading.test.d.ts.map +0 -1
  693. package/dist/tests/fixtures.d.ts.map +0 -1
  694. package/dist/tests/groupsAndAccounts.test.d.ts.map +0 -1
  695. package/dist/tests/imageDef.test.d.ts.map +0 -1
  696. package/dist/tests/inbox.test.d.ts.map +0 -1
  697. package/dist/tests/interfaces.test.d.ts.map +0 -1
  698. package/dist/tests/invites.test.d.ts.map +0 -1
  699. package/dist/tests/load.test.d.ts.map +0 -1
  700. package/dist/tests/patterns/notifications.test.d.ts.map +0 -1
  701. package/dist/tests/patterns/requestToJoin.test.d.ts.map +0 -1
  702. package/dist/tests/schema.test.d.ts.map +0 -1
  703. package/dist/tests/schemaUnion.test.d.ts.map +0 -1
  704. package/dist/tests/subscribe.test.d.ts.map +0 -1
  705. package/dist/tests/testing.test.d.ts.map +0 -1
  706. package/dist/tests/utils.d.ts.map +0 -1
  707. package/dist/tests/zod.test.d.ts.map +0 -1
  708. package/dist/types.d.ts.map +0 -1
  709. package/src/coValues/coFeed.ts +0 -943
  710. package/src/coValues/coMap.ts +0 -825
  711. package/src/coValues/interfaces.ts +0 -454
  712. package/src/exports.ts +0 -108
  713. package/src/implementation/zodSchema/schemaTypes/CoMapSchema.ts +0 -150
  714. package/src/implementation/zodSchema/zodCo.ts +0 -364
  715. package/src/subscribe/CoValueCoreSubscription.ts +0 -71
  716. package/src/subscribe/SubscriptionScope.ts +0 -614
  717. package/src/tests/coFeed.test.ts +0 -771
  718. package/src/tests/coMap.test.ts +0 -1637
  719. package/src/tests/load.test.ts +0 -116
  720. /package/dist/{tests → react-core/tests}/fixtures.d.ts +0 -0
  721. /package/dist/{auth → tools/auth}/AuthSecretStorage.d.ts +0 -0
  722. /package/dist/{auth → tools/auth}/DemoAuth.d.ts +0 -0
  723. /package/dist/{auth → tools/auth}/InMemoryKVStore.d.ts +0 -0
  724. /package/dist/{auth → tools/auth}/KvStoreContext.d.ts +0 -0
  725. /package/dist/{auth → tools/auth}/PassphraseAuth.d.ts +0 -0
  726. /package/dist/{coValues → tools/coValues}/CoValueBase.d.ts +0 -0
  727. /package/dist/{coValues → tools/coValues}/account.d.ts +0 -0
  728. /package/dist/{coValues → tools/coValues}/coList.d.ts +0 -0
  729. /package/dist/{coValues → tools/coValues}/coPlainText.d.ts +0 -0
  730. /package/dist/{coValues → tools/coValues}/coRichText.d.ts +0 -0
  731. /package/dist/{coValues → tools/coValues}/deepLoading.d.ts +0 -0
  732. /package/dist/{coValues → tools/coValues}/extensions/imageDef.d.ts +0 -0
  733. /package/dist/{coValues → tools/coValues}/group.d.ts +0 -0
  734. /package/dist/{coValues → tools/coValues}/inbox.d.ts +0 -0
  735. /package/dist/{coValues → tools/coValues}/profile.d.ts +0 -0
  736. /package/dist/{coValues → tools/coValues}/registeredSchemas.d.ts +0 -0
  737. /package/dist/{coValues → tools/coValues}/schemaUnion.d.ts +0 -0
  738. /package/dist/{implementation → tools/implementation}/ContextManager.d.ts +0 -0
  739. /package/dist/{implementation → tools/implementation}/activeAccountContext.d.ts +0 -0
  740. /package/dist/{implementation → tools/implementation}/anonymousJazzAgent.d.ts +0 -0
  741. /package/dist/{implementation → tools/implementation}/createContext.d.ts +0 -0
  742. /package/dist/{implementation → tools/implementation}/devtoolsFormatters.d.ts +0 -0
  743. /package/dist/{implementation → tools/implementation}/errors.d.ts +0 -0
  744. /package/dist/{implementation → tools/implementation}/inspect.d.ts +0 -0
  745. /package/dist/{implementation → tools/implementation}/invites.d.ts +0 -0
  746. /package/dist/{implementation → tools/implementation}/refs.d.ts +0 -0
  747. /package/dist/{implementation → tools/implementation}/schema.d.ts +0 -0
  748. /package/dist/{implementation → tools/implementation}/symbols.d.ts +0 -0
  749. /package/dist/{implementation → tools/implementation}/zodSchema/coExport.d.ts +0 -0
  750. /package/dist/{implementation → tools/implementation}/zodSchema/runtimeConverters/zodFieldToCoFieldDef.d.ts +0 -0
  751. /package/dist/{implementation → tools/implementation}/zodSchema/runtimeConverters/zodSchemaToCoSchema.d.ts +0 -0
  752. /package/dist/{implementation → tools/implementation}/zodSchema/schemaTypes/AccountSchema.d.ts +0 -0
  753. /package/dist/{implementation → tools/implementation}/zodSchema/schemaTypes/CoFeedSchema.d.ts +0 -0
  754. /package/dist/{implementation → tools/implementation}/zodSchema/schemaTypes/CoListSchema.d.ts +0 -0
  755. /package/dist/{implementation → tools/implementation}/zodSchema/schemaTypes/CoRecordSchema.d.ts +0 -0
  756. /package/dist/{implementation → tools/implementation}/zodSchema/schemaTypes/FileStreamSchema.d.ts +0 -0
  757. /package/dist/{implementation → tools/implementation}/zodSchema/schemaTypes/PlainTextSchema.d.ts +0 -0
  758. /package/dist/{implementation → tools/implementation}/zodSchema/schemaTypes/RichTextSchema.d.ts +0 -0
  759. /package/dist/{implementation → tools/implementation}/zodSchema/typeConverters/InstanceOfSchema.d.ts +0 -0
  760. /package/dist/{implementation → tools/implementation}/zodSchema/typeConverters/InstanceOfSchemaCoValuesNullable.d.ts +0 -0
  761. /package/dist/{implementation → tools/implementation}/zodSchema/typeConverters/InstanceOrPrimitiveOfSchema.d.ts +0 -0
  762. /package/dist/{implementation → tools/implementation}/zodSchema/typeConverters/InstanceOrPrimitiveOfSchemaCoValuesNullable.d.ts +0 -0
  763. /package/dist/{implementation → tools/implementation}/zodSchema/unionUtils.d.ts +0 -0
  764. /package/dist/{implementation → tools/implementation}/zodSchema/zodCo.d.ts +0 -0
  765. /package/dist/{implementation → tools/implementation}/zodSchema/zodReExport.d.ts +0 -0
  766. /package/dist/{implementation → tools/implementation}/zodSchema/zodSchema.d.ts +0 -0
  767. /package/dist/{internal.d.ts → tools/internal.d.ts} +0 -0
  768. /package/dist/{lib → tools/lib}/cache.d.ts +0 -0
  769. /package/dist/{lib → tools/lib}/cache.test.d.ts +0 -0
  770. /package/dist/{lib → tools/lib}/migration.d.ts +0 -0
  771. /package/dist/{subscribe → tools/subscribe}/JazzError.d.ts +0 -0
  772. /package/dist/{subscribe → tools/subscribe}/index.d.ts +0 -0
  773. /package/dist/{subscribe → tools/subscribe}/types.d.ts +0 -0
  774. /package/dist/{subscribe → tools/subscribe}/utils.d.ts +0 -0
  775. /package/dist/{tests → tools/tests}/AuthSecretStorage.test.d.ts +0 -0
  776. /package/dist/{tests → tools/tests}/ContextManager.test.d.ts +0 -0
  777. /package/dist/{tests → tools/tests}/DemoAuth.test.d.ts +0 -0
  778. /package/dist/{tests → tools/tests}/PassphraseAuth.test.d.ts +0 -0
  779. /package/dist/{tests → tools/tests}/account.test.d.ts +0 -0
  780. /package/dist/{tests → tools/tests}/coFeed.test-d.d.ts +0 -0
  781. /package/dist/{tests → tools/tests}/coFeed.test.d.ts +0 -0
  782. /package/dist/{tests → tools/tests}/coList.test-d.d.ts +0 -0
  783. /package/dist/{tests → tools/tests}/coList.test.d.ts +0 -0
  784. /package/dist/{tests → tools/tests}/coMap.record.test-d.d.ts +0 -0
  785. /package/dist/{tests → tools/tests}/coMap.record.test.d.ts +0 -0
  786. /package/dist/{tests → tools/tests}/coMap.test-d.d.ts +0 -0
  787. /package/dist/{tests → tools/tests}/coMap.test.d.ts +0 -0
  788. /package/dist/{tests → tools/tests}/coPlainText.test.d.ts +0 -0
  789. /package/dist/{tests → tools/tests}/createContext.test.d.ts +0 -0
  790. /package/dist/{tests → tools/tests}/deepLoading.test.d.ts +0 -0
  791. /package/dist/{tests → tools/tests}/groupsAndAccounts.test.d.ts +0 -0
  792. /package/dist/{tests → tools/tests}/imageDef.test.d.ts +0 -0
  793. /package/dist/{tests → tools/tests}/inbox.test.d.ts +0 -0
  794. /package/dist/{tests → tools/tests}/interfaces.test.d.ts +0 -0
  795. /package/dist/{tests → tools/tests}/invites.test.d.ts +0 -0
  796. /package/dist/{tests → tools/tests}/load.test.d.ts +0 -0
  797. /package/dist/{tests → tools/tests}/patterns/notifications.test.d.ts +0 -0
  798. /package/dist/{tests → tools/tests}/patterns/requestToJoin.test.d.ts +0 -0
  799. /package/dist/{tests → tools/tests}/schema.test.d.ts +0 -0
  800. /package/dist/{tests → tools/tests}/schemaUnion.test.d.ts +0 -0
  801. /package/dist/{tests → tools/tests}/subscribe.test.d.ts +0 -0
  802. /package/dist/{tests → tools/tests}/testing.test.d.ts +0 -0
  803. /package/dist/{tests → tools/tests}/utils.d.ts +0 -0
  804. /package/dist/{tests → tools/tests}/zod.test.d.ts +0 -0
  805. /package/dist/{types.d.ts → tools/types.d.ts} +0 -0
  806. /package/src/{tests → react-core/tests}/fixtures.ts +0 -0
  807. /package/src/{auth/KvStoreContext.ts → react-native-core/storage/kv-store-context.ts} +0 -0
  808. /package/src/{auth → tools/auth}/AuthSecretStorage.ts +0 -0
  809. /package/src/{auth → tools/auth}/DemoAuth.ts +0 -0
  810. /package/src/{auth → tools/auth}/InMemoryKVStore.ts +0 -0
  811. /package/src/{auth → tools/auth}/PassphraseAuth.ts +0 -0
  812. /package/src/{coValues → tools/coValues}/CoValueBase.ts +0 -0
  813. /package/src/{coValues → tools/coValues}/account.ts +0 -0
  814. /package/src/{coValues → tools/coValues}/coList.ts +0 -0
  815. /package/src/{coValues → tools/coValues}/coPlainText.ts +0 -0
  816. /package/src/{coValues → tools/coValues}/coRichText.ts +0 -0
  817. /package/src/{coValues → tools/coValues}/deepLoading.ts +0 -0
  818. /package/src/{coValues → tools/coValues}/extensions/imageDef.ts +0 -0
  819. /package/src/{coValues → tools/coValues}/group.ts +0 -0
  820. /package/src/{coValues → tools/coValues}/inbox.ts +0 -0
  821. /package/src/{coValues → tools/coValues}/profile.ts +0 -0
  822. /package/src/{coValues → tools/coValues}/registeredSchemas.ts +0 -0
  823. /package/src/{coValues → tools/coValues}/schemaUnion.ts +0 -0
  824. /package/src/{implementation → tools/implementation}/ContextManager.ts +0 -0
  825. /package/src/{implementation → tools/implementation}/activeAccountContext.ts +0 -0
  826. /package/src/{implementation → tools/implementation}/anonymousJazzAgent.ts +0 -0
  827. /package/src/{implementation → tools/implementation}/createContext.ts +0 -0
  828. /package/src/{implementation → tools/implementation}/devtoolsFormatters.ts +0 -0
  829. /package/src/{implementation → tools/implementation}/errors.ts +0 -0
  830. /package/src/{implementation → tools/implementation}/inspect.ts +0 -0
  831. /package/src/{implementation → tools/implementation}/invites.ts +0 -0
  832. /package/src/{implementation → tools/implementation}/refs.ts +0 -0
  833. /package/src/{implementation → tools/implementation}/schema.ts +0 -0
  834. /package/src/{implementation → tools/implementation}/symbols.ts +0 -0
  835. /package/src/{implementation → tools/implementation}/zodSchema/coExport.ts +0 -0
  836. /package/src/{implementation → tools/implementation}/zodSchema/runtimeConverters/zodFieldToCoFieldDef.ts +0 -0
  837. /package/src/{implementation → tools/implementation}/zodSchema/runtimeConverters/zodSchemaToCoSchema.ts +0 -0
  838. /package/src/{implementation → tools/implementation}/zodSchema/schemaTypes/AccountSchema.ts +0 -0
  839. /package/src/{implementation → tools/implementation}/zodSchema/schemaTypes/CoFeedSchema.ts +0 -0
  840. /package/src/{implementation → tools/implementation}/zodSchema/schemaTypes/CoListSchema.ts +0 -0
  841. /package/src/{implementation → tools/implementation}/zodSchema/schemaTypes/CoRecordSchema.ts +0 -0
  842. /package/src/{implementation → tools/implementation}/zodSchema/schemaTypes/FileStreamSchema.ts +0 -0
  843. /package/src/{implementation → tools/implementation}/zodSchema/schemaTypes/PlainTextSchema.ts +0 -0
  844. /package/src/{implementation → tools/implementation}/zodSchema/schemaTypes/RichTextSchema.ts +0 -0
  845. /package/src/{implementation → tools/implementation}/zodSchema/typeConverters/InstanceOfSchema.ts +0 -0
  846. /package/src/{implementation → tools/implementation}/zodSchema/typeConverters/InstanceOfSchemaCoValuesNullable.ts +0 -0
  847. /package/src/{implementation → tools/implementation}/zodSchema/typeConverters/InstanceOrPrimitiveOfSchema.ts +0 -0
  848. /package/src/{implementation → tools/implementation}/zodSchema/typeConverters/InstanceOrPrimitiveOfSchemaCoValuesNullable.ts +0 -0
  849. /package/src/{implementation → tools/implementation}/zodSchema/unionUtils.ts +0 -0
  850. /package/src/{implementation → tools/implementation}/zodSchema/zodReExport.ts +0 -0
  851. /package/src/{implementation → tools/implementation}/zodSchema/zodSchema.ts +0 -0
  852. /package/src/{internal.ts → tools/internal.ts} +0 -0
  853. /package/src/{lib → tools/lib}/cache.test.ts +0 -0
  854. /package/src/{lib → tools/lib}/cache.ts +0 -0
  855. /package/src/{lib → tools/lib}/migration.ts +0 -0
  856. /package/src/{subscribe → tools/subscribe}/JazzError.ts +0 -0
  857. /package/src/{subscribe → tools/subscribe}/index.ts +0 -0
  858. /package/src/{subscribe → tools/subscribe}/types.ts +0 -0
  859. /package/src/{subscribe → tools/subscribe}/utils.ts +0 -0
  860. /package/src/{tests → tools/tests}/AuthSecretStorage.test.ts +0 -0
  861. /package/src/{tests → tools/tests}/ContextManager.test.ts +0 -0
  862. /package/src/{tests → tools/tests}/DemoAuth.test.ts +0 -0
  863. /package/src/{tests → tools/tests}/PassphraseAuth.test.ts +0 -0
  864. /package/src/{tests → tools/tests}/account.test.ts +0 -0
  865. /package/src/{tests → tools/tests}/coFeed.test-d.ts +0 -0
  866. /package/src/{tests → tools/tests}/coList.test-d.ts +0 -0
  867. /package/src/{tests → tools/tests}/coList.test.ts +0 -0
  868. /package/src/{tests → tools/tests}/coMap.record.test-d.ts +0 -0
  869. /package/src/{tests → tools/tests}/coMap.record.test.ts +0 -0
  870. /package/src/{tests → tools/tests}/coMap.test-d.ts +0 -0
  871. /package/src/{tests → tools/tests}/coPlainText.test.ts +0 -0
  872. /package/src/{tests → tools/tests}/createContext.test.ts +0 -0
  873. /package/src/{tests → tools/tests}/deepLoading.test.ts +0 -0
  874. /package/src/{tests → tools/tests}/groupsAndAccounts.test.ts +0 -0
  875. /package/src/{tests → tools/tests}/imageDef.test.ts +0 -0
  876. /package/src/{tests → tools/tests}/inbox.test.ts +0 -0
  877. /package/src/{tests → tools/tests}/interfaces.test.ts +0 -0
  878. /package/src/{tests → tools/tests}/invites.test.ts +0 -0
  879. /package/src/{tests → tools/tests}/patterns/notifications.test.ts +0 -0
  880. /package/src/{tests → tools/tests}/patterns/requestToJoin.test.ts +0 -0
  881. /package/src/{tests → tools/tests}/schema.test.ts +0 -0
  882. /package/src/{tests → tools/tests}/schemaUnion.test.ts +0 -0
  883. /package/src/{tests → tools/tests}/subscribe.test.ts +0 -0
  884. /package/src/{tests → tools/tests}/testing.test.ts +0 -0
  885. /package/src/{tests → tools/tests}/utils.ts +0 -0
  886. /package/src/{tests → tools/tests}/zod.test.ts +0 -0
  887. /package/src/{types.ts → tools/types.ts} +0 -0
@@ -1,771 +0,0 @@
1
- import { WasmCrypto } from "cojson/crypto/WasmCrypto";
2
- import { describe, expect, expectTypeOf, test } from "vitest";
3
- import {
4
- Account,
5
- FileStream,
6
- Group,
7
- co,
8
- cojsonInternals,
9
- isControlledAccount,
10
- z,
11
- } from "../index.js";
12
- import {
13
- Loaded,
14
- createJazzContextFromExistingCredentials,
15
- randomSessionProvider,
16
- } from "../internal.js";
17
- import { createJazzTestAccount } from "../testing.js";
18
- import { setupTwoNodes } from "./utils.js";
19
-
20
- const Crypto = await WasmCrypto.create();
21
-
22
- const connectedPeers = cojsonInternals.connectedPeers;
23
-
24
- describe("Simple CoFeed operations", async () => {
25
- const me = await Account.create({
26
- creationProps: { name: "Hermes Puggington" },
27
- crypto: Crypto,
28
- });
29
- if (!isControlledAccount(me)) {
30
- throw "me is not a controlled account";
31
- }
32
- const TestStream = co.feed(z.string());
33
-
34
- const stream = TestStream.create(["milk"], { owner: me });
35
-
36
- test("Construction", () => {
37
- expect(stream.perAccount[me.id]?.value).toEqual("milk");
38
- expect(stream.perSession[me.sessionID]?.value).toEqual("milk");
39
- });
40
-
41
- test("Construction with an Account", () => {
42
- const stream = TestStream.create(["milk"], me);
43
-
44
- expect(stream.perAccount[me.id]?.value).toEqual("milk");
45
- expect(stream.perSession[me.sessionID]?.value).toEqual("milk");
46
- });
47
-
48
- test("Construction with a Group", () => {
49
- const group = Group.create(me);
50
- const stream = TestStream.create(["milk"], group);
51
-
52
- expect(stream.perAccount[me.id]?.value).toEqual("milk");
53
- expect(stream.perSession[me.sessionID]?.value).toEqual("milk");
54
- });
55
-
56
- describe("Mutation", () => {
57
- test("pushing", () => {
58
- stream.push("bread");
59
- expect(stream.perAccount[me.id]?.value).toEqual("bread");
60
- expect(stream.perSession[me.sessionID]?.value).toEqual("bread");
61
-
62
- stream.push("butter");
63
- expect(stream.perAccount[me.id]?.value).toEqual("butter");
64
- expect(stream.perSession[me.sessionID]?.value).toEqual("butter");
65
- });
66
- });
67
- });
68
-
69
- describe("CoFeed resolution", async () => {
70
- const TwiceNestedStream = co.feed(z.string());
71
- const NestedStream = co.feed(TwiceNestedStream);
72
- const TestStream = co.feed(NestedStream);
73
-
74
- const initNodeAndStream = async () => {
75
- const me = await Account.create({
76
- creationProps: { name: "Hermes Puggington" },
77
- crypto: Crypto,
78
- });
79
-
80
- const stream = TestStream.create(
81
- [
82
- NestedStream.create(
83
- [TwiceNestedStream.create(["milk"], { owner: me })],
84
- { owner: me },
85
- ),
86
- ],
87
- { owner: me },
88
- );
89
-
90
- return { me, stream };
91
- };
92
-
93
- test("Construction", async () => {
94
- const { me, stream } = await initNodeAndStream();
95
-
96
- // TODO: fix this
97
- // expectTypeOf(stream[me.id]).not.toBeAny();
98
-
99
- expect(
100
- stream.perAccount[me.id]?.value?.perAccount[me.id]?.value?.perAccount[
101
- me.id
102
- ]?.value,
103
- ).toEqual("milk");
104
- });
105
-
106
- test("Loading and availability", async () => {
107
- const { me, stream } = await initNodeAndStream();
108
- const [initialAsPeer, secondPeer] = connectedPeers("initial", "second", {
109
- peer1role: "server",
110
- peer2role: "client",
111
- });
112
- if (!isControlledAccount(me)) {
113
- throw "me is not a controlled account";
114
- }
115
- me._raw.core.node.syncManager.addPeer(secondPeer);
116
- const { account: meOnSecondPeer } =
117
- await createJazzContextFromExistingCredentials({
118
- credentials: {
119
- accountID: me.id,
120
- secret: me._raw.core.node.getCurrentAgent().agentSecret,
121
- },
122
- sessionProvider: randomSessionProvider,
123
- peersToLoadFrom: [initialAsPeer],
124
- crypto: Crypto,
125
- });
126
-
127
- const loadedStream = await TestStream.load(stream.id, {
128
- loadAs: meOnSecondPeer,
129
- });
130
-
131
- // TODO: fix this
132
- // expectTypeOf(loadedStream?.[me.id]).not.toBeAny();
133
-
134
- expect(loadedStream?.perAccount[me.id]?.value).toEqual(null);
135
- expect(loadedStream?.perAccount[me.id]?.ref?.id).toEqual(
136
- stream.perAccount[me.id]?.value?.id,
137
- );
138
-
139
- const loadedNestedStream = await NestedStream.load(
140
- stream.perAccount[me.id]!.value!.id,
141
- { loadAs: meOnSecondPeer },
142
- );
143
-
144
- // expect(loadedStream?.[me.id]?.value).toEqual(loadedNestedStream);
145
- expect(loadedStream?.perAccount[me.id]?.value?.id).toEqual(
146
- loadedNestedStream?.id,
147
- );
148
- expect(
149
- loadedStream?.perAccount[me.id]?.value?.perAccount[me.id]?.value,
150
- ).toEqual(null);
151
- // expect(loadedStream?.[me.id]?.ref?.value).toEqual(loadedNestedStream);
152
- expect(loadedStream?.perAccount[me.id]?.ref?.value?.id).toEqual(
153
- loadedNestedStream?.id,
154
- );
155
- expect(
156
- loadedStream?.perAccount[me.id]?.value?.perAccount[me.id]?.ref?.id,
157
- ).toEqual(stream.perAccount[me.id]?.value?.perAccount[me.id]?.value?.id);
158
-
159
- const loadedTwiceNestedStream = await TwiceNestedStream.load(
160
- stream.perAccount[me.id]!.value!.perAccount[me.id]!.value!.id,
161
- { loadAs: meOnSecondPeer },
162
- );
163
-
164
- // expect(loadedStream?.[me.id]?.value?.[me.id]?.value).toEqual(
165
- // loadedTwiceNestedStream
166
- // );
167
- expect(
168
- loadedStream?.perAccount[me.id]?.value?.perAccount[me.id]?.value?.id,
169
- ).toEqual(loadedTwiceNestedStream?.id);
170
- // expect(loadedStream?.[me.id]?.ref?.value).toEqual(loadedNestedStream);
171
- expect(loadedStream?.perAccount[me.id]?.ref?.value?.id).toEqual(
172
- loadedNestedStream?.id,
173
- );
174
- expect(
175
- loadedStream?.perAccount[me.id]?.value?.perAccount[me.id]?.ref?.value?.id,
176
- ).toEqual(loadedTwiceNestedStream?.id);
177
-
178
- const otherNestedStream = NestedStream.create(
179
- [TwiceNestedStream.create(["butter"], { owner: meOnSecondPeer })],
180
- { owner: meOnSecondPeer },
181
- );
182
- loadedStream?.push(otherNestedStream);
183
- // expect(loadedStream?.[me.id]?.value).toEqual(otherNestedStream);
184
- expect(loadedStream?.perAccount[me.id]?.value?.id).toEqual(
185
- otherNestedStream?.id,
186
- );
187
- expect(loadedStream?.perAccount[me.id]?.ref?.value?.id).toEqual(
188
- otherNestedStream?.id,
189
- );
190
- expect(
191
- loadedStream?.perAccount[me.id]?.value?.perAccount[me.id]?.value?.id,
192
- ).toEqual(otherNestedStream.perAccount[me.id]?.value?.id);
193
- });
194
-
195
- test("Subscription & auto-resolution", async () => {
196
- const { me, stream } = await initNodeAndStream();
197
-
198
- const [initialAsPeer, secondAsPeer] = connectedPeers("initial", "second", {
199
- peer1role: "server",
200
- peer2role: "client",
201
- });
202
-
203
- me._raw.core.node.syncManager.addPeer(secondAsPeer);
204
- if (!isControlledAccount(me)) {
205
- throw "me is not a controlled account";
206
- }
207
- const { account: meOnSecondPeer } =
208
- await createJazzContextFromExistingCredentials({
209
- credentials: {
210
- accountID: me.id,
211
- secret: me._raw.core.node.getCurrentAgent().agentSecret,
212
- },
213
- sessionProvider: randomSessionProvider,
214
- peersToLoadFrom: [initialAsPeer],
215
- crypto: Crypto,
216
- });
217
-
218
- const queue = new cojsonInternals.Channel();
219
-
220
- TestStream.subscribe(
221
- stream.id,
222
- { loadAs: meOnSecondPeer },
223
- (subscribedStream) => {
224
- void queue.push(subscribedStream);
225
- },
226
- );
227
-
228
- const update1 = (await queue.next()).value;
229
- expect(update1.perAccount[me.id]?.value).toEqual(null);
230
-
231
- const update2 = (await queue.next()).value;
232
- expect(update2.perAccount[me.id]?.value).toBeDefined();
233
- expect(update2.perAccount[me.id]?.value?.perAccount[me.id]?.value).toBe(
234
- null,
235
- );
236
-
237
- const update3 = (await queue.next()).value;
238
- expect(
239
- update3.perAccount[me.id]?.value?.perAccount[me.id]?.value,
240
- ).toBeDefined();
241
- expect(
242
- update3.perAccount[me.id]?.value?.perAccount[me.id]?.value?.perAccount[
243
- me.id
244
- ]?.value,
245
- ).toBe("milk");
246
-
247
- update3.perAccount[me.id]!.value!.perAccount[me.id]!.value!.push("bread");
248
-
249
- const update4 = (await queue.next()).value;
250
- expect(
251
- update4.perAccount[me.id]?.value?.perAccount[me.id]?.value?.perAccount[
252
- me.id
253
- ]?.value,
254
- ).toBe("bread");
255
-
256
- // When assigning a new nested stream, we get an update
257
- const newTwiceNested = TwiceNestedStream.create(["butter"], {
258
- owner: meOnSecondPeer,
259
- });
260
-
261
- const newNested = NestedStream.create([newTwiceNested], {
262
- owner: meOnSecondPeer,
263
- });
264
-
265
- update4.push(newNested);
266
-
267
- const update5 = (await queue.next()).value;
268
- expect(
269
- update5.perAccount[me.id]?.value?.perAccount[me.id]?.value?.perAccount[
270
- me.id
271
- ]?.value,
272
- ).toBe("butter");
273
-
274
- // we get updates when the new nested stream changes
275
- newTwiceNested.push("jam");
276
- const update6 = (await queue.next()).value;
277
- expect(
278
- update6.perAccount[me.id]?.value?.perAccount[me.id]?.value?.perAccount[
279
- me.id
280
- ]?.value,
281
- ).toBe("jam");
282
- });
283
-
284
- test("Subscription without options", async () => {
285
- const { me, stream } = await initNodeAndStream();
286
-
287
- const [initialAsPeer, secondAsPeer] = connectedPeers("initial", "second", {
288
- peer1role: "server",
289
- peer2role: "client",
290
- });
291
- if (!isControlledAccount(me)) {
292
- throw "me is not a controlled account";
293
- }
294
- me._raw.core.node.syncManager.addPeer(secondAsPeer);
295
-
296
- await createJazzContextFromExistingCredentials({
297
- credentials: {
298
- accountID: me.id,
299
- secret: me._raw.core.node.getCurrentAgent().agentSecret,
300
- },
301
- sessionProvider: randomSessionProvider,
302
- peersToLoadFrom: [initialAsPeer],
303
- crypto: Crypto,
304
- });
305
-
306
- const queue = new cojsonInternals.Channel<Loaded<typeof TestStream>>();
307
-
308
- TestStream.subscribe(stream.id, (subscribedStream) => {
309
- void queue.push(subscribedStream);
310
- });
311
-
312
- const update1 = (await queue.next()).value;
313
- expect(update1.perAccount[me.id]?.value).toEqual(null);
314
-
315
- const update2 = (await queue.next()).value;
316
- expect(update2.perAccount[me.id]?.value?.perAccount[me.id]?.value).toEqual(
317
- null,
318
- );
319
-
320
- const update3 = (await queue.next()).value;
321
- expect(
322
- update3.perAccount[me.id]?.value?.perAccount[me.id]?.value,
323
- ).toBeDefined();
324
- expect(
325
- update3.perAccount[me.id]?.value?.perAccount[me.id]?.value?.perAccount[
326
- me.id
327
- ]?.value,
328
- ).toBe("milk");
329
-
330
- update3.perAccount[me.id]!.value!.perAccount[me.id]!.value!.push("bread");
331
-
332
- const update4 = (await queue.next()).value;
333
- expect(
334
- update4.perAccount[me.id]?.value?.perAccount[me.id]?.value?.perAccount[
335
- me.id
336
- ]?.value,
337
- ).toBe("bread");
338
- });
339
- });
340
-
341
- describe("Simple FileStream operations", async () => {
342
- const me = await Account.create({
343
- creationProps: { name: "Hermes Puggington" },
344
- crypto: Crypto,
345
- });
346
-
347
- const stream = FileStream.create({ owner: me });
348
-
349
- describe("FileStream", () => {
350
- test("Construction", () => {
351
- expect(stream.getChunks()).toBe(undefined);
352
- });
353
-
354
- test("Mutation", () => {
355
- stream.start({ mimeType: "text/plain" });
356
- stream.push(new Uint8Array([1, 2, 3]));
357
- stream.push(new Uint8Array([4, 5, 6]));
358
- stream.end();
359
-
360
- const chunks = stream.getChunks();
361
- expect(chunks?.mimeType).toBe("text/plain");
362
- expect(chunks?.chunks).toEqual([
363
- new Uint8Array([1, 2, 3]),
364
- new Uint8Array([4, 5, 6]),
365
- ]);
366
- expect(chunks?.finished).toBe(true);
367
- });
368
- });
369
-
370
- describe("co.fileStream", () => {
371
- const fs = co.fileStream().create({ owner: me });
372
-
373
- test("Construction", () => {
374
- expect(fs.getChunks()).toBe(undefined);
375
- });
376
-
377
- test("Type compatibility", () => {
378
- // Check base functionality works
379
- expectTypeOf(co.fileStream()).toHaveProperty("create");
380
-
381
- // We can acknowledge the type error exists
382
- // This is a runtime test that verifies that despite the TypeScript error,
383
- // the functionality still works as expected
384
- expect(typeof fs.getChunks).toBe("function");
385
- });
386
-
387
- test("Mutation", () => {
388
- fs.start({ mimeType: "text/plain" });
389
- fs.push(new Uint8Array([1, 2, 3]));
390
- fs.push(new Uint8Array([4, 5, 6]));
391
- fs.end();
392
- });
393
- });
394
- });
395
-
396
- describe("FileStream loading & Subscription", async () => {
397
- const initNodeAndStream = async () => {
398
- const me = await Account.create({
399
- creationProps: { name: "Hermes Puggington" },
400
- crypto: Crypto,
401
- });
402
-
403
- const stream = FileStream.create({ owner: me });
404
-
405
- stream.start({ mimeType: "text/plain" });
406
- stream.push(new Uint8Array([1, 2, 3]));
407
- stream.push(new Uint8Array([4, 5, 6]));
408
- stream.end();
409
-
410
- return { me, stream };
411
- };
412
-
413
- test("Construction", async () => {
414
- const { stream } = await initNodeAndStream();
415
- expect(stream.getChunks()).toEqual({
416
- mimeType: "text/plain",
417
- chunks: [new Uint8Array([1, 2, 3]), new Uint8Array([4, 5, 6])],
418
- finished: true,
419
- });
420
- });
421
-
422
- test("Loading and availability", async () => {
423
- const { me, stream } = await initNodeAndStream();
424
- const [initialAsPeer, secondAsPeer] = connectedPeers("initial", "second", {
425
- peer1role: "server",
426
- peer2role: "client",
427
- });
428
- if (!isControlledAccount(me)) {
429
- throw "me is not a controlled account";
430
- }
431
- me._raw.core.node.syncManager.addPeer(secondAsPeer);
432
- const { account: meOnSecondPeer } =
433
- await createJazzContextFromExistingCredentials({
434
- credentials: {
435
- accountID: me.id,
436
- secret: me._raw.core.node.getCurrentAgent().agentSecret,
437
- },
438
- sessionProvider: randomSessionProvider,
439
- peersToLoadFrom: [initialAsPeer],
440
- crypto: Crypto,
441
- });
442
-
443
- const loadedStream = await FileStream.load(stream.id, {
444
- loadAs: meOnSecondPeer,
445
- });
446
-
447
- expect(loadedStream?.getChunks()).toEqual({
448
- mimeType: "text/plain",
449
- chunks: [new Uint8Array([1, 2, 3]), new Uint8Array([4, 5, 6])],
450
- finished: true,
451
- });
452
- });
453
-
454
- test("Subscription", async () => {
455
- const { me } = await initNodeAndStream();
456
- const stream = FileStream.create({ owner: me });
457
-
458
- const [initialAsPeer, secondAsPeer] = connectedPeers("initial", "second", {
459
- peer1role: "server",
460
- peer2role: "client",
461
- });
462
- me._raw.core.node.syncManager.addPeer(secondAsPeer);
463
- if (!isControlledAccount(me)) {
464
- throw "me is not a controlled account";
465
- }
466
- const { account: meOnSecondPeer } =
467
- await createJazzContextFromExistingCredentials({
468
- credentials: {
469
- accountID: me.id,
470
- secret: me._raw.core.node.getCurrentAgent().agentSecret,
471
- },
472
- sessionProvider: randomSessionProvider,
473
- peersToLoadFrom: [initialAsPeer],
474
- crypto: Crypto,
475
- });
476
-
477
- const queue = new cojsonInternals.Channel();
478
-
479
- FileStream.subscribe(
480
- stream.id,
481
- { loadAs: meOnSecondPeer },
482
- (subscribedStream) => {
483
- void queue.push(subscribedStream);
484
- },
485
- );
486
-
487
- const update1 = (await queue.next()).value;
488
- expect(update1.getChunks()).toBe(undefined);
489
-
490
- stream.start({ mimeType: "text/plain" });
491
-
492
- const update2 = (await queue.next()).value;
493
- expect(update2.getChunks({ allowUnfinished: true })).toEqual({
494
- mimeType: "text/plain",
495
- fileName: undefined,
496
- chunks: [],
497
- totalSizeBytes: undefined,
498
- finished: false,
499
- });
500
-
501
- stream.push(new Uint8Array([1, 2, 3]));
502
-
503
- const update3 = (await queue.next()).value;
504
- expect(update3.getChunks({ allowUnfinished: true })).toEqual({
505
- mimeType: "text/plain",
506
- fileName: undefined,
507
- chunks: [new Uint8Array([1, 2, 3])],
508
- totalSizeBytes: undefined,
509
- finished: false,
510
- });
511
-
512
- stream.push(new Uint8Array([4, 5, 6]));
513
-
514
- const update4 = (await queue.next()).value;
515
- expect(update4.getChunks({ allowUnfinished: true })).toEqual({
516
- mimeType: "text/plain",
517
- fileName: undefined,
518
- chunks: [new Uint8Array([1, 2, 3]), new Uint8Array([4, 5, 6])],
519
- totalSizeBytes: undefined,
520
- finished: false,
521
- });
522
-
523
- stream.end();
524
-
525
- const update5 = (await queue.next()).value;
526
- expect(update5.getChunks()).toEqual({
527
- mimeType: "text/plain",
528
- fileName: undefined,
529
- chunks: [new Uint8Array([1, 2, 3]), new Uint8Array([4, 5, 6])],
530
- totalSizeBytes: undefined,
531
- finished: true,
532
- });
533
- });
534
-
535
- test("Subscription without options", async () => {
536
- const { me } = await initNodeAndStream();
537
- const stream = FileStream.create({ owner: me });
538
-
539
- const [initialAsPeer, secondAsPeer] = connectedPeers("initial", "second", {
540
- peer1role: "server",
541
- peer2role: "client",
542
- });
543
- me._raw.core.node.syncManager.addPeer(secondAsPeer);
544
- if (!isControlledAccount(me)) {
545
- throw "me is not a controlled account";
546
- }
547
- await createJazzContextFromExistingCredentials({
548
- credentials: {
549
- accountID: me.id,
550
- secret: me._raw.core.node.getCurrentAgent().agentSecret,
551
- },
552
- sessionProvider: randomSessionProvider,
553
- peersToLoadFrom: [initialAsPeer],
554
- crypto: Crypto,
555
- });
556
-
557
- const queue = new cojsonInternals.Channel();
558
-
559
- FileStream.subscribe(stream.id, (subscribedStream) => {
560
- void queue.push(subscribedStream);
561
- });
562
-
563
- // Initial state
564
- const update1 = (await queue.next()).value;
565
- expect(update1.getChunks()).toBe(undefined);
566
-
567
- // Start the stream
568
- stream.start({ mimeType: "text/plain" });
569
- const update2 = (await queue.next()).value;
570
- expect(update2.getChunks({ allowUnfinished: true })).toMatchObject({
571
- mimeType: "text/plain",
572
- finished: false,
573
- });
574
-
575
- // Push a chunk
576
- stream.push(new Uint8Array([1, 2, 3]));
577
- const update3 = (await queue.next()).value;
578
- expect(update3.getChunks({ allowUnfinished: true })?.chunks).toHaveLength(
579
- 1,
580
- );
581
- expect(update3.getChunks({ allowUnfinished: true })?.chunks?.[0]).toEqual(
582
- new Uint8Array([1, 2, 3]),
583
- );
584
-
585
- // End the stream
586
- stream.end();
587
- const update4 = (await queue.next()).value;
588
- expect(update4.getChunks()?.finished).toBe(true);
589
- });
590
- });
591
-
592
- describe("FileStream.load", async () => {
593
- async function setup() {
594
- const me = await Account.create({
595
- creationProps: { name: "Hermes Puggington" },
596
- crypto: Crypto,
597
- });
598
-
599
- const stream = FileStream.create({ owner: me });
600
-
601
- stream.start({ mimeType: "text/plain" });
602
-
603
- return { stream, me };
604
- }
605
-
606
- test("resolves only when the stream is ended", async () => {
607
- const { stream, me } = await setup();
608
- stream.push(new Uint8Array([1]));
609
-
610
- const promise = FileStream.load(stream.id, { loadAs: me });
611
-
612
- stream.push(new Uint8Array([2]));
613
- stream.end();
614
-
615
- const blob = await promise;
616
-
617
- // The promise resolves only when the stream is ended
618
- // so we get a blob with all the chunks
619
- expect(blob?.getChunks()?.finished).toBe(true);
620
- });
621
-
622
- test("resolves with an unfinshed blob if allowUnfinished: true", async () => {
623
- const { stream, me } = await setup();
624
- stream.push(new Uint8Array([1]));
625
-
626
- const promise = FileStream.load(stream.id, {
627
- loadAs: me,
628
- allowUnfinished: true,
629
- });
630
-
631
- const blob = await promise;
632
-
633
- stream.push(new Uint8Array([2]));
634
-
635
- // The promise resolves before the stream is ended
636
- // so we get a blob only with the first chunk
637
- expect(blob?.getChunks({ allowUnfinished: true })?.finished).toBe(false);
638
- });
639
- });
640
-
641
- describe("FileStream.loadAsBlob", async () => {
642
- async function setup() {
643
- const me = await Account.create({
644
- creationProps: { name: "Hermes Puggington" },
645
- crypto: Crypto,
646
- });
647
-
648
- const stream = FileStream.create({ owner: me });
649
-
650
- stream.start({ mimeType: "text/plain" });
651
-
652
- return { stream, me };
653
- }
654
-
655
- test("resolves only when the stream is ended", async () => {
656
- const { stream, me } = await setup();
657
- stream.push(new Uint8Array([1]));
658
-
659
- const promise = FileStream.loadAsBlob(stream.id, { loadAs: me });
660
-
661
- stream.push(new Uint8Array([2]));
662
- stream.end();
663
-
664
- const blob = await promise;
665
-
666
- // The promise resolves only when the stream is ended
667
- // so we get a blob with all the chunks
668
- expect(blob?.size).toBe(2);
669
- });
670
-
671
- test("resolves with an unfinshed blob if allowUnfinished: true", async () => {
672
- const { stream, me } = await setup();
673
- stream.push(new Uint8Array([1]));
674
-
675
- const promise = FileStream.loadAsBlob(stream.id, {
676
- loadAs: me,
677
- allowUnfinished: true,
678
- });
679
-
680
- const blob = await promise;
681
-
682
- stream.push(new Uint8Array([2]));
683
- stream.end();
684
-
685
- // The promise resolves before the stream is ended
686
- // so we get a blob only with the first chunk
687
- expect(blob?.size).toBe(1);
688
- });
689
- });
690
-
691
- describe("FileStream progress tracking", async () => {
692
- test("createFromBlob should report upload progress correctly", async () => {
693
- // Create 5MB test blob
694
- const testData = new Uint8Array(5 * 1024 * 1024); // 5MB instead of 500KB
695
- for (let i = 0; i < testData.length; i++) testData[i] = i % 256;
696
- const testBlob = new Blob([testData]);
697
-
698
- // Collect progress updates
699
- const progressUpdates: number[] = [];
700
- await FileStream.createFromBlob(testBlob, {
701
- onProgress: (progress) => progressUpdates.push(progress),
702
- });
703
-
704
- // Verify progress reporting
705
- expect(progressUpdates.length).toBeGreaterThan(1);
706
-
707
- // Check values between 0-1, increasing, with final=1
708
- progressUpdates.forEach((p) => {
709
- expect(p).toBeGreaterThanOrEqual(0);
710
- expect(p).toBeLessThanOrEqual(1);
711
- });
712
-
713
- for (let i = 1; i < progressUpdates.length; i++) {
714
- expect(progressUpdates[i]!).toBeGreaterThanOrEqual(
715
- progressUpdates[i - 1]!,
716
- );
717
- }
718
-
719
- expect(progressUpdates[progressUpdates.length - 1]).toBe(1);
720
- });
721
- });
722
-
723
- describe("waitForSync", async () => {
724
- test("CoFeed: should resolve when the value is uploaded", async () => {
725
- const TestStream = co.feed(z.string());
726
-
727
- const { clientNode, serverNode, clientAccount } = await setupTwoNodes();
728
-
729
- const stream = TestStream.create(["1", "2", "3"], { owner: clientAccount });
730
-
731
- await stream.waitForSync({ timeout: 1000 });
732
-
733
- // Killing the client node so the serverNode can't load the map from it
734
- clientNode.gracefulShutdown();
735
-
736
- const loadedStream = await serverNode.load(stream._raw.id);
737
-
738
- expect(loadedStream).not.toBe("unavailable");
739
- });
740
-
741
- test("FileStream: should resolve when the value is uploaded", async () => {
742
- const { clientNode, serverNode, clientAccount } = await setupTwoNodes();
743
-
744
- const stream = FileStream.create({ owner: clientAccount });
745
-
746
- stream.start({ mimeType: "text/plain" });
747
- stream.push(new Uint8Array([2]));
748
- stream.end();
749
-
750
- await stream.waitForSync({ timeout: 1000 });
751
-
752
- // Killing the client node so the serverNode can't load the map from it
753
- clientNode.gracefulShutdown();
754
-
755
- const loadedStream = await serverNode.load(stream._raw.id);
756
-
757
- expect(loadedStream).not.toBe("unavailable");
758
- });
759
-
760
- test("should rely on the current active account if no account is provided", async () => {
761
- const account = await createJazzTestAccount({
762
- isCurrentActiveAccount: true,
763
- });
764
-
765
- const stream = FileStream.create();
766
- expect(stream._owner._type).toEqual("Group");
767
- expect(stream._owner.castAs(Group)._raw.roleOf(account._raw.id)).toEqual(
768
- "admin",
769
- );
770
- });
771
- });