jazz-tools 0.14.27 → 0.15.0

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 (871) 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 +21 -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-FSIM7N33.js +4827 -0
  65. package/dist/chunk-FSIM7N33.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 +2027 -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-page-path.d.ts +10 -0
  161. package/dist/inspector/viewer/use-page-path.d.ts.map +1 -0
  162. package/dist/inspector/viewer/use-resolve-covalue.d.ts +67 -0
  163. package/dist/inspector/viewer/use-resolve-covalue.d.ts.map +1 -0
  164. package/dist/inspector/viewer/value-renderer.d.ts +12 -0
  165. package/dist/inspector/viewer/value-renderer.d.ts.map +1 -0
  166. package/dist/prosemirror/index.d.ts +3 -0
  167. package/dist/prosemirror/index.d.ts.map +1 -0
  168. package/dist/prosemirror/index.js +2185 -0
  169. package/dist/prosemirror/index.js.map +1 -0
  170. package/dist/prosemirror/lib/converter.d.ts +33 -0
  171. package/dist/prosemirror/lib/converter.d.ts.map +1 -0
  172. package/dist/prosemirror/lib/plugin.d.ts +43 -0
  173. package/dist/prosemirror/lib/plugin.d.ts.map +1 -0
  174. package/dist/prosemirror/lib/sync.d.ts +35 -0
  175. package/dist/prosemirror/lib/sync.d.ts.map +1 -0
  176. package/dist/prosemirror/tests/plugin.test.d.ts +2 -0
  177. package/dist/prosemirror/tests/plugin.test.d.ts.map +1 -0
  178. package/dist/react/auth/Clerk.d.ts +7 -0
  179. package/dist/react/auth/Clerk.d.ts.map +1 -0
  180. package/dist/react/auth/DemoAuth.d.ts +5 -0
  181. package/dist/react/auth/DemoAuth.d.ts.map +1 -0
  182. package/dist/react/auth/PasskeyAuth.d.ts +24 -0
  183. package/dist/react/auth/PasskeyAuth.d.ts.map +1 -0
  184. package/dist/react/auth/PassphraseAuth.d.ts +6 -0
  185. package/dist/react/auth/PassphraseAuth.d.ts.map +1 -0
  186. package/dist/react/auth/auth.d.ts +6 -0
  187. package/dist/react/auth/auth.d.ts.map +1 -0
  188. package/dist/react/hooks.d.ts +9 -0
  189. package/dist/react/hooks.d.ts.map +1 -0
  190. package/dist/react/index.d.ts +8 -0
  191. package/dist/react/index.d.ts.map +1 -0
  192. package/dist/react/index.js +700 -0
  193. package/dist/react/index.js.map +1 -0
  194. package/dist/react/media.d.ts +24 -0
  195. package/dist/react/media.d.ts.map +1 -0
  196. package/dist/react/provider.d.ts +10 -0
  197. package/dist/react/provider.d.ts.map +1 -0
  198. package/dist/react/ssr.d.ts +4 -0
  199. package/dist/react/ssr.d.ts.map +1 -0
  200. package/dist/react/ssr.js +25 -0
  201. package/dist/react/ssr.js.map +1 -0
  202. package/dist/react/testing.d.ts +2 -0
  203. package/dist/react/testing.d.ts.map +1 -0
  204. package/dist/react/testing.js +5 -0
  205. package/dist/react/testing.js.map +1 -0
  206. package/dist/react/tests/testUtils.d.ts +14 -0
  207. package/dist/react/tests/testUtils.d.ts.map +1 -0
  208. package/dist/react/tests/useAcceptInvite.test.d.ts +2 -0
  209. package/dist/react/tests/useAcceptInvite.test.d.ts.map +1 -0
  210. package/dist/react-core/auth/DemoAuth.d.ts +17 -0
  211. package/dist/react-core/auth/DemoAuth.d.ts.map +1 -0
  212. package/dist/react-core/auth/PassphraseAuth.d.ts +21 -0
  213. package/dist/react-core/auth/PassphraseAuth.d.ts.map +1 -0
  214. package/dist/react-core/auth/index.d.ts +3 -0
  215. package/dist/react-core/auth/index.d.ts.map +1 -0
  216. package/dist/react-core/chunk-7DYMJ74I.js +12 -0
  217. package/dist/react-core/chunk-7DYMJ74I.js.map +1 -0
  218. package/dist/react-core/hooks.d.ts +17 -0
  219. package/dist/react-core/hooks.d.ts.map +1 -0
  220. package/dist/react-core/index.d.ts +4 -0
  221. package/dist/react-core/index.d.ts.map +1 -0
  222. package/dist/react-core/index.js +302 -0
  223. package/dist/react-core/index.js.map +1 -0
  224. package/dist/react-core/provider.d.ts +5 -0
  225. package/dist/react-core/provider.d.ts.map +1 -0
  226. package/dist/react-core/testing.d.ts +10 -0
  227. package/dist/react-core/testing.d.ts.map +1 -0
  228. package/dist/react-core/testing.js +43 -0
  229. package/dist/react-core/testing.js.map +1 -0
  230. package/dist/react-core/tests/fixtures.d.ts.map +1 -0
  231. package/dist/react-core/tests/testUtils.d.ts +15 -0
  232. package/dist/react-core/tests/testUtils.d.ts.map +1 -0
  233. package/dist/react-core/tests/useAccount.test.d.ts +2 -0
  234. package/dist/react-core/tests/useAccount.test.d.ts.map +1 -0
  235. package/dist/react-core/tests/useCoState.test.d.ts +2 -0
  236. package/dist/react-core/tests/useCoState.test.d.ts.map +1 -0
  237. package/dist/react-core/tests/useInboxSender.test.d.ts +2 -0
  238. package/dist/react-core/tests/useInboxSender.test.d.ts.map +1 -0
  239. package/dist/react-core/tests/useIsAuthenticated.test.d.ts +2 -0
  240. package/dist/react-core/tests/useIsAuthenticated.test.d.ts.map +1 -0
  241. package/dist/react-core/tests/usePassPhraseAuth.test.d.ts +2 -0
  242. package/dist/react-core/tests/usePassPhraseAuth.test.d.ts.map +1 -0
  243. package/dist/react-core/utils.d.ts +4 -0
  244. package/dist/react-core/utils.d.ts.map +1 -0
  245. package/dist/react-native/crypto.d.ts +2 -0
  246. package/dist/react-native/crypto.d.ts.map +1 -0
  247. package/dist/react-native/crypto.js +3 -0
  248. package/dist/react-native/crypto.js.map +1 -0
  249. package/dist/react-native/index.d.ts +5 -0
  250. package/dist/react-native/index.d.ts.map +1 -0
  251. package/dist/react-native/index.js +103 -0
  252. package/dist/react-native/index.js.map +1 -0
  253. package/dist/react-native/provider.d.ts +4 -0
  254. package/dist/react-native/provider.d.ts.map +1 -0
  255. package/dist/react-native/storage/mmkv-store-adapter.d.ts +8 -0
  256. package/dist/react-native/storage/mmkv-store-adapter.d.ts.map +1 -0
  257. package/dist/react-native/storage/op-sqlite-adapter.d.ts +13 -0
  258. package/dist/react-native/storage/op-sqlite-adapter.d.ts.map +1 -0
  259. package/dist/react-native/testing.d.ts +2 -0
  260. package/dist/react-native/testing.d.ts.map +1 -0
  261. package/dist/react-native/testing.js +3 -0
  262. package/dist/react-native/testing.js.map +1 -0
  263. package/dist/react-native-core/ReactNativeContextManager.d.ts +31 -0
  264. package/dist/react-native-core/ReactNativeContextManager.d.ts.map +1 -0
  265. package/dist/react-native-core/auth/DemoAuthUI.d.ts +8 -0
  266. package/dist/react-native-core/auth/DemoAuthUI.d.ts.map +1 -0
  267. package/dist/react-native-core/auth/auth.d.ts +3 -0
  268. package/dist/react-native-core/auth/auth.d.ts.map +1 -0
  269. package/dist/react-native-core/crypto/RNQuickCrypto.d.ts +15 -0
  270. package/dist/react-native-core/crypto/RNQuickCrypto.d.ts.map +1 -0
  271. package/dist/react-native-core/crypto/index.d.ts +2 -0
  272. package/dist/react-native-core/crypto/index.d.ts.map +1 -0
  273. package/dist/react-native-core/crypto.js +65 -0
  274. package/dist/react-native-core/crypto.js.map +1 -0
  275. package/dist/react-native-core/hooks.d.ts +8 -0
  276. package/dist/react-native-core/hooks.d.ts.map +1 -0
  277. package/dist/react-native-core/index.d.ts +9 -0
  278. package/dist/react-native-core/index.d.ts.map +1 -0
  279. package/dist/react-native-core/index.js +669 -0
  280. package/dist/react-native-core/index.js.map +1 -0
  281. package/dist/react-native-core/media.d.ts +24 -0
  282. package/dist/react-native-core/media.d.ts.map +1 -0
  283. package/dist/react-native-core/platform.d.ts +45 -0
  284. package/dist/react-native-core/platform.d.ts.map +1 -0
  285. package/dist/react-native-core/provider.d.ts +10 -0
  286. package/dist/react-native-core/provider.d.ts.map +1 -0
  287. package/dist/react-native-core/storage/kv-store-context.d.ts +17 -0
  288. package/dist/react-native-core/storage/kv-store-context.d.ts.map +1 -0
  289. package/dist/react-native-core/storage/sqlite-react-native.d.ts +9 -0
  290. package/dist/react-native-core/storage/sqlite-react-native.d.ts.map +1 -0
  291. package/dist/react-native-core/testing.js +3 -0
  292. package/dist/react-native-core/testing.js.map +1 -0
  293. package/dist/react-native-media-images/index.d.ts +7 -0
  294. package/dist/react-native-media-images/index.d.ts.map +1 -0
  295. package/dist/react-native-media-images/index.js +177 -0
  296. package/dist/react-native-media-images/index.js.map +1 -0
  297. package/dist/svelte/Provider.svelte +61 -0
  298. package/dist/svelte/Provider.svelte.d.ts +19 -0
  299. package/dist/svelte/Provider.svelte.d.ts.map +1 -0
  300. package/dist/svelte/auth/PasskeyAuth.svelte.d.ts +11 -0
  301. package/dist/svelte/auth/PasskeyAuth.svelte.d.ts.map +1 -0
  302. package/dist/svelte/auth/PasskeyAuth.svelte.js +20 -0
  303. package/dist/svelte/auth/PasskeyAuthBasicUI.svelte +81 -0
  304. package/dist/svelte/auth/PasskeyAuthBasicUI.svelte.d.ts +9 -0
  305. package/dist/svelte/auth/PasskeyAuthBasicUI.svelte.d.ts.map +1 -0
  306. package/dist/svelte/auth/PassphraseAuth.svelte.d.ts +12 -0
  307. package/dist/svelte/auth/PassphraseAuth.svelte.d.ts.map +1 -0
  308. package/dist/svelte/auth/PassphraseAuth.svelte.js +30 -0
  309. package/dist/svelte/auth/index.d.ts +4 -0
  310. package/dist/svelte/auth/index.d.ts.map +1 -0
  311. package/dist/svelte/auth/index.js +3 -0
  312. package/dist/svelte/auth/useIsAuthenticated.svelte.d.ts +6 -0
  313. package/dist/svelte/auth/useIsAuthenticated.svelte.d.ts.map +1 -0
  314. package/dist/svelte/auth/useIsAuthenticated.svelte.js +22 -0
  315. package/dist/svelte/index.d.ts +6 -0
  316. package/dist/svelte/index.d.ts.map +1 -0
  317. package/dist/svelte/index.js +5 -0
  318. package/dist/svelte/jazz.class.svelte.d.ts +21 -0
  319. package/dist/svelte/jazz.class.svelte.d.ts.map +1 -0
  320. package/dist/svelte/jazz.class.svelte.js +117 -0
  321. package/dist/svelte/jazz.svelte.d.ts +39 -0
  322. package/dist/svelte/jazz.svelte.d.ts.map +1 -0
  323. package/dist/svelte/jazz.svelte.js +70 -0
  324. package/dist/svelte/testing.d.ts +10 -0
  325. package/dist/svelte/testing.d.ts.map +1 -0
  326. package/dist/svelte/testing.js +23 -0
  327. package/dist/testing.d.ts +1 -42
  328. package/dist/testing.d.ts.map +1 -1
  329. package/dist/testing.js +2 -2
  330. package/dist/testing.js.map +1 -1
  331. package/dist/tiptap/index.d.ts +11 -0
  332. package/dist/tiptap/index.d.ts.map +1 -0
  333. package/dist/tiptap/index.js +22 -0
  334. package/dist/tiptap/index.js.map +1 -0
  335. package/dist/tools/auth/AuthSecretStorage.d.ts.map +1 -0
  336. package/dist/tools/auth/DemoAuth.d.ts.map +1 -0
  337. package/dist/tools/auth/InMemoryKVStore.d.ts.map +1 -0
  338. package/dist/tools/auth/KvStoreContext.d.ts.map +1 -0
  339. package/dist/tools/auth/PassphraseAuth.d.ts.map +1 -0
  340. package/dist/tools/auth/clerk/getClerkUsername.d.ts +3 -0
  341. package/dist/tools/auth/clerk/getClerkUsername.d.ts.map +1 -0
  342. package/dist/tools/auth/clerk/index.d.ts +25 -0
  343. package/dist/tools/auth/clerk/index.d.ts.map +1 -0
  344. package/dist/tools/auth/clerk/tests/JazzClerkAuth.test.d.ts +2 -0
  345. package/dist/tools/auth/clerk/tests/JazzClerkAuth.test.d.ts.map +1 -0
  346. package/dist/tools/auth/clerk/tests/getClerkUsername.test.d.ts +2 -0
  347. package/dist/tools/auth/clerk/tests/getClerkUsername.test.d.ts.map +1 -0
  348. package/dist/tools/auth/clerk/tests/types.test.d.ts +2 -0
  349. package/dist/tools/auth/clerk/tests/types.test.d.ts.map +1 -0
  350. package/dist/tools/auth/clerk/types.d.ts +32 -0
  351. package/dist/tools/auth/clerk/types.d.ts.map +1 -0
  352. package/dist/tools/coValues/CoValueBase.d.ts.map +1 -0
  353. package/dist/tools/coValues/account.d.ts.map +1 -0
  354. package/dist/tools/coValues/coFeed.d.ts +368 -0
  355. package/dist/tools/coValues/coFeed.d.ts.map +1 -0
  356. package/dist/tools/coValues/coList.d.ts.map +1 -0
  357. package/dist/tools/coValues/coMap.d.ts.map +1 -0
  358. package/dist/tools/coValues/coPlainText.d.ts.map +1 -0
  359. package/dist/tools/coValues/coRichText.d.ts.map +1 -0
  360. package/dist/tools/coValues/deepLoading.d.ts.map +1 -0
  361. package/dist/tools/coValues/extensions/imageDef.d.ts.map +1 -0
  362. package/dist/tools/coValues/group.d.ts.map +1 -0
  363. package/dist/tools/coValues/inbox.d.ts.map +1 -0
  364. package/dist/tools/coValues/interfaces.d.ts.map +1 -0
  365. package/dist/tools/coValues/profile.d.ts.map +1 -0
  366. package/dist/tools/coValues/registeredSchemas.d.ts.map +1 -0
  367. package/dist/tools/coValues/schemaUnion.d.ts.map +1 -0
  368. package/dist/tools/exports.d.ts +24 -0
  369. package/dist/tools/exports.d.ts.map +1 -0
  370. package/dist/tools/implementation/ContextManager.d.ts.map +1 -0
  371. package/dist/tools/implementation/activeAccountContext.d.ts.map +1 -0
  372. package/dist/tools/implementation/anonymousJazzAgent.d.ts.map +1 -0
  373. package/dist/tools/implementation/createContext.d.ts.map +1 -0
  374. package/dist/tools/implementation/devtoolsFormatters.d.ts.map +1 -0
  375. package/dist/tools/implementation/errors.d.ts.map +1 -0
  376. package/dist/tools/implementation/inspect.d.ts.map +1 -0
  377. package/dist/tools/implementation/invites.d.ts.map +1 -0
  378. package/dist/tools/implementation/refs.d.ts.map +1 -0
  379. package/dist/tools/implementation/schema.d.ts.map +1 -0
  380. package/dist/tools/implementation/symbols.d.ts.map +1 -0
  381. package/dist/tools/implementation/zodSchema/coExport.d.ts.map +1 -0
  382. package/dist/tools/implementation/zodSchema/runtimeConverters/zodFieldToCoFieldDef.d.ts.map +1 -0
  383. package/dist/tools/implementation/zodSchema/runtimeConverters/zodSchemaToCoSchema.d.ts.map +1 -0
  384. package/dist/tools/implementation/zodSchema/schemaTypes/AccountSchema.d.ts.map +1 -0
  385. package/dist/tools/implementation/zodSchema/schemaTypes/CoFeedSchema.d.ts.map +1 -0
  386. package/dist/tools/implementation/zodSchema/schemaTypes/CoListSchema.d.ts.map +1 -0
  387. package/dist/tools/implementation/zodSchema/schemaTypes/CoMapSchema.d.ts.map +1 -0
  388. package/dist/tools/implementation/zodSchema/schemaTypes/CoRecordSchema.d.ts.map +1 -0
  389. package/dist/tools/implementation/zodSchema/schemaTypes/FileStreamSchema.d.ts.map +1 -0
  390. package/dist/tools/implementation/zodSchema/schemaTypes/PlainTextSchema.d.ts.map +1 -0
  391. package/dist/tools/implementation/zodSchema/schemaTypes/RichTextSchema.d.ts.map +1 -0
  392. package/dist/tools/implementation/zodSchema/typeConverters/InstanceOfSchema.d.ts.map +1 -0
  393. package/dist/tools/implementation/zodSchema/typeConverters/InstanceOfSchemaCoValuesNullable.d.ts.map +1 -0
  394. package/dist/tools/implementation/zodSchema/typeConverters/InstanceOrPrimitiveOfSchema.d.ts.map +1 -0
  395. package/dist/tools/implementation/zodSchema/typeConverters/InstanceOrPrimitiveOfSchemaCoValuesNullable.d.ts.map +1 -0
  396. package/dist/tools/implementation/zodSchema/unionUtils.d.ts.map +1 -0
  397. package/dist/tools/implementation/zodSchema/zodCo.d.ts.map +1 -0
  398. package/dist/tools/implementation/zodSchema/zodReExport.d.ts.map +1 -0
  399. package/dist/tools/implementation/zodSchema/zodSchema.d.ts.map +1 -0
  400. package/dist/tools/index.d.ts +3 -0
  401. package/dist/tools/index.d.ts.map +1 -0
  402. package/dist/tools/internal.d.ts.map +1 -0
  403. package/dist/tools/lib/cache.d.ts.map +1 -0
  404. package/dist/tools/lib/cache.test.d.ts.map +1 -0
  405. package/dist/tools/lib/migration.d.ts.map +1 -0
  406. package/dist/tools/subscribe/CoValueCoreSubscription.d.ts.map +1 -0
  407. package/dist/tools/subscribe/JazzError.d.ts.map +1 -0
  408. package/dist/tools/subscribe/SubscriptionScope.d.ts.map +1 -0
  409. package/dist/tools/subscribe/index.d.ts.map +1 -0
  410. package/dist/tools/subscribe/types.d.ts.map +1 -0
  411. package/dist/tools/subscribe/utils.d.ts.map +1 -0
  412. package/dist/tools/testing.d.ts +43 -0
  413. package/dist/tools/testing.d.ts.map +1 -0
  414. package/dist/tools/tests/AuthSecretStorage.test.d.ts.map +1 -0
  415. package/dist/tools/tests/ContextManager.test.d.ts.map +1 -0
  416. package/dist/tools/tests/DemoAuth.test.d.ts.map +1 -0
  417. package/dist/tools/tests/PassphraseAuth.test.d.ts.map +1 -0
  418. package/dist/tools/tests/account.test.d.ts.map +1 -0
  419. package/dist/tools/tests/coFeed.test-d.d.ts.map +1 -0
  420. package/dist/tools/tests/coFeed.test.d.ts.map +1 -0
  421. package/dist/tools/tests/coList.test-d.d.ts.map +1 -0
  422. package/dist/tools/tests/coList.test.d.ts.map +1 -0
  423. package/dist/tools/tests/coMap.record.test-d.d.ts.map +1 -0
  424. package/dist/tools/tests/coMap.record.test.d.ts.map +1 -0
  425. package/dist/tools/tests/coMap.test-d.d.ts.map +1 -0
  426. package/dist/tools/tests/coMap.test.d.ts.map +1 -0
  427. package/dist/tools/tests/coPlainText.test.d.ts.map +1 -0
  428. package/dist/tools/tests/createContext.test.d.ts.map +1 -0
  429. package/dist/tools/tests/deepLoading.test.d.ts.map +1 -0
  430. package/dist/tools/tests/fixtures.d.ts +2 -0
  431. package/dist/tools/tests/fixtures.d.ts.map +1 -0
  432. package/dist/tools/tests/groupsAndAccounts.test.d.ts.map +1 -0
  433. package/dist/tools/tests/imageDef.test.d.ts.map +1 -0
  434. package/dist/tools/tests/inbox.test.d.ts.map +1 -0
  435. package/dist/tools/tests/interfaces.test.d.ts.map +1 -0
  436. package/dist/tools/tests/invites.test.d.ts.map +1 -0
  437. package/dist/tools/tests/load.test.d.ts.map +1 -0
  438. package/dist/tools/tests/patterns/notifications.test.d.ts.map +1 -0
  439. package/dist/tools/tests/patterns/requestToJoin.test.d.ts.map +1 -0
  440. package/dist/tools/tests/schema.test.d.ts.map +1 -0
  441. package/dist/tools/tests/schemaUnion.test.d.ts.map +1 -0
  442. package/dist/tools/tests/subscribe.test.d.ts.map +1 -0
  443. package/dist/tools/tests/testing.test.d.ts.map +1 -0
  444. package/dist/tools/tests/utils.d.ts.map +1 -0
  445. package/dist/tools/tests/zod.test.d.ts.map +1 -0
  446. package/dist/tools/types.d.ts.map +1 -0
  447. package/dist/worker/index.d.ts +25 -0
  448. package/dist/worker/index.d.ts.map +1 -0
  449. package/dist/worker/index.js +93 -0
  450. package/dist/worker/index.js.map +1 -0
  451. package/package.json +193 -11
  452. package/src/browser/BrowserContextManager.ts +85 -0
  453. package/src/browser/auth/LocalStorageKVStore.ts +21 -0
  454. package/src/browser/auth/PasskeyAuth.ts +175 -0
  455. package/src/browser/createBrowserContext.ts +326 -0
  456. package/src/browser/index.ts +72 -0
  457. package/src/browser/storageOptions.ts +17 -0
  458. package/src/browser/tests/LocalStorageKVStore.test.ts +67 -0
  459. package/src/browser/tests/PasskeyAuth.test.ts +242 -0
  460. package/src/browser/tests/createInviteLink.test.ts +18 -0
  461. package/src/browser/tests/storageOptions.test.ts +33 -0
  462. package/src/browser/tests/utils.ts +93 -0
  463. package/src/browser/utils/export-account-inspector.ts +58 -0
  464. package/src/browser-media-images/index.ts +130 -0
  465. package/src/expo/auth/clerk/README.md +44 -0
  466. package/src/expo/auth/clerk/index.tsx +80 -0
  467. package/src/expo/crypto.ts +1 -0
  468. package/src/expo/index.ts +6 -0
  469. package/src/expo/provider.tsx +29 -0
  470. package/src/expo/storage/expo-secure-store-adapter.ts +29 -0
  471. package/src/expo/storage/expo-sqlite-adapter.ts +94 -0
  472. package/src/expo/testing.ts +1 -0
  473. package/src/index.ts +1 -3
  474. package/src/inspector/custom-element.tsx +63 -0
  475. package/src/inspector/index.ts +23 -0
  476. package/src/inspector/register-custom-element.ts +3 -0
  477. package/src/inspector/ui/badge.tsx +20 -0
  478. package/src/inspector/ui/button.tsx +81 -0
  479. package/src/inspector/ui/card.tsx +23 -0
  480. package/src/inspector/ui/global-styles.tsx +74 -0
  481. package/src/inspector/ui/grid.tsx +48 -0
  482. package/src/inspector/ui/heading.tsx +15 -0
  483. package/src/inspector/ui/icon.tsx +71 -0
  484. package/src/inspector/ui/icons/chevron-down-icon.tsx +16 -0
  485. package/src/inspector/ui/icons/delete-icon.tsx +19 -0
  486. package/src/inspector/ui/icons/link-icon.tsx +18 -0
  487. package/src/inspector/ui/input.tsx +51 -0
  488. package/src/inspector/ui/select.tsx +73 -0
  489. package/src/inspector/ui/table.tsx +90 -0
  490. package/src/inspector/ui/text.tsx +62 -0
  491. package/src/inspector/viewer/account-or-group-text.tsx +52 -0
  492. package/src/inspector/viewer/account-view.tsx +34 -0
  493. package/src/inspector/viewer/breadcrumbs.tsx +52 -0
  494. package/src/inspector/viewer/co-stream-view.tsx +374 -0
  495. package/src/inspector/viewer/grid-view.tsx +90 -0
  496. package/src/inspector/viewer/group-view.tsx +67 -0
  497. package/src/inspector/viewer/inpsector-button.tsx +89 -0
  498. package/src/inspector/viewer/new-app.tsx +171 -0
  499. package/src/inspector/viewer/page-stack.tsx +56 -0
  500. package/src/inspector/viewer/page.tsx +199 -0
  501. package/src/inspector/viewer/raw-data-card.tsx +53 -0
  502. package/src/inspector/viewer/role-display.tsx +28 -0
  503. package/src/inspector/viewer/table-viewer.tsx +184 -0
  504. package/src/inspector/viewer/type-icon.tsx +63 -0
  505. package/src/inspector/viewer/types.ts +11 -0
  506. package/src/inspector/viewer/use-page-path.ts +52 -0
  507. package/src/inspector/viewer/use-resolve-covalue.ts +214 -0
  508. package/src/inspector/viewer/value-renderer.tsx +266 -0
  509. package/src/prosemirror/index.ts +2 -0
  510. package/src/prosemirror/lib/converter.ts +50 -0
  511. package/src/prosemirror/lib/plugin.ts +120 -0
  512. package/src/prosemirror/lib/sync.ts +96 -0
  513. package/src/prosemirror/tests/plugin.test.ts +127 -0
  514. package/src/react/auth/Clerk.tsx +82 -0
  515. package/src/react/auth/DemoAuth.tsx +121 -0
  516. package/src/react/auth/PasskeyAuth.tsx +168 -0
  517. package/src/react/auth/PassphraseAuth.tsx +196 -0
  518. package/src/react/auth/auth.ts +9 -0
  519. package/src/react/hooks.tsx +53 -0
  520. package/src/react/index.ts +16 -0
  521. package/src/react/media.tsx +74 -0
  522. package/src/react/provider.tsx +114 -0
  523. package/src/react/scratch.tsx +50 -0
  524. package/src/react/ssr.ts +25 -0
  525. package/src/react/testing.tsx +1 -0
  526. package/src/react/tests/testUtils.tsx +54 -0
  527. package/src/react/tests/useAcceptInvite.test.ts +55 -0
  528. package/src/react-core/auth/DemoAuth.tsx +47 -0
  529. package/src/react-core/auth/PassphraseAuth.tsx +58 -0
  530. package/src/react-core/auth/index.ts +2 -0
  531. package/src/react-core/hooks.ts +310 -0
  532. package/src/react-core/index.ts +3 -0
  533. package/src/react-core/provider.tsx +11 -0
  534. package/src/react-core/testing.tsx +42 -0
  535. package/src/react-core/tests/testUtils.tsx +65 -0
  536. package/src/react-core/tests/useAccount.test.ts +238 -0
  537. package/src/react-core/tests/useCoState.test.ts +553 -0
  538. package/src/react-core/tests/useDemoAuth.test.tsx +84 -0
  539. package/src/react-core/tests/useInboxSender.test.ts +58 -0
  540. package/src/react-core/tests/useIsAuthenticated.test.ts +34 -0
  541. package/src/react-core/tests/usePassPhraseAuth.test.ts +180 -0
  542. package/src/react-core/utils.ts +28 -0
  543. package/src/react-native/crypto.ts +1 -0
  544. package/src/react-native/index.ts +5 -0
  545. package/src/react-native/provider.tsx +30 -0
  546. package/src/react-native/storage/mmkv-store-adapter.ts +24 -0
  547. package/src/react-native/storage/op-sqlite-adapter.ts +79 -0
  548. package/src/react-native/testing.ts +1 -0
  549. package/src/react-native-core/ReactNativeContextManager.ts +84 -0
  550. package/src/react-native-core/auth/DemoAuthUI.tsx +202 -0
  551. package/src/react-native-core/auth/auth.ts +14 -0
  552. package/src/react-native-core/crypto/RNQuickCrypto.ts +92 -0
  553. package/src/react-native-core/crypto/index.ts +1 -0
  554. package/src/react-native-core/hooks.tsx +64 -0
  555. package/src/react-native-core/index.ts +9 -0
  556. package/src/react-native-core/media.tsx +99 -0
  557. package/src/react-native-core/platform.ts +250 -0
  558. package/src/react-native-core/provider.tsx +115 -0
  559. package/src/react-native-core/storage/sqlite-react-native.ts +19 -0
  560. package/src/react-native-core/testing.tsx +1 -0
  561. package/src/react-native-media-images/index.ts +238 -0
  562. package/src/svelte/Provider.svelte +61 -0
  563. package/src/svelte/auth/PasskeyAuth.svelte.ts +42 -0
  564. package/src/svelte/auth/PasskeyAuthBasicUI.svelte +81 -0
  565. package/src/svelte/auth/PassphraseAuth.svelte.ts +49 -0
  566. package/src/svelte/auth/index.ts +3 -0
  567. package/src/svelte/auth/useIsAuthenticated.svelte.ts +28 -0
  568. package/src/svelte/index.ts +5 -0
  569. package/src/svelte/jazz.class.svelte.ts +172 -0
  570. package/src/svelte/jazz.svelte.ts +109 -0
  571. package/src/svelte/testing.ts +42 -0
  572. package/src/testing.ts +1 -312
  573. package/src/tiptap/index.ts +28 -0
  574. package/src/tools/auth/KvStoreContext.ts +39 -0
  575. package/src/tools/auth/clerk/getClerkUsername.ts +36 -0
  576. package/src/tools/auth/clerk/index.ts +174 -0
  577. package/src/tools/auth/clerk/tests/JazzClerkAuth.test.ts +284 -0
  578. package/src/tools/auth/clerk/tests/getClerkUsername.test.ts +81 -0
  579. package/src/tools/auth/clerk/tests/types.test.ts +49 -0
  580. package/src/tools/auth/clerk/types.ts +56 -0
  581. package/src/tools/coValues/coFeed.ts +943 -0
  582. package/src/tools/exports.ts +117 -0
  583. package/src/tools/index.ts +8 -0
  584. package/src/tools/testing.ts +301 -0
  585. package/src/tools/tests/coFeed.test.ts +771 -0
  586. package/src/tools/tests/fixtures.ts +2050 -0
  587. package/src/worker/index.ts +127 -0
  588. package/tsconfig.json +10 -3
  589. package/tsconfig.svelte.json +6 -0
  590. package/tsup.config.ts +143 -9
  591. package/dist/auth/AuthSecretStorage.d.ts.map +0 -1
  592. package/dist/auth/DemoAuth.d.ts.map +0 -1
  593. package/dist/auth/InMemoryKVStore.d.ts.map +0 -1
  594. package/dist/auth/KvStoreContext.d.ts.map +0 -1
  595. package/dist/auth/PassphraseAuth.d.ts.map +0 -1
  596. package/dist/chunk-G3QC4FAY.js +0 -4826
  597. package/dist/chunk-G3QC4FAY.js.map +0 -1
  598. package/dist/coValues/CoValueBase.d.ts.map +0 -1
  599. package/dist/coValues/account.d.ts.map +0 -1
  600. package/dist/coValues/coFeed.d.ts +0 -367
  601. package/dist/coValues/coFeed.d.ts.map +0 -1
  602. package/dist/coValues/coList.d.ts.map +0 -1
  603. package/dist/coValues/coMap.d.ts.map +0 -1
  604. package/dist/coValues/coPlainText.d.ts.map +0 -1
  605. package/dist/coValues/coRichText.d.ts.map +0 -1
  606. package/dist/coValues/deepLoading.d.ts.map +0 -1
  607. package/dist/coValues/extensions/imageDef.d.ts.map +0 -1
  608. package/dist/coValues/group.d.ts.map +0 -1
  609. package/dist/coValues/inbox.d.ts.map +0 -1
  610. package/dist/coValues/interfaces.d.ts.map +0 -1
  611. package/dist/coValues/profile.d.ts.map +0 -1
  612. package/dist/coValues/registeredSchemas.d.ts.map +0 -1
  613. package/dist/coValues/schemaUnion.d.ts.map +0 -1
  614. package/dist/exports.d.ts +0 -23
  615. package/dist/exports.d.ts.map +0 -1
  616. package/dist/implementation/ContextManager.d.ts.map +0 -1
  617. package/dist/implementation/activeAccountContext.d.ts.map +0 -1
  618. package/dist/implementation/anonymousJazzAgent.d.ts.map +0 -1
  619. package/dist/implementation/createContext.d.ts.map +0 -1
  620. package/dist/implementation/devtoolsFormatters.d.ts.map +0 -1
  621. package/dist/implementation/errors.d.ts.map +0 -1
  622. package/dist/implementation/inspect.d.ts.map +0 -1
  623. package/dist/implementation/invites.d.ts.map +0 -1
  624. package/dist/implementation/refs.d.ts.map +0 -1
  625. package/dist/implementation/schema.d.ts.map +0 -1
  626. package/dist/implementation/symbols.d.ts.map +0 -1
  627. package/dist/implementation/zodSchema/coExport.d.ts.map +0 -1
  628. package/dist/implementation/zodSchema/runtimeConverters/zodFieldToCoFieldDef.d.ts.map +0 -1
  629. package/dist/implementation/zodSchema/runtimeConverters/zodSchemaToCoSchema.d.ts.map +0 -1
  630. package/dist/implementation/zodSchema/schemaTypes/AccountSchema.d.ts.map +0 -1
  631. package/dist/implementation/zodSchema/schemaTypes/CoFeedSchema.d.ts.map +0 -1
  632. package/dist/implementation/zodSchema/schemaTypes/CoListSchema.d.ts.map +0 -1
  633. package/dist/implementation/zodSchema/schemaTypes/CoMapSchema.d.ts.map +0 -1
  634. package/dist/implementation/zodSchema/schemaTypes/CoRecordSchema.d.ts.map +0 -1
  635. package/dist/implementation/zodSchema/schemaTypes/FileStreamSchema.d.ts.map +0 -1
  636. package/dist/implementation/zodSchema/schemaTypes/PlainTextSchema.d.ts.map +0 -1
  637. package/dist/implementation/zodSchema/schemaTypes/RichTextSchema.d.ts.map +0 -1
  638. package/dist/implementation/zodSchema/typeConverters/InstanceOfSchema.d.ts.map +0 -1
  639. package/dist/implementation/zodSchema/typeConverters/InstanceOfSchemaCoValuesNullable.d.ts.map +0 -1
  640. package/dist/implementation/zodSchema/typeConverters/InstanceOrPrimitiveOfSchema.d.ts.map +0 -1
  641. package/dist/implementation/zodSchema/typeConverters/InstanceOrPrimitiveOfSchemaCoValuesNullable.d.ts.map +0 -1
  642. package/dist/implementation/zodSchema/unionUtils.d.ts.map +0 -1
  643. package/dist/implementation/zodSchema/zodCo.d.ts.map +0 -1
  644. package/dist/implementation/zodSchema/zodReExport.d.ts.map +0 -1
  645. package/dist/implementation/zodSchema/zodSchema.d.ts.map +0 -1
  646. package/dist/internal.d.ts.map +0 -1
  647. package/dist/lib/cache.d.ts.map +0 -1
  648. package/dist/lib/cache.test.d.ts.map +0 -1
  649. package/dist/lib/migration.d.ts.map +0 -1
  650. package/dist/subscribe/CoValueCoreSubscription.d.ts.map +0 -1
  651. package/dist/subscribe/JazzError.d.ts.map +0 -1
  652. package/dist/subscribe/SubscriptionScope.d.ts.map +0 -1
  653. package/dist/subscribe/index.d.ts.map +0 -1
  654. package/dist/subscribe/types.d.ts.map +0 -1
  655. package/dist/subscribe/utils.d.ts.map +0 -1
  656. package/dist/tests/AuthSecretStorage.test.d.ts.map +0 -1
  657. package/dist/tests/ContextManager.test.d.ts.map +0 -1
  658. package/dist/tests/DemoAuth.test.d.ts.map +0 -1
  659. package/dist/tests/PassphraseAuth.test.d.ts.map +0 -1
  660. package/dist/tests/account.test.d.ts.map +0 -1
  661. package/dist/tests/coFeed.test-d.d.ts.map +0 -1
  662. package/dist/tests/coFeed.test.d.ts.map +0 -1
  663. package/dist/tests/coList.test-d.d.ts.map +0 -1
  664. package/dist/tests/coList.test.d.ts.map +0 -1
  665. package/dist/tests/coMap.record.test-d.d.ts.map +0 -1
  666. package/dist/tests/coMap.record.test.d.ts.map +0 -1
  667. package/dist/tests/coMap.test-d.d.ts.map +0 -1
  668. package/dist/tests/coMap.test.d.ts.map +0 -1
  669. package/dist/tests/coPlainText.test.d.ts.map +0 -1
  670. package/dist/tests/createContext.test.d.ts.map +0 -1
  671. package/dist/tests/deepLoading.test.d.ts.map +0 -1
  672. package/dist/tests/fixtures.d.ts.map +0 -1
  673. package/dist/tests/groupsAndAccounts.test.d.ts.map +0 -1
  674. package/dist/tests/imageDef.test.d.ts.map +0 -1
  675. package/dist/tests/inbox.test.d.ts.map +0 -1
  676. package/dist/tests/interfaces.test.d.ts.map +0 -1
  677. package/dist/tests/invites.test.d.ts.map +0 -1
  678. package/dist/tests/load.test.d.ts.map +0 -1
  679. package/dist/tests/patterns/notifications.test.d.ts.map +0 -1
  680. package/dist/tests/patterns/requestToJoin.test.d.ts.map +0 -1
  681. package/dist/tests/schema.test.d.ts.map +0 -1
  682. package/dist/tests/schemaUnion.test.d.ts.map +0 -1
  683. package/dist/tests/subscribe.test.d.ts.map +0 -1
  684. package/dist/tests/testing.test.d.ts.map +0 -1
  685. package/dist/tests/utils.d.ts.map +0 -1
  686. package/dist/tests/zod.test.d.ts.map +0 -1
  687. package/dist/types.d.ts.map +0 -1
  688. package/src/coValues/coFeed.ts +0 -938
  689. package/src/exports.ts +0 -108
  690. package/src/tests/coFeed.test.ts +0 -722
  691. /package/dist/{tests → react-core/tests}/fixtures.d.ts +0 -0
  692. /package/dist/{auth → tools/auth}/AuthSecretStorage.d.ts +0 -0
  693. /package/dist/{auth → tools/auth}/DemoAuth.d.ts +0 -0
  694. /package/dist/{auth → tools/auth}/InMemoryKVStore.d.ts +0 -0
  695. /package/dist/{auth → tools/auth}/KvStoreContext.d.ts +0 -0
  696. /package/dist/{auth → tools/auth}/PassphraseAuth.d.ts +0 -0
  697. /package/dist/{coValues → tools/coValues}/CoValueBase.d.ts +0 -0
  698. /package/dist/{coValues → tools/coValues}/account.d.ts +0 -0
  699. /package/dist/{coValues → tools/coValues}/coList.d.ts +0 -0
  700. /package/dist/{coValues → tools/coValues}/coMap.d.ts +0 -0
  701. /package/dist/{coValues → tools/coValues}/coPlainText.d.ts +0 -0
  702. /package/dist/{coValues → tools/coValues}/coRichText.d.ts +0 -0
  703. /package/dist/{coValues → tools/coValues}/deepLoading.d.ts +0 -0
  704. /package/dist/{coValues → tools/coValues}/extensions/imageDef.d.ts +0 -0
  705. /package/dist/{coValues → tools/coValues}/group.d.ts +0 -0
  706. /package/dist/{coValues → tools/coValues}/inbox.d.ts +0 -0
  707. /package/dist/{coValues → tools/coValues}/interfaces.d.ts +0 -0
  708. /package/dist/{coValues → tools/coValues}/profile.d.ts +0 -0
  709. /package/dist/{coValues → tools/coValues}/registeredSchemas.d.ts +0 -0
  710. /package/dist/{coValues → tools/coValues}/schemaUnion.d.ts +0 -0
  711. /package/dist/{implementation → tools/implementation}/ContextManager.d.ts +0 -0
  712. /package/dist/{implementation → tools/implementation}/activeAccountContext.d.ts +0 -0
  713. /package/dist/{implementation → tools/implementation}/anonymousJazzAgent.d.ts +0 -0
  714. /package/dist/{implementation → tools/implementation}/createContext.d.ts +0 -0
  715. /package/dist/{implementation → tools/implementation}/devtoolsFormatters.d.ts +0 -0
  716. /package/dist/{implementation → tools/implementation}/errors.d.ts +0 -0
  717. /package/dist/{implementation → tools/implementation}/inspect.d.ts +0 -0
  718. /package/dist/{implementation → tools/implementation}/invites.d.ts +0 -0
  719. /package/dist/{implementation → tools/implementation}/refs.d.ts +0 -0
  720. /package/dist/{implementation → tools/implementation}/schema.d.ts +0 -0
  721. /package/dist/{implementation → tools/implementation}/symbols.d.ts +0 -0
  722. /package/dist/{implementation → tools/implementation}/zodSchema/coExport.d.ts +0 -0
  723. /package/dist/{implementation → tools/implementation}/zodSchema/runtimeConverters/zodFieldToCoFieldDef.d.ts +0 -0
  724. /package/dist/{implementation → tools/implementation}/zodSchema/runtimeConverters/zodSchemaToCoSchema.d.ts +0 -0
  725. /package/dist/{implementation → tools/implementation}/zodSchema/schemaTypes/AccountSchema.d.ts +0 -0
  726. /package/dist/{implementation → tools/implementation}/zodSchema/schemaTypes/CoFeedSchema.d.ts +0 -0
  727. /package/dist/{implementation → tools/implementation}/zodSchema/schemaTypes/CoListSchema.d.ts +0 -0
  728. /package/dist/{implementation → tools/implementation}/zodSchema/schemaTypes/CoMapSchema.d.ts +0 -0
  729. /package/dist/{implementation → tools/implementation}/zodSchema/schemaTypes/CoRecordSchema.d.ts +0 -0
  730. /package/dist/{implementation → tools/implementation}/zodSchema/schemaTypes/FileStreamSchema.d.ts +0 -0
  731. /package/dist/{implementation → tools/implementation}/zodSchema/schemaTypes/PlainTextSchema.d.ts +0 -0
  732. /package/dist/{implementation → tools/implementation}/zodSchema/schemaTypes/RichTextSchema.d.ts +0 -0
  733. /package/dist/{implementation → tools/implementation}/zodSchema/typeConverters/InstanceOfSchema.d.ts +0 -0
  734. /package/dist/{implementation → tools/implementation}/zodSchema/typeConverters/InstanceOfSchemaCoValuesNullable.d.ts +0 -0
  735. /package/dist/{implementation → tools/implementation}/zodSchema/typeConverters/InstanceOrPrimitiveOfSchema.d.ts +0 -0
  736. /package/dist/{implementation → tools/implementation}/zodSchema/typeConverters/InstanceOrPrimitiveOfSchemaCoValuesNullable.d.ts +0 -0
  737. /package/dist/{implementation → tools/implementation}/zodSchema/unionUtils.d.ts +0 -0
  738. /package/dist/{implementation → tools/implementation}/zodSchema/zodCo.d.ts +0 -0
  739. /package/dist/{implementation → tools/implementation}/zodSchema/zodReExport.d.ts +0 -0
  740. /package/dist/{implementation → tools/implementation}/zodSchema/zodSchema.d.ts +0 -0
  741. /package/dist/{internal.d.ts → tools/internal.d.ts} +0 -0
  742. /package/dist/{lib → tools/lib}/cache.d.ts +0 -0
  743. /package/dist/{lib → tools/lib}/cache.test.d.ts +0 -0
  744. /package/dist/{lib → tools/lib}/migration.d.ts +0 -0
  745. /package/dist/{subscribe → tools/subscribe}/CoValueCoreSubscription.d.ts +0 -0
  746. /package/dist/{subscribe → tools/subscribe}/JazzError.d.ts +0 -0
  747. /package/dist/{subscribe → tools/subscribe}/SubscriptionScope.d.ts +0 -0
  748. /package/dist/{subscribe → tools/subscribe}/index.d.ts +0 -0
  749. /package/dist/{subscribe → tools/subscribe}/types.d.ts +0 -0
  750. /package/dist/{subscribe → tools/subscribe}/utils.d.ts +0 -0
  751. /package/dist/{tests → tools/tests}/AuthSecretStorage.test.d.ts +0 -0
  752. /package/dist/{tests → tools/tests}/ContextManager.test.d.ts +0 -0
  753. /package/dist/{tests → tools/tests}/DemoAuth.test.d.ts +0 -0
  754. /package/dist/{tests → tools/tests}/PassphraseAuth.test.d.ts +0 -0
  755. /package/dist/{tests → tools/tests}/account.test.d.ts +0 -0
  756. /package/dist/{tests → tools/tests}/coFeed.test-d.d.ts +0 -0
  757. /package/dist/{tests → tools/tests}/coFeed.test.d.ts +0 -0
  758. /package/dist/{tests → tools/tests}/coList.test-d.d.ts +0 -0
  759. /package/dist/{tests → tools/tests}/coList.test.d.ts +0 -0
  760. /package/dist/{tests → tools/tests}/coMap.record.test-d.d.ts +0 -0
  761. /package/dist/{tests → tools/tests}/coMap.record.test.d.ts +0 -0
  762. /package/dist/{tests → tools/tests}/coMap.test-d.d.ts +0 -0
  763. /package/dist/{tests → tools/tests}/coMap.test.d.ts +0 -0
  764. /package/dist/{tests → tools/tests}/coPlainText.test.d.ts +0 -0
  765. /package/dist/{tests → tools/tests}/createContext.test.d.ts +0 -0
  766. /package/dist/{tests → tools/tests}/deepLoading.test.d.ts +0 -0
  767. /package/dist/{tests → tools/tests}/groupsAndAccounts.test.d.ts +0 -0
  768. /package/dist/{tests → tools/tests}/imageDef.test.d.ts +0 -0
  769. /package/dist/{tests → tools/tests}/inbox.test.d.ts +0 -0
  770. /package/dist/{tests → tools/tests}/interfaces.test.d.ts +0 -0
  771. /package/dist/{tests → tools/tests}/invites.test.d.ts +0 -0
  772. /package/dist/{tests → tools/tests}/load.test.d.ts +0 -0
  773. /package/dist/{tests → tools/tests}/patterns/notifications.test.d.ts +0 -0
  774. /package/dist/{tests → tools/tests}/patterns/requestToJoin.test.d.ts +0 -0
  775. /package/dist/{tests → tools/tests}/schema.test.d.ts +0 -0
  776. /package/dist/{tests → tools/tests}/schemaUnion.test.d.ts +0 -0
  777. /package/dist/{tests → tools/tests}/subscribe.test.d.ts +0 -0
  778. /package/dist/{tests → tools/tests}/testing.test.d.ts +0 -0
  779. /package/dist/{tests → tools/tests}/utils.d.ts +0 -0
  780. /package/dist/{tests → tools/tests}/zod.test.d.ts +0 -0
  781. /package/dist/{types.d.ts → tools/types.d.ts} +0 -0
  782. /package/src/{tests → react-core/tests}/fixtures.ts +0 -0
  783. /package/src/{auth/KvStoreContext.ts → react-native-core/storage/kv-store-context.ts} +0 -0
  784. /package/src/{auth → tools/auth}/AuthSecretStorage.ts +0 -0
  785. /package/src/{auth → tools/auth}/DemoAuth.ts +0 -0
  786. /package/src/{auth → tools/auth}/InMemoryKVStore.ts +0 -0
  787. /package/src/{auth → tools/auth}/PassphraseAuth.ts +0 -0
  788. /package/src/{coValues → tools/coValues}/CoValueBase.ts +0 -0
  789. /package/src/{coValues → tools/coValues}/account.ts +0 -0
  790. /package/src/{coValues → tools/coValues}/coList.ts +0 -0
  791. /package/src/{coValues → tools/coValues}/coMap.ts +0 -0
  792. /package/src/{coValues → tools/coValues}/coPlainText.ts +0 -0
  793. /package/src/{coValues → tools/coValues}/coRichText.ts +0 -0
  794. /package/src/{coValues → tools/coValues}/deepLoading.ts +0 -0
  795. /package/src/{coValues → tools/coValues}/extensions/imageDef.ts +0 -0
  796. /package/src/{coValues → tools/coValues}/group.ts +0 -0
  797. /package/src/{coValues → tools/coValues}/inbox.ts +0 -0
  798. /package/src/{coValues → tools/coValues}/interfaces.ts +0 -0
  799. /package/src/{coValues → tools/coValues}/profile.ts +0 -0
  800. /package/src/{coValues → tools/coValues}/registeredSchemas.ts +0 -0
  801. /package/src/{coValues → tools/coValues}/schemaUnion.ts +0 -0
  802. /package/src/{implementation → tools/implementation}/ContextManager.ts +0 -0
  803. /package/src/{implementation → tools/implementation}/activeAccountContext.ts +0 -0
  804. /package/src/{implementation → tools/implementation}/anonymousJazzAgent.ts +0 -0
  805. /package/src/{implementation → tools/implementation}/createContext.ts +0 -0
  806. /package/src/{implementation → tools/implementation}/devtoolsFormatters.ts +0 -0
  807. /package/src/{implementation → tools/implementation}/errors.ts +0 -0
  808. /package/src/{implementation → tools/implementation}/inspect.ts +0 -0
  809. /package/src/{implementation → tools/implementation}/invites.ts +0 -0
  810. /package/src/{implementation → tools/implementation}/refs.ts +0 -0
  811. /package/src/{implementation → tools/implementation}/schema.ts +0 -0
  812. /package/src/{implementation → tools/implementation}/symbols.ts +0 -0
  813. /package/src/{implementation → tools/implementation}/zodSchema/coExport.ts +0 -0
  814. /package/src/{implementation → tools/implementation}/zodSchema/runtimeConverters/zodFieldToCoFieldDef.ts +0 -0
  815. /package/src/{implementation → tools/implementation}/zodSchema/runtimeConverters/zodSchemaToCoSchema.ts +0 -0
  816. /package/src/{implementation → tools/implementation}/zodSchema/schemaTypes/AccountSchema.ts +0 -0
  817. /package/src/{implementation → tools/implementation}/zodSchema/schemaTypes/CoFeedSchema.ts +0 -0
  818. /package/src/{implementation → tools/implementation}/zodSchema/schemaTypes/CoListSchema.ts +0 -0
  819. /package/src/{implementation → tools/implementation}/zodSchema/schemaTypes/CoMapSchema.ts +0 -0
  820. /package/src/{implementation → tools/implementation}/zodSchema/schemaTypes/CoRecordSchema.ts +0 -0
  821. /package/src/{implementation → tools/implementation}/zodSchema/schemaTypes/FileStreamSchema.ts +0 -0
  822. /package/src/{implementation → tools/implementation}/zodSchema/schemaTypes/PlainTextSchema.ts +0 -0
  823. /package/src/{implementation → tools/implementation}/zodSchema/schemaTypes/RichTextSchema.ts +0 -0
  824. /package/src/{implementation → tools/implementation}/zodSchema/typeConverters/InstanceOfSchema.ts +0 -0
  825. /package/src/{implementation → tools/implementation}/zodSchema/typeConverters/InstanceOfSchemaCoValuesNullable.ts +0 -0
  826. /package/src/{implementation → tools/implementation}/zodSchema/typeConverters/InstanceOrPrimitiveOfSchema.ts +0 -0
  827. /package/src/{implementation → tools/implementation}/zodSchema/typeConverters/InstanceOrPrimitiveOfSchemaCoValuesNullable.ts +0 -0
  828. /package/src/{implementation → tools/implementation}/zodSchema/unionUtils.ts +0 -0
  829. /package/src/{implementation → tools/implementation}/zodSchema/zodCo.ts +0 -0
  830. /package/src/{implementation → tools/implementation}/zodSchema/zodReExport.ts +0 -0
  831. /package/src/{implementation → tools/implementation}/zodSchema/zodSchema.ts +0 -0
  832. /package/src/{internal.ts → tools/internal.ts} +0 -0
  833. /package/src/{lib → tools/lib}/cache.test.ts +0 -0
  834. /package/src/{lib → tools/lib}/cache.ts +0 -0
  835. /package/src/{lib → tools/lib}/migration.ts +0 -0
  836. /package/src/{subscribe → tools/subscribe}/CoValueCoreSubscription.ts +0 -0
  837. /package/src/{subscribe → tools/subscribe}/JazzError.ts +0 -0
  838. /package/src/{subscribe → tools/subscribe}/SubscriptionScope.ts +0 -0
  839. /package/src/{subscribe → tools/subscribe}/index.ts +0 -0
  840. /package/src/{subscribe → tools/subscribe}/types.ts +0 -0
  841. /package/src/{subscribe → tools/subscribe}/utils.ts +0 -0
  842. /package/src/{tests → tools/tests}/AuthSecretStorage.test.ts +0 -0
  843. /package/src/{tests → tools/tests}/ContextManager.test.ts +0 -0
  844. /package/src/{tests → tools/tests}/DemoAuth.test.ts +0 -0
  845. /package/src/{tests → tools/tests}/PassphraseAuth.test.ts +0 -0
  846. /package/src/{tests → tools/tests}/account.test.ts +0 -0
  847. /package/src/{tests → tools/tests}/coFeed.test-d.ts +0 -0
  848. /package/src/{tests → tools/tests}/coList.test-d.ts +0 -0
  849. /package/src/{tests → tools/tests}/coList.test.ts +0 -0
  850. /package/src/{tests → tools/tests}/coMap.record.test-d.ts +0 -0
  851. /package/src/{tests → tools/tests}/coMap.record.test.ts +0 -0
  852. /package/src/{tests → tools/tests}/coMap.test-d.ts +0 -0
  853. /package/src/{tests → tools/tests}/coMap.test.ts +0 -0
  854. /package/src/{tests → tools/tests}/coPlainText.test.ts +0 -0
  855. /package/src/{tests → tools/tests}/createContext.test.ts +0 -0
  856. /package/src/{tests → tools/tests}/deepLoading.test.ts +0 -0
  857. /package/src/{tests → tools/tests}/groupsAndAccounts.test.ts +0 -0
  858. /package/src/{tests → tools/tests}/imageDef.test.ts +0 -0
  859. /package/src/{tests → tools/tests}/inbox.test.ts +0 -0
  860. /package/src/{tests → tools/tests}/interfaces.test.ts +0 -0
  861. /package/src/{tests → tools/tests}/invites.test.ts +0 -0
  862. /package/src/{tests → tools/tests}/load.test.ts +0 -0
  863. /package/src/{tests → tools/tests}/patterns/notifications.test.ts +0 -0
  864. /package/src/{tests → tools/tests}/patterns/requestToJoin.test.ts +0 -0
  865. /package/src/{tests → tools/tests}/schema.test.ts +0 -0
  866. /package/src/{tests → tools/tests}/schemaUnion.test.ts +0 -0
  867. /package/src/{tests → tools/tests}/subscribe.test.ts +0 -0
  868. /package/src/{tests → tools/tests}/testing.test.ts +0 -0
  869. /package/src/{tests → tools/tests}/utils.ts +0 -0
  870. /package/src/{tests → tools/tests}/zod.test.ts +0 -0
  871. /package/src/{types.ts → tools/types.ts} +0 -0
@@ -0,0 +1,771 @@
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
+ });