@dxos/app-framework 0.8.4-main.ae835ea → 0.8.4-main.bc674ce
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 -1
- package/.storybook/preview.mts +2 -2
- package/dist/lib/browser/app-graph-builder-M2VPYQC6.mjs +149 -0
- package/dist/lib/browser/app-graph-builder-M2VPYQC6.mjs.map +7 -0
- package/dist/lib/browser/capability-7PCNSWBT.mjs +33 -0
- package/dist/lib/browser/capability-7PCNSWBT.mjs.map +7 -0
- package/dist/lib/browser/capability-KP3PFEXD.mjs +31 -0
- package/dist/lib/browser/capability-KP3PFEXD.mjs.map +7 -0
- package/dist/lib/browser/chunk-6Y7PZV72.mjs +77 -0
- package/dist/lib/browser/chunk-6Y7PZV72.mjs.map +7 -0
- package/dist/lib/browser/chunk-7IQHKD4U.mjs +170 -0
- package/dist/lib/browser/chunk-7IQHKD4U.mjs.map +7 -0
- package/dist/lib/browser/chunk-BLQJSGL3.mjs +732 -0
- package/dist/lib/browser/chunk-BLQJSGL3.mjs.map +7 -0
- package/dist/lib/browser/chunk-FHQTHCX7.mjs +8 -0
- package/dist/lib/browser/chunk-FHQTHCX7.mjs.map +7 -0
- package/dist/lib/browser/chunk-FMZN33N4.mjs +807 -0
- package/dist/lib/browser/chunk-FMZN33N4.mjs.map +7 -0
- package/dist/lib/browser/chunk-H4WPA7U7.mjs +77 -0
- package/dist/lib/browser/chunk-H4WPA7U7.mjs.map +7 -0
- package/dist/lib/browser/chunk-J5LGTIGS.mjs +10 -0
- package/dist/lib/browser/chunk-PKQT6C53.mjs +47 -0
- package/dist/lib/browser/chunk-PKQT6C53.mjs.map +7 -0
- package/dist/lib/browser/chunk-TCLLRCS3.mjs +145 -0
- package/dist/lib/browser/chunk-TCLLRCS3.mjs.map +7 -0
- package/dist/lib/browser/chunk-XYNO72GQ.mjs +746 -0
- package/dist/lib/browser/chunk-XYNO72GQ.mjs.map +7 -0
- package/dist/lib/browser/common/index.mjs +38 -0
- package/dist/lib/browser/core/activation-event.mjs +20 -0
- package/dist/lib/browser/core/capability.mjs +28 -0
- package/dist/lib/browser/core/plugin-manager.mjs +15 -0
- package/dist/lib/browser/core/plugin-manager.mjs.map +7 -0
- package/dist/lib/browser/core/plugin.mjs +27 -0
- package/dist/lib/browser/core/plugin.mjs.map +7 -0
- package/dist/lib/browser/index.mjs +162 -128
- package/dist/lib/browser/index.mjs.map +4 -4
- package/dist/lib/browser/invoker-capability-SZRSTHEH.mjs +32 -0
- package/dist/lib/browser/invoker-capability-SZRSTHEH.mjs.map +7 -0
- package/dist/lib/browser/meta.json +1 -1
- package/dist/lib/browser/operation-resolver-6MP2MYOY.mjs +64 -0
- package/dist/lib/browser/operation-resolver-6MP2MYOY.mjs.map +7 -0
- package/dist/lib/browser/react/index.mjs +46 -0
- package/dist/lib/browser/react/index.mjs.map +7 -0
- package/dist/lib/browser/testing/index.mjs +68 -22
- package/dist/lib/browser/testing/index.mjs.map +4 -4
- package/dist/lib/node-esm/app-graph-builder-LROHGJEM.mjs +150 -0
- package/dist/lib/node-esm/app-graph-builder-LROHGJEM.mjs.map +7 -0
- package/dist/lib/node-esm/capability-CFLQ2QQU.mjs +34 -0
- package/dist/lib/node-esm/capability-CFLQ2QQU.mjs.map +7 -0
- package/dist/lib/node-esm/capability-RCUNM2M7.mjs +32 -0
- package/dist/lib/node-esm/capability-RCUNM2M7.mjs.map +7 -0
- package/dist/lib/node-esm/chunk-663A54LQ.mjs +171 -0
- package/dist/lib/node-esm/chunk-663A54LQ.mjs.map +7 -0
- package/dist/lib/node-esm/chunk-6WXBT3EC.mjs +747 -0
- package/dist/lib/node-esm/chunk-6WXBT3EC.mjs.map +7 -0
- package/dist/lib/node-esm/chunk-7OWSHPYK.mjs +48 -0
- package/dist/lib/node-esm/chunk-7OWSHPYK.mjs.map +7 -0
- package/dist/lib/node-esm/chunk-GQEBIGKD.mjs +733 -0
- package/dist/lib/node-esm/chunk-GQEBIGKD.mjs.map +7 -0
- package/dist/lib/node-esm/chunk-GT6OKM5I.mjs +146 -0
- package/dist/lib/node-esm/chunk-GT6OKM5I.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-STMXUEPO.mjs +78 -0
- package/dist/lib/node-esm/chunk-STMXUEPO.mjs.map +7 -0
- package/dist/lib/node-esm/chunk-UEWJDI2L.mjs +10 -0
- package/dist/lib/node-esm/chunk-UEWJDI2L.mjs.map +7 -0
- package/dist/lib/node-esm/chunk-XR6NMKEP.mjs +78 -0
- package/dist/lib/node-esm/chunk-XR6NMKEP.mjs.map +7 -0
- package/dist/lib/node-esm/chunk-XYQTBFPA.mjs +808 -0
- package/dist/lib/node-esm/chunk-XYQTBFPA.mjs.map +7 -0
- package/dist/lib/node-esm/common/index.mjs +39 -0
- package/dist/lib/node-esm/common/index.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 +29 -0
- package/dist/lib/node-esm/core/capability.mjs.map +7 -0
- package/dist/lib/node-esm/core/plugin-manager.mjs +16 -0
- package/dist/lib/node-esm/core/plugin-manager.mjs.map +7 -0
- package/dist/lib/node-esm/core/plugin.mjs +28 -0
- package/dist/lib/node-esm/core/plugin.mjs.map +7 -0
- package/dist/lib/node-esm/index.mjs +162 -128
- package/dist/lib/node-esm/index.mjs.map +4 -4
- package/dist/lib/node-esm/invoker-capability-PNMA5JOS.mjs +33 -0
- package/dist/lib/node-esm/invoker-capability-PNMA5JOS.mjs.map +7 -0
- package/dist/lib/node-esm/meta.json +1 -1
- package/dist/lib/node-esm/operation-resolver-7YWDMTNU.mjs +65 -0
- package/dist/lib/node-esm/operation-resolver-7YWDMTNU.mjs.map +7 -0
- package/dist/lib/node-esm/react/index.mjs +47 -0
- package/dist/lib/node-esm/react/index.mjs.map +7 -0
- package/dist/lib/node-esm/testing/index.mjs +68 -22
- package/dist/lib/node-esm/testing/index.mjs.map +4 -4
- package/dist/types/src/cli.d.ts +39 -0
- package/dist/types/src/cli.d.ts.map +1 -0
- package/dist/types/src/common/activation-event.d.ts +66 -0
- package/dist/types/src/common/activation-event.d.ts.map +1 -0
- package/dist/types/src/common/capability.d.ts +265 -0
- package/dist/types/src/common/capability.d.ts.map +1 -0
- package/dist/types/src/common/collaboration.d.ts +23 -17
- package/dist/types/src/common/collaboration.d.ts.map +1 -1
- package/dist/types/src/common/graph.d.ts +2 -2
- package/dist/types/src/common/graph.d.ts.map +1 -1
- package/dist/types/src/common/index.d.ts +4 -3
- package/dist/types/src/common/index.d.ts.map +1 -1
- package/dist/types/src/common/operations.d.ts +380 -0
- package/dist/types/src/common/operations.d.ts.map +1 -0
- package/dist/types/src/common/plugin.d.ts +201 -0
- package/dist/types/src/common/plugin.d.ts.map +1 -0
- package/dist/types/src/common/surface.d.ts +48 -13
- package/dist/types/src/common/surface.d.ts.map +1 -1
- package/dist/types/src/common/translations.d.ts +9 -0
- 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} +6 -6
- package/dist/types/src/core/activation-event.d.ts.map +1 -0
- package/dist/types/src/core/capability-manager.d.ts +43 -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 +150 -0
- package/dist/types/src/core/capability.d.ts.map +1 -0
- package/dist/types/src/core/index.d.ts +5 -4
- package/dist/types/src/core/index.d.ts.map +1 -1
- package/dist/types/src/core/plugin-manager.d.ts +66 -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.d.ts +92 -34
- package/dist/types/src/core/plugin.d.ts.map +1 -1
- package/dist/types/src/index.d.ts +5 -4
- package/dist/types/src/index.d.ts.map +1 -1
- package/dist/types/src/playground/debug/Debug.d.ts +4 -2
- package/dist/types/src/playground/debug/Debug.d.ts.map +1 -1
- package/dist/types/src/playground/debug/plugin.d.ts +2 -1
- package/dist/types/src/playground/debug/plugin.d.ts.map +1 -1
- package/dist/types/src/playground/generator/Main.d.ts +4 -2
- package/dist/types/src/playground/generator/Main.d.ts.map +1 -1
- package/dist/types/src/playground/generator/Toolbar.d.ts +4 -2
- package/dist/types/src/playground/generator/Toolbar.d.ts.map +1 -1
- package/dist/types/src/playground/generator/generator.d.ts +17 -5
- package/dist/types/src/playground/generator/generator.d.ts.map +1 -1
- package/dist/types/src/playground/generator/plugin.d.ts +2 -1
- package/dist/types/src/playground/generator/plugin.d.ts.map +1 -1
- package/dist/types/src/playground/layout/Layout.d.ts +4 -2
- package/dist/types/src/playground/layout/Layout.d.ts.map +1 -1
- package/dist/types/src/playground/layout/plugin.d.ts +2 -1
- package/dist/types/src/playground/layout/plugin.d.ts.map +1 -1
- package/dist/types/src/playground/logger/Toolbar.d.ts +4 -2
- package/dist/types/src/playground/logger/Toolbar.d.ts.map +1 -1
- package/dist/types/src/playground/logger/plugin.d.ts +2 -1
- package/dist/types/src/playground/logger/plugin.d.ts.map +1 -1
- package/dist/types/src/playground/logger/schema.d.ts +14 -0
- package/dist/types/src/playground/logger/schema.d.ts.map +1 -1
- package/dist/types/src/playground/playground.stories.d.ts.map +1 -1
- package/dist/types/src/plugin-operation/OperationPlugin.d.ts +3 -0
- package/dist/types/src/plugin-operation/OperationPlugin.d.ts.map +1 -0
- package/dist/types/src/plugin-operation/history/capability.d.ts +7 -0
- package/dist/types/src/plugin-operation/history/capability.d.ts.map +1 -0
- package/dist/types/src/plugin-operation/history/errors.d.ts +5 -0
- package/dist/types/src/plugin-operation/history/errors.d.ts.map +1 -0
- package/dist/types/src/plugin-operation/history/history-tracker.d.ts +18 -0
- package/dist/types/src/plugin-operation/history/history-tracker.d.ts.map +1 -0
- package/dist/types/src/plugin-operation/history/history-tracker.test.d.ts +2 -0
- package/dist/types/src/plugin-operation/history/history-tracker.test.d.ts.map +1 -0
- package/dist/types/src/plugin-operation/history/index.d.ts +6 -0
- package/dist/types/src/plugin-operation/history/index.d.ts.map +1 -0
- package/dist/types/src/plugin-operation/history/types.d.ts +13 -0
- package/dist/types/src/plugin-operation/history/types.d.ts.map +1 -0
- package/dist/types/src/plugin-operation/history/undo-mapping.d.ts +93 -0
- package/dist/types/src/plugin-operation/history/undo-mapping.d.ts.map +1 -0
- package/dist/types/src/plugin-operation/history/undo-registry.d.ts +23 -0
- package/dist/types/src/plugin-operation/history/undo-registry.d.ts.map +1 -0
- package/dist/types/src/plugin-operation/history/undo-registry.test.d.ts +2 -0
- package/dist/types/src/plugin-operation/history/undo-registry.test.d.ts.map +1 -0
- package/dist/types/src/plugin-operation/index.d.ts +3 -0
- package/dist/types/src/plugin-operation/index.d.ts.map +1 -0
- package/dist/types/src/plugin-operation/invoker-capability.d.ts +6 -0
- package/dist/types/src/plugin-operation/invoker-capability.d.ts.map +1 -0
- package/dist/types/src/plugin-operation/meta.d.ts +3 -0
- package/dist/types/src/plugin-operation/meta.d.ts.map +1 -0
- package/dist/types/src/plugin-operation/testing.d.ts +109 -0
- package/dist/types/src/plugin-operation/testing.d.ts.map +1 -0
- package/dist/types/src/plugin-runtime/RuntimePlugin.d.ts +3 -0
- package/dist/types/src/plugin-runtime/RuntimePlugin.d.ts.map +1 -0
- package/dist/types/src/plugin-runtime/capability.d.ts +6 -0
- package/dist/types/src/plugin-runtime/capability.d.ts.map +1 -0
- package/dist/types/src/plugin-runtime/index.d.ts +2 -0
- package/dist/types/src/plugin-runtime/index.d.ts.map +1 -0
- package/dist/types/src/plugin-runtime/meta.d.ts +3 -0
- package/dist/types/src/plugin-runtime/meta.d.ts.map +1 -0
- package/dist/types/src/plugin-settings/SettingsPlugin.d.ts +2 -1
- package/dist/types/src/plugin-settings/SettingsPlugin.d.ts.map +1 -1
- package/dist/types/src/plugin-settings/actions.d.ts +36 -0
- package/dist/types/src/plugin-settings/actions.d.ts.map +1 -1
- package/dist/types/src/plugin-settings/app-graph-builder.d.ts +4 -2
- package/dist/types/src/plugin-settings/app-graph-builder.d.ts.map +1 -1
- package/dist/types/src/plugin-settings/meta.d.ts +2 -2
- package/dist/types/src/plugin-settings/meta.d.ts.map +1 -1
- package/dist/types/src/plugin-settings/operation-resolver.d.ts +6 -0
- package/dist/types/src/plugin-settings/operation-resolver.d.ts.map +1 -0
- package/dist/types/src/react/App.d.ts +8 -0
- package/dist/types/src/react/App.d.ts.map +1 -0
- package/dist/types/src/react/App.stories.d.ts.map +1 -0
- package/dist/types/src/react/DefaultFallback.d.ts.map +1 -0
- package/dist/types/src/react/PluginManagerContext.stories.d.ts +13 -0
- package/dist/types/src/react/PluginManagerContext.stories.d.ts.map +1 -0
- package/dist/types/src/react/PluginManagerProvider.d.ts +2 -2
- package/dist/types/src/react/PluginManagerProvider.d.ts.map +1 -1
- package/dist/types/src/react/Surface.d.ts +8 -6
- package/dist/types/src/react/Surface.d.ts.map +1 -1
- package/dist/types/src/react/Surface.stories.d.ts +3 -6
- package/dist/types/src/react/Surface.stories.d.ts.map +1 -1
- package/dist/types/src/react/SurfaceInfo.d.ts +11 -0
- package/dist/types/src/react/SurfaceInfo.d.ts.map +1 -0
- package/dist/types/src/react/common.d.ts +13 -12
- package/dist/types/src/react/common.d.ts.map +1 -1
- package/dist/types/src/react/index.d.ts +3 -1
- package/dist/types/src/react/index.d.ts.map +1 -1
- package/dist/types/src/react/types.d.ts +12 -0
- package/dist/types/src/react/types.d.ts.map +1 -0
- package/dist/types/src/{components → react}/useApp.d.ts +7 -6
- package/dist/types/src/react/useApp.d.ts.map +1 -0
- package/dist/types/src/react/useCapabilities.d.ts +16 -3
- package/dist/types/src/react/useCapabilities.d.ts.map +1 -1
- package/dist/types/src/{components → react}/useLoading.d.ts +1 -2
- package/dist/types/src/react/useLoading.d.ts.map +1 -0
- package/dist/types/src/react/useOperationResolver.d.ts +19 -0
- package/dist/types/src/react/useOperationResolver.d.ts.map +1 -0
- package/dist/types/src/testing/index.d.ts +1 -0
- package/dist/types/src/testing/index.d.ts.map +1 -1
- 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 +4 -4
- package/dist/types/src/testing/withPluginManager.d.ts.map +1 -1
- package/dist/types/tsconfig.tsbuildinfo +1 -1
- package/moon.yml +6 -2
- package/package.json +101 -45
- package/src/cli.ts +107 -0
- package/src/common/activation-event.ts +99 -0
- package/src/common/capability.ts +343 -0
- package/src/common/collaboration.ts +23 -10
- package/src/common/graph.ts +2 -2
- package/src/common/index.ts +4 -3
- package/src/common/operations.ts +412 -0
- package/src/common/plugin.ts +364 -0
- package/src/common/surface.ts +56 -19
- package/src/common/translations.ts +20 -0
- package/src/context.ts +9 -0
- package/src/core/{events.ts → activation-event.ts} +5 -5
- package/src/core/capability-manager.test.ts +151 -0
- package/src/core/capability-manager.ts +171 -0
- package/src/core/capability.ts +236 -0
- package/src/core/index.ts +5 -4
- package/src/core/plugin-manager.test.ts +845 -0
- package/src/core/plugin-manager.ts +696 -0
- package/src/core/plugin.ts +221 -39
- package/src/index.ts +5 -4
- package/src/playground/debug/Debug.tsx +26 -16
- package/src/playground/debug/plugin.ts +8 -8
- package/src/playground/generator/Main.tsx +20 -11
- package/src/playground/generator/Toolbar.tsx +26 -16
- package/src/playground/generator/generator.ts +27 -27
- package/src/playground/generator/plugin.ts +11 -12
- package/src/playground/layout/Layout.tsx +11 -7
- package/src/playground/layout/plugin.ts +8 -8
- package/src/playground/logger/Toolbar.tsx +19 -16
- package/src/playground/logger/plugin.ts +24 -23
- package/src/playground/logger/schema.ts +10 -0
- package/src/playground/playground.stories.tsx +14 -6
- package/src/plugin-operation/OperationPlugin.ts +25 -0
- package/src/plugin-operation/history/capability.ts +37 -0
- package/src/plugin-operation/history/errors.ts +11 -0
- package/src/plugin-operation/history/history-tracker.test.ts +380 -0
- package/src/plugin-operation/history/history-tracker.ts +129 -0
- package/src/plugin-operation/history/index.ts +9 -0
- package/src/plugin-operation/history/types.ts +17 -0
- package/src/plugin-operation/history/undo-mapping.ts +132 -0
- package/src/plugin-operation/history/undo-registry.test.ts +73 -0
- package/src/plugin-operation/history/undo-registry.ts +54 -0
- package/src/plugin-operation/index.ts +6 -0
- package/src/plugin-operation/invoker-capability.ts +40 -0
- package/src/plugin-operation/meta.ts +11 -0
- package/src/plugin-operation/testing.ts +174 -0
- package/src/plugin-runtime/RuntimePlugin.ts +20 -0
- package/src/plugin-runtime/capability.ts +53 -0
- package/src/{components → plugin-runtime}/index.ts +1 -1
- package/src/plugin-runtime/meta.ts +11 -0
- package/src/plugin-settings/SettingsPlugin.ts +11 -26
- package/src/plugin-settings/actions.ts +39 -0
- package/src/plugin-settings/app-graph-builder.ts +122 -142
- package/src/plugin-settings/meta.ts +2 -2
- package/src/plugin-settings/operation-resolver.ts +55 -0
- package/src/plugin-settings/translations.ts +1 -1
- package/src/react/App.stories.tsx +63 -0
- package/src/{components → react}/App.tsx +11 -10
- package/src/{components → react}/DefaultFallback.tsx +1 -1
- package/src/react/PluginManagerContext.stories.tsx +184 -0
- package/src/react/PluginManagerProvider.ts +2 -2
- package/src/react/Surface.stories.tsx +91 -51
- package/src/react/Surface.tsx +226 -45
- package/src/react/SurfaceInfo.tsx +107 -0
- package/src/react/common.ts +29 -5
- package/src/react/index.ts +5 -1
- package/src/react/types.ts +27 -0
- package/src/react/useApp.tsx +209 -0
- package/src/react/useCapabilities.ts +37 -5
- package/src/{components → react}/useLoading.tsx +4 -6
- package/src/react/useOperationResolver.ts +40 -0
- package/src/testing/index.ts +1 -0
- package/src/testing/service.ts +52 -0
- package/src/testing/withPluginManager.stories.tsx +5 -5
- package/src/testing/withPluginManager.tsx +21 -23
- package/tsconfig.json +25 -7
- package/.swc/plugins/linux_x86_64_19.0.0/fce1bdb8e20a094e4af08bad09cc81497ed0e2e7c51223b07d371063cca18429.wasmer-v7 +0 -0
- package/dist/lib/browser/app-graph-builder-PSA3RESL.mjs +0 -138
- package/dist/lib/browser/app-graph-builder-PSA3RESL.mjs.map +0 -7
- package/dist/lib/browser/chunk-2VZ4RF4A.mjs +0 -1608
- package/dist/lib/browser/chunk-2VZ4RF4A.mjs.map +0 -7
- package/dist/lib/browser/chunk-CPVYIS24.mjs +0 -451
- package/dist/lib/browser/chunk-CPVYIS24.mjs.map +0 -7
- package/dist/lib/browser/chunk-SCPE4ZO2.mjs +0 -35
- package/dist/lib/browser/chunk-SCPE4ZO2.mjs.map +0 -7
- package/dist/lib/browser/intent-dispatcher-BND6IF4U.mjs +0 -11
- package/dist/lib/browser/intent-resolver-27FJAJDE.mjs +0 -39
- package/dist/lib/browser/intent-resolver-27FJAJDE.mjs.map +0 -7
- package/dist/lib/browser/store-F545UOIR.mjs +0 -30
- package/dist/lib/browser/store-F545UOIR.mjs.map +0 -7
- package/dist/lib/browser/worker.mjs +0 -77
- package/dist/lib/node-esm/app-graph-builder-VJGZ6KH7.mjs +0 -139
- package/dist/lib/node-esm/app-graph-builder-VJGZ6KH7.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-3RRWO5TD.mjs +0 -1610
- package/dist/lib/node-esm/chunk-3RRWO5TD.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-MN37WUJ2.mjs +0 -452
- package/dist/lib/node-esm/chunk-MN37WUJ2.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-ZX63QUGE.mjs +0 -37
- package/dist/lib/node-esm/chunk-ZX63QUGE.mjs.map +0 -7
- package/dist/lib/node-esm/intent-dispatcher-254AZ6EE.mjs +0 -12
- package/dist/lib/node-esm/intent-resolver-NPMOPNFL.mjs +0 -40
- package/dist/lib/node-esm/intent-resolver-NPMOPNFL.mjs.map +0 -7
- package/dist/lib/node-esm/store-CINC4R4L.mjs +0 -31
- package/dist/lib/node-esm/store-CINC4R4L.mjs.map +0 -7
- package/dist/lib/node-esm/worker.mjs +0 -78
- package/dist/types/src/common/capabilities.d.ts +0 -201
- package/dist/types/src/common/capabilities.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/layout.d.ts +0 -279
- package/dist/types/src/common/layout.d.ts.map +0 -1
- package/dist/types/src/components/App.d.ts +0 -10
- package/dist/types/src/components/App.d.ts.map +0 -1
- package/dist/types/src/components/App.stories.d.ts.map +0 -1
- package/dist/types/src/components/DefaultFallback.d.ts.map +0 -1
- package/dist/types/src/components/index.d.ts +0 -2
- package/dist/types/src/components/index.d.ts.map +0 -1
- package/dist/types/src/components/useApp.d.ts.map +0 -1
- package/dist/types/src/components/useLoading.d.ts.map +0 -1
- package/dist/types/src/core/capabilities.d.ts +0 -117
- 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/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 -36
- 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 -6
- 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-intent/meta.d.ts +0 -3
- package/dist/types/src/plugin-intent/meta.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/react/IntentContext.d.ts +0 -8
- package/dist/types/src/react/IntentContext.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/common/capabilities.ts +0 -217
- package/src/common/events.ts +0 -79
- package/src/common/layout.ts +0 -277
- package/src/components/App.stories.tsx +0 -33
- package/src/components/useApp.tsx +0 -164
- package/src/core/capabilities.test.ts +0 -136
- package/src/core/capabilities.ts +0 -263
- package/src/core/manager.test.ts +0 -516
- package/src/core/manager.ts +0 -604
- package/src/plugin-intent/IntentPlugin.ts +0 -20
- package/src/plugin-intent/actions.ts +0 -31
- package/src/plugin-intent/errors.ts +0 -40
- package/src/plugin-intent/index.ts +0 -9
- package/src/plugin-intent/intent-dispatcher.test.ts +0 -286
- package/src/plugin-intent/intent-dispatcher.ts +0 -337
- package/src/plugin-intent/intent.ts +0 -154
- package/src/plugin-intent/meta.ts +0 -10
- package/src/plugin-settings/intent-resolver.ts +0 -35
- package/src/plugin-settings/store.ts +0 -33
- package/src/react/IntentContext.tsx +0 -35
- package/src/react/useIntentResolver.ts +0 -22
- package/src/worker.ts +0 -11
- /package/dist/lib/browser/{intent-dispatcher-BND6IF4U.mjs.map → chunk-J5LGTIGS.mjs.map} +0 -0
- /package/dist/lib/browser/{worker.mjs.map → common/index.mjs.map} +0 -0
- /package/dist/lib/{node-esm/intent-dispatcher-254AZ6EE.mjs.map → browser/core/activation-event.mjs.map} +0 -0
- /package/dist/lib/{node-esm/worker.mjs.map → browser/core/capability.mjs.map} +0 -0
- /package/dist/types/src/{components → react}/App.stories.d.ts +0 -0
- /package/dist/types/src/{components → react}/DefaultFallback.d.ts +0 -0
package/src/core/manager.ts
DELETED
|
@@ -1,604 +0,0 @@
|
|
|
1
|
-
//
|
|
2
|
-
// Copyright 2025 DXOS.org
|
|
3
|
-
//
|
|
4
|
-
|
|
5
|
-
import { Registry } from '@effect-rx/rx-react';
|
|
6
|
-
import { untracked } from '@preact/signals-core';
|
|
7
|
-
import * as Array from 'effect/Array';
|
|
8
|
-
import * as Duration from 'effect/Duration';
|
|
9
|
-
import * as Effect from 'effect/Effect';
|
|
10
|
-
import * as Fiber from 'effect/Fiber';
|
|
11
|
-
import * as Function from 'effect/Function';
|
|
12
|
-
import * as HashSet from 'effect/HashSet';
|
|
13
|
-
import * as Match from 'effect/Match';
|
|
14
|
-
import * as Ref from 'effect/Ref';
|
|
15
|
-
|
|
16
|
-
import { Event } from '@dxos/async';
|
|
17
|
-
import { type Live, live } from '@dxos/live-object';
|
|
18
|
-
import { log } from '@dxos/log';
|
|
19
|
-
import { type MaybePromise } from '@dxos/util';
|
|
20
|
-
|
|
21
|
-
import { type AnyCapability, PluginContext } from './capabilities';
|
|
22
|
-
import { type ActivationEvent, eventKey, getEvents, isAllOf } from './events';
|
|
23
|
-
import { type Plugin, type PluginModule } from './plugin';
|
|
24
|
-
|
|
25
|
-
// TODO(wittjosiah): Factor out?
|
|
26
|
-
const isPromise = (value: unknown): value is Promise<unknown> => {
|
|
27
|
-
return value !== null && typeof value === 'object' && 'then' in value;
|
|
28
|
-
};
|
|
29
|
-
|
|
30
|
-
export type PluginManagerOptions = {
|
|
31
|
-
pluginLoader: (id: string) => MaybePromise<Plugin>;
|
|
32
|
-
plugins?: Plugin[];
|
|
33
|
-
core?: string[];
|
|
34
|
-
enabled?: string[];
|
|
35
|
-
registry?: Registry.Registry;
|
|
36
|
-
};
|
|
37
|
-
|
|
38
|
-
type PluginManagerState = {
|
|
39
|
-
// Plugins
|
|
40
|
-
plugins: Plugin[];
|
|
41
|
-
core: string[];
|
|
42
|
-
enabled: string[];
|
|
43
|
-
|
|
44
|
-
// Modules
|
|
45
|
-
modules: PluginModule[];
|
|
46
|
-
active: string[];
|
|
47
|
-
|
|
48
|
-
// Events
|
|
49
|
-
eventsFired: string[];
|
|
50
|
-
pendingReset: string[];
|
|
51
|
-
};
|
|
52
|
-
|
|
53
|
-
export class PluginManager {
|
|
54
|
-
readonly activation = new Event<{ event: string; state: 'activating' | 'activated' | 'error'; error?: any }>();
|
|
55
|
-
readonly context: PluginContext;
|
|
56
|
-
readonly registry: Registry.Registry;
|
|
57
|
-
|
|
58
|
-
// TODO(wittjosiah): Replace with Rx.
|
|
59
|
-
private readonly _state: Live<PluginManagerState>;
|
|
60
|
-
private readonly _pluginLoader: PluginManagerOptions['pluginLoader'];
|
|
61
|
-
private readonly _capabilities = new Map<string, AnyCapability[]>();
|
|
62
|
-
private readonly _moduleMemoMap = new Map<PluginModule['id'], Promise<AnyCapability[]>>();
|
|
63
|
-
private readonly _activatingEvents = Effect.runSync(Ref.make<string[]>([]));
|
|
64
|
-
private readonly _activatingModules = Effect.runSync(Ref.make<string[]>([]));
|
|
65
|
-
|
|
66
|
-
constructor({
|
|
67
|
-
pluginLoader,
|
|
68
|
-
plugins = [],
|
|
69
|
-
core = plugins.map(({ meta }) => meta.id),
|
|
70
|
-
enabled = [],
|
|
71
|
-
registry,
|
|
72
|
-
}: PluginManagerOptions) {
|
|
73
|
-
this.registry = registry ?? Registry.make();
|
|
74
|
-
this.context = new PluginContext({
|
|
75
|
-
registry: this.registry,
|
|
76
|
-
activate: (event) => this._activate(event),
|
|
77
|
-
reset: (id) => this._reset(id),
|
|
78
|
-
});
|
|
79
|
-
|
|
80
|
-
this._pluginLoader = pluginLoader;
|
|
81
|
-
this._state = live({
|
|
82
|
-
plugins,
|
|
83
|
-
core,
|
|
84
|
-
enabled,
|
|
85
|
-
modules: [],
|
|
86
|
-
active: [],
|
|
87
|
-
eventsFired: [],
|
|
88
|
-
pendingReset: [],
|
|
89
|
-
});
|
|
90
|
-
plugins.forEach((plugin) => this._addPlugin(plugin));
|
|
91
|
-
core.forEach((id) => this.enable(id));
|
|
92
|
-
enabled.forEach((id) => this.enable(id));
|
|
93
|
-
}
|
|
94
|
-
|
|
95
|
-
/**
|
|
96
|
-
* Plugins that are currently registered.
|
|
97
|
-
*
|
|
98
|
-
* @reactive
|
|
99
|
-
*/
|
|
100
|
-
get plugins(): Live<readonly Plugin[]> {
|
|
101
|
-
return this._state.plugins;
|
|
102
|
-
}
|
|
103
|
-
|
|
104
|
-
/**
|
|
105
|
-
* Ids of plugins that are core and cannot be removed.
|
|
106
|
-
*
|
|
107
|
-
* @reactive
|
|
108
|
-
*/
|
|
109
|
-
get core(): Live<readonly string[]> {
|
|
110
|
-
return this._state.core;
|
|
111
|
-
}
|
|
112
|
-
|
|
113
|
-
/**
|
|
114
|
-
* Ids of plugins that are currently enabled.
|
|
115
|
-
*
|
|
116
|
-
* @reactive
|
|
117
|
-
*/
|
|
118
|
-
get enabled(): Live<readonly string[]> {
|
|
119
|
-
return this._state.enabled;
|
|
120
|
-
}
|
|
121
|
-
|
|
122
|
-
/**
|
|
123
|
-
* Modules of plugins which are currently enabled.
|
|
124
|
-
*
|
|
125
|
-
* @reactive
|
|
126
|
-
*/
|
|
127
|
-
get modules(): Live<readonly PluginModule[]> {
|
|
128
|
-
return this._state.modules;
|
|
129
|
-
}
|
|
130
|
-
|
|
131
|
-
/**
|
|
132
|
-
* Ids of modules which are currently active.
|
|
133
|
-
*
|
|
134
|
-
* @reactive
|
|
135
|
-
*/
|
|
136
|
-
get active(): Live<readonly string[]> {
|
|
137
|
-
return this._state.active;
|
|
138
|
-
}
|
|
139
|
-
|
|
140
|
-
/**
|
|
141
|
-
* Ids of events which have been fired.
|
|
142
|
-
*
|
|
143
|
-
* @reactive
|
|
144
|
-
*/
|
|
145
|
-
get eventsFired(): Live<readonly string[]> {
|
|
146
|
-
return this._state.eventsFired;
|
|
147
|
-
}
|
|
148
|
-
|
|
149
|
-
/**
|
|
150
|
-
* Ids of modules which are pending reset.
|
|
151
|
-
*
|
|
152
|
-
* @reactive
|
|
153
|
-
*/
|
|
154
|
-
get pendingReset(): Live<readonly string[]> {
|
|
155
|
-
return this._state.pendingReset;
|
|
156
|
-
}
|
|
157
|
-
|
|
158
|
-
/**
|
|
159
|
-
* Adds a plugin to the manager via the plugin loader.
|
|
160
|
-
* @param id The id of the plugin.
|
|
161
|
-
*/
|
|
162
|
-
async add(id: string): Promise<boolean> {
|
|
163
|
-
return untracked(async () => {
|
|
164
|
-
log('add plugin', { id });
|
|
165
|
-
const plugin = await this._pluginLoader(id);
|
|
166
|
-
this._addPlugin(plugin);
|
|
167
|
-
return this.enable(id);
|
|
168
|
-
});
|
|
169
|
-
}
|
|
170
|
-
|
|
171
|
-
/**
|
|
172
|
-
* Enables a plugin.
|
|
173
|
-
* @param id The id of the plugin.
|
|
174
|
-
*/
|
|
175
|
-
enable(id: string): Promise<boolean> {
|
|
176
|
-
return untracked(async () => {
|
|
177
|
-
log('enable plugin', { id });
|
|
178
|
-
const plugin = this._getPlugin(id);
|
|
179
|
-
if (!plugin) {
|
|
180
|
-
return false;
|
|
181
|
-
}
|
|
182
|
-
|
|
183
|
-
if (!this._state.enabled.includes(id)) {
|
|
184
|
-
this._state.enabled.push(id);
|
|
185
|
-
}
|
|
186
|
-
|
|
187
|
-
plugin.modules.forEach((module) => {
|
|
188
|
-
this._addModule(module);
|
|
189
|
-
this._setPendingResetByModule(module);
|
|
190
|
-
});
|
|
191
|
-
|
|
192
|
-
log('pending reset', { events: [...this.pendingReset] });
|
|
193
|
-
await Effect.runPromise(
|
|
194
|
-
Effect.all(
|
|
195
|
-
this.pendingReset.map((event) => this._activate(event)),
|
|
196
|
-
{ concurrency: 'unbounded' },
|
|
197
|
-
),
|
|
198
|
-
);
|
|
199
|
-
|
|
200
|
-
return true;
|
|
201
|
-
});
|
|
202
|
-
}
|
|
203
|
-
|
|
204
|
-
/**
|
|
205
|
-
* Removes a plugin from the manager.
|
|
206
|
-
* @param id The id of the plugin.
|
|
207
|
-
*/
|
|
208
|
-
remove(id: string): boolean {
|
|
209
|
-
return untracked(() => {
|
|
210
|
-
log('remove plugin', { id });
|
|
211
|
-
const result = this.disable(id);
|
|
212
|
-
if (!result) {
|
|
213
|
-
return false;
|
|
214
|
-
}
|
|
215
|
-
|
|
216
|
-
this._removePlugin(id);
|
|
217
|
-
return true;
|
|
218
|
-
});
|
|
219
|
-
}
|
|
220
|
-
|
|
221
|
-
/**
|
|
222
|
-
* Disables a plugin.
|
|
223
|
-
* @param id The id of the plugin.
|
|
224
|
-
*/
|
|
225
|
-
disable(id: string): Promise<boolean> {
|
|
226
|
-
return untracked(async () => {
|
|
227
|
-
log('disable plugin', { id });
|
|
228
|
-
if (this._state.core.includes(id)) {
|
|
229
|
-
return false;
|
|
230
|
-
}
|
|
231
|
-
|
|
232
|
-
const plugin = this._getPlugin(id);
|
|
233
|
-
if (!plugin) {
|
|
234
|
-
return false;
|
|
235
|
-
}
|
|
236
|
-
|
|
237
|
-
const enabledIndex = this._state.enabled.findIndex((enabled) => enabled === id);
|
|
238
|
-
if (enabledIndex !== -1) {
|
|
239
|
-
this._state.enabled.splice(enabledIndex, 1);
|
|
240
|
-
await Effect.runPromise(this._deactivate(id));
|
|
241
|
-
|
|
242
|
-
plugin.modules.forEach((module) => {
|
|
243
|
-
this._removeModule(module.id);
|
|
244
|
-
});
|
|
245
|
-
}
|
|
246
|
-
|
|
247
|
-
return true;
|
|
248
|
-
});
|
|
249
|
-
}
|
|
250
|
-
|
|
251
|
-
/**
|
|
252
|
-
* Activates plugins based on the activation event.
|
|
253
|
-
* @param event The activation event.
|
|
254
|
-
* @returns Whether the activation was successful.
|
|
255
|
-
*/
|
|
256
|
-
activate(event: ActivationEvent | string): Promise<boolean> {
|
|
257
|
-
return untracked(() => Effect.runPromise(this._activate(event)));
|
|
258
|
-
}
|
|
259
|
-
|
|
260
|
-
/**
|
|
261
|
-
* Deactivates all of the modules for a plugin.
|
|
262
|
-
* @param id The id of the plugin.
|
|
263
|
-
* @returns Whether the deactivation was successful.
|
|
264
|
-
*/
|
|
265
|
-
deactivate(id: string): Promise<boolean> {
|
|
266
|
-
return untracked(() => Effect.runPromise(this._deactivate(id)));
|
|
267
|
-
}
|
|
268
|
-
|
|
269
|
-
/**
|
|
270
|
-
* Re-activates the modules that were activated by the event.
|
|
271
|
-
* @param event The activation event.
|
|
272
|
-
* @returns Whether the reset was successful.
|
|
273
|
-
*/
|
|
274
|
-
reset(event: ActivationEvent | string): Promise<boolean> {
|
|
275
|
-
return untracked(() => Effect.runPromise(this._reset(event)));
|
|
276
|
-
}
|
|
277
|
-
|
|
278
|
-
private _addPlugin(plugin: Plugin): void {
|
|
279
|
-
untracked(() => {
|
|
280
|
-
log('add plugin', { id: plugin.meta.id });
|
|
281
|
-
// TODO(wittjosiah): Find a way to add a warning for duplicate plugins that doesn't cause log spam.
|
|
282
|
-
if (!this._state.plugins.includes(plugin)) {
|
|
283
|
-
this._state.plugins.push(plugin);
|
|
284
|
-
}
|
|
285
|
-
});
|
|
286
|
-
}
|
|
287
|
-
|
|
288
|
-
private _removePlugin(id: string): void {
|
|
289
|
-
untracked(() => {
|
|
290
|
-
log('remove plugin', { id });
|
|
291
|
-
const pluginIndex = this._state.plugins.findIndex((plugin) => plugin.meta.id === id);
|
|
292
|
-
if (pluginIndex !== -1) {
|
|
293
|
-
this._state.plugins.splice(pluginIndex, 1);
|
|
294
|
-
}
|
|
295
|
-
});
|
|
296
|
-
}
|
|
297
|
-
|
|
298
|
-
private _addModule(module: PluginModule): void {
|
|
299
|
-
untracked(() => {
|
|
300
|
-
log('add module', { id: module.id });
|
|
301
|
-
// TODO(wittjosiah): Find a way to add a warning for duplicate modules that doesn't cause log spam.
|
|
302
|
-
if (!this._state.modules.includes(module)) {
|
|
303
|
-
this._state.modules.push(module);
|
|
304
|
-
}
|
|
305
|
-
});
|
|
306
|
-
}
|
|
307
|
-
|
|
308
|
-
private _removeModule(id: string): void {
|
|
309
|
-
untracked(() => {
|
|
310
|
-
log('remove module', { id });
|
|
311
|
-
const moduleIndex = this._state.modules.findIndex((module) => module.id === id);
|
|
312
|
-
if (moduleIndex !== -1) {
|
|
313
|
-
this._state.modules.splice(moduleIndex, 1);
|
|
314
|
-
}
|
|
315
|
-
});
|
|
316
|
-
}
|
|
317
|
-
|
|
318
|
-
private _getPlugin(id: string): Plugin | undefined {
|
|
319
|
-
return this._state.plugins.find((plugin) => plugin.meta.id === id);
|
|
320
|
-
}
|
|
321
|
-
|
|
322
|
-
private _getActiveModules(): PluginModule[] {
|
|
323
|
-
return this._state.modules.filter((module) => this._state.active.includes(module.id));
|
|
324
|
-
}
|
|
325
|
-
|
|
326
|
-
private _getInactiveModules(): PluginModule[] {
|
|
327
|
-
return this._state.modules.filter((module) => !this._state.active.includes(module.id));
|
|
328
|
-
}
|
|
329
|
-
|
|
330
|
-
private _getActiveModulesByEvent(key: string): PluginModule[] {
|
|
331
|
-
return this._getActiveModules().filter((module) => getEvents(module.activatesOn).map(eventKey).includes(key));
|
|
332
|
-
}
|
|
333
|
-
|
|
334
|
-
private _getInactiveModulesByEvent(key: string): PluginModule[] {
|
|
335
|
-
return this._getInactiveModules().filter((module) => getEvents(module.activatesOn).map(eventKey).includes(key));
|
|
336
|
-
}
|
|
337
|
-
|
|
338
|
-
private _setPendingResetByModule(module: PluginModule): void {
|
|
339
|
-
return untracked(() => {
|
|
340
|
-
const activationEvents = getEvents(module.activatesOn)
|
|
341
|
-
.map(eventKey)
|
|
342
|
-
.filter((key) => this._state.eventsFired.includes(key));
|
|
343
|
-
|
|
344
|
-
const pendingReset = Array.fromIterable(new Set(activationEvents)).filter(
|
|
345
|
-
(event) => !this._state.pendingReset.includes(event),
|
|
346
|
-
);
|
|
347
|
-
if (pendingReset.length > 0) {
|
|
348
|
-
log('pending reset', { events: pendingReset });
|
|
349
|
-
this._state.pendingReset.push(...pendingReset);
|
|
350
|
-
}
|
|
351
|
-
});
|
|
352
|
-
}
|
|
353
|
-
|
|
354
|
-
/**
|
|
355
|
-
* @internal
|
|
356
|
-
*/
|
|
357
|
-
// TODO(wittjosiah): Improve error typing.
|
|
358
|
-
_activate(
|
|
359
|
-
event: ActivationEvent | string,
|
|
360
|
-
params?: { before?: string; after?: string },
|
|
361
|
-
): Effect.Effect<boolean, Error> {
|
|
362
|
-
return Effect.gen(this, function* () {
|
|
363
|
-
const key = typeof event === 'string' ? event : eventKey(event);
|
|
364
|
-
log('activating', { key, ...params });
|
|
365
|
-
yield* Ref.update(this._activatingEvents, (activating) => Array.append(activating, key));
|
|
366
|
-
const pendingIndex = this._state.pendingReset.findIndex((event) => event === key);
|
|
367
|
-
if (pendingIndex !== -1) {
|
|
368
|
-
this._state.pendingReset.splice(pendingIndex, 1);
|
|
369
|
-
}
|
|
370
|
-
|
|
371
|
-
const activatingEvents = yield* this._activatingEvents;
|
|
372
|
-
const activatingModules = yield* this._activatingModules;
|
|
373
|
-
const modules = this._getInactiveModulesByEvent(key).filter((module) => {
|
|
374
|
-
const allOf = isAllOf(module.activatesOn);
|
|
375
|
-
if (!allOf) {
|
|
376
|
-
return true;
|
|
377
|
-
}
|
|
378
|
-
|
|
379
|
-
// Check to see if all of the events in the `allOf` have been fired.
|
|
380
|
-
// An event can be considered "fired" if it is in the `eventsFired` list or if it is currently being activated.
|
|
381
|
-
const events = module.activatesOn.events.filter((event) => eventKey(event) !== key);
|
|
382
|
-
return (
|
|
383
|
-
events.every(
|
|
384
|
-
(event) => this._state.eventsFired.includes(eventKey(event)) || activatingEvents.includes(eventKey(event)),
|
|
385
|
-
) && !activatingModules.includes(module.id)
|
|
386
|
-
);
|
|
387
|
-
});
|
|
388
|
-
yield* Ref.update(this._activatingModules, (activating) =>
|
|
389
|
-
Array.appendAll(
|
|
390
|
-
activating,
|
|
391
|
-
modules.map((module) => module.id),
|
|
392
|
-
),
|
|
393
|
-
);
|
|
394
|
-
if (modules.length === 0) {
|
|
395
|
-
log('no modules to activate', { key });
|
|
396
|
-
if (!this._state.eventsFired.includes(key)) {
|
|
397
|
-
this._state.eventsFired.push(key);
|
|
398
|
-
}
|
|
399
|
-
return false;
|
|
400
|
-
}
|
|
401
|
-
|
|
402
|
-
log('activating modules', { key, modules: modules.map((module) => module.id) });
|
|
403
|
-
this.activation.emit({ event: key, state: 'activating' });
|
|
404
|
-
|
|
405
|
-
// Fire activatesBefore events.
|
|
406
|
-
yield* Function.pipe(
|
|
407
|
-
modules,
|
|
408
|
-
Array.flatMap((module) => module.activatesBefore ?? []),
|
|
409
|
-
HashSet.fromIterable,
|
|
410
|
-
HashSet.toValues,
|
|
411
|
-
Array.filter((event) => !activatingEvents.includes(eventKey(event))),
|
|
412
|
-
Array.map((event) => this._activate(event, { before: key })),
|
|
413
|
-
Effect.allWith({ concurrency: 'unbounded' }),
|
|
414
|
-
);
|
|
415
|
-
|
|
416
|
-
// Concurrently triggers loading of lazy capabilities.
|
|
417
|
-
const getCapabilities = yield* Function.pipe(
|
|
418
|
-
modules,
|
|
419
|
-
Array.map((mod) => this._loadModule(mod)),
|
|
420
|
-
Effect.allWith({ concurrency: 'unbounded' }),
|
|
421
|
-
Effect.catchAll((error) => {
|
|
422
|
-
this.activation.emit({ event: key, state: 'error', error });
|
|
423
|
-
return Effect.fail(error);
|
|
424
|
-
}),
|
|
425
|
-
);
|
|
426
|
-
|
|
427
|
-
// Contribute the capabilities from the activated modules.
|
|
428
|
-
yield* Function.pipe(
|
|
429
|
-
modules,
|
|
430
|
-
Array.zip(getCapabilities),
|
|
431
|
-
Array.map(([module, capabilities]) => this._contributeCapabilities(module, capabilities)),
|
|
432
|
-
// TODO(wittjosiah): This currently can't be run in parallel.
|
|
433
|
-
// Running this with concurrency causes races with `allOf` activation events.
|
|
434
|
-
Effect.all,
|
|
435
|
-
);
|
|
436
|
-
|
|
437
|
-
// Fire activatesAfter events.
|
|
438
|
-
yield* Function.pipe(
|
|
439
|
-
modules,
|
|
440
|
-
Array.flatMap((module) => module.activatesAfter ?? []),
|
|
441
|
-
HashSet.fromIterable,
|
|
442
|
-
HashSet.toValues,
|
|
443
|
-
Array.filter((event) => !activatingEvents.includes(eventKey(event))),
|
|
444
|
-
Array.map((event) => this._activate(event, { after: key })),
|
|
445
|
-
Effect.allWith({ concurrency: 'unbounded' }),
|
|
446
|
-
);
|
|
447
|
-
|
|
448
|
-
yield* Ref.update(this._activatingEvents, (activating) => Array.filter(activating, (event) => event !== key));
|
|
449
|
-
yield* Ref.update(this._activatingModules, (activating) =>
|
|
450
|
-
Array.filter(activating, (module) => !modules.map((module) => module.id).includes(module)),
|
|
451
|
-
);
|
|
452
|
-
|
|
453
|
-
if (!this._state.eventsFired.includes(key)) {
|
|
454
|
-
this._state.eventsFired.push(key);
|
|
455
|
-
}
|
|
456
|
-
|
|
457
|
-
this.activation.emit({ event: key, state: 'activated' });
|
|
458
|
-
log('activated', { key });
|
|
459
|
-
|
|
460
|
-
return true;
|
|
461
|
-
});
|
|
462
|
-
}
|
|
463
|
-
|
|
464
|
-
// Memoized with _moduleMemoMap
|
|
465
|
-
private _loadModule = (mod: PluginModule): Effect.Effect<AnyCapability[], Error> =>
|
|
466
|
-
Effect.tryPromise({
|
|
467
|
-
try: async () => {
|
|
468
|
-
const entry = this._moduleMemoMap.get(mod.id);
|
|
469
|
-
if (entry) {
|
|
470
|
-
return entry;
|
|
471
|
-
}
|
|
472
|
-
|
|
473
|
-
const promise = (async () => {
|
|
474
|
-
const start = performance.now();
|
|
475
|
-
let failed = false;
|
|
476
|
-
try {
|
|
477
|
-
log('loading module', { module: mod.id });
|
|
478
|
-
// TODO(wittjosiah): Support activation with an effect.
|
|
479
|
-
let activationResult = await mod.activate(this.context);
|
|
480
|
-
if (typeof activationResult === 'function') {
|
|
481
|
-
activationResult = await activationResult();
|
|
482
|
-
}
|
|
483
|
-
return Array.isArray(activationResult) ? activationResult : [activationResult];
|
|
484
|
-
} catch (error) {
|
|
485
|
-
failed = true;
|
|
486
|
-
throw error;
|
|
487
|
-
} finally {
|
|
488
|
-
performance.measure('activate-module', {
|
|
489
|
-
start,
|
|
490
|
-
end: performance.now(),
|
|
491
|
-
detail: {
|
|
492
|
-
module: mod.id,
|
|
493
|
-
},
|
|
494
|
-
});
|
|
495
|
-
log('loaded module', { module: mod.id, elapsed: performance.now() - start, failed });
|
|
496
|
-
}
|
|
497
|
-
})();
|
|
498
|
-
this._moduleMemoMap.set(mod.id, promise);
|
|
499
|
-
return promise;
|
|
500
|
-
},
|
|
501
|
-
catch: (error) => error as Error,
|
|
502
|
-
}).pipe(
|
|
503
|
-
Effect.withSpan('PluginManager._loadModule'),
|
|
504
|
-
together(
|
|
505
|
-
Effect.sleep(Duration.seconds(10)).pipe(
|
|
506
|
-
Effect.andThen(Effect.sync(() => log.warn(`module is taking a long time to activate`, { module: mod.id }))),
|
|
507
|
-
),
|
|
508
|
-
),
|
|
509
|
-
);
|
|
510
|
-
|
|
511
|
-
private _contributeCapabilities(module: PluginModule, capabilities: AnyCapability[]): Effect.Effect<void, Error> {
|
|
512
|
-
return Effect.gen(this, function* () {
|
|
513
|
-
capabilities.forEach((capability) => {
|
|
514
|
-
this.context.contributeCapability({ module: module.id, ...capability });
|
|
515
|
-
});
|
|
516
|
-
this._state.active.push(module.id);
|
|
517
|
-
this._capabilities.set(module.id, capabilities);
|
|
518
|
-
});
|
|
519
|
-
}
|
|
520
|
-
|
|
521
|
-
private _deactivate(id: string): Effect.Effect<boolean, Error> {
|
|
522
|
-
return Effect.gen(this, function* () {
|
|
523
|
-
const plugin = this._getPlugin(id);
|
|
524
|
-
if (!plugin) {
|
|
525
|
-
return false;
|
|
526
|
-
}
|
|
527
|
-
|
|
528
|
-
const modules = plugin.modules;
|
|
529
|
-
const results = yield* Effect.all(
|
|
530
|
-
modules.map((module) => this._deactivateModule(module)),
|
|
531
|
-
{ concurrency: 'unbounded' },
|
|
532
|
-
);
|
|
533
|
-
return results.every((result) => result);
|
|
534
|
-
});
|
|
535
|
-
}
|
|
536
|
-
|
|
537
|
-
private _deactivateModule(module: PluginModule): Effect.Effect<boolean, Error> {
|
|
538
|
-
return Effect.gen(this, function* () {
|
|
539
|
-
const id = module.id;
|
|
540
|
-
log('deactivating', { id });
|
|
541
|
-
this._moduleMemoMap.delete(id);
|
|
542
|
-
|
|
543
|
-
const capabilities = this._capabilities.get(id);
|
|
544
|
-
if (capabilities) {
|
|
545
|
-
for (const capability of capabilities) {
|
|
546
|
-
this.context.removeCapability(capability.interface, capability.implementation);
|
|
547
|
-
const program = capability.deactivate?.();
|
|
548
|
-
yield* Match.value(program).pipe(
|
|
549
|
-
Match.when(Effect.isEffect, (effect) => effect),
|
|
550
|
-
Match.when(isPromise, (promise) =>
|
|
551
|
-
Effect.tryPromise({
|
|
552
|
-
try: () => promise,
|
|
553
|
-
catch: (error) => error as Error,
|
|
554
|
-
}),
|
|
555
|
-
),
|
|
556
|
-
Match.orElse((program) => Effect.succeed(program)),
|
|
557
|
-
);
|
|
558
|
-
}
|
|
559
|
-
this._capabilities.delete(id);
|
|
560
|
-
}
|
|
561
|
-
|
|
562
|
-
const activeIndex = this._state.active.findIndex((event) => event === id);
|
|
563
|
-
if (activeIndex !== -1) {
|
|
564
|
-
this._state.active.splice(activeIndex, 1);
|
|
565
|
-
}
|
|
566
|
-
|
|
567
|
-
log('deactivated', { id });
|
|
568
|
-
return true;
|
|
569
|
-
});
|
|
570
|
-
}
|
|
571
|
-
|
|
572
|
-
private _reset(event: ActivationEvent | string): Effect.Effect<boolean, Error> {
|
|
573
|
-
return Effect.gen(this, function* () {
|
|
574
|
-
const key = typeof event === 'string' ? event : eventKey(event);
|
|
575
|
-
log('reset', { key });
|
|
576
|
-
const modules = this._getActiveModulesByEvent(key);
|
|
577
|
-
const results = yield* Effect.all(
|
|
578
|
-
modules.map((module) => this._deactivateModule(module)),
|
|
579
|
-
{ concurrency: 'unbounded' },
|
|
580
|
-
);
|
|
581
|
-
|
|
582
|
-
if (results.every((result) => result)) {
|
|
583
|
-
return yield* this._activate(key);
|
|
584
|
-
} else {
|
|
585
|
-
return false;
|
|
586
|
-
}
|
|
587
|
-
});
|
|
588
|
-
}
|
|
589
|
-
}
|
|
590
|
-
|
|
591
|
-
/**
|
|
592
|
-
* Runs an effect concurrently with another effect.
|
|
593
|
-
* If the first effect completes, the second effect is interrupted.
|
|
594
|
-
*/
|
|
595
|
-
// TODO(dmaretskyi): Effect.race > Effect.asVoid
|
|
596
|
-
const together =
|
|
597
|
-
<R1>(togetherEffect: Effect.Effect<void, never, R1>) =>
|
|
598
|
-
<A, E, R2>(effect: Effect.Effect<A, E, R2>): Effect.Effect<A, E, R1 | R2> =>
|
|
599
|
-
Effect.gen(function* () {
|
|
600
|
-
const togetherFiber = yield* Effect.fork(togetherEffect);
|
|
601
|
-
const result = yield* effect;
|
|
602
|
-
yield* Fiber.interrupt(togetherFiber);
|
|
603
|
-
return result;
|
|
604
|
-
});
|
|
@@ -1,20 +0,0 @@
|
|
|
1
|
-
//
|
|
2
|
-
// Copyright 2025 DXOS.org
|
|
3
|
-
//
|
|
4
|
-
|
|
5
|
-
import { Events } from '../common';
|
|
6
|
-
import { defineModule, definePlugin, lazy } from '../core';
|
|
7
|
-
|
|
8
|
-
import { meta } from './meta';
|
|
9
|
-
|
|
10
|
-
export const IntentPlugin = definePlugin(meta, () => [
|
|
11
|
-
defineModule({
|
|
12
|
-
id: `${meta.id}/module/dispatcher`,
|
|
13
|
-
// TODO(wittjosiah): This will mean that startup needs to be reset when intents are added or removed.
|
|
14
|
-
// This is fine for now because it's how it worked prior to capabilities api anyways.
|
|
15
|
-
// In the future, the intent dispatcher should be able to be reset without resetting the entire app.
|
|
16
|
-
activatesOn: Events.Startup,
|
|
17
|
-
activatesAfter: [Events.DispatcherReady],
|
|
18
|
-
activate: lazy(() => import('./intent-dispatcher')),
|
|
19
|
-
}),
|
|
20
|
-
]);
|
|
@@ -1,31 +0,0 @@
|
|
|
1
|
-
//
|
|
2
|
-
// Copyright 2025 DXOS.org
|
|
3
|
-
//
|
|
4
|
-
|
|
5
|
-
import * as Schema from 'effect/Schema';
|
|
6
|
-
|
|
7
|
-
import { Label } from './intent';
|
|
8
|
-
import { meta } from './meta';
|
|
9
|
-
|
|
10
|
-
export namespace IntentAction {
|
|
11
|
-
/**
|
|
12
|
-
* Log an intent.
|
|
13
|
-
*/
|
|
14
|
-
export class Track extends Schema.TaggedClass<Track>()(`${meta.id}/action/track`, {
|
|
15
|
-
input: Schema.Struct({
|
|
16
|
-
intents: Schema.Array(Schema.String),
|
|
17
|
-
error: Schema.optional(Schema.String),
|
|
18
|
-
}),
|
|
19
|
-
output: Schema.Void,
|
|
20
|
-
}) {}
|
|
21
|
-
|
|
22
|
-
/**
|
|
23
|
-
* Fired after an intent is dispatched if the intent is undoable.
|
|
24
|
-
*/
|
|
25
|
-
export class ShowUndo extends Schema.TaggedClass<ShowUndo>()(`${meta.id}/action/show-undo`, {
|
|
26
|
-
input: Schema.Struct({
|
|
27
|
-
message: Label,
|
|
28
|
-
}),
|
|
29
|
-
output: Schema.Void,
|
|
30
|
-
}) {}
|
|
31
|
-
}
|
|
@@ -1,40 +0,0 @@
|
|
|
1
|
-
//
|
|
2
|
-
// Copyright 2025 DXOS.org
|
|
3
|
-
//
|
|
4
|
-
|
|
5
|
-
// TODO(wittjosiah): Reconcile with @dxos/protocols. Factor out errors.
|
|
6
|
-
|
|
7
|
-
/**
|
|
8
|
-
* NOTE: Messages should be sentences (Start with a capital letter and end with a period).
|
|
9
|
-
* Errors can optionally include a JSON context object.
|
|
10
|
-
*/
|
|
11
|
-
export class BaseError extends Error {
|
|
12
|
-
constructor(
|
|
13
|
-
readonly code: string,
|
|
14
|
-
message?: string,
|
|
15
|
-
readonly context?: Record<string, any>,
|
|
16
|
-
) {
|
|
17
|
-
// TODO(dmaretskyi): Error.cause.
|
|
18
|
-
super(message ?? code, { cause: context });
|
|
19
|
-
this.name = code;
|
|
20
|
-
// NOTE: Restores prototype chain (https://stackoverflow.com/a/48342359).
|
|
21
|
-
Object.setPrototypeOf(this, new.target.prototype);
|
|
22
|
-
}
|
|
23
|
-
}
|
|
24
|
-
|
|
25
|
-
export class NoResolversError extends BaseError {
|
|
26
|
-
constructor(action: string) {
|
|
27
|
-
super('NO_RESOLVERS', `No resolvers were found for the action: ${action}`, { action });
|
|
28
|
-
}
|
|
29
|
-
}
|
|
30
|
-
|
|
31
|
-
// TODO(burdon): Detect loops.
|
|
32
|
-
export class CycleDetectedError extends BaseError {
|
|
33
|
-
constructor(context?: Record<string, any>) {
|
|
34
|
-
super(
|
|
35
|
-
'CYCLE_DETECTED',
|
|
36
|
-
'Intent execution limit exceeded. This is likely due to an infinite loop within intent resolvers.',
|
|
37
|
-
context,
|
|
38
|
-
);
|
|
39
|
-
}
|
|
40
|
-
}
|