@dxos/app-framework 0.8.4-main.b97322e → 0.8.4-main.dedc0f3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (153) hide show
  1. package/.swc/plugins/linux_x86_64_19.0.0/727453fb3a62f7f1d952a41e051ca8a6f88cadc45cee43c6a4d1aa45f9b75665.wasmer-v7 +0 -0
  2. package/.swc/plugins/{v7_linux_x86_64_13.0.0/fce1bdb8e20a094e4af08bad09cc81497ed0e2e7c51223b07d371063cca18429 → linux_x86_64_19.0.0/fce1bdb8e20a094e4af08bad09cc81497ed0e2e7c51223b07d371063cca18429.wasmer-v7} +0 -0
  3. package/dist/lib/browser/{app-graph-builder-LYF7EKNN.mjs → app-graph-builder-AFFC6VB2.mjs} +3 -3
  4. package/dist/lib/browser/app-graph-builder-AFFC6VB2.mjs.map +7 -0
  5. package/dist/lib/browser/{chunk-FMN65HSW.mjs → chunk-OZY7HV2A.mjs} +376 -252
  6. package/dist/lib/browser/chunk-OZY7HV2A.mjs.map +7 -0
  7. package/dist/lib/browser/{chunk-FO2PH7M3.mjs → chunk-T6M7JB7M.mjs} +186 -130
  8. package/dist/lib/browser/chunk-T6M7JB7M.mjs.map +7 -0
  9. package/dist/lib/browser/index.mjs +11 -5
  10. package/dist/lib/browser/index.mjs.map +2 -2
  11. package/dist/lib/browser/{intent-dispatcher-LSYQZSEB.mjs → intent-dispatcher-QG7UPGQX.mjs} +2 -2
  12. package/dist/lib/browser/{intent-resolver-ZTNOSO3A.mjs → intent-resolver-4S4PSTM5.mjs} +2 -2
  13. package/dist/lib/browser/intent-resolver-4S4PSTM5.mjs.map +7 -0
  14. package/dist/lib/browser/meta.json +1 -1
  15. package/dist/lib/browser/{store-KML2R4IE.mjs → store-6E33KLGK.mjs} +2 -2
  16. package/dist/lib/browser/{store-KML2R4IE.mjs.map → store-6E33KLGK.mjs.map} +1 -1
  17. package/dist/lib/browser/testing/index.mjs +5 -7
  18. package/dist/lib/browser/testing/index.mjs.map +3 -3
  19. package/dist/lib/browser/worker.mjs +7 -1
  20. package/dist/lib/node-esm/{app-graph-builder-SAOWGJDK.mjs → app-graph-builder-S4OAULX5.mjs} +3 -3
  21. package/dist/lib/node-esm/app-graph-builder-S4OAULX5.mjs.map +7 -0
  22. package/dist/lib/node-esm/{chunk-ZEZ4FVEU.mjs → chunk-F63ZRXMK.mjs} +376 -252
  23. package/dist/lib/node-esm/chunk-F63ZRXMK.mjs.map +7 -0
  24. package/dist/lib/node-esm/{chunk-73HGSHKE.mjs → chunk-HJFU7QOR.mjs} +186 -130
  25. package/dist/lib/node-esm/chunk-HJFU7QOR.mjs.map +7 -0
  26. package/dist/lib/node-esm/index.mjs +11 -5
  27. package/dist/lib/node-esm/index.mjs.map +2 -2
  28. package/dist/lib/node-esm/{intent-dispatcher-6CYNGPSW.mjs → intent-dispatcher-NXBGPJOX.mjs} +2 -2
  29. package/dist/lib/node-esm/{intent-resolver-W7Z7WFFM.mjs → intent-resolver-2ZKXI5ET.mjs} +2 -2
  30. package/dist/lib/node-esm/intent-resolver-2ZKXI5ET.mjs.map +7 -0
  31. package/dist/lib/node-esm/meta.json +1 -1
  32. package/dist/lib/node-esm/{store-QEXGXLWZ.mjs → store-QQUTQHHT.mjs} +2 -2
  33. package/dist/lib/node-esm/{store-QEXGXLWZ.mjs.map → store-QQUTQHHT.mjs.map} +1 -1
  34. package/dist/lib/node-esm/testing/index.mjs +5 -7
  35. package/dist/lib/node-esm/testing/index.mjs.map +3 -3
  36. package/dist/lib/node-esm/worker.mjs +7 -1
  37. package/dist/types/src/common/capabilities.d.ts +75 -8
  38. package/dist/types/src/common/capabilities.d.ts.map +1 -1
  39. package/dist/types/src/common/collaboration.d.ts +9 -8
  40. package/dist/types/src/common/collaboration.d.ts.map +1 -1
  41. package/dist/types/src/common/events.d.ts.map +1 -1
  42. package/dist/types/src/common/index.d.ts +1 -1
  43. package/dist/types/src/common/index.d.ts.map +1 -1
  44. package/dist/types/src/common/surface.d.ts +1 -1
  45. package/dist/types/src/common/surface.d.ts.map +1 -1
  46. package/dist/types/src/components/App.d.ts +10 -0
  47. package/dist/types/src/components/App.d.ts.map +1 -0
  48. package/dist/types/src/components/App.stories.d.ts +15 -0
  49. package/dist/types/src/components/App.stories.d.ts.map +1 -0
  50. package/dist/types/src/components/DefaultFallback.d.ts +8 -0
  51. package/dist/types/src/components/DefaultFallback.d.ts.map +1 -0
  52. package/dist/types/src/components/index.d.ts +2 -0
  53. package/dist/types/src/components/index.d.ts.map +1 -0
  54. package/dist/types/src/{App.d.ts → components/useApp.d.ts} +7 -6
  55. package/dist/types/src/components/useApp.d.ts.map +1 -0
  56. package/dist/types/src/components/useLoading.d.ts +19 -0
  57. package/dist/types/src/components/useLoading.d.ts.map +1 -0
  58. package/dist/types/src/core/capabilities.d.ts +4 -1
  59. package/dist/types/src/core/capabilities.d.ts.map +1 -1
  60. package/dist/types/src/core/manager.d.ts +6 -2
  61. package/dist/types/src/core/manager.d.ts.map +1 -1
  62. package/dist/types/src/index.d.ts +1 -1
  63. package/dist/types/src/index.d.ts.map +1 -1
  64. package/dist/types/src/playground/debug/Debug.d.ts +1 -1
  65. package/dist/types/src/playground/generator/Main.d.ts +1 -1
  66. package/dist/types/src/playground/generator/Toolbar.d.ts +1 -1
  67. package/dist/types/src/playground/generator/Toolbar.d.ts.map +1 -1
  68. package/dist/types/src/playground/generator/generator.d.ts.map +1 -1
  69. package/dist/types/src/playground/layout/Layout.d.ts +2 -2
  70. package/dist/types/src/playground/logger/Toolbar.d.ts +1 -1
  71. package/dist/types/src/playground/logger/Toolbar.d.ts.map +1 -1
  72. package/dist/types/src/playground/logger/plugin.d.ts.map +1 -1
  73. package/dist/types/src/playground/playground.stories.d.ts +5 -3
  74. package/dist/types/src/playground/playground.stories.d.ts.map +1 -1
  75. package/dist/types/src/plugin-intent/IntentPlugin.d.ts.map +1 -1
  76. package/dist/types/src/plugin-intent/index.d.ts +1 -0
  77. package/dist/types/src/plugin-intent/index.d.ts.map +1 -1
  78. package/dist/types/src/plugin-intent/intent-dispatcher.d.ts +3 -3
  79. package/dist/types/src/plugin-intent/intent-dispatcher.d.ts.map +1 -1
  80. package/dist/types/src/plugin-settings/SettingsPlugin.d.ts.map +1 -1
  81. package/dist/types/src/plugin-settings/app-graph-builder.d.ts +1 -1
  82. package/dist/types/src/plugin-settings/app-graph-builder.d.ts.map +1 -1
  83. package/dist/types/src/plugin-settings/intent-resolver.d.ts +1 -1
  84. package/dist/types/src/plugin-settings/intent-resolver.d.ts.map +1 -1
  85. package/dist/types/src/plugin-settings/store.d.ts +1 -1
  86. package/dist/types/src/plugin-settings/store.d.ts.map +1 -1
  87. package/dist/types/src/react/ErrorBoundary.d.ts +13 -14
  88. package/dist/types/src/react/ErrorBoundary.d.ts.map +1 -1
  89. package/dist/types/src/react/IntentContext.d.ts.map +1 -1
  90. package/dist/types/src/react/Surface.d.ts.map +1 -1
  91. package/dist/types/src/react/Surface.stories.d.ts +6 -4
  92. package/dist/types/src/react/Surface.stories.d.ts.map +1 -1
  93. package/dist/types/src/react/common.d.ts.map +1 -1
  94. package/dist/types/src/react/useCapabilities.d.ts.map +1 -1
  95. package/dist/types/src/testing/withPluginManager.d.ts +4 -2
  96. package/dist/types/src/testing/withPluginManager.d.ts.map +1 -1
  97. package/dist/types/src/testing/withPluginManager.stories.d.ts +9 -3
  98. package/dist/types/src/testing/withPluginManager.stories.d.ts.map +1 -1
  99. package/dist/types/tsconfig.tsbuildinfo +1 -1
  100. package/package.json +28 -24
  101. package/src/common/capabilities.ts +91 -10
  102. package/src/common/collaboration.ts +5 -8
  103. package/src/common/events.ts +3 -1
  104. package/src/common/index.ts +1 -1
  105. package/src/common/surface.ts +1 -1
  106. package/src/components/App.stories.tsx +35 -0
  107. package/src/components/App.tsx +59 -0
  108. package/src/components/DefaultFallback.tsx +26 -0
  109. package/src/components/index.ts +5 -0
  110. package/src/{App.tsx → components/useApp.tsx} +20 -130
  111. package/src/components/useLoading.tsx +70 -0
  112. package/src/core/capabilities.test.ts +1 -1
  113. package/src/core/capabilities.ts +11 -6
  114. package/src/core/manager.test.ts +4 -3
  115. package/src/core/manager.ts +132 -54
  116. package/src/helpers.test.ts +1 -1
  117. package/src/index.ts +1 -1
  118. package/src/playground/debug/Debug.tsx +1 -1
  119. package/src/playground/generator/Toolbar.tsx +2 -1
  120. package/src/playground/generator/generator.ts +2 -2
  121. package/src/playground/layout/plugin.ts +1 -1
  122. package/src/playground/logger/Toolbar.tsx +2 -1
  123. package/src/playground/logger/plugin.ts +3 -2
  124. package/src/playground/playground.stories.tsx +15 -10
  125. package/src/plugin-intent/IntentPlugin.ts +2 -1
  126. package/src/plugin-intent/index.ts +1 -0
  127. package/src/plugin-intent/intent-dispatcher.test.ts +1 -1
  128. package/src/plugin-intent/intent-dispatcher.ts +10 -8
  129. package/src/plugin-settings/SettingsPlugin.ts +3 -2
  130. package/src/plugin-settings/app-graph-builder.ts +4 -3
  131. package/src/plugin-settings/intent-resolver.ts +3 -2
  132. package/src/plugin-settings/store.ts +1 -1
  133. package/src/react/ErrorBoundary.tsx +24 -15
  134. package/src/react/IntentContext.tsx +3 -2
  135. package/src/react/Surface.stories.tsx +21 -13
  136. package/src/react/Surface.tsx +4 -3
  137. package/src/react/common.ts +2 -1
  138. package/src/react/useCapabilities.ts +2 -1
  139. package/src/testing/withPluginManager.stories.tsx +9 -5
  140. package/src/testing/withPluginManager.tsx +13 -13
  141. package/tsconfig.json +1 -8
  142. package/.swc/plugins/v7_linux_x86_64_13.0.0/f45bdff002284d9e8f9ef3f0be909de12da36c049cbcf261ac78fc00abb09a2d +0 -0
  143. package/dist/lib/browser/app-graph-builder-LYF7EKNN.mjs.map +0 -7
  144. package/dist/lib/browser/chunk-FMN65HSW.mjs.map +0 -7
  145. package/dist/lib/browser/chunk-FO2PH7M3.mjs.map +0 -7
  146. package/dist/lib/browser/intent-resolver-ZTNOSO3A.mjs.map +0 -7
  147. package/dist/lib/node-esm/app-graph-builder-SAOWGJDK.mjs.map +0 -7
  148. package/dist/lib/node-esm/chunk-73HGSHKE.mjs.map +0 -7
  149. package/dist/lib/node-esm/chunk-ZEZ4FVEU.mjs.map +0 -7
  150. package/dist/lib/node-esm/intent-resolver-W7Z7WFFM.mjs.map +0 -7
  151. package/dist/types/src/App.d.ts.map +0 -1
  152. /package/dist/lib/browser/{intent-dispatcher-LSYQZSEB.mjs.map → intent-dispatcher-QG7UPGQX.mjs.map} +0 -0
  153. /package/dist/lib/node-esm/{intent-dispatcher-6CYNGPSW.mjs.map → intent-dispatcher-NXBGPJOX.mjs.map} +0 -0
