@dxos/plugin-assistant 0.8.4-main.9735255 → 0.8.4-main.9be5663bfe
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-7QMO3LGF.mjs +97 -0
- package/dist/lib/browser/AssistantSettings-7QMO3LGF.mjs.map +7 -0
- package/dist/lib/browser/blueprints/index.mjs +3 -7
- package/dist/lib/browser/chunk-ATHYBVGN.mjs +176 -0
- package/dist/lib/browser/chunk-ATHYBVGN.mjs.map +7 -0
- package/dist/lib/browser/chunk-EZRS3J25.mjs +30 -0
- package/dist/lib/browser/chunk-EZRS3J25.mjs.map +7 -0
- package/dist/lib/browser/chunk-RUV2WOQH.mjs +154 -0
- package/dist/lib/browser/chunk-RUV2WOQH.mjs.map +7 -0
- package/dist/lib/browser/create-chat-LBZHGVSN.mjs +82 -0
- package/dist/lib/browser/create-chat-LBZHGVSN.mjs.map +7 -0
- package/dist/lib/browser/ensure-companion-chat-FR4AWZ2P.mjs +65 -0
- package/dist/lib/browser/ensure-companion-chat-FR4AWZ2P.mjs.map +7 -0
- package/dist/lib/browser/index.mjs +3163 -245
- 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 +22 -0
- package/dist/lib/browser/on-create-space-54RNX5JI.mjs.map +7 -0
- package/dist/lib/browser/operations/index.mjs +13 -0
- package/dist/lib/browser/operations/index.mjs.map +7 -0
- package/dist/lib/browser/resolve-navigation-targets-NZOD66NY.mjs +22 -0
- package/dist/lib/browser/resolve-navigation-targets-NZOD66NY.mjs.map +7 -0
- package/dist/lib/browser/run-prompt-in-new-chat-4YQ37XIS.mjs +136 -0
- package/dist/lib/browser/run-prompt-in-new-chat-4YQ37XIS.mjs.map +7 -0
- package/dist/lib/browser/set-current-chat-WJI3WAVM.mjs +54 -0
- package/dist/lib/browser/set-current-chat-WJI3WAVM.mjs.map +7 -0
- package/dist/lib/browser/types/index.mjs +1 -4
- package/dist/lib/browser/update-chat-name-3Y36KFAS.mjs +71 -0
- package/dist/lib/browser/update-chat-name-3Y36KFAS.mjs.map +7 -0
- package/dist/lib/node-esm/AssistantSettings-UVUTKO7E.mjs +98 -0
- package/dist/lib/node-esm/AssistantSettings-UVUTKO7E.mjs.map +7 -0
- package/dist/lib/node-esm/blueprints/index.mjs +3 -7
- package/dist/lib/node-esm/chunk-NZIKC7AN.mjs +32 -0
- package/dist/lib/node-esm/chunk-NZIKC7AN.mjs.map +7 -0
- package/dist/lib/node-esm/chunk-PXAJSTGZ.mjs +177 -0
- package/dist/lib/node-esm/chunk-PXAJSTGZ.mjs.map +7 -0
- package/dist/lib/node-esm/chunk-PY4X6FJT.mjs +155 -0
- package/dist/lib/node-esm/chunk-PY4X6FJT.mjs.map +7 -0
- package/dist/lib/node-esm/create-chat-3BEG4R6J.mjs +83 -0
- package/dist/lib/node-esm/create-chat-3BEG4R6J.mjs.map +7 -0
- package/dist/lib/node-esm/ensure-companion-chat-BLP7NT32.mjs +66 -0
- package/dist/lib/node-esm/ensure-companion-chat-BLP7NT32.mjs.map +7 -0
- package/dist/lib/node-esm/index.mjs +3163 -245
- 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 +23 -0
- package/dist/lib/node-esm/on-create-space-YRPZ6HZY.mjs.map +7 -0
- package/dist/lib/node-esm/operations/index.mjs +14 -0
- package/dist/lib/node-esm/operations/index.mjs.map +7 -0
- package/dist/lib/node-esm/resolve-navigation-targets-3PPK7XLH.mjs +23 -0
- package/dist/lib/node-esm/resolve-navigation-targets-3PPK7XLH.mjs.map +7 -0
- package/dist/lib/node-esm/run-prompt-in-new-chat-2IJBSDTM.mjs +137 -0
- package/dist/lib/node-esm/run-prompt-in-new-chat-2IJBSDTM.mjs.map +7 -0
- package/dist/lib/node-esm/set-current-chat-KBMMZULR.mjs +55 -0
- package/dist/lib/node-esm/set-current-chat-KBMMZULR.mjs.map +7 -0
- package/dist/lib/node-esm/types/index.mjs +1 -4
- package/dist/lib/node-esm/update-chat-name-HM2P4NSI.mjs +72 -0
- package/dist/lib/node-esm/update-chat-name-HM2P4NSI.mjs.map +7 -0
- package/dist/types/src/AssistantPlugin.d.ts.map +1 -1
- package/dist/types/src/blueprints/assistant/blueprint.d.ts +4 -0
- package/dist/types/src/blueprints/assistant/blueprint.d.ts.map +1 -0
- package/dist/types/src/blueprints/assistant/blueprint.test.d.ts +2 -0
- package/dist/types/src/blueprints/assistant/blueprint.test.d.ts.map +1 -0
- package/dist/types/src/blueprints/assistant/index.d.ts +2 -0
- package/dist/types/src/blueprints/assistant/index.d.ts.map +1 -0
- package/dist/types/src/blueprints/index.d.ts +1 -6
- package/dist/types/src/blueprints/index.d.ts.map +1 -1
- 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 +6 -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/edge-model-resolver.d.ts +7 -0
- package/dist/types/src/capabilities/edge-model-resolver.d.ts.map +1 -0
- package/dist/types/src/capabilities/index.d.ts +41 -11
- package/dist/types/src/capabilities/index.d.ts.map +1 -1
- package/dist/types/src/capabilities/local-model-resolver.d.ts +13 -0
- package/dist/types/src/capabilities/local-model-resolver.d.ts.map +1 -0
- package/dist/types/src/capabilities/markdown.d.ts +5 -0
- package/dist/types/src/capabilities/markdown.d.ts.map +1 -0
- package/dist/types/src/capabilities/migrations.d.ts +5 -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 +5 -0
- package/dist/types/src/capabilities/react-surface.d.ts.map +1 -0
- package/dist/types/src/capabilities/{settings/settings.d.ts → settings.d.ts} +4 -3
- 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 +6 -0
- package/dist/types/src/capabilities/toolkit.d.ts.map +1 -0
- package/dist/types/src/components/AssistantSettings/AssistantSettings.d.ts +4 -6
- package/dist/types/src/components/AssistantSettings/AssistantSettings.d.ts.map +1 -1
- package/dist/types/src/components/AssistantSettings/AssistantSettings.stories.d.ts +553 -0
- package/dist/types/src/components/AssistantSettings/AssistantSettings.stories.d.ts.map +1 -0
- package/dist/types/src/components/AssistantSettings/index.d.ts +1 -1
- package/dist/types/src/components/AssistantSettings/index.d.ts.map +1 -1
- package/dist/types/src/components/Chat/Chat.d.ts +15 -11
- package/dist/types/src/components/Chat/Chat.d.ts.map +1 -1
- package/dist/types/src/components/ChatProgress/ChatProgress.d.ts +6 -3
- package/dist/types/src/components/ChatProgress/ChatProgress.d.ts.map +1 -1
- 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/ChatOptions.d.ts.map +1 -1
- package/dist/types/src/components/ChatPrompt/ChatReferences.d.ts.map +1 -1
- package/dist/types/src/components/ChatThread/ChatThread.d.ts +3 -3
- package/dist/types/src/components/ChatThread/ChatThread.d.ts.map +1 -1
- package/dist/types/src/components/ChatThread/ChatThread.stories.d.ts +535 -303
- package/dist/types/src/components/ChatThread/ChatThread.stories.d.ts.map +1 -1
- package/dist/types/src/components/ChatThread/MarkdownStream.stories.d.ts +573 -0
- package/dist/types/src/components/ChatThread/MarkdownStream.stories.d.ts.map +1 -0
- package/dist/types/src/components/ChatThread/registry.d.ts.map +1 -1
- package/dist/types/src/components/ChatThread/sync.d.ts +6 -5
- 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/PromptWidget.d.ts +14 -0
- package/dist/types/src/components/ChatThread/widgets/PromptWidget.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 +25 -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 +553 -0
- package/dist/types/src/components/ChatThread/widgets/ToolWidget.stories.d.ts.map +1 -0
- package/dist/types/src/components/ChatThread/widgets/index.d.ts +11 -0
- package/dist/types/src/components/ChatThread/widgets/index.d.ts.map +1 -0
- package/dist/types/src/components/ProcessTree/ProcessTree.d.ts +10 -0
- package/dist/types/src/components/ProcessTree/ProcessTree.d.ts.map +1 -0
- package/dist/types/src/components/ProcessTree/ProcessTree.stories.d.ts +8 -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/TemplateEditor/TemplateEditor.d.ts +5 -4
- package/dist/types/src/components/TemplateEditor/TemplateEditor.d.ts.map +1 -1
- package/dist/types/src/components/TemplateEditor/TemplateEditor.stories.d.ts +529 -295
- package/dist/types/src/components/TemplateEditor/TemplateEditor.stories.d.ts.map +1 -1
- package/dist/types/src/components/TemplateEditor/TemplateForm.d.ts.map +1 -1
- package/dist/types/src/components/TemplateEditor/TemplateForm.stories.d.ts +529 -295
- package/dist/types/src/components/TemplateEditor/TemplateForm.stories.d.ts.map +1 -1
- package/dist/types/src/components/ToolBlock/ToolBlock.d.ts +0 -9
- package/dist/types/src/components/ToolBlock/ToolBlock.d.ts.map +1 -1
- package/dist/types/src/components/Toolbox/Toolbox.d.ts +10 -8
- package/dist/types/src/components/Toolbox/Toolbox.d.ts.map +1 -1
- package/dist/types/src/components/Toolbox/Toolbox.stories.d.ts +529 -295
- package/dist/types/src/components/Toolbox/Toolbox.stories.d.ts.map +1 -1
- package/dist/types/src/components/Typewriter/AssistantToolbar.d.ts +2 -2
- package/dist/types/src/components/Typewriter/AssistantToolbar.d.ts.map +1 -1
- package/dist/types/src/components/Typewriter/Typewriter.d.ts.map +1 -1
- package/dist/types/src/components/Typewriter/Typewriter.stories.d.ts.map +1 -1
- package/dist/types/src/components/index.d.ts +3 -12
- 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 +554 -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/AgentProperties.stories.d.ts +554 -0
- package/dist/types/src/containers/AgentProperties/AgentProperties.stories.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 +6 -0
- package/dist/types/src/containers/BlueprintArticle/BlueprintArticle.d.ts.map +1 -0
- package/dist/types/src/containers/BlueprintArticle/index.d.ts +2 -0
- package/dist/types/src/containers/BlueprintArticle/index.d.ts.map +1 -0
- package/dist/types/src/containers/ChatCompanion/ChatCompanion.d.ts +18 -0
- package/dist/types/src/containers/ChatCompanion/ChatCompanion.d.ts.map +1 -0
- package/dist/types/src/containers/ChatCompanion/index.d.ts +2 -0
- package/dist/types/src/containers/ChatCompanion/index.d.ts.map +1 -0
- package/dist/types/src/containers/ChatContainer/ChatContainer.d.ts +12 -0
- package/dist/types/src/containers/ChatContainer/ChatContainer.d.ts.map +1 -0
- package/dist/types/src/containers/ChatContainer/index.d.ts +2 -0
- package/dist/types/src/containers/ChatContainer/index.d.ts.map +1 -0
- package/dist/types/src/{components → containers/ChatDialog}/ChatDialog.d.ts +2 -3
- package/dist/types/src/containers/ChatDialog/ChatDialog.d.ts.map +1 -0
- package/dist/types/src/containers/ChatDialog/index.d.ts +2 -0
- package/dist/types/src/containers/ChatDialog/index.d.ts.map +1 -0
- package/dist/types/src/containers/PromptArticle/PromptArticle.d.ts +6 -0
- package/dist/types/src/containers/PromptArticle/PromptArticle.d.ts.map +1 -0
- package/dist/types/src/containers/PromptArticle/index.d.ts +2 -0
- package/dist/types/src/containers/PromptArticle/index.d.ts.map +1 -0
- package/dist/types/src/containers/PromptList/PromptList.d.ts +6 -0
- package/dist/types/src/containers/PromptList/PromptList.d.ts.map +1 -0
- package/dist/types/src/containers/PromptList/PromptList.stories.d.ts +559 -0
- package/dist/types/src/containers/PromptList/PromptList.stories.d.ts.map +1 -0
- package/dist/types/src/containers/PromptList/index.d.ts +2 -0
- package/dist/types/src/containers/PromptList/index.d.ts.map +1 -0
- package/dist/types/src/containers/TracePanel/TracePanel.d.ts +6 -0
- package/dist/types/src/containers/TracePanel/TracePanel.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/TriggerStatus/TriggerStatus.d.ts +4 -0
- package/dist/types/src/containers/TriggerStatus/TriggerStatus.d.ts.map +1 -0
- package/dist/types/src/containers/TriggerStatus/index.d.ts +2 -0
- package/dist/types/src/containers/TriggerStatus/index.d.ts.map +1 -0
- package/dist/types/src/containers/index.d.ts +12 -0
- package/dist/types/src/containers/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/hooks/useBlueprintRegistry.d.ts.map +1 -1
- package/dist/types/src/hooks/useChatProcessor.d.ts +7 -6
- package/dist/types/src/hooks/useChatProcessor.d.ts.map +1 -1
- package/dist/types/src/hooks/useChatServices.d.ts +3 -6
- package/dist/types/src/hooks/useChatServices.d.ts.map +1 -1
- package/dist/types/src/hooks/useChatToolbarActions.d.ts +2 -2
- package/dist/types/src/hooks/useChatToolbarActions.d.ts.map +1 -1
- package/dist/types/src/hooks/useContextBinder.d.ts +3 -2
- 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/useFilteredTypes.d.ts +1 -1
- package/dist/types/src/hooks/useFilteredTypes.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 +1 -1
- package/dist/types/src/index.d.ts.map +1 -1
- package/dist/types/src/meta.d.ts +2 -0
- 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/definitions.d.ts +135 -0
- package/dist/types/src/operations/definitions.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 +4 -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/resolve-navigation-targets.d.ts +15 -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/update-chat-name.d.ts +5 -0
- package/dist/types/src/operations/update-chat-name.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/processor.d.ts +33 -28
- package/dist/types/src/processor/processor.d.ts.map +1 -1
- package/dist/types/src/testing/test-generator.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/translations.d.ts +529 -295
- package/dist/types/src/translations.d.ts.map +1 -1
- package/dist/types/src/types/Assistant.d.ts +17 -39
- package/dist/types/src/types/Assistant.d.ts.map +1 -1
- package/dist/types/src/types/Settings.d.ts +10 -0
- package/dist/types/src/types/Settings.d.ts.map +1 -0
- package/dist/types/src/types/capabilities.d.ts +11 -0
- package/dist/types/src/types/capabilities.d.ts.map +1 -1
- package/dist/types/src/types/index.d.ts +1 -1
- package/dist/types/src/types/index.d.ts.map +1 -1
- package/dist/types/src/types/service.d.ts.map +1 -1
- package/dist/types/tsconfig.tsbuildinfo +1 -1
- package/package.json +120 -92
- package/src/AssistantPlugin.tsx +148 -52
- package/src/blueprints/assistant/blueprint.conversations.json +1 -0
- package/src/blueprints/assistant/blueprint.test.ts +46 -0
- package/src/blueprints/assistant/blueprint.ts +31 -0
- package/src/blueprints/assistant/index.ts +5 -0
- package/src/blueprints/index.ts +1 -8
- package/src/capabilities/{ai-service/ai-service.ts → ai-service.ts} +4 -3
- package/src/capabilities/app-graph-builder.ts +217 -0
- package/src/capabilities/blueprint-definition.ts +58 -0
- package/src/capabilities/companion-chat-provisioner.ts +164 -0
- package/src/capabilities/{edge-model-resolver/edge-model-resolver.ts → edge-model-resolver.ts} +4 -3
- package/src/capabilities/index.ts +22 -11
- package/src/capabilities/{local-model-resolver/local-model-resolver.ts → local-model-resolver.ts} +4 -3
- package/src/capabilities/markdown.ts +40 -0
- package/src/capabilities/migrations.ts +34 -0
- package/src/capabilities/operation-handler.ts +16 -0
- package/src/capabilities/react-surface.tsx +157 -0
- package/src/capabilities/{settings/settings.ts → settings.ts} +5 -4
- package/src/capabilities/{state/state.ts → state.ts} +11 -3
- package/src/capabilities/toolkit.ts +13 -0
- package/src/components/AssistantSettings/AssistantSettings.stories.tsx +34 -0
- package/src/components/AssistantSettings/AssistantSettings.tsx +104 -92
- package/src/components/AssistantSettings/index.ts +2 -2
- package/src/components/Chat/Chat.tsx +88 -45
- package/src/components/ChatProgress/ChatProgress.tsx +9 -7
- package/src/components/ChatPrompt/ChatActions.tsx +25 -5
- package/src/components/ChatPrompt/ChatOptions.tsx +43 -29
- package/src/components/ChatPrompt/ChatReferences.tsx +18 -8
- package/src/components/ChatThread/ChatThread.stories.tsx +31 -48
- package/src/components/ChatThread/ChatThread.tsx +28 -17
- package/src/components/ChatThread/Link.tsx +1 -1
- package/src/components/ChatThread/MarkdownStream.stories.tsx +243 -0
- package/src/components/ChatThread/registry.tsx +107 -43
- package/src/components/ChatThread/sync.test.ts +12 -10
- package/src/components/ChatThread/sync.ts +43 -32
- 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/PromptWidget.ts +28 -0
- package/src/components/ChatThread/widgets/ReasoningWidget.stories.tsx +68 -0
- package/src/components/ChatThread/widgets/ReasoningWidget.ts +133 -0
- package/src/components/ChatThread/widgets/ReferenceWidget.ts +31 -0
- package/src/components/ChatThread/widgets/SelectWidget.ts +37 -0
- package/src/components/ChatThread/widgets/StatsWidget.ts +29 -0
- package/src/components/ChatThread/widgets/StatusWidget.ts +133 -0
- package/src/components/ChatThread/widgets/SuggestionWidget.ts +41 -0
- package/src/components/ChatThread/widgets/SummaryWidget.tsx +28 -0
- package/src/components/ChatThread/widgets/ToolWidget.stories.tsx +54 -0
- package/src/components/ChatThread/widgets/ToolWidget.tsx +156 -0
- package/src/components/ChatThread/widgets/index.ts +14 -0
- package/src/components/ProcessTree/ProcessTree.stories.tsx +109 -0
- package/src/components/ProcessTree/ProcessTree.tsx +85 -0
- package/src/components/ProcessTree/index.ts +5 -0
- package/src/components/TemplateEditor/TemplateEditor.stories.tsx +4 -9
- package/src/components/TemplateEditor/TemplateEditor.tsx +50 -42
- package/src/components/TemplateEditor/TemplateForm.stories.tsx +7 -6
- package/src/components/TemplateEditor/TemplateForm.tsx +9 -10
- package/src/components/TemplateEditor/extensions/handlebars-extension.ts +4 -4
- package/src/components/ToolBlock/ToolBlock.tsx +21 -20
- package/src/components/Toolbox/Toolbox.stories.tsx +4 -6
- package/src/components/Toolbox/Toolbox.tsx +66 -60
- package/src/components/Typewriter/AssistantToolbar.tsx +7 -7
- package/src/components/Typewriter/Typewriter.stories.tsx +18 -15
- package/src/components/Typewriter/Typewriter.tsx +6 -10
- package/src/components/Typewriter/assistant-extension.tsx +5 -8
- package/src/components/index.ts +3 -7
- package/src/containers/AgentArticle/AgentArticle.stories.tsx +105 -0
- package/src/containers/AgentArticle/AgentArticle.tsx +157 -0
- package/src/containers/AgentArticle/index.ts +5 -0
- package/src/containers/AgentProperties/AgentProperties.stories.tsx +91 -0
- package/src/containers/AgentProperties/AgentProperties.tsx +169 -0
- package/src/containers/AgentProperties/index.ts +5 -0
- package/src/containers/BlueprintArticle/BlueprintArticle.tsx +29 -0
- package/src/containers/BlueprintArticle/index.ts +5 -0
- package/src/{components → containers/ChatCompanion}/ChatCompanion.tsx +23 -44
- package/src/containers/ChatCompanion/index.ts +5 -0
- package/src/containers/ChatContainer/ChatContainer.tsx +95 -0
- package/src/containers/ChatContainer/index.ts +5 -0
- package/src/{components → containers/ChatDialog}/ChatDialog.tsx +10 -12
- package/src/containers/ChatDialog/index.ts +5 -0
- package/src/containers/PromptArticle/PromptArticle.tsx +59 -0
- package/src/containers/PromptArticle/index.ts +5 -0
- package/src/containers/PromptList/PromptList.stories.tsx +129 -0
- package/src/containers/PromptList/PromptList.tsx +49 -0
- package/src/containers/PromptList/index.ts +5 -0
- package/src/containers/TracePanel/TracePanel.tsx +361 -0
- package/src/containers/TracePanel/dxn-extractor.test.ts +153 -0
- package/src/containers/TracePanel/dxn-extractor.ts +178 -0
- package/src/containers/TracePanel/index.ts +9 -0
- package/src/containers/TriggerStatus/TriggerStatus.tsx +144 -0
- package/src/containers/TriggerStatus/index.ts +5 -0
- package/src/containers/index.ts +16 -0
- package/src/extensions/index.ts +5 -0
- package/src/extensions/prompt-extension.ts +111 -0
- package/src/hooks/useBlueprintRegistry.ts +8 -4
- package/src/hooks/useChatProcessor.ts +30 -17
- package/src/hooks/useChatServices.ts +7 -28
- package/src/hooks/useChatToolbarActions.ts +13 -12
- package/src/hooks/useContextBinder.ts +17 -6
- package/src/hooks/useContextObjects.ts +8 -4
- package/src/hooks/useFilteredTypes.ts +3 -3
- package/src/hooks/usePresets.ts +2 -1
- package/src/hooks/useReferencesProvider.ts +1 -5
- package/src/index.ts +1 -1
- package/src/meta.ts +6 -3
- package/src/operations/create-chat.ts +80 -0
- package/src/operations/definitions.ts +127 -0
- package/src/operations/ensure-companion-chat.ts +61 -0
- package/src/operations/index.ts +17 -0
- package/src/operations/on-create-space.ts +24 -0
- package/src/operations/resolve-navigation-targets.ts +26 -0
- package/src/operations/run-prompt-in-new-chat.ts +113 -0
- package/src/operations/set-current-chat.ts +50 -0
- package/src/operations/update-chat-name.ts +61 -0
- package/src/processor/index.ts +0 -1
- package/src/processor/presets.ts +2 -2
- package/src/processor/processor.test.ts +18 -50
- package/src/processor/processor.ts +190 -129
- package/src/queue-logger.ts +2 -2
- package/src/testing/test-generator.ts +45 -14
- package/src/testing/test-sequence.ts +3 -3
- package/src/testing/test-services.ts +2 -2
- package/src/translations.ts +134 -83
- package/src/types/Assistant.ts +8 -56
- package/src/types/Settings.ts +21 -0
- package/src/types/capabilities.ts +11 -3
- package/src/types/events.ts +2 -2
- package/src/types/index.ts +3 -1
- package/src/types/service.ts +5 -5
- package/dist/lib/browser/BlueprintArticle-WP3G5GLG.mjs +0 -31
- package/dist/lib/browser/BlueprintArticle-WP3G5GLG.mjs.map +0 -7
- package/dist/lib/browser/ChatCompanion-ECQYUQ2B.mjs +0 -153
- package/dist/lib/browser/ChatCompanion-ECQYUQ2B.mjs.map +0 -7
- package/dist/lib/browser/ChatContainer-QCCOFBUX.mjs +0 -73
- package/dist/lib/browser/ChatContainer-QCCOFBUX.mjs.map +0 -7
- package/dist/lib/browser/ChatDialog-SMK4RSZU.mjs +0 -85
- package/dist/lib/browser/ChatDialog-SMK4RSZU.mjs.map +0 -7
- package/dist/lib/browser/PromptArticle-K362ZPAE.mjs +0 -53
- package/dist/lib/browser/PromptArticle-K362ZPAE.mjs.map +0 -7
- package/dist/lib/browser/ai-service-5GUDOEWF.mjs +0 -21
- package/dist/lib/browser/ai-service-5GUDOEWF.mjs.map +0 -7
- package/dist/lib/browser/app-graph-builder-DSNH2OMY.mjs +0 -212
- package/dist/lib/browser/app-graph-builder-DSNH2OMY.mjs.map +0 -7
- package/dist/lib/browser/blueprint-definition-DGHH7MUU.mjs +0 -14
- package/dist/lib/browser/blueprint-definition-DGHH7MUU.mjs.map +0 -7
- package/dist/lib/browser/chunk-3JYPE2MM.mjs +0 -1832
- package/dist/lib/browser/chunk-3JYPE2MM.mjs.map +0 -7
- package/dist/lib/browser/chunk-DKQMSMBN.mjs +0 -326
- package/dist/lib/browser/chunk-DKQMSMBN.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-ML3QCFKA.mjs +0 -265
- package/dist/lib/browser/chunk-ML3QCFKA.mjs.map +0 -7
- package/dist/lib/browser/chunk-MRJVYGLU.mjs +0 -208
- package/dist/lib/browser/chunk-MRJVYGLU.mjs.map +0 -7
- package/dist/lib/browser/chunk-V772AMZM.mjs +0 -250
- package/dist/lib/browser/chunk-V772AMZM.mjs.map +0 -7
- package/dist/lib/browser/chunk-WGQTU6UJ.mjs +0 -41
- package/dist/lib/browser/chunk-WGQTU6UJ.mjs.map +0 -7
- package/dist/lib/browser/edge-model-resolver-26BOY6HY.mjs +0 -20
- package/dist/lib/browser/edge-model-resolver-26BOY6HY.mjs.map +0 -7
- package/dist/lib/browser/local-model-resolver-ZFIM6GGV.mjs +0 -19
- package/dist/lib/browser/local-model-resolver-ZFIM6GGV.mjs.map +0 -7
- package/dist/lib/browser/operation-resolver-7XJLBRQY.mjs +0 -132
- package/dist/lib/browser/operation-resolver-7XJLBRQY.mjs.map +0 -7
- package/dist/lib/browser/react-surface-NCITRSJJ.mjs +0 -109
- package/dist/lib/browser/react-surface-NCITRSJJ.mjs.map +0 -7
- package/dist/lib/browser/repair-6QGAKOVM.mjs +0 -54
- package/dist/lib/browser/repair-6QGAKOVM.mjs.map +0 -7
- package/dist/lib/browser/settings-4ZDLUMYE.mjs +0 -32
- package/dist/lib/browser/settings-4ZDLUMYE.mjs.map +0 -7
- package/dist/lib/browser/state-AN6336ZX.mjs +0 -26
- package/dist/lib/browser/state-AN6336ZX.mjs.map +0 -7
- package/dist/lib/browser/toolkit-7AVTEPMA.mjs +0 -18
- package/dist/lib/browser/toolkit-7AVTEPMA.mjs.map +0 -7
- package/dist/lib/node-esm/BlueprintArticle-WZ76E2C4.mjs +0 -32
- package/dist/lib/node-esm/BlueprintArticle-WZ76E2C4.mjs.map +0 -7
- package/dist/lib/node-esm/ChatCompanion-Q4FUZ2MW.mjs +0 -154
- package/dist/lib/node-esm/ChatCompanion-Q4FUZ2MW.mjs.map +0 -7
- package/dist/lib/node-esm/ChatContainer-AKI33HIB.mjs +0 -74
- package/dist/lib/node-esm/ChatContainer-AKI33HIB.mjs.map +0 -7
- package/dist/lib/node-esm/ChatDialog-AP45PVZR.mjs +0 -86
- package/dist/lib/node-esm/ChatDialog-AP45PVZR.mjs.map +0 -7
- package/dist/lib/node-esm/PromptArticle-D4HAIIC6.mjs +0 -54
- package/dist/lib/node-esm/PromptArticle-D4HAIIC6.mjs.map +0 -7
- package/dist/lib/node-esm/ai-service-PXKKCFIF.mjs +0 -22
- package/dist/lib/node-esm/ai-service-PXKKCFIF.mjs.map +0 -7
- package/dist/lib/node-esm/app-graph-builder-TJCUEXW5.mjs +0 -213
- package/dist/lib/node-esm/app-graph-builder-TJCUEXW5.mjs.map +0 -7
- package/dist/lib/node-esm/blueprint-definition-SEMDEIYG.mjs +0 -15
- package/dist/lib/node-esm/blueprint-definition-SEMDEIYG.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-355W5B27.mjs +0 -251
- package/dist/lib/node-esm/chunk-355W5B27.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-75PHXBN3.mjs +0 -327
- package/dist/lib/node-esm/chunk-75PHXBN3.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-DCA5QWQT.mjs +0 -209
- package/dist/lib/node-esm/chunk-DCA5QWQT.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-MSBPC4RJ.mjs +0 -42
- package/dist/lib/node-esm/chunk-MSBPC4RJ.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/chunk-XI5T3MJC.mjs +0 -1833
- package/dist/lib/node-esm/chunk-XI5T3MJC.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-ZRIPP7YF.mjs +0 -267
- package/dist/lib/node-esm/chunk-ZRIPP7YF.mjs.map +0 -7
- package/dist/lib/node-esm/edge-model-resolver-G5KMODPO.mjs +0 -21
- package/dist/lib/node-esm/edge-model-resolver-G5KMODPO.mjs.map +0 -7
- package/dist/lib/node-esm/local-model-resolver-KDZLYI7Y.mjs +0 -20
- package/dist/lib/node-esm/local-model-resolver-KDZLYI7Y.mjs.map +0 -7
- package/dist/lib/node-esm/operation-resolver-SX4WMNA7.mjs +0 -133
- package/dist/lib/node-esm/operation-resolver-SX4WMNA7.mjs.map +0 -7
- package/dist/lib/node-esm/react-surface-ST6V7LPE.mjs +0 -110
- package/dist/lib/node-esm/react-surface-ST6V7LPE.mjs.map +0 -7
- package/dist/lib/node-esm/repair-QJ7CQDKU.mjs +0 -55
- package/dist/lib/node-esm/repair-QJ7CQDKU.mjs.map +0 -7
- package/dist/lib/node-esm/settings-CQEOHR3R.mjs +0 -33
- package/dist/lib/node-esm/settings-CQEOHR3R.mjs.map +0 -7
- package/dist/lib/node-esm/state-HDON4REW.mjs +0 -27
- package/dist/lib/node-esm/state-HDON4REW.mjs.map +0 -7
- package/dist/lib/node-esm/toolkit-OWGCEKOO.mjs +0 -19
- package/dist/lib/node-esm/toolkit-OWGCEKOO.mjs.map +0 -7
- package/dist/types/src/blueprints/assistant-blueprint.d.ts +0 -209
- package/dist/types/src/blueprints/assistant-blueprint.d.ts.map +0 -1
- package/dist/types/src/capabilities/ai-service/ai-service.d.ts +0 -5
- 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 +0 -6
- 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 -21
- 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 -4
- 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 +0 -6
- 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 -12
- 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 +0 -5
- 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 +0 -6
- 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.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 +0 -5
- package/dist/types/src/capabilities/toolkit/toolkit.d.ts.map +0 -1
- package/dist/types/src/components/BlueprintArticle.d.ts +0 -7
- package/dist/types/src/components/BlueprintArticle.d.ts.map +0 -1
- package/dist/types/src/components/ChatCompanion.d.ts +0 -13
- package/dist/types/src/components/ChatCompanion.d.ts.map +0 -1
- package/dist/types/src/components/ChatContainer.d.ts +0 -19
- package/dist/types/src/components/ChatContainer.d.ts.map +0 -1
- package/dist/types/src/components/ChatDialog.d.ts.map +0 -1
- package/dist/types/src/components/PromptArticle.d.ts +0 -7
- package/dist/types/src/components/PromptArticle.d.ts.map +0 -1
- package/dist/types/src/functions/index.d.ts +0 -4
- package/dist/types/src/functions/index.d.ts.map +0 -1
- package/dist/types/src/functions/object-list.d.ts +0 -10
- package/dist/types/src/functions/object-list.d.ts.map +0 -1
- package/dist/types/src/functions/object-load.d.ts +0 -8
- package/dist/types/src/functions/object-load.d.ts.map +0 -1
- package/dist/types/src/functions/object-search.d.ts +0 -10
- package/dist/types/src/functions/object-search.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/types/AssistantAction.d.ts +0 -95
- package/dist/types/src/types/AssistantAction.d.ts.map +0 -1
- package/src/blueprints/assistant-blueprint.ts +0 -62
- package/src/capabilities/ai-service/index.ts +0 -7
- package/src/capabilities/app-graph-builder/app-graph-builder.ts +0 -180
- package/src/capabilities/app-graph-builder/index.ts +0 -7
- package/src/capabilities/blueprint-definition/blueprint-definition.ts +0 -60
- package/src/capabilities/blueprint-definition/index.ts +0 -8
- 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 -110
- package/src/capabilities/react-surface/index.ts +0 -7
- package/src/capabilities/react-surface/react-surface.tsx +0 -95
- package/src/capabilities/repair/index.ts +0 -7
- package/src/capabilities/repair/repair.ts +0 -63
- 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/capabilities/toolkit/toolkit.ts +0 -26
- package/src/components/BlueprintArticle.tsx +0 -29
- package/src/components/ChatContainer.tsx +0 -61
- package/src/components/PromptArticle.tsx +0 -50
- package/src/functions/index.ts +0 -7
- package/src/functions/object-list.ts +0 -49
- package/src/functions/object-load.ts +0 -47
- package/src/functions/object-search.ts +0 -46
- package/src/processor/update-name.ts +0 -59
- package/src/types/AssistantAction.ts +0 -75
|
@@ -0,0 +1,361 @@
|
|
|
1
|
+
//
|
|
2
|
+
// Copyright 2025 DXOS.org
|
|
3
|
+
//
|
|
4
|
+
|
|
5
|
+
import { Atom } from '@effect-atom/atom';
|
|
6
|
+
import { useAtomValue } from '@effect-atom/atom-react';
|
|
7
|
+
import { pipe } from 'effect/Function';
|
|
8
|
+
import React, { useCallback, useMemo } from 'react';
|
|
9
|
+
|
|
10
|
+
import { useOperationInvoker } from '@dxos/app-framework/ui';
|
|
11
|
+
import { LayoutOperation } from '@dxos/app-toolkit';
|
|
12
|
+
import { AGENT_PROCESS_KEY, CompleteBlock } from '@dxos/assistant';
|
|
13
|
+
import { Filter, Query } from '@dxos/echo';
|
|
14
|
+
import { AtomQuery } from '@dxos/echo-atom';
|
|
15
|
+
import { Trace } from '@dxos/functions';
|
|
16
|
+
import { FeedTraceSink, Process } from '@dxos/functions-runtime';
|
|
17
|
+
import { DXN, SpaceId } from '@dxos/keys';
|
|
18
|
+
import { LogLevel } from '@dxos/log';
|
|
19
|
+
import { useComputeRuntimeService } from '@dxos/plugin-automation/hooks';
|
|
20
|
+
import { type Space } from '@dxos/react-client/echo';
|
|
21
|
+
import { Panel } from '@dxos/react-ui';
|
|
22
|
+
import { Timeline, type Commit } from '@dxos/react-ui-components';
|
|
23
|
+
import { mx } from '@dxos/ui-theme';
|
|
24
|
+
|
|
25
|
+
import { ProcessTree } from '../../components';
|
|
26
|
+
|
|
27
|
+
export const TracePanel = ({ space }: { space: Space }) => {
|
|
28
|
+
const { invokePromise } = useOperationInvoker();
|
|
29
|
+
const activeProcesses = useActiveProcesses(space.id);
|
|
30
|
+
const runtime = useComputeRuntimeService(Process.ProcessMonitorService, space.id);
|
|
31
|
+
|
|
32
|
+
const { branches, commits } = useAtomValue(
|
|
33
|
+
useMemo(
|
|
34
|
+
() => getExecutionGraph(space, runtime?.processTreeAtom ?? Atom.make(() => [])),
|
|
35
|
+
[space, runtime?.processTreeAtom],
|
|
36
|
+
),
|
|
37
|
+
);
|
|
38
|
+
|
|
39
|
+
const handleCommitClick = useCallback(
|
|
40
|
+
(commit: Commit) => {
|
|
41
|
+
if (commit.link) {
|
|
42
|
+
const dxn = DXN.tryParse(commit.link)?.asEchoDXN();
|
|
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
|
+
);
|
|
51
|
+
|
|
52
|
+
return (
|
|
53
|
+
<Panel.Root>
|
|
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
|
+
);
|
|
63
|
+
};
|
|
64
|
+
|
|
65
|
+
type InvocationInfo = {
|
|
66
|
+
eventLimit: number;
|
|
67
|
+
};
|
|
68
|
+
|
|
69
|
+
const getExecutionGraph = (
|
|
70
|
+
space: Space,
|
|
71
|
+
processTreeAtom: Atom.Atom<readonly Process.Info[]>,
|
|
72
|
+
{ eventLimit = 100 }: { eventLimit?: number } = {},
|
|
73
|
+
): Atom.Atom<{
|
|
74
|
+
branches: string[];
|
|
75
|
+
commits: Commit[];
|
|
76
|
+
}> => {
|
|
77
|
+
return pipe(
|
|
78
|
+
AtomQuery.make(space.db, FeedTraceSink.query),
|
|
79
|
+
Atom.map((feeds) => {
|
|
80
|
+
// TODO(dmaretskyi): This should be possible in a single query with properly working limit(1) and feed > feed contents traversal.
|
|
81
|
+
return AtomQuery.make(
|
|
82
|
+
space.db,
|
|
83
|
+
feeds.length > 0
|
|
84
|
+
? Query.type(Trace.Message).from(feeds[0])
|
|
85
|
+
: (Query.select(Filter.nothing()) as Query.Query<never>),
|
|
86
|
+
);
|
|
87
|
+
}),
|
|
88
|
+
(_) => Atom.make((get) => get(get(_))),
|
|
89
|
+
(_) =>
|
|
90
|
+
Atom.make((get) => {
|
|
91
|
+
const builder = new GraphBuilder();
|
|
92
|
+
|
|
93
|
+
const events = get(_)
|
|
94
|
+
.slice(-eventLimit)
|
|
95
|
+
.flatMap((message) =>
|
|
96
|
+
message.events.map((event: Trace.Event) => ({
|
|
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
|
+
}),
|
|
201
|
+
);
|
|
202
|
+
};
|
|
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';
|
|
@@ -0,0 +1,153 @@
|
|
|
1
|
+
//
|
|
2
|
+
// Copyright 2025 DXOS.org
|
|
3
|
+
//
|
|
4
|
+
|
|
5
|
+
import { describe, test } from 'vitest';
|
|
6
|
+
|
|
7
|
+
import {
|
|
8
|
+
extractDxnsFromObject,
|
|
9
|
+
extractDxnsFromString,
|
|
10
|
+
extractFirstDxnFromToolInput,
|
|
11
|
+
extractFirstDxnFromToolResult,
|
|
12
|
+
} from './dxn-extractor';
|
|
13
|
+
|
|
14
|
+
describe('dxn-extractor', () => {
|
|
15
|
+
describe('extractDxnsFromString', () => {
|
|
16
|
+
test('extracts plain DXN from string', ({ expect }) => {
|
|
17
|
+
const result = extractDxnsFromString('Found object dxn:echo:@:01KG7R1ZXWFMWQ4DA1Q6TN1DG4');
|
|
18
|
+
expect(result).toHaveLength(1);
|
|
19
|
+
expect(result[0].toString()).toBe('dxn:echo:@:01KG7R1ZXWFMWQ4DA1Q6TN1DG4');
|
|
20
|
+
});
|
|
21
|
+
|
|
22
|
+
test('extracts @dxn prefixed reference from string', ({ expect }) => {
|
|
23
|
+
const result = extractDxnsFromString('Reference to @dxn:echo:@:01KG7R1ZXWFMWQ4DA1Q6TN1DG4 in text');
|
|
24
|
+
expect(result).toHaveLength(1);
|
|
25
|
+
expect(result[0].toString()).toBe('dxn:echo:@:01KG7R1ZXWFMWQ4DA1Q6TN1DG4');
|
|
26
|
+
});
|
|
27
|
+
|
|
28
|
+
test('extracts multiple DXNs from string', ({ expect }) => {
|
|
29
|
+
const result = extractDxnsFromString(
|
|
30
|
+
'Objects: dxn:echo:@:01KG7R1ZXWFMWQ4DA1Q6TN1DG4 and @dxn:queue:data:SPACE:QUEUE:01KG7R1ZXWFMWQ4DA1Q6TN1DG5',
|
|
31
|
+
);
|
|
32
|
+
expect(result).toHaveLength(2);
|
|
33
|
+
});
|
|
34
|
+
|
|
35
|
+
test('deduplicates DXNs', ({ expect }) => {
|
|
36
|
+
const result = extractDxnsFromString(
|
|
37
|
+
'Same object dxn:echo:@:01KG7R1ZXWFMWQ4DA1Q6TN1DG4 and dxn:echo:@:01KG7R1ZXWFMWQ4DA1Q6TN1DG4',
|
|
38
|
+
);
|
|
39
|
+
expect(result).toHaveLength(1);
|
|
40
|
+
});
|
|
41
|
+
|
|
42
|
+
test('returns empty array for string without DXNs', ({ expect }) => {
|
|
43
|
+
const result = extractDxnsFromString('No DXNs here');
|
|
44
|
+
expect(result).toHaveLength(0);
|
|
45
|
+
});
|
|
46
|
+
});
|
|
47
|
+
|
|
48
|
+
describe('extractDxnsFromObject', () => {
|
|
49
|
+
test('extracts IPLD-style reference { "/": "dxn:..." }', ({ expect }) => {
|
|
50
|
+
const result = extractDxnsFromObject({
|
|
51
|
+
'/': 'dxn:echo:@:01KG7R1ZXWFMWQ4DA1Q6TN1DG4',
|
|
52
|
+
});
|
|
53
|
+
expect(result).toHaveLength(1);
|
|
54
|
+
expect(result[0].toString()).toBe('dxn:echo:@:01KG7R1ZXWFMWQ4DA1Q6TN1DG4');
|
|
55
|
+
});
|
|
56
|
+
|
|
57
|
+
test('extracts @dxn key reference { "@dxn": "dxn:..." }', ({ expect }) => {
|
|
58
|
+
const result = extractDxnsFromObject({
|
|
59
|
+
'@dxn': 'dxn:echo:@:01KG7R1ZXWFMWQ4DA1Q6TN1DG4',
|
|
60
|
+
name: 'Test',
|
|
61
|
+
});
|
|
62
|
+
expect(result).toHaveLength(1);
|
|
63
|
+
expect(result[0].toString()).toBe('dxn:echo:@:01KG7R1ZXWFMWQ4DA1Q6TN1DG4');
|
|
64
|
+
});
|
|
65
|
+
|
|
66
|
+
test('extracts reference block { _tag: "reference", reference: { dxn: ... } }', ({ expect }) => {
|
|
67
|
+
const result = extractDxnsFromObject({
|
|
68
|
+
_tag: 'reference',
|
|
69
|
+
reference: {
|
|
70
|
+
dxn: 'dxn:echo:@:01KG7R1ZXWFMWQ4DA1Q6TN1DG4',
|
|
71
|
+
},
|
|
72
|
+
});
|
|
73
|
+
expect(result).toHaveLength(1);
|
|
74
|
+
expect(result[0].toString()).toBe('dxn:echo:@:01KG7R1ZXWFMWQ4DA1Q6TN1DG4');
|
|
75
|
+
});
|
|
76
|
+
|
|
77
|
+
test('extracts DXN from nested object', ({ expect }) => {
|
|
78
|
+
const result = extractDxnsFromObject({
|
|
79
|
+
data: {
|
|
80
|
+
items: [
|
|
81
|
+
{
|
|
82
|
+
ref: { '/': 'dxn:echo:@:01KG7R1ZXWFMWQ4DA1Q6TN1DG4' },
|
|
83
|
+
},
|
|
84
|
+
],
|
|
85
|
+
},
|
|
86
|
+
});
|
|
87
|
+
expect(result).toHaveLength(1);
|
|
88
|
+
});
|
|
89
|
+
|
|
90
|
+
test('extracts DXN from string property', ({ expect }) => {
|
|
91
|
+
const result = extractDxnsFromObject({
|
|
92
|
+
message: 'Created object dxn:echo:@:01KG7R1ZXWFMWQ4DA1Q6TN1DG4',
|
|
93
|
+
});
|
|
94
|
+
expect(result).toHaveLength(1);
|
|
95
|
+
});
|
|
96
|
+
|
|
97
|
+
test('extracts DXN from array', ({ expect }) => {
|
|
98
|
+
const result = extractDxnsFromObject([
|
|
99
|
+
{ '/': 'dxn:echo:@:01KG7R1ZXWFMWQ4DA1Q6TN1DG4' },
|
|
100
|
+
{ '/': 'dxn:echo:@:01KG7R1ZXWFMWQ4DA1Q6TN1DG5' },
|
|
101
|
+
]);
|
|
102
|
+
expect(result).toHaveLength(2);
|
|
103
|
+
});
|
|
104
|
+
|
|
105
|
+
test('handles null and undefined', ({ expect }) => {
|
|
106
|
+
expect(extractDxnsFromObject(null)).toHaveLength(0);
|
|
107
|
+
expect(extractDxnsFromObject(undefined)).toHaveLength(0);
|
|
108
|
+
});
|
|
109
|
+
});
|
|
110
|
+
|
|
111
|
+
describe('extractFirstDxnFromToolInput', () => {
|
|
112
|
+
test('extracts DXN from JSON tool input', ({ expect }) => {
|
|
113
|
+
const input = JSON.stringify({
|
|
114
|
+
objectRef: { '/': 'dxn:echo:@:01KG7R1ZXWFMWQ4DA1Q6TN1DG4' },
|
|
115
|
+
});
|
|
116
|
+
const result = extractFirstDxnFromToolInput(input);
|
|
117
|
+
expect(result?.toString()).toBe('dxn:echo:@:01KG7R1ZXWFMWQ4DA1Q6TN1DG4');
|
|
118
|
+
});
|
|
119
|
+
|
|
120
|
+
test('extracts DXN from invalid JSON string', ({ expect }) => {
|
|
121
|
+
const input = 'Invalid JSON but contains dxn:echo:@:01KG7R1ZXWFMWQ4DA1Q6TN1DG4';
|
|
122
|
+
const result = extractFirstDxnFromToolInput(input);
|
|
123
|
+
expect(result?.toString()).toBe('dxn:echo:@:01KG7R1ZXWFMWQ4DA1Q6TN1DG4');
|
|
124
|
+
});
|
|
125
|
+
|
|
126
|
+
test('returns undefined for input without DXNs', ({ expect }) => {
|
|
127
|
+
const input = JSON.stringify({ name: 'Test' });
|
|
128
|
+
const result = extractFirstDxnFromToolInput(input);
|
|
129
|
+
expect(result).toBeUndefined();
|
|
130
|
+
});
|
|
131
|
+
});
|
|
132
|
+
|
|
133
|
+
describe('extractFirstDxnFromToolResult', () => {
|
|
134
|
+
test('extracts DXN from JSON tool result', ({ expect }) => {
|
|
135
|
+
const result = JSON.stringify({
|
|
136
|
+
created: { '/': 'dxn:echo:@:01KG7R1ZXWFMWQ4DA1Q6TN1DG4' },
|
|
137
|
+
});
|
|
138
|
+
const dxn = extractFirstDxnFromToolResult(result);
|
|
139
|
+
expect(dxn?.toString()).toBe('dxn:echo:@:01KG7R1ZXWFMWQ4DA1Q6TN1DG4');
|
|
140
|
+
});
|
|
141
|
+
|
|
142
|
+
test('returns undefined for undefined result', ({ expect }) => {
|
|
143
|
+
const dxn = extractFirstDxnFromToolResult(undefined);
|
|
144
|
+
expect(dxn).toBeUndefined();
|
|
145
|
+
});
|
|
146
|
+
|
|
147
|
+
test('returns undefined for result without DXNs', ({ expect }) => {
|
|
148
|
+
const result = JSON.stringify({ success: true });
|
|
149
|
+
const dxn = extractFirstDxnFromToolResult(result);
|
|
150
|
+
expect(dxn).toBeUndefined();
|
|
151
|
+
});
|
|
152
|
+
});
|
|
153
|
+
});
|
|
@@ -0,0 +1,178 @@
|
|
|
1
|
+
//
|
|
2
|
+
// Copyright 2025 DXOS.org
|
|
3
|
+
//
|
|
4
|
+
|
|
5
|
+
import { DXN } from '@dxos/keys';
|
|
6
|
+
|
|
7
|
+
/**
|
|
8
|
+
* Patterns for extracting DXN references from tool call params/results.
|
|
9
|
+
*
|
|
10
|
+
* Supported formats:
|
|
11
|
+
* - `{ "/": "dxn:..." }` - IPLD-style encoded references
|
|
12
|
+
* - `{ "@dxn": "dxn:..." }` - Alternative format with @dxn key
|
|
13
|
+
* - `@dxn:...` - In-text references (with @ prefix)
|
|
14
|
+
* - `dxn:...` - Plain DXN strings
|
|
15
|
+
*/
|
|
16
|
+
|
|
17
|
+
/**
|
|
18
|
+
* Regex to match DXN strings in various formats.
|
|
19
|
+
* Matches: dxn:kind:part1:part2:...
|
|
20
|
+
*/
|
|
21
|
+
const DXN_PATTERN = /dxn:[a-zA-Z0-9]+(?::[a-zA-Z0-9@_-]+)+/g;
|
|
22
|
+
|
|
23
|
+
/**
|
|
24
|
+
* Regex to match @dxn: prefixed references in text.
|
|
25
|
+
*/
|
|
26
|
+
const AT_DXN_PATTERN = /@(dxn:[a-zA-Z0-9]+(?::[a-zA-Z0-9@_-]+)+)/g;
|
|
27
|
+
|
|
28
|
+
/**
|
|
29
|
+
* Extracts all DXN references from a string.
|
|
30
|
+
*/
|
|
31
|
+
export const extractDxnsFromString = (text: string): DXN[] => {
|
|
32
|
+
const dxns: DXN[] = [];
|
|
33
|
+
const seen = new Set<string>();
|
|
34
|
+
|
|
35
|
+
// Match @dxn: prefixed references.
|
|
36
|
+
let match;
|
|
37
|
+
while ((match = AT_DXN_PATTERN.exec(text)) !== null) {
|
|
38
|
+
const dxnStr = match[1];
|
|
39
|
+
if (!seen.has(dxnStr)) {
|
|
40
|
+
const dxn = DXN.tryParse(dxnStr);
|
|
41
|
+
if (dxn) {
|
|
42
|
+
dxns.push(dxn);
|
|
43
|
+
seen.add(dxnStr);
|
|
44
|
+
}
|
|
45
|
+
}
|
|
46
|
+
}
|
|
47
|
+
|
|
48
|
+
// Match plain dxn: strings.
|
|
49
|
+
while ((match = DXN_PATTERN.exec(text)) !== null) {
|
|
50
|
+
const dxnStr = match[0];
|
|
51
|
+
if (!seen.has(dxnStr)) {
|
|
52
|
+
const dxn = DXN.tryParse(dxnStr);
|
|
53
|
+
if (dxn) {
|
|
54
|
+
dxns.push(dxn);
|
|
55
|
+
seen.add(dxnStr);
|
|
56
|
+
}
|
|
57
|
+
}
|
|
58
|
+
}
|
|
59
|
+
|
|
60
|
+
return dxns;
|
|
61
|
+
};
|
|
62
|
+
|
|
63
|
+
/**
|
|
64
|
+
* Extracts DXN references from a JSON object.
|
|
65
|
+
* Handles IPLD-style references `{ "/": "dxn:..." }` and `{ "@dxn": "dxn:..." }`.
|
|
66
|
+
*/
|
|
67
|
+
export const extractDxnsFromObject = (obj: unknown): DXN[] => {
|
|
68
|
+
const dxns: DXN[] = [];
|
|
69
|
+
const seen = new Set<string>();
|
|
70
|
+
|
|
71
|
+
const addDxn = (dxnStr: string) => {
|
|
72
|
+
if (!seen.has(dxnStr)) {
|
|
73
|
+
const dxn = DXN.tryParse(dxnStr);
|
|
74
|
+
if (dxn) {
|
|
75
|
+
dxns.push(dxn);
|
|
76
|
+
seen.add(dxnStr);
|
|
77
|
+
}
|
|
78
|
+
}
|
|
79
|
+
};
|
|
80
|
+
|
|
81
|
+
const traverse = (value: unknown): void => {
|
|
82
|
+
if (value === null || value === undefined) {
|
|
83
|
+
return;
|
|
84
|
+
}
|
|
85
|
+
|
|
86
|
+
if (typeof value === 'string') {
|
|
87
|
+
// Check if the string itself is a DXN.
|
|
88
|
+
if (value.startsWith('dxn:')) {
|
|
89
|
+
addDxn(value);
|
|
90
|
+
} else if (value.startsWith('@dxn:')) {
|
|
91
|
+
addDxn(value.slice(1));
|
|
92
|
+
}
|
|
93
|
+
// Also extract DXNs from within the string.
|
|
94
|
+
const extracted = extractDxnsFromString(value);
|
|
95
|
+
for (const dxn of extracted) {
|
|
96
|
+
addDxn(dxn.toString());
|
|
97
|
+
}
|
|
98
|
+
return;
|
|
99
|
+
}
|
|
100
|
+
|
|
101
|
+
if (Array.isArray(value)) {
|
|
102
|
+
for (const item of value) {
|
|
103
|
+
traverse(item);
|
|
104
|
+
}
|
|
105
|
+
return;
|
|
106
|
+
}
|
|
107
|
+
|
|
108
|
+
if (typeof value === 'object') {
|
|
109
|
+
const record = value as Record<string, unknown>;
|
|
110
|
+
|
|
111
|
+
// Check for IPLD-style reference: { "/": "dxn:..." }
|
|
112
|
+
if ('/' in record && typeof record['/'] === 'string') {
|
|
113
|
+
const dxnStr = record['/'];
|
|
114
|
+
if (typeof dxnStr === 'string' && dxnStr.startsWith('dxn:')) {
|
|
115
|
+
addDxn(dxnStr);
|
|
116
|
+
}
|
|
117
|
+
}
|
|
118
|
+
|
|
119
|
+
// Check for @dxn key: { "@dxn": "dxn:..." }
|
|
120
|
+
if ('@dxn' in record && typeof record['@dxn'] === 'string') {
|
|
121
|
+
const dxnStr = record['@dxn'];
|
|
122
|
+
if (typeof dxnStr === 'string' && dxnStr.startsWith('dxn:')) {
|
|
123
|
+
addDxn(dxnStr);
|
|
124
|
+
}
|
|
125
|
+
}
|
|
126
|
+
|
|
127
|
+
// Check for reference blocks: { _tag: 'reference', reference: { dxn: ... } }
|
|
128
|
+
if (record._tag === 'reference' && record.reference && typeof record.reference === 'object') {
|
|
129
|
+
const ref = record.reference as Record<string, unknown>;
|
|
130
|
+
if (ref.dxn && typeof ref.dxn === 'string') {
|
|
131
|
+
addDxn(ref.dxn);
|
|
132
|
+
}
|
|
133
|
+
}
|
|
134
|
+
|
|
135
|
+
// Recursively traverse all properties.
|
|
136
|
+
for (const key of Object.keys(record)) {
|
|
137
|
+
traverse(record[key]);
|
|
138
|
+
}
|
|
139
|
+
}
|
|
140
|
+
};
|
|
141
|
+
|
|
142
|
+
traverse(obj);
|
|
143
|
+
return dxns;
|
|
144
|
+
};
|
|
145
|
+
|
|
146
|
+
/**
|
|
147
|
+
* Extracts the first DXN from a tool call input string (JSON).
|
|
148
|
+
*/
|
|
149
|
+
export const extractFirstDxnFromToolInput = (input: string): DXN | undefined => {
|
|
150
|
+
try {
|
|
151
|
+
const parsed = JSON.parse(input);
|
|
152
|
+
const dxns = extractDxnsFromObject(parsed);
|
|
153
|
+
return dxns[0];
|
|
154
|
+
} catch {
|
|
155
|
+
// If JSON parsing fails, try to extract from the raw string.
|
|
156
|
+
const dxns = extractDxnsFromString(input);
|
|
157
|
+
return dxns[0];
|
|
158
|
+
}
|
|
159
|
+
};
|
|
160
|
+
|
|
161
|
+
/**
|
|
162
|
+
* Extracts the first DXN from a tool result string (JSON).
|
|
163
|
+
*/
|
|
164
|
+
export const extractFirstDxnFromToolResult = (result: string | undefined): DXN | undefined => {
|
|
165
|
+
if (!result) {
|
|
166
|
+
return undefined;
|
|
167
|
+
}
|
|
168
|
+
|
|
169
|
+
try {
|
|
170
|
+
const parsed = JSON.parse(result);
|
|
171
|
+
const dxns = extractDxnsFromObject(parsed);
|
|
172
|
+
return dxns[0];
|
|
173
|
+
} catch {
|
|
174
|
+
// If JSON parsing fails, try to extract from the raw string.
|
|
175
|
+
const dxns = extractDxnsFromString(result);
|
|
176
|
+
return dxns[0];
|
|
177
|
+
}
|
|
178
|
+
};
|