@dxos/plugin-assistant 0.8.4-main.422d1c7879 → 0.8.4-main.4668b7de9b
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +102 -5
- package/PLUGIN.mdl +439 -0
- package/README.md +1 -1
- package/dist/lib/neutral/AgentArticle-OYQPCK3Q.mjs +161 -0
- package/dist/lib/neutral/AgentArticle-OYQPCK3Q.mjs.map +7 -0
- package/dist/lib/neutral/AgentProperties-W6LD56IB.mjs +40 -0
- package/dist/lib/neutral/AgentProperties-W6LD56IB.mjs.map +7 -0
- package/dist/lib/neutral/AssistantPlugin.mjs +10 -0
- package/dist/lib/neutral/AssistantPlugin.node.mjs +66 -0
- package/dist/lib/neutral/AssistantPlugin.node.mjs.map +7 -0
- package/dist/lib/neutral/AssistantPlugin.workerd.mjs +40 -0
- package/dist/lib/neutral/AssistantPlugin.workerd.mjs.map +7 -0
- package/dist/lib/neutral/AssistantSettings-GG52BLKS.mjs +40 -0
- package/dist/lib/neutral/AssistantSettings-GG52BLKS.mjs.map +7 -0
- package/dist/lib/neutral/BlueprintArticle-ZBOZNZM7.mjs +27 -0
- package/dist/lib/neutral/BlueprintArticle-ZBOZNZM7.mjs.map +7 -0
- package/dist/lib/neutral/ChatArticle-PWD4OEFZ.mjs +8 -0
- package/dist/lib/neutral/ChatCompanion-TPY7HF3C.mjs +122 -0
- package/dist/lib/neutral/ChatCompanion-TPY7HF3C.mjs.map +7 -0
- package/dist/lib/neutral/ChatDialog-DCA6FLOV.mjs +73 -0
- package/dist/lib/neutral/ChatDialog-DCA6FLOV.mjs.map +7 -0
- package/dist/lib/neutral/PlanArticle-TS5ULWYS.mjs +28 -0
- package/dist/lib/neutral/PlanArticle-TS5ULWYS.mjs.map +7 -0
- package/dist/lib/neutral/RoutineArticle-5NYXHRG6.mjs +119 -0
- package/dist/lib/neutral/RoutineArticle-5NYXHRG6.mjs.map +7 -0
- package/dist/lib/neutral/RoutineList-SO5ETHNT.mjs +48 -0
- package/dist/lib/neutral/RoutineList-SO5ETHNT.mjs.map +7 -0
- package/dist/lib/neutral/RoutineProperties-FISLMW2R.mjs +17 -0
- package/dist/lib/neutral/RoutineProperties-FISLMW2R.mjs.map +7 -0
- package/dist/lib/neutral/TracePanel-CHJHFTTQ.mjs +136 -0
- package/dist/lib/neutral/TracePanel-CHJHFTTQ.mjs.map +7 -0
- package/dist/lib/neutral/TriggerStatus-X7Y5JFZJ.mjs +93 -0
- package/dist/lib/neutral/TriggerStatus-X7Y5JFZJ.mjs.map +7 -0
- package/dist/lib/neutral/ai-context-IABBIEHG.mjs +42 -0
- package/dist/lib/neutral/ai-context-IABBIEHG.mjs.map +7 -0
- package/dist/lib/neutral/ai-service-3SH2UQIR.mjs +42 -0
- package/dist/lib/neutral/ai-service-3SH2UQIR.mjs.map +7 -0
- package/dist/lib/neutral/app-graph-builder-RJW5O57E.mjs +199 -0
- package/dist/lib/neutral/app-graph-builder-RJW5O57E.mjs.map +7 -0
- package/dist/lib/neutral/blueprint-definition-VXJYQ5AE.mjs +32 -0
- package/dist/lib/neutral/blueprint-definition-VXJYQ5AE.mjs.map +7 -0
- package/dist/lib/{browser → neutral}/blueprints/index.mjs +1 -1
- package/dist/lib/neutral/capabilities/index.mjs +37 -0
- package/dist/lib/neutral/capabilities/index.mjs.map +7 -0
- package/dist/lib/neutral/chunk-47OH7ZF6.mjs +8 -0
- package/dist/lib/neutral/chunk-47OH7ZF6.mjs.map +7 -0
- package/dist/lib/{browser/chunk-EZRS3J25.mjs → neutral/chunk-5H6UJHLF.mjs} +3 -3
- package/dist/lib/neutral/chunk-5H6UJHLF.mjs.map +7 -0
- package/dist/lib/neutral/chunk-6BUTAYVO.mjs +123 -0
- package/dist/lib/neutral/chunk-6BUTAYVO.mjs.map +7 -0
- package/dist/lib/neutral/chunk-A2XIILMZ.mjs +107 -0
- package/dist/lib/neutral/chunk-A2XIILMZ.mjs.map +7 -0
- package/dist/lib/neutral/chunk-UWI53RCD.mjs +386 -0
- package/dist/lib/neutral/chunk-UWI53RCD.mjs.map +7 -0
- package/dist/lib/neutral/chunk-XYHPOGTK.mjs +43 -0
- package/dist/lib/neutral/chunk-XYHPOGTK.mjs.map +7 -0
- package/dist/lib/neutral/companion-chat-provisioner-7RTSXL6M.mjs +116 -0
- package/dist/lib/neutral/companion-chat-provisioner-7RTSXL6M.mjs.map +7 -0
- package/dist/lib/neutral/components/index.mjs +2384 -0
- package/dist/lib/neutral/components/index.mjs.map +7 -0
- package/dist/lib/neutral/containers/index.mjs +29 -0
- package/dist/lib/neutral/containers/index.mjs.map +7 -0
- package/dist/lib/neutral/create-chat-67GZNG3T.mjs +54 -0
- package/dist/lib/neutral/create-chat-67GZNG3T.mjs.map +7 -0
- package/dist/lib/neutral/create-object-XPVVVEKF.mjs +89 -0
- package/dist/lib/neutral/create-object-XPVVVEKF.mjs.map +7 -0
- package/dist/lib/neutral/edge-model-resolver-7SMCGDRL.mjs +50 -0
- package/dist/lib/neutral/edge-model-resolver-7SMCGDRL.mjs.map +7 -0
- package/dist/lib/{browser/ensure-companion-chat-ZEZA34MZ.mjs → neutral/ensure-companion-chat-AMOF3C66.mjs} +14 -21
- package/dist/lib/neutral/ensure-companion-chat-AMOF3C66.mjs.map +7 -0
- package/dist/lib/neutral/execution-graph/index.mjs +658 -0
- package/dist/lib/neutral/execution-graph/index.mjs.map +7 -0
- package/dist/lib/neutral/hooks/index.mjs +965 -0
- package/dist/lib/neutral/hooks/index.mjs.map +7 -0
- package/dist/lib/neutral/index.mjs +32 -0
- package/dist/lib/neutral/local-model-resolver-I2BENFFS.mjs +24 -0
- package/dist/lib/neutral/local-model-resolver-I2BENFFS.mjs.map +7 -0
- package/dist/lib/neutral/markdown-KTBFOMFM.mjs +110 -0
- package/dist/lib/neutral/markdown-KTBFOMFM.mjs.map +7 -0
- package/dist/lib/neutral/meta.json +1 -0
- package/dist/lib/neutral/meta.mjs +12 -0
- package/dist/lib/neutral/migrations-7DEMVBOG.mjs +28 -0
- package/dist/lib/neutral/migrations-7DEMVBOG.mjs.map +7 -0
- package/dist/lib/{browser/on-create-space-54RNX5JI.mjs → neutral/on-create-space-Q2R7OSP6.mjs} +5 -8
- package/dist/lib/neutral/on-create-space-Q2R7OSP6.mjs.map +7 -0
- package/dist/lib/neutral/operation-handler-SF36MOB5.mjs +13 -0
- package/dist/lib/neutral/operation-handler-SF36MOB5.mjs.map +7 -0
- package/dist/lib/neutral/operations/index.mjs +8 -0
- package/dist/lib/neutral/operations/index.mjs.map +7 -0
- package/dist/lib/neutral/plugin.mjs +16 -0
- package/dist/lib/neutral/plugin.mjs.map +7 -0
- package/dist/lib/neutral/react-surface-XRTBW5OJ.mjs +174 -0
- package/dist/lib/neutral/react-surface-XRTBW5OJ.mjs.map +7 -0
- package/dist/lib/{browser/resolve-navigation-targets-NZOD66NY.mjs → neutral/resolve-navigation-targets-ZHIMMH7L.mjs} +6 -6
- package/dist/lib/neutral/resolve-navigation-targets-ZHIMMH7L.mjs.map +7 -0
- package/dist/lib/{browser/run-prompt-in-new-chat-THLK5YQC.mjs → neutral/run-prompt-in-new-chat-NRDYPCJK.mjs} +21 -55
- package/dist/lib/neutral/run-prompt-in-new-chat-NRDYPCJK.mjs.map +7 -0
- package/dist/lib/{browser/set-current-chat-LRS3VFSH.mjs → neutral/set-current-chat-VWBPSIMZ.mjs} +7 -13
- package/dist/lib/neutral/set-current-chat-VWBPSIMZ.mjs.map +7 -0
- package/dist/lib/neutral/settings-W4BLWQ53.mjs +28 -0
- package/dist/lib/neutral/settings-W4BLWQ53.mjs.map +7 -0
- package/dist/lib/neutral/state-H3G7QCU6.mjs +28 -0
- package/dist/lib/neutral/state-H3G7QCU6.mjs.map +7 -0
- package/dist/lib/neutral/testing.mjs +8 -0
- package/dist/lib/neutral/testing.mjs.map +7 -0
- package/dist/lib/neutral/toggle-trace-panel-debug-JGTB6KVJ.mjs +21 -0
- package/dist/lib/neutral/toggle-trace-panel-debug-JGTB6KVJ.mjs.map +7 -0
- package/dist/lib/neutral/toolkit-GVWXPDLJ.mjs +14 -0
- package/dist/lib/neutral/toolkit-GVWXPDLJ.mjs.map +7 -0
- package/dist/lib/neutral/translations.mjs +175 -0
- package/dist/lib/neutral/translations.mjs.map +7 -0
- package/dist/lib/neutral/types/index.mjs +20 -0
- package/dist/lib/neutral/types/index.mjs.map +7 -0
- package/dist/lib/{browser/update-chat-name-3Y36KFAS.mjs → neutral/update-chat-name-ENXRUMDJ.mjs} +8 -25
- package/dist/lib/neutral/update-chat-name-ENXRUMDJ.mjs.map +7 -0
- package/dist/types/src/AssistantPlugin.d.ts +3 -1
- package/dist/types/src/AssistantPlugin.d.ts.map +1 -1
- package/dist/types/src/AssistantPlugin.node.d.ts +5 -0
- package/dist/types/src/AssistantPlugin.node.d.ts.map +1 -0
- package/dist/types/src/AssistantPlugin.test.d.ts +2 -0
- package/dist/types/src/AssistantPlugin.test.d.ts.map +1 -0
- package/dist/types/src/AssistantPlugin.workerd.d.ts +4 -0
- package/dist/types/src/AssistantPlugin.workerd.d.ts.map +1 -0
- package/dist/types/src/blueprints/assistant/blueprint.d.ts +2 -2
- package/dist/types/src/blueprints/assistant/blueprint.d.ts.map +1 -1
- package/dist/types/src/blueprints/assistant/blueprint.node.test.d.ts +2 -0
- package/dist/types/src/blueprints/assistant/blueprint.node.test.d.ts.map +1 -0
- package/dist/types/src/capabilities/ai-context.d.ts +6 -0
- package/dist/types/src/capabilities/ai-context.d.ts.map +1 -0
- package/dist/types/src/capabilities/ai-service.d.ts +2 -2
- 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/create-object.d.ts +31 -0
- package/dist/types/src/capabilities/create-object.d.ts.map +1 -0
- package/dist/types/src/capabilities/edge-model-resolver.d.ts +1 -1
- package/dist/types/src/capabilities/edge-model-resolver.d.ts.map +1 -1
- package/dist/types/src/capabilities/index.d.ts +30 -2
- package/dist/types/src/capabilities/index.d.ts.map +1 -1
- package/dist/types/src/capabilities/local-model-resolver.d.ts.map +1 -1
- package/dist/types/src/capabilities/markdown.d.ts.map +1 -1
- package/dist/types/src/capabilities/migrations.d.ts +2 -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.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/components/AgentProperties/AgentProperties.d.ts +7 -0
- package/dist/types/src/components/AgentProperties/AgentProperties.d.ts.map +1 -0
- package/dist/types/src/{containers → components}/AgentProperties/AgentProperties.stories.d.ts +1 -2
- package/dist/types/src/components/AgentProperties/AgentProperties.stories.d.ts.map +1 -0
- package/dist/types/src/components/AgentProperties/index.d.ts +2 -0
- package/dist/types/src/components/AgentProperties/index.d.ts.map +1 -0
- package/dist/types/src/components/AssistantSettings/AssistantSettings.d.ts +1 -1
- package/dist/types/src/components/AssistantSettings/AssistantSettings.d.ts.map +1 -1
- package/dist/types/src/components/AssistantSettings/AssistantSettings.stories.d.ts.map +1 -1
- package/dist/types/src/components/Chat/Chat.d.ts +36 -40
- 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 +8 -7
- package/dist/types/src/components/ChatPrompt/ChatOptions.d.ts.map +1 -1
- package/dist/types/src/components/ChatPrompt/ChatOptions.stories.d.ts +1 -1
- package/dist/types/src/components/ChatPrompt/ChatOptions.stories.d.ts.map +1 -1
- package/dist/types/src/components/ChatPrompt/ChatPresets.d.ts.map +1 -1
- package/dist/types/src/components/ChatPrompt/ChatPrompt.d.ts +28 -0
- package/dist/types/src/components/ChatPrompt/ChatPrompt.d.ts.map +1 -0
- package/dist/types/src/components/ChatPrompt/ChatReferences.d.ts +2 -2
- package/dist/types/src/components/ChatPrompt/ChatReferences.d.ts.map +1 -1
- package/dist/types/src/components/ChatPrompt/ChatStatus.d.ts +20 -0
- package/dist/types/src/components/ChatPrompt/ChatStatus.d.ts.map +1 -0
- package/dist/types/src/components/ChatPrompt/ChatStatusIndicator.d.ts.map +1 -1
- package/dist/types/src/components/ChatPrompt/index.d.ts +3 -0
- package/dist/types/src/components/ChatPrompt/index.d.ts.map +1 -1
- package/dist/types/src/components/ChatThread/Anchor.stories.d.ts.map +1 -1
- 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 +5 -5
- package/dist/types/src/components/ChatThread/ChatThread.stories.d.ts.map +1 -1
- package/dist/types/src/components/ChatThread/Link.d.ts +2 -2
- package/dist/types/src/components/ChatThread/Link.d.ts.map +1 -1
- package/dist/types/src/components/ChatThread/MarkdownStream.stories.d.ts +1 -1
- 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 +3 -3
- 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 +2 -15
- 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.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 +4 -3
- 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/RoutineProperties/RoutineProperties.d.ts +7 -0
- package/dist/types/src/components/RoutineProperties/RoutineProperties.d.ts.map +1 -0
- package/dist/types/src/components/RoutineProperties/RoutineProperties.stories.d.ts +15 -0
- package/dist/types/src/components/RoutineProperties/RoutineProperties.stories.d.ts.map +1 -0
- package/dist/types/src/components/RoutineProperties/index.d.ts +2 -0
- package/dist/types/src/components/RoutineProperties/index.d.ts.map +1 -0
- package/dist/types/src/components/TaskList/TaskList.d.ts +10 -0
- package/dist/types/src/components/TaskList/TaskList.d.ts.map +1 -0
- package/dist/types/src/components/TaskList/TaskList.stories.d.ts +16 -0
- package/dist/types/src/components/TaskList/TaskList.stories.d.ts.map +1 -0
- package/dist/types/src/components/TaskList/index.d.ts +2 -0
- package/dist/types/src/components/TaskList/index.d.ts.map +1 -0
- package/dist/types/src/components/TemplateEditor/TemplateEditor.d.ts +5 -3
- package/dist/types/src/components/TemplateEditor/TemplateEditor.d.ts.map +1 -1
- package/dist/types/src/components/TemplateEditor/TemplateEditor.stories.d.ts.map +1 -1
- package/dist/types/src/components/TemplateEditor/TemplateForm.d.ts +4 -5
- package/dist/types/src/components/TemplateEditor/TemplateForm.d.ts.map +1 -1
- package/dist/types/src/components/TemplateEditor/TemplateForm.stories.d.ts +1 -1
- 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.map +1 -1
- package/dist/types/src/components/index.d.ts +3 -0
- package/dist/types/src/components/index.d.ts.map +1 -1
- package/dist/types/src/containers/AgentArticle/AgentArticle.d.ts.map +1 -1
- package/dist/types/src/containers/AgentArticle/AgentArticle.stories.d.ts +0 -2
- 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/BlueprintArticle/BlueprintArticle.d.ts +1 -1
- package/dist/types/src/containers/BlueprintArticle/BlueprintArticle.d.ts.map +1 -1
- package/dist/types/src/containers/{ChatContainer/ChatContainer.d.ts → ChatArticle/ChatArticle.d.ts} +3 -3
- package/dist/types/src/containers/ChatArticle/ChatArticle.d.ts.map +1 -0
- package/dist/types/src/containers/ChatArticle/ChatArticle.stories.d.ts +15 -0
- package/dist/types/src/containers/ChatArticle/ChatArticle.stories.d.ts.map +1 -0
- package/dist/types/src/containers/ChatArticle/index.d.ts +2 -0
- package/dist/types/src/containers/ChatArticle/index.d.ts.map +1 -0
- package/dist/types/src/containers/ChatCompanion/ChatCompanion.d.ts +11 -3
- package/dist/types/src/containers/ChatCompanion/ChatCompanion.d.ts.map +1 -1
- package/dist/types/src/containers/ChatDialog/ChatDialog.d.ts.map +1 -1
- package/dist/types/src/containers/PlanArticle/PlanArticle.d.ts +6 -0
- package/dist/types/src/containers/PlanArticle/PlanArticle.d.ts.map +1 -0
- package/dist/types/src/containers/PlanArticle/index.d.ts +2 -0
- package/dist/types/src/containers/PlanArticle/index.d.ts.map +1 -0
- package/dist/types/src/containers/RoutineArticle/RoutineArticle.d.ts +6 -0
- package/dist/types/src/containers/RoutineArticle/RoutineArticle.d.ts.map +1 -0
- package/dist/types/src/containers/RoutineArticle/RoutineArticle.stories.d.ts +15 -0
- package/dist/types/src/containers/RoutineArticle/RoutineArticle.stories.d.ts.map +1 -0
- package/dist/types/src/containers/RoutineArticle/index.d.ts +2 -0
- package/dist/types/src/containers/RoutineArticle/index.d.ts.map +1 -0
- package/dist/types/src/containers/RoutineList/RoutineList.d.ts +6 -0
- package/dist/types/src/containers/RoutineList/RoutineList.d.ts.map +1 -0
- package/dist/types/src/containers/{PromptList/PromptList.stories.d.ts → RoutineList/RoutineList.stories.d.ts} +1 -1
- 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 +3 -2
- package/dist/types/src/containers/TracePanel/TracePanel.d.ts.map +1 -1
- package/dist/types/src/containers/TracePanel/TracePanel.stories.d.ts +3 -4
- package/dist/types/src/containers/TracePanel/TracePanel.stories.d.ts.map +1 -1
- package/dist/types/src/containers/TracePanel/dxn-extractor.d.ts +5 -5
- package/dist/types/src/containers/TracePanel/dxn-extractor.d.ts.map +1 -1
- 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.map +1 -1
- package/dist/types/src/containers/index.d.ts +6 -5
- package/dist/types/src/containers/index.d.ts.map +1 -1
- package/dist/types/src/execution-graph/execution-graph.d.ts +108 -0
- package/dist/types/src/execution-graph/execution-graph.d.ts.map +1 -0
- package/dist/types/src/execution-graph/execution-graph.test.d.ts +2 -0
- package/dist/types/src/execution-graph/execution-graph.test.d.ts.map +1 -0
- package/dist/types/src/execution-graph/index.d.ts +3 -0
- package/dist/types/src/execution-graph/index.d.ts.map +1 -0
- package/dist/types/src/execution-graph/remote-snapshot.test.d.ts +2 -0
- package/dist/types/src/execution-graph/remote-snapshot.test.d.ts.map +1 -0
- package/dist/types/src/execution-graph/span-tree.d.ts +76 -0
- package/dist/types/src/execution-graph/span-tree.d.ts.map +1 -0
- package/dist/types/src/execution-graph/span-tree.test.d.ts +2 -0
- package/dist/types/src/execution-graph/span-tree.test.d.ts.map +1 -0
- package/dist/types/src/execution-graph/testing/collect-trace-events.d.ts +40 -0
- package/dist/types/src/execution-graph/testing/collect-trace-events.d.ts.map +1 -0
- package/dist/types/src/execution-graph/testing/index.d.ts +2 -0
- package/dist/types/src/execution-graph/testing/index.d.ts.map +1 -0
- package/dist/types/src/extensions/prompt-extension.d.ts.map +1 -1
- package/dist/types/src/feed-logger.d.ts +13 -0
- package/dist/types/src/feed-logger.d.ts.map +1 -0
- package/dist/types/src/hooks/index.d.ts +2 -0
- package/dist/types/src/hooks/index.d.ts.map +1 -1
- package/dist/types/src/hooks/useBlueprintRegistry.d.ts +56 -15
- package/dist/types/src/hooks/useBlueprintRegistry.d.ts.map +1 -1
- package/dist/types/src/hooks/useChatKeymap.d.ts +12 -0
- package/dist/types/src/hooks/useChatKeymap.d.ts.map +1 -0
- package/dist/types/src/hooks/useChatProcessor.d.ts +5 -5
- package/dist/types/src/hooks/useChatProcessor.d.ts.map +1 -1
- package/dist/types/src/hooks/useChatServices.d.ts +7 -3
- 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 +2 -2
- package/dist/types/src/hooks/useContextBinder.d.ts.map +1 -1
- package/dist/types/src/hooks/useContextObjects.d.ts +5 -4
- package/dist/types/src/hooks/useContextObjects.d.ts.map +1 -1
- package/dist/types/src/hooks/useDebug.d.ts +10 -0
- package/dist/types/src/hooks/useDebug.d.ts.map +1 -0
- package/dist/types/src/hooks/useFilteredTypes.d.ts +1 -1
- package/dist/types/src/hooks/useFilteredTypes.d.ts.map +1 -1
- package/dist/types/src/hooks/useFlush.d.ts +1 -1
- package/dist/types/src/hooks/useFlush.d.ts.map +1 -1
- package/dist/types/src/hooks/usePresets.d.ts.map +1 -1
- package/dist/types/src/hooks/useReferencesProvider.d.ts.map +1 -1
- package/dist/types/src/index.d.ts +0 -4
- package/dist/types/src/index.d.ts.map +1 -1
- package/dist/types/src/meta.d.ts +3 -2
- package/dist/types/src/meta.d.ts.map +1 -1
- package/dist/types/src/operations/create-chat.d.ts +3 -3
- package/dist/types/src/operations/create-chat.d.ts.map +1 -1
- package/dist/types/src/operations/ensure-companion-chat.d.ts +3 -3
- package/dist/types/src/operations/ensure-companion-chat.d.ts.map +1 -1
- package/dist/types/src/operations/index.d.ts +1 -2
- package/dist/types/src/operations/index.d.ts.map +1 -1
- package/dist/types/src/operations/on-create-space.d.ts +3 -3
- package/dist/types/src/operations/on-create-space.d.ts.map +1 -1
- package/dist/types/src/operations/prompt.node.test.d.ts +2 -0
- package/dist/types/src/operations/prompt.node.test.d.ts.map +1 -0
- package/dist/types/src/operations/resolve-navigation-targets.d.ts +4 -2
- 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 +3 -3
- 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 +3 -3
- package/dist/types/src/operations/set-current-chat.d.ts.map +1 -1
- package/dist/types/src/operations/toggle-trace-panel-debug.d.ts +5 -0
- package/dist/types/src/operations/toggle-trace-panel-debug.d.ts.map +1 -0
- package/dist/types/src/operations/update-chat-name.d.ts +3 -3
- package/dist/types/src/operations/update-chat-name.d.ts.map +1 -1
- package/dist/types/src/plugin.d.ts +4 -0
- package/dist/types/src/plugin.d.ts.map +1 -0
- package/dist/types/src/processor/processor.d.ts +263 -20
- package/dist/types/src/processor/processor.d.ts.map +1 -1
- package/dist/types/src/processor/processor.node.test.d.ts +2 -0
- package/dist/types/src/processor/processor.node.test.d.ts.map +1 -0
- package/dist/types/src/testing/index.d.ts +2 -0
- package/dist/types/src/testing/index.d.ts.map +1 -1
- package/dist/types/src/testing/snapshot.d.ts +21 -0
- package/dist/types/src/testing/snapshot.d.ts.map +1 -0
- package/dist/types/src/testing/test-generator.d.ts +2 -3
- package/dist/types/src/testing/test-generator.d.ts.map +1 -1
- package/dist/types/src/testing/test-sequence.d.ts +10 -3
- package/dist/types/src/testing/test-sequence.d.ts.map +1 -1
- package/dist/types/src/testing/test-services.d.ts.map +1 -1
- package/dist/types/src/testing/test-trace.d.ts +5 -0
- package/dist/types/src/testing/test-trace.d.ts.map +1 -0
- package/dist/types/src/testing/trace-timeline.node.test.d.ts +2 -0
- package/dist/types/src/testing/trace-timeline.node.test.d.ts.map +1 -0
- package/dist/types/src/testing.d.ts +2 -0
- package/dist/types/src/testing.d.ts.map +1 -0
- package/dist/types/src/translations.d.ts.map +1 -1
- package/dist/types/src/types/Assistant.d.ts +25 -8
- package/dist/types/src/types/Assistant.d.ts.map +1 -1
- package/dist/types/src/types/AssistantCapabilities.d.ts +30 -0
- package/dist/types/src/types/AssistantCapabilities.d.ts.map +1 -0
- package/dist/types/src/types/AssistantEvents.d.ts +3 -0
- package/dist/types/src/types/AssistantEvents.d.ts.map +1 -0
- package/dist/types/src/{operations/definitions.d.ts → types/AssistantOperation.d.ts} +61 -59
- package/dist/types/src/types/AssistantOperation.d.ts.map +1 -0
- package/dist/types/src/types/Settings.d.ts +21 -5
- package/dist/types/src/types/Settings.d.ts.map +1 -1
- package/dist/types/src/types/index.d.ts +7 -3
- package/dist/types/src/types/index.d.ts.map +1 -1
- package/dist/types/src/types/service.d.ts +2 -3
- package/dist/types/src/types/service.d.ts.map +1 -1
- package/dist/types/src/util/suggestions.d.ts +9 -0
- package/dist/types/src/util/suggestions.d.ts.map +1 -0
- package/dist/types/src/util/suggestions.test.d.ts +2 -0
- package/dist/types/src/util/suggestions.test.d.ts.map +1 -0
- package/dist/types/tsconfig.tsbuildinfo +1 -1
- package/package.json +168 -128
- package/src/AssistantPlugin.conversations.json +1 -0
- package/src/AssistantPlugin.node.ts +77 -0
- package/src/AssistantPlugin.test.ts +152 -0
- package/src/AssistantPlugin.ts +147 -0
- package/src/AssistantPlugin.workerd.ts +41 -0
- package/src/blueprints/assistant/{blueprint.test.ts → blueprint.node.test.ts} +5 -5
- package/src/blueprints/assistant/blueprint.ts +4 -4
- package/src/capabilities/ai-context.ts +85 -0
- package/src/capabilities/ai-service.ts +36 -9
- package/src/capabilities/app-graph-builder.ts +55 -20
- package/src/capabilities/blueprint-definition.ts +2 -4
- package/src/capabilities/companion-chat-provisioner.ts +4 -5
- package/src/capabilities/create-object.ts +98 -0
- package/src/capabilities/edge-model-resolver.ts +47 -11
- package/src/capabilities/index.ts +10 -2
- package/src/capabilities/markdown.ts +1 -1
- package/src/capabilities/migrations.ts +4 -11
- package/src/capabilities/operation-handler.ts +1 -1
- package/src/capabilities/react-surface.tsx +33 -20
- package/src/components/AgentProperties/AgentProperties.stories.tsx +74 -0
- package/src/components/AgentProperties/AgentProperties.tsx +104 -0
- package/src/components/AgentProperties/index.ts +5 -0
- package/src/components/AssistantSettings/AssistantSettings.stories.tsx +3 -2
- package/src/components/AssistantSettings/AssistantSettings.tsx +22 -111
- package/src/components/Chat/Chat.tsx +85 -259
- 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 +32 -18
- package/src/components/ChatPrompt/ChatOptions.tsx +103 -82
- package/src/components/ChatPrompt/ChatPrompt.tsx +182 -0
- package/src/components/ChatPrompt/ChatReferences.tsx +9 -13
- package/src/components/ChatPrompt/ChatStatus.tsx +123 -0
- package/src/components/ChatPrompt/ChatStatusIndicator.tsx +1 -1
- package/src/components/ChatPrompt/index.ts +3 -0
- package/src/components/ChatThread/Anchor.stories.tsx +7 -7
- package/src/components/ChatThread/ChatThread.stories.tsx +27 -31
- package/src/components/ChatThread/ChatThread.tsx +43 -21
- package/src/components/ChatThread/DEBUG.md +41 -0
- package/src/components/ChatThread/Link.tsx +5 -5
- package/src/components/ChatThread/MarkdownStream.stories.tsx +5 -4
- package/src/components/ChatThread/registry.tsx +62 -19
- package/src/components/ChatThread/sync.test.ts +84 -18
- package/src/components/ChatThread/sync.ts +3 -3
- package/src/components/ChatThread/widgets/ReasoningWidget.ts +13 -7
- package/src/components/ChatThread/widgets/ReferenceWidget.ts +3 -1
- package/src/components/ChatThread/widgets/SelectWidget.ts +4 -2
- package/src/components/ChatThread/widgets/StatsWidget.ts +3 -1
- package/src/components/ChatThread/widgets/StatusWidget.ts +6 -84
- package/src/components/ChatThread/widgets/SuggestionWidget.ts +2 -2
- package/src/components/ChatThread/widgets/SummaryWidget.tsx +3 -4
- package/src/components/ChatThread/widgets/ToolWidget.stories.tsx +2 -1
- package/src/components/ChatThread/widgets/ToolWidget.tsx +19 -4
- 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 +13 -39
- package/src/components/ProcessTree/ProcessTree.tsx +101 -67
- package/src/components/RoutineProperties/RoutineProperties.stories.tsx +59 -0
- package/src/components/RoutineProperties/RoutineProperties.tsx +23 -0
- package/src/components/RoutineProperties/index.ts +5 -0
- package/src/components/TaskList/TaskList.stories.tsx +44 -0
- package/src/components/TaskList/TaskList.tsx +45 -0
- package/src/{cli → components/TaskList}/index.ts +1 -1
- package/src/components/TemplateEditor/TemplateEditor.stories.tsx +5 -4
- package/src/components/TemplateEditor/TemplateEditor.tsx +11 -9
- package/src/components/TemplateEditor/TemplateForm.stories.tsx +6 -9
- package/src/components/TemplateEditor/TemplateForm.tsx +52 -73
- package/src/components/ToolBlock/ToolBlock.tsx +1 -1
- package/src/components/Toolbox/Toolbox.stories.tsx +6 -5
- package/src/components/Toolbox/Toolbox.tsx +6 -5
- package/src/components/index.ts +3 -0
- package/src/containers/AgentArticle/AgentArticle.stories.tsx +19 -15
- package/src/containers/AgentArticle/AgentArticle.tsx +37 -48
- package/src/containers/AgentProperties/AgentProperties.tsx +19 -103
- package/src/containers/BlueprintArticle/BlueprintArticle.tsx +2 -2
- package/src/containers/ChatArticle/ChatArticle.stories.tsx +76 -0
- package/src/containers/{ChatContainer/ChatContainer.tsx → ChatArticle/ChatArticle.tsx} +30 -17
- package/src/containers/ChatArticle/index.ts +5 -0
- package/src/containers/ChatCompanion/ChatCompanion.tsx +39 -60
- package/src/containers/ChatDialog/ChatDialog.tsx +6 -11
- package/src/containers/PlanArticle/PlanArticle.tsx +33 -0
- package/src/containers/PlanArticle/index.ts +5 -0
- package/src/containers/RoutineArticle/RoutineArticle.stories.tsx +75 -0
- package/src/containers/RoutineArticle/RoutineArticle.tsx +109 -0
- package/src/containers/RoutineArticle/index.ts +5 -0
- package/src/containers/{PromptList/PromptList.stories.tsx → RoutineList/RoutineList.stories.tsx} +13 -12
- package/src/containers/{PromptList/PromptList.tsx → RoutineList/RoutineList.tsx} +9 -8
- package/src/containers/RoutineList/index.ts +5 -0
- package/src/containers/TracePanel/TracePanel.stories.tsx +251 -204
- package/src/containers/TracePanel/TracePanel.tsx +172 -72
- package/src/containers/TracePanel/dxn-extractor.test.ts +7 -7
- package/src/containers/TracePanel/dxn-extractor.ts +25 -35
- 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 +2 -1
- package/src/containers/index.ts +6 -5
- package/src/execution-graph/SPEC.md +678 -0
- package/src/execution-graph/execution-graph.test.ts +799 -0
- package/src/execution-graph/execution-graph.ts +714 -0
- package/src/execution-graph/index.ts +24 -0
- package/src/execution-graph/remote-snapshot.test.ts +116 -0
- package/src/execution-graph/span-tree.test.ts +249 -0
- package/src/execution-graph/span-tree.ts +259 -0
- package/src/execution-graph/testing/collect-trace-events.ts +74 -0
- package/src/execution-graph/testing/index.ts +5 -0
- package/src/{queue-logger.ts → feed-logger.ts} +39 -25
- package/src/hooks/index.ts +2 -0
- package/src/hooks/useBlueprintRegistry.ts +62 -46
- package/src/hooks/useChatKeymap.ts +52 -0
- package/src/hooks/useChatProcessor.ts +30 -14
- package/src/hooks/useChatServices.ts +8 -6
- package/src/hooks/useChatToolbarActions.ts +87 -89
- package/src/hooks/useContextBinder.ts +4 -4
- package/src/hooks/useContextObjects.ts +6 -5
- package/src/hooks/useDebug.ts +38 -0
- package/src/hooks/useFilteredTypes.ts +17 -16
- package/src/hooks/useReferencesProvider.ts +7 -15
- package/src/index.ts +0 -5
- package/src/meta.ts +27 -8
- package/src/operations/create-chat.ts +14 -37
- package/src/operations/ensure-companion-chat.ts +49 -47
- package/src/operations/index.ts +2 -3
- package/src/operations/on-create-space.ts +4 -4
- package/src/operations/{prompt.test.ts → prompt.node.test.ts} +24 -23
- package/src/operations/resolve-navigation-targets.ts +8 -3
- package/src/operations/run-prompt-in-new-chat.ts +86 -86
- package/src/operations/set-current-chat.ts +6 -7
- package/src/operations/toggle-trace-panel-debug.ts +27 -0
- package/src/operations/update-chat-name.ts +4 -4
- package/src/plugin.ts +11 -0
- package/src/processor/{processor.test.ts → processor.node.test.ts} +6 -6
- package/src/processor/processor.ts +112 -33
- package/src/testing/data/trace-timeline-multiple.dx.json +1 -0
- package/src/testing/data/trace-timeline-remote.dx.json +1 -0
- package/src/testing/data/trace-timeline.dx.json +3737 -1200
- package/src/testing/index.ts +2 -0
- package/src/testing/snapshot.ts +35 -0
- package/src/testing/test-generator.test.ts +42 -52
- package/src/testing/test-generator.ts +177 -192
- package/src/testing/test-sequence.ts +3 -3
- package/src/testing/test-services.ts +1 -1
- package/src/testing/test-trace.ts +20 -0
- package/src/testing/trace-timeline.node.conversations.json +1 -0
- package/src/testing/{trace-timeline.test.ts → trace-timeline.node.test.ts} +44 -49
- package/src/testing.ts +9 -0
- package/src/translations.ts +34 -37
- package/src/types/Assistant.ts +13 -1
- package/src/types/AssistantCapabilities.ts +35 -0
- package/src/types/AssistantEvents.ts +11 -0
- package/src/{operations/definitions.ts → types/AssistantOperation.ts} +57 -20
- package/src/types/Settings.ts +68 -7
- package/src/types/index.ts +11 -3
- package/src/types/service.ts +5 -10
- package/src/util/suggestions.test.ts +52 -0
- package/src/util/suggestions.ts +42 -0
- package/src/vite-env.d.ts +5 -0
- package/dist/lib/browser/AssistantSettings-7QMO3LGF.mjs +0 -97
- package/dist/lib/browser/AssistantSettings-7QMO3LGF.mjs.map +0 -7
- package/dist/lib/browser/chunk-ATHYBVGN.mjs +0 -176
- package/dist/lib/browser/chunk-ATHYBVGN.mjs.map +0 -7
- package/dist/lib/browser/chunk-EZRS3J25.mjs.map +0 -7
- package/dist/lib/browser/chunk-LMVTXH54.mjs +0 -154
- package/dist/lib/browser/chunk-LMVTXH54.mjs.map +0 -7
- package/dist/lib/browser/cli/index.mjs +0 -74
- package/dist/lib/browser/cli/index.mjs.map +0 -7
- package/dist/lib/browser/create-chat-LBZHGVSN.mjs +0 -82
- package/dist/lib/browser/create-chat-LBZHGVSN.mjs.map +0 -7
- package/dist/lib/browser/ensure-companion-chat-ZEZA34MZ.mjs.map +0 -7
- package/dist/lib/browser/index.mjs +0 -3446
- package/dist/lib/browser/index.mjs.map +0 -7
- package/dist/lib/browser/meta.json +0 -1
- package/dist/lib/browser/on-create-space-54RNX5JI.mjs.map +0 -7
- package/dist/lib/browser/operations/index.mjs +0 -13
- package/dist/lib/browser/operations/index.mjs.map +0 -7
- package/dist/lib/browser/resolve-navigation-targets-NZOD66NY.mjs.map +0 -7
- package/dist/lib/browser/run-prompt-in-new-chat-THLK5YQC.mjs.map +0 -7
- package/dist/lib/browser/set-current-chat-LRS3VFSH.mjs.map +0 -7
- package/dist/lib/browser/types/index.mjs +0 -20
- 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/blueprints/index.mjs +0 -9
- package/dist/lib/node-esm/chunk-HSLMI22Q.mjs +0 -11
- 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 +0 -177
- package/dist/lib/node-esm/chunk-PXAJSTGZ.mjs.map +0 -7
- package/dist/lib/node-esm/chunk-W3JZ2F4T.mjs +0 -155
- package/dist/lib/node-esm/chunk-W3JZ2F4T.mjs.map +0 -7
- package/dist/lib/node-esm/cli/index.mjs +0 -75
- package/dist/lib/node-esm/cli/index.mjs.map +0 -7
- package/dist/lib/node-esm/create-chat-3BEG4R6J.mjs +0 -83
- package/dist/lib/node-esm/create-chat-3BEG4R6J.mjs.map +0 -7
- package/dist/lib/node-esm/ensure-companion-chat-6K2WEWFP.mjs +0 -66
- package/dist/lib/node-esm/ensure-companion-chat-6K2WEWFP.mjs.map +0 -7
- package/dist/lib/node-esm/index.mjs +0 -3447
- package/dist/lib/node-esm/index.mjs.map +0 -7
- package/dist/lib/node-esm/meta.json +0 -1
- package/dist/lib/node-esm/on-create-space-YRPZ6HZY.mjs +0 -23
- package/dist/lib/node-esm/on-create-space-YRPZ6HZY.mjs.map +0 -7
- package/dist/lib/node-esm/operations/index.mjs +0 -14
- package/dist/lib/node-esm/operations/index.mjs.map +0 -7
- package/dist/lib/node-esm/resolve-navigation-targets-3PPK7XLH.mjs +0 -23
- package/dist/lib/node-esm/resolve-navigation-targets-3PPK7XLH.mjs.map +0 -7
- package/dist/lib/node-esm/run-prompt-in-new-chat-OUYKCMQ7.mjs +0 -137
- package/dist/lib/node-esm/run-prompt-in-new-chat-OUYKCMQ7.mjs.map +0 -7
- package/dist/lib/node-esm/set-current-chat-SMXZJD3F.mjs +0 -55
- package/dist/lib/node-esm/set-current-chat-SMXZJD3F.mjs.map +0 -7
- package/dist/lib/node-esm/types/index.mjs +0 -21
- package/dist/lib/node-esm/update-chat-name-HM2P4NSI.mjs +0 -72
- package/dist/lib/node-esm/update-chat-name-HM2P4NSI.mjs.map +0 -7
- package/dist/types/src/blueprints/assistant/blueprint.test.d.ts +0 -2
- package/dist/types/src/blueprints/assistant/blueprint.test.d.ts.map +0 -1
- package/dist/types/src/cli/index.d.ts +0 -2
- package/dist/types/src/cli/index.d.ts.map +0 -1
- package/dist/types/src/cli/plugin.d.ts +0 -10
- package/dist/types/src/cli/plugin.d.ts.map +0 -1
- 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 -15
- package/dist/types/src/components/ChatThread/widgets/PromptWidget.d.ts.map +0 -1
- package/dist/types/src/containers/AgentProperties/AgentProperties.stories.d.ts.map +0 -1
- package/dist/types/src/containers/ChatContainer/ChatContainer.d.ts.map +0 -1
- package/dist/types/src/containers/ChatContainer/index.d.ts +0 -2
- package/dist/types/src/containers/ChatContainer/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.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/containers/TracePanel/execution-graph.d.ts +0 -17
- package/dist/types/src/containers/TracePanel/execution-graph.d.ts.map +0 -1
- package/dist/types/src/operations/definitions.d.ts.map +0 -1
- package/dist/types/src/operations/prompt.test.d.ts +0 -2
- package/dist/types/src/operations/prompt.test.d.ts.map +0 -1
- package/dist/types/src/processor/processor.test.d.ts +0 -2
- package/dist/types/src/processor/processor.test.d.ts.map +0 -1
- package/dist/types/src/queue-logger.d.ts +0 -11
- package/dist/types/src/queue-logger.d.ts.map +0 -1
- package/dist/types/src/testing/trace-timeline.test.d.ts +0 -2
- package/dist/types/src/testing/trace-timeline.test.d.ts.map +0 -1
- package/dist/types/src/types/capabilities.d.ts +0 -32
- package/dist/types/src/types/capabilities.d.ts.map +0 -1
- package/dist/types/src/types/defs.d.ts +0 -2
- package/dist/types/src/types/defs.d.ts.map +0 -1
- package/dist/types/src/types/events.d.ts +0 -5
- package/dist/types/src/types/events.d.ts.map +0 -1
- package/src/AssistantPlugin.tsx +0 -238
- package/src/cli/plugin.ts +0 -84
- package/src/components/ChatProgress/ChatProgress.tsx +0 -56
- package/src/components/ChatProgress/index.ts +0 -5
- package/src/components/ChatThread/widgets/PromptWidget.ts +0 -30
- package/src/containers/AgentProperties/AgentProperties.stories.tsx +0 -100
- package/src/containers/ChatContainer/index.ts +0 -5
- package/src/containers/PromptArticle/PromptArticle.tsx +0 -59
- package/src/containers/PromptArticle/index.ts +0 -5
- package/src/containers/PromptList/index.ts +0 -5
- package/src/containers/TracePanel/execution-graph.ts +0 -452
- package/src/testing/trace-timeline.conversations.json +0 -1
- package/src/types/capabilities.ts +0 -35
- package/src/types/defs.ts +0 -5
- package/src/types/events.ts +0 -11
- /package/dist/lib/{browser/blueprints/index.mjs.map → neutral/AssistantPlugin.mjs.map} +0 -0
- /package/dist/lib/{browser/chunk-J5LGTIGS.mjs.map → neutral/ChatArticle-PWD4OEFZ.mjs.map} +0 -0
- /package/dist/lib/{browser/types → neutral/blueprints}/index.mjs.map +0 -0
- /package/dist/lib/{browser → neutral}/chunk-J5LGTIGS.mjs +0 -0
- /package/dist/lib/{node-esm/blueprints/index.mjs.map → neutral/chunk-J5LGTIGS.mjs.map} +0 -0
- /package/dist/lib/{node-esm/types → neutral}/index.mjs.map +0 -0
- /package/dist/lib/{node-esm/chunk-HSLMI22Q.mjs.map → neutral/meta.mjs.map} +0 -0
|
@@ -4,110 +4,210 @@
|
|
|
4
4
|
|
|
5
5
|
import { Atom } from '@effect-atom/atom';
|
|
6
6
|
import { useAtomValue } from '@effect-atom/atom-react';
|
|
7
|
+
import * as Data from 'effect/Data';
|
|
8
|
+
import * as Duration from 'effect/Duration';
|
|
7
9
|
import { pipe } from 'effect/Function';
|
|
8
|
-
import React, { useCallback, useMemo } from 'react';
|
|
10
|
+
import React, { useCallback, useDeferredValue, useMemo, useState } from 'react';
|
|
9
11
|
|
|
10
|
-
import {
|
|
12
|
+
import { Capabilities } from '@dxos/app-framework';
|
|
13
|
+
import { useCapability, useAtomCapability, useOperationInvoker } from '@dxos/app-framework/ui';
|
|
11
14
|
import { LayoutOperation } from '@dxos/app-toolkit';
|
|
12
15
|
import { type AppSurface } from '@dxos/app-toolkit/ui';
|
|
16
|
+
import { Process, Trace } from '@dxos/compute';
|
|
13
17
|
import { Filter, Query } from '@dxos/echo';
|
|
14
18
|
import { AtomQuery } from '@dxos/echo-atom';
|
|
15
|
-
import {
|
|
16
|
-
import {
|
|
17
|
-
import { DXN } from '@dxos/keys';
|
|
18
|
-
import { useComputeRuntimeService } from '@dxos/plugin-automation/hooks';
|
|
19
|
+
import { FeedTraceSink } from '@dxos/functions-runtime';
|
|
20
|
+
import { EID } from '@dxos/keys';
|
|
19
21
|
import { type Space } from '@dxos/react-client/echo';
|
|
20
|
-
import {
|
|
22
|
+
import { ScrollContainer } from '@dxos/react-ui';
|
|
23
|
+
import { composable, composableProps } from '@dxos/react-ui';
|
|
24
|
+
import { useAttentionAttributes } from '@dxos/react-ui-attention';
|
|
21
25
|
import { Timeline, type Commit } from '@dxos/react-ui-components';
|
|
22
|
-
import {
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
import {
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
export
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
26
|
+
import { Syntax } from '@dxos/react-ui-syntax-highlighter';
|
|
27
|
+
import { mx } from '@dxos/ui-theme';
|
|
28
|
+
|
|
29
|
+
import { ProcessTree, ProcessTreeProps } from '#components';
|
|
30
|
+
import { buildExecutionGraph, type ExecutionGraph } from '#execution-graph';
|
|
31
|
+
import { AssistantCapabilities } from '#types';
|
|
32
|
+
|
|
33
|
+
export type TracePanelProps = AppSurface.SpaceArticleProps<Pick<ProcessTreeProps, 'onProcessTerminate'>>;
|
|
34
|
+
|
|
35
|
+
export const TracePanel = composable<HTMLDivElement, TracePanelProps>(
|
|
36
|
+
({ space, attendableId, onProcessTerminate, ...props }, forwardedRef) => {
|
|
37
|
+
const attentionAttrs = useAttentionAttributes(attendableId);
|
|
38
|
+
const { invokePromise } = useOperationInvoker();
|
|
39
|
+
const settings = useAtomCapability(AssistantCapabilities.Settings);
|
|
40
|
+
const tracePanelDebug = settings.tracePanelDebug ?? false;
|
|
41
|
+
|
|
42
|
+
// `useDeferredValue` batches update bursts, works together with `React.memo`.
|
|
43
|
+
// See the comment in `ProcessTreeContainer` for more details.
|
|
44
|
+
const { branches, commits, spanTree, details } = useDeferredValue(useExecutionGraph(space));
|
|
45
|
+
|
|
46
|
+
const [selectedCommit, setSelectedCommit] = useState<Commit | undefined>();
|
|
47
|
+
const handleCommitSelect = useCallback(
|
|
48
|
+
(commit: Commit | undefined) => {
|
|
49
|
+
setSelectedCommit(commit);
|
|
50
|
+
if (commit?.link) {
|
|
51
|
+
const echoUri = EID.tryParse(commit.link);
|
|
52
|
+
const spaceId = echoUri ? EID.getSpaceId(echoUri) : undefined;
|
|
53
|
+
const objectId = echoUri ? EID.getEntityId(echoUri) : undefined;
|
|
54
|
+
if (spaceId && objectId) {
|
|
55
|
+
// TODO(dmaretskyi): Navigates, but fails to open.
|
|
56
|
+
void invokePromise(LayoutOperation.Open, {
|
|
57
|
+
subject: [`${spaceId}:${objectId}`],
|
|
58
|
+
});
|
|
59
|
+
}
|
|
42
60
|
}
|
|
43
|
-
}
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
);
|
|
61
|
+
},
|
|
62
|
+
[invokePromise, setSelectedCommit],
|
|
63
|
+
);
|
|
47
64
|
|
|
48
|
-
|
|
49
|
-
<
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
}
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
65
|
+
// Select current branch.
|
|
66
|
+
const [currentBranch, setCurrentBranch] = useState<string | null>(null);
|
|
67
|
+
const handleProcessSelect = useCallback(
|
|
68
|
+
(process: Process.Info) => {
|
|
69
|
+
const branch = branches.find((branch) => branch === process.pid.toString());
|
|
70
|
+
if (branch) {
|
|
71
|
+
setCurrentBranch(branch);
|
|
72
|
+
}
|
|
73
|
+
},
|
|
74
|
+
[branches],
|
|
75
|
+
);
|
|
76
|
+
|
|
77
|
+
return (
|
|
78
|
+
<div
|
|
79
|
+
{...composableProps(props, {
|
|
80
|
+
...attentionAttrs,
|
|
81
|
+
classNames: mx(
|
|
82
|
+
'h-full grid divide-y divide-separator',
|
|
83
|
+
!tracePanelDebug && selectedCommit
|
|
84
|
+
? 'grid-rows-[minmax(0,160px)_1fr_minmax(0,206px)]'
|
|
85
|
+
: 'grid-rows-[minmax(0,160px)_1fr]',
|
|
86
|
+
),
|
|
87
|
+
})}
|
|
88
|
+
ref={forwardedRef}
|
|
89
|
+
>
|
|
90
|
+
<ProcessTreeContainer onProcessSelect={handleProcessSelect} onProcessTerminate={onProcessTerminate} />
|
|
91
|
+
|
|
92
|
+
<ScrollContainer.Root pin>
|
|
93
|
+
<ScrollContainer.Content thin>
|
|
94
|
+
<ScrollContainer.Fade />
|
|
95
|
+
<ScrollContainer.Viewport>
|
|
96
|
+
{tracePanelDebug ? (
|
|
97
|
+
<Syntax.Root data={spanTree}>
|
|
98
|
+
<Syntax.Content>
|
|
99
|
+
<Syntax.Viewport>
|
|
100
|
+
<Syntax.Code className='text-xs' />
|
|
101
|
+
</Syntax.Viewport>
|
|
102
|
+
</Syntax.Content>
|
|
103
|
+
</Syntax.Root>
|
|
104
|
+
) : (
|
|
105
|
+
<Timeline
|
|
106
|
+
compact
|
|
107
|
+
commits={commits}
|
|
108
|
+
branches={branches}
|
|
109
|
+
currentBranch={currentBranch}
|
|
110
|
+
onSelect={handleCommitSelect}
|
|
111
|
+
/>
|
|
112
|
+
)}
|
|
113
|
+
</ScrollContainer.Viewport>
|
|
114
|
+
<ScrollContainer.ScrollDownButton />
|
|
115
|
+
</ScrollContainer.Content>
|
|
116
|
+
</ScrollContainer.Root>
|
|
117
|
+
|
|
118
|
+
{!tracePanelDebug && selectedCommit && (
|
|
119
|
+
<Syntax.Root data={details[selectedCommit.id] ?? selectedCommit}>
|
|
120
|
+
<Syntax.Content>
|
|
121
|
+
<Syntax.Viewport>
|
|
122
|
+
<Syntax.Code className='text-xs' />
|
|
123
|
+
</Syntax.Viewport>
|
|
124
|
+
</Syntax.Content>
|
|
125
|
+
</Syntax.Root>
|
|
126
|
+
)}
|
|
127
|
+
</div>
|
|
128
|
+
);
|
|
129
|
+
},
|
|
130
|
+
);
|
|
70
131
|
|
|
71
132
|
// Stable ref.
|
|
72
133
|
const atomEmpty = Atom.make(() => [] as const);
|
|
73
134
|
|
|
74
|
-
type ExecutionGraph = {
|
|
75
|
-
branches: string[];
|
|
76
|
-
commits: Commit[];
|
|
77
|
-
};
|
|
78
|
-
|
|
79
135
|
type UseExecutionGraphOptions = {
|
|
80
136
|
eventLimit?: number;
|
|
81
137
|
};
|
|
82
138
|
|
|
83
139
|
const useExecutionGraph = (space: Space, { eventLimit }: UseExecutionGraphOptions = {}): ExecutionGraph => {
|
|
84
|
-
const
|
|
140
|
+
const monitor = useCapability(Capabilities.ProcessMonitor);
|
|
141
|
+
const processesAtom = monitor?.processTreeAtom ?? atomEmpty;
|
|
142
|
+
|
|
143
|
+
const atom = useMemo(
|
|
144
|
+
() => getExecutionGraph(space, processesAtom, { eventLimit }),
|
|
145
|
+
[space, processesAtom, eventLimit],
|
|
146
|
+
);
|
|
147
|
+
|
|
85
148
|
return useAtomValue(atom);
|
|
86
149
|
};
|
|
87
150
|
|
|
88
151
|
const getExecutionGraph = (
|
|
89
152
|
space: Space,
|
|
153
|
+
processesAtom: Atom.Atom<readonly Process.Info[]>,
|
|
90
154
|
{ eventLimit = 100 }: UseExecutionGraphOptions = {},
|
|
91
155
|
): Atom.Atom<ExecutionGraph> => {
|
|
92
|
-
|
|
156
|
+
const traceMessages = pipe(
|
|
93
157
|
AtomQuery.make(space.db, FeedTraceSink.query),
|
|
94
|
-
Atom.map((feeds) =>
|
|
158
|
+
Atom.map((feeds) =>
|
|
95
159
|
// TODO(dmaretskyi): This should be possible in a single query with properly working limit(1) and feed > feed contents traversal.
|
|
96
|
-
|
|
160
|
+
AtomQuery.make(
|
|
97
161
|
space.db,
|
|
98
162
|
feeds.length > 0
|
|
99
163
|
? Query.type(Trace.Message).from(feeds[0])
|
|
100
164
|
: (Query.select(Filter.nothing()) as Query.Query<never>),
|
|
101
|
-
);
|
|
102
|
-
}),
|
|
103
|
-
(_) => Atom.make((get) => get(get(_))),
|
|
104
|
-
(_) =>
|
|
105
|
-
Atom.make((get) =>
|
|
106
|
-
buildExecutionGraph({
|
|
107
|
-
traceMessages: [...get(_)],
|
|
108
|
-
activeProcesses: [],
|
|
109
|
-
eventLimit,
|
|
110
|
-
}),
|
|
111
165
|
),
|
|
166
|
+
),
|
|
167
|
+
(atom) => Atom.make((get) => get(get(atom))),
|
|
168
|
+
);
|
|
169
|
+
|
|
170
|
+
const activeProcesses = pipe(
|
|
171
|
+
processesAtom,
|
|
172
|
+
Atom.debounce(Duration.millis(100)),
|
|
173
|
+
Atom.map((processes) =>
|
|
174
|
+
// `Data.array` does structural comparison on the array elements.
|
|
175
|
+
Data.array(
|
|
176
|
+
processes
|
|
177
|
+
.filter((process) => process.state === Process.State.RUNNING || process.state === Process.State.HYBERNATING)
|
|
178
|
+
.map(Data.struct),
|
|
179
|
+
),
|
|
180
|
+
),
|
|
181
|
+
);
|
|
182
|
+
|
|
183
|
+
return Atom.make((get) =>
|
|
184
|
+
buildExecutionGraph({
|
|
185
|
+
traceMessages: get(traceMessages),
|
|
186
|
+
activeProcesses: get(activeProcesses),
|
|
187
|
+
eventLimit,
|
|
188
|
+
}),
|
|
189
|
+
);
|
|
190
|
+
};
|
|
191
|
+
TracePanel.displayName = 'TracePanel';
|
|
192
|
+
|
|
193
|
+
// Isolate `ProcessTree` updates from the rest of the panel.
|
|
194
|
+
// TODO(dmaretskyi): Currently not useful since `useExecutionGraph` also pulls in the updates.
|
|
195
|
+
const ProcessTreeContainer = ({
|
|
196
|
+
onProcessSelect,
|
|
197
|
+
onProcessTerminate,
|
|
198
|
+
}: Pick<ProcessTreeProps, 'onProcessSelect' | 'onProcessTerminate'>) => {
|
|
199
|
+
const monitor = useCapability(Capabilities.ProcessMonitor);
|
|
200
|
+
const processes = useAtomValue(monitor?.processTreeAtom ?? atomEmpty);
|
|
201
|
+
|
|
202
|
+
// `processes` updates in bursts (about 14 updates per navigation).
|
|
203
|
+
// `useDeferredValue` will debounce update propagation, returning stale value for short periods.
|
|
204
|
+
// NOTE: `ProcessTree` MUST use `React.memo`, otherwise this will not work.
|
|
205
|
+
const processesDeferred = useDeferredValue(processes);
|
|
206
|
+
return (
|
|
207
|
+
<ProcessTree
|
|
208
|
+
processes={processesDeferred}
|
|
209
|
+
onProcessSelect={onProcessSelect}
|
|
210
|
+
onProcessTerminate={onProcessTerminate}
|
|
211
|
+
/>
|
|
112
212
|
);
|
|
113
213
|
};
|
|
@@ -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
|
});
|
|
@@ -2,7 +2,7 @@
|
|
|
2
2
|
// Copyright 2025 DXOS.org
|
|
3
3
|
//
|
|
4
4
|
|
|
5
|
-
import {
|
|
5
|
+
import { URI } from '@dxos/keys';
|
|
6
6
|
|
|
7
7
|
/**
|
|
8
8
|
* Patterns for extracting DXN references from tool call params/results.
|
|
@@ -28,8 +28,8 @@ 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
|
|
32
|
-
const dxns:
|
|
31
|
+
export const extractDxnFromString = (text: string): URI.URI[] => {
|
|
32
|
+
const dxns: URI.URI[] = [];
|
|
33
33
|
const seen = new Set<string>();
|
|
34
34
|
|
|
35
35
|
// Match @dxn: prefixed references.
|
|
@@ -37,11 +37,8 @@ export const extractDxnsFromString = (text: string): DXN[] => {
|
|
|
37
37
|
while ((match = AT_DXN_PATTERN.exec(text)) !== null) {
|
|
38
38
|
const dxnStr = match[1];
|
|
39
39
|
if (!seen.has(dxnStr)) {
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
dxns.push(dxn);
|
|
43
|
-
seen.add(dxnStr);
|
|
44
|
-
}
|
|
40
|
+
dxns.push(URI.make(dxnStr));
|
|
41
|
+
seen.add(dxnStr);
|
|
45
42
|
}
|
|
46
43
|
}
|
|
47
44
|
|
|
@@ -49,11 +46,8 @@ export const extractDxnsFromString = (text: string): DXN[] => {
|
|
|
49
46
|
while ((match = DXN_PATTERN.exec(text)) !== null) {
|
|
50
47
|
const dxnStr = match[0];
|
|
51
48
|
if (!seen.has(dxnStr)) {
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
dxns.push(dxn);
|
|
55
|
-
seen.add(dxnStr);
|
|
56
|
-
}
|
|
49
|
+
dxns.push(URI.make(dxnStr));
|
|
50
|
+
seen.add(dxnStr);
|
|
57
51
|
}
|
|
58
52
|
}
|
|
59
53
|
|
|
@@ -64,17 +58,14 @@ export const extractDxnsFromString = (text: string): DXN[] => {
|
|
|
64
58
|
* Extracts DXN references from a JSON object.
|
|
65
59
|
* Handles IPLD-style references `{ "/": "dxn:..." }` and `{ "@dxn": "dxn:..." }`.
|
|
66
60
|
*/
|
|
67
|
-
export const extractDxnsFromObject = (obj: unknown):
|
|
68
|
-
const dxns:
|
|
61
|
+
export const extractDxnsFromObject = (obj: unknown): URI.URI[] => {
|
|
62
|
+
const dxns: URI.URI[] = [];
|
|
69
63
|
const seen = new Set<string>();
|
|
70
64
|
|
|
71
65
|
const addDxn = (dxnStr: string) => {
|
|
72
66
|
if (!seen.has(dxnStr)) {
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
dxns.push(dxn);
|
|
76
|
-
seen.add(dxnStr);
|
|
77
|
-
}
|
|
67
|
+
dxns.push(URI.make(dxnStr));
|
|
68
|
+
seen.add(dxnStr);
|
|
78
69
|
}
|
|
79
70
|
};
|
|
80
71
|
|
|
@@ -91,9 +82,9 @@ export const extractDxnsFromObject = (obj: unknown): DXN[] => {
|
|
|
91
82
|
addDxn(value.slice(1));
|
|
92
83
|
}
|
|
93
84
|
// Also extract DXNs from within the string.
|
|
94
|
-
const extracted =
|
|
85
|
+
const extracted = extractDxnFromString(value);
|
|
95
86
|
for (const dxn of extracted) {
|
|
96
|
-
addDxn(dxn
|
|
87
|
+
addDxn(dxn);
|
|
97
88
|
}
|
|
98
89
|
return;
|
|
99
90
|
}
|
|
@@ -116,19 +107,18 @@ export const extractDxnsFromObject = (obj: unknown): DXN[] => {
|
|
|
116
107
|
}
|
|
117
108
|
}
|
|
118
109
|
|
|
119
|
-
// Check for @dxn key: { "@dxn": "dxn
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
addDxn(dxnStr);
|
|
124
|
-
}
|
|
110
|
+
// Check for @uri key (new) or @dxn key (legacy): { "@uri": "echo://…" } / { "@dxn": "dxn:…" }
|
|
111
|
+
const selfUri = (record as any)['@uri'] ?? (record as any)['@dxn'];
|
|
112
|
+
if (typeof selfUri === 'string' && (selfUri.startsWith('dxn:') || selfUri.startsWith('echo:'))) {
|
|
113
|
+
addDxn(selfUri);
|
|
125
114
|
}
|
|
126
115
|
|
|
127
|
-
// Check for reference blocks: { _tag: 'reference', reference: {
|
|
116
|
+
// Check for reference blocks: { _tag: 'reference', reference: { uri: ... } } (or legacy { dxn: ... })
|
|
128
117
|
if (record._tag === 'reference' && record.reference && typeof record.reference === 'object') {
|
|
129
118
|
const ref = record.reference as Record<string, unknown>;
|
|
130
|
-
|
|
131
|
-
|
|
119
|
+
const refUri = ref.uri ?? ref.dxn;
|
|
120
|
+
if (refUri && typeof refUri === 'string') {
|
|
121
|
+
addDxn(refUri);
|
|
132
122
|
}
|
|
133
123
|
}
|
|
134
124
|
|
|
@@ -146,14 +136,14 @@ export const extractDxnsFromObject = (obj: unknown): DXN[] => {
|
|
|
146
136
|
/**
|
|
147
137
|
* Extracts the first DXN from a tool call input string (JSON).
|
|
148
138
|
*/
|
|
149
|
-
export const extractFirstDxnFromToolInput = (input: string):
|
|
139
|
+
export const extractFirstDxnFromToolInput = (input: string): URI.URI | undefined => {
|
|
150
140
|
try {
|
|
151
141
|
const parsed = JSON.parse(input);
|
|
152
142
|
const dxns = extractDxnsFromObject(parsed);
|
|
153
143
|
return dxns[0];
|
|
154
144
|
} catch {
|
|
155
145
|
// If JSON parsing fails, try to extract from the raw string.
|
|
156
|
-
const dxns =
|
|
146
|
+
const dxns = extractDxnFromString(input);
|
|
157
147
|
return dxns[0];
|
|
158
148
|
}
|
|
159
149
|
};
|
|
@@ -161,7 +151,7 @@ export const extractFirstDxnFromToolInput = (input: string): DXN | undefined =>
|
|
|
161
151
|
/**
|
|
162
152
|
* Extracts the first DXN from a tool result string (JSON).
|
|
163
153
|
*/
|
|
164
|
-
export const extractFirstDxnFromToolResult = (result: string | undefined):
|
|
154
|
+
export const extractFirstDxnFromToolResult = (result: string | undefined): URI.URI | undefined => {
|
|
165
155
|
if (!result) {
|
|
166
156
|
return undefined;
|
|
167
157
|
}
|
|
@@ -172,7 +162,7 @@ export const extractFirstDxnFromToolResult = (result: string | undefined): DXN |
|
|
|
172
162
|
return dxns[0];
|
|
173
163
|
} catch {
|
|
174
164
|
// If JSON parsing fails, try to extract from the raw string.
|
|
175
|
-
const dxns =
|
|
165
|
+
const dxns = extractDxnFromString(result);
|
|
176
166
|
return dxns[0];
|
|
177
167
|
}
|
|
178
168
|
};
|
|
@@ -0,0 +1,114 @@
|
|
|
1
|
+
//
|
|
2
|
+
// Copyright 2026 DXOS.org
|
|
3
|
+
//
|
|
4
|
+
|
|
5
|
+
import * as Effect from 'effect/Effect';
|
|
6
|
+
import * as Schema from 'effect/Schema';
|
|
7
|
+
|
|
8
|
+
import { AgentRequestBegin, AgentRequestEnd, CompleteBlock } from '@dxos/assistant';
|
|
9
|
+
import { Process, Trace } from '@dxos/compute';
|
|
10
|
+
import { EntityId } from '@dxos/keys';
|
|
11
|
+
|
|
12
|
+
export interface AgentScenario {
|
|
13
|
+
readonly prompt: string;
|
|
14
|
+
readonly tools: readonly string[];
|
|
15
|
+
}
|
|
16
|
+
|
|
17
|
+
/** Probability that any given run aborts with a simulated tool failure. */
|
|
18
|
+
const FAILURE_PROBABILITY = 0.1;
|
|
19
|
+
|
|
20
|
+
export const agentScenarios: readonly AgentScenario[] = [
|
|
21
|
+
{
|
|
22
|
+
prompt: 'Create an organization called "Cyberdyne Systems"',
|
|
23
|
+
tools: ['list-schemas', 'create-object'],
|
|
24
|
+
},
|
|
25
|
+
{
|
|
26
|
+
prompt: 'Search for all organizations and persons',
|
|
27
|
+
tools: ['list-schemas', 'query', 'query'],
|
|
28
|
+
},
|
|
29
|
+
{
|
|
30
|
+
prompt: 'Create a person named "John Connor"',
|
|
31
|
+
tools: ['create-object'],
|
|
32
|
+
},
|
|
33
|
+
];
|
|
34
|
+
|
|
35
|
+
const delay = (ms: number) => Effect.promise(() => new Promise<void>((resolve) => setTimeout(resolve, ms)));
|
|
36
|
+
|
|
37
|
+
/**
|
|
38
|
+
* Write a trace event and yield to the event loop so FeedTraceSink flushes it to ECHO before continuing.
|
|
39
|
+
*/
|
|
40
|
+
const writeAndFlush = <T>(eventType: Trace.EventType<T>, payload: T) =>
|
|
41
|
+
Effect.gen(function* () {
|
|
42
|
+
yield* Trace.write(eventType, payload);
|
|
43
|
+
yield* Effect.promise(() => new Promise((resolve) => setTimeout(resolve, 100)));
|
|
44
|
+
});
|
|
45
|
+
|
|
46
|
+
/**
|
|
47
|
+
* Storybook fixture: a {@link Process} that emits a deterministic stream of agent trace events
|
|
48
|
+
* (request begin/end, user message, sequential tool calls with simulated latency).
|
|
49
|
+
*
|
|
50
|
+
* Input is a scenario index into {@link agentScenarios} (modulo the array length).
|
|
51
|
+
*/
|
|
52
|
+
export const SimulatedAgent = Process.make(
|
|
53
|
+
{
|
|
54
|
+
key: 'org.dxos.testing.process.agent',
|
|
55
|
+
input: Schema.Number,
|
|
56
|
+
output: Schema.Void,
|
|
57
|
+
services: [Trace.TraceService],
|
|
58
|
+
},
|
|
59
|
+
(ctx) =>
|
|
60
|
+
Effect.succeed({
|
|
61
|
+
onInput: (index: number) =>
|
|
62
|
+
Effect.gen(function* () {
|
|
63
|
+
const messageId = EntityId.random();
|
|
64
|
+
const scenario = agentScenarios[index % agentScenarios.length];
|
|
65
|
+
|
|
66
|
+
// Decide upfront whether this run will fail (and at which tool) so the trace shows a partial sequence.
|
|
67
|
+
const failAtToolIndex =
|
|
68
|
+
Math.random() < FAILURE_PROBABILITY ? Math.floor(Math.random() * scenario.tools.length) : -1;
|
|
69
|
+
|
|
70
|
+
// Agent begins processing.
|
|
71
|
+
yield* writeAndFlush(AgentRequestBegin, {});
|
|
72
|
+
|
|
73
|
+
// User message.
|
|
74
|
+
yield* writeAndFlush(CompleteBlock, {
|
|
75
|
+
messageId,
|
|
76
|
+
role: 'user',
|
|
77
|
+
block: { _tag: 'text', text: scenario.prompt },
|
|
78
|
+
});
|
|
79
|
+
|
|
80
|
+
// Simulate tool calls sequentially with delays.
|
|
81
|
+
for (const [index, toolName] of scenario.tools.entries()) {
|
|
82
|
+
const toolCallId = EntityId.random();
|
|
83
|
+
|
|
84
|
+
// Tool call event.
|
|
85
|
+
yield* writeAndFlush(CompleteBlock, {
|
|
86
|
+
messageId,
|
|
87
|
+
role: 'assistant',
|
|
88
|
+
block: { _tag: 'toolCall', toolCallId, name: toolName, input: '{}', providerExecuted: false },
|
|
89
|
+
});
|
|
90
|
+
|
|
91
|
+
// Simulate tool execution time.
|
|
92
|
+
yield* delay(1_000 + Math.random() * 3_000);
|
|
93
|
+
|
|
94
|
+
if (index === failAtToolIndex) {
|
|
95
|
+
ctx.fail(new Error(`Simulated failure in tool '${toolName}'`));
|
|
96
|
+
return;
|
|
97
|
+
}
|
|
98
|
+
|
|
99
|
+
// Tool result event.
|
|
100
|
+
yield* writeAndFlush(CompleteBlock, {
|
|
101
|
+
messageId,
|
|
102
|
+
role: 'assistant',
|
|
103
|
+
block: { _tag: 'toolResult', toolCallId, name: toolName, providerExecuted: false },
|
|
104
|
+
});
|
|
105
|
+
}
|
|
106
|
+
|
|
107
|
+
// Agent completes.
|
|
108
|
+
yield* writeAndFlush(AgentRequestEnd, {});
|
|
109
|
+
ctx.succeed();
|
|
110
|
+
}).pipe(Effect.orDie),
|
|
111
|
+
onAlarm: () => Effect.void,
|
|
112
|
+
onChildEvent: () => Effect.void,
|
|
113
|
+
}),
|
|
114
|
+
);
|
|
@@ -0,0 +1,45 @@
|
|
|
1
|
+
//
|
|
2
|
+
// Copyright 2026 DXOS.org
|
|
3
|
+
//
|
|
4
|
+
|
|
5
|
+
import { type Dispatch, type SetStateAction, useEffect, useRef, useState } from 'react';
|
|
6
|
+
|
|
7
|
+
/**
|
|
8
|
+
* Interval (ms) between auto-played trace messages in the snapshot playback story.
|
|
9
|
+
*/
|
|
10
|
+
export const PLAYBACK_INTERVAL_MS = 250;
|
|
11
|
+
|
|
12
|
+
export const STEP_STORAGE_KEY = 'plugin-assistant.trace-panel.snapshot.step';
|
|
13
|
+
|
|
14
|
+
/**
|
|
15
|
+
* `useState<number>` that hydrates from and persists to `localStorage`.
|
|
16
|
+
* The third tuple member is `true` iff a valid value was loaded on first render.
|
|
17
|
+
*/
|
|
18
|
+
export const useLocalStorageNumber = (
|
|
19
|
+
key: string,
|
|
20
|
+
initial: number,
|
|
21
|
+
): [number, Dispatch<SetStateAction<number>>, boolean] => {
|
|
22
|
+
const initRef = useRef<{ value: number; hydrated: boolean } | null>(null);
|
|
23
|
+
if (initRef.current === null) {
|
|
24
|
+
let value = initial;
|
|
25
|
+
let hydrated = false;
|
|
26
|
+
if (typeof window !== 'undefined') {
|
|
27
|
+
const stored = window.localStorage.getItem(key);
|
|
28
|
+
const parsed = stored === null ? Number.NaN : Number(stored);
|
|
29
|
+
if (Number.isInteger(parsed) && parsed >= 0) {
|
|
30
|
+
value = parsed;
|
|
31
|
+
hydrated = true;
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
initRef.current = { value, hydrated };
|
|
35
|
+
}
|
|
36
|
+
|
|
37
|
+
const [value, setValue] = useState(initRef.current.value);
|
|
38
|
+
useEffect(() => {
|
|
39
|
+
if (typeof window !== 'undefined') {
|
|
40
|
+
window.localStorage.setItem(key, String(value));
|
|
41
|
+
}
|
|
42
|
+
}, [key, value]);
|
|
43
|
+
|
|
44
|
+
return [value, setValue, initRef.current.hydrated];
|
|
45
|
+
};
|
|
@@ -7,7 +7,7 @@ import React, { useMemo } from 'react';
|
|
|
7
7
|
import { AppSurface } from '@dxos/app-toolkit/ui';
|
|
8
8
|
import { type InvocationsState } from '@dxos/functions-runtime';
|
|
9
9
|
import { useTriggerRuntimeControls } from '@dxos/plugin-automation/hooks';
|
|
10
|
-
import { StatusBar } from '@dxos/plugin-status-bar';
|
|
10
|
+
import { StatusBar } from '@dxos/plugin-status-bar/components';
|
|
11
11
|
import { useObject } from '@dxos/react-client/echo';
|
|
12
12
|
import { IconButton, Popover, useTranslation } from '@dxos/react-ui';
|
|
13
13
|
|
|
@@ -80,6 +80,7 @@ export const SpaceStatus = ({ space }: SpaceStatusProps) => {
|
|
|
80
80
|
<Popover.Trigger asChild>
|
|
81
81
|
<StatusBar.Item>
|
|
82
82
|
<IconButton
|
|
83
|
+
variant='ghost'
|
|
83
84
|
icon={getIcon(triggerState)}
|
|
84
85
|
iconOnly
|
|
85
86
|
label={t(`trigger-status-${triggerState}.label`)}
|