@dxos/app-framework 0.8.4-main.67995b8 → 0.8.4-main.a4bbb77

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 (199) 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-LYF7EKNN.mjs → app-graph-builder-XH4OYQLC.mjs} +25 -25
  6. package/dist/lib/browser/app-graph-builder-XH4OYQLC.mjs.map +7 -0
  7. package/dist/lib/browser/{chunk-FMN65HSW.mjs → chunk-6V54SRFL.mjs} +388 -269
  8. package/dist/lib/browser/chunk-6V54SRFL.mjs.map +7 -0
  9. package/dist/lib/browser/{chunk-ORWHM7CO.mjs → chunk-RGKMLI6U.mjs} +10 -7
  10. package/dist/lib/browser/chunk-RGKMLI6U.mjs.map +7 -0
  11. package/dist/lib/browser/{chunk-FO2PH7M3.mjs → chunk-ZZVFNUHZ.mjs} +189 -137
  12. package/dist/lib/browser/chunk-ZZVFNUHZ.mjs.map +7 -0
  13. package/dist/lib/browser/index.mjs +20 -28
  14. package/dist/lib/browser/index.mjs.map +3 -3
  15. package/dist/lib/browser/{intent-dispatcher-LSYQZSEB.mjs → intent-dispatcher-VFMJVO2M.mjs} +2 -2
  16. package/dist/lib/browser/{intent-resolver-ZTNOSO3A.mjs → intent-resolver-ICAPD4JL.mjs} +5 -5
  17. package/dist/lib/browser/intent-resolver-ICAPD4JL.mjs.map +7 -0
  18. package/dist/lib/browser/meta.json +1 -1
  19. package/dist/lib/browser/{store-KML2R4IE.mjs → store-7ZGMHOGB.mjs} +4 -4
  20. package/dist/lib/browser/{store-KML2R4IE.mjs.map → store-7ZGMHOGB.mjs.map} +2 -2
  21. package/dist/lib/browser/testing/index.mjs +14 -19
  22. package/dist/lib/browser/testing/index.mjs.map +3 -3
  23. package/dist/lib/browser/worker.mjs +7 -9
  24. package/dist/lib/node-esm/{app-graph-builder-SAOWGJDK.mjs → app-graph-builder-C7H22SOL.mjs} +25 -25
  25. package/dist/lib/node-esm/app-graph-builder-C7H22SOL.mjs.map +7 -0
  26. package/dist/lib/node-esm/{chunk-73HGSHKE.mjs → chunk-AXSZKZFD.mjs} +189 -137
  27. package/dist/lib/node-esm/chunk-AXSZKZFD.mjs.map +7 -0
  28. package/dist/lib/node-esm/{chunk-UMZQERLE.mjs → chunk-LKPMRTRR.mjs} +10 -7
  29. package/dist/lib/node-esm/chunk-LKPMRTRR.mjs.map +7 -0
  30. package/dist/lib/node-esm/{chunk-ZEZ4FVEU.mjs → chunk-SOVTUUAY.mjs} +388 -269
  31. package/dist/lib/node-esm/chunk-SOVTUUAY.mjs.map +7 -0
  32. package/dist/lib/node-esm/index.mjs +20 -28
  33. package/dist/lib/node-esm/index.mjs.map +3 -3
  34. package/dist/lib/node-esm/{intent-dispatcher-6CYNGPSW.mjs → intent-dispatcher-SAPOKSLZ.mjs} +2 -2
  35. package/dist/lib/node-esm/{intent-resolver-W7Z7WFFM.mjs → intent-resolver-CRNJ6BMD.mjs} +5 -5
  36. package/dist/lib/node-esm/intent-resolver-CRNJ6BMD.mjs.map +7 -0
  37. package/dist/lib/node-esm/meta.json +1 -1
  38. package/dist/lib/node-esm/{store-QEXGXLWZ.mjs → store-H4F4RMYD.mjs} +4 -4
  39. package/dist/lib/node-esm/{store-QEXGXLWZ.mjs.map → store-H4F4RMYD.mjs.map} +2 -2
  40. package/dist/lib/node-esm/testing/index.mjs +14 -19
  41. package/dist/lib/node-esm/testing/index.mjs.map +3 -3
  42. package/dist/lib/node-esm/worker.mjs +7 -9
  43. package/dist/types/src/common/capabilities.d.ts +82 -8
  44. package/dist/types/src/common/capabilities.d.ts.map +1 -1
  45. package/dist/types/src/common/collaboration.d.ts +9 -8
  46. package/dist/types/src/common/collaboration.d.ts.map +1 -1
  47. package/dist/types/src/common/events.d.ts.map +1 -1
  48. package/dist/types/src/common/index.d.ts +1 -1
  49. package/dist/types/src/common/index.d.ts.map +1 -1
  50. package/dist/types/src/common/layout.d.ts +0 -2
  51. package/dist/types/src/common/layout.d.ts.map +1 -1
  52. package/dist/types/src/common/surface.d.ts +7 -13
  53. package/dist/types/src/common/surface.d.ts.map +1 -1
  54. package/dist/types/src/components/App.d.ts +10 -0
  55. package/dist/types/src/components/App.d.ts.map +1 -0
  56. package/dist/types/src/components/App.stories.d.ts +14 -0
  57. package/dist/types/src/components/App.stories.d.ts.map +1 -0
  58. package/dist/types/src/components/DefaultFallback.d.ts +8 -0
  59. package/dist/types/src/components/DefaultFallback.d.ts.map +1 -0
  60. package/dist/types/src/components/index.d.ts +2 -0
  61. package/dist/types/src/components/index.d.ts.map +1 -0
  62. package/dist/types/src/{App.d.ts → components/useApp.d.ts} +7 -6
  63. package/dist/types/src/components/useApp.d.ts.map +1 -0
  64. package/dist/types/src/components/useLoading.d.ts +19 -0
  65. package/dist/types/src/components/useLoading.d.ts.map +1 -0
  66. package/dist/types/src/core/capabilities.d.ts +4 -1
  67. package/dist/types/src/core/capabilities.d.ts.map +1 -1
  68. package/dist/types/src/core/manager.d.ts +6 -2
  69. package/dist/types/src/core/manager.d.ts.map +1 -1
  70. package/dist/types/src/core/plugin.d.ts +4 -1
  71. package/dist/types/src/core/plugin.d.ts.map +1 -1
  72. package/dist/types/src/index.d.ts +1 -1
  73. package/dist/types/src/index.d.ts.map +1 -1
  74. package/dist/types/src/playground/debug/Debug.d.ts +1 -1
  75. package/dist/types/src/playground/debug/plugin.d.ts +1 -1
  76. package/dist/types/src/playground/debug/plugin.d.ts.map +1 -1
  77. package/dist/types/src/playground/generator/Main.d.ts +1 -1
  78. package/dist/types/src/playground/generator/Toolbar.d.ts +1 -1
  79. package/dist/types/src/playground/generator/Toolbar.d.ts.map +1 -1
  80. package/dist/types/src/playground/generator/generator.d.ts +1 -1
  81. package/dist/types/src/playground/generator/generator.d.ts.map +1 -1
  82. package/dist/types/src/playground/generator/plugin.d.ts +1 -1
  83. package/dist/types/src/playground/generator/plugin.d.ts.map +1 -1
  84. package/dist/types/src/playground/layout/Layout.d.ts +2 -2
  85. package/dist/types/src/playground/layout/plugin.d.ts +1 -1
  86. package/dist/types/src/playground/layout/plugin.d.ts.map +1 -1
  87. package/dist/types/src/playground/logger/Toolbar.d.ts +1 -1
  88. package/dist/types/src/playground/logger/Toolbar.d.ts.map +1 -1
  89. package/dist/types/src/playground/logger/plugin.d.ts +1 -1
  90. package/dist/types/src/playground/logger/plugin.d.ts.map +1 -1
  91. package/dist/types/src/playground/playground.stories.d.ts +5 -4
  92. package/dist/types/src/playground/playground.stories.d.ts.map +1 -1
  93. package/dist/types/src/plugin-intent/IntentPlugin.d.ts +1 -1
  94. package/dist/types/src/plugin-intent/IntentPlugin.d.ts.map +1 -1
  95. package/dist/types/src/plugin-intent/actions.d.ts +4 -6
  96. package/dist/types/src/plugin-intent/actions.d.ts.map +1 -1
  97. package/dist/types/src/plugin-intent/errors.d.ts.map +1 -1
  98. package/dist/types/src/plugin-intent/index.d.ts +1 -0
  99. package/dist/types/src/plugin-intent/index.d.ts.map +1 -1
  100. package/dist/types/src/plugin-intent/intent-dispatcher.d.ts +3 -3
  101. package/dist/types/src/plugin-intent/intent-dispatcher.d.ts.map +1 -1
  102. package/dist/types/src/plugin-intent/meta.d.ts +3 -0
  103. package/dist/types/src/plugin-intent/meta.d.ts.map +1 -0
  104. package/dist/types/src/plugin-settings/SettingsPlugin.d.ts +1 -1
  105. package/dist/types/src/plugin-settings/SettingsPlugin.d.ts.map +1 -1
  106. package/dist/types/src/plugin-settings/actions.d.ts +4 -6
  107. package/dist/types/src/plugin-settings/actions.d.ts.map +1 -1
  108. package/dist/types/src/plugin-settings/app-graph-builder.d.ts +1 -1
  109. package/dist/types/src/plugin-settings/app-graph-builder.d.ts.map +1 -1
  110. package/dist/types/src/plugin-settings/intent-resolver.d.ts +1 -1
  111. package/dist/types/src/plugin-settings/intent-resolver.d.ts.map +1 -1
  112. package/dist/types/src/plugin-settings/meta.d.ts +3 -0
  113. package/dist/types/src/plugin-settings/meta.d.ts.map +1 -0
  114. package/dist/types/src/plugin-settings/store.d.ts +1 -1
  115. package/dist/types/src/plugin-settings/store.d.ts.map +1 -1
  116. package/dist/types/src/plugin-settings/translations.d.ts +2 -1
  117. package/dist/types/src/plugin-settings/translations.d.ts.map +1 -1
  118. package/dist/types/src/react/ErrorBoundary.d.ts +13 -14
  119. package/dist/types/src/react/ErrorBoundary.d.ts.map +1 -1
  120. package/dist/types/src/react/IntentContext.d.ts.map +1 -1
  121. package/dist/types/src/react/Surface.d.ts +2 -2
  122. package/dist/types/src/react/Surface.d.ts.map +1 -1
  123. package/dist/types/src/react/Surface.stories.d.ts +6 -5
  124. package/dist/types/src/react/Surface.stories.d.ts.map +1 -1
  125. package/dist/types/src/react/common.d.ts.map +1 -1
  126. package/dist/types/src/react/useCapabilities.d.ts.map +1 -1
  127. package/dist/types/src/testing/withPluginManager.d.ts +6 -6
  128. package/dist/types/src/testing/withPluginManager.d.ts.map +1 -1
  129. package/dist/types/src/testing/withPluginManager.stories.d.ts +9 -3
  130. package/dist/types/src/testing/withPluginManager.stories.d.ts.map +1 -1
  131. package/dist/types/tsconfig.tsbuildinfo +1 -1
  132. package/moon.yml +4 -0
  133. package/package.json +37 -35
  134. package/src/common/capabilities.ts +106 -10
  135. package/src/common/collaboration.ts +5 -8
  136. package/src/common/events.ts +3 -1
  137. package/src/common/index.ts +1 -1
  138. package/src/common/layout.ts +2 -3
  139. package/src/common/surface.ts +15 -18
  140. package/src/components/App.stories.tsx +33 -0
  141. package/src/components/App.tsx +59 -0
  142. package/src/components/DefaultFallback.tsx +26 -0
  143. package/src/components/index.ts +5 -0
  144. package/src/{App.tsx → components/useApp.tsx} +24 -136
  145. package/src/components/useLoading.tsx +70 -0
  146. package/src/core/capabilities.test.ts +1 -1
  147. package/src/core/capabilities.ts +11 -6
  148. package/src/core/manager.test.ts +21 -20
  149. package/src/core/manager.ts +132 -54
  150. package/src/core/plugin.ts +8 -2
  151. package/src/helpers.test.ts +1 -1
  152. package/src/index.ts +1 -1
  153. package/src/playground/debug/Debug.tsx +1 -1
  154. package/src/playground/debug/plugin.ts +7 -8
  155. package/src/playground/generator/Toolbar.tsx +2 -1
  156. package/src/playground/generator/generator.ts +3 -3
  157. package/src/playground/generator/plugin.ts +12 -13
  158. package/src/playground/layout/plugin.ts +10 -9
  159. package/src/playground/logger/Toolbar.tsx +2 -1
  160. package/src/playground/logger/plugin.ts +30 -25
  161. package/src/playground/playground.stories.tsx +20 -16
  162. package/src/plugin-intent/IntentPlugin.ts +13 -13
  163. package/src/plugin-intent/actions.ts +3 -5
  164. package/src/plugin-intent/errors.ts +1 -0
  165. package/src/plugin-intent/index.ts +1 -0
  166. package/src/plugin-intent/intent-dispatcher.test.ts +1 -1
  167. package/src/plugin-intent/intent-dispatcher.ts +9 -8
  168. package/src/plugin-intent/meta.ts +10 -0
  169. package/src/plugin-settings/SettingsPlugin.ts +27 -28
  170. package/src/plugin-settings/actions.ts +8 -12
  171. package/src/plugin-settings/app-graph-builder.ts +14 -12
  172. package/src/plugin-settings/intent-resolver.ts +3 -2
  173. package/src/plugin-settings/meta.ts +10 -0
  174. package/src/plugin-settings/store.ts +1 -1
  175. package/src/plugin-settings/translations.ts +3 -3
  176. package/src/react/ErrorBoundary.tsx +24 -15
  177. package/src/react/IntentContext.tsx +3 -2
  178. package/src/react/Surface.stories.tsx +23 -18
  179. package/src/react/Surface.tsx +14 -5
  180. package/src/react/common.ts +2 -1
  181. package/src/react/useCapabilities.ts +2 -1
  182. package/src/testing/withPluginManager.stories.tsx +9 -5
  183. package/src/testing/withPluginManager.tsx +25 -29
  184. package/tsconfig.json +1 -8
  185. package/vitest.config.ts +8 -6
  186. package/.swc/plugins/v7_linux_x86_64_13.0.0/f45bdff002284d9e8f9ef3f0be909de12da36c049cbcf261ac78fc00abb09a2d +0 -0
  187. package/dist/lib/browser/app-graph-builder-LYF7EKNN.mjs.map +0 -7
  188. package/dist/lib/browser/chunk-FMN65HSW.mjs.map +0 -7
  189. package/dist/lib/browser/chunk-FO2PH7M3.mjs.map +0 -7
  190. package/dist/lib/browser/chunk-ORWHM7CO.mjs.map +0 -7
  191. package/dist/lib/browser/intent-resolver-ZTNOSO3A.mjs.map +0 -7
  192. package/dist/lib/node-esm/app-graph-builder-SAOWGJDK.mjs.map +0 -7
  193. package/dist/lib/node-esm/chunk-73HGSHKE.mjs.map +0 -7
  194. package/dist/lib/node-esm/chunk-UMZQERLE.mjs.map +0 -7
  195. package/dist/lib/node-esm/chunk-ZEZ4FVEU.mjs.map +0 -7
  196. package/dist/lib/node-esm/intent-resolver-W7Z7WFFM.mjs.map +0 -7
  197. package/dist/types/src/App.d.ts.map +0 -1
  198. /package/dist/lib/browser/{intent-dispatcher-LSYQZSEB.mjs.map → intent-dispatcher-VFMJVO2M.mjs.map} +0 -0
  199. /package/dist/lib/node-esm/{intent-dispatcher-6CYNGPSW.mjs.map → intent-dispatcher-SAPOKSLZ.mjs.map} +0 -0
