@dxos/app-framework 0.8.4-main.5ad4a44 → 0.8.4-main.66e292d

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