@dxos/app-framework 0.8.4-main.e098934 → 0.8.4-main.e8ec1fe
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/.storybook/main.mts +11 -0
- package/.storybook/preview.mts +8 -0
- package/dist/lib/browser/{app-graph-builder-AFFC6VB2.mjs → app-graph-builder-OIEZZC45.mjs} +31 -30
- package/dist/lib/browser/app-graph-builder-OIEZZC45.mjs.map +7 -0
- package/dist/lib/browser/{chunk-ORWHM7CO.mjs → chunk-SCPE4ZO2.mjs} +11 -8
- package/dist/lib/browser/chunk-SCPE4ZO2.mjs.map +7 -0
- package/dist/lib/browser/{chunk-T6M7JB7M.mjs → chunk-VFUKEZIN.mjs} +121 -109
- package/dist/lib/browser/chunk-VFUKEZIN.mjs.map +7 -0
- package/dist/lib/browser/{chunk-OZY7HV2A.mjs → chunk-WPW5VVAX.mjs} +281 -273
- package/dist/lib/browser/chunk-WPW5VVAX.mjs.map +7 -0
- package/dist/lib/browser/index.mjs +14 -56
- package/dist/lib/browser/index.mjs.map +3 -3
- package/dist/lib/browser/{intent-dispatcher-QG7UPGQX.mjs → intent-dispatcher-LZ4AE66E.mjs} +2 -2
- package/dist/lib/browser/{intent-resolver-4S4PSTM5.mjs → intent-resolver-QVCKRX6G.mjs} +7 -7
- package/dist/lib/browser/intent-resolver-QVCKRX6G.mjs.map +7 -0
- package/dist/lib/browser/meta.json +1 -1
- package/dist/lib/browser/react/index.mjs +34 -0
- package/dist/lib/browser/{store-6E33KLGK.mjs → store-CNPHOYTJ.mjs} +5 -5
- package/dist/lib/browser/store-CNPHOYTJ.mjs.map +7 -0
- package/dist/lib/browser/testing/index.mjs +14 -16
- package/dist/lib/browser/testing/index.mjs.map +3 -3
- package/dist/lib/node-esm/{app-graph-builder-S4OAULX5.mjs → app-graph-builder-EBU4NVWD.mjs} +31 -30
- package/dist/lib/node-esm/app-graph-builder-EBU4NVWD.mjs.map +7 -0
- package/dist/lib/node-esm/{chunk-HJFU7QOR.mjs → chunk-IJOHO66N.mjs} +121 -109
- package/dist/lib/node-esm/chunk-IJOHO66N.mjs.map +7 -0
- package/dist/lib/node-esm/{chunk-F63ZRXMK.mjs → chunk-XJZGUJ3H.mjs} +281 -273
- package/dist/lib/node-esm/chunk-XJZGUJ3H.mjs.map +7 -0
- package/dist/lib/node-esm/{chunk-UMZQERLE.mjs → chunk-ZX63QUGE.mjs} +11 -8
- package/dist/lib/node-esm/chunk-ZX63QUGE.mjs.map +7 -0
- package/dist/lib/node-esm/index.mjs +14 -56
- package/dist/lib/node-esm/index.mjs.map +3 -3
- package/dist/lib/node-esm/{intent-dispatcher-NXBGPJOX.mjs → intent-dispatcher-MGOJ3CHD.mjs} +2 -2
- package/dist/lib/node-esm/{intent-resolver-2ZKXI5ET.mjs → intent-resolver-URF3HN3G.mjs} +7 -7
- package/dist/lib/node-esm/intent-resolver-URF3HN3G.mjs.map +7 -0
- package/dist/lib/node-esm/meta.json +1 -1
- package/dist/lib/node-esm/react/index.mjs +35 -0
- package/dist/lib/node-esm/{store-QQUTQHHT.mjs → store-RK5B4XEL.mjs} +5 -5
- package/dist/lib/node-esm/store-RK5B4XEL.mjs.map +7 -0
- package/dist/lib/node-esm/testing/index.mjs +14 -16
- package/dist/lib/node-esm/testing/index.mjs.map +3 -3
- package/dist/types/src/common/capabilities.d.ts +41 -37
- package/dist/types/src/common/capabilities.d.ts.map +1 -1
- package/dist/types/src/common/collaboration.d.ts +1 -1
- package/dist/types/src/common/collaboration.d.ts.map +1 -1
- package/dist/types/src/common/file.d.ts +1 -1
- package/dist/types/src/common/file.d.ts.map +1 -1
- package/dist/types/src/common/layout.d.ts +1 -3
- package/dist/types/src/common/layout.d.ts.map +1 -1
- package/dist/types/src/common/surface.d.ts +19 -16
- package/dist/types/src/common/surface.d.ts.map +1 -1
- package/dist/types/src/common/translations.d.ts +1 -1
- package/dist/types/src/common/translations.d.ts.map +1 -1
- package/dist/types/src/core/capabilities.d.ts +15 -15
- package/dist/types/src/core/capabilities.d.ts.map +1 -1
- package/dist/types/src/core/manager.d.ts +1 -1
- package/dist/types/src/core/manager.d.ts.map +1 -1
- package/dist/types/src/core/plugin.d.ts +8 -1
- package/dist/types/src/core/plugin.d.ts.map +1 -1
- package/dist/types/src/index.d.ts +0 -2
- package/dist/types/src/index.d.ts.map +1 -1
- package/dist/types/src/playground/debug/plugin.d.ts +1 -1
- package/dist/types/src/playground/debug/plugin.d.ts.map +1 -1
- package/dist/types/src/playground/generator/Main.d.ts.map +1 -1
- package/dist/types/src/playground/generator/generator.d.ts +1 -1
- package/dist/types/src/playground/generator/generator.d.ts.map +1 -1
- package/dist/types/src/playground/generator/plugin.d.ts +1 -1
- package/dist/types/src/playground/generator/plugin.d.ts.map +1 -1
- package/dist/types/src/playground/layout/plugin.d.ts +1 -1
- package/dist/types/src/playground/layout/plugin.d.ts.map +1 -1
- package/dist/types/src/playground/logger/plugin.d.ts +1 -1
- package/dist/types/src/playground/logger/plugin.d.ts.map +1 -1
- package/dist/types/src/playground/logger/schema.d.ts +1 -1
- package/dist/types/src/playground/logger/schema.d.ts.map +1 -1
- package/dist/types/src/playground/playground.stories.d.ts +0 -1
- package/dist/types/src/playground/playground.stories.d.ts.map +1 -1
- package/dist/types/src/plugin-intent/IntentPlugin.d.ts +1 -1
- package/dist/types/src/plugin-intent/IntentPlugin.d.ts.map +1 -1
- package/dist/types/src/plugin-intent/actions.d.ts +5 -7
- package/dist/types/src/plugin-intent/actions.d.ts.map +1 -1
- package/dist/types/src/plugin-intent/errors.d.ts.map +1 -1
- package/dist/types/src/plugin-intent/intent-dispatcher.d.ts +4 -4
- package/dist/types/src/plugin-intent/intent-dispatcher.d.ts.map +1 -1
- package/dist/types/src/plugin-intent/intent.d.ts +1 -1
- package/dist/types/src/plugin-intent/intent.d.ts.map +1 -1
- package/dist/types/src/plugin-intent/meta.d.ts +3 -0
- package/dist/types/src/plugin-intent/meta.d.ts.map +1 -0
- package/dist/types/src/plugin-settings/SettingsPlugin.d.ts +1 -1
- package/dist/types/src/plugin-settings/SettingsPlugin.d.ts.map +1 -1
- package/dist/types/src/plugin-settings/actions.d.ts +5 -7
- package/dist/types/src/plugin-settings/actions.d.ts.map +1 -1
- package/dist/types/src/plugin-settings/app-graph-builder.d.ts.map +1 -1
- package/dist/types/src/plugin-settings/meta.d.ts +3 -0
- package/dist/types/src/plugin-settings/meta.d.ts.map +1 -0
- package/dist/types/src/plugin-settings/translations.d.ts +2 -1
- package/dist/types/src/plugin-settings/translations.d.ts.map +1 -1
- package/dist/types/src/react/App.d.ts.map +1 -0
- package/dist/types/src/{components → react}/App.stories.d.ts +0 -1
- package/dist/types/src/react/App.stories.d.ts.map +1 -0
- package/dist/types/src/react/DefaultFallback.d.ts.map +1 -0
- package/dist/types/src/react/ErrorBoundary.d.ts +2 -2
- package/dist/types/src/react/ErrorBoundary.d.ts.map +1 -1
- package/dist/types/src/react/Surface.d.ts +5 -5
- package/dist/types/src/react/Surface.d.ts.map +1 -1
- package/dist/types/src/react/Surface.stories.d.ts +3 -7
- package/dist/types/src/react/Surface.stories.d.ts.map +1 -1
- package/dist/types/src/react/index.d.ts +2 -0
- package/dist/types/src/react/index.d.ts.map +1 -1
- package/dist/types/src/react/types.d.ts +14 -0
- package/dist/types/src/react/types.d.ts.map +1 -0
- package/dist/types/src/{components → react}/useApp.d.ts +2 -2
- package/dist/types/src/react/useApp.d.ts.map +1 -0
- package/dist/types/src/react/useLoading.d.ts.map +1 -0
- package/dist/types/src/testing/withPluginManager.d.ts +6 -7
- package/dist/types/src/testing/withPluginManager.d.ts.map +1 -1
- package/dist/types/tsconfig.tsbuildinfo +1 -1
- package/moon.yml +5 -1
- package/package.json +44 -40
- package/src/common/capabilities.ts +34 -19
- package/src/common/collaboration.ts +3 -3
- package/src/common/file.ts +1 -1
- package/src/common/layout.ts +3 -4
- package/src/common/surface.ts +23 -21
- package/src/common/translations.ts +1 -1
- package/src/core/capabilities.test.ts +2 -2
- package/src/core/capabilities.ts +26 -22
- package/src/core/manager.test.ts +19 -19
- package/src/core/manager.ts +14 -7
- package/src/core/plugin.ts +13 -2
- package/src/index.ts +0 -2
- package/src/playground/debug/plugin.ts +7 -8
- package/src/playground/generator/Main.tsx +0 -1
- package/src/playground/generator/generator.ts +2 -2
- package/src/playground/generator/plugin.ts +12 -13
- package/src/playground/layout/plugin.ts +9 -8
- package/src/playground/logger/plugin.ts +27 -23
- package/src/playground/logger/schema.ts +1 -1
- package/src/playground/playground.stories.tsx +6 -7
- package/src/plugin-intent/IntentPlugin.ts +12 -13
- package/src/plugin-intent/actions.ts +4 -6
- package/src/plugin-intent/errors.ts +2 -1
- package/src/plugin-intent/intent-dispatcher.test.ts +10 -3
- package/src/plugin-intent/intent-dispatcher.ts +13 -6
- package/src/plugin-intent/intent.ts +1 -1
- package/src/plugin-intent/meta.ts +10 -0
- package/src/plugin-settings/SettingsPlugin.ts +25 -27
- package/src/plugin-settings/actions.ts +9 -13
- package/src/plugin-settings/app-graph-builder.ts +22 -20
- package/src/plugin-settings/intent-resolver.ts +2 -2
- package/src/plugin-settings/meta.ts +10 -0
- package/src/plugin-settings/store.ts +2 -2
- package/src/plugin-settings/translations.ts +4 -4
- package/src/{components → react}/App.stories.tsx +1 -3
- package/src/{components → react}/App.tsx +1 -1
- package/src/{components → react}/DefaultFallback.tsx +1 -1
- package/src/react/ErrorBoundary.tsx +10 -8
- package/src/react/Surface.stories.tsx +70 -49
- package/src/react/Surface.tsx +67 -36
- package/src/react/index.ts +4 -0
- package/src/react/types.ts +37 -0
- package/src/{components → react}/useApp.tsx +23 -24
- package/src/react/useCapabilities.ts +2 -2
- package/src/testing/withPluginManager.stories.tsx +1 -1
- package/src/testing/withPluginManager.tsx +22 -21
- package/tsconfig.json +10 -1
- package/vitest.config.ts +8 -6
- package/dist/lib/browser/app-graph-builder-AFFC6VB2.mjs.map +0 -7
- package/dist/lib/browser/chunk-ORWHM7CO.mjs.map +0 -7
- package/dist/lib/browser/chunk-OZY7HV2A.mjs.map +0 -7
- package/dist/lib/browser/chunk-T6M7JB7M.mjs.map +0 -7
- package/dist/lib/browser/intent-resolver-4S4PSTM5.mjs.map +0 -7
- package/dist/lib/browser/store-6E33KLGK.mjs.map +0 -7
- package/dist/lib/browser/worker.mjs +0 -85
- package/dist/lib/node-esm/app-graph-builder-S4OAULX5.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-F63ZRXMK.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-HJFU7QOR.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-UMZQERLE.mjs.map +0 -7
- package/dist/lib/node-esm/intent-resolver-2ZKXI5ET.mjs.map +0 -7
- package/dist/lib/node-esm/store-QQUTQHHT.mjs.map +0 -7
- package/dist/lib/node-esm/worker.mjs +0 -86
- package/dist/types/src/components/App.d.ts.map +0 -1
- package/dist/types/src/components/App.stories.d.ts.map +0 -1
- package/dist/types/src/components/DefaultFallback.d.ts.map +0 -1
- package/dist/types/src/components/index.d.ts +0 -2
- package/dist/types/src/components/index.d.ts.map +0 -1
- package/dist/types/src/components/useApp.d.ts.map +0 -1
- package/dist/types/src/components/useLoading.d.ts.map +0 -1
- package/dist/types/src/worker.d.ts +0 -4
- package/dist/types/src/worker.d.ts.map +0 -1
- package/src/components/index.ts +0 -5
- package/src/worker.ts +0 -11
- /package/dist/lib/browser/{intent-dispatcher-QG7UPGQX.mjs.map → intent-dispatcher-LZ4AE66E.mjs.map} +0 -0
- /package/dist/lib/browser/{worker.mjs.map → react/index.mjs.map} +0 -0
- /package/dist/lib/node-esm/{intent-dispatcher-NXBGPJOX.mjs.map → intent-dispatcher-MGOJ3CHD.mjs.map} +0 -0
- /package/dist/lib/node-esm/{worker.mjs.map → react/index.mjs.map} +0 -0
- /package/dist/types/src/{components → react}/App.d.ts +0 -0
- /package/dist/types/src/{components → react}/DefaultFallback.d.ts +0 -0
- /package/dist/types/src/{components → react}/useLoading.d.ts +0 -0
- /package/src/{components → react}/useLoading.tsx +0 -0
|
@@ -1,26 +1,27 @@
|
|
|
1
1
|
import {
|
|
2
2
|
SETTINGS_ID,
|
|
3
3
|
SETTINGS_KEY,
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
} from "./chunk-
|
|
4
|
+
SettingsAction,
|
|
5
|
+
meta
|
|
6
|
+
} from "./chunk-SCPE4ZO2.mjs";
|
|
7
7
|
import {
|
|
8
8
|
Capabilities,
|
|
9
9
|
contributes,
|
|
10
10
|
createIntent
|
|
11
|
-
} from "./chunk-
|
|
11
|
+
} from "./chunk-WPW5VVAX.mjs";
|
|
12
12
|
|
|
13
13
|
// src/plugin-settings/app-graph-builder.ts
|
|
14
|
-
import {
|
|
15
|
-
import
|
|
14
|
+
import { Atom } from "@effect-atom/atom-react";
|
|
15
|
+
import * as Function from "effect/Function";
|
|
16
|
+
import * as Option from "effect/Option";
|
|
16
17
|
import { ROOT_ID, createExtension } from "@dxos/app-graph";
|
|
17
18
|
import { isNonNullable } from "@dxos/util";
|
|
18
|
-
var app_graph_builder_default = (context) => contributes(Capabilities.AppGraphBuilder, [
|
|
19
|
+
var app_graph_builder_default = ((context) => contributes(Capabilities.AppGraphBuilder, [
|
|
19
20
|
createExtension({
|
|
20
|
-
id: `${
|
|
21
|
-
actions: (node) =>
|
|
21
|
+
id: `${meta.id}/action`,
|
|
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
|
{
|
|
23
|
-
id:
|
|
24
|
+
id: meta.id,
|
|
24
25
|
data: async () => {
|
|
25
26
|
const { dispatchPromise: dispatch } = context.getCapability(Capabilities.IntentDispatcher);
|
|
26
27
|
await dispatch(createIntent(SettingsAction.Open));
|
|
@@ -29,7 +30,7 @@ var app_graph_builder_default = (context) => contributes(Capabilities.AppGraphBu
|
|
|
29
30
|
label: [
|
|
30
31
|
"open settings label",
|
|
31
32
|
{
|
|
32
|
-
ns:
|
|
33
|
+
ns: meta.id
|
|
33
34
|
}
|
|
34
35
|
],
|
|
35
36
|
icon: "ph--gear--regular",
|
|
@@ -43,16 +44,16 @@ var app_graph_builder_default = (context) => contributes(Capabilities.AppGraphBu
|
|
|
43
44
|
]), Option.getOrElse(() => [])))
|
|
44
45
|
}),
|
|
45
46
|
createExtension({
|
|
46
|
-
id: `${
|
|
47
|
-
connector: (node) =>
|
|
47
|
+
id: `${meta.id}/core`,
|
|
48
|
+
connector: (node) => Atom.make((get) => Function.pipe(get(node), Option.flatMap((node2) => node2.id === ROOT_ID ? Option.some(node2) : Option.none()), Option.map(() => [
|
|
48
49
|
{
|
|
49
50
|
id: SETTINGS_ID,
|
|
50
|
-
type:
|
|
51
|
+
type: meta.id,
|
|
51
52
|
properties: {
|
|
52
53
|
label: [
|
|
53
54
|
"app settings label",
|
|
54
55
|
{
|
|
55
|
-
ns:
|
|
56
|
+
ns: meta.id
|
|
56
57
|
}
|
|
57
58
|
],
|
|
58
59
|
icon: "ph--gear--regular",
|
|
@@ -64,8 +65,8 @@ var app_graph_builder_default = (context) => contributes(Capabilities.AppGraphBu
|
|
|
64
65
|
]), Option.getOrElse(() => [])))
|
|
65
66
|
}),
|
|
66
67
|
createExtension({
|
|
67
|
-
id: `${
|
|
68
|
-
connector: (node) =>
|
|
68
|
+
id: `${meta.id}/core-plugins`,
|
|
69
|
+
connector: (node) => Atom.make((get) => Function.pipe(get(node), Option.flatMap((node2) => node2.id !== SETTINGS_ID ? Option.none() : Option.some(node2)), Option.map(() => {
|
|
69
70
|
const manager = get(context.capability(Capabilities.PluginManager));
|
|
70
71
|
const [settingsStore] = get(context.capabilities(Capabilities.SettingsStore));
|
|
71
72
|
return [
|
|
@@ -78,13 +79,13 @@ var app_graph_builder_default = (context) => contributes(Capabilities.AppGraphBu
|
|
|
78
79
|
plugin.meta,
|
|
79
80
|
settings
|
|
80
81
|
];
|
|
81
|
-
}).filter(isNonNullable).map(([
|
|
82
|
-
id: `${SETTINGS_KEY}:${
|
|
82
|
+
}).filter(isNonNullable).map(([meta2, settings]) => ({
|
|
83
|
+
id: `${SETTINGS_KEY}:${meta2.id.replaceAll("/", ":")}`,
|
|
83
84
|
type: "category",
|
|
84
85
|
data: settings,
|
|
85
86
|
properties: {
|
|
86
|
-
label:
|
|
87
|
-
icon:
|
|
87
|
+
label: meta2.name ?? meta2.id,
|
|
88
|
+
icon: meta2.icon ?? "ph--circle--regular"
|
|
88
89
|
}
|
|
89
90
|
})),
|
|
90
91
|
{
|
|
@@ -94,7 +95,7 @@ var app_graph_builder_default = (context) => contributes(Capabilities.AppGraphBu
|
|
|
94
95
|
label: [
|
|
95
96
|
"custom plugins label",
|
|
96
97
|
{
|
|
97
|
-
ns:
|
|
98
|
+
ns: meta.id
|
|
98
99
|
}
|
|
99
100
|
],
|
|
100
101
|
icon: "ph--squares-four--regular",
|
|
@@ -106,8 +107,8 @@ var app_graph_builder_default = (context) => contributes(Capabilities.AppGraphBu
|
|
|
106
107
|
}), Option.getOrElse(() => [])))
|
|
107
108
|
}),
|
|
108
109
|
createExtension({
|
|
109
|
-
id: `${
|
|
110
|
-
connector: (node) =>
|
|
110
|
+
id: `${meta.id}/custom-plugins`,
|
|
111
|
+
connector: (node) => Atom.make((get) => Function.pipe(get(node), Option.flatMap((node2) => node2.id !== `${SETTINGS_KEY}:custom-plugins` ? Option.none() : Option.some(node2)), Option.map(() => {
|
|
111
112
|
const manager = get(context.capability(Capabilities.PluginManager));
|
|
112
113
|
const [settingsStore] = get(context.capabilities(Capabilities.SettingsStore));
|
|
113
114
|
return manager.plugins.filter((plugin) => !manager.core.includes(plugin.meta.id)).map((plugin) => {
|
|
@@ -119,19 +120,19 @@ var app_graph_builder_default = (context) => contributes(Capabilities.AppGraphBu
|
|
|
119
120
|
plugin.meta,
|
|
120
121
|
settings
|
|
121
122
|
];
|
|
122
|
-
}).filter(isNonNullable).map(([
|
|
123
|
-
id: `${SETTINGS_KEY}:${
|
|
123
|
+
}).filter(isNonNullable).map(([meta2, settings]) => ({
|
|
124
|
+
id: `${SETTINGS_KEY}:${meta2.id.replaceAll("/", ":")}`,
|
|
124
125
|
type: "category",
|
|
125
126
|
data: settings,
|
|
126
127
|
properties: {
|
|
127
|
-
label:
|
|
128
|
-
icon:
|
|
128
|
+
label: meta2.name ?? meta2.id,
|
|
129
|
+
icon: meta2.icon ?? "ph--circle--regular"
|
|
129
130
|
}
|
|
130
131
|
}));
|
|
131
132
|
}), Option.getOrElse(() => [])))
|
|
132
133
|
})
|
|
133
|
-
]);
|
|
134
|
+
]));
|
|
134
135
|
export {
|
|
135
136
|
app_graph_builder_default as default
|
|
136
137
|
};
|
|
137
|
-
//# sourceMappingURL=app-graph-builder-
|
|
138
|
+
//# sourceMappingURL=app-graph-builder-OIEZZC45.mjs.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../src/plugin-settings/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 { ROOT_ID, createExtension } from '@dxos/app-graph';\nimport { type SettingsStore, type SettingsValue } from '@dxos/local-storage';\nimport { isNonNullable } from '@dxos/util';\n\nimport { Capabilities } from '../common';\nimport { type PluginContext, type PluginMeta, contributes } from '../core';\nimport { createIntent } from '../plugin-intent';\n\nimport { SETTINGS_ID, SETTINGS_KEY, SettingsAction } from './actions';\nimport { meta } from './meta';\n\nexport default (context: PluginContext) =>\n contributes(Capabilities.AppGraphBuilder, [\n createExtension({\n id: `${meta.id}/action`,\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 {\n id: meta.id,\n data: async () => {\n const { dispatchPromise: dispatch } = context.getCapability(Capabilities.IntentDispatcher);\n await dispatch(createIntent(SettingsAction.Open));\n },\n properties: {\n label: ['open settings label', { ns: meta.id }],\n icon: 'ph--gear--regular',\n disposition: 'menu',\n keyBinding: {\n macos: 'meta+,',\n windows: 'alt+,',\n },\n },\n },\n ]),\n Option.getOrElse(() => []),\n ),\n ),\n }),\n createExtension({\n id: `${meta.id}/core`,\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 {\n id: SETTINGS_ID,\n type: meta.id,\n properties: {\n label: ['app settings label', { ns: meta.id }],\n icon: 'ph--gear--regular',\n disposition: 'pin-end',\n position: 'hoist',\n testId: 'treeView.appSettings',\n },\n },\n ]),\n Option.getOrElse(() => []),\n ),\n ),\n }),\n createExtension({\n id: `${meta.id}/core-plugins`,\n connector: (node) =>\n Atom.make((get) =>\n Function.pipe(\n get(node),\n Option.flatMap((node) => (node.id !== SETTINGS_ID ? Option.none() : Option.some(node))),\n Option.map(() => {\n const manager = get(context.capability(Capabilities.PluginManager));\n const [settingsStore] = get(context.capabilities(Capabilities.SettingsStore));\n return [\n ...manager.plugins\n .filter((plugin) => manager.core.includes(plugin.meta.id))\n .map((plugin): [PluginMeta, SettingsStore<SettingsValue>] | null => {\n const settings = settingsStore?.getStore(plugin.meta.id);\n if (!settings) {\n return null;\n }\n\n return [plugin.meta, settings];\n })\n .filter(isNonNullable)\n .map(([meta, settings]) => ({\n id: `${SETTINGS_KEY}:${meta.id.replaceAll('/', ':')}`,\n type: 'category',\n data: settings,\n properties: {\n label: meta.name ?? meta.id,\n icon: meta.icon ?? 'ph--circle--regular',\n },\n })),\n\n {\n id: `${SETTINGS_KEY}:custom-plugins`,\n type: 'category',\n properties: {\n label: ['custom plugins label', { ns: meta.id }],\n icon: 'ph--squares-four--regular',\n role: 'branch',\n disposition: 'collection',\n },\n },\n ];\n }),\n Option.getOrElse(() => []),\n ),\n ),\n }),\n createExtension({\n id: `${meta.id}/custom-plugins`,\n connector: (node) =>\n Atom.make((get) =>\n Function.pipe(\n get(node),\n Option.flatMap((node) =>\n node.id !== `${SETTINGS_KEY}:custom-plugins` ? Option.none() : Option.some(node),\n ),\n Option.map(() => {\n const manager = get(context.capability(Capabilities.PluginManager));\n const [settingsStore] = get(context.capabilities(Capabilities.SettingsStore));\n return manager.plugins\n .filter((plugin) => !manager.core.includes(plugin.meta.id))\n .map((plugin): [PluginMeta, SettingsStore<SettingsValue>] | null => {\n const settings = settingsStore?.getStore(plugin.meta.id);\n if (!settings) {\n return null;\n }\n\n return [plugin.meta, settings];\n })\n .filter(isNonNullable)\n .map(([meta, settings]) => ({\n id: `${SETTINGS_KEY}:${meta.id.replaceAll('/', ':')}`,\n type: 'category',\n data: settings,\n properties: {\n label: meta.name ?? meta.id,\n icon: meta.icon ?? 'ph--circle--regular',\n },\n }));\n }),\n Option.getOrElse(() => []),\n ),\n ),\n }),\n ]);\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
|
+
"names": ["Atom", "Function", "Option", "ROOT_ID", "createExtension", "isNonNullable", "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", "SettingsAction", "Open", "properties", "label", "ns", "icon", "disposition", "keyBinding", "macos", "windows", "getOrElse", "connector", "SETTINGS_ID", "type", "position", "testId", "manager", "capability", "PluginManager", "settingsStore", "capabilities", "SettingsStore", "plugins", "filter", "plugin", "core", "includes", "settings", "getStore", "isNonNullable", "SETTINGS_KEY", "replaceAll", "name", "role"]
|
|
7
|
+
}
|
|
@@ -1,11 +1,15 @@
|
|
|
1
|
+
// src/plugin-settings/meta.ts
|
|
2
|
+
var meta = {
|
|
3
|
+
id: "dxos.org/plugin/settings",
|
|
4
|
+
name: "Settings"
|
|
5
|
+
};
|
|
6
|
+
|
|
1
7
|
// src/plugin-settings/actions.ts
|
|
2
|
-
import
|
|
3
|
-
var SETTINGS_PLUGIN = "dxos.org/plugin/settings";
|
|
4
|
-
var SETTINGS_ACTION = `${SETTINGS_PLUGIN}/action`;
|
|
8
|
+
import * as Schema from "effect/Schema";
|
|
5
9
|
var SETTINGS_ID = "!dxos:settings";
|
|
6
10
|
var SETTINGS_KEY = "settings";
|
|
7
11
|
(function(SettingsAction2) {
|
|
8
|
-
class Open extends Schema.TaggedClass()(`${
|
|
12
|
+
class Open extends Schema.TaggedClass()(`${meta.id}/open`, {
|
|
9
13
|
input: Schema.Struct({
|
|
10
14
|
plugin: Schema.optional(Schema.String)
|
|
11
15
|
}),
|
|
@@ -13,7 +17,7 @@ var SETTINGS_KEY = "settings";
|
|
|
13
17
|
}) {
|
|
14
18
|
}
|
|
15
19
|
SettingsAction2.Open = Open;
|
|
16
|
-
class OpenPluginRegistry extends Schema.TaggedClass()(`${
|
|
20
|
+
class OpenPluginRegistry extends Schema.TaggedClass()(`${meta.id}/open-plugin-registry`, {
|
|
17
21
|
input: Schema.Void,
|
|
18
22
|
output: Schema.Void
|
|
19
23
|
}) {
|
|
@@ -23,10 +27,9 @@ var SETTINGS_KEY = "settings";
|
|
|
23
27
|
var SettingsAction;
|
|
24
28
|
|
|
25
29
|
export {
|
|
26
|
-
|
|
27
|
-
SETTINGS_ACTION,
|
|
30
|
+
meta,
|
|
28
31
|
SETTINGS_ID,
|
|
29
32
|
SETTINGS_KEY,
|
|
30
33
|
SettingsAction
|
|
31
34
|
};
|
|
32
|
-
//# sourceMappingURL=chunk-
|
|
35
|
+
//# sourceMappingURL=chunk-SCPE4ZO2.mjs.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../src/plugin-settings/meta.ts", "../../../src/plugin-settings/actions.ts"],
|
|
4
|
+
"sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport { type PluginMeta } from '@dxos/app-framework';\n\nexport const meta: PluginMeta = {\n id: 'dxos.org/plugin/settings',\n name: 'Settings',\n};\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport * as Schema from 'effect/Schema';\n\nimport { meta } from './meta';\n\n// TODO(burdon): Document.\nexport const SETTINGS_ID = '!dxos:settings';\nexport const SETTINGS_KEY = 'settings';\n\nexport namespace SettingsAction {\n export class Open extends Schema.TaggedClass<Open>()(`${meta.id}/open`, {\n input: Schema.Struct({\n plugin: Schema.optional(Schema.String),\n }),\n output: Schema.Void,\n }) {}\n\n export class OpenPluginRegistry extends Schema.TaggedClass<OpenPluginRegistry>()(`${meta.id}/open-plugin-registry`, {\n input: Schema.Void,\n output: Schema.Void,\n }) {}\n}\n"],
|
|
5
|
+
"mappings": ";AAMO,IAAMA,OAAmB;EAC9BC,IAAI;EACJC,MAAM;AACR;;;ACLA,YAAYC,YAAY;AAKjB,IAAMC,cAAc;AACpB,IAAMC,eAAe;UAEXC,iBAAAA;EACR,MAAMC,aAAoBC,mBAAW,EAAS,GAAGC,KAAKC,EAAE,SAAS;IACtEC,OAAcC,cAAO;MACnBC,QAAeC,gBAAgBC,aAAM;IACvC,CAAA;IACAC,QAAeC;EACjB,CAAA,EAAA;EAAI;kBALSV,OAAAA;EAON,MAAMW,2BAAkCV,mBAAW,EAAuB,GAAGC,KAAKC,EAAE,yBAAyB;IAClHC,OAAcM;IACdD,QAAeC;EACjB,CAAA,EAAA;EAAI;kBAHSC,qBAAAA;AAIf,GAZiBZ,mBAAAA,iBAAAA,CAAAA,EAAAA;;",
|
|
6
|
+
"names": ["meta", "id", "name", "Schema", "SETTINGS_ID", "SETTINGS_KEY", "SettingsAction", "Open", "TaggedClass", "meta", "id", "input", "Struct", "plugin", "optional", "String", "output", "Void", "OpenPluginRegistry"]
|
|
7
|
+
}
|
|
@@ -2,7 +2,11 @@ import {
|
|
|
2
2
|
Capabilities,
|
|
3
3
|
Events,
|
|
4
4
|
PluginManager
|
|
5
|
-
} from "./chunk-
|
|
5
|
+
} from "./chunk-WPW5VVAX.mjs";
|
|
6
|
+
|
|
7
|
+
// src/react/useCapabilities.ts
|
|
8
|
+
import { useAtomValue } from "@effect-atom/atom-react";
|
|
9
|
+
import { invariant } from "@dxos/invariant";
|
|
6
10
|
|
|
7
11
|
// src/react/PluginManagerProvider.ts
|
|
8
12
|
import { createContext, useContext } from "react";
|
|
@@ -12,12 +16,10 @@ var usePluginManager = () => useContext(PluginManagerContext) ?? raise(new Error
|
|
|
12
16
|
var PluginManagerProvider = PluginManagerContext.Provider;
|
|
13
17
|
|
|
14
18
|
// src/react/useCapabilities.ts
|
|
15
|
-
import { useRxValue } from "@effect-rx/rx-react";
|
|
16
|
-
import { invariant } from "@dxos/invariant";
|
|
17
19
|
var __dxlog_file = "/__w/dxos/dxos/packages/sdk/app-framework/src/react/useCapabilities.ts";
|
|
18
20
|
var useCapabilities = (interfaceDef) => {
|
|
19
21
|
const manager = usePluginManager();
|
|
20
|
-
return
|
|
22
|
+
return useAtomValue(manager.context.capabilities(interfaceDef));
|
|
21
23
|
};
|
|
22
24
|
var useCapability = (interfaceDef) => {
|
|
23
25
|
const capabilities = useCapabilities(interfaceDef);
|
|
@@ -38,28 +40,22 @@ var useIntentDispatcher = () => useCapability(Capabilities.IntentDispatcher);
|
|
|
38
40
|
var useAppGraph = () => useCapability(Capabilities.AppGraph);
|
|
39
41
|
var useLayout = () => useCapability(Capabilities.Layout);
|
|
40
42
|
|
|
43
|
+
// src/react/types.ts
|
|
44
|
+
import * as Schema from "effect/Schema";
|
|
45
|
+
var SurfaceCardRole = Schema.Literal("card", "card--popover", "card--intrinsic", "card--extrinsic", "card--transclusion");
|
|
46
|
+
|
|
41
47
|
// src/react/ErrorBoundary.tsx
|
|
42
48
|
import { useSignals as _useSignals } from "@preact-signals/safe-react/tracking";
|
|
43
49
|
import React, { Component } from "react";
|
|
44
|
-
function _define_property(obj, key, value) {
|
|
45
|
-
if (key in obj) {
|
|
46
|
-
Object.defineProperty(obj, key, {
|
|
47
|
-
value,
|
|
48
|
-
enumerable: true,
|
|
49
|
-
configurable: true,
|
|
50
|
-
writable: true
|
|
51
|
-
});
|
|
52
|
-
} else {
|
|
53
|
-
obj[key] = value;
|
|
54
|
-
}
|
|
55
|
-
return obj;
|
|
56
|
-
}
|
|
57
50
|
var ErrorBoundary = class extends Component {
|
|
58
51
|
static getDerivedStateFromError(error) {
|
|
59
52
|
return {
|
|
60
53
|
error
|
|
61
54
|
};
|
|
62
55
|
}
|
|
56
|
+
state = {
|
|
57
|
+
error: void 0
|
|
58
|
+
};
|
|
63
59
|
componentDidUpdate(prevProps) {
|
|
64
60
|
if (prevProps.data !== this.props.data) {
|
|
65
61
|
this.resetError();
|
|
@@ -80,21 +76,16 @@ var ErrorBoundary = class extends Component {
|
|
|
80
76
|
error: void 0
|
|
81
77
|
});
|
|
82
78
|
}
|
|
83
|
-
constructor(...args) {
|
|
84
|
-
super(...args), _define_property(this, "state", {
|
|
85
|
-
error: void 0
|
|
86
|
-
});
|
|
87
|
-
}
|
|
88
79
|
};
|
|
89
80
|
var DefaultFallback = ({ data, error }) => {
|
|
90
81
|
var _effect = _useSignals();
|
|
91
82
|
try {
|
|
92
83
|
return /* @__PURE__ */ React.createElement("div", {
|
|
93
84
|
className: "flex flex-col gap-2 overflow-hidden border border-red-500 rounded-sm"
|
|
94
|
-
}, /* @__PURE__ */ React.createElement("
|
|
95
|
-
className: "
|
|
85
|
+
}, /* @__PURE__ */ React.createElement("h1", {
|
|
86
|
+
className: "p-2"
|
|
96
87
|
}, "ERROR: ", error.message), /* @__PURE__ */ React.createElement("pre", {
|
|
97
|
-
className: "
|
|
88
|
+
className: "p-2 overflow-y-auto text-sm text-subdued"
|
|
98
89
|
}, JSON.stringify(data, null, 2)));
|
|
99
90
|
} finally {
|
|
100
91
|
_effect.f();
|
|
@@ -107,34 +98,17 @@ import React2, { Fragment, Suspense, forwardRef, memo, useMemo } from "react";
|
|
|
107
98
|
import { useDefaultValue } from "@dxos/react-hooks";
|
|
108
99
|
import { byPosition } from "@dxos/util";
|
|
109
100
|
var DEFAULT_PLACEHOLDER = /* @__PURE__ */ React2.createElement(Fragment, null);
|
|
110
|
-
var
|
|
111
|
-
const surfaces = useCapabilities(Capabilities.ReactSurface);
|
|
112
|
-
return useMemo(() => surfaces.flat(), [
|
|
113
|
-
surfaces
|
|
114
|
-
]);
|
|
115
|
-
};
|
|
116
|
-
var findCandidates = (surfaces, { role, data }) => {
|
|
117
|
-
return Object.values(surfaces).filter((definition) => Array.isArray(definition.role) ? definition.role.includes(role) : definition.role === role).filter(({ filter }) => filter ? filter(data ?? {}) : true).toSorted(byPosition);
|
|
118
|
-
};
|
|
119
|
-
var isSurfaceAvailable = (context, { role, data }) => {
|
|
120
|
-
const surfaces = context.getCapabilities(Capabilities.ReactSurface);
|
|
121
|
-
const candidates = findCandidates(surfaces.flat(), {
|
|
122
|
-
role,
|
|
123
|
-
data
|
|
124
|
-
});
|
|
125
|
-
return candidates.length > 0;
|
|
126
|
-
};
|
|
127
|
-
var Surface = /* @__PURE__ */ memo(/* @__PURE__ */ forwardRef(({ id: _id, role, data: _data, limit, fallback, placeholder = DEFAULT_PLACEHOLDER, ...rest }, forwardedRef) => {
|
|
101
|
+
var Surface = /* @__PURE__ */ memo(/* @__PURE__ */ forwardRef(({ id: _id, role, data: dataParam, limit, fallback = DefaultFallback2, placeholder = DEFAULT_PLACEHOLDER, ...rest }, forwardedRef) => {
|
|
128
102
|
var _effect = _useSignals2();
|
|
129
103
|
try {
|
|
130
104
|
const surfaces = useSurfaces();
|
|
131
|
-
const data = useDefaultValue(
|
|
105
|
+
const data = useDefaultValue(dataParam, () => ({}));
|
|
132
106
|
const definitions = findCandidates(surfaces, {
|
|
133
107
|
role,
|
|
134
108
|
data
|
|
135
109
|
});
|
|
136
110
|
const candidates = limit ? definitions.slice(0, limit) : definitions;
|
|
137
|
-
const nodes = candidates.map(({ component: Component2
|
|
111
|
+
const nodes = candidates.map(({ id, component: Component2 }) => /* @__PURE__ */ React2.createElement(Component2, {
|
|
138
112
|
ref: forwardedRef,
|
|
139
113
|
key: id,
|
|
140
114
|
id,
|
|
@@ -146,42 +120,67 @@ var Surface = /* @__PURE__ */ memo(/* @__PURE__ */ forwardRef(({ id: _id, role,
|
|
|
146
120
|
const suspense = /* @__PURE__ */ React2.createElement(Suspense, {
|
|
147
121
|
fallback: placeholder
|
|
148
122
|
}, nodes);
|
|
149
|
-
return
|
|
123
|
+
return /* @__PURE__ */ React2.createElement(ErrorBoundary, {
|
|
150
124
|
data,
|
|
151
125
|
fallback
|
|
152
|
-
}, suspense)
|
|
126
|
+
}, suspense);
|
|
153
127
|
} finally {
|
|
154
128
|
_effect.f();
|
|
155
129
|
}
|
|
156
130
|
}));
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
}
|
|
169
|
-
return
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
|
|
131
|
+
var DefaultFallback2 = ({ data, error, dev }) => {
|
|
132
|
+
var _effect = _useSignals2();
|
|
133
|
+
try {
|
|
134
|
+
if (dev) {
|
|
135
|
+
return /* @__PURE__ */ React2.createElement("div", {
|
|
136
|
+
className: "flex flex-col gap-4 p-4 is-full overflow-y-auto"
|
|
137
|
+
}, /* @__PURE__ */ React2.createElement("h1", {
|
|
138
|
+
className: "flex gap-2 text-sm mbs-2"
|
|
139
|
+
}, error.message), /* @__PURE__ */ React2.createElement("pre", {
|
|
140
|
+
className: "overflow-auto text-xs text-description"
|
|
141
|
+
}, JSON.stringify(data, null, 2)));
|
|
142
|
+
}
|
|
143
|
+
return /* @__PURE__ */ React2.createElement("div", {
|
|
144
|
+
className: "flex flex-col gap-4 p-4 is-full overflow-y-auto border border-roseFill"
|
|
145
|
+
}, /* @__PURE__ */ React2.createElement("h1", {
|
|
146
|
+
className: "flex gap-2 text-sm mbs-2 text-rose-500"
|
|
147
|
+
}, error.message), /* @__PURE__ */ React2.createElement("pre", {
|
|
148
|
+
className: "overflow-auto text-xs text-description"
|
|
149
|
+
}, error.stack), /* @__PURE__ */ React2.createElement("pre", {
|
|
150
|
+
className: "overflow-auto text-xs text-description"
|
|
151
|
+
}, JSON.stringify(data, null, 2)));
|
|
152
|
+
} finally {
|
|
153
|
+
_effect.f();
|
|
154
|
+
}
|
|
155
|
+
};
|
|
156
|
+
var useSurfaces = () => {
|
|
157
|
+
const surfaces = useCapabilities(Capabilities.ReactSurface);
|
|
158
|
+
return useMemo(() => surfaces.flat(), [
|
|
159
|
+
surfaces
|
|
173
160
|
]);
|
|
174
161
|
};
|
|
162
|
+
var isSurfaceAvailable = (context, { role, data }) => {
|
|
163
|
+
const surfaces = context.getCapabilities(Capabilities.ReactSurface);
|
|
164
|
+
const candidates = findCandidates(surfaces.flat(), {
|
|
165
|
+
role,
|
|
166
|
+
data
|
|
167
|
+
});
|
|
168
|
+
return candidates.length > 0;
|
|
169
|
+
};
|
|
170
|
+
var findCandidates = (surfaces, { role, data }) => {
|
|
171
|
+
return Object.values(surfaces).filter((definition) => Array.isArray(definition.role) ? definition.role.includes(role) : definition.role === role).filter(({ filter }) => filter ? filter(data ?? {}) : true).toSorted(byPosition);
|
|
172
|
+
};
|
|
173
|
+
Surface.displayName = "Surface";
|
|
175
174
|
|
|
176
|
-
// src/
|
|
177
|
-
import { RegistryContext } from "@effect-
|
|
175
|
+
// src/react/useApp.tsx
|
|
176
|
+
import { RegistryContext } from "@effect-atom/atom-react";
|
|
178
177
|
import { effect } from "@preact/signals-core";
|
|
179
|
-
import React5, { useCallback, useEffect as
|
|
178
|
+
import React5, { useCallback, useEffect as useEffect2, useMemo as useMemo2 } from "react";
|
|
180
179
|
import { invariant as invariant2 } from "@dxos/invariant";
|
|
181
180
|
import { live } from "@dxos/live-object";
|
|
182
181
|
import { useAsyncEffect, useDefaultValue as useDefaultValue2 } from "@dxos/react-hooks";
|
|
183
182
|
|
|
184
|
-
// src/
|
|
183
|
+
// src/react/App.tsx
|
|
185
184
|
import { useSignals as _useSignals3 } from "@preact-signals/safe-react/tracking";
|
|
186
185
|
import React3 from "react";
|
|
187
186
|
|
|
@@ -216,18 +215,18 @@ var topologicalSort = (nodes) => {
|
|
|
216
215
|
return allDependencies.map((id) => nodes.find((node) => node.id === id)).filter((node) => node !== void 0);
|
|
217
216
|
};
|
|
218
217
|
|
|
219
|
-
// src/
|
|
220
|
-
import { useEffect
|
|
221
|
-
var LoadingState = /* @__PURE__ */ function(LoadingState2) {
|
|
218
|
+
// src/react/useLoading.tsx
|
|
219
|
+
import { useEffect, useState } from "react";
|
|
220
|
+
var LoadingState = /* @__PURE__ */ (function(LoadingState2) {
|
|
222
221
|
LoadingState2[LoadingState2["Loading"] = 0] = "Loading";
|
|
223
222
|
LoadingState2[LoadingState2["FadeIn"] = 1] = "FadeIn";
|
|
224
223
|
LoadingState2[LoadingState2["FadeOut"] = 2] = "FadeOut";
|
|
225
224
|
LoadingState2[LoadingState2["Done"] = 3] = "Done";
|
|
226
225
|
return LoadingState2;
|
|
227
|
-
}({});
|
|
226
|
+
})({});
|
|
228
227
|
var useLoading = (state, debounce = 0) => {
|
|
229
228
|
const [stage, setStage] = useState(0);
|
|
230
|
-
|
|
229
|
+
useEffect(() => {
|
|
231
230
|
if (!debounce) {
|
|
232
231
|
return;
|
|
233
232
|
}
|
|
@@ -266,7 +265,7 @@ var useLoading = (state, debounce = 0) => {
|
|
|
266
265
|
return stage;
|
|
267
266
|
};
|
|
268
267
|
|
|
269
|
-
// src/
|
|
268
|
+
// src/react/App.tsx
|
|
270
269
|
var App = ({ placeholder: Placeholder, state, debounce }) => {
|
|
271
270
|
var _effect = _useSignals3();
|
|
272
271
|
try {
|
|
@@ -299,10 +298,10 @@ var composeContexts = (contexts) => {
|
|
|
299
298
|
return topologicalSort(contexts).map(({ context }) => context).reduce((Acc, Next) => ({ children }) => /* @__PURE__ */ React3.createElement(Acc, null, /* @__PURE__ */ React3.createElement(Next, null, children)));
|
|
300
299
|
};
|
|
301
300
|
|
|
302
|
-
// src/
|
|
301
|
+
// src/react/DefaultFallback.tsx
|
|
303
302
|
import { useSignals as _useSignals4 } from "@preact-signals/safe-react/tracking";
|
|
304
303
|
import React4 from "react";
|
|
305
|
-
var
|
|
304
|
+
var DefaultFallback3 = ({ error }) => {
|
|
306
305
|
var _effect = _useSignals4();
|
|
307
306
|
try {
|
|
308
307
|
return /* @__PURE__ */ React4.createElement("div", {
|
|
@@ -318,7 +317,7 @@ var DefaultFallback2 = ({ error }) => {
|
|
|
318
317
|
margin: "0.5rem 0",
|
|
319
318
|
fontSize: "1.2rem"
|
|
320
319
|
}
|
|
321
|
-
}, "
|
|
320
|
+
}, "ERROR: ", error.message), /* @__PURE__ */ React4.createElement("pre", {
|
|
322
321
|
style: {
|
|
323
322
|
overflow: "auto",
|
|
324
323
|
fontSize: "1rem",
|
|
@@ -331,18 +330,18 @@ var DefaultFallback2 = ({ error }) => {
|
|
|
331
330
|
}
|
|
332
331
|
};
|
|
333
332
|
|
|
334
|
-
// src/
|
|
335
|
-
var __dxlog_file2 = "/__w/dxos/dxos/packages/sdk/app-framework/src/
|
|
333
|
+
// src/react/useApp.tsx
|
|
334
|
+
var __dxlog_file2 = "/__w/dxos/dxos/packages/sdk/app-framework/src/react/useApp.tsx";
|
|
336
335
|
var ENABLED_KEY = "dxos.org/app-framework/enabled";
|
|
337
|
-
var useApp = ({ pluginManager, pluginLoader:
|
|
338
|
-
const plugins = useDefaultValue2(
|
|
339
|
-
const core = useDefaultValue2(
|
|
340
|
-
const defaults = useDefaultValue2(
|
|
341
|
-
const pluginLoader = useMemo2(() =>
|
|
336
|
+
var useApp = ({ pluginManager, pluginLoader: pluginLoaderParam, plugins: pluginsParam, core: coreParam, defaults: defaultsParam, placeholder, fallback = DefaultFallback3, cacheEnabled = false, safeMode = false, debounce = 0 }) => {
|
|
337
|
+
const plugins = useDefaultValue2(pluginsParam, () => []);
|
|
338
|
+
const core = useDefaultValue2(coreParam, () => plugins.map(({ meta }) => meta.id));
|
|
339
|
+
const defaults = useDefaultValue2(defaultsParam, () => []);
|
|
340
|
+
const pluginLoader = useMemo2(() => pluginLoaderParam ?? ((id) => {
|
|
342
341
|
const plugin = plugins.find((plugin2) => plugin2.meta.id === id);
|
|
343
342
|
invariant2(plugin, `Plugin not found: ${id}`, {
|
|
344
343
|
F: __dxlog_file2,
|
|
345
|
-
L:
|
|
344
|
+
L: 83,
|
|
346
345
|
S: void 0,
|
|
347
346
|
A: [
|
|
348
347
|
"plugin",
|
|
@@ -351,7 +350,7 @@ var useApp = ({ pluginManager, pluginLoader: _pluginLoader, plugins: _plugins, c
|
|
|
351
350
|
});
|
|
352
351
|
return plugin;
|
|
353
352
|
}), [
|
|
354
|
-
|
|
353
|
+
pluginLoaderParam,
|
|
355
354
|
plugins
|
|
356
355
|
]);
|
|
357
356
|
const state = useMemo2(() => live({
|
|
@@ -377,7 +376,7 @@ var useApp = ({ pluginManager, pluginLoader: _pluginLoader, plugins: _plugins, c
|
|
|
377
376
|
core,
|
|
378
377
|
enabled
|
|
379
378
|
]);
|
|
380
|
-
|
|
379
|
+
useEffect2(() => {
|
|
381
380
|
return manager.activation.on(({ event, state: _state, error }) => {
|
|
382
381
|
if (!state.ready && event === Events.Startup.id) {
|
|
383
382
|
state.ready = _state === "activated";
|
|
@@ -390,7 +389,7 @@ var useApp = ({ pluginManager, pluginLoader: _pluginLoader, plugins: _plugins, c
|
|
|
390
389
|
manager,
|
|
391
390
|
state
|
|
392
391
|
]);
|
|
393
|
-
|
|
392
|
+
useEffect2(() => {
|
|
394
393
|
effect(() => {
|
|
395
394
|
cacheEnabled && localStorage.setItem(ENABLED_KEY, JSON.stringify(manager.enabled));
|
|
396
395
|
});
|
|
@@ -398,35 +397,31 @@ var useApp = ({ pluginManager, pluginLoader: _pluginLoader, plugins: _plugins, c
|
|
|
398
397
|
cacheEnabled,
|
|
399
398
|
manager
|
|
400
399
|
]);
|
|
401
|
-
|
|
400
|
+
useEffect2(() => {
|
|
401
|
+
setupDevtools(manager);
|
|
402
|
+
}, [
|
|
403
|
+
manager
|
|
404
|
+
]);
|
|
405
|
+
useAsyncEffect(async () => {
|
|
402
406
|
manager.context.contributeCapability({
|
|
403
407
|
interface: Capabilities.PluginManager,
|
|
404
408
|
implementation: manager,
|
|
405
409
|
module: "dxos.org/app-framework/plugin-manager"
|
|
406
410
|
});
|
|
407
411
|
manager.context.contributeCapability({
|
|
408
|
-
interface: Capabilities.
|
|
412
|
+
interface: Capabilities.AtomRegistry,
|
|
409
413
|
implementation: manager.registry,
|
|
410
|
-
module: "dxos.org/app-framework/
|
|
414
|
+
module: "dxos.org/app-framework/atom-registry"
|
|
411
415
|
});
|
|
412
|
-
return () => {
|
|
413
|
-
manager.context.removeCapability(Capabilities.PluginManager, manager);
|
|
414
|
-
manager.context.removeCapability(Capabilities.RxRegistry, manager.registry);
|
|
415
|
-
};
|
|
416
|
-
}, [
|
|
417
|
-
manager
|
|
418
|
-
]);
|
|
419
|
-
useEffect3(() => {
|
|
420
|
-
setupDevtools(manager);
|
|
421
|
-
}, [
|
|
422
|
-
manager
|
|
423
|
-
]);
|
|
424
|
-
useAsyncEffect(async () => {
|
|
425
416
|
await Promise.all([
|
|
426
417
|
// TODO(wittjosiah): Factor out such that this could be called per surface role when attempting to render.
|
|
427
418
|
manager.activate(Events.SetupReactSurface),
|
|
428
419
|
manager.activate(Events.Startup)
|
|
429
420
|
]);
|
|
421
|
+
return () => {
|
|
422
|
+
manager.context.removeCapability(Capabilities.PluginManager, manager);
|
|
423
|
+
manager.context.removeCapability(Capabilities.AtomRegistry, manager.registry);
|
|
424
|
+
};
|
|
430
425
|
}, [
|
|
431
426
|
manager
|
|
432
427
|
]);
|
|
@@ -448,11 +443,27 @@ var useApp = ({ pluginManager, pluginLoader: _pluginLoader, plugins: _plugins, c
|
|
|
448
443
|
]);
|
|
449
444
|
};
|
|
450
445
|
var setupDevtools = (manager) => {
|
|
451
|
-
|
|
452
|
-
(_globalThis = globalThis).composer ?? (_globalThis.composer = {});
|
|
446
|
+
globalThis.composer ??= {};
|
|
453
447
|
globalThis.composer.manager = manager;
|
|
454
448
|
};
|
|
455
449
|
|
|
450
|
+
// src/react/useIntentResolver.ts
|
|
451
|
+
import { useEffect as useEffect3 } from "react";
|
|
452
|
+
var useIntentResolver = (module, resolver) => {
|
|
453
|
+
const manager = usePluginManager();
|
|
454
|
+
useEffect3(() => {
|
|
455
|
+
manager.context.contributeCapability({
|
|
456
|
+
module,
|
|
457
|
+
interface: Capabilities.IntentResolver,
|
|
458
|
+
implementation: resolver
|
|
459
|
+
});
|
|
460
|
+
return () => manager.context.removeCapability(Capabilities.IntentResolver, resolver);
|
|
461
|
+
}, [
|
|
462
|
+
module,
|
|
463
|
+
resolver
|
|
464
|
+
]);
|
|
465
|
+
};
|
|
466
|
+
|
|
456
467
|
export {
|
|
457
468
|
usePluginManager,
|
|
458
469
|
PluginManagerProvider,
|
|
@@ -461,11 +472,12 @@ export {
|
|
|
461
472
|
useIntentDispatcher,
|
|
462
473
|
useAppGraph,
|
|
463
474
|
useLayout,
|
|
475
|
+
SurfaceCardRole,
|
|
464
476
|
ErrorBoundary,
|
|
477
|
+
Surface,
|
|
465
478
|
useSurfaces,
|
|
466
479
|
isSurfaceAvailable,
|
|
467
|
-
|
|
468
|
-
useIntentResolver
|
|
469
|
-
useApp
|
|
480
|
+
useApp,
|
|
481
|
+
useIntentResolver
|
|
470
482
|
};
|
|
471
|
-
//# sourceMappingURL=chunk-
|
|
483
|
+
//# sourceMappingURL=chunk-VFUKEZIN.mjs.map
|