@dxos/plugin-client 0.8.4-main.72ec0f3 → 0.8.4-main.74a063c4e0

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 (485) hide show
  1. package/dist/lib/browser/chunk-ELAYKIQU.mjs +12 -0
  2. package/dist/lib/browser/chunk-ELAYKIQU.mjs.map +7 -0
  3. package/dist/lib/browser/chunk-J5LGTIGS.mjs +10 -0
  4. package/dist/lib/browser/chunk-J5LGTIGS.mjs.map +7 -0
  5. package/dist/lib/browser/chunk-M43LJQ5U.mjs +175 -0
  6. package/dist/lib/browser/chunk-M43LJQ5U.mjs.map +7 -0
  7. package/dist/lib/browser/{chunk-RDIG75CA.mjs → chunk-WNJRYPGG.mjs} +36 -15
  8. package/dist/lib/browser/chunk-WNJRYPGG.mjs.map +7 -0
  9. package/dist/lib/browser/cli/index.mjs +1060 -0
  10. package/dist/lib/browser/cli/index.mjs.map +7 -0
  11. package/dist/lib/browser/create-agent-SS5SE35J.mjs +34 -0
  12. package/dist/lib/browser/create-agent-SS5SE35J.mjs.map +7 -0
  13. package/dist/lib/browser/create-identity-PBEUEIPN.mjs +30 -0
  14. package/dist/lib/browser/create-identity-PBEUEIPN.mjs.map +7 -0
  15. package/dist/lib/browser/create-passkey-JN6I5WMM.mjs +105 -0
  16. package/dist/lib/browser/create-passkey-JN6I5WMM.mjs.map +7 -0
  17. package/dist/lib/browser/create-recovery-code-32I6IWZC.mjs +44 -0
  18. package/dist/lib/browser/create-recovery-code-32I6IWZC.mjs.map +7 -0
  19. package/dist/lib/browser/index.mjs +120 -133
  20. package/dist/lib/browser/index.mjs.map +4 -4
  21. package/dist/lib/browser/join-identity-2BP4G2SD.mjs +27 -0
  22. package/dist/lib/browser/join-identity-2BP4G2SD.mjs.map +7 -0
  23. package/dist/lib/browser/meta.json +1 -1
  24. package/dist/lib/browser/operations/index.mjs +13 -0
  25. package/dist/lib/browser/operations/index.mjs.map +7 -0
  26. package/dist/lib/browser/recover-identity-LS6B5INB.mjs +26 -0
  27. package/dist/lib/browser/recover-identity-LS6B5INB.mjs.map +7 -0
  28. package/dist/lib/browser/redeem-passkey-OCIV6VCK.mjs +82 -0
  29. package/dist/lib/browser/redeem-passkey-OCIV6VCK.mjs.map +7 -0
  30. package/dist/lib/browser/redeem-token-6BCRGKV6.mjs +37 -0
  31. package/dist/lib/browser/redeem-token-6BCRGKV6.mjs.map +7 -0
  32. package/dist/lib/browser/reset-storage-RQHXLTZ7.mjs +26 -0
  33. package/dist/lib/browser/reset-storage-RQHXLTZ7.mjs.map +7 -0
  34. package/dist/lib/browser/share-identity-YJEBJTPA.mjs +31 -0
  35. package/dist/lib/browser/share-identity-YJEBJTPA.mjs.map +7 -0
  36. package/dist/lib/browser/testing/index.mjs +22 -0
  37. package/dist/lib/browser/testing/index.mjs.map +7 -0
  38. package/dist/lib/browser/types/index.mjs +8 -4
  39. package/dist/lib/node-esm/chunk-HSLMI22Q.mjs +11 -0
  40. package/dist/lib/node-esm/chunk-HSLMI22Q.mjs.map +7 -0
  41. package/dist/lib/node-esm/{chunk-VENKFPBC.mjs → chunk-IT5LAIV3.mjs} +37 -15
  42. package/dist/lib/node-esm/chunk-IT5LAIV3.mjs.map +7 -0
  43. package/dist/lib/node-esm/chunk-J5RWSQT6.mjs +14 -0
  44. package/dist/lib/node-esm/chunk-J5RWSQT6.mjs.map +7 -0
  45. package/dist/lib/node-esm/chunk-SJ6FDER5.mjs +176 -0
  46. package/dist/lib/node-esm/chunk-SJ6FDER5.mjs.map +7 -0
  47. package/dist/lib/node-esm/cli/index.mjs +1061 -0
  48. package/dist/lib/node-esm/cli/index.mjs.map +7 -0
  49. package/dist/lib/node-esm/create-agent-QGEHMHBL.mjs +35 -0
  50. package/dist/lib/node-esm/create-agent-QGEHMHBL.mjs.map +7 -0
  51. package/dist/lib/node-esm/create-identity-EHRJQOO4.mjs +31 -0
  52. package/dist/lib/node-esm/create-identity-EHRJQOO4.mjs.map +7 -0
  53. package/dist/lib/node-esm/create-passkey-PFBHHBEQ.mjs +106 -0
  54. package/dist/lib/node-esm/create-passkey-PFBHHBEQ.mjs.map +7 -0
  55. package/dist/lib/node-esm/create-recovery-code-HBAM2A72.mjs +45 -0
  56. package/dist/lib/node-esm/create-recovery-code-HBAM2A72.mjs.map +7 -0
  57. package/dist/lib/node-esm/index.mjs +120 -133
  58. package/dist/lib/node-esm/index.mjs.map +4 -4
  59. package/dist/lib/node-esm/join-identity-75JCKQHM.mjs +28 -0
  60. package/dist/lib/node-esm/join-identity-75JCKQHM.mjs.map +7 -0
  61. package/dist/lib/node-esm/meta.json +1 -1
  62. package/dist/lib/node-esm/operations/index.mjs +14 -0
  63. package/dist/lib/node-esm/operations/index.mjs.map +7 -0
  64. package/dist/lib/node-esm/recover-identity-AKGNTUJI.mjs +27 -0
  65. package/dist/lib/node-esm/recover-identity-AKGNTUJI.mjs.map +7 -0
  66. package/dist/lib/node-esm/redeem-passkey-FZO3LZ57.mjs +83 -0
  67. package/dist/lib/node-esm/redeem-passkey-FZO3LZ57.mjs.map +7 -0
  68. package/dist/lib/node-esm/redeem-token-IHHIAIQ2.mjs +38 -0
  69. package/dist/lib/node-esm/redeem-token-IHHIAIQ2.mjs.map +7 -0
  70. package/dist/lib/node-esm/reset-storage-OWV5UDMC.mjs +27 -0
  71. package/dist/lib/node-esm/reset-storage-OWV5UDMC.mjs.map +7 -0
  72. package/dist/lib/node-esm/share-identity-QZLY3VHE.mjs +32 -0
  73. package/dist/lib/node-esm/share-identity-QZLY3VHE.mjs.map +7 -0
  74. package/dist/lib/node-esm/testing/index.mjs +23 -0
  75. package/dist/lib/node-esm/testing/index.mjs.map +7 -0
  76. package/dist/lib/node-esm/types/index.mjs +8 -4
  77. package/dist/types/src/ClientPlugin.d.ts +3 -2
  78. package/dist/types/src/ClientPlugin.d.ts.map +1 -1
  79. package/dist/types/src/capabilities/app-graph-builder.d.ts +4 -2
  80. package/dist/types/src/capabilities/app-graph-builder.d.ts.map +1 -1
  81. package/dist/types/src/capabilities/client.d.ts +6 -7
  82. package/dist/types/src/capabilities/client.d.ts.map +1 -1
  83. package/dist/types/src/capabilities/index.d.ts +28 -15
  84. package/dist/types/src/capabilities/index.d.ts.map +1 -1
  85. package/dist/types/src/capabilities/migrations.d.ts +3 -2
  86. package/dist/types/src/capabilities/migrations.d.ts.map +1 -1
  87. package/dist/types/src/capabilities/navigation-handler/index.d.ts +4 -0
  88. package/dist/types/src/capabilities/navigation-handler/index.d.ts.map +1 -0
  89. package/dist/types/src/capabilities/navigation-handler/navigation-handler.d.ts +15 -0
  90. package/dist/types/src/capabilities/navigation-handler/navigation-handler.d.ts.map +1 -0
  91. package/dist/types/src/capabilities/node.d.ts +21 -0
  92. package/dist/types/src/capabilities/node.d.ts.map +1 -0
  93. package/dist/types/src/capabilities/operation-handler.d.ts +6 -0
  94. package/dist/types/src/capabilities/operation-handler.d.ts.map +1 -0
  95. package/dist/types/src/capabilities/react-context.d.ts +4 -2
  96. package/dist/types/src/capabilities/react-context.d.ts.map +1 -1
  97. package/dist/types/src/capabilities/react-surface.d.ts +4 -3
  98. package/dist/types/src/capabilities/react-surface.d.ts.map +1 -1
  99. package/dist/types/src/capabilities/schema-defs.d.ts +3 -2
  100. package/dist/types/src/capabilities/schema-defs.d.ts.map +1 -1
  101. package/dist/types/src/cli/commands/config/index.d.ts +5 -0
  102. package/dist/types/src/cli/commands/config/index.d.ts.map +1 -0
  103. package/dist/types/src/cli/commands/config/view.d.ts +5 -0
  104. package/dist/types/src/cli/commands/config/view.d.ts.map +1 -0
  105. package/dist/types/src/cli/commands/device/index.d.ts +7 -0
  106. package/dist/types/src/cli/commands/device/index.d.ts.map +1 -0
  107. package/dist/types/src/cli/commands/device/info/index.d.ts +2 -0
  108. package/dist/types/src/cli/commands/device/info/index.d.ts.map +1 -0
  109. package/dist/types/src/cli/commands/device/info/info.d.ts +7 -0
  110. package/dist/types/src/cli/commands/device/info/info.d.ts.map +1 -0
  111. package/dist/types/src/cli/commands/device/info/info.test.d.ts +2 -0
  112. package/dist/types/src/cli/commands/device/info/info.test.d.ts.map +1 -0
  113. package/dist/types/src/cli/commands/device/list/index.d.ts +2 -0
  114. package/dist/types/src/cli/commands/device/list/index.d.ts.map +1 -0
  115. package/dist/types/src/cli/commands/device/list/list.d.ts +7 -0
  116. package/dist/types/src/cli/commands/device/list/list.d.ts.map +1 -0
  117. package/dist/types/src/cli/commands/device/list/list.test.d.ts +2 -0
  118. package/dist/types/src/cli/commands/device/list/list.test.d.ts.map +1 -0
  119. package/dist/types/src/cli/commands/device/update/index.d.ts +2 -0
  120. package/dist/types/src/cli/commands/device/update/index.d.ts.map +1 -0
  121. package/dist/types/src/cli/commands/device/update/update.d.ts +11 -0
  122. package/dist/types/src/cli/commands/device/update/update.d.ts.map +1 -0
  123. package/dist/types/src/cli/commands/device/util.d.ts +16 -0
  124. package/dist/types/src/cli/commands/device/util.d.ts.map +1 -0
  125. package/dist/types/src/cli/commands/edge/index.d.ts +5 -0
  126. package/dist/types/src/cli/commands/edge/index.d.ts.map +1 -0
  127. package/dist/types/src/cli/commands/edge/status.d.ts +7 -0
  128. package/dist/types/src/cli/commands/edge/status.d.ts.map +1 -0
  129. package/dist/types/src/cli/commands/halo/create/create.d.ts +15 -0
  130. package/dist/types/src/cli/commands/halo/create/create.d.ts.map +1 -0
  131. package/dist/types/src/cli/commands/halo/create/create.test.d.ts +2 -0
  132. package/dist/types/src/cli/commands/halo/create/create.test.d.ts.map +1 -0
  133. package/dist/types/src/cli/commands/halo/create/index.d.ts +2 -0
  134. package/dist/types/src/cli/commands/halo/create/index.d.ts.map +1 -0
  135. package/dist/types/src/cli/commands/halo/credential/add/add.d.ts +13 -0
  136. package/dist/types/src/cli/commands/halo/credential/add/add.d.ts.map +1 -0
  137. package/dist/types/src/cli/commands/halo/credential/add/index.d.ts +2 -0
  138. package/dist/types/src/cli/commands/halo/credential/add/index.d.ts.map +1 -0
  139. package/dist/types/src/cli/commands/halo/credential/index.d.ts +12 -0
  140. package/dist/types/src/cli/commands/halo/credential/index.d.ts.map +1 -0
  141. package/dist/types/src/cli/commands/halo/credential/list/index.d.ts +2 -0
  142. package/dist/types/src/cli/commands/halo/credential/list/index.d.ts.map +1 -0
  143. package/dist/types/src/cli/commands/halo/credential/list/list.d.ts +19 -0
  144. package/dist/types/src/cli/commands/halo/credential/list/list.d.ts.map +1 -0
  145. package/dist/types/src/cli/commands/halo/credential/list/list.test.d.ts +2 -0
  146. package/dist/types/src/cli/commands/halo/credential/list/list.test.d.ts.map +1 -0
  147. package/dist/types/src/cli/commands/halo/identity/identity.d.ts +7 -0
  148. package/dist/types/src/cli/commands/halo/identity/identity.d.ts.map +1 -0
  149. package/dist/types/src/cli/commands/halo/identity/identity.test.d.ts +2 -0
  150. package/dist/types/src/cli/commands/halo/identity/identity.test.d.ts.map +1 -0
  151. package/dist/types/src/cli/commands/halo/identity/index.d.ts +2 -0
  152. package/dist/types/src/cli/commands/halo/identity/index.d.ts.map +1 -0
  153. package/dist/types/src/cli/commands/halo/index.d.ts +3 -0
  154. package/dist/types/src/cli/commands/halo/index.d.ts.map +1 -0
  155. package/dist/types/src/cli/commands/halo/join/index.d.ts +2 -0
  156. package/dist/types/src/cli/commands/halo/join/index.d.ts.map +1 -0
  157. package/dist/types/src/cli/commands/halo/join/join.d.ts +8 -0
  158. package/dist/types/src/cli/commands/halo/join/join.d.ts.map +1 -0
  159. package/dist/types/src/cli/commands/halo/join/join.test.d.ts +2 -0
  160. package/dist/types/src/cli/commands/halo/join/join.test.d.ts.map +1 -0
  161. package/dist/types/src/cli/commands/halo/keys/index.d.ts +2 -0
  162. package/dist/types/src/cli/commands/halo/keys/index.d.ts.map +1 -0
  163. package/dist/types/src/cli/commands/halo/keys/keys.d.ts +7 -0
  164. package/dist/types/src/cli/commands/halo/keys/keys.d.ts.map +1 -0
  165. package/dist/types/src/cli/commands/halo/keys/keys.test.d.ts +2 -0
  166. package/dist/types/src/cli/commands/halo/keys/keys.test.d.ts.map +1 -0
  167. package/dist/types/src/cli/commands/halo/recover/index.d.ts +2 -0
  168. package/dist/types/src/cli/commands/halo/recover/index.d.ts.map +1 -0
  169. package/dist/types/src/cli/commands/halo/recover/recover.d.ts +7 -0
  170. package/dist/types/src/cli/commands/halo/recover/recover.d.ts.map +1 -0
  171. package/dist/types/src/cli/commands/halo/recover/recover.test.d.ts +2 -0
  172. package/dist/types/src/cli/commands/halo/recover/recover.test.d.ts.map +1 -0
  173. package/dist/types/src/cli/commands/halo/seed/index.d.ts +2 -0
  174. package/dist/types/src/cli/commands/halo/seed/index.d.ts.map +1 -0
  175. package/dist/types/src/cli/commands/halo/seed/seed.d.ts +7 -0
  176. package/dist/types/src/cli/commands/halo/seed/seed.d.ts.map +1 -0
  177. package/dist/types/src/cli/commands/halo/share/index.d.ts +2 -0
  178. package/dist/types/src/cli/commands/halo/share/index.d.ts.map +1 -0
  179. package/dist/types/src/cli/commands/halo/share/share.d.ts +15 -0
  180. package/dist/types/src/cli/commands/halo/share/share.d.ts.map +1 -0
  181. package/dist/types/src/cli/commands/halo/update/index.d.ts +2 -0
  182. package/dist/types/src/cli/commands/halo/update/index.d.ts.map +1 -0
  183. package/dist/types/src/cli/commands/halo/update/update.d.ts +11 -0
  184. package/dist/types/src/cli/commands/halo/update/update.d.ts.map +1 -0
  185. package/dist/types/src/cli/commands/halo/update/update.test.d.ts +2 -0
  186. package/dist/types/src/cli/commands/halo/update/update.test.d.ts.map +1 -0
  187. package/dist/types/src/cli/commands/halo/util.d.ts +13 -0
  188. package/dist/types/src/cli/commands/halo/util.d.ts.map +1 -0
  189. package/dist/types/src/cli/commands/index.d.ts +6 -0
  190. package/dist/types/src/cli/commands/index.d.ts.map +1 -0
  191. package/dist/types/src/cli/commands/profile/create.d.ts +10 -0
  192. package/dist/types/src/cli/commands/profile/create.d.ts.map +1 -0
  193. package/dist/types/src/cli/commands/profile/delete.d.ts +8 -0
  194. package/dist/types/src/cli/commands/profile/delete.d.ts.map +1 -0
  195. package/dist/types/src/cli/commands/profile/import.d.ts +17 -0
  196. package/dist/types/src/cli/commands/profile/import.d.ts.map +1 -0
  197. package/dist/types/src/cli/commands/profile/index.d.ts +19 -0
  198. package/dist/types/src/cli/commands/profile/index.d.ts.map +1 -0
  199. package/dist/types/src/cli/commands/profile/inspect.d.ts +13 -0
  200. package/dist/types/src/cli/commands/profile/inspect.d.ts.map +1 -0
  201. package/dist/types/src/cli/commands/profile/list.d.ts +6 -0
  202. package/dist/types/src/cli/commands/profile/list.d.ts.map +1 -0
  203. package/dist/types/src/cli/commands/profile/reset.d.ts +8 -0
  204. package/dist/types/src/cli/commands/profile/reset.d.ts.map +1 -0
  205. package/dist/types/src/cli/commands/profile/util.d.ts +24 -0
  206. package/dist/types/src/cli/commands/profile/util.d.ts.map +1 -0
  207. package/dist/types/src/cli/index.d.ts +2 -0
  208. package/dist/types/src/cli/index.d.ts.map +1 -0
  209. package/dist/types/src/cli/plugin.d.ts +4 -0
  210. package/dist/types/src/cli/plugin.d.ts.map +1 -0
  211. package/dist/types/src/cli/testing/test-console.d.ts +37 -0
  212. package/dist/types/src/cli/testing/test-console.d.ts.map +1 -0
  213. package/dist/types/src/components/index.d.ts +0 -6
  214. package/dist/types/src/components/index.d.ts.map +1 -1
  215. package/dist/types/src/constants.d.ts +4 -0
  216. package/dist/types/src/constants.d.ts.map +1 -0
  217. package/dist/types/src/containers/DevicesContainer/DevicesContainer.d.ts.map +1 -0
  218. package/dist/types/src/containers/DevicesContainer/DevicesContainer.stories.d.ts +184 -0
  219. package/dist/types/src/containers/DevicesContainer/DevicesContainer.stories.d.ts.map +1 -0
  220. package/dist/types/src/containers/DevicesContainer/index.d.ts +2 -0
  221. package/dist/types/src/containers/DevicesContainer/index.d.ts.map +1 -0
  222. package/dist/types/src/{components → containers/JoinDialog}/JoinDialog.d.ts +0 -1
  223. package/dist/types/src/containers/JoinDialog/JoinDialog.d.ts.map +1 -0
  224. package/dist/types/src/containers/JoinDialog/JoinDialog.stories.d.ts +15 -0
  225. package/dist/types/src/containers/JoinDialog/JoinDialog.stories.d.ts.map +1 -0
  226. package/dist/types/src/containers/JoinDialog/index.d.ts +2 -0
  227. package/dist/types/src/containers/JoinDialog/index.d.ts.map +1 -0
  228. package/dist/types/src/containers/ProfileContainer/ProfileContainer.d.ts.map +1 -0
  229. package/dist/types/src/containers/ProfileContainer/ProfileContainer.stories.d.ts +14 -0
  230. package/dist/types/src/containers/ProfileContainer/ProfileContainer.stories.d.ts.map +1 -0
  231. package/dist/types/src/containers/ProfileContainer/index.d.ts +2 -0
  232. package/dist/types/src/containers/ProfileContainer/index.d.ts.map +1 -0
  233. package/dist/types/src/{components → containers/RecoveryCodeDialog}/RecoveryCodeDialog.d.ts +0 -1
  234. package/dist/types/src/containers/RecoveryCodeDialog/RecoveryCodeDialog.d.ts.map +1 -0
  235. package/dist/types/src/containers/RecoveryCodeDialog/RecoveryCodeDialog.stories.d.ts +16 -0
  236. package/dist/types/src/containers/RecoveryCodeDialog/RecoveryCodeDialog.stories.d.ts.map +1 -0
  237. package/dist/types/src/containers/RecoveryCodeDialog/index.d.ts +4 -0
  238. package/dist/types/src/containers/RecoveryCodeDialog/index.d.ts.map +1 -0
  239. package/dist/types/src/containers/RecoveryCredentialsContainer/RecoveryCredentialsContainer.d.ts.map +1 -0
  240. package/dist/types/src/containers/RecoveryCredentialsContainer/RecoveryCredentialsContainer.stories.d.ts +14 -0
  241. package/dist/types/src/containers/RecoveryCredentialsContainer/RecoveryCredentialsContainer.stories.d.ts.map +1 -0
  242. package/dist/types/src/containers/RecoveryCredentialsContainer/index.d.ts +2 -0
  243. package/dist/types/src/containers/RecoveryCredentialsContainer/index.d.ts.map +1 -0
  244. package/dist/types/src/containers/ResetDialog/ResetDialog.d.ts +9 -0
  245. package/dist/types/src/containers/ResetDialog/ResetDialog.d.ts.map +1 -0
  246. package/dist/types/src/containers/ResetDialog/ResetDialog.stories.d.ts +19 -0
  247. package/dist/types/src/containers/ResetDialog/ResetDialog.stories.d.ts.map +1 -0
  248. package/dist/types/src/containers/ResetDialog/index.d.ts +4 -0
  249. package/dist/types/src/containers/ResetDialog/index.d.ts.map +1 -0
  250. package/dist/types/src/containers/index.d.ts +10 -0
  251. package/dist/types/src/containers/index.d.ts.map +1 -0
  252. package/dist/types/src/index.d.ts +2 -5
  253. package/dist/types/src/index.d.ts.map +1 -1
  254. package/dist/types/src/meta.d.ts +2 -2
  255. package/dist/types/src/meta.d.ts.map +1 -1
  256. package/dist/types/src/operations/create-agent.d.ts +5 -0
  257. package/dist/types/src/operations/create-agent.d.ts.map +1 -0
  258. package/dist/types/src/operations/create-identity.d.ts +5 -0
  259. package/dist/types/src/operations/create-identity.d.ts.map +1 -0
  260. package/dist/types/src/operations/create-passkey.d.ts +5 -0
  261. package/dist/types/src/operations/create-passkey.d.ts.map +1 -0
  262. package/dist/types/src/operations/create-recovery-code.d.ts +5 -0
  263. package/dist/types/src/operations/create-recovery-code.d.ts.map +1 -0
  264. package/dist/types/src/operations/definitions.d.ts +36 -0
  265. package/dist/types/src/operations/definitions.d.ts.map +1 -0
  266. package/dist/types/src/operations/index.d.ts +4 -0
  267. package/dist/types/src/operations/index.d.ts.map +1 -0
  268. package/dist/types/src/operations/join-identity.d.ts +5 -0
  269. package/dist/types/src/operations/join-identity.d.ts.map +1 -0
  270. package/dist/types/src/operations/recover-identity.d.ts +5 -0
  271. package/dist/types/src/operations/recover-identity.d.ts.map +1 -0
  272. package/dist/types/src/operations/redeem-passkey.d.ts +5 -0
  273. package/dist/types/src/operations/redeem-passkey.d.ts.map +1 -0
  274. package/dist/types/src/operations/redeem-token.d.ts +5 -0
  275. package/dist/types/src/operations/redeem-token.d.ts.map +1 -0
  276. package/dist/types/src/operations/reset-storage.d.ts +5 -0
  277. package/dist/types/src/operations/reset-storage.d.ts.map +1 -0
  278. package/dist/types/src/operations/share-identity.d.ts +5 -0
  279. package/dist/types/src/operations/share-identity.d.ts.map +1 -0
  280. package/dist/types/src/testing/index.d.ts +2 -0
  281. package/dist/types/src/testing/index.d.ts.map +1 -0
  282. package/dist/types/src/testing/initializeIdentity.d.ts +13 -0
  283. package/dist/types/src/testing/initializeIdentity.d.ts.map +1 -0
  284. package/dist/types/src/translations.d.ts +2 -48
  285. package/dist/types/src/translations.d.ts.map +1 -1
  286. package/dist/types/src/types/capabilities.d.ts +10 -0
  287. package/dist/types/src/types/capabilities.d.ts.map +1 -0
  288. package/dist/types/src/types/events.d.ts +9 -0
  289. package/dist/types/src/types/events.d.ts.map +1 -0
  290. package/dist/types/src/types/index.d.ts +2 -0
  291. package/dist/types/src/types/index.d.ts.map +1 -1
  292. package/dist/types/src/types/schema.d.ts +36 -31
  293. package/dist/types/src/types/schema.d.ts.map +1 -1
  294. package/dist/types/tsconfig.tsbuildinfo +1 -1
  295. package/package.json +89 -38
  296. package/src/ClientPlugin.ts +53 -58
  297. package/src/capabilities/app-graph-builder.ts +86 -104
  298. package/src/capabilities/client.ts +66 -30
  299. package/src/capabilities/index.ts +14 -10
  300. package/src/capabilities/migrations.ts +22 -17
  301. package/src/capabilities/navigation-handler/index.ts +9 -0
  302. package/src/capabilities/navigation-handler/navigation-handler.ts +64 -0
  303. package/src/capabilities/node.ts +13 -0
  304. package/src/capabilities/operation-handler.ts +16 -0
  305. package/src/capabilities/react-context.tsx +17 -14
  306. package/src/capabilities/react-surface.tsx +54 -48
  307. package/src/capabilities/schema-defs.ts +27 -20
  308. package/src/cli/commands/config/index.ts +12 -0
  309. package/src/cli/commands/config/view.ts +29 -0
  310. package/src/cli/commands/device/index.ts +14 -0
  311. package/src/cli/commands/device/info/index.ts +5 -0
  312. package/src/cli/commands/device/info/info.test.ts +28 -0
  313. package/src/cli/commands/device/info/info.ts +48 -0
  314. package/src/cli/commands/device/list/index.ts +5 -0
  315. package/src/cli/commands/device/list/list.test.ts +30 -0
  316. package/src/cli/commands/device/list/list.ts +28 -0
  317. package/src/cli/commands/device/update/index.ts +5 -0
  318. package/src/cli/commands/device/update/update.ts +68 -0
  319. package/src/cli/commands/device/util.ts +55 -0
  320. package/src/cli/commands/edge/index.ts +12 -0
  321. package/src/cli/commands/edge/status.ts +46 -0
  322. package/src/cli/commands/halo/create/create.test.ts +51 -0
  323. package/src/cli/commands/halo/create/create.ts +83 -0
  324. package/src/cli/commands/halo/create/index.ts +5 -0
  325. package/src/cli/commands/halo/credential/add/add.ts +97 -0
  326. package/src/cli/commands/halo/credential/add/index.ts +5 -0
  327. package/src/cli/commands/halo/credential/index.ts +13 -0
  328. package/src/cli/commands/halo/credential/list/index.ts +5 -0
  329. package/src/cli/commands/halo/credential/list/list.test.ts +27 -0
  330. package/src/cli/commands/halo/credential/list/list.ts +115 -0
  331. package/src/cli/commands/halo/identity/identity.test.ts +40 -0
  332. package/src/cli/commands/halo/identity/identity.ts +45 -0
  333. package/src/cli/commands/halo/identity/index.ts +5 -0
  334. package/src/cli/commands/halo/index.ts +21 -0
  335. package/src/cli/commands/halo/join/index.ts +5 -0
  336. package/src/cli/commands/halo/join/join.test.ts +10 -0
  337. package/src/cli/commands/halo/join/join.ts +87 -0
  338. package/src/cli/commands/halo/keys/index.ts +5 -0
  339. package/src/cli/commands/halo/keys/keys.test.ts +29 -0
  340. package/src/cli/commands/halo/keys/keys.ts +40 -0
  341. package/src/cli/commands/halo/recover/index.ts +5 -0
  342. package/src/cli/commands/halo/recover/recover.test.ts +10 -0
  343. package/src/cli/commands/halo/recover/recover.ts +44 -0
  344. package/src/cli/commands/halo/seed/index.ts +5 -0
  345. package/src/cli/commands/halo/seed/seed.ts +36 -0
  346. package/src/cli/commands/halo/share/index.ts +5 -0
  347. package/src/cli/commands/halo/share/share.ts +97 -0
  348. package/src/cli/commands/halo/update/index.ts +5 -0
  349. package/src/cli/commands/halo/update/update.test.ts +28 -0
  350. package/src/cli/commands/halo/update/update.ts +67 -0
  351. package/src/cli/commands/halo/util.ts +18 -0
  352. package/src/cli/commands/index.ts +9 -0
  353. package/src/cli/commands/profile/create.ts +90 -0
  354. package/src/cli/commands/profile/delete.ts +36 -0
  355. package/src/cli/commands/profile/import.ts +101 -0
  356. package/src/cli/commands/profile/index.ts +17 -0
  357. package/src/cli/commands/profile/inspect.ts +64 -0
  358. package/src/cli/commands/profile/list.ts +55 -0
  359. package/src/cli/commands/profile/reset.ts +45 -0
  360. package/src/cli/commands/profile/util.ts +48 -0
  361. package/src/cli/index.ts +5 -0
  362. package/src/cli/plugin.ts +31 -0
  363. package/src/cli/testing/test-console.ts +87 -0
  364. package/src/components/index.ts +0 -7
  365. package/src/constants.ts +9 -0
  366. package/src/{components → containers/DevicesContainer}/DevicesContainer.stories.tsx +15 -10
  367. package/src/{components → containers/DevicesContainer}/DevicesContainer.tsx +86 -92
  368. package/src/containers/DevicesContainer/index.ts +5 -0
  369. package/src/containers/JoinDialog/JoinDialog.stories.tsx +42 -0
  370. package/src/containers/JoinDialog/JoinDialog.tsx +56 -0
  371. package/src/containers/JoinDialog/index.ts +5 -0
  372. package/src/{components → containers/ProfileContainer}/ProfileContainer.stories.tsx +4 -5
  373. package/src/{components → containers/ProfileContainer}/ProfileContainer.tsx +66 -55
  374. package/src/containers/ProfileContainer/index.ts +5 -0
  375. package/src/{components → containers/RecoveryCodeDialog}/RecoveryCodeDialog.stories.tsx +4 -5
  376. package/src/{components → containers/RecoveryCodeDialog}/RecoveryCodeDialog.tsx +29 -28
  377. package/src/containers/RecoveryCodeDialog/index.ts +8 -0
  378. package/src/containers/RecoveryCredentialsContainer/RecoveryCredentialsContainer.stories.tsx +47 -0
  379. package/src/containers/RecoveryCredentialsContainer/RecoveryCredentialsContainer.tsx +66 -0
  380. package/src/containers/RecoveryCredentialsContainer/index.ts +5 -0
  381. package/src/containers/ResetDialog/ResetDialog.stories.tsx +72 -0
  382. package/src/containers/ResetDialog/ResetDialog.tsx +50 -0
  383. package/src/containers/ResetDialog/index.ts +8 -0
  384. package/src/containers/index.ts +15 -0
  385. package/src/index.ts +2 -6
  386. package/src/meta.ts +3 -3
  387. package/src/operations/create-agent.ts +26 -0
  388. package/src/operations/create-identity.ts +29 -0
  389. package/src/operations/create-passkey.ts +88 -0
  390. package/src/operations/create-recovery-code.ts +34 -0
  391. package/src/operations/definitions.ts +107 -0
  392. package/src/operations/index.ts +20 -0
  393. package/src/operations/join-identity.ts +28 -0
  394. package/src/operations/recover-identity.ts +28 -0
  395. package/src/operations/redeem-passkey.ts +85 -0
  396. package/src/operations/redeem-token.ts +31 -0
  397. package/src/operations/reset-storage.ts +27 -0
  398. package/src/operations/share-identity.ts +26 -0
  399. package/src/testing/index.ts +5 -0
  400. package/src/testing/initializeIdentity.ts +24 -0
  401. package/src/translations.ts +57 -43
  402. package/src/types/capabilities.ts +16 -0
  403. package/src/types/events.ts +15 -0
  404. package/src/types/index.ts +2 -0
  405. package/src/types/schema.ts +28 -20
  406. package/dist/lib/browser/app-graph-builder-ARY4H3VC.mjs +0 -124
  407. package/dist/lib/browser/app-graph-builder-ARY4H3VC.mjs.map +0 -7
  408. package/dist/lib/browser/chunk-4G4YWIUQ.mjs +0 -686
  409. package/dist/lib/browser/chunk-4G4YWIUQ.mjs.map +0 -7
  410. package/dist/lib/browser/chunk-4LRO3Y2O.mjs +0 -19
  411. package/dist/lib/browser/chunk-4LRO3Y2O.mjs.map +0 -7
  412. package/dist/lib/browser/chunk-N5UR2HOE.mjs +0 -18
  413. package/dist/lib/browser/chunk-N5UR2HOE.mjs.map +0 -7
  414. package/dist/lib/browser/chunk-RDIG75CA.mjs.map +0 -7
  415. package/dist/lib/browser/chunk-ZRVMXLDR.mjs +0 -15
  416. package/dist/lib/browser/chunk-ZRVMXLDR.mjs.map +0 -7
  417. package/dist/lib/browser/client-O7U3MQ6J.mjs +0 -43
  418. package/dist/lib/browser/client-O7U3MQ6J.mjs.map +0 -7
  419. package/dist/lib/browser/intent-resolver-KLK7PJZK.mjs +0 -305
  420. package/dist/lib/browser/intent-resolver-KLK7PJZK.mjs.map +0 -7
  421. package/dist/lib/browser/migrations-RUAKBBTF.mjs +0 -23
  422. package/dist/lib/browser/migrations-RUAKBBTF.mjs.map +0 -7
  423. package/dist/lib/browser/react-context-PCT5C3BN.mjs +0 -25
  424. package/dist/lib/browser/react-context-PCT5C3BN.mjs.map +0 -7
  425. package/dist/lib/browser/react-surface-RCXEA65V.mjs +0 -66
  426. package/dist/lib/browser/react-surface-RCXEA65V.mjs.map +0 -7
  427. package/dist/lib/browser/schema-defs-UNNBAEFW.mjs +0 -25
  428. package/dist/lib/browser/schema-defs-UNNBAEFW.mjs.map +0 -7
  429. package/dist/lib/node-esm/app-graph-builder-LLM25DRR.mjs +0 -125
  430. package/dist/lib/node-esm/app-graph-builder-LLM25DRR.mjs.map +0 -7
  431. package/dist/lib/node-esm/chunk-6ANOJ7ZM.mjs +0 -19
  432. package/dist/lib/node-esm/chunk-6ANOJ7ZM.mjs.map +0 -7
  433. package/dist/lib/node-esm/chunk-7M7VWQJW.mjs +0 -20
  434. package/dist/lib/node-esm/chunk-7M7VWQJW.mjs.map +0 -7
  435. package/dist/lib/node-esm/chunk-DJ6XKSE4.mjs +0 -687
  436. package/dist/lib/node-esm/chunk-DJ6XKSE4.mjs.map +0 -7
  437. package/dist/lib/node-esm/chunk-QT3EQXDU.mjs +0 -17
  438. package/dist/lib/node-esm/chunk-QT3EQXDU.mjs.map +0 -7
  439. package/dist/lib/node-esm/chunk-VENKFPBC.mjs.map +0 -7
  440. package/dist/lib/node-esm/client-6MTNT7M6.mjs +0 -44
  441. package/dist/lib/node-esm/client-6MTNT7M6.mjs.map +0 -7
  442. package/dist/lib/node-esm/intent-resolver-YR2C224X.mjs +0 -306
  443. package/dist/lib/node-esm/intent-resolver-YR2C224X.mjs.map +0 -7
  444. package/dist/lib/node-esm/migrations-ASF2SAUR.mjs +0 -24
  445. package/dist/lib/node-esm/migrations-ASF2SAUR.mjs.map +0 -7
  446. package/dist/lib/node-esm/react-context-F4QOBWSP.mjs +0 -26
  447. package/dist/lib/node-esm/react-context-F4QOBWSP.mjs.map +0 -7
  448. package/dist/lib/node-esm/react-surface-SQBRXVMZ.mjs +0 -67
  449. package/dist/lib/node-esm/react-surface-SQBRXVMZ.mjs.map +0 -7
  450. package/dist/lib/node-esm/schema-defs-MSIT2KK2.mjs +0 -26
  451. package/dist/lib/node-esm/schema-defs-MSIT2KK2.mjs.map +0 -7
  452. package/dist/types/src/capabilities/capabilities.d.ts +0 -9
  453. package/dist/types/src/capabilities/capabilities.d.ts.map +0 -1
  454. package/dist/types/src/capabilities/intent-resolver.d.ts +0 -8
  455. package/dist/types/src/capabilities/intent-resolver.d.ts.map +0 -1
  456. package/dist/types/src/components/DevicesContainer.d.ts.map +0 -1
  457. package/dist/types/src/components/DevicesContainer.stories.d.ts +0 -227
  458. package/dist/types/src/components/DevicesContainer.stories.d.ts.map +0 -1
  459. package/dist/types/src/components/JoinDialog.d.ts.map +0 -1
  460. package/dist/types/src/components/ProfileContainer.d.ts.map +0 -1
  461. package/dist/types/src/components/ProfileContainer.stories.d.ts +0 -60
  462. package/dist/types/src/components/ProfileContainer.stories.d.ts.map +0 -1
  463. package/dist/types/src/components/RecoveryCodeDialog.d.ts.map +0 -1
  464. package/dist/types/src/components/RecoveryCodeDialog.stories.d.ts +0 -62
  465. package/dist/types/src/components/RecoveryCodeDialog.stories.d.ts.map +0 -1
  466. package/dist/types/src/components/RecoveryCredentialsContainer.d.ts.map +0 -1
  467. package/dist/types/src/components/RecoveryCredentialsContainer.stories.d.ts +0 -60
  468. package/dist/types/src/components/RecoveryCredentialsContainer.stories.d.ts.map +0 -1
  469. package/dist/types/src/components/ResetDialog.d.ts +0 -7
  470. package/dist/types/src/components/ResetDialog.d.ts.map +0 -1
  471. package/dist/types/src/components/ResetDialog.stories.d.ts +0 -65
  472. package/dist/types/src/components/ResetDialog.stories.d.ts.map +0 -1
  473. package/dist/types/src/events.d.ts +0 -8
  474. package/dist/types/src/events.d.ts.map +0 -1
  475. package/src/capabilities/capabilities.ts +0 -18
  476. package/src/capabilities/intent-resolver.ts +0 -251
  477. package/src/components/JoinDialog.tsx +0 -54
  478. package/src/components/RecoveryCredentialsContainer.stories.tsx +0 -42
  479. package/src/components/RecoveryCredentialsContainer.tsx +0 -69
  480. package/src/components/ResetDialog.stories.tsx +0 -52
  481. package/src/components/ResetDialog.tsx +0 -50
  482. package/src/events.ts +0 -15
  483. /package/dist/types/src/{components → containers/DevicesContainer}/DevicesContainer.d.ts +0 -0
  484. /package/dist/types/src/{components → containers/ProfileContainer}/ProfileContainer.d.ts +0 -0
  485. /package/dist/types/src/{components → containers/RecoveryCredentialsContainer}/RecoveryCredentialsContainer.d.ts +0 -0