@@ -2,26 +2,26 @@ import { createRequire } from 'node:module';const require = createRequire(import
2
2
  import {
3
3
  SETTINGS_ID,
4
4
  SETTINGS_KEY,
5
- SETTINGS_PLUGIN,
6
- SettingsAction
7
- } from "./chunk-UMZQERLE.mjs";
5
+ SettingsAction,
6
+ meta
7
+ } from "./chunk-LKPMRTRR.mjs";
8
8
  import {
9
9
  Capabilities,
10
10
  contributes,
11
11
  createIntent
12
- } from "./chunk-ZEZ4FVEU.mjs";
12
+ } from "./chunk-SOVTUUAY.mjs";
13
13
 
14
14
  // src/plugin-settings/app-graph-builder.ts
15
15
  import { Rx } from "@effect-rx/rx-react";
16
16
  import { Option, pipe } from "effect";
17
- import { createExtension, ROOT_ID } from "@dxos/app-graph";
17
+ import { ROOT_ID, createExtension } from "@dxos/app-graph";
18
18
  import { isNonNullable } from "@dxos/util";
19
- var app_graph_builder_default = (context) => contributes(Capabilities.AppGraphBuilder, [
19
+ var app_graph_builder_default = ((context) => contributes(Capabilities.AppGraphBuilder, [
20
20
  createExtension({
21
- id: `${SETTINGS_PLUGIN}/action`,
21
+ id: `${meta.id}/action`,
22
22
  actions: (node) => Rx.make((get) => pipe(get(node), Option.flatMap((node2) => node2.id === ROOT_ID ? Option.some(node2) : Option.none()), Option.map(() => [
23
23
  {
24
- id: SETTINGS_PLUGIN,
24
+ id: meta.id,
25
25
  data: async () => {
26
26
  const { dispatchPromise: dispatch } = context.getCapability(Capabilities.IntentDispatcher);
27
27
  await dispatch(createIntent(SettingsAction.Open));
@@ -30,7 +30,7 @@ var app_graph_builder_default = (context) => contributes(Capabilities.AppGraphBu
30
30
  label: [
31
31
  "open settings label",
32
32
  {
33
- ns: SETTINGS_PLUGIN
33
+ ns: meta.id
34
34
  }
35
35
  ],
36
36
  icon: "ph--gear--regular",
@@ -44,16 +44,16 @@ var app_graph_builder_default = (context) => contributes(Capabilities.AppGraphBu
44
44
  ]), Option.getOrElse(() => [])))
45
45
  }),
46
46
  createExtension({
47
- id: `${SETTINGS_PLUGIN}/core`,
47
+ id: `${meta.id}/core`,
48
48
  connector: (node) => Rx.make((get) => 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
- type: SETTINGS_PLUGIN,
51
+ type: meta.id,
52
52
  properties: {
53
53
  label: [
54
54
  "app settings label",
55
55
  {
56
- ns: SETTINGS_PLUGIN
56
+ ns: meta.id
57
57
  }
58
58
  ],
59
59
  icon: "ph--gear--regular",
@@ -65,7 +65,7 @@ var app_graph_builder_default = (context) => contributes(Capabilities.AppGraphBu
65
65
  ]), Option.getOrElse(() => [])))
66
66
  }),
67
67
  createExtension({
68
- id: `${SETTINGS_PLUGIN}/core-plugins`,
68
+ id: `${meta.id}/core-plugins`,
69
69
  connector: (node) => Rx.make((get) => 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));
@@ -79,13 +79,13 @@ var app_graph_builder_default = (context) => contributes(Capabilities.AppGraphBu
79
79
  plugin.meta,
80
80
  settings
81
81
  ];
82
- }).filter(isNonNullable).map(([meta, settings]) => ({
83
- id: `${SETTINGS_KEY}:${meta.id.replaceAll("/", ":")}`,
82
+ }).filter(isNonNullable).map(([meta2, settings]) => ({
83
+ id: `${SETTINGS_KEY}:${meta2.id.replaceAll("/", ":")}`,
84
84
  type: "category",
85
85
  data: settings,
86
86
  properties: {
87
- label: meta.name ?? meta.id,
88
- icon: meta.icon ?? "ph--circle--regular"
87
+ label: meta2.name ?? meta2.id,
88
+ icon: meta2.icon ?? "ph--circle--regular"
89
89
  }
90
90
  })),
91
91
  {
@@ -95,7 +95,7 @@ var app_graph_builder_default = (context) => contributes(Capabilities.AppGraphBu
95
95
  label: [
96
96
  "custom plugins label",
97
97
  {
98
- ns: SETTINGS_PLUGIN
98
+ ns: meta.id
99
99
  }
100
100
  ],
101
101
  icon: "ph--squares-four--regular",
@@ -107,7 +107,7 @@ var app_graph_builder_default = (context) => contributes(Capabilities.AppGraphBu
107
107
  }), Option.getOrElse(() => [])))
108
108
  }),
109
109
  createExtension({
110
- id: `${SETTINGS_PLUGIN}/custom-plugins`,
110
+ id: `${meta.id}/custom-plugins`,
111
111
  connector: (node) => Rx.make((get) => 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));
@@ -120,19 +120,19 @@ var app_graph_builder_default = (context) => contributes(Capabilities.AppGraphBu
120
120
  plugin.meta,
121
121
  settings
122
122
  ];
123
- }).filter(isNonNullable).map(([meta, settings]) => ({
124
- id: `${SETTINGS_KEY}:${meta.id.replaceAll("/", ":")}`,
123
+ }).filter(isNonNullable).map(([meta2, settings]) => ({
124
+ id: `${SETTINGS_KEY}:${meta2.id.replaceAll("/", ":")}`,
125
125
  type: "category",
126
126
  data: settings,
127
127
  properties: {
128
- label: meta.name ?? meta.id,
129
- icon: meta.icon ?? "ph--circle--regular"
128
+ label: meta2.name ?? meta2.id,
129
+ icon: meta2.icon ?? "ph--circle--regular"
130
130
  }
131
131
  }));
132
132
  }), Option.getOrElse(() => [])))
133
133
  })