@@ -3,7 +3,7 @@ import {
3
3
  Capabilities,
4
4
  Events,
5
5
  PluginManager
6
- } from "./chunk-ZEZ4FVEU.mjs";
6
+ } from "./chunk-F63ZRXMK.mjs";
7
7
 
8
8
  // src/react/PluginManagerProvider.ts
9
9
  import { createContext, useContext } from "react";
@@ -24,7 +24,7 @@ var useCapability = (interfaceDef) => {
24
24
  const capabilities = useCapabilities(interfaceDef);
25
25
  invariant(capabilities.length > 0, `No capability found for ${interfaceDef.identifier}`, {
26
26
  F: __dxlog_file,
27
- L: 28,
27
+ L: 29,
28
28
  S: void 0,
29
29
  A: [
30
30
  "capabilities.length > 0",
@@ -40,14 +40,22 @@ var useAppGraph = () => useCapability(Capabilities.AppGraph);
40
40
  var useLayout = () => useCapability(Capabilities.Layout);
41
41
 
42
42
  // src/react/ErrorBoundary.tsx
43
+ import { useSignals as _useSignals } from "@preact-signals/safe-react/tracking";
43
44
  import React, { Component } from "react";
44
- var ErrorBoundary = class extends Component {
45
- constructor(props) {
46
- super(props);
47
- this.state = {
48
- error: void 0
49
- };
45
+ function _define_property(obj, key, value) {
46
+ if (key in obj) {
47
+ Object.defineProperty(obj, key, {
48
+ value,
49
+ enumerable: true,
50
+ configurable: true,
51
+ writable: true
52
+ });
53
+ } else {
54
+ obj[key] = value;
50
55
  }
56
+ return obj;
57
+ }
58
+ var ErrorBoundary = class extends Component {
51
59
  static getDerivedStateFromError(error) {
52
60
  return {
53
61
  error
@@ -60,10 +68,10 @@ var ErrorBoundary = class extends Component {
60
68
  }
61
69
  render() {
62
70
  if (this.state.error) {
63
- return /* @__PURE__ */ React.createElement(this.props.fallback, {
71
+ const Fallback = this.props.fallback ?? DefaultFallback;
72
+ return /* @__PURE__ */ React.createElement(Fallback, {
64
73
  data: this.props.data,
65
- error: this.state.error,
66
- reset: this.resetError
74
+ error: this.state.error
67
75
  });
68
76
  }
69
77
  return this.props.children;
@@ -73,11 +81,30 @@ var ErrorBoundary = class extends Component {
73
81
  error: void 0
74
82
  });
75
83
  }
84
+ constructor(...args) {
85
+ super(...args), _define_property(this, "state", {
86
+ error: void 0
87
+ });
88
+ }
89
+ };
90
+ var DefaultFallback = ({ data, error }) => {
91
+ var _effect = _useSignals();
92
+ try {
93
+ return /* @__PURE__ */ React.createElement("div", {
94
+ className: "flex flex-col gap-2 overflow-hidden border border-red-500 rounded-sm"
95
+ }, /* @__PURE__ */ React.createElement("pre", {
96
+ className: "whitespace-pre-wrap font-sm text-xs p-2"
97
+ }, "ERROR: ", error.message), /* @__PURE__ */ React.createElement("pre", {
98
+ className: "whitespace-pre-wrap font-sm text-xs p-2 text-subdued"
99
+ }, JSON.stringify(data, null, 2)));
100
+ } finally {
101
+ _effect.f();
102
+ }
76
103
  };
77
104
 
78
105
  // src/react/Surface.tsx
79
- import { useSignals as _useSignals } from "@preact-signals/safe-react/tracking";
80
- import React2, { memo, forwardRef, Suspense, useMemo, Fragment } from "react";
106
+ import { useSignals as _useSignals2 } from "@preact-signals/safe-react/tracking";
107
+ import React2, { Fragment, Suspense, forwardRef, memo, useMemo } from "react";
81
108
  import { useDefaultValue } from "@dxos/react-hooks";
82
109
  import { byPosition } from "@dxos/util";
83
110
  var DEFAULT_PLACEHOLDER = /* @__PURE__ */ React2.createElement(Fragment, null);
@@ -99,7 +126,7 @@ var isSurfaceAvailable = (context, { role, data }) => {
99
126
  return candidates.length > 0;
100
127
  };
101
128
  var Surface = /* @__PURE__ */ memo(/* @__PURE__ */ forwardRef(({ id: _id, role, data: _data, limit, fallback, placeholder = DEFAULT_PLACEHOLDER, ...rest }, forwardedRef) => {
102
- var _effect = _useSignals();
129
+ var _effect = _useSignals2();
103
130
  try {
104
131
  const surfaces = useSurfaces();
105
132
  const data = useDefaultValue(_data, () => ({}));
@@ -147,14 +174,17 @@ var useIntentResolver = (module, resolver) => {
147
174
  ]);
148
175
  };
149
176
 
150
- // src/App.tsx
151
- import { useSignals as _useSignals2 } from "@preact-signals/safe-react/tracking";
177
+ // src/components/useApp.tsx
152
178
  import { RegistryContext } from "@effect-rx/rx-react";
153
179
  import { effect } from "@preact/signals-core";
154
- import React3, { useCallback, useEffect as useEffect2, useMemo as useMemo2, useState } from "react";
180
+ import React5, { useCallback, useEffect as useEffect3, useMemo as useMemo2 } from "react";
155
181
  import { invariant as invariant2 } from "@dxos/invariant";
156
182
  import { live } from "@dxos/live-object";
157
- import { useDefaultValue as useDefaultValue2 } from "@dxos/react-hooks";
183
+ import { useAsyncEffect, useDefaultValue as useDefaultValue2 } from "@dxos/react-hooks";
184
+
185
+ // src/components/App.tsx
186
+ import { useSignals as _useSignals3 } from "@preact-signals/safe-react/tracking";
187
+ import React3 from "react";
158
188
 
159
189
  // src/helpers.ts
160
190
  var topologicalSort = (nodes) => {
@@ -187,10 +217,125 @@ var topologicalSort = (nodes) => {
187
217
  return allDependencies.map((id) => nodes.find((node) => node.id === id)).filter((node) => node !== void 0);
188
218
  };
189
219
 
190
- // src/App.tsx
191
- var __dxlog_file2 = "/__w/dxos/dxos/packages/sdk/app-framework/src/App.tsx";
220
+ // src/components/useLoading.tsx
221
+ import { useEffect as useEffect2, useState } from "react";
222
+ var LoadingState = /* @__PURE__ */ function(LoadingState2) {
223
+ LoadingState2[LoadingState2["Loading"] = 0] = "Loading";
224
+ LoadingState2[LoadingState2["FadeIn"] = 1] = "FadeIn";
225
+ LoadingState2[LoadingState2["FadeOut"] = 2] = "FadeOut";
226
+ LoadingState2[LoadingState2["Done"] = 3] = "Done";
227
+ return LoadingState2;
228
+ }({});
229
+ var useLoading = (state, debounce = 0) => {
230
+ const [stage, setStage] = useState(0);
231
+ useEffect2(() => {
232
+ if (!debounce) {
233
+ return;
234
+ }
235
+ const i = setInterval(() => {
236
+ setStage((stage2) => {
237
+ switch (stage2) {
238
+ case 0: {
239
+ if (!state.ready) {
240
+ return 1;
241
+ } else {
242
+ clearInterval(i);
243
+ return 3;
244
+ }
245
+ }
246
+ case 1: {
247
+ if (state.ready) {
248
+ return 2;
249
+ }
250
+ break;
251
+ }
252
+ case 2: {
253
+ clearInterval(i);
254
+ return 3;
255
+ }
256
+ }
257
+ return stage2;
258
+ });
259
+ }, debounce);
260
+ return () => clearInterval(i);
261
+ }, [
262
+ debounce
263
+ ]);
264
+ if (!debounce) {
265
+ return state.ready ? 3 : 0;
266
+ }
267
+ return stage;
268
+ };
269
+
270
+ // src/components/App.tsx
271
+ var App = ({ placeholder: Placeholder, state, debounce }) => {
272
+ var _effect = _useSignals3();
273
+ try {
274
+ const reactContexts = useCapabilities(Capabilities.ReactContext);
275
+ const reactRoots = useCapabilities(Capabilities.ReactRoot);
276
+ const stage = useLoading(state, debounce);
277
+ if (state.error) {
278
+ throw state.error;
279
+ }
280
+ if (stage < LoadingState.Done) {
281
+ if (!Placeholder) {
282
+ return null;
283
+ }
284
+ return /* @__PURE__ */ React3.createElement(Placeholder, {
285
+ stage
286
+ });
287
+ }
288
+ const ComposedContext = composeContexts(reactContexts);
289
+ return /* @__PURE__ */ React3.createElement(ComposedContext, null, reactRoots.map(({ id, root: Component2 }) => /* @__PURE__ */ React3.createElement(Component2, {
290
+ key: id
291
+ })));
292
+ } finally {
293
+ _effect.f();
294
+ }
295
+ };
296
+ var composeContexts = (contexts) => {
297
+ if (contexts.length === 0) {
298
+ return ({ children }) => /* @__PURE__ */ React3.createElement(React3.Fragment, null, children);
299
+ }
300
+ return topologicalSort(contexts).map(({ context }) => context).reduce((Acc, Next) => ({ children }) => /* @__PURE__ */ React3.createElement(Acc, null, /* @__PURE__ */ React3.createElement(Next, null, children)));
301
+ };
302
+
303
+ // src/components/DefaultFallback.tsx
304
+ import { useSignals as _useSignals4 } from "@preact-signals/safe-react/tracking";
305
+ import React4 from "react";
306
+ var DefaultFallback2 = ({ error }) => {
307
+ var _effect = _useSignals4();
308
+ try {
309
+ return /* @__PURE__ */ React4.createElement("div", {
310
+ style: {
311
+ margin: "1rem",
312
+ padding: "1rem",
313
+ overflow: "hidden",
314
+ border: "4px solid teal",
315
+ borderRadius: "1rem"
316
+ }
317
+ }, /* @__PURE__ */ React4.createElement("h1", {
318
+ style: {
319
+ margin: "0.5rem 0",
320
+ fontSize: "1.2rem"
321
+ }
322
+ }, "[ERROR]: ", error.message), /* @__PURE__ */ React4.createElement("pre", {
323
+ style: {
324
+ overflow: "auto",
325
+ fontSize: "1rem",
326
+ whiteSpace: "pre-wrap",
327
+ color: "#888888"
328
+ }
329
+ }, error.stack));
330
+ } finally {
331
+ _effect.f();
332
+ }
333
+ };
334
+
335
+ // src/components/useApp.tsx
336
+ var __dxlog_file2 = "/__w/dxos/dxos/packages/sdk/app-framework/src/components/useApp.tsx";
192
337
  var ENABLED_KEY = "dxos.org/app-framework/enabled";
193
- var useApp = ({ pluginManager, pluginLoader: _pluginLoader, plugins: _plugins, core: _core, defaults: _defaults, placeholder, fallback = DefaultFallback, cacheEnabled = false, safeMode = false }) => {
338
+ var useApp = ({ pluginManager, pluginLoader: _pluginLoader, plugins: _plugins, core: _core, defaults: _defaults, placeholder, fallback = DefaultFallback2, cacheEnabled = false, safeMode = false, debounce = 0 }) => {
194
339
  const plugins = useDefaultValue2(_plugins, () => []);
195
340
  const core = useDefaultValue2(_core, () => plugins.map(({ meta }) => meta.id));
196
341
  const defaults = useDefaultValue2(_defaults, () => []);
@@ -198,7 +343,7 @@ var useApp = ({ pluginManager, pluginLoader: _pluginLoader, plugins: _plugins, c
198
343
  const plugin = plugins.find((plugin2) => plugin2.meta.id === id);
199
344
  invariant2(plugin, `Plugin not found: ${id}`, {
200
345
  F: __dxlog_file2,
201
- L: 78,
346
+ L: 82,
202
347
  S: void 0,
203
348
  A: [
204
349
  "plugin",
@@ -233,7 +378,7 @@ var useApp = ({ pluginManager, pluginLoader: _pluginLoader, plugins: _plugins, c
233
378
  core,
234
379
  enabled
235
380
  ]);
236
- useEffect2(() => {
381
+ useEffect3(() => {
237
382
  return manager.activation.on(({ event, state: _state, error }) => {
238
383
  if (!state.ready && event === Events.Startup.id) {
239
384
  state.ready = _state === "activated";
@@ -246,7 +391,7 @@ var useApp = ({ pluginManager, pluginLoader: _pluginLoader, plugins: _plugins, c
246
391
  manager,
247
392
  state
248
393
  ]);
249
- useEffect2(() => {
394
+ useEffect3(() => {
250
395
  effect(() => {
251
396
  cacheEnabled && localStorage.setItem(ENABLED_KEY, JSON.stringify(manager.enabled));
252
397
  });
@@ -254,7 +399,7 @@ var useApp = ({ pluginManager, pluginLoader: _pluginLoader, plugins: _plugins, c
254
399
  cacheEnabled,
255
400
  manager
256
401
  ]);
257
- useEffect2(() => {
402
+ useEffect3(() => {
258
403
  manager.context.contributeCapability({
259
404
  interface: Capabilities.PluginManager,
260
405
  implementation: manager,
@@ -272,32 +417,30 @@ var useApp = ({ pluginManager, pluginLoader: _pluginLoader, plugins: _plugins, c
272
417
  }, [
273
418
  manager
274
419
  ]);
275
- useEffect2(() => {
420
+ useEffect3(() => {
276
421
  setupDevtools(manager);
277
422
  }, [
278
423
  manager
279
424
  ]);
280
- useEffect2(() => {
281
- const timeout = setTimeout(async () => {
282
- await Promise.all([
283
- // TODO(wittjosiah): Factor out such that this could be called per surface role when attempting to render.
284
- manager.activate(Events.SetupReactSurface),
285
- manager.activate(Events.Startup)
286
- ]);
287
- });
288
- return () => clearTimeout(timeout);
425
+ useAsyncEffect(async () => {
426
+ await Promise.all([
427
+ // TODO(wittjosiah): Factor out such that this could be called per surface role when attempting to render.
428
+ manager.activate(Events.SetupReactSurface),
429
+ manager.activate(Events.Startup)
430
+ ]);
289
431
  }, [
290
432
  manager
291
433
  ]);
292
- return useCallback(() => /* @__PURE__ */ React3.createElement(ErrorBoundary, {
434
+ return useCallback(() => /* @__PURE__ */ React5.createElement(ErrorBoundary, {
293
435
  fallback
294
- }, /* @__PURE__ */ React3.createElement(PluginManagerProvider, {
436
+ }, /* @__PURE__ */ React5.createElement(PluginManagerProvider, {
295
437
  value: manager
296
- }, /* @__PURE__ */ React3.createElement(RegistryContext.Provider, {
438
+ }, /* @__PURE__ */ React5.createElement(RegistryContext.Provider, {
297
439
  value: manager.registry
298
- }, /* @__PURE__ */ React3.createElement(App, {
440
+ }, /* @__PURE__ */ React5.createElement(App, {
299
441
  placeholder,
300
- state
442
+ state,
443
+ debounce
301
444
  })))), [
302
445
  fallback,
303
446
  manager,
@@ -305,96 +448,9 @@ var useApp = ({ pluginManager, pluginLoader: _pluginLoader, plugins: _plugins, c
305
448
  state
306
449
  ]);
307
450
  };
308
- var DELAY_PLACEHOLDER = 2e3;
309
- var useLoading = (state) => {
310
- const [stage, setStage] = useState(0);
311
- useEffect2(() => {
312
- const i = setInterval(() => {
313
- setStage((tick) => {
314
- switch (tick) {
315
- case 0:
316
- if (!state.ready) {
317
- return 1;
318
- } else {
319
- clearInterval(i);
320
- return 3;
321
- }
322
- case 1:
323
- if (state.ready) {
324
- return 2;
325
- }
326
- break;
327
- case 2:
328
- clearInterval(i);
329
- return 3;
330
- }
331
- return tick;
332
- });
333
- }, DELAY_PLACEHOLDER);
334
- return () => clearInterval(i);
335
- }, []);
336
- return stage;
337
- };
338
- var App = ({ placeholder: Placeholder, state }) => {
339
- var _effect = _useSignals2();
340
- try {
341
- const reactContexts = useCapabilities(Capabilities.ReactContext);
342
- const reactRoots = useCapabilities(Capabilities.ReactRoot);
343
- const stage = useLoading(state);
344
- if (state.error) {
345
- throw state.error;
346
- }
347
- if (stage < 3) {
348
- if (!Placeholder) {
349
- return null;
350
- }
351
- return /* @__PURE__ */ React3.createElement(Placeholder, {
352
- stage
353
- });
354
- }
355
- const ComposedContext = composeContexts(reactContexts);
356
- return /* @__PURE__ */ React3.createElement(ComposedContext, null, reactRoots.map(({ id, root: Component2 }) => /* @__PURE__ */ React3.createElement(Component2, {
357
- key: id
358
- })));
359
- } finally {
360
- _effect.f();
361
- }
362
- };
363
- var DefaultFallback = ({ error }) => {
364
- var _effect = _useSignals2();
365
- try {
366
- return /* @__PURE__ */ React3.createElement("div", {
367
- style: {
368
- margin: "0.5rem",
369
- padding: "1rem",
370
- overflow: "hidden",
371
- border: "1px solid red"
372
- }
373
- }, /* @__PURE__ */ React3.createElement("h1", {
374
- style: {
375
- margin: "0.5rem 0",
376
- fontSize: "1.2rem"
377
- }
378
- }, "[ERROR]: ", error.message), /* @__PURE__ */ React3.createElement("pre", {
379
- style: {
380
- overflow: "auto",
381
- fontSize: "1rem",
382
- whiteSpace: "pre-wrap",
383
- color: "#888888"
384
- }
385
- }, error.stack));
386
- } finally {
387
- _effect.f();
388
- }
389
- };
390
- var composeContexts = (contexts) => {
391
- if (contexts.length === 0) {
392
- return ({ children }) => /* @__PURE__ */ React3.createElement(React3.Fragment, null, children);
393
- }
394
- return topologicalSort(contexts).map(({ context }) => context).reduce((Acc, Next) => ({ children }) => /* @__PURE__ */ React3.createElement(Acc, null, /* @__PURE__ */ React3.createElement(Next, null, children)));
395
- };
396
451
  var setupDevtools = (manager) => {
397
- globalThis.composer ??= {};
452
+ var _globalThis;
453
+ (_globalThis = globalThis).composer ?? (_globalThis.composer = {});
398
454
  globalThis.composer.manager = manager;
399
455
  };
400
456
 
@@ -413,4 +469,4 @@ export {
413
469
  useIntentResolver,
414
470
  useApp
415
471
  };
416
- //# sourceMappingURL=chunk-73HGSHKE.mjs.map
472
+ //# sourceMappingURL=chunk-HJFU7QOR.mjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/react/PluginManagerProvider.ts", "../../../src/react/useCapabilities.ts", "../../../src/react/common.ts", "../../../src/react/ErrorBoundary.tsx", "../../../src/react/Surface.tsx", "../../../src/react/useIntentResolver.ts", "../../../src/components/useApp.tsx", "../../../src/components/App.tsx", "../../../src/helpers.ts", "../../../src/components/useLoading.tsx", "../../../src/components/DefaultFallback.tsx"],
4
+ "sourcesContent": ["//\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 { useRxValue } from '@effect-rx/rx-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 useRxValue(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 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 JSX, 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(): string | number | boolean | JSX.Element | Iterable<ReactNode> | null | undefined {\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 <div className='flex flex-col gap-2 overflow-hidden border border-red-500 rounded-sm'>\n <pre className='whitespace-pre-wrap font-sm text-xs p-2'>ERROR: {error.message}</pre>\n <pre className='whitespace-pre-wrap font-sm text-xs p-2 text-subdued'>{JSON.stringify(data, null, 2)}</pre>\n </div>\n);\n", "//\n// Copyright 2025 DXOS.org\n//\n\nimport React, { Fragment, Suspense, forwardRef, memo, useMemo } 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 * @internal\n */\nexport const useSurfaces = () => {\n const surfaces = useCapabilities(Capabilities.ReactSurface);\n return useMemo(() => surfaces.flat(), [surfaces]);\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\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\n/**\n * A surface is a named region of the screen that can be populated by plugins.\n */\nexport const Surface = memo(\n forwardRef<HTMLElement, SurfaceProps>(\n ({ id: _id, role, data: _data, limit, fallback, placeholder = DEFAULT_PLACEHOLDER, ...rest }, forwardedRef) => {\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 anyways.\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(_data, () => ({}));\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(({ component: Component, id }) => (\n <Component ref={forwardedRef} key={id} id={id} role={role} data={data} limit={limit} {...rest} />\n ));\n\n const suspense = <Suspense fallback={placeholder}>{nodes}</Suspense>;\n\n return fallback ? (\n <ErrorBoundary data={data} fallback={fallback}>\n {suspense}\n </ErrorBoundary>\n ) : (\n suspense\n );\n },\n ),\n);\n\nSurface.displayName = 'Surface';\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", "//\n// Copyright 2025 DXOS.org\n//\n\nimport { RegistryContext } from '@effect-rx/rx-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';\nimport { ErrorBoundary, PluginManagerProvider } from '../react';\n\nimport { App } from './App';\nimport { DefaultFallback } from './DefaultFallback';\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: _pluginLoader,\n plugins: _plugins,\n core: _core,\n defaults: _defaults,\n placeholder,\n fallback = DefaultFallback,\n cacheEnabled = false,\n safeMode = false,\n debounce = 0,\n}: UseAppOptions) => {\n const plugins = useDefaultValue(_plugins, () => []);\n const core = useDefaultValue(_core, () => plugins.map(({ meta }) => meta.id));\n const defaults = useDefaultValue(_defaults, () => []);\n\n // TODO(wittjosiah): Provide a custom plugin loader which supports loading via url.\n const pluginLoader = useMemo(\n () =>\n _pluginLoader ??\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 [_pluginLoader, 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 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/rx-registry',\n });\n\n return () => {\n manager.context.removeCapability(Capabilities.PluginManager, manager);\n manager.context.removeCapability(Capabilities.RxRegistry, manager.registry);\n };\n }, [manager]);\n\n useEffect(() => {\n setupDevtools(manager);\n }, [manager]);\n\n useAsyncEffect(async () => {\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 }, [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';\nimport { useCapabilities } from '../react';\n\nimport { type UseAppOptions } from './useApp';\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"],
5
+ "mappings": "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",
6
+ "names": ["createContext", "useContext", "raise", "PluginManagerContext", "createContext", "undefined", "usePluginManager", "useContext", "raise", "Error", "PluginManagerProvider", "Provider", "useRxValue", "invariant", "useCapabilities", "interfaceDef", "manager", "usePluginManager", "useRxValue", "context", "capabilities", "useCapability", "invariant", "length", "identifier", "useIntentDispatcher", "useCapability", "Capabilities", "IntentDispatcher", "useAppGraph", "AppGraph", "useLayout", "Layout", "React", "Component", "ErrorBoundary", "Component", "getDerivedStateFromError", "error", "componentDidUpdate", "prevProps", "data", "props", "resetError", "render", "state", "Fallback", "fallback", "DefaultFallback", "children", "setState", "undefined", "div", "className", "pre", "message", "JSON", "stringify", "React", "Fragment", "Suspense", "forwardRef", "memo", "useMemo", "useDefaultValue", "byPosition", "DEFAULT_PLACEHOLDER", "React", "Fragment", "useSurfaces", "surfaces", "useCapabilities", "Capabilities", "ReactSurface", "useMemo", "flat", "findCandidates", "role", "data", "Object", "values", "filter", "definition", "Array", "isArray", "includes", "toSorted", "byPosition", "isSurfaceAvailable", "context", "getCapabilities", "candidates", "length", "Surface", "memo", "forwardRef", "id", "_id", "_data", "limit", "fallback", "placeholder", "rest", "forwardedRef", "useDefaultValue", "definitions", "slice", "nodes", "map", "component", "Component", "ref", "key", "suspense", "Suspense", "ErrorBoundary", "displayName", "useEffect", "useIntentResolver", "module", "resolver", "manager", "usePluginManager", "useEffect", "context", "contributeCapability", "interface", "Capabilities", "IntentResolver", "implementation", "removeCapability", "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", "_pluginLoader", "plugins", "_plugins", "core", "_core", "defaults", "_defaults", "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", "context", "contributeCapability", "interface", "Capabilities", "implementation", "module", "RxRegistry", "registry", "removeCapability", "setupDevtools", "useAsyncEffect", "Promise", "all", "activate", "SetupReactSurface", "useCallback", "React", "ErrorBoundary", "PluginManagerProvider", "value", "RegistryContext", "Provider", "App", "globalThis", "composer"]
7
+ }
@@ -13,7 +13,7 @@ import {
13
13
  useLayout,
14
14
  usePluginManager,
15
15
  useSurfaces
16
- } from "./chunk-73HGSHKE.mjs";
16
+ } from "./chunk-HJFU7QOR.mjs";
17
17
  import {
18
18
  SETTINGS_ACTION,
19
19
  SETTINGS_ID,
@@ -22,8 +22,10 @@ import {
22
22
  SettingsAction
23
23
  } from "./chunk-UMZQERLE.mjs";
24
24
  import {
25
+ BaseError,
25
26
  Capabilities,
26
27
  CollaborationActions,
28
+ CycleDetectedError,
27
29
  Events,
28
30
  FileInfoSchema,
29
31
  INTENT_ACTION,
@@ -34,6 +36,7 @@ import {
34
36
  LAYOUT_PLUGIN,
35
37
  Label,
36
38
  LayoutAction,
39
+ NoResolversError,
37
40
  Plugin,
38
41
  PluginContext,
39
42
  PluginManager,
@@ -59,7 +62,7 @@ import {
59
62
  isOneOf,
60
63
  lazy,
61
64
  oneOf
62
- } from "./chunk-ZEZ4FVEU.mjs";
65
+ } from "./chunk-F63ZRXMK.mjs";
63
66
 
64
67
  // src/plugin-settings/translations.ts
65
68
  var translations = [
@@ -88,7 +91,7 @@ var SettingsPlugin = () => definePlugin({
88
91
  activatesAfter: [
89
92
  Events.SettingsReady
90
93
  ],
91
- activate: lazy(() => import("./store-QEXGXLWZ.mjs"))
94
+ activate: lazy(() => import("./store-QQUTQHHT.mjs"))
92
95
  }),
93
96
  defineModule({
94
97
  id: `${SETTINGS_PLUGIN}/module/translations`,
@@ -98,17 +101,19 @@ var SettingsPlugin = () => definePlugin({
98
101
  defineModule({
99
102
  id: `${SETTINGS_PLUGIN}/module/intent-resolver`,
100
103
  activatesOn: Events.SetupIntentResolver,
101
- activate: lazy(() => import("./intent-resolver-W7Z7WFFM.mjs"))
104
+ activate: lazy(() => import("./intent-resolver-2ZKXI5ET.mjs"))
102
105
  }),
103
106
  defineModule({
104
107
  id: `${SETTINGS_PLUGIN}/module/app-graph-builder`,
105
108
  activatesOn: Events.SetupAppGraph,
106
- activate: lazy(() => import("./app-graph-builder-SAOWGJDK.mjs"))
109
+ activate: lazy(() => import("./app-graph-builder-S4OAULX5.mjs"))
107
110
  })
108
111
  ]);
109
112
  export {
113
+ BaseError,
110
114
  Capabilities,
111
115
  CollaborationActions,
116
+ CycleDetectedError,
112
117
  ErrorBoundary,
113
118
  Events,
114
119
  FileInfoSchema,
@@ -120,6 +125,7 @@ export {
120
125
  LAYOUT_PLUGIN,
121
126
  Label,
122
127
  LayoutAction,
128
+ NoResolversError,
123
129
  Plugin,
124
130
  PluginContext,
125
131
  PluginManager,
@@ -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 2023 DXOS.org\n//\n\nimport { type Resource } from '@dxos/react-ui';\n\nimport { SETTINGS_PLUGIN } from './actions';\n\nexport const translations = [\n {\n 'en-US': {\n [SETTINGS_PLUGIN]: {\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 { SETTINGS_PLUGIN } from './actions';\nimport { translations } from './translations';\nimport { Capabilities, Events } from '../common';\nimport { contributes, defineModule, definePlugin, lazy } from '../core';\n\n// TODO(wittjosiah): Add options to exclude some modules.\nexport const SettingsPlugin = () =>\n definePlugin({ id: SETTINGS_PLUGIN, name: 'Settings' }, [\n defineModule({\n id: `${SETTINGS_PLUGIN}/module/store`,\n activatesOn: Events.Startup,\n activatesBefore: [Events.SetupSettings],\n activatesAfter: [Events.SettingsReady],\n activate: lazy(() => import('./store')),\n }),\n defineModule({\n id: `${SETTINGS_PLUGIN}/module/translations`,\n activatesOn: Events.SetupTranslations,\n activate: () => contributes(Capabilities.Translations, translations),\n }),\n defineModule({\n id: `${SETTINGS_PLUGIN}/module/intent-resolver`,\n activatesOn: Events.SetupIntentResolver,\n activate: lazy(() => import('./intent-resolver')),\n }),\n defineModule({\n id: `${SETTINGS_PLUGIN}/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,eAAAA,GAAkB;QACjB,uBAAuB;QACvB,sBAAsB;QACtB,wBAAwB;MAC1B;IACF;EACF;;;;ACPK,IAAMC,iBAAiB,MAC5BC,aAAa;EAAEC,IAAIC;EAAiBC,MAAM;AAAW,GAAG;EACtDC,aAAa;IACXH,IAAI,GAAGC,eAAAA;IACPG,aAAaC,OAAOC;IACpBC,iBAAiB;MAACF,OAAOG;;IACzBC,gBAAgB;MAACJ,OAAOK;;IACxBC,UAAUC,KAAK,MAAM,OAAO,sBAAA,CAAA;EAC9B,CAAA;EACAT,aAAa;IACXH,IAAI,GAAGC,eAAAA;IACPG,aAAaC,OAAOQ;IACpBF,UAAU,MAAMG,YAAYC,aAAaC,cAAcC,YAAAA;EACzD,CAAA;EACAd,aAAa;IACXH,IAAI,GAAGC,eAAAA;IACPG,aAAaC,OAAOa;IACpBP,UAAUC,KAAK,MAAM,OAAO,gCAAA,CAAA;EAC9B,CAAA;EACAT,aAAa;IACXH,IAAI,GAAGC,eAAAA;IACPG,aAAaC,OAAOc;IACpBR,UAAUC,KAAK,MAAM,OAAO,kCAAA,CAAA;EAC9B,CAAA;CACD;",
4
+ "sourcesContent": ["//\n// Copyright 2023 DXOS.org\n//\n\nimport { type Resource } from '@dxos/react-ui';\n\nimport { SETTINGS_PLUGIN } from './actions';\n\nexport const translations = [\n {\n 'en-US': {\n [SETTINGS_PLUGIN]: {\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 { SETTINGS_PLUGIN } from './actions';\nimport { translations } from './translations';\n\n// TODO(wittjosiah): Add options to exclude some modules.\nexport const SettingsPlugin = () =>\n definePlugin({ id: SETTINGS_PLUGIN, name: 'Settings' }, [\n defineModule({\n id: `${SETTINGS_PLUGIN}/module/store`,\n activatesOn: Events.Startup,\n activatesBefore: [Events.SetupSettings],\n activatesAfter: [Events.SettingsReady],\n activate: lazy(() => import('./store')),\n }),\n defineModule({\n id: `${SETTINGS_PLUGIN}/module/translations`,\n activatesOn: Events.SetupTranslations,\n activate: () => contributes(Capabilities.Translations, translations),\n }),\n defineModule({\n id: `${SETTINGS_PLUGIN}/module/intent-resolver`,\n activatesOn: Events.SetupIntentResolver,\n activate: lazy(() => import('./intent-resolver')),\n }),\n defineModule({\n id: `${SETTINGS_PLUGIN}/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,eAAAA,GAAkB;QACjB,uBAAuB;QACvB,sBAAsB;QACtB,wBAAwB;MAC1B;IACF;EACF;;;;ACNK,IAAMC,iBAAiB,MAC5BC,aAAa;EAAEC,IAAIC;EAAiBC,MAAM;AAAW,GAAG;EACtDC,aAAa;IACXH,IAAI,GAAGC,eAAAA;IACPG,aAAaC,OAAOC;IACpBC,iBAAiB;MAACF,OAAOG;;IACzBC,gBAAgB;MAACJ,OAAOK;;IACxBC,UAAUC,KAAK,MAAM,OAAO,sBAAA,CAAA;EAC9B,CAAA;EACAT,aAAa;IACXH,IAAI,GAAGC,eAAAA;IACPG,aAAaC,OAAOQ;IACpBF,UAAU,MAAMG,YAAYC,aAAaC,cAAcC,YAAAA;EACzD,CAAA;EACAd,aAAa;IACXH,IAAI,GAAGC,eAAAA;IACPG,aAAaC,OAAOa;IACpBP,UAAUC,KAAK,MAAM,OAAO,gCAAA,CAAA;EAC9B,CAAA;EACAT,aAAa;IACXH,IAAI,GAAGC,eAAAA;IACPG,aAAaC,OAAOc;IACpBR,UAAUC,KAAK,MAAM,OAAO,kCAAA,CAAA;EAC9B,CAAA;CACD;",
6
6
  "names": ["translations", "SETTINGS_PLUGIN", "SettingsPlugin", "definePlugin", "id", "SETTINGS_PLUGIN", "name", "defineModule", "activatesOn", "Events", "Startup", "activatesBefore", "SetupSettings", "activatesAfter", "SettingsReady", "activate", "lazy", "SetupTranslations", "contributes", "Capabilities", "Translations", "translations", "SetupIntentResolver", "SetupAppGraph"]
7
7
  }
@@ -3,10 +3,10 @@ import {
3
3
  createDispatcher,
4
4
  createResolver,
5
5
  intent_dispatcher_default
6
- } from "./chunk-ZEZ4FVEU.mjs";
6
+ } from "./chunk-F63ZRXMK.mjs";
7
7
  export {
8
8
  createDispatcher,
9
9
  createResolver,
10
10
  intent_dispatcher_default as default
11
11
  };
12
- //# sourceMappingURL=intent-dispatcher-6CYNGPSW.mjs.map
12
+ //# sourceMappingURL=intent-dispatcher-NXBGPJOX.mjs.map
@@ -11,7 +11,7 @@ import {
11
11
  contributes,
12
12
  createIntent,
13
13
  createResolver
14
- } from "./chunk-ZEZ4FVEU.mjs";
14
+ } from "./chunk-F63ZRXMK.mjs";
15
15
 
16
16
  // src/plugin-settings/intent-resolver.ts
17
17
  import { pipe } from "effect";
@@ -37,4 +37,4 @@ var intent_resolver_default = () => contributes(Capabilities.IntentResolver, cre
37
37
  export {
38
38
  intent_resolver_default as default
39
39
  };
40
- //# sourceMappingURL=intent-resolver-W7Z7WFFM.mjs.map
40
+ //# sourceMappingURL=intent-resolver-2ZKXI5ET.mjs.map
@@ -0,0 +1,7 @@
1
+ {
2
+ "version": 3,
3
+ "sources": ["../../../src/plugin-settings/intent-resolver.ts"],
4
+ "sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport { pipe } from 'effect';\n\nimport { Capabilities, LayoutAction } from '../common';\nimport { contributes } from '../core';\nimport { chain, createIntent, createResolver } from '../plugin-intent';\n\nimport { SETTINGS_ID, SETTINGS_KEY, SettingsAction } from './actions';\n\nexport default () =>\n contributes(\n Capabilities.IntentResolver,\n createResolver({\n intent: SettingsAction.Open,\n resolve: ({ plugin }) => {\n const openSettings = createIntent(LayoutAction.SwitchWorkspace, { part: 'workspace', subject: SETTINGS_ID });\n return {\n intents: [\n plugin\n ? pipe(\n openSettings,\n chain(LayoutAction.Open, {\n part: 'main',\n subject: [`${SETTINGS_KEY}:${plugin.replaceAll('/', ':')}`],\n }),\n )\n : openSettings,\n ],\n };\n },\n }),\n );\n"],
5
+ "mappings": ";;;;;;;;;;;;;;;;AAIA,SAASA,YAAY;AAQrB,IAAA,0BAAe,MACbC,YACEC,aAAaC,gBACbC,eAAe;EACbC,QAAQC,eAAeC;EACvBC,SAAS,CAAC,EAAEC,OAAM,MAAE;AAClB,UAAMC,eAAeC,aAAaC,aAAaC,iBAAiB;MAAEC,MAAM;MAAaC,SAASC;IAAY,CAAA;AAC1G,WAAO;MACLC,SAAS;QACPR,SACIS,KACER,cACAS,MAAMP,aAAaL,MAAM;UACvBO,MAAM;UACNC,SAAS;YAAC,GAAGK,YAAAA,IAAgBX,OAAOY,WAAW,KAAK,GAAA,CAAA;;QACtD,CAAA,CAAA,IAEFX;;IAER;EACF;AACF,CAAA,CAAA;",
6
+ "names": ["pipe", "contributes", "Capabilities", "IntentResolver", "createResolver", "intent", "SettingsAction", "Open", "resolve", "plugin", "openSettings", "createIntent", "LayoutAction", "SwitchWorkspace", "part", "subject", "SETTINGS_ID", "intents", "pipe", "chain", "SETTINGS_KEY", "replaceAll"]
7
+ }