@dxos/plugin-assistant 0.8.4-main.9be5663bfe → 0.8.4-main.abd8ff62ef
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/dist/lib/browser/AssistantSettings-GG52BLKS.mjs +40 -0
- package/dist/lib/browser/AssistantSettings-GG52BLKS.mjs.map +7 -0
- package/dist/lib/browser/blueprints/index.mjs +26 -3
- package/dist/lib/browser/blueprints/index.mjs.map +4 -4
- package/dist/lib/browser/{chunk-ATHYBVGN.mjs → chunk-DVOOFAWU.mjs} +4 -5
- package/dist/lib/browser/chunk-DVOOFAWU.mjs.map +7 -0
- package/dist/lib/browser/chunk-M55MBYG7.mjs +932 -0
- package/dist/lib/browser/chunk-M55MBYG7.mjs.map +7 -0
- package/dist/lib/browser/{chunk-RUV2WOQH.mjs → chunk-SEMCG4ZK.mjs} +58 -17
- package/dist/lib/browser/chunk-SEMCG4ZK.mjs.map +7 -0
- package/dist/lib/browser/chunk-VK53MITK.mjs +2300 -0
- package/dist/lib/browser/chunk-VK53MITK.mjs.map +7 -0
- package/dist/lib/browser/cli/index.mjs +73 -0
- package/dist/lib/browser/cli/index.mjs.map +7 -0
- package/dist/lib/browser/components/index.mjs +20 -0
- package/dist/lib/browser/components/index.mjs.map +7 -0
- package/dist/lib/browser/{create-chat-LBZHGVSN.mjs → create-chat-E2ZLVTLP.mjs} +4 -13
- package/dist/lib/browser/create-chat-E2ZLVTLP.mjs.map +7 -0
- package/dist/lib/browser/{ensure-companion-chat-FR4AWZ2P.mjs → ensure-companion-chat-7GDMXSQW.mjs} +4 -4
- package/dist/lib/browser/ensure-companion-chat-7GDMXSQW.mjs.map +7 -0
- package/dist/lib/browser/hooks/index.mjs +39 -0
- package/dist/lib/browser/hooks/index.mjs.map +7 -0
- package/dist/lib/browser/index.mjs +43 -3233
- package/dist/lib/browser/index.mjs.map +4 -4
- package/dist/lib/browser/meta.json +1 -1
- package/dist/lib/browser/{on-create-space-54RNX5JI.mjs → on-create-space-4J3KTNAJ.mjs} +3 -3
- package/dist/lib/browser/{on-create-space-54RNX5JI.mjs.map → on-create-space-4J3KTNAJ.mjs.map} +1 -1
- package/dist/lib/browser/operations/index.mjs +3 -3
- package/dist/lib/browser/operations/index.mjs.map +3 -3
- package/dist/lib/browser/{resolve-navigation-targets-NZOD66NY.mjs → resolve-navigation-targets-3ZPQE6SZ.mjs} +3 -3
- package/dist/lib/browser/{resolve-navigation-targets-NZOD66NY.mjs.map → resolve-navigation-targets-3ZPQE6SZ.mjs.map} +1 -1
- package/dist/lib/browser/{run-prompt-in-new-chat-4YQ37XIS.mjs → run-prompt-in-new-chat-AA3KPBDN.mjs} +9 -39
- package/dist/lib/browser/run-prompt-in-new-chat-AA3KPBDN.mjs.map +7 -0
- package/dist/lib/browser/{set-current-chat-WJI3WAVM.mjs → set-current-chat-P4VHI3YF.mjs} +4 -4
- package/dist/lib/browser/set-current-chat-P4VHI3YF.mjs.map +7 -0
- package/dist/lib/browser/translations.mjs +172 -0
- package/dist/lib/browser/translations.mjs.map +7 -0
- package/dist/lib/browser/types/index.mjs +1 -3
- package/dist/lib/browser/{update-chat-name-3Y36KFAS.mjs → update-chat-name-VWKNUON7.mjs} +7 -22
- package/dist/lib/browser/update-chat-name-VWKNUON7.mjs.map +7 -0
- package/dist/lib/node-esm/AssistantSettings-23A5IMHS.mjs +41 -0
- package/dist/lib/node-esm/AssistantSettings-23A5IMHS.mjs.map +7 -0
- package/dist/lib/node-esm/blueprints/index.mjs +26 -3
- package/dist/lib/node-esm/blueprints/index.mjs.map +4 -4
- package/dist/lib/node-esm/chunk-FWC3ZGPH.mjs +933 -0
- package/dist/lib/node-esm/chunk-FWC3ZGPH.mjs.map +7 -0
- package/dist/lib/node-esm/chunk-JKEB3NFZ.mjs +2302 -0
- package/dist/lib/node-esm/chunk-JKEB3NFZ.mjs.map +7 -0
- package/dist/lib/node-esm/{chunk-PXAJSTGZ.mjs → chunk-MBDVPB4V.mjs} +4 -5
- package/dist/lib/node-esm/chunk-MBDVPB4V.mjs.map +7 -0
- package/dist/lib/node-esm/{chunk-PY4X6FJT.mjs → chunk-XAFVSEUJ.mjs} +58 -17
- package/dist/lib/node-esm/chunk-XAFVSEUJ.mjs.map +7 -0
- package/dist/lib/node-esm/cli/index.mjs +74 -0
- package/dist/lib/node-esm/cli/index.mjs.map +7 -0
- package/dist/lib/node-esm/components/index.mjs +21 -0
- package/dist/lib/node-esm/components/index.mjs.map +7 -0
- package/dist/lib/node-esm/{create-chat-3BEG4R6J.mjs → create-chat-UQQ3542N.mjs} +4 -13
- package/dist/lib/node-esm/create-chat-UQQ3542N.mjs.map +7 -0
- package/dist/lib/node-esm/{ensure-companion-chat-BLP7NT32.mjs → ensure-companion-chat-LVCPD4DJ.mjs} +4 -4
- package/dist/lib/node-esm/ensure-companion-chat-LVCPD4DJ.mjs.map +7 -0
- package/dist/lib/node-esm/hooks/index.mjs +40 -0
- package/dist/lib/node-esm/hooks/index.mjs.map +7 -0
- package/dist/lib/node-esm/index.mjs +43 -3233
- package/dist/lib/node-esm/index.mjs.map +4 -4
- package/dist/lib/node-esm/meta.json +1 -1
- package/dist/lib/node-esm/{on-create-space-YRPZ6HZY.mjs → on-create-space-M63UBTTT.mjs} +3 -3
- package/dist/lib/node-esm/{on-create-space-YRPZ6HZY.mjs.map → on-create-space-M63UBTTT.mjs.map} +1 -1
- package/dist/lib/node-esm/operations/index.mjs +3 -3
- package/dist/lib/node-esm/operations/index.mjs.map +3 -3
- package/dist/lib/node-esm/{resolve-navigation-targets-3PPK7XLH.mjs → resolve-navigation-targets-HO77CAFT.mjs} +3 -3
- package/dist/lib/node-esm/{resolve-navigation-targets-3PPK7XLH.mjs.map → resolve-navigation-targets-HO77CAFT.mjs.map} +1 -1
- package/dist/lib/node-esm/{run-prompt-in-new-chat-2IJBSDTM.mjs → run-prompt-in-new-chat-RIRYYYPK.mjs} +9 -39
- package/dist/lib/node-esm/run-prompt-in-new-chat-RIRYYYPK.mjs.map +7 -0
- package/dist/lib/node-esm/{set-current-chat-KBMMZULR.mjs → set-current-chat-Z7GJ52VX.mjs} +4 -4
- package/dist/lib/node-esm/set-current-chat-Z7GJ52VX.mjs.map +7 -0
- package/dist/lib/node-esm/translations.mjs +173 -0
- package/dist/lib/node-esm/translations.mjs.map +7 -0
- package/dist/lib/node-esm/types/index.mjs +1 -3
- package/dist/lib/node-esm/{update-chat-name-HM2P4NSI.mjs → update-chat-name-GV4HX32Z.mjs} +7 -22
- package/dist/lib/node-esm/update-chat-name-GV4HX32Z.mjs.map +7 -0
- package/dist/types/src/AssistantPlugin.d.ts +1 -0
- package/dist/types/src/AssistantPlugin.d.ts.map +1 -1
- package/dist/types/src/AssistantPlugin.node.d.ts +4 -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/blueprints/assistant/blueprint.d.ts +2 -2
- package/dist/types/src/blueprints/assistant/blueprint.d.ts.map +1 -1
- package/dist/types/src/capabilities/ai-service.d.ts.map +1 -1
- package/dist/types/src/capabilities/app-graph-builder.d.ts.map +1 -1
- package/dist/types/src/capabilities/blueprint-definition.d.ts.map +1 -1
- package/dist/types/src/capabilities/companion-chat-provisioner.d.ts.map +1 -1
- package/dist/types/src/capabilities/edge-model-resolver.d.ts.map +1 -1
- package/dist/types/src/capabilities/index.d.ts +5 -17
- package/dist/types/src/capabilities/index.d.ts.map +1 -1
- package/dist/types/src/capabilities/local-model-resolver.d.ts +6 -3
- package/dist/types/src/capabilities/local-model-resolver.d.ts.map +1 -1
- package/dist/types/src/capabilities/markdown.d.ts +1 -1
- package/dist/types/src/capabilities/markdown.d.ts.map +1 -1
- package/dist/types/src/capabilities/migrations.d.ts +1 -1
- package/dist/types/src/capabilities/migrations.d.ts.map +1 -1
- package/dist/types/src/capabilities/operation-handler.d.ts +1 -1
- package/dist/types/src/capabilities/operation-handler.d.ts.map +1 -1
- package/dist/types/src/capabilities/react-surface.d.ts.map +1 -1
- package/dist/types/src/capabilities/settings.d.ts +1 -13
- package/dist/types/src/capabilities/settings.d.ts.map +1 -1
- package/dist/types/src/capabilities/state.d.ts.map +1 -1
- package/dist/types/src/capabilities/toolkit.d.ts.map +1 -1
- 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/cli/plugin.d.ts +10 -0
- package/dist/types/src/cli/plugin.d.ts.map +1 -0
- package/dist/types/src/components/AssistantSettings/AssistantSettings.d.ts +1 -1
- package/dist/types/src/components/AssistantSettings/AssistantSettings.d.ts.map +1 -1
- package/dist/types/src/components/AssistantSettings/AssistantSettings.stories.d.ts +1 -539
- package/dist/types/src/components/AssistantSettings/AssistantSettings.stories.d.ts.map +1 -1
- package/dist/types/src/components/Chat/Chat.d.ts +32 -42
- 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.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 +6 -2
- 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.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 +4 -541
- package/dist/types/src/components/ChatThread/ChatThread.stories.d.ts.map +1 -1
- package/dist/types/src/components/ChatThread/Link.d.ts.map +1 -1
- package/dist/types/src/components/ChatThread/MarkdownStream.stories.d.ts +9 -540
- package/dist/types/src/components/ChatThread/MarkdownStream.stories.d.ts.map +1 -1
- 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 +40 -14
- package/dist/types/src/components/ChatThread/sync.d.ts.map +1 -1
- package/dist/types/src/components/ChatThread/tool-widget-state.d.ts.map +1 -1
- package/dist/types/src/components/ChatThread/widgets/FallbackWidget.d.ts +4 -4
- package/dist/types/src/components/ChatThread/widgets/FallbackWidget.d.ts.map +1 -1
- package/dist/types/src/components/ChatThread/widgets/ReasoningWidget.d.ts.map +1 -1
- package/dist/types/src/components/ChatThread/widgets/ReasoningWidget.stories.d.ts.map +1 -1
- package/dist/types/src/components/ChatThread/widgets/ReferenceWidget.d.ts.map +1 -1
- package/dist/types/src/components/ChatThread/widgets/SelectWidget.d.ts.map +1 -1
- package/dist/types/src/components/ChatThread/widgets/StatsWidget.d.ts.map +1 -1
- package/dist/types/src/components/ChatThread/widgets/StatusWidget.d.ts.map +1 -1
- package/dist/types/src/components/ChatThread/widgets/SuggestionWidget.d.ts.map +1 -1
- package/dist/types/src/components/ChatThread/widgets/SummaryWidget.d.ts.map +1 -1
- package/dist/types/src/components/ChatThread/widgets/ToolWidget.d.ts.map +1 -1
- package/dist/types/src/components/ChatThread/widgets/ToolWidget.stories.d.ts +1 -539
- package/dist/types/src/components/ChatThread/widgets/ToolWidget.stories.d.ts.map +1 -1
- 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 +1 -2
- package/dist/types/src/components/ChatThread/widgets/index.d.ts.map +1 -1
- package/dist/types/src/components/ProcessTree/ProcessTree.d.ts +2 -1
- package/dist/types/src/components/ProcessTree/ProcessTree.d.ts.map +1 -1
- package/dist/types/src/components/ProcessTree/ProcessTree.stories.d.ts +0 -1
- package/dist/types/src/components/ProcessTree/ProcessTree.stories.d.ts.map +1 -1
- package/dist/types/src/components/TemplateEditor/TemplateEditor.d.ts +2 -2
- package/dist/types/src/components/TemplateEditor/TemplateEditor.d.ts.map +1 -1
- package/dist/types/src/components/TemplateEditor/TemplateEditor.stories.d.ts +1 -539
- package/dist/types/src/components/TemplateEditor/TemplateEditor.stories.d.ts.map +1 -1
- package/dist/types/src/components/TemplateEditor/TemplateForm.d.ts +3 -3
- package/dist/types/src/components/TemplateEditor/TemplateForm.d.ts.map +1 -1
- package/dist/types/src/components/TemplateEditor/TemplateForm.stories.d.ts +1 -539
- 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 -4
- package/dist/types/src/components/ToolBlock/ToolBlock.d.ts.map +1 -1
- package/dist/types/src/components/Toolbox/Toolbox.d.ts +3 -3
- package/dist/types/src/components/Toolbox/Toolbox.d.ts.map +1 -1
- package/dist/types/src/components/Toolbox/Toolbox.stories.d.ts +1 -539
- package/dist/types/src/components/Toolbox/Toolbox.stories.d.ts.map +1 -1
- package/dist/types/src/containers/AgentArticle/AgentArticle.d.ts +2 -2
- package/dist/types/src/containers/AgentArticle/AgentArticle.d.ts.map +1 -1
- package/dist/types/src/containers/AgentArticle/AgentArticle.stories.d.ts +7 -540
- package/dist/types/src/containers/AgentArticle/AgentArticle.stories.d.ts.map +1 -1
- package/dist/types/src/containers/AgentProperties/AgentProperties.d.ts +1 -1
- package/dist/types/src/containers/AgentProperties/AgentProperties.d.ts.map +1 -1
- package/dist/types/src/containers/AgentProperties/AgentProperties.stories.d.ts +1 -539
- package/dist/types/src/containers/AgentProperties/AgentProperties.stories.d.ts.map +1 -1
- package/dist/types/src/containers/BlueprintArticle/BlueprintArticle.d.ts +1 -1
- package/dist/types/src/containers/BlueprintArticle/BlueprintArticle.d.ts.map +1 -1
- package/dist/types/src/containers/ChatCompanion/ChatCompanion.d.ts +1 -1
- package/dist/types/src/containers/ChatContainer/ChatContainer.d.ts.map +1 -1
- package/dist/types/src/containers/ChatDialog/ChatDialog.d.ts.map +1 -1
- 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/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 +6 -4
- package/dist/types/src/containers/TracePanel/TracePanel.d.ts.map +1 -1
- package/dist/types/src/containers/TracePanel/TracePanel.stories.d.ts +13 -0
- package/dist/types/src/containers/TracePanel/TracePanel.stories.d.ts.map +1 -0
- package/dist/types/src/containers/TracePanel/dxn-extractor.d.ts +1 -1
- package/dist/types/src/containers/TracePanel/dxn-extractor.d.ts.map +1 -1
- package/dist/types/src/containers/TracePanel/execution-graph.d.ts +97 -0
- package/dist/types/src/containers/TracePanel/execution-graph.d.ts.map +1 -0
- package/dist/types/src/containers/TracePanel/execution-graph.test.d.ts +2 -0
- package/dist/types/src/containers/TracePanel/execution-graph.test.d.ts.map +1 -0
- package/dist/types/src/containers/TracePanel/index.d.ts.map +1 -1
- 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 -1
- package/dist/types/src/containers/TriggerStatus/index.d.ts.map +1 -1
- package/dist/types/src/containers/index.d.ts +2 -2
- package/dist/types/src/containers/index.d.ts.map +1 -1
- package/dist/types/src/extensions/prompt-extension.d.ts.map +1 -1
- 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 +1 -1
- 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 +1 -1
- package/dist/types/src/hooks/useChatProcessor.d.ts.map +1 -1
- 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.map +1 -1
- 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.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.map +1 -1
- package/dist/types/src/hooks/useReferencesProvider.d.ts.map +1 -1
- package/dist/types/src/index.d.ts +3 -5
- package/dist/types/src/index.d.ts.map +1 -1
- package/dist/types/src/operations/create-chat.d.ts +1 -1
- package/dist/types/src/operations/create-chat.d.ts.map +1 -1
- package/dist/types/src/operations/definitions.d.ts +24 -19
- package/dist/types/src/operations/definitions.d.ts.map +1 -1
- package/dist/types/src/operations/ensure-companion-chat.d.ts +1 -1
- package/dist/types/src/operations/ensure-companion-chat.d.ts.map +1 -1
- package/dist/types/src/operations/index.d.ts +1 -1
- package/dist/types/src/operations/index.d.ts.map +1 -1
- package/dist/types/src/operations/on-create-space.d.ts +1 -1
- package/dist/types/src/operations/on-create-space.d.ts.map +1 -1
- package/dist/types/src/operations/prompt.test.d.ts +2 -0
- package/dist/types/src/operations/prompt.test.d.ts.map +1 -0
- package/dist/types/src/operations/resolve-navigation-targets.d.ts +1 -1
- package/dist/types/src/operations/resolve-navigation-targets.d.ts.map +1 -1
- package/dist/types/src/operations/run-prompt-in-new-chat.d.ts +1 -1
- package/dist/types/src/operations/run-prompt-in-new-chat.d.ts.map +1 -1
- package/dist/types/src/operations/set-current-chat.d.ts +1 -1
- package/dist/types/src/operations/set-current-chat.d.ts.map +1 -1
- package/dist/types/src/operations/update-chat-name.d.ts +1 -1
- package/dist/types/src/operations/update-chat-name.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 +25 -7
- package/dist/types/src/processor/processor.d.ts.map +1 -1
- package/dist/types/src/queue-logger.d.ts.map +1 -1
- 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/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-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.test.d.ts +2 -0
- package/dist/types/src/testing/trace-timeline.test.d.ts.map +1 -0
- package/dist/types/src/translations.d.ts +2 -539
- package/dist/types/src/translations.d.ts.map +1 -1
- package/dist/types/src/types/Assistant.d.ts +22 -6
- package/dist/types/src/types/Assistant.d.ts.map +1 -1
- package/dist/types/src/types/Settings.d.ts +22 -6
- package/dist/types/src/types/Settings.d.ts.map +1 -1
- package/dist/types/src/types/capabilities.d.ts +1 -13
- package/dist/types/src/types/capabilities.d.ts.map +1 -1
- package/dist/types/src/types/events.d.ts.map +1 -1
- package/dist/types/src/types/index.d.ts +0 -1
- package/dist/types/src/types/index.d.ts.map +1 -1
- package/dist/types/src/types/service.d.ts +1 -1
- package/dist/types/src/types/service.d.ts.map +1 -1
- package/dist/types/tsconfig.tsbuildinfo +1 -1
- package/package.json +113 -99
- package/src/AssistantPlugin.node.ts +125 -0
- package/src/AssistantPlugin.test.ts +35 -0
- package/src/AssistantPlugin.tsx +22 -16
- package/src/blueprints/assistant/blueprint.test.ts +3 -3
- package/src/blueprints/assistant/blueprint.ts +3 -3
- package/src/capabilities/app-graph-builder.ts +5 -61
- package/src/capabilities/blueprint-definition.ts +2 -4
- package/src/capabilities/index.ts +2 -1
- package/src/capabilities/local-model-resolver.ts +14 -4
- package/src/capabilities/markdown.ts +1 -1
- package/src/capabilities/migrations.ts +1 -7
- package/src/capabilities/operation-handler.ts +1 -1
- package/src/capabilities/react-surface.tsx +38 -28
- package/src/capabilities/toolkit.ts +2 -2
- package/src/{components/Typewriter → cli}/index.ts +1 -1
- package/src/cli/plugin.ts +83 -0
- package/src/components/AssistantSettings/AssistantSettings.stories.tsx +3 -2
- package/src/components/AssistantSettings/AssistantSettings.tsx +22 -111
- package/src/components/Chat/Chat.tsx +82 -286
- package/src/components/Chat/context.ts +39 -0
- package/src/components/ChatPrompt/ChatActions.tsx +10 -10
- package/src/components/ChatPrompt/ChatMcpErrors.tsx +50 -0
- package/src/components/ChatPrompt/ChatOptions.stories.tsx +136 -0
- package/src/components/ChatPrompt/ChatOptions.tsx +229 -37
- package/src/components/ChatPrompt/ChatPrompt.tsx +182 -0
- package/src/components/ChatPrompt/ChatReferences.tsx +1 -1
- package/src/components/ChatPrompt/ChatStatus.tsx +123 -0
- package/src/components/ChatPrompt/index.ts +3 -0
- package/src/components/ChatThread/Anchor.stories.tsx +95 -0
- package/src/components/ChatThread/ChatThread.stories.tsx +39 -29
- package/src/components/ChatThread/ChatThread.tsx +36 -21
- package/src/components/ChatThread/DEBUG.md +41 -0
- package/src/components/ChatThread/MarkdownStream.stories.tsx +43 -5
- package/src/components/ChatThread/registry.tsx +72 -24
- package/src/components/ChatThread/sync.test.ts +175 -15
- package/src/components/ChatThread/sync.ts +87 -102
- package/src/components/ChatThread/testing/reasoning.md +25 -0
- package/src/components/ChatThread/widgets/FallbackWidget.tsx +2 -2
- package/src/components/ChatThread/widgets/ReasoningWidget.stories.tsx +1 -1
- package/src/components/ChatThread/widgets/ReasoningWidget.ts +6 -6
- package/src/components/ChatThread/widgets/ReferenceWidget.ts +3 -1
- package/src/components/ChatThread/widgets/SelectWidget.ts +3 -1
- package/src/components/ChatThread/widgets/StatsWidget.ts +3 -1
- package/src/components/ChatThread/widgets/StatusWidget.ts +3 -3
- package/src/components/ChatThread/widgets/SuggestionWidget.ts +1 -1
- package/src/components/ChatThread/widgets/SummaryWidget.tsx +3 -2
- package/src/components/ChatThread/widgets/ToolWidget.stories.tsx +3 -2
- package/src/components/ChatThread/widgets/ToolWidget.tsx +2 -2
- package/src/components/ChatThread/widgets/defaults.ts +8 -0
- package/src/components/ChatThread/widgets/index.ts +1 -2
- package/src/components/ProcessTree/ProcessTree.stories.tsx +12 -38
- package/src/components/ProcessTree/ProcessTree.tsx +70 -37
- package/src/components/TemplateEditor/TemplateEditor.stories.tsx +3 -2
- package/src/components/TemplateEditor/TemplateEditor.tsx +5 -5
- package/src/components/TemplateEditor/TemplateForm.stories.tsx +4 -3
- package/src/components/TemplateEditor/TemplateForm.tsx +3 -3
- package/src/components/TemplateEditor/extensions/handlebars-extension.ts +1 -1
- package/src/components/ToolBlock/ToolBlock.tsx +2 -2
- package/src/components/Toolbox/Toolbox.stories.tsx +2 -1
- package/src/components/Toolbox/Toolbox.tsx +2 -2
- package/src/containers/AgentArticle/AgentArticle.stories.tsx +40 -25
- package/src/containers/AgentArticle/AgentArticle.tsx +96 -53
- package/src/containers/AgentProperties/AgentProperties.stories.tsx +14 -4
- package/src/containers/AgentProperties/AgentProperties.tsx +46 -88
- package/src/containers/BlueprintArticle/BlueprintArticle.tsx +1 -1
- package/src/containers/ChatCompanion/ChatCompanion.tsx +1 -1
- package/src/containers/ChatContainer/ChatContainer.tsx +16 -6
- package/src/containers/ChatDialog/ChatDialog.tsx +3 -9
- package/src/containers/{PromptArticle/PromptArticle.tsx → RoutineArticle/RoutineArticle.tsx} +4 -4
- package/src/containers/RoutineArticle/index.ts +5 -0
- package/src/containers/{PromptList/PromptList.stories.tsx → RoutineList/RoutineList.stories.tsx} +11 -10
- package/src/containers/{PromptList/PromptList.tsx → RoutineList/RoutineList.tsx} +6 -5
- package/src/containers/RoutineList/index.ts +5 -0
- package/src/containers/TracePanel/TracePanel.stories.tsx +278 -0
- package/src/containers/TracePanel/TracePanel.tsx +95 -318
- package/src/containers/TracePanel/dxn-extractor.test.ts +7 -7
- package/src/containers/TracePanel/dxn-extractor.ts +4 -4
- package/src/containers/TracePanel/execution-graph.test.ts +382 -0
- package/src/containers/TracePanel/execution-graph.ts +579 -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 +19 -34
- package/src/containers/TriggerStatus/index.ts +1 -1
- package/src/containers/index.ts +2 -2
- package/src/hooks/index.ts +2 -0
- package/src/hooks/useBlueprintRegistry.ts +1 -1
- package/src/hooks/useChatKeymap.ts +52 -0
- package/src/hooks/useChatProcessor.ts +11 -11
- package/src/hooks/useDebug.ts +38 -0
- package/src/index.ts +8 -6
- package/src/operations/create-chat.ts +1 -2
- package/src/operations/definitions.ts +3 -4
- package/src/operations/ensure-companion-chat.ts +1 -1
- package/src/operations/index.ts +1 -1
- package/src/operations/on-create-space.ts +1 -1
- package/src/operations/prompt.test.ts +77 -0
- package/src/operations/resolve-navigation-targets.ts +1 -1
- package/src/operations/run-prompt-in-new-chat.ts +2 -3
- package/src/operations/set-current-chat.ts +1 -1
- package/src/operations/update-chat-name.ts +2 -2
- package/src/processor/presets.ts +9 -1
- package/src/processor/processor.test.ts +4 -4
- package/src/processor/processor.ts +43 -27
- package/src/queue-logger.ts +19 -8
- package/src/testing/data/trace-timeline.dx.json +4657 -0
- package/src/testing/index.ts +1 -0
- package/src/testing/test-generator.test.ts +81 -0
- package/src/testing/test-generator.ts +46 -40
- package/src/testing/test-trace.ts +20 -0
- package/src/testing/trace-timeline.conversations.json +1 -0
- package/src/testing/trace-timeline.test.ts +249 -0
- package/src/translations.ts +49 -34
- package/src/types/Assistant.ts +11 -0
- package/src/types/Settings.ts +63 -8
- package/src/types/index.ts +0 -1
- package/src/types/service.ts +1 -1
- package/dist/lib/browser/AssistantSettings-7QMO3LGF.mjs +0 -97
- package/dist/lib/browser/AssistantSettings-7QMO3LGF.mjs.map +0 -7
- package/dist/lib/browser/chunk-ATHYBVGN.mjs.map +0 -7
- package/dist/lib/browser/chunk-EZRS3J25.mjs +0 -30
- package/dist/lib/browser/chunk-EZRS3J25.mjs.map +0 -7
- package/dist/lib/browser/chunk-RUV2WOQH.mjs.map +0 -7
- package/dist/lib/browser/create-chat-LBZHGVSN.mjs.map +0 -7
- package/dist/lib/browser/ensure-companion-chat-FR4AWZ2P.mjs.map +0 -7
- package/dist/lib/browser/run-prompt-in-new-chat-4YQ37XIS.mjs.map +0 -7
- package/dist/lib/browser/set-current-chat-WJI3WAVM.mjs.map +0 -7
- package/dist/lib/browser/update-chat-name-3Y36KFAS.mjs.map +0 -7
- package/dist/lib/node-esm/AssistantSettings-UVUTKO7E.mjs +0 -98
- package/dist/lib/node-esm/AssistantSettings-UVUTKO7E.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-NZIKC7AN.mjs +0 -32
- package/dist/lib/node-esm/chunk-NZIKC7AN.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-PXAJSTGZ.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-PY4X6FJT.mjs.map +0 -7
- package/dist/lib/node-esm/create-chat-3BEG4R6J.mjs.map +0 -7
- package/dist/lib/node-esm/ensure-companion-chat-BLP7NT32.mjs.map +0 -7
- package/dist/lib/node-esm/run-prompt-in-new-chat-2IJBSDTM.mjs.map +0 -7
- package/dist/lib/node-esm/set-current-chat-KBMMZULR.mjs.map +0 -7
- package/dist/lib/node-esm/update-chat-name-HM2P4NSI.mjs.map +0 -7
- package/dist/types/src/components/ChatProgress/ChatProgress.d.ts +0 -10
- 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/ChatThread/widgets/PromptWidget.d.ts +0 -14
- package/dist/types/src/components/ChatThread/widgets/PromptWidget.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/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 -2
- package/dist/types/src/containers/PromptArticle/index.d.ts.map +0 -1
- package/dist/types/src/containers/PromptList/PromptList.d.ts +0 -6
- package/dist/types/src/containers/PromptList/PromptList.d.ts.map +0 -1
- package/dist/types/src/containers/PromptList/PromptList.stories.d.ts +0 -559
- package/dist/types/src/containers/PromptList/PromptList.stories.d.ts.map +0 -1
- package/dist/types/src/containers/PromptList/index.d.ts +0 -2
- package/dist/types/src/containers/PromptList/index.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/src/blueprints/assistant/blueprint.conversations.json +0 -1
- package/src/components/ChatProgress/ChatProgress.tsx +0 -56
- package/src/components/ChatProgress/index.ts +0 -5
- package/src/components/ChatThread/widgets/PromptWidget.ts +0 -28
- package/src/components/Typewriter/AssistantToolbar.tsx +0 -161
- package/src/components/Typewriter/Typewriter.stories.tsx +0 -86
- package/src/components/Typewriter/Typewriter.tsx +0 -50
- package/src/components/Typewriter/assistant-extension.tsx +0 -141
- package/src/containers/PromptArticle/index.ts +0 -5
- package/src/containers/PromptList/index.ts +0 -5
- package/src/types/defs.ts +0 -5
|
@@ -5,78 +5,118 @@
|
|
|
5
5
|
import { Atom } from '@effect-atom/atom';
|
|
6
6
|
import { useAtomValue } from '@effect-atom/atom-react';
|
|
7
7
|
import { pipe } from 'effect/Function';
|
|
8
|
-
import React, { useCallback, useMemo } from 'react';
|
|
8
|
+
import React, { useCallback, useMemo, useState } from 'react';
|
|
9
9
|
|
|
10
10
|
import { useOperationInvoker } from '@dxos/app-framework/ui';
|
|
11
11
|
import { LayoutOperation } from '@dxos/app-toolkit';
|
|
12
|
-
import {
|
|
12
|
+
import { type AppSurface } from '@dxos/app-toolkit/ui';
|
|
13
|
+
import { Trace } from '@dxos/compute';
|
|
13
14
|
import { Filter, Query } from '@dxos/echo';
|
|
14
15
|
import { AtomQuery } from '@dxos/echo-atom';
|
|
15
|
-
import { Trace } from '@dxos/functions';
|
|
16
16
|
import { FeedTraceSink, Process } from '@dxos/functions-runtime';
|
|
17
|
-
import { DXN
|
|
18
|
-
import {
|
|
17
|
+
import { DXN } from '@dxos/keys';
|
|
18
|
+
import { log } from '@dxos/log';
|
|
19
19
|
import { useComputeRuntimeService } from '@dxos/plugin-automation/hooks';
|
|
20
20
|
import { type Space } from '@dxos/react-client/echo';
|
|
21
21
|
import { Panel } from '@dxos/react-ui';
|
|
22
22
|
import { Timeline, type Commit } from '@dxos/react-ui-components';
|
|
23
|
-
import { mx } from '@dxos/ui-theme';
|
|
23
|
+
import { composable, mx } from '@dxos/ui-theme';
|
|
24
|
+
|
|
25
|
+
import { ProcessTree, ProcessTreeProps } from '#components';
|
|
26
|
+
|
|
27
|
+
import { buildExecutionGraph } from './execution-graph';
|
|
28
|
+
|
|
29
|
+
export type TracePanelProps = AppSurface.SpaceArticleProps<Pick<ProcessTreeProps, 'onProcessTerminate'>>;
|
|
30
|
+
|
|
31
|
+
export const TracePanel = composable<HTMLDivElement, TracePanelProps>(
|
|
32
|
+
({ space, onProcessTerminate, ...props }, forwardedRef) => {
|
|
33
|
+
const { invokePromise } = useOperationInvoker();
|
|
34
|
+
const { branches, commits } = useExecutionGraph(space);
|
|
35
|
+
const runtime = useComputeRuntimeService(Process.ProcessMonitorService, space.id);
|
|
36
|
+
const processes = useAtomValue(runtime?.processTreeAtom ?? atomEmpty);
|
|
37
|
+
|
|
38
|
+
const handleCommitClick = useCallback(
|
|
39
|
+
(commit: Commit) => {
|
|
40
|
+
if (commit.link) {
|
|
41
|
+
const dxn = DXN.tryParse(commit.link)?.asEchoDXN();
|
|
42
|
+
if (dxn?.spaceId && dxn.echoId) {
|
|
43
|
+
// TODO(dmaretskyi): Navigates, but fails to open.
|
|
44
|
+
void invokePromise(LayoutOperation.Open, {
|
|
45
|
+
subject: [`${dxn.spaceId}:${dxn.echoId}`],
|
|
46
|
+
});
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
},
|
|
50
|
+
[invokePromise],
|
|
51
|
+
);
|
|
24
52
|
|
|
25
|
-
|
|
53
|
+
// Select current branch.
|
|
54
|
+
const [currentBranch, setCurrentBranch] = useState<string | null>(null);
|
|
55
|
+
const handleProcessSelect = useCallback(
|
|
56
|
+
(process: Process.Info) => {
|
|
57
|
+
const branch = branches.find((branch) => branch === process.pid.toString());
|
|
58
|
+
if (branch) {
|
|
59
|
+
log.info('select', { process, branch });
|
|
60
|
+
setCurrentBranch(branch);
|
|
61
|
+
}
|
|
62
|
+
},
|
|
63
|
+
[branches],
|
|
64
|
+
);
|
|
26
65
|
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
66
|
+
return (
|
|
67
|
+
<Panel.Root {...props} ref={forwardedRef}>
|
|
68
|
+
<Panel.Content className='grid grid-rows-[min-content_1fr] divide-y divide-separator'>
|
|
69
|
+
<ProcessTree
|
|
70
|
+
classNames={mx('max-h-[8lh] border-b border-separator')}
|
|
71
|
+
processes={processes}
|
|
72
|
+
onProcessSelect={handleProcessSelect}
|
|
73
|
+
onProcessTerminate={onProcessTerminate}
|
|
74
|
+
/>
|
|
75
|
+
<Timeline
|
|
76
|
+
currentBranch={currentBranch}
|
|
77
|
+
branches={branches}
|
|
78
|
+
commits={commits}
|
|
79
|
+
compact
|
|
80
|
+
onCommitClick={handleCommitClick}
|
|
81
|
+
/>
|
|
82
|
+
</Panel.Content>
|
|
83
|
+
</Panel.Root>
|
|
84
|
+
);
|
|
85
|
+
},
|
|
86
|
+
);
|
|
31
87
|
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
() => getExecutionGraph(space, runtime?.processTreeAtom ?? Atom.make(() => [])),
|
|
35
|
-
[space, runtime?.processTreeAtom],
|
|
36
|
-
),
|
|
37
|
-
);
|
|
88
|
+
// Stable ref.
|
|
89
|
+
const atomEmpty = Atom.make(() => [] as const);
|
|
38
90
|
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
if (dxn?.spaceId && dxn.echoId) {
|
|
44
|
-
// TODO(dmaretskyi): Navigates, but fails to open.
|
|
45
|
-
void invokePromise(LayoutOperation.Open, { subject: [`${dxn.spaceId}:${dxn.echoId}`] });
|
|
46
|
-
}
|
|
47
|
-
}
|
|
48
|
-
},
|
|
49
|
-
[invokePromise],
|
|
50
|
-
);
|
|
91
|
+
type ExecutionGraph = {
|
|
92
|
+
branches: string[];
|
|
93
|
+
commits: Commit[];
|
|
94
|
+
};
|
|
51
95
|
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
<Panel.Content className='grid grid-rows-[min-content_1fr]'>
|
|
55
|
-
<ProcessTree
|
|
56
|
-
classNames={mx('max-h-[8lh] px-2', activeProcesses.length > 0 && 'border-b border-separator')}
|
|
57
|
-
processes={activeProcesses}
|
|
58
|
-
/>
|
|
59
|
-
<Timeline classNames='py-1' branches={branches} commits={commits} compact onCommitClick={handleCommitClick} />
|
|
60
|
-
</Panel.Content>
|
|
61
|
-
</Panel.Root>
|
|
62
|
-
);
|
|
96
|
+
type UseExecutionGraphOptions = {
|
|
97
|
+
eventLimit?: number;
|
|
63
98
|
};
|
|
64
99
|
|
|
65
|
-
|
|
66
|
-
|
|
100
|
+
const useExecutionGraph = (space: Space, { eventLimit }: UseExecutionGraphOptions = {}): ExecutionGraph => {
|
|
101
|
+
const runtime = useComputeRuntimeService(Process.ProcessMonitorService, space.id);
|
|
102
|
+
const activeProcesses = useAtomValue(runtime?.processTreeAtom ?? atomEmpty);
|
|
103
|
+
const atom = useMemo(
|
|
104
|
+
() => getExecutionGraph(space, activeProcesses, { eventLimit }),
|
|
105
|
+
[space, activeProcesses, eventLimit],
|
|
106
|
+
);
|
|
107
|
+
|
|
108
|
+
return useAtomValue(atom);
|
|
67
109
|
};
|
|
68
110
|
|
|
69
111
|
const getExecutionGraph = (
|
|
70
112
|
space: Space,
|
|
71
|
-
|
|
72
|
-
{ eventLimit =
|
|
73
|
-
): Atom.Atom<{
|
|
74
|
-
branches: string[];
|
|
75
|
-
commits: Commit[];
|
|
76
|
-
}> => {
|
|
113
|
+
activeProcesses: readonly Process.Info[] = [],
|
|
114
|
+
{ eventLimit = 300 }: UseExecutionGraphOptions = {},
|
|
115
|
+
): Atom.Atom<ExecutionGraph> => {
|
|
77
116
|
return pipe(
|
|
78
117
|
AtomQuery.make(space.db, FeedTraceSink.query),
|
|
79
118
|
Atom.map((feeds) => {
|
|
119
|
+
log('trace panel query trace feeds', { spaceId: space.id, feedCount: feeds.length });
|
|
80
120
|
// TODO(dmaretskyi): This should be possible in a single query with properly working limit(1) and feed > feed contents traversal.
|
|
81
121
|
return AtomQuery.make(
|
|
82
122
|
space.db,
|
|
@@ -87,275 +127,12 @@ const getExecutionGraph = (
|
|
|
87
127
|
}),
|
|
88
128
|
(_) => Atom.make((get) => get(get(_))),
|
|
89
129
|
(_) =>
|
|
90
|
-
Atom.make((get) =>
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
id: message.id,
|
|
98
|
-
meta: message.meta,
|
|
99
|
-
...event,
|
|
100
|
-
})),
|
|
101
|
-
);
|
|
102
|
-
|
|
103
|
-
for (const event of events) {
|
|
104
|
-
if (Trace.isOfType(CompleteBlock, event)) {
|
|
105
|
-
switch (event.data.block._tag) {
|
|
106
|
-
case 'text': {
|
|
107
|
-
if (event.data.role === 'user') {
|
|
108
|
-
builder.addUserMessage(
|
|
109
|
-
event.id,
|
|
110
|
-
event.meta.conversationId ?? 'unknown_conversation',
|
|
111
|
-
event.meta.pid ?? crypto.randomUUID(),
|
|
112
|
-
event.data.block.text,
|
|
113
|
-
event.timestamp,
|
|
114
|
-
);
|
|
115
|
-
} else {
|
|
116
|
-
builder.addAssistantMessage(
|
|
117
|
-
event.id,
|
|
118
|
-
event.meta.conversationId ?? 'unknown_conversation',
|
|
119
|
-
event.meta.pid ?? crypto.randomUUID(),
|
|
120
|
-
event.data.block.text,
|
|
121
|
-
event.timestamp,
|
|
122
|
-
);
|
|
123
|
-
}
|
|
124
|
-
break;
|
|
125
|
-
}
|
|
126
|
-
case 'status': {
|
|
127
|
-
builder.addStatusMessage(
|
|
128
|
-
event.id,
|
|
129
|
-
event.meta.conversationId ?? 'unknown_conversation',
|
|
130
|
-
event.meta.pid ?? crypto.randomUUID(),
|
|
131
|
-
event.data.block.statusText,
|
|
132
|
-
event.timestamp,
|
|
133
|
-
);
|
|
134
|
-
break;
|
|
135
|
-
}
|
|
136
|
-
case 'toolCall': {
|
|
137
|
-
builder.addToolCall(
|
|
138
|
-
`${event.data.block.toolCallId}:call`,
|
|
139
|
-
event.meta.conversationId ?? 'unknown_conversation',
|
|
140
|
-
event.meta.pid ?? crypto.randomUUID(),
|
|
141
|
-
event.data.block.name,
|
|
142
|
-
event.timestamp,
|
|
143
|
-
);
|
|
144
|
-
break;
|
|
145
|
-
}
|
|
146
|
-
case 'toolResult': {
|
|
147
|
-
builder.addToolResult(
|
|
148
|
-
`${event.data.block.toolCallId}:result`,
|
|
149
|
-
event.meta.conversationId ?? 'unknown_conversation',
|
|
150
|
-
event.meta.pid ?? crypto.randomUUID(),
|
|
151
|
-
event.data.block.error,
|
|
152
|
-
event.timestamp,
|
|
153
|
-
);
|
|
154
|
-
break;
|
|
155
|
-
}
|
|
156
|
-
}
|
|
157
|
-
}
|
|
158
|
-
|
|
159
|
-
// Process operation trace events.
|
|
160
|
-
if (Trace.isOfType(Trace.OperationStart, event)) {
|
|
161
|
-
if (!event.meta.conversationId) {
|
|
162
|
-
// Operations inside conversations will be handled by tool call events.
|
|
163
|
-
builder.addOperationStart(
|
|
164
|
-
`${event.id}:${event.data.key}:start`,
|
|
165
|
-
event.meta.pid ?? crypto.randomUUID(),
|
|
166
|
-
event.data.name ?? event.data.key,
|
|
167
|
-
event.timestamp,
|
|
168
|
-
);
|
|
169
|
-
}
|
|
170
|
-
}
|
|
171
|
-
if (Trace.isOfType(Trace.OperationEnd, event)) {
|
|
172
|
-
if (!event.meta.conversationId) {
|
|
173
|
-
// Operations inside conversations will be handled by tool call events.
|
|
174
|
-
builder.addOperationEnd(
|
|
175
|
-
`${event.id}:${event.data.key}:end`,
|
|
176
|
-
event.meta.pid ?? crypto.randomUUID(),
|
|
177
|
-
event.data.name ?? event.data.key,
|
|
178
|
-
event.data.outcome,
|
|
179
|
-
event.data.error,
|
|
180
|
-
event.timestamp,
|
|
181
|
-
);
|
|
182
|
-
}
|
|
183
|
-
}
|
|
184
|
-
}
|
|
185
|
-
|
|
186
|
-
const activeProcesses = get(processTreeAtom);
|
|
187
|
-
for (const process of activeProcesses) {
|
|
188
|
-
if (
|
|
189
|
-
process.key === AGENT_PROCESS_KEY &&
|
|
190
|
-
process.params.target &&
|
|
191
|
-
(process.state === Process.State.RUNNING || process.state === Process.State.HYBERNATING)
|
|
192
|
-
) {
|
|
193
|
-
const conversationId = DXN.parse(process.params.target).asEchoDXN()?.echoId;
|
|
194
|
-
if (conversationId) {
|
|
195
|
-
builder.addRunningAgent(process.pid, conversationId, Date.now());
|
|
196
|
-
}
|
|
197
|
-
}
|
|
198
|
-
}
|
|
199
|
-
return builder.build();
|
|
200
|
-
}),
|
|
130
|
+
Atom.make((get) =>
|
|
131
|
+
buildExecutionGraph({
|
|
132
|
+
traceMessages: [...get(_)],
|
|
133
|
+
activeProcesses,
|
|
134
|
+
eventLimit,
|
|
135
|
+
}),
|
|
136
|
+
),
|
|
201
137
|
);
|
|
202
138
|
};
|
|
203
|
-
|
|
204
|
-
// Stable ref.
|
|
205
|
-
const atomEmpty = Atom.make(() => [] as const);
|
|
206
|
-
|
|
207
|
-
const useActiveProcesses = (id?: SpaceId) => {
|
|
208
|
-
const runtime = useComputeRuntimeService(Process.ProcessMonitorService, id);
|
|
209
|
-
return useAtomValue(runtime?.processTreeAtom ?? atomEmpty);
|
|
210
|
-
};
|
|
211
|
-
|
|
212
|
-
class GraphBuilder {
|
|
213
|
-
#commits: Commit[] = [];
|
|
214
|
-
#branches = new Set<string>();
|
|
215
|
-
#lastCommitByBranch = new Map<string, string>();
|
|
216
|
-
#operationPidToStartCommitId = new Map<string, string>();
|
|
217
|
-
|
|
218
|
-
#addCommit(commit: Commit, opts?: { replaceCommit?: string }) {
|
|
219
|
-
this.#branches.add(commit.branch);
|
|
220
|
-
if (opts?.replaceCommit) {
|
|
221
|
-
const commitIdx = this.#commits.findIndex((commit) => commit.id === opts.replaceCommit);
|
|
222
|
-
if (commitIdx !== -1) {
|
|
223
|
-
this.#commits[commitIdx] = commit;
|
|
224
|
-
}
|
|
225
|
-
} else {
|
|
226
|
-
this.#commits.push(commit);
|
|
227
|
-
this.#lastCommitByBranch.set(commit.branch, commit.id);
|
|
228
|
-
}
|
|
229
|
-
}
|
|
230
|
-
|
|
231
|
-
#defaultParents(branch: string, opts?: { branchForFirst?: string }) {
|
|
232
|
-
return this.#lastCommitByBranch.get(branch)
|
|
233
|
-
? [this.#lastCommitByBranch.get(branch)!]
|
|
234
|
-
: opts?.branchForFirst
|
|
235
|
-
? [opts.branchForFirst]
|
|
236
|
-
: [];
|
|
237
|
-
}
|
|
238
|
-
|
|
239
|
-
build() {
|
|
240
|
-
return {
|
|
241
|
-
commits: this.#commits,
|
|
242
|
-
branches: [...this.#branches],
|
|
243
|
-
};
|
|
244
|
-
}
|
|
245
|
-
|
|
246
|
-
addUserMessage(id: string, coversationId: string, pid: string, text: string, ts: number) {
|
|
247
|
-
this.#addCommit({
|
|
248
|
-
id,
|
|
249
|
-
branch: coversationId,
|
|
250
|
-
parents: this.#defaultParents(coversationId, { branchForFirst: this.#operationPidToStartCommitId.get(pid) }),
|
|
251
|
-
icon: 'ph--paper-plane-right--regular',
|
|
252
|
-
level: LogLevel.VERBOSE,
|
|
253
|
-
message: text.slice(0, 100),
|
|
254
|
-
timestamp: new Date(ts),
|
|
255
|
-
});
|
|
256
|
-
}
|
|
257
|
-
|
|
258
|
-
addAssistantMessage(id: string, coversationId: string, pid: string, text: string, ts: number) {
|
|
259
|
-
this.#addCommit({
|
|
260
|
-
id,
|
|
261
|
-
branch: coversationId,
|
|
262
|
-
parents: this.#defaultParents(coversationId, { branchForFirst: this.#operationPidToStartCommitId.get(pid) }),
|
|
263
|
-
icon: 'ph--drone--regular',
|
|
264
|
-
level: LogLevel.VERBOSE,
|
|
265
|
-
message: text.slice(0, 100),
|
|
266
|
-
timestamp: new Date(ts),
|
|
267
|
-
});
|
|
268
|
-
}
|
|
269
|
-
|
|
270
|
-
addStatusMessage(id: string, coversationId: string, pid: string, status: string, ts: number) {
|
|
271
|
-
this.#addCommit({
|
|
272
|
-
id,
|
|
273
|
-
branch: coversationId,
|
|
274
|
-
parents: this.#defaultParents(coversationId, { branchForFirst: this.#operationPidToStartCommitId.get(pid) }),
|
|
275
|
-
icon: 'ph--dot-outline--regular',
|
|
276
|
-
level: LogLevel.INFO,
|
|
277
|
-
message: status,
|
|
278
|
-
timestamp: new Date(ts),
|
|
279
|
-
});
|
|
280
|
-
}
|
|
281
|
-
addToolCall(id: string, coversationId: string, pid: string, toolName: string, ts: number) {
|
|
282
|
-
this.#addCommit({
|
|
283
|
-
id,
|
|
284
|
-
branch: coversationId,
|
|
285
|
-
parents: this.#defaultParents(coversationId, { branchForFirst: this.#operationPidToStartCommitId.get(pid) }),
|
|
286
|
-
icon: 'ph--wrench--regular',
|
|
287
|
-
level: LogLevel.INFO,
|
|
288
|
-
message: toolName,
|
|
289
|
-
timestamp: new Date(ts),
|
|
290
|
-
});
|
|
291
|
-
}
|
|
292
|
-
|
|
293
|
-
addToolResult(id: string, coversationId: string, pid: string, error: string | undefined, ts: number) {
|
|
294
|
-
this.#addCommit({
|
|
295
|
-
id,
|
|
296
|
-
branch: coversationId,
|
|
297
|
-
parents: this.#defaultParents(coversationId, { branchForFirst: this.#operationPidToStartCommitId.get(pid) }),
|
|
298
|
-
icon: error ? 'ph--x-circle--regular' : 'ph--check-circle--regular',
|
|
299
|
-
level: error ? LogLevel.ERROR : LogLevel.INFO,
|
|
300
|
-
message: error ? `Error: ${error}` : 'Success',
|
|
301
|
-
timestamp: new Date(ts),
|
|
302
|
-
});
|
|
303
|
-
}
|
|
304
|
-
|
|
305
|
-
addRunningAgent(pid: string, conversationId: string, ts: number) {
|
|
306
|
-
this.#addCommit({
|
|
307
|
-
id: pid,
|
|
308
|
-
branch: conversationId,
|
|
309
|
-
parents: this.#defaultParents(conversationId),
|
|
310
|
-
icon: 'ph--spinner-gap--regular',
|
|
311
|
-
level: LogLevel.INFO,
|
|
312
|
-
message: 'Generating...',
|
|
313
|
-
timestamp: new Date(ts),
|
|
314
|
-
});
|
|
315
|
-
}
|
|
316
|
-
|
|
317
|
-
addOperationStart(id: string, pid: string, operationName: string, ts: number) {
|
|
318
|
-
this.#operationPidToStartCommitId.set(pid, id);
|
|
319
|
-
this.#addCommit({
|
|
320
|
-
id,
|
|
321
|
-
branch: OPERATIONS_BRANCH,
|
|
322
|
-
parents: this.#defaultParents(OPERATIONS_BRANCH),
|
|
323
|
-
icon: 'ph--play--regular',
|
|
324
|
-
level: LogLevel.INFO,
|
|
325
|
-
message: operationName,
|
|
326
|
-
timestamp: new Date(ts),
|
|
327
|
-
});
|
|
328
|
-
}
|
|
329
|
-
|
|
330
|
-
addOperationEnd(
|
|
331
|
-
id: string,
|
|
332
|
-
pid: string,
|
|
333
|
-
operationName: string,
|
|
334
|
-
outcome: 'success' | 'failure',
|
|
335
|
-
error: string | undefined,
|
|
336
|
-
ts: number,
|
|
337
|
-
) {
|
|
338
|
-
const isError = outcome === 'failure';
|
|
339
|
-
const startCommitId = this.#operationPidToStartCommitId.get(pid);
|
|
340
|
-
const hasChildren = this.#commits.some((commit) => commit.parents?.includes(startCommitId!));
|
|
341
|
-
this.#addCommit(
|
|
342
|
-
{
|
|
343
|
-
id,
|
|
344
|
-
branch: OPERATIONS_BRANCH,
|
|
345
|
-
parents: this.#defaultParents(OPERATIONS_BRANCH),
|
|
346
|
-
icon: isError ? 'ph--x-circle--regular' : 'ph--check-circle--regular',
|
|
347
|
-
level: isError ? LogLevel.ERROR : LogLevel.INFO,
|
|
348
|
-
message: isError ? `${operationName}: ${error ?? 'Failed'}` : operationName,
|
|
349
|
-
timestamp: new Date(ts),
|
|
350
|
-
},
|
|
351
|
-
{
|
|
352
|
-
replaceCommit: hasChildren ? undefined : this.#operationPidToStartCommitId.get(pid),
|
|
353
|
-
},
|
|
354
|
-
);
|
|
355
|
-
}
|
|
356
|
-
}
|
|
357
|
-
|
|
358
|
-
/**
|
|
359
|
-
* Branch name for top-level operation invocations.
|
|
360
|
-
*/
|
|
361
|
-
const OPERATIONS_BRANCH = 'operations';
|
|
@@ -6,41 +6,41 @@ import { describe, test } from 'vitest';
|
|
|
6
6
|
|
|
7
7
|
import {
|
|
8
8
|
extractDxnsFromObject,
|
|
9
|
-
|
|
9
|
+
extractDxnFromString,
|
|
10
10
|
extractFirstDxnFromToolInput,
|
|
11
11
|
extractFirstDxnFromToolResult,
|
|
12
12
|
} from './dxn-extractor';
|
|
13
13
|
|
|
14
14
|
describe('dxn-extractor', () => {
|
|
15
|
-
describe('
|
|
15
|
+
describe('extractDxnFromString', () => {
|
|
16
16
|
test('extracts plain DXN from string', ({ expect }) => {
|
|
17
|
-
const result =
|
|
17
|
+
const result = extractDxnFromString('Found object dxn:echo:@:01KG7R1ZXWFMWQ4DA1Q6TN1DG4');
|
|
18
18
|
expect(result).toHaveLength(1);
|
|
19
19
|
expect(result[0].toString()).toBe('dxn:echo:@:01KG7R1ZXWFMWQ4DA1Q6TN1DG4');
|
|
20
20
|
});
|
|
21
21
|
|
|
22
22
|
test('extracts @dxn prefixed reference from string', ({ expect }) => {
|
|
23
|
-
const result =
|
|
23
|
+
const result = extractDxnFromString('Reference to @dxn:echo:@:01KG7R1ZXWFMWQ4DA1Q6TN1DG4 in text');
|
|
24
24
|
expect(result).toHaveLength(1);
|
|
25
25
|
expect(result[0].toString()).toBe('dxn:echo:@:01KG7R1ZXWFMWQ4DA1Q6TN1DG4');
|
|
26
26
|
});
|
|
27
27
|
|
|
28
28
|
test('extracts multiple DXNs from string', ({ expect }) => {
|
|
29
|
-
const result =
|
|
29
|
+
const result = extractDxnFromString(
|
|
30
30
|
'Objects: dxn:echo:@:01KG7R1ZXWFMWQ4DA1Q6TN1DG4 and @dxn:queue:data:SPACE:QUEUE:01KG7R1ZXWFMWQ4DA1Q6TN1DG5',
|
|
31
31
|
);
|
|
32
32
|
expect(result).toHaveLength(2);
|
|
33
33
|
});
|
|
34
34
|
|
|
35
35
|
test('deduplicates DXNs', ({ expect }) => {
|
|
36
|
-
const result =
|
|
36
|
+
const result = extractDxnFromString(
|
|
37
37
|
'Same object dxn:echo:@:01KG7R1ZXWFMWQ4DA1Q6TN1DG4 and dxn:echo:@:01KG7R1ZXWFMWQ4DA1Q6TN1DG4',
|
|
38
38
|
);
|
|
39
39
|
expect(result).toHaveLength(1);
|
|
40
40
|
});
|
|
41
41
|
|
|
42
42
|
test('returns empty array for string without DXNs', ({ expect }) => {
|
|
43
|
-
const result =
|
|
43
|
+
const result = extractDxnFromString('No DXNs here');
|
|
44
44
|
expect(result).toHaveLength(0);
|
|
45
45
|
});
|
|
46
46
|
});
|
|
@@ -28,7 +28,7 @@ const AT_DXN_PATTERN = /@(dxn:[a-zA-Z0-9]+(?::[a-zA-Z0-9@_-]+)+)/g;
|
|
|
28
28
|
/**
|
|
29
29
|
* Extracts all DXN references from a string.
|
|
30
30
|
*/
|
|
31
|
-
export const
|
|
31
|
+
export const extractDxnFromString = (text: string): DXN[] => {
|
|
32
32
|
const dxns: DXN[] = [];
|
|
33
33
|
const seen = new Set<string>();
|
|
34
34
|
|
|
@@ -91,7 +91,7 @@ export const extractDxnsFromObject = (obj: unknown): DXN[] => {
|
|
|
91
91
|
addDxn(value.slice(1));
|
|
92
92
|
}
|
|
93
93
|
// Also extract DXNs from within the string.
|
|
94
|
-
const extracted =
|
|
94
|
+
const extracted = extractDxnFromString(value);
|
|
95
95
|
for (const dxn of extracted) {
|
|
96
96
|
addDxn(dxn.toString());
|
|
97
97
|
}
|
|
@@ -153,7 +153,7 @@ export const extractFirstDxnFromToolInput = (input: string): DXN | undefined =>
|
|
|
153
153
|
return dxns[0];
|
|
154
154
|
} catch {
|
|
155
155
|
// If JSON parsing fails, try to extract from the raw string.
|
|
156
|
-
const dxns =
|
|
156
|
+
const dxns = extractDxnFromString(input);
|
|
157
157
|
return dxns[0];
|
|
158
158
|
}
|
|
159
159
|
};
|
|
@@ -172,7 +172,7 @@ export const extractFirstDxnFromToolResult = (result: string | undefined): DXN |
|
|
|
172
172
|
return dxns[0];
|
|
173
173
|
} catch {
|
|
174
174
|
// If JSON parsing fails, try to extract from the raw string.
|
|
175
|
-
const dxns =
|
|
175
|
+
const dxns = extractDxnFromString(result);
|
|
176
176
|
return dxns[0];
|
|
177
177
|
}
|
|
178
178
|
};
|