@dxos/app-framework 0.8.4-main.fd6878d → 0.8.4-main.fffef41

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (209) hide show
  1. package/.storybook/main.mts +11 -0
  2. package/.storybook/preview.mts +8 -0
  3. package/.swc/plugins/linux_x86_64_19.0.0/727453fb3a62f7f1d952a41e051ca8a6f88cadc45cee43c6a4d1aa45f9b75665.wasmer-v7 +0 -0
  4. package/.swc/plugins/{v7_linux_x86_64_13.0.0/fce1bdb8e20a094e4af08bad09cc81497ed0e2e7c51223b07d371063cca18429 → linux_x86_64_19.0.0/fce1bdb8e20a094e4af08bad09cc81497ed0e2e7c51223b07d371063cca18429.wasmer-v7} +0 -0
  5. package/dist/lib/browser/{app-graph-builder-MOVKFH3J.mjs → app-graph-builder-OIEZZC45.mjs} +31 -30
  6. package/dist/lib/browser/app-graph-builder-OIEZZC45.mjs.map +7 -0
  7. package/dist/lib/browser/{chunk-OSBZFKMO.mjs → chunk-6XKO24JP.mjs} +232 -177
  8. package/dist/lib/browser/chunk-6XKO24JP.mjs.map +7 -0
  9. package/dist/lib/browser/{chunk-ORWHM7CO.mjs → chunk-SCPE4ZO2.mjs} +11 -8
  10. package/dist/lib/browser/chunk-SCPE4ZO2.mjs.map +7 -0
  11. package/dist/lib/browser/{chunk-NKCIDYDI.mjs → chunk-WPW5VVAX.mjs} +189 -136
  12. package/dist/lib/browser/chunk-WPW5VVAX.mjs.map +7 -0
  13. package/dist/lib/browser/index.mjs +20 -56
  14. package/dist/lib/browser/index.mjs.map +3 -3
  15. package/dist/lib/browser/{intent-dispatcher-FTTJLVGN.mjs → intent-dispatcher-LZ4AE66E.mjs} +2 -2
  16. package/dist/lib/browser/{intent-resolver-ZCGEAG3E.mjs → intent-resolver-QVCKRX6G.mjs} +7 -7
  17. package/dist/lib/browser/intent-resolver-QVCKRX6G.mjs.map +7 -0
  18. package/dist/lib/browser/meta.json +1 -1
  19. package/dist/lib/browser/react/index.mjs +34 -0
  20. package/dist/lib/browser/{store-3QB6Q2BC.mjs → store-CNPHOYTJ.mjs} +5 -5
  21. package/dist/lib/browser/store-CNPHOYTJ.mjs.map +7 -0
  22. package/dist/lib/browser/testing/index.mjs +17 -21
  23. package/dist/lib/browser/testing/index.mjs.map +3 -3
  24. package/dist/lib/node-esm/{app-graph-builder-ODE4B5GT.mjs → app-graph-builder-EBU4NVWD.mjs} +31 -30
  25. package/dist/lib/node-esm/app-graph-builder-EBU4NVWD.mjs.map +7 -0
  26. package/dist/lib/node-esm/{chunk-WU3QN5B6.mjs → chunk-3UPX5OIS.mjs} +232 -177
  27. package/dist/lib/node-esm/chunk-3UPX5OIS.mjs.map +7 -0
  28. package/dist/lib/node-esm/{chunk-YEN7NKTF.mjs → chunk-XJZGUJ3H.mjs} +189 -136
  29. package/dist/lib/node-esm/chunk-XJZGUJ3H.mjs.map +7 -0
  30. package/dist/lib/node-esm/{chunk-UMZQERLE.mjs → chunk-ZX63QUGE.mjs} +11 -8
  31. package/dist/lib/node-esm/chunk-ZX63QUGE.mjs.map +7 -0
  32. package/dist/lib/node-esm/index.mjs +20 -56
  33. package/dist/lib/node-esm/index.mjs.map +3 -3
  34. package/dist/lib/node-esm/{intent-dispatcher-YQIQ55LJ.mjs → intent-dispatcher-MGOJ3CHD.mjs} +2 -2
  35. package/dist/lib/node-esm/{intent-resolver-KG27L7EQ.mjs → intent-resolver-URF3HN3G.mjs} +7 -7
  36. package/dist/lib/node-esm/intent-resolver-URF3HN3G.mjs.map +7 -0
  37. package/dist/lib/node-esm/meta.json +1 -1
  38. package/dist/lib/node-esm/react/index.mjs +35 -0
  39. package/dist/lib/node-esm/{store-TIJAVO3D.mjs → store-RK5B4XEL.mjs} +5 -5
  40. package/dist/lib/node-esm/store-RK5B4XEL.mjs.map +7 -0
  41. package/dist/lib/node-esm/testing/index.mjs +17 -21
  42. package/dist/lib/node-esm/testing/index.mjs.map +3 -3
  43. package/dist/types/src/common/capabilities.d.ts +41 -43
  44. package/dist/types/src/common/capabilities.d.ts.map +1 -1
  45. package/dist/types/src/common/collaboration.d.ts +10 -9
  46. package/dist/types/src/common/collaboration.d.ts.map +1 -1
  47. package/dist/types/src/common/file.d.ts +1 -1
  48. package/dist/types/src/common/file.d.ts.map +1 -1
  49. package/dist/types/src/common/layout.d.ts +1 -3
  50. package/dist/types/src/common/layout.d.ts.map +1 -1
  51. package/dist/types/src/common/surface.d.ts +19 -16
  52. package/dist/types/src/common/surface.d.ts.map +1 -1
  53. package/dist/types/src/common/translations.d.ts +1 -1
  54. package/dist/types/src/common/translations.d.ts.map +1 -1
  55. package/dist/types/src/core/capabilities.d.ts +19 -16
  56. package/dist/types/src/core/capabilities.d.ts.map +1 -1
  57. package/dist/types/src/core/manager.d.ts +1 -1
  58. package/dist/types/src/core/manager.d.ts.map +1 -1
  59. package/dist/types/src/core/plugin.d.ts +8 -1
  60. package/dist/types/src/core/plugin.d.ts.map +1 -1
  61. package/dist/types/src/index.d.ts +0 -2
  62. package/dist/types/src/index.d.ts.map +1 -1
  63. package/dist/types/src/playground/debug/Debug.d.ts +1 -1
  64. package/dist/types/src/playground/debug/plugin.d.ts +1 -1
  65. package/dist/types/src/playground/debug/plugin.d.ts.map +1 -1
  66. package/dist/types/src/playground/generator/Main.d.ts +1 -1
  67. package/dist/types/src/playground/generator/Main.d.ts.map +1 -1
  68. package/dist/types/src/playground/generator/Toolbar.d.ts +1 -1
  69. package/dist/types/src/playground/generator/generator.d.ts +1 -1
  70. package/dist/types/src/playground/generator/generator.d.ts.map +1 -1
  71. package/dist/types/src/playground/generator/plugin.d.ts +1 -1
  72. package/dist/types/src/playground/generator/plugin.d.ts.map +1 -1
  73. package/dist/types/src/playground/layout/Layout.d.ts +2 -2
  74. package/dist/types/src/playground/layout/plugin.d.ts +1 -1
  75. package/dist/types/src/playground/layout/plugin.d.ts.map +1 -1
  76. package/dist/types/src/playground/logger/Toolbar.d.ts +1 -1
  77. package/dist/types/src/playground/logger/plugin.d.ts +1 -1
  78. package/dist/types/src/playground/logger/plugin.d.ts.map +1 -1
  79. package/dist/types/src/playground/logger/schema.d.ts +1 -1
  80. package/dist/types/src/playground/logger/schema.d.ts.map +1 -1
  81. package/dist/types/src/playground/playground.stories.d.ts +5 -4
  82. package/dist/types/src/playground/playground.stories.d.ts.map +1 -1
  83. package/dist/types/src/plugin-intent/IntentPlugin.d.ts +1 -1
  84. package/dist/types/src/plugin-intent/IntentPlugin.d.ts.map +1 -1
  85. package/dist/types/src/plugin-intent/actions.d.ts +5 -7
  86. package/dist/types/src/plugin-intent/actions.d.ts.map +1 -1
  87. package/dist/types/src/plugin-intent/errors.d.ts.map +1 -1
  88. package/dist/types/src/plugin-intent/index.d.ts +1 -0
  89. package/dist/types/src/plugin-intent/index.d.ts.map +1 -1
  90. package/dist/types/src/plugin-intent/intent-dispatcher.d.ts +5 -5
  91. package/dist/types/src/plugin-intent/intent-dispatcher.d.ts.map +1 -1
  92. package/dist/types/src/plugin-intent/intent.d.ts +1 -1
  93. package/dist/types/src/plugin-intent/intent.d.ts.map +1 -1
  94. package/dist/types/src/plugin-intent/meta.d.ts +3 -0
  95. package/dist/types/src/plugin-intent/meta.d.ts.map +1 -0
  96. package/dist/types/src/plugin-settings/SettingsPlugin.d.ts +1 -1
  97. package/dist/types/src/plugin-settings/SettingsPlugin.d.ts.map +1 -1
  98. package/dist/types/src/plugin-settings/actions.d.ts +5 -7
  99. package/dist/types/src/plugin-settings/actions.d.ts.map +1 -1
  100. package/dist/types/src/plugin-settings/app-graph-builder.d.ts +1 -1
  101. package/dist/types/src/plugin-settings/app-graph-builder.d.ts.map +1 -1
  102. package/dist/types/src/plugin-settings/intent-resolver.d.ts +1 -1
  103. package/dist/types/src/plugin-settings/meta.d.ts +3 -0
  104. package/dist/types/src/plugin-settings/meta.d.ts.map +1 -0
  105. package/dist/types/src/plugin-settings/store.d.ts +1 -1
  106. package/dist/types/src/plugin-settings/translations.d.ts +2 -1
  107. package/dist/types/src/plugin-settings/translations.d.ts.map +1 -1
  108. package/dist/types/src/react/App.d.ts +10 -0
  109. package/dist/types/src/react/App.d.ts.map +1 -0
  110. package/dist/types/src/react/App.stories.d.ts +14 -0
  111. package/dist/types/src/react/App.stories.d.ts.map +1 -0
  112. package/dist/types/src/react/DefaultFallback.d.ts +8 -0
  113. package/dist/types/src/react/DefaultFallback.d.ts.map +1 -0
  114. package/dist/types/src/react/ErrorBoundary.d.ts +2 -2
  115. package/dist/types/src/react/ErrorBoundary.d.ts.map +1 -1
  116. package/dist/types/src/react/Surface.d.ts +5 -5
  117. package/dist/types/src/react/Surface.d.ts.map +1 -1
  118. package/dist/types/src/react/Surface.stories.d.ts +8 -10
  119. package/dist/types/src/react/Surface.stories.d.ts.map +1 -1
  120. package/dist/types/src/react/index.d.ts +2 -0
  121. package/dist/types/src/react/index.d.ts.map +1 -1
  122. package/dist/types/src/react/types.d.ts +14 -0
  123. package/dist/types/src/react/types.d.ts.map +1 -0
  124. package/dist/types/src/{App.d.ts → react/useApp.d.ts} +7 -6
  125. package/dist/types/src/react/useApp.d.ts.map +1 -0
  126. package/dist/types/src/react/useLoading.d.ts +19 -0
  127. package/dist/types/src/react/useLoading.d.ts.map +1 -0
  128. package/dist/types/src/testing/withPluginManager.d.ts +7 -8
  129. package/dist/types/src/testing/withPluginManager.d.ts.map +1 -1
  130. package/dist/types/src/testing/withPluginManager.stories.d.ts +9 -3
  131. package/dist/types/src/testing/withPluginManager.stories.d.ts.map +1 -1
  132. package/dist/types/tsconfig.tsbuildinfo +1 -1
  133. package/moon.yml +5 -1
  134. package/package.json +44 -40
  135. package/src/common/capabilities.ts +33 -25
  136. package/src/common/collaboration.ts +6 -9
  137. package/src/common/file.ts +1 -1
  138. package/src/common/layout.ts +3 -4
  139. package/src/common/surface.ts +23 -21
  140. package/src/common/translations.ts +1 -1
  141. package/src/core/capabilities.test.ts +2 -2
  142. package/src/core/capabilities.ts +35 -27
  143. package/src/core/manager.test.ts +19 -19
  144. package/src/core/manager.ts +14 -7
  145. package/src/core/plugin.ts +13 -2
  146. package/src/index.ts +0 -2
  147. package/src/playground/debug/Debug.tsx +1 -1
  148. package/src/playground/debug/plugin.ts +7 -8
  149. package/src/playground/generator/Main.tsx +0 -1
  150. package/src/playground/generator/generator.ts +2 -2
  151. package/src/playground/generator/plugin.ts +12 -13
  152. package/src/playground/layout/plugin.ts +9 -8
  153. package/src/playground/logger/plugin.ts +27 -23
  154. package/src/playground/logger/schema.ts +1 -1
  155. package/src/playground/playground.stories.tsx +17 -14
  156. package/src/plugin-intent/IntentPlugin.ts +12 -13
  157. package/src/plugin-intent/actions.ts +4 -6
  158. package/src/plugin-intent/errors.ts +2 -1
  159. package/src/plugin-intent/index.ts +1 -0
  160. package/src/plugin-intent/intent-dispatcher.test.ts +10 -3
  161. package/src/plugin-intent/intent-dispatcher.ts +16 -8
  162. package/src/plugin-intent/intent.ts +1 -1
  163. package/src/plugin-intent/meta.ts +10 -0
  164. package/src/plugin-settings/SettingsPlugin.ts +25 -27
  165. package/src/plugin-settings/actions.ts +9 -13
  166. package/src/plugin-settings/app-graph-builder.ts +22 -20
  167. package/src/plugin-settings/intent-resolver.ts +2 -2
  168. package/src/plugin-settings/meta.ts +10 -0
  169. package/src/plugin-settings/store.ts +2 -2
  170. package/src/plugin-settings/translations.ts +4 -4
  171. package/src/react/App.stories.tsx +33 -0
  172. package/src/react/App.tsx +59 -0
  173. package/src/react/DefaultFallback.tsx +26 -0
  174. package/src/react/ErrorBoundary.tsx +10 -8
  175. package/src/react/Surface.stories.tsx +79 -51
  176. package/src/react/Surface.tsx +67 -36
  177. package/src/react/index.ts +4 -0
  178. package/src/react/types.ts +38 -0
  179. package/src/react/useApp.tsx +165 -0
  180. package/src/react/useCapabilities.ts +2 -2
  181. package/src/react/useLoading.tsx +70 -0
  182. package/src/testing/withPluginManager.stories.tsx +7 -4
  183. package/src/testing/withPluginManager.tsx +27 -29
  184. package/tsconfig.json +11 -9
  185. package/vitest.config.ts +8 -6
  186. package/.swc/plugins/v7_linux_x86_64_13.0.0/c614d7475354583212fbd7669acbae95b9832c305bf51bdaabe2e6de05abb6bf +0 -0
  187. package/dist/lib/browser/app-graph-builder-MOVKFH3J.mjs.map +0 -7
  188. package/dist/lib/browser/chunk-NKCIDYDI.mjs.map +0 -7
  189. package/dist/lib/browser/chunk-ORWHM7CO.mjs.map +0 -7
  190. package/dist/lib/browser/chunk-OSBZFKMO.mjs.map +0 -7
  191. package/dist/lib/browser/intent-resolver-ZCGEAG3E.mjs.map +0 -7
  192. package/dist/lib/browser/store-3QB6Q2BC.mjs.map +0 -7
  193. package/dist/lib/browser/worker.mjs +0 -79
  194. package/dist/lib/node-esm/app-graph-builder-ODE4B5GT.mjs.map +0 -7
  195. package/dist/lib/node-esm/chunk-UMZQERLE.mjs.map +0 -7
  196. package/dist/lib/node-esm/chunk-WU3QN5B6.mjs.map +0 -7
  197. package/dist/lib/node-esm/chunk-YEN7NKTF.mjs.map +0 -7
  198. package/dist/lib/node-esm/intent-resolver-KG27L7EQ.mjs.map +0 -7
  199. package/dist/lib/node-esm/store-TIJAVO3D.mjs.map +0 -7
  200. package/dist/lib/node-esm/worker.mjs +0 -80
  201. package/dist/types/src/App.d.ts.map +0 -1
  202. package/dist/types/src/worker.d.ts +0 -4
  203. package/dist/types/src/worker.d.ts.map +0 -1
  204. package/src/App.tsx +0 -284
  205. package/src/worker.ts +0 -11
  206. /package/dist/lib/browser/{intent-dispatcher-FTTJLVGN.mjs.map → intent-dispatcher-LZ4AE66E.mjs.map} +0 -0
  207. /package/dist/lib/browser/{worker.mjs.map → react/index.mjs.map} +0 -0
  208. /package/dist/lib/node-esm/{intent-dispatcher-YQIQ55LJ.mjs.map → intent-dispatcher-MGOJ3CHD.mjs.map} +0 -0
  209. /package/dist/lib/node-esm/{worker.mjs.map → react/index.mjs.map} +0 -0
