@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.
Files changed (117) hide show
  1. package/dist/lib/browser/{app-graph-builder-LG4RG2LM.mjs → app-graph-builder-JPUFNED5.mjs} +7 -7
  2. package/dist/lib/browser/app-graph-builder-JPUFNED5.mjs.map +7 -0
  3. package/dist/lib/browser/{chunk-2GRQ4QXA.mjs → chunk-LVSO2N4X.mjs} +160 -199
  4. package/dist/lib/browser/chunk-LVSO2N4X.mjs.map +7 -0
  5. package/dist/lib/browser/{chunk-FRUTKCPG.mjs → chunk-XRAWIHTQ.mjs} +101 -90
  6. package/dist/lib/browser/chunk-XRAWIHTQ.mjs.map +7 -0
  7. package/dist/lib/browser/index.mjs +5 -33
  8. package/dist/lib/browser/index.mjs.map +2 -2
  9. package/dist/lib/browser/{intent-dispatcher-6SHA5B3N.mjs → intent-dispatcher-TNEVDPI6.mjs} +2 -2
  10. package/dist/lib/browser/{intent-resolver-UZZ4OANZ.mjs → intent-resolver-SYLXP62Y.mjs} +2 -2
  11. package/dist/lib/browser/meta.json +1 -1
  12. package/dist/lib/browser/react/index.mjs +32 -0
  13. package/dist/lib/browser/{store-ACBEYK4B.mjs → store-3HDXKFXP.mjs} +2 -2
  14. package/dist/lib/browser/testing/index.mjs +5 -4
  15. package/dist/lib/browser/testing/index.mjs.map +3 -3
  16. package/dist/lib/node-esm/{app-graph-builder-FMHVHPWA.mjs → app-graph-builder-VO6RTSOS.mjs} +7 -7
  17. package/dist/lib/node-esm/app-graph-builder-VO6RTSOS.mjs.map +7 -0
  18. package/dist/lib/node-esm/{chunk-KSPOOYT3.mjs → chunk-FO5NIDOR.mjs} +160 -199
  19. package/dist/lib/node-esm/chunk-FO5NIDOR.mjs.map +7 -0
  20. package/dist/lib/node-esm/{chunk-CXT6CYPE.mjs → chunk-JH3SFOXA.mjs} +101 -90
  21. package/dist/lib/node-esm/chunk-JH3SFOXA.mjs.map +7 -0
  22. package/dist/lib/node-esm/index.mjs +5 -33
  23. package/dist/lib/node-esm/index.mjs.map +2 -2
  24. package/dist/lib/node-esm/{intent-dispatcher-SIYQ5ZIU.mjs → intent-dispatcher-WUNOPJES.mjs} +2 -2
  25. package/dist/lib/node-esm/{intent-resolver-7FYJMXAG.mjs → intent-resolver-VTZI3NO7.mjs} +2 -2
  26. package/dist/lib/node-esm/meta.json +1 -1
  27. package/dist/lib/node-esm/react/index.mjs +33 -0
  28. package/dist/lib/node-esm/{store-6OBLTVXC.mjs → store-PAJPVOLG.mjs} +2 -2
  29. package/dist/lib/node-esm/testing/index.mjs +5 -4
  30. package/dist/lib/node-esm/testing/index.mjs.map +3 -3
  31. package/dist/types/src/common/capabilities.d.ts +36 -42
  32. package/dist/types/src/common/capabilities.d.ts.map +1 -1
  33. package/dist/types/src/common/surface.d.ts +1 -0
  34. package/dist/types/src/common/surface.d.ts.map +1 -1
  35. package/dist/types/src/core/capabilities.d.ts +12 -12
  36. package/dist/types/src/core/capabilities.d.ts.map +1 -1
  37. package/dist/types/src/core/manager.d.ts +1 -1
  38. package/dist/types/src/core/manager.d.ts.map +1 -1
  39. package/dist/types/src/core/plugin.d.ts +4 -0
  40. package/dist/types/src/core/plugin.d.ts.map +1 -1
  41. package/dist/types/src/index.d.ts +0 -2
  42. package/dist/types/src/index.d.ts.map +1 -1
  43. package/dist/types/src/playground/generator/Main.d.ts.map +1 -1
  44. package/dist/types/src/react/App.d.ts.map +1 -0
  45. package/dist/types/src/react/App.stories.d.ts.map +1 -0
  46. package/dist/types/src/react/DefaultFallback.d.ts.map +1 -0
  47. package/dist/types/src/react/Surface.d.ts +4 -4
  48. package/dist/types/src/react/Surface.d.ts.map +1 -1
  49. package/dist/types/src/react/Surface.stories.d.ts +3 -6
  50. package/dist/types/src/react/Surface.stories.d.ts.map +1 -1
  51. package/dist/types/src/react/index.d.ts +2 -0
  52. package/dist/types/src/react/index.d.ts.map +1 -1
  53. package/dist/types/src/react/types.d.ts +6 -0
  54. package/dist/types/src/react/types.d.ts.map +1 -0
  55. package/dist/types/src/{components → react}/useApp.d.ts +2 -2
  56. package/dist/types/src/react/useApp.d.ts.map +1 -0
  57. package/dist/types/src/react/useLoading.d.ts.map +1 -0
  58. package/dist/types/src/testing/withPluginManager.d.ts +4 -3
  59. package/dist/types/src/testing/withPluginManager.d.ts.map +1 -1
  60. package/dist/types/tsconfig.tsbuildinfo +1 -1
  61. package/moon.yml +1 -1
  62. package/package.json +36 -33
  63. package/src/common/capabilities.ts +18 -19
  64. package/src/common/collaboration.ts +2 -2
  65. package/src/common/surface.ts +1 -0
  66. package/src/core/capabilities.test.ts +1 -1
  67. package/src/core/capabilities.ts +23 -19
  68. package/src/core/manager.ts +2 -2
  69. package/src/core/plugin.ts +5 -0
  70. package/src/index.ts +0 -2
  71. package/src/playground/generator/Main.tsx +0 -1
  72. package/src/playground/playground.stories.tsx +1 -1
  73. package/src/plugin-settings/app-graph-builder.ts +5 -5
  74. package/src/plugin-settings/translations.ts +1 -1
  75. package/src/{components → react}/App.tsx +1 -1
  76. package/src/{components → react}/DefaultFallback.tsx +1 -1
  77. package/src/react/Surface.stories.tsx +69 -45
  78. package/src/react/Surface.tsx +56 -33
  79. package/src/react/index.ts +4 -0
  80. package/src/react/types.ts +13 -0
  81. package/src/{components → react}/useApp.tsx +13 -12
  82. package/src/react/useCapabilities.ts +2 -2
  83. package/src/testing/withPluginManager.tsx +9 -4
  84. package/tsconfig.json +9 -0
  85. package/dist/lib/browser/app-graph-builder-LG4RG2LM.mjs.map +0 -7
  86. package/dist/lib/browser/chunk-2GRQ4QXA.mjs.map +0 -7
  87. package/dist/lib/browser/chunk-FRUTKCPG.mjs.map +0 -7
  88. package/dist/lib/browser/worker.mjs +0 -77
  89. package/dist/lib/node-esm/app-graph-builder-FMHVHPWA.mjs.map +0 -7
  90. package/dist/lib/node-esm/chunk-CXT6CYPE.mjs.map +0 -7
  91. package/dist/lib/node-esm/chunk-KSPOOYT3.mjs.map +0 -7
  92. package/dist/lib/node-esm/worker.mjs +0 -78
  93. package/dist/types/src/components/App.d.ts.map +0 -1
  94. package/dist/types/src/components/App.stories.d.ts.map +0 -1
  95. package/dist/types/src/components/DefaultFallback.d.ts.map +0 -1
  96. package/dist/types/src/components/index.d.ts +0 -2
  97. package/dist/types/src/components/index.d.ts.map +0 -1
  98. package/dist/types/src/components/useApp.d.ts.map +0 -1
  99. package/dist/types/src/components/useLoading.d.ts.map +0 -1
  100. package/dist/types/src/worker.d.ts +0 -4
  101. package/dist/types/src/worker.d.ts.map +0 -1
  102. package/src/components/index.ts +0 -5
  103. package/src/worker.ts +0 -11
  104. /package/dist/lib/browser/{intent-dispatcher-6SHA5B3N.mjs.map → intent-dispatcher-TNEVDPI6.mjs.map} +0 -0
  105. /package/dist/lib/browser/{intent-resolver-UZZ4OANZ.mjs.map → intent-resolver-SYLXP62Y.mjs.map} +0 -0
  106. /package/dist/lib/browser/{worker.mjs.map → react/index.mjs.map} +0 -0
  107. /package/dist/lib/browser/{store-ACBEYK4B.mjs.map → store-3HDXKFXP.mjs.map} +0 -0
  108. /package/dist/lib/node-esm/{intent-dispatcher-SIYQ5ZIU.mjs.map → intent-dispatcher-WUNOPJES.mjs.map} +0 -0
  109. /package/dist/lib/node-esm/{intent-resolver-7FYJMXAG.mjs.map → intent-resolver-VTZI3NO7.mjs.map} +0 -0
  110. /package/dist/lib/node-esm/{worker.mjs.map → react/index.mjs.map} +0 -0
  111. /package/dist/lib/node-esm/{store-6OBLTVXC.mjs.map → store-PAJPVOLG.mjs.map} +0 -0
  112. /package/dist/types/src/{components → react}/App.d.ts +0 -0
  113. /package/dist/types/src/{components → react}/App.stories.d.ts +0 -0
  114. /package/dist/types/src/{components → react}/DefaultFallback.d.ts +0 -0
  115. /package/dist/types/src/{components → react}/useLoading.d.ts +0 -0
  116. /package/src/{components → react}/App.stories.tsx +0 -0
  117. /package/src/{components → react}/useLoading.tsx +0 -0
