@dxos/plugin-assistant 0.8.4-main.74a063c4e0 → 0.8.4-main.765dc60934
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/README.md +1 -1
- package/dist/lib/neutral/AgentArticle-5XDDEXMP.mjs +169 -0
- package/dist/lib/neutral/AgentArticle-5XDDEXMP.mjs.map +7 -0
- package/dist/lib/neutral/AgentProperties-CNH4JMDZ.mjs +100 -0
- package/dist/lib/neutral/AgentProperties-CNH4JMDZ.mjs.map +7 -0
- package/dist/lib/neutral/AssistantPlugin.mjs +10 -0
- package/dist/lib/neutral/AssistantPlugin.node.mjs +46 -0
- package/dist/lib/neutral/AssistantPlugin.node.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-U7LUBFOS.mjs +27 -0
- package/dist/lib/neutral/BlueprintArticle-U7LUBFOS.mjs.map +7 -0
- package/dist/lib/neutral/ChatArticle-WVAFZPVI.mjs +8 -0
- package/dist/lib/neutral/ChatCompanion-DFRMRUK3.mjs +133 -0
- package/dist/lib/neutral/ChatCompanion-DFRMRUK3.mjs.map +7 -0
- package/dist/lib/neutral/ChatDialog-QKZLG7SQ.mjs +72 -0
- package/dist/lib/neutral/ChatDialog-QKZLG7SQ.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-H7ECM7AH.mjs +116 -0
- package/dist/lib/neutral/RoutineArticle-H7ECM7AH.mjs.map +7 -0
- package/dist/lib/neutral/RoutineList-CLDXGQUD.mjs +48 -0
- package/dist/lib/neutral/RoutineList-CLDXGQUD.mjs.map +7 -0
- package/dist/lib/neutral/TracePanel-HYVPDIAA.mjs +565 -0
- package/dist/lib/neutral/TracePanel-HYVPDIAA.mjs.map +7 -0
- package/dist/lib/neutral/TriggerStatus-WTFYUIG5.mjs +92 -0
- package/dist/lib/neutral/TriggerStatus-WTFYUIG5.mjs.map +7 -0
- package/dist/lib/neutral/ai-service-GJXMI5OI.mjs +22 -0
- package/dist/lib/neutral/ai-service-GJXMI5OI.mjs.map +7 -0
- package/dist/lib/neutral/app-graph-builder-QNKVSPPG.mjs +187 -0
- package/dist/lib/neutral/app-graph-builder-QNKVSPPG.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 +35 -0
- package/dist/lib/neutral/capabilities/index.mjs.map +7 -0
- package/dist/lib/neutral/chunk-4CQZCMRP.mjs +25 -0
- package/dist/lib/neutral/chunk-4CQZCMRP.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-CU5S7SGF.mjs +8 -0
- package/dist/lib/neutral/chunk-CU5S7SGF.mjs.map +7 -0
- package/dist/lib/neutral/chunk-ITJX2YZZ.mjs +98 -0
- package/dist/lib/neutral/chunk-ITJX2YZZ.mjs.map +7 -0
- package/dist/lib/neutral/chunk-SLIPV6NN.mjs +106 -0
- package/dist/lib/neutral/chunk-SLIPV6NN.mjs.map +7 -0
- package/dist/lib/neutral/chunk-VHPTYKYD.mjs +361 -0
- package/dist/lib/neutral/chunk-VHPTYKYD.mjs.map +7 -0
- package/dist/lib/neutral/companion-chat-provisioner-2Y6PRSDK.mjs +116 -0
- package/dist/lib/neutral/companion-chat-provisioner-2Y6PRSDK.mjs.map +7 -0
- package/dist/lib/neutral/components/index.mjs +2298 -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/{browser/create-chat-DF5TG5XC.mjs → neutral/create-chat-QQZURUBW.mjs} +16 -27
- package/dist/lib/neutral/create-chat-QQZURUBW.mjs.map +7 -0
- package/dist/lib/neutral/create-object-UZCJCPWM.mjs +93 -0
- package/dist/lib/neutral/create-object-UZCJCPWM.mjs.map +7 -0
- package/dist/lib/neutral/edge-model-resolver-XDNBZ3US.mjs +21 -0
- package/dist/lib/neutral/edge-model-resolver-XDNBZ3US.mjs.map +7 -0
- package/dist/lib/{browser/ensure-companion-chat-FR4AWZ2P.mjs → neutral/ensure-companion-chat-5S4LZM2H.mjs} +10 -17
- package/dist/lib/neutral/ensure-companion-chat-5S4LZM2H.mjs.map +7 -0
- package/dist/lib/neutral/hooks/index.mjs +927 -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-T4R65UJU.mjs +174 -0
- package/dist/lib/neutral/react-surface-T4R65UJU.mjs.map +7 -0
- package/dist/lib/{browser/resolve-navigation-targets-NZOD66NY.mjs → neutral/resolve-navigation-targets-VXBSWV5L.mjs} +4 -6
- package/dist/lib/neutral/resolve-navigation-targets-VXBSWV5L.mjs.map +7 -0
- package/dist/lib/{browser/run-prompt-in-new-chat-4YQ37XIS.mjs → neutral/run-prompt-in-new-chat-VJXXZ6SI.mjs} +18 -51
- package/dist/lib/neutral/run-prompt-in-new-chat-VJXXZ6SI.mjs.map +7 -0
- package/dist/lib/{browser/set-current-chat-WJI3WAVM.mjs → neutral/set-current-chat-ZFDCYK5I.mjs} +5 -11
- package/dist/lib/neutral/set-current-chat-ZFDCYK5I.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/toolkit-GVWXPDLJ.mjs +14 -0
- package/dist/lib/neutral/toolkit-GVWXPDLJ.mjs.map +7 -0
- package/dist/lib/neutral/translations.mjs +174 -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 +1 -0
- package/dist/types/src/AssistantPlugin.d.ts.map +1 -1
- package/dist/types/src/AssistantPlugin.node.d.ts +4 -0
- package/dist/types/src/AssistantPlugin.node.d.ts.map +1 -0
- package/dist/types/src/AssistantPlugin.test.d.ts +2 -0
- package/dist/types/src/AssistantPlugin.test.d.ts.map +1 -0
- package/dist/types/src/blueprints/assistant/blueprint.d.ts +2 -2
- package/dist/types/src/blueprints/assistant/blueprint.d.ts.map +1 -1
- package/dist/types/src/capabilities/ai-service.d.ts.map +1 -1
- package/dist/types/src/capabilities/app-graph-builder.d.ts.map +1 -1
- package/dist/types/src/capabilities/blueprint-definition.d.ts.map +1 -1
- package/dist/types/src/capabilities/companion-chat-provisioner.d.ts.map +1 -1
- package/dist/types/src/capabilities/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.map +1 -1
- package/dist/types/src/capabilities/index.d.ts +30 -16
- package/dist/types/src/capabilities/index.d.ts.map +1 -1
- package/dist/types/src/capabilities/local-model-resolver.d.ts +6 -3
- package/dist/types/src/capabilities/local-model-resolver.d.ts.map +1 -1
- package/dist/types/src/capabilities/markdown.d.ts.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 +1 -13
- package/dist/types/src/capabilities/settings.d.ts.map +1 -1
- package/dist/types/src/capabilities/state.d.ts.map +1 -1
- package/dist/types/src/capabilities/toolkit.d.ts.map +1 -1
- package/dist/types/src/components/AssistantSettings/AssistantSettings.d.ts +1 -1
- package/dist/types/src/components/AssistantSettings/AssistantSettings.d.ts.map +1 -1
- package/dist/types/src/components/AssistantSettings/AssistantSettings.stories.d.ts +1 -503
- package/dist/types/src/components/AssistantSettings/AssistantSettings.stories.d.ts.map +1 -1
- package/dist/types/src/components/Chat/Chat.d.ts +38 -50
- 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 -4
- package/dist/types/src/components/ChatPrompt/ChatOptions.d.ts.map +1 -1
- package/dist/types/src/components/ChatPrompt/ChatOptions.stories.d.ts +19 -0
- package/dist/types/src/components/ChatPrompt/ChatOptions.stories.d.ts.map +1 -0
- package/dist/types/src/components/ChatPrompt/ChatPresets.d.ts.map +1 -1
- package/dist/types/src/components/ChatPrompt/ChatPrompt.d.ts +28 -0
- package/dist/types/src/components/ChatPrompt/ChatPrompt.d.ts.map +1 -0
- package/dist/types/src/components/ChatPrompt/ChatReferences.d.ts +2 -2
- package/dist/types/src/components/ChatPrompt/ChatReferences.d.ts.map +1 -1
- package/dist/types/src/components/ChatPrompt/ChatStatus.d.ts +20 -0
- package/dist/types/src/components/ChatPrompt/ChatStatus.d.ts.map +1 -0
- package/dist/types/src/components/ChatPrompt/ChatStatusIndicator.d.ts.map +1 -1
- package/dist/types/src/components/ChatPrompt/index.d.ts +3 -0
- package/dist/types/src/components/ChatPrompt/index.d.ts.map +1 -1
- package/dist/types/src/components/ChatThread/Anchor.stories.d.ts +14 -0
- package/dist/types/src/components/ChatThread/Anchor.stories.d.ts.map +1 -0
- package/dist/types/src/components/ChatThread/ChatThread.d.ts +6 -3
- package/dist/types/src/components/ChatThread/ChatThread.d.ts.map +1 -1
- package/dist/types/src/components/ChatThread/ChatThread.stories.d.ts +7 -509
- package/dist/types/src/components/ChatThread/ChatThread.stories.d.ts.map +1 -1
- package/dist/types/src/components/ChatThread/Link.d.ts.map +1 -1
- package/dist/types/src/components/ChatThread/MarkdownStream.stories.d.ts +42 -0
- package/dist/types/src/components/ChatThread/MarkdownStream.stories.d.ts.map +1 -0
- package/dist/types/src/components/ChatThread/registry.d.ts +18 -0
- package/dist/types/src/components/ChatThread/registry.d.ts.map +1 -1
- package/dist/types/src/components/ChatThread/sync.d.ts +40 -13
- 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 +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 +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.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 +12 -0
- package/dist/types/src/components/ChatThread/widgets/StatusWidget.d.ts.map +1 -0
- package/dist/types/src/components/ChatThread/widgets/SuggestionWidget.d.ts.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 +15 -0
- package/dist/types/src/components/ChatThread/widgets/ToolWidget.stories.d.ts.map +1 -0
- package/dist/types/src/components/ChatThread/widgets/defaults.d.ts +5 -0
- package/dist/types/src/components/ChatThread/widgets/defaults.d.ts.map +1 -0
- package/dist/types/src/components/ChatThread/widgets/index.d.ts +1 -1
- package/dist/types/src/components/ChatThread/widgets/index.d.ts.map +1 -1
- package/dist/types/src/components/ProcessTree/ProcessTree.d.ts +2 -5
- 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/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 +2 -6
- package/dist/types/src/components/TemplateEditor/TemplateEditor.d.ts.map +1 -1
- package/dist/types/src/components/TemplateEditor/TemplateEditor.stories.d.ts +1 -503
- package/dist/types/src/components/TemplateEditor/TemplateEditor.stories.d.ts.map +1 -1
- package/dist/types/src/components/TemplateEditor/TemplateForm.d.ts +4 -5
- package/dist/types/src/components/TemplateEditor/TemplateForm.d.ts.map +1 -1
- package/dist/types/src/components/TemplateEditor/TemplateForm.stories.d.ts +2 -504
- 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 -7
- package/dist/types/src/components/Toolbox/Toolbox.d.ts.map +1 -1
- package/dist/types/src/components/Toolbox/Toolbox.stories.d.ts +1 -503
- package/dist/types/src/components/Toolbox/Toolbox.stories.d.ts.map +1 -1
- package/dist/types/src/components/index.d.ts +1 -0
- package/dist/types/src/components/index.d.ts.map +1 -1
- package/dist/types/src/containers/AgentArticle/AgentArticle.d.ts +6 -0
- package/dist/types/src/containers/AgentArticle/AgentArticle.d.ts.map +1 -0
- package/dist/types/src/containers/AgentArticle/AgentArticle.stories.d.ts +21 -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 +16 -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/{ProjectSettings → AgentProperties}/index.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/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 +1 -1
- 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/{ProjectArticle → RoutineArticle}/index.d.ts.map +1 -1
- package/dist/types/src/containers/RoutineList/RoutineList.d.ts +6 -0
- package/dist/types/src/containers/RoutineList/RoutineList.d.ts.map +1 -0
- package/dist/types/src/containers/RoutineList/RoutineList.stories.d.ts +21 -0
- package/dist/types/src/containers/RoutineList/RoutineList.stories.d.ts.map +1 -0
- package/dist/types/src/containers/RoutineList/index.d.ts +2 -0
- package/dist/types/src/containers/RoutineList/index.d.ts.map +1 -0
- package/dist/types/src/containers/TracePanel/TracePanel.d.ts +6 -4
- package/dist/types/src/containers/TracePanel/TracePanel.d.ts.map +1 -1
- package/dist/types/src/containers/TracePanel/TracePanel.stories.d.ts +13 -0
- package/dist/types/src/containers/TracePanel/TracePanel.stories.d.ts.map +1 -0
- package/dist/types/src/containers/TracePanel/dxn-extractor.d.ts +1 -1
- package/dist/types/src/containers/TracePanel/dxn-extractor.d.ts.map +1 -1
- package/dist/types/src/containers/TracePanel/execution-graph.d.ts +97 -0
- package/dist/types/src/containers/TracePanel/execution-graph.d.ts.map +1 -0
- package/dist/types/src/containers/TracePanel/execution-graph.test.d.ts +2 -0
- package/dist/types/src/containers/TracePanel/execution-graph.test.d.ts.map +1 -0
- package/dist/types/src/containers/TracePanel/index.d.ts.map +1 -1
- package/dist/types/src/containers/TracePanel/testing/index.d.ts +3 -0
- package/dist/types/src/containers/TracePanel/testing/index.d.ts.map +1 -0
- package/dist/types/src/containers/TracePanel/testing/simulated-agent.d.ts +14 -0
- package/dist/types/src/containers/TracePanel/testing/simulated-agent.d.ts.map +1 -0
- package/dist/types/src/containers/TracePanel/testing/snapshot-playback.d.ts +12 -0
- package/dist/types/src/containers/TracePanel/testing/snapshot-playback.d.ts.map +1 -0
- package/dist/types/src/containers/TriggerStatus/TriggerStatus.d.ts +3 -2
- package/dist/types/src/containers/TriggerStatus/TriggerStatus.d.ts.map +1 -1
- package/dist/types/src/containers/TriggerStatus/index.d.ts +1 -1
- package/dist/types/src/containers/TriggerStatus/index.d.ts.map +1 -1
- package/dist/types/src/containers/index.d.ts +6 -5
- package/dist/types/src/containers/index.d.ts.map +1 -1
- package/dist/types/src/extensions/prompt-extension.d.ts.map +1 -1
- package/dist/types/src/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 +4 -4
- 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 +2 -2
- package/dist/types/src/hooks/useChatProcessor.d.ts.map +1 -1
- package/dist/types/src/hooks/useChatServices.d.ts +1 -1
- package/dist/types/src/hooks/useChatServices.d.ts.map +1 -1
- package/dist/types/src/hooks/useChatToolbarActions.d.ts.map +1 -1
- package/dist/types/src/hooks/useContextBinder.d.ts +2 -2
- package/dist/types/src/hooks/useContextBinder.d.ts.map +1 -1
- package/dist/types/src/hooks/useContextObjects.d.ts +2 -2
- package/dist/types/src/hooks/useContextObjects.d.ts.map +1 -1
- package/dist/types/src/hooks/useDebug.d.ts +10 -0
- package/dist/types/src/hooks/useDebug.d.ts.map +1 -0
- package/dist/types/src/hooks/useFilteredTypes.d.ts.map +1 -1
- package/dist/types/src/hooks/useFlush.d.ts +1 -1
- package/dist/types/src/hooks/useFlush.d.ts.map +1 -1
- package/dist/types/src/hooks/usePresets.d.ts.map +1 -1
- package/dist/types/src/hooks/useReferencesProvider.d.ts.map +1 -1
- package/dist/types/src/index.d.ts +0 -4
- package/dist/types/src/index.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.test.d.ts +2 -0
- package/dist/types/src/operations/prompt.test.d.ts.map +1 -0
- package/dist/types/src/operations/resolve-navigation-targets.d.ts +1 -1
- package/dist/types/src/operations/resolve-navigation-targets.d.ts.map +1 -1
- package/dist/types/src/operations/run-prompt-in-new-chat.d.ts +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/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/presets.d.ts +1 -1
- package/dist/types/src/processor/presets.d.ts.map +1 -1
- package/dist/types/src/processor/processor.d.ts +31 -13
- package/dist/types/src/processor/processor.d.ts.map +1 -1
- package/dist/types/src/testing/index.d.ts +1 -0
- package/dist/types/src/testing/index.d.ts.map +1 -1
- package/dist/types/src/testing/test-generator.d.ts +2 -3
- package/dist/types/src/testing/test-generator.d.ts.map +1 -1
- package/dist/types/src/testing/test-generator.test.d.ts +2 -0
- package/dist/types/src/testing/test-generator.test.d.ts.map +1 -0
- package/dist/types/src/testing/test-sequence.d.ts +3 -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.test.d.ts +2 -0
- package/dist/types/src/testing/trace-timeline.test.d.ts.map +1 -0
- package/dist/types/src/testing.d.ts +2 -0
- package/dist/types/src/testing.d.ts.map +1 -0
- package/dist/types/src/translations.d.ts +2 -503
- package/dist/types/src/translations.d.ts.map +1 -1
- package/dist/types/src/types/Assistant.d.ts +22 -6
- package/dist/types/src/types/Assistant.d.ts.map +1 -1
- package/dist/types/src/types/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} +26 -20
- package/dist/types/src/types/AssistantOperation.d.ts.map +1 -0
- package/dist/types/src/types/Settings.d.ts +22 -6
- package/dist/types/src/types/Settings.d.ts.map +1 -1
- package/dist/types/src/types/index.d.ts +3 -3
- package/dist/types/src/types/index.d.ts.map +1 -1
- package/dist/types/src/types/service.d.ts +1 -1
- package/dist/types/src/types/service.d.ts.map +1 -1
- package/dist/types/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 +163 -124
- package/src/AssistantPlugin.node.ts +44 -0
- package/src/AssistantPlugin.test.ts +35 -0
- package/src/AssistantPlugin.ts +126 -0
- package/src/blueprints/assistant/blueprint.test.ts +3 -3
- package/src/blueprints/assistant/blueprint.ts +4 -4
- package/src/capabilities/app-graph-builder.ts +32 -57
- package/src/capabilities/blueprint-definition.ts +10 -12
- package/src/capabilities/companion-chat-provisioner.ts +4 -5
- package/src/capabilities/create-object.ts +107 -0
- package/src/capabilities/index.ts +3 -1
- package/src/capabilities/local-model-resolver.ts +14 -4
- package/src/capabilities/markdown.ts +1 -1
- package/src/capabilities/migrations.ts +4 -10
- package/src/capabilities/operation-handler.ts +1 -1
- package/src/capabilities/react-surface.tsx +57 -39
- package/src/capabilities/toolkit.ts +2 -2
- package/src/components/AssistantSettings/AssistantSettings.stories.tsx +3 -2
- package/src/components/AssistantSettings/AssistantSettings.tsx +22 -111
- package/src/components/Chat/Chat.tsx +105 -279
- package/src/components/Chat/context.ts +39 -0
- package/src/components/ChatPrompt/ChatActions.tsx +10 -10
- package/src/components/ChatPrompt/ChatMcpErrors.tsx +50 -0
- package/src/components/ChatPrompt/ChatOptions.stories.tsx +136 -0
- package/src/components/ChatPrompt/ChatOptions.tsx +238 -45
- package/src/components/ChatPrompt/ChatPrompt.tsx +182 -0
- package/src/components/ChatPrompt/ChatReferences.tsx +4 -4
- package/src/components/ChatPrompt/ChatStatus.tsx +123 -0
- package/src/components/ChatPrompt/ChatStatusIndicator.tsx +1 -1
- package/src/components/ChatPrompt/index.ts +3 -0
- package/src/components/ChatThread/Anchor.stories.tsx +95 -0
- package/src/components/ChatThread/ChatThread.stories.tsx +48 -42
- package/src/components/ChatThread/ChatThread.tsx +36 -21
- package/src/components/ChatThread/DEBUG.md +41 -0
- package/src/components/ChatThread/MarkdownStream.stories.tsx +281 -0
- package/src/components/ChatThread/registry.tsx +106 -24
- package/src/components/ChatThread/sync.test.ts +179 -21
- package/src/components/ChatThread/sync.ts +89 -87
- package/src/components/ChatThread/testing/reasoning.md +25 -0
- package/src/components/ChatThread/testing/thinking.md +21 -0
- package/src/components/ChatThread/testing/thread-1.md +13 -0
- package/src/components/ChatThread/testing/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 +5 -3
- package/src/components/ChatThread/widgets/ReasoningWidget.stories.tsx +68 -0
- package/src/components/ChatThread/widgets/ReasoningWidget.ts +19 -6
- package/src/components/ChatThread/widgets/ReferenceWidget.ts +3 -1
- package/src/components/ChatThread/widgets/SelectWidget.ts +3 -1
- package/src/components/ChatThread/widgets/StatsWidget.ts +3 -1
- package/src/components/ChatThread/widgets/StatusWidget.ts +53 -0
- package/src/components/ChatThread/widgets/SuggestionWidget.ts +1 -1
- package/src/components/ChatThread/widgets/SummaryWidget.tsx +3 -4
- package/src/components/ChatThread/widgets/ToolWidget.stories.tsx +55 -0
- package/src/components/ChatThread/widgets/ToolWidget.tsx +26 -13
- package/src/components/ChatThread/widgets/defaults.ts +8 -0
- package/src/components/ChatThread/widgets/index.ts +1 -1
- package/src/components/ProcessTree/ProcessTree.stories.tsx +12 -38
- package/src/components/ProcessTree/ProcessTree.tsx +72 -38
- package/src/components/TaskList/TaskList.stories.tsx +44 -0
- package/src/components/TaskList/TaskList.tsx +45 -0
- package/src/components/{Typewriter → TaskList}/index.ts +1 -1
- package/src/components/TemplateEditor/TemplateEditor.stories.tsx +4 -3
- package/src/components/TemplateEditor/TemplateEditor.tsx +5 -5
- package/src/components/TemplateEditor/TemplateForm.stories.tsx +6 -9
- package/src/components/TemplateEditor/TemplateForm.tsx +51 -72
- package/src/components/TemplateEditor/extensions/handlebars-extension.ts +1 -1
- package/src/components/ToolBlock/ToolBlock.tsx +2 -2
- package/src/components/Toolbox/Toolbox.stories.tsx +6 -5
- package/src/components/Toolbox/Toolbox.tsx +4 -4
- package/src/components/index.ts +1 -0
- package/src/containers/AgentArticle/AgentArticle.stories.tsx +120 -0
- package/src/containers/AgentArticle/AgentArticle.tsx +204 -0
- package/src/containers/AgentArticle/index.ts +5 -0
- package/src/containers/AgentProperties/AgentProperties.stories.tsx +101 -0
- package/src/containers/AgentProperties/AgentProperties.tsx +127 -0
- package/src/containers/AgentProperties/index.ts +5 -0
- package/src/containers/BlueprintArticle/BlueprintArticle.tsx +1 -1
- package/src/containers/{ChatContainer/ChatContainer.tsx → ChatArticle/ChatArticle.tsx} +22 -10
- package/src/containers/ChatArticle/index.ts +5 -0
- package/src/containers/ChatCompanion/ChatCompanion.tsx +21 -30
- package/src/containers/ChatDialog/ChatDialog.tsx +3 -9
- 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} +14 -13
- package/src/containers/{PromptList/PromptList.tsx → RoutineList/RoutineList.tsx} +8 -7
- package/src/containers/RoutineList/index.ts +5 -0
- package/src/containers/TracePanel/TracePanel.stories.tsx +285 -0
- package/src/containers/TracePanel/TracePanel.tsx +128 -266
- package/src/containers/TracePanel/dxn-extractor.test.ts +7 -7
- package/src/containers/TracePanel/dxn-extractor.ts +11 -11
- package/src/containers/TracePanel/execution-graph.test.ts +382 -0
- package/src/containers/TracePanel/execution-graph.ts +621 -0
- package/src/containers/TracePanel/testing/index.ts +6 -0
- package/src/containers/TracePanel/testing/simulated-agent.ts +114 -0
- package/src/containers/TracePanel/testing/snapshot-playback.ts +45 -0
- package/src/containers/TriggerStatus/TriggerStatus.tsx +19 -34
- package/src/containers/TriggerStatus/index.ts +1 -1
- package/src/containers/index.ts +6 -5
- package/src/{queue-logger.ts → feed-logger.ts} +45 -24
- package/src/hooks/index.ts +2 -0
- package/src/hooks/useBlueprintRegistry.ts +13 -7
- package/src/hooks/useChatKeymap.ts +52 -0
- package/src/hooks/useChatProcessor.ts +12 -12
- package/src/hooks/useChatServices.ts +1 -1
- package/src/hooks/useChatToolbarActions.ts +86 -88
- package/src/hooks/useContextBinder.ts +4 -4
- package/src/hooks/useContextObjects.ts +2 -2
- package/src/hooks/useDebug.ts +38 -0
- package/src/index.ts +0 -5
- package/src/meta.ts +1 -1
- package/src/operations/create-chat.ts +21 -17
- package/src/operations/ensure-companion-chat.ts +49 -47
- package/src/operations/index.ts +1 -3
- package/src/operations/on-create-space.ts +4 -4
- package/src/operations/prompt.test.ts +77 -0
- package/src/operations/resolve-navigation-targets.ts +3 -3
- package/src/operations/run-prompt-in-new-chat.ts +86 -86
- package/src/operations/set-current-chat.ts +4 -5
- package/src/operations/update-chat-name.ts +4 -4
- package/src/plugin.ts +11 -0
- package/src/processor/presets.ts +11 -3
- package/src/processor/processor.test.ts +4 -4
- package/src/processor/processor.ts +54 -38
- package/src/testing/data/trace-timeline.dx.json +4657 -0
- package/src/testing/index.ts +1 -0
- package/src/testing/test-generator.test.ts +70 -0
- package/src/testing/test-generator.ts +213 -191
- package/src/testing/test-sequence.ts +3 -3
- package/src/testing/test-trace.ts +20 -0
- package/src/testing/trace-timeline.conversations.json +1 -0
- package/src/testing/trace-timeline.test.ts +250 -0
- package/src/testing.ts +7 -0
- package/src/translations.ts +74 -49
- 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} +5 -4
- package/src/types/Settings.ts +63 -8
- package/src/types/index.ts +5 -3
- package/src/types/service.ts +1 -1
- package/src/util/suggestions.test.ts +52 -0
- package/src/util/suggestions.ts +42 -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-RUV2WOQH.mjs +0 -154
- package/dist/lib/browser/chunk-RUV2WOQH.mjs.map +0 -7
- package/dist/lib/browser/create-chat-DF5TG5XC.mjs.map +0 -7
- package/dist/lib/browser/ensure-companion-chat-FR4AWZ2P.mjs.map +0 -7
- package/dist/lib/browser/index.mjs +0 -3122
- 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-4YQ37XIS.mjs.map +0 -7
- package/dist/lib/browser/set-current-chat-WJI3WAVM.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-PY4X6FJT.mjs +0 -155
- package/dist/lib/node-esm/chunk-PY4X6FJT.mjs.map +0 -7
- package/dist/lib/node-esm/create-chat-RAV7IX2S.mjs +0 -83
- package/dist/lib/node-esm/create-chat-RAV7IX2S.mjs.map +0 -7
- package/dist/lib/node-esm/ensure-companion-chat-BLP7NT32.mjs +0 -66
- package/dist/lib/node-esm/ensure-companion-chat-BLP7NT32.mjs.map +0 -7
- package/dist/lib/node-esm/index.mjs +0 -3123
- 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-2IJBSDTM.mjs +0 -137
- package/dist/lib/node-esm/run-prompt-in-new-chat-2IJBSDTM.mjs.map +0 -7
- package/dist/lib/node-esm/set-current-chat-KBMMZULR.mjs +0 -55
- package/dist/lib/node-esm/set-current-chat-KBMMZULR.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/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/ChatStream.stories.d.ts +0 -530
- package/dist/types/src/components/ChatThread/ChatStream.stories.d.ts.map +0 -1
- package/dist/types/src/components/ChatThread/widgets/PromptWidget.d.ts +0 -14
- package/dist/types/src/components/ChatThread/widgets/PromptWidget.d.ts.map +0 -1
- package/dist/types/src/components/Typewriter/AssistantToolbar.d.ts +0 -12
- package/dist/types/src/components/Typewriter/AssistantToolbar.d.ts.map +0 -1
- package/dist/types/src/components/Typewriter/Typewriter.d.ts +0 -11
- package/dist/types/src/components/Typewriter/Typewriter.d.ts.map +0 -1
- package/dist/types/src/components/Typewriter/Typewriter.stories.d.ts +0 -7
- package/dist/types/src/components/Typewriter/Typewriter.stories.d.ts.map +0 -1
- package/dist/types/src/components/Typewriter/assistant-extension.d.ts +0 -5
- package/dist/types/src/components/Typewriter/assistant-extension.d.ts.map +0 -1
- package/dist/types/src/components/Typewriter/index.d.ts +0 -2
- package/dist/types/src/components/Typewriter/index.d.ts.map +0 -1
- package/dist/types/src/containers/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/ProjectArticle/ProjectArticle.d.ts +0 -6
- package/dist/types/src/containers/ProjectArticle/ProjectArticle.d.ts.map +0 -1
- package/dist/types/src/containers/ProjectArticle/index.d.ts +0 -2
- package/dist/types/src/containers/ProjectSettings/ProjectSettings.d.ts +0 -6
- package/dist/types/src/containers/ProjectSettings/ProjectSettings.d.ts.map +0 -1
- package/dist/types/src/containers/ProjectSettings/index.d.ts +0 -2
- package/dist/types/src/containers/PromptArticle/PromptArticle.d.ts +0 -6
- package/dist/types/src/containers/PromptArticle/PromptArticle.d.ts.map +0 -1
- package/dist/types/src/containers/PromptArticle/index.d.ts +0 -2
- package/dist/types/src/containers/PromptArticle/index.d.ts.map +0 -1
- package/dist/types/src/containers/PromptList/PromptList.d.ts +0 -6
- package/dist/types/src/containers/PromptList/PromptList.d.ts.map +0 -1
- package/dist/types/src/containers/PromptList/PromptList.stories.d.ts +0 -523
- 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/operations/definitions.d.ts.map +0 -1
- package/dist/types/src/queue-logger.d.ts +0 -11
- package/dist/types/src/queue-logger.d.ts.map +0 -1
- package/dist/types/src/types/capabilities.d.ts +0 -44
- 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 -235
- package/src/blueprints/assistant/blueprint.conversations.json +0 -1
- package/src/components/ChatProgress/ChatProgress.tsx +0 -56
- package/src/components/ChatProgress/index.ts +0 -5
- package/src/components/ChatThread/ChatStream.stories.tsx +0 -168
- package/src/components/ChatThread/widgets/PromptWidget.ts +0 -28
- package/src/components/Typewriter/AssistantToolbar.tsx +0 -161
- package/src/components/Typewriter/Typewriter.stories.tsx +0 -86
- package/src/components/Typewriter/Typewriter.tsx +0 -50
- package/src/components/Typewriter/assistant-extension.tsx +0 -141
- package/src/containers/ChatContainer/index.ts +0 -5
- package/src/containers/ProjectArticle/ProjectArticle.tsx +0 -131
- package/src/containers/ProjectArticle/index.ts +0 -5
- package/src/containers/ProjectSettings/ProjectSettings.tsx +0 -139
- package/src/containers/ProjectSettings/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/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-WVAFZPVI.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
|
@@ -5,301 +5,163 @@
|
|
|
5
5
|
import { Atom } from '@effect-atom/atom';
|
|
6
6
|
import { useAtomValue } from '@effect-atom/atom-react';
|
|
7
7
|
import { pipe } from 'effect/Function';
|
|
8
|
-
import React, { useCallback, useMemo } from 'react';
|
|
8
|
+
import React, { useCallback, useMemo, useState } from 'react';
|
|
9
9
|
|
|
10
10
|
import { useOperationInvoker } from '@dxos/app-framework/ui';
|
|
11
11
|
import { LayoutOperation } from '@dxos/app-toolkit';
|
|
12
|
-
import {
|
|
12
|
+
import { type AppSurface } from '@dxos/app-toolkit/ui';
|
|
13
|
+
import { Trace } from '@dxos/compute';
|
|
13
14
|
import { Filter, Query } from '@dxos/echo';
|
|
14
15
|
import { AtomQuery } from '@dxos/echo-atom';
|
|
15
|
-
import { Trace } from '@dxos/functions';
|
|
16
16
|
import { FeedTraceSink, Process } from '@dxos/functions-runtime';
|
|
17
|
-
import { DXN
|
|
18
|
-
import {
|
|
17
|
+
import { DXN } from '@dxos/keys';
|
|
18
|
+
import { log } from '@dxos/log';
|
|
19
19
|
import { useComputeRuntimeService } from '@dxos/plugin-automation/hooks';
|
|
20
20
|
import { type Space } from '@dxos/react-client/echo';
|
|
21
|
-
import {
|
|
21
|
+
import { ScrollContainer } from '@dxos/react-ui';
|
|
22
|
+
import { useAttentionAttributes } from '@dxos/react-ui-attention';
|
|
22
23
|
import { Timeline, type Commit } from '@dxos/react-ui-components';
|
|
23
|
-
import {
|
|
24
|
+
import { Syntax } from '@dxos/react-ui-syntax-highlighter';
|
|
25
|
+
import { composable, composableProps, mx } from '@dxos/ui-theme';
|
|
26
|
+
|
|
27
|
+
import { ProcessTree, ProcessTreeProps } from '#components';
|
|
28
|
+
|
|
29
|
+
import { buildExecutionGraph } from './execution-graph';
|
|
30
|
+
|
|
31
|
+
export type TracePanelProps = AppSurface.SpaceArticleProps<Pick<ProcessTreeProps, 'onProcessTerminate'>>;
|
|
32
|
+
|
|
33
|
+
export const TracePanel = composable<HTMLDivElement, TracePanelProps>(
|
|
34
|
+
({ space, attendableId, onProcessTerminate, ...props }, forwardedRef) => {
|
|
35
|
+
const attentionAttrs = useAttentionAttributes(attendableId);
|
|
36
|
+
const { invokePromise } = useOperationInvoker();
|
|
37
|
+
const { branches, commits } = useExecutionGraph(space);
|
|
38
|
+
const runtime = useComputeRuntimeService(Process.ProcessMonitorService, space.id);
|
|
39
|
+
const processes = useAtomValue(runtime?.processTreeAtom ?? atomEmpty);
|
|
40
|
+
|
|
41
|
+
const [selectedCommit, setSelectedCommit] = useState<Commit | undefined>();
|
|
42
|
+
const handleCommitSelect = useCallback(
|
|
43
|
+
(commit: Commit | undefined) => {
|
|
44
|
+
setSelectedCommit(commit);
|
|
45
|
+
if (commit?.link) {
|
|
46
|
+
const dxn = DXN.tryParse(commit.link)?.asEchoDXN();
|
|
47
|
+
if (dxn?.spaceId && dxn.echoId) {
|
|
48
|
+
// TODO(dmaretskyi): Navigates, but fails to open.
|
|
49
|
+
void invokePromise(LayoutOperation.Open, {
|
|
50
|
+
subject: [`${dxn.spaceId}:${dxn.echoId}`],
|
|
51
|
+
});
|
|
52
|
+
}
|
|
53
|
+
}
|
|
54
|
+
},
|
|
55
|
+
[invokePromise, setSelectedCommit],
|
|
56
|
+
);
|
|
57
|
+
|
|
58
|
+
// Select current branch.
|
|
59
|
+
const [currentBranch, setCurrentBranch] = useState<string | null>(null);
|
|
60
|
+
const handleProcessSelect = useCallback(
|
|
61
|
+
(process: Process.Info) => {
|
|
62
|
+
const branch = branches.find((branch) => branch === process.pid.toString());
|
|
63
|
+
if (branch) {
|
|
64
|
+
setCurrentBranch(branch);
|
|
65
|
+
}
|
|
66
|
+
},
|
|
67
|
+
[branches],
|
|
68
|
+
);
|
|
69
|
+
|
|
70
|
+
return (
|
|
71
|
+
<div
|
|
72
|
+
{...composableProps(props, {
|
|
73
|
+
...attentionAttrs,
|
|
74
|
+
classNames: mx(
|
|
75
|
+
'h-full grid divide-y divide-separator',
|
|
76
|
+
selectedCommit ? 'grid-rows-[minmax(0,4lh)_1fr_minmax(0,206px)]' : 'grid-rows-[minmax(0,4lh)_1fr]',
|
|
77
|
+
),
|
|
78
|
+
})}
|
|
79
|
+
ref={forwardedRef}
|
|
80
|
+
>
|
|
81
|
+
<ProcessTree
|
|
82
|
+
processes={processes}
|
|
83
|
+
onProcessSelect={handleProcessSelect}
|
|
84
|
+
onProcessTerminate={onProcessTerminate}
|
|
85
|
+
/>
|
|
24
86
|
|
|
25
|
-
|
|
87
|
+
<ScrollContainer.Root pin>
|
|
88
|
+
<ScrollContainer.Content thin>
|
|
89
|
+
<ScrollContainer.Fade />
|
|
90
|
+
<ScrollContainer.Viewport>
|
|
91
|
+
<Timeline
|
|
92
|
+
compact
|
|
93
|
+
commits={commits}
|
|
94
|
+
branches={branches}
|
|
95
|
+
currentBranch={currentBranch}
|
|
96
|
+
onSelect={handleCommitSelect}
|
|
97
|
+
/>
|
|
98
|
+
</ScrollContainer.Viewport>
|
|
99
|
+
<ScrollContainer.ScrollDownButton />
|
|
100
|
+
</ScrollContainer.Content>
|
|
101
|
+
</ScrollContainer.Root>
|
|
102
|
+
|
|
103
|
+
{selectedCommit && (
|
|
104
|
+
<Syntax.Root data={selectedCommit}>
|
|
105
|
+
<Syntax.Content>
|
|
106
|
+
<Syntax.Viewport>
|
|
107
|
+
<Syntax.Code className='text-xs' />
|
|
108
|
+
</Syntax.Viewport>
|
|
109
|
+
</Syntax.Content>
|
|
110
|
+
</Syntax.Root>
|
|
111
|
+
)}
|
|
112
|
+
</div>
|
|
113
|
+
);
|
|
114
|
+
},
|
|
115
|
+
);
|
|
26
116
|
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
const activeProcesses = useActiveProcesses(space.id);
|
|
30
|
-
const runtime = useComputeRuntimeService(Process.ProcessMonitorService, space.id);
|
|
117
|
+
// Stable ref.
|
|
118
|
+
const atomEmpty = Atom.make(() => [] as const);
|
|
31
119
|
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
),
|
|
37
|
-
);
|
|
120
|
+
type ExecutionGraph = {
|
|
121
|
+
branches: string[];
|
|
122
|
+
commits: Commit[];
|
|
123
|
+
};
|
|
38
124
|
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
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
|
-
);
|
|
125
|
+
type UseExecutionGraphOptions = {
|
|
126
|
+
eventLimit?: number;
|
|
127
|
+
};
|
|
51
128
|
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
/>
|
|
59
|
-
<Timeline classNames='py-1' branches={branches} commits={commits} compact onCommitClick={handleCommitClick} />
|
|
60
|
-
</Panel.Content>
|
|
61
|
-
</Panel.Root>
|
|
129
|
+
const useExecutionGraph = (space: Space, { eventLimit }: UseExecutionGraphOptions = {}): ExecutionGraph => {
|
|
130
|
+
const runtime = useComputeRuntimeService(Process.ProcessMonitorService, space.id);
|
|
131
|
+
const activeProcesses = useAtomValue(runtime?.processTreeAtom ?? atomEmpty);
|
|
132
|
+
const atom = useMemo(
|
|
133
|
+
() => getExecutionGraph(space, activeProcesses, { eventLimit }),
|
|
134
|
+
[space, activeProcesses, eventLimit],
|
|
62
135
|
);
|
|
63
|
-
};
|
|
64
136
|
|
|
65
|
-
|
|
66
|
-
eventLimit: number;
|
|
137
|
+
return useAtomValue(atom);
|
|
67
138
|
};
|
|
68
139
|
|
|
69
140
|
const getExecutionGraph = (
|
|
70
141
|
space: Space,
|
|
71
|
-
|
|
72
|
-
{ eventLimit =
|
|
73
|
-
): Atom.Atom<{
|
|
74
|
-
branches: string[];
|
|
75
|
-
commits: Commit[];
|
|
76
|
-
}> => {
|
|
142
|
+
activeProcesses: readonly Process.Info[] = [],
|
|
143
|
+
{ eventLimit = 300 }: UseExecutionGraphOptions = {},
|
|
144
|
+
): Atom.Atom<ExecutionGraph> => {
|
|
77
145
|
return pipe(
|
|
78
146
|
AtomQuery.make(space.db, FeedTraceSink.query),
|
|
79
147
|
Atom.map((feeds) => {
|
|
148
|
+
log('trace panel query trace feeds', { spaceId: space.id, feedCount: feeds.length });
|
|
80
149
|
// TODO(dmaretskyi): This should be possible in a single query with properly working limit(1) and feed > feed contents traversal.
|
|
81
150
|
return AtomQuery.make(
|
|
82
151
|
space.db,
|
|
83
|
-
feeds.length > 0
|
|
152
|
+
feeds.length > 0
|
|
153
|
+
? Query.type(Trace.Message).from(feeds[0])
|
|
154
|
+
: (Query.select(Filter.nothing()) as Query.Query<never>),
|
|
84
155
|
);
|
|
85
156
|
}),
|
|
86
157
|
(_) => Atom.make((get) => get(get(_))),
|
|
87
158
|
(_) =>
|
|
88
|
-
Atom.make((get) =>
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
93
|
-
|
|
94
|
-
|
|
95
|
-
id: message.id,
|
|
96
|
-
meta: message.meta,
|
|
97
|
-
...event,
|
|
98
|
-
})),
|
|
99
|
-
);
|
|
100
|
-
|
|
101
|
-
for (const event of events) {
|
|
102
|
-
if (Trace.isOfType(CompleteBlock, event)) {
|
|
103
|
-
switch (event.data.block._tag) {
|
|
104
|
-
case 'text': {
|
|
105
|
-
if (event.data.role === 'user') {
|
|
106
|
-
builder.addUserMessage(
|
|
107
|
-
event.id,
|
|
108
|
-
event.meta.conversationId ?? 'unknown_conversation',
|
|
109
|
-
event.data.block.text,
|
|
110
|
-
event.timestamp,
|
|
111
|
-
);
|
|
112
|
-
} else {
|
|
113
|
-
builder.addAssistantMessage(
|
|
114
|
-
event.id,
|
|
115
|
-
event.meta.conversationId ?? 'unknown_conversation',
|
|
116
|
-
event.data.block.text,
|
|
117
|
-
event.timestamp,
|
|
118
|
-
);
|
|
119
|
-
}
|
|
120
|
-
break;
|
|
121
|
-
}
|
|
122
|
-
case 'toolCall': {
|
|
123
|
-
builder.addToolCall(
|
|
124
|
-
`${event.data.block.toolCallId}:call`,
|
|
125
|
-
event.meta.conversationId ?? 'unknown_conversation',
|
|
126
|
-
event.data.block.name,
|
|
127
|
-
event.timestamp,
|
|
128
|
-
);
|
|
129
|
-
break;
|
|
130
|
-
}
|
|
131
|
-
case 'toolResult': {
|
|
132
|
-
builder.addToolResult(
|
|
133
|
-
`${event.data.block.toolCallId}:result`,
|
|
134
|
-
event.meta.conversationId ?? 'unknown_conversation',
|
|
135
|
-
event.data.block.error,
|
|
136
|
-
event.timestamp,
|
|
137
|
-
);
|
|
138
|
-
break;
|
|
139
|
-
}
|
|
140
|
-
}
|
|
141
|
-
}
|
|
142
|
-
|
|
143
|
-
// Process operation trace events.
|
|
144
|
-
if (Trace.isOfType(Trace.OperationStart, event)) {
|
|
145
|
-
builder.addOperationStart(
|
|
146
|
-
`${event.id}:${event.data.key}:start`,
|
|
147
|
-
event.data.name ?? event.data.key,
|
|
148
|
-
event.timestamp,
|
|
149
|
-
);
|
|
150
|
-
}
|
|
151
|
-
if (Trace.isOfType(Trace.OperationEnd, event)) {
|
|
152
|
-
builder.addOperationEnd(
|
|
153
|
-
`${event.id}:${event.data.key}:end`,
|
|
154
|
-
event.data.name ?? event.data.key,
|
|
155
|
-
event.data.outcome,
|
|
156
|
-
event.data.error,
|
|
157
|
-
event.timestamp,
|
|
158
|
-
);
|
|
159
|
-
}
|
|
160
|
-
}
|
|
161
|
-
|
|
162
|
-
const activeProcesses = get(processTreeAtom);
|
|
163
|
-
for (const process of activeProcesses) {
|
|
164
|
-
if (
|
|
165
|
-
process.key === AGENT_PROCESS_KEY &&
|
|
166
|
-
process.params.target &&
|
|
167
|
-
(process.state === Process.State.RUNNING || process.state === Process.State.HYBERNATING)
|
|
168
|
-
) {
|
|
169
|
-
const conversationId = DXN.parse(process.params.target).asEchoDXN()?.echoId;
|
|
170
|
-
if (conversationId) {
|
|
171
|
-
builder.addRunningAgent(process.pid, conversationId, Date.now());
|
|
172
|
-
}
|
|
173
|
-
}
|
|
174
|
-
}
|
|
175
|
-
return builder.build();
|
|
176
|
-
}),
|
|
159
|
+
Atom.make((get) =>
|
|
160
|
+
buildExecutionGraph({
|
|
161
|
+
traceMessages: [...get(_)],
|
|
162
|
+
activeProcesses,
|
|
163
|
+
eventLimit,
|
|
164
|
+
}),
|
|
165
|
+
),
|
|
177
166
|
);
|
|
178
167
|
};
|
|
179
|
-
|
|
180
|
-
// Stable ref.
|
|
181
|
-
const atomEmpty = Atom.make(() => [] as const);
|
|
182
|
-
|
|
183
|
-
const useActiveProcesses = (id?: SpaceId) => {
|
|
184
|
-
const runtime = useComputeRuntimeService(Process.ProcessMonitorService, id);
|
|
185
|
-
return useAtomValue(runtime?.processTreeAtom ?? atomEmpty);
|
|
186
|
-
};
|
|
187
|
-
|
|
188
|
-
class GraphBuilder {
|
|
189
|
-
#commits: Commit[] = [];
|
|
190
|
-
#branches = new Set<string>();
|
|
191
|
-
#lastCommitByBranch = new Map<string, string>();
|
|
192
|
-
|
|
193
|
-
#addCommit(commit: Commit) {
|
|
194
|
-
this.#branches.add(commit.branch);
|
|
195
|
-
this.#commits.push(commit);
|
|
196
|
-
this.#lastCommitByBranch.set(commit.branch, commit.id);
|
|
197
|
-
}
|
|
198
|
-
|
|
199
|
-
#defaultParents(branch: string) {
|
|
200
|
-
return this.#lastCommitByBranch.get(branch) ? [this.#lastCommitByBranch.get(branch)!] : [];
|
|
201
|
-
}
|
|
202
|
-
|
|
203
|
-
build() {
|
|
204
|
-
return {
|
|
205
|
-
commits: this.#commits,
|
|
206
|
-
branches: [...this.#branches],
|
|
207
|
-
};
|
|
208
|
-
}
|
|
209
|
-
|
|
210
|
-
addUserMessage(id: string, coversationId: string, text: string, ts: number) {
|
|
211
|
-
this.#addCommit({
|
|
212
|
-
id,
|
|
213
|
-
branch: coversationId,
|
|
214
|
-
parents: this.#defaultParents(coversationId),
|
|
215
|
-
icon: 'ph--paper-plane-right--regular',
|
|
216
|
-
level: LogLevel.VERBOSE,
|
|
217
|
-
message: text.slice(0, 100),
|
|
218
|
-
timestamp: new Date(ts),
|
|
219
|
-
});
|
|
220
|
-
}
|
|
221
|
-
|
|
222
|
-
addAssistantMessage(id: string, coversationId: string, text: string, ts: number) {
|
|
223
|
-
this.#addCommit({
|
|
224
|
-
id,
|
|
225
|
-
branch: coversationId,
|
|
226
|
-
parents: this.#defaultParents(coversationId),
|
|
227
|
-
icon: 'ph--robot--regular',
|
|
228
|
-
level: LogLevel.VERBOSE,
|
|
229
|
-
message: text.slice(0, 100),
|
|
230
|
-
timestamp: new Date(ts),
|
|
231
|
-
});
|
|
232
|
-
}
|
|
233
|
-
|
|
234
|
-
addToolCall(id: string, coversationId: string, toolName: string, ts: number) {
|
|
235
|
-
this.#addCommit({
|
|
236
|
-
id,
|
|
237
|
-
branch: coversationId,
|
|
238
|
-
parents: this.#defaultParents(coversationId),
|
|
239
|
-
icon: 'ph--wrench--regular',
|
|
240
|
-
level: LogLevel.INFO,
|
|
241
|
-
message: toolName,
|
|
242
|
-
timestamp: new Date(ts),
|
|
243
|
-
});
|
|
244
|
-
}
|
|
245
|
-
|
|
246
|
-
addToolResult(id: string, coversationId: string, error: string | undefined, ts: number) {
|
|
247
|
-
this.#addCommit({
|
|
248
|
-
id,
|
|
249
|
-
branch: coversationId,
|
|
250
|
-
parents: this.#defaultParents(coversationId),
|
|
251
|
-
icon: error ? 'ph--x-circle--regular' : 'ph--check-circle--regular',
|
|
252
|
-
level: error ? LogLevel.ERROR : LogLevel.INFO,
|
|
253
|
-
message: error ? `Error: ${error}` : 'Success',
|
|
254
|
-
timestamp: new Date(ts),
|
|
255
|
-
});
|
|
256
|
-
}
|
|
257
|
-
|
|
258
|
-
addRunningAgent(pid: string, conversationId: string, ts: number) {
|
|
259
|
-
this.#addCommit({
|
|
260
|
-
id: pid,
|
|
261
|
-
branch: conversationId,
|
|
262
|
-
parents: this.#defaultParents(conversationId),
|
|
263
|
-
icon: 'ph--spinner-gap--regular',
|
|
264
|
-
level: LogLevel.INFO,
|
|
265
|
-
message: 'Generating...',
|
|
266
|
-
timestamp: new Date(ts),
|
|
267
|
-
});
|
|
268
|
-
}
|
|
269
|
-
|
|
270
|
-
addOperationStart(id: string, operationName: string, ts: number) {
|
|
271
|
-
this.#addCommit({
|
|
272
|
-
id,
|
|
273
|
-
branch: OPERATIONS_BRANCH,
|
|
274
|
-
parents: this.#defaultParents(OPERATIONS_BRANCH),
|
|
275
|
-
icon: 'ph--play--regular',
|
|
276
|
-
level: LogLevel.INFO,
|
|
277
|
-
message: operationName,
|
|
278
|
-
timestamp: new Date(ts),
|
|
279
|
-
});
|
|
280
|
-
}
|
|
281
|
-
|
|
282
|
-
addOperationEnd(
|
|
283
|
-
id: string,
|
|
284
|
-
operationName: string,
|
|
285
|
-
outcome: 'success' | 'failure',
|
|
286
|
-
error: string | undefined,
|
|
287
|
-
ts: number,
|
|
288
|
-
) {
|
|
289
|
-
const isError = outcome === 'failure';
|
|
290
|
-
this.#addCommit({
|
|
291
|
-
id,
|
|
292
|
-
branch: OPERATIONS_BRANCH,
|
|
293
|
-
parents: this.#defaultParents(OPERATIONS_BRANCH),
|
|
294
|
-
icon: isError ? 'ph--x-circle--regular' : 'ph--check-circle--regular',
|
|
295
|
-
level: isError ? LogLevel.ERROR : LogLevel.INFO,
|
|
296
|
-
message: isError ? `${operationName}: ${error ?? 'Failed'}` : operationName,
|
|
297
|
-
timestamp: new Date(ts),
|
|
298
|
-
});
|
|
299
|
-
}
|
|
300
|
-
}
|
|
301
|
-
|
|
302
|
-
/**
|
|
303
|
-
* Branch name for top-level operation invocations.
|
|
304
|
-
*/
|
|
305
|
-
const OPERATIONS_BRANCH = 'operations';
|
|
@@ -6,41 +6,41 @@ import { describe, test } from 'vitest';
|
|
|
6
6
|
|
|
7
7
|
import {
|
|
8
8
|
extractDxnsFromObject,
|
|
9
|
-
|
|
9
|
+
extractDxnFromString,
|
|
10
10
|
extractFirstDxnFromToolInput,
|
|
11
11
|
extractFirstDxnFromToolResult,
|
|
12
12
|
} from './dxn-extractor';
|
|
13
13
|
|
|
14
14
|
describe('dxn-extractor', () => {
|
|
15
|
-
describe('
|
|
15
|
+
describe('extractDxnFromString', () => {
|
|
16
16
|
test('extracts plain DXN from string', ({ expect }) => {
|
|
17
|
-
const result =
|
|
17
|
+
const result = extractDxnFromString('Found object dxn:echo:@:01KG7R1ZXWFMWQ4DA1Q6TN1DG4');
|
|
18
18
|
expect(result).toHaveLength(1);
|
|
19
19
|
expect(result[0].toString()).toBe('dxn:echo:@:01KG7R1ZXWFMWQ4DA1Q6TN1DG4');
|
|
20
20
|
});
|
|
21
21
|
|
|
22
22
|
test('extracts @dxn prefixed reference from string', ({ expect }) => {
|
|
23
|
-
const result =
|
|
23
|
+
const result = extractDxnFromString('Reference to @dxn:echo:@:01KG7R1ZXWFMWQ4DA1Q6TN1DG4 in text');
|
|
24
24
|
expect(result).toHaveLength(1);
|
|
25
25
|
expect(result[0].toString()).toBe('dxn:echo:@:01KG7R1ZXWFMWQ4DA1Q6TN1DG4');
|
|
26
26
|
});
|
|
27
27
|
|
|
28
28
|
test('extracts multiple DXNs from string', ({ expect }) => {
|
|
29
|
-
const result =
|
|
29
|
+
const result = extractDxnFromString(
|
|
30
30
|
'Objects: dxn:echo:@:01KG7R1ZXWFMWQ4DA1Q6TN1DG4 and @dxn:queue:data:SPACE:QUEUE:01KG7R1ZXWFMWQ4DA1Q6TN1DG5',
|
|
31
31
|
);
|
|
32
32
|
expect(result).toHaveLength(2);
|
|
33
33
|
});
|
|
34
34
|
|
|
35
35
|
test('deduplicates DXNs', ({ expect }) => {
|
|
36
|
-
const result =
|
|
36
|
+
const result = extractDxnFromString(
|
|
37
37
|
'Same object dxn:echo:@:01KG7R1ZXWFMWQ4DA1Q6TN1DG4 and dxn:echo:@:01KG7R1ZXWFMWQ4DA1Q6TN1DG4',
|
|
38
38
|
);
|
|
39
39
|
expect(result).toHaveLength(1);
|
|
40
40
|
});
|
|
41
41
|
|
|
42
42
|
test('returns empty array for string without DXNs', ({ expect }) => {
|
|
43
|
-
const result =
|
|
43
|
+
const result = extractDxnFromString('No DXNs here');
|
|
44
44
|
expect(result).toHaveLength(0);
|
|
45
45
|
});
|
|
46
46
|
});
|
|
@@ -28,7 +28,7 @@ const AT_DXN_PATTERN = /@(dxn:[a-zA-Z0-9]+(?::[a-zA-Z0-9@_-]+)+)/g;
|
|
|
28
28
|
/**
|
|
29
29
|
* Extracts all DXN references from a string.
|
|
30
30
|
*/
|
|
31
|
-
export const
|
|
31
|
+
export const extractDxnFromString = (text: string): DXN[] => {
|
|
32
32
|
const dxns: DXN[] = [];
|
|
33
33
|
const seen = new Set<string>();
|
|
34
34
|
|
|
@@ -68,7 +68,7 @@ export const extractDxnsFromObject = (obj: unknown): DXN[] => {
|
|
|
68
68
|
const dxns: DXN[] = [];
|
|
69
69
|
const seen = new Set<string>();
|
|
70
70
|
|
|
71
|
-
const
|
|
71
|
+
const addDXN = (dxnStr: string) => {
|
|
72
72
|
if (!seen.has(dxnStr)) {
|
|
73
73
|
const dxn = DXN.tryParse(dxnStr);
|
|
74
74
|
if (dxn) {
|
|
@@ -86,14 +86,14 @@ export const extractDxnsFromObject = (obj: unknown): DXN[] => {
|
|
|
86
86
|
if (typeof value === 'string') {
|
|
87
87
|
// Check if the string itself is a DXN.
|
|
88
88
|
if (value.startsWith('dxn:')) {
|
|
89
|
-
|
|
89
|
+
addDXN(value);
|
|
90
90
|
} else if (value.startsWith('@dxn:')) {
|
|
91
|
-
|
|
91
|
+
addDXN(value.slice(1));
|
|
92
92
|
}
|
|
93
93
|
// Also extract DXNs from within the string.
|
|
94
|
-
const extracted =
|
|
94
|
+
const extracted = extractDxnFromString(value);
|
|
95
95
|
for (const dxn of extracted) {
|
|
96
|
-
|
|
96
|
+
addDXN(dxn.toString());
|
|
97
97
|
}
|
|
98
98
|
return;
|
|
99
99
|
}
|
|
@@ -112,7 +112,7 @@ export const extractDxnsFromObject = (obj: unknown): DXN[] => {
|
|
|
112
112
|
if ('/' in record && typeof record['/'] === 'string') {
|
|
113
113
|
const dxnStr = record['/'];
|
|
114
114
|
if (typeof dxnStr === 'string' && dxnStr.startsWith('dxn:')) {
|
|
115
|
-
|
|
115
|
+
addDXN(dxnStr);
|
|
116
116
|
}
|
|
117
117
|
}
|
|
118
118
|
|
|
@@ -120,7 +120,7 @@ export const extractDxnsFromObject = (obj: unknown): DXN[] => {
|
|
|
120
120
|
if ('@dxn' in record && typeof record['@dxn'] === 'string') {
|
|
121
121
|
const dxnStr = record['@dxn'];
|
|
122
122
|
if (typeof dxnStr === 'string' && dxnStr.startsWith('dxn:')) {
|
|
123
|
-
|
|
123
|
+
addDXN(dxnStr);
|
|
124
124
|
}
|
|
125
125
|
}
|
|
126
126
|
|
|
@@ -128,7 +128,7 @@ export const extractDxnsFromObject = (obj: unknown): DXN[] => {
|
|
|
128
128
|
if (record._tag === 'reference' && record.reference && typeof record.reference === 'object') {
|
|
129
129
|
const ref = record.reference as Record<string, unknown>;
|
|
130
130
|
if (ref.dxn && typeof ref.dxn === 'string') {
|
|
131
|
-
|
|
131
|
+
addDXN(ref.dxn);
|
|
132
132
|
}
|
|
133
133
|
}
|
|
134
134
|
|
|
@@ -153,7 +153,7 @@ export const extractFirstDxnFromToolInput = (input: string): DXN | undefined =>
|
|
|
153
153
|
return dxns[0];
|
|
154
154
|
} catch {
|
|
155
155
|
// If JSON parsing fails, try to extract from the raw string.
|
|
156
|
-
const dxns =
|
|
156
|
+
const dxns = extractDxnFromString(input);
|
|
157
157
|
return dxns[0];
|
|
158
158
|
}
|
|
159
159
|
};
|
|
@@ -172,7 +172,7 @@ export const extractFirstDxnFromToolResult = (result: string | undefined): DXN |
|
|
|
172
172
|
return dxns[0];
|
|
173
173
|
} catch {
|
|
174
174
|
// If JSON parsing fails, try to extract from the raw string.
|
|
175
|
-
const dxns =
|
|
175
|
+
const dxns = extractDxnFromString(result);
|
|
176
176
|
return dxns[0];
|
|
177
177
|
}
|
|
178
178
|
};
|