@dxos/plugin-assistant 0.8.4-main.c85a9c8dae → 0.8.4-main.d9fc60f731
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/LICENSE +102 -5
- package/PLUGIN.mdl +439 -0
- package/README.md +1 -1
- package/dist/lib/neutral/AgentArticle-OYQPCK3Q.mjs +161 -0
- package/dist/lib/neutral/AgentArticle-OYQPCK3Q.mjs.map +7 -0
- package/dist/lib/neutral/AgentProperties-W6LD56IB.mjs +40 -0
- package/dist/lib/neutral/AgentProperties-W6LD56IB.mjs.map +7 -0
- package/dist/lib/neutral/AssistantPlugin.mjs +10 -0
- package/dist/lib/neutral/AssistantPlugin.node.mjs +66 -0
- package/dist/lib/neutral/AssistantPlugin.node.mjs.map +7 -0
- package/dist/lib/neutral/AssistantPlugin.workerd.mjs +40 -0
- package/dist/lib/neutral/AssistantPlugin.workerd.mjs.map +7 -0
- package/dist/lib/neutral/AssistantSettings-GG52BLKS.mjs +40 -0
- package/dist/lib/neutral/AssistantSettings-GG52BLKS.mjs.map +7 -0
- package/dist/lib/{browser/BlueprintArticle-CCS25MNW.mjs → neutral/BlueprintArticle-ZBOZNZM7.mjs} +7 -16
- package/dist/lib/neutral/BlueprintArticle-ZBOZNZM7.mjs.map +7 -0
- package/dist/lib/neutral/ChatArticle-PWD4OEFZ.mjs +8 -0
- package/dist/lib/neutral/ChatCompanion-TPY7HF3C.mjs +122 -0
- package/dist/lib/neutral/ChatCompanion-TPY7HF3C.mjs.map +7 -0
- package/dist/lib/{browser/ChatDialog-AET7GVIB.mjs → neutral/ChatDialog-DCA6FLOV.mjs} +16 -28
- package/dist/lib/neutral/ChatDialog-DCA6FLOV.mjs.map +7 -0
- package/dist/lib/neutral/PlanArticle-TS5ULWYS.mjs +28 -0
- package/dist/lib/neutral/PlanArticle-TS5ULWYS.mjs.map +7 -0
- package/dist/lib/neutral/RoutineArticle-5NYXHRG6.mjs +119 -0
- package/dist/lib/neutral/RoutineArticle-5NYXHRG6.mjs.map +7 -0
- package/dist/lib/neutral/RoutineList-SO5ETHNT.mjs +48 -0
- package/dist/lib/neutral/RoutineList-SO5ETHNT.mjs.map +7 -0
- package/dist/lib/neutral/RoutineProperties-FISLMW2R.mjs +17 -0
- package/dist/lib/neutral/RoutineProperties-FISLMW2R.mjs.map +7 -0
- package/dist/lib/neutral/TracePanel-CHJHFTTQ.mjs +136 -0
- package/dist/lib/neutral/TracePanel-CHJHFTTQ.mjs.map +7 -0
- package/dist/lib/neutral/TriggerStatus-X7Y5JFZJ.mjs +93 -0
- package/dist/lib/neutral/TriggerStatus-X7Y5JFZJ.mjs.map +7 -0
- package/dist/lib/neutral/ai-context-IABBIEHG.mjs +42 -0
- package/dist/lib/neutral/ai-context-IABBIEHG.mjs.map +7 -0
- package/dist/lib/neutral/ai-service-3SH2UQIR.mjs +42 -0
- package/dist/lib/neutral/ai-service-3SH2UQIR.mjs.map +7 -0
- package/dist/lib/neutral/app-graph-builder-RJW5O57E.mjs +199 -0
- package/dist/lib/neutral/app-graph-builder-RJW5O57E.mjs.map +7 -0
- package/dist/lib/neutral/blueprint-definition-VXJYQ5AE.mjs +32 -0
- package/dist/lib/neutral/blueprint-definition-VXJYQ5AE.mjs.map +7 -0
- package/dist/lib/{browser → neutral}/blueprints/index.mjs +1 -1
- package/dist/lib/neutral/capabilities/index.mjs +37 -0
- package/dist/lib/neutral/capabilities/index.mjs.map +7 -0
- package/dist/lib/neutral/chunk-47OH7ZF6.mjs +8 -0
- package/dist/lib/neutral/chunk-47OH7ZF6.mjs.map +7 -0
- package/dist/lib/neutral/chunk-5H6UJHLF.mjs +30 -0
- package/dist/lib/neutral/chunk-5H6UJHLF.mjs.map +7 -0
- package/dist/lib/neutral/chunk-6BUTAYVO.mjs +123 -0
- package/dist/lib/neutral/chunk-6BUTAYVO.mjs.map +7 -0
- package/dist/lib/neutral/chunk-A2XIILMZ.mjs +107 -0
- package/dist/lib/neutral/chunk-A2XIILMZ.mjs.map +7 -0
- package/dist/lib/neutral/chunk-UWI53RCD.mjs +386 -0
- package/dist/lib/neutral/chunk-UWI53RCD.mjs.map +7 -0
- package/dist/lib/neutral/chunk-XYHPOGTK.mjs +43 -0
- package/dist/lib/neutral/chunk-XYHPOGTK.mjs.map +7 -0
- package/dist/lib/neutral/companion-chat-provisioner-7RTSXL6M.mjs +116 -0
- package/dist/lib/neutral/companion-chat-provisioner-7RTSXL6M.mjs.map +7 -0
- package/dist/lib/neutral/components/index.mjs +2384 -0
- package/dist/lib/neutral/components/index.mjs.map +7 -0
- package/dist/lib/neutral/containers/index.mjs +29 -0
- package/dist/lib/neutral/containers/index.mjs.map +7 -0
- package/dist/lib/neutral/create-chat-67GZNG3T.mjs +54 -0
- package/dist/lib/neutral/create-chat-67GZNG3T.mjs.map +7 -0
- package/dist/lib/neutral/create-object-XPVVVEKF.mjs +89 -0
- package/dist/lib/neutral/create-object-XPVVVEKF.mjs.map +7 -0
- package/dist/lib/neutral/edge-model-resolver-7SMCGDRL.mjs +50 -0
- package/dist/lib/neutral/edge-model-resolver-7SMCGDRL.mjs.map +7 -0
- package/dist/lib/neutral/ensure-companion-chat-AMOF3C66.mjs +58 -0
- package/dist/lib/neutral/ensure-companion-chat-AMOF3C66.mjs.map +7 -0
- package/dist/lib/neutral/execution-graph/index.mjs +658 -0
- package/dist/lib/neutral/execution-graph/index.mjs.map +7 -0
- package/dist/lib/neutral/hooks/index.mjs +965 -0
- package/dist/lib/neutral/hooks/index.mjs.map +7 -0
- package/dist/lib/neutral/index.mjs +32 -0
- package/dist/lib/{browser/local-model-resolver-CGRQH37T.mjs → neutral/local-model-resolver-I2BENFFS.mjs} +8 -4
- package/dist/lib/neutral/local-model-resolver-I2BENFFS.mjs.map +7 -0
- package/dist/lib/neutral/markdown-KTBFOMFM.mjs +110 -0
- package/dist/lib/neutral/markdown-KTBFOMFM.mjs.map +7 -0
- package/dist/lib/neutral/meta.json +1 -0
- package/dist/lib/neutral/meta.mjs +12 -0
- package/dist/lib/neutral/migrations-7DEMVBOG.mjs +28 -0
- package/dist/lib/neutral/migrations-7DEMVBOG.mjs.map +7 -0
- package/dist/lib/neutral/on-create-space-Q2R7OSP6.mjs +19 -0
- package/dist/lib/neutral/on-create-space-Q2R7OSP6.mjs.map +7 -0
- package/dist/lib/neutral/operation-handler-SF36MOB5.mjs +13 -0
- package/dist/lib/neutral/operation-handler-SF36MOB5.mjs.map +7 -0
- package/dist/lib/neutral/operations/index.mjs +8 -0
- package/dist/lib/neutral/plugin.mjs +16 -0
- package/dist/lib/neutral/plugin.mjs.map +7 -0
- package/dist/lib/neutral/react-surface-XRTBW5OJ.mjs +174 -0
- package/dist/lib/neutral/react-surface-XRTBW5OJ.mjs.map +7 -0
- package/dist/lib/neutral/resolve-navigation-targets-ZHIMMH7L.mjs +22 -0
- package/dist/lib/neutral/resolve-navigation-targets-ZHIMMH7L.mjs.map +7 -0
- package/dist/lib/neutral/run-prompt-in-new-chat-NRDYPCJK.mjs +102 -0
- package/dist/lib/neutral/run-prompt-in-new-chat-NRDYPCJK.mjs.map +7 -0
- package/dist/lib/neutral/set-current-chat-VWBPSIMZ.mjs +48 -0
- package/dist/lib/neutral/set-current-chat-VWBPSIMZ.mjs.map +7 -0
- package/dist/lib/{browser/settings-YREVQAZ5.mjs → neutral/settings-W4BLWQ53.mjs} +6 -11
- package/dist/lib/neutral/settings-W4BLWQ53.mjs.map +7 -0
- package/dist/lib/neutral/state-H3G7QCU6.mjs +28 -0
- package/dist/lib/neutral/state-H3G7QCU6.mjs.map +7 -0
- package/dist/lib/neutral/testing.mjs +8 -0
- package/dist/lib/neutral/toggle-trace-panel-debug-JGTB6KVJ.mjs +21 -0
- package/dist/lib/neutral/toggle-trace-panel-debug-JGTB6KVJ.mjs.map +7 -0
- package/dist/lib/neutral/toolkit-GVWXPDLJ.mjs +14 -0
- package/dist/lib/neutral/toolkit-GVWXPDLJ.mjs.map +7 -0
- package/dist/lib/neutral/translations.mjs +175 -0
- package/dist/lib/neutral/translations.mjs.map +7 -0
- package/dist/lib/neutral/types/index.mjs +20 -0
- package/dist/lib/neutral/types/index.mjs.map +7 -0
- package/dist/lib/neutral/update-chat-name-ENXRUMDJ.mjs +54 -0
- package/dist/lib/neutral/update-chat-name-ENXRUMDJ.mjs.map +7 -0
- package/dist/types/src/AssistantPlugin.d.ts +3 -1
- package/dist/types/src/AssistantPlugin.d.ts.map +1 -1
- package/dist/types/src/AssistantPlugin.node.d.ts +5 -0
- package/dist/types/src/AssistantPlugin.node.d.ts.map +1 -0
- package/dist/types/src/AssistantPlugin.test.d.ts +2 -0
- package/dist/types/src/AssistantPlugin.test.d.ts.map +1 -0
- package/dist/types/src/AssistantPlugin.workerd.d.ts +4 -0
- package/dist/types/src/AssistantPlugin.workerd.d.ts.map +1 -0
- package/dist/types/src/blueprints/assistant/blueprint.d.ts +2 -2
- package/dist/types/src/blueprints/assistant/blueprint.d.ts.map +1 -1
- package/dist/types/src/blueprints/assistant/blueprint.node.test.d.ts +2 -0
- package/dist/types/src/blueprints/assistant/blueprint.node.test.d.ts.map +1 -0
- package/dist/types/src/capabilities/ai-context.d.ts +6 -0
- package/dist/types/src/capabilities/ai-context.d.ts.map +1 -0
- package/dist/types/src/capabilities/ai-service.d.ts +6 -0
- package/dist/types/src/capabilities/ai-service.d.ts.map +1 -0
- package/dist/types/src/capabilities/app-graph-builder.d.ts.map +1 -0
- package/dist/types/src/capabilities/blueprint-definition.d.ts +5 -0
- package/dist/types/src/capabilities/blueprint-definition.d.ts.map +1 -0
- package/dist/types/src/capabilities/companion-chat-provisioner.d.ts +9 -0
- package/dist/types/src/capabilities/companion-chat-provisioner.d.ts.map +1 -0
- package/dist/types/src/capabilities/create-object.d.ts +31 -0
- package/dist/types/src/capabilities/create-object.d.ts.map +1 -0
- package/dist/types/src/capabilities/{edge-model-resolver/edge-model-resolver.d.ts → edge-model-resolver.d.ts} +1 -1
- package/dist/types/src/capabilities/edge-model-resolver.d.ts.map +1 -0
- package/dist/types/src/capabilities/index.d.ts +57 -11
- package/dist/types/src/capabilities/index.d.ts.map +1 -1
- package/dist/types/src/capabilities/local-model-resolver.d.ts +16 -0
- package/dist/types/src/capabilities/local-model-resolver.d.ts.map +1 -0
- package/dist/types/src/capabilities/{repair/repair.d.ts → markdown.d.ts} +2 -3
- package/dist/types/src/capabilities/markdown.d.ts.map +1 -0
- package/dist/types/src/capabilities/migrations.d.ts +6 -0
- package/dist/types/src/capabilities/migrations.d.ts.map +1 -0
- package/dist/types/src/capabilities/operation-handler.d.ts +6 -0
- package/dist/types/src/capabilities/operation-handler.d.ts.map +1 -0
- package/dist/types/src/capabilities/react-surface.d.ts.map +1 -0
- package/dist/types/src/capabilities/settings.d.ts +6 -0
- package/dist/types/src/capabilities/settings.d.ts.map +1 -0
- package/dist/types/src/capabilities/state.d.ts +21 -0
- package/dist/types/src/capabilities/state.d.ts.map +1 -0
- package/dist/types/src/capabilities/toolkit.d.ts.map +1 -0
- package/dist/types/src/components/AgentProperties/AgentProperties.d.ts +7 -0
- package/dist/types/src/components/AgentProperties/AgentProperties.d.ts.map +1 -0
- package/dist/types/src/components/AgentProperties/AgentProperties.stories.d.ts +15 -0
- package/dist/types/src/components/AgentProperties/AgentProperties.stories.d.ts.map +1 -0
- package/dist/types/src/components/AgentProperties/index.d.ts +2 -0
- package/dist/types/src/components/AgentProperties/index.d.ts.map +1 -0
- package/dist/types/src/components/AssistantSettings/AssistantSettings.d.ts +6 -0
- package/dist/types/src/components/AssistantSettings/AssistantSettings.d.ts.map +1 -0
- package/dist/types/src/components/AssistantSettings/AssistantSettings.stories.d.ts +15 -0
- package/dist/types/src/components/AssistantSettings/AssistantSettings.stories.d.ts.map +1 -0
- package/dist/types/src/components/AssistantSettings/index.d.ts +2 -0
- package/dist/types/src/components/AssistantSettings/index.d.ts.map +1 -0
- package/dist/types/src/components/Chat/Chat.d.ts +43 -47
- package/dist/types/src/components/Chat/Chat.d.ts.map +1 -1
- package/dist/types/src/components/Chat/context.d.ts +29 -0
- package/dist/types/src/components/Chat/context.d.ts.map +1 -0
- package/dist/types/src/components/ChatPrompt/ChatActions.d.ts +2 -1
- package/dist/types/src/components/ChatPrompt/ChatActions.d.ts.map +1 -1
- package/dist/types/src/components/ChatPrompt/ChatMcpErrors.d.ts +12 -0
- package/dist/types/src/components/ChatPrompt/ChatMcpErrors.d.ts.map +1 -0
- package/dist/types/src/components/ChatPrompt/ChatOptions.d.ts +9 -6
- package/dist/types/src/components/ChatPrompt/ChatOptions.d.ts.map +1 -1
- package/dist/types/src/components/ChatPrompt/ChatOptions.stories.d.ts +19 -0
- package/dist/types/src/components/ChatPrompt/ChatOptions.stories.d.ts.map +1 -0
- package/dist/types/src/components/ChatPrompt/ChatPresets.d.ts.map +1 -1
- package/dist/types/src/components/ChatPrompt/ChatPrompt.d.ts +28 -0
- package/dist/types/src/components/ChatPrompt/ChatPrompt.d.ts.map +1 -0
- package/dist/types/src/components/ChatPrompt/ChatReferences.d.ts +2 -2
- package/dist/types/src/components/ChatPrompt/ChatReferences.d.ts.map +1 -1
- package/dist/types/src/components/ChatPrompt/ChatStatus.d.ts +20 -0
- package/dist/types/src/components/ChatPrompt/ChatStatus.d.ts.map +1 -0
- package/dist/types/src/components/ChatPrompt/ChatStatusIndicator.d.ts.map +1 -1
- package/dist/types/src/components/ChatPrompt/index.d.ts +3 -0
- package/dist/types/src/components/ChatPrompt/index.d.ts.map +1 -1
- package/dist/types/src/components/ChatThread/Anchor.stories.d.ts +14 -0
- package/dist/types/src/components/ChatThread/Anchor.stories.d.ts.map +1 -0
- package/dist/types/src/components/ChatThread/ChatThread.d.ts +6 -3
- package/dist/types/src/components/ChatThread/ChatThread.d.ts.map +1 -1
- package/dist/types/src/components/ChatThread/ChatThread.stories.d.ts +10 -430
- package/dist/types/src/components/ChatThread/ChatThread.stories.d.ts.map +1 -1
- package/dist/types/src/components/ChatThread/Link.d.ts +2 -2
- package/dist/types/src/components/ChatThread/Link.d.ts.map +1 -1
- package/dist/types/src/components/ChatThread/MarkdownStream.stories.d.ts +42 -0
- package/dist/types/src/components/ChatThread/MarkdownStream.stories.d.ts.map +1 -0
- package/dist/types/src/components/ChatThread/registry.d.ts +18 -0
- package/dist/types/src/components/ChatThread/registry.d.ts.map +1 -1
- package/dist/types/src/components/ChatThread/sync.d.ts +46 -19
- package/dist/types/src/components/ChatThread/sync.d.ts.map +1 -1
- package/dist/types/src/components/ChatThread/tool-widget-state.d.ts +18 -0
- package/dist/types/src/components/ChatThread/tool-widget-state.d.ts.map +1 -0
- package/dist/types/src/components/ChatThread/tool-widget-state.test.d.ts +2 -0
- package/dist/types/src/components/ChatThread/tool-widget-state.test.d.ts.map +1 -0
- package/dist/types/src/components/ChatThread/widgets/FallbackWidget.d.ts +8 -0
- package/dist/types/src/components/ChatThread/widgets/FallbackWidget.d.ts.map +1 -0
- package/dist/types/src/components/ChatThread/widgets/ReasoningWidget.d.ts +25 -0
- package/dist/types/src/components/ChatThread/widgets/ReasoningWidget.d.ts.map +1 -0
- package/dist/types/src/components/ChatThread/widgets/ReasoningWidget.stories.d.ts +18 -0
- package/dist/types/src/components/ChatThread/widgets/ReasoningWidget.stories.d.ts.map +1 -0
- package/dist/types/src/components/ChatThread/widgets/ReferenceWidget.d.ts +9 -0
- package/dist/types/src/components/ChatThread/widgets/ReferenceWidget.d.ts.map +1 -0
- package/dist/types/src/components/ChatThread/widgets/SelectWidget.d.ts +14 -0
- package/dist/types/src/components/ChatThread/widgets/SelectWidget.d.ts.map +1 -0
- package/dist/types/src/components/ChatThread/widgets/StatsWidget.d.ts +12 -0
- package/dist/types/src/components/ChatThread/widgets/StatsWidget.d.ts.map +1 -0
- package/dist/types/src/components/ChatThread/widgets/StatusWidget.d.ts +12 -0
- package/dist/types/src/components/ChatThread/widgets/StatusWidget.d.ts.map +1 -0
- package/dist/types/src/components/ChatThread/widgets/SuggestionWidget.d.ts +11 -0
- package/dist/types/src/components/ChatThread/widgets/SuggestionWidget.d.ts.map +1 -0
- package/dist/types/src/components/ChatThread/widgets/SummaryWidget.d.ts +5 -0
- package/dist/types/src/components/ChatThread/widgets/SummaryWidget.d.ts.map +1 -0
- package/dist/types/src/components/ChatThread/widgets/ToolWidget.d.ts +9 -0
- package/dist/types/src/components/ChatThread/widgets/ToolWidget.d.ts.map +1 -0
- package/dist/types/src/components/ChatThread/widgets/ToolWidget.stories.d.ts +15 -0
- package/dist/types/src/components/ChatThread/widgets/ToolWidget.stories.d.ts.map +1 -0
- package/dist/types/src/components/ChatThread/widgets/defaults.d.ts +5 -0
- package/dist/types/src/components/ChatThread/widgets/defaults.d.ts.map +1 -0
- package/dist/types/src/components/ChatThread/widgets/index.d.ts +10 -0
- package/dist/types/src/components/ChatThread/widgets/index.d.ts.map +1 -0
- package/dist/types/src/components/ProcessTree/ProcessTree.d.ts +11 -0
- package/dist/types/src/components/ProcessTree/ProcessTree.d.ts.map +1 -0
- package/dist/types/src/components/ProcessTree/ProcessTree.stories.d.ts +7 -0
- package/dist/types/src/components/ProcessTree/ProcessTree.stories.d.ts.map +1 -0
- package/dist/types/src/components/ProcessTree/index.d.ts +2 -0
- package/dist/types/src/components/ProcessTree/index.d.ts.map +1 -0
- package/dist/types/src/components/RoutineProperties/RoutineProperties.d.ts +7 -0
- package/dist/types/src/components/RoutineProperties/RoutineProperties.d.ts.map +1 -0
- package/dist/types/src/components/RoutineProperties/RoutineProperties.stories.d.ts +15 -0
- package/dist/types/src/components/RoutineProperties/RoutineProperties.stories.d.ts.map +1 -0
- package/dist/types/src/components/RoutineProperties/index.d.ts +2 -0
- package/dist/types/src/components/RoutineProperties/index.d.ts.map +1 -0
- package/dist/types/src/components/TaskList/TaskList.d.ts +10 -0
- package/dist/types/src/components/TaskList/TaskList.d.ts.map +1 -0
- package/dist/types/src/components/TaskList/TaskList.stories.d.ts +16 -0
- package/dist/types/src/components/TaskList/TaskList.stories.d.ts.map +1 -0
- package/dist/types/src/components/TaskList/index.d.ts +2 -0
- package/dist/types/src/components/TaskList/index.d.ts.map +1 -0
- package/dist/types/src/components/TemplateEditor/TemplateEditor.d.ts +9 -6
- package/dist/types/src/components/TemplateEditor/TemplateEditor.d.ts.map +1 -1
- package/dist/types/src/components/TemplateEditor/TemplateEditor.stories.d.ts +1 -419
- package/dist/types/src/components/TemplateEditor/TemplateEditor.stories.d.ts.map +1 -1
- package/dist/types/src/components/TemplateEditor/TemplateForm.d.ts +4 -5
- package/dist/types/src/components/TemplateEditor/TemplateForm.d.ts.map +1 -1
- package/dist/types/src/components/TemplateEditor/TemplateForm.stories.d.ts +2 -420
- package/dist/types/src/components/TemplateEditor/TemplateForm.stories.d.ts.map +1 -1
- package/dist/types/src/components/TemplateEditor/extensions/handlebars-extension.d.ts.map +1 -1
- package/dist/types/src/components/TemplateEditor/extensions/xml-extension.d.ts.map +1 -1
- package/dist/types/src/components/ToolBlock/ToolBlock.d.ts +4 -13
- package/dist/types/src/components/ToolBlock/ToolBlock.d.ts.map +1 -1
- package/dist/types/src/components/Toolbox/Toolbox.d.ts +11 -9
- package/dist/types/src/components/Toolbox/Toolbox.d.ts.map +1 -1
- package/dist/types/src/components/Toolbox/Toolbox.stories.d.ts +1 -419
- package/dist/types/src/components/Toolbox/Toolbox.stories.d.ts.map +1 -1
- package/dist/types/src/components/index.d.ts +6 -0
- package/dist/types/src/components/index.d.ts.map +1 -1
- package/dist/types/src/containers/AgentArticle/AgentArticle.d.ts +6 -0
- package/dist/types/src/containers/AgentArticle/AgentArticle.d.ts.map +1 -0
- package/dist/types/src/containers/AgentArticle/AgentArticle.stories.d.ts +19 -0
- package/dist/types/src/containers/AgentArticle/AgentArticle.stories.d.ts.map +1 -0
- package/dist/types/src/containers/AgentArticle/index.d.ts +2 -0
- package/dist/types/src/containers/AgentArticle/index.d.ts.map +1 -0
- package/dist/types/src/containers/AgentProperties/AgentProperties.d.ts +6 -0
- package/dist/types/src/containers/AgentProperties/AgentProperties.d.ts.map +1 -0
- package/dist/types/src/containers/AgentProperties/index.d.ts +2 -0
- package/dist/types/src/containers/AgentProperties/index.d.ts.map +1 -0
- package/dist/types/src/containers/BlueprintArticle/BlueprintArticle.d.ts +4 -4
- package/dist/types/src/containers/BlueprintArticle/BlueprintArticle.d.ts.map +1 -1
- package/dist/types/src/containers/BlueprintArticle/index.d.ts +1 -2
- package/dist/types/src/containers/BlueprintArticle/index.d.ts.map +1 -1
- package/dist/types/src/containers/ChatArticle/ChatArticle.d.ts +12 -0
- package/dist/types/src/containers/ChatArticle/ChatArticle.d.ts.map +1 -0
- package/dist/types/src/containers/ChatArticle/ChatArticle.stories.d.ts +15 -0
- package/dist/types/src/containers/ChatArticle/ChatArticle.stories.d.ts.map +1 -0
- package/dist/types/src/containers/ChatArticle/index.d.ts +2 -0
- package/dist/types/src/containers/ChatArticle/index.d.ts.map +1 -0
- package/dist/types/src/containers/ChatCompanion/ChatCompanion.d.ts +23 -9
- package/dist/types/src/containers/ChatCompanion/ChatCompanion.d.ts.map +1 -1
- package/dist/types/src/containers/ChatCompanion/index.d.ts +1 -2
- package/dist/types/src/containers/ChatCompanion/index.d.ts.map +1 -1
- package/dist/types/src/containers/ChatDialog/ChatDialog.d.ts.map +1 -1
- package/dist/types/src/containers/ChatDialog/index.d.ts +1 -2
- package/dist/types/src/containers/ChatDialog/index.d.ts.map +1 -1
- package/dist/types/src/containers/PlanArticle/PlanArticle.d.ts +6 -0
- package/dist/types/src/containers/PlanArticle/PlanArticle.d.ts.map +1 -0
- package/dist/types/src/containers/PlanArticle/index.d.ts +2 -0
- package/dist/types/src/containers/PlanArticle/index.d.ts.map +1 -0
- package/dist/types/src/containers/RoutineArticle/RoutineArticle.d.ts +6 -0
- package/dist/types/src/containers/RoutineArticle/RoutineArticle.d.ts.map +1 -0
- package/dist/types/src/containers/RoutineArticle/RoutineArticle.stories.d.ts +15 -0
- package/dist/types/src/containers/RoutineArticle/RoutineArticle.stories.d.ts.map +1 -0
- package/dist/types/src/containers/RoutineArticle/index.d.ts +2 -0
- package/dist/types/src/containers/RoutineArticle/index.d.ts.map +1 -0
- package/dist/types/src/containers/RoutineList/RoutineList.d.ts +6 -0
- package/dist/types/src/containers/RoutineList/RoutineList.d.ts.map +1 -0
- package/dist/types/src/containers/RoutineList/RoutineList.stories.d.ts +21 -0
- package/dist/types/src/containers/RoutineList/RoutineList.stories.d.ts.map +1 -0
- package/dist/types/src/containers/RoutineList/index.d.ts +2 -0
- package/dist/types/src/containers/RoutineList/index.d.ts.map +1 -0
- package/dist/types/src/containers/TracePanel/TracePanel.d.ts +8 -0
- package/dist/types/src/containers/TracePanel/TracePanel.d.ts.map +1 -0
- package/dist/types/src/containers/TracePanel/TracePanel.stories.d.ts +15 -0
- package/dist/types/src/containers/TracePanel/TracePanel.stories.d.ts.map +1 -0
- package/dist/types/src/containers/TracePanel/dxn-extractor.d.ts +19 -0
- package/dist/types/src/containers/TracePanel/dxn-extractor.d.ts.map +1 -0
- package/dist/types/src/containers/TracePanel/dxn-extractor.test.d.ts +2 -0
- package/dist/types/src/containers/TracePanel/dxn-extractor.test.d.ts.map +1 -0
- package/dist/types/src/containers/TracePanel/index.d.ts +4 -0
- package/dist/types/src/containers/TracePanel/index.d.ts.map +1 -0
- package/dist/types/src/containers/TracePanel/testing/index.d.ts +3 -0
- package/dist/types/src/containers/TracePanel/testing/index.d.ts.map +1 -0
- package/dist/types/src/containers/TracePanel/testing/simulated-agent.d.ts +14 -0
- package/dist/types/src/containers/TracePanel/testing/simulated-agent.d.ts.map +1 -0
- package/dist/types/src/containers/TracePanel/testing/snapshot-playback.d.ts +12 -0
- package/dist/types/src/containers/TracePanel/testing/snapshot-playback.d.ts.map +1 -0
- package/dist/types/src/containers/TriggerStatus/TriggerStatus.d.ts +3 -2
- package/dist/types/src/containers/TriggerStatus/TriggerStatus.d.ts.map +1 -1
- package/dist/types/src/containers/TriggerStatus/index.d.ts +1 -2
- package/dist/types/src/containers/TriggerStatus/index.d.ts.map +1 -1
- package/dist/types/src/containers/index.d.ts +7 -4
- package/dist/types/src/containers/index.d.ts.map +1 -1
- package/dist/types/src/execution-graph/execution-graph.d.ts +108 -0
- package/dist/types/src/execution-graph/execution-graph.d.ts.map +1 -0
- package/dist/types/src/execution-graph/execution-graph.test.d.ts +2 -0
- package/dist/types/src/execution-graph/execution-graph.test.d.ts.map +1 -0
- package/dist/types/src/execution-graph/index.d.ts +3 -0
- package/dist/types/src/execution-graph/index.d.ts.map +1 -0
- package/dist/types/src/execution-graph/remote-snapshot.test.d.ts +2 -0
- package/dist/types/src/execution-graph/remote-snapshot.test.d.ts.map +1 -0
- package/dist/types/src/execution-graph/span-tree.d.ts +76 -0
- package/dist/types/src/execution-graph/span-tree.d.ts.map +1 -0
- package/dist/types/src/execution-graph/span-tree.test.d.ts +2 -0
- package/dist/types/src/execution-graph/span-tree.test.d.ts.map +1 -0
- package/dist/types/src/execution-graph/testing/collect-trace-events.d.ts +40 -0
- package/dist/types/src/execution-graph/testing/collect-trace-events.d.ts.map +1 -0
- package/dist/types/src/execution-graph/testing/index.d.ts +2 -0
- package/dist/types/src/execution-graph/testing/index.d.ts.map +1 -0
- package/dist/types/src/extensions/index.d.ts +2 -0
- package/dist/types/src/extensions/index.d.ts.map +1 -0
- package/dist/types/src/extensions/prompt-extension.d.ts +10 -0
- package/dist/types/src/extensions/prompt-extension.d.ts.map +1 -0
- package/dist/types/src/feed-logger.d.ts +13 -0
- package/dist/types/src/feed-logger.d.ts.map +1 -0
- package/dist/types/src/hooks/index.d.ts +2 -0
- package/dist/types/src/hooks/index.d.ts.map +1 -1
- package/dist/types/src/hooks/useBlueprintRegistry.d.ts +56 -15
- package/dist/types/src/hooks/useBlueprintRegistry.d.ts.map +1 -1
- package/dist/types/src/hooks/useChatKeymap.d.ts +12 -0
- package/dist/types/src/hooks/useChatKeymap.d.ts.map +1 -0
- package/dist/types/src/hooks/useChatProcessor.d.ts +7 -7
- package/dist/types/src/hooks/useChatProcessor.d.ts.map +1 -1
- package/dist/types/src/hooks/useChatServices.d.ts +7 -6
- package/dist/types/src/hooks/useChatServices.d.ts.map +1 -1
- package/dist/types/src/hooks/useChatToolbarActions.d.ts.map +1 -1
- package/dist/types/src/hooks/useContextBinder.d.ts +4 -3
- package/dist/types/src/hooks/useContextBinder.d.ts.map +1 -1
- package/dist/types/src/hooks/useContextObjects.d.ts +5 -4
- package/dist/types/src/hooks/useContextObjects.d.ts.map +1 -1
- package/dist/types/src/hooks/useDebug.d.ts +10 -0
- package/dist/types/src/hooks/useDebug.d.ts.map +1 -0
- package/dist/types/src/hooks/useFilteredTypes.d.ts +1 -1
- package/dist/types/src/hooks/useFilteredTypes.d.ts.map +1 -1
- package/dist/types/src/hooks/useFlush.d.ts +1 -1
- package/dist/types/src/hooks/useFlush.d.ts.map +1 -1
- package/dist/types/src/hooks/usePresets.d.ts +1 -1
- package/dist/types/src/hooks/usePresets.d.ts.map +1 -1
- package/dist/types/src/hooks/useReferencesProvider.d.ts.map +1 -1
- package/dist/types/src/index.d.ts +0 -5
- package/dist/types/src/index.d.ts.map +1 -1
- package/dist/types/src/meta.d.ts +5 -2
- package/dist/types/src/meta.d.ts.map +1 -1
- package/dist/types/src/operations/create-chat.d.ts +5 -0
- package/dist/types/src/operations/create-chat.d.ts.map +1 -0
- package/dist/types/src/operations/ensure-companion-chat.d.ts +5 -0
- package/dist/types/src/operations/ensure-companion-chat.d.ts.map +1 -0
- package/dist/types/src/operations/index.d.ts +3 -0
- package/dist/types/src/operations/index.d.ts.map +1 -0
- package/dist/types/src/operations/on-create-space.d.ts +5 -0
- package/dist/types/src/operations/on-create-space.d.ts.map +1 -0
- package/dist/types/src/operations/prompt.node.test.d.ts +2 -0
- package/dist/types/src/operations/prompt.node.test.d.ts.map +1 -0
- package/dist/types/src/operations/resolve-navigation-targets.d.ts +17 -0
- package/dist/types/src/operations/resolve-navigation-targets.d.ts.map +1 -0
- package/dist/types/src/operations/run-prompt-in-new-chat.d.ts +5 -0
- package/dist/types/src/operations/run-prompt-in-new-chat.d.ts.map +1 -0
- package/dist/types/src/operations/set-current-chat.d.ts +5 -0
- package/dist/types/src/operations/set-current-chat.d.ts.map +1 -0
- package/dist/types/src/operations/toggle-trace-panel-debug.d.ts +5 -0
- package/dist/types/src/operations/toggle-trace-panel-debug.d.ts.map +1 -0
- package/dist/types/src/operations/update-chat-name.d.ts +5 -0
- package/dist/types/src/operations/update-chat-name.d.ts.map +1 -0
- package/dist/types/src/plugin.d.ts +4 -0
- package/dist/types/src/plugin.d.ts.map +1 -0
- package/dist/types/src/processor/index.d.ts +0 -1
- package/dist/types/src/processor/index.d.ts.map +1 -1
- package/dist/types/src/processor/presets.d.ts +1 -1
- package/dist/types/src/processor/presets.d.ts.map +1 -1
- package/dist/types/src/processor/processor.d.ts +285 -41
- package/dist/types/src/processor/processor.d.ts.map +1 -1
- package/dist/types/src/processor/processor.node.test.d.ts +2 -0
- package/dist/types/src/processor/processor.node.test.d.ts.map +1 -0
- package/dist/types/src/testing/index.d.ts +2 -0
- package/dist/types/src/testing/index.d.ts.map +1 -1
- package/dist/types/src/testing/snapshot.d.ts +21 -0
- package/dist/types/src/testing/snapshot.d.ts.map +1 -0
- package/dist/types/src/testing/test-generator.d.ts +2 -3
- package/dist/types/src/testing/test-generator.d.ts.map +1 -1
- package/dist/types/src/testing/test-generator.test.d.ts +2 -0
- package/dist/types/src/testing/test-generator.test.d.ts.map +1 -0
- package/dist/types/src/testing/test-sequence.d.ts +10 -3
- package/dist/types/src/testing/test-sequence.d.ts.map +1 -1
- package/dist/types/src/testing/test-services.d.ts +1 -1
- package/dist/types/src/testing/test-services.d.ts.map +1 -1
- package/dist/types/src/testing/test-trace.d.ts +5 -0
- package/dist/types/src/testing/test-trace.d.ts.map +1 -0
- package/dist/types/src/testing/trace-timeline.node.test.d.ts +2 -0
- package/dist/types/src/testing/trace-timeline.node.test.d.ts.map +1 -0
- package/dist/types/src/testing.d.ts +2 -0
- package/dist/types/src/testing.d.ts.map +1 -0
- package/dist/types/src/translations.d.ts +2 -419
- package/dist/types/src/translations.d.ts.map +1 -1
- package/dist/types/src/types/Assistant.d.ts +31 -14
- package/dist/types/src/types/Assistant.d.ts.map +1 -1
- package/dist/types/src/types/AssistantCapabilities.d.ts +30 -0
- package/dist/types/src/types/AssistantCapabilities.d.ts.map +1 -0
- package/dist/types/src/types/AssistantEvents.d.ts +3 -0
- package/dist/types/src/types/AssistantEvents.d.ts.map +1 -0
- package/dist/types/src/types/AssistantOperation.d.ts +137 -0
- package/dist/types/src/types/AssistantOperation.d.ts.map +1 -0
- package/dist/types/src/types/Settings.d.ts +27 -0
- package/dist/types/src/types/Settings.d.ts.map +1 -0
- package/dist/types/src/types/index.d.ts +7 -4
- package/dist/types/src/types/index.d.ts.map +1 -1
- package/dist/types/src/types/service.d.ts +2 -3
- package/dist/types/src/types/service.d.ts.map +1 -1
- package/dist/types/src/util/suggestions.d.ts +9 -0
- package/dist/types/src/util/suggestions.d.ts.map +1 -0
- package/dist/types/src/util/suggestions.test.d.ts +2 -0
- package/dist/types/src/util/suggestions.test.d.ts.map +1 -0
- package/dist/types/tsconfig.tsbuildinfo +1 -1
- package/package.json +183 -126
- package/src/AssistantPlugin.conversations.json +1 -0
- package/src/AssistantPlugin.node.ts +77 -0
- package/src/AssistantPlugin.test.ts +152 -0
- package/src/AssistantPlugin.ts +147 -0
- package/src/AssistantPlugin.workerd.ts +41 -0
- package/src/blueprints/assistant/blueprint.node.test.ts +46 -0
- package/src/blueprints/assistant/blueprint.ts +11 -7
- package/src/capabilities/ai-context.ts +85 -0
- package/src/capabilities/ai-service.ts +57 -0
- package/src/capabilities/app-graph-builder.ts +197 -0
- package/src/capabilities/blueprint-definition.ts +56 -0
- package/src/capabilities/companion-chat-provisioner.ts +163 -0
- package/src/capabilities/create-object.ts +98 -0
- package/src/capabilities/edge-model-resolver.ts +69 -0
- package/src/capabilities/index.ts +30 -11
- package/src/capabilities/{local-model-resolver/local-model-resolver.ts → local-model-resolver.ts} +14 -4
- package/src/capabilities/markdown.ts +40 -0
- package/src/capabilities/migrations.ts +28 -0
- package/src/capabilities/operation-handler.ts +16 -0
- package/src/capabilities/react-surface.tsx +174 -0
- package/src/capabilities/{settings/settings.ts → settings.ts} +2 -2
- package/src/capabilities/{state/state.ts → state.ts} +11 -3
- package/src/capabilities/{toolkit/toolkit.ts → toolkit.ts} +2 -4
- package/src/components/AgentProperties/AgentProperties.stories.tsx +74 -0
- package/src/components/AgentProperties/AgentProperties.tsx +104 -0
- package/src/components/AgentProperties/index.ts +5 -0
- package/src/components/AssistantSettings/AssistantSettings.stories.tsx +35 -0
- package/src/components/AssistantSettings/AssistantSettings.tsx +43 -0
- package/src/components/AssistantSettings/index.ts +5 -0
- package/src/components/Chat/Chat.tsx +118 -286
- package/src/components/Chat/context.ts +39 -0
- package/src/components/ChatPrompt/ChatActions.tsx +28 -16
- package/src/components/ChatPrompt/ChatMcpErrors.tsx +50 -0
- package/src/components/ChatPrompt/ChatOptions.stories.tsx +136 -0
- package/src/components/ChatPrompt/ChatOptions.tsx +242 -75
- package/src/components/ChatPrompt/ChatPrompt.tsx +182 -0
- package/src/components/ChatPrompt/ChatReferences.tsx +12 -16
- package/src/components/ChatPrompt/ChatStatus.tsx +123 -0
- package/src/components/ChatPrompt/ChatStatusIndicator.tsx +1 -1
- package/src/components/ChatPrompt/index.ts +3 -0
- package/src/components/ChatThread/Anchor.stories.tsx +95 -0
- package/src/components/ChatThread/ChatThread.stories.tsx +64 -75
- package/src/components/ChatThread/ChatThread.tsx +57 -31
- package/src/components/ChatThread/DEBUG.md +41 -0
- package/src/components/ChatThread/Link.tsx +5 -5
- package/src/components/ChatThread/MarkdownStream.stories.tsx +281 -0
- package/src/components/ChatThread/registry.tsx +149 -66
- package/src/components/ChatThread/sync.test.ts +186 -28
- package/src/components/ChatThread/sync.ts +95 -105
- package/src/components/ChatThread/testing/reasoning.md +25 -0
- package/src/components/ChatThread/testing/thinking.md +21 -0
- package/src/components/ChatThread/testing/thread-1.md +30 -0
- package/src/components/ChatThread/testing/{thread.md → thread-2.md} +19 -0
- package/src/components/ChatThread/testing/thread-widgets.md +79 -0
- package/src/components/ChatThread/tool-widget-state.test.ts +34 -0
- package/src/components/ChatThread/tool-widget-state.ts +48 -0
- package/src/components/ChatThread/widgets/FallbackWidget.tsx +26 -0
- package/src/components/ChatThread/widgets/ReasoningWidget.stories.tsx +68 -0
- package/src/components/ChatThread/widgets/ReasoningWidget.ts +139 -0
- package/src/components/ChatThread/widgets/ReferenceWidget.ts +33 -0
- package/src/components/ChatThread/widgets/SelectWidget.ts +39 -0
- package/src/components/ChatThread/widgets/StatsWidget.ts +31 -0
- package/src/components/ChatThread/widgets/StatusWidget.ts +53 -0
- package/src/components/ChatThread/widgets/SuggestionWidget.ts +41 -0
- package/src/components/ChatThread/widgets/SummaryWidget.tsx +27 -0
- package/src/components/ChatThread/widgets/ToolWidget.stories.tsx +55 -0
- package/src/components/ChatThread/widgets/ToolWidget.tsx +171 -0
- package/src/components/ChatThread/widgets/defaults.ts +8 -0
- package/src/components/ChatThread/widgets/index.ts +13 -0
- package/src/components/ProcessTree/ProcessTree.stories.tsx +83 -0
- package/src/components/ProcessTree/ProcessTree.tsx +120 -0
- package/src/components/ProcessTree/index.ts +5 -0
- package/src/components/RoutineProperties/RoutineProperties.stories.tsx +59 -0
- package/src/components/RoutineProperties/RoutineProperties.tsx +23 -0
- package/src/components/RoutineProperties/index.ts +5 -0
- package/src/components/TaskList/TaskList.stories.tsx +44 -0
- package/src/components/TaskList/TaskList.tsx +45 -0
- package/src/components/{Typewriter → TaskList}/index.ts +1 -1
- package/src/components/TemplateEditor/TemplateEditor.stories.tsx +5 -9
- package/src/components/TemplateEditor/TemplateEditor.tsx +54 -44
- package/src/components/TemplateEditor/TemplateForm.stories.tsx +8 -10
- package/src/components/TemplateEditor/TemplateForm.tsx +53 -74
- package/src/components/TemplateEditor/extensions/handlebars-extension.ts +1 -1
- package/src/components/ToolBlock/ToolBlock.tsx +21 -20
- package/src/components/Toolbox/Toolbox.stories.tsx +7 -8
- package/src/components/Toolbox/Toolbox.tsx +66 -58
- package/src/components/index.ts +8 -0
- package/src/containers/AgentArticle/AgentArticle.stories.tsx +124 -0
- package/src/containers/AgentArticle/AgentArticle.tsx +189 -0
- package/src/containers/AgentArticle/index.ts +5 -0
- package/src/containers/AgentProperties/AgentProperties.tsx +43 -0
- package/src/containers/AgentProperties/index.ts +5 -0
- package/src/containers/BlueprintArticle/BlueprintArticle.tsx +8 -9
- package/src/containers/BlueprintArticle/index.ts +1 -3
- package/src/containers/ChatArticle/ChatArticle.stories.tsx +76 -0
- package/src/containers/ChatArticle/ChatArticle.tsx +108 -0
- package/src/containers/ChatArticle/index.ts +5 -0
- package/src/containers/ChatCompanion/ChatCompanion.tsx +51 -155
- package/src/containers/ChatCompanion/index.ts +1 -3
- package/src/containers/ChatDialog/ChatDialog.tsx +10 -15
- package/src/containers/ChatDialog/index.ts +1 -3
- package/src/containers/PlanArticle/PlanArticle.tsx +33 -0
- package/src/containers/PlanArticle/index.ts +5 -0
- package/src/containers/RoutineArticle/RoutineArticle.stories.tsx +75 -0
- package/src/containers/RoutineArticle/RoutineArticle.tsx +109 -0
- package/src/containers/RoutineArticle/index.ts +5 -0
- package/src/containers/RoutineList/RoutineList.stories.tsx +130 -0
- package/src/containers/RoutineList/RoutineList.tsx +50 -0
- package/src/containers/RoutineList/index.ts +5 -0
- package/src/containers/TracePanel/TracePanel.stories.tsx +319 -0
- package/src/containers/TracePanel/TracePanel.tsx +213 -0
- package/src/containers/TracePanel/dxn-extractor.test.ts +153 -0
- package/src/containers/TracePanel/dxn-extractor.ts +168 -0
- package/src/containers/TracePanel/index.ts +9 -0
- package/src/containers/TracePanel/testing/index.ts +6 -0
- package/src/containers/TracePanel/testing/simulated-agent.ts +114 -0
- package/src/containers/TracePanel/testing/snapshot-playback.ts +45 -0
- package/src/containers/TriggerStatus/TriggerStatus.tsx +42 -62
- package/src/containers/TriggerStatus/index.ts +1 -3
- package/src/containers/index.ts +7 -5
- package/src/execution-graph/SPEC.md +678 -0
- package/src/execution-graph/execution-graph.test.ts +799 -0
- package/src/execution-graph/execution-graph.ts +714 -0
- package/src/execution-graph/index.ts +24 -0
- package/src/execution-graph/remote-snapshot.test.ts +116 -0
- package/src/execution-graph/span-tree.test.ts +249 -0
- package/src/execution-graph/span-tree.ts +259 -0
- package/src/execution-graph/testing/collect-trace-events.ts +74 -0
- package/src/execution-graph/testing/index.ts +5 -0
- package/src/extensions/index.ts +5 -0
- package/src/extensions/prompt-extension.ts +111 -0
- package/src/{queue-logger.ts → feed-logger.ts} +47 -22
- package/src/hooks/index.ts +2 -0
- package/src/hooks/useBlueprintRegistry.ts +62 -45
- package/src/hooks/useChatKeymap.ts +52 -0
- package/src/hooks/useChatProcessor.ts +57 -29
- package/src/hooks/useChatServices.ts +11 -30
- package/src/hooks/useChatToolbarActions.ts +89 -91
- package/src/hooks/useContextBinder.ts +19 -8
- package/src/hooks/useContextObjects.ts +13 -8
- package/src/hooks/useDebug.ts +38 -0
- package/src/hooks/useFilteredTypes.ts +17 -16
- package/src/hooks/usePresets.ts +2 -1
- package/src/hooks/useReferencesProvider.ts +7 -15
- package/src/index.ts +0 -6
- package/src/meta.ts +31 -9
- package/src/operations/create-chat.ts +57 -0
- package/src/operations/ensure-companion-chat.ts +63 -0
- package/src/operations/index.ts +16 -0
- package/src/operations/on-create-space.ts +24 -0
- package/src/operations/prompt.node.test.ts +80 -0
- package/src/operations/resolve-navigation-targets.ts +31 -0
- package/src/operations/run-prompt-in-new-chat.ts +113 -0
- package/src/operations/set-current-chat.ts +49 -0
- package/src/operations/toggle-trace-panel-debug.ts +27 -0
- package/src/operations/update-chat-name.ts +61 -0
- package/src/plugin.ts +11 -0
- package/src/processor/index.ts +0 -1
- package/src/processor/presets.ts +11 -3
- package/src/processor/processor.node.test.ts +40 -0
- package/src/processor/processor.ts +270 -166
- package/src/testing/data/trace-timeline-multiple.dx.json +1 -0
- package/src/testing/data/trace-timeline-remote.dx.json +1 -0
- package/src/testing/data/trace-timeline.dx.json +4657 -0
- package/src/testing/index.ts +2 -0
- package/src/testing/snapshot.ts +35 -0
- package/src/testing/test-generator.test.ts +71 -0
- package/src/testing/test-generator.ts +214 -192
- package/src/testing/test-sequence.ts +3 -3
- package/src/testing/test-services.ts +2 -2
- package/src/testing/test-trace.ts +20 -0
- package/src/testing/trace-timeline.node.conversations.json +1 -0
- package/src/testing/trace-timeline.node.test.ts +241 -0
- package/src/testing.ts +9 -0
- package/src/translations.ts +157 -109
- package/src/types/Assistant.ts +16 -18
- package/src/types/AssistantCapabilities.ts +35 -0
- package/src/types/AssistantEvents.ts +11 -0
- package/src/types/AssistantOperation.ts +164 -0
- package/src/types/Settings.ts +82 -0
- package/src/types/index.ts +11 -4
- package/src/types/service.ts +6 -11
- package/src/util/suggestions.test.ts +52 -0
- package/src/util/suggestions.ts +42 -0
- package/src/vite-env.d.ts +5 -0
- package/dist/lib/browser/AssistantSettings-2LFAG5OQ.mjs +0 -93
- package/dist/lib/browser/AssistantSettings-2LFAG5OQ.mjs.map +0 -7
- package/dist/lib/browser/BlueprintArticle-CCS25MNW.mjs.map +0 -7
- package/dist/lib/browser/ChatCompanion-UGD4V34A.mjs +0 -202
- package/dist/lib/browser/ChatCompanion-UGD4V34A.mjs.map +0 -7
- package/dist/lib/browser/ChatContainer-ZGRSZ5EU.mjs +0 -12
- package/dist/lib/browser/ChatDialog-AET7GVIB.mjs.map +0 -7
- package/dist/lib/browser/ProjectArticle-QDBTIFNE.mjs +0 -91
- package/dist/lib/browser/ProjectArticle-QDBTIFNE.mjs.map +0 -7
- package/dist/lib/browser/ProjectSettings-R6RRARLO.mjs +0 -194
- package/dist/lib/browser/ProjectSettings-R6RRARLO.mjs.map +0 -7
- package/dist/lib/browser/PromptArticle-USQO4WX6.mjs +0 -71
- package/dist/lib/browser/PromptArticle-USQO4WX6.mjs.map +0 -7
- package/dist/lib/browser/TriggerStatus-65X3EUSN.mjs +0 -122
- package/dist/lib/browser/TriggerStatus-65X3EUSN.mjs.map +0 -7
- package/dist/lib/browser/ai-service-CY2BYPH6.mjs +0 -22
- package/dist/lib/browser/ai-service-CY2BYPH6.mjs.map +0 -7
- package/dist/lib/browser/app-graph-builder-SFYYUKTT.mjs +0 -234
- package/dist/lib/browser/app-graph-builder-SFYYUKTT.mjs.map +0 -7
- package/dist/lib/browser/blueprint-definition-RB5RHZZM.mjs +0 -34
- package/dist/lib/browser/blueprint-definition-RB5RHZZM.mjs.map +0 -7
- package/dist/lib/browser/chunk-7DXYAXLZ.mjs +0 -230
- package/dist/lib/browser/chunk-7DXYAXLZ.mjs.map +0 -7
- package/dist/lib/browser/chunk-EXVT7D4B.mjs +0 -23
- package/dist/lib/browser/chunk-EXVT7D4B.mjs.map +0 -7
- package/dist/lib/browser/chunk-JYY5AD65.mjs +0 -286
- package/dist/lib/browser/chunk-JYY5AD65.mjs.map +0 -7
- package/dist/lib/browser/chunk-LEXIQDXZ.mjs +0 -26
- package/dist/lib/browser/chunk-LEXIQDXZ.mjs.map +0 -7
- package/dist/lib/browser/chunk-RU4G5NY4.mjs +0 -69
- package/dist/lib/browser/chunk-RU4G5NY4.mjs.map +0 -7
- package/dist/lib/browser/chunk-UUA6GNGG.mjs +0 -2125
- package/dist/lib/browser/chunk-UUA6GNGG.mjs.map +0 -7
- package/dist/lib/browser/edge-model-resolver-YTMFQEN5.mjs +0 -21
- package/dist/lib/browser/edge-model-resolver-YTMFQEN5.mjs.map +0 -7
- package/dist/lib/browser/index.mjs +0 -386
- package/dist/lib/browser/index.mjs.map +0 -7
- package/dist/lib/browser/local-model-resolver-CGRQH37T.mjs.map +0 -7
- package/dist/lib/browser/meta.json +0 -1
- package/dist/lib/browser/operation-resolver-ELXDQZEG.mjs +0 -136
- package/dist/lib/browser/operation-resolver-ELXDQZEG.mjs.map +0 -7
- package/dist/lib/browser/react-surface-KYQSZO2I.mjs +0 -144
- package/dist/lib/browser/react-surface-KYQSZO2I.mjs.map +0 -7
- package/dist/lib/browser/repair-ZFZWZALX.mjs +0 -52
- package/dist/lib/browser/repair-ZFZWZALX.mjs.map +0 -7
- package/dist/lib/browser/settings-YREVQAZ5.mjs.map +0 -7
- package/dist/lib/browser/state-MPG42ZO4.mjs +0 -26
- package/dist/lib/browser/state-MPG42ZO4.mjs.map +0 -7
- package/dist/lib/browser/toolkit-XRSBBB3L.mjs +0 -16
- package/dist/lib/browser/toolkit-XRSBBB3L.mjs.map +0 -7
- package/dist/lib/browser/types/index.mjs +0 -23
- package/dist/lib/node-esm/AssistantSettings-QWFEMJG7.mjs +0 -94
- package/dist/lib/node-esm/AssistantSettings-QWFEMJG7.mjs.map +0 -7
- package/dist/lib/node-esm/BlueprintArticle-SNEN6LOY.mjs +0 -37
- package/dist/lib/node-esm/BlueprintArticle-SNEN6LOY.mjs.map +0 -7
- package/dist/lib/node-esm/ChatCompanion-NP4R5BFE.mjs +0 -203
- package/dist/lib/node-esm/ChatCompanion-NP4R5BFE.mjs.map +0 -7
- package/dist/lib/node-esm/ChatContainer-IFHDIFJH.mjs +0 -13
- package/dist/lib/node-esm/ChatDialog-UZNQBTKZ.mjs +0 -86
- package/dist/lib/node-esm/ChatDialog-UZNQBTKZ.mjs.map +0 -7
- package/dist/lib/node-esm/ProjectArticle-BCIBESJN.mjs +0 -92
- package/dist/lib/node-esm/ProjectArticle-BCIBESJN.mjs.map +0 -7
- package/dist/lib/node-esm/ProjectSettings-Q5QY6BYS.mjs +0 -195
- package/dist/lib/node-esm/ProjectSettings-Q5QY6BYS.mjs.map +0 -7
- package/dist/lib/node-esm/PromptArticle-PGMJMQK7.mjs +0 -72
- package/dist/lib/node-esm/PromptArticle-PGMJMQK7.mjs.map +0 -7
- package/dist/lib/node-esm/TriggerStatus-UR5S7PXJ.mjs +0 -123
- package/dist/lib/node-esm/TriggerStatus-UR5S7PXJ.mjs.map +0 -7
- package/dist/lib/node-esm/ai-service-ZI3A6RVG.mjs +0 -23
- package/dist/lib/node-esm/ai-service-ZI3A6RVG.mjs.map +0 -7
- package/dist/lib/node-esm/app-graph-builder-E25JXI34.mjs +0 -235
- package/dist/lib/node-esm/app-graph-builder-E25JXI34.mjs.map +0 -7
- package/dist/lib/node-esm/blueprint-definition-L7XKRYIW.mjs +0 -35
- package/dist/lib/node-esm/blueprint-definition-L7XKRYIW.mjs.map +0 -7
- package/dist/lib/node-esm/blueprints/index.mjs +0 -9
- package/dist/lib/node-esm/chunk-3QBVFAYO.mjs +0 -28
- package/dist/lib/node-esm/chunk-3QBVFAYO.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-6NCLKQCL.mjs +0 -70
- package/dist/lib/node-esm/chunk-6NCLKQCL.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-GZ4ERNT2.mjs +0 -2126
- package/dist/lib/node-esm/chunk-GZ4ERNT2.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-HSLMI22Q.mjs +0 -11
- package/dist/lib/node-esm/chunk-JMBYVUD6.mjs +0 -288
- package/dist/lib/node-esm/chunk-JMBYVUD6.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-MWYYLALM.mjs +0 -231
- package/dist/lib/node-esm/chunk-MWYYLALM.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-POWB2BPC.mjs +0 -25
- package/dist/lib/node-esm/chunk-POWB2BPC.mjs.map +0 -7
- package/dist/lib/node-esm/edge-model-resolver-CMJ3KNLQ.mjs +0 -22
- package/dist/lib/node-esm/edge-model-resolver-CMJ3KNLQ.mjs.map +0 -7
- package/dist/lib/node-esm/index.mjs +0 -387
- package/dist/lib/node-esm/index.mjs.map +0 -7
- package/dist/lib/node-esm/local-model-resolver-FFDAKOXN.mjs +0 -21
- package/dist/lib/node-esm/local-model-resolver-FFDAKOXN.mjs.map +0 -7
- package/dist/lib/node-esm/meta.json +0 -1
- package/dist/lib/node-esm/operation-resolver-Q5GNP2GH.mjs +0 -137
- package/dist/lib/node-esm/operation-resolver-Q5GNP2GH.mjs.map +0 -7
- package/dist/lib/node-esm/react-surface-JJRGVGKD.mjs +0 -145
- package/dist/lib/node-esm/react-surface-JJRGVGKD.mjs.map +0 -7
- package/dist/lib/node-esm/repair-LXFVOK4B.mjs +0 -53
- package/dist/lib/node-esm/repair-LXFVOK4B.mjs.map +0 -7
- package/dist/lib/node-esm/settings-N452OW6Y.mjs +0 -34
- package/dist/lib/node-esm/settings-N452OW6Y.mjs.map +0 -7
- package/dist/lib/node-esm/state-WHZFKIEL.mjs +0 -27
- package/dist/lib/node-esm/state-WHZFKIEL.mjs.map +0 -7
- package/dist/lib/node-esm/toolkit-5IWGLUF4.mjs +0 -17
- package/dist/lib/node-esm/toolkit-5IWGLUF4.mjs.map +0 -7
- package/dist/lib/node-esm/types/index.mjs +0 -24
- package/dist/types/src/blueprints/assistant/blueprint.test.d.ts +0 -2
- package/dist/types/src/blueprints/assistant/blueprint.test.d.ts.map +0 -1
- package/dist/types/src/capabilities/ai-service/ai-service.d.ts +0 -6
- package/dist/types/src/capabilities/ai-service/ai-service.d.ts.map +0 -1
- package/dist/types/src/capabilities/ai-service/index.d.ts +0 -3
- package/dist/types/src/capabilities/ai-service/index.d.ts.map +0 -1
- package/dist/types/src/capabilities/app-graph-builder/app-graph-builder.d.ts.map +0 -1
- package/dist/types/src/capabilities/app-graph-builder/index.d.ts +0 -3
- package/dist/types/src/capabilities/app-graph-builder/index.d.ts.map +0 -1
- package/dist/types/src/capabilities/blueprint-definition/blueprint-definition.d.ts +0 -6
- package/dist/types/src/capabilities/blueprint-definition/blueprint-definition.d.ts.map +0 -1
- package/dist/types/src/capabilities/blueprint-definition/index.d.ts +0 -3
- package/dist/types/src/capabilities/blueprint-definition/index.d.ts.map +0 -1
- package/dist/types/src/capabilities/edge-model-resolver/edge-model-resolver.d.ts.map +0 -1
- package/dist/types/src/capabilities/edge-model-resolver/index.d.ts +0 -3
- package/dist/types/src/capabilities/edge-model-resolver/index.d.ts.map +0 -1
- package/dist/types/src/capabilities/local-model-resolver/index.d.ts +0 -3
- package/dist/types/src/capabilities/local-model-resolver/index.d.ts.map +0 -1
- package/dist/types/src/capabilities/local-model-resolver/local-model-resolver.d.ts +0 -13
- package/dist/types/src/capabilities/local-model-resolver/local-model-resolver.d.ts.map +0 -1
- package/dist/types/src/capabilities/operation-resolver/index.d.ts +0 -3
- package/dist/types/src/capabilities/operation-resolver/index.d.ts.map +0 -1
- package/dist/types/src/capabilities/operation-resolver/operation-resolver.d.ts +0 -5
- package/dist/types/src/capabilities/operation-resolver/operation-resolver.d.ts.map +0 -1
- package/dist/types/src/capabilities/react-surface/index.d.ts +0 -3
- package/dist/types/src/capabilities/react-surface/index.d.ts.map +0 -1
- package/dist/types/src/capabilities/react-surface/react-surface.d.ts.map +0 -1
- package/dist/types/src/capabilities/repair/index.d.ts +0 -3
- package/dist/types/src/capabilities/repair/index.d.ts.map +0 -1
- package/dist/types/src/capabilities/repair/repair.d.ts.map +0 -1
- package/dist/types/src/capabilities/settings/index.d.ts +0 -15
- package/dist/types/src/capabilities/settings/index.d.ts.map +0 -1
- package/dist/types/src/capabilities/settings/settings.d.ts +0 -18
- package/dist/types/src/capabilities/settings/settings.d.ts.map +0 -1
- package/dist/types/src/capabilities/state/index.d.ts +0 -11
- package/dist/types/src/capabilities/state/index.d.ts.map +0 -1
- package/dist/types/src/capabilities/state/state.d.ts +0 -13
- package/dist/types/src/capabilities/state/state.d.ts.map +0 -1
- package/dist/types/src/capabilities/toolkit/index.d.ts +0 -3
- package/dist/types/src/capabilities/toolkit/index.d.ts.map +0 -1
- package/dist/types/src/capabilities/toolkit/toolkit.d.ts.map +0 -1
- package/dist/types/src/components/ChatProgress/ChatProgress.d.ts +0 -7
- package/dist/types/src/components/ChatProgress/ChatProgress.d.ts.map +0 -1
- package/dist/types/src/components/ChatProgress/index.d.ts +0 -2
- package/dist/types/src/components/ChatProgress/index.d.ts.map +0 -1
- package/dist/types/src/components/Typewriter/AssistantToolbar.d.ts +0 -12
- package/dist/types/src/components/Typewriter/AssistantToolbar.d.ts.map +0 -1
- package/dist/types/src/components/Typewriter/Typewriter.d.ts +0 -11
- package/dist/types/src/components/Typewriter/Typewriter.d.ts.map +0 -1
- package/dist/types/src/components/Typewriter/Typewriter.stories.d.ts +0 -7
- package/dist/types/src/components/Typewriter/Typewriter.stories.d.ts.map +0 -1
- package/dist/types/src/components/Typewriter/assistant-extension.d.ts +0 -5
- package/dist/types/src/components/Typewriter/assistant-extension.d.ts.map +0 -1
- package/dist/types/src/components/Typewriter/index.d.ts +0 -2
- package/dist/types/src/components/Typewriter/index.d.ts.map +0 -1
- package/dist/types/src/containers/AssistantSettings/AssistantSettings.d.ts +0 -8
- package/dist/types/src/containers/AssistantSettings/AssistantSettings.d.ts.map +0 -1
- package/dist/types/src/containers/AssistantSettings/index.d.ts +0 -3
- package/dist/types/src/containers/AssistantSettings/index.d.ts.map +0 -1
- package/dist/types/src/containers/ChatContainer/ChatContainer.d.ts +0 -18
- package/dist/types/src/containers/ChatContainer/ChatContainer.d.ts.map +0 -1
- package/dist/types/src/containers/ChatContainer/index.d.ts +0 -3
- package/dist/types/src/containers/ChatContainer/index.d.ts.map +0 -1
- package/dist/types/src/containers/Project/ProjectArticle.d.ts +0 -7
- package/dist/types/src/containers/Project/ProjectArticle.d.ts.map +0 -1
- package/dist/types/src/containers/Project/ProjectSettings.d.ts +0 -6
- package/dist/types/src/containers/Project/ProjectSettings.d.ts.map +0 -1
- package/dist/types/src/containers/Project/index.d.ts +0 -7
- package/dist/types/src/containers/Project/index.d.ts.map +0 -1
- package/dist/types/src/containers/Project/triggers.d.ts +0 -6
- package/dist/types/src/containers/Project/triggers.d.ts.map +0 -1
- package/dist/types/src/containers/PromptArticle/PromptArticle.d.ts +0 -6
- package/dist/types/src/containers/PromptArticle/PromptArticle.d.ts.map +0 -1
- package/dist/types/src/containers/PromptArticle/index.d.ts +0 -3
- package/dist/types/src/containers/PromptArticle/index.d.ts.map +0 -1
- package/dist/types/src/processor/processor.test.d.ts +0 -2
- package/dist/types/src/processor/processor.test.d.ts.map +0 -1
- package/dist/types/src/processor/update-name.d.ts +0 -10
- package/dist/types/src/processor/update-name.d.ts.map +0 -1
- package/dist/types/src/queue-logger.d.ts +0 -11
- package/dist/types/src/queue-logger.d.ts.map +0 -1
- package/dist/types/src/types/AssistantAction.d.ts +0 -93
- package/dist/types/src/types/AssistantAction.d.ts.map +0 -1
- package/dist/types/src/types/capabilities.d.ts +0 -33
- package/dist/types/src/types/capabilities.d.ts.map +0 -1
- package/dist/types/src/types/defs.d.ts +0 -2
- package/dist/types/src/types/defs.d.ts.map +0 -1
- package/dist/types/src/types/events.d.ts +0 -5
- package/dist/types/src/types/events.d.ts.map +0 -1
- package/src/AssistantPlugin.tsx +0 -172
- package/src/blueprints/assistant/blueprint.conversations.json +0 -1
- package/src/blueprints/assistant/blueprint.test.ts +0 -48
- package/src/capabilities/ai-service/ai-service.ts +0 -30
- package/src/capabilities/ai-service/index.ts +0 -7
- package/src/capabilities/app-graph-builder/app-graph-builder.ts +0 -198
- package/src/capabilities/app-graph-builder/index.ts +0 -7
- package/src/capabilities/blueprint-definition/blueprint-definition.ts +0 -48
- package/src/capabilities/blueprint-definition/index.ts +0 -7
- package/src/capabilities/edge-model-resolver/edge-model-resolver.ts +0 -33
- package/src/capabilities/edge-model-resolver/index.ts +0 -7
- package/src/capabilities/local-model-resolver/index.ts +0 -7
- package/src/capabilities/operation-resolver/index.ts +0 -7
- package/src/capabilities/operation-resolver/operation-resolver.ts +0 -121
- package/src/capabilities/react-surface/index.ts +0 -7
- package/src/capabilities/react-surface/react-surface.tsx +0 -121
- package/src/capabilities/repair/index.ts +0 -7
- package/src/capabilities/repair/repair.ts +0 -69
- package/src/capabilities/settings/index.ts +0 -7
- package/src/capabilities/state/index.ts +0 -7
- package/src/capabilities/toolkit/index.ts +0 -7
- package/src/components/ChatProgress/ChatProgress.tsx +0 -53
- package/src/components/ChatProgress/index.ts +0 -5
- package/src/components/Typewriter/AssistantToolbar.tsx +0 -161
- package/src/components/Typewriter/Typewriter.stories.tsx +0 -86
- package/src/components/Typewriter/Typewriter.tsx +0 -54
- package/src/components/Typewriter/assistant-extension.tsx +0 -142
- package/src/containers/AssistantSettings/AssistantSettings.tsx +0 -120
- package/src/containers/AssistantSettings/index.ts +0 -7
- package/src/containers/ChatContainer/ChatContainer.tsx +0 -69
- package/src/containers/ChatContainer/index.ts +0 -7
- package/src/containers/Project/ProjectArticle.tsx +0 -117
- package/src/containers/Project/ProjectSettings.tsx +0 -118
- package/src/containers/Project/index.ts +0 -16
- package/src/containers/Project/triggers.ts +0 -131
- package/src/containers/PromptArticle/PromptArticle.tsx +0 -59
- package/src/containers/PromptArticle/index.ts +0 -7
- package/src/processor/processor.test.ts +0 -73
- package/src/processor/update-name.ts +0 -58
- package/src/types/AssistantAction.ts +0 -76
- package/src/types/capabilities.ts +0 -27
- package/src/types/defs.ts +0 -5
- package/src/types/events.ts +0 -11
- /package/dist/lib/{browser/ChatContainer-ZGRSZ5EU.mjs.map → neutral/AssistantPlugin.mjs.map} +0 -0
- /package/dist/lib/{browser/blueprints/index.mjs.map → neutral/ChatArticle-PWD4OEFZ.mjs.map} +0 -0
- /package/dist/lib/{browser/types → neutral/blueprints}/index.mjs.map +0 -0
- /package/dist/lib/{browser → neutral}/chunk-J5LGTIGS.mjs +0 -0
- /package/dist/lib/{browser → neutral}/chunk-J5LGTIGS.mjs.map +0 -0
- /package/dist/lib/{node-esm/blueprints → neutral}/index.mjs.map +0 -0
- /package/dist/lib/{node-esm/ChatContainer-IFHDIFJH.mjs.map → neutral/meta.mjs.map} +0 -0
- /package/dist/lib/{node-esm/types → neutral/operations}/index.mjs.map +0 -0
- /package/dist/lib/{node-esm/chunk-HSLMI22Q.mjs.map → neutral/testing.mjs.map} +0 -0
- /package/dist/types/src/capabilities/{app-graph-builder/app-graph-builder.d.ts → app-graph-builder.d.ts} +0 -0
- /package/dist/types/src/capabilities/{react-surface/react-surface.d.ts → react-surface.d.ts} +0 -0
- /package/dist/types/src/capabilities/{toolkit/toolkit.d.ts → toolkit.d.ts} +0 -0
|
@@ -0,0 +1,74 @@
|
|
|
1
|
+
//
|
|
2
|
+
// Copyright 2026 DXOS.org
|
|
3
|
+
//
|
|
4
|
+
|
|
5
|
+
import * as Cause from 'effect/Cause';
|
|
6
|
+
import * as Context from 'effect/Context';
|
|
7
|
+
import * as Effect from 'effect/Effect';
|
|
8
|
+
import * as Layer from 'effect/Layer';
|
|
9
|
+
|
|
10
|
+
import { Trace } from '@dxos/compute';
|
|
11
|
+
|
|
12
|
+
/**
|
|
13
|
+
* Internal tag carrying the monotonic clock created by {@link collectTraceEvents}. Nested
|
|
14
|
+
* {@link withMeta} scopes read it so every emitted message gets a strictly increasing
|
|
15
|
+
* timestamp regardless of how many writes happened in the same wall-clock millisecond.
|
|
16
|
+
*/
|
|
17
|
+
class TestClock extends Context.Tag('@dxos/plugin-assistant/CollectTraceEvents/TestClock')<TestClock, () => number>() {}
|
|
18
|
+
|
|
19
|
+
/**
|
|
20
|
+
* Runs the given Effect with a mock {@link Trace.TraceService} and {@link Trace.TraceSink}
|
|
21
|
+
* whose writes accumulate into an in-memory list of {@link Trace.Message}s.
|
|
22
|
+
*
|
|
23
|
+
* Each `Trace.write(...)` call inside the effect produces one `Trace.Message` carrying the
|
|
24
|
+
* meta of the innermost {@link withMeta} scope (or empty meta if none is provided). Useful
|
|
25
|
+
* for building deterministic span fixtures without spinning up a feed sink.
|
|
26
|
+
*
|
|
27
|
+
* Timestamps are produced by an internal monotonic counter so multiple synchronous writes
|
|
28
|
+
* are ordered in insertion order — wall-clock `Date.now()` would otherwise tie and corrupt
|
|
29
|
+
* the resulting graph for fast tests.
|
|
30
|
+
*
|
|
31
|
+
* The effect is run synchronously; any failure is rethrown so callers don't pay error
|
|
32
|
+
* boilerplate in tests.
|
|
33
|
+
*/
|
|
34
|
+
export const collectTraceEvents = <A, E>(
|
|
35
|
+
effect: Effect.Effect<A, E, Trace.TraceService | Trace.TraceSink | TestClock>,
|
|
36
|
+
): Trace.Message[] => {
|
|
37
|
+
const messages: Trace.Message[] = [];
|
|
38
|
+
let counter = 0;
|
|
39
|
+
const clock = () => {
|
|
40
|
+
counter += 1;
|
|
41
|
+
return counter;
|
|
42
|
+
};
|
|
43
|
+
|
|
44
|
+
const sinkLayer: Layer.Layer<Trace.TraceSink> = Layer.succeed(Trace.TraceSink, {
|
|
45
|
+
write: (message) => {
|
|
46
|
+
messages.push(message);
|
|
47
|
+
},
|
|
48
|
+
});
|
|
49
|
+
const clockLayer: Layer.Layer<TestClock> = Layer.succeed(TestClock, clock);
|
|
50
|
+
const traceLayer: Layer.Layer<Trace.TraceService> = Trace.testTraceService({ clock }).pipe(Layer.provide(sinkLayer));
|
|
51
|
+
const layer = Layer.mergeAll(traceLayer, sinkLayer, clockLayer);
|
|
52
|
+
|
|
53
|
+
const exit = Effect.runSyncExit(effect.pipe(Effect.provide(layer)));
|
|
54
|
+
if (exit._tag === 'Failure') {
|
|
55
|
+
throw new Error(`collectTraceEvents: effect failed\n${Cause.pretty(exit.cause)}`);
|
|
56
|
+
}
|
|
57
|
+
return messages;
|
|
58
|
+
};
|
|
59
|
+
|
|
60
|
+
/**
|
|
61
|
+
* Wraps an effect so that {@link Trace.write} calls inside it tag their messages with the
|
|
62
|
+
* given {@link Trace.Meta}. Nested `withMeta` scopes shadow the outer meta for their inner
|
|
63
|
+
* effect — exactly the pattern needed to fixture multi-process traces (e.g. an agent
|
|
64
|
+
* process containing nested operation processes).
|
|
65
|
+
*
|
|
66
|
+
* Implemented by re-providing a fresh {@link Trace.TraceService} layer over the existing
|
|
67
|
+
* {@link Trace.TraceSink} and shared monotonic clock, so all messages still flow into the
|
|
68
|
+
* same accumulator with monotonically increasing timestamps.
|
|
69
|
+
*/
|
|
70
|
+
export const withMeta = <A, E, R>(
|
|
71
|
+
meta: Trace.Meta,
|
|
72
|
+
effect: Effect.Effect<A, E, R>,
|
|
73
|
+
): Effect.Effect<A, E, Exclude<R, Trace.TraceService> | Trace.TraceSink | TestClock> =>
|
|
74
|
+
Effect.flatMap(TestClock, (clock) => Effect.provide(effect, Trace.testTraceService({ meta, clock })));
|
|
@@ -0,0 +1,111 @@
|
|
|
1
|
+
//
|
|
2
|
+
// Copyright 2025 DXOS.org
|
|
3
|
+
//
|
|
4
|
+
|
|
5
|
+
import { syntaxTree } from '@codemirror/language';
|
|
6
|
+
import { type Extension } from '@codemirror/state';
|
|
7
|
+
import { Decoration, type DecorationSet, EditorView, ViewPlugin, type ViewUpdate, WidgetType } from '@codemirror/view';
|
|
8
|
+
|
|
9
|
+
import { Domino } from '@dxos/ui';
|
|
10
|
+
|
|
11
|
+
export type PromptExtensionOptions = {
|
|
12
|
+
/** Called when the user clicks the run button on a prompt code block. */
|
|
13
|
+
onRun: (promptText: string) => void;
|
|
14
|
+
};
|
|
15
|
+
|
|
16
|
+
/**
|
|
17
|
+
* CodeMirror extension that adds a green "run" button to ```prompt fenced code blocks.
|
|
18
|
+
*/
|
|
19
|
+
export const promptRunExtension = ({ onRun }: PromptExtensionOptions): Extension => {
|
|
20
|
+
return [
|
|
21
|
+
ViewPlugin.fromClass(
|
|
22
|
+
class {
|
|
23
|
+
decorations: DecorationSet;
|
|
24
|
+
|
|
25
|
+
constructor(view: EditorView) {
|
|
26
|
+
this.decorations = this.buildDecorations(view);
|
|
27
|
+
}
|
|
28
|
+
|
|
29
|
+
update(update: ViewUpdate) {
|
|
30
|
+
if (update.docChanged || update.viewportChanged || update.selectionSet || update.focusChanged) {
|
|
31
|
+
this.decorations = this.buildDecorations(update.view);
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
|
|
35
|
+
buildDecorations(view: EditorView): DecorationSet {
|
|
36
|
+
const decorations: Array<{ from: number; to: number; decoration: Decoration }> = [];
|
|
37
|
+
|
|
38
|
+
syntaxTree(view.state).iterate({
|
|
39
|
+
enter: (node) => {
|
|
40
|
+
if (node.name === 'FencedCode') {
|
|
41
|
+
const info = node.node.getChild('CodeInfo');
|
|
42
|
+
if (info) {
|
|
43
|
+
const type = view.state.sliceDoc(info.from, info.to);
|
|
44
|
+
const text = node.node.getChild('CodeText');
|
|
45
|
+
if (type === 'prompt' && text) {
|
|
46
|
+
const content = view.state.sliceDoc(text.from, text.to).trim();
|
|
47
|
+
if (content.length > 0) {
|
|
48
|
+
const widget = new PromptRunWidget(content, onRun);
|
|
49
|
+
decorations.push({
|
|
50
|
+
from: node.from,
|
|
51
|
+
to: node.from,
|
|
52
|
+
decoration: Decoration.widget({ widget, side: -1 }),
|
|
53
|
+
});
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
},
|
|
59
|
+
});
|
|
60
|
+
|
|
61
|
+
return Decoration.set(
|
|
62
|
+
decorations.sort((a, b) => a.from - b.from || a.to - b.to).map((d) => d.decoration.range(d.from, d.to)),
|
|
63
|
+
);
|
|
64
|
+
}
|
|
65
|
+
},
|
|
66
|
+
{
|
|
67
|
+
decorations: (v) => v.decorations,
|
|
68
|
+
},
|
|
69
|
+
),
|
|
70
|
+
];
|
|
71
|
+
};
|
|
72
|
+
|
|
73
|
+
class PromptRunWidget extends WidgetType {
|
|
74
|
+
constructor(
|
|
75
|
+
private readonly prompt: string,
|
|
76
|
+
private readonly onClick: (promptText: string) => void,
|
|
77
|
+
) {
|
|
78
|
+
super();
|
|
79
|
+
}
|
|
80
|
+
|
|
81
|
+
override eq(other: this) {
|
|
82
|
+
return this.prompt === other.prompt;
|
|
83
|
+
}
|
|
84
|
+
|
|
85
|
+
override ignoreEvent() {
|
|
86
|
+
return false;
|
|
87
|
+
}
|
|
88
|
+
|
|
89
|
+
override toDOM() {
|
|
90
|
+
return Domino.of('div')
|
|
91
|
+
.classNames('relative')
|
|
92
|
+
.append(
|
|
93
|
+
Domino.of('button')
|
|
94
|
+
.classNames('dx-button absolute right-0 top-4')
|
|
95
|
+
.on('mousedown', (event) => {
|
|
96
|
+
event.preventDefault();
|
|
97
|
+
event.stopPropagation();
|
|
98
|
+
this.onClick(this.prompt);
|
|
99
|
+
})
|
|
100
|
+
.append(
|
|
101
|
+
Domino.of('svg', Domino.SVG)
|
|
102
|
+
.classNames('w-4 h-4 cursor-pointer')
|
|
103
|
+
.append(
|
|
104
|
+
Domino.of('use', Domino.SVG).attributes({
|
|
105
|
+
href: Domino.icon('ph--play--regular'),
|
|
106
|
+
}),
|
|
107
|
+
),
|
|
108
|
+
),
|
|
109
|
+
).root;
|
|
110
|
+
}
|
|
111
|
+
}
|
|
@@ -2,51 +2,65 @@
|
|
|
2
2
|
// Copyright 2025 DXOS.org
|
|
3
3
|
//
|
|
4
4
|
|
|
5
|
-
import
|
|
6
|
-
import
|
|
7
|
-
|
|
5
|
+
import * as Effect from 'effect/Effect';
|
|
6
|
+
import * as Layer from 'effect/Layer';
|
|
7
|
+
|
|
8
|
+
import { createFeedServiceLayer, type Space, getSpace } from '@dxos/client/echo';
|
|
9
|
+
import { Sequence, type SequenceEvent, type SequenceLogger } from '@dxos/conductor';
|
|
10
|
+
import { Feed, Obj, Ref } from '@dxos/echo';
|
|
11
|
+
import { type Queue } from '@dxos/echo-db';
|
|
12
|
+
import { runAndForwardErrors } from '@dxos/effect';
|
|
8
13
|
import { InvocationTraceEndEvent, InvocationTraceEventType, InvocationTraceStartEvent } from '@dxos/functions-runtime';
|
|
9
14
|
import { TraceEvent } from '@dxos/functions-runtime';
|
|
10
15
|
import { InvocationOutcome } from '@dxos/functions-runtime';
|
|
11
|
-
import { type InvocationTraceEvent } from '@dxos/functions-runtime';
|
|
12
16
|
import { invariant } from '@dxos/invariant';
|
|
13
|
-
import {
|
|
17
|
+
import { EID, type EntityId } from '@dxos/keys';
|
|
14
18
|
|
|
15
19
|
export class QueueLogger implements SequenceLogger {
|
|
16
20
|
private _space: Space;
|
|
17
|
-
private
|
|
21
|
+
private _invocationTraceFeed: Feed.Feed;
|
|
22
|
+
private _feedServiceLayer: Layer.Layer<Feed.FeedService>;
|
|
18
23
|
|
|
19
|
-
constructor(private readonly sequence: Sequence) {
|
|
24
|
+
constructor(private readonly sequence: Sequence.Sequence) {
|
|
20
25
|
const space = getSpace(sequence);
|
|
21
26
|
invariant(space, 'Space not found');
|
|
22
27
|
this._space = space;
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
28
|
+
this._feedServiceLayer = createFeedServiceLayer(space.queues);
|
|
29
|
+
|
|
30
|
+
const existingFeedRef = this._space.properties.invocationTraceFeed;
|
|
31
|
+
|
|
32
|
+
if (existingFeedRef) {
|
|
33
|
+
// A feed reference exists; ensure its target is loaded. If not, fail loudly
|
|
34
|
+
// rather than silently creating a new feed and orphaning existing traces.
|
|
35
|
+
invariant(existingFeedRef.target, 'invocationTraceFeed reference is not yet loaded');
|
|
36
|
+
invariant(Feed.getQueueUri(existingFeedRef.target), 'invocationTraceFeed has no queue DXN');
|
|
37
|
+
this._invocationTraceFeed = existingFeedRef.target;
|
|
38
|
+
} else {
|
|
39
|
+
const feed = space.db.add(Feed.make({ namespace: 'trace' }));
|
|
40
|
+
invariant(Feed.getQueueUri(feed), 'New invocationTraceFeed has no queue DXN');
|
|
41
|
+
Obj.update(this._space.properties, (obj) => {
|
|
42
|
+
obj.invocationTraceFeed = Ref.make(feed);
|
|
29
43
|
});
|
|
44
|
+
this._invocationTraceFeed = feed;
|
|
30
45
|
}
|
|
31
|
-
this._invocationTraceQueue = this._space.queues.get(dxn);
|
|
32
46
|
}
|
|
33
47
|
|
|
34
48
|
log(event: SequenceEvent) {
|
|
35
49
|
switch (event.type) {
|
|
36
50
|
case 'begin':
|
|
37
|
-
void this.
|
|
51
|
+
void this._appendToTraceFeed([
|
|
38
52
|
Obj.make(InvocationTraceStartEvent, {
|
|
39
53
|
type: InvocationTraceEventType.START,
|
|
40
54
|
invocationId: event.invocationId,
|
|
41
55
|
timestamp: Date.now(),
|
|
42
56
|
input: {},
|
|
43
|
-
|
|
57
|
+
invocationTraceFeed: Ref.fromURI(this._getTraceQueueEchoId(event.invocationId)),
|
|
44
58
|
invocationTarget: Ref.make(this.sequence),
|
|
45
59
|
}),
|
|
46
60
|
]);
|
|
47
61
|
break;
|
|
48
62
|
case 'end':
|
|
49
|
-
void this.
|
|
63
|
+
void this._appendToTraceFeed([
|
|
50
64
|
Obj.make(InvocationTraceEndEvent, {
|
|
51
65
|
type: InvocationTraceEventType.END,
|
|
52
66
|
invocationId: event.invocationId,
|
|
@@ -113,12 +127,23 @@ export class QueueLogger implements SequenceLogger {
|
|
|
113
127
|
}
|
|
114
128
|
}
|
|
115
129
|
|
|
116
|
-
private
|
|
117
|
-
return
|
|
130
|
+
private _getTraceQueueEchoId(invocationId: EntityId): EID.EID {
|
|
131
|
+
return EID.make({ spaceId: this._space.id, entityId: invocationId });
|
|
132
|
+
}
|
|
133
|
+
|
|
134
|
+
private _appendToTraceFeed(items: any[]): Promise<void> {
|
|
135
|
+
return Feed.append(this._invocationTraceFeed, items).pipe(
|
|
136
|
+
Effect.provide(this._feedServiceLayer),
|
|
137
|
+
runAndForwardErrors,
|
|
138
|
+
);
|
|
118
139
|
}
|
|
119
140
|
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
141
|
+
// TODO(burdon): The per-invocation trace event queues address feeds by raw queue DXN
|
|
142
|
+
// (no backing Feed.Feed object). Migration to Feed.append is blocked on either
|
|
143
|
+
// (a) materializing a Feed object per invocation, or (b) a lower-level
|
|
144
|
+
// FeedService.appendByDxn primitive. Tracked as Phase 6 work in echo/AUDIT.md.
|
|
145
|
+
private _getTraceEventQueue(invocationId: EntityId): Queue<TraceEvent> {
|
|
146
|
+
const echoUri = this._getTraceQueueEchoId(invocationId);
|
|
147
|
+
return this._space.queues.get(echoUri);
|
|
123
148
|
}
|
|
124
149
|
}
|
package/src/hooks/index.ts
CHANGED
|
@@ -3,11 +3,13 @@
|
|
|
3
3
|
//
|
|
4
4
|
|
|
5
5
|
export * from './useBlueprintRegistry';
|
|
6
|
+
export * from './useChatKeymap';
|
|
6
7
|
export * from './useChatProcessor';
|
|
7
8
|
export * from './useChatServices';
|
|
8
9
|
export * from './useChatToolbarActions';
|
|
9
10
|
export * from './useContextBinder';
|
|
10
11
|
export * from './useContextObjects';
|
|
12
|
+
export { useDebug } from './useDebug';
|
|
11
13
|
export * from './useFilteredTypes';
|
|
12
14
|
export * from './useFlush';
|
|
13
15
|
export * from './useOnline';
|
|
@@ -4,46 +4,40 @@
|
|
|
4
4
|
|
|
5
5
|
import { useCallback, useEffect, useMemo, useState } from 'react';
|
|
6
6
|
|
|
7
|
-
import {
|
|
8
|
-
import {
|
|
9
|
-
import { type
|
|
10
|
-
import { Blueprint } from '@dxos/blueprints';
|
|
11
|
-
import { type Database, Filter, Obj, Ref } from '@dxos/echo';
|
|
7
|
+
import { type AiContext } from '@dxos/assistant';
|
|
8
|
+
import { Blueprint } from '@dxos/compute';
|
|
9
|
+
import { type Database, Filter, Obj, Ref, type Registry } from '@dxos/echo';
|
|
12
10
|
import { useQuery } from '@dxos/react-client/echo';
|
|
13
11
|
import { distinctBy } from '@dxos/util';
|
|
14
12
|
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
// TODO(burdon): Reconcile with eventual public registry.
|
|
19
|
-
export const useBlueprintRegistry = () => {
|
|
20
|
-
const blueprintDefinitions = useCapabilities(AppCapabilities.BlueprintDefinition);
|
|
21
|
-
return useMemo(
|
|
22
|
-
() => new Blueprint.Registry(blueprintDefinitions.map((blueprint) => blueprint.make())),
|
|
23
|
-
[blueprintDefinitions],
|
|
13
|
+
export const useBlueprints = ({ registry, db }: { registry?: Registry.Registry; db?: Database.Database }) => {
|
|
14
|
+
const [registryBlueprints, setRegistryBlueprints] = useState<Blueprint.Blueprint[]>(
|
|
15
|
+
() => registry?.query(Filter.type(Blueprint.Blueprint)).runSync() ?? [],
|
|
24
16
|
);
|
|
25
|
-
};
|
|
26
17
|
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
18
|
+
useEffect(() => {
|
|
19
|
+
if (!registry) {
|
|
20
|
+
setRegistryBlueprints([]);
|
|
21
|
+
return;
|
|
22
|
+
}
|
|
23
|
+
setRegistryBlueprints(registry.query(Filter.type(Blueprint.Blueprint)).runSync());
|
|
24
|
+
return registry.changed.on(() => {
|
|
25
|
+
setRegistryBlueprints(registry.query(Filter.type(Blueprint.Blueprint)).runSync());
|
|
26
|
+
});
|
|
27
|
+
}, [registry]);
|
|
28
|
+
|
|
35
29
|
const spaceBlueprints = useQuery(db, Filter.type(Blueprint.Blueprint));
|
|
36
30
|
return useMemo(() => {
|
|
37
|
-
const blueprints = distinctBy([...
|
|
31
|
+
const blueprints = distinctBy([...registryBlueprints, ...spaceBlueprints], (b) => Obj.getMeta(b).key);
|
|
38
32
|
blueprints.sort(({ name: a }, { name: b }) => a.localeCompare(b));
|
|
39
33
|
return blueprints;
|
|
40
|
-
}, [
|
|
34
|
+
}, [registryBlueprints, spaceBlueprints]);
|
|
41
35
|
};
|
|
42
36
|
|
|
43
37
|
/**
|
|
44
38
|
* Create reactive map of active blueprints (by key).
|
|
45
39
|
*/
|
|
46
|
-
export const useActiveBlueprints = ({ context }: { context?:
|
|
40
|
+
export const useActiveBlueprints = ({ context }: { context?: AiContext.Binder }) => {
|
|
47
41
|
const [active, setActive] = useState<Map<string, Blueprint.Blueprint>>(new Map());
|
|
48
42
|
|
|
49
43
|
useEffect(() => {
|
|
@@ -54,7 +48,13 @@ export const useActiveBlueprints = ({ context }: { context?: AiContextBinder })
|
|
|
54
48
|
|
|
55
49
|
const updateActive = () => {
|
|
56
50
|
const blueprints = context.getBlueprints();
|
|
57
|
-
setActive(
|
|
51
|
+
setActive(
|
|
52
|
+
new Map(
|
|
53
|
+
blueprints
|
|
54
|
+
.map((blueprint) => [Obj.getMeta(blueprint).key, blueprint] as const)
|
|
55
|
+
.filter((entry): entry is readonly [string, Blueprint.Blueprint] => entry[0] !== undefined),
|
|
56
|
+
),
|
|
57
|
+
);
|
|
58
58
|
};
|
|
59
59
|
|
|
60
60
|
// Set initial value.
|
|
@@ -71,37 +71,54 @@ export const useActiveBlueprints = ({ context }: { context?: AiContextBinder })
|
|
|
71
71
|
export const useBlueprintHandlers = ({
|
|
72
72
|
db,
|
|
73
73
|
context,
|
|
74
|
-
|
|
74
|
+
registry,
|
|
75
75
|
}: {
|
|
76
76
|
db: Database.Database;
|
|
77
|
-
context?:
|
|
78
|
-
|
|
77
|
+
context?: AiContext.Binder;
|
|
78
|
+
registry?: Registry.Registry;
|
|
79
79
|
}) => {
|
|
80
80
|
const onUpdateBlueprint = useCallback(
|
|
81
81
|
async (key: string, checked: boolean) => {
|
|
82
|
-
if (!context
|
|
82
|
+
if (!context) {
|
|
83
83
|
return;
|
|
84
84
|
}
|
|
85
85
|
|
|
86
|
-
// Find existing cloned blueprint.
|
|
87
|
-
const objects = await db.query(Filter.type(Blueprint.Blueprint)).run();
|
|
88
|
-
let storedBlueprint = objects.find((blueprint) => blueprint.key === key);
|
|
89
86
|
if (checked) {
|
|
90
|
-
if
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
87
|
+
// Check if the blueprint is in the registry — if so, bind via its key URI directly
|
|
88
|
+
// (no DB clone needed). Fall back to an existing DB copy for user-forked blueprints.
|
|
89
|
+
const registryBlueprint = registry
|
|
90
|
+
?.query(Filter.type(Blueprint.Blueprint))
|
|
91
|
+
.runSync()
|
|
92
|
+
.find((b) => Obj.getMeta(b).key === key);
|
|
95
93
|
|
|
96
|
-
|
|
97
|
-
|
|
94
|
+
if (registryBlueprint) {
|
|
95
|
+
await context.bind({ blueprints: [Ref.fromURI(Blueprint.registryURI(key))] });
|
|
96
|
+
} else {
|
|
97
|
+
// User-forked blueprint (in DB but not in registry): bind via DB ref.
|
|
98
|
+
const objects = await db.query(Filter.type(Blueprint.Blueprint)).run();
|
|
99
|
+
const storedBlueprint = objects.find((blueprint) => Obj.getMeta(blueprint).key === key);
|
|
100
|
+
if (storedBlueprint) {
|
|
101
|
+
await context.bind({ blueprints: [Ref.make(storedBlueprint)] });
|
|
102
|
+
}
|
|
103
|
+
}
|
|
104
|
+
} else {
|
|
105
|
+
// Unbind: try registry ref first, then DB ref.
|
|
106
|
+
const registryBlueprint = registry
|
|
107
|
+
?.query(Filter.type(Blueprint.Blueprint))
|
|
108
|
+
.runSync()
|
|
109
|
+
.find((b) => Obj.getMeta(b).key === key);
|
|
110
|
+
if (registryBlueprint) {
|
|
111
|
+
await context.unbind({ blueprints: [Ref.fromURI(Blueprint.registryURI(key))] });
|
|
112
|
+
} else {
|
|
113
|
+
const objects = await db.query(Filter.type(Blueprint.Blueprint)).run();
|
|
114
|
+
const storedBlueprint = objects.find((blueprint) => Obj.getMeta(blueprint).key === key);
|
|
115
|
+
if (storedBlueprint) {
|
|
116
|
+
await context.unbind({ blueprints: [Ref.make(storedBlueprint)] });
|
|
117
|
+
}
|
|
98
118
|
}
|
|
99
|
-
await context.bind({ blueprints: [Ref.make(storedBlueprint)] });
|
|
100
|
-
} else if (storedBlueprint) {
|
|
101
|
-
await context.unbind({ blueprints: [Ref.make(storedBlueprint)] });
|
|
102
119
|
}
|
|
103
120
|
},
|
|
104
|
-
[db, context,
|
|
121
|
+
[db, context, registry],
|
|
105
122
|
);
|
|
106
123
|
|
|
107
124
|
return { onUpdateBlueprint };
|
|
@@ -0,0 +1,52 @@
|
|
|
1
|
+
//
|
|
2
|
+
// Copyright 2025 DXOS.org
|
|
3
|
+
//
|
|
4
|
+
|
|
5
|
+
import { type Extension, Prec } from '@codemirror/state';
|
|
6
|
+
import { keymap } from '@codemirror/view';
|
|
7
|
+
import { useMemo } from 'react';
|
|
8
|
+
|
|
9
|
+
import { type Event } from '@dxos/async';
|
|
10
|
+
import { isTruthy } from '@dxos/util';
|
|
11
|
+
|
|
12
|
+
import { type ChatEvent } from '../components/Chat/events';
|
|
13
|
+
|
|
14
|
+
/**
|
|
15
|
+
* CodeMirror keymap shared by the chat document (Thread) and the prompt editor — pressing
|
|
16
|
+
* Mod-Arrow keys when either editor is focused emits the corresponding `ChatEvent` on the
|
|
17
|
+
* shared event bus.
|
|
18
|
+
*/
|
|
19
|
+
export const useChatKeymapExtensions = ({ event }: { event: Event<ChatEvent> }): Extension[] => {
|
|
20
|
+
return useMemo<Extension[]>(() => {
|
|
21
|
+
return [
|
|
22
|
+
Prec.highest(
|
|
23
|
+
keymap.of([
|
|
24
|
+
{
|
|
25
|
+
key: 'Mod-ArrowUp',
|
|
26
|
+
preventDefault: true,
|
|
27
|
+
run: () => {
|
|
28
|
+
event.emit({ type: 'nav-previous' });
|
|
29
|
+
return true;
|
|
30
|
+
},
|
|
31
|
+
shift: () => {
|
|
32
|
+
event.emit({ type: 'thread-open' });
|
|
33
|
+
return true;
|
|
34
|
+
},
|
|
35
|
+
},
|
|
36
|
+
{
|
|
37
|
+
key: 'Mod-ArrowDown',
|
|
38
|
+
preventDefault: true,
|
|
39
|
+
run: () => {
|
|
40
|
+
event.emit({ type: 'nav-next' });
|
|
41
|
+
return true;
|
|
42
|
+
},
|
|
43
|
+
shift: () => {
|
|
44
|
+
event.emit({ type: 'thread-close' });
|
|
45
|
+
return true;
|
|
46
|
+
},
|
|
47
|
+
},
|
|
48
|
+
]),
|
|
49
|
+
),
|
|
50
|
+
].filter(isTruthy);
|
|
51
|
+
}, [event]);
|
|
52
|
+
};
|
|
@@ -2,26 +2,35 @@
|
|
|
2
2
|
// Copyright 2025 DXOS.org
|
|
3
3
|
//
|
|
4
4
|
|
|
5
|
-
import {
|
|
6
|
-
import
|
|
5
|
+
import { RegistryContext } from '@effect-atom/atom-react';
|
|
6
|
+
import * as Effect from 'effect/Effect';
|
|
7
|
+
import * as Layer from 'effect/Layer';
|
|
7
8
|
import { useContext, useMemo, useState } from 'react';
|
|
8
9
|
|
|
9
|
-
import {
|
|
10
|
+
import { AiService, OpaqueToolkit } from '@dxos/ai';
|
|
11
|
+
import { Capabilities } from '@dxos/app-framework';
|
|
12
|
+
import { useCapability } from '@dxos/app-framework/ui';
|
|
13
|
+
import { AiSession } from '@dxos/assistant';
|
|
10
14
|
import { type Chat } from '@dxos/assistant-toolkit';
|
|
11
|
-
import {
|
|
15
|
+
import { Credential, OperationRegistry, ServiceResolver } from '@dxos/compute';
|
|
16
|
+
import { Database, Feed, Ref, type Registry } from '@dxos/echo';
|
|
17
|
+
import { createFeedServiceLayer } from '@dxos/echo-db';
|
|
18
|
+
import { runAndForwardErrors } from '@dxos/effect';
|
|
19
|
+
import { AgentService } from '@dxos/functions-runtime';
|
|
12
20
|
import { log } from '@dxos/log';
|
|
13
|
-
import { type
|
|
21
|
+
import { type Space } from '@dxos/react-client/echo';
|
|
14
22
|
import { useAsyncEffect } from '@dxos/react-ui';
|
|
15
23
|
|
|
16
|
-
import {
|
|
17
|
-
|
|
24
|
+
import { type Assistant } from '#types';
|
|
25
|
+
|
|
26
|
+
import { AiChatProcessor, type AiServicePreset } from '../processor';
|
|
18
27
|
|
|
19
28
|
export type UseChatProcessorProps = {
|
|
20
29
|
space?: Space;
|
|
21
30
|
chat?: Chat.Chat;
|
|
22
31
|
preset?: AiServicePreset;
|
|
23
|
-
|
|
24
|
-
|
|
32
|
+
runtime?: Capabilities.ProcessManagerRuntime;
|
|
33
|
+
registry?: Registry.Registry;
|
|
25
34
|
settings?: Assistant.Settings;
|
|
26
35
|
};
|
|
27
36
|
|
|
@@ -32,47 +41,66 @@ export const useChatProcessor = ({
|
|
|
32
41
|
space,
|
|
33
42
|
chat,
|
|
34
43
|
preset,
|
|
35
|
-
|
|
36
|
-
|
|
44
|
+
runtime,
|
|
45
|
+
registry,
|
|
37
46
|
settings,
|
|
38
47
|
}: UseChatProcessorProps): AiChatProcessor | undefined => {
|
|
39
48
|
const observableRegistry = useContext(RegistryContext);
|
|
40
49
|
|
|
41
|
-
|
|
42
|
-
const [conversation, setConversation] = useState<AiConversation>();
|
|
50
|
+
const [session, setSession] = useState<AiSession.Session>();
|
|
43
51
|
useAsyncEffect(async () => {
|
|
44
52
|
if (!space || !chat) {
|
|
45
53
|
return;
|
|
46
54
|
}
|
|
47
55
|
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
56
|
+
const feedTarget = chat.feed.target;
|
|
57
|
+
if (!feedTarget) {
|
|
58
|
+
return;
|
|
59
|
+
}
|
|
60
|
+
const feedServiceLayer = createFeedServiceLayer(space.queues);
|
|
61
|
+
const runtime = await runAndForwardErrors(
|
|
62
|
+
Effect.runtime<Feed.FeedService>().pipe(Effect.provide(feedServiceLayer)),
|
|
63
|
+
);
|
|
64
|
+
const session = new AiSession.Session({
|
|
65
|
+
feed: feedTarget,
|
|
66
|
+
runtime,
|
|
67
|
+
registry: observableRegistry,
|
|
54
68
|
});
|
|
55
|
-
await
|
|
56
|
-
|
|
69
|
+
await session.open();
|
|
70
|
+
setSession(session);
|
|
57
71
|
return () => {
|
|
58
|
-
void
|
|
59
|
-
|
|
72
|
+
void session.close();
|
|
73
|
+
setSession(undefined);
|
|
60
74
|
};
|
|
61
|
-
}, [space, chat?.
|
|
75
|
+
}, [space, chat?.feed.target]);
|
|
76
|
+
|
|
77
|
+
const feed = chat?.feed.target;
|
|
78
|
+
const serviceResolver = useCapability(Capabilities.ServiceResolver);
|
|
62
79
|
|
|
63
|
-
// Create processor.
|
|
64
80
|
const processor = useMemo(() => {
|
|
65
|
-
if (!
|
|
81
|
+
if (!runtime || !session || !chat || !feed || !space) {
|
|
66
82
|
return undefined;
|
|
67
83
|
}
|
|
68
84
|
|
|
85
|
+
const spaceLayer = ServiceResolver.provide(
|
|
86
|
+
{ space: space.id },
|
|
87
|
+
Database.Service,
|
|
88
|
+
Feed.FeedService,
|
|
89
|
+
Credential.CredentialsService,
|
|
90
|
+
AiService.AiService,
|
|
91
|
+
AgentService.AgentService,
|
|
92
|
+
OperationRegistry.Service,
|
|
93
|
+
OpaqueToolkit.OpaqueToolkitProvider,
|
|
94
|
+
).pipe(Layer.provide(Layer.succeed(ServiceResolver.ServiceResolver, serviceResolver)));
|
|
95
|
+
|
|
69
96
|
log('creating processor', { preset, model: preset?.model, settings });
|
|
70
|
-
return new AiChatProcessor(
|
|
97
|
+
return new AiChatProcessor(session, runtime, feed, spaceLayer, {
|
|
98
|
+
chat: chat ? Ref.make(chat) : undefined,
|
|
71
99
|
observableRegistry,
|
|
72
|
-
|
|
100
|
+
registry,
|
|
73
101
|
model: preset?.model,
|
|
74
102
|
});
|
|
75
|
-
}, [
|
|
103
|
+
}, [runtime, session, registry, preset, chat, feed, space?.id]);
|
|
76
104
|
|
|
77
105
|
return processor;
|
|
78
106
|
};
|