@@ -3,7 +3,11 @@ import {
3
3
  Capabilities,
4
4
  Events,
5
5
  PluginManager
6
- } from "./chunk-KSPOOYT3.mjs";
6
+ } from "./chunk-FO5NIDOR.mjs";
7
+
8
+ // src/react/useCapabilities.ts
9
+ import { useAtomValue } from "@effect-atom/atom-react";
10
+ import { invariant } from "@dxos/invariant";
7
11
 
8
12
  // src/react/PluginManagerProvider.ts
9
13
  import { createContext, useContext } from "react";
@@ -13,12 +17,10 @@ var usePluginManager = () => useContext(PluginManagerContext) ?? raise(new Error
13
17
  var PluginManagerProvider = PluginManagerContext.Provider;
14
18
 
15
19
  // src/react/useCapabilities.ts
16
- import { useRxValue } from "@effect-rx/rx-react";
17
- import { invariant } from "@dxos/invariant";
18
20
  var __dxlog_file = "/__w/dxos/dxos/packages/sdk/app-framework/src/react/useCapabilities.ts";
19
21
  var useCapabilities = (interfaceDef) => {
20
22
  const manager = usePluginManager();
21
- return useRxValue(manager.context.capabilities(interfaceDef));
23
+ return useAtomValue(manager.context.capabilities(interfaceDef));
22
24
  };
23
25
  var useCapability = (interfaceDef) => {
24
26
  const capabilities = useCapabilities(interfaceDef);
@@ -42,25 +44,15 @@ var useLayout = () => useCapability(Capabilities.Layout);
42
44
  // src/react/ErrorBoundary.tsx
43
45
  import { useSignals as _useSignals } from "@preact-signals/safe-react/tracking";
44
46
  import React, { Component } from "react";
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;
55
- }
56
- return obj;
57
- }
58
47
  var ErrorBoundary = class extends Component {
59
48
  static getDerivedStateFromError(error) {
60
49
  return {
61
50
  error
62
51
  };
63
52
  }
53
+ state = {
54
+ error: void 0
55
+ };
64
56
  componentDidUpdate(prevProps) {
65
57
  if (prevProps.data !== this.props.data) {
66
58
  this.resetError();
@@ -81,11 +73,6 @@ var ErrorBoundary = class extends Component {
81
73
  error: void 0
82
74
  });
83
75
  }
84
- constructor(...args) {
85
- super(...args), _define_property(this, "state", {
86
- error: void 0
87
- });
88
- }
89
76
  };
90
77
  var DefaultFallback = ({ data, error }) => {
91
78
  var _effect = _useSignals();
@@ -108,34 +95,17 @@ import React2, { Fragment, Suspense, forwardRef, memo, useMemo } from "react";
108
95
  import { useDefaultValue } from "@dxos/react-hooks";
109
96
  import { byPosition } from "@dxos/util";
110
97
  var DEFAULT_PLACEHOLDER = /* @__PURE__ */ React2.createElement(Fragment, null);
111
- var useSurfaces = () => {
112
- const surfaces = useCapabilities(Capabilities.ReactSurface);
113
- return useMemo(() => surfaces.flat(), [
114
- surfaces
115
- ]);
116
- };
117
- var findCandidates = (surfaces, { role, data }) => {
118
- 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);
119
- };
120
- var isSurfaceAvailable = (context, { role, data }) => {
121
- const surfaces = context.getCapabilities(Capabilities.ReactSurface);
122
- const candidates = findCandidates(surfaces.flat(), {
123
- role,
124
- data
125
- });
126
- return candidates.length > 0;
127
- };
128
- var Surface = /* @__PURE__ */ memo(/* @__PURE__ */ forwardRef(({ id: _id, role, data: _data, limit, fallback, placeholder = DEFAULT_PLACEHOLDER, ...rest }, forwardedRef) => {
98
+ var Surface = /* @__PURE__ */ memo(/* @__PURE__ */ forwardRef(({ id: _id, role, data: dataParam, limit, fallback = DefaultFallback2, placeholder = DEFAULT_PLACEHOLDER, ...rest }, forwardedRef) => {
129
99
  var _effect = _useSignals2();
130
100
  try {
131
101
  const surfaces = useSurfaces();
132
- const data = useDefaultValue(_data, () => ({}));
102
+ const data = useDefaultValue(dataParam, () => ({}));
133
103
  const definitions = findCandidates(surfaces, {
134
104
  role,
135
105
  data
136
106
  });
137
107
  const candidates = limit ? definitions.slice(0, limit) : definitions;
138
- const nodes = candidates.map(({ component: Component2, id }) => /* @__PURE__ */ React2.createElement(Component2, {
108
+ const nodes = candidates.map(({ id, component: Component2 }) => /* @__PURE__ */ React2.createElement(Component2, {
139
109
  ref: forwardedRef,
140
110
  key: id,
141
111
  id,
@@ -147,42 +117,67 @@ var Surface = /* @__PURE__ */ memo(/* @__PURE__ */ forwardRef(({ id: _id, role,
147
117
  const suspense = /* @__PURE__ */ React2.createElement(Suspense, {
148
118
  fallback: placeholder
149
119
  }, nodes);
150
- return fallback ? /* @__PURE__ */ React2.createElement(ErrorBoundary, {
120
+ return /* @__PURE__ */ React2.createElement(ErrorBoundary, {
151
121
  data,
152
122
  fallback
153
- }, suspense) : suspense;
123
+ }, suspense);
154
124
  } finally {
155
125
  _effect.f();
156
126
  }
157
127
  }));
158
- Surface.displayName = "Surface";
159
-
160
- // src/react/useIntentResolver.ts
161
- import { useEffect } from "react";
162
- var useIntentResolver = (module, resolver) => {
163
- const manager = usePluginManager();
164
- useEffect(() => {
165
- manager.context.contributeCapability({
166
- module,
167
- interface: Capabilities.IntentResolver,
168
- implementation: resolver
169
- });
170
- return () => manager.context.removeCapability(Capabilities.IntentResolver, resolver);
171
- }, [
172
- module,
173
- resolver
128
+ var DefaultFallback2 = ({ data, error, dev }) => {
129
+ var _effect = _useSignals2();
130
+ try {
131
+ if (dev) {
132
+ return /* @__PURE__ */ React2.createElement("div", {
133
+ className: "flex flex-col gap-4 p-4 is-full overflow-y-auto"
134
+ }, /* @__PURE__ */ React2.createElement("h1", {
135
+ className: "flex gap-2 text-sm mbs-2"
136
+ }, error.message), /* @__PURE__ */ React2.createElement("pre", {
137
+ className: "overflow-auto text-xs text-description"
138
+ }, JSON.stringify(data, null, 2)));
139
+ }
140
+ return /* @__PURE__ */ React2.createElement("div", {
141
+ className: "flex flex-col gap-4 p-4 is-full overflow-y-auto border border-rose-500"
142
+ }, /* @__PURE__ */ React2.createElement("h1", {
143
+ className: "flex gap-2 text-sm mbs-2 text-rose-500"
144
+ }, error.message), /* @__PURE__ */ React2.createElement("pre", {
145
+ className: "overflow-auto text-xs text-description"
146
+ }, error.stack), /* @__PURE__ */ React2.createElement("pre", {
147
+ className: "overflow-auto text-xs text-description"
148
+ }, JSON.stringify(data, null, 2)));
149
+ } finally {
150
+ _effect.f();
151
+ }
152
+ };
153
+ var useSurfaces = () => {
154
+ const surfaces = useCapabilities(Capabilities.ReactSurface);
155
+ return useMemo(() => surfaces.flat(), [
156
+ surfaces
174
157
  ]);
175
158
  };
159
+ var isSurfaceAvailable = (context, { role, data }) => {
160
+ const surfaces = context.getCapabilities(Capabilities.ReactSurface);
161
+ const candidates = findCandidates(surfaces.flat(), {
162
+ role,
163
+ data
164
+ });
165
+ return candidates.length > 0;
166
+ };
167
+ var findCandidates = (surfaces, { role, data }) => {
168
+ 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);
169
+ };
170
+ Surface.displayName = "Surface";
176
171
 
177
- // src/components/useApp.tsx
178
- import { RegistryContext } from "@effect-rx/rx-react";
172
+ // src/react/useApp.tsx
173
+ import { RegistryContext } from "@effect-atom/atom-react";
179
174
  import { effect } from "@preact/signals-core";
180
- import React5, { useCallback, useEffect as useEffect3, useMemo as useMemo2 } from "react";
175
+ import React5, { useCallback, useEffect as useEffect2, useMemo as useMemo2 } from "react";
181
176
  import { invariant as invariant2 } from "@dxos/invariant";
182
177
  import { live } from "@dxos/live-object";
183
178
  import { useAsyncEffect, useDefaultValue as useDefaultValue2 } from "@dxos/react-hooks";
184
179
 
185
- // src/components/App.tsx
180
+ // src/react/App.tsx
186
181
  import { useSignals as _useSignals3 } from "@preact-signals/safe-react/tracking";
187
182
  import React3 from "react";
188
183
 
@@ -217,8 +212,8 @@ var topologicalSort = (nodes) => {
217
212
  return allDependencies.map((id) => nodes.find((node) => node.id === id)).filter((node) => node !== void 0);
218
213
  };
219
214
 
220
- // src/components/useLoading.tsx
221
- import { useEffect as useEffect2, useState } from "react";
215
+ // src/react/useLoading.tsx
216
+ import { useEffect, useState } from "react";
222
217
  var LoadingState = /* @__PURE__ */ (function(LoadingState2) {
223
218
  LoadingState2[LoadingState2["Loading"] = 0] = "Loading";
224
219
  LoadingState2[LoadingState2["FadeIn"] = 1] = "FadeIn";
@@ -228,7 +223,7 @@ var LoadingState = /* @__PURE__ */ (function(LoadingState2) {
228
223
  })({});
229
224
  var useLoading = (state, debounce = 0) => {
230
225
  const [stage, setStage] = useState(0);
231
- useEffect2(() => {
226
+ useEffect(() => {
232
227
  if (!debounce) {
233
228
  return;
234
229
  }
@@ -267,7 +262,7 @@ var useLoading = (state, debounce = 0) => {
267
262
  return stage;
268
263
  };
269
264
 
270
- // src/components/App.tsx
265
+ // src/react/App.tsx
271
266
  var App = ({ placeholder: Placeholder, state, debounce }) => {
272
267
  var _effect = _useSignals3();
273
268
  try {
@@ -300,10 +295,10 @@ var composeContexts = (contexts) => {
300
295
  return topologicalSort(contexts).map(({ context }) => context).reduce((Acc, Next) => ({ children }) => /* @__PURE__ */ React3.createElement(Acc, null, /* @__PURE__ */ React3.createElement(Next, null, children)));
301
296
  };
302
297
 
303
- // src/components/DefaultFallback.tsx
298
+ // src/react/DefaultFallback.tsx
304
299
  import { useSignals as _useSignals4 } from "@preact-signals/safe-react/tracking";
305
300
  import React4 from "react";
306
- var DefaultFallback2 = ({ error }) => {
301
+ var DefaultFallback3 = ({ error }) => {
307
302
  var _effect = _useSignals4();
308
303
  try {
309
304
  return /* @__PURE__ */ React4.createElement("div", {
@@ -319,7 +314,7 @@ var DefaultFallback2 = ({ error }) => {
319
314
  margin: "0.5rem 0",
320
315
  fontSize: "1.2rem"
321
316
  }
322
- }, "[ERROR]: ", error.message), /* @__PURE__ */ React4.createElement("pre", {
317
+ }, "ERROR: ", error.message), /* @__PURE__ */ React4.createElement("pre", {
323
318
  style: {
324
319
  overflow: "auto",
325
320
  fontSize: "1rem",
@@ -332,18 +327,18 @@ var DefaultFallback2 = ({ error }) => {
332
327
  }
333
328
  };
334
329
 
335
- // src/components/useApp.tsx
336
- var __dxlog_file2 = "/__w/dxos/dxos/packages/sdk/app-framework/src/components/useApp.tsx";
330
+ // src/react/useApp.tsx
331
+ var __dxlog_file2 = "/__w/dxos/dxos/packages/sdk/app-framework/src/react/useApp.tsx";
337
332
  var ENABLED_KEY = "dxos.org/app-framework/enabled";
338
- var useApp = ({ pluginManager, pluginLoader: _pluginLoader, plugins: _plugins, core: _core, defaults: _defaults, placeholder, fallback = DefaultFallback2, cacheEnabled = false, safeMode = false, debounce = 0 }) => {
339
- const plugins = useDefaultValue2(_plugins, () => []);
340
- const core = useDefaultValue2(_core, () => plugins.map(({ meta }) => meta.id));
341
- const defaults = useDefaultValue2(_defaults, () => []);
342
- const pluginLoader = useMemo2(() => _pluginLoader ?? ((id) => {
333
+ var useApp = ({ pluginManager, pluginLoader: pluginLoaderParam, plugins: pluginsParam, core: coreParam, defaults: defaultsParam, placeholder, fallback = DefaultFallback3, cacheEnabled = false, safeMode = false, debounce = 0 }) => {
334
+ const plugins = useDefaultValue2(pluginsParam, () => []);
335
+ const core = useDefaultValue2(coreParam, () => plugins.map(({ meta }) => meta.id));
336
+ const defaults = useDefaultValue2(defaultsParam, () => []);
337
+ const pluginLoader = useMemo2(() => pluginLoaderParam ?? ((id) => {
343
338
  const plugin = plugins.find((plugin2) => plugin2.meta.id === id);
344
339
  invariant2(plugin, `Plugin not found: ${id}`, {
345
340
  F: __dxlog_file2,
346
- L: 82,
341
+ L: 83,
347
342
  S: void 0,
348
343
  A: [
349
344
  "plugin",
@@ -352,7 +347,7 @@ var useApp = ({ pluginManager, pluginLoader: _pluginLoader, plugins: _plugins, c
352
347
  });
353
348
  return plugin;
354
349
  }), [
355
- _pluginLoader,
350
+ pluginLoaderParam,
356
351
  plugins
357
352
  ]);
358
353
  const state = useMemo2(() => live({
@@ -378,7 +373,7 @@ var useApp = ({ pluginManager, pluginLoader: _pluginLoader, plugins: _plugins, c
378
373
  core,
379
374
  enabled
380
375
  ]);
381
- useEffect3(() => {
376
+ useEffect2(() => {
382
377
  return manager.activation.on(({ event, state: _state, error }) => {
383
378
  if (!state.ready && event === Events.Startup.id) {
384
379
  state.ready = _state === "activated";
@@ -391,7 +386,7 @@ var useApp = ({ pluginManager, pluginLoader: _pluginLoader, plugins: _plugins, c
391
386
  manager,
392
387
  state
393
388
  ]);
394
- useEffect3(() => {
389
+ useEffect2(() => {
395
390
  effect(() => {
396
391
  cacheEnabled && localStorage.setItem(ENABLED_KEY, JSON.stringify(manager.enabled));
397
392
  });
@@ -399,7 +394,7 @@ var useApp = ({ pluginManager, pluginLoader: _pluginLoader, plugins: _plugins, c
399
394
  cacheEnabled,
400
395
  manager
401
396
  ]);
402
- useEffect3(() => {
397
+ useEffect2(() => {
403
398
  setupDevtools(manager);
404
399
  }, [
405
400
  manager
@@ -413,7 +408,7 @@ var useApp = ({ pluginManager, pluginLoader: _pluginLoader, plugins: _plugins, c
413
408
  manager.context.contributeCapability({
414
409
  interface: Capabilities.RxRegistry,
415
410
  implementation: manager.registry,
416
- module: "dxos.org/app-framework/rx-registry"
411
+ module: "dxos.org/app-framework/atom-registry"
417
412
  });
418
413
  await Promise.all([
419
414
  // TODO(wittjosiah): Factor out such that this could be called per surface role when attempting to render.
@@ -445,11 +440,27 @@ var useApp = ({ pluginManager, pluginLoader: _pluginLoader, plugins: _plugins, c
445
440
  ]);
446
441
  };
447
442
  var setupDevtools = (manager) => {
448
- var _globalThis;
449
- (_globalThis = globalThis).composer ?? (_globalThis.composer = {});
443
+ globalThis.composer ??= {};
450
444
  globalThis.composer.manager = manager;
451
445
  };
452
446
 
447
+ // src/react/useIntentResolver.ts
448
+ import { useEffect as useEffect3 } from "react";
449
+ var useIntentResolver = (module, resolver) => {
450
+ const manager = usePluginManager();
451
+ useEffect3(() => {
452
+ manager.context.contributeCapability({
453
+ module,
454
+ interface: Capabilities.IntentResolver,
455
+ implementation: resolver
456
+ });
457
+ return () => manager.context.removeCapability(Capabilities.IntentResolver, resolver);
458
+ }, [
459
+ module,
460
+ resolver
461
+ ]);
462
+ };
463
+
453
464
  export {
454
465
  usePluginManager,
455
466
  PluginManagerProvider,
@@ -459,10 +470,10 @@ export {
459
470
  useAppGraph,
460
471
  useLayout,
461
472
  ErrorBoundary,
473
+ Surface,
462
474
  useSurfaces,
463
475
  isSurfaceAvailable,
464
- Surface,
465
- useIntentResolver,
466
- useApp
476
+ useApp,
477
+ useIntentResolver
467
478
  };
468
- //# sourceMappingURL=chunk-CXT6CYPE.mjs.map
479
+ //# sourceMappingURL=chunk-JH3SFOXA.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,19 +1,4 @@
1
1
  import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
2
- import {
3
- ErrorBoundary,
4
- PluginManagerProvider,
5
- Surface,
6
- isSurfaceAvailable,
7
- useApp,
8
- useAppGraph,
9
- useCapabilities,
10
- useCapability,
11
- useIntentDispatcher,
12
- useIntentResolver,
13
- useLayout,
14
- usePluginManager,
15
- useSurfaces
16
- } from "./chunk-CXT6CYPE.mjs";
17
2
  import {
18
3
  SETTINGS_ID,
19
4
  SETTINGS_KEY,
@@ -57,7 +42,7 @@ import {
57
42
  isOneOf,
58
43
  lazy,
59
44
  oneOf
60
- } from "./chunk-KSPOOYT3.mjs";
45
+ } from "./chunk-FO5NIDOR.mjs";
61
46
 
62
47
  // src/plugin-settings/translations.ts
63
48
  var translations = [
@@ -83,7 +68,7 @@ var SettingsPlugin = definePlugin(meta, () => [
83
68
  activatesAfter: [
84
69
  Events.SettingsReady
85
70
  ],
86
- activate: lazy(() => import("./store-6OBLTVXC.mjs"))
71
+ activate: lazy(() => import("./store-PAJPVOLG.mjs"))
87
72
  }),
88
73
  defineModule({
89
74
  id: `${meta.id}/module/translations`,
@@ -93,12 +78,12 @@ var SettingsPlugin = definePlugin(meta, () => [
93
78
  defineModule({
94
79
  id: `${meta.id}/module/intent-resolver`,
95
80
  activatesOn: Events.SetupIntentResolver,
96
- activate: lazy(() => import("./intent-resolver-7FYJMXAG.mjs"))
81
+ activate: lazy(() => import("./intent-resolver-VTZI3NO7.mjs"))
97
82
  }),
98
83
  defineModule({
99
84
  id: `${meta.id}/module/app-graph-builder`,
100
85
  activatesOn: Events.SetupAppGraph,
101
- activate: lazy(() => import("./app-graph-builder-FMHVHPWA.mjs"))
86
+ activate: lazy(() => import("./app-graph-builder-VO6RTSOS.mjs"))
102
87
  })
103
88
  ]);
104
89
  export {
@@ -106,7 +91,6 @@ export {
106
91
  Capabilities,
107
92
  CollaborationActions,
108
93
  CycleDetectedError,
109
- ErrorBoundary,
110
94
  Events,
111
95
  FileInfoSchema,
112
96
  IntentAction,
@@ -117,7 +101,6 @@ export {
117
101
  Plugin,
118
102
  PluginContext,
119
103
  PluginManager,
120
- PluginManagerProvider,
121
104
  PluginModule,
122
105
  Resource,
123
106
  ResourceKey,
@@ -126,7 +109,6 @@ export {
126
109
  SETTINGS_KEY,
127
110
  SettingsAction,
128
111
  SettingsPlugin,
129
- Surface,
130
112
  allOf,
131
113
  chain,
132
114
  contributes,
@@ -143,17 +125,7 @@ export {
143
125
  getEvents,
144
126
  isAllOf,
145
127
  isOneOf,
146
- isSurfaceAvailable,
147
128
  lazy,
148
- oneOf,
149
- useApp,
150
- useAppGraph,
151
- useCapabilities,
152
- useCapability,
153
- useIntentDispatcher,
154
- useIntentResolver,
155
- useLayout,
156
- usePluginManager,
157
- useSurfaces
129
+ oneOf
158
130
  };
159
131
  //# 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 '@dxos/react-ui';\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;",
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
  }
@@ -3,10 +3,10 @@ import {
3
3
  createDispatcher,
4
4
  createResolver,
5
5
  intent_dispatcher_default
6
- } from "./chunk-KSPOOYT3.mjs";
6
+ } from "./chunk-FO5NIDOR.mjs";
7
7
  export {
8
8
  createDispatcher,
9
9
  createResolver,
10
10
  intent_dispatcher_default as default
11
11
  };
12
- //# sourceMappingURL=intent-dispatcher-SIYQ5ZIU.mjs.map
12
+ //# sourceMappingURL=intent-dispatcher-WUNOPJES.mjs.map
@@ -11,7 +11,7 @@ import {
11
11
  contributes,
12
12
  createIntent,
13
13
  createResolver
14
- } from "./chunk-KSPOOYT3.mjs";
14
+ } from "./chunk-FO5NIDOR.mjs";
15
15
 
16
16
  // src/plugin-settings/intent-resolver.ts
17
17
  import * as Function from "effect/Function";
@@ -37,4 +37,4 @@ var intent_resolver_default = (() => contributes(Capabilities.IntentResolver, cr
37
37
  export {
38
38
  intent_resolver_default as default
39
39
  };
40
- //# sourceMappingURL=intent-resolver-7FYJMXAG.mjs.map
40
+ //# sourceMappingURL=intent-resolver-VTZI3NO7.mjs.map