@@ -5,103 +5,94 @@
5
5
  import React, { useCallback, useEffect, useState } from 'react';
6
6
  import { QR } from 'react-qr-rounded';
7
7
 
8
- import { createIntent } from '@dxos/app-framework';
9
- import { useIntentDispatcher } from '@dxos/app-framework/react';
8
+ import { useOperationInvoker } from '@dxos/app-framework/ui';
10
9
  import { log } from '@dxos/log';
11
10
  import { useClient, useMulticastObservable } from '@dxos/react-client';
12
11
  import { type Device, useDevices } from '@dxos/react-client/halo';
13
12
  import { type CancellableInvitationObservable, Invitation, InvitationEncoder } from '@dxos/react-client/invitations';
14
13
  import { useNetworkStatus } from '@dxos/react-client/mesh';
15
14
  import { Button, Clipboard, Icon, IconButton, List, useId, useTranslation } from '@dxos/react-ui';
16
- import {
17
- ControlFrame,
18
- ControlFrameItem,
19
- ControlGroup,
20
- ControlItem,
21
- ControlPage,
22
- ControlSection,
23
- } from '@dxos/react-ui-form';
24
- import { AuthCode, Centered, DeviceListItem, Emoji, Viewport } from '@dxos/shell/react';
15
+ import { Settings } from '@dxos/react-ui-form';
16
+ import { AuthCode, Centered, DeviceListItem, Emoji, Viewport, translationKey } from '@dxos/shell/react';
17
+ import { osTranslations } from '@dxos/ui-theme';
25
18
  import { hexToEmoji } from '@dxos/util';
