@dxos/app-framework 0.8.4-main.406dc2a → 0.8.4-main.548089c
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-LG4RG2LM.mjs → app-graph-builder-JPUFNED5.mjs} +7 -7
- package/dist/lib/browser/app-graph-builder-JPUFNED5.mjs.map +7 -0
- package/dist/lib/browser/{chunk-2GRQ4QXA.mjs → chunk-LVSO2N4X.mjs} +160 -199
- package/dist/lib/browser/chunk-LVSO2N4X.mjs.map +7 -0
- package/dist/lib/browser/{chunk-FRUTKCPG.mjs → chunk-XRAWIHTQ.mjs} +101 -90
- package/dist/lib/browser/chunk-XRAWIHTQ.mjs.map +7 -0
- package/dist/lib/browser/index.mjs +5 -33
- package/dist/lib/browser/index.mjs.map +2 -2
- package/dist/lib/browser/{intent-dispatcher-6SHA5B3N.mjs → intent-dispatcher-TNEVDPI6.mjs} +2 -2
- package/dist/lib/browser/{intent-resolver-UZZ4OANZ.mjs → intent-resolver-SYLXP62Y.mjs} +2 -2
- package/dist/lib/browser/meta.json +1 -1
- package/dist/lib/browser/react/index.mjs +32 -0
- package/dist/lib/browser/{store-ACBEYK4B.mjs → store-3HDXKFXP.mjs} +2 -2
- package/dist/lib/browser/testing/index.mjs +5 -4
- package/dist/lib/browser/testing/index.mjs.map +3 -3
- package/dist/lib/node-esm/{app-graph-builder-FMHVHPWA.mjs → app-graph-builder-VO6RTSOS.mjs} +7 -7
- package/dist/lib/node-esm/app-graph-builder-VO6RTSOS.mjs.map +7 -0
- package/dist/lib/node-esm/{chunk-KSPOOYT3.mjs → chunk-FO5NIDOR.mjs} +160 -199
- package/dist/lib/node-esm/chunk-FO5NIDOR.mjs.map +7 -0
- package/dist/lib/node-esm/{chunk-CXT6CYPE.mjs → chunk-JH3SFOXA.mjs} +101 -90
- package/dist/lib/node-esm/chunk-JH3SFOXA.mjs.map +7 -0
- package/dist/lib/node-esm/index.mjs +5 -33
- package/dist/lib/node-esm/index.mjs.map +2 -2
- package/dist/lib/node-esm/{intent-dispatcher-SIYQ5ZIU.mjs → intent-dispatcher-WUNOPJES.mjs} +2 -2
- package/dist/lib/node-esm/{intent-resolver-7FYJMXAG.mjs → intent-resolver-VTZI3NO7.mjs} +2 -2
- package/dist/lib/node-esm/meta.json +1 -1
- package/dist/lib/node-esm/react/index.mjs +33 -0
- package/dist/lib/node-esm/{store-6OBLTVXC.mjs → store-PAJPVOLG.mjs} +2 -2
- package/dist/lib/node-esm/testing/index.mjs +5 -4
- package/dist/lib/node-esm/testing/index.mjs.map +3 -3
- package/dist/types/src/common/capabilities.d.ts +36 -42
- package/dist/types/src/common/capabilities.d.ts.map +1 -1
- package/dist/types/src/common/surface.d.ts +1 -0
- package/dist/types/src/common/surface.d.ts.map +1 -1
- package/dist/types/src/core/capabilities.d.ts +12 -12
- 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 +4 -0
- 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/generator/Main.d.ts.map +1 -1
- package/dist/types/src/react/App.d.ts.map +1 -0
- 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/Surface.d.ts +4 -4
- package/dist/types/src/react/Surface.d.ts.map +1 -1
- package/dist/types/src/react/Surface.stories.d.ts +3 -6
- 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 +6 -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 +4 -3
- package/dist/types/src/testing/withPluginManager.d.ts.map +1 -1
- package/dist/types/tsconfig.tsbuildinfo +1 -1
- package/moon.yml +1 -1
- package/package.json +36 -33
- package/src/common/capabilities.ts +18 -19
- package/src/common/collaboration.ts +2 -2
- package/src/common/surface.ts +1 -0
- package/src/core/capabilities.test.ts +1 -1
- package/src/core/capabilities.ts +23 -19
- package/src/core/manager.ts +2 -2
- package/src/core/plugin.ts +5 -0
- package/src/index.ts +0 -2
- package/src/playground/generator/Main.tsx +0 -1
- package/src/playground/playground.stories.tsx +1 -1
- package/src/plugin-settings/app-graph-builder.ts +5 -5
- package/src/plugin-settings/translations.ts +1 -1
- package/src/{components → react}/App.tsx +1 -1
- package/src/{components → react}/DefaultFallback.tsx +1 -1
- package/src/react/Surface.stories.tsx +69 -45
- package/src/react/Surface.tsx +56 -33
- package/src/react/index.ts +4 -0
- package/src/react/types.ts +13 -0
- package/src/{components → react}/useApp.tsx +13 -12
- package/src/react/useCapabilities.ts +2 -2
- package/src/testing/withPluginManager.tsx +9 -4
- package/tsconfig.json +9 -0
- package/dist/lib/browser/app-graph-builder-LG4RG2LM.mjs.map +0 -7
- package/dist/lib/browser/chunk-2GRQ4QXA.mjs.map +0 -7
- package/dist/lib/browser/chunk-FRUTKCPG.mjs.map +0 -7
- package/dist/lib/browser/worker.mjs +0 -77
- package/dist/lib/node-esm/app-graph-builder-FMHVHPWA.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-CXT6CYPE.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-KSPOOYT3.mjs.map +0 -7
- package/dist/lib/node-esm/worker.mjs +0 -78
- 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-6SHA5B3N.mjs.map → intent-dispatcher-TNEVDPI6.mjs.map} +0 -0
- /package/dist/lib/browser/{intent-resolver-UZZ4OANZ.mjs.map → intent-resolver-SYLXP62Y.mjs.map} +0 -0
- /package/dist/lib/browser/{worker.mjs.map → react/index.mjs.map} +0 -0
- /package/dist/lib/browser/{store-ACBEYK4B.mjs.map → store-3HDXKFXP.mjs.map} +0 -0
- /package/dist/lib/node-esm/{intent-dispatcher-SIYQ5ZIU.mjs.map → intent-dispatcher-WUNOPJES.mjs.map} +0 -0
- /package/dist/lib/node-esm/{intent-resolver-7FYJMXAG.mjs.map → intent-resolver-VTZI3NO7.mjs.map} +0 -0
- /package/dist/lib/node-esm/{worker.mjs.map → react/index.mjs.map} +0 -0
- /package/dist/lib/node-esm/{store-6OBLTVXC.mjs.map → store-PAJPVOLG.mjs.map} +0 -0
- /package/dist/types/src/{components → react}/App.d.ts +0 -0
- /package/dist/types/src/{components → react}/App.stories.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}/App.stories.tsx +0 -0
- /package/src/{components → react}/useLoading.tsx +0 -0
|
@@ -2,7 +2,11 @@ import {
|
|
|
2
2
|
Capabilities,
|
|
3
3
|
Events,
|
|
4
4
|
PluginManager
|
|
5
|
-
} from "./chunk-
|
|
5
|
+
} from "./chunk-LVSO2N4X.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);
|
|
@@ -41,25 +43,15 @@ var useLayout = () => useCapability(Capabilities.Layout);
|
|
|
41
43
|
// src/react/ErrorBoundary.tsx
|
|
42
44
|
import { useSignals as _useSignals } from "@preact-signals/safe-react/tracking";
|
|
43
45
|
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
46
|
var ErrorBoundary = class extends Component {
|
|
58
47
|
static getDerivedStateFromError(error) {
|
|
59
48
|
return {
|
|
60
49
|
error
|
|
61
50
|
};
|
|
62
51
|
}
|
|
52
|
+
state = {
|
|
53
|
+
error: void 0
|
|
54
|
+
};
|
|
63
55
|
componentDidUpdate(prevProps) {
|
|
64
56
|
if (prevProps.data !== this.props.data) {
|
|
65
57
|
this.resetError();
|
|
@@ -80,11 +72,6 @@ var ErrorBoundary = class extends Component {
|
|
|
80
72
|
error: void 0
|
|
81
73
|
});
|
|
82
74
|
}
|
|
83
|
-
constructor(...args) {
|
|
84
|
-
super(...args), _define_property(this, "state", {
|
|
85
|
-
error: void 0
|
|
86
|
-
});
|
|
87
|
-
}
|
|
88
75
|
};
|
|
89
76
|
var DefaultFallback = ({ data, error }) => {
|
|
90
77
|
var _effect = _useSignals();
|
|
@@ -107,34 +94,17 @@ import React2, { Fragment, Suspense, forwardRef, memo, useMemo } from "react";
|
|
|
107
94
|
import { useDefaultValue } from "@dxos/react-hooks";
|
|
108
95
|
import { byPosition } from "@dxos/util";
|
|
109
96
|
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) => {
|
|
97
|
+
var Surface = /* @__PURE__ */ memo(/* @__PURE__ */ forwardRef(({ id: _id, role, data: dataParam, limit, fallback = DefaultFallback2, placeholder = DEFAULT_PLACEHOLDER, ...rest }, forwardedRef) => {
|
|
128
98
|
var _effect = _useSignals2();
|
|
129
99
|
try {
|
|
130
100
|
const surfaces = useSurfaces();
|
|
131
|
-
const data = useDefaultValue(
|
|
101
|
+
const data = useDefaultValue(dataParam, () => ({}));
|
|
132
102
|
const definitions = findCandidates(surfaces, {
|
|
133
103
|
role,
|
|
134
104
|
data
|
|
135
105
|
});
|
|
136
106
|
const candidates = limit ? definitions.slice(0, limit) : definitions;
|
|
137
|
-
const nodes = candidates.map(({ component: Component2
|
|
107
|
+
const nodes = candidates.map(({ id, component: Component2 }) => /* @__PURE__ */ React2.createElement(Component2, {
|
|
138
108
|
ref: forwardedRef,
|
|
139
109
|
key: id,
|
|
140
110
|
id,
|
|
@@ -146,42 +116,67 @@ var Surface = /* @__PURE__ */ memo(/* @__PURE__ */ forwardRef(({ id: _id, role,
|
|
|
146
116
|
const suspense = /* @__PURE__ */ React2.createElement(Suspense, {
|
|
147
117
|
fallback: placeholder
|
|
148
118
|
}, nodes);
|
|
149
|
-
return
|
|
119
|
+
return /* @__PURE__ */ React2.createElement(ErrorBoundary, {
|
|
150
120
|
data,
|
|
151
121
|
fallback
|
|
152
|
-
}, suspense)
|
|
122
|
+
}, suspense);
|
|
153
123
|
} finally {
|
|
154
124
|
_effect.f();
|
|
155
125
|
}
|
|
156
126
|
}));
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
}
|
|
169
|
-
return
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
|
|
127
|
+
var DefaultFallback2 = ({ data, error, dev }) => {
|
|
128
|
+
var _effect = _useSignals2();
|
|
129
|
+
try {
|
|
130
|
+
if (dev) {
|
|
131
|
+
return /* @__PURE__ */ React2.createElement("div", {
|
|
132
|
+
className: "flex flex-col gap-4 p-4 is-full overflow-y-auto"
|
|
133
|
+
}, /* @__PURE__ */ React2.createElement("h1", {
|
|
134
|
+
className: "flex gap-2 text-sm mbs-2"
|
|
135
|
+
}, error.message), /* @__PURE__ */ React2.createElement("pre", {
|
|
136
|
+
className: "overflow-auto text-xs text-description"
|
|
137
|
+
}, JSON.stringify(data, null, 2)));
|
|
138
|
+
}
|
|
139
|
+
return /* @__PURE__ */ React2.createElement("div", {
|
|
140
|
+
className: "flex flex-col gap-4 p-4 is-full overflow-y-auto border border-rose-500"
|
|
141
|
+
}, /* @__PURE__ */ React2.createElement("h1", {
|
|
142
|
+
className: "flex gap-2 text-sm mbs-2 text-rose-500"
|
|
143
|
+
}, error.message), /* @__PURE__ */ React2.createElement("pre", {
|
|
144
|
+
className: "overflow-auto text-xs text-description"
|
|
145
|
+
}, error.stack), /* @__PURE__ */ React2.createElement("pre", {
|
|
146
|
+
className: "overflow-auto text-xs text-description"
|
|
147
|
+
}, JSON.stringify(data, null, 2)));
|
|
148
|
+
} finally {
|
|
149
|
+
_effect.f();
|
|
150
|
+
}
|
|
151
|
+
};
|
|
152
|
+
var useSurfaces = () => {
|
|
153
|
+
const surfaces = useCapabilities(Capabilities.ReactSurface);
|
|
154
|
+
return useMemo(() => surfaces.flat(), [
|
|
155
|
+
surfaces
|
|
173
156
|
]);
|
|
174
157
|
};
|
|
158
|
+
var isSurfaceAvailable = (context, { role, data }) => {
|
|
159
|
+
const surfaces = context.getCapabilities(Capabilities.ReactSurface);
|
|
160
|
+
const candidates = findCandidates(surfaces.flat(), {
|
|
161
|
+
role,
|
|
162
|
+
data
|
|
163
|
+
});
|
|
164
|
+
return candidates.length > 0;
|
|
165
|
+
};
|
|
166
|
+
var findCandidates = (surfaces, { role, data }) => {
|
|
167
|
+
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);
|
|
168
|
+
};
|
|
169
|
+
Surface.displayName = "Surface";
|
|
175
170
|
|
|
176
|
-
// src/
|
|
177
|
-
import { RegistryContext } from "@effect-
|
|
171
|
+
// src/react/useApp.tsx
|
|
172
|
+
import { RegistryContext } from "@effect-atom/atom-react";
|
|
178
173
|
import { effect } from "@preact/signals-core";
|
|
179
|
-
import React5, { useCallback, useEffect as
|
|
174
|
+
import React5, { useCallback, useEffect as useEffect2, useMemo as useMemo2 } from "react";
|
|
180
175
|
import { invariant as invariant2 } from "@dxos/invariant";
|
|
181
176
|
import { live } from "@dxos/live-object";
|
|
182
177
|
import { useAsyncEffect, useDefaultValue as useDefaultValue2 } from "@dxos/react-hooks";
|
|
183
178
|
|
|
184
|
-
// src/
|
|
179
|
+
// src/react/App.tsx
|
|
185
180
|
import { useSignals as _useSignals3 } from "@preact-signals/safe-react/tracking";
|
|
186
181
|
import React3 from "react";
|
|
187
182
|
|
|
@@ -216,8 +211,8 @@ var topologicalSort = (nodes) => {
|
|
|
216
211
|
return allDependencies.map((id) => nodes.find((node) => node.id === id)).filter((node) => node !== void 0);
|
|
217
212
|
};
|
|
218
213
|
|
|
219
|
-
// src/
|
|
220
|
-
import { useEffect
|
|
214
|
+
// src/react/useLoading.tsx
|
|
215
|
+
import { useEffect, useState } from "react";
|
|
221
216
|
var LoadingState = /* @__PURE__ */ (function(LoadingState2) {
|
|
222
217
|
LoadingState2[LoadingState2["Loading"] = 0] = "Loading";
|
|
223
218
|
LoadingState2[LoadingState2["FadeIn"] = 1] = "FadeIn";
|
|
@@ -227,7 +222,7 @@ var LoadingState = /* @__PURE__ */ (function(LoadingState2) {
|
|
|
227
222
|
})({});
|
|
228
223
|
var useLoading = (state, debounce = 0) => {
|
|
229
224
|
const [stage, setStage] = useState(0);
|
|
230
|
-
|
|
225
|
+
useEffect(() => {
|
|
231
226
|
if (!debounce) {
|
|
232
227
|
return;
|
|
233
228
|
}
|
|
@@ -266,7 +261,7 @@ var useLoading = (state, debounce = 0) => {
|
|
|
266
261
|
return stage;
|
|
267
262
|
};
|
|
268
263
|
|
|
269
|
-
// src/
|
|
264
|
+
// src/react/App.tsx
|
|
270
265
|
var App = ({ placeholder: Placeholder, state, debounce }) => {
|
|
271
266
|
var _effect = _useSignals3();
|
|
272
267
|
try {
|
|
@@ -299,10 +294,10 @@ var composeContexts = (contexts) => {
|
|
|
299
294
|
return topologicalSort(contexts).map(({ context }) => context).reduce((Acc, Next) => ({ children }) => /* @__PURE__ */ React3.createElement(Acc, null, /* @__PURE__ */ React3.createElement(Next, null, children)));
|
|
300
295
|
};
|
|
301
296
|
|
|
302
|
-
// src/
|
|
297
|
+
// src/react/DefaultFallback.tsx
|
|
303
298
|
import { useSignals as _useSignals4 } from "@preact-signals/safe-react/tracking";
|
|
304
299
|
import React4 from "react";
|
|
305
|
-
var
|
|
300
|
+
var DefaultFallback3 = ({ error }) => {
|
|
306
301
|
var _effect = _useSignals4();
|
|
307
302
|
try {
|
|
308
303
|
return /* @__PURE__ */ React4.createElement("div", {
|
|
@@ -318,7 +313,7 @@ var DefaultFallback2 = ({ error }) => {
|
|
|
318
313
|
margin: "0.5rem 0",
|
|
319
314
|
fontSize: "1.2rem"
|
|
320
315
|
}
|
|
321
|
-
}, "
|
|
316
|
+
}, "ERROR: ", error.message), /* @__PURE__ */ React4.createElement("pre", {
|
|
322
317
|
style: {
|
|
323
318
|
overflow: "auto",
|
|
324
319
|
fontSize: "1rem",
|
|
@@ -331,18 +326,18 @@ var DefaultFallback2 = ({ error }) => {
|
|
|
331
326
|
}
|
|
332
327
|
};
|
|
333
328
|
|
|
334
|
-
// src/
|
|
335
|
-
var __dxlog_file2 = "/__w/dxos/dxos/packages/sdk/app-framework/src/
|
|
329
|
+
// src/react/useApp.tsx
|
|
330
|
+
var __dxlog_file2 = "/__w/dxos/dxos/packages/sdk/app-framework/src/react/useApp.tsx";
|
|
336
331
|
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(() =>
|
|
332
|
+
var useApp = ({ pluginManager, pluginLoader: pluginLoaderParam, plugins: pluginsParam, core: coreParam, defaults: defaultsParam, placeholder, fallback = DefaultFallback3, cacheEnabled = false, safeMode = false, debounce = 0 }) => {
|
|
333
|
+
const plugins = useDefaultValue2(pluginsParam, () => []);
|
|
334
|
+
const core = useDefaultValue2(coreParam, () => plugins.map(({ meta }) => meta.id));
|
|
335
|
+
const defaults = useDefaultValue2(defaultsParam, () => []);
|
|
336
|
+
const pluginLoader = useMemo2(() => pluginLoaderParam ?? ((id) => {
|
|
342
337
|
const plugin = plugins.find((plugin2) => plugin2.meta.id === id);
|
|
343
338
|
invariant2(plugin, `Plugin not found: ${id}`, {
|
|
344
339
|
F: __dxlog_file2,
|
|
345
|
-
L:
|
|
340
|
+
L: 83,
|
|
346
341
|
S: void 0,
|
|
347
342
|
A: [
|
|
348
343
|
"plugin",
|
|
@@ -351,7 +346,7 @@ var useApp = ({ pluginManager, pluginLoader: _pluginLoader, plugins: _plugins, c
|
|
|
351
346
|
});
|
|
352
347
|
return plugin;
|
|
353
348
|
}), [
|
|
354
|
-
|
|
349
|
+
pluginLoaderParam,
|
|
355
350
|
plugins
|
|
356
351
|
]);
|
|
357
352
|
const state = useMemo2(() => live({
|
|
@@ -377,7 +372,7 @@ var useApp = ({ pluginManager, pluginLoader: _pluginLoader, plugins: _plugins, c
|
|
|
377
372
|
core,
|
|
378
373
|
enabled
|
|
379
374
|
]);
|
|
380
|
-
|
|
375
|
+
useEffect2(() => {
|
|
381
376
|
return manager.activation.on(({ event, state: _state, error }) => {
|
|
382
377
|
if (!state.ready && event === Events.Startup.id) {
|
|
383
378
|
state.ready = _state === "activated";
|
|
@@ -390,7 +385,7 @@ var useApp = ({ pluginManager, pluginLoader: _pluginLoader, plugins: _plugins, c
|
|
|
390
385
|
manager,
|
|
391
386
|
state
|
|
392
387
|
]);
|
|
393
|
-
|
|
388
|
+
useEffect2(() => {
|
|
394
389
|
effect(() => {
|
|
395
390
|
cacheEnabled && localStorage.setItem(ENABLED_KEY, JSON.stringify(manager.enabled));
|
|
396
391
|
});
|
|
@@ -398,7 +393,7 @@ var useApp = ({ pluginManager, pluginLoader: _pluginLoader, plugins: _plugins, c
|
|
|
398
393
|
cacheEnabled,
|
|
399
394
|
manager
|
|
400
395
|
]);
|
|
401
|
-
|
|
396
|
+
useEffect2(() => {
|
|
402
397
|
setupDevtools(manager);
|
|
403
398
|
}, [
|
|
404
399
|
manager
|
|
@@ -412,7 +407,7 @@ var useApp = ({ pluginManager, pluginLoader: _pluginLoader, plugins: _plugins, c
|
|
|
412
407
|
manager.context.contributeCapability({
|
|
413
408
|
interface: Capabilities.RxRegistry,
|
|
414
409
|
implementation: manager.registry,
|
|
415
|
-
module: "dxos.org/app-framework/
|
|
410
|
+
module: "dxos.org/app-framework/atom-registry"
|
|
416
411
|
});
|
|
417
412
|
await Promise.all([
|
|
418
413
|
// TODO(wittjosiah): Factor out such that this could be called per surface role when attempting to render.
|
|
@@ -444,11 +439,27 @@ var useApp = ({ pluginManager, pluginLoader: _pluginLoader, plugins: _plugins, c
|
|
|
444
439
|
]);
|
|
445
440
|
};
|
|
446
441
|
var setupDevtools = (manager) => {
|
|
447
|
-
|
|
448
|
-
(_globalThis = globalThis).composer ?? (_globalThis.composer = {});
|
|
442
|
+
globalThis.composer ??= {};
|
|
449
443
|
globalThis.composer.manager = manager;
|
|
450
444
|
};
|
|
451
445
|
|
|
446
|
+
// src/react/useIntentResolver.ts
|
|
447
|
+
import { useEffect as useEffect3 } from "react";
|
|
448
|
+
var useIntentResolver = (module, resolver) => {
|
|
449
|
+
const manager = usePluginManager();
|
|
450
|
+
useEffect3(() => {
|
|
451
|
+
manager.context.contributeCapability({
|
|
452
|
+
module,
|
|
453
|
+
interface: Capabilities.IntentResolver,
|
|
454
|
+
implementation: resolver
|
|
455
|
+
});
|
|
456
|
+
return () => manager.context.removeCapability(Capabilities.IntentResolver, resolver);
|
|
457
|
+
}, [
|
|
458
|
+
module,
|
|
459
|
+
resolver
|
|
460
|
+
]);
|
|
461
|
+
};
|
|
462
|
+
|
|
452
463
|
export {
|
|
453
464
|
usePluginManager,
|
|
454
465
|
PluginManagerProvider,
|
|
@@ -458,10 +469,10 @@ export {
|
|
|
458
469
|
useAppGraph,
|
|
459
470
|
useLayout,
|
|
460
471
|
ErrorBoundary,
|
|
472
|
+
Surface,
|
|
461
473
|
useSurfaces,
|
|
462
474
|
isSurfaceAvailable,
|
|
463
|
-
|
|
464
|
-
useIntentResolver
|
|
465
|
-
useApp
|
|
475
|
+
useApp,
|
|
476
|
+
useIntentResolver
|
|
466
477
|
};
|
|
467
|
-
//# sourceMappingURL=chunk-
|
|
478
|
+
//# sourceMappingURL=chunk-XRAWIHTQ.mjs.map
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../src/react/useCapabilities.ts", "../../../src/react/PluginManagerProvider.ts", "../../../src/react/common.ts", "../../../src/react/ErrorBoundary.tsx", "../../../src/react/Surface.tsx", "../../../src/react/useApp.tsx", "../../../src/react/App.tsx", "../../../src/helpers.ts", "../../../src/react/useLoading.tsx", "../../../src/react/DefaultFallback.tsx", "../../../src/react/useIntentResolver.ts"],
|
|
4
|
+
"sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport { useAtomValue } from '@effect-atom/atom-react';\n\nimport { invariant } from '@dxos/invariant';\n\nimport { type InterfaceDef } from '../core';\n\nimport { usePluginManager } from './PluginManagerProvider';\n\n/**\n * Hook to request capabilities from the plugin context.\n * @returns An array of capabilities.\n */\nexport const useCapabilities = <T>(interfaceDef: InterfaceDef<T>) => {\n const manager = usePluginManager();\n return useAtomValue(manager.context.capabilities(interfaceDef));\n};\n\n/**\n * Hook to request a capability from the plugin context.\n * @returns The capability.\n * @throws If no capability is found.\n */\nexport const useCapability = <T>(interfaceDef: InterfaceDef<T>) => {\n const capabilities = useCapabilities(interfaceDef);\n invariant(capabilities.length > 0, `No capability found for ${interfaceDef.identifier}`);\n return capabilities[0];\n};\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport { createContext, useContext } from 'react';\n\nimport { raise } from '@dxos/debug';\n\nimport { type PluginManager } from '../core';\n\nconst PluginManagerContext = createContext<PluginManager | undefined>(undefined);\n\n/**\n * Get the plugin manager.\n */\nexport const usePluginManager = (): PluginManager =>\n useContext(PluginManagerContext) ?? raise(new Error('Missing PluginManagerContext'));\n\n/**\n * Context provider for a plugin manager.\n */\nexport const PluginManagerProvider = PluginManagerContext.Provider;\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport { Capabilities } from '../common';\n\nimport { useCapability } from './useCapabilities';\n\nexport const useIntentDispatcher = () => useCapability(Capabilities.IntentDispatcher);\n\nexport const useAppGraph = () => useCapability(Capabilities.AppGraph);\n\nexport const useLayout = () => useCapability(Capabilities.Layout);\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport React, { Component, type FC, type PropsWithChildren, type ReactNode } from 'react';\n\ntype State = {\n error: Error | undefined;\n};\n\nexport type ErrorBoundaryProps = PropsWithChildren<{\n data?: any;\n fallback?: FC<{ data?: any; error: Error }>;\n}>;\n\n/**\n * Surface error boundary.\n * For basic usage prefer providing a fallback component to `Surface`.\n *\n * Ref: https://react.dev/reference/react/Component#catching-rendering-errors-with-an-error-boundary\n */\nexport class ErrorBoundary extends Component<ErrorBoundaryProps, State> {\n static getDerivedStateFromError(error: Error): { error: Error } {\n return { error };\n }\n\n override state = { error: undefined };\n\n override componentDidUpdate(prevProps: ErrorBoundaryProps): void {\n if (prevProps.data !== this.props.data) {\n this.resetError();\n }\n }\n\n override render(): ReactNode {\n if (this.state.error) {\n const Fallback = this.props.fallback ?? DefaultFallback;\n return <Fallback data={this.props.data} error={this.state.error} />;\n }\n\n return this.props.children;\n }\n\n private resetError(): void {\n this.setState({ error: undefined });\n }\n}\n\nconst DefaultFallback: NonNullable<ErrorBoundaryProps['fallback']> = ({ data, error }) => {\n return (\n <div className='flex flex-col gap-2 overflow-hidden border border-red-500 rounded-sm'>\n <h1 className='p-2'>ERROR: {error.message}</h1>\n <pre className='p-2 overflow-y-auto text-sm text-subdued'>{JSON.stringify(data, null, 2)}</pre>\n </div>\n );\n};\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport React, {\n Fragment,\n type NamedExoticComponent,\n type RefAttributes,\n Suspense,\n forwardRef,\n memo,\n useMemo,\n} from 'react';\n\nimport { useDefaultValue } from '@dxos/react-hooks';\nimport { byPosition } from '@dxos/util';\n\nimport { Capabilities, type SurfaceDefinition, type SurfaceProps } from '../common';\nimport { type PluginContext } from '../core';\n\nimport { ErrorBoundary } from './ErrorBoundary';\nimport { useCapabilities } from './useCapabilities';\n\nconst DEFAULT_PLACEHOLDER = <Fragment />;\n\n/**\n * A surface is a named region of the screen that can be populated by plugins.\n */\nexport const Surface: NamedExoticComponent<SurfaceProps & RefAttributes<HTMLElement>> = memo(\n forwardRef(\n (\n { id: _id, role, data: dataParam, limit, fallback = DefaultFallback, placeholder = DEFAULT_PLACEHOLDER, ...rest },\n forwardedRef,\n ) => {\n // TODO(wittjosiah): This will make all surfaces depend on a single signal.\n // This isn't ideal because it means that any change to the data will cause all surfaces to re-render.\n // This effectively means that plugin modules which contribute surfaces need to all be activated at startup.\n // This should be fine for now because it's how it worked prior to capabilities api anyway.\n // In the future, it would be nice to be able to bucket the surface contributions by role.\n const surfaces = useSurfaces();\n const data = useDefaultValue(dataParam, () => ({}));\n\n // NOTE: Memoizing the candidates makes the surface not re-render based on reactivity within data.\n const definitions = findCandidates(surfaces, { role, data });\n const candidates = limit ? definitions.slice(0, limit) : definitions;\n const nodes = candidates.map(({ id, component: Component }) => (\n <Component ref={forwardedRef} key={id} id={id} role={role} data={data} limit={limit} {...rest} />\n ));\n\n // TODO(burdon): Able to inject DOM properties into root (e.g., object.id).\n const suspense = <Suspense fallback={placeholder}>{nodes}</Suspense>;\n\n return (\n <ErrorBoundary data={data} fallback={fallback}>\n {suspense}\n </ErrorBoundary>\n );\n },\n ),\n);\n\n// TODO(burdon): Make user facing, with telemetry.\n// TODO(burdon): Change based on dev/prod mode; infer subject type, id.\nconst DefaultFallback = ({ data, error, dev }: { data: any; error: Error; dev?: boolean }) => {\n if (dev) {\n return (\n <div className='flex flex-col gap-4 p-4 is-full overflow-y-auto'>\n <h1 className='flex gap-2 text-sm mbs-2'>{error.message}</h1>\n <pre className='overflow-auto text-xs text-description'>{JSON.stringify(data, null, 2)}</pre>\n </div>\n );\n }\n\n return (\n <div className='flex flex-col gap-4 p-4 is-full overflow-y-auto border border-rose-500'>\n <h1 className='flex gap-2 text-sm mbs-2 text-rose-500'>{error.message}</h1>\n <pre className='overflow-auto text-xs text-description'>{error.stack}</pre>\n <pre className='overflow-auto text-xs text-description'>{JSON.stringify(data, null, 2)}</pre>\n </div>\n );\n};\n\n/**\n * @internal\n */\nexport const useSurfaces = () => {\n const surfaces = useCapabilities(Capabilities.ReactSurface);\n return useMemo(() => surfaces.flat(), [surfaces]);\n};\n\n/**\n * @returns `true` if there is a contributed surface which matches the specified role & data, `false` otherwise.\n */\nexport const isSurfaceAvailable = (context: PluginContext, { role, data }: Pick<SurfaceProps, 'role' | 'data'>) => {\n const surfaces = context.getCapabilities(Capabilities.ReactSurface);\n const candidates = findCandidates(surfaces.flat(), { role, data });\n return candidates.length > 0;\n};\n\nconst findCandidates = (surfaces: SurfaceDefinition[], { role, data }: Pick<SurfaceProps, 'role' | 'data'>) => {\n return Object.values(surfaces)\n .filter((definition) =>\n Array.isArray(definition.role) ? definition.role.includes(role) : definition.role === role,\n )\n .filter(({ filter }) => (filter ? filter(data ?? {}) : true))\n .toSorted(byPosition);\n};\n\nSurface.displayName = 'Surface';\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport { RegistryContext } from '@effect-atom/atom-react';\nimport { effect } from '@preact/signals-core';\nimport React, { type FC, useCallback, useEffect, useMemo } from 'react';\n\nimport { invariant } from '@dxos/invariant';\nimport { live } from '@dxos/live-object';\nimport { useAsyncEffect, useDefaultValue } from '@dxos/react-hooks';\n\nimport { Capabilities, Events } from '../common';\nimport { type Plugin, PluginManager, type PluginManagerOptions } from '../core';\n\nimport { App } from './App';\nimport { DefaultFallback } from './DefaultFallback';\nimport { ErrorBoundary } from './ErrorBoundary';\nimport { PluginManagerProvider } from './PluginManagerProvider';\n\nconst ENABLED_KEY = 'dxos.org/app-framework/enabled';\n\nexport type UseAppOptions = {\n pluginManager?: PluginManager;\n pluginLoader?: PluginManagerOptions['pluginLoader'];\n plugins?: Plugin[];\n core?: string[];\n defaults?: string[];\n placeholder?: FC<{ stage: number }>;\n fallback?: ErrorBoundary['props']['fallback'];\n cacheEnabled?: boolean;\n safeMode?: boolean;\n debounce?: number;\n};\n\n/**\n * Expected usage is for this to be the entrypoint of the application.\n * Initializes plugins and renders the root components.\n *\n * @example\n * const plugins = [LayoutPlugin(), MyPlugin()];\n * const core = [LayoutPluginId];\n * const default = [MyPluginId];\n * const fallback = <div>Initializing Plugins...</div>;\n * const App = useApp({ plugins, core, default, fallback });\n * createRoot(document.getElementById('root')!).render(\n * <StrictMode>\n * <App />\n * </StrictMode>,\n * );\n *\n * @param params.pluginLoader A function which loads new plugins.\n * @param params.plugins All plugins available to the application.\n * @param params.core Core plugins which will always be enabled.\n * @param params.defaults Default plugins are enabled by default but can be disabled by the user.\n * @param params.placeholder Placeholder component to render during startup.\n * @param params.fallback Fallback component to render if an error occurs during startup.\n * @param params.cacheEnabled Whether to cache enabled plugins in localStorage.\n * @param params.safeMode Whether to enable safe mode, which disables optional plugins.\n */\nexport const useApp = ({\n pluginManager,\n pluginLoader: pluginLoaderParam,\n plugins: pluginsParam,\n core: coreParam,\n defaults: defaultsParam,\n placeholder,\n fallback = DefaultFallback,\n cacheEnabled = false,\n safeMode = false,\n debounce = 0,\n}: UseAppOptions) => {\n const plugins = useDefaultValue(pluginsParam, () => []);\n const core = useDefaultValue(coreParam, () => plugins.map(({ meta }) => meta.id));\n const defaults = useDefaultValue(defaultsParam, () => []);\n\n // TODO(wittjosiah): Provide a custom plugin loader which supports loading via url.\n const pluginLoader = useMemo(\n () =>\n pluginLoaderParam ??\n ((id: string) => {\n const plugin = plugins.find((plugin) => plugin.meta.id === id);\n invariant(plugin, `Plugin not found: ${id}`);\n return plugin;\n }),\n [pluginLoaderParam, plugins],\n );\n\n const state = useMemo(() => live({ ready: false, error: null }), []);\n const cached: string[] = useMemo(() => JSON.parse(localStorage.getItem(ENABLED_KEY) ?? '[]'), []);\n const enabled = useMemo(\n () => (safeMode ? [] : cacheEnabled && cached.length > 0 ? cached : defaults),\n [safeMode, cacheEnabled, cached, defaults],\n );\n const manager = useMemo(\n () => pluginManager ?? new PluginManager({ pluginLoader, plugins, core, enabled }),\n [pluginManager, pluginLoader, plugins, core, enabled],\n );\n\n useEffect(() => {\n return manager.activation.on(({ event, state: _state, error }) => {\n // Once the app is ready the first time, don't show the fallback again.\n if (!state.ready && event === Events.Startup.id) {\n state.ready = _state === 'activated';\n }\n\n if (error && !state.ready && !state.error) {\n state.error = error;\n }\n });\n }, [manager, state]);\n\n useEffect(() => {\n effect(() => {\n cacheEnabled && localStorage.setItem(ENABLED_KEY, JSON.stringify(manager.enabled));\n });\n }, [cacheEnabled, manager]);\n\n useEffect(() => {\n setupDevtools(manager);\n }, [manager]);\n\n useAsyncEffect(async () => {\n manager.context.contributeCapability({\n interface: Capabilities.PluginManager,\n implementation: manager,\n module: 'dxos.org/app-framework/plugin-manager',\n });\n\n manager.context.contributeCapability({\n interface: Capabilities.RxRegistry,\n implementation: manager.registry,\n module: 'dxos.org/app-framework/atom-registry',\n });\n\n await Promise.all([\n // TODO(wittjosiah): Factor out such that this could be called per surface role when attempting to render.\n manager.activate(Events.SetupReactSurface),\n manager.activate(Events.Startup),\n ]);\n\n return () => {\n manager.context.removeCapability(Capabilities.PluginManager, manager);\n manager.context.removeCapability(Capabilities.RxRegistry, manager.registry);\n };\n }, [manager]);\n\n return useCallback(\n () => (\n <ErrorBoundary fallback={fallback}>\n <PluginManagerProvider value={manager}>\n <RegistryContext.Provider value={manager.registry}>\n <App placeholder={placeholder} state={state} debounce={debounce} />\n </RegistryContext.Provider>\n </PluginManagerProvider>\n </ErrorBoundary>\n ),\n [fallback, manager, placeholder, state],\n );\n};\n\nconst setupDevtools = (manager: PluginManager) => {\n (globalThis as any).composer ??= {};\n (globalThis as any).composer.manager = manager;\n};\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport React, { type PropsWithChildren } from 'react';\n\nimport { Capabilities } from '../common';\nimport { topologicalSort } from '../helpers';\n\nimport { type UseAppOptions } from './useApp';\nimport { useCapabilities } from './useCapabilities';\nimport { LoadingState, useLoading } from './useLoading';\n\nexport type AppProps = Pick<UseAppOptions, 'placeholder' | 'debounce'> & {\n state: { ready: boolean; error: unknown };\n};\n\nexport const App = ({ placeholder: Placeholder, state, debounce }: AppProps) => {\n const reactContexts = useCapabilities(Capabilities.ReactContext);\n const reactRoots = useCapabilities(Capabilities.ReactRoot);\n const stage = useLoading(state, debounce);\n\n if (state.error) {\n // This triggers the error boundary to provide UI feedback for the startup error.\n throw state.error;\n }\n\n // TODO(wittjosiah): Consider using Suspense instead.\n if (stage < LoadingState.Done) {\n if (!Placeholder) {\n return null;\n }\n\n return <Placeholder stage={stage} />;\n }\n\n const ComposedContext = composeContexts(reactContexts);\n return (\n <ComposedContext>\n {reactRoots.map(({ id, root: Component }) => (\n <Component key={id} />\n ))}\n </ComposedContext>\n );\n};\n\nconst composeContexts = (contexts: Capabilities.ReactContext[]) => {\n if (contexts.length === 0) {\n return ({ children }: PropsWithChildren) => <>{children}</>;\n }\n\n return topologicalSort(contexts)\n .map(({ context }) => context)\n .reduce((Acc, Next) => ({ children }) => (\n <Acc>\n <Next>{children}</Next>\n </Acc>\n ));\n};\n", "//\n// Copyright 2025 DXOS.org\n//\n\ntype DependencyNode = {\n id: string;\n dependsOn?: string[];\n};\n\n/**\n * Topologically sorts a list of nodes based on their dependencies.\n */\n// TODO(wittjosiah): Factor out?\nexport const topologicalSort = <T extends DependencyNode>(nodes: T[]): T[] => {\n const getDependencies = (nodeId: string, seen = new Set<string>(), path = new Set<string>()): string[] => {\n if (path.has(nodeId)) {\n throw new Error(`Circular dependency detected involving ${nodeId}`);\n }\n if (seen.has(nodeId)) {\n return [];\n }\n\n const node = nodes.find((n) => n.id === nodeId);\n if (!node) {\n throw new Error(`Node ${nodeId} not found but is listed as a dependency`);\n }\n\n const newPath = new Set([...path, nodeId]);\n const newSeen = new Set([...seen, nodeId]);\n\n const dependsOn = node.dependsOn ?? [];\n return [...dependsOn.flatMap((depId) => getDependencies(depId, newSeen, newPath)), nodeId];\n };\n\n // Get all unique dependencies.\n const allDependencies = nodes\n .map((node) => node.id)\n .flatMap((id) => getDependencies(id))\n .filter((id, index, self) => self.indexOf(id) === index);\n\n // Map back to original nodes\n return allDependencies\n .map((id) => nodes.find((node) => node.id === id))\n .filter((node): node is T => node !== undefined);\n};\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport { useEffect, useState } from 'react';\n\nimport { type AppProps } from './App';\n\nexport enum LoadingState {\n Loading = 0,\n FadeIn = 1,\n FadeOut = 2,\n Done = 3,\n}\n\n/**\n * To avoid \"flashing\" the placeholder, we wait a period of time before starting the loading animation.\n * If loading completes during this time the placehoder is not shown, otherwise is it displayed for a minimum period of time.\n *\n * States:\n * 0: Loading - Wait for a period of time before starting the loading animation.\n * 1: Fade-in - Display a loading animation.\n * 2: Fade-out - Fade out the loading animation.\n * 3: Done - Remove the placeholder.\n */\nexport const useLoading = (state: AppProps['state'], debounce = 0) => {\n const [stage, setStage] = useState<LoadingState>(LoadingState.Loading);\n useEffect(() => {\n if (!debounce) {\n return;\n }\n\n const i = setInterval(() => {\n setStage((stage) => {\n switch (stage) {\n case LoadingState.Loading: {\n if (!state.ready) {\n return LoadingState.FadeIn;\n } else {\n clearInterval(i);\n return LoadingState.Done;\n }\n }\n\n case LoadingState.FadeIn: {\n if (state.ready) {\n return LoadingState.FadeOut;\n }\n break;\n }\n\n case LoadingState.FadeOut: {\n clearInterval(i);\n return LoadingState.Done;\n }\n }\n\n return stage;\n });\n }, debounce);\n\n return () => clearInterval(i);\n }, [debounce]);\n\n if (!debounce) {\n return state.ready ? LoadingState.Done : LoadingState.Loading;\n }\n\n return stage;\n};\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport React from 'react';\n\n/**\n * NOTE: Default fallback should not use tailwind or theme.\n */\nexport const DefaultFallback = ({ error }: { error: Error }) => {\n return (\n <div\n style={{\n margin: '1rem',\n padding: '1rem',\n overflow: 'hidden',\n border: '4px solid teal',\n borderRadius: '1rem',\n }}\n >\n {/* TODO(wittjosiah): Link to docs for replacing default. */}\n <h1 style={{ margin: '0.5rem 0', fontSize: '1.2rem' }}>ERROR: {error.message}</h1>\n <pre style={{ overflow: 'auto', fontSize: '1rem', whiteSpace: 'pre-wrap', color: '#888888' }}>{error.stack}</pre>\n </div>\n );\n};\n", "//\n// Copyright 2023 DXOS.org\n//\n\nimport { useEffect } from 'react';\n\nimport { Capabilities } from '../common';\nimport { type AnyIntentResolver } from '../plugin-intent';\nimport { usePluginManager } from '../react';\n\nexport const useIntentResolver = (module: string, resolver: AnyIntentResolver) => {\n const manager = usePluginManager();\n useEffect(() => {\n manager.context.contributeCapability({\n module,\n interface: Capabilities.IntentResolver,\n implementation: resolver,\n });\n\n return () => manager.context.removeCapability(Capabilities.IntentResolver, resolver);\n }, [module, resolver]);\n};\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
|
+
"names": ["useAtomValue", "invariant", "createContext", "useContext", "raise", "PluginManagerContext", "createContext", "undefined", "usePluginManager", "useContext", "raise", "Error", "PluginManagerProvider", "Provider", "useCapabilities", "interfaceDef", "manager", "usePluginManager", "useAtomValue", "context", "capabilities", "useCapability", "invariant", "length", "identifier", "useIntentDispatcher", "useCapability", "Capabilities", "IntentDispatcher", "useAppGraph", "AppGraph", "useLayout", "Layout", "React", "Component", "ErrorBoundary", "Component", "getDerivedStateFromError", "error", "state", "undefined", "componentDidUpdate", "prevProps", "data", "props", "resetError", "render", "Fallback", "fallback", "DefaultFallback", "children", "setState", "div", "className", "h1", "message", "pre", "JSON", "stringify", "React", "Fragment", "Suspense", "forwardRef", "memo", "useMemo", "useDefaultValue", "byPosition", "DEFAULT_PLACEHOLDER", "React", "Fragment", "Surface", "memo", "forwardRef", "id", "_id", "role", "data", "dataParam", "limit", "fallback", "DefaultFallback", "placeholder", "rest", "forwardedRef", "surfaces", "useSurfaces", "useDefaultValue", "definitions", "findCandidates", "candidates", "slice", "nodes", "map", "component", "Component", "ref", "key", "suspense", "Suspense", "ErrorBoundary", "error", "dev", "div", "className", "h1", "message", "pre", "JSON", "stringify", "stack", "useCapabilities", "Capabilities", "ReactSurface", "useMemo", "flat", "isSurfaceAvailable", "context", "getCapabilities", "length", "Object", "values", "filter", "definition", "Array", "isArray", "includes", "toSorted", "byPosition", "displayName", "RegistryContext", "effect", "React", "useCallback", "useEffect", "useMemo", "invariant", "live", "useAsyncEffect", "useDefaultValue", "React", "topologicalSort", "nodes", "getDependencies", "nodeId", "seen", "Set", "path", "has", "Error", "node", "find", "n", "id", "newPath", "newSeen", "dependsOn", "flatMap", "depId", "allDependencies", "map", "filter", "index", "self", "indexOf", "undefined", "useEffect", "useState", "LoadingState", "useLoading", "state", "debounce", "stage", "setStage", "useState", "useEffect", "i", "setInterval", "ready", "clearInterval", "App", "placeholder", "Placeholder", "state", "debounce", "reactContexts", "useCapabilities", "Capabilities", "ReactContext", "reactRoots", "ReactRoot", "stage", "useLoading", "error", "LoadingState", "Done", "React", "ComposedContext", "composeContexts", "map", "id", "root", "Component", "key", "contexts", "length", "children", "topologicalSort", "context", "reduce", "Acc", "Next", "React", "DefaultFallback", "error", "React", "div", "style", "margin", "padding", "overflow", "border", "borderRadius", "h1", "fontSize", "message", "pre", "whiteSpace", "color", "stack", "ENABLED_KEY", "useApp", "pluginManager", "pluginLoader", "pluginLoaderParam", "plugins", "pluginsParam", "core", "coreParam", "defaults", "defaultsParam", "placeholder", "fallback", "DefaultFallback", "cacheEnabled", "safeMode", "debounce", "useDefaultValue", "map", "meta", "id", "useMemo", "plugin", "find", "invariant", "state", "live", "ready", "error", "cached", "JSON", "parse", "localStorage", "getItem", "enabled", "length", "manager", "PluginManager", "useEffect", "activation", "on", "event", "_state", "Events", "Startup", "effect", "setItem", "stringify", "setupDevtools", "useAsyncEffect", "context", "contributeCapability", "interface", "Capabilities", "implementation", "module", "RxRegistry", "registry", "Promise", "all", "activate", "SetupReactSurface", "removeCapability", "useCallback", "React", "ErrorBoundary", "PluginManagerProvider", "value", "RegistryContext", "Provider", "App", "globalThis", "composer", "useEffect", "useIntentResolver", "module", "resolver", "manager", "usePluginManager", "useEffect", "context", "contributeCapability", "interface", "Capabilities", "IntentResolver", "implementation", "removeCapability"]
|
|
7
|
+
}
|
|
@@ -1,18 +1,3 @@
|
|
|
1
|
-
import {
|
|
2
|
-
ErrorBoundary,
|
|
3
|
-
PluginManagerProvider,
|
|
4
|
-
Surface,
|
|
5
|
-
isSurfaceAvailable,
|
|
6
|
-
useApp,
|
|
7
|
-
useAppGraph,
|
|
8
|
-
useCapabilities,
|
|
9
|
-
useCapability,
|
|
10
|
-
useIntentDispatcher,
|
|
11
|
-
useIntentResolver,
|
|
12
|
-
useLayout,
|
|
13
|
-
usePluginManager,
|
|
14
|
-
useSurfaces
|
|
15
|
-
} from "./chunk-FRUTKCPG.mjs";
|
|
16
1
|
import {
|
|
17
2
|
SETTINGS_ID,
|
|
18
3
|
SETTINGS_KEY,
|
|
@@ -56,7 +41,7 @@ import {
|
|
|
56
41
|
isOneOf,
|
|
57
42
|
lazy,
|
|
58
43
|
oneOf
|
|
59
|
-
} from "./chunk-
|
|
44
|
+
} from "./chunk-LVSO2N4X.mjs";
|
|
60
45
|
|
|
61
46
|
// src/plugin-settings/translations.ts
|
|
62
47
|
var translations = [
|
|
@@ -82,7 +67,7 @@ var SettingsPlugin = definePlugin(meta, () => [
|
|
|
82
67
|
activatesAfter: [
|
|
83
68
|
Events.SettingsReady
|
|
84
69
|
],
|
|
85
|
-
activate: lazy(() => import("./store-
|
|
70
|
+
activate: lazy(() => import("./store-3HDXKFXP.mjs"))
|
|
86
71
|
}),
|
|
87
72
|
defineModule({
|
|
88
73
|
id: `${meta.id}/module/translations`,
|
|
@@ -92,12 +77,12 @@ var SettingsPlugin = definePlugin(meta, () => [
|
|
|
92
77
|
defineModule({
|
|
93
78
|
id: `${meta.id}/module/intent-resolver`,
|
|
94
79
|
activatesOn: Events.SetupIntentResolver,
|
|
95
|
-
activate: lazy(() => import("./intent-resolver-
|
|
80
|
+
activate: lazy(() => import("./intent-resolver-SYLXP62Y.mjs"))
|
|
96
81
|
}),
|
|
97
82
|
defineModule({
|
|
98
83
|
id: `${meta.id}/module/app-graph-builder`,
|
|
99
84
|
activatesOn: Events.SetupAppGraph,
|
|
100
|
-
activate: lazy(() => import("./app-graph-builder-
|
|
85
|
+
activate: lazy(() => import("./app-graph-builder-JPUFNED5.mjs"))
|
|
101
86
|
})
|
|
102
87
|
]);
|
|
103
88
|
export {
|
|
@@ -105,7 +90,6 @@ export {
|
|
|
105
90
|
Capabilities,
|
|
106
91
|
CollaborationActions,
|
|
107
92
|
CycleDetectedError,
|
|
108
|
-
ErrorBoundary,
|
|
109
93
|
Events,
|
|
110
94
|
FileInfoSchema,
|
|
111
95
|
IntentAction,
|
|
@@ -116,7 +100,6 @@ export {
|
|
|
116
100
|
Plugin,
|
|
117
101
|
PluginContext,
|
|
118
102
|
PluginManager,
|
|
119
|
-
PluginManagerProvider,
|
|
120
103
|
PluginModule,
|
|
121
104
|
Resource,
|
|
122
105
|
ResourceKey,
|
|
@@ -125,7 +108,6 @@ export {
|
|
|
125
108
|
SETTINGS_KEY,
|
|
126
109
|
SettingsAction,
|
|
127
110
|
SettingsPlugin,
|
|
128
|
-
Surface,
|
|
129
111
|
allOf,
|
|
130
112
|
chain,
|
|
131
113
|
contributes,
|
|
@@ -142,17 +124,7 @@ export {
|
|
|
142
124
|
getEvents,
|
|
143
125
|
isAllOf,
|
|
144
126
|
isOneOf,
|
|
145
|
-
isSurfaceAvailable,
|
|
146
127
|
lazy,
|
|
147
|
-
oneOf
|
|
148
|
-
useApp,
|
|
149
|
-
useAppGraph,
|
|
150
|
-
useCapabilities,
|
|
151
|
-
useCapability,
|
|
152
|
-
useIntentDispatcher,
|
|
153
|
-
useIntentResolver,
|
|
154
|
-
useLayout,
|
|
155
|
-
usePluginManager,
|
|
156
|
-
useSurfaces
|
|
128
|
+
oneOf
|
|
157
129
|
};
|
|
158
130
|
//# sourceMappingURL=index.mjs.map
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../../../src/plugin-settings/translations.ts", "../../../src/plugin-settings/SettingsPlugin.ts"],
|
|
4
|
-
"sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport { type Resource } from '
|
|
5
|
-
"mappings": "
|
|
4
|
+
"sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport { type Resource } from '../common';\n\nimport { meta } from './meta';\n\nexport const translations = [\n {\n 'en-US': {\n [meta.id]: {\n 'open settings label': 'Open settings',\n 'app settings label': 'Settings',\n 'custom plugins label': 'Plugins',\n },\n },\n },\n] as const satisfies Resource[];\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport { Capabilities, Events } from '../common';\nimport { contributes, defineModule, definePlugin, lazy } from '../core';\n\nimport { meta } from './meta';\nimport { translations } from './translations';\n\nexport const SettingsPlugin = definePlugin(meta, () => [\n defineModule({\n id: `${meta.id}/module/store`,\n activatesOn: Events.Startup,\n activatesBefore: [Events.SetupSettings],\n activatesAfter: [Events.SettingsReady],\n activate: lazy(() => import('./store')),\n }),\n defineModule({\n id: `${meta.id}/module/translations`,\n activatesOn: Events.SetupTranslations,\n activate: () => contributes(Capabilities.Translations, translations),\n }),\n defineModule({\n id: `${meta.id}/module/intent-resolver`,\n activatesOn: Events.SetupIntentResolver,\n activate: lazy(() => import('./intent-resolver')),\n }),\n defineModule({\n id: `${meta.id}/module/app-graph-builder`,\n activatesOn: Events.SetupAppGraph,\n activate: lazy(() => import('./app-graph-builder')),\n }),\n]);\n"],
|
|
5
|
+
"mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAQO,IAAMA,eAAe;EAC1B;IACE,SAAS;MACP,CAACC,KAAKC,EAAE,GAAG;QACT,uBAAuB;QACvB,sBAAsB;QACtB,wBAAwB;MAC1B;IACF;EACF;;;;ACPK,IAAMC,iBAAiBC,aAAaC,MAAM,MAAM;EACrDC,aAAa;IACXC,IAAI,GAAGF,KAAKE,EAAE;IACdC,aAAaC,OAAOC;IACpBC,iBAAiB;MAACF,OAAOG;;IACzBC,gBAAgB;MAACJ,OAAOK;;IACxBC,UAAUC,KAAK,MAAM,OAAO,sBAAA,CAAA;EAC9B,CAAA;EACAV,aAAa;IACXC,IAAI,GAAGF,KAAKE,EAAE;IACdC,aAAaC,OAAOQ;IACpBF,UAAU,MAAMG,YAAYC,aAAaC,cAAcC,YAAAA;EACzD,CAAA;EACAf,aAAa;IACXC,IAAI,GAAGF,KAAKE,EAAE;IACdC,aAAaC,OAAOa;IACpBP,UAAUC,KAAK,MAAM,OAAO,gCAAA,CAAA;EAC9B,CAAA;EACAV,aAAa;IACXC,IAAI,GAAGF,KAAKE,EAAE;IACdC,aAAaC,OAAOc;IACpBR,UAAUC,KAAK,MAAM,OAAO,kCAAA,CAAA;EAC9B,CAAA;CACD;",
|
|
6
6
|
"names": ["translations", "meta", "id", "SettingsPlugin", "definePlugin", "meta", "defineModule", "id", "activatesOn", "Events", "Startup", "activatesBefore", "SetupSettings", "activatesAfter", "SettingsReady", "activate", "lazy", "SetupTranslations", "contributes", "Capabilities", "Translations", "translations", "SetupIntentResolver", "SetupAppGraph"]
|
|
7
7
|
}
|
|
@@ -2,10 +2,10 @@ import {
|
|
|
2
2
|
createDispatcher,
|
|
3
3
|
createResolver,
|
|
4
4
|
intent_dispatcher_default
|
|
5
|
-
} from "./chunk-
|
|
5
|
+
} from "./chunk-LVSO2N4X.mjs";
|
|
6
6
|
export {
|
|
7
7
|
createDispatcher,
|
|
8
8
|
createResolver,
|
|
9
9
|
intent_dispatcher_default as default
|
|
10
10
|
};
|
|
11
|
-
//# sourceMappingURL=intent-dispatcher-
|
|
11
|
+
//# sourceMappingURL=intent-dispatcher-TNEVDPI6.mjs.map
|
|
@@ -10,7 +10,7 @@ import {
|
|
|
10
10
|
contributes,
|
|
11
11
|
createIntent,
|
|
12
12
|
createResolver
|
|
13
|
-
} from "./chunk-
|
|
13
|
+
} from "./chunk-LVSO2N4X.mjs";
|
|
14
14
|
|
|
15
15
|
// src/plugin-settings/intent-resolver.ts
|
|
16
16
|
import * as Function from "effect/Function";
|
|
@@ -36,4 +36,4 @@ var intent_resolver_default = (() => contributes(Capabilities.IntentResolver, cr
|
|
|
36
36
|
export {
|
|
37
37
|
intent_resolver_default as default
|
|
38
38
|
};
|
|
39
|
-
//# sourceMappingURL=intent-resolver-
|
|
39
|
+
//# sourceMappingURL=intent-resolver-SYLXP62Y.mjs.map
|