@dxos/app-framework 0.8.4-main.bc674ce → 0.8.4-main.bcb3aa67d6
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 +1 -3
- package/dist/lib/browser/{capability-7PCNSWBT.mjs → capability-4NSF2SOO.mjs} +16 -11
- package/dist/lib/browser/capability-4NSF2SOO.mjs.map +7 -0
- package/dist/lib/browser/capability-EB3UKSKA.mjs +35 -0
- package/dist/lib/browser/capability-EB3UKSKA.mjs.map +7 -0
- package/dist/lib/browser/{chunk-FMZN33N4.mjs → chunk-27FZETIA.mjs} +324 -181
- package/dist/lib/browser/chunk-27FZETIA.mjs.map +7 -0
- package/dist/lib/browser/chunk-CV7I2AAB.mjs +80 -0
- package/dist/lib/browser/chunk-CV7I2AAB.mjs.map +7 -0
- package/dist/lib/browser/{chunk-6Y7PZV72.mjs → chunk-FL2XTEJH.mjs} +3 -4
- package/dist/lib/browser/chunk-FL2XTEJH.mjs.map +7 -0
- package/dist/lib/browser/chunk-H7OMDDGW.mjs +42 -0
- package/dist/lib/browser/chunk-H7OMDDGW.mjs.map +7 -0
- package/dist/lib/browser/chunk-HDQXX5DC.mjs +157 -0
- package/dist/lib/browser/chunk-HDQXX5DC.mjs.map +7 -0
- package/dist/lib/browser/chunk-I34GF4NG.mjs +34 -0
- package/dist/lib/browser/chunk-I34GF4NG.mjs.map +7 -0
- package/dist/lib/browser/chunk-KNBRTZVK.mjs +892 -0
- package/dist/lib/browser/chunk-KNBRTZVK.mjs.map +7 -0
- package/dist/lib/browser/{chunk-7IQHKD4U.mjs → chunk-NO7R7QHA.mjs} +4 -7
- package/dist/lib/browser/chunk-NO7R7QHA.mjs.map +7 -0
- package/dist/lib/browser/{chunk-TCLLRCS3.mjs → chunk-P2E7VMRF.mjs} +10 -7
- package/dist/lib/browser/chunk-P2E7VMRF.mjs.map +7 -0
- package/dist/lib/browser/{chunk-PKQT6C53.mjs → chunk-QSXYHXCE.mjs} +3 -2
- package/dist/lib/browser/chunk-QSXYHXCE.mjs.map +7 -0
- package/dist/lib/browser/chunk-RFSO3JRG.mjs +1 -0
- package/dist/lib/browser/chunk-TGX63LTL.mjs +8 -0
- package/dist/lib/browser/{chunk-FHQTHCX7.mjs.map → chunk-TGX63LTL.mjs.map} +1 -1
- package/dist/lib/browser/cli/index.mjs +90 -0
- package/dist/lib/browser/cli/index.mjs.map +7 -0
- package/dist/lib/browser/common/activation-events.mjs +24 -0
- package/dist/lib/browser/common/capabilities.mjs +46 -0
- package/dist/lib/browser/core/activation-event.mjs +1 -1
- package/dist/lib/browser/core/capability.mjs +1 -1
- package/dist/lib/browser/core/plugin-manager.mjs +4 -4
- package/dist/lib/browser/core/plugin.mjs +6 -4
- package/dist/lib/browser/core/url-loader.mjs +12 -0
- package/dist/lib/browser/index.mjs +40 -131
- package/dist/lib/browser/index.mjs.map +4 -4
- package/dist/lib/browser/invoker-capability-P7KPBTP3.mjs +43 -0
- package/dist/lib/browser/invoker-capability-P7KPBTP3.mjs.map +7 -0
- package/dist/lib/browser/meta.json +1 -1
- package/dist/lib/browser/testing/index.mjs +56 -34
- package/dist/lib/browser/testing/index.mjs.map +3 -3
- package/dist/lib/browser/{react → ui}/index.mjs +19 -21
- package/dist/lib/browser/ui/index.mjs.map +7 -0
- package/dist/lib/node-esm/{capability-CFLQ2QQU.mjs → capability-CB3MNEI3.mjs} +16 -11
- package/dist/lib/node-esm/capability-CB3MNEI3.mjs.map +7 -0
- package/dist/lib/node-esm/capability-CMROGK7R.mjs +36 -0
- package/dist/lib/node-esm/capability-CMROGK7R.mjs.map +7 -0
- package/dist/lib/node-esm/{chunk-STMXUEPO.mjs → chunk-37NG7SIN.mjs} +3 -4
- package/dist/lib/node-esm/chunk-37NG7SIN.mjs.map +7 -0
- package/dist/lib/node-esm/chunk-7JPKC7OM.mjs +893 -0
- package/dist/lib/node-esm/chunk-7JPKC7OM.mjs.map +7 -0
- package/dist/lib/node-esm/chunk-7PPVTBYR.mjs +81 -0
- package/dist/lib/node-esm/chunk-7PPVTBYR.mjs.map +7 -0
- package/dist/lib/node-esm/chunk-BQ56U4QX.mjs +43 -0
- package/dist/lib/node-esm/chunk-BQ56U4QX.mjs.map +7 -0
- package/dist/lib/node-esm/{chunk-GT6OKM5I.mjs → chunk-CG6UBBZZ.mjs} +10 -7
- package/dist/lib/node-esm/chunk-CG6UBBZZ.mjs.map +7 -0
- package/dist/lib/node-esm/chunk-EL3R25OQ.mjs +2 -0
- package/dist/lib/node-esm/chunk-EL3R25OQ.mjs.map +7 -0
- package/dist/lib/node-esm/{chunk-663A54LQ.mjs → chunk-EXYTXQ47.mjs} +4 -7
- package/dist/lib/node-esm/chunk-EXYTXQ47.mjs.map +7 -0
- package/dist/lib/node-esm/{chunk-UEWJDI2L.mjs → chunk-FKE4Z3D6.mjs} +2 -2
- package/dist/lib/node-esm/{chunk-UEWJDI2L.mjs.map → chunk-FKE4Z3D6.mjs.map} +1 -1
- package/dist/lib/node-esm/chunk-OXXXRCQX.mjs +158 -0
- package/dist/lib/node-esm/chunk-OXXXRCQX.mjs.map +7 -0
- package/dist/lib/node-esm/chunk-WZCSOX5Q.mjs +35 -0
- package/dist/lib/node-esm/chunk-WZCSOX5Q.mjs.map +7 -0
- package/dist/lib/node-esm/{chunk-XYQTBFPA.mjs → chunk-YH44RHP6.mjs} +324 -181
- package/dist/lib/node-esm/chunk-YH44RHP6.mjs.map +7 -0
- package/dist/lib/node-esm/{chunk-7OWSHPYK.mjs → chunk-ZZ7CKK6W.mjs} +3 -2
- package/dist/lib/node-esm/chunk-ZZ7CKK6W.mjs.map +7 -0
- package/dist/lib/node-esm/cli/index.mjs +91 -0
- package/dist/lib/node-esm/cli/index.mjs.map +7 -0
- package/dist/lib/node-esm/common/activation-events.mjs +25 -0
- package/dist/lib/node-esm/common/activation-events.mjs.map +7 -0
- package/dist/lib/node-esm/common/capabilities.mjs +47 -0
- package/dist/lib/node-esm/common/capabilities.mjs.map +7 -0
- package/dist/lib/node-esm/core/activation-event.mjs +1 -1
- package/dist/lib/node-esm/core/capability.mjs +1 -1
- package/dist/lib/node-esm/core/plugin-manager.mjs +4 -4
- package/dist/lib/node-esm/core/plugin.mjs +6 -4
- package/dist/lib/node-esm/core/url-loader.mjs +13 -0
- package/dist/lib/node-esm/core/url-loader.mjs.map +7 -0
- package/dist/lib/node-esm/index.mjs +40 -131
- package/dist/lib/node-esm/index.mjs.map +4 -4
- package/dist/lib/node-esm/invoker-capability-3C5H46ZY.mjs +44 -0
- package/dist/lib/node-esm/invoker-capability-3C5H46ZY.mjs.map +7 -0
- package/dist/lib/node-esm/meta.json +1 -1
- package/dist/lib/node-esm/testing/index.mjs +56 -34
- package/dist/lib/node-esm/testing/index.mjs.map +3 -3
- package/dist/lib/node-esm/{react → ui}/index.mjs +19 -21
- package/dist/lib/node-esm/ui/index.mjs.map +7 -0
- package/dist/plugin/node-esm/index.mjs +384 -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.d.ts → cli/cli.d.ts} +2 -2
- 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 +27 -0
- package/dist/types/src/common/activation-events.d.ts.map +1 -0
- package/dist/types/src/common/capabilities.d.ts +110 -0
- package/dist/types/src/common/capabilities.d.ts.map +1 -0
- package/dist/types/src/common/index.d.ts +4 -9
- package/dist/types/src/common/index.d.ts.map +1 -1
- package/dist/types/src/common/operations.d.ts +8 -369
- package/dist/types/src/common/operations.d.ts.map +1 -1
- package/dist/types/src/common/translations.d.ts +0 -9
- package/dist/types/src/common/translations.d.ts.map +1 -1
- package/dist/types/src/core/activation-event.d.ts +1 -1
- package/dist/types/src/core/activation-event.d.ts.map +1 -1
- package/dist/types/src/core/capability.d.ts +7 -7
- package/dist/types/src/core/capability.d.ts.map +1 -1
- package/dist/types/src/core/index.d.ts +1 -0
- package/dist/types/src/core/index.d.ts.map +1 -1
- package/dist/types/src/core/plugin-manager.d.ts +9 -2
- package/dist/types/src/core/plugin-manager.d.ts.map +1 -1
- package/dist/types/src/core/plugin.d.ts +6 -1
- package/dist/types/src/core/plugin.d.ts.map +1 -1
- package/dist/types/src/core/url-loader.d.ts +25 -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/index.d.ts +1 -3
- package/dist/types/src/index.d.ts.map +1 -1
- package/dist/types/src/plugin-operation/history/capability.d.ts +1 -1
- package/dist/types/src/plugin-operation/history/errors.d.ts +30 -3
- package/dist/types/src/plugin-operation/history/errors.d.ts.map +1 -1
- package/dist/types/src/plugin-operation/history/undo-mapping.d.ts +11 -3
- package/dist/types/src/plugin-operation/history/undo-mapping.d.ts.map +1 -1
- package/dist/types/src/plugin-operation/invoker-capability.d.ts +1 -1
- package/dist/types/src/plugin-operation/invoker-capability.d.ts.map +1 -1
- package/dist/types/src/plugin-operation/testing.d.ts +26 -77
- package/dist/types/src/plugin-operation/testing.d.ts.map +1 -1
- package/dist/types/src/plugin-runtime/capability.d.ts +2 -2
- package/dist/types/src/plugin-runtime/capability.d.ts.map +1 -1
- package/dist/types/src/testing/withPluginManager.d.ts +1 -1
- package/dist/types/src/testing/withPluginManager.d.ts.map +1 -1
- package/dist/types/src/{react → ui/components/App}/App.d.ts +3 -2
- package/dist/types/src/ui/components/App/App.d.ts.map +1 -0
- package/dist/types/src/{react/Surface.stories.d.ts → ui/components/App/App.stories.d.ts} +7 -2
- 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.map +1 -0
- package/dist/types/src/{react → ui/components/PluginManager}/PluginManagerProvider.d.ts +1 -1
- 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 +12 -0
- package/dist/types/src/ui/components/Surface/SurfaceComponent.d.ts.map +1 -0
- package/dist/types/src/{react/App.stories.d.ts → ui/components/Surface/SurfaceComponent.stories.d.ts} +1 -1
- package/dist/types/src/ui/components/Surface/SurfaceComponent.stories.d.ts.map +1 -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 +26 -0
- package/dist/types/src/ui/components/Surface/index.d.ts.map +1 -0
- package/dist/types/src/{common/surface.d.ts → ui/components/Surface/types.d.ts} +20 -18
- package/dist/types/src/ui/components/Surface/types.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 +6 -0
- package/dist/types/src/ui/hooks/index.d.ts.map +1 -0
- package/dist/types/src/{react → ui/hooks}/useApp.d.ts +26 -9
- 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/{react → ui/hooks}/useCapabilities.d.ts +6 -1
- package/dist/types/src/ui/hooks/useCapabilities.d.ts.map +1 -0
- package/dist/types/src/ui/hooks/useLoading.d.ts.map +1 -0
- package/dist/types/src/{react/common.d.ts → ui/hooks/useSettingsState.d.ts} +1 -5
- 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/composer-plugin.d.ts +18 -0
- package/dist/types/src/vite-plugin/composer-plugin.d.ts.map +1 -0
- package/dist/types/src/vite-plugin/import-map-plugin.d.ts +16 -0
- package/dist/types/src/vite-plugin/import-map-plugin.d.ts.map +1 -0
- package/dist/types/src/vite-plugin/index.d.ts +3 -0
- package/dist/types/src/vite-plugin/index.d.ts.map +1 -0
- package/dist/types/src/vite-plugin/packages.d.ts +7 -0
- package/dist/types/src/vite-plugin/packages.d.ts.map +1 -0
- package/dist/types/tsconfig.tsbuildinfo +1 -1
- package/moon.yml +20 -6
- package/package.json +91 -64
- package/src/{cli.ts → cli/cli.ts} +10 -10
- package/src/{playground/debug → cli}/index.ts +1 -1
- package/src/common/activation-events.ts +44 -0
- package/src/common/capabilities.ts +172 -0
- package/src/common/index.ts +4 -9
- package/src/common/operations.ts +6 -382
- package/src/common/translations.ts +0 -12
- package/src/context.ts +1 -1
- package/src/core/activation-event.ts +5 -2
- package/src/core/capability-manager.ts +1 -1
- package/src/core/capability.ts +11 -10
- package/src/core/index.ts +1 -0
- package/src/core/plugin-manager.test.ts +313 -44
- package/src/core/plugin-manager.ts +344 -157
- package/src/core/plugin.ts +10 -2
- package/src/core/url-loader.test.ts +79 -0
- package/src/core/url-loader.ts +148 -0
- package/src/index.ts +1 -3
- package/src/plugin-operation/OperationPlugin.ts +5 -5
- package/src/plugin-operation/history/capability.ts +5 -5
- package/src/plugin-operation/history/errors.ts +2 -6
- package/src/plugin-operation/history/history-tracker.test.ts +36 -42
- package/src/plugin-operation/history/undo-mapping.ts +6 -3
- package/src/plugin-operation/history/undo-registry.test.ts +3 -3
- package/src/plugin-operation/invoker-capability.ts +21 -7
- package/src/plugin-operation/meta.ts +1 -1
- package/src/plugin-operation/testing.ts +25 -45
- package/src/plugin-runtime/RuntimePlugin.ts +4 -4
- package/src/plugin-runtime/capability.ts +5 -5
- package/src/plugin-runtime/meta.ts +1 -1
- package/src/testing/service.ts +6 -6
- package/src/testing/withPluginManager.stories.tsx +6 -6
- package/src/testing/withPluginManager.tsx +46 -19
- package/src/ui/components/App/App.stories.tsx +92 -0
- package/src/{react → ui/components/App}/App.tsx +9 -11
- package/src/{playground/layout → ui/components/App}/index.ts +1 -1
- package/src/{react → ui/components/PluginManager}/PluginManagerContext.stories.tsx +13 -14
- package/src/{react → ui/components/PluginManager}/PluginManagerProvider.ts +1 -1
- package/src/ui/components/PluginManager/index.ts +5 -0
- package/src/{react/Surface.stories.tsx → ui/components/Surface/SurfaceComponent.stories.tsx} +28 -24
- package/src/{react/Surface.tsx → ui/components/Surface/SurfaceComponent.tsx} +48 -58
- package/src/{react → ui/components/Surface}/SurfaceInfo.tsx +2 -2
- 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 +35 -0
- package/src/{common/surface.ts → ui/components/Surface/types.ts} +22 -25
- package/src/ui/components/index.ts +7 -0
- package/src/ui/hooks/index.ts +9 -0
- package/src/ui/hooks/useApp.test.tsx +159 -0
- package/src/{react → ui/hooks}/useApp.tsx +110 -30
- package/src/{react → ui/hooks}/useCapabilities.ts +9 -5
- package/src/{react/common.ts → ui/hooks/useSettingsState.ts} +0 -11
- package/src/ui/hooks/useSurface.ts +13 -0
- package/src/ui/index.ts +6 -0
- package/src/vite-plugin/composer-plugin.ts +128 -0
- package/src/vite-plugin/import-map-plugin.ts +315 -0
- package/src/vite-plugin/index.ts +6 -0
- package/src/vite-plugin/packages.ts +29 -0
- package/tsconfig.json +4 -28
- package/tsconfig.node.json +2 -4
- package/typedoc.json +2 -4
- package/vitest.config.ts +1 -1
- package/dist/lib/browser/app-graph-builder-M2VPYQC6.mjs +0 -149
- package/dist/lib/browser/app-graph-builder-M2VPYQC6.mjs.map +0 -7
- package/dist/lib/browser/capability-7PCNSWBT.mjs.map +0 -7
- package/dist/lib/browser/capability-KP3PFEXD.mjs +0 -31
- package/dist/lib/browser/capability-KP3PFEXD.mjs.map +0 -7
- package/dist/lib/browser/chunk-6Y7PZV72.mjs.map +0 -7
- package/dist/lib/browser/chunk-7IQHKD4U.mjs.map +0 -7
- package/dist/lib/browser/chunk-BLQJSGL3.mjs +0 -732
- package/dist/lib/browser/chunk-BLQJSGL3.mjs.map +0 -7
- package/dist/lib/browser/chunk-FHQTHCX7.mjs +0 -8
- package/dist/lib/browser/chunk-FMZN33N4.mjs.map +0 -7
- package/dist/lib/browser/chunk-H4WPA7U7.mjs +0 -77
- package/dist/lib/browser/chunk-H4WPA7U7.mjs.map +0 -7
- package/dist/lib/browser/chunk-PKQT6C53.mjs.map +0 -7
- package/dist/lib/browser/chunk-TCLLRCS3.mjs.map +0 -7
- package/dist/lib/browser/chunk-XYNO72GQ.mjs +0 -746
- package/dist/lib/browser/chunk-XYNO72GQ.mjs.map +0 -7
- package/dist/lib/browser/common/index.mjs +0 -38
- package/dist/lib/browser/invoker-capability-SZRSTHEH.mjs +0 -32
- package/dist/lib/browser/invoker-capability-SZRSTHEH.mjs.map +0 -7
- package/dist/lib/browser/operation-resolver-6MP2MYOY.mjs +0 -64
- package/dist/lib/browser/operation-resolver-6MP2MYOY.mjs.map +0 -7
- package/dist/lib/node-esm/app-graph-builder-LROHGJEM.mjs +0 -150
- package/dist/lib/node-esm/app-graph-builder-LROHGJEM.mjs.map +0 -7
- package/dist/lib/node-esm/capability-CFLQ2QQU.mjs.map +0 -7
- package/dist/lib/node-esm/capability-RCUNM2M7.mjs +0 -32
- package/dist/lib/node-esm/capability-RCUNM2M7.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-663A54LQ.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-6WXBT3EC.mjs +0 -747
- package/dist/lib/node-esm/chunk-6WXBT3EC.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-7OWSHPYK.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-GQEBIGKD.mjs +0 -733
- package/dist/lib/node-esm/chunk-GQEBIGKD.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-GT6OKM5I.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-STMXUEPO.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-XR6NMKEP.mjs +0 -78
- package/dist/lib/node-esm/chunk-XR6NMKEP.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-XYQTBFPA.mjs.map +0 -7
- package/dist/lib/node-esm/common/index.mjs +0 -39
- package/dist/lib/node-esm/invoker-capability-PNMA5JOS.mjs +0 -33
- package/dist/lib/node-esm/invoker-capability-PNMA5JOS.mjs.map +0 -7
- package/dist/lib/node-esm/operation-resolver-7YWDMTNU.mjs +0 -65
- package/dist/lib/node-esm/operation-resolver-7YWDMTNU.mjs.map +0 -7
- package/dist/types/src/cli.d.ts.map +0 -1
- package/dist/types/src/common/activation-event.d.ts +0 -66
- package/dist/types/src/common/activation-event.d.ts.map +0 -1
- package/dist/types/src/common/capability.d.ts +0 -265
- package/dist/types/src/common/capability.d.ts.map +0 -1
- package/dist/types/src/common/collaboration.d.ts +0 -26
- package/dist/types/src/common/collaboration.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/plugin.d.ts +0 -201
- package/dist/types/src/common/plugin.d.ts.map +0 -1
- package/dist/types/src/common/surface.d.ts.map +0 -1
- package/dist/types/src/playground/debug/Debug.d.ts +0 -8
- 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 -3
- package/dist/types/src/playground/debug/plugin.d.ts.map +0 -1
- package/dist/types/src/playground/generator/Main.d.ts +0 -8
- package/dist/types/src/playground/generator/Main.d.ts.map +0 -1
- package/dist/types/src/playground/generator/Toolbar.d.ts +0 -8
- package/dist/types/src/playground/generator/Toolbar.d.ts.map +0 -1
- package/dist/types/src/playground/generator/generator.d.ts +0 -19
- 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 -3
- package/dist/types/src/playground/generator/plugin.d.ts.map +0 -1
- package/dist/types/src/playground/layout/Layout.d.ts +0 -10
- 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 -3
- package/dist/types/src/playground/layout/plugin.d.ts.map +0 -1
- package/dist/types/src/playground/logger/Toolbar.d.ts +0 -8
- 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 -3
- package/dist/types/src/playground/logger/plugin.d.ts.map +0 -1
- package/dist/types/src/playground/logger/schema.d.ts +0 -27
- package/dist/types/src/playground/logger/schema.d.ts.map +0 -1
- package/dist/types/src/playground/playground.stories.d.ts +0 -11
- package/dist/types/src/playground/playground.stories.d.ts.map +0 -1
- package/dist/types/src/plugin-settings/SettingsPlugin.d.ts +0 -3
- package/dist/types/src/plugin-settings/SettingsPlugin.d.ts.map +0 -1
- package/dist/types/src/plugin-settings/actions.d.ts +0 -61
- package/dist/types/src/plugin-settings/actions.d.ts.map +0 -1
- package/dist/types/src/plugin-settings/app-graph-builder.d.ts +0 -6
- 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/meta.d.ts +0 -3
- package/dist/types/src/plugin-settings/meta.d.ts.map +0 -1
- package/dist/types/src/plugin-settings/operation-resolver.d.ts +0 -6
- package/dist/types/src/plugin-settings/operation-resolver.d.ts.map +0 -1
- package/dist/types/src/plugin-settings/translations.d.ts +0 -11
- package/dist/types/src/plugin-settings/translations.d.ts.map +0 -1
- package/dist/types/src/react/App.d.ts.map +0 -1
- package/dist/types/src/react/App.stories.d.ts.map +0 -1
- package/dist/types/src/react/DefaultFallback.d.ts +0 -8
- package/dist/types/src/react/DefaultFallback.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/PluginManagerContext.stories.d.ts.map +0 -1
- package/dist/types/src/react/PluginManagerProvider.d.ts.map +0 -1
- package/dist/types/src/react/Surface.d.ts +0 -14
- package/dist/types/src/react/Surface.d.ts.map +0 -1
- package/dist/types/src/react/Surface.stories.d.ts.map +0 -1
- package/dist/types/src/react/SurfaceInfo.d.ts.map +0 -1
- package/dist/types/src/react/common.d.ts.map +0 -1
- package/dist/types/src/react/index.d.ts +0 -9
- package/dist/types/src/react/index.d.ts.map +0 -1
- package/dist/types/src/react/types.d.ts +0 -12
- package/dist/types/src/react/types.d.ts.map +0 -1
- package/dist/types/src/react/useApp.d.ts.map +0 -1
- package/dist/types/src/react/useCapabilities.d.ts.map +0 -1
- package/dist/types/src/react/useLoading.d.ts.map +0 -1
- package/dist/types/src/react/useOperationResolver.d.ts +0 -19
- package/dist/types/src/react/useOperationResolver.d.ts.map +0 -1
- package/src/common/activation-event.ts +0 -99
- package/src/common/capability.ts +0 -343
- package/src/common/collaboration.ts +0 -31
- package/src/common/file.ts +0 -22
- package/src/common/graph.ts +0 -30
- package/src/common/plugin.ts +0 -364
- package/src/playground/debug/Debug.tsx +0 -49
- package/src/playground/debug/plugin.ts +0 -16
- package/src/playground/generator/Main.tsx +0 -80
- package/src/playground/generator/Toolbar.tsx +0 -57
- package/src/playground/generator/generator.ts +0 -48
- package/src/playground/generator/index.ts +0 -6
- package/src/playground/generator/plugin.ts +0 -21
- package/src/playground/layout/Layout.tsx +0 -37
- package/src/playground/layout/plugin.ts +0 -18
- package/src/playground/logger/Toolbar.tsx +0 -33
- package/src/playground/logger/index.ts +0 -5
- package/src/playground/logger/plugin.ts +0 -42
- package/src/playground/logger/schema.ts +0 -22
- package/src/playground/playground.stories.tsx +0 -54
- package/src/plugin-settings/SettingsPlugin.ts +0 -19
- package/src/plugin-settings/actions.ts +0 -64
- package/src/plugin-settings/app-graph-builder.ts +0 -140
- package/src/plugin-settings/index.ts +0 -6
- package/src/plugin-settings/meta.ts +0 -10
- package/src/plugin-settings/operation-resolver.ts +0 -55
- package/src/plugin-settings/translations.ts +0 -19
- package/src/react/App.stories.tsx +0 -63
- package/src/react/DefaultFallback.tsx +0 -26
- package/src/react/ErrorBoundary.tsx +0 -56
- package/src/react/index.ts +0 -14
- package/src/react/types.ts +0 -27
- package/src/react/useOperationResolver.ts +0 -40
- /package/dist/lib/{node-esm/react/index.mjs.map → browser/chunk-RFSO3JRG.mjs.map} +0 -0
- /package/dist/lib/{node-esm/common/index.mjs.map → browser/common/activation-events.mjs.map} +0 -0
- /package/dist/lib/browser/{react/index.mjs.map → common/capabilities.mjs.map} +0 -0
- /package/dist/lib/browser/{common/index.mjs.map → core/url-loader.mjs.map} +0 -0
- /package/dist/types/src/{react → ui/components/PluginManager}/PluginManagerContext.stories.d.ts +0 -0
- /package/dist/types/src/{react → ui/components/Surface}/SurfaceInfo.d.ts +0 -0
- /package/dist/types/src/{react → ui/hooks}/useLoading.d.ts +0 -0
- /package/src/{react → ui/hooks}/useLoading.tsx +0 -0
|
@@ -2,41 +2,39 @@
|
|
|
2
2
|
// Copyright 2023 DXOS.org
|
|
3
3
|
//
|
|
4
4
|
|
|
5
|
-
import type { PropsWithChildren, ReactNode, RefCallback } from 'react';
|
|
5
|
+
import type { FC, PropsWithChildren, ReactNode, RefCallback } from 'react';
|
|
6
6
|
|
|
7
7
|
import type { MakeOptional, Position } from '@dxos/util';
|
|
8
8
|
|
|
9
|
-
import type { ErrorBoundary } from '../react';
|
|
10
|
-
|
|
11
9
|
/**
|
|
12
|
-
*
|
|
10
|
+
* Props that are passed to the Surface component.
|
|
13
11
|
*/
|
|
14
|
-
export type
|
|
12
|
+
export type Props<T extends Record<string, any> = Record<string, unknown>> = {
|
|
15
13
|
/**
|
|
16
14
|
* If specified, the Surface will be wrapped in an error boundary.
|
|
17
15
|
* The fallback component will be rendered if an error occurs.
|
|
18
16
|
*/
|
|
19
|
-
fallback?:
|
|
17
|
+
fallback?: FC<{ error: Error; data?: any }>;
|
|
20
18
|
|
|
21
19
|
/**
|
|
22
20
|
* If specified, the Surface will be wrapped in a suspense boundary.
|
|
23
21
|
* The placeholder component will be rendered while the surface component is loading.
|
|
24
22
|
*/
|
|
25
23
|
placeholder?: ReactNode;
|
|
26
|
-
} & MakeOptional<
|
|
24
|
+
} & MakeOptional<CoreProps<T>, 'id' | 'data'> &
|
|
27
25
|
/**
|
|
28
26
|
* Additional props to pass to the component.
|
|
29
27
|
* These props are not used by Surface itself but may be used by components which resolve the surface.
|
|
30
28
|
* Exclude known prop names to prevent overriding well-defined props.
|
|
31
29
|
*/
|
|
32
30
|
{
|
|
33
|
-
[K in keyof Record<string, any>]: K extends keyof
|
|
31
|
+
[K in keyof Record<string, any>]: K extends keyof CoreProps<T> | 'fallback' | 'placeholder' ? never : any;
|
|
34
32
|
};
|
|
35
33
|
|
|
36
34
|
/**
|
|
37
35
|
* NOTE: If `[key: string]: unknown` is included in shared types, when re-used other fields become unknown as well.
|
|
38
36
|
*/
|
|
39
|
-
export type
|
|
37
|
+
export type CoreProps<T extends Record<string, any> = Record<string, unknown>> = PropsWithChildren<{
|
|
40
38
|
/**
|
|
41
39
|
* ID for debugging.
|
|
42
40
|
*/
|
|
@@ -59,33 +57,34 @@ export type CoreSurfaceProps<T extends Record<string, any> = Record<string, unkn
|
|
|
59
57
|
limit?: number | undefined;
|
|
60
58
|
}>;
|
|
61
59
|
|
|
62
|
-
|
|
60
|
+
// TODO(burdon): Remove ref since relying on this would be error prone.
|
|
61
|
+
export type ComponentProps<T extends Record<string, any> = Record<string, any>> = CoreProps<T> & {
|
|
63
62
|
ref?: RefCallback<HTMLElement>;
|
|
64
63
|
} & Record<string, any>;
|
|
65
64
|
|
|
66
65
|
/**
|
|
67
66
|
* React component used to render a surface once is has matched.
|
|
68
67
|
*/
|
|
69
|
-
export type
|
|
70
|
-
props:
|
|
68
|
+
export type ComponentFunction<T extends Record<string, any> = Record<string, any>> = (
|
|
69
|
+
props: ComponentProps<T>,
|
|
71
70
|
) => ReactNode;
|
|
72
71
|
|
|
73
72
|
/**
|
|
74
|
-
* Definition of when a React
|
|
73
|
+
* Definition of when a React component surface should be rendered.
|
|
75
74
|
*/
|
|
76
|
-
export type
|
|
75
|
+
export type ReactDefinition<T extends Record<string, any> = any> = Readonly<{
|
|
77
76
|
kind: 'react';
|
|
78
77
|
id: string;
|
|
79
78
|
role: string | string[];
|
|
80
79
|
position?: Position;
|
|
81
|
-
component:
|
|
80
|
+
component: ComponentFunction<T>;
|
|
82
81
|
filter?: (data: Record<string, unknown>) => data is T;
|
|
83
82
|
}>;
|
|
84
83
|
|
|
85
84
|
/**
|
|
86
85
|
* Definition of when a Web Component surface should be rendered.
|
|
87
86
|
*/
|
|
88
|
-
export type
|
|
87
|
+
export type WebComponentDefinition<T extends Record<string, any> = any> = Readonly<{
|
|
89
88
|
kind: 'web-component';
|
|
90
89
|
id: string;
|
|
91
90
|
role: string | string[];
|
|
@@ -101,20 +100,18 @@ export type WebComponentSurfaceDefinition<T extends Record<string, any> = any> =
|
|
|
101
100
|
/**
|
|
102
101
|
* Definition of when a surface (React or Web Component) should be rendered.
|
|
103
102
|
*/
|
|
104
|
-
export type
|
|
105
|
-
| ReactSurfaceDefinition<T>
|
|
106
|
-
| WebComponentSurfaceDefinition<T>;
|
|
103
|
+
export type Definition<T extends Record<string, any> = any> = ReactDefinition<T> | WebComponentDefinition<T>;
|
|
107
104
|
|
|
108
105
|
/**
|
|
109
106
|
* Creates a React surface definition.
|
|
110
107
|
*/
|
|
111
|
-
export const
|
|
112
|
-
definition: Omit<
|
|
113
|
-
):
|
|
108
|
+
export const create = <T extends Record<string, any> = any>(
|
|
109
|
+
definition: Omit<ReactDefinition<T>, 'kind'>,
|
|
110
|
+
): ReactDefinition<T> => ({ ...definition, kind: 'react' });
|
|
114
111
|
|
|
115
112
|
/**
|
|
116
113
|
* Creates a Web Component surface definition.
|
|
117
114
|
*/
|
|
118
|
-
export const
|
|
119
|
-
definition: Omit<
|
|
120
|
-
):
|
|
115
|
+
export const createWeb = <T extends Record<string, any> = any>(
|
|
116
|
+
definition: Omit<WebComponentDefinition<T>, 'kind'>,
|
|
117
|
+
): WebComponentDefinition<T> => ({ ...definition, kind: 'web-component' });
|
|
@@ -0,0 +1,159 @@
|
|
|
1
|
+
//
|
|
2
|
+
// Copyright 2025 DXOS.org
|
|
3
|
+
//
|
|
4
|
+
|
|
5
|
+
import { assert, describe, it } from '@effect/vitest';
|
|
6
|
+
import { render, waitFor } from '@testing-library/react';
|
|
7
|
+
import * as Effect from 'effect/Effect';
|
|
8
|
+
import React from 'react';
|
|
9
|
+
|
|
10
|
+
import { ActivationEvents, Capabilities } from '../../common';
|
|
11
|
+
import { Capability, Plugin, PluginManager } from '../../core';
|
|
12
|
+
import { useApp } from './useApp';
|
|
13
|
+
|
|
14
|
+
const String = Capability.make<{ string: string }>('org.dxos.test.string');
|
|
15
|
+
const testMeta = { id: 'org.dxos.plugin.test', name: 'Test' };
|
|
16
|
+
|
|
17
|
+
const pluginLoader = (plugins: Plugin.Plugin[]) =>
|
|
18
|
+
Effect.fn(function* (id: string) {
|
|
19
|
+
const plugin = plugins.find((plugin) => plugin.meta.id === id);
|
|
20
|
+
if (!plugin) {
|
|
21
|
+
return yield* Effect.fail(new Error(`Plugin not found: ${id}`));
|
|
22
|
+
}
|
|
23
|
+
return plugin;
|
|
24
|
+
});
|
|
25
|
+
|
|
26
|
+
const TestHost = ({ manager }: { manager: PluginManager.PluginManager }) => {
|
|
27
|
+
const App = useApp({ pluginManager: manager });
|
|
28
|
+
return <App />;
|
|
29
|
+
};
|
|
30
|
+
|
|
31
|
+
describe('useApp cleanup integration', () => {
|
|
32
|
+
it.effect('external manager is not shut down when useApp does not own it', () =>
|
|
33
|
+
Effect.gen(function* () {
|
|
34
|
+
const plugin = Plugin.define(testMeta).pipe(
|
|
35
|
+
Plugin.addModule({
|
|
36
|
+
id: 'Hello',
|
|
37
|
+
activatesOn: ActivationEvents.Startup,
|
|
38
|
+
activate: () => Effect.succeed(Capability.contributes(String, { string: 'hello' })),
|
|
39
|
+
}),
|
|
40
|
+
Plugin.make,
|
|
41
|
+
)();
|
|
42
|
+
|
|
43
|
+
const manager = PluginManager.make({
|
|
44
|
+
pluginLoader: pluginLoader([plugin]),
|
|
45
|
+
plugins: [plugin],
|
|
46
|
+
});
|
|
47
|
+
|
|
48
|
+
manager.capabilities.contribute({
|
|
49
|
+
interface: Capabilities.PluginManager,
|
|
50
|
+
implementation: manager,
|
|
51
|
+
module: 'org.dxos.app-framework.plugin-manager',
|
|
52
|
+
});
|
|
53
|
+
manager.capabilities.contribute({
|
|
54
|
+
interface: Capabilities.AtomRegistry,
|
|
55
|
+
implementation: manager.registry,
|
|
56
|
+
module: 'org.dxos.app-framework.atom-registry',
|
|
57
|
+
});
|
|
58
|
+
|
|
59
|
+
const view = yield* Effect.promise(() => Promise.resolve(render(<TestHost manager={manager} />)));
|
|
60
|
+
yield* Effect.promise(() =>
|
|
61
|
+
waitFor(() => {
|
|
62
|
+
assert.strictEqual(manager.capabilities.getAll(Capabilities.PluginManager).length, 1);
|
|
63
|
+
assert.strictEqual(manager.capabilities.getAll(Capabilities.AtomRegistry).length, 1);
|
|
64
|
+
assert.strictEqual(manager.capabilities.getAll(String).length, 1);
|
|
65
|
+
assert.isTrue(manager.getActive().length > 0);
|
|
66
|
+
}),
|
|
67
|
+
);
|
|
68
|
+
|
|
69
|
+
yield* Effect.promise(() => Promise.resolve(view.unmount()));
|
|
70
|
+
yield* Effect.promise(() =>
|
|
71
|
+
waitFor(() => {
|
|
72
|
+
assert.strictEqual(manager.capabilities.getAll(Capabilities.PluginManager).length, 1);
|
|
73
|
+
assert.strictEqual(manager.capabilities.getAll(Capabilities.AtomRegistry).length, 1);
|
|
74
|
+
assert.strictEqual(manager.capabilities.getAll(String).length, 1);
|
|
75
|
+
assert.isTrue(manager.getActive().length > 0);
|
|
76
|
+
}),
|
|
77
|
+
);
|
|
78
|
+
|
|
79
|
+
yield* manager.shutdown();
|
|
80
|
+
|
|
81
|
+
assert.strictEqual(manager.capabilities.getAll(Capabilities.PluginManager).length, 1);
|
|
82
|
+
assert.strictEqual(manager.capabilities.getAll(Capabilities.AtomRegistry).length, 1);
|
|
83
|
+
assert.strictEqual(manager.capabilities.getAll(String).length, 0);
|
|
84
|
+
assert.deepStrictEqual(manager.getActive(), []);
|
|
85
|
+
}),
|
|
86
|
+
);
|
|
87
|
+
|
|
88
|
+
it.effect('shutdown deactivates modules and clears bookkeeping', () =>
|
|
89
|
+
Effect.gen(function* () {
|
|
90
|
+
const plugin = Plugin.define(testMeta).pipe(
|
|
91
|
+
Plugin.addModule({
|
|
92
|
+
id: 'Hello',
|
|
93
|
+
activatesOn: ActivationEvents.Startup,
|
|
94
|
+
activate: () => Effect.succeed(Capability.contributes(String, { string: 'hello' })),
|
|
95
|
+
}),
|
|
96
|
+
Plugin.make,
|
|
97
|
+
)();
|
|
98
|
+
|
|
99
|
+
const manager = PluginManager.make({
|
|
100
|
+
pluginLoader: pluginLoader([plugin]),
|
|
101
|
+
plugins: [plugin],
|
|
102
|
+
});
|
|
103
|
+
|
|
104
|
+
manager.capabilities.contribute({
|
|
105
|
+
interface: Capabilities.PluginManager,
|
|
106
|
+
implementation: manager,
|
|
107
|
+
module: 'org.dxos.app-framework.plugin-manager',
|
|
108
|
+
});
|
|
109
|
+
manager.capabilities.contribute({
|
|
110
|
+
interface: Capabilities.AtomRegistry,
|
|
111
|
+
implementation: manager.registry,
|
|
112
|
+
module: 'org.dxos.app-framework.atom-registry',
|
|
113
|
+
});
|
|
114
|
+
yield* manager.activate(ActivationEvents.Startup);
|
|
115
|
+
|
|
116
|
+
assert.strictEqual(manager.capabilities.getAll(String).length, 1);
|
|
117
|
+
assert.isTrue(manager.getActive().length > 0);
|
|
118
|
+
|
|
119
|
+
yield* manager.shutdown();
|
|
120
|
+
|
|
121
|
+
assert.strictEqual(manager.capabilities.getAll(String).length, 0);
|
|
122
|
+
assert.deepStrictEqual(manager.getActive(), []);
|
|
123
|
+
assert.deepStrictEqual(manager.getEventsFired(), []);
|
|
124
|
+
}),
|
|
125
|
+
);
|
|
126
|
+
|
|
127
|
+
it.effect('shutdown is idempotent when called multiple times', () =>
|
|
128
|
+
Effect.gen(function* () {
|
|
129
|
+
const plugin = Plugin.define(testMeta).pipe(
|
|
130
|
+
Plugin.addModule({
|
|
131
|
+
id: 'Hello',
|
|
132
|
+
activatesOn: ActivationEvents.Startup,
|
|
133
|
+
activate: () => Effect.succeed(Capability.contributes(String, { string: 'hello' })),
|
|
134
|
+
}),
|
|
135
|
+
Plugin.make,
|
|
136
|
+
)();
|
|
137
|
+
|
|
138
|
+
const manager = PluginManager.make({
|
|
139
|
+
pluginLoader: pluginLoader([plugin]),
|
|
140
|
+
plugins: [plugin],
|
|
141
|
+
});
|
|
142
|
+
|
|
143
|
+
manager.capabilities.contribute({
|
|
144
|
+
interface: Capabilities.PluginManager,
|
|
145
|
+
implementation: manager,
|
|
146
|
+
module: 'org.dxos.app-framework.plugin-manager',
|
|
147
|
+
});
|
|
148
|
+
yield* manager.activate(ActivationEvents.Startup);
|
|
149
|
+
|
|
150
|
+
yield* manager.shutdown();
|
|
151
|
+
assert.deepStrictEqual(manager.getActive(), []);
|
|
152
|
+
|
|
153
|
+
// Second shutdown should succeed without error.
|
|
154
|
+
const result = yield* manager.shutdown();
|
|
155
|
+
assert.isTrue(result);
|
|
156
|
+
assert.deepStrictEqual(manager.getActive(), []);
|
|
157
|
+
}),
|
|
158
|
+
);
|
|
159
|
+
});
|
|
@@ -12,19 +12,32 @@ import React, { type FC, useCallback, useEffect, useMemo, useRef, useState } fro
|
|
|
12
12
|
import { runAndForwardErrors } from '@dxos/effect';
|
|
13
13
|
import { invariant } from '@dxos/invariant';
|
|
14
14
|
import { log } from '@dxos/log';
|
|
15
|
+
import { ErrorBoundary, ErrorFallback, type FallbackProps } from '@dxos/react-error-boundary';
|
|
15
16
|
import { useAsyncEffect, useDefaultValue } from '@dxos/react-hooks';
|
|
16
17
|
import { ContextProtocolProvider } from '@dxos/web-context-react';
|
|
17
18
|
|
|
18
|
-
import
|
|
19
|
-
import { PluginManagerContext } from '
|
|
20
|
-
import { type Plugin, PluginManager } from '
|
|
19
|
+
import { ActivationEvents, Capabilities } from '../../common';
|
|
20
|
+
import { PluginManagerContext } from '../../context';
|
|
21
|
+
import { type ActivationEvent, type Plugin, PluginManager } from '../../core';
|
|
22
|
+
import { App, PluginManagerProvider } from '../components';
|
|
21
23
|
|
|
22
|
-
|
|
23
|
-
import { DefaultFallback } from './DefaultFallback';
|
|
24
|
-
import { ErrorBoundary } from './ErrorBoundary';
|
|
25
|
-
import { PluginManagerProvider } from './PluginManagerProvider';
|
|
24
|
+
const ENABLED_KEY = 'org.dxos.app-framework.enabled';
|
|
26
25
|
|
|
27
|
-
|
|
26
|
+
export type StartupProgress = {
|
|
27
|
+
/** Number of modules that have been activated. */
|
|
28
|
+
activated: number;
|
|
29
|
+
/** Total number of modules registered. */
|
|
30
|
+
total: number;
|
|
31
|
+
/** Fractional progress (0-1). */
|
|
32
|
+
progress: number;
|
|
33
|
+
/** Human-readable label for the currently activating module. */
|
|
34
|
+
status?: string;
|
|
35
|
+
};
|
|
36
|
+
|
|
37
|
+
export type PlaceholderProps = {
|
|
38
|
+
stage?: number;
|
|
39
|
+
progress?: StartupProgress;
|
|
40
|
+
};
|
|
28
41
|
|
|
29
42
|
export type UseAppOptions = {
|
|
30
43
|
pluginManager?: PluginManager.PluginManager;
|
|
@@ -32,12 +45,17 @@ export type UseAppOptions = {
|
|
|
32
45
|
plugins?: Plugin.Plugin[];
|
|
33
46
|
core?: string[];
|
|
34
47
|
defaults?: string[];
|
|
35
|
-
|
|
36
|
-
|
|
48
|
+
/**
|
|
49
|
+
* Additional activation events to fire before startup.
|
|
50
|
+
* These are fired alongside SetupReactSurface before the Startup event.
|
|
51
|
+
*/
|
|
52
|
+
setupEvents?: ActivationEvent.ActivationEvent[];
|
|
37
53
|
cacheEnabled?: boolean;
|
|
38
54
|
safeMode?: boolean;
|
|
39
55
|
debounce?: number;
|
|
40
56
|
timeout?: number;
|
|
57
|
+
fallback?: FC<FallbackProps>;
|
|
58
|
+
placeholder?: FC<PlaceholderProps>;
|
|
41
59
|
};
|
|
42
60
|
|
|
43
61
|
/**
|
|
@@ -60,10 +78,10 @@ export type UseAppOptions = {
|
|
|
60
78
|
* @param params.plugins All plugins available to the application.
|
|
61
79
|
* @param params.core Core plugins which will always be enabled.
|
|
62
80
|
* @param params.defaults Default plugins are enabled by default but can be disabled by the user.
|
|
63
|
-
* @param params.placeholder Placeholder component to render during startup.
|
|
64
|
-
* @param params.fallback Fallback component to render if an error occurs during startup.
|
|
65
81
|
* @param params.cacheEnabled Whether to cache enabled plugins in localStorage.
|
|
66
82
|
* @param params.safeMode Whether to enable safe mode, which disables optional plugins.
|
|
83
|
+
* @param params.fallback Fallback component to render if an error occurs during startup.
|
|
84
|
+
* @param params.placeholder Placeholder component to render during startup.
|
|
67
85
|
*/
|
|
68
86
|
export const useApp = ({
|
|
69
87
|
pluginManager,
|
|
@@ -71,8 +89,9 @@ export const useApp = ({
|
|
|
71
89
|
plugins: pluginsProp,
|
|
72
90
|
core: coreProp,
|
|
73
91
|
defaults: defaultsProp,
|
|
92
|
+
setupEvents: setupEventsProp,
|
|
74
93
|
placeholder,
|
|
75
|
-
fallback =
|
|
94
|
+
fallback = ErrorFallback,
|
|
76
95
|
cacheEnabled = false,
|
|
77
96
|
safeMode = false,
|
|
78
97
|
debounce = 0,
|
|
@@ -81,8 +100,8 @@ export const useApp = ({
|
|
|
81
100
|
const plugins = useDefaultValue(pluginsProp, () => []);
|
|
82
101
|
const core = useDefaultValue(coreProp, () => plugins.map(({ meta }) => meta.id));
|
|
83
102
|
const defaults = useDefaultValue(defaultsProp, () => []);
|
|
103
|
+
const setupEvents = useDefaultValue(setupEventsProp, () => []);
|
|
84
104
|
|
|
85
|
-
// TODO(wittjosiah): Provide a custom plugin loader which supports loading via url.
|
|
86
105
|
const pluginLoader = useMemo(
|
|
87
106
|
() =>
|
|
88
107
|
pluginLoaderProp ??
|
|
@@ -99,16 +118,23 @@ export const useApp = ({
|
|
|
99
118
|
const [ready, setReady] = useState(false);
|
|
100
119
|
const errorRef = useRef<unknown>(null);
|
|
101
120
|
const [error, setError] = useState<unknown>(null);
|
|
121
|
+
const [startupProgress, setStartupProgress] = useState<StartupProgress>({
|
|
122
|
+
activated: 0,
|
|
123
|
+
total: 0,
|
|
124
|
+
progress: 0,
|
|
125
|
+
});
|
|
102
126
|
// TODO(wittjosiah): Migrate to Atom.kvs for isomorphic storage.
|
|
103
127
|
const cached: string[] = useMemo(() => JSON.parse(localStorage.getItem(ENABLED_KEY) ?? '[]'), []);
|
|
104
128
|
const enabled = useMemo(
|
|
105
129
|
() => (safeMode ? [] : cacheEnabled && cached.length > 0 ? cached : defaults),
|
|
106
130
|
[safeMode, cacheEnabled, cached, defaults],
|
|
107
131
|
);
|
|
108
|
-
const
|
|
109
|
-
|
|
110
|
-
|
|
111
|
-
|
|
132
|
+
const isExternalManager = !!pluginManager;
|
|
133
|
+
const manager = useMemo(() => {
|
|
134
|
+
const mgr = pluginManager ?? PluginManager.make({ pluginLoader, plugins, core, enabled });
|
|
135
|
+
log('useApp: useMemo created/reused manager', { provided: !!pluginManager });
|
|
136
|
+
return mgr;
|
|
137
|
+
}, [pluginManager, pluginLoader, plugins, core, enabled]);
|
|
112
138
|
|
|
113
139
|
useEffect(() => {
|
|
114
140
|
if (!cacheEnabled) {
|
|
@@ -124,28 +150,52 @@ export const useApp = ({
|
|
|
124
150
|
}, [manager]);
|
|
125
151
|
|
|
126
152
|
useAsyncEffect(async () => {
|
|
153
|
+
log('useApp: effect mount');
|
|
154
|
+
|
|
127
155
|
manager.capabilities.contribute({
|
|
128
|
-
interface:
|
|
156
|
+
interface: Capabilities.PluginManager,
|
|
129
157
|
implementation: manager,
|
|
130
|
-
module: 'dxos.
|
|
158
|
+
module: 'org.dxos.app-framework.plugin-manager',
|
|
131
159
|
});
|
|
132
160
|
|
|
133
161
|
manager.capabilities.contribute({
|
|
134
|
-
interface:
|
|
162
|
+
interface: Capabilities.AtomRegistry,
|
|
135
163
|
implementation: manager.registry,
|
|
136
|
-
module: 'dxos.
|
|
164
|
+
module: 'org.dxos.app-framework.atom-registry',
|
|
137
165
|
});
|
|
138
166
|
|
|
167
|
+
// Poll manager atoms for progress (avoids PubSub subscription race).
|
|
168
|
+
const progressInterval = setInterval(() => {
|
|
169
|
+
if (readyRef.current) {
|
|
170
|
+
clearInterval(progressInterval);
|
|
171
|
+
return;
|
|
172
|
+
}
|
|
173
|
+
const active = manager.getActive();
|
|
174
|
+
const modules = manager.getModules();
|
|
175
|
+
const total = modules.length;
|
|
176
|
+
const activated = active.length;
|
|
177
|
+
const lastModule = active.length > 0 ? active[active.length - 1] : undefined;
|
|
178
|
+
setStartupProgress({
|
|
179
|
+
activated,
|
|
180
|
+
total,
|
|
181
|
+
progress: total > 0 ? activated / total : 0,
|
|
182
|
+
status: lastModule ? humanizeModuleId(lastModule) : undefined,
|
|
183
|
+
});
|
|
184
|
+
}, 100);
|
|
185
|
+
|
|
139
186
|
const fiber = Effect.gen(function* () {
|
|
140
187
|
const queue = yield* PubSub.subscribe(manager.activation);
|
|
141
188
|
const listener = yield* Effect.forkDaemon(
|
|
142
189
|
Queue.take(queue).pipe(
|
|
143
190
|
Effect.tap(({ event, state, error: error$ }) =>
|
|
144
191
|
Effect.sync(() => {
|
|
145
|
-
if (event ===
|
|
192
|
+
if (event === ActivationEvents.Startup.id && state === 'activated') {
|
|
146
193
|
clearTimeout(timeoutId);
|
|
194
|
+
clearInterval(progressInterval);
|
|
147
195
|
setReady(true);
|
|
148
196
|
readyRef.current = true;
|
|
197
|
+
// Trigger startup profiler dump if available.
|
|
198
|
+
(globalThis as any).composer?.profiler?.dump();
|
|
149
199
|
}
|
|
150
200
|
if (error$ && !readyRef.current) {
|
|
151
201
|
setError(error$);
|
|
@@ -158,9 +208,9 @@ export const useApp = ({
|
|
|
158
208
|
);
|
|
159
209
|
|
|
160
210
|
yield* Effect.all([
|
|
161
|
-
manager.activate(
|
|
162
|
-
manager.activate(
|
|
163
|
-
manager.activate(
|
|
211
|
+
...setupEvents.map((event) => manager.activate(event)),
|
|
212
|
+
manager.activate(ActivationEvents.SetupReactSurface),
|
|
213
|
+
manager.activate(ActivationEvents.Startup),
|
|
164
214
|
]);
|
|
165
215
|
|
|
166
216
|
return yield* Fiber.join(listener);
|
|
@@ -180,20 +230,29 @@ export const useApp = ({
|
|
|
180
230
|
}, timeout);
|
|
181
231
|
|
|
182
232
|
return () => {
|
|
233
|
+
log('useApp: effect cleanup');
|
|
183
234
|
clearTimeout(timeoutId);
|
|
235
|
+
clearInterval(progressInterval);
|
|
184
236
|
void runAndForwardErrors(Fiber.interrupt(fiber));
|
|
185
|
-
|
|
186
|
-
|
|
237
|
+
if (!isExternalManager) {
|
|
238
|
+
void runAndForwardErrors(manager.shutdown());
|
|
239
|
+
}
|
|
187
240
|
};
|
|
188
241
|
}, [manager]);
|
|
189
242
|
|
|
190
243
|
return useCallback(
|
|
191
244
|
() => (
|
|
192
|
-
<ErrorBoundary
|
|
245
|
+
<ErrorBoundary name='app' FallbackComponent={fallback}>
|
|
193
246
|
<PluginManagerProvider value={manager}>
|
|
194
247
|
<ContextProtocolProvider value={manager} context={PluginManagerContext}>
|
|
195
248
|
<RegistryContext.Provider value={manager.registry}>
|
|
196
|
-
<App
|
|
249
|
+
<App
|
|
250
|
+
placeholder={placeholder}
|
|
251
|
+
ready={ready}
|
|
252
|
+
error={error}
|
|
253
|
+
debounce={debounce}
|
|
254
|
+
progress={startupProgress}
|
|
255
|
+
/>
|
|
197
256
|
</RegistryContext.Provider>
|
|
198
257
|
</ContextProtocolProvider>
|
|
199
258
|
</PluginManagerProvider>
|
|
@@ -207,3 +266,24 @@ const setupDevtools = (manager: PluginManager.PluginManager) => {
|
|
|
207
266
|
(globalThis as any).composer ??= {};
|
|
208
267
|
(globalThis as any).composer.manager = manager;
|
|
209
268
|
};
|
|
269
|
+
|
|
270
|
+
/**
|
|
271
|
+
* Extracts a human-readable label from a module ID.
|
|
272
|
+
* E.g., "org.dxos.plugin.markdown.module.ReactSurface" → "Markdown".
|
|
273
|
+
*/
|
|
274
|
+
const humanizeModuleId = (moduleId: string): string => {
|
|
275
|
+
// Extract plugin name from pattern: org.dxos.plugin.<name>.module.<capability>
|
|
276
|
+
const pluginMatch = moduleId.match(/\.plugin\.([^.]+)\./);
|
|
277
|
+
if (pluginMatch) {
|
|
278
|
+
const name = pluginMatch[1];
|
|
279
|
+
// Convert kebab-case to title case.
|
|
280
|
+
return name
|
|
281
|
+
.split('-')
|
|
282
|
+
.map((word) => word.charAt(0).toUpperCase() + word.slice(1))
|
|
283
|
+
.join(' ');
|
|
284
|
+
}
|
|
285
|
+
|
|
286
|
+
// Fallback: use the last segment.
|
|
287
|
+
const parts = moduleId.split('.');
|
|
288
|
+
return parts[parts.length - 1];
|
|
289
|
+
};
|
|
@@ -7,10 +7,9 @@ import { useCallback } from 'react';
|
|
|
7
7
|
|
|
8
8
|
import { invariant } from '@dxos/invariant';
|
|
9
9
|
|
|
10
|
-
import
|
|
11
|
-
import { type Capability } from '
|
|
12
|
-
|
|
13
|
-
import { usePluginManager } from './PluginManagerProvider';
|
|
10
|
+
import { Capabilities } from '../../common';
|
|
11
|
+
import { type Capability } from '../../core';
|
|
12
|
+
import { usePluginManager } from '../components';
|
|
14
13
|
|
|
15
14
|
/**
|
|
16
15
|
* Hook to request capabilities from the plugin context.
|
|
@@ -50,7 +49,7 @@ export const useAtomCapability = <T>(atomCapability: Capability.InterfaceDef<Ato
|
|
|
50
49
|
export const useAtomCapabilityState = <T>(
|
|
51
50
|
atomCapability: Capability.InterfaceDef<Atom.Writable<T>>,
|
|
52
51
|
): [T, (fn: (current: T) => T) => void] => {
|
|
53
|
-
const registry = useCapability(
|
|
52
|
+
const registry = useCapability(Capabilities.AtomRegistry);
|
|
54
53
|
const atom = useCapability(atomCapability);
|
|
55
54
|
const value = useAtomValue(atom);
|
|
56
55
|
const update = useCallback(
|
|
@@ -61,3 +60,8 @@ export const useAtomCapabilityState = <T>(
|
|
|
61
60
|
);
|
|
62
61
|
return [value, update];
|
|
63
62
|
};
|
|
63
|
+
|
|
64
|
+
/**
|
|
65
|
+
* Hook to get the operation invoker capability.
|
|
66
|
+
*/
|
|
67
|
+
export const useOperationInvoker = (): Capabilities.OperationInvoker => useCapability(Capabilities.OperationInvoker);
|
|
@@ -5,17 +5,6 @@
|
|
|
5
5
|
import { type Atom, RegistryContext, useAtomValue } from '@effect-atom/atom-react';
|
|
6
6
|
import { useCallback, useContext } from 'react';
|
|
7
7
|
|
|
8
|
-
import * as Common from '../common';
|
|
9
|
-
|
|
10
|
-
import { useAtomCapability, useCapability } from './useCapabilities';
|
|
11
|
-
|
|
12
|
-
export const useOperationInvoker = (): Common.Capability.OperationInvoker =>
|
|
13
|
-
useCapability(Common.Capability.OperationInvoker);
|
|
14
|
-
|
|
15
|
-
export const useAppGraph = (): Common.Capability.AppGraph => useCapability(Common.Capability.AppGraph);
|
|
16
|
-
|
|
17
|
-
export const useLayout = (): Common.Capability.Layout => useAtomCapability(Common.Capability.Layout);
|
|
18
|
-
|
|
19
8
|
/**
|
|
20
9
|
* Hook to read and update a settings atom.
|
|
21
10
|
* Returns the current value and an update function.
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
//
|
|
2
|
+
// Copyright 2025 DXOS.org
|
|
3
|
+
//
|
|
4
|
+
|
|
5
|
+
import { useContext } from 'react';
|
|
6
|
+
|
|
7
|
+
import { raise } from '@dxos/debug';
|
|
8
|
+
|
|
9
|
+
import { Surface } from '../components';
|
|
10
|
+
|
|
11
|
+
export const useSurface = (): Surface.Context => {
|
|
12
|
+
return useContext(Surface.Context) ?? raise(new Error('Missing SurfaceContext'));
|
|
13
|
+
};
|