134
- ]);
134
+ ]));
135
135
  export {
136
136
  app_graph_builder_default as default
137
137
  };
138
- //# sourceMappingURL=app-graph-builder-SAOWGJDK.mjs.map
138
+ //# sourceMappingURL=app-graph-builder-C7H22SOL.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 { Rx } from '@effect-rx/rx-react';\nimport { Option, pipe } from 'effect';\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 Rx.make((get) =>\n 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 Rx.make((get) =>\n 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 Rx.make((get) =>\n 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 Rx.make((get) =>\n 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": ";;;;;;;;;;;;;;AAIA,SAASA,UAAU;AACnB,SAASC,QAAQC,YAAY;AAE7B,SAASC,SAASC,uBAAuB;AAEzC,SAASC,qBAAqB;AAS9B,IAAA,6BAAe,CAACC,YACdC,YAAYC,aAAaC,iBAAiB;EACxCC,gBAAgB;IACdC,IAAI,GAAGC,KAAKD,EAAE;IACdE,SAAS,CAACC,SACRC,GAAGC,KAAK,CAACC,QACPC,KACED,IAAIH,IAAAA,GACJK,OAAOC,QAAQ,CAACN,UAAUA,MAAKH,OAAOU,UAAUF,OAAOG,KAAKR,KAAAA,IAAQK,OAAOI,KAAI,CAAA,GAC/EJ,OAAOK,IAAI,MAAM;MACf;QACEb,IAAIC,KAAKD;QACTc,MAAM,YAAA;AACJ,gBAAM,EAAEC,iBAAiBC,SAAQ,IAAKrB,QAAQsB,cAAcpB,aAAaqB,gBAAgB;AACzF,gBAAMF,SAASG,aAAaC,eAAeC,IAAI,CAAA;QACjD;QACAC,YAAY;UACVC,OAAO;YAAC;YAAuB;cAAEC,IAAIvB,KAAKD;YAAG;;UAC7CyB,MAAM;UACNC,aAAa;UACbC,YAAY;YACVC,OAAO;YACPC,SAAS;UACX;QACF;MACF;KACD,GACDrB,OAAOsB,UAAU,MAAM,CAAA,CAAE,CAAA,CAAA;EAGjC,CAAA;EACA/B,gBAAgB;IACdC,IAAI,GAAGC,KAAKD,EAAE;IACd+B,WAAW,CAAC5B,SACVC,GAAGC,KAAK,CAACC,QACPC,KACED,IAAIH,IAAAA,GACJK,OAAOC,QAAQ,CAACN,UAAUA,MAAKH,OAAOU,UAAUF,OAAOG,KAAKR,KAAAA,IAAQK,OAAOI,KAAI,CAAA,GAC/EJ,OAAOK,IAAI,MAAM;MACf;QACEb,IAAIgC;QACJC,MAAMhC,KAAKD;QACXsB,YAAY;UACVC,OAAO;YAAC;YAAsB;cAAEC,IAAIvB,KAAKD;YAAG;;UAC5CyB,MAAM;UACNC,aAAa;UACbQ,UAAU;UACVC,QAAQ;QACV;MACF;KACD,GACD3B,OAAOsB,UAAU,MAAM,CAAA,CAAE,CAAA,CAAA;EAGjC,CAAA;EACA/B,gBAAgB;IACdC,IAAI,GAAGC,KAAKD,EAAE;IACd+B,WAAW,CAAC5B,SACVC,GAAGC,KAAK,CAACC,QACPC,KACED,IAAIH,IAAAA,GACJK,OAAOC,QAAQ,CAACN,UAAUA,MAAKH,OAAOgC,cAAcxB,OAAOI,KAAI,IAAKJ,OAAOG,KAAKR,KAAAA,CAAAA,GAChFK,OAAOK,IAAI,MAAA;AACT,YAAMuB,UAAU9B,IAAIX,QAAQ0C,WAAWxC,aAAayC,aAAa,CAAA;AACjE,YAAM,CAACC,aAAAA,IAAiBjC,IAAIX,QAAQ6C,aAAa3C,aAAa4C,aAAa,CAAA;AAC3E,aAAO;WACFL,QAAQM,QACRC,OAAO,CAACC,WAAWR,QAAQS,KAAKC,SAASF,OAAO3C,KAAKD,EAAE,CAAA,EACvDa,IAAI,CAAC+B,WAAAA;AACJ,gBAAMG,WAAWR,eAAeS,SAASJ,OAAO3C,KAAKD,EAAE;AACvD,cAAI,CAAC+C,UAAU;AACb,mBAAO;UACT;AAEA,iBAAO;YAACH,OAAO3C;YAAM8C;;QACvB,CAAA,EACCJ,OAAOM,aAAAA,EACPpC,IAAI,CAAC,CAACZ,OAAM8C,QAAAA,OAAe;UAC1B/C,IAAI,GAAGkD,YAAAA,IAAgBjD,MAAKD,GAAGmD,WAAW,KAAK,GAAA,CAAA;UAC/ClB,MAAM;UACNnB,MAAMiC;UACNzB,YAAY;YACVC,OAAOtB,MAAKmD,QAAQnD,MAAKD;YACzByB,MAAMxB,MAAKwB,QAAQ;UACrB;QACF,EAAA;QAEF;UACEzB,IAAI,GAAGkD,YAAAA;UACPjB,MAAM;UACNX,YAAY;YACVC,OAAO;cAAC;cAAwB;gBAAEC,IAAIvB,KAAKD;cAAG;;YAC9CyB,MAAM;YACN4B,MAAM;YACN3B,aAAa;UACf;QACF;;IAEJ,CAAA,GACAlB,OAAOsB,UAAU,MAAM,CAAA,CAAE,CAAA,CAAA;EAGjC,CAAA;EACA/B,gBAAgB;IACdC,IAAI,GAAGC,KAAKD,EAAE;IACd+B,WAAW,CAAC5B,SACVC,GAAGC,KAAK,CAACC,QACPC,KACED,IAAIH,IAAAA,GACJK,OAAOC,QAAQ,CAACN,UACdA,MAAKH,OAAO,GAAGkD,YAAAA,oBAAgC1C,OAAOI,KAAI,IAAKJ,OAAOG,KAAKR,KAAAA,CAAAA,GAE7EK,OAAOK,IAAI,MAAA;AACT,YAAMuB,UAAU9B,IAAIX,QAAQ0C,WAAWxC,aAAayC,aAAa,CAAA;AACjE,YAAM,CAACC,aAAAA,IAAiBjC,IAAIX,QAAQ6C,aAAa3C,aAAa4C,aAAa,CAAA;AAC3E,aAAOL,QAAQM,QACZC,OAAO,CAACC,WAAW,CAACR,QAAQS,KAAKC,SAASF,OAAO3C,KAAKD,EAAE,CAAA,EACxDa,IAAI,CAAC+B,WAAAA;AACJ,cAAMG,WAAWR,eAAeS,SAASJ,OAAO3C,KAAKD,EAAE;AACvD,YAAI,CAAC+C,UAAU;AACb,iBAAO;QACT;AAEA,eAAO;UAACH,OAAO3C;UAAM8C;;MACvB,CAAA,EACCJ,OAAOM,aAAAA,EACPpC,IAAI,CAAC,CAACZ,OAAM8C,QAAAA,OAAe;QAC1B/C,IAAI,GAAGkD,YAAAA,IAAgBjD,MAAKD,GAAGmD,WAAW,KAAK,GAAA,CAAA;QAC/ClB,MAAM;QACNnB,MAAMiC;QACNzB,YAAY;UACVC,OAAOtB,MAAKmD,QAAQnD,MAAKD;UACzByB,MAAMxB,MAAKwB,QAAQ;QACrB;MACF,EAAA;IACJ,CAAA,GACAjB,OAAOsB,UAAU,MAAM,CAAA,CAAE,CAAA,CAAA;EAGjC,CAAA;CACD;",
6
+ "names": ["Rx", "Option", "pipe", "ROOT_ID", "createExtension", "isNonNullable", "context", "contributes", "Capabilities", "AppGraphBuilder", "createExtension", "id", "meta", "actions", "node", "Rx", "make", "get", "pipe", "Option", "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
+ }
@@ -3,7 +3,7 @@ import {
3
3
  Capabilities,
4
4
  Events,
5
5
  PluginManager
6
- } from "./chunk-ZEZ4FVEU.mjs";
6
+ } from "./chunk-SOVTUUAY.mjs";
7
7
 
