@dxos/app-framework 0.8.4-main.c1de068 → 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 +9 -0
- package/.storybook/preview.mts +8 -0
- package/.swc/plugins/linux_x86_64_19.0.0/727453fb3a62f7f1d952a41e051ca8a6f88cadc45cee43c6a4d1aa45f9b75665.wasmer-v7 +0 -0
- 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 -156
- 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 +89 -39
- 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 -156
- 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 +89 -39
- 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 -123
- 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 +8 -8
- package/dist/types/src/common/translations.d.ts.map +1 -1
- package/dist/types/src/context.d.ts +5 -0
- package/dist/types/src/context.d.ts.map +1 -0
- package/dist/types/src/core/{events.d.ts → activation-event.d.ts} +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 +97 -32
- 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 +11 -10
- package/dist/types/src/testing/withPluginManager.d.ts.map +1 -1
- package/dist/types/src/testing/withPluginManager.stories.d.ts +9 -3
- package/dist/types/src/testing/withPluginManager.stories.d.ts.map +1 -1
- package/dist/types/src/ui/components/App/App.d.ts +8 -0
- package/dist/types/src/ui/components/App/App.d.ts.map +1 -0
- package/dist/types/src/ui/components/App/App.stories.d.ts +19 -0
- package/dist/types/src/ui/components/App/App.stories.d.ts.map +1 -0
- package/dist/types/src/ui/components/App/index.d.ts +2 -0
- package/dist/types/src/ui/components/App/index.d.ts.map +1 -0
- package/dist/types/src/ui/components/PluginManager/PluginManagerContext.stories.d.ts +13 -0
- package/dist/types/src/ui/components/PluginManager/PluginManagerContext.stories.d.ts.map +1 -0
- package/dist/types/src/ui/components/PluginManager/PluginManagerProvider.d.ts +10 -0
- package/dist/types/src/ui/components/PluginManager/PluginManagerProvider.d.ts.map +1 -0
- package/dist/types/src/ui/components/PluginManager/index.d.ts +2 -0
- package/dist/types/src/ui/components/PluginManager/index.d.ts.map +1 -0
- package/dist/types/src/ui/components/Surface/SurfaceComponent.d.ts +12 -0
- package/dist/types/src/ui/components/Surface/SurfaceComponent.d.ts.map +1 -0
- package/dist/types/src/ui/components/Surface/SurfaceComponent.stories.d.ts +14 -0
- package/dist/types/src/ui/components/Surface/SurfaceComponent.stories.d.ts.map +1 -0
- package/dist/types/src/ui/components/Surface/SurfaceInfo.d.ts +11 -0
- package/dist/types/src/ui/components/Surface/SurfaceInfo.d.ts.map +1 -0
- package/dist/types/src/ui/components/Surface/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/{App.d.ts → ui/hooks/useApp.d.ts} +21 -14
- 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/ui/hooks/useLoading.d.ts +18 -0
- package/dist/types/src/ui/hooks/useLoading.d.ts.map +1 -0
- package/dist/types/src/ui/hooks/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 +11 -3
- package/package.json +113 -44
- package/src/cli/cli.ts +107 -0
- package/src/{playground/layout → cli}/index.ts +1 -1
- package/src/common/activation-events.ts +44 -0
- package/src/common/capabilities.ts +174 -114
- package/src/common/index.ts +4 -8
- package/src/common/operations.ts +38 -0
- package/src/common/translations.ts +18 -10
- 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 +230 -36
- package/src/helpers.test.ts +1 -1
- 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/debug → 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 +15 -11
- package/src/testing/withPluginManager.tsx +47 -45
- package/src/ui/components/App/App.stories.tsx +92 -0
- package/src/ui/components/App/App.tsx +57 -0
- package/src/{playground/logger → 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/ui/hooks/useLoading.tsx +68 -0
- 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 +14 -30
- package/tsconfig.node.json +1 -3
- package/typedoc.json +2 -4
- package/vitest.config.ts +8 -6
- package/.swc/plugins/v7_linux_x86_64_13.0.0/f45bdff002284d9e8f9ef3f0be909de12da36c049cbcf261ac78fc00abb09a2d +0 -0
- package/.swc/plugins/v7_linux_x86_64_13.0.0/fce1bdb8e20a094e4af08bad09cc81497ed0e2e7c51223b07d371063cca18429 +0 -0
- package/dist/lib/browser/app-graph-builder-LYF7EKNN.mjs +0 -137
- package/dist/lib/browser/app-graph-builder-LYF7EKNN.mjs.map +0 -7
- package/dist/lib/browser/chunk-FMN65HSW.mjs +0 -1519
- package/dist/lib/browser/chunk-FMN65HSW.mjs.map +0 -7
- package/dist/lib/browser/chunk-FO2PH7M3.mjs +0 -415
- package/dist/lib/browser/chunk-FO2PH7M3.mjs.map +0 -7
- package/dist/lib/browser/chunk-ORWHM7CO.mjs +0 -32
- package/dist/lib/browser/chunk-ORWHM7CO.mjs.map +0 -7
- package/dist/lib/browser/intent-dispatcher-LSYQZSEB.mjs +0 -11
- package/dist/lib/browser/intent-resolver-ZTNOSO3A.mjs +0 -39
- package/dist/lib/browser/intent-resolver-ZTNOSO3A.mjs.map +0 -7
- package/dist/lib/browser/store-KML2R4IE.mjs +0 -30
- package/dist/lib/browser/store-KML2R4IE.mjs.map +0 -7
- package/dist/lib/browser/worker.mjs +0 -79
- package/dist/lib/node-esm/app-graph-builder-SAOWGJDK.mjs +0 -138
- package/dist/lib/node-esm/app-graph-builder-SAOWGJDK.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-73HGSHKE.mjs +0 -416
- package/dist/lib/node-esm/chunk-73HGSHKE.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-UMZQERLE.mjs +0 -34
- package/dist/lib/node-esm/chunk-UMZQERLE.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-ZEZ4FVEU.mjs +0 -1521
- package/dist/lib/node-esm/chunk-ZEZ4FVEU.mjs.map +0 -7
- package/dist/lib/node-esm/intent-dispatcher-6CYNGPSW.mjs +0 -12
- package/dist/lib/node-esm/intent-resolver-W7Z7WFFM.mjs +0 -40
- package/dist/lib/node-esm/intent-resolver-W7Z7WFFM.mjs.map +0 -7
- package/dist/lib/node-esm/store-QEXGXLWZ.mjs +0 -31
- package/dist/lib/node-esm/store-QEXGXLWZ.mjs.map +0 -7
- package/dist/lib/node-esm/worker.mjs +0 -80
- package/dist/types/src/App.d.ts.map +0 -1
- package/dist/types/src/common/collaboration.d.ts +0 -19
- package/dist/types/src/common/collaboration.d.ts.map +0 -1
- package/dist/types/src/common/events.d.ts +0 -52
- package/dist/types/src/common/events.d.ts.map +0 -1
- package/dist/types/src/common/file.d.ts +0 -14
- package/dist/types/src/common/file.d.ts.map +0 -1
- package/dist/types/src/common/graph.d.ts +0 -21
- package/dist/types/src/common/graph.d.ts.map +0 -1
- package/dist/types/src/common/layout.d.ts +0 -281
- package/dist/types/src/common/layout.d.ts.map +0 -1
- package/dist/types/src/common/surface.d.ts +0 -65
- package/dist/types/src/common/surface.d.ts.map +0 -1
- package/dist/types/src/core/capabilities.d.ts +0 -114
- package/dist/types/src/core/capabilities.d.ts.map +0 -1
- package/dist/types/src/core/capabilities.test.d.ts +0 -2
- package/dist/types/src/core/capabilities.test.d.ts.map +0 -1
- package/dist/types/src/core/events.d.ts.map +0 -1
- package/dist/types/src/core/manager.d.ts +0 -122
- package/dist/types/src/core/manager.d.ts.map +0 -1
- package/dist/types/src/core/manager.test.d.ts +0 -2
- package/dist/types/src/core/manager.test.d.ts.map +0 -1
- package/dist/types/src/playground/debug/Debug.d.ts +0 -6
- package/dist/types/src/playground/debug/Debug.d.ts.map +0 -1
- package/dist/types/src/playground/debug/index.d.ts +0 -2
- package/dist/types/src/playground/debug/index.d.ts.map +0 -1
- package/dist/types/src/playground/debug/plugin.d.ts +0 -2
- package/dist/types/src/playground/debug/plugin.d.ts.map +0 -1
- package/dist/types/src/playground/generator/Main.d.ts +0 -6
- package/dist/types/src/playground/generator/Main.d.ts.map +0 -1
- package/dist/types/src/playground/generator/Toolbar.d.ts +0 -6
- package/dist/types/src/playground/generator/Toolbar.d.ts.map +0 -1
- package/dist/types/src/playground/generator/generator.d.ts +0 -7
- package/dist/types/src/playground/generator/generator.d.ts.map +0 -1
- package/dist/types/src/playground/generator/index.d.ts +0 -3
- package/dist/types/src/playground/generator/index.d.ts.map +0 -1
- package/dist/types/src/playground/generator/plugin.d.ts +0 -2
- package/dist/types/src/playground/generator/plugin.d.ts.map +0 -1
- package/dist/types/src/playground/layout/Layout.d.ts +0 -8
- package/dist/types/src/playground/layout/Layout.d.ts.map +0 -1
- package/dist/types/src/playground/layout/index.d.ts +0 -2
- package/dist/types/src/playground/layout/index.d.ts.map +0 -1
- package/dist/types/src/playground/layout/plugin.d.ts +0 -2
- package/dist/types/src/playground/layout/plugin.d.ts.map +0 -1
- package/dist/types/src/playground/logger/Toolbar.d.ts +0 -6
- package/dist/types/src/playground/logger/Toolbar.d.ts.map +0 -1
- package/dist/types/src/playground/logger/index.d.ts +0 -2
- package/dist/types/src/playground/logger/index.d.ts.map +0 -1
- package/dist/types/src/playground/logger/plugin.d.ts +0 -2
- package/dist/types/src/playground/logger/plugin.d.ts.map +0 -1
- package/dist/types/src/playground/logger/schema.d.ts +0 -13
- package/dist/types/src/playground/logger/schema.d.ts.map +0 -1
- package/dist/types/src/playground/playground.stories.d.ts +0 -10
- package/dist/types/src/playground/playground.stories.d.ts.map +0 -1
- package/dist/types/src/plugin-intent/IntentPlugin.d.ts +0 -2
- package/dist/types/src/plugin-intent/IntentPlugin.d.ts.map +0 -1
- package/dist/types/src/plugin-intent/actions.d.ts +0 -38
- package/dist/types/src/plugin-intent/actions.d.ts.map +0 -1
- package/dist/types/src/plugin-intent/errors.d.ts +0 -16
- package/dist/types/src/plugin-intent/errors.d.ts.map +0 -1
- package/dist/types/src/plugin-intent/index.d.ts +0 -5
- package/dist/types/src/plugin-intent/index.d.ts.map +0 -1
- package/dist/types/src/plugin-intent/intent-dispatcher.d.ts +0 -139
- package/dist/types/src/plugin-intent/intent-dispatcher.d.ts.map +0 -1
- package/dist/types/src/plugin-intent/intent-dispatcher.test.d.ts +0 -2
- package/dist/types/src/plugin-intent/intent-dispatcher.test.d.ts.map +0 -1
- package/dist/types/src/plugin-intent/intent.d.ts +0 -63
- package/dist/types/src/plugin-intent/intent.d.ts.map +0 -1
- package/dist/types/src/plugin-settings/SettingsPlugin.d.ts +0 -2
- package/dist/types/src/plugin-settings/SettingsPlugin.d.ts.map +0 -1
- package/dist/types/src/plugin-settings/actions.d.ts +0 -27
- package/dist/types/src/plugin-settings/actions.d.ts.map +0 -1
- package/dist/types/src/plugin-settings/app-graph-builder.d.ts +0 -4
- package/dist/types/src/plugin-settings/app-graph-builder.d.ts.map +0 -1
- package/dist/types/src/plugin-settings/index.d.ts +0 -3
- package/dist/types/src/plugin-settings/index.d.ts.map +0 -1
- package/dist/types/src/plugin-settings/intent-resolver.d.ts +0 -4
- package/dist/types/src/plugin-settings/intent-resolver.d.ts.map +0 -1
- package/dist/types/src/plugin-settings/store.d.ts +0 -5
- package/dist/types/src/plugin-settings/store.d.ts.map +0 -1
- package/dist/types/src/plugin-settings/translations.d.ts +0 -10
- package/dist/types/src/plugin-settings/translations.d.ts.map +0 -1
- package/dist/types/src/react/ErrorBoundary.d.ts +0 -31
- package/dist/types/src/react/ErrorBoundary.d.ts.map +0 -1
- package/dist/types/src/react/IntentContext.d.ts +0 -8
- package/dist/types/src/react/IntentContext.d.ts.map +0 -1
- package/dist/types/src/react/PluginManagerProvider.d.ts +0 -10
- package/dist/types/src/react/PluginManagerProvider.d.ts.map +0 -1
- package/dist/types/src/react/Surface.d.ts +0 -12
- package/dist/types/src/react/Surface.d.ts.map +0 -1
- package/dist/types/src/react/Surface.stories.d.ts +0 -16
- package/dist/types/src/react/Surface.stories.d.ts.map +0 -1
- package/dist/types/src/react/common.d.ts +0 -13
- package/dist/types/src/react/common.d.ts.map +0 -1
- package/dist/types/src/react/index.d.ts +0 -7
- package/dist/types/src/react/index.d.ts.map +0 -1
- package/dist/types/src/react/useCapabilities.d.ts +0 -13
- package/dist/types/src/react/useCapabilities.d.ts.map +0 -1
- package/dist/types/src/react/useIntentResolver.d.ts +0 -3
- package/dist/types/src/react/useIntentResolver.d.ts.map +0 -1
- package/dist/types/src/worker.d.ts +0 -4
- package/dist/types/src/worker.d.ts.map +0 -1
- package/src/App.tsx +0 -276
- package/src/common/collaboration.ts +0 -21
- package/src/common/events.ts +0 -77
- package/src/common/file.ts +0 -22
- package/src/common/graph.ts +0 -30
- package/src/common/layout.ts +0 -278
- package/src/common/surface.ts +0 -86
- package/src/core/capabilities.test.ts +0 -136
- package/src/core/capabilities.ts +0 -254
- package/src/core/manager.test.ts +0 -515
- package/src/core/manager.ts +0 -519
- package/src/playground/debug/Debug.tsx +0 -39
- package/src/playground/debug/plugin.ts +0 -17
- package/src/playground/generator/Main.tsx +0 -71
- package/src/playground/generator/Toolbar.tsx +0 -46
- package/src/playground/generator/generator.ts +0 -48
- package/src/playground/generator/index.ts +0 -6
- package/src/playground/generator/plugin.ts +0 -23
- package/src/playground/layout/Layout.tsx +0 -33
- package/src/playground/layout/plugin.ts +0 -17
- package/src/playground/logger/Toolbar.tsx +0 -29
- package/src/playground/logger/plugin.ts +0 -36
- package/src/playground/logger/schema.ts +0 -12
- package/src/playground/playground.stories.tsx +0 -42
- package/src/plugin-intent/IntentPlugin.ts +0 -20
- package/src/plugin-intent/actions.ts +0 -33
- package/src/plugin-intent/errors.ts +0 -39
- package/src/plugin-intent/index.ts +0 -8
- package/src/plugin-intent/intent-dispatcher.test.ts +0 -279
- package/src/plugin-intent/intent-dispatcher.ts +0 -333
- package/src/plugin-intent/intent.ts +0 -154
- package/src/plugin-settings/SettingsPlugin.ts +0 -35
- package/src/plugin-settings/actions.ts +0 -29
- package/src/plugin-settings/app-graph-builder.ts +0 -157
- package/src/plugin-settings/index.ts +0 -6
- package/src/plugin-settings/intent-resolver.ts +0 -34
- package/src/plugin-settings/store.ts +0 -33
- package/src/plugin-settings/translations.ts +0 -19
- package/src/react/ErrorBoundary.tsx +0 -45
- package/src/react/IntentContext.tsx +0 -34
- package/src/react/Surface.stories.tsx +0 -96
- package/src/react/Surface.tsx +0 -77
- package/src/react/common.ts +0 -12
- package/src/react/index.ts +0 -10
- package/src/react/useCapabilities.ts +0 -30
- package/src/react/useIntentResolver.ts +0 -22
- package/src/worker.ts +0 -11
- /package/dist/lib/browser/{intent-dispatcher-LSYQZSEB.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-6CYNGPSW.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
|
@@ -1,157 +0,0 @@
|
|
|
1
|
-
//
|
|
2
|
-
// Copyright 2025 DXOS.org
|
|
3
|
-
//
|
|
4
|
-
|
|
5
|
-
import { Rx } from '@effect-rx/rx-react';
|
|
6
|
-
import { Option, pipe } from 'effect';
|
|
7
|
-
|
|
8
|
-
import { createExtension, ROOT_ID } from '@dxos/app-graph';
|
|
9
|
-
import { type SettingsStore, type SettingsValue } from '@dxos/local-storage';
|
|
10
|
-
import { isNonNullable } from '@dxos/util';
|
|
11
|
-
|
|
12
|
-
import { SETTINGS_ID, SETTINGS_KEY, SETTINGS_PLUGIN, SettingsAction } from './actions';
|
|
13
|
-
import { Capabilities } from '../common';
|
|
14
|
-
import { contributes, type PluginMeta, type PluginContext } from '../core';
|
|
15
|
-
import { createIntent } from '../plugin-intent';
|
|
16
|
-
|
|
17
|
-
export default (context: PluginContext) =>
|
|
18
|
-
contributes(Capabilities.AppGraphBuilder, [
|
|
19
|
-
createExtension({
|
|
20
|
-
id: `${SETTINGS_PLUGIN}/action`,
|
|
21
|
-
actions: (node) =>
|
|
22
|
-
Rx.make((get) =>
|
|
23
|
-
pipe(
|
|
24
|
-
get(node),
|
|
25
|
-
Option.flatMap((node) => (node.id === ROOT_ID ? Option.some(node) : Option.none())),
|
|
26
|
-
Option.map(() => [
|
|
27
|
-
{
|
|
28
|
-
id: SETTINGS_PLUGIN,
|
|
29
|
-
data: async () => {
|
|
30
|
-
const { dispatchPromise: dispatch } = context.getCapability(Capabilities.IntentDispatcher);
|
|
31
|
-
await dispatch(createIntent(SettingsAction.Open));
|
|
32
|
-
},
|
|
33
|
-
properties: {
|
|
34
|
-
label: ['open settings label', { ns: SETTINGS_PLUGIN }],
|
|
35
|
-
icon: 'ph--gear--regular',
|
|
36
|
-
disposition: 'menu',
|
|
37
|
-
keyBinding: {
|
|
38
|
-
macos: 'meta+,',
|
|
39
|
-
windows: 'alt+,',
|
|
40
|
-
},
|
|
41
|
-
},
|
|
42
|
-
},
|
|
43
|
-
]),
|
|
44
|
-
Option.getOrElse(() => []),
|
|
45
|
-
),
|
|
46
|
-
),
|
|
47
|
-
}),
|
|
48
|
-
createExtension({
|
|
49
|
-
id: `${SETTINGS_PLUGIN}/core`,
|
|
50
|
-
connector: (node) =>
|
|
51
|
-
Rx.make((get) =>
|
|
52
|
-
pipe(
|
|
53
|
-
get(node),
|
|
54
|
-
Option.flatMap((node) => (node.id === ROOT_ID ? Option.some(node) : Option.none())),
|
|
55
|
-
Option.map(() => [
|
|
56
|
-
{
|
|
57
|
-
id: SETTINGS_ID,
|
|
58
|
-
type: SETTINGS_PLUGIN,
|
|
59
|
-
properties: {
|
|
60
|
-
label: ['app settings label', { ns: SETTINGS_PLUGIN }],
|
|
61
|
-
icon: 'ph--gear--regular',
|
|
62
|
-
disposition: 'pin-end',
|
|
63
|
-
position: 'hoist',
|
|
64
|
-
testId: 'treeView.appSettings',
|
|
65
|
-
},
|
|
66
|
-
},
|
|
67
|
-
]),
|
|
68
|
-
Option.getOrElse(() => []),
|
|
69
|
-
),
|
|
70
|
-
),
|
|
71
|
-
}),
|
|
72
|
-
createExtension({
|
|
73
|
-
id: `${SETTINGS_PLUGIN}/core-plugins`,
|
|
74
|
-
connector: (node) =>
|
|
75
|
-
Rx.make((get) =>
|
|
76
|
-
pipe(
|
|
77
|
-
get(node),
|
|
78
|
-
Option.flatMap((node) => (node.id !== SETTINGS_ID ? Option.none() : Option.some(node))),
|
|
79
|
-
Option.map(() => {
|
|
80
|
-
const manager = get(context.capability(Capabilities.PluginManager));
|
|
81
|
-
const [settingsStore] = get(context.capabilities(Capabilities.SettingsStore));
|
|
82
|
-
return [
|
|
83
|
-
...manager.plugins
|
|
84
|
-
.filter((plugin) => manager.core.includes(plugin.meta.id))
|
|
85
|
-
.map((plugin): [PluginMeta, SettingsStore<SettingsValue>] | null => {
|
|
86
|
-
const settings = settingsStore?.getStore(plugin.meta.id);
|
|
87
|
-
if (!settings) {
|
|
88
|
-
return null;
|
|
89
|
-
}
|
|
90
|
-
|
|
91
|
-
return [plugin.meta, settings];
|
|
92
|
-
})
|
|
93
|
-
.filter(isNonNullable)
|
|
94
|
-
.map(([meta, settings]) => ({
|
|
95
|
-
id: `${SETTINGS_KEY}:${meta.id.replaceAll('/', ':')}`,
|
|
96
|
-
type: 'category',
|
|
97
|
-
data: settings,
|
|
98
|
-
properties: {
|
|
99
|
-
label: meta.name ?? meta.id,
|
|
100
|
-
icon: meta.icon ?? 'ph--circle--regular',
|
|
101
|
-
},
|
|
102
|
-
})),
|
|
103
|
-
|
|
104
|
-
{
|
|
105
|
-
id: `${SETTINGS_KEY}:custom-plugins`,
|
|
106
|
-
type: 'category',
|
|
107
|
-
properties: {
|
|
108
|
-
label: ['custom plugins label', { ns: SETTINGS_PLUGIN }],
|
|
109
|
-
icon: 'ph--squares-four--regular',
|
|
110
|
-
role: 'branch',
|
|
111
|
-
disposition: 'collection',
|
|
112
|
-
},
|
|
113
|
-
},
|
|
114
|
-
];
|
|
115
|
-
}),
|
|
116
|
-
Option.getOrElse(() => []),
|
|
117
|
-
),
|
|
118
|
-
),
|
|
119
|
-
}),
|
|
120
|
-
createExtension({
|
|
121
|
-
id: `${SETTINGS_PLUGIN}/custom-plugins`,
|
|
122
|
-
connector: (node) =>
|
|
123
|
-
Rx.make((get) =>
|
|
124
|
-
pipe(
|
|
125
|
-
get(node),
|
|
126
|
-
Option.flatMap((node) =>
|
|
127
|
-
node.id !== `${SETTINGS_KEY}:custom-plugins` ? Option.none() : Option.some(node),
|
|
128
|
-
),
|
|
129
|
-
Option.map(() => {
|
|
130
|
-
const manager = get(context.capability(Capabilities.PluginManager));
|
|
131
|
-
const [settingsStore] = get(context.capabilities(Capabilities.SettingsStore));
|
|
132
|
-
return manager.plugins
|
|
133
|
-
.filter((plugin) => !manager.core.includes(plugin.meta.id))
|
|
134
|
-
.map((plugin): [PluginMeta, SettingsStore<SettingsValue>] | null => {
|
|
135
|
-
const settings = settingsStore?.getStore(plugin.meta.id);
|
|
136
|
-
if (!settings) {
|
|
137
|
-
return null;
|
|
138
|
-
}
|
|
139
|
-
|
|
140
|
-
return [plugin.meta, settings];
|
|
141
|
-
})
|
|
142
|
-
.filter(isNonNullable)
|
|
143
|
-
.map(([meta, settings]) => ({
|
|
144
|
-
id: `${SETTINGS_KEY}:${meta.id.replaceAll('/', ':')}`,
|
|
145
|
-
type: 'category',
|
|
146
|
-
data: settings,
|
|
147
|
-
properties: {
|
|
148
|
-
label: meta.name ?? meta.id,
|
|
149
|
-
icon: meta.icon ?? 'ph--circle--regular',
|
|
150
|
-
},
|
|
151
|
-
}));
|
|
152
|
-
}),
|
|
153
|
-
Option.getOrElse(() => []),
|
|
154
|
-
),
|
|
155
|
-
),
|
|
156
|
-
}),
|
|
157
|
-
]);
|
|
@@ -1,34 +0,0 @@
|
|
|
1
|
-
//
|
|
2
|
-
// Copyright 2025 DXOS.org
|
|
3
|
-
//
|
|
4
|
-
|
|
5
|
-
import { pipe } from 'effect';
|
|
6
|
-
|
|
7
|
-
import { SETTINGS_ID, SETTINGS_KEY, SettingsAction } from './actions';
|
|
8
|
-
import { Capabilities, LayoutAction } from '../common';
|
|
9
|
-
import { contributes } from '../core';
|
|
10
|
-
import { createResolver, createIntent, chain } from '../plugin-intent';
|
|
11
|
-
|
|
12
|
-
export default () =>
|
|
13
|
-
contributes(
|
|
14
|
-
Capabilities.IntentResolver,
|
|
15
|
-
createResolver({
|
|
16
|
-
intent: SettingsAction.Open,
|
|
17
|
-
resolve: ({ plugin }) => {
|
|
18
|
-
const openSettings = createIntent(LayoutAction.SwitchWorkspace, { part: 'workspace', subject: SETTINGS_ID });
|
|
19
|
-
return {
|
|
20
|
-
intents: [
|
|
21
|
-
plugin
|
|
22
|
-
? pipe(
|
|
23
|
-
openSettings,
|
|
24
|
-
chain(LayoutAction.Open, {
|
|
25
|
-
part: 'main',
|
|
26
|
-
subject: [`${SETTINGS_KEY}:${plugin.replaceAll('/', ':')}`],
|
|
27
|
-
}),
|
|
28
|
-
)
|
|
29
|
-
: openSettings,
|
|
30
|
-
],
|
|
31
|
-
};
|
|
32
|
-
},
|
|
33
|
-
}),
|
|
34
|
-
);
|
|
@@ -1,33 +0,0 @@
|
|
|
1
|
-
//
|
|
2
|
-
// Copyright 2025 DXOS.org
|
|
3
|
-
//
|
|
4
|
-
|
|
5
|
-
import { RootSettingsStore } from '@dxos/local-storage';
|
|
6
|
-
|
|
7
|
-
import { Capabilities } from '../common';
|
|
8
|
-
import { contributes, type PluginContext } from '../core';
|
|
9
|
-
|
|
10
|
-
export default (context: PluginContext) => {
|
|
11
|
-
// TODO(wittjosiah): Replace with rx?
|
|
12
|
-
const settingsStore = new RootSettingsStore();
|
|
13
|
-
|
|
14
|
-
let previous: Capabilities.Settings[] = [];
|
|
15
|
-
const registry = context.getCapability(Capabilities.RxRegistry);
|
|
16
|
-
const cancel = registry.subscribe(
|
|
17
|
-
context.capabilities(Capabilities.Settings),
|
|
18
|
-
(allSettings) => {
|
|
19
|
-
const added = allSettings.filter((setting) => !previous.includes(setting));
|
|
20
|
-
const removed = previous.filter((setting) => !allSettings.includes(setting));
|
|
21
|
-
previous = allSettings;
|
|
22
|
-
added.forEach((setting) => {
|
|
23
|
-
settingsStore.createStore(setting as any);
|
|
24
|
-
});
|
|
25
|
-
removed.forEach((setting) => {
|
|
26
|
-
settingsStore.removeStore(setting.prefix);
|
|
27
|
-
});
|
|
28
|
-
},
|
|
29
|
-
{ immediate: true },
|
|
30
|
-
);
|
|
31
|
-
|
|
32
|
-
return contributes(Capabilities.SettingsStore, settingsStore, () => cancel());
|
|
33
|
-
};
|
|
@@ -1,19 +0,0 @@
|
|
|
1
|
-
//
|
|
2
|
-
// Copyright 2023 DXOS.org
|
|
3
|
-
//
|
|
4
|
-
|
|
5
|
-
import { type Resource } from '@dxos/react-ui';
|
|
6
|
-
|
|
7
|
-
import { SETTINGS_PLUGIN } from './actions';
|
|
8
|
-
|
|
9
|
-
export const translations = [
|
|
10
|
-
{
|
|
11
|
-
'en-US': {
|
|
12
|
-
[SETTINGS_PLUGIN]: {
|
|
13
|
-
'open settings label': 'Open settings',
|
|
14
|
-
'app settings label': 'Settings',
|
|
15
|
-
'custom plugins label': 'Plugins',
|
|
16
|
-
},
|
|
17
|
-
},
|
|
18
|
-
},
|
|
19
|
-
] as const satisfies Resource[];
|
|
@@ -1,45 +0,0 @@
|
|
|
1
|
-
//
|
|
2
|
-
// Copyright 2023 DXOS.org
|
|
3
|
-
//
|
|
4
|
-
|
|
5
|
-
import React, { Component, type FC, type PropsWithChildren } from 'react';
|
|
6
|
-
|
|
7
|
-
type Props = PropsWithChildren<{ data?: any; fallback: FC<{ data?: any; error: Error; reset: () => void }> }>;
|
|
8
|
-
type State = { error: Error | undefined };
|
|
9
|
-
|
|
10
|
-
/**
|
|
11
|
-
* Surface error boundary.
|
|
12
|
-
*
|
|
13
|
-
* For basic usage prefer providing a fallback component to `Surface`.
|
|
14
|
-
*
|
|
15
|
-
* For more information on error boundaries, see:
|
|
16
|
-
* https://react.dev/reference/react/Component#catching-rendering-errors-with-an-error-boundary
|
|
17
|
-
*/
|
|
18
|
-
export class ErrorBoundary extends Component<Props, State> {
|
|
19
|
-
constructor(props: Props) {
|
|
20
|
-
super(props);
|
|
21
|
-
this.state = { error: undefined };
|
|
22
|
-
}
|
|
23
|
-
|
|
24
|
-
static getDerivedStateFromError(error: Error): { error: Error } {
|
|
25
|
-
return { error };
|
|
26
|
-
}
|
|
27
|
-
|
|
28
|
-
override componentDidUpdate(prevProps: Props): void {
|
|
29
|
-
if (prevProps.data !== this.props.data) {
|
|
30
|
-
this.resetError();
|
|
31
|
-
}
|
|
32
|
-
}
|
|
33
|
-
|
|
34
|
-
override render(): string | number | boolean | React.JSX.Element | Iterable<React.ReactNode> | null | undefined {
|
|
35
|
-
if (this.state.error) {
|
|
36
|
-
return <this.props.fallback data={this.props.data} error={this.state.error} reset={this.resetError} />;
|
|
37
|
-
}
|
|
38
|
-
|
|
39
|
-
return this.props.children;
|
|
40
|
-
}
|
|
41
|
-
|
|
42
|
-
private resetError(): void {
|
|
43
|
-
this.setState({ error: undefined });
|
|
44
|
-
}
|
|
45
|
-
}
|
|
@@ -1,34 +0,0 @@
|
|
|
1
|
-
//
|
|
2
|
-
// Copyright 2023 DXOS.org
|
|
3
|
-
//
|
|
4
|
-
|
|
5
|
-
import { type Context, createContext, useContext, type Provider, useEffect } from 'react';
|
|
6
|
-
|
|
7
|
-
import { raise } from '@dxos/debug';
|
|
8
|
-
import { pick } from '@dxos/util';
|
|
9
|
-
|
|
10
|
-
import { usePluginManager } from './PluginManagerProvider';
|
|
11
|
-
import { Capabilities } from '../common';
|
|
12
|
-
import { type AnyIntentResolver, type IntentContext } from '../plugin-intent';
|
|
13
|
-
|
|
14
|
-
const IntentContext: Context<IntentContext | undefined> = createContext<IntentContext | undefined>(undefined);
|
|
15
|
-
|
|
16
|
-
export const useIntentDispatcher = (): Pick<IntentContext, 'dispatch' | 'dispatchPromise'> => {
|
|
17
|
-
const context = useContext(IntentContext) ?? raise(new Error('IntentContext not found'));
|
|
18
|
-
return pick(context, ['dispatch', 'dispatchPromise']);
|
|
19
|
-
};
|
|
20
|
-
|
|
21
|
-
export const useIntentResolver = (module: string, resolver: AnyIntentResolver) => {
|
|
22
|
-
const manager = usePluginManager();
|
|
23
|
-
useEffect(() => {
|
|
24
|
-
manager.context.contributeCapability({
|
|
25
|
-
module,
|
|
26
|
-
interface: Capabilities.IntentResolver,
|
|
27
|
-
implementation: resolver,
|
|
28
|
-
});
|
|
29
|
-
|
|
30
|
-
return () => manager.context.removeCapability(Capabilities.IntentResolver, resolver);
|
|
31
|
-
}, [module, resolver]);
|
|
32
|
-
};
|
|
33
|
-
|
|
34
|
-
export const IntentProvider: Provider<IntentContext | undefined> = IntentContext.Provider;
|
|
@@ -1,96 +0,0 @@
|
|
|
1
|
-
//
|
|
2
|
-
// Copyright 2025 DXOS.org
|
|
3
|
-
//
|
|
4
|
-
|
|
5
|
-
import '@dxos-theme';
|
|
6
|
-
|
|
7
|
-
import React, { useCallback, useState } from 'react';
|
|
8
|
-
|
|
9
|
-
import { faker } from '@dxos/random';
|
|
10
|
-
import { Button, List, ListItem } from '@dxos/react-ui';
|
|
11
|
-
import { withLayout, withTheme } from '@dxos/storybook-utils';
|
|
12
|
-
|
|
13
|
-
import { PluginManagerProvider, usePluginManager } from './PluginManagerProvider';
|
|
14
|
-
import { Surface, useSurfaces } from './Surface';
|
|
15
|
-
import { Capabilities, createSurface } from '../common';
|
|
16
|
-
import { type PluginManager } from '../core';
|
|
17
|
-
import { setupPluginManager } from '../testing';
|
|
18
|
-
|
|
19
|
-
const randomColor = (): string => {
|
|
20
|
-
const hue = faker.number.int({ min: 0, max: 360 });
|
|
21
|
-
const saturation = faker.number.int({ min: 50, max: 90 });
|
|
22
|
-
const lightness = faker.number.int({ min: 40, max: 70 });
|
|
23
|
-
return `hsl(${hue}, ${saturation}%, ${lightness}%)`;
|
|
24
|
-
};
|
|
25
|
-
|
|
26
|
-
const Story = () => {
|
|
27
|
-
const manager = usePluginManager();
|
|
28
|
-
const surfaces = useSurfaces();
|
|
29
|
-
const [picked, setPicked] = useState('test');
|
|
30
|
-
|
|
31
|
-
const handleAdd = useCallback(() => {
|
|
32
|
-
const id = `test-${faker.number.int({ min: 0, max: 1_000_000 })}`;
|
|
33
|
-
const backgroundColor = randomColor();
|
|
34
|
-
|
|
35
|
-
manager.context.contributeCapability({
|
|
36
|
-
module: 'test',
|
|
37
|
-
interface: Capabilities.ReactSurface,
|
|
38
|
-
implementation: createSurface({
|
|
39
|
-
id,
|
|
40
|
-
role: id,
|
|
41
|
-
component: () => (
|
|
42
|
-
<div className='flex-1' style={{ backgroundColor }}>
|
|
43
|
-
{id}
|
|
44
|
-
</div>
|
|
45
|
-
),
|
|
46
|
-
}),
|
|
47
|
-
});
|
|
48
|
-
|
|
49
|
-
setPicked(id);
|
|
50
|
-
}, [manager]);
|
|
51
|
-
|
|
52
|
-
const handlePick = useCallback(() => {
|
|
53
|
-
setPicked(faker.helpers.arrayElement(surfaces).id);
|
|
54
|
-
}, [surfaces]);
|
|
55
|
-
|
|
56
|
-
return (
|
|
57
|
-
<div className='flex flex-col gap-2'>
|
|
58
|
-
<div className='flex gap-2'>
|
|
59
|
-
<Button onClick={handleAdd}>Add</Button>
|
|
60
|
-
<Button onClick={handlePick}>Pick</Button>
|
|
61
|
-
</div>
|
|
62
|
-
<div className='flex gap-2'>
|
|
63
|
-
<div className='flex-1'>
|
|
64
|
-
<List itemSizes='one'>
|
|
65
|
-
{surfaces.map((surface) => (
|
|
66
|
-
<ListItem.Root key={surface.id} id={surface.id}>
|
|
67
|
-
<ListItem.Heading classNames='grow pbs-2'>{surface.id}</ListItem.Heading>
|
|
68
|
-
</ListItem.Root>
|
|
69
|
-
))}
|
|
70
|
-
</List>
|
|
71
|
-
</div>
|
|
72
|
-
<div className='flex-1'>
|
|
73
|
-
<Surface role={picked} limit={1} />
|
|
74
|
-
</div>
|
|
75
|
-
</div>
|
|
76
|
-
</div>
|
|
77
|
-
);
|
|
78
|
-
};
|
|
79
|
-
|
|
80
|
-
export default {
|
|
81
|
-
title: 'sdk/app-framework/Surface',
|
|
82
|
-
render: ({ manager }: { manager: PluginManager }) => {
|
|
83
|
-
return (
|
|
84
|
-
<PluginManagerProvider value={manager}>
|
|
85
|
-
<Story />
|
|
86
|
-
</PluginManagerProvider>
|
|
87
|
-
);
|
|
88
|
-
},
|
|
89
|
-
// NOTE: Intentionally not using withPluginManager to try to reduce surface area of the story.
|
|
90
|
-
decorators: [withTheme, withLayout()],
|
|
91
|
-
args: {
|
|
92
|
-
manager: setupPluginManager(),
|
|
93
|
-
},
|
|
94
|
-
};
|
|
95
|
-
|
|
96
|
-
export const Default = {};
|
package/src/react/Surface.tsx
DELETED
|
@@ -1,77 +0,0 @@
|
|
|
1
|
-
//
|
|
2
|
-
// Copyright 2025 DXOS.org
|
|
3
|
-
//
|
|
4
|
-
|
|
5
|
-
import React, { memo, forwardRef, Suspense, useMemo, Fragment } from 'react';
|
|
6
|
-
|
|
7
|
-
import { useDefaultValue } from '@dxos/react-hooks';
|
|
8
|
-
import { byPosition } from '@dxos/util';
|
|
9
|
-
|
|
10
|
-
import { ErrorBoundary } from './ErrorBoundary';
|
|
11
|
-
import { useCapabilities } from './useCapabilities';
|
|
12
|
-
import { Capabilities, type SurfaceDefinition, type SurfaceProps } from '../common';
|
|
13
|
-
import { type PluginContext } from '../core';
|
|
14
|
-
|
|
15
|
-
const DEFAULT_PLACEHOLDER = <Fragment />;
|
|
16
|
-
|
|
17
|
-
/**
|
|
18
|
-
* @internal
|
|
19
|
-
*/
|
|
20
|
-
export const useSurfaces = () => {
|
|
21
|
-
const surfaces = useCapabilities(Capabilities.ReactSurface);
|
|
22
|
-
return useMemo(() => surfaces.flat(), [surfaces]);
|
|
23
|
-
};
|
|
24
|
-
|
|
25
|
-
const findCandidates = (surfaces: SurfaceDefinition[], { role, data }: Pick<SurfaceProps, 'role' | 'data'>) => {
|
|
26
|
-
return Object.values(surfaces)
|
|
27
|
-
.filter((definition) =>
|
|
28
|
-
Array.isArray(definition.role) ? definition.role.includes(role) : definition.role === role,
|
|
29
|
-
)
|
|
30
|
-
.filter(({ filter }) => (filter ? filter(data ?? {}) : true))
|
|
31
|
-
.toSorted(byPosition);
|
|
32
|
-
};
|
|
33
|
-
|
|
34
|
-
/**
|
|
35
|
-
* @returns `true` if there is a contributed surface which matches the specified role & data, `false` otherwise.
|
|
36
|
-
*/
|
|
37
|
-
export const isSurfaceAvailable = (context: PluginContext, { role, data }: Pick<SurfaceProps, 'role' | 'data'>) => {
|
|
38
|
-
const surfaces = context.getCapabilities(Capabilities.ReactSurface);
|
|
39
|
-
const candidates = findCandidates(surfaces.flat(), { role, data });
|
|
40
|
-
return candidates.length > 0;
|
|
41
|
-
};
|
|
42
|
-
|
|
43
|
-
/**
|
|
44
|
-
* A surface is a named region of the screen that can be populated by plugins.
|
|
45
|
-
*/
|
|
46
|
-
export const Surface = memo(
|
|
47
|
-
forwardRef<HTMLElement, SurfaceProps>(
|
|
48
|
-
({ id: _id, role, data: _data, limit, fallback, placeholder = DEFAULT_PLACEHOLDER, ...rest }, forwardedRef) => {
|
|
49
|
-
// TODO(wittjosiah): This will make all surfaces depend on a single signal.
|
|
50
|
-
// This isn't ideal because it means that any change to the data will cause all surfaces to re-render.
|
|
51
|
-
// This effectively means that plugin modules which contribute surfaces need to all be activated at startup.
|
|
52
|
-
// This should be fine for now because it's how it worked prior to capabilities api anyways.
|
|
53
|
-
// In the future, it would be nice to be able to bucket the surface contributions by role.
|
|
54
|
-
const surfaces = useSurfaces();
|
|
55
|
-
const data = useDefaultValue(_data, () => ({}));
|
|
56
|
-
|
|
57
|
-
// NOTE: Memoizing the candidates makes the surface not re-render based on reactivity within data.
|
|
58
|
-
const definitions = findCandidates(surfaces, { role, data });
|
|
59
|
-
const candidates = limit ? definitions.slice(0, limit) : definitions;
|
|
60
|
-
const nodes = candidates.map(({ component: Component, id }) => (
|
|
61
|
-
<Component ref={forwardedRef} key={id} id={id} role={role} data={data} limit={limit} {...rest} />
|
|
62
|
-
));
|
|
63
|
-
|
|
64
|
-
const suspense = <Suspense fallback={placeholder}>{nodes}</Suspense>;
|
|
65
|
-
|
|
66
|
-
return fallback ? (
|
|
67
|
-
<ErrorBoundary data={data} fallback={fallback}>
|
|
68
|
-
{suspense}
|
|
69
|
-
</ErrorBoundary>
|
|
70
|
-
) : (
|
|
71
|
-
suspense
|
|
72
|
-
);
|
|
73
|
-
},
|
|
74
|
-
),
|
|
75
|
-
);
|
|
76
|
-
|
|
77
|
-
Surface.displayName = 'Surface';
|
package/src/react/common.ts
DELETED
|
@@ -1,12 +0,0 @@
|
|
|
1
|
-
//
|
|
2
|
-
// Copyright 2025 DXOS.org
|
|
3
|
-
//
|
|
4
|
-
|
|
5
|
-
import { useCapability } from './useCapabilities';
|
|
6
|
-
import { Capabilities } from '../common';
|
|
7
|
-
|
|
8
|
-
export const useIntentDispatcher = () => useCapability(Capabilities.IntentDispatcher);
|
|
9
|
-
|
|
10
|
-
export const useAppGraph = () => useCapability(Capabilities.AppGraph);
|
|
11
|
-
|
|
12
|
-
export const useLayout = () => useCapability(Capabilities.Layout);
|
package/src/react/index.ts
DELETED
|
@@ -1,30 +0,0 @@
|
|
|
1
|
-
//
|
|
2
|
-
// Copyright 2025 DXOS.org
|
|
3
|
-
//
|
|
4
|
-
|
|
5
|
-
import { useRxValue } from '@effect-rx/rx-react';
|
|
6
|
-
|
|
7
|
-
import { invariant } from '@dxos/invariant';
|
|
8
|
-
|
|
9
|
-
import { usePluginManager } from './PluginManagerProvider';
|
|
10
|
-
import { type InterfaceDef } from '../core';
|
|
11
|
-
|
|
12
|
-
/**
|
|
13
|
-
* Hook to request capabilities from the plugin context.
|
|
14
|
-
* @returns An array of capabilities.
|
|
15
|
-
*/
|
|
16
|
-
export const useCapabilities = <T>(interfaceDef: InterfaceDef<T>) => {
|
|
17
|
-
const manager = usePluginManager();
|
|
18
|
-
return useRxValue(manager.context.capabilities(interfaceDef));
|
|
19
|
-
};
|
|
20
|
-
|
|
21
|
-
/**
|
|
22
|
-
* Hook to request a capability from the plugin context.
|
|
23
|
-
* @returns The capability.
|
|
24
|
-
* @throws If no capability is found.
|
|
25
|
-
*/
|
|
26
|
-
export const useCapability = <T>(interfaceDef: InterfaceDef<T>) => {
|
|
27
|
-
const capabilities = useCapabilities(interfaceDef);
|
|
28
|
-
invariant(capabilities.length > 0, `No capability found for ${interfaceDef.identifier}`);
|
|
29
|
-
return capabilities[0];
|
|
30
|
-
};
|
|
@@ -1,22 +0,0 @@
|
|
|
1
|
-
//
|
|
2
|
-
// Copyright 2023 DXOS.org
|
|
3
|
-
//
|
|
4
|
-
|
|
5
|
-
import { useEffect } from 'react';
|
|
6
|
-
|
|
7
|
-
import { Capabilities } from '../common';
|
|
8
|
-
import { type AnyIntentResolver } from '../plugin-intent';
|
|
9
|
-
import { usePluginManager } from '../react';
|
|
10
|
-
|
|
11
|
-
export const useIntentResolver = (module: string, resolver: AnyIntentResolver) => {
|
|
12
|
-
const manager = usePluginManager();
|
|
13
|
-
useEffect(() => {
|
|
14
|
-
manager.context.contributeCapability({
|
|
15
|
-
module,
|
|
16
|
-
interface: Capabilities.IntentResolver,
|
|
17
|
-
implementation: resolver,
|
|
18
|
-
});
|
|
19
|
-
|
|
20
|
-
return () => manager.context.removeCapability(Capabilities.IntentResolver, resolver);
|
|
21
|
-
}, [module, resolver]);
|
|
22
|
-
};
|
package/src/worker.ts
DELETED
|
@@ -1,11 +0,0 @@
|
|
|
1
|
-
//
|
|
2
|
-
// Copyright 2025 DXOS.org
|
|
3
|
-
//
|
|
4
|
-
|
|
5
|
-
// Entrypoint for using plugins in workers runtimes (e.g. Cloudflare Workers, etc.)
|
|
6
|
-
// Excludes all frontend code & dependencies (e.g. localStorage, React, etc.)
|
|
7
|
-
|
|
8
|
-
export * from './core';
|
|
9
|
-
// NOTE: Common includes browser capabilities but they are types only.
|
|
10
|
-
export * from './common';
|
|
11
|
-
export * from './plugin-intent';
|
|
File without changes
|
|
File without changes
|
|
File without changes
|
|
File without changes
|