@dxos/app-framework 0.8.4-main.c4373fc → 0.8.4-main.c85a9c8dae
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 +2 -4
- package/.storybook/preview.mts +2 -2
- package/dist/lib/browser/capability-2GL5JAGJ.mjs +37 -0
- package/dist/lib/browser/capability-2GL5JAGJ.mjs.map +7 -0
- package/dist/lib/browser/capability-7RLVE42K.mjs +34 -0
- package/dist/lib/browser/capability-7RLVE42K.mjs.map +7 -0
- package/dist/lib/browser/chunk-4CTRO67U.mjs +703 -0
- package/dist/lib/browser/chunk-4CTRO67U.mjs.map +7 -0
- package/dist/lib/browser/chunk-5RJNZV7K.mjs +44 -0
- package/dist/lib/browser/chunk-5RJNZV7K.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-FNKT2QQ2.mjs +145 -0
- package/dist/lib/browser/chunk-FNKT2QQ2.mjs.map +7 -0
- package/dist/lib/browser/chunk-HE27PNNQ.mjs +824 -0
- package/dist/lib/browser/chunk-HE27PNNQ.mjs.map +7 -0
- package/dist/lib/browser/chunk-J5LGTIGS.mjs +10 -0
- package/dist/lib/browser/chunk-NPUEVX42.mjs +34 -0
- package/dist/lib/browser/chunk-NPUEVX42.mjs.map +7 -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-REORGDJT.mjs +80 -0
- package/dist/lib/browser/chunk-REORGDJT.mjs.map +7 -0
- package/dist/lib/browser/chunk-YAFEA4GV.mjs +1 -0
- package/dist/lib/browser/chunk-YNFPIQGB.mjs +76 -0
- package/dist/lib/browser/chunk-YNFPIQGB.mjs.map +7 -0
- package/dist/lib/browser/chunk-ZRWBPIZG.mjs +170 -0
- package/dist/lib/browser/chunk-ZRWBPIZG.mjs.map +7 -0
- package/dist/lib/browser/cli/index.mjs +89 -0
- package/dist/lib/browser/cli/index.mjs.map +7 -0
- package/dist/lib/browser/common/activation-events.mjs +23 -0
- package/dist/lib/browser/common/capabilities.mjs +45 -0
- package/dist/lib/browser/core/activation-event.mjs +20 -0
- package/dist/lib/browser/core/activation-event.mjs.map +7 -0
- package/dist/lib/browser/core/capability.mjs +28 -0
- package/dist/lib/browser/core/capability.mjs.map +7 -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 +87 -148
- package/dist/lib/browser/index.mjs.map +4 -4
- package/dist/lib/browser/invoker-capability-BNLVNYHU.mjs +36 -0
- package/dist/lib/browser/invoker-capability-BNLVNYHU.mjs.map +7 -0
- package/dist/lib/browser/meta.json +1 -1
- package/dist/lib/browser/testing/index.mjs +81 -26
- package/dist/lib/browser/testing/index.mjs.map +4 -4
- package/dist/lib/browser/ui/index.mjs +45 -0
- package/dist/lib/browser/ui/index.mjs.map +7 -0
- package/dist/lib/node-esm/capability-CHIMU6LX.mjs +38 -0
- package/dist/lib/node-esm/capability-CHIMU6LX.mjs.map +7 -0
- package/dist/lib/node-esm/capability-EVZK4REM.mjs +35 -0
- package/dist/lib/node-esm/capability-EVZK4REM.mjs.map +7 -0
- package/dist/lib/node-esm/chunk-2A4PRBIX.mjs +171 -0
- package/dist/lib/node-esm/chunk-2A4PRBIX.mjs.map +7 -0
- package/dist/lib/node-esm/chunk-7CPNAEGV.mjs +704 -0
- package/dist/lib/node-esm/chunk-7CPNAEGV.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-CJCQS2YL.mjs +146 -0
- package/dist/lib/node-esm/chunk-CJCQS2YL.mjs.map +7 -0
- package/dist/lib/node-esm/chunk-DTCHT2X2.mjs +825 -0
- package/dist/lib/node-esm/chunk-DTCHT2X2.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-JAZVHID3.mjs +35 -0
- package/dist/lib/node-esm/chunk-JAZVHID3.mjs.map +7 -0
- package/dist/lib/node-esm/chunk-SB5ODNPX.mjs +77 -0
- package/dist/lib/node-esm/chunk-SB5ODNPX.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-UFW652GS.mjs +81 -0
- package/dist/lib/node-esm/chunk-UFW652GS.mjs.map +7 -0
- package/dist/lib/node-esm/chunk-VUIUFIGT.mjs +45 -0
- package/dist/lib/node-esm/chunk-VUIUFIGT.mjs.map +7 -0
- package/dist/lib/node-esm/chunk-Z4TJPSMP.mjs +2 -0
- package/dist/lib/node-esm/chunk-Z4TJPSMP.mjs.map +7 -0
- package/dist/lib/node-esm/cli/index.mjs +90 -0
- package/dist/lib/node-esm/cli/index.mjs.map +7 -0
- package/dist/lib/node-esm/common/activation-events.mjs +24 -0
- package/dist/lib/node-esm/common/activation-events.mjs.map +7 -0
- package/dist/lib/node-esm/common/capabilities.mjs +46 -0
- package/dist/lib/node-esm/common/capabilities.mjs.map +7 -0
- package/dist/lib/node-esm/core/activation-event.mjs +21 -0
- package/dist/lib/node-esm/core/activation-event.mjs.map +7 -0
- package/dist/lib/node-esm/core/capability.mjs +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 +87 -148
- package/dist/lib/node-esm/index.mjs.map +4 -4
- package/dist/lib/node-esm/invoker-capability-VF6SP44V.mjs +37 -0
- package/dist/lib/node-esm/invoker-capability-VF6SP44V.mjs.map +7 -0
- package/dist/lib/node-esm/meta.json +1 -1
- package/dist/lib/node-esm/testing/index.mjs +81 -26
- package/dist/lib/node-esm/testing/index.mjs.map +4 -4
- package/dist/lib/node-esm/ui/index.mjs +46 -0
- package/dist/lib/node-esm/ui/index.mjs.map +7 -0
- package/dist/types/src/cli/cli.d.ts +39 -0
- package/dist/types/src/cli/cli.d.ts.map +1 -0
- package/dist/types/src/cli/index.d.ts +2 -0
- package/dist/types/src/cli/index.d.ts.map +1 -0
- package/dist/types/src/common/activation-events.d.ts +27 -0
- package/dist/types/src/common/activation-events.d.ts.map +1 -0
- package/dist/types/src/common/capabilities.d.ts +114 -200
- package/dist/types/src/common/capabilities.d.ts.map +1 -1
- package/dist/types/src/common/index.d.ts +4 -8
- package/dist/types/src/common/index.d.ts.map +1 -1
- package/dist/types/src/common/operations.d.ts +33 -0
- package/dist/types/src/common/operations.d.ts.map +1 -0
- package/dist/types/src/common/translations.d.ts +7 -7
- 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 +96 -34
- package/dist/types/src/core/plugin.d.ts.map +1 -1
- package/dist/types/src/index.d.ts +3 -4
- package/dist/types/src/index.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 +101 -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/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 +7 -6
- package/dist/types/src/testing/withPluginManager.d.ts.map +1 -1
- package/dist/types/src/ui/components/App/App.d.ts +8 -0
- 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} +9 -7
- 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/{playground/playground.stories.d.ts → ui/components/PluginManager/PluginManagerContext.stories.d.ts} +5 -3
- package/dist/types/src/ui/components/PluginManager/PluginManagerContext.stories.d.ts.map +1 -0
- package/dist/types/src/ui/components/PluginManager/PluginManagerProvider.d.ts +10 -0
- package/dist/types/src/ui/components/PluginManager/PluginManagerProvider.d.ts.map +1 -0
- package/dist/types/src/ui/components/PluginManager/index.d.ts +2 -0
- package/dist/types/src/ui/components/PluginManager/index.d.ts.map +1 -0
- package/dist/types/src/ui/components/Surface/SurfaceComponent.d.ts +12 -0
- package/dist/types/src/ui/components/Surface/SurfaceComponent.d.ts.map +1 -0
- package/dist/types/src/{components/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 +11 -0
- package/dist/types/src/ui/components/Surface/SurfaceInfo.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 +20 -0
- package/dist/types/src/ui/components/Surface/index.d.ts.map +1 -0
- package/dist/types/src/ui/components/Surface/types.d.ts +96 -0
- 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 +7 -0
- package/dist/types/src/ui/hooks/index.d.ts.map +1 -0
- package/dist/types/src/{components → ui/hooks}/useApp.d.ts +18 -12
- package/dist/types/src/ui/hooks/useApp.d.ts.map +1 -0
- package/dist/types/src/ui/hooks/useCapabilities.d.ts +31 -0
- package/dist/types/src/ui/hooks/useCapabilities.d.ts.map +1 -0
- package/dist/types/src/{components → ui/hooks}/useLoading.d.ts +1 -2
- package/dist/types/src/ui/hooks/useLoading.d.ts.map +1 -0
- package/dist/types/src/ui/hooks/useOperationResolver.d.ts +19 -0
- package/dist/types/src/ui/hooks/useOperationResolver.d.ts.map +1 -0
- package/dist/types/src/ui/hooks/useSettingsState.d.ts +10 -0
- package/dist/types/src/ui/hooks/useSettingsState.d.ts.map +1 -0
- package/dist/types/src/ui/hooks/useSurface.d.ts +3 -0
- package/dist/types/src/ui/hooks/useSurface.d.ts.map +1 -0
- package/dist/types/src/ui/index.d.ts +3 -0
- package/dist/types/src/ui/index.d.ts.map +1 -0
- package/dist/types/tsconfig.tsbuildinfo +1 -1
- package/moon.yml +10 -6
- package/package.json +111 -47
- package/src/cli/cli.ts +107 -0
- package/src/{components → cli}/index.ts +1 -1
- package/src/common/activation-events.ts +44 -0
- package/src/common/capabilities.ts +174 -213
- package/src/common/index.ts +4 -8
- package/src/common/operations.ts +38 -0
- package/src/common/translations.ts +17 -9
- 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 +715 -0
- package/src/core/plugin.ts +227 -39
- package/src/index.ts +3 -4
- 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 +135 -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/{playground/logger → plugin-runtime}/index.ts +1 -1
- package/src/plugin-runtime/meta.ts +11 -0
- package/src/testing/index.ts +1 -0
- package/src/testing/service.ts +52 -0
- package/src/testing/withPluginManager.stories.tsx +7 -7
- package/src/testing/withPluginManager.tsx +33 -27
- package/src/ui/components/App/App.stories.tsx +92 -0
- package/src/{components → ui/components/App}/App.tsx +9 -11
- package/src/{playground/debug → ui/components/App}/index.ts +1 -1
- package/src/ui/components/PluginManager/PluginManagerContext.stories.tsx +183 -0
- package/src/{react → ui/components/PluginManager}/PluginManagerProvider.ts +3 -3
- package/src/ui/components/PluginManager/index.ts +5 -0
- package/src/ui/components/Surface/SurfaceComponent.stories.tsx +143 -0
- package/src/ui/components/Surface/SurfaceComponent.tsx +247 -0
- package/src/ui/components/Surface/SurfaceInfo.tsx +107 -0
- package/src/ui/components/Surface/context.ts +12 -0
- package/src/ui/components/Surface/index.ts +20 -0
- package/src/ui/components/Surface/types.ts +117 -0
- package/src/ui/components/index.ts +7 -0
- package/src/ui/hooks/index.ts +10 -0
- package/src/ui/hooks/useApp.tsx +213 -0
- package/src/ui/hooks/useCapabilities.ts +67 -0
- package/src/{components → ui/hooks}/useLoading.tsx +4 -6
- package/src/ui/hooks/useOperationResolver.ts +40 -0
- package/src/ui/hooks/useSettingsState.ts +26 -0
- package/src/ui/hooks/useSurface.ts +13 -0
- package/src/ui/index.ts +6 -0
- package/tsconfig.json +12 -21
- package/tsconfig.node.json +1 -3
- package/typedoc.json +2 -4
- package/.swc/plugins/linux_x86_64_19.0.0/fce1bdb8e20a094e4af08bad09cc81497ed0e2e7c51223b07d371063cca18429.wasmer-v7 +0 -0
- package/dist/lib/browser/app-graph-builder-77MY7KAY.mjs +0 -138
- package/dist/lib/browser/app-graph-builder-77MY7KAY.mjs.map +0 -7
- package/dist/lib/browser/chunk-4NFLRSTX.mjs +0 -467
- package/dist/lib/browser/chunk-4NFLRSTX.mjs.map +0 -7
- package/dist/lib/browser/chunk-OKF2PAWO.mjs +0 -1646
- package/dist/lib/browser/chunk-OKF2PAWO.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-Y4LZNOBC.mjs +0 -11
- package/dist/lib/browser/intent-resolver-XO5OYWVD.mjs +0 -39
- package/dist/lib/browser/intent-resolver-XO5OYWVD.mjs.map +0 -7
- package/dist/lib/browser/store-E3YSBPJQ.mjs +0 -30
- package/dist/lib/browser/store-E3YSBPJQ.mjs.map +0 -7
- package/dist/lib/browser/worker.mjs +0 -77
- package/dist/lib/node-esm/app-graph-builder-WK7WBM6I.mjs +0 -139
- package/dist/lib/node-esm/app-graph-builder-WK7WBM6I.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-7DNZQ6H2.mjs +0 -1648
- package/dist/lib/node-esm/chunk-7DNZQ6H2.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-AHCD4UYO.mjs +0 -468
- package/dist/lib/node-esm/chunk-AHCD4UYO.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-R4CCPBHO.mjs +0 -12
- package/dist/lib/node-esm/intent-resolver-NVYY6BQA.mjs +0 -40
- package/dist/lib/node-esm/intent-resolver-NVYY6BQA.mjs.map +0 -7
- package/dist/lib/node-esm/store-QA5DGTOS.mjs +0 -31
- package/dist/lib/node-esm/store-QA5DGTOS.mjs.map +0 -7
- package/dist/lib/node-esm/worker.mjs +0 -78
- package/dist/types/src/common/collaboration.d.ts +0 -20
- package/dist/types/src/common/collaboration.d.ts.map +0 -1
- package/dist/types/src/common/events.d.ts +0 -52
- package/dist/types/src/common/events.d.ts.map +0 -1
- package/dist/types/src/common/file.d.ts +0 -14
- package/dist/types/src/common/file.d.ts.map +0 -1
- package/dist/types/src/common/graph.d.ts +0 -21
- package/dist/types/src/common/graph.d.ts.map +0 -1
- package/dist/types/src/common/layout.d.ts +0 -279
- package/dist/types/src/common/layout.d.ts.map +0 -1
- package/dist/types/src/common/surface.d.ts +0 -59
- package/dist/types/src/common/surface.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 +0 -8
- 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/playground/debug/Debug.d.ts +0 -6
- package/dist/types/src/playground/debug/Debug.d.ts.map +0 -1
- package/dist/types/src/playground/debug/index.d.ts +0 -2
- package/dist/types/src/playground/debug/index.d.ts.map +0 -1
- package/dist/types/src/playground/debug/plugin.d.ts +0 -2
- package/dist/types/src/playground/debug/plugin.d.ts.map +0 -1
- package/dist/types/src/playground/generator/Main.d.ts +0 -6
- package/dist/types/src/playground/generator/Main.d.ts.map +0 -1
- package/dist/types/src/playground/generator/Toolbar.d.ts +0 -6
- package/dist/types/src/playground/generator/Toolbar.d.ts.map +0 -1
- package/dist/types/src/playground/generator/generator.d.ts +0 -7
- package/dist/types/src/playground/generator/generator.d.ts.map +0 -1
- package/dist/types/src/playground/generator/index.d.ts +0 -3
- package/dist/types/src/playground/generator/index.d.ts.map +0 -1
- package/dist/types/src/playground/generator/plugin.d.ts +0 -2
- package/dist/types/src/playground/generator/plugin.d.ts.map +0 -1
- package/dist/types/src/playground/layout/Layout.d.ts +0 -8
- package/dist/types/src/playground/layout/Layout.d.ts.map +0 -1
- package/dist/types/src/playground/layout/index.d.ts +0 -2
- package/dist/types/src/playground/layout/index.d.ts.map +0 -1
- package/dist/types/src/playground/layout/plugin.d.ts +0 -2
- package/dist/types/src/playground/layout/plugin.d.ts.map +0 -1
- package/dist/types/src/playground/logger/Toolbar.d.ts +0 -6
- package/dist/types/src/playground/logger/Toolbar.d.ts.map +0 -1
- package/dist/types/src/playground/logger/index.d.ts +0 -2
- package/dist/types/src/playground/logger/index.d.ts.map +0 -1
- package/dist/types/src/playground/logger/plugin.d.ts +0 -2
- package/dist/types/src/playground/logger/plugin.d.ts.map +0 -1
- package/dist/types/src/playground/logger/schema.d.ts +0 -13
- package/dist/types/src/playground/logger/schema.d.ts.map +0 -1
- package/dist/types/src/playground/playground.stories.d.ts.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/SettingsPlugin.d.ts +0 -2
- package/dist/types/src/plugin-settings/SettingsPlugin.d.ts.map +0 -1
- package/dist/types/src/plugin-settings/actions.d.ts +0 -25
- package/dist/types/src/plugin-settings/actions.d.ts.map +0 -1
- package/dist/types/src/plugin-settings/app-graph-builder.d.ts +0 -4
- package/dist/types/src/plugin-settings/app-graph-builder.d.ts.map +0 -1
- package/dist/types/src/plugin-settings/index.d.ts +0 -3
- package/dist/types/src/plugin-settings/index.d.ts.map +0 -1
- package/dist/types/src/plugin-settings/intent-resolver.d.ts +0 -4
- package/dist/types/src/plugin-settings/intent-resolver.d.ts.map +0 -1
- package/dist/types/src/plugin-settings/meta.d.ts +0 -3
- package/dist/types/src/plugin-settings/meta.d.ts.map +0 -1
- package/dist/types/src/plugin-settings/store.d.ts +0 -5
- package/dist/types/src/plugin-settings/store.d.ts.map +0 -1
- package/dist/types/src/plugin-settings/translations.d.ts +0 -11
- package/dist/types/src/plugin-settings/translations.d.ts.map +0 -1
- package/dist/types/src/react/ErrorBoundary.d.ts +0 -30
- package/dist/types/src/react/ErrorBoundary.d.ts.map +0 -1
- package/dist/types/src/react/IntentContext.d.ts +0 -8
- package/dist/types/src/react/IntentContext.d.ts.map +0 -1
- package/dist/types/src/react/PluginManagerProvider.d.ts +0 -10
- package/dist/types/src/react/PluginManagerProvider.d.ts.map +0 -1
- package/dist/types/src/react/Surface.d.ts +0 -12
- package/dist/types/src/react/Surface.d.ts.map +0 -1
- package/dist/types/src/react/Surface.stories.d.ts.map +0 -1
- package/dist/types/src/react/common.d.ts +0 -13
- package/dist/types/src/react/common.d.ts.map +0 -1
- package/dist/types/src/react/index.d.ts +0 -7
- package/dist/types/src/react/index.d.ts.map +0 -1
- package/dist/types/src/react/useCapabilities.d.ts +0 -13
- package/dist/types/src/react/useCapabilities.d.ts.map +0 -1
- package/dist/types/src/react/useIntentResolver.d.ts +0 -3
- package/dist/types/src/react/useIntentResolver.d.ts.map +0 -1
- package/dist/types/src/worker.d.ts +0 -4
- package/dist/types/src/worker.d.ts.map +0 -1
- package/src/common/collaboration.ts +0 -18
- package/src/common/events.ts +0 -79
- package/src/common/file.ts +0 -22
- package/src/common/graph.ts +0 -30
- package/src/common/layout.ts +0 -277
- package/src/common/surface.ts +0 -83
- package/src/components/App.stories.tsx +0 -33
- package/src/components/DefaultFallback.tsx +0 -26
- package/src/components/useApp.tsx +0 -164
- package/src/core/capabilities.test.ts +0 -136
- package/src/core/capabilities.ts +0 -259
- package/src/core/manager.test.ts +0 -516
- package/src/core/manager.ts +0 -604
- package/src/playground/debug/Debug.tsx +0 -39
- package/src/playground/debug/plugin.ts +0 -16
- package/src/playground/generator/Main.tsx +0 -71
- package/src/playground/generator/Toolbar.tsx +0 -47
- package/src/playground/generator/generator.ts +0 -48
- package/src/playground/generator/index.ts +0 -6
- package/src/playground/generator/plugin.ts +0 -22
- package/src/playground/layout/Layout.tsx +0 -33
- package/src/playground/layout/index.ts +0 -5
- package/src/playground/layout/plugin.ts +0 -18
- package/src/playground/logger/Toolbar.tsx +0 -30
- package/src/playground/logger/plugin.ts +0 -41
- package/src/playground/logger/schema.ts +0 -12
- package/src/playground/playground.stories.tsx +0 -46
- 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/SettingsPlugin.ts +0 -34
- package/src/plugin-settings/actions.ts +0 -25
- package/src/plugin-settings/app-graph-builder.ts +0 -160
- package/src/plugin-settings/index.ts +0 -6
- package/src/plugin-settings/intent-resolver.ts +0 -35
- package/src/plugin-settings/meta.ts +0 -10
- package/src/plugin-settings/store.ts +0 -33
- package/src/plugin-settings/translations.ts +0 -19
- package/src/react/ErrorBoundary.tsx +0 -56
- package/src/react/IntentContext.tsx +0 -35
- package/src/react/Surface.stories.tsx +0 -101
- package/src/react/Surface.tsx +0 -86
- package/src/react/common.ts +0 -13
- package/src/react/index.ts +0 -10
- package/src/react/useCapabilities.ts +0 -31
- package/src/react/useIntentResolver.ts +0 -22
- package/src/worker.ts +0 -11
- /package/dist/lib/browser/{intent-dispatcher-Y4LZNOBC.mjs.map → chunk-J5LGTIGS.mjs.map} +0 -0
- /package/dist/lib/browser/{worker.mjs.map → chunk-YAFEA4GV.mjs.map} +0 -0
- /package/dist/lib/{node-esm/intent-dispatcher-R4CCPBHO.mjs.map → browser/common/activation-events.mjs.map} +0 -0
- /package/dist/lib/{node-esm/worker.mjs.map → browser/common/capabilities.mjs.map} +0 -0
|
@@ -0,0 +1,73 @@
|
|
|
1
|
+
//
|
|
2
|
+
// Copyright 2025 DXOS.org
|
|
3
|
+
//
|
|
4
|
+
|
|
5
|
+
import { describe, test } from 'vitest';
|
|
6
|
+
|
|
7
|
+
import { Compute, HalveCompute } from '../testing';
|
|
8
|
+
|
|
9
|
+
import * as UndoMapping from './undo-mapping';
|
|
10
|
+
import * as UndoRegistry from './undo-registry';
|
|
11
|
+
|
|
12
|
+
describe('UndoRegistry', () => {
|
|
13
|
+
test('looks up undo mapping by operation key', ({ expect }) => {
|
|
14
|
+
const undoMapping = UndoMapping.make({
|
|
15
|
+
operation: Compute,
|
|
16
|
+
inverse: HalveCompute,
|
|
17
|
+
deriveContext: (_input, output) => ({ value: output.value }),
|
|
18
|
+
});
|
|
19
|
+
const registry = UndoRegistry.make(() => [undoMapping]);
|
|
20
|
+
|
|
21
|
+
const result = registry.lookup(Compute);
|
|
22
|
+
expect(result).not.toBe(undefined);
|
|
23
|
+
expect(result?.inverse.meta.key).toBe('test.halve-compute');
|
|
24
|
+
});
|
|
25
|
+
|
|
26
|
+
test('returns undefined for unmapped operations', ({ expect }) => {
|
|
27
|
+
const registry = UndoRegistry.make(() => []);
|
|
28
|
+
|
|
29
|
+
const result = registry.lookup(Compute);
|
|
30
|
+
expect(result).toBe(undefined);
|
|
31
|
+
});
|
|
32
|
+
|
|
33
|
+
test('deriveContext extracts correct undo input', ({ expect }) => {
|
|
34
|
+
const undoMapping = UndoMapping.make({
|
|
35
|
+
operation: Compute,
|
|
36
|
+
inverse: HalveCompute,
|
|
37
|
+
// Note: This tests that input and output types are inferred correctly.
|
|
38
|
+
deriveContext: (input, output) => ({ value: output.value + input.value }),
|
|
39
|
+
});
|
|
40
|
+
const registry = UndoRegistry.make(() => [undoMapping]);
|
|
41
|
+
|
|
42
|
+
const result = registry.lookup(Compute);
|
|
43
|
+
const context = result?.deriveContext({ value: 5 }, { value: 10 });
|
|
44
|
+
expect(context).toEqual({ value: 15 });
|
|
45
|
+
});
|
|
46
|
+
});
|
|
47
|
+
|
|
48
|
+
describe('resolveMessage', () => {
|
|
49
|
+
test('returns undefined for undefined message', ({ expect }) => {
|
|
50
|
+
const result = UndoMapping.resolveMessage(undefined, { value: 1 }, { value: 2 });
|
|
51
|
+
expect(result).toBe(undefined);
|
|
52
|
+
});
|
|
53
|
+
|
|
54
|
+
test('returns static label as-is', ({ expect }) => {
|
|
55
|
+
const staticMessage: [string, { ns: string }] = ['test message', { ns: 'test' }];
|
|
56
|
+
const result = UndoMapping.resolveMessage(staticMessage, { value: 1 }, { value: 2 });
|
|
57
|
+
expect(result).toEqual(staticMessage);
|
|
58
|
+
});
|
|
59
|
+
|
|
60
|
+
test('calls function message with input and output', ({ expect }) => {
|
|
61
|
+
const messageFunc = (input: { value: number }, output: { value: number }): [string, { ns: string }] => [
|
|
62
|
+
`input: ${input.value}, output: ${output.value}`,
|
|
63
|
+
{ ns: 'test' },
|
|
64
|
+
];
|
|
65
|
+
const result = UndoMapping.resolveMessage(messageFunc, { value: 5 }, { value: 10 });
|
|
66
|
+
expect(result).toEqual(['input: 5, output: 10', { ns: 'test' }]);
|
|
67
|
+
});
|
|
68
|
+
|
|
69
|
+
test('returns string label as-is', ({ expect }) => {
|
|
70
|
+
const result = UndoMapping.resolveMessage('simple string', { value: 1 }, { value: 2 });
|
|
71
|
+
expect(result).toBe('simple string');
|
|
72
|
+
});
|
|
73
|
+
});
|
|
@@ -0,0 +1,54 @@
|
|
|
1
|
+
//
|
|
2
|
+
// Copyright 2025 DXOS.org
|
|
3
|
+
//
|
|
4
|
+
|
|
5
|
+
import type { Operation } from '@dxos/operation';
|
|
6
|
+
|
|
7
|
+
import type * as UndoMapping from './undo-mapping';
|
|
8
|
+
|
|
9
|
+
//
|
|
10
|
+
// Public Interface
|
|
11
|
+
//
|
|
12
|
+
|
|
13
|
+
/**
|
|
14
|
+
* Lookup result from UndoRegistry.
|
|
15
|
+
*/
|
|
16
|
+
export type UndoMappingResult = {
|
|
17
|
+
inverse: Operation.Definition<any, any>;
|
|
18
|
+
/** Returns undefined to indicate the operation is not undoable. */
|
|
19
|
+
deriveContext: (input: any, output: any) => any | undefined;
|
|
20
|
+
/** Message provider - may be a static Label or a function. */
|
|
21
|
+
message?: UndoMapping.MessageProvider<Operation.Definition<any, any>>;
|
|
22
|
+
};
|
|
23
|
+
|
|
24
|
+
/**
|
|
25
|
+
* UndoRegistry interface - looks up inverse operations.
|
|
26
|
+
*/
|
|
27
|
+
export interface UndoRegistry {
|
|
28
|
+
lookup: (operation: Operation.Definition<any, any>) => UndoMappingResult | undefined;
|
|
29
|
+
}
|
|
30
|
+
|
|
31
|
+
//
|
|
32
|
+
// Factory
|
|
33
|
+
//
|
|
34
|
+
|
|
35
|
+
/**
|
|
36
|
+
* Creates an UndoRegistry that looks up inverse operations.
|
|
37
|
+
*/
|
|
38
|
+
export const make = (getMappings: () => UndoMapping.UndoMapping[]): UndoRegistry => {
|
|
39
|
+
const lookup = (operation: Operation.Definition<any, any>): UndoMappingResult | undefined => {
|
|
40
|
+
const mappings = getMappings();
|
|
41
|
+
const mapping = mappings.find((m) => m.operation.meta.key === operation.meta.key);
|
|
42
|
+
if (!mapping) {
|
|
43
|
+
return undefined;
|
|
44
|
+
}
|
|
45
|
+
|
|
46
|
+
return {
|
|
47
|
+
inverse: mapping.inverse,
|
|
48
|
+
deriveContext: mapping.deriveContext,
|
|
49
|
+
message: mapping.message,
|
|
50
|
+
};
|
|
51
|
+
};
|
|
52
|
+
|
|
53
|
+
return { lookup };
|
|
54
|
+
};
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
//
|
|
2
|
+
// Copyright 2025 DXOS.org
|
|
3
|
+
//
|
|
4
|
+
|
|
5
|
+
import * as Effect from 'effect/Effect';
|
|
6
|
+
|
|
7
|
+
import { OperationInvoker } from '@dxos/operation';
|
|
8
|
+
|
|
9
|
+
import { ActivationEvents, Capabilities } from '../common';
|
|
10
|
+
import { Capability, Plugin } from '../core';
|
|
11
|
+
|
|
12
|
+
//
|
|
13
|
+
// Capability Module
|
|
14
|
+
//
|
|
15
|
+
|
|
16
|
+
export default Capability.makeModule(
|
|
17
|
+
Effect.fnUntraced(function* () {
|
|
18
|
+
// Get the services for synchronous access in callbacks.
|
|
19
|
+
const capabilityManager = yield* Capability.Service;
|
|
20
|
+
const pluginManager = yield* Plugin.Service;
|
|
21
|
+
|
|
22
|
+
// Get the ManagedRuntime capability (should be available since we activate after ManagedRuntimeReady).
|
|
23
|
+
const managedRuntimes = yield* Capability.getAll(Capabilities.ManagedRuntime);
|
|
24
|
+
const managedRuntime = managedRuntimes.length > 0 ? managedRuntimes[0] : undefined;
|
|
25
|
+
|
|
26
|
+
const invoker = OperationInvoker.make(
|
|
27
|
+
() =>
|
|
28
|
+
Effect.gen(function* () {
|
|
29
|
+
yield* Plugin.activate(ActivationEvents.SetupOperationResolver);
|
|
30
|
+
return (yield* Capability.getAll(Capabilities.OperationResolver)).flat();
|
|
31
|
+
}).pipe(
|
|
32
|
+
Effect.provideService(Capability.Service, capabilityManager),
|
|
33
|
+
Effect.provideService(Plugin.Service, pluginManager),
|
|
34
|
+
),
|
|
35
|
+
managedRuntime,
|
|
36
|
+
);
|
|
37
|
+
|
|
38
|
+
return Capability.contributes(Capabilities.OperationInvoker, invoker);
|
|
39
|
+
}),
|
|
40
|
+
);
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
//
|
|
2
|
+
// Copyright 2025 DXOS.org
|
|
3
|
+
//
|
|
4
|
+
|
|
5
|
+
import { type Plugin } from '../core';
|
|
6
|
+
|
|
7
|
+
export const meta: Plugin.Meta = {
|
|
8
|
+
id: 'dxos.org/plugin/operation',
|
|
9
|
+
name: 'Operation Plugin',
|
|
10
|
+
description: 'Provides operation invocation, undo registry, and history tracking.',
|
|
11
|
+
};
|
|
@@ -0,0 +1,174 @@
|
|
|
1
|
+
//
|
|
2
|
+
// Copyright 2025 DXOS.org
|
|
3
|
+
//
|
|
4
|
+
|
|
5
|
+
import * as Deferred from 'effect/Deferred';
|
|
6
|
+
import * as Effect from 'effect/Effect';
|
|
7
|
+
import * as Fiber from 'effect/Fiber';
|
|
8
|
+
import * as Ref from 'effect/Ref';
|
|
9
|
+
import * as Schema from 'effect/Schema';
|
|
10
|
+
import * as Stream from 'effect/Stream';
|
|
11
|
+
|
|
12
|
+
import { Operation, type OperationInvoker, OperationResolver } from '@dxos/operation';
|
|
13
|
+
|
|
14
|
+
//
|
|
15
|
+
// Test Operations
|
|
16
|
+
//
|
|
17
|
+
|
|
18
|
+
export const Compute = Operation.make({
|
|
19
|
+
schema: {
|
|
20
|
+
input: Schema.Struct({ value: Schema.Number }),
|
|
21
|
+
output: Schema.Struct({ value: Schema.Number }),
|
|
22
|
+
},
|
|
23
|
+
meta: { key: 'test.compute' },
|
|
24
|
+
});
|
|
25
|
+
|
|
26
|
+
export const HalveCompute = Operation.make({
|
|
27
|
+
schema: {
|
|
28
|
+
input: Schema.Struct({ value: Schema.Number }),
|
|
29
|
+
output: Schema.Struct({ value: Schema.Number }),
|
|
30
|
+
},
|
|
31
|
+
meta: { key: 'test.halve-compute' },
|
|
32
|
+
});
|
|
33
|
+
|
|
34
|
+
export const ToString = Operation.make({
|
|
35
|
+
schema: {
|
|
36
|
+
input: Schema.Struct({ value: Schema.Number }),
|
|
37
|
+
output: Schema.Struct({ string: Schema.String }),
|
|
38
|
+
},
|
|
39
|
+
meta: { key: 'test.to-string' },
|
|
40
|
+
});
|
|
41
|
+
|
|
42
|
+
export const Add = Operation.make({
|
|
43
|
+
schema: {
|
|
44
|
+
input: Schema.Tuple(Schema.Number, Schema.Number),
|
|
45
|
+
output: Schema.Number,
|
|
46
|
+
},
|
|
47
|
+
meta: { key: 'test.add' },
|
|
48
|
+
});
|
|
49
|
+
|
|
50
|
+
export const SideEffect = Operation.make({
|
|
51
|
+
schema: {
|
|
52
|
+
input: Schema.Void,
|
|
53
|
+
output: Schema.Void,
|
|
54
|
+
},
|
|
55
|
+
meta: { key: 'test.side-effect' },
|
|
56
|
+
});
|
|
57
|
+
|
|
58
|
+
//
|
|
59
|
+
// Test Handlers
|
|
60
|
+
//
|
|
61
|
+
|
|
62
|
+
export const computeHandler = OperationResolver.make({
|
|
63
|
+
operation: Compute,
|
|
64
|
+
handler: (data) =>
|
|
65
|
+
Effect.gen(function* () {
|
|
66
|
+
yield* Effect.sleep(data.value * 10);
|
|
67
|
+
return { value: data.value * 2 };
|
|
68
|
+
}),
|
|
69
|
+
});
|
|
70
|
+
|
|
71
|
+
export const halveComputeHandler = OperationResolver.make({
|
|
72
|
+
operation: HalveCompute,
|
|
73
|
+
handler: (data) => Effect.succeed({ value: data.value / 2 }),
|
|
74
|
+
});
|
|
75
|
+
|
|
76
|
+
export const toStringHandler = OperationResolver.make({
|
|
77
|
+
operation: ToString,
|
|
78
|
+
handler: (data) => Effect.succeed({ string: data.value.toString() }),
|
|
79
|
+
});
|
|
80
|
+
|
|
81
|
+
export const addHandler = OperationResolver.make({
|
|
82
|
+
operation: Add,
|
|
83
|
+
handler: (data) => Effect.succeed(data[0] + data[1]),
|
|
84
|
+
});
|
|
85
|
+
|
|
86
|
+
export const sideEffectHandler = OperationResolver.make({
|
|
87
|
+
operation: SideEffect,
|
|
88
|
+
handler: () => Effect.succeed(undefined),
|
|
89
|
+
});
|
|
90
|
+
|
|
91
|
+
//
|
|
92
|
+
// Test Utilities
|
|
93
|
+
//
|
|
94
|
+
|
|
95
|
+
/**
|
|
96
|
+
* Event collector for testing - provides deterministic event collection using Effect primitives.
|
|
97
|
+
*/
|
|
98
|
+
export interface EventCollector {
|
|
99
|
+
/** All collected events. */
|
|
100
|
+
readonly events: OperationInvoker.InvocationEvent[];
|
|
101
|
+
/** Wait until N events have been collected. */
|
|
102
|
+
waitForEvents: (count: number) => Effect.Effect<void>;
|
|
103
|
+
/** Clean up the subscription fiber. */
|
|
104
|
+
dispose: Effect.Effect<void>;
|
|
105
|
+
}
|
|
106
|
+
|
|
107
|
+
/**
|
|
108
|
+
* Creates an event collector that subscribes to invoker events.
|
|
109
|
+
* Uses Effect primitives for synchronization.
|
|
110
|
+
*/
|
|
111
|
+
export const createEventCollector = (invoker: OperationInvoker.OperationInvoker): Effect.Effect<EventCollector> =>
|
|
112
|
+
Effect.gen(function* () {
|
|
113
|
+
const events: OperationInvoker.InvocationEvent[] = [];
|
|
114
|
+
|
|
115
|
+
// Ref to track current waiter (waiting for N events).
|
|
116
|
+
const waiterRef = yield* Ref.make<{ count: number; deferred: Deferred.Deferred<void> } | null>(null);
|
|
117
|
+
|
|
118
|
+
// Deferred to signal when subscription is ready.
|
|
119
|
+
const subscriptionReady = yield* Deferred.make<void>();
|
|
120
|
+
|
|
121
|
+
const checkWaiter = Effect.gen(function* () {
|
|
122
|
+
const waiter = yield* Ref.get(waiterRef);
|
|
123
|
+
if (waiter && events.length >= waiter.count) {
|
|
124
|
+
yield* Deferred.succeed(waiter.deferred, undefined);
|
|
125
|
+
yield* Ref.set(waiterRef, null);
|
|
126
|
+
}
|
|
127
|
+
});
|
|
128
|
+
|
|
129
|
+
// Fork a fiber to consume the invocation stream.
|
|
130
|
+
const fiber = yield* Effect.fork(
|
|
131
|
+
Effect.gen(function* () {
|
|
132
|
+
// Signal that subscription is about to start.
|
|
133
|
+
yield* Deferred.succeed(subscriptionReady, undefined);
|
|
134
|
+
yield* Stream.fromPubSub(invoker.invocations).pipe(
|
|
135
|
+
Stream.runForEach((event) =>
|
|
136
|
+
Effect.gen(function* () {
|
|
137
|
+
events.push(event);
|
|
138
|
+
yield* checkWaiter;
|
|
139
|
+
}),
|
|
140
|
+
),
|
|
141
|
+
);
|
|
142
|
+
}),
|
|
143
|
+
);
|
|
144
|
+
|
|
145
|
+
// Wait for the subscription to be established.
|
|
146
|
+
yield* Deferred.await(subscriptionReady);
|
|
147
|
+
// Additional yield to ensure PubSub subscription is fully registered.
|
|
148
|
+
yield* Effect.yieldNow();
|
|
149
|
+
|
|
150
|
+
const waitForEvents = (count: number): Effect.Effect<void> =>
|
|
151
|
+
Effect.gen(function* () {
|
|
152
|
+
if (events.length >= count) {
|
|
153
|
+
return;
|
|
154
|
+
}
|
|
155
|
+
const deferred = yield* Deferred.make<void>();
|
|
156
|
+
yield* Ref.set(waiterRef, { count, deferred });
|
|
157
|
+
yield* Deferred.await(deferred);
|
|
158
|
+
});
|
|
159
|
+
|
|
160
|
+
const dispose = Fiber.interrupt(fiber);
|
|
161
|
+
|
|
162
|
+
return { events, waitForEvents, dispose };
|
|
163
|
+
});
|
|
164
|
+
|
|
165
|
+
/**
|
|
166
|
+
* Waits until a condition is true, yielding to the JS event loop between checks.
|
|
167
|
+
* Uses setImmediate to allow other async work to complete.
|
|
168
|
+
*/
|
|
169
|
+
export const waitUntil = (condition: () => boolean): Effect.Effect<void> =>
|
|
170
|
+
Effect.gen(function* () {
|
|
171
|
+
while (!condition()) {
|
|
172
|
+
yield* Effect.promise(() => new Promise((r) => setImmediate(r)));
|
|
173
|
+
}
|
|
174
|
+
});
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
//
|
|
2
|
+
// Copyright 2025 DXOS.org
|
|
3
|
+
//
|
|
4
|
+
|
|
5
|
+
import { ActivationEvents } from '../common';
|
|
6
|
+
import { Capability, Plugin } from '../core';
|
|
7
|
+
|
|
8
|
+
import { meta } from './meta';
|
|
9
|
+
|
|
10
|
+
const ManagedRuntimeCapability = Capability.lazy('ManagedRuntime', () => import('./capability'));
|
|
11
|
+
|
|
12
|
+
export const RuntimePlugin = Plugin.define(meta).pipe(
|
|
13
|
+
Plugin.addModule({
|
|
14
|
+
activatesOn: ActivationEvents.Startup,
|
|
15
|
+
activatesBefore: [ActivationEvents.SetupLayer],
|
|
16
|
+
activatesAfter: [ActivationEvents.ManagedRuntimeReady],
|
|
17
|
+
activate: ManagedRuntimeCapability,
|
|
18
|
+
}),
|
|
19
|
+
Plugin.make,
|
|
20
|
+
);
|
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
//
|
|
2
|
+
// Copyright 2025 DXOS.org
|
|
3
|
+
//
|
|
4
|
+
|
|
5
|
+
import * as Effect from 'effect/Effect';
|
|
6
|
+
import * as Layer from 'effect/Layer';
|
|
7
|
+
import * as ManagedRuntime from 'effect/ManagedRuntime';
|
|
8
|
+
|
|
9
|
+
import { ActivationEvents, Capabilities } from '../common';
|
|
10
|
+
import { Capability, Plugin } from '../core';
|
|
11
|
+
|
|
12
|
+
//
|
|
13
|
+
// Capability Module
|
|
14
|
+
//
|
|
15
|
+
|
|
16
|
+
export default Capability.makeModule(
|
|
17
|
+
Effect.fnUntraced(function* () {
|
|
18
|
+
// Get the CapabilityManager to create a layer for it.
|
|
19
|
+
const capabilityManager = yield* Capability.Service;
|
|
20
|
+
|
|
21
|
+
// Get the PluginManager to create a layer for it.
|
|
22
|
+
const pluginManager = yield* Plugin.Service;
|
|
23
|
+
|
|
24
|
+
// Trigger setup event so plugins can contribute their layers.
|
|
25
|
+
yield* Plugin.activate(ActivationEvents.SetupLayer);
|
|
26
|
+
|
|
27
|
+
// Gather all contributed layers.
|
|
28
|
+
const layers = yield* Capability.getAll(Capabilities.Layer);
|
|
29
|
+
|
|
30
|
+
// Create layers that provide Capability.Service and Plugin.Service.
|
|
31
|
+
const capabilityServiceLayer = Layer.succeed(Capability.Service, capabilityManager);
|
|
32
|
+
const pluginServiceLayer = Layer.succeed(Plugin.Service, pluginManager);
|
|
33
|
+
|
|
34
|
+
// Merge all layers including service layers.
|
|
35
|
+
// Layer.mergeAll requires a tuple type, so we use a cast for dynamic arrays.
|
|
36
|
+
const composedLayer =
|
|
37
|
+
layers.length > 0
|
|
38
|
+
? (Layer.mergeAll as (...args: Layer.Layer<any, any, any>[]) => Layer.Layer<any, any, never>)(
|
|
39
|
+
capabilityServiceLayer,
|
|
40
|
+
pluginServiceLayer,
|
|
41
|
+
...layers,
|
|
42
|
+
)
|
|
43
|
+
: (Layer.mergeAll as (...args: Layer.Layer<any, any, any>[]) => Layer.Layer<any, any, never>)(
|
|
44
|
+
capabilityServiceLayer,
|
|
45
|
+
pluginServiceLayer,
|
|
46
|
+
);
|
|
47
|
+
|
|
48
|
+
// Create the managed runtime from the composed layer.
|
|
49
|
+
const runtime = ManagedRuntime.make(composedLayer) as Capabilities.ManagedRuntime;
|
|
50
|
+
|
|
51
|
+
return Capability.contributes(Capabilities.ManagedRuntime, runtime);
|
|
52
|
+
}),
|
|
53
|
+
);
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
//
|
|
2
|
+
// Copyright 2025 DXOS.org
|
|
3
|
+
//
|
|
4
|
+
|
|
5
|
+
import { type Plugin } from '../core';
|
|
6
|
+
|
|
7
|
+
export const meta: Plugin.Meta = {
|
|
8
|
+
id: 'dxos.org/plugin/runtime',
|
|
9
|
+
name: 'Runtime Plugin',
|
|
10
|
+
description: 'Provides a managed Effect runtime by composing contributed layers.',
|
|
11
|
+
};
|
package/src/testing/index.ts
CHANGED
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
//
|
|
2
|
+
// Copyright 2025 DXOS.org
|
|
3
|
+
//
|
|
4
|
+
|
|
5
|
+
import * as Effect from 'effect/Effect';
|
|
6
|
+
import * as Layer from 'effect/Layer';
|
|
7
|
+
|
|
8
|
+
import { invariant } from '@dxos/invariant';
|
|
9
|
+
|
|
10
|
+
import { ActivationEvents, Capabilities } from '../common';
|
|
11
|
+
import { Plugin, PluginManager } from '../core';
|
|
12
|
+
|
|
13
|
+
/**
|
|
14
|
+
* Creates a Plugin.Service layer from a list of plugins.
|
|
15
|
+
* This is primarily used for testing.
|
|
16
|
+
*/
|
|
17
|
+
export const fromPlugins = (plugins: Plugin.Plugin[]) =>
|
|
18
|
+
Layer.effect(
|
|
19
|
+
Plugin.Service,
|
|
20
|
+
Effect.gen(function* () {
|
|
21
|
+
// TODO(wittjosiah): Try to dedupe logic between here, createCliApp and useApp.
|
|
22
|
+
|
|
23
|
+
const pluginLoader = (id: string) =>
|
|
24
|
+
Effect.sync(() => {
|
|
25
|
+
const plugin = plugins.find((plugin) => plugin.meta.id === id);
|
|
26
|
+
invariant(plugin, `Plugin not found: ${id}`);
|
|
27
|
+
return plugin;
|
|
28
|
+
});
|
|
29
|
+
|
|
30
|
+
const manager = PluginManager.make({
|
|
31
|
+
pluginLoader,
|
|
32
|
+
plugins,
|
|
33
|
+
core: plugins.map((plugin) => plugin.meta.id),
|
|
34
|
+
});
|
|
35
|
+
|
|
36
|
+
manager.capabilities.contribute({
|
|
37
|
+
interface: Capabilities.PluginManager,
|
|
38
|
+
implementation: manager,
|
|
39
|
+
module: 'dxos.org/app-framework/plugin-manager',
|
|
40
|
+
});
|
|
41
|
+
|
|
42
|
+
manager.capabilities.contribute({
|
|
43
|
+
interface: Capabilities.AtomRegistry,
|
|
44
|
+
implementation: manager.registry,
|
|
45
|
+
module: 'dxos.org/app-framework/atom-registry',
|
|
46
|
+
});
|
|
47
|
+
|
|
48
|
+
yield* manager.activate(ActivationEvents.Startup);
|
|
49
|
+
|
|
50
|
+
return manager;
|
|
51
|
+
}),
|
|
52
|
+
);
|
|
@@ -7,9 +7,9 @@ import React from 'react';
|
|
|
7
7
|
|
|
8
8
|
import { withTheme } from '@dxos/react-ui/testing';
|
|
9
9
|
|
|
10
|
-
import { Capabilities
|
|
11
|
-
import {
|
|
12
|
-
import { Surface } from '../
|
|
10
|
+
import { Capabilities } from '../common';
|
|
11
|
+
import { Capability } from '../core';
|
|
12
|
+
import { Surface } from '../ui';
|
|
13
13
|
|
|
14
14
|
import { withPluginManager } from './withPluginManager';
|
|
15
15
|
|
|
@@ -18,7 +18,7 @@ const DefaultStory = () => {
|
|
|
18
18
|
return (
|
|
19
19
|
<div>
|
|
20
20
|
<div>Hello</div>
|
|
21
|
-
<Surface role='main' />
|
|
21
|
+
<Surface.Surface role='main' />
|
|
22
22
|
</div>
|
|
23
23
|
);
|
|
24
24
|
};
|
|
@@ -27,12 +27,12 @@ const meta = {
|
|
|
27
27
|
title: 'sdk/app-framework/withPluginManager',
|
|
28
28
|
render: DefaultStory,
|
|
29
29
|
decorators: [
|
|
30
|
-
withTheme,
|
|
30
|
+
withTheme(),
|
|
31
31
|
withPluginManager({
|
|
32
32
|
capabilities: [
|
|
33
|
-
contributes(
|
|
33
|
+
Capability.contributes(
|
|
34
34
|
Capabilities.ReactSurface,
|
|
35
|
-
|
|
35
|
+
Surface.create({
|
|
36
36
|
id: 'test',
|
|
37
37
|
role: 'main',
|
|
38
38
|
component: ({ role }) => <span>{JSON.stringify({ role })}</span>,
|
|
@@ -2,24 +2,17 @@
|
|
|
2
2
|
// Copyright 2025 DXOS.org
|
|
3
3
|
//
|
|
4
4
|
|
|
5
|
-
import { type Decorator } from '@storybook/react';
|
|
5
|
+
import { type Decorator, type StoryContext } from '@storybook/react';
|
|
6
|
+
import * as Effect from 'effect/Effect';
|
|
6
7
|
import React, { useEffect, useMemo } from 'react';
|
|
7
8
|
|
|
8
9
|
import { raise } from '@dxos/debug';
|
|
9
10
|
import { useAsyncEffect } from '@dxos/react-hooks';
|
|
10
11
|
import { type MaybeProvider, getProviderValue } from '@dxos/util';
|
|
11
12
|
|
|
12
|
-
import {
|
|
13
|
-
import { type
|
|
14
|
-
import {
|
|
15
|
-
type ActivationEvent,
|
|
16
|
-
type AnyCapability,
|
|
17
|
-
type PluginContext,
|
|
18
|
-
PluginManager,
|
|
19
|
-
contributes,
|
|
20
|
-
defineModule,
|
|
21
|
-
definePlugin,
|
|
22
|
-
} from '../core';
|
|
13
|
+
import { ActivationEvents, Capabilities } from '../common';
|
|
14
|
+
import { type ActivationEvent, Capability, type CapabilityManager, Plugin, PluginManager } from '../core';
|
|
15
|
+
import { type UseAppOptions, useApp } from '../ui';
|
|
23
16
|
|
|
24
17
|
/**
|
|
25
18
|
* @internal
|
|
@@ -30,16 +23,16 @@ export const setupPluginManager = ({
|
|
|
30
23
|
core = plugins.map(({ meta }) => meta.id),
|
|
31
24
|
...options
|
|
32
25
|
}: UseAppOptions & Pick<WithPluginManagerOptions, 'capabilities'> = {}) => {
|
|
33
|
-
const pluginManager =
|
|
26
|
+
const pluginManager = PluginManager.make({
|
|
34
27
|
pluginLoader: () => raise(new Error('Not implemented')),
|
|
35
|
-
plugins: [StoryPlugin
|
|
28
|
+
plugins: [StoryPlugin, ...plugins],
|
|
36
29
|
core: [StoryPlugin.meta.id, ...core],
|
|
37
30
|
...options,
|
|
38
31
|
});
|
|
39
32
|
|
|
40
33
|
if (capabilities) {
|
|
41
|
-
getProviderValue(capabilities, pluginManager.
|
|
42
|
-
pluginManager.
|
|
34
|
+
getProviderValue(capabilities, pluginManager.capabilities).forEach((capability) => {
|
|
35
|
+
pluginManager.capabilities.contribute({
|
|
43
36
|
interface: capability.interface,
|
|
44
37
|
implementation: capability.implementation,
|
|
45
38
|
module: 'story',
|
|
@@ -52,33 +45,41 @@ export const setupPluginManager = ({
|
|
|
52
45
|
|
|
53
46
|
export type WithPluginManagerOptions = UseAppOptions & {
|
|
54
47
|
/** @deprecated */
|
|
55
|
-
capabilities?: MaybeProvider<
|
|
48
|
+
capabilities?: MaybeProvider<Capability.Any[], CapabilityManager.CapabilityManager>;
|
|
56
49
|
/** @deprecated */
|
|
57
|
-
fireEvents?: (ActivationEvent | string)[];
|
|
50
|
+
fireEvents?: (ActivationEvent.ActivationEvent | string)[];
|
|
58
51
|
};
|
|
59
52
|
|
|
53
|
+
export type WithPluginManagerInitializer<Args = void> =
|
|
54
|
+
| WithPluginManagerOptions
|
|
55
|
+
| ((context: StoryContext<Args>) => WithPluginManagerOptions);
|
|
56
|
+
|
|
60
57
|
/**
|
|
61
58
|
* Wraps a story with a plugin manager.
|
|
62
59
|
* NOTE: This builds up and tears down the plugin manager on every render.
|
|
63
60
|
*/
|
|
64
|
-
export const withPluginManager = (
|
|
61
|
+
export const withPluginManager = <Args,>(init: WithPluginManagerInitializer<Args> = {}): Decorator => {
|
|
65
62
|
return (Story, context) => {
|
|
66
|
-
const
|
|
63
|
+
const options = typeof init === 'function' ? init(context as any) : init;
|
|
64
|
+
const { pluginManager, setupEvents } = useMemo(
|
|
65
|
+
() => ({ pluginManager: setupPluginManager(options), setupEvents: options.setupEvents }),
|
|
66
|
+
[init],
|
|
67
|
+
);
|
|
67
68
|
|
|
68
69
|
// Set-up root capability.
|
|
69
70
|
useEffect(() => {
|
|
70
|
-
const capability = contributes(Capabilities.ReactRoot, {
|
|
71
|
+
const capability = Capability.contributes(Capabilities.ReactRoot, {
|
|
71
72
|
id: context.id,
|
|
72
73
|
root: () => <Story />,
|
|
73
74
|
});
|
|
74
75
|
|
|
75
|
-
pluginManager.
|
|
76
|
+
pluginManager.capabilities.contribute({
|
|
76
77
|
...capability,
|
|
77
78
|
module: 'dxos.org/app-framework/withPluginManager',
|
|
78
79
|
});
|
|
79
80
|
|
|
80
81
|
return () => {
|
|
81
|
-
pluginManager.
|
|
82
|
+
pluginManager.capabilities.remove(capability.interface, capability.implementation);
|
|
82
83
|
};
|
|
83
84
|
}, [pluginManager, context]);
|
|
84
85
|
|
|
@@ -88,7 +89,7 @@ export const withPluginManager = (options: WithPluginManagerOptions = {}): Decor
|
|
|
88
89
|
}, [pluginManager]);
|
|
89
90
|
|
|
90
91
|
// Create app.
|
|
91
|
-
const App = useApp({ pluginManager });
|
|
92
|
+
const App = useApp({ pluginManager, setupEvents });
|
|
92
93
|
|
|
93
94
|
return <App />;
|
|
94
95
|
};
|
|
@@ -101,6 +102,11 @@ const storyMeta = {
|
|
|
101
102
|
|
|
102
103
|
// No-op plugin to ensure there exists at least one plugin for the startup event.
|
|
103
104
|
// This is necessary because `createApp` expects the startup event to complete before the app is ready.
|
|
104
|
-
const StoryPlugin =
|
|
105
|
-
|
|
106
|
-
|
|
105
|
+
const StoryPlugin = Plugin.define(storyMeta).pipe(
|
|
106
|
+
Plugin.addModule({
|
|
107
|
+
id: 'Story',
|
|
108
|
+
activatesOn: ActivationEvents.Startup,
|
|
109
|
+
activate: () => Effect.succeed([]),
|
|
110
|
+
}),
|
|
111
|
+
Plugin.make,
|
|
112
|
+
)();
|