@dxos/plugin-client 0.7.4 → 0.7.5-feature-compute.4d9d99a

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 (132) hide show
  1. package/dist/lib/browser/app-graph-builder-6LOTDB4T.mjs +44 -0
  2. package/dist/lib/browser/app-graph-builder-6LOTDB4T.mjs.map +7 -0
  3. package/dist/lib/browser/chunk-6IF6PREG.mjs +158 -0
  4. package/dist/lib/browser/chunk-6IF6PREG.mjs.map +7 -0
  5. package/dist/lib/browser/chunk-E3OUNOEL.mjs +76 -0
  6. package/dist/lib/browser/chunk-E3OUNOEL.mjs.map +7 -0
  7. package/dist/lib/browser/chunk-NHIL4T3L.mjs +12 -0
  8. package/dist/lib/browser/chunk-NHIL4T3L.mjs.map +7 -0
  9. package/dist/lib/browser/chunk-R4Q6H7RD.mjs +18 -0
  10. package/dist/lib/browser/chunk-R4Q6H7RD.mjs.map +7 -0
  11. package/dist/lib/browser/chunk-SVBQRT7I.mjs +17 -0
  12. package/dist/lib/browser/chunk-SVBQRT7I.mjs.map +7 -0
  13. package/dist/lib/browser/client-25GYH6TN.mjs +45 -0
  14. package/dist/lib/browser/client-25GYH6TN.mjs.map +7 -0
  15. package/dist/lib/browser/index.mjs +70 -428
  16. package/dist/lib/browser/index.mjs.map +4 -4
  17. package/dist/lib/browser/intent-resolver-IWWLWOZD.mjs +132 -0
  18. package/dist/lib/browser/intent-resolver-IWWLWOZD.mjs.map +7 -0
  19. package/dist/lib/browser/meta.json +1 -1
  20. package/dist/lib/browser/react-context-M3RT6SSG.mjs +24 -0
  21. package/dist/lib/browser/react-context-M3RT6SSG.mjs.map +7 -0
  22. package/dist/lib/browser/react-surface-XXONPG5T.mjs +41 -0
  23. package/dist/lib/browser/react-surface-XXONPG5T.mjs.map +7 -0
  24. package/dist/lib/browser/types.mjs +8 -0
  25. package/dist/lib/node/app-graph-builder-JCND3P6G.cjs +58 -0
  26. package/dist/lib/node/app-graph-builder-JCND3P6G.cjs.map +7 -0
  27. package/dist/lib/node/chunk-3OB25QN2.cjs +36 -0
  28. package/dist/lib/node/chunk-3OB25QN2.cjs.map +7 -0
  29. package/dist/lib/node/chunk-IXVWJCYB.cjs +37 -0
  30. package/dist/lib/node/chunk-IXVWJCYB.cjs.map +7 -0
  31. package/dist/lib/node/chunk-N3U7KVO3.cjs +186 -0
  32. package/dist/lib/node/chunk-N3U7KVO3.cjs.map +7 -0
  33. package/dist/lib/node/chunk-NVYWMDF3.cjs +95 -0
  34. package/dist/lib/node/chunk-NVYWMDF3.cjs.map +7 -0
  35. package/dist/lib/node/{meta.cjs → chunk-OIFPM5ZW.cjs} +12 -11
  36. package/dist/lib/node/chunk-OIFPM5ZW.cjs.map +7 -0
  37. package/dist/lib/node/client-52L4TUYU.cjs +59 -0
  38. package/dist/lib/node/client-52L4TUYU.cjs.map +7 -0
  39. package/dist/lib/node/index.cjs +65 -416
  40. package/dist/lib/node/index.cjs.map +4 -4
  41. package/dist/lib/node/intent-resolver-H3Y64MIP.cjs +140 -0
  42. package/dist/lib/node/intent-resolver-H3Y64MIP.cjs.map +7 -0
  43. package/dist/lib/node/meta.json +1 -1
  44. package/dist/lib/node/react-context-B2DNULH4.cjs +48 -0
  45. package/dist/lib/node/react-context-B2DNULH4.cjs.map +7 -0
  46. package/dist/lib/node/react-surface-7USN5NOO.cjs +62 -0
  47. package/dist/lib/node/react-surface-7USN5NOO.cjs.map +7 -0
  48. package/dist/lib/node/types.cjs +30 -0
  49. package/dist/lib/node/types.cjs.map +7 -0
  50. package/dist/lib/node-esm/app-graph-builder-ZLGKFBLY.mjs +45 -0
  51. package/dist/lib/node-esm/app-graph-builder-ZLGKFBLY.mjs.map +7 -0
  52. package/dist/lib/node-esm/chunk-73M5MK5Q.mjs +19 -0
  53. package/dist/lib/node-esm/chunk-73M5MK5Q.mjs.map +7 -0
  54. package/dist/lib/node-esm/chunk-74T33KTB.mjs +77 -0
  55. package/dist/lib/node-esm/chunk-74T33KTB.mjs.map +7 -0
  56. package/dist/lib/node-esm/chunk-EHGD3UJH.mjs +159 -0
  57. package/dist/lib/node-esm/chunk-EHGD3UJH.mjs.map +7 -0
  58. package/dist/lib/node-esm/chunk-HO7WDE7C.mjs +14 -0
  59. package/dist/lib/node-esm/chunk-HO7WDE7C.mjs.map +7 -0
  60. package/dist/lib/node-esm/chunk-OBGRL3DF.mjs +18 -0
  61. package/dist/lib/node-esm/chunk-OBGRL3DF.mjs.map +7 -0
  62. package/dist/lib/node-esm/client-K52NWOUN.mjs +46 -0
  63. package/dist/lib/node-esm/client-K52NWOUN.mjs.map +7 -0
  64. package/dist/lib/node-esm/index.mjs +70 -428
  65. package/dist/lib/node-esm/index.mjs.map +4 -4
  66. package/dist/lib/node-esm/intent-resolver-JCKD6R6L.mjs +133 -0
  67. package/dist/lib/node-esm/intent-resolver-JCKD6R6L.mjs.map +7 -0
  68. package/dist/lib/node-esm/meta.json +1 -1
  69. package/dist/lib/node-esm/react-context-IGEHJQK5.mjs +25 -0
  70. package/dist/lib/node-esm/react-context-IGEHJQK5.mjs.map +7 -0
  71. package/dist/lib/node-esm/react-surface-CXLBCMPN.mjs +42 -0
  72. package/dist/lib/node-esm/react-surface-CXLBCMPN.mjs.map +7 -0
  73. package/dist/lib/node-esm/types.mjs +9 -0
  74. package/dist/types/src/ClientPlugin.d.ts +2 -36
  75. package/dist/types/src/ClientPlugin.d.ts.map +1 -1
  76. package/dist/types/src/capabilities/app-graph-builder.d.ts +181 -0
  77. package/dist/types/src/capabilities/app-graph-builder.d.ts.map +1 -0
  78. package/dist/types/src/capabilities/capabilities.d.ts +8 -0
  79. package/dist/types/src/capabilities/capabilities.d.ts.map +1 -0
  80. package/dist/types/src/capabilities/client.d.ts +9 -0
  81. package/dist/types/src/capabilities/client.d.ts.map +1 -0
  82. package/dist/types/src/capabilities/index.d.ts +193 -0
  83. package/dist/types/src/capabilities/index.d.ts.map +1 -0
  84. package/dist/types/src/capabilities/intent-resolver.d.ts +8 -0
  85. package/dist/types/src/capabilities/intent-resolver.d.ts.map +1 -0
  86. package/dist/types/src/capabilities/react-context.d.ts +8 -0
  87. package/dist/types/src/capabilities/react-context.d.ts.map +1 -0
  88. package/dist/types/src/capabilities/react-surface.d.ts +7 -0
  89. package/dist/types/src/capabilities/react-surface.d.ts.map +1 -0
  90. package/dist/types/src/components/IdentityDialog.d.ts +1 -0
  91. package/dist/types/src/components/IdentityDialog.d.ts.map +1 -1
  92. package/dist/types/src/components/JoinDialog.d.ts +1 -0
  93. package/dist/types/src/components/JoinDialog.d.ts.map +1 -1
  94. package/dist/types/src/components/RecoveryCodeDialog.d.ts +1 -0
  95. package/dist/types/src/components/RecoveryCodeDialog.d.ts.map +1 -1
  96. package/dist/types/src/events.d.ts +7 -0
  97. package/dist/types/src/events.d.ts.map +1 -0
  98. package/dist/types/src/index.d.ts +3 -2
  99. package/dist/types/src/index.d.ts.map +1 -1
  100. package/dist/types/src/meta.d.ts +1 -12
  101. package/dist/types/src/meta.d.ts.map +1 -1
  102. package/dist/types/src/types.d.ts +98 -0
  103. package/dist/types/src/types.d.ts.map +1 -0
  104. package/dist/types/tsconfig.tsbuildinfo +1 -0
  105. package/package.json +21 -19
  106. package/src/ClientPlugin.ts +59 -0
  107. package/src/capabilities/app-graph-builder.ts +39 -0
  108. package/src/capabilities/capabilities.ts +15 -0
  109. package/src/capabilities/client.ts +48 -0
  110. package/src/capabilities/index.ts +13 -0
  111. package/src/capabilities/intent-resolver.ts +101 -0
  112. package/src/capabilities/react-context.tsx +20 -0
  113. package/src/capabilities/react-surface.tsx +44 -0
  114. package/src/components/IdentityDialog.tsx +13 -11
  115. package/src/components/JoinDialog.tsx +13 -19
  116. package/src/components/RecoveryCodeDialog.tsx +3 -1
  117. package/src/events.ts +14 -0
  118. package/src/index.ts +4 -4
  119. package/src/meta.ts +1 -15
  120. package/src/types.ts +89 -0
  121. package/dist/lib/browser/chunk-FGUXUNOK.mjs +0 -26
  122. package/dist/lib/browser/chunk-FGUXUNOK.mjs.map +0 -7
  123. package/dist/lib/browser/meta.mjs +0 -13
  124. package/dist/lib/node/chunk-XYLDQWFV.cjs +0 -51
  125. package/dist/lib/node/chunk-XYLDQWFV.cjs.map +0 -7
  126. package/dist/lib/node/meta.cjs.map +0 -7
  127. package/dist/lib/node-esm/chunk-C6X363FK.mjs +0 -28
  128. package/dist/lib/node-esm/chunk-C6X363FK.mjs.map +0 -7
  129. package/dist/lib/node-esm/meta.mjs +0 -14
  130. package/src/ClientPlugin.tsx +0 -316
  131. /package/dist/lib/browser/{meta.mjs.map → types.mjs.map} +0 -0
  132. /package/dist/lib/node-esm/{meta.mjs.map → types.mjs.map} +0 -0
