@dxos/plugin-client 0.8.2-main.fbd8ed0 → 0.8.2-staging.7ac8446
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.
- package/dist/lib/browser/{app-graph-builder-ROTCC3C4.mjs → app-graph-builder-WAS4YZNA.mjs} +31 -35
- package/dist/lib/browser/app-graph-builder-WAS4YZNA.mjs.map +7 -0
- package/dist/lib/browser/chunk-AN7FJKIJ.mjs +105 -0
- package/dist/lib/browser/chunk-AN7FJKIJ.mjs.map +7 -0
- package/dist/lib/browser/{chunk-7OW22D2O.mjs → chunk-XZ4TQC56.mjs} +25 -29
- package/dist/lib/browser/chunk-XZ4TQC56.mjs.map +7 -0
- package/dist/lib/browser/{client-ICXXK55V.mjs → client-LV67Q3R7.mjs} +1 -1
- package/dist/lib/browser/client-LV67Q3R7.mjs.map +7 -0
- package/dist/lib/browser/index.mjs +9 -9
- package/dist/lib/browser/index.mjs.map +3 -3
- package/dist/lib/browser/{intent-resolver-L4STUWGK.mjs → intent-resolver-NCISOZW4.mjs} +10 -10
- package/dist/lib/browser/intent-resolver-NCISOZW4.mjs.map +7 -0
- package/dist/lib/browser/meta.json +1 -1
- package/dist/lib/browser/migrations-3DWFOL5Q.mjs +21 -0
- package/dist/lib/browser/migrations-3DWFOL5Q.mjs.map +7 -0
- package/dist/lib/browser/{react-surface-VXFG7BEM.mjs → react-surface-J7SZR2J6.mjs} +3 -3
- package/dist/lib/browser/schema-JQAT6Q7S.mjs +23 -0
- package/dist/lib/browser/schema-JQAT6Q7S.mjs.map +7 -0
- package/dist/lib/browser/types.mjs +1 -1
- package/dist/lib/node/{app-graph-builder-DOHFMHXU.cjs → app-graph-builder-PXOJZJO5.cjs} +40 -44
- package/dist/lib/node/app-graph-builder-PXOJZJO5.cjs.map +7 -0
- package/dist/lib/node/{chunk-FABH7MJ3.cjs → chunk-3JE5BFCT.cjs} +25 -29
- package/dist/lib/node/chunk-3JE5BFCT.cjs.map +7 -0
- package/dist/lib/node/{chunk-J5SQ5Q22.cjs → chunk-FROKBEVH.cjs} +47 -47
- package/dist/lib/node/chunk-FROKBEVH.cjs.map +7 -0
- package/dist/lib/node/{client-OUBG63HJ.cjs → client-BKTGRBYM.cjs} +4 -4
- package/dist/lib/node/client-BKTGRBYM.cjs.map +7 -0
- package/dist/lib/node/index.cjs +9 -9
- package/dist/lib/node/index.cjs.map +3 -3
- package/dist/lib/node/{intent-resolver-IDLAVEHS.cjs → intent-resolver-U2576ALY.cjs} +29 -29
- package/dist/lib/node/intent-resolver-U2576ALY.cjs.map +7 -0
- package/dist/lib/node/meta.json +1 -1
- package/dist/lib/node/{migrations-ZI52SX4M.cjs → migrations-TGNI4FVL.cjs} +9 -11
- package/dist/lib/node/migrations-TGNI4FVL.cjs.map +7 -0
- package/dist/lib/node/{react-surface-UGXE6OAD.cjs → react-surface-BSTIXMER.cjs} +24 -24
- package/dist/lib/node/{schema-defs-BYGBDKOU.cjs → schema-INQ72F54.cjs} +11 -13
- package/dist/lib/node/schema-INQ72F54.cjs.map +7 -0
- package/dist/lib/node/types.cjs +3 -3
- package/dist/lib/node/types.cjs.map +1 -1
- package/dist/lib/node-esm/{app-graph-builder-XMXJG5YT.mjs → app-graph-builder-KIN6NWFI.mjs} +31 -35
- package/dist/lib/node-esm/app-graph-builder-KIN6NWFI.mjs.map +7 -0
- package/dist/lib/node-esm/chunk-AD5W5QCQ.mjs +106 -0
- package/dist/lib/node-esm/chunk-AD5W5QCQ.mjs.map +7 -0
- package/dist/lib/node-esm/{chunk-34X2AMVA.mjs → chunk-LZN2UNN7.mjs} +25 -29
- package/dist/lib/node-esm/chunk-LZN2UNN7.mjs.map +7 -0
- package/dist/lib/node-esm/{client-YJNEHNUV.mjs → client-QQD6WFOB.mjs} +1 -1
- package/dist/lib/node-esm/client-QQD6WFOB.mjs.map +7 -0
- package/dist/lib/node-esm/index.mjs +9 -9
- package/dist/lib/node-esm/index.mjs.map +3 -3
- package/dist/lib/node-esm/{intent-resolver-73FZIXX5.mjs → intent-resolver-G25U4UGI.mjs} +10 -10
- package/dist/lib/node-esm/intent-resolver-G25U4UGI.mjs.map +7 -0
- package/dist/lib/node-esm/meta.json +1 -1
- package/dist/lib/node-esm/{migrations-GHO52HKW.mjs → migrations-IVGATGZR.mjs} +6 -8
- package/dist/lib/node-esm/migrations-IVGATGZR.mjs.map +7 -0
- package/dist/lib/node-esm/{react-surface-R65DYUV6.mjs → react-surface-ZPI7T4EM.mjs} +3 -3
- package/dist/lib/node-esm/schema-OK7HY3JJ.mjs +24 -0
- package/dist/lib/node-esm/schema-OK7HY3JJ.mjs.map +7 -0
- package/dist/lib/node-esm/types.mjs +1 -1
- package/dist/types/src/ClientPlugin.d.ts.map +1 -1
- package/dist/types/src/capabilities/app-graph-builder.d.ts +179 -2
- package/dist/types/src/capabilities/app-graph-builder.d.ts.map +1 -1
- package/dist/types/src/capabilities/client.d.ts +2 -2
- package/dist/types/src/capabilities/client.d.ts.map +1 -1
- package/dist/types/src/capabilities/index.d.ts +181 -5
- package/dist/types/src/capabilities/index.d.ts.map +1 -1
- package/dist/types/src/capabilities/intent-resolver.d.ts +2 -2
- package/dist/types/src/capabilities/intent-resolver.d.ts.map +1 -1
- package/dist/types/src/capabilities/migrations.d.ts +2 -2
- package/dist/types/src/capabilities/migrations.d.ts.map +1 -1
- package/dist/types/src/capabilities/react-surface.d.ts.map +1 -1
- package/dist/types/src/capabilities/schema.d.ts +4 -0
- package/dist/types/src/capabilities/schema.d.ts.map +1 -0
- package/dist/types/src/components/DevicesContainer.d.ts +3 -4
- package/dist/types/src/components/DevicesContainer.d.ts.map +1 -1
- package/dist/types/src/components/DevicesContainer.stories.d.ts.map +1 -1
- package/dist/types/src/components/JoinDialog.d.ts.map +1 -1
- package/dist/types/src/components/ProfileContainer.d.ts.map +1 -1
- package/dist/types/src/components/RecoveryCodeDialog.d.ts.map +1 -1
- package/dist/types/src/components/RecoveryCredentialsContainer.d.ts.map +1 -1
- package/dist/types/src/components/ResetDialog.d.ts.map +1 -1
- package/dist/types/src/components/ResetDialog.stories.d.ts.map +1 -1
- package/dist/types/src/types.d.ts +53 -53
- package/dist/types/src/types.d.ts.map +1 -1
- package/dist/types/tsconfig.tsbuildinfo +1 -1
- package/package.json +25 -31
- package/src/ClientPlugin.ts +2 -2
- package/src/capabilities/app-graph-builder.ts +76 -94
- package/src/capabilities/client.ts +2 -2
- package/src/capabilities/index.ts +1 -1
- package/src/capabilities/intent-resolver.ts +9 -9
- package/src/capabilities/migrations.ts +11 -14
- package/src/capabilities/schema.ts +26 -0
- package/src/components/DevicesContainer.stories.tsx +3 -7
- package/src/components/DevicesContainer.tsx +61 -85
- package/src/components/ProfileContainer.stories.tsx +1 -1
- package/src/components/ProfileContainer.tsx +21 -30
- package/src/components/RecoveryCodeDialog.stories.tsx +1 -1
- package/src/components/RecoveryCredentialsContainer.stories.tsx +2 -2
- package/src/components/RecoveryCredentialsContainer.tsx +46 -48
- package/src/components/ResetDialog.stories.tsx +1 -7
- package/src/translations.ts +2 -2
- package/src/types.ts +46 -50
- package/dist/lib/browser/app-graph-builder-ROTCC3C4.mjs.map +0 -7
- package/dist/lib/browser/chunk-7OW22D2O.mjs.map +0 -7
- package/dist/lib/browser/chunk-XPHDZ277.mjs +0 -105
- package/dist/lib/browser/chunk-XPHDZ277.mjs.map +0 -7
- package/dist/lib/browser/client-ICXXK55V.mjs.map +0 -7
- package/dist/lib/browser/intent-resolver-L4STUWGK.mjs.map +0 -7
- package/dist/lib/browser/migrations-DYDZ7DVP.mjs +0 -23
- package/dist/lib/browser/migrations-DYDZ7DVP.mjs.map +0 -7
- package/dist/lib/browser/schema-defs-QVXP2JGN.mjs +0 -25
- package/dist/lib/browser/schema-defs-QVXP2JGN.mjs.map +0 -7
- package/dist/lib/node/app-graph-builder-DOHFMHXU.cjs.map +0 -7
- package/dist/lib/node/chunk-FABH7MJ3.cjs.map +0 -7
- package/dist/lib/node/chunk-J5SQ5Q22.cjs.map +0 -7
- package/dist/lib/node/client-OUBG63HJ.cjs.map +0 -7
- package/dist/lib/node/intent-resolver-IDLAVEHS.cjs.map +0 -7
- package/dist/lib/node/migrations-ZI52SX4M.cjs.map +0 -7
- package/dist/lib/node/schema-defs-BYGBDKOU.cjs.map +0 -7
- package/dist/lib/node-esm/app-graph-builder-XMXJG5YT.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-34X2AMVA.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-V6SJNSKG.mjs +0 -106
- package/dist/lib/node-esm/chunk-V6SJNSKG.mjs.map +0 -7
- package/dist/lib/node-esm/client-YJNEHNUV.mjs.map +0 -7
- package/dist/lib/node-esm/intent-resolver-73FZIXX5.mjs.map +0 -7
- package/dist/lib/node-esm/migrations-GHO52HKW.mjs.map +0 -7
- package/dist/lib/node-esm/schema-defs-O4OHIIBN.mjs +0 -26
- package/dist/lib/node-esm/schema-defs-O4OHIIBN.mjs.map +0 -7
- package/dist/types/src/capabilities/schema-defs.d.ts +0 -4
- package/dist/types/src/capabilities/schema-defs.d.ts.map +0 -1
- package/src/capabilities/schema-defs.ts +0 -29
- /package/dist/lib/browser/{react-surface-VXFG7BEM.mjs.map → react-surface-J7SZR2J6.mjs.map} +0 -0
- /package/dist/lib/node/{react-surface-UGXE6OAD.cjs.map → react-surface-BSTIXMER.cjs.map} +0 -0
- /package/dist/lib/node-esm/{react-surface-R65DYUV6.mjs.map → react-surface-ZPI7T4EM.mjs.map} +0 -0
|
@@ -4,51 +4,47 @@ import {
|
|
|
4
4
|
import {
|
|
5
5
|
Account,
|
|
6
6
|
ClientAction
|
|
7
|
-
} from "./chunk-
|
|
7
|
+
} from "./chunk-AN7FJKIJ.mjs";
|
|
8
8
|
import {
|
|
9
9
|
CLIENT_PLUGIN
|
|
10
10
|
} from "./chunk-MCEXD5XH.mjs";
|
|
11
11
|
|
|
12
12
|
// packages/plugins/plugin-client/src/capabilities/app-graph-builder.ts
|
|
13
|
-
import { Rx } from "@effect-rx/rx-react";
|
|
14
|
-
import { Option, pipe } from "effect";
|
|
15
13
|
import { createIntent } from "@dxos/app-framework";
|
|
16
14
|
import { Capabilities, contributes } from "@dxos/app-framework";
|
|
17
|
-
import { createExtension,
|
|
15
|
+
import { createExtension, toSignal } from "@dxos/plugin-graph";
|
|
18
16
|
import { ConnectionState } from "@dxos/react-client/mesh";
|
|
19
17
|
var app_graph_builder_default = (context) => contributes(Capabilities.AppGraphBuilder, createExtension({
|
|
20
18
|
id: CLIENT_PLUGIN,
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
}
|
|
35
|
-
],
|
|
36
|
-
icon: "ph--user--regular",
|
|
37
|
-
disposition: "menu",
|
|
38
|
-
keyBinding: {
|
|
39
|
-
macos: "meta+shift+.",
|
|
40
|
-
// TODO(wittjosiah): Test on windows to see if it behaves the same as linux.
|
|
41
|
-
windows: "alt+shift+.",
|
|
42
|
-
linux: "alt+shift+>"
|
|
19
|
+
filter: (node) => node.id === "root",
|
|
20
|
+
actions: () => [
|
|
21
|
+
{
|
|
22
|
+
id: `${CLIENT_PLUGIN}/open-user-account`,
|
|
23
|
+
data: async () => {
|
|
24
|
+
const { dispatchPromise: dispatch } = context.requestCapability(Capabilities.IntentDispatcher);
|
|
25
|
+
await dispatch(createIntent(ClientAction.ShareIdentity));
|
|
26
|
+
},
|
|
27
|
+
properties: {
|
|
28
|
+
label: [
|
|
29
|
+
"open user account label",
|
|
30
|
+
{
|
|
31
|
+
ns: CLIENT_PLUGIN
|
|
43
32
|
}
|
|
33
|
+
],
|
|
34
|
+
icon: "ph--user--regular",
|
|
35
|
+
keyBinding: {
|
|
36
|
+
macos: "meta+shift+.",
|
|
37
|
+
// TODO(wittjosiah): Test on windows to see if it behaves the same as linux.
|
|
38
|
+
windows: "alt+shift+.",
|
|
39
|
+
linux: "alt+shift+>"
|
|
44
40
|
}
|
|
45
41
|
}
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
connector: (
|
|
49
|
-
const client = context.
|
|
50
|
-
const identity =
|
|
51
|
-
const status =
|
|
42
|
+
}
|
|
43
|
+
],
|
|
44
|
+
connector: () => {
|
|
45
|
+
const client = context.requestCapability(ClientCapabilities.Client);
|
|
46
|
+
const identity = client.halo.identity.get();
|
|
47
|
+
const status = toSignal((onChange) => client.mesh.networkStatus.subscribe(() => onChange()).unsubscribe, () => client.mesh.networkStatus.get());
|
|
52
48
|
return [
|
|
53
49
|
{
|
|
54
50
|
id: Account.id,
|
|
@@ -66,7 +62,7 @@ var app_graph_builder_default = (context) => contributes(Capabilities.AppGraphBu
|
|
|
66
62
|
userId: identity?.identityKey.toHex(),
|
|
67
63
|
hue: identity?.profile?.data?.hue,
|
|
68
64
|
emoji: identity?.profile?.data?.emoji,
|
|
69
|
-
status: status
|
|
65
|
+
status: status?.swarm === ConnectionState.OFFLINE ? "error" : "active"
|
|
70
66
|
},
|
|
71
67
|
nodes: [
|
|
72
68
|
{
|
|
@@ -115,9 +111,9 @@ var app_graph_builder_default = (context) => contributes(Capabilities.AppGraphBu
|
|
|
115
111
|
]
|
|
116
112
|
}
|
|
117
113
|
];
|
|
118
|
-
}
|
|
114
|
+
}
|
|
119
115
|
}));
|
|
120
116
|
export {
|
|
121
117
|
app_graph_builder_default as default
|
|
122
118
|
};
|
|
123
|
-
//# sourceMappingURL=app-graph-builder-
|
|
119
|
+
//# sourceMappingURL=app-graph-builder-WAS4YZNA.mjs.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../src/capabilities/app-graph-builder.ts"],
|
|
4
|
+
"sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport { createIntent } from '@dxos/app-framework';\nimport { Capabilities, contributes, type PluginsContext } from '@dxos/app-framework';\nimport { createExtension, toSignal, type Node } from '@dxos/plugin-graph';\nimport { ConnectionState } from '@dxos/react-client/mesh';\n\nimport { ClientCapabilities } from './capabilities';\nimport { CLIENT_PLUGIN } from '../meta';\nimport { Account, ClientAction } from '../types';\n\nexport default (context: PluginsContext) =>\n contributes(\n Capabilities.AppGraphBuilder,\n createExtension({\n id: CLIENT_PLUGIN,\n filter: (node): node is Node<null> => node.id === 'root',\n actions: () => [\n {\n id: `${CLIENT_PLUGIN}/open-user-account`,\n data: async () => {\n const { dispatchPromise: dispatch } = context.requestCapability(Capabilities.IntentDispatcher);\n await dispatch(createIntent(ClientAction.ShareIdentity));\n },\n properties: {\n label: ['open user account label', { ns: CLIENT_PLUGIN }],\n icon: 'ph--user--regular',\n keyBinding: {\n macos: 'meta+shift+.',\n // TODO(wittjosiah): Test on windows to see if it behaves the same as linux.\n windows: 'alt+shift+.',\n linux: 'alt+shift+>',\n },\n },\n },\n ],\n connector: () => {\n const client = context.requestCapability(ClientCapabilities.Client);\n const identity = client.halo.identity.get();\n const status = toSignal(\n (onChange) => client.mesh.networkStatus.subscribe(() => onChange()).unsubscribe,\n () => client.mesh.networkStatus.get(),\n );\n\n return [\n {\n id: Account.id,\n type: CLIENT_PLUGIN,\n properties: {\n label: ['account label', { ns: CLIENT_PLUGIN }],\n icon: 'ph--user--regular',\n disposition: 'user-account',\n // NOTE: This currently needs to be the identity key because the fallback is generated from hex.\n userId: identity?.identityKey.toHex(),\n hue: identity?.profile?.data?.hue,\n emoji: identity?.profile?.data?.emoji,\n status: status?.swarm === ConnectionState.OFFLINE ? 'error' : 'active',\n },\n nodes: [\n {\n id: Account.Profile,\n data: Account.Profile,\n type: CLIENT_PLUGIN,\n properties: {\n label: ['profile label', { ns: CLIENT_PLUGIN }],\n icon: 'ph--user--regular',\n },\n },\n {\n id: Account.Devices,\n data: Account.Devices,\n type: CLIENT_PLUGIN,\n properties: {\n label: ['devices label', { ns: CLIENT_PLUGIN }],\n icon: 'ph--devices--regular',\n testId: 'clientPlugin.devices',\n },\n },\n {\n id: Account.Security,\n data: Account.Security,\n type: CLIENT_PLUGIN,\n properties: {\n label: ['security label', { ns: CLIENT_PLUGIN }],\n icon: 'ph--key--regular',\n },\n },\n ],\n },\n ];\n },\n }),\n );\n"],
|
|
5
|
+
"mappings": ";;;;;;;;;;;;AAIA,SAASA,oBAAoB;AAC7B,SAASC,cAAcC,mBAAwC;AAC/D,SAASC,iBAAiBC,gBAA2B;AACrD,SAASC,uBAAuB;AAMhC,IAAA,4BAAe,CAACC,YACdC,YACEC,aAAaC,iBACbC,gBAAgB;EACdC,IAAIC;EACJC,QAAQ,CAACC,SAA6BA,KAAKH,OAAO;EAClDI,SAAS,MAAM;IACb;MACEJ,IAAI,GAAGC,aAAAA;MACPI,MAAM,YAAA;AACJ,cAAM,EAAEC,iBAAiBC,SAAQ,IAAKZ,QAAQa,kBAAkBX,aAAaY,gBAAgB;AAC7F,cAAMF,SAASG,aAAaC,aAAaC,aAAa,CAAA;MACxD;MACAC,YAAY;QACVC,OAAO;UAAC;UAA2B;YAAEC,IAAId;UAAc;;QACvDe,MAAM;QACNC,YAAY;UACVC,OAAO;;UAEPC,SAAS;UACTC,OAAO;QACT;MACF;IACF;;EAEFC,WAAW,MAAA;AACT,UAAMC,SAAS3B,QAAQa,kBAAkBe,mBAAmBC,MAAM;AAClE,UAAMC,WAAWH,OAAOI,KAAKD,SAASE,IAAG;AACzC,UAAMC,SAASC,SACb,CAACC,aAAaR,OAAOS,KAAKC,cAAcC,UAAU,MAAMH,SAAAA,CAAAA,EAAYI,aACpE,MAAMZ,OAAOS,KAAKC,cAAcL,IAAG,CAAA;AAGrC,WAAO;MACL;QACE3B,IAAImC,QAAQnC;QACZoC,MAAMnC;QACNY,YAAY;UACVC,OAAO;YAAC;YAAiB;cAAEC,IAAId;YAAc;;UAC7Ce,MAAM;UACNqB,aAAa;;UAEbC,QAAQb,UAAUc,YAAYC,MAAAA;UAC9BC,KAAKhB,UAAUiB,SAASrC,MAAMoC;UAC9BE,OAAOlB,UAAUiB,SAASrC,MAAMsC;UAChCf,QAAQA,QAAQgB,UAAUC,gBAAgBC,UAAU,UAAU;QAChE;QACAC,OAAO;UACL;YACE/C,IAAImC,QAAQa;YACZ3C,MAAM8B,QAAQa;YACdZ,MAAMnC;YACNY,YAAY;cACVC,OAAO;gBAAC;gBAAiB;kBAAEC,IAAId;gBAAc;;cAC7Ce,MAAM;YACR;UACF;UACA;YACEhB,IAAImC,QAAQc;YACZ5C,MAAM8B,QAAQc;YACdb,MAAMnC;YACNY,YAAY;cACVC,OAAO;gBAAC;gBAAiB;kBAAEC,IAAId;gBAAc;;cAC7Ce,MAAM;cACNkC,QAAQ;YACV;UACF;UACA;YACElD,IAAImC,QAAQgB;YACZ9C,MAAM8B,QAAQgB;YACdf,MAAMnC;YACNY,YAAY;cACVC,OAAO;gBAAC;gBAAkB;kBAAEC,IAAId;gBAAc;;cAC9Ce,MAAM;YACR;UACF;;MAEJ;;EAEJ;AACF,CAAA,CAAA;",
|
|
6
|
+
"names": ["createIntent", "Capabilities", "contributes", "createExtension", "toSignal", "ConnectionState", "context", "contributes", "Capabilities", "AppGraphBuilder", "createExtension", "id", "CLIENT_PLUGIN", "filter", "node", "actions", "data", "dispatchPromise", "dispatch", "requestCapability", "IntentDispatcher", "createIntent", "ClientAction", "ShareIdentity", "properties", "label", "ns", "icon", "keyBinding", "macos", "windows", "linux", "connector", "client", "ClientCapabilities", "Client", "identity", "halo", "get", "status", "toSignal", "onChange", "mesh", "networkStatus", "subscribe", "unsubscribe", "Account", "type", "disposition", "userId", "identityKey", "toHex", "hue", "profile", "emoji", "swarm", "ConnectionState", "OFFLINE", "nodes", "Profile", "Devices", "testId", "Security"]
|
|
7
|
+
}
|
|
@@ -0,0 +1,105 @@
|
|
|
1
|
+
import {
|
|
2
|
+
CLIENT_PLUGIN
|
|
3
|
+
} from "./chunk-MCEXD5XH.mjs";
|
|
4
|
+
|
|
5
|
+
// packages/plugins/plugin-client/src/types.ts
|
|
6
|
+
import { S } from "@dxos/echo-schema";
|
|
7
|
+
import { PublicKey } from "@dxos/react-client";
|
|
8
|
+
var IdentitySchema = S.Struct({
|
|
9
|
+
identityKey: S.instanceOf(PublicKey),
|
|
10
|
+
spaceKey: S.optional(S.instanceOf(PublicKey)),
|
|
11
|
+
profile: S.optional(S.Struct({
|
|
12
|
+
displayName: S.optional(S.String),
|
|
13
|
+
avatarCid: S.optional(S.String),
|
|
14
|
+
data: S.optional(S.Record({
|
|
15
|
+
key: S.String,
|
|
16
|
+
value: S.Any
|
|
17
|
+
}))
|
|
18
|
+
}))
|
|
19
|
+
});
|
|
20
|
+
var CLIENT_ACTION = `${CLIENT_PLUGIN}/action`;
|
|
21
|
+
var ClientAction;
|
|
22
|
+
(function(ClientAction2) {
|
|
23
|
+
class CreateIdentity extends S.TaggedClass()(`${CLIENT_ACTION}/create-identity`, {
|
|
24
|
+
input: S.Struct({
|
|
25
|
+
displayName: S.optional(S.String)
|
|
26
|
+
}),
|
|
27
|
+
output: IdentitySchema
|
|
28
|
+
}) {
|
|
29
|
+
}
|
|
30
|
+
ClientAction2.CreateIdentity = CreateIdentity;
|
|
31
|
+
class JoinIdentity extends S.TaggedClass()(`${CLIENT_ACTION}/join-identity`, {
|
|
32
|
+
input: S.Struct({
|
|
33
|
+
invitationCode: S.optional(S.String)
|
|
34
|
+
}),
|
|
35
|
+
output: S.Void
|
|
36
|
+
}) {
|
|
37
|
+
}
|
|
38
|
+
ClientAction2.JoinIdentity = JoinIdentity;
|
|
39
|
+
class ShareIdentity extends S.TaggedClass()(`${CLIENT_ACTION}/share-identity`, {
|
|
40
|
+
input: S.Void,
|
|
41
|
+
output: S.Void
|
|
42
|
+
}) {
|
|
43
|
+
}
|
|
44
|
+
ClientAction2.ShareIdentity = ShareIdentity;
|
|
45
|
+
class RecoverIdentity extends S.TaggedClass()(`${CLIENT_ACTION}/recover-identity`, {
|
|
46
|
+
input: S.Void,
|
|
47
|
+
output: S.Void
|
|
48
|
+
}) {
|
|
49
|
+
}
|
|
50
|
+
ClientAction2.RecoverIdentity = RecoverIdentity;
|
|
51
|
+
class ResetStorage extends S.TaggedClass()(`${CLIENT_ACTION}/reset-storage`, {
|
|
52
|
+
input: S.Struct({
|
|
53
|
+
mode: S.optional(S.String)
|
|
54
|
+
}),
|
|
55
|
+
output: S.Void
|
|
56
|
+
}) {
|
|
57
|
+
}
|
|
58
|
+
ClientAction2.ResetStorage = ResetStorage;
|
|
59
|
+
class CreateAgent extends S.TaggedClass()(`${CLIENT_ACTION}/create-agent`, {
|
|
60
|
+
input: S.Void,
|
|
61
|
+
output: S.Void
|
|
62
|
+
}) {
|
|
63
|
+
}
|
|
64
|
+
ClientAction2.CreateAgent = CreateAgent;
|
|
65
|
+
class CreateRecoveryCode extends S.TaggedClass()(`${CLIENT_ACTION}/create-recovery-code`, {
|
|
66
|
+
input: S.Void,
|
|
67
|
+
output: S.Void
|
|
68
|
+
}) {
|
|
69
|
+
}
|
|
70
|
+
ClientAction2.CreateRecoveryCode = CreateRecoveryCode;
|
|
71
|
+
class CreatePasskey extends S.TaggedClass()(`${CLIENT_ACTION}/create-passkey`, {
|
|
72
|
+
input: S.Void,
|
|
73
|
+
output: S.Void
|
|
74
|
+
}) {
|
|
75
|
+
}
|
|
76
|
+
ClientAction2.CreatePasskey = CreatePasskey;
|
|
77
|
+
class RedeemPasskey extends S.TaggedClass()(`${CLIENT_ACTION}/redeem-passkey`, {
|
|
78
|
+
input: S.Void,
|
|
79
|
+
output: S.Void
|
|
80
|
+
}) {
|
|
81
|
+
}
|
|
82
|
+
ClientAction2.RedeemPasskey = RedeemPasskey;
|
|
83
|
+
class RedeemToken extends S.TaggedClass()(`${CLIENT_ACTION}/redeem-token`, {
|
|
84
|
+
input: S.Struct({
|
|
85
|
+
token: S.String
|
|
86
|
+
}),
|
|
87
|
+
output: S.Void
|
|
88
|
+
}) {
|
|
89
|
+
}
|
|
90
|
+
ClientAction2.RedeemToken = RedeemToken;
|
|
91
|
+
})(ClientAction || (ClientAction = {}));
|
|
92
|
+
var Account;
|
|
93
|
+
(function(Account2) {
|
|
94
|
+
const _id = "dxos.org.plugin.client.account";
|
|
95
|
+
Account2.id = `!${_id}`;
|
|
96
|
+
Account2.Profile = `${_id}.profile`;
|
|
97
|
+
Account2.Devices = `${_id}.devices`;
|
|
98
|
+
Account2.Security = `${_id}.security`;
|
|
99
|
+
})(Account || (Account = {}));
|
|
100
|
+
|
|
101
|
+
export {
|
|
102
|
+
ClientAction,
|
|
103
|
+
Account
|
|
104
|
+
};
|
|
105
|
+
//# sourceMappingURL=chunk-AN7FJKIJ.mjs.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../src/types.ts"],
|
|
4
|
+
"sourcesContent": ["//\n// Copyright 2024 DXOS.org\n//\n\nimport { type PluginsContext } from '@dxos/app-framework';\nimport { S } from '@dxos/echo-schema';\nimport { type Client, PublicKey, type ClientOptions } from '@dxos/react-client';\nimport { type MaybePromise } from '@dxos/util';\n\nimport { CLIENT_PLUGIN } from './meta';\n\n// TODO(wittjosiah): Factor out. Generate?\nconst IdentitySchema = S.Struct({\n identityKey: S.instanceOf(PublicKey),\n spaceKey: S.optional(S.instanceOf(PublicKey)),\n profile: S.optional(\n S.Struct({\n displayName: S.optional(S.String),\n avatarCid: S.optional(S.String),\n data: S.optional(S.Record({ key: S.String, value: S.Any })),\n }),\n ),\n});\n\nconst CLIENT_ACTION = `${CLIENT_PLUGIN}/action`;\nexport namespace ClientAction {\n export class CreateIdentity extends S.TaggedClass<CreateIdentity>()(`${CLIENT_ACTION}/create-identity`, {\n input: S.Struct({\n displayName: S.optional(S.String),\n }),\n output: IdentitySchema,\n }) {}\n\n export class JoinIdentity extends S.TaggedClass<JoinIdentity>()(`${CLIENT_ACTION}/join-identity`, {\n input: S.Struct({\n invitationCode: S.optional(S.String),\n }),\n output: S.Void,\n }) {}\n\n export class ShareIdentity extends S.TaggedClass<ShareIdentity>()(`${CLIENT_ACTION}/share-identity`, {\n input: S.Void,\n output: S.Void,\n }) {}\n\n export class RecoverIdentity extends S.TaggedClass<RecoverIdentity>()(`${CLIENT_ACTION}/recover-identity`, {\n input: S.Void,\n output: S.Void,\n }) {}\n\n export class ResetStorage extends S.TaggedClass<ResetStorage>()(`${CLIENT_ACTION}/reset-storage`, {\n input: S.Struct({\n mode: S.optional(S.String),\n }),\n output: S.Void,\n }) {}\n\n export class CreateAgent extends S.TaggedClass<CreateAgent>()(`${CLIENT_ACTION}/create-agent`, {\n input: S.Void,\n output: S.Void,\n }) {}\n\n export class CreateRecoveryCode extends S.TaggedClass<CreateRecoveryCode>()(`${CLIENT_ACTION}/create-recovery-code`, {\n input: S.Void,\n output: S.Void,\n }) {}\n\n export class CreatePasskey extends S.TaggedClass<CreatePasskey>()(`${CLIENT_ACTION}/create-passkey`, {\n input: S.Void,\n output: S.Void,\n }) {}\n\n export class RedeemPasskey extends S.TaggedClass<RedeemPasskey>()(`${CLIENT_ACTION}/redeem-passkey`, {\n input: S.Void,\n output: S.Void,\n }) {}\n\n export class RedeemToken extends S.TaggedClass<RedeemToken>()(`${CLIENT_ACTION}/redeem-token`, {\n input: S.Struct({\n token: S.String,\n }),\n output: S.Void,\n }) {}\n}\n\nexport type ClientPluginOptions = ClientOptions & {\n /**\n * Base URL for the invitation link.\n */\n invitationUrl?: string;\n\n /**\n * Query parameter for the invitation code.\n */\n invitationParam?: string;\n\n /**\n * Run after the client has been initialized.\n */\n onClientInitialized?: (context: PluginsContext, client: Client) => MaybePromise<void>;\n\n /**\n * Called when the client is reset.\n */\n onReset?: (params: { target?: string }) => MaybePromise<void>;\n};\n\nexport namespace Account {\n // TODO(wittjosiah): Cannot use slashes in ids until we have a router which decouples ids from url paths.\n const _id = 'dxos.org.plugin.client.account';\n // TODO(wittjosiah): This is a hack to prevent the previous deck from being set for pinned items.\n // Ideally this should be worked into the data model in a generic way.\n export const id = `!${_id}`;\n\n export const Profile = `${_id}.profile`;\n export const Devices = `${_id}.devices`;\n export const Security = `${_id}.security`;\n}\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
|
+
"names": ["S", "PublicKey", "IdentitySchema", "S", "Struct", "identityKey", "instanceOf", "PublicKey", "spaceKey", "optional", "profile", "displayName", "String", "avatarCid", "data", "Record", "key", "value", "Any", "CLIENT_ACTION", "CLIENT_PLUGIN", "ClientAction", "CreateIdentity", "TaggedClass", "input", "output", "JoinIdentity", "invitationCode", "Void", "ShareIdentity", "RecoverIdentity", "ResetStorage", "mode", "CreateAgent", "CreateRecoveryCode", "CreatePasskey", "RedeemPasskey", "RedeemToken", "token", "Account", "_id", "id", "Profile", "Devices", "Security"]
|
|
7
|
+
}
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import {
|
|
2
2
|
ClientAction
|
|
3
|
-
} from "./chunk-
|
|
3
|
+
} from "./chunk-AN7FJKIJ.mjs";
|
|
4
4
|
import {
|
|
5
5
|
CLIENT_PLUGIN
|
|
6
6
|
} from "./chunk-MCEXD5XH.mjs";
|
|
@@ -16,7 +16,7 @@ import { useDevices } from "@dxos/react-client/halo";
|
|
|
16
16
|
import { Invitation, InvitationEncoder } from "@dxos/react-client/invitations";
|
|
17
17
|
import { useNetworkStatus } from "@dxos/react-client/mesh";
|
|
18
18
|
import { Button, Clipboard, IconButton, List, useId, useTranslation } from "@dxos/react-ui";
|
|
19
|
-
import { ControlFrame, ControlFrameItem, ControlGroup, ControlItem,
|
|
19
|
+
import { ControlFrame, ControlFrameItem, ControlGroup, ControlItem, ControlSection } from "@dxos/react-ui-form";
|
|
20
20
|
import { StackItem } from "@dxos/react-ui-stack";
|
|
21
21
|
import { getSize, mx } from "@dxos/react-ui-theme";
|
|
22
22
|
import { AuthCode, Centered, DeviceListItem, Emoji, Viewport } from "@dxos/shell/react";
|
|
@@ -41,8 +41,8 @@ var DevicesContainer = ({ createInvitationUrl }) => {
|
|
|
41
41
|
dispatch
|
|
42
42
|
]);
|
|
43
43
|
return /* @__PURE__ */ React.createElement(Clipboard.Provider, null, /* @__PURE__ */ React.createElement(StackItem.Content, {
|
|
44
|
-
classNames: "block overflow-y-auto"
|
|
45
|
-
}, /* @__PURE__ */ React.createElement(
|
|
44
|
+
classNames: "p-2 block overflow-y-auto"
|
|
45
|
+
}, /* @__PURE__ */ React.createElement(ControlSection, {
|
|
46
46
|
title: t("devices verbose label", {
|
|
47
47
|
ns: CLIENT_PLUGIN
|
|
48
48
|
}),
|
|
@@ -59,7 +59,7 @@ var DevicesContainer = ({ createInvitationUrl }) => {
|
|
|
59
59
|
device,
|
|
60
60
|
connectionState
|
|
61
61
|
});
|
|
62
|
-
}))),
|
|
62
|
+
}))), /* @__PURE__ */ React.createElement(ControlFrameItem, {
|
|
63
63
|
title: "Add device"
|
|
64
64
|
}, /* @__PURE__ */ React.createElement(DeviceInvitation, {
|
|
65
65
|
createInvitationUrl
|
|
@@ -97,7 +97,7 @@ var DevicesContainer = ({ createInvitationUrl }) => {
|
|
|
97
97
|
variant: "destructive",
|
|
98
98
|
onClick: handleJoinNewIdentity,
|
|
99
99
|
"data-testid": "devicesContainer.joinExisting"
|
|
100
|
-
}, t("join new identity label")))))))
|
|
100
|
+
}, t("join new identity label")))))));
|
|
101
101
|
};
|
|
102
102
|
var DeviceInvitation = (props) => {
|
|
103
103
|
const client = useClient();
|
|
@@ -113,7 +113,7 @@ var DeviceInvitation = (props) => {
|
|
|
113
113
|
authCode: invitation3.authCode
|
|
114
114
|
}), void 0, {
|
|
115
115
|
F: __dxlog_file,
|
|
116
|
-
L:
|
|
116
|
+
L: 122,
|
|
117
117
|
S: void 0,
|
|
118
118
|
C: (f, a) => f(...a)
|
|
119
119
|
});
|
|
@@ -222,16 +222,12 @@ var InvitationQR = ({ id, url, onCancel }) => {
|
|
|
222
222
|
}))), /* @__PURE__ */ React.createElement("span", {
|
|
223
223
|
id: qrLabel,
|
|
224
224
|
className: "sr-only"
|
|
225
|
-
}, t("qr label"))
|
|
226
|
-
className: "flex justify-center"
|
|
227
|
-
}, /* @__PURE__ */ React.createElement("div", {
|
|
228
|
-
className: "flex gap-2"
|
|
229
|
-
}, /* @__PURE__ */ React.createElement(Clipboard.Button, {
|
|
225
|
+
}, t("qr label")), /* @__PURE__ */ React.createElement(Clipboard.Button, {
|
|
230
226
|
value: url ?? "never"
|
|
231
|
-
}), /* @__PURE__ */ React.createElement(Button, {
|
|
227
|
+
})), /* @__PURE__ */ React.createElement(Button, {
|
|
232
228
|
variant: "ghost",
|
|
233
229
|
onClick: onCancel
|
|
234
|
-
}, t("cancel label")))
|
|
230
|
+
}, t("cancel label")));
|
|
235
231
|
};
|
|
236
232
|
var InvitationAuthCode = ({ id, code, onCancel }) => {
|
|
237
233
|
const { t } = useTranslation("os");
|
|
@@ -309,13 +305,13 @@ var JoinDialog = (props) => {
|
|
|
309
305
|
};
|
|
310
306
|
|
|
311
307
|
// packages/plugins/plugin-client/src/components/ProfileContainer.tsx
|
|
312
|
-
import { Schema } from "effect";
|
|
308
|
+
import { Schema as S } from "effect";
|
|
313
309
|
import React3, { useCallback as useCallback3, useMemo, useState as useState2 } from "react";
|
|
314
310
|
import { debounce } from "@dxos/async";
|
|
315
311
|
import { useClient as useClient2 } from "@dxos/react-client";
|
|
316
312
|
import { useIdentity } from "@dxos/react-client/halo";
|
|
317
313
|
import { ButtonGroup, Clipboard as Clipboard2, Input, useTranslation as useTranslation3 } from "@dxos/react-ui";
|
|
318
|
-
import { Form, ControlItem as ControlItem2, ControlItemInput, ControlSection as ControlSection2
|
|
314
|
+
import { Form, ControlItem as ControlItem2, ControlItemInput, ControlSection as ControlSection2 } from "@dxos/react-ui-form";
|
|
319
315
|
import { EmojiPickerBlock, HuePicker } from "@dxos/react-ui-pickers";
|
|
320
316
|
import { StackItem as StackItem2 } from "@dxos/react-ui-stack";
|
|
321
317
|
import { hexToHue, hexToEmoji as hexToEmoji2 } from "@dxos/util";
|
|
@@ -428,8 +424,8 @@ var ProfileContainer = () => {
|
|
|
428
424
|
t
|
|
429
425
|
]);
|
|
430
426
|
return /* @__PURE__ */ React3.createElement(StackItem2.Content, {
|
|
431
|
-
classNames: "block overflow-y-auto"
|
|
432
|
-
}, /* @__PURE__ */ React3.createElement(
|
|
427
|
+
classNames: "p-2 block overflow-y-auto"
|
|
428
|
+
}, /* @__PURE__ */ React3.createElement(Clipboard2.Provider, null, /* @__PURE__ */ React3.createElement(ControlSection2, {
|
|
433
429
|
title: t("profile label"),
|
|
434
430
|
description: t("profile description")
|
|
435
431
|
}, /* @__PURE__ */ React3.createElement(Form, {
|
|
@@ -439,19 +435,19 @@ var ProfileContainer = () => {
|
|
|
439
435
|
onSave: handleSave,
|
|
440
436
|
Custom: customElements,
|
|
441
437
|
classNames: 'p-0 container-max-width [&_[role="form"]]:grid [&_[role="form"]]:grid-cols-1 md:[&_[role="form"]]:grid-cols-[1fr_min-content] [&_[role="form"]]:gap-4'
|
|
442
|
-
}))))
|
|
438
|
+
}))));
|
|
443
439
|
};
|
|
444
|
-
var ProfileSchema =
|
|
445
|
-
displayName:
|
|
440
|
+
var ProfileSchema = S.Struct({
|
|
441
|
+
displayName: S.String.annotations({
|
|
446
442
|
title: "Display name"
|
|
447
443
|
}),
|
|
448
|
-
emoji:
|
|
444
|
+
emoji: S.String.annotations({
|
|
449
445
|
title: "Avatar"
|
|
450
446
|
}),
|
|
451
|
-
hue:
|
|
447
|
+
hue: S.String.annotations({
|
|
452
448
|
title: "Color"
|
|
453
449
|
}),
|
|
454
|
-
did:
|
|
450
|
+
did: S.String.annotations({
|
|
455
451
|
title: "DID"
|
|
456
452
|
})
|
|
457
453
|
});
|
|
@@ -512,7 +508,7 @@ import React5 from "react";
|
|
|
512
508
|
import { createIntent as createIntent3, useIntentDispatcher as useIntentDispatcher3 } from "@dxos/app-framework";
|
|
513
509
|
import { useCredentials } from "@dxos/react-client/halo";
|
|
514
510
|
import { Icon, IconButton as IconButton2, List as List2, ListItem, useTranslation as useTranslation5, Message } from "@dxos/react-ui";
|
|
515
|
-
import { ControlGroup as ControlGroup2, ControlItem as ControlItem3,
|
|
511
|
+
import { ControlGroup as ControlGroup2, ControlItem as ControlItem3, ControlSection as ControlSection3 } from "@dxos/react-ui-form";
|
|
516
512
|
import { StackItem as StackItem3 } from "@dxos/react-ui-stack";
|
|
517
513
|
var MANAGE_CREDENTIALS_DIALOG = `${CLIENT_PLUGIN}/ManageCredentialsDialog`;
|
|
518
514
|
var RecoveryCredentialsContainer = () => {
|
|
@@ -521,8 +517,8 @@ var RecoveryCredentialsContainer = () => {
|
|
|
521
517
|
const credentials = useCredentials();
|
|
522
518
|
const recoveryCredentials = credentials.filter((credential) => credential.subject.assertion["@type"] === "dxos.halo.credentials.IdentityRecovery");
|
|
523
519
|
return /* @__PURE__ */ React5.createElement(StackItem3.Content, {
|
|
524
|
-
classNames: "block overflow-y-auto"
|
|
525
|
-
}, /* @__PURE__ */ React5.createElement(
|
|
520
|
+
classNames: "p-2 block overflow-y-auto"
|
|
521
|
+
}, /* @__PURE__ */ React5.createElement(ControlSection3, {
|
|
526
522
|
title: t("recovery setup dialog title"),
|
|
527
523
|
description: t("recovery setup dialog description")
|
|
528
524
|
}, /* @__PURE__ */ React5.createElement(ControlGroup2, null, /* @__PURE__ */ React5.createElement(ControlItem3, {
|
|
@@ -559,7 +555,7 @@ var RecoveryCredentialsContainer = () => {
|
|
|
559
555
|
}, /* @__PURE__ */ React5.createElement(ListItem.Endcap, null, /* @__PURE__ */ React5.createElement(Icon, {
|
|
560
556
|
icon: "ph--key--regular",
|
|
561
557
|
size: 5
|
|
562
|
-
})), /* @__PURE__ */ React5.createElement(ListItem.Heading, null, credential.issuanceDate.toLocaleString()))))))
|
|
558
|
+
})), /* @__PURE__ */ React5.createElement(ListItem.Heading, null, credential.issuanceDate.toLocaleString()))))));
|
|
563
559
|
};
|
|
564
560
|
|
|
565
561
|
// packages/plugins/plugin-client/src/components/ResetDialog.tsx
|
|
@@ -620,4 +616,4 @@ export {
|
|
|
620
616
|
RESET_DIALOG,
|
|
621
617
|
ResetDialog
|
|
622
618
|
};
|
|
623
|
-
//# sourceMappingURL=chunk-
|
|
619
|
+
//# sourceMappingURL=chunk-XZ4TQC56.mjs.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../src/components/DevicesContainer.tsx", "../../../src/components/JoinDialog.tsx", "../../../src/components/ProfileContainer.tsx", "../../../src/components/RecoveryCodeDialog.tsx", "../../../src/components/RecoveryCredentialsContainer.tsx", "../../../src/components/ResetDialog.tsx"],
|
|
4
|
+
"sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport { Check, X } from '@phosphor-icons/react';\nimport React, { useCallback, useEffect, useState } from 'react';\nimport { QR } from 'react-qr-rounded';\n\nimport { createIntent, useIntentDispatcher } from '@dxos/app-framework';\nimport { log } from '@dxos/log';\nimport { useClient, useMulticastObservable } from '@dxos/react-client';\nimport { type Device, useDevices } from '@dxos/react-client/halo';\nimport { type CancellableInvitationObservable, Invitation, InvitationEncoder } from '@dxos/react-client/invitations';\nimport { useNetworkStatus } from '@dxos/react-client/mesh';\nimport { Button, Clipboard, IconButton, List, useId, useTranslation } from '@dxos/react-ui';\nimport { ControlFrame, ControlFrameItem, ControlGroup, ControlItem, ControlSection } from '@dxos/react-ui-form';\nimport { StackItem } from '@dxos/react-ui-stack';\nimport { getSize, mx } from '@dxos/react-ui-theme';\nimport { AuthCode, Centered, DeviceListItem, Emoji, Viewport } from '@dxos/shell/react';\nimport { hexToEmoji } from '@dxos/util';\n\nimport { CLIENT_PLUGIN } from '../meta';\nimport { ClientAction } from '../types';\n\nexport const DevicesContainer = ({\n createInvitationUrl,\n}: {\n createInvitationUrl: (invitationCode: string) => string;\n}) => {\n const { t } = useTranslation('os');\n const { dispatchPromise: dispatch } = useIntentDispatcher();\n const devices = useDevices();\n const { swarm: connectionState } = useNetworkStatus();\n\n const handleResetStorage = useCallback(() => dispatch(createIntent(ClientAction.ResetStorage)), [dispatch]);\n\n const handleRecover = useCallback(\n () => dispatch(createIntent(ClientAction.ResetStorage, { mode: 'recover' })),\n [dispatch],\n );\n\n const handleJoinNewIdentity = useCallback(\n () => dispatch(createIntent(ClientAction.ResetStorage, { mode: 'join new identity' })),\n [dispatch],\n );\n\n return (\n <Clipboard.Provider>\n <StackItem.Content classNames='p-2 block overflow-y-auto'>\n <ControlSection\n title={t('devices verbose label', { ns: CLIENT_PLUGIN })}\n description={t('devices description', { ns: CLIENT_PLUGIN })}\n >\n <ControlFrame>\n <ControlFrameItem title={t('devices label', { ns: CLIENT_PLUGIN })}>\n <List>\n {devices.map((device: Device) => {\n return (\n <DeviceListItem key={device.deviceKey.toHex()} device={device} connectionState={connectionState} />\n );\n })}\n </List>\n </ControlFrameItem>\n <ControlFrameItem title='Add device'>\n <DeviceInvitation createInvitationUrl={createInvitationUrl} />\n </ControlFrameItem>\n </ControlFrame>\n </ControlSection>\n <ControlSection\n title={t('danger zone title', { ns: CLIENT_PLUGIN })}\n description={t('danger zone description', { ns: CLIENT_PLUGIN })}\n >\n <ControlGroup>\n <ControlItem\n title={t('reset device label')}\n description={t('reset device description', { ns: CLIENT_PLUGIN })}\n >\n <Button variant='destructive' onClick={handleResetStorage} data-testid='devicesContainer.reset'>\n {t('reset device label')}\n </Button>\n </ControlItem>\n <ControlItem\n title={t('recover identity label')}\n description={t('recover identity description', { ns: CLIENT_PLUGIN })}\n >\n <Button variant='destructive' onClick={handleRecover} data-testid='devicesContainer.recover'>\n {t('recover identity label')}\n </Button>\n </ControlItem>\n <ControlItem\n title={t('join new identity label')}\n description={t('join new identity description', { ns: CLIENT_PLUGIN })}\n >\n <Button variant='destructive' onClick={handleJoinNewIdentity} data-testid='devicesContainer.joinExisting'>\n {t('join new identity label')}\n </Button>\n </ControlItem>\n </ControlGroup>\n </ControlSection>\n </StackItem.Content>\n </Clipboard.Provider>\n );\n};\n\ntype DeviceInvitationProps = {\n invitation?: CancellableInvitationObservable;\n createInvitationUrl: (invitationCode: string) => string;\n onInvitationDone: () => void;\n onInvitationCreate: () => void;\n};\n\nconst DeviceInvitation = (props: Pick<DeviceInvitationProps, 'createInvitationUrl'>) => {\n const client = useClient();\n const [invitation, setInvitation] = useState<CancellableInvitationObservable>();\n\n const onInvitationCreate = useCallback(() => {\n const invitation = client.halo.share();\n if (client.config.values.runtime?.app?.env?.DX_ENVIRONMENT !== 'production') {\n const subscription = invitation.subscribe((invitation: Invitation) => {\n const invitationCode = InvitationEncoder.encode(invitation);\n if (invitation.state === Invitation.State.CONNECTING) {\n log.info(JSON.stringify({ invitationCode, authCode: invitation.authCode }));\n subscription.unsubscribe();\n }\n });\n }\n setInvitation(invitation);\n }, [client]);\n\n const onInvitationDone = useCallback(() => {\n setInvitation(undefined);\n }, []);\n\n if (invitation) {\n return <DeviceInvitationImpl {...props} {...{ invitation, onInvitationCreate, onInvitationDone }} />;\n } else {\n return <InvitationSection {...props} {...{ onInvitationCreate, onInvitationDone }} />;\n }\n};\n\nconst DeviceInvitationImpl = ({\n invitation: invitationObservable,\n createInvitationUrl,\n onInvitationDone,\n onInvitationCreate,\n}: DeviceInvitationProps) => {\n const invitation = useMulticastObservable(invitationObservable!);\n const url = createInvitationUrl(InvitationEncoder.encode(invitation));\n\n useEffect(() => {\n if (invitation.state >= Invitation.State.SUCCESS) {\n onInvitationDone();\n }\n }, [invitation.state]);\n\n return <InvitationSection {...invitation} {...{ url, onInvitationDone, onInvitationCreate }} />;\n};\n\ntype InvitationComponentProps = Partial<\n Pick<Invitation, 'authCode' | 'invitationId'> &\n Pick<DeviceInvitationProps, 'onInvitationDone' | 'onInvitationCreate'> & {\n state: number;\n url: string;\n }\n>;\n\nconst InvitationSection = ({\n state = -1,\n authCode,\n invitationId = 'never',\n url = 'never',\n onInvitationDone = () => {},\n onInvitationCreate = () => {},\n}: InvitationComponentProps) => {\n const { t } = useTranslation(CLIENT_PLUGIN);\n const activeView =\n state < 0\n ? 'init'\n : state >= Invitation.State.CANCELLED\n ? 'complete'\n : state >= Invitation.State.READY_FOR_AUTHENTICATION && authCode\n ? 'auth-code'\n : 'qr-code';\n return activeView === 'init' ? (\n <>\n <p className='text-description mbe-2'>{t('add device description')}</p>\n <IconButton\n icon='ph--plus--regular'\n label={t('create device invitation label')}\n disabled={state >= 0}\n classNames='is-full'\n data-testid='devicesContainer.createInvitation'\n onClick={onInvitationCreate}\n />\n </>\n ) : (\n <Viewport.Root activeView={activeView}>\n <Viewport.Views>\n <Viewport.View id='init'>\n {/* This view intentionally left blank while conditionally rendering the viewport. */}\n </Viewport.View>\n <Viewport.View id='complete'>\n <InvitationComplete statusValue={state} />\n </Viewport.View>\n <Viewport.View id='auth-code'>\n <InvitationAuthCode id={invitationId} code={authCode ?? 'never'} onCancel={onInvitationDone} />\n </Viewport.View>\n <Viewport.View id='qr-code'>\n <InvitationQR id={invitationId} url={url} onCancel={onInvitationDone} />\n </Viewport.View>\n </Viewport.Views>\n </Viewport.Root>\n );\n};\n\nconst InvitationQR = ({ id, url, onCancel }: { id: string; url: string; onCancel: () => void }) => {\n const { t } = useTranslation('os');\n const qrLabel = useId('devices-container__qr-code');\n const emoji = hexToEmoji(id);\n return (\n <>\n <p className='text-description'>{t('qr code description', { ns: CLIENT_PLUGIN })}</p>\n <div role='group' className='grid grid-cols-[1fr_min-content] mlb-2 gap-2'>\n <div role='none' className='is-full aspect-square relative text-description'>\n <QR\n rounding={100}\n backgroundColor='transparent'\n color='currentColor'\n aria-labelledby={qrLabel}\n errorCorrectionLevel='Q'\n cutout={true}\n >\n {url ?? 'never'}\n </QR>\n <Centered>\n <Emoji text={emoji} />\n </Centered>\n </div>\n <span id={qrLabel} className='sr-only'>\n {t('qr label')}\n </span>\n <Clipboard.Button value={url ?? 'never'} />\n </div>\n <Button variant='ghost' onClick={onCancel}>\n {t('cancel label')}\n </Button>\n </>\n );\n};\n\nconst InvitationAuthCode = ({ id, code, onCancel }: { id: string; code: string; onCancel: () => void }) => {\n const { t } = useTranslation('os');\n const emoji = hexToEmoji(id);\n\n return (\n <>\n <p className='text-description'>{t('auth other device emoji message')}</p>\n {emoji && <Emoji text={emoji} className='mli-auto mlb-2 text-center' />}\n <p className='text-description'>{t('auth code message')}</p>\n <AuthCode code={code} large classNames='mli-auto mlb-2 text-center grow' />\n <Button variant='ghost' onClick={onCancel}>\n {t('cancel label')}\n </Button>\n </>\n );\n};\n\nconst InvitationComplete = ({ statusValue }: { statusValue: number }) => {\n return statusValue > 0 ? <Check className={mx('m-1.5', getSize(6))} /> : <X className={mx('m-1.5', getSize(6))} />;\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, useTranslation } 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 const { t } = useTranslation(CLIENT_PLUGIN);\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.UpdateDialog, { part: 'dialog', options: { 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 <Dialog.Title classNames='sr-only'>{t('join space label', { ns: 'os' })}</Dialog.Title>\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 2025 DXOS.org\n//\n\nimport { Schema as S } from 'effect';\nimport React, { type ChangeEvent, useCallback, useMemo, useState } from 'react';\n\nimport { debounce } from '@dxos/async';\nimport { useClient } from '@dxos/react-client';\nimport { type Identity, useIdentity } from '@dxos/react-client/halo';\nimport { ButtonGroup, Clipboard, Input, useTranslation } from '@dxos/react-ui';\nimport { Form, type InputComponent, ControlItem, ControlItemInput, ControlSection } from '@dxos/react-ui-form';\nimport { EmojiPickerBlock, HuePicker } from '@dxos/react-ui-pickers';\nimport { StackItem } from '@dxos/react-ui-stack';\nimport { hexToHue, hexToEmoji } from '@dxos/util';\n\nimport { CLIENT_PLUGIN } from '../meta';\n\n// TODO(thure): Factor out?\nconst getDefaultHueValue = (identity: Identity | null) => hexToHue(identity?.identityKey.toHex() ?? '0');\nconst getDefaultEmojiValue = (identity: Identity | null) => hexToEmoji(identity?.identityKey.toHex() ?? '0');\nconst getHueValue = (identity: Identity | null) => identity?.profile?.data?.hue || getDefaultHueValue(identity);\nconst getEmojiValue = (identity: Identity | null) => identity?.profile?.data?.emoji || getDefaultEmojiValue(identity);\n\nexport const ProfileContainer = () => {\n const { t } = useTranslation(CLIENT_PLUGIN);\n const client = useClient();\n const identity = useIdentity();\n const [displayName, setDisplayNameDirectly] = useState(identity?.profile?.displayName ?? '');\n const [emoji, setEmojiDirectly] = useState<string>(getEmojiValue(identity));\n const [hue, setHueDirectly] = useState<string>(getHueValue(identity));\n\n const updateProfile = useMemo(\n () =>\n debounce(\n (profile: Partial<Profile>) =>\n client.halo.updateProfile({\n displayName: profile.displayName,\n data: {\n emoji: profile.emoji,\n hue: profile.hue,\n },\n }),\n 2_000,\n ),\n [],\n );\n\n const handleSave = useCallback(\n (profile: Profile) => {\n setDisplayNameDirectly(profile.displayName);\n setEmojiDirectly(profile.emoji);\n setHueDirectly(profile.hue);\n updateProfile(profile);\n },\n [identity],\n );\n\n const values = useMemo(\n () => ({\n displayName,\n emoji,\n hue,\n did: identity?.did,\n }),\n [identity, displayName, emoji, hue],\n );\n\n // TODO(wittjosiah): Integrate descriptions with the form schema.\n const customElements: Partial<Record<string, InputComponent>> = useMemo(\n () => ({\n displayName: ({ type, label, getValue, onValueChange }) => {\n const handleChange = useCallback(\n ({ target: { value } }: ChangeEvent<HTMLInputElement>) => onValueChange(type, value),\n [onValueChange, type],\n );\n return (\n <ControlItemInput title={label} description={t('display name description')}>\n <Input.TextInput\n value={getValue()}\n onChange={handleChange}\n placeholder={t('display name input placeholder')}\n classNames='min-is-64'\n />\n </ControlItemInput>\n );\n },\n emoji: ({ type, label, getValue, onValueChange }) => {\n const handleChange = useCallback((nextEmoji: string) => onValueChange(type, nextEmoji), [onValueChange, type]);\n const handleEmojiReset = useCallback(\n () => onValueChange(type, getDefaultEmojiValue(identity)),\n [onValueChange, type],\n );\n return (\n <ControlItem title={label} description={t('icon description')}>\n <EmojiPickerBlock\n triggerVariant='default'\n emoji={getValue()}\n onChangeEmoji={handleChange}\n onClickClear={handleEmojiReset}\n classNames='justify-self-end'\n />\n </ControlItem>\n );\n },\n hue: ({ type, label, getValue, onValueChange }) => {\n const handleChange = useCallback((nextHue: string) => onValueChange(type, nextHue), [onValueChange, type]);\n const handleHueReset = useCallback(\n () => onValueChange(type, getDefaultHueValue(identity)),\n [onValueChange, type],\n );\n return (\n <ControlItem title={label} description={t('hue description')}>\n <HuePicker\n value={getValue()}\n onChange={handleChange}\n onReset={handleHueReset}\n classNames='[--hue-preview-size:1.5rem] justify-self-end'\n />\n </ControlItem>\n );\n },\n // TODO(wittjosiah): We need text input annotations for disabled and copyable.\n did: ({ label, getValue }) => {\n return (\n <ControlItemInput title={label} description={t('did description')}>\n <ButtonGroup>\n <Input.TextInput value={getValue()} disabled classNames='min-is-64' />\n <Clipboard.IconButton value={getValue() ?? ''} />\n </ButtonGroup>\n </ControlItemInput>\n );\n },\n }),\n [t],\n );\n\n return (\n <StackItem.Content classNames='p-2 block overflow-y-auto'>\n <Clipboard.Provider>\n <ControlSection title={t('profile label')} description={t('profile description')}>\n <Form\n schema={ProfileSchema}\n values={values}\n autoSave\n onSave={handleSave}\n Custom={customElements}\n classNames='p-0 container-max-width [&_[role=\"form\"]]:grid [&_[role=\"form\"]]:grid-cols-1 md:[&_[role=\"form\"]]:grid-cols-[1fr_min-content] [&_[role=\"form\"]]:gap-4'\n />\n </ControlSection>\n </Clipboard.Provider>\n </StackItem.Content>\n );\n};\n\n// TODO(wittjosiah): Integrate annotations with translations.\nconst ProfileSchema = S.Struct({\n displayName: S.String.annotations({ title: 'Display name' }),\n emoji: S.String.annotations({ title: 'Avatar' }),\n hue: S.String.annotations({ title: 'Color' }),\n did: S.String.annotations({ title: 'DID' }),\n});\ntype Profile = S.Schema.Type<typeof ProfileSchema>;\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 RECOVERY_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'>\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", "//\n// Copyright 2024 DXOS.org\n//\n\nimport React from 'react';\n\nimport { createIntent, useIntentDispatcher } from '@dxos/app-framework';\nimport { useCredentials } from '@dxos/react-client/halo';\nimport { Icon, IconButton, List, ListItem, useTranslation, Message } from '@dxos/react-ui';\nimport { ControlGroup, ControlItem, ControlSection } from '@dxos/react-ui-form';\nimport { StackItem } from '@dxos/react-ui-stack';\n\nimport { CLIENT_PLUGIN } from '../meta';\nimport { ClientAction } from '../types';\n\nexport const MANAGE_CREDENTIALS_DIALOG = `${CLIENT_PLUGIN}/ManageCredentialsDialog`;\n\nexport const RecoveryCredentialsContainer = () => {\n const { t } = useTranslation(CLIENT_PLUGIN);\n const { dispatchPromise: dispatch } = useIntentDispatcher();\n const credentials = useCredentials();\n const recoveryCredentials = credentials.filter(\n (credential) => credential.subject.assertion['@type'] === 'dxos.halo.credentials.IdentityRecovery',\n );\n\n return (\n <StackItem.Content classNames='p-2 block overflow-y-auto'>\n <ControlSection title={t('recovery setup dialog title')} description={t('recovery setup dialog description')}>\n <ControlGroup>\n <ControlItem title={t('create passkey label')} description={t('create passkey description')}>\n <IconButton\n label={t('create passkey label')}\n icon='ph--key--duotone'\n variant='primary'\n size={5}\n onClick={() => dispatch(createIntent(ClientAction.CreatePasskey))}\n />\n </ControlItem>\n <ControlItem title={t('create recovery code label')} description={t('create recovery code description')}>\n <IconButton\n label={t('create recovery code label')}\n icon='ph--receipt--duotone'\n variant='default'\n size={5}\n onClick={() => dispatch(createIntent(ClientAction.CreateRecoveryCode))}\n />\n </ControlItem>\n </ControlGroup>\n </ControlSection>\n <ControlSection title={t('credentials list label')}>\n {recoveryCredentials.length < 1 ? (\n <Message.Root valence='error' className='container-max-width'>\n <Message.Title>\n <Icon icon='ph--shield-warning--duotone' size={5} classNames='inline-block align-top mbs-px mie-1' />\n {t('no credentials title')}\n </Message.Title>\n <Message.Body>{t('no credentials message')}</Message.Body>\n </Message.Root>\n ) : (\n <List classNames='container-max-width pli-2'>\n {recoveryCredentials.map((credential) => (\n <ListItem.Root key={credential.id?.toHex()}>\n <ListItem.Endcap>\n <Icon icon='ph--key--regular' size={5} />\n </ListItem.Endcap>\n <ListItem.Heading>{credential.issuanceDate.toLocaleString()}</ListItem.Heading>\n </ListItem.Root>\n ))}\n </List>\n )}\n </ControlSection>\n </StackItem.Content>\n );\n};\n", "//\n// Copyright 2025 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 { Dialog, useTranslation } from '@dxos/react-ui';\nimport { ConfirmReset, type ConfirmResetProps } from '@dxos/shell/react';\n\nimport { CLIENT_PLUGIN } from '../meta';\nimport { type ClientPluginOptions } from '../types';\n\nexport const RESET_DIALOG = `${CLIENT_PLUGIN}/ResetDialog`;\n\nexport type ResetDialogProps = Pick<ConfirmResetProps, 'mode'> & Pick<ClientPluginOptions, 'onReset'>;\n\nexport const ResetDialog = ({ mode, onReset }: ResetDialogProps) => {\n const { t } = useTranslation(CLIENT_PLUGIN);\n const { dispatchPromise: dispatch } = useIntentDispatcher();\n const client = useClient();\n\n const handleReset = useCallback(async () => {\n await client.reset();\n const target =\n mode === 'join new identity' ? 'deviceInvitation' : mode === 'recover' ? 'recoverIdentity' : undefined;\n await onReset?.({ target });\n }, [dispatch, client, mode, onReset]);\n\n const handleCancel = useCallback(() => {\n void dispatch(\n createIntent(LayoutAction.UpdateDialog, {\n part: 'dialog',\n options: { state: false },\n }),\n );\n }, [dispatch]);\n\n // TODO(wittjosiah): Add the sr-only translations.\n // TODO(wittjosiah): Add missing descriptions to other dialogs.\n return (\n <Dialog.Content classNames='bs-content min-bs-[15rem] max-bs-full md:max-is-[40rem] overflow-hidden'>\n <Dialog.Title classNames='sr-only'>{t('reset dialog title')}</Dialog.Title>\n <Dialog.Description classNames='sr-only'>{t('reset dialog description')}</Dialog.Description>\n <ConfirmReset active mode={mode} onConfirm={handleReset} onCancel={handleCancel} />\n </Dialog.Content>\n );\n};\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
|
+
"names": ["Check", "X", "React", "useCallback", "useEffect", "useState", "QR", "createIntent", "useIntentDispatcher", "log", "useClient", "useMulticastObservable", "useDevices", "Invitation", "InvitationEncoder", "useNetworkStatus", "Button", "Clipboard", "IconButton", "List", "useId", "useTranslation", "ControlFrame", "ControlFrameItem", "ControlGroup", "ControlItem", "ControlSection", "StackItem", "getSize", "mx", "AuthCode", "Centered", "DeviceListItem", "Emoji", "Viewport", "hexToEmoji", "DevicesContainer", "createInvitationUrl", "t", "useTranslation", "dispatchPromise", "dispatch", "useIntentDispatcher", "devices", "useDevices", "swarm", "connectionState", "useNetworkStatus", "handleResetStorage", "useCallback", "createIntent", "ClientAction", "ResetStorage", "handleRecover", "mode", "handleJoinNewIdentity", "Clipboard", "Provider", "StackItem", "Content", "classNames", "ControlSection", "title", "ns", "CLIENT_PLUGIN", "description", "ControlFrame", "ControlFrameItem", "List", "map", "device", "DeviceListItem", "key", "deviceKey", "toHex", "DeviceInvitation", "ControlGroup", "ControlItem", "Button", "variant", "onClick", "data-testid", "props", "client", "useClient", "invitation", "setInvitation", "useState", "onInvitationCreate", "halo", "share", "config", "values", "runtime", "app", "env", "DX_ENVIRONMENT", "subscription", "subscribe", "invitationCode", "InvitationEncoder", "encode", "state", "Invitation", "State", "CONNECTING", "log", "info", "JSON", "stringify", "authCode", "unsubscribe", "onInvitationDone", "undefined", "DeviceInvitationImpl", "InvitationSection", "invitationObservable", "useMulticastObservable", "url", "useEffect", "SUCCESS", "invitationId", "activeView", "CANCELLED", "READY_FOR_AUTHENTICATION", "p", "className", "IconButton", "icon", "label", "disabled", "Viewport", "Root", "Views", "View", "id", "InvitationComplete", "statusValue", "InvitationAuthCode", "code", "onCancel", "InvitationQR", "qrLabel", "useId", "emoji", "hexToEmoji", "div", "role", "QR", "rounding", "backgroundColor", "color", "aria-labelledby", "errorCorrectionLevel", "cutout", "Centered", "Emoji", "text", "span", "value", "AuthCode", "large", "Check", "mx", "getSize", "X", "React", "useCallback", "createIntent", "LayoutAction", "useIntentDispatcher", "ObservabilityAction", "Dialog", "useTranslation", "JoinPanel", "JOIN_DIALOG", "CLIENT_PLUGIN", "JoinDialog", "props", "dispatchPromise", "dispatch", "useIntentDispatcher", "t", "useTranslation", "handleCancelResetStorage", "useCallback", "createIntent", "ClientAction", "ShareIdentity", "handleDone", "result", "identityKey", "Promise", "all", "LayoutAction", "UpdateDialog", "part", "options", "state", "ObservabilityAction", "SendEvent", "name", "initialDisposition", "React", "Dialog", "Content", "Title", "classNames", "ns", "JoinPanel", "mode", "exitActionParent", "Close", "asChild", "doneActionParent", "onCancelResetStorage", "onDone", "Schema", "S", "React", "useCallback", "useMemo", "useState", "debounce", "useClient", "useIdentity", "ButtonGroup", "Clipboard", "Input", "useTranslation", "Form", "ControlItem", "ControlItemInput", "ControlSection", "EmojiPickerBlock", "HuePicker", "StackItem", "hexToHue", "hexToEmoji", "getDefaultHueValue", "identity", "hexToHue", "identityKey", "toHex", "getDefaultEmojiValue", "hexToEmoji", "getHueValue", "profile", "data", "hue", "getEmojiValue", "emoji", "ProfileContainer", "t", "useTranslation", "CLIENT_PLUGIN", "client", "useClient", "useIdentity", "displayName", "setDisplayNameDirectly", "useState", "setEmojiDirectly", "setHueDirectly", "updateProfile", "useMemo", "debounce", "halo", "handleSave", "useCallback", "values", "did", "customElements", "type", "label", "getValue", "onValueChange", "handleChange", "target", "value", "React", "ControlItemInput", "title", "description", "Input", "TextInput", "onChange", "placeholder", "classNames", "nextEmoji", "handleEmojiReset", "ControlItem", "EmojiPickerBlock", "triggerVariant", "onChangeEmoji", "onClickClear", "nextHue", "handleHueReset", "HuePicker", "onReset", "ButtonGroup", "disabled", "Clipboard", "IconButton", "StackItem", "Content", "Provider", "ControlSection", "Form", "schema", "ProfileSchema", "autoSave", "onSave", "Custom", "S", "Struct", "String", "annotations", "React", "useCallback", "useState", "AlertDialog", "Button", "Clipboard", "Input", "useTranslation", "RECOVERY_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", "React", "createIntent", "useIntentDispatcher", "useCredentials", "Icon", "IconButton", "List", "ListItem", "useTranslation", "Message", "ControlGroup", "ControlItem", "ControlSection", "StackItem", "MANAGE_CREDENTIALS_DIALOG", "CLIENT_PLUGIN", "RecoveryCredentialsContainer", "t", "useTranslation", "dispatchPromise", "dispatch", "useIntentDispatcher", "credentials", "useCredentials", "recoveryCredentials", "filter", "credential", "subject", "assertion", "React", "StackItem", "Content", "classNames", "ControlSection", "title", "description", "ControlGroup", "ControlItem", "IconButton", "label", "icon", "variant", "size", "onClick", "createIntent", "ClientAction", "CreatePasskey", "CreateRecoveryCode", "length", "Message", "Root", "valence", "className", "Title", "Icon", "Body", "List", "map", "ListItem", "key", "id", "toHex", "Endcap", "Heading", "issuanceDate", "toLocaleString", "React", "useCallback", "createIntent", "LayoutAction", "useIntentDispatcher", "useClient", "Dialog", "useTranslation", "ConfirmReset", "RESET_DIALOG", "CLIENT_PLUGIN", "ResetDialog", "mode", "onReset", "t", "useTranslation", "dispatchPromise", "dispatch", "useIntentDispatcher", "client", "useClient", "handleReset", "useCallback", "reset", "target", "undefined", "handleCancel", "createIntent", "LayoutAction", "UpdateDialog", "part", "options", "state", "React", "Dialog", "Content", "classNames", "Title", "Description", "ConfirmReset", "active", "onConfirm", "onCancel"]
|
|
7
|
+
}
|
|
@@ -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 { 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 client = new Client(options);\n await client.initialize();\n await onClientInitialized?.(context, client);\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.activatePromise(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,cAAc;AAUvB,IAAA,iBAAe,OAAO,EAAEC,SAASC,qBAAqB,GAAGC,QAAAA,MAAkC;AACzF,QAAMC,SAAS,IAAIC,OAAOF,OAAAA;AAC1B,QAAMC,OAAOE,WAAU;AACvB,QAAMJ,sBAAsBD,SAASG,MAAAA;AAGrCA,SAAOG,SAASC,GAAG,MAAA;AACjBJ,WAAOK,KAAKC,SAASC,UAAU,OAAOD,aAAAA;AACpC,UAAIA,UAAU;AACZE,eAAOC,SAASC,OAAOF,OAAOC,SAASE;MACzC;IACF,CAAA;EACF,CAAA;AAEA,QAAMC,eAAeZ,OAAOa,OAAOC,QAAQP,UAAU,OAAOQ,UAAAA;AAC1D,QAAIA,OAAO;AACT,YAAMlB,QAAQmB,gBAAgBC,aAAaC,WAAW;IACxD;EACF,CAAA;AAEA,SAAOC,YAAYC,mBAAmBnB,QAAQD,QAAQ,YAAA;AACpDY,iBAAaS,YAAW;AACxB,UAAMrB,OAAOsB,QAAO;EACtB,CAAA;AACF;",
|
|
6
|
+
"names": ["contributes", "Client", "context", "onClientInitialized", "options", "client", "Client", "initialize", "reloaded", "on", "halo", "identity", "subscribe", "window", "location", "href", "origin", "subscription", "spaces", "isReady", "ready", "activatePromise", "ClientEvents", "SpacesReady", "contributes", "ClientCapabilities", "unsubscribe", "destroy"]
|
|
7
|
+
}
|
|
@@ -14,13 +14,13 @@ import { Capabilities, contributes, defineModule, definePlugin, Events, oneOf }
|
|
|
14
14
|
|
|
15
15
|
// packages/plugins/plugin-client/src/capabilities/index.ts
|
|
16
16
|
import { lazy } from "@dxos/app-framework";
|
|
17
|
-
var AppGraphBuilder = lazy(async () => import("./app-graph-builder-
|
|
18
|
-
var Client = lazy(async () => import("./client-
|
|
19
|
-
var IntentResolver = lazy(async () => import("./intent-resolver-
|
|
20
|
-
var Migrations = lazy(async () => import("./migrations-
|
|
17
|
+
var AppGraphBuilder = lazy(async () => import("./app-graph-builder-WAS4YZNA.mjs"));
|
|
18
|
+
var Client = lazy(async () => import("./client-LV67Q3R7.mjs"));
|
|
19
|
+
var IntentResolver = lazy(async () => import("./intent-resolver-NCISOZW4.mjs"));
|
|
20
|
+
var Migrations = lazy(async () => import("./migrations-3DWFOL5Q.mjs"));
|
|
21
21
|
var ReactContext = lazy(async () => import("./react-context-WEH7SL4I.mjs"));
|
|
22
|
-
var ReactSurface = lazy(async () => import("./react-surface-
|
|
23
|
-
var
|
|
22
|
+
var ReactSurface = lazy(async () => import("./react-surface-J7SZR2J6.mjs"));
|
|
23
|
+
var Schema = lazy(async () => import("./schema-JQAT6Q7S.mjs"));
|
|
24
24
|
|
|
25
25
|
// packages/plugins/plugin-client/src/translations.ts
|
|
26
26
|
var translations_default = [
|
|
@@ -29,7 +29,7 @@ var translations_default = [
|
|
|
29
29
|
[CLIENT_PLUGIN]: {
|
|
30
30
|
"account label": "User Account",
|
|
31
31
|
"profile label": "Profile",
|
|
32
|
-
"profile description": "You can adjust how
|
|
32
|
+
"profile description": "You can adjust how you\u2019re represented in Composer here.",
|
|
33
33
|
"devices label": "Devices",
|
|
34
34
|
"devices verbose label": "Manage devices",
|
|
35
35
|
"add device description": "Authenticating another device is a two-step process. To get started, create a code using the button below.",
|
|
@@ -54,7 +54,7 @@ var translations_default = [
|
|
|
54
54
|
"open user account label": "Open user account",
|
|
55
55
|
"manage credentials dialog title": "Manage Account Recovery",
|
|
56
56
|
"credentials list label": "Recovery credentials",
|
|
57
|
-
"no credentials title": "
|
|
57
|
+
"no credentials title": "There\u2019s no way to recover your account\xA0yet.",
|
|
58
58
|
"no credentials message": "Create a recovery credential above to secure your\xA0account.",
|
|
59
59
|
"recovery setup dialog title": "Account Security",
|
|
60
60
|
"recovery setup dialog description": "In order to maintain access to your account you need to register a recovery credential. Passkeys are the recommended way to do this, they can be stored in your browser or in a password\xA0manager.",
|
|
@@ -100,7 +100,7 @@ var ClientPlugin = ({ invitationUrl = window.location.origin, invitationParam =
|
|
|
100
100
|
activatesBefore: [
|
|
101
101
|
ClientEvents.SetupSchema
|
|
102
102
|
],
|
|
103
|
-
activate:
|
|
103
|
+
activate: Schema
|
|
104
104
|
}),
|
|
105
105
|
defineModule({
|
|
106
106
|
id: `${meta.id}/module/migration`,
|