26
19
 
27
- import { meta } from '../meta';
28
- import { ClientAction } from '../types';
20
+ import { meta } from '#meta';
21
+ import { ClientOperation } from '#operations';
29
22
 
30
23
  export type DevicesContainerProps = {
31
24
  createInvitationUrl?: (invitationCode: string) => string;
32
25
  };
33
26
 
34
27
  export const DevicesContainer = ({ createInvitationUrl }: DevicesContainerProps) => {
35
- const { t } = useTranslation('os');
36
- const { dispatchPromise: dispatch } = useIntentDispatcher();
28
+ const { t } = useTranslation(translationKey);
29
+ const { invokePromise } = useOperationInvoker();
37
30
  const devices = useDevices();
38
31
  const { swarm: connectionState } = useNetworkStatus();
39
32
 
40
- const handleResetStorage = useCallback(() => dispatch(createIntent(ClientAction.ResetStorage)), [dispatch]);
33
+ const handleResetStorage = useCallback(() => invokePromise(ClientOperation.ResetStorage, {}), [invokePromise]);
41
34
 
42
35
  const handleRecover = useCallback(
43
- () => dispatch(createIntent(ClientAction.ResetStorage, { mode: 'recover' })),
44
- [dispatch],
36
+ () => invokePromise(ClientOperation.ResetStorage, { mode: 'recover' }),
37
+ [invokePromise],
45
38
  );
46
39
 
47
40
  const handleJoinNewIdentity = useCallback(
48
- () => dispatch(createIntent(ClientAction.ResetStorage, { mode: 'join new identity' })),
49
- [dispatch],
41
+ () => invokePromise(ClientOperation.ResetStorage, { mode: 'join new identity' }),
42
+ [invokePromise],
50
43
  );
51
44
 
52
45
  return (
53
46
  <Clipboard.Provider>
54
- <ControlPage>
55
- <ControlSection
56
- title={t('devices verbose label', { ns: meta.id })}
57
- description={t('devices description', { ns: meta.id })}
47
+ <Settings.Viewport>
48
+ <Settings.Section
49
+ title={t('devices-verbose.label', { ns: meta.id })}
50
+ description={t('devices.description', { ns: meta.id })}
58
51
  >
59
- <ControlFrame>
60
- <ControlFrameItem title={t('devices label', { ns: meta.id })}>
52
+ <Settings.Panel>
53
+ <div role='group' className='min-w-0'>
54
+ <h3 className='text-lg mb-2'>{t('devices.label', { ns: meta.id })}</h3>
61
55
  <List>
62
- {devices.map((device: Device) => {
63
- return (
64
- <DeviceListItem key={device.deviceKey.toHex()} device={device} connectionState={connectionState} />
65
- );
66
- })}
56
+ {devices.map((device: Device) => (
57
+ <DeviceListItem key={device.deviceKey.toHex()} device={device} connectionState={connectionState} />
58
+ ))}
67
59
  </List>
68
- </ControlFrameItem>
60
+ </div>
69
61
  {createInvitationUrl && (
70
- <ControlFrameItem title='Add device'>
62
+ <div role='group' className='min-w-0'>
63
+ <h3 className='text-lg mb-2'>{t('add-device.label')}</h3>
71
64
  <DeviceInvitation createInvitationUrl={createInvitationUrl} />
72
- </ControlFrameItem>
65
+ </div>
73
66
  )}
74
- </ControlFrame>
75
- </ControlSection>
76
- <ControlSection
77
- title={t('danger zone title', { ns: meta.id })}
78
- description={t('danger zone description', { ns: meta.id })}
67
+ </Settings.Panel>
68
+ </Settings.Section>
69
+ <Settings.Section
70
+ title={t('danger-zone.title', { ns: meta.id })}
71
+ description={t('danger-zone.description', { ns: meta.id })}
79
72
  >
80
- <ControlGroup>
81
- <ControlItem title={t('reset device label')} description={t('reset device description', { ns: meta.id })}>
82
- <Button variant='destructive' onClick={handleResetStorage} data-testid='devicesContainer.reset'>
83
- {t('reset device label')}
84
- </Button>
85
- </ControlItem>
86
- <ControlItem
87
- title={t('recover identity label')}
88
- description={t('recover identity description', { ns: meta.id })}
89
- >
90
- <Button variant='destructive' onClick={handleRecover} data-testid='devicesContainer.recover'>
91
- {t('recover identity label')}
92
- </Button>
93
- </ControlItem>
94
- <ControlItem
95
- title={t('join new identity label')}
96
- description={t('join new identity description', { ns: meta.id })}
97
- >
98
- <Button variant='destructive' onClick={handleJoinNewIdentity} data-testid='devicesContainer.joinExisting'>
99
- {t('join new identity label')}
100
- </Button>
101
- </ControlItem>
102
- </ControlGroup>
103
- </ControlSection>
104
- </ControlPage>
73
+ <Settings.Item title={t('reset-device.label')} description={t('reset-device.description', { ns: meta.id })}>
74
+ <Button variant='destructive' onClick={handleResetStorage} data-testid='devicesContainer.reset'>
75
+ {t('reset-device.label')}
76
+ </Button>
77
+ </Settings.Item>
78
+ <Settings.Item
79
+ title={t('recover-identity.label')}
80
+ description={t('recover-identity.description', { ns: meta.id })}
81
+ >
82
+ <Button variant='destructive' onClick={handleRecover} data-testid='devicesContainer.recover'>
83
+ {t('recover-identity.label')}
84
+ </Button>
85
+ </Settings.Item>
86
+ <Settings.Item
87
+ title={t('join-new-identity.label')}
88
+ description={t('join-new-identity.description', { ns: meta.id })}
89
+ >
90
+ <Button variant='destructive' onClick={handleJoinNewIdentity} data-testid='devicesContainer.joinExisting'>
91
+ {t('join-new-identity.label')}
92
+ </Button>
93
+ </Settings.Item>
94
+ </Settings.Section>
95
+ </Settings.Viewport>
105
96
  </Clipboard.Provider>
106
97
  );
107
98
  };