@@ -0,0 +1,159 @@
1
+ import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
2
+ import {
3
+ ClientAction
4
+ } from "./chunk-74T33KTB.mjs";
5
+ import {
6
+ CLIENT_PLUGIN
7
+ } from "./chunk-HO7WDE7C.mjs";
8
+
9
+ // packages/plugins/plugin-client/src/components/IdentityDialog.tsx
10
+ import React, { useCallback } from "react";
11
+ import { createIntent, LayoutAction, useIntentDispatcher } from "@dxos/app-framework";
12
+ import { useClient } from "@dxos/react-client";
13
+ import { Clipboard, Dialog } from "@dxos/react-ui";
14
+ import { IdentityPanel } from "@dxos/shell/react";
15
+ var IDENTITY_DIALOG = `${CLIENT_PLUGIN}/IdentityDialog`;
16
+ var IdentityDialog = (props) => {
17
+ const { dispatchPromise: dispatch } = useIntentDispatcher();
18
+ const client = useClient();
19
+ const handleDone = useCallback(() => dispatch(createIntent(LayoutAction.SetLayout, {
20
+ element: "dialog",
21
+ state: false
22
+ })), [
23
+ dispatch
24
+ ]);
25
+ const handleResetStorage = useCallback(async () => {
26
+ await client.reset();
27
+ await dispatch(createIntent(ClientAction.ResetStorage));
28
+ }, [
29
+ dispatch
30
+ ]);
31
+ const handleRecover = useCallback(async () => {
32
+ await client.reset();
33
+ await dispatch(createIntent(ClientAction.ResetStorage, {
34
+ target: "recoverIdentity"
35
+ }));
36
+ }, [
37
+ dispatch
38
+ ]);
39
+ const handleJoinNewIdentity = useCallback(async () => {
40
+ await client.reset();
41
+ await dispatch(createIntent(ClientAction.ResetStorage, {
42
+ target: "deviceInvitation"
43
+ }));
44
+ }, [
45
+ dispatch
46
+ ]);
47
+ return /* @__PURE__ */ React.createElement(Dialog.Content, null, /* @__PURE__ */ React.createElement(Clipboard.Provider, null, /* @__PURE__ */ React.createElement(IdentityPanel, {
48
+ ...props,
49
+ doneActionParent: /* @__PURE__ */ React.createElement(Dialog.Close, {
50
+ asChild: true
51
+ }),
52
+ onDone: handleDone,
53
+ onResetStorage: handleResetStorage,
54
+ onRecover: handleRecover,
55
+ onJoinNewIdentity: handleJoinNewIdentity
56
+ })));
57
+ };
58
+
59
+ // packages/plugins/plugin-client/src/components/JoinDialog.tsx
60
+ import React2, { useCallback as useCallback2 } from "react";
61
+ import { createIntent as createIntent2, LayoutAction as LayoutAction2, useIntentDispatcher as useIntentDispatcher2 } from "@dxos/app-framework";
62
+ import { ObservabilityAction } from "@dxos/plugin-observability/types";
63
+ import { Dialog as Dialog2 } from "@dxos/react-ui";
64
+ import { JoinPanel } from "@dxos/shell/react";
65
+ var JOIN_DIALOG = `${CLIENT_PLUGIN}/JoinDialog`;
66
+ var JoinDialog = (props) => {
67
+ const { dispatchPromise: dispatch } = useIntentDispatcher2();
68
+ const handleCancelResetStorage = useCallback2(() => dispatch(createIntent2(ClientAction.ShareIdentity)), [
69
+ dispatch
70
+ ]);
71
+ const handleDone = useCallback2(async (result) => {
72
+ if (result?.identityKey) {
73
+ await Promise.all([
74
+ dispatch(createIntent2(LayoutAction2.SetLayout, {
75
+ element: "dialog",
76
+ state: false
77
+ })),
78
+ dispatch(createIntent2(ObservabilityAction.SendEvent, {
79
+ name: props.initialDisposition === "recover-identity" ? "identity.recover" : "identity.join"
80
+ }))
81
+ ]);
82
+ }
83
+ }, [
84
+ dispatch
85
+ ]);
86
+ return /* @__PURE__ */ React2.createElement(Dialog2.Content, null, /* @__PURE__ */ React2.createElement(JoinPanel, {
87
+ mode: "halo-only",
88
+ ...props,
89
+ exitActionParent: /* @__PURE__ */ React2.createElement(Dialog2.Close, {
90
+ asChild: true
91
+ }),
92
+ doneActionParent: /* @__PURE__ */ React2.createElement(Dialog2.Close, {
93
+ asChild: true
94
+ }),
95
+ onCancelResetStorage: handleCancelResetStorage,
96
+ onDone: handleDone
97
+ }));
98
+ };
99
+
100
+ // packages/plugins/plugin-client/src/components/RecoveryCodeDialog.tsx
101
+ import React3, { useCallback as useCallback3, useState } from "react";
102
+ import { AlertDialog, Button, Clipboard as Clipboard2, Input, useTranslation } from "@dxos/react-ui";
103
+ var RECOVER_CODE_DIALOG = `${CLIENT_PLUGIN}/RecoveryCodeDialog`;
104
+ var RecoveryCodeDialog = ({ code }) => {
105
+ const { t } = useTranslation(CLIENT_PLUGIN);
106
+ const [confirmation, setConfirmation] = useState(false);
107
+ const handleConfirmation = useCallback3((checked) => setConfirmation(checked), []);
108
+ return /* @__PURE__ */ React3.createElement(AlertDialog.Content, {
109
+ classNames: "bs-content min-bs-[15rem] max-bs-full md:max-is-[40rem] overflow-hidden"
110
+ }, /* @__PURE__ */ React3.createElement(AlertDialog.Title, null, t("recovery code dialog title")), /* @__PURE__ */ React3.createElement("p", {
111
+ className: "py-4"
112
+ }, t("recovery code dialog description")), /* @__PURE__ */ React3.createElement(Clipboard2.Provider, null, /* @__PURE__ */ React3.createElement(Code, {
113
+ code
114
+ })), /* @__PURE__ */ React3.createElement("div", {
115
+ className: "flex flex-col py-4 gap-2"
116
+ }, /* @__PURE__ */ React3.createElement("p", null, t("recovery code dialog warning 1")), /* @__PURE__ */ React3.createElement("p", null, t("recovery code dialog warning 2"))), /* @__PURE__ */ React3.createElement("div", {
117
+ className: "flex items-center gap-2 pbe-4"
118
+ }, /* @__PURE__ */ React3.createElement(Input.Root, null, /* @__PURE__ */ React3.createElement(Input.Checkbox, {
119
+ "data-testid": "recoveryCode.confirm",
120
+ checked: confirmation,
121
+ onCheckedChange: handleConfirmation
122
+ }), /* @__PURE__ */ React3.createElement(Input.Label, null, t("recovery code confirmation label")))), /* @__PURE__ */ React3.createElement("div", {
123
+ className: "flex justify-end"
124
+ }, /* @__PURE__ */ React3.createElement(AlertDialog.Action, {
125
+ asChild: true
126
+ }, /* @__PURE__ */ React3.createElement(Button, {
127
+ "data-testid": "recoveryCode.continue",
128
+ variant: "primary",
129
+ disabled: !confirmation
130
+ }, t("continue label")))));
131
+ };
132
+ var Code = ({ code }) => {
133
+ const words = code.split(" ");
134
+ return /* @__PURE__ */ React3.createElement("div", {
135
+ className: "relative p-2 border border-separator rounded group"
136
+ }, /* @__PURE__ */ React3.createElement(Clipboard2.IconButton, {
137
+ value: code,
138
+ classNames: "absolute top-2 right-2 invisible group-hover:visible"
139
+ }), /* @__PURE__ */ React3.createElement("div", {
140
+ className: "grid grid-cols-4"
141
+ }, words.map((word, i) => /* @__PURE__ */ React3.createElement("div", {
142
+ key: i,
143
+ className: "flex items-center p-2 gap-2 items-center"
144
+ }, /* @__PURE__ */ React3.createElement("div", {
145
+ className: "w-4 text-xs text-center text-subdued"
146
+ }, i + 1), /* @__PURE__ */ React3.createElement("div", {
147
+ className: "text-sm"
148
+ }, word)))));
149
+ };
150
+
151
+ export {
152
+ IDENTITY_DIALOG,
153
+ IdentityDialog,
154
+ JOIN_DIALOG,
155
+ JoinDialog,
156
+ RECOVER_CODE_DIALOG,
157
+ RecoveryCodeDialog
158
+ };
159
+ //# sourceMappingURL=chunk-EHGD3UJH.mjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/components/IdentityDialog.tsx", "../../../src/components/JoinDialog.tsx", "../../../src/components/RecoveryCodeDialog.tsx"],
4
+ "sourcesContent": ["//\n// Copyright 2024 DXOS.org\n//\n\nimport React, { useCallback } from 'react';\n\nimport { createIntent, LayoutAction, useIntentDispatcher } from '@dxos/app-framework';\nimport { useClient } from '@dxos/react-client';\nimport { Clipboard, Dialog } from '@dxos/react-ui';\nimport { IdentityPanel, type IdentityPanelProps } from '@dxos/shell/react';\n\nimport { CLIENT_PLUGIN } from '../meta';\nimport { ClientAction } from '../types';\n\nexport const IDENTITY_DIALOG = `${CLIENT_PLUGIN}/IdentityDialog`;\n\nexport const IdentityDialog = (props: IdentityPanelProps) => {\n const { dispatchPromise: dispatch } = useIntentDispatcher();\n const client = useClient();\n\n const handleDone = useCallback(\n () =>\n dispatch(\n createIntent(LayoutAction.SetLayout, {\n element: 'dialog',\n state: false,\n }),\n ),\n [dispatch],\n );\n\n const handleResetStorage = useCallback(async () => {\n await client.reset();\n await dispatch(createIntent(ClientAction.ResetStorage));\n }, [dispatch]);\n\n const handleRecover = useCallback(async () => {\n await client.reset();\n await dispatch(createIntent(ClientAction.ResetStorage, { target: 'recoverIdentity' }));\n }, [dispatch]);\n\n const handleJoinNewIdentity = useCallback(async () => {\n await client.reset();\n await dispatch(createIntent(ClientAction.ResetStorage, { target: 'deviceInvitation' }));\n }, [dispatch]);\n\n return (\n <Dialog.Content>\n <Clipboard.Provider>\n <IdentityPanel\n {...props}\n doneActionParent={<Dialog.Close asChild />}\n onDone={handleDone}\n onResetStorage={handleResetStorage}\n onRecover={handleRecover}\n onJoinNewIdentity={handleJoinNewIdentity}\n />\n </Clipboard.Provider>\n </Dialog.Content>\n );\n};\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport React, { useCallback } from 'react';\n\nimport { createIntent, LayoutAction, useIntentDispatcher } from '@dxos/app-framework';\nimport { ObservabilityAction } from '@dxos/plugin-observability/types';\nimport { type InvitationResult } from '@dxos/react-client/invitations';\nimport { Dialog } from '@dxos/react-ui';\nimport { JoinPanel, type JoinPanelProps } from '@dxos/shell/react';\n\nimport { CLIENT_PLUGIN } from '../meta';\nimport { ClientAction } from '../types';\n\nexport const JOIN_DIALOG = `${CLIENT_PLUGIN}/JoinDialog`;\n\nexport const JoinDialog = (props: JoinPanelProps) => {\n const { dispatchPromise: dispatch } = useIntentDispatcher();\n\n const handleCancelResetStorage = useCallback(() => dispatch(createIntent(ClientAction.ShareIdentity)), [dispatch]);\n\n const handleDone = useCallback(\n async (result: InvitationResult | null) => {\n if (result?.identityKey) {\n await Promise.all([\n dispatch(createIntent(LayoutAction.SetLayout, { element: 'dialog', state: false })),\n dispatch(\n createIntent(ObservabilityAction.SendEvent, {\n name: props.initialDisposition === 'recover-identity' ? 'identity.recover' : 'identity.join',\n }),\n ),\n ]);\n }\n },\n [dispatch],\n );\n\n return (\n <Dialog.Content>\n <JoinPanel\n mode='halo-only'\n {...props}\n exitActionParent={<Dialog.Close asChild />}\n doneActionParent={<Dialog.Close asChild />}\n onCancelResetStorage={handleCancelResetStorage}\n onDone={handleDone}\n />\n </Dialog.Content>\n );\n};\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport React, { useCallback, useState } from 'react';\n\nimport { AlertDialog, Button, Clipboard, Input, useTranslation } from '@dxos/react-ui';\n\nimport { CLIENT_PLUGIN } from '../meta';\n\nexport const RECOVER_CODE_DIALOG = `${CLIENT_PLUGIN}/RecoveryCodeDialog`;\n\nexport type RecoveryCodeDialogProps = {\n code: string;\n};\n\nexport const RecoveryCodeDialog = ({ code }: RecoveryCodeDialogProps) => {\n const { t } = useTranslation(CLIENT_PLUGIN);\n const [confirmation, setConfirmation] = useState(false);\n\n const handleConfirmation = useCallback((checked: boolean) => setConfirmation(checked), []);\n\n return (\n <AlertDialog.Content classNames='bs-content min-bs-[15rem] max-bs-full md:max-is-[40rem] overflow-hidden'>\n <AlertDialog.Title>{t('recovery code dialog title')}</AlertDialog.Title>\n <p className='py-4'>{t('recovery code dialog description')}</p>\n <Clipboard.Provider>\n <Code code={code} />\n </Clipboard.Provider>\n <div className='flex flex-col py-4 gap-2'>\n <p>{t('recovery code dialog warning 1')}</p>\n <p>{t('recovery code dialog warning 2')}</p>\n </div>\n <div className='flex items-center gap-2 pbe-4'>\n <Input.Root>\n <Input.Checkbox\n data-testid='recoveryCode.confirm'\n checked={confirmation}\n onCheckedChange={handleConfirmation}\n />\n <Input.Label>{t('recovery code confirmation label')}</Input.Label>\n </Input.Root>\n </div>\n <div className='flex justify-end'>\n <AlertDialog.Action asChild>\n <Button data-testid='recoveryCode.continue' variant='primary' disabled={!confirmation}>\n {t('continue label')}\n </Button>\n </AlertDialog.Action>\n </div>\n </AlertDialog.Content>\n );\n};\n\nconst Code = ({ code }: { code: string }) => {\n const words = code.split(' ');\n return (\n <div className='relative p-2 border border-separator rounded group'>\n <Clipboard.IconButton value={code} classNames='absolute top-2 right-2 invisible group-hover:visible' />\n <div className='grid grid-cols-4'>\n {words.map((word, i) => (\n <div key={i} className='flex items-center p-2 gap-2 items-center'>\n <div className='w-4 text-xs text-center text-subdued'>{i + 1}</div>\n <div className='text-sm'>{word}</div>\n </div>\n ))}\n </div>\n </div>\n );\n};\n"],
5
+ "mappings": ";;;;;;;;;AAIA,OAAOA,SAASC,mBAAmB;AAEnC,SAASC,cAAcC,cAAcC,2BAA2B;AAChE,SAASC,iBAAiB;AAC1B,SAASC,WAAWC,cAAc;AAClC,SAASC,qBAA8C;AAKhD,IAAMC,kBAAkB,GAAGC,aAAAA;AAE3B,IAAMC,iBAAiB,CAACC,UAAAA;AAC7B,QAAM,EAAEC,iBAAiBC,SAAQ,IAAKC,oBAAAA;AACtC,QAAMC,SAASC,UAAAA;AAEf,QAAMC,aAAaC,YACjB,MACEL,SACEM,aAAaC,aAAaC,WAAW;IACnCC,SAAS;IACTC,OAAO;EACT,CAAA,CAAA,GAEJ;IAACV;GAAS;AAGZ,QAAMW,qBAAqBN,YAAY,YAAA;AACrC,UAAMH,OAAOU,MAAK;AAClB,UAAMZ,SAASM,aAAaO,aAAaC,YAAY,CAAA;EACvD,GAAG;IAACd;GAAS;AAEb,QAAMe,gBAAgBV,YAAY,YAAA;AAChC,UAAMH,OAAOU,MAAK;AAClB,UAAMZ,SAASM,aAAaO,aAAaC,cAAc;MAAEE,QAAQ;IAAkB,CAAA,CAAA;EACrF,GAAG;IAAChB;GAAS;AAEb,QAAMiB,wBAAwBZ,YAAY,YAAA;AACxC,UAAMH,OAAOU,MAAK;AAClB,UAAMZ,SAASM,aAAaO,aAAaC,cAAc;MAAEE,QAAQ;IAAmB,CAAA,CAAA;EACtF,GAAG;IAAChB;GAAS;AAEb,SACE,sBAAA,cAACkB,OAAOC,SAAO,MACb,sBAAA,cAACC,UAAUC,UAAQ,MACjB,sBAAA,cAACC,eAAAA;IACE,GAAGxB;IACJyB,kBAAkB,sBAAA,cAACL,OAAOM,OAAK;MAACC,SAAAA;;IAChCC,QAAQtB;IACRuB,gBAAgBhB;IAChBiB,WAAWb;IACXc,mBAAmBZ;;AAK7B;;;ACxDA,OAAOa,UAASC,eAAAA,oBAAmB;AAEnC,SAASC,gBAAAA,eAAcC,gBAAAA,eAAcC,uBAAAA,4BAA2B;AAChE,SAASC,2BAA2B;AAEpC,SAASC,UAAAA,eAAc;AACvB,SAASC,iBAAsC;AAKxC,IAAMC,cAAc,GAAGC,aAAAA;AAEvB,IAAMC,aAAa,CAACC,UAAAA;AACzB,QAAM,EAAEC,iBAAiBC,SAAQ,IAAKC,qBAAAA;AAEtC,QAAMC,2BAA2BC,aAAY,MAAMH,SAASI,cAAaC,aAAaC,aAAa,CAAA,GAAI;IAACN;GAAS;AAEjH,QAAMO,aAAaJ,aACjB,OAAOK,WAAAA;AACL,QAAIA,QAAQC,aAAa;AACvB,YAAMC,QAAQC,IAAI;QAChBX,SAASI,cAAaQ,cAAaC,WAAW;UAAEC,SAAS;UAAUC,OAAO;QAAM,CAAA,CAAA;QAChFf,SACEI,cAAaY,oBAAoBC,WAAW;UAC1CC,MAAMpB,MAAMqB,uBAAuB,qBAAqB,qBAAqB;QAC/E,CAAA,CAAA;OAEH;IACH;EACF,GACA;IAACnB;GAAS;AAGZ,SACE,gBAAAoB,OAAA,cAACC,QAAOC,SAAO,MACb,gBAAAF,OAAA,cAACG,WAAAA;IACCC,MAAK;IACJ,GAAG1B;IACJ2B,kBAAkB,gBAAAL,OAAA,cAACC,QAAOK,OAAK;MAACC,SAAAA;;IAChCC,kBAAkB,gBAAAR,OAAA,cAACC,QAAOK,OAAK;MAACC,SAAAA;;IAChCE,sBAAsB3B;IACtB4B,QAAQvB;;AAIhB;;;AC9CA,OAAOwB,UAASC,eAAAA,cAAaC,gBAAgB;AAE7C,SAASC,aAAaC,QAAQC,aAAAA,YAAWC,OAAOC,sBAAsB;AAI/D,IAAMC,sBAAsB,GAAGC,aAAAA;AAM/B,IAAMC,qBAAqB,CAAC,EAAEC,KAAI,MAA2B;AAClE,QAAM,EAAEC,EAAC,IAAKC,eAAeJ,aAAAA;AAC7B,QAAM,CAACK,cAAcC,eAAAA,IAAmBC,SAAS,KAAA;AAEjD,QAAMC,qBAAqBC,aAAY,CAACC,YAAqBJ,gBAAgBI,OAAAA,GAAU,CAAA,CAAE;AAEzF,SACE,gBAAAC,OAAA,cAACC,YAAYC,SAAO;IAACC,YAAW;KAC9B,gBAAAH,OAAA,cAACC,YAAYG,OAAK,MAAEZ,EAAE,4BAAA,CAAA,GACtB,gBAAAQ,OAAA,cAACK,KAAAA;IAAEC,WAAU;KAAQd,EAAE,kCAAA,CAAA,GACvB,gBAAAQ,OAAA,cAACO,WAAUC,UAAQ,MACjB,gBAAAR,OAAA,cAACS,MAAAA;IAAKlB;OAER,gBAAAS,OAAA,cAACU,OAAAA;IAAIJ,WAAU;KACb,gBAAAN,OAAA,cAACK,KAAAA,MAAGb,EAAE,gCAAA,CAAA,GACN,gBAAAQ,OAAA,cAACK,KAAAA,MAAGb,EAAE,gCAAA,CAAA,CAAA,GAER,gBAAAQ,OAAA,cAACU,OAAAA;IAAIJ,WAAU;KACb,gBAAAN,OAAA,cAACW,MAAMC,MAAI,MACT,gBAAAZ,OAAA,cAACW,MAAME,UAAQ;IACbC,eAAY;IACZf,SAASL;IACTqB,iBAAiBlB;MAEnB,gBAAAG,OAAA,cAACW,MAAMK,OAAK,MAAExB,EAAE,kCAAA,CAAA,CAAA,CAAA,GAGpB,gBAAAQ,OAAA,cAACU,OAAAA;IAAIJ,WAAU;KACb,gBAAAN,OAAA,cAACC,YAAYgB,QAAM;IAACC,SAAAA;KAClB,gBAAAlB,OAAA,cAACmB,QAAAA;IAAOL,eAAY;IAAwBM,SAAQ;IAAUC,UAAU,CAAC3B;KACtEF,EAAE,gBAAA,CAAA,CAAA,CAAA,CAAA;AAMf;AAEA,IAAMiB,OAAO,CAAC,EAAElB,KAAI,MAAoB;AACtC,QAAM+B,QAAQ/B,KAAKgC,MAAM,GAAA;AACzB,SACE,gBAAAvB,OAAA,cAACU,OAAAA;IAAIJ,WAAU;KACb,gBAAAN,OAAA,cAACO,WAAUiB,YAAU;IAACC,OAAOlC;IAAMY,YAAW;MAC9C,gBAAAH,OAAA,cAACU,OAAAA;IAAIJ,WAAU;KACZgB,MAAMI,IAAI,CAACC,MAAMC,MAChB,gBAAA5B,OAAA,cAACU,OAAAA;IAAImB,KAAKD;IAAGtB,WAAU;KACrB,gBAAAN,OAAA,cAACU,OAAAA;IAAIJ,WAAU;KAAwCsB,IAAI,CAAA,GAC3D,gBAAA5B,OAAA,cAACU,OAAAA;IAAIJ,WAAU;KAAWqB,IAAAA,CAAAA,CAAAA,CAAAA,CAAAA;AAMtC;",
6
+ "names": ["React", "useCallback", "createIntent", "LayoutAction", "useIntentDispatcher", "useClient", "Clipboard", "Dialog", "IdentityPanel", "IDENTITY_DIALOG", "CLIENT_PLUGIN", "IdentityDialog", "props", "dispatchPromise", "dispatch", "useIntentDispatcher", "client", "useClient", "handleDone", "useCallback", "createIntent", "LayoutAction", "SetLayout", "element", "state", "handleResetStorage", "reset", "ClientAction", "ResetStorage", "handleRecover", "target", "handleJoinNewIdentity", "Dialog", "Content", "Clipboard", "Provider", "IdentityPanel", "doneActionParent", "Close", "asChild", "onDone", "onResetStorage", "onRecover", "onJoinNewIdentity", "React", "useCallback", "createIntent", "LayoutAction", "useIntentDispatcher", "ObservabilityAction", "Dialog", "JoinPanel", "JOIN_DIALOG", "CLIENT_PLUGIN", "JoinDialog", "props", "dispatchPromise", "dispatch", "useIntentDispatcher", "handleCancelResetStorage", "useCallback", "createIntent", "ClientAction", "ShareIdentity", "handleDone", "result", "identityKey", "Promise", "all", "LayoutAction", "SetLayout", "element", "state", "ObservabilityAction", "SendEvent", "name", "initialDisposition", "React", "Dialog", "Content", "JoinPanel", "mode", "exitActionParent", "Close", "asChild", "doneActionParent", "onCancelResetStorage", "onDone", "React", "useCallback", "useState", "AlertDialog", "Button", "Clipboard", "Input", "useTranslation", "RECOVER_CODE_DIALOG", "CLIENT_PLUGIN", "RecoveryCodeDialog", "code", "t", "useTranslation", "confirmation", "setConfirmation", "useState", "handleConfirmation", "useCallback", "checked", "React", "AlertDialog", "Content", "classNames", "Title", "p", "className", "Clipboard", "Provider", "Code", "div", "Input", "Root", "Checkbox", "data-testid", "onCheckedChange", "Label", "Action", "asChild", "Button", "variant", "disabled", "words", "split", "IconButton", "value", "map", "word", "i", "key"]
7
+ }
@@ -0,0 +1,14 @@
1
+ import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
2
+
3
+ // packages/plugins/plugin-client/src/meta.ts
4
+ var CLIENT_PLUGIN = "dxos.org/plugin/client";
5
+ var meta = {
6
+ id: CLIENT_PLUGIN,
7
+ name: "Client"
8
+ };
9
+
10
+ export {
11
+ CLIENT_PLUGIN,
12
+ meta
13
+ };
14
+ //# sourceMappingURL=chunk-HO7WDE7C.mjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/meta.ts"],
4
+ "sourcesContent": ["//\n// Copyright 2023 DXOS.org\n//\n\nimport { type PluginMeta } from '@dxos/app-framework';\n\nexport const CLIENT_PLUGIN = 'dxos.org/plugin/client';\n\nexport const meta = {\n id: CLIENT_PLUGIN,\n name: 'Client',\n} satisfies PluginMeta;\n"],
5
+ "mappings": ";;;AAMO,IAAMA,gBAAgB;AAEtB,IAAMC,OAAO;EAClBC,IAAIF;EACJG,MAAM;AACR;",
6
+ "names": ["CLIENT_PLUGIN", "meta", "id", "name"]
7
+ }
@@ -0,0 +1,18 @@
1
+ import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
2
+ import {
3
+ CLIENT_PLUGIN
4
+ } from "./chunk-HO7WDE7C.mjs";
5
+
6
+ // packages/plugins/plugin-client/src/capabilities/capabilities.ts
7
+ import { defineCapability } from "@dxos/app-framework";
8
+ var ClientCapabilities;
9
+ (function(ClientCapabilities2) {
10
+ ClientCapabilities2.Client = defineCapability(`${CLIENT_PLUGIN}/capability/client`);
11
+ ClientCapabilities2.Schema = defineCapability(`${CLIENT_PLUGIN}/capability/schema`);
12
+ ClientCapabilities2.SystemSchema = defineCapability(`${CLIENT_PLUGIN}/capability/system-schema`);
13
+ })(ClientCapabilities || (ClientCapabilities = {}));
14
+
15
+ export {
16
+ ClientCapabilities
17
+ };
18
+ //# sourceMappingURL=chunk-OBGRL3DF.mjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/capabilities/capabilities.ts"],
4
+ "sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport { defineCapability } from '@dxos/app-framework';\nimport { type TypedObject } from '@dxos/echo-schema';\nimport { type Client } from '@dxos/react-client';\n\nimport { CLIENT_PLUGIN } from '../meta';\n\nexport namespace ClientCapabilities {\n export const Client = defineCapability<Client>(`${CLIENT_PLUGIN}/capability/client`);\n export const Schema = defineCapability<TypedObject[]>(`${CLIENT_PLUGIN}/capability/schema`);\n export const SystemSchema = defineCapability<TypedObject[]>(`${CLIENT_PLUGIN}/capability/system-schema`);\n}\n"],
5
+ "mappings": ";;;;;;AAIA,SAASA,wBAAwB;;UAMhBC,qBAAAA;sBACFC,SAASC,iBAAyB,GAAGC,aAAAA,oBAAiC;sBACtEC,SAASF,iBAAgC,GAAGC,aAAAA,oBAAiC;sBAC7EE,eAAeH,iBAAgC,GAAGC,aAAAA,2BAAwC;AACzG,GAJiBH,uBAAAA,qBAAAA,CAAAA,EAAAA;",
6
+ "names": ["defineCapability", "ClientCapabilities", "Client", "defineCapability", "CLIENT_PLUGIN", "Schema", "SystemSchema"]
7
+ }
@@ -0,0 +1,46 @@
1
+ import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
2
+ import {
3
+ ClientEvents
4
+ } from "./chunk-73M5MK5Q.mjs";
5
+ import {
6
+ ClientCapabilities
7
+ } from "./chunk-OBGRL3DF.mjs";
8
+ import "./chunk-HO7WDE7C.mjs";
9
+
10
+ // packages/plugins/plugin-client/src/capabilities/client.ts
11
+ import { contributes } from "@dxos/app-framework";
12
+ import { Config, Defaults, Envs, Local, Storage } from "@dxos/config";
13
+ import { Client } from "@dxos/react-client";
14
+ var client_default = async ({ context, onClientInitialized, ...options }) => {
15
+ const config = new Config(await Storage(), Envs(), Local(), Defaults());
16
+ const client = new Client({
17
+ config,
18
+ ...options
19
+ });
20
+ await client.initialize();
21
+ await onClientInitialized?.(context, client);
22
+ const systemSchemas = Array.from(new Set(context.requestCapabilities(ClientCapabilities.SystemSchema).flat()));
23
+ const schemas = Array.from(new Set(context.requestCapabilities(ClientCapabilities.Schema).flat()));
24
+ client.addTypes(systemSchemas);
25
+ client.addTypes(schemas);
26
+ client.reloaded.on(() => {
27
+ client.halo.identity.subscribe(async (identity) => {
28
+ if (identity) {
29
+ window.location.href = window.location.origin;
30
+ }
31
+ });
32
+ });
33
+ const subscription = client.spaces.isReady.subscribe(async (ready) => {
34
+ if (ready) {
35
+ await context.activate(ClientEvents.SpacesReady);
36
+ }
37
+ });
38
+ return contributes(ClientCapabilities.Client, client, async () => {
39
+ subscription.unsubscribe();
40
+ await client.destroy();
41
+ });
42
+ };
43
+ export {
44
+ client_default as default
45
+ };
46
+ //# sourceMappingURL=client-K52NWOUN.mjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/capabilities/client.ts"],
4
+ "sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport { contributes, type PluginsContext } from '@dxos/app-framework';\nimport { Config, Defaults, Envs, Local, Storage } from '@dxos/config';\nimport { Client } from '@dxos/react-client';\n\nimport { ClientCapabilities } from './capabilities';\nimport { ClientEvents } from '../events';\nimport { type ClientPluginOptions } from '../types';\n\ntype ClientCapabilityOptions = Omit<ClientPluginOptions, 'appKey' | 'invitationUrl' | 'invitationParam' | 'onReset'> & {\n context: PluginsContext;\n};\n\nexport default async ({ context, onClientInitialized, ...options }: ClientCapabilityOptions) => {\n const config = new Config(await Storage(), Envs(), Local(), Defaults());\n const client = new Client({ config, ...options });\n\n await client.initialize();\n await onClientInitialized?.(context, client);\n\n const systemSchemas = Array.from(new Set(context.requestCapabilities(ClientCapabilities.SystemSchema).flat()));\n const schemas = Array.from(new Set(context.requestCapabilities(ClientCapabilities.Schema).flat()));\n client.addTypes(systemSchemas);\n client.addTypes(schemas);\n\n // TODO(wittjosiah): Remove. This is a hack to get the app to boot with the new identity after a reset.\n client.reloaded.on(() => {\n client.halo.identity.subscribe(async (identity) => {\n if (identity) {\n window.location.href = window.location.origin;\n }\n });\n });\n\n const subscription = client.spaces.isReady.subscribe(async (ready) => {\n if (ready) {\n await context.activate(ClientEvents.SpacesReady);\n }\n });\n\n return contributes(ClientCapabilities.Client, client, async () => {\n subscription.unsubscribe();\n await client.destroy();\n });\n};\n"],
5
+ "mappings": ";;;;;;;;;;AAIA,SAASA,mBAAwC;AACjD,SAASC,QAAQC,UAAUC,MAAMC,OAAOC,eAAe;AACvD,SAASC,cAAc;AAUvB,IAAA,iBAAe,OAAO,EAAEC,SAASC,qBAAqB,GAAGC,QAAAA,MAAkC;AACzF,QAAMC,SAAS,IAAIC,OAAO,MAAMC,QAAAA,GAAWC,KAAAA,GAAQC,MAAAA,GAASC,SAAAA,CAAAA;AAC5D,QAAMC,SAAS,IAAIC,OAAO;IAAEP;IAAQ,GAAGD;EAAQ,CAAA;AAE/C,QAAMO,OAAOE,WAAU;AACvB,QAAMV,sBAAsBD,SAASS,MAAAA;AAErC,QAAMG,gBAAgBC,MAAMC,KAAK,IAAIC,IAAIf,QAAQgB,oBAAoBC,mBAAmBC,YAAY,EAAEC,KAAI,CAAA,CAAA;AAC1G,QAAMC,UAAUP,MAAMC,KAAK,IAAIC,IAAIf,QAAQgB,oBAAoBC,mBAAmBI,MAAM,EAAEF,KAAI,CAAA,CAAA;AAC9FV,SAAOa,SAASV,aAAAA;AAChBH,SAAOa,SAASF,OAAAA;AAGhBX,SAAOc,SAASC,GAAG,MAAA;AACjBf,WAAOgB,KAAKC,SAASC,UAAU,OAAOD,aAAAA;AACpC,UAAIA,UAAU;AACZE,eAAOC,SAASC,OAAOF,OAAOC,SAASE;MACzC;IACF,CAAA;EACF,CAAA;AAEA,QAAMC,eAAevB,OAAOwB,OAAOC,QAAQP,UAAU,OAAOQ,UAAAA;AAC1D,QAAIA,OAAO;AACT,YAAMnC,QAAQoC,SAASC,aAAaC,WAAW;IACjD;EACF,CAAA;AAEA,SAAOC,YAAYtB,mBAAmBP,QAAQD,QAAQ,YAAA;AACpDuB,iBAAaQ,YAAW;AACxB,UAAM/B,OAAOgC,QAAO;EACtB,CAAA;AACF;",
6
+ "names": ["contributes", "Config", "Defaults", "Envs", "Local", "Storage", "Client", "context", "onClientInitialized", "options", "config", "Config", "Storage", "Envs", "Local", "Defaults", "client", "Client", "initialize", "systemSchemas", "Array", "from", "Set", "requestCapabilities", "ClientCapabilities", "SystemSchema", "flat", "schemas", "Schema", "addTypes", "reloaded", "on", "halo", "identity", "subscribe", "window", "location", "href", "origin", "subscription", "spaces", "isReady", "ready", "activate", "ClientEvents", "SpacesReady", "contributes", "unsubscribe", "destroy"]
7
+ }