8
8
  // src/react/PluginManagerProvider.ts
9
9
  import { createContext, useContext } from "react";
@@ -24,7 +24,7 @@ var useCapability = (interfaceDef) => {
24
24
  const capabilities = useCapabilities(interfaceDef);
25
25
  invariant(capabilities.length > 0, `No capability found for ${interfaceDef.identifier}`, {
26
26
  F: __dxlog_file,
27
- L: 28,
27
+ L: 29,
28
28
  S: void 0,
29
29
  A: [
30
30
  "capabilities.length > 0",
@@ -40,14 +40,22 @@ var useAppGraph = () => useCapability(Capabilities.AppGraph);
40
40
  var useLayout = () => useCapability(Capabilities.Layout);
41
41
 
42
42
  // src/react/ErrorBoundary.tsx
43
+ import { useSignals as _useSignals } from "@preact-signals/safe-react/tracking";
43
44
  import React, { Component } from "react";
44
- var ErrorBoundary = class extends Component {
45
- constructor(props) {
46
- super(props);
47
- this.state = {
48
- error: void 0
49
- };
45
+ function _define_property(obj, key, value) {
46
+ if (key in obj) {
47
+ Object.defineProperty(obj, key, {
48
+ value,
49
+ enumerable: true,
50
+ configurable: true,
51
+ writable: true
52
+ });
53
+ } else {
54
+ obj[key] = value;
50
55
  }
56
+ return obj;
57
+ }
58
+ var ErrorBoundary = class extends Component {
51
59
  static getDerivedStateFromError(error) {
52
60
  return {
53
61
  error
@@ -60,10 +68,10 @@ var ErrorBoundary = class extends Component {
60
68
  }
61
69
  render() {
62
70
  if (this.state.error) {
63
- return /* @__PURE__ */ React.createElement(this.props.fallback, {
71
+ const Fallback = this.props.fallback ?? DefaultFallback;
72
+ return /* @__PURE__ */ React.createElement(Fallback, {
64
73
  data: this.props.data,
65
- error: this.state.error,
66
- reset: this.resetError
74
+ error: this.state.error
67
75
  });
68
76
  }
69
77
  return this.props.children;
@@ -73,11 +81,30 @@ var ErrorBoundary = class extends Component {
73
81
  error: void 0
74
82
  });
75
83
  }
84
+ constructor(...args) {
85
+ super(...args), _define_property(this, "state", {
86
+ error: void 0
87
+ });
88
+ }
89
+ };
90
+ var DefaultFallback = ({ data, error }) => {
91
+ var _effect = _useSignals();
92
+ try {
93
+ return /* @__PURE__ */ React.createElement("div", {
94
+ className: "flex flex-col gap-2 overflow-hidden border border-red-500 rounded-sm"
95
+ }, /* @__PURE__ */ React.createElement("pre", {
96
+ className: "whitespace-pre-wrap font-sm text-xs p-2"
97
+ }, "ERROR: ", error.message), /* @__PURE__ */ React.createElement("pre", {
98
+ className: "whitespace-pre-wrap font-sm text-xs p-2 text-subdued"
99
+ }, JSON.stringify(data, null, 2)));
100
+ } finally {
101
+ _effect.f();
102
+ }
76
103
  };
77
104
 
78
105
  // src/react/Surface.tsx
79
- import { useSignals as _useSignals } from "@preact-signals/safe-react/tracking";
80
- import React2, { memo, forwardRef, Suspense, useMemo, Fragment } from "react";
106
+ import { useSignals as _useSignals2 } from "@preact-signals/safe-react/tracking";
107
+ import React2, { Fragment, Suspense, forwardRef, memo, useMemo } from "react";
81
108
  import { useDefaultValue } from "@dxos/react-hooks";
82
109
  import { byPosition } from "@dxos/util";
83
110
  var DEFAULT_PLACEHOLDER = /* @__PURE__ */ React2.createElement(Fragment, null);
@@ -99,7 +126,7 @@ var isSurfaceAvailable = (context, { role, data }) => {
99
126
  return candidates.length > 0;
100
127
  };
101
128
  var Surface = /* @__PURE__ */ memo(/* @__PURE__ */ forwardRef(({ id: _id, role, data: _data, limit, fallback, placeholder = DEFAULT_PLACEHOLDER, ...rest }, forwardedRef) => {
102
- var _effect = _useSignals();
129
+ var _effect = _useSignals2();
103
130
  try {
104
131
  const surfaces = useSurfaces();
105
132
  const data = useDefaultValue(_data, () => ({}));
@@ -147,14 +174,17 @@ var useIntentResolver = (module, resolver) => {
147
174
  ]);
148
175
  };
149
176
 
150
- // src/App.tsx
151
- import { useSignals as _useSignals2 } from "@preact-signals/safe-react/tracking";
177
+ // src/components/useApp.tsx
152
178
  import { RegistryContext } from "@effect-rx/rx-react";
153
179
  import { effect } from "@preact/signals-core";
154
- import React3, { useCallback, useEffect as useEffect2, useMemo as useMemo2, useState } from "react";
180
+ import React5, { useCallback, useEffect as useEffect3, useMemo as useMemo2 } from "react";
155
181
  import { invariant as invariant2 } from "@dxos/invariant";
156
182
  import { live } from "@dxos/live-object";
157
- import { useDefaultValue as useDefaultValue2 } from "@dxos/react-hooks";
183
+ import { useAsyncEffect, useDefaultValue as useDefaultValue2 } from "@dxos/react-hooks";
184
+
185
+ // src/components/App.tsx
186
+ import { useSignals as _useSignals3 } from "@preact-signals/safe-react/tracking";
187
+ import React3 from "react";
158
188
 
159
189
  // src/helpers.ts
160
190
  var topologicalSort = (nodes) => {
@@ -187,10 +217,125 @@ var topologicalSort = (nodes) => {
187
217
  return allDependencies.map((id) => nodes.find((node) => node.id === id)).filter((node) => node !== void 0);
188
218
  };
189
219
 
190
- // src/App.tsx
191
- var __dxlog_file2 = "/__w/dxos/dxos/packages/sdk/app-framework/src/App.tsx";
220
+ // src/components/useLoading.tsx
221
+ import { useEffect as useEffect2, useState } from "react";
222
+ var LoadingState = /* @__PURE__ */ (function(LoadingState2) {
223
+ LoadingState2[LoadingState2["Loading"] = 0] = "Loading";
224
+ LoadingState2[LoadingState2["FadeIn"] = 1] = "FadeIn";
225
+ LoadingState2[LoadingState2["FadeOut"] = 2] = "FadeOut";
226
+ LoadingState2[LoadingState2["Done"] = 3] = "Done";
227
+ return LoadingState2;
228
+ })({});
229
+ var useLoading = (state, debounce = 0) => {
230
+ const [stage, setStage] = useState(0);
231
+ useEffect2(() => {
232
+ if (!debounce) {
233
+ return;
234
+ }
235
+ const i = setInterval(() => {
236
+ setStage((stage2) => {
237
+ switch (stage2) {
238
+ case 0: {
239
+ if (!state.ready) {
240
+ return 1;
241
+ } else {
242
+ clearInterval(i);
243
+ return 3;
244
+ }
245
+ }
246
+ case 1: {
247
+ if (state.ready) {
248
+ return 2;
249
+ }
250
+ break;
251
+ }
252
+ case 2: {
253
+ clearInterval(i);
254
+ return 3;
255
+ }
256
+ }
257
+ return stage2;
258
+ });
259
+ }, debounce);
260
+ return () => clearInterval(i);
261
+ }, [
262
+ debounce
263
+ ]);
264
+ if (!debounce) {
265
+ return state.ready ? 3 : 0;
266
+ }
267
+ return stage;
268
+ };
269
+
270
+ // src/components/App.tsx
271
+ var App = ({ placeholder: Placeholder, state, debounce }) => {
272
+ var _effect = _useSignals3();
273
+ try {
274
+ const reactContexts = useCapabilities(Capabilities.ReactContext);
275
+ const reactRoots = useCapabilities(Capabilities.ReactRoot);
276
+ const stage = useLoading(state, debounce);
277
+ if (state.error) {
278
+ throw state.error;
279
+ }
280
+ if (stage < LoadingState.Done) {
281
+ if (!Placeholder) {
282
+ return null;
283
+ }
284
+ return /* @__PURE__ */ React3.createElement(Placeholder, {
285
+ stage
286
+ });
287
+ }
288
+ const ComposedContext = composeContexts(reactContexts);
289
+ return /* @__PURE__ */ React3.createElement(ComposedContext, null, reactRoots.map(({ id, root: Component2 }) => /* @__PURE__ */ React3.createElement(Component2, {
290
+ key: id
291
+ })));
292
+ } finally {
293
+ _effect.f();
294
+ }
295
+ };
296
+ var composeContexts = (contexts) => {
297
+ if (contexts.length === 0) {
298
+ return ({ children }) => /* @__PURE__ */ React3.createElement(React3.Fragment, null, children);
299
+ }
300
+ return topologicalSort(contexts).map(({ context }) => context).reduce((Acc, Next) => ({ children }) => /* @__PURE__ */ React3.createElement(Acc, null, /* @__PURE__ */ React3.createElement(Next, null, children)));
301
+ };
302
+
303
+ // src/components/DefaultFallback.tsx
304
+ import { useSignals as _useSignals4 } from "@preact-signals/safe-react/tracking";
305
+ import React4 from "react";
306
+ var DefaultFallback2 = ({ error }) => {
307
+ var _effect = _useSignals4();
308
+ try {
309
+ return /* @__PURE__ */ React4.createElement("div", {
310
+ style: {
311
+ margin: "1rem",
312
+ padding: "1rem",
313
+ overflow: "hidden",
314
+ border: "4px solid teal",
315
+ borderRadius: "1rem"
316
+ }
317
+ }, /* @__PURE__ */ React4.createElement("h1", {
318
+ style: {
319
+ margin: "0.5rem 0",
320
+ fontSize: "1.2rem"
321
+ }
322
+ }, "[ERROR]: ", error.message), /* @__PURE__ */ React4.createElement("pre", {
323
+ style: {
324
+ overflow: "auto",
325
+ fontSize: "1rem",
326
+ whiteSpace: "pre-wrap",
327
+ color: "#888888"
328
+ }
329
+ }, error.stack));
330
+ } finally {
331
+ _effect.f();
332
+ }
333
+ };
334
+
335
+ // src/components/useApp.tsx
336
+ var __dxlog_file2 = "/__w/dxos/dxos/packages/sdk/app-framework/src/components/useApp.tsx";
192
337
  var ENABLED_KEY = "dxos.org/app-framework/enabled";
193
- var useApp = ({ pluginManager, pluginLoader: _pluginLoader, plugins: _plugins, core: _core, defaults: _defaults, placeholder, fallback = DefaultFallback, cacheEnabled = false, safeMode = false }) => {
338
+ var useApp = ({ pluginManager, pluginLoader: _pluginLoader, plugins: _plugins, core: _core, defaults: _defaults, placeholder, fallback = DefaultFallback2, cacheEnabled = false, safeMode = false, debounce = 0 }) => {
194
339
  const plugins = useDefaultValue2(_plugins, () => []);
195
340
  const core = useDefaultValue2(_core, () => plugins.map(({ meta }) => meta.id));
196
341
  const defaults = useDefaultValue2(_defaults, () => []);
@@ -198,7 +343,7 @@ var useApp = ({ pluginManager, pluginLoader: _pluginLoader, plugins: _plugins, c
198
343
  const plugin = plugins.find((plugin2) => plugin2.meta.id === id);
199
344
  invariant2(plugin, `Plugin not found: ${id}`, {
200
345
  F: __dxlog_file2,
201
- L: 78,
346
+ L: 82,
202
347
  S: void 0,
203
348
  A: [
204
349
  "plugin",
@@ -233,7 +378,7 @@ var useApp = ({ pluginManager, pluginLoader: _pluginLoader, plugins: _plugins, c
233
378
  core,
234
379
  enabled
235
380
  ]);
236
- useEffect2(() => {
381
+ useEffect3(() => {
237
382
  return manager.activation.on(({ event, state: _state, error }) => {
238
383
  if (!state.ready && event === Events.Startup.id) {
239
384
  state.ready = _state === "activated";
@@ -246,7 +391,7 @@ var useApp = ({ pluginManager, pluginLoader: _pluginLoader, plugins: _plugins, c
246
391
  manager,
247
392
  state
248
393
  ]);
249
- useEffect2(() => {
394
+ useEffect3(() => {
250
395
  effect(() => {
251
396
  cacheEnabled && localStorage.setItem(ENABLED_KEY, JSON.stringify(manager.enabled));
252
397
  });
@@ -254,7 +399,12 @@ var useApp = ({ pluginManager, pluginLoader: _pluginLoader, plugins: _plugins, c
254
399
  cacheEnabled,
255
400
  manager
256
401
  ]);
257
- useEffect2(() => {
402
+ useEffect3(() => {
403
+ setupDevtools(manager);
404
+ }, [
405
+ manager
406
+ ]);
407
+ useAsyncEffect(async () => {
258
408
  manager.context.contributeCapability({
259
409
  interface: Capabilities.PluginManager,
260
410
  implementation: manager,
@@ -265,6 +415,11 @@ var useApp = ({ pluginManager, pluginLoader: _pluginLoader, plugins: _plugins, c
265
415
  implementation: manager.registry,
266
416
  module: "dxos.org/app-framework/rx-registry"
267
417
  });
418
+ await Promise.all([
419
+ // TODO(wittjosiah): Factor out such that this could be called per surface role when attempting to render.
420
+ manager.activate(Events.SetupReactSurface),
421
+ manager.activate(Events.Startup)
422
+ ]);
268
423
  return () => {
269
424
  manager.context.removeCapability(Capabilities.PluginManager, manager);
270
425
  manager.context.removeCapability(Capabilities.RxRegistry, manager.registry);
@@ -272,32 +427,16 @@ var useApp = ({ pluginManager, pluginLoader: _pluginLoader, plugins: _plugins, c
272
427
  }, [
273
428
  manager
274
429
  ]);
275
- useEffect2(() => {
276
- setupDevtools(manager);
277
- }, [
278
- manager
279
- ]);
280
- useEffect2(() => {
281
- const timeout = setTimeout(async () => {
282
- await Promise.all([
283
- // TODO(wittjosiah): Factor out such that this could be called per surface role when attempting to render.
284
- manager.activate(Events.SetupReactSurface),
285
- manager.activate(Events.Startup)
286
- ]);
287
- });
288
- return () => clearTimeout(timeout);
289
- }, [
290
- manager
291
- ]);
292
- return useCallback(() => /* @__PURE__ */ React3.createElement(ErrorBoundary, {
430
+ return useCallback(() => /* @__PURE__ */ React5.createElement(ErrorBoundary, {
293
431
  fallback
294
- }, /* @__PURE__ */ React3.createElement(PluginManagerProvider, {
432
+ }, /* @__PURE__ */ React5.createElement(PluginManagerProvider, {
295
433
  value: manager
296
- }, /* @__PURE__ */ React3.createElement(RegistryContext.Provider, {
434
+ }, /* @__PURE__ */ React5.createElement(RegistryContext.Provider, {
297
435
  value: manager.registry
298
- }, /* @__PURE__ */ React3.createElement(App, {
436
+ }, /* @__PURE__ */ React5.createElement(App, {
299
437
  placeholder,
300
- state
438
+ state,
439
+ debounce
301
440
  })))), [
302
441
  fallback,
303
442
  manager,
@@ -305,96 +444,9 @@ var useApp = ({ pluginManager, pluginLoader: _pluginLoader, plugins: _plugins, c
305
444
  state
306
445
  ]);
307
446
  };
308
- var DELAY_PLACEHOLDER = 2e3;
309
- var useLoading = (state) => {
310
- const [stage, setStage] = useState(0);
311
- useEffect2(() => {
312
- const i = setInterval(() => {
313
- setStage((tick) => {
314
- switch (tick) {
315
- case 0:
316
- if (!state.ready) {
317
- return 1;
318
- } else {
319
- clearInterval(i);
320
- return 3;
321
- }
322
- case 1:
323
- if (state.ready) {
324
- return 2;
325
- }
326
- break;
327
- case 2:
328
- clearInterval(i);
329
- return 3;
330
- }
331
- return tick;
332
- });
333
- }, DELAY_PLACEHOLDER);
334
- return () => clearInterval(i);
335
- }, []);
336
- return stage;
337
- };
338
- var App = ({ placeholder: Placeholder, state }) => {
339
- var _effect = _useSignals2();
340
- try {
341
- const reactContexts = useCapabilities(Capabilities.ReactContext);
342
- const reactRoots = useCapabilities(Capabilities.ReactRoot);
343
- const stage = useLoading(state);
344
- if (state.error) {
345
- throw state.error;
346
- }
347
- if (stage < 3) {
348
- if (!Placeholder) {
349
- return null;
350
- }
351
- return /* @__PURE__ */ React3.createElement(Placeholder, {
352
- stage
353
- });
354
- }
355
- const ComposedContext = composeContexts(reactContexts);
356
- return /* @__PURE__ */ React3.createElement(ComposedContext, null, reactRoots.map(({ id, root: Component2 }) => /* @__PURE__ */ React3.createElement(Component2, {
357
- key: id
358
- })));
359
- } finally {
360
- _effect.f();
361
- }
362
- };
363
- var DefaultFallback = ({ error }) => {
364
- var _effect = _useSignals2();
365
- try {
366
- return /* @__PURE__ */ React3.createElement("div", {
367
- style: {
368
- margin: "0.5rem",
369
- padding: "1rem",
370
- overflow: "hidden",
371
- border: "1px solid red"
372
- }
373
- }, /* @__PURE__ */ React3.createElement("h1", {
374
- style: {
375
- margin: "0.5rem 0",
376
- fontSize: "1.2rem"
377
- }
378
- }, "[ERROR]: ", error.message), /* @__PURE__ */ React3.createElement("pre", {
379
- style: {
380
- overflow: "auto",
381
- fontSize: "1rem",
382
- whiteSpace: "pre-wrap",
383
- color: "#888888"
384
- }
385
- }, error.stack));
386
- } finally {
387
- _effect.f();
388
- }
389
- };
390
- var composeContexts = (contexts) => {
391
- if (contexts.length === 0) {
392
- return ({ children }) => /* @__PURE__ */ React3.createElement(React3.Fragment, null, children);
393
- }
394
- return topologicalSort(contexts).map(({ context }) => context).reduce((Acc, Next) => ({ children }) => /* @__PURE__ */ React3.createElement(Acc, null, /* @__PURE__ */ React3.createElement(Next, null, children)));
395
- };
396
447
  var setupDevtools = (manager) => {
397
- globalThis.composer ??= {};
448
+ var _globalThis;
449
+ (_globalThis = globalThis).composer ?? (_globalThis.composer = {});
398
450
  globalThis.composer.manager = manager;
399
451
  };
400
452
 
@@ -413,4 +465,4 @@ export {
413
465
  useIntentResolver,
414
466
  useApp
415
467
  };
416
- //# sourceMappingURL=chunk-73HGSHKE.mjs.map
468
+ //# sourceMappingURL=chunk-AXSZKZFD.mjs.map