@dxos/app-framework 0.8.4-main.fd6878d → 0.8.4-staging.60fe92afc8
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.
- package/.storybook/main.mts +9 -0
- package/.storybook/preview.mts +8 -0
- package/LICENSE +102 -5
- package/README.md +1 -1
- package/dist/lib/browser/capability-BOPAKKWG.mjs +35 -0
- package/dist/lib/browser/capability-BOPAKKWG.mjs.map +7 -0
- package/dist/lib/browser/chunk-5GY3YOEL.mjs +28 -0
- package/dist/lib/browser/chunk-5GY3YOEL.mjs.map +7 -0
- package/dist/lib/browser/chunk-66IXTIVK.mjs +48 -0
- package/dist/lib/browser/chunk-66IXTIVK.mjs.map +7 -0
- package/dist/lib/browser/chunk-CO3XLNUX.mjs +95 -0
- package/dist/lib/browser/chunk-CO3XLNUX.mjs.map +7 -0
- package/dist/lib/browser/chunk-DC3WRPBV.mjs +227 -0
- package/dist/lib/browser/chunk-DC3WRPBV.mjs.map +7 -0
- package/dist/lib/browser/chunk-FJ4765WW.mjs +8 -0
- package/dist/lib/browser/chunk-FJ4765WW.mjs.map +7 -0
- package/dist/lib/browser/chunk-FO3IYSLV.mjs +68 -0
- package/dist/lib/browser/chunk-FO3IYSLV.mjs.map +7 -0
- package/dist/lib/browser/chunk-HFLKXMT7.mjs +587 -0
- package/dist/lib/browser/chunk-HFLKXMT7.mjs.map +7 -0
- package/dist/lib/browser/chunk-IW44C7UL.mjs +83 -0
- package/dist/lib/browser/chunk-IW44C7UL.mjs.map +7 -0
- package/dist/lib/browser/chunk-J5LGTIGS.mjs +10 -0
- package/dist/lib/browser/chunk-KZUDO43J.mjs +422 -0
- package/dist/lib/browser/chunk-KZUDO43J.mjs.map +7 -0
- package/dist/lib/browser/chunk-Q2GLJTVV.mjs +12 -0
- package/dist/lib/browser/chunk-Q2GLJTVV.mjs.map +7 -0
- package/dist/lib/browser/chunk-SYXIYT6T.mjs +143 -0
- package/dist/lib/browser/chunk-SYXIYT6T.mjs.map +7 -0
- package/dist/lib/browser/chunk-XHS5KDNX.mjs +1471 -0
- package/dist/lib/browser/chunk-XHS5KDNX.mjs.map +7 -0
- package/dist/lib/browser/chunk-Y66ELD4U.mjs +476 -0
- package/dist/lib/browser/chunk-Y66ELD4U.mjs.map +7 -0
- package/dist/lib/browser/cli/index.mjs +74 -0
- package/dist/lib/browser/cli/index.mjs.map +7 -0
- package/dist/lib/browser/common/activation-events.mjs +20 -0
- package/dist/lib/browser/common/capabilities.mjs +56 -0
- package/dist/lib/browser/core/activation-event.mjs +20 -0
- package/dist/lib/browser/core/capability.mjs +32 -0
- package/dist/lib/browser/core/capability.mjs.map +7 -0
- package/dist/lib/browser/core/plugin-manager.mjs +19 -0
- package/dist/lib/browser/core/plugin-manager.mjs.map +7 -0
- package/dist/lib/browser/core/plugin.mjs +41 -0
- package/dist/lib/browser/core/plugin.mjs.map +7 -0
- package/dist/lib/browser/core/url-loader.mjs +24 -0
- package/dist/lib/browser/core/url-loader.mjs.map +7 -0
- package/dist/lib/browser/index.mjs +85 -157
- package/dist/lib/browser/index.mjs.map +4 -4
- package/dist/lib/browser/meta.json +1 -1
- package/dist/lib/browser/process-manager-capability-GXNUO7AR.mjs +132 -0
- package/dist/lib/browser/process-manager-capability-GXNUO7AR.mjs.map +7 -0
- package/dist/lib/browser/testing/index.mjs +321 -56
- package/dist/lib/browser/testing/index.mjs.map +4 -4
- package/dist/lib/browser/testing/react.mjs +78 -0
- package/dist/lib/browser/testing/react.mjs.map +7 -0
- package/dist/lib/browser/ui/index.mjs +52 -0
- package/dist/lib/browser/ui/index.mjs.map +7 -0
- package/dist/lib/node-esm/capability-KZWRTX7R.mjs +36 -0
- package/dist/lib/node-esm/capability-KZWRTX7R.mjs.map +7 -0
- package/dist/lib/node-esm/chunk-37Z53PXZ.mjs +10 -0
- package/dist/lib/node-esm/chunk-37Z53PXZ.mjs.map +7 -0
- package/dist/lib/node-esm/chunk-A5CHGAZE.mjs +588 -0
- package/dist/lib/node-esm/chunk-A5CHGAZE.mjs.map +7 -0
- package/dist/lib/node-esm/chunk-COHOWGGJ.mjs +144 -0
- package/dist/lib/node-esm/chunk-COHOWGGJ.mjs.map +7 -0
- package/dist/lib/node-esm/chunk-CTKEZHKF.mjs +84 -0
- package/dist/lib/node-esm/chunk-CTKEZHKF.mjs.map +7 -0
- package/dist/lib/node-esm/chunk-FPW45EZH.mjs +14 -0
- package/dist/lib/node-esm/chunk-FPW45EZH.mjs.map +7 -0
- package/dist/lib/node-esm/chunk-FSVGKTF6.mjs +477 -0
- package/dist/lib/node-esm/chunk-FSVGKTF6.mjs.map +7 -0
- package/dist/lib/node-esm/chunk-HSLMI22Q.mjs +11 -0
- package/dist/lib/node-esm/chunk-HSLMI22Q.mjs.map +7 -0
- package/dist/lib/node-esm/chunk-KFZEB6BV.mjs +29 -0
- package/dist/lib/node-esm/chunk-KFZEB6BV.mjs.map +7 -0
- package/dist/lib/node-esm/chunk-NULBHQYS.mjs +96 -0
- package/dist/lib/node-esm/chunk-NULBHQYS.mjs.map +7 -0
- package/dist/lib/node-esm/chunk-SX5NVETP.mjs +1472 -0
- package/dist/lib/node-esm/chunk-SX5NVETP.mjs.map +7 -0
- package/dist/lib/node-esm/chunk-WK7OIQKI.mjs +70 -0
- package/dist/lib/node-esm/chunk-WK7OIQKI.mjs.map +7 -0
- package/dist/lib/node-esm/chunk-XGBUKRCK.mjs +423 -0
- package/dist/lib/node-esm/chunk-XGBUKRCK.mjs.map +7 -0
- package/dist/lib/node-esm/chunk-XIGPWXCQ.mjs +228 -0
- package/dist/lib/node-esm/chunk-XIGPWXCQ.mjs.map +7 -0
- package/dist/lib/node-esm/chunk-XOCUANHO.mjs +49 -0
- package/dist/lib/node-esm/chunk-XOCUANHO.mjs.map +7 -0
- package/dist/lib/node-esm/cli/index.mjs +75 -0
- package/dist/lib/node-esm/cli/index.mjs.map +7 -0
- package/dist/lib/node-esm/common/activation-events.mjs +21 -0
- package/dist/lib/node-esm/common/activation-events.mjs.map +7 -0
- package/dist/lib/node-esm/common/capabilities.mjs +57 -0
- package/dist/lib/node-esm/common/capabilities.mjs.map +7 -0
- package/dist/lib/node-esm/core/activation-event.mjs +21 -0
- package/dist/lib/node-esm/core/activation-event.mjs.map +7 -0
- package/dist/lib/node-esm/core/capability.mjs +33 -0
- package/dist/lib/node-esm/core/capability.mjs.map +7 -0
- package/dist/lib/node-esm/core/plugin-manager.mjs +20 -0
- package/dist/lib/node-esm/core/plugin-manager.mjs.map +7 -0
- package/dist/lib/node-esm/core/plugin.mjs +42 -0
- package/dist/lib/node-esm/core/plugin.mjs.map +7 -0
- package/dist/lib/node-esm/core/url-loader.mjs +25 -0
- package/dist/lib/node-esm/core/url-loader.mjs.map +7 -0
- package/dist/lib/node-esm/index.mjs +85 -157
- package/dist/lib/node-esm/index.mjs.map +4 -4
- package/dist/lib/node-esm/meta.json +1 -1
- package/dist/lib/node-esm/process-manager-capability-TX5TA6YN.mjs +133 -0
- package/dist/lib/node-esm/process-manager-capability-TX5TA6YN.mjs.map +7 -0
- package/dist/lib/node-esm/testing/index.mjs +321 -56
- package/dist/lib/node-esm/testing/index.mjs.map +4 -4
- package/dist/lib/node-esm/testing/react.mjs +79 -0
- package/dist/lib/node-esm/testing/react.mjs.map +7 -0
- package/dist/lib/node-esm/ui/index.mjs +53 -0
- package/dist/lib/node-esm/ui/index.mjs.map +7 -0
- package/dist/plugin/node-esm/index.mjs +977 -0
- package/dist/plugin/node-esm/index.mjs.map +7 -0
- package/dist/plugin/node-esm/meta.json +1 -0
- package/dist/types/src/cli/cli.d.ts +37 -0
- package/dist/types/src/cli/cli.d.ts.map +1 -0
- package/dist/types/src/cli/index.d.ts +2 -0
- package/dist/types/src/cli/index.d.ts.map +1 -0
- package/dist/types/src/common/activation-events.d.ts +24 -0
- package/dist/types/src/common/activation-events.d.ts.map +1 -0
- package/dist/types/src/common/annotations.d.ts +1 -0
- package/dist/types/src/common/annotations.d.ts.map +1 -0
- package/dist/types/src/common/capabilities.d.ts +214 -195
- package/dist/types/src/common/capabilities.d.ts.map +1 -1
- package/dist/types/src/common/index.d.ts +3 -8
- package/dist/types/src/common/index.d.ts.map +1 -1
- package/dist/types/src/common/translations.d.ts +8 -8
- package/dist/types/src/common/translations.d.ts.map +1 -1
- package/dist/types/src/context.d.ts +5 -0
- package/dist/types/src/context.d.ts.map +1 -0
- package/dist/types/src/core/{events.d.ts → activation-event.d.ts} +11 -11
- package/dist/types/src/core/activation-event.d.ts.map +1 -0
- package/dist/types/src/core/capability-manager.d.ts +52 -0
- package/dist/types/src/core/capability-manager.d.ts.map +1 -0
- package/dist/types/src/core/capability-manager.test.d.ts +2 -0
- package/dist/types/src/core/capability-manager.test.d.ts.map +1 -0
- package/dist/types/src/core/capability.d.ts +161 -0
- package/dist/types/src/core/capability.d.ts.map +1 -0
- package/dist/types/src/core/edge-registry-plugin-provider.d.ts +30 -0
- package/dist/types/src/core/edge-registry-plugin-provider.d.ts.map +1 -0
- package/dist/types/src/core/index.d.ts +11 -4
- package/dist/types/src/core/index.d.ts.map +1 -1
- package/dist/types/src/core/plugin-asset-cache.d.ts +71 -0
- package/dist/types/src/core/plugin-asset-cache.d.ts.map +1 -0
- package/dist/types/src/core/plugin-manager.d.ts +297 -0
- package/dist/types/src/core/plugin-manager.d.ts.map +1 -0
- package/dist/types/src/core/plugin-manager.test.d.ts +2 -0
- package/dist/types/src/core/plugin-manager.test.d.ts.map +1 -0
- package/dist/types/src/core/plugin-manifest.d.ts +101 -0
- package/dist/types/src/core/plugin-manifest.d.ts.map +1 -0
- package/dist/types/src/core/plugin-manifest.test.d.ts +2 -0
- package/dist/types/src/core/plugin-manifest.test.d.ts.map +1 -0
- package/dist/types/src/core/plugin.d.ts +308 -41
- package/dist/types/src/core/plugin.d.ts.map +1 -1
- package/dist/types/src/core/registry.d.ts +107 -0
- package/dist/types/src/core/registry.d.ts.map +1 -0
- package/dist/types/src/core/url-loader.d.ts +127 -0
- package/dist/types/src/core/url-loader.d.ts.map +1 -0
- package/dist/types/src/core/url-loader.test.d.ts +2 -0
- package/dist/types/src/core/url-loader.test.d.ts.map +1 -0
- package/dist/types/src/helpers.d.ts.map +1 -1
- package/dist/types/src/index.d.ts +2 -4
- package/dist/types/src/index.d.ts.map +1 -1
- package/dist/types/src/plugin-process-manager/ProcessManagerPlugin.d.ts +3 -0
- package/dist/types/src/plugin-process-manager/ProcessManagerPlugin.d.ts.map +1 -0
- package/dist/types/src/plugin-process-manager/history/capability.d.ts +7 -0
- package/dist/types/src/plugin-process-manager/history/capability.d.ts.map +1 -0
- package/dist/types/src/plugin-process-manager/history/errors.d.ts +32 -0
- package/dist/types/src/plugin-process-manager/history/errors.d.ts.map +1 -0
- package/dist/types/src/plugin-process-manager/history/history-tracker.d.ts +32 -0
- package/dist/types/src/plugin-process-manager/history/history-tracker.d.ts.map +1 -0
- package/dist/types/src/plugin-process-manager/history/history-tracker.test.d.ts +2 -0
- package/dist/types/src/plugin-process-manager/history/history-tracker.test.d.ts.map +1 -0
- package/dist/types/src/plugin-process-manager/history/index.d.ts +6 -0
- package/dist/types/src/plugin-process-manager/history/index.d.ts.map +1 -0
- package/dist/types/src/plugin-process-manager/history/types.d.ts +13 -0
- package/dist/types/src/plugin-process-manager/history/types.d.ts.map +1 -0
- package/dist/types/src/plugin-process-manager/history/undo-mapping.d.ts +101 -0
- package/dist/types/src/plugin-process-manager/history/undo-mapping.d.ts.map +1 -0
- package/dist/types/src/plugin-process-manager/history/undo-registry.d.ts +23 -0
- package/dist/types/src/plugin-process-manager/history/undo-registry.d.ts.map +1 -0
- package/dist/types/src/plugin-process-manager/history/undo-registry.test.d.ts +2 -0
- package/dist/types/src/plugin-process-manager/history/undo-registry.test.d.ts.map +1 -0
- package/dist/types/src/plugin-process-manager/idb-key-value-store.d.ts +10 -0
- package/dist/types/src/plugin-process-manager/idb-key-value-store.d.ts.map +1 -0
- package/dist/types/src/plugin-process-manager/index.d.ts +3 -0
- package/dist/types/src/plugin-process-manager/index.d.ts.map +1 -0
- package/dist/types/src/plugin-process-manager/meta.d.ts +3 -0
- package/dist/types/src/plugin-process-manager/meta.d.ts.map +1 -0
- package/dist/types/src/plugin-process-manager/process-manager-capability.d.ts +8 -0
- package/dist/types/src/plugin-process-manager/process-manager-capability.d.ts.map +1 -0
- package/dist/types/src/plugin-process-manager/testing.d.ts +59 -0
- package/dist/types/src/plugin-process-manager/testing.d.ts.map +1 -0
- package/dist/types/src/testing/harness.d.ts +79 -0
- package/dist/types/src/testing/harness.d.ts.map +1 -0
- package/dist/types/src/testing/index.d.ts +3 -0
- package/dist/types/src/testing/index.d.ts.map +1 -1
- package/dist/types/src/testing/operationCapture.d.ts +64 -0
- package/dist/types/src/testing/operationCapture.d.ts.map +1 -0
- package/dist/types/src/testing/react.d.ts +27 -0
- package/dist/types/src/testing/react.d.ts.map +1 -0
- package/dist/types/src/testing/react.test.d.ts +2 -0
- package/dist/types/src/testing/react.test.d.ts.map +1 -0
- package/dist/types/src/testing/service.d.ts +8 -0
- package/dist/types/src/testing/service.d.ts.map +1 -0
- package/dist/types/src/testing/withPluginManager.d.ts +9 -10
- package/dist/types/src/testing/withPluginManager.d.ts.map +1 -1
- package/dist/types/src/testing/withPluginManager.stories.d.ts +9 -3
- package/dist/types/src/testing/withPluginManager.stories.d.ts.map +1 -1
- package/dist/types/src/ui/components/App/App.d.ts +41 -0
- package/dist/types/src/ui/components/App/App.d.ts.map +1 -0
- package/dist/types/src/ui/components/App/App.stories.d.ts +19 -0
- package/dist/types/src/ui/components/App/App.stories.d.ts.map +1 -0
- package/dist/types/src/ui/components/App/index.d.ts +2 -0
- package/dist/types/src/ui/components/App/index.d.ts.map +1 -0
- package/dist/types/src/ui/components/PluginManager/PluginManagerContext.stories.d.ts +13 -0
- package/dist/types/src/ui/components/PluginManager/PluginManagerContext.stories.d.ts.map +1 -0
- package/dist/types/src/ui/components/PluginManager/PluginManagerProvider.d.ts +10 -0
- package/dist/types/src/ui/components/PluginManager/PluginManagerProvider.d.ts.map +1 -0
- package/dist/types/src/ui/components/PluginManager/index.d.ts +2 -0
- package/dist/types/src/ui/components/PluginManager/index.d.ts.map +1 -0
- package/dist/types/src/ui/components/Surface/SurfaceComponent.d.ts +24 -0
- package/dist/types/src/ui/components/Surface/SurfaceComponent.d.ts.map +1 -0
- package/dist/types/src/ui/components/Surface/SurfaceComponent.stories.d.ts +14 -0
- package/dist/types/src/ui/components/Surface/SurfaceComponent.stories.d.ts.map +1 -0
- package/dist/types/src/ui/components/Surface/SurfaceInfo.d.ts +11 -0
- package/dist/types/src/ui/components/Surface/SurfaceInfo.d.ts.map +1 -0
- package/dist/types/src/ui/components/Surface/SurfaceProfilerContext.d.ts +48 -0
- package/dist/types/src/ui/components/Surface/SurfaceProfilerContext.d.ts.map +1 -0
- package/dist/types/src/ui/components/Surface/context.d.ts +5 -0
- package/dist/types/src/ui/components/Surface/context.d.ts.map +1 -0
- package/dist/types/src/ui/components/Surface/index.d.ts +36 -0
- package/dist/types/src/ui/components/Surface/index.d.ts.map +1 -0
- package/dist/types/src/ui/components/Surface/types.d.ts +197 -0
- package/dist/types/src/ui/components/Surface/types.d.ts.map +1 -0
- package/dist/types/src/ui/components/Surface/types.test.d.ts +2 -0
- package/dist/types/src/ui/components/Surface/types.test.d.ts.map +1 -0
- package/dist/types/src/ui/components/index.d.ts +4 -0
- package/dist/types/src/ui/components/index.d.ts.map +1 -0
- package/dist/types/src/ui/hooks/index.d.ts +7 -0
- package/dist/types/src/ui/hooks/index.d.ts.map +1 -0
- package/dist/types/src/ui/hooks/useApp.d.ts +80 -0
- package/dist/types/src/ui/hooks/useApp.d.ts.map +1 -0
- package/dist/types/src/ui/hooks/useApp.test.d.ts +2 -0
- package/dist/types/src/ui/hooks/useApp.test.d.ts.map +1 -0
- package/dist/types/src/ui/hooks/useCapabilities.d.ts +31 -0
- package/dist/types/src/ui/hooks/useCapabilities.d.ts.map +1 -0
- package/dist/types/src/ui/hooks/useLoading.d.ts +18 -0
- package/dist/types/src/ui/hooks/useLoading.d.ts.map +1 -0
- package/dist/types/src/ui/hooks/useProcessManagerRuntime.d.ts +30 -0
- package/dist/types/src/ui/hooks/useProcessManagerRuntime.d.ts.map +1 -0
- package/dist/types/src/ui/hooks/useSettingsState.d.ts +10 -0
- package/dist/types/src/ui/hooks/useSettingsState.d.ts.map +1 -0
- package/dist/types/src/ui/hooks/useSurface.d.ts +3 -0
- package/dist/types/src/ui/hooks/useSurface.d.ts.map +1 -0
- package/dist/types/src/ui/index.d.ts +3 -0
- package/dist/types/src/ui/index.d.ts.map +1 -0
- package/dist/types/src/vite-plugin/boot-loader/index.d.ts +2 -0
- package/dist/types/src/vite-plugin/boot-loader/index.d.ts.map +1 -0
- package/dist/types/src/vite-plugin/boot-loader/loader.d.ts +59 -0
- package/dist/types/src/vite-plugin/boot-loader/loader.d.ts.map +1 -0
- package/dist/types/src/vite-plugin/composer/index.d.ts +34 -0
- package/dist/types/src/vite-plugin/composer/index.d.ts.map +1 -0
- package/dist/types/src/vite-plugin/import-map/index.d.ts +28 -0
- package/dist/types/src/vite-plugin/import-map/index.d.ts.map +1 -0
- package/dist/types/src/vite-plugin/index.d.ts +5 -0
- package/dist/types/src/vite-plugin/index.d.ts.map +1 -0
- package/dist/types/src/vite-plugin/manifest.d.ts +41 -0
- package/dist/types/src/vite-plugin/manifest.d.ts.map +1 -0
- package/dist/types/src/vite-plugin/manifest.test.d.ts +2 -0
- package/dist/types/src/vite-plugin/manifest.test.d.ts.map +1 -0
- package/dist/types/src/vite-plugin/packages.d.ts +13 -0
- package/dist/types/src/vite-plugin/packages.d.ts.map +1 -0
- package/dist/types/tsconfig.tsbuildinfo +1 -1
- package/moon.yml +26 -3
- package/package.json +125 -55
- package/src/cli/cli.ts +102 -0
- package/src/{playground/layout → cli}/index.ts +1 -1
- package/src/common/activation-events.ts +39 -0
- package/src/{playground/debug/index.ts → common/annotations.ts} +0 -2
- package/src/common/capabilities.ts +287 -184
- package/src/common/index.ts +3 -8
- package/src/common/translations.ts +18 -10
- package/src/context.ts +9 -0
- package/src/core/{events.ts → activation-event.ts} +10 -7
- package/src/core/capability-manager.test.ts +154 -0
- package/src/core/capability-manager.ts +213 -0
- package/src/core/capability.ts +254 -0
- package/src/core/edge-registry-plugin-provider.ts +92 -0
- package/src/core/index.ts +11 -4
- package/src/core/plugin-asset-cache.ts +60 -0
- package/src/core/plugin-manager.test.ts +1929 -0
- package/src/core/plugin-manager.ts +1696 -0
- package/src/core/plugin-manifest.test.ts +75 -0
- package/src/core/plugin-manifest.ts +134 -0
- package/src/core/plugin.ts +458 -46
- package/src/core/registry.ts +163 -0
- package/src/core/url-loader.test.ts +222 -0
- package/src/core/url-loader.ts +388 -0
- package/src/index.ts +2 -4
- package/src/plugin-process-manager/ProcessManagerPlugin.ts +24 -0
- package/src/plugin-process-manager/history/capability.ts +36 -0
- package/src/plugin-process-manager/history/errors.ts +7 -0
- package/src/plugin-process-manager/history/history-tracker.test.ts +353 -0
- package/src/plugin-process-manager/history/history-tracker.ts +144 -0
- package/src/plugin-process-manager/history/index.ts +9 -0
- package/src/plugin-process-manager/history/types.ts +17 -0
- package/src/plugin-process-manager/history/undo-mapping.ts +135 -0
- package/src/plugin-process-manager/history/undo-registry.test.ts +74 -0
- package/src/plugin-process-manager/history/undo-registry.ts +54 -0
- package/src/plugin-process-manager/idb-key-value-store.ts +64 -0
- package/src/plugin-process-manager/index.ts +6 -0
- package/src/plugin-process-manager/meta.ts +16 -0
- package/src/plugin-process-manager/process-manager-capability.ts +178 -0
- package/src/plugin-process-manager/testing.ts +156 -0
- package/src/testing/harness.ts +247 -0
- package/src/testing/index.ts +3 -0
- package/src/testing/operationCapture.ts +144 -0
- package/src/testing/react.test.tsx +50 -0
- package/src/testing/react.tsx +113 -0
- package/src/testing/service.ts +52 -0
- package/src/testing/withPluginManager.stories.tsx +15 -13
- package/src/testing/withPluginManager.tsx +81 -56
- package/src/ui/components/App/App.stories.tsx +84 -0
- package/src/ui/components/App/App.tsx +144 -0
- package/src/{playground/logger → ui/components/App}/index.ts +1 -1
- package/src/ui/components/PluginManager/PluginManagerContext.stories.tsx +179 -0
- package/src/{react → ui/components/PluginManager}/PluginManagerProvider.ts +3 -3
- package/src/ui/components/PluginManager/index.ts +5 -0
- package/src/ui/components/Surface/SurfaceComponent.stories.tsx +144 -0
- package/src/ui/components/Surface/SurfaceComponent.tsx +303 -0
- package/src/ui/components/Surface/SurfaceInfo.tsx +106 -0
- package/src/ui/components/Surface/SurfaceProfilerContext.tsx +207 -0
- package/src/ui/components/Surface/context.ts +12 -0
- package/src/ui/components/Surface/index.ts +54 -0
- package/src/ui/components/Surface/types.test.ts +126 -0
- package/src/ui/components/Surface/types.ts +290 -0
- package/src/ui/components/index.ts +7 -0
- package/src/ui/hooks/index.ts +10 -0
- package/src/ui/hooks/useApp.test.tsx +161 -0
- package/src/ui/hooks/useApp.tsx +404 -0
- package/src/ui/hooks/useCapabilities.ts +68 -0
- package/src/ui/hooks/useLoading.tsx +76 -0
- package/src/ui/hooks/useProcessManagerRuntime.ts +78 -0
- package/src/ui/hooks/useSettingsState.ts +26 -0
- package/src/ui/hooks/useSurface.ts +13 -0
- package/src/ui/index.ts +6 -0
- package/src/vite-plugin/boot-loader/BootLoader.solid-stories.tsx +198 -0
- package/src/vite-plugin/boot-loader/index.ts +5 -0
- package/src/vite-plugin/boot-loader/loader-app/Loader.tsx +166 -0
- package/src/vite-plugin/boot-loader/loader-app/boot-loader.css +311 -0
- package/src/vite-plugin/boot-loader/loader-app/bridge.ts +25 -0
- package/src/vite-plugin/boot-loader/loader-app/entry.tsx +21 -0
- package/src/vite-plugin/boot-loader/loader-app/mount.tsx +70 -0
- package/src/vite-plugin/boot-loader/loader-app/store.test.ts +137 -0
- package/src/vite-plugin/boot-loader/loader-app/store.ts +149 -0
- package/src/vite-plugin/boot-loader/loader-app/tsconfig.json +11 -0
- package/src/vite-plugin/boot-loader/loader-app/types.ts +78 -0
- package/src/vite-plugin/boot-loader/loader.ts +204 -0
- package/src/vite-plugin/composer/index.ts +306 -0
- package/src/vite-plugin/import-map/index.ts +527 -0
- package/src/vite-plugin/index.ts +10 -0
- package/src/vite-plugin/manifest.test.ts +55 -0
- package/src/vite-plugin/manifest.ts +63 -0
- package/src/vite-plugin/packages.ts +187 -0
- package/tsconfig.json +31 -24
- package/tsconfig.node.json +2 -4
- package/typedoc.json +2 -4
- package/vitest.config.ts +8 -6
- package/.swc/plugins/v7_linux_x86_64_13.0.0/c614d7475354583212fbd7669acbae95b9832c305bf51bdaabe2e6de05abb6bf +0 -0
- package/.swc/plugins/v7_linux_x86_64_13.0.0/fce1bdb8e20a094e4af08bad09cc81497ed0e2e7c51223b07d371063cca18429 +0 -0
- package/dist/lib/browser/app-graph-builder-MOVKFH3J.mjs +0 -137
- package/dist/lib/browser/app-graph-builder-MOVKFH3J.mjs.map +0 -7
- package/dist/lib/browser/chunk-NKCIDYDI.mjs +0 -1598
- package/dist/lib/browser/chunk-NKCIDYDI.mjs.map +0 -7
- package/dist/lib/browser/chunk-ORWHM7CO.mjs +0 -32
- package/dist/lib/browser/chunk-ORWHM7CO.mjs.map +0 -7
- package/dist/lib/browser/chunk-OSBZFKMO.mjs +0 -428
- package/dist/lib/browser/chunk-OSBZFKMO.mjs.map +0 -7
- package/dist/lib/browser/intent-dispatcher-FTTJLVGN.mjs +0 -11
- package/dist/lib/browser/intent-resolver-ZCGEAG3E.mjs +0 -39
- package/dist/lib/browser/intent-resolver-ZCGEAG3E.mjs.map +0 -7
- package/dist/lib/browser/store-3QB6Q2BC.mjs +0 -30
- package/dist/lib/browser/store-3QB6Q2BC.mjs.map +0 -7
- package/dist/lib/browser/worker.mjs +0 -79
- package/dist/lib/node-esm/app-graph-builder-ODE4B5GT.mjs +0 -138
- package/dist/lib/node-esm/app-graph-builder-ODE4B5GT.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-UMZQERLE.mjs +0 -34
- package/dist/lib/node-esm/chunk-UMZQERLE.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-WU3QN5B6.mjs +0 -429
- package/dist/lib/node-esm/chunk-WU3QN5B6.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-YEN7NKTF.mjs +0 -1600
- package/dist/lib/node-esm/chunk-YEN7NKTF.mjs.map +0 -7
- package/dist/lib/node-esm/intent-dispatcher-YQIQ55LJ.mjs +0 -12
- package/dist/lib/node-esm/intent-resolver-KG27L7EQ.mjs +0 -40
- package/dist/lib/node-esm/intent-resolver-KG27L7EQ.mjs.map +0 -7
- package/dist/lib/node-esm/store-TIJAVO3D.mjs +0 -31
- package/dist/lib/node-esm/store-TIJAVO3D.mjs.map +0 -7
- package/dist/lib/node-esm/worker.mjs +0 -80
- package/dist/types/src/App.d.ts +0 -43
- package/dist/types/src/App.d.ts.map +0 -1
- package/dist/types/src/common/collaboration.d.ts +0 -19
- package/dist/types/src/common/collaboration.d.ts.map +0 -1
- package/dist/types/src/common/events.d.ts +0 -52
- package/dist/types/src/common/events.d.ts.map +0 -1
- package/dist/types/src/common/file.d.ts +0 -14
- package/dist/types/src/common/file.d.ts.map +0 -1
- package/dist/types/src/common/graph.d.ts +0 -21
- package/dist/types/src/common/graph.d.ts.map +0 -1
- package/dist/types/src/common/layout.d.ts +0 -281
- package/dist/types/src/common/layout.d.ts.map +0 -1
- package/dist/types/src/common/surface.d.ts +0 -65
- package/dist/types/src/common/surface.d.ts.map +0 -1
- package/dist/types/src/core/capabilities.d.ts +0 -114
- package/dist/types/src/core/capabilities.d.ts.map +0 -1
- package/dist/types/src/core/capabilities.test.d.ts +0 -2
- package/dist/types/src/core/capabilities.test.d.ts.map +0 -1
- package/dist/types/src/core/events.d.ts.map +0 -1
- package/dist/types/src/core/manager.d.ts +0 -126
- package/dist/types/src/core/manager.d.ts.map +0 -1
- package/dist/types/src/core/manager.test.d.ts +0 -2
- package/dist/types/src/core/manager.test.d.ts.map +0 -1
- package/dist/types/src/playground/debug/Debug.d.ts +0 -6
- package/dist/types/src/playground/debug/Debug.d.ts.map +0 -1
- package/dist/types/src/playground/debug/index.d.ts +0 -2
- package/dist/types/src/playground/debug/index.d.ts.map +0 -1
- package/dist/types/src/playground/debug/plugin.d.ts +0 -2
- package/dist/types/src/playground/debug/plugin.d.ts.map +0 -1
- package/dist/types/src/playground/generator/Main.d.ts +0 -6
- package/dist/types/src/playground/generator/Main.d.ts.map +0 -1
- package/dist/types/src/playground/generator/Toolbar.d.ts +0 -6
- package/dist/types/src/playground/generator/Toolbar.d.ts.map +0 -1
- package/dist/types/src/playground/generator/generator.d.ts +0 -7
- package/dist/types/src/playground/generator/generator.d.ts.map +0 -1
- package/dist/types/src/playground/generator/index.d.ts +0 -3
- package/dist/types/src/playground/generator/index.d.ts.map +0 -1
- package/dist/types/src/playground/generator/plugin.d.ts +0 -2
- package/dist/types/src/playground/generator/plugin.d.ts.map +0 -1
- package/dist/types/src/playground/layout/Layout.d.ts +0 -8
- package/dist/types/src/playground/layout/Layout.d.ts.map +0 -1
- package/dist/types/src/playground/layout/index.d.ts +0 -2
- package/dist/types/src/playground/layout/index.d.ts.map +0 -1
- package/dist/types/src/playground/layout/plugin.d.ts +0 -2
- package/dist/types/src/playground/layout/plugin.d.ts.map +0 -1
- package/dist/types/src/playground/logger/Toolbar.d.ts +0 -6
- package/dist/types/src/playground/logger/Toolbar.d.ts.map +0 -1
- package/dist/types/src/playground/logger/index.d.ts +0 -2
- package/dist/types/src/playground/logger/index.d.ts.map +0 -1
- package/dist/types/src/playground/logger/plugin.d.ts +0 -2
- package/dist/types/src/playground/logger/plugin.d.ts.map +0 -1
- package/dist/types/src/playground/logger/schema.d.ts +0 -13
- package/dist/types/src/playground/logger/schema.d.ts.map +0 -1
- package/dist/types/src/playground/playground.stories.d.ts +0 -10
- package/dist/types/src/playground/playground.stories.d.ts.map +0 -1
- package/dist/types/src/plugin-intent/IntentPlugin.d.ts +0 -2
- package/dist/types/src/plugin-intent/IntentPlugin.d.ts.map +0 -1
- package/dist/types/src/plugin-intent/actions.d.ts +0 -38
- package/dist/types/src/plugin-intent/actions.d.ts.map +0 -1
- package/dist/types/src/plugin-intent/errors.d.ts +0 -16
- package/dist/types/src/plugin-intent/errors.d.ts.map +0 -1
- package/dist/types/src/plugin-intent/index.d.ts +0 -5
- package/dist/types/src/plugin-intent/index.d.ts.map +0 -1
- package/dist/types/src/plugin-intent/intent-dispatcher.d.ts +0 -139
- package/dist/types/src/plugin-intent/intent-dispatcher.d.ts.map +0 -1
- package/dist/types/src/plugin-intent/intent-dispatcher.test.d.ts +0 -2
- package/dist/types/src/plugin-intent/intent-dispatcher.test.d.ts.map +0 -1
- package/dist/types/src/plugin-intent/intent.d.ts +0 -63
- package/dist/types/src/plugin-intent/intent.d.ts.map +0 -1
- package/dist/types/src/plugin-settings/SettingsPlugin.d.ts +0 -2
- package/dist/types/src/plugin-settings/SettingsPlugin.d.ts.map +0 -1
- package/dist/types/src/plugin-settings/actions.d.ts +0 -27
- package/dist/types/src/plugin-settings/actions.d.ts.map +0 -1
- package/dist/types/src/plugin-settings/app-graph-builder.d.ts +0 -4
- package/dist/types/src/plugin-settings/app-graph-builder.d.ts.map +0 -1
- package/dist/types/src/plugin-settings/index.d.ts +0 -3
- package/dist/types/src/plugin-settings/index.d.ts.map +0 -1
- package/dist/types/src/plugin-settings/intent-resolver.d.ts +0 -4
- package/dist/types/src/plugin-settings/intent-resolver.d.ts.map +0 -1
- package/dist/types/src/plugin-settings/store.d.ts +0 -5
- package/dist/types/src/plugin-settings/store.d.ts.map +0 -1
- package/dist/types/src/plugin-settings/translations.d.ts +0 -10
- package/dist/types/src/plugin-settings/translations.d.ts.map +0 -1
- package/dist/types/src/react/ErrorBoundary.d.ts +0 -30
- package/dist/types/src/react/ErrorBoundary.d.ts.map +0 -1
- package/dist/types/src/react/IntentContext.d.ts +0 -8
- package/dist/types/src/react/IntentContext.d.ts.map +0 -1
- package/dist/types/src/react/PluginManagerProvider.d.ts +0 -10
- package/dist/types/src/react/PluginManagerProvider.d.ts.map +0 -1
- package/dist/types/src/react/Surface.d.ts +0 -12
- package/dist/types/src/react/Surface.d.ts.map +0 -1
- package/dist/types/src/react/Surface.stories.d.ts +0 -16
- package/dist/types/src/react/Surface.stories.d.ts.map +0 -1
- package/dist/types/src/react/common.d.ts +0 -13
- package/dist/types/src/react/common.d.ts.map +0 -1
- package/dist/types/src/react/index.d.ts +0 -7
- package/dist/types/src/react/index.d.ts.map +0 -1
- package/dist/types/src/react/useCapabilities.d.ts +0 -13
- package/dist/types/src/react/useCapabilities.d.ts.map +0 -1
- package/dist/types/src/react/useIntentResolver.d.ts +0 -3
- package/dist/types/src/react/useIntentResolver.d.ts.map +0 -1
- package/dist/types/src/worker.d.ts +0 -4
- package/dist/types/src/worker.d.ts.map +0 -1
- package/src/App.tsx +0 -284
- package/src/common/collaboration.ts +0 -21
- package/src/common/events.ts +0 -79
- package/src/common/file.ts +0 -22
- package/src/common/graph.ts +0 -30
- package/src/common/layout.ts +0 -278
- package/src/common/surface.ts +0 -86
- package/src/core/capabilities.test.ts +0 -136
- package/src/core/capabilities.ts +0 -255
- package/src/core/manager.test.ts +0 -516
- package/src/core/manager.ts +0 -597
- package/src/playground/debug/Debug.tsx +0 -39
- package/src/playground/debug/plugin.ts +0 -17
- package/src/playground/generator/Main.tsx +0 -71
- package/src/playground/generator/Toolbar.tsx +0 -47
- package/src/playground/generator/generator.ts +0 -48
- package/src/playground/generator/index.ts +0 -6
- package/src/playground/generator/plugin.ts +0 -23
- package/src/playground/layout/Layout.tsx +0 -33
- package/src/playground/layout/plugin.ts +0 -17
- package/src/playground/logger/Toolbar.tsx +0 -30
- package/src/playground/logger/plugin.ts +0 -37
- package/src/playground/logger/schema.ts +0 -12
- package/src/playground/playground.stories.tsx +0 -43
- package/src/plugin-intent/IntentPlugin.ts +0 -21
- package/src/plugin-intent/actions.ts +0 -33
- package/src/plugin-intent/errors.ts +0 -39
- package/src/plugin-intent/index.ts +0 -8
- package/src/plugin-intent/intent-dispatcher.test.ts +0 -279
- package/src/plugin-intent/intent-dispatcher.ts +0 -334
- package/src/plugin-intent/intent.ts +0 -154
- package/src/plugin-settings/SettingsPlugin.ts +0 -36
- package/src/plugin-settings/actions.ts +0 -29
- package/src/plugin-settings/app-graph-builder.ts +0 -158
- package/src/plugin-settings/index.ts +0 -6
- package/src/plugin-settings/intent-resolver.ts +0 -35
- package/src/plugin-settings/store.ts +0 -33
- package/src/plugin-settings/translations.ts +0 -19
- package/src/react/ErrorBoundary.tsx +0 -54
- package/src/react/IntentContext.tsx +0 -35
- package/src/react/Surface.stories.tsx +0 -97
- package/src/react/Surface.tsx +0 -78
- package/src/react/common.ts +0 -13
- package/src/react/index.ts +0 -10
- package/src/react/useCapabilities.ts +0 -31
- package/src/react/useIntentResolver.ts +0 -22
- package/src/worker.ts +0 -11
- /package/dist/lib/browser/{intent-dispatcher-FTTJLVGN.mjs.map → chunk-J5LGTIGS.mjs.map} +0 -0
- /package/dist/lib/browser/{worker.mjs.map → common/activation-events.mjs.map} +0 -0
- /package/dist/lib/{node-esm/intent-dispatcher-YQIQ55LJ.mjs.map → browser/common/capabilities.mjs.map} +0 -0
- /package/dist/lib/{node-esm/worker.mjs.map → browser/core/activation-event.mjs.map} +0 -0
package/src/core/plugin.ts
CHANGED
|
@@ -2,12 +2,84 @@
|
|
|
2
2
|
// Copyright 2025 DXOS.org
|
|
3
3
|
//
|
|
4
4
|
|
|
5
|
-
import
|
|
5
|
+
import * as Context from 'effect/Context';
|
|
6
|
+
import * as Effect from 'effect/Effect';
|
|
7
|
+
import * as Option from 'effect/Option';
|
|
8
|
+
import * as Pipeable from 'effect/Pipeable';
|
|
6
9
|
|
|
7
|
-
import {
|
|
8
|
-
import {
|
|
10
|
+
import { BaseError } from '@dxos/errors';
|
|
11
|
+
import { invariant } from '@dxos/invariant';
|
|
12
|
+
import { DXN } from '@dxos/keys';
|
|
9
13
|
|
|
10
|
-
|
|
14
|
+
import type * as ActivationEvent from './activation-event';
|
|
15
|
+
import * as Capability from './capability';
|
|
16
|
+
import type * as PluginManager from './plugin-manager';
|
|
17
|
+
|
|
18
|
+
//
|
|
19
|
+
// Plugin Service Layer
|
|
20
|
+
//
|
|
21
|
+
|
|
22
|
+
/**
|
|
23
|
+
* Effect Context.Tag for accessing PluginManager via the Effect layer system.
|
|
24
|
+
* This allows lifecycle operations to access the plugin manager without having it passed as an argument.
|
|
25
|
+
*/
|
|
26
|
+
export class Service extends Context.Tag('@dxos/app-framework/PluginManager')<Service, PluginManager.PluginManager>() {}
|
|
27
|
+
|
|
28
|
+
//
|
|
29
|
+
// Lifecycle Functions
|
|
30
|
+
//
|
|
31
|
+
|
|
32
|
+
/**
|
|
33
|
+
* Activates plugins based on the activation event.
|
|
34
|
+
* Accesses the PluginManager via the Effect layer system.
|
|
35
|
+
* @param event The activation event.
|
|
36
|
+
* @returns Whether the activation was successful.
|
|
37
|
+
*/
|
|
38
|
+
export const activate = (event: ActivationEvent.ActivationEvent): Effect.Effect<boolean, Error, Service> =>
|
|
39
|
+
Effect.flatMap(Service, (manager) => manager.activate(event));
|
|
40
|
+
|
|
41
|
+
/**
|
|
42
|
+
* Re-activates the modules that were activated by the event.
|
|
43
|
+
* Accesses the PluginManager via the Effect layer system.
|
|
44
|
+
* @param event The activation event.
|
|
45
|
+
* @returns Whether the reset was successful.
|
|
46
|
+
*/
|
|
47
|
+
export const reset = (event: ActivationEvent.ActivationEvent): Effect.Effect<boolean, Error, Service> =>
|
|
48
|
+
Effect.flatMap(Service, (manager) => manager.reset(event));
|
|
49
|
+
|
|
50
|
+
/**
|
|
51
|
+
* Shuts down the plugin manager, deactivating all active modules and clearing lifecycle state.
|
|
52
|
+
* Accesses the PluginManager via the Effect layer system.
|
|
53
|
+
*/
|
|
54
|
+
export const shutdown = (): Effect.Effect<boolean, Error, Service> =>
|
|
55
|
+
Effect.flatMap(Service, (manager) => manager.shutdown());
|
|
56
|
+
|
|
57
|
+
/**
|
|
58
|
+
* Computes a module ID from plugin ID and export name.
|
|
59
|
+
*/
|
|
60
|
+
const computeModuleId = (pluginId: string, moduleName: string): string => {
|
|
61
|
+
return `${pluginId}.module.${moduleName}`;
|
|
62
|
+
};
|
|
63
|
+
|
|
64
|
+
/**
|
|
65
|
+
* Identifier denoting a PluginModule.
|
|
66
|
+
*/
|
|
67
|
+
export const PluginModuleTypeId: unique symbol = Symbol.for('@dxos/app-framework/PluginModule');
|
|
68
|
+
export type PluginModuleTypeId = typeof PluginModuleTypeId;
|
|
69
|
+
|
|
70
|
+
/**
|
|
71
|
+
* Type guard to check if a value is a PluginModule.
|
|
72
|
+
*/
|
|
73
|
+
export const isPluginModule = (value: unknown): value is PluginModule => {
|
|
74
|
+
return typeof value === 'object' && value !== null && PluginModuleTypeId in value;
|
|
75
|
+
};
|
|
76
|
+
|
|
77
|
+
/**
|
|
78
|
+
* A unit of containment of modular functionality that can be provided to an application.
|
|
79
|
+
* Activation of a module is async allowing for code to split and loaded lazily.
|
|
80
|
+
*/
|
|
81
|
+
export interface PluginModule {
|
|
82
|
+
readonly [PluginModuleTypeId]: PluginModuleTypeId;
|
|
11
83
|
/**
|
|
12
84
|
* Unique id of the module.
|
|
13
85
|
*/
|
|
@@ -16,76 +88,107 @@ interface PluginModuleInterface {
|
|
|
16
88
|
/**
|
|
17
89
|
* Events for which the module will be activated.
|
|
18
90
|
*/
|
|
19
|
-
activatesOn:
|
|
91
|
+
activatesOn: ActivationEvent.Events;
|
|
20
92
|
|
|
21
93
|
/**
|
|
22
|
-
* Events
|
|
23
|
-
*
|
|
24
|
-
*
|
|
94
|
+
* Events that this module fires *before* its own activation runs.
|
|
95
|
+
*
|
|
96
|
+
* When this module is asked to activate (via {@link activatesOn}), the
|
|
97
|
+
* plugin manager first activates every event listed here, ensuring any
|
|
98
|
+
* other modules that contribute to those events have completed before
|
|
99
|
+
* this module's {@link activate} body executes. These events are fired
|
|
100
|
+
* by the framework on this module's behalf — the module does not need
|
|
101
|
+
* to wait for some other code to fire them.
|
|
102
|
+
*
|
|
103
|
+
* The module is marked as needing reset if a module activated by one
|
|
104
|
+
* of these events is later removed.
|
|
105
|
+
*
|
|
106
|
+
* Read as: "this module fires these events before [its] activation".
|
|
25
107
|
*/
|
|
26
|
-
|
|
108
|
+
firesBeforeActivation?: ActivationEvent.ActivationEvent[];
|
|
27
109
|
|
|
28
110
|
/**
|
|
29
|
-
* Events
|
|
111
|
+
* Events that this module fires *after* its own activation completes.
|
|
112
|
+
*
|
|
113
|
+
* Once this module's {@link activate} body has finished executing, the
|
|
114
|
+
* plugin manager activates every event listed here, causing any modules
|
|
115
|
+
* listening on those events to run. These events are fired by the
|
|
116
|
+
* framework on this module's behalf as part of this module's lifecycle.
|
|
117
|
+
*
|
|
118
|
+
* Read as: "this module fires these events after [its] activation".
|
|
30
119
|
*/
|
|
31
|
-
|
|
120
|
+
firesAfterActivation?: ActivationEvent.ActivationEvent[];
|
|
32
121
|
|
|
33
122
|
/**
|
|
34
123
|
* Called when the module is activated.
|
|
35
|
-
*
|
|
124
|
+
* CapabilityManager is accessed via the Effect layer system (Capability.Service).
|
|
125
|
+
* PluginManager is accessed via Plugin.Service.
|
|
126
|
+
* @param props Optional props passed to the module.
|
|
36
127
|
* @returns The capabilities of the module.
|
|
37
128
|
*/
|
|
38
|
-
activate: (
|
|
39
|
-
context: PluginContext,
|
|
40
|
-
) => MaybePromise<AnyCapability | AnyCapability[]> | Promise<() => Promise<AnyCapability | AnyCapability[]>>;
|
|
129
|
+
activate: (props?: any) => Effect.Effect<Capability.ModuleReturn, Error, Capability.Service | Service | never>;
|
|
41
130
|
}
|
|
42
131
|
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
readonly
|
|
50
|
-
readonly
|
|
51
|
-
readonly
|
|
52
|
-
readonly activatesAfter?: PluginModuleInterface['activatesAfter'];
|
|
53
|
-
readonly activate: PluginModuleInterface['activate'];
|
|
132
|
+
export type PluginModuleOptions = Omit<PluginModule, 'id' | typeof PluginModuleTypeId> & { id?: string };
|
|
133
|
+
|
|
134
|
+
class PluginModuleImpl implements PluginModule {
|
|
135
|
+
readonly [PluginModuleTypeId]: PluginModuleTypeId = PluginModuleTypeId;
|
|
136
|
+
readonly id: PluginModule['id'];
|
|
137
|
+
readonly activatesOn: PluginModule['activatesOn'];
|
|
138
|
+
readonly firesBeforeActivation?: PluginModule['firesBeforeActivation'];
|
|
139
|
+
readonly firesAfterActivation?: PluginModule['firesAfterActivation'];
|
|
140
|
+
readonly activate: PluginModule['activate'];
|
|
54
141
|
|
|
55
|
-
constructor(options:
|
|
142
|
+
constructor(options: Omit<PluginModule, typeof PluginModuleTypeId>) {
|
|
56
143
|
this.id = options.id;
|
|
57
144
|
this.activatesOn = options.activatesOn;
|
|
58
|
-
this.
|
|
59
|
-
this.
|
|
145
|
+
this.firesBeforeActivation = options.firesBeforeActivation;
|
|
146
|
+
this.firesAfterActivation = options.firesAfterActivation;
|
|
60
147
|
this.activate = options.activate;
|
|
61
148
|
}
|
|
62
149
|
}
|
|
63
150
|
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
151
|
+
export type Meta = {
|
|
152
|
+
/**
|
|
153
|
+
* Bare NSID (the name portion of {@link key}, e.g. `org.dxos.plugin.example`).
|
|
154
|
+
* Stable across versions; used for module-id namespacing, i18n namespaces,
|
|
155
|
+
* enable/disable, and registry lookups. Derived from `key` by {@link makeMeta} —
|
|
156
|
+
* do not set directly.
|
|
157
|
+
*/
|
|
158
|
+
id: string;
|
|
68
159
|
|
|
69
|
-
export type PluginMeta = {
|
|
70
160
|
/**
|
|
71
|
-
*
|
|
72
|
-
*
|
|
73
|
-
*
|
|
161
|
+
* Canonical identity DXN, including version when published
|
|
162
|
+
* (e.g. `dxn:org.dxos.plugin.example:0.8.3`). The validated source of truth
|
|
163
|
+
* from which {@link id} and {@link version} are derived.
|
|
74
164
|
*
|
|
75
|
-
* @example dxos.
|
|
165
|
+
* @example DXN.make('org.dxos.plugin.example', '0.8.3')
|
|
76
166
|
*/
|
|
77
|
-
|
|
167
|
+
key: DXN.DXN;
|
|
78
168
|
|
|
79
169
|
/**
|
|
80
170
|
* Human-readable name.
|
|
81
171
|
*/
|
|
82
172
|
name: string;
|
|
83
173
|
|
|
174
|
+
/**
|
|
175
|
+
* Semver version string of the plugin, typically the publishing package's
|
|
176
|
+
* `package.json` version. Derived from the version segment of {@link key} by
|
|
177
|
+
* {@link makeMeta} — do not set directly.
|
|
178
|
+
*/
|
|
179
|
+
version?: string;
|
|
180
|
+
|
|
84
181
|
/**
|
|
85
182
|
* Short description of plugin functionality.
|
|
86
183
|
*/
|
|
87
184
|
description?: string;
|
|
88
185
|
|
|
186
|
+
/**
|
|
187
|
+
* Name of the author or organization that created the plugin.
|
|
188
|
+
*/
|
|
189
|
+
// TODO(burdon): DID or domain name?
|
|
190
|
+
author?: string;
|
|
191
|
+
|
|
89
192
|
/**
|
|
90
193
|
* URL of home page.
|
|
91
194
|
*/
|
|
@@ -96,6 +199,14 @@ export type PluginMeta = {
|
|
|
96
199
|
*/
|
|
97
200
|
source?: string;
|
|
98
201
|
|
|
202
|
+
/**
|
|
203
|
+
* Relative path (inside the published package) to the plugin's bundled MDL
|
|
204
|
+
* specification file — e.g. `'PLUGIN.mdl'` or `'docs/PLUGIN.mdl'`. The file
|
|
205
|
+
* is shipped via the package's `files` entry and resolved by registry
|
|
206
|
+
* surfaces to render an in-app viewer and/or external link.
|
|
207
|
+
*/
|
|
208
|
+
spec?: string;
|
|
209
|
+
|
|
99
210
|
/**
|
|
100
211
|
* URL of screenshot.
|
|
101
212
|
*/
|
|
@@ -110,23 +221,324 @@ export type PluginMeta = {
|
|
|
110
221
|
* A grep-able symbol string which can be resolved to an icon asset by @ch-ui/icons, via @ch-ui/vite-plugin-icons.
|
|
111
222
|
*/
|
|
112
223
|
icon?: string;
|
|
224
|
+
|
|
225
|
+
/**
|
|
226
|
+
* Icon hue (ChromaticPalette).
|
|
227
|
+
*/
|
|
228
|
+
iconHue?: string;
|
|
229
|
+
|
|
230
|
+
/**
|
|
231
|
+
* IDs of plugins this plugin functionally depends on.
|
|
232
|
+
*
|
|
233
|
+
* Treated as a convenience by the default `PluginManager` flow:
|
|
234
|
+
* - Enabling this plugin auto-enables the transitive closure of `dependsOn`
|
|
235
|
+
* (installing missing entries from the plugin registry when possible).
|
|
236
|
+
* - Disabling a depended-upon plugin surfaces dependents to the caller; the
|
|
237
|
+
* `PluginManager.disable` API supports an opt-in cascade.
|
|
238
|
+
*
|
|
239
|
+
* Not an invariant: low-level `PluginManager` APIs accept opt-outs
|
|
240
|
+
* (`resolveDependencies: false`, `ignoreDependents: true`) so a caller may
|
|
241
|
+
* substitute an alternative implementation that satisfies the dependent's
|
|
242
|
+
* capability needs in its own way.
|
|
243
|
+
*/
|
|
244
|
+
dependsOn?: string[];
|
|
245
|
+
};
|
|
246
|
+
|
|
247
|
+
/**
|
|
248
|
+
* Options for {@link makeMeta}: a {@link Meta} minus the fields derived from `key`.
|
|
249
|
+
* Identity and version are specified solely through the `key` DXN — `id` and
|
|
250
|
+
* `version` cannot be passed directly.
|
|
251
|
+
*/
|
|
252
|
+
export type MakeMetaOptions = Omit<Meta, 'id' | 'version'>;
|
|
253
|
+
|
|
254
|
+
/**
|
|
255
|
+
* Constructs a plugin {@link Meta} from a single canonical DXN. The `key` DXN is
|
|
256
|
+
* the one source of truth; `id` (bare NSID) and `version` (semver) are derived
|
|
257
|
+
* from it so each datum has exactly one home and cannot drift out of sync.
|
|
258
|
+
*
|
|
259
|
+
* @example
|
|
260
|
+
* export const meta = Plugin.makeMeta({
|
|
261
|
+
* key: DXN.make('org.dxos.plugin.example', '0.8.3'),
|
|
262
|
+
* name: 'Example',
|
|
263
|
+
* });
|
|
264
|
+
*/
|
|
265
|
+
export const makeMeta = (options: MakeMetaOptions): Meta => ({
|
|
266
|
+
...options,
|
|
267
|
+
id: DXN.getName(options.key),
|
|
268
|
+
version: DXN.getVersion(options.key),
|
|
269
|
+
});
|
|
270
|
+
|
|
271
|
+
/**
|
|
272
|
+
* Identifier denoting a Plugin.
|
|
273
|
+
*/
|
|
274
|
+
export const PluginTypeId: unique symbol = Symbol.for('@dxos/app-framework/Plugin');
|
|
275
|
+
export type PluginTypeId = typeof PluginTypeId;
|
|
276
|
+
|
|
277
|
+
/**
|
|
278
|
+
* Type guard to check if a value is a Plugin.
|
|
279
|
+
*/
|
|
280
|
+
export const isPlugin = (value: unknown): value is Plugin => {
|
|
281
|
+
return typeof value === 'object' && value !== null && PluginTypeId in value;
|
|
113
282
|
};
|
|
114
283
|
|
|
115
284
|
/**
|
|
116
285
|
* A collection of modules that are be enabled/disabled as a unit.
|
|
117
286
|
* Plugins provide things such as components, state, actions, etc. to the application.
|
|
118
287
|
*/
|
|
119
|
-
//
|
|
120
|
-
export
|
|
288
|
+
// TODO(burdon): Convert to ECHO schema.
|
|
289
|
+
export interface Plugin {
|
|
290
|
+
readonly [PluginTypeId]: PluginTypeId;
|
|
291
|
+
readonly meta: Readonly<Meta>;
|
|
292
|
+
readonly modules: ReadonlyArray<PluginModule>;
|
|
293
|
+
}
|
|
294
|
+
|
|
295
|
+
/**
|
|
296
|
+
* Internal implementation of Plugin.
|
|
297
|
+
* @internal
|
|
298
|
+
*/
|
|
299
|
+
class PluginImpl implements Plugin {
|
|
300
|
+
readonly [PluginTypeId]: PluginTypeId = PluginTypeId;
|
|
301
|
+
|
|
121
302
|
constructor(
|
|
122
|
-
readonly
|
|
123
|
-
readonly
|
|
303
|
+
private readonly _meta: Meta,
|
|
304
|
+
private readonly _modules: PluginModule[],
|
|
124
305
|
) {}
|
|
306
|
+
|
|
307
|
+
get meta(): Readonly<Meta> {
|
|
308
|
+
return this._meta;
|
|
309
|
+
}
|
|
310
|
+
|
|
311
|
+
get modules(): ReadonlyArray<PluginModule> {
|
|
312
|
+
return this._modules;
|
|
313
|
+
}
|
|
125
314
|
}
|
|
126
315
|
|
|
127
316
|
/**
|
|
128
|
-
*
|
|
317
|
+
* Builder interface for creating plugins incrementally.
|
|
129
318
|
*/
|
|
130
|
-
export
|
|
131
|
-
|
|
319
|
+
export interface PluginBuilder<T = void> extends Pipeable.Pipeable {
|
|
320
|
+
readonly meta: Meta;
|
|
321
|
+
readonly modules: ReadonlyArray<PluginModuleOptions | ((options: T) => PluginModuleOptions)>;
|
|
322
|
+
addModule(moduleOptions: PluginModuleOptions | ((options: T) => PluginModuleOptions)): PluginBuilder<T>;
|
|
323
|
+
}
|
|
324
|
+
|
|
325
|
+
/**
|
|
326
|
+
* Builder implementation for creating plugins incrementally.
|
|
327
|
+
*/
|
|
328
|
+
class PluginBuilderImpl<T = void> implements PluginBuilder<T> {
|
|
329
|
+
readonly meta: Meta;
|
|
330
|
+
private readonly _modules: Array<PluginModuleOptions | ((options: T) => PluginModuleOptions)> = [];
|
|
331
|
+
|
|
332
|
+
constructor(meta: Meta) {
|
|
333
|
+
this.meta = meta;
|
|
334
|
+
}
|
|
335
|
+
|
|
336
|
+
get modules(): ReadonlyArray<PluginModuleOptions | ((options: T) => PluginModuleOptions)> {
|
|
337
|
+
return this._modules;
|
|
338
|
+
}
|
|
339
|
+
|
|
340
|
+
addModule(moduleOptions: PluginModuleOptions | ((options: T) => PluginModuleOptions)): PluginBuilder<T> {
|
|
341
|
+
this._modules.push(moduleOptions);
|
|
342
|
+
return this;
|
|
343
|
+
}
|
|
344
|
+
|
|
345
|
+
pipe() {
|
|
346
|
+
// eslint-disable-next-line prefer-rest-params
|
|
347
|
+
return Pipeable.pipeArguments(this, arguments);
|
|
348
|
+
}
|
|
349
|
+
}
|
|
350
|
+
|
|
351
|
+
/**
|
|
352
|
+
* Creates a new PluginBuilder to start building a plugin.
|
|
353
|
+
*/
|
|
354
|
+
export const define = <T = void>(meta: Meta): PluginBuilder<T> => new PluginBuilderImpl<T>(meta);
|
|
355
|
+
|
|
356
|
+
/**
|
|
357
|
+
* Adds a module to a plugin builder.
|
|
358
|
+
* Supports both pipeline and direct call styles.
|
|
359
|
+
* Modules can be either PluginModuleOptions or functions that receive options.
|
|
360
|
+
*/
|
|
361
|
+
export function addModule<T>(
|
|
362
|
+
moduleOptions: PluginModuleOptions | ((options: T) => PluginModuleOptions),
|
|
363
|
+
): (builder: PluginBuilder<T>) => PluginBuilder<T>;
|
|
364
|
+
export function addModule<T>(
|
|
365
|
+
builder: PluginBuilder<T>,
|
|
366
|
+
moduleOptions: PluginModuleOptions | ((options: T) => PluginModuleOptions),
|
|
367
|
+
): PluginBuilder<T>;
|
|
368
|
+
export function addModule<T>(
|
|
369
|
+
moduleOptionsOrBuilder: PluginModuleOptions | ((options: T) => PluginModuleOptions) | PluginBuilder<T>,
|
|
370
|
+
moduleOptions?: PluginModuleOptions | ((options: T) => PluginModuleOptions),
|
|
371
|
+
): ((builder: PluginBuilder<T>) => PluginBuilder<T>) | PluginBuilder<T> {
|
|
372
|
+
// If second arg is provided, it's the direct call style: addModule(builder, moduleOptions)
|
|
373
|
+
if (moduleOptions !== undefined) {
|
|
374
|
+
return (moduleOptionsOrBuilder as PluginBuilder<T>).addModule(moduleOptions);
|
|
375
|
+
}
|
|
376
|
+
// Otherwise it's pipeline style: addModule(moduleOptions) returns a function
|
|
377
|
+
const moduleOpts = moduleOptionsOrBuilder as PluginModuleOptions | ((options: T) => PluginModuleOptions);
|
|
378
|
+
return (builder: PluginBuilder<T>) => builder.addModule(moduleOpts);
|
|
379
|
+
}
|
|
380
|
+
|
|
381
|
+
export type PluginFactory<T = void> = ((options: T) => Plugin) & { meta: Meta };
|
|
382
|
+
|
|
383
|
+
/**
|
|
384
|
+
* Resolves a module from either PluginModuleOptions or a function that returns PluginModuleOptions.
|
|
385
|
+
*/
|
|
386
|
+
const resolveModule = (
|
|
387
|
+
meta: Meta,
|
|
388
|
+
module: PluginModuleOptions | ((options: any) => PluginModuleOptions),
|
|
389
|
+
options?: any,
|
|
390
|
+
): PluginModuleImpl => {
|
|
391
|
+
const moduleOptions = typeof module === 'function' ? module(options) : module;
|
|
392
|
+
const pluginName = meta.id;
|
|
393
|
+
const id = Option.fromNullable(moduleOptions.id).pipe(
|
|
394
|
+
Option.match({
|
|
395
|
+
onNone: () => {
|
|
396
|
+
const exportName = Capability.getModuleTag(moduleOptions.activate);
|
|
397
|
+
invariant(exportName, `Plugin module missing name. Plugin: ${meta.id}`);
|
|
398
|
+
return computeModuleId(pluginName, exportName);
|
|
399
|
+
},
|
|
400
|
+
onSome: (id) => computeModuleId(pluginName, id),
|
|
401
|
+
}),
|
|
402
|
+
);
|
|
403
|
+
return new PluginModuleImpl({ ...moduleOptions, id });
|
|
404
|
+
};
|
|
405
|
+
|
|
406
|
+
/**
|
|
407
|
+
* Creates a Plugin from a builder.
|
|
408
|
+
* Supports both pipeline and direct call styles.
|
|
409
|
+
* Always returns a factory function (options: T) => Plugin.
|
|
410
|
+
* When T is void, the function takes no arguments: () => Plugin.
|
|
411
|
+
*/
|
|
412
|
+
export function make<T>(builder: PluginBuilder<T>): PluginFactory<T>;
|
|
413
|
+
export function make<T>(builder: PluginBuilder<T>): PluginFactory<T> {
|
|
414
|
+
const meta = builder.meta;
|
|
415
|
+
// `dependsOn` entries and `id` are both bare NSIDs, so compare directly.
|
|
416
|
+
invariant(!meta.dependsOn?.includes(meta.id), `Plugin ${meta.id} declares itself as a dependency.`);
|
|
417
|
+
|
|
418
|
+
const factory = (options: T) => {
|
|
419
|
+
const modules = builder.modules.map((module) => resolveModule(meta, module, options));
|
|
420
|
+
return new PluginImpl(meta, modules);
|
|
421
|
+
};
|
|
422
|
+
|
|
423
|
+
return Object.assign(factory, { meta });
|
|
424
|
+
}
|
|
425
|
+
|
|
426
|
+
//
|
|
427
|
+
// Lazy plugin loading
|
|
428
|
+
//
|
|
429
|
+
|
|
430
|
+
/**
|
|
431
|
+
* Symbol used to tag lazy plugin stubs with their loader closure.
|
|
432
|
+
* Hidden from enumeration so plugin manager iteration / serialization paths
|
|
433
|
+
* don't trip over it.
|
|
434
|
+
*/
|
|
435
|
+
const LazyTag: unique symbol = Symbol.for('@dxos/app-framework/Plugin/Lazy');
|
|
436
|
+
|
|
437
|
+
/**
|
|
438
|
+
* Async loader for a lazy plugin's real implementation.
|
|
439
|
+
* The default export of the loaded module must be a `PluginFactory<T>` —
|
|
440
|
+
* i.e. the same shape `Plugin.make` produces.
|
|
441
|
+
*/
|
|
442
|
+
export type LazyLoader<T = void> = () => Promise<{ default: PluginFactory<T> }>;
|
|
443
|
+
|
|
444
|
+
/** Internal: payload carried on a lazy stub. */
|
|
445
|
+
type LazyPayload = { loader: LazyLoader<any>; options: unknown };
|
|
446
|
+
|
|
447
|
+
/**
|
|
448
|
+
* Defines a lazy plugin whose body is loaded on first enable.
|
|
449
|
+
*
|
|
450
|
+
* The returned factory produces a stub `Plugin` that exposes `meta`
|
|
451
|
+
* synchronously (so callers can read `Plugin.meta.id` for free) but defers
|
|
452
|
+
* loading the real plugin's modules until the manager calls
|
|
453
|
+
* `Plugin.resolveLazy`. This lets the plugin's main entry point ship as a
|
|
454
|
+
* tiny meta-only chunk — the heavy capabilities, schema, React surfaces,
|
|
455
|
+
* etc. live behind the dynamic `import()` and become a separate Rollup
|
|
456
|
+
* chunk that is only fetched when the plugin is enabled.
|
|
457
|
+
*
|
|
458
|
+
* @example
|
|
459
|
+
* ```ts
|
|
460
|
+
* // plugin-markdown/src/index.ts
|
|
461
|
+
* import { Plugin } from '@dxos/app-framework';
|
|
462
|
+
* import { meta } from './meta';
|
|
463
|
+
*
|
|
464
|
+
* export const MarkdownPlugin = Plugin.lazy(meta, () => import('./MarkdownPlugin'));
|
|
465
|
+
*
|
|
466
|
+
* // plugin-markdown/src/MarkdownPlugin.tsx
|
|
467
|
+
* export const MarkdownPlugin = Plugin.define(meta).pipe(...heavy modules..., Plugin.make);
|
|
468
|
+
* export default MarkdownPlugin;
|
|
469
|
+
* ```
|
|
470
|
+
*/
|
|
471
|
+
export const lazy = <T = void>(meta: Meta, loader: LazyLoader<T>): PluginFactory<T> => {
|
|
472
|
+
const factory = (options: T): Plugin => {
|
|
473
|
+
const stub = new PluginImpl(meta, []);
|
|
474
|
+
Object.defineProperty(stub, LazyTag, {
|
|
475
|
+
value: { loader, options } satisfies LazyPayload,
|
|
476
|
+
enumerable: false,
|
|
477
|
+
});
|
|
478
|
+
return stub;
|
|
479
|
+
};
|
|
480
|
+
return Object.assign(factory, { meta });
|
|
132
481
|
};
|
|
482
|
+
|
|
483
|
+
/**
|
|
484
|
+
* Type guard for lazy plugin stubs produced by {@link lazy}.
|
|
485
|
+
*/
|
|
486
|
+
export const isLazy = (plugin: Plugin): boolean => LazyTag in plugin;
|
|
487
|
+
|
|
488
|
+
/**
|
|
489
|
+
* Tagged error for failures during lazy plugin resolution. `context.id` is
|
|
490
|
+
* the lazy plugin's `meta.id`; `context.reason` discriminates the failure
|
|
491
|
+
* mode (`'load-failed' | 'missing-default' | 'invalid-plugin' |
|
|
492
|
+
* 'meta-mismatch'`) so callers can route on it.
|
|
493
|
+
*/
|
|
494
|
+
export class LazyPluginError extends BaseError.extend('LazyPluginError', 'Failed to resolve lazy plugin') {}
|
|
495
|
+
|
|
496
|
+
/**
|
|
497
|
+
* Tagged error for plugin-level dependency resolution failures.
|
|
498
|
+
*
|
|
499
|
+
* `context.id` is the plugin id the manager was acting on. `context.reason`
|
|
500
|
+
* discriminates the failure mode:
|
|
501
|
+
* - `'missing'` — declared dep is neither registered nor in the catalog.
|
|
502
|
+
* `context.missing` lists offending ids.
|
|
503
|
+
* - `'install-failed'` — dep was found in the catalog but `add()` failed.
|
|
504
|
+
* `cause` carries the original error.
|
|
505
|
+
* - `'cycle'` — closure walk detected a cycle. `context.path` is the cycle path.
|
|
506
|
+
* - `'core-dependent'` — cascade-disable would have to disable a core plugin.
|
|
507
|
+
* `context.coreDependent` is the blocking id.
|
|
508
|
+
*/
|
|
509
|
+
export class PluginDependencyError extends BaseError.extend(
|
|
510
|
+
'PluginDependencyError',
|
|
511
|
+
'Plugin dependency resolution failed',
|
|
512
|
+
) {}
|
|
513
|
+
|
|
514
|
+
/**
|
|
515
|
+
* Resolves a lazy plugin stub to its real plugin.
|
|
516
|
+
* Returns the plugin unchanged if it is not lazy. Failures surface as
|
|
517
|
+
* {@link LazyPluginError} with `context.reason` indicating the failure mode
|
|
518
|
+
* and (for loader failures) `cause` set to the original error.
|
|
519
|
+
*/
|
|
520
|
+
export const resolveLazy = (plugin: Plugin): Effect.Effect<Plugin, LazyPluginError> =>
|
|
521
|
+
Effect.gen(function* () {
|
|
522
|
+
if (!isLazy(plugin)) {
|
|
523
|
+
return plugin;
|
|
524
|
+
}
|
|
525
|
+
const id = plugin.meta.id;
|
|
526
|
+
const { loader, options } = (plugin as unknown as { [LazyTag]: LazyPayload })[LazyTag];
|
|
527
|
+
const mod = yield* Effect.tryPromise({
|
|
528
|
+
try: loader,
|
|
529
|
+
catch: (error) => new LazyPluginError({ context: { id, reason: 'load-failed' }, cause: error }),
|
|
530
|
+
});
|
|
531
|
+
if (!mod || typeof mod.default !== 'function') {
|
|
532
|
+
return yield* Effect.fail(new LazyPluginError({ context: { id, reason: 'missing-default' } }));
|
|
533
|
+
}
|
|
534
|
+
const result = mod.default(options);
|
|
535
|
+
if (!isPlugin(result)) {
|
|
536
|
+
return yield* Effect.fail(new LazyPluginError({ context: { id, reason: 'invalid-plugin' } }));
|
|
537
|
+
}
|
|
538
|
+
if (result.meta.id !== id) {
|
|
539
|
+
return yield* Effect.fail(
|
|
540
|
+
new LazyPluginError({ context: { id, reason: 'meta-mismatch', returnedId: result.meta.id } }),
|
|
541
|
+
);
|
|
542
|
+
}
|
|
543
|
+
return result;
|
|
544
|
+
});
|