@@ -185,14 +176,15 @@ const InvitationSection = ({
185
176
  : state >= Invitation.State.READY_FOR_AUTHENTICATION && authCode
186
177
  ? 'auth-code'
187
178
  : 'qr-code';
179
+
188
180
  return activeView === 'init' ? (
189
181
  <>
190
- <p className='text-description mbe-2'>{t('add device description')}</p>
182
+ <p className='text-description mb-2'>{t('add-device.description')}</p>
191
183
  <IconButton
192
184
  icon='ph--plus--regular'
193
- label={t('create device invitation label')}
185
+ label={t('create-device-invitation.label')}
194
186
  disabled={state >= 0}
195
- classNames='is-full'
187
+ classNames='w-full'
196
188
  data-testid='devicesContainer.createInvitation'
197
189
  onClick={onInvitationCreate}
198
190
  />
@@ -218,30 +210,32 @@ const InvitationSection = ({
218
210
  };
219
211
 
220
212
  const InvitationQR = ({ id, url, onCancel }: { id: string; url: string; onCancel: () => void }) => {
221
- const { t } = useTranslation('os');
213
+ const { t } = useTranslation(osTranslations);
222
214
  const qrLabel = useId('devices-container__qr-code');
223
215
  const emoji = hexToEmoji(id);
224
216
  return (
225
217
  <>
226
- <p className='text-description'>{t('qr code description', { ns: meta.id })}</p>
227
- <div role='group' className='grid grid-cols-[1fr_min-content] mlb-2 gap-2'>
228
- <div role='none' className='is-full aspect-square relative text-description'>
229
- <QR
230
- rounding={100}
231
- backgroundColor='transparent'
232
- color='currentColor'
233
- aria-labelledby={qrLabel}
234
- errorCorrectionLevel='Q'
235
- cutout={true}
236
- >
237
- {url ?? 'never'}
238
- </QR>
239
- <Centered>
240
- <Emoji text={emoji} />
241
- </Centered>
218
+ <p className='text-description'>{t('qr-code.description', { ns: meta.id })}</p>
219
+ <div role='group' className='grid grid-cols-[1fr_min-content]'>
220
+ <div className='flex justify-center py-4'>
221
+ <div role='none' className='w-full md:max-w-80 aspect-square relative text-description'>
222
+ <QR
223
+ rounding={100}
224
+ backgroundColor='transparent'
225
+ color='currentColor'
226
+ aria-labelledby={qrLabel}
227
+ errorCorrectionLevel='Q'
228
+ cutout={true}
229
+ >
230
+ {url ?? 'never'}
231
+ </QR>
232
+ <Centered>
233
+ <Emoji text={emoji} />
234
+ </Centered>
235
+ </div>
242
236
  </div>
243
237
  <span id={qrLabel} className='sr-only'>
244
- {t('qr label')}
238
+ {t('qr.label')}
245
239
  </span>
246
240
  </div>
247
241
  {/* TODO(burdon): Factor out button bar */}
@@ -249,7 +243,7 @@ const InvitationQR = ({ id, url, onCancel }: { id: string; url: string; onCancel
249
243
  <div className='flex gap-2'>
250
244
  <Clipboard.Button value={url ?? 'never'} />
251
245
  <Button variant='ghost' onClick={onCancel}>
252
- {t('cancel label')}
246
+ {t('cancel.label')}
253
247
  </Button>
254
248
  </div>
255
249
  </div>
@@ -258,17 +252,17 @@ const InvitationQR = ({ id, url, onCancel }: { id: string; url: string; onCancel
258
252
  };
259
253
 
260
254
  const InvitationAuthCode = ({ id, code, onCancel }: { id: string; code: string; onCancel: () => void }) => {
261
- const { t } = useTranslation('os');
255
+ const { t } = useTranslation(osTranslations);
262
256
  const emoji = hexToEmoji(id);
263
257
 
264
258
  return (
265
259
  <>
266
- <p className='text-description'>{t('auth other device emoji message')}</p>
267
- {emoji && <Emoji text={emoji} className='mli-auto mlb-2 text-center' />}
268
- <p className='text-description'>{t('auth code message')}</p>
269
- <AuthCode code={code} large classNames='mli-auto mlb-2 text-center grow' />
260
+ <p className='text-description'>{t('auth-other-device-emoji.message')}</p>
261
+ {emoji && <Emoji text={emoji} className='mx-auto my-2 text-center' />}
262
+ <p className='text-description'>{t('auth-code.message')}</p>
263
+ <AuthCode code={code} large classNames='mx-auto my-2 text-center grow' />
270
264
  <Button variant='ghost' onClick={onCancel}>
271
- {t('cancel label')}
265
+ {t('cancel.label')}
272
266
  </Button>
273
267
  </>
274
268
  );
@@ -0,0 +1,5 @@
1
+ //
2
+ // Copyright 2025 DXOS.org
3
+ //
4
+
5
+ export { DevicesContainer as default } from './DevicesContainer';
@@ -0,0 +1,42 @@
1
+ //
2
+ // Copyright 2025 DXOS.org
3
+ //
4
+
5
+ import { type Meta, type StoryObj } from '@storybook/react-vite';
6
+ import React from 'react';
7
+
8
+ import { withPluginManager } from '@dxos/app-framework/testing';
9
+ import { corePlugins } from '@dxos/plugin-testing';
10
+ import { Dialog } from '@dxos/react-ui';
11
+
12
+ import { ClientPlugin } from '../../ClientPlugin';
13
+ import { translations } from '../../translations';
14
+ import { JoinDialog } from './JoinDialog';
15
+
16
+ const DefaultStory = () => (
17
+ <Dialog.Root defaultOpen>
18
+ <Dialog.Overlay>
19
+ <JoinDialog />
20
+ </Dialog.Overlay>
21
+ </Dialog.Root>
22
+ );
23
+
24
+ const meta = {
25
+ title: 'plugins/plugin-client/containers/JoinDialog',
26
+ component: JoinDialog,
27
+ render: DefaultStory,
28
+ decorators: [
29
+ withPluginManager({
30
+ plugins: [...corePlugins(), ClientPlugin({})],
31
+ }),
32
+ ],
33
+ parameters: {
34
+ translations,
35
+ },
36
+ } satisfies Meta<typeof JoinDialog>;
37
+
38
+ export default meta;
39
+
40
+ type Story = StoryObj<typeof meta>;
41
+
42
+ export const Default: Story = {};
@@ -0,0 +1,56 @@
1
+ //
2
+ // Copyright 2024 DXOS.org
3
+ //
4
+
5
+ import React, { useCallback } from 'react';
6
+
7
+ import { useOperationInvoker } from '@dxos/app-framework/ui';
8
+ import { LayoutOperation } from '@dxos/app-toolkit';
9
+ import { ObservabilityOperation } from '@dxos/plugin-observability/operations';
10
+ import { type InvitationResult } from '@dxos/react-client/invitations';
11
+ import { Dialog, useTranslation } from '@dxos/react-ui';
12
+ import { JoinPanel, type JoinPanelProps } from '@dxos/shell/react';
13
+ import { osTranslations } from '@dxos/ui-theme';
14
+
15
+ import { meta } from '#meta';
16
+ import { ClientOperation } from '#operations';
17
+
18
+ export const JoinDialog = (props: JoinPanelProps) => {
19
+ const { invokePromise } = useOperationInvoker();
20
+ const { t } = useTranslation(meta.id);
21
+
22
+ const handleCancelResetStorage = useCallback(() => invokePromise(ClientOperation.ShareIdentity), [invokePromise]);
23
+
24
+ const handleDone = useCallback(
25
+ async (result: InvitationResult | null) => {
26
+ if (result?.identityKey) {
27
+ await Promise.all([
28
+ invokePromise(LayoutOperation.UpdateDialog, { state: false }),
29
+ invokePromise(ObservabilityOperation.SendEvent, {
30
+ name: props.initialDisposition === 'recover-identity' ? 'identity.recover' : 'identity.join',
31
+ }),
32
+ ]);
33
+ }
34
+ },
35
+ [invokePromise],
36
+ );
37
+
38
+ // TODO(burdon): Move JoinHeading into Dialog.Heading.
39
+ return (
40
+ <Dialog.Content>
41
+ <Dialog.Header>
42
+ <Dialog.Title classNames='sr-only'>{t('join-space.label', { ns: osTranslations })}</Dialog.Title>
43
+ </Dialog.Header>
44
+ <Dialog.Body>
45
+ <JoinPanel
46
+ {...props}
47
+ mode='halo-only'
48
+ exitActionParent={<Dialog.Close asChild />}
49
+ doneActionParent={<Dialog.Close asChild />}
50
+ onCancelResetStorage={handleCancelResetStorage}
51
+ onDone={handleDone}
52
+ />
53
+ </Dialog.Body>
54
+ </Dialog.Content>
55
+ );
56
+ };
@@ -0,0 +1,5 @@
1
+ //
2
+ // Copyright 2025 DXOS.org
3
+ //
4
+
5
+ export { JoinDialog as default } from './JoinDialog';
@@ -5,16 +5,15 @@
5
5
  import { type Meta, type StoryObj } from '@storybook/react-vite';
6
6
 
7
7
  import { withClientProvider } from '@dxos/react-client/testing';
8
- import { withTheme } from '@dxos/react-ui/testing';
9
-
10
- import { translations } from '../translations';
8
+ import { withLayout, withTheme } from '@dxos/react-ui/testing';
11
9
 
10
+ import { translations } from '../../translations';
12
11
  import { ProfileContainer } from './ProfileContainer';
13
12
 
14
13
  const meta = {
15
- title: 'plugins/plugin-client/ProfileContainer',
14
+ title: 'plugins/plugin-client/containers/ProfileContainer',
16
15
  component: ProfileContainer,
17
- decorators: [withTheme, withClientProvider({ createIdentity: true })],
16
+ decorators: [withTheme(), withLayout({ layout: 'fullscreen' }), withClientProvider({ createIdentity: true })],
18
17
  parameters: {
19
18
  layout: 'fullscreen',
20
19
  translations,
@@ -9,23 +9,27 @@ import { debounce } from '@dxos/async';
9
9
  import { useClient } from '@dxos/react-client';
10
10
  import { type Identity, useIdentity } from '@dxos/react-client/halo';
11
11
  import { ButtonGroup, Clipboard, Input, useTranslation } from '@dxos/react-ui';
12
- import {
13
- ControlItem,
14
- ControlItemInput,
15
- ControlPage,
16
- ControlSection,
17
- Form,
18
- type InputComponent,
19
- } from '@dxos/react-ui-form';
12
+ import { Form, type FormFieldMap, type FormUpdateMeta, Settings } from '@dxos/react-ui-form';
20
13
  import { EmojiPickerBlock, HuePicker } from '@dxos/react-ui-pickers';
21
14
  import { hexToEmoji, hexToHue } from '@dxos/util';
22
15
 
23
- import { meta } from '../meta';
16
+ import { meta } from '#meta';
17
+
18
+ // TOOD(burdon): Factor out?
19
+ // TODO(wittjosiah): Integrate annotations with translations.
20
+ const UserProfile = Schema.Struct({
21
+ did: Schema.String.annotations({ title: 'DID' }),
22
+ displayName: Schema.String.annotations({ title: 'Display name' }),
23
+ emoji: Schema.String.annotations({ title: 'Avatar' }),
24
+ hue: Schema.String.annotations({ title: 'Color' }),
25
+ });
26
+
27
+ type UserProfile = Schema.Schema.Type<typeof UserProfile>;
24
28
 
25
29
  // TODO(thure): Factor out?
26
30
  const getDefaultHueValue = (identity: Identity | null) => hexToHue(identity?.identityKey.toHex() ?? '0');
27
- const getDefaultEmojiValue = (identity: Identity | null) => hexToEmoji(identity?.identityKey.toHex() ?? '0');
28
31
  const getHueValue = (identity: Identity | null) => identity?.profile?.data?.hue || getDefaultHueValue(identity);
32
+ const getDefaultEmojiValue = (identity: Identity | null) => hexToEmoji(identity?.identityKey.toHex() ?? '0');
29
33
  const getEmojiValue = (identity: Identity | null) => identity?.profile?.data?.emoji || getDefaultEmojiValue(identity);
30
34
 
31
35
  export const ProfileContainer = () => {
@@ -39,7 +43,7 @@ export const ProfileContainer = () => {
39
43
  const updateProfile = useMemo(
40
44
  () =>
41
45
  debounce(
42
- (profile: Partial<Profile>) =>
46
+ (profile: Partial<UserProfile>) =>
43
47
  client.halo.updateProfile({
44
48
  displayName: profile.displayName,
45
49
  data: {
@@ -52,11 +56,26 @@ export const ProfileContainer = () => {
52
56
  [],
53
57
  );
54
58
 
55
- const handleSave = useCallback(
56
- (profile: Profile) => {
57
- setDisplayNameDirectly(profile.displayName);
58
- setEmojiDirectly(profile.emoji);
59
- setHueDirectly(profile.hue);
59
+ const handleChange = useCallback(
60
+ (profile: Partial<UserProfile>, meta: FormUpdateMeta<UserProfile>) => {
61
+ for (const [path, changed] of Object.entries(meta.changed)) {
62
+ if (changed) {
63
+ switch (path) {
64
+ case 'displayName':
65
+ setDisplayNameDirectly(profile.displayName ?? '');
66
+ break;
67
+ case 'emoji':
68
+ setEmojiDirectly(profile.emoji ?? getDefaultEmojiValue(identity));
69
+ break;
70
+ case 'hue':
71
+ setHueDirectly(profile.hue ?? getDefaultHueValue(identity));
72
+ break;
73
+ default:
74
+ break;
75
+ }
76
+ }
77
+ }
78
+
60
79
  void updateProfile(profile);
61
80
  },
62
81
  [identity],
@@ -64,31 +83,32 @@ export const ProfileContainer = () => {
64
83
 
65
84
  const values = useMemo(
66
85
  () => ({
86
+ did: identity?.did,
67
87
  displayName,
68
88
  emoji,
69
89
  hue,
70
- did: identity?.did,
71
90
  }),
72
91
  [identity, displayName, emoji, hue],
73
92
  );
74
93
 
75
94
  // TODO(wittjosiah): Integrate descriptions with the form schema.
76
- const customElements: Partial<Record<string, InputComponent>> = useMemo(
95
+ const fieldMap = useMemo<FormFieldMap>(
77
96
  () => ({
78
97
  displayName: ({ type, label, getValue, onValueChange }) => {
79
98
  const handleChange = useCallback(
80
99
  ({ target: { value } }: ChangeEvent<HTMLInputElement>) => onValueChange(type, value),
81
100
  [onValueChange, type],
82
101
  );
102
+
83
103
  return (
84
- <ControlItemInput title={label} description={t('display name description')}>
104
+ <Settings.Item title={label} description={t('display-name.description')}>
85
105
  <Input.TextInput
86
106
  value={getValue()}
87
107
  onChange={handleChange}
88
- placeholder={t('display name input placeholder')}
89
- classNames='min-is-64'
108
+ placeholder={t('display-name-input.placeholder')}
109
+ classNames='min-w-64'
90
110
  />
91
- </ControlItemInput>
111
+ </Settings.Item>
92
112
  );
93
113
  },
94
114
  emoji: ({ type, label, getValue, onValueChange }) => {
@@ -97,8 +117,9 @@ export const ProfileContainer = () => {
97
117
  () => onValueChange(type, getDefaultEmojiValue(identity)),
98
118
  [onValueChange, type],
99
119
  );
120
+
100
121
  return (
101
- <ControlItem title={label} description={t('icon description')}>
122
+ <Settings.Item title={label} description={t('icon.description')}>
102
123
  <EmojiPickerBlock
103
124
  triggerVariant='default'
104
125
  emoji={getValue()}
@@ -106,7 +127,7 @@ export const ProfileContainer = () => {
106
127
  onClickClear={handleEmojiReset}
107
128
  classNames='justify-self-end'
108
129
  />
109
- </ControlItem>
130
+ </Settings.Item>
110
131
  );
111
132
  },
112
133
  hue: ({ type, label, getValue, onValueChange }) => {
@@ -115,21 +136,24 @@ export const ProfileContainer = () => {
115
136
  () => onValueChange(type, getDefaultHueValue(identity)),
116
137
  [onValueChange, type],
117
138
  );
139
+
118
140
  return (
119
- <ControlItem title={label} description={t('hue description')}>
120
- <HuePicker value={getValue()} onChange={handleChange} onReset={handleHueReset} />
121
- </ControlItem>
141
+ <Settings.Item title={label} description={t('hue.description')}>
142
+ <div role='none' className='flex justify-self-end'>
143
+ <HuePicker value={getValue()} onChange={handleChange} onReset={handleHueReset} />
144
+ </div>
145
+ </Settings.Item>
122
146
  );
123
147
  },
124
148
  // TODO(wittjosiah): We need text input annotations for disabled and copyable.
125
149
  did: ({ label, getValue }) => {
126
150
  return (
127
- <ControlItemInput title={label} description={t('did description')}>
128
- <ButtonGroup>
129
- <Input.TextInput value={getValue()} disabled classNames='min-is-64' />
151
+ <Settings.Item title={label} description={t('did.description')}>
152
+ <ButtonGroup classNames='w-full'>
153
+ <Input.TextInput value={getValue()} disabled classNames='min-w-64' />
130
154
  <Clipboard.IconButton value={getValue() ?? ''} />
131
155
  </ButtonGroup>
132
- </ControlItemInput>
156
+ </Settings.Item>
133
157
  );
134
158
  },
135
159
  }),
@@ -137,29 +161,16 @@ export const ProfileContainer = () => {
137
161
  );
138
162
 
139
163
  return (
140
- <ControlPage>
141
- <Clipboard.Provider>
142
- <ControlSection title={t('profile label')} description={t('profile description')}>
143
- <Form
144
- schema={ProfileSchema}
145
- values={values}
146
- autoSave
147
- onSave={handleSave}
148
- Custom={customElements}
149
- classNames='container-max-width grid grid-cols-1 md:grid-cols-[1fr_min-content]'
150
- outerSpacing={false}
151
- />
152
- </ControlSection>
153
- </Clipboard.Provider>
154
- </ControlPage>
164
+ <Clipboard.Provider>
165
+ <Settings.Viewport>
166
+ <Settings.Section title={t('profile.label')} description={t('profile.description')}>
167
+ <Form.Root schema={UserProfile} values={values} fieldMap={fieldMap} onValuesChanged={handleChange}>
168
+ <Form.Content>
169
+ <Form.FieldSet />
170
+ </Form.Content>
171
+ </Form.Root>
172
+ </Settings.Section>
173
+ </Settings.Viewport>
174
+ </Clipboard.Provider>
155
175
  );
156
176
  };
157
-
158
- // TODO(wittjosiah): Integrate annotations with translations.
159
- const ProfileSchema = Schema.Struct({
160
- displayName: Schema.String.annotations({ title: 'Display name' }),
161
- emoji: Schema.String.annotations({ title: 'Avatar' }),
162
- hue: Schema.String.annotations({ title: 'Color' }),
163
- did: Schema.String.annotations({ title: 'DID' }),
164
- });
165
- type Profile = Schema.Schema.Type<typeof ProfileSchema>;
@@ -0,0 +1,5 @@
1
+ //
2
+ // Copyright 2025 DXOS.org
3
+ //
4
+
5
+ export { ProfileContainer as default } from './ProfileContainer';
@@ -8,10 +8,9 @@ import React, { useState } from 'react';
8
8
  import { useClient } from '@dxos/react-client';
9
9
  import { withClientProvider } from '@dxos/react-client/testing';
10
10
  import { AlertDialog, useAsyncEffect } from '@dxos/react-ui';
11
- import { withTheme } from '@dxos/react-ui/testing';
12
-
13
- import { translations } from '../translations';
11
+ import { withLayout, withTheme } from '@dxos/react-ui/testing';
14
12
 
13
+ import { translations } from '../../translations';
15
14
  import { RecoveryCodeDialog } from './RecoveryCodeDialog';
16
15
 
17
16
  const DefaultStory = () => {
@@ -32,10 +31,10 @@ const DefaultStory = () => {
32
31
  };
33
32
 
34
33
  const meta = {
35
- title: 'plugins/plugin-client/RecoveryCodeDialog',
34
+ title: 'plugins/plugin-client/containers/RecoveryCodeDialog',
36
35
  component: RecoveryCodeDialog as any,
37
36
  render: DefaultStory,
38
- decorators: [withTheme, withClientProvider({ createIdentity: true })],
37
+ decorators: [withTheme(), withLayout({ layout: 'fullscreen' }), withClientProvider({ createIdentity: true })],
39
38
  parameters: {
40
39
  layout: 'fullscreen',
41
40
  translations,