@dxos/plugin-client 0.8.4-main.f9ba587 → 0.8.4-main.fffef41
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-3EILEBWW.mjs → app-graph-builder-ARY4H3VC.mjs} +26 -25
- package/dist/lib/browser/app-graph-builder-ARY4H3VC.mjs.map +7 -0
- package/dist/lib/browser/{chunk-64ANQXYZ.mjs → chunk-4G4YWIUQ.mjs} +59 -66
- package/dist/lib/browser/chunk-4G4YWIUQ.mjs.map +7 -0
- package/dist/lib/browser/chunk-4LRO3Y2O.mjs +19 -0
- package/dist/lib/browser/chunk-4LRO3Y2O.mjs.map +7 -0
- package/dist/lib/browser/chunk-N5UR2HOE.mjs +18 -0
- package/dist/lib/browser/chunk-N5UR2HOE.mjs.map +7 -0
- package/dist/lib/browser/{chunk-Q7TFRFHI.mjs → chunk-RDIG75CA.mjs} +15 -16
- package/dist/lib/browser/chunk-RDIG75CA.mjs.map +7 -0
- package/dist/lib/browser/chunk-ZRVMXLDR.mjs +15 -0
- package/dist/lib/browser/chunk-ZRVMXLDR.mjs.map +7 -0
- package/dist/lib/browser/{client-JFNMEFOK.mjs → client-O7U3MQ6J.mjs} +14 -8
- package/dist/lib/browser/client-O7U3MQ6J.mjs.map +7 -0
- package/dist/lib/browser/index.mjs +23 -19
- package/dist/lib/browser/index.mjs.map +4 -4
- package/dist/lib/browser/{intent-resolver-YGAQVXI2.mjs → intent-resolver-KLK7PJZK.mjs} +18 -18
- package/dist/lib/browser/intent-resolver-KLK7PJZK.mjs.map +7 -0
- package/dist/lib/browser/meta.json +1 -1
- package/dist/lib/browser/{migrations-5COKGS4E.mjs → migrations-RUAKBBTF.mjs} +6 -6
- package/dist/lib/browser/migrations-RUAKBBTF.mjs.map +7 -0
- package/dist/lib/browser/{react-context-GBNYT5QK.mjs → react-context-PCT5C3BN.mjs} +9 -8
- package/dist/lib/browser/react-context-PCT5C3BN.mjs.map +7 -0
- package/dist/lib/browser/{react-surface-YKQAUE2M.mjs → react-surface-RCXEA65V.mjs} +7 -7
- package/dist/lib/browser/{react-surface-YKQAUE2M.mjs.map → react-surface-RCXEA65V.mjs.map} +3 -3
- package/dist/lib/browser/{schema-defs-6L7W2RHL.mjs → schema-defs-UNNBAEFW.mjs} +6 -6
- package/dist/lib/browser/schema-defs-UNNBAEFW.mjs.map +7 -0
- package/dist/lib/browser/types/index.mjs +10 -0
- package/dist/lib/node-esm/{app-graph-builder-GINHOE7A.mjs → app-graph-builder-LLM25DRR.mjs} +26 -25
- package/dist/lib/node-esm/app-graph-builder-LLM25DRR.mjs.map +7 -0
- package/dist/lib/node-esm/chunk-6ANOJ7ZM.mjs +19 -0
- package/dist/lib/node-esm/chunk-6ANOJ7ZM.mjs.map +7 -0
- package/dist/lib/node-esm/chunk-7M7VWQJW.mjs +20 -0
- package/dist/lib/node-esm/chunk-7M7VWQJW.mjs.map +7 -0
- package/dist/lib/node-esm/{chunk-K4PIKBQQ.mjs → chunk-DJ6XKSE4.mjs} +59 -66
- package/dist/lib/node-esm/chunk-DJ6XKSE4.mjs.map +7 -0
- package/dist/lib/node-esm/chunk-QT3EQXDU.mjs +17 -0
- package/dist/lib/node-esm/chunk-QT3EQXDU.mjs.map +7 -0
- package/dist/lib/node-esm/{chunk-GDJMDBWM.mjs → chunk-VENKFPBC.mjs} +15 -16
- package/dist/lib/node-esm/chunk-VENKFPBC.mjs.map +7 -0
- package/dist/lib/node-esm/{client-XDYQARBL.mjs → client-6MTNT7M6.mjs} +14 -8
- package/dist/lib/node-esm/client-6MTNT7M6.mjs.map +7 -0
- package/dist/lib/node-esm/index.mjs +23 -19
- package/dist/lib/node-esm/index.mjs.map +4 -4
- package/dist/lib/node-esm/{intent-resolver-IN7YG7N7.mjs → intent-resolver-YR2C224X.mjs} +18 -18
- package/dist/lib/node-esm/intent-resolver-YR2C224X.mjs.map +7 -0
- package/dist/lib/node-esm/meta.json +1 -1
- package/dist/lib/node-esm/{migrations-FE4PDX6W.mjs → migrations-ASF2SAUR.mjs} +6 -6
- package/dist/lib/node-esm/migrations-ASF2SAUR.mjs.map +7 -0
- package/dist/lib/node-esm/{react-context-UCK43H3Z.mjs → react-context-F4QOBWSP.mjs} +9 -8
- package/dist/lib/node-esm/react-context-F4QOBWSP.mjs.map +7 -0
- package/dist/lib/node-esm/{react-surface-HDHC6XHQ.mjs → react-surface-SQBRXVMZ.mjs} +7 -7
- package/dist/lib/node-esm/{react-surface-HDHC6XHQ.mjs.map → react-surface-SQBRXVMZ.mjs.map} +3 -3
- package/dist/lib/node-esm/{schema-defs-GZIVMHLW.mjs → schema-defs-MSIT2KK2.mjs} +6 -6
- package/dist/lib/node-esm/schema-defs-MSIT2KK2.mjs.map +7 -0
- package/dist/lib/node-esm/{types.mjs → types/index.mjs} +3 -3
- package/dist/types/src/ClientPlugin.d.ts +1 -1
- package/dist/types/src/ClientPlugin.d.ts.map +1 -1
- package/dist/types/src/capabilities/app-graph-builder.d.ts +1 -1
- package/dist/types/src/capabilities/app-graph-builder.d.ts.map +1 -1
- package/dist/types/src/capabilities/capabilities.d.ts +2 -3
- package/dist/types/src/capabilities/capabilities.d.ts.map +1 -1
- package/dist/types/src/capabilities/client.d.ts +1 -1
- package/dist/types/src/capabilities/client.d.ts.map +1 -1
- package/dist/types/src/capabilities/index.d.ts +10 -10
- package/dist/types/src/capabilities/index.d.ts.map +1 -1
- package/dist/types/src/capabilities/intent-resolver.d.ts +1 -1
- package/dist/types/src/capabilities/intent-resolver.d.ts.map +1 -1
- package/dist/types/src/capabilities/migrations.d.ts +1 -1
- package/dist/types/src/capabilities/migrations.d.ts.map +1 -1
- package/dist/types/src/capabilities/react-context.d.ts +2 -2
- package/dist/types/src/capabilities/react-context.d.ts.map +1 -1
- package/dist/types/src/capabilities/react-surface.d.ts +1 -1
- package/dist/types/src/capabilities/react-surface.d.ts.map +1 -1
- package/dist/types/src/capabilities/schema-defs.d.ts +1 -1
- package/dist/types/src/capabilities/schema-defs.d.ts.map +1 -1
- package/dist/types/src/components/DevicesContainer.d.ts.map +1 -1
- package/dist/types/src/components/DevicesContainer.stories.d.ts +224 -5
- package/dist/types/src/components/DevicesContainer.stories.d.ts.map +1 -1
- package/dist/types/src/components/JoinDialog.d.ts +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/ProfileContainer.stories.d.ts +57 -5
- package/dist/types/src/components/ProfileContainer.stories.d.ts.map +1 -1
- package/dist/types/src/components/RecoveryCodeDialog.d.ts +1 -1
- package/dist/types/src/components/RecoveryCodeDialog.d.ts.map +1 -1
- package/dist/types/src/components/RecoveryCodeDialog.stories.d.ts +59 -5
- package/dist/types/src/components/RecoveryCodeDialog.stories.d.ts.map +1 -1
- package/dist/types/src/components/RecoveryCredentialsContainer.d.ts +1 -1
- package/dist/types/src/components/RecoveryCredentialsContainer.d.ts.map +1 -1
- package/dist/types/src/components/RecoveryCredentialsContainer.stories.d.ts +57 -5
- package/dist/types/src/components/RecoveryCredentialsContainer.stories.d.ts.map +1 -1
- package/dist/types/src/components/ResetDialog.d.ts +1 -1
- package/dist/types/src/components/ResetDialog.d.ts.map +1 -1
- package/dist/types/src/components/ResetDialog.stories.d.ts +59 -4
- package/dist/types/src/components/ResetDialog.stories.d.ts.map +1 -1
- package/dist/types/src/events.d.ts.map +1 -1
- package/dist/types/src/index.d.ts +3 -2
- package/dist/types/src/index.d.ts.map +1 -1
- package/dist/types/src/meta.d.ts +0 -1
- package/dist/types/src/meta.d.ts.map +1 -1
- package/dist/types/src/types/index.d.ts +2 -0
- package/dist/types/src/types/index.d.ts.map +1 -0
- package/dist/types/src/{types.d.ts → types/schema.d.ts} +31 -25
- package/dist/types/src/types/schema.d.ts.map +1 -0
- package/dist/types/tsconfig.tsbuildinfo +1 -1
- package/package.json +41 -42
- package/src/ClientPlugin.ts +57 -59
- package/src/capabilities/app-graph-builder.ts +25 -23
- package/src/capabilities/capabilities.ts +7 -6
- package/src/capabilities/client.ts +6 -4
- package/src/capabilities/intent-resolver.ts +7 -6
- package/src/capabilities/migrations.ts +2 -2
- package/src/capabilities/react-context.tsx +5 -3
- package/src/capabilities/react-surface.tsx +3 -3
- package/src/capabilities/schema-defs.ts +4 -4
- package/src/components/DevicesContainer.stories.tsx +9 -11
- package/src/components/DevicesContainer.tsx +61 -72
- package/src/components/JoinDialog.tsx +5 -4
- package/src/components/ProfileContainer.stories.tsx +8 -9
- package/src/components/ProfileContainer.tsx +24 -32
- package/src/components/RecoveryCodeDialog.stories.tsx +9 -10
- package/src/components/RecoveryCodeDialog.tsx +6 -6
- package/src/components/RecoveryCredentialsContainer.stories.tsx +9 -11
- package/src/components/RecoveryCredentialsContainer.tsx +47 -51
- package/src/components/ResetDialog.stories.tsx +10 -11
- package/src/components/ResetDialog.tsx +5 -4
- package/src/events.ts +6 -6
- package/src/index.ts +4 -3
- package/src/meta.ts +6 -3
- package/src/types/index.ts +5 -0
- package/src/{types.ts → types/schema.ts} +15 -16
- package/dist/lib/browser/app-graph-builder-3EILEBWW.mjs.map +0 -7
- package/dist/lib/browser/chunk-64ANQXYZ.mjs.map +0 -7
- package/dist/lib/browser/chunk-AWXKL4UR.mjs +0 -18
- package/dist/lib/browser/chunk-AWXKL4UR.mjs.map +0 -7
- package/dist/lib/browser/chunk-CAF2COXW.mjs +0 -19
- package/dist/lib/browser/chunk-CAF2COXW.mjs.map +0 -7
- package/dist/lib/browser/chunk-GS3LDHYD.mjs +0 -12
- package/dist/lib/browser/chunk-GS3LDHYD.mjs.map +0 -7
- package/dist/lib/browser/chunk-Q7TFRFHI.mjs.map +0 -7
- package/dist/lib/browser/client-JFNMEFOK.mjs.map +0 -7
- package/dist/lib/browser/intent-resolver-YGAQVXI2.mjs.map +0 -7
- package/dist/lib/browser/migrations-5COKGS4E.mjs.map +0 -7
- package/dist/lib/browser/react-context-GBNYT5QK.mjs.map +0 -7
- package/dist/lib/browser/schema-defs-6L7W2RHL.mjs.map +0 -7
- package/dist/lib/browser/types.mjs +0 -10
- package/dist/lib/node-esm/app-graph-builder-GINHOE7A.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-3BUB64JB.mjs +0 -19
- package/dist/lib/node-esm/chunk-3BUB64JB.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-GDJMDBWM.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-K4PIKBQQ.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-SZLX4BVJ.mjs +0 -14
- package/dist/lib/node-esm/chunk-SZLX4BVJ.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-UMO3ETDV.mjs +0 -20
- package/dist/lib/node-esm/chunk-UMO3ETDV.mjs.map +0 -7
- package/dist/lib/node-esm/client-XDYQARBL.mjs.map +0 -7
- package/dist/lib/node-esm/intent-resolver-IN7YG7N7.mjs.map +0 -7
- package/dist/lib/node-esm/migrations-FE4PDX6W.mjs.map +0 -7
- package/dist/lib/node-esm/react-context-UCK43H3Z.mjs.map +0 -7
- package/dist/lib/node-esm/schema-defs-GZIVMHLW.mjs.map +0 -7
- package/dist/types/src/types.d.ts.map +0 -1
- /package/dist/lib/browser/{types.mjs.map → types/index.mjs.map} +0 -0
- /package/dist/lib/node-esm/{types.mjs.map → types/index.mjs.map} +0 -0
|
@@ -1,27 +1,28 @@
|
|
|
1
1
|
import {
|
|
2
2
|
ClientCapabilities
|
|
3
|
-
} from "./chunk-
|
|
3
|
+
} from "./chunk-N5UR2HOE.mjs";
|
|
4
4
|
import {
|
|
5
5
|
Account,
|
|
6
6
|
ClientAction
|
|
7
|
-
} from "./chunk-
|
|
7
|
+
} from "./chunk-RDIG75CA.mjs";
|
|
8
8
|
import {
|
|
9
|
-
|
|
10
|
-
} from "./chunk-
|
|
9
|
+
meta
|
|
10
|
+
} from "./chunk-ZRVMXLDR.mjs";
|
|
11
11
|
|
|
12
12
|
// src/capabilities/app-graph-builder.ts
|
|
13
|
-
import {
|
|
14
|
-
import
|
|
13
|
+
import { Atom } from "@effect-atom/atom-react";
|
|
14
|
+
import * as Function from "effect/Function";
|
|
15
|
+
import * as Option from "effect/Option";
|
|
15
16
|
import { createIntent } from "@dxos/app-framework";
|
|
16
17
|
import { Capabilities, contributes } from "@dxos/app-framework";
|
|
17
|
-
import {
|
|
18
|
+
import { ROOT_ID, atomFromObservable, createExtension } from "@dxos/plugin-graph";
|
|
18
19
|
import { ConnectionState } from "@dxos/react-client/mesh";
|
|
19
|
-
var app_graph_builder_default = (context) => contributes(Capabilities.AppGraphBuilder, createExtension({
|
|
20
|
-
id:
|
|
21
|
-
actions: (node) =>
|
|
20
|
+
var app_graph_builder_default = ((context) => contributes(Capabilities.AppGraphBuilder, createExtension({
|
|
21
|
+
id: meta.id,
|
|
22
|
+
actions: (node) => Atom.make((get) => Function.pipe(get(node), Option.flatMap((node2) => node2.id === ROOT_ID ? Option.some(node2) : Option.none()), Option.map(() => {
|
|
22
23
|
return [
|
|
23
24
|
{
|
|
24
|
-
id: `${
|
|
25
|
+
id: `${meta.id}/open-user-account`,
|
|
25
26
|
data: async () => {
|
|
26
27
|
const { dispatchPromise: dispatch } = context.getCapability(Capabilities.IntentDispatcher);
|
|
27
28
|
await dispatch(createIntent(ClientAction.ShareIdentity));
|
|
@@ -30,7 +31,7 @@ var app_graph_builder_default = (context) => contributes(Capabilities.AppGraphBu
|
|
|
30
31
|
label: [
|
|
31
32
|
"open user account label",
|
|
32
33
|
{
|
|
33
|
-
ns:
|
|
34
|
+
ns: meta.id
|
|
34
35
|
}
|
|
35
36
|
],
|
|
36
37
|
icon: "ph--user--regular",
|
|
@@ -45,19 +46,19 @@ var app_graph_builder_default = (context) => contributes(Capabilities.AppGraphBu
|
|
|
45
46
|
}
|
|
46
47
|
];
|
|
47
48
|
}), Option.getOrElse(() => []))),
|
|
48
|
-
connector: (node) =>
|
|
49
|
+
connector: (node) => Atom.make((get) => Function.pipe(get(node), Option.flatMap((node2) => node2.id === ROOT_ID ? Option.some(node2) : Option.none()), Option.map(() => {
|
|
49
50
|
const client = context.getCapability(ClientCapabilities.Client);
|
|
50
|
-
const identity = get(
|
|
51
|
-
const status = get(
|
|
51
|
+
const identity = get(atomFromObservable(client.halo.identity));
|
|
52
|
+
const status = get(atomFromObservable(client.mesh.networkStatus));
|
|
52
53
|
return [
|
|
53
54
|
{
|
|
54
55
|
id: Account.id,
|
|
55
|
-
type:
|
|
56
|
+
type: meta.id,
|
|
56
57
|
properties: {
|
|
57
58
|
label: [
|
|
58
59
|
"account label",
|
|
59
60
|
{
|
|
60
|
-
ns:
|
|
61
|
+
ns: meta.id
|
|
61
62
|
}
|
|
62
63
|
],
|
|
63
64
|
icon: "ph--user--regular",
|
|
@@ -72,12 +73,12 @@ var app_graph_builder_default = (context) => contributes(Capabilities.AppGraphBu
|
|
|
72
73
|
{
|
|
73
74
|
id: Account.Profile,
|
|
74
75
|
data: Account.Profile,
|
|
75
|
-
type:
|
|
76
|
+
type: meta.id,
|
|
76
77
|
properties: {
|
|
77
78
|
label: [
|
|
78
79
|
"profile label",
|
|
79
80
|
{
|
|
80
|
-
ns:
|
|
81
|
+
ns: meta.id
|
|
81
82
|
}
|
|
82
83
|
],
|
|
83
84
|
icon: "ph--user--regular"
|
|
@@ -86,12 +87,12 @@ var app_graph_builder_default = (context) => contributes(Capabilities.AppGraphBu
|
|
|
86
87
|
{
|
|
87
88
|
id: Account.Devices,
|
|
88
89
|
data: Account.Devices,
|
|
89
|
-
type:
|
|
90
|
+
type: meta.id,
|
|
90
91
|
properties: {
|
|
91
92
|
label: [
|
|
92
93
|
"devices label",
|
|
93
94
|
{
|
|
94
|
-
ns:
|
|
95
|
+
ns: meta.id
|
|
95
96
|
}
|
|
96
97
|
],
|
|
97
98
|
icon: "ph--devices--regular",
|
|
@@ -101,12 +102,12 @@ var app_graph_builder_default = (context) => contributes(Capabilities.AppGraphBu
|
|
|
101
102
|
{
|
|
102
103
|
id: Account.Security,
|
|
103
104
|
data: Account.Security,
|
|
104
|
-
type:
|
|
105
|
+
type: meta.id,
|
|
105
106
|
properties: {
|
|
106
107
|
label: [
|
|
107
108
|
"security label",
|
|
108
109
|
{
|
|
109
|
-
ns:
|
|
110
|
+
ns: meta.id
|
|
110
111
|
}
|
|
111
112
|
],
|
|
112
113
|
icon: "ph--key--regular"
|
|
@@ -116,8 +117,8 @@ var app_graph_builder_default = (context) => contributes(Capabilities.AppGraphBu
|
|
|
116
117
|
}
|
|
117
118
|
];
|
|
118
119
|
}), Option.getOrElse(() => [])))
|
|
119
|
-
}));
|
|
120
|
+
})));
|
|
120
121
|
export {
|
|
121
122
|
app_graph_builder_default as default
|
|
122
123
|
};
|
|
123
|
-
//# sourceMappingURL=app-graph-builder-
|
|
124
|
+
//# sourceMappingURL=app-graph-builder-ARY4H3VC.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 { Atom } from '@effect-atom/atom-react';\nimport * as Function from 'effect/Function';\nimport * as Option from 'effect/Option';\n\nimport { createIntent } from '@dxos/app-framework';\nimport { Capabilities, type PluginContext, contributes } from '@dxos/app-framework';\nimport { ROOT_ID, atomFromObservable, createExtension } from '@dxos/plugin-graph';\nimport { ConnectionState } from '@dxos/react-client/mesh';\n\nimport { meta } from '../meta';\nimport { Account, ClientAction } from '../types';\n\nimport { ClientCapabilities } from './capabilities';\n\nexport default (context: PluginContext) =>\n contributes(\n Capabilities.AppGraphBuilder,\n createExtension({\n id: meta.id,\n actions: (node) =>\n Atom.make((get) =>\n Function.pipe(\n get(node),\n Option.flatMap((node) => (node.id === ROOT_ID ? Option.some(node) : Option.none())),\n Option.map(() => {\n return [\n {\n id: `${meta.id}/open-user-account`,\n data: async () => {\n const { dispatchPromise: dispatch } = context.getCapability(Capabilities.IntentDispatcher);\n await dispatch(createIntent(ClientAction.ShareIdentity));\n },\n properties: {\n label: ['open user account label', { ns: meta.id }],\n icon: 'ph--user--regular',\n disposition: 'menu',\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 }),\n Option.getOrElse(() => []),\n ),\n ),\n connector: (node) =>\n Atom.make((get) =>\n Function.pipe(\n get(node),\n Option.flatMap((node) => (node.id === ROOT_ID ? Option.some(node) : Option.none())),\n Option.map(() => {\n const client = context.getCapability(ClientCapabilities.Client);\n const identity = get(atomFromObservable(client.halo.identity));\n const status = get(atomFromObservable(client.mesh.networkStatus));\n\n return [\n {\n id: Account.id,\n type: meta.id,\n properties: {\n label: ['account label', { ns: meta.id }],\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: meta.id,\n properties: {\n label: ['profile label', { ns: meta.id }],\n icon: 'ph--user--regular',\n },\n },\n {\n id: Account.Devices,\n data: Account.Devices,\n type: meta.id,\n properties: {\n label: ['devices label', { ns: meta.id }],\n icon: 'ph--devices--regular',\n testId: 'clientPlugin.devices',\n },\n },\n {\n id: Account.Security,\n data: Account.Security,\n type: meta.id,\n properties: {\n label: ['security label', { ns: meta.id }],\n icon: 'ph--key--regular',\n },\n },\n ],\n },\n ];\n }),\n Option.getOrElse(() => []),\n ),\n ),\n }),\n );\n"],
|
|
5
|
+
"mappings": ";;;;;;;;;;;;AAIA,SAASA,YAAY;AACrB,YAAYC,cAAc;AAC1B,YAAYC,YAAY;AAExB,SAASC,oBAAoB;AAC7B,SAASC,cAAkCC,mBAAmB;AAC9D,SAASC,SAASC,oBAAoBC,uBAAuB;AAC7D,SAASC,uBAAuB;AAOhC,IAAA,6BAAe,CAACC,YACdC,YACEC,aAAaC,iBACbC,gBAAgB;EACdC,IAAIC,KAAKD;EACTE,SAAS,CAACC,SACRC,KAAKC,KAAK,CAACC,QACAC,cACPD,IAAIH,IAAAA,GACGK,eAAQ,CAACL,UAAUA,MAAKH,OAAOS,UAAiBC,YAAKP,KAAAA,IAAeQ,YAAI,CAAA,GACxEC,WAAI,MAAA;AACT,WAAO;MACL;QACEZ,IAAI,GAAGC,KAAKD,EAAE;QACda,MAAM,YAAA;AACJ,gBAAM,EAAEC,iBAAiBC,SAAQ,IAAKpB,QAAQqB,cAAcnB,aAAaoB,gBAAgB;AACzF,gBAAMF,SAASG,aAAaC,aAAaC,aAAa,CAAA;QACxD;QACAC,YAAY;UACVC,OAAO;YAAC;YAA2B;cAAEC,IAAItB,KAAKD;YAAG;;UACjDwB,MAAM;UACNC,aAAa;UACbC,YAAY;YACVC,OAAO;;YAEPC,SAAS;YACTC,OAAO;UACT;QACF;MACF;;EAEJ,CAAA,GACOC,iBAAU,MAAM,CAAA,CAAE,CAAA,CAAA;EAG/BC,WAAW,CAAC5B,SACVC,KAAKC,KAAK,CAACC,QACAC,cACPD,IAAIH,IAAAA,GACGK,eAAQ,CAACL,UAAUA,MAAKH,OAAOS,UAAiBC,YAAKP,KAAAA,IAAeQ,YAAI,CAAA,GACxEC,WAAI,MAAA;AACT,UAAMoB,SAASrC,QAAQqB,cAAciB,mBAAmBC,MAAM;AAC9D,UAAMC,WAAW7B,IAAI8B,mBAAmBJ,OAAOK,KAAKF,QAAQ,CAAA;AAC5D,UAAMG,SAAShC,IAAI8B,mBAAmBJ,OAAOO,KAAKC,aAAa,CAAA;AAE/D,WAAO;MACL;QACExC,IAAIyC,QAAQzC;QACZ0C,MAAMzC,KAAKD;QACXqB,YAAY;UACVC,OAAO;YAAC;YAAiB;cAAEC,IAAItB,KAAKD;YAAG;;UACvCwB,MAAM;UACNC,aAAa;;UAEbkB,QAAQR,UAAUS,YAAYC,MAAAA;UAC9BC,KAAKX,UAAUY,SAASlC,MAAMiC;UAC9BE,OAAOb,UAAUY,SAASlC,MAAMmC;UAChCV,QAAQA,OAAOW,UAAUC,gBAAgBC,UAAU,UAAU;QAC/D;QACAC,OAAO;UACL;YACEpD,IAAIyC,QAAQY;YACZxC,MAAM4B,QAAQY;YACdX,MAAMzC,KAAKD;YACXqB,YAAY;cACVC,OAAO;gBAAC;gBAAiB;kBAAEC,IAAItB,KAAKD;gBAAG;;cACvCwB,MAAM;YACR;UACF;UACA;YACExB,IAAIyC,QAAQa;YACZzC,MAAM4B,QAAQa;YACdZ,MAAMzC,KAAKD;YACXqB,YAAY;cACVC,OAAO;gBAAC;gBAAiB;kBAAEC,IAAItB,KAAKD;gBAAG;;cACvCwB,MAAM;cACN+B,QAAQ;YACV;UACF;UACA;YACEvD,IAAIyC,QAAQe;YACZ3C,MAAM4B,QAAQe;YACdd,MAAMzC,KAAKD;YACXqB,YAAY;cACVC,OAAO;gBAAC;gBAAkB;kBAAEC,IAAItB,KAAKD;gBAAG;;cACxCwB,MAAM;YACR;UACF;;MAEJ;;EAEJ,CAAA,GACOM,iBAAU,MAAM,CAAA,CAAE,CAAA,CAAA;AAGjC,CAAA,CAAA;",
|
|
6
|
+
"names": ["Atom", "Function", "Option", "createIntent", "Capabilities", "contributes", "ROOT_ID", "atomFromObservable", "createExtension", "ConnectionState", "context", "contributes", "Capabilities", "AppGraphBuilder", "createExtension", "id", "meta", "actions", "node", "Atom", "make", "get", "pipe", "flatMap", "ROOT_ID", "some", "none", "map", "data", "dispatchPromise", "dispatch", "getCapability", "IntentDispatcher", "createIntent", "ClientAction", "ShareIdentity", "properties", "label", "ns", "icon", "disposition", "keyBinding", "macos", "windows", "linux", "getOrElse", "connector", "client", "ClientCapabilities", "Client", "identity", "atomFromObservable", "halo", "status", "mesh", "networkStatus", "Account", "type", "userId", "identityKey", "toHex", "hue", "profile", "emoji", "swarm", "ConnectionState", "OFFLINE", "nodes", "Profile", "Devices", "testId", "Security"]
|
|
7
|
+
}
|
|
@@ -1,25 +1,23 @@
|
|
|
1
1
|
import {
|
|
2
2
|
ClientAction
|
|
3
|
-
} from "./chunk-
|
|
3
|
+
} from "./chunk-RDIG75CA.mjs";
|
|
4
4
|
import {
|
|
5
|
-
|
|
6
|
-
} from "./chunk-
|
|
5
|
+
meta
|
|
6
|
+
} from "./chunk-ZRVMXLDR.mjs";
|
|
7
7
|
|
|
8
8
|
// src/components/DevicesContainer.tsx
|
|
9
9
|
import { useSignals as _useSignals } from "@preact-signals/safe-react/tracking";
|
|
10
|
-
import { Check, X } from "@phosphor-icons/react";
|
|
11
10
|
import React, { useCallback, useEffect, useState } from "react";
|
|
12
11
|
import { QR } from "react-qr-rounded";
|
|
13
|
-
import { createIntent
|
|
12
|
+
import { createIntent } from "@dxos/app-framework";
|
|
13
|
+
import { useIntentDispatcher } from "@dxos/app-framework/react";
|
|
14
14
|
import { log } from "@dxos/log";
|
|
15
15
|
import { useClient, useMulticastObservable } from "@dxos/react-client";
|
|
16
16
|
import { useDevices } from "@dxos/react-client/halo";
|
|
17
17
|
import { Invitation, InvitationEncoder } from "@dxos/react-client/invitations";
|
|
18
18
|
import { useNetworkStatus } from "@dxos/react-client/mesh";
|
|
19
|
-
import { Button, Clipboard, IconButton, List, useId, useTranslation } from "@dxos/react-ui";
|
|
19
|
+
import { Button, Clipboard, Icon, IconButton, List, useId, useTranslation } from "@dxos/react-ui";
|
|
20
20
|
import { ControlFrame, ControlFrameItem, ControlGroup, ControlItem, ControlPage, ControlSection } from "@dxos/react-ui-form";
|
|
21
|
-
import { StackItem } from "@dxos/react-ui-stack";
|
|
22
|
-
import { getSize, mx } from "@dxos/react-ui-theme";
|
|
23
21
|
import { AuthCode, Centered, DeviceListItem, Emoji, Viewport } from "@dxos/shell/react";
|
|
24
22
|
import { hexToEmoji } from "@dxos/util";
|
|
25
23
|
var __dxlog_file = "/__w/dxos/dxos/packages/plugins/plugin-client/src/components/DevicesContainer.tsx";
|
|
@@ -43,18 +41,16 @@ var DevicesContainer = ({ createInvitationUrl }) => {
|
|
|
43
41
|
})), [
|
|
44
42
|
dispatch
|
|
45
43
|
]);
|
|
46
|
-
return /* @__PURE__ */ React.createElement(Clipboard.Provider, null, /* @__PURE__ */ React.createElement(
|
|
47
|
-
classNames: "block overflow-y-auto"
|
|
48
|
-
}, /* @__PURE__ */ React.createElement(ControlPage, null, /* @__PURE__ */ React.createElement(ControlSection, {
|
|
44
|
+
return /* @__PURE__ */ React.createElement(Clipboard.Provider, null, /* @__PURE__ */ React.createElement(ControlPage, null, /* @__PURE__ */ React.createElement(ControlSection, {
|
|
49
45
|
title: t("devices verbose label", {
|
|
50
|
-
ns:
|
|
46
|
+
ns: meta.id
|
|
51
47
|
}),
|
|
52
48
|
description: t("devices description", {
|
|
53
|
-
ns:
|
|
49
|
+
ns: meta.id
|
|
54
50
|
})
|
|
55
51
|
}, /* @__PURE__ */ React.createElement(ControlFrame, null, /* @__PURE__ */ React.createElement(ControlFrameItem, {
|
|
56
52
|
title: t("devices label", {
|
|
57
|
-
ns:
|
|
53
|
+
ns: meta.id
|
|
58
54
|
})
|
|
59
55
|
}, /* @__PURE__ */ React.createElement(List, null, devices.map((device) => {
|
|
60
56
|
return /* @__PURE__ */ React.createElement(DeviceListItem, {
|
|
@@ -68,15 +64,15 @@ var DevicesContainer = ({ createInvitationUrl }) => {
|
|
|
68
64
|
createInvitationUrl
|
|
69
65
|
})))), /* @__PURE__ */ React.createElement(ControlSection, {
|
|
70
66
|
title: t("danger zone title", {
|
|
71
|
-
ns:
|
|
67
|
+
ns: meta.id
|
|
72
68
|
}),
|
|
73
69
|
description: t("danger zone description", {
|
|
74
|
-
ns:
|
|
70
|
+
ns: meta.id
|
|
75
71
|
})
|
|
76
72
|
}, /* @__PURE__ */ React.createElement(ControlGroup, null, /* @__PURE__ */ React.createElement(ControlItem, {
|
|
77
73
|
title: t("reset device label"),
|
|
78
74
|
description: t("reset device description", {
|
|
79
|
-
ns:
|
|
75
|
+
ns: meta.id
|
|
80
76
|
})
|
|
81
77
|
}, /* @__PURE__ */ React.createElement(Button, {
|
|
82
78
|
variant: "destructive",
|
|
@@ -85,7 +81,7 @@ var DevicesContainer = ({ createInvitationUrl }) => {
|
|
|
85
81
|
}, t("reset device label"))), /* @__PURE__ */ React.createElement(ControlItem, {
|
|
86
82
|
title: t("recover identity label"),
|
|
87
83
|
description: t("recover identity description", {
|
|
88
|
-
ns:
|
|
84
|
+
ns: meta.id
|
|
89
85
|
})
|
|
90
86
|
}, /* @__PURE__ */ React.createElement(Button, {
|
|
91
87
|
variant: "destructive",
|
|
@@ -94,13 +90,13 @@ var DevicesContainer = ({ createInvitationUrl }) => {
|
|
|
94
90
|
}, t("recover identity label"))), /* @__PURE__ */ React.createElement(ControlItem, {
|
|
95
91
|
title: t("join new identity label"),
|
|
96
92
|
description: t("join new identity description", {
|
|
97
|
-
ns:
|
|
93
|
+
ns: meta.id
|
|
98
94
|
})
|
|
99
95
|
}, /* @__PURE__ */ React.createElement(Button, {
|
|
100
96
|
variant: "destructive",
|
|
101
97
|
onClick: handleJoinNewIdentity,
|
|
102
98
|
"data-testid": "devicesContainer.joinExisting"
|
|
103
|
-
}, t("join new identity label")))))))
|
|
99
|
+
}, t("join new identity label")))))));
|
|
104
100
|
} finally {
|
|
105
101
|
_effect.f();
|
|
106
102
|
}
|
|
@@ -121,7 +117,7 @@ var DeviceInvitation = (props) => {
|
|
|
121
117
|
authCode: invitation3.authCode
|
|
122
118
|
}), void 0, {
|
|
123
119
|
F: __dxlog_file,
|
|
124
|
-
L:
|
|
120
|
+
L: 126,
|
|
125
121
|
S: void 0,
|
|
126
122
|
C: (f, a) => f(...a)
|
|
127
123
|
});
|
|
@@ -181,7 +177,7 @@ var InvitationSection = ({ state = -1, authCode, invitationId = "never", url = "
|
|
|
181
177
|
} }) => {
|
|
182
178
|
var _effect = _useSignals();
|
|
183
179
|
try {
|
|
184
|
-
const { t } = useTranslation(
|
|
180
|
+
const { t } = useTranslation(meta.id);
|
|
185
181
|
const activeView = state < 0 ? "init" : state >= Invitation.State.CANCELLED ? "complete" : state >= Invitation.State.READY_FOR_AUTHENTICATION && authCode ? "auth-code" : "qr-code";
|
|
186
182
|
return activeView === "init" ? /* @__PURE__ */ React.createElement(React.Fragment, null, /* @__PURE__ */ React.createElement("p", {
|
|
187
183
|
className: "text-description mbe-2"
|
|
@@ -226,7 +222,7 @@ var InvitationQR = ({ id, url, onCancel }) => {
|
|
|
226
222
|
return /* @__PURE__ */ React.createElement(React.Fragment, null, /* @__PURE__ */ React.createElement("p", {
|
|
227
223
|
className: "text-description"
|
|
228
224
|
}, t("qr code description", {
|
|
229
|
-
ns:
|
|
225
|
+
ns: meta.id
|
|
230
226
|
})), /* @__PURE__ */ React.createElement("div", {
|
|
231
227
|
role: "group",
|
|
232
228
|
className: "grid grid-cols-[1fr_min-content] mlb-2 gap-2"
|
|
@@ -286,10 +282,14 @@ var InvitationAuthCode = ({ id, code, onCancel }) => {
|
|
|
286
282
|
var InvitationComplete = ({ statusValue }) => {
|
|
287
283
|
var _effect = _useSignals();
|
|
288
284
|
try {
|
|
289
|
-
return statusValue > 0 ? /* @__PURE__ */ React.createElement(
|
|
290
|
-
|
|
291
|
-
|
|
292
|
-
|
|
285
|
+
return statusValue > 0 ? /* @__PURE__ */ React.createElement(Icon, {
|
|
286
|
+
icon: "ph--check--regular",
|
|
287
|
+
size: 6,
|
|
288
|
+
classNames: "m-1.5"
|
|
289
|
+
}) : /* @__PURE__ */ React.createElement(Icon, {
|
|
290
|
+
icon: "ph--x--regular",
|
|
291
|
+
size: 6,
|
|
292
|
+
classNames: "m-1.5"
|
|
293
293
|
});
|
|
294
294
|
} finally {
|
|
295
295
|
_effect.f();
|
|
@@ -299,16 +299,17 @@ var InvitationComplete = ({ statusValue }) => {
|
|
|
299
299
|
// src/components/JoinDialog.tsx
|
|
300
300
|
import { useSignals as _useSignals2 } from "@preact-signals/safe-react/tracking";
|
|
301
301
|
import React2, { useCallback as useCallback2 } from "react";
|
|
302
|
-
import {
|
|
302
|
+
import { LayoutAction, createIntent as createIntent2 } from "@dxos/app-framework";
|
|
303
|
+
import { useIntentDispatcher as useIntentDispatcher2 } from "@dxos/app-framework/react";
|
|
303
304
|
import { ObservabilityAction } from "@dxos/plugin-observability/types";
|
|
304
305
|
import { Dialog, useTranslation as useTranslation2 } from "@dxos/react-ui";
|
|
305
306
|
import { JoinPanel } from "@dxos/shell/react";
|
|
306
|
-
var JOIN_DIALOG = `${
|
|
307
|
+
var JOIN_DIALOG = `${meta.id}/JoinDialog`;
|
|
307
308
|
var JoinDialog = (props) => {
|
|
308
309
|
var _effect = _useSignals2();
|
|
309
310
|
try {
|
|
310
311
|
const { dispatchPromise: dispatch } = useIntentDispatcher2();
|
|
311
|
-
const { t } = useTranslation2(
|
|
312
|
+
const { t } = useTranslation2(meta.id);
|
|
312
313
|
const handleCancelResetStorage = useCallback2(() => dispatch(createIntent2(ClientAction.ShareIdentity)), [
|
|
313
314
|
dispatch
|
|
314
315
|
]);
|
|
@@ -352,16 +353,15 @@ var JoinDialog = (props) => {
|
|
|
352
353
|
|
|
353
354
|
// src/components/ProfileContainer.tsx
|
|
354
355
|
import { useSignals as _useSignals3 } from "@preact-signals/safe-react/tracking";
|
|
355
|
-
import
|
|
356
|
+
import * as Schema from "effect/Schema";
|
|
356
357
|
import React3, { useCallback as useCallback3, useMemo, useState as useState2 } from "react";
|
|
357
358
|
import { debounce } from "@dxos/async";
|
|
358
359
|
import { useClient as useClient2 } from "@dxos/react-client";
|
|
359
360
|
import { useIdentity } from "@dxos/react-client/halo";
|
|
360
361
|
import { ButtonGroup, Clipboard as Clipboard2, Input, useTranslation as useTranslation3 } from "@dxos/react-ui";
|
|
361
|
-
import {
|
|
362
|
+
import { ControlItem as ControlItem2, ControlItemInput, ControlPage as ControlPage2, ControlSection as ControlSection2, Form } from "@dxos/react-ui-form";
|
|
362
363
|
import { EmojiPickerBlock, HuePicker } from "@dxos/react-ui-pickers";
|
|
363
|
-
import {
|
|
364
|
-
import { hexToHue, hexToEmoji as hexToEmoji2 } from "@dxos/util";
|
|
364
|
+
import { hexToEmoji as hexToEmoji2, hexToHue } from "@dxos/util";
|
|
365
365
|
var getDefaultHueValue = (identity) => hexToHue(identity?.identityKey.toHex() ?? "0");
|
|
366
366
|
var getDefaultEmojiValue = (identity) => hexToEmoji2(identity?.identityKey.toHex() ?? "0");
|
|
367
367
|
var getHueValue = (identity) => identity?.profile?.data?.hue || getDefaultHueValue(identity);
|
|
@@ -369,7 +369,7 @@ var getEmojiValue = (identity) => identity?.profile?.data?.emoji || getDefaultEm
|
|
|
369
369
|
var ProfileContainer = () => {
|
|
370
370
|
var _effect = _useSignals3();
|
|
371
371
|
try {
|
|
372
|
-
const { t } = useTranslation3(
|
|
372
|
+
const { t } = useTranslation3(meta.id);
|
|
373
373
|
const client = useClient2();
|
|
374
374
|
const identity = useIdentity();
|
|
375
375
|
const [displayName, setDisplayNameDirectly] = useState2(identity?.profile?.displayName ?? "");
|
|
@@ -386,7 +386,7 @@ var ProfileContainer = () => {
|
|
|
386
386
|
setDisplayNameDirectly(profile.displayName);
|
|
387
387
|
setEmojiDirectly(profile.emoji);
|
|
388
388
|
setHueDirectly(profile.hue);
|
|
389
|
-
updateProfile(profile);
|
|
389
|
+
void updateProfile(profile);
|
|
390
390
|
}, [
|
|
391
391
|
identity
|
|
392
392
|
]);
|
|
@@ -452,8 +452,7 @@ var ProfileContainer = () => {
|
|
|
452
452
|
}, /* @__PURE__ */ React3.createElement(HuePicker, {
|
|
453
453
|
value: getValue(),
|
|
454
454
|
onChange: handleChange,
|
|
455
|
-
onReset: handleHueReset
|
|
456
|
-
classNames: "[--hue-preview-size:1.5rem] justify-self-end"
|
|
455
|
+
onReset: handleHueReset
|
|
457
456
|
}));
|
|
458
457
|
},
|
|
459
458
|
// TODO(wittjosiah): We need text input annotations for disabled and copyable.
|
|
@@ -472,9 +471,7 @@ var ProfileContainer = () => {
|
|
|
472
471
|
}), [
|
|
473
472
|
t
|
|
474
473
|
]);
|
|
475
|
-
return /* @__PURE__ */ React3.createElement(
|
|
476
|
-
classNames: "block overflow-y-auto"
|
|
477
|
-
}, /* @__PURE__ */ React3.createElement(ControlPage2, null, /* @__PURE__ */ React3.createElement(Clipboard2.Provider, null, /* @__PURE__ */ React3.createElement(ControlSection2, {
|
|
474
|
+
return /* @__PURE__ */ React3.createElement(ControlPage2, null, /* @__PURE__ */ React3.createElement(Clipboard2.Provider, null, /* @__PURE__ */ React3.createElement(ControlSection2, {
|
|
478
475
|
title: t("profile label"),
|
|
479
476
|
description: t("profile description")
|
|
480
477
|
}, /* @__PURE__ */ React3.createElement(Form, {
|
|
@@ -483,9 +480,9 @@ var ProfileContainer = () => {
|
|
|
483
480
|
autoSave: true,
|
|
484
481
|
onSave: handleSave,
|
|
485
482
|
Custom: customElements,
|
|
486
|
-
classNames: "container-max-width grid grid-cols-1 md:grid-cols-[1fr_min-content]
|
|
483
|
+
classNames: "container-max-width grid grid-cols-1 md:grid-cols-[1fr_min-content]",
|
|
487
484
|
outerSpacing: false
|
|
488
|
-
}))))
|
|
485
|
+
}))));
|
|
489
486
|
} finally {
|
|
490
487
|
_effect.f();
|
|
491
488
|
}
|
|
@@ -509,21 +506,21 @@ var ProfileSchema = Schema.Struct({
|
|
|
509
506
|
import { useSignals as _useSignals4 } from "@preact-signals/safe-react/tracking";
|
|
510
507
|
import React4, { useCallback as useCallback4, useState as useState3 } from "react";
|
|
511
508
|
import { AlertDialog, Button as Button2, Clipboard as Clipboard3, Input as Input2, useTranslation as useTranslation4 } from "@dxos/react-ui";
|
|
512
|
-
var RECOVERY_CODE_DIALOG = `${
|
|
509
|
+
var RECOVERY_CODE_DIALOG = `${meta.id}/RecoveryCodeDialog`;
|
|
513
510
|
var RecoveryCodeDialog = ({ code }) => {
|
|
514
511
|
var _effect = _useSignals4();
|
|
515
512
|
try {
|
|
516
|
-
const { t } = useTranslation4(
|
|
513
|
+
const { t } = useTranslation4(meta.id);
|
|
517
514
|
const [confirmation, setConfirmation] = useState3(false);
|
|
518
515
|
const handleConfirmation = useCallback4((checked) => setConfirmation(checked), []);
|
|
519
516
|
return /* @__PURE__ */ React4.createElement(AlertDialog.Content, {
|
|
520
517
|
classNames: "bs-content min-bs-[15rem] max-bs-full md:max-is-[40rem] overflow-hidden"
|
|
521
518
|
}, /* @__PURE__ */ React4.createElement(AlertDialog.Title, null, t("recovery code dialog title")), /* @__PURE__ */ React4.createElement("p", {
|
|
522
|
-
className: "
|
|
519
|
+
className: "plb-4"
|
|
523
520
|
}, t("recovery code dialog description")), /* @__PURE__ */ React4.createElement(Clipboard3.Provider, null, /* @__PURE__ */ React4.createElement(Code, {
|
|
524
521
|
code
|
|
525
522
|
})), /* @__PURE__ */ React4.createElement("div", {
|
|
526
|
-
className: "flex flex-col
|
|
523
|
+
className: "flex flex-col plb-4 gap-2"
|
|
527
524
|
}, /* @__PURE__ */ React4.createElement("p", null, t("recovery code dialog warning 1")), /* @__PURE__ */ React4.createElement("p", null, t("recovery code dialog warning 2"))), /* @__PURE__ */ React4.createElement("div", {
|
|
528
525
|
className: "flex items-center gap-2 pbe-4"
|
|
529
526
|
}, /* @__PURE__ */ React4.createElement(Input2.Root, null, /* @__PURE__ */ React4.createElement(Input2.Checkbox, {
|
|
@@ -558,7 +555,7 @@ var Code = ({ code }) => {
|
|
|
558
555
|
key: i,
|
|
559
556
|
className: "flex items-center p-2 gap-2"
|
|
560
557
|
}, /* @__PURE__ */ React4.createElement("div", {
|
|
561
|
-
className: "
|
|
558
|
+
className: "is-4 text-xs text-center text-subdued"
|
|
562
559
|
}, i + 1), /* @__PURE__ */ React4.createElement("div", {
|
|
563
560
|
className: "text-sm"
|
|
564
561
|
}, word)))));
|
|
@@ -570,22 +567,20 @@ var Code = ({ code }) => {
|
|
|
570
567
|
// src/components/RecoveryCredentialsContainer.tsx
|
|
571
568
|
import { useSignals as _useSignals5 } from "@preact-signals/safe-react/tracking";
|
|
572
569
|
import React5 from "react";
|
|
573
|
-
import { createIntent as createIntent3
|
|
570
|
+
import { createIntent as createIntent3 } from "@dxos/app-framework";
|
|
571
|
+
import { useIntentDispatcher as useIntentDispatcher3 } from "@dxos/app-framework/react";
|
|
574
572
|
import { useCredentials } from "@dxos/react-client/halo";
|
|
575
|
-
import { Icon, IconButton as IconButton2, List as List2, ListItem, useTranslation as useTranslation5
|
|
573
|
+
import { Icon as Icon2, IconButton as IconButton2, List as List2, ListItem, Message, useTranslation as useTranslation5 } from "@dxos/react-ui";
|
|
576
574
|
import { ControlGroup as ControlGroup2, ControlItem as ControlItem3, ControlPage as ControlPage3, ControlSection as ControlSection3 } from "@dxos/react-ui-form";
|
|
577
|
-
|
|
578
|
-
var MANAGE_CREDENTIALS_DIALOG = `${CLIENT_PLUGIN}/ManageCredentialsDialog`;
|
|
575
|
+
var MANAGE_CREDENTIALS_DIALOG = `${meta.id}/ManageCredentialsDialog`;
|
|
579
576
|
var RecoveryCredentialsContainer = () => {
|
|
580
577
|
var _effect = _useSignals5();
|
|
581
578
|
try {
|
|
582
|
-
const { t } = useTranslation5(
|
|
579
|
+
const { t } = useTranslation5(meta.id);
|
|
583
580
|
const { dispatchPromise: dispatch } = useIntentDispatcher3();
|
|
584
581
|
const credentials = useCredentials();
|
|
585
582
|
const recoveryCredentials = credentials.filter((credential) => credential.subject.assertion["@type"] === "dxos.halo.credentials.IdentityRecovery");
|
|
586
|
-
return /* @__PURE__ */ React5.createElement(
|
|
587
|
-
classNames: "block overflow-y-auto"
|
|
588
|
-
}, /* @__PURE__ */ React5.createElement(ControlPage3, null, /* @__PURE__ */ React5.createElement(ControlSection3, {
|
|
583
|
+
return /* @__PURE__ */ React5.createElement(ControlPage3, null, /* @__PURE__ */ React5.createElement(ControlSection3, {
|
|
589
584
|
title: t("recovery setup dialog title"),
|
|
590
585
|
description: t("recovery setup dialog description")
|
|
591
586
|
}, /* @__PURE__ */ React5.createElement(ControlGroup2, null, /* @__PURE__ */ React5.createElement(ControlItem3, {
|
|
@@ -595,7 +590,6 @@ var RecoveryCredentialsContainer = () => {
|
|
|
595
590
|
label: t("create passkey label"),
|
|
596
591
|
icon: "ph--key--duotone",
|
|
597
592
|
variant: "primary",
|
|
598
|
-
size: 5,
|
|
599
593
|
onClick: () => dispatch(createIntent3(ClientAction.CreatePasskey))
|
|
600
594
|
})), /* @__PURE__ */ React5.createElement(ControlItem3, {
|
|
601
595
|
title: t("create recovery code label"),
|
|
@@ -604,7 +598,6 @@ var RecoveryCredentialsContainer = () => {
|
|
|
604
598
|
label: t("create recovery code label"),
|
|
605
599
|
icon: "ph--receipt--duotone",
|
|
606
600
|
variant: "default",
|
|
607
|
-
size: 5,
|
|
608
601
|
onClick: () => dispatch(createIntent3(ClientAction.CreateRecoveryCode))
|
|
609
602
|
})))), /* @__PURE__ */ React5.createElement(ControlSection3, {
|
|
610
603
|
title: t("credentials list label")
|
|
@@ -617,10 +610,9 @@ var RecoveryCredentialsContainer = () => {
|
|
|
617
610
|
classNames: "container-max-width pli-2"
|
|
618
611
|
}, recoveryCredentials.map((credential) => /* @__PURE__ */ React5.createElement(ListItem.Root, {
|
|
619
612
|
key: credential.id?.toHex()
|
|
620
|
-
}, /* @__PURE__ */ React5.createElement(ListItem.Endcap, null, /* @__PURE__ */ React5.createElement(
|
|
621
|
-
icon: "ph--key--regular"
|
|
622
|
-
|
|
623
|
-
})), /* @__PURE__ */ React5.createElement(ListItem.Heading, null, credential.issuanceDate.toLocaleString())))))));
|
|
613
|
+
}, /* @__PURE__ */ React5.createElement(ListItem.Endcap, null, /* @__PURE__ */ React5.createElement(Icon2, {
|
|
614
|
+
icon: "ph--key--regular"
|
|
615
|
+
})), /* @__PURE__ */ React5.createElement(ListItem.Heading, null, credential.issuanceDate.toLocaleString()))))));
|
|
624
616
|
} finally {
|
|
625
617
|
_effect.f();
|
|
626
618
|
}
|
|
@@ -629,15 +621,16 @@ var RecoveryCredentialsContainer = () => {
|
|
|
629
621
|
// src/components/ResetDialog.tsx
|
|
630
622
|
import { useSignals as _useSignals6 } from "@preact-signals/safe-react/tracking";
|
|
631
623
|
import React6, { useCallback as useCallback5 } from "react";
|
|
632
|
-
import {
|
|
624
|
+
import { LayoutAction as LayoutAction2, createIntent as createIntent4 } from "@dxos/app-framework";
|
|
625
|
+
import { useIntentDispatcher as useIntentDispatcher4 } from "@dxos/app-framework/react";
|
|
633
626
|
import { useClient as useClient3 } from "@dxos/react-client";
|
|
634
627
|
import { Dialog as Dialog2, useTranslation as useTranslation6 } from "@dxos/react-ui";
|
|
635
628
|
import { ConfirmReset } from "@dxos/shell/react";
|
|
636
|
-
var RESET_DIALOG = `${
|
|
629
|
+
var RESET_DIALOG = `${meta.id}/ResetDialog`;
|
|
637
630
|
var ResetDialog = ({ mode, onReset }) => {
|
|
638
631
|
var _effect = _useSignals6();
|
|
639
632
|
try {
|
|
640
|
-
const { t } = useTranslation6(
|
|
633
|
+
const { t } = useTranslation6(meta.id);
|
|
641
634
|
const { dispatchPromise: dispatch } = useIntentDispatcher4();
|
|
642
635
|
const client = useClient3();
|
|
643
636
|
const handleReset = useCallback5(async () => {
|
|
@@ -690,4 +683,4 @@ export {
|
|
|
690
683
|
RESET_DIALOG,
|
|
691
684
|
ResetDialog
|
|
692
685
|
};
|
|
693
|
-
//# sourceMappingURL=chunk-
|
|
686
|
+
//# sourceMappingURL=chunk-4G4YWIUQ.mjs.map
|