@@ -3,7 +3,11 @@ import {
3
3
  Capabilities,
4
4
  Events,
5
5
  PluginManager
6
- } from "./chunk-YEN7NKTF.mjs";
6
+ } from "./chunk-XJZGUJ3H.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);
@@ -39,6 +41,10 @@ var useIntentDispatcher = () => useCapability(Capabilities.IntentDispatcher);
39
41
  var useAppGraph = () => useCapability(Capabilities.AppGraph);
40
42
  var useLayout = () => useCapability(Capabilities.Layout);
41
43
 
44
+ // src/react/types.ts
45
+ import * as Schema from "effect/Schema";
46
+ var SurfaceCardRole = Schema.Literal("card", "card--popover", "card--intrinsic", "card--extrinsic", "card--transclusion");
47
+
42
48
  // src/react/ErrorBoundary.tsx
43
49
  import { useSignals as _useSignals } from "@preact-signals/safe-react/tracking";
44
50
  import React, { Component } from "react";
@@ -77,10 +83,10 @@ var DefaultFallback = ({ data, error }) => {
77
83
  try {
78
84
  return /* @__PURE__ */ React.createElement("div", {
79
85
  className: "flex flex-col gap-2 overflow-hidden border border-red-500 rounded-sm"
80
- }, /* @__PURE__ */ React.createElement("pre", {
81
- className: "whitespace-pre-wrap font-sm text-xs p-2"
86
+ }, /* @__PURE__ */ React.createElement("h1", {
87
+ className: "p-2"
82
88
  }, "ERROR: ", error.message), /* @__PURE__ */ React.createElement("pre", {
83
- className: "whitespace-pre-wrap font-sm text-xs p-2 text-subdued"
89
+ className: "p-2 overflow-y-auto text-sm text-subdued"
84
90
  }, JSON.stringify(data, null, 2)));
85
91
  } finally {
86
92
  _effect.f();
@@ -93,34 +99,17 @@ import React2, { Fragment, Suspense, forwardRef, memo, useMemo } from "react";
93
99
  import { useDefaultValue } from "@dxos/react-hooks";
94
100
  import { byPosition } from "@dxos/util";
95
101
  var DEFAULT_PLACEHOLDER = /* @__PURE__ */ React2.createElement(Fragment, null);
96
- var useSurfaces = () => {
97
- const surfaces = useCapabilities(Capabilities.ReactSurface);
98
- return useMemo(() => surfaces.flat(), [
99
- surfaces
100
- ]);
101
- };
102
- var findCandidates = (surfaces, { role, data }) => {
103
- 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);
104
- };
105
- var isSurfaceAvailable = (context, { role, data }) => {
106
- const surfaces = context.getCapabilities(Capabilities.ReactSurface);
107
- const candidates = findCandidates(surfaces.flat(), {
108
- role,
109
- data
110
- });
111
- return candidates.length > 0;
112
- };
113
- var Surface = /* @__PURE__ */ memo(/* @__PURE__ */ forwardRef(({ id: _id, role, data: _data, limit, fallback, placeholder = DEFAULT_PLACEHOLDER, ...rest }, forwardedRef) => {
102
+ var Surface = /* @__PURE__ */ memo(/* @__PURE__ */ forwardRef(({ id: _id, role, data: dataParam, limit, fallback = DefaultFallback2, placeholder = DEFAULT_PLACEHOLDER, ...rest }, forwardedRef) => {
114
103
  var _effect = _useSignals2();
115
104
  try {
116
105
  const surfaces = useSurfaces();
117
- const data = useDefaultValue(_data, () => ({}));
106
+ const data = useDefaultValue(dataParam, () => ({}));
118
107
  const definitions = findCandidates(surfaces, {
119
108
  role,
120
109
  data
121
110
  });
122
111
  const candidates = limit ? definitions.slice(0, limit) : definitions;
123
- const nodes = candidates.map(({ component: Component2, id }) => /* @__PURE__ */ React2.createElement(Component2, {
112
+ const nodes = candidates.map(({ id, component: Component2 }) => /* @__PURE__ */ React2.createElement(Component2, {
124
113
  ref: forwardedRef,
125
114
  key: id,
126
115
  id,
@@ -132,41 +121,69 @@ var Surface = /* @__PURE__ */ memo(/* @__PURE__ */ forwardRef(({ id: _id, role,
132
121
  const suspense = /* @__PURE__ */ React2.createElement(Suspense, {
133
122
  fallback: placeholder
134
123
  }, nodes);
135
- return fallback ? /* @__PURE__ */ React2.createElement(ErrorBoundary, {
124
+ return /* @__PURE__ */ React2.createElement(ErrorBoundary, {
136
125
  data,
137
126
  fallback
138
- }, suspense) : suspense;
127
+ }, suspense);
139
128
  } finally {
140
129
  _effect.f();
141
130
  }
142
131
  }));
143
- Surface.displayName = "Surface";
144
-
145
- // src/react/useIntentResolver.ts
146
- import { useEffect } from "react";
147
- var useIntentResolver = (module, resolver) => {
148
- const manager = usePluginManager();
149
- useEffect(() => {
150
- manager.context.contributeCapability({
151
- module,
152
- interface: Capabilities.IntentResolver,
153
- implementation: resolver
154
- });
155
- return () => manager.context.removeCapability(Capabilities.IntentResolver, resolver);
156
- }, [
157
- module,
158
- resolver
132
+ var DefaultFallback2 = ({ data, error, dev }) => {
133
+ var _effect = _useSignals2();
134
+ try {
135
+ if (dev) {
136
+ return /* @__PURE__ */ React2.createElement("div", {
137
+ className: "flex flex-col gap-4 p-4 is-full overflow-y-auto"
138
+ }, /* @__PURE__ */ React2.createElement("h1", {
139
+ className: "flex gap-2 text-sm mbs-2"
140
+ }, error.message), /* @__PURE__ */ React2.createElement("pre", {
141
+ className: "overflow-auto text-xs text-description"
142
+ }, JSON.stringify(data, null, 2)));
143
+ }
144
+ return /* @__PURE__ */ React2.createElement("div", {
145
+ className: "flex flex-col gap-4 p-4 is-full overflow-y-auto border border-roseFill"
146
+ }, /* @__PURE__ */ React2.createElement("h1", {
147
+ className: "flex gap-2 text-sm mbs-2 text-rose-500"
148
+ }, error.message), /* @__PURE__ */ React2.createElement("pre", {
149
+ className: "overflow-auto text-xs text-description"
150
+ }, error.stack), /* @__PURE__ */ React2.createElement("pre", {
151
+ className: "overflow-auto text-xs text-description"
152
+ }, JSON.stringify(data, null, 2)));
153
+ } finally {
154
+ _effect.f();
155
+ }
156
+ };
157
+ var useSurfaces = () => {
158
+ const surfaces = useCapabilities(Capabilities.ReactSurface);
159
+ return useMemo(() => surfaces.flat(), [
160
+ surfaces
159
161
  ]);
160
162
  };
163
+ var isSurfaceAvailable = (context, { role, data }) => {
164
+ const surfaces = context.getCapabilities(Capabilities.ReactSurface);
165
+ const candidates = findCandidates(surfaces.flat(), {
166
+ role,
167
+ data
168
+ });
169
+ return candidates.length > 0;
170
+ };
171
+ var findCandidates = (surfaces, { role, data }) => {
172
+ 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);
173
+ };
174
+ Surface.displayName = "Surface";
161
175
 
162
- // src/App.tsx
163
- import { useSignals as _useSignals3 } from "@preact-signals/safe-react/tracking";
164
- import { RegistryContext } from "@effect-rx/rx-react";
176
+ // src/react/useApp.tsx
177
+ import { RegistryContext } from "@effect-atom/atom-react";
165
178
  import { effect } from "@preact/signals-core";
166
- import React3, { useCallback, useEffect as useEffect2, useMemo as useMemo2, useState } from "react";
179
+ import React5, { useCallback, useEffect as useEffect2, useMemo as useMemo2 } from "react";
167
180
  import { invariant as invariant2 } from "@dxos/invariant";
168
181
  import { live } from "@dxos/live-object";
169
- import { useDefaultValue as useDefaultValue2 } from "@dxos/react-hooks";
182
+ import { useAsyncEffect, useDefaultValue as useDefaultValue2 } from "@dxos/react-hooks";
183
+
184
+ // src/react/App.tsx
185
+ import { useSignals as _useSignals3 } from "@preact-signals/safe-react/tracking";
186
+ import React3 from "react";
170
187
 
171
188
  // src/helpers.ts
172
189
  var topologicalSort = (nodes) => {
@@ -199,18 +216,133 @@ var topologicalSort = (nodes) => {
199
216
  return allDependencies.map((id) => nodes.find((node) => node.id === id)).filter((node) => node !== void 0);
200
217
  };
201
218
 
202
- // src/App.tsx
203
- var __dxlog_file2 = "/__w/dxos/dxos/packages/sdk/app-framework/src/App.tsx";
219
+ // src/react/useLoading.tsx
220
+ import { useEffect, useState } from "react";
221
+ var LoadingState = /* @__PURE__ */ (function(LoadingState2) {
222
+ LoadingState2[LoadingState2["Loading"] = 0] = "Loading";
223
+ LoadingState2[LoadingState2["FadeIn"] = 1] = "FadeIn";
224
+ LoadingState2[LoadingState2["FadeOut"] = 2] = "FadeOut";
225
+ LoadingState2[LoadingState2["Done"] = 3] = "Done";
226
+ return LoadingState2;
227
+ })({});
228
+ var useLoading = (state, debounce = 0) => {
229
+ const [stage, setStage] = useState(0);
230
+ useEffect(() => {
231
+ if (!debounce) {
232
+ return;
233
+ }
234
+ const i = setInterval(() => {
235
+ setStage((stage2) => {
236
+ switch (stage2) {
237
+ case 0: {
238
+ if (!state.ready) {
239
+ return 1;
240
+ } else {
241
+ clearInterval(i);
242
+ return 3;
243
+ }
244
+ }
245
+ case 1: {
246
+ if (state.ready) {
247
+ return 2;
248
+ }
249
+ break;
250
+ }
251
+ case 2: {
252
+ clearInterval(i);
253
+ return 3;
254
+ }
255
+ }
256
+ return stage2;
257
+ });
258
+ }, debounce);
259
+ return () => clearInterval(i);
260
+ }, [
261
+ debounce
262
+ ]);
263
+ if (!debounce) {
264
+ return state.ready ? 3 : 0;
265
+ }
266
+ return stage;
267
+ };
268
+
269
+ // src/react/App.tsx
270
+ var App = ({ placeholder: Placeholder, state, debounce }) => {
271
+ var _effect = _useSignals3();
272
+ try {
273
+ const reactContexts = useCapabilities(Capabilities.ReactContext);
274
+ const reactRoots = useCapabilities(Capabilities.ReactRoot);
275
+ const stage = useLoading(state, debounce);
276
+ if (state.error) {
277
+ throw state.error;
278
+ }
279
+ if (stage < LoadingState.Done) {
280
+ if (!Placeholder) {
281
+ return null;
282
+ }
283
+ return /* @__PURE__ */ React3.createElement(Placeholder, {
284
+ stage
285
+ });
286
+ }
287
+ const ComposedContext = composeContexts(reactContexts);
288
+ return /* @__PURE__ */ React3.createElement(ComposedContext, null, reactRoots.map(({ id, root: Component2 }) => /* @__PURE__ */ React3.createElement(Component2, {
289
+ key: id
290
+ })));
291
+ } finally {
292
+ _effect.f();
293
+ }
294
+ };
295
+ var composeContexts = (contexts) => {
296
+ if (contexts.length === 0) {
297
+ return ({ children }) => /* @__PURE__ */ React3.createElement(React3.Fragment, null, children);
298
+ }
299
+ return topologicalSort(contexts).map(({ context }) => context).reduce((Acc, Next) => ({ children }) => /* @__PURE__ */ React3.createElement(Acc, null, /* @__PURE__ */ React3.createElement(Next, null, children)));
300
+ };
301
+
302
+ // src/react/DefaultFallback.tsx
303
+ import { useSignals as _useSignals4 } from "@preact-signals/safe-react/tracking";
304
+ import React4 from "react";
305
+ var DefaultFallback3 = ({ error }) => {
306
+ var _effect = _useSignals4();
307
+ try {
308
+ return /* @__PURE__ */ React4.createElement("div", {
309
+ style: {
310
+ margin: "1rem",
311
+ padding: "1rem",
312
+ overflow: "hidden",
313
+ border: "4px solid teal",
314
+ borderRadius: "1rem"
315
+ }
316
+ }, /* @__PURE__ */ React4.createElement("h1", {
317
+ style: {
318
+ margin: "0.5rem 0",
319
+ fontSize: "1.2rem"
320
+ }
321
+ }, "ERROR: ", error.message), /* @__PURE__ */ React4.createElement("pre", {
322
+ style: {
323
+ overflow: "auto",
324
+ fontSize: "1rem",
325
+ whiteSpace: "pre-wrap",
326
+ color: "#888888"
327
+ }
328
+ }, error.stack));
329
+ } finally {
330
+ _effect.f();
331
+ }
332
+ };
333
+
334
+ // src/react/useApp.tsx
335
+ var __dxlog_file2 = "/__w/dxos/dxos/packages/sdk/app-framework/src/react/useApp.tsx";
204
336
  var ENABLED_KEY = "dxos.org/app-framework/enabled";
205
- var useApp = ({ pluginManager, pluginLoader: _pluginLoader, plugins: _plugins, core: _core, defaults: _defaults, placeholder, fallback = DefaultFallback2, cacheEnabled = false, safeMode = false }) => {
206
- const plugins = useDefaultValue2(_plugins, () => []);
207
- const core = useDefaultValue2(_core, () => plugins.map(({ meta }) => meta.id));
208
- const defaults = useDefaultValue2(_defaults, () => []);
209
- const pluginLoader = useMemo2(() => _pluginLoader ?? ((id) => {
337
+ var useApp = ({ pluginManager, pluginLoader: pluginLoaderParam, plugins: pluginsParam, core: coreParam, defaults: defaultsParam, placeholder, fallback = DefaultFallback3, cacheEnabled = false, safeMode = false, debounce = 0 }) => {
338
+ const plugins = useDefaultValue2(pluginsParam, () => []);
339
+ const core = useDefaultValue2(coreParam, () => plugins.map(({ meta }) => meta.id));
340
+ const defaults = useDefaultValue2(defaultsParam, () => []);
341
+ const pluginLoader = useMemo2(() => pluginLoaderParam ?? ((id) => {
210
342
  const plugin = plugins.find((plugin2) => plugin2.meta.id === id);
211
343
  invariant2(plugin, `Plugin not found: ${id}`, {
212
344
  F: __dxlog_file2,
213
- L: 78,
345
+ L: 83,
214
346
  S: void 0,
215
347
  A: [
216
348
  "plugin",
@@ -219,7 +351,7 @@ var useApp = ({ pluginManager, pluginLoader: _pluginLoader, plugins: _plugins, c
219
351
  });
220
352
  return plugin;
221
353
  }), [
222
- _pluginLoader,
354
+ pluginLoaderParam,
223
355
  plugins
224
356
  ]);
225
357
  const state = useMemo2(() => live({
@@ -267,49 +399,43 @@ var useApp = ({ pluginManager, pluginLoader: _pluginLoader, plugins: _plugins, c
267
399
  manager
268
400
  ]);
269
401
  useEffect2(() => {
402
+ setupDevtools(manager);
403
+ }, [
404
+ manager
405
+ ]);
406
+ useAsyncEffect(async () => {
270
407
  manager.context.contributeCapability({
271
408
  interface: Capabilities.PluginManager,
272
409
  implementation: manager,
273
410
  module: "dxos.org/app-framework/plugin-manager"
274
411
  });
275
412
  manager.context.contributeCapability({
276
- interface: Capabilities.RxRegistry,
413
+ interface: Capabilities.AtomRegistry,
277
414
  implementation: manager.registry,
278
- module: "dxos.org/app-framework/rx-registry"
415
+ module: "dxos.org/app-framework/atom-registry"
279
416
  });
417
+ await Promise.all([
418
+ // TODO(wittjosiah): Factor out such that this could be called per surface role when attempting to render.
419
+ manager.activate(Events.SetupReactSurface),
420
+ manager.activate(Events.Startup)
421
+ ]);
280
422
  return () => {
281
423
  manager.context.removeCapability(Capabilities.PluginManager, manager);
282
- manager.context.removeCapability(Capabilities.RxRegistry, manager.registry);
424
+ manager.context.removeCapability(Capabilities.AtomRegistry, manager.registry);
283
425
  };
284
426
  }, [
285
427
  manager
286
428
  ]);
287
- useEffect2(() => {
288
- setupDevtools(manager);
289
- }, [
290
- manager
291
- ]);
292
- useEffect2(() => {
293
- const timeout = setTimeout(async () => {
294
- await Promise.all([
295
- // TODO(wittjosiah): Factor out such that this could be called per surface role when attempting to render.
296
- manager.activate(Events.SetupReactSurface),
297
- manager.activate(Events.Startup)
298
- ]);
299
- });
300
- return () => clearTimeout(timeout);
301
- }, [
302
- manager
303
- ]);
304
- return useCallback(() => /* @__PURE__ */ React3.createElement(ErrorBoundary, {
429
+ return useCallback(() => /* @__PURE__ */ React5.createElement(ErrorBoundary, {
305
430
  fallback
306
- }, /* @__PURE__ */ React3.createElement(PluginManagerProvider, {
431
+ }, /* @__PURE__ */ React5.createElement(PluginManagerProvider, {
307
432
  value: manager
308
- }, /* @__PURE__ */ React3.createElement(RegistryContext.Provider, {
433
+ }, /* @__PURE__ */ React5.createElement(RegistryContext.Provider, {
309
434
  value: manager.registry
310
- }, /* @__PURE__ */ React3.createElement(App, {
435
+ }, /* @__PURE__ */ React5.createElement(App, {
311
436
  placeholder,
312
- state
437
+ state,
438
+ debounce
313
439
  })))), [
314
440
  fallback,
315
441
  manager,
@@ -317,100 +443,28 @@ var useApp = ({ pluginManager, pluginLoader: _pluginLoader, plugins: _plugins, c
317
443
  state
318
444
  ]);
319
445
  };
320
- var DELAY_PLACEHOLDER = 2e3;
321
- var useLoading = (state) => {
322
- const [stage, setStage] = useState(0);
323
- useEffect2(() => {
324
- const i = setInterval(() => {
325
- setStage((tick) => {
326
- switch (tick) {
327
- case 0:
328
- if (!state.ready) {
329
- return 1;
330
- } else {
331
- clearInterval(i);
332
- return 3;
333
- }
334
- case 1:
335
- if (state.ready) {
336
- return 2;
337
- }
338
- break;
339
- case 2:
340
- clearInterval(i);
341
- return 3;
342
- }
343
- return tick;
344
- });
345
- }, DELAY_PLACEHOLDER);
346
- return () => clearInterval(i);
347
- }, []);
348
- return stage;
349
- };
350
- var App = ({ placeholder: Placeholder, state }) => {
351
- var _effect = _useSignals3();
352
- try {
353
- const reactContexts = useCapabilities(Capabilities.ReactContext);
354
- const reactRoots = useCapabilities(Capabilities.ReactRoot);
355
- const stage = useLoading(state);
356
- if (state.error) {
357
- throw state.error;
358
- }
359
- if (stage < 3) {
360
- if (!Placeholder) {
361
- return null;
362
- }
363
- return /* @__PURE__ */ React3.createElement(Placeholder, {
364
- stage
365
- });
366
- }
367
- const ComposedContext = composeContexts(reactContexts);
368
- return /* @__PURE__ */ React3.createElement(ComposedContext, null, reactRoots.map(({ id, root: Component2 }) => /* @__PURE__ */ React3.createElement(Component2, {
369
- key: id
370
- })));
371
- } finally {
372
- _effect.f();
373
- }
374
- };
375
- var DefaultFallback2 = ({ error }) => {
376
- var _effect = _useSignals3();
377
- try {
378
- return /* @__PURE__ */ React3.createElement("div", {
379
- style: {
380
- margin: "1rem",
381
- padding: "1rem",
382
- overflow: "hidden",
383
- border: "4px solid teal",
384
- borderRadius: "1rem"
385
- }
386
- }, /* @__PURE__ */ React3.createElement("h1", {
387
- style: {
388
- margin: "0.5rem 0",
389
- fontSize: "1.2rem"
390
- }
391
- }, "[ERROR]: ", error.message), /* @__PURE__ */ React3.createElement("pre", {
392
- style: {
393
- overflow: "auto",
394
- fontSize: "1rem",
395
- whiteSpace: "pre-wrap",
396
- color: "#888888"
397
- }
398
- }, error.stack));
399
- } finally {
400
- _effect.f();
401
- }
402
- };
403
- var composeContexts = (contexts) => {
404
- if (contexts.length === 0) {
405
- return ({ children }) => /* @__PURE__ */ React3.createElement(React3.Fragment, null, children);
406
- }
407
- return topologicalSort(contexts).map(({ context }) => context).reduce((Acc, Next) => ({ children }) => /* @__PURE__ */ React3.createElement(Acc, null, /* @__PURE__ */ React3.createElement(Next, null, children)));
408
- };
409
446
  var setupDevtools = (manager) => {
410
447
  globalThis.composer ??= {};
411
448
  globalThis.composer.manager = manager;
412
449
  };
413
450
 
451
+ // src/react/useIntentResolver.ts
452
+ import { useEffect as useEffect3 } from "react";
453
+ var useIntentResolver = (module, resolver) => {
454
+ const manager = usePluginManager();
455
+ useEffect3(() => {
456
+ manager.context.contributeCapability({
457
+ module,
458
+ interface: Capabilities.IntentResolver,
459
+ implementation: resolver
460
+ });
461
+ return () => manager.context.removeCapability(Capabilities.IntentResolver, resolver);
462
+ }, [
463
+ module,
464
+ resolver
465
+ ]);
466
+ };
467
+
414
468
  export {
415
469
  usePluginManager,
416
470
  PluginManagerProvider,
@@ -419,11 +473,12 @@ export {
419
473
  useIntentDispatcher,
420
474
  useAppGraph,
421
475
  useLayout,
476
+ SurfaceCardRole,
422
477
  ErrorBoundary,
478
+ Surface,
423
479
  useSurfaces,
424
480
  isSurfaceAvailable,
425
- Surface,
426
- useIntentResolver,
427
- useApp
481
+ useApp,
482
+ useIntentResolver
428
483
  };
429
- //# sourceMappingURL=chunk-WU3QN5B6.mjs.map
484
+ //# sourceMappingURL=chunk-3UPX5OIS.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/types.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 2025 DXOS.org\n//\n\nimport * as Schema from 'effect/Schema';\n\nimport { type Obj } from '@dxos/echo';\n\nexport const SurfaceCardRole = Schema.Literal(\n 'card',\n 'card--popover',\n 'card--intrinsic',\n 'card--extrinsic',\n 'card--transclusion',\n);\n\nexport type SurfaceCardRole = Schema.Schema.Type<typeof SurfaceCardRole>;\n\n// TODO(burdon): Define all roles.\nexport type SurfaceRole =\n | 'item'\n | 'article'\n | 'complementary' // (for companion?)\n | 'section'\n | SurfaceCardRole;\n\n/**\n * Base type for surface components.\n */\n// TODO(burdon): Standardize PluginSettings and ObjectProperties.\n// TODO(burdon): Include attendableId?\n// TODO(burdon): companionTo?\nexport type SurfaceComponentProps<Subject extends Obj.Any = Obj.Any, Role extends string = string> = {\n role?: Role;\n\n /** The primary object being displayed. */\n subject: Subject;\n};\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-roseFill'>\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.AtomRegistry,\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.AtomRegistry, 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", "Schema", "SurfaceCardRole", "Literal", "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", "AtomRegistry